✨ 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
114 lines
5.2 KiB
JavaScript
114 lines
5.2 KiB
JavaScript
"use strict";
|
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
exports.AddAction = void 0;
|
|
const chalk = require("chalk");
|
|
const get_value_or_default_1 = require("../lib/compiler/helpers/get-value-or-default");
|
|
const package_managers_1 = require("../lib/package-managers");
|
|
const schematics_1 = require("../lib/schematics");
|
|
const ui_1 = require("../lib/ui");
|
|
const load_configuration_1 = require("../lib/utils/load-configuration");
|
|
const project_utils_1 = require("../lib/utils/project-utils");
|
|
const abstract_action_1 = require("./abstract.action");
|
|
const schematicName = 'nest-add';
|
|
class AddAction extends abstract_action_1.AbstractAction {
|
|
async handle(inputs, options, extraFlags) {
|
|
const libraryName = this.getLibraryName(inputs);
|
|
const packageName = this.getPackageName(libraryName);
|
|
const collectionName = this.getCollectionName(libraryName, packageName);
|
|
const tagName = this.getTagName(packageName);
|
|
const skipInstall = (0, project_utils_1.hasValidOptionFlag)('skip-install', options);
|
|
const packageInstallSuccess = skipInstall || (await this.installPackage(collectionName, tagName));
|
|
if (packageInstallSuccess) {
|
|
const sourceRootOption = await this.getSourceRoot(inputs.concat(options));
|
|
options.push(sourceRootOption);
|
|
await this.addLibrary(collectionName, options, extraFlags);
|
|
}
|
|
else {
|
|
console.error(chalk.red(ui_1.MESSAGES.LIBRARY_INSTALLATION_FAILED_BAD_PACKAGE(libraryName)));
|
|
throw new Error(ui_1.MESSAGES.LIBRARY_INSTALLATION_FAILED_BAD_PACKAGE(libraryName));
|
|
}
|
|
}
|
|
async getSourceRoot(inputs) {
|
|
const configuration = await (0, load_configuration_1.loadConfiguration)();
|
|
const configurationProjects = configuration.projects;
|
|
const appName = inputs.find((option) => option.name === 'project')
|
|
.value;
|
|
let sourceRoot = appName
|
|
? (0, get_value_or_default_1.getValueOrDefault)(configuration, 'sourceRoot', appName)
|
|
: configuration.sourceRoot;
|
|
const shouldAsk = (0, project_utils_1.shouldAskForProject)(schematicName, configurationProjects, appName);
|
|
if (shouldAsk) {
|
|
const defaultLabel = ' [ Default ]';
|
|
let defaultProjectName = configuration.sourceRoot + defaultLabel;
|
|
for (const property in configurationProjects) {
|
|
if (configurationProjects[property].sourceRoot ===
|
|
configuration.sourceRoot) {
|
|
defaultProjectName = property + defaultLabel;
|
|
break;
|
|
}
|
|
}
|
|
const projects = (0, project_utils_1.moveDefaultProjectToStart)(configuration, defaultProjectName, defaultLabel);
|
|
const answers = await (0, project_utils_1.askForProjectName)(ui_1.MESSAGES.LIBRARY_PROJECT_SELECTION_QUESTION, projects);
|
|
const project = answers.appName.replace(defaultLabel, '');
|
|
if (project !== configuration.sourceRoot) {
|
|
sourceRoot = configurationProjects[project].sourceRoot;
|
|
}
|
|
}
|
|
return { name: 'sourceRoot', value: sourceRoot };
|
|
}
|
|
async installPackage(collectionName, tagName) {
|
|
const manager = await package_managers_1.PackageManagerFactory.find();
|
|
tagName = tagName || 'latest';
|
|
let installResult = false;
|
|
try {
|
|
installResult = await manager.addProduction([collectionName], tagName);
|
|
}
|
|
catch (error) {
|
|
if (error && error.message) {
|
|
console.error(chalk.red(error.message));
|
|
}
|
|
}
|
|
return installResult;
|
|
}
|
|
async addLibrary(collectionName, options, extraFlags) {
|
|
console.info(ui_1.MESSAGES.LIBRARY_INSTALLATION_STARTS);
|
|
const schematicOptions = [];
|
|
schematicOptions.push(new schematics_1.SchematicOption('sourceRoot', options.find((option) => option.name === 'sourceRoot').value));
|
|
const extraFlagsString = extraFlags ? extraFlags.join(' ') : undefined;
|
|
try {
|
|
const collection = schematics_1.CollectionFactory.create(collectionName);
|
|
await collection.execute(schematicName, schematicOptions, extraFlagsString);
|
|
}
|
|
catch (error) {
|
|
if (error && error.message) {
|
|
console.error(chalk.red(error.message));
|
|
return Promise.reject();
|
|
}
|
|
}
|
|
}
|
|
getLibraryName(inputs) {
|
|
const libraryInput = inputs.find((input) => input.name === 'library');
|
|
if (!libraryInput) {
|
|
throw new Error('No library found in command input');
|
|
}
|
|
return libraryInput.value;
|
|
}
|
|
getPackageName(library) {
|
|
return library.startsWith('@')
|
|
? library.split('/', 2).join('/')
|
|
: library.split('/', 1)[0];
|
|
}
|
|
getCollectionName(library, packageName) {
|
|
return ((packageName.startsWith('@')
|
|
? packageName.split('@', 2).join('@')
|
|
: packageName.split('@', 1).join('@')) +
|
|
library.slice(packageName.length));
|
|
}
|
|
getTagName(packageName) {
|
|
return packageName.startsWith('@')
|
|
? packageName.split('@', 3)[2]
|
|
: packageName.split('@', 2)[1];
|
|
}
|
|
}
|
|
exports.AddAction = AddAction;
|