✨ 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
81 lines
4.0 KiB
JavaScript
81 lines
4.0 KiB
JavaScript
"use strict";
|
|
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
if (k2 === undefined) k2 = k;
|
|
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
}
|
|
Object.defineProperty(o, k2, desc);
|
|
}) : (function(o, m, k, k2) {
|
|
if (k2 === undefined) k2 = k;
|
|
o[k2] = m[k];
|
|
}));
|
|
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
};
|
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
exports.registerSchema = exports.validateSync = exports.validateOrReject = exports.validate = void 0;
|
|
const MetadataStorage_1 = require("./metadata/MetadataStorage");
|
|
const Validator_1 = require("./validation/Validator");
|
|
const container_1 = require("./container");
|
|
// -------------------------------------------------------------------------
|
|
// Export everything api users needs
|
|
// -------------------------------------------------------------------------
|
|
__exportStar(require("./container"), exports);
|
|
__exportStar(require("./decorator/decorators"), exports);
|
|
__exportStar(require("./decorator/ValidationOptions"), exports);
|
|
__exportStar(require("./validation/ValidatorConstraintInterface"), exports);
|
|
__exportStar(require("./validation/ValidationError"), exports);
|
|
__exportStar(require("./validation/ValidatorOptions"), exports);
|
|
__exportStar(require("./validation/ValidationArguments"), exports);
|
|
__exportStar(require("./validation/ValidationTypes"), exports);
|
|
__exportStar(require("./validation/Validator"), exports);
|
|
__exportStar(require("./validation-schema/ValidationSchema"), exports);
|
|
__exportStar(require("./register-decorator"), exports);
|
|
__exportStar(require("./metadata/MetadataStorage"), exports);
|
|
/**
|
|
* Validates given object by object's decorators or given validation schema.
|
|
*/
|
|
function validate(schemaNameOrObject, objectOrValidationOptions, maybeValidatorOptions) {
|
|
if (typeof schemaNameOrObject === 'string') {
|
|
return (0, container_1.getFromContainer)(Validator_1.Validator).validate(schemaNameOrObject, objectOrValidationOptions, maybeValidatorOptions);
|
|
}
|
|
else {
|
|
return (0, container_1.getFromContainer)(Validator_1.Validator).validate(schemaNameOrObject, objectOrValidationOptions);
|
|
}
|
|
}
|
|
exports.validate = validate;
|
|
/**
|
|
* Validates given object by object's decorators or given validation schema and reject on error.
|
|
*/
|
|
function validateOrReject(schemaNameOrObject, objectOrValidationOptions, maybeValidatorOptions) {
|
|
if (typeof schemaNameOrObject === 'string') {
|
|
return (0, container_1.getFromContainer)(Validator_1.Validator).validateOrReject(schemaNameOrObject, objectOrValidationOptions, maybeValidatorOptions);
|
|
}
|
|
else {
|
|
return (0, container_1.getFromContainer)(Validator_1.Validator).validateOrReject(schemaNameOrObject, objectOrValidationOptions);
|
|
}
|
|
}
|
|
exports.validateOrReject = validateOrReject;
|
|
/**
|
|
* Validates given object by object's decorators or given validation schema.
|
|
* Note that this method completely ignores async validations.
|
|
* If you want to properly perform validation you need to call validate method instead.
|
|
*/
|
|
function validateSync(schemaNameOrObject, objectOrValidationOptions, maybeValidatorOptions) {
|
|
if (typeof schemaNameOrObject === 'string') {
|
|
return (0, container_1.getFromContainer)(Validator_1.Validator).validateSync(schemaNameOrObject, objectOrValidationOptions, maybeValidatorOptions);
|
|
}
|
|
else {
|
|
return (0, container_1.getFromContainer)(Validator_1.Validator).validateSync(schemaNameOrObject, objectOrValidationOptions);
|
|
}
|
|
}
|
|
exports.validateSync = validateSync;
|
|
/**
|
|
* Registers a new validation schema.
|
|
*/
|
|
function registerSchema(schema) {
|
|
(0, MetadataStorage_1.getMetadataStorage)().addValidationSchema(schema);
|
|
}
|
|
exports.registerSchema = registerSchema;
|
|
//# sourceMappingURL=index.js.map
|