adb-shared 2.0.32 → 2.0.35
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/components/adb-toast/adb-toast.mjs +15 -9
- package/esm2020/lib/components/adb-toast/adb-toast.service.mjs +34 -20
- package/esm2020/lib/components/date-picker/adb-date-picker.directive.mjs +33 -9
- package/fesm2015/adb-shared.mjs +80 -37
- package/fesm2015/adb-shared.mjs.map +1 -1
- package/fesm2020/adb-shared.mjs +79 -37
- package/fesm2020/adb-shared.mjs.map +1 -1
- package/lib/components/adb-toast/adb-toast.d.ts +7 -11
- package/lib/components/adb-toast/adb-toast.service.d.ts +20 -3
- package/lib/components/date-picker/adb-date-picker.directive.d.ts +5 -1
- package/package.json +1 -1
|
@@ -1,19 +1,25 @@
|
|
|
1
|
-
import { Component
|
|
1
|
+
import { Component } from '@angular/core';
|
|
2
|
+
import { ToastType } from './adb-toast.service';
|
|
2
3
|
import * as i0 from "@angular/core";
|
|
3
4
|
import * as i1 from "./adb-toast.service";
|
|
4
5
|
import * as i2 from "@angular/common";
|
|
5
6
|
import * as i3 from "@ngx-translate/core";
|
|
6
7
|
export class AdbToast {
|
|
7
|
-
constructor(
|
|
8
|
-
this.
|
|
8
|
+
constructor(toastService) {
|
|
9
|
+
this.toastService = toastService;
|
|
10
|
+
this.toastType = ToastType;
|
|
11
|
+
this.toastService.$toasts.subscribe(toasts => {
|
|
12
|
+
this.toasts = toasts;
|
|
13
|
+
});
|
|
14
|
+
}
|
|
15
|
+
onRemoveToast(toast) {
|
|
16
|
+
this.toastService.remove(toast);
|
|
9
17
|
}
|
|
10
18
|
}
|
|
11
19
|
/** @nocollapse */ AdbToast.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.8", ngImport: i0, type: AdbToast, deps: [{ token: i1.AdbToastService }], target: i0.ɵɵFactoryTarget.Component });
|
|
12
|
-
/** @nocollapse */ AdbToast.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.8", type: AdbToast, selector: "ng-component",
|
|
20
|
+
/** @nocollapse */ AdbToast.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.8", type: AdbToast, selector: "ng-component", ngImport: i0, template: "<div class=\"position-fixed bottom-0 end-0\" style=\"z-index: 50000;min-width: 15rem;\">\r\n <div class=\"text-white px-3 pb-3 pt-2 mb-2\" *ngFor=\"let toast of toasts\"\r\n [class.bg-success]=\"toast.type===toastType.Success\" [class.bg-info]=\"toast.type===toastType.Info\" [class.bg-danger]=\"toast.type===toastType.Warn\">\r\n <div class=\"d-flex align-items-center justify-content-between pb-1\" *ngIf=\"toast.header\">\r\n <div class=\"fw-bold pb-1\">{{toast.header|translate}}</div>\r\n <button class=\"btn top-0 end-0 btn p-0 ms-2 text-white\" (click)=\"onRemoveToast(toast)\"><i class=\"fas fa-times\"></i></button>\r\n </div>\r\n <div class=\"d-flex align-items-center justify-content-between mt-1\">\r\n <div>{{toast.message|translate}}</div>\r\n <button *ngIf=\"!toast.header\" class=\"btn p-0 ms-2 text-white\" (click)=\"onRemoveToast(toast)\"><i class=\"fas fa-times\"></i></button>\r\n </div>\r\n </div>\r\n</div>", directives: [{ type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], pipes: { "translate": i3.TranslatePipe } });
|
|
13
21
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.8", ngImport: i0, type: AdbToast, decorators: [{
|
|
14
22
|
type: Component,
|
|
15
|
-
args: [{ template: "
|
|
16
|
-
}], ctorParameters: function () { return [{ type: i1.AdbToastService }]; }
|
|
17
|
-
|
|
18
|
-
}] } });
|
|
19
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWRiLXRvYXN0LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYXJ0ZGF0YS1zaGFyZWQvc3JjL2xpYi9jb21wb25lbnRzL2FkYi10b2FzdC9hZGItdG9hc3QudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9hcnRkYXRhLXNoYXJlZC9zcmMvbGliL2NvbXBvbmVudHMvYWRiLXRvYXN0L2FkYi10b2FzdC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFFLE1BQU0sZUFBZSxDQUFDOzs7OztBQUtqRCxNQUFNLE9BQU8sUUFBUTtJQUVqQixZQUFtQixRQUF5QjtRQUF6QixhQUFRLEdBQVIsUUFBUSxDQUFpQjtJQUFHLENBQUM7O3dIQUZ2QyxRQUFROzRHQUFSLFFBQVEsZ0ZDTHJCLG15QkFTVTsyRkRKRyxRQUFRO2tCQUhwQixTQUFTOztzR0FJVSxLQUFLO3NCQUFwQixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBJbnB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBBZGJUb2FzdFNlcnZpY2UgfSBmcm9tICcuL2FkYi10b2FzdC5zZXJ2aWNlJztcclxuQENvbXBvbmVudCh7XHJcbiAgICB0ZW1wbGF0ZVVybDogJ2FkYi10b2FzdC5odG1sJ1xyXG59KVxyXG5leHBvcnQgY2xhc3MgQWRiVG9hc3Qge1xyXG4gICAgQElucHV0KCkgcHVibGljIG1vZGVsOiBUb2FzdE1vZGVsO1xyXG4gICAgY29uc3RydWN0b3IocHVibGljIHRvYXN0UmVmOiBBZGJUb2FzdFNlcnZpY2UpIHt9XHJcbn1cclxuXHJcbmV4cG9ydCBpbnRlcmZhY2UgVG9hc3RNb2RlbCB7XHJcbiAgICBib2R5OiBzdHJpbmc7XHJcbiAgICBoZWFkZXI/OiBzdHJpbmc7XHJcbiAgICBzdGF0ZT86ICdpbmZvJyB8ICdzdWNjZXNzJyB8ICdkYW5nZXInO1xyXG4gICAgdGltZUluTXM/OiBudW1iZXI7XHJcbn1cclxuIiwiICAgIDxkaXYgI3RvYXN0IChjbGljayk9XCJ0b2FzdC5yZW1vdmUoKVwiIGFkYi10b2FzdCBjbGFzcz1cInRleHQtd2hpdGUgcHgtMyBwYi0zIHB0LTIgbWItMlwiIHN0eWxlPVwiei1pbmRleDogNTAwMDA7bWluLXdpZHRoOiAxNXJlbTtcIiBbY2xhc3NdPVwiJ2JnLScgKyBtb2RlbC5zdGF0ZVwiPlxyXG4gICAgICAgIDxkaXYgKm5nSWY9XCJtb2RlbC5oZWFkZXJcIiBjbGFzcz1cImQtZmxleCBhbGlnbi1pdGVtcy1jZW50ZXIganVzdGlmeS1jb250ZW50LWJldHdlZW4gcGItMVwiPlxyXG4gICAgICAgICAgICA8ZGl2IGNsYXNzPVwiZnctYm9sZFwiPnt7bW9kZWwuaGVhZGVyfHRyYW5zbGF0ZX19PC9kaXY+XHJcbiAgICAgICAgICAgIDxidXR0b24gY2xhc3M9XCJidG4gcC0wIG1zLTIgdGV4dC13aGl0ZVwiIChjbGljayk9XCJ0b2FzdC5yZW1vdmUoKVwiPjxpIGNsYXNzPVwiZmFzIGZhLXRpbWVzXCI+PC9pPjwvYnV0dG9uPlxyXG4gICAgICAgIDwvZGl2PlxyXG4gICAgICAgIDxkaXYgY2xhc3M9XCJkLWZsZXggYWxpZ24taXRlbXMtY2VudGVyIGp1c3RpZnktY29udGVudC1iZXR3ZWVuIG10LTFcIj5cclxuICAgICAgICAgICAgPGRpdj4ge3ttb2RlbC5ib2R5fHRyYW5zbGF0ZX19PC9kaXY+XHJcbiAgICAgICAgICAgIDxidXR0b24gKm5nSWY9XCIhbW9kZWwuaGVhZGVyXCIgY2xhc3M9XCJidG4gcC0wIG1zLTIgdGV4dC13aGl0ZVwiIChjbGljayk9XCJ0b2FzdC5yZW1vdmUoKVwiPjxpIGNsYXNzPVwiZmFzIGZhLXRpbWVzXCI+PC9pPjwvYnV0dG9uPlxyXG4gICAgICAgIDwvZGl2PlxyXG4gICAgPC9kaXY+Il19
|
|
23
|
+
args: [{ template: "<div class=\"position-fixed bottom-0 end-0\" style=\"z-index: 50000;min-width: 15rem;\">\r\n <div class=\"text-white px-3 pb-3 pt-2 mb-2\" *ngFor=\"let toast of toasts\"\r\n [class.bg-success]=\"toast.type===toastType.Success\" [class.bg-info]=\"toast.type===toastType.Info\" [class.bg-danger]=\"toast.type===toastType.Warn\">\r\n <div class=\"d-flex align-items-center justify-content-between pb-1\" *ngIf=\"toast.header\">\r\n <div class=\"fw-bold pb-1\">{{toast.header|translate}}</div>\r\n <button class=\"btn top-0 end-0 btn p-0 ms-2 text-white\" (click)=\"onRemoveToast(toast)\"><i class=\"fas fa-times\"></i></button>\r\n </div>\r\n <div class=\"d-flex align-items-center justify-content-between mt-1\">\r\n <div>{{toast.message|translate}}</div>\r\n <button *ngIf=\"!toast.header\" class=\"btn p-0 ms-2 text-white\" (click)=\"onRemoveToast(toast)\"><i class=\"fas fa-times\"></i></button>\r\n </div>\r\n </div>\r\n</div>" }]
|
|
24
|
+
}], ctorParameters: function () { return [{ type: i1.AdbToastService }]; } });
|
|
25
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWRiLXRvYXN0LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYXJ0ZGF0YS1zaGFyZWQvc3JjL2xpYi9jb21wb25lbnRzL2FkYi10b2FzdC9hZGItdG9hc3QudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9hcnRkYXRhLXNoYXJlZC9zcmMvbGliL2NvbXBvbmVudHMvYWRiLXRvYXN0L2FkYi10b2FzdC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUNBLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDMUMsT0FBTyxFQUFpQyxTQUFTLEVBQUUsTUFBTSxxQkFBcUIsQ0FBQzs7Ozs7QUFJL0UsTUFBTSxPQUFPLFFBQVE7SUFHakIsWUFBbUIsWUFBNkI7UUFBN0IsaUJBQVksR0FBWixZQUFZLENBQWlCO1FBRGhELGNBQVMsR0FBRyxTQUFTLENBQUM7UUFFbEIsSUFBSSxDQUFDLFlBQVksQ0FBQyxPQUFPLENBQUMsU0FBUyxDQUFDLE1BQU0sQ0FBQyxFQUFFO1lBQ3pDLElBQUksQ0FBQyxNQUFNLEdBQUcsTUFBTSxDQUFDO1FBQ3pCLENBQUMsQ0FBQyxDQUFDO0lBQ1AsQ0FBQztJQUNELGFBQWEsQ0FBQyxLQUFtQjtRQUM3QixJQUFJLENBQUMsWUFBWSxDQUFDLE1BQU0sQ0FBQyxLQUFLLENBQUMsQ0FBQztJQUNwQyxDQUFDOzt3SEFWUSxRQUFROzRHQUFSLFFBQVEsb0RDTnJCLHcvQkFZTTsyRkROTyxRQUFRO2tCQUhwQixTQUFTIiwic291cmNlc0NvbnRlbnQiOlsiXHJcbmltcG9ydCB7IENvbXBvbmVudCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBBZGJUb2FzdFNlcnZpY2UsIFRvYXN0TWVzc2FnZSwgVG9hc3RUeXBlIH0gZnJvbSAnLi9hZGItdG9hc3Quc2VydmljZSc7XHJcbkBDb21wb25lbnQoe1xyXG4gICAgdGVtcGxhdGVVcmw6ICdhZGItdG9hc3QuaHRtbCdcclxufSlcclxuZXhwb3J0IGNsYXNzIEFkYlRvYXN0IHtcclxuICAgIHRvYXN0czogVG9hc3RNZXNzYWdlW107XHJcbiAgICB0b2FzdFR5cGUgPSBUb2FzdFR5cGU7XHJcbiAgICBjb25zdHJ1Y3RvcihwdWJsaWMgdG9hc3RTZXJ2aWNlOiBBZGJUb2FzdFNlcnZpY2UpIHtcclxuICAgICAgICB0aGlzLnRvYXN0U2VydmljZS4kdG9hc3RzLnN1YnNjcmliZSh0b2FzdHMgPT4ge1xyXG4gICAgICAgICAgICB0aGlzLnRvYXN0cyA9IHRvYXN0cztcclxuICAgICAgICB9KTtcclxuICAgIH1cclxuICAgIG9uUmVtb3ZlVG9hc3QodG9hc3Q6IFRvYXN0TWVzc2FnZSk6IHZvaWQge1xyXG4gICAgICAgIHRoaXMudG9hc3RTZXJ2aWNlLnJlbW92ZSh0b2FzdCk7XHJcbiAgICB9XHJcbn0iLCI8ZGl2IGNsYXNzPVwicG9zaXRpb24tZml4ZWQgYm90dG9tLTAgZW5kLTBcIiBzdHlsZT1cInotaW5kZXg6IDUwMDAwO21pbi13aWR0aDogMTVyZW07XCI+XHJcbiAgICA8ZGl2IGNsYXNzPVwidGV4dC13aGl0ZSBweC0zIHBiLTMgcHQtMiBtYi0yXCIgKm5nRm9yPVwibGV0IHRvYXN0IG9mIHRvYXN0c1wiXHJcbiAgICAgICAgW2NsYXNzLmJnLXN1Y2Nlc3NdPVwidG9hc3QudHlwZT09PXRvYXN0VHlwZS5TdWNjZXNzXCIgW2NsYXNzLmJnLWluZm9dPVwidG9hc3QudHlwZT09PXRvYXN0VHlwZS5JbmZvXCIgW2NsYXNzLmJnLWRhbmdlcl09XCJ0b2FzdC50eXBlPT09dG9hc3RUeXBlLldhcm5cIj5cclxuICAgICAgICA8ZGl2IGNsYXNzPVwiZC1mbGV4IGFsaWduLWl0ZW1zLWNlbnRlciBqdXN0aWZ5LWNvbnRlbnQtYmV0d2VlbiBwYi0xXCIgKm5nSWY9XCJ0b2FzdC5oZWFkZXJcIj5cclxuICAgICAgICAgICAgPGRpdiBjbGFzcz1cImZ3LWJvbGQgcGItMVwiPnt7dG9hc3QuaGVhZGVyfHRyYW5zbGF0ZX19PC9kaXY+XHJcbiAgICAgICAgICAgIDxidXR0b24gY2xhc3M9XCJidG4gdG9wLTAgZW5kLTAgYnRuIHAtMCBtcy0yIHRleHQtd2hpdGVcIiAoY2xpY2spPVwib25SZW1vdmVUb2FzdCh0b2FzdClcIj48aSBjbGFzcz1cImZhcyBmYS10aW1lc1wiPjwvaT48L2J1dHRvbj5cclxuICAgICAgICA8L2Rpdj5cclxuICAgICAgICA8ZGl2IGNsYXNzPVwiZC1mbGV4IGFsaWduLWl0ZW1zLWNlbnRlciBqdXN0aWZ5LWNvbnRlbnQtYmV0d2VlbiBtdC0xXCI+XHJcbiAgICAgICAgICAgIDxkaXY+e3t0b2FzdC5tZXNzYWdlfHRyYW5zbGF0ZX19PC9kaXY+XHJcbiAgICAgICAgICAgIDxidXR0b24gICpuZ0lmPVwiIXRvYXN0LmhlYWRlclwiIGNsYXNzPVwiYnRuIHAtMCBtcy0yIHRleHQtd2hpdGVcIiAoY2xpY2spPVwib25SZW1vdmVUb2FzdCh0b2FzdClcIj48aSBjbGFzcz1cImZhcyBmYS10aW1lc1wiPjwvaT48L2J1dHRvbj5cclxuICAgICAgICA8L2Rpdj5cclxuICAgIDwvZGl2PlxyXG48L2Rpdj4iXX0=
|
|
@@ -1,35 +1,43 @@
|
|
|
1
1
|
import { Injectable } from "@angular/core";
|
|
2
|
+
import { of, Subject } from "rxjs";
|
|
3
|
+
import { delay } from "rxjs/operators";
|
|
2
4
|
import { AdbToast } from "./adb-toast";
|
|
3
5
|
import * as i0 from "@angular/core";
|
|
4
6
|
export class AdbToastService {
|
|
5
7
|
constructor(componentFactoryResolver, rendererFactory, appRef, injector) {
|
|
6
8
|
this.componentFactoryResolver = componentFactoryResolver;
|
|
9
|
+
this.rendererFactory = rendererFactory;
|
|
7
10
|
this.appRef = appRef;
|
|
8
11
|
this.injector = injector;
|
|
9
|
-
this.
|
|
12
|
+
this.toasts = new Array();
|
|
13
|
+
this.toastsSubject = new Subject();
|
|
14
|
+
this.$toasts = this.toastsSubject.asObservable();
|
|
10
15
|
}
|
|
11
|
-
|
|
16
|
+
add(toastMessage, time = 4000) {
|
|
17
|
+
this.addContainer();
|
|
18
|
+
toastMessage.type = toastMessage.type ? toastMessage.type : ToastType.Success;
|
|
19
|
+
toastMessage.index = this.toasts.length;
|
|
20
|
+
toastMessage.delay = of(toastMessage).pipe(delay(time)).subscribe(toast => {
|
|
21
|
+
this.remove(toast);
|
|
22
|
+
});
|
|
23
|
+
this.toasts.push(toastMessage);
|
|
24
|
+
this.toastsSubject.next(this.toasts);
|
|
25
|
+
}
|
|
26
|
+
remove(toast) {
|
|
27
|
+
this.toasts = this.toasts?.filter(x => x.index !== toast.index);
|
|
28
|
+
this.toastsSubject.next(this.toasts);
|
|
29
|
+
}
|
|
30
|
+
addContainer() {
|
|
12
31
|
if (!this.container) {
|
|
32
|
+
this.renderer = this.rendererFactory.createRenderer(null, null);
|
|
33
|
+
//create container i top
|
|
13
34
|
this.container = this.renderer.createElement('div');
|
|
14
|
-
this.container.setAttribute('adb-toast-container', '');
|
|
15
|
-
this.container.classList.add('position-fixed', 'bottom-0', 'end-0');
|
|
16
35
|
this.renderer.appendChild(document.body, this.container);
|
|
36
|
+
let componentRef = this.componentFactoryResolver.resolveComponentFactory(AdbToast).create(this.injector);
|
|
37
|
+
this.appRef.attachView(componentRef.hostView);
|
|
38
|
+
const element = componentRef.hostView.rootNodes[0];
|
|
39
|
+
this.container.prepend(element);
|
|
17
40
|
}
|
|
18
|
-
this.createToast(model);
|
|
19
|
-
}
|
|
20
|
-
createToast(model) {
|
|
21
|
-
if (!model.state)
|
|
22
|
-
model.state = 'info';
|
|
23
|
-
if (!model.timeInMs)
|
|
24
|
-
model.timeInMs = 4000;
|
|
25
|
-
let componentRef = this.componentFactoryResolver.resolveComponentFactory(AdbToast).create(this.injector);
|
|
26
|
-
componentRef.instance.model = model;
|
|
27
|
-
this.appRef.attachView(componentRef.hostView);
|
|
28
|
-
const element = componentRef.hostView.rootNodes[0];
|
|
29
|
-
this.container.prepend(element);
|
|
30
|
-
setTimeout(() => {
|
|
31
|
-
// element.remove();
|
|
32
|
-
}, model.timeInMs);
|
|
33
41
|
}
|
|
34
42
|
}
|
|
35
43
|
/** @nocollapse */ AdbToastService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.8", ngImport: i0, type: AdbToastService, deps: [{ token: i0.ComponentFactoryResolver }, { token: i0.RendererFactory2 }, { token: i0.ApplicationRef }, { token: i0.Injector }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
@@ -37,4 +45,10 @@ export class AdbToastService {
|
|
|
37
45
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.8", ngImport: i0, type: AdbToastService, decorators: [{
|
|
38
46
|
type: Injectable
|
|
39
47
|
}], ctorParameters: function () { return [{ type: i0.ComponentFactoryResolver }, { type: i0.RendererFactory2 }, { type: i0.ApplicationRef }, { type: i0.Injector }]; } });
|
|
40
|
-
|
|
48
|
+
export var ToastType;
|
|
49
|
+
(function (ToastType) {
|
|
50
|
+
ToastType[ToastType["Info"] = 1] = "Info";
|
|
51
|
+
ToastType[ToastType["Success"] = 2] = "Success";
|
|
52
|
+
ToastType[ToastType["Warn"] = 3] = "Warn";
|
|
53
|
+
})(ToastType || (ToastType = {}));
|
|
54
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWRiLXRvYXN0LnNlcnZpY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9hcnRkYXRhLXNoYXJlZC9zcmMvbGliL2NvbXBvbmVudHMvYWRiLXRvYXN0L2FkYi10b2FzdC5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBNkQsVUFBVSxFQUF5QyxNQUFNLGVBQWUsQ0FBQztBQUM3SSxPQUFPLEVBQWMsRUFBRSxFQUFFLE9BQU8sRUFBRSxNQUFNLE1BQU0sQ0FBQztBQUMvQyxPQUFPLEVBQUUsS0FBSyxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFDdkMsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGFBQWEsQ0FBQzs7QUFFdkMsTUFBTSxPQUFPLGVBQWU7SUFReEIsWUFDWSx3QkFBa0QsRUFDbEQsZUFBaUMsRUFDakMsTUFBc0IsRUFDdEIsUUFBa0I7UUFIbEIsNkJBQXdCLEdBQXhCLHdCQUF3QixDQUEwQjtRQUNsRCxvQkFBZSxHQUFmLGVBQWUsQ0FBa0I7UUFDakMsV0FBTSxHQUFOLE1BQU0sQ0FBZ0I7UUFDdEIsYUFBUSxHQUFSLFFBQVEsQ0FBVTtRQVh0QixXQUFNLEdBQUcsSUFBSSxLQUFLLEVBQWdCLENBQUM7UUFDbkMsa0JBQWEsR0FBRyxJQUFJLE9BQU8sRUFBa0IsQ0FBQztRQUN0RCxZQUFPLEdBQStCLElBQUksQ0FBQyxhQUFhLENBQUMsWUFBWSxFQUFFLENBQUM7SUFXeEUsQ0FBQztJQUVELEdBQUcsQ0FBQyxZQUEwQixFQUFFLElBQUksR0FBRyxJQUFJO1FBQ3ZDLElBQUksQ0FBQyxZQUFZLEVBQUUsQ0FBQztRQUNwQixZQUFZLENBQUMsSUFBSSxHQUFHLFlBQVksQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLFlBQVksQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLFNBQVMsQ0FBQyxPQUFPLENBQUM7UUFDOUUsWUFBWSxDQUFDLEtBQUssR0FBRyxJQUFJLENBQUMsTUFBTSxDQUFDLE1BQU0sQ0FBQztRQUN4QyxZQUFZLENBQUMsS0FBSyxHQUFHLEVBQUUsQ0FBQyxZQUFZLENBQUMsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsU0FBUyxDQUFDLEtBQUssQ0FBQyxFQUFFO1lBQ3RFLElBQUksQ0FBQyxNQUFNLENBQUMsS0FBSyxDQUFDLENBQUM7UUFDdkIsQ0FBQyxDQUFDLENBQUM7UUFDSCxJQUFJLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxZQUFZLENBQUMsQ0FBQztRQUMvQixJQUFJLENBQUMsYUFBYSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLENBQUM7SUFDekMsQ0FBQztJQUVELE1BQU0sQ0FBQyxLQUFtQjtRQUN0QixJQUFJLENBQUMsTUFBTSxHQUFHLElBQUksQ0FBQyxNQUFNLEVBQUUsTUFBTSxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDLEtBQUssS0FBSyxLQUFLLENBQUMsS0FBSyxDQUFDLENBQUM7UUFDaEUsSUFBSSxDQUFDLGFBQWEsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxDQUFDO0lBQ3pDLENBQUM7SUFFTyxZQUFZO1FBQ2hCLElBQUksQ0FBQyxJQUFJLENBQUMsU0FBUyxFQUFFO1lBQ2pCLElBQUksQ0FBQyxRQUFRLEdBQUcsSUFBSSxDQUFDLGVBQWUsQ0FBQyxjQUFjLENBQUMsSUFBSSxFQUFFLElBQUksQ0FBQyxDQUFDO1lBQ2hFLHdCQUF3QjtZQUN4QixJQUFJLENBQUMsU0FBUyxHQUFHLElBQUksQ0FBQyxRQUFRLENBQUMsYUFBYSxDQUFDLEtBQUssQ0FBQyxDQUFDO1lBQ3BELElBQUksQ0FBQyxRQUFRLENBQUMsV0FBVyxDQUFDLFFBQVEsQ0FBQyxJQUFJLEVBQUUsSUFBSSxDQUFDLFNBQVMsQ0FBQyxDQUFDO1lBQ3pELElBQUksWUFBWSxHQUFHLElBQUksQ0FBQyx3QkFBd0IsQ0FBQyx1QkFBdUIsQ0FBQyxRQUFRLENBQUMsQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLFFBQVEsQ0FBQyxDQUFDO1lBQ3pHLElBQUksQ0FBQyxNQUFNLENBQUMsVUFBVSxDQUFDLFlBQVksQ0FBQyxRQUFRLENBQUMsQ0FBQztZQUM5QyxNQUFNLE9BQU8sR0FBSSxZQUFZLENBQUMsUUFBaUMsQ0FBQyxTQUFTLENBQUMsQ0FBQyxDQUFnQixDQUFDO1lBQzVGLElBQUksQ0FBQyxTQUFTLENBQUMsT0FBTyxDQUFDLE9BQU8sQ0FBQyxDQUFDO1NBQ25DO0lBQ0wsQ0FBQzs7K0hBM0NRLGVBQWU7bUlBQWYsZUFBZTsyRkFBZixlQUFlO2tCQUQzQixVQUFVOztBQXFEWCxNQUFNLENBQU4sSUFBWSxTQUlYO0FBSkQsV0FBWSxTQUFTO0lBQ2pCLHlDQUFRLENBQUE7SUFDUiwrQ0FBVyxDQUFBO0lBQ1gseUNBQVEsQ0FBQTtBQUNaLENBQUMsRUFKVyxTQUFTLEtBQVQsU0FBUyxRQUlwQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEFwcGxpY2F0aW9uUmVmLCBDb21wb25lbnRGYWN0b3J5UmVzb2x2ZXIsIEVtYmVkZGVkVmlld1JlZiwgSW5qZWN0YWJsZSwgSW5qZWN0b3IsIFJlbmRlcmVyMiwgUmVuZGVyZXJGYWN0b3J5MiB9IGZyb20gXCJAYW5ndWxhci9jb3JlXCI7XHJcbmltcG9ydCB7IE9ic2VydmFibGUsIG9mLCBTdWJqZWN0IH0gZnJvbSBcInJ4anNcIjtcclxuaW1wb3J0IHsgZGVsYXkgfSBmcm9tIFwicnhqcy9vcGVyYXRvcnNcIjtcclxuaW1wb3J0IHsgQWRiVG9hc3QgfSBmcm9tIFwiLi9hZGItdG9hc3RcIjtcclxuQEluamVjdGFibGUoKVxyXG5leHBvcnQgY2xhc3MgQWRiVG9hc3RTZXJ2aWNlIHtcclxuICAgIHByaXZhdGUgdG9hc3RzID0gbmV3IEFycmF5PFRvYXN0TWVzc2FnZT4oKTtcclxuICAgIHByaXZhdGUgdG9hc3RzU3ViamVjdCA9IG5ldyBTdWJqZWN0PFRvYXN0TWVzc2FnZVtdPigpO1xyXG4gICAgJHRvYXN0czogT2JzZXJ2YWJsZTxUb2FzdE1lc3NhZ2VbXT4gPSB0aGlzLnRvYXN0c1N1YmplY3QuYXNPYnNlcnZhYmxlKCk7XHJcbiAgICByZW5kZXJlcjogUmVuZGVyZXIyO1xyXG4gICAgZG9tRWxlbWVudDogSFRNTEVsZW1lbnQ7XHJcbiAgICBjb250YWluZXI6IGFueTtcclxuXHJcbiAgICBjb25zdHJ1Y3RvcihcclxuICAgICAgICBwcml2YXRlIGNvbXBvbmVudEZhY3RvcnlSZXNvbHZlcjogQ29tcG9uZW50RmFjdG9yeVJlc29sdmVyLFxyXG4gICAgICAgIHByaXZhdGUgcmVuZGVyZXJGYWN0b3J5OiBSZW5kZXJlckZhY3RvcnkyLFxyXG4gICAgICAgIHByaXZhdGUgYXBwUmVmOiBBcHBsaWNhdGlvblJlZixcclxuICAgICAgICBwcml2YXRlIGluamVjdG9yOiBJbmplY3Rvcikge1xyXG5cclxuICAgIH1cclxuXHJcbiAgICBhZGQodG9hc3RNZXNzYWdlOiBUb2FzdE1lc3NhZ2UsIHRpbWUgPSA0MDAwKTogdm9pZCB7XHJcbiAgICAgICAgdGhpcy5hZGRDb250YWluZXIoKTtcclxuICAgICAgICB0b2FzdE1lc3NhZ2UudHlwZSA9IHRvYXN0TWVzc2FnZS50eXBlID8gdG9hc3RNZXNzYWdlLnR5cGUgOiBUb2FzdFR5cGUuU3VjY2VzcztcclxuICAgICAgICB0b2FzdE1lc3NhZ2UuaW5kZXggPSB0aGlzLnRvYXN0cy5sZW5ndGg7XHJcbiAgICAgICAgdG9hc3RNZXNzYWdlLmRlbGF5ID0gb2YodG9hc3RNZXNzYWdlKS5waXBlKGRlbGF5KHRpbWUpKS5zdWJzY3JpYmUodG9hc3QgPT4ge1xyXG4gICAgICAgICAgICB0aGlzLnJlbW92ZSh0b2FzdCk7XHJcbiAgICAgICAgfSk7XHJcbiAgICAgICAgdGhpcy50b2FzdHMucHVzaCh0b2FzdE1lc3NhZ2UpO1xyXG4gICAgICAgIHRoaXMudG9hc3RzU3ViamVjdC5uZXh0KHRoaXMudG9hc3RzKTtcclxuICAgIH1cclxuXHJcbiAgICByZW1vdmUodG9hc3Q6IFRvYXN0TWVzc2FnZSkge1xyXG4gICAgICAgIHRoaXMudG9hc3RzID0gdGhpcy50b2FzdHM/LmZpbHRlcih4ID0+IHguaW5kZXggIT09IHRvYXN0LmluZGV4KTtcclxuICAgICAgICB0aGlzLnRvYXN0c1N1YmplY3QubmV4dCh0aGlzLnRvYXN0cyk7XHJcbiAgICB9XHJcblxyXG4gICAgcHJpdmF0ZSBhZGRDb250YWluZXIoKTogdm9pZCB7XHJcbiAgICAgICAgaWYgKCF0aGlzLmNvbnRhaW5lcikge1xyXG4gICAgICAgICAgICB0aGlzLnJlbmRlcmVyID0gdGhpcy5yZW5kZXJlckZhY3RvcnkuY3JlYXRlUmVuZGVyZXIobnVsbCwgbnVsbCk7XHJcbiAgICAgICAgICAgIC8vY3JlYXRlIGNvbnRhaW5lciBpIHRvcFxyXG4gICAgICAgICAgICB0aGlzLmNvbnRhaW5lciA9IHRoaXMucmVuZGVyZXIuY3JlYXRlRWxlbWVudCgnZGl2Jyk7XHJcbiAgICAgICAgICAgIHRoaXMucmVuZGVyZXIuYXBwZW5kQ2hpbGQoZG9jdW1lbnQuYm9keSwgdGhpcy5jb250YWluZXIpO1xyXG4gICAgICAgICAgICBsZXQgY29tcG9uZW50UmVmID0gdGhpcy5jb21wb25lbnRGYWN0b3J5UmVzb2x2ZXIucmVzb2x2ZUNvbXBvbmVudEZhY3RvcnkoQWRiVG9hc3QpLmNyZWF0ZSh0aGlzLmluamVjdG9yKTtcclxuICAgICAgICAgICAgdGhpcy5hcHBSZWYuYXR0YWNoVmlldyhjb21wb25lbnRSZWYuaG9zdFZpZXcpO1xyXG4gICAgICAgICAgICBjb25zdCBlbGVtZW50ID0gKGNvbXBvbmVudFJlZi5ob3N0VmlldyBhcyBFbWJlZGRlZFZpZXdSZWY8YW55Pikucm9vdE5vZGVzWzBdIGFzIEhUTUxFbGVtZW50O1xyXG4gICAgICAgICAgICB0aGlzLmNvbnRhaW5lci5wcmVwZW5kKGVsZW1lbnQpO1xyXG4gICAgICAgIH1cclxuICAgIH1cclxufVxyXG5leHBvcnQgaW50ZXJmYWNlIFRvYXN0TWVzc2FnZSB7XHJcbiAgICBoZWFkZXI/OiBzdHJpbmcsXHJcbiAgICBtZXNzYWdlOiBzdHJpbmcsXHJcbiAgICB0eXBlPzogVG9hc3RUeXBlLFxyXG4gICAgaW5kZXg/OiBudW1iZXI7XHJcbiAgICBkZWxheT86IGFueTtcclxufVxyXG5leHBvcnQgZW51bSBUb2FzdFR5cGUge1xyXG4gICAgSW5mbyA9IDEsXHJcbiAgICBTdWNjZXNzID0gMixcclxuICAgIFdhcm4gPSAzXHJcbn0iXX0=
|
|
@@ -18,6 +18,7 @@ export class AdbDatePickerDirective {
|
|
|
18
18
|
this.subscriptions = new Subscription();
|
|
19
19
|
this.format = 'yyyy-MM-dd';
|
|
20
20
|
this.settings = null;
|
|
21
|
+
this.pickOnly = true;
|
|
21
22
|
//ControlValueAccessor
|
|
22
23
|
this.onChange = () => { };
|
|
23
24
|
this.onTouched = () => { };
|
|
@@ -35,6 +36,7 @@ export class AdbDatePickerDirective {
|
|
|
35
36
|
this.id = this.getId();
|
|
36
37
|
viewRef.instance.id = this.id;
|
|
37
38
|
viewRef.instance.selectDate.subscribe((date) => {
|
|
39
|
+
this.elementRef.nativeElement.classList.remove('ng-invalid');
|
|
38
40
|
this.renderer.setProperty(this.elementRef.nativeElement, 'value', formatDate(date, this.format, this.translate.currentLang));
|
|
39
41
|
this.onChange(date);
|
|
40
42
|
this.initialDate = date;
|
|
@@ -45,22 +47,32 @@ export class AdbDatePickerDirective {
|
|
|
45
47
|
});
|
|
46
48
|
this.adbDatePickerService.viewRef = viewRef;
|
|
47
49
|
}
|
|
50
|
+
onKeyup(event) {
|
|
51
|
+
const date = AdbDatePickerDirective.tryParse(event.target.value, this.format);
|
|
52
|
+
if (date) {
|
|
53
|
+
this.onChange(date);
|
|
54
|
+
this.initialDate = date;
|
|
55
|
+
}
|
|
56
|
+
}
|
|
48
57
|
onHide() {
|
|
49
58
|
this.adbDatePickerService.viewRef = null;
|
|
50
59
|
this.viewContainerRef.detach();
|
|
51
60
|
this.viewContainerRef.clear();
|
|
52
61
|
}
|
|
62
|
+
onBlur() {
|
|
63
|
+
const date = AdbDatePickerDirective.tryParse(this.elementRef.nativeElement.value, this.format);
|
|
64
|
+
if (!date) {
|
|
65
|
+
this.elementRef.nativeElement.classList.add('ng-invalid');
|
|
66
|
+
}
|
|
67
|
+
else {
|
|
68
|
+
this.elementRef.nativeElement.classList.remove('ng-invalid');
|
|
69
|
+
}
|
|
70
|
+
}
|
|
53
71
|
handleKeyboardEvent(event) {
|
|
54
72
|
if (event.key === 'Tab') {
|
|
55
73
|
this.onHide();
|
|
56
74
|
}
|
|
57
|
-
else if (
|
|
58
|
-
this.initialDate = null;
|
|
59
|
-
this.renderer.setProperty(this.elementRef.nativeElement, 'value', null);
|
|
60
|
-
this.onChange();
|
|
61
|
-
this.onHide();
|
|
62
|
-
}
|
|
63
|
-
else {
|
|
75
|
+
else if (this.pickOnly) {
|
|
64
76
|
event.preventDefault();
|
|
65
77
|
}
|
|
66
78
|
}
|
|
@@ -117,12 +129,16 @@ export class AdbDatePickerDirective {
|
|
|
117
129
|
return null;
|
|
118
130
|
}
|
|
119
131
|
}
|
|
132
|
+
static tryParse(dateString, format) {
|
|
133
|
+
const parsed = parseISO(dateString);
|
|
134
|
+
return isValid(parsed) && dateString?.length === 10 ? parsed : null;
|
|
135
|
+
}
|
|
120
136
|
getId() {
|
|
121
137
|
return '' + Math.floor(Math.random() * Date.now());
|
|
122
138
|
}
|
|
123
139
|
}
|
|
124
140
|
/** @nocollapse */ AdbDatePickerDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.8", ngImport: i0, type: AdbDatePickerDirective, deps: [{ token: i0.ViewContainerRef }, { token: i0.Renderer2 }, { token: i0.ElementRef }, { token: i1.AdbDatePickerService }, { token: i2.TranslateService }], target: i0.ɵɵFactoryTarget.Directive });
|
|
125
|
-
/** @nocollapse */ AdbDatePickerDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.3.8", type: AdbDatePickerDirective, selector: "input[adbDatepicker]", inputs: { format: "format", toLeft: "toLeft", settings: "settings" }, host: { listeners: { "click": "onClick()", "keyup.esc": "onHide()", "keydown": "handleKeyboardEvent($event)", "document:click": "onCheckOutSideClick($event.target)" }, properties: { "autocomplete": "this.autocomplete" } }, providers: [{
|
|
141
|
+
/** @nocollapse */ AdbDatePickerDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.3.8", type: AdbDatePickerDirective, selector: "input[adbDatepicker]", inputs: { format: "format", toLeft: "toLeft", settings: "settings", pickOnly: "pickOnly" }, host: { listeners: { "click": "onClick()", "keyup": "onKeyup($event)", "keyup.esc": "onHide()", "blur": "onBlur()", "keydown": "handleKeyboardEvent($event)", "document:click": "onCheckOutSideClick($event.target)" }, properties: { "autocomplete": "this.autocomplete" } }, providers: [{
|
|
126
142
|
provide: NG_VALUE_ACCESSOR, useExisting: forwardRef((() => AdbDatePickerDirective)),
|
|
127
143
|
multi: true
|
|
128
144
|
}], ngImport: i0 });
|
|
@@ -144,12 +160,20 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.8", ngImpor
|
|
|
144
160
|
type: Input
|
|
145
161
|
}], settings: [{
|
|
146
162
|
type: Input
|
|
163
|
+
}], pickOnly: [{
|
|
164
|
+
type: Input
|
|
147
165
|
}], onClick: [{
|
|
148
166
|
type: HostListener,
|
|
149
167
|
args: ['click']
|
|
168
|
+
}], onKeyup: [{
|
|
169
|
+
type: HostListener,
|
|
170
|
+
args: ['keyup', ['$event']]
|
|
150
171
|
}], onHide: [{
|
|
151
172
|
type: HostListener,
|
|
152
173
|
args: ['keyup.esc']
|
|
174
|
+
}], onBlur: [{
|
|
175
|
+
type: HostListener,
|
|
176
|
+
args: ['blur']
|
|
153
177
|
}], handleKeyboardEvent: [{
|
|
154
178
|
type: HostListener,
|
|
155
179
|
args: ['keydown', ['$event']]
|
|
@@ -157,4 +181,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.8", ngImpor
|
|
|
157
181
|
type: HostListener,
|
|
158
182
|
args: ['document:click', ['$event.target']]
|
|
159
183
|
}] } });
|
|
160
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"adb-date-picker.directive.js","sourceRoot":"","sources":["../../../../../../projects/artdata-shared/src/lib/components/date-picker/adb-date-picker.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { formatDate } from \"@angular/common\";\r\nimport { Directive, ElementRef, forwardRef, HostBinding, HostListener, Input, OnDestroy, OnInit, Renderer2, ViewContainerRef } from \"@angular/core\";\r\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR} from \"@angular/forms\";\r\nimport { TranslateService } from \"@ngx-translate/core\";\r\nimport { isValid, parse, parseISO } from \"date-fns\";\r\nimport { Subscription } from \"rxjs\";\r\nimport { AdbDatePickerComponent } from \"./adb-date-picker.component\";\r\nimport { AdbDatePickerService } from \"./adb-date-picker.service\";\r\n\r\n@Directive({\r\n    selector: `input[adbDatepicker]`,\r\n    providers: [{\r\n        provide: NG_VALUE_ACCESSOR, useExisting: forwardRef(() => AdbDatePickerDirective),\r\n        multi: true\r\n    }]\r\n})\r\nexport class AdbDatePickerDirective implements ControlValueAccessor, OnInit, OnDestroy {\r\n    @HostBinding('autocomplete') autocomplete = 'off';\r\n    private subscriptions = new Subscription();\r\n    @Input() format = 'yyyy-MM-dd';\r\n    @Input() toLeft: boolean;\r\n    @Input() settings: { maxDate?: Date | string, minDate?: Date | string } = null;\r\n    id: string;\r\n    initialDate: Date;\r\n\r\n    constructor(\r\n        private viewContainerRef: ViewContainerRef,\r\n        private renderer: Renderer2,\r\n        private elementRef: ElementRef,\r\n        private adbDatePickerService: AdbDatePickerService,\r\n        public translate: TranslateService) {\r\n\r\n    }\r\n\r\n    ngOnInit(): void {\r\n    }\r\n\r\n    @HostListener('click')\r\n    onClick(): void {\r\n        if (this.adbDatePickerService.viewRef) {\r\n            this.adbDatePickerService.viewRef.destroy();\r\n        }\r\n        const viewRef = this.viewContainerRef.createComponent<AdbDatePickerComponent>(AdbDatePickerComponent);\r\n        viewRef.instance.settings = this.settings;\r\n        viewRef.instance.toLeft = this.toLeft;\r\n        viewRef.instance.initialDate = this.initialDate;\r\n        this.id = this.getId();\r\n        viewRef.instance.id = this.id;\r\n        viewRef.instance.selectDate.subscribe((date) => {\r\n            this.renderer.setProperty(this.elementRef.nativeElement, 'value', formatDate(date, this.format, this.translate.currentLang));\r\n            this.onChange(date);\r\n            this.initialDate = date;\r\n            this.onHide();\r\n        });\r\n        viewRef.instance.hide.subscribe(() => {\r\n            this.onHide();\r\n        });\r\n        this.adbDatePickerService.viewRef = viewRef;\r\n    }\r\n\r\n    @HostListener('keyup.esc')\r\n    onHide(): void {\r\n        this.adbDatePickerService.viewRef = null;\r\n        this.viewContainerRef.detach();\r\n        this.viewContainerRef.clear();\r\n    }\r\n\r\n    @HostListener('keydown', ['$event'])\r\n    handleKeyboardEvent(event: KeyboardEvent) {\r\n        if (event.key === 'Tab') {\r\n            this.onHide();\r\n        } else if (event.key === 'Backspace') {\r\n            this.initialDate = null;\r\n            this.renderer.setProperty(this.elementRef.nativeElement, 'value', null);\r\n            this.onChange();\r\n            this.onHide();\r\n        }\r\n         else {\r\n            event.preventDefault();\r\n        }\r\n    }\r\n\r\n\r\n    @HostListener('document:click', ['$event.target'])\r\n    onCheckOutSideClick(target: any): void {\r\n        const nativeElement = this.adbDatePickerService.viewRef?.instance.elementRef.nativeElement ?? null;\r\n        if (nativeElement) {\r\n            if (nativeElement.id === this.id) {\r\n                if (!target.hasAttribute('adbdatepicker')) {\r\n                    const clickedInside = nativeElement.contains(target);\r\n                    if (!clickedInside) {\r\n                        this.onHide();\r\n                    }\r\n                }\r\n            }\r\n        }\r\n    }\r\n\r\n    ngOnDestroy(): void {\r\n        this.subscriptions.unsubscribe();\r\n    }\r\n\r\n    //ControlValueAccessor\r\n    onChange: any = () => { };\r\n    onTouched: any = () => { };\r\n\r\n    writeValue(value: Date | string): void {\r\n        if (value) {\r\n            this.initialDate = AdbDatePickerDirective.parseDate(value);\r\n            if (this.initialDate) {\r\n                this.renderer.setProperty(this.elementRef.nativeElement, 'value', formatDate(this.initialDate, this.format, this.translate.currentLang));\r\n            }\r\n        } else {\r\n            this.initialDate = null;\r\n            this.renderer.setProperty(this.elementRef.nativeElement, 'value', '');\r\n        }\r\n    }\r\n\r\n    registerOnChange(fn: any): void {\r\n        this.onChange = fn;\r\n    }\r\n\r\n    registerOnTouched(fn: any): void {\r\n        this.onTouched = fn;\r\n    }\r\n\r\n    setDisabledState?(isDisabled: boolean): void {\r\n        this.viewContainerRef.clear();\r\n    }\r\n\r\n    static parseDate(value: Date | string): Date {\r\n        if (typeof value === 'string') {\r\n            if (isValid(parseISO(value))) {\r\n                return parseISO(value);\r\n            } else {\r\n                return null;\r\n            }\r\n        } else if (value instanceof Date) {\r\n            return value;\r\n        } else {\r\n            return null;\r\n        }\r\n    }\r\n\r\n    private getId(): string {\r\n        return '' + Math.floor(Math.random() * Date.now())\r\n    }\r\n}"]}
|
|
184
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"adb-date-picker.directive.js","sourceRoot":"","sources":["../../../../../../projects/artdata-shared/src/lib/components/date-picker/adb-date-picker.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { formatDate } from \"@angular/common\";\r\nimport { Directive, ElementRef, forwardRef, HostBinding, HostListener, Input, OnChanges, OnDestroy, OnInit, Renderer2, SimpleChanges, ViewContainerRef } from \"@angular/core\";\r\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from \"@angular/forms\";\r\nimport { TranslateService } from \"@ngx-translate/core\";\r\nimport { isValid, parse, parseISO } from \"date-fns\";\r\nimport { Subscription } from \"rxjs\";\r\nimport { AdbDatePickerComponent } from \"./adb-date-picker.component\";\r\nimport { AdbDatePickerService } from \"./adb-date-picker.service\";\r\n\r\n@Directive({\r\n    selector: `input[adbDatepicker]`,\r\n    providers: [{\r\n        provide: NG_VALUE_ACCESSOR, useExisting: forwardRef(() => AdbDatePickerDirective),\r\n        multi: true\r\n    }]\r\n})\r\nexport class AdbDatePickerDirective implements ControlValueAccessor, OnInit, OnDestroy {\r\n    @HostBinding('autocomplete') autocomplete = 'off';\r\n    private subscriptions = new Subscription();\r\n    @Input() format = 'yyyy-MM-dd';\r\n    @Input() toLeft: boolean;\r\n    @Input() settings: { maxDate?: Date | string, minDate?: Date | string } = null;\r\n    @Input() pickOnly = true;\r\n    id: string;\r\n    initialDate: Date;\r\n\r\n    constructor(\r\n        private viewContainerRef: ViewContainerRef,\r\n        private renderer: Renderer2,\r\n        private elementRef: ElementRef,\r\n        private adbDatePickerService: AdbDatePickerService,\r\n        public translate: TranslateService) {\r\n\r\n    }\r\n\r\n    ngOnInit(): void {\r\n    }\r\n\r\n    @HostListener('click')\r\n    onClick(): void {\r\n        if (this.adbDatePickerService.viewRef) {\r\n            this.adbDatePickerService.viewRef.destroy();\r\n        }\r\n        const viewRef = this.viewContainerRef.createComponent<AdbDatePickerComponent>(AdbDatePickerComponent);\r\n        viewRef.instance.settings = this.settings;\r\n        viewRef.instance.toLeft = this.toLeft;\r\n        viewRef.instance.initialDate = this.initialDate;\r\n        this.id = this.getId();\r\n        viewRef.instance.id = this.id;\r\n        viewRef.instance.selectDate.subscribe((date) => {\r\n            this.elementRef.nativeElement.classList.remove('ng-invalid');\r\n            this.renderer.setProperty(this.elementRef.nativeElement, 'value', formatDate(date, this.format, this.translate.currentLang));\r\n            this.onChange(date);\r\n            this.initialDate = date;\r\n            this.onHide();\r\n        });\r\n        viewRef.instance.hide.subscribe(() => {\r\n            this.onHide();\r\n        });\r\n        this.adbDatePickerService.viewRef = viewRef;\r\n    }\r\n\r\n    @HostListener('keyup', ['$event']) public onKeyup(event: KeyboardEvent): void {\r\n        const date = AdbDatePickerDirective.tryParse((event.target as HTMLInputElement).value, this.format);\r\n        if (date) {\r\n            this.onChange(date);\r\n            this.initialDate = date;\r\n        }\r\n    }\r\n\r\n    @HostListener('keyup.esc')\r\n    onHide(): void {\r\n        this.adbDatePickerService.viewRef = null;\r\n        this.viewContainerRef.detach();\r\n        this.viewContainerRef.clear();\r\n    }\r\n\r\n    @HostListener('blur')\r\n    onBlur(): void {\r\n        const date = AdbDatePickerDirective.tryParse((this.elementRef.nativeElement as HTMLInputElement).value, this.format);\r\n        if (!date) {\r\n            this.elementRef.nativeElement.classList.add('ng-invalid');\r\n        } else {\r\n            this.elementRef.nativeElement.classList.remove('ng-invalid');\r\n        }\r\n    }\r\n\r\n    @HostListener('keydown', ['$event'])\r\n    handleKeyboardEvent(event: KeyboardEvent) {\r\n        if (event.key === 'Tab') {\r\n            this.onHide();\r\n        }\r\n        else if (this.pickOnly) {\r\n            event.preventDefault();\r\n        }\r\n    }\r\n\r\n\r\n    @HostListener('document:click', ['$event.target'])\r\n    onCheckOutSideClick(target: any): void {\r\n        const nativeElement = this.adbDatePickerService.viewRef?.instance.elementRef.nativeElement ?? null;\r\n        if (nativeElement) {\r\n            if (nativeElement.id === this.id) {\r\n                if (!target.hasAttribute('adbdatepicker')) {\r\n                    const clickedInside = nativeElement.contains(target);\r\n                    if (!clickedInside) {\r\n                        this.onHide();\r\n                    }\r\n                }\r\n            }\r\n        }\r\n    }\r\n\r\n    ngOnDestroy(): void {\r\n        this.subscriptions.unsubscribe();\r\n    }\r\n\r\n    //ControlValueAccessor\r\n    onChange: any = () => { };\r\n    onTouched: any = () => { };\r\n\r\n    writeValue(value: Date | string): void {\r\n        if (value) {\r\n            this.initialDate = AdbDatePickerDirective.parseDate(value);\r\n            if (this.initialDate) {\r\n                this.renderer.setProperty(this.elementRef.nativeElement, 'value', formatDate(this.initialDate, this.format, this.translate.currentLang));\r\n            }\r\n        } else {\r\n            this.initialDate = null;\r\n            this.renderer.setProperty(this.elementRef.nativeElement, 'value', '');\r\n        }\r\n    }\r\n\r\n    registerOnChange(fn: any): void {\r\n        this.onChange = fn;\r\n    }\r\n\r\n    registerOnTouched(fn: any): void {\r\n        this.onTouched = fn;\r\n    }\r\n\r\n    setDisabledState?(isDisabled: boolean): void {\r\n        this.viewContainerRef.clear();\r\n    }\r\n\r\n    static parseDate(value: Date | string): Date {\r\n        if (typeof value === 'string') {\r\n            if (isValid(parseISO(value))) {\r\n                return parseISO(value);\r\n            } else {\r\n                return null;\r\n            }\r\n        } else if (value instanceof Date) {\r\n            return value;\r\n        } else {\r\n            return null;\r\n        }\r\n    }\r\n\r\n    static tryParse(dateString: string, format: string): Date {\r\n        const parsed = parseISO(dateString);\r\n        return isValid(parsed) && dateString?.length === 10 ? parsed : null;\r\n    }\r\n\r\n    private getId(): string {\r\n        return '' + Math.floor(Math.random() * Date.now())\r\n    }\r\n}"]}
|
package/fesm2015/adb-shared.mjs
CHANGED
|
@@ -4,13 +4,14 @@ import * as i0 from '@angular/core';
|
|
|
4
4
|
import { Injectable, Inject, EventEmitter, Component, Output, Input, Directive, HostListener, NgModule, HostBinding, Pipe, forwardRef } from '@angular/core';
|
|
5
5
|
import * as i1$1 from '@ngx-translate/core';
|
|
6
6
|
import { TranslateModule } from '@ngx-translate/core';
|
|
7
|
-
import { Subscription, Subject } from 'rxjs';
|
|
7
|
+
import { Subscription, Subject, of } from 'rxjs';
|
|
8
8
|
import * as i1 from '@angular/common/http';
|
|
9
9
|
import { HttpClientModule } from '@angular/common/http';
|
|
10
10
|
import * as i1$2 from '@angular/router';
|
|
11
11
|
import { RouterModule } from '@angular/router';
|
|
12
12
|
import { isValid, parseISO, startOfDay, subYears, endOfDay, addYears, getMonth, subMonths, addMonths, isSameYear, startOfMonth, endOfMonth, eachWeekOfInterval, getISOWeek, addDays, eachDayOfInterval, getHours, getMinutes, isSameDay, isSameMonth, isWithinInterval } from 'date-fns';
|
|
13
13
|
import { NG_VALUE_ACCESSOR } from '@angular/forms';
|
|
14
|
+
import { delay } from 'rxjs/operators';
|
|
14
15
|
|
|
15
16
|
class EnvironmentService {
|
|
16
17
|
constructor(environment) {
|
|
@@ -501,6 +502,7 @@ class AdbDatePickerDirective {
|
|
|
501
502
|
this.subscriptions = new Subscription();
|
|
502
503
|
this.format = 'yyyy-MM-dd';
|
|
503
504
|
this.settings = null;
|
|
505
|
+
this.pickOnly = true;
|
|
504
506
|
//ControlValueAccessor
|
|
505
507
|
this.onChange = () => { };
|
|
506
508
|
this.onTouched = () => { };
|
|
@@ -518,6 +520,7 @@ class AdbDatePickerDirective {
|
|
|
518
520
|
this.id = this.getId();
|
|
519
521
|
viewRef.instance.id = this.id;
|
|
520
522
|
viewRef.instance.selectDate.subscribe((date) => {
|
|
523
|
+
this.elementRef.nativeElement.classList.remove('ng-invalid');
|
|
521
524
|
this.renderer.setProperty(this.elementRef.nativeElement, 'value', formatDate(date, this.format, this.translate.currentLang));
|
|
522
525
|
this.onChange(date);
|
|
523
526
|
this.initialDate = date;
|
|
@@ -528,22 +531,32 @@ class AdbDatePickerDirective {
|
|
|
528
531
|
});
|
|
529
532
|
this.adbDatePickerService.viewRef = viewRef;
|
|
530
533
|
}
|
|
534
|
+
onKeyup(event) {
|
|
535
|
+
const date = AdbDatePickerDirective.tryParse(event.target.value, this.format);
|
|
536
|
+
if (date) {
|
|
537
|
+
this.onChange(date);
|
|
538
|
+
this.initialDate = date;
|
|
539
|
+
}
|
|
540
|
+
}
|
|
531
541
|
onHide() {
|
|
532
542
|
this.adbDatePickerService.viewRef = null;
|
|
533
543
|
this.viewContainerRef.detach();
|
|
534
544
|
this.viewContainerRef.clear();
|
|
535
545
|
}
|
|
546
|
+
onBlur() {
|
|
547
|
+
const date = AdbDatePickerDirective.tryParse(this.elementRef.nativeElement.value, this.format);
|
|
548
|
+
if (!date) {
|
|
549
|
+
this.elementRef.nativeElement.classList.add('ng-invalid');
|
|
550
|
+
}
|
|
551
|
+
else {
|
|
552
|
+
this.elementRef.nativeElement.classList.remove('ng-invalid');
|
|
553
|
+
}
|
|
554
|
+
}
|
|
536
555
|
handleKeyboardEvent(event) {
|
|
537
556
|
if (event.key === 'Tab') {
|
|
538
557
|
this.onHide();
|
|
539
558
|
}
|
|
540
|
-
else if (
|
|
541
|
-
this.initialDate = null;
|
|
542
|
-
this.renderer.setProperty(this.elementRef.nativeElement, 'value', null);
|
|
543
|
-
this.onChange();
|
|
544
|
-
this.onHide();
|
|
545
|
-
}
|
|
546
|
-
else {
|
|
559
|
+
else if (this.pickOnly) {
|
|
547
560
|
event.preventDefault();
|
|
548
561
|
}
|
|
549
562
|
}
|
|
@@ -601,12 +614,16 @@ class AdbDatePickerDirective {
|
|
|
601
614
|
return null;
|
|
602
615
|
}
|
|
603
616
|
}
|
|
617
|
+
static tryParse(dateString, format) {
|
|
618
|
+
const parsed = parseISO(dateString);
|
|
619
|
+
return isValid(parsed) && (dateString === null || dateString === void 0 ? void 0 : dateString.length) === 10 ? parsed : null;
|
|
620
|
+
}
|
|
604
621
|
getId() {
|
|
605
622
|
return '' + Math.floor(Math.random() * Date.now());
|
|
606
623
|
}
|
|
607
624
|
}
|
|
608
625
|
/** @nocollapse */ AdbDatePickerDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.8", ngImport: i0, type: AdbDatePickerDirective, deps: [{ token: i0.ViewContainerRef }, { token: i0.Renderer2 }, { token: i0.ElementRef }, { token: AdbDatePickerService }, { token: i1$1.TranslateService }], target: i0.ɵɵFactoryTarget.Directive });
|
|
609
|
-
/** @nocollapse */ AdbDatePickerDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.3.8", type: AdbDatePickerDirective, selector: "input[adbDatepicker]", inputs: { format: "format", toLeft: "toLeft", settings: "settings" }, host: { listeners: { "click": "onClick()", "keyup.esc": "onHide()", "keydown": "handleKeyboardEvent($event)", "document:click": "onCheckOutSideClick($event.target)" }, properties: { "autocomplete": "this.autocomplete" } }, providers: [{
|
|
626
|
+
/** @nocollapse */ AdbDatePickerDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.3.8", type: AdbDatePickerDirective, selector: "input[adbDatepicker]", inputs: { format: "format", toLeft: "toLeft", settings: "settings", pickOnly: "pickOnly" }, host: { listeners: { "click": "onClick()", "keyup": "onKeyup($event)", "keyup.esc": "onHide()", "blur": "onBlur()", "keydown": "handleKeyboardEvent($event)", "document:click": "onCheckOutSideClick($event.target)" }, properties: { "autocomplete": "this.autocomplete" } }, providers: [{
|
|
610
627
|
provide: NG_VALUE_ACCESSOR, useExisting: forwardRef((() => AdbDatePickerDirective)),
|
|
611
628
|
multi: true
|
|
612
629
|
}], ngImport: i0 });
|
|
@@ -628,12 +645,20 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.8", ngImpor
|
|
|
628
645
|
type: Input
|
|
629
646
|
}], settings: [{
|
|
630
647
|
type: Input
|
|
648
|
+
}], pickOnly: [{
|
|
649
|
+
type: Input
|
|
631
650
|
}], onClick: [{
|
|
632
651
|
type: HostListener,
|
|
633
652
|
args: ['click']
|
|
653
|
+
}], onKeyup: [{
|
|
654
|
+
type: HostListener,
|
|
655
|
+
args: ['keyup', ['$event']]
|
|
634
656
|
}], onHide: [{
|
|
635
657
|
type: HostListener,
|
|
636
658
|
args: ['keyup.esc']
|
|
659
|
+
}], onBlur: [{
|
|
660
|
+
type: HostListener,
|
|
661
|
+
args: ['blur']
|
|
637
662
|
}], handleKeyboardEvent: [{
|
|
638
663
|
type: HostListener,
|
|
639
664
|
args: ['keydown', ['$event']]
|
|
@@ -1002,53 +1027,71 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.8", ngImpor
|
|
|
1002
1027
|
class AdbToastService {
|
|
1003
1028
|
constructor(componentFactoryResolver, rendererFactory, appRef, injector) {
|
|
1004
1029
|
this.componentFactoryResolver = componentFactoryResolver;
|
|
1030
|
+
this.rendererFactory = rendererFactory;
|
|
1005
1031
|
this.appRef = appRef;
|
|
1006
1032
|
this.injector = injector;
|
|
1007
|
-
this.
|
|
1033
|
+
this.toasts = new Array();
|
|
1034
|
+
this.toastsSubject = new Subject();
|
|
1035
|
+
this.$toasts = this.toastsSubject.asObservable();
|
|
1036
|
+
}
|
|
1037
|
+
add(toastMessage, time = 4000) {
|
|
1038
|
+
this.addContainer();
|
|
1039
|
+
toastMessage.type = toastMessage.type ? toastMessage.type : ToastType.Success;
|
|
1040
|
+
toastMessage.index = this.toasts.length;
|
|
1041
|
+
toastMessage.delay = of(toastMessage).pipe(delay(time)).subscribe(toast => {
|
|
1042
|
+
this.remove(toast);
|
|
1043
|
+
});
|
|
1044
|
+
this.toasts.push(toastMessage);
|
|
1045
|
+
this.toastsSubject.next(this.toasts);
|
|
1008
1046
|
}
|
|
1009
|
-
|
|
1047
|
+
remove(toast) {
|
|
1048
|
+
var _a;
|
|
1049
|
+
this.toasts = (_a = this.toasts) === null || _a === void 0 ? void 0 : _a.filter(x => x.index !== toast.index);
|
|
1050
|
+
this.toastsSubject.next(this.toasts);
|
|
1051
|
+
}
|
|
1052
|
+
addContainer() {
|
|
1010
1053
|
if (!this.container) {
|
|
1054
|
+
this.renderer = this.rendererFactory.createRenderer(null, null);
|
|
1055
|
+
//create container i top
|
|
1011
1056
|
this.container = this.renderer.createElement('div');
|
|
1012
|
-
this.container.setAttribute('adb-toast-container', '');
|
|
1013
|
-
this.container.classList.add('position-fixed', 'bottom-0', 'end-0');
|
|
1014
1057
|
this.renderer.appendChild(document.body, this.container);
|
|
1058
|
+
let componentRef = this.componentFactoryResolver.resolveComponentFactory(AdbToast).create(this.injector);
|
|
1059
|
+
this.appRef.attachView(componentRef.hostView);
|
|
1060
|
+
const element = componentRef.hostView.rootNodes[0];
|
|
1061
|
+
this.container.prepend(element);
|
|
1015
1062
|
}
|
|
1016
|
-
this.createToast(model);
|
|
1017
|
-
}
|
|
1018
|
-
createToast(model) {
|
|
1019
|
-
if (!model.state)
|
|
1020
|
-
model.state = 'info';
|
|
1021
|
-
if (!model.timeInMs)
|
|
1022
|
-
model.timeInMs = 4000;
|
|
1023
|
-
let componentRef = this.componentFactoryResolver.resolveComponentFactory(AdbToast).create(this.injector);
|
|
1024
|
-
componentRef.instance.model = model;
|
|
1025
|
-
this.appRef.attachView(componentRef.hostView);
|
|
1026
|
-
const element = componentRef.hostView.rootNodes[0];
|
|
1027
|
-
this.container.prepend(element);
|
|
1028
|
-
setTimeout(() => {
|
|
1029
|
-
// element.remove();
|
|
1030
|
-
}, model.timeInMs);
|
|
1031
1063
|
}
|
|
1032
1064
|
}
|
|
1033
1065
|
/** @nocollapse */ AdbToastService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.8", ngImport: i0, type: AdbToastService, deps: [{ token: i0.ComponentFactoryResolver }, { token: i0.RendererFactory2 }, { token: i0.ApplicationRef }, { token: i0.Injector }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
1034
1066
|
/** @nocollapse */ AdbToastService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "13.3.8", ngImport: i0, type: AdbToastService });
|
|
1035
1067
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.8", ngImport: i0, type: AdbToastService, decorators: [{
|
|
1036
1068
|
type: Injectable
|
|
1037
|
-
}], ctorParameters: function () { return [{ type: i0.ComponentFactoryResolver }, { type: i0.RendererFactory2 }, { type: i0.ApplicationRef }, { type: i0.Injector }]; } });
|
|
1069
|
+
}], ctorParameters: function () { return [{ type: i0.ComponentFactoryResolver }, { type: i0.RendererFactory2 }, { type: i0.ApplicationRef }, { type: i0.Injector }]; } });
|
|
1070
|
+
var ToastType;
|
|
1071
|
+
(function (ToastType) {
|
|
1072
|
+
ToastType[ToastType["Info"] = 1] = "Info";
|
|
1073
|
+
ToastType[ToastType["Success"] = 2] = "Success";
|
|
1074
|
+
ToastType[ToastType["Warn"] = 3] = "Warn";
|
|
1075
|
+
})(ToastType || (ToastType = {}));
|
|
1038
1076
|
|
|
1039
1077
|
class AdbToast {
|
|
1040
|
-
constructor(
|
|
1041
|
-
this.
|
|
1078
|
+
constructor(toastService) {
|
|
1079
|
+
this.toastService = toastService;
|
|
1080
|
+
this.toastType = ToastType;
|
|
1081
|
+
this.toastService.$toasts.subscribe(toasts => {
|
|
1082
|
+
this.toasts = toasts;
|
|
1083
|
+
});
|
|
1084
|
+
}
|
|
1085
|
+
onRemoveToast(toast) {
|
|
1086
|
+
this.toastService.remove(toast);
|
|
1042
1087
|
}
|
|
1043
1088
|
}
|
|
1044
1089
|
/** @nocollapse */ AdbToast.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.8", ngImport: i0, type: AdbToast, deps: [{ token: AdbToastService }], target: i0.ɵɵFactoryTarget.Component });
|
|
1045
|
-
/** @nocollapse */ AdbToast.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.8", type: AdbToast, selector: "ng-component",
|
|
1090
|
+
/** @nocollapse */ AdbToast.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.8", type: AdbToast, selector: "ng-component", ngImport: i0, template: "<div class=\"position-fixed bottom-0 end-0\" style=\"z-index: 50000;min-width: 15rem;\">\r\n <div class=\"text-white px-3 pb-3 pt-2 mb-2\" *ngFor=\"let toast of toasts\"\r\n [class.bg-success]=\"toast.type===toastType.Success\" [class.bg-info]=\"toast.type===toastType.Info\" [class.bg-danger]=\"toast.type===toastType.Warn\">\r\n <div class=\"d-flex align-items-center justify-content-between pb-1\" *ngIf=\"toast.header\">\r\n <div class=\"fw-bold pb-1\">{{toast.header|translate}}</div>\r\n <button class=\"btn top-0 end-0 btn p-0 ms-2 text-white\" (click)=\"onRemoveToast(toast)\"><i class=\"fas fa-times\"></i></button>\r\n </div>\r\n <div class=\"d-flex align-items-center justify-content-between mt-1\">\r\n <div>{{toast.message|translate}}</div>\r\n <button *ngIf=\"!toast.header\" class=\"btn p-0 ms-2 text-white\" (click)=\"onRemoveToast(toast)\"><i class=\"fas fa-times\"></i></button>\r\n </div>\r\n </div>\r\n</div>", directives: [{ type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], pipes: { "translate": i1$1.TranslatePipe } });
|
|
1046
1091
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.8", ngImport: i0, type: AdbToast, decorators: [{
|
|
1047
1092
|
type: Component,
|
|
1048
|
-
args: [{ template: "
|
|
1049
|
-
}], ctorParameters: function () { return [{ type: AdbToastService }]; }
|
|
1050
|
-
type: Input
|
|
1051
|
-
}] } });
|
|
1093
|
+
args: [{ template: "<div class=\"position-fixed bottom-0 end-0\" style=\"z-index: 50000;min-width: 15rem;\">\r\n <div class=\"text-white px-3 pb-3 pt-2 mb-2\" *ngFor=\"let toast of toasts\"\r\n [class.bg-success]=\"toast.type===toastType.Success\" [class.bg-info]=\"toast.type===toastType.Info\" [class.bg-danger]=\"toast.type===toastType.Warn\">\r\n <div class=\"d-flex align-items-center justify-content-between pb-1\" *ngIf=\"toast.header\">\r\n <div class=\"fw-bold pb-1\">{{toast.header|translate}}</div>\r\n <button class=\"btn top-0 end-0 btn p-0 ms-2 text-white\" (click)=\"onRemoveToast(toast)\"><i class=\"fas fa-times\"></i></button>\r\n </div>\r\n <div class=\"d-flex align-items-center justify-content-between mt-1\">\r\n <div>{{toast.message|translate}}</div>\r\n <button *ngIf=\"!toast.header\" class=\"btn p-0 ms-2 text-white\" (click)=\"onRemoveToast(toast)\"><i class=\"fas fa-times\"></i></button>\r\n </div>\r\n </div>\r\n</div>" }]
|
|
1094
|
+
}], ctorParameters: function () { return [{ type: AdbToastService }]; } });
|
|
1052
1095
|
|
|
1053
1096
|
class AdbToastModule {
|
|
1054
1097
|
}
|
|
@@ -1073,5 +1116,5 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.8", ngImpor
|
|
|
1073
1116
|
* Generated bundle index. Do not edit.
|
|
1074
1117
|
*/
|
|
1075
1118
|
|
|
1076
|
-
export { ADBHeaderComponent, ADBHeaderModule, AdbConfirmModal, AdbDatePickerComponent, AdbDatePickerDirective, AdbDatePickerModule, AdbDirectivesModule, AdbDropdownDirective, AdbDropdownModule, AdbModalModule, AdbModalService, AdbPagersModule, AdbPipesModule, AdbToast, AdbToastModule, AdbToastService, ClickOutsideDirective, FileUploadDirective, FocusDirective, HighlightPipe, InfiniteScrollComponent, LocaleDatePipe, NumberSpacingPipe, PagerComponent };
|
|
1119
|
+
export { ADBHeaderComponent, ADBHeaderModule, AdbConfirmModal, AdbDatePickerComponent, AdbDatePickerDirective, AdbDatePickerModule, AdbDirectivesModule, AdbDropdownDirective, AdbDropdownModule, AdbModalModule, AdbModalService, AdbPagersModule, AdbPipesModule, AdbToast, AdbToastModule, AdbToastService, ClickOutsideDirective, FileUploadDirective, FocusDirective, HighlightPipe, InfiniteScrollComponent, LocaleDatePipe, NumberSpacingPipe, PagerComponent, ToastType };
|
|
1077
1120
|
//# sourceMappingURL=adb-shared.mjs.map
|