@morozeckiy/dd-lib 0.2.71 → 0.4.25
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/assets/images/svg/file.svg +12 -0
- package/assets/images/svg/reload.svg +11 -0
- package/assets/scss/common.scss +22 -1
- package/assets/scss/grid.scss +158 -0
- package/assets/scss/keyframes.scss +9 -0
- package/assets/scss/reset.scss +4 -0
- package/assets/scss/titles.scss +24 -10
- package/assets/styles.scss +2 -0
- package/esm2022/lib/common/lib-common-input-text.mjs +31 -26
- package/esm2022/lib/components/data-empty/data-empty.component.mjs +8 -3
- package/esm2022/lib/core/dialog/modal-base/modal-base.component.mjs +12 -5
- package/esm2022/lib/core/directives/click-outside.directive.mjs +2 -2
- package/esm2022/lib/core/directives/counter.directive.mjs +16 -4
- package/esm2022/lib/core/services/destroy.service.mjs +1 -1
- package/esm2022/lib/core/services/fetcher.service.mjs +26 -48
- package/esm2022/lib/core/services/validators.service.mjs +33 -1
- package/esm2022/lib/core/toast/toast/toast.component.mjs +6 -9
- package/esm2022/lib/core/toast/toast-config.mjs +13 -2
- package/esm2022/lib/core/toast/toast.service.mjs +24 -5
- package/esm2022/lib/core/tooltip/tooltip.directive.mjs +75 -33
- package/esm2022/lib/lib-button/lib-button.component.mjs +3 -7
- package/esm2022/lib/lib-card/lib-card.component.mjs +3 -3
- package/esm2022/lib/lib-checkbox/lib-checkbox.component.mjs +9 -5
- package/esm2022/lib/lib-date-range/lib-date-range.component.mjs +3 -8
- package/esm2022/lib/lib-file-loader/lib-file-loader.component.mjs +34 -11
- package/esm2022/lib/lib-file-upload/lib-file-upload.component.mjs +21 -18
- package/esm2022/lib/lib-filter-button/lib-filter-button.component.mjs +3 -3
- package/esm2022/lib/lib-image-loader/lib-image-loader.component.mjs +3 -3
- package/esm2022/lib/lib-info-card/lib-info-card.component.mjs +30 -0
- package/esm2022/lib/lib-input/lib-input.component.mjs +55 -11
- package/esm2022/lib/lib-loader/lib-loader.component.mjs +6 -3
- package/esm2022/lib/lib-radio/lib-radio.component.mjs +3 -3
- package/esm2022/lib/lib-search-input/lib-search-input.component.mjs +3 -3
- package/esm2022/lib/lib-select/lib-select.component.mjs +68 -15
- package/esm2022/lib/lib-tabs-fragment/lib-tabs-fragment.component.mjs +5 -2
- package/esm2022/lib/lib-textarea/lib-textarea.component.mjs +12 -3
- package/esm2022/lib/svg-icons/svg-icon.model.mjs +11 -1
- package/esm2022/public-api.mjs +2 -1
- package/fesm2022/morozeckiy-dd-lib.mjs +481 -211
- package/fesm2022/morozeckiy-dd-lib.mjs.map +1 -1
- package/lib/common/lib-common-input-text.d.ts +11 -4
- package/lib/components/data-empty/data-empty.component.d.ts +2 -1
- package/lib/core/dialog/modal-base/modal-base.component.d.ts +4 -2
- package/lib/core/directives/counter.directive.d.ts +4 -1
- package/lib/core/services/fetcher.service.d.ts +32 -6
- package/lib/core/services/validators.service.d.ts +3 -2
- package/lib/core/toast/toast/toast.component.d.ts +2 -2
- package/lib/core/toast/toast-config.d.ts +6 -3
- package/lib/core/toast/toast.service.d.ts +6 -2
- package/lib/core/tooltip/tooltip.directive.d.ts +4 -1
- package/lib/lib-button/lib-button.component.d.ts +1 -1
- package/lib/lib-checkbox/lib-checkbox.component.d.ts +2 -1
- package/lib/lib-date-range/lib-date-range.component.d.ts +0 -1
- package/lib/lib-file-loader/lib-file-loader.component.d.ts +10 -5
- package/lib/lib-file-upload/lib-file-upload.component.d.ts +11 -9
- package/lib/lib-info-card/lib-info-card.component.d.ts +12 -0
- package/lib/lib-input/lib-input.component.d.ts +17 -5
- package/lib/lib-loader/lib-loader.component.d.ts +1 -0
- package/lib/lib-select/lib-select.component.d.ts +18 -6
- package/lib/lib-tabs-fragment/lib-tabs-fragment.component.d.ts +3 -2
- package/lib/lib-textarea/lib-textarea.component.d.ts +5 -3
- package/lib/svg-icons/svg-icon.model.d.ts +15 -1
- package/morozeckiy-dd-lib-0.4.25.tgz +0 -0
- package/package.json +1 -1
- package/public-api.d.ts +1 -0
- package/morozeckiy-dd-lib-0.2.71.tgz +0 -0
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
import { Component, HostListener, Input } from '@angular/core';
|
|
2
2
|
import { NgComponentOutlet, NgTemplateOutlet } from '@angular/common';
|
|
3
|
+
import { LibLoaderComponent } from "../../../lib-loader/lib-loader.component";
|
|
3
4
|
import * as i0 from "@angular/core";
|
|
4
5
|
import * as i1 from "@angular/router";
|
|
5
6
|
import * as i2 from "../dialog-ref";
|
|
@@ -9,7 +10,9 @@ export class ModalBaseComponent {
|
|
|
9
10
|
this.router = router;
|
|
10
11
|
this.dialog = dialog;
|
|
11
12
|
this.clearFragment = true;
|
|
12
|
-
this.
|
|
13
|
+
this.borderMobile = false;
|
|
14
|
+
this.showLoader = false;
|
|
15
|
+
this.showContentLoader = false;
|
|
13
16
|
this.afterDestroy = () => {
|
|
14
17
|
if (this.clearFragment) {
|
|
15
18
|
this.router.navigate([], { fragment: undefined, preserveFragment: false, relativeTo: this.route });
|
|
@@ -25,21 +28,25 @@ export class ModalBaseComponent {
|
|
|
25
28
|
this.dialog.close();
|
|
26
29
|
}
|
|
27
30
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.2", ngImport: i0, type: ModalBaseComponent, deps: [{ token: i1.ActivatedRoute }, { token: i1.Router }, { token: i2.DDDialogRef }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
28
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.2.2", type: ModalBaseComponent, isStandalone: true, selector: "dd-modal-base", inputs: { content: "content", component: "component", clearFragment: "clearFragment",
|
|
31
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.2.2", type: ModalBaseComponent, isStandalone: true, selector: "dd-modal-base", inputs: { content: "content", component: "component", clearFragment: "clearFragment", borderMobile: "borderMobile", showLoader: "showLoader", showContentLoader: "showContentLoader" }, host: { listeners: { "document:keydown": "onKeydownComponent($event)" } }, ngImport: i0, template: "<div class=\"popup\" [class.border-mobile]=\"borderMobile\">\r\n @if (showContentLoader) {\r\n <div class=\"loader-modal\">\r\n <dd-lib-loader size=\"giant\"></dd-lib-loader>\r\n </div>\r\n } @else {\r\n <div (click)=\"close()\" class=\"popup__close\"></div>\r\n @if (content) {\r\n <div class=\"popup__content\">\r\n <ng-template [ngTemplateOutletContext]=\"{ data }\" [ngTemplateOutlet]=\"content\"></ng-template>\r\n </div>\r\n }\r\n @if (component) {\r\n <div class=\"popup__content\">\r\n <ng-template [ngComponentOutlet]=\"component\"></ng-template>\r\n </div>\r\n } @else {\r\n <ng-content></ng-content>\r\n }\r\n }\r\n\r\n @if (showLoader) {\r\n <div class=\"loader-modal\">\r\n <dd-lib-loader size=\"giant\"></dd-lib-loader>\r\n </div>\r\n }\r\n</div>\r\n", styles: [".popup{position:relative;max-width:var(--main-body-width);border-radius:24px;background:var(--white-color)}.popup .loader-modal{position:absolute;width:100%;height:100%;top:0;display:flex;align-items:center;justify-content:center;border-radius:24px;background:#251c2c33}@media screen and (max-width: 1320px){.popup{max-width:100%}}@media screen and (max-width: 480px){.popup{border-radius:0}}@media screen and (max-width: 480px){.popup.border-mobile{border-radius:24px}}.popup__close{position:absolute;top:24px;right:24px;width:20px;height:20px;background:url('data:image/svg+xml,<svg fill=\"none\" height=\"20\" viewBox=\"0 0 20 20\" width=\"20\" xmlns=\"http://www.w3.org/2000/svg\">%0D%0A <g clip-path=\"url(%23clip0_355_22081)\">%0D%0A <path d=\"M15 5L5 15\" stroke=\"%23A79BAD\" stroke-linecap=\"round\" stroke-linejoin=\"round\" stroke-width=\"1.5\"/>%0D%0A <path d=\"M5 5L15 15\" stroke=\"%23A79BAD\" stroke-linecap=\"round\" stroke-linejoin=\"round\" stroke-width=\"1.5\"/>%0D%0A </g>%0D%0A <defs>%0D%0A <clipPath id=\"clip0_355_22081\">%0D%0A <rect fill=\"white\" height=\"20\" width=\"20\"/>%0D%0A </clipPath>%0D%0A </defs>%0D%0A</svg>%0D%0A') no-repeat center;cursor:pointer}@media screen and (max-width: 480px){.popup__close{top:16px;right:16px}}\n"], dependencies: [{ kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: NgComponentOutlet, selector: "[ngComponentOutlet]", inputs: ["ngComponentOutlet", "ngComponentOutletInputs", "ngComponentOutletInjector", "ngComponentOutletContent", "ngComponentOutletNgModule", "ngComponentOutletNgModuleFactory"] }, { kind: "component", type: LibLoaderComponent, selector: "dd-lib-loader", inputs: ["color", "size"] }] }); }
|
|
29
32
|
}
|
|
30
33
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.2", ngImport: i0, type: ModalBaseComponent, decorators: [{
|
|
31
34
|
type: Component,
|
|
32
|
-
args: [{ selector: 'dd-modal-base', standalone: true, imports: [NgTemplateOutlet, NgComponentOutlet], template: "<div class=\"popup\">\r\n <div (click)=\"close()\" class=\"popup__close\"></div>\r\n
|
|
35
|
+
args: [{ selector: 'dd-modal-base', standalone: true, imports: [NgTemplateOutlet, NgComponentOutlet, LibLoaderComponent], template: "<div class=\"popup\" [class.border-mobile]=\"borderMobile\">\r\n @if (showContentLoader) {\r\n <div class=\"loader-modal\">\r\n <dd-lib-loader size=\"giant\"></dd-lib-loader>\r\n </div>\r\n } @else {\r\n <div (click)=\"close()\" class=\"popup__close\"></div>\r\n @if (content) {\r\n <div class=\"popup__content\">\r\n <ng-template [ngTemplateOutletContext]=\"{ data }\" [ngTemplateOutlet]=\"content\"></ng-template>\r\n </div>\r\n }\r\n @if (component) {\r\n <div class=\"popup__content\">\r\n <ng-template [ngComponentOutlet]=\"component\"></ng-template>\r\n </div>\r\n } @else {\r\n <ng-content></ng-content>\r\n }\r\n }\r\n\r\n @if (showLoader) {\r\n <div class=\"loader-modal\">\r\n <dd-lib-loader size=\"giant\"></dd-lib-loader>\r\n </div>\r\n }\r\n</div>\r\n", styles: [".popup{position:relative;max-width:var(--main-body-width);border-radius:24px;background:var(--white-color)}.popup .loader-modal{position:absolute;width:100%;height:100%;top:0;display:flex;align-items:center;justify-content:center;border-radius:24px;background:#251c2c33}@media screen and (max-width: 1320px){.popup{max-width:100%}}@media screen and (max-width: 480px){.popup{border-radius:0}}@media screen and (max-width: 480px){.popup.border-mobile{border-radius:24px}}.popup__close{position:absolute;top:24px;right:24px;width:20px;height:20px;background:url('data:image/svg+xml,<svg fill=\"none\" height=\"20\" viewBox=\"0 0 20 20\" width=\"20\" xmlns=\"http://www.w3.org/2000/svg\">%0D%0A <g clip-path=\"url(%23clip0_355_22081)\">%0D%0A <path d=\"M15 5L5 15\" stroke=\"%23A79BAD\" stroke-linecap=\"round\" stroke-linejoin=\"round\" stroke-width=\"1.5\"/>%0D%0A <path d=\"M5 5L15 15\" stroke=\"%23A79BAD\" stroke-linecap=\"round\" stroke-linejoin=\"round\" stroke-width=\"1.5\"/>%0D%0A </g>%0D%0A <defs>%0D%0A <clipPath id=\"clip0_355_22081\">%0D%0A <rect fill=\"white\" height=\"20\" width=\"20\"/>%0D%0A </clipPath>%0D%0A </defs>%0D%0A</svg>%0D%0A') no-repeat center;cursor:pointer}@media screen and (max-width: 480px){.popup__close{top:16px;right:16px}}\n"] }]
|
|
33
36
|
}], ctorParameters: () => [{ type: i1.ActivatedRoute }, { type: i1.Router }, { type: i2.DDDialogRef }], propDecorators: { content: [{
|
|
34
37
|
type: Input
|
|
35
38
|
}], component: [{
|
|
36
39
|
type: Input
|
|
37
40
|
}], clearFragment: [{
|
|
38
41
|
type: Input
|
|
39
|
-
}],
|
|
42
|
+
}], borderMobile: [{
|
|
43
|
+
type: Input
|
|
44
|
+
}], showLoader: [{
|
|
45
|
+
type: Input
|
|
46
|
+
}], showContentLoader: [{
|
|
40
47
|
type: Input
|
|
41
48
|
}], onKeydownComponent: [{
|
|
42
49
|
type: HostListener,
|
|
43
50
|
args: ['document:keydown', ['$event']]
|
|
44
51
|
}] } });
|
|
45
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
52
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibW9kYWwtYmFzZS5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9kZC1saWIvc3JjL2xpYi9jb3JlL2RpYWxvZy9tb2RhbC1iYXNlL21vZGFsLWJhc2UuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZGQtbGliL3NyYy9saWIvY29yZS9kaWFsb2cvbW9kYWwtYmFzZS9tb2RhbC1iYXNlLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyxTQUFTLEVBQUUsWUFBWSxFQUFFLEtBQUssRUFBb0IsTUFBTSxlQUFlLENBQUM7QUFDaEYsT0FBTyxFQUFDLGlCQUFpQixFQUFFLGdCQUFnQixFQUFDLE1BQU0saUJBQWlCLENBQUM7QUFHcEUsT0FBTyxFQUFDLGtCQUFrQixFQUFDLE1BQU0sMENBQTBDLENBQUM7Ozs7QUFTNUUsTUFBTSxPQUFPLGtCQUFrQjtJQVk3QixZQUNVLEtBQXFCLEVBQ3JCLE1BQWMsRUFDZCxNQUF1QztRQUZ2QyxVQUFLLEdBQUwsS0FBSyxDQUFnQjtRQUNyQixXQUFNLEdBQU4sTUFBTSxDQUFRO1FBQ2QsV0FBTSxHQUFOLE1BQU0sQ0FBaUM7UUFaakMsa0JBQWEsR0FBRyxJQUFJLENBQUM7UUFDckIsaUJBQVksR0FBRyxLQUFLLENBQUM7UUFDckIsZUFBVSxHQUErQixLQUFLLENBQUM7UUFDL0Msc0JBQWlCLEdBQStCLEtBQUssQ0FBQztRQW1CL0QsaUJBQVksR0FBRyxHQUFHLEVBQUU7WUFDekIsSUFBSSxJQUFJLENBQUMsYUFBYSxFQUFFLENBQUM7Z0JBQ3ZCLElBQUksQ0FBQyxNQUFNLENBQUMsUUFBUSxDQUFDLEVBQUUsRUFBRSxFQUFFLFFBQVEsRUFBRSxTQUFTLEVBQUUsZ0JBQWdCLEVBQUUsS0FBSyxFQUFFLFVBQVUsRUFBRSxJQUFJLENBQUMsS0FBSyxFQUFFLENBQUMsQ0FBQztZQUNyRyxDQUFDO1FBQ0gsQ0FBQyxDQUFDO0lBYkMsQ0FBQztJQUdHLGtCQUFrQixDQUFDLEtBQW9CO1FBQzVDLElBQUksS0FBSyxDQUFDLEdBQUcsS0FBSyxRQUFRLElBQUksS0FBSyxDQUFDLEdBQUcsS0FBSyxLQUFLLEVBQUUsQ0FBQztZQUNsRCxJQUFJLENBQUMsT0FBUSxFQUFFLENBQUM7UUFDbEIsQ0FBQztJQUNILENBQUM7SUFRTSxLQUFLO1FBQ1YsSUFBSSxDQUFDLE1BQU0sQ0FBQyxLQUFLLEVBQUUsQ0FBQztJQUN0QixDQUFDOzhHQWpDVSxrQkFBa0I7a0dBQWxCLGtCQUFrQiw0VUNiL0IsazFCQTJCQSwyekNEbEJZLGdCQUFnQixvSkFBRSxpQkFBaUIsb1BBQUUsa0JBQWtCOzsyRkFJdEQsa0JBQWtCO2tCQVA5QixTQUFTOytCQUNFLGVBQWUsY0FDYixJQUFJLFdBQ1AsQ0FBQyxnQkFBZ0IsRUFBRSxpQkFBaUIsRUFBRSxrQkFBa0IsQ0FBQztrSUFLbEQsT0FBTztzQkFBdEIsS0FBSztnQkFDVSxTQUFTO3NCQUF4QixLQUFLO2dCQUNVLGFBQWE7c0JBQTVCLEtBQUs7Z0JBQ1UsWUFBWTtzQkFBM0IsS0FBSztnQkFDVSxVQUFVO3NCQUF6QixLQUFLO2dCQUNVLGlCQUFpQjtzQkFBaEMsS0FBSztnQkFhQyxrQkFBa0I7c0JBRHhCLFlBQVk7dUJBQUMsa0JBQWtCLEVBQUUsQ0FBQyxRQUFRLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0NvbXBvbmVudCwgSG9zdExpc3RlbmVyLCBJbnB1dCwgVGVtcGxhdGVSZWYsIFR5cGV9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQge05nQ29tcG9uZW50T3V0bGV0LCBOZ1RlbXBsYXRlT3V0bGV0fSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xyXG5pbXBvcnQge0FjdGl2YXRlZFJvdXRlLCBSb3V0ZXJ9IGZyb20gJ0Bhbmd1bGFyL3JvdXRlcic7XHJcbmltcG9ydCB7REREaWFsb2dSZWZ9IGZyb20gXCIuLi9kaWFsb2ctcmVmXCI7XHJcbmltcG9ydCB7TGliTG9hZGVyQ29tcG9uZW50fSBmcm9tIFwiLi4vLi4vLi4vbGliLWxvYWRlci9saWItbG9hZGVyLmNvbXBvbmVudFwiO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgc2VsZWN0b3I6ICdkZC1tb2RhbC1iYXNlJyxcclxuICBzdGFuZGFsb25lOiB0cnVlLFxyXG4gIGltcG9ydHM6IFtOZ1RlbXBsYXRlT3V0bGV0LCBOZ0NvbXBvbmVudE91dGxldCwgTGliTG9hZGVyQ29tcG9uZW50XSxcclxuICB0ZW1wbGF0ZVVybDogJy4vbW9kYWwtYmFzZS5jb21wb25lbnQuaHRtbCcsXHJcbiAgc3R5bGVVcmxzOiBbJy4vbW9kYWwtYmFzZS5jb21wb25lbnQuc2NzcyddLFxyXG59KVxyXG5leHBvcnQgY2xhc3MgTW9kYWxCYXNlQ29tcG9uZW50IHtcclxuICBASW5wdXQoKSBwdWJsaWMgY29udGVudDogVGVtcGxhdGVSZWY8YW55PiB8IHVuZGVmaW5lZDtcclxuICBASW5wdXQoKSBwdWJsaWMgY29tcG9uZW50OiBUeXBlPGFueT4gfCBudWxsIHwgdW5kZWZpbmVkO1xyXG4gIEBJbnB1dCgpIHB1YmxpYyBjbGVhckZyYWdtZW50ID0gdHJ1ZTtcclxuICBASW5wdXQoKSBwdWJsaWMgYm9yZGVyTW9iaWxlID0gZmFsc2U7XHJcbiAgQElucHV0KCkgcHVibGljIHNob3dMb2FkZXI6IG51bGwgfCBib29sZWFuIHwgdW5kZWZpbmVkID0gZmFsc2U7XHJcbiAgQElucHV0KCkgcHVibGljIHNob3dDb250ZW50TG9hZGVyOiBudWxsIHwgYm9vbGVhbiB8IHVuZGVmaW5lZCA9IGZhbHNlO1xyXG5cclxuICBwdWJsaWMgZGF0YTogYW55O1xyXG5cclxuICBwdWJsaWMgZGVzdHJveTogKCgpID0+IHt9KSB8IHVuZGVmaW5lZDtcclxuXHJcbiAgY29uc3RydWN0b3IoXHJcbiAgICBwcml2YXRlIHJvdXRlOiBBY3RpdmF0ZWRSb3V0ZSxcclxuICAgIHByaXZhdGUgcm91dGVyOiBSb3V0ZXIsXHJcbiAgICBwcml2YXRlIGRpYWxvZzogREREaWFsb2dSZWY8TW9kYWxCYXNlQ29tcG9uZW50PixcclxuICApIHt9XHJcblxyXG4gIEBIb3N0TGlzdGVuZXIoJ2RvY3VtZW50OmtleWRvd24nLCBbJyRldmVudCddKVxyXG4gIHB1YmxpYyBvbktleWRvd25Db21wb25lbnQoZXZlbnQ6IEtleWJvYXJkRXZlbnQpOiB2b2lkIHtcclxuICAgIGlmIChldmVudC5rZXkgPT09ICdFc2NhcGUnIHx8IGV2ZW50LmtleSA9PT0gJ0VzYycpIHtcclxuICAgICAgdGhpcy5kZXN0cm95ISgpO1xyXG4gICAgfVxyXG4gIH1cclxuXHJcbiAgcHVibGljIGFmdGVyRGVzdHJveSA9ICgpID0+IHtcclxuICAgIGlmICh0aGlzLmNsZWFyRnJhZ21lbnQpIHtcclxuICAgICAgdGhpcy5yb3V0ZXIubmF2aWdhdGUoW10sIHsgZnJhZ21lbnQ6IHVuZGVmaW5lZCwgcHJlc2VydmVGcmFnbWVudDogZmFsc2UsIHJlbGF0aXZlVG86IHRoaXMucm91dGUgfSk7XHJcbiAgICB9XHJcbiAgfTtcclxuXHJcbiAgcHVibGljIGNsb3NlKCk6IHZvaWQge1xyXG4gICAgdGhpcy5kaWFsb2cuY2xvc2UoKTtcclxuICB9XHJcbn1cclxuIiwiPGRpdiBjbGFzcz1cInBvcHVwXCIgW2NsYXNzLmJvcmRlci1tb2JpbGVdPVwiYm9yZGVyTW9iaWxlXCI+XHJcbiAgQGlmIChzaG93Q29udGVudExvYWRlcikge1xyXG4gICAgPGRpdiBjbGFzcz1cImxvYWRlci1tb2RhbFwiPlxyXG4gICAgICA8ZGQtbGliLWxvYWRlciBzaXplPVwiZ2lhbnRcIj48L2RkLWxpYi1sb2FkZXI+XHJcbiAgICA8L2Rpdj5cclxuICB9IEBlbHNlIHtcclxuICAgIDxkaXYgKGNsaWNrKT1cImNsb3NlKClcIiBjbGFzcz1cInBvcHVwX19jbG9zZVwiPjwvZGl2PlxyXG4gICAgQGlmIChjb250ZW50KSB7XHJcbiAgICAgIDxkaXYgY2xhc3M9XCJwb3B1cF9fY29udGVudFwiPlxyXG4gICAgICAgIDxuZy10ZW1wbGF0ZSBbbmdUZW1wbGF0ZU91dGxldENvbnRleHRdPVwieyBkYXRhIH1cIiBbbmdUZW1wbGF0ZU91dGxldF09XCJjb250ZW50XCI+PC9uZy10ZW1wbGF0ZT5cclxuICAgICAgPC9kaXY+XHJcbiAgICB9XHJcbiAgICBAaWYgKGNvbXBvbmVudCkge1xyXG4gICAgICA8ZGl2IGNsYXNzPVwicG9wdXBfX2NvbnRlbnRcIj5cclxuICAgICAgICA8bmctdGVtcGxhdGUgW25nQ29tcG9uZW50T3V0bGV0XT1cImNvbXBvbmVudFwiPjwvbmctdGVtcGxhdGU+XHJcbiAgICAgIDwvZGl2PlxyXG4gICAgfSBAZWxzZSB7XHJcbiAgICAgIDxuZy1jb250ZW50PjwvbmctY29udGVudD5cclxuICAgIH1cclxuICB9XHJcblxyXG4gIEBpZiAoc2hvd0xvYWRlcikge1xyXG4gICAgPGRpdiBjbGFzcz1cImxvYWRlci1tb2RhbFwiPlxyXG4gICAgICA8ZGQtbGliLWxvYWRlciBzaXplPVwiZ2lhbnRcIj48L2RkLWxpYi1sb2FkZXI+XHJcbiAgICA8L2Rpdj5cclxuICB9XHJcbjwvZGl2PlxyXG4iXX0=
|
|
@@ -18,7 +18,7 @@ export class ClickOutsideDirective {
|
|
|
18
18
|
});
|
|
19
19
|
}
|
|
20
20
|
const clickedInside = this.el.nativeElement.contains(targetElement.target);
|
|
21
|
-
if (!clickedElemInside) {
|
|
21
|
+
if (!clickedElemInside && !clickedInside) {
|
|
22
22
|
this.ddClickOutside.emit(clickedInside);
|
|
23
23
|
}
|
|
24
24
|
}
|
|
@@ -39,4 +39,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.2", ngImpor
|
|
|
39
39
|
type: HostListener,
|
|
40
40
|
args: ['document:click', ['$event']]
|
|
41
41
|
}] } });
|
|
42
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
42
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2xpY2stb3V0c2lkZS5kaXJlY3RpdmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9kZC1saWIvc3JjL2xpYi9jb3JlL2RpcmVjdGl2ZXMvY2xpY2stb3V0c2lkZS5kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBYyxZQUFZLEVBQUUsWUFBWSxFQUFFLEtBQUssRUFBRSxNQUFNLEVBQUUsTUFBTSxlQUFlLENBQUM7O0FBTWpHLE1BQU0sT0FBTyxxQkFBcUI7SUFJaEMsWUFBb0IsRUFBYztRQUFkLE9BQUUsR0FBRixFQUFFLENBQVk7UUFGakIsbUJBQWMsR0FBRyxJQUFJLFlBQVksRUFBRSxDQUFDO0lBRWhCLENBQUM7SUFHL0IsT0FBTyxDQUFDLGFBQW9CO1FBQ2pDLElBQUksaUJBQWlCLEdBQUcsS0FBSyxDQUFDO1FBQzlCLElBQUksSUFBSSxDQUFDLFFBQVEsRUFBRSxNQUFNLEVBQUUsQ0FBQztZQUMxQixJQUFJLENBQUMsUUFBUSxDQUFDLE9BQU8sQ0FBQyxFQUFFLENBQUMsRUFBRTtnQkFDekIsSUFBSSxFQUFFLEVBQUUsQ0FBQztvQkFDUCxNQUFNLElBQUksR0FBRyxRQUFRLENBQUMsY0FBYyxDQUFDLEVBQUUsQ0FBUSxDQUFDO29CQUNoRCxJQUFJLElBQUksSUFBSSxDQUFDLGlCQUFpQixFQUFFLENBQUM7d0JBQy9CLGlCQUFpQixHQUFHLElBQUksQ0FBQyxRQUFRLENBQUMsYUFBYSxDQUFDLE1BQU0sQ0FBQyxDQUFDO29CQUMxRCxDQUFDO2dCQUNILENBQUM7WUFDSCxDQUFDLENBQUMsQ0FBQztRQUNMLENBQUM7UUFFRCxNQUFNLGFBQWEsR0FBRyxJQUFJLENBQUMsRUFBRSxDQUFDLGFBQWEsQ0FBQyxRQUFRLENBQUMsYUFBYSxDQUFDLE1BQU0sQ0FBQyxDQUFDO1FBQzNFLElBQUksQ0FBQyxpQkFBaUIsSUFBSSxDQUFDLGFBQWEsRUFBRSxDQUFDO1lBQ3pDLElBQUksQ0FBQyxjQUFjLENBQUMsSUFBSSxDQUFDLGFBQWEsQ0FBQyxDQUFDO1FBQzFDLENBQUM7SUFDSCxDQUFDOzhHQXhCVSxxQkFBcUI7a0dBQXJCLHFCQUFxQjs7MkZBQXJCLHFCQUFxQjtrQkFKakMsU0FBUzttQkFBQztvQkFDVCxVQUFVLEVBQUUsSUFBSTtvQkFDaEIsUUFBUSxFQUFFLGtCQUFrQjtpQkFDN0I7K0VBRWlCLFFBQVE7c0JBQXZCLEtBQUs7Z0JBQ1csY0FBYztzQkFBOUIsTUFBTTtnQkFLQSxPQUFPO3NCQURiLFlBQVk7dUJBQUMsZ0JBQWdCLEVBQUUsQ0FBQyxRQUFRLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBEaXJlY3RpdmUsIEVsZW1lbnRSZWYsIEV2ZW50RW1pdHRlciwgSG9zdExpc3RlbmVyLCBJbnB1dCwgT3V0cHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcblxyXG5ARGlyZWN0aXZlKHtcclxuICBzdGFuZGFsb25lOiB0cnVlLFxyXG4gIHNlbGVjdG9yOiAnW2RkQ2xpY2tPdXRzaWRlXScsXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBDbGlja091dHNpZGVEaXJlY3RpdmUge1xyXG4gIEBJbnB1dCgpIHB1YmxpYyBlbGVtZW50cyE6IHN0cmluZ1tdIHwgdW5kZWZpbmVkO1xyXG4gIEBPdXRwdXQoKSBwdWJsaWMgZGRDbGlja091dHNpZGUgPSBuZXcgRXZlbnRFbWl0dGVyKCk7XHJcblxyXG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgZWw6IEVsZW1lbnRSZWYpIHt9XHJcblxyXG4gIEBIb3N0TGlzdGVuZXIoJ2RvY3VtZW50OmNsaWNrJywgWyckZXZlbnQnXSlcclxuICBwdWJsaWMgb25DbGljayh0YXJnZXRFbGVtZW50OiBFdmVudCkge1xyXG4gICAgbGV0IGNsaWNrZWRFbGVtSW5zaWRlID0gZmFsc2U7XHJcbiAgICBpZiAodGhpcy5lbGVtZW50cz8ubGVuZ3RoKSB7XHJcbiAgICAgIHRoaXMuZWxlbWVudHMuZm9yRWFjaChlbCA9PiB7XHJcbiAgICAgICAgaWYgKGVsKSB7XHJcbiAgICAgICAgICBjb25zdCBlbGVtID0gZG9jdW1lbnQuZ2V0RWxlbWVudEJ5SWQoZWwpIGFzIGFueTtcclxuICAgICAgICAgIGlmIChlbGVtICYmICFjbGlja2VkRWxlbUluc2lkZSkge1xyXG4gICAgICAgICAgICBjbGlja2VkRWxlbUluc2lkZSA9IGVsZW0uY29udGFpbnModGFyZ2V0RWxlbWVudC50YXJnZXQpO1xyXG4gICAgICAgICAgfVxyXG4gICAgICAgIH1cclxuICAgICAgfSk7XHJcbiAgICB9XHJcblxyXG4gICAgY29uc3QgY2xpY2tlZEluc2lkZSA9IHRoaXMuZWwubmF0aXZlRWxlbWVudC5jb250YWlucyh0YXJnZXRFbGVtZW50LnRhcmdldCk7XHJcbiAgICBpZiAoIWNsaWNrZWRFbGVtSW5zaWRlICYmICFjbGlja2VkSW5zaWRlKSB7XHJcbiAgICAgIHRoaXMuZGRDbGlja091dHNpZGUuZW1pdChjbGlja2VkSW5zaWRlKTtcclxuICAgIH1cclxuICB9XHJcbn1cclxuIl19
|
|
@@ -5,6 +5,7 @@ export class CounterDirective {
|
|
|
5
5
|
constructor(el) {
|
|
6
6
|
this.el = el;
|
|
7
7
|
this.needPositive = false;
|
|
8
|
+
this.digitsInfo = '1.1-1';
|
|
8
9
|
}
|
|
9
10
|
ngOnChanges(change) {
|
|
10
11
|
this.el.nativeElement.innerHTML = 0;
|
|
@@ -19,10 +20,15 @@ export class CounterDirective {
|
|
|
19
20
|
interval = setInterval(() => {
|
|
20
21
|
if (x + step >= change['ddCounter'].currentValue) {
|
|
21
22
|
/** Если шаг увеличивает значение больше чем исходные число, приравниваем к исходнику и заканчиваем*/
|
|
22
|
-
const
|
|
23
|
-
|
|
23
|
+
const val = change['ddCounter'].currentValue;
|
|
24
|
+
const digitsInfo = Number.isInteger(val) ? '' : this.digitsInfo;
|
|
25
|
+
const transformNumberFirst = new DecimalPipe('ru').transform(val, digitsInfo);
|
|
26
|
+
let num = this.needPositive
|
|
24
27
|
? '+' + transformNumberFirst
|
|
25
28
|
: transformNumberFirst;
|
|
29
|
+
num = this.postfix ? num + this.postfix : num;
|
|
30
|
+
num = this.postfix ? this.postfix + num : num;
|
|
31
|
+
this.el.nativeElement.innerHTML = num;
|
|
26
32
|
clearInterval(interval);
|
|
27
33
|
return;
|
|
28
34
|
}
|
|
@@ -48,7 +54,7 @@ export class CounterDirective {
|
|
|
48
54
|
}, 4000);
|
|
49
55
|
}
|
|
50
56
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.2", ngImport: i0, type: CounterDirective, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
51
|
-
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.2.2", type: CounterDirective, isStandalone: true, selector: "[ddCounter]", inputs: { ddCounter: "ddCounter", needPositive: "needPositive" }, usesOnChanges: true, ngImport: i0 }); }
|
|
57
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.2.2", type: CounterDirective, isStandalone: true, selector: "[ddCounter]", inputs: { ddCounter: "ddCounter", needPositive: "needPositive", digitsInfo: "digitsInfo", prefix: "prefix", postfix: "postfix" }, usesOnChanges: true, ngImport: i0 }); }
|
|
52
58
|
}
|
|
53
59
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.2", ngImport: i0, type: CounterDirective, decorators: [{
|
|
54
60
|
type: Directive,
|
|
@@ -60,5 +66,11 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.2", ngImpor
|
|
|
60
66
|
type: Input
|
|
61
67
|
}], needPositive: [{
|
|
62
68
|
type: Input
|
|
69
|
+
}], digitsInfo: [{
|
|
70
|
+
type: Input
|
|
71
|
+
}], prefix: [{
|
|
72
|
+
type: Input
|
|
73
|
+
}], postfix: [{
|
|
74
|
+
type: Input
|
|
63
75
|
}] } });
|
|
64
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
76
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY291bnRlci5kaXJlY3RpdmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9kZC1saWIvc3JjL2xpYi9jb3JlL2RpcmVjdGl2ZXMvY291bnRlci5kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBYyxLQUFLLEVBQTRCLE1BQU0sZUFBZSxDQUFDO0FBQ3ZGLE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQzs7QUFNOUMsTUFBTSxPQUFPLGdCQUFnQjtJQU8zQixZQUFvQixFQUFjO1FBQWQsT0FBRSxHQUFGLEVBQUUsQ0FBWTtRQUxsQixpQkFBWSxHQUFHLEtBQUssQ0FBQztRQUNyQixlQUFVLEdBQUcsT0FBTyxDQUFDO0lBSUEsQ0FBQztJQUUvQixXQUFXLENBQUMsTUFBcUI7UUFDdEMsSUFBSSxDQUFDLEVBQUUsQ0FBQyxhQUFhLENBQUMsU0FBUyxHQUFHLENBQUMsQ0FBQztRQUNwQyxJQUFJLFFBQWEsQ0FBQztRQUNsQixJQUFJLE1BQU0sQ0FBQyxXQUFXLENBQUMsRUFBRSxZQUFZLEVBQUUsQ0FBQztZQUN0QyxnRUFBZ0U7WUFDaEUsSUFBSSxJQUFJLEdBQUcsSUFBSSxDQUFDLEtBQUssQ0FBQyxNQUFNLENBQUMsV0FBVyxDQUFDLENBQUMsWUFBWSxHQUFHLEVBQUUsQ0FBQyxDQUFDO1lBQzdELDRDQUE0QztZQUM1QyxJQUFJLEdBQUcsSUFBSSxJQUFJLENBQUMsSUFBSSxJQUFJLElBQUksQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDO1lBQzFDLElBQUksQ0FBQyxHQUFHLENBQUMsQ0FBQztZQUNWLElBQUksTUFBTSxDQUFDLFdBQVcsQ0FBQyxDQUFDLFlBQVksR0FBRyxDQUFDLEVBQUUsQ0FBQztnQkFDekMsUUFBUSxHQUFHLFdBQVcsQ0FBQyxHQUFHLEVBQUU7b0JBQzFC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ekIsS0FBSztnQkFDVSxNQUFNO3NCQUFyQixLQUFLO2dCQUNVLE9BQU87c0JBQXRCLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBEaXJlY3RpdmUsIEVsZW1lbnRSZWYsIElucHV0LCBPbkNoYW5nZXMsIFNpbXBsZUNoYW5nZXMgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgRGVjaW1hbFBpcGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xyXG5cclxuQERpcmVjdGl2ZSh7XHJcbiAgc2VsZWN0b3I6ICdbZGRDb3VudGVyXScsXHJcbiAgc3RhbmRhbG9uZTogdHJ1ZSxcclxufSlcclxuZXhwb3J0IGNsYXNzIENvdW50ZXJEaXJlY3RpdmUgaW1wbGVtZW50cyBPbkNoYW5nZXMge1xyXG4gIEBJbnB1dCgpIHB1YmxpYyBkZENvdW50ZXI6IG51bWJlciB8IHVuZGVmaW5lZDtcclxuICBASW5wdXQoKSBwdWJsaWMgbmVlZFBvc2l0aXZlID0gZmFsc2U7XHJcbiAgQElucHV0KCkgcHVibGljIGRpZ2l0c0luZm8gPSAnMS4xLTEnO1xyXG4gIEBJbnB1dCgpIHB1YmxpYyBwcmVmaXg/OiBzdHJpbmc7XHJcbiAgQElucHV0KCkgcHVibGljIHBvc3RmaXg/OiBzdHJpbmc7XHJcblxyXG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgZWw6IEVsZW1lbnRSZWYpIHt9XHJcblxyXG4gIHB1YmxpYyBuZ09uQ2hhbmdlcyhjaGFuZ2U6IFNpbXBsZUNoYW5nZXMpOiB2b2lkIHtcclxuICAgIHRoaXMuZWwubmF0aXZlRWxlbWVudC5pbm5lckhUTUwgPSAwO1xyXG4gICAgbGV0IGludGVydmFsOiBhbnk7XHJcbiAgICBpZiAoY2hhbmdlWydkZENvdW50ZXInXT8uY3VycmVudFZhbHVlKSB7XHJcbiAgICAgIC8qKiDQv9C+0LvRg9GH0LDQtdC8INGI0LDQsyDQtNC70Y8g0LjQvdC60YDQtdC80LXQvdGC0LAg0LTQtdC70LXQvdC40LXQvCDQutC+0L3QtdGH0L3QvtCz0L4g0YfQuNGB0LvQsCDQvdCwIDIwKi9cclxuICAgICAgbGV0IHN0ZXAgPSBNYXRoLmZsb29yKGNoYW5nZVsnZGRDb3VudGVyJ10uY3VycmVudFZhbHVlIC8gMjApO1xyXG4gICAgICAvKiog0LHRi9Cy0LDRjtGCINC80LDQu9C10L3RjNC60LjQtSDQuCDQvtGC0YDQuNGG0LDRgtC10LvRjNC90YvQtSDRh9C40YHQu9CwKi9cclxuICAgICAgc3RlcCA9IHN0ZXAgPj0gMSB8fCBzdGVwIDw9IC0xID8gc3RlcCA6IDE7XHJcbiAgICAgIGxldCB4ID0gMDtcclxuICAgICAgaWYgKGNoYW5nZVsnZGRDb3VudGVyJ10uY3VycmVudFZhbHVlID4gMCkge1xyXG4gICAgICAgIGludGVydmFsID0gc2V0SW50ZXJ2YWwoKCkgPT4ge1xyXG4gICAgICAgICAgaWYgKHggKyBzdGVwID49IGNoYW5nZVsnZGRDb3VudGVyJ10uY3VycmVudFZhbHVlKSB7XHJcbiAgICAgICAgICAgIC8qKiDQldGB0LvQuCDRiNCw0LMg0YPQstC10LvQuNGH0LjQstCw0LXRgiDQt9C90LDRh9C10L3QuNC1INCx0L7Qu9GM0YjQtSDRh9C10Lwg0LjRgdGF0L7QtNC90YvQtSDRh9C40YHQu9C+LCDQv9GA0LjRgNCw0LLQvdC40LLQsNC10Lwg0Log0LjRgdGF0L7QtNC90LjQutGDINC4INC30LDQutCw0L3Rh9C40LLQsNC10LwqL1xyXG4gICAgICAgICAgICBjb25zdCB2YWwgPSBjaGFuZ2VbJ2RkQ291bnRlciddLmN1cnJlbnRWYWx1ZTtcclxuICAgICAgICAgICAgY29uc3QgZGlnaXRzSW5mbyA9IE51bWJlci5pc0ludGVnZXIodmFsKSA/ICcnIDogdGhpcy5kaWdpdHNJbmZvXHJcbiAgICAgICAgICAgIGNvbnN0IHRyYW5zZm9ybU51bWJlckZpcnN0ID0gbmV3IERlY2ltYWxQaXBlKCdydScpLnRyYW5zZm9ybSh2YWwsIGRpZ2l0c0luZm8pO1xyXG4gICAgICAgICAgICBsZXQgbnVtID0gdGhpcy5uZWVkUG9zaXRpdmVcclxuICAgICAgICAgICAgICA/ICcrJyArIHRyYW5zZm9ybU51bWJlckZpcnN0XHJcbiAgICAgICAgICAgICAgOiB0cmFuc2Zvcm1OdW1iZXJGaXJzdDtcclxuICAgICAgICAgICAgbnVtID0gdGhpcy5wb3N0Zml4ID8gbnVtICsgdGhpcy5wb3N0Zml4IDogbnVtO1xyXG4gICAgICAgICAgICBudW0gPSB0aGlzLnBvc3RmaXggPyB0aGlzLnBvc3RmaXggKyBudW0gOiBudW07XHJcbiAgICAgICAgICAgIHRoaXMuZWwubmF0aXZlRWxlbWVudC5pbm5lckhUTUwgPSBudW07XHJcbiAgICAgICAgICAgIGNsZWFySW50ZXJ2YWwoaW50ZXJ2YWwpO1xyXG4gICAgICAgICAgICByZXR1cm47XHJcbiAgICAgICAgICB9XHJcbiAgICAgICAgICB4ICs9IHN0ZXA7XHJcbiAgICAgICAgICBjb25zdCB0cmFuc2Zvcm1OdW1iZXIgPSBuZXcgRGVjaW1hbFBpcGUoJ3J1JykudHJhbnNmb3JtKHgpO1xyXG4gICAgICAgICAgdGhpcy5lbC5uYXRpdmVFbGVtZW50LmlubmVySFRNTCA9IHRoaXMubmVlZFBvc2l0aXZlID8gJysnICsgdHJhbnNmb3JtTnVtYmVyIDogdHJhbnNmb3JtTnVtYmVyO1xyXG4gICAgICAgIH0sIDEpO1xyXG4gICAgICB9IGVsc2UgaWYgKGNoYW5nZVsnZGRDb3VudGVyJ10uY3VycmVudFZhbHVlIDwgMCkge1xyXG4gICAgICAgIGludGVydmFsID0gc2V0SW50ZXJ2YWwoKCkgPT4ge1xyXG4gICAgICAgICAgaWYgKHggLSBzdGVwIDw9IGNoYW5nZVsnZGRDb3VudGVyJ10uY3VycmVudFZhbHVlKSB7XHJcbiAgICAgICAgICAgIHRoaXMuZWwubmF0aXZlRWxlbWVudC5pbm5lckhUTUwgPSBuZXcgRGVjaW1hbFBpcGUoJ3J1JykudHJhbnNmb3JtKGNoYW5nZVsnZGRDb3VudGVyJ10uY3VycmVudFZhbHVlKTtcclxuICAgICAgICAgICAgY2xlYXJJbnRlcnZhbChpbnRlcnZhbCk7XHJcbiAgICAgICAgICAgIHJldHVybjtcclxuICAgICAgICAgIH1cclxuICAgICAgICAgIHggKz0gc3RlcDtcclxuICAgICAgICAgIHRoaXMuZWwubmF0aXZlRWxlbWVudC5pbm5lckhUTUwgPSBuZXcgRGVjaW1hbFBpcGUoJ3J1JykudHJhbnNmb3JtKHgpO1xyXG4gICAgICAgIH0sIDEwKTtcclxuICAgICAgfVxyXG4gICAgfVxyXG4gICAgc2V0VGltZW91dCgoKSA9PiB7XHJcbiAgICAgIGNsZWFySW50ZXJ2YWwoaW50ZXJ2YWwpO1xyXG4gICAgfSwgNDAwMCk7XHJcbiAgfVxyXG59XHJcbiJdfQ==
|
|
@@ -12,4 +12,4 @@ export class DestroyService extends Subject {
|
|
|
12
12
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.2", ngImport: i0, type: DestroyService, decorators: [{
|
|
13
13
|
type: Injectable
|
|
14
14
|
}] });
|
|
15
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
15
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGVzdHJveS5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZGQtbGliL3NyYy9saWIvY29yZS9zZXJ2aWNlcy9kZXN0cm95LnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFVBQVUsRUFBYSxNQUFNLGVBQWUsQ0FBQztBQUN0RCxPQUFPLEVBQWtCLE9BQU8sRUFBQyxNQUFNLE1BQU0sQ0FBQzs7QUFHOUMsTUFBTSxPQUFPLGNBQWUsU0FBUSxPQUFhO0lBRXhDLFdBQVc7UUFDaEIsSUFBSSxDQUFDLElBQUksRUFBRSxDQUFDO1FBQ1osSUFBSSxDQUFDLFFBQVEsRUFBRSxDQUFDO0lBQ2xCLENBQUM7OEdBTFUsY0FBYztrSEFBZCxjQUFjOzsyRkFBZCxjQUFjO2tCQUQxQixVQUFVIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSW5qZWN0YWJsZSwgT25EZXN0cm95IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7QmVoYXZpb3JTdWJqZWN0LCBTdWJqZWN0fSBmcm9tICdyeGpzJztcclxuXHJcbkBJbmplY3RhYmxlKClcclxuZXhwb3J0IGNsYXNzIERlc3Ryb3lTZXJ2aWNlIGV4dGVuZHMgU3ViamVjdDx2b2lkPiBpbXBsZW1lbnRzIE9uRGVzdHJveSB7XHJcblxyXG4gIHB1YmxpYyBuZ09uRGVzdHJveSgpOiB2b2lkIHtcclxuICAgIHRoaXMubmV4dCgpO1xyXG4gICAgdGhpcy5jb21wbGV0ZSgpO1xyXG4gIH1cclxufVxyXG4iXX0=
|
|
@@ -1,36 +1,18 @@
|
|
|
1
1
|
import { HttpHeaders, HttpParams } from '@angular/common/http';
|
|
2
2
|
import { Inject, Injectable } from '@angular/core';
|
|
3
|
-
import {
|
|
4
|
-
import { switchMap } from 'rxjs/operators';
|
|
3
|
+
import { map } from 'rxjs/operators';
|
|
5
4
|
import * as i0 from "@angular/core";
|
|
6
5
|
import * as i1 from "@angular/common/http";
|
|
7
6
|
export class FetcherService {
|
|
8
7
|
constructor(http, apiUrl = 'api') {
|
|
9
8
|
this.http = http;
|
|
10
9
|
this.apiUrl = apiUrl;
|
|
11
|
-
// private apiUrl = 'api';
|
|
12
10
|
this.payloadMethods = ['post', 'put'];
|
|
13
11
|
}
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
let params = new HttpParams();
|
|
18
|
-
for (const key of Object.keys(options)) {
|
|
19
|
-
if (options[key] != null) {
|
|
20
|
-
if (options[key]?.length && Array.isArray(options[key])) {
|
|
21
|
-
options[key].forEach((f) => {
|
|
22
|
-
params = params.append(key, f);
|
|
23
|
-
});
|
|
24
|
-
}
|
|
25
|
-
else {
|
|
26
|
-
params = params.append(key, options[key]);
|
|
27
|
-
}
|
|
28
|
-
}
|
|
12
|
+
prepareOptions(options = {}) {
|
|
13
|
+
if (options?.headers) {
|
|
14
|
+
options.headers = new HttpHeaders(options.headers);
|
|
29
15
|
}
|
|
30
|
-
return this.request('get', url, { params });
|
|
31
|
-
}
|
|
32
|
-
post(urlParts, data, options = {}) {
|
|
33
|
-
const url = [this.apiUrl].concat(urlParts).join('/');
|
|
34
16
|
if (options?.params) {
|
|
35
17
|
let params = new HttpParams();
|
|
36
18
|
for (const key of Object.keys(options.params)) {
|
|
@@ -40,15 +22,31 @@ export class FetcherService {
|
|
|
40
22
|
}
|
|
41
23
|
options.params = params;
|
|
42
24
|
}
|
|
43
|
-
|
|
25
|
+
options.observe = options.observe || 'response';
|
|
26
|
+
return options || {};
|
|
27
|
+
}
|
|
28
|
+
get(urlParts, options, urlId) {
|
|
29
|
+
urlParts = urlId ? urlParts.replace(/{[^}]+}/g, urlId.toString()) : urlParts;
|
|
30
|
+
const url = urlParts ? [this.apiUrl].concat(urlParts).join('/') : this.apiUrl;
|
|
31
|
+
const prepareOptions = this.prepareOptions(options);
|
|
32
|
+
return this.http.get(url, prepareOptions).pipe(map(res => res.body));
|
|
44
33
|
}
|
|
45
|
-
|
|
34
|
+
delete(urlParts, options) {
|
|
46
35
|
const url = [this.apiUrl].concat(urlParts).join('/');
|
|
47
|
-
|
|
36
|
+
const prepareOptions = this.prepareOptions(options);
|
|
37
|
+
return this.http.delete(url, prepareOptions).pipe(map(res => res.body));
|
|
48
38
|
}
|
|
49
|
-
|
|
39
|
+
post(urlParts, body, options, urlId) {
|
|
40
|
+
urlParts = urlId ? urlParts.replace(/{[^}]+}/g, urlId.toString()) : urlParts;
|
|
50
41
|
const url = [this.apiUrl].concat(urlParts).join('/');
|
|
51
|
-
|
|
42
|
+
const prepareOptions = this.prepareOptions(options);
|
|
43
|
+
return this.http.post(url, body, prepareOptions).pipe(map(res => res.body));
|
|
44
|
+
}
|
|
45
|
+
put(urlParts, body, options, urlId) {
|
|
46
|
+
urlParts = urlId ? urlParts.replace(/{[^}]+}/g, urlId.toString()) : urlParts;
|
|
47
|
+
const url = [this.apiUrl].concat(urlParts).join('/');
|
|
48
|
+
const prepareOptions = this.prepareOptions(options);
|
|
49
|
+
return this.http.put(url, body, prepareOptions).pipe(map(res => res.body));
|
|
52
50
|
}
|
|
53
51
|
/** перегоняем объкты в форм дату*/
|
|
54
52
|
createFormData(form) {
|
|
@@ -58,26 +56,6 @@ export class FetcherService {
|
|
|
58
56
|
});
|
|
59
57
|
return formData;
|
|
60
58
|
}
|
|
61
|
-
request(method, url, options, data) {
|
|
62
|
-
if (options.headers) {
|
|
63
|
-
options.headers = new HttpHeaders(options.headers);
|
|
64
|
-
}
|
|
65
|
-
let request;
|
|
66
|
-
options.withCredentials = true;
|
|
67
|
-
if (this.payloadMethods.includes(method)) {
|
|
68
|
-
request = this.http[method](url, data, options);
|
|
69
|
-
}
|
|
70
|
-
else {
|
|
71
|
-
request = this.http[method](url, options);
|
|
72
|
-
}
|
|
73
|
-
return request.pipe(switchMap((response) => {
|
|
74
|
-
if (response && response.error) {
|
|
75
|
-
console.error(`API error with status: ${response.status}`);
|
|
76
|
-
console.error(response.error);
|
|
77
|
-
}
|
|
78
|
-
return of(response);
|
|
79
|
-
}));
|
|
80
|
-
}
|
|
81
59
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.2", ngImport: i0, type: FetcherService, deps: [{ token: i1.HttpClient }, { token: 'apiUrl' }], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
82
60
|
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.2.2", ngImport: i0, type: FetcherService, providedIn: 'root' }); }
|
|
83
61
|
}
|
|
@@ -88,4 +66,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.2", ngImpor
|
|
|
88
66
|
type: Inject,
|
|
89
67
|
args: ['apiUrl']
|
|
90
68
|
}] }] });
|
|
91
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"fetcher.service.js","sourceRoot":"","sources":["../../../../../../projects/dd-lib/src/lib/core/services/fetcher.service.ts"],"names":[],"mappings":"AAAA,OAAO,EAAa,WAAW,EAAE,UAAU,EAAC,MAAM,sBAAsB,CAAC;AACzE,OAAO,EAAC,MAAM,EAAE,UAAU,EAAC,MAAM,eAAe,CAAC;AAEjD,OAAO,EAAa,EAAE,EAAC,MAAM,MAAM,CAAC;AACpC,OAAO,EAAC,SAAS,EAAC,MAAM,gBAAgB,CAAC;;;AAgBzC,MAAM,OAAO,cAAc;IAIzB,YAAoB,IAAgB,EAA4B,SAAiB,KAAK;QAAlE,SAAI,GAAJ,IAAI,CAAY;QAA4B,WAAM,GAAN,MAAM,CAAgB;QAHtF,0BAA0B;QACT,mBAAc,GAAa,CAAC,MAAM,EAAE,KAAK,CAAC,CAAC;IAG5D,CAAC;IAEM,GAAG,CAAI,QAAgB,EAAE,UAAe,EAAE,EAAE,KAAuB;QACxE,QAAQ,GAAG,KAAK,CAAC,CAAC,CAAC,QAAQ,CAAC,OAAO,CAAC,UAAU,EAAE,KAAK,CAAC,QAAQ,EAAE,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC;QAC7E,MAAM,GAAG,GAAW,QAAQ,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC;QACtF,IAAI,MAAM,GAAG,IAAI,UAAU,EAAE,CAAC;QAC9B,KAAK,MAAM,GAAG,IAAI,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,EAAE,CAAC;YACvC,IAAI,OAAO,CAAC,GAAG,CAAC,IAAI,IAAI,EAAE,CAAC;gBACzB,IAAI,OAAO,CAAC,GAAG,CAAC,EAAE,MAAM,IAAI,KAAK,CAAC,OAAO,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC;oBACxD,OAAO,CAAC,GAAG,CAAC,CAAC,OAAO,CAAC,CAAC,CAA4B,EAAE,EAAE;wBACpD,MAAM,GAAG,MAAM,CAAC,MAAM,CAAC,GAAG,EAAE,CAAC,CAAC,CAAC;oBACjC,CAAC,CAAC,CAAC;gBACL,CAAC;qBAAM,CAAC;oBACN,MAAM,GAAG,MAAM,CAAC,MAAM,CAAC,GAAG,EAAE,OAAO,CAAC,GAAG,CAAC,CAAC,CAAC;gBAC5C,CAAC;YACH,CAAC;QACH,CAAC;QACD,OAAO,IAAI,CAAC,OAAO,CAAC,KAAK,EAAE,GAAG,EAAE,EAAC,MAAM,EAAC,CAAC,CAAC;IAC5C,CAAC;IAEM,IAAI,CAAI,QAA2B,EAAE,IAAU,EAAE,UAAe,EAAE;QACvE,MAAM,GAAG,GAAW,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;QAC7D,IAAI,OAAO,EAAE,MAAM,EAAE,CAAC;YACpB,IAAI,MAAM,GAAG,IAAI,UAAU,EAAE,CAAC;YAC9B,KAAK,MAAM,GAAG,IAAI,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE,CAAC;gBAC9C,IAAI,OAAO,CAAC,MAAM,CAAC,GAAG,CAAC,IAAI,IAAI,EAAE,CAAC;oBAChC,MAAM,GAAG,MAAM,CAAC,MAAM,CAAC,GAAG,EAAE,OAAO,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC;gBACnD,CAAC;YACH,CAAC;YACD,OAAO,CAAC,MAAM,GAAG,MAAM,CAAC;QAC1B,CAAC;QACD,OAAO,IAAI,CAAC,OAAO,CAAC,MAAM,EAAE,GAAG,EAAE,OAAO,EAAE,IAAI,CAAC,CAAC;IAClD,CAAC;IAEM,GAAG,CAAI,QAA2B,EAAE,IAAU,EAAE,UAAe,EAAE;QACtE,MAAM,GAAG,GAAW,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;QAC7D,OAAO,IAAI,CAAC,OAAO,CAAC,KAAK,EAAE,GAAG,EAAE,OAAO,EAAE,IAAI,CAAC,CAAC;IACjD,CAAC;IAEM,MAAM,CAAI,QAA2B,EAAE,UAAe,EAAE;QAC7D,MAAM,GAAG,GAAW,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;QAC7D,OAAO,IAAI,CAAC,OAAO,CAAC,QAAQ,EAAE,GAAG,EAAE,OAAO,CAAC,CAAC;IAC9C,CAAC;IAED,mCAAmC;IAC5B,cAAc,CAAC,IAA0B;QAC9C,MAAM,QAAQ,GAAa,IAAI,QAAQ,EAAE,CAAC;QAC1C,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,OAAO,CAAC,CAAC,IAAY,EAAE,EAAE;YACzC,QAAQ,CAAC,MAAM,CAAC,IAAI,EAAE,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC;QACpC,CAAC,CAAC,CAAC;QACH,OAAO,QAAQ,CAAC;IAClB,CAAC;IAEO,OAAO,CAAI,MAAqB,EAAE,GAAW,EAAE,OAAY,EAAE,IAAU;QAC7E,IAAI,OAAO,CAAC,OAAO,EAAE,CAAC;YACpB,OAAO,CAAC,OAAO,GAAG,IAAI,WAAW,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC;QACrD,CAAC;QACD,IAAI,OAAwB,CAAC;QAC7B,OAAO,CAAC,eAAe,GAAG,IAAI,CAAC;QAE/B,IAAI,IAAI,CAAC,cAAc,CAAC,QAAQ,CAAC,MAAM,CAAC,EAAE,CAAC;YACzC,OAAO,GAAG,IAAI,CAAC,IAAI,CAAC,MAAwB,CAAC,CAAC,GAAG,EAAE,IAAI,EAAE,OAAO,CAAC,CAAC;QACpE,CAAC;aAAM,CAAC;YACN,OAAO,GAAI,IAAI,CAAC,IAAY,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,OAAO,CAAC,CAAC;QACrD,CAAC;QAED,OAAO,OAAO,CAAC,IAAI,CACjB,SAAS,CAAC,CAAC,QAAa,EAAE,EAAE;YAC1B,IAAI,QAAQ,IAAI,QAAQ,CAAC,KAAK,EAAE,CAAC;gBAC/B,OAAO,CAAC,KAAK,CAAC,0BAA0B,QAAQ,CAAC,MAAM,EAAE,CAAC,CAAC;gBAC3D,OAAO,CAAC,KAAK,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;YAChC,CAAC;YACD,OAAO,EAAE,CAAC,QAAQ,CAAC,CAAC;QACtB,CAAC,CAAC,CAQH,CAAC;IACJ,CAAC;8GAvFU,cAAc,4CAIqB,QAAQ;kHAJ3C,cAAc,cADF,MAAM;;2FAClB,cAAc;kBAD1B,UAAU;mBAAC,EAAC,UAAU,EAAE,MAAM,EAAC;;0BAKS,MAAM;2BAAC,QAAQ","sourcesContent":["import {HttpClient, HttpHeaders, HttpParams} from '@angular/common/http';\r\nimport {Inject, Injectable} from '@angular/core';\r\n\r\nimport {Observable, of} from 'rxjs';\r\nimport {switchMap} from 'rxjs/operators';\r\nimport {isArray} from \"rxjs/internal-compatibility\";\r\n\r\nexport interface HttpIResponse<T> {\r\n  error: string;\r\n  errorCode: string;\r\n  message: null | string;\r\n  redirect: null | string;\r\n  systemMessage: null | string;\r\n  result: 'OK' | 'ERROR' | 'FAIL';\r\n  value: T;\r\n}\r\n\r\ntype PayloadMethod = 'post' | 'put' | 'get' | 'delete';\r\n\r\n@Injectable({providedIn: 'root'}) /** сервис обработки запросов к api */\r\nexport class FetcherService {\r\n  // private apiUrl = 'api';\r\n  private readonly payloadMethods: string[] = ['post', 'put'];\r\n\r\n  constructor(private http: HttpClient, @Inject('apiUrl') private apiUrl: string = 'api') {\r\n  }\r\n\r\n  public get<R>(urlParts: string, options: any = {}, urlId?: string | number): Observable<R> {\r\n    urlParts = urlId ? urlParts.replace(/{[^}]+}/g, urlId.toString()) : urlParts;\r\n    const url: string = urlParts ? [this.apiUrl].concat(urlParts).join('/') : this.apiUrl;\r\n    let params = new HttpParams();\r\n    for (const key of Object.keys(options)) {\r\n      if (options[key] != null) {\r\n        if (options[key]?.length && Array.isArray(options[key])) {\r\n          options[key].forEach((f: string | number | boolean) => {\r\n            params = params.append(key, f);\r\n          });\r\n        } else {\r\n          params = params.append(key, options[key]);\r\n        }\r\n      }\r\n    }\r\n    return this.request('get', url, {params});\r\n  }\r\n\r\n  public post<R>(urlParts: string[] | string, data?: any, options: any = {}): Observable<R> {\r\n    const url: string = [this.apiUrl].concat(urlParts).join('/');\r\n    if (options?.params) {\r\n      let params = new HttpParams();\r\n      for (const key of Object.keys(options.params)) {\r\n        if (options.params[key] != null) {\r\n          params = params.append(key, options.params[key]);\r\n        }\r\n      }\r\n      options.params = params;\r\n    }\r\n    return this.request('post', url, options, data);\r\n  }\r\n\r\n  public put<R>(urlParts: string[] | string, data?: any, options: any = {}): Observable<R> {\r\n    const url: string = [this.apiUrl].concat(urlParts).join('/');\r\n    return this.request('put', url, options, data);\r\n  }\r\n\r\n  public delete<R>(urlParts: string[] | string, options: any = {}): Observable<R> {\r\n    const url: string = [this.apiUrl].concat(urlParts).join('/');\r\n    return this.request('delete', url, options);\r\n  }\r\n\r\n  /** перегоняем объкты в форм дату*/\r\n  public createFormData(form: { [x: string]: any }) {\r\n    const formData: FormData = new FormData();\r\n    Object.keys(form).forEach((item: string) => {\r\n      formData.append(item, form[item]);\r\n    });\r\n    return formData;\r\n  }\r\n\r\n  private request<R>(method: PayloadMethod, url: string, options: any, data?: any): Observable<R> {\r\n    if (options.headers) {\r\n      options.headers = new HttpHeaders(options.headers);\r\n    }\r\n    let request: Observable<any>;\r\n    options.withCredentials = true;\r\n\r\n    if (this.payloadMethods.includes(method)) {\r\n      request = this.http[method as 'post' | 'put'](url, data, options);\r\n    } else {\r\n      request = (this.http as any)[method](url, options);\r\n    }\r\n\r\n    return request.pipe(\r\n      switchMap((response: any) => {\r\n        if (response && response.error) {\r\n          console.error(`API error with status: ${response.status}`);\r\n          console.error(response.error);\r\n        }\r\n        return of(response);\r\n      }),\r\n      // catchError((error: any) => {\r\n      // console.timeEnd('Время выполнения - ' + url);\r\n      // if (error.status !== 403) {\r\n      // console.log(error);\r\n      // }\r\n      // return of(error);\r\n      // }),\r\n    );\r\n  }\r\n}\r\n"]}
|
|
69
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"fetcher.service.js","sourceRoot":"","sources":["../../../../../../projects/dd-lib/src/lib/core/services/fetcher.service.ts"],"names":[],"mappings":"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","sourcesContent":["import {HttpClient, HttpContext, HttpHeaders, HttpParams} from '@angular/common/http';\r\nimport {Inject, Injectable} from '@angular/core';\r\n\r\nimport {Observable} from 'rxjs';\r\nimport {map} from 'rxjs/operators';\r\n\r\nexport interface HttpIResponse<T> {\r\n  error: string;\r\n  errorCode: string;\r\n  message: null | string;\r\n  redirect: null | string;\r\n  systemMessage: null | string;\r\n  result: 'OK' | 'ERROR' | 'FAIL';\r\n  value: T;\r\n}\r\n\r\nexport interface HttpIRequest {\r\n  headers?: HttpHeaders | {\r\n    [header: string]: string | string[];\r\n  };\r\n  observe: 'response';\r\n  context?: HttpContext;\r\n  params?: HttpParams | {\r\n    [param: string]: string | number | boolean | ReadonlyArray<string | number | boolean>;\r\n  };\r\n  reportProgress?: boolean;\r\n  responseType?: 'json';\r\n  withCredentials?: boolean;\r\n  transferCache?: {\r\n    includeHeaders?: string[];\r\n  } | boolean;\r\n}\r\n\r\n\r\nexport interface IRequestOptions {\r\n  headers?: any;\r\n  context?: any;\r\n  reportProgress?: boolean;\r\n  params?: any;\r\n  observe?: any;\r\n  responseType?: 'arraybuffer' | 'blob' | 'json' | 'text';\r\n  withCredentials?: boolean;\r\n  body?: any | null;\r\n}\r\n\r\ntype PayloadMethod = 'post' | 'put' | 'get' | 'delete';\r\n\r\n@Injectable({providedIn: 'root'}) /** сервис обработки запросов к api */\r\nexport class FetcherService {\r\n  private readonly payloadMethods: string[] = ['post', 'put'];\r\n\r\n  constructor(private http: HttpClient, @Inject('apiUrl') private apiUrl: string = 'api') {\r\n  }\r\n\r\n  private prepareOptions(options: IRequestOptions = {}): HttpIRequest {\r\n    if (options?.headers) {\r\n      options.headers = new HttpHeaders(options.headers);\r\n    }\r\n    if (options?.params) {\r\n      let params = new HttpParams();\r\n      for (const key of Object.keys(options.params)) {\r\n        if (options.params[key] != null) {\r\n          params = params.append(key, options.params[key]);\r\n        }\r\n      }\r\n      options.params = params;\r\n    }\r\n    options.observe = options.observe || 'response'\r\n\r\n    return options as HttpIRequest || {};\r\n  }\r\n  public get<R>(urlParts: string, options?: IRequestOptions, urlId?: string | number): Observable<R> {\r\n    urlParts = urlId ? urlParts.replace(/{[^}]+}/g, urlId.toString()) : urlParts;\r\n    const url: string = urlParts ? [this.apiUrl].concat(urlParts).join('/') : this.apiUrl;\r\n    const prepareOptions = this.prepareOptions(options);\r\n    return this.http.get<R>(url, prepareOptions).pipe(map(res => res.body!))\r\n  }\r\n\r\n  public delete<R>(urlParts: string, options?: IRequestOptions): Observable<R> {\r\n    const url: string = [this.apiUrl].concat(urlParts).join('/');\r\n    const prepareOptions = this.prepareOptions(options);\r\n    return this.http.delete<R>(url, prepareOptions).pipe(map(res => res.body!))\r\n\r\n  }\r\n\r\n\r\n  public post<R>(urlParts: string, body?: any, options?: IRequestOptions, urlId?: string | number): Observable<R> {\r\n    urlParts = urlId ? urlParts.replace(/{[^}]+}/g, urlId.toString()) : urlParts;\r\n    const url: string = [this.apiUrl].concat(urlParts).join('/');\r\n    const prepareOptions = this.prepareOptions(options);\r\n    return this.http.post<R>(url, body, prepareOptions).pipe(map(res => res.body!))\r\n  }\r\n\r\n  public put<R>(urlParts: string, body?: any, options?: IRequestOptions, urlId?: string | number): Observable<R> {\r\n    urlParts = urlId ? urlParts.replace(/{[^}]+}/g, urlId.toString()) : urlParts;\r\n    const url: string = [this.apiUrl].concat(urlParts).join('/');\r\n    const prepareOptions = this.prepareOptions(options);\r\n    return this.http.put<R>(url, body, prepareOptions).pipe(map(res => res.body!))\r\n  }\r\n\r\n\r\n  /** перегоняем объкты в форм дату*/\r\n  public createFormData(form: { [x: string]: any }) {\r\n    const formData: FormData = new FormData();\r\n    Object.keys(form).forEach((item: string) => {\r\n      formData.append(item, form[item]);\r\n    });\r\n    return formData;\r\n  }\r\n\r\n\r\n}\r\n"]}
|
|
@@ -64,6 +64,38 @@ export class ValidatorsService {
|
|
|
64
64
|
return of(null);
|
|
65
65
|
}
|
|
66
66
|
}
|
|
67
|
+
static getErrorText(error) {
|
|
68
|
+
const presetErrors = ['minlength', 'maxlength', 'email', 'required', 'pattern'];
|
|
69
|
+
if (error) {
|
|
70
|
+
const key = Object.keys(error)?.[0];
|
|
71
|
+
if (key && presetErrors.includes(key)) {
|
|
72
|
+
switch (key) {
|
|
73
|
+
case 'minlength': {
|
|
74
|
+
return `Не менее ${error['minlength'].requiredLength} символов`;
|
|
75
|
+
}
|
|
76
|
+
case 'maxlength': {
|
|
77
|
+
return `Не более${error['maxlength'].requiredLength} символов`;
|
|
78
|
+
}
|
|
79
|
+
case 'pattern': {
|
|
80
|
+
return `Неверно заполнено поле`;
|
|
81
|
+
}
|
|
82
|
+
case 'email': {
|
|
83
|
+
return `Неверно введен email`;
|
|
84
|
+
}
|
|
85
|
+
case 'required': {
|
|
86
|
+
return `Обязательное поле`;
|
|
87
|
+
}
|
|
88
|
+
default: {
|
|
89
|
+
return 'Неверно введен текст';
|
|
90
|
+
}
|
|
91
|
+
}
|
|
92
|
+
}
|
|
93
|
+
else if (key && !presetErrors.includes(key)) {
|
|
94
|
+
return error[key];
|
|
95
|
+
}
|
|
96
|
+
}
|
|
97
|
+
return undefined;
|
|
98
|
+
}
|
|
67
99
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.2", ngImport: i0, type: ValidatorsService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
68
100
|
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.2.2", ngImport: i0, type: ValidatorsService, providedIn: 'root' }); }
|
|
69
101
|
}
|
|
@@ -71,4 +103,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.2", ngImpor
|
|
|
71
103
|
type: Injectable,
|
|
72
104
|
args: [{ providedIn: 'root' }]
|
|
73
105
|
}], ctorParameters: () => [] });
|
|
74
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
106
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"validators.service.js","sourceRoot":"","sources":["../../../../../../projects/dd-lib/src/lib/core/services/validators.service.ts"],"names":[],"mappings":"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","sourcesContent":["import {Injectable} from '@angular/core';\r\nimport {AbstractControl, FormGroup, ValidationErrors, Validators} from '@angular/forms';\r\nimport {Observable, of} from 'rxjs';\r\n\r\n@Injectable({ providedIn: 'root' })\r\nexport class ValidatorsService {\r\n  constructor() {}\r\n\r\n  /** валидатор совпадения пароллей. При использовании указывать поля pswd & confPswd*/\r\n  public static passEqual(passwordKey: string, passwordConfirmationKey: string): ValidationErrors {\r\n    return (group: FormGroup) => {\r\n      const passwordInput = group.controls[passwordKey];\r\n      const passwordConfirmationInput = group.controls[passwordConfirmationKey];\r\n      if (passwordInput.value !== passwordConfirmationInput.value) {\r\n        return passwordConfirmationInput.setErrors({ notEquivalent: true });\r\n      } else {\r\n        return passwordConfirmationInput.setErrors(null);\r\n      }\r\n    };\r\n  }\r\n\r\n  public static passNotEqual(el: AbstractControl): ValidationErrors | null {\r\n    if (!el.get('pswd') || !el.get('oldPswd')) {\r\n      return null;\r\n    }\r\n    if (!(el.dirty || el.touched) || el.get('pswd')?.value !== el.get('oldPswd')?.value) {\r\n      return null;\r\n    }\r\n    return {\r\n      passNotEqual: 'Старый и новый пароли не должны совпадать',\r\n    };\r\n  }\r\n\r\n  public static wrongLogin(): ValidationErrors {\r\n    return {\r\n      wrongMail: 'Неверный логин!',\r\n    };\r\n  }\r\n\r\n  public static wrongLoginOrPswd(): ValidationErrors {\r\n    return {\r\n      wrongLogin: 'Неверный логин или пароль!',\r\n    };\r\n  }\r\n\r\n  public static existLogin(): ValidationErrors {\r\n    return {\r\n      mailErr: 'Пользователь с таким адресом уже зарегистрирован.',\r\n    };\r\n  }\r\n\r\n  /** валидатор имени*/\r\n  public static getNameValid() {\r\n    return [Validators.required, Validators.pattern(/^[A-ZА-Яa-zа-яЁё0-9- .]+$/), Validators.maxLength(35)];\r\n  }\r\n\r\n  /** валидатор email*/\r\n  public static getMailValid(el?: AbstractControl): Observable<ValidationErrors | null> {\r\n    const pattern =\r\n      /^([A-Za-z0-9+_-]+\\.)*[A-Za-z0-9+_-]+@[A-Za-z0-9+_-]+(\\.[A-Za-z0-9+_-]+)*\\.[A-Za-z]{2,6}$/;\r\n    if (!el?.value) {\r\n      return of({\r\n        required: 'Это поле обязательно для заполнения',\r\n      });\r\n    } else if (!pattern.test(el.value) && el.value !== 'test_admin' && el.value !== 'admin') {\r\n      return of({\r\n        email: 'Некорректно введены данные',\r\n      });\r\n    } else {\r\n      return of(null);\r\n    }\r\n  }\r\n\r\n  public static getErrorText(error: ValidationErrors | null | undefined): string | undefined {\r\n    const presetErrors = ['minlength', 'maxlength', 'email', 'required', 'pattern']\r\n    if (error) {\r\n      const key = Object.keys(error)?.[0];\r\n      if (key && presetErrors.includes(key)) {\r\n        switch (key) {\r\n          case 'minlength': {\r\n            return `Не менее ${error['minlength'].requiredLength} символов`\r\n          }\r\n          case 'maxlength': {\r\n            return `Не более${error['maxlength'].requiredLength} символов`\r\n          }\r\n          case 'pattern': {\r\n            return `Неверно заполнено поле`\r\n          }\r\n          case 'email': {\r\n            return `Неверно введен email`\r\n          }\r\n          case 'required': {\r\n            return `Обязательное поле`\r\n          }\r\n          default: {\r\n            return 'Неверно введен текст'\r\n          }\r\n\r\n        }\r\n      } else if (key && !presetErrors.includes(key)) {\r\n        return error[key]\r\n      }\r\n    }\r\n    return undefined;\r\n  }\r\n}\r\n"]}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { ChangeDetectionStrategy, Component, EventEmitter,
|
|
1
|
+
import { ChangeDetectionStrategy, Component, EventEmitter, Output } from '@angular/core';
|
|
2
2
|
import { defaultToastConfig, TOAST_CONFIG_TOKEN } from "../toast-config";
|
|
3
3
|
import { toastAnimations } from "./toast-animations";
|
|
4
4
|
import { OverlayModule } from "@angular/cdk/overlay";
|
|
@@ -8,10 +8,10 @@ import * as i0 from "@angular/core";
|
|
|
8
8
|
import * as i1 from "../toast-config";
|
|
9
9
|
import * as i2 from "../toast-ref";
|
|
10
10
|
export class ToastComponent {
|
|
11
|
-
constructor(data,
|
|
11
|
+
constructor(data, toastConfig, ref) {
|
|
12
12
|
this.data = data;
|
|
13
|
-
this.ref = ref;
|
|
14
13
|
this.toastConfig = toastConfig;
|
|
14
|
+
this.ref = ref;
|
|
15
15
|
this.callEvent = new EventEmitter();
|
|
16
16
|
this.animationState$ = new BehaviorSubject('default');
|
|
17
17
|
}
|
|
@@ -37,7 +37,7 @@ export class ToastComponent {
|
|
|
37
37
|
this.close();
|
|
38
38
|
}
|
|
39
39
|
}
|
|
40
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.2", ngImport: i0, type: ToastComponent, deps: [{ token: i1.ToastData }, { token:
|
|
40
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.2", ngImport: i0, type: ToastComponent, deps: [{ token: i1.ToastData }, { token: i1.ToastConfig }, { token: i2.ToastRef }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
41
41
|
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.2.2", type: ToastComponent, isStandalone: true, selector: "dd-toast", outputs: { callEvent: "callEvent" }, providers: [
|
|
42
42
|
{
|
|
43
43
|
provide: TOAST_CONFIG_TOKEN,
|
|
@@ -56,10 +56,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.2", ngImpor
|
|
|
56
56
|
useValue: defaultToastConfig,
|
|
57
57
|
}
|
|
58
58
|
], animations: [toastAnimations.fadeToast], changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"toast {{ data.type }}\" (click)=\"close()\"\r\n [@fadeAnimation]=\"{value: (animationState$ | async), params:\r\n { fadeIn: toastConfig!.animation!.fadeIn, fadeOut: toastConfig!.animation!.fadeOut }}\"\r\n (@fadeAnimation.done)=\"onFadeFinished($event)\">\r\n<!-- <dd-lib-svg-icon [icon]=\"data.type\"></dd-lib-svg-icon>-->\r\n @if (data.type === 'success') {\r\n <svg fill=\"none\" height=\"16\" viewBox=\"0 0 16 16\" width=\"16\" xmlns=\"http://www.w3.org/2000/svg\">\r\n <path\r\n d=\"M8 0C3.592 0 0 3.592 0 8C0 12.408 3.592 16 8 16C12.408 16 16 12.408 16 8C16 3.592 12.408 0 8 0ZM11.824 6.16L7.288 10.696C7.176 10.808 7.024 10.872 6.864 10.872C6.704 10.872 6.552 10.808 6.44 10.696L4.176 8.432C3.944 8.2 3.944 7.816 4.176 7.584C4.408 7.352 4.792 7.352 5.024 7.584L6.864 9.424L10.976 5.312C11.208 5.08 11.592 5.08 11.824 5.312C12.056 5.544 12.056 5.92 11.824 6.16Z\"\r\n fill=\"#07B700\"/>\r\n </svg>\r\n }\r\n @if (data.type === 'warning') {\r\n <svg fill=\"none\" height=\"16\" viewBox=\"0 0 16 16\" width=\"16\" xmlns=\"http://www.w3.org/2000/svg\">\r\n <path\r\n d=\"M8 0C3.592 0 0 3.592 0 8C0 12.408 3.592 16 8 16C12.408 16 16 12.408 16 8C16 3.592 12.408 0 8 0ZM7.4 4.8C7.4 4.472 7.672 4.2 8 4.2C8.328 4.2 8.6 4.472 8.6 4.8V8.8C8.6 9.128 8.328 9.4 8 9.4C7.672 9.4 7.4 9.128 7.4 8.8V4.8ZM8.736 11.504C8.696 11.608 8.64 11.688 8.568 11.768C8.488 11.84 8.4 11.896 8.304 11.936C8.208 11.976 8.104 12 8 12C7.896 12 7.792 11.976 7.696 11.936C7.6 11.896 7.512 11.84 7.432 11.768C7.36 11.688 7.304 11.608 7.264 11.504C7.224 11.408 7.2 11.304 7.2 11.2C7.2 11.096 7.224 10.992 7.264 10.896C7.304 10.8 7.36 10.712 7.432 10.632C7.512 10.56 7.6 10.504 7.696 10.464C7.888 10.384 8.112 10.384 8.304 10.464C8.4 10.504 8.488 10.56 8.568 10.632C8.64 10.712 8.696 10.8 8.736 10.896C8.776 10.992 8.8 11.096 8.8 11.2C8.8 11.304 8.776 11.408 8.736 11.504Z\"\r\n fill=\"#FAAD14\"/>\r\n </svg>\r\n\r\n }\r\n @if (data.type === 'danger') {\r\n <svg fill=\"none\" height=\"16\" viewBox=\"0 0 16 16\" width=\"16\" xmlns=\"http://www.w3.org/2000/svg\">\r\n <path\r\n d=\"M8 0C3.592 0 0 3.592 0 8C0 12.408 3.592 16 8 16C12.408 16 16 12.408 16 8C16 3.592 12.408 0 8 0ZM10.688 9.84C10.92 10.072 10.92 10.456 10.688 10.688C10.568 10.808 10.416 10.864 10.264 10.864C10.112 10.864 9.96 10.808 9.84 10.688L8 8.848L6.16 10.688C6.04 10.808 5.888 10.864 5.736 10.864C5.584 10.864 5.432 10.808 5.312 10.688C5.08 10.456 5.08 10.072 5.312 9.84L7.152 8L5.312 6.16C5.08 5.928 5.08 5.544 5.312 5.312C5.544 5.08 5.928 5.08 6.16 5.312L8 7.152L9.84 5.312C10.072 5.08 10.456 5.08 10.688 5.312C10.92 5.544 10.92 5.928 10.688 6.16L8.848 8L10.688 9.84Z\"\r\n fill=\"#FF3645\"/>\r\n </svg>\r\n\r\n }\r\n @if (data.type === 'info') {\r\n <svg fill=\"none\" height=\"16\" viewBox=\"0 0 16 16\" width=\"16\" xmlns=\"http://www.w3.org/2000/svg\">\r\n <path\r\n d=\"M8 16C12.408 16 16 12.408 16 8C16 3.592 12.408 0 8 0C3.592 0 0 3.592 0 8C0 12.408 3.592 16 8 16ZM8.6 11.2C8.6 11.528 8.328 11.8 8 11.8C7.672 11.8 7.4 11.528 7.4 11.2V7.2C7.4 6.872 7.672 6.6 8 6.6C8.328 6.6 8.6 6.872 8.6 7.2L8.6 11.2ZM7.264 4.496C7.304 4.392 7.36 4.312 7.432 4.232C7.512 4.16 7.6 4.104 7.696 4.064C7.792 4.024 7.896 4 8 4C8.104 4 8.208 4.024 8.304 4.064C8.4 4.104 8.488 4.16 8.568 4.232C8.64 4.312 8.696 4.392 8.736 4.496C8.776 4.592 8.8 4.696 8.8 4.8C8.8 4.904 8.776 5.008 8.736 5.104C8.696 5.2 8.64 5.288 8.568 5.368C8.488 5.44 8.4 5.496 8.304 5.536C8.112 5.616 7.888 5.616 7.696 5.536C7.6 5.496 7.512 5.44 7.432 5.368C7.36 5.288 7.304 5.2 7.264 5.104C7.224 5.008 7.2 4.904 7.2 4.8C7.2 4.696 7.224 4.592 7.264 4.496Z\"\r\n fill=\"#007BFB\"/>\r\n </svg>\r\n\r\n }\r\n <div class=\"ml-24\">\r\n <div [innerHTML]=\"data.title\"></div>\r\n <div (click)=\"onClickDesc($event)\" [innerHTML]=\"data.description\"></div>\r\n </div>\r\n</div>\r\n", styles: [":host{display:block}.toast{position:relative;margin-bottom:20px;display:flex;align-items:center;padding:20px;background:#eefaf3;border-radius:12px;opacity:1;max-width:350px;width:100%}.toast.success{background-color:var(--light-green-color)}.toast.info{background-color:var(--light-blue-color)}.toast.warning{background-color:var(--yellow-card)}.toast.danger{background-color:var(--red-light-color)}\n"] }]
|
|
59
|
-
}], ctorParameters: () => [{ type: i1.ToastData }, { type:
|
|
60
|
-
type: Inject,
|
|
61
|
-
args: [TOAST_CONFIG_TOKEN]
|
|
62
|
-
}] }], propDecorators: { callEvent: [{
|
|
59
|
+
}], ctorParameters: () => [{ type: i1.ToastData }, { type: i1.ToastConfig }, { type: i2.ToastRef }], propDecorators: { callEvent: [{
|
|
63
60
|
type: Output
|
|
64
61
|
}] } });
|
|
65
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"toast.component.js","sourceRoot":"","sources":["../../../../../../../projects/dd-lib/src/lib/core/toast/toast/toast.component.ts","../../../../../../../projects/dd-lib/src/lib/core/toast/toast/toast.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAC,uBAAuB,EAAE,SAAS,EAAE,YAAY,EAAE,MAAM,EAAqB,MAAM,EAAC,MAAM,eAAe,CAAC;AAClH,OAAO,EAAC,kBAAkB,EAAE,kBAAkB,EAAyB,MAAM,iBAAiB,CAAC;AAE/F,OAAO,EAAC,eAAe,EAAsB,MAAM,oBAAoB,CAAC;AACxE,OAAO,EAAC,aAAa,EAAC,MAAM,sBAAsB,CAAC;AACnD,OAAO,EAAC,eAAe,EAAC,MAAM,MAAM,CAAC;AACrC,OAAO,EAAC,SAAS,EAAC,MAAM,iBAAiB,CAAC;;;;AAoB1C,MAAM,OAAO,cAAc;IAMzB,YACW,IAAe,EACf,GAAa,EACa,WAAwB;QAFlD,SAAI,GAAJ,IAAI,CAAW;QACf,QAAG,GAAH,GAAG,CAAU;QACa,gBAAW,GAAX,WAAW,CAAa;QAR5C,cAAS,GAAG,IAAI,YAAY,EAAE,CAAC;QACzC,oBAAe,GAAG,IAAI,eAAe,CAAsB,SAAS,CAAC,CAAC;IAS7E,CAAC;IAEM,QAAQ;QACb,IAAI,CAAC,UAAU,GAAG,UAAU,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,SAAS,CAAC,EAAE,IAAI,CAAC,WAAW,CAAC,QAAQ,CAAC,CAAC;IACtG,CAAC;IACM,WAAW,CAAC,MAAkB;QACnC,IAAK,MAAM,CAAC,MAAsB,CAAC,OAAO,KAAK,GAAG,EAAE,CAAC;YACnD,IAAI,CAAC,SAAS,CAAC,IAAI,EAAE,CAAC;QACxB,CAAC;IACH,CAAC;IACM,WAAW;QAChB,YAAY,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;IAChC,CAAC;IAEM,KAAK;QACV,IAAI,CAAC,GAAG,CAAC,KAAK,EAAE,CAAC;IACnB,CAAC;IAEM,cAAc,CAAC,KAAU;QAC9B,MAAM,EAAC,OAAO,EAAC,GAAG,KAAK,CAAC;QACxB,MAAM,SAAS,GAAI,OAA+B,KAAK,SAAS,CAAC;QACjE,MAAM,UAAU,GAAG,IAAI,CAAC,eAAe,CAAC,QAAQ,EAAE,KAAK,SAAS,CAAC;QAEjE,IAAI,SAAS,IAAI,UAAU,EAAE,CAAC;YAC5B,IAAI,CAAC,KAAK,EAAE,CAAC;QACf,CAAC;IACH,CAAC;8GArCU,cAAc,mEASf,kBAAkB;kGATjB,cAAc,4FAXd;YACT;gBACE,OAAO,EAAE,kBAAkB;gBAC3B,QAAQ,EAAE,kBAAkB;aAC7B;SACF,0BCpBH,g1HAyCA,0cD7BI,aAAa,0BACb,SAAS,gCAUC,CAAC,eAAe,CAAC,SAAS,CAAC;;2FAG5B,cAAc;kBAlB1B,SAAS;+BACE,UAAU,cACR,IAAI,WACP;wBACP,aAAa;wBACb,SAAS;qBACV,aACU;wBACT;4BACE,OAAO,EAAE,kBAAkB;4BAC3B,QAAQ,EAAE,kBAAkB;yBAC7B;qBACF,cAGW,CAAC,eAAe,CAAC,SAAS,CAAC,mBACtB,uBAAuB,CAAC,MAAM;;0BAW5C,MAAM;2BAAC,kBAAkB;yCARX,SAAS;sBAAzB,MAAM","sourcesContent":["import {ChangeDetectionStrategy, Component, EventEmitter, Inject, OnDestroy, OnInit, Output} from '@angular/core';\r\nimport {defaultToastConfig, TOAST_CONFIG_TOKEN, ToastConfig, ToastData} from \"../toast-config\";\r\nimport {ToastRef} from \"../toast-ref\";\r\nimport {toastAnimations, ToastAnimationState} from \"./toast-animations\";\r\nimport {OverlayModule} from \"@angular/cdk/overlay\";\r\nimport {BehaviorSubject} from \"rxjs\";\r\nimport {AsyncPipe} from \"@angular/common\";\r\n\r\n@Component({\r\n  selector: 'dd-toast',\r\n  standalone: true,\r\n  imports: [\r\n    OverlayModule,\r\n    AsyncPipe,\r\n  ],\r\n  providers: [\r\n    {\r\n      provide: TOAST_CONFIG_TOKEN,\r\n      useValue: defaultToastConfig,\r\n    }\r\n  ],\r\n  templateUrl: './toast.component.html',\r\n  styleUrl: './toast.component.scss',\r\n  animations: [toastAnimations.fadeToast],\r\n  changeDetection: ChangeDetectionStrategy.OnPush\r\n})\r\nexport class ToastComponent implements OnInit, OnDestroy {\r\n  @Output() public callEvent = new EventEmitter();\r\n  public animationState$ = new BehaviorSubject<ToastAnimationState>('default');\r\n\r\n  private intervalId: number | undefined;\r\n\r\n  constructor(\r\n    readonly data: ToastData,\r\n    readonly ref: ToastRef,\r\n    @Inject(TOAST_CONFIG_TOKEN) public toastConfig: ToastConfig\r\n  ) {\r\n  }\r\n\r\n  public ngOnInit() {\r\n    this.intervalId = setTimeout(() => this.animationState$.next('closing'), this.toastConfig.interval);\r\n  }\r\n  public onClickDesc($event: MouseEvent): void {\r\n    if (($event.target as HTMLElement).tagName === 'A') {\r\n      this.callEvent.emit();\r\n    }\r\n  }\r\n  public ngOnDestroy() {\r\n    clearTimeout(this.intervalId);\r\n  }\r\n\r\n  public close() {\r\n    this.ref.close();\r\n  }\r\n\r\n  public onFadeFinished(event: any) {\r\n    const {toState} = event;\r\n    const isFadeOut = (toState as ToastAnimationState) === 'closing';\r\n    const itFinished = this.animationState$.getValue() === 'closing';\r\n\r\n    if (isFadeOut && itFinished) {\r\n      this.close();\r\n    }\r\n  }\r\n}\r\n","<div class=\"toast  {{ data.type }}\" (click)=\"close()\"\r\n     [@fadeAnimation]=\"{value: (animationState$ | async), params:\r\n        { fadeIn: toastConfig!.animation!.fadeIn, fadeOut: toastConfig!.animation!.fadeOut }}\"\r\n     (@fadeAnimation.done)=\"onFadeFinished($event)\">\r\n<!--  <dd-lib-svg-icon [icon]=\"data.type\"></dd-lib-svg-icon>-->\r\n  @if (data.type === 'success') {\r\n    <svg fill=\"none\" height=\"16\" viewBox=\"0 0 16 16\" width=\"16\" xmlns=\"http://www.w3.org/2000/svg\">\r\n      <path\r\n        d=\"M8 0C3.592 0 0 3.592 0 8C0 12.408 3.592 16 8 16C12.408 16 16 12.408 16 8C16 3.592 12.408 0 8 0ZM11.824 6.16L7.288 10.696C7.176 10.808 7.024 10.872 6.864 10.872C6.704 10.872 6.552 10.808 6.44 10.696L4.176 8.432C3.944 8.2 3.944 7.816 4.176 7.584C4.408 7.352 4.792 7.352 5.024 7.584L6.864 9.424L10.976 5.312C11.208 5.08 11.592 5.08 11.824 5.312C12.056 5.544 12.056 5.92 11.824 6.16Z\"\r\n        fill=\"#07B700\"/>\r\n    </svg>\r\n  }\r\n  @if (data.type === 'warning') {\r\n    <svg fill=\"none\" height=\"16\" viewBox=\"0 0 16 16\" width=\"16\" xmlns=\"http://www.w3.org/2000/svg\">\r\n      <path\r\n        d=\"M8 0C3.592 0 0 3.592 0 8C0 12.408 3.592 16 8 16C12.408 16 16 12.408 16 8C16 3.592 12.408 0 8 0ZM7.4 4.8C7.4 4.472 7.672 4.2 8 4.2C8.328 4.2 8.6 4.472 8.6 4.8V8.8C8.6 9.128 8.328 9.4 8 9.4C7.672 9.4 7.4 9.128 7.4 8.8V4.8ZM8.736 11.504C8.696 11.608 8.64 11.688 8.568 11.768C8.488 11.84 8.4 11.896 8.304 11.936C8.208 11.976 8.104 12 8 12C7.896 12 7.792 11.976 7.696 11.936C7.6 11.896 7.512 11.84 7.432 11.768C7.36 11.688 7.304 11.608 7.264 11.504C7.224 11.408 7.2 11.304 7.2 11.2C7.2 11.096 7.224 10.992 7.264 10.896C7.304 10.8 7.36 10.712 7.432 10.632C7.512 10.56 7.6 10.504 7.696 10.464C7.888 10.384 8.112 10.384 8.304 10.464C8.4 10.504 8.488 10.56 8.568 10.632C8.64 10.712 8.696 10.8 8.736 10.896C8.776 10.992 8.8 11.096 8.8 11.2C8.8 11.304 8.776 11.408 8.736 11.504Z\"\r\n        fill=\"#FAAD14\"/>\r\n    </svg>\r\n\r\n  }\r\n  @if (data.type === 'danger') {\r\n    <svg fill=\"none\" height=\"16\" viewBox=\"0 0 16 16\" width=\"16\" xmlns=\"http://www.w3.org/2000/svg\">\r\n      <path\r\n        d=\"M8 0C3.592 0 0 3.592 0 8C0 12.408 3.592 16 8 16C12.408 16 16 12.408 16 8C16 3.592 12.408 0 8 0ZM10.688 9.84C10.92 10.072 10.92 10.456 10.688 10.688C10.568 10.808 10.416 10.864 10.264 10.864C10.112 10.864 9.96 10.808 9.84 10.688L8 8.848L6.16 10.688C6.04 10.808 5.888 10.864 5.736 10.864C5.584 10.864 5.432 10.808 5.312 10.688C5.08 10.456 5.08 10.072 5.312 9.84L7.152 8L5.312 6.16C5.08 5.928 5.08 5.544 5.312 5.312C5.544 5.08 5.928 5.08 6.16 5.312L8 7.152L9.84 5.312C10.072 5.08 10.456 5.08 10.688 5.312C10.92 5.544 10.92 5.928 10.688 6.16L8.848 8L10.688 9.84Z\"\r\n        fill=\"#FF3645\"/>\r\n    </svg>\r\n\r\n  }\r\n  @if (data.type === 'info') {\r\n    <svg fill=\"none\" height=\"16\" viewBox=\"0 0 16 16\" width=\"16\" xmlns=\"http://www.w3.org/2000/svg\">\r\n      <path\r\n        d=\"M8 16C12.408 16 16 12.408 16 8C16 3.592 12.408 0 8 0C3.592 0 0 3.592 0 8C0 12.408 3.592 16 8 16ZM8.6 11.2C8.6 11.528 8.328 11.8 8 11.8C7.672 11.8 7.4 11.528 7.4 11.2V7.2C7.4 6.872 7.672 6.6 8 6.6C8.328 6.6 8.6 6.872 8.6 7.2L8.6 11.2ZM7.264 4.496C7.304 4.392 7.36 4.312 7.432 4.232C7.512 4.16 7.6 4.104 7.696 4.064C7.792 4.024 7.896 4 8 4C8.104 4 8.208 4.024 8.304 4.064C8.4 4.104 8.488 4.16 8.568 4.232C8.64 4.312 8.696 4.392 8.736 4.496C8.776 4.592 8.8 4.696 8.8 4.8C8.8 4.904 8.776 5.008 8.736 5.104C8.696 5.2 8.64 5.288 8.568 5.368C8.488 5.44 8.4 5.496 8.304 5.536C8.112 5.616 7.888 5.616 7.696 5.536C7.6 5.496 7.512 5.44 7.432 5.368C7.36 5.288 7.304 5.2 7.264 5.104C7.224 5.008 7.2 4.904 7.2 4.8C7.2 4.696 7.224 4.592 7.264 4.496Z\"\r\n        fill=\"#007BFB\"/>\r\n    </svg>\r\n\r\n  }\r\n  <div class=\"ml-24\">\r\n    <div [innerHTML]=\"data.title\"></div>\r\n    <div (click)=\"onClickDesc($event)\" [innerHTML]=\"data.description\"></div>\r\n  </div>\r\n</div>\r\n"]}
|
|
62
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"toast.component.js","sourceRoot":"","sources":["../../../../../../../projects/dd-lib/src/lib/core/toast/toast/toast.component.ts","../../../../../../../projects/dd-lib/src/lib/core/toast/toast/toast.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAC,uBAAuB,EAAE,SAAS,EAAE,YAAY,EAA6B,MAAM,EAAC,MAAM,eAAe,CAAC;AAClH,OAAO,EAAC,kBAAkB,EAAE,kBAAkB,EAAyB,MAAM,iBAAiB,CAAC;AAE/F,OAAO,EAAC,eAAe,EAAsB,MAAM,oBAAoB,CAAC;AACxE,OAAO,EAAC,aAAa,EAAC,MAAM,sBAAsB,CAAC;AACnD,OAAO,EAAC,eAAe,EAAC,MAAM,MAAM,CAAC;AACrC,OAAO,EAAC,SAAS,EAAC,MAAM,iBAAiB,CAAC;;;;AAoB1C,MAAM,OAAO,cAAc;IAMzB,YACW,IAAe,EACf,WAAwB,EACxB,GAAa;QAFb,SAAI,GAAJ,IAAI,CAAW;QACf,gBAAW,GAAX,WAAW,CAAa;QACxB,QAAG,GAAH,GAAG,CAAU;QARP,cAAS,GAAG,IAAI,YAAY,EAAE,CAAC;QACzC,oBAAe,GAAG,IAAI,eAAe,CAAsB,SAAS,CAAC,CAAC;IAS7E,CAAC;IAEM,QAAQ;QACb,IAAI,CAAC,UAAU,GAAG,UAAU,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,SAAS,CAAC,EAAE,IAAI,CAAC,WAAW,CAAC,QAAQ,CAAC,CAAC;IACtG,CAAC;IACM,WAAW,CAAC,MAAkB;QACnC,IAAK,MAAM,CAAC,MAAsB,CAAC,OAAO,KAAK,GAAG,EAAE,CAAC;YACnD,IAAI,CAAC,SAAS,CAAC,IAAI,EAAE,CAAC;QACxB,CAAC;IACH,CAAC;IACM,WAAW;QAChB,YAAY,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;IAChC,CAAC;IAEM,KAAK;QACV,IAAI,CAAC,GAAG,CAAC,KAAK,EAAE,CAAC;IACnB,CAAC;IAEM,cAAc,CAAC,KAAU;QAC9B,MAAM,EAAC,OAAO,EAAC,GAAG,KAAK,CAAC;QACxB,MAAM,SAAS,GAAI,OAA+B,KAAK,SAAS,CAAC;QACjE,MAAM,UAAU,GAAG,IAAI,CAAC,eAAe,CAAC,QAAQ,EAAE,KAAK,SAAS,CAAC;QAEjE,IAAI,SAAS,IAAI,UAAU,EAAE,CAAC;YAC5B,IAAI,CAAC,KAAK,EAAE,CAAC;QACf,CAAC;IACH,CAAC;8GArCU,cAAc;kGAAd,cAAc,4FAXd;YACT;gBACE,OAAO,EAAE,kBAAkB;gBAC3B,QAAQ,EAAE,kBAAkB;aAC7B;SACF,0BCpBH,g1HAyCA,0cD7BI,aAAa,0BACb,SAAS,gCAUC,CAAC,eAAe,CAAC,SAAS,CAAC;;2FAG5B,cAAc;kBAlB1B,SAAS;+BACE,UAAU,cACR,IAAI,WACP;wBACP,aAAa;wBACb,SAAS;qBACV,aACU;wBACT;4BACE,OAAO,EAAE,kBAAkB;4BAC3B,QAAQ,EAAE,kBAAkB;yBAC7B;qBACF,cAGW,CAAC,eAAe,CAAC,SAAS,CAAC,mBACtB,uBAAuB,CAAC,MAAM;+HAG9B,SAAS;sBAAzB,MAAM","sourcesContent":["import {ChangeDetectionStrategy, Component, EventEmitter, Inject, OnDestroy, OnInit, Output} from '@angular/core';\r\nimport {defaultToastConfig, TOAST_CONFIG_TOKEN, ToastConfig, ToastData} from \"../toast-config\";\r\nimport {ToastRef} from \"../toast-ref\";\r\nimport {toastAnimations, ToastAnimationState} from \"./toast-animations\";\r\nimport {OverlayModule} from \"@angular/cdk/overlay\";\r\nimport {BehaviorSubject} from \"rxjs\";\r\nimport {AsyncPipe} from \"@angular/common\";\r\n\r\n@Component({\r\n  selector: 'dd-toast',\r\n  standalone: true,\r\n  imports: [\r\n    OverlayModule,\r\n    AsyncPipe,\r\n  ],\r\n  providers: [\r\n    {\r\n      provide: TOAST_CONFIG_TOKEN,\r\n      useValue: defaultToastConfig,\r\n    }\r\n  ],\r\n  templateUrl: './toast.component.html',\r\n  styleUrl: './toast.component.scss',\r\n  animations: [toastAnimations.fadeToast],\r\n  changeDetection: ChangeDetectionStrategy.OnPush\r\n})\r\nexport class ToastComponent implements OnInit, OnDestroy {\r\n  @Output() public callEvent = new EventEmitter();\r\n  public animationState$ = new BehaviorSubject<ToastAnimationState>('default');\r\n\r\n  private intervalId: number | undefined;\r\n\r\n  constructor(\r\n    readonly data: ToastData,\r\n    readonly toastConfig: ToastConfig,\r\n    readonly ref: ToastRef,\r\n  ) {\r\n  }\r\n\r\n  public ngOnInit() {\r\n    this.intervalId = setTimeout(() => this.animationState$.next('closing'), this.toastConfig.interval);\r\n  }\r\n  public onClickDesc($event: MouseEvent): void {\r\n    if (($event.target as HTMLElement).tagName === 'A') {\r\n      this.callEvent.emit();\r\n    }\r\n  }\r\n  public ngOnDestroy() {\r\n    clearTimeout(this.intervalId);\r\n  }\r\n\r\n  public close() {\r\n    this.ref.close();\r\n  }\r\n\r\n  public onFadeFinished(event: any) {\r\n    const {toState} = event;\r\n    const isFadeOut = (toState as ToastAnimationState) === 'closing';\r\n    const itFinished = this.animationState$.getValue() === 'closing';\r\n\r\n    if (isFadeOut && itFinished) {\r\n      this.close();\r\n    }\r\n  }\r\n}\r\n","<div class=\"toast  {{ data.type }}\" (click)=\"close()\"\r\n     [@fadeAnimation]=\"{value: (animationState$ | async), params:\r\n        { fadeIn: toastConfig!.animation!.fadeIn, fadeOut: toastConfig!.animation!.fadeOut }}\"\r\n     (@fadeAnimation.done)=\"onFadeFinished($event)\">\r\n<!--  <dd-lib-svg-icon [icon]=\"data.type\"></dd-lib-svg-icon>-->\r\n  @if (data.type === 'success') {\r\n    <svg fill=\"none\" height=\"16\" viewBox=\"0 0 16 16\" width=\"16\" xmlns=\"http://www.w3.org/2000/svg\">\r\n      <path\r\n        d=\"M8 0C3.592 0 0 3.592 0 8C0 12.408 3.592 16 8 16C12.408 16 16 12.408 16 8C16 3.592 12.408 0 8 0ZM11.824 6.16L7.288 10.696C7.176 10.808 7.024 10.872 6.864 10.872C6.704 10.872 6.552 10.808 6.44 10.696L4.176 8.432C3.944 8.2 3.944 7.816 4.176 7.584C4.408 7.352 4.792 7.352 5.024 7.584L6.864 9.424L10.976 5.312C11.208 5.08 11.592 5.08 11.824 5.312C12.056 5.544 12.056 5.92 11.824 6.16Z\"\r\n        fill=\"#07B700\"/>\r\n    </svg>\r\n  }\r\n  @if (data.type === 'warning') {\r\n    <svg fill=\"none\" height=\"16\" viewBox=\"0 0 16 16\" width=\"16\" xmlns=\"http://www.w3.org/2000/svg\">\r\n      <path\r\n        d=\"M8 0C3.592 0 0 3.592 0 8C0 12.408 3.592 16 8 16C12.408 16 16 12.408 16 8C16 3.592 12.408 0 8 0ZM7.4 4.8C7.4 4.472 7.672 4.2 8 4.2C8.328 4.2 8.6 4.472 8.6 4.8V8.8C8.6 9.128 8.328 9.4 8 9.4C7.672 9.4 7.4 9.128 7.4 8.8V4.8ZM8.736 11.504C8.696 11.608 8.64 11.688 8.568 11.768C8.488 11.84 8.4 11.896 8.304 11.936C8.208 11.976 8.104 12 8 12C7.896 12 7.792 11.976 7.696 11.936C7.6 11.896 7.512 11.84 7.432 11.768C7.36 11.688 7.304 11.608 7.264 11.504C7.224 11.408 7.2 11.304 7.2 11.2C7.2 11.096 7.224 10.992 7.264 10.896C7.304 10.8 7.36 10.712 7.432 10.632C7.512 10.56 7.6 10.504 7.696 10.464C7.888 10.384 8.112 10.384 8.304 10.464C8.4 10.504 8.488 10.56 8.568 10.632C8.64 10.712 8.696 10.8 8.736 10.896C8.776 10.992 8.8 11.096 8.8 11.2C8.8 11.304 8.776 11.408 8.736 11.504Z\"\r\n        fill=\"#FAAD14\"/>\r\n    </svg>\r\n\r\n  }\r\n  @if (data.type === 'danger') {\r\n    <svg fill=\"none\" height=\"16\" viewBox=\"0 0 16 16\" width=\"16\" xmlns=\"http://www.w3.org/2000/svg\">\r\n      <path\r\n        d=\"M8 0C3.592 0 0 3.592 0 8C0 12.408 3.592 16 8 16C12.408 16 16 12.408 16 8C16 3.592 12.408 0 8 0ZM10.688 9.84C10.92 10.072 10.92 10.456 10.688 10.688C10.568 10.808 10.416 10.864 10.264 10.864C10.112 10.864 9.96 10.808 9.84 10.688L8 8.848L6.16 10.688C6.04 10.808 5.888 10.864 5.736 10.864C5.584 10.864 5.432 10.808 5.312 10.688C5.08 10.456 5.08 10.072 5.312 9.84L7.152 8L5.312 6.16C5.08 5.928 5.08 5.544 5.312 5.312C5.544 5.08 5.928 5.08 6.16 5.312L8 7.152L9.84 5.312C10.072 5.08 10.456 5.08 10.688 5.312C10.92 5.544 10.92 5.928 10.688 6.16L8.848 8L10.688 9.84Z\"\r\n        fill=\"#FF3645\"/>\r\n    </svg>\r\n\r\n  }\r\n  @if (data.type === 'info') {\r\n    <svg fill=\"none\" height=\"16\" viewBox=\"0 0 16 16\" width=\"16\" xmlns=\"http://www.w3.org/2000/svg\">\r\n      <path\r\n        d=\"M8 16C12.408 16 16 12.408 16 8C16 3.592 12.408 0 8 0C3.592 0 0 3.592 0 8C0 12.408 3.592 16 8 16ZM8.6 11.2C8.6 11.528 8.328 11.8 8 11.8C7.672 11.8 7.4 11.528 7.4 11.2V7.2C7.4 6.872 7.672 6.6 8 6.6C8.328 6.6 8.6 6.872 8.6 7.2L8.6 11.2ZM7.264 4.496C7.304 4.392 7.36 4.312 7.432 4.232C7.512 4.16 7.6 4.104 7.696 4.064C7.792 4.024 7.896 4 8 4C8.104 4 8.208 4.024 8.304 4.064C8.4 4.104 8.488 4.16 8.568 4.232C8.64 4.312 8.696 4.392 8.736 4.496C8.776 4.592 8.8 4.696 8.8 4.8C8.8 4.904 8.776 5.008 8.736 5.104C8.696 5.2 8.64 5.288 8.568 5.368C8.488 5.44 8.4 5.496 8.304 5.536C8.112 5.616 7.888 5.616 7.696 5.536C7.6 5.496 7.512 5.44 7.432 5.368C7.36 5.288 7.304 5.2 7.264 5.104C7.224 5.008 7.2 4.904 7.2 4.8C7.2 4.696 7.224 4.592 7.264 4.496Z\"\r\n        fill=\"#007BFB\"/>\r\n    </svg>\r\n\r\n  }\r\n  <div class=\"ml-24\">\r\n    <div [innerHTML]=\"data.title\"></div>\r\n    <div (click)=\"onClickDesc($event)\" [innerHTML]=\"data.description\"></div>\r\n  </div>\r\n</div>\r\n"]}
|
|
@@ -1,5 +1,16 @@
|
|
|
1
1
|
import { InjectionToken } from '@angular/core';
|
|
2
|
-
export class
|
|
2
|
+
export class ToastTypeData {
|
|
3
|
+
}
|
|
4
|
+
export class ToastData extends ToastTypeData {
|
|
5
|
+
constructor(type, data) {
|
|
6
|
+
super();
|
|
7
|
+
this.type = type;
|
|
8
|
+
if (data) {
|
|
9
|
+
Object.assign(this, data);
|
|
10
|
+
}
|
|
11
|
+
}
|
|
12
|
+
}
|
|
13
|
+
export class ToastConfig {
|
|
3
14
|
}
|
|
4
15
|
export const defaultToastConfig = {
|
|
5
16
|
position: {
|
|
@@ -21,4 +32,4 @@ export const provideToast = (config = defaultToastConfig) => {
|
|
|
21
32
|
}
|
|
22
33
|
];
|
|
23
34
|
};
|
|
24
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
35
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidG9hc3QtY29uZmlnLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZGQtbGliL3NyYy9saWIvY29yZS90b2FzdC90b2FzdC1jb25maWcudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFDLGNBQWMsRUFBd0IsTUFBTSxlQUFlLENBQUM7QUFFcEUsTUFBTSxPQUFPLGFBQWE7Q0FPekI7QUFDRCxNQUFNLE9BQU8sU0FBVSxTQUFRLGFBQWE7SUFHMUMsWUFBWSxJQUFlLEVBQUUsSUFBb0I7UUFDL0MsS0FBSyxFQUFFLENBQUM7UUFDUixJQUFJLENBQUMsSUFBSSxHQUFHLElBQUksQ0FBQztRQUNqQixJQUFJLElBQUksRUFBRSxDQUFDO1lBQ1QsTUFBTSxDQUFDLE1BQU0sQ0FBQyxJQUFJLEVBQUUsSUFBSSxDQUFDLENBQUE7UUFDM0IsQ0FBQztJQUNILENBQUM7Q0FDRjtBQUlELE1BQU0sT0FBTyxXQUFXO0NBVXZCO0FBRUQsTUFBTSxDQUFDLE1BQU0sa0JBQWtCLEdBQWdCO0lBQzdDLFFBQVEsRUFBRTtRQUNSLEdBQUcsRUFBRSxFQUFFO1FBQ1AsS0FBSyxFQUFFLEVBQUU7S0FDVjtJQUNELFNBQVMsRUFBRTtRQUNULE9BQU8sRUFBRSxJQUFJO1FBQ2IsTUFBTSxFQUFFLEdBQUc7S0FDWjtJQUNELFFBQVEsRUFBRSxJQUFJO0NBQ2YsQ0FBQztBQUVGLE1BQU0sQ0FBQyxNQUFNLGtCQUFrQixHQUFHLElBQUksY0FBYyxDQUFjLGNBQWMsQ0FBQyxDQUFDO0FBR2xGLE1BQU0sQ0FBQyxNQUFNLFlBQVksR0FBRyxDQUFDLFNBQStCLGtCQUFrQixFQUFjLEVBQUU7SUFDNUYsT0FBTztRQUNMO1lBQ0UsT0FBTyxFQUFFLGtCQUFrQjtZQUMzQixRQUFRLEVBQUUsRUFBRSxHQUFHLGtCQUFrQixFQUFFLEdBQUcsTUFBTSxFQUFFO1NBQy9DO0tBQ0YsQ0FBQztBQUNKLENBQUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7SW5qZWN0aW9uVG9rZW4sIFByb3ZpZGVyLCBUZW1wbGF0ZVJlZn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcblxyXG5leHBvcnQgY2xhc3MgVG9hc3RUeXBlRGF0YSB7XHJcbiAgdGl0bGU/OiBzdHJpbmc7XHJcbiAgZGVzY3JpcHRpb24/OiBzdHJpbmc7XHJcbiAgdGVtcGxhdGU/OiBUZW1wbGF0ZVJlZjxhbnk+O1xyXG4gIHRlbXBsYXRlQ29udGV4dD86IHt9O1xyXG5cclxuXHJcbn1cclxuZXhwb3J0IGNsYXNzIFRvYXN0RGF0YSBleHRlbmRzIFRvYXN0VHlwZURhdGEge1xyXG4gIHR5cGUhOiBUb2FzdFR5cGU7XHJcblxyXG4gIGNvbnN0cnVjdG9yKHR5cGU6IFRvYXN0VHlwZSwgZGF0YT86IFRvYXN0VHlwZURhdGEgKSB7XHJcbiAgICBzdXBlcigpO1xyXG4gICAgdGhpcy50eXBlID0gdHlwZTtcclxuICAgIGlmIChkYXRhKSB7XHJcbiAgICAgIE9iamVjdC5hc3NpZ24odGhpcywgZGF0YSlcclxuICAgIH1cclxuICB9XHJcbn1cclxuXHJcbmV4cG9ydCB0eXBlIFRvYXN0VHlwZSA9ICd3YXJuaW5nJyB8ICdpbmZvJyB8ICdzdWNjZXNzJyB8ICdkYW5nZXInO1xyXG5cclxuZXhwb3J0IGNsYXNzIFRvYXN0Q29uZmlnIHtcclxuIHB1YmxpYyBwb3NpdGlvbj86IHtcclxuICAgIHRvcDogbnVtYmVyO1xyXG4gICAgcmlnaHQ6IG51bWJlcjtcclxuICB9O1xyXG4gIHB1YmxpYyBhbmltYXRpb24/OiB7XHJcbiAgICBmYWRlT3V0OiBudW1iZXI7XHJcbiAgICBmYWRlSW46IG51bWJlcjtcclxuICB9O1xyXG4gIHB1YmxpYyBpbnRlcnZhbD86IG51bWJlclxyXG59XHJcblxyXG5leHBvcnQgY29uc3QgZGVmYXVsdFRvYXN0Q29uZmlnOiBUb2FzdENvbmZpZyA9IHtcclxuICBwb3NpdGlvbjoge1xyXG4gICAgdG9wOiAyMCxcclxuICAgIHJpZ2h0OiAyMCxcclxuICB9LFxyXG4gIGFuaW1hdGlvbjoge1xyXG4gICAgZmFkZU91dDogMjUwMCxcclxuICAgIGZhZGVJbjogMzAwLFxyXG4gIH0sXHJcbiAgaW50ZXJ2YWw6IDUwMDBcclxufTtcclxuXHJcbmV4cG9ydCBjb25zdCBUT0FTVF9DT05GSUdfVE9LRU4gPSBuZXcgSW5qZWN0aW9uVG9rZW48VG9hc3RDb25maWc+KCd0b2FzdCBjb25maWcnKTtcclxuXHJcblxyXG5leHBvcnQgY29uc3QgcHJvdmlkZVRvYXN0ID0gKGNvbmZpZzogUGFydGlhbDxUb2FzdENvbmZpZz4gPSBkZWZhdWx0VG9hc3RDb25maWcpOiBQcm92aWRlcltdID0+IHtcclxuICByZXR1cm4gW1xyXG4gICAge1xyXG4gICAgICBwcm92aWRlOiBUT0FTVF9DT05GSUdfVE9LRU4sXHJcbiAgICAgIHVzZVZhbHVlOiB7IC4uLmRlZmF1bHRUb2FzdENvbmZpZywgLi4uY29uZmlnIH1cclxuICAgIH1cclxuICBdO1xyXG59O1xyXG4iXX0=
|