✨ MAJOR FEATURES: • Auto-zoom intelligence với smart bounds fitting • Enhanced 3D GPS markers với pulsing effects • Professional route display với 6-layer rendering • Status-based parking icons với availability indicators • Production-ready build optimizations 🗺️ AUTO-ZOOM FEATURES: • Smart bounds fitting cho GPS + selected parking • Adaptive padding (50px) cho visual balance • Max zoom control (level 16) để tránh quá gần • Dynamic centering khi không có selection 🎨 ENHANCED VISUALS: • 3D GPS marker với multi-layer pulse effects • Advanced parking icons với status colors • Selection highlighting với animation • Dimming system cho non-selected items 🛣️ ROUTE SYSTEM: • OpenRouteService API integration • Multi-layer route rendering (glow, shadow, main, animated) • Real-time distance & duration calculation • Visual route info trong popup 📱 PRODUCTION READY: • SSR safe với dynamic imports • Build errors resolved • Global deployment via Vercel • Optimized performance 🌍 DEPLOYMENT: • Vercel: https://whatever-ctk2auuxr-phong12hexdockworks-projects.vercel.app • Bundle size: 22.8 kB optimized • Global CDN distribution • HTTPS enabled 💾 VERSION CONTROL: • MapView-v2.0.tsx backup created • MAPVIEW_VERSIONS.md documentation • Full version history tracking
118 lines
3.6 KiB
TypeScript
118 lines
3.6 KiB
TypeScript
import { INestApplication, HttpServer } from '@nestjs/common';
|
|
import type { Server as CoreHttpServer } from 'http';
|
|
import type { Server as CoreHttpsServer } from 'https';
|
|
import type { Express } from 'express';
|
|
import { NestExpressBodyParserOptions } from './nest-express-body-parser-options.interface';
|
|
import { NestExpressBodyParserType } from './nest-express-body-parser.interface';
|
|
import { ServeStaticOptions } from './serve-static-options.interface';
|
|
/**
|
|
* Interface describing methods on NestExpressApplication.
|
|
*
|
|
* @see [Platform](https://docs.nestjs.com/first-steps#platform)
|
|
*
|
|
* @publicApi
|
|
*/
|
|
export interface NestExpressApplication<TServer extends CoreHttpServer | CoreHttpsServer = CoreHttpServer> extends INestApplication<TServer> {
|
|
/**
|
|
* Returns the underlying HTTP adapter bounded to the Express.js app.
|
|
*
|
|
* @returns {HttpServer}
|
|
*/
|
|
getHttpAdapter(): HttpServer<Express.Request, Express.Response, Express>;
|
|
/**
|
|
* Starts the application.
|
|
*
|
|
* @param {number|string} port
|
|
* @param {string} [hostname]
|
|
* @param {Function} [callback] Optional callback
|
|
* @returns {Promise} A Promise that, when resolved, is a reference to the underlying HttpServer.
|
|
*/
|
|
listen(port: number | string, callback?: () => void): Promise<TServer>;
|
|
listen(port: number | string, hostname: string, callback?: () => void): Promise<TServer>;
|
|
/**
|
|
* A wrapper function around native `express.set()` method.
|
|
*
|
|
* @example
|
|
* app.set('trust proxy', 'loopback')
|
|
*
|
|
* @returns {this}
|
|
*/
|
|
set(...args: any[]): this;
|
|
/**
|
|
* A wrapper function around native `express.engine()` method.
|
|
* @example
|
|
* app.engine('mustache', mustacheExpress())
|
|
*
|
|
* @returns {this}
|
|
*/
|
|
engine(...args: any[]): this;
|
|
/**
|
|
* A wrapper function around native `express.enable()` method.
|
|
* @example
|
|
* app.enable('x-powered-by')
|
|
*
|
|
* @returns {this}
|
|
*/
|
|
enable(...args: any[]): this;
|
|
/**
|
|
* A wrapper function around native `express.disable()` method.
|
|
*
|
|
* @example
|
|
* app.disable('x-powered-by')
|
|
*
|
|
* @returns {this}
|
|
*/
|
|
disable(...args: any[]): this;
|
|
useStaticAssets(options: ServeStaticOptions): this;
|
|
/**
|
|
* Sets a base directory for public assets.
|
|
* @example
|
|
* app.useStaticAssets('public')
|
|
*
|
|
* @returns {this}
|
|
*/
|
|
useStaticAssets(path: string, options?: ServeStaticOptions): this;
|
|
/**
|
|
* Register Express body parsers on the fly. Will respect
|
|
* the application's `rawBody` option.
|
|
*
|
|
* @example
|
|
* const app = await NestFactory.create<NestExpressApplication>(
|
|
* AppModule,
|
|
* { rawBody: true }
|
|
* );
|
|
* app.useBodyParser('json', { limit: '50mb' });
|
|
*
|
|
* @returns {this}
|
|
*/
|
|
useBodyParser<Options = NestExpressBodyParserOptions>(parser: NestExpressBodyParserType, options?: Omit<Options, 'verify'>): this;
|
|
/**
|
|
* Sets one or multiple base directories for templates (views).
|
|
*
|
|
* @example
|
|
* app.setBaseViewsDir('views')
|
|
*
|
|
* @returns {this}
|
|
*/
|
|
setBaseViewsDir(path: string | string[]): this;
|
|
/**
|
|
* Sets a view engine for templates (views).
|
|
* @example
|
|
* app.setViewEngine('pug')
|
|
*
|
|
* @returns {this}
|
|
*/
|
|
setViewEngine(engine: string): this;
|
|
/**
|
|
* Sets app-level globals for view templates.
|
|
*
|
|
* @example
|
|
* app.setLocal('title', 'My Site')
|
|
*
|
|
* @see https://expressjs.com/en/4x/api.html#app.locals
|
|
*
|
|
* @returns {this}
|
|
*/
|
|
setLocal(key: string, value: any): this;
|
|
}
|