{
- return `${this.ecoData.bonusRange || 0} km`;
- },
- offsetX: 50,
- offsetY: 10,
- },
- },
- barLabels: {
- enabled: true,
- useSeriesColors: true,
- margin: 8,
- fontSize: '16px',
- formatter: (seriesName, opts) => {
- return `${seriesName}: ${opts.w.globals.series[opts.seriesIndex]}`;
- },
- },
- },
- },
- colors: ['#1ab7ea', '#0084ff', '#39539E'],
- labels: ['Acceleration', 'Constant', 'Free wheel'],
- responsive: [
- {
- breakpoint: 480,
- options: {
- legend: {
- show: false,
- },
- },
- },
- ],
- };
- }
- firstUpdated() {
- var _a;
- this.chart = new apexcharts_common((_a = this.shadowRoot) === null || _a === void 0 ? void 0 : _a.getElementById('chart'), this.options);
- this.chart.render();
- }
- updated(changedProperties) {
- if (changedProperties.has('ecoData')) {
- this.updateChart();
- }
- }
- updateChart() {
- if (this.chart) {
- this.chart.updateOptions({
- series: [this.ecoData.acceleration, this.ecoData.constant, this.ecoData.freeWheel],
- plotOptions: {
- radialBar: {
- dataLabels: {
- total: {
- formatter: () => {
- return `${this.ecoData.bonusRange || 0} km`;
- },
- },
- },
- },
- },
- });
- }
- }
- render() {
- return x `
`;
- }
-};
-EcoChart.styles = i$2 `
- #chart {
- display: flex;
- justify-content: center;
- position: relative;
- width: 100%;
- max-height: 350px;
- margin: 0;
- font-family: system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Oxygen, Ubuntu, Cantarell,
- 'Open Sans', 'Helvetica Neue', sans-serif !important;
- }
- .apexcharts-datalabels-group .apexcharts-text {
- font-size: 1.2rem;
- fill: var(--primary-text-color);
- }
- .apexcharts-radialbar-track > path {
- stroke: var(--divider-color);
- }
- .apexcharts-radialbar-hollow {
- fill: var(--ha-card-background, var(--card-background-color, #fff));
- }
- `;
-__decorate([
- n({ type: Object })
-], EcoChart.prototype, "ecoData", void 0);
-__decorate([
- r$1()
-], EcoChart.prototype, "chart", void 0);
-EcoChart = __decorate([
- t$1('eco-chart')
-], EcoChart);
-
-// Format timestamp to human readable format (dd.mm.yyyy - hh:mm)
-function formatTimestamp(timestamp) {
- const date = new Date(timestamp);
- const day = date.toLocaleString('en-GB', { day: '2-digit' });
- const month = date.toLocaleString('en-GB', { month: '2-digit' });
- const year = date.toLocaleString('en-GB', { year: 'numeric' });
- const hours = date.toLocaleString('en-GB', { hour: '2-digit', hour12: false });
- const minutes = date.getMinutes().toString().padStart(2, '0');
- return `${day}. ${month}. ${year} - ${hours}:${minutes}`;
-}
-function cloneDeep(obj) {
- return JSON.parse(JSON.stringify(obj));
-}
-
-const servicesCtrl = {
- auxheat: { name: 'Auxiliary heating', icon: 'mdi:radiator' },
- charge: { name: 'Charge program', icon: 'mdi:ev-station' },
- doorsLock: { name: 'Security', icon: 'mdi:key-chain' },
- engine: { name: 'Engine control', icon: 'mdi:engine' },
- preheat: { name: 'Preheat settings', icon: 'mdi:car-seat-heater' },
- sendRoute: { name: 'Send route', icon: 'mdi:map-marker-path' },
- sigPos: { name: 'Signal position', icon: 'mdi:bugle' },
- sunroof: { name: 'Sunroof', icon: 'mdi:window-open' },
- windows: { name: 'Windows', icon: 'mdi:car-door' },
-};
-const serviceData = {
- auxheatConfig: {
- service: {
- START: { command: 'auxheat_start', icon: 'mdi:radiator', label: 'Start' },
- STOP: { command: 'auxheat_stop', icon: 'mdi:radiator-off', label: 'Stop' },
- DATA_CONFIGURE: { command: 'auxheat_configure', icon: 'mdi:cog', label: 'save' },
- },
- data: {
- time_selection: 0, // Store the selected value here
- time_selection_options: {
- 0: 'No selection',
- 1: 'Time 1',
- 2: 'Time 2',
- 3: 'Time 3',
- },
- items: {
- time_1: { label: 'Time 1', value: 0 },
- time_2: { label: 'Time 2', value: 0 },
- time_3: { label: 'Time 3', value: 0 },
- },
- },
- },
- windowsConfig: {
- service: {
- OPEN: { command: 'windows_open', icon: 'mdi:arrow-up-bold', label: 'Open' },
- CLOSE: { command: 'windows_close', icon: 'mdi:arrow-down-bold', label: 'Close' },
- DATA_MOVE: { command: 'windows_move', icon: 'mdi:swap-vertical-bold', label: 'Move' },
- },
- data: {
- positions: {
- front_left: { label: 'Front left', value: 0 },
- front_right: { label: 'Front right', value: 0 },
- rear_left: { label: 'Rear left', value: 0 },
- rear_right: { label: 'Rear right', value: 0 },
- },
- },
- },
- preheatConfig: {
- service: {
- DATA_START_DEP_TIME: { command: 'preheat_start_departure_time', icon: 'mdi:cog', label: 'start time' },
- STOP_DEP_TIME: { command: 'preheat_stop_departure_time', icon: 'mdi:cog-off', label: 'stop time' },
- START: { command: 'preheat_start', icon: 'mdi:car-seat-heater', label: 'Start' },
- STOP: { command: 'preheat_stop', icon: 'mdi:car-seat', label: 'Stop' },
- },
- data: {
- time: { label: 'Departure time', value: 0 },
- },
- },
- engineConfig: {
- service: {
- START: { command: 'engine_start', icon: 'mdi:engine', label: 'Start' },
- STOP: { command: 'engine_stop', icon: 'mdi:engine-off', label: 'Stop' },
- },
- },
- batteryChargeConfig: {
- service: {
- DATA_MAX_SOC_CONFIGURE: {
- command: 'battery_max_soc_configure',
- icon: 'mdi:battery-charging-high',
- label: 'set max soc',
- },
- DATA_CHARGE_PROGRAM: { command: 'charge_program_configure', icon: 'mdi:ev-station', label: 'set program' },
- },
- data: {
- selected_program: 0, // Store the selected value here
- program_options: {
- 0: 'DEFAULT',
- 2: 'HOME',
- 3: 'WORK',
- },
- max_soc: { label: 'Max state of charge', value: 50 },
- },
- },
- sendRouteConfig: {
- service: {
- DATA_SEND_ROUTE: { command: 'send_route', icon: 'mdi:map-marker', label: 'send' },
- },
- data: {
- title: { label: 'Title', value: '' },
- latitude: { label: 'Latitude', value: 0 },
- longitude: { label: 'Longitude', value: 0 },
- city: { label: 'City', value: '' },
- postcode: { label: 'Postcode', value: '' },
- street: { label: 'Street', value: '' },
- },
- },
- sunroofConfigData: {
- service: {
- OPEN: { command: 'sunroof_open', icon: 'mdi:window-open', label: 'Open' },
- CLOSE: { command: 'sunroof_close', icon: 'mdi:window-close', label: 'Close' },
- TILT: { command: 'sunroof_tilt', icon: 'mdi:window-shutter', label: 'Tilt' },
- },
- },
-};
-
-var css_248z = i$2`:host {
- --control-icon-size: 32px;
- --control-btn-radius: 0.5;
-}
-.service-control {
- display: flex;
- flex-direction: column;
- margin-top: 1rem;
- margin-bottom: 1rem;
-}
-
-#toast {
- visibility: hidden;
- opacity: 0;
- max-height: 0;
-}
-
-#toast.show {
- visibility: visible;
- opacity: 1;
- max-height: 100px;
- animation: fade-in 0.3s ease-in-out forwards;
-}
-
-.head-row {
- display: grid;
- grid-template-columns: repeat(auto-fit, minmax(130px, 1fr));
- grid-gap: 0.5rem;
- gap: 0.5rem;
- position: relative;
-}
-
-.head-sub-row {
- display: grid;
- grid-template-columns: repeat(auto-fit, minmax(130px, 1fr));
- position: relative;
- grid-gap: 0.5rem;
- gap: 0.5rem;
-}
-
-.head-sub-row.preheat {
- grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
-}
-
-@media screen and (max-width: 768px) {
- .head-sub-row {
- grid-template-columns: repeat(auto-fit, minmax(90px, 1fr));
- }
- .head-sub-row.preheat {
- grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
- }
-}
-
-@keyframes fade-in {
- from {
- opacity: 0;
- }
- to {
- opacity: 1;
- }
-}
-
-@keyframes fade-out {
- from {
- opacity: 1;
- }
- to {
- opacity: 0;
- }
-}
-
-.hidden {
- display: none !important;
-}
-
-.fade-in {
- animation: fade-in 0.3s ease-in-out forwards;
-}
-
-.fade-out {
- animation: fade-out 0.3s ease-in-out forwards;
-}
-
-.sub-card-wrapper {
- display: flex;
- flex-direction: column;
- gap: 1rem;
- padding: 1rem 0.6rem;
- margin-top: 0.5rem;
- height: auto;
-}
-
-.control-btn-sm,
-.control-btn-rounded {
- display: flex;
- align-items: center;
- justify-content: center;
- padding: 0.5rem 1rem;
- background-color: var(--remote-control-btn-color);
- box-shadow: rgba(0, 0, 0, 0.1) 0px 0px 10px 0px;
- box-sizing: border-box;
- border-radius: 12px;
- border-radius: var(--ha-card-border-radius, 12px);
- border-width: 1px;
- border-width: var(--ha-card-border-width, 1px);
- border-style: solid;
- border-color: #e0e0e0;
- border-color: var(--ha-card-border-color, var(--divider-color, #e0e0e0));
- transition: all 0.3s ease !important;
- cursor: pointer;
- text-wrap: nowrap;
- gap: 0.5rem;
-}
-
-.control-btn-sm:hover, .control-btn-rounded:hover {
- box-shadow: inset 0 0 50px var(--primary-color) !important;
- }
-
-.control-btn-rounded {
- flex-direction: column;
-}
-
-.control-btn-rounded.active {
- background-color: rgba(var(--rgb-primary-color), 0.4);
- color: var(--primary-color);
-}
-
-.control-btn-rounded ha-icon {
- --mdc-icon-size: var(--control-icon-size);
-}
-
-.control-btn-sm {
- padding: 0.5rem !important;
- border-radius: 8px;
- text-transform: uppercase;
-}
-.control-btn-sm.reset {
- background-color: var(--disabled-text-color) !important;
- height: -moz-min-content;
- height: min-content;
- padding: 0;
- opacity: 0.5;
-}
-.sub-row {
- display: flex;
- flex-direction: column;
- gap: 0.5rem;
-}
-.items-row {
- display: inline-flex;
- width: 100%;
- height: -moz-min-content;
- height: min-content;
- flex-direction: row;
- justify-content: space-between;
- align-items: center;
- border-bottom: 1px solid var(--divider-color);
- padding-bottom: 0.5rem;
-}
-
-.items-row:last-child {
- border-bottom: none;
- padding-bottom: 0;
-}
-
-.items-control {
- display: flex;
- gap: 0.5rem;
- align-items: center;
-}
-
-.items-control input[type='number'] {
- height: 2.5rem;
- width: -moz-fit-content;
- width: fit-content;
- background-color: var(--remote-control-btn-color);
- color: var(--primary-text-color);
- border-radius: 4px;
- padding: 0 0.5rem;
- border: none;
- text-align: center;
- font-size: 1rem;
-}
-.control-btn {
- width: 1.2rem;
- height: 1.2rem;
- display: flex;
- justify-content: center;
- align-items: center;
- cursor: pointer;
-}
-
-.value {
- min-width: 2rem;
- text-align: center;
- font-size: 0.9rem;
-}
-`;
-styleInject(css_248z);
-
-window.loadCardHelpers ? window.loadCardHelpers() : undefined;
-let RemoteControl = class RemoteControl extends s {
- constructor() {
- super(...arguments);
- this.subcardType = null;
- this.serviceData = cloneDeep(serviceData);
- }
- isAnyServiceEnabled() {
- if (!this.servicesConfig)
- return false;
- return Object.values(this.servicesConfig).some((service) => service);
- }
- get auxheatConfig() {
- return this.serviceData.auxheatConfig;
- }
- get windowsConfig() {
- return this.serviceData.windowsConfig;
- }
- get preheatConfig() {
- return this.serviceData.preheatConfig;
- }
- get engineConfig() {
- return this.serviceData.engineConfig;
- }
- get chargeConfig() {
- return this.serviceData.batteryChargeConfig;
- }
- get sendRouteConfig() {
- return this.serviceData.sendRouteConfig;
- }
- get sunroofConfig() {
- return this.serviceData.sunroofConfigData;
- }
- static get styles() {
- return [css_248z, css_248z$3];
- }
- updated(changedProperties) {
- super.updated(changedProperties);
- if (changedProperties.has('darkMode')) {
- this.updateCSSVariables();
- }
- }
- updateCSSVariables() {
- if (this.darkMode) {
- this.style.setProperty('--remote-control-btn-color', '#292929');
- }
- else {
- this.style.setProperty('--remote-control-btn-color', '#eeeeee');
- }
- }
- render() {
- if (!this.isAnyServiceEnabled())
- return x `No service selected. `;
- return x `
-
-
${this._renderControlBtn()}
- ${this._renderSubCard()}
-
- ${this._renderToast()}
- `;
- }
- _renderSubCard() {
- if (!this.subcardType)
- return;
- const subCardMap = {
- doorsLock: this._renderLockControl(),
- windows: this._renderWindowsControl(),
- auxheat: this._renderAuxHeatControl(),
- charge: this._renderChargeControl(),
- engine: this._renderEngineControl(),
- preheat: this._renderPreheatControl(),
- sendRoute: this._renderSendRouteControl(),
- sunroof: this._renderSunroofControl(),
- };
- const subCard = subCardMap[this.subcardType];
- if (!subCard)
- return;
- return x `${subCard}
`;
- }
- _renderControlBtn() {
- var _a;
- const activeServices = Object.entries((_a = this.servicesConfig) !== null && _a !== void 0 ? _a : {})
- .filter(([_, isActive]) => isActive === true)
- .map(([type, _]) => type);
- const handleClick = (type) => {
- if (type === 'sigPos') {
- this.callService('sigpos_start');
- }
- else {
- this._handleSubCardClick(type);
- }
- };
- const controlBtns = activeServices.map((type) => {
- const { name, icon } = servicesCtrl[type]; // Get name and icon from servicesCtrl
- const activeClass = this.subcardType === type ? 'active' : '';
- return x `
- handleClick(type)} class="control-btn-rounded ${activeClass} click-shrink">
-
- ${name}
-
- `;
- });
- return x `${controlBtns}`;
- }
- _renderToast() {
- return x `
-
- Command sent success!
-
- `;
- }
- /* ---------------------------- TEMPLATE RENDERS ---------------------------- */
- _renderServiceBtn(serviceKey, serviceItem) {
- const { command, icon, label } = serviceItem;
- const handleClick = serviceKey.includes('DATA_')
- ? () => this.saveConfigChange(command)
- : () => this.callService(command);
- return x `
-
- ${label}
-
- `;
- }
- _renderResetBtn() {
- return x ` this.resetConfig()}>
- RESET
-
`;
- }
- /* ----------------------------- SUBCARD RENDERS ---------------------------- */
- _renderSunroofControl() {
- const { sunroofConfig } = this;
- const service = sunroofConfig.service;
- return x `
-
- ${Object.entries(service).map(([key, data]) => {
- return this._renderServiceBtn(key, data);
- })}
-
- `;
- }
- _renderSendRouteControl() {
- const { sendRouteConfig } = this;
- const data = sendRouteConfig.data;
- const sampleData = {
- data: {
- title: { label: 'Title', value: 'Brandenburger Tor' },
- latitude: { label: 'Latitude', value: 52.5163 },
- longitude: { label: 'Longitude', value: 13.3777 },
- city: { label: 'City', value: 'Berlin' },
- postcode: { label: 'Postcode', value: '10117' },
- street: { label: 'Street', value: 'Pariser Platz' },
- },
- };
- const setSampleData = () => {
- this.sendRouteConfig.data = cloneDeep(sampleData.data);
- this.requestUpdate();
- };
- const formElements = Object.entries(data).map(([key, { label, value }]) => {
- return x `
-
-
${label}
-
- this.handleSendRouteChange(key, e)}>
-
-
- `;
- });
- return x `
- ${formElements}
-
-
- ${this._renderResetBtn()}
-
- Sample
-
- ${Object.entries(sendRouteConfig.service).map(([key, data]) => {
- return this._renderServiceBtn(key, data);
- })}
-
- `;
- }
- _renderPreheatControl() {
- const { preheatConfig } = this;
- const { time } = preheatConfig.data;
- const service = preheatConfig.service;
- const preheatDepartureTimeEL = x `
-
- `;
- return x `
- ${preheatDepartureTimeEL}
- ${this._renderResetBtn()}
-
- ${Object.entries(service).map(([key, data]) => {
- return this._renderServiceBtn(key, data);
- })}
-
- `;
- }
- _renderEngineControl() {
- return x `
-
- ${Object.entries(this.engineConfig.service).map(([key, data]) => {
- return this._renderServiceBtn(key, data);
- })}
-
- `;
- }
- _renderChargeControl() {
- const { chargeConfig } = this;
- const data = chargeConfig.data;
- const selectedProgram = data.selected_program;
- const programOptions = data.program_options;
- const maxSoc = data.max_soc;
- const services = chargeConfig.service;
- const selectChargeProgram = x `
-
-
Charge Program
-
this.handleChargeProgramChange('selected_program', e)}
- >
- ${Object.entries(programOptions).map(([value, label]) => {
- return x `${label} `;
- })}
-
-
- `;
- const maxSocConfig = x `
-
-
${maxSoc.label}
-
this.handleChargeProgramChange('max_soc', e)}
- >
-
-
-
- `;
- return x `
- ${selectChargeProgram}
- ${maxSocConfig}
- ${this._renderResetBtn()}
-
- ${Object.entries(services).map(([key, data]) => {
- return this._renderServiceBtn(key, data);
- })}
-
- `;
- }
- _renderAuxHeatControl() {
- const { auxheatConfig } = this;
- const timeItems = auxheatConfig.data.items;
- const selectedTimeSelection = auxheatConfig.data.time_selection;
- const timeSelectOptions = auxheatConfig.data.time_selection_options;
- const service = auxheatConfig.service;
- const timeElements = Object.entries(timeItems).map(([item, { label, value }]) => {
- return x `
-
-
${label}
-
-
- this.handleAuxheatChange('items', item, e)}
- />
- min
-
-
-
- `;
- });
- const timeSelectEl = x `
-
-
Time Selection
-
this.handleAuxheatChange('time_selection', '', e)}
- >
- ${Object.entries(timeSelectOptions).map(([value, label]) => {
- return x `${label} `;
- })}
-
-
- `;
- const serviceBtns = Object.entries(service).map(([key, data]) => {
- return this._renderServiceBtn(key, data);
- });
- return x `
- ${timeSelectEl} ${timeElements}
- ${this._renderResetBtn()}
- ${serviceBtns}
- `;
- }
- _renderLockControl() {
- const lockState = this.hass.states[this.carLockEntity].state;
- const config = {
- locked: {
- icon: 'mdi:lock',
- stateDisplay: 'UNLOCK CAR',
- command: 'doors_unlock',
- bgColor: 'var(--state-lock-locked-color)',
- },
- unlocked: {
- icon: 'mdi:lock-open',
- stateDisplay: 'LOCK CAR',
- command: 'doors_lock',
- bgColor: 'var(--state-lock-unlocked-color)',
- },
- unlocking: {
- icon: 'mdi:lock-clock',
- stateDisplay: lockState,
- command: '',
- bgColor: 'var(--state-lock-unlocking-color)',
- },
- };
- const { icon, stateDisplay, command, bgColor } = config[lockState];
- return x `
-
-
this.callService(command)}
- >
- ${stateDisplay}
-
-
- MORE INFO
-
-
- `;
- }
- _renderWindowsControl() {
- const { windowsConfig } = this;
- const positionItems = windowsConfig.data.positions;
- const service = windowsConfig.service;
- const moveEl = Object.entries(positionItems).map(([key, { label, value }]) => {
- return x `
-
-
${label}
-
- this.handleWindowsChange(key, e)}
- >
-
-
- `;
- });
- return x `
- ${moveEl}
- ${this._renderResetBtn()}
-
-
- ${Object.entries(service).map(([key, data]) => {
- return this._renderServiceBtn(key, data);
- })}
-
- `;
- }
- /* ----------------------------- HANDLER METHODS ---------------------------- */
- saveConfigChange(service) {
- switch (service) {
- case 'preheat_start_departure_time':
- const data = {
- time: this.preheatConfig.data.time.value,
- };
- this.callService(service, data);
- break;
- case 'auxheat_configure':
- const items = Object.entries(this.auxheatConfig.data.items).reduce((acc, [key, { value }]) => {
- acc[key] = value;
- return acc;
- }, {});
- const dataAux = Object.assign({ time_selection: this.auxheatConfig.data.time_selection }, items);
- this.callService(service, dataAux);
- break;
- case 'battery_max_soc_configure':
- const dataCharge = {
- charge_program: this.chargeConfig.data.selected_program,
- max_soc: this.chargeConfig.data.max_soc.value,
- };
- this.callService(service, dataCharge);
- break;
- case 'charge_program_configure':
- const dataProgram = {
- charge_program: this.chargeConfig.data.selected_program,
- };
- this.callService(service, dataProgram);
- break;
- case 'windows_move':
- const dataWindows = Object.entries(this.windowsConfig.data.positions).reduce((acc, [key, { value }]) => {
- acc[key] = value;
- return acc;
- }, {});
- this.callService(service, dataWindows);
- break;
- case 'send_route':
- const dataRoute = Object.entries(this.sendRouteConfig.data).reduce((acc, [key, { value }]) => {
- acc[key] = value;
- return acc;
- }, {});
- this.callService(service, dataRoute);
- break;
- }
- }
- handleSendRouteChange(key, e) {
- const value = e.target.value;
- this.sendRouteConfig.data[key].value = value;
- this.requestUpdate(); // Trigger re-render to update UI after change
- }
- handleChargeProgramChange(type, e) {
- const value = e.target.value;
- if (type === 'max_soc') {
- this.chargeConfig.data[type].value = parseInt(value, 10);
- }
- else {
- this.chargeConfig.data[type] = parseInt(value, 10);
- }
- this.requestUpdate(); // Trigger re-render to update UI after change
- }
- handlePreheatTimeChange(e) {
- const value = e.target.value;
- this.preheatConfig.data.time.value = parseInt(value, 10);
- this.requestUpdate(); // Trigger re-render to update UI after change
- }
- handleAuxheatChange(type, item, e) {
- const value = e.target.value;
- if (type === 'time_selection') {
- this.auxheatConfig.data.time_selection = parseInt(value, 10);
- }
- else {
- this.auxheatConfig.data[type][item].value = parseInt(value, 10);
- }
- this.requestUpdate(); // Trigger re-render to update UI after change
- }
- handleWindowsChange(key, e) {
- this.windowsConfig.data.positions[key].value = e.detail.value;
- this.requestUpdate(); // Trigger re-render to update UI after change
- }
- _handleSubCardClick(type) {
- this.subcardType = this.subcardType === type ? null : type;
- setTimeout(() => {
- var _a;
- const gridBtn = (_a = this.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelectorAll('.control-btn-rounded:not(.active).click-shrink');
- gridBtn === null || gridBtn === void 0 ? void 0 : gridBtn.forEach((btn) => {
- btn.classList.remove('fade-in', 'fade-out', 'hidden');
- if (this.subcardType === null) {
- btn.classList.add('fade-in');
- btn.classList.remove('hidden');
- }
- else {
- btn.classList.add('fade-out');
- btn.addEventListener('animationend', () => {
- btn.classList.add('hidden');
- }, { once: true });
- }
- });
- }, 0);
- }
- resetConfig() {
- this.serviceData = cloneDeep(serviceData);
- this.requestUpdate(); // Trigger re-render to update UI after reset
- }
- lockMoreInfo() {
- ne(this, 'hass-more-info', {
- entityId: this.carLockEntity,
- });
- }
- callService(service, data) {
- this.hass.callService('mbapi2020', service, Object.assign({ vin: this.carVin }, data));
- console.log('call-service:', service, data);
- this.launchToast();
- }
- launchToast() {
- var _a;
- const toast = (_a = this.shadowRoot) === null || _a === void 0 ? void 0 : _a.getElementById('toast');
- if (!toast)
- return;
- toast.classList.add('show');
- setTimeout(() => {
- toast.classList.remove('show');
- }, 3000);
- }
-};
-__decorate([
- n({ attribute: false })
-], RemoteControl.prototype, "hass", void 0);
-__decorate([
- n({ type: Object })
-], RemoteControl.prototype, "servicesConfig", void 0);
-__decorate([
- n({ type: String })
-], RemoteControl.prototype, "carVin", void 0);
-__decorate([
- n({ type: String })
-], RemoteControl.prototype, "carLockEntity", void 0);
-__decorate([
- n({ type: Boolean })
-], RemoteControl.prototype, "darkMode", void 0);
-__decorate([
- r$1()
-], RemoteControl.prototype, "subcardType", void 0);
-__decorate([
- r$1()
-], RemoteControl.prototype, "serviceData", void 0);
-RemoteControl = __decorate([
- t$1('remote-control')
-], RemoteControl);
-
-/**
- *
- * @param car
- * @returns
- */
-async function getVehicleEntities(hass, config) {
- const allEntities = await hass.callWS({
- type: 'config/entity_registry/list',
- });
- const carEntity = allEntities.find((e) => e.entity_id === config.entity);
- if (!carEntity) {
- return {};
- }
- const deviceEntities = allEntities.filter((e) => e.device_id === carEntity.device_id);
- const entityIds = {};
- for (const entityName of Object.keys(combinedFilters)) {
- const { prefix, suffix } = combinedFilters[entityName];
- if (!prefix) {
- const entity = deviceEntities.find((e) => e.unique_id.endsWith(suffix));
- if (entity) {
- entityIds[entityName] = {
- entity_id: entity.entity_id,
- original_name: entity.original_name,
- device_id: entity.device_id,
- };
- }
- }
- else {
- if (entityName === 'soc') {
- const socName = 'State of Charge';
- const entity = deviceEntities.find((e) => e.original_name === socName);
- if (entity) {
- entityIds[entityName] = {
- entity_id: entity.entity_id,
- original_name: entity.original_name,
- unique_id: entity.unique_id,
- device_id: entity.device_id,
- };
- }
- }
- else if (entityName === 'maxSoc') {
- const maxSocName = 'Max State of Charge';
- const entity = deviceEntities.find((e) => e.original_name === maxSocName);
- if (entity) {
- entityIds[entityName] = {
- entity_id: entity.entity_id,
- original_name: entity.original_name,
- unique_id: entity.unique_id,
- device_id: entity.device_id,
- };
- }
- }
- const entity = deviceEntities.find((e) => e.entity_id.startsWith(prefix) && e.entity_id.endsWith(suffix));
- if (entity) {
- entityIds[entityName] = {
- entity_id: entity.entity_id,
- original_name: entity.original_name,
- unique_id: entity.unique_id,
- device_id: entity.device_id,
- };
- }
- }
- }
- return entityIds;
-}
-/**
- * Additional card listeners
- * @param cardElement
- * @param toggleCard
- */
-function setupCardListeners(cardElement, toggleCard) {
- if (!cardElement)
- return;
- // Variables to store touch/mouse coordinates
- let xDown = null;
- let yDown = null;
- let xDiff = null;
- let yDiff = null;
- let isSwiping = false;
- const presDown = (e) => {
- e.stopImmediatePropagation();
- if (e instanceof TouchEvent) {
- xDown = e.touches[0].clientX;
- yDown = e.touches[0].clientY;
- }
- else if (e instanceof MouseEvent) {
- xDown = e.clientX;
- yDown = e.clientY;
- }
- ['touchmove', 'mousemove'].forEach((event) => {
- cardElement.addEventListener(event, pressMove);
- });
- ['touchend', 'mouseup'].forEach((event) => {
- cardElement.addEventListener(event, pressRelease);
- });
- };
- const pressMove = (e) => {
- if (xDown === null || yDown === null)
- return;
- if (e instanceof TouchEvent) {
- xDiff = xDown - e.touches[0].clientX;
- yDiff = yDown - e.touches[0].clientY;
- }
- else if (e instanceof MouseEvent) {
- xDiff = xDown - e.clientX;
- yDiff = yDown - e.clientY;
- }
- if (xDiff !== null && yDiff !== null) {
- if (Math.abs(xDiff) > 1 && Math.abs(yDiff) > 1) {
- isSwiping = true;
- }
- }
- };
- const pressRelease = (e) => {
- e.stopImmediatePropagation();
- ['touchmove', 'mousemove'].forEach((event) => {
- cardElement.removeEventListener(event, pressMove);
- });
- ['touchend', 'mouseup'].forEach((event) => {
- cardElement.removeEventListener(event, pressRelease);
- });
- const cardWidth = cardElement.clientWidth;
- if (isSwiping && xDiff !== null && yDiff !== null) {
- if (Math.abs(xDiff) > Math.abs(yDiff) && Math.abs(xDiff) > cardWidth / 3) {
- if (xDiff > 0) {
- // Next card - swipe left
- cardElement.classList.add('swiping-left');
- setTimeout(() => {
- toggleCard('next');
- cardElement.classList.remove('swiping-left');
- }, 300);
- }
- else {
- // Previous card - swipe right
- cardElement.classList.add('swiping-right');
- setTimeout(() => {
- toggleCard('prev');
- cardElement.classList.remove('swiping-right');
- }, 300);
- }
- }
- xDiff = yDiff = xDown = yDown = null;
- isSwiping = false;
- }
- };
- // Attach the initial pressDown listeners
- ['touchstart', 'mousedown'].forEach((event) => {
- cardElement.addEventListener(event, presDown);
- });
-}
-
-const HELPERS = window.loadCardHelpers ? window.loadCardHelpers() : undefined;
-let VehicleCard = class VehicleCard extends s {
- constructor() {
- super(...arguments);
- this.vehicleEntities = {};
- this.additionalCards = {};
- this.activeCardType = null;
- this.lockAttributesVisible = false;
- this.windowAttributesVisible = false;
- this.doorsAttributesVisible = false;
- this.chargingInfoVisible = false;
- }
- static async getConfigElement() {
- await Promise.resolve().then(function () { return editor; });
- return document.createElement('vehicle-info-card-editor');
- }
- get isCharging() {
- var _a;
- return this.getEntityAttribute((_a = this.vehicleEntities.rangeElectric) === null || _a === void 0 ? void 0 : _a.entity_id, 'chargingactive');
- }
- get carVinNumber() {
- if (!this.config.entity)
- return '';
- return this.getEntityAttribute(this.config.entity, 'vin');
- }
- get isDark() {
- return this.hass.themes.darkMode;
- }
- // https://lit.dev/docs/components/styles/
- static get styles() {
- return css_248z$3;
- }
- async setConfig(config) {
- var _a, _b, _c;
- if (!config) {
- throw new Error('Invalid configuration');
- }
- this.config = Object.assign({}, config);
- for (const cardType of cardTypes) {
- if (this.config[cardType.config]) {
- this.createCards(this.config[cardType.config], cardType.type);
- }
- }
- if (this.config.device_tracker) {
- const haMapConfig = {
- type: 'map',
- default_zoom: (_a = this.config.map_popup_config) === null || _a === void 0 ? void 0 : _a.default_zoom,
- hours_to_show: (_b = this.config.map_popup_config) === null || _b === void 0 ? void 0 : _b.hours_to_show,
- theme_mode: (_c = this.config.map_popup_config) === null || _c === void 0 ? void 0 : _c.theme_mode,
- entities: [
- {
- entity: this.config.device_tracker,
- },
- ],
- };
- this.createCards([haMapConfig], 'mapDialog');
- }
- }
- getCardSize() {
- return 3;
- }
- firstUpdated(changedProperties) {
- super.firstUpdated(changedProperties);
- this.configureAsync();
- }
- async configureAsync() {
- this.vehicleEntities = await getVehicleEntities(this.hass, this.config);
- this.requestUpdate();
- }
- connectedCallback() {
- super.connectedCallback();
- {
- window.BenzCard = this;
- }
- }
- disconnectedCallback() {
- if (window.BenzCard === this) {
- window.BenzCard = undefined;
- }
- super.disconnectedCallback();
- }
- async createCards(cardConfigs, stateProperty) {
- if (HELPERS) {
- const helpers = await HELPERS;
- const cards = await Promise.all(cardConfigs.map(async (cardConfig) => {
- const element = await helpers.createCardElement(cardConfig);
- element.hass = this.hass;
- return element;
- }));
- this.additionalCards[stateProperty] = cards;
- }
- }
- updated(changedProps) {
- var _a;
- super.updated(changedProps);
- if (changedProps.has('activeCardType') && this.activeCardType !== 'mapDialog') {
- const cardElement = (_a = this.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector('.card-element');
- if (!cardElement)
- return;
- setupCardListeners(cardElement, this.toggleCard.bind(this));
- }
- }
- // https://lit.dev/docs/components/lifecycle/#reactive-update-cycle-performing
- shouldUpdate(changedProps) {
- if (!this.config) {
- return false;
- }
- if (changedProps.has('hass')) {
- return true;
- }
- return _e(this, changedProps, false);
- }
- /* -------------------------------------------------------------------------- */
- /* MAIN RENDER */
- /* -------------------------------------------------------------------------- */
- // https://lit.dev/docs/components/rendering/
- render() {
- if (!this.config || !this.hass) {
- return x ``;
- }
- const isDark = this.isDark ? 'dark' : '';
- const name = this.config.name || '';
- return x `
-
- ${this._renderHeaderBackground()}
-
- ${this.activeCardType ? this._renderCustomCard() : this._renderMainCard()}
-
- `;
- }
- _renderHeaderBackground() {
- if (!this.config.show_background || this.activeCardType !== null)
- return x ``;
- const background = this.isDark ? amgWhite : amgBlack;
- return x ` `;
- }
- _renderMainCard() {
- return x `
-
-
- ${this._renderHeaderSlides()} ${this._renderMap()} ${this._renderButtons()}
-
- `;
- }
- _renderWarnings() {
- const defaultIndicData = this.createDataArray([{ key: 'lockSensor' }, { key: 'parkBrake' }]);
- const defaultIdicator = defaultIndicData.map(({ state, icon }) => {
- return x `
-
- `;
- });
- const addedChargingInfo = this.isCharging
- ? x ` (this.chargingInfoVisible = !this.chargingInfoVisible)}>
-
-
-
`
- : x ``;
- const serviceControl = this.config.enable_services_control
- ? x `
- this.toggleCardFromButtons('servicesCard')}>
-
-
-
- `
- : x ``;
- return x `${defaultIdicator} ${serviceControl} ${addedChargingInfo}
`;
- }
- _renderChargingInfo() {
- const chargingData = this.createDataArray(chargingOverview);
- const chargingClass = this.chargingInfoVisible ? 'info-box charge active' : 'info-box charge';
- return x `
-
- ${chargingData.map(({ name, state, icon }) => {
- if (state) {
- return x `
-
-
-
- ${state}
-
-
- ${name}
-
-
- `;
- }
- else {
- return x ``;
- }
- })}
-
- `;
- }
- _renderRangeInfo() {
- if (this.chargingInfoVisible)
- return;
- const { fuelLevel, rangeLiquid, rangeElectric, soc } = this.vehicleEntities;
- const fuelInfo = this.getEntityInfo(fuelLevel === null || fuelLevel === void 0 ? void 0 : fuelLevel.entity_id);
- const rangeLiquidInfo = this.getEntityInfo(rangeLiquid === null || rangeLiquid === void 0 ? void 0 : rangeLiquid.entity_id);
- const rangeElectricInfo = this.getEntityInfo(rangeElectric === null || rangeElectric === void 0 ? void 0 : rangeElectric.entity_id);
- const socInfo = this.getEntityInfo(soc === null || soc === void 0 ? void 0 : soc.entity_id);
- const renderInfoBox = (icon, state, unit, rangeState, rangeUnit) => x `
-
-
-
-
- ${rangeState} ${rangeUnit}
-
-
- `;
- if (fuelInfo.state && rangeLiquidInfo.state) {
- return renderInfoBox('mdi:gas-station', fuelInfo.state, fuelInfo.unit, rangeLiquidInfo.state, rangeLiquidInfo.unit);
- }
- else if (rangeElectricInfo.state && socInfo.state) {
- return renderInfoBox('mdi:ev-station', socInfo.state, socInfo.unit, rangeElectricInfo.state, rangeElectricInfo.unit);
- }
- }
- _renderHeaderSlides() {
- if (!this.config.images || !this.config.show_slides)
- return x ``;
- const images = this.config.images;
- return x ` `;
- }
- _renderMap() {
- const { config, hass } = this;
- if (!config.show_map) {
- return;
- }
- if (!config.device_tracker && config.show_map) {
- return this._showWarning('No device_tracker entity provided.');
- }
- const darkMode = this.isDark;
- return x `
-
- (this.activeCardType = 'mapDialog')}
- >
-
- `;
- }
- _renderEcoChart() {
- var _a, _b, _c, _d;
- if (this.activeCardType !== 'ecoCards')
- return x ``;
- const ecoData = {
- bonusRange: parseFloat(this.getEntityState((_a = this.vehicleEntities.ecoScoreBonusRange) === null || _a === void 0 ? void 0 : _a.entity_id)) || 0,
- acceleration: parseFloat(this.getEntityState((_b = this.vehicleEntities.ecoScoreAcceleraion) === null || _b === void 0 ? void 0 : _b.entity_id)) || 0,
- constant: parseFloat(this.getEntityState((_c = this.vehicleEntities.ecoScoreConstant) === null || _c === void 0 ? void 0 : _c.entity_id)) || 0,
- freeWheel: parseFloat(this.getEntityState((_d = this.vehicleEntities.ecoScoreFreeWheel) === null || _d === void 0 ? void 0 : _d.entity_id)) || 0,
- };
- return x ` `;
- }
- _renderButtons() {
- if (!this.config.show_buttons)
- return x ``;
- return x `
-
- ${cardTypes.map((cardType) => x `
-
this.toggleCardFromButtons(cardType.type)}>
-
-
-
-
- ${cardType.name}
- ${this.getSecondaryInfo(cardType.type)}
-
-
- `)}
-
- `;
- }
- _renderCustomCard() {
- if (!this.activeCardType)
- return x ``;
- const { config } = this;
- const cardConfigMap = {
- tripCards: {
- config: config.trip_card,
- defaultRender: this._renderDefaultTripCard.bind(this),
- },
- vehicleCards: {
- config: config.vehicle_card,
- defaultRender: this._renderDefaultVehicleCard.bind(this),
- },
- ecoCards: {
- config: config.eco_card,
- defaultRender: this._renderDefaultEcoCard.bind(this),
- },
- tyreCards: {
- config: config.tyre_card,
- defaultRender: this._renderDefaultTyreCard.bind(this),
- },
- mapDialog: {
- config: [],
- defaultRender: () => this.additionalCards['mapDialog'],
- },
- servicesCard: {
- config: [],
- defaultRender: this._renderServiceControl.bind(this),
- },
- };
- const cardInfo = cardConfigMap[this.activeCardType];
- if (!cardInfo) {
- return x ``;
- }
- const isDefaultCard = !cardInfo.config || cardInfo.config.length === 0;
- const cards = isDefaultCard ? cardInfo.defaultRender() : this.additionalCards[this.activeCardType];
- const lastCarUpdate = config.entity ? this.hass.states[config.entity].last_changed : '';
- const formattedDate = this.hass.locale
- ? v(new Date(lastCarUpdate), this.hass.locale)
- : formatTimestamp(lastCarUpdate);
- const cardHeaderBox = x ` `;
- return x `
-
- ${cardHeaderBox}
-
- ${isDefaultCard ? cards : cards.map((card) => x `${card}
`)}
-
- ${isDefaultCard ? x `Last update: ${formattedDate}
` : ''}
-
- `;
- }
- _renderDefaultTripCard() {
- const sections = [
- { title: 'Overview', data: this.createDataArray(tripOverview) },
- { title: 'From start', data: this.createDataArray(tripFromStart) },
- { title: 'From reset', data: this.createDataArray(tripFromReset) },
- ];
- return x ` ${sections.map((section) => this.createItemDataRow(section.title, section.data))} `;
- }
- _renderDefaultVehicleCard() {
- const warningsData = this.createDataArray(vehicleWarnings);
- const subCardVisible = this.isSubCardVisible();
- return x `
-
-
- ${this._renderOverviewDataWithSubCard()}
-
-
-
- ${warningsData.map(({ key, icon, state, name, active }) => x `
-
-
- { var _a; return this.toggleMoreInfo((_a = this.vehicleEntities[key]) === null || _a === void 0 ? void 0 : _a.entity_id); }}
- >
- ${name}
-
-
{ var _a; return this.toggleMoreInfo((_a = this.vehicleEntities[key]) === null || _a === void 0 ? void 0 : _a.entity_id); }}
- >
- ${state}
-
-
- `)}
-
- `;
- }
- _renderDefaultEcoCard() {
- const ecoData = this.createDataArray(ecoScores);
- return x `
-
- ${this._renderEcoChart()}
-
- ${this.createItemDataRow('Scores', ecoData)}`;
- }
- _renderDefaultTyreCard() {
- var _a;
- const isPressureWarning = this.getBooleanState((_a = this.vehicleEntities.tirePressureWarning) === null || _a === void 0 ? void 0 : _a.entity_id);
- const tyreInfo = isPressureWarning ? 'Pressure loss detected. Check tyres.' : 'No pressure loss detected';
- const infoClass = isPressureWarning ? 'warning' : '';
- return x `
-
-
-
-
- ${tyrePressures.map((tyre) => {
- var _a;
- return x `
- ${this.getStateDisplay((_a = this.vehicleEntities[tyre.key]) === null || _a === void 0 ? void 0 : _a.entity_id)}
- ${tyre.name}
-
`;
- })}
-
-
- ${tyreInfo}
-
-
- `;
- }
- _renderServiceControl() {
- var _a;
- if (!this.config.services) {
- return x `Select services to display `;
- }
- const hass = this.hass;
- const serviceControl = this.config.services;
- const carVin = this.carVinNumber;
- const carLockEntity = (_a = this.vehicleEntities.lock) === null || _a === void 0 ? void 0 : _a.entity_id;
- return x `
-
-
-
-
- `;
- }
- _showWarning(warning) {
- return x ` ${warning} `;
- }
- /* -------------------------------------------------------------------------- */
- /* ADDED CARD FUNCTIONALITY */
- /* -------------------------------------------------------------------------- */
- toggleCard(action) {
- var _a;
- le('light');
- const cardElement = (_a = this.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector('.card-element');
- if (!this.activeCardType || !cardElement)
- return;
- if (action === 'next' || action === 'prev') {
- const currentIndex = cardTypes.findIndex((card) => card.type === this.activeCardType);
- const newIndex = action === 'next'
- ? (currentIndex + 1) % cardTypes.length
- : (currentIndex - 1 + cardTypes.length) % cardTypes.length;
- cardElement.style.animation = 'none';
- setTimeout(() => {
- this.activeCardType = cardTypes[newIndex].type;
- cardElement.style.animation = 'fadeIn 0.3s ease';
- }, 300);
- // this.activeCardType = cardTypes[newIndex].type;
- }
- else if (action === 'close') {
- this.activeCardType = null;
- }
- }
- toggleCardFromButtons(cardType) {
- le('light');
- setTimeout(() => {
- this.activeCardType = this.activeCardType === cardType ? null : cardType;
- }, 200);
- }
- /* --------------------- SUBCARDS METHODS AND RENDERING --------------------- */
- _renderOverviewDataWithSubCard() {
- const overViewData = this.createDataArray(vehicleOverview);
- const toggleAttributes = (key) => {
- if (key === 'lockSensor') {
- this.lockAttributesVisible = !this.lockAttributesVisible;
- }
- else if (key === 'windowsClosed') {
- this.windowAttributesVisible = !this.windowAttributesVisible;
- }
- else if (key === 'doorStatusOverall') {
- this.doorsAttributesVisible = !this.doorsAttributesVisible;
- }
- else {
- return;
- }
- };
- const subCardIconActive = (key) => {
- if (['lockSensor', 'windowsClosed', 'doorStatusOverall'].includes(key)) {
- const isVisible = key === 'lockSensor'
- ? this.lockAttributesVisible
- : key === 'windowsClosed'
- ? this.windowAttributesVisible
- : this.doorsAttributesVisible;
- return isVisible ? 'active' : '';
- }
- return 'hidden';
- };
- const subCardElements = (key) => {
- if (['lockSensor', 'windowsClosed', 'doorStatusOverall'].includes(key)) {
- return key === 'lockSensor'
- ? this._renderSubCard('lock')
- : key === 'windowsClosed'
- ? this._renderSubCard('window')
- : this._renderSubCard('door');
- }
- return null;
- };
- const toggleMoreInfo = (key) => {
- var _a, _b;
- if (['lockSensor', 'doorStatusOverall'].includes(key)) {
- this.toggleMoreInfo((_a = this.vehicleEntities.lockSensor) === null || _a === void 0 ? void 0 : _a.entity_id);
- }
- else {
- this.toggleMoreInfo((_b = this.vehicleEntities[key]) === null || _b === void 0 ? void 0 : _b.entity_id);
- }
- };
- return x `
- ${overViewData.map(({ key, name, icon, state, active }) => x `
-
-
- toggleMoreInfo(key)}
- >
- ${name}
-
-
toggleAttributes(key)}>
- ${state}
-
-
-
- ${subCardElements(key)}
- `)}
- `;
- }
- _renderSubCard(attributeType) {
- const state = {};
- const entityID = this.getEntityTypeId(attributeType);
- const stateMapping = this.getAttrStateMap(attributeType);
- const attributesVisible = this.getSubCardVisible(attributeType);
- const attributesClass = attributesVisible ? 'sub-attributes active' : 'sub-attributes';
- // Iterate over the keys of the stateMapping object
- Object.keys(stateMapping).forEach((attribute) => {
- const attributeState = this.getEntityAttribute(entityID, attribute);
- if (attributeState !== undefined && attributeState !== null) {
- state[attribute] = attributeState;
- }
- });
- // Render the attributes
- return x `
-
- ${Object.keys(state).map((attribute) => {
- const rawState = state[attribute];
- // Check if the state is valid and the attribute mapping exists
- if (rawState !== undefined && rawState !== null && stateMapping[attribute]) {
- const readableState = stateMapping[attribute].state[rawState] || 'Unknown';
- const classState = rawState === '2' || rawState === false ? '' : 'warning';
- return x `
-
-
${stateMapping[attribute].name}
-
- ${readableState}
-
-
- `;
- }
- // Return nothing if the attribute state is not valid or attribute mapping does not exist
- return '';
- })}
-
- `;
- }
- getEntityTypeId(attributeType) {
- var _a, _b, _c;
- switch (attributeType) {
- case 'lock':
- return (_a = this.vehicleEntities.lockSensor) === null || _a === void 0 ? void 0 : _a.entity_id;
- case 'window':
- return (_b = this.vehicleEntities.windowsClosed) === null || _b === void 0 ? void 0 : _b.entity_id;
- case 'door':
- return (_c = this.vehicleEntities.lockSensor) === null || _c === void 0 ? void 0 : _c.entity_id;
- }
- }
- getAttrStateMap(attributeType) {
- switch (attributeType) {
- case 'lock':
- return lockAttributes;
- case 'window':
- return windowAttributes;
- case 'door':
- return doorAttributes;
- }
- }
- getSubCardVisible(attributeType) {
- switch (attributeType) {
- case 'lock':
- return this.lockAttributesVisible;
- case 'window':
- return this.windowAttributesVisible;
- case 'door':
- return this.doorsAttributesVisible;
- }
- }
- isSubCardVisible() {
- const attributeVisibilityStates = [
- this.lockAttributesVisible,
- this.windowAttributesVisible,
- this.doorsAttributesVisible,
- ];
- return attributeVisibilityStates.some((state) => state);
- }
- /* -------------------------------------------------------------------------- */
- /* GET ENTITIES STATE AND ATTRIBUTES */
- /* -------------------------------------------------------------------------- */
- createItemDataRow(title, data) {
- return x `
-
-
- ${data.map(({ key, name, icon, state }) => {
- if (key && name && state) {
- return x `
-
-
-
- ${name}
-
-
{ var _a; return this.toggleMoreInfo((_a = this.vehicleEntities[key]) === null || _a === void 0 ? void 0 : _a.entity_id); }}>
- ${state}
-
-
- `;
- }
- else {
- return x ``;
- }
- })}
-
- `;
- }
- createDataArray(keys) {
- return keys.map((config) => this.getEntityInfoByKey(config));
- }
- getEntityInfoByKey({ key, name, icon, unit, state }) {
- var _a, _b;
- const vehicleEntity = this.vehicleEntities[key];
- if (!vehicleEntity) {
- if (key === 'selectedProgram') {
- return {
- key,
- name: 'Program',
- icon: 'mdi:ev-station',
- state: chargeSelectedProgram[this.getEntityAttribute((_a = this.vehicleEntities.rangeElectric) === null || _a === void 0 ? void 0 : _a.entity_id, 'selectedChargeProgram')],
- unit,
- };
- }
- else if (key === 'doorStatusOverall') {
- const doorValue = this.getEntityAttribute((_b = this.vehicleEntities.lockSensor) === null || _b === void 0 ? void 0 : _b.entity_id, 'doorStatusOverall');
- const doorFormatted = doorStatus[doorValue] || 'Unknown';
- const activeState = doorValue === '1' ? true : false;
- return {
- key,
- name: 'Doors',
- icon: 'mdi:car-door-lock',
- state: doorFormatted,
- active: activeState,
- unit,
- };
- }
- return { key, name, icon, state: '', unit };
- }
- const defaultInfo = {
- key,
- name: name !== null && name !== void 0 ? name : vehicleEntity.original_name,
- icon: icon !== null && icon !== void 0 ? icon : this.getEntityAttribute(vehicleEntity.entity_id, 'icon'),
- state: state !== null && state !== void 0 ? state : this.getStateDisplay(vehicleEntity.entity_id),
- unit: unit !== null && unit !== void 0 ? unit : this.getEntityAttribute(vehicleEntity.entity_id, 'unit_of_measurement'),
- };
- switch (key) {
- case 'soc': {
- const currentState = this.getEntityState(vehicleEntity.entity_id);
- const stateValue = currentState ? parseFloat(currentState) : 0;
- let socIcon;
- if (stateValue < 35) {
- socIcon = 'mdi:battery-charging-low';
- }
- else if (stateValue < 70) {
- socIcon = 'mdi:battery-charging-medium';
- }
- else {
- socIcon = 'mdi:battery-charging-high';
- }
- return Object.assign(Object.assign({}, defaultInfo), { icon: socIcon });
- }
- case 'maxSoc': {
- const maxSocState = this.getEntityState(vehicleEntity.entity_id);
- const maxSocStateValue = maxSocState ? parseFloat(maxSocState) : 0;
- const iconValue = Math.round(maxSocStateValue / 10) * 10;
- const maxSocIcon = `mdi:battery-charging-${iconValue}`;
- return Object.assign(Object.assign({}, defaultInfo), { icon: maxSocIcon });
- }
- case 'chargingPower': {
- const powerState = this.getEntityState(vehicleEntity.entity_id);
- const powerStateValue = powerState ? parseFloat(powerState) : 0;
- const powerStateUnit = this.getEntityAttribute(vehicleEntity.entity_id, 'unit_of_measurement') || 'kW';
- const powerStateDecimals = H(powerStateValue, this.hass.locale);
- const powerStateDislay = powerStateDecimals + ' ' + powerStateUnit;
- return Object.assign(Object.assign({}, defaultInfo), { state: powerStateDislay });
- }
- case 'parkBrake': {
- const parkBrakeState = this.getBooleanState(vehicleEntity.entity_id);
- return Object.assign(Object.assign({}, defaultInfo), { name: name !== null && name !== void 0 ? name : 'Parking brake', state: parkBrakeState ? 'Engaged' : 'Released', active: parkBrakeState });
- }
- case 'windowsClosed': {
- let windowState;
- const windowsState = this.getBooleanState(vehicleEntity.entity_id);
- if (windowsState) {
- windowState = 'Closed';
- }
- else {
- const windowAttributeStates = {};
- Object.keys(windowAttributes).forEach((attribute) => {
- const attributeState = this.getEntityAttribute(vehicleEntity.entity_id, attribute);
- if (attributeState !== undefined && attributeState !== null) {
- windowAttributeStates[attribute] = attributeState;
- }
- });
- const openWindows = Object.keys(windowAttributeStates).filter((attribute) => windowAttributeStates[attribute] === '0');
- const totalOpenWindows = openWindows.length;
- windowState = `${totalOpenWindows} window${totalOpenWindows !== 1 ? 's' : ''} open`;
- }
- return Object.assign(Object.assign({}, defaultInfo), { name: name || 'Windows', state: windowState, active: windowsState });
- }
- case 'ignitionState': {
- const shortValue = this.getEntityAttribute(vehicleEntity.entity_id, 'value_short');
- const realState = this.getEntityState(vehicleEntity.entity_id);
- const activeState = realState === '0' || realState === '1' ? true : false;
- return Object.assign(Object.assign({}, defaultInfo), { state: shortValue || 'Unknown', active: activeState });
- }
- case 'lockSensor': {
- const lockState = this.getEntityState(vehicleEntity.entity_id);
- const lockStateFormatted = lockStates[lockState] || lockStates['4'];
- const lockIcon = lockState === '2' || lockState === '1' ? 'mdi:lock' : 'mdi:lock-open';
- return Object.assign(Object.assign({}, defaultInfo), { icon: lockIcon, state: lockStateFormatted, active: lockState === '2' || lockState === '1' ? true : false });
- }
- case 'starterBatteryState': {
- const stateValue = this.getEntityState(vehicleEntity.entity_id);
- const stateFormated = starterBattery[stateValue] || 'Unknown';
- return Object.assign(Object.assign({}, defaultInfo), { state: stateFormated });
- }
- default:
- if (vehicleWarnings.map((key) => key.key).includes(key)) {
- const warningState = this.getBooleanState(vehicleEntity.entity_id);
- return Object.assign(Object.assign({}, defaultInfo), { state: warningState ? 'Problem' : 'Ok', active: warningState });
- }
- return defaultInfo;
- }
- }
- getStateDisplay(entityId) {
- if (!entityId || !this.hass.states[entityId] || !this.hass.locale)
- return '';
- return W(this.hass.localize, this.hass.states[entityId], this.hass.locale);
- }
- getSecondaryInfo(cardType) {
- const { odometer, lockSensor, ecoScoreBonusRange } = this.vehicleEntities;
- switch (cardType) {
- case 'tripCards':
- return this.getStateDisplay(odometer === null || odometer === void 0 ? void 0 : odometer.entity_id);
- case 'vehicleCards':
- const lockedDisplayText = lockStates[this.getEntityState(lockSensor === null || lockSensor === void 0 ? void 0 : lockSensor.entity_id)] || lockStates['4'];
- return lockedDisplayText;
- case 'ecoCards':
- return this.getStateDisplay(ecoScoreBonusRange === null || ecoScoreBonusRange === void 0 ? void 0 : ecoScoreBonusRange.entity_id);
- case 'tyreCards':
- const secondaryInfoTyres = this.getMinMaxTyrePressure();
- return secondaryInfoTyres;
- default:
- return 'Unknown Card';
- }
- }
- /* --------------------------- GET INFO FROM HASS --------------------------- */
- getEntityInfo(entity) {
- const state = this.getEntityState(entity);
- const unit = this.getEntityAttribute(entity, 'unit_of_measurement');
- return { state, unit };
- }
- getBooleanState(entity) {
- if (!entity || !this.hass.states[entity])
- return false;
- return this.hass.states[entity].state === 'on';
- }
- getEntityState(entity) {
- if (!entity || !this.hass.states[entity])
- return '';
- return this.hass.states[entity].state;
- }
- getEntityAttribute(entity, attribute) {
- if (!entity || !this.hass.states[entity] || !this.hass.states[entity].attributes)
- return undefined;
- return this.hass.states[entity].attributes[attribute];
- }
- toggleMoreInfo(entity) {
- ne(this, 'hass-more-info', { entityId: entity });
- }
- getMinMaxTyrePressure() {
- var _a;
- const { vehicleEntities } = this;
- const pressuresWithUnits = tyreAttributes.map((key) => {
- var _a, _b;
- return ({
- pressure: this.getEntityState((_a = vehicleEntities[key]) === null || _a === void 0 ? void 0 : _a.entity_id) || '',
- unit: this.getEntityAttribute((_b = vehicleEntities[key]) === null || _b === void 0 ? void 0 : _b.entity_id, 'unit_of_measurement'),
- });
- });
- // Find the minimum and maximum pressures
- const minPressure = Math.min(...pressuresWithUnits.map(({ pressure }) => parseFloat(pressure)));
- const maxPressure = Math.max(...pressuresWithUnits.map(({ pressure }) => parseFloat(pressure)));
- // Format the minimum and maximum pressures with their original units
- const tireUnit = ((_a = pressuresWithUnits[0]) === null || _a === void 0 ? void 0 : _a.unit) || '';
- const formattedMinPressure = minPressure % 1 === 0 ? minPressure.toFixed(0) : minPressure.toFixed(1);
- const formattedMaxPressure = maxPressure % 1 === 0 ? maxPressure.toFixed(0) : maxPressure.toFixed(1);
- return `${formattedMinPressure} - ${formattedMaxPressure} ${tireUnit}`;
- }
-};
-VehicleCard.getStubConfig = () => {
- return Object.assign({}, defaultConfig);
-};
-__decorate([
- n({ attribute: false })
-], VehicleCard.prototype, "hass", void 0);
-__decorate([
- n({ type: Object })
-], VehicleCard.prototype, "config", void 0);
-__decorate([
- r$1()
-], VehicleCard.prototype, "vehicleEntities", void 0);
-__decorate([
- r$1()
-], VehicleCard.prototype, "additionalCards", void 0);
-__decorate([
- r$1()
-], VehicleCard.prototype, "activeCardType", void 0);
-__decorate([
- n({ type: Boolean })
-], VehicleCard.prototype, "lockAttributesVisible", void 0);
-__decorate([
- n({ type: Boolean })
-], VehicleCard.prototype, "windowAttributesVisible", void 0);
-__decorate([
- n({ type: Boolean })
-], VehicleCard.prototype, "doorsAttributesVisible", void 0);
-__decorate([
- n({ type: Boolean })
-], VehicleCard.prototype, "chargingInfoVisible", void 0);
-VehicleCard = __decorate([
- t$1('vehicle-info-card')
-], VehicleCard);
-window.customCards = window.customCards || [];
-window.customCards.push({
- type: 'vehicle-info-card',
- name: 'Vehicle Card',
- preview: true,
- description: 'A custom card to display vehicle data with a map and additional cards.',
- documentationURL: 'https://github.com/ngocjohn/vehicle-info-card?tab=readme-ov-file#configuration',
-});
-
-const Char = {
- ANCHOR: '&',
- COMMENT: '#',
- TAG: '!',
- DIRECTIVES_END: '-',
- DOCUMENT_END: '.'
-};
-const Type = {
- ALIAS: 'ALIAS',
- BLANK_LINE: 'BLANK_LINE',
- BLOCK_FOLDED: 'BLOCK_FOLDED',
- BLOCK_LITERAL: 'BLOCK_LITERAL',
- COMMENT: 'COMMENT',
- DIRECTIVE: 'DIRECTIVE',
- DOCUMENT: 'DOCUMENT',
- FLOW_MAP: 'FLOW_MAP',
- FLOW_SEQ: 'FLOW_SEQ',
- MAP: 'MAP',
- MAP_KEY: 'MAP_KEY',
- MAP_VALUE: 'MAP_VALUE',
- PLAIN: 'PLAIN',
- QUOTE_DOUBLE: 'QUOTE_DOUBLE',
- QUOTE_SINGLE: 'QUOTE_SINGLE',
- SEQ: 'SEQ',
- SEQ_ITEM: 'SEQ_ITEM'
-};
-const defaultTagPrefix = 'tag:yaml.org,2002:';
-const defaultTags = {
- MAP: 'tag:yaml.org,2002:map',
- SEQ: 'tag:yaml.org,2002:seq',
- STR: 'tag:yaml.org,2002:str'
-};
-
-function findLineStarts(src) {
- const ls = [0];
- let offset = src.indexOf('\n');
-
- while (offset !== -1) {
- offset += 1;
- ls.push(offset);
- offset = src.indexOf('\n', offset);
- }
-
- return ls;
-}
-
-function getSrcInfo(cst) {
- let lineStarts, src;
-
- if (typeof cst === 'string') {
- lineStarts = findLineStarts(cst);
- src = cst;
- } else {
- if (Array.isArray(cst)) cst = cst[0];
-
- if (cst && cst.context) {
- if (!cst.lineStarts) cst.lineStarts = findLineStarts(cst.context.src);
- lineStarts = cst.lineStarts;
- src = cst.context.src;
- }
- }
-
- return {
- lineStarts,
- src
- };
-}
-/**
- * @typedef {Object} LinePos - One-indexed position in the source
- * @property {number} line
- * @property {number} col
- */
-
-/**
- * Determine the line/col position matching a character offset.
- *
- * Accepts a source string or a CST document as the second parameter. With
- * the latter, starting indices for lines are cached in the document as
- * `lineStarts: number[]`.
- *
- * Returns a one-indexed `{ line, col }` location if found, or
- * `undefined` otherwise.
- *
- * @param {number} offset
- * @param {string|Document|Document[]} cst
- * @returns {?LinePos}
- */
-
-
-function getLinePos(offset, cst) {
- if (typeof offset !== 'number' || offset < 0) return null;
- const {
- lineStarts,
- src
- } = getSrcInfo(cst);
- if (!lineStarts || !src || offset > src.length) return null;
-
- for (let i = 0; i < lineStarts.length; ++i) {
- const start = lineStarts[i];
-
- if (offset < start) {
- return {
- line: i,
- col: offset - lineStarts[i - 1] + 1
- };
- }
-
- if (offset === start) return {
- line: i + 1,
- col: 1
- };
- }
-
- const line = lineStarts.length;
- return {
- line,
- col: offset - lineStarts[line - 1] + 1
- };
-}
-/**
- * Get a specified line from the source.
- *
- * Accepts a source string or a CST document as the second parameter. With
- * the latter, starting indices for lines are cached in the document as
- * `lineStarts: number[]`.
- *
- * Returns the line as a string if found, or `null` otherwise.
- *
- * @param {number} line One-indexed line number
- * @param {string|Document|Document[]} cst
- * @returns {?string}
- */
-
-function getLine(line, cst) {
- const {
- lineStarts,
- src
- } = getSrcInfo(cst);
- if (!lineStarts || !(line >= 1) || line > lineStarts.length) return null;
- const start = lineStarts[line - 1];
- let end = lineStarts[line]; // undefined for last line; that's ok for slice()
-
- while (end && end > start && src[end - 1] === '\n') --end;
-
- return src.slice(start, end);
-}
-/**
- * Pretty-print the starting line from the source indicated by the range `pos`
- *
- * Trims output to `maxWidth` chars while keeping the starting column visible,
- * using `…` at either end to indicate dropped characters.
- *
- * Returns a two-line string (or `null`) with `\n` as separator; the second line
- * will hold appropriately indented `^` marks indicating the column range.
- *
- * @param {Object} pos
- * @param {LinePos} pos.start
- * @param {LinePos} [pos.end]
- * @param {string|Document|Document[]*} cst
- * @param {number} [maxWidth=80]
- * @returns {?string}
- */
-
-function getPrettyContext({
- start,
- end
-}, cst, maxWidth = 80) {
- let src = getLine(start.line, cst);
- if (!src) return null;
- let {
- col
- } = start;
-
- if (src.length > maxWidth) {
- if (col <= maxWidth - 10) {
- src = src.substr(0, maxWidth - 1) + '…';
- } else {
- const halfWidth = Math.round(maxWidth / 2);
- if (src.length > col + halfWidth) src = src.substr(0, col + halfWidth - 1) + '…';
- col -= src.length - maxWidth;
- src = '…' + src.substr(1 - maxWidth);
- }
- }
-
- let errLen = 1;
- let errEnd = '';
-
- if (end) {
- if (end.line === start.line && col + (end.col - start.col) <= maxWidth + 1) {
- errLen = end.col - start.col;
- } else {
- errLen = Math.min(src.length + 1, maxWidth) - col;
- errEnd = '…';
- }
- }
-
- const offset = col > 1 ? ' '.repeat(col - 1) : '';
- const err = '^'.repeat(errLen);
- return `${src}\n${offset}${err}${errEnd}`;
-}
-
-class Range {
- static copy(orig) {
- return new Range(orig.start, orig.end);
- }
-
- constructor(start, end) {
- this.start = start;
- this.end = end || start;
- }
-
- isEmpty() {
- return typeof this.start !== 'number' || !this.end || this.end <= this.start;
- }
- /**
- * Set `origStart` and `origEnd` to point to the original source range for
- * this node, which may differ due to dropped CR characters.
- *
- * @param {number[]} cr - Positions of dropped CR characters
- * @param {number} offset - Starting index of `cr` from the last call
- * @returns {number} - The next offset, matching the one found for `origStart`
- */
-
-
- setOrigRange(cr, offset) {
- const {
- start,
- end
- } = this;
-
- if (cr.length === 0 || end <= cr[0]) {
- this.origStart = start;
- this.origEnd = end;
- return offset;
- }
-
- let i = offset;
-
- while (i < cr.length) {
- if (cr[i] > start) break;else ++i;
- }
-
- this.origStart = start + i;
- const nextOffset = i;
-
- while (i < cr.length) {
- // if end was at \n, it should now be at \r
- if (cr[i] >= end) break;else ++i;
- }
-
- this.origEnd = end + i;
- return nextOffset;
- }
-
-}
-
-/** Root class of all nodes */
-
-class Node$2 {
- static addStringTerminator(src, offset, str) {
- if (str[str.length - 1] === '\n') return str;
- const next = Node$2.endOfWhiteSpace(src, offset);
- return next >= src.length || src[next] === '\n' ? str + '\n' : str;
- } // ^(---|...)
-
-
- static atDocumentBoundary(src, offset, sep) {
- const ch0 = src[offset];
- if (!ch0) return true;
- const prev = src[offset - 1];
- if (prev && prev !== '\n') return false;
-
- if (sep) {
- if (ch0 !== sep) return false;
- } else {
- if (ch0 !== Char.DIRECTIVES_END && ch0 !== Char.DOCUMENT_END) return false;
- }
-
- const ch1 = src[offset + 1];
- const ch2 = src[offset + 2];
- if (ch1 !== ch0 || ch2 !== ch0) return false;
- const ch3 = src[offset + 3];
- return !ch3 || ch3 === '\n' || ch3 === '\t' || ch3 === ' ';
- }
-
- static endOfIdentifier(src, offset) {
- let ch = src[offset];
- const isVerbatim = ch === '<';
- const notOk = isVerbatim ? ['\n', '\t', ' ', '>'] : ['\n', '\t', ' ', '[', ']', '{', '}', ','];
-
- while (ch && notOk.indexOf(ch) === -1) ch = src[offset += 1];
-
- if (isVerbatim && ch === '>') offset += 1;
- return offset;
- }
-
- static endOfIndent(src, offset) {
- let ch = src[offset];
-
- while (ch === ' ') ch = src[offset += 1];
-
- return offset;
- }
-
- static endOfLine(src, offset) {
- let ch = src[offset];
-
- while (ch && ch !== '\n') ch = src[offset += 1];
-
- return offset;
- }
-
- static endOfWhiteSpace(src, offset) {
- let ch = src[offset];
-
- while (ch === '\t' || ch === ' ') ch = src[offset += 1];
-
- return offset;
- }
-
- static startOfLine(src, offset) {
- let ch = src[offset - 1];
- if (ch === '\n') return offset;
-
- while (ch && ch !== '\n') ch = src[offset -= 1];
-
- return offset + 1;
- }
- /**
- * End of indentation, or null if the line's indent level is not more
- * than `indent`
- *
- * @param {string} src
- * @param {number} indent
- * @param {number} lineStart
- * @returns {?number}
- */
-
-
- static endOfBlockIndent(src, indent, lineStart) {
- const inEnd = Node$2.endOfIndent(src, lineStart);
-
- if (inEnd > lineStart + indent) {
- return inEnd;
- } else {
- const wsEnd = Node$2.endOfWhiteSpace(src, inEnd);
- const ch = src[wsEnd];
- if (!ch || ch === '\n') return wsEnd;
- }
-
- return null;
- }
-
- static atBlank(src, offset, endAsBlank) {
- const ch = src[offset];
- return ch === '\n' || ch === '\t' || ch === ' ' || endAsBlank && !ch;
- }
-
- static nextNodeIsIndented(ch, indentDiff, indicatorAsIndent) {
- if (!ch || indentDiff < 0) return false;
- if (indentDiff > 0) return true;
- return indicatorAsIndent && ch === '-';
- } // should be at line or string end, or at next non-whitespace char
-
-
- static normalizeOffset(src, offset) {
- const ch = src[offset];
- return !ch ? offset : ch !== '\n' && src[offset - 1] === '\n' ? offset - 1 : Node$2.endOfWhiteSpace(src, offset);
- } // fold single newline into space, multiple newlines to N - 1 newlines
- // presumes src[offset] === '\n'
-
-
- static foldNewline(src, offset, indent) {
- let inCount = 0;
- let error = false;
- let fold = '';
- let ch = src[offset + 1];
-
- while (ch === ' ' || ch === '\t' || ch === '\n') {
- switch (ch) {
- case '\n':
- inCount = 0;
- offset += 1;
- fold += '\n';
- break;
-
- case '\t':
- if (inCount <= indent) error = true;
- offset = Node$2.endOfWhiteSpace(src, offset + 2) - 1;
- break;
-
- case ' ':
- inCount += 1;
- offset += 1;
- break;
- }
-
- ch = src[offset + 1];
- }
-
- if (!fold) fold = ' ';
- if (ch && inCount <= indent) error = true;
- return {
- fold,
- offset,
- error
- };
- }
-
- constructor(type, props, context) {
- Object.defineProperty(this, 'context', {
- value: context || null,
- writable: true
- });
- this.error = null;
- this.range = null;
- this.valueRange = null;
- this.props = props || [];
- this.type = type;
- this.value = null;
- }
-
- getPropValue(idx, key, skipKey) {
- if (!this.context) return null;
- const {
- src
- } = this.context;
- const prop = this.props[idx];
- return prop && src[prop.start] === key ? src.slice(prop.start + (skipKey ? 1 : 0), prop.end) : null;
- }
-
- get anchor() {
- for (let i = 0; i < this.props.length; ++i) {
- const anchor = this.getPropValue(i, Char.ANCHOR, true);
- if (anchor != null) return anchor;
- }
-
- return null;
- }
-
- get comment() {
- const comments = [];
-
- for (let i = 0; i < this.props.length; ++i) {
- const comment = this.getPropValue(i, Char.COMMENT, true);
- if (comment != null) comments.push(comment);
- }
-
- return comments.length > 0 ? comments.join('\n') : null;
- }
-
- commentHasRequiredWhitespace(start) {
- const {
- src
- } = this.context;
- if (this.header && start === this.header.end) return false;
- if (!this.valueRange) return false;
- const {
- end
- } = this.valueRange;
- return start !== end || Node$2.atBlank(src, end - 1);
- }
-
- get hasComment() {
- if (this.context) {
- const {
- src
- } = this.context;
-
- for (let i = 0; i < this.props.length; ++i) {
- if (src[this.props[i].start] === Char.COMMENT) return true;
- }
- }
-
- return false;
- }
-
- get hasProps() {
- if (this.context) {
- const {
- src
- } = this.context;
-
- for (let i = 0; i < this.props.length; ++i) {
- if (src[this.props[i].start] !== Char.COMMENT) return true;
- }
- }
-
- return false;
- }
-
- get includesTrailingLines() {
- return false;
- }
-
- get jsonLike() {
- const jsonLikeTypes = [Type.FLOW_MAP, Type.FLOW_SEQ, Type.QUOTE_DOUBLE, Type.QUOTE_SINGLE];
- return jsonLikeTypes.indexOf(this.type) !== -1;
- }
-
- get rangeAsLinePos() {
- if (!this.range || !this.context) return undefined;
- const start = getLinePos(this.range.start, this.context.root);
- if (!start) return undefined;
- const end = getLinePos(this.range.end, this.context.root);
- return {
- start,
- end
- };
- }
-
- get rawValue() {
- if (!this.valueRange || !this.context) return null;
- const {
- start,
- end
- } = this.valueRange;
- return this.context.src.slice(start, end);
- }
-
- get tag() {
- for (let i = 0; i < this.props.length; ++i) {
- const tag = this.getPropValue(i, Char.TAG, false);
-
- if (tag != null) {
- if (tag[1] === '<') {
- return {
- verbatim: tag.slice(2, -1)
- };
- } else {
- // eslint-disable-next-line no-unused-vars
- const [_, handle, suffix] = tag.match(/^(.*!)([^!]*)$/);
- return {
- handle,
- suffix
- };
- }
- }
- }
-
- return null;
- }
-
- get valueRangeContainsNewline() {
- if (!this.valueRange || !this.context) return false;
- const {
- start,
- end
- } = this.valueRange;
- const {
- src
- } = this.context;
-
- for (let i = start; i < end; ++i) {
- if (src[i] === '\n') return true;
- }
-
- return false;
- }
-
- parseComment(start) {
- const {
- src
- } = this.context;
-
- if (src[start] === Char.COMMENT) {
- const end = Node$2.endOfLine(src, start + 1);
- const commentRange = new Range(start, end);
- this.props.push(commentRange);
- return end;
- }
-
- return start;
- }
- /**
- * Populates the `origStart` and `origEnd` values of all ranges for this
- * node. Extended by child classes to handle descendant nodes.
- *
- * @param {number[]} cr - Positions of dropped CR characters
- * @param {number} offset - Starting index of `cr` from the last call
- * @returns {number} - The next offset, matching the one found for `origStart`
- */
-
-
- setOrigRanges(cr, offset) {
- if (this.range) offset = this.range.setOrigRange(cr, offset);
- if (this.valueRange) this.valueRange.setOrigRange(cr, offset);
- this.props.forEach(prop => prop.setOrigRange(cr, offset));
- return offset;
- }
-
- toString() {
- const {
- context: {
- src
- },
- range,
- value
- } = this;
- if (value != null) return value;
- const str = src.slice(range.start, range.end);
- return Node$2.addStringTerminator(src, range.end, str);
- }
-
-}
-
-class YAMLError extends Error {
- constructor(name, source, message) {
- if (!message || !(source instanceof Node$2)) throw new Error(`Invalid arguments for new ${name}`);
- super();
- this.name = name;
- this.message = message;
- this.source = source;
- }
-
- makePretty() {
- if (!this.source) return;
- this.nodeType = this.source.type;
- const cst = this.source.context && this.source.context.root;
-
- if (typeof this.offset === 'number') {
- this.range = new Range(this.offset, this.offset + 1);
- const start = cst && getLinePos(this.offset, cst);
-
- if (start) {
- const end = {
- line: start.line,
- col: start.col + 1
- };
- this.linePos = {
- start,
- end
- };
- }
-
- delete this.offset;
- } else {
- this.range = this.source.range;
- this.linePos = this.source.rangeAsLinePos;
- }
-
- if (this.linePos) {
- const {
- line,
- col
- } = this.linePos.start;
- this.message += ` at line ${line}, column ${col}`;
- const ctx = cst && getPrettyContext(this.linePos, cst);
- if (ctx) this.message += `:\n\n${ctx}\n`;
- }
-
- delete this.source;
- }
-
-}
-class YAMLReferenceError extends YAMLError {
- constructor(source, message) {
- super('YAMLReferenceError', source, message);
- }
-
-}
-class YAMLSemanticError extends YAMLError {
- constructor(source, message) {
- super('YAMLSemanticError', source, message);
- }
-
-}
-class YAMLSyntaxError extends YAMLError {
- constructor(source, message) {
- super('YAMLSyntaxError', source, message);
- }
-
-}
-class YAMLWarning extends YAMLError {
- constructor(source, message) {
- super('YAMLWarning', source, message);
- }
-
-}
-
-function _defineProperty(obj, key, value) {
- if (key in obj) {
- Object.defineProperty(obj, key, {
- value: value,
- enumerable: true,
- configurable: true,
- writable: true
- });
- } else {
- obj[key] = value;
- }
-
- return obj;
-}
-
-class PlainValue extends Node$2 {
- static endOfLine(src, start, inFlow) {
- let ch = src[start];
- let offset = start;
-
- while (ch && ch !== '\n') {
- if (inFlow && (ch === '[' || ch === ']' || ch === '{' || ch === '}' || ch === ',')) break;
- const next = src[offset + 1];
- if (ch === ':' && (!next || next === '\n' || next === '\t' || next === ' ' || inFlow && next === ',')) break;
- if ((ch === ' ' || ch === '\t') && next === '#') break;
- offset += 1;
- ch = next;
- }
-
- return offset;
- }
-
- get strValue() {
- if (!this.valueRange || !this.context) return null;
- let {
- start,
- end
- } = this.valueRange;
- const {
- src
- } = this.context;
- let ch = src[end - 1];
-
- while (start < end && (ch === '\n' || ch === '\t' || ch === ' ')) ch = src[--end - 1];
-
- let str = '';
-
- for (let i = start; i < end; ++i) {
- const ch = src[i];
-
- if (ch === '\n') {
- const {
- fold,
- offset
- } = Node$2.foldNewline(src, i, -1);
- str += fold;
- i = offset;
- } else if (ch === ' ' || ch === '\t') {
- // trim trailing whitespace
- const wsStart = i;
- let next = src[i + 1];
-
- while (i < end && (next === ' ' || next === '\t')) {
- i += 1;
- next = src[i + 1];
- }
-
- if (next !== '\n') str += i > wsStart ? src.slice(wsStart, i + 1) : ch;
- } else {
- str += ch;
- }
- }
-
- const ch0 = src[start];
-
- switch (ch0) {
- case '\t':
- {
- const msg = 'Plain value cannot start with a tab character';
- const errors = [new YAMLSemanticError(this, msg)];
- return {
- errors,
- str
- };
- }
-
- case '@':
- case '`':
- {
- const msg = `Plain value cannot start with reserved character ${ch0}`;
- const errors = [new YAMLSemanticError(this, msg)];
- return {
- errors,
- str
- };
- }
-
- default:
- return str;
- }
- }
-
- parseBlockValue(start) {
- const {
- indent,
- inFlow,
- src
- } = this.context;
- let offset = start;
- let valueEnd = start;
-
- for (let ch = src[offset]; ch === '\n'; ch = src[offset]) {
- if (Node$2.atDocumentBoundary(src, offset + 1)) break;
- const end = Node$2.endOfBlockIndent(src, indent, offset + 1);
- if (end === null || src[end] === '#') break;
-
- if (src[end] === '\n') {
- offset = end;
- } else {
- valueEnd = PlainValue.endOfLine(src, end, inFlow);
- offset = valueEnd;
- }
- }
-
- if (this.valueRange.isEmpty()) this.valueRange.start = start;
- this.valueRange.end = valueEnd;
- return valueEnd;
- }
- /**
- * Parses a plain value from the source
- *
- * Accepted forms are:
- * ```
- * #comment
- *
- * first line
- *
- * first line #comment
- *
- * first line
- * block
- * lines
- *
- * #comment
- * block
- * lines
- * ```
- * where block lines are empty or have an indent level greater than `indent`.
- *
- * @param {ParseContext} context
- * @param {number} start - Index of first character
- * @returns {number} - Index of the character after this scalar, may be `\n`
- */
-
-
- parse(context, start) {
- this.context = context;
- const {
- inFlow,
- src
- } = context;
- let offset = start;
- const ch = src[offset];
-
- if (ch && ch !== '#' && ch !== '\n') {
- offset = PlainValue.endOfLine(src, start, inFlow);
- }
-
- this.valueRange = new Range(start, offset);
- offset = Node$2.endOfWhiteSpace(src, offset);
- offset = this.parseComment(offset);
-
- if (!this.hasComment || this.valueRange.isEmpty()) {
- offset = this.parseBlockValue(offset);
- }
-
- return offset;
- }
-
-}
-
-var Char_1 = Char;
-var Node_1$1 = Node$2;
-var PlainValue_1 = PlainValue;
-var Range_1 = Range;
-var Type_1 = Type;
-var YAMLError_1 = YAMLError;
-var YAMLReferenceError_1 = YAMLReferenceError;
-var YAMLSemanticError_1 = YAMLSemanticError;
-var YAMLSyntaxError_1 = YAMLSyntaxError;
-var YAMLWarning_1 = YAMLWarning;
-var _defineProperty_1 = _defineProperty;
-var defaultTagPrefix_1 = defaultTagPrefix;
-var defaultTags_1 = defaultTags;
-
-var PlainValueEc8e588e = {
- Char: Char_1,
- Node: Node_1$1,
- PlainValue: PlainValue_1,
- Range: Range_1,
- Type: Type_1,
- YAMLError: YAMLError_1,
- YAMLReferenceError: YAMLReferenceError_1,
- YAMLSemanticError: YAMLSemanticError_1,
- YAMLSyntaxError: YAMLSyntaxError_1,
- YAMLWarning: YAMLWarning_1,
- _defineProperty: _defineProperty_1,
- defaultTagPrefix: defaultTagPrefix_1,
- defaultTags: defaultTags_1
-};
-
-class BlankLine extends PlainValueEc8e588e.Node {
- constructor() {
- super(PlainValueEc8e588e.Type.BLANK_LINE);
- }
- /* istanbul ignore next */
-
-
- get includesTrailingLines() {
- // This is never called from anywhere, but if it were,
- // this is the value it should return.
- return true;
- }
- /**
- * Parses a blank line from the source
- *
- * @param {ParseContext} context
- * @param {number} start - Index of first \n character
- * @returns {number} - Index of the character after this
- */
-
-
- parse(context, start) {
- this.context = context;
- this.range = new PlainValueEc8e588e.Range(start, start + 1);
- return start + 1;
- }
-
-}
-
-class CollectionItem extends PlainValueEc8e588e.Node {
- constructor(type, props) {
- super(type, props);
- this.node = null;
- }
-
- get includesTrailingLines() {
- return !!this.node && this.node.includesTrailingLines;
- }
- /**
- * @param {ParseContext} context
- * @param {number} start - Index of first character
- * @returns {number} - Index of the character after this
- */
-
-
- parse(context, start) {
- this.context = context;
- const {
- parseNode,
- src
- } = context;
- let {
- atLineStart,
- lineStart
- } = context;
- if (!atLineStart && this.type === PlainValueEc8e588e.Type.SEQ_ITEM) this.error = new PlainValueEc8e588e.YAMLSemanticError(this, 'Sequence items must not have preceding content on the same line');
- const indent = atLineStart ? start - lineStart : context.indent;
- let offset = PlainValueEc8e588e.Node.endOfWhiteSpace(src, start + 1);
- let ch = src[offset];
- const inlineComment = ch === '#';
- const comments = [];
- let blankLine = null;
-
- while (ch === '\n' || ch === '#') {
- if (ch === '#') {
- const end = PlainValueEc8e588e.Node.endOfLine(src, offset + 1);
- comments.push(new PlainValueEc8e588e.Range(offset, end));
- offset = end;
- } else {
- atLineStart = true;
- lineStart = offset + 1;
- const wsEnd = PlainValueEc8e588e.Node.endOfWhiteSpace(src, lineStart);
-
- if (src[wsEnd] === '\n' && comments.length === 0) {
- blankLine = new BlankLine();
- lineStart = blankLine.parse({
- src
- }, lineStart);
- }
-
- offset = PlainValueEc8e588e.Node.endOfIndent(src, lineStart);
- }
-
- ch = src[offset];
- }
-
- if (PlainValueEc8e588e.Node.nextNodeIsIndented(ch, offset - (lineStart + indent), this.type !== PlainValueEc8e588e.Type.SEQ_ITEM)) {
- this.node = parseNode({
- atLineStart,
- inCollection: false,
- indent,
- lineStart,
- parent: this
- }, offset);
- } else if (ch && lineStart > start + 1) {
- offset = lineStart - 1;
- }
-
- if (this.node) {
- if (blankLine) {
- // Only blank lines preceding non-empty nodes are captured. Note that
- // this means that collection item range start indices do not always
- // increase monotonically. -- eemeli/yaml#126
- const items = context.parent.items || context.parent.contents;
- if (items) items.push(blankLine);
- }
-
- if (comments.length) Array.prototype.push.apply(this.props, comments);
- offset = this.node.range.end;
- } else {
- if (inlineComment) {
- const c = comments[0];
- this.props.push(c);
- offset = c.end;
- } else {
- offset = PlainValueEc8e588e.Node.endOfLine(src, start + 1);
- }
- }
-
- const end = this.node ? this.node.valueRange.end : offset;
- this.valueRange = new PlainValueEc8e588e.Range(start, end);
- return offset;
- }
-
- setOrigRanges(cr, offset) {
- offset = super.setOrigRanges(cr, offset);
- return this.node ? this.node.setOrigRanges(cr, offset) : offset;
- }
-
- toString() {
- const {
- context: {
- src
- },
- node,
- range,
- value
- } = this;
- if (value != null) return value;
- const str = node ? src.slice(range.start, node.range.start) + String(node) : src.slice(range.start, range.end);
- return PlainValueEc8e588e.Node.addStringTerminator(src, range.end, str);
- }
-
-}
-
-class Comment extends PlainValueEc8e588e.Node {
- constructor() {
- super(PlainValueEc8e588e.Type.COMMENT);
- }
- /**
- * Parses a comment line from the source
- *
- * @param {ParseContext} context
- * @param {number} start - Index of first character
- * @returns {number} - Index of the character after this scalar
- */
-
-
- parse(context, start) {
- this.context = context;
- const offset = this.parseComment(start);
- this.range = new PlainValueEc8e588e.Range(start, offset);
- return offset;
- }
-
-}
-
-function grabCollectionEndComments(node) {
- let cnode = node;
-
- while (cnode instanceof CollectionItem) cnode = cnode.node;
-
- if (!(cnode instanceof Collection$1)) return null;
- const len = cnode.items.length;
- let ci = -1;
-
- for (let i = len - 1; i >= 0; --i) {
- const n = cnode.items[i];
-
- if (n.type === PlainValueEc8e588e.Type.COMMENT) {
- // Keep sufficiently indented comments with preceding node
- const {
- indent,
- lineStart
- } = n.context;
- if (indent > 0 && n.range.start >= lineStart + indent) break;
- ci = i;
- } else if (n.type === PlainValueEc8e588e.Type.BLANK_LINE) ci = i;else break;
- }
-
- if (ci === -1) return null;
- const ca = cnode.items.splice(ci, len - ci);
- const prevEnd = ca[0].range.start;
-
- while (true) {
- cnode.range.end = prevEnd;
- if (cnode.valueRange && cnode.valueRange.end > prevEnd) cnode.valueRange.end = prevEnd;
- if (cnode === node) break;
- cnode = cnode.context.parent;
- }
-
- return ca;
-}
-class Collection$1 extends PlainValueEc8e588e.Node {
- static nextContentHasIndent(src, offset, indent) {
- const lineStart = PlainValueEc8e588e.Node.endOfLine(src, offset) + 1;
- offset = PlainValueEc8e588e.Node.endOfWhiteSpace(src, lineStart);
- const ch = src[offset];
- if (!ch) return false;
- if (offset >= lineStart + indent) return true;
- if (ch !== '#' && ch !== '\n') return false;
- return Collection$1.nextContentHasIndent(src, offset, indent);
- }
-
- constructor(firstItem) {
- super(firstItem.type === PlainValueEc8e588e.Type.SEQ_ITEM ? PlainValueEc8e588e.Type.SEQ : PlainValueEc8e588e.Type.MAP);
-
- for (let i = firstItem.props.length - 1; i >= 0; --i) {
- if (firstItem.props[i].start < firstItem.context.lineStart) {
- // props on previous line are assumed by the collection
- this.props = firstItem.props.slice(0, i + 1);
- firstItem.props = firstItem.props.slice(i + 1);
- const itemRange = firstItem.props[0] || firstItem.valueRange;
- firstItem.range.start = itemRange.start;
- break;
- }
- }
-
- this.items = [firstItem];
- const ec = grabCollectionEndComments(firstItem);
- if (ec) Array.prototype.push.apply(this.items, ec);
- }
-
- get includesTrailingLines() {
- return this.items.length > 0;
- }
- /**
- * @param {ParseContext} context
- * @param {number} start - Index of first character
- * @returns {number} - Index of the character after this
- */
-
-
- parse(context, start) {
- this.context = context;
- const {
- parseNode,
- src
- } = context; // It's easier to recalculate lineStart here rather than tracking down the
- // last context from which to read it -- eemeli/yaml#2
-
- let lineStart = PlainValueEc8e588e.Node.startOfLine(src, start);
- const firstItem = this.items[0]; // First-item context needs to be correct for later comment handling
- // -- eemeli/yaml#17
-
- firstItem.context.parent = this;
- this.valueRange = PlainValueEc8e588e.Range.copy(firstItem.valueRange);
- const indent = firstItem.range.start - firstItem.context.lineStart;
- let offset = start;
- offset = PlainValueEc8e588e.Node.normalizeOffset(src, offset);
- let ch = src[offset];
- let atLineStart = PlainValueEc8e588e.Node.endOfWhiteSpace(src, lineStart) === offset;
- let prevIncludesTrailingLines = false;
-
- while (ch) {
- while (ch === '\n' || ch === '#') {
- if (atLineStart && ch === '\n' && !prevIncludesTrailingLines) {
- const blankLine = new BlankLine();
- offset = blankLine.parse({
- src
- }, offset);
- this.valueRange.end = offset;
-
- if (offset >= src.length) {
- ch = null;
- break;
- }
-
- this.items.push(blankLine);
- offset -= 1; // blankLine.parse() consumes terminal newline
- } else if (ch === '#') {
- if (offset < lineStart + indent && !Collection$1.nextContentHasIndent(src, offset, indent)) {
- return offset;
- }
-
- const comment = new Comment();
- offset = comment.parse({
- indent,
- lineStart,
- src
- }, offset);
- this.items.push(comment);
- this.valueRange.end = offset;
-
- if (offset >= src.length) {
- ch = null;
- break;
- }
- }
-
- lineStart = offset + 1;
- offset = PlainValueEc8e588e.Node.endOfIndent(src, lineStart);
-
- if (PlainValueEc8e588e.Node.atBlank(src, offset)) {
- const wsEnd = PlainValueEc8e588e.Node.endOfWhiteSpace(src, offset);
- const next = src[wsEnd];
-
- if (!next || next === '\n' || next === '#') {
- offset = wsEnd;
- }
- }
-
- ch = src[offset];
- atLineStart = true;
- }
-
- if (!ch) {
- break;
- }
-
- if (offset !== lineStart + indent && (atLineStart || ch !== ':')) {
- if (offset < lineStart + indent) {
- if (lineStart > start) offset = lineStart;
- break;
- } else if (!this.error) {
- const msg = 'All collection items must start at the same column';
- this.error = new PlainValueEc8e588e.YAMLSyntaxError(this, msg);
- }
- }
-
- if (firstItem.type === PlainValueEc8e588e.Type.SEQ_ITEM) {
- if (ch !== '-') {
- if (lineStart > start) offset = lineStart;
- break;
- }
- } else if (ch === '-' && !this.error) {
- // map key may start with -, as long as it's followed by a non-whitespace char
- const next = src[offset + 1];
-
- if (!next || next === '\n' || next === '\t' || next === ' ') {
- const msg = 'A collection cannot be both a mapping and a sequence';
- this.error = new PlainValueEc8e588e.YAMLSyntaxError(this, msg);
- }
- }
-
- const node = parseNode({
- atLineStart,
- inCollection: true,
- indent,
- lineStart,
- parent: this
- }, offset);
- if (!node) return offset; // at next document start
-
- this.items.push(node);
- this.valueRange.end = node.valueRange.end;
- offset = PlainValueEc8e588e.Node.normalizeOffset(src, node.range.end);
- ch = src[offset];
- atLineStart = false;
- prevIncludesTrailingLines = node.includesTrailingLines; // Need to reset lineStart and atLineStart here if preceding node's range
- // has advanced to check the current line's indentation level
- // -- eemeli/yaml#10 & eemeli/yaml#38
-
- if (ch) {
- let ls = offset - 1;
- let prev = src[ls];
-
- while (prev === ' ' || prev === '\t') prev = src[--ls];
-
- if (prev === '\n') {
- lineStart = ls + 1;
- atLineStart = true;
- }
- }
-
- const ec = grabCollectionEndComments(node);
- if (ec) Array.prototype.push.apply(this.items, ec);
- }
-
- return offset;
- }
-
- setOrigRanges(cr, offset) {
- offset = super.setOrigRanges(cr, offset);
- this.items.forEach(node => {
- offset = node.setOrigRanges(cr, offset);
- });
- return offset;
- }
-
- toString() {
- const {
- context: {
- src
- },
- items,
- range,
- value
- } = this;
- if (value != null) return value;
- let str = src.slice(range.start, items[0].range.start) + String(items[0]);
-
- for (let i = 1; i < items.length; ++i) {
- const item = items[i];
- const {
- atLineStart,
- indent
- } = item.context;
- if (atLineStart) for (let i = 0; i < indent; ++i) str += ' ';
- str += String(item);
- }
-
- return PlainValueEc8e588e.Node.addStringTerminator(src, range.end, str);
- }
-
-}
-
-class Directive extends PlainValueEc8e588e.Node {
- constructor() {
- super(PlainValueEc8e588e.Type.DIRECTIVE);
- this.name = null;
- }
-
- get parameters() {
- const raw = this.rawValue;
- return raw ? raw.trim().split(/[ \t]+/) : [];
- }
-
- parseName(start) {
- const {
- src
- } = this.context;
- let offset = start;
- let ch = src[offset];
-
- while (ch && ch !== '\n' && ch !== '\t' && ch !== ' ') ch = src[offset += 1];
-
- this.name = src.slice(start, offset);
- return offset;
- }
-
- parseParameters(start) {
- const {
- src
- } = this.context;
- let offset = start;
- let ch = src[offset];
-
- while (ch && ch !== '\n' && ch !== '#') ch = src[offset += 1];
-
- this.valueRange = new PlainValueEc8e588e.Range(start, offset);
- return offset;
- }
-
- parse(context, start) {
- this.context = context;
- let offset = this.parseName(start + 1);
- offset = this.parseParameters(offset);
- offset = this.parseComment(offset);
- this.range = new PlainValueEc8e588e.Range(start, offset);
- return offset;
- }
-
-}
-
-class Document$3 extends PlainValueEc8e588e.Node {
- static startCommentOrEndBlankLine(src, start) {
- const offset = PlainValueEc8e588e.Node.endOfWhiteSpace(src, start);
- const ch = src[offset];
- return ch === '#' || ch === '\n' ? offset : start;
- }
-
- constructor() {
- super(PlainValueEc8e588e.Type.DOCUMENT);
- this.directives = null;
- this.contents = null;
- this.directivesEndMarker = null;
- this.documentEndMarker = null;
- }
-
- parseDirectives(start) {
- const {
- src
- } = this.context;
- this.directives = [];
- let atLineStart = true;
- let hasDirectives = false;
- let offset = start;
-
- while (!PlainValueEc8e588e.Node.atDocumentBoundary(src, offset, PlainValueEc8e588e.Char.DIRECTIVES_END)) {
- offset = Document$3.startCommentOrEndBlankLine(src, offset);
-
- switch (src[offset]) {
- case '\n':
- if (atLineStart) {
- const blankLine = new BlankLine();
- offset = blankLine.parse({
- src
- }, offset);
-
- if (offset < src.length) {
- this.directives.push(blankLine);
- }
- } else {
- offset += 1;
- atLineStart = true;
- }
-
- break;
-
- case '#':
- {
- const comment = new Comment();
- offset = comment.parse({
- src
- }, offset);
- this.directives.push(comment);
- atLineStart = false;
- }
- break;
-
- case '%':
- {
- const directive = new Directive();
- offset = directive.parse({
- parent: this,
- src
- }, offset);
- this.directives.push(directive);
- hasDirectives = true;
- atLineStart = false;
- }
- break;
-
- default:
- if (hasDirectives) {
- this.error = new PlainValueEc8e588e.YAMLSemanticError(this, 'Missing directives-end indicator line');
- } else if (this.directives.length > 0) {
- this.contents = this.directives;
- this.directives = [];
- }
-
- return offset;
- }
- }
-
- if (src[offset]) {
- this.directivesEndMarker = new PlainValueEc8e588e.Range(offset, offset + 3);
- return offset + 3;
- }
-
- if (hasDirectives) {
- this.error = new PlainValueEc8e588e.YAMLSemanticError(this, 'Missing directives-end indicator line');
- } else if (this.directives.length > 0) {
- this.contents = this.directives;
- this.directives = [];
- }
-
- return offset;
- }
-
- parseContents(start) {
- const {
- parseNode,
- src
- } = this.context;
- if (!this.contents) this.contents = [];
- let lineStart = start;
-
- while (src[lineStart - 1] === '-') lineStart -= 1;
-
- let offset = PlainValueEc8e588e.Node.endOfWhiteSpace(src, start);
- let atLineStart = lineStart === start;
- this.valueRange = new PlainValueEc8e588e.Range(offset);
-
- while (!PlainValueEc8e588e.Node.atDocumentBoundary(src, offset, PlainValueEc8e588e.Char.DOCUMENT_END)) {
- switch (src[offset]) {
- case '\n':
- if (atLineStart) {
- const blankLine = new BlankLine();
- offset = blankLine.parse({
- src
- }, offset);
-
- if (offset < src.length) {
- this.contents.push(blankLine);
- }
- } else {
- offset += 1;
- atLineStart = true;
- }
-
- lineStart = offset;
- break;
-
- case '#':
- {
- const comment = new Comment();
- offset = comment.parse({
- src
- }, offset);
- this.contents.push(comment);
- atLineStart = false;
- }
- break;
-
- default:
- {
- const iEnd = PlainValueEc8e588e.Node.endOfIndent(src, offset);
- const context = {
- atLineStart,
- indent: -1,
- inFlow: false,
- inCollection: false,
- lineStart,
- parent: this
- };
- const node = parseNode(context, iEnd);
- if (!node) return this.valueRange.end = iEnd; // at next document start
-
- this.contents.push(node);
- offset = node.range.end;
- atLineStart = false;
- const ec = grabCollectionEndComments(node);
- if (ec) Array.prototype.push.apply(this.contents, ec);
- }
- }
-
- offset = Document$3.startCommentOrEndBlankLine(src, offset);
- }
-
- this.valueRange.end = offset;
-
- if (src[offset]) {
- this.documentEndMarker = new PlainValueEc8e588e.Range(offset, offset + 3);
- offset += 3;
-
- if (src[offset]) {
- offset = PlainValueEc8e588e.Node.endOfWhiteSpace(src, offset);
-
- if (src[offset] === '#') {
- const comment = new Comment();
- offset = comment.parse({
- src
- }, offset);
- this.contents.push(comment);
- }
-
- switch (src[offset]) {
- case '\n':
- offset += 1;
- break;
-
- case undefined:
- break;
-
- default:
- this.error = new PlainValueEc8e588e.YAMLSyntaxError(this, 'Document end marker line cannot have a non-comment suffix');
- }
- }
- }
-
- return offset;
- }
- /**
- * @param {ParseContext} context
- * @param {number} start - Index of first character
- * @returns {number} - Index of the character after this
- */
-
-
- parse(context, start) {
- context.root = this;
- this.context = context;
- const {
- src
- } = context;
- let offset = src.charCodeAt(start) === 0xfeff ? start + 1 : start; // skip BOM
-
- offset = this.parseDirectives(offset);
- offset = this.parseContents(offset);
- return offset;
- }
-
- setOrigRanges(cr, offset) {
- offset = super.setOrigRanges(cr, offset);
- this.directives.forEach(node => {
- offset = node.setOrigRanges(cr, offset);
- });
- if (this.directivesEndMarker) offset = this.directivesEndMarker.setOrigRange(cr, offset);
- this.contents.forEach(node => {
- offset = node.setOrigRanges(cr, offset);
- });
- if (this.documentEndMarker) offset = this.documentEndMarker.setOrigRange(cr, offset);
- return offset;
- }
-
- toString() {
- const {
- contents,
- directives,
- value
- } = this;
- if (value != null) return value;
- let str = directives.join('');
-
- if (contents.length > 0) {
- if (directives.length > 0 || contents[0].type === PlainValueEc8e588e.Type.COMMENT) str += '---\n';
- str += contents.join('');
- }
-
- if (str[str.length - 1] !== '\n') str += '\n';
- return str;
- }
-
-}
-
-class Alias$1 extends PlainValueEc8e588e.Node {
- /**
- * Parses an *alias from the source
- *
- * @param {ParseContext} context
- * @param {number} start - Index of first character
- * @returns {number} - Index of the character after this scalar
- */
- parse(context, start) {
- this.context = context;
- const {
- src
- } = context;
- let offset = PlainValueEc8e588e.Node.endOfIdentifier(src, start + 1);
- this.valueRange = new PlainValueEc8e588e.Range(start + 1, offset);
- offset = PlainValueEc8e588e.Node.endOfWhiteSpace(src, offset);
- offset = this.parseComment(offset);
- return offset;
- }
-
-}
-
-const Chomp = {
- CLIP: 'CLIP',
- KEEP: 'KEEP',
- STRIP: 'STRIP'
-};
-class BlockValue extends PlainValueEc8e588e.Node {
- constructor(type, props) {
- super(type, props);
- this.blockIndent = null;
- this.chomping = Chomp.CLIP;
- this.header = null;
- }
-
- get includesTrailingLines() {
- return this.chomping === Chomp.KEEP;
- }
-
- get strValue() {
- if (!this.valueRange || !this.context) return null;
- let {
- start,
- end
- } = this.valueRange;
- const {
- indent,
- src
- } = this.context;
- if (this.valueRange.isEmpty()) return '';
- let lastNewLine = null;
- let ch = src[end - 1];
-
- while (ch === '\n' || ch === '\t' || ch === ' ') {
- end -= 1;
-
- if (end <= start) {
- if (this.chomping === Chomp.KEEP) break;else return ''; // probably never happens
- }
-
- if (ch === '\n') lastNewLine = end;
- ch = src[end - 1];
- }
-
- let keepStart = end + 1;
-
- if (lastNewLine) {
- if (this.chomping === Chomp.KEEP) {
- keepStart = lastNewLine;
- end = this.valueRange.end;
- } else {
- end = lastNewLine;
- }
- }
-
- const bi = indent + this.blockIndent;
- const folded = this.type === PlainValueEc8e588e.Type.BLOCK_FOLDED;
- let atStart = true;
- let str = '';
- let sep = '';
- let prevMoreIndented = false;
-
- for (let i = start; i < end; ++i) {
- for (let j = 0; j < bi; ++j) {
- if (src[i] !== ' ') break;
- i += 1;
- }
-
- const ch = src[i];
-
- if (ch === '\n') {
- if (sep === '\n') str += '\n';else sep = '\n';
- } else {
- const lineEnd = PlainValueEc8e588e.Node.endOfLine(src, i);
- const line = src.slice(i, lineEnd);
- i = lineEnd;
-
- if (folded && (ch === ' ' || ch === '\t') && i < keepStart) {
- if (sep === ' ') sep = '\n';else if (!prevMoreIndented && !atStart && sep === '\n') sep = '\n\n';
- str += sep + line; //+ ((lineEnd < end && src[lineEnd]) || '')
-
- sep = lineEnd < end && src[lineEnd] || '';
- prevMoreIndented = true;
- } else {
- str += sep + line;
- sep = folded && i < keepStart ? ' ' : '\n';
- prevMoreIndented = false;
- }
-
- if (atStart && line !== '') atStart = false;
- }
- }
-
- return this.chomping === Chomp.STRIP ? str : str + '\n';
- }
-
- parseBlockHeader(start) {
- const {
- src
- } = this.context;
- let offset = start + 1;
- let bi = '';
-
- while (true) {
- const ch = src[offset];
-
- switch (ch) {
- case '-':
- this.chomping = Chomp.STRIP;
- break;
-
- case '+':
- this.chomping = Chomp.KEEP;
- break;
-
- case '0':
- case '1':
- case '2':
- case '3':
- case '4':
- case '5':
- case '6':
- case '7':
- case '8':
- case '9':
- bi += ch;
- break;
-
- default:
- this.blockIndent = Number(bi) || null;
- this.header = new PlainValueEc8e588e.Range(start, offset);
- return offset;
- }
-
- offset += 1;
- }
- }
-
- parseBlockValue(start) {
- const {
- indent,
- src
- } = this.context;
- const explicit = !!this.blockIndent;
- let offset = start;
- let valueEnd = start;
- let minBlockIndent = 1;
-
- for (let ch = src[offset]; ch === '\n'; ch = src[offset]) {
- offset += 1;
- if (PlainValueEc8e588e.Node.atDocumentBoundary(src, offset)) break;
- const end = PlainValueEc8e588e.Node.endOfBlockIndent(src, indent, offset); // should not include tab?
-
- if (end === null) break;
- const ch = src[end];
- const lineIndent = end - (offset + indent);
-
- if (!this.blockIndent) {
- // no explicit block indent, none yet detected
- if (src[end] !== '\n') {
- // first line with non-whitespace content
- if (lineIndent < minBlockIndent) {
- const msg = 'Block scalars with more-indented leading empty lines must use an explicit indentation indicator';
- this.error = new PlainValueEc8e588e.YAMLSemanticError(this, msg);
- }
-
- this.blockIndent = lineIndent;
- } else if (lineIndent > minBlockIndent) {
- // empty line with more whitespace
- minBlockIndent = lineIndent;
- }
- } else if (ch && ch !== '\n' && lineIndent < this.blockIndent) {
- if (src[end] === '#') break;
-
- if (!this.error) {
- const src = explicit ? 'explicit indentation indicator' : 'first line';
- const msg = `Block scalars must not be less indented than their ${src}`;
- this.error = new PlainValueEc8e588e.YAMLSemanticError(this, msg);
- }
- }
-
- if (src[end] === '\n') {
- offset = end;
- } else {
- offset = valueEnd = PlainValueEc8e588e.Node.endOfLine(src, end);
- }
- }
-
- if (this.chomping !== Chomp.KEEP) {
- offset = src[valueEnd] ? valueEnd + 1 : valueEnd;
- }
-
- this.valueRange = new PlainValueEc8e588e.Range(start + 1, offset);
- return offset;
- }
- /**
- * Parses a block value from the source
- *
- * Accepted forms are:
- * ```
- * BS
- * block
- * lines
- *
- * BS #comment
- * block
- * lines
- * ```
- * where the block style BS matches the regexp `[|>][-+1-9]*` and block lines
- * are empty or have an indent level greater than `indent`.
- *
- * @param {ParseContext} context
- * @param {number} start - Index of first character
- * @returns {number} - Index of the character after this block
- */
-
-
- parse(context, start) {
- this.context = context;
- const {
- src
- } = context;
- let offset = this.parseBlockHeader(start);
- offset = PlainValueEc8e588e.Node.endOfWhiteSpace(src, offset);
- offset = this.parseComment(offset);
- offset = this.parseBlockValue(offset);
- return offset;
- }
-
- setOrigRanges(cr, offset) {
- offset = super.setOrigRanges(cr, offset);
- return this.header ? this.header.setOrigRange(cr, offset) : offset;
- }
-
-}
-
-class FlowCollection extends PlainValueEc8e588e.Node {
- constructor(type, props) {
- super(type, props);
- this.items = null;
- }
-
- prevNodeIsJsonLike(idx = this.items.length) {
- const node = this.items[idx - 1];
- return !!node && (node.jsonLike || node.type === PlainValueEc8e588e.Type.COMMENT && this.prevNodeIsJsonLike(idx - 1));
- }
- /**
- * @param {ParseContext} context
- * @param {number} start - Index of first character
- * @returns {number} - Index of the character after this
- */
-
-
- parse(context, start) {
- this.context = context;
- const {
- parseNode,
- src
- } = context;
- let {
- indent,
- lineStart
- } = context;
- let char = src[start]; // { or [
-
- this.items = [{
- char,
- offset: start
- }];
- let offset = PlainValueEc8e588e.Node.endOfWhiteSpace(src, start + 1);
- char = src[offset];
-
- while (char && char !== ']' && char !== '}') {
- switch (char) {
- case '\n':
- {
- lineStart = offset + 1;
- const wsEnd = PlainValueEc8e588e.Node.endOfWhiteSpace(src, lineStart);
-
- if (src[wsEnd] === '\n') {
- const blankLine = new BlankLine();
- lineStart = blankLine.parse({
- src
- }, lineStart);
- this.items.push(blankLine);
- }
-
- offset = PlainValueEc8e588e.Node.endOfIndent(src, lineStart);
-
- if (offset <= lineStart + indent) {
- char = src[offset];
-
- if (offset < lineStart + indent || char !== ']' && char !== '}') {
- const msg = 'Insufficient indentation in flow collection';
- this.error = new PlainValueEc8e588e.YAMLSemanticError(this, msg);
- }
- }
- }
- break;
-
- case ',':
- {
- this.items.push({
- char,
- offset
- });
- offset += 1;
- }
- break;
-
- case '#':
- {
- const comment = new Comment();
- offset = comment.parse({
- src
- }, offset);
- this.items.push(comment);
- }
- break;
-
- case '?':
- case ':':
- {
- const next = src[offset + 1];
-
- if (next === '\n' || next === '\t' || next === ' ' || next === ',' || // in-flow : after JSON-like key does not need to be followed by whitespace
- char === ':' && this.prevNodeIsJsonLike()) {
- this.items.push({
- char,
- offset
- });
- offset += 1;
- break;
- }
- }
- // fallthrough
-
- default:
- {
- const node = parseNode({
- atLineStart: false,
- inCollection: false,
- inFlow: true,
- indent: -1,
- lineStart,
- parent: this
- }, offset);
-
- if (!node) {
- // at next document start
- this.valueRange = new PlainValueEc8e588e.Range(start, offset);
- return offset;
- }
-
- this.items.push(node);
- offset = PlainValueEc8e588e.Node.normalizeOffset(src, node.range.end);
- }
- }
-
- offset = PlainValueEc8e588e.Node.endOfWhiteSpace(src, offset);
- char = src[offset];
- }
-
- this.valueRange = new PlainValueEc8e588e.Range(start, offset + 1);
-
- if (char) {
- this.items.push({
- char,
- offset
- });
- offset = PlainValueEc8e588e.Node.endOfWhiteSpace(src, offset + 1);
- offset = this.parseComment(offset);
- }
-
- return offset;
- }
-
- setOrigRanges(cr, offset) {
- offset = super.setOrigRanges(cr, offset);
- this.items.forEach(node => {
- if (node instanceof PlainValueEc8e588e.Node) {
- offset = node.setOrigRanges(cr, offset);
- } else if (cr.length === 0) {
- node.origOffset = node.offset;
- } else {
- let i = offset;
-
- while (i < cr.length) {
- if (cr[i] > node.offset) break;else ++i;
- }
-
- node.origOffset = node.offset + i;
- offset = i;
- }
- });
- return offset;
- }
-
- toString() {
- const {
- context: {
- src
- },
- items,
- range,
- value
- } = this;
- if (value != null) return value;
- const nodes = items.filter(item => item instanceof PlainValueEc8e588e.Node);
- let str = '';
- let prevEnd = range.start;
- nodes.forEach(node => {
- const prefix = src.slice(prevEnd, node.range.start);
- prevEnd = node.range.end;
- str += prefix + String(node);
-
- if (str[str.length - 1] === '\n' && src[prevEnd - 1] !== '\n' && src[prevEnd] === '\n') {
- // Comment range does not include the terminal newline, but its
- // stringified value does. Without this fix, newlines at comment ends
- // get duplicated.
- prevEnd += 1;
- }
- });
- str += src.slice(prevEnd, range.end);
- return PlainValueEc8e588e.Node.addStringTerminator(src, range.end, str);
- }
-
-}
-
-class QuoteDouble extends PlainValueEc8e588e.Node {
- static endOfQuote(src, offset) {
- let ch = src[offset];
-
- while (ch && ch !== '"') {
- offset += ch === '\\' ? 2 : 1;
- ch = src[offset];
- }
-
- return offset + 1;
- }
- /**
- * @returns {string | { str: string, errors: YAMLSyntaxError[] }}
- */
-
-
- get strValue() {
- if (!this.valueRange || !this.context) return null;
- const errors = [];
- const {
- start,
- end
- } = this.valueRange;
- const {
- indent,
- src
- } = this.context;
- if (src[end - 1] !== '"') errors.push(new PlainValueEc8e588e.YAMLSyntaxError(this, 'Missing closing "quote')); // Using String#replace is too painful with escaped newlines preceded by
- // escaped backslashes; also, this should be faster.
-
- let str = '';
-
- for (let i = start + 1; i < end - 1; ++i) {
- const ch = src[i];
-
- if (ch === '\n') {
- if (PlainValueEc8e588e.Node.atDocumentBoundary(src, i + 1)) errors.push(new PlainValueEc8e588e.YAMLSemanticError(this, 'Document boundary indicators are not allowed within string values'));
- const {
- fold,
- offset,
- error
- } = PlainValueEc8e588e.Node.foldNewline(src, i, indent);
- str += fold;
- i = offset;
- if (error) errors.push(new PlainValueEc8e588e.YAMLSemanticError(this, 'Multi-line double-quoted string needs to be sufficiently indented'));
- } else if (ch === '\\') {
- i += 1;
-
- switch (src[i]) {
- case '0':
- str += '\0';
- break;
- // null character
-
- case 'a':
- str += '\x07';
- break;
- // bell character
-
- case 'b':
- str += '\b';
- break;
- // backspace
-
- case 'e':
- str += '\x1b';
- break;
- // escape character
-
- case 'f':
- str += '\f';
- break;
- // form feed
-
- case 'n':
- str += '\n';
- break;
- // line feed
-
- case 'r':
- str += '\r';
- break;
- // carriage return
-
- case 't':
- str += '\t';
- break;
- // horizontal tab
-
- case 'v':
- str += '\v';
- break;
- // vertical tab
-
- case 'N':
- str += '\u0085';
- break;
- // Unicode next line
-
- case '_':
- str += '\u00a0';
- break;
- // Unicode non-breaking space
-
- case 'L':
- str += '\u2028';
- break;
- // Unicode line separator
-
- case 'P':
- str += '\u2029';
- break;
- // Unicode paragraph separator
-
- case ' ':
- str += ' ';
- break;
-
- case '"':
- str += '"';
- break;
-
- case '/':
- str += '/';
- break;
-
- case '\\':
- str += '\\';
- break;
-
- case '\t':
- str += '\t';
- break;
-
- case 'x':
- str += this.parseCharCode(i + 1, 2, errors);
- i += 2;
- break;
-
- case 'u':
- str += this.parseCharCode(i + 1, 4, errors);
- i += 4;
- break;
-
- case 'U':
- str += this.parseCharCode(i + 1, 8, errors);
- i += 8;
- break;
-
- case '\n':
- // skip escaped newlines, but still trim the following line
- while (src[i + 1] === ' ' || src[i + 1] === '\t') i += 1;
-
- break;
-
- default:
- errors.push(new PlainValueEc8e588e.YAMLSyntaxError(this, `Invalid escape sequence ${src.substr(i - 1, 2)}`));
- str += '\\' + src[i];
- }
- } else if (ch === ' ' || ch === '\t') {
- // trim trailing whitespace
- const wsStart = i;
- let next = src[i + 1];
-
- while (next === ' ' || next === '\t') {
- i += 1;
- next = src[i + 1];
- }
-
- if (next !== '\n') str += i > wsStart ? src.slice(wsStart, i + 1) : ch;
- } else {
- str += ch;
- }
- }
-
- return errors.length > 0 ? {
- errors,
- str
- } : str;
- }
-
- parseCharCode(offset, length, errors) {
- const {
- src
- } = this.context;
- const cc = src.substr(offset, length);
- const ok = cc.length === length && /^[0-9a-fA-F]+$/.test(cc);
- const code = ok ? parseInt(cc, 16) : NaN;
-
- if (isNaN(code)) {
- errors.push(new PlainValueEc8e588e.YAMLSyntaxError(this, `Invalid escape sequence ${src.substr(offset - 2, length + 2)}`));
- return src.substr(offset - 2, length + 2);
- }
-
- return String.fromCodePoint(code);
- }
- /**
- * Parses a "double quoted" value from the source
- *
- * @param {ParseContext} context
- * @param {number} start - Index of first character
- * @returns {number} - Index of the character after this scalar
- */
-
-
- parse(context, start) {
- this.context = context;
- const {
- src
- } = context;
- let offset = QuoteDouble.endOfQuote(src, start + 1);
- this.valueRange = new PlainValueEc8e588e.Range(start, offset);
- offset = PlainValueEc8e588e.Node.endOfWhiteSpace(src, offset);
- offset = this.parseComment(offset);
- return offset;
- }
-
-}
-
-class QuoteSingle extends PlainValueEc8e588e.Node {
- static endOfQuote(src, offset) {
- let ch = src[offset];
-
- while (ch) {
- if (ch === "'") {
- if (src[offset + 1] !== "'") break;
- ch = src[offset += 2];
- } else {
- ch = src[offset += 1];
- }
- }
-
- return offset + 1;
- }
- /**
- * @returns {string | { str: string, errors: YAMLSyntaxError[] }}
- */
-
-
- get strValue() {
- if (!this.valueRange || !this.context) return null;
- const errors = [];
- const {
- start,
- end
- } = this.valueRange;
- const {
- indent,
- src
- } = this.context;
- if (src[end - 1] !== "'") errors.push(new PlainValueEc8e588e.YAMLSyntaxError(this, "Missing closing 'quote"));
- let str = '';
-
- for (let i = start + 1; i < end - 1; ++i) {
- const ch = src[i];
-
- if (ch === '\n') {
- if (PlainValueEc8e588e.Node.atDocumentBoundary(src, i + 1)) errors.push(new PlainValueEc8e588e.YAMLSemanticError(this, 'Document boundary indicators are not allowed within string values'));
- const {
- fold,
- offset,
- error
- } = PlainValueEc8e588e.Node.foldNewline(src, i, indent);
- str += fold;
- i = offset;
- if (error) errors.push(new PlainValueEc8e588e.YAMLSemanticError(this, 'Multi-line single-quoted string needs to be sufficiently indented'));
- } else if (ch === "'") {
- str += ch;
- i += 1;
- if (src[i] !== "'") errors.push(new PlainValueEc8e588e.YAMLSyntaxError(this, 'Unescaped single quote? This should not happen.'));
- } else if (ch === ' ' || ch === '\t') {
- // trim trailing whitespace
- const wsStart = i;
- let next = src[i + 1];
-
- while (next === ' ' || next === '\t') {
- i += 1;
- next = src[i + 1];
- }
-
- if (next !== '\n') str += i > wsStart ? src.slice(wsStart, i + 1) : ch;
- } else {
- str += ch;
- }
- }
-
- return errors.length > 0 ? {
- errors,
- str
- } : str;
- }
- /**
- * Parses a 'single quoted' value from the source
- *
- * @param {ParseContext} context
- * @param {number} start - Index of first character
- * @returns {number} - Index of the character after this scalar
- */
-
-
- parse(context, start) {
- this.context = context;
- const {
- src
- } = context;
- let offset = QuoteSingle.endOfQuote(src, start + 1);
- this.valueRange = new PlainValueEc8e588e.Range(start, offset);
- offset = PlainValueEc8e588e.Node.endOfWhiteSpace(src, offset);
- offset = this.parseComment(offset);
- return offset;
- }
-
-}
-
-function createNewNode(type, props) {
- switch (type) {
- case PlainValueEc8e588e.Type.ALIAS:
- return new Alias$1(type, props);
-
- case PlainValueEc8e588e.Type.BLOCK_FOLDED:
- case PlainValueEc8e588e.Type.BLOCK_LITERAL:
- return new BlockValue(type, props);
-
- case PlainValueEc8e588e.Type.FLOW_MAP:
- case PlainValueEc8e588e.Type.FLOW_SEQ:
- return new FlowCollection(type, props);
-
- case PlainValueEc8e588e.Type.MAP_KEY:
- case PlainValueEc8e588e.Type.MAP_VALUE:
- case PlainValueEc8e588e.Type.SEQ_ITEM:
- return new CollectionItem(type, props);
-
- case PlainValueEc8e588e.Type.COMMENT:
- case PlainValueEc8e588e.Type.PLAIN:
- return new PlainValueEc8e588e.PlainValue(type, props);
-
- case PlainValueEc8e588e.Type.QUOTE_DOUBLE:
- return new QuoteDouble(type, props);
-
- case PlainValueEc8e588e.Type.QUOTE_SINGLE:
- return new QuoteSingle(type, props);
-
- /* istanbul ignore next */
-
- default:
- return null;
- // should never happen
- }
-}
-/**
- * @param {boolean} atLineStart - Node starts at beginning of line
- * @param {boolean} inFlow - true if currently in a flow context
- * @param {boolean} inCollection - true if currently in a collection context
- * @param {number} indent - Current level of indentation
- * @param {number} lineStart - Start of the current line
- * @param {Node} parent - The parent of the node
- * @param {string} src - Source of the YAML document
- */
-
-
-class ParseContext {
- static parseType(src, offset, inFlow) {
- switch (src[offset]) {
- case '*':
- return PlainValueEc8e588e.Type.ALIAS;
-
- case '>':
- return PlainValueEc8e588e.Type.BLOCK_FOLDED;
-
- case '|':
- return PlainValueEc8e588e.Type.BLOCK_LITERAL;
-
- case '{':
- return PlainValueEc8e588e.Type.FLOW_MAP;
-
- case '[':
- return PlainValueEc8e588e.Type.FLOW_SEQ;
-
- case '?':
- return !inFlow && PlainValueEc8e588e.Node.atBlank(src, offset + 1, true) ? PlainValueEc8e588e.Type.MAP_KEY : PlainValueEc8e588e.Type.PLAIN;
-
- case ':':
- return !inFlow && PlainValueEc8e588e.Node.atBlank(src, offset + 1, true) ? PlainValueEc8e588e.Type.MAP_VALUE : PlainValueEc8e588e.Type.PLAIN;
-
- case '-':
- return !inFlow && PlainValueEc8e588e.Node.atBlank(src, offset + 1, true) ? PlainValueEc8e588e.Type.SEQ_ITEM : PlainValueEc8e588e.Type.PLAIN;
-
- case '"':
- return PlainValueEc8e588e.Type.QUOTE_DOUBLE;
-
- case "'":
- return PlainValueEc8e588e.Type.QUOTE_SINGLE;
-
- default:
- return PlainValueEc8e588e.Type.PLAIN;
- }
- }
-
- constructor(orig = {}, {
- atLineStart,
- inCollection,
- inFlow,
- indent,
- lineStart,
- parent
- } = {}) {
- PlainValueEc8e588e._defineProperty(this, "parseNode", (overlay, start) => {
- if (PlainValueEc8e588e.Node.atDocumentBoundary(this.src, start)) return null;
- const context = new ParseContext(this, overlay);
- const {
- props,
- type,
- valueStart
- } = context.parseProps(start);
- const node = createNewNode(type, props);
- let offset = node.parse(context, valueStart);
- node.range = new PlainValueEc8e588e.Range(start, offset);
- /* istanbul ignore if */
-
- if (offset <= start) {
- // This should never happen, but if it does, let's make sure to at least
- // step one character forward to avoid a busy loop.
- node.error = new Error(`Node#parse consumed no characters`);
- node.error.parseEnd = offset;
- node.error.source = node;
- node.range.end = start + 1;
- }
-
- if (context.nodeStartsCollection(node)) {
- if (!node.error && !context.atLineStart && context.parent.type === PlainValueEc8e588e.Type.DOCUMENT) {
- node.error = new PlainValueEc8e588e.YAMLSyntaxError(node, 'Block collection must not have preceding content here (e.g. directives-end indicator)');
- }
-
- const collection = new Collection$1(node);
- offset = collection.parse(new ParseContext(context), offset);
- collection.range = new PlainValueEc8e588e.Range(start, offset);
- return collection;
- }
-
- return node;
- });
-
- this.atLineStart = atLineStart != null ? atLineStart : orig.atLineStart || false;
- this.inCollection = inCollection != null ? inCollection : orig.inCollection || false;
- this.inFlow = inFlow != null ? inFlow : orig.inFlow || false;
- this.indent = indent != null ? indent : orig.indent;
- this.lineStart = lineStart != null ? lineStart : orig.lineStart;
- this.parent = parent != null ? parent : orig.parent || {};
- this.root = orig.root;
- this.src = orig.src;
- }
-
- nodeStartsCollection(node) {
- const {
- inCollection,
- inFlow,
- src
- } = this;
- if (inCollection || inFlow) return false;
- if (node instanceof CollectionItem) return true; // check for implicit key
-
- let offset = node.range.end;
- if (src[offset] === '\n' || src[offset - 1] === '\n') return false;
- offset = PlainValueEc8e588e.Node.endOfWhiteSpace(src, offset);
- return src[offset] === ':';
- } // Anchor and tag are before type, which determines the node implementation
- // class; hence this intermediate step.
-
-
- parseProps(offset) {
- const {
- inFlow,
- parent,
- src
- } = this;
- const props = [];
- let lineHasProps = false;
- offset = this.atLineStart ? PlainValueEc8e588e.Node.endOfIndent(src, offset) : PlainValueEc8e588e.Node.endOfWhiteSpace(src, offset);
- let ch = src[offset];
-
- while (ch === PlainValueEc8e588e.Char.ANCHOR || ch === PlainValueEc8e588e.Char.COMMENT || ch === PlainValueEc8e588e.Char.TAG || ch === '\n') {
- if (ch === '\n') {
- let inEnd = offset;
- let lineStart;
-
- do {
- lineStart = inEnd + 1;
- inEnd = PlainValueEc8e588e.Node.endOfIndent(src, lineStart);
- } while (src[inEnd] === '\n');
-
- const indentDiff = inEnd - (lineStart + this.indent);
- const noIndicatorAsIndent = parent.type === PlainValueEc8e588e.Type.SEQ_ITEM && parent.context.atLineStart;
- if (src[inEnd] !== '#' && !PlainValueEc8e588e.Node.nextNodeIsIndented(src[inEnd], indentDiff, !noIndicatorAsIndent)) break;
- this.atLineStart = true;
- this.lineStart = lineStart;
- lineHasProps = false;
- offset = inEnd;
- } else if (ch === PlainValueEc8e588e.Char.COMMENT) {
- const end = PlainValueEc8e588e.Node.endOfLine(src, offset + 1);
- props.push(new PlainValueEc8e588e.Range(offset, end));
- offset = end;
- } else {
- let end = PlainValueEc8e588e.Node.endOfIdentifier(src, offset + 1);
-
- if (ch === PlainValueEc8e588e.Char.TAG && src[end] === ',' && /^[a-zA-Z0-9-]+\.[a-zA-Z0-9-]+,\d\d\d\d(-\d\d){0,2}\/\S/.test(src.slice(offset + 1, end + 13))) {
- // Let's presume we're dealing with a YAML 1.0 domain tag here, rather
- // than an empty but 'foo.bar' private-tagged node in a flow collection
- // followed without whitespace by a plain string starting with a year
- // or date divided by something.
- end = PlainValueEc8e588e.Node.endOfIdentifier(src, end + 5);
- }
-
- props.push(new PlainValueEc8e588e.Range(offset, end));
- lineHasProps = true;
- offset = PlainValueEc8e588e.Node.endOfWhiteSpace(src, end);
- }
-
- ch = src[offset];
- } // '- &a : b' has an anchor on an empty node
-
-
- if (lineHasProps && ch === ':' && PlainValueEc8e588e.Node.atBlank(src, offset + 1, true)) offset -= 1;
- const type = ParseContext.parseType(src, offset, inFlow);
- return {
- props,
- type,
- valueStart: offset
- };
- }
- /**
- * Parses a node from the source
- * @param {ParseContext} overlay
- * @param {number} start - Index of first non-whitespace character for the node
- * @returns {?Node} - null if at a document boundary
- */
-
-
-}
-
-// Published as 'yaml/parse-cst'
-function parse$1(src) {
- const cr = [];
-
- if (src.indexOf('\r') !== -1) {
- src = src.replace(/\r\n?/g, (match, offset) => {
- if (match.length > 1) cr.push(offset);
- return '\n';
- });
- }
-
- const documents = [];
- let offset = 0;
-
- do {
- const doc = new Document$3();
- const context = new ParseContext({
- src
- });
- offset = doc.parse(context, offset);
- documents.push(doc);
- } while (offset < src.length);
-
- documents.setOrigRanges = () => {
- if (cr.length === 0) return false;
-
- for (let i = 1; i < cr.length; ++i) cr[i] -= i;
-
- let crOffset = 0;
-
- for (let i = 0; i < documents.length; ++i) {
- crOffset = documents[i].setOrigRanges(cr, crOffset);
- }
-
- cr.splice(0, cr.length);
- return true;
- };
-
- documents.toString = () => documents.join('...\n');
-
- return documents;
-}
-
-var parse_1 = parse$1;
-
-var parseCst = {
- parse: parse_1
-};
-
-function addCommentBefore(str, indent, comment) {
- if (!comment) return str;
- const cc = comment.replace(/[\s\S]^/gm, `$&${indent}#`);
- return `#${cc}\n${indent}${str}`;
-}
-function addComment(str, indent, comment) {
- return !comment ? str : comment.indexOf('\n') === -1 ? `${str} #${comment}` : `${str}\n` + comment.replace(/^/gm, `${indent || ''}#`);
-}
-
-class Node$1 {}
-
-function toJSON(value, arg, ctx) {
- if (Array.isArray(value)) return value.map((v, i) => toJSON(v, String(i), ctx));
-
- if (value && typeof value.toJSON === 'function') {
- const anchor = ctx && ctx.anchors && ctx.anchors.get(value);
- if (anchor) ctx.onCreate = res => {
- anchor.res = res;
- delete ctx.onCreate;
- };
- const res = value.toJSON(arg, ctx);
- if (anchor && ctx.onCreate) ctx.onCreate(res);
- return res;
- }
-
- if ((!ctx || !ctx.keep) && typeof value === 'bigint') return Number(value);
- return value;
-}
-
-class Scalar extends Node$1 {
- constructor(value) {
- super();
- this.value = value;
- }
-
- toJSON(arg, ctx) {
- return ctx && ctx.keep ? this.value : toJSON(this.value, arg, ctx);
- }
-
- toString() {
- return String(this.value);
- }
-
-}
-
-function collectionFromPath(schema, path, value) {
- let v = value;
-
- for (let i = path.length - 1; i >= 0; --i) {
- const k = path[i];
-
- if (Number.isInteger(k) && k >= 0) {
- const a = [];
- a[k] = v;
- v = a;
- } else {
- const o = {};
- Object.defineProperty(o, k, {
- value: v,
- writable: true,
- enumerable: true,
- configurable: true
- });
- v = o;
- }
- }
-
- return schema.createNode(v, false);
-} // null, undefined, or an empty non-string iterable (e.g. [])
-
-
-const isEmptyPath = path => path == null || typeof path === 'object' && path[Symbol.iterator]().next().done;
-class Collection extends Node$1 {
- constructor(schema) {
- super();
-
- PlainValueEc8e588e._defineProperty(this, "items", []);
-
- this.schema = schema;
- }
-
- addIn(path, value) {
- if (isEmptyPath(path)) this.add(value);else {
- const [key, ...rest] = path;
- const node = this.get(key, true);
- if (node instanceof Collection) node.addIn(rest, value);else if (node === undefined && this.schema) this.set(key, collectionFromPath(this.schema, rest, value));else throw new Error(`Expected YAML collection at ${key}. Remaining path: ${rest}`);
- }
- }
-
- deleteIn([key, ...rest]) {
- if (rest.length === 0) return this.delete(key);
- const node = this.get(key, true);
- if (node instanceof Collection) return node.deleteIn(rest);else throw new Error(`Expected YAML collection at ${key}. Remaining path: ${rest}`);
- }
-
- getIn([key, ...rest], keepScalar) {
- const node = this.get(key, true);
- if (rest.length === 0) return !keepScalar && node instanceof Scalar ? node.value : node;else return node instanceof Collection ? node.getIn(rest, keepScalar) : undefined;
- }
-
- hasAllNullValues() {
- return this.items.every(node => {
- if (!node || node.type !== 'PAIR') return false;
- const n = node.value;
- return n == null || n instanceof Scalar && n.value == null && !n.commentBefore && !n.comment && !n.tag;
- });
- }
-
- hasIn([key, ...rest]) {
- if (rest.length === 0) return this.has(key);
- const node = this.get(key, true);
- return node instanceof Collection ? node.hasIn(rest) : false;
- }
-
- setIn([key, ...rest], value) {
- if (rest.length === 0) {
- this.set(key, value);
- } else {
- const node = this.get(key, true);
- if (node instanceof Collection) node.setIn(rest, value);else if (node === undefined && this.schema) this.set(key, collectionFromPath(this.schema, rest, value));else throw new Error(`Expected YAML collection at ${key}. Remaining path: ${rest}`);
- }
- } // overridden in implementations
-
- /* istanbul ignore next */
-
-
- toJSON() {
- return null;
- }
-
- toString(ctx, {
- blockItem,
- flowChars,
- isMap,
- itemIndent
- }, onComment, onChompKeep) {
- const {
- indent,
- indentStep,
- stringify
- } = ctx;
- const inFlow = this.type === PlainValueEc8e588e.Type.FLOW_MAP || this.type === PlainValueEc8e588e.Type.FLOW_SEQ || ctx.inFlow;
- if (inFlow) itemIndent += indentStep;
- const allNullValues = isMap && this.hasAllNullValues();
- ctx = Object.assign({}, ctx, {
- allNullValues,
- indent: itemIndent,
- inFlow,
- type: null
- });
- let chompKeep = false;
- let hasItemWithNewLine = false;
- const nodes = this.items.reduce((nodes, item, i) => {
- let comment;
-
- if (item) {
- if (!chompKeep && item.spaceBefore) nodes.push({
- type: 'comment',
- str: ''
- });
- if (item.commentBefore) item.commentBefore.match(/^.*$/gm).forEach(line => {
- nodes.push({
- type: 'comment',
- str: `#${line}`
- });
- });
- if (item.comment) comment = item.comment;
- if (inFlow && (!chompKeep && item.spaceBefore || item.commentBefore || item.comment || item.key && (item.key.commentBefore || item.key.comment) || item.value && (item.value.commentBefore || item.value.comment))) hasItemWithNewLine = true;
- }
-
- chompKeep = false;
- let str = stringify(item, ctx, () => comment = null, () => chompKeep = true);
- if (inFlow && !hasItemWithNewLine && str.includes('\n')) hasItemWithNewLine = true;
- if (inFlow && i < this.items.length - 1) str += ',';
- str = addComment(str, itemIndent, comment);
- if (chompKeep && (comment || inFlow)) chompKeep = false;
- nodes.push({
- type: 'item',
- str
- });
- return nodes;
- }, []);
- let str;
-
- if (nodes.length === 0) {
- str = flowChars.start + flowChars.end;
- } else if (inFlow) {
- const {
- start,
- end
- } = flowChars;
- const strings = nodes.map(n => n.str);
-
- if (hasItemWithNewLine || strings.reduce((sum, str) => sum + str.length + 2, 2) > Collection.maxFlowStringSingleLineLength) {
- str = start;
-
- for (const s of strings) {
- str += s ? `\n${indentStep}${indent}${s}` : '\n';
- }
-
- str += `\n${indent}${end}`;
- } else {
- str = `${start} ${strings.join(' ')} ${end}`;
- }
- } else {
- const strings = nodes.map(blockItem);
- str = strings.shift();
-
- for (const s of strings) str += s ? `\n${indent}${s}` : '\n';
- }
-
- if (this.comment) {
- str += '\n' + this.comment.replace(/^/gm, `${indent}#`);
- if (onComment) onComment();
- } else if (chompKeep && onChompKeep) onChompKeep();
-
- return str;
- }
-
-}
-
-PlainValueEc8e588e._defineProperty(Collection, "maxFlowStringSingleLineLength", 60);
-
-function asItemIndex(key) {
- let idx = key instanceof Scalar ? key.value : key;
- if (idx && typeof idx === 'string') idx = Number(idx);
- return Number.isInteger(idx) && idx >= 0 ? idx : null;
-}
-
-class YAMLSeq extends Collection {
- add(value) {
- this.items.push(value);
- }
-
- delete(key) {
- const idx = asItemIndex(key);
- if (typeof idx !== 'number') return false;
- const del = this.items.splice(idx, 1);
- return del.length > 0;
- }
-
- get(key, keepScalar) {
- const idx = asItemIndex(key);
- if (typeof idx !== 'number') return undefined;
- const it = this.items[idx];
- return !keepScalar && it instanceof Scalar ? it.value : it;
- }
-
- has(key) {
- const idx = asItemIndex(key);
- return typeof idx === 'number' && idx < this.items.length;
- }
-
- set(key, value) {
- const idx = asItemIndex(key);
- if (typeof idx !== 'number') throw new Error(`Expected a valid index, not ${key}.`);
- this.items[idx] = value;
- }
-
- toJSON(_, ctx) {
- const seq = [];
- if (ctx && ctx.onCreate) ctx.onCreate(seq);
- let i = 0;
-
- for (const item of this.items) seq.push(toJSON(item, String(i++), ctx));
-
- return seq;
- }
-
- toString(ctx, onComment, onChompKeep) {
- if (!ctx) return JSON.stringify(this);
- return super.toString(ctx, {
- blockItem: n => n.type === 'comment' ? n.str : `- ${n.str}`,
- flowChars: {
- start: '[',
- end: ']'
- },
- isMap: false,
- itemIndent: (ctx.indent || '') + ' '
- }, onComment, onChompKeep);
- }
-
-}
-
-const stringifyKey = (key, jsKey, ctx) => {
- if (jsKey === null) return '';
- if (typeof jsKey !== 'object') return String(jsKey);
- if (key instanceof Node$1 && ctx && ctx.doc) return key.toString({
- anchors: Object.create(null),
- doc: ctx.doc,
- indent: '',
- indentStep: ctx.indentStep,
- inFlow: true,
- inStringifyKey: true,
- stringify: ctx.stringify
- });
- return JSON.stringify(jsKey);
-};
-
-class Pair extends Node$1 {
- constructor(key, value = null) {
- super();
- this.key = key;
- this.value = value;
- this.type = Pair.Type.PAIR;
- }
-
- get commentBefore() {
- return this.key instanceof Node$1 ? this.key.commentBefore : undefined;
- }
-
- set commentBefore(cb) {
- if (this.key == null) this.key = new Scalar(null);
- if (this.key instanceof Node$1) this.key.commentBefore = cb;else {
- const msg = 'Pair.commentBefore is an alias for Pair.key.commentBefore. To set it, the key must be a Node.';
- throw new Error(msg);
- }
- }
-
- addToJSMap(ctx, map) {
- const key = toJSON(this.key, '', ctx);
-
- if (map instanceof Map) {
- const value = toJSON(this.value, key, ctx);
- map.set(key, value);
- } else if (map instanceof Set) {
- map.add(key);
- } else {
- const stringKey = stringifyKey(this.key, key, ctx);
- const value = toJSON(this.value, stringKey, ctx);
- if (stringKey in map) Object.defineProperty(map, stringKey, {
- value,
- writable: true,
- enumerable: true,
- configurable: true
- });else map[stringKey] = value;
- }
-
- return map;
- }
-
- toJSON(_, ctx) {
- const pair = ctx && ctx.mapAsMap ? new Map() : {};
- return this.addToJSMap(ctx, pair);
- }
-
- toString(ctx, onComment, onChompKeep) {
- if (!ctx || !ctx.doc) return JSON.stringify(this);
- const {
- indent: indentSize,
- indentSeq,
- simpleKeys
- } = ctx.doc.options;
- let {
- key,
- value
- } = this;
- let keyComment = key instanceof Node$1 && key.comment;
-
- if (simpleKeys) {
- if (keyComment) {
- throw new Error('With simple keys, key nodes cannot have comments');
- }
-
- if (key instanceof Collection) {
- const msg = 'With simple keys, collection cannot be used as a key value';
- throw new Error(msg);
- }
- }
-
- let explicitKey = !simpleKeys && (!key || keyComment || (key instanceof Node$1 ? key instanceof Collection || key.type === PlainValueEc8e588e.Type.BLOCK_FOLDED || key.type === PlainValueEc8e588e.Type.BLOCK_LITERAL : typeof key === 'object'));
- const {
- doc,
- indent,
- indentStep,
- stringify
- } = ctx;
- ctx = Object.assign({}, ctx, {
- implicitKey: !explicitKey,
- indent: indent + indentStep
- });
- let chompKeep = false;
- let str = stringify(key, ctx, () => keyComment = null, () => chompKeep = true);
- str = addComment(str, ctx.indent, keyComment);
-
- if (!explicitKey && str.length > 1024) {
- if (simpleKeys) throw new Error('With simple keys, single line scalar must not span more than 1024 characters');
- explicitKey = true;
- }
-
- if (ctx.allNullValues && !simpleKeys) {
- if (this.comment) {
- str = addComment(str, ctx.indent, this.comment);
- if (onComment) onComment();
- } else if (chompKeep && !keyComment && onChompKeep) onChompKeep();
-
- return ctx.inFlow && !explicitKey ? str : `? ${str}`;
- }
-
- str = explicitKey ? `? ${str}\n${indent}:` : `${str}:`;
-
- if (this.comment) {
- // expected (but not strictly required) to be a single-line comment
- str = addComment(str, ctx.indent, this.comment);
- if (onComment) onComment();
- }
-
- let vcb = '';
- let valueComment = null;
-
- if (value instanceof Node$1) {
- if (value.spaceBefore) vcb = '\n';
-
- if (value.commentBefore) {
- const cs = value.commentBefore.replace(/^/gm, `${ctx.indent}#`);
- vcb += `\n${cs}`;
- }
-
- valueComment = value.comment;
- } else if (value && typeof value === 'object') {
- value = doc.schema.createNode(value, true);
- }
-
- ctx.implicitKey = false;
- if (!explicitKey && !this.comment && value instanceof Scalar) ctx.indentAtStart = str.length + 1;
- chompKeep = false;
-
- if (!indentSeq && indentSize >= 2 && !ctx.inFlow && !explicitKey && value instanceof YAMLSeq && value.type !== PlainValueEc8e588e.Type.FLOW_SEQ && !value.tag && !doc.anchors.getName(value)) {
- // If indentSeq === false, consider '- ' as part of indentation where possible
- ctx.indent = ctx.indent.substr(2);
- }
-
- const valueStr = stringify(value, ctx, () => valueComment = null, () => chompKeep = true);
- let ws = ' ';
-
- if (vcb || this.comment) {
- ws = `${vcb}\n${ctx.indent}`;
- } else if (!explicitKey && value instanceof Collection) {
- const flow = valueStr[0] === '[' || valueStr[0] === '{';
- if (!flow || valueStr.includes('\n')) ws = `\n${ctx.indent}`;
- } else if (valueStr[0] === '\n') ws = '';
-
- if (chompKeep && !valueComment && onChompKeep) onChompKeep();
- return addComment(str + ws + valueStr, ctx.indent, valueComment);
- }
-
-}
-
-PlainValueEc8e588e._defineProperty(Pair, "Type", {
- PAIR: 'PAIR',
- MERGE_PAIR: 'MERGE_PAIR'
-});
-
-const getAliasCount = (node, anchors) => {
- if (node instanceof Alias) {
- const anchor = anchors.get(node.source);
- return anchor.count * anchor.aliasCount;
- } else if (node instanceof Collection) {
- let count = 0;
-
- for (const item of node.items) {
- const c = getAliasCount(item, anchors);
- if (c > count) count = c;
- }
-
- return count;
- } else if (node instanceof Pair) {
- const kc = getAliasCount(node.key, anchors);
- const vc = getAliasCount(node.value, anchors);
- return Math.max(kc, vc);
- }
-
- return 1;
-};
-
-class Alias extends Node$1 {
- static stringify({
- range,
- source
- }, {
- anchors,
- doc,
- implicitKey,
- inStringifyKey
- }) {
- let anchor = Object.keys(anchors).find(a => anchors[a] === source);
- if (!anchor && inStringifyKey) anchor = doc.anchors.getName(source) || doc.anchors.newName();
- if (anchor) return `*${anchor}${implicitKey ? ' ' : ''}`;
- const msg = doc.anchors.getName(source) ? 'Alias node must be after source node' : 'Source node not found for alias node';
- throw new Error(`${msg} [${range}]`);
- }
-
- constructor(source) {
- super();
- this.source = source;
- this.type = PlainValueEc8e588e.Type.ALIAS;
- }
-
- set tag(t) {
- throw new Error('Alias nodes cannot have tags');
- }
-
- toJSON(arg, ctx) {
- if (!ctx) return toJSON(this.source, arg, ctx);
- const {
- anchors,
- maxAliasCount
- } = ctx;
- const anchor = anchors.get(this.source);
- /* istanbul ignore if */
-
- if (!anchor || anchor.res === undefined) {
- const msg = 'This should not happen: Alias anchor was not resolved?';
- if (this.cstNode) throw new PlainValueEc8e588e.YAMLReferenceError(this.cstNode, msg);else throw new ReferenceError(msg);
- }
-
- if (maxAliasCount >= 0) {
- anchor.count += 1;
- if (anchor.aliasCount === 0) anchor.aliasCount = getAliasCount(this.source, anchors);
-
- if (anchor.count * anchor.aliasCount > maxAliasCount) {
- const msg = 'Excessive alias count indicates a resource exhaustion attack';
- if (this.cstNode) throw new PlainValueEc8e588e.YAMLReferenceError(this.cstNode, msg);else throw new ReferenceError(msg);
- }
- }
-
- return anchor.res;
- } // Only called when stringifying an alias mapping key while constructing
- // Object output.
-
-
- toString(ctx) {
- return Alias.stringify(this, ctx);
- }
-
-}
-
-PlainValueEc8e588e._defineProperty(Alias, "default", true);
-
-function findPair(items, key) {
- const k = key instanceof Scalar ? key.value : key;
-
- for (const it of items) {
- if (it instanceof Pair) {
- if (it.key === key || it.key === k) return it;
- if (it.key && it.key.value === k) return it;
- }
- }
-
- return undefined;
-}
-class YAMLMap extends Collection {
- add(pair, overwrite) {
- if (!pair) pair = new Pair(pair);else if (!(pair instanceof Pair)) pair = new Pair(pair.key || pair, pair.value);
- const prev = findPair(this.items, pair.key);
- const sortEntries = this.schema && this.schema.sortMapEntries;
-
- if (prev) {
- if (overwrite) prev.value = pair.value;else throw new Error(`Key ${pair.key} already set`);
- } else if (sortEntries) {
- const i = this.items.findIndex(item => sortEntries(pair, item) < 0);
- if (i === -1) this.items.push(pair);else this.items.splice(i, 0, pair);
- } else {
- this.items.push(pair);
- }
- }
-
- delete(key) {
- const it = findPair(this.items, key);
- if (!it) return false;
- const del = this.items.splice(this.items.indexOf(it), 1);
- return del.length > 0;
- }
-
- get(key, keepScalar) {
- const it = findPair(this.items, key);
- const node = it && it.value;
- return !keepScalar && node instanceof Scalar ? node.value : node;
- }
-
- has(key) {
- return !!findPair(this.items, key);
- }
-
- set(key, value) {
- this.add(new Pair(key, value), true);
- }
- /**
- * @param {*} arg ignored
- * @param {*} ctx Conversion context, originally set in Document#toJSON()
- * @param {Class} Type If set, forces the returned collection type
- * @returns {*} Instance of Type, Map, or Object
- */
-
-
- toJSON(_, ctx, Type) {
- const map = Type ? new Type() : ctx && ctx.mapAsMap ? new Map() : {};
- if (ctx && ctx.onCreate) ctx.onCreate(map);
-
- for (const item of this.items) item.addToJSMap(ctx, map);
-
- return map;
- }
-
- toString(ctx, onComment, onChompKeep) {
- if (!ctx) return JSON.stringify(this);
-
- for (const item of this.items) {
- if (!(item instanceof Pair)) throw new Error(`Map items must all be pairs; found ${JSON.stringify(item)} instead`);
- }
-
- return super.toString(ctx, {
- blockItem: n => n.str,
- flowChars: {
- start: '{',
- end: '}'
- },
- isMap: true,
- itemIndent: ctx.indent || ''
- }, onComment, onChompKeep);
- }
-
-}
-
-const MERGE_KEY = '<<';
-class Merge extends Pair {
- constructor(pair) {
- if (pair instanceof Pair) {
- let seq = pair.value;
-
- if (!(seq instanceof YAMLSeq)) {
- seq = new YAMLSeq();
- seq.items.push(pair.value);
- seq.range = pair.value.range;
- }
-
- super(pair.key, seq);
- this.range = pair.range;
- } else {
- super(new Scalar(MERGE_KEY), new YAMLSeq());
- }
-
- this.type = Pair.Type.MERGE_PAIR;
- } // If the value associated with a merge key is a single mapping node, each of
- // its key/value pairs is inserted into the current mapping, unless the key
- // already exists in it. If the value associated with the merge key is a
- // sequence, then this sequence is expected to contain mapping nodes and each
- // of these nodes is merged in turn according to its order in the sequence.
- // Keys in mapping nodes earlier in the sequence override keys specified in
- // later mapping nodes. -- http://yaml.org/type/merge.html
-
-
- addToJSMap(ctx, map) {
- for (const {
- source
- } of this.value.items) {
- if (!(source instanceof YAMLMap)) throw new Error('Merge sources must be maps');
- const srcMap = source.toJSON(null, ctx, Map);
-
- for (const [key, value] of srcMap) {
- if (map instanceof Map) {
- if (!map.has(key)) map.set(key, value);
- } else if (map instanceof Set) {
- map.add(key);
- } else if (!Object.prototype.hasOwnProperty.call(map, key)) {
- Object.defineProperty(map, key, {
- value,
- writable: true,
- enumerable: true,
- configurable: true
- });
- }
- }
- }
-
- return map;
- }
-
- toString(ctx, onComment) {
- const seq = this.value;
- if (seq.items.length > 1) return super.toString(ctx, onComment);
- this.value = seq.items[0];
- const str = super.toString(ctx, onComment);
- this.value = seq;
- return str;
- }
-
-}
-
-const binaryOptions = {
- defaultType: PlainValueEc8e588e.Type.BLOCK_LITERAL,
- lineWidth: 76
-};
-const boolOptions = {
- trueStr: 'true',
- falseStr: 'false'
-};
-const intOptions = {
- asBigInt: false
-};
-const nullOptions = {
- nullStr: 'null'
-};
-const strOptions = {
- defaultType: PlainValueEc8e588e.Type.PLAIN,
- doubleQuoted: {
- jsonEncoding: false,
- minMultiLineLength: 40
- },
- fold: {
- lineWidth: 80,
- minContentWidth: 20
- }
-};
-
-function resolveScalar(str, tags, scalarFallback) {
- for (const {
- format,
- test,
- resolve
- } of tags) {
- if (test) {
- const match = str.match(test);
-
- if (match) {
- let res = resolve.apply(null, match);
- if (!(res instanceof Scalar)) res = new Scalar(res);
- if (format) res.format = format;
- return res;
- }
- }
- }
-
- if (scalarFallback) str = scalarFallback(str);
- return new Scalar(str);
-}
-
-const FOLD_FLOW = 'flow';
-const FOLD_BLOCK = 'block';
-const FOLD_QUOTED = 'quoted'; // presumes i+1 is at the start of a line
-// returns index of last newline in more-indented block
-
-const consumeMoreIndentedLines = (text, i) => {
- let ch = text[i + 1];
-
- while (ch === ' ' || ch === '\t') {
- do {
- ch = text[i += 1];
- } while (ch && ch !== '\n');
-
- ch = text[i + 1];
- }
-
- return i;
-};
-/**
- * Tries to keep input at up to `lineWidth` characters, splitting only on spaces
- * not followed by newlines or spaces unless `mode` is `'quoted'`. Lines are
- * terminated with `\n` and started with `indent`.
- *
- * @param {string} text
- * @param {string} indent
- * @param {string} [mode='flow'] `'block'` prevents more-indented lines
- * from being folded; `'quoted'` allows for `\` escapes, including escaped
- * newlines
- * @param {Object} options
- * @param {number} [options.indentAtStart] Accounts for leading contents on
- * the first line, defaulting to `indent.length`
- * @param {number} [options.lineWidth=80]
- * @param {number} [options.minContentWidth=20] Allow highly indented lines to
- * stretch the line width or indent content from the start
- * @param {function} options.onFold Called once if the text is folded
- * @param {function} options.onFold Called once if any line of text exceeds
- * lineWidth characters
- */
-
-
-function foldFlowLines(text, indent, mode, {
- indentAtStart,
- lineWidth = 80,
- minContentWidth = 20,
- onFold,
- onOverflow
-}) {
- if (!lineWidth || lineWidth < 0) return text;
- const endStep = Math.max(1 + minContentWidth, 1 + lineWidth - indent.length);
- if (text.length <= endStep) return text;
- const folds = [];
- const escapedFolds = {};
- let end = lineWidth - indent.length;
-
- if (typeof indentAtStart === 'number') {
- if (indentAtStart > lineWidth - Math.max(2, minContentWidth)) folds.push(0);else end = lineWidth - indentAtStart;
- }
-
- let split = undefined;
- let prev = undefined;
- let overflow = false;
- let i = -1;
- let escStart = -1;
- let escEnd = -1;
-
- if (mode === FOLD_BLOCK) {
- i = consumeMoreIndentedLines(text, i);
- if (i !== -1) end = i + endStep;
- }
-
- for (let ch; ch = text[i += 1];) {
- if (mode === FOLD_QUOTED && ch === '\\') {
- escStart = i;
-
- switch (text[i + 1]) {
- case 'x':
- i += 3;
- break;
-
- case 'u':
- i += 5;
- break;
-
- case 'U':
- i += 9;
- break;
-
- default:
- i += 1;
- }
-
- escEnd = i;
- }
-
- if (ch === '\n') {
- if (mode === FOLD_BLOCK) i = consumeMoreIndentedLines(text, i);
- end = i + endStep;
- split = undefined;
- } else {
- if (ch === ' ' && prev && prev !== ' ' && prev !== '\n' && prev !== '\t') {
- // space surrounded by non-space can be replaced with newline + indent
- const next = text[i + 1];
- if (next && next !== ' ' && next !== '\n' && next !== '\t') split = i;
- }
-
- if (i >= end) {
- if (split) {
- folds.push(split);
- end = split + endStep;
- split = undefined;
- } else if (mode === FOLD_QUOTED) {
- // white-space collected at end may stretch past lineWidth
- while (prev === ' ' || prev === '\t') {
- prev = ch;
- ch = text[i += 1];
- overflow = true;
- } // Account for newline escape, but don't break preceding escape
-
-
- const j = i > escEnd + 1 ? i - 2 : escStart - 1; // Bail out if lineWidth & minContentWidth are shorter than an escape string
-
- if (escapedFolds[j]) return text;
- folds.push(j);
- escapedFolds[j] = true;
- end = j + endStep;
- split = undefined;
- } else {
- overflow = true;
- }
- }
- }
-
- prev = ch;
- }
-
- if (overflow && onOverflow) onOverflow();
- if (folds.length === 0) return text;
- if (onFold) onFold();
- let res = text.slice(0, folds[0]);
-
- for (let i = 0; i < folds.length; ++i) {
- const fold = folds[i];
- const end = folds[i + 1] || text.length;
- if (fold === 0) res = `\n${indent}${text.slice(0, end)}`;else {
- if (mode === FOLD_QUOTED && escapedFolds[fold]) res += `${text[fold]}\\`;
- res += `\n${indent}${text.slice(fold + 1, end)}`;
- }
- }
-
- return res;
-}
-
-const getFoldOptions = ({
- indentAtStart
-}) => indentAtStart ? Object.assign({
- indentAtStart
-}, strOptions.fold) : strOptions.fold; // Also checks for lines starting with %, as parsing the output as YAML 1.1 will
-// presume that's starting a new document.
-
-
-const containsDocumentMarker = str => /^(%|---|\.\.\.)/m.test(str);
-
-function lineLengthOverLimit(str, lineWidth, indentLength) {
- if (!lineWidth || lineWidth < 0) return false;
- const limit = lineWidth - indentLength;
- const strLen = str.length;
- if (strLen <= limit) return false;
-
- for (let i = 0, start = 0; i < strLen; ++i) {
- if (str[i] === '\n') {
- if (i - start > limit) return true;
- start = i + 1;
- if (strLen - start <= limit) return false;
- }
- }
-
- return true;
-}
-
-function doubleQuotedString(value, ctx) {
- const {
- implicitKey
- } = ctx;
- const {
- jsonEncoding,
- minMultiLineLength
- } = strOptions.doubleQuoted;
- const json = JSON.stringify(value);
- if (jsonEncoding) return json;
- const indent = ctx.indent || (containsDocumentMarker(value) ? ' ' : '');
- let str = '';
- let start = 0;
-
- for (let i = 0, ch = json[i]; ch; ch = json[++i]) {
- if (ch === ' ' && json[i + 1] === '\\' && json[i + 2] === 'n') {
- // space before newline needs to be escaped to not be folded
- str += json.slice(start, i) + '\\ ';
- i += 1;
- start = i;
- ch = '\\';
- }
-
- if (ch === '\\') switch (json[i + 1]) {
- case 'u':
- {
- str += json.slice(start, i);
- const code = json.substr(i + 2, 4);
-
- switch (code) {
- case '0000':
- str += '\\0';
- break;
-
- case '0007':
- str += '\\a';
- break;
-
- case '000b':
- str += '\\v';
- break;
-
- case '001b':
- str += '\\e';
- break;
-
- case '0085':
- str += '\\N';
- break;
-
- case '00a0':
- str += '\\_';
- break;
-
- case '2028':
- str += '\\L';
- break;
-
- case '2029':
- str += '\\P';
- break;
-
- default:
- if (code.substr(0, 2) === '00') str += '\\x' + code.substr(2);else str += json.substr(i, 6);
- }
-
- i += 5;
- start = i + 1;
- }
- break;
-
- case 'n':
- if (implicitKey || json[i + 2] === '"' || json.length < minMultiLineLength) {
- i += 1;
- } else {
- // folding will eat first newline
- str += json.slice(start, i) + '\n\n';
-
- while (json[i + 2] === '\\' && json[i + 3] === 'n' && json[i + 4] !== '"') {
- str += '\n';
- i += 2;
- }
-
- str += indent; // space after newline needs to be escaped to not be folded
-
- if (json[i + 2] === ' ') str += '\\';
- i += 1;
- start = i + 1;
- }
-
- break;
-
- default:
- i += 1;
- }
- }
-
- str = start ? str + json.slice(start) : json;
- return implicitKey ? str : foldFlowLines(str, indent, FOLD_QUOTED, getFoldOptions(ctx));
-}
-
-function singleQuotedString(value, ctx) {
- if (ctx.implicitKey) {
- if (/\n/.test(value)) return doubleQuotedString(value, ctx);
- } else {
- // single quoted string can't have leading or trailing whitespace around newline
- if (/[ \t]\n|\n[ \t]/.test(value)) return doubleQuotedString(value, ctx);
- }
-
- const indent = ctx.indent || (containsDocumentMarker(value) ? ' ' : '');
- const res = "'" + value.replace(/'/g, "''").replace(/\n+/g, `$&\n${indent}`) + "'";
- return ctx.implicitKey ? res : foldFlowLines(res, indent, FOLD_FLOW, getFoldOptions(ctx));
-}
-
-function blockString({
- comment,
- type,
- value
-}, ctx, onComment, onChompKeep) {
- // 1. Block can't end in whitespace unless the last line is non-empty.
- // 2. Strings consisting of only whitespace are best rendered explicitly.
- if (/\n[\t ]+$/.test(value) || /^\s*$/.test(value)) {
- return doubleQuotedString(value, ctx);
- }
-
- const indent = ctx.indent || (ctx.forceBlockIndent || containsDocumentMarker(value) ? ' ' : '');
- const indentSize = indent ? '2' : '1'; // root is at -1
-
- const literal = type === PlainValueEc8e588e.Type.BLOCK_FOLDED ? false : type === PlainValueEc8e588e.Type.BLOCK_LITERAL ? true : !lineLengthOverLimit(value, strOptions.fold.lineWidth, indent.length);
- let header = literal ? '|' : '>';
- if (!value) return header + '\n';
- let wsStart = '';
- let wsEnd = '';
- value = value.replace(/[\n\t ]*$/, ws => {
- const n = ws.indexOf('\n');
-
- if (n === -1) {
- header += '-'; // strip
- } else if (value === ws || n !== ws.length - 1) {
- header += '+'; // keep
-
- if (onChompKeep) onChompKeep();
- }
-
- wsEnd = ws.replace(/\n$/, '');
- return '';
- }).replace(/^[\n ]*/, ws => {
- if (ws.indexOf(' ') !== -1) header += indentSize;
- const m = ws.match(/ +$/);
-
- if (m) {
- wsStart = ws.slice(0, -m[0].length);
- return m[0];
- } else {
- wsStart = ws;
- return '';
- }
- });
- if (wsEnd) wsEnd = wsEnd.replace(/\n+(?!\n|$)/g, `$&${indent}`);
- if (wsStart) wsStart = wsStart.replace(/\n+/g, `$&${indent}`);
-
- if (comment) {
- header += ' #' + comment.replace(/ ?[\r\n]+/g, ' ');
- if (onComment) onComment();
- }
-
- if (!value) return `${header}${indentSize}\n${indent}${wsEnd}`;
-
- if (literal) {
- value = value.replace(/\n+/g, `$&${indent}`);
- return `${header}\n${indent}${wsStart}${value}${wsEnd}`;
- }
-
- value = value.replace(/\n+/g, '\n$&').replace(/(?:^|\n)([\t ].*)(?:([\n\t ]*)\n(?![\n\t ]))?/g, '$1$2') // more-indented lines aren't folded
- // ^ ind.line ^ empty ^ capture next empty lines only at end of indent
- .replace(/\n+/g, `$&${indent}`);
- const body = foldFlowLines(`${wsStart}${value}${wsEnd}`, indent, FOLD_BLOCK, strOptions.fold);
- return `${header}\n${indent}${body}`;
-}
-
-function plainString(item, ctx, onComment, onChompKeep) {
- const {
- comment,
- type,
- value
- } = item;
- const {
- actualString,
- implicitKey,
- indent,
- inFlow
- } = ctx;
-
- if (implicitKey && /[\n[\]{},]/.test(value) || inFlow && /[[\]{},]/.test(value)) {
- return doubleQuotedString(value, ctx);
- }
-
- if (!value || /^[\n\t ,[\]{}#&*!|>'"%@`]|^[?-]$|^[?-][ \t]|[\n:][ \t]|[ \t]\n|[\n\t ]#|[\n\t :]$/.test(value)) {
- // not allowed:
- // - empty string, '-' or '?'
- // - start with an indicator character (except [?:-]) or /[?-] /
- // - '\n ', ': ' or ' \n' anywhere
- // - '#' not preceded by a non-space char
- // - end with ' ' or ':'
- return implicitKey || inFlow || value.indexOf('\n') === -1 ? value.indexOf('"') !== -1 && value.indexOf("'") === -1 ? singleQuotedString(value, ctx) : doubleQuotedString(value, ctx) : blockString(item, ctx, onComment, onChompKeep);
- }
-
- if (!implicitKey && !inFlow && type !== PlainValueEc8e588e.Type.PLAIN && value.indexOf('\n') !== -1) {
- // Where allowed & type not set explicitly, prefer block style for multiline strings
- return blockString(item, ctx, onComment, onChompKeep);
- }
-
- if (indent === '' && containsDocumentMarker(value)) {
- ctx.forceBlockIndent = true;
- return blockString(item, ctx, onComment, onChompKeep);
- }
-
- const str = value.replace(/\n+/g, `$&\n${indent}`); // Verify that output will be parsed as a string, as e.g. plain numbers and
- // booleans get parsed with those types in v1.2 (e.g. '42', 'true' & '0.9e-3'),
- // and others in v1.1.
-
- if (actualString) {
- const {
- tags
- } = ctx.doc.schema;
- const resolved = resolveScalar(str, tags, tags.scalarFallback).value;
- if (typeof resolved !== 'string') return doubleQuotedString(value, ctx);
- }
-
- const body = implicitKey ? str : foldFlowLines(str, indent, FOLD_FLOW, getFoldOptions(ctx));
-
- if (comment && !inFlow && (body.indexOf('\n') !== -1 || comment.indexOf('\n') !== -1)) {
- if (onComment) onComment();
- return addCommentBefore(body, indent, comment);
- }
-
- return body;
-}
-
-function stringifyString(item, ctx, onComment, onChompKeep) {
- const {
- defaultType
- } = strOptions;
- const {
- implicitKey,
- inFlow
- } = ctx;
- let {
- type,
- value
- } = item;
-
- if (typeof value !== 'string') {
- value = String(value);
- item = Object.assign({}, item, {
- value
- });
- }
-
- const _stringify = _type => {
- switch (_type) {
- case PlainValueEc8e588e.Type.BLOCK_FOLDED:
- case PlainValueEc8e588e.Type.BLOCK_LITERAL:
- return blockString(item, ctx, onComment, onChompKeep);
-
- case PlainValueEc8e588e.Type.QUOTE_DOUBLE:
- return doubleQuotedString(value, ctx);
-
- case PlainValueEc8e588e.Type.QUOTE_SINGLE:
- return singleQuotedString(value, ctx);
-
- case PlainValueEc8e588e.Type.PLAIN:
- return plainString(item, ctx, onComment, onChompKeep);
-
- default:
- return null;
- }
- };
-
- if (type !== PlainValueEc8e588e.Type.QUOTE_DOUBLE && /[\x00-\x08\x0b-\x1f\x7f-\x9f]/.test(value)) {
- // force double quotes on control characters
- type = PlainValueEc8e588e.Type.QUOTE_DOUBLE;
- } else if ((implicitKey || inFlow) && (type === PlainValueEc8e588e.Type.BLOCK_FOLDED || type === PlainValueEc8e588e.Type.BLOCK_LITERAL)) {
- // should not happen; blocks are not valid inside flow containers
- type = PlainValueEc8e588e.Type.QUOTE_DOUBLE;
- }
-
- let res = _stringify(type);
-
- if (res === null) {
- res = _stringify(defaultType);
- if (res === null) throw new Error(`Unsupported default string type ${defaultType}`);
- }
-
- return res;
-}
-
-function stringifyNumber({
- format,
- minFractionDigits,
- tag,
- value
-}) {
- if (typeof value === 'bigint') return String(value);
- if (!isFinite(value)) return isNaN(value) ? '.nan' : value < 0 ? '-.inf' : '.inf';
- let n = JSON.stringify(value);
-
- if (!format && minFractionDigits && (!tag || tag === 'tag:yaml.org,2002:float') && /^\d/.test(n)) {
- let i = n.indexOf('.');
-
- if (i < 0) {
- i = n.length;
- n += '.';
- }
-
- let d = minFractionDigits - (n.length - i - 1);
-
- while (d-- > 0) n += '0';
- }
-
- return n;
-}
-
-function checkFlowCollectionEnd(errors, cst) {
- let char, name;
-
- switch (cst.type) {
- case PlainValueEc8e588e.Type.FLOW_MAP:
- char = '}';
- name = 'flow map';
- break;
-
- case PlainValueEc8e588e.Type.FLOW_SEQ:
- char = ']';
- name = 'flow sequence';
- break;
-
- default:
- errors.push(new PlainValueEc8e588e.YAMLSemanticError(cst, 'Not a flow collection!?'));
- return;
- }
-
- let lastItem;
-
- for (let i = cst.items.length - 1; i >= 0; --i) {
- const item = cst.items[i];
-
- if (!item || item.type !== PlainValueEc8e588e.Type.COMMENT) {
- lastItem = item;
- break;
- }
- }
-
- if (lastItem && lastItem.char !== char) {
- const msg = `Expected ${name} to end with ${char}`;
- let err;
-
- if (typeof lastItem.offset === 'number') {
- err = new PlainValueEc8e588e.YAMLSemanticError(cst, msg);
- err.offset = lastItem.offset + 1;
- } else {
- err = new PlainValueEc8e588e.YAMLSemanticError(lastItem, msg);
- if (lastItem.range && lastItem.range.end) err.offset = lastItem.range.end - lastItem.range.start;
- }
-
- errors.push(err);
- }
-}
-function checkFlowCommentSpace(errors, comment) {
- const prev = comment.context.src[comment.range.start - 1];
-
- if (prev !== '\n' && prev !== '\t' && prev !== ' ') {
- const msg = 'Comments must be separated from other tokens by white space characters';
- errors.push(new PlainValueEc8e588e.YAMLSemanticError(comment, msg));
- }
-}
-function getLongKeyError(source, key) {
- const sk = String(key);
- const k = sk.substr(0, 8) + '...' + sk.substr(-8);
- return new PlainValueEc8e588e.YAMLSemanticError(source, `The "${k}" key is too long`);
-}
-function resolveComments(collection, comments) {
- for (const {
- afterKey,
- before,
- comment
- } of comments) {
- let item = collection.items[before];
-
- if (!item) {
- if (comment !== undefined) {
- if (collection.comment) collection.comment += '\n' + comment;else collection.comment = comment;
- }
- } else {
- if (afterKey && item.value) item = item.value;
-
- if (comment === undefined) {
- if (afterKey || !item.commentBefore) item.spaceBefore = true;
- } else {
- if (item.commentBefore) item.commentBefore += '\n' + comment;else item.commentBefore = comment;
- }
- }
- }
-}
-
-// on error, will return { str: string, errors: Error[] }
-function resolveString(doc, node) {
- const res = node.strValue;
- if (!res) return '';
- if (typeof res === 'string') return res;
- res.errors.forEach(error => {
- if (!error.source) error.source = node;
- doc.errors.push(error);
- });
- return res.str;
-}
-
-function resolveTagHandle(doc, node) {
- const {
- handle,
- suffix
- } = node.tag;
- let prefix = doc.tagPrefixes.find(p => p.handle === handle);
-
- if (!prefix) {
- const dtp = doc.getDefaults().tagPrefixes;
- if (dtp) prefix = dtp.find(p => p.handle === handle);
- if (!prefix) throw new PlainValueEc8e588e.YAMLSemanticError(node, `The ${handle} tag handle is non-default and was not declared.`);
- }
-
- if (!suffix) throw new PlainValueEc8e588e.YAMLSemanticError(node, `The ${handle} tag has no suffix.`);
-
- if (handle === '!' && (doc.version || doc.options.version) === '1.0') {
- if (suffix[0] === '^') {
- doc.warnings.push(new PlainValueEc8e588e.YAMLWarning(node, 'YAML 1.0 ^ tag expansion is not supported'));
- return suffix;
- }
-
- if (/[:/]/.test(suffix)) {
- // word/foo -> tag:word.yaml.org,2002:foo
- const vocab = suffix.match(/^([a-z0-9-]+)\/(.*)/i);
- return vocab ? `tag:${vocab[1]}.yaml.org,2002:${vocab[2]}` : `tag:${suffix}`;
- }
- }
-
- return prefix.prefix + decodeURIComponent(suffix);
-}
-
-function resolveTagName(doc, node) {
- const {
- tag,
- type
- } = node;
- let nonSpecific = false;
-
- if (tag) {
- const {
- handle,
- suffix,
- verbatim
- } = tag;
-
- if (verbatim) {
- if (verbatim !== '!' && verbatim !== '!!') return verbatim;
- const msg = `Verbatim tags aren't resolved, so ${verbatim} is invalid.`;
- doc.errors.push(new PlainValueEc8e588e.YAMLSemanticError(node, msg));
- } else if (handle === '!' && !suffix) {
- nonSpecific = true;
- } else {
- try {
- return resolveTagHandle(doc, node);
- } catch (error) {
- doc.errors.push(error);
- }
- }
- }
-
- switch (type) {
- case PlainValueEc8e588e.Type.BLOCK_FOLDED:
- case PlainValueEc8e588e.Type.BLOCK_LITERAL:
- case PlainValueEc8e588e.Type.QUOTE_DOUBLE:
- case PlainValueEc8e588e.Type.QUOTE_SINGLE:
- return PlainValueEc8e588e.defaultTags.STR;
-
- case PlainValueEc8e588e.Type.FLOW_MAP:
- case PlainValueEc8e588e.Type.MAP:
- return PlainValueEc8e588e.defaultTags.MAP;
-
- case PlainValueEc8e588e.Type.FLOW_SEQ:
- case PlainValueEc8e588e.Type.SEQ:
- return PlainValueEc8e588e.defaultTags.SEQ;
-
- case PlainValueEc8e588e.Type.PLAIN:
- return nonSpecific ? PlainValueEc8e588e.defaultTags.STR : null;
-
- default:
- return null;
- }
-}
-
-function resolveByTagName(doc, node, tagName) {
- const {
- tags
- } = doc.schema;
- const matchWithTest = [];
-
- for (const tag of tags) {
- if (tag.tag === tagName) {
- if (tag.test) matchWithTest.push(tag);else {
- const res = tag.resolve(doc, node);
- return res instanceof Collection ? res : new Scalar(res);
- }
- }
- }
-
- const str = resolveString(doc, node);
- if (typeof str === 'string' && matchWithTest.length > 0) return resolveScalar(str, matchWithTest, tags.scalarFallback);
- return null;
-}
-
-function getFallbackTagName({
- type
-}) {
- switch (type) {
- case PlainValueEc8e588e.Type.FLOW_MAP:
- case PlainValueEc8e588e.Type.MAP:
- return PlainValueEc8e588e.defaultTags.MAP;
-
- case PlainValueEc8e588e.Type.FLOW_SEQ:
- case PlainValueEc8e588e.Type.SEQ:
- return PlainValueEc8e588e.defaultTags.SEQ;
-
- default:
- return PlainValueEc8e588e.defaultTags.STR;
- }
-}
-
-function resolveTag(doc, node, tagName) {
- try {
- const res = resolveByTagName(doc, node, tagName);
-
- if (res) {
- if (tagName && node.tag) res.tag = tagName;
- return res;
- }
- } catch (error) {
- /* istanbul ignore if */
- if (!error.source) error.source = node;
- doc.errors.push(error);
- return null;
- }
-
- try {
- const fallback = getFallbackTagName(node);
- if (!fallback) throw new Error(`The tag ${tagName} is unavailable`);
- const msg = `The tag ${tagName} is unavailable, falling back to ${fallback}`;
- doc.warnings.push(new PlainValueEc8e588e.YAMLWarning(node, msg));
- const res = resolveByTagName(doc, node, fallback);
- res.tag = tagName;
- return res;
- } catch (error) {
- const refError = new PlainValueEc8e588e.YAMLReferenceError(node, error.message);
- refError.stack = error.stack;
- doc.errors.push(refError);
- return null;
- }
-}
-
-const isCollectionItem = node => {
- if (!node) return false;
- const {
- type
- } = node;
- return type === PlainValueEc8e588e.Type.MAP_KEY || type === PlainValueEc8e588e.Type.MAP_VALUE || type === PlainValueEc8e588e.Type.SEQ_ITEM;
-};
-
-function resolveNodeProps(errors, node) {
- const comments = {
- before: [],
- after: []
- };
- let hasAnchor = false;
- let hasTag = false;
- const props = isCollectionItem(node.context.parent) ? node.context.parent.props.concat(node.props) : node.props;
-
- for (const {
- start,
- end
- } of props) {
- switch (node.context.src[start]) {
- case PlainValueEc8e588e.Char.COMMENT:
- {
- if (!node.commentHasRequiredWhitespace(start)) {
- const msg = 'Comments must be separated from other tokens by white space characters';
- errors.push(new PlainValueEc8e588e.YAMLSemanticError(node, msg));
- }
-
- const {
- header,
- valueRange
- } = node;
- const cc = valueRange && (start > valueRange.start || header && start > header.start) ? comments.after : comments.before;
- cc.push(node.context.src.slice(start + 1, end));
- break;
- }
- // Actual anchor & tag resolution is handled by schema, here we just complain
-
- case PlainValueEc8e588e.Char.ANCHOR:
- if (hasAnchor) {
- const msg = 'A node can have at most one anchor';
- errors.push(new PlainValueEc8e588e.YAMLSemanticError(node, msg));
- }
-
- hasAnchor = true;
- break;
-
- case PlainValueEc8e588e.Char.TAG:
- if (hasTag) {
- const msg = 'A node can have at most one tag';
- errors.push(new PlainValueEc8e588e.YAMLSemanticError(node, msg));
- }
-
- hasTag = true;
- break;
- }
- }
-
- return {
- comments,
- hasAnchor,
- hasTag
- };
-}
-
-function resolveNodeValue(doc, node) {
- const {
- anchors,
- errors,
- schema
- } = doc;
-
- if (node.type === PlainValueEc8e588e.Type.ALIAS) {
- const name = node.rawValue;
- const src = anchors.getNode(name);
-
- if (!src) {
- const msg = `Aliased anchor not found: ${name}`;
- errors.push(new PlainValueEc8e588e.YAMLReferenceError(node, msg));
- return null;
- } // Lazy resolution for circular references
-
-
- const res = new Alias(src);
-
- anchors._cstAliases.push(res);
-
- return res;
- }
-
- const tagName = resolveTagName(doc, node);
- if (tagName) return resolveTag(doc, node, tagName);
-
- if (node.type !== PlainValueEc8e588e.Type.PLAIN) {
- const msg = `Failed to resolve ${node.type} node here`;
- errors.push(new PlainValueEc8e588e.YAMLSyntaxError(node, msg));
- return null;
- }
-
- try {
- const str = resolveString(doc, node);
- return resolveScalar(str, schema.tags, schema.tags.scalarFallback);
- } catch (error) {
- if (!error.source) error.source = node;
- errors.push(error);
- return null;
- }
-} // sets node.resolved on success
-
-
-function resolveNode(doc, node) {
- if (!node) return null;
- if (node.error) doc.errors.push(node.error);
- const {
- comments,
- hasAnchor,
- hasTag
- } = resolveNodeProps(doc.errors, node);
-
- if (hasAnchor) {
- const {
- anchors
- } = doc;
- const name = node.anchor;
- const prev = anchors.getNode(name); // At this point, aliases for any preceding node with the same anchor
- // name have already been resolved, so it may safely be renamed.
-
- if (prev) anchors.map[anchors.newName(name)] = prev; // During parsing, we need to store the CST node in anchors.map as
- // anchors need to be available during resolution to allow for
- // circular references.
-
- anchors.map[name] = node;
- }
-
- if (node.type === PlainValueEc8e588e.Type.ALIAS && (hasAnchor || hasTag)) {
- const msg = 'An alias node must not specify any properties';
- doc.errors.push(new PlainValueEc8e588e.YAMLSemanticError(node, msg));
- }
-
- const res = resolveNodeValue(doc, node);
-
- if (res) {
- res.range = [node.range.start, node.range.end];
- if (doc.options.keepCstNodes) res.cstNode = node;
- if (doc.options.keepNodeTypes) res.type = node.type;
- const cb = comments.before.join('\n');
-
- if (cb) {
- res.commentBefore = res.commentBefore ? `${res.commentBefore}\n${cb}` : cb;
- }
-
- const ca = comments.after.join('\n');
- if (ca) res.comment = res.comment ? `${res.comment}\n${ca}` : ca;
- }
-
- return node.resolved = res;
-}
-
-function resolveMap(doc, cst) {
- if (cst.type !== PlainValueEc8e588e.Type.MAP && cst.type !== PlainValueEc8e588e.Type.FLOW_MAP) {
- const msg = `A ${cst.type} node cannot be resolved as a mapping`;
- doc.errors.push(new PlainValueEc8e588e.YAMLSyntaxError(cst, msg));
- return null;
- }
-
- const {
- comments,
- items
- } = cst.type === PlainValueEc8e588e.Type.FLOW_MAP ? resolveFlowMapItems(doc, cst) : resolveBlockMapItems(doc, cst);
- const map = new YAMLMap();
- map.items = items;
- resolveComments(map, comments);
- let hasCollectionKey = false;
-
- for (let i = 0; i < items.length; ++i) {
- const {
- key: iKey
- } = items[i];
- if (iKey instanceof Collection) hasCollectionKey = true;
-
- if (doc.schema.merge && iKey && iKey.value === MERGE_KEY) {
- items[i] = new Merge(items[i]);
- const sources = items[i].value.items;
- let error = null;
- sources.some(node => {
- if (node instanceof Alias) {
- // During parsing, alias sources are CST nodes; to account for
- // circular references their resolved values can't be used here.
- const {
- type
- } = node.source;
- if (type === PlainValueEc8e588e.Type.MAP || type === PlainValueEc8e588e.Type.FLOW_MAP) return false;
- return error = 'Merge nodes aliases can only point to maps';
- }
-
- return error = 'Merge nodes can only have Alias nodes as values';
- });
- if (error) doc.errors.push(new PlainValueEc8e588e.YAMLSemanticError(cst, error));
- } else {
- for (let j = i + 1; j < items.length; ++j) {
- const {
- key: jKey
- } = items[j];
-
- if (iKey === jKey || iKey && jKey && Object.prototype.hasOwnProperty.call(iKey, 'value') && iKey.value === jKey.value) {
- const msg = `Map keys must be unique; "${iKey}" is repeated`;
- doc.errors.push(new PlainValueEc8e588e.YAMLSemanticError(cst, msg));
- break;
- }
- }
- }
- }
-
- if (hasCollectionKey && !doc.options.mapAsMap) {
- const warn = 'Keys with collection values will be stringified as YAML due to JS Object restrictions. Use mapAsMap: true to avoid this.';
- doc.warnings.push(new PlainValueEc8e588e.YAMLWarning(cst, warn));
- }
-
- cst.resolved = map;
- return map;
-}
-
-const valueHasPairComment = ({
- context: {
- lineStart,
- node,
- src
- },
- props
-}) => {
- if (props.length === 0) return false;
- const {
- start
- } = props[0];
- if (node && start > node.valueRange.start) return false;
- if (src[start] !== PlainValueEc8e588e.Char.COMMENT) return false;
-
- for (let i = lineStart; i < start; ++i) if (src[i] === '\n') return false;
-
- return true;
-};
-
-function resolvePairComment(item, pair) {
- if (!valueHasPairComment(item)) return;
- const comment = item.getPropValue(0, PlainValueEc8e588e.Char.COMMENT, true);
- let found = false;
- const cb = pair.value.commentBefore;
-
- if (cb && cb.startsWith(comment)) {
- pair.value.commentBefore = cb.substr(comment.length + 1);
- found = true;
- } else {
- const cc = pair.value.comment;
-
- if (!item.node && cc && cc.startsWith(comment)) {
- pair.value.comment = cc.substr(comment.length + 1);
- found = true;
- }
- }
-
- if (found) pair.comment = comment;
-}
-
-function resolveBlockMapItems(doc, cst) {
- const comments = [];
- const items = [];
- let key = undefined;
- let keyStart = null;
-
- for (let i = 0; i < cst.items.length; ++i) {
- const item = cst.items[i];
-
- switch (item.type) {
- case PlainValueEc8e588e.Type.BLANK_LINE:
- comments.push({
- afterKey: !!key,
- before: items.length
- });
- break;
-
- case PlainValueEc8e588e.Type.COMMENT:
- comments.push({
- afterKey: !!key,
- before: items.length,
- comment: item.comment
- });
- break;
-
- case PlainValueEc8e588e.Type.MAP_KEY:
- if (key !== undefined) items.push(new Pair(key));
- if (item.error) doc.errors.push(item.error);
- key = resolveNode(doc, item.node);
- keyStart = null;
- break;
-
- case PlainValueEc8e588e.Type.MAP_VALUE:
- {
- if (key === undefined) key = null;
- if (item.error) doc.errors.push(item.error);
-
- if (!item.context.atLineStart && item.node && item.node.type === PlainValueEc8e588e.Type.MAP && !item.node.context.atLineStart) {
- const msg = 'Nested mappings are not allowed in compact mappings';
- doc.errors.push(new PlainValueEc8e588e.YAMLSemanticError(item.node, msg));
- }
-
- let valueNode = item.node;
-
- if (!valueNode && item.props.length > 0) {
- // Comments on an empty mapping value need to be preserved, so we
- // need to construct a minimal empty node here to use instead of the
- // missing `item.node`. -- eemeli/yaml#19
- valueNode = new PlainValueEc8e588e.PlainValue(PlainValueEc8e588e.Type.PLAIN, []);
- valueNode.context = {
- parent: item,
- src: item.context.src
- };
- const pos = item.range.start + 1;
- valueNode.range = {
- start: pos,
- end: pos
- };
- valueNode.valueRange = {
- start: pos,
- end: pos
- };
-
- if (typeof item.range.origStart === 'number') {
- const origPos = item.range.origStart + 1;
- valueNode.range.origStart = valueNode.range.origEnd = origPos;
- valueNode.valueRange.origStart = valueNode.valueRange.origEnd = origPos;
- }
- }
-
- const pair = new Pair(key, resolveNode(doc, valueNode));
- resolvePairComment(item, pair);
- items.push(pair);
-
- if (key && typeof keyStart === 'number') {
- if (item.range.start > keyStart + 1024) doc.errors.push(getLongKeyError(cst, key));
- }
-
- key = undefined;
- keyStart = null;
- }
- break;
-
- default:
- if (key !== undefined) items.push(new Pair(key));
- key = resolveNode(doc, item);
- keyStart = item.range.start;
- if (item.error) doc.errors.push(item.error);
-
- next: for (let j = i + 1;; ++j) {
- const nextItem = cst.items[j];
-
- switch (nextItem && nextItem.type) {
- case PlainValueEc8e588e.Type.BLANK_LINE:
- case PlainValueEc8e588e.Type.COMMENT:
- continue next;
-
- case PlainValueEc8e588e.Type.MAP_VALUE:
- break next;
-
- default:
- {
- const msg = 'Implicit map keys need to be followed by map values';
- doc.errors.push(new PlainValueEc8e588e.YAMLSemanticError(item, msg));
- break next;
- }
- }
- }
-
- if (item.valueRangeContainsNewline) {
- const msg = 'Implicit map keys need to be on a single line';
- doc.errors.push(new PlainValueEc8e588e.YAMLSemanticError(item, msg));
- }
-
- }
- }
-
- if (key !== undefined) items.push(new Pair(key));
- return {
- comments,
- items
- };
-}
-
-function resolveFlowMapItems(doc, cst) {
- const comments = [];
- const items = [];
- let key = undefined;
- let explicitKey = false;
- let next = '{';
-
- for (let i = 0; i < cst.items.length; ++i) {
- const item = cst.items[i];
-
- if (typeof item.char === 'string') {
- const {
- char,
- offset
- } = item;
-
- if (char === '?' && key === undefined && !explicitKey) {
- explicitKey = true;
- next = ':';
- continue;
- }
-
- if (char === ':') {
- if (key === undefined) key = null;
-
- if (next === ':') {
- next = ',';
- continue;
- }
- } else {
- if (explicitKey) {
- if (key === undefined && char !== ',') key = null;
- explicitKey = false;
- }
-
- if (key !== undefined) {
- items.push(new Pair(key));
- key = undefined;
-
- if (char === ',') {
- next = ':';
- continue;
- }
- }
- }
-
- if (char === '}') {
- if (i === cst.items.length - 1) continue;
- } else if (char === next) {
- next = ':';
- continue;
- }
-
- const msg = `Flow map contains an unexpected ${char}`;
- const err = new PlainValueEc8e588e.YAMLSyntaxError(cst, msg);
- err.offset = offset;
- doc.errors.push(err);
- } else if (item.type === PlainValueEc8e588e.Type.BLANK_LINE) {
- comments.push({
- afterKey: !!key,
- before: items.length
- });
- } else if (item.type === PlainValueEc8e588e.Type.COMMENT) {
- checkFlowCommentSpace(doc.errors, item);
- comments.push({
- afterKey: !!key,
- before: items.length,
- comment: item.comment
- });
- } else if (key === undefined) {
- if (next === ',') doc.errors.push(new PlainValueEc8e588e.YAMLSemanticError(item, 'Separator , missing in flow map'));
- key = resolveNode(doc, item);
- } else {
- if (next !== ',') doc.errors.push(new PlainValueEc8e588e.YAMLSemanticError(item, 'Indicator : missing in flow map entry'));
- items.push(new Pair(key, resolveNode(doc, item)));
- key = undefined;
- explicitKey = false;
- }
- }
-
- checkFlowCollectionEnd(doc.errors, cst);
- if (key !== undefined) items.push(new Pair(key));
- return {
- comments,
- items
- };
-}
-
-function resolveSeq(doc, cst) {
- if (cst.type !== PlainValueEc8e588e.Type.SEQ && cst.type !== PlainValueEc8e588e.Type.FLOW_SEQ) {
- const msg = `A ${cst.type} node cannot be resolved as a sequence`;
- doc.errors.push(new PlainValueEc8e588e.YAMLSyntaxError(cst, msg));
- return null;
- }
-
- const {
- comments,
- items
- } = cst.type === PlainValueEc8e588e.Type.FLOW_SEQ ? resolveFlowSeqItems(doc, cst) : resolveBlockSeqItems(doc, cst);
- const seq = new YAMLSeq();
- seq.items = items;
- resolveComments(seq, comments);
-
- if (!doc.options.mapAsMap && items.some(it => it instanceof Pair && it.key instanceof Collection)) {
- const warn = 'Keys with collection values will be stringified as YAML due to JS Object restrictions. Use mapAsMap: true to avoid this.';
- doc.warnings.push(new PlainValueEc8e588e.YAMLWarning(cst, warn));
- }
-
- cst.resolved = seq;
- return seq;
-}
-
-function resolveBlockSeqItems(doc, cst) {
- const comments = [];
- const items = [];
-
- for (let i = 0; i < cst.items.length; ++i) {
- const item = cst.items[i];
-
- switch (item.type) {
- case PlainValueEc8e588e.Type.BLANK_LINE:
- comments.push({
- before: items.length
- });
- break;
-
- case PlainValueEc8e588e.Type.COMMENT:
- comments.push({
- comment: item.comment,
- before: items.length
- });
- break;
-
- case PlainValueEc8e588e.Type.SEQ_ITEM:
- if (item.error) doc.errors.push(item.error);
- items.push(resolveNode(doc, item.node));
-
- if (item.hasProps) {
- const msg = 'Sequence items cannot have tags or anchors before the - indicator';
- doc.errors.push(new PlainValueEc8e588e.YAMLSemanticError(item, msg));
- }
-
- break;
-
- default:
- if (item.error) doc.errors.push(item.error);
- doc.errors.push(new PlainValueEc8e588e.YAMLSyntaxError(item, `Unexpected ${item.type} node in sequence`));
- }
- }
-
- return {
- comments,
- items
- };
-}
-
-function resolveFlowSeqItems(doc, cst) {
- const comments = [];
- const items = [];
- let explicitKey = false;
- let key = undefined;
- let keyStart = null;
- let next = '[';
- let prevItem = null;
-
- for (let i = 0; i < cst.items.length; ++i) {
- const item = cst.items[i];
-
- if (typeof item.char === 'string') {
- const {
- char,
- offset
- } = item;
-
- if (char !== ':' && (explicitKey || key !== undefined)) {
- if (explicitKey && key === undefined) key = next ? items.pop() : null;
- items.push(new Pair(key));
- explicitKey = false;
- key = undefined;
- keyStart = null;
- }
-
- if (char === next) {
- next = null;
- } else if (!next && char === '?') {
- explicitKey = true;
- } else if (next !== '[' && char === ':' && key === undefined) {
- if (next === ',') {
- key = items.pop();
-
- if (key instanceof Pair) {
- const msg = 'Chaining flow sequence pairs is invalid';
- const err = new PlainValueEc8e588e.YAMLSemanticError(cst, msg);
- err.offset = offset;
- doc.errors.push(err);
- }
-
- if (!explicitKey && typeof keyStart === 'number') {
- const keyEnd = item.range ? item.range.start : item.offset;
- if (keyEnd > keyStart + 1024) doc.errors.push(getLongKeyError(cst, key));
- const {
- src
- } = prevItem.context;
-
- for (let i = keyStart; i < keyEnd; ++i) if (src[i] === '\n') {
- const msg = 'Implicit keys of flow sequence pairs need to be on a single line';
- doc.errors.push(new PlainValueEc8e588e.YAMLSemanticError(prevItem, msg));
- break;
- }
- }
- } else {
- key = null;
- }
-
- keyStart = null;
- explicitKey = false;
- next = null;
- } else if (next === '[' || char !== ']' || i < cst.items.length - 1) {
- const msg = `Flow sequence contains an unexpected ${char}`;
- const err = new PlainValueEc8e588e.YAMLSyntaxError(cst, msg);
- err.offset = offset;
- doc.errors.push(err);
- }
- } else if (item.type === PlainValueEc8e588e.Type.BLANK_LINE) {
- comments.push({
- before: items.length
- });
- } else if (item.type === PlainValueEc8e588e.Type.COMMENT) {
- checkFlowCommentSpace(doc.errors, item);
- comments.push({
- comment: item.comment,
- before: items.length
- });
- } else {
- if (next) {
- const msg = `Expected a ${next} in flow sequence`;
- doc.errors.push(new PlainValueEc8e588e.YAMLSemanticError(item, msg));
- }
-
- const value = resolveNode(doc, item);
-
- if (key === undefined) {
- items.push(value);
- prevItem = item;
- } else {
- items.push(new Pair(key, value));
- key = undefined;
- }
-
- keyStart = item.range.start;
- next = ',';
- }
- }
-
- checkFlowCollectionEnd(doc.errors, cst);
- if (key !== undefined) items.push(new Pair(key));
- return {
- comments,
- items
- };
-}
-
-var Alias_1 = Alias;
-var Collection_1 = Collection;
-var Merge_1 = Merge;
-var Node_1 = Node$1;
-var Pair_1 = Pair;
-var Scalar_1 = Scalar;
-var YAMLMap_1 = YAMLMap;
-var YAMLSeq_1 = YAMLSeq;
-var addComment_1 = addComment;
-var binaryOptions_1 = binaryOptions;
-var boolOptions_1 = boolOptions;
-var findPair_1 = findPair;
-var intOptions_1 = intOptions;
-var isEmptyPath_1 = isEmptyPath;
-var nullOptions_1 = nullOptions;
-var resolveMap_1 = resolveMap;
-var resolveNode_1 = resolveNode;
-var resolveSeq_1 = resolveSeq;
-var resolveString_1 = resolveString;
-var strOptions_1 = strOptions;
-var stringifyNumber_1 = stringifyNumber;
-var stringifyString_1 = stringifyString;
-var toJSON_1 = toJSON;
-
-var resolveSeqD03cb037 = {
- Alias: Alias_1,
- Collection: Collection_1,
- Merge: Merge_1,
- Node: Node_1,
- Pair: Pair_1,
- Scalar: Scalar_1,
- YAMLMap: YAMLMap_1,
- YAMLSeq: YAMLSeq_1,
- addComment: addComment_1,
- binaryOptions: binaryOptions_1,
- boolOptions: boolOptions_1,
- findPair: findPair_1,
- intOptions: intOptions_1,
- isEmptyPath: isEmptyPath_1,
- nullOptions: nullOptions_1,
- resolveMap: resolveMap_1,
- resolveNode: resolveNode_1,
- resolveSeq: resolveSeq_1,
- resolveString: resolveString_1,
- strOptions: strOptions_1,
- stringifyNumber: stringifyNumber_1,
- stringifyString: stringifyString_1,
- toJSON: toJSON_1
-};
-
-/* global atob, btoa, Buffer */
-const binary = {
- identify: value => value instanceof Uint8Array,
- // Buffer inherits from Uint8Array
- default: false,
- tag: 'tag:yaml.org,2002:binary',
-
- /**
- * Returns a Buffer in node and an Uint8Array in browsers
- *
- * To use the resulting buffer as an image, you'll want to do something like:
- *
- * const blob = new Blob([buffer], { type: 'image/jpeg' })
- * document.querySelector('#photo').src = URL.createObjectURL(blob)
- */
- resolve: (doc, node) => {
- const src = resolveSeqD03cb037.resolveString(doc, node);
-
- if (typeof Buffer === 'function') {
- return Buffer.from(src, 'base64');
- } else if (typeof atob === 'function') {
- // On IE 11, atob() can't handle newlines
- const str = atob(src.replace(/[\n\r]/g, ''));
- const buffer = new Uint8Array(str.length);
-
- for (let i = 0; i < str.length; ++i) buffer[i] = str.charCodeAt(i);
-
- return buffer;
- } else {
- const msg = 'This environment does not support reading binary tags; either Buffer or atob is required';
- doc.errors.push(new PlainValueEc8e588e.YAMLReferenceError(node, msg));
- return null;
- }
- },
- options: resolveSeqD03cb037.binaryOptions,
- stringify: ({
- comment,
- type,
- value
- }, ctx, onComment, onChompKeep) => {
- let src;
-
- if (typeof Buffer === 'function') {
- src = value instanceof Buffer ? value.toString('base64') : Buffer.from(value.buffer).toString('base64');
- } else if (typeof btoa === 'function') {
- let s = '';
-
- for (let i = 0; i < value.length; ++i) s += String.fromCharCode(value[i]);
-
- src = btoa(s);
- } else {
- throw new Error('This environment does not support writing binary tags; either Buffer or btoa is required');
- }
-
- if (!type) type = resolveSeqD03cb037.binaryOptions.defaultType;
-
- if (type === PlainValueEc8e588e.Type.QUOTE_DOUBLE) {
- value = src;
- } else {
- const {
- lineWidth
- } = resolveSeqD03cb037.binaryOptions;
- const n = Math.ceil(src.length / lineWidth);
- const lines = new Array(n);
-
- for (let i = 0, o = 0; i < n; ++i, o += lineWidth) {
- lines[i] = src.substr(o, lineWidth);
- }
-
- value = lines.join(type === PlainValueEc8e588e.Type.BLOCK_LITERAL ? '\n' : ' ');
- }
-
- return resolveSeqD03cb037.stringifyString({
- comment,
- type,
- value
- }, ctx, onComment, onChompKeep);
- }
-};
-
-function parsePairs(doc, cst) {
- const seq = resolveSeqD03cb037.resolveSeq(doc, cst);
-
- for (let i = 0; i < seq.items.length; ++i) {
- let item = seq.items[i];
- if (item instanceof resolveSeqD03cb037.Pair) continue;else if (item instanceof resolveSeqD03cb037.YAMLMap) {
- if (item.items.length > 1) {
- const msg = 'Each pair must have its own sequence indicator';
- throw new PlainValueEc8e588e.YAMLSemanticError(cst, msg);
- }
-
- const pair = item.items[0] || new resolveSeqD03cb037.Pair();
- if (item.commentBefore) pair.commentBefore = pair.commentBefore ? `${item.commentBefore}\n${pair.commentBefore}` : item.commentBefore;
- if (item.comment) pair.comment = pair.comment ? `${item.comment}\n${pair.comment}` : item.comment;
- item = pair;
- }
- seq.items[i] = item instanceof resolveSeqD03cb037.Pair ? item : new resolveSeqD03cb037.Pair(item);
- }
-
- return seq;
-}
-function createPairs(schema, iterable, ctx) {
- const pairs = new resolveSeqD03cb037.YAMLSeq(schema);
- pairs.tag = 'tag:yaml.org,2002:pairs';
-
- for (const it of iterable) {
- let key, value;
-
- if (Array.isArray(it)) {
- if (it.length === 2) {
- key = it[0];
- value = it[1];
- } else throw new TypeError(`Expected [key, value] tuple: ${it}`);
- } else if (it && it instanceof Object) {
- const keys = Object.keys(it);
-
- if (keys.length === 1) {
- key = keys[0];
- value = it[key];
- } else throw new TypeError(`Expected { key: value } tuple: ${it}`);
- } else {
- key = it;
- }
-
- const pair = schema.createPair(key, value, ctx);
- pairs.items.push(pair);
- }
-
- return pairs;
-}
-const pairs = {
- default: false,
- tag: 'tag:yaml.org,2002:pairs',
- resolve: parsePairs,
- createNode: createPairs
-};
-
-class YAMLOMap extends resolveSeqD03cb037.YAMLSeq {
- constructor() {
- super();
-
- PlainValueEc8e588e._defineProperty(this, "add", resolveSeqD03cb037.YAMLMap.prototype.add.bind(this));
-
- PlainValueEc8e588e._defineProperty(this, "delete", resolveSeqD03cb037.YAMLMap.prototype.delete.bind(this));
-
- PlainValueEc8e588e._defineProperty(this, "get", resolveSeqD03cb037.YAMLMap.prototype.get.bind(this));
-
- PlainValueEc8e588e._defineProperty(this, "has", resolveSeqD03cb037.YAMLMap.prototype.has.bind(this));
-
- PlainValueEc8e588e._defineProperty(this, "set", resolveSeqD03cb037.YAMLMap.prototype.set.bind(this));
-
- this.tag = YAMLOMap.tag;
- }
-
- toJSON(_, ctx) {
- const map = new Map();
- if (ctx && ctx.onCreate) ctx.onCreate(map);
-
- for (const pair of this.items) {
- let key, value;
-
- if (pair instanceof resolveSeqD03cb037.Pair) {
- key = resolveSeqD03cb037.toJSON(pair.key, '', ctx);
- value = resolveSeqD03cb037.toJSON(pair.value, key, ctx);
- } else {
- key = resolveSeqD03cb037.toJSON(pair, '', ctx);
- }
-
- if (map.has(key)) throw new Error('Ordered maps must not include duplicate keys');
- map.set(key, value);
- }
-
- return map;
- }
-
-}
-
-PlainValueEc8e588e._defineProperty(YAMLOMap, "tag", 'tag:yaml.org,2002:omap');
-
-function parseOMap(doc, cst) {
- const pairs = parsePairs(doc, cst);
- const seenKeys = [];
-
- for (const {
- key
- } of pairs.items) {
- if (key instanceof resolveSeqD03cb037.Scalar) {
- if (seenKeys.includes(key.value)) {
- const msg = 'Ordered maps must not include duplicate keys';
- throw new PlainValueEc8e588e.YAMLSemanticError(cst, msg);
- } else {
- seenKeys.push(key.value);
- }
- }
- }
-
- return Object.assign(new YAMLOMap(), pairs);
-}
-
-function createOMap(schema, iterable, ctx) {
- const pairs = createPairs(schema, iterable, ctx);
- const omap = new YAMLOMap();
- omap.items = pairs.items;
- return omap;
-}
-
-const omap = {
- identify: value => value instanceof Map,
- nodeClass: YAMLOMap,
- default: false,
- tag: 'tag:yaml.org,2002:omap',
- resolve: parseOMap,
- createNode: createOMap
-};
-
-class YAMLSet extends resolveSeqD03cb037.YAMLMap {
- constructor() {
- super();
- this.tag = YAMLSet.tag;
- }
-
- add(key) {
- const pair = key instanceof resolveSeqD03cb037.Pair ? key : new resolveSeqD03cb037.Pair(key);
- const prev = resolveSeqD03cb037.findPair(this.items, pair.key);
- if (!prev) this.items.push(pair);
- }
-
- get(key, keepPair) {
- const pair = resolveSeqD03cb037.findPair(this.items, key);
- return !keepPair && pair instanceof resolveSeqD03cb037.Pair ? pair.key instanceof resolveSeqD03cb037.Scalar ? pair.key.value : pair.key : pair;
- }
-
- set(key, value) {
- if (typeof value !== 'boolean') throw new Error(`Expected boolean value for set(key, value) in a YAML set, not ${typeof value}`);
- const prev = resolveSeqD03cb037.findPair(this.items, key);
-
- if (prev && !value) {
- this.items.splice(this.items.indexOf(prev), 1);
- } else if (!prev && value) {
- this.items.push(new resolveSeqD03cb037.Pair(key));
- }
- }
-
- toJSON(_, ctx) {
- return super.toJSON(_, ctx, Set);
- }
-
- toString(ctx, onComment, onChompKeep) {
- if (!ctx) return JSON.stringify(this);
- if (this.hasAllNullValues()) return super.toString(ctx, onComment, onChompKeep);else throw new Error('Set items must all have null values');
- }
-
-}
-
-PlainValueEc8e588e._defineProperty(YAMLSet, "tag", 'tag:yaml.org,2002:set');
-
-function parseSet(doc, cst) {
- const map = resolveSeqD03cb037.resolveMap(doc, cst);
- if (!map.hasAllNullValues()) throw new PlainValueEc8e588e.YAMLSemanticError(cst, 'Set items must all have null values');
- return Object.assign(new YAMLSet(), map);
-}
-
-function createSet(schema, iterable, ctx) {
- const set = new YAMLSet();
-
- for (const value of iterable) set.items.push(schema.createPair(value, null, ctx));
-
- return set;
-}
-
-const set = {
- identify: value => value instanceof Set,
- nodeClass: YAMLSet,
- default: false,
- tag: 'tag:yaml.org,2002:set',
- resolve: parseSet,
- createNode: createSet
-};
-
-const parseSexagesimal = (sign, parts) => {
- const n = parts.split(':').reduce((n, p) => n * 60 + Number(p), 0);
- return sign === '-' ? -n : n;
-}; // hhhh:mm:ss.sss
-
-
-const stringifySexagesimal = ({
- value
-}) => {
- if (isNaN(value) || !isFinite(value)) return resolveSeqD03cb037.stringifyNumber(value);
- let sign = '';
-
- if (value < 0) {
- sign = '-';
- value = Math.abs(value);
- }
-
- const parts = [value % 60]; // seconds, including ms
-
- if (value < 60) {
- parts.unshift(0); // at least one : is required
- } else {
- value = Math.round((value - parts[0]) / 60);
- parts.unshift(value % 60); // minutes
-
- if (value >= 60) {
- value = Math.round((value - parts[0]) / 60);
- parts.unshift(value); // hours
- }
- }
-
- return sign + parts.map(n => n < 10 ? '0' + String(n) : String(n)).join(':').replace(/000000\d*$/, '') // % 60 may introduce error
- ;
-};
-
-const intTime = {
- identify: value => typeof value === 'number',
- default: true,
- tag: 'tag:yaml.org,2002:int',
- format: 'TIME',
- test: /^([-+]?)([0-9][0-9_]*(?::[0-5]?[0-9])+)$/,
- resolve: (str, sign, parts) => parseSexagesimal(sign, parts.replace(/_/g, '')),
- stringify: stringifySexagesimal
-};
-const floatTime = {
- identify: value => typeof value === 'number',
- default: true,
- tag: 'tag:yaml.org,2002:float',
- format: 'TIME',
- test: /^([-+]?)([0-9][0-9_]*(?::[0-5]?[0-9])+\.[0-9_]*)$/,
- resolve: (str, sign, parts) => parseSexagesimal(sign, parts.replace(/_/g, '')),
- stringify: stringifySexagesimal
-};
-const timestamp = {
- identify: value => value instanceof Date,
- default: true,
- tag: 'tag:yaml.org,2002:timestamp',
- // If the time zone is omitted, the timestamp is assumed to be specified in UTC. The time part
- // may be omitted altogether, resulting in a date format. In such a case, the time part is
- // assumed to be 00:00:00Z (start of day, UTC).
- test: RegExp('^(?:' + '([0-9]{4})-([0-9]{1,2})-([0-9]{1,2})' + // YYYY-Mm-Dd
- '(?:(?:t|T|[ \\t]+)' + // t | T | whitespace
- '([0-9]{1,2}):([0-9]{1,2}):([0-9]{1,2}(\\.[0-9]+)?)' + // Hh:Mm:Ss(.ss)?
- '(?:[ \\t]*(Z|[-+][012]?[0-9](?::[0-9]{2})?))?' + // Z | +5 | -03:30
- ')?' + ')$'),
- resolve: (str, year, month, day, hour, minute, second, millisec, tz) => {
- if (millisec) millisec = (millisec + '00').substr(1, 3);
- let date = Date.UTC(year, month - 1, day, hour || 0, minute || 0, second || 0, millisec || 0);
-
- if (tz && tz !== 'Z') {
- let d = parseSexagesimal(tz[0], tz.slice(1));
- if (Math.abs(d) < 30) d *= 60;
- date -= 60000 * d;
- }
-
- return new Date(date);
- },
- stringify: ({
- value
- }) => value.toISOString().replace(/((T00:00)?:00)?\.000Z$/, '')
-};
-
-/* global console, process, YAML_SILENCE_DEPRECATION_WARNINGS, YAML_SILENCE_WARNINGS */
-function shouldWarn(deprecation) {
- const env = typeof process !== 'undefined' && process.env || {};
-
- if (deprecation) {
- if (typeof YAML_SILENCE_DEPRECATION_WARNINGS !== 'undefined') return !YAML_SILENCE_DEPRECATION_WARNINGS;
- return !env.YAML_SILENCE_DEPRECATION_WARNINGS;
- }
-
- if (typeof YAML_SILENCE_WARNINGS !== 'undefined') return !YAML_SILENCE_WARNINGS;
- return !env.YAML_SILENCE_WARNINGS;
-}
-
-function warn(warning, type) {
- if (shouldWarn(false)) {
- const emit = typeof process !== 'undefined' && process.emitWarning; // This will throw in Jest if `warning` is an Error instance due to
- // https://github.com/facebook/jest/issues/2549
-
- if (emit) emit(warning, type);else {
- // eslint-disable-next-line no-console
- console.warn(type ? `${type}: ${warning}` : warning);
- }
- }
-}
-function warnFileDeprecation(filename) {
- if (shouldWarn(true)) {
- const path = filename.replace(/.*yaml[/\\]/i, '').replace(/\.js$/, '').replace(/\\/g, '/');
- warn(`The endpoint 'yaml/${path}' will be removed in a future release.`, 'DeprecationWarning');
- }
-}
-const warned = {};
-function warnOptionDeprecation(name, alternative) {
- if (!warned[name] && shouldWarn(true)) {
- warned[name] = true;
- let msg = `The option '${name}' will be removed in a future release`;
- msg += alternative ? `, use '${alternative}' instead.` : '.';
- warn(msg, 'DeprecationWarning');
- }
-}
-
-var binary_1 = binary;
-var floatTime_1 = floatTime;
-var intTime_1 = intTime;
-var omap_1 = omap;
-var pairs_1 = pairs;
-var set_1 = set;
-var timestamp_1 = timestamp;
-var warn_1 = warn;
-var warnFileDeprecation_1 = warnFileDeprecation;
-var warnOptionDeprecation_1 = warnOptionDeprecation;
-
-var warnings1000a372 = {
- binary: binary_1,
- floatTime: floatTime_1,
- intTime: intTime_1,
- omap: omap_1,
- pairs: pairs_1,
- set: set_1,
- timestamp: timestamp_1,
- warn: warn_1,
- warnFileDeprecation: warnFileDeprecation_1,
- warnOptionDeprecation: warnOptionDeprecation_1
-};
-
-function createMap(schema, obj, ctx) {
- const map = new resolveSeqD03cb037.YAMLMap(schema);
-
- if (obj instanceof Map) {
- for (const [key, value] of obj) map.items.push(schema.createPair(key, value, ctx));
- } else if (obj && typeof obj === 'object') {
- for (const key of Object.keys(obj)) map.items.push(schema.createPair(key, obj[key], ctx));
- }
-
- if (typeof schema.sortMapEntries === 'function') {
- map.items.sort(schema.sortMapEntries);
- }
-
- return map;
-}
-
-const map = {
- createNode: createMap,
- default: true,
- nodeClass: resolveSeqD03cb037.YAMLMap,
- tag: 'tag:yaml.org,2002:map',
- resolve: resolveSeqD03cb037.resolveMap
-};
-
-function createSeq(schema, obj, ctx) {
- const seq = new resolveSeqD03cb037.YAMLSeq(schema);
-
- if (obj && obj[Symbol.iterator]) {
- for (const it of obj) {
- const v = schema.createNode(it, ctx.wrapScalars, null, ctx);
- seq.items.push(v);
- }
- }
-
- return seq;
-}
-
-const seq = {
- createNode: createSeq,
- default: true,
- nodeClass: resolveSeqD03cb037.YAMLSeq,
- tag: 'tag:yaml.org,2002:seq',
- resolve: resolveSeqD03cb037.resolveSeq
-};
-
-const string = {
- identify: value => typeof value === 'string',
- default: true,
- tag: 'tag:yaml.org,2002:str',
- resolve: resolveSeqD03cb037.resolveString,
-
- stringify(item, ctx, onComment, onChompKeep) {
- ctx = Object.assign({
- actualString: true
- }, ctx);
- return resolveSeqD03cb037.stringifyString(item, ctx, onComment, onChompKeep);
- },
-
- options: resolveSeqD03cb037.strOptions
-};
-
-const failsafe = [map, seq, string];
-
-/* global BigInt */
-
-const intIdentify$2 = value => typeof value === 'bigint' || Number.isInteger(value);
-
-const intResolve$1 = (src, part, radix) => resolveSeqD03cb037.intOptions.asBigInt ? BigInt(src) : parseInt(part, radix);
-
-function intStringify$1(node, radix, prefix) {
- const {
- value
- } = node;
- if (intIdentify$2(value) && value >= 0) return prefix + value.toString(radix);
- return resolveSeqD03cb037.stringifyNumber(node);
-}
-
-const nullObj = {
- identify: value => value == null,
- createNode: (schema, value, ctx) => ctx.wrapScalars ? new resolveSeqD03cb037.Scalar(null) : null,
- default: true,
- tag: 'tag:yaml.org,2002:null',
- test: /^(?:~|[Nn]ull|NULL)?$/,
- resolve: () => null,
- options: resolveSeqD03cb037.nullOptions,
- stringify: () => resolveSeqD03cb037.nullOptions.nullStr
-};
-const boolObj = {
- identify: value => typeof value === 'boolean',
- default: true,
- tag: 'tag:yaml.org,2002:bool',
- test: /^(?:[Tt]rue|TRUE|[Ff]alse|FALSE)$/,
- resolve: str => str[0] === 't' || str[0] === 'T',
- options: resolveSeqD03cb037.boolOptions,
- stringify: ({
- value
- }) => value ? resolveSeqD03cb037.boolOptions.trueStr : resolveSeqD03cb037.boolOptions.falseStr
-};
-const octObj = {
- identify: value => intIdentify$2(value) && value >= 0,
- default: true,
- tag: 'tag:yaml.org,2002:int',
- format: 'OCT',
- test: /^0o([0-7]+)$/,
- resolve: (str, oct) => intResolve$1(str, oct, 8),
- options: resolveSeqD03cb037.intOptions,
- stringify: node => intStringify$1(node, 8, '0o')
-};
-const intObj = {
- identify: intIdentify$2,
- default: true,
- tag: 'tag:yaml.org,2002:int',
- test: /^[-+]?[0-9]+$/,
- resolve: str => intResolve$1(str, str, 10),
- options: resolveSeqD03cb037.intOptions,
- stringify: resolveSeqD03cb037.stringifyNumber
-};
-const hexObj = {
- identify: value => intIdentify$2(value) && value >= 0,
- default: true,
- tag: 'tag:yaml.org,2002:int',
- format: 'HEX',
- test: /^0x([0-9a-fA-F]+)$/,
- resolve: (str, hex) => intResolve$1(str, hex, 16),
- options: resolveSeqD03cb037.intOptions,
- stringify: node => intStringify$1(node, 16, '0x')
-};
-const nanObj = {
- identify: value => typeof value === 'number',
- default: true,
- tag: 'tag:yaml.org,2002:float',
- test: /^(?:[-+]?\.inf|(\.nan))$/i,
- resolve: (str, nan) => nan ? NaN : str[0] === '-' ? Number.NEGATIVE_INFINITY : Number.POSITIVE_INFINITY,
- stringify: resolveSeqD03cb037.stringifyNumber
-};
-const expObj = {
- identify: value => typeof value === 'number',
- default: true,
- tag: 'tag:yaml.org,2002:float',
- format: 'EXP',
- test: /^[-+]?(?:\.[0-9]+|[0-9]+(?:\.[0-9]*)?)[eE][-+]?[0-9]+$/,
- resolve: str => parseFloat(str),
- stringify: ({
- value
- }) => Number(value).toExponential()
-};
-const floatObj = {
- identify: value => typeof value === 'number',
- default: true,
- tag: 'tag:yaml.org,2002:float',
- test: /^[-+]?(?:\.([0-9]+)|[0-9]+\.([0-9]*))$/,
-
- resolve(str, frac1, frac2) {
- const frac = frac1 || frac2;
- const node = new resolveSeqD03cb037.Scalar(parseFloat(str));
- if (frac && frac[frac.length - 1] === '0') node.minFractionDigits = frac.length;
- return node;
- },
-
- stringify: resolveSeqD03cb037.stringifyNumber
-};
-const core = failsafe.concat([nullObj, boolObj, octObj, intObj, hexObj, nanObj, expObj, floatObj]);
-
-/* global BigInt */
-
-const intIdentify$1 = value => typeof value === 'bigint' || Number.isInteger(value);
-
-const stringifyJSON = ({
- value
-}) => JSON.stringify(value);
-
-const json = [map, seq, {
- identify: value => typeof value === 'string',
- default: true,
- tag: 'tag:yaml.org,2002:str',
- resolve: resolveSeqD03cb037.resolveString,
- stringify: stringifyJSON
-}, {
- identify: value => value == null,
- createNode: (schema, value, ctx) => ctx.wrapScalars ? new resolveSeqD03cb037.Scalar(null) : null,
- default: true,
- tag: 'tag:yaml.org,2002:null',
- test: /^null$/,
- resolve: () => null,
- stringify: stringifyJSON
-}, {
- identify: value => typeof value === 'boolean',
- default: true,
- tag: 'tag:yaml.org,2002:bool',
- test: /^true|false$/,
- resolve: str => str === 'true',
- stringify: stringifyJSON
-}, {
- identify: intIdentify$1,
- default: true,
- tag: 'tag:yaml.org,2002:int',
- test: /^-?(?:0|[1-9][0-9]*)$/,
- resolve: str => resolveSeqD03cb037.intOptions.asBigInt ? BigInt(str) : parseInt(str, 10),
- stringify: ({
- value
- }) => intIdentify$1(value) ? value.toString() : JSON.stringify(value)
-}, {
- identify: value => typeof value === 'number',
- default: true,
- tag: 'tag:yaml.org,2002:float',
- test: /^-?(?:0|[1-9][0-9]*)(?:\.[0-9]*)?(?:[eE][-+]?[0-9]+)?$/,
- resolve: str => parseFloat(str),
- stringify: stringifyJSON
-}];
-
-json.scalarFallback = str => {
- throw new SyntaxError(`Unresolved plain scalar ${JSON.stringify(str)}`);
-};
-
-/* global BigInt */
-
-const boolStringify = ({
- value
-}) => value ? resolveSeqD03cb037.boolOptions.trueStr : resolveSeqD03cb037.boolOptions.falseStr;
-
-const intIdentify = value => typeof value === 'bigint' || Number.isInteger(value);
-
-function intResolve(sign, src, radix) {
- let str = src.replace(/_/g, '');
-
- if (resolveSeqD03cb037.intOptions.asBigInt) {
- switch (radix) {
- case 2:
- str = `0b${str}`;
- break;
-
- case 8:
- str = `0o${str}`;
- break;
-
- case 16:
- str = `0x${str}`;
- break;
- }
-
- const n = BigInt(str);
- return sign === '-' ? BigInt(-1) * n : n;
- }
-
- const n = parseInt(str, radix);
- return sign === '-' ? -1 * n : n;
-}
-
-function intStringify(node, radix, prefix) {
- const {
- value
- } = node;
-
- if (intIdentify(value)) {
- const str = value.toString(radix);
- return value < 0 ? '-' + prefix + str.substr(1) : prefix + str;
- }
-
- return resolveSeqD03cb037.stringifyNumber(node);
-}
-
-const yaml11 = failsafe.concat([{
- identify: value => value == null,
- createNode: (schema, value, ctx) => ctx.wrapScalars ? new resolveSeqD03cb037.Scalar(null) : null,
- default: true,
- tag: 'tag:yaml.org,2002:null',
- test: /^(?:~|[Nn]ull|NULL)?$/,
- resolve: () => null,
- options: resolveSeqD03cb037.nullOptions,
- stringify: () => resolveSeqD03cb037.nullOptions.nullStr
-}, {
- identify: value => typeof value === 'boolean',
- default: true,
- tag: 'tag:yaml.org,2002:bool',
- test: /^(?:Y|y|[Yy]es|YES|[Tt]rue|TRUE|[Oo]n|ON)$/,
- resolve: () => true,
- options: resolveSeqD03cb037.boolOptions,
- stringify: boolStringify
-}, {
- identify: value => typeof value === 'boolean',
- default: true,
- tag: 'tag:yaml.org,2002:bool',
- test: /^(?:N|n|[Nn]o|NO|[Ff]alse|FALSE|[Oo]ff|OFF)$/i,
- resolve: () => false,
- options: resolveSeqD03cb037.boolOptions,
- stringify: boolStringify
-}, {
- identify: intIdentify,
- default: true,
- tag: 'tag:yaml.org,2002:int',
- format: 'BIN',
- test: /^([-+]?)0b([0-1_]+)$/,
- resolve: (str, sign, bin) => intResolve(sign, bin, 2),
- stringify: node => intStringify(node, 2, '0b')
-}, {
- identify: intIdentify,
- default: true,
- tag: 'tag:yaml.org,2002:int',
- format: 'OCT',
- test: /^([-+]?)0([0-7_]+)$/,
- resolve: (str, sign, oct) => intResolve(sign, oct, 8),
- stringify: node => intStringify(node, 8, '0')
-}, {
- identify: intIdentify,
- default: true,
- tag: 'tag:yaml.org,2002:int',
- test: /^([-+]?)([0-9][0-9_]*)$/,
- resolve: (str, sign, abs) => intResolve(sign, abs, 10),
- stringify: resolveSeqD03cb037.stringifyNumber
-}, {
- identify: intIdentify,
- default: true,
- tag: 'tag:yaml.org,2002:int',
- format: 'HEX',
- test: /^([-+]?)0x([0-9a-fA-F_]+)$/,
- resolve: (str, sign, hex) => intResolve(sign, hex, 16),
- stringify: node => intStringify(node, 16, '0x')
-}, {
- identify: value => typeof value === 'number',
- default: true,
- tag: 'tag:yaml.org,2002:float',
- test: /^(?:[-+]?\.inf|(\.nan))$/i,
- resolve: (str, nan) => nan ? NaN : str[0] === '-' ? Number.NEGATIVE_INFINITY : Number.POSITIVE_INFINITY,
- stringify: resolveSeqD03cb037.stringifyNumber
-}, {
- identify: value => typeof value === 'number',
- default: true,
- tag: 'tag:yaml.org,2002:float',
- format: 'EXP',
- test: /^[-+]?([0-9][0-9_]*)?(\.[0-9_]*)?[eE][-+]?[0-9]+$/,
- resolve: str => parseFloat(str.replace(/_/g, '')),
- stringify: ({
- value
- }) => Number(value).toExponential()
-}, {
- identify: value => typeof value === 'number',
- default: true,
- tag: 'tag:yaml.org,2002:float',
- test: /^[-+]?(?:[0-9][0-9_]*)?\.([0-9_]*)$/,
-
- resolve(str, frac) {
- const node = new resolveSeqD03cb037.Scalar(parseFloat(str.replace(/_/g, '')));
-
- if (frac) {
- const f = frac.replace(/_/g, '');
- if (f[f.length - 1] === '0') node.minFractionDigits = f.length;
- }
-
- return node;
- },
-
- stringify: resolveSeqD03cb037.stringifyNumber
-}], warnings1000a372.binary, warnings1000a372.omap, warnings1000a372.pairs, warnings1000a372.set, warnings1000a372.intTime, warnings1000a372.floatTime, warnings1000a372.timestamp);
-
-const schemas = {
- core,
- failsafe,
- json,
- yaml11
-};
-const tags = {
- binary: warnings1000a372.binary,
- bool: boolObj,
- float: floatObj,
- floatExp: expObj,
- floatNaN: nanObj,
- floatTime: warnings1000a372.floatTime,
- int: intObj,
- intHex: hexObj,
- intOct: octObj,
- intTime: warnings1000a372.intTime,
- map,
- null: nullObj,
- omap: warnings1000a372.omap,
- pairs: warnings1000a372.pairs,
- seq,
- set: warnings1000a372.set,
- timestamp: warnings1000a372.timestamp
-};
-
-function findTagObject(value, tagName, tags) {
- if (tagName) {
- const match = tags.filter(t => t.tag === tagName);
- const tagObj = match.find(t => !t.format) || match[0];
- if (!tagObj) throw new Error(`Tag ${tagName} not found`);
- return tagObj;
- } // TODO: deprecate/remove class check
-
-
- return tags.find(t => (t.identify && t.identify(value) || t.class && value instanceof t.class) && !t.format);
-}
-
-function createNode$1(value, tagName, ctx) {
- if (value instanceof resolveSeqD03cb037.Node) return value;
- const {
- defaultPrefix,
- onTagObj,
- prevObjects,
- schema,
- wrapScalars
- } = ctx;
- if (tagName && tagName.startsWith('!!')) tagName = defaultPrefix + tagName.slice(2);
- let tagObj = findTagObject(value, tagName, schema.tags);
-
- if (!tagObj) {
- if (typeof value.toJSON === 'function') value = value.toJSON();
- if (!value || typeof value !== 'object') return wrapScalars ? new resolveSeqD03cb037.Scalar(value) : value;
- tagObj = value instanceof Map ? map : value[Symbol.iterator] ? seq : map;
- }
-
- if (onTagObj) {
- onTagObj(tagObj);
- delete ctx.onTagObj;
- } // Detect duplicate references to the same object & use Alias nodes for all
- // after first. The `obj` wrapper allows for circular references to resolve.
-
-
- const obj = {
- value: undefined,
- node: undefined
- };
-
- if (value && typeof value === 'object' && prevObjects) {
- const prev = prevObjects.get(value);
-
- if (prev) {
- const alias = new resolveSeqD03cb037.Alias(prev); // leaves source dirty; must be cleaned by caller
-
- ctx.aliasNodes.push(alias); // defined along with prevObjects
-
- return alias;
- }
-
- obj.value = value;
- prevObjects.set(value, obj);
- }
-
- obj.node = tagObj.createNode ? tagObj.createNode(ctx.schema, value, ctx) : wrapScalars ? new resolveSeqD03cb037.Scalar(value) : value;
- if (tagName && obj.node instanceof resolveSeqD03cb037.Node) obj.node.tag = tagName;
- return obj.node;
-}
-
-function getSchemaTags(schemas, knownTags, customTags, schemaId) {
- let tags = schemas[schemaId.replace(/\W/g, '')]; // 'yaml-1.1' -> 'yaml11'
-
- if (!tags) {
- const keys = Object.keys(schemas).map(key => JSON.stringify(key)).join(', ');
- throw new Error(`Unknown schema "${schemaId}"; use one of ${keys}`);
- }
-
- if (Array.isArray(customTags)) {
- for (const tag of customTags) tags = tags.concat(tag);
- } else if (typeof customTags === 'function') {
- tags = customTags(tags.slice());
- }
-
- for (let i = 0; i < tags.length; ++i) {
- const tag = tags[i];
-
- if (typeof tag === 'string') {
- const tagObj = knownTags[tag];
-
- if (!tagObj) {
- const keys = Object.keys(knownTags).map(key => JSON.stringify(key)).join(', ');
- throw new Error(`Unknown custom tag "${tag}"; use one of ${keys}`);
- }
-
- tags[i] = tagObj;
- }
- }
-
- return tags;
-}
-
-const sortMapEntriesByKey = (a, b) => a.key < b.key ? -1 : a.key > b.key ? 1 : 0;
-
-class Schema {
- // TODO: remove in v2
- // TODO: remove in v2
- constructor({
- customTags,
- merge,
- schema,
- sortMapEntries,
- tags: deprecatedCustomTags
- }) {
- this.merge = !!merge;
- this.name = schema;
- this.sortMapEntries = sortMapEntries === true ? sortMapEntriesByKey : sortMapEntries || null;
- if (!customTags && deprecatedCustomTags) warnings1000a372.warnOptionDeprecation('tags', 'customTags');
- this.tags = getSchemaTags(schemas, tags, customTags || deprecatedCustomTags, schema);
- }
-
- createNode(value, wrapScalars, tagName, ctx) {
- const baseCtx = {
- defaultPrefix: Schema.defaultPrefix,
- schema: this,
- wrapScalars
- };
- const createCtx = ctx ? Object.assign(ctx, baseCtx) : baseCtx;
- return createNode$1(value, tagName, createCtx);
- }
-
- createPair(key, value, ctx) {
- if (!ctx) ctx = {
- wrapScalars: true
- };
- const k = this.createNode(key, ctx.wrapScalars, null, ctx);
- const v = this.createNode(value, ctx.wrapScalars, null, ctx);
- return new resolveSeqD03cb037.Pair(k, v);
- }
-
-}
-
-PlainValueEc8e588e._defineProperty(Schema, "defaultPrefix", PlainValueEc8e588e.defaultTagPrefix);
-
-PlainValueEc8e588e._defineProperty(Schema, "defaultTags", PlainValueEc8e588e.defaultTags);
-
-var Schema_1 = Schema;
-
-var Schema88e323a7 = {
- Schema: Schema_1
-};
-
-const defaultOptions = {
- anchorPrefix: 'a',
- customTags: null,
- indent: 2,
- indentSeq: true,
- keepCstNodes: false,
- keepNodeTypes: true,
- keepBlobsInJSON: true,
- mapAsMap: false,
- maxAliasCount: 100,
- prettyErrors: false,
- // TODO Set true in v2
- simpleKeys: false,
- version: '1.2'
-};
-const scalarOptions = {
- get binary() {
- return resolveSeqD03cb037.binaryOptions;
- },
-
- set binary(opt) {
- Object.assign(resolveSeqD03cb037.binaryOptions, opt);
- },
-
- get bool() {
- return resolveSeqD03cb037.boolOptions;
- },
-
- set bool(opt) {
- Object.assign(resolveSeqD03cb037.boolOptions, opt);
- },
-
- get int() {
- return resolveSeqD03cb037.intOptions;
- },
-
- set int(opt) {
- Object.assign(resolveSeqD03cb037.intOptions, opt);
- },
-
- get null() {
- return resolveSeqD03cb037.nullOptions;
- },
-
- set null(opt) {
- Object.assign(resolveSeqD03cb037.nullOptions, opt);
- },
-
- get str() {
- return resolveSeqD03cb037.strOptions;
- },
-
- set str(opt) {
- Object.assign(resolveSeqD03cb037.strOptions, opt);
- }
-
-};
-const documentOptions = {
- '1.0': {
- schema: 'yaml-1.1',
- merge: true,
- tagPrefixes: [{
- handle: '!',
- prefix: PlainValueEc8e588e.defaultTagPrefix
- }, {
- handle: '!!',
- prefix: 'tag:private.yaml.org,2002:'
- }]
- },
- 1.1: {
- schema: 'yaml-1.1',
- merge: true,
- tagPrefixes: [{
- handle: '!',
- prefix: '!'
- }, {
- handle: '!!',
- prefix: PlainValueEc8e588e.defaultTagPrefix
- }]
- },
- 1.2: {
- schema: 'core',
- merge: false,
- tagPrefixes: [{
- handle: '!',
- prefix: '!'
- }, {
- handle: '!!',
- prefix: PlainValueEc8e588e.defaultTagPrefix
- }]
- }
-};
-
-function stringifyTag(doc, tag) {
- if ((doc.version || doc.options.version) === '1.0') {
- const priv = tag.match(/^tag:private\.yaml\.org,2002:([^:/]+)$/);
- if (priv) return '!' + priv[1];
- const vocab = tag.match(/^tag:([a-zA-Z0-9-]+)\.yaml\.org,2002:(.*)/);
- return vocab ? `!${vocab[1]}/${vocab[2]}` : `!${tag.replace(/^tag:/, '')}`;
- }
-
- let p = doc.tagPrefixes.find(p => tag.indexOf(p.prefix) === 0);
-
- if (!p) {
- const dtp = doc.getDefaults().tagPrefixes;
- p = dtp && dtp.find(p => tag.indexOf(p.prefix) === 0);
- }
-
- if (!p) return tag[0] === '!' ? tag : `!<${tag}>`;
- const suffix = tag.substr(p.prefix.length).replace(/[!,[\]{}]/g, ch => ({
- '!': '%21',
- ',': '%2C',
- '[': '%5B',
- ']': '%5D',
- '{': '%7B',
- '}': '%7D'
- })[ch]);
- return p.handle + suffix;
-}
-
-function getTagObject(tags, item) {
- if (item instanceof resolveSeqD03cb037.Alias) return resolveSeqD03cb037.Alias;
-
- if (item.tag) {
- const match = tags.filter(t => t.tag === item.tag);
- if (match.length > 0) return match.find(t => t.format === item.format) || match[0];
- }
-
- let tagObj, obj;
-
- if (item instanceof resolveSeqD03cb037.Scalar) {
- obj = item.value; // TODO: deprecate/remove class check
-
- const match = tags.filter(t => t.identify && t.identify(obj) || t.class && obj instanceof t.class);
- tagObj = match.find(t => t.format === item.format) || match.find(t => !t.format);
- } else {
- obj = item;
- tagObj = tags.find(t => t.nodeClass && obj instanceof t.nodeClass);
- }
-
- if (!tagObj) {
- const name = obj && obj.constructor ? obj.constructor.name : typeof obj;
- throw new Error(`Tag not resolved for ${name} value`);
- }
-
- return tagObj;
-} // needs to be called before value stringifier to allow for circular anchor refs
-
-
-function stringifyProps(node, tagObj, {
- anchors,
- doc
-}) {
- const props = [];
- const anchor = doc.anchors.getName(node);
-
- if (anchor) {
- anchors[anchor] = node;
- props.push(`&${anchor}`);
- }
-
- if (node.tag) {
- props.push(stringifyTag(doc, node.tag));
- } else if (!tagObj.default) {
- props.push(stringifyTag(doc, tagObj.tag));
- }
-
- return props.join(' ');
-}
-
-function stringify$1(item, ctx, onComment, onChompKeep) {
- const {
- anchors,
- schema
- } = ctx.doc;
- let tagObj;
-
- if (!(item instanceof resolveSeqD03cb037.Node)) {
- const createCtx = {
- aliasNodes: [],
- onTagObj: o => tagObj = o,
- prevObjects: new Map()
- };
- item = schema.createNode(item, true, null, createCtx);
-
- for (const alias of createCtx.aliasNodes) {
- alias.source = alias.source.node;
- let name = anchors.getName(alias.source);
-
- if (!name) {
- name = anchors.newName();
- anchors.map[name] = alias.source;
- }
- }
- }
-
- if (item instanceof resolveSeqD03cb037.Pair) return item.toString(ctx, onComment, onChompKeep);
- if (!tagObj) tagObj = getTagObject(schema.tags, item);
- const props = stringifyProps(item, tagObj, ctx);
- if (props.length > 0) ctx.indentAtStart = (ctx.indentAtStart || 0) + props.length + 1;
- const str = typeof tagObj.stringify === 'function' ? tagObj.stringify(item, ctx, onComment, onChompKeep) : item instanceof resolveSeqD03cb037.Scalar ? resolveSeqD03cb037.stringifyString(item, ctx, onComment, onChompKeep) : item.toString(ctx, onComment, onChompKeep);
- if (!props) return str;
- return item instanceof resolveSeqD03cb037.Scalar || str[0] === '{' || str[0] === '[' ? `${props} ${str}` : `${props}\n${ctx.indent}${str}`;
-}
-
-class Anchors {
- static validAnchorNode(node) {
- return node instanceof resolveSeqD03cb037.Scalar || node instanceof resolveSeqD03cb037.YAMLSeq || node instanceof resolveSeqD03cb037.YAMLMap;
- }
-
- constructor(prefix) {
- PlainValueEc8e588e._defineProperty(this, "map", Object.create(null));
-
- this.prefix = prefix;
- }
-
- createAlias(node, name) {
- this.setAnchor(node, name);
- return new resolveSeqD03cb037.Alias(node);
- }
-
- createMergePair(...sources) {
- const merge = new resolveSeqD03cb037.Merge();
- merge.value.items = sources.map(s => {
- if (s instanceof resolveSeqD03cb037.Alias) {
- if (s.source instanceof resolveSeqD03cb037.YAMLMap) return s;
- } else if (s instanceof resolveSeqD03cb037.YAMLMap) {
- return this.createAlias(s);
- }
-
- throw new Error('Merge sources must be Map nodes or their Aliases');
- });
- return merge;
- }
-
- getName(node) {
- const {
- map
- } = this;
- return Object.keys(map).find(a => map[a] === node);
- }
-
- getNames() {
- return Object.keys(this.map);
- }
-
- getNode(name) {
- return this.map[name];
- }
-
- newName(prefix) {
- if (!prefix) prefix = this.prefix;
- const names = Object.keys(this.map);
-
- for (let i = 1; true; ++i) {
- const name = `${prefix}${i}`;
- if (!names.includes(name)) return name;
- }
- } // During parsing, map & aliases contain CST nodes
-
-
- resolveNodes() {
- const {
- map,
- _cstAliases
- } = this;
- Object.keys(map).forEach(a => {
- map[a] = map[a].resolved;
- });
-
- _cstAliases.forEach(a => {
- a.source = a.source.resolved;
- });
-
- delete this._cstAliases;
- }
-
- setAnchor(node, name) {
- if (node != null && !Anchors.validAnchorNode(node)) {
- throw new Error('Anchors may only be set for Scalar, Seq and Map nodes');
- }
-
- if (name && /[\x00-\x19\s,[\]{}]/.test(name)) {
- throw new Error('Anchor names must not contain whitespace or control characters');
- }
-
- const {
- map
- } = this;
- const prev = node && Object.keys(map).find(a => map[a] === node);
-
- if (prev) {
- if (!name) {
- return prev;
- } else if (prev !== name) {
- delete map[prev];
- map[name] = node;
- }
- } else {
- if (!name) {
- if (!node) return null;
- name = this.newName();
- }
-
- map[name] = node;
- }
-
- return name;
- }
-
-}
-
-const visit = (node, tags) => {
- if (node && typeof node === 'object') {
- const {
- tag
- } = node;
-
- if (node instanceof resolveSeqD03cb037.Collection) {
- if (tag) tags[tag] = true;
- node.items.forEach(n => visit(n, tags));
- } else if (node instanceof resolveSeqD03cb037.Pair) {
- visit(node.key, tags);
- visit(node.value, tags);
- } else if (node instanceof resolveSeqD03cb037.Scalar) {
- if (tag) tags[tag] = true;
- }
- }
-
- return tags;
-};
-
-const listTagNames = node => Object.keys(visit(node, {}));
-
-function parseContents(doc, contents) {
- const comments = {
- before: [],
- after: []
- };
- let body = undefined;
- let spaceBefore = false;
-
- for (const node of contents) {
- if (node.valueRange) {
- if (body !== undefined) {
- const msg = 'Document contains trailing content not separated by a ... or --- line';
- doc.errors.push(new PlainValueEc8e588e.YAMLSyntaxError(node, msg));
- break;
- }
-
- const res = resolveSeqD03cb037.resolveNode(doc, node);
-
- if (spaceBefore) {
- res.spaceBefore = true;
- spaceBefore = false;
- }
-
- body = res;
- } else if (node.comment !== null) {
- const cc = body === undefined ? comments.before : comments.after;
- cc.push(node.comment);
- } else if (node.type === PlainValueEc8e588e.Type.BLANK_LINE) {
- spaceBefore = true;
-
- if (body === undefined && comments.before.length > 0 && !doc.commentBefore) {
- // space-separated comments at start are parsed as document comments
- doc.commentBefore = comments.before.join('\n');
- comments.before = [];
- }
- }
- }
-
- doc.contents = body || null;
-
- if (!body) {
- doc.comment = comments.before.concat(comments.after).join('\n') || null;
- } else {
- const cb = comments.before.join('\n');
-
- if (cb) {
- const cbNode = body instanceof resolveSeqD03cb037.Collection && body.items[0] ? body.items[0] : body;
- cbNode.commentBefore = cbNode.commentBefore ? `${cb}\n${cbNode.commentBefore}` : cb;
- }
-
- doc.comment = comments.after.join('\n') || null;
- }
-}
-
-function resolveTagDirective({
- tagPrefixes
-}, directive) {
- const [handle, prefix] = directive.parameters;
-
- if (!handle || !prefix) {
- const msg = 'Insufficient parameters given for %TAG directive';
- throw new PlainValueEc8e588e.YAMLSemanticError(directive, msg);
- }
-
- if (tagPrefixes.some(p => p.handle === handle)) {
- const msg = 'The %TAG directive must only be given at most once per handle in the same document.';
- throw new PlainValueEc8e588e.YAMLSemanticError(directive, msg);
- }
-
- return {
- handle,
- prefix
- };
-}
-
-function resolveYamlDirective(doc, directive) {
- let [version] = directive.parameters;
- if (directive.name === 'YAML:1.0') version = '1.0';
-
- if (!version) {
- const msg = 'Insufficient parameters given for %YAML directive';
- throw new PlainValueEc8e588e.YAMLSemanticError(directive, msg);
- }
-
- if (!documentOptions[version]) {
- const v0 = doc.version || doc.options.version;
- const msg = `Document will be parsed as YAML ${v0} rather than YAML ${version}`;
- doc.warnings.push(new PlainValueEc8e588e.YAMLWarning(directive, msg));
- }
-
- return version;
-}
-
-function parseDirectives(doc, directives, prevDoc) {
- const directiveComments = [];
- let hasDirectives = false;
-
- for (const directive of directives) {
- const {
- comment,
- name
- } = directive;
-
- switch (name) {
- case 'TAG':
- try {
- doc.tagPrefixes.push(resolveTagDirective(doc, directive));
- } catch (error) {
- doc.errors.push(error);
- }
-
- hasDirectives = true;
- break;
-
- case 'YAML':
- case 'YAML:1.0':
- if (doc.version) {
- const msg = 'The %YAML directive must only be given at most once per document.';
- doc.errors.push(new PlainValueEc8e588e.YAMLSemanticError(directive, msg));
- }
-
- try {
- doc.version = resolveYamlDirective(doc, directive);
- } catch (error) {
- doc.errors.push(error);
- }
-
- hasDirectives = true;
- break;
-
- default:
- if (name) {
- const msg = `YAML only supports %TAG and %YAML directives, and not %${name}`;
- doc.warnings.push(new PlainValueEc8e588e.YAMLWarning(directive, msg));
- }
-
- }
-
- if (comment) directiveComments.push(comment);
- }
-
- if (prevDoc && !hasDirectives && '1.1' === (doc.version || prevDoc.version || doc.options.version)) {
- const copyTagPrefix = ({
- handle,
- prefix
- }) => ({
- handle,
- prefix
- });
-
- doc.tagPrefixes = prevDoc.tagPrefixes.map(copyTagPrefix);
- doc.version = prevDoc.version;
- }
-
- doc.commentBefore = directiveComments.join('\n') || null;
-}
-
-function assertCollection(contents) {
- if (contents instanceof resolveSeqD03cb037.Collection) return true;
- throw new Error('Expected a YAML collection as document contents');
-}
-
-class Document$2 {
- constructor(options) {
- this.anchors = new Anchors(options.anchorPrefix);
- this.commentBefore = null;
- this.comment = null;
- this.contents = null;
- this.directivesEndMarker = null;
- this.errors = [];
- this.options = options;
- this.schema = null;
- this.tagPrefixes = [];
- this.version = null;
- this.warnings = [];
- }
-
- add(value) {
- assertCollection(this.contents);
- return this.contents.add(value);
- }
-
- addIn(path, value) {
- assertCollection(this.contents);
- this.contents.addIn(path, value);
- }
-
- delete(key) {
- assertCollection(this.contents);
- return this.contents.delete(key);
- }
-
- deleteIn(path) {
- if (resolveSeqD03cb037.isEmptyPath(path)) {
- if (this.contents == null) return false;
- this.contents = null;
- return true;
- }
-
- assertCollection(this.contents);
- return this.contents.deleteIn(path);
- }
-
- getDefaults() {
- return Document$2.defaults[this.version] || Document$2.defaults[this.options.version] || {};
- }
-
- get(key, keepScalar) {
- return this.contents instanceof resolveSeqD03cb037.Collection ? this.contents.get(key, keepScalar) : undefined;
- }
-
- getIn(path, keepScalar) {
- if (resolveSeqD03cb037.isEmptyPath(path)) return !keepScalar && this.contents instanceof resolveSeqD03cb037.Scalar ? this.contents.value : this.contents;
- return this.contents instanceof resolveSeqD03cb037.Collection ? this.contents.getIn(path, keepScalar) : undefined;
- }
-
- has(key) {
- return this.contents instanceof resolveSeqD03cb037.Collection ? this.contents.has(key) : false;
- }
-
- hasIn(path) {
- if (resolveSeqD03cb037.isEmptyPath(path)) return this.contents !== undefined;
- return this.contents instanceof resolveSeqD03cb037.Collection ? this.contents.hasIn(path) : false;
- }
-
- set(key, value) {
- assertCollection(this.contents);
- this.contents.set(key, value);
- }
-
- setIn(path, value) {
- if (resolveSeqD03cb037.isEmptyPath(path)) this.contents = value;else {
- assertCollection(this.contents);
- this.contents.setIn(path, value);
- }
- }
-
- setSchema(id, customTags) {
- if (!id && !customTags && this.schema) return;
- if (typeof id === 'number') id = id.toFixed(1);
-
- if (id === '1.0' || id === '1.1' || id === '1.2') {
- if (this.version) this.version = id;else this.options.version = id;
- delete this.options.schema;
- } else if (id && typeof id === 'string') {
- this.options.schema = id;
- }
-
- if (Array.isArray(customTags)) this.options.customTags = customTags;
- const opt = Object.assign({}, this.getDefaults(), this.options);
- this.schema = new Schema88e323a7.Schema(opt);
- }
-
- parse(node, prevDoc) {
- if (this.options.keepCstNodes) this.cstNode = node;
- if (this.options.keepNodeTypes) this.type = 'DOCUMENT';
- const {
- directives = [],
- contents = [],
- directivesEndMarker,
- error,
- valueRange
- } = node;
-
- if (error) {
- if (!error.source) error.source = this;
- this.errors.push(error);
- }
-
- parseDirectives(this, directives, prevDoc);
- if (directivesEndMarker) this.directivesEndMarker = true;
- this.range = valueRange ? [valueRange.start, valueRange.end] : null;
- this.setSchema();
- this.anchors._cstAliases = [];
- parseContents(this, contents);
- this.anchors.resolveNodes();
-
- if (this.options.prettyErrors) {
- for (const error of this.errors) if (error instanceof PlainValueEc8e588e.YAMLError) error.makePretty();
-
- for (const warn of this.warnings) if (warn instanceof PlainValueEc8e588e.YAMLError) warn.makePretty();
- }
-
- return this;
- }
-
- listNonDefaultTags() {
- return listTagNames(this.contents).filter(t => t.indexOf(Schema88e323a7.Schema.defaultPrefix) !== 0);
- }
-
- setTagPrefix(handle, prefix) {
- if (handle[0] !== '!' || handle[handle.length - 1] !== '!') throw new Error('Handle must start and end with !');
-
- if (prefix) {
- const prev = this.tagPrefixes.find(p => p.handle === handle);
- if (prev) prev.prefix = prefix;else this.tagPrefixes.push({
- handle,
- prefix
- });
- } else {
- this.tagPrefixes = this.tagPrefixes.filter(p => p.handle !== handle);
- }
- }
-
- toJSON(arg, onAnchor) {
- const {
- keepBlobsInJSON,
- mapAsMap,
- maxAliasCount
- } = this.options;
- const keep = keepBlobsInJSON && (typeof arg !== 'string' || !(this.contents instanceof resolveSeqD03cb037.Scalar));
- const ctx = {
- doc: this,
- indentStep: ' ',
- keep,
- mapAsMap: keep && !!mapAsMap,
- maxAliasCount,
- stringify: stringify$1 // Requiring directly in Pair would create circular dependencies
-
- };
- const anchorNames = Object.keys(this.anchors.map);
- if (anchorNames.length > 0) ctx.anchors = new Map(anchorNames.map(name => [this.anchors.map[name], {
- alias: [],
- aliasCount: 0,
- count: 1
- }]));
- const res = resolveSeqD03cb037.toJSON(this.contents, arg, ctx);
- if (typeof onAnchor === 'function' && ctx.anchors) for (const {
- count,
- res
- } of ctx.anchors.values()) onAnchor(res, count);
- return res;
- }
-
- toString() {
- if (this.errors.length > 0) throw new Error('Document with errors cannot be stringified');
- const indentSize = this.options.indent;
-
- if (!Number.isInteger(indentSize) || indentSize <= 0) {
- const s = JSON.stringify(indentSize);
- throw new Error(`"indent" option must be a positive integer, not ${s}`);
- }
-
- this.setSchema();
- const lines = [];
- let hasDirectives = false;
-
- if (this.version) {
- let vd = '%YAML 1.2';
-
- if (this.schema.name === 'yaml-1.1') {
- if (this.version === '1.0') vd = '%YAML:1.0';else if (this.version === '1.1') vd = '%YAML 1.1';
- }
-
- lines.push(vd);
- hasDirectives = true;
- }
-
- const tagNames = this.listNonDefaultTags();
- this.tagPrefixes.forEach(({
- handle,
- prefix
- }) => {
- if (tagNames.some(t => t.indexOf(prefix) === 0)) {
- lines.push(`%TAG ${handle} ${prefix}`);
- hasDirectives = true;
- }
- });
- if (hasDirectives || this.directivesEndMarker) lines.push('---');
-
- if (this.commentBefore) {
- if (hasDirectives || !this.directivesEndMarker) lines.unshift('');
- lines.unshift(this.commentBefore.replace(/^/gm, '#'));
- }
-
- const ctx = {
- anchors: Object.create(null),
- doc: this,
- indent: '',
- indentStep: ' '.repeat(indentSize),
- stringify: stringify$1 // Requiring directly in nodes would create circular dependencies
-
- };
- let chompKeep = false;
- let contentComment = null;
-
- if (this.contents) {
- if (this.contents instanceof resolveSeqD03cb037.Node) {
- if (this.contents.spaceBefore && (hasDirectives || this.directivesEndMarker)) lines.push('');
- if (this.contents.commentBefore) lines.push(this.contents.commentBefore.replace(/^/gm, '#')); // top-level block scalars need to be indented if followed by a comment
-
- ctx.forceBlockIndent = !!this.comment;
- contentComment = this.contents.comment;
- }
-
- const onChompKeep = contentComment ? null : () => chompKeep = true;
- const body = stringify$1(this.contents, ctx, () => contentComment = null, onChompKeep);
- lines.push(resolveSeqD03cb037.addComment(body, '', contentComment));
- } else if (this.contents !== undefined) {
- lines.push(stringify$1(this.contents, ctx));
- }
-
- if (this.comment) {
- if ((!chompKeep || contentComment) && lines[lines.length - 1] !== '') lines.push('');
- lines.push(this.comment.replace(/^/gm, '#'));
- }
-
- return lines.join('\n') + '\n';
- }
-
-}
-
-PlainValueEc8e588e._defineProperty(Document$2, "defaults", documentOptions);
-
-var Document_1 = Document$2;
-var defaultOptions_1 = defaultOptions;
-var scalarOptions_1 = scalarOptions;
-
-var Document9b4560a1 = {
- Document: Document_1,
- defaultOptions: defaultOptions_1,
- scalarOptions: scalarOptions_1
-};
-
-function createNode(value, wrapScalars = true, tag) {
- if (tag === undefined && typeof wrapScalars === 'string') {
- tag = wrapScalars;
- wrapScalars = true;
- }
-
- const options = Object.assign({}, Document9b4560a1.Document.defaults[Document9b4560a1.defaultOptions.version], Document9b4560a1.defaultOptions);
- const schema = new Schema88e323a7.Schema(options);
- return schema.createNode(value, wrapScalars, tag);
-}
-
-class Document$1 extends Document9b4560a1.Document {
- constructor(options) {
- super(Object.assign({}, Document9b4560a1.defaultOptions, options));
- }
-
-}
-
-function parseAllDocuments(src, options) {
- const stream = [];
- let prev;
-
- for (const cstDoc of parseCst.parse(src)) {
- const doc = new Document$1(options);
- doc.parse(cstDoc, prev);
- stream.push(doc);
- prev = doc;
- }
-
- return stream;
-}
-
-function parseDocument(src, options) {
- const cst = parseCst.parse(src);
- const doc = new Document$1(options).parse(cst[0]);
-
- if (cst.length > 1) {
- const errMsg = 'Source contains multiple documents; please use YAML.parseAllDocuments()';
- doc.errors.unshift(new PlainValueEc8e588e.YAMLSemanticError(cst[1], errMsg));
- }
-
- return doc;
-}
-
-function parse(src, options) {
- const doc = parseDocument(src, options);
- doc.warnings.forEach(warning => warnings1000a372.warn(warning));
- if (doc.errors.length > 0) throw doc.errors[0];
- return doc.toJSON();
-}
-
-function stringify(value, options) {
- const doc = new Document$1(options);
- doc.contents = value;
- return String(doc);
-}
-
-const YAML = {
- createNode,
- defaultOptions: Document9b4560a1.defaultOptions,
- Document: Document$1,
- parse,
- parseAllDocuments,
- parseCST: parseCst.parse,
- parseDocument,
- scalarOptions: Document9b4560a1.scalarOptions,
- stringify
-};
-
-var YAML_1 = YAML;
-
-var dist = {
- YAML: YAML_1
-};
-
-var yaml = dist.YAML;
-
-let VehicleCardEditor = class VehicleCardEditor extends s {
- constructor() {
- super(...arguments);
- this.isVehicleCardEditor = false;
- this.isTripCardEditor = false;
- this.isEcoCardEditor = false;
- this.isTyreCardEditor = false;
- }
- get isSubEditorOpen() {
- return this.isVehicleCardEditor || this.isTripCardEditor || this.isEcoCardEditor || this.isTyreCardEditor;
- }
- async setConfig(config) {
- this._config = config;
- if (!this._config.entity) {
- this._config.entity = this.getCarEntity();
- this._config.name = await this.getDeviceModelName();
- ne(this, 'config-changed', { config: this._config });
- }
- this.loadCardHelpers();
- }
- getCarEntity() {
- if (!this.hass)
- return '';
- const entities = Object.keys(this.hass.states).filter((entity) => entity.startsWith('sensor') && entity.endsWith('_car'));
- return entities[0] || '';
- }
- async getDeviceModelName() {
- var _a;
- if (!((_a = this._config) === null || _a === void 0 ? void 0 : _a.entity))
- return '';
- const carEntityId = this._config.entity;
- // Fetch all entities
- const allEntities = await this.hass.callWS({
- type: 'config/entity_registry/list',
- });
- // Find the car entity
- const carEntity = allEntities.find((entity) => entity.entity_id === carEntityId);
- if (!carEntity)
- return '';
- console.log('Car Entity:', carEntity);
- const deviceId = carEntity.device_id;
- if (!deviceId)
- return '';
- // Fetch all devices
- const allDevices = await this.hass.callWS({
- type: 'config/device_registry/list',
- });
- // Find the device by ID
- const device = allDevices.find((device) => device.id === deviceId);
- if (!device)
- return '';
- console.log('Device:', device);
- return device.model || '';
- }
- get _name() {
- var _a;
- return ((_a = this._config) === null || _a === void 0 ? void 0 : _a.name) || '';
- }
- get _entity() {
- var _a;
- return ((_a = this._config) === null || _a === void 0 ? void 0 : _a.entity) || '';
- }
- get _device_tracker() {
- var _a;
- return ((_a = this._config) === null || _a === void 0 ? void 0 : _a.device_tracker) || '';
- }
- get _show_slides() {
- var _a;
- return ((_a = this._config) === null || _a === void 0 ? void 0 : _a.show_slides) || false;
- }
- get _show_map() {
- var _a;
- return ((_a = this._config) === null || _a === void 0 ? void 0 : _a.show_map) || false;
- }
- get _show_buttons() {
- var _a;
- return ((_a = this._config) === null || _a === void 0 ? void 0 : _a.show_buttons) || false;
- }
- get _show_background() {
- var _a;
- return ((_a = this._config) === null || _a === void 0 ? void 0 : _a.show_background) || false;
- }
- get _enable_map_popup() {
- var _a;
- return ((_a = this._config) === null || _a === void 0 ? void 0 : _a.enable_map_popup) || false;
- }
- get _google_api_key() {
- var _a;
- return ((_a = this._config) === null || _a === void 0 ? void 0 : _a.google_api_key) || '';
- }
- get _enable_services_control() {
- var _a;
- return ((_a = this._config) === null || _a === void 0 ? void 0 : _a.enable_services_control) || false;
- }
- render() {
- if (!this.hass || !this._helpers) {
- return x ``;
- }
- return x `
-
- ${this._renderBaseConfig()} ${this._renderSubCardConfig('vehicle', this.isVehicleCardEditor)}
- ${this._renderSubCardConfig('trip', this.isTripCardEditor)}
- ${this._renderSubCardConfig('eco', this.isEcoCardEditor)}
- ${this._renderSubCardConfig('tyre', this.isTyreCardEditor)}
-
- `;
- }
- _renderBaseConfig() {
- if (this.isSubEditorOpen)
- return x ``;
- return x `
-
- ${this._renderFormSelectors()} ${this._renderCardEditorButtons()} ${this._renderMapPopupConfig()}
- ${this._renderImageConfig()} ${this._renderServicesConfig()}
-
-
${this._renderSwitches()}
-
-
version: ${CARD_VERSION}
-
-
- `;
- }
- _renderCardEditorButtons() {
- return x `
-
- Buttons configuration
-
-
Select the card you want to configure.
-
- (this.isTripCardEditor = true)}>Trip Card
- (this.isVehicleCardEditor = true)}>Vehicle Card
- (this.isEcoCardEditor = true)}>Eco Card
- (this.isTyreCardEditor = true)}>Tyre Card
-
-
-
-
`;
- }
- _renderSubCardConfig(cardType, isEditorOpen) {
- var _a;
- if (!isEditorOpen)
- return x ``;
- return x `
-
-
- this._handleCardConfigChange(ev, `${cardType}_card`)}
- >
-
- `;
- }
- _handleBackClick() {
- this.isVehicleCardEditor = false;
- this.isTripCardEditor = false;
- this.isEcoCardEditor = false;
- this.isTyreCardEditor = false;
- }
- _getCardTitle(cardType) {
- return `${cardType.charAt(0).toUpperCase() + cardType.slice(1)} Card Configuration`;
- }
- _renderSwitches() {
- var _a, _b, _c;
- return x `
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- `;
- }
- _renderFormSelectors() {
- // You can restrict on domain type
- // const entities = Object.keys(this.hass.states).filter((entity) => entity.startsWith('sensor'));
- const entities = Object.keys(this.hass.states).filter((entity) => entity.startsWith('sensor') && entity.endsWith('_car'));
- const device_trackers = Object.keys(this.hass.states).filter((entity) => entity.startsWith('device_tracker'));
- return x `
- ev.stopPropagation()}
- >
- ${entities.map((entity) => {
- return x `${entity} `;
- })}
-
-
- ev.stopPropagation()}
- >
-
- ${device_trackers.map((entity) => {
- return x `${entity} `;
- })}
-
- `;
- }
- _renderImageConfig() {
- let images = '';
- if (this._config && Array.isArray(this._config.images)) {
- images = this._config.images.join('\n');
- }
- else if (this._config && typeof this._config.images === 'string') {
- images = this._config.images;
- }
- return x `
-
- Images configuration
-
-
- There is no need to add a '-' for each line. Each line will be treated as a separate URL
- automatically.
-
-
-
-
`;
- }
- _renderMapPopupConfig() {
- var _a, _b, _c, _d, _e, _f;
- return x `
-
-
-
-
- Map Popup configuration
-
-
-
-
- ev.stopPropagation()}
- >
- Auto
- Dark
- Light
-
-
-
-
- `;
- }
- _renderServicesConfig() {
- var _a;
- const services = ((_a = this._config) === null || _a === void 0 ? void 0 : _a.services) || {}; // Ensure services object exists and default to empty object if undefined
- return x `
-
-
-
-
- Services configuration
-
-
-
- Choose which services you want to enable. If a service is disabled, it will not be shown in the card.
-
-
- ${Object.entries(servicesCtrl).map(([key, { name }]) => x `
-
-
-
- `)}
-
-
-
-
- `;
- }
- async loadCardHelpers() {
- this._helpers = await window.loadCardHelpers();
- }
- _handleCardConfigChange(ev, configKey) {
- if (!this._config || !this.hass) {
- return;
- }
- const target = ev.target;
- let newValue;
- try {
- newValue = yaml.parse(target.value); // Parse YAML content
- // If the parsed value is null or not an array, set it to an empty array
- if (!newValue || !Array.isArray(newValue)) {
- newValue = [];
- }
- }
- catch (e) {
- console.error(`Parsing error for ${configKey}:`, e);
- return;
- }
- this._config = Object.assign(Object.assign({}, this._config), { [configKey]: newValue });
- ne(this, 'config-changed', { config: this._config });
- }
- _servicesValueChanged(ev) {
- if (!this._config || !this.hass) {
- return;
- }
- const target = ev.target;
- const configValue = target.configValue;
- if (this[`${configValue}`] === target.checked) {
- return;
- }
- this._config = Object.assign(Object.assign({}, this._config), { services: Object.assign(Object.assign({}, this._config.services), { [configValue]: target.checked }) });
- ne(this, 'config-changed', { config: this._config });
- }
- _valueChanged(ev) {
- if (!this._config || !this.hass) {
- return;
- }
- const target = ev.target;
- const configValue = target.configValue;
- if (this[`_${configValue}`] === target.value) {
- return;
- }
- let newValue;
- if (configValue === 'images') {
- newValue = target.value
- .split('\n')
- .map((line) => line.trim())
- .filter((line) => line); // Remove empty lines
- this._config = Object.assign(Object.assign({}, this._config), { images: newValue });
- }
- else if (['hours_to_show', 'default_zoom'].includes(configValue)) {
- newValue = target.value === '' ? undefined : Number(target.value);
- if (!isNaN(newValue)) {
- this._config = Object.assign(Object.assign({}, this._config), { map_popup_config: Object.assign(Object.assign({}, this._config.map_popup_config), { [configValue]: newValue }) });
- }
- }
- else if (configValue === 'theme_mode') {
- newValue = target.value;
- this._config = Object.assign(Object.assign({}, this._config), { map_popup_config: Object.assign(Object.assign({}, this._config.map_popup_config), { [configValue]: newValue }) });
- }
- else {
- newValue = target.checked !== undefined ? target.checked : target.value;
- this._config = Object.assign(Object.assign({}, this._config), { [configValue]: newValue });
- }
- if (newValue && newValue.length === 0) {
- // Check for an empty array
- const tmpConfig = Object.assign({}, this._config);
- delete tmpConfig[configValue];
- this._config = tmpConfig;
- }
- ne(this, 'config-changed', { config: this._config });
- }
-};
-VehicleCardEditor.styles = i$2 `
- .card-config {
- width: 100%;
- }
- .panel-container {
- margin-top: 16px;
- }
-
- .switches {
- display: grid;
- grid-template-columns: 1fr 1fr;
- gap: 1rem;
- margin-block: 2rem;
- }
- ha-select,
- ha-textfield {
- margin-bottom: 16px;
- display: block;
- width: 100%;
- }
- ha-formfield {
- padding-bottom: 8px;
- width: 100%;
- }
- ha-switch {
- --mdc-theme-secondary: var(--switch-checked-color);
- }
-
- ha-expansion-panel .container {
- padding: 0px 1rem !important;
- }
- h3 {
- color: var(--secondary-text-color);
- margin-block: 0;
- }
-
- .note {
- color: var(--secondary-text-color);
- text-align: start;
- }
- .cards-buttons {
- display: flex;
- justify-content: space-around;
- }
-
- .sub-card-header {
- display: flex;
- width: 100%;
- justify-content: space-between;
- padding: 0.5rem 0 1rem;
- align-items: center;
- border-bottom: 1px solid var(--divider-color);
- }
-
- .sub-card-config {
- margin-top: 16px;
- }
- `;
-__decorate([
- n({ attribute: false })
-], VehicleCardEditor.prototype, "hass", void 0);
-__decorate([
- r$1()
-], VehicleCardEditor.prototype, "_config", void 0);
-__decorate([
- r$1()
-], VehicleCardEditor.prototype, "_helpers", void 0);
-__decorate([
- n({ type: Boolean })
-], VehicleCardEditor.prototype, "isVehicleCardEditor", void 0);
-__decorate([
- n({ type: Boolean })
-], VehicleCardEditor.prototype, "isTripCardEditor", void 0);
-__decorate([
- n({ type: Boolean })
-], VehicleCardEditor.prototype, "isEcoCardEditor", void 0);
-__decorate([
- n({ type: Boolean })
-], VehicleCardEditor.prototype, "isTyreCardEditor", void 0);
-VehicleCardEditor = __decorate([
- t$1('vehicle-info-card-editor')
-], VehicleCardEditor);
-
-var editor = /*#__PURE__*/Object.freeze({
- __proto__: null,
- get VehicleCardEditor () { return VehicleCardEditor; }
-});
-
-export { VehicleCard };
-//# sourceMappingURL=vehicle-info-card-dev.js.map
diff --git a/config/www/dashboard-resources/vehicle-info-card.js b/config/www/dashboard-resources/vehicle-info-card.js
deleted file mode 100755
index 273a4bb..0000000
--- a/config/www/dashboard-resources/vehicle-info-card.js
+++ /dev/null
@@ -1,3489 +0,0 @@
-/*! *****************************************************************************
-Copyright (c) Microsoft Corporation.
-
-Permission to use, copy, modify, and/or distribute this software for any
-purpose with or without fee is hereby granted.
-
-THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH
-REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY
-AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,
-INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM
-LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR
-OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
-PERFORMANCE OF THIS SOFTWARE.
-***************************************************************************** */
-function e(e,t,i,a){var n,r=arguments.length,s=r<3?t:null===a?a=Object.getOwnPropertyDescriptor(t,i):a;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)s=Reflect.decorate(e,t,i,a);else for(var o=e.length-1;o>=0;o--)(n=e[o])&&(s=(r<3?n(s):r>3?n(t,i,s):n(t,i))||s);return r>3&&s&&Object.defineProperty(t,i,s),s
-/**
- * @license
- * Copyright 2019 Google LLC
- * SPDX-License-Identifier: BSD-3-Clause
- */}console.groupCollapsed("%c 🏎️ 💨 VEHICLE-INFO-CARD 🚜 v1.1.1 🛺 💨 \n%c https://github.com/ngocjohn/vehicle-info-card ","color: orange; font-weight: bold; background: transparent","font-weight: bold; background: dimgray"),console.info("Lovelace custom card for displaying vehicle information from Mercedes Component integration"),console.info("Github: https://github.com/ngocjohn/vehicle-info-card"),console.info("If you like the card, consider supporting the developer: https://github.com/sponsors/ngocjohn"),console.groupEnd();const t=globalThis,i=t.ShadowRoot&&(void 0===t.ShadyCSS||t.ShadyCSS.nativeShadow)&&"adoptedStyleSheets"in Document.prototype&&"replace"in CSSStyleSheet.prototype,a=Symbol(),n=new WeakMap;class r{constructor(e,t,i){if(this._$cssResult$=!0,i!==a)throw Error("CSSResult is not constructable. Use `unsafeCSS` or `css` instead.");this.cssText=e,this.t=t}get styleSheet(){let e=this.o;const t=this.t;if(i&&void 0===e){const i=void 0!==t&&1===t.length;i&&(e=n.get(t)),void 0===e&&((this.o=e=new CSSStyleSheet).replaceSync(this.cssText),i&&n.set(t,e))}return e}toString(){return this.cssText}}const s=e=>new r("string"==typeof e?e:e+"",void 0,a),o=(e,...t)=>{const i=1===e.length?e[0]:t.reduce(((t,i,a)=>t+(e=>{if(!0===e._$cssResult$)return e.cssText;if("number"==typeof e)return e;throw Error("Value passed to 'css' function must be a 'css' function result: "+e+". Use 'unsafeCSS' to pass non-literal values, but take care to ensure page security.")})(i)+e[a+1]),e[0]);return new r(i,e,a)},l=(e,a)=>{if(i)e.adoptedStyleSheets=a.map((e=>e instanceof CSSStyleSheet?e:e.styleSheet));else for(const i of a){const a=document.createElement("style"),n=t.litNonce;void 0!==n&&a.setAttribute("nonce",n),a.textContent=i.cssText,e.appendChild(a)}},c=i?e=>e:e=>e instanceof CSSStyleSheet?(e=>{let t="";for(const i of e.cssRules)t+=i.cssText;return s(t)})(e):e
-/**
- * @license
- * Copyright 2017 Google LLC
- * SPDX-License-Identifier: BSD-3-Clause
- */,{is:d,defineProperty:h,getOwnPropertyDescriptor:u,getOwnPropertyNames:p,getOwnPropertySymbols:f,getPrototypeOf:g}=Object,m=globalThis,v=m.trustedTypes,b=v?v.emptyScript:"",x=m.reactiveElementPolyfillSupport,y=(e,t)=>e,w={toAttribute(e,t){switch(t){case Boolean:e=e?b:null;break;case Object:case Array:e=null==e?e:JSON.stringify(e)}return e},fromAttribute(e,t){let i=e;switch(t){case Boolean:i=null!==e;break;case Number:i=null===e?null:Number(e);break;case Object:case Array:try{i=JSON.parse(e)}catch(e){i=null}}return i}},A=(e,t)=>!d(e,t),C={attribute:!0,type:String,converter:w,reflect:!1,hasChanged:A};Symbol.metadata??=Symbol("metadata"),m.litPropertyMetadata??=new WeakMap;class z extends HTMLElement{static addInitializer(e){this._$Ei(),(this.l??=[]).push(e)}static get observedAttributes(){return this.finalize(),this._$Eh&&[...this._$Eh.keys()]}static createProperty(e,t=C){if(t.state&&(t.attribute=!1),this._$Ei(),this.elementProperties.set(e,t),!t.noAccessor){const i=Symbol(),a=this.getPropertyDescriptor(e,i,t);void 0!==a&&h(this.prototype,e,a)}}static getPropertyDescriptor(e,t,i){const{get:a,set:n}=u(this.prototype,e)??{get(){return this[t]},set(e){this[t]=e}};return{get(){return a?.call(this)},set(t){const r=a?.call(this);n.call(this,t),this.requestUpdate(e,r,i)},configurable:!0,enumerable:!0}}static getPropertyOptions(e){return this.elementProperties.get(e)??C}static _$Ei(){if(this.hasOwnProperty(y("elementProperties")))return;const e=g(this);e.finalize(),void 0!==e.l&&(this.l=[...e.l]),this.elementProperties=new Map(e.elementProperties)}static finalize(){if(this.hasOwnProperty(y("finalized")))return;if(this.finalized=!0,this._$Ei(),this.hasOwnProperty(y("properties"))){const e=this.properties,t=[...p(e),...f(e)];for(const i of t)this.createProperty(i,e[i])}const e=this[Symbol.metadata];if(null!==e){const t=litPropertyMetadata.get(e);if(void 0!==t)for(const[e,i]of t)this.elementProperties.set(e,i)}this._$Eh=new Map;for(const[e,t]of this.elementProperties){const i=this._$Eu(e,t);void 0!==i&&this._$Eh.set(i,e)}this.elementStyles=this.finalizeStyles(this.styles)}static finalizeStyles(e){const t=[];if(Array.isArray(e)){const i=new Set(e.flat(1/0).reverse());for(const e of i)t.unshift(c(e))}else void 0!==e&&t.push(c(e));return t}static _$Eu(e,t){const i=t.attribute;return!1===i?void 0:"string"==typeof i?i:"string"==typeof e?e.toLowerCase():void 0}constructor(){super(),this._$Ep=void 0,this.isUpdatePending=!1,this.hasUpdated=!1,this._$Em=null,this._$Ev()}_$Ev(){this._$ES=new Promise((e=>this.enableUpdating=e)),this._$AL=new Map,this._$E_(),this.requestUpdate(),this.constructor.l?.forEach((e=>e(this)))}addController(e){(this._$EO??=new Set).add(e),void 0!==this.renderRoot&&this.isConnected&&e.hostConnected?.()}removeController(e){this._$EO?.delete(e)}_$E_(){const e=new Map,t=this.constructor.elementProperties;for(const i of t.keys())this.hasOwnProperty(i)&&(e.set(i,this[i]),delete this[i]);e.size>0&&(this._$Ep=e)}createRenderRoot(){const e=this.shadowRoot??this.attachShadow(this.constructor.shadowRootOptions);return l(e,this.constructor.elementStyles),e}connectedCallback(){this.renderRoot??=this.createRenderRoot(),this.enableUpdating(!0),this._$EO?.forEach((e=>e.hostConnected?.()))}enableUpdating(e){}disconnectedCallback(){this._$EO?.forEach((e=>e.hostDisconnected?.()))}attributeChangedCallback(e,t,i){this._$AK(e,i)}_$EC(e,t){const i=this.constructor.elementProperties.get(e),a=this.constructor._$Eu(e,i);if(void 0!==a&&!0===i.reflect){const n=(void 0!==i.converter?.toAttribute?i.converter:w).toAttribute(t,i.type);this._$Em=e,null==n?this.removeAttribute(a):this.setAttribute(a,n),this._$Em=null}}_$AK(e,t){const i=this.constructor,a=i._$Eh.get(e);if(void 0!==a&&this._$Em!==a){const e=i.getPropertyOptions(a),n="function"==typeof e.converter?{fromAttribute:e.converter}:void 0!==e.converter?.fromAttribute?e.converter:w;this._$Em=a,this[a]=n.fromAttribute(t,e.type),this._$Em=null}}requestUpdate(e,t,i){if(void 0!==e){if(i??=this.constructor.getPropertyOptions(e),!(i.hasChanged??A)(this[e],t))return;this.P(e,t,i)}!1===this.isUpdatePending&&(this._$ES=this._$ET())}P(e,t,i){this._$AL.has(e)||this._$AL.set(e,t),!0===i.reflect&&this._$Em!==e&&(this._$Ej??=new Set).add(e)}async _$ET(){this.isUpdatePending=!0;try{await this._$ES}catch(e){Promise.reject(e)}const e=this.scheduleUpdate();return null!=e&&await e,!this.isUpdatePending}scheduleUpdate(){return this.performUpdate()}performUpdate(){if(!this.isUpdatePending)return;if(!this.hasUpdated){if(this.renderRoot??=this.createRenderRoot(),this._$Ep){for(const[e,t]of this._$Ep)this[e]=t;this._$Ep=void 0}const e=this.constructor.elementProperties;if(e.size>0)for(const[t,i]of e)!0!==i.wrapped||this._$AL.has(t)||void 0===this[t]||this.P(t,this[t],i)}let e=!1;const t=this._$AL;try{e=this.shouldUpdate(t),e?(this.willUpdate(t),this._$EO?.forEach((e=>e.hostUpdate?.())),this.update(t)):this._$EU()}catch(t){throw e=!1,this._$EU(),t}e&&this._$AE(t)}willUpdate(e){}_$AE(e){this._$EO?.forEach((e=>e.hostUpdated?.())),this.hasUpdated||(this.hasUpdated=!0,this.firstUpdated(e)),this.updated(e)}_$EU(){this._$AL=new Map,this.isUpdatePending=!1}get updateComplete(){return this.getUpdateComplete()}getUpdateComplete(){return this._$ES}shouldUpdate(e){return!0}update(e){this._$Ej&&=this._$Ej.forEach((e=>this._$EC(e,this[e]))),this._$EU()}updated(e){}firstUpdated(e){}}z.elementStyles=[],z.shadowRootOptions={mode:"open"},z[y("elementProperties")]=new Map,z[y("finalized")]=new Map,x?.({ReactiveElement:z}),(m.reactiveElementVersions??=[]).push("2.0.4");
-/**
- * @license
- * Copyright 2017 Google LLC
- * SPDX-License-Identifier: BSD-3-Clause
- */
-const P=globalThis,S=P.trustedTypes,k=S?S.createPolicy("lit-html",{createHTML:e=>e}):void 0,E="$lit$",M=`lit$${Math.random().toFixed(9).slice(2)}$`,O="?"+M,I=`<${O}>`,B=document,V=()=>B.createComment(""),R=e=>null===e||"object"!=typeof e&&"function"!=typeof e,D=Array.isArray,q=e=>D(e)||"function"==typeof e?.[Symbol.iterator],T="[ \t\n\f\r]",N=/<(?:(!--|\/[^a-zA-Z])|(\/?[a-zA-Z][^>\s]*)|(\/?$))/g,X=/-->/g,j=/>/g,F=RegExp(`>|${T}(?:([^\\s"'>=/]+)(${T}*=${T}*(?:[^ \t\n\f\r"'\`<>=]|("|')|))|$)`,"g"),W=/'/g,H=/"/g,Y=/^(?:script|style|textarea|title)$/i,G=e=>(t,...i)=>({_$litType$:e,strings:t,values:i}),Z=G(1),Q=Symbol.for("lit-noChange"),U=Symbol.for("lit-nothing"),K=new WeakMap,J=B.createTreeWalker(B,129);function _(e,t){if(!Array.isArray(e)||!e.hasOwnProperty("raw"))throw Error("invalid template strings array");return void 0!==k?k.createHTML(t):t}const $=(e,t)=>{const i=e.length-1,a=[];let n,r=2===t?"":"",s=N;for(let t=0;t"===l[0]?(s=n??N,c=-1):void 0===l[1]?c=-2:(c=s.lastIndex-l[2].length,o=l[1],s=void 0===l[3]?F:'"'===l[3]?H:W):s===H||s===W?s=F:s===X||s===j?s=N:(s=F,n=void 0);const h=s===F&&e[t+1].startsWith("/>")?" ":"";r+=s===N?i+I:c>=0?(a.push(o),i.slice(0,c)+E+i.slice(c)+M+h):i+M+(-2===c?t:h)}return[_(e,r+(e[i]||">")+(2===t?" ":"")),a]};class ee{constructor({strings:e,_$litType$:t},i){let a;this.parts=[];let n=0,r=0;const s=e.length-1,o=this.parts,[l,c]=$(e,t);if(this.el=ee.createElement(l,i),J.currentNode=this.el.content,2===t){const e=this.el.content.firstChild;e.replaceWith(...e.childNodes)}for(;null!==(a=J.nextNode())&&o.length0){a.textContent=S?S.emptyScript:"";for(let i=0;i2||""!==i[0]||""!==i[1]?(this._$AH=Array(i.length-1).fill(new String),this.strings=i):this._$AH=U}_$AI(e,t=this,i,a){const n=this.strings;let r=!1;if(void 0===n)e=te(this,e,t,0),r=!R(e)||e!==this._$AH&&e!==Q,r&&(this._$AH=e);else{const a=e;let s,o;for(e=n[0],s=0;s{const a=i?.renderBefore??t;let n=a._$litPart$;if(void 0===n){const e=i?.renderBefore??null;a._$litPart$=n=new ae(t.insertBefore(V(),e),e,void 0,i??{})}return n._$AI(e),n
-/**
- * @license
- * Copyright 2017 Google LLC
- * SPDX-License-Identifier: BSD-3-Clause
- */};class ue extends z{constructor(){super(...arguments),this.renderOptions={host:this},this._$Do=void 0}createRenderRoot(){const e=super.createRenderRoot();return this.renderOptions.renderBefore??=e.firstChild,e}update(e){const t=this.render();this.hasUpdated||(this.renderOptions.isConnected=this.isConnected),super.update(e),this._$Do=he(t,this.renderRoot,this.renderOptions)}connectedCallback(){super.connectedCallback(),this._$Do?.setConnected(!0)}disconnectedCallback(){super.disconnectedCallback(),this._$Do?.setConnected(!1)}render(){return Q}}ue._$litElement$=!0,ue.finalized=!0,globalThis.litElementHydrateSupport?.({LitElement:ue});const pe=globalThis.litElementPolyfillSupport;pe?.({LitElement:ue}),(globalThis.litElementVersions??=[]).push("4.0.6");
-/**
- * @license
- * Copyright 2017 Google LLC
- * SPDX-License-Identifier: BSD-3-Clause
- */
-const fe=e=>(t,i)=>{void 0!==i?i.addInitializer((()=>{customElements.define(e,t)})):customElements.define(e,t)}
-/**
- * @license
- * Copyright 2017 Google LLC
- * SPDX-License-Identifier: BSD-3-Clause
- */,ge={attribute:!0,type:String,converter:w,reflect:!1,hasChanged:A},me=(e=ge,t,i)=>{const{kind:a,metadata:n}=i;let r=globalThis.litPropertyMetadata.get(n);if(void 0===r&&globalThis.litPropertyMetadata.set(n,r=new Map),r.set(i.name,e),"accessor"===a){const{name:a}=i;return{set(i){const n=t.get.call(this);t.set.call(this,i),this.requestUpdate(a,n,e)},init(t){return void 0!==t&&this.P(a,void 0,e),t}}}if("setter"===a){const{name:a}=i;return function(i){const n=this[a];t.call(this,i),this.requestUpdate(a,n,e)}}throw Error("Unsupported decorator location: "+a)};function ve(e){return(t,i)=>"object"==typeof i?me(e,t,i):((e,t,i)=>{const a=t.hasOwnProperty(i);return t.constructor.createProperty(i,a?{...e,wrapped:!0}:e),a?Object.getOwnPropertyDescriptor(t,i):void 0})(e,t,i)
-/**
- * @license
- * Copyright 2017 Google LLC
- * SPDX-License-Identifier: BSD-3-Clause
- */}function be(e){return ve({...e,state:!0,attribute:!1})}
-/**
- * @license
- * Copyright 2017 Google LLC
- * SPDX-License-Identifier: BSD-3-Clause
- */const xe={ATTRIBUTE:1,CHILD:2,PROPERTY:3,BOOLEAN_ATTRIBUTE:4,EVENT:5,ELEMENT:6},ye=e=>(...t)=>({_$litDirective$:e,values:t});class we{constructor(e){}get _$AU(){return this._$AM._$AU}_$AT(e,t,i){this._$Ct=e,this._$AM=t,this._$Ci=i}_$AS(e,t){return this.update(e,t)}update(e,t){return this.render(...t)}}
-/**
- * @license
- * Copyright 2018 Google LLC
- * SPDX-License-Identifier: BSD-3-Clause
- */const Ae=ye(class extends we{constructor(e){if(super(e),e.type!==xe.ATTRIBUTE||"class"!==e.name||e.strings?.length>2)throw Error("`classMap()` can only be used in the `class` attribute and must be the only part in the attribute.")}render(e){return" "+Object.keys(e).filter((t=>e[t])).join(" ")+" "}update(e,[t]){if(void 0===this.st){this.st=new Set,void 0!==e.strings&&(this.nt=new Set(e.strings.join(" ").split(/\s/).filter((e=>""!==e))));for(const e in t)t[e]&&!this.nt?.has(e)&&this.st.add(e);return this.render(t)}const i=e.element.classList;for(const e of this.st)e in t||(i.remove(e),this.st.delete(e));for(const e in t){const a=!!t[e];a===this.st.has(e)||this.nt?.has(e)||(a?(i.add(e),this.st.add(e)):(i.remove(e),this.st.delete(e)))}return Q}});var Ce,ze;!function(e){e.language="language",e.system="system",e.comma_decimal="comma_decimal",e.decimal_comma="decimal_comma",e.space_comma="space_comma",e.none="none"}(Ce||(Ce={})),function(e){e.language="language",e.system="system",e.am_pm="12",e.twenty_four="24"}(ze||(ze={}));var Pe=function(e){if(e.time_format===ze.language||e.time_format===ze.system){var t=e.time_format===ze.language?e.language:void 0,i=(new Date).toLocaleString(t);return i.includes("AM")||i.includes("PM")}return e.time_format===ze.am_pm},Se=function(e,t){return ke(t).format(e)},ke=function(e){return new Intl.DateTimeFormat(e.language,{year:"numeric",month:"long",day:"numeric",hour:Pe(e)?"numeric":"2-digit",minute:"2-digit",hour12:Pe(e)})};function Ee(){return(Ee=Object.assign||function(e){for(var t=1;t-1?e.split(".")[1].length:0;i.minimumFractionDigits=a,i.maximumFractionDigits=a}return i},Ve=function(e,t,i,a){a=a||{},i=null==i?{}:i;var n=new Event(t,{bubbles:void 0===a.bubbles||a.bubbles,cancelable:Boolean(a.cancelable),composed:void 0===a.composed||a.composed});return n.detail=i,e.dispatchEvent(n),n},Re=function(e){Ve(window,"haptic",e)};function De(e,t,i){if(t.has("config")||i)return!0;if(e.config.entity){var a=t.get("hass");return!a||a.states[e.config.entity]!==e.hass.states[e.config.entity]}return!1}const qe={type:"custom:vehicle-info-card",name:"Mercedes Vehicle Card",entity:"",model_name:"",show_slides:!1,show_map:!1,show_buttons:!0,show_background:!0,enable_map_popup:!1,enable_services_control:!1,show_error_notify:!1,services:{auxheat:!1,charge:!1,doorsLock:!1,engine:!1,preheat:!1,sendRoute:!1,sigPos:!1,sunroof:!1,windows:!1}};var Te="Czech",Ne="Čeština",Xe={common:{lastUpdate:"Aktualizováno",stateCharging:"Nabíjení",stateClosed:"Zavřené",stateLocked:"Zamknuté",stateLockedInt:"Interně zamčeno",stateNotExisting:"Neexistující",stateOpen:"Otevřené",stateParkBrakeOff:"Uvolněno",stateParkBrakeOn:"Přitaženo",statePartlyUnlocked:"Částečně odemčeno",stateUnknown:"Neznámý",stateUnlocked:"Odemknuté",titleRemoteControl:"Vzdálené ovládání",titleServices:"Služby",toastCommandSent:"Příkaz odeslán úspěšně!",toastImageError:"Chyba při nahrávání obrázku. Jsou povoleny pouze soubory PNG a JPEG."},cardType:{ecoCards:"Ukazatel ECO",tripCards:"Údaje o jízdě",tyreCards:"Tlak pneumatik",vehicleCards:"Stav vozidla"},chargingOverview:{chargingPower:"Výkon",maxSoc:"Maximum",selectedProgram:"Program",soc:"Stav nabití"},doorAttributes:{decklidstatus:"Zavazadlový prostor",doorstatusfrontleft:"Přední levé dveře",doorstatusfrontright:"Přední pravé dveře",doorstatusrearleft:"Zadní levé dveře",doorstatusrearright:"Zadní pravé dveře",enginehoodstatus:"Kapota",sunroofstatus:"Střešní okno"},ecoCard:{ecoDisplay:"Ukazatel ECO",ecoScore:"Skóre",ecoScoreAcceleraion:"Zrychlení",ecoScoreBonusRange:"Bonusový dojezd",ecoScoreConstant:"Konstanta",ecoScoreFreeWheel:"Volnoběh"},lockAttributes:{doorlockstatusfrontleft:"Přední levé dveře",doorlockstatusfrontright:"Přední pravé dveře",doorlockstatusgas:"Zámek nádrže",doorlockstatusrearleft:"Zadní levé dveře",doorlockstatusrearright:"Zadní pravé dveře"},serviceData:{labelChargeProgram:"Program nabíjení",labelCity:"Město",labelClose:"Zavřít",labelDepartureTime:"Čas odjezdu",labelDurationTime:"Doba trvání",labelLatitude:"Zeměpisná šířka",labelLockCar:"Zamknout auto",labelLongitude:"Zeměpisná délka",labelMaxStateOfCharge:"Maximální stav nabití",labelMoreInfo:"Více",labelMove:"Přesunout",labelNoSelection:"Žádný výběr",labelOpen:"Otevřít",labelPostCode:"PSČ",labelSave:"Uložit",labelSend:"Odeslat",labelSetMaxSoc:"Nastavit maximum",labelSetProgram:"Nastavit program",labelStart:"Start",labelStartTime:"Čas začátku",labelStop:"Stop",labelStopTime:"Čas konce",labelStreet:"Ulice",labelTilt:"Náklon",labelTime1:"Čas 1",labelTime2:"Čas 2",labelTime3:"Čas 3",labelTimeSelection:"Výběr času",labelTitle:"Název",labelUnlockCar:"Odemknout auto",labelWindowFrontLeft:"Přední vlevo",labelWindowFrontRight:"Přední vpravo",labelWindowRearLeft:"Zadní vlevo",labelWindowRearRight:"Zadní vpravo"},servicesCtrl:{auxheat:"Pomocné vytápění",charge:"Nabíjení",doorsLock:"Zabezpečení",engine:"Ovládání motoru",preheat:"Předkondicionování",sendRoute:"Odeslat trasu",sigPos:"Signální pozice",sunroof:"Střešní okno",windows:"Okna"},starterBattery:{notAvailable:"Není k dispozici",partlyCharged:"Částečně nabitá",remoteServiceDisabled:"Vzdálená služba zakázána",stateOk:"Ok",vehicleNoLongerAvailable:"Vozidlo již není k dispozici"},sunroofState:{antiBoomingLifting:"Proti hučení zvedání",antiBoomingPosition:"Pozice proti hučení",closing:"Zavírání",closingLifting:"Zavírání zvedání",intermediatePosition:"Mezilehlá pozice",liftingIntermediate:"Mezilehlé zvedání",liftingOpen:"Zvedání otevřeno",opening:"Otevírání",openingLifting:"Otevírání zvedání",running:"V provozu",slidingIntermediate:"Mezilehlé posunutí",stateClosed:"Zamknuté",stateOpen:"Otevřené"},tripCard:{adBlueLevel:"Hladina AdBlue",averageSpeedReset:"Průměrná rychlost",averageSpeedStart:"Průměrná rychlost",distanceReset:"Ujetá vzdálenost",distanceStart:"Ujetá vzdálenost",drivenTimeReset:"Doba jízdy",drivenTimeStart:"Doba jízdy",electricConsumptionReset:"Průměrná spotřeba",electricConsumptionStart:"Průměrná spotřeba",fromReset:"Od resetu",fromStart:"Od startu",fuelLevel:"Hladina paliva",liquidConsumptionReset:"Průměrná spotřeba",liquidConsumptionStart:"Průměrná spotřeba",maxSoc:"Maximální stav nabití",odometer:"Tachometr",overview:"Přehled",rangeElectric:"Dojezd",rangeLiquid:"Dojezd",soc:"Stav nabití"},tyreCard:{tirePressureFrontLeft:"Přední levá",tirePressureFrontRight:"Přední pravá",tirePressureRearLeft:"Zadní levá",tirePressureRearRight:"Zadní pravá",tireWarningOk:"Nepoznána žádná ztráta tlaku",tireWarningProblem:"Zjištěna ztráta tlaku. Zkontrolujte pneumatiky.",tyrePressure:"Tlak vzduchu v pneumatikách"},vehicleCard:{doorStatusOverall:"Dveře",engineLight:"Kontrolka motoru",ignitionState:"Stav zapalování",lockSensor:"Stav zamknutí",lowBrakeFluid:"Brzdová kapalina",lowCoolantLevel:"Chladicí kapalina",lowWashWater:"Kapalina ostřikovače",parkBrake:"Ruční brzda",starterBatteryState:"Akumulátor",tirePressureWarning:"Stav tlaku v pneumatikách",vehicleStatus:"Stav vozidla",vehicleWarnings:"Varování",windowsClosed:"Okna"},windowAttributes:{windowstatusfrontleft:"Okno přední levé",windowstatusfrontleftblind:"Okno přední levé roleta",windowstatusfrontright:"Okno přední pravé",windowstatusfrontrightblind:"Okno přední pravé roleta",windowstatusrearleft:"Okno zadní levé",windowstatusrearleftblind:"Okno zadní levé roleta",windowstatusrearright:"Okno zadní pravé",windowstatusrearrightblind:"Okno zadní pravé roleta"}},je={buttonConfig:{desc:"Nakonfigurujte podkarty pro jednotlivá tlačítka.",title:"Konfigurace tlačítek"},common:{checkAll:"Vyrat vše",infoButton:"Vyberte kartu, kterou chcete nakonfigurovat.",infoImages:"Není potřeba přidávat '-' pro každý řádek. Každý řádek bude automaticky považován za samostatnou URL adresu.",infoMap:"Toto je konfigurace pro mapové vyskakovací okno.",infoServices:"Vyberte, které služby chcete povolit. Pokud je služba deaktivována, nebude v kartě zobrazena.",uncheckAll:"Zrušit vše"},imagesConfig:{desc:"Přidejte URL adresy obrázků.",title:"Konfigurace obrázků"},mapConfig:{desc:"Vyberte konfiguraci pro mapu",title:"Konfigurace mapy"},servicesConfig:{desc:"Vyberte služby, které chcete povolit.",title:"Konfigurace služeb"},showConfig:{desc:"Vyberte položky, které chcete zobrazit.",title:"Konfigurace zobrazení"},showOpts:{enable_map_popup:"Povolit vyskakovací okno mapy",enable_services_control:"Povolit ovládání služeb",show_background:"Zobrazit pozadí",show_buttons:"Zobrazit tlačítka",show_error_notify:"Zobrazit oznámení o chybě",show_map:"Zobrazit mapu",show_slides:"Zobrazit snímky"},themeLangConfig:{desc:"Vyberte téma a jazyk.",title:"Témata a jazyk"}},Fe={name:Te,nativeName:Ne,card:Xe,editor:je},We=Object.freeze({__proto__:null,name:Te,nativeName:Ne,card:Xe,editor:je,default:Fe}),He="German",Ye="Deutsch",Ge={common:{lastUpdate:"Letztes Update",stateCharging:"Laden",stateClosed:"Geschlossen",stateLocked:"Verriegelt",stateLockedInt:"Intern verriegelt",stateNotExisting:"Nicht vorhanden",stateOpen:"Offen",stateParkBrakeOff:"Gelöst",stateParkBrakeOn:"Angezogen",statePartlyUnlocked:"Teilweise entriegelt",stateUnknown:"Unbekannt",stateUnlocked:"Entriegelt",titleRemoteControl:"Fernbedienung",titleServices:"Dienste",toastCommandSent:"Befehl gesendet!",toastImageError:"Fehler beim Hochladen des Bildes. Es sind nur PNG- und JPEG-Dateien erlaubt."},cardType:{ecoCards:"Ökoanzeige",tripCards:"Reisedaten",tyreCards:"Reifendruck",vehicleCards:"Fahrzeugstatus"},chargingOverview:{chargingPower:"Leistung",maxSoc:"Maximal",selectedProgram:"Programm",soc:"Aktueller Zustand"},doorAttributes:{decklidstatus:"Heckklappe",doorstatusfrontleft:"Tür vorne links",doorstatusfrontright:"Tür vorne rechts",doorstatusrearleft:"Tür hinten links",doorstatusrearright:"Tür hinten rechts",enginehoodstatus:"Motorhaube",sunroofstatus:"Schiebedach"},ecoCard:{ecoDisplay:"Ökoanzeige",ecoScore:"Punkte",ecoScoreAcceleraion:"Beschleunigung",ecoScoreBonusRange:"Bonusreichweite",ecoScoreConstant:"Konstant",ecoScoreFreeWheel:"Freilauf"},lockAttributes:{doorlockstatusfrontleft:"Türverriegelung vorne links",doorlockstatusfrontright:"Türverriegelung vorne rechts",doorlockstatusgas:"Tankverriegelung",doorlockstatusrearleft:"Türverriegelung hinten links",doorlockstatusrearright:"Türverriegelung hinten rechts"},serviceData:{labelChargeProgram:"Ladeprogramm",labelCity:"Stadt",labelClose:"Schließen",labelDepartureTime:"Abfahrtszeit",labelDurationTime:"Dauerzeit",labelLatitude:"Breitengrad",labelLockCar:"Auto verriegeln",labelLongitude:"Längengrad",labelMaxStateOfCharge:"Maximaler Ladezustand",labelMoreInfo:"Mehr Infos",labelMove:"Bewegen",labelNoSelection:"Keine Auswahl",labelOpen:"Öffnen",labelPostCode:"Postleitzahl",labelSave:"Speichern",labelSend:"Senden",labelSetMaxSoc:"Maximum setzen",labelSetProgram:"Programm setzen",labelStart:"Start",labelStartTime:"Startzeit",labelStop:"Stopp",labelStopTime:"Stoppzeit",labelStreet:"Straße",labelTilt:"Kippen",labelTime1:"Zeit 1",labelTime2:"Zeit 2",labelTime3:"Zeit 3",labelTimeSelection:"Zeitauswahl",labelTitle:"Titel",labelUnlockCar:"Auto entriegeln",labelWindowFrontLeft:"Vorne links",labelWindowFrontRight:"Vorne rechts",labelWindowRearLeft:"Hinten links",labelWindowRearRight:"Hinten rechts"},servicesCtrl:{auxheat:"Zusatzheizung",charge:"Laden",doorsLock:"Sicherheit",engine:"Motorsteuerung",preheat:"Vorkonditionierung",sendRoute:"Route senden",sigPos:"Position signalisieren",sunroof:"Schiebedach",windows:"Fenster"},starterBattery:{notAvailable:"Nicht verfügbar",partlyCharged:"Teilweise geladen",remoteServiceDisabled:"Fernservice deaktiviert",stateOk:"Okay",vehicleNoLongerAvailable:"Fahrzeug nicht mehr verfügbar"},sunroofState:{antiBoomingLifting:"Anti-Boom-Heben",antiBoomingPosition:"Anti-Boom-Position",closing:"Schließen",closingLifting:"Schließen Heben",intermediatePosition:"Zwischenposition",liftingIntermediate:"Zwischenposition anheben",liftingOpen:"Angehoben offen",opening:"Öffnen",openingLifting:"Öffnen Heben",running:"Laufen",slidingIntermediate:"Zwischenposition schieben",stateClosed:"Geschlossen",stateOpen:"Offen"},tripCard:{adBlueLevel:"AdBlue-Stand",averageSpeedReset:"Durchschnittsgeschwindigkeit",averageSpeedStart:"Durchschnittsgeschwindigkeit",distanceReset:"Zurückgelegte Strecke",distanceStart:"Zurückgelegte Strecke",drivenTimeReset:"Fahrzeit",drivenTimeStart:"Fahrzeit",electricConsumptionReset:"Durchschnittsverbrauch",electricConsumptionStart:"Durchschnittsverbrauch",fromReset:"Von Reset",fromStart:"Von Anfang",fuelLevel:"Kraftstoffstand",liquidConsumptionReset:"Durchschnittsverbrauch",liquidConsumptionStart:"Durchschnittsverbrauch",maxSoc:"Maximaler Ladezustand",odometer:"Kilometerzähler",overview:"Übersicht",rangeElectric:"Reichweite",rangeLiquid:"Reichweite",soc:"Ladezustand"},tyreCard:{tirePressureFrontLeft:"Vorne links",tirePressureFrontRight:"Vorne rechts",tirePressureRearLeft:"Hinten links",tirePressureRearRight:"Hinten rechts",tireWarningOk:"Kein Druckverlust festgestellt",tireWarningProblem:"Druckverlust festgestellt. Reifen überprüfen.",tyrePressure:"Reifendruck"},vehicleCard:{doorStatusOverall:"Türen",engineLight:"Motorleuchte",ignitionState:"Zündstatus",lockSensor:"Verriegelungsstatus",lowBrakeFluid:"Bremsflüssigkeit",lowCoolantLevel:"Kühlmittel",lowWashWater:"Waschwasser",parkBrake:"Feststellbremse",starterBatteryState:"Starterbatterie",tirePressureWarning:"Reifendruck",vehicleStatus:"Fahrzeugstatus",vehicleWarnings:"Warnungen",windowsClosed:"Fenster"},windowAttributes:{windowstatusfrontleft:"Fenster vorne links",windowstatusfrontleftblind:"Fenster vorne links blind",windowstatusfrontright:"Fenster vorne rechts",windowstatusfrontrightblind:"Fenster vorne rechts blind",windowstatusrearleft:"Fenster hinten links",windowstatusrearleftblind:"Fenster hinten links blind",windowstatusrearright:"Fenster hinten rechts",windowstatusrearrightblind:"Fenster hinten rechts blind"}},Ze={buttonConfig:{desc:"Konfigurieren Sie die Unterkarten für einzelne Schaltflächen.",title:"Schaltflächenkonfiguration"},common:{checkAll:"Alles auswählen",infoButton:"Wählen Sie die Karte aus, die Sie konfigurieren möchten.",infoImages:"Es ist nicht erforderlich, für jede Zeile ein '-' hinzuzufügen. Jede Zeile wird automatisch als separate URL behandelt.",infoMap:"Dies ist die Konfiguration für das Karten-Popup.",infoServices:"Wählen Sie die Dienste aus, die Sie aktivieren möchten. Wenn ein Dienst deaktiviert ist, wird er nicht auf der Karte angezeigt.",uncheckAll:"Alles abwählen"},imagesConfig:{desc:"Fügen Sie die URLs der Bilder hinzu.",title:"Bildkonfiguration"},mapConfig:{desc:"Wählen Sie die Konfiguration für die Karte",title:"Karteneinstellungen"},servicesConfig:{desc:"Wählen Sie die Dienste aus, die Sie aktivieren möchten.",title:"Dienstkonfiguration"},showConfig:{desc:"Wählen Sie die Elemente aus, die Sie anzeigen möchten.",title:"Anzeigeeinstellungen"},showOpts:{enable_map_popup:"Karten-Popup aktivieren",enable_services_control:"Dienststeuerung aktivieren",show_background:"Hintergrund anzeigen",show_buttons:"Schaltflächen anzeigen",show_error_notify:"Fehlermeldung anzeigen",show_map:"Karte anzeigen",show_slides:"Dias anzeigen"},themeLangConfig:{desc:"Wählen Sie das Thema und die Sprache.",title:"Themen & Sprache"}},Qe={name:He,nativeName:Ye,card:Ge,editor:Ze},Ue=Object.freeze({__proto__:null,name:He,nativeName:Ye,card:Ge,editor:Ze,default:Qe}),Ke="English",Je="English",_e={common:{lastUpdate:"Last update",stateCharging:"Charging",stateClosed:"Closed",stateLocked:"Locked",stateLockedInt:"Locked int",stateNotExisting:"Not existing",stateOpen:"Open",stateParkBrakeOff:"Released",stateParkBrakeOn:"Engaged",statePartlyUnlocked:"Partly unlocked",stateUnknown:"Unknown",stateUnlocked:"Unlocked",titleRemoteControl:"Remote control",titleServices:"Services",toastCommandSent:"Command sent sucess!",toastImageError:"Error uploading image. Only PNG and JPEG files are allowed."},cardType:{ecoCards:"Eco display",tripCards:"Trip data",tyreCards:"Tyre pressure",vehicleCards:"Vehicle status"},chargingOverview:{chargingPower:"Power",maxSoc:"Maximum",selectedProgram:"Program",soc:"Current state"},doorAttributes:{decklidstatus:"Luggage compartment",doorstatusfrontleft:"Door front left",doorstatusfrontright:"Door front right",doorstatusrearleft:"Door rear left",doorstatusrearright:"Door rear right",enginehoodstatus:"Engine hood",sunroofstatus:"Sunroof"},ecoCard:{ecoDisplay:"Eco display",ecoScore:"Scores",ecoScoreAcceleraion:"Acceleraion",ecoScoreBonusRange:"Bonus range",ecoScoreConstant:"Constant",ecoScoreFreeWheel:"Free wheel"},lockAttributes:{doorlockstatusfrontleft:"Door lock front left",doorlockstatusfrontright:"Door lock front right",doorlockstatusgas:"Gas cap lock",doorlockstatusrearleft:"Door lock rear left",doorlockstatusrearright:"Door lock rear right"},serviceData:{labelChargeProgram:"Charge program",labelCity:"City",labelClose:"Close",labelDepartureTime:"Departure time",labelDurationTime:"Duration time",labelLatitude:"Latitude",labelLockCar:"Lock car",labelLongitude:"Longitude",labelMaxStateOfCharge:"Max state of charge",labelMoreInfo:"More info",labelMove:"Move",labelNoSelection:"No selection",labelOpen:"Open",labelPostCode:"Post code",labelSave:"Save",labelSend:"Send",labelSetMaxSoc:"Set maximum",labelSetProgram:"Set program",labelStart:"Start",labelStartTime:"Start time",labelStop:"Stop",labelStopTime:"Stop time",labelStreet:"Street",labelTilt:"Tilt",labelTime1:"Time 1",labelTime2:"Time 2",labelTime3:"Time 3",labelTimeSelection:"Time selection",labelTitle:"Title",labelUnlockCar:"Unlock car",labelWindowFrontLeft:"Front left",labelWindowFrontRight:"Front right",labelWindowRearLeft:"Rear left",labelWindowRearRight:"Rear right"},servicesCtrl:{auxheat:"Auxiliary heating",charge:"Charge",doorsLock:"Security",engine:"Engine control",preheat:"Pre-conditioning",sendRoute:"Send route",sigPos:"Signal position",sunroof:"Sunroof",windows:"Windows"},starterBattery:{notAvailable:"Not available",partlyCharged:"Partly charged",remoteServiceDisabled:"Remote service disabled",stateOk:"Ok",vehicleNoLongerAvailable:"Vehicle no longer available"},sunroofState:{antiBoomingLifting:"Anti-booming lifting",antiBoomingPosition:"Anti-booming position",closing:"Closing",closingLifting:"Closing lifting",intermediatePosition:"Intermediate position",liftingIntermediate:"Lifting intermediate",liftingOpen:"Lifting open",opening:"Opening",openingLifting:"Opening lifting",running:"Running",slidingIntermediate:"Sliding intermediate",stateClosed:"Closed",stateOpen:"Open"},tripCard:{adBlueLevel:"AdBlue level",averageSpeedReset:"Average speed",averageSpeedStart:"Average speed",distanceReset:"Distance traveled",distanceStart:"Distance traveled",drivenTimeReset:"Driving time",drivenTimeStart:"Driving time",electricConsumptionReset:"Average consumption",electricConsumptionStart:"Average consumption",fromReset:"From reset",fromStart:"From start",fuelLevel:"Fuel level",liquidConsumptionReset:"Average consumption",liquidConsumptionStart:"Average consumption",maxSoc:"Max state of charge",odometer:"Odometer",overview:"Overview",rangeElectric:"Range",rangeLiquid:"Range",soc:"State of charge"},tyreCard:{tirePressureFrontLeft:"Front left",tirePressureFrontRight:"Front right",tirePressureRearLeft:"Rear left",tirePressureRearRight:"Rear right",tireWarningOk:"No pressure loss detected",tireWarningProblem:"Pressure loss detected. Check tyres.",tyrePressure:"Tyre pressures"},vehicleCard:{doorStatusOverall:"Doors",engineLight:"Engine light",ignitionState:"Ignition state",lockSensor:"Lock status",lowBrakeFluid:"Brake fluid",lowCoolantLevel:"Coolant",lowWashWater:"Washer fluid",parkBrake:"Parking brake",starterBatteryState:"Starter battery",tirePressureWarning:"Tire pressure",vehicleStatus:"Vehicle status",vehicleWarnings:"Warnings",windowsClosed:"Windows"},windowAttributes:{windowstatusfrontleft:"Window front left",windowstatusfrontleftblind:"Window front left blind",windowstatusfrontright:"Window front right",windowstatusfrontrightblind:"Window front right blind",windowstatusrearleft:"Window rear left",windowstatusrearleftblind:"Window rear left blind",windowstatusrearright:"Window rear right",windowstatusrearrightblind:"Window rear right blind"}},$e={buttonConfig:{desc:"Configure the subcards for individual buttons.",title:"Buttons configuration"},common:{checkAll:"Check all",infoButton:"Select the card you want to configure.",infoImages:"There is no need to add a '-' for each line. Each line will be treated as a separate URL automatically.",infoMap:"This is configuration for map popup.",infoServices:"Choose which services you want to enable. If a service is disabled, it will not be shown in the card.",uncheckAll:"Uncheck all"},imagesConfig:{desc:"Add the URLs of the images.",title:"Image configuration"},mapConfig:{desc:"Choose the configuration for the map",title:"Map configuration"},servicesConfig:{desc:"Choose the services you want to enable.",title:"Services configuration"},showConfig:{desc:"Choose the items you want to display.",title:"Show configuration"},showOpts:{enable_map_popup:"Enable map popup",enable_services_control:"Enable services control",show_background:"Show background",show_buttons:"Show buttons",show_error_notify:"Show error notification",show_map:"Show map",show_slides:"Show slides"},themeLangConfig:{desc:"Choose the theme and language.",title:"Themes & Language"}},et={name:Ke,nativeName:Je,card:_e,editor:$e},tt=Object.freeze({__proto__:null,name:Ke,nativeName:Je,card:_e,editor:$e,default:et}),it="English (GB)",at="English (GB)",nt={common:{lastUpdate:"Last update",stateCharging:"Charging",stateClosed:"Closed",stateLocked:"Locked",stateLockedInt:"Locked int",stateNotExisting:"Not existing",stateOpen:"Open",stateParkBrakeOff:"Released",stateParkBrakeOn:"Engaged",statePartlyUnlocked:"Partly unlocked",stateUnknown:"Unknown",stateUnlocked:"Unlocked",titleRemoteControl:"Remote control",titleServices:"Services",toastCommandSent:"Command sent sucess!",toastImageError:"Error uploading image. Only PNG and JPEG files are allowed."},cardType:{ecoCards:"Eco display",tripCards:"Trip data",tyreCards:"Tyre pressure",vehicleCards:"Vehicle status"},chargingOverview:{chargingPower:"Power",maxSoc:"Maximum",selectedProgram:"Programme",soc:"Current state"},doorAttributes:{decklidstatus:"Boot lid/Tailgate",doorstatusfrontleft:"Door front left",doorstatusfrontright:"Door front right",doorstatusrearleft:"Door rear left",doorstatusrearright:"Door rear right",enginehoodstatus:"Bonnet",sunroofstatus:"Sunroof"},ecoCard:{ecoDisplay:"Eco display",ecoScore:"Scores",ecoScoreAcceleraion:"Acceleraion",ecoScoreBonusRange:"Bonus range",ecoScoreConstant:"Constant",ecoScoreFreeWheel:"Free wheel"},lockAttributes:{doorlockstatusfrontleft:"Door lock front left",doorlockstatusfrontright:"Door lock front right",doorlockstatusgas:"Fuel flap lock",doorlockstatusrearleft:"Door lock rear left",doorlockstatusrearright:"Door lock rear right"},serviceData:{labelChargeProgram:"Charge programme",labelCity:"City",labelClose:"Close",labelDepartureTime:"Departure time",labelDurationTime:"Duration time",labelLatitude:"Latitude",labelLockCar:"Lock car",labelLongitude:"Longitude",labelMaxStateOfCharge:"Max state of charge",labelMoreInfo:"More info",labelMove:"Move",labelNoSelection:"No selection",labelOpen:"Open",labelPostCode:"Post code",labelSave:"Save",labelSend:"Send",labelSetMaxSoc:"Set maximum",labelSetProgram:"Set program",labelStart:"Start",labelStartTime:"Start time",labelStop:"Stop",labelStopTime:"Stop time",labelStreet:"Street",labelTilt:"Tilt",labelTime1:"Time 1",labelTime2:"Time 2",labelTime3:"Time 3",labelTimeSelection:"Time selection",labelTitle:"Title",labelUnlockCar:"Unlock car",labelWindowFrontLeft:"Front left",labelWindowFrontRight:"Front right",labelWindowRearLeft:"Rear left",labelWindowRearRight:"Rear right"},servicesCtrl:{auxheat:"Auxiliary heating",charge:"Charge",doorsLock:"Security",engine:"Engine control",preheat:"Pre-conditioning",sendRoute:"Send route",sigPos:"Signal position",sunroof:"Sunroof",windows:"Windows"},starterBattery:{notAvailable:"Not available",partlyCharged:"Partly charged",remoteServiceDisabled:"Remote service disabled",stateOk:"Ok",vehicleNoLongerAvailable:"Vehicle no longer available"},sunroofState:{antiBoomingLifting:"Anti-booming lifting",antiBoomingPosition:"Anti-booming position",closing:"Closing",closingLifting:"Closing lifting",intermediatePosition:"Intermediate position",liftingIntermediate:"Lifting intermediate",liftingOpen:"Lifting open",opening:"Opening",openingLifting:"Opening lifting",running:"Running",slidingIntermediate:"Sliding intermediate",stateClosed:"Closed",stateOpen:"Open"},tripCard:{adBlueLevel:"AdBlue level",averageSpeedReset:"Average speed",averageSpeedStart:"Average speed",distanceReset:"Distance travelled",distanceStart:"Distance travelled",drivenTimeReset:"Driving time",drivenTimeStart:"Driving time",electricConsumptionReset:"Average consumption",electricConsumptionStart:"Average consumption",fromReset:"From reset",fromStart:"From start",fuelLevel:"Fuel level",liquidConsumptionReset:"Average consumption",liquidConsumptionStart:"Average consumption",maxSoc:"Max state of charge",odometer:"Odometer",overview:"Overview",rangeElectric:"Range",rangeLiquid:"Range",soc:"State of charge"},tyreCard:{tirePressureFrontLeft:"Front left",tirePressureFrontRight:"Front right",tirePressureRearLeft:"Rear left",tirePressureRearRight:"Rear right",tireWarningOk:"No pressure loss detected",tireWarningProblem:"Pressure loss detected. Check tyres.",tyrePressure:"Tyre pressures"},vehicleCard:{doorStatusOverall:"Doors",engineLight:"Engine light",ignitionState:"Ignition state",lockSensor:"Lock status",lowBrakeFluid:"Brake fluid",lowCoolantLevel:"Coolant",lowWashWater:"Washer fluid",parkBrake:"Parking brake",starterBatteryState:"12v battery",tirePressureWarning:"Tyre pressure",vehicleStatus:"Vehicle status",vehicleWarnings:"Warnings",windowsClosed:"Windows"},windowAttributes:{windowstatusfrontleft:"Window front left",windowstatusfrontleftblind:"Window front left blind",windowstatusfrontright:"Window front right",windowstatusfrontrightblind:"Window front right blind",windowstatusrearleft:"Window rear left",windowstatusrearleftblind:"Window rear left blind",windowstatusrearright:"Window rear right",windowstatusrearrightblind:"Window rear right blind"}},rt={buttonConfig:{desc:"Configure the subcards for individual buttons.",title:"Buttons configuration"},common:{checkAll:"Check all",infoButton:"Select the card you want to configure.",infoImages:"There is no need to add a '-' for each line. Each line will be treated as a separate URL automatically.",infoMap:"This is configuration for map popup.",infoServices:"Choose which services you want to enable. If a service is disabled, it will not be shown in the card.",uncheckAll:"Uncheck all"},imagesConfig:{desc:"Add the URLs of the images.",title:"Image configuration"},mapConfig:{desc:"Choose the configuration for the map",title:"Map configuration"},servicesConfig:{desc:"Choose the services you want to enable.",title:"Services configuration"},showConfig:{desc:"Choose the items you want to display.",title:"Show configuration"},showOpts:{enable_map_popup:"Enable map popup",enable_services_control:"Enable services control",show_background:"Show background",show_buttons:"Show buttons",show_error_notify:"Show error notification",show_map:"Show map",show_slides:"Show slides"},themeLangConfig:{desc:"Choose the theme and language.",title:"Themes & Language"}},st={name:it,nativeName:at,card:nt,editor:rt},ot=Object.freeze({__proto__:null,name:it,nativeName:at,card:nt,editor:rt,default:st}),lt="French",ct="Français",dt={common:{lastUpdate:"Dernière mise à jour",stateCharging:"En charge",stateClosed:"Fermé",stateLocked:"Verrouillé",stateLockedInt:"Verrouillage int.",stateNotExisting:"Inexistant",stateOpen:"Ouvert",stateParkBrakeOff:"Désactivé",stateParkBrakeOn:"Activé",statePartlyUnlocked:"Partiellement déverrouillé",stateUnknown:"Inconnu",stateUnlocked:"Déverrouillé",titleRemoteControl:"Télécommande",titleServices:"Services",toastCommandSent:"Commande envoyée avec succès !",toastImageError:"Erreur lors du téléchargement de l'image. Seuls les fichiers PNG et JPEG sont autorisés."},cardType:{ecoCards:"Affichage éco",tripCards:"Trajet",tyreCards:"Pression pneus",vehicleCards:"État véhicule"},chargingOverview:{chargingPower:"En charge",maxSoc:"État Maximal",selectedProgram:"Programme",soc:"État actuel"},doorAttributes:{decklidstatus:"Coffre arrière",doorstatusfrontleft:"Porte avant gauche",doorstatusfrontright:"Porte avant droite",doorstatusrearleft:"Porte arrière gauche",doorstatusrearright:"Porte arrière droite",enginehoodstatus:"Capot moteur",sunroofstatus:"Toit ouvrant"},ecoCard:{ecoDisplay:"Affichage éco",ecoScore:"Scores",ecoScoreAcceleraion:"Accélération",ecoScoreBonusRange:"Autonomie bonus",ecoScoreConstant:"Constante",ecoScoreFreeWheel:"Roue libre"},lockAttributes:{doorlockstatusfrontleft:"Porte avant gauche",doorlockstatusfrontright:"Porte avant droit",doorlockstatusgas:"Trappe carburant",doorlockstatusrearleft:"Porte arrière gauche",doorlockstatusrearright:"Porte arrière droit"},serviceData:{labelChargeProgram:"Programme de charge",labelCity:"Ville",labelClose:"Fermer",labelDepartureTime:"Heure de départ",labelDurationTime:"Durée",labelLatitude:"Latitude",labelLockCar:"Verrouillage véhicule",labelLongitude:"Longitude",labelMaxStateOfCharge:"État de charge max.",labelMoreInfo:"Plus d'infos",labelMove:"Déplacer",labelNoSelection:"Aucune sélection",labelOpen:"Ouvrir",labelPostCode:"Code postal",labelSave:"Enregistrer",labelSend:"Envoyer",labelSetMaxSoc:"Définir le maximum",labelSetProgram:"Définir le programme",labelStart:"Démarrer",labelStartTime:"Heure de début",labelStop:"Arrêter",labelStopTime:"Heure de fin",labelStreet:"Rue",labelTilt:"Inclinaison",labelTime1:"Durée 1",labelTime2:"Durée 2",labelTime3:"Durée 3",labelTimeSelection:"Sélection du temps",labelTitle:"Titre",labelUnlockCar:"Déverrouiller véhicule",labelWindowFrontLeft:"Avant gauche",labelWindowFrontRight:"Avant droit",labelWindowRearLeft:"Arrière gauche",labelWindowRearRight:"Arrière droit"},servicesCtrl:{auxheat:"Chauffage auxiliaire",charge:"Charge",doorsLock:"Sécurité",engine:"Contrôle moteur",preheat:"Pré-chauffage",sendRoute:"Envoyer itinéraire",sigPos:"Signal position",sunroof:"Toit ouvrant",windows:"Vitres"},starterBattery:{notAvailable:"Non disponible",partlyCharged:"Partiellement chargé",remoteServiceDisabled:"Service à distance désactivé",stateOk:"Ok",vehicleNoLongerAvailable:"Véhicule non disponible"},sunroofState:{antiBoomingLifting:"Levé déflecteur d'air",antiBoomingPosition:"Position anti-bruit d'air",closing:"Fermeture",closingLifting:"Fermeture mode levé",intermediatePosition:"Position intermédiaire",liftingIntermediate:"Mode Levé intermédiaire",liftingOpen:"Mode levé ouvert",opening:"Ouverture",openingLifting:"Mode levé en cours",running:"En cours",slidingIntermediate:"Ouverture partielle",stateClosed:"Fermé",stateOpen:"Ouvert"},tripCard:{adBlueLevel:"Niveau AdBlue",averageSpeedReset:"Vitesse moyenne",averageSpeedStart:"Vitesse moyenne",distanceReset:"Distance parcourue",distanceStart:"Distance parcourue",drivenTimeReset:"Durée du trajet",drivenTimeStart:"Durée du trajet",electricConsumptionReset:"Consommation moyenne",electricConsumptionStart:"Consommation moyenne",fromReset:"Depuis la remise à zéro",fromStart:"Depuis le départ",fuelLevel:"Niveau de carburant",liquidConsumptionReset:"Consommation moyenne",liquidConsumptionStart:"Consommation moyenne",maxSoc:"État de charge max.",odometer:"Compteur kilométrique",overview:"Aperçu",rangeElectric:"Autonomie",rangeLiquid:"Autonomie",soc:"État de charge"},tyreCard:{tirePressureFrontLeft:"Avant gauche",tirePressureFrontRight:"Avant droit",tirePressureRearLeft:"Arrière gauche",tirePressureRearRight:"Arrière droit",tireWarningOk:"Pas de perte de pression détectée",tireWarningProblem:"Perte de pression détectée! Vérifiez les pneus.",tyrePressure:"Pressions pneus"},vehicleCard:{doorStatusOverall:"Portes",engineLight:"Voyant moteur",ignitionState:"État de l'allumage",lockSensor:"État du verrouillage",lowBrakeFluid:"Liquide de frein",lowCoolantLevel:"Liquide de refroidissement",lowWashWater:"Liquide lave-glace",parkBrake:"Frein de stationnement",starterBatteryState:"Batterie de démarrage",tirePressureWarning:"Pression des pneus",vehicleStatus:"État du véhicule",vehicleWarnings:"Avertissements",windowsClosed:"Vitres"},windowAttributes:{windowstatusfrontleft:"Vitre avant gauche",windowstatusfrontleftblind:"Store avant gauche",windowstatusfrontright:"Vitre avant droite",windowstatusfrontrightblind:"Store avant droit",windowstatusrearleft:"Vitre arrière gauche",windowstatusrearleftblind:"Store arrière gauche",windowstatusrearright:"Vitre arrière droite",windowstatusrearrightblind:"Store arrière droit"}},ht={buttonConfig:{desc:"Configurer les sous-cartes pour chaque bouton.",title:"Configuration des boutons"},common:{checkAll:"Tout cocher",infoButton:"Sélectionnez la carte que vous souhaitez configurer.",infoImages:"Il n'est pas nécessaire d'ajouter un '-' pour chaque ligne. Chaque ligne sera traitée comme une URL séparée automatiquement.",infoMap:"Configuration pour la popup de carte.",infoServices:"Choisissez les services que vous souhaitez activer. Si un service est désactivé, il ne sera pas affiché dans la carte.",uncheckAll:"Tout décocher"},imagesConfig:{desc:"Ajouter les URL des images.",title:"Configuration image"},mapConfig:{desc:"Choisissez la configuration de la carte",title:"Configuration carte"},servicesConfig:{desc:"Choisissez les services que vous souhaitez activer.",title:"Configuration services"},showConfig:{desc:"Choisissez les éléments que vous souhaitez afficher.",title:"Afficher la configuration"},showOpts:{enable_map_popup:"Activer le popup carte",enable_services_control:"Activer les services",show_background:"Afficher l'arrière plan ",show_buttons:"Afficher les boutons",show_error_notify:"Afficher les notifications d'erreurs",show_map:"Afficher la carte",show_slides:"Afficher le slide"},themeLangConfig:{desc:"Choisissez le thème et la langue.",title:"Thèmes & Langage"}},ut={name:lt,nativeName:ct,card:dt,editor:ht},pt=Object.freeze({__proto__:null,name:lt,nativeName:ct,card:dt,editor:ht,default:ut}),ft="Lithuanian",gt="Lietuvių",mt={common:{lastUpdate:"Paskutinis atnaujinimas",stateCharging:"Įkrovimas",stateClosed:"Uždaryta",stateLocked:"Užrakinta",stateLockedInt:"Užrakinta int",stateNotExisting:"Neegzistuoja",stateOpen:"Atidaryta",stateParkBrakeOff:"Išleista",stateParkBrakeOn:"Įtraukta",statePartlyUnlocked:"Iš dalies atrakinta",stateUnknown:"Nežinomas",stateUnlocked:"Atrakinta",titleRemoteControl:"Nuotolinis valdymas",titleServices:"Paslaugos",toastCommandSent:"Komanda išsiųsta sėkmingai!",toastImageError:"Klaida įkeliant vaizdą. Leidžiami tik PNG ir JPEG failai."},cardType:{ecoCards:"Eco ekranas",tripCards:"Kelionės duomenys",tyreCards:"Padangų slėgis",vehicleCards:"Transporto priemonės būklė"},chargingOverview:{chargingPower:"Galia",maxSoc:"Maksimalus",selectedProgram:"Programa",soc:"Dabartinė būklė"},doorAttributes:{decklidstatus:"Palubės dangtis",doorstatusfrontleft:"Priekinės kairės pusės durys",doorstatusfrontright:"Priekinės dešinės pusės durys",doorstatusrearleft:"Galinės kairės pusės durys",doorstatusrearright:"Galinės dešinės pusės durys",enginehoodstatus:"Variklio gaubtas",sunroofstatus:"Stoglangis"},ecoCard:{ecoDisplay:"Eco ekranas",ecoScore:"Rezultatai",ecoScoreAcceleraion:"Akceleratorius",ecoScoreBonusRange:"Papildomas diapazonas",ecoScoreConstant:"Nuolatinis",ecoScoreFreeWheel:"Laisvas ratas"},lockAttributes:{doorlockstatusfrontleft:"Durų užraktas priekyje kairėje",doorlockstatusfrontright:"Durų užraktas priekyje dešinėje",doorlockstatusgas:"Dujų užraktas",doorlockstatusrearleft:"Durų užraktas gale kairėje",doorlockstatusrearright:"Durų užraktas gale dešinėje"},serviceData:{labelChargeProgram:"Įkrovimo programa",labelCity:"Miestas",labelClose:"Uždaryti",labelDepartureTime:"Išvykimo laikas",labelDurationTime:"Trukmės laikas",labelLatitude:"Platuma",labelLockCar:"Automobilio užrakinimas",labelLongitude:"Ilguma",labelMaxStateOfCharge:"Maksimali įkrovos būsena",labelMoreInfo:"Daugiau informacijos",labelMove:"Perkelti",labelNoSelection:"Nėra pasirinkimo",labelOpen:"Atviras",labelPostCode:"Pašto kodas",labelSave:"Išsaugoti",labelSend:"Siųsti",labelSetMaxSoc:"Nustatykite didžiausią",labelSetProgram:"Nustatyti programą",labelStart:"Pradėti",labelStartTime:"Pradžios laikas",labelStop:"Sustabdyti",labelStopTime:"Sustojimo laikas",labelStreet:"Gatvė",labelTilt:"Pakreipti",labelTime1:"Laikas 1",labelTime2:"Laikas 2",labelTime3:"Laikas 3",labelTimeSelection:"Laiko pasirinkimas",labelTitle:"Pavadinimas",labelUnlockCar:"Automobilio atrakinimas",labelWindowFrontLeft:"Priekinė kairė",labelWindowFrontRight:"Priekinė dešinė",labelWindowRearLeft:"Galinė kairė",labelWindowRearRight:"Galinė dešinė"},servicesCtrl:{auxheat:"Papildomas šildymas",charge:"Įkrovimas",doorsLock:"Sauga",engine:"Variklio valdymas",preheat:"Pirminis kondicionavimas",sendRoute:"Siųsti maršrutą",sigPos:"Signalo padėtis",sunroof:"Stoglangis",windows:"Langai"},starterBattery:{notAvailable:"Nerastas",partlyCharged:"Iš dalies įkrautas",remoteServiceDisabled:"Nuotolinė paslauga išjungta",stateOk:"Ok",vehicleNoLongerAvailable:"Transporto priemonė nebėra prieinama"},sunroofState:{antiBoomingLifting:"Anti-booming lifting",antiBoomingPosition:"Apsaugos nuo šuolių padėtis",closing:"Uždarymas",closingLifting:"Uždarymo kėlimas",intermediatePosition:"Tarpinė padėtis",liftingIntermediate:"Tarpinis kėlimas",liftingOpen:"Atidarytas pakėlimas",opening:"Atidarymas",openingLifting:"Atidarymo kėlimas",running:"Bėgimas",slidingIntermediate:"Stumdomas tarpinis",stateClosed:"Uždaryta",stateOpen:"Atidaryta"},tripCard:{adBlueLevel:"AdBlue lygis",averageSpeedReset:"Vidutinis greitis",averageSpeedStart:"Vidutinis greitis",distanceReset:"Nuvažiuotas atstumas",distanceStart:"Nuvažiuotas atstumas",drivenTimeReset:"Važiavimo laikas",drivenTimeStart:"Važiavimo laikas",electricConsumptionReset:"Vidutinis suvartojimas",electricConsumptionStart:"Vidutinis suvartojimas",fromReset:"Iš naujo",fromStart:"Nuo pradžios",fuelLevel:"Kuro lygis",liquidConsumptionReset:"Vidutinis suvartojimas",liquidConsumptionStart:"Vidutinis suvartojimas",maxSoc:"Maksimali įkrovos būsena",odometer:"Odometras",overview:"Apžvalga",rangeElectric:"Nuotolis",rangeLiquid:"Nuotolis",soc:"Įkrovimo būklė"},tyreCard:{tirePressureFrontLeft:"Priekinė kairė",tirePressureFrontRight:"Priekinė dešinė",tirePressureRearLeft:"Galinė kairė",tirePressureRearRight:"Galinė dešinė",tireWarningOk:"Slėgio sumažėjimo neaptikta",tireWarningProblem:"Aptiktas slėgio sumažėjimas. Patikrinkite padangas.",tyrePressure:"Padangų slėgis"},vehicleCard:{doorStatusOverall:"Durys",engineLight:"Variklio indikatorius",ignitionState:"Užvedimo būsena",lockSensor:"Užrakinimo būklė",lowBrakeFluid:"Stabdžių skystis",lowCoolantLevel:"Aušinimo skystis",lowWashWater:"Plovimo skystis",parkBrake:"Stovėjimo stabdys",starterBatteryState:"Užvedimo akumuliatorius",tirePressureWarning:"Padangų slėgis",vehicleStatus:"Transporto priemonės būklė",vehicleWarnings:"Įspėjimai",windowsClosed:"Langai"},windowAttributes:{windowstatusfrontleft:"Priekinis kairės pusės langas",windowstatusfrontleftblind:"Priekinio lango kairės pusės žaliuzė",windowstatusfrontright:"Priekinis dešinės pusės langas",windowstatusfrontrightblind:"Priekinio lango dešinės pusės žaliuzė",windowstatusrearleft:"Užpakalinis kairės pusės langas",windowstatusrearleftblind:"Galinio lango kairės pusės žaliuzė",windowstatusrearright:"Užpakalinis dešinės pusės langas",windowstatusrearrightblind:"Galinio lango dešinės pusės žaliuzė"}},vt={buttonConfig:{desc:"Sukonfigūruokite atskirų mygtukų antrines korteles.",title:"Mygtukų konfigūracija"},common:{checkAll:"Pažymėkite visus",infoButton:"Pasirinkite kortelę, kurią norite konfigūruoti.",infoImages:"Kiekvienoje eilutėje nereikia pridėti. Kiekviena eilutė automatiškai bus laikoma atskiru URL.",infoMap:"TTai iššokančio žemėlapio konfigūracija.",infoServices:"Pasirinkite, kurias paslaugas norite įjungti. Jei paslauga išjungta, ji nebus rodoma kortelėje.",uncheckAll:"Atsisakykite visų"},imagesConfig:{desc:"Pridėkite paveikslėlių URL adresus.",title:"Paveikslėlio konfigūracija"},mapConfig:{desc:"Pasirinkite žemėlapio konfigūraciją",title:"Žemėlapio konfigūracija"},servicesConfig:{desc:"Pasirinkite paslaugas, kurias norite įjungti.",title:"Paslaugų konfigūracija"},showConfig:{desc:"Pasirinkite elementus, kuriuos norite rodyti.",title:"Rodyti konfigūraciją"},showOpts:{enable_map_popup:"Įjungti iššokantį žemėlapio langą",enable_services_control:"Paslaugų valdymo įjungimas",show_background:"Rodyti foną",show_buttons:"Rodyti mygtukus",show_error_notify:"Rodyti pranešimą apie klaidą",show_map:"Rodyti žemėlapį",show_slides:"Parodyti skaidres"},themeLangConfig:{desc:"Pasirinkite temą ir kalbą.",title:"Temos ir kalba"}},bt={name:ft,nativeName:gt,card:mt,editor:vt},xt=Object.freeze({__proto__:null,name:ft,nativeName:gt,card:mt,editor:vt,default:bt}),yt="Polish",wt="Polski",At={common:{lastUpdate:"Zaktualizowano",stateCharging:"Ładowanie",stateClosed:"Zamknięte",stateLocked:"Zamknięte",stateLockedInt:"Zamknięte wewnętrznie",stateNotExisting:"Nie istnieje",stateOpen:"Otwarte",stateParkBrakeOff:"Zwolniony",stateParkBrakeOn:"Zaciągnięty",statePartlyUnlocked:"Częściowo odblokowane",stateUnknown:"Nieznany",stateUnlocked:"Odblokowane",titleRemoteControl:"Zdalne sterowanie",titleServices:"Usługi",toastCommandSent:"Polecenie wysłane pomyślnie!",toastImageError:"Błąd przesyłania obrazu. Dozwolone są tylko pliki PNG i JPEG."},cardType:{ecoCards:"Wskaźnik ECO",tripCards:"Dane o podróży",tyreCards:"Ciśnienie opon",vehicleCards:"Status pojazdu"},chargingOverview:{chargingPower:"Moc",maxSoc:"Maksimum",selectedProgram:"Program",soc:"Stan naładowania"},doorAttributes:{decklidstatus:"Pokrywa bagażnika",doorstatusfrontleft:"Przednie lewe drzwi",doorstatusfrontright:"Przednie prawe drzwi",doorstatusrearleft:"Tylne lewe drzwi",doorstatusrearright:"Tylne prawe drzwi",enginehoodstatus:"Maska silnika",sunroofstatus:"Szyberdach"},ecoCard:{ecoDisplay:"Status ECO",ecoScore:"Wynik",ecoScoreAcceleraion:"Przyspieszenie",ecoScoreBonusRange:"Dodatkowy zasięg",ecoScoreConstant:"Stała",ecoScoreFreeWheel:"Jazda bezwładnościowa"},lockAttributes:{doorlockstatusfrontleft:"Zamek przednich lewych drzwi",doorlockstatusfrontright:"Zamek przednich prawych drzwi",doorlockstatusgas:"Zamek wlewu paliwa",doorlockstatusrearleft:"Zamek tylnych lewych drzwi",doorlockstatusrearright:"Zamek tylnych prawych drzwi"},serviceData:{labelChargeProgram:"Program ładowania",labelCity:"Miasto",labelClose:"Zamknij",labelDepartureTime:"Czas odjazdu",labelDurationTime:"Czas trwania",labelLatitude:"Szerokość geograficzna",labelLockCar:"Zablokuj samochód",labelLongitude:"Długość geograficzna",labelMaxStateOfCharge:"Maksymalny stan naładowania",labelMoreInfo:"Więcej informacji",labelMove:"Przesuń",labelNoSelection:"Brak wyboru",labelOpen:"Otwórz",labelPostCode:"Kod pocztowy",labelSave:"Zapisz",labelSend:"Wyślij",labelSetMaxSoc:"Ustaw maksimum",labelSetProgram:"Ustaw program",labelStart:"Start",labelStartTime:"Czas rozpoczęcia",labelStop:"Stop",labelStopTime:"Czas zakończenia",labelStreet:"Ulica",labelTilt:"Pochylenie",labelTime1:"Czas 1",labelTime2:"Czas 2",labelTime3:"Czas 3",labelTimeSelection:"Wybór czasu",labelTitle:"Tytuł",labelUnlockCar:"Odblokuj samochód",labelWindowFrontLeft:"Przednie lewe",labelWindowFrontRight:"Przednie prawe",labelWindowRearLeft:"Tylne lewe",labelWindowRearRight:"Tylne prawe"},servicesCtrl:{auxheat:"Ogrzewanie pomocnicze",charge:"Ładowanie",doorsLock:"Zabezpieczenia",engine:"Sterowanie silnikiem",preheat:"Przygotowanie",sendRoute:"Wyślij trasę",sigPos:"Pozycja sygnału",sunroof:"Szyberdach",windows:"Okna"},starterBattery:{notAvailable:"Niedostępny",partlyCharged:"Częściowo naładowany",remoteServiceDisabled:"Zdalna usługa wyłączona",stateOk:"Ok",vehicleNoLongerAvailable:"Pojazd już niedostępny"},sunroofState:{antiBoomingLifting:"Podnoszenie anty-hałasowe",antiBoomingPosition:"Pozycja anty-hałasowa",closing:"Zamykanie",closingLifting:"Zamykanie podnoszenie",intermediatePosition:"Pozycja pośrednia",liftingIntermediate:"Podnoszenie pośrednie",liftingOpen:"Podnoszenie otwarte",opening:"Otwieranie",openingLifting:"Otwieranie podnoszenie",running:"Ruch",slidingIntermediate:"Przesuwanie pośrednie",stateClosed:"Zamknięte",stateOpen:"Otwarte"},tripCard:{adBlueLevel:"Poziom AdBlue",averageSpeedReset:"Średnia prędkość",averageSpeedStart:"Średnia prędkość",distanceReset:"Przejechana odległość",distanceStart:"Przejechana odległość",drivenTimeReset:"Czas jazdy",drivenTimeStart:"Czas jazdy",electricConsumptionReset:"Średnie zużycie",electricConsumptionStart:"Średnie zużycie",fromReset:"Od resetu",fromStart:"Od rozruchu",fuelLevel:"Poziom paliwa",liquidConsumptionReset:"Średnie zużycie",liquidConsumptionStart:"Średnie zużycie",maxSoc:"Maksymalny stan naładowania",odometer:"Licznik kilometrów",overview:"Przegląd",rangeElectric:"Zasięg",rangeLiquid:"Zasięg",soc:"Stan naładowania"},tyreCard:{tirePressureFrontLeft:"Przednia lewa",tirePressureFrontRight:"Przednia prawa",tirePressureRearLeft:"Tylna lewa",tirePressureRearRight:"Tylna prawa",tireWarningOk:"Nie wykryto utraty ciśnienia",tireWarningProblem:"Wykryto utratę ciśnienia. Sprawdź opony.",tyrePressure:"Ciśnienie w oponach"},vehicleCard:{doorStatusOverall:"Drzwi",engineLight:"Kontrolka silnika",ignitionState:"Stan zapłonu",lockSensor:"Stan zamka",lowBrakeFluid:"Płyn hamulcowy",lowCoolantLevel:"Chłodziwo",lowWashWater:"Płyn do spryskiwaczy",parkBrake:"Hamulec postojowy",starterBatteryState:"Akumulator",tirePressureWarning:"Stan ciśnienia w oponach",vehicleStatus:"Stan pojazdu",vehicleWarnings:"Ostrzeżenia",windowsClosed:"Okna"},windowAttributes:{windowstatusfrontleft:"Przednie lewe okno",windowstatusfrontleftblind:"Przednie lewe okno z roletą",windowstatusfrontright:"Przednie prawe okno",windowstatusfrontrightblind:"Przednie prawe okno z roletą",windowstatusrearleft:"Tylne lewe okno",windowstatusrearleftblind:"Tylne lewe okno z roletą",windowstatusrearright:"Tylne prawe okno",windowstatusrearrightblind:"Tylne prawe okno z roletą"}},Ct={buttonConfig:{desc:"Skonfiguruj podkarty dla poszczególnych przycisków.",title:"Konfiguracja przycisków"},common:{checkAll:"Zaznacz wszystko",infoButton:"Wybierz kartę, którą chcesz skonfigurować.",infoImages:"Nie ma potrzeby dodawania '-' dla każdej linii. Każda linia będzie automatycznie traktowana jako oddzielny URL.",infoMap:"To jest konfiguracja dla okienka mapy.",infoServices:"Wybierz, które usługi chcesz włączyć. Jeśli usługa jest wyłączona, nie będzie wyświetlana na karcie.",uncheckAll:"Odznacz wszystko"},imagesConfig:{desc:"Dodaj URL-e obrazów.",title:"Konfiguracja obrazów"},mapConfig:{desc:"Wybierz konfigurację dla mapy",title:"Konfiguracja mapy"},servicesConfig:{desc:"Wybierz usługi, które chcesz włączyć.",title:"Konfiguracja usług"},showConfig:{desc:"Wybierz elementy, które chcesz wyświetlić.",title:"Konfiguracja wyświetlania"},showOpts:{enable_map_popup:"Włącz wyskakujące okienko mapy",enable_services_control:"Włącz kontrolę usług",show_background:"Pokaż tło",show_buttons:"Pokaż przyciski",show_error_notify:"Pokaż powiadomienie o błędzie",show_map:"Pokaż mapę",show_slides:"Pokaż slajdy"},themeLangConfig:{desc:"Wybierz temat i język.",title:"Tematy i język"}},zt={name:yt,nativeName:wt,card:At,editor:Ct},Pt=Object.freeze({__proto__:null,name:yt,nativeName:wt,card:At,editor:Ct,default:zt}),St="Slovak",kt="Slovenčina",Et={common:{lastUpdate:"Posledná aktualizácia",stateCharging:"Nabíjanie",stateClosed:"Zatvorené",stateLocked:"Zamknuté",stateLockedInt:"Vnútorné zamknutie",stateNotExisting:"Neexistujúce",stateOpen:"Otvorené",stateParkBrakeOff:"Uvoľnená",stateParkBrakeOn:"Zaparkovaná",statePartlyUnlocked:"Čiastočne odomknuté",stateUnknown:"Neznáme",stateUnlocked:"Odomknuté",titleRemoteControl:"Vzdialené ovládanie",titleServices:"Služby",toastCommandSent:"Príkaz úspešne odoslaný!",toastImageError:"Chyba pri nahrávaní obrázka. Povolené sú iba súbory PNG a JPEG."},cardType:{ecoCards:"Ukazovateľ ECO",tripCards:"Údaje o jazde",tyreCards:"Tlak v pneumatikách",vehicleCards:"Stav vozidla"},chargingOverview:{chargingPower:"Výkon",maxSoc:"Maximum",selectedProgram:"Program",soc:"Stav nabitia"},doorAttributes:{decklidstatus:"Stav batožinového priestoru",doorstatusfrontleft:"Predné ľavé dvere",doorstatusfrontright:"Predné pravé dvere",doorstatusrearleft:"Zadné ľavé dvere",doorstatusrearright:"Zadné pravé dvere",enginehoodstatus:"Kapota motora",sunroofstatus:"Strešné okno"},ecoCard:{ecoDisplay:"Ukazovateľ ECO",ecoScore:"Skóre",ecoScoreAcceleraion:"Zrýchlenie",ecoScoreBonusRange:"Bonusový dojazd",ecoScoreConstant:"Konštanta",ecoScoreFreeWheel:"Voľnobeh"},lockAttributes:{doorlockstatusfrontleft:"Zámok predných ľavých dverí",doorlockstatusfrontright:"Zámok predných pravých dverí",doorlockstatusgas:"Zámok nádrže",doorlockstatusrearleft:"Zámok zadných ľavých dverí",doorlockstatusrearright:"Zámok zadných pravých dverí"},serviceData:{labelChargeProgram:"Program nabíjania",labelCity:"Mesto",labelClose:"Zatvoriť",labelDepartureTime:"Čas odchodu",labelDurationTime:"Doba trvania",labelLatitude:"Zemepisná šírka",labelLockCar:"Zamknúť auto",labelLongitude:"Zemepisná dĺžka",labelMaxStateOfCharge:"Maximálny stav nabitia",labelMoreInfo:"Viac informácií",labelMove:"Presunúť",labelNoSelection:"Žiadny výber",labelOpen:"Otvoriť",labelPostCode:"PSČ",labelSave:"Uložiť",labelSend:"Odoslať",labelSetMaxSoc:"Nastaviť maximum",labelSetProgram:"Nastaviť program",labelStart:"Štart",labelStartTime:"Čas začiatku",labelStop:"Stop",labelStopTime:"Čas konca",labelStreet:"Ulica",labelTilt:"Náklon",labelTime1:"Čas 1",labelTime2:"Čas 2",labelTime3:"Čas 3",labelTimeSelection:"Výber času",labelTitle:"Názov",labelUnlockCar:"Odomknúť auto",labelWindowFrontLeft:"Predné vľavo",labelWindowFrontRight:"Predné vpravo",labelWindowRearLeft:"Zadné vľavo",labelWindowRearRight:"Zadné vpravo"},servicesCtrl:{auxheat:"Prídavné kúrenie",charge:"Nabíjanie",doorsLock:"Bezpečnosť",engine:"Ovládanie motora",preheat:"Predhrievanie",sendRoute:"Odoslať trasu",sigPos:"Signalizovať polohu",sunroof:"Strešné okno",windows:"Okienka"},starterBattery:{notAvailable:"Nie je dostupné",partlyCharged:"Čiastočne nabité",remoteServiceDisabled:"Vzdialená služba deaktivovaná",stateOk:"Ok",vehicleNoLongerAvailable:"Vozidlo už nie je dostupné"},sunroofState:{antiBoomingLifting:"Zdvihnutie proti hučaniu",antiBoomingPosition:"Pozícia proti hučaniu",closing:"Zatváranie",closingLifting:"Zatváranie a zdvihnutie",intermediatePosition:"Medzipoloha",liftingIntermediate:"Zdvihnutie do medzipolohy",liftingOpen:"Zdvihnuté otvorené",opening:"Otváranie",openingLifting:"Otváranie a zdvihnutie",running:"V prevádzke",slidingIntermediate:"Posúvanie do medzipolohy",stateClosed:"Zatvorené",stateOpen:"Otvorené"},tripCard:{adBlueLevel:"Hladina AdBlue",averageSpeedReset:"Priemerná rýchlosť",averageSpeedStart:"Priemerná rýchlosť",distanceReset:"Najazdená vzdialenosť",distanceStart:"Najazdená vzdialenosť",drivenTimeReset:"Čas jazdy",drivenTimeStart:"Čas jazdy",electricConsumptionReset:"Priemerná spotreba",electricConsumptionStart:"Priemerná spotreba",fromReset:"Od resetu",fromStart:"Od začiatku",fuelLevel:"Hladina paliva",liquidConsumptionReset:"Priemerná spotreba",liquidConsumptionStart:"Priemerná spotreba",maxSoc:"Maximálny stav nabitia",odometer:"Odometer",overview:"Prehľad",rangeElectric:"Dojazd",rangeLiquid:"Dojazd",soc:"Stav nabitia"},tyreCard:{tirePressureFrontLeft:"Predná ľavá",tirePressureFrontRight:"Predná pravá",tirePressureRearLeft:"Zadná ľavá",tirePressureRearRight:"Zadná pravá",tireWarningOk:"Žiadna strata tlaku nebola zistená",tireWarningProblem:"Zistená strata tlaku. Skontrolujte pneumatiky.",tyrePressure:"Tlak v pneumatikách"},vehicleCard:{doorStatusOverall:"Dvere",engineLight:"Kontrolka motora",ignitionState:"Stav zapaľovania",lockSensor:"Stav zamknutia",lowBrakeFluid:"Brzdová kvapalina",lowCoolantLevel:"Chladiaca kvapalina",lowWashWater:"Kvapalina do ostrekovača",parkBrake:"Ručná brzda",starterBatteryState:"Štartovacia batéria",tirePressureWarning:"Stav tlaku v pneumatike",vehicleStatus:"Stav vozidla",vehicleWarnings:"Upozornenia",windowsClosed:"Okienka"},windowAttributes:{windowstatusfrontleft:"Predné ľavé okno",windowstatusfrontleftblind:"Predné ľavé okno so žalúziou",windowstatusfrontright:"Predné pravé okno",windowstatusfrontrightblind:"Predné pravé okno so žalúziou",windowstatusrearleft:"Zadné ľavé okno",windowstatusrearleftblind:"Zadné ľavé okno so žalúziou",windowstatusrearright:"Zadné pravé okno",windowstatusrearrightblind:"Zadné pravé okno so žalúziou"}},Mt={buttonConfig:{desc:"Nakonfigurujte podkarty pre jednotlivé tlačidlá.",title:"Konfigurácia tlačidiel"},common:{checkAll:"Zaškrtnúť všetko",infoButton:"Vyberte kartu, ktorú chcete nakonfigurovať.",infoImages:"Nie je potrebné pridávať '-' pre každý riadok. Každý riadok bude automaticky považovaný za samostatnú URL adresu.",infoMap:"Toto je konfigurácia pre mapové vyskakovacie okno.",infoServices:"Vyberte služby, ktoré chcete povoliť. Ak je služba deaktivovaná, nebude na karte zobrazená.",uncheckAll:"Zrušiť všetko"},imagesConfig:{desc:"Pridajte URL adresy obrázkov.",title:"Konfigurácia obrázkov"},mapConfig:{desc:"Vyberte konfiguráciu pre mapu",title:"Konfigurácia mapy"},servicesConfig:{desc:"Vyberte služby, ktoré chcete povoliť.",title:"Konfigurácia služieb"},showConfig:{desc:"Vyberte položky, ktoré chcete zobraziť.",title:"Konfigurácia zobrazenia"},showOpts:{enable_map_popup:"Povoliť vyskakovacie okno mapy",enable_services_control:"Povoliť ovládanie služieb",show_background:"Zobraziť pozadie",show_buttons:"Zobraziť tlačidlá",show_error_notify:"Zobraziť upozornenie na chybu",show_map:"Zobraziť mapu",show_slides:"Zobraziť snímky"},themeLangConfig:{desc:"Vyberte tému a jazyk.",title:"Témy a jazyk"}},Ot={name:St,nativeName:kt,card:Et,editor:Mt},Lt=Object.freeze({__proto__:null,name:St,nativeName:kt,card:Et,editor:Mt,default:Ot}),It="Vietnamese",Bt="Tiếng Việt",Vt={common:{lastUpdate:"Cập nhật cuối",stateCharging:"Đang sạc",stateClosed:"Đã đóng",stateLocked:"Đã khóa",stateLockedInt:"Khóa bên trong",stateNotExisting:"Không tồn tại",stateOpen:"Đã mở",stateParkBrakeOff:"Đã tắt",stateParkBrakeOn:"Đang kích hoạt",statePartlyUnlocked:"Mở khóa một phần",stateUnknown:"Không rõ",stateUnlocked:"Đã mở khóa",titleRemoteControl:"Điều khiển từ xa",titleServices:"Dịch vụ",toastCommandSent:"Lệnh đã được gửi thành công!",toastImageError:"Lỗi khi tải ảnh lên. Chỉ cho phép tệp PNG và JPEG."},cardType:{ecoCards:"Điểm số ECO",tripCards:"Dữ liệu chuyến đi",tyreCards:"Áp suất lốp",vehicleCards:"Trạng thái xe"},chargingOverview:{chargingPower:"Công suất",maxSoc:"Tối đa",selectedProgram:"Chương trình",soc:"Hiện tại"},doorAttributes:{decklidstatus:"Nắp khoang hành lý",doorstatusfrontleft:"Cửa trước trái",doorstatusfrontright:"Cửa trước phải",doorstatusrearleft:"Cửa sau trái",doorstatusrearright:"Cửa sau phải",enginehoodstatus:"Nắp động cơ",sunroofstatus:"Cửa sổ trời"},ecoCard:{ecoDisplay:"Hiển thị Eco",ecoScore:"Điểm số",ecoScoreAcceleraion:"Gia tốc",ecoScoreBonusRange:"Phạm vi thưởng",ecoScoreConstant:"Ổn định",ecoScoreFreeWheel:"Bánh tự do"},lockAttributes:{doorlockstatusfrontleft:"Khóa cửa trước trái",doorlockstatusfrontright:"Khóa cửa trước phải",doorlockstatusgas:"Khóa nhiên liệu",doorlockstatusrearleft:"Khóa cửa sau trái",doorlockstatusrearright:"Khóa cửa sau phải"},serviceData:{labelChargeProgram:"Chương trình sạc",labelCity:"Thành phố",labelClose:"Đóng",labelDepartureTime:"Thời gian khởi hành",labelDurationTime:"Thời gian kéo dài",labelLatitude:"Vĩ độ",labelLockCar:"Khóa xe",labelLongitude:"Kinh độ",labelMaxStateOfCharge:"Trạng thái sạc tối đa",labelMoreInfo:"Thêm thông tin",labelMove:"Di chuyển",labelNoSelection:"Không có lựa chọn",labelOpen:"Mở",labelPostCode:"Mã bưu điện",labelSave:"Lưu",labelSend:"Gửi",labelSetMaxSoc:"Đặt tối đa",labelSetProgram:"Đặt chương trình",labelStart:"Bắt đầu",labelStartTime:"Thời gian bắt đầu",labelStop:"Dừng lại",labelStopTime:"Thời gian dừng",labelStreet:"Đường phố",labelTilt:"Nghiêng",labelTime1:"Thời gian 1",labelTime2:"Thời gian 2",labelTime3:"Thời gian 3",labelTimeSelection:"Chọn thời gian",labelTitle:"Tiêu đề",labelUnlockCar:"Mở khóa xe",labelWindowFrontLeft:"Trước trái",labelWindowFrontRight:"Trước phải",labelWindowRearLeft:"Sau trái",labelWindowRearRight:"Sau phải"},servicesCtrl:{auxheat:"Sưởi phụ",charge:"Sạc",doorsLock:"An ninh",engine:"Kiểm soát động cơ",preheat:"Điều hòa trước",sendRoute:"Gửi lộ trình",sigPos:"Vị trí tín hiệu",sunroof:"Cửa sổ trời",windows:"Cửa sổ"},starterBattery:{notAvailable:"Không có sẵn",partlyCharged:"Sạc một phần",remoteServiceDisabled:"Dịch vụ từ xa bị tắt",stateOk:"Tốt",vehicleNoLongerAvailable:"Xe không còn có sẵn"},sunroofState:{antiBoomingLifting:"Nâng chống rung",antiBoomingPosition:"Vị trí chống rung",closing:"Đang đóng",closingLifting:"Đang đóng nâng",intermediatePosition:"Vị trí trung gian",liftingIntermediate:"Nâng trung gian",liftingOpen:"Nâng mở",opening:"Đang mở",openingLifting:"Đang mở nâng",running:"Chạy",slidingIntermediate:"Trượt trung gian",stateClosed:"Đóng",stateOpen:"Mở"},tripCard:{adBlueLevel:"Mức AdBlue",averageSpeedReset:"Tốc độ trung bình",averageSpeedStart:"Tốc độ trung bình",distanceReset:"Khoảng cách đã đi",distanceStart:"Khoảng cách đã đi",drivenTimeReset:"Thời gian lái xe",drivenTimeStart:"Thời gian lái xe",electricConsumptionReset:"Tiêu thụ nhiên liệu",electricConsumptionStart:"Tiêu thụ nhiên liệu",fromReset:"Từ khi đặt lại",fromStart:"Từ đầu",fuelLevel:"Mức nhiên liệu",liquidConsumptionReset:"Tiêu thụ nhiên liệu",liquidConsumptionStart:"Tiêu thụ nhiên liệu",maxSoc:"Trạng thái sạc tối đa",odometer:"Đồng hồ đo quãng đường",overview:"Tổng quan",rangeElectric:"Phạm vi",rangeLiquid:"Phạm vi",soc:"Trạng thái sạc"},tyreCard:{tirePressureFrontLeft:"Trước trái",tirePressureFrontRight:"Trước phải",tirePressureRearLeft:"Sau trái",tirePressureRearRight:"Sau phải",tireWarningOk:"Không phát hiện mất áp suất",tireWarningProblem:"Phát hiện mất áp suất. Kiểm tra lốp xe.",tyrePressure:"Áp suất lốp"},vehicleCard:{doorStatusOverall:"Cửa",engineLight:"Đèn động cơ",ignitionState:"Trạng thái khởi động",lockSensor:"Trạng thái khóa",lowBrakeFluid:"Dầu phanh",lowCoolantLevel:"Nước làm mát",lowWashWater:"Nước rửa kính",parkBrake:"Phanh đỗ",starterBatteryState:"Pin khởi động",tirePressureWarning:"Áp suất lốp",vehicleStatus:"Trạng thái xe",vehicleWarnings:"Cảnh báo",windowsClosed:"Cửa sổ"},windowAttributes:{windowstatusfrontleft:"Cửa sổ trước trái",windowstatusfrontleftblind:"Cửa sổ che trước trái",windowstatusfrontright:"Cửa sổ trước phải",windowstatusfrontrightblind:"Cửa sổ che trước phải",windowstatusrearleft:"Cửa sổ sau trái",windowstatusrearleftblind:"Cửa sổ che sau trái",windowstatusrearright:"Cửa sổ sau phải",windowstatusrearrightblind:"Cửa sổ che sau phải"}},Rt={buttonConfig:{desc:"Cấu hình các thẻ con cho các nút riêng lẻ.",title:"Cấu hình nút"},common:{checkAll:"Chọn tất cả",infoButton:"Chọn thẻ bạn muốn cấu hình.",infoImages:"Không cần thêm '-' cho mỗi dòng. Mỗi dòng sẽ được coi là một URL riêng biệt tự động.",infoMap:"Đây là cấu hình cho cửa sổ bật lên bản đồ.",infoServices:"Chọn dịch vụ bạn muốn kích hoạt. Nếu dịch vụ bị tắt, nó sẽ không được hiển thị trong thẻ.",uncheckAll:"Bỏ chọn tất cả"},imagesConfig:{desc:"Thêm URL của hình ảnh.",title:"Cấu hình hình ảnh"},mapConfig:{desc:"Chọn cấu hình cho bản đồ",title:"Cấu hình bản đồ"},servicesConfig:{desc:"Chọn các dịch vụ bạn muốn kích hoạt.",title:"Cấu hình dịch vụ"},showConfig:{desc:"Chọn các mục bạn muốn hiển thị.",title:"Cấu hình hiển thị"},showOpts:{enable_map_popup:"Bật cửa sổ bản đồ",enable_services_control:"Bật điều khiển dịch vụ",show_background:"Hiển thị nền",show_buttons:"Hiển thị nút",show_error_notify:"Hiển thị thông báo lỗi",show_map:"Hiển thị bản đồ",show_slides:"Hiển thị slide"},themeLangConfig:{desc:"Chọn chủ đề và ngôn ngữ.",title:"Chủ đề và ngôn ngữ"}},Dt={name:It,nativeName:Bt,card:Vt,editor:Rt},qt=Object.freeze({__proto__:null,name:It,nativeName:Bt,card:Vt,editor:Rt,default:Dt});const Tt={cs:We,de:Ue,en:tt,en_GB:ot,fr:pt,lt:xt,pl:Pt,sk:Lt,vi:qt},Nt=[{key:"cs",name:Te,nativeName:Ne},{key:"de",name:He,nativeName:Ye},{key:"en",name:Ke,nativeName:Je},{key:"en_GB",name:it,nativeName:at},{key:"fr",name:lt,nativeName:ct},{key:"lt",name:ft,nativeName:gt},{key:"pl",name:yt,nativeName:wt},{key:"sk",name:St,nativeName:kt},{key:"vi",name:It,nativeName:Bt}];function Xt(e,t,i="",a=""){const n=t.replace(/['"]+/g,"").replace("-","_");let r;try{r=e.split(".").reduce(((e,t)=>e[t]),Tt[n])}catch(t){r=e.split(".").reduce(((e,t)=>e[t]),Tt.en)}return void 0!==r&&""!==r||(r=e.split(".").reduce(((e,t)=>e[t]),Tt.en)),""!==i&&""!==a&&(r=r.replace(i,a)),r}const jt=(e,t,i)=>({label:Xt(e,t),configKey:i}),Ft=e=>[jt("editor.showOpts.show_slides",e,"show_slides"),jt("editor.showOpts.show_buttons",e,"show_buttons"),jt("editor.showOpts.show_map",e,"show_map"),jt("editor.showOpts.show_background",e,"show_background"),jt("editor.showOpts.enable_map_popup",e,"enable_map_popup"),jt("editor.showOpts.enable_services_control",e,"enable_services_control"),jt("editor.showOpts.show_error_notify",e,"show_error_notify")],Wt=(e,t,i,a,n,r)=>({type:e,name:Xt(`card.${t}`,r),icon:i,config:a,editor:n}),Ht=e=>[Wt("tripCards","cardType.tripCards","mdi:map-marker-path","trip_card","isTripCardEditor",e),Wt("vehicleCards","cardType.vehicleCards","mdi:car-info","vehicle_card","isVehicleCardEditor",e),Wt("ecoCards","cardType.ecoCards","mdi:leaf","eco_card","isEcoCardEditor",e),Wt("tyreCards","cardType.tyreCards","mdi:tire","tyre_card","isTyreCardEditor",e)],Yt=(e,t,i,a,n)=>Object.assign(Object.assign({key:e,name:Xt(`card.${t}`,i)},a?{icon:a}:{}),n?{apexProp:n}:{}),Gt=e=>[Yt("odometer","tripCard.odometer",e,"mdi:counter"),Yt("fuelLevel","tripCard.fuelLevel",e),Yt("adBlueLevel","tripCard.adBlueLevel",e,"mdi:fuel"),Yt("rangeLiquid","tripCard.rangeLiquid",e),Yt("rangeElectric","tripCard.rangeElectric",e),Yt("soc","tripCard.soc",e),Yt("maxSoc","tripCard.maxSoc",e)],Zt=e=>[Yt("distanceReset","tripCard.distanceReset",e),Yt("drivenTimeReset","tripCard.drivenTimeReset",e,"mdi:clock"),Yt("averageSpeedReset","tripCard.averageSpeedReset",e,"mdi:speedometer"),Yt("liquidConsumptionReset","tripCard.liquidConsumptionReset",e),Yt("electricConsumptionReset","tripCard.electricConsumptionReset",e)],Qt=e=>[Yt("distanceStart","tripCard.distanceStart",e),Yt("drivenTimeStart","tripCard.drivenTimeStart",e,"mdi:clock"),Yt("averageSpeedStart","tripCard.averageSpeedStart",e,"mdi:speedometer-slow"),Yt("liquidConsumptionStart","tripCard.liquidConsumptionStart",e),Yt("electricConsumptionStart","tripCard.electricConsumptionStart",e)],Ut=e=>[Yt("lockSensor","vehicleCard.lockSensor",e),Yt("windowsClosed","vehicleCard.windowsClosed",e),Yt("doorStatusOverall","vehicleCard.doorStatusOverall",e,"mdi:car-door-lock"),Yt("parkBrake","vehicleCard.parkBrake",e),Yt("ignitionState","vehicleCard.ignitionState",e)],Kt=e=>[Yt("starterBatteryState","vehicleCard.starterBatteryState",e),Yt("lowCoolantLevel","vehicleCard.lowCoolantLevel",e,"mdi:car-coolant-level"),Yt("lowBrakeFluid","vehicleCard.lowBrakeFluid",e,"mdi:car-brake-fluid-level"),Yt("lowWashWater","vehicleCard.lowWashWater",e),Yt("tirePressureWarning","vehicleCard.tirePressureWarning",e)],Jt=e=>[Yt("ecoScoreBonusRange","ecoCard.ecoScoreBonusRange",e,void 0,"bonusRange"),Yt("ecoScoreAcceleraion","ecoCard.ecoScoreAcceleraion",e,void 0,"acceleration"),Yt("ecoScoreConstant","ecoCard.ecoScoreConstant",e,void 0,"constant"),Yt("ecoScoreFreeWheel","ecoCard.ecoScoreFreeWheel",e,void 0,"freeWheel")],_t=e=>[Yt("tirePressureFrontLeft","tyreCard.tirePressureFrontLeft",e,"mdi:tire"),Yt("tirePressureFrontRight","tyreCard.tirePressureFrontRight",e,"mdi:tire"),Yt("tirePressureRearLeft","tyreCard.tirePressureRearLeft",e,"mdi:tire"),Yt("tirePressureRearRight","tyreCard.tirePressureRearRight",e,"mdi:tire")],$t=e=>[Yt("chargingPower","chargingOverview.chargingPower",e,"mdi:flash"),Yt("soc","chargingOverview.soc",e),Yt("maxSoc","chargingOverview.maxSoc",e),Yt("selectedProgram","chargingOverview.selectedProgram",e,"mdi:ev-station")],ei=["tirePressureFrontRight","tirePressureFrontRight","tirePressureRearLeft","tirePressureRearRight"],ti=["lockAttributesVisible","windowAttributesVisible","doorsAttributesVisible","tripFromResetVisible","tripFromStartVisible","ecoScoresVisible"],ii=(e,t,i)=>({state:{false:Xt(e,i),true:Xt(t,i)}}),ai=(e,t,i,a)=>Object.assign({name:Xt(e,a)},ii(t,i,a)),ni=(e,t,i)=>({name:Xt(e,i),state:Object.keys(t).reduce(((e,a)=>(e[a]=Xt(t[a],i),e)),{})}),ri=e=>({0:Xt("card.common.stateOpen",e),1:Xt("card.common.stateClosed",e),2:Xt("card.common.stateNotExisting",e),3:Xt("card.common.stateUnknown",e)}),si=ri,oi=e=>({0:Xt("card.common.stateUnlocked",e),1:Xt("card.common.stateLockedInt",e),2:Xt("card.common.stateLocked",e),3:Xt("card.common.statePartlyUnlocked",e),4:Xt("card.common.stateUnknown",e)}),li=e=>({0:"Standard",1:Xt("card.common.stateUnknown",e),2:"Home",3:"Work"}),ci=e=>({0:Xt("card.starterBattery.stateOk",e),1:Xt("card.starterBattery.partlyCharged",e),2:Xt("card.starterBattery.notAvailable",e),3:Xt("card.starterBattery.remoteServiceDisabled",e),4:Xt("card.starterBattery.vehicleNoLongerAvailable",e)}),di=e=>({doorlockstatusfrontleft:ai("card.lockAttributes.doorlockstatusfrontleft","card.common.stateLocked","card.common.stateUnlocked",e),doorlockstatusfrontright:ai("card.lockAttributes.doorlockstatusfrontright","card.common.stateLocked","card.common.stateUnlocked",e),doorlockstatusrearleft:ai("card.lockAttributes.doorlockstatusrearleft","card.common.stateLocked","card.common.stateUnlocked",e),doorlockstatusrearright:ai("card.lockAttributes.doorlockstatusrearright","card.common.stateLocked","card.common.stateUnlocked",e),doorlockstatusgas:ai("card.lockAttributes.doorlockstatusgas","card.common.stateLocked","card.common.stateUnlocked",e)}),hi=e=>({decklidstatus:ai("card.doorAttributes.decklidstatus","card.common.stateClosed","card.common.stateOpen",e),doorstatusfrontleft:ai("card.doorAttributes.doorstatusfrontleft","card.common.stateClosed","card.common.stateOpen",e),doorstatusfrontright:ai("card.doorAttributes.doorstatusfrontright","card.common.stateClosed","card.common.stateOpen",e),doorstatusrearleft:ai("card.doorAttributes.doorstatusrearleft","card.common.stateClosed","card.common.stateOpen",e),doorstatusrearright:ai("card.doorAttributes.doorstatusrearright","card.common.stateClosed","card.common.stateOpen",e),enginehoodstatus:ai("card.doorAttributes.enginehoodstatus","card.common.stateClosed","card.common.stateOpen",e),sunroofstatus:ni("card.doorAttributes.sunroofstatus",{0:"card.sunroofState.stateClosed",1:"card.sunroofState.stateOpen",2:"card.sunroofState.liftingOpen",3:"card.sunroofState.running",4:"card.sunroofState.antiBoomingPosition",5:"card.sunroofState.slidingIntermediate",6:"card.sunroofState.liftingIntermediate",7:"card.sunroofState.opening",8:"card.sunroofState.closing",9:"card.sunroofState.antiBoomingLifting",10:"card.sunroofState.intermediatePosition",11:"card.sunroofState.openingLifting",12:"card.sunroofState.closingLifting"},e)}),ui=oi,pi=ci,fi=li,gi=(e,t)=>ni(e,{2:"card.common.stateClosed",0:"card.common.stateOpen"},t),mi=e=>({windowstatusrearleft:gi("card.windowAttributes.windowstatusrearleft",e),windowstatusrearright:gi("card.windowAttributes.windowstatusrearright",e),windowstatusfrontleft:gi("card.windowAttributes.windowstatusfrontleft",e),windowstatusfrontright:gi("card.windowAttributes.windowstatusfrontright",e),windowstatusrearleftblind:gi("card.windowAttributes.windowstatusrearleftblind",e),windowstatusrearrightblind:gi("card.windowAttributes.windowstatusrearrightblind",e),windowstatusfrontleftblind:gi("card.windowAttributes.windowstatusfrontleftblind",e),windowstatusfrontrightblind:gi("card.windowAttributes.windowstatusfrontrightblind",e)}),vi="",bi="",xi="",yi="";function wi(e,t){void 0===t&&(t={});var i=t.insertAt;if(e&&"undefined"!=typeof document){var a=document.head||document.getElementsByTagName("head")[0],n=document.createElement("style");n.type="text/css","top"===i&&a.firstChild?a.insertBefore(n,a.firstChild):a.appendChild(n),n.styleSheet?n.styleSheet.cssText=e:n.appendChild(document.createTextNode(e))}}var Ai=o`:host {
- --vic-gutter-gap: 8px;
- --vic-card-padding: 12px;
- --vic-icon-size: 36px;
- --vic-icon-border-radius: 50%;
- --vic-icon-shape-color: rgba(var(--rgb-primary-text-color), 0.05);
-}
-*:focus {
- outline: none;
-}
-
-ha-card {
- position: relative;
- overflow: hidden;
- display: block;
- width: 100%;
- height: auto;
- padding: var(--vic-card-padding);
- background-color: var(--card-background-color);
-}
-
-/* ha-card.--dark {
- background-color: #0c0c0c;
-} */
-
-header h1 {
- color: --primary-text-color;
- color: var(--ha-card-header-color, --primary-text-color);
- font-family: serif !important;
- font-size: 24px;
- font-size: var(--ha-card-header-font-size, 24px);
- letter-spacing: -0.012em;
- line-height: 48px;
- display: block;
- margin-top: 0px;
- margin-bottom: 0px;
- font-weight: 400;
- text-align: center;
-}
-
-.header-background {
- display: flex;
- justify-content: center;
- align-items: center;
- position: absolute;
- width: 100%;
- height: 100%;
- max-height: 250px;
- top: 0px;
- left: 50%;
- opacity: 0.1;
- z-index: 0;
- -webkit-mask-image: linear-gradient(transparent 0%, black 40%, black 70%, transparent 100%);
- mask-image: linear-gradient(transparent 0%, black 40%, black 70%, transparent 100%);
- transform: translate(-50%);
- background-size: contain;
- background-repeat: no-repeat;
- background-position: center;
-}
-
-#map-box {
- position: relative;
- width: 100%;
- height: 150px;
- margin: 0;
- padding: 0;
- overflow: hidden;
-}
-
-.header-info-box {
- display: flex;
- justify-content: center;
- align-items: center;
- position: relative;
- width: 100%;
- height: -moz-fit-content;
- height: fit-content;
- overflow: hidden;
- gap: var(--vic-gutter-gap);
- flex-wrap: wrap;
- transition: all 0.5s ease;
- margin-bottom: var(--vic-gutter-gap);
-}
-
-.info-box {
- --mdc-icon-size: 17px;
- display: flex;
- justify-content: center;
- align-items: center;
- position: relative;
- width: 100%;
- height: -moz-fit-content;
- height: fit-content;
- gap: var(--vic-gutter-gap);
- flex-wrap: wrap;
- /* opacity: 0.8; */
- /* text-transform: capitalize; */
-}
-
-.info-box .item {
- display: flex;
- align-items: center;
- gap: 0.4rem;
-}
-
-.info-box .item ha-icon {
- margin-bottom: 3px;
- }
-
-@media screen and (max-width: 768px) {
- ha-card {
- padding: 0.5rem;
- }
- .info-box .item .base-menu {
- font-size: 0.8rem;
- }
-}
-
-.added-item-arrow {
- display: flex;
-}
-
-.item.active-btn {
- cursor: pointer;
-}
-
-.info-box.charge {
- overflow: hidden;
- justify-content: space-evenly;
- max-height: 0;
- opacity: 0;
- transition: all 0.5s ease-in-out;
-}
-
-.info-box.charge.active {
- max-height: 100px; /* Adjust this to be more than the expected height of the content */
- opacity: 1;
- padding-top: 0.5rem;
- padding-bottom: 0.5rem;
-}
-
-.info-box.charge .item {
- display: flex;
- align-items: center;
- flex-wrap: wrap;
- flex-direction: column;
- gap: initial;
- width: -moz-max-content;
- width: max-content;
-}
-
-.info-box.charge .item-name {
- color: var(--secondary-text-color);
-}
-
-.fuel-wrapper {
- display: inline-block;
- width: 40%;
- height: 5px;
- background-color: #909090;
- border-radius: 5px;
- position: relative;
-}
-
-.fuel-wrapper .fuel-level-bar {
- position: absolute;
- background-color: #4caf50;
- border-radius: 5px;
- transition: width 0.5s ease;
- height: 5px;
- }
-
-.grid-container {
- display: grid;
- grid-template-columns: repeat(2, minmax(140px, 1fr));
- grid-gap: var(--vic-gutter-gap);
- gap: var(--vic-gutter-gap);
- /* margin-top: 1rem; */
- position: relative;
-}
-
-.grid-item {
- display: flex;
- position: relative;
- gap: var(--vic-card-padding);
- padding: var(--vic-gutter-gap) var(--vic-card-padding);
- height: 100%;
- flex-direction: row;
- align-items: center;
- background: #fff;
- background: var(--secondary-background-color, var(--card-background-color, #fff));
- box-shadow: none;
- box-shadow: var(--ha-card-box-shadow, none);
- box-sizing: border-box;
- border-radius: 12px;
- border-radius: var(--ha-card-border-radius, 12px);
- border-width: 1px;
- border-width: var(--ha-card-border-width, 1px);
- border-style: solid;
- border-color: #e0e0e0;
- border-color: var(--ha-card-border-color, var(--divider-color, #e0e0e0));
- transition: all 0.3s ease-out;
- opacity: 1;
- cursor: pointer;
-}
-
-.grid-item:hover {
- box-shadow: 0 0 8px 0 rgba(0, 0, 0, 0.3);
- }
-/* @media screen and (max-width: 768px) {
- .grid-item {
- padding: 8px;
- gap: 0.5rem;
- }
-} */
-.grid-item .item-notify {
- display: flex;
- position: absolute;
- top: -4px;
- right: -8px;
- /* opacity: 0.8; */
- color: #db4437;
- color: var(--error-color, #db4437);
- --mdc-icon-size: 1.4rem;
-}
-.grid-item .item-notify.hidden {
- display: none;
-}
-
-/* .grid-item .item-icon {
- display: inline-block;
- border-radius: 50% 50%;
- background-color: var(--chip-background-color);
- padding: 0.5rem;
-} */
-
-.grid-item .item-icon {
- position: relative;
- display: block;
- --mdc-icon-size: 22px;
-}
-
-.item-icon .icon-background {
- position: relative;
- width: var(--vic-icon-size);
- height: var(--vic-icon-size);
- font-size: var(--vic-icon-size);
- border-radius: var(--vic-icon-border-radius);
- display: flex;
- align-items: center;
- justify-content: center;
- background-color: var(--vic-icon-shape-color);
- transition-property: background-color, box-shadow;
- transition-duration: 280ms;
- transition-timing-function: ease-out;
-}
-.grid-item .item-content {
- display: flex;
- flex-direction: column;
- min-width: 0;
- overflow: hidden;
-}
-.grid-item .item-content .primary {
- font-weight: 500;
- font-size: 1rem;
- white-space: nowrap;
- position: relative;
- text-overflow: ellipsis;
- overflow: hidden;
- }
-.grid-item .item-content .secondary {
- color: var(--secondary-text-color);
- /* text-transform: capitalize; */
- letter-spacing: 0.5px;
- font-size: smaller;
- text-wrap: nowrap;
- }
-
-.primary.title-wrap {
- position: relative;
- width: 100%;
- height: 100%;
- display: block;
- left: 0;
- top: 0;
-}
-
-.primary.title-wrap::after {
- content: '';
- position: absolute;
- bottom: 0;
- left: -15px;
- width: 40%;
- height: 100%;
- background-image: linear-gradient(
- to left,
- transparent 0,
- #fff 100%
- );
- background-image: linear-gradient(
- to left,
- transparent 0,
- var(--secondary-background-color, var(--card-background-color, #fff)) 100%
- );
-}
-
-.marquee {
- display: inline-block;
- animation: marquee 6s linear 1s infinite;
- overflow: visible !important;
- animation-iteration-count: 3;
- /* left: 100%; */
-}
-
-@keyframes marquee {
- 0% {
- transform: translateX(0%);
- }
- 50% {
- transform: translateX(-50%);
- }
- 100% {
- transform: translateX(0%);
- }
-}
-
-.added-card-header {
- display: flex;
- justify-content: space-between;
- align-items: center;
- margin-bottom: 1rem;
-}
-.added-card-header .headder-btn {
- cursor: pointer;
- color: var(--secondary-text-color);
- opacity: 0.5;
- transition: opacity 0.3s;
-}
-.added-card-header .headder-btn:hover {
- opacity: 1;
- }
-
-.added-card-header .card-toggle {
- display: flex;
- gap: 1rem;
-}
-
-.added-card {
- position: relative;
- width: 100%;
- height: auto;
- margin-top: 1rem;
- padding: 0;
- overflow: hidden;
-}
-
-.added-card:first-child {
- margin-top: 0;
-}
-
-.last-update {
- display: inline-flex;
- width: 100%;
- justify-content: center;
- color: var(--secondary-text-color);
- margin-top: 0.5rem;
- opacity: 0.5;
- font-size: 0.8rem;
-}
-#cards-wrapper {
- animation: fadeIn 0.5s ease-in-out;
- position: relative;
-}
-#main-wrapper {
- animation: fadeIn 0.3s ease;
- position: relative;
-}
-
-.card-element {
- transition: all 0.5s ease;
- position: relative;
-}
-
-/* .card-element.swiping-left {
- transform: translateX(-120%);
-} */
-
-/* .card-element.swiping-right {
- transform: translateX(120%);
-} */
-
-.slide-left-enter {
- transform: translateX(100%);
-}
-
-.slide-left-enter-active {
- transform: translateX(0);
-}
-
-.slide-left-exit {
- transform: translateX(0);
-}
-
-.slide-left-exit-active {
- transform: translateX(-100%);
-}
-
-.slide-right-enter {
- transform: translateX(-100%);
-}
-
-.slide-right-enter-active {
- transform: translateX(0);
-}
-
-.slide-right-exit {
- transform: translateX(0);
-}
-
-.slide-right-exit-active {
- transform: translateX(100%);
-}
-@keyframes fadeIn {
- from {
- opacity: 0;
- }
- to {
- opacity: 1;
- }
-}
-
-.default-card {
- align-items: center;
- padding: var(--vic-card-padding);
- background: var(--ha-card-background-color, var(--secondary-background-color));
- box-shadow: none;
- box-shadow: var(--ha-card-box-shadow, none);
- box-sizing: border-box;
- border-radius: 12px;
- border-radius: var(--ha-card-border-radius, 12px);
- border-width: 1px;
- border-width: var(--ha-card-border-width, 1px);
- border-style: solid;
- border-color: #e0e0e0;
- border-color: var(--ha-card-border-color, var(--divider-color, #e0e0e0));
- transition: all 0.3s ease-out;
- margin-bottom: 1rem;
- position: relative;
-}
-
-.default-card:not(:first-child) {
- animation: slideUpDown 0.3s linear;
-}
-
-@keyframes slideUpDown {
- 0% {
- transform: translateY(-100%);
- }
- 100% {
- transform: translateY(0);
- }
-}
-
-.default-card:last-child {
- margin-bottom: 0;
-}
-
-.default-card .data-header {
- color: --primary-text-color;
- color: var(--ha-card-header-color, --primary-text-color);
- font-family: inherit;
- font-family: var(--ha-card-header-font-family, inherit);
- font-size: 1.5rem;
- line-height: inherit;
- display: flex;
- justify-content: space-between;
- align-items: center;
- cursor: auto;
- /* padding: 8px 0; */
-}
-
-.default-card .data-box {
- opacity: 1;
- padding-top: var(--vic-gutter-gap);
- max-height: 1000px;
- transition: all 0.3s ease-in-out;
-}
-
-.default-card .data-box.hidden {
- opacity: 0;
- max-height: 0;
- overflow: hidden;
- padding: 0;
-}
-
-.default-card.remote-tab {
- border: none !important;
- background: none !important;
- padding: 0px;
-}
-.data-row {
- display: flex;
- justify-content: space-between;
- padding: var(--vic-gutter-gap);
- border-bottom: 1px solid #444;
-}
-
-.data-row .data-value-unit {
- cursor: pointer;
-}
-
-.data-row > div > span {
- height: 100%;
- display: flex;
- align-items: flex-end;
- margin-left: 8px;
-}
-
-.data-row:last-child {
- border-bottom: none;
- padding-bottom: 0;
-}
-.data-row div {
- display: flex;
- align-items: center;
- gap: var(--vic-gutter-gap);
-}
-.data-icon {
- color: var(--secondary-text-color);
-}
-
-.data-icon.warning,
-.warning {
- color: --error-color !important;
- color: var(--warning-color, --error-color) !important;
-}
-
-.subcard-icon {
- transition: transform 0.3s;
- transform: rotate(0deg);
- display: inline-block;
- cursor: pointer;
-}
-
-.subcard-icon.active {
- transform: rotate(180deg);
-}
-
-.subcard-icon.hidden {
- visibility: hidden;
-}
-
-.sub-attributes {
- overflow: hidden;
- padding-top: 0px !important;
- max-height: 0;
- opacity: 0;
- transition: all 0.5s ease-in-out;
-}
-
-.sub-attributes.active {
- max-height: 1000px;
- opacity: 1;
- padding: var(--vic-card-padding);
-}
-
-.error {
- color: var(--error-color);
-}
-
-dialog {
- width: 100%;
- overflow: hidden;
- max-width: 500px;
- background: none;
- border: none;
- border-radius: 12px;
-}
-
-dialog::backdrop {
- background: rgba(0, 0, 0, 0.5);
- -webkit-backdrop-filter: blur(5px);
- backdrop-filter: blur(5px);
-}
-
-@keyframes slideUpDown {
- 0% {
- transform: translateY(-100%);
- }
- 100% {
- transform: translateY(0);
- }
-}
-
-@keyframes tap-feedback {
- 0% {
- transform: translateX(-50%);
- }
- 100% {
- transform: translateX(100%);
- }
-}
-
-.click-shrink {
- transition: transform 0.1s;
-}
-
-.click-shrink:active {
- transform: scale(0.9);
-}
-
-.tyre-wrapper {
- position: relative;
- width: 100%;
- height: 100%;
- aspect-ratio: 1;
- transition: all 0.5s ease-in-out;
-}
-
-.tyre-toggle-btn {
- position: absolute;
- top: 0;
- right: 0;
- z-index: 2;
- padding: var(--vic-card-padding);
- opacity: 0.5;
- cursor: pointer;
- transition: opacity 0.3s;
-}
-
-.tyre-toggle-btn:hover {
- opacity: 1;
- }
-
-/* TYRE WRAP ROTATED */
-.tyre-wrapper.rotated {
- transform: rotate(90deg);
-}
-
-.tyre-box.rotated {
- transform: rotate(-90deg);
-}
-
-.tyre-wrapper .background {
- position: absolute;
- width: 100%;
- height: 100%;
- z-index: 0;
- top: 50%;
- left: 50%;
- transform: translate(-50%, -50%);
- background-size: cover;
- background-repeat: no-repeat;
- overflow: hidden;
- filter: drop-shadow(2px 4px 1rem rgba(0,0,0,0.84706));
-}
-
-.tyre-wrapper .tyre-box {
- position: absolute;
- width: 30%;
- height: 60%;
- z-index: 1;
- display: flex;
- align-items: center;
- flex-direction: column;
- justify-content: center;
- gap: 0.5rem;
- text-shadow: 0 1px 0 rgba(255, 255, 255, 0.3);
- transition: all 0.5s ease-in-out;
-}
-
-.tyre-value {
- font-size: 1.5rem;
- color: var(--primary-text-color);
- text-align: center;
- margin: 0;
-}
-.tyre-name {
- color: var(--secondary-text-color);
- text-align: left;
- margin: 0;
- text-transform: uppercase;
- letter-spacing: 1.5px;
- text-wrap: nowrap;
-}
-.tyre-info {
- display: flex;
- justify-content: center;
- align-items: center;
- gap: 0.5rem;
- font-size: 0.9rem;
- color: var(--secondary-text-color);
- text-align: center;
-}
-
-.frontleft {
- top: 0%;
- left: 0%;
- /* transform: translate(-15%, -10%); */
-}
-
-.frontright {
- top: 0%;
- right: 0%;
- /* transform: translate(15%, -10%); */
-}
-
-.rearleft {
- bottom: 0%;
- left: 0%;
- /* transform: translate(-15%, 10%); */
-}
-
-.rearright {
- bottom: 0%;
- right: 0%;
- /* transform: translate(15%, 10%); */
-}
-
-.loading-image {
- display: flex;
- justify-content: center;
- align-items: center;
-}
-
-.loading-image img {
- width: 100px; /* Adjust size as needed */
- height: 100px; /* Adjust size as needed */
- -o-object-fit: cover;
- object-fit: cover;
- animation: zoomRotate 2s linear infinite;
-}
-
-@keyframes zoomRotate {
- 0% {
- transform: scale(0) rotate(0deg);
- opacity: 0;
- }
- 50% {
- transform: scale(1) rotate(180deg);
- opacity: 0.7;
- }
- 100% {
- transform: scale(0) rotate(360deg);
- opacity: 0;
- }
-}
-`;wi(Ai);var Ci="undefined"!=typeof globalThis?globalThis:"undefined"!=typeof window?window:"undefined"!=typeof global?global:"undefined"!=typeof self?self:{};function zi(e,t){return e(t={exports:{}},t.exports),t.exports}var Pi=zi((function(e,t){
-/* @preserve
- * Leaflet 1.9.4, a JS library for interactive maps. https://leafletjs.com
- * (c) 2010-2023 Vladimir Agafonkin, (c) 2010-2011 CloudMade
- */
-!function(e){var t="1.9.4";function i(e){var t,i,a,n;for(i=1,a=arguments.length;i0?Math.floor(e):Math.ceil(e)};function R(e,t,i){return e instanceof B?e:v(e)?new B(e[0],e[1]):null==e?e:"object"==typeof e&&"x"in e&&"y"in e?new B(e.x,e.y):new B(e,t,i)}function D(e,t){if(e)for(var i=t?[e,t]:e,a=0,n=i.length;a=this.min.x&&i.x<=this.max.x&&t.y>=this.min.y&&i.y<=this.max.y},intersects:function(e){e=q(e);var t=this.min,i=this.max,a=e.min,n=e.max,r=n.x>=t.x&&a.x<=i.x,s=n.y>=t.y&&a.y<=i.y;return r&&s},overlaps:function(e){e=q(e);var t=this.min,i=this.max,a=e.min,n=e.max,r=n.x>t.x&&a.xt.y&&a.y=a.lat&&i.lat<=n.lat&&t.lng>=a.lng&&i.lng<=n.lng},intersects:function(e){e=N(e);var t=this._southWest,i=this._northEast,a=e.getSouthWest(),n=e.getNorthEast(),r=n.lat>=t.lat&&a.lat<=i.lat,s=n.lng>=t.lng&&a.lng<=i.lng;return r&&s},overlaps:function(e){e=N(e);var t=this._southWest,i=this._northEast,a=e.getSouthWest(),n=e.getNorthEast(),r=n.lat>t.lat&&a.latt.lng&&a.lng1,Me=function(){var e=!1;try{var t=Object.defineProperty({},"passive",{get:function(){e=!0}});window.addEventListener("testPassiveEventSupport",c,t),window.removeEventListener("testPassiveEventSupport",c,t)}catch(e){}return e}(),Oe=!!document.createElement("canvas").getContext,Le=!(!document.createElementNS||!K("svg").createSVGRect),Ie=!!Le&&((_=document.createElement("div")).innerHTML=" ","http://www.w3.org/2000/svg"===(_.firstChild&&_.firstChild.namespaceURI)),Be=!Le&&function(){try{var e=document.createElement("div");e.innerHTML=' ';var t=e.firstChild;return t.style.behavior="url(#default#VML)",t&&"object"==typeof t.adj}catch(e){return!1}}(),Ve=0===navigator.platform.indexOf("Mac"),Re=0===navigator.platform.indexOf("Linux");function De(e){return navigator.userAgent.toLowerCase().indexOf(e)>=0}var qe={ie:ee,ielt9:te,edge:ie,webkit:ae,android:ne,android23:re,androidStock:oe,opera:le,chrome:ce,gecko:de,safari:he,phantom:ue,opera12:pe,win:fe,ie3d:ge,webkit3d:me,gecko3d:ve,any3d:be,mobile:xe,mobileWebkit:ye,mobileWebkit3d:we,msPointer:Ae,pointer:Ce,touch:Pe,touchNative:ze,mobileOpera:Se,mobileGecko:ke,retina:Ee,passiveEvents:Me,canvas:Oe,svg:Le,vml:Be,inlineSvg:Ie,mac:Ve,linux:Re},Te=qe.msPointer?"MSPointerDown":"pointerdown",Ne=qe.msPointer?"MSPointerMove":"pointermove",Xe=qe.msPointer?"MSPointerUp":"pointerup",je=qe.msPointer?"MSPointerCancel":"pointercancel",Fe={touchstart:Te,touchmove:Ne,touchend:Xe,touchcancel:je},We={touchstart:$e,touchmove:_e,touchend:_e,touchcancel:_e},He={},Ye=!1;function Ge(e,t,i){return"touchstart"===t&&Je(),We[t]?(i=We[t].bind(this,i),e.addEventListener(Fe[t],i,!1),i):(console.warn("wrong event specified:",t),c)}function Ze(e,t,i){Fe[t]?e.removeEventListener(Fe[t],i,!1):console.warn("wrong event specified:",t)}function Qe(e){He[e.pointerId]=e}function Ue(e){He[e.pointerId]&&(He[e.pointerId]=e)}function Ke(e){delete He[e.pointerId]}function Je(){Ye||(document.addEventListener(Te,Qe,!0),document.addEventListener(Ne,Ue,!0),document.addEventListener(Xe,Ke,!0),document.addEventListener(je,Ke,!0),Ye=!0)}function _e(e,t){if(t.pointerType!==(t.MSPOINTER_TYPE_MOUSE||"mouse")){for(var i in t.touches=[],He)t.touches.push(He[i]);t.changedTouches=[t],e(t)}}function $e(e,t){t.MSPOINTER_TYPE_TOUCH&&t.pointerType===t.MSPOINTER_TYPE_TOUCH&&Qt(t),_e(e,t)}function et(e){var t,i,a={};for(i in e)t=e[i],a[i]=t&&t.bind?t.bind(e):t;return e=a,a.type="dblclick",a.detail=2,a.isTrusted=!1,a._simulated=!0,a}var tt=200;function it(e,t){e.addEventListener("dblclick",t);var i,a=0;function n(e){if(1===e.detail){if("mouse"!==e.pointerType&&(!e.sourceCapabilities||e.sourceCapabilities.firesTouchEvents)){var n=Kt(e);if(!n.some((function(e){return e instanceof HTMLLabelElement&&e.attributes.for}))||n.some((function(e){return e instanceof HTMLInputElement||e instanceof HTMLSelectElement}))){var r=Date.now();r-a<=tt?2==++i&&t(et(e)):i=1,a=r}}}else i=e.detail}return e.addEventListener("click",n),{dblclick:t,simDblclick:n}}function at(e,t){e.removeEventListener("dblclick",t.dblclick),e.removeEventListener("click",t.simDblclick)}var nt,rt,st,ot,lt,ct=St(["transform","webkitTransform","OTransform","MozTransform","msTransform"]),dt=St(["webkitTransition","transition","OTransition","MozTransition","msTransition"]),ht="webkitTransition"===dt||"OTransition"===dt?dt+"End":"transitionend";function ut(e){return"string"==typeof e?document.getElementById(e):e}function pt(e,t){var i=e.style[t]||e.currentStyle&&e.currentStyle[t];if((!i||"auto"===i)&&document.defaultView){var a=document.defaultView.getComputedStyle(e,null);i=a?a[t]:null}return"auto"===i?null:i}function ft(e,t,i){var a=document.createElement(e);return a.className=t||"",i&&i.appendChild(a),a}function gt(e){var t=e.parentNode;t&&t.removeChild(e)}function mt(e){for(;e.firstChild;)e.removeChild(e.firstChild)}function vt(e){var t=e.parentNode;t&&t.lastChild!==e&&t.appendChild(e)}function bt(e){var t=e.parentNode;t&&t.firstChild!==e&&t.insertBefore(e,t.firstChild)}function xt(e,t){if(void 0!==e.classList)return e.classList.contains(t);var i=Ct(e);return i.length>0&&new RegExp("(^|\\s)"+t+"(\\s|$)").test(i)}function yt(e,t){if(void 0!==e.classList)for(var i=u(t),a=0,n=i.length;a0?2*window.devicePixelRatio:1;function $t(e){return qe.edge?e.wheelDeltaY/2:e.deltaY&&0===e.deltaMode?-e.deltaY/_t:e.deltaY&&1===e.deltaMode?20*-e.deltaY:e.deltaY&&2===e.deltaMode?60*-e.deltaY:e.deltaX||e.deltaZ?0:e.wheelDelta?(e.wheelDeltaY||e.wheelDelta)/2:e.detail&&Math.abs(e.detail)<32765?20*-e.detail:e.detail?e.detail/-32765*60:0}function ei(e,t){var i=t.relatedTarget;if(!i)return!0;try{for(;i&&i!==e;)i=i.parentNode}catch(e){return!1}return i!==e}var ti={__proto__:null,on:Tt,off:Xt,stopPropagation:Yt,disableScrollPropagation:Gt,disableClickPropagation:Zt,preventDefault:Qt,stop:Ut,getPropagationPath:Kt,getMousePosition:Jt,getWheelDelta:$t,isExternalTarget:ei,addListener:Tt,removeListener:Xt},ii=I.extend({run:function(e,t,i,a){this.stop(),this._el=e,this._inProgress=!0,this._duration=i||.25,this._easeOutPower=1/Math.max(a||.5,.2),this._startPos=Mt(e),this._offset=t.subtract(this._startPos),this._startTime=+new Date,this.fire("start"),this._animate()},stop:function(){this._inProgress&&(this._step(!0),this._complete())},_animate:function(){this._animId=P(this._animate,this),this._step()},_step:function(e){var t=+new Date-this._startTime,i=1e3*this._duration;tthis.options.maxZoom)?this.setZoom(e):this},panInsideBounds:function(e,t){this._enforcingBounds=!0;var i=this.getCenter(),a=this._limitCenter(i,this._zoom,N(e));return i.equals(a)||this.panTo(a,t),this._enforcingBounds=!1,this},panInside:function(e,t){var i=R((t=t||{}).paddingTopLeft||t.padding||[0,0]),a=R(t.paddingBottomRight||t.padding||[0,0]),n=this.project(this.getCenter()),r=this.project(e),s=this.getPixelBounds(),o=q([s.min.add(i),s.max.subtract(a)]),l=o.getSize();if(!o.contains(r)){this._enforcingBounds=!0;var c=r.subtract(o.getCenter()),d=o.extend(r).getSize().subtract(l);n.x+=c.x<0?-d.x:d.x,n.y+=c.y<0?-d.y:d.y,this.panTo(this.unproject(n),t),this._enforcingBounds=!1}return this},invalidateSize:function(e){if(!this._loaded)return this;e=i({animate:!1,pan:!0},!0===e?{animate:!0}:e);var t=this.getSize();this._sizeChanged=!0,this._lastCenter=null;var a=this.getSize(),r=t.divideBy(2).round(),s=a.divideBy(2).round(),o=r.subtract(s);return o.x||o.y?(e.animate&&e.pan?this.panBy(o):(e.pan&&this._rawPanBy(o),this.fire("move"),e.debounceMoveend?(clearTimeout(this._sizeTimer),this._sizeTimer=setTimeout(n(this.fire,this,"moveend"),200)):this.fire("moveend")),this.fire("resize",{oldSize:t,newSize:a})):this},stop:function(){return this.setZoom(this._limitZoom(this._zoom)),this.options.zoomSnap||this.fire("viewreset"),this._stop()},locate:function(e){if(e=this._locateOptions=i({timeout:1e4,watch:!1},e),!("geolocation"in navigator))return this._handleGeolocationError({code:0,message:"Geolocation not supported."}),this;var t=n(this._handleGeolocationResponse,this),a=n(this._handleGeolocationError,this);return e.watch?this._locationWatchId=navigator.geolocation.watchPosition(t,a,e):navigator.geolocation.getCurrentPosition(t,a,e),this},stopLocate:function(){return navigator.geolocation&&navigator.geolocation.clearWatch&&navigator.geolocation.clearWatch(this._locationWatchId),this._locateOptions&&(this._locateOptions.setView=!1),this},_handleGeolocationError:function(e){if(this._container._leaflet_id){var t=e.code,i=e.message||(1===t?"permission denied":2===t?"position unavailable":"timeout");this._locateOptions.setView&&!this._loaded&&this.fitWorld(),this.fire("locationerror",{code:t,message:"Geolocation error: "+i+"."})}},_handleGeolocationResponse:function(e){if(this._container._leaflet_id){var t=new X(e.coords.latitude,e.coords.longitude),i=t.toBounds(2*e.coords.accuracy),a=this._locateOptions;if(a.setView){var n=this.getBoundsZoom(i);this.setView(t,a.maxZoom?Math.min(n,a.maxZoom):n)}var r={latlng:t,bounds:i,timestamp:e.timestamp};for(var s in e.coords)"number"==typeof e.coords[s]&&(r[s]=e.coords[s]);this.fire("locationfound",r)}},addHandler:function(e,t){if(!t)return this;var i=this[e]=new t(this);return this._handlers.push(i),this.options[e]&&i.enable(),this},remove:function(){if(this._initEvents(!0),this.options.maxBounds&&this.off("moveend",this._panInsideMaxBounds),this._containerId!==this._container._leaflet_id)throw new Error("Map container is being reused by another instance");try{delete this._container._leaflet_id,delete this._containerId}catch(e){this._container._leaflet_id=void 0,this._containerId=void 0}var e;for(e in void 0!==this._locationWatchId&&this.stopLocate(),this._stop(),gt(this._mapPane),this._clearControlPos&&this._clearControlPos(),this._resizeRequest&&(S(this._resizeRequest),this._resizeRequest=null),this._clearHandlers(),this._loaded&&this.fire("unload"),this._layers)this._layers[e].remove();for(e in this._panes)gt(this._panes[e]);return this._layers=[],this._panes=[],delete this._mapPane,delete this._renderer,this},createPane:function(e,t){var i=ft("div","leaflet-pane"+(e?" leaflet-"+e.replace("Pane","")+"-pane":""),t||this._mapPane);return e&&(this._panes[e]=i),i},getCenter:function(){return this._checkIfLoaded(),this._lastCenter&&!this._moved()?this._lastCenter.clone():this.layerPointToLatLng(this._getCenterLayerPoint())},getZoom:function(){return this._zoom},getBounds:function(){var e=this.getPixelBounds();return new T(this.unproject(e.getBottomLeft()),this.unproject(e.getTopRight()))},getMinZoom:function(){return void 0===this.options.minZoom?this._layersMinZoom||0:this.options.minZoom},getMaxZoom:function(){return void 0===this.options.maxZoom?void 0===this._layersMaxZoom?1/0:this._layersMaxZoom:this.options.maxZoom},getBoundsZoom:function(e,t,i){e=N(e),i=R(i||[0,0]);var a=this.getZoom()||0,n=this.getMinZoom(),r=this.getMaxZoom(),s=e.getNorthWest(),o=e.getSouthEast(),l=this.getSize().subtract(i),c=q(this.project(o,a),this.project(s,a)).getSize(),d=qe.any3d?this.options.zoomSnap:1,h=l.x/c.x,u=l.y/c.y,p=t?Math.max(h,u):Math.min(h,u);return a=this.getScaleZoom(p,a),d&&(a=Math.round(a/(d/100))*(d/100),a=t?Math.ceil(a/d)*d:Math.floor(a/d)*d),Math.max(n,Math.min(r,a))},getSize:function(){return this._size&&!this._sizeChanged||(this._size=new B(this._container.clientWidth||0,this._container.clientHeight||0),this._sizeChanged=!1),this._size.clone()},getPixelBounds:function(e,t){var i=this._getTopLeftPoint(e,t);return new D(i,i.add(this.getSize()))},getPixelOrigin:function(){return this._checkIfLoaded(),this._pixelOrigin},getPixelWorldBounds:function(e){return this.options.crs.getProjectedBounds(void 0===e?this.getZoom():e)},getPane:function(e){return"string"==typeof e?this._panes[e]:e},getPanes:function(){return this._panes},getContainer:function(){return this._container},getZoomScale:function(e,t){var i=this.options.crs;return t=void 0===t?this._zoom:t,i.scale(e)/i.scale(t)},getScaleZoom:function(e,t){var i=this.options.crs;t=void 0===t?this._zoom:t;var a=i.zoom(e*i.scale(t));return isNaN(a)?1/0:a},project:function(e,t){return t=void 0===t?this._zoom:t,this.options.crs.latLngToPoint(j(e),t)},unproject:function(e,t){return t=void 0===t?this._zoom:t,this.options.crs.pointToLatLng(R(e),t)},layerPointToLatLng:function(e){var t=R(e).add(this.getPixelOrigin());return this.unproject(t)},latLngToLayerPoint:function(e){return this.project(j(e))._round()._subtract(this.getPixelOrigin())},wrapLatLng:function(e){return this.options.crs.wrapLatLng(j(e))},wrapLatLngBounds:function(e){return this.options.crs.wrapLatLngBounds(N(e))},distance:function(e,t){return this.options.crs.distance(j(e),j(t))},containerPointToLayerPoint:function(e){return R(e).subtract(this._getMapPanePos())},layerPointToContainerPoint:function(e){return R(e).add(this._getMapPanePos())},containerPointToLatLng:function(e){var t=this.containerPointToLayerPoint(R(e));return this.layerPointToLatLng(t)},latLngToContainerPoint:function(e){return this.layerPointToContainerPoint(this.latLngToLayerPoint(j(e)))},mouseEventToContainerPoint:function(e){return Jt(e,this._container)},mouseEventToLayerPoint:function(e){return this.containerPointToLayerPoint(this.mouseEventToContainerPoint(e))},mouseEventToLatLng:function(e){return this.layerPointToLatLng(this.mouseEventToLayerPoint(e))},_initContainer:function(e){var t=this._container=ut(e);if(!t)throw new Error("Map container not found.");if(t._leaflet_id)throw new Error("Map container is already initialized.");Tt(t,"scroll",this._onScroll,this),this._containerId=s(t)},_initLayout:function(){var e=this._container;this._fadeAnimated=this.options.fadeAnimation&&qe.any3d,yt(e,"leaflet-container"+(qe.touch?" leaflet-touch":"")+(qe.retina?" leaflet-retina":"")+(qe.ielt9?" leaflet-oldie":"")+(qe.safari?" leaflet-safari":"")+(this._fadeAnimated?" leaflet-fade-anim":""));var t=pt(e,"position");"absolute"!==t&&"relative"!==t&&"fixed"!==t&&"sticky"!==t&&(e.style.position="relative"),this._initPanes(),this._initControlPos&&this._initControlPos()},_initPanes:function(){var e=this._panes={};this._paneRenderers={},this._mapPane=this.createPane("mapPane",this._container),Et(this._mapPane,new B(0,0)),this.createPane("tilePane"),this.createPane("overlayPane"),this.createPane("shadowPane"),this.createPane("markerPane"),this.createPane("tooltipPane"),this.createPane("popupPane"),this.options.markerZoomAnimation||(yt(e.markerPane,"leaflet-zoom-hide"),yt(e.shadowPane,"leaflet-zoom-hide"))},_resetView:function(e,t,i){Et(this._mapPane,new B(0,0));var a=!this._loaded;this._loaded=!0,t=this._limitZoom(t),this.fire("viewprereset");var n=this._zoom!==t;this._moveStart(n,i)._move(e,t)._moveEnd(n),this.fire("viewreset"),a&&this.fire("load")},_moveStart:function(e,t){return e&&this.fire("zoomstart"),t||this.fire("movestart"),this},_move:function(e,t,i,a){void 0===t&&(t=this._zoom);var n=this._zoom!==t;return this._zoom=t,this._lastCenter=e,this._pixelOrigin=this._getNewPixelOrigin(e),a?i&&i.pinch&&this.fire("zoom",i):((n||i&&i.pinch)&&this.fire("zoom",i),this.fire("move",i)),this},_moveEnd:function(e){return e&&this.fire("zoomend"),this.fire("moveend")},_stop:function(){return S(this._flyToFrame),this._panAnim&&this._panAnim.stop(),this},_rawPanBy:function(e){Et(this._mapPane,this._getMapPanePos().subtract(e))},_getZoomSpan:function(){return this.getMaxZoom()-this.getMinZoom()},_panInsideMaxBounds:function(){this._enforcingBounds||this.panInsideBounds(this.options.maxBounds)},_checkIfLoaded:function(){if(!this._loaded)throw new Error("Set map center and zoom first.")},_initEvents:function(e){this._targets={},this._targets[s(this._container)]=this;var t=e?Xt:Tt;t(this._container,"click dblclick mousedown mouseup mouseover mouseout mousemove contextmenu keypress keydown keyup",this._handleDOMEvent,this),this.options.trackResize&&t(window,"resize",this._onResize,this),qe.any3d&&this.options.transform3DLimit&&(e?this.off:this.on).call(this,"moveend",this._onMoveEnd)},_onResize:function(){S(this._resizeRequest),this._resizeRequest=P((function(){this.invalidateSize({debounceMoveend:!0})}),this)},_onScroll:function(){this._container.scrollTop=0,this._container.scrollLeft=0},_onMoveEnd:function(){var e=this._getMapPanePos();Math.max(Math.abs(e.x),Math.abs(e.y))>=this.options.transform3DLimit&&this._resetView(this.getCenter(),this.getZoom())},_findEventTargets:function(e,t){for(var i,a=[],n="mouseout"===t||"mouseover"===t,r=e.target||e.srcElement,o=!1;r;){if((i=this._targets[s(r)])&&("click"===t||"preclick"===t)&&this._draggableMoved(i)){o=!0;break}if(i&&i.listens(t,!0)){if(n&&!ei(r,e))break;if(a.push(i),n)break}if(r===this._container)break;r=r.parentNode}return a.length||o||n||!this.listens(t,!0)||(a=[this]),a},_isClickDisabled:function(e){for(;e&&e!==this._container;){if(e._leaflet_disable_click)return!0;e=e.parentNode}},_handleDOMEvent:function(e){var t=e.target||e.srcElement;if(!(!this._loaded||t._leaflet_disable_events||"click"===e.type&&this._isClickDisabled(t))){var i=e.type;"mousedown"===i&&Bt(t),this._fireDOMEvent(e,i)}},_mouseEvents:["click","dblclick","mouseover","mouseout","contextmenu"],_fireDOMEvent:function(e,t,a){if("click"===e.type){var n=i({},e);n.type="preclick",this._fireDOMEvent(n,n.type,a)}var r=this._findEventTargets(e,t);if(a){for(var s=[],o=0;o0?Math.round(e-t)/2:Math.max(0,Math.ceil(e))-Math.max(0,Math.floor(t))},_limitZoom:function(e){var t=this.getMinZoom(),i=this.getMaxZoom(),a=qe.any3d?this.options.zoomSnap:1;return a&&(e=Math.round(e/a)*a),Math.max(t,Math.min(i,e))},_onPanTransitionStep:function(){this.fire("move")},_onPanTransitionEnd:function(){wt(this._mapPane,"leaflet-pan-anim"),this.fire("moveend")},_tryAnimatedPan:function(e,t){var i=this._getCenterOffset(e)._trunc();return!(!0!==(t&&t.animate)&&!this.getSize().contains(i)||(this.panBy(i,t),0))},_createAnimProxy:function(){var e=this._proxy=ft("div","leaflet-proxy leaflet-zoom-animated");this._panes.mapPane.appendChild(e),this.on("zoomanim",(function(e){var t=ct,i=this._proxy.style[t];kt(this._proxy,this.project(e.center,e.zoom),this.getZoomScale(e.zoom,1)),i===this._proxy.style[t]&&this._animatingZoom&&this._onZoomTransitionEnd()}),this),this.on("load moveend",this._animMoveEnd,this),this._on("unload",this._destroyAnimProxy,this)},_destroyAnimProxy:function(){gt(this._proxy),this.off("load moveend",this._animMoveEnd,this),delete this._proxy},_animMoveEnd:function(){var e=this.getCenter(),t=this.getZoom();kt(this._proxy,this.project(e,t),this.getZoomScale(t,1))},_catchTransitionEnd:function(e){this._animatingZoom&&e.propertyName.indexOf("transform")>=0&&this._onZoomTransitionEnd()},_nothingToAnimate:function(){return!this._container.getElementsByClassName("leaflet-zoom-animated").length},_tryAnimatedZoom:function(e,t,i){if(this._animatingZoom)return!0;if(i=i||{},!this._zoomAnimated||!1===i.animate||this._nothingToAnimate()||Math.abs(t-this._zoom)>this.options.zoomAnimationThreshold)return!1;var a=this.getZoomScale(t),n=this._getCenterOffset(e)._divideBy(1-1/a);return!(!0!==i.animate&&!this.getSize().contains(n)||(P((function(){this._moveStart(!0,i.noMoveStart||!1)._animateZoom(e,t,!0)}),this),0))},_animateZoom:function(e,t,i,a){this._mapPane&&(i&&(this._animatingZoom=!0,this._animateToCenter=e,this._animateToZoom=t,yt(this._mapPane,"leaflet-zoom-anim")),this.fire("zoomanim",{center:e,zoom:t,noUpdate:a}),this._tempFireZoomEvent||(this._tempFireZoomEvent=this._zoom!==this._animateToZoom),this._move(this._animateToCenter,this._animateToZoom,void 0,!0),setTimeout(n(this._onZoomTransitionEnd,this),250))},_onZoomTransitionEnd:function(){this._animatingZoom&&(this._mapPane&&wt(this._mapPane,"leaflet-zoom-anim"),this._animatingZoom=!1,this._move(this._animateToCenter,this._animateToZoom,void 0,!0),this._tempFireZoomEvent&&this.fire("zoom"),delete this._tempFireZoomEvent,this.fire("move"),this._moveEnd(!0))}});function ni(e,t){return new ai(e,t)}var ri=E.extend({options:{position:"topright"},initialize:function(e){p(this,e)},getPosition:function(){return this.options.position},setPosition:function(e){var t=this._map;return t&&t.removeControl(this),this.options.position=e,t&&t.addControl(this),this},getContainer:function(){return this._container},addTo:function(e){this.remove(),this._map=e;var t=this._container=this.onAdd(e),i=this.getPosition(),a=e._controlCorners[i];return yt(t,"leaflet-control"),-1!==i.indexOf("bottom")?a.insertBefore(t,a.firstChild):a.appendChild(t),this._map.on("unload",this.remove,this),this},remove:function(){return this._map?(gt(this._container),this.onRemove&&this.onRemove(this._map),this._map.off("unload",this.remove,this),this._map=null,this):this},_refocusOnMap:function(e){this._map&&e&&e.screenX>0&&e.screenY>0&&this._map.getContainer().focus()}}),si=function(e){return new ri(e)};ai.include({addControl:function(e){return e.addTo(this),this},removeControl:function(e){return e.remove(),this},_initControlPos:function(){var e=this._controlCorners={},t="leaflet-",i=this._controlContainer=ft("div",t+"control-container",this._container);function a(a,n){var r=t+a+" "+t+n;e[a+n]=ft("div",r,i)}a("top","left"),a("top","right"),a("bottom","left"),a("bottom","right")},_clearControlPos:function(){for(var e in this._controlCorners)gt(this._controlCorners[e]);gt(this._controlContainer),delete this._controlCorners,delete this._controlContainer}});var oi=ri.extend({options:{collapsed:!0,position:"topright",autoZIndex:!0,hideSingleBase:!1,sortLayers:!1,sortFunction:function(e,t,i,a){return i1,this._baseLayersList.style.display=e?"":"none"),this._separator.style.display=t&&e?"":"none",this},_onLayerChange:function(e){this._handlingClick||this._update();var t=this._getLayer(s(e.target)),i=t.overlay?"add"===e.type?"overlayadd":"overlayremove":"add"===e.type?"baselayerchange":null;i&&this._map.fire(i,t)},_createRadioElement:function(e,t){var i=' ",a=document.createElement("div");return a.innerHTML=i,a.firstChild},_addItem:function(e){var t,i=document.createElement("label"),a=this._map.hasLayer(e.layer);e.overlay?((t=document.createElement("input")).type="checkbox",t.className="leaflet-control-layers-selector",t.defaultChecked=a):t=this._createRadioElement("leaflet-base-layers_"+s(this),a),this._layerControlInputs.push(t),t.layerId=s(e.layer),Tt(t,"click",this._onInputClick,this);var n=document.createElement("span");n.innerHTML=" "+e.name;var r=document.createElement("span");return i.appendChild(r),r.appendChild(t),r.appendChild(n),(e.overlay?this._overlaysList:this._baseLayersList).appendChild(i),this._checkDisabledLayers(),i},_onInputClick:function(){if(!this._preventClick){var e,t,i=this._layerControlInputs,a=[],n=[];this._handlingClick=!0;for(var r=i.length-1;r>=0;r--)e=i[r],t=this._getLayer(e.layerId).layer,e.checked?a.push(t):e.checked||n.push(t);for(r=0;r=0;n--)e=i[n],t=this._getLayer(e.layerId).layer,e.disabled=void 0!==t.options.minZoom&&at.options.maxZoom},_expandIfNotCollapsed:function(){return this._map&&!this.options.collapsed&&this.expand(),this},_expandSafely:function(){var e=this._section;this._preventClick=!0,Tt(e,"click",Qt),this.expand();var t=this;setTimeout((function(){Xt(e,"click",Qt),t._preventClick=!1}))}}),li=function(e,t,i){return new oi(e,t,i)},ci=ri.extend({options:{position:"topleft",zoomInText:'+ ',zoomInTitle:"Zoom in",zoomOutText:'− ',zoomOutTitle:"Zoom out"},onAdd:function(e){var t="leaflet-control-zoom",i=ft("div",t+" leaflet-bar"),a=this.options;return this._zoomInButton=this._createButton(a.zoomInText,a.zoomInTitle,t+"-in",i,this._zoomIn),this._zoomOutButton=this._createButton(a.zoomOutText,a.zoomOutTitle,t+"-out",i,this._zoomOut),this._updateDisabled(),e.on("zoomend zoomlevelschange",this._updateDisabled,this),i},onRemove:function(e){e.off("zoomend zoomlevelschange",this._updateDisabled,this)},disable:function(){return this._disabled=!0,this._updateDisabled(),this},enable:function(){return this._disabled=!1,this._updateDisabled(),this},_zoomIn:function(e){!this._disabled&&this._map._zoomthis._map.getMinZoom()&&this._map.zoomOut(this._map.options.zoomDelta*(e.shiftKey?3:1))},_createButton:function(e,t,i,a,n){var r=ft("a",i,a);return r.innerHTML=e,r.href="#",r.title=t,r.setAttribute("role","button"),r.setAttribute("aria-label",t),Zt(r),Tt(r,"click",Ut),Tt(r,"click",n,this),Tt(r,"click",this._refocusOnMap,this),r},_updateDisabled:function(){var e=this._map,t="leaflet-disabled";wt(this._zoomInButton,t),wt(this._zoomOutButton,t),this._zoomInButton.setAttribute("aria-disabled","false"),this._zoomOutButton.setAttribute("aria-disabled","false"),(this._disabled||e._zoom===e.getMinZoom())&&(yt(this._zoomOutButton,t),this._zoomOutButton.setAttribute("aria-disabled","true")),(this._disabled||e._zoom===e.getMaxZoom())&&(yt(this._zoomInButton,t),this._zoomInButton.setAttribute("aria-disabled","true"))}});ai.mergeOptions({zoomControl:!0}),ai.addInitHook((function(){this.options.zoomControl&&(this.zoomControl=new ci,this.addControl(this.zoomControl))}));var di=function(e){return new ci(e)},hi=ri.extend({options:{position:"bottomleft",maxWidth:100,metric:!0,imperial:!0},onAdd:function(e){var t="leaflet-control-scale",i=ft("div",t),a=this.options;return this._addScales(a,t+"-line",i),e.on(a.updateWhenIdle?"moveend":"move",this._update,this),e.whenReady(this._update,this),i},onRemove:function(e){e.off(this.options.updateWhenIdle?"moveend":"move",this._update,this)},_addScales:function(e,t,i){e.metric&&(this._mScale=ft("div",t,i)),e.imperial&&(this._iScale=ft("div",t,i))},_update:function(){var e=this._map,t=e.getSize().y/2,i=e.distance(e.containerPointToLatLng([0,t]),e.containerPointToLatLng([this.options.maxWidth,t]));this._updateScales(i)},_updateScales:function(e){this.options.metric&&e&&this._updateMetric(e),this.options.imperial&&e&&this._updateImperial(e)},_updateMetric:function(e){var t=this._getRoundNum(e),i=t<1e3?t+" m":t/1e3+" km";this._updateScale(this._mScale,i,t/e)},_updateImperial:function(e){var t,i,a,n=3.2808399*e;n>5280?(t=n/5280,i=this._getRoundNum(t),this._updateScale(this._iScale,i+" mi",i/t)):(a=this._getRoundNum(n),this._updateScale(this._iScale,a+" ft",a/n))},_updateScale:function(e,t,i){e.style.width=Math.round(this.options.maxWidth*i)+"px",e.innerHTML=t},_getRoundNum:function(e){var t=Math.pow(10,(Math.floor(e)+"").length-1),i=e/t;return t*(i=i>=10?10:i>=5?5:i>=3?3:i>=2?2:1)}}),ui=function(e){return new hi(e)},pi=' ',fi=ri.extend({options:{position:"bottomright",prefix:''+(qe.inlineSvg?pi+" ":"")+"Leaflet "},initialize:function(e){p(this,e),this._attributions={}},onAdd:function(e){for(var t in e.attributionControl=this,this._container=ft("div","leaflet-control-attribution"),Zt(this._container),e._layers)e._layers[t].getAttribution&&this.addAttribution(e._layers[t].getAttribution());return this._update(),e.on("layeradd",this._addAttribution,this),this._container},onRemove:function(e){e.off("layeradd",this._addAttribution,this)},_addAttribution:function(e){e.layer.getAttribution&&(this.addAttribution(e.layer.getAttribution()),e.layer.once("remove",(function(){this.removeAttribution(e.layer.getAttribution())}),this))},setPrefix:function(e){return this.options.prefix=e,this._update(),this},addAttribution:function(e){return e?(this._attributions[e]||(this._attributions[e]=0),this._attributions[e]++,this._update(),this):this},removeAttribution:function(e){return e?(this._attributions[e]&&(this._attributions[e]--,this._update()),this):this},_update:function(){if(this._map){var e=[];for(var t in this._attributions)this._attributions[t]&&e.push(t);var i=[];this.options.prefix&&i.push(this.options.prefix),e.length&&i.push(e.join(", ")),this._container.innerHTML=i.join(' | ')}}});ai.mergeOptions({attributionControl:!0}),ai.addInitHook((function(){this.options.attributionControl&&(new fi).addTo(this)}));var gi=function(e){return new fi(e)};ri.Layers=oi,ri.Zoom=ci,ri.Scale=hi,ri.Attribution=fi,si.layers=li,si.zoom=di,si.scale=ui,si.attribution=gi;var mi=E.extend({initialize:function(e){this._map=e},enable:function(){return this._enabled||(this._enabled=!0,this.addHooks()),this},disable:function(){return this._enabled?(this._enabled=!1,this.removeHooks(),this):this},enabled:function(){return!!this._enabled}});mi.addTo=function(e,t){return e.addHandler(t,this),this};var vi={Events:O},bi=qe.touch?"touchstart mousedown":"mousedown",xi=I.extend({options:{clickTolerance:3},initialize:function(e,t,i,a){p(this,a),this._element=e,this._dragStartTarget=t||e,this._preventOutline=i},enable:function(){this._enabled||(Tt(this._dragStartTarget,bi,this._onDown,this),this._enabled=!0)},disable:function(){this._enabled&&(xi._dragging===this&&this.finishDrag(!0),Xt(this._dragStartTarget,bi,this._onDown,this),this._enabled=!1,this._moved=!1)},_onDown:function(e){if(this._enabled&&(this._moved=!1,!xt(this._element,"leaflet-zoom-anim")))if(e.touches&&1!==e.touches.length)xi._dragging===this&&this.finishDrag();else if(!(xi._dragging||e.shiftKey||1!==e.which&&1!==e.button&&!e.touches||(xi._dragging=this,this._preventOutline&&Bt(this._element),Lt(),nt(),this._moving))){this.fire("down");var t=e.touches?e.touches[0]:e,i=Rt(this._element);this._startPoint=new B(t.clientX,t.clientY),this._startPos=Mt(this._element),this._parentScale=Dt(i);var a="mousedown"===e.type;Tt(document,a?"mousemove":"touchmove",this._onMove,this),Tt(document,a?"mouseup":"touchend touchcancel",this._onUp,this)}},_onMove:function(e){if(this._enabled)if(e.touches&&e.touches.length>1)this._moved=!0;else{var t=e.touches&&1===e.touches.length?e.touches[0]:e,i=new B(t.clientX,t.clientY)._subtract(this._startPoint);(i.x||i.y)&&(Math.abs(i.x)+Math.abs(i.y)l&&(r=s,l=o);l>i&&(t[r]=1,Mi(e,t,i,a,r),Mi(e,t,i,r,n))}function Oi(e,t){for(var i=[e[0]],a=1,n=0,r=e.length;at&&(i.push(e[a]),n=a);return nt.max.x&&(i|=2),e.yt.max.y&&(i|=8),i}function Vi(e,t){var i=t.x-e.x,a=t.y-e.y;return i*i+a*a}function Ri(e,t,i,a){var n,r=t.x,s=t.y,o=i.x-r,l=i.y-s,c=o*o+l*l;return c>0&&((n=((e.x-r)*o+(e.y-s)*l)/c)>1?(r=i.x,s=i.y):n>0&&(r+=o*n,s+=l*n)),o=e.x-r,l=e.y-s,a?o*o+l*l:new B(r,s)}function Di(e){return!v(e[0])||"object"!=typeof e[0][0]&&void 0!==e[0][0]}function qi(e){return console.warn("Deprecated use of _flat, please use L.LineUtil.isFlat instead."),Di(e)}function Ti(e,t){var i,a,n,r,s,o,l,c;if(!e||0===e.length)throw new Error("latlngs not passed");Di(e)||(console.warn("latlngs are not flat! Only the first ring will be used"),e=e[0]);var d=j([0,0]),h=N(e);h.getNorthWest().distanceTo(h.getSouthWest())*h.getNorthEast().distanceTo(h.getNorthWest())<1700&&(d=Ai(e));var u=e.length,p=[];for(i=0;ia){l=(r-a)/n,c=[o.x-l*(o.x-s.x),o.y-l*(o.y-s.y)];break}var g=t.unproject(R(c));return j([g.lat+d.lat,g.lng+d.lng])}var Ni={__proto__:null,simplify:Pi,pointToSegmentDistance:Si,closestPointOnSegment:ki,clipSegment:Li,_getEdgeIntersection:Ii,_getBitCode:Bi,_sqClosestPointOnSegment:Ri,isFlat:Di,_flat:qi,polylineCenter:Ti},Xi={project:function(e){return new B(e.lng,e.lat)},unproject:function(e){return new X(e.y,e.x)},bounds:new D([-180,-90],[180,90])},ji={R:6378137,R_MINOR:6356752.314245179,bounds:new D([-20037508.34279,-15496570.73972],[20037508.34279,18764656.23138]),project:function(e){var t=Math.PI/180,i=this.R,a=e.lat*t,n=this.R_MINOR/i,r=Math.sqrt(1-n*n),s=r*Math.sin(a),o=Math.tan(Math.PI/4-a/2)/Math.pow((1-s)/(1+s),r/2);return a=-i*Math.log(Math.max(o,1e-10)),new B(e.lng*t*i,a)},unproject:function(e){for(var t,i=180/Math.PI,a=this.R,n=this.R_MINOR/a,r=Math.sqrt(1-n*n),s=Math.exp(-e.y/a),o=Math.PI/2-2*Math.atan(s),l=0,c=.1;l<15&&Math.abs(c)>1e-7;l++)t=r*Math.sin(o),t=Math.pow((1-t)/(1+t),r/2),o+=c=Math.PI/2-2*Math.atan(s*t)-o;return new X(o*i,e.x*i/a)}},Fi={__proto__:null,LonLat:Xi,Mercator:ji,SphericalMercator:Y},Wi=i({},W,{code:"EPSG:3395",projection:ji,transformation:function(){var e=.5/(Math.PI*ji.R);return Z(e,.5,-e,.5)}()}),Hi=i({},W,{code:"EPSG:4326",projection:Xi,transformation:Z(1/180,1,-1/180,.5)}),Yi=i({},F,{projection:Xi,transformation:Z(1,0,-1,0),scale:function(e){return Math.pow(2,e)},zoom:function(e){return Math.log(e)/Math.LN2},distance:function(e,t){var i=t.lng-e.lng,a=t.lat-e.lat;return Math.sqrt(i*i+a*a)},infinite:!0});F.Earth=W,F.EPSG3395=Wi,F.EPSG3857=Q,F.EPSG900913=U,F.EPSG4326=Hi,F.Simple=Yi;var Gi=I.extend({options:{pane:"overlayPane",attribution:null,bubblingMouseEvents:!0},addTo:function(e){return e.addLayer(this),this},remove:function(){return this.removeFrom(this._map||this._mapToAdd)},removeFrom:function(e){return e&&e.removeLayer(this),this},getPane:function(e){return this._map.getPane(e?this.options[e]||e:this.options.pane)},addInteractiveTarget:function(e){return this._map._targets[s(e)]=this,this},removeInteractiveTarget:function(e){return delete this._map._targets[s(e)],this},getAttribution:function(){return this.options.attribution},_layerAdd:function(e){var t=e.target;if(t.hasLayer(this)){if(this._map=t,this._zoomAnimated=t._zoomAnimated,this.getEvents){var i=this.getEvents();t.on(i,this),this.once("remove",(function(){t.off(i,this)}),this)}this.onAdd(t),this.fire("add"),t.fire("layeradd",{layer:this})}}});ai.include({addLayer:function(e){if(!e._layerAdd)throw new Error("The provided object is not a Layer.");var t=s(e);return this._layers[t]||(this._layers[t]=e,e._mapToAdd=this,e.beforeAdd&&e.beforeAdd(this),this.whenReady(e._layerAdd,e)),this},removeLayer:function(e){var t=s(e);return this._layers[t]?(this._loaded&&e.onRemove(this),delete this._layers[t],this._loaded&&(this.fire("layerremove",{layer:e}),e.fire("remove")),e._map=e._mapToAdd=null,this):this},hasLayer:function(e){return s(e)in this._layers},eachLayer:function(e,t){for(var i in this._layers)e.call(t,this._layers[i]);return this},_addLayers:function(e){for(var t=0,i=(e=e?v(e)?e:[e]:[]).length;tthis._layersMaxZoom&&this.setZoom(this._layersMaxZoom),void 0===this.options.minZoom&&this._layersMinZoom&&this.getZoom()=2&&t[0]instanceof X&&t[0].equals(t[i-1])&&t.pop(),t},_setLatLngs:function(e){la.prototype._setLatLngs.call(this,e),Di(this._latlngs)&&(this._latlngs=[this._latlngs])},_defaultShape:function(){return Di(this._latlngs[0])?this._latlngs[0]:this._latlngs[0][0]},_clipPoints:function(){var e=this._renderer._bounds,t=this.options.weight,i=new B(t,t);if(e=new D(e.min.subtract(i),e.max.add(i)),this._parts=[],this._pxBounds&&this._pxBounds.intersects(e))if(this.options.noClip)this._parts=this._rings;else for(var a,n=0,r=this._rings.length;ne.y!=a.y>e.y&&e.x<(a.x-i.x)*(e.y-i.y)/(a.y-i.y)+i.x&&(c=!c);return c||la.prototype._containsPoint.call(this,e,!0)}});function ha(e,t){return new da(e,t)}var ua=Ui.extend({initialize:function(e,t){p(this,t),this._layers={},e&&this.addData(e)},addData:function(e){var t,i,a,n=v(e)?e:e.features;if(n){for(t=0,i=n.length;t0&&n.push(n[0].slice()),n}function xa(e,t){return e.feature?i({},e.feature,{geometry:t}):ya(t)}function ya(e){return"Feature"===e.type||"FeatureCollection"===e.type?e:{type:"Feature",properties:{},geometry:e}}var wa={toGeoJSON:function(e){return xa(this,{type:"Point",coordinates:va(this.getLatLng(),e)})}};function Aa(e,t){return new ua(e,t)}ta.include(wa),sa.include(wa),na.include(wa),la.include({toGeoJSON:function(e){var t=!Di(this._latlngs);return xa(this,{type:(t?"Multi":"")+"LineString",coordinates:ba(this._latlngs,t?1:0,!1,e)})}}),da.include({toGeoJSON:function(e){var t=!Di(this._latlngs),i=t&&!Di(this._latlngs[0]),a=ba(this._latlngs,i?2:t?1:0,!0,e);return t||(a=[a]),xa(this,{type:(i?"Multi":"")+"Polygon",coordinates:a})}}),Zi.include({toMultiPoint:function(e){var t=[];return this.eachLayer((function(i){t.push(i.toGeoJSON(e).geometry.coordinates)})),xa(this,{type:"MultiPoint",coordinates:t})},toGeoJSON:function(e){var t=this.feature&&this.feature.geometry&&this.feature.geometry.type;if("MultiPoint"===t)return this.toMultiPoint(e);var i="GeometryCollection"===t,a=[];return this.eachLayer((function(t){if(t.toGeoJSON){var n=t.toGeoJSON(e);if(i)a.push(n.geometry);else{var r=ya(n);"FeatureCollection"===r.type?a.push.apply(a,r.features):a.push(r)}}})),i?xa(this,{geometries:a,type:"GeometryCollection"}):{type:"FeatureCollection",features:a}}});var Ca=Aa,za=Gi.extend({options:{opacity:1,alt:"",interactive:!1,crossOrigin:!1,errorOverlayUrl:"",zIndex:1,className:""},initialize:function(e,t,i){this._url=e,this._bounds=N(t),p(this,i)},onAdd:function(){this._image||(this._initImage(),this.options.opacity<1&&this._updateOpacity()),this.options.interactive&&(yt(this._image,"leaflet-interactive"),this.addInteractiveTarget(this._image)),this.getPane().appendChild(this._image),this._reset()},onRemove:function(){gt(this._image),this.options.interactive&&this.removeInteractiveTarget(this._image)},setOpacity:function(e){return this.options.opacity=e,this._image&&this._updateOpacity(),this},setStyle:function(e){return e.opacity&&this.setOpacity(e.opacity),this},bringToFront:function(){return this._map&&vt(this._image),this},bringToBack:function(){return this._map&&bt(this._image),this},setUrl:function(e){return this._url=e,this._image&&(this._image.src=e),this},setBounds:function(e){return this._bounds=N(e),this._map&&this._reset(),this},getEvents:function(){var e={zoom:this._reset,viewreset:this._reset};return this._zoomAnimated&&(e.zoomanim=this._animateZoom),e},setZIndex:function(e){return this.options.zIndex=e,this._updateZIndex(),this},getBounds:function(){return this._bounds},getElement:function(){return this._image},_initImage:function(){var e="IMG"===this._url.tagName,t=this._image=e?this._url:ft("img");yt(t,"leaflet-image-layer"),this._zoomAnimated&&yt(t,"leaflet-zoom-animated"),this.options.className&&yt(t,this.options.className),t.onselectstart=c,t.onmousemove=c,t.onload=n(this.fire,this,"load"),t.onerror=n(this._overlayOnError,this,"error"),(this.options.crossOrigin||""===this.options.crossOrigin)&&(t.crossOrigin=!0===this.options.crossOrigin?"":this.options.crossOrigin),this.options.zIndex&&this._updateZIndex(),e?this._url=t.src:(t.src=this._url,t.alt=this.options.alt)},_animateZoom:function(e){var t=this._map.getZoomScale(e.zoom),i=this._map._latLngBoundsToNewLayerBounds(this._bounds,e.zoom,e.center).min;kt(this._image,i,t)},_reset:function(){var e=this._image,t=new D(this._map.latLngToLayerPoint(this._bounds.getNorthWest()),this._map.latLngToLayerPoint(this._bounds.getSouthEast())),i=t.getSize();Et(e,t.min),e.style.width=i.x+"px",e.style.height=i.y+"px"},_updateOpacity:function(){zt(this._image,this.options.opacity)},_updateZIndex:function(){this._image&&void 0!==this.options.zIndex&&null!==this.options.zIndex&&(this._image.style.zIndex=this.options.zIndex)},_overlayOnError:function(){this.fire("error");var e=this.options.errorOverlayUrl;e&&this._url!==e&&(this._url=e,this._image.src=e)},getCenter:function(){return this._bounds.getCenter()}}),Pa=function(e,t,i){return new za(e,t,i)},Sa=za.extend({options:{autoplay:!0,loop:!0,keepAspectRatio:!0,muted:!1,playsInline:!0},_initImage:function(){var e="VIDEO"===this._url.tagName,t=this._image=e?this._url:ft("video");if(yt(t,"leaflet-image-layer"),this._zoomAnimated&&yt(t,"leaflet-zoom-animated"),this.options.className&&yt(t,this.options.className),t.onselectstart=c,t.onmousemove=c,t.onloadeddata=n(this.fire,this,"load"),e){for(var i=t.getElementsByTagName("source"),a=[],r=0;r0?a:[t.src]}else{v(this._url)||(this._url=[this._url]),!this.options.keepAspectRatio&&Object.prototype.hasOwnProperty.call(t.style,"objectFit")&&(t.style.objectFit="fill"),t.autoplay=!!this.options.autoplay,t.loop=!!this.options.loop,t.muted=!!this.options.muted,t.playsInline=!!this.options.playsInline;for(var s=0;s×',Tt(a,"click",(function(e){Qt(e),this.close()}),this)}},_updateLayout:function(){var e=this._contentNode,t=e.style;t.width="",t.whiteSpace="nowrap";var i=e.offsetWidth;i=Math.min(i,this.options.maxWidth),i=Math.max(i,this.options.minWidth),t.width=i+1+"px",t.whiteSpace="",t.height="";var a=e.offsetHeight,n=this.options.maxHeight,r="leaflet-popup-scrolled";n&&a>n?(t.height=n+"px",yt(e,r)):wt(e,r),this._containerWidth=this._container.offsetWidth},_animateZoom:function(e){var t=this._map._latLngToNewLayerPoint(this._latlng,e.zoom,e.center),i=this._getAnchor();Et(this._container,t.add(i))},_adjustPan:function(){if(this.options.autoPan)if(this._map._panAnim&&this._map._panAnim.stop(),this._autopanning)this._autopanning=!1;else{var e=this._map,t=parseInt(pt(this._container,"marginBottom"),10)||0,i=this._container.offsetHeight+t,a=this._containerWidth,n=new B(this._containerLeft,-i-this._containerBottom);n._add(Mt(this._container));var r=e.layerPointToContainerPoint(n),s=R(this.options.autoPanPadding),o=R(this.options.autoPanPaddingTopLeft||s),l=R(this.options.autoPanPaddingBottomRight||s),c=e.getSize(),d=0,h=0;r.x+a+l.x>c.x&&(d=r.x+a-c.x+l.x),r.x-d-o.x<0&&(d=r.x-o.x),r.y+i+l.y>c.y&&(h=r.y+i-c.y+l.y),r.y-h-o.y<0&&(h=r.y-o.y),(d||h)&&(this.options.keepInView&&(this._autopanning=!0),e.fire("autopanstart").panBy([d,h]))}},_getAnchor:function(){return R(this._source&&this._source._getPopupAnchor?this._source._getPopupAnchor():[0,0])}}),Ia=function(e,t){return new La(e,t)};ai.mergeOptions({closePopupOnClick:!0}),ai.include({openPopup:function(e,t,i){return this._initOverlay(La,e,t,i).openOn(this),this},closePopup:function(e){return(e=arguments.length?e:this._popup)&&e.close(),this}}),Gi.include({bindPopup:function(e,t){return this._popup=this._initOverlay(La,this._popup,e,t),this._popupHandlersAdded||(this.on({click:this._openPopup,keypress:this._onKeyPress,remove:this.closePopup,move:this._movePopup}),this._popupHandlersAdded=!0),this},unbindPopup:function(){return this._popup&&(this.off({click:this._openPopup,keypress:this._onKeyPress,remove:this.closePopup,move:this._movePopup}),this._popupHandlersAdded=!1,this._popup=null),this},openPopup:function(e){return this._popup&&(this instanceof Ui||(this._popup._source=this),this._popup._prepareOpen(e||this._latlng)&&this._popup.openOn(this._map)),this},closePopup:function(){return this._popup&&this._popup.close(),this},togglePopup:function(){return this._popup&&this._popup.toggle(this),this},isPopupOpen:function(){return!!this._popup&&this._popup.isOpen()},setPopupContent:function(e){return this._popup&&this._popup.setContent(e),this},getPopup:function(){return this._popup},_openPopup:function(e){if(this._popup&&this._map){Ut(e);var t=e.layer||e.target;this._popup._source!==t||t instanceof aa?(this._popup._source=t,this.openPopup(e.latlng)):this._map.hasLayer(this._popup)?this.closePopup():this.openPopup(e.latlng)}},_movePopup:function(e){this._popup.setLatLng(e.latlng)},_onKeyPress:function(e){13===e.originalEvent.keyCode&&this._openPopup(e)}});var Ba=Oa.extend({options:{pane:"tooltipPane",offset:[0,0],direction:"auto",permanent:!1,sticky:!1,opacity:.9},onAdd:function(e){Oa.prototype.onAdd.call(this,e),this.setOpacity(this.options.opacity),e.fire("tooltipopen",{tooltip:this}),this._source&&(this.addEventParent(this._source),this._source.fire("tooltipopen",{tooltip:this},!0))},onRemove:function(e){Oa.prototype.onRemove.call(this,e),e.fire("tooltipclose",{tooltip:this}),this._source&&(this.removeEventParent(this._source),this._source.fire("tooltipclose",{tooltip:this},!0))},getEvents:function(){var e=Oa.prototype.getEvents.call(this);return this.options.permanent||(e.preclick=this.close),e},_initLayout:function(){var e="leaflet-tooltip "+(this.options.className||"")+" leaflet-zoom-"+(this._zoomAnimated?"animated":"hide");this._contentNode=this._container=ft("div",e),this._container.setAttribute("role","tooltip"),this._container.setAttribute("id","leaflet-tooltip-"+s(this))},_updateLayout:function(){},_adjustPan:function(){},_setPosition:function(e){var t,i,a=this._map,n=this._container,r=a.latLngToContainerPoint(a.getCenter()),s=a.layerPointToContainerPoint(e),o=this.options.direction,l=n.offsetWidth,c=n.offsetHeight,d=R(this.options.offset),h=this._getAnchor();"top"===o?(t=l/2,i=c):"bottom"===o?(t=l/2,i=0):"center"===o?(t=l/2,i=c/2):"right"===o?(t=0,i=c/2):"left"===o?(t=l,i=c/2):s.xthis.options.maxZoom||ia&&this._retainParent(n,r,s,a))},_retainChildren:function(e,t,i,a){for(var n=2*e;n<2*e+2;n++)for(var r=2*t;r<2*t+2;r++){var s=new B(n,r);s.z=i+1;var o=this._tileCoordsToKey(s),l=this._tiles[o];l&&l.active?l.retain=!0:(l&&l.loaded&&(l.retain=!0),i+1this.options.maxZoom||void 0!==this.options.minZoom&&n1)this._setView(e,i);else{for(var h=n.min.y;h<=n.max.y;h++)for(var u=n.min.x;u<=n.max.x;u++){var p=new B(u,h);if(p.z=this._tileZoom,this._isValidTile(p)){var f=this._tiles[this._tileCoordsToKey(p)];f?f.current=!0:s.push(p)}}if(s.sort((function(e,t){return e.distanceTo(r)-t.distanceTo(r)})),0!==s.length){this._loading||(this._loading=!0,this.fire("loading"));var g=document.createDocumentFragment();for(u=0;ui.max.x)||!t.wrapLat&&(e.yi.max.y))return!1}if(!this.options.bounds)return!0;var a=this._tileCoordsToBounds(e);return N(this.options.bounds).overlaps(a)},_keyToBounds:function(e){return this._tileCoordsToBounds(this._keyToTileCoords(e))},_tileCoordsToNwSe:function(e){var t=this._map,i=this.getTileSize(),a=e.scaleBy(i),n=a.add(i);return[t.unproject(a,e.z),t.unproject(n,e.z)]},_tileCoordsToBounds:function(e){var t=this._tileCoordsToNwSe(e),i=new T(t[0],t[1]);return this.options.noWrap||(i=this._map.wrapLatLngBounds(i)),i},_tileCoordsToKey:function(e){return e.x+":"+e.y+":"+e.z},_keyToTileCoords:function(e){var t=e.split(":"),i=new B(+t[0],+t[1]);return i.z=+t[2],i},_removeTile:function(e){var t=this._tiles[e];t&&(gt(t.el),delete this._tiles[e],this.fire("tileunload",{tile:t.el,coords:this._keyToTileCoords(e)}))},_initTile:function(e){yt(e,"leaflet-tile");var t=this.getTileSize();e.style.width=t.x+"px",e.style.height=t.y+"px",e.onselectstart=c,e.onmousemove=c,qe.ielt9&&this.options.opacity<1&&zt(e,this.options.opacity)},_addTile:function(e,t){var i=this._getTilePos(e),a=this._tileCoordsToKey(e),r=this.createTile(this._wrapCoords(e),n(this._tileReady,this,e));this._initTile(r),this.createTile.length<2&&P(n(this._tileReady,this,e,null,r)),Et(r,i),this._tiles[a]={el:r,coords:e,current:!0},t.appendChild(r),this.fire("tileloadstart",{tile:r,coords:e})},_tileReady:function(e,t,i){t&&this.fire("tileerror",{error:t,tile:i,coords:e});var a=this._tileCoordsToKey(e);(i=this._tiles[a])&&(i.loaded=+new Date,this._map._fadeAnimated?(zt(i.el,0),S(this._fadeFrame),this._fadeFrame=P(this._updateOpacity,this)):(i.active=!0,this._pruneTiles()),t||(yt(i.el,"leaflet-tile-loaded"),this.fire("tileload",{tile:i.el,coords:e})),this._noTilesToLoad()&&(this._loading=!1,this.fire("load"),qe.ielt9||!this._map._fadeAnimated?P(this._pruneTiles,this):setTimeout(n(this._pruneTiles,this),250)))},_getTilePos:function(e){return e.scaleBy(this.getTileSize()).subtract(this._level.origin)},_wrapCoords:function(e){var t=new B(this._wrapX?l(e.x,this._wrapX):e.x,this._wrapY?l(e.y,this._wrapY):e.y);return t.z=e.z,t},_pxBoundsToTileRange:function(e){var t=this.getTileSize();return new D(e.min.unscaleBy(t).floor(),e.max.unscaleBy(t).ceil().subtract([1,1]))},_noTilesToLoad:function(){for(var e in this._tiles)if(!this._tiles[e].loaded)return!1;return!0}});function Ta(e){return new qa(e)}var Na=qa.extend({options:{minZoom:0,maxZoom:18,subdomains:"abc",errorTileUrl:"",zoomOffset:0,tms:!1,zoomReverse:!1,detectRetina:!1,crossOrigin:!1,referrerPolicy:!1},initialize:function(e,t){this._url=e,(t=p(this,t)).detectRetina&&qe.retina&&t.maxZoom>0?(t.tileSize=Math.floor(t.tileSize/2),t.zoomReverse?(t.zoomOffset--,t.minZoom=Math.min(t.maxZoom,t.minZoom+1)):(t.zoomOffset++,t.maxZoom=Math.max(t.minZoom,t.maxZoom-1)),t.minZoom=Math.max(0,t.minZoom)):t.zoomReverse?t.minZoom=Math.min(t.maxZoom,t.minZoom):t.maxZoom=Math.max(t.minZoom,t.maxZoom),"string"==typeof t.subdomains&&(t.subdomains=t.subdomains.split("")),this.on("tileunload",this._onTileRemove)},setUrl:function(e,t){return this._url===e&&void 0===t&&(t=!0),this._url=e,t||this.redraw(),this},createTile:function(e,t){var i=document.createElement("img");return Tt(i,"load",n(this._tileOnLoad,this,t,i)),Tt(i,"error",n(this._tileOnError,this,t,i)),(this.options.crossOrigin||""===this.options.crossOrigin)&&(i.crossOrigin=!0===this.options.crossOrigin?"":this.options.crossOrigin),"string"==typeof this.options.referrerPolicy&&(i.referrerPolicy=this.options.referrerPolicy),i.alt="",i.src=this.getTileUrl(e),i},getTileUrl:function(e){var t={r:qe.retina?"@2x":"",s:this._getSubdomain(e),x:e.x,y:e.y,z:this._getZoomForUrl()};if(this._map&&!this._map.options.crs.infinite){var a=this._globalTileRange.max.y-e.y;this.options.tms&&(t.y=a),t["-y"]=a}return m(this._url,i(t,this.options))},_tileOnLoad:function(e,t){qe.ielt9?setTimeout(n(e,this,null,t),0):e(null,t)},_tileOnError:function(e,t,i){var a=this.options.errorTileUrl;a&&t.getAttribute("src")!==a&&(t.src=a),e(i,t)},_onTileRemove:function(e){e.tile.onload=null},_getZoomForUrl:function(){var e=this._tileZoom,t=this.options.maxZoom;return this.options.zoomReverse&&(e=t-e),e+this.options.zoomOffset},_getSubdomain:function(e){var t=Math.abs(e.x+e.y)%this.options.subdomains.length;return this.options.subdomains[t]},_abortLoading:function(){var e,t;for(e in this._tiles)if(this._tiles[e].coords.z!==this._tileZoom&&((t=this._tiles[e].el).onload=c,t.onerror=c,!t.complete)){t.src=x;var i=this._tiles[e].coords;gt(t),delete this._tiles[e],this.fire("tileabort",{tile:t,coords:i})}},_removeTile:function(e){var t=this._tiles[e];if(t)return t.el.setAttribute("src",x),qa.prototype._removeTile.call(this,e)},_tileReady:function(e,t,i){if(this._map&&(!i||i.getAttribute("src")!==x))return qa.prototype._tileReady.call(this,e,t,i)}});function Xa(e,t){return new Na(e,t)}var ja=Na.extend({defaultWmsParams:{service:"WMS",request:"GetMap",layers:"",styles:"",format:"image/jpeg",transparent:!1,version:"1.1.1"},options:{crs:null,uppercase:!1},initialize:function(e,t){this._url=e;var a=i({},this.defaultWmsParams);for(var n in t)n in this.options||(a[n]=t[n]);var r=(t=p(this,t)).detectRetina&&qe.retina?2:1,s=this.getTileSize();a.width=s.x*r,a.height=s.y*r,this.wmsParams=a},onAdd:function(e){this._crs=this.options.crs||e.options.crs,this._wmsVersion=parseFloat(this.wmsParams.version);var t=this._wmsVersion>=1.3?"crs":"srs";this.wmsParams[t]=this._crs.code,Na.prototype.onAdd.call(this,e)},getTileUrl:function(e){var t=this._tileCoordsToNwSe(e),i=this._crs,a=q(i.project(t[0]),i.project(t[1])),n=a.min,r=a.max,s=(this._wmsVersion>=1.3&&this._crs===Hi?[n.y,n.x,r.y,r.x]:[n.x,n.y,r.x,r.y]).join(","),o=Na.prototype.getTileUrl.call(this,e);return o+f(this.wmsParams,o,this.options.uppercase)+(this.options.uppercase?"&BBOX=":"&bbox=")+s},setParams:function(e,t){return i(this.wmsParams,e),t||this.redraw(),this}});function Fa(e,t){return new ja(e,t)}Na.WMS=ja,Xa.wms=Fa;var Wa=Gi.extend({options:{padding:.1},initialize:function(e){p(this,e),s(this),this._layers=this._layers||{}},onAdd:function(){this._container||(this._initContainer(),yt(this._container,"leaflet-zoom-animated")),this.getPane().appendChild(this._container),this._update(),this.on("update",this._updatePaths,this)},onRemove:function(){this.off("update",this._updatePaths,this),this._destroyContainer()},getEvents:function(){var e={viewreset:this._reset,zoom:this._onZoom,moveend:this._update,zoomend:this._onZoomEnd};return this._zoomAnimated&&(e.zoomanim=this._onAnimZoom),e},_onAnimZoom:function(e){this._updateTransform(e.center,e.zoom)},_onZoom:function(){this._updateTransform(this._map.getCenter(),this._map.getZoom())},_updateTransform:function(e,t){var i=this._map.getZoomScale(t,this._zoom),a=this._map.getSize().multiplyBy(.5+this.options.padding),n=this._map.project(this._center,t),r=a.multiplyBy(-i).add(n).subtract(this._map._getNewPixelOrigin(e,t));qe.any3d?kt(this._container,r,i):Et(this._container,r)},_reset:function(){for(var e in this._update(),this._updateTransform(this._center,this._zoom),this._layers)this._layers[e]._reset()},_onZoomEnd:function(){for(var e in this._layers)this._layers[e]._project()},_updatePaths:function(){for(var e in this._layers)this._layers[e]._update()},_update:function(){var e=this.options.padding,t=this._map.getSize(),i=this._map.containerPointToLayerPoint(t.multiplyBy(-e)).round();this._bounds=new D(i,i.add(t.multiplyBy(1+2*e)).round()),this._center=this._map.getCenter(),this._zoom=this._map.getZoom()}}),Ha=Wa.extend({options:{tolerance:0},getEvents:function(){var e=Wa.prototype.getEvents.call(this);return e.viewprereset=this._onViewPreReset,e},_onViewPreReset:function(){this._postponeUpdatePaths=!0},onAdd:function(){Wa.prototype.onAdd.call(this),this._draw()},_initContainer:function(){var e=this._container=document.createElement("canvas");Tt(e,"mousemove",this._onMouseMove,this),Tt(e,"click dblclick mousedown mouseup contextmenu",this._onClick,this),Tt(e,"mouseout",this._handleMouseOut,this),e._leaflet_disable_events=!0,this._ctx=e.getContext("2d")},_destroyContainer:function(){S(this._redrawRequest),delete this._ctx,gt(this._container),Xt(this._container),delete this._container},_updatePaths:function(){if(!this._postponeUpdatePaths){for(var e in this._redrawBounds=null,this._layers)this._layers[e]._update();this._redraw()}},_update:function(){if(!this._map._animatingZoom||!this._bounds){Wa.prototype._update.call(this);var e=this._bounds,t=this._container,i=e.getSize(),a=qe.retina?2:1;Et(t,e.min),t.width=a*i.x,t.height=a*i.y,t.style.width=i.x+"px",t.style.height=i.y+"px",qe.retina&&this._ctx.scale(2,2),this._ctx.translate(-e.min.x,-e.min.y),this.fire("update")}},_reset:function(){Wa.prototype._reset.call(this),this._postponeUpdatePaths&&(this._postponeUpdatePaths=!1,this._updatePaths())},_initPath:function(e){this._updateDashArray(e),this._layers[s(e)]=e;var t=e._order={layer:e,prev:this._drawLast,next:null};this._drawLast&&(this._drawLast.next=t),this._drawLast=t,this._drawFirst=this._drawFirst||this._drawLast},_addPath:function(e){this._requestRedraw(e)},_removePath:function(e){var t=e._order,i=t.next,a=t.prev;i?i.prev=a:this._drawLast=a,a?a.next=i:this._drawFirst=i,delete e._order,delete this._layers[s(e)],this._requestRedraw(e)},_updatePath:function(e){this._extendRedrawBounds(e),e._project(),e._update(),this._requestRedraw(e)},_updateStyle:function(e){this._updateDashArray(e),this._requestRedraw(e)},_updateDashArray:function(e){if("string"==typeof e.options.dashArray){var t,i,a=e.options.dashArray.split(/[, ]+/),n=[];for(i=0;i')}}catch(e){}return function(e){return document.createElement("<"+e+' xmlns="urn:schemas-microsoft.com:vml" class="lvml">')}}(),Za={_initContainer:function(){this._container=ft("div","leaflet-vml-container")},_update:function(){this._map._animatingZoom||(Wa.prototype._update.call(this),this.fire("update"))},_initPath:function(e){var t=e._container=Ga("shape");yt(t,"leaflet-vml-shape "+(this.options.className||"")),t.coordsize="1 1",e._path=Ga("path"),t.appendChild(e._path),this._updateStyle(e),this._layers[s(e)]=e},_addPath:function(e){var t=e._container;this._container.appendChild(t),e.options.interactive&&e.addInteractiveTarget(t)},_removePath:function(e){var t=e._container;gt(t),e.removeInteractiveTarget(t),delete this._layers[s(e)]},_updateStyle:function(e){var t=e._stroke,i=e._fill,a=e.options,n=e._container;n.stroked=!!a.stroke,n.filled=!!a.fill,a.stroke?(t||(t=e._stroke=Ga("stroke")),n.appendChild(t),t.weight=a.weight+"px",t.color=a.color,t.opacity=a.opacity,a.dashArray?t.dashStyle=v(a.dashArray)?a.dashArray.join(" "):a.dashArray.replace(/( *, *)/g," "):t.dashStyle="",t.endcap=a.lineCap.replace("butt","flat"),t.joinstyle=a.lineJoin):t&&(n.removeChild(t),e._stroke=null),a.fill?(i||(i=e._fill=Ga("fill")),n.appendChild(i),i.color=a.fillColor||a.color,i.opacity=a.fillOpacity):i&&(n.removeChild(i),e._fill=null)},_updateCircle:function(e){var t=e._point.round(),i=Math.round(e._radius),a=Math.round(e._radiusY||i);this._setPath(e,e._empty()?"M0 0":"AL "+t.x+","+t.y+" "+i+","+a+" 0,23592600")},_setPath:function(e,t){e._path.v=t},_bringToFront:function(e){vt(e._container)},_bringToBack:function(e){bt(e._container)}},Qa=qe.vml?Ga:K,Ua=Wa.extend({_initContainer:function(){this._container=Qa("svg"),this._container.setAttribute("pointer-events","none"),this._rootGroup=Qa("g"),this._container.appendChild(this._rootGroup)},_destroyContainer:function(){gt(this._container),Xt(this._container),delete this._container,delete this._rootGroup,delete this._svgSize},_update:function(){if(!this._map._animatingZoom||!this._bounds){Wa.prototype._update.call(this);var e=this._bounds,t=e.getSize(),i=this._container;this._svgSize&&this._svgSize.equals(t)||(this._svgSize=t,i.setAttribute("width",t.x),i.setAttribute("height",t.y)),Et(i,e.min),i.setAttribute("viewBox",[e.min.x,e.min.y,t.x,t.y].join(" ")),this.fire("update")}},_initPath:function(e){var t=e._path=Qa("path");e.options.className&&yt(t,e.options.className),e.options.interactive&&yt(t,"leaflet-interactive"),this._updateStyle(e),this._layers[s(e)]=e},_addPath:function(e){this._rootGroup||this._initContainer(),this._rootGroup.appendChild(e._path),e.addInteractiveTarget(e._path)},_removePath:function(e){gt(e._path),e.removeInteractiveTarget(e._path),delete this._layers[s(e)]},_updatePath:function(e){e._project(),e._update()},_updateStyle:function(e){var t=e._path,i=e.options;t&&(i.stroke?(t.setAttribute("stroke",i.color),t.setAttribute("stroke-opacity",i.opacity),t.setAttribute("stroke-width",i.weight),t.setAttribute("stroke-linecap",i.lineCap),t.setAttribute("stroke-linejoin",i.lineJoin),i.dashArray?t.setAttribute("stroke-dasharray",i.dashArray):t.removeAttribute("stroke-dasharray"),i.dashOffset?t.setAttribute("stroke-dashoffset",i.dashOffset):t.removeAttribute("stroke-dashoffset")):t.setAttribute("stroke","none"),i.fill?(t.setAttribute("fill",i.fillColor||i.color),t.setAttribute("fill-opacity",i.fillOpacity),t.setAttribute("fill-rule",i.fillRule||"evenodd")):t.setAttribute("fill","none"))},_updatePoly:function(e,t){this._setPath(e,J(e._parts,t))},_updateCircle:function(e){var t=e._point,i=Math.max(Math.round(e._radius),1),a="a"+i+","+(Math.max(Math.round(e._radiusY),1)||i)+" 0 1,0 ",n=e._empty()?"M0 0":"M"+(t.x-i)+","+t.y+a+2*i+",0 "+a+2*-i+",0 ";this._setPath(e,n)},_setPath:function(e,t){e._path.setAttribute("d",t)},_bringToFront:function(e){vt(e._path)},_bringToBack:function(e){bt(e._path)}});function Ka(e){return qe.svg||qe.vml?new Ua(e):null}qe.vml&&Ua.include(Za),ai.include({getRenderer:function(e){var t=e.options.renderer||this._getPaneRenderer(e.options.pane)||this.options.renderer||this._renderer;return t||(t=this._renderer=this._createRenderer()),this.hasLayer(t)||this.addLayer(t),t},_getPaneRenderer:function(e){if("overlayPane"===e||void 0===e)return!1;var t=this._paneRenderers[e];return void 0===t&&(t=this._createRenderer({pane:e}),this._paneRenderers[e]=t),t},_createRenderer:function(e){return this.options.preferCanvas&&Ya(e)||Ka(e)}});var Ja=da.extend({initialize:function(e,t){da.prototype.initialize.call(this,this._boundsToLatLngs(e),t)},setBounds:function(e){return this.setLatLngs(this._boundsToLatLngs(e))},_boundsToLatLngs:function(e){return[(e=N(e)).getSouthWest(),e.getNorthWest(),e.getNorthEast(),e.getSouthEast()]}});function _a(e,t){return new Ja(e,t)}Ua.create=Qa,Ua.pointsToPath=J,ua.geometryToLayer=pa,ua.coordsToLatLng=ga,ua.coordsToLatLngs=ma,ua.latLngToCoords=va,ua.latLngsToCoords=ba,ua.getFeature=xa,ua.asFeature=ya,ai.mergeOptions({boxZoom:!0});var $a=mi.extend({initialize:function(e){this._map=e,this._container=e._container,this._pane=e._panes.overlayPane,this._resetStateTimeout=0,e.on("unload",this._destroy,this)},addHooks:function(){Tt(this._container,"mousedown",this._onMouseDown,this)},removeHooks:function(){Xt(this._container,"mousedown",this._onMouseDown,this)},moved:function(){return this._moved},_destroy:function(){gt(this._pane),delete this._pane},_resetState:function(){this._resetStateTimeout=0,this._moved=!1},_clearDeferredResetState:function(){0!==this._resetStateTimeout&&(clearTimeout(this._resetStateTimeout),this._resetStateTimeout=0)},_onMouseDown:function(e){if(!e.shiftKey||1!==e.which&&1!==e.button)return!1;this._clearDeferredResetState(),this._resetState(),nt(),Lt(),this._startPoint=this._map.mouseEventToContainerPoint(e),Tt(document,{contextmenu:Ut,mousemove:this._onMouseMove,mouseup:this._onMouseUp,keydown:this._onKeyDown},this)},_onMouseMove:function(e){this._moved||(this._moved=!0,this._box=ft("div","leaflet-zoom-box",this._container),yt(this._container,"leaflet-crosshair"),this._map.fire("boxzoomstart")),this._point=this._map.mouseEventToContainerPoint(e);var t=new D(this._point,this._startPoint),i=t.getSize();Et(this._box,t.min),this._box.style.width=i.x+"px",this._box.style.height=i.y+"px"},_finish:function(){this._moved&&(gt(this._box),wt(this._container,"leaflet-crosshair")),rt(),It(),Xt(document,{contextmenu:Ut,mousemove:this._onMouseMove,mouseup:this._onMouseUp,keydown:this._onKeyDown},this)},_onMouseUp:function(e){if((1===e.which||1===e.button)&&(this._finish(),this._moved)){this._clearDeferredResetState(),this._resetStateTimeout=setTimeout(n(this._resetState,this),0);var t=new T(this._map.containerPointToLatLng(this._startPoint),this._map.containerPointToLatLng(this._point));this._map.fitBounds(t).fire("boxzoomend",{boxZoomBounds:t})}},_onKeyDown:function(e){27===e.keyCode&&(this._finish(),this._clearDeferredResetState(),this._resetState())}});ai.addInitHook("addHandler","boxZoom",$a),ai.mergeOptions({doubleClickZoom:!0});var en=mi.extend({addHooks:function(){this._map.on("dblclick",this._onDoubleClick,this)},removeHooks:function(){this._map.off("dblclick",this._onDoubleClick,this)},_onDoubleClick:function(e){var t=this._map,i=t.getZoom(),a=t.options.zoomDelta,n=e.originalEvent.shiftKey?i-a:i+a;"center"===t.options.doubleClickZoom?t.setZoom(n):t.setZoomAround(e.containerPoint,n)}});ai.addInitHook("addHandler","doubleClickZoom",en),ai.mergeOptions({dragging:!0,inertia:!0,inertiaDeceleration:3400,inertiaMaxSpeed:1/0,easeLinearity:.2,worldCopyJump:!1,maxBoundsViscosity:0});var tn=mi.extend({addHooks:function(){if(!this._draggable){var e=this._map;this._draggable=new xi(e._mapPane,e._container),this._draggable.on({dragstart:this._onDragStart,drag:this._onDrag,dragend:this._onDragEnd},this),this._draggable.on("predrag",this._onPreDragLimit,this),e.options.worldCopyJump&&(this._draggable.on("predrag",this._onPreDragWrap,this),e.on("zoomend",this._onZoomEnd,this),e.whenReady(this._onZoomEnd,this))}yt(this._map._container,"leaflet-grab leaflet-touch-drag"),this._draggable.enable(),this._positions=[],this._times=[]},removeHooks:function(){wt(this._map._container,"leaflet-grab"),wt(this._map._container,"leaflet-touch-drag"),this._draggable.disable()},moved:function(){return this._draggable&&this._draggable._moved},moving:function(){return this._draggable&&this._draggable._moving},_onDragStart:function(){var e=this._map;if(e._stop(),this._map.options.maxBounds&&this._map.options.maxBoundsViscosity){var t=N(this._map.options.maxBounds);this._offsetLimit=q(this._map.latLngToContainerPoint(t.getNorthWest()).multiplyBy(-1),this._map.latLngToContainerPoint(t.getSouthEast()).multiplyBy(-1).add(this._map.getSize())),this._viscosity=Math.min(1,Math.max(0,this._map.options.maxBoundsViscosity))}else this._offsetLimit=null;e.fire("movestart").fire("dragstart"),e.options.inertia&&(this._positions=[],this._times=[])},_onDrag:function(e){if(this._map.options.inertia){var t=this._lastTime=+new Date,i=this._lastPos=this._draggable._absPos||this._draggable._newPos;this._positions.push(i),this._times.push(t),this._prunePositions(t)}this._map.fire("move",e).fire("drag",e)},_prunePositions:function(e){for(;this._positions.length>1&&e-this._times[0]>50;)this._positions.shift(),this._times.shift()},_onZoomEnd:function(){var e=this._map.getSize().divideBy(2),t=this._map.latLngToLayerPoint([0,0]);this._initialWorldOffset=t.subtract(e).x,this._worldWidth=this._map.getPixelWorldBounds().getSize().x},_viscousLimit:function(e,t){return e-(e-t)*this._viscosity},_onPreDragLimit:function(){if(this._viscosity&&this._offsetLimit){var e=this._draggable._newPos.subtract(this._draggable._startPos),t=this._offsetLimit;e.xt.max.x&&(e.x=this._viscousLimit(e.x,t.max.x)),e.y>t.max.y&&(e.y=this._viscousLimit(e.y,t.max.y)),this._draggable._newPos=this._draggable._startPos.add(e)}},_onPreDragWrap:function(){var e=this._worldWidth,t=Math.round(e/2),i=this._initialWorldOffset,a=this._draggable._newPos.x,n=(a-t+i)%e+t-i,r=(a+t+i)%e-t-i,s=Math.abs(n+i)0?r:-r))-t;this._delta=0,this._startTime=null,s&&("center"===e.options.scrollWheelZoom?e.setZoom(t+s):e.setZoomAround(this._lastMousePos,t+s))}});ai.addInitHook("addHandler","scrollWheelZoom",nn);var rn=600;ai.mergeOptions({tapHold:qe.touchNative&&qe.safari&&qe.mobile,tapTolerance:15});var sn=mi.extend({addHooks:function(){Tt(this._map._container,"touchstart",this._onDown,this)},removeHooks:function(){Xt(this._map._container,"touchstart",this._onDown,this)},_onDown:function(e){if(clearTimeout(this._holdTimeout),1===e.touches.length){var t=e.touches[0];this._startPos=this._newPos=new B(t.clientX,t.clientY),this._holdTimeout=setTimeout(n((function(){this._cancel(),this._isTapValid()&&(Tt(document,"touchend",Qt),Tt(document,"touchend touchcancel",this._cancelClickPrevent),this._simulateEvent("contextmenu",t))}),this),rn),Tt(document,"touchend touchcancel contextmenu",this._cancel,this),Tt(document,"touchmove",this._onMove,this)}},_cancelClickPrevent:function e(){Xt(document,"touchend",Qt),Xt(document,"touchend touchcancel",e)},_cancel:function(){clearTimeout(this._holdTimeout),Xt(document,"touchend touchcancel contextmenu",this._cancel,this),Xt(document,"touchmove",this._onMove,this)},_onMove:function(e){var t=e.touches[0];this._newPos=new B(t.clientX,t.clientY)},_isTapValid:function(){return this._newPos.distanceTo(this._startPos)<=this._map.options.tapTolerance},_simulateEvent:function(e,t){var i=new MouseEvent(e,{bubbles:!0,cancelable:!0,view:window,screenX:t.screenX,screenY:t.screenY,clientX:t.clientX,clientY:t.clientY});i._simulated=!0,t.target.dispatchEvent(i)}});ai.addInitHook("addHandler","tapHold",sn),ai.mergeOptions({touchZoom:qe.touch,bounceAtZoomLimits:!0});var on=mi.extend({addHooks:function(){yt(this._map._container,"leaflet-touch-zoom"),Tt(this._map._container,"touchstart",this._onTouchStart,this)},removeHooks:function(){wt(this._map._container,"leaflet-touch-zoom"),Xt(this._map._container,"touchstart",this._onTouchStart,this)},_onTouchStart:function(e){var t=this._map;if(e.touches&&2===e.touches.length&&!t._animatingZoom&&!this._zooming){var i=t.mouseEventToContainerPoint(e.touches[0]),a=t.mouseEventToContainerPoint(e.touches[1]);this._centerPoint=t.getSize()._divideBy(2),this._startLatLng=t.containerPointToLatLng(this._centerPoint),"center"!==t.options.touchZoom&&(this._pinchStartLatLng=t.containerPointToLatLng(i.add(a)._divideBy(2))),this._startDist=i.distanceTo(a),this._startZoom=t.getZoom(),this._moved=!1,this._zooming=!0,t._stop(),Tt(document,"touchmove",this._onTouchMove,this),Tt(document,"touchend touchcancel",this._onTouchEnd,this),Qt(e)}},_onTouchMove:function(e){if(e.touches&&2===e.touches.length&&this._zooming){var t=this._map,i=t.mouseEventToContainerPoint(e.touches[0]),a=t.mouseEventToContainerPoint(e.touches[1]),r=i.distanceTo(a)/this._startDist;if(this._zoom=t.getScaleZoom(r,this._startZoom),!t.options.bounceAtZoomLimits&&(this._zoomt.getMaxZoom()&&r>1)&&(this._zoom=t._limitZoom(this._zoom)),"center"===t.options.touchZoom){if(this._center=this._startLatLng,1===r)return}else{var s=i._add(a)._divideBy(2)._subtract(this._centerPoint);if(1===r&&0===s.x&&0===s.y)return;this._center=t.unproject(t.project(this._pinchStartLatLng,this._zoom).subtract(s),this._zoom)}this._moved||(t._moveStart(!0,!1),this._moved=!0),S(this._animRequest);var o=n(t._move,t,this._center,this._zoom,{pinch:!0,round:!1},void 0);this._animRequest=P(o,this,!0),Qt(e)}},_onTouchEnd:function(){this._moved&&this._zooming?(this._zooming=!1,S(this._animRequest),Xt(document,"touchmove",this._onTouchMove,this),Xt(document,"touchend touchcancel",this._onTouchEnd,this),this._map.options.zoomAnimation?this._map._animateZoom(this._center,this._map._limitZoom(this._zoom),!0,this._map.options.zoomSnap):this._map._resetView(this._center,this._map._limitZoom(this._zoom))):this._zooming=!1}});ai.addInitHook("addHandler","touchZoom",on),ai.BoxZoom=$a,ai.DoubleClickZoom=en,ai.Drag=tn,ai.Keyboard=an,ai.ScrollWheelZoom=nn,ai.TapHold=sn,ai.TouchZoom=on,e.Bounds=D,e.Browser=qe,e.CRS=F,e.Canvas=Ha,e.Circle=sa,e.CircleMarker=na,e.Class=E,e.Control=ri,e.DivIcon=Ra,e.DivOverlay=Oa,e.DomEvent=ti,e.DomUtil=qt,e.Draggable=xi,e.Evented=I,e.FeatureGroup=Ui,e.GeoJSON=ua,e.GridLayer=qa,e.Handler=mi,e.Icon=Ji,e.ImageOverlay=za,e.LatLng=X,e.LatLngBounds=T,e.Layer=Gi,e.LayerGroup=Zi,e.LineUtil=Ni,e.Map=ai,e.Marker=ta,e.Mixin=vi,e.Path=aa,e.Point=B,e.PolyUtil=zi,e.Polygon=da,e.Polyline=la,e.Popup=La,e.PosAnimation=ii,e.Projection=Fi,e.Rectangle=Ja,e.Renderer=Wa,e.SVG=Ua,e.SVGOverlay=Ea,e.TileLayer=Na,e.Tooltip=Ba,e.Transformation=G,e.Util=k,e.VideoOverlay=Sa,e.bind=n,e.bounds=q,e.canvas=Ya,e.circle=oa,e.circleMarker=ra,e.control=si,e.divIcon=Da,e.extend=i,e.featureGroup=Ki,e.geoJSON=Aa,e.geoJson=Ca,e.gridLayer=Ta,e.icon=_i,e.imageOverlay=Pa,e.latLng=j,e.latLngBounds=N,e.layerGroup=Qi,e.map=ni,e.marker=ia,e.point=R,e.polygon=ha,e.polyline=ca,e.popup=Ia,e.rectangle=_a,e.setOptions=p,e.stamp=s,e.svg=Ka,e.svgOverlay=Ma,e.tileLayer=Xa,e.tooltip=Va,e.transformation=Z,e.version=t,e.videoOverlay=ka;var ln=window.L;e.noConflict=function(){return window.L=ln,this},window.L=e}(t)}));zi((function(e){var t;t=function(e){return e.TileLayer.Provider=e.TileLayer.extend({initialize:function(t,i){var a=e.TileLayer.Provider.providers,n=t.split("."),r=n[0],s=n[1];if(!a[r])throw"No such provider ("+r+")";var o={url:a[r].url,options:a[r].options};if(s&&"variants"in a[r]){if(!(s in a[r].variants))throw"No such variant of "+r+" ("+s+")";var l,c=a[r].variants[s];l="string"==typeof c?{variant:c}:c.options,o={url:c.url||o.url,options:e.Util.extend({},o.options,l)}}var d=function(e){return-1===e.indexOf("{attribution.")?e:e.replace(/\{attribution.(\w*)\}/g,(function(e,t){return d(a[t].options.attribution)}))};o.options.attribution=d(o.options.attribution);var h=e.Util.extend({},o.options,i);e.TileLayer.prototype.initialize.call(this,o.url,h)}}),e.TileLayer.Provider.providers={OpenStreetMap:{url:"https://tile.openstreetmap.org/{z}/{x}/{y}.png",options:{maxZoom:19,attribution:'© OpenStreetMap contributors'},variants:{Mapnik:{},DE:{url:"https://tile.openstreetmap.de/{z}/{x}/{y}.png",options:{maxZoom:18}},CH:{url:"https://tile.osm.ch/switzerland/{z}/{x}/{y}.png",options:{maxZoom:18,bounds:[[45,5],[48,11]]}},France:{url:"https://{s}.tile.openstreetmap.fr/osmfr/{z}/{x}/{y}.png",options:{maxZoom:20,attribution:"© OpenStreetMap France | {attribution.OpenStreetMap}"}},HOT:{url:"https://{s}.tile.openstreetmap.fr/hot/{z}/{x}/{y}.png",options:{attribution:'{attribution.OpenStreetMap}, Tiles style by Humanitarian OpenStreetMap Team hosted by OpenStreetMap France '}},BZH:{url:"https://tile.openstreetmap.bzh/br/{z}/{x}/{y}.png",options:{attribution:'{attribution.OpenStreetMap}, Tiles courtesy of Breton OpenStreetMap Team ',bounds:[[46.2,-5.5],[50,.7]]}}}},MapTilesAPI:{url:"https://maptiles.p.rapidapi.com/{variant}/{z}/{x}/{y}.png?rapidapi-key={apikey}",options:{attribution:'© MapTiles API , {attribution.OpenStreetMap}',variant:"en/map/v1",apikey:"",maxZoom:19},variants:{OSMEnglish:{options:{variant:"en/map/v1"}},OSMFrancais:{options:{variant:"fr/map/v1"}},OSMEspagnol:{options:{variant:"es/map/v1"}}}},OpenSeaMap:{url:"https://tiles.openseamap.org/seamark/{z}/{x}/{y}.png",options:{attribution:'Map data: © OpenSeaMap contributors'}},OPNVKarte:{url:"https://tileserver.memomaps.de/tilegen/{z}/{x}/{y}.png",options:{maxZoom:18,attribution:'Map memomaps.de CC-BY-SA , map data {attribution.OpenStreetMap}'}},OpenTopoMap:{url:"https://{s}.tile.opentopomap.org/{z}/{x}/{y}.png",options:{maxZoom:17,attribution:'Map data: {attribution.OpenStreetMap}, SRTM | Map style: © OpenTopoMap (CC-BY-SA )'}},OpenRailwayMap:{url:"https://{s}.tiles.openrailwaymap.org/standard/{z}/{x}/{y}.png",options:{maxZoom:19,attribution:'Map data: {attribution.OpenStreetMap} | Map style: © OpenRailwayMap (CC-BY-SA )'}},OpenFireMap:{url:"http://openfiremap.org/hytiles/{z}/{x}/{y}.png",options:{maxZoom:19,attribution:'Map data: {attribution.OpenStreetMap} | Map style: © OpenFireMap (CC-BY-SA )'}},SafeCast:{url:"https://s3.amazonaws.com/te512.safecast.org/{z}/{x}/{y}.png",options:{maxZoom:16,attribution:'Map data: {attribution.OpenStreetMap} | Map style: © SafeCast (CC-BY-SA )'}},Stadia:{url:"https://tiles.stadiamaps.com/tiles/{variant}/{z}/{x}/{y}{r}.{ext}",options:{minZoom:0,maxZoom:20,attribution:'© Stadia Maps © OpenMapTiles {attribution.OpenStreetMap}',variant:"alidade_smooth",ext:"png"},variants:{AlidadeSmooth:"alidade_smooth",AlidadeSmoothDark:"alidade_smooth_dark",OSMBright:"osm_bright",Outdoors:"outdoors",StamenToner:{options:{attribution:'© Stadia Maps © Stamen Design © OpenMapTiles {attribution.OpenStreetMap}',variant:"stamen_toner"}},StamenTonerBackground:{options:{attribution:'© Stadia Maps © Stamen Design © OpenMapTiles {attribution.OpenStreetMap}',variant:"stamen_toner_background"}},StamenTonerLines:{options:{attribution:'© Stadia Maps © Stamen Design © OpenMapTiles {attribution.OpenStreetMap}',variant:"stamen_toner_lines"}},StamenTonerLabels:{options:{attribution:'© Stadia Maps © Stamen Design © OpenMapTiles {attribution.OpenStreetMap}',variant:"stamen_toner_labels"}},StamenTonerLite:{options:{attribution:'© Stadia Maps © Stamen Design © OpenMapTiles {attribution.OpenStreetMap}',variant:"stamen_toner_lite"}},StamenWatercolor:{url:"https://tiles.stadiamaps.com/tiles/{variant}/{z}/{x}/{y}.{ext}",options:{attribution:'© Stadia Maps © Stamen Design © OpenMapTiles {attribution.OpenStreetMap}',variant:"stamen_watercolor",ext:"jpg",minZoom:1,maxZoom:16}},StamenTerrain:{options:{attribution:'© Stadia Maps © Stamen Design © OpenMapTiles {attribution.OpenStreetMap}',variant:"stamen_terrain",minZoom:0,maxZoom:18}},StamenTerrainBackground:{options:{attribution:'© Stadia Maps © Stamen Design © OpenMapTiles {attribution.OpenStreetMap}',variant:"stamen_terrain_background",minZoom:0,maxZoom:18}},StamenTerrainLabels:{options:{attribution:'© Stadia Maps © Stamen Design © OpenMapTiles {attribution.OpenStreetMap}',variant:"stamen_terrain_labels",minZoom:0,maxZoom:18}},StamenTerrainLines:{options:{attribution:'© Stadia Maps © Stamen Design © OpenMapTiles {attribution.OpenStreetMap}',variant:"stamen_terrain_lines",minZoom:0,maxZoom:18}}}},Thunderforest:{url:"https://{s}.tile.thunderforest.com/{variant}/{z}/{x}/{y}.png?apikey={apikey}",options:{attribution:'© Thunderforest , {attribution.OpenStreetMap}',variant:"cycle",apikey:"",maxZoom:22},variants:{OpenCycleMap:"cycle",Transport:{options:{variant:"transport"}},TransportDark:{options:{variant:"transport-dark"}},SpinalMap:{options:{variant:"spinal-map"}},Landscape:"landscape",Outdoors:"outdoors",Pioneer:"pioneer",MobileAtlas:"mobile-atlas",Neighbourhood:"neighbourhood"}},CyclOSM:{url:"https://{s}.tile-cyclosm.openstreetmap.fr/cyclosm/{z}/{x}/{y}.png",options:{maxZoom:20,attribution:'CyclOSM | Map data: {attribution.OpenStreetMap}'}},Jawg:{url:"https://{s}.tile.jawg.io/{variant}/{z}/{x}/{y}{r}.png?access-token={accessToken}",options:{attribution:'© Jawg Maps {attribution.OpenStreetMap}',minZoom:0,maxZoom:22,subdomains:"abcd",variant:"jawg-terrain",accessToken:""},variants:{Streets:"jawg-streets",Terrain:"jawg-terrain",Sunny:"jawg-sunny",Dark:"jawg-dark",Light:"jawg-light",Matrix:"jawg-matrix"}},MapBox:{url:"https://api.mapbox.com/styles/v1/{id}/tiles/{z}/{x}/{y}{r}?access_token={accessToken}",options:{attribution:'© Mapbox {attribution.OpenStreetMap} Improve this map ',tileSize:512,maxZoom:18,zoomOffset:-1,id:"mapbox/streets-v11",accessToken:""}},MapTiler:{url:"https://api.maptiler.com/maps/{variant}/{z}/{x}/{y}{r}.{ext}?key={key}",options:{attribution:'© MapTiler © OpenStreetMap contributors ',variant:"streets",ext:"png",key:"",tileSize:512,zoomOffset:-1,minZoom:0,maxZoom:21},variants:{Streets:"streets",Basic:"basic",Bright:"bright",Pastel:"pastel",Positron:"positron",Hybrid:{options:{variant:"hybrid",ext:"jpg"}},Toner:"toner",Topo:"topo",Voyager:"voyager"}},TomTom:{url:"https://{s}.api.tomtom.com/map/1/tile/{variant}/{style}/{z}/{x}/{y}.{ext}?key={apikey}",options:{variant:"basic",maxZoom:22,attribution:'© 1992 - '+(new Date).getFullYear()+" TomTom. ",subdomains:"abcd",style:"main",ext:"png",apikey:""},variants:{Basic:"basic",Hybrid:"hybrid",Labels:"labels"}},Esri:{url:"https://server.arcgisonline.com/ArcGIS/rest/services/{variant}/MapServer/tile/{z}/{y}/{x}",options:{variant:"World_Street_Map",attribution:"Tiles © Esri"},variants:{WorldStreetMap:{options:{attribution:"{attribution.Esri} — Source: Esri, DeLorme, NAVTEQ, USGS, Intermap, iPC, NRCAN, Esri Japan, METI, Esri China (Hong Kong), Esri (Thailand), TomTom, 2012"}},DeLorme:{options:{variant:"Specialty/DeLorme_World_Base_Map",minZoom:1,maxZoom:11,attribution:"{attribution.Esri} — Copyright: ©2012 DeLorme"}},WorldTopoMap:{options:{variant:"World_Topo_Map",attribution:"{attribution.Esri} — Esri, DeLorme, NAVTEQ, TomTom, Intermap, iPC, USGS, FAO, NPS, NRCAN, GeoBase, Kadaster NL, Ordnance Survey, Esri Japan, METI, Esri China (Hong Kong), and the GIS User Community"}},WorldImagery:{options:{variant:"World_Imagery",attribution:"{attribution.Esri} — Source: Esri, i-cubed, USDA, USGS, AEX, GeoEye, Getmapping, Aerogrid, IGN, IGP, UPR-EGP, and the GIS User Community"}},WorldTerrain:{options:{variant:"World_Terrain_Base",maxZoom:13,attribution:"{attribution.Esri} — Source: USGS, Esri, TANA, DeLorme, and NPS"}},WorldShadedRelief:{options:{variant:"World_Shaded_Relief",maxZoom:13,attribution:"{attribution.Esri} — Source: Esri"}},WorldPhysical:{options:{variant:"World_Physical_Map",maxZoom:8,attribution:"{attribution.Esri} — Source: US National Park Service"}},OceanBasemap:{options:{variant:"Ocean/World_Ocean_Base",maxZoom:13,attribution:"{attribution.Esri} — Sources: GEBCO, NOAA, CHS, OSU, UNH, CSUMB, National Geographic, DeLorme, NAVTEQ, and Esri"}},NatGeoWorldMap:{options:{variant:"NatGeo_World_Map",maxZoom:16,attribution:"{attribution.Esri} — National Geographic, Esri, DeLorme, NAVTEQ, UNEP-WCMC, USGS, NASA, ESA, METI, NRCAN, GEBCO, NOAA, iPC"}},WorldGrayCanvas:{options:{variant:"Canvas/World_Light_Gray_Base",maxZoom:16,attribution:"{attribution.Esri} — Esri, DeLorme, NAVTEQ"}}}},OpenWeatherMap:{url:"http://{s}.tile.openweathermap.org/map/{variant}/{z}/{x}/{y}.png?appid={apiKey}",options:{maxZoom:19,attribution:'Map data © OpenWeatherMap ',apiKey:"",opacity:.5},variants:{Clouds:"clouds",CloudsClassic:"clouds_cls",Precipitation:"precipitation",PrecipitationClassic:"precipitation_cls",Rain:"rain",RainClassic:"rain_cls",Pressure:"pressure",PressureContour:"pressure_cntr",Wind:"wind",Temperature:"temp",Snow:"snow"}},HERE:{url:"https://{s}.{base}.maps.api.here.com/maptile/2.1/{type}/{mapID}/{variant}/{z}/{x}/{y}/{size}/{format}?app_id={app_id}&app_code={app_code}&lg={language}",options:{attribution:"Map © 1987-"+(new Date).getFullYear()+' HERE ',subdomains:"1234",mapID:"newest",app_id:"",app_code:"",base:"base",variant:"normal.day",maxZoom:20,type:"maptile",language:"eng",format:"png8",size:"256"},variants:{normalDay:"normal.day",normalDayCustom:"normal.day.custom",normalDayGrey:"normal.day.grey",normalDayMobile:"normal.day.mobile",normalDayGreyMobile:"normal.day.grey.mobile",normalDayTransit:"normal.day.transit",normalDayTransitMobile:"normal.day.transit.mobile",normalDayTraffic:{options:{variant:"normal.traffic.day",base:"traffic",type:"traffictile"}},normalNight:"normal.night",normalNightMobile:"normal.night.mobile",normalNightGrey:"normal.night.grey",normalNightGreyMobile:"normal.night.grey.mobile",normalNightTransit:"normal.night.transit",normalNightTransitMobile:"normal.night.transit.mobile",reducedDay:"reduced.day",reducedNight:"reduced.night",basicMap:{options:{type:"basetile"}},mapLabels:{options:{type:"labeltile",format:"png"}},trafficFlow:{options:{base:"traffic",type:"flowtile"}},carnavDayGrey:"carnav.day.grey",hybridDay:{options:{base:"aerial",variant:"hybrid.day"}},hybridDayMobile:{options:{base:"aerial",variant:"hybrid.day.mobile"}},hybridDayTransit:{options:{base:"aerial",variant:"hybrid.day.transit"}},hybridDayGrey:{options:{base:"aerial",variant:"hybrid.grey.day"}},hybridDayTraffic:{options:{variant:"hybrid.traffic.day",base:"traffic",type:"traffictile"}},pedestrianDay:"pedestrian.day",pedestrianNight:"pedestrian.night",satelliteDay:{options:{base:"aerial",variant:"satellite.day"}},terrainDay:{options:{base:"aerial",variant:"terrain.day"}},terrainDayMobile:{options:{base:"aerial",variant:"terrain.day.mobile"}}}},HEREv3:{url:"https://{s}.{base}.maps.ls.hereapi.com/maptile/2.1/{type}/{mapID}/{variant}/{z}/{x}/{y}/{size}/{format}?apiKey={apiKey}&lg={language}",options:{attribution:"Map © 1987-"+(new Date).getFullYear()+' HERE ',subdomains:"1234",mapID:"newest",apiKey:"",base:"base",variant:"normal.day",maxZoom:20,type:"maptile",language:"eng",format:"png8",size:"256"},variants:{normalDay:"normal.day",normalDayCustom:"normal.day.custom",normalDayGrey:"normal.day.grey",normalDayMobile:"normal.day.mobile",normalDayGreyMobile:"normal.day.grey.mobile",normalDayTransit:"normal.day.transit",normalDayTransitMobile:"normal.day.transit.mobile",normalNight:"normal.night",normalNightMobile:"normal.night.mobile",normalNightGrey:"normal.night.grey",normalNightGreyMobile:"normal.night.grey.mobile",normalNightTransit:"normal.night.transit",normalNightTransitMobile:"normal.night.transit.mobile",reducedDay:"reduced.day",reducedNight:"reduced.night",basicMap:{options:{type:"basetile"}},mapLabels:{options:{type:"labeltile",format:"png"}},trafficFlow:{options:{base:"traffic",type:"flowtile"}},carnavDayGrey:"carnav.day.grey",hybridDay:{options:{base:"aerial",variant:"hybrid.day"}},hybridDayMobile:{options:{base:"aerial",variant:"hybrid.day.mobile"}},hybridDayTransit:{options:{base:"aerial",variant:"hybrid.day.transit"}},hybridDayGrey:{options:{base:"aerial",variant:"hybrid.grey.day"}},pedestrianDay:"pedestrian.day",pedestrianNight:"pedestrian.night",satelliteDay:{options:{base:"aerial",variant:"satellite.day"}},terrainDay:{options:{base:"aerial",variant:"terrain.day"}},terrainDayMobile:{options:{base:"aerial",variant:"terrain.day.mobile"}}}},FreeMapSK:{url:"https://{s}.freemap.sk/T/{z}/{x}/{y}.jpeg",options:{minZoom:8,maxZoom:16,subdomains:"abcd",bounds:[[47.204642,15.996093],[49.830896,22.576904]],attribution:'{attribution.OpenStreetMap}, visualization CC-By-SA 2.0 Freemap.sk '}},MtbMap:{url:"http://tile.mtbmap.cz/mtbmap_tiles/{z}/{x}/{y}.png",options:{attribution:"{attribution.OpenStreetMap} & USGS"}},CartoDB:{url:"https://{s}.basemaps.cartocdn.com/{variant}/{z}/{x}/{y}{r}.png",options:{attribution:'{attribution.OpenStreetMap} © CARTO ',subdomains:"abcd",maxZoom:20,variant:"light_all"},variants:{Positron:"light_all",PositronNoLabels:"light_nolabels",PositronOnlyLabels:"light_only_labels",DarkMatter:"dark_all",DarkMatterNoLabels:"dark_nolabels",DarkMatterOnlyLabels:"dark_only_labels",Voyager:"rastertiles/voyager",VoyagerNoLabels:"rastertiles/voyager_nolabels",VoyagerOnlyLabels:"rastertiles/voyager_only_labels",VoyagerLabelsUnder:"rastertiles/voyager_labels_under"}},HikeBike:{url:"https://tiles.wmflabs.org/{variant}/{z}/{x}/{y}.png",options:{maxZoom:19,attribution:"{attribution.OpenStreetMap}",variant:"hikebike"},variants:{HikeBike:{},HillShading:{options:{maxZoom:15,variant:"hillshading"}}}},BasemapAT:{url:"https://mapsneu.wien.gv.at/basemap/{variant}/{type}/google3857/{z}/{y}/{x}.{format}",options:{maxZoom:19,attribution:'Datenquelle: basemap.at ',type:"normal",format:"png",bounds:[[46.35877,8.782379],[49.037872,17.189532]],variant:"geolandbasemap"},variants:{basemap:{options:{maxZoom:20,variant:"geolandbasemap"}},grau:"bmapgrau",overlay:"bmapoverlay",terrain:{options:{variant:"bmapgelaende",type:"grau",format:"jpeg"}},surface:{options:{variant:"bmapoberflaeche",type:"grau",format:"jpeg"}},highdpi:{options:{variant:"bmaphidpi",format:"jpeg"}},orthofoto:{options:{maxZoom:20,variant:"bmaporthofoto30cm",format:"jpeg"}}}},nlmaps:{url:"https://service.pdok.nl/brt/achtergrondkaart/wmts/v2_0/{variant}/EPSG:3857/{z}/{x}/{y}.png",options:{minZoom:6,maxZoom:19,bounds:[[50.5,3.25],[54,7.6]],attribution:'Kaartgegevens © Kadaster '},variants:{standaard:"standaard",pastel:"pastel",grijs:"grijs",water:"water",luchtfoto:{url:"https://service.pdok.nl/hwh/luchtfotorgb/wmts/v1_0/Actueel_ortho25/EPSG:3857/{z}/{x}/{y}.jpeg"}}},NASAGIBS:{url:"https://map1.vis.earthdata.nasa.gov/wmts-webmerc/{variant}/default/{time}/{tilematrixset}{maxZoom}/{z}/{y}/{x}.{format}",options:{attribution:'Imagery provided by services from the Global Imagery Browse Services (GIBS), operated by the NASA/GSFC/Earth Science Data and Information System (ESDIS ) with funding provided by NASA/HQ.',bounds:[[-85.0511287776,-179.999999975],[85.0511287776,179.999999975]],minZoom:1,maxZoom:9,format:"jpg",time:"",tilematrixset:"GoogleMapsCompatible_Level"},variants:{ModisTerraTrueColorCR:"MODIS_Terra_CorrectedReflectance_TrueColor",ModisTerraBands367CR:"MODIS_Terra_CorrectedReflectance_Bands367",ViirsEarthAtNight2012:{options:{variant:"VIIRS_CityLights_2012",maxZoom:8}},ModisTerraLSTDay:{options:{variant:"MODIS_Terra_Land_Surface_Temp_Day",format:"png",maxZoom:7,opacity:.75}},ModisTerraSnowCover:{options:{variant:"MODIS_Terra_NDSI_Snow_Cover",format:"png",maxZoom:8,opacity:.75}},ModisTerraAOD:{options:{variant:"MODIS_Terra_Aerosol",format:"png",maxZoom:6,opacity:.75}},ModisTerraChlorophyll:{options:{variant:"MODIS_Terra_Chlorophyll_A",format:"png",maxZoom:7,opacity:.75}}}},NLS:{url:"https://nls-{s}.tileserver.com/nls/{z}/{x}/{y}.jpg",options:{attribution:'National Library of Scotland Historic Maps ',bounds:[[49.6,-12],[61.7,3]],minZoom:1,maxZoom:18,subdomains:"0123"}},JusticeMap:{url:"https://www.justicemap.org/tile/{size}/{variant}/{z}/{x}/{y}.png",options:{attribution:'Justice Map ',size:"county",bounds:[[14,-180],[72,-56]]},variants:{income:"income",americanIndian:"indian",asian:"asian",black:"black",hispanic:"hispanic",multi:"multi",nonWhite:"nonwhite",white:"white",plurality:"plural"}},GeoportailFrance:{url:"https://wxs.ign.fr/{apikey}/geoportail/wmts?REQUEST=GetTile&SERVICE=WMTS&VERSION=1.0.0&STYLE={style}&TILEMATRIXSET=PM&FORMAT={format}&LAYER={variant}&TILEMATRIX={z}&TILEROW={y}&TILECOL={x}",options:{attribution:'Geoportail France ',bounds:[[-75,-180],[81,180]],minZoom:2,maxZoom:18,apikey:"choisirgeoportail",format:"image/png",style:"normal",variant:"GEOGRAPHICALGRIDSYSTEMS.PLANIGNV2"},variants:{plan:"GEOGRAPHICALGRIDSYSTEMS.PLANIGNV2",parcels:{options:{variant:"CADASTRALPARCELS.PARCELLAIRE_EXPRESS",style:"PCI vecteur",maxZoom:20}},orthos:{options:{maxZoom:19,format:"image/jpeg",variant:"ORTHOIMAGERY.ORTHOPHOTOS"}}}},OneMapSG:{url:"https://maps-{s}.onemap.sg/v3/{variant}/{z}/{x}/{y}.png",options:{variant:"Default",minZoom:11,maxZoom:18,bounds:[[1.56073,104.11475],[1.16,103.502]],attribution:' New OneMap | Map data © contributors, Singapore Land Authority '},variants:{Default:"Default",Night:"Night",Original:"Original",Grey:"Grey",LandLot:"LandLot"}},USGS:{url:"https://basemap.nationalmap.gov/arcgis/rest/services/USGSTopo/MapServer/tile/{z}/{y}/{x}",options:{maxZoom:20,attribution:'Tiles courtesy of the U.S. Geological Survey '},variants:{USTopo:{},USImagery:{url:"https://basemap.nationalmap.gov/arcgis/rest/services/USGSImageryOnly/MapServer/tile/{z}/{y}/{x}"},USImageryTopo:{url:"https://basemap.nationalmap.gov/arcgis/rest/services/USGSImageryTopo/MapServer/tile/{z}/{y}/{x}"}}},WaymarkedTrails:{url:"https://tile.waymarkedtrails.org/{variant}/{z}/{x}/{y}.png",options:{maxZoom:18,attribution:'Map data: {attribution.OpenStreetMap} | Map style: © waymarkedtrails.org (CC-BY-SA )'},variants:{hiking:"hiking",cycling:"cycling",mtb:"mtb",slopes:"slopes",riding:"riding",skating:"skating"}},OpenAIP:{url:"https://{s}.tile.maps.openaip.net/geowebcache/service/tms/1.0.0/openaip_basemap@EPSG%3A900913@png/{z}/{x}/{y}.{ext}",options:{attribution:'openAIP Data (CC-BY-NC-SA )',ext:"png",minZoom:4,maxZoom:14,tms:!0,detectRetina:!0,subdomains:"12"}},OpenSnowMap:{url:"https://tiles.opensnowmap.org/{variant}/{z}/{x}/{y}.png",options:{minZoom:9,maxZoom:18,attribution:'Map data: {attribution.OpenStreetMap} & ODbL, © www.opensnowmap.org CC-BY-SA '},variants:{pistes:"pistes"}},AzureMaps:{url:"https://atlas.microsoft.com/map/tile?api-version={apiVersion}&tilesetId={variant}&x={x}&y={y}&zoom={z}&language={language}&subscription-key={subscriptionKey}",options:{attribution:"See https://docs.microsoft.com/en-us/rest/api/maps/render-v2/get-map-tile for details.",apiVersion:"2.0",variant:"microsoft.imagery",subscriptionKey:"",language:"en-US"},variants:{MicrosoftImagery:"microsoft.imagery",MicrosoftBaseDarkGrey:"microsoft.base.darkgrey",MicrosoftBaseRoad:"microsoft.base.road",MicrosoftBaseHybridRoad:"microsoft.base.hybrid.road",MicrosoftTerraMain:"microsoft.terra.main",MicrosoftWeatherInfraredMain:{url:"https://atlas.microsoft.com/map/tile?api-version={apiVersion}&tilesetId={variant}&x={x}&y={y}&zoom={z}&timeStamp={timeStamp}&language={language}&subscription-key={subscriptionKey}",options:{timeStamp:"2021-05-08T09:03:00Z",attribution:"See https://docs.microsoft.com/en-us/rest/api/maps/render-v2/get-map-tile#uri-parameters for details.",variant:"microsoft.weather.infrared.main"}},MicrosoftWeatherRadarMain:{url:"https://atlas.microsoft.com/map/tile?api-version={apiVersion}&tilesetId={variant}&x={x}&y={y}&zoom={z}&timeStamp={timeStamp}&language={language}&subscription-key={subscriptionKey}",options:{timeStamp:"2021-05-08T09:03:00Z",attribution:"See https://docs.microsoft.com/en-us/rest/api/maps/render-v2/get-map-tile#uri-parameters for details.",variant:"microsoft.weather.radar.main"}}}},SwissFederalGeoportal:{url:"https://wmts.geo.admin.ch/1.0.0/{variant}/default/current/3857/{z}/{x}/{y}.jpeg",options:{attribution:'© swisstopo ',minZoom:2,maxZoom:18,bounds:[[45.398181,5.140242],[48.230651,11.47757]]},variants:{NationalMapColor:"ch.swisstopo.pixelkarte-farbe",NationalMapGrey:"ch.swisstopo.pixelkarte-grau",SWISSIMAGE:{options:{variant:"ch.swisstopo.swissimage",maxZoom:19}}}}},e.tileLayer.provider=function(t,i){return new e.TileLayer.Provider(t,i)},e},"object"==typeof modules&&e.exports?e.exports=t(Pi):t(L)}));var Si=o`/* required styles */
-
-.leaflet-pane,
-.leaflet-tile,
-.leaflet-marker-icon,
-.leaflet-marker-shadow,
-.leaflet-tile-container,
-.leaflet-pane > svg,
-.leaflet-pane > canvas,
-.leaflet-zoom-box,
-.leaflet-image-layer,
-.leaflet-layer {
- position: absolute;
- left: 0;
- top: 0;
- }
-.leaflet-container {
- overflow: hidden;
- }
-.leaflet-tile,
-.leaflet-marker-icon,
-.leaflet-marker-shadow {
- -webkit-user-select: none;
- -moz-user-select: none;
- user-select: none;
- -webkit-user-drag: none;
- }
-/* Prevents IE11 from highlighting tiles in blue */
-.leaflet-tile::-moz-selection {
- background: transparent;
-}
-.leaflet-tile::selection {
- background: transparent;
-}
-/* Safari renders non-retina tile on retina better with this, but Chrome is worse */
-.leaflet-safari .leaflet-tile {
- image-rendering: -webkit-optimize-contrast;
- }
-/* hack that prevents hw layers "stretching" when loading new tiles */
-.leaflet-safari .leaflet-tile-container {
- width: 1600px;
- height: 1600px;
- -webkit-transform-origin: 0 0;
- }
-.leaflet-marker-icon,
-.leaflet-marker-shadow {
- display: block;
- }
-/* .leaflet-container svg: reset svg max-width decleration shipped in Joomla! (joomla.org) 3.x */
-/* .leaflet-container img: map is broken in FF if you have max-width: 100% on tiles */
-.leaflet-container .leaflet-overlay-pane svg {
- max-width: none !important;
- max-height: none !important;
- }
-.leaflet-container .leaflet-marker-pane img,
-.leaflet-container .leaflet-shadow-pane img,
-.leaflet-container .leaflet-tile-pane img,
-.leaflet-container img.leaflet-image-layer,
-.leaflet-container .leaflet-tile {
- max-width: none !important;
- max-height: none !important;
- width: auto;
- padding: 0;
- }
-
-.leaflet-container img.leaflet-tile {
- /* See: https://bugs.chromium.org/p/chromium/issues/detail?id=600120 */
- mix-blend-mode: plus-lighter;
-}
-
-.leaflet-container.leaflet-touch-zoom {
- touch-action: pan-x pan-y;
- }
-.leaflet-container.leaflet-touch-drag {
- /* Fallback for FF which doesn't support pinch-zoom */
- touch-action: none;
- touch-action: pinch-zoom;
-}
-.leaflet-container.leaflet-touch-drag.leaflet-touch-zoom {
- touch-action: none;
-}
-.leaflet-container {
- -webkit-tap-highlight-color: transparent;
-}
-.leaflet-container a {
- -webkit-tap-highlight-color: rgba(51, 181, 229, 0.4);
-}
-.leaflet-tile {
- filter: inherit;
- visibility: hidden;
- }
-.leaflet-tile-loaded {
- visibility: inherit;
- }
-.leaflet-zoom-box {
- width: 0;
- height: 0;
- box-sizing: border-box;
- z-index: 800;
- }
-/* workaround for https://bugzilla.mozilla.org/show_bug.cgi?id=888319 */
-.leaflet-overlay-pane svg {
- -moz-user-select: none;
- }
-
-.leaflet-pane { z-index: 400; }
-
-.leaflet-tile-pane { z-index: 200; }
-.leaflet-overlay-pane { z-index: 400; }
-.leaflet-shadow-pane { z-index: 500; }
-.leaflet-marker-pane { z-index: 600; }
-.leaflet-tooltip-pane { z-index: 650; }
-.leaflet-popup-pane { z-index: 700; }
-
-.leaflet-map-pane canvas { z-index: 100; }
-.leaflet-map-pane svg { z-index: 200; }
-
-.leaflet-vml-shape {
- width: 1px;
- height: 1px;
- }
-.lvml {
- behavior: url(#default#VML);
- display: inline-block;
- position: absolute;
- }
-
-
-/* control positioning */
-
-.leaflet-control {
- position: relative;
- z-index: 800;
- pointer-events: visiblePainted; /* IE 9-10 doesn't have auto */
- pointer-events: auto;
- }
-.leaflet-top,
-.leaflet-bottom {
- position: absolute;
- z-index: 1000;
- pointer-events: none;
- }
-.leaflet-top {
- top: 0;
- }
-.leaflet-right {
- right: 0;
- }
-.leaflet-bottom {
- bottom: 0;
- }
-.leaflet-left {
- left: 0;
- }
-.leaflet-control {
- float: left;
- clear: both;
- }
-.leaflet-right .leaflet-control {
- float: right;
- }
-.leaflet-top .leaflet-control {
- margin-top: 10px;
- }
-.leaflet-bottom .leaflet-control {
- margin-bottom: 10px;
- }
-.leaflet-left .leaflet-control {
- margin-left: 10px;
- }
-.leaflet-right .leaflet-control {
- margin-right: 10px;
- }
-
-
-/* zoom and fade animations */
-
-.leaflet-fade-anim .leaflet-popup {
- opacity: 0;
- transition: opacity 0.2s linear;
- }
-.leaflet-fade-anim .leaflet-map-pane .leaflet-popup {
- opacity: 1;
- }
-.leaflet-zoom-animated {
- transform-origin: 0 0;
- }
-svg.leaflet-zoom-animated {
- will-change: transform;
-}
-
-.leaflet-zoom-anim .leaflet-zoom-animated {
- transition: transform 0.25s cubic-bezier(0,0,0.25,1);
- }
-.leaflet-zoom-anim .leaflet-tile,
-.leaflet-pan-anim .leaflet-tile {
- transition: none;
- }
-
-.leaflet-zoom-anim .leaflet-zoom-hide {
- visibility: hidden;
- }
-
-
-/* cursors */
-
-.leaflet-interactive {
- cursor: pointer;
- }
-.leaflet-grab {
- cursor: grab;
- }
-.leaflet-crosshair,
-.leaflet-crosshair .leaflet-interactive {
- cursor: crosshair;
- }
-.leaflet-popup-pane,
-.leaflet-control {
- cursor: auto;
- }
-.leaflet-dragging .leaflet-grab,
-.leaflet-dragging .leaflet-grab .leaflet-interactive,
-.leaflet-dragging .leaflet-marker-draggable {
- cursor: move;
- cursor: grabbing;
- }
-
-/* marker & overlays interactivity */
-.leaflet-marker-icon,
-.leaflet-marker-shadow,
-.leaflet-image-layer,
-.leaflet-pane > svg path,
-.leaflet-tile-container {
- pointer-events: none;
- }
-
-.leaflet-marker-icon.leaflet-interactive,
-.leaflet-image-layer.leaflet-interactive,
-.leaflet-pane > svg path.leaflet-interactive,
-svg.leaflet-image-layer.leaflet-interactive path {
- pointer-events: visiblePainted; /* IE 9-10 doesn't have auto */
- pointer-events: auto;
- }
-
-/* visual tweaks */
-
-.leaflet-container {
- background: #ddd;
- outline-offset: 1px;
- }
-.leaflet-container a {
- color: #0078A8;
- }
-.leaflet-zoom-box {
- border: 2px dotted #38f;
- background: rgba(255,255,255,0.5);
- }
-
-
-/* general typography */
-.leaflet-container {
- font-family: "Helvetica Neue", Arial, Helvetica, sans-serif;
- font-size: 12px;
- font-size: 0.75rem;
- line-height: 1.5;
- }
-
-
-/* general toolbar styles */
-
-.leaflet-bar {
- box-shadow: 0 1px 5px rgba(0,0,0,0.65);
- border-radius: 4px;
- }
-.leaflet-bar a {
- background-color: #fff;
- border-bottom: 1px solid #ccc;
- width: 26px;
- height: 26px;
- line-height: 26px;
- display: block;
- text-align: center;
- -webkit-text-decoration: none;
- text-decoration: none;
- color: black;
- }
-.leaflet-bar a,
-.leaflet-control-layers-toggle {
- background-position: 50% 50%;
- background-repeat: no-repeat;
- display: block;
- }
-.leaflet-bar a:hover,
-.leaflet-bar a:focus {
- background-color: #f4f4f4;
- }
-.leaflet-bar a:first-child {
- border-top-left-radius: 4px;
- border-top-right-radius: 4px;
- }
-.leaflet-bar a:last-child {
- border-bottom-left-radius: 4px;
- border-bottom-right-radius: 4px;
- border-bottom: none;
- }
-.leaflet-bar a.leaflet-disabled {
- cursor: default;
- background-color: #f4f4f4;
- color: #bbb;
- }
-
-.leaflet-touch .leaflet-bar a {
- width: 30px;
- height: 30px;
- line-height: 30px;
- }
-.leaflet-touch .leaflet-bar a:first-child {
- border-top-left-radius: 2px;
- border-top-right-radius: 2px;
- }
-.leaflet-touch .leaflet-bar a:last-child {
- border-bottom-left-radius: 2px;
- border-bottom-right-radius: 2px;
- }
-
-/* zoom control */
-
-.leaflet-control-zoom-in,
-.leaflet-control-zoom-out {
- font: bold 18px 'Lucida Console', Monaco, monospace;
- text-indent: 1px;
- }
-
-.leaflet-touch .leaflet-control-zoom-in, .leaflet-touch .leaflet-control-zoom-out {
- font-size: 22px;
- }
-
-
-/* layers control */
-
-.leaflet-control-layers {
- box-shadow: 0 1px 5px rgba(0,0,0,0.4);
- background: #fff;
- border-radius: 5px;
- }
-.leaflet-control-layers-toggle {
- background-image: url(images/layers.png);
- width: 36px;
- height: 36px;
- }
-.leaflet-retina .leaflet-control-layers-toggle {
- background-image: url(images/layers-2x.png);
- background-size: 26px 26px;
- }
-.leaflet-touch .leaflet-control-layers-toggle {
- width: 44px;
- height: 44px;
- }
-.leaflet-control-layers .leaflet-control-layers-list,
-.leaflet-control-layers-expanded .leaflet-control-layers-toggle {
- display: none;
- }
-.leaflet-control-layers-expanded .leaflet-control-layers-list {
- display: block;
- position: relative;
- }
-.leaflet-control-layers-expanded {
- padding: 6px 10px 6px 6px;
- color: #333;
- background: #fff;
- }
-.leaflet-control-layers-scrollbar {
- overflow-y: scroll;
- overflow-x: hidden;
- padding-right: 5px;
- }
-.leaflet-control-layers-selector {
- margin-top: 2px;
- position: relative;
- top: 1px;
- }
-.leaflet-control-layers label {
- display: block;
- font-size: 13px;
- font-size: 1.08333em;
- }
-.leaflet-control-layers-separator {
- height: 0;
- border-top: 1px solid #ddd;
- margin: 5px -10px 5px -6px;
- }
-
-/* Default icon URLs */
-.leaflet-default-icon-path { /* used only in path-guessing heuristic, see L.Icon.Default */
- background-image: url(images/marker-icon.png);
- }
-
-
-/* attribution and scale controls */
-
-.leaflet-container .leaflet-control-attribution {
- background: #fff;
- background: rgba(255, 255, 255, 0.8);
- margin: 0;
- }
-.leaflet-control-attribution,
-.leaflet-control-scale-line {
- padding: 0 5px;
- color: #333;
- line-height: 1.4;
- }
-.leaflet-control-attribution a {
- -webkit-text-decoration: none;
- text-decoration: none;
- }
-.leaflet-control-attribution a:hover,
-.leaflet-control-attribution a:focus {
- -webkit-text-decoration: underline;
- text-decoration: underline;
- }
-.leaflet-attribution-flag {
- display: inline !important;
- vertical-align: baseline !important;
- width: 1em;
- height: 0.6669em;
- }
-.leaflet-left .leaflet-control-scale {
- margin-left: 5px;
- }
-.leaflet-bottom .leaflet-control-scale {
- margin-bottom: 5px;
- }
-.leaflet-control-scale-line {
- border: 2px solid #777;
- border-top: none;
- line-height: 1.1;
- padding: 2px 5px 1px;
- white-space: nowrap;
- box-sizing: border-box;
- background: rgba(255, 255, 255, 0.8);
- text-shadow: 1px 1px #fff;
- }
-.leaflet-control-scale-line:not(:first-child) {
- border-top: 2px solid #777;
- border-bottom: none;
- margin-top: -2px;
- }
-.leaflet-control-scale-line:not(:first-child):not(:last-child) {
- border-bottom: 2px solid #777;
- }
-
-.leaflet-touch .leaflet-control-attribution,
-.leaflet-touch .leaflet-control-layers,
-.leaflet-touch .leaflet-bar {
- box-shadow: none;
- }
-.leaflet-touch .leaflet-control-layers,
-.leaflet-touch .leaflet-bar {
- border: 2px solid rgba(0,0,0,0.2);
- background-clip: padding-box;
- }
-
-
-/* popup */
-
-.leaflet-popup {
- position: absolute;
- text-align: center;
- margin-bottom: 20px;
- }
-.leaflet-popup-content-wrapper {
- padding: 1px;
- text-align: left;
- border-radius: 12px;
- }
-.leaflet-popup-content {
- margin: 13px 24px 13px 20px;
- line-height: 1.3;
- font-size: 13px;
- font-size: 1.08333em;
- min-height: 1px;
- }
-.leaflet-popup-content p {
- margin: 17px 0;
- margin: 1.3em 0;
- }
-.leaflet-popup-tip-container {
- width: 40px;
- height: 20px;
- position: absolute;
- left: 50%;
- margin-top: -1px;
- margin-left: -20px;
- overflow: hidden;
- pointer-events: none;
- }
-.leaflet-popup-tip {
- width: 17px;
- height: 17px;
- padding: 1px;
-
- margin: -10px auto 0;
- pointer-events: auto;
- transform: rotate(45deg);
- }
-.leaflet-popup-content-wrapper,
-.leaflet-popup-tip {
- background: white;
- color: #333;
- box-shadow: 0 3px 14px rgba(0,0,0,0.4);
- }
-.leaflet-container a.leaflet-popup-close-button {
- position: absolute;
- top: 0;
- right: 0;
- border: none;
- text-align: center;
- width: 24px;
- height: 24px;
- font: 16px/24px Tahoma, Verdana, sans-serif;
- color: #757575;
- -webkit-text-decoration: none;
- text-decoration: none;
- background: transparent;
- }
-.leaflet-container a.leaflet-popup-close-button:hover,
-.leaflet-container a.leaflet-popup-close-button:focus {
- color: #585858;
- }
-.leaflet-popup-scrolled {
- overflow: auto;
- }
-
-.leaflet-oldie .leaflet-popup-content-wrapper {
- -ms-zoom: 1;
- }
-.leaflet-oldie .leaflet-popup-tip {
- width: 24px;
- margin: 0 auto;
-
- -ms-filter: "progid:DXImageTransform.Microsoft.Matrix(M11=0.70710678, M12=0.70710678, M21=-0.70710678, M22=0.70710678)";
- filter: progid:DXImageTransform.Microsoft.Matrix(M11=0.70710678, M12=0.70710678, M21=-0.70710678, M22=0.70710678);
- }
-
-.leaflet-oldie .leaflet-control-zoom,
-.leaflet-oldie .leaflet-control-layers,
-.leaflet-oldie .leaflet-popup-content-wrapper,
-.leaflet-oldie .leaflet-popup-tip {
- border: 1px solid #999;
- }
-
-
-/* div icon */
-
-.leaflet-div-icon {
- background: #fff;
- border: 1px solid #666;
- }
-
-
-/* Tooltip */
-/* Base styles for the element that has a tooltip */
-.leaflet-tooltip {
- position: absolute;
- padding: 6px;
- background-color: #fff;
- border: 1px solid #fff;
- border-radius: 3px;
- color: #222;
- white-space: nowrap;
- -webkit-user-select: none;
- -moz-user-select: none;
- user-select: none;
- pointer-events: none;
- box-shadow: 0 1px 3px rgba(0,0,0,0.4);
- }
-.leaflet-tooltip.leaflet-interactive {
- cursor: pointer;
- pointer-events: auto;
- }
-.leaflet-tooltip-top:before,
-.leaflet-tooltip-bottom:before,
-.leaflet-tooltip-left:before,
-.leaflet-tooltip-right:before {
- position: absolute;
- pointer-events: none;
- border: 6px solid transparent;
- background: transparent;
- content: "";
- }
-
-/* Directions */
-
-.leaflet-tooltip-bottom {
- margin-top: 6px;
-}
-.leaflet-tooltip-top {
- margin-top: -6px;
-}
-.leaflet-tooltip-bottom:before,
-.leaflet-tooltip-top:before {
- left: 50%;
- margin-left: -6px;
- }
-.leaflet-tooltip-top:before {
- bottom: 0;
- margin-bottom: -12px;
- border-top-color: #fff;
- }
-.leaflet-tooltip-bottom:before {
- top: 0;
- margin-top: -12px;
- margin-left: -6px;
- border-bottom-color: #fff;
- }
-.leaflet-tooltip-left {
- margin-left: -6px;
-}
-.leaflet-tooltip-right {
- margin-left: 6px;
-}
-.leaflet-tooltip-left:before,
-.leaflet-tooltip-right:before {
- top: 50%;
- margin-top: -6px;
- }
-.leaflet-tooltip-left:before {
- right: 0;
- margin-right: -12px;
- border-left-color: #fff;
- }
-.leaflet-tooltip-right:before {
- left: 0;
- margin-left: -12px;
- border-right-color: #fff;
- }
-
-/* Printing */
-
-@media print {
- /* Prevent printers from removing background-images of controls. */
- .leaflet-control {
- -webkit-print-color-adjust: exact;
- print-color-adjust: exact;
- }
- }
-`;wi(Si);let ki=class extends ue{constructor(){super(...arguments),this.map=null,this.marker=null,this.lat=0,this.lon=0,this.zoom=16,this.state="",this.address={},this.enableAdress=!1,this.apiKey=""}static get styles(){return[Si,o`
- *:focus {
- outline: none;
- }
- :host {
- --vic-map-marker-color: var(--primary-color);
- --vic-map-tiles-light-filter: none;
- --vic-map-tiles-dark-filter: brightness(0.6) invert(1) contrast(3) hue-rotate(200deg) saturate(0.3)
- brightness(0.7);
- --vic-map-tiles-filter: var(--vic-map-tiles-light-filter);
- --vic-marker-dark-filter: brightness(1) contrast(1.2) saturate(6) brightness(1.3);
- --vic-marker-light-filter: none;
- --vic-maker-filter: var(--vic-marker-light-filter);
- --vic-map-mask-image: linear-gradient(to right, transparent 0%, black 10%, black 90%, transparent 100%),
- linear-gradient(to bottom, transparent 10%, black 20%, black 90%, transparent 100%);
- }
- .map-wrapper {
- position: relative;
- width: 100%;
- height: 100%;
- }
- .map-overlay {
- position: absolute;
- top: 0;
- left: 0;
- width: 100%;
- height: 100%;
- background-color: var(--card-background-color);
- opacity: 0.6; /* Adjust the opacity as needed */
- pointer-events: none; /* Ensure the overlay does not interfere with map interactions */
- }
- #map {
- height: 100%;
- width: 100%;
- background: transparent !important;
- mask-image: var(--vic-map-mask-image);
- mask-composite: intersect;
- }
-
- .map-tiles {
- filter: var(--vic-map-tiles-filter, none);
- }
-
- .marker {
- position: relative;
- width: 46px;
- height: 46px;
- filter: var(--vic-marker-filter);
- }
-
- .dot {
- position: absolute;
- width: 14px;
- height: 14px;
- background-color: var(--vic-map-marker-color);
- border-radius: 50%;
- top: 50%;
- left: 50%;
- border: 1px solid white;
- transform: translate(-50%, -50%);
- opacity: 1;
- }
- .shadow {
- position: absolute;
- width: 100%;
- height: 100%;
- background-image: radial-gradient(circle, var(--vic-map-marker-color) 0%, transparent 100%);
- border-radius: 50%;
- top: 50%;
- left: 50%;
- transform: translate(-50%, -50%);
- border: none !important;
- opacity: 0.6;
- }
- .marker:hover .dot {
- filter: brightness(1.2);
- }
- .leaflet-control-container {
- display: none;
- }
- .reset-button {
- position: absolute;
- top: 15%;
- right: 1rem;
- z-index: 2;
- cursor: pointer;
- opacity: 0.5;
- &:hover {
- opacity: 1;
- }
- }
- .address {
- position: absolute;
- width: max-content;
- height: fit-content;
- top: 50%;
- left: 1rem;
- z-index: 2;
- display: flex;
- align-items: flex-start;
- justify-content: center;
- flex-direction: column;
- gap: 0.5rem;
- color: var(--primary-text-color);
- backdrop-filter: blur(1px);
- .address-line {
- display: flex;
- gap: 0.5rem;
- align-items: center;
- text-shadow: 0 0 black;
- span {
- font-size: 0.9rem;
- }
- }
- }
- `]}firstUpdated(){this.updateCSSVariables(),this.setEntityAttribute()}updated(e){e.has("darkMode")&&(this.updateCSSVariables(),this.updateMap())}setEntityAttribute(){if(!this.config.device_tracker)return;const e=this.hass.states[this.config.device_tracker];e&&(this.lat=e.attributes.latitude,this.lon=e.attributes.longitude,this.state=e.state,this.getAddress(this.lat,this.lon)),setTimeout((()=>{this.initMap()}),200)}updateCSSVariables(){this.darkMode?(this.style.setProperty("--vic-map-marker-color","var(--accent-color)"),this.style.setProperty("--vic-marker-filter","var(--vic-marker-dark-filter)"),this.style.setProperty("--vic-map-tiles-filter","var(--vic-map-tiles-dark-filter)")):(this.style.setProperty("--vic-map-marker-color","var(--primary-color)"),this.style.setProperty("--vic-marker-filter","var(--vic-marker-light-filter)"),this.style.setProperty("--vic-map-tiles-filter","var(--vic-map-tiles-light-filter)"))}async getAddress(e,t){let i=null;i=""!==this.apiKey?await this.getAddressFromGoggle(e,t):await this.getAddressFromOpenStreet(e,t),i?(this.address=i,this.enableAdress=!0,this.requestUpdate()):this.enableAdress=!1}initMap(){var e;this.map=Pi.map(null===(e=this.shadowRoot)||void 0===e?void 0:e.getElementById("map"),{dragging:!0,zoomControl:!1,scrollWheelZoom:!0}).setView([this.lat,this.lon],this.zoom);Pi.tileLayer("https://api.mapbox.com/styles/v1/emkay2k9/clyd2zi0o00mu01pgfm6f6cie/tiles/{z}/{x}/{y}@2x?access_token=pk.eyJ1IjoiZW1rYXkyazkiLCJhIjoiY2xrcHo5NzJwMXJ3MDNlbzM1bWJhcGx6eiJ9.kyNZp2l02lfkNlD2svnDsg",{maxZoom:18,tileSize:512,zoomOffset:-1,className:"map-tiles"}).addTo(this.map);const t=Pi.divIcon({html:'',iconSize:[24,24],iconAnchor:[12,12],className:"custom-marker"});this.marker=Pi.marker([this.lat,this.lon],{icon:t}).addTo(this.map),this.config.enable_map_popup&&this.marker.on("click",(()=>{this.togglePopup()})),this.marker.bindTooltip(this.state),this.updateMap(),this.updateCSSVariables()}togglePopup(){const e=new CustomEvent("toggle-map-popup",{detail:{},bubbles:!0,composed:!0});this.dispatchEvent(e)}updateMap(){if(!this.map||!this.marker)return;const e=this.calculateLatLngOffset(this.map,this.lat,this.lon,this.map.getSize().x/5,3);this.map.setView(e,this.zoom),this.marker.setLatLng([this.lat,this.lon])}calculateLatLngOffset(e,t,i,a,n){const r=e.latLngToContainerPoint([t,i]),s=Pi.point(r.x-a,r.y-n),o=e.containerPointToLatLng(s);return[o.lat,o.lng]}render(){return Z`
-
-
-
-
-
-
- ${this._renderAddress()}
-
- `}_renderAddress(){return this.enableAdress?Z`
-
-
-
-
- ${this.address.streetNumber} ${this.address.streetName} ${this.address.sublocality?this.address.sublocality:this.address.city}
-
-
-
- `:Z``}async getAddressFromOpenStreet(e,t){const i=`https://nominatim.openstreetmap.org/reverse?lat=${e}&lon=${t}&format=jsonv2`;try{const e=await fetch(i),t=await e.json();if(e.ok){return{streetNumber:t.address.house_number||"",streetName:t.address.road||"",sublocality:t.address.suburb||t.address.village||"",city:t.address.city||t.address.town||"",state:t.address.state||t.address.county||"",country:t.address.country||"",postcode:t.address.postcode||""}}throw new Error("Failed to fetch address OpenStreetMap")}catch(e){return null}}async getAddressFromGoggle(e,t){const i=`https://maps.googleapis.com/maps/api/geocode/json?latlng=${e},${t}&key=${this.apiKey}`;try{const e=await fetch(i),t=await e.json();if("OK"===t.status){const e=t.results[0].address_components;let i="",a="",n="",r="";return e.forEach((e=>{e.types.includes("street_number")&&(i=e.long_name),e.types.includes("route")&&(a=e.long_name),e.types.includes("sublocality")&&(n=e.short_name),e.types.includes("locality")&&(r=e.long_name),!r&&e.types.includes("administrative_area_level_2")&&(r=e.short_name),!r&&e.types.includes("administrative_area_level_1")&&(r=e.short_name)})),{streetNumber:i,streetName:a,sublocality:n,city:r}}throw new Error("No results found")}catch(e){return null}}};function Ei(e){return null!==e&&"object"==typeof e&&"constructor"in e&&e.constructor===Object}function Mi(e,t){void 0===e&&(e={}),void 0===t&&(t={}),Object.keys(t).forEach((i=>{void 0===e[i]?e[i]=t[i]:Ei(t[i])&&Ei(e[i])&&Object.keys(t[i]).length>0&&Mi(e[i],t[i])}))}e([ve({attribute:!1})],ki.prototype,"hass",void 0),e([ve({type:Object})],ki.prototype,"config",void 0),e([ve({type:Boolean})],ki.prototype,"darkMode",void 0),e([be()],ki.prototype,"map",void 0),e([be()],ki.prototype,"marker",void 0),e([be()],ki.prototype,"lat",void 0),e([be()],ki.prototype,"lon",void 0),e([be()],ki.prototype,"zoom",void 0),e([be()],ki.prototype,"state",void 0),e([be()],ki.prototype,"address",void 0),e([be()],ki.prototype,"enableAdress",void 0),e([be()],ki.prototype,"apiKey",void 0),ki=e([fe("vehicle-map")],ki);const Oi={body:{},addEventListener(){},removeEventListener(){},activeElement:{blur(){},nodeName:""},querySelector:()=>null,querySelectorAll:()=>[],getElementById:()=>null,createEvent:()=>({initEvent(){}}),createElement:()=>({children:[],childNodes:[],style:{},setAttribute(){},getElementsByTagName:()=>[]}),createElementNS:()=>({}),importNode:()=>null,location:{hash:"",host:"",hostname:"",href:"",origin:"",pathname:"",protocol:"",search:""}};function Li(){const e="undefined"!=typeof document?document:{};return Mi(e,Oi),e}const Ii={document:Oi,navigator:{userAgent:""},location:{hash:"",host:"",hostname:"",href:"",origin:"",pathname:"",protocol:"",search:""},history:{replaceState(){},pushState(){},go(){},back(){}},CustomEvent:function(){return this},addEventListener(){},removeEventListener(){},getComputedStyle:()=>({getPropertyValue:()=>""}),Image(){},Date(){},screen:{},setTimeout(){},clearTimeout(){},matchMedia:()=>({}),requestAnimationFrame:e=>"undefined"==typeof setTimeout?(e(),null):setTimeout(e,0),cancelAnimationFrame(e){"undefined"!=typeof setTimeout&&clearTimeout(e)}};function Bi(){const e="undefined"!=typeof window?window:{};return Mi(e,Ii),e}function Vi(e){return void 0===e&&(e=""),e.trim().split(" ").filter((e=>!!e.trim()))}function Ri(e){const t=e;Object.keys(t).forEach((e=>{try{t[e]=null}catch(e){}try{delete t[e]}catch(e){}}))}function Di(e,t){return void 0===t&&(t=0),setTimeout(e,t)}function qi(){return Date.now()}function Ti(e){const t=Bi();let i;return t.getComputedStyle&&(i=t.getComputedStyle(e,null)),!i&&e.currentStyle&&(i=e.currentStyle),i||(i=e.style),i}function Ni(e,t){void 0===t&&(t="x");const i=Bi();let a,n,r;const s=Ti(e);return i.WebKitCSSMatrix?(n=s.transform||s.webkitTransform,n.split(",").length>6&&(n=n.split(", ").map((e=>e.replace(",","."))).join(", ")),r=new i.WebKitCSSMatrix("none"===n?"":n)):(r=s.MozTransform||s.OTransform||s.MsTransform||s.msTransform||s.transform||s.getPropertyValue("transform").replace("translate(","matrix(1, 0, 0, 1,"),a=r.toString().split(",")),"x"===t&&(n=i.WebKitCSSMatrix?r.m41:16===a.length?parseFloat(a[12]):parseFloat(a[4])),"y"===t&&(n=i.WebKitCSSMatrix?r.m42:16===a.length?parseFloat(a[13]):parseFloat(a[5])),n||0}function Xi(e){return"object"==typeof e&&null!==e&&e.constructor&&"Object"===Object.prototype.toString.call(e).slice(8,-1)}function ji(e){return"undefined"!=typeof window&&void 0!==window.HTMLElement?e instanceof HTMLElement:e&&(1===e.nodeType||11===e.nodeType)}function Fi(){const e=Object(arguments.length<=0?void 0:arguments[0]),t=["__proto__","constructor","prototype"];for(let i=1;it.indexOf(e)<0));for(let t=0,n=i.length;tr?"next":"prev",d=(e,t)=>"next"===c&&e>=t||"prev"===c&&e<=t,h=()=>{s=(new Date).getTime(),null===o&&(o=s);const e=Math.max(Math.min((s-o)/l,1),0),c=.5-Math.cos(e*Math.PI)/2;let u=r+c*(i-r);if(d(u,i)&&(u=i),t.wrapperEl.scrollTo({[a]:u}),d(u,i))return t.wrapperEl.style.overflow="hidden",t.wrapperEl.style.scrollSnapType="",setTimeout((()=>{t.wrapperEl.style.overflow="",t.wrapperEl.scrollTo({[a]:u})})),void n.cancelAnimationFrame(t.cssModeFrameID);t.cssModeFrameID=n.requestAnimationFrame(h)};h()}function Yi(e,t){return void 0===t&&(t=""),[...e.children].filter((e=>e.matches(t)))}function Gi(e){try{return void console.warn(e)}catch(e){}}function Zi(e,t){void 0===t&&(t=[]);const i=document.createElement(e);return i.classList.add(...Array.isArray(t)?t:Vi(t)),i}function Qi(e,t){const i=[];for(;e.previousElementSibling;){const a=e.previousElementSibling;t?a.matches(t)&&i.push(a):i.push(a),e=a}return i}function Ui(e,t){const i=[];for(;e.nextElementSibling;){const a=e.nextElementSibling;t?a.matches(t)&&i.push(a):i.push(a),e=a}return i}function Ki(e,t){return Bi().getComputedStyle(e,null).getPropertyValue(t)}function Ji(e){let t,i=e;if(i){for(t=0;null!==(i=i.previousSibling);)1===i.nodeType&&(t+=1);return t}}function _i(e,t){const i=[];let a=e.parentElement;for(;a;)t?a.matches(t)&&i.push(a):i.push(a),a=a.parentElement;return i}function $i(e,t,i){const a=Bi();return i?e["width"===t?"offsetWidth":"offsetHeight"]+parseFloat(a.getComputedStyle(e,null).getPropertyValue("width"===t?"margin-right":"margin-top"))+parseFloat(a.getComputedStyle(e,null).getPropertyValue("width"===t?"margin-left":"margin-bottom")):e.offsetWidth}function ea(e){return(Array.isArray(e)?e:[e]).filter((e=>!!e))}let ta,ia,aa;function na(){const e=Bi(),t=Li();return{smoothScroll:t.documentElement&&t.documentElement.style&&"scrollBehavior"in t.documentElement.style,touch:!!("ontouchstart"in e||e.DocumentTouch&&t instanceof e.DocumentTouch)}}function ra(){return ta||(ta=na()),ta}function sa(e){let{userAgent:t}=void 0===e?{}:e;const i=ra(),a=Bi(),n=a.navigator.platform,r=t||a.navigator.userAgent,s={ios:!1,android:!1},o=a.screen.width,l=a.screen.height,c=r.match(/(Android);?[\s\/]+([\d.]+)?/);let d=r.match(/(iPad).*OS\s([\d_]+)/);const h=r.match(/(iPod)(.*OS\s([\d_]+))?/),u=!d&&r.match(/(iPhone\sOS|iOS)\s([\d_]+)/),p="Win32"===n;let f="MacIntel"===n;return!d&&f&&i.touch&&["1024x1366","1366x1024","834x1194","1194x834","834x1112","1112x834","768x1024","1024x768","820x1180","1180x820","810x1080","1080x810"].indexOf(`${o}x${l}`)>=0&&(d=r.match(/(Version)\/([\d.]+)/),d||(d=[0,1,"13_0_0"]),f=!1),c&&!p&&(s.os="android",s.android=!0),(d||u||h)&&(s.os="ios",s.ios=!0),s}function oa(e){return void 0===e&&(e={}),ia||(ia=sa(e)),ia}function la(){const e=Bi(),t=oa();let i=!1;function a(){const t=e.navigator.userAgent.toLowerCase();return t.indexOf("safari")>=0&&t.indexOf("chrome")<0&&t.indexOf("android")<0}if(a()){const t=String(e.navigator.userAgent);if(t.includes("Version/")){const[e,a]=t.split("Version/")[1].split(" ")[0].split(".").map((e=>Number(e)));i=e<16||16===e&&a<2}}const n=/(iPhone|iPod|iPad).*AppleWebKit(?!.*Safari)/i.test(e.navigator.userAgent),r=a();return{isSafari:i||r,needPerspectiveFix:i,need3dFix:r||n&&t.ios,isWebView:n}}function ca(){return aa||(aa=la()),aa}function da(e){let{swiper:t,on:i,emit:a}=e;const n=Bi();let r=null,s=null;const o=()=>{t&&!t.destroyed&&t.initialized&&(a("beforeResize"),a("resize"))},l=()=>{t&&!t.destroyed&&t.initialized&&a("orientationchange")};i("init",(()=>{t.params.resizeObserver&&void 0!==n.ResizeObserver?t&&!t.destroyed&&t.initialized&&(r=new ResizeObserver((e=>{s=n.requestAnimationFrame((()=>{const{width:i,height:a}=t;let n=i,r=a;e.forEach((e=>{let{contentBoxSize:i,contentRect:a,target:s}=e;s&&s!==t.el||(n=a?a.width:(i[0]||i).inlineSize,r=a?a.height:(i[0]||i).blockSize)})),n===i&&r===a||o()}))})),r.observe(t.el)):(n.addEventListener("resize",o),n.addEventListener("orientationchange",l))})),i("destroy",(()=>{s&&n.cancelAnimationFrame(s),r&&r.unobserve&&t.el&&(r.unobserve(t.el),r=null),n.removeEventListener("resize",o),n.removeEventListener("orientationchange",l)}))}function ha(e){let{swiper:t,extendParams:i,on:a,emit:n}=e;const r=[],s=Bi(),o=function(e,i){void 0===i&&(i={});const a=new(s.MutationObserver||s.WebkitMutationObserver)((e=>{if(t.__preventObserver__)return;if(1===e.length)return void n("observerUpdate",e[0]);const i=function(){n("observerUpdate",e[0])};s.requestAnimationFrame?s.requestAnimationFrame(i):s.setTimeout(i,0)}));a.observe(e,{attributes:void 0===i.attributes||i.attributes,childList:void 0===i.childList||i.childList,characterData:void 0===i.characterData||i.characterData}),r.push(a)};i({observer:!1,observeParents:!1,observeSlideChildren:!1}),a("init",(()=>{if(t.params.observer){if(t.params.observeParents){const e=_i(t.hostEl);for(let t=0;t{r.forEach((e=>{e.disconnect()})),r.splice(0,r.length)}))}var ua={on(e,t,i){const a=this;if(!a.eventsListeners||a.destroyed)return a;if("function"!=typeof t)return a;const n=i?"unshift":"push";return e.split(" ").forEach((e=>{a.eventsListeners[e]||(a.eventsListeners[e]=[]),a.eventsListeners[e][n](t)})),a},once(e,t,i){const a=this;if(!a.eventsListeners||a.destroyed)return a;if("function"!=typeof t)return a;function n(){a.off(e,n),n.__emitterProxy&&delete n.__emitterProxy;for(var i=arguments.length,r=new Array(i),s=0;s=0&&t.eventsAnyListeners.splice(i,1),t},off(e,t){const i=this;return!i.eventsListeners||i.destroyed?i:i.eventsListeners?(e.split(" ").forEach((e=>{void 0===t?i.eventsListeners[e]=[]:i.eventsListeners[e]&&i.eventsListeners[e].forEach(((a,n)=>{(a===t||a.__emitterProxy&&a.__emitterProxy===t)&&i.eventsListeners[e].splice(n,1)}))})),i):i},emit(){const e=this;if(!e.eventsListeners||e.destroyed)return e;if(!e.eventsListeners)return e;let t,i,a;for(var n=arguments.length,r=new Array(n),s=0;s{e.eventsAnyListeners&&e.eventsAnyListeners.length&&e.eventsAnyListeners.forEach((e=>{e.apply(a,[t,...i])})),e.eventsListeners&&e.eventsListeners[t]&&e.eventsListeners[t].forEach((e=>{e.apply(a,i)}))})),e}};function pa(){const e=this;let t,i;const a=e.el;t=void 0!==e.params.width&&null!==e.params.width?e.params.width:a.clientWidth,i=void 0!==e.params.height&&null!==e.params.height?e.params.height:a.clientHeight,0===t&&e.isHorizontal()||0===i&&e.isVertical()||(t=t-parseInt(Ki(a,"padding-left")||0,10)-parseInt(Ki(a,"padding-right")||0,10),i=i-parseInt(Ki(a,"padding-top")||0,10)-parseInt(Ki(a,"padding-bottom")||0,10),Number.isNaN(t)&&(t=0),Number.isNaN(i)&&(i=0),Object.assign(e,{width:t,height:i,size:e.isHorizontal()?t:i}))}function fa(){const e=this;function t(t,i){return parseFloat(t.getPropertyValue(e.getDirectionLabel(i))||0)}const i=e.params,{wrapperEl:a,slidesEl:n,size:r,rtlTranslate:s,wrongRTL:o}=e,l=e.virtual&&i.virtual.enabled,c=l?e.virtual.slides.length:e.slides.length,d=Yi(n,`.${e.params.slideClass}, swiper-slide`),h=l?e.virtual.slides.length:d.length;let u=[];const p=[],f=[];let g=i.slidesOffsetBefore;"function"==typeof g&&(g=i.slidesOffsetBefore.call(e));let m=i.slidesOffsetAfter;"function"==typeof m&&(m=i.slidesOffsetAfter.call(e));const v=e.snapGrid.length,b=e.slidesGrid.length;let x=i.spaceBetween,y=-g,w=0,A=0;if(void 0===r)return;"string"==typeof x&&x.indexOf("%")>=0?x=parseFloat(x.replace("%",""))/100*r:"string"==typeof x&&(x=parseFloat(x)),e.virtualSize=-x,d.forEach((e=>{s?e.style.marginLeft="":e.style.marginRight="",e.style.marginBottom="",e.style.marginTop=""})),i.centeredSlides&&i.cssMode&&(Wi(a,"--swiper-centered-offset-before",""),Wi(a,"--swiper-centered-offset-after",""));const C=i.grid&&i.grid.rows>1&&e.grid;let z;C?e.grid.initSlides(d):e.grid&&e.grid.unsetSlides();const P="auto"===i.slidesPerView&&i.breakpoints&&Object.keys(i.breakpoints).filter((e=>void 0!==i.breakpoints[e].slidesPerView)).length>0;for(let a=0;a1&&u.push(e.virtualSize-r)}if(l&&i.loop){const t=f[0]+x;if(i.slidesPerGroup>1){const a=Math.ceil((e.virtual.slidesBefore+e.virtual.slidesAfter)/i.slidesPerGroup),n=t*i.slidesPerGroup;for(let e=0;e!(i.cssMode&&!i.loop)||t!==d.length-1)).forEach((e=>{e.style[t]=`${x}px`}))}if(i.centeredSlides&&i.centeredSlidesBounds){let e=0;f.forEach((t=>{e+=t+(x||0)})),e-=x;const t=e-r;u=u.map((e=>e<=0?-g:e>t?t+m:e))}if(i.centerInsufficientSlides){let e=0;f.forEach((t=>{e+=t+(x||0)})),e-=x;const t=(i.slidesOffsetBefore||0)+(i.slidesOffsetAfter||0);if(e+t{u[t]=e-i})),p.forEach(((e,t)=>{p[t]=e+i}))}}if(Object.assign(e,{slides:d,snapGrid:u,slidesGrid:p,slidesSizesGrid:f}),i.centeredSlides&&i.cssMode&&!i.centeredSlidesBounds){Wi(a,"--swiper-centered-offset-before",-u[0]+"px"),Wi(a,"--swiper-centered-offset-after",e.size/2-f[f.length-1]/2+"px");const t=-e.snapGrid[0],i=-e.slidesGrid[0];e.snapGrid=e.snapGrid.map((e=>e+t)),e.slidesGrid=e.slidesGrid.map((e=>e+i))}if(h!==c&&e.emit("slidesLengthChange"),u.length!==v&&(e.params.watchOverflow&&e.checkOverflow(),e.emit("snapGridLengthChange")),p.length!==b&&e.emit("slidesGridLengthChange"),i.watchSlidesProgress&&e.updateSlidesOffset(),e.emit("slidesUpdated"),!(l||i.cssMode||"slide"!==i.effect&&"fade"!==i.effect)){const t=`${i.containerModifierClass}backface-hidden`,a=e.el.classList.contains(t);h<=i.maxBackfaceHiddenSlides?a||e.el.classList.add(t):a&&e.el.classList.remove(t)}}function ga(e){const t=this,i=[],a=t.virtual&&t.params.virtual.enabled;let n,r=0;"number"==typeof e?t.setTransition(e):!0===e&&t.setTransition(t.params.speed);const s=e=>a?t.slides[t.getSlideIndexByData(e)]:t.slides[e];if("auto"!==t.params.slidesPerView&&t.params.slidesPerView>1)if(t.params.centeredSlides)(t.visibleSlides||[]).forEach((e=>{i.push(e)}));else for(n=0;nt.slides.length&&!a)break;i.push(s(e))}else i.push(s(t.activeIndex));for(n=0;nr?e:r}(r||0===r)&&(t.wrapperEl.style.height=`${r}px`)}function ma(){const e=this,t=e.slides,i=e.isElement?e.isHorizontal()?e.wrapperEl.offsetLeft:e.wrapperEl.offsetTop:0;for(let a=0;a{t&&!e.classList.contains(i)?e.classList.add(i):!t&&e.classList.contains(i)&&e.classList.remove(i)};function ba(e){void 0===e&&(e=this&&this.translate||0);const t=this,i=t.params,{slides:a,rtlTranslate:n,snapGrid:r}=t;if(0===a.length)return;void 0===a[0].swiperSlideOffset&&t.updateSlidesOffset();let s=-e;n&&(s=e),t.visibleSlidesIndexes=[],t.visibleSlides=[];let o=i.spaceBetween;"string"==typeof o&&o.indexOf("%")>=0?o=parseFloat(o.replace("%",""))/100*t.size:"string"==typeof o&&(o=parseFloat(o));for(let e=0;e=0&&u<=t.size-t.slidesSizesGrid[e],g=u>=0&&u1&&p<=t.size||u<=0&&p>=t.size;g&&(t.visibleSlides.push(l),t.visibleSlidesIndexes.push(e)),va(l,g,i.slideVisibleClass),va(l,f,i.slideFullyVisibleClass),l.progress=n?-d:d,l.originalProgress=n?-h:h}}function xa(e){const t=this;if(void 0===e){const i=t.rtlTranslate?-1:1;e=t&&t.translate&&t.translate*i||0}const i=t.params,a=t.maxTranslate()-t.minTranslate();let{progress:n,isBeginning:r,isEnd:s,progressLoop:o}=t;const l=r,c=s;if(0===a)n=0,r=!0,s=!0;else{n=(e-t.minTranslate())/a;const i=Math.abs(e-t.minTranslate())<1,o=Math.abs(e-t.maxTranslate())<1;r=i||n<=0,s=o||n>=1,i&&(n=0),o&&(n=1)}if(i.loop){const i=t.getSlideIndexByData(0),a=t.getSlideIndexByData(t.slides.length-1),n=t.slidesGrid[i],r=t.slidesGrid[a],s=t.slidesGrid[t.slidesGrid.length-1],l=Math.abs(e);o=l>=n?(l-n)/s:(l+s-r)/s,o>1&&(o-=1)}Object.assign(t,{progress:n,progressLoop:o,isBeginning:r,isEnd:s}),(i.watchSlidesProgress||i.centeredSlides&&i.autoHeight)&&t.updateSlidesProgress(e),r&&!l&&t.emit("reachBeginning toEdge"),s&&!c&&t.emit("reachEnd toEdge"),(l&&!r||c&&!s)&&t.emit("fromEdge"),t.emit("progress",n)}const ya=(e,t,i)=>{t&&!e.classList.contains(i)?e.classList.add(i):!t&&e.classList.contains(i)&&e.classList.remove(i)};function wa(){const e=this,{slides:t,params:i,slidesEl:a,activeIndex:n}=e,r=e.virtual&&i.virtual.enabled,s=e.grid&&i.grid&&i.grid.rows>1,o=e=>Yi(a,`.${i.slideClass}${e}, swiper-slide${e}`)[0];let l,c,d;if(r)if(i.loop){let t=n-e.virtual.slidesBefore;t<0&&(t=e.virtual.slides.length+t),t>=e.virtual.slides.length&&(t-=e.virtual.slides.length),l=o(`[data-swiper-slide-index="${t}"]`)}else l=o(`[data-swiper-slide-index="${n}"]`);else s?(l=t.filter((e=>e.column===n))[0],d=t.filter((e=>e.column===n+1))[0],c=t.filter((e=>e.column===n-1))[0]):l=t[n];l&&(s||(d=Ui(l,`.${i.slideClass}, swiper-slide`)[0],i.loop&&!d&&(d=t[0]),c=Qi(l,`.${i.slideClass}, swiper-slide`)[0],i.loop&&0===!c&&(c=t[t.length-1]))),t.forEach((e=>{ya(e,e===l,i.slideActiveClass),ya(e,e===d,i.slideNextClass),ya(e,e===c,i.slidePrevClass)})),e.emitSlidesClasses()}const Aa=(e,t)=>{if(!e||e.destroyed||!e.params)return;const i=t.closest(e.isElement?"swiper-slide":`.${e.params.slideClass}`);if(i){let t=i.querySelector(`.${e.params.lazyPreloaderClass}`);!t&&e.isElement&&(i.shadowRoot?t=i.shadowRoot.querySelector(`.${e.params.lazyPreloaderClass}`):requestAnimationFrame((()=>{i.shadowRoot&&(t=i.shadowRoot.querySelector(`.${e.params.lazyPreloaderClass}`),t&&t.remove())}))),t&&t.remove()}},Ca=(e,t)=>{if(!e.slides[t])return;const i=e.slides[t].querySelector('[loading="lazy"]');i&&i.removeAttribute("loading")},za=e=>{if(!e||e.destroyed||!e.params)return;let t=e.params.lazyPreloadPrevNext;const i=e.slides.length;if(!i||!t||t<0)return;t=Math.min(t,i);const a="auto"===e.params.slidesPerView?e.slidesPerViewDynamic():Math.ceil(e.params.slidesPerView),n=e.activeIndex;if(e.params.grid&&e.params.grid.rows>1){const i=n,r=[i-t];return r.push(...Array.from({length:t}).map(((e,t)=>i+a+t))),void e.slides.forEach(((t,i)=>{r.includes(t.column)&&Ca(e,i)}))}const r=n+a-1;if(e.params.rewind||e.params.loop)for(let a=n-t;a<=r+t;a+=1){const t=(a%i+i)%i;(tr)&&Ca(e,t)}else for(let a=Math.max(n-t,0);a<=Math.min(r+t,i-1);a+=1)a!==n&&(a>r||a=t[e]&&a=t[e]&&a=t[e]&&(n=e);return i.normalizeSlideIndex&&(n<0||void 0===n)&&(n=0),n}function Sa(e){const t=this,i=t.rtlTranslate?t.translate:-t.translate,{snapGrid:a,params:n,activeIndex:r,realIndex:s,snapIndex:o}=t;let l,c=e;const d=e=>{let i=e-t.virtual.slidesBefore;return i<0&&(i=t.virtual.slides.length+i),i>=t.virtual.slides.length&&(i-=t.virtual.slides.length),i};if(void 0===c&&(c=Pa(t)),a.indexOf(i)>=0)l=a.indexOf(i);else{const e=Math.min(n.slidesPerGroupSkip,c);l=e+Math.floor((c-e)/n.slidesPerGroup)}if(l>=a.length&&(l=a.length-1),c===r&&!t.params.loop)return void(l!==o&&(t.snapIndex=l,t.emit("snapIndexChange")));if(c===r&&t.params.loop&&t.virtual&&t.params.virtual.enabled)return void(t.realIndex=d(c));const h=t.grid&&n.grid&&n.grid.rows>1;let u;if(t.virtual&&n.virtual.enabled&&n.loop)u=d(c);else if(h){const e=t.slides.filter((e=>e.column===c))[0];let i=parseInt(e.getAttribute("data-swiper-slide-index"),10);Number.isNaN(i)&&(i=Math.max(t.slides.indexOf(e),0)),u=Math.floor(i/n.grid.rows)}else if(t.slides[c]){const e=t.slides[c].getAttribute("data-swiper-slide-index");u=e?parseInt(e,10):c}else u=c;Object.assign(t,{previousSnapIndex:o,snapIndex:l,previousRealIndex:s,realIndex:u,previousIndex:r,activeIndex:c}),t.initialized&&za(t),t.emit("activeIndexChange"),t.emit("snapIndexChange"),(t.initialized||t.params.runCallbacksOnInit)&&(s!==u&&t.emit("realIndexChange"),t.emit("slideChange"))}function ka(e,t){const i=this,a=i.params;let n=e.closest(`.${a.slideClass}, swiper-slide`);!n&&i.isElement&&t&&t.length>1&&t.includes(e)&&[...t.slice(t.indexOf(e)+1,t.length)].forEach((e=>{!n&&e.matches&&e.matches(`.${a.slideClass}, swiper-slide`)&&(n=e)}));let r,s=!1;if(n)for(let e=0;el?l:a&&es?"next":r=l.length&&(m=l.length-1);const v=-l[m];if(o.normalizeSlideIndex)for(let e=0;e=i&&t=i&&t=i&&(s=e)}if(r.initialized&&s!==h){if(!r.allowSlideNext&&(u?v>r.translate&&v>r.minTranslate():vr.translate&&v>r.maxTranslate()&&(h||0)!==s)return!1}let b;if(s!==(d||0)&&i&&r.emit("beforeSlideChangeStart"),r.updateProgress(v),b=s>h?"next":s0?(r._cssModeVirtualInitialSet=!0,requestAnimationFrame((()=>{p[e?"scrollLeft":"scrollTop"]=i}))):p[e?"scrollLeft":"scrollTop"]=i,t&&requestAnimationFrame((()=>{r.wrapperEl.style.scrollSnapType="",r._immediateVirtual=!1}))}else{if(!r.support.smoothScroll)return Hi({swiper:r,targetPosition:i,side:e?"left":"top"}),!0;p.scrollTo({[e?"left":"top"]:i,behavior:"smooth"})}return!0}return r.setTransition(t),r.setTranslate(v),r.updateActiveIndex(s),r.updateSlidesClasses(),r.emit("beforeTransitionStart",t,a),r.transitionStart(i,b),0===t?r.transitionEnd(i,b):r.animating||(r.animating=!0,r.onSlideToWrapperTransitionEnd||(r.onSlideToWrapperTransitionEnd=function(e){r&&!r.destroyed&&e.target===this&&(r.wrapperEl.removeEventListener("transitionend",r.onSlideToWrapperTransitionEnd),r.onSlideToWrapperTransitionEnd=null,delete r.onSlideToWrapperTransitionEnd,r.transitionEnd(i,b))}),r.wrapperEl.addEventListener("transitionend",r.onSlideToWrapperTransitionEnd)),!0}function ja(e,t,i,a){if(void 0===e&&(e=0),void 0===i&&(i=!0),"string"==typeof e){e=parseInt(e,10)}const n=this;if(n.destroyed)return;void 0===t&&(t=n.params.speed);const r=n.grid&&n.params.grid&&n.params.grid.rows>1;let s=e;if(n.params.loop)if(n.virtual&&n.params.virtual.enabled)s+=n.virtual.slidesBefore;else{let e;if(r){const t=s*n.params.grid.rows;e=n.slides.filter((e=>1*e.getAttribute("data-swiper-slide-index")===t))[0].column}else e=n.getSlideIndexByData(s);const t=r?Math.ceil(n.slides.length/n.params.grid.rows):n.slides.length,{centeredSlides:i}=n.params;let o=n.params.slidesPerView;"auto"===o?o=n.slidesPerViewDynamic():(o=Math.ceil(parseFloat(n.params.slidesPerView,10)),i&&o%2==0&&(o+=1));let l=t-e1*t.getAttribute("data-swiper-slide-index")===e))[0].column}else s=n.getSlideIndexByData(s)}return requestAnimationFrame((()=>{n.slideTo(s,t,i,a)})),n}function Fa(e,t,i){void 0===t&&(t=!0);const a=this,{enabled:n,params:r,animating:s}=a;if(!n||a.destroyed)return a;void 0===e&&(e=a.params.speed);let o=r.slidesPerGroup;"auto"===r.slidesPerView&&1===r.slidesPerGroup&&r.slidesPerGroupAuto&&(o=Math.max(a.slidesPerViewDynamic("current",!0),1));const l=a.activeIndex{a.slideTo(a.activeIndex+l,e,t,i)})),!0}return r.rewind&&a.isEnd?a.slideTo(0,e,t,i):a.slideTo(a.activeIndex+l,e,t,i)}function Wa(e,t,i){void 0===t&&(t=!0);const a=this,{params:n,snapGrid:r,slidesGrid:s,rtlTranslate:o,enabled:l,animating:c}=a;if(!l||a.destroyed)return a;void 0===e&&(e=a.params.speed);const d=a.virtual&&n.virtual.enabled;if(n.loop){if(c&&!d&&n.loopPreventsSliding)return!1;a.loopFix({direction:"prev"}),a._clientLeft=a.wrapperEl.clientLeft}function h(e){return e<0?-Math.floor(Math.abs(e)):Math.floor(e)}const u=h(o?a.translate:-a.translate),p=r.map((e=>h(e)));let f=r[p.indexOf(u)-1];if(void 0===f&&n.cssMode){let e;r.forEach(((t,i)=>{u>=t&&(e=i)})),void 0!==e&&(f=r[e>0?e-1:e])}let g=0;if(void 0!==f&&(g=s.indexOf(f),g<0&&(g=a.activeIndex-1),"auto"===n.slidesPerView&&1===n.slidesPerGroup&&n.slidesPerGroupAuto&&(g=g-a.slidesPerViewDynamic("previous",!0)+1,g=Math.max(g,0))),n.rewind&&a.isBeginning){const n=a.params.virtual&&a.params.virtual.enabled&&a.virtual?a.virtual.slides.length-1:a.slides.length-1;return a.slideTo(n,e,t,i)}return n.loop&&0===a.activeIndex&&n.cssMode?(requestAnimationFrame((()=>{a.slideTo(g,e,t,i)})),!0):a.slideTo(g,e,t,i)}function Ha(e,t,i){void 0===t&&(t=!0);const a=this;if(!a.destroyed)return void 0===e&&(e=a.params.speed),a.slideTo(a.activeIndex,e,t,i)}function Ya(e,t,i,a){void 0===t&&(t=!0),void 0===a&&(a=.5);const n=this;if(n.destroyed)return;void 0===e&&(e=n.params.speed);let r=n.activeIndex;const s=Math.min(n.params.slidesPerGroupSkip,r),o=s+Math.floor((r-s)/n.params.slidesPerGroup),l=n.rtlTranslate?n.translate:-n.translate;if(l>=n.snapGrid[o]){const e=n.snapGrid[o];l-e>(n.snapGrid[o+1]-e)*a&&(r+=n.params.slidesPerGroup)}else{const e=n.snapGrid[o-1];l-e<=(n.snapGrid[o]-e)*a&&(r-=n.params.slidesPerGroup)}return r=Math.max(r,0),r=Math.min(r,n.slidesGrid.length-1),n.slideTo(r,e,t,i)}function Ga(){const e=this;if(e.destroyed)return;const{params:t,slidesEl:i}=e,a="auto"===t.slidesPerView?e.slidesPerViewDynamic():t.slidesPerView;let n,r=e.clickedIndex;const s=e.isElement?"swiper-slide":`.${t.slideClass}`;if(t.loop){if(e.animating)return;n=parseInt(e.clickedSlide.getAttribute("data-swiper-slide-index"),10),t.centeredSlides?re.slides.length-e.loopedSlides+a/2?(e.loopFix(),r=e.getSlideIndex(Yi(i,`${s}[data-swiper-slide-index="${n}"]`)[0]),Di((()=>{e.slideTo(r)}))):e.slideTo(r):r>e.slides.length-a?(e.loopFix(),r=e.getSlideIndex(Yi(i,`${s}[data-swiper-slide-index="${n}"]`)[0]),Di((()=>{e.slideTo(r)}))):e.slideTo(r)}else e.slideTo(r)}var Za={slideTo:Xa,slideToLoop:ja,slideNext:Fa,slidePrev:Wa,slideReset:Ha,slideToClosest:Ya,slideToClickedSlide:Ga};function Qa(e){const t=this,{params:i,slidesEl:a}=t;if(!i.loop||t.virtual&&t.params.virtual.enabled)return;const n=()=>{Yi(a,`.${i.slideClass}, swiper-slide`).forEach(((e,t)=>{e.setAttribute("data-swiper-slide-index",t)}))},r=t.grid&&i.grid&&i.grid.rows>1,s=i.slidesPerGroup*(r?i.grid.rows:1),o=t.slides.length%s!=0,l=r&&t.slides.length%i.grid.rows!=0,c=e=>{for(let a=0;a1;c.lengthe.classList.contains(p.slideActiveClass)))[0]):w=r;const A="next"===a||!a,C="prev"===a||!a;let z=0,P=0;const S=b?Math.ceil(c.length/p.grid.rows):c.length,k=(b?c[r].column:r)+(f&&void 0===n?-g/2+.5:0);if(k