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.
@@ -1,19 +1,25 @@
1
- import { Component, Input } from '@angular/core';
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(toastRef) {
8
- this.toastRef = toastRef;
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", inputs: { model: "model" }, ngImport: i0, template: " <div #toast (click)=\"toast.remove()\" adb-toast class=\"text-white px-3 pb-3 pt-2 mb-2\" style=\"z-index: 50000;min-width: 15rem;\" [class]=\"'bg-' + model.state\">\r\n <div *ngIf=\"model.header\" class=\"d-flex align-items-center justify-content-between pb-1\">\r\n <div class=\"fw-bold\">{{model.header|translate}}</div>\r\n <button class=\"btn p-0 ms-2 text-white\" (click)=\"toast.remove()\"><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> {{model.body|translate}}</div>\r\n <button *ngIf=\"!model.header\" class=\"btn p-0 ms-2 text-white\" (click)=\"toast.remove()\"><i class=\"fas fa-times\"></i></button>\r\n </div>\r\n </div>", directives: [{ type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], pipes: { "translate": i3.TranslatePipe } });
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: " <div #toast (click)=\"toast.remove()\" adb-toast class=\"text-white px-3 pb-3 pt-2 mb-2\" style=\"z-index: 50000;min-width: 15rem;\" [class]=\"'bg-' + model.state\">\r\n <div *ngIf=\"model.header\" class=\"d-flex align-items-center justify-content-between pb-1\">\r\n <div class=\"fw-bold\">{{model.header|translate}}</div>\r\n <button class=\"btn p-0 ms-2 text-white\" (click)=\"toast.remove()\"><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> {{model.body|translate}}</div>\r\n <button *ngIf=\"!model.header\" class=\"btn p-0 ms-2 text-white\" (click)=\"toast.remove()\"><i class=\"fas fa-times\"></i></button>\r\n </div>\r\n </div>" }]
16
- }], ctorParameters: function () { return [{ type: i1.AdbToastService }]; }, propDecorators: { model: [{
17
- type: Input
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.renderer = rendererFactory.createRenderer(null, null);
12
+ this.toasts = new Array();
13
+ this.toastsSubject = new Subject();
14
+ this.$toasts = this.toastsSubject.asObservable();
10
15
  }
11
- show(model) {
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
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWRiLXRvYXN0LnNlcnZpY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9hcnRkYXRhLXNoYXJlZC9zcmMvbGliL2NvbXBvbmVudHMvYWRiLXRvYXN0L2FkYi10b2FzdC5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBNkQsVUFBVSxFQUF5QyxNQUFNLGVBQWUsQ0FBQztBQUM3SSxPQUFPLEVBQUUsUUFBUSxFQUFjLE1BQU0sYUFBYSxDQUFDOztBQUduRCxNQUFNLE9BQU8sZUFBZTtJQUt4QixZQUNZLHdCQUFrRCxFQUMxRCxlQUFpQyxFQUN6QixNQUFzQixFQUN0QixRQUFrQjtRQUhsQiw2QkFBd0IsR0FBeEIsd0JBQXdCLENBQTBCO1FBRWxELFdBQU0sR0FBTixNQUFNLENBQWdCO1FBQ3RCLGFBQVEsR0FBUixRQUFRLENBQVU7UUFDMUIsSUFBSSxDQUFDLFFBQVEsR0FBRyxlQUFlLENBQUMsY0FBYyxDQUFDLElBQUksRUFBRSxJQUFJLENBQUMsQ0FBQztJQUMvRCxDQUFDO0lBRUQsSUFBSSxDQUFDLEtBQWlCO1FBQ2xCLElBQUksQ0FBQyxJQUFJLENBQUMsU0FBUyxFQUFDO1lBQ2hCLElBQUksQ0FBQyxTQUFTLEdBQUcsSUFBSSxDQUFDLFFBQVEsQ0FBQyxhQUFhLENBQUMsS0FBSyxDQUFDLENBQUM7WUFDcEQsSUFBSSxDQUFDLFNBQVMsQ0FBQyxZQUFZLENBQUMscUJBQXFCLEVBQUUsRUFBRSxDQUFDLENBQUM7WUFDdkQsSUFBSSxDQUFDLFNBQVMsQ0FBQyxTQUFTLENBQUMsR0FBRyxDQUFDLGdCQUFnQixFQUFFLFVBQVUsRUFBRSxPQUFPLENBQUMsQ0FBQztZQUNwRSxJQUFJLENBQUMsUUFBUSxDQUFDLFdBQVcsQ0FBQyxRQUFRLENBQUMsSUFBSSxFQUFFLElBQUksQ0FBQyxTQUFTLENBQUMsQ0FBQztTQUM1RDtRQUVELElBQUksQ0FBQyxXQUFXLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDNUIsQ0FBQztJQUVPLFdBQVcsQ0FBQyxLQUFpQjtRQUNqQyxJQUFJLENBQUMsS0FBSyxDQUFDLEtBQUs7WUFDWixLQUFLLENBQUMsS0FBSyxHQUFHLE1BQU0sQ0FBQztRQUN6QixJQUFJLENBQUMsS0FBSyxDQUFDLFFBQVE7WUFDZixLQUFLLENBQUMsUUFBUSxHQUFHLElBQUksQ0FBQztRQUUxQixJQUFJLFlBQVksR0FBRyxJQUFJLENBQUMsd0JBQXdCLENBQUMsdUJBQXVCLENBQUMsUUFBUSxDQUFDLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxRQUFRLENBQUMsQ0FBQztRQUN6RyxZQUFZLENBQUMsUUFBUSxDQUFDLEtBQUssR0FBRyxLQUFLLENBQUM7UUFDcEMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxVQUFVLENBQUMsWUFBWSxDQUFDLFFBQVEsQ0FBQyxDQUFDO1FBQzlDLE1BQU0sT0FBTyxHQUFJLFlBQVksQ0FBQyxRQUFpQyxDQUFDLFNBQVMsQ0FBQyxDQUFDLENBQWdCLENBQUM7UUFDNUYsSUFBSSxDQUFDLFNBQVMsQ0FBQyxPQUFPLENBQUMsT0FBTyxDQUFDLENBQUM7UUFFaEMsVUFBVSxDQUFDLEdBQUcsRUFBRTtZQUNaLG9CQUFvQjtRQUN4QixDQUFDLEVBQUUsS0FBSyxDQUFDLFFBQVEsQ0FBQyxDQUFDO0lBQ3ZCLENBQUM7OytIQXZDUSxlQUFlO21JQUFmLGVBQWU7MkZBQWYsZUFBZTtrQkFEM0IsVUFBVSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEFwcGxpY2F0aW9uUmVmLCBDb21wb25lbnRGYWN0b3J5UmVzb2x2ZXIsIEVtYmVkZGVkVmlld1JlZiwgSW5qZWN0YWJsZSwgSW5qZWN0b3IsIFJlbmRlcmVyMiwgUmVuZGVyZXJGYWN0b3J5MiB9IGZyb20gXCJAYW5ndWxhci9jb3JlXCI7XHJcbmltcG9ydCB7IEFkYlRvYXN0LCBUb2FzdE1vZGVsIH0gZnJvbSBcIi4vYWRiLXRvYXN0XCI7XHJcblxyXG5ASW5qZWN0YWJsZSgpXHJcbmV4cG9ydCBjbGFzcyBBZGJUb2FzdFNlcnZpY2Uge1xyXG4gICAgcmVuZGVyZXI6IFJlbmRlcmVyMjtcclxuICAgIGRvbUVsZW1lbnQ6IEhUTUxFbGVtZW50O1xyXG4gICAgY29udGFpbmVyOiBhbnk7XHJcblxyXG4gICAgY29uc3RydWN0b3IoXHJcbiAgICAgICAgcHJpdmF0ZSBjb21wb25lbnRGYWN0b3J5UmVzb2x2ZXI6IENvbXBvbmVudEZhY3RvcnlSZXNvbHZlcixcclxuICAgICAgICByZW5kZXJlckZhY3Rvcnk6IFJlbmRlcmVyRmFjdG9yeTIsXHJcbiAgICAgICAgcHJpdmF0ZSBhcHBSZWY6IEFwcGxpY2F0aW9uUmVmLFxyXG4gICAgICAgIHByaXZhdGUgaW5qZWN0b3I6IEluamVjdG9yKSB7XHJcbiAgICAgICAgdGhpcy5yZW5kZXJlciA9IHJlbmRlcmVyRmFjdG9yeS5jcmVhdGVSZW5kZXJlcihudWxsLCBudWxsKTtcclxuICAgIH1cclxuXHJcbiAgICBzaG93KG1vZGVsOiBUb2FzdE1vZGVsKTogdm9pZCB7XHJcbiAgICAgICAgaWYgKCF0aGlzLmNvbnRhaW5lcil7XHJcbiAgICAgICAgICAgIHRoaXMuY29udGFpbmVyID0gdGhpcy5yZW5kZXJlci5jcmVhdGVFbGVtZW50KCdkaXYnKTtcclxuICAgICAgICAgICAgdGhpcy5jb250YWluZXIuc2V0QXR0cmlidXRlKCdhZGItdG9hc3QtY29udGFpbmVyJywgJycpO1xyXG4gICAgICAgICAgICB0aGlzLmNvbnRhaW5lci5jbGFzc0xpc3QuYWRkKCdwb3NpdGlvbi1maXhlZCcsICdib3R0b20tMCcsICdlbmQtMCcpO1xyXG4gICAgICAgICAgICB0aGlzLnJlbmRlcmVyLmFwcGVuZENoaWxkKGRvY3VtZW50LmJvZHksIHRoaXMuY29udGFpbmVyKTtcclxuICAgICAgICB9XHJcblxyXG4gICAgICAgIHRoaXMuY3JlYXRlVG9hc3QobW9kZWwpO1xyXG4gICAgfVxyXG5cclxuICAgIHByaXZhdGUgY3JlYXRlVG9hc3QobW9kZWw6IFRvYXN0TW9kZWwpOiB2b2lkIHtcclxuICAgICAgICBpZiAoIW1vZGVsLnN0YXRlKVxyXG4gICAgICAgICAgICBtb2RlbC5zdGF0ZSA9ICdpbmZvJztcclxuICAgICAgICBpZiAoIW1vZGVsLnRpbWVJbk1zKVxyXG4gICAgICAgICAgICBtb2RlbC50aW1lSW5NcyA9IDQwMDA7XHJcblxyXG4gICAgICAgIGxldCBjb21wb25lbnRSZWYgPSB0aGlzLmNvbXBvbmVudEZhY3RvcnlSZXNvbHZlci5yZXNvbHZlQ29tcG9uZW50RmFjdG9yeShBZGJUb2FzdCkuY3JlYXRlKHRoaXMuaW5qZWN0b3IpO1xyXG4gICAgICAgIGNvbXBvbmVudFJlZi5pbnN0YW5jZS5tb2RlbCA9IG1vZGVsO1xyXG4gICAgICAgIHRoaXMuYXBwUmVmLmF0dGFjaFZpZXcoY29tcG9uZW50UmVmLmhvc3RWaWV3KTtcclxuICAgICAgICBjb25zdCBlbGVtZW50ID0gKGNvbXBvbmVudFJlZi5ob3N0VmlldyBhcyBFbWJlZGRlZFZpZXdSZWY8YW55Pikucm9vdE5vZGVzWzBdIGFzIEhUTUxFbGVtZW50O1xyXG4gICAgICAgIHRoaXMuY29udGFpbmVyLnByZXBlbmQoZWxlbWVudCk7XHJcblxyXG4gICAgICAgIHNldFRpbWVvdXQoKCkgPT4ge1xyXG4gICAgICAgICAgICAvLyBlbGVtZW50LnJlbW92ZSgpO1xyXG4gICAgICAgIH0sIG1vZGVsLnRpbWVJbk1zKTtcclxuICAgIH1cclxufSJdfQ==
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 (event.key === 'Backspace') {
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}"]}
@@ -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 (event.key === 'Backspace') {
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.renderer = rendererFactory.createRenderer(null, null);
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
- show(model) {
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(toastRef) {
1041
- this.toastRef = toastRef;
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", inputs: { model: "model" }, ngImport: i0, template: " <div #toast (click)=\"toast.remove()\" adb-toast class=\"text-white px-3 pb-3 pt-2 mb-2\" style=\"z-index: 50000;min-width: 15rem;\" [class]=\"'bg-' + model.state\">\r\n <div *ngIf=\"model.header\" class=\"d-flex align-items-center justify-content-between pb-1\">\r\n <div class=\"fw-bold\">{{model.header|translate}}</div>\r\n <button class=\"btn p-0 ms-2 text-white\" (click)=\"toast.remove()\"><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> {{model.body|translate}}</div>\r\n <button *ngIf=\"!model.header\" class=\"btn p-0 ms-2 text-white\" (click)=\"toast.remove()\"><i class=\"fas fa-times\"></i></button>\r\n </div>\r\n </div>", directives: [{ type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], pipes: { "translate": i1$1.TranslatePipe } });
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: " <div #toast (click)=\"toast.remove()\" adb-toast class=\"text-white px-3 pb-3 pt-2 mb-2\" style=\"z-index: 50000;min-width: 15rem;\" [class]=\"'bg-' + model.state\">\r\n <div *ngIf=\"model.header\" class=\"d-flex align-items-center justify-content-between pb-1\">\r\n <div class=\"fw-bold\">{{model.header|translate}}</div>\r\n <button class=\"btn p-0 ms-2 text-white\" (click)=\"toast.remove()\"><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> {{model.body|translate}}</div>\r\n <button *ngIf=\"!model.header\" class=\"btn p-0 ms-2 text-white\" (click)=\"toast.remove()\"><i class=\"fas fa-times\"></i></button>\r\n </div>\r\n </div>" }]
1049
- }], ctorParameters: function () { return [{ type: AdbToastService }]; }, propDecorators: { model: [{
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