barsa-develop-components 1.0.289 → 1.0.290
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2020/lib/barsa-develop-components.module.mjs +8 -4
- package/esm2020/lib/barsa-geographic-location/barsa-geographic-location.component.mjs +144 -0
- package/esm2020/lib/geographic-location/geographic-location.component.mjs +59 -169
- package/esm2020/public-api.mjs +2 -1
- package/fesm2015/barsa-develop-components.mjs +158 -129
- package/fesm2015/barsa-develop-components.mjs.map +1 -1
- package/fesm2020/barsa-develop-components.mjs +157 -129
- package/fesm2020/barsa-develop-components.mjs.map +1 -1
- package/lib/barsa-develop-components.module.d.ts +16 -14
- package/lib/barsa-geographic-location/barsa-geographic-location.component.d.ts +39 -0
- package/lib/geographic-location/geographic-location.component.d.ts +18 -20
- package/package.json +1 -1
- package/public-api.d.ts +1 -0
|
@@ -1,193 +1,83 @@
|
|
|
1
|
-
import { ChangeDetectionStrategy, Component } from '@angular/core';
|
|
2
|
-
import {
|
|
1
|
+
import { ChangeDetectionStrategy, Component, ViewChild } from '@angular/core';
|
|
2
|
+
import { BarsaApi } from 'barsa-novin-ray-core';
|
|
3
3
|
import { UiMoInfoSubFormUiComponent } from 'barsa-sap-ui';
|
|
4
|
-
import * as L from 'leaflet';
|
|
5
4
|
import * as i0 from "@angular/core";
|
|
6
5
|
import * as i1 from "@angular/common";
|
|
7
6
|
import * as i2 from "barsa-novin-ray-core";
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
circle: [11, 10],
|
|
13
|
-
'circle-dot': [5, 5],
|
|
14
|
-
'rectangle-dot': [5, 6],
|
|
15
|
-
doughnut: [8, 8]
|
|
16
|
-
},
|
|
17
|
-
popupAnchor: {
|
|
18
|
-
marker: [0, -25],
|
|
19
|
-
circle: [-3, -76],
|
|
20
|
-
'circle-dot': [0, -2],
|
|
21
|
-
'rectangle-dot': [0, -2],
|
|
22
|
-
doughnut: [0, -2]
|
|
23
|
-
},
|
|
24
|
-
innerIconAnchor: {
|
|
25
|
-
marker: [-2, 5],
|
|
26
|
-
circle: [0, 2]
|
|
27
|
-
},
|
|
28
|
-
iconSize: {
|
|
29
|
-
marker: [28, 28],
|
|
30
|
-
circle: [22, 22],
|
|
31
|
-
'circle-dot': [2, 2],
|
|
32
|
-
'rectangle-dot': [2, 2],
|
|
33
|
-
doughnut: [15, 15]
|
|
34
|
-
}
|
|
35
|
-
};
|
|
36
|
-
L.BeautifyIcon = {
|
|
37
|
-
Icon: L.Icon.extend({
|
|
38
|
-
options: {
|
|
39
|
-
icon: 'leaf',
|
|
40
|
-
iconSize: defaults.iconSize.circle,
|
|
41
|
-
iconAnchor: defaults.iconAnchor.circle,
|
|
42
|
-
iconShape: 'circle',
|
|
43
|
-
iconStyle: '',
|
|
44
|
-
innerIconAnchor: [0, 3],
|
|
45
|
-
innerIconStyle: '',
|
|
46
|
-
isAlphaNumericIcon: false,
|
|
47
|
-
text: 1,
|
|
48
|
-
borderColor: defaults.iconColor,
|
|
49
|
-
borderWidth: 2,
|
|
50
|
-
borderStyle: 'solid',
|
|
51
|
-
backgroundColor: 'white',
|
|
52
|
-
textColor: defaults.iconColor,
|
|
53
|
-
customClasses: '',
|
|
54
|
-
spin: false,
|
|
55
|
-
prefix: 'sap-icon--',
|
|
56
|
-
html: ''
|
|
57
|
-
},
|
|
58
|
-
createIconInnerHtml() {
|
|
59
|
-
const options = this.options;
|
|
60
|
-
if (options.iconShape === 'circle-dot' ||
|
|
61
|
-
options.iconShape === 'rectangle-dot' ||
|
|
62
|
-
options.iconShape === 'doughnut') {
|
|
63
|
-
return '';
|
|
64
|
-
}
|
|
65
|
-
const innerIconStyle = this.getInnerIconStyle(options);
|
|
66
|
-
if (options.isAlphaNumericIcon) {
|
|
67
|
-
return '<div style="' + innerIconStyle + '">' + options.text + '</div>';
|
|
68
|
-
}
|
|
69
|
-
let spinClass = '';
|
|
70
|
-
if (options.spin) {
|
|
71
|
-
spinClass = ' fa-spin';
|
|
72
|
-
}
|
|
73
|
-
return ('<fd-icon class="' +
|
|
74
|
-
options.prefix +
|
|
75
|
-
' ' +
|
|
76
|
-
options.prefix +
|
|
77
|
-
'-' +
|
|
78
|
-
options.icon +
|
|
79
|
-
spinClass +
|
|
80
|
-
'" style="' +
|
|
81
|
-
innerIconStyle +
|
|
82
|
-
'"></fd-icon>');
|
|
83
|
-
},
|
|
84
|
-
getInnerIconStyle(options) {
|
|
85
|
-
const innerAnchor = L.point(options.innerIconAnchor);
|
|
86
|
-
return ('color:' +
|
|
87
|
-
options.textColor +
|
|
88
|
-
';margin-top:' +
|
|
89
|
-
innerAnchor.y +
|
|
90
|
-
'px; margin-left:' +
|
|
91
|
-
innerAnchor.x +
|
|
92
|
-
'px;' +
|
|
93
|
-
options.innerIconStyle);
|
|
94
|
-
}
|
|
95
|
-
})
|
|
96
|
-
};
|
|
7
|
+
import * as i3 from "@fundamental-ngx/core/bar";
|
|
8
|
+
import * as i4 from "@fundamental-ngx/core/dialog";
|
|
9
|
+
import * as i5 from "@fundamental-ngx/core/title";
|
|
10
|
+
import * as i6 from "../barsa-geographic-location/barsa-geographic-location.component";
|
|
97
11
|
export class GeographicLocationComponent extends UiMoInfoSubFormUiComponent {
|
|
98
12
|
constructor() {
|
|
99
13
|
super(...arguments);
|
|
100
|
-
this.
|
|
101
|
-
this.
|
|
102
|
-
this.
|
|
103
|
-
|
|
104
|
-
timeout: 5000,
|
|
105
|
-
maximumAge: 0
|
|
106
|
-
};
|
|
14
|
+
this.fullscreen = false;
|
|
15
|
+
this.currentLocation = [];
|
|
16
|
+
this.latitude = 35.7568;
|
|
17
|
+
this.longitude = 51.412;
|
|
107
18
|
}
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
this._initilaize();
|
|
19
|
+
get latitudeUi() {
|
|
20
|
+
return this.customFormPanelUi._dictFieldUi.Latitude;
|
|
111
21
|
}
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
this._map.setView([latitude, longitude], 16);
|
|
115
|
-
L.tileLayer('https://api.mapbox.com/styles/v1/{id}/tiles/{z}/{x}/{y}?access_token={accessToken}', {
|
|
116
|
-
attribution: '',
|
|
117
|
-
maxZoom: 18,
|
|
118
|
-
id: 'mapbox/streets-v11',
|
|
119
|
-
tileSize: 512,
|
|
120
|
-
zoomOffset: -1,
|
|
121
|
-
accessToken: 'pk.eyJ1IjoibXJlemFkZXZlbG9wZXIiLCJhIjoiY2p6anlrdTE2MDBxdjNtczZtYWFqbHFmdiJ9.SzniRy2KH6U3gdbOFnwA7Q'
|
|
122
|
-
}).addTo(this._map);
|
|
123
|
-
const marker = this._createMarker('0', { mo: 'test' }, latitude, longitude, 'my location', 'assets/images/UploadTarget_32.png', true);
|
|
124
|
-
marker.addTo(this._map);
|
|
22
|
+
get longitudeUi() {
|
|
23
|
+
return this.customFormPanelUi._dictFieldUi.Longitude;
|
|
125
24
|
}
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
25
|
+
openDialog(dialog) {
|
|
26
|
+
this._dialogService.open(dialog, {
|
|
27
|
+
responsivePadding: true,
|
|
28
|
+
fullScreen: true,
|
|
29
|
+
mobile: true,
|
|
30
|
+
ariaLabelledBy: 'map',
|
|
31
|
+
ariaDescribedBy: 'choose location',
|
|
32
|
+
focusTrapped: true
|
|
33
|
+
});
|
|
135
34
|
}
|
|
136
|
-
|
|
137
|
-
|
|
35
|
+
ngOnInit() {
|
|
36
|
+
super.ngOnInit();
|
|
37
|
+
this._setCurrentLocation(this.latitudeUi?.value, this.longitudeUi?.value);
|
|
138
38
|
}
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
}
|
|
39
|
+
onFullscreen() {
|
|
40
|
+
this.fullscreen = true;
|
|
41
|
+
this.openDialog(this.dialogTemplate);
|
|
143
42
|
}
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
Data: mo,
|
|
148
|
-
title: text,
|
|
149
|
-
draggable,
|
|
150
|
-
icon: new L.BeautifyIcon.Icon({
|
|
151
|
-
icon: 'functional-location',
|
|
152
|
-
iconSize: [24, 24] // size of the icon
|
|
153
|
-
})
|
|
154
|
-
};
|
|
155
|
-
// var marker = L.BeautifyMarker.marker([Number(lat), Number(lng)], {
|
|
156
|
-
const marker = L.marker([Number(lat), Number(lng)], markerCfg);
|
|
157
|
-
// marker.on('click', function (e) { this.fireEvent('ItemClick', this, e); });
|
|
158
|
-
marker.on('dblclick', (e) => {
|
|
159
|
-
this._dbleClickOnMarker(e);
|
|
160
|
-
});
|
|
161
|
-
marker.on('moveend', (e) => {
|
|
162
|
-
this._onMoveEnd(e, marker);
|
|
163
|
-
});
|
|
164
|
-
marker.on('move', (e) => {
|
|
165
|
-
this._onMove(e, marker);
|
|
166
|
-
});
|
|
167
|
-
return marker;
|
|
43
|
+
onExistFullscreen() {
|
|
44
|
+
this.fullscreen = false;
|
|
45
|
+
this._cdr.detectChanges();
|
|
168
46
|
}
|
|
169
|
-
|
|
170
|
-
|
|
47
|
+
onOpenChange(isOpen) {
|
|
48
|
+
this.fullscreen = isOpen;
|
|
171
49
|
}
|
|
172
|
-
|
|
173
|
-
|
|
50
|
+
onErrorNavigatorLocation(err) {
|
|
51
|
+
const err2 = `خطا در دریافت موقعیت مکانی جاری. (${err.message})`;
|
|
52
|
+
BarsaApi.Bw.Toast.Error(err2);
|
|
53
|
+
}
|
|
54
|
+
onMove(e) {
|
|
55
|
+
this.latitude = e.latlng.lat;
|
|
56
|
+
this.longitude = e.latlng.lng;
|
|
174
57
|
}
|
|
175
|
-
|
|
176
|
-
this.
|
|
177
|
-
this.longitudeUi.value = e.latlng.lng;
|
|
58
|
+
onMoveEnd(e) {
|
|
59
|
+
this._valueChanged();
|
|
178
60
|
}
|
|
179
|
-
|
|
61
|
+
_setCurrentLocation(lat, lng) {
|
|
62
|
+
if (lat && lng) {
|
|
63
|
+
this.currentLocation = [lat, lng];
|
|
64
|
+
}
|
|
65
|
+
}
|
|
66
|
+
_valueChanged() {
|
|
67
|
+
this.latitudeUi.value = this.latitude;
|
|
68
|
+
this.longitudeUi.value = this.longitude;
|
|
180
69
|
this.latitudeUi.fireEvent('change', this.latitudeUi, this.latitudeUi.value);
|
|
181
70
|
this.longitudeUi.fireEvent('change', this.longitudeUi, this.longitudeUi.value);
|
|
182
|
-
|
|
183
|
-
_dbleClickOnMarker(e) {
|
|
184
|
-
// debugger;
|
|
71
|
+
this._setCurrentLocation(this.latitude, this.longitude);
|
|
185
72
|
}
|
|
186
73
|
}
|
|
187
74
|
GeographicLocationComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: GeographicLocationComponent, deps: null, target: i0.ɵɵFactoryTarget.Component });
|
|
188
|
-
GeographicLocationComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.7", type: GeographicLocationComponent, selector: "bdc-geographic-location", usesInheritance: true, ngImport: i0, template: "<ng-container *ngIf=\"customFormPanelUi\">\n <bnrc-form *untilInView=\"el\" [customFormPanelUi]=\"customFormPanelUi\"></bnrc-form>\n</ng-container>\n", styles: [":host{display:block;
|
|
75
|
+
GeographicLocationComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.7", type: GeographicLocationComponent, selector: "bdc-geographic-location", viewQueries: [{ propertyName: "dialogTemplate", first: true, predicate: ["confirmationDialog"], descendants: true }], usesInheritance: true, ngImport: i0, template: "<ng-container *ngIf=\"customFormPanelUi\">\n <bnrc-form style=\"display: none\" *untilInView=\"el\" [customFormPanelUi]=\"customFormPanelUi\"></bnrc-form>\n</ng-container>\n\n<bdc-barsa-geographic-location\n *ngIf=\"!fullscreen\"\n [defaultLocation]=\"[35.7568, 51.412]\"\n [showFullscreenButton]=\"customFieldInfo.ShowFullscreenButton\"\n [showLocationButton]=\"customFieldInfo.ShowLocationButton\"\n [setAutomaticLocation]=\"customFieldInfo.GetCurrentLocation\"\n [currentLocation]=\"currentLocation\"\n [disableOrReadonly]=\"(disableOrReadonly$ | async) === true || customFieldInfo.Draggable === false\"\n (move)=\"onMove($event)\"\n (error)=\"onErrorNavigatorLocation($event)\"\n (moveEnd)=\"onMoveEnd($event)\"\n (fullscreen)=\"onFullscreen()\"\n></bdc-barsa-geographic-location>\n\n<ng-template let-dialog let-dialogConfig=\"dialogConfig\" #confirmationDialog>\n <fd-dialog [dialogConfig]=\"dialogConfig\" [dialogRef]=\"dialog\">\n <fd-dialog-header>\n <h1 id=\"fd-dialog-header-10\" fd-title>Map</h1>\n </fd-dialog-header>\n\n <fd-dialog-body>\n <bdc-barsa-geographic-location\n style=\"height: 100% !important\"\n [defaultLocation]=\"[35.7568, 51.412]\"\n [showFullscreenButton]=\"false\"\n [showLocationButton]=\"customFieldInfo.ShowLocationButton\"\n [setAutomaticLocation]=\"customFieldInfo.GetCurrentLocation\"\n [currentLocation]=\"currentLocation\"\n [disableOrReadonly]=\"(disableOrReadonly$ | async) === true || customFieldInfo.Draggable === false\"\n (move)=\"onMove($event)\"\n (error)=\"onErrorNavigatorLocation($event)\"\n (moveEnd)=\"onMoveEnd($event)\"\n ></bdc-barsa-geographic-location>\n </fd-dialog-body>\n\n <fd-dialog-footer>\n <fd-button-bar\n fdType=\"standard\"\n [label]=\"'Close' | bbbTranslate\"\n (click)=\"onExistFullscreen(); dialog.close('Continue')\"\n [ariaLabel]=\"'Close' | bbbTranslate\"\n ></fd-button-bar>\n </fd-dialog-footer>\n </fd-dialog>\n</ng-template>\n", styles: [":host{display:block;position:relative}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.FormComponent, selector: "bnrc-form", inputs: ["params", "customFormPanelUi", "formPanelCtrl", "formPanelCtrlId"], outputs: ["titleChanged", "moChanged", "formClose", "formRendered"] }, { kind: "directive", type: i2.UntilInViewDirective, selector: "[untilInView]", inputs: ["untilInView", "intersectionDebounce"] }, { kind: "component", type: i3.ButtonBarComponent, selector: "fd-button-bar", inputs: ["fullWidth", "fdType", "title", "ariaLabel", "ariaLabelledby", "id"] }, { kind: "component", type: i4.DialogComponent, selector: "fd-dialog", inputs: ["class", "dialogRef", "dialogConfig"] }, { kind: "component", type: i4.DialogBodyComponent, selector: "fd-dialog-body" }, { kind: "component", type: i4.DialogFooterComponent, selector: "fd-dialog-footer" }, { kind: "component", type: i4.DialogHeaderComponent, selector: "fd-dialog-header" }, { kind: "component", type: i5.TitleComponent, selector: "h1[fd-title], h2[fd-title], h3[fd-title], h4[fd-title], h5[fd-title], h6[fd-title]", inputs: ["headerSize", "wrap"], exportAs: ["fd-title"] }, { kind: "component", type: i6.BarsaGeographicLocationComponent, selector: "bdc-barsa-geographic-location", inputs: ["disableOrReadonly", "currentLocation", "setAutomaticLocation", "showLocationButton", "showFullscreenButton", "defaultLocation"], outputs: ["move", "moveEnd", "fullscreen", "error"] }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }, { kind: "pipe", type: i2.BbbTranslatePipe, name: "bbbTranslate" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
189
76
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: GeographicLocationComponent, decorators: [{
|
|
190
77
|
type: Component,
|
|
191
|
-
args: [{ selector: 'bdc-geographic-location', changeDetection: ChangeDetectionStrategy.OnPush, template: "<ng-container *ngIf=\"customFormPanelUi\">\n <bnrc-form *untilInView=\"el\" [customFormPanelUi]=\"customFormPanelUi\"></bnrc-form>\n</ng-container>\n", styles: [":host{display:block;
|
|
192
|
-
}]
|
|
193
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"geographic-location.component.js","sourceRoot":"","sources":["../../../../../projects/barsa-develop-components/src/lib/geographic-location/geographic-location.component.ts","../../../../../projects/barsa-develop-components/src/lib/geographic-location/geographic-location.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, OnInit, AfterViewInit } from '@angular/core';\nimport { getUniqueId } from 'barsa-novin-ray-core';\nimport { UiMoInfoSubFormUiComponent } from 'barsa-sap-ui';\n\nimport * as L from 'leaflet';\n\nconst defaults = {\n    iconColor: '#1EB300',\n\n    iconAnchor: {\n        marker: [14, 36],\n        circle: [11, 10],\n        'circle-dot': [5, 5],\n        'rectangle-dot': [5, 6],\n        doughnut: [8, 8]\n    },\n\n    popupAnchor: {\n        marker: [0, -25],\n        circle: [-3, -76],\n        'circle-dot': [0, -2],\n        'rectangle-dot': [0, -2],\n        doughnut: [0, -2]\n    },\n\n    innerIconAnchor: {\n        marker: [-2, 5],\n        circle: [0, 2]\n    },\n\n    iconSize: {\n        marker: [28, 28],\n        circle: [22, 22],\n        'circle-dot': [2, 2],\n        'rectangle-dot': [2, 2],\n        doughnut: [15, 15]\n    }\n};\nL.BeautifyIcon = {\n    Icon: L.Icon.extend({\n        options: {\n            icon: 'leaf',\n            iconSize: defaults.iconSize.circle,\n            iconAnchor: defaults.iconAnchor.circle,\n            iconShape: 'circle',\n            iconStyle: '',\n            innerIconAnchor: [0, 3], // circle with fa or glyphicon or marker with text\n            innerIconStyle: '',\n            isAlphaNumericIcon: false,\n            text: 1,\n            borderColor: defaults.iconColor,\n            borderWidth: 2,\n            borderStyle: 'solid',\n            backgroundColor: 'white',\n            textColor: defaults.iconColor,\n            customClasses: '',\n            spin: false,\n            prefix: 'sap-icon--',\n            html: ''\n        },\n        createIconInnerHtml() {\n            const options = this.options;\n            if (\n                options.iconShape === 'circle-dot' ||\n                options.iconShape === 'rectangle-dot' ||\n                options.iconShape === 'doughnut'\n            ) {\n                return '';\n            }\n            const innerIconStyle = this.getInnerIconStyle(options);\n            if (options.isAlphaNumericIcon) {\n                return '<div style=\"' + innerIconStyle + '\">' + options.text + '</div>';\n            }\n\n            let spinClass = '';\n            if (options.spin) {\n                spinClass = ' fa-spin';\n            }\n\n            return (\n                '<fd-icon class=\"' +\n                options.prefix +\n                ' ' +\n                options.prefix +\n                '-' +\n                options.icon +\n                spinClass +\n                '\" style=\"' +\n                innerIconStyle +\n                '\"></fd-icon>'\n            );\n        },\n        getInnerIconStyle(options) {\n            const innerAnchor = L.point(options.innerIconAnchor);\n            return (\n                'color:' +\n                options.textColor +\n                ';margin-top:' +\n                innerAnchor.y +\n                'px; margin-left:' +\n                innerAnchor.x +\n                'px;' +\n                options.innerIconStyle\n            );\n        }\n    })\n};\n@Component({\n    selector: 'bdc-geographic-location',\n    templateUrl: './geographic-location.component.html',\n    styleUrls: ['./geographic-location.component.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class GeographicLocationComponent extends UiMoInfoSubFormUiComponent implements OnInit, AfterViewInit {\n    id = getUniqueId(3);\n    applied = false;\n\n    private _map: any;\n    private _navigatorOptions = {\n        enableHighAccuracy: true,\n        timeout: 5000,\n        maximumAge: 0\n    };\n\n    ngAfterViewInit(): void {\n        super.ngAfterViewInit();\n        this._initilaize();\n    }\n    protected _setGeoLocation(position: { coords: { latitude: any; longitude: any } }): void {\n        const {\n            coords: { latitude, longitude }\n        } = position;\n\n        this._map.setView([latitude, longitude], 16);\n        L.tileLayer('https://api.mapbox.com/styles/v1/{id}/tiles/{z}/{x}/{y}?access_token={accessToken}', {\n            attribution: '',\n            maxZoom: 18,\n            id: 'mapbox/streets-v11',\n            tileSize: 512,\n            zoomOffset: -1,\n            accessToken:\n                'pk.eyJ1IjoibXJlemFkZXZlbG9wZXIiLCJhIjoiY2p6anlrdTE2MDBxdjNtczZtYWFqbHFmdiJ9.SzniRy2KH6U3gdbOFnwA7Q'\n        }).addTo(this._map);\n        const marker = this._createMarker(\n            '0',\n            { mo: 'test' },\n            latitude,\n            longitude,\n            'my location',\n            'assets/images/UploadTarget_32.png',\n            true\n        );\n        marker.addTo(this._map);\n    }\n\n    protected _initilaize(): void {\n        const defaultLatLng = [35.7568, 51.412];\n        if (this.latitudeUi && this.latitudeUi.value) {\n            defaultLatLng[0] = this.latitudeUi.value;\n            defaultLatLng[1] = this.longitudeUi.value;\n        }\n\n        this._map = L.map(this._el.nativeElement);\n        this._setGeoLocation({ coords: { latitude: defaultLatLng[0], longitude: defaultLatLng[1] } });\n        this._getNavigatorCurrentPosition();\n    }\n    protected _onErrorNavigatorLocation(err): void {\n        console.error(err);\n    }\n    protected _getNavigatorCurrentPosition(): void {\n        if (navigator.geolocation) {\n            navigator.geolocation.getCurrentPosition(\n                (position) => this._setGeoLocation(position),\n                (err) => this._onErrorNavigatorLocation(err),\n                this._navigatorOptions\n            );\n        }\n    }\n    protected _createMarker(id, mo, lat, lng, text, icon, draggable): any {\n        const markerCfg = {\n            Id: id,\n            Data: mo,\n            title: text,\n            draggable,\n            icon: new L.BeautifyIcon.Icon({\n                icon: 'functional-location',\n                iconSize: [24, 24] // size of the icon\n            })\n        };\n\n        // var marker = L.BeautifyMarker.marker([Number(lat), Number(lng)], {\n        const marker = L.marker([Number(lat), Number(lng)], markerCfg);\n\n        // marker.on('click', function (e) { this.fireEvent('ItemClick', this, e); });\n        marker.on('dblclick', (e) => {\n            this._dbleClickOnMarker(e);\n        });\n        marker.on('moveend', (e) => {\n            this._onMoveEnd(e, marker);\n        });\n        marker.on('move', (e) => {\n            this._onMove(e, marker);\n        });\n\n        return marker;\n    }\n    get latitudeUi(): any {\n        return this.customFormPanelUi._dictFieldUi.Latitude;\n    }\n    get longitudeUi(): any {\n        return this.customFormPanelUi._dictFieldUi.Longitude;\n    }\n    protected _onMove(e, marker): void {\n        this.latitudeUi.value = e.latlng.lat;\n        this.longitudeUi.value = e.latlng.lng;\n    }\n    protected _onMoveEnd(e, marker): void {\n        this.latitudeUi.fireEvent('change', this.latitudeUi, this.latitudeUi.value);\n        this.longitudeUi.fireEvent('change', this.longitudeUi, this.longitudeUi.value);\n    }\n    protected _dbleClickOnMarker(e): void {\n        // debugger;\n    }\n}\n","<ng-container *ngIf=\"customFormPanelUi\">\n    <bnrc-form *untilInView=\"el\" [customFormPanelUi]=\"customFormPanelUi\"></bnrc-form>\n</ng-container>\n"]}
|
|
78
|
+
args: [{ selector: 'bdc-geographic-location', changeDetection: ChangeDetectionStrategy.OnPush, template: "<ng-container *ngIf=\"customFormPanelUi\">\n <bnrc-form style=\"display: none\" *untilInView=\"el\" [customFormPanelUi]=\"customFormPanelUi\"></bnrc-form>\n</ng-container>\n\n<bdc-barsa-geographic-location\n *ngIf=\"!fullscreen\"\n [defaultLocation]=\"[35.7568, 51.412]\"\n [showFullscreenButton]=\"customFieldInfo.ShowFullscreenButton\"\n [showLocationButton]=\"customFieldInfo.ShowLocationButton\"\n [setAutomaticLocation]=\"customFieldInfo.GetCurrentLocation\"\n [currentLocation]=\"currentLocation\"\n [disableOrReadonly]=\"(disableOrReadonly$ | async) === true || customFieldInfo.Draggable === false\"\n (move)=\"onMove($event)\"\n (error)=\"onErrorNavigatorLocation($event)\"\n (moveEnd)=\"onMoveEnd($event)\"\n (fullscreen)=\"onFullscreen()\"\n></bdc-barsa-geographic-location>\n\n<ng-template let-dialog let-dialogConfig=\"dialogConfig\" #confirmationDialog>\n <fd-dialog [dialogConfig]=\"dialogConfig\" [dialogRef]=\"dialog\">\n <fd-dialog-header>\n <h1 id=\"fd-dialog-header-10\" fd-title>Map</h1>\n </fd-dialog-header>\n\n <fd-dialog-body>\n <bdc-barsa-geographic-location\n style=\"height: 100% !important\"\n [defaultLocation]=\"[35.7568, 51.412]\"\n [showFullscreenButton]=\"false\"\n [showLocationButton]=\"customFieldInfo.ShowLocationButton\"\n [setAutomaticLocation]=\"customFieldInfo.GetCurrentLocation\"\n [currentLocation]=\"currentLocation\"\n [disableOrReadonly]=\"(disableOrReadonly$ | async) === true || customFieldInfo.Draggable === false\"\n (move)=\"onMove($event)\"\n (error)=\"onErrorNavigatorLocation($event)\"\n (moveEnd)=\"onMoveEnd($event)\"\n ></bdc-barsa-geographic-location>\n </fd-dialog-body>\n\n <fd-dialog-footer>\n <fd-button-bar\n fdType=\"standard\"\n [label]=\"'Close' | bbbTranslate\"\n (click)=\"onExistFullscreen(); dialog.close('Continue')\"\n [ariaLabel]=\"'Close' | bbbTranslate\"\n ></fd-button-bar>\n </fd-dialog-footer>\n </fd-dialog>\n</ng-template>\n", styles: [":host{display:block;position:relative}\n"] }]
|
|
79
|
+
}], propDecorators: { dialogTemplate: [{
|
|
80
|
+
type: ViewChild,
|
|
81
|
+
args: ['confirmationDialog']
|
|
82
|
+
}] } });
|
|
83
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"geographic-location.component.js","sourceRoot":"","sources":["../../../../../projects/barsa-develop-components/src/lib/geographic-location/geographic-location.component.ts","../../../../../projects/barsa-develop-components/src/lib/geographic-location/geographic-location.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, OnInit, TemplateRef, ViewChild } from '@angular/core';\nimport { BarsaApi } from 'barsa-novin-ray-core';\nimport { UiMoInfoSubFormUiComponent } from 'barsa-sap-ui';\n\n@Component({\n    selector: 'bdc-geographic-location',\n    templateUrl: './geographic-location.component.html',\n    styleUrls: ['./geographic-location.component.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class GeographicLocationComponent extends UiMoInfoSubFormUiComponent implements OnInit {\n    @ViewChild('confirmationDialog') dialogTemplate: TemplateRef<any>;\n    fullscreen = false;\n    currentLocation: number[] = [];\n    latitude = 35.7568;\n    longitude = 51.412;\n    customFormPanelUi: any;\n    get latitudeUi(): any {\n        return this.customFormPanelUi._dictFieldUi.Latitude;\n    }\n    get longitudeUi(): any {\n        return this.customFormPanelUi._dictFieldUi.Longitude;\n    }\n\n    openDialog(dialog: TemplateRef<any>): void {\n        this._dialogService.open(dialog, {\n            responsivePadding: true,\n            fullScreen: true,\n            mobile: true,\n            ariaLabelledBy: 'map',\n            ariaDescribedBy: 'choose location',\n            focusTrapped: true\n        });\n    }\n    ngOnInit(): void {\n        super.ngOnInit();\n        this._setCurrentLocation(this.latitudeUi?.value, this.longitudeUi?.value);\n    }\n    onFullscreen(): void {\n        this.fullscreen = true;\n        this.openDialog(this.dialogTemplate);\n    }\n    onExistFullscreen(): void {\n        this.fullscreen = false;\n        this._cdr.detectChanges();\n    }\n    onOpenChange(isOpen): void {\n        this.fullscreen = isOpen;\n    }\n    onErrorNavigatorLocation(err): void {\n        const err2 = `خطا در دریافت موقعیت مکانی جاری. (${err.message})`;\n        BarsaApi.Bw.Toast.Error(err2);\n    }\n    onMove(e): void {\n        this.latitude = e.latlng.lat;\n        this.longitude = e.latlng.lng;\n    }\n    onMoveEnd(e): void {\n        this._valueChanged();\n    }\n    protected _setCurrentLocation(lat: number | undefined, lng: number | undefined): void {\n        if (lat && lng) {\n            this.currentLocation = [lat, lng];\n        }\n    }\n    protected _valueChanged(): void {\n        this.latitudeUi.value = this.latitude;\n        this.longitudeUi.value = this.longitude;\n        this.latitudeUi.fireEvent('change', this.latitudeUi, this.latitudeUi.value);\n        this.longitudeUi.fireEvent('change', this.longitudeUi, this.longitudeUi.value);\n        this._setCurrentLocation(this.latitude, this.longitude);\n    }\n}\n","<ng-container *ngIf=\"customFormPanelUi\">\n    <bnrc-form style=\"display: none\" *untilInView=\"el\" [customFormPanelUi]=\"customFormPanelUi\"></bnrc-form>\n</ng-container>\n\n<bdc-barsa-geographic-location\n    *ngIf=\"!fullscreen\"\n    [defaultLocation]=\"[35.7568, 51.412]\"\n    [showFullscreenButton]=\"customFieldInfo.ShowFullscreenButton\"\n    [showLocationButton]=\"customFieldInfo.ShowLocationButton\"\n    [setAutomaticLocation]=\"customFieldInfo.GetCurrentLocation\"\n    [currentLocation]=\"currentLocation\"\n    [disableOrReadonly]=\"(disableOrReadonly$ | async) === true || customFieldInfo.Draggable === false\"\n    (move)=\"onMove($event)\"\n    (error)=\"onErrorNavigatorLocation($event)\"\n    (moveEnd)=\"onMoveEnd($event)\"\n    (fullscreen)=\"onFullscreen()\"\n></bdc-barsa-geographic-location>\n\n<ng-template let-dialog let-dialogConfig=\"dialogConfig\" #confirmationDialog>\n    <fd-dialog [dialogConfig]=\"dialogConfig\" [dialogRef]=\"dialog\">\n        <fd-dialog-header>\n            <h1 id=\"fd-dialog-header-10\" fd-title>Map</h1>\n        </fd-dialog-header>\n\n        <fd-dialog-body>\n            <bdc-barsa-geographic-location\n                style=\"height: 100% !important\"\n                [defaultLocation]=\"[35.7568, 51.412]\"\n                [showFullscreenButton]=\"false\"\n                [showLocationButton]=\"customFieldInfo.ShowLocationButton\"\n                [setAutomaticLocation]=\"customFieldInfo.GetCurrentLocation\"\n                [currentLocation]=\"currentLocation\"\n                [disableOrReadonly]=\"(disableOrReadonly$ | async) === true || customFieldInfo.Draggable === false\"\n                (move)=\"onMove($event)\"\n                (error)=\"onErrorNavigatorLocation($event)\"\n                (moveEnd)=\"onMoveEnd($event)\"\n            ></bdc-barsa-geographic-location>\n        </fd-dialog-body>\n\n        <fd-dialog-footer>\n            <fd-button-bar\n                fdType=\"standard\"\n                [label]=\"'Close' | bbbTranslate\"\n                (click)=\"onExistFullscreen(); dialog.close('Continue')\"\n                [ariaLabel]=\"'Close' | bbbTranslate\"\n            ></fd-button-bar>\n        </fd-dialog-footer>\n    </fd-dialog>\n</ng-template>\n"]}
|
package/esm2020/public-api.mjs
CHANGED
|
@@ -49,8 +49,9 @@ export * from './lib/barsa-document-list-item/barsa-document-list-item.component
|
|
|
49
49
|
export * from './lib/accept-reject/accept-reject.component';
|
|
50
50
|
export * from './lib/footer/footer.component';
|
|
51
51
|
export * from './lib/geographic-location/geographic-location.component';
|
|
52
|
+
export * from './lib/barsa-geographic-location/barsa-geographic-location.component';
|
|
52
53
|
/*
|
|
53
54
|
* Public API Surface of barsa-develop-components
|
|
54
55
|
*/
|
|
55
56
|
export * from './lib/barsa-develop-components.module';
|
|
56
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
57
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3Byb2plY3RzL2JhcnNhLWRldmVsb3AtY29tcG9uZW50cy9zcmMvcHVibGljLWFwaS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLDJEQUEyRCxDQUFDO0FBQzFFLGNBQWMsbURBQW1ELENBQUM7QUFDbEUsY0FBYyxtRUFBbUUsQ0FBQztBQUNsRixjQUFjLGlFQUFpRSxDQUFDO0FBQ2hGLGNBQWMsMkNBQTJDLENBQUM7QUFDMUQsY0FBYywyREFBMkQsQ0FBQztBQUMxRSxjQUFjLDZEQUE2RCxDQUFDO0FBQzVFLGNBQWMsK0NBQStDLENBQUM7QUFDOUQsY0FBYyxxQ0FBcUMsQ0FBQztBQUNwRCxjQUFjLG1FQUFtRSxDQUFDO0FBQ2xGLGNBQWMsdUNBQXVDLENBQUM7QUFDdEQsY0FBYyx5REFBeUQsQ0FBQztBQUN4RSxjQUFjLDJFQUEyRSxDQUFDO0FBQzFGLGNBQWMsaUZBQWlGLENBQUM7QUFDaEcsY0FBYyxpRUFBaUUsQ0FBQztBQUNoRixjQUFjLHlFQUF5RSxDQUFDO0FBQ3hGLGNBQWMsNkVBQTZFLENBQUM7QUFDNUYsY0FBYyxpSEFBaUgsQ0FBQztBQUNoSSxjQUFjLDZFQUE2RSxDQUFDO0FBQzVGLGNBQWMsbUdBQW1HLENBQUM7QUFDbEgsY0FBYyxtR0FBbUcsQ0FBQztBQUNsSCxjQUFjLGlHQUFpRyxDQUFDO0FBQ2hILGNBQWMsbUVBQW1FLENBQUM7QUFDbEYsY0FBYyxpREFBaUQsQ0FBQztBQUNoRSxjQUFjLDJCQUEyQixDQUFDO0FBQzFDLGNBQWMsaURBQWlELENBQUM7QUFDaEUsY0FBYywrREFBK0QsQ0FBQztBQUM5RSxjQUFjLGlEQUFpRCxDQUFDO0FBQ2hFLGNBQWMsaUVBQWlFLENBQUM7QUFDaEYsY0FBYyx1REFBdUQsQ0FBQztBQUN0RSxjQUFjLHlFQUF5RSxDQUFDO0FBQ3hGLGNBQWMsaUVBQWlFLENBQUM7QUFDaEYsY0FBYywyRUFBMkUsQ0FBQztBQUMxRixjQUFjLHlDQUF5QyxDQUFDO0FBQ3hELGNBQWMsK0JBQStCLENBQUM7QUFDOUMsY0FBYyx5Q0FBeUMsQ0FBQztBQUN4RCxjQUFjLG1EQUFtRCxDQUFDO0FBQ2xFLGNBQWMseUVBQXlFLENBQUM7QUFDeEYsY0FBYyx5REFBeUQsQ0FBQztBQUN4RSxjQUFjLDZFQUE2RSxDQUFDO0FBQzVGLGNBQWMsMkRBQTJELENBQUM7QUFDMUUsY0FBYyx5Q0FBeUMsQ0FBQztBQUN4RCxjQUFjLHlEQUF5RCxDQUFDO0FBQ3hFLGNBQWMsNkRBQTZELENBQUM7QUFDNUUsY0FBYyxpRUFBaUUsQ0FBQztBQUNoRixjQUFjLHVEQUF1RCxDQUFDO0FBQ3RFLGNBQWMsaURBQWlELENBQUM7QUFDaEUsY0FBYyxtRUFBbUUsQ0FBQztBQUNsRixjQUFjLDZDQUE2QyxDQUFDO0FBQzVELGNBQWMsK0JBQStCLENBQUM7QUFDOUMsY0FBYyx5REFBeUQsQ0FBQztBQUN4RSxjQUFjLHFFQUFxRSxDQUFDO0FBQ3BGOztHQUVHO0FBRUgsY0FBYyx1Q0FBdUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vbGliL3VpLXRleHQtZmllbGQtc2VhcmNoL3VpLXRleHQtZmllbGQtc2VhcmNoLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi90YWItcHJvY2Vzcy12aWV3L3RhYi1wcm9jZXNzLXZpZXcuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3VpLWVudW0tc2VnbWVudGVkLWJ1dHRvbi91aS1lbnVtLXNlZ21lbnRlZC1idXR0b24uY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL21pY3JvLXByb2Nlc3MtZmxvdy12aWV3L21pY3JvLXByb2Nlc3MtZmxvdy12aWV3LmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9zZXR0aW5nLWZvcm0vc2V0dGluZy1mb3JtLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9iYXJjb2RlLXJlYWRlci12aWRlby9iYXJjb2RlLXJlYWRlci12aWRlby5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvYmFyY29kZS1yZWFkZXItZGlhbG9nL2JhcmNvZGUtcmVhZGVyLWRpYWxvZy5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvYmFyY29kZS1yZWFkZXIvYmFyY29kZS1yZWFkZXIuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3VpLXBlcnNvbi91aS1wZXJzb24uY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2xvZ2luLXNvY2lhbC1jb25uY2V0aW9ucy9sb2dpbi1zb2NpYWwtY29ubmNldGlvbnMuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2xvZ2luLWZvcm0vbG9naW4tZm9ybS5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvc2VydmljZS1kZXNrLWhlYWRlci9zZXJ2aWNlLWRlc2staGVhZGVyLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jYXJkLWNvbnRlbnQtaW1hZ2UtYW5kLXRpdGxlL2NhcmQtY29udGVudC1pbWFnZS1hbmQtdGl0bGUuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NhcmQtaGVhZGVyLWxvZ28tdGl0bGUtc3VidGl0bGUvY2FyZC1oZWFkZXItbG9nby10aXRsZS1zdWJ0aXRsZS5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvZm9ybS1jb250ZW50LXF1aWNrLXZpZXcvZm9ybS1jb250ZW50LXF1aWNrLXZpZXcuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3NlcnZpY2UtZGVzay1zZXJ2Y2llLWRldGFpbC9zZXJ2aWNlLWRlc2stc2VydmNpZS1kZXRhaWwuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3NlcnZpY2UtZGVzay12aWV3LW9mLXNlcnZpY2VzL3NlcnZpY2UtZGVzay12aWV3LW9mLXNlcnZpY2VzLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9zZXJ2aWNlLWRlc2stY2FyZC1jb250ZW50LW1vamF2ZXpoYXktYWtoei1zaG9kZS9zZXJ2aWNlLWRlc2stY2FyZC1jb250ZW50LW1vamF2ZXpoYXktYWtoei1zaG9kZS5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvc2VydmljZS1kZXNrLXZpZXctb2Ytc2VydmljZXMvc2VydmljZS1kZXNrLXZpZXctb2Ytc2VydmljZXMuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NhcmQtaGVhZGVyLWJpZy1pbWFnZS10aXRsZS1hbmQtc3VidGl0bGUvY2FyZC1oZWFkZXItYmlnLWltYWdlLXRpdGxlLWFuZC1zdWJ0aXRsZS5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvc2VydmljZS1kZXNrLWZvcm0tbGF5b3V0LWNvbnRlbnQtbW9qYXZlei9zZXJ2aWNlLWRlc2stZm9ybS1sYXlvdXQtY29udGVudC1tb2phdmV6LmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi91bHYtY29udGV4dC1tZW51LWl0ZW0tc2hvdy1maWxlLWNvbnRlbnQvdWx2LWNvbnRleHQtbWVudS1pdGVtLXNob3ctZmlsZS1jb250ZW50LmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9yZXNlbmQtdmVyaWZpY2F0aW9uLWNvZGUvcmVzZW5kLXZlcmlmaWNhdGlvbi1jb2RlLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jaGVja2JveC1idXR0b24vY2hlY2tib3gtYnV0dG9uLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9iYXJjb2RlLWZvcm1hdC1waXBlJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3JlcG9ydC10YWItdmlldy9yZXBvcnQtdGFiLXZpZXcuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3JlcG9ydC1saW5lLWNoYXJ0LXZpZXcvcmVwb3J0LWxpbmUtY2hhcnQtdmlldy5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY2FyZC1oZWFkZXIta3BpL2NhcmQtaGVhZGVyLWtwaS5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY2FyZC1jb250ZW50LWxpbmUtY2hhcnQvY2FyZC1jb250ZW50LWxpbmUtY2hhcnQuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2Zvcm0tY2hhcnQtY29udGVudC9mb3JtLWNoYXJ0LWNvbnRlbnQuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3RhYmxlLXZpZXctdmVydGljYWwtY29sdW1ucy90YWJsZS12aWV3LXZlcnRpY2FsLWNvbHVtbnMuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3F1ZXJ5LXN0cmluZy1vYnNlcnZhYmxlL3F1ZXJ5LXN0cmluZy1vYnNlcnZhYmxlLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9xdWVyeS1zdHJpbmctZm9ybS1vYnNlcnZhYmxlL3F1ZXJ5LXN0cmluZy1mb3JtLW9ic2VydmFibGUuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2c0Yi1kZXRhaWxzL2c0Yi1kZXRhaWxzLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9hdmF0YXIvYXZhdGFyLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9nNGItZXN0ZWxhbS9nNGItZXN0ZWxhbS5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvdGltZXItY291bnQtZG93bi90aW1lci1jb3VudC1kb3duLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9tby1pbmZvLW1pY3JvLXByb2NjZXNzLWZsb3cvbW8taW5mby1taWNyby1wcm9jY2Vzcy1mbG93LmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9taWNyby1wcm9jY2Vzcy1mbG93L21pY3JvLXByb2NjZXNzLWZsb3cuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2VudW0taW5mby1taWNyby1wcm9jY2Vzcy1mbG93L2VudW0taW5mby1taWNyby1wcm9jY2Vzcy1mbG93LmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi91aS1waWN0dXJlcy1jYXJvdXNlbC91aS1waWN0dXJlcy1jYXJvdXNlbC5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvdWktbnVtLXJhdGUvdWktbnVtLXJhdGUuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL21lZGlhLWZpbGUtdXBsb2FkZXIvbWVkaWEtZmlsZS11cGxvYWRlci5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvc3ViZm9ybS1pbi1yb3ctcmVwb3J0L3N1YmZvcm0taW4tcm93LXJlcG9ydC5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvbWFzdGVyLWRldGFpbC1jYXJkLWZvcm0vbWFzdGVyLWRldGFpbC1jYXJkLWZvcm0uY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3JlcG9ydC1idXR0b24tdmlldy9yZXBvcnQtYnV0dG9uLXZpZXcuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2JhcnNhLWRvY3VtZW50cy9iYXJzYS1kb2N1bWVudHMuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2JhcnNhLWRvY3VtZW50LWxpc3QtaXRlbS9iYXJzYS1kb2N1bWVudC1saXN0LWl0ZW0uY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2FjY2VwdC1yZWplY3QvYWNjZXB0LXJlamVjdC5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvZm9vdGVyL2Zvb3Rlci5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvZ2VvZ3JhcGhpYy1sb2NhdGlvbi9nZW9ncmFwaGljLWxvY2F0aW9uLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9iYXJzYS1nZW9ncmFwaGljLWxvY2F0aW9uL2JhcnNhLWdlb2dyYXBoaWMtbG9jYXRpb24uY29tcG9uZW50Jztcbi8qXG4gKiBQdWJsaWMgQVBJIFN1cmZhY2Ugb2YgYmFyc2EtZGV2ZWxvcC1jb21wb25lbnRzXG4gKi9cblxuZXhwb3J0ICogZnJvbSAnLi9saWIvYmFyc2EtZGV2ZWxvcC1jb21wb25lbnRzLm1vZHVsZSc7XG4iXX0=
|