@theseam/ui-common 0.4.22 → 0.4.24-beta.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/breadcrumbs/breadcrumbs/breadcrumbs.component.scss +1 -1
- package/datatable/datatable/datatable.component.d.ts +10 -1
- package/datatable/models/action-item-column-position.d.ts +13 -0
- package/datatable/services/columns-manager.service.d.ts +7 -0
- package/datatable/utils/create-action-menu-column.d.ts +1 -1
- package/esm2020/breadcrumbs/breadcrumbs/breadcrumbs.component.mjs +2 -2
- package/esm2020/datatable/datatable/datatable.component.mjs +20 -4
- package/esm2020/datatable/datatable-action-menu/datatable-action-menu.component.mjs +2 -2
- package/esm2020/datatable/datatable-column-preferences-button/datatable-column-preferences-button.component.mjs +1 -1
- package/esm2020/datatable/datatable-export-button/datatable-export-button.component.mjs +1 -1
- package/esm2020/datatable/models/action-item-column-position.mjs +5 -0
- package/esm2020/datatable/services/columns-manager.service.mjs +27 -2
- package/esm2020/datatable/utils/create-action-menu-column.mjs +4 -3
- package/esm2020/datatable-dynamic/datatable-dynamic-action-menu/datatable-dynamic-action-menu.component.mjs +1 -1
- package/esm2020/datatable-dynamic/datatable-dynamic.component.mjs +1 -1
- package/esm2020/form-field/form-field-required-indicator.component.mjs +22 -7
- package/esm2020/form-field/input.directive.mjs +19 -16
- package/esm2020/form-field/testing/form-field.harness.mjs +45 -0
- package/esm2020/form-field/testing/index.mjs +2 -1
- package/esm2020/framework/base-layout/base-layout.component.mjs +14 -4
- package/esm2020/framework/base-layout/base-layout.module.mjs +6 -1
- package/esm2020/framework/base-layout/directives/base-layout-nav-toggle.directive.mjs +21 -5
- package/esm2020/framework/base-layout/directives/base-layout-side-bar-header.directive.mjs +16 -0
- package/esm2020/framework/base-layout/index.mjs +2 -1
- package/esm2020/framework/nav/horizontal-nav/horizontal-nav.component.mjs +55 -0
- package/esm2020/framework/nav/index.mjs +6 -0
- package/esm2020/framework/nav/nav-item/nav-item.component.mjs +227 -0
- package/esm2020/framework/nav/nav-utils.mjs +107 -0
- package/esm2020/framework/nav/nav.models.mjs +2 -0
- package/esm2020/framework/nav/nav.module.mjs +67 -0
- package/esm2020/framework/nav/nav.service.mjs +204 -0
- package/esm2020/framework/public-api.mjs +2 -1
- package/esm2020/framework/schema-form-controls/schema-form-submit-split/schema-form-submit-split.component.mjs +2 -2
- package/esm2020/framework/side-nav/side-nav-item/side-nav-item.component.mjs +28 -67
- package/esm2020/framework/side-nav/side-nav-toggle/side-nav-toggle.component.mjs +12 -5
- package/esm2020/framework/side-nav/side-nav.component.mjs +116 -38
- package/esm2020/framework/side-nav/side-nav.models.mjs +1 -1
- package/esm2020/framework/side-nav/side-nav.module.mjs +9 -39
- package/esm2020/framework/side-nav/side-nav.service.mjs +1 -1
- package/esm2020/framework/top-bar/index.mjs +3 -1
- package/esm2020/framework/top-bar/top-bar-compact-menu-btn-detail.directive.mjs +16 -0
- package/esm2020/framework/top-bar/top-bar-item.directive.mjs +10 -4
- package/esm2020/framework/top-bar/top-bar-menu-button/top-bar-menu-button.component.mjs +6 -4
- package/esm2020/framework/top-bar/top-bar-nav-toggle-btn-detail.directive.mjs +16 -0
- package/esm2020/framework/top-bar/top-bar.component.mjs +55 -11
- package/esm2020/framework/top-bar/top-bar.module.mjs +15 -5
- package/esm2020/google-maps/google-maps-places-autocomplete/google-maps-places-autocomplete.component.mjs +3 -3
- package/esm2020/layout/layout.service.mjs +12 -2
- package/esm2020/menu/menu-toggle.directive.mjs +7 -2
- package/esm2020/story-helpers/story-modal-container.component.mjs +3 -3
- package/esm2020/tabbed/tabbed.component.mjs +25 -18
- package/esm2020/table-cell-types/table-cell-type-string/table-cell-type-string.component.mjs +4 -2
- package/esm2020/utils/geo-json/coerce-feature-collection.mjs +1 -1
- package/esm2020/utils/geo-json/is-feature-collection.validator.mjs +1 -1
- package/esm2020/utils/geo-json/is-only-geometry-types.mjs +1 -1
- package/esm2020/utils/geo-json/merge-polygons.mjs +1 -1
- package/esm2020/utils/geo-json/no-inner-rings.validator.mjs +1 -1
- package/esm2020/utils/geo-json/split-multi-polygons.mjs +1 -1
- package/fesm2015/theseam-ui-common-breadcrumbs.mjs +2 -2
- package/fesm2015/theseam-ui-common-breadcrumbs.mjs.map +1 -1
- package/fesm2015/theseam-ui-common-datatable-dynamic.mjs +2 -2
- package/fesm2015/theseam-ui-common-datatable-dynamic.mjs.map +1 -1
- package/fesm2015/theseam-ui-common-datatable.mjs +56 -10
- package/fesm2015/theseam-ui-common-datatable.mjs.map +1 -1
- package/fesm2015/theseam-ui-common-form-field.mjs +92 -27
- package/fesm2015/theseam-ui-common-form-field.mjs.map +1 -1
- package/fesm2015/theseam-ui-common-framework.mjs +905 -156
- package/fesm2015/theseam-ui-common-framework.mjs.map +1 -1
- package/fesm2015/theseam-ui-common-google-maps.mjs +2 -2
- package/fesm2015/theseam-ui-common-google-maps.mjs.map +1 -1
- package/fesm2015/theseam-ui-common-layout.mjs +11 -2
- package/fesm2015/theseam-ui-common-layout.mjs.map +1 -1
- package/fesm2015/theseam-ui-common-menu.mjs +6 -1
- package/fesm2015/theseam-ui-common-menu.mjs.map +1 -1
- package/fesm2015/theseam-ui-common-story-helpers.mjs +2 -2
- package/fesm2015/theseam-ui-common-story-helpers.mjs.map +1 -1
- package/fesm2015/theseam-ui-common-tabbed.mjs +26 -19
- package/fesm2015/theseam-ui-common-tabbed.mjs.map +1 -1
- package/fesm2015/theseam-ui-common-table-cell-types.mjs +3 -1
- package/fesm2015/theseam-ui-common-table-cell-types.mjs.map +1 -1
- package/fesm2015/theseam-ui-common-utils.mjs.map +1 -1
- package/fesm2020/theseam-ui-common-breadcrumbs.mjs +2 -2
- package/fesm2020/theseam-ui-common-breadcrumbs.mjs.map +1 -1
- package/fesm2020/theseam-ui-common-datatable-dynamic.mjs +2 -2
- package/fesm2020/theseam-ui-common-datatable-dynamic.mjs.map +1 -1
- package/fesm2020/theseam-ui-common-datatable.mjs +56 -10
- package/fesm2020/theseam-ui-common-datatable.mjs.map +1 -1
- package/fesm2020/theseam-ui-common-form-field.mjs +88 -27
- package/fesm2020/theseam-ui-common-form-field.mjs.map +1 -1
- package/fesm2020/theseam-ui-common-framework.mjs +907 -156
- package/fesm2020/theseam-ui-common-framework.mjs.map +1 -1
- package/fesm2020/theseam-ui-common-google-maps.mjs +2 -2
- package/fesm2020/theseam-ui-common-google-maps.mjs.map +1 -1
- package/fesm2020/theseam-ui-common-layout.mjs +11 -2
- package/fesm2020/theseam-ui-common-layout.mjs.map +1 -1
- package/fesm2020/theseam-ui-common-menu.mjs +6 -1
- package/fesm2020/theseam-ui-common-menu.mjs.map +1 -1
- package/fesm2020/theseam-ui-common-story-helpers.mjs +2 -2
- package/fesm2020/theseam-ui-common-story-helpers.mjs.map +1 -1
- package/fesm2020/theseam-ui-common-tabbed.mjs +24 -17
- package/fesm2020/theseam-ui-common-tabbed.mjs.map +1 -1
- package/fesm2020/theseam-ui-common-table-cell-types.mjs +3 -1
- package/fesm2020/theseam-ui-common-table-cell-types.mjs.map +1 -1
- package/fesm2020/theseam-ui-common-utils.mjs.map +1 -1
- package/form-field/form-field-required-indicator.component.d.ts +6 -1
- package/form-field/input.directive.d.ts +9 -15
- package/form-field/testing/form-field.harness.d.ts +14 -0
- package/form-field/testing/index.d.ts +1 -0
- package/framework/base-layout/base-layout.component.d.ts +4 -2
- package/framework/base-layout/base-layout.component.scss +18 -10
- package/framework/base-layout/base-layout.module.d.ts +11 -10
- package/framework/base-layout/directives/base-layout-nav-toggle.directive.d.ts +8 -3
- package/framework/base-layout/directives/base-layout-side-bar-header.directive.d.ts +9 -0
- package/framework/base-layout/index.d.ts +1 -0
- package/framework/base-layout/styles/_variables.scss +21 -0
- package/framework/nav/_nav-theme.scss +4 -0
- package/framework/nav/horizontal-nav/horizontal-nav.component.d.ts +25 -0
- package/framework/nav/horizontal-nav/horizontal-nav.component.scss +50 -0
- package/framework/nav/index.d.ts +5 -0
- package/framework/nav/nav-item/nav-item.component.d.ts +74 -0
- package/framework/nav/nav-item/nav-item.component.scss +203 -0
- package/framework/nav/nav-utils.d.ts +20 -0
- package/framework/nav/nav.models.d.ts +77 -0
- package/framework/nav/nav.module.d.ts +17 -0
- package/framework/nav/nav.service.d.ts +27 -0
- package/framework/nav/styles/_themes/light/_variables.scss +56 -0
- package/framework/nav/styles/_themes/primary/_variables.scss +56 -0
- package/framework/nav/styles/_utilities.scss +3 -0
- package/framework/nav/styles/_variables.scss +2 -0
- package/framework/public-api.d.ts +1 -0
- package/framework/side-nav/side-nav-item/side-nav-item.component.d.ts +7 -14
- package/framework/side-nav/side-nav-item/side-nav-item.component.scss +7 -5
- package/framework/side-nav/side-nav-toggle/side-nav-toggle.component.d.ts +5 -3
- package/framework/side-nav/side-nav-toggle/side-nav-toggle.component.scss +3 -6
- package/framework/side-nav/side-nav.component.d.ts +13 -1
- package/framework/side-nav/side-nav.component.scss +0 -1
- package/framework/side-nav/side-nav.models.d.ts +7 -1
- package/framework/side-nav/side-nav.module.d.ts +1 -9
- package/framework/side-nav/styles/_themes/light/_variables.scss +24 -14
- package/framework/side-nav/styles/_themes/primary/_variables.scss +8 -0
- package/framework/top-bar/index.d.ts +2 -0
- package/framework/top-bar/top-bar-compact-menu-btn-detail.directive.d.ts +8 -0
- package/framework/top-bar/top-bar-item.directive.d.ts +4 -1
- package/framework/top-bar/top-bar-menu-button/top-bar-menu-button.component.d.ts +5 -2
- package/framework/top-bar/top-bar-nav-toggle-btn-detail.directive.d.ts +8 -0
- package/framework/top-bar/top-bar.component.d.ts +25 -3
- package/framework/top-bar/top-bar.component.scss +7 -2
- package/framework/top-bar/top-bar.module.d.ts +10 -8
- package/layout/layout.service.d.ts +9 -1
- package/menu/menu-toggle.directive.d.ts +2 -1
- package/package.json +2 -2
- package/styles/vendor/ngx-datatable/_ngx-datatable.scss +57 -14
- package/styles/vendor/ngx-datatable/_themes/bootstrap/_variables.scss +33 -5
- package/tabbed/tabbed.component.d.ts +9 -4
|
@@ -88,7 +88,7 @@ export class DatatableExportButtonComponent {
|
|
|
88
88
|
}
|
|
89
89
|
}
|
|
90
90
|
DatatableExportButtonComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.7", ngImport: i0, type: DatatableExportButtonComponent, deps: [{ token: THESEAM_DATATABLE }, { token: i1.ToastrService }, { token: i2.TheSeamLoadingOverlayService }, { token: i3.DynamicValueHelperService }, { token: THESEAM_DYNAMIC_DATA, optional: true }], target: i0.ɵɵFactoryTarget.Component });
|
|
91
|
-
DatatableExportButtonComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.7", type: DatatableExportButtonComponent, selector: "seam-datatable-export-button", inputs: { exporters: "exporters" }, ngImport: i0, template: "<seam-menu #menu>\n <button *ngFor=\"let exp of exporters\"\n seamMenuItem\n [icon]=\"exp?.icon\"\n (click)=\"_onExporterClicked(exp)\">\n {{ exp.label }}\n </button>\n</seam-menu>\n<button\n [seamMenuToggle]=\"menu\"\n seamButton\n theme=\"lightgray\"\n size=\"sm\"\n class=\"dropdown-toggle\"\n style=\"padding-left: 10px; padding-right: 10px;\"\n title=\"Export\"\n [disabled]=\"disabled\"\n >\n <seam-icon [icon]=\"icon\" class=\"mr-2\"></seam-icon>\n</button>\n", styles: [":host{display:inline-block}\n"], dependencies: [{ kind: "directive", type: i4.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "component", type: i5.MenuComponent, selector: "seam-menu", inputs: ["menuClass", "baseWidth", "animationType"], outputs: ["closed"], exportAs: ["seamMenu"] }, { kind: "directive", type: i5.MenuToggleDirective, selector: "[seamMenuToggle]", inputs: ["seamMenuToggle", "positions", "seamMenuTogglePositionsOffsetY"], outputs: ["menuOpened", "menuClosed"], exportAs: ["seamMenuToggle"] }, { kind: "component", type: i5.MenuItemComponent, selector: "[seamMenuItem]", inputs: ["disabled", "role", "icon", "iconClass", "sublevelIcon", "subLevelIconClass", "badgeText", "badgeTheme"], exportAs: ["seamMenuItem"] }, { kind: "component", type: i6.IconComponent, selector: "seam-icon", inputs: ["grayscaleOnDisable", "disabled", "iconClass", "icon", "size", "showDefaultOnError", "defaultIcon", "iconType"] }, { kind: "component", type: i7.TheSeamButtonComponent, selector: "button[seamButton]", inputs: ["disabled", "theme", "size", "type"], exportAs: ["seamButton"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
91
|
+
DatatableExportButtonComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.7", type: DatatableExportButtonComponent, selector: "seam-datatable-export-button", inputs: { exporters: "exporters" }, ngImport: i0, template: "<seam-menu #menu>\n <button *ngFor=\"let exp of exporters\"\n seamMenuItem\n [icon]=\"exp?.icon\"\n (click)=\"_onExporterClicked(exp)\">\n {{ exp.label }}\n </button>\n</seam-menu>\n<button\n [seamMenuToggle]=\"menu\"\n seamButton\n theme=\"lightgray\"\n size=\"sm\"\n class=\"dropdown-toggle\"\n style=\"padding-left: 10px; padding-right: 10px;\"\n title=\"Export\"\n [disabled]=\"disabled\"\n >\n <seam-icon [icon]=\"icon\" class=\"mr-2\"></seam-icon>\n</button>\n", styles: [":host{display:inline-block}\n"], dependencies: [{ kind: "directive", type: i4.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "component", type: i5.MenuComponent, selector: "seam-menu", inputs: ["menuClass", "baseWidth", "animationType"], outputs: ["closed"], exportAs: ["seamMenu"] }, { kind: "directive", type: i5.MenuToggleDirective, selector: "[seamMenuToggle]", inputs: ["seamMenuToggle", "positions", "seamMenuTogglePositionsOffsetY"], outputs: ["menuToggle", "menuOpened", "menuClosed"], exportAs: ["seamMenuToggle"] }, { kind: "component", type: i5.MenuItemComponent, selector: "[seamMenuItem]", inputs: ["disabled", "role", "icon", "iconClass", "sublevelIcon", "subLevelIconClass", "badgeText", "badgeTheme"], exportAs: ["seamMenuItem"] }, { kind: "component", type: i6.IconComponent, selector: "seam-icon", inputs: ["grayscaleOnDisable", "disabled", "iconClass", "icon", "size", "showDefaultOnError", "defaultIcon", "iconType"] }, { kind: "component", type: i7.TheSeamButtonComponent, selector: "button[seamButton]", inputs: ["disabled", "theme", "size", "type"], exportAs: ["seamButton"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
92
92
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.7", ngImport: i0, type: DatatableExportButtonComponent, decorators: [{
|
|
93
93
|
type: Component,
|
|
94
94
|
args: [{ selector: 'seam-datatable-export-button', changeDetection: ChangeDetectionStrategy.OnPush, template: "<seam-menu #menu>\n <button *ngFor=\"let exp of exporters\"\n seamMenuItem\n [icon]=\"exp?.icon\"\n (click)=\"_onExporterClicked(exp)\">\n {{ exp.label }}\n </button>\n</seam-menu>\n<button\n [seamMenuToggle]=\"menu\"\n seamButton\n theme=\"lightgray\"\n size=\"sm\"\n class=\"dropdown-toggle\"\n style=\"padding-left: 10px; padding-right: 10px;\"\n title=\"Export\"\n [disabled]=\"disabled\"\n >\n <seam-icon [icon]=\"icon\" class=\"mr-2\"></seam-icon>\n</button>\n", styles: [":host{display:inline-block}\n"] }]
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
const ActionItemColumnPosition = ['frozenLeft', 'frozenRight', 'staticLeft', 'staticRight'];
|
|
2
|
+
export function isActionItemColumnPosition(input) {
|
|
3
|
+
return ActionItemColumnPosition.indexOf(input) != -1;
|
|
4
|
+
}
|
|
5
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWN0aW9uLWl0ZW0tY29sdW1uLXBvc2l0aW9uLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdWktY29tbW9uL2RhdGF0YWJsZS9tb2RlbHMvYWN0aW9uLWl0ZW0tY29sdW1uLXBvc2l0aW9uLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE1BQU0sd0JBQXdCLEdBQUcsQ0FBQyxZQUFZLEVBQUUsYUFBYSxFQUFFLFlBQVksRUFBRSxhQUFhLENBQVUsQ0FBQTtBQWFwRyxNQUFNLFVBQVUsMEJBQTBCLENBQUMsS0FBYztJQUN2RCxPQUFPLHdCQUF3QixDQUFDLE9BQU8sQ0FBQyxLQUFpQyxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUM7QUFDbkYsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImNvbnN0IEFjdGlvbkl0ZW1Db2x1bW5Qb3NpdGlvbiA9IFsnZnJvemVuTGVmdCcsICdmcm96ZW5SaWdodCcsICdzdGF0aWNMZWZ0JywgJ3N0YXRpY1JpZ2h0J10gYXMgY29uc3RcblxuLyoqXG4gKiBJZiBgZnJvemVuTGVmdGAsIGFjdGlvbiBpdGVtIGNvbHVtbiB3aWxsIGJlIGZpeGVkIHRvIHRoZSBsZWZ0IHNpZGUgb2YgdGhlIHRhYmxlLlxuICpcbiAqIElmIGBmcm96ZW5SaWdodGAsIGFjdGlvbiBpdGVtIGNvbHVtbiB3aWxsIGJlIGZpeGVkIHRvIHRoZSByaWdodCBzaWRlIG9mIHRoZSB0YWJsZS5cbiAqXG4gKiBJZiBgc3RhdGljTGVmdGAsIGFjdGlvbiBpdGVtIGNvbHVtbiB3aWxsIGJlIHRoZSBmaXJzdCBzdGF0aWMgY29sdW1uIG9uIHRoZSBsZWZ0IHNpZGUgb2YgdGhlIHRhYmxlLlxuICpcbiAqIElmIGBzdGF0aWNSaWdodGAsIGFjdGlvbiBpdGVtIGNvbHVtbiB3aWxsIGJlIHRoZSBsYXN0IHN0YXRpYyBjb2x1bW4gb24gdGhlIHJpZ2h0IHNpZGUgb2YgdGhlIHRhYmxlLlxuICovXG5leHBvcnQgdHlwZSBBY3Rpb25JdGVtQ29sdW1uUG9zaXRpb24gPSB0eXBlb2YgQWN0aW9uSXRlbUNvbHVtblBvc2l0aW9uW251bWJlcl07XG5cbmV4cG9ydCBmdW5jdGlvbiBpc0FjdGlvbkl0ZW1Db2x1bW5Qb3NpdGlvbihpbnB1dDogdW5rbm93bik6IGlucHV0IGlzIEFjdGlvbkl0ZW1Db2x1bW5Qb3NpdGlvbiB7XG4gIHJldHVybiBBY3Rpb25JdGVtQ29sdW1uUG9zaXRpb24uaW5kZXhPZihpbnB1dCBhcyBBY3Rpb25JdGVtQ29sdW1uUG9zaXRpb24pICE9IC0xO1xufVxuIl19
|
|
@@ -78,6 +78,13 @@ export class ColumnsManagerService {
|
|
|
78
78
|
this._updateColumns.next(undefined);
|
|
79
79
|
}
|
|
80
80
|
}
|
|
81
|
+
setActionItemColumnPosition(actionItemColumnPosition) {
|
|
82
|
+
const changed = this._actionItemColumnPosition !== actionItemColumnPosition;
|
|
83
|
+
this._actionItemColumnPosition = actionItemColumnPosition;
|
|
84
|
+
if (changed) {
|
|
85
|
+
this._updateColumns.next(undefined);
|
|
86
|
+
}
|
|
87
|
+
}
|
|
81
88
|
setActionMenuCellTpl(actionMenuCellTpl) {
|
|
82
89
|
const changed = this._actionMenuCellTpl !== actionMenuCellTpl;
|
|
83
90
|
this._actionMenuCellTpl = actionMenuCellTpl;
|
|
@@ -156,7 +163,13 @@ export class ColumnsManagerService {
|
|
|
156
163
|
cols.push(_col);
|
|
157
164
|
}
|
|
158
165
|
if (this._shouldAddRowActionColumn()) {
|
|
159
|
-
|
|
166
|
+
const actionMenuColumn = createActionMenuColumn(this._actionMenuCellTpl, this._blankHeaderTpl, this._rowActionColumnIsFrozenLeft(), this._rowActionColumnIsFrozenRight());
|
|
167
|
+
if (this._rowActionColumnIsStaticLeft()) {
|
|
168
|
+
cols.unshift(actionMenuColumn);
|
|
169
|
+
}
|
|
170
|
+
else {
|
|
171
|
+
cols.push(actionMenuColumn);
|
|
172
|
+
}
|
|
160
173
|
}
|
|
161
174
|
// Make sure the default for any missing props are set.
|
|
162
175
|
// TODO: Determine if this should be done earlier, because I don't like
|
|
@@ -242,6 +255,18 @@ export class ColumnsManagerService {
|
|
|
242
255
|
_shouldAddRowActionColumn() {
|
|
243
256
|
return this._rowActionItem !== undefined;
|
|
244
257
|
}
|
|
258
|
+
_rowActionColumnIsFrozenLeft() {
|
|
259
|
+
return this._actionItemColumnPosition === 'frozenLeft';
|
|
260
|
+
}
|
|
261
|
+
_rowActionColumnIsFrozenRight() {
|
|
262
|
+
return this._actionItemColumnPosition === 'frozenRight';
|
|
263
|
+
}
|
|
264
|
+
_rowActionColumnIsStaticLeft() {
|
|
265
|
+
return this._actionItemColumnPosition === 'staticLeft';
|
|
266
|
+
}
|
|
267
|
+
_rowActionColumnIsStaticRight() {
|
|
268
|
+
return this._actionItemColumnPosition === 'staticRight';
|
|
269
|
+
}
|
|
245
270
|
_shouldAddTreeToggleColumn(column) {
|
|
246
271
|
return column.isTreeColumn !== undefined && column.isTreeColumn &&
|
|
247
272
|
(!hasProperty(column, 'treeToggleTemplate') || !notNullOrUndefined(column.treeToggleTemplate));
|
|
@@ -258,4 +283,4 @@ ColumnsManagerService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0"
|
|
|
258
283
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.7", ngImport: i0, type: ColumnsManagerService, decorators: [{
|
|
259
284
|
type: Injectable
|
|
260
285
|
}], ctorParameters: function () { return [{ type: i0.KeyValueDiffers }, { type: i1.DatatableColumnChangesService }]; } });
|
|
261
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"columns-manager.service.js","sourceRoot":"","sources":["../../../../../projects/ui-common/datatable/services/columns-manager.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, KeyValueChanges, KeyValueDiffer, KeyValueDiffers, TemplateRef } from '@angular/core'\nimport { BehaviorSubject, combineLatest, defer, EMPTY, Observable, of, Subject } from 'rxjs'\nimport { auditTime, map, shareReplay, startWith, switchMap } from 'rxjs/operators'\n\nimport {\n  DataTableColumnCellTreeToggle,\n  DataTableColumnDirective,\n  DataTableColumnHeaderDirective,\n  SelectionType,\n  TableColumn,\n  TableColumnProp,\n} from '@marklb/ngx-datatable'\n\nimport { hasProperty, notNullOrUndefined } from '@theseam/ui-common/utils'\n\nimport { DatatableColumnComponent } from '../datatable-column/datatable-column.component'\nimport { DatatableRowActionItemDirective } from '../directives/datatable-row-action-item.directive'\nimport { TheSeamDatatableColumn } from '../models/table-column'\nimport { createActionMenuColumn } from '../utils/create-action-menu-column'\nimport { createCheckboxColumn } from '../utils/create-checkbox-column'\nimport { getColumnProp } from '../utils/get-column-prop'\nimport { setColumnDefaults } from '../utils/set-column-defaults'\nimport { translateTemplateColumns } from '../utils/translate-templates'\nimport { DatatableColumnChangesService } from './datatable-column-changes.service'\n\nenum ColumnsTypes {\n  Input,\n  Template,\n  Result,\n}\n\nexport type InternalColumnsGetter = () => TableColumn[]\n\n@Injectable()\nexport class ColumnsManagerService {\n  private readonly _updateColumns = new Subject<void>()\n\n  private readonly _inputColumns = new BehaviorSubject<TheSeamDatatableColumn[]>([])\n  private readonly _templateColumns = new BehaviorSubject<DatatableColumnComponent[]>([])\n\n  private readonly _inpColDiffersMap = new Map<TableColumnProp, KeyValueDiffer<any, any>>()\n  private readonly _tplColDiffersMap = new Map<TableColumnProp, KeyValueDiffer<any, any>>()\n  private readonly _resultColDiffersMap = new Map<TableColumnProp, KeyValueDiffer<any, any>>()\n  private _colPropsDiffer?: KeyValueDiffer<any, any>\n\n  private _internalColumnsGetter?: InternalColumnsGetter\n\n  private _selectionType: SelectionType | undefined\n  private _rowActionItem: DatatableRowActionItemDirective | undefined\n  private _actionMenuCellTpl: TemplateRef<DataTableColumnDirective> | undefined\n  private _blankHeaderTpl: TemplateRef<DataTableColumnHeaderDirective> | undefined\n  private _treeToggleTpl: TemplateRef<DataTableColumnCellTreeToggle> | undefined\n  private _headerTpl: TemplateRef<DataTableColumnHeaderDirective> | undefined\n  private _cellTypeSelectorTpl: TemplateRef<DataTableColumnDirective> | undefined\n\n  // TODO: Consider making this a columns changed obervable, to make changes more predictable.\n  public readonly columns$: Observable<TheSeamDatatableColumn[]>\n\n  constructor(\n    private readonly _differs: KeyValueDiffers,\n    private readonly _columnChangesService: DatatableColumnChangesService,\n  ) {\n    const templateColumns$ = this._columnChangesService.columnInputChanges$.pipe(\n      startWith(undefined),\n      switchMap(() => {\n        return this._templateColumns.asObservable().pipe(map(translateTemplateColumns))\n      })\n    )\n\n    this.columns$ = defer(() => {\n      let isFirst = true\n      return combineLatest([\n        this._inputColumns.asObservable(),\n        templateColumns$,\n        this._updateColumns.asObservable().pipe(auditTime(0), startWith(undefined))\n      ]).pipe(\n        switchMap(([ inputColumns, templateColumns ]) => {\n          const cols = this._mergeColumns(inputColumns, templateColumns)\n\n          const hasColumnsChanged = this._hasColumnsChanged(cols)\n\n          // TODO: Look for columns added/removed and remove the removed columns\n          // differs, not just changes to columns.\n          const hasAddedOrRemovedColumns = this._hasAddedOrRemovedColumns(cols)\n\n          // NOTE: Both checks need to be run, even though only one needs to be\n          // true, because their differs need to be called.\n          if (hasColumnsChanged || hasAddedOrRemovedColumns || isFirst) {\n            isFirst = false\n            return of(cols)\n          }\n\n          return EMPTY\n        }),\n      )\n    }).pipe(\n      shareReplay({ refCount: true, bufferSize: 1 })\n    )\n  }\n\n  public setInputColumns(columns: TheSeamDatatableColumn[]): void {\n    this._inputColumns.next(columns)\n  }\n\n  public setTemplateColumns(columns: DatatableColumnComponent[]): void {\n    this._templateColumns.next(columns)\n  }\n\n  public setInternalColumnsGetter(getter: InternalColumnsGetter | null): void {\n    this._internalColumnsGetter = getter || undefined\n    this._updateColumns.next(undefined)\n  }\n\n  public setSelectionType(selectionType: SelectionType | undefined): void {\n    const changed = this._selectionType !== selectionType\n    this._selectionType = selectionType\n    if (changed) {\n      this._updateColumns.next(undefined)\n    }\n  }\n\n  public getSelectionType(): SelectionType | undefined {\n    return this._selectionType\n  }\n\n  public setRowActionItem(rowActionItem: DatatableRowActionItemDirective | undefined): void {\n    const changed = this._rowActionItem !== rowActionItem\n    this._rowActionItem = rowActionItem\n    if (changed) {\n      this._updateColumns.next(undefined)\n    }\n  }\n\n  public setActionMenuCellTpl(actionMenuCellTpl: TemplateRef<DataTableColumnDirective> | undefined): void {\n    const changed = this._actionMenuCellTpl !== actionMenuCellTpl\n    this._actionMenuCellTpl = actionMenuCellTpl\n    if (changed) {\n      this._updateColumns.next(undefined)\n    }\n  }\n\n  public setBlankHeaderTpl(blankHeaderTpl: TemplateRef<DataTableColumnHeaderDirective> | undefined): void {\n    const changed = this._blankHeaderTpl !== blankHeaderTpl\n    this._blankHeaderTpl = blankHeaderTpl\n    if (changed) {\n      this._updateColumns.next(undefined)\n    }\n  }\n\n  public setTreeToggleTpl(treeToggleTpl: TemplateRef<DataTableColumnCellTreeToggle> | undefined): void {\n    const changed = this._treeToggleTpl !== treeToggleTpl\n    this._treeToggleTpl = treeToggleTpl\n    if (changed) {\n      this._updateColumns.next(undefined)\n    }\n  }\n\n  public setHeaderTpl(headerTpl: TemplateRef<DataTableColumnHeaderDirective> | undefined): void {\n    const changed = this._headerTpl !== headerTpl\n    this._headerTpl = headerTpl\n    if (changed) {\n      this._updateColumns.next(undefined)\n    }\n  }\n\n  public setCellTypeSelectorTpl(cellTypeSelectorTpl: TemplateRef<DataTableColumnDirective> | undefined): void {\n    const changed = this._cellTypeSelectorTpl !== cellTypeSelectorTpl\n    this._cellTypeSelectorTpl = cellTypeSelectorTpl\n    if (changed) {\n      this._updateColumns.next(undefined)\n    }\n  }\n\n  private _mergeColumns(\n    inputColumns: TheSeamDatatableColumn[],\n    templateColumns: DatatableColumnComponent[]\n  ): TheSeamDatatableColumn[] {\n    const cols: TheSeamDatatableColumn[] = []\n\n    // Add the first column checkbox if 'checkbox' selection is enabled.\n    if (this._shouldAddCheckboxColumn()) {\n      cols.push(createCheckboxColumn())\n    }\n\n    // Column needs to be provided in the inputColumns, so iterate the\n    // inputColumns.\n    for (const inpCol of inputColumns) {\n      const prop = getColumnProp(inpCol)\n      if (!notNullOrUndefined(prop)) {\n        throw Error(`Column may have 'prop' or 'name' defined.`)\n      }\n\n      const internalCol = this._getInternalColumn(prop)\n\n      const inpColDif = this._getColDif(inpCol, ColumnsTypes.Input)\n      if (notNullOrUndefined(inpColDif)) {\n        this._updateColDif(inpColDif, internalCol, inpCol)\n      }\n\n      const tplCol = this._findColumnByProp(prop, templateColumns)\n      if (tplCol !== undefined) {\n        const tplColDif = this._getColDif(tplCol, ColumnsTypes.Template)\n        if (notNullOrUndefined(tplColDif)) {\n          this._updateColDif(tplColDif, internalCol, tplCol)\n        }\n      }\n\n      const _col: TheSeamDatatableColumn = {\n        ...(internalCol || {}),\n        ...inpCol,\n        // TODO: Rethink this, because I don't know if this is correct.\n        ...(tplCol as any || {})\n      }\n\n      if (this._shouldAddTreeToggleColumn(_col)) {\n        _col.treeToggleTemplate = this._treeToggleTpl\n      }\n\n      if (this._shouldAddHeaderTemplate(_col)) {\n        _col.headerTemplate = this._headerTpl\n      }\n\n      if (this._shouldAddCellTypeSelectorTpl(_col)) {\n        _col.cellTemplate = this._cellTypeSelectorTpl\n      }\n\n      cols.push(_col)\n    }\n\n    if (this._shouldAddRowActionColumn()) {\n      cols.push(createActionMenuColumn(this._actionMenuCellTpl, this._blankHeaderTpl))\n    }\n\n    // Make sure the default for any missing props are set.\n    // TODO: Determine if this should be done earlier, because I don't like\n    // how this is done after dif checks.\n    setColumnDefaults(cols)\n\n    return cols\n  }\n\n  private _getInternalColumns(): TableColumn[] | undefined {\n    if (this._internalColumnsGetter === undefined) {\n      return undefined\n    }\n\n    return this._internalColumnsGetter()\n  }\n\n  private _getInternalColumn(prop: TableColumnProp): TableColumn | undefined {\n    const internalCols = this._getInternalColumns()\n\n    if (internalCols === undefined) {\n      return undefined\n    }\n\n    return internalCols.find(c => getColumnProp(c) === prop)\n  }\n\n  private _findColumnByProp<T extends TheSeamDatatableColumn | DatatableColumnComponent>(\n    prop: TableColumnProp,\n    columns: T[]\n  ): T | undefined {\n    return columns.find(c => getColumnProp(c) === prop)\n  }\n\n  private _getDifMapForColumnsType(columnsType: ColumnsTypes): Map<TableColumnProp, KeyValueDiffer<any, any>> {\n    switch (columnsType) {\n      case ColumnsTypes.Input: return this._inpColDiffersMap\n      case ColumnsTypes.Template: return this._tplColDiffersMap\n      case ColumnsTypes.Result: return this._resultColDiffersMap\n    }\n  }\n\n  private _getColumnDiffer(prop: TableColumnProp, colsType: ColumnsTypes): KeyValueDiffer<string, any> {\n    const difMap = this._getDifMapForColumnsType(colsType)\n    if (difMap === null) {\n      throw Error(`Invalid columns type.`)\n    }\n\n    if (!difMap.has(prop)) {\n      difMap.set(prop, this._differs.find({}).create())\n    }\n\n    const differ = difMap.get(prop)\n    if (differ === undefined) {\n      throw Error(`Differ not found. New differ should have been created.`)\n    }\n\n    return differ\n  }\n\n  private _getColDif(\n    col: TheSeamDatatableColumn | DatatableColumnComponent,\n    colsType: ColumnsTypes\n  ): KeyValueChanges<string, any> | null {\n    const prop = getColumnProp(col)\n    if (prop === undefined) {\n      throw Error(`Column prop not found.`)\n    }\n\n    return this._getColumnDiffer(prop, colsType).diff(col)\n  }\n\n  private _updateColDif(\n    colDif: KeyValueChanges<string, any>,\n    internalColumn: TableColumn | undefined,\n    col: TheSeamDatatableColumn | DatatableColumnComponent\n  ): void {\n    colDif.forEachRemovedItem(r => {\n      if (internalColumn && Object.prototype.hasOwnProperty.call(internalColumn, r.key)) {\n        const k = r.key as keyof TableColumn\n        delete internalColumn[k]\n      }\n    })\n    colDif.forEachAddedItem(r => (col as any)[r.key] = r.currentValue)\n    colDif.forEachChangedItem(r => (col as any)[r.key] = r.currentValue)\n  }\n\n  private _hasAddedOrRemovedColumns(columns: TheSeamDatatableColumn[]): boolean {\n    if (!this._colPropsDiffer) {\n      this._colPropsDiffer = this._differs.find([]).create()\n    }\n\n    const props = columns.map(c => getColumnProp(c))\n    return this._colPropsDiffer.diff(props) !== null\n  }\n\n  private _hasColumnsChanged(columns: TheSeamDatatableColumn[]): boolean {\n    let colChanged = false\n    for (const col of columns) {\n      const resultDif = this._getColDif(col, ColumnsTypes.Result)\n      if (resultDif) {\n        // NOTE: Can't return early, because the differs need to be updated.\n        colChanged = true\n      }\n    }\n    return colChanged\n  }\n\n  private _shouldAddCheckboxColumn(): boolean {\n    return this._selectionType === SelectionType.checkbox\n  }\n\n  private _shouldAddRowActionColumn(): boolean {\n    return this._rowActionItem !== undefined\n  }\n\n  private _shouldAddTreeToggleColumn(column: TheSeamDatatableColumn): boolean {\n    return column.isTreeColumn !== undefined && column.isTreeColumn &&\n      (!hasProperty(column, 'treeToggleTemplate') || !notNullOrUndefined(column.treeToggleTemplate))\n  }\n\n  private _shouldAddHeaderTemplate(column: TheSeamDatatableColumn): boolean {\n    return !hasProperty(column, 'headerTemplate')\n  }\n\n  private _shouldAddCellTypeSelectorTpl(column: TheSeamDatatableColumn): boolean {\n    return hasProperty(column, 'cellType')\n  }\n\n}\n"]}
|
|
286
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"columns-manager.service.js","sourceRoot":"","sources":["../../../../../projects/ui-common/datatable/services/columns-manager.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, KeyValueChanges, KeyValueDiffer, KeyValueDiffers, TemplateRef } from '@angular/core'\nimport { BehaviorSubject, combineLatest, defer, EMPTY, Observable, of, Subject } from 'rxjs'\nimport { auditTime, map, shareReplay, startWith, switchMap } from 'rxjs/operators'\n\nimport {\n  DataTableColumnCellTreeToggle,\n  DataTableColumnDirective,\n  DataTableColumnHeaderDirective,\n  SelectionType,\n  TableColumn,\n  TableColumnProp,\n} from '@marklb/ngx-datatable'\n\nimport { hasProperty, notNullOrUndefined } from '@theseam/ui-common/utils'\n\nimport { DatatableColumnComponent } from '../datatable-column/datatable-column.component'\nimport { DatatableRowActionItemDirective } from '../directives/datatable-row-action-item.directive'\nimport { TheSeamDatatableColumn } from '../models/table-column'\nimport { createActionMenuColumn } from '../utils/create-action-menu-column'\nimport { createCheckboxColumn } from '../utils/create-checkbox-column'\nimport { getColumnProp } from '../utils/get-column-prop'\nimport { setColumnDefaults } from '../utils/set-column-defaults'\nimport { translateTemplateColumns } from '../utils/translate-templates'\nimport { DatatableColumnChangesService } from './datatable-column-changes.service'\nimport { ActionItemColumnPosition } from '../models/action-item-column-position'\n\nenum ColumnsTypes {\n  Input,\n  Template,\n  Result,\n}\n\nexport type InternalColumnsGetter = () => TableColumn[]\n\n@Injectable()\nexport class ColumnsManagerService {\n  private readonly _updateColumns = new Subject<void>()\n\n  private readonly _inputColumns = new BehaviorSubject<TheSeamDatatableColumn[]>([])\n  private readonly _templateColumns = new BehaviorSubject<DatatableColumnComponent[]>([])\n\n  private readonly _inpColDiffersMap = new Map<TableColumnProp, KeyValueDiffer<any, any>>()\n  private readonly _tplColDiffersMap = new Map<TableColumnProp, KeyValueDiffer<any, any>>()\n  private readonly _resultColDiffersMap = new Map<TableColumnProp, KeyValueDiffer<any, any>>()\n  private _colPropsDiffer?: KeyValueDiffer<any, any>\n\n  private _internalColumnsGetter?: InternalColumnsGetter\n\n  private _selectionType: SelectionType | undefined\n  private _rowActionItem: DatatableRowActionItemDirective | undefined\n  private _actionMenuCellTpl: TemplateRef<DataTableColumnDirective> | undefined\n  private _actionItemColumnPosition: ActionItemColumnPosition | undefined\n  private _blankHeaderTpl: TemplateRef<DataTableColumnHeaderDirective> | undefined\n  private _treeToggleTpl: TemplateRef<DataTableColumnCellTreeToggle> | undefined\n  private _headerTpl: TemplateRef<DataTableColumnHeaderDirective> | undefined\n  private _cellTypeSelectorTpl: TemplateRef<DataTableColumnDirective> | undefined\n\n  // TODO: Consider making this a columns changed obervable, to make changes more predictable.\n  public readonly columns$: Observable<TheSeamDatatableColumn[]>\n\n  constructor(\n    private readonly _differs: KeyValueDiffers,\n    private readonly _columnChangesService: DatatableColumnChangesService,\n  ) {\n    const templateColumns$ = this._columnChangesService.columnInputChanges$.pipe(\n      startWith(undefined),\n      switchMap(() => {\n        return this._templateColumns.asObservable().pipe(map(translateTemplateColumns))\n      })\n    )\n\n    this.columns$ = defer(() => {\n      let isFirst = true\n      return combineLatest([\n        this._inputColumns.asObservable(),\n        templateColumns$,\n        this._updateColumns.asObservable().pipe(auditTime(0), startWith(undefined))\n      ]).pipe(\n        switchMap(([ inputColumns, templateColumns ]) => {\n          const cols = this._mergeColumns(inputColumns, templateColumns)\n\n          const hasColumnsChanged = this._hasColumnsChanged(cols)\n\n          // TODO: Look for columns added/removed and remove the removed columns\n          // differs, not just changes to columns.\n          const hasAddedOrRemovedColumns = this._hasAddedOrRemovedColumns(cols)\n\n          // NOTE: Both checks need to be run, even though only one needs to be\n          // true, because their differs need to be called.\n          if (hasColumnsChanged || hasAddedOrRemovedColumns || isFirst) {\n            isFirst = false\n            return of(cols)\n          }\n\n          return EMPTY\n        }),\n      )\n    }).pipe(\n      shareReplay({ refCount: true, bufferSize: 1 })\n    )\n  }\n\n  public setInputColumns(columns: TheSeamDatatableColumn[]): void {\n    this._inputColumns.next(columns)\n  }\n\n  public setTemplateColumns(columns: DatatableColumnComponent[]): void {\n    this._templateColumns.next(columns)\n  }\n\n  public setInternalColumnsGetter(getter: InternalColumnsGetter | null): void {\n    this._internalColumnsGetter = getter || undefined\n    this._updateColumns.next(undefined)\n  }\n\n  public setSelectionType(selectionType: SelectionType | undefined): void {\n    const changed = this._selectionType !== selectionType\n    this._selectionType = selectionType\n    if (changed) {\n      this._updateColumns.next(undefined)\n    }\n  }\n\n  public getSelectionType(): SelectionType | undefined {\n    return this._selectionType\n  }\n\n  public setRowActionItem(rowActionItem: DatatableRowActionItemDirective | undefined): void {\n    const changed = this._rowActionItem !== rowActionItem\n    this._rowActionItem = rowActionItem\n    if (changed) {\n      this._updateColumns.next(undefined)\n    }\n  }\n\n  public setActionItemColumnPosition(actionItemColumnPosition: ActionItemColumnPosition | undefined) {\n    const changed = this._actionItemColumnPosition !== actionItemColumnPosition\n    this._actionItemColumnPosition = actionItemColumnPosition\n    if (changed) {\n      this._updateColumns.next(undefined)\n    }\n  }\n\n  public setActionMenuCellTpl(actionMenuCellTpl: TemplateRef<DataTableColumnDirective> | undefined): void {\n    const changed = this._actionMenuCellTpl !== actionMenuCellTpl\n    this._actionMenuCellTpl = actionMenuCellTpl\n    if (changed) {\n      this._updateColumns.next(undefined)\n    }\n  }\n\n  public setBlankHeaderTpl(blankHeaderTpl: TemplateRef<DataTableColumnHeaderDirective> | undefined): void {\n    const changed = this._blankHeaderTpl !== blankHeaderTpl\n    this._blankHeaderTpl = blankHeaderTpl\n    if (changed) {\n      this._updateColumns.next(undefined)\n    }\n  }\n\n  public setTreeToggleTpl(treeToggleTpl: TemplateRef<DataTableColumnCellTreeToggle> | undefined): void {\n    const changed = this._treeToggleTpl !== treeToggleTpl\n    this._treeToggleTpl = treeToggleTpl\n    if (changed) {\n      this._updateColumns.next(undefined)\n    }\n  }\n\n  public setHeaderTpl(headerTpl: TemplateRef<DataTableColumnHeaderDirective> | undefined): void {\n    const changed = this._headerTpl !== headerTpl\n    this._headerTpl = headerTpl\n    if (changed) {\n      this._updateColumns.next(undefined)\n    }\n  }\n\n  public setCellTypeSelectorTpl(cellTypeSelectorTpl: TemplateRef<DataTableColumnDirective> | undefined): void {\n    const changed = this._cellTypeSelectorTpl !== cellTypeSelectorTpl\n    this._cellTypeSelectorTpl = cellTypeSelectorTpl\n    if (changed) {\n      this._updateColumns.next(undefined)\n    }\n  }\n\n  private _mergeColumns(\n    inputColumns: TheSeamDatatableColumn[],\n    templateColumns: DatatableColumnComponent[]\n  ): TheSeamDatatableColumn[] {\n    const cols: TheSeamDatatableColumn[] = []\n\n    // Add the first column checkbox if 'checkbox' selection is enabled.\n    if (this._shouldAddCheckboxColumn()) {\n      cols.push(createCheckboxColumn())\n    }\n\n    // Column needs to be provided in the inputColumns, so iterate the\n    // inputColumns.\n    for (const inpCol of inputColumns) {\n      const prop = getColumnProp(inpCol)\n      if (!notNullOrUndefined(prop)) {\n        throw Error(`Column may have 'prop' or 'name' defined.`)\n      }\n\n      const internalCol = this._getInternalColumn(prop)\n\n      const inpColDif = this._getColDif(inpCol, ColumnsTypes.Input)\n      if (notNullOrUndefined(inpColDif)) {\n        this._updateColDif(inpColDif, internalCol, inpCol)\n      }\n\n      const tplCol = this._findColumnByProp(prop, templateColumns)\n      if (tplCol !== undefined) {\n        const tplColDif = this._getColDif(tplCol, ColumnsTypes.Template)\n        if (notNullOrUndefined(tplColDif)) {\n          this._updateColDif(tplColDif, internalCol, tplCol)\n        }\n      }\n\n      const _col: TheSeamDatatableColumn = {\n        ...(internalCol || {}),\n        ...inpCol,\n        // TODO: Rethink this, because I don't know if this is correct.\n        ...(tplCol as any || {})\n      }\n\n      if (this._shouldAddTreeToggleColumn(_col)) {\n        _col.treeToggleTemplate = this._treeToggleTpl\n      }\n\n      if (this._shouldAddHeaderTemplate(_col)) {\n        _col.headerTemplate = this._headerTpl\n      }\n\n      if (this._shouldAddCellTypeSelectorTpl(_col)) {\n        _col.cellTemplate = this._cellTypeSelectorTpl\n      }\n\n      cols.push(_col)\n    }\n\n    if (this._shouldAddRowActionColumn()) {\n      const actionMenuColumn = createActionMenuColumn(this._actionMenuCellTpl, this._blankHeaderTpl, this._rowActionColumnIsFrozenLeft(), this._rowActionColumnIsFrozenRight())\n\n      if (this._rowActionColumnIsStaticLeft()) {\n        cols.unshift(actionMenuColumn)\n      } else {\n        cols.push(actionMenuColumn)\n      }\n    }\n\n    // Make sure the default for any missing props are set.\n    // TODO: Determine if this should be done earlier, because I don't like\n    // how this is done after dif checks.\n    setColumnDefaults(cols)\n\n    return cols\n  }\n\n  private _getInternalColumns(): TableColumn[] | undefined {\n    if (this._internalColumnsGetter === undefined) {\n      return undefined\n    }\n\n    return this._internalColumnsGetter()\n  }\n\n  private _getInternalColumn(prop: TableColumnProp): TableColumn | undefined {\n    const internalCols = this._getInternalColumns()\n\n    if (internalCols === undefined) {\n      return undefined\n    }\n\n    return internalCols.find(c => getColumnProp(c) === prop)\n  }\n\n  private _findColumnByProp<T extends TheSeamDatatableColumn | DatatableColumnComponent>(\n    prop: TableColumnProp,\n    columns: T[]\n  ): T | undefined {\n    return columns.find(c => getColumnProp(c) === prop)\n  }\n\n  private _getDifMapForColumnsType(columnsType: ColumnsTypes): Map<TableColumnProp, KeyValueDiffer<any, any>> {\n    switch (columnsType) {\n      case ColumnsTypes.Input: return this._inpColDiffersMap\n      case ColumnsTypes.Template: return this._tplColDiffersMap\n      case ColumnsTypes.Result: return this._resultColDiffersMap\n    }\n  }\n\n  private _getColumnDiffer(prop: TableColumnProp, colsType: ColumnsTypes): KeyValueDiffer<string, any> {\n    const difMap = this._getDifMapForColumnsType(colsType)\n    if (difMap === null) {\n      throw Error(`Invalid columns type.`)\n    }\n\n    if (!difMap.has(prop)) {\n      difMap.set(prop, this._differs.find({}).create())\n    }\n\n    const differ = difMap.get(prop)\n    if (differ === undefined) {\n      throw Error(`Differ not found. New differ should have been created.`)\n    }\n\n    return differ\n  }\n\n  private _getColDif(\n    col: TheSeamDatatableColumn | DatatableColumnComponent,\n    colsType: ColumnsTypes\n  ): KeyValueChanges<string, any> | null {\n    const prop = getColumnProp(col)\n    if (prop === undefined) {\n      throw Error(`Column prop not found.`)\n    }\n\n    return this._getColumnDiffer(prop, colsType).diff(col)\n  }\n\n  private _updateColDif(\n    colDif: KeyValueChanges<string, any>,\n    internalColumn: TableColumn | undefined,\n    col: TheSeamDatatableColumn | DatatableColumnComponent\n  ): void {\n    colDif.forEachRemovedItem(r => {\n      if (internalColumn && Object.prototype.hasOwnProperty.call(internalColumn, r.key)) {\n        const k = r.key as keyof TableColumn\n        delete internalColumn[k]\n      }\n    })\n    colDif.forEachAddedItem(r => (col as any)[r.key] = r.currentValue)\n    colDif.forEachChangedItem(r => (col as any)[r.key] = r.currentValue)\n  }\n\n  private _hasAddedOrRemovedColumns(columns: TheSeamDatatableColumn[]): boolean {\n    if (!this._colPropsDiffer) {\n      this._colPropsDiffer = this._differs.find([]).create()\n    }\n\n    const props = columns.map(c => getColumnProp(c))\n    return this._colPropsDiffer.diff(props) !== null\n  }\n\n  private _hasColumnsChanged(columns: TheSeamDatatableColumn[]): boolean {\n    let colChanged = false\n    for (const col of columns) {\n      const resultDif = this._getColDif(col, ColumnsTypes.Result)\n      if (resultDif) {\n        // NOTE: Can't return early, because the differs need to be updated.\n        colChanged = true\n      }\n    }\n    return colChanged\n  }\n\n  private _shouldAddCheckboxColumn(): boolean {\n    return this._selectionType === SelectionType.checkbox\n  }\n\n  private _shouldAddRowActionColumn(): boolean {\n    return this._rowActionItem !== undefined\n  }\n\n  private _rowActionColumnIsFrozenLeft(): boolean {\n    return this._actionItemColumnPosition === 'frozenLeft'\n  }\n\n  private _rowActionColumnIsFrozenRight(): boolean {\n    return this._actionItemColumnPosition === 'frozenRight'\n  }\n\n  private _rowActionColumnIsStaticLeft(): boolean {\n    return this._actionItemColumnPosition === 'staticLeft'\n  }\n\n  private _rowActionColumnIsStaticRight(): boolean {\n    return this._actionItemColumnPosition === 'staticRight'\n  }\n\n  private _shouldAddTreeToggleColumn(column: TheSeamDatatableColumn): boolean {\n    return column.isTreeColumn !== undefined && column.isTreeColumn &&\n      (!hasProperty(column, 'treeToggleTemplate') || !notNullOrUndefined(column.treeToggleTemplate))\n  }\n\n  private _shouldAddHeaderTemplate(column: TheSeamDatatableColumn): boolean {\n    return !hasProperty(column, 'headerTemplate')\n  }\n\n  private _shouldAddCellTypeSelectorTpl(column: TheSeamDatatableColumn): boolean {\n    return hasProperty(column, 'cellType')\n  }\n\n}\n"]}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
export const ACTION_MENU_COLUMN_PROP = '$$__actionMenu__';
|
|
2
|
-
export function createActionMenuColumn(cellTemplate, headerTemplate) {
|
|
2
|
+
export function createActionMenuColumn(cellTemplate, headerTemplate, frozenLeft, frozenRight) {
|
|
3
3
|
return {
|
|
4
4
|
prop: ACTION_MENU_COLUMN_PROP,
|
|
5
5
|
name: '',
|
|
@@ -10,9 +10,10 @@ export function createActionMenuColumn(cellTemplate, headerTemplate) {
|
|
|
10
10
|
sortable: false,
|
|
11
11
|
draggable: false,
|
|
12
12
|
// TODO: Fix column auto sizing with fixed column and cell overlay before enabling.
|
|
13
|
-
|
|
13
|
+
frozenLeft: frozenLeft,
|
|
14
|
+
frozenRight: frozenRight,
|
|
14
15
|
cellTemplate,
|
|
15
16
|
headerTemplate,
|
|
16
17
|
};
|
|
17
18
|
}
|
|
18
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
19
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3JlYXRlLWFjdGlvbi1tZW51LWNvbHVtbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3VpLWNvbW1vbi9kYXRhdGFibGUvdXRpbHMvY3JlYXRlLWFjdGlvbi1tZW51LWNvbHVtbi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFFQSxNQUFNLENBQUMsTUFBTSx1QkFBdUIsR0FBRyxrQkFBa0IsQ0FBQTtBQUV6RCxNQUFNLFVBQVUsc0JBQXNCLENBQ3BDLFlBQWlCLEVBQ2pCLGNBQW1CLEVBQ25CLFVBQW9CLEVBQ3BCLFdBQXFCO0lBRXJCLE9BQU87UUFDTCxJQUFJLEVBQUUsdUJBQXVCO1FBQzdCLElBQUksRUFBRSxFQUFFO1FBQ1IsS0FBSyxFQUFFLEVBQUU7UUFDVCxRQUFRLEVBQUUsRUFBRTtRQUNaLFFBQVEsRUFBRSxFQUFFO1FBQ1osVUFBVSxFQUFFLEtBQUs7UUFDakIsUUFBUSxFQUFFLEtBQUs7UUFDZixTQUFTLEVBQUUsS0FBSztRQUNoQixtRkFBbUY7UUFDbkYsVUFBVSxFQUFFLFVBQVU7UUFDdEIsV0FBVyxFQUFFLFdBQVc7UUFDeEIsWUFBWTtRQUNaLGNBQWM7S0FDZixDQUFBO0FBQ0gsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFRoZVNlYW1EYXRhdGFibGVDb2x1bW4gfSBmcm9tICcuLi9tb2RlbHMvdGFibGUtY29sdW1uJ1xuXG5leHBvcnQgY29uc3QgQUNUSU9OX01FTlVfQ09MVU1OX1BST1AgPSAnJCRfX2FjdGlvbk1lbnVfXydcblxuZXhwb3J0IGZ1bmN0aW9uIGNyZWF0ZUFjdGlvbk1lbnVDb2x1bW4oXG4gIGNlbGxUZW1wbGF0ZTogYW55LFxuICBoZWFkZXJUZW1wbGF0ZTogYW55LFxuICBmcm96ZW5MZWZ0PzogYm9vbGVhbixcbiAgZnJvemVuUmlnaHQ/OiBib29sZWFuXG4pOiBUaGVTZWFtRGF0YXRhYmxlQ29sdW1uIHtcbiAgcmV0dXJuIHtcbiAgICBwcm9wOiBBQ1RJT05fTUVOVV9DT0xVTU5fUFJPUCxcbiAgICBuYW1lOiAnJyxcbiAgICB3aWR0aDogNTAsXG4gICAgbWluV2lkdGg6IDUwLFxuICAgIG1heFdpZHRoOiA1MCxcbiAgICByZXNpemVhYmxlOiBmYWxzZSxcbiAgICBzb3J0YWJsZTogZmFsc2UsXG4gICAgZHJhZ2dhYmxlOiBmYWxzZSxcbiAgICAvLyBUT0RPOiBGaXggY29sdW1uIGF1dG8gc2l6aW5nIHdpdGggZml4ZWQgY29sdW1uIGFuZCBjZWxsIG92ZXJsYXkgYmVmb3JlIGVuYWJsaW5nLlxuICAgIGZyb3plbkxlZnQ6IGZyb3plbkxlZnQsXG4gICAgZnJvemVuUmlnaHQ6IGZyb3plblJpZ2h0LFxuICAgIGNlbGxUZW1wbGF0ZSxcbiAgICBoZWFkZXJUZW1wbGF0ZSxcbiAgfVxufVxuIl19
|
|
@@ -106,7 +106,7 @@ export class DatatableDynamicActionMenuComponent {
|
|
|
106
106
|
}
|
|
107
107
|
}
|
|
108
108
|
DatatableDynamicActionMenuComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.7", ngImport: i0, type: DatatableDynamicActionMenuComponent, deps: [{ token: i1.DynamicValueHelperService }, { token: i2.DynamicDatatableRowActionsService }], target: i0.ɵɵFactoryTarget.Component });
|
|
109
|
-
DatatableDynamicActionMenuComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.7", type: DatatableDynamicActionMenuComponent, selector: "seam-datatable-dynamic-action-menu", inputs: { row: "row", actionDefs: "actionDefs" }, ngImport: i0, template: "<seam-menu #menu\n menuClass=\"list-group py-0 border-0 seam-datatable-action-menu\"\n animationType=\"fade\">\n\n <ng-container *ngFor=\"let record of _menuRecords$ | async\">\n\n <a *ngIf=\"record.elementType === 'a'\"\n seamMenuItem\n [seamDatatableDynamicActionMenuItem]=\"record\"\n class=\"list-group-item list-group-item-action py-1\">{{ record.rowAction.label }}</a>\n\n <button *ngIf=\"record.elementType === 'button'\"\n seamMenuItem\n [seamDatatableDynamicActionMenuItem]=\"record\"\n type=\"button\"\n class=\"list-group-item list-group-item-action py-1\">{{ record.rowAction.label }}</button>\n\n </ng-container>\n\n <!-- <ng-container *ngIf=\"(item.routerLink || item.href) && !item.confirmDialog; else noRouterLink\">\n <a *ngIf=\"item.href; else noHref\"\n seamMenuItem\n class=\"list-group-item list-group-item-action py-1\"\n [attr.href]=\"item.href\"\n [target]=\"item.target\"\n (click)=\"activateItem($event, item)\">\n {{ item.label }}\n </a>\n <ng-template #noHref>\n <a seamMenuItem\n class=\"list-group-item list-group-item-action py-1\"\n [queryParams]=\"item.queryParams\"\n [fragment]=\"item.fragment\"\n [queryParamsHandling]=\"item.queryParamsHandling\"\n [preserveFragment]=\"item.preserveFragment\"\n [skipLocationChange]=\"item.skipLocationChange\"\n [replaceUrl]=\"item.replaceUrl\"\n [state]=\"item.state\"\n [routerLink]=\"item.routerLink\"\n [target]=\"item.target\"\n (click)=\"activateItem($event, item)\">\n {{ item.label }}\n </a>\n </ng-template>\n </ng-container>\n <ng-template #noRouterLink>\n <button seamMenuItem\n type=\"button\"\n class=\"list-group-item list-group-item-action py-1\"\n (click)=\"activateItem($event, item)\">\n {{ item.label }}\n </button>\n </ng-template>\n </ng-container> -->\n</seam-menu>\n\n<button type=\"button\" class=\"datatable-action-button btn\"\n [seamMenuToggle]=\"menu\"\n [positions]=\"$any(_actionMenuPositions)\"\n title=\"Row Actions\">\n <seam-icon [icon]=\"faEllipsisH\"></seam-icon>\n</button>\n", styles: [":host{display:block;position:relative}.datatable-action-button{font-size:20px;line-height:20px;width:30px;height:30px;padding:0;border-radius:15px;text-align:center}.datatable-action-button::ng-deep .svg-inline--fa{vertical-align:middle}\n"], dependencies: [{ kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i4.IconComponent, selector: "seam-icon", inputs: ["grayscaleOnDisable", "disabled", "iconClass", "icon", "size", "showDefaultOnError", "defaultIcon", "iconType"] }, { kind: "component", type: i5.MenuComponent, selector: "seam-menu", inputs: ["menuClass", "baseWidth", "animationType"], outputs: ["closed"], exportAs: ["seamMenu"] }, { kind: "directive", type: i5.MenuToggleDirective, selector: "[seamMenuToggle]", inputs: ["seamMenuToggle", "positions", "seamMenuTogglePositionsOffsetY"], outputs: ["menuOpened", "menuClosed"], exportAs: ["seamMenuToggle"] }, { kind: "component", type: i5.MenuItemComponent, selector: "[seamMenuItem]", inputs: ["disabled", "role", "icon", "iconClass", "sublevelIcon", "subLevelIconClass", "badgeText", "badgeTheme"], exportAs: ["seamMenuItem"] }, { kind: "directive", type: i6.DatatableDynamicActionMenuItemDirective, selector: "[seamDatatableDynamicActionMenuItem]", inputs: ["seamDatatableDynamicActionMenuItem"], exportAs: ["seamDatatableDynamicActionMenuItem"] }, { kind: "pipe", type: i3.AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
109
|
+
DatatableDynamicActionMenuComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.7", type: DatatableDynamicActionMenuComponent, selector: "seam-datatable-dynamic-action-menu", inputs: { row: "row", actionDefs: "actionDefs" }, ngImport: i0, template: "<seam-menu #menu\n menuClass=\"list-group py-0 border-0 seam-datatable-action-menu\"\n animationType=\"fade\">\n\n <ng-container *ngFor=\"let record of _menuRecords$ | async\">\n\n <a *ngIf=\"record.elementType === 'a'\"\n seamMenuItem\n [seamDatatableDynamicActionMenuItem]=\"record\"\n class=\"list-group-item list-group-item-action py-1\">{{ record.rowAction.label }}</a>\n\n <button *ngIf=\"record.elementType === 'button'\"\n seamMenuItem\n [seamDatatableDynamicActionMenuItem]=\"record\"\n type=\"button\"\n class=\"list-group-item list-group-item-action py-1\">{{ record.rowAction.label }}</button>\n\n </ng-container>\n\n <!-- <ng-container *ngIf=\"(item.routerLink || item.href) && !item.confirmDialog; else noRouterLink\">\n <a *ngIf=\"item.href; else noHref\"\n seamMenuItem\n class=\"list-group-item list-group-item-action py-1\"\n [attr.href]=\"item.href\"\n [target]=\"item.target\"\n (click)=\"activateItem($event, item)\">\n {{ item.label }}\n </a>\n <ng-template #noHref>\n <a seamMenuItem\n class=\"list-group-item list-group-item-action py-1\"\n [queryParams]=\"item.queryParams\"\n [fragment]=\"item.fragment\"\n [queryParamsHandling]=\"item.queryParamsHandling\"\n [preserveFragment]=\"item.preserveFragment\"\n [skipLocationChange]=\"item.skipLocationChange\"\n [replaceUrl]=\"item.replaceUrl\"\n [state]=\"item.state\"\n [routerLink]=\"item.routerLink\"\n [target]=\"item.target\"\n (click)=\"activateItem($event, item)\">\n {{ item.label }}\n </a>\n </ng-template>\n </ng-container>\n <ng-template #noRouterLink>\n <button seamMenuItem\n type=\"button\"\n class=\"list-group-item list-group-item-action py-1\"\n (click)=\"activateItem($event, item)\">\n {{ item.label }}\n </button>\n </ng-template>\n </ng-container> -->\n</seam-menu>\n\n<button type=\"button\" class=\"datatable-action-button btn\"\n [seamMenuToggle]=\"menu\"\n [positions]=\"$any(_actionMenuPositions)\"\n title=\"Row Actions\">\n <seam-icon [icon]=\"faEllipsisH\"></seam-icon>\n</button>\n", styles: [":host{display:block;position:relative}.datatable-action-button{font-size:20px;line-height:20px;width:30px;height:30px;padding:0;border-radius:15px;text-align:center}.datatable-action-button::ng-deep .svg-inline--fa{vertical-align:middle}\n"], dependencies: [{ kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i4.IconComponent, selector: "seam-icon", inputs: ["grayscaleOnDisable", "disabled", "iconClass", "icon", "size", "showDefaultOnError", "defaultIcon", "iconType"] }, { kind: "component", type: i5.MenuComponent, selector: "seam-menu", inputs: ["menuClass", "baseWidth", "animationType"], outputs: ["closed"], exportAs: ["seamMenu"] }, { kind: "directive", type: i5.MenuToggleDirective, selector: "[seamMenuToggle]", inputs: ["seamMenuToggle", "positions", "seamMenuTogglePositionsOffsetY"], outputs: ["menuToggle", "menuOpened", "menuClosed"], exportAs: ["seamMenuToggle"] }, { kind: "component", type: i5.MenuItemComponent, selector: "[seamMenuItem]", inputs: ["disabled", "role", "icon", "iconClass", "sublevelIcon", "subLevelIconClass", "badgeText", "badgeTheme"], exportAs: ["seamMenuItem"] }, { kind: "directive", type: i6.DatatableDynamicActionMenuItemDirective, selector: "[seamDatatableDynamicActionMenuItem]", inputs: ["seamDatatableDynamicActionMenuItem"], exportAs: ["seamDatatableDynamicActionMenuItem"] }, { kind: "pipe", type: i3.AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
110
110
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.7", ngImport: i0, type: DatatableDynamicActionMenuComponent, decorators: [{
|
|
111
111
|
type: Component,
|
|
112
112
|
args: [{ selector: 'seam-datatable-dynamic-action-menu', changeDetection: ChangeDetectionStrategy.OnPush, template: "<seam-menu #menu\n menuClass=\"list-group py-0 border-0 seam-datatable-action-menu\"\n animationType=\"fade\">\n\n <ng-container *ngFor=\"let record of _menuRecords$ | async\">\n\n <a *ngIf=\"record.elementType === 'a'\"\n seamMenuItem\n [seamDatatableDynamicActionMenuItem]=\"record\"\n class=\"list-group-item list-group-item-action py-1\">{{ record.rowAction.label }}</a>\n\n <button *ngIf=\"record.elementType === 'button'\"\n seamMenuItem\n [seamDatatableDynamicActionMenuItem]=\"record\"\n type=\"button\"\n class=\"list-group-item list-group-item-action py-1\">{{ record.rowAction.label }}</button>\n\n </ng-container>\n\n <!-- <ng-container *ngIf=\"(item.routerLink || item.href) && !item.confirmDialog; else noRouterLink\">\n <a *ngIf=\"item.href; else noHref\"\n seamMenuItem\n class=\"list-group-item list-group-item-action py-1\"\n [attr.href]=\"item.href\"\n [target]=\"item.target\"\n (click)=\"activateItem($event, item)\">\n {{ item.label }}\n </a>\n <ng-template #noHref>\n <a seamMenuItem\n class=\"list-group-item list-group-item-action py-1\"\n [queryParams]=\"item.queryParams\"\n [fragment]=\"item.fragment\"\n [queryParamsHandling]=\"item.queryParamsHandling\"\n [preserveFragment]=\"item.preserveFragment\"\n [skipLocationChange]=\"item.skipLocationChange\"\n [replaceUrl]=\"item.replaceUrl\"\n [state]=\"item.state\"\n [routerLink]=\"item.routerLink\"\n [target]=\"item.target\"\n (click)=\"activateItem($event, item)\">\n {{ item.label }}\n </a>\n </ng-template>\n </ng-container>\n <ng-template #noRouterLink>\n <button seamMenuItem\n type=\"button\"\n class=\"list-group-item list-group-item-action py-1\"\n (click)=\"activateItem($event, item)\">\n {{ item.label }}\n </button>\n </ng-template>\n </ng-container> -->\n</seam-menu>\n\n<button type=\"button\" class=\"datatable-action-button btn\"\n [seamMenuToggle]=\"menu\"\n [positions]=\"$any(_actionMenuPositions)\"\n title=\"Row Actions\">\n <seam-icon [icon]=\"faEllipsisH\"></seam-icon>\n</button>\n", styles: [":host{display:block;position:relative}.datatable-action-button{font-size:20px;line-height:20px;width:30px;height:30px;padding:0;border-radius:15px;text-align:center}.datatable-action-button::ng-deep .svg-inline--fa{vertical-align:middle}\n"] }]
|
|
@@ -62,7 +62,7 @@ DatatableDynamicComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0"
|
|
|
62
62
|
DatatableDynamicComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.7", type: DatatableDynamicComponent, selector: "seam-datatable-dynamic", inputs: { def: "def" }, providers: [
|
|
63
63
|
DynamicDatatableDefService,
|
|
64
64
|
DynamicDatatableRowActionsService
|
|
65
|
-
], ngImport: i0, template: "<ng-container *ngIf=\"_hasDef$ | async\">\n <seam-datatable *ngIf=\"_options$ | async as opts\"\n class=\"w-100 h-100\"\n [columns]=\"_tmp_columns$ | async\"\n [rows]=\"_tmp_rows$ | async\"\n [virtualization]=\"opts.virtualization\">\n\n <seam-datatable-menu-bar *ngIf=\"menuBar$ | async as menuBar\">\n <seam-datatable-dynamic-menu-bar-content [def]=\"menuBar\"></seam-datatable-dynamic-menu-bar-content>\n </seam-datatable-menu-bar>\n <!-- <seam-datatable-menu-bar *ngIf=\"_hasFilterMenu$ | async\">\n <div class=\"d-flex flex-row pb-2\">\n <div class=\"d-flex flex-row justify-content-end flex-grow-1\">\n <seam-data-filter-search seamDatatableFilter *ngIf=\"_hasFullSearch$\"></seam-data-filter-search>\n </div>\n </div>\n <div class=\"d-flex flex-row\">\n <div class=\"d-flex justify-content-center flex-grow-1\">\n <ng-container *ngFor=\"let r of _commonFilterMenuItems$ | async; let isFirst = first\">\n <seam-datatable-dynamic-filter-container\n [class.ml-1]=\"!isFirst\"\n [filterComponent]=\"r.component\"\n [options]=\"r.options\">\n </seam-datatable-dynamic-filter-container>\n </ng-container>\n </div>\n <seam-datatable-export-button *ngIf=\"_exporters$ | async as exporters\"\n [exporters]=\"exporters\">\n </seam-datatable-export-button>\n </div>\n </seam-datatable-menu-bar> -->\n\n <ng-template seamDatatableRowActionItem let-row>\n <seam-datatable-dynamic-action-menu [row]=\"row\"></seam-datatable-dynamic-action-menu>\n </ng-template>\n\n </seam-datatable>\n</ng-container>\n", styles: [":host{display:flex;flex-direction:column}\n"], dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i3.DatatableComponent, selector: "seam-datatable", inputs: ["preferencesKey", "targetMarkerTemplate", "columns", "rows", "columnMode", "groupRowsBy", "groupedRows", "selected", "externalPaging", "externalSorting", "externalFiltering", "limit", "count", "offset", "loadingIndicator", "selectionType", "reorderable", "swapColumns", "sortType", "sorts", "cssClasses", "messages", "rowIdentity", "rowClass", "selectCheck", "displayCheck", "groupExpansionDefault", "trackByProp", "selectAllRowsOnPage", "treeFromRelation", "treeToRelation", "summaryRow", "summaryHeight", "summaryPosition", "virtualization", "headerHeight", "rowHeight", "footerHeight", "scrollbarV", "scrollbarH", "dataSource"], outputs: ["scroll", "activate", "select", "sort", "page", "reorder", "resize", "tableContextmenu", "treeAction", "actionRefreshRequest", "hiddenColumnsChange"] }, { kind: "component", type: i3.DatatableMenuBarComponent, selector: "seam-datatable-menu-bar" }, { kind: "directive", type: i3.DatatableRowActionItemDirective, selector: "[seamDatatableRowActionItem]" }, { kind: "component", type: i4.DatatableDynamicActionMenuComponent, selector: "seam-datatable-dynamic-action-menu", inputs: ["row", "actionDefs"] }, { kind: "component", type: i5.DatatableDynamicMenuBarContentComponent, selector: "seam-datatable-dynamic-menu-bar-content", inputs: ["def"] }, { kind: "pipe", type: i2.AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
65
|
+
], ngImport: i0, template: "<ng-container *ngIf=\"_hasDef$ | async\">\n <seam-datatable *ngIf=\"_options$ | async as opts\"\n class=\"w-100 h-100\"\n [columns]=\"_tmp_columns$ | async\"\n [rows]=\"_tmp_rows$ | async\"\n [virtualization]=\"opts.virtualization\">\n\n <seam-datatable-menu-bar *ngIf=\"menuBar$ | async as menuBar\">\n <seam-datatable-dynamic-menu-bar-content [def]=\"menuBar\"></seam-datatable-dynamic-menu-bar-content>\n </seam-datatable-menu-bar>\n <!-- <seam-datatable-menu-bar *ngIf=\"_hasFilterMenu$ | async\">\n <div class=\"d-flex flex-row pb-2\">\n <div class=\"d-flex flex-row justify-content-end flex-grow-1\">\n <seam-data-filter-search seamDatatableFilter *ngIf=\"_hasFullSearch$\"></seam-data-filter-search>\n </div>\n </div>\n <div class=\"d-flex flex-row\">\n <div class=\"d-flex justify-content-center flex-grow-1\">\n <ng-container *ngFor=\"let r of _commonFilterMenuItems$ | async; let isFirst = first\">\n <seam-datatable-dynamic-filter-container\n [class.ml-1]=\"!isFirst\"\n [filterComponent]=\"r.component\"\n [options]=\"r.options\">\n </seam-datatable-dynamic-filter-container>\n </ng-container>\n </div>\n <seam-datatable-export-button *ngIf=\"_exporters$ | async as exporters\"\n [exporters]=\"exporters\">\n </seam-datatable-export-button>\n </div>\n </seam-datatable-menu-bar> -->\n\n <ng-template seamDatatableRowActionItem let-row>\n <seam-datatable-dynamic-action-menu [row]=\"row\"></seam-datatable-dynamic-action-menu>\n </ng-template>\n\n </seam-datatable>\n</ng-container>\n", styles: [":host{display:flex;flex-direction:column}\n"], dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i3.DatatableComponent, selector: "seam-datatable", inputs: ["preferencesKey", "targetMarkerTemplate", "columns", "rows", "columnMode", "groupRowsBy", "groupedRows", "selected", "externalPaging", "externalSorting", "externalFiltering", "limit", "count", "offset", "loadingIndicator", "selectionType", "reorderable", "swapColumns", "sortType", "sorts", "cssClasses", "messages", "rowIdentity", "rowClass", "selectCheck", "displayCheck", "groupExpansionDefault", "trackByProp", "selectAllRowsOnPage", "treeFromRelation", "treeToRelation", "summaryRow", "summaryHeight", "summaryPosition", "virtualization", "headerHeight", "rowHeight", "footerHeight", "scrollbarV", "scrollbarH", "dataSource", "actionItemColumnPosition"], outputs: ["scroll", "activate", "select", "sort", "page", "reorder", "resize", "tableContextmenu", "treeAction", "actionRefreshRequest", "hiddenColumnsChange"] }, { kind: "component", type: i3.DatatableMenuBarComponent, selector: "seam-datatable-menu-bar" }, { kind: "directive", type: i3.DatatableRowActionItemDirective, selector: "[seamDatatableRowActionItem]" }, { kind: "component", type: i4.DatatableDynamicActionMenuComponent, selector: "seam-datatable-dynamic-action-menu", inputs: ["row", "actionDefs"] }, { kind: "component", type: i5.DatatableDynamicMenuBarContentComponent, selector: "seam-datatable-dynamic-menu-bar-content", inputs: ["def"] }, { kind: "pipe", type: i2.AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
66
66
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.7", ngImport: i0, type: DatatableDynamicComponent, decorators: [{
|
|
67
67
|
type: Component,
|
|
68
68
|
args: [{ selector: 'seam-datatable-dynamic', providers: [
|
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
import { __decorate } from "tslib";
|
|
2
2
|
import { ChangeDetectionStrategy, Component, Inject, Input, Optional } from '@angular/core';
|
|
3
|
+
import { shareReplay, startWith, Subject, switchMap } from 'rxjs';
|
|
3
4
|
import { InputBoolean } from '@theseam/ui-common/core';
|
|
4
5
|
import { FORM_FIELD_COMPONENT } from './form-field-tokens';
|
|
5
6
|
import * as i0 from "@angular/core";
|
|
@@ -7,27 +8,41 @@ import * as i1 from "@angular/common";
|
|
|
7
8
|
export class FormFieldRequiredIndicatorComponent {
|
|
8
9
|
constructor(_formField) {
|
|
9
10
|
this._formField = _formField;
|
|
11
|
+
this._requiredChange = new Subject();
|
|
10
12
|
/** Used if a form control is not found. */
|
|
11
13
|
this.required = false;
|
|
14
|
+
if (_formField) {
|
|
15
|
+
this._controlRequired$ = _formField._contentInputSubject.pipe(switchMap((contentInput) => {
|
|
16
|
+
if (!contentInput) {
|
|
17
|
+
return this._requiredChange.pipe(startWith(this.required));
|
|
18
|
+
}
|
|
19
|
+
return contentInput.requiredChange.pipe(startWith(contentInput.required));
|
|
20
|
+
}), shareReplay({ bufferSize: 1, refCount: true }));
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
ngOnChanges(changes) {
|
|
24
|
+
if (changes.required) {
|
|
25
|
+
this._requiredChange.next(this.required);
|
|
26
|
+
}
|
|
12
27
|
}
|
|
13
28
|
}
|
|
14
29
|
FormFieldRequiredIndicatorComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.7", ngImport: i0, type: FormFieldRequiredIndicatorComponent, deps: [{ token: FORM_FIELD_COMPONENT, optional: true }], target: i0.ɵɵFactoryTarget.Component });
|
|
15
|
-
FormFieldRequiredIndicatorComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.7", type: FormFieldRequiredIndicatorComponent, selector: "seam-form-field-required-indicator", inputs: { required: "required" }, host: { classAttribute: "text-danger" }, ngImport: i0, template: `
|
|
16
|
-
<ng-container *ngIf="
|
|
17
|
-
<ng-container *ngIf="
|
|
30
|
+
FormFieldRequiredIndicatorComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.7", type: FormFieldRequiredIndicatorComponent, selector: "seam-form-field-required-indicator", inputs: { required: "required" }, host: { classAttribute: "text-danger" }, usesOnChanges: true, ngImport: i0, template: `
|
|
31
|
+
<ng-container *ngIf="_controlRequired$; else noControl">
|
|
32
|
+
<ng-container *ngIf="_controlRequired$ | async">*</ng-container>
|
|
18
33
|
</ng-container>
|
|
19
34
|
<ng-template #noControl>
|
|
20
35
|
<ng-container *ngIf="required">*</ng-container>
|
|
21
36
|
</ng-template>
|
|
22
|
-
`, isInline: true, dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
37
|
+
`, isInline: true, dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
23
38
|
__decorate([
|
|
24
39
|
InputBoolean()
|
|
25
40
|
], FormFieldRequiredIndicatorComponent.prototype, "required", void 0);
|
|
26
41
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.7", ngImport: i0, type: FormFieldRequiredIndicatorComponent, decorators: [{
|
|
27
42
|
type: Component,
|
|
28
43
|
args: [{ selector: 'seam-form-field-required-indicator', template: `
|
|
29
|
-
<ng-container *ngIf="
|
|
30
|
-
<ng-container *ngIf="
|
|
44
|
+
<ng-container *ngIf="_controlRequired$; else noControl">
|
|
45
|
+
<ng-container *ngIf="_controlRequired$ | async">*</ng-container>
|
|
31
46
|
</ng-container>
|
|
32
47
|
<ng-template #noControl>
|
|
33
48
|
<ng-container *ngIf="required">*</ng-container>
|
|
@@ -43,4 +58,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.7", ngImpor
|
|
|
43
58
|
}] }]; }, propDecorators: { required: [{
|
|
44
59
|
type: Input
|
|
45
60
|
}] } });
|
|
46
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
61
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZm9ybS1maWVsZC1yZXF1aXJlZC1pbmRpY2F0b3IuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vcHJvamVjdHMvdWktY29tbW9uL2Zvcm0tZmllbGQvZm9ybS1maWVsZC1yZXF1aXJlZC1pbmRpY2F0b3IuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFDQSxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsU0FBUyxFQUFFLE1BQU0sRUFBRSxLQUFLLEVBQWEsUUFBUSxFQUFpQixNQUFNLGVBQWUsQ0FBQTtBQUNySCxPQUFPLEVBQWMsV0FBVyxFQUFFLFNBQVMsRUFBRSxPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0sTUFBTSxDQUFBO0FBRTdFLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQTtBQUV0RCxPQUFPLEVBQUUsb0JBQW9CLEVBQUUsTUFBTSxxQkFBcUIsQ0FBQTs7O0FBa0IxRCxNQUFNLE9BQU8sbUNBQW1DO0lBVTlDLFlBQzRELFVBQWU7UUFBZixlQUFVLEdBQVYsVUFBVSxDQUFLO1FBUjFELG9CQUFlLEdBQUcsSUFBSSxPQUFPLEVBQVcsQ0FBQTtRQUV6RCwyQ0FBMkM7UUFDbEIsYUFBUSxHQUFHLEtBQUssQ0FBQTtRQU92QyxJQUFJLFVBQVUsRUFBRTtZQUNkLElBQUksQ0FBQyxpQkFBaUIsR0FBRyxVQUFVLENBQUMsb0JBQW9CLENBQUMsSUFBSSxDQUMzRCxTQUFTLENBQUMsQ0FBQyxZQUFpQixFQUFFLEVBQUU7Z0JBQzlCLElBQUksQ0FBQyxZQUFZLEVBQUU7b0JBQ2pCLE9BQU8sSUFBSSxDQUFDLGVBQWUsQ0FBQyxJQUFJLENBQzlCLFNBQVMsQ0FBQyxJQUFJLENBQUMsUUFBUSxDQUFDLENBQ3pCLENBQUE7aUJBQ0Y7Z0JBRUQsT0FBTyxZQUFZLENBQUMsY0FBYyxDQUFDLElBQUksQ0FDckMsU0FBUyxDQUFDLFlBQVksQ0FBQyxRQUFRLENBQUMsQ0FDakMsQ0FBQTtZQUNILENBQUMsQ0FBQyxFQUNGLFdBQVcsQ0FBQyxFQUFFLFVBQVUsRUFBRSxDQUFDLEVBQUUsUUFBUSxFQUFFLElBQUksRUFBRSxDQUFDLENBQy9DLENBQUE7U0FDRjtJQUNILENBQUM7SUFFRCxXQUFXLENBQUMsT0FBc0I7UUFDaEMsSUFBSSxPQUFPLENBQUMsUUFBUSxFQUFFO1lBQ3BCLElBQUksQ0FBQyxlQUFlLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxRQUFRLENBQUMsQ0FBQTtTQUN6QztJQUNILENBQUM7O2dJQW5DVSxtQ0FBbUMsa0JBV3hCLG9CQUFvQjtvSEFYL0IsbUNBQW1DLDBLQWRwQzs7Ozs7OztHQU9UO0FBYXdCO0lBQWYsWUFBWSxFQUFFO3FFQUFpQjsyRkFOOUIsbUNBQW1DO2tCQWhCL0MsU0FBUzsrQkFDRSxvQ0FBb0MsWUFDcEM7Ozs7Ozs7R0FPVCxRQUVLO3dCQUNKLE9BQU8sRUFBRSxhQUFhO3FCQUN2QixtQkFDZ0IsdUJBQXVCLENBQUMsTUFBTTs7MEJBYTVDLFFBQVE7OzBCQUFJLE1BQU07MkJBQUMsb0JBQW9COzRDQUxqQixRQUFRO3NCQUFoQyxLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQm9vbGVhbklucHV0IH0gZnJvbSAnQGFuZ3VsYXIvY2RrL2NvZXJjaW9uJ1xuaW1wb3J0IHsgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIENvbXBvbmVudCwgSW5qZWN0LCBJbnB1dCwgT25DaGFuZ2VzLCBPcHRpb25hbCwgU2ltcGxlQ2hhbmdlcyB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnXG5pbXBvcnQgeyBPYnNlcnZhYmxlLCBzaGFyZVJlcGxheSwgc3RhcnRXaXRoLCBTdWJqZWN0LCBzd2l0Y2hNYXAgfSBmcm9tICdyeGpzJ1xuXG5pbXBvcnQgeyBJbnB1dEJvb2xlYW4gfSBmcm9tICdAdGhlc2VhbS91aS1jb21tb24vY29yZSdcblxuaW1wb3J0IHsgRk9STV9GSUVMRF9DT01QT05FTlQgfSBmcm9tICcuL2Zvcm0tZmllbGQtdG9rZW5zJ1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdzZWFtLWZvcm0tZmllbGQtcmVxdWlyZWQtaW5kaWNhdG9yJyxcbiAgdGVtcGxhdGU6IGBcbiAgICA8bmctY29udGFpbmVyICpuZ0lmPVwiX2NvbnRyb2xSZXF1aXJlZCQ7IGVsc2Ugbm9Db250cm9sXCI+XG4gICAgICA8bmctY29udGFpbmVyICpuZ0lmPVwiX2NvbnRyb2xSZXF1aXJlZCQgfCBhc3luY1wiPio8L25nLWNvbnRhaW5lcj5cbiAgICA8L25nLWNvbnRhaW5lcj5cbiAgICA8bmctdGVtcGxhdGUgI25vQ29udHJvbD5cbiAgICAgIDxuZy1jb250YWluZXIgKm5nSWY9XCJyZXF1aXJlZFwiPio8L25nLWNvbnRhaW5lcj5cbiAgICA8L25nLXRlbXBsYXRlPlxuICBgLFxuICBzdHlsZXM6IFtdLFxuICBob3N0OiB7XG4gICAgJ2NsYXNzJzogJ3RleHQtZGFuZ2VyJ1xuICB9LFxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaFxufSlcbmV4cG9ydCBjbGFzcyBGb3JtRmllbGRSZXF1aXJlZEluZGljYXRvckNvbXBvbmVudCBpbXBsZW1lbnRzIE9uQ2hhbmdlcyB7XG4gIHN0YXRpYyBuZ0FjY2VwdElucHV0VHlwZV9yZXF1aXJlZDogQm9vbGVhbklucHV0XG5cbiAgcHJpdmF0ZSByZWFkb25seSBfcmVxdWlyZWRDaGFuZ2UgPSBuZXcgU3ViamVjdDxib29sZWFuPigpXG5cbiAgLyoqIFVzZWQgaWYgYSBmb3JtIGNvbnRyb2wgaXMgbm90IGZvdW5kLiAqL1xuICBASW5wdXQoKSBASW5wdXRCb29sZWFuKCkgcmVxdWlyZWQgPSBmYWxzZVxuXG4gIHJlYWRvbmx5IF9jb250cm9sUmVxdWlyZWQkOiBPYnNlcnZhYmxlPGJvb2xlYW4+IHwgdW5kZWZpbmVkXG5cbiAgY29uc3RydWN0b3IoXG4gICAgQE9wdGlvbmFsKCkgQEluamVjdChGT1JNX0ZJRUxEX0NPTVBPTkVOVCkgcHVibGljIHJlYWRvbmx5IF9mb3JtRmllbGQ6IGFueVxuICApIHtcbiAgICBpZiAoX2Zvcm1GaWVsZCkge1xuICAgICAgdGhpcy5fY29udHJvbFJlcXVpcmVkJCA9IF9mb3JtRmllbGQuX2NvbnRlbnRJbnB1dFN1YmplY3QucGlwZShcbiAgICAgICAgc3dpdGNoTWFwKChjb250ZW50SW5wdXQ6IGFueSkgPT4ge1xuICAgICAgICAgIGlmICghY29udGVudElucHV0KSB7XG4gICAgICAgICAgICByZXR1cm4gdGhpcy5fcmVxdWlyZWRDaGFuZ2UucGlwZShcbiAgICAgICAgICAgICAgc3RhcnRXaXRoKHRoaXMucmVxdWlyZWQpLFxuICAgICAgICAgICAgKVxuICAgICAgICAgIH1cblxuICAgICAgICAgIHJldHVybiBjb250ZW50SW5wdXQucmVxdWlyZWRDaGFuZ2UucGlwZShcbiAgICAgICAgICAgIHN0YXJ0V2l0aChjb250ZW50SW5wdXQucmVxdWlyZWQpLFxuICAgICAgICAgIClcbiAgICAgICAgfSksXG4gICAgICAgIHNoYXJlUmVwbGF5KHsgYnVmZmVyU2l6ZTogMSwgcmVmQ291bnQ6IHRydWUgfSksXG4gICAgICApXG4gICAgfVxuICB9XG5cbiAgbmdPbkNoYW5nZXMoY2hhbmdlczogU2ltcGxlQ2hhbmdlcyk6IHZvaWQge1xuICAgIGlmIChjaGFuZ2VzLnJlcXVpcmVkKSB7XG4gICAgICB0aGlzLl9yZXF1aXJlZENoYW5nZS5uZXh0KHRoaXMucmVxdWlyZWQpXG4gICAgfVxuICB9XG5cbn1cbiJdfQ==
|
|
@@ -32,10 +32,6 @@ export class InputDirective {
|
|
|
32
32
|
this._elementRef.nativeElement.type = this._type;
|
|
33
33
|
}
|
|
34
34
|
}
|
|
35
|
-
/**
|
|
36
|
-
* Implemented as part of MatFormFieldControl.
|
|
37
|
-
* @docs-private
|
|
38
|
-
*/
|
|
39
35
|
get disabled() {
|
|
40
36
|
if (this.ngControl && this.ngControl.disabled !== null) {
|
|
41
37
|
return this.ngControl.disabled;
|
|
@@ -66,10 +62,6 @@ export class InputDirective {
|
|
|
66
62
|
this._isFormControl = true;
|
|
67
63
|
this.seamInputSize = 'normal';
|
|
68
64
|
this._type = 'text';
|
|
69
|
-
/**
|
|
70
|
-
* Implemented as part of MatFormFieldControl.
|
|
71
|
-
* @docs-private
|
|
72
|
-
*/
|
|
73
65
|
this.required = false;
|
|
74
66
|
this._disabled = false;
|
|
75
67
|
this.focused = false;
|
|
@@ -84,6 +76,12 @@ export class InputDirective {
|
|
|
84
76
|
// }
|
|
85
77
|
/** Whether the element is readonly. */
|
|
86
78
|
this.readonly = false;
|
|
79
|
+
this._requiredChange = new Subject();
|
|
80
|
+
this._disabledChange = new Subject();
|
|
81
|
+
this._readonlyChange = new Subject();
|
|
82
|
+
this.requiredChange = this._requiredChange.asObservable();
|
|
83
|
+
this.disabledChange = this._disabledChange.asObservable();
|
|
84
|
+
this.readonlyChange = this._readonlyChange.asObservable;
|
|
87
85
|
// Force setter to be called in case id was not specified.
|
|
88
86
|
// eslint-disable-next-line no-self-assign
|
|
89
87
|
this.id = this.id;
|
|
@@ -91,6 +89,17 @@ export class InputDirective {
|
|
|
91
89
|
this._isFormControl = false;
|
|
92
90
|
}
|
|
93
91
|
}
|
|
92
|
+
ngOnChanges(changes) {
|
|
93
|
+
if (changes.required) {
|
|
94
|
+
this._requiredChange.next(this.required);
|
|
95
|
+
}
|
|
96
|
+
if (changes.disabled) {
|
|
97
|
+
this._disabledChange.next(this.disabled);
|
|
98
|
+
}
|
|
99
|
+
if (changes.readonly) {
|
|
100
|
+
this._readonlyChange.next(this.readonly);
|
|
101
|
+
}
|
|
102
|
+
}
|
|
94
103
|
ngDoCheck() {
|
|
95
104
|
if (this._isNgSelect()) {
|
|
96
105
|
this._ngSelect.labelForId = this.id;
|
|
@@ -135,12 +144,6 @@ export class InputDirective {
|
|
|
135
144
|
_isQuillEditor() {
|
|
136
145
|
return this._elementRef.nativeElement.nodeName.toLowerCase() === 'quill-editor';
|
|
137
146
|
}
|
|
138
|
-
/** Make sure the input is a supported type. */
|
|
139
|
-
// protected _validateType() {
|
|
140
|
-
// if (MAT_INPUT_INVALID_TYPES.indexOf(this._type) > -1) {
|
|
141
|
-
// throw getMatInputUnsupportedTypeError(this._type)
|
|
142
|
-
// }
|
|
143
|
-
// }
|
|
144
147
|
/** Focuses the input. */
|
|
145
148
|
focus() {
|
|
146
149
|
this._elementRef.nativeElement.focus();
|
|
@@ -159,7 +162,7 @@ export class InputDirective {
|
|
|
159
162
|
}
|
|
160
163
|
}
|
|
161
164
|
InputDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.7", ngImport: i0, type: InputDirective, deps: [{ token: i0.ElementRef }, { token: i1.NgControl, optional: true, self: true }, { token: i1.NgForm, optional: true }, { token: i1.FormGroupDirective, optional: true }, { token: i2.NgSelectComponent, optional: true }], target: i0.ɵɵFactoryTarget.Directive });
|
|
162
|
-
InputDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "15.2.7", type: InputDirective, selector: "input[seamInput], textarea[seamInput], ng-select[seamInput], seam-checkbox[seamInput] [ngbRadioGroup], seam-tel-input[seamInput], quill-editor[seamInput], seam-google-maps[seamInput]", inputs: { seamInputSize: "seamInputSize", id: "id", type: "type", placeholder: "placeholder", required: "required", disabled: "disabled", readonly: "readonly" }, host: { properties: { "class.form-control": "this._isFormControl", "class.form-control-sm": "this._isFormControlSmall", "class.is-invalid": "this._isInvalid", "attr.id": "this._attrId", "attr.placeholder": "this._attrPlaceholder", "attr.aria-describedby": "this.ariaDescribedBy" } }, exportAs: ["seamInput"], ngImport: i0 });
|
|
165
|
+
InputDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "15.2.7", type: InputDirective, selector: "input[seamInput], textarea[seamInput], ng-select[seamInput], seam-checkbox[seamInput] [ngbRadioGroup], seam-tel-input[seamInput], quill-editor[seamInput], seam-google-maps[seamInput]", inputs: { seamInputSize: "seamInputSize", id: "id", type: "type", placeholder: "placeholder", required: "required", disabled: "disabled", readonly: "readonly" }, host: { properties: { "class.form-control": "this._isFormControl", "class.form-control-sm": "this._isFormControlSmall", "class.is-invalid": "this._isInvalid", "attr.id": "this._attrId", "attr.placeholder": "this._attrPlaceholder", "attr.aria-describedby": "this.ariaDescribedBy" } }, exportAs: ["seamInput"], usesOnChanges: true, ngImport: i0 });
|
|
163
166
|
__decorate([
|
|
164
167
|
InputBoolean()
|
|
165
168
|
], InputDirective.prototype, "required", void 0);
|
|
@@ -217,4 +220,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.7", ngImpor
|
|
|
217
220
|
}], readonly: [{
|
|
218
221
|
type: Input
|
|
219
222
|
}] } });
|
|
220
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input.directive.js","sourceRoot":"","sources":["../../../../projects/ui-common/form-field/input.directive.ts"],"names":[],"mappings":";AAAA,OAAO,EAAgB,qBAAqB,EAAE,MAAM,uBAAuB,CAAA;AAC3E,OAAO,EAAE,SAAS,EAAuB,WAAW,EAAE,KAAK,EAAE,QAAQ,EAAE,IAAI,EAAE,MAAM,eAAe,CAAA;AAElG,OAAO,EAAE,OAAO,EAAE,MAAM,MAAM,CAAA;AAI9B,OAAO,EAAE,YAAY,EAAE,MAAM,yBAAyB,CAAA;AACtD,OAAO,EAAE,eAAe,EAAE,MAAM,0BAA0B,CAAA;;;;AAE1D,8GAA8G;AAE9G,IAAI,YAAY,GAAG,CAAC,CAAA;AAQpB,MAAM,OAAO,cAAc;IAWzB,IAA0C,mBAAmB;QAC3D,OAAO,IAAI,CAAC,cAAc,IAAI,IAAI,CAAC,aAAa,KAAK,IAAI,CAAA;IAC3D,CAAC;IACD,IAAqC,UAAU;QAC7C,OAAO,IAAI,CAAC,SAAS,IAAI,IAAI,CAAC,SAAS,CAAC,OAAO,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,KAAK,IAAI,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,CAAA;IACrG,CAAC;IAED,IAA4B,OAAO,KAAK,OAAO,IAAI,CAAC,WAAW,EAAE,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,IAAI,CAAC,EAAE,CAAA,CAAC,CAAC;IACzF,IAAqC,gBAAgB,KAAK,OAAO,IAAI,CAAC,WAAW,CAAA,CAAC,CAAC;IAKnF,IACI,EAAE,KAAgC,OAAO,IAAI,CAAC,GAAG,CAAA,CAAC,CAAC;IACvD,IAAI,EAAE,CAAC,KAAgC,IAAI,IAAI,CAAC,GAAG,GAAG,KAAK,IAAI,IAAI,CAAC,IAAI,CAAA,CAAC,CAAC;IAG1E,iCAAiC;IACjC,IACI,IAAI,KAAgC,OAAO,IAAI,CAAC,KAAK,CAAA,CAAC,CAAC;IAC3D,IAAI,IAAI,CAAC,KAAgC;QACvC,IAAI,CAAC,KAAK,GAAG,KAAK,IAAI,MAAM,CAAA;QAC5B,uBAAuB;QAEvB,+FAA+F;QAC/F,qFAAqF;QACrF,4FAA4F;QAC5F,IAAI,CAAC,CAAC,IAAI,CAAC,WAAW,EAAE,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC,CAAC,iDAAiD,EAAE;YACjG,IAAI,CAAC,WAAW,CAAC,aAAkC,CAAC,IAAI,GAAG,IAAI,CAAC,KAAK,CAAA;SACvE;IACH,CAAC;IAeD;;;OAGG;IACH,IACI,QAAQ;QACV,IAAI,IAAI,CAAC,SAAS,IAAI,IAAI,CAAC,SAAS,CAAC,QAAQ,KAAK,IAAI,EAAE;YACtD,OAAO,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAA;SAC/B;QACD,OAAO,IAAI,CAAC,SAAS,CAAA;IACvB,CAAC;IACD,IAAI,QAAQ,CAAC,KAAc;QACzB,IAAI,CAAC,SAAS,GAAG,qBAAqB,CAAC,KAAK,CAAC,CAAA;QAE7C,6EAA6E;QAC7E,mEAAmE;QACnE,IAAI,IAAI,CAAC,OAAO,EAAE;YAChB,IAAI,CAAC,OAAO,GAAG,KAAK,CAAA;YACpB,IAAI,CAAC,YAAY,CAAC,IAAI,EAAE,CAAA;SACzB;IACH,CAAC;IAmBD,YACS,WAAmF,EAC/D,SAAoB,EAC3B,WAAmB,EACnB,gBAAoC;IACxD,oBAAoB;IACA,SAA4B;QALzC,gBAAW,GAAX,WAAW,CAAwE;QAC/D,cAAS,GAAT,SAAS,CAAW;QAC3B,gBAAW,GAAX,WAAW,CAAQ;QACnB,qBAAgB,GAAhB,gBAAgB,CAAoB;QAEpC,cAAS,GAAT,SAAS,CAAmB;QAjGxC,SAAI,GAAG,aAAa,YAAY,EAAE,EAAE,CAAA;QAE9C,wEAAwE;QACxE,yEAAyE;QACzE,0EAA0E;QACvC,mBAAc,GAAG,IAAI,CAAA;QAY/C,kBAAa,GAAoB,QAAQ,CAAA;QAqBxC,UAAK,GAA8B,MAAM,CAAA;QAQnD;;;WAGG;QACsB,aAAQ,GAAG,KAAK,CAAA;QAuB/B,cAAS,GAAG,KAAK,CAAA;QAE3B,YAAO,GAAG,KAAK,CAAA;QAEN,iBAAY,GAAkB,IAAI,OAAO,EAAQ,CAAA;QAE1D,WAAW;QACX,iEAAiE;QACjE,6BAA6B;QAC7B,gCAAgC;QAChC,8CAA8C;QAC9C,gCAAgC;QAChC,MAAM;QACN,IAAI;QAEJ,uCAAuC;QACd,aAAQ,GAAG,KAAK,CAAA;QAUvC,0DAA0D;QAC1D,0CAA0C;QAC1C,IAAI,CAAC,EAAE,GAAG,IAAI,CAAC,EAAE,CAAA;QAEjB,IAAI,CAAC,IAAI,CAAC,8BAA8B,EAAE,EAAE;YAC1C,IAAI,CAAC,cAAc,GAAG,KAAK,CAAA;SAC5B;IACH,CAAC;IAED,SAAS;QACP,IAAI,IAAI,CAAC,WAAW,EAAE,EAAE;YACtB,IAAI,CAAC,SAAS,CAAC,UAAU,GAAG,IAAI,CAAC,EAAE,CAAA;YACnC,IAAI,CAAC,SAAS,CAAC,gBAAgB,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAA;SAC/C;aAAM;YACL,eAAe,CAAC,IAAI,CAAC,WAAW,CAAC,aAAa,EAAE,UAAU,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAA;YAC1E,eAAe,CAAC,IAAI,CAAC,WAAW,CAAC,aAAa,EAAE,UAAU,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAA;SAC3E;IACH,CAAC;IAED,uFAAuF;IAC7E,8BAA8B;QACtC,OAAO,CAAC,IAAI,CAAC,eAAe,EAAE;YAC5B,CAAC,IAAI,CAAC,aAAa,EAAE;YACrB,CAAC,IAAI,CAAC,gBAAgB,EAAE;YACxB,CAAC,IAAI,CAAC,WAAW,EAAE;YACnB,CAAC,IAAI,CAAC,cAAc,EAAE,CAAA;IAC1B,CAAC;IAED,sDAAsD;IAC5C,WAAW;QACnB,OAAO,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,QAAQ,CAAC,WAAW,EAAE,KAAK,UAAU,CAAA;IAC7E,CAAC;IAED,uDAAuD;IAC7C,WAAW;QACnB,OAAO,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,QAAQ,CAAC,WAAW,EAAE,KAAK,WAAW,CAAA;IAC9E,CAAC;IAED,2DAA2D;IACjD,eAAe;QACvB,OAAO,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,QAAQ,CAAC,WAAW,EAAE,KAAK,eAAe,CAAA;IAClF,CAAC;IAED,yDAAyD;IAC/C,aAAa;QACrB,OAAO,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,QAAQ,CAAC,WAAW,EAAE,KAAK,OAAO;YACtE,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,IAAI,CAAC,WAAW,EAAE,KAAK,OAAO,CAAA;IACjE,CAAC;IAES,gBAAgB;QACxB,OAAO,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,YAAY,CAAC,eAAe,CAAC,KAAK,IAAI,CAAA;IAC9E,CAAC;IAES,WAAW;QACnB,OAAO,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,QAAQ,CAAC,WAAW,EAAE,KAAK,gBAAgB,CAAA;IACnF,CAAC;IAES,cAAc;QACtB,OAAO,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,QAAQ,CAAC,WAAW,EAAE,KAAK,cAAc,CAAA;IACjF,CAAC;IAED,+CAA+C;IAC/C,8BAA8B;IAC9B,4DAA4D;IAC5D,wDAAwD;IACxD,MAAM;IACN,IAAI;IAEJ,yBAAyB;IACzB,KAAK;QACH,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,KAAK,EAAE,CAAA;IACxC,CAAC;IAED,2BAA2B;IAC3B,IAAI;QACF,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,IAAI,EAAE,CAAA;IACvC,CAAC;IAED,QAAQ,CAAC,KAAU;QACjB,IAAI,IAAI,CAAC,SAAS,EAAE;YAClB,MAAM,OAAO,GAAG,IAAI,CAAC,SAAS,CAAC,OAAO,CAAA;YACtC,IAAI,OAAO,EAAE;gBACX,OAAO,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAA;aACxB;SACF;IACH,CAAC;;2GA7LU,cAAc;+FAAd,cAAc;AAuDA;IAAf,YAAY,EAAE;gDAAiB;AAuChB;IAAf,YAAY,EAAE;gDAAiB;2FA9F9B,cAAc;kBAN1B,SAAS;mBAAC;oBACT,8EAA8E;oBAC9E,uDAAuD;oBACvD,QAAQ,EAAE,wLAAwL;oBAClM,QAAQ,EAAE,WAAW;iBACtB;;0BAmGI,QAAQ;;0BAAI,IAAI;;0BAChB,QAAQ;;0BACR,QAAQ;;0BAER,QAAQ;4CA5FwB,cAAc;sBAAhD,WAAW;uBAAC,oBAAoB;gBACS,mBAAmB;sBAA5D,WAAW;uBAAC,uBAAuB;gBAGC,UAAU;sBAA9C,WAAW;uBAAC,kBAAkB;gBAIH,OAAO;sBAAlC,WAAW;uBAAC,SAAS;gBACe,gBAAgB;sBAApD,WAAW;uBAAC,kBAAkB;gBACO,eAAe;sBAApD,WAAW;uBAAC,uBAAuB;gBAE3B,aAAa;sBAArB,KAAK;gBAGF,EAAE;sBADL,KAAK;gBAOF,IAAI;sBADP,KAAK;gBAmBG,WAAW;sBAAnB,KAAK;gBAMmB,QAAQ;sBAAhC,KAAK;gBAOF,QAAQ;sBADX,KAAK;gBAiCmB,QAAQ;sBAAhC,KAAK","sourcesContent":["import { BooleanInput, coerceBooleanProperty } from '@angular/cdk/coercion'\nimport { Directive, DoCheck, ElementRef, HostBinding, Input, Optional, Self } from '@angular/core'\nimport { FormGroupDirective, NgControl, NgForm } from '@angular/forms'\nimport { Subject } from 'rxjs'\n\nimport { NgSelectComponent } from '@ng-select/ng-select'\n\nimport { InputBoolean } from '@theseam/ui-common/core'\nimport { toggleAttribute } from '@theseam/ui-common/utils'\n\n// NOTE: Partially based on mat-input: https://github.com/angular/material2/blob/master/src/lib/input/input.ts\n\nlet nextUniqueId = 0\n\n@Directive({\n  // TODO: Consider removing restriction and instead adding a dev warning. A few\n  // inputs in the app need to be changed for this first.\n  selector: 'input[seamInput], textarea[seamInput], ng-select[seamInput], seam-checkbox[seamInput] [ngbRadioGroup], seam-tel-input[seamInput], quill-editor[seamInput], seam-google-maps[seamInput]',\n  exportAs: 'seamInput',\n})\nexport class InputDirective implements DoCheck {\n  static ngAcceptInputType_required: BooleanInput\n  static ngAcceptInputType_disabled: BooleanInput\n  static ngAcceptInputType_readonly: BooleanInput\n\n  protected _uid = `lib-input-${nextUniqueId++}`\n\n  // TODO: Remove this being added to all seamInput elements or break this\n  // directive up. Some elements in our app already have worked around this\n  // class being there, so some refactoring will be required before removal.\n  @HostBinding('class.form-control') _isFormControl = true\n  @HostBinding('class.form-control-sm') get _isFormControlSmall() {\n    return this._isFormControl && this.seamInputSize === 'sm'\n  }\n  @HostBinding('class.is-invalid') get _isInvalid() {\n    return this.ngControl && this.ngControl.invalid && (this.ngControl.dirty || this.ngControl.touched)\n  }\n\n  @HostBinding('attr.id') get _attrId() { return this._isNgSelect() ? undefined : this.id }\n  @HostBinding('attr.placeholder') get _attrPlaceholder() { return this.placeholder }\n  @HostBinding('attr.aria-describedby') ariaDescribedBy: string | undefined\n\n  @Input() seamInputSize: 'sm' | 'normal' = 'normal'\n\n  @Input()\n  get id(): string | undefined | null { return this._id }\n  set id(value: string | undefined | null) { this._id = value || this._uid }\n  protected _id: string | undefined | null\n\n  /** Input type of the element. */\n  @Input()\n  get type(): string | undefined | null { return this._type }\n  set type(value: string | undefined | null) {\n    this._type = value || 'text'\n    // this._validateType()\n\n    // When using Angular inputs, developers are no longer able to set the properties on the native\n    // input element. To ensure that bindings for `type` work, we need to sync the setter\n    // with the native property. Textarea elements don't support the type property or attribute.\n    if ((!this._isTextarea() && !this._isNgSelect()) /* && getSupportedInputTypes().has(this._type) */) {\n      (this._elementRef.nativeElement as HTMLInputElement).type = this._type\n    }\n  }\n  protected _type: string | undefined | null = 'text'\n\n  /**\n   * Implemented as part of MatFormFieldControl.\n   * @docs-private\n   */\n  @Input() placeholder: string | undefined | null\n\n  /**\n   * Implemented as part of MatFormFieldControl.\n   * @docs-private\n   */\n  @Input() @InputBoolean() required = false\n\n  /**\n   * Implemented as part of MatFormFieldControl.\n   * @docs-private\n   */\n  @Input()\n  get disabled(): boolean {\n    if (this.ngControl && this.ngControl.disabled !== null) {\n      return this.ngControl.disabled\n    }\n    return this._disabled\n  }\n  set disabled(value: boolean) {\n    this._disabled = coerceBooleanProperty(value)\n\n    // Browsers may not fire the blur event if the input is disabled too quickly.\n    // Reset from here to ensure that the element doesn't become stuck.\n    if (this.focused) {\n      this.focused = false\n      this.stateChanges.next()\n    }\n  }\n  protected _disabled = false\n\n  focused = false\n\n  readonly stateChanges: Subject<void> = new Subject<void>()\n\n  // @Input()\n  // get value(): string { return this._inputValueAccessor.value; }\n  // set value(value: string) {\n  //   if (value !== this.value) {\n  //     this._inputValueAccessor.value = value;\n  //     this.stateChanges.next();\n  //   }\n  // }\n\n  /** Whether the element is readonly. */\n  @Input() @InputBoolean() readonly = false\n\n  constructor(\n    public _elementRef: ElementRef<HTMLInputElement | HTMLSelectElement | HTMLTextAreaElement>,\n    @Optional() @Self() public ngControl: NgControl,\n    @Optional() private _parentForm: NgForm,\n    @Optional() private _parentFormGroup: FormGroupDirective,\n    // 3rd party support\n    @Optional() private _ngSelect: NgSelectComponent\n  ) {\n    // Force setter to be called in case id was not specified.\n    // eslint-disable-next-line no-self-assign\n    this.id = this.id\n\n    if (!this._shouldHaveFormControlCssClass()) {\n      this._isFormControl = false\n    }\n  }\n\n  ngDoCheck() {\n    if (this._isNgSelect()) {\n      this._ngSelect.labelForId = this.id\n      this._ngSelect.setDisabledState(this.disabled)\n    } else {\n      toggleAttribute(this._elementRef.nativeElement, 'required', this.required)\n      toggleAttribute(this._elementRef.nativeElement, 'disabled', this.disabled)\n    }\n  }\n\n  /** Should only be textual inputs, but initially our app added to all form controls. */\n  protected _shouldHaveFormControlCssClass() {\n    return !this._isSeamCheckbox() &&\n      !this._isRadioInput() &&\n      !this._isNgbRadioGroup() &&\n      !this._isTelInput() &&\n      !this._isQuillEditor()\n  }\n\n  /** Determines if the component host is a textarea. */\n  protected _isTextarea() {\n    return this._elementRef.nativeElement.nodeName.toLowerCase() === 'textarea'\n  }\n\n  /** Determines if the component host is a ng-select. */\n  protected _isNgSelect() {\n    return this._elementRef.nativeElement.nodeName.toLowerCase() === 'ng-select'\n  }\n\n  /** Determines if the component host is a seam-checkbox. */\n  protected _isSeamCheckbox() {\n    return this._elementRef.nativeElement.nodeName.toLowerCase() === 'seam-checkbox'\n  }\n\n  /** Determines if the component host is a radio input. */\n  protected _isRadioInput() {\n    return this._elementRef.nativeElement.nodeName.toLowerCase() === 'input' &&\n      this._elementRef.nativeElement.type.toLowerCase() === 'radio'\n  }\n\n  protected _isNgbRadioGroup() {\n    return this._elementRef.nativeElement.getAttribute('ngbRadioGroup') !== null\n  }\n\n  protected _isTelInput() {\n    return this._elementRef.nativeElement.nodeName.toLowerCase() === 'seam-tel-input'\n  }\n\n  protected _isQuillEditor() {\n    return this._elementRef.nativeElement.nodeName.toLowerCase() === 'quill-editor'\n  }\n\n  /** Make sure the input is a supported type. */\n  // protected _validateType() {\n  //   if (MAT_INPUT_INVALID_TYPES.indexOf(this._type) > -1) {\n  //     throw getMatInputUnsupportedTypeError(this._type)\n  //   }\n  // }\n\n  /** Focuses the input. */\n  focus(): void {\n    this._elementRef.nativeElement.focus()\n  }\n\n  /** Unfocuses the input. */\n  blur(): void {\n    this._elementRef.nativeElement.blur()\n  }\n\n  setValue(value: any) {\n    if (this.ngControl) {\n      const control = this.ngControl.control\n      if (control) {\n        control.setValue(value)\n      }\n    }\n  }\n\n}\n"]}
|
|
223
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input.directive.js","sourceRoot":"","sources":["../../../../projects/ui-common/form-field/input.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { BooleanInput, coerceBooleanProperty } from '@angular/cdk/coercion'\nimport { Directive, DoCheck, ElementRef, HostBinding, Input, OnChanges, Optional, Self, SimpleChanges } from '@angular/core'\nimport { FormGroupDirective, NgControl, NgForm } from '@angular/forms'\nimport { Subject } from 'rxjs'\n\nimport { NgSelectComponent } from '@ng-select/ng-select'\n\nimport { InputBoolean } from '@theseam/ui-common/core'\nimport { toggleAttribute } from '@theseam/ui-common/utils'\n\n// NOTE: Partially based on mat-input: https://github.com/angular/material2/blob/master/src/lib/input/input.ts\n\nlet nextUniqueId = 0\n\n@Directive({\n  // TODO: Consider removing restriction and instead adding a dev warning. A few\n  // inputs in the app need to be changed for this first.\n  selector: 'input[seamInput], textarea[seamInput], ng-select[seamInput], seam-checkbox[seamInput] [ngbRadioGroup], seam-tel-input[seamInput], quill-editor[seamInput], seam-google-maps[seamInput]',\n  exportAs: 'seamInput',\n})\nexport class InputDirective implements DoCheck, OnChanges {\n  static ngAcceptInputType_required: BooleanInput\n  static ngAcceptInputType_disabled: BooleanInput\n  static ngAcceptInputType_readonly: BooleanInput\n\n  protected _uid = `lib-input-${nextUniqueId++}`\n\n  // TODO: Remove this being added to all seamInput elements or break this\n  // directive up. Some elements in our app already have worked around this\n  // class being there, so some refactoring will be required before removal.\n  @HostBinding('class.form-control') _isFormControl = true\n  @HostBinding('class.form-control-sm') get _isFormControlSmall() {\n    return this._isFormControl && this.seamInputSize === 'sm'\n  }\n  @HostBinding('class.is-invalid') get _isInvalid() {\n    return this.ngControl && this.ngControl.invalid && (this.ngControl.dirty || this.ngControl.touched)\n  }\n\n  @HostBinding('attr.id') get _attrId() { return this._isNgSelect() ? undefined : this.id }\n  @HostBinding('attr.placeholder') get _attrPlaceholder() { return this.placeholder }\n  @HostBinding('attr.aria-describedby') ariaDescribedBy: string | undefined\n\n  @Input() seamInputSize: 'sm' | 'normal' = 'normal'\n\n  @Input()\n  get id(): string | undefined | null { return this._id }\n  set id(value: string | undefined | null) { this._id = value || this._uid }\n  protected _id: string | undefined | null\n\n  /** Input type of the element. */\n  @Input()\n  get type(): string | undefined | null { return this._type }\n  set type(value: string | undefined | null) {\n    this._type = value || 'text'\n    // this._validateType()\n\n    // When using Angular inputs, developers are no longer able to set the properties on the native\n    // input element. To ensure that bindings for `type` work, we need to sync the setter\n    // with the native property. Textarea elements don't support the type property or attribute.\n    if ((!this._isTextarea() && !this._isNgSelect()) /* && getSupportedInputTypes().has(this._type) */) {\n      (this._elementRef.nativeElement as HTMLInputElement).type = this._type\n    }\n  }\n  protected _type: string | undefined | null = 'text'\n\n  @Input() placeholder: string | undefined | null\n\n  @Input() @InputBoolean() required = false\n\n  @Input()\n  get disabled(): boolean {\n    if (this.ngControl && this.ngControl.disabled !== null) {\n      return this.ngControl.disabled\n    }\n    return this._disabled\n  }\n  set disabled(value: boolean) {\n    this._disabled = coerceBooleanProperty(value)\n\n    // Browsers may not fire the blur event if the input is disabled too quickly.\n    // Reset from here to ensure that the element doesn't become stuck.\n    if (this.focused) {\n      this.focused = false\n      this.stateChanges.next()\n    }\n  }\n  protected _disabled = false\n\n  focused = false\n\n  readonly stateChanges: Subject<void> = new Subject<void>()\n\n  // @Input()\n  // get value(): string { return this._inputValueAccessor.value; }\n  // set value(value: string) {\n  //   if (value !== this.value) {\n  //     this._inputValueAccessor.value = value;\n  //     this.stateChanges.next();\n  //   }\n  // }\n\n  /** Whether the element is readonly. */\n  @Input() @InputBoolean() readonly = false\n\n  private readonly _requiredChange = new Subject<boolean>()\n  private readonly _disabledChange = new Subject<boolean>()\n  private readonly _readonlyChange = new Subject<boolean>()\n\n  public readonly requiredChange = this._requiredChange.asObservable()\n  public readonly disabledChange = this._disabledChange.asObservable()\n  public readonly readonlyChange = this._readonlyChange.asObservable\n\n  constructor(\n    public _elementRef: ElementRef<HTMLInputElement | HTMLSelectElement | HTMLTextAreaElement>,\n    @Optional() @Self() public ngControl: NgControl,\n    @Optional() private _parentForm: NgForm,\n    @Optional() private _parentFormGroup: FormGroupDirective,\n    // 3rd party support\n    @Optional() private _ngSelect: NgSelectComponent\n  ) {\n    // Force setter to be called in case id was not specified.\n    // eslint-disable-next-line no-self-assign\n    this.id = this.id\n\n    if (!this._shouldHaveFormControlCssClass()) {\n      this._isFormControl = false\n    }\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes.required) {\n      this._requiredChange.next(this.required)\n    }\n    if (changes.disabled) {\n      this._disabledChange.next(this.disabled)\n    }\n    if (changes.readonly) {\n      this._readonlyChange.next(this.readonly)\n    }\n  }\n\n  ngDoCheck() {\n    if (this._isNgSelect()) {\n      this._ngSelect.labelForId = this.id\n      this._ngSelect.setDisabledState(this.disabled)\n    } else {\n      toggleAttribute(this._elementRef.nativeElement, 'required', this.required)\n      toggleAttribute(this._elementRef.nativeElement, 'disabled', this.disabled)\n    }\n  }\n\n  /** Should only be textual inputs, but initially our app added to all form controls. */\n  protected _shouldHaveFormControlCssClass() {\n    return !this._isSeamCheckbox() &&\n      !this._isRadioInput() &&\n      !this._isNgbRadioGroup() &&\n      !this._isTelInput() &&\n      !this._isQuillEditor()\n  }\n\n  /** Determines if the component host is a textarea. */\n  protected _isTextarea() {\n    return this._elementRef.nativeElement.nodeName.toLowerCase() === 'textarea'\n  }\n\n  /** Determines if the component host is a ng-select. */\n  protected _isNgSelect() {\n    return this._elementRef.nativeElement.nodeName.toLowerCase() === 'ng-select'\n  }\n\n  /** Determines if the component host is a seam-checkbox. */\n  protected _isSeamCheckbox() {\n    return this._elementRef.nativeElement.nodeName.toLowerCase() === 'seam-checkbox'\n  }\n\n  /** Determines if the component host is a radio input. */\n  protected _isRadioInput() {\n    return this._elementRef.nativeElement.nodeName.toLowerCase() === 'input' &&\n      this._elementRef.nativeElement.type.toLowerCase() === 'radio'\n  }\n\n  protected _isNgbRadioGroup() {\n    return this._elementRef.nativeElement.getAttribute('ngbRadioGroup') !== null\n  }\n\n  protected _isTelInput() {\n    return this._elementRef.nativeElement.nodeName.toLowerCase() === 'seam-tel-input'\n  }\n\n  protected _isQuillEditor() {\n    return this._elementRef.nativeElement.nodeName.toLowerCase() === 'quill-editor'\n  }\n\n  /** Focuses the input. */\n  focus(): void {\n    this._elementRef.nativeElement.focus()\n  }\n\n  /** Unfocuses the input. */\n  blur(): void {\n    this._elementRef.nativeElement.blur()\n  }\n\n  setValue(value: any) {\n    if (this.ngControl) {\n      const control = this.ngControl.control\n      if (control) {\n        control.setValue(value)\n      }\n    }\n  }\n\n}\n"]}
|