@sebgroup/green-angular 3.3.0 → 3.5.0
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 +55 -14
- package/esm2020/index.mjs +2 -1
- package/esm2020/lib/cell-table/cell-table-item.component.mjs +91 -0
- package/esm2020/lib/cell-table/cell-table.component.mjs +97 -0
- package/esm2020/lib/cell-table/cell-table.module.mjs +26 -0
- package/esm2020/lib/cell-table/cell-table.types.mjs +7 -0
- package/esm2020/lib/cell-table/cell-underline.directive.mjs +55 -0
- package/esm2020/lib/cell-table/index.mjs +4 -0
- package/esm2020/lib/datepicker/datepicker.component.mjs +8 -4
- package/esm2020/lib/dropdown/dropdown.component.mjs +6 -4
- package/esm2020/lib/green-angular.module.mjs +5 -1
- package/fesm2015/sebgroup-green-angular.mjs +278 -8
- package/fesm2015/sebgroup-green-angular.mjs.map +1 -1
- package/fesm2020/sebgroup-green-angular.mjs +276 -8
- package/fesm2020/sebgroup-green-angular.mjs.map +1 -1
- package/index.d.ts +1 -0
- package/lib/cell-table/cell-table-item.component.d.ts +14 -0
- package/lib/cell-table/cell-table.component.d.ts +44 -0
- package/lib/cell-table/cell-table.module.d.ts +10 -0
- package/lib/cell-table/cell-table.types.d.ts +34 -0
- package/lib/cell-table/cell-underline.directive.d.ts +14 -0
- package/lib/cell-table/index.d.ts +3 -0
- package/lib/datepicker/datepicker.component.d.ts +3 -1
- package/lib/dropdown/dropdown.component.d.ts +2 -1
- package/lib/green-angular.module.d.ts +3 -2
- package/package.json +3 -3
package/README.md
CHANGED
|
@@ -1,27 +1,68 @@
|
|
|
1
|
-
|
|
1
|
+
<div align="center">
|
|
2
|
+
<img width="600" alt="green-angular" src="https://github.com/sebgroup/green/assets/11420341/c776109a-c980-4c33-92dd-109f1ff31ba2">
|
|
3
|
+
<h1>@sebgroup/green-angular</h1>
|
|
4
|
+
<p>
|
|
5
|
+
Angular components with SEB's look and feel.
|
|
6
|
+
</p>
|
|
7
|
+
</div>
|
|
2
8
|
|
|
3
|
-
|
|
9
|
+
## Install
|
|
4
10
|
|
|
5
|
-
|
|
11
|
+
If you are using the latest version of Angular, you can simply install `@sebgroup/green-angular` like this:
|
|
6
12
|
|
|
7
|
-
|
|
13
|
+
```
|
|
14
|
+
// If you are using yarn
|
|
15
|
+
yarn install @sebgroup/green-angular --save
|
|
8
16
|
|
|
9
|
-
|
|
17
|
+
// If you are using npm
|
|
18
|
+
npm install @sebgroup/green-angular --save
|
|
19
|
+
```
|
|
10
20
|
|
|
11
|
-
|
|
21
|
+
However, because `@sebgroup/green-angular` has a peer dependency to `@angular/cdk`, and Angular is very picky about which versions go together, if you use an older version of Angular you need to explicitly install the matching version of `@angular/cdk` as well.
|
|
12
22
|
|
|
13
|
-
|
|
23
|
+
For example, for Angular 14:
|
|
14
24
|
|
|
15
|
-
|
|
25
|
+
```
|
|
26
|
+
npm install @angular/cdk@~14.0.0 @sebgroup/green-angular --save
|
|
27
|
+
```
|
|
16
28
|
|
|
17
|
-
|
|
29
|
+
Currently, our aim is to support the LTS version of Angular as well as the current latest version.
|
|
18
30
|
|
|
19
|
-
|
|
31
|
+
## Import module
|
|
20
32
|
|
|
21
|
-
|
|
33
|
+
We recommend that you import `NggModule` (or just the module you need for Angular Green) into a shared module eg. `SharedModule` that can be imported into other, preferably lazy loaded modules when needed.
|
|
22
34
|
|
|
23
|
-
|
|
35
|
+
```ts
|
|
36
|
+
import { NggModule } from '@sebgroup/green-angular'
|
|
24
37
|
|
|
25
|
-
|
|
38
|
+
@NgModule({
|
|
39
|
+
declarations: [...],
|
|
40
|
+
imports: [
|
|
41
|
+
...
|
|
42
|
+
NggModule
|
|
43
|
+
],
|
|
44
|
+
exports: [
|
|
45
|
+
NggModule
|
|
46
|
+
]
|
|
47
|
+
})
|
|
48
|
+
export class SharedModule {}
|
|
49
|
+
```
|
|
26
50
|
|
|
27
|
-
|
|
51
|
+
## Import styling
|
|
52
|
+
|
|
53
|
+
We recommend setting up your Angular project to use scss (SASS) for css preprocessing.
|
|
54
|
+
|
|
55
|
+
Once configured to use scss, it's just a matter of including the scss to your main styles file, typically it would be `styles.scss` located at the root of the `src` folder unless you've changed it.
|
|
56
|
+
|
|
57
|
+
### Add scss
|
|
58
|
+
|
|
59
|
+
`{project}/src/styles.scss`
|
|
60
|
+
|
|
61
|
+
```css
|
|
62
|
+
// import base styles from @sebgroup/chlorophyll
|
|
63
|
+
@use '@sebgroup/chlorophyll/scss';
|
|
64
|
+
```
|
|
65
|
+
|
|
66
|
+
### Have other needs?
|
|
67
|
+
|
|
68
|
+
More examples and use cases coming soon! In the meantime create an [issue over at github](https://github.com/sebgroup/green/issues)
|
package/esm2020/index.mjs
CHANGED
|
@@ -12,5 +12,6 @@ export * from './lib/shared';
|
|
|
12
12
|
export * from './lib/slider';
|
|
13
13
|
export * from './lib/in-page-wizard';
|
|
14
14
|
export * from './lib/context-menu';
|
|
15
|
+
export * from './lib/cell-table';
|
|
15
16
|
export * from './lib/shared/core-element';
|
|
16
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
17
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9saWJzL2FuZ3VsYXIvc3JjL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsNEJBQTRCLENBQUE7QUFDMUMsY0FBYyxpQkFBaUIsQ0FBQTtBQUMvQixjQUFjLGFBQWEsQ0FBQTtBQUMzQixjQUFjLGNBQWMsQ0FBQTtBQUM1QixjQUFjLGtCQUFrQixDQUFBO0FBQ2hDLGNBQWMsZ0JBQWdCLENBQUE7QUFDOUIsY0FBYyxhQUFhLENBQUE7QUFDM0IsY0FBYyxrQkFBa0IsQ0FBQTtBQUNoQyxjQUFjLHVCQUF1QixDQUFBO0FBQ3JDLGNBQWMseUJBQXlCLENBQUE7QUFDdkMsY0FBYyxjQUFjLENBQUE7QUFDNUIsY0FBYyxjQUFjLENBQUE7QUFDNUIsY0FBYyxzQkFBc0IsQ0FBQTtBQUNwQyxjQUFjLG9CQUFvQixDQUFBO0FBQ2xDLGNBQWMsa0JBQWtCLENBQUE7QUFFaEMsY0FBYywyQkFBMkIsQ0FBQSIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vbGliL2dyZWVuLWFuZ3VsYXIubW9kdWxlJ1xuZXhwb3J0ICogZnJvbSAnLi9saWIvYWNjb3JkaW9uJ1xuZXhwb3J0ICogZnJvbSAnLi9saWIvYmFkZ2UnXG5leHBvcnQgKiBmcm9tICcuL2xpYi9idXR0b24nXG5leHBvcnQgKiBmcm9tICcuL2xpYi9kYXRlcGlja2VyJ1xuZXhwb3J0ICogZnJvbSAnLi9saWIvZHJvcGRvd24nXG5leHBvcnQgKiBmcm9tICcuL2xpYi9tb2RhbCdcbmV4cG9ydCAqIGZyb20gJy4vbGliL3BhZ2luYXRpb24nXG5leHBvcnQgKiBmcm9tICcuL2xpYi9wcm9ncmVzcy1jaXJjbGUnXG5leHBvcnQgKiBmcm9tICcuL2xpYi9zZWdtZW50ZWQtY29udHJvbCdcbmV4cG9ydCAqIGZyb20gJy4vbGliL3NoYXJlZCdcbmV4cG9ydCAqIGZyb20gJy4vbGliL3NsaWRlcidcbmV4cG9ydCAqIGZyb20gJy4vbGliL2luLXBhZ2Utd2l6YXJkJ1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY29udGV4dC1tZW51J1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY2VsbC10YWJsZSdcblxuZXhwb3J0ICogZnJvbSAnLi9saWIvc2hhcmVkL2NvcmUtZWxlbWVudCdcbiJdfQ==
|
|
@@ -0,0 +1,91 @@
|
|
|
1
|
+
import { Component, Input } from '@angular/core';
|
|
2
|
+
import { DomSanitizer } from '@angular/platform-browser';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
import * as i1 from "@angular/platform-browser";
|
|
5
|
+
import * as i2 from "@angular/common";
|
|
6
|
+
import * as i3 from "./cell-underline.directive";
|
|
7
|
+
export class CellTableItemComponent {
|
|
8
|
+
constructor(sanitizer) {
|
|
9
|
+
this.sanitizer = sanitizer;
|
|
10
|
+
this.valueType = 'string';
|
|
11
|
+
this.id = '';
|
|
12
|
+
this.getSignColor = (value) => {
|
|
13
|
+
if (/[−-]/.test(String(value)))
|
|
14
|
+
return 'text-danger';
|
|
15
|
+
else if (/[1-9]/.test(String(value)))
|
|
16
|
+
return 'text-success';
|
|
17
|
+
return '';
|
|
18
|
+
};
|
|
19
|
+
}
|
|
20
|
+
transformHTML(value) {
|
|
21
|
+
if (value && value.length) {
|
|
22
|
+
return this.sanitizer.bypassSecurityTrustHtml(value);
|
|
23
|
+
}
|
|
24
|
+
else {
|
|
25
|
+
return '';
|
|
26
|
+
}
|
|
27
|
+
}
|
|
28
|
+
}
|
|
29
|
+
CellTableItemComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: CellTableItemComponent, deps: [{ token: i1.DomSanitizer }], target: i0.ɵɵFactoryTarget.Component });
|
|
30
|
+
CellTableItemComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.9", type: CellTableItemComponent, selector: "[nggCellTableItem]", inputs: { row: "row", valueType: "valueType", id: "id" }, ngImport: i0, template: `
|
|
31
|
+
<ng-container [ngSwitch]="valueType">
|
|
32
|
+
<span *ngSwitchCase="'string'">{{ row || '–' }}</span>
|
|
33
|
+
<span *ngSwitchCase="'number'">{{ (row | number) || '–' }}</span>
|
|
34
|
+
<span *ngSwitchCase="'datetime'">{{
|
|
35
|
+
(row | date : 'HH:mm:ss') || '–'
|
|
36
|
+
}}</span>
|
|
37
|
+
<span *ngSwitchCase="'date'">{{
|
|
38
|
+
(row | date : 'YYYY-MM-dd') || '–'
|
|
39
|
+
}}</span>
|
|
40
|
+
<span
|
|
41
|
+
*ngSwitchCase="'custom-html'"
|
|
42
|
+
[innerHtml]="transformHTML(row) || '–'"
|
|
43
|
+
></span>
|
|
44
|
+
<span *ngSwitchCase="'sign'" [ngClass]="getSignColor(row)">{{
|
|
45
|
+
row || '–'
|
|
46
|
+
}}</span>
|
|
47
|
+
<span *ngSwitchCase="'pct'">{{ row || '–' }}</span>
|
|
48
|
+
<span *ngSwitchCase="'streamSign'" [nggSlidingUnderline]="row">{{
|
|
49
|
+
row || '–'
|
|
50
|
+
}}</span>
|
|
51
|
+
<span *ngSwitchDefault>–</span>
|
|
52
|
+
</ng-container>
|
|
53
|
+
`, isInline: true, dependencies: [{ kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { kind: "directive", type: i2.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { kind: "directive", type: i2.NgSwitchDefault, selector: "[ngSwitchDefault]" }, { kind: "directive", type: i3.SlidingUnderlineDirective, selector: "[nggSlidingUnderline]", inputs: ["nggSlidingUnderline", "key", "disabled"] }, { kind: "pipe", type: i2.DecimalPipe, name: "number" }, { kind: "pipe", type: i2.DatePipe, name: "date" }] });
|
|
54
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: CellTableItemComponent, decorators: [{
|
|
55
|
+
type: Component,
|
|
56
|
+
args: [{
|
|
57
|
+
// eslint-disable-next-line @angular-eslint/component-selector
|
|
58
|
+
selector: '[nggCellTableItem]',
|
|
59
|
+
template: `
|
|
60
|
+
<ng-container [ngSwitch]="valueType">
|
|
61
|
+
<span *ngSwitchCase="'string'">{{ row || '–' }}</span>
|
|
62
|
+
<span *ngSwitchCase="'number'">{{ (row | number) || '–' }}</span>
|
|
63
|
+
<span *ngSwitchCase="'datetime'">{{
|
|
64
|
+
(row | date : 'HH:mm:ss') || '–'
|
|
65
|
+
}}</span>
|
|
66
|
+
<span *ngSwitchCase="'date'">{{
|
|
67
|
+
(row | date : 'YYYY-MM-dd') || '–'
|
|
68
|
+
}}</span>
|
|
69
|
+
<span
|
|
70
|
+
*ngSwitchCase="'custom-html'"
|
|
71
|
+
[innerHtml]="transformHTML(row) || '–'"
|
|
72
|
+
></span>
|
|
73
|
+
<span *ngSwitchCase="'sign'" [ngClass]="getSignColor(row)">{{
|
|
74
|
+
row || '–'
|
|
75
|
+
}}</span>
|
|
76
|
+
<span *ngSwitchCase="'pct'">{{ row || '–' }}</span>
|
|
77
|
+
<span *ngSwitchCase="'streamSign'" [nggSlidingUnderline]="row">{{
|
|
78
|
+
row || '–'
|
|
79
|
+
}}</span>
|
|
80
|
+
<span *ngSwitchDefault>–</span>
|
|
81
|
+
</ng-container>
|
|
82
|
+
`,
|
|
83
|
+
}]
|
|
84
|
+
}], ctorParameters: function () { return [{ type: i1.DomSanitizer }]; }, propDecorators: { row: [{
|
|
85
|
+
type: Input
|
|
86
|
+
}], valueType: [{
|
|
87
|
+
type: Input
|
|
88
|
+
}], id: [{
|
|
89
|
+
type: Input
|
|
90
|
+
}] } });
|
|
91
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2VsbC10YWJsZS1pdGVtLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvYW5ndWxhci9zcmMvbGliL2NlbGwtdGFibGUvY2VsbC10YWJsZS1pdGVtLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBRSxNQUFNLGVBQWUsQ0FBQTtBQUVoRCxPQUFPLEVBQUUsWUFBWSxFQUFZLE1BQU0sMkJBQTJCLENBQUE7Ozs7O0FBOEJsRSxNQUFNLE9BQU8sc0JBQXNCO0lBS2pDLFlBQW9CLFNBQXVCO1FBQXZCLGNBQVMsR0FBVCxTQUFTLENBQWM7UUFIbEMsY0FBUyxHQUE2QixRQUFRLENBQUE7UUFDOUMsT0FBRSxHQUFHLEVBQUUsQ0FBQTtRQUloQixpQkFBWSxHQUFHLENBQUMsS0FBc0IsRUFBRSxFQUFFO1lBQ3hDLElBQUksTUFBTSxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsS0FBSyxDQUFDLENBQUM7Z0JBQUUsT0FBTyxhQUFhLENBQUE7aUJBQy9DLElBQUksT0FBTyxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsS0FBSyxDQUFDLENBQUM7Z0JBQUUsT0FBTyxjQUFjLENBQUE7WUFDM0QsT0FBTyxFQUFFLENBQUE7UUFDWCxDQUFDLENBQUE7SUFONkMsQ0FBQztJQVEvQyxhQUFhLENBQUMsS0FBYTtRQUN6QixJQUFJLEtBQUssSUFBSSxLQUFLLENBQUMsTUFBTSxFQUFFO1lBQ3pCLE9BQU8sSUFBSSxDQUFDLFNBQVMsQ0FBQyx1QkFBdUIsQ0FBQyxLQUFLLENBQUMsQ0FBQTtTQUNyRDthQUFNO1lBQ0wsT0FBTyxFQUFFLENBQUE7U0FDVjtJQUNILENBQUM7O21IQW5CVSxzQkFBc0I7dUdBQXRCLHNCQUFzQixvSEF6QnZCOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztHQXVCVDsyRkFFVSxzQkFBc0I7a0JBNUJsQyxTQUFTO21CQUFDO29CQUNULDhEQUE4RDtvQkFDOUQsUUFBUSxFQUFFLG9CQUFvQjtvQkFDOUIsUUFBUSxFQUFFOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztHQXVCVDtpQkFDRjttR0FFVSxHQUFHO3NCQUFYLEtBQUs7Z0JBQ0csU0FBUztzQkFBakIsS0FBSztnQkFDRyxFQUFFO3NCQUFWLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIElucHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSdcbmltcG9ydCB7IFRhYmxlSGVhZGVyTGlzdFZhbHVlVHlwZSB9IGZyb20gJy4vY2VsbC10YWJsZS50eXBlcydcbmltcG9ydCB7IERvbVNhbml0aXplciwgU2FmZUh0bWwgfSBmcm9tICdAYW5ndWxhci9wbGF0Zm9ybS1icm93c2VyJ1xuXG5AQ29tcG9uZW50KHtcbiAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIEBhbmd1bGFyLWVzbGludC9jb21wb25lbnQtc2VsZWN0b3JcbiAgc2VsZWN0b3I6ICdbbmdnQ2VsbFRhYmxlSXRlbV0nLFxuICB0ZW1wbGF0ZTogYFxuICAgIDxuZy1jb250YWluZXIgW25nU3dpdGNoXT1cInZhbHVlVHlwZVwiPlxuICAgICAgPHNwYW4gKm5nU3dpdGNoQ2FzZT1cIidzdHJpbmcnXCI+e3sgcm93IHx8ICfigJMnIH19PC9zcGFuPlxuICAgICAgPHNwYW4gKm5nU3dpdGNoQ2FzZT1cIidudW1iZXInXCI+e3sgKHJvdyB8IG51bWJlcikgfHwgJ+KAkycgfX08L3NwYW4+XG4gICAgICA8c3BhbiAqbmdTd2l0Y2hDYXNlPVwiJ2RhdGV0aW1lJ1wiPnt7XG4gICAgICAgIChyb3cgfCBkYXRlIDogJ0hIOm1tOnNzJykgfHwgJ+KAkydcbiAgICAgIH19PC9zcGFuPlxuICAgICAgPHNwYW4gKm5nU3dpdGNoQ2FzZT1cIidkYXRlJ1wiPnt7XG4gICAgICAgIChyb3cgfCBkYXRlIDogJ1lZWVktTU0tZGQnKSB8fCAn4oCTJ1xuICAgICAgfX08L3NwYW4+XG4gICAgICA8c3BhblxuICAgICAgICAqbmdTd2l0Y2hDYXNlPVwiJ2N1c3RvbS1odG1sJ1wiXG4gICAgICAgIFtpbm5lckh0bWxdPVwidHJhbnNmb3JtSFRNTChyb3cpIHx8ICfigJMnXCJcbiAgICAgID48L3NwYW4+XG4gICAgICA8c3BhbiAqbmdTd2l0Y2hDYXNlPVwiJ3NpZ24nXCIgW25nQ2xhc3NdPVwiZ2V0U2lnbkNvbG9yKHJvdylcIj57e1xuICAgICAgICByb3cgfHwgJ+KAkydcbiAgICAgIH19PC9zcGFuPlxuICAgICAgPHNwYW4gKm5nU3dpdGNoQ2FzZT1cIidwY3QnXCI+e3sgcm93IHx8ICfigJMnIH19PC9zcGFuPlxuICAgICAgPHNwYW4gKm5nU3dpdGNoQ2FzZT1cIidzdHJlYW1TaWduJ1wiIFtuZ2dTbGlkaW5nVW5kZXJsaW5lXT1cInJvd1wiPnt7XG4gICAgICAgIHJvdyB8fCAn4oCTJ1xuICAgICAgfX08L3NwYW4+XG4gICAgICA8c3BhbiAqbmdTd2l0Y2hEZWZhdWx0PuKAkzwvc3Bhbj5cbiAgICA8L25nLWNvbnRhaW5lcj5cbiAgYCxcbn0pXG5leHBvcnQgY2xhc3MgQ2VsbFRhYmxlSXRlbUNvbXBvbmVudCB7XG4gIEBJbnB1dCgpIHJvdzogYW55XG4gIEBJbnB1dCgpIHZhbHVlVHlwZTogVGFibGVIZWFkZXJMaXN0VmFsdWVUeXBlID0gJ3N0cmluZydcbiAgQElucHV0KCkgaWQgPSAnJ1xuXG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgc2FuaXRpemVyOiBEb21TYW5pdGl6ZXIpIHt9XG5cbiAgZ2V0U2lnbkNvbG9yID0gKHZhbHVlOiBzdHJpbmcgfCBudW1iZXIpID0+IHtcbiAgICBpZiAoL1viiJItXS8udGVzdChTdHJpbmcodmFsdWUpKSkgcmV0dXJuICd0ZXh0LWRhbmdlcidcbiAgICBlbHNlIGlmICgvWzEtOV0vLnRlc3QoU3RyaW5nKHZhbHVlKSkpIHJldHVybiAndGV4dC1zdWNjZXNzJ1xuICAgIHJldHVybiAnJ1xuICB9XG5cbiAgdHJhbnNmb3JtSFRNTCh2YWx1ZTogc3RyaW5nKTogU2FmZUh0bWwge1xuICAgIGlmICh2YWx1ZSAmJiB2YWx1ZS5sZW5ndGgpIHtcbiAgICAgIHJldHVybiB0aGlzLnNhbml0aXplci5ieXBhc3NTZWN1cml0eVRydXN0SHRtbCh2YWx1ZSlcbiAgICB9IGVsc2Uge1xuICAgICAgcmV0dXJuICcnXG4gICAgfVxuICB9XG59XG4iXX0=
|
|
@@ -0,0 +1,97 @@
|
|
|
1
|
+
import { ChangeDetectionStrategy, Component, EventEmitter, Input, Output, QueryList, ViewChildren, } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
import * as i1 from "@angular/common";
|
|
4
|
+
import * as i2 from "./cell-table-item.component";
|
|
5
|
+
export class NggCellTableComponent {
|
|
6
|
+
constructor() {
|
|
7
|
+
this.items = new QueryList();
|
|
8
|
+
/** Make the most left element wrap */
|
|
9
|
+
this.overflowReverse = false;
|
|
10
|
+
/** List of table headers */
|
|
11
|
+
this.headerList = [];
|
|
12
|
+
/** List of data */
|
|
13
|
+
this.rows = [];
|
|
14
|
+
/** Make rows clickable and add arrow to the right */
|
|
15
|
+
this.clickableRows = false;
|
|
16
|
+
/** Label for the chevron of clickable rows */
|
|
17
|
+
this.clickLabel = 'View details';
|
|
18
|
+
/** Callback when a row is clicked */
|
|
19
|
+
this.rowClicked = new EventEmitter();
|
|
20
|
+
// ------------- EVENTS ------------------
|
|
21
|
+
/**
|
|
22
|
+
* handles the logic for when a row is clicked
|
|
23
|
+
* @param {TableRowClickedEvent} value the TableRowClickedEvent
|
|
24
|
+
*/
|
|
25
|
+
this.handleClickRow = (value) => {
|
|
26
|
+
if (this.clickableRows)
|
|
27
|
+
this.rowClicked.emit(value);
|
|
28
|
+
};
|
|
29
|
+
this.getValueTypeFromMain = () => {
|
|
30
|
+
const getMain = this.headerList.find((x) => x.main);
|
|
31
|
+
if (getMain)
|
|
32
|
+
return getMain.valueType || '';
|
|
33
|
+
return '';
|
|
34
|
+
};
|
|
35
|
+
this.getTableHeaderListValueFromNonMain = (header) => {
|
|
36
|
+
if (header.valueType)
|
|
37
|
+
return header.valueType || '';
|
|
38
|
+
return '';
|
|
39
|
+
};
|
|
40
|
+
this.mainHeader = (row) => {
|
|
41
|
+
const getMain = this.headerList.find((x) => x.main);
|
|
42
|
+
if (row && getMain) {
|
|
43
|
+
return {
|
|
44
|
+
value: row[getMain.tableKeySelector],
|
|
45
|
+
valueType: getMain.valueType || 'string',
|
|
46
|
+
tableKeySelector: getMain.tableKeySelector,
|
|
47
|
+
};
|
|
48
|
+
}
|
|
49
|
+
return {
|
|
50
|
+
value: '-',
|
|
51
|
+
valueType: 'string',
|
|
52
|
+
tableKeySelector: '-',
|
|
53
|
+
};
|
|
54
|
+
};
|
|
55
|
+
this.headerNoneMain = (headers) => {
|
|
56
|
+
if (this.overflowReverse)
|
|
57
|
+
return headers.filter((x) => !x.main).reverse();
|
|
58
|
+
return headers.filter((x) => !x.main);
|
|
59
|
+
};
|
|
60
|
+
this.getTableKeySelector = (row) => {
|
|
61
|
+
return this.mainHeader(row).tableKeySelector + row.rowId;
|
|
62
|
+
};
|
|
63
|
+
}
|
|
64
|
+
// ------- TRACKBY FOR STREAM ------------
|
|
65
|
+
trackByrowId(_, b) {
|
|
66
|
+
return b.rowId;
|
|
67
|
+
}
|
|
68
|
+
KeySelector(_, b) {
|
|
69
|
+
return b.tableKeySelector;
|
|
70
|
+
}
|
|
71
|
+
}
|
|
72
|
+
NggCellTableComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: NggCellTableComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
73
|
+
NggCellTableComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.9", type: NggCellTableComponent, selector: "ngg-cell-table", inputs: { minWidth: "minWidth", overflowReverse: "overflowReverse", className: "className", headerList: "headerList", rows: "rows", clickableRows: "clickableRows", clickLabel: "clickLabel" }, outputs: { rowClicked: "rowClicked" }, viewQueries: [{ propertyName: "items", predicate: ["items"], descendants: true }], ngImport: i0, template: "<div #targetElement role=\"table\" [ngClass]=\"className\">\n <div class=\"cell-table-table d-flex flex-column\">\n <div\n *ngFor=\"let row of rows; trackBy: trackByrowId\"\n (click)=\"handleClickRow(row)\"\n class=\"cell-table--row-wrapper\"\n role=\"rowgroup\"\n [class.is-clickable]=\"clickableRows\"\n >\n <div>\n <div #items [class.overflow-reverse]=\"overflowReverse\">\n <!-- Main header -->\n <div role=\"row\">\n <div\n nggCellTableItem\n [row]=\"mainHeader(row).value\"\n [valueType]=\"getValueTypeFromMain()\"\n [attr.valueType]=\"getValueTypeFromMain()\"\n [attr.id]=\"getTableKeySelector(row)\"\n role=\"rowheader\"\n aria-rowspan=\"3\"\n aria-colspan=\"3\"\n ></div>\n </div>\n <div role=\"row\">\n <div class=\"d-flex\">\n <!-- Sub Header -->\n <div\n nggCellTableItem\n class=\"sub-header py-0 fw-bold\"\n [row]=\"header.label\"\n [valueType]=\"getTableHeaderListValueFromNonMain(header)\"\n role=\"columnheader\"\n *ngFor=\"\n let header of headerNoneMain(headerList);\n trackBy: KeySelector\n \"\n ></div>\n </div>\n </div>\n\n <div role=\"row\">\n <!-- Sub Values -->\n <div class=\"d-flex\">\n <div\n nggCellTableItem\n class=\"sub-value py-0\"\n [row]=\"row[header.tableKeySelector]\"\n [valueType]=\"getTableHeaderListValueFromNonMain(header)\"\n [attr.valueType]=\"header.valueType\"\n role=\"cell\"\n *ngFor=\"\n let header of headerNoneMain(headerList);\n trackBy: KeySelector\n \"\n ></div>\n </div>\n </div>\n </div>\n </div>\n <div\n *ngIf=\"clickableRows\"\n role=\"row\"\n class=\"d-grid align-items-center ms-4 me-4 cell-table--arrow-container\"\n >\n <div role=\"cell\">\n <div\n role=\"button\"\n [attr.aria-label]=\"clickLabel\"\n tabindex=\"0\"\n [attr.aria-describedby]=\"getTableKeySelector(row)\"\n (keydown.enter)=\"handleClickRow(row)\"\n >\n <svg\n data-prefix=\"far\"\n data-icon=\"chevron-right\"\n class=\"svg-inline--fa fa-chevron-right fa-w-10\"\n xmlns=\"http://www.w3.org/2000/svg\"\n viewBox=\"0 0 320 512\"\n >\n <path\n fill=\"currentColor\"\n d=\"M113.3 47.41l183.1 191.1c4.469 4.625 6.688 10.62 6.688 16.59s-2.219 11.97-6.688 16.59l-183.1 191.1c-9.152 9.594-24.34 9.906-33.9 .7187c-9.625-9.125-9.938-24.38-.7187-33.91l168-175.4L78.71 80.6c-9.219-9.5-8.906-24.78 .7187-33.91C88.99 37.5 104.2 37.82 113.3 47.41z\"\n ></path>\n </svg>\n </div>\n </div>\n </div>\n </div>\n </div>\n</div>\n", styles: ["[role=rowheader]{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;margin-bottom:.5rem}[role=cell],[role=columnheader]{flex:1 1 0;margin-bottom:.125rem}.cell-table--row-wrapper{border-top:1px solid var(--gds-ref-pallet-base400);display:flex;padding:1rem}.cell-table--row-wrapper>div:first-child{flex:1 1 0}.cell-table--row-wrapper.is-clickable{cursor:pointer}.cell-table--row-wrapper.is-clickable:hover{background-color:var(--gds-ref-pallet-base100)}.cell-table--arrow-container{flex:0 0 auto;width:10px}.cell-table--arrow-container [tabindex=\"0\"]:focus{outline:2px solid var(--gds-ref-pallet-base800)}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.CellTableItemComponent, selector: "[nggCellTableItem]", inputs: ["row", "valueType", "id"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
74
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: NggCellTableComponent, decorators: [{
|
|
75
|
+
type: Component,
|
|
76
|
+
args: [{ selector: 'ngg-cell-table', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div #targetElement role=\"table\" [ngClass]=\"className\">\n <div class=\"cell-table-table d-flex flex-column\">\n <div\n *ngFor=\"let row of rows; trackBy: trackByrowId\"\n (click)=\"handleClickRow(row)\"\n class=\"cell-table--row-wrapper\"\n role=\"rowgroup\"\n [class.is-clickable]=\"clickableRows\"\n >\n <div>\n <div #items [class.overflow-reverse]=\"overflowReverse\">\n <!-- Main header -->\n <div role=\"row\">\n <div\n nggCellTableItem\n [row]=\"mainHeader(row).value\"\n [valueType]=\"getValueTypeFromMain()\"\n [attr.valueType]=\"getValueTypeFromMain()\"\n [attr.id]=\"getTableKeySelector(row)\"\n role=\"rowheader\"\n aria-rowspan=\"3\"\n aria-colspan=\"3\"\n ></div>\n </div>\n <div role=\"row\">\n <div class=\"d-flex\">\n <!-- Sub Header -->\n <div\n nggCellTableItem\n class=\"sub-header py-0 fw-bold\"\n [row]=\"header.label\"\n [valueType]=\"getTableHeaderListValueFromNonMain(header)\"\n role=\"columnheader\"\n *ngFor=\"\n let header of headerNoneMain(headerList);\n trackBy: KeySelector\n \"\n ></div>\n </div>\n </div>\n\n <div role=\"row\">\n <!-- Sub Values -->\n <div class=\"d-flex\">\n <div\n nggCellTableItem\n class=\"sub-value py-0\"\n [row]=\"row[header.tableKeySelector]\"\n [valueType]=\"getTableHeaderListValueFromNonMain(header)\"\n [attr.valueType]=\"header.valueType\"\n role=\"cell\"\n *ngFor=\"\n let header of headerNoneMain(headerList);\n trackBy: KeySelector\n \"\n ></div>\n </div>\n </div>\n </div>\n </div>\n <div\n *ngIf=\"clickableRows\"\n role=\"row\"\n class=\"d-grid align-items-center ms-4 me-4 cell-table--arrow-container\"\n >\n <div role=\"cell\">\n <div\n role=\"button\"\n [attr.aria-label]=\"clickLabel\"\n tabindex=\"0\"\n [attr.aria-describedby]=\"getTableKeySelector(row)\"\n (keydown.enter)=\"handleClickRow(row)\"\n >\n <svg\n data-prefix=\"far\"\n data-icon=\"chevron-right\"\n class=\"svg-inline--fa fa-chevron-right fa-w-10\"\n xmlns=\"http://www.w3.org/2000/svg\"\n viewBox=\"0 0 320 512\"\n >\n <path\n fill=\"currentColor\"\n d=\"M113.3 47.41l183.1 191.1c4.469 4.625 6.688 10.62 6.688 16.59s-2.219 11.97-6.688 16.59l-183.1 191.1c-9.152 9.594-24.34 9.906-33.9 .7187c-9.625-9.125-9.938-24.38-.7187-33.91l168-175.4L78.71 80.6c-9.219-9.5-8.906-24.78 .7187-33.91C88.99 37.5 104.2 37.82 113.3 47.41z\"\n ></path>\n </svg>\n </div>\n </div>\n </div>\n </div>\n </div>\n</div>\n", styles: ["[role=rowheader]{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;margin-bottom:.5rem}[role=cell],[role=columnheader]{flex:1 1 0;margin-bottom:.125rem}.cell-table--row-wrapper{border-top:1px solid var(--gds-ref-pallet-base400);display:flex;padding:1rem}.cell-table--row-wrapper>div:first-child{flex:1 1 0}.cell-table--row-wrapper.is-clickable{cursor:pointer}.cell-table--row-wrapper.is-clickable:hover{background-color:var(--gds-ref-pallet-base100)}.cell-table--arrow-container{flex:0 0 auto;width:10px}.cell-table--arrow-container [tabindex=\"0\"]:focus{outline:2px solid var(--gds-ref-pallet-base800)}\n"] }]
|
|
77
|
+
}], propDecorators: { items: [{
|
|
78
|
+
type: ViewChildren,
|
|
79
|
+
args: ['items']
|
|
80
|
+
}], minWidth: [{
|
|
81
|
+
type: Input
|
|
82
|
+
}], overflowReverse: [{
|
|
83
|
+
type: Input
|
|
84
|
+
}], className: [{
|
|
85
|
+
type: Input
|
|
86
|
+
}], headerList: [{
|
|
87
|
+
type: Input
|
|
88
|
+
}], rows: [{
|
|
89
|
+
type: Input
|
|
90
|
+
}], clickableRows: [{
|
|
91
|
+
type: Input
|
|
92
|
+
}], clickLabel: [{
|
|
93
|
+
type: Input
|
|
94
|
+
}], rowClicked: [{
|
|
95
|
+
type: Output
|
|
96
|
+
}] } });
|
|
97
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cell-table.component.js","sourceRoot":"","sources":["../../../../../../libs/angular/src/lib/cell-table/cell-table.component.ts","../../../../../../libs/angular/src/lib/cell-table/cell-table.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  Component,\n  ElementRef,\n  EventEmitter,\n  Input,\n  Output,\n  QueryList,\n  ViewChildren,\n} from '@angular/core'\nimport {\n  TableHeaderListItem,\n  TableHeaderListValueType,\n  TableRow,\n} from './cell-table.types'\n\n@Component({\n  selector: 'ngg-cell-table',\n  templateUrl: './cell-table.component.html',\n  styleUrls: ['./cell-table.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class NggCellTableComponent {\n  @ViewChildren('items') items: QueryList<ElementRef> =\n    new QueryList<ElementRef>()\n\n  /** Cell min-width to force same width on small screens */\n  @Input() minWidth?: number\n\n  /** Make the most left element wrap */\n  @Input() overflowReverse = false\n\n  /** Element class name */\n  @Input() className?: string\n\n  /** List of table headers */\n  @Input() headerList: TableHeaderListItem[] = []\n\n  /** List of data */\n  @Input() rows: TableRow[] = []\n\n  /** Make rows clickable and add arrow to the right */\n  @Input() clickableRows = false\n\n  /** Label for the chevron of clickable rows */\n  @Input() clickLabel = 'View details'\n\n  /** Callback when a row is clicked */\n  @Output() rowClicked: EventEmitter<TableRow> = new EventEmitter()\n\n  // ------------- EVENTS ------------------\n  /**\n   * handles the logic for when a row is clicked\n   * @param {TableRowClickedEvent} value the TableRowClickedEvent\n   */\n  handleClickRow = (value: TableRow): void => {\n    if (this.clickableRows) this.rowClicked.emit(value)\n  }\n\n  getValueTypeFromMain = (): TableHeaderListValueType => {\n    const getMain = this.headerList.find((x) => x.main)\n    if (getMain) return getMain.valueType || ''\n    return ''\n  }\n\n  getTableHeaderListValueFromNonMain = (\n    header: TableHeaderListItem\n  ): TableHeaderListValueType => {\n    if (header.valueType) return header.valueType || ''\n    return ''\n  }\n\n  mainHeader = (row: TableRow) => {\n    const getMain = this.headerList.find((x) => x.main)\n    if (row && getMain) {\n      return {\n        value: row[getMain.tableKeySelector],\n        valueType: getMain.valueType || 'string',\n        tableKeySelector: getMain.tableKeySelector,\n      }\n    }\n    return {\n      value: '-',\n      valueType: 'string',\n      tableKeySelector: '-',\n    }\n  }\n\n  headerNoneMain = (headers: TableHeaderListItem[]) => {\n    if (this.overflowReverse) return headers.filter((x) => !x.main).reverse()\n    return headers.filter((x) => !x.main)\n  }\n\n  getTableKeySelector = (row: TableRow) => {\n    return this.mainHeader(row).tableKeySelector + row.rowId\n  }\n\n  // ------- TRACKBY FOR STREAM ------------\n  trackByrowId(_: any, b: TableRow) {\n    return b.rowId\n  }\n  KeySelector(_: any, b: TableHeaderListItem) {\n    return b.tableKeySelector\n  }\n}\n","<div #targetElement role=\"table\" [ngClass]=\"className\">\n  <div class=\"cell-table-table d-flex flex-column\">\n    <div\n      *ngFor=\"let row of rows; trackBy: trackByrowId\"\n      (click)=\"handleClickRow(row)\"\n      class=\"cell-table--row-wrapper\"\n      role=\"rowgroup\"\n      [class.is-clickable]=\"clickableRows\"\n    >\n      <div>\n        <div #items [class.overflow-reverse]=\"overflowReverse\">\n          <!-- Main header -->\n          <div role=\"row\">\n            <div\n              nggCellTableItem\n              [row]=\"mainHeader(row).value\"\n              [valueType]=\"getValueTypeFromMain()\"\n              [attr.valueType]=\"getValueTypeFromMain()\"\n              [attr.id]=\"getTableKeySelector(row)\"\n              role=\"rowheader\"\n              aria-rowspan=\"3\"\n              aria-colspan=\"3\"\n            ></div>\n          </div>\n          <div role=\"row\">\n            <div class=\"d-flex\">\n              <!-- Sub Header -->\n              <div\n                nggCellTableItem\n                class=\"sub-header py-0 fw-bold\"\n                [row]=\"header.label\"\n                [valueType]=\"getTableHeaderListValueFromNonMain(header)\"\n                role=\"columnheader\"\n                *ngFor=\"\n                  let header of headerNoneMain(headerList);\n                  trackBy: KeySelector\n                \"\n              ></div>\n            </div>\n          </div>\n\n          <div role=\"row\">\n            <!-- Sub Values -->\n            <div class=\"d-flex\">\n              <div\n                nggCellTableItem\n                class=\"sub-value py-0\"\n                [row]=\"row[header.tableKeySelector]\"\n                [valueType]=\"getTableHeaderListValueFromNonMain(header)\"\n                [attr.valueType]=\"header.valueType\"\n                role=\"cell\"\n                *ngFor=\"\n                  let header of headerNoneMain(headerList);\n                  trackBy: KeySelector\n                \"\n              ></div>\n            </div>\n          </div>\n        </div>\n      </div>\n      <div\n        *ngIf=\"clickableRows\"\n        role=\"row\"\n        class=\"d-grid align-items-center ms-4 me-4 cell-table--arrow-container\"\n      >\n        <div role=\"cell\">\n          <div\n            role=\"button\"\n            [attr.aria-label]=\"clickLabel\"\n            tabindex=\"0\"\n            [attr.aria-describedby]=\"getTableKeySelector(row)\"\n            (keydown.enter)=\"handleClickRow(row)\"\n          >\n            <svg\n              data-prefix=\"far\"\n              data-icon=\"chevron-right\"\n              class=\"svg-inline--fa fa-chevron-right fa-w-10\"\n              xmlns=\"http://www.w3.org/2000/svg\"\n              viewBox=\"0 0 320 512\"\n            >\n              <path\n                fill=\"currentColor\"\n                d=\"M113.3 47.41l183.1 191.1c4.469 4.625 6.688 10.62 6.688 16.59s-2.219 11.97-6.688 16.59l-183.1 191.1c-9.152 9.594-24.34 9.906-33.9 .7187c-9.625-9.125-9.938-24.38-.7187-33.91l168-175.4L78.71 80.6c-9.219-9.5-8.906-24.78 .7187-33.91C88.99 37.5 104.2 37.82 113.3 47.41z\"\n              ></path>\n            </svg>\n          </div>\n        </div>\n      </div>\n    </div>\n  </div>\n</div>\n"]}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
import { CommonModule } from '@angular/common';
|
|
2
|
+
import { NgModule } from '@angular/core';
|
|
3
|
+
import { NggCellTableComponent } from './cell-table.component';
|
|
4
|
+
import { CellTableItemComponent } from './cell-table-item.component';
|
|
5
|
+
import { SlidingUnderlineDirective } from './cell-underline.directive';
|
|
6
|
+
import * as i0 from "@angular/core";
|
|
7
|
+
export class NggCellTableModule {
|
|
8
|
+
}
|
|
9
|
+
NggCellTableModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: NggCellTableModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
10
|
+
NggCellTableModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "15.2.9", ngImport: i0, type: NggCellTableModule, declarations: [NggCellTableComponent,
|
|
11
|
+
CellTableItemComponent,
|
|
12
|
+
SlidingUnderlineDirective], imports: [CommonModule], exports: [NggCellTableComponent] });
|
|
13
|
+
NggCellTableModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: NggCellTableModule, imports: [CommonModule] });
|
|
14
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: NggCellTableModule, decorators: [{
|
|
15
|
+
type: NgModule,
|
|
16
|
+
args: [{
|
|
17
|
+
imports: [CommonModule],
|
|
18
|
+
exports: [NggCellTableComponent],
|
|
19
|
+
declarations: [
|
|
20
|
+
NggCellTableComponent,
|
|
21
|
+
CellTableItemComponent,
|
|
22
|
+
SlidingUnderlineDirective,
|
|
23
|
+
],
|
|
24
|
+
}]
|
|
25
|
+
}] });
|
|
26
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2VsbC10YWJsZS5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9saWJzL2FuZ3VsYXIvc3JjL2xpYi9jZWxsLXRhYmxlL2NlbGwtdGFibGUubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQTtBQUM5QyxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFBO0FBRXhDLE9BQU8sRUFBRSxxQkFBcUIsRUFBRSxNQUFNLHdCQUF3QixDQUFBO0FBQzlELE9BQU8sRUFBRSxzQkFBc0IsRUFBRSxNQUFNLDZCQUE2QixDQUFBO0FBQ3BFLE9BQU8sRUFBRSx5QkFBeUIsRUFBRSxNQUFNLDRCQUE0QixDQUFBOztBQVd0RSxNQUFNLE9BQU8sa0JBQWtCOzsrR0FBbEIsa0JBQWtCO2dIQUFsQixrQkFBa0IsaUJBTDNCLHFCQUFxQjtRQUNyQixzQkFBc0I7UUFDdEIseUJBQXlCLGFBTGpCLFlBQVksYUFDWixxQkFBcUI7Z0hBT3BCLGtCQUFrQixZQVJuQixZQUFZOzJGQVFYLGtCQUFrQjtrQkFUOUIsUUFBUTttQkFBQztvQkFDUixPQUFPLEVBQUUsQ0FBQyxZQUFZLENBQUM7b0JBQ3ZCLE9BQU8sRUFBRSxDQUFDLHFCQUFxQixDQUFDO29CQUNoQyxZQUFZLEVBQUU7d0JBQ1oscUJBQXFCO3dCQUNyQixzQkFBc0I7d0JBQ3RCLHlCQUF5QjtxQkFDMUI7aUJBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nXG5pbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnXG5cbmltcG9ydCB7IE5nZ0NlbGxUYWJsZUNvbXBvbmVudCB9IGZyb20gJy4vY2VsbC10YWJsZS5jb21wb25lbnQnXG5pbXBvcnQgeyBDZWxsVGFibGVJdGVtQ29tcG9uZW50IH0gZnJvbSAnLi9jZWxsLXRhYmxlLWl0ZW0uY29tcG9uZW50J1xuaW1wb3J0IHsgU2xpZGluZ1VuZGVybGluZURpcmVjdGl2ZSB9IGZyb20gJy4vY2VsbC11bmRlcmxpbmUuZGlyZWN0aXZlJ1xuXG5ATmdNb2R1bGUoe1xuICBpbXBvcnRzOiBbQ29tbW9uTW9kdWxlXSxcbiAgZXhwb3J0czogW05nZ0NlbGxUYWJsZUNvbXBvbmVudF0sXG4gIGRlY2xhcmF0aW9uczogW1xuICAgIE5nZ0NlbGxUYWJsZUNvbXBvbmVudCxcbiAgICBDZWxsVGFibGVJdGVtQ29tcG9uZW50LFxuICAgIFNsaWRpbmdVbmRlcmxpbmVEaXJlY3RpdmUsXG4gIF0sXG59KVxuZXhwb3J0IGNsYXNzIE5nZ0NlbGxUYWJsZU1vZHVsZSB7fVxuIl19
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
export default class Table {
|
|
2
|
+
constructor(table) {
|
|
3
|
+
this.data = table.data;
|
|
4
|
+
this.header = table.header;
|
|
5
|
+
}
|
|
6
|
+
}
|
|
7
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2VsbC10YWJsZS50eXBlcy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvYW5ndWxhci9zcmMvbGliL2NlbGwtdGFibGUvY2VsbC10YWJsZS50eXBlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxNQUFNLENBQUMsT0FBTyxPQUFPLEtBQUs7SUFDeEIsWUFBWSxLQUEwRDtRQUNwRSxJQUFJLENBQUMsSUFBSSxHQUFHLEtBQUssQ0FBQyxJQUFJLENBQUE7UUFDdEIsSUFBSSxDQUFDLE1BQU0sR0FBRyxLQUFLLENBQUMsTUFBTSxDQUFBO0lBQzVCLENBQUM7Q0FHRiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBkZWZhdWx0IGNsYXNzIFRhYmxlIHtcbiAgY29uc3RydWN0b3IodGFibGU6IHsgZGF0YTogVGFibGVSb3dbXTsgaGVhZGVyOiBUYWJsZUhlYWRlckxpc3RJdGVtW10gfSkge1xuICAgIHRoaXMuZGF0YSA9IHRhYmxlLmRhdGFcbiAgICB0aGlzLmhlYWRlciA9IHRhYmxlLmhlYWRlclxuICB9XG4gIGRhdGE6IFRhYmxlUm93W11cbiAgaGVhZGVyOiBUYWJsZUhlYWRlckxpc3RJdGVtW11cbn1cblxuLyoqIFRoZSB0eXBlIG9mIGEgZGF0YSB0aGUgdmFsdWVzIGluIGEgY29sdW1uIHJlcHJlc2VudCAgKi9cbmV4cG9ydCB0eXBlIFRhYmxlSGVhZGVyTGlzdFZhbHVlVHlwZSA9XG4gIHwgJ251bWJlcidcbiAgfCAnc3RyaW5nJ1xuICB8ICdkYXRlJ1xuICB8ICdkYXRldGltZSdcbiAgfCAnYm9vbCdcbiAgfCAnY3VzdG9tLWh0bWwnXG4gIHwgJ3NpZ24nXG4gIHwgJ3N0cmVhbVNpZ24nXG4gIHwgJydcblxuLyoqIFRhYmxlIEhlYWRlciBMaXN0IEl0ZW0gSW50ZXJmYWNlICovXG5leHBvcnQgaW50ZXJmYWNlIFRhYmxlSGVhZGVyTGlzdEl0ZW08XG4gIFQgZXh0ZW5kcyBSZWNvcmQ8c3RyaW5nLCB1bmtub3duPiA9IFJlY29yZDxzdHJpbmcsIHVua25vd24+XG4+IHtcbiAgLyoqIFRoZSBsYWJlbCBkaXNwbGF5ZWQgKi9cbiAgbGFiZWw6IHN0cmluZ1xuICAvKiogdGhlIGtleSBzZWxlY3RvciBjb3JyZXNwb25kaW5nIHRvIHRvIHRoZSBUYWJsZUxpc3QgSXRlbSB3aGljaCB0aGlzIGNvbHVtbiBpcyB0YXJnZXRpbmcgKi9cbiAgLy8gdGFibGVLZXlTZWxlY3Rvcjoga2V5b2YgVDtcbiAgdGFibGVLZXlTZWxlY3Rvcjogc3RyaW5nXG4gIC8qKiB0aGUgdHlwZSBvZiB2YWx1ZTogc3RyaW5nLCBkYXRlIG9yIG51bWJlciAqL1xuICB2YWx1ZVR5cGU/OiBUYWJsZUhlYWRlckxpc3RWYWx1ZVR5cGVcblxuICAvKiogdGhlIG1haW4gZmllbGQgZm9yIHN0YWNrZWQgdGFibGUgKi9cbiAgbWFpbj86IGJvb2xlYW5cbn1cblxuZXhwb3J0IGludGVyZmFjZSBUYWJsZVJvdyB7XG4gIFtwcm9wOiBzdHJpbmddOiBhbnlcbiAgcm93SWQ6IHN0cmluZyB8IG51bWJlclxufVxuXG4vKiogVGhlIGluZm9ybWF0aW9uIG9uIHRoZSBjdXJyZW50bHkgc2VsZWN0ZWQgc29ydDogY29sdW1uIG5hbWUsIHR5cGUgYW5kIGFzYy9kZXNjICAqL1xuZXhwb3J0IGludGVyZmFjZSBTb3J0SW5mbzxcbiAgVCBleHRlbmRzIFJlY29yZDxzdHJpbmcsIHVua25vd24+ID0geyBbazogc3RyaW5nXTogYW55IH1cbj4ge1xuICAvKiogY29sdW1uIG5hbWUgKi9cbiAgY29sdW1uOiBrZXlvZiBUXG4gIC8qKiBpcyBhc2NlbmRpbmcgKGZhbHNlIGZvciBkZXNjZW5kaW5nKSAqL1xuICBpc0FzY2VuZGluZzogYm9vbGVhblxufVxuIl19
|
|
@@ -0,0 +1,55 @@
|
|
|
1
|
+
import { Directive, ElementRef, Input, } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
export class SlidingUnderlineDirective {
|
|
4
|
+
constructor(element) {
|
|
5
|
+
this.element = element;
|
|
6
|
+
}
|
|
7
|
+
ngOnInit() {
|
|
8
|
+
if (this.element?.nativeElement) {
|
|
9
|
+
this.element.nativeElement.classList.add('slider');
|
|
10
|
+
this.element.nativeElement.addEventListener('animationend', () => {
|
|
11
|
+
this.element.nativeElement.classList.remove('left', 'slider-positive', 'slider-negative');
|
|
12
|
+
});
|
|
13
|
+
}
|
|
14
|
+
}
|
|
15
|
+
ngOnChanges(changes) {
|
|
16
|
+
if (!this.disabled) {
|
|
17
|
+
if (changes.slidingUnderline &&
|
|
18
|
+
changes.key &&
|
|
19
|
+
!changes.slidingUnderline.isFirstChange() &&
|
|
20
|
+
!changes?.key?.isFirstChange()) {
|
|
21
|
+
if (changes.key.currentValue === changes.key.previousValue) {
|
|
22
|
+
this.addAnimation(changes.slidingUnderline.currentValue, changes.slidingUnderline.previousValue);
|
|
23
|
+
}
|
|
24
|
+
}
|
|
25
|
+
else {
|
|
26
|
+
if (changes.slidingUnderline &&
|
|
27
|
+
!changes.slidingUnderline.isFirstChange()) {
|
|
28
|
+
this.addAnimation(changes.slidingUnderline.currentValue, changes.slidingUnderline.previousValue);
|
|
29
|
+
}
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
}
|
|
33
|
+
addAnimation(current, previous) {
|
|
34
|
+
if (current > previous)
|
|
35
|
+
this.element.nativeElement.classList.add('slider-positive');
|
|
36
|
+
else
|
|
37
|
+
this.element.nativeElement.classList.add('slider-negative');
|
|
38
|
+
this.element.nativeElement.classList.add('left');
|
|
39
|
+
}
|
|
40
|
+
}
|
|
41
|
+
SlidingUnderlineDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: SlidingUnderlineDirective, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive });
|
|
42
|
+
SlidingUnderlineDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "15.2.9", type: SlidingUnderlineDirective, selector: "[nggSlidingUnderline]", inputs: { nggSlidingUnderline: "nggSlidingUnderline", key: "key", disabled: "disabled" }, usesOnChanges: true, ngImport: i0 });
|
|
43
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: SlidingUnderlineDirective, decorators: [{
|
|
44
|
+
type: Directive,
|
|
45
|
+
args: [{
|
|
46
|
+
selector: '[nggSlidingUnderline]',
|
|
47
|
+
}]
|
|
48
|
+
}], ctorParameters: function () { return [{ type: i0.ElementRef }]; }, propDecorators: { nggSlidingUnderline: [{
|
|
49
|
+
type: Input
|
|
50
|
+
}], key: [{
|
|
51
|
+
type: Input
|
|
52
|
+
}], disabled: [{
|
|
53
|
+
type: Input
|
|
54
|
+
}] } });
|
|
55
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2VsbC11bmRlcmxpbmUuZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9hbmd1bGFyL3NyYy9saWIvY2VsbC10YWJsZS9jZWxsLXVuZGVybGluZS5kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUNMLFNBQVMsRUFDVCxVQUFVLEVBQ1YsS0FBSyxHQUlOLE1BQU0sZUFBZSxDQUFBOztBQUt0QixNQUFNLE9BQU8seUJBQXlCO0lBQ3BDLFlBQW9CLE9BQWdDO1FBQWhDLFlBQU8sR0FBUCxPQUFPLENBQXlCO0lBQUcsQ0FBQztJQU14RCxRQUFRO1FBQ04sSUFBSSxJQUFJLENBQUMsT0FBTyxFQUFFLGFBQWEsRUFBRTtZQUMvQixJQUFJLENBQUMsT0FBTyxDQUFDLGFBQWEsQ0FBQyxTQUFTLENBQUMsR0FBRyxDQUFDLFFBQVEsQ0FBQyxDQUFBO1lBRWxELElBQUksQ0FBQyxPQUFPLENBQUMsYUFBYSxDQUFDLGdCQUFnQixDQUFDLGNBQWMsRUFBRSxHQUFHLEVBQUU7Z0JBQy9ELElBQUksQ0FBQyxPQUFPLENBQUMsYUFBYSxDQUFDLFNBQVMsQ0FBQyxNQUFNLENBQ3pDLE1BQU0sRUFDTixpQkFBaUIsRUFDakIsaUJBQWlCLENBQ2xCLENBQUE7WUFDSCxDQUFDLENBQUMsQ0FBQTtTQUNIO0lBQ0gsQ0FBQztJQUVELFdBQVcsQ0FBQyxPQUFzQjtRQUNoQyxJQUFJLENBQUMsSUFBSSxDQUFDLFFBQVEsRUFBRTtZQUNsQixJQUNFLE9BQU8sQ0FBQyxnQkFBZ0I7Z0JBQ3hCLE9BQU8sQ0FBQyxHQUFHO2dCQUNYLENBQUMsT0FBTyxDQUFDLGdCQUFnQixDQUFDLGFBQWEsRUFBRTtnQkFDekMsQ0FBQyxPQUFPLEVBQUUsR0FBRyxFQUFFLGFBQWEsRUFBRSxFQUM5QjtnQkFDQSxJQUFJLE9BQU8sQ0FBQyxHQUFHLENBQUMsWUFBWSxLQUFLLE9BQU8sQ0FBQyxHQUFHLENBQUMsYUFBYSxFQUFFO29CQUMxRCxJQUFJLENBQUMsWUFBWSxDQUNmLE9BQU8sQ0FBQyxnQkFBZ0IsQ0FBQyxZQUFZLEVBQ3JDLE9BQU8sQ0FBQyxnQkFBZ0IsQ0FBQyxhQUFhLENBQ3ZDLENBQUE7aUJBQ0Y7YUFDRjtpQkFBTTtnQkFDTCxJQUNFLE9BQU8sQ0FBQyxnQkFBZ0I7b0JBQ3hCLENBQUMsT0FBTyxDQUFDLGdCQUFnQixDQUFDLGFBQWEsRUFBRSxFQUN6QztvQkFDQSxJQUFJLENBQUMsWUFBWSxDQUNmLE9BQU8sQ0FBQyxnQkFBZ0IsQ0FBQyxZQUFZLEVBQ3JDLE9BQU8sQ0FBQyxnQkFBZ0IsQ0FBQyxhQUFhLENBQ3ZDLENBQUE7aUJBQ0Y7YUFDRjtTQUNGO0lBQ0gsQ0FBQztJQUVELFlBQVksQ0FBQyxPQUFZLEVBQUUsUUFBYTtRQUN0QyxJQUFJLE9BQU8sR0FBRyxRQUFRO1lBQ3BCLElBQUksQ0FBQyxPQUFPLENBQUMsYUFBYSxDQUFDLFNBQVMsQ0FBQyxHQUFHLENBQUMsaUJBQWlCLENBQUMsQ0FBQTs7WUFDeEQsSUFBSSxDQUFDLE9BQU8sQ0FBQyxhQUFhLENBQUMsU0FBUyxDQUFDLEdBQUcsQ0FBQyxpQkFBaUIsQ0FBQyxDQUFBO1FBQ2hFLElBQUksQ0FBQyxPQUFPLENBQUMsYUFBYSxDQUFDLFNBQVMsQ0FBQyxHQUFHLENBQUMsTUFBTSxDQUFDLENBQUE7SUFDbEQsQ0FBQzs7c0hBdERVLHlCQUF5QjswR0FBekIseUJBQXlCOzJGQUF6Qix5QkFBeUI7a0JBSHJDLFNBQVM7bUJBQUM7b0JBQ1QsUUFBUSxFQUFFLHVCQUF1QjtpQkFDbEM7aUdBSWlCLG1CQUFtQjtzQkFBbEMsS0FBSztnQkFDVSxHQUFHO3NCQUFsQixLQUFLO2dCQUNVLFFBQVE7c0JBQXZCLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xuICBEaXJlY3RpdmUsXG4gIEVsZW1lbnRSZWYsXG4gIElucHV0LFxuICBTaW1wbGVDaGFuZ2VzLFxuICBPbkNoYW5nZXMsXG4gIE9uSW5pdCxcbn0gZnJvbSAnQGFuZ3VsYXIvY29yZSdcblxuQERpcmVjdGl2ZSh7XG4gIHNlbGVjdG9yOiAnW25nZ1NsaWRpbmdVbmRlcmxpbmVdJyxcbn0pXG5leHBvcnQgY2xhc3MgU2xpZGluZ1VuZGVybGluZURpcmVjdGl2ZSBpbXBsZW1lbnRzIE9uSW5pdCwgT25DaGFuZ2VzIHtcbiAgY29uc3RydWN0b3IocHJpdmF0ZSBlbGVtZW50OiBFbGVtZW50UmVmPEhUTUxFbGVtZW50Pikge31cblxuICBASW5wdXQoKSBwdWJsaWMgbmdnU2xpZGluZ1VuZGVybGluZTogYW55XG4gIEBJbnB1dCgpIHB1YmxpYyBrZXk/OiBhbnlcbiAgQElucHV0KCkgcHVibGljIGRpc2FibGVkPzogYm9vbGVhblxuXG4gIG5nT25Jbml0KCk6IHZvaWQge1xuICAgIGlmICh0aGlzLmVsZW1lbnQ/Lm5hdGl2ZUVsZW1lbnQpIHtcbiAgICAgIHRoaXMuZWxlbWVudC5uYXRpdmVFbGVtZW50LmNsYXNzTGlzdC5hZGQoJ3NsaWRlcicpXG5cbiAgICAgIHRoaXMuZWxlbWVudC5uYXRpdmVFbGVtZW50LmFkZEV2ZW50TGlzdGVuZXIoJ2FuaW1hdGlvbmVuZCcsICgpID0+IHtcbiAgICAgICAgdGhpcy5lbGVtZW50Lm5hdGl2ZUVsZW1lbnQuY2xhc3NMaXN0LnJlbW92ZShcbiAgICAgICAgICAnbGVmdCcsXG4gICAgICAgICAgJ3NsaWRlci1wb3NpdGl2ZScsXG4gICAgICAgICAgJ3NsaWRlci1uZWdhdGl2ZSdcbiAgICAgICAgKVxuICAgICAgfSlcbiAgICB9XG4gIH1cblxuICBuZ09uQ2hhbmdlcyhjaGFuZ2VzOiBTaW1wbGVDaGFuZ2VzKSB7XG4gICAgaWYgKCF0aGlzLmRpc2FibGVkKSB7XG4gICAgICBpZiAoXG4gICAgICAgIGNoYW5nZXMuc2xpZGluZ1VuZGVybGluZSAmJlxuICAgICAgICBjaGFuZ2VzLmtleSAmJlxuICAgICAgICAhY2hhbmdlcy5zbGlkaW5nVW5kZXJsaW5lLmlzRmlyc3RDaGFuZ2UoKSAmJlxuICAgICAgICAhY2hhbmdlcz8ua2V5Py5pc0ZpcnN0Q2hhbmdlKClcbiAgICAgICkge1xuICAgICAgICBpZiAoY2hhbmdlcy5rZXkuY3VycmVudFZhbHVlID09PSBjaGFuZ2VzLmtleS5wcmV2aW91c1ZhbHVlKSB7XG4gICAgICAgICAgdGhpcy5hZGRBbmltYXRpb24oXG4gICAgICAgICAgICBjaGFuZ2VzLnNsaWRpbmdVbmRlcmxpbmUuY3VycmVudFZhbHVlLFxuICAgICAgICAgICAgY2hhbmdlcy5zbGlkaW5nVW5kZXJsaW5lLnByZXZpb3VzVmFsdWVcbiAgICAgICAgICApXG4gICAgICAgIH1cbiAgICAgIH0gZWxzZSB7XG4gICAgICAgIGlmIChcbiAgICAgICAgICBjaGFuZ2VzLnNsaWRpbmdVbmRlcmxpbmUgJiZcbiAgICAgICAgICAhY2hhbmdlcy5zbGlkaW5nVW5kZXJsaW5lLmlzRmlyc3RDaGFuZ2UoKVxuICAgICAgICApIHtcbiAgICAgICAgICB0aGlzLmFkZEFuaW1hdGlvbihcbiAgICAgICAgICAgIGNoYW5nZXMuc2xpZGluZ1VuZGVybGluZS5jdXJyZW50VmFsdWUsXG4gICAgICAgICAgICBjaGFuZ2VzLnNsaWRpbmdVbmRlcmxpbmUucHJldmlvdXNWYWx1ZVxuICAgICAgICAgIClcbiAgICAgICAgfVxuICAgICAgfVxuICAgIH1cbiAgfVxuXG4gIGFkZEFuaW1hdGlvbihjdXJyZW50OiBhbnksIHByZXZpb3VzOiBhbnkpIHtcbiAgICBpZiAoY3VycmVudCA+IHByZXZpb3VzKVxuICAgICAgdGhpcy5lbGVtZW50Lm5hdGl2ZUVsZW1lbnQuY2xhc3NMaXN0LmFkZCgnc2xpZGVyLXBvc2l0aXZlJylcbiAgICBlbHNlIHRoaXMuZWxlbWVudC5uYXRpdmVFbGVtZW50LmNsYXNzTGlzdC5hZGQoJ3NsaWRlci1uZWdhdGl2ZScpXG4gICAgdGhpcy5lbGVtZW50Lm5hdGl2ZUVsZW1lbnQuY2xhc3NMaXN0LmFkZCgnbGVmdCcpXG4gIH1cbn1cbiJdfQ==
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
export * from './cell-table.component';
|
|
2
|
+
export * from './cell-table.module';
|
|
3
|
+
export * from './cell-table.types';
|
|
4
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9saWJzL2FuZ3VsYXIvc3JjL2xpYi9jZWxsLXRhYmxlL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsd0JBQXdCLENBQUE7QUFDdEMsY0FBYyxxQkFBcUIsQ0FBQTtBQUNuQyxjQUFjLG9CQUFvQixDQUFBIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9jZWxsLXRhYmxlLmNvbXBvbmVudCdcbmV4cG9ydCAqIGZyb20gJy4vY2VsbC10YWJsZS5tb2R1bGUnXG5leHBvcnQgKiBmcm9tICcuL2NlbGwtdGFibGUudHlwZXMnXG4iXX0=
|
|
@@ -62,13 +62,13 @@ export class NggDatepickerComponent {
|
|
|
62
62
|
}
|
|
63
63
|
}
|
|
64
64
|
NggDatepickerComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: NggDatepickerComponent, deps: [{ token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
|
|
65
|
-
NggDatepickerComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.9", type: NggDatepickerComponent, selector: "ngg-datepicker", inputs: { size: "size", hideLabel: "hideLabel", options: "options", value: "value", id: "id", label: "label", isValid: "isValid" }, outputs: { valueChange: "valueChange" }, providers: [
|
|
65
|
+
NggDatepickerComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.9", type: NggDatepickerComponent, selector: "ngg-datepicker", inputs: { size: "size", hideLabel: "hideLabel", disabledWeekends: "disabledWeekends", disabledDates: "disabledDates", options: "options", value: "value", id: "id", label: "label", isValid: "isValid" }, outputs: { valueChange: "valueChange" }, providers: [
|
|
66
66
|
{
|
|
67
67
|
provide: NG_VALUE_ACCESSOR,
|
|
68
68
|
useExisting: NggDatepickerComponent,
|
|
69
69
|
multi: true,
|
|
70
70
|
},
|
|
71
|
-
], ngImport: i0, template: "<div class=\"form-group\">\n <gds-datepicker\n *nggCoreElement\n [attr.id]=\"id\"\n [label]=\"label\"\n [value]=\"value\"\n (change)=\"onDateChange($event)\"\n [invalid]=\"isValid === false\"\n [min]=\"min\"\n [max]=\"max\"\n [showWeekNumbers]=\"showWeekNumbers\"\n [dateformat]=\"dateFormat\"\n [size]=\"size\"\n [hideLabel]=\"hideLabel\"\n >\n <span slot=\"message\">\n <ng-content select=\"[data-form-info]\"></ng-content>\n </span>\n </gds-datepicker>\n</div>\n", dependencies: [{ kind: "directive", type: i1.NggCoreElementDirective, selector: "[nggCoreElement]" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
71
|
+
], ngImport: i0, template: "<div class=\"form-group\">\n <gds-datepicker\n *nggCoreElement\n [attr.id]=\"id\"\n [label]=\"label\"\n [value]=\"value\"\n (change)=\"onDateChange($event)\"\n [invalid]=\"isValid === false\"\n [min]=\"min\"\n [max]=\"max\"\n [showWeekNumbers]=\"showWeekNumbers\"\n [dateformat]=\"dateFormat\"\n [size]=\"size\"\n [hideLabel]=\"hideLabel\"\n [disabledWeekends]=\"disabledWeekends\"\n [disabledDates]=\"disabledDates\"\n >\n <span slot=\"message\">\n <ng-content select=\"[data-form-info]\"></ng-content>\n </span>\n </gds-datepicker>\n</div>\n", dependencies: [{ kind: "directive", type: i1.NggCoreElementDirective, selector: "[nggCoreElement]" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
72
72
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: NggDatepickerComponent, decorators: [{
|
|
73
73
|
type: Component,
|
|
74
74
|
args: [{ selector: 'ngg-datepicker', providers: [
|
|
@@ -77,11 +77,15 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImpor
|
|
|
77
77
|
useExisting: NggDatepickerComponent,
|
|
78
78
|
multi: true,
|
|
79
79
|
},
|
|
80
|
-
], changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"form-group\">\n <gds-datepicker\n *nggCoreElement\n [attr.id]=\"id\"\n [label]=\"label\"\n [value]=\"value\"\n (change)=\"onDateChange($event)\"\n [invalid]=\"isValid === false\"\n [min]=\"min\"\n [max]=\"max\"\n [showWeekNumbers]=\"showWeekNumbers\"\n [dateformat]=\"dateFormat\"\n [size]=\"size\"\n [hideLabel]=\"hideLabel\"\n >\n <span slot=\"message\">\n <ng-content select=\"[data-form-info]\"></ng-content>\n </span>\n </gds-datepicker>\n</div>\n" }]
|
|
80
|
+
], changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"form-group\">\n <gds-datepicker\n *nggCoreElement\n [attr.id]=\"id\"\n [label]=\"label\"\n [value]=\"value\"\n (change)=\"onDateChange($event)\"\n [invalid]=\"isValid === false\"\n [min]=\"min\"\n [max]=\"max\"\n [showWeekNumbers]=\"showWeekNumbers\"\n [dateformat]=\"dateFormat\"\n [size]=\"size\"\n [hideLabel]=\"hideLabel\"\n [disabledWeekends]=\"disabledWeekends\"\n [disabledDates]=\"disabledDates\"\n >\n <span slot=\"message\">\n <ng-content select=\"[data-form-info]\"></ng-content>\n </span>\n </gds-datepicker>\n</div>\n" }]
|
|
81
81
|
}], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }]; }, propDecorators: { size: [{
|
|
82
82
|
type: Input
|
|
83
83
|
}], hideLabel: [{
|
|
84
84
|
type: Input
|
|
85
|
+
}], disabledWeekends: [{
|
|
86
|
+
type: Input
|
|
87
|
+
}], disabledDates: [{
|
|
88
|
+
type: Input
|
|
85
89
|
}], options: [{
|
|
86
90
|
type: Input
|
|
87
91
|
}], value: [{
|
|
@@ -127,4 +131,4 @@ export function dateValidator(dates) {
|
|
|
127
131
|
return null;
|
|
128
132
|
};
|
|
129
133
|
}
|
|
130
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"datepicker.component.js","sourceRoot":"","sources":["../../../../../../libs/angular/src/lib/datepicker/datepicker.component.ts","../../../../../../libs/angular/src/lib/datepicker/datepicker.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  Component,\n  Input,\n  Output,\n  EventEmitter,\n  ChangeDetectorRef,\n} from '@angular/core'\nimport {\n  AbstractControl,\n  ControlValueAccessor,\n  NG_VALUE_ACCESSOR,\n  ValidationErrors,\n  ValidatorFn,\n} from '@angular/forms'\nimport { randomId } from '@sebgroup/extract'\nimport { endOfDay, startOfDay } from 'date-fns'\n\nimport { GdsDatepicker } from '@sebgroup/green-core'\nimport { registerTransitionalStyles } from '@sebgroup/green-core/transitional-styles'\n\nexport interface Attributes {\n  id?: string\n  role?: string\n  style?: CSSStyleDeclaration\n  tabIndex?: number\n}\n\nexport interface ElementProps {\n  attributes: Attributes\n  classes: string[]\n}\n\nexport interface DatepickerOptions {\n  label?: string\n  locale?: string\n  currentDate?: Date | string\n  selectedDate?: Date | string\n  closeOnSelect?: boolean\n  useCurrentTime?: boolean\n  weekName?: { abbr: string; displayText: string }\n  showWeeks?: boolean\n  minDate?: Date\n  maxDate?: Date\n  dateFormat?: string\n  onChange?: (selectedDate: Date) => void\n}\n\n@Component({\n  selector: 'ngg-datepicker',\n  templateUrl: 'datepicker.component.html',\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: NggDatepickerComponent,\n      multi: true,\n    },\n  ],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class NggDatepickerComponent\n  implements ControlValueAccessor, AfterViewInit\n{\n  @Input() size?: 'small' | 'medium'\n  @Input() hideLabel?: boolean\n\n  @Input()\n  get options(): DatepickerOptions {\n    return <DatepickerOptions>this._options\n  }\n  set options(value: DatepickerOptions) {\n    this._options = value\n  }\n\n  get showWeekNumbers(): boolean {\n    return this.options?.showWeeks ?? false\n  }\n\n  get dateFormat(): string {\n    return this.options?.dateFormat ?? 'y-m-d'\n  }\n\n  @Input()\n  get value(): string | Date | undefined {\n    return this._value\n  }\n  set value(newValue: string | Date | undefined) {\n    if (newValue !== this._value) {\n      this._value = newValue || undefined\n    }\n  }\n\n  @Input() id?: string = randomId()\n  @Input() label?: string\n  @Input() isValid: boolean | null = null\n  @Output() readonly valueChange: EventEmitter<any> = new EventEmitter<any>()\n\n  onChangeFn?: (value: any) => void\n  onTouchedFn?: any\n\n  _value: string | Date | undefined\n  private _options?: DatepickerOptions\n\n  get min(): Date | undefined {\n    const minDate = this.options?.minDate\n    return minDate ? minDate : new Date(new Date().getFullYear() - 10, 0, 1)\n  }\n\n  get max(): Date | undefined {\n    const maxDate = this.options?.maxDate\n    return maxDate ? maxDate : new Date(new Date().getFullYear() + 10, 0, 1)\n  }\n\n  constructor(private _cdr: ChangeDetectorRef) {\n    registerTransitionalStyles()\n  }\n\n  writeValue(value: any): void {\n    this.value = value\n    this._cdr.detectChanges()\n  }\n\n  registerOnChange(fn: any): void {\n    this.onChangeFn = fn\n  }\n\n  registerOnTouched(fn: any): void {\n    this.onTouchedFn = fn\n  }\n\n  onDateChange(evt: Event) {\n    const e = evt as CustomEvent\n\n    this.value = e.detail.value\n\n    this.valueChange.emit(e.detail.value)\n    this.onChangeFn && this.onChangeFn(e.detail.value)\n  }\n\n  ngAfterViewInit(): void {\n    this._cdr.detectChanges()\n  }\n}\n\nexport function dateValidator(dates?: { min?: Date; max?: Date }): ValidatorFn {\n  return (control: AbstractControl): ValidationErrors | null => {\n    const value = control.value\n    if (!value) {\n      return null\n    }\n    const newDate = new Date(value)\n    const isValidDate = !isNaN(newDate.getTime())\n    if (!isValidDate) {\n      return { validDate: true }\n    }\n\n    const validMinDate = dates?.min ? newDate >= startOfDay(dates.min) : true\n    const validMaxDate = dates?.max ? newDate <= endOfDay(dates.max) : true\n\n    if (!validMinDate && dates?.min) {\n      return {\n        validDate: {\n          minDate: startOfDay(dates.min),\n          actualDate: newDate,\n        },\n      }\n    }\n    if (!validMaxDate && dates?.max) {\n      return {\n        validDate: {\n          maxDate: endOfDay(dates.max),\n          actualDate: newDate,\n        },\n      }\n    }\n\n    return null\n  }\n}\n","<div class=\"form-group\">\n  <gds-datepicker\n    *nggCoreElement\n    [attr.id]=\"id\"\n    [label]=\"label\"\n    [value]=\"value\"\n    (change)=\"onDateChange($event)\"\n    [invalid]=\"isValid === false\"\n    [min]=\"min\"\n    [max]=\"max\"\n    [showWeekNumbers]=\"showWeekNumbers\"\n    [dateformat]=\"dateFormat\"\n    [size]=\"size\"\n    [hideLabel]=\"hideLabel\"\n  >\n    <span slot=\"message\">\n      <ng-content select=\"[data-form-info]\"></ng-content>\n    </span>\n  </gds-datepicker>\n</div>\n"]}
|
|
134
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"datepicker.component.js","sourceRoot":"","sources":["../../../../../../libs/angular/src/lib/datepicker/datepicker.component.ts","../../../../../../libs/angular/src/lib/datepicker/datepicker.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  Component,\n  Input,\n  Output,\n  EventEmitter,\n  ChangeDetectorRef,\n} from '@angular/core'\nimport {\n  AbstractControl,\n  ControlValueAccessor,\n  NG_VALUE_ACCESSOR,\n  ValidationErrors,\n  ValidatorFn,\n} from '@angular/forms'\nimport { randomId } from '@sebgroup/extract'\nimport { endOfDay, startOfDay } from 'date-fns'\n\nimport { GdsDatepicker } from '@sebgroup/green-core'\nimport { registerTransitionalStyles } from '@sebgroup/green-core/transitional-styles'\n\nexport interface Attributes {\n  id?: string\n  role?: string\n  style?: CSSStyleDeclaration\n  tabIndex?: number\n}\n\nexport interface ElementProps {\n  attributes: Attributes\n  classes: string[]\n}\n\nexport interface DatepickerOptions {\n  label?: string\n  locale?: string\n  currentDate?: Date | string\n  selectedDate?: Date | string\n  closeOnSelect?: boolean\n  useCurrentTime?: boolean\n  weekName?: { abbr: string; displayText: string }\n  showWeeks?: boolean\n  minDate?: Date\n  maxDate?: Date\n  dateFormat?: string\n  onChange?: (selectedDate: Date) => void\n}\n\n@Component({\n  selector: 'ngg-datepicker',\n  templateUrl: 'datepicker.component.html',\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: NggDatepickerComponent,\n      multi: true,\n    },\n  ],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class NggDatepickerComponent\n  implements ControlValueAccessor, AfterViewInit\n{\n  @Input() size?: 'small' | 'medium'\n  @Input() hideLabel?: boolean\n  @Input() disabledWeekends?: boolean\n  @Input() disabledDates?: Date[]\n\n  @Input()\n  get options(): DatepickerOptions {\n    return <DatepickerOptions>this._options\n  }\n  set options(value: DatepickerOptions) {\n    this._options = value\n  }\n\n  get showWeekNumbers(): boolean {\n    return this.options?.showWeeks ?? false\n  }\n\n  get dateFormat(): string {\n    return this.options?.dateFormat ?? 'y-m-d'\n  }\n\n  @Input()\n  get value(): string | Date | undefined {\n    return this._value\n  }\n  set value(newValue: string | Date | undefined) {\n    if (newValue !== this._value) {\n      this._value = newValue || undefined\n    }\n  }\n\n  @Input() id?: string = randomId()\n  @Input() label?: string\n  @Input() isValid: boolean | null = null\n  @Output() readonly valueChange: EventEmitter<any> = new EventEmitter<any>()\n\n  onChangeFn?: (value: any) => void\n  onTouchedFn?: any\n\n  _value: string | Date | undefined\n  private _options?: DatepickerOptions\n\n  get min(): Date | undefined {\n    const minDate = this.options?.minDate\n    return minDate ? minDate : new Date(new Date().getFullYear() - 10, 0, 1)\n  }\n\n  get max(): Date | undefined {\n    const maxDate = this.options?.maxDate\n    return maxDate ? maxDate : new Date(new Date().getFullYear() + 10, 0, 1)\n  }\n\n  constructor(private _cdr: ChangeDetectorRef) {\n    registerTransitionalStyles()\n  }\n\n  writeValue(value: any): void {\n    this.value = value\n    this._cdr.detectChanges()\n  }\n\n  registerOnChange(fn: any): void {\n    this.onChangeFn = fn\n  }\n\n  registerOnTouched(fn: any): void {\n    this.onTouchedFn = fn\n  }\n\n  onDateChange(evt: Event) {\n    const e = evt as CustomEvent\n\n    this.value = e.detail.value\n\n    this.valueChange.emit(e.detail.value)\n    this.onChangeFn && this.onChangeFn(e.detail.value)\n  }\n\n  ngAfterViewInit(): void {\n    this._cdr.detectChanges()\n  }\n}\n\nexport function dateValidator(dates?: { min?: Date; max?: Date }): ValidatorFn {\n  return (control: AbstractControl): ValidationErrors | null => {\n    const value = control.value\n    if (!value) {\n      return null\n    }\n    const newDate = new Date(value)\n    const isValidDate = !isNaN(newDate.getTime())\n    if (!isValidDate) {\n      return { validDate: true }\n    }\n\n    const validMinDate = dates?.min ? newDate >= startOfDay(dates.min) : true\n    const validMaxDate = dates?.max ? newDate <= endOfDay(dates.max) : true\n\n    if (!validMinDate && dates?.min) {\n      return {\n        validDate: {\n          minDate: startOfDay(dates.min),\n          actualDate: newDate,\n        },\n      }\n    }\n    if (!validMaxDate && dates?.max) {\n      return {\n        validDate: {\n          maxDate: endOfDay(dates.max),\n          actualDate: newDate,\n        },\n      }\n    }\n\n    return null\n  }\n}\n","<div class=\"form-group\">\n  <gds-datepicker\n    *nggCoreElement\n    [attr.id]=\"id\"\n    [label]=\"label\"\n    [value]=\"value\"\n    (change)=\"onDateChange($event)\"\n    [invalid]=\"isValid === false\"\n    [min]=\"min\"\n    [max]=\"max\"\n    [showWeekNumbers]=\"showWeekNumbers\"\n    [dateformat]=\"dateFormat\"\n    [size]=\"size\"\n    [hideLabel]=\"hideLabel\"\n    [disabledWeekends]=\"disabledWeekends\"\n    [disabledDates]=\"disabledDates\"\n  >\n    <span slot=\"message\">\n      <ng-content select=\"[data-form-info]\"></ng-content>\n    </span>\n  </gds-datepicker>\n</div>\n"]}
|