@ng-atomic/components 17.0.4 → 17.2.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/esm2022/atoms/icon/icon.atom.mjs +2 -2
- package/esm2022/frames/app/app.frame.mjs +2 -2
- package/esm2022/frames/auto-layout/auto-layout.frame.mjs +2 -2
- package/esm2022/frames/columns/columns.frame.mjs +2 -2
- package/esm2022/frames/divider/divider.frame.mjs +2 -2
- package/esm2022/frames/drawer/drawer.frame.mjs +2 -2
- package/esm2022/frames/fab/fab.frame.mjs +2 -2
- package/esm2022/frames/line-up/line-up.frame.mjs +2 -2
- package/esm2022/frames/loading/loading.frame.mjs +2 -2
- package/esm2022/frames/overlay/overlay.frame.mjs +2 -2
- package/esm2022/frames/router-outlet/router-outlet.frame.mjs +3 -3
- package/esm2022/frames/scroll/scroll.frame.mjs +2 -2
- package/esm2022/frames/scroll-v2/scroll.frame.mjs +2 -2
- package/esm2022/frames/side-nav/side-nav.frame.mjs +3 -3
- package/esm2022/frames/smart-menu/smart-menu.frame.mjs +2 -2
- package/esm2022/frames/vertical-hide/vertical-hide.frame.mjs +2 -2
- package/esm2022/molecules/checkbox-column/checkbox-column.molecule.mjs +15 -10
- package/esm2022/molecules/date-input-field/date-input-field.molecule.mjs +2 -2
- package/esm2022/molecules/date-range-input-field/date-range-input-field.molecule.mjs +48 -34
- package/esm2022/molecules/grid-item/grid-item.molecule.mjs +2 -2
- package/esm2022/molecules/loading-box/loading-box.molecule.mjs +2 -2
- package/esm2022/molecules/navigation-list-item/navigation-list-item.molecule.mjs +2 -2
- package/esm2022/molecules/select-input-field/select-input-field.molecule.mjs +2 -2
- package/esm2022/molecules/textarea-field/textarea-field.molecule.mjs +15 -14
- package/esm2022/molecules/tree-column/tree-column.molecule.mjs +4 -9
- package/esm2022/organisms/action-buttons-section/action-buttons-section.organism.mjs +2 -2
- package/esm2022/organisms/action-input-section/action-input-section.organism.mjs +2 -2
- package/esm2022/organisms/card-input-section/card-input-section.organism.mjs +2 -2
- package/esm2022/organisms/cvc-and-exp-input-section/cvc-and-exp-input-section.organism.mjs +2 -2
- package/esm2022/organisms/date-input-section/date-input-section.organism.mjs +2 -2
- package/esm2022/organisms/date-range-input-section/date-range-input-section.organism.mjs +3 -3
- package/esm2022/organisms/definition-list/definition-list.organism.mjs +2 -2
- package/esm2022/organisms/file-input-section/file-input-section.organism.mjs +2 -2
- package/esm2022/organisms/grid-cards-section/grid-cards-section.organism.mjs +2 -2
- package/esm2022/organisms/heading/heading.organism.mjs +2 -2
- package/esm2022/organisms/menu-footer/menu-footer.organism.mjs +2 -2
- package/esm2022/organisms/menu-header/menu-header.organism.mjs +2 -2
- package/esm2022/organisms/messages-section/messages-section.organism.mjs +2 -2
- package/esm2022/organisms/navigation-list/navigation-list.organism.mjs +2 -2
- package/esm2022/organisms/navigator/navigator.organism.mjs +2 -2
- package/esm2022/organisms/number-input-section/number-input-section.organism.mjs +2 -2
- package/esm2022/organisms/password-input-section/password-input-section.organism.mjs +2 -2
- package/esm2022/organisms/select-input-section/select-input-section.organism.mjs +2 -2
- package/esm2022/organisms/social-login-section/social-login-section.organism.mjs +2 -2
- package/esm2022/organisms/table/index.helpers.mjs +19 -2
- package/esm2022/organisms/table/table.helpers.mjs +10 -0
- package/esm2022/organisms/table/table.organism.mjs +25 -84
- package/esm2022/organisms/text-input-section/text-input-section.organism.mjs +2 -2
- package/esm2022/organisms/textarea-section/textarea-section.organism.mjs +3 -5
- package/esm2022/organisms/thread-messages-section/thread-messages-section.organism.mjs +2 -2
- package/esm2022/pages/_index/index.page.mjs +2 -2
- package/esm2022/pages/form/form.page.mjs +11 -5
- package/esm2022/templates/_index/index.template.mjs +4 -4
- package/esm2022/templates/background/background.template.mjs +2 -2
- package/esm2022/templates/entrance/entrance.template.mjs +2 -2
- package/esm2022/templates/form/form.template.mjs +2 -2
- package/esm2022/templates/icon-button-menu/icon-button-menu.template.mjs +2 -2
- package/esm2022/templates/menu/menu.template.mjs +2 -2
- package/esm2022/templates/selection/selection.template.mjs +2 -2
- package/esm2022/templates/settings/settings.template.mjs +2 -2
- package/fesm2022/ng-atomic-components-atoms-icon.mjs +2 -2
- package/fesm2022/ng-atomic-components-frames-app.mjs +2 -2
- package/fesm2022/ng-atomic-components-frames-auto-layout.mjs +2 -2
- package/fesm2022/ng-atomic-components-frames-columns.mjs +2 -2
- package/fesm2022/ng-atomic-components-frames-divider.mjs +2 -2
- package/fesm2022/ng-atomic-components-frames-drawer.mjs +2 -2
- package/fesm2022/ng-atomic-components-frames-fab.mjs +2 -2
- package/fesm2022/ng-atomic-components-frames-line-up.mjs +2 -2
- package/fesm2022/ng-atomic-components-frames-loading.mjs +2 -2
- package/fesm2022/ng-atomic-components-frames-overlay.mjs +2 -2
- package/fesm2022/ng-atomic-components-frames-router-outlet.mjs +2 -2
- package/fesm2022/ng-atomic-components-frames-router-outlet.mjs.map +1 -1
- package/fesm2022/ng-atomic-components-frames-scroll-v2.mjs +2 -2
- package/fesm2022/ng-atomic-components-frames-scroll.mjs +2 -2
- package/fesm2022/ng-atomic-components-frames-side-nav.mjs +2 -2
- package/fesm2022/ng-atomic-components-frames-side-nav.mjs.map +1 -1
- package/fesm2022/ng-atomic-components-frames-smart-menu.mjs +2 -2
- package/fesm2022/ng-atomic-components-frames-vertical-hide.mjs +2 -2
- package/fesm2022/ng-atomic-components-molecules-checkbox-column.mjs +14 -9
- package/fesm2022/ng-atomic-components-molecules-checkbox-column.mjs.map +1 -1
- package/fesm2022/ng-atomic-components-molecules-date-input-field.mjs +2 -2
- package/fesm2022/ng-atomic-components-molecules-date-range-input-field.mjs +48 -34
- package/fesm2022/ng-atomic-components-molecules-date-range-input-field.mjs.map +1 -1
- package/fesm2022/ng-atomic-components-molecules-grid-item.mjs +2 -2
- package/fesm2022/ng-atomic-components-molecules-loading-box.mjs +2 -2
- package/fesm2022/ng-atomic-components-molecules-navigation-list-item.mjs +2 -2
- package/fesm2022/ng-atomic-components-molecules-select-input-field.mjs +2 -2
- package/fesm2022/ng-atomic-components-molecules-textarea-field.mjs +14 -13
- package/fesm2022/ng-atomic-components-molecules-textarea-field.mjs.map +1 -1
- package/fesm2022/ng-atomic-components-molecules-tree-column.mjs +3 -8
- package/fesm2022/ng-atomic-components-molecules-tree-column.mjs.map +1 -1
- package/fesm2022/ng-atomic-components-organisms-action-buttons-section.mjs +2 -2
- package/fesm2022/ng-atomic-components-organisms-action-input-section.mjs +2 -2
- package/fesm2022/ng-atomic-components-organisms-card-input-section.mjs +2 -2
- package/fesm2022/ng-atomic-components-organisms-cvc-and-exp-input-section.mjs +2 -2
- package/fesm2022/ng-atomic-components-organisms-date-input-section.mjs +2 -2
- package/fesm2022/ng-atomic-components-organisms-date-range-input-section.mjs +2 -2
- package/fesm2022/ng-atomic-components-organisms-date-range-input-section.mjs.map +1 -1
- package/fesm2022/ng-atomic-components-organisms-definition-list.mjs +2 -2
- package/fesm2022/ng-atomic-components-organisms-file-input-section.mjs +2 -2
- package/fesm2022/ng-atomic-components-organisms-grid-cards-section.mjs +2 -2
- package/fesm2022/ng-atomic-components-organisms-heading.mjs +2 -2
- package/fesm2022/ng-atomic-components-organisms-menu-footer.mjs +2 -2
- package/fesm2022/ng-atomic-components-organisms-menu-header.mjs +2 -2
- package/fesm2022/ng-atomic-components-organisms-messages-section.mjs +2 -2
- package/fesm2022/ng-atomic-components-organisms-navigation-list.mjs +2 -2
- package/fesm2022/ng-atomic-components-organisms-navigator.mjs +2 -2
- package/fesm2022/ng-atomic-components-organisms-number-input-section.mjs +2 -2
- package/fesm2022/ng-atomic-components-organisms-password-input-section.mjs +2 -2
- package/fesm2022/ng-atomic-components-organisms-select-input-section.mjs +2 -2
- package/fesm2022/ng-atomic-components-organisms-social-login-section.mjs +2 -2
- package/fesm2022/ng-atomic-components-organisms-table.mjs +52 -84
- package/fesm2022/ng-atomic-components-organisms-table.mjs.map +1 -1
- package/fesm2022/ng-atomic-components-organisms-text-input-section.mjs +2 -2
- package/fesm2022/ng-atomic-components-organisms-textarea-section.mjs +2 -4
- package/fesm2022/ng-atomic-components-organisms-textarea-section.mjs.map +1 -1
- package/fesm2022/ng-atomic-components-organisms-thread-messages-section.mjs +2 -2
- package/fesm2022/ng-atomic-components-pages-_index.mjs +2 -2
- package/fesm2022/ng-atomic-components-pages-form.mjs +10 -4
- package/fesm2022/ng-atomic-components-pages-form.mjs.map +1 -1
- package/fesm2022/ng-atomic-components-templates-_index.mjs +3 -3
- package/fesm2022/ng-atomic-components-templates-_index.mjs.map +1 -1
- package/fesm2022/ng-atomic-components-templates-background.mjs +2 -2
- package/fesm2022/ng-atomic-components-templates-entrance.mjs +2 -2
- package/fesm2022/ng-atomic-components-templates-form.mjs +2 -2
- package/fesm2022/ng-atomic-components-templates-icon-button-menu.mjs +2 -2
- package/fesm2022/ng-atomic-components-templates-menu.mjs +2 -2
- package/fesm2022/ng-atomic-components-templates-selection.mjs +2 -2
- package/fesm2022/ng-atomic-components-templates-settings.mjs +2 -2
- package/molecules/checkbox-column/checkbox-column.molecule.d.ts +2 -1
- package/molecules/date-range-input-field/date-range-input-field.molecule.d.ts +12 -7
- package/molecules/textarea-field/textarea-field.molecule.d.ts +0 -1
- package/organisms/table/index.helpers.d.ts +9 -2
- package/organisms/table/table.helpers.d.ts +3 -0
- package/organisms/table/table.organism.d.ts +5 -33
- package/package.json +3 -3
- package/pages/form/form.page.d.ts +5 -1
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { __decorate, __metadata } from "tslib";
|
|
2
|
-
import { ChangeDetectionStrategy, Component, Directive,
|
|
2
|
+
import { ChangeDetectionStrategy, Component, Directive, computed, effect, inject, input } from '@angular/core';
|
|
3
3
|
import { MatTableDataSource, MatTableModule } from '@angular/material/table';
|
|
4
4
|
import { MatCheckboxModule } from '@angular/material/checkbox';
|
|
5
5
|
import { MatMenuModule } from '@angular/material/menu';
|
|
@@ -12,88 +12,18 @@ import { SmartColumnMolecule } from '@ng-atomic/components/molecules/smart-colum
|
|
|
12
12
|
import { Effect, InjectableComponent, NgAtomicComponent, TokenizedType } from '@ng-atomic/core';
|
|
13
13
|
import { SelectionModel } from '@angular/cdk/collections';
|
|
14
14
|
import { TreeColumnMolecule } from '@ng-atomic/components/molecules/tree-column';
|
|
15
|
-
import { get } from 'lodash-es';
|
|
16
|
-
import { flattenExcludeDayjs } from '@nx-ddd/core/util/walk-obj';
|
|
17
15
|
import { IndexTemplateFormBuilder } from './index.helpers';
|
|
18
16
|
import { computedRawValue } from '@ng-atomic/common/utils';
|
|
19
17
|
import { NgClass } from '@angular/common';
|
|
18
|
+
import { ColumnsPipe } from '@ng-atomic/common/pipes/columns';
|
|
19
|
+
import { ResolveColumnsPipe } from '@ng-atomic/common/pipes/resolve-columns';
|
|
20
|
+
import { MapPipe } from '@ng-atomic/common/pipes/map';
|
|
21
|
+
import { AutoColumnsPipe } from '@ng-atomic/common/pipes/auto-columns';
|
|
22
|
+
import { SortPipe } from '@ng-atomic/common/pipes/sort';
|
|
23
|
+
import { buildTreeFlatDataSource } from './table.helpers';
|
|
24
|
+
import { FlatTreeControl } from '@angular/cdk/tree';
|
|
20
25
|
import * as i0 from "@angular/core";
|
|
21
26
|
import * as i1 from "@angular/material/table";
|
|
22
|
-
export class ResolveColumnsPipe {
|
|
23
|
-
transform(columns) {
|
|
24
|
-
const data = columns.map((column, i) => {
|
|
25
|
-
if (typeof column === 'string') {
|
|
26
|
-
if (column === '__checkbox')
|
|
27
|
-
return { type: 'checkbox', name: `__checkbox_${i}` };
|
|
28
|
-
if (column === '__actions')
|
|
29
|
-
return { type: 'actions', name: `__actions_${i}` };
|
|
30
|
-
return { type: 'key', name: column };
|
|
31
|
-
}
|
|
32
|
-
return { type: 'actions', name: `__actions_${i}`, payload: column };
|
|
33
|
-
});
|
|
34
|
-
return data;
|
|
35
|
-
}
|
|
36
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.2", ngImport: i0, type: ResolveColumnsPipe, deps: [], target: i0.ɵɵFactoryTarget.Pipe }); }
|
|
37
|
-
static { this.ɵpipe = i0.ɵɵngDeclarePipe({ minVersion: "14.0.0", version: "17.2.2", ngImport: i0, type: ResolveColumnsPipe, isStandalone: true, name: "resolveColumns" }); }
|
|
38
|
-
}
|
|
39
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.2", ngImport: i0, type: ResolveColumnsPipe, decorators: [{
|
|
40
|
-
type: Pipe,
|
|
41
|
-
args: [{ name: 'resolveColumns', standalone: true, pure: true }]
|
|
42
|
-
}] });
|
|
43
|
-
export class MapPipe {
|
|
44
|
-
transform(itemOrItems, path) {
|
|
45
|
-
if (Array.isArray(itemOrItems))
|
|
46
|
-
return itemOrItems.map(item => get(item, path));
|
|
47
|
-
return get(itemOrItems, path);
|
|
48
|
-
}
|
|
49
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.2", ngImport: i0, type: MapPipe, deps: [], target: i0.ɵɵFactoryTarget.Pipe }); }
|
|
50
|
-
static { this.ɵpipe = i0.ɵɵngDeclarePipe({ minVersion: "14.0.0", version: "17.2.2", ngImport: i0, type: MapPipe, isStandalone: true, name: "map" }); }
|
|
51
|
-
}
|
|
52
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.2", ngImport: i0, type: MapPipe, decorators: [{
|
|
53
|
-
type: Pipe,
|
|
54
|
-
args: [{ name: 'map', standalone: true, pure: true }]
|
|
55
|
-
}] });
|
|
56
|
-
export class AutoColumnsPipe {
|
|
57
|
-
transform(items) {
|
|
58
|
-
const keys = new Set();
|
|
59
|
-
items.slice(0, 1).forEach(item => {
|
|
60
|
-
const obj = flattenExcludeDayjs(item);
|
|
61
|
-
Object.keys(obj).forEach(key => keys.add(key));
|
|
62
|
-
});
|
|
63
|
-
return [...keys, '__actions'];
|
|
64
|
-
}
|
|
65
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.2", ngImport: i0, type: AutoColumnsPipe, deps: [], target: i0.ɵɵFactoryTarget.Pipe }); }
|
|
66
|
-
static { this.ɵpipe = i0.ɵɵngDeclarePipe({ minVersion: "14.0.0", version: "17.2.2", ngImport: i0, type: AutoColumnsPipe, isStandalone: true, name: "autoColumns" }); }
|
|
67
|
-
}
|
|
68
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.2", ngImport: i0, type: AutoColumnsPipe, decorators: [{
|
|
69
|
-
type: Pipe,
|
|
70
|
-
args: [{ name: 'autoColumns', standalone: true, pure: true }]
|
|
71
|
-
}] });
|
|
72
|
-
export class SortPipe {
|
|
73
|
-
transform(column, sort) {
|
|
74
|
-
return sort.key === column.name ? sort.order : 'none';
|
|
75
|
-
}
|
|
76
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.2", ngImport: i0, type: SortPipe, deps: [], target: i0.ɵɵFactoryTarget.Pipe }); }
|
|
77
|
-
static { this.ɵpipe = i0.ɵɵngDeclarePipe({ minVersion: "14.0.0", version: "17.2.2", ngImport: i0, type: SortPipe, isStandalone: true, name: "sort" }); }
|
|
78
|
-
}
|
|
79
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.2", ngImport: i0, type: SortPipe, decorators: [{
|
|
80
|
-
type: Pipe,
|
|
81
|
-
args: [{ name: 'sort', standalone: true, pure: true }]
|
|
82
|
-
}] });
|
|
83
|
-
export class ColumnsPipe {
|
|
84
|
-
transform(columns) {
|
|
85
|
-
return columns.filter(item => item.visible).map((column, i) => ({
|
|
86
|
-
...column,
|
|
87
|
-
name: ['checkbox', 'actions'].includes(column.type) ? `${column.name}_${i}` : column.name,
|
|
88
|
-
}));
|
|
89
|
-
}
|
|
90
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.2", ngImport: i0, type: ColumnsPipe, deps: [], target: i0.ɵɵFactoryTarget.Pipe }); }
|
|
91
|
-
static { this.ɵpipe = i0.ɵɵngDeclarePipe({ minVersion: "14.0.0", version: "17.2.2", ngImport: i0, type: ColumnsPipe, isStandalone: true, name: "columns" }); }
|
|
92
|
-
}
|
|
93
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.2", ngImport: i0, type: ColumnsPipe, decorators: [{
|
|
94
|
-
type: Pipe,
|
|
95
|
-
args: [{ name: 'columns', standalone: true, pure: true }]
|
|
96
|
-
}] });
|
|
97
27
|
let TableOrganismStore = class TableOrganismStore extends InjectableComponent {
|
|
98
28
|
constructor() {
|
|
99
29
|
super();
|
|
@@ -102,9 +32,16 @@ let TableOrganismStore = class TableOrganismStore extends InjectableComponent {
|
|
|
102
32
|
this.itemActions = input([]);
|
|
103
33
|
this.selection = input(new SelectionModel(true, []));
|
|
104
34
|
this.highlight = input(new SelectionModel(true, []));
|
|
105
|
-
this.childrenKey = input(
|
|
35
|
+
this.childrenKey = input(null);
|
|
106
36
|
this.items = input([]);
|
|
107
|
-
this.
|
|
37
|
+
this.treeControl = input(new FlatTreeControl(n => n.level, n => n.isExpandable));
|
|
38
|
+
this.dataSource = computed(() => {
|
|
39
|
+
if (this.childrenKey()) {
|
|
40
|
+
return buildTreeFlatDataSource(this.treeControl(), this.items(), this.childrenKey());
|
|
41
|
+
}
|
|
42
|
+
return new MatTableDataSource(this.items());
|
|
43
|
+
});
|
|
44
|
+
this.isHidden = computed(() => (item) => this.treeControl().getLevel(item) === 0);
|
|
108
45
|
this.formValue = computedRawValue(() => this.form());
|
|
109
46
|
this.sort = computed(() => this.formValue()?.sort ?? { key: '', order: 'asc' }, {
|
|
110
47
|
equal: (a, b) => JSON.stringify(a) === JSON.stringify(b),
|
|
@@ -143,7 +80,7 @@ let TableOrganismStore = class TableOrganismStore extends InjectableComponent {
|
|
|
143
80
|
});
|
|
144
81
|
}
|
|
145
82
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.2", ngImport: i0, type: TableOrganismStore, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
146
|
-
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "17.1.0", version: "17.2.2", type: TableOrganismStore, isStandalone: true, selector: "organisms-table", inputs: { form: { classPropertyName: "form", publicName: "form", isSignal: true, isRequired: false, transformFunction: null }, itemActions: { classPropertyName: "itemActions", publicName: "itemActions", isSignal: true, isRequired: false, transformFunction: null }, selection: { classPropertyName: "selection", publicName: "selection", isSignal: true, isRequired: false, transformFunction: null }, highlight: { classPropertyName: "highlight", publicName: "highlight", isSignal: true, isRequired: false, transformFunction: null }, childrenKey: { classPropertyName: "childrenKey", publicName: "childrenKey", isSignal: true, isRequired: false, transformFunction: null }, items: { classPropertyName: "items", publicName: "items", isSignal: true, isRequired: false, transformFunction: null } }, providers: [DomainPipe], usesInheritance: true, ngImport: i0 }); }
|
|
83
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "17.1.0", version: "17.2.2", type: TableOrganismStore, isStandalone: true, selector: "organisms-table", inputs: { form: { classPropertyName: "form", publicName: "form", isSignal: true, isRequired: false, transformFunction: null }, itemActions: { classPropertyName: "itemActions", publicName: "itemActions", isSignal: true, isRequired: false, transformFunction: null }, selection: { classPropertyName: "selection", publicName: "selection", isSignal: true, isRequired: false, transformFunction: null }, highlight: { classPropertyName: "highlight", publicName: "highlight", isSignal: true, isRequired: false, transformFunction: null }, childrenKey: { classPropertyName: "childrenKey", publicName: "childrenKey", isSignal: true, isRequired: false, transformFunction: null }, items: { classPropertyName: "items", publicName: "items", isSignal: true, isRequired: false, transformFunction: null }, treeControl: { classPropertyName: "treeControl", publicName: "treeControl", isSignal: true, isRequired: false, transformFunction: null } }, providers: [DomainPipe], usesInheritance: true, ngImport: i0 }); }
|
|
147
84
|
};
|
|
148
85
|
TableOrganismStore = __decorate([
|
|
149
86
|
TokenizedType(),
|
|
@@ -191,6 +128,7 @@ export class TableOrganism extends NgAtomicComponent {
|
|
|
191
128
|
<molecules-checkbox-column
|
|
192
129
|
[name]="column.name"
|
|
193
130
|
[selection]="store.selection()"
|
|
131
|
+
[isHidden]="store.isHidden()"
|
|
194
132
|
(action)="dispatch($event)"
|
|
195
133
|
/>
|
|
196
134
|
}
|
|
@@ -205,6 +143,7 @@ export class TableOrganism extends NgAtomicComponent {
|
|
|
205
143
|
<molecules-tree-column
|
|
206
144
|
[name]="column.name"
|
|
207
145
|
[headerText]="column.headerText"
|
|
146
|
+
[treeControl]="store.treeControl()"
|
|
208
147
|
[sort]="column.sort"
|
|
209
148
|
(headerClick)="onHeaderClick(column.name)"
|
|
210
149
|
/>
|
|
@@ -227,7 +166,7 @@ export class TableOrganism extends NgAtomicComponent {
|
|
|
227
166
|
></tr>
|
|
228
167
|
<div class="mat-row" *matNoDataRow>No Data</div>
|
|
229
168
|
</table>
|
|
230
|
-
`, isInline: true, styles: [":host{--width: 100%;--width-SCOPED-IN-smart-table-
|
|
169
|
+
`, isInline: true, styles: [":host{--width: 100%;--width-SCOPED-IN-smart-table-xILg: var(--width);--cell: 8px;--cell-SCOPED-IN-smart-table-xILg: var(--cell);--column-vertical-padding: 4px;--column-vertical-padding-SCOPED-IN-smart-table-xILg: var(--column-vertical-padding)}:host{position:relative;display:block;width:100%;height:100%;overflow:scroll}:host::-webkit-scrollbar{display:none}:host table{width:100%;max-height:100%}:host table .nowrap{width:160px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}:host table ::ng-deep th,:host table ::ng-deep td{padding:0 var(--column-vertical-padding-SCOPED-IN-smart-table-xILg)}:host table ::ng-deep tr.highlight{background-color:#f0f0f0;transition:background-color .5s}:host .no-data-message{display:flex;justify-content:flex-start;align-items:center;width:calc(var(--width-SCOPED-IN-smart-table-xILg) - var(--cell-SCOPED-IN-smart-table-xILg) * 4);height:3em;padding-left:calc(var(--cell-SCOPED-IN-smart-table-xILg) * 2);padding-right:calc(var(--cell-SCOPED-IN-smart-table-xILg) * 2)}\n"], dependencies: [{ kind: "directive", type: NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "ngmodule", type: MatTableModule }, { kind: "component", type: i1.MatTable, selector: "mat-table, table[mat-table]", exportAs: ["matTable"] }, { kind: "directive", type: i1.MatRecycleRows, selector: "mat-table[recycleRows], table[mat-table][recycleRows]" }, { kind: "directive", type: i1.MatHeaderRowDef, selector: "[matHeaderRowDef]", inputs: ["matHeaderRowDef", "matHeaderRowDefSticky"] }, { kind: "directive", type: i1.MatRowDef, selector: "[matRowDef]", inputs: ["matRowDefColumns", "matRowDefWhen"] }, { kind: "component", type: i1.MatHeaderRow, selector: "mat-header-row, tr[mat-header-row]", exportAs: ["matHeaderRow"] }, { kind: "component", type: i1.MatRow, selector: "mat-row, tr[mat-row]", exportAs: ["matRow"] }, { kind: "directive", type: i1.MatNoDataRow, selector: "ng-template[matNoDataRow]" }, { kind: "ngmodule", type: MatCheckboxModule }, { kind: "ngmodule", type: MatMenuModule }, { kind: "ngmodule", type: MatButtonModule }, { kind: "ngmodule", type: MatIconModule }, { kind: "component", type: ActionsColumnMolecule, selector: "molecules-actions-column" }, { kind: "component", type: CheckboxColumnMolecule, selector: "molecules-checkbox-column", inputs: ["name", "selection", "isHidden"] }, { kind: "component", type: SmartColumnMolecule, selector: "molecules-smart-column", inputs: ["headerText", "name"], outputs: ["headerClick"] }, { kind: "component", type: TreeColumnMolecule, selector: "molecules-tree-column", outputs: ["headerClick"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
231
170
|
}
|
|
232
171
|
__decorate([
|
|
233
172
|
Effect(CheckboxColumnMolecule.ActionId.CHECKBOX_CLICK),
|
|
@@ -269,6 +208,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.2", ngImpor
|
|
|
269
208
|
<molecules-checkbox-column
|
|
270
209
|
[name]="column.name"
|
|
271
210
|
[selection]="store.selection()"
|
|
211
|
+
[isHidden]="store.isHidden()"
|
|
272
212
|
(action)="dispatch($event)"
|
|
273
213
|
/>
|
|
274
214
|
}
|
|
@@ -283,6 +223,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.2", ngImpor
|
|
|
283
223
|
<molecules-tree-column
|
|
284
224
|
[name]="column.name"
|
|
285
225
|
[headerText]="column.headerText"
|
|
226
|
+
[treeControl]="store.treeControl()"
|
|
286
227
|
[sort]="column.sort"
|
|
287
228
|
(headerClick)="onHeaderClick(column.name)"
|
|
288
229
|
/>
|
|
@@ -310,6 +251,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.2", ngImpor
|
|
|
310
251
|
directive: TableOrganismStore,
|
|
311
252
|
inputs: ['form', 'itemActions', 'selection', 'items', 'childrenKey', 'highlight'],
|
|
312
253
|
},
|
|
313
|
-
], host: { class: 'organism' }, styles: [":host{--width: 100%;--width-SCOPED-IN-smart-table-
|
|
254
|
+
], host: { class: 'organism' }, styles: [":host{--width: 100%;--width-SCOPED-IN-smart-table-xILg: var(--width);--cell: 8px;--cell-SCOPED-IN-smart-table-xILg: var(--cell);--column-vertical-padding: 4px;--column-vertical-padding-SCOPED-IN-smart-table-xILg: var(--column-vertical-padding)}:host{position:relative;display:block;width:100%;height:100%;overflow:scroll}:host::-webkit-scrollbar{display:none}:host table{width:100%;max-height:100%}:host table .nowrap{width:160px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}:host table ::ng-deep th,:host table ::ng-deep td{padding:0 var(--column-vertical-padding-SCOPED-IN-smart-table-xILg)}:host table ::ng-deep tr.highlight{background-color:#f0f0f0;transition:background-color .5s}:host .no-data-message{display:flex;justify-content:flex-start;align-items:center;width:calc(var(--width-SCOPED-IN-smart-table-xILg) - var(--cell-SCOPED-IN-smart-table-xILg) * 4);height:3em;padding-left:calc(var(--cell-SCOPED-IN-smart-table-xILg) * 2);padding-right:calc(var(--cell-SCOPED-IN-smart-table-xILg) * 2)}\n"] }]
|
|
314
255
|
}], propDecorators: { onCheckboxClick: [] } });
|
|
315
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table.organism.js","sourceRoot":"","sources":["../../../../../../../packages/@ng-atomic/components/src/lib/organisms/table/table.organism.ts"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, Directive, Pipe, PipeTransform, computed, effect, inject, input } from '@angular/core';\nimport { MatTableDataSource, MatTableModule } from '@angular/material/table';\nimport { MatCheckboxModule } from '@angular/material/checkbox';\nimport { MatMenuModule } from '@angular/material/menu';\nimport { MatButtonModule } from '@angular/material/button';\nimport { MatIconModule } from '@angular/material/icon';\nimport { DomainPipe } from '@ng-atomic/common/pipes/domain';\nimport { ActionsColumnMolecule } from '@ng-atomic/components/molecules/actions-column';\nimport { CheckboxColumnMolecule } from '@ng-atomic/components/molecules/checkbox-column';\nimport { SmartColumnMolecule } from '@ng-atomic/components/molecules/smart-column';\nimport { Actions, Effect, InjectableComponent, NgAtomicComponent, TokenizedType } from '@ng-atomic/core';\nimport { SelectionModel } from '@angular/cdk/collections';\nimport { TreeColumnMolecule } from '@ng-atomic/components/molecules/tree-column';\nimport { get } from 'lodash-es';\nimport { flattenExcludeDayjs } from '@nx-ddd/core/util/walk-obj';\nimport { IndexTemplateFormBuilder } from './index.helpers';\nimport { Column, Sort } from '@ng-atomic/common/models';\nimport { computedRawValue } from '@ng-atomic/common/utils';\nimport { NgClass } from '@angular/common';\n\n@Pipe({name: 'resolveColumns', standalone: true, pure: true})\nexport class ResolveColumnsPipe implements PipeTransform {\n  transform(columns: string[]): {type: 'key' | 'actions' | 'checkbox', name: string, payload?: any}[] {\n    const data = columns.map((column, i) => {\n      if (typeof column === 'string') {\n        if (column === '__checkbox') return {type: 'checkbox', name: `__checkbox_${i}`};\n        if (column === '__actions') return {type: 'actions', name: `__actions_${i}`};\n        return {type: 'key', name: column};\n      }\n      return {type: 'actions', name: `__actions_${i}`, payload: column};\n    });\n    return data as any;\n  }\n}\n\n@Pipe({name: 'map', standalone: true, pure: true})\nexport class MapPipe<T> implements PipeTransform {\n  transform(itemOrItems: T | T[], path: string): any | any[] {\n    if (Array.isArray(itemOrItems)) return itemOrItems.map(item => get(item, path));\n    return get(itemOrItems, path);\n  }\n}\n\n@Pipe({name: 'autoColumns', standalone: true, pure: true})\nexport class AutoColumnsPipe<T> implements PipeTransform {\n  transform(items: T[]): string[] {\n    const keys = new Set<string>();\n    items.slice(0, 1).forEach(item => {\n      const obj = flattenExcludeDayjs(item);\n      Object.keys(obj).forEach(key => keys.add(key));\n    })\n    return [...keys, '__actions'];\n  }\n}\n\n@Pipe({name: 'sort', standalone: true, pure: true})\nexport class SortPipe implements PipeTransform {\n  transform<T>(column: Column, sort: Sort): 'asc' | 'desc' | 'none' {\n    return sort.key === column.name ? sort.order : 'none';\n  }\n}\n\n@Pipe({name: 'columns', standalone: true, pure: true})\nexport class ColumnsPipe implements PipeTransform {\n  transform<T>(columns: Column[]): Column[] {\n    return columns.filter(item => item.visible).map((column, i) => ({\n      ...column,\n      name: ['checkbox', 'actions'].includes(column.type) ? `${column.name}_${i}` : column.name,\n    }));\n  }\n}\n\n@TokenizedType()\n@Directive({\n  standalone: true,\n  selector: 'organisms-table',\n  providers: [DomainPipe],\n})\nexport class TableOrganismStore<T> extends InjectableComponent {\n  readonly domainPipe = inject(DomainPipe);\n  readonly form = input(inject(IndexTemplateFormBuilder).build());\n  readonly itemActions = input<Actions>([]);\n  readonly selection = input(new SelectionModel<string>(true, []));\n  readonly highlight = input(new SelectionModel<string>(true, [])); \n  readonly childrenKey = input('children');\n  readonly items = input<T[]>([]);\n  readonly dataSource = computed(() => new MatTableDataSource<T>(this.items()));\n\n  readonly formValue = computedRawValue(() => this.form());\n  readonly sort = computed(() => this.formValue()?.sort ?? {key: '', order: 'asc'}, {\n    equal: (a, b) => JSON.stringify(a) === JSON.stringify(b),\n  });\n  readonly columns = computed(() => {\n    return new ColumnsPipe().transform((this.formValue()?.columns ?? []) as Column[]).map(column => {\n      if (column.name.startsWith('__tree_')) {\n        return {\n          ...column,\n          type: 'tree',\n          sort: this.sort().key === column.name ? this.sort().order : 'none',\n        };\n      } else if (column.type === 'actions') {\n        return {\n          ...column,\n          actions: column.actions ?? this.itemActions(),\n          type: 'actions',\n          sort: this.sort().key === column.name ? this.sort().order : 'none',\n        }\n      } else {\n        return {\n          ...column,\n          headerText: this.domainPipe.transform(column?.name),\n          sort: this.sort().key === column.name ? this.sort().order : 'none',\n        };\n      }\n    });\n  }, { equal: (a, b) => JSON.stringify(a) === JSON.stringify(b) });\n  readonly columnNames = computed(() => this.columns().map(column => column.name), {\n    equal: (a, b) => JSON.stringify(a) === JSON.stringify(b),\n  });\n\n  constructor() {\n    super();\n    effect(() => {\n      console.debug('highlight', this.highlight());\n    });\n  }\n}\n\nenum ActionId {\n  CHECKBOX_CLICK = '[@ng-atomic/components/organisms/checkbox-column] Checkbox Click',\n  HEADER_CLICK = '[@ng-atomic/components/organisms/table] Header Click',\n}\n\n@Component({\n  selector: 'organisms-table',\n  standalone: true,\n  imports: [\n    NgClass,\n    DomainPipe,\n    MatTableModule,\n    MatCheckboxModule,\n    MatMenuModule,\n    MatButtonModule,\n    MatIconModule,\n    ActionsColumnMolecule,\n    CheckboxColumnMolecule,\n    SmartColumnMolecule,\n    TreeColumnMolecule,\n    ResolveColumnsPipe,\n    MapPipe,\n    AutoColumnsPipe,\n    SortPipe,\n    ColumnsPipe,\n  ],\n  template: `\n  <table\n    mat-table\n    recycleRows\n    matSort\n    matSortDisableClear\n    matSortDirection=\"desc\"\n    [dataSource]=\"store.dataSource()\"\n  >\n    @for (column of store.columns(); track column.name; let i = $index) {\n      @switch (column.type) {\n        @case ('checkbox') {\n          <molecules-checkbox-column\n            [name]=\"column.name\"\n            [selection]=\"store.selection()\"\n            (action)=\"dispatch($event)\"\n          />\n        }\n        @case ('actions') {\n          <molecules-actions-column\n            [name]=\"column.name\"\n            [itemActions]=\"column.actions\"\n            (action)=\"dispatch($event)\"\n          />\n        }\n        @case('tree') {\n          <molecules-tree-column\n            [name]=\"column.name\"\n            [headerText]=\"column.headerText\"\n            [sort]=\"column.sort\"\n            (headerClick)=\"onHeaderClick(column.name)\"\n          />\n        }\n        @default {\n          <molecules-smart-column\n            [name]=\"column.name\"\n            [headerText]=\"column.headerText\"\n            [sort]=\"column.sort\"\n            (headerClick)=\"onHeaderClick(column.name)\"\n          />\n        }\n      }\n    }\n    <tr mat-header-row *matHeaderRowDef=\"store.columnNames(); sticky: true\"></tr>\n    <tr\n      mat-row\n      *matRowDef=\"let item; columns: store.columnNames();\"\n      [ngClass]=\"{ highlight: store.highlight().isSelected(item.id) }\"\n    ></tr>\n    <div class=\"mat-row\" *matNoDataRow>No Data</div>\n  </table>\n  `,\n  styleUrls: ['./table.organism.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  hostDirectives: [\n    {\n      directive: TableOrganismStore,\n      inputs: ['form', 'itemActions', 'selection', 'items', 'childrenKey', 'highlight'],\n    },\n  ],\n  host: {class: 'organism'},\n})\nexport class TableOrganism<Item extends object> extends NgAtomicComponent {\n  static readonly ActionId = ActionId;\n  protected store = inject(TableOrganismStore);\n\n  @Effect(CheckboxColumnMolecule.ActionId.CHECKBOX_CLICK)\n  protected onCheckboxClick(item: Item) {\n    this.dispatch({id: ActionId.CHECKBOX_CLICK, payload: item});\n  }\n\n  protected onHeaderClick(column: string) {\n    this.dispatch({id: ActionId.HEADER_CLICK, payload: column});\n  }\n}\n"]}
|
|
256
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table.organism.js","sourceRoot":"","sources":["../../../../../../../packages/@ng-atomic/components/src/lib/organisms/table/table.organism.ts"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, Directive, computed, effect, inject, input } from '@angular/core';\nimport { MatTableDataSource, MatTableModule } from '@angular/material/table';\nimport { MatCheckboxModule } from '@angular/material/checkbox';\nimport { MatMenuModule } from '@angular/material/menu';\nimport { MatButtonModule } from '@angular/material/button';\nimport { MatIconModule } from '@angular/material/icon';\nimport { DomainPipe } from '@ng-atomic/common/pipes/domain';\nimport { ActionsColumnMolecule } from '@ng-atomic/components/molecules/actions-column';\nimport { CheckboxColumnMolecule } from '@ng-atomic/components/molecules/checkbox-column';\nimport { SmartColumnMolecule } from '@ng-atomic/components/molecules/smart-column';\nimport { Actions, Effect, InjectableComponent, NgAtomicComponent, TokenizedType } from '@ng-atomic/core';\nimport { SelectionModel } from '@angular/cdk/collections';\nimport { TreeColumnMolecule } from '@ng-atomic/components/molecules/tree-column';\nimport { IndexTemplateFormBuilder } from './index.helpers';\nimport { Column } from '@ng-atomic/common/models';\nimport { computedRawValue } from '@ng-atomic/common/utils';\nimport { NgClass } from '@angular/common';\nimport { ColumnsPipe } from '@ng-atomic/common/pipes/columns';\nimport { ResolveColumnsPipe } from '@ng-atomic/common/pipes/resolve-columns';\nimport { MapPipe } from '@ng-atomic/common/pipes/map';\nimport { AutoColumnsPipe } from '@ng-atomic/common/pipes/auto-columns';\nimport { SortPipe } from '@ng-atomic/common/pipes/sort';\nimport { buildTreeFlatDataSource } from './table.helpers';\nimport { FlatTreeControl } from '@angular/cdk/tree';\n\n@TokenizedType()\n@Directive({\n  standalone: true,\n  selector: 'organisms-table',\n  providers: [DomainPipe],\n})\nexport class TableOrganismStore<T> extends InjectableComponent {\n  readonly domainPipe = inject(DomainPipe);\n  readonly form = input(inject(IndexTemplateFormBuilder).build());\n  readonly itemActions = input<Actions>([]);\n  readonly selection = input(new SelectionModel<string>(true, []));\n  readonly highlight = input(new SelectionModel<string>(true, [])); \n  readonly childrenKey = input<string>(null);\n  readonly items = input<T[]>([]);\n  readonly treeControl = input(new FlatTreeControl<any>(n => n.level, n => n.isExpandable));\n  readonly dataSource = computed(() => {\n    if (this.childrenKey()) {\n      return buildTreeFlatDataSource(this.treeControl(), this.items(), this.childrenKey());\n    }\n    return new MatTableDataSource<T>(this.items());\n  });\n  readonly isHidden = computed(() => (item: T) => this.treeControl().getLevel(item) === 0);\n\n  readonly formValue = computedRawValue(() => this.form());\n  readonly sort = computed(() => this.formValue()?.sort ?? {key: '', order: 'asc'}, {\n    equal: (a, b) => JSON.stringify(a) === JSON.stringify(b),\n  });\n  readonly columns = computed(() => {\n    return new ColumnsPipe().transform((this.formValue()?.columns ?? []) as Column[]).map(column => {\n      if (column.name.startsWith('__tree_')) {\n        return {\n          ...column,\n          type: 'tree',\n          sort: this.sort().key === column.name ? this.sort().order : 'none',\n        };\n      } else if (column.type === 'actions') {\n        return {\n          ...column,\n          actions: column.actions ?? this.itemActions(),\n          type: 'actions',\n          sort: this.sort().key === column.name ? this.sort().order : 'none',\n        }\n      } else {\n        return {\n          ...column,\n          headerText: this.domainPipe.transform(column?.name),\n          sort: this.sort().key === column.name ? this.sort().order : 'none',\n        };\n      }\n    });\n  }, { equal: (a, b) => JSON.stringify(a) === JSON.stringify(b) });\n  readonly columnNames = computed(() => this.columns().map(column => column.name), {\n    equal: (a, b) => JSON.stringify(a) === JSON.stringify(b),\n  });\n\n  constructor() {\n    super();\n    effect(() => {\n      console.debug('highlight', this.highlight());\n    });\n  }\n}\n\nenum ActionId {\n  CHECKBOX_CLICK = '[@ng-atomic/components/organisms/checkbox-column] Checkbox Click',\n  HEADER_CLICK = '[@ng-atomic/components/organisms/table] Header Click',\n}\n\n@Component({\n  selector: 'organisms-table',\n  standalone: true,\n  imports: [\n    NgClass,\n    DomainPipe,\n    MatTableModule,\n    MatCheckboxModule,\n    MatMenuModule,\n    MatButtonModule,\n    MatIconModule,\n    ActionsColumnMolecule,\n    CheckboxColumnMolecule,\n    SmartColumnMolecule,\n    TreeColumnMolecule,\n    ResolveColumnsPipe,\n    MapPipe,\n    AutoColumnsPipe,\n    SortPipe,\n    ColumnsPipe,\n  ],\n  template: `\n  <table\n    mat-table\n    recycleRows\n    matSort\n    matSortDisableClear\n    matSortDirection=\"desc\"\n    [dataSource]=\"store.dataSource()\"\n  >\n    @for (column of store.columns(); track column.name; let i = $index) {\n      @switch (column.type) {\n        @case ('checkbox') {\n          <molecules-checkbox-column\n            [name]=\"column.name\"\n            [selection]=\"store.selection()\"\n            [isHidden]=\"store.isHidden()\"\n            (action)=\"dispatch($event)\"\n          />\n        }\n        @case ('actions') {\n          <molecules-actions-column\n            [name]=\"column.name\"\n            [itemActions]=\"column.actions\"\n            (action)=\"dispatch($event)\"\n          />\n        }\n        @case('tree') {\n          <molecules-tree-column\n            [name]=\"column.name\"\n            [headerText]=\"column.headerText\"\n            [treeControl]=\"store.treeControl()\"\n            [sort]=\"column.sort\"\n            (headerClick)=\"onHeaderClick(column.name)\"\n          />\n        }\n        @default {\n          <molecules-smart-column\n            [name]=\"column.name\"\n            [headerText]=\"column.headerText\"\n            [sort]=\"column.sort\"\n            (headerClick)=\"onHeaderClick(column.name)\"\n          />\n        }\n      }\n    }\n    <tr mat-header-row *matHeaderRowDef=\"store.columnNames(); sticky: true\"></tr>\n    <tr\n      mat-row\n      *matRowDef=\"let item; columns: store.columnNames();\"\n      [ngClass]=\"{ highlight: store.highlight().isSelected(item.id) }\"\n    ></tr>\n    <div class=\"mat-row\" *matNoDataRow>No Data</div>\n  </table>\n  `,\n  styleUrls: ['./table.organism.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  hostDirectives: [\n    {\n      directive: TableOrganismStore,\n      inputs: ['form', 'itemActions', 'selection', 'items', 'childrenKey', 'highlight'],\n    },\n  ],\n  host: {class: 'organism'},\n})\nexport class TableOrganism<Item extends object> extends NgAtomicComponent {\n  static readonly ActionId = ActionId;\n  protected store = inject(TableOrganismStore);\n\n  @Effect(CheckboxColumnMolecule.ActionId.CHECKBOX_CLICK)\n  protected onCheckboxClick(item: Item) {\n    this.dispatch({id: ActionId.CHECKBOX_CLICK, payload: item});\n  }\n\n  protected onHeaderClick(column: string) {\n    this.dispatch({id: ActionId.HEADER_CLICK, payload: column});\n  }\n}\n"]}
|
|
@@ -48,7 +48,7 @@ export class TextInputSectionOrganism extends NgAtomicComponent {
|
|
|
48
48
|
(action)="dispatch($event)"
|
|
49
49
|
/>
|
|
50
50
|
}
|
|
51
|
-
`, isInline: true, styles: [":host{--horizontal-padding: 16px;--horizontal-padding-SCOPED-IN-text-input-section-
|
|
51
|
+
`, isInline: true, styles: [":host{--horizontal-padding: 16px;--horizontal-padding-SCOPED-IN-text-input-section-yrr1: var(--horizontal-padding)}:host{display:flex;flex-direction:row;width:100%;padding:0 var(--horizontal-padding-SCOPED-IN-text-input-section-yrr1) 0;box-sizing:border-box}:host:has(atoms-smart-button){padding:0 0 0 var(--horizontal-padding-SCOPED-IN-text-input-section-yrr1)}:host .molecule.input-field,:host mat-form-field{width:100%;flex:1fr}:host atoms-smart-menu-button{flex:auto;margin-top:4px;margin-right:-16px}\n"], dependencies: [{ kind: "directive", type: TextInputFieldMoleculeStore, selector: "molecules-text-input-field", inputs: ["appearance", "type", "name", "label", "control", "placeholder", "hint", "pattern", "autoComplete"] }, { kind: "directive", type: SmartMenuButtonAtomStore, selector: "atoms-smart-menu-button", inputs: ["actions", "type"] }] }); }
|
|
52
52
|
}
|
|
53
53
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.2", ngImport: i0, type: TextInputSectionOrganism, decorators: [{
|
|
54
54
|
type: Component,
|
|
@@ -75,6 +75,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.2", ngImpor
|
|
|
75
75
|
directive: TextInputSectionOrganismStore,
|
|
76
76
|
inputs: ['label', 'placeholder', 'type', 'hint', 'control', 'autoComplete', 'actions'],
|
|
77
77
|
}
|
|
78
|
-
], styles: [":host{--horizontal-padding: 16px;--horizontal-padding-SCOPED-IN-text-input-section-
|
|
78
|
+
], styles: [":host{--horizontal-padding: 16px;--horizontal-padding-SCOPED-IN-text-input-section-yrr1: var(--horizontal-padding)}:host{display:flex;flex-direction:row;width:100%;padding:0 var(--horizontal-padding-SCOPED-IN-text-input-section-yrr1) 0;box-sizing:border-box}:host:has(atoms-smart-button){padding:0 0 0 var(--horizontal-padding-SCOPED-IN-text-input-section-yrr1)}:host .molecule.input-field,:host mat-form-field{width:100%;flex:1fr}:host atoms-smart-menu-button{flex:auto;margin-top:4px;margin-right:-16px}\n"] }]
|
|
79
79
|
}] });
|
|
80
80
|
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGV4dC1pbnB1dC1zZWN0aW9uLm9yZ2FuaXNtLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvQG5nLWF0b21pYy9jb21wb25lbnRzL3NyYy9saWIvb3JnYW5pc21zL3RleHQtaW5wdXQtc2VjdGlvbi90ZXh0LWlucHV0LXNlY3Rpb24ub3JnYW5pc20udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsU0FBUyxFQUFFLE1BQU0sRUFBRSxLQUFLLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDcEUsT0FBTyxFQUFFLFdBQVcsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBQzdDLE9BQU8sRUFBRSx3QkFBd0IsRUFBRSxNQUFNLCtDQUErQyxDQUFDO0FBQ3pGLE9BQU8sRUFBRSwyQkFBMkIsRUFBRSxNQUFNLGtEQUFrRCxDQUFDO0FBQy9GLE9BQU8sRUFBVSxtQkFBbUIsRUFBRSxpQkFBaUIsRUFBRSxhQUFhLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQzs7QUFJekYsSUFBTSw2QkFBNkIsR0FBbkMsTUFBTSw2QkFBOEIsU0FBUSxtQkFBbUI7SUFBL0Q7O1FBQ0ksVUFBSyxHQUFHLEtBQUssQ0FBQyxPQUFPLENBQUMsQ0FBQztRQUN2QixnQkFBVyxHQUFHLEtBQUssQ0FBQyxhQUFhLENBQUMsQ0FBQztRQUNuQyxTQUFJLEdBQUcsS0FBSyxDQUFpQyxNQUFNLENBQUMsQ0FBQztRQUNyRCxTQUFJLEdBQUcsS0FBSyxFQUFVLENBQUM7UUFDdkIsWUFBTyxHQUFHLEtBQUssQ0FBQyxJQUFJLFdBQVcsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDO1FBQ3JDLGlCQUFZLEdBQUcsS0FBSyxDQUFXLEVBQUUsQ0FBQyxDQUFDO1FBQ25DLFlBQU8sR0FBRyxLQUFLLENBQVcsRUFBRSxDQUFDLENBQUM7S0FDeEM7OEdBUlksNkJBQTZCO2tHQUE3Qiw2QkFBNkI7O0FBQTdCLDZCQUE2QjtJQUZ6QyxhQUFhLEVBQUU7R0FFSCw2QkFBNkIsQ0FRekM7OzJGQVJZLDZCQUE2QjtrQkFEekMsU0FBUzttQkFBQyxFQUFFLFVBQVUsRUFBRSxJQUFJLEVBQUUsUUFBUSxFQUFFLDhCQUE4QixFQUFFOztBQTBDekUsTUFBTSxPQUFPLHdCQUF5QixTQUFRLGlCQUFpQjtJQS9CL0Q7O1FBZ0NZLFVBQUssR0FBRyxNQUFNLENBQUMsNkJBQTZCLENBQUMsQ0FBQztLQUN6RDs4R0FGWSx3QkFBd0I7a0dBQXhCLHdCQUF3QixxSEF6Q3hCLDZCQUE2QixtTUFpQjlCOzs7Ozs7Ozs7Ozs7Ozs7R0FlVCxxa0JBbEJDLDJCQUEyQixxTEFDM0Isd0JBQXdCOzsyRkEwQmYsd0JBQXdCO2tCQS9CcEMsU0FBUzsrQkFDRSw4QkFBOEIsY0FDNUIsSUFBSSxXQUNQO3dCQUNQLDJCQUEyQjt3QkFDM0Isd0JBQXdCO3FCQUN6QixZQUNTOzs7Ozs7Ozs7Ozs7Ozs7R0FlVCxrQkFFZTt3QkFDZDs0QkFDRSxTQUFTLEVBQUUsNkJBQTZCOzRCQUN4QyxNQUFNLEVBQUUsQ0FBQyxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sRUFBRSxNQUFNLEVBQUUsU0FBUyxFQUFFLGNBQWMsRUFBRSxTQUFTLENBQUM7eUJBQ3ZGO3FCQUNGIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBEaXJlY3RpdmUsIGluamVjdCwgaW5wdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEZvcm1Db250cm9sIH0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xuaW1wb3J0IHsgU21hcnRNZW51QnV0dG9uQXRvbVN0b3JlIH0gZnJvbSAnQG5nLWF0b21pYy9jb21wb25lbnRzL2F0b21zL3NtYXJ0LW1lbnUtYnV0dG9uJztcbmltcG9ydCB7IFRleHRJbnB1dEZpZWxkTW9sZWN1bGVTdG9yZSB9IGZyb20gJ0BuZy1hdG9taWMvY29tcG9uZW50cy9tb2xlY3VsZXMvdGV4dC1pbnB1dC1maWVsZCc7XG5pbXBvcnQgeyBBY3Rpb24sIEluamVjdGFibGVDb21wb25lbnQsIE5nQXRvbWljQ29tcG9uZW50LCBUb2tlbml6ZWRUeXBlIH0gZnJvbSAnQG5nLWF0b21pYy9jb3JlJztcblxuQFRva2VuaXplZFR5cGUoKVxuQERpcmVjdGl2ZSh7IHN0YW5kYWxvbmU6IHRydWUsIHNlbGVjdG9yOiAnb3JnYW5pc21zLXRleHQtaW5wdXQtc2VjdGlvbicgfSlcbmV4cG9ydCBjbGFzcyBUZXh0SW5wdXRTZWN0aW9uT3JnYW5pc21TdG9yZSBleHRlbmRzIEluamVjdGFibGVDb21wb25lbnQge1xuICByZWFkb25seSBsYWJlbCA9IGlucHV0KCdsYWJlbCcpO1xuICByZWFkb25seSBwbGFjZWhvbGRlciA9IGlucHV0KCdwbGFjZWhvbGRlcicpO1xuICByZWFkb25seSB0eXBlID0gaW5wdXQ8J3RleHQnIHwgJ251bWJlcicgfCAncGFzc3dvcmQnPigndGV4dCcpO1xuICByZWFkb25seSBoaW50ID0gaW5wdXQ8c3RyaW5nPigpO1xuICByZWFkb25seSBjb250cm9sID0gaW5wdXQobmV3IEZvcm1Db250cm9sKCcnKSk7XG4gIHJlYWRvbmx5IGF1dG9Db21wbGV0ZSA9IGlucHV0PHN0cmluZ1tdPihbXSk7XG4gIHJlYWRvbmx5IGFjdGlvbnMgPSBpbnB1dDxBY3Rpb25bXT4oW10pO1xufVxuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdvcmdhbmlzbXMtdGV4dC1pbnB1dC1zZWN0aW9uJyxcbiAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgaW1wb3J0czogW1xuICAgIFRleHRJbnB1dEZpZWxkTW9sZWN1bGVTdG9yZSxcbiAgICBTbWFydE1lbnVCdXR0b25BdG9tU3RvcmUsXG4gIF0sXG4gIHRlbXBsYXRlOiBgXG4gIDxtb2xlY3VsZXMtdGV4dC1pbnB1dC1maWVsZCBpbmplY3RhYmxlXG4gICAgW3R5cGVdPVwic3RvcmUudHlwZSgpXCJcbiAgICBbY29udHJvbF09XCJzdG9yZS5jb250cm9sKClcIlxuICAgIFtsYWJlbF09XCJzdG9yZS5sYWJlbCgpXCJcbiAgICBbcGxhY2Vob2xkZXJdPVwic3RvcmUucGxhY2Vob2xkZXIoKVwiXG4gICAgW2hpbnRdPVwic3RvcmUuaGludCgpXCJcbiAgICBbYXV0b0NvbXBsZXRlXT1cInN0b3JlLmF1dG9Db21wbGV0ZSgpXCJcbiAgLz5cbiAgQGlmIChzdG9yZS5hY3Rpb25zKCk/Lmxlbmd0aCkge1xuICAgIDxhdG9tcy1zbWFydC1tZW51LWJ1dHRvbiBpbmplY3RhYmxlXG4gICAgICBbYWN0aW9uc109XCJzdG9yZS5hY3Rpb25zKClcIlxuICAgICAgKGFjdGlvbik9XCJkaXNwYXRjaCgkZXZlbnQpXCJcbiAgICAvPlxuICB9XG4gIGAsXG4gIHN0eWxlVXJsczogWycuL3RleHQtaW5wdXQtc2VjdGlvbi5vcmdhbmlzbS5zY3NzJ10sXG4gIGhvc3REaXJlY3RpdmVzOiBbXG4gICAge1xuICAgICAgZGlyZWN0aXZlOiBUZXh0SW5wdXRTZWN0aW9uT3JnYW5pc21TdG9yZSxcbiAgICAgIGlucHV0czogWydsYWJlbCcsICdwbGFjZWhvbGRlcicsICd0eXBlJywgJ2hpbnQnLCAnY29udHJvbCcsICdhdXRvQ29tcGxldGUnLCAnYWN0aW9ucyddLFxuICAgIH1cbiAgXVxufSlcbmV4cG9ydCBjbGFzcyBUZXh0SW5wdXRTZWN0aW9uT3JnYW5pc20gZXh0ZW5kcyBOZ0F0b21pY0NvbXBvbmVudCB7XG4gIHByb3RlY3RlZCBzdG9yZSA9IGluamVjdChUZXh0SW5wdXRTZWN0aW9uT3JnYW5pc21TdG9yZSk7XG59XG4iXX0=
|
|
@@ -1,5 +1,4 @@
|
|
|
1
1
|
import { __decorate } from "tslib";
|
|
2
|
-
import { CommonModule } from '@angular/common';
|
|
3
2
|
import { ChangeDetectionStrategy, Component, Directive, input, inject } from '@angular/core';
|
|
4
3
|
import { FormControl } from '@angular/forms';
|
|
5
4
|
import { InjectableComponent, NgAtomicComponent, TokenizedType } from '@ng-atomic/core';
|
|
@@ -52,12 +51,11 @@ export class TextareaSectionOrganism extends NgAtomicComponent {
|
|
|
52
51
|
(action)="dispatch($event)"
|
|
53
52
|
/>
|
|
54
53
|
}
|
|
55
|
-
`, isInline: true, styles: [":host{--vertical-padding: 16px;--vertical-padding-SCOPED-IN-textarea-section-
|
|
54
|
+
`, isInline: true, styles: [":host{--vertical-padding: 16px;--vertical-padding-SCOPED-IN-textarea-section-rRHi: var(--vertical-padding)}:host{display:block;width:100%;position:relative;padding:0 var(--vertical-padding-SCOPED-IN-textarea-section-rRHi);box-sizing:border-box}:host molecules-textarea-field{width:100%}:host atoms-smart-menu-button{position:absolute;bottom:4px;right:4px;background-color:#fff}\n"], dependencies: [{ kind: "component", type: TextareaFieldMolecule, selector: "molecules-textarea-field" }, { kind: "component", type: SmartMenuButtonAtom, selector: "atoms-smart-menu-button" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
56
55
|
}
|
|
57
56
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.2", ngImport: i0, type: TextareaSectionOrganism, decorators: [{
|
|
58
57
|
type: Component,
|
|
59
58
|
args: [{ selector: 'organisms-textarea-section', standalone: true, imports: [
|
|
60
|
-
CommonModule,
|
|
61
59
|
TextareaFieldMolecule,
|
|
62
60
|
SmartMenuButtonAtom,
|
|
63
61
|
], template: `
|
|
@@ -82,6 +80,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.2", ngImpor
|
|
|
82
80
|
directive: TextareaSectionOrganismStore,
|
|
83
81
|
inputs: ['appearance', 'label', 'rows', 'placeholder', 'floatLabel', 'hint', 'control', 'actions'],
|
|
84
82
|
}
|
|
85
|
-
], styles: [":host{--vertical-padding: 16px;--vertical-padding-SCOPED-IN-textarea-section-
|
|
83
|
+
], styles: [":host{--vertical-padding: 16px;--vertical-padding-SCOPED-IN-textarea-section-rRHi: var(--vertical-padding)}:host{display:block;width:100%;position:relative;padding:0 var(--vertical-padding-SCOPED-IN-textarea-section-rRHi);box-sizing:border-box}:host molecules-textarea-field{width:100%}:host atoms-smart-menu-button{position:absolute;bottom:4px;right:4px;background-color:#fff}\n"] }]
|
|
86
84
|
}] });
|
|
87
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
85
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGV4dGFyZWEtc2VjdGlvbi5vcmdhbmlzbS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL0BuZy1hdG9taWMvY29tcG9uZW50cy9zcmMvbGliL29yZ2FuaXNtcy90ZXh0YXJlYS1zZWN0aW9uL3RleHRhcmVhLXNlY3Rpb24ub3JnYW5pc20udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxTQUFTLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBRSxNQUFNLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDN0YsT0FBTyxFQUFFLFdBQVcsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBQzdDLE9BQU8sRUFBVSxtQkFBbUIsRUFBRSxpQkFBaUIsRUFBRSxhQUFhLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUNoRyxPQUFPLEVBQUUscUJBQXFCLEVBQUUsTUFBTSxnREFBZ0QsQ0FBQztBQUN2RixPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSwrQ0FBK0MsQ0FBQzs7QUFJN0UsSUFBTSw0QkFBNEIsR0FBbEMsTUFBTSw0QkFBNkIsU0FBUSxtQkFBbUI7SUFBOUQ7O1FBQ0ksZUFBVSxHQUFHLEtBQUssQ0FBNkMsU0FBUyxDQUFDLENBQUM7UUFDMUUsVUFBSyxHQUFHLEtBQUssQ0FBQyxPQUFPLENBQUMsQ0FBQztRQUN2QixTQUFJLEdBQUcsS0FBSyxDQUFDLEVBQUUsQ0FBQyxDQUFDO1FBQ2pCLGdCQUFXLEdBQUcsS0FBSyxDQUFTLGFBQWEsQ0FBQyxDQUFDO1FBQzNDLGVBQVUsR0FBRyxLQUFLLENBQThCLE1BQU0sQ0FBQyxDQUFDO1FBQ3hELFNBQUksR0FBRyxLQUFLLEVBQVUsQ0FBQztRQUN2QixZQUFPLEdBQUcsS0FBSyxDQUFDLElBQUksV0FBVyxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUM7UUFDckMsWUFBTyxHQUFHLEtBQUssQ0FBVyxFQUFFLENBQUMsQ0FBQztLQUN4Qzs4R0FUWSw0QkFBNEI7a0dBQTVCLDRCQUE0Qjs7QUFBNUIsNEJBQTRCO0lBRnhDLGFBQWEsRUFBRTtHQUVILDRCQUE0QixDQVN4Qzs7MkZBVFksNEJBQTRCO2tCQUR4QyxTQUFTO21CQUFDLEVBQUUsVUFBVSxFQUFFLElBQUksRUFBRSxRQUFRLEVBQUUsNEJBQTRCLEVBQUU7O0FBOEN2RSxNQUFNLE9BQU8sdUJBQXdCLFNBQVEsaUJBQWlCO0lBbEM5RDs7UUFtQ1ksVUFBSyxHQUFHLE1BQU0sQ0FBQyw0QkFBNEIsQ0FBQyxDQUFDO0tBQ3hEOzhHQUZZLHVCQUF1QjtrR0FBdkIsdUJBQXVCLG1IQTdDdkIsNEJBQTRCLDJOQWtCN0I7Ozs7Ozs7Ozs7Ozs7Ozs7O0dBaUJULHFjQXBCQyxxQkFBcUIscUVBQ3JCLG1CQUFtQjs7MkZBNkJWLHVCQUF1QjtrQkFsQ25DLFNBQVM7K0JBQ0UsNEJBQTRCLGNBQzFCLElBQUksV0FDUDt3QkFDUCxxQkFBcUI7d0JBQ3JCLG1CQUFtQjtxQkFDcEIsWUFDUzs7Ozs7Ozs7Ozs7Ozs7Ozs7R0FpQlQsbUJBRWdCLHVCQUF1QixDQUFDLE1BQU0sa0JBQy9CO3dCQUNkOzRCQUNFLFNBQVMsRUFBRSw0QkFBNEI7NEJBQ3ZDLE1BQU0sRUFBRSxDQUFDLFlBQVksRUFBRSxPQUFPLEVBQUUsTUFBTSxFQUFFLGFBQWEsRUFBRSxZQUFZLEVBQUUsTUFBTSxFQUFFLFNBQVMsRUFBRSxTQUFTLENBQUM7eUJBQ25HO3FCQUNGIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIENvbXBvbmVudCwgRGlyZWN0aXZlLCBpbnB1dCwgaW5qZWN0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBGb3JtQ29udHJvbCB9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcbmltcG9ydCB7IEFjdGlvbiwgSW5qZWN0YWJsZUNvbXBvbmVudCwgTmdBdG9taWNDb21wb25lbnQsIFRva2VuaXplZFR5cGUgfSBmcm9tICdAbmctYXRvbWljL2NvcmUnO1xuaW1wb3J0IHsgVGV4dGFyZWFGaWVsZE1vbGVjdWxlIH0gZnJvbSAnQG5nLWF0b21pYy9jb21wb25lbnRzL21vbGVjdWxlcy90ZXh0YXJlYS1maWVsZCc7XG5pbXBvcnQgeyBTbWFydE1lbnVCdXR0b25BdG9tIH0gZnJvbSAnQG5nLWF0b21pYy9jb21wb25lbnRzL2F0b21zL3NtYXJ0LW1lbnUtYnV0dG9uJztcblxuQFRva2VuaXplZFR5cGUoKVxuQERpcmVjdGl2ZSh7IHN0YW5kYWxvbmU6IHRydWUsIHNlbGVjdG9yOiAnb3JnYW5pc21zLXRleHRhcmVhLXNlY3Rpb24nIH0pXG5leHBvcnQgY2xhc3MgVGV4dGFyZWFTZWN0aW9uT3JnYW5pc21TdG9yZSBleHRlbmRzIEluamVjdGFibGVDb21wb25lbnQge1xuICByZWFkb25seSBhcHBlYXJhbmNlID0gaW5wdXQ8J2xlZ2FjeScgfCAnc3RhbmRhcmQnIHwgJ2ZpbGwnIHwgJ291dGxpbmUnPignb3V0bGluZScpO1xuICByZWFkb25seSBsYWJlbCA9IGlucHV0KCdsYWJlbCcpO1xuICByZWFkb25seSByb3dzID0gaW5wdXQoMTApO1xuICByZWFkb25seSBwbGFjZWhvbGRlciA9IGlucHV0PHN0cmluZz4oJ3BsYWNlaG9sZGVyJyk7XG4gIHJlYWRvbmx5IGZsb2F0TGFiZWwgPSBpbnB1dDwnYXV0bycgfCAnYWx3YXlzJyB8ICduZXZlcic+KCdhdXRvJyk7XG4gIHJlYWRvbmx5IGhpbnQgPSBpbnB1dDxzdHJpbmc+KCk7XG4gIHJlYWRvbmx5IGNvbnRyb2wgPSBpbnB1dChuZXcgRm9ybUNvbnRyb2woJycpKTtcbiAgcmVhZG9ubHkgYWN0aW9ucyA9IGlucHV0PEFjdGlvbltdPihbXSk7XG59XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ29yZ2FuaXNtcy10ZXh0YXJlYS1zZWN0aW9uJyxcbiAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgaW1wb3J0czogW1xuICAgIFRleHRhcmVhRmllbGRNb2xlY3VsZSxcbiAgICBTbWFydE1lbnVCdXR0b25BdG9tLFxuICBdLFxuICB0ZW1wbGF0ZTogYFxuICA8bW9sZWN1bGVzLXRleHRhcmVhLWZpZWxkXG4gICAgW2FwcGVhcmFuY2VdPVwic3RvcmUuYXBwZWFyYW5jZSgpXCJcbiAgICBbY29udHJvbF09XCJzdG9yZS5jb250cm9sKClcIlxuICAgIFtsYWJlbF09XCJzdG9yZS5sYWJlbCgpXCJcbiAgICBbZmxvYXRMYWJlbF09XCJzdG9yZS5mbG9hdExhYmVsKClcIlxuICAgIFtoaW50XT1cInN0b3JlLmhpbnQoKVwiXG4gICAgW3Jvd3NdPVwic3RvcmUucm93cygpXCJcbiAgICBbcGxhY2Vob2xkZXJdPVwic3RvcmUucGxhY2Vob2xkZXIoKVwiXG4gICAgKGFjdGlvbik9XCJkaXNwYXRjaCgkZXZlbnQpXCJcbiAgLz5cbiAgQGlmIChzdG9yZS5hY3Rpb25zKCkubGVuZ3RoKSB7XG4gICAgPGF0b21zLXNtYXJ0LW1lbnUtYnV0dG9uXG4gICAgICBbYWN0aW9uc109XCJzdG9yZS5hY3Rpb25zKClcIlxuICAgICAgKGFjdGlvbik9XCJkaXNwYXRjaCgkZXZlbnQpXCJcbiAgICAvPlxuICB9XG4gIGAsXG4gIHN0eWxlVXJsczogWycuL3RleHRhcmVhLXNlY3Rpb24ub3JnYW5pc20uc2NzcyddLFxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcbiAgaG9zdERpcmVjdGl2ZXM6IFtcbiAgICB7XG4gICAgICBkaXJlY3RpdmU6IFRleHRhcmVhU2VjdGlvbk9yZ2FuaXNtU3RvcmUsXG4gICAgICBpbnB1dHM6IFsnYXBwZWFyYW5jZScsICdsYWJlbCcsICdyb3dzJywgJ3BsYWNlaG9sZGVyJywgJ2Zsb2F0TGFiZWwnLCAnaGludCcsICdjb250cm9sJywgJ2FjdGlvbnMnXSxcbiAgICB9XG4gIF0sXG59KVxuZXhwb3J0IGNsYXNzIFRleHRhcmVhU2VjdGlvbk9yZ2FuaXNtIGV4dGVuZHMgTmdBdG9taWNDb21wb25lbnQge1xuICBwcm90ZWN0ZWQgc3RvcmUgPSBpbmplY3QoVGV4dGFyZWFTZWN0aW9uT3JnYW5pc21TdG9yZSk7XG59XG4iXX0=
|
|
@@ -63,7 +63,7 @@ export class ThreadMessagesSectionOrganism extends NgAtomicComponent {
|
|
|
63
63
|
</div>
|
|
64
64
|
<mat-divider />
|
|
65
65
|
}
|
|
66
|
-
`, isInline: true, styles: [":host{display:block;--primary-color: inherit;--primary-color-SCOPED-IN-%COMP%-
|
|
66
|
+
`, isInline: true, styles: [":host{display:block;--primary-color: inherit;--primary-color-SCOPED-IN-%COMP%-6cYF: var(--primary-color);--on-primary-color: inherit;--on-primary-color-SCOPED-IN-%COMP%-6cYF: var(--on-primary-color);--surface-color: inherit;--surface-color-SCOPED-IN-%COMP%-6cYF: var(--surface-color);--on-surface-color: inherit;--on-surface-color-SCOPED-IN-%COMP%-6cYF: var(--on-surface-color);--background-color: inherit;--background-color-SCOPED-IN-%COMP%-6cYF: var(--background-color);--on-background-color: inherit;--on-background-color-SCOPED-IN-%COMP%-6cYF: var(--on-background-color)}:host{display:flex;flex-direction:column;justify-content:flex-start;color:var(--on-surface-color-SCOPED-IN-%COMP%-6cYF)}:host .message{padding:8px 16px}:host .message .header{display:flex;justify-content:flex-start;align-items:center;padding:8px 0;box-sizing:border-box;gap:8px}:host .message .header .name{font-size:14px;font-weight:700}:host .message .header .description{display:flex;justify-content:flex-start;gap:4px;font-size:12px}:host .message .header img{width:40px;height:40px;border-radius:50%;background-color:var(--primary-color-SCOPED-IN-%COMP%-6cYF)}:host .message .content{font-size:14px;padding-bottom:24px;box-sizing:border-box}:host .message .bottom.actions{display:flex;justify-content:flex-end;align-items:center;gap:8px}:host .message .bottom.actions button{height:32px;padding:0 8px;--mdc-outlined-button-label-text-size: 12px}:host mat-divider{width:calc(100% - 16px);box-sizing:border-box;margin:0 8px}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "pipe", type: ActionsPipe, name: "resolveActions" }, { kind: "ngmodule", type: MatButtonModule }, { kind: "component", type: i1.MatButton, selector: " button[mat-button], button[mat-raised-button], button[mat-flat-button], button[mat-stroked-button] ", exportAs: ["matButton"] }, { kind: "pipe", type: DataAccessorPipe, name: "dataAccessor" }, { kind: "ngmodule", type: MatDividerModule }, { kind: "component", type: i2.MatDivider, selector: "mat-divider", inputs: ["vertical", "inset"] }, { kind: "directive", type: FallbackSrcDirective, selector: "[fallbackSrc]" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
67
67
|
}
|
|
68
68
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.2", ngImport: i0, type: ThreadMessagesSectionOrganism, decorators: [{
|
|
69
69
|
type: Component,
|
|
@@ -114,6 +114,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.2", ngImpor
|
|
|
114
114
|
directive: ThreadMessagesSectionOrganismStore,
|
|
115
115
|
inputs: ['comments', 'noCommentMessage', 'commentActions']
|
|
116
116
|
}
|
|
117
|
-
], styles: [":host{display:block;--primary-color: inherit;--primary-color-SCOPED-IN-%COMP%-
|
|
117
|
+
], styles: [":host{display:block;--primary-color: inherit;--primary-color-SCOPED-IN-%COMP%-6cYF: var(--primary-color);--on-primary-color: inherit;--on-primary-color-SCOPED-IN-%COMP%-6cYF: var(--on-primary-color);--surface-color: inherit;--surface-color-SCOPED-IN-%COMP%-6cYF: var(--surface-color);--on-surface-color: inherit;--on-surface-color-SCOPED-IN-%COMP%-6cYF: var(--on-surface-color);--background-color: inherit;--background-color-SCOPED-IN-%COMP%-6cYF: var(--background-color);--on-background-color: inherit;--on-background-color-SCOPED-IN-%COMP%-6cYF: var(--on-background-color)}:host{display:flex;flex-direction:column;justify-content:flex-start;color:var(--on-surface-color-SCOPED-IN-%COMP%-6cYF)}:host .message{padding:8px 16px}:host .message .header{display:flex;justify-content:flex-start;align-items:center;padding:8px 0;box-sizing:border-box;gap:8px}:host .message .header .name{font-size:14px;font-weight:700}:host .message .header .description{display:flex;justify-content:flex-start;gap:4px;font-size:12px}:host .message .header img{width:40px;height:40px;border-radius:50%;background-color:var(--primary-color-SCOPED-IN-%COMP%-6cYF)}:host .message .content{font-size:14px;padding-bottom:24px;box-sizing:border-box}:host .message .bottom.actions{display:flex;justify-content:flex-end;align-items:center;gap:8px}:host .message .bottom.actions button{height:32px;padding:0 8px;--mdc-outlined-button-label-text-size: 12px}:host mat-divider{width:calc(100% - 16px);box-sizing:border-box;margin:0 8px}\n"] }]
|
|
118
118
|
}] });
|
|
119
119
|
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGhyZWFkLW1lc3NhZ2VzLXNlY3Rpb24ub3JnYW5pc20uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9AbmctYXRvbWljL2NvbXBvbmVudHMvc3JjL2xpYi9vcmdhbmlzbXMvdGhyZWFkLW1lc3NhZ2VzLXNlY3Rpb24vdGhyZWFkLW1lc3NhZ2VzLXNlY3Rpb24ub3JnYW5pc20udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLHVCQUF1QixFQUFFLFNBQVMsRUFBRSxTQUFTLEVBQVUsTUFBTSxFQUFFLEtBQUssRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUNyRyxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFXLGlCQUFpQixFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDN0QsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sMkJBQTJCLENBQUM7QUFDN0QsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sMkNBQTJDLENBQUM7QUFDakYsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sdUNBQXVDLENBQUM7QUFDekUsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLDBCQUEwQixDQUFDO0FBQzNELE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSxpQ0FBaUMsQ0FBQzs7OztBQUc5RCxNQUFNLE9BQU8sa0NBQWtDO0lBRC9DO1FBRVcsYUFBUSxHQUFHLEtBQUssQ0FBTSxFQUFFLENBQUMsQ0FBQztRQUMxQixxQkFBZ0IsR0FBRyxLQUFLLENBQUMsZUFBZSxDQUFDLENBQUM7UUFDMUMsbUJBQWMsR0FBRyxLQUFLLENBQVUsRUFBRSxDQUFDLENBQUM7S0FDOUM7OEdBSlksa0NBQWtDO2tHQUFsQyxrQ0FBa0M7OzJGQUFsQyxrQ0FBa0M7a0JBRDlDLFNBQVM7bUJBQUMsRUFBRSxVQUFVLEVBQUUsSUFBSSxFQUFFOztBQStEL0IsTUFBTSxPQUFPLDZCQUE4QixTQUFRLGlCQUFpQjtJQXhEcEU7O1FBeURZLFVBQUssR0FBRyxNQUFNLENBQUMsa0NBQWtDLENBQUMsQ0FBQztLQUM5RDs4R0FGWSw2QkFBNkI7a0dBQTdCLDZCQUE2QixpSEE5RDdCLGtDQUFrQywySUFpQm5DOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztHQW1DVCx5aURBMUNDLFlBQVksMEJBQ1osV0FBVyxzREFDWCxlQUFlLHVOQUNmLGdCQUFnQixvREFDaEIsZ0JBQWdCLG1JQUNoQixvQkFBb0I7OzJGQStDWCw2QkFBNkI7a0JBeER6QyxTQUFTOytCQUNFLDBCQUEwQixjQUN4QixJQUFJLFdBQ1A7d0JBQ1AsWUFBWTt3QkFDWixXQUFXO3dCQUNYLGVBQWU7d0JBQ2YsZ0JBQWdCO3dCQUNoQixnQkFBZ0I7d0JBQ2hCLG9CQUFvQjtxQkFDckIsWUFDUzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7R0FtQ1QsbUJBRWdCLHVCQUF1QixDQUFDLE1BQU0sa0JBQy9CO3dCQUNkOzRCQUNFLFNBQVMsRUFBRSxrQ0FBa0M7NEJBQzdDLE1BQU0sRUFBRSxDQUFDLFVBQVUsRUFBRSxrQkFBa0IsRUFBRSxnQkFBZ0IsQ0FBQzt5QkFDM0Q7cUJBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSwgQ29tcG9uZW50LCBEaXJlY3RpdmUsIGVmZmVjdCwgaW5qZWN0LCBpbnB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7IEFjdGlvbnMsIE5nQXRvbWljQ29tcG9uZW50IH0gZnJvbSAnQG5nLWF0b21pYy9jb3JlJztcbmltcG9ydCB7IE1hdERpdmlkZXJNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9kaXZpZGVyJztcbmltcG9ydCB7IEZhbGxiYWNrU3JjRGlyZWN0aXZlIH0gZnJvbSAnQG5nLWF0b21pYy9jb21tb24vZGlyZWN0aXZlcy9mYWxsYmFjay1zcmMnO1xuaW1wb3J0IHsgRGF0YUFjY2Vzc29yUGlwZSB9IGZyb20gJ0BuZy1hdG9taWMvY29tbW9uL3BpcGVzL2RhdGEtYWNjZXNzb3InO1xuaW1wb3J0IHsgTWF0QnV0dG9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvYnV0dG9uJztcbmltcG9ydCB7IEFjdGlvbnNQaXBlIH0gZnJvbSAnQG5nLWF0b21pYy9jb21tb24vcGlwZXMvYWN0aW9ucyc7XG5cbkBEaXJlY3RpdmUoeyBzdGFuZGFsb25lOiB0cnVlIH0pXG5leHBvcnQgY2xhc3MgVGhyZWFkTWVzc2FnZXNTZWN0aW9uT3JnYW5pc21TdG9yZTxUPiB7XG4gIHJlYWRvbmx5IGNvbW1lbnRzID0gaW5wdXQ8VFtdPihbXSk7XG4gIHJlYWRvbmx5IG5vQ29tbWVudE1lc3NhZ2UgPSBpbnB1dCgn44G+44Gg44Kz44Oh44Oz44OI44Gv44GC44KK44G+44Gb44KT44CCJyk7XG4gIHJlYWRvbmx5IGNvbW1lbnRBY3Rpb25zID0gaW5wdXQ8QWN0aW9ucz4oW10pO1xufVxuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdvcmdhbmlzbXMtdGhyZWFkLXNlY3Rpb24nLFxuICBzdGFuZGFsb25lOiB0cnVlLFxuICBpbXBvcnRzOiBbXG4gICAgQ29tbW9uTW9kdWxlLFxuICAgIEFjdGlvbnNQaXBlLFxuICAgIE1hdEJ1dHRvbk1vZHVsZSxcbiAgICBEYXRhQWNjZXNzb3JQaXBlLFxuICAgIE1hdERpdmlkZXJNb2R1bGUsXG4gICAgRmFsbGJhY2tTcmNEaXJlY3RpdmUsXG4gIF0sXG4gIHRlbXBsYXRlOiBgXG4gIEBpZiAoc3RvcmUuY29tbWVudHMoKT8ubGVuZ3RoID09PSAwKSB7XG4gICAgPGRpdiBjbGFzcz1cIm1lc3NhZ2VcIj5cbiAgICAgIDxkaXYgY2xhc3M9XCJjb250ZW50XCI+XG4gICAgICAgIDxzcGFuPnt7IHN0b3JlLm5vQ29tbWVudE1lc3NhZ2UoKSB9fTwvc3Bhbj5cbiAgICAgIDwvZGl2PlxuICAgIDwvZGl2PlxuICB9XG5cbiAgQGZvciAoY29tbWVudCBvZiBzdG9yZS5jb21tZW50cygpID8/IFtdOyB0cmFjayBjb21tZW50KSB7XG4gICAgPGRpdiBjbGFzcz1cIm1lc3NhZ2VcIj5cbiAgICAgIDxkaXYgY2xhc3M9XCJoZWFkZXJcIj5cbiAgICAgICAgPGltZyBbc3JjXT1cImNvbW1lbnQgfCBkYXRhQWNjZXNzb3I6J2ljb25VcmwnXCIgZmFsbGJhY2tTcmMgYWx0PVwiXCI+XG4gICAgICAgIDxkaXY+XG4gICAgICAgICAgPHNwYW4gY2xhc3M9XCJuYW1lXCI+e3sgY29tbWVudCB8IGRhdGFBY2Nlc3NvcjonYXV0aG9yTmFtZScgfX08L3NwYW4+XG4gICAgICAgICAgPGRpdiBjbGFzcz1cImRlc2NyaXB0aW9uXCI+XG4gICAgICAgICAgICA8c3Bhbj57eyBjb21tZW50IHwgZGF0YUFjY2Vzc29yOidkZXNjcmlwdGlvbicgfX08L3NwYW4+XG4gICAgICAgICAgPC9kaXY+XG4gICAgICAgIDwvZGl2PlxuICAgICAgPC9kaXY+XG4gICAgICA8ZGl2IGNsYXNzPVwiY29udGVudFwiPlxuICAgICAgICA8c3Bhbj57eyBjb21tZW50IHwgZGF0YUFjY2Vzc29yOidjb250ZW50JyB9fTwvc3Bhbj5cbiAgICAgIDwvZGl2PlxuICAgICAgPGRpdiBjbGFzcz1cImJvdHRvbSBhY3Rpb25zXCI+XG4gICAgICAgIEBmb3IgKGFjdGlvbiBvZiBzdG9yZS5jb21tZW50QWN0aW9ucygpIHwgcmVzb2x2ZUFjdGlvbnM6Y29tbWVudDsgdHJhY2sgYWN0aW9uLmlkKSB7XG4gICAgICAgICAgPGJ1dHRvblxuICAgICAgICAgICAgbWF0LXN0cm9rZWQtYnV0dG9uXG4gICAgICAgICAgICBjb2xvcj1cInByaW1hcnlcIlxuICAgICAgICAgICAgKGNsaWNrKT1cImRpc3BhdGNoKGFjdGlvbilcIlxuICAgICAgICAgID57eyBhY3Rpb24ubmFtZSB9fTwvYnV0dG9uPlxuICAgICAgICB9XG4gICAgICA8L2Rpdj5cbiAgICA8L2Rpdj5cbiAgICA8bWF0LWRpdmlkZXIgLz5cbiAgfVxuICBgLFxuICBzdHlsZVVybHM6IFsnLi90aHJlYWQtbWVzc2FnZXMtc2VjdGlvbi5vcmdhbmlzbS5zY3NzJ10sXG4gIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoLFxuICBob3N0RGlyZWN0aXZlczogW1xuICAgIHtcbiAgICAgIGRpcmVjdGl2ZTogVGhyZWFkTWVzc2FnZXNTZWN0aW9uT3JnYW5pc21TdG9yZSxcbiAgICAgIGlucHV0czogWydjb21tZW50cycsICdub0NvbW1lbnRNZXNzYWdlJywgJ2NvbW1lbnRBY3Rpb25zJ11cbiAgICB9XG4gIF1cbn0pXG5leHBvcnQgY2xhc3MgVGhyZWFkTWVzc2FnZXNTZWN0aW9uT3JnYW5pc20gZXh0ZW5kcyBOZ0F0b21pY0NvbXBvbmVudCB7XG4gIHByb3RlY3RlZCBzdG9yZSA9IGluamVjdChUaHJlYWRNZXNzYWdlc1NlY3Rpb25PcmdhbmlzbVN0b3JlKTtcbn1cbiJdfQ==
|
|
@@ -112,7 +112,7 @@ export class IndexPage extends NgAtomicComponent {
|
|
|
112
112
|
(action)="dispatch($event)"
|
|
113
113
|
/>
|
|
114
114
|
</frames-router-outlet>
|
|
115
|
-
`, isInline: true, styles: [":host{width:100%;height:100%;display:block;--page-width-lv3-SCOPED-IN-index-
|
|
115
|
+
`, isInline: true, styles: [":host{width:100%;height:100%;display:block;--page-width-lv3-SCOPED-IN-index-TSxj: var(--page-width-lv3);--primary-color-SCOPED-IN-index-TSxj: var(--primary-color);--on-primary-color-SCOPED-IN-index-TSxj: var(--on-primary-color);--surface-color-SCOPED-IN-index-TSxj: var(--surface-color);--on-surface-color-SCOPED-IN-index-TSxj: var(--on-surface-color);--on-background-color-SCOPED-IN-index-TSxj: var(--on-background-color);--background-color-SCOPED-IN-index-TSxj: var(--background-color)}:host .template{width:var(--page-width-lv3-SCOPED-IN-index-TSxj)}:host *{--primary-color: var(--primary-color-SCOPED-IN-index-TSxj);--on-primary-color: var(--on-primary-color-SCOPED-IN-index-TSxj);--surface-color: var(--surface-color-SCOPED-IN-index-TSxj);--on-surface-color: var(--on-surface-color-SCOPED-IN-index-TSxj);--background-color: var(--background-color-SCOPED-IN-index-TSxj);--on-background-color: var(--on-background-color-SCOPED-IN-index-TSxj)}\n"], dependencies: [{ kind: "component", type: RouterOutletFrame, selector: "frames-router-outlet" }, { kind: "component", type: IndexTemplate, selector: "templates-index" }] }); }
|
|
116
116
|
}
|
|
117
117
|
__decorate([
|
|
118
118
|
Effect(IndexTemplate.ActionId.BACK),
|
|
@@ -153,6 +153,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.2", ngImpor
|
|
|
153
153
|
(action)="dispatch($event)"
|
|
154
154
|
/>
|
|
155
155
|
</frames-router-outlet>
|
|
156
|
-
`, hostDirectives: [IndexPageStore], styles: [":host{width:100%;height:100%;display:block;--page-width-lv3-SCOPED-IN-index-
|
|
156
|
+
`, hostDirectives: [IndexPageStore], styles: [":host{width:100%;height:100%;display:block;--page-width-lv3-SCOPED-IN-index-TSxj: var(--page-width-lv3);--primary-color-SCOPED-IN-index-TSxj: var(--primary-color);--on-primary-color-SCOPED-IN-index-TSxj: var(--on-primary-color);--surface-color-SCOPED-IN-index-TSxj: var(--surface-color);--on-surface-color-SCOPED-IN-index-TSxj: var(--on-surface-color);--on-background-color-SCOPED-IN-index-TSxj: var(--on-background-color);--background-color-SCOPED-IN-index-TSxj: var(--background-color)}:host .template{width:var(--page-width-lv3-SCOPED-IN-index-TSxj)}:host *{--primary-color: var(--primary-color-SCOPED-IN-index-TSxj);--on-primary-color: var(--on-primary-color-SCOPED-IN-index-TSxj);--surface-color: var(--surface-color-SCOPED-IN-index-TSxj);--on-surface-color: var(--on-surface-color-SCOPED-IN-index-TSxj);--background-color: var(--background-color-SCOPED-IN-index-TSxj);--on-background-color: var(--on-background-color-SCOPED-IN-index-TSxj)}\n"] }]
|
|
157
157
|
}], propDecorators: { back: [], checkboxClick: [], itemClick: [] } });
|
|
158
158
|
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.page.js","sourceRoot":"","sources":["../../../../../../../packages/@ng-atomic/components/src/lib/pages/_index/index.page.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, Directive, Signal, computed, inject, input, signal } from '@angular/core';\nimport { RouterOutletFrame } from '@ng-atomic/components/frames/router-outlet';\nimport { IndexTemplate } from '@ng-atomic/components/templates/_index';\nimport { injectAll } from '@ng-atomic/common/stores/entities';\nimport { injectModel, injectModelName } from '@ng-atomic/common/pipes/domain';\nimport { Actions, Effect, InjectableComponent, NgAtomicComponent, _computed } from '@ng-atomic/core';\nimport { ActivatedRoute, Router } from '@angular/router';\nimport { buildColumns, injectIndexForm } from '@ng-atomic/components/organisms/table';\nimport { injectIsRootPage, injectNavStartActions, makeConfig } from '@ng-atomic/common/services/ui';\nimport { SelectionModel } from '@angular/cdk/collections';\nimport { injectEntityIdName } from '@ng-atomic/components/pages/form';\nimport { injectChildRouteParam } from \"@ng-atomic/common/utils\";\n\nexport function injectHighlight(key: string): Signal<SelectionModel<string>> {\n  const transferId = injectChildRouteParam(key);\n  return computed(() => new SelectionModel<string>(true, [transferId()]));\n}\n\nenum ActionId {\n  BACK = '[@ng-atomic/components/pages] Back',\n  CHECKBOX_CLICK = '[@ng-atomic/components/pages] CheckboxClick',\n  ADD = '[@ng-atomic/components/pages] Add',\n  DETAIL = '[@ng-atomic/components/pages] Detail',\n}\n\n@Directive({ standalone: true })\nexport class IndexPageStore extends InjectableComponent {\n  static readonly ActionId = ActionId;\n  static readonly Config = makeConfig(() => {\n    const highlight = injectHighlight(injectEntityIdName());\n    const isRootPage = injectIsRootPage();\n    const navStartActions = injectNavStartActions(isRootPage);\n    return () => ({\n      style: {\n        width: 'var(--page-width-lv3)',\n      },\n      items: [],\n      itemActions: () => [] as Actions,\n      title: `${injectModelName()()}一覧`,\n      type: 'table',\n      selection: new SelectionModel<string>(true, []),\n      highlight: highlight(),\n      form: injectIndexForm({\n        columns: buildColumns([\n          'id', \n          'createdAt',\n          'updatedAt',\n          (item: {id: string}) => [{ id: ActionId.DETAIL, icon: 'open_in_new', name: '詳細', payload: item }],\n        ]),\n      }),\n      navStartActions: navStartActions(),\n      navEndActions: [],\n      filterFunc: (item: any) => true,\n    }) as any;\n  }, ['components', 'pages', 'index']);\n  static provideItemsFromRepository = IndexPageStore.Config.provide(() => {\n    const Model = injectModel();\n    const items = Model ? injectAll(Model) : signal([]);\n    return (config) => ({...config, items: items()});\n  });\n\n  readonly config = IndexPageStore.Config.inject();\n  readonly route = inject(ActivatedRoute);\n  readonly type = input(_computed(() => this.config().type));\n  readonly items = input(_computed(() => this.config().items));\n  readonly itemActions = input(_computed(() => this.config().itemActions));\n  readonly title = input(_computed(() => this.config().title));\n  readonly form = input(_computed(() => this.config().form));\n  readonly selection = input(_computed(() => this.config().selection));\n  readonly highlight = input(_computed(() => this.config().highlight));\n  readonly navStartActions = input(_computed(() => this.config().navStartActions));\n  readonly navEndActions = input(_computed(() => this.config().navEndActions));\n  readonly filterFunc = input(_computed(() => this.config().filterFunc));\n  readonly filteredItems = computed(() => this.items().filter(this.filterFunc()));\n}\n\n@Component({\n  selector: 'pages-index',\n  standalone: true,\n  imports: [\n    RouterOutletFrame,\n    IndexTemplate,\n  ],\n  template: `\n  <frames-router-outlet>\n    <templates-index\n      [style.width]=\"store.config().style.width\"\n      [title]=\"store.title()\"\n      [type]=\"store.type()\"\n      [items]=\"store.filteredItems()\"\n      [itemActions]=\"store.itemActions()\"\n      [form]=\"store.form()\"\n      [selection]=\"store.selection()\"\n      [highlight]=\"store.highlight()\"\n      [navStartActions]=\"store.navStartActions()\"\n      [navEndActions]=\"store.navEndActions()\"\n      (action)=\"dispatch($event)\"\n    />\n  </frames-router-outlet>\n  `,\n  styleUrl: './index.page.scss',\n  hostDirectives: [IndexPageStore],\n  // providers: [EffectReducer],\n})\nexport class IndexPage extends NgAtomicComponent {\n  protected store = inject(IndexPageStore);\n  protected router = inject(Router);\n\n  @Effect(IndexTemplate.ActionId.BACK)\n  protected back() {\n    this.dispatch({id: ActionId.BACK});\n  }\n\n  @Effect(IndexTemplate.ActionId.CHECKBOX_CLICK)\n  protected checkboxClick(item: {id: string}) {\n    this.store.selection().toggle(item.id);\n  }\n\n  @Effect(IndexTemplate.ActionId.ITEM_CLICK)\n  protected itemClick(item: {id: string}) {\n    this.dispatch({id: ActionId.DETAIL, payload: item});\n  }\n\n  // @Effect(ActionId.DETAIL)\n  // protected detail(item: {id: string}) {\n  //   this.router.navigate([item?.id ?? 'new'], {relativeTo: this.store.route});\n  // }\n}\n"]}
|