ecabs-components 1.0.88 → 1.0.90
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/README.md +6 -0
- package/esm2022/lib/base/directives/paginator.directive.mjs +157 -0
- package/esm2022/lib/base/directives/paginator.directive.module.mjs +18 -0
- package/esm2022/lib/base/element-wrapper/element-wrapper.component.mjs +4 -4
- package/esm2022/lib/base/element-wrapper/element-wrapper.module.mjs +5 -5
- package/esm2022/lib/ecabs-date-picker/ecabs-date-picker.component.mjs +1 -1
- package/esm2022/lib/ecabs-date-picker/ecabs-date-picker.module.mjs +1 -1
- package/esm2022/lib/ecabs-hint/ecabs-hint.component.mjs +21 -0
- package/esm2022/lib/ecabs-hint/ecabs-hint.module.mjs +18 -0
- package/esm2022/lib/ecabs-table/ecabs-table.component.mjs +5 -5
- package/esm2022/lib/ecabs-table/ecabs-table.module.mjs +3 -3
- package/esm2022/public-api.mjs +5 -1
- package/fesm2022/ecabs-components.mjs +200 -32
- package/fesm2022/ecabs-components.mjs.map +1 -1
- package/lib/base/directives/paginator.directive.d.ts +36 -0
- package/lib/base/directives/paginator.directive.module.d.ts +8 -0
- package/lib/base/element-wrapper/element-wrapper.module.d.ts +2 -2
- package/lib/ecabs-hint/ecabs-hint.component.d.ts +8 -0
- package/lib/ecabs-hint/ecabs-hint.module.d.ts +8 -0
- package/lib/ecabs-table/ecabs-table.component.d.ts +1 -1
- package/lib/ecabs-table/ecabs-table.module.d.ts +3 -3
- package/package.json +1 -1
- package/public-api.d.ts +4 -0
- package/src/assets/styles/material/_theme.scss +0 -12
- package/src/assets/styles/material/overrides/_paginator.scss +75 -0
- package/src/assets/styles/material/overrides/_progress.scss +7 -0
- package/src/assets/styles/material/overrides/_select.scss +2 -13
- package/src/assets/styles/material/overrides/_toaster.scss +36 -38
- package/src/assets/styles/material/overrides/index.scss +1 -0
- package/src/assets/styles/scss/base/_normalize.scss +6 -0
- package/esm2022/lib/base/hint/hint.component.mjs +0 -21
- package/esm2022/lib/base/hint/hint.module.mjs +0 -20
- package/lib/base/hint/hint.component.d.ts +0 -8
- package/lib/base/hint/hint.module.d.ts +0 -10
package/README.md
CHANGED
|
@@ -43,3 +43,9 @@ v1.0.84 - Emit `falsey` result when Close button is clicked on `EcabsDialogConfi
|
|
|
43
43
|
v1.0.85 - Improve styling for `EcabsTable` row colors.
|
|
44
44
|
v1.0.87 - Apply min/max Date logic for date picker
|
|
45
45
|
v1.0.88 - Roll back 1.0.87
|
|
46
|
+
v1.0.84 - Emit `falsey` result when Close button is clicked on `EcabsDialogConfirm` and `EcabsDialogMessage`.
|
|
47
|
+
v1.0.89 - Upgrade `MatLegacyTable` and `MatLegacyProgress` to `MDC`.
|
|
48
|
+
v1.0.90 - Upgrade `MatLegacyPaginator` to `MDC`.
|
|
49
|
+
- Add `EcabsPaginatorDirective`.
|
|
50
|
+
- Rename `AppHint` to `EcabsHint`.
|
|
51
|
+
- Apply `ngx-toaster` overrides.
|
|
@@ -0,0 +1,157 @@
|
|
|
1
|
+
import { Directive, Host, Input, Optional, Self, } from '@angular/core';
|
|
2
|
+
import { takeUntilDestroyed } from '@angular/core/rxjs-interop';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
import * as i1 from "@angular/material/paginator";
|
|
5
|
+
export class EcabsPaginatorDirective {
|
|
6
|
+
matPag;
|
|
7
|
+
vr;
|
|
8
|
+
ren;
|
|
9
|
+
destroyRef;
|
|
10
|
+
length;
|
|
11
|
+
_rangeStart;
|
|
12
|
+
_rangeEnd;
|
|
13
|
+
_buttons = [];
|
|
14
|
+
_curPageObj = {
|
|
15
|
+
length: 0,
|
|
16
|
+
pageIndex: 0,
|
|
17
|
+
pageSize: 0,
|
|
18
|
+
previousPageIndex: 0,
|
|
19
|
+
};
|
|
20
|
+
_showTotalPages = 3;
|
|
21
|
+
get showTotalPages() {
|
|
22
|
+
return this._showTotalPages;
|
|
23
|
+
}
|
|
24
|
+
get inc() {
|
|
25
|
+
return this._showTotalPages % 2 === 0
|
|
26
|
+
? this.showTotalPages / 2
|
|
27
|
+
: (this.showTotalPages - 1) / 2;
|
|
28
|
+
}
|
|
29
|
+
get lastPageIndex() {
|
|
30
|
+
return this.matPag.getNumberOfPages() - 1;
|
|
31
|
+
}
|
|
32
|
+
set showTotalPages(value) {
|
|
33
|
+
this._showTotalPages = value % 2 === 0 ? value + 1 : value;
|
|
34
|
+
}
|
|
35
|
+
constructor(matPag, vr, ren, destroyRef) {
|
|
36
|
+
this.matPag = matPag;
|
|
37
|
+
this.vr = vr;
|
|
38
|
+
this.ren = ren;
|
|
39
|
+
this.destroyRef = destroyRef;
|
|
40
|
+
// to rerender buttons on items per page change and first, last, next and prior buttons
|
|
41
|
+
this.matPag.page
|
|
42
|
+
.pipe(takeUntilDestroyed(this.destroyRef))
|
|
43
|
+
.subscribe((e) => {
|
|
44
|
+
this.pageChanged(e);
|
|
45
|
+
});
|
|
46
|
+
this.matPag.selectConfig = {
|
|
47
|
+
panelClass: 'paginator--selector',
|
|
48
|
+
};
|
|
49
|
+
}
|
|
50
|
+
pageChanged(page) {
|
|
51
|
+
if (this._curPageObj.pageSize !== page.pageSize &&
|
|
52
|
+
this._curPageObj.pageIndex !== 0) {
|
|
53
|
+
page.pageIndex = 0;
|
|
54
|
+
this._rangeStart = 0;
|
|
55
|
+
this._rangeEnd = this._showTotalPages - 1;
|
|
56
|
+
}
|
|
57
|
+
this._curPageObj = page;
|
|
58
|
+
this.initPageRange();
|
|
59
|
+
}
|
|
60
|
+
ngOnChanges(changes) {
|
|
61
|
+
if (changes['length'] && !changes['length']?.firstChange) {
|
|
62
|
+
this.pageChanged(this._curPageObj);
|
|
63
|
+
}
|
|
64
|
+
}
|
|
65
|
+
//Initialize default state after view init
|
|
66
|
+
ngAfterViewInit() {
|
|
67
|
+
this._rangeStart = 0;
|
|
68
|
+
this._rangeEnd = this._showTotalPages - 1;
|
|
69
|
+
this.initPageRange();
|
|
70
|
+
}
|
|
71
|
+
buildPageNumbers() {
|
|
72
|
+
const actionContainer = this.vr.element.nativeElement.querySelector('div.mat-mdc-paginator-range-actions');
|
|
73
|
+
// including flex box in container
|
|
74
|
+
const container = this.vr.element.nativeElement.querySelector('div.mat-mdc-paginator-container');
|
|
75
|
+
// removing item per page
|
|
76
|
+
const itemPerPage = this.vr.element.nativeElement.querySelector('div.mat-mdc-paginator-page-size');
|
|
77
|
+
this.ren.appendChild(container, itemPerPage);
|
|
78
|
+
// remove buttons before creating new ones
|
|
79
|
+
if (this._buttons.length > 0) {
|
|
80
|
+
this._buttons.forEach((button) => {
|
|
81
|
+
this.ren.removeChild(actionContainer, button);
|
|
82
|
+
});
|
|
83
|
+
// Empty state array
|
|
84
|
+
this._buttons.length = 0;
|
|
85
|
+
}
|
|
86
|
+
}
|
|
87
|
+
// calculates the button range based on class input parameters and based on current page index value. Used to render new buttons after event.
|
|
88
|
+
initPageRange() {
|
|
89
|
+
const middleIndex = (this._rangeStart + this._rangeEnd) / 2;
|
|
90
|
+
this._rangeStart = this.calcRangeStart(middleIndex);
|
|
91
|
+
this._rangeEnd = this.calcRangeEnd(middleIndex);
|
|
92
|
+
this.buildPageNumbers();
|
|
93
|
+
}
|
|
94
|
+
// Helper function To calculate start of button range
|
|
95
|
+
calcRangeStart(middleIndex) {
|
|
96
|
+
switch (true) {
|
|
97
|
+
case this._curPageObj.pageIndex === 0 && this._rangeStart !== 0:
|
|
98
|
+
return 0;
|
|
99
|
+
case this._curPageObj.pageIndex > this._rangeEnd:
|
|
100
|
+
return this._curPageObj.pageIndex + this.inc > this.lastPageIndex
|
|
101
|
+
? this.lastPageIndex - this.inc * 2
|
|
102
|
+
: this._curPageObj.pageIndex - this.inc;
|
|
103
|
+
case this._curPageObj.pageIndex > this._curPageObj.previousPageIndex &&
|
|
104
|
+
this._curPageObj.pageIndex > middleIndex &&
|
|
105
|
+
this._rangeEnd < this.lastPageIndex:
|
|
106
|
+
return this._rangeStart + 1;
|
|
107
|
+
case this._curPageObj.pageIndex < this._curPageObj.previousPageIndex &&
|
|
108
|
+
this._curPageObj.pageIndex < middleIndex &&
|
|
109
|
+
this._rangeStart > 0:
|
|
110
|
+
return this._rangeStart - 1;
|
|
111
|
+
default:
|
|
112
|
+
return this._rangeStart;
|
|
113
|
+
}
|
|
114
|
+
}
|
|
115
|
+
// Helper function to calculate end of button range
|
|
116
|
+
calcRangeEnd(middleIndex) {
|
|
117
|
+
switch (true) {
|
|
118
|
+
case this._curPageObj.pageIndex === 0 &&
|
|
119
|
+
this._rangeEnd !== this._showTotalPages:
|
|
120
|
+
return this._showTotalPages - 1;
|
|
121
|
+
case this._curPageObj.pageIndex > this._rangeEnd:
|
|
122
|
+
return this._curPageObj.pageIndex + this.inc > this.lastPageIndex
|
|
123
|
+
? this.lastPageIndex
|
|
124
|
+
: this._curPageObj.pageIndex + 1;
|
|
125
|
+
case this._curPageObj.pageIndex > this._curPageObj.previousPageIndex &&
|
|
126
|
+
this._curPageObj.pageIndex > middleIndex &&
|
|
127
|
+
this._rangeEnd < this.lastPageIndex:
|
|
128
|
+
return this._rangeEnd + 1;
|
|
129
|
+
case this._curPageObj.pageIndex < this._curPageObj.previousPageIndex &&
|
|
130
|
+
this._curPageObj.pageIndex < middleIndex &&
|
|
131
|
+
this._rangeStart >= 0 &&
|
|
132
|
+
this._rangeEnd > this._showTotalPages - 1:
|
|
133
|
+
return this._rangeEnd - 1;
|
|
134
|
+
default:
|
|
135
|
+
return this._rangeEnd;
|
|
136
|
+
}
|
|
137
|
+
}
|
|
138
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: EcabsPaginatorDirective, deps: [{ token: i1.MatPaginator, host: true, optional: true, self: true }, { token: i0.ViewContainerRef }, { token: i0.Renderer2 }, { token: i0.DestroyRef }], target: i0.ɵɵFactoryTarget.Directive });
|
|
139
|
+
static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.2.12", type: EcabsPaginatorDirective, selector: "[ecabsPaginator]", inputs: { length: "length", showTotalPages: "showTotalPages" }, usesOnChanges: true, ngImport: i0 });
|
|
140
|
+
}
|
|
141
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: EcabsPaginatorDirective, decorators: [{
|
|
142
|
+
type: Directive,
|
|
143
|
+
args: [{
|
|
144
|
+
selector: '[ecabsPaginator]',
|
|
145
|
+
}]
|
|
146
|
+
}], ctorParameters: function () { return [{ type: i1.MatPaginator, decorators: [{
|
|
147
|
+
type: Host
|
|
148
|
+
}, {
|
|
149
|
+
type: Self
|
|
150
|
+
}, {
|
|
151
|
+
type: Optional
|
|
152
|
+
}] }, { type: i0.ViewContainerRef }, { type: i0.Renderer2 }, { type: i0.DestroyRef }]; }, propDecorators: { length: [{
|
|
153
|
+
type: Input
|
|
154
|
+
}], showTotalPages: [{
|
|
155
|
+
type: Input
|
|
156
|
+
}] } });
|
|
157
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"paginator.directive.js","sourceRoot":"","sources":["../../../../../../projects/ecabs-components/src/lib/base/directives/paginator.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  AfterViewInit,\r\n  DestroyRef,\r\n  Directive,\r\n  Host,\r\n  Input,\r\n  OnChanges,\r\n  Optional,\r\n  Renderer2,\r\n  Self,\r\n  SimpleChanges,\r\n  ViewContainerRef,\r\n} from '@angular/core';\r\nimport { MatPaginator } from '@angular/material/paginator';\r\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\r\n\r\ninterface PageObject {\r\n  length: number;\r\n  pageIndex: number;\r\n  pageSize: number;\r\n  previousPageIndex: number;\r\n}\r\n\r\n@Directive({\r\n  selector: '[ecabsPaginator]',\r\n})\r\nexport class EcabsPaginatorDirective implements AfterViewInit, OnChanges {\r\n  @Input()\r\n  length: number;\r\n\r\n  private _rangeStart: number;\r\n  private _rangeEnd: number;\r\n  private _buttons = [];\r\n  private _curPageObj: PageObject = {\r\n    length: 0,\r\n    pageIndex: 0,\r\n    pageSize: 0,\r\n    previousPageIndex: 0,\r\n  };\r\n  private _showTotalPages = 3;\r\n\r\n  @Input()\r\n  get showTotalPages(): number {\r\n    return this._showTotalPages;\r\n  }\r\n\r\n  get inc(): number {\r\n    return this._showTotalPages % 2 === 0\r\n      ? this.showTotalPages / 2\r\n      : (this.showTotalPages - 1) / 2;\r\n  }\r\n\r\n  get lastPageIndex(): number {\r\n    return this.matPag.getNumberOfPages() - 1;\r\n  }\r\n\r\n  set showTotalPages(value: number) {\r\n    this._showTotalPages = value % 2 === 0 ? value + 1 : value;\r\n  }\r\n\r\n  constructor(\r\n    @Host()\r\n    @Self()\r\n    @Optional()\r\n    private readonly matPag: MatPaginator,\r\n    private readonly vr: ViewContainerRef,\r\n    private readonly ren: Renderer2,\r\n    private readonly destroyRef: DestroyRef,\r\n  ) {\r\n    // to rerender buttons on items per page change and first, last, next and prior buttons\r\n    this.matPag.page\r\n      .pipe(takeUntilDestroyed(this.destroyRef))\r\n      .subscribe((e: PageObject) => {\r\n        this.pageChanged(e);\r\n      });\r\n\r\n    this.matPag.selectConfig = {\r\n      panelClass: 'paginator--selector',\r\n    };\r\n  }\r\n\r\n  pageChanged(page: PageObject): void {\r\n    if (\r\n      this._curPageObj.pageSize !== page.pageSize &&\r\n      this._curPageObj.pageIndex !== 0\r\n    ) {\r\n      page.pageIndex = 0;\r\n      this._rangeStart = 0;\r\n      this._rangeEnd = this._showTotalPages - 1;\r\n    }\r\n    this._curPageObj = page;\r\n    this.initPageRange();\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    if (changes['length'] && !changes['length']?.firstChange) {\r\n      this.pageChanged(this._curPageObj);\r\n    }\r\n  }\r\n\r\n  //Initialize default state after view init\r\n  public ngAfterViewInit(): void {\r\n    this._rangeStart = 0;\r\n    this._rangeEnd = this._showTotalPages - 1;\r\n    this.initPageRange();\r\n  }\r\n\r\n  private buildPageNumbers(): void {\r\n    const actionContainer = this.vr.element.nativeElement.querySelector(\r\n      'div.mat-mdc-paginator-range-actions',\r\n    );\r\n\r\n    // including flex box in container\r\n    const container = this.vr.element.nativeElement.querySelector(\r\n      'div.mat-mdc-paginator-container',\r\n    );\r\n\r\n    // removing item per page\r\n    const itemPerPage = this.vr.element.nativeElement.querySelector(\r\n      'div.mat-mdc-paginator-page-size',\r\n    );\r\n    this.ren.appendChild(container, itemPerPage);\r\n\r\n    // remove buttons before creating new ones\r\n    if (this._buttons.length > 0) {\r\n      this._buttons.forEach((button) => {\r\n        this.ren.removeChild(actionContainer, button);\r\n      });\r\n      // Empty state array\r\n      this._buttons.length = 0;\r\n    }\r\n  }\r\n\r\n  // calculates the button range based on class input parameters and based on current page index value. Used to render new buttons after event.\r\n  private initPageRange(): void {\r\n    const middleIndex = (this._rangeStart + this._rangeEnd) / 2;\r\n\r\n    this._rangeStart = this.calcRangeStart(middleIndex);\r\n    this._rangeEnd = this.calcRangeEnd(middleIndex);\r\n\r\n    this.buildPageNumbers();\r\n  }\r\n\r\n  // Helper function To calculate start of button range\r\n  private calcRangeStart(middleIndex: number): number {\r\n    switch (true) {\r\n      case this._curPageObj.pageIndex === 0 && this._rangeStart !== 0:\r\n        return 0;\r\n\r\n      case this._curPageObj.pageIndex > this._rangeEnd:\r\n        return this._curPageObj.pageIndex + this.inc > this.lastPageIndex\r\n          ? this.lastPageIndex - this.inc * 2\r\n          : this._curPageObj.pageIndex - this.inc;\r\n\r\n      case this._curPageObj.pageIndex > this._curPageObj.previousPageIndex &&\r\n        this._curPageObj.pageIndex > middleIndex &&\r\n        this._rangeEnd < this.lastPageIndex:\r\n        return this._rangeStart + 1;\r\n\r\n      case this._curPageObj.pageIndex < this._curPageObj.previousPageIndex &&\r\n        this._curPageObj.pageIndex < middleIndex &&\r\n        this._rangeStart > 0:\r\n        return this._rangeStart - 1;\r\n\r\n      default:\r\n        return this._rangeStart;\r\n    }\r\n  }\r\n\r\n  // Helper function to calculate end of button range\r\n  private calcRangeEnd(middleIndex: number): number {\r\n    switch (true) {\r\n      case this._curPageObj.pageIndex === 0 &&\r\n        this._rangeEnd !== this._showTotalPages:\r\n        return this._showTotalPages - 1;\r\n\r\n      case this._curPageObj.pageIndex > this._rangeEnd:\r\n        return this._curPageObj.pageIndex + this.inc > this.lastPageIndex\r\n          ? this.lastPageIndex\r\n          : this._curPageObj.pageIndex + 1;\r\n\r\n      case this._curPageObj.pageIndex > this._curPageObj.previousPageIndex &&\r\n        this._curPageObj.pageIndex > middleIndex &&\r\n        this._rangeEnd < this.lastPageIndex:\r\n        return this._rangeEnd + 1;\r\n\r\n      case this._curPageObj.pageIndex < this._curPageObj.previousPageIndex &&\r\n        this._curPageObj.pageIndex < middleIndex &&\r\n        this._rangeStart >= 0 &&\r\n        this._rangeEnd > this._showTotalPages - 1:\r\n        return this._rangeEnd - 1;\r\n\r\n      default:\r\n        return this._rangeEnd;\r\n    }\r\n  }\r\n}\r\n"]}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import { CommonModule } from '@angular/common';
|
|
2
|
+
import { NgModule } from '@angular/core';
|
|
3
|
+
import { EcabsPaginatorDirective } from './paginator.directive';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
export class EcabsPaginatorDirectiveModule {
|
|
6
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: EcabsPaginatorDirectiveModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
7
|
+
static ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "16.2.12", ngImport: i0, type: EcabsPaginatorDirectiveModule, declarations: [EcabsPaginatorDirective], imports: [CommonModule], exports: [EcabsPaginatorDirective] });
|
|
8
|
+
static ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: EcabsPaginatorDirectiveModule, imports: [CommonModule] });
|
|
9
|
+
}
|
|
10
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: EcabsPaginatorDirectiveModule, decorators: [{
|
|
11
|
+
type: NgModule,
|
|
12
|
+
args: [{
|
|
13
|
+
imports: [CommonModule],
|
|
14
|
+
declarations: [EcabsPaginatorDirective],
|
|
15
|
+
exports: [EcabsPaginatorDirective],
|
|
16
|
+
}]
|
|
17
|
+
}] });
|
|
18
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGFnaW5hdG9yLmRpcmVjdGl2ZS5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9lY2Ficy1jb21wb25lbnRzL3NyYy9saWIvYmFzZS9kaXJlY3RpdmVzL3BhZ2luYXRvci5kaXJlY3RpdmUubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pDLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxNQUFNLHVCQUF1QixDQUFDOztBQU9oRSxNQUFNLE9BQU8sNkJBQTZCO3dHQUE3Qiw2QkFBNkI7eUdBQTdCLDZCQUE2QixpQkFIekIsdUJBQXVCLGFBRDVCLFlBQVksYUFFWix1QkFBdUI7eUdBRXRCLDZCQUE2QixZQUo5QixZQUFZOzs0RkFJWCw2QkFBNkI7a0JBTHpDLFFBQVE7bUJBQUM7b0JBQ1IsT0FBTyxFQUFFLENBQUMsWUFBWSxDQUFDO29CQUN2QixZQUFZLEVBQUUsQ0FBQyx1QkFBdUIsQ0FBQztvQkFDdkMsT0FBTyxFQUFFLENBQUMsdUJBQXVCLENBQUM7aUJBQ25DIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcclxuaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgRWNhYnNQYWdpbmF0b3JEaXJlY3RpdmUgfSBmcm9tICcuL3BhZ2luYXRvci5kaXJlY3RpdmUnO1xyXG5cclxuQE5nTW9kdWxlKHtcclxuICBpbXBvcnRzOiBbQ29tbW9uTW9kdWxlXSxcclxuICBkZWNsYXJhdGlvbnM6IFtFY2Fic1BhZ2luYXRvckRpcmVjdGl2ZV0sXHJcbiAgZXhwb3J0czogW0VjYWJzUGFnaW5hdG9yRGlyZWN0aXZlXSxcclxufSlcclxuZXhwb3J0IGNsYXNzIEVjYWJzUGFnaW5hdG9yRGlyZWN0aXZlTW9kdWxlIHt9XHJcbiJdfQ==
|
|
@@ -5,7 +5,7 @@ import * as i2 from "../../ecabs-loading/spinner/spinner.component";
|
|
|
5
5
|
import * as i3 from "../validation/validation.component";
|
|
6
6
|
import * as i4 from "@angular/material/icon";
|
|
7
7
|
import * as i5 from "@angular/material/legacy-tooltip";
|
|
8
|
-
import * as i6 from "
|
|
8
|
+
import * as i6 from "../../ecabs-hint/ecabs-hint.component";
|
|
9
9
|
export class ElementWrapperComponent {
|
|
10
10
|
data;
|
|
11
11
|
showCloseIcon;
|
|
@@ -29,11 +29,11 @@ export class ElementWrapperComponent {
|
|
|
29
29
|
this.decrease.emit();
|
|
30
30
|
}
|
|
31
31
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ElementWrapperComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
32
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: ElementWrapperComponent, selector: "app-element-wrapper", inputs: { data: "data", showCloseIcon: "showCloseIcon", focusedFlag: "focusedFlag", showPassword: "showPassword", control: "control" }, outputs: { showHidePassword: "showHidePassword", clear: "clear", increase: "increase", decrease: "decrease" }, ngImport: i0, template: "<div\r\n class=\"form-field\"\r\n [ngClass]=\"{\r\n 'form-field--invalid':\r\n data?.showValidation && (data?.control?.touched || data?.showValidationOnNotTouched) && data?.control?.invalid,\r\n disabled: data?.disabled,\r\n 'form-field--required': data?.required && data?.showAsterisk\r\n }\"\r\n>\r\n <div class=\"flex\">\r\n <label
|
|
32
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: ElementWrapperComponent, selector: "app-element-wrapper", inputs: { data: "data", showCloseIcon: "showCloseIcon", focusedFlag: "focusedFlag", showPassword: "showPassword", control: "control" }, outputs: { showHidePassword: "showHidePassword", clear: "clear", increase: "increase", decrease: "decrease" }, ngImport: i0, template: "<div\r\n class=\"form-field\"\r\n [ngClass]=\"{\r\n 'form-field--invalid':\r\n data?.showValidation && (data?.control?.touched || data?.showValidationOnNotTouched) && data?.control?.invalid,\r\n disabled: data?.disabled,\r\n 'form-field--required': data?.required && data?.showAsterisk\r\n }\"\r\n>\r\n <div class=\"flex\">\r\n <label\r\n class=\"form-field__label\"\r\n [attr.for]=\"data?.name\" *ngIf=\"data?.label && data?.showLabel\"\r\n >\r\n <span [innerHTML]=\"data?.label\"></span>\r\n </label>\r\n <mat-icon class=\"icon ml-4 mat-icon-input-tooltip\" matTooltipClass=\"break-line-tooltip\" *ngIf=\"data?.tooltip\"\r\n [matTooltip]=\"data?.tooltip\">error_outline\r\n </mat-icon>\r\n </div>\r\n\r\n <div class=\"form-field__label-note\" *ngIf=\"data?.labelNote\" [innerHTML]=\"data?.labelNote\"></div>\r\n\r\n <ng-content></ng-content>\r\n\r\n <ecabs-loading-spinner class=\"spinner\" size=\"tiny\" *ngIf=\"data.loading\"></ecabs-loading-spinner>\r\n\r\n <ecabs-hint [element]=\"data?.control\" [showHint]=\"data?.showHint\" [maxValue]=\"data?.maxLength\"></ecabs-hint>\r\n\r\n <ecabs-validations-messages\r\n *ngIf=\"data?.showValidation && !data?.hideValidationMessage\"\r\n [element]=\"data?.control\"\r\n [label]=\"data?.label ? data?.label : data?.placeholder ? data.placeholder : data?.validationLabel\"\r\n [showValidationOnNotTouched]=\"data?.showValidationOnNotTouched\"\r\n >\r\n </ecabs-validations-messages>\r\n</div>\r\n", styles: [":host ::ng-deep .break-line-tooltip{white-space:pre-line}:host ::ng-deep .mat-icon-input-tooltip{font-size:18px;height:18px;width:18px}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.EcabsSpinnerComponent, selector: "ecabs-loading-spinner", inputs: ["size"] }, { kind: "component", type: i3.ValidationComponent, selector: "ecabs-validations-messages", inputs: ["element", "label", "showValidationOnNotTouched", "updatedErrors"] }, { kind: "component", type: i4.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "directive", type: i5.MatLegacyTooltip, selector: "[matTooltip]", exportAs: ["matTooltip"] }, { kind: "component", type: i6.EcabsHintComponent, selector: "ecabs-hint", inputs: ["element", "maxValue", "showHint"] }] });
|
|
33
33
|
}
|
|
34
34
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ElementWrapperComponent, decorators: [{
|
|
35
35
|
type: Component,
|
|
36
|
-
args: [{ selector: 'app-element-wrapper', template: "<div\r\n class=\"form-field\"\r\n [ngClass]=\"{\r\n 'form-field--invalid':\r\n data?.showValidation && (data?.control?.touched || data?.showValidationOnNotTouched) && data?.control?.invalid,\r\n disabled: data?.disabled,\r\n 'form-field--required': data?.required && data?.showAsterisk\r\n }\"\r\n>\r\n <div class=\"flex\">\r\n <label
|
|
36
|
+
args: [{ selector: 'app-element-wrapper', template: "<div\r\n class=\"form-field\"\r\n [ngClass]=\"{\r\n 'form-field--invalid':\r\n data?.showValidation && (data?.control?.touched || data?.showValidationOnNotTouched) && data?.control?.invalid,\r\n disabled: data?.disabled,\r\n 'form-field--required': data?.required && data?.showAsterisk\r\n }\"\r\n>\r\n <div class=\"flex\">\r\n <label\r\n class=\"form-field__label\"\r\n [attr.for]=\"data?.name\" *ngIf=\"data?.label && data?.showLabel\"\r\n >\r\n <span [innerHTML]=\"data?.label\"></span>\r\n </label>\r\n <mat-icon class=\"icon ml-4 mat-icon-input-tooltip\" matTooltipClass=\"break-line-tooltip\" *ngIf=\"data?.tooltip\"\r\n [matTooltip]=\"data?.tooltip\">error_outline\r\n </mat-icon>\r\n </div>\r\n\r\n <div class=\"form-field__label-note\" *ngIf=\"data?.labelNote\" [innerHTML]=\"data?.labelNote\"></div>\r\n\r\n <ng-content></ng-content>\r\n\r\n <ecabs-loading-spinner class=\"spinner\" size=\"tiny\" *ngIf=\"data.loading\"></ecabs-loading-spinner>\r\n\r\n <ecabs-hint [element]=\"data?.control\" [showHint]=\"data?.showHint\" [maxValue]=\"data?.maxLength\"></ecabs-hint>\r\n\r\n <ecabs-validations-messages\r\n *ngIf=\"data?.showValidation && !data?.hideValidationMessage\"\r\n [element]=\"data?.control\"\r\n [label]=\"data?.label ? data?.label : data?.placeholder ? data.placeholder : data?.validationLabel\"\r\n [showValidationOnNotTouched]=\"data?.showValidationOnNotTouched\"\r\n >\r\n </ecabs-validations-messages>\r\n</div>\r\n", styles: [":host ::ng-deep .break-line-tooltip{white-space:pre-line}:host ::ng-deep .mat-icon-input-tooltip{font-size:18px;height:18px;width:18px}\n"] }]
|
|
37
37
|
}], propDecorators: { data: [{
|
|
38
38
|
type: Input
|
|
39
39
|
}], showCloseIcon: [{
|
|
@@ -53,4 +53,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
53
53
|
}], decrease: [{
|
|
54
54
|
type: Output
|
|
55
55
|
}] } });
|
|
56
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
56
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWxlbWVudC13cmFwcGVyLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2VjYWJzLWNvbXBvbmVudHMvc3JjL2xpYi9iYXNlL2VsZW1lbnQtd3JhcHBlci9lbGVtZW50LXdyYXBwZXIuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZWNhYnMtY29tcG9uZW50cy9zcmMvbGliL2Jhc2UvZWxlbWVudC13cmFwcGVyL2VsZW1lbnQtd3JhcHBlci5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBRSxNQUFNLEVBQUUsWUFBWSxFQUFFLE1BQU0sZUFBZSxDQUFDOzs7Ozs7OztBQU92RSxNQUFNLE9BQU8sdUJBQXVCO0lBQ3pCLElBQUksQ0FBTztJQUNYLGFBQWEsQ0FBVztJQUN4QixXQUFXLENBQU87SUFDbEIsWUFBWSxDQUFXO0lBQ3ZCLE9BQU8sQ0FBTztJQUNiLGdCQUFnQixHQUFHLElBQUksWUFBWSxFQUFPLENBQUM7SUFDM0MsS0FBSyxHQUFHLElBQUksWUFBWSxFQUFPLENBQUM7SUFDaEMsUUFBUSxHQUFHLElBQUksWUFBWSxFQUFPLENBQUM7SUFDbkMsUUFBUSxHQUFHLElBQUksWUFBWSxFQUFPLENBQUM7SUFFN0Msa0JBQWtCLENBQUMsS0FBVTtRQUMzQixJQUFJLENBQUMsZ0JBQWdCLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQ3BDLENBQUM7SUFFRCxPQUFPO1FBQ0wsSUFBSSxDQUFDLEtBQUssQ0FBQyxJQUFJLEVBQUUsQ0FBQztJQUNwQixDQUFDO0lBRUQsVUFBVTtRQUNSLElBQUksQ0FBQyxRQUFRLENBQUMsSUFBSSxFQUFFLENBQUM7SUFDdkIsQ0FBQztJQUVELFVBQVU7UUFDUixJQUFJLENBQUMsUUFBUSxDQUFDLElBQUksRUFBRSxDQUFDO0lBQ3ZCLENBQUM7d0dBekJVLHVCQUF1Qjs0RkFBdkIsdUJBQXVCLGtUQ1BwQyxvL0NBcUNBOzs0RkQ5QmEsdUJBQXVCO2tCQUxuQyxTQUFTOytCQUNFLHFCQUFxQjs4QkFLdEIsSUFBSTtzQkFBWixLQUFLO2dCQUNHLGFBQWE7c0JBQXJCLEtBQUs7Z0JBQ0csV0FBVztzQkFBbkIsS0FBSztnQkFDRyxZQUFZO3NCQUFwQixLQUFLO2dCQUNHLE9BQU87c0JBQWYsS0FBSztnQkFDSSxnQkFBZ0I7c0JBQXpCLE1BQU07Z0JBQ0csS0FBSztzQkFBZCxNQUFNO2dCQUNHLFFBQVE7c0JBQWpCLE1BQU07Z0JBQ0csUUFBUTtzQkFBakIsTUFBTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgSW5wdXQsIE91dHB1dCwgRXZlbnRFbWl0dGVyIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcblxyXG5AQ29tcG9uZW50KHtcclxuICBzZWxlY3RvcjogJ2FwcC1lbGVtZW50LXdyYXBwZXInLFxyXG4gIHRlbXBsYXRlVXJsOiAnLi9lbGVtZW50LXdyYXBwZXIuY29tcG9uZW50Lmh0bWwnLFxyXG4gIHN0eWxlVXJsczogWycuL2VsZW1lbnQtd3JhcHBlci5jb21wb25lbnQuc2NzcyddLFxyXG59KVxyXG5leHBvcnQgY2xhc3MgRWxlbWVudFdyYXBwZXJDb21wb25lbnQge1xyXG4gIEBJbnB1dCgpIGRhdGEhOiBhbnk7XHJcbiAgQElucHV0KCkgc2hvd0Nsb3NlSWNvbiE6IGJvb2xlYW47XHJcbiAgQElucHV0KCkgZm9jdXNlZEZsYWchOiBhbnk7XHJcbiAgQElucHV0KCkgc2hvd1Bhc3N3b3JkITogYm9vbGVhbjtcclxuICBASW5wdXQoKSBjb250cm9sITogYW55O1xyXG4gIEBPdXRwdXQoKSBzaG93SGlkZVBhc3N3b3JkID0gbmV3IEV2ZW50RW1pdHRlcjxhbnk+KCk7XHJcbiAgQE91dHB1dCgpIGNsZWFyID0gbmV3IEV2ZW50RW1pdHRlcjxhbnk+KCk7XHJcbiAgQE91dHB1dCgpIGluY3JlYXNlID0gbmV3IEV2ZW50RW1pdHRlcjxhbnk+KCk7XHJcbiAgQE91dHB1dCgpIGRlY3JlYXNlID0gbmV3IEV2ZW50RW1pdHRlcjxhbnk+KCk7XHJcblxyXG4gIHNob3dIaWRlUGFzc3dvcmRGbihldmVudDogYW55KTogdm9pZCB7XHJcbiAgICB0aGlzLnNob3dIaWRlUGFzc3dvcmQuZW1pdChldmVudCk7XHJcbiAgfVxyXG5cclxuICBjbGVhckZuKCk6IHZvaWQge1xyXG4gICAgdGhpcy5jbGVhci5lbWl0KCk7XHJcbiAgfVxyXG5cclxuICBpbmNyZWFzZUZuKCk6IHZvaWQge1xyXG4gICAgdGhpcy5pbmNyZWFzZS5lbWl0KCk7XHJcbiAgfVxyXG5cclxuICBkZWNyZWFzZUZuKCk6IHZvaWQge1xyXG4gICAgdGhpcy5kZWNyZWFzZS5lbWl0KCk7XHJcbiAgfVxyXG59XHJcbiIsIjxkaXZcclxuICBjbGFzcz1cImZvcm0tZmllbGRcIlxyXG4gIFtuZ0NsYXNzXT1cIntcclxuICAgICdmb3JtLWZpZWxkLS1pbnZhbGlkJzpcclxuICAgICAgZGF0YT8uc2hvd1ZhbGlkYXRpb24gJiYgKGRhdGE/LmNvbnRyb2w/LnRvdWNoZWQgfHwgZGF0YT8uc2hvd1ZhbGlkYXRpb25Pbk5vdFRvdWNoZWQpICYmIGRhdGE/LmNvbnRyb2w/LmludmFsaWQsXHJcbiAgICBkaXNhYmxlZDogZGF0YT8uZGlzYWJsZWQsXHJcbiAgICAnZm9ybS1maWVsZC0tcmVxdWlyZWQnOiBkYXRhPy5yZXF1aXJlZCAmJiBkYXRhPy5zaG93QXN0ZXJpc2tcclxuICB9XCJcclxuPlxyXG4gIDxkaXYgY2xhc3M9XCJmbGV4XCI+XHJcbiAgICA8bGFiZWxcclxuICAgICAgY2xhc3M9XCJmb3JtLWZpZWxkX19sYWJlbFwiXHJcbiAgICAgIFthdHRyLmZvcl09XCJkYXRhPy5uYW1lXCIgKm5nSWY9XCJkYXRhPy5sYWJlbCAmJiBkYXRhPy5zaG93TGFiZWxcIlxyXG4gICAgPlxyXG4gICAgICA8c3BhbiBbaW5uZXJIVE1MXT1cImRhdGE/LmxhYmVsXCI+PC9zcGFuPlxyXG4gICAgPC9sYWJlbD5cclxuICAgIDxtYXQtaWNvbiBjbGFzcz1cImljb24gbWwtNCBtYXQtaWNvbi1pbnB1dC10b29sdGlwXCIgbWF0VG9vbHRpcENsYXNzPVwiYnJlYWstbGluZS10b29sdGlwXCIgKm5nSWY9XCJkYXRhPy50b29sdGlwXCJcclxuICAgICAgICAgICAgICBbbWF0VG9vbHRpcF09XCJkYXRhPy50b29sdGlwXCI+ZXJyb3Jfb3V0bGluZVxyXG4gICAgPC9tYXQtaWNvbj5cclxuICA8L2Rpdj5cclxuXHJcbiAgPGRpdiBjbGFzcz1cImZvcm0tZmllbGRfX2xhYmVsLW5vdGVcIiAqbmdJZj1cImRhdGE/LmxhYmVsTm90ZVwiIFtpbm5lckhUTUxdPVwiZGF0YT8ubGFiZWxOb3RlXCI+PC9kaXY+XHJcblxyXG4gIDxuZy1jb250ZW50PjwvbmctY29udGVudD5cclxuXHJcbiAgPGVjYWJzLWxvYWRpbmctc3Bpbm5lciBjbGFzcz1cInNwaW5uZXJcIiBzaXplPVwidGlueVwiICpuZ0lmPVwiZGF0YS5sb2FkaW5nXCI+PC9lY2Ficy1sb2FkaW5nLXNwaW5uZXI+XHJcblxyXG4gIDxlY2Ficy1oaW50IFtlbGVtZW50XT1cImRhdGE/LmNvbnRyb2xcIiBbc2hvd0hpbnRdPVwiZGF0YT8uc2hvd0hpbnRcIiBbbWF4VmFsdWVdPVwiZGF0YT8ubWF4TGVuZ3RoXCI+PC9lY2Ficy1oaW50PlxyXG5cclxuICA8ZWNhYnMtdmFsaWRhdGlvbnMtbWVzc2FnZXNcclxuICAgICpuZ0lmPVwiZGF0YT8uc2hvd1ZhbGlkYXRpb24gJiYgIWRhdGE/LmhpZGVWYWxpZGF0aW9uTWVzc2FnZVwiXHJcbiAgICBbZWxlbWVudF09XCJkYXRhPy5jb250cm9sXCJcclxuICAgIFtsYWJlbF09XCJkYXRhPy5sYWJlbCA/IGRhdGE/LmxhYmVsIDogZGF0YT8ucGxhY2Vob2xkZXIgPyBkYXRhLnBsYWNlaG9sZGVyIDogZGF0YT8udmFsaWRhdGlvbkxhYmVsXCJcclxuICAgIFtzaG93VmFsaWRhdGlvbk9uTm90VG91Y2hlZF09XCJkYXRhPy5zaG93VmFsaWRhdGlvbk9uTm90VG91Y2hlZFwiXHJcbiAgPlxyXG4gIDwvZWNhYnMtdmFsaWRhdGlvbnMtbWVzc2FnZXM+XHJcbjwvZGl2PlxyXG4iXX0=
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import { CommonModule } from '@angular/common';
|
|
2
2
|
import { NgModule } from '@angular/core';
|
|
3
3
|
import { FormsModule } from '@angular/forms';
|
|
4
|
-
import {
|
|
4
|
+
import { EcabsHintModule } from '../../ecabs-hint/ecabs-hint.module';
|
|
5
5
|
import { EcabsValidationModule } from '../validation/validation.module';
|
|
6
6
|
import { ElementWrapperComponent } from './element-wrapper.component';
|
|
7
7
|
import { MatIconModule } from '@angular/material/icon';
|
|
@@ -29,7 +29,7 @@ export class ElementWrapperModule {
|
|
|
29
29
|
MatFormFieldModule,
|
|
30
30
|
MatIconModule,
|
|
31
31
|
MatTooltipModule,
|
|
32
|
-
|
|
32
|
+
EcabsHintModule], exports: [ElementWrapperComponent] });
|
|
33
33
|
static ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ElementWrapperModule, providers: [
|
|
34
34
|
{
|
|
35
35
|
provide: MAT_FORM_FIELD_DEFAULT_OPTIONS,
|
|
@@ -47,7 +47,7 @@ export class ElementWrapperModule {
|
|
|
47
47
|
MatFormFieldModule,
|
|
48
48
|
MatIconModule,
|
|
49
49
|
MatTooltipModule,
|
|
50
|
-
|
|
50
|
+
EcabsHintModule] });
|
|
51
51
|
}
|
|
52
52
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ElementWrapperModule, decorators: [{
|
|
53
53
|
type: NgModule,
|
|
@@ -61,7 +61,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
61
61
|
MatFormFieldModule,
|
|
62
62
|
MatIconModule,
|
|
63
63
|
MatTooltipModule,
|
|
64
|
-
|
|
64
|
+
EcabsHintModule,
|
|
65
65
|
],
|
|
66
66
|
providers: [
|
|
67
67
|
{
|
|
@@ -77,4 +77,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
77
77
|
exports: [ElementWrapperComponent],
|
|
78
78
|
}]
|
|
79
79
|
}] });
|
|
80
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
80
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWxlbWVudC13cmFwcGVyLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2VjYWJzLWNvbXBvbmVudHMvc3JjL2xpYi9iYXNlL2VsZW1lbnQtd3JhcHBlci9lbGVtZW50LXdyYXBwZXIubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pDLE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUU3QyxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sb0NBQW9DLENBQUM7QUFDckUsT0FBTyxFQUFFLHFCQUFxQixFQUFFLE1BQU0saUNBQWlDLENBQUM7QUFDeEUsT0FBTyxFQUFFLHVCQUF1QixFQUFFLE1BQU0sNkJBQTZCLENBQUM7QUFDdEUsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLHdCQUF3QixDQUFDO0FBQ3ZELE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLDBDQUEwQyxDQUFDO0FBQzlFLE9BQU8sRUFDTCw4QkFBOEIsRUFFOUIsa0JBQWtCLEdBQ25CLE1BQU0sOEJBQThCLENBQUM7QUFDdEMsT0FBTyxFQUFFLHNCQUFzQixJQUFJLGdCQUFnQixFQUFFLE1BQU0sa0NBQWtDLENBQUM7QUFDOUYsT0FBTyxFQUF1QixPQUFPLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQztBQUNwRSxPQUFPLEVBQUUsMEJBQTBCLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQzs7QUFFdEUsTUFBTSxVQUFVLEdBQStCO0lBQzdDLFVBQVUsRUFBRSxTQUFTO0lBQ3JCLFVBQVUsRUFBRSxRQUFRO0lBQ3BCLGtCQUFrQixFQUFFLElBQUk7SUFDeEIsZUFBZSxFQUFFLFNBQVM7Q0FDM0IsQ0FBQztBQUVGLE1BQU0sVUFBVSxhQUFhLENBQUMsT0FBZ0I7SUFDNUMsT0FBTyxHQUFHLEVBQUUsQ0FBQyxPQUFPLENBQUMsZ0JBQWdCLENBQUMsS0FBSyxFQUFFLENBQUM7QUFDaEQsQ0FBQztBQTJCRCxNQUFNLE9BQU8sb0JBQW9CO3dHQUFwQixvQkFBb0I7eUdBQXBCLG9CQUFvQixpQkF4QmhCLHVCQUF1QixhQUVwQyxZQUFZO1lBQ1osV0FBVztZQUNYLGtCQUFrQjtZQUNsQixxQkFBcUI7WUFDckIsa0JBQWtCO1lBQ2xCLGFBQWE7WUFDYixnQkFBZ0I7WUFDaEIsZUFBZSxhQWFQLHVCQUF1Qjt5R0FFdEIsb0JBQW9CLGFBYnBCO1lBQ1Q7Z0JBQ0UsT0FBTyxFQUFFLDhCQUE4QjtnQkFDdkMsUUFBUSxFQUFFLFVBQVU7YUFDckI7WUFDRDtnQkFDRSxPQUFPLEVBQUUsMEJBQTBCO2dCQUNuQyxVQUFVLEVBQUUsYUFBYTtnQkFDekIsSUFBSSxFQUFFLENBQUMsT0FBTyxDQUFDO2FBQ2hCO1NBQ0YsWUFuQkMsWUFBWTtZQUNaLFdBQVc7WUFDWCxrQkFBa0I7WUFDbEIscUJBQXFCO1lBQ3JCLGtCQUFrQjtZQUNsQixhQUFhO1lBQ2IsZ0JBQWdCO1lBQ2hCLGVBQWU7OzRGQWVOLG9CQUFvQjtrQkF6QmhDLFFBQVE7bUJBQUM7b0JBQ1IsWUFBWSxFQUFFLENBQUMsdUJBQXVCLENBQUM7b0JBQ3ZDLE9BQU8sRUFBRTt3QkFDUCxZQUFZO3dCQUNaLFdBQVc7d0JBQ1gsa0JBQWtCO3dCQUNsQixxQkFBcUI7d0JBQ3JCLGtCQUFrQjt3QkFDbEIsYUFBYTt3QkFDYixnQkFBZ0I7d0JBQ2hCLGVBQWU7cUJBQ2hCO29CQUNELFNBQVMsRUFBRTt3QkFDVDs0QkFDRSxPQUFPLEVBQUUsOEJBQThCOzRCQUN2QyxRQUFRLEVBQUUsVUFBVTt5QkFDckI7d0JBQ0Q7NEJBQ0UsT0FBTyxFQUFFLDBCQUEwQjs0QkFDbkMsVUFBVSxFQUFFLGFBQWE7NEJBQ3pCLElBQUksRUFBRSxDQUFDLE9BQU8sQ0FBQzt5QkFDaEI7cUJBQ0Y7b0JBQ0QsT0FBTyxFQUFFLENBQUMsdUJBQXVCLENBQUM7aUJBQ25DIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcclxuaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgRm9ybXNNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XHJcblxyXG5pbXBvcnQgeyBFY2Fic0hpbnRNb2R1bGUgfSBmcm9tICcuLi8uLi9lY2Ficy1oaW50L2VjYWJzLWhpbnQubW9kdWxlJztcclxuaW1wb3J0IHsgRWNhYnNWYWxpZGF0aW9uTW9kdWxlIH0gZnJvbSAnLi4vdmFsaWRhdGlvbi92YWxpZGF0aW9uLm1vZHVsZSc7XHJcbmltcG9ydCB7IEVsZW1lbnRXcmFwcGVyQ29tcG9uZW50IH0gZnJvbSAnLi9lbGVtZW50LXdyYXBwZXIuY29tcG9uZW50JztcclxuaW1wb3J0IHsgTWF0SWNvbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2ljb24nO1xyXG5pbXBvcnQgeyBFY2Fic0xvYWRpbmdNb2R1bGUgfSBmcm9tICcuLi8uLi9lY2Ficy1sb2FkaW5nL2VjYWJzLWxvYWRpbmcubW9kdWxlJztcclxuaW1wb3J0IHtcclxuICBNQVRfRk9STV9GSUVMRF9ERUZBVUxUX09QVElPTlMsXHJcbiAgTWF0Rm9ybUZpZWxkRGVmYXVsdE9wdGlvbnMsXHJcbiAgTWF0Rm9ybUZpZWxkTW9kdWxlLFxyXG59IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2Zvcm0tZmllbGQnO1xyXG5pbXBvcnQgeyBNYXRMZWdhY3lUb29sdGlwTW9kdWxlIGFzIE1hdFRvb2x0aXBNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9sZWdhY3ktdG9vbHRpcCc7XHJcbmltcG9ydCB7IEJsb2NrU2Nyb2xsU3RyYXRlZ3ksIE92ZXJsYXkgfSBmcm9tICdAYW5ndWxhci9jZGsvb3ZlcmxheSc7XHJcbmltcG9ydCB7IE1BVF9TRUxFQ1RfU0NST0xMX1NUUkFURUdZIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvc2VsZWN0JztcclxuXHJcbmNvbnN0IGFwcGVhcmFuY2U6IE1hdEZvcm1GaWVsZERlZmF1bHRPcHRpb25zID0ge1xyXG4gIGFwcGVhcmFuY2U6ICdvdXRsaW5lJyxcclxuICBmbG9hdExhYmVsOiAnYWx3YXlzJyxcclxuICBoaWRlUmVxdWlyZWRNYXJrZXI6IHRydWUsXHJcbiAgc3Vic2NyaXB0U2l6aW5nOiAnZHluYW1pYycsXHJcbn07XHJcblxyXG5leHBvcnQgZnVuY3Rpb24gc2Nyb2xsRmFjdG9yeShvdmVybGF5OiBPdmVybGF5KTogKCkgPT4gQmxvY2tTY3JvbGxTdHJhdGVneSB7XHJcbiAgcmV0dXJuICgpID0+IG92ZXJsYXkuc2Nyb2xsU3RyYXRlZ2llcy5ibG9jaygpO1xyXG59XHJcblxyXG5ATmdNb2R1bGUoe1xyXG4gIGRlY2xhcmF0aW9uczogW0VsZW1lbnRXcmFwcGVyQ29tcG9uZW50XSxcclxuICBpbXBvcnRzOiBbXHJcbiAgICBDb21tb25Nb2R1bGUsXHJcbiAgICBGb3Jtc01vZHVsZSxcclxuICAgIEVjYWJzTG9hZGluZ01vZHVsZSxcclxuICAgIEVjYWJzVmFsaWRhdGlvbk1vZHVsZSxcclxuICAgIE1hdEZvcm1GaWVsZE1vZHVsZSxcclxuICAgIE1hdEljb25Nb2R1bGUsXHJcbiAgICBNYXRUb29sdGlwTW9kdWxlLFxyXG4gICAgRWNhYnNIaW50TW9kdWxlLFxyXG4gIF0sXHJcbiAgcHJvdmlkZXJzOiBbXHJcbiAgICB7XHJcbiAgICAgIHByb3ZpZGU6IE1BVF9GT1JNX0ZJRUxEX0RFRkFVTFRfT1BUSU9OUyxcclxuICAgICAgdXNlVmFsdWU6IGFwcGVhcmFuY2UsXHJcbiAgICB9LFxyXG4gICAge1xyXG4gICAgICBwcm92aWRlOiBNQVRfU0VMRUNUX1NDUk9MTF9TVFJBVEVHWSxcclxuICAgICAgdXNlRmFjdG9yeTogc2Nyb2xsRmFjdG9yeSxcclxuICAgICAgZGVwczogW092ZXJsYXldLFxyXG4gICAgfSxcclxuICBdLFxyXG4gIGV4cG9ydHM6IFtFbGVtZW50V3JhcHBlckNvbXBvbmVudF0sXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBFbGVtZW50V3JhcHBlck1vZHVsZSB7fVxyXG4iXX0=
|
|
@@ -143,4 +143,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
143
143
|
}], onblur: [{
|
|
144
144
|
type: Output
|
|
145
145
|
}] } });
|
|
146
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ecabs-date-picker.component.js","sourceRoot":"","sources":["../../../../../projects/ecabs-components/src/lib/ecabs-date-picker/ecabs-date-picker.component.ts","../../../../../projects/ecabs-components/src/lib/ecabs-date-picker/ecabs-date-picker.component.html"],"names":[],"mappings":"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","sourcesContent":["import { format, isEqual, isValid } from 'date-fns';\r\nimport { takeUntil } from 'rxjs';\r\nimport Holidays from 'date-holidays';\r\n\r\nimport {\r\n  AfterViewInit,\r\n  Component,\r\n  EventEmitter,\r\n  Injector,\r\n  Input,\r\n  OnInit,\r\n  Output,\r\n} from '@angular/core';\r\nimport {\r\n  ControlValueAccessor,\r\n  NG_VALUE_ACCESSOR,\r\n  NgControl,\r\n  UntypedFormControl,\r\n} from '@angular/forms';\r\n\r\nimport ElementBaseComponent from '../base/element-base';\r\nimport {\r\n  EcabsDatePickerHolidayOptions,\r\n  EcabsDatePickerTranslations,\r\n} from '../base/models/ecabs-date-picker-translations.models';\r\n\r\nimport { EcabsDatePickerHeaderService } from '../base/services/ecabs-date-picker-translations.service';\r\nimport { UnsubscribeService } from '../base/services/unsubscribe.service';\r\n\r\nimport { EcabsDatePickerHeaderComponent } from './components/ecabs-date-picker-header/ecabs-date-picker-header.component';\r\n\r\n@Component( {\r\n  selector: 'ecabs-date-picker',\r\n  templateUrl: './ecabs-date-picker.component.html',\r\n  styleUrls: [ './ecabs-date-picker.component.scss' ],\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      useExisting: EcabsDatePickerComponent,\r\n      multi: true,\r\n    },\r\n    UnsubscribeService,\r\n  ],\r\n} )\r\nexport class EcabsDatePickerComponent\r\n  extends ElementBaseComponent\r\n  implements ControlValueAccessor, AfterViewInit, OnInit {\r\n  @Input() minDate: Date;\r\n  @Input() maxDate: Date;\r\n  @Input() touchUi = false;\r\n  @Input() cancelLabel: string;\r\n  @Input() applyLabel: string;\r\n  @Input() excludeHolidays: boolean;\r\n  @Input() excludeWeekends: boolean;\r\n  @Input() specificDates: Date[];\r\n  @Input() holidayOptions: EcabsDatePickerHolidayOptions;\r\n\r\n  @Output() onblur = new EventEmitter<any>();\r\n\r\n  val: string | number;\r\n  header = EcabsDatePickerHeaderComponent;\r\n  translationConfig: EcabsDatePickerTranslations;\r\n\r\n  get value(): string | number {\r\n    return this.val;\r\n  }\r\n\r\n  set value( val: string | number ) {\r\n    if ( this.val !== val && ( !val || isValid( new Date( val ) ) ) ) {\r\n      this.val = val;\r\n      this.onChange( val );\r\n      this.onTouch( val );\r\n    }\r\n  }\r\n\r\n  constructor(\r\n    private readonly injector: Injector,\r\n    private readonly ecabsDatePickerHeaderService: EcabsDatePickerHeaderService,\r\n    private readonly unsubscribeService: UnsubscribeService,\r\n  ) {\r\n    super();\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    this.ecabsDatePickerHeaderService\r\n      .getConfig()\r\n      .pipe( takeUntil( this.unsubscribeService.subscription() ) )\r\n      .subscribe( ( config ) => ( this.translationConfig = config ) );\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    const ngControl: NgControl = this.injector.get( NgControl, null );\r\n    if ( ngControl ) {\r\n      this.control = ngControl.control as UntypedFormControl;\r\n    }\r\n  }\r\n\r\n  onChange: any = () => { };\r\n  onTouch: any = () => { };\r\n\r\n  writeValue( value: any ): void {\r\n    this.value = value;\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.onTouch = fn;\r\n  }\r\n\r\n  blurChange( e: any ): void {\r\n    this.onblur.emit( e );\r\n  }\r\n\r\n  isDateNotHoliday( date: Date ): boolean {\r\n    const { countryCode, timeZoneOffset } = this.holidayOptions ?? {};\r\n\r\n    if ( countryCode && timeZoneOffset ) {\r\n      const holiday = new Holidays( countryCode.toUpperCase() );\r\n\r\n      return !holiday.isHoliday(\r\n        `${ format( date, 'yyyy-MM-dd' ) }T00:00:00${ timeZoneOffset }`,\r\n      );\r\n    }\r\n\r\n    return true;\r\n  }\r\n\r\n  filterDateRange = ( date: Date ): boolean => {\r\n    let result = true;\r\n\r\n    if ( isValid( new Date( date ) ) ) {\r\n      const day = date?.getDay();\r\n\r\n      if ( this.excludeWeekends ) {\r\n        result = result && day !== 0 && day !== 6;\r\n      }\r\n\r\n      if ( this.excludeHolidays ) {\r\n        result = result && this.isDateNotHoliday( date );\r\n      }\r\n\r\n      if ( this.specificDates?.length > 0 ) {\r\n        const specificDates = this.specificDates;\r\n        if ( specificDates && specificDates.length > 0 ) {\r\n          const index = specificDates.findIndex( ( specificDate ) =>\r\n            isEqual( date, specificDate ),\r\n          );\r\n          result = result && index === -1;\r\n        }\r\n      }\r\n    }\r\n\r\n    return result;\r\n  };\r\n}\r\n","<app-element-wrapper [data]=\"getData()\">\r\n  <div class=\"form-field__input--wrapper\">\r\n    <input\r\n      class=\"form-field__input date-input\"\r\n      [id]=\"name\"\r\n      [(ngModel)]=\"value\"\r\n      [placeholder]=\"placeholder\"\r\n      [disabled]=\"disabled\"\r\n      [matDatepicker]=\"picker\"\r\n      [min]=\"minDate\"\r\n      [max]=\"maxDate\"\r\n      [matDatepickerFilter]=\"filterDateRange\"\r\n      (blur)=\"onTouch()\"\r\n    />\r\n    <mat-datepicker-toggle\r\n      matSuffix [for]=\"picker\"\r\n      class=\"text-gray-500\"\r\n    >\r\n      <mat-icon matDatepickerToggleIcon>calendar_today</mat-icon>\r\n    </mat-datepicker-toggle>\r\n    <mat-datepicker #picker\r\n      [calendarHeaderComponent]=\"header\"\r\n      [touchUi]=\"touchUi\"\r\n    >\r\n      <mat-datepicker-actions>\r\n        <ecabs-date-picker-actions\r\n          [applyLabel]=\"applyLabel ?? translationConfig?.applyLabel\"\r\n          [cancelLabel]=\"cancelLabel ?? translationConfig?.cancelLabel\"\r\n        >\r\n        </ecabs-date-picker-actions>\r\n      </mat-datepicker-actions>\r\n    </mat-datepicker>\r\n  </div>\r\n</app-element-wrapper>\r\n"]}
|
|
146
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ecabs-date-picker.component.js","sourceRoot":"","sources":["../../../../../projects/ecabs-components/src/lib/ecabs-date-picker/ecabs-date-picker.component.ts","../../../../../projects/ecabs-components/src/lib/ecabs-date-picker/ecabs-date-picker.component.html"],"names":[],"mappings":"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","sourcesContent":["import { format, isEqual, isValid } from 'date-fns';\r\nimport { takeUntil } from 'rxjs';\r\nimport Holidays from 'date-holidays';\r\n\r\nimport {\r\n  AfterViewInit,\r\n  Component,\r\n  EventEmitter,\r\n  Injector,\r\n  Input,\r\n  OnInit,\r\n  Output,\r\n} from '@angular/core';\r\nimport {\r\n  ControlValueAccessor,\r\n  NG_VALUE_ACCESSOR,\r\n  NgControl,\r\n  UntypedFormControl,\r\n} from '@angular/forms';\r\n\r\nimport ElementBaseComponent from '../base/element-base';\r\nimport {\r\n  EcabsDatePickerHolidayOptions,\r\n  EcabsDatePickerTranslations,\r\n} from '../base/models/ecabs-date-picker-translations.models';\r\n\r\nimport { EcabsDatePickerHeaderService } from '../base/services/ecabs-date-picker-translations.service';\r\nimport { UnsubscribeService } from '../base/services/unsubscribe.service';\r\n\r\nimport { EcabsDatePickerHeaderComponent } from './components/ecabs-date-picker-header/ecabs-date-picker-header.component';\r\n\r\n@Component({\r\n  selector: 'ecabs-date-picker',\r\n  templateUrl: './ecabs-date-picker.component.html',\r\n  styleUrls: ['./ecabs-date-picker.component.scss'],\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      useExisting: EcabsDatePickerComponent,\r\n      multi: true,\r\n    },\r\n    UnsubscribeService,\r\n  ],\r\n})\r\nexport class EcabsDatePickerComponent\r\n  extends ElementBaseComponent\r\n  implements ControlValueAccessor, AfterViewInit, OnInit\r\n{\r\n  @Input() minDate: Date;\r\n  @Input() maxDate: Date;\r\n  @Input() touchUi = false;\r\n  @Input() cancelLabel: string;\r\n  @Input() applyLabel: string;\r\n  @Input() excludeHolidays: boolean;\r\n  @Input() excludeWeekends: boolean;\r\n  @Input() specificDates: Date[];\r\n  @Input() holidayOptions: EcabsDatePickerHolidayOptions;\r\n\r\n  @Output() onblur = new EventEmitter<any>();\r\n\r\n  val: string | number;\r\n  header = EcabsDatePickerHeaderComponent;\r\n  translationConfig: EcabsDatePickerTranslations;\r\n\r\n  get value(): string | number {\r\n    return this.val;\r\n  }\r\n\r\n  set value(val: string | number) {\r\n    if (this.val !== val && (!val || isValid(new Date(val)))) {\r\n      this.val = val;\r\n      this.onChange(val);\r\n      this.onTouch(val);\r\n    }\r\n  }\r\n\r\n  constructor(\r\n    private readonly injector: Injector,\r\n    private readonly ecabsDatePickerHeaderService: EcabsDatePickerHeaderService,\r\n    private readonly unsubscribeService: UnsubscribeService,\r\n  ) {\r\n    super();\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    this.ecabsDatePickerHeaderService\r\n      .getConfig()\r\n      .pipe(takeUntil(this.unsubscribeService.subscription()))\r\n      .subscribe((config) => (this.translationConfig = config));\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    const ngControl: NgControl = this.injector.get(NgControl, null);\r\n    if (ngControl) {\r\n      this.control = ngControl.control as UntypedFormControl;\r\n    }\r\n  }\r\n\r\n  onChange: any = () => {};\r\n  onTouch: any = () => {};\r\n\r\n  writeValue(value: any): void {\r\n    this.value = value;\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.onTouch = fn;\r\n  }\r\n\r\n  blurChange(e: any): void {\r\n    this.onblur.emit(e);\r\n  }\r\n\r\n  isDateNotHoliday(date: Date): boolean {\r\n    const { countryCode, timeZoneOffset } = this.holidayOptions ?? {};\r\n\r\n    if (countryCode && timeZoneOffset) {\r\n      const holiday = new Holidays(countryCode.toUpperCase());\r\n\r\n      return !holiday.isHoliday(\r\n        `${format(date, 'yyyy-MM-dd')}T00:00:00${timeZoneOffset}`,\r\n      );\r\n    }\r\n\r\n    return true;\r\n  }\r\n\r\n  filterDateRange = (date: Date): boolean => {\r\n    let result = true;\r\n\r\n    if (isValid(new Date(date))) {\r\n      const day = date?.getDay();\r\n\r\n      if (this.excludeWeekends) {\r\n        result = result && day !== 0 && day !== 6;\r\n      }\r\n\r\n      if (this.excludeHolidays) {\r\n        result = result && this.isDateNotHoliday(date);\r\n      }\r\n\r\n      if (this.specificDates?.length > 0) {\r\n        const specificDates = this.specificDates;\r\n        if (specificDates && specificDates.length > 0) {\r\n          const index = specificDates.findIndex((specificDate) =>\r\n            isEqual(date, specificDate),\r\n          );\r\n          result = result && index === -1;\r\n        }\r\n      }\r\n    }\r\n\r\n    return result;\r\n  };\r\n}\r\n","<app-element-wrapper [data]=\"getData()\">\r\n  <div class=\"form-field__input--wrapper\">\r\n    <input\r\n      class=\"form-field__input date-input\"\r\n      [id]=\"name\"\r\n      [(ngModel)]=\"value\"\r\n      [placeholder]=\"placeholder\"\r\n      [disabled]=\"disabled\"\r\n      [matDatepicker]=\"picker\"\r\n      [min]=\"minDate\"\r\n      [max]=\"maxDate\"\r\n      [matDatepickerFilter]=\"filterDateRange\"\r\n      (blur)=\"onTouch()\"\r\n    />\r\n    <mat-datepicker-toggle\r\n      matSuffix [for]=\"picker\"\r\n      class=\"text-gray-500\"\r\n    >\r\n      <mat-icon matDatepickerToggleIcon>calendar_today</mat-icon>\r\n    </mat-datepicker-toggle>\r\n    <mat-datepicker #picker\r\n      [calendarHeaderComponent]=\"header\"\r\n      [touchUi]=\"touchUi\"\r\n    >\r\n      <mat-datepicker-actions>\r\n        <ecabs-date-picker-actions\r\n          [applyLabel]=\"applyLabel ?? translationConfig?.applyLabel\"\r\n          [cancelLabel]=\"cancelLabel ?? translationConfig?.cancelLabel\"\r\n        >\r\n        </ecabs-date-picker-actions>\r\n      </mat-datepicker-actions>\r\n    </mat-datepicker>\r\n  </div>\r\n</app-element-wrapper>\r\n"]}
|
|
@@ -53,4 +53,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
53
53
|
exports: [EcabsDatePickerComponent, EcabsDatePickerHeaderComponent],
|
|
54
54
|
}]
|
|
55
55
|
}] });
|
|
56
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
56
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWNhYnMtZGF0ZS1waWNrZXIubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZWNhYnMtY29tcG9uZW50cy9zcmMvbGliL2VjYWJzLWRhdGUtcGlja2VyL2VjYWJzLWRhdGUtcGlja2VyLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsV0FBVyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFDbEUsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sOEJBQThCLENBQUM7QUFDbkUsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLHdCQUF3QixDQUFDO0FBRXZELE9BQU8sRUFBRSxvQkFBb0IsRUFBRSxNQUFNLGdEQUFnRCxDQUFDO0FBQ3RGLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxNQUFNLG1EQUFtRCxDQUFDO0FBQzVGLE9BQU8sRUFBRSw4QkFBOEIsRUFBRSxNQUFNLDBFQUEwRSxDQUFDO0FBQzFILE9BQU8sRUFBRSx3QkFBd0IsRUFBRSxNQUFNLCtCQUErQixDQUFDO0FBQ3pFLE9BQU8sRUFBRSw0QkFBNEIsRUFBRSxNQUFNLCtEQUErRCxDQUFDO0FBQzdHLE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQztBQUN6RCxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sMEJBQTBCLENBQUM7O0FBa0IzRCxNQUFNLE9BQU8scUJBQXFCO3dHQUFyQixxQkFBcUI7eUdBQXJCLHFCQUFxQixpQkFmakIsd0JBQXdCLEVBQUUsOEJBQThCLGFBRXJFLFlBQVk7WUFDWixvQkFBb0I7WUFDcEIsYUFBYTtZQUNiLG1CQUFtQjtZQUNuQixXQUFXO1lBQ1gsbUJBQW1CO1lBQ25CLHVCQUF1QjtZQUN2QixlQUFlO1lBQ2YsY0FBYztZQUNkLDRCQUE0QixhQUVwQix3QkFBd0IsRUFBRSw4QkFBOEI7eUdBRXZELHFCQUFxQixZQWI5QixZQUFZO1lBQ1osb0JBQW9CO1lBQ3BCLGFBQWE7WUFDYixtQkFBbUI7WUFDbkIsV0FBVztZQUNYLG1CQUFtQjtZQUNuQix1QkFBdUI7WUFDdkIsZUFBZTtZQUNmLGNBQWM7WUFDZCw0QkFBNEI7OzRGQUluQixxQkFBcUI7a0JBaEJqQyxRQUFRO21CQUFDO29CQUNSLFlBQVksRUFBRSxDQUFDLHdCQUF3QixFQUFFLDhCQUE4QixDQUFDO29CQUN4RSxPQUFPLEVBQUU7d0JBQ1AsWUFBWTt3QkFDWixvQkFBb0I7d0JBQ3BCLGFBQWE7d0JBQ2IsbUJBQW1CO3dCQUNuQixXQUFXO3dCQUNYLG1CQUFtQjt3QkFDbkIsdUJBQXVCO3dCQUN2QixlQUFlO3dCQUNmLGNBQWM7d0JBQ2QsNEJBQTRCO3FCQUM3QjtvQkFDRCxPQUFPLEVBQUUsQ0FBQyx3QkFBd0IsRUFBRSw4QkFBOEIsQ0FBQztpQkFDcEUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xyXG5pbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBGb3Jtc01vZHVsZSwgUmVhY3RpdmVGb3Jtc01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcclxuaW1wb3J0IHsgTWF0RGF0ZXBpY2tlck1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2RhdGVwaWNrZXInO1xyXG5pbXBvcnQgeyBNYXRJY29uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvaWNvbic7XHJcblxyXG5pbXBvcnQgeyBFbGVtZW50V3JhcHBlck1vZHVsZSB9IGZyb20gJy4uL2Jhc2UvZWxlbWVudC13cmFwcGVyL2VsZW1lbnQtd3JhcHBlci5tb2R1bGUnO1xyXG5pbXBvcnQgeyBFY2Fic1BpY2tlckhlYWRlck1vZHVsZSB9IGZyb20gJy4uL2VjYWJzLXBpY2tlci1oZWFkZXIvZWNhYnMtcGlja2VyLWhlYWRlci5tb2R1bGUnO1xyXG5pbXBvcnQgeyBFY2Fic0RhdGVQaWNrZXJIZWFkZXJDb21wb25lbnQgfSBmcm9tICcuL2NvbXBvbmVudHMvZWNhYnMtZGF0ZS1waWNrZXItaGVhZGVyL2VjYWJzLWRhdGUtcGlja2VyLWhlYWRlci5jb21wb25lbnQnO1xyXG5pbXBvcnQgeyBFY2Fic0RhdGVQaWNrZXJDb21wb25lbnQgfSBmcm9tICcuL2VjYWJzLWRhdGUtcGlja2VyLmNvbXBvbmVudCc7XHJcbmltcG9ydCB7IEVjYWJzRGF0ZVBpY2tlckFjdGlvbnNNb2R1bGUgfSBmcm9tICcuLi9lY2Ficy1kYXRlLXBpY2tlci1hY3Rpb25zL2VjYWJzLWRhdGUtcGlja2VyLWFjdGlvbnMubW9kdWxlJztcclxuaW1wb3J0IHsgTWF0SW5wdXRNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9pbnB1dCc7XHJcbmltcG9ydCB7IE1hdEJ1dHRvbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2J1dHRvbic7XHJcblxyXG5ATmdNb2R1bGUoe1xyXG4gIGRlY2xhcmF0aW9uczogW0VjYWJzRGF0ZVBpY2tlckNvbXBvbmVudCwgRWNhYnNEYXRlUGlja2VySGVhZGVyQ29tcG9uZW50XSxcclxuICBpbXBvcnRzOiBbXHJcbiAgICBDb21tb25Nb2R1bGUsXHJcbiAgICBFbGVtZW50V3JhcHBlck1vZHVsZSxcclxuICAgIE1hdEljb25Nb2R1bGUsXHJcbiAgICBNYXREYXRlcGlja2VyTW9kdWxlLFxyXG4gICAgRm9ybXNNb2R1bGUsXHJcbiAgICBSZWFjdGl2ZUZvcm1zTW9kdWxlLFxyXG4gICAgRWNhYnNQaWNrZXJIZWFkZXJNb2R1bGUsXHJcbiAgICBNYXRCdXR0b25Nb2R1bGUsXHJcbiAgICBNYXRJbnB1dE1vZHVsZSxcclxuICAgIEVjYWJzRGF0ZVBpY2tlckFjdGlvbnNNb2R1bGUsXHJcbiAgXSxcclxuICBleHBvcnRzOiBbRWNhYnNEYXRlUGlja2VyQ29tcG9uZW50LCBFY2Fic0RhdGVQaWNrZXJIZWFkZXJDb21wb25lbnRdLFxyXG59KVxyXG5leHBvcnQgY2xhc3MgRWNhYnNEYXRlUGlja2VyTW9kdWxlIHt9XHJcbiJdfQ==
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import { Component, Input } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
import * as i1 from "@angular/common";
|
|
4
|
+
export class EcabsHintComponent {
|
|
5
|
+
element;
|
|
6
|
+
maxValue;
|
|
7
|
+
showHint = false;
|
|
8
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: EcabsHintComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
9
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: EcabsHintComponent, selector: "ecabs-hint", inputs: { element: "element", maxValue: "maxValue", showHint: "showHint" }, ngImport: i0, template: "<div class=\"hint\" *ngIf=\"element && showHint\">{{ element?.value?.length || 0 }}/{{ this.maxValue }}</div>\r\n", styles: [""], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] });
|
|
10
|
+
}
|
|
11
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: EcabsHintComponent, decorators: [{
|
|
12
|
+
type: Component,
|
|
13
|
+
args: [{ selector: 'ecabs-hint', template: "<div class=\"hint\" *ngIf=\"element && showHint\">{{ element?.value?.length || 0 }}/{{ this.maxValue }}</div>\r\n" }]
|
|
14
|
+
}], propDecorators: { element: [{
|
|
15
|
+
type: Input
|
|
16
|
+
}], maxValue: [{
|
|
17
|
+
type: Input
|
|
18
|
+
}], showHint: [{
|
|
19
|
+
type: Input
|
|
20
|
+
}] } });
|
|
21
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWNhYnMtaGludC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9lY2Ficy1jb21wb25lbnRzL3NyYy9saWIvZWNhYnMtaGludC9lY2Ficy1oaW50LmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2VjYWJzLWNvbXBvbmVudHMvc3JjL2xpYi9lY2Ficy1oaW50L2VjYWJzLWhpbnQuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxLQUFLLEVBQUUsTUFBTSxlQUFlLENBQUM7OztBQU9qRCxNQUFNLE9BQU8sa0JBQWtCO0lBQ3BCLE9BQU8sQ0FBTztJQUNkLFFBQVEsQ0FBVTtJQUNsQixRQUFRLEdBQUcsS0FBSyxDQUFDO3dHQUhmLGtCQUFrQjs0RkFBbEIsa0JBQWtCLDhIQ1AvQixtSEFDQTs7NEZETWEsa0JBQWtCO2tCQUw5QixTQUFTOytCQUNFLFlBQVk7OEJBS2IsT0FBTztzQkFBZixLQUFLO2dCQUNHLFFBQVE7c0JBQWhCLEtBQUs7Z0JBQ0csUUFBUTtzQkFBaEIsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgSW5wdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuXHJcbkBDb21wb25lbnQoe1xyXG4gIHNlbGVjdG9yOiAnZWNhYnMtaGludCcsXHJcbiAgdGVtcGxhdGVVcmw6ICcuL2VjYWJzLWhpbnQuY29tcG9uZW50Lmh0bWwnLFxyXG4gIHN0eWxlVXJsczogWycuL2VjYWJzLWhpbnQuY29tcG9uZW50LnNjc3MnXSxcclxufSlcclxuZXhwb3J0IGNsYXNzIEVjYWJzSGludENvbXBvbmVudCB7XHJcbiAgQElucHV0KCkgZWxlbWVudCE6IGFueTtcclxuICBASW5wdXQoKSBtYXhWYWx1ZSE6IG51bWJlcjtcclxuICBASW5wdXQoKSBzaG93SGludCA9IGZhbHNlO1xyXG59XHJcbiIsIjxkaXYgY2xhc3M9XCJoaW50XCIgKm5nSWY9XCJlbGVtZW50ICYmIHNob3dIaW50XCI+e3sgZWxlbWVudD8udmFsdWU/Lmxlbmd0aCB8fCAwIH19L3t7IHRoaXMubWF4VmFsdWUgfX08L2Rpdj5cclxuIl19
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import { CommonModule } from '@angular/common';
|
|
2
|
+
import { NgModule } from '@angular/core';
|
|
3
|
+
import { EcabsHintComponent } from './ecabs-hint.component';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
export class EcabsHintModule {
|
|
6
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: EcabsHintModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
7
|
+
static ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "16.2.12", ngImport: i0, type: EcabsHintModule, declarations: [EcabsHintComponent], imports: [CommonModule], exports: [EcabsHintComponent] });
|
|
8
|
+
static ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: EcabsHintModule, imports: [CommonModule] });
|
|
9
|
+
}
|
|
10
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: EcabsHintModule, decorators: [{
|
|
11
|
+
type: NgModule,
|
|
12
|
+
args: [{
|
|
13
|
+
declarations: [EcabsHintComponent],
|
|
14
|
+
imports: [CommonModule],
|
|
15
|
+
exports: [EcabsHintComponent],
|
|
16
|
+
}]
|
|
17
|
+
}] });
|
|
18
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWNhYnMtaGludC5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9lY2Ficy1jb21wb25lbnRzL3NyYy9saWIvZWNhYnMtaGludC9lY2Ficy1oaW50Lm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQzs7QUFPNUQsTUFBTSxPQUFPLGVBQWU7d0dBQWYsZUFBZTt5R0FBZixlQUFlLGlCQUpYLGtCQUFrQixhQUN2QixZQUFZLGFBQ1osa0JBQWtCO3lHQUVqQixlQUFlLFlBSGhCLFlBQVk7OzRGQUdYLGVBQWU7a0JBTDNCLFFBQVE7bUJBQUM7b0JBQ1IsWUFBWSxFQUFFLENBQUMsa0JBQWtCLENBQUM7b0JBQ2xDLE9BQU8sRUFBRSxDQUFDLFlBQVksQ0FBQztvQkFDdkIsT0FBTyxFQUFFLENBQUMsa0JBQWtCLENBQUM7aUJBQzlCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcclxuaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgRWNhYnNIaW50Q29tcG9uZW50IH0gZnJvbSAnLi9lY2Ficy1oaW50LmNvbXBvbmVudCc7XHJcblxyXG5ATmdNb2R1bGUoe1xyXG4gIGRlY2xhcmF0aW9uczogW0VjYWJzSGludENvbXBvbmVudF0sXHJcbiAgaW1wb3J0czogW0NvbW1vbk1vZHVsZV0sXHJcbiAgZXhwb3J0czogW0VjYWJzSGludENvbXBvbmVudF0sXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBFY2Fic0hpbnRNb2R1bGUge31cclxuIl19
|
|
@@ -1,14 +1,14 @@
|
|
|
1
1
|
import { Component, ContentChild, Input, } from '@angular/core';
|
|
2
|
-
import {
|
|
2
|
+
import { MatTable } from '@angular/material/table';
|
|
3
3
|
import * as i0 from "@angular/core";
|
|
4
4
|
import * as i1 from "@angular/common";
|
|
5
|
-
import * as i2 from "@angular/material/
|
|
5
|
+
import * as i2 from "@angular/material/progress-bar";
|
|
6
6
|
import * as i3 from "../ecabs-empty-placeholder/ecabs-empty-placeholder.component";
|
|
7
7
|
export class TableComponent {
|
|
8
8
|
table;
|
|
9
9
|
header;
|
|
10
10
|
paginator;
|
|
11
|
-
bordered =
|
|
11
|
+
bordered = true;
|
|
12
12
|
loading = false;
|
|
13
13
|
isEmpty;
|
|
14
14
|
isEmptyMessage;
|
|
@@ -20,7 +20,7 @@ export class TableComponent {
|
|
|
20
20
|
}
|
|
21
21
|
}
|
|
22
22
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TableComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
23
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: TableComponent, selector: "ecabs-table", inputs: { header: "header", paginator: "paginator", bordered: "bordered", loading: "loading", isEmpty: "isEmpty", isEmptyMessage: "isEmptyMessage", redirectPath: "redirectPath", srcImageEmpty: "srcImageEmpty" }, queries: [{ propertyName: "table", first: true, predicate: MatTable, descendants: true }], ngImport: i0, template: "<section class=\"table-ui table-ui--wrapper\" [ngClass]=\"{ 'table-ui__bordered': bordered, loading: loading }\">\r\n <mat-progress-bar *ngIf=\"loading\" mode=\"indeterminate\" class=\"table-ui__progress\"></mat-progress-bar>\r\n\r\n <div *ngIf=\"header\" class=\"table-ui__header\">\r\n <ng-container *ngTemplateOutlet=\"header\"></ng-container>\r\n </div>\r\n\r\n <ng-container *ngIf=\"!(isEmptyMessage && isEmpty); else noDataTemplate\">\r\n <ng-content></ng-content>\r\n\r\n <div *ngIf=\"paginator\" class=\"table-ui__paginator\">\r\n <ng-container *ngTemplateOutlet=\"paginator\"></ng-container>\r\n </div>\r\n </ng-container>\r\n\r\n <!--#For Empty state -->\r\n <ng-template #noDataTemplate>\r\n <ecabs-empty-placeholder\r\n *ngIf=\"!loading\"\r\n [redirectPath]=\"redirectPath\"\r\n [isEmptyMessage]=\"isEmptyMessage\"\r\n [srcImage]=\"srcImageEmpty\"\r\n ></ecabs-empty-placeholder>\r\n </ng-template>\r\n</section>\r\n", styles: [":host mat-progress-bar{position:absolute;width:auto}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i2.
|
|
23
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: TableComponent, selector: "ecabs-table", inputs: { header: "header", paginator: "paginator", bordered: "bordered", loading: "loading", isEmpty: "isEmpty", isEmptyMessage: "isEmptyMessage", redirectPath: "redirectPath", srcImageEmpty: "srcImageEmpty" }, queries: [{ propertyName: "table", first: true, predicate: MatTable, descendants: true }], ngImport: i0, template: "<section class=\"table-ui table-ui--wrapper\" [ngClass]=\"{ 'table-ui__bordered': bordered, loading: loading }\">\r\n <mat-progress-bar *ngIf=\"loading\" mode=\"indeterminate\" class=\"table-ui__progress\"></mat-progress-bar>\r\n\r\n <div *ngIf=\"header\" class=\"table-ui__header\">\r\n <ng-container *ngTemplateOutlet=\"header\"></ng-container>\r\n </div>\r\n\r\n <ng-container *ngIf=\"!(isEmptyMessage && isEmpty); else noDataTemplate\">\r\n <ng-content></ng-content>\r\n\r\n <div *ngIf=\"paginator\" class=\"table-ui__paginator\">\r\n <ng-container *ngTemplateOutlet=\"paginator\"></ng-container>\r\n </div>\r\n </ng-container>\r\n\r\n <!--#For Empty state -->\r\n <ng-template #noDataTemplate>\r\n <ecabs-empty-placeholder\r\n *ngIf=\"!loading\"\r\n [redirectPath]=\"redirectPath\"\r\n [isEmptyMessage]=\"isEmptyMessage\"\r\n [srcImage]=\"srcImageEmpty\"\r\n ></ecabs-empty-placeholder>\r\n </ng-template>\r\n</section>\r\n", styles: [":host mat-progress-bar{position:absolute;width:auto}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i2.MatProgressBar, selector: "mat-progress-bar", inputs: ["color", "value", "bufferValue", "mode"], outputs: ["animationEnd"], exportAs: ["matProgressBar"] }, { kind: "component", type: i3.EcabsEmptyPlaceholderComponent, selector: "ecabs-empty-placeholder", inputs: ["isEmptyMessage", "redirectPath", "srcImage"] }] });
|
|
24
24
|
}
|
|
25
25
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TableComponent, decorators: [{
|
|
26
26
|
type: Component,
|
|
@@ -45,4 +45,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
45
45
|
}], srcImageEmpty: [{
|
|
46
46
|
type: Input
|
|
47
47
|
}] } });
|
|
48
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
48
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWNhYnMtdGFibGUuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZWNhYnMtY29tcG9uZW50cy9zcmMvbGliL2VjYWJzLXRhYmxlL2VjYWJzLXRhYmxlLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2VjYWJzLWNvbXBvbmVudHMvc3JjL2xpYi9lY2Ficy10YWJsZS9lY2Ficy10YWJsZS5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBRUwsU0FBUyxFQUNULFlBQVksRUFDWixLQUFLLEdBRU4sTUFBTSxlQUFlLENBQUM7QUFDdkIsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLHlCQUF5QixDQUFDOzs7OztBQVFuRCxNQUFNLE9BQU8sY0FBYztJQUV6QixLQUFLLENBQWdCO0lBR3JCLE1BQU0sQ0FBbUI7SUFHekIsU0FBUyxDQUFtQjtJQUc1QixRQUFRLEdBQUcsSUFBSSxDQUFDO0lBR2hCLE9BQU8sR0FBRyxLQUFLLENBQUM7SUFHaEIsT0FBTyxDQUFVO0lBRWpCLGNBQWMsQ0FBUztJQUd2QixZQUFZLENBQTBCO0lBR3RDLGFBQWEsQ0FBUztJQUV0QixxQkFBcUI7UUFDbkIsSUFBSSxJQUFJLENBQUMsS0FBSyxFQUFFO1lBQ2QsSUFBSSxDQUFDLE9BQU8sR0FBRyxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsT0FBTyxDQUFDLEVBQUUsTUFBTSxDQUFDO1NBQzdDO0lBQ0gsQ0FBQzt3R0EvQlUsY0FBYzs0RkFBZCxjQUFjLDBTQUNYLFFBQVEsZ0RDaEJ4QixxOUJBeUJBOzs0RkRWYSxjQUFjO2tCQUwxQixTQUFTOytCQUNFLGFBQWE7OEJBTXZCLEtBQUs7c0JBREosWUFBWTt1QkFBQyxRQUFRO2dCQUl0QixNQUFNO3NCQURMLEtBQUs7Z0JBSU4sU0FBUztzQkFEUixLQUFLO2dCQUlOLFFBQVE7c0JBRFAsS0FBSztnQkFJTixPQUFPO3NCQUROLEtBQUs7Z0JBSU4sT0FBTztzQkFETixLQUFLO2dCQUdOLGNBQWM7c0JBRGIsS0FBSztnQkFJTixZQUFZO3NCQURYLEtBQUs7Z0JBSU4sYUFBYTtzQkFEWixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcclxuICBBZnRlckNvbnRlbnRDaGVja2VkLFxyXG4gIENvbXBvbmVudCxcclxuICBDb250ZW50Q2hpbGQsXHJcbiAgSW5wdXQsXHJcbiAgVGVtcGxhdGVSZWYsXHJcbn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IE1hdFRhYmxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvdGFibGUnO1xyXG5pbXBvcnQgeyBQbGFjZWhvbGRlclJlZGlyZWN0UGF0aCB9IGZyb20gJy4uL2VjYWJzLWVtcHR5LXBsYWNlaG9sZGVyL2VjYWJzLWVtcHR5LXBsYWNlaG9sZGVyLmNvbXBvbmVudCc7XHJcblxyXG5AQ29tcG9uZW50KHtcclxuICBzZWxlY3RvcjogJ2VjYWJzLXRhYmxlJyxcclxuICB0ZW1wbGF0ZVVybDogJy4vZWNhYnMtdGFibGUuY29tcG9uZW50Lmh0bWwnLFxyXG4gIHN0eWxlVXJsczogWycuL2VjYWJzLXRhYmxlLmNvbXBvbmVudC5zY3NzJ10sXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBUYWJsZUNvbXBvbmVudCBpbXBsZW1lbnRzIEFmdGVyQ29udGVudENoZWNrZWQge1xyXG4gIEBDb250ZW50Q2hpbGQoTWF0VGFibGUpXHJcbiAgdGFibGU6IE1hdFRhYmxlPGFueT47XHJcblxyXG4gIEBJbnB1dCgpXHJcbiAgaGVhZGVyOiBUZW1wbGF0ZVJlZjxhbnk+O1xyXG5cclxuICBASW5wdXQoKVxyXG4gIHBhZ2luYXRvcjogVGVtcGxhdGVSZWY8YW55PjtcclxuXHJcbiAgQElucHV0KClcclxuICBib3JkZXJlZCA9IHRydWU7XHJcblxyXG4gIEBJbnB1dCgpXHJcbiAgbG9hZGluZyA9IGZhbHNlO1xyXG5cclxuICBASW5wdXQoKVxyXG4gIGlzRW1wdHk6IGJvb2xlYW47XHJcbiAgQElucHV0KClcclxuICBpc0VtcHR5TWVzc2FnZTogc3RyaW5nO1xyXG5cclxuICBASW5wdXQoKVxyXG4gIHJlZGlyZWN0UGF0aDogUGxhY2Vob2xkZXJSZWRpcmVjdFBhdGg7XHJcblxyXG4gIEBJbnB1dCgpXHJcbiAgc3JjSW1hZ2VFbXB0eTogc3RyaW5nO1xyXG5cclxuICBuZ0FmdGVyQ29udGVudENoZWNrZWQoKTogdm9pZCB7XHJcbiAgICBpZiAodGhpcy50YWJsZSkge1xyXG4gICAgICB0aGlzLmlzRW1wdHkgPSAhdGhpcy50YWJsZVsnX2RhdGEnXT8ubGVuZ3RoO1xyXG4gICAgfVxyXG4gIH1cclxufVxyXG4iLCI8c2VjdGlvbiBjbGFzcz1cInRhYmxlLXVpIHRhYmxlLXVpLS13cmFwcGVyXCIgW25nQ2xhc3NdPVwieyAndGFibGUtdWlfX2JvcmRlcmVkJzogYm9yZGVyZWQsIGxvYWRpbmc6IGxvYWRpbmcgfVwiPlxyXG4gIDxtYXQtcHJvZ3Jlc3MtYmFyICpuZ0lmPVwibG9hZGluZ1wiIG1vZGU9XCJpbmRldGVybWluYXRlXCIgY2xhc3M9XCJ0YWJsZS11aV9fcHJvZ3Jlc3NcIj48L21hdC1wcm9ncmVzcy1iYXI+XHJcblxyXG4gIDxkaXYgKm5nSWY9XCJoZWFkZXJcIiBjbGFzcz1cInRhYmxlLXVpX19oZWFkZXJcIj5cclxuICAgIDxuZy1jb250YWluZXIgKm5nVGVtcGxhdGVPdXRsZXQ9XCJoZWFkZXJcIj48L25nLWNvbnRhaW5lcj5cclxuICA8L2Rpdj5cclxuXHJcbiAgPG5nLWNvbnRhaW5lciAqbmdJZj1cIiEoaXNFbXB0eU1lc3NhZ2UgJiYgaXNFbXB0eSk7IGVsc2Ugbm9EYXRhVGVtcGxhdGVcIj5cclxuICAgIDxuZy1jb250ZW50PjwvbmctY29udGVudD5cclxuXHJcbiAgICA8ZGl2ICpuZ0lmPVwicGFnaW5hdG9yXCIgY2xhc3M9XCJ0YWJsZS11aV9fcGFnaW5hdG9yXCI+XHJcbiAgICAgIDxuZy1jb250YWluZXIgKm5nVGVtcGxhdGVPdXRsZXQ9XCJwYWdpbmF0b3JcIj48L25nLWNvbnRhaW5lcj5cclxuICAgIDwvZGl2PlxyXG4gIDwvbmctY29udGFpbmVyPlxyXG5cclxuICA8IS0tI0ZvciBFbXB0eSBzdGF0ZSAtLT5cclxuICA8bmctdGVtcGxhdGUgI25vRGF0YVRlbXBsYXRlPlxyXG4gICAgPGVjYWJzLWVtcHR5LXBsYWNlaG9sZGVyXHJcbiAgICAgICpuZ0lmPVwiIWxvYWRpbmdcIlxyXG4gICAgICBbcmVkaXJlY3RQYXRoXT1cInJlZGlyZWN0UGF0aFwiXHJcbiAgICAgIFtpc0VtcHR5TWVzc2FnZV09XCJpc0VtcHR5TWVzc2FnZVwiXHJcbiAgICAgIFtzcmNJbWFnZV09XCJzcmNJbWFnZUVtcHR5XCJcclxuICAgID48L2VjYWJzLWVtcHR5LXBsYWNlaG9sZGVyPlxyXG4gIDwvbmctdGVtcGxhdGU+XHJcbjwvc2VjdGlvbj5cclxuIl19
|
|
@@ -1,10 +1,10 @@
|
|
|
1
1
|
import { NgModule } from '@angular/core';
|
|
2
2
|
import { CommonModule } from '@angular/common';
|
|
3
3
|
import { TableComponent } from './ecabs-table.component';
|
|
4
|
-
import {
|
|
4
|
+
import { MatProgressBarModule } from '@angular/material/progress-bar';
|
|
5
5
|
import { RouterModule } from '@angular/router';
|
|
6
6
|
import { EcabsEmptyPlaceholderModule } from '../ecabs-empty-placeholder/ecabs-empty-placeholder.module';
|
|
7
|
-
import {
|
|
7
|
+
import { MatTableModule } from '@angular/material/table';
|
|
8
8
|
import * as i0 from "@angular/core";
|
|
9
9
|
export class EcabsTableModule {
|
|
10
10
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: EcabsTableModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
@@ -30,4 +30,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
30
30
|
exports: [TableComponent, MatTableModule, EcabsEmptyPlaceholderModule],
|
|
31
31
|
}]
|
|
32
32
|
}] });
|
|
33
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
33
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWNhYnMtdGFibGUubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZWNhYnMtY29tcG9uZW50cy9zcmMvbGliL2VjYWJzLXRhYmxlL2VjYWJzLXRhYmxlLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pDLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0seUJBQXlCLENBQUM7QUFDekQsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sZ0NBQWdDLENBQUM7QUFDdEUsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSwyQkFBMkIsRUFBRSxNQUFNLDJEQUEyRCxDQUFDO0FBQ3hHLE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQzs7QUFZekQsTUFBTSxPQUFPLGdCQUFnQjt3R0FBaEIsZ0JBQWdCO3lHQUFoQixnQkFBZ0IsaUJBVFosY0FBYyxhQUUzQixZQUFZO1lBQ1osb0JBQW9CO1lBQ3BCLFlBQVk7WUFDWiwyQkFBMkIsYUFFbkIsY0FBYyxFQUFFLGNBQWMsRUFBRSwyQkFBMkI7eUdBRTFELGdCQUFnQixZQVB6QixZQUFZO1lBQ1osb0JBQW9CO1lBQ3BCLFlBQVk7WUFDWiwyQkFBMkIsRUFFSCxjQUFjLEVBQUUsMkJBQTJCOzs0RkFFMUQsZ0JBQWdCO2tCQVY1QixRQUFRO21CQUFDO29CQUNSLFlBQVksRUFBRSxDQUFDLGNBQWMsQ0FBQztvQkFDOUIsT0FBTyxFQUFFO3dCQUNQLFlBQVk7d0JBQ1osb0JBQW9CO3dCQUNwQixZQUFZO3dCQUNaLDJCQUEyQjtxQkFDNUI7b0JBQ0QsT0FBTyxFQUFFLENBQUMsY0FBYyxFQUFFLGNBQWMsRUFBRSwyQkFBMkIsQ0FBQztpQkFDdkUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xyXG5pbXBvcnQgeyBUYWJsZUNvbXBvbmVudCB9IGZyb20gJy4vZWNhYnMtdGFibGUuY29tcG9uZW50JztcclxuaW1wb3J0IHsgTWF0UHJvZ3Jlc3NCYXJNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9wcm9ncmVzcy1iYXInO1xyXG5pbXBvcnQgeyBSb3V0ZXJNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9yb3V0ZXInO1xyXG5pbXBvcnQgeyBFY2Fic0VtcHR5UGxhY2Vob2xkZXJNb2R1bGUgfSBmcm9tICcuLi9lY2Ficy1lbXB0eS1wbGFjZWhvbGRlci9lY2Ficy1lbXB0eS1wbGFjZWhvbGRlci5tb2R1bGUnO1xyXG5pbXBvcnQgeyBNYXRUYWJsZU1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL3RhYmxlJztcclxuXHJcbkBOZ01vZHVsZSh7XHJcbiAgZGVjbGFyYXRpb25zOiBbVGFibGVDb21wb25lbnRdLFxyXG4gIGltcG9ydHM6IFtcclxuICAgIENvbW1vbk1vZHVsZSxcclxuICAgIE1hdFByb2dyZXNzQmFyTW9kdWxlLFxyXG4gICAgUm91dGVyTW9kdWxlLFxyXG4gICAgRWNhYnNFbXB0eVBsYWNlaG9sZGVyTW9kdWxlLFxyXG4gIF0sXHJcbiAgZXhwb3J0czogW1RhYmxlQ29tcG9uZW50LCBNYXRUYWJsZU1vZHVsZSwgRWNhYnNFbXB0eVBsYWNlaG9sZGVyTW9kdWxlXSxcclxufSlcclxuZXhwb3J0IGNsYXNzIEVjYWJzVGFibGVNb2R1bGUge31cclxuIl19
|