@sd-angular/core 0.0.901 → 0.0.905
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/bundles/sd-angular-core-grid-material.umd.js +219 -61
- package/bundles/sd-angular-core-grid-material.umd.js.map +1 -1
- package/bundles/sd-angular-core-grid-material.umd.min.js +2 -2
- package/bundles/sd-angular-core-grid-material.umd.min.js.map +1 -1
- package/bundles/sd-angular-core-select.umd.js +10 -2
- package/bundles/sd-angular-core-select.umd.js.map +1 -1
- package/bundles/sd-angular-core-select.umd.min.js +1 -1
- package/bundles/sd-angular-core-select.umd.min.js.map +1 -1
- package/bundles/sd-angular-core-setting.umd.js +2 -2
- package/bundles/sd-angular-core-setting.umd.js.map +1 -1
- package/bundles/sd-angular-core-setting.umd.min.js +1 -1
- package/bundles/sd-angular-core-setting.umd.min.js.map +1 -1
- package/bundles/sd-angular-core-tab-router.umd.js +11 -8
- package/bundles/sd-angular-core-tab-router.umd.js.map +1 -1
- package/bundles/sd-angular-core-tab-router.umd.min.js +1 -1
- package/bundles/sd-angular-core-tab-router.umd.min.js.map +1 -1
- package/esm2015/grid-material/sd-angular-core-grid-material.js +20 -18
- package/esm2015/grid-material/src/lib/components/desktop-cell-view/desktop-cell-view.component.js +2 -2
- package/esm2015/grid-material/src/lib/components/dynamic-column/dynamic-column.component.js +98 -0
- package/esm2015/grid-material/src/lib/components/popup-grid-configuration/popup-grid-configuration.component.js +23 -5
- package/esm2015/grid-material/src/lib/grid-material.component.js +1 -2
- package/esm2015/grid-material/src/lib/grid-material.module.js +8 -2
- package/esm2015/grid-material/src/lib/models/grid-column.model.js +1 -1
- package/esm2015/grid-material/src/lib/models/grid-config.model.js +1 -1
- package/esm2015/grid-material/src/lib/pipes/column-badge.pipe.js +4 -1
- package/esm2015/grid-material/src/lib/pipes/column-transform.pipe.js +5 -1
- package/esm2015/grid-material/src/lib/services/generated-column/generated-column.model.js +2 -0
- package/esm2015/grid-material/src/lib/services/generated-column/generated-column.service.js +57 -0
- package/esm2015/grid-material/src/lib/services/grid-configuration.service.js +13 -18
- package/esm2015/select/src/lib/select.component.js +11 -3
- package/esm2015/setting/src/lib/setting.model.js +1 -1
- package/esm2015/setting/src/lib/setting.service.js +5 -5
- package/esm2015/tab-router/src/lib/components/tab-router-outlet/tab-router-outlet.component.js +21 -18
- package/fesm2015/sd-angular-core-grid-material.js +196 -34
- package/fesm2015/sd-angular-core-grid-material.js.map +1 -1
- package/fesm2015/sd-angular-core-select.js +10 -2
- package/fesm2015/sd-angular-core-select.js.map +1 -1
- package/fesm2015/sd-angular-core-setting.js +4 -4
- package/fesm2015/sd-angular-core-setting.js.map +1 -1
- package/fesm2015/sd-angular-core-tab-router.js +11 -8
- package/fesm2015/sd-angular-core-tab-router.js.map +1 -1
- package/grid-material/sd-angular-core-grid-material.d.ts +19 -17
- package/grid-material/sd-angular-core-grid-material.metadata.json +1 -1
- package/grid-material/src/lib/components/dynamic-column/dynamic-column.component.d.ts +32 -0
- package/grid-material/src/lib/components/popup-grid-configuration/popup-grid-configuration.component.d.ts +9 -0
- package/grid-material/src/lib/models/grid-column.model.d.ts +2 -0
- package/grid-material/src/lib/models/grid-config.model.d.ts +11 -1
- package/grid-material/src/lib/services/generated-column/generated-column.model.d.ts +8 -0
- package/grid-material/src/lib/services/generated-column/generated-column.service.d.ts +10 -0
- package/package.json +1 -1
- package/{sd-angular-core-0.0.901.tgz → sd-angular-core-0.0.905.tgz} +0 -0
- package/setting/src/lib/setting.model.d.ts +2 -2
- package/tab-router/src/lib/components/tab-router-outlet/tab-router-outlet.component.d.ts +7 -7
|
@@ -5,6 +5,7 @@ export * from './index';
|
|
|
5
5
|
export { SdDesktopCellChildrenView as ɵk } from './src/lib/components/desktop-cell-children-view/desktop-cell-children-view.component';
|
|
6
6
|
export { SdDesktopCellView as ɵj } from './src/lib/components/desktop-cell-view/desktop-cell-view.component';
|
|
7
7
|
export { SdDesktopCommand as ɵl } from './src/lib/components/desktop-command/desktop-command.component';
|
|
8
|
+
export { SdDynamicColumn as ɵo } from './src/lib/components/dynamic-column/dynamic-column.component';
|
|
8
9
|
export { SdGridFilter as ɵb } from './src/lib/components/grid-filter/grid-filter.component';
|
|
9
10
|
export { SdPopupExport as ɵe } from './src/lib/components/popup-export/popup-export.component';
|
|
10
11
|
export { SdPopupFilter as ɵc } from './src/lib/components/popup-filter/popup-filter.component';
|
|
@@ -12,24 +13,25 @@ export { SdPopupGridConfiguration as ɵn } from './src/lib/components/popup-grid
|
|
|
12
13
|
export { SdLetDirective as ɵm } from './src/lib/directives/sd-let.directive';
|
|
13
14
|
export { MatPaginatorIntlCro as ɵa } from './src/lib/grid-material.module';
|
|
14
15
|
export { GRID_MATERIAL_CONFIG as ɵg } from './src/lib/models/grid-configuration.model';
|
|
15
|
-
export { SdColumnBadgePipe as
|
|
16
|
-
export { SdColumnChildrenFilterPipe as
|
|
17
|
-
export { SdColumnHtmlTemplatePipe as
|
|
18
|
-
export { SdColumnTitlePipe as
|
|
19
|
-
export { SdColumnTooltipPipe as
|
|
20
|
-
export { SdColumnTransformPipe as
|
|
21
|
-
export { SdColumnValuesPipe as
|
|
22
|
-
export { SdCommandDisablePipe as
|
|
23
|
-
export { SdCommandFilterPipe as
|
|
24
|
-
export { SdCommandIconPipe as
|
|
25
|
-
export { SdCommandTitlePipe as
|
|
26
|
-
export { SdFilterColumnPipe as
|
|
27
|
-
export { SdFilterExternalPipe as
|
|
28
|
-
export { SdGridConfigurationResultPipe as
|
|
29
|
-
export { SdSelectionActionFilterPipe as
|
|
30
|
-
export { SdSelectionDisableSelectAllPipe as
|
|
31
|
-
export { SdSelectionDisablePipe as
|
|
16
|
+
export { SdColumnBadgePipe as ɵbb } from './src/lib/pipes/column-badge.pipe';
|
|
17
|
+
export { SdColumnChildrenFilterPipe as ɵr } from './src/lib/pipes/column-children-filter.pipe';
|
|
18
|
+
export { SdColumnHtmlTemplatePipe as ɵy } from './src/lib/pipes/column-html-template.pipe';
|
|
19
|
+
export { SdColumnTitlePipe as ɵs } from './src/lib/pipes/column-title.pipe';
|
|
20
|
+
export { SdColumnTooltipPipe as ɵba } from './src/lib/pipes/column-tooltip.pipe';
|
|
21
|
+
export { SdColumnTransformPipe as ɵz } from './src/lib/pipes/column-transform.pipe';
|
|
22
|
+
export { SdColumnValuesPipe as ɵx } from './src/lib/pipes/column-values.pipe';
|
|
23
|
+
export { SdCommandDisablePipe as ɵu } from './src/lib/pipes/command-disable.pipe';
|
|
24
|
+
export { SdCommandFilterPipe as ɵt } from './src/lib/pipes/command-filter.pipe';
|
|
25
|
+
export { SdCommandIconPipe as ɵv } from './src/lib/pipes/command-icon.pipe';
|
|
26
|
+
export { SdCommandTitlePipe as ɵw } from './src/lib/pipes/command-title.pipe';
|
|
27
|
+
export { SdFilterColumnPipe as ɵbc } from './src/lib/pipes/filter-column.pipe';
|
|
28
|
+
export { SdFilterExternalPipe as ɵbd } from './src/lib/pipes/filter-external.pipe';
|
|
29
|
+
export { SdGridConfigurationResultPipe as ɵq } from './src/lib/pipes/grid-configuration-result.pipe';
|
|
30
|
+
export { SdSelectionActionFilterPipe as ɵbe } from './src/lib/pipes/selection-action-filter.pipe';
|
|
31
|
+
export { SdSelectionDisableSelectAllPipe as ɵbg } from './src/lib/pipes/selection-disable-select-all.pipe';
|
|
32
|
+
export { SdSelectionDisablePipe as ɵbf } from './src/lib/pipes/selection-disable.pipe';
|
|
33
|
+
export { SdGeneratedColumnService as ɵp } from './src/lib/services/generated-column/generated-column.service';
|
|
32
34
|
export { SdGridConfigurationService as ɵh } from './src/lib/services/grid-configuration.service';
|
|
33
35
|
export { SdGridFilterService as ɵd } from './src/lib/services/grid-filter.service';
|
|
34
36
|
export { SdGridService as ɵi } from './src/lib/services/grid.service';
|
|
35
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
37
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2QtYW5ndWxhci1jb3JlLWdyaWQtbWF0ZXJpYWwuanMiLCJzb3VyY2VSb290IjoiQzovVXNlcnMvdXNlci9Eb2N1bWVudHMvbGliLWNvcmUtdWkvcHJvamVjdHMvc2QtY29yZS9ncmlkLW1hdGVyaWFsLyIsInNvdXJjZXMiOlsic2QtYW5ndWxhci1jb3JlLWdyaWQtbWF0ZXJpYWwudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFFSCxjQUFjLFNBQVMsQ0FBQztBQUV4QixPQUFPLEVBQUMseUJBQXlCLElBQUksRUFBRSxFQUFDLE1BQU0sc0ZBQXNGLENBQUM7QUFDckksT0FBTyxFQUFDLGlCQUFpQixJQUFJLEVBQUUsRUFBQyxNQUFNLG9FQUFvRSxDQUFDO0FBQzNHLE9BQU8sRUFBQyxnQkFBZ0IsSUFBSSxFQUFFLEVBQUMsTUFBTSxnRUFBZ0UsQ0FBQztBQUN0RyxPQUFPLEVBQUMsZUFBZSxJQUFJLEVBQUUsRUFBQyxNQUFNLDhEQUE4RCxDQUFDO0FBQ25HLE9BQU8sRUFBQyxZQUFZLElBQUksRUFBRSxFQUFDLE1BQU0sd0RBQXdELENBQUM7QUFDMUYsT0FBTyxFQUFDLGFBQWEsSUFBSSxFQUFFLEVBQUMsTUFBTSwwREFBMEQsQ0FBQztBQUM3RixPQUFPLEVBQUMsYUFBYSxJQUFJLEVBQUUsRUFBQyxNQUFNLDBEQUEwRCxDQUFDO0FBQzdGLE9BQU8sRUFBQyx3QkFBd0IsSUFBSSxFQUFFLEVBQUMsTUFBTSxrRkFBa0YsQ0FBQztBQUNoSSxPQUFPLEVBQUMsY0FBYyxJQUFJLEVBQUUsRUFBQyxNQUFNLHVDQUF1QyxDQUFDO0FBQzNFLE9BQU8sRUFBQyxtQkFBbUIsSUFBSSxFQUFFLEVBQUMsTUFBTSxnQ0FBZ0MsQ0FBQztBQUN6RSxPQUFPLEVBQUMsb0JBQW9CLElBQUksRUFBRSxFQUFvQyxNQUFNLDJDQUEyQyxDQUFDO0FBQ3hILE9BQU8sRUFBQyxpQkFBaUIsSUFBSSxHQUFHLEVBQUMsTUFBTSxtQ0FBbUMsQ0FBQztBQUMzRSxPQUFPLEVBQUMsMEJBQTBCLElBQUksRUFBRSxFQUFDLE1BQU0sNkNBQTZDLENBQUM7QUFDN0YsT0FBTyxFQUFDLHdCQUF3QixJQUFJLEVBQUUsRUFBQyxNQUFNLDJDQUEyQyxDQUFDO0FBQ3pGLE9BQU8sRUFBQyxpQkFBaUIsSUFBSSxFQUFFLEVBQUMsTUFBTSxtQ0FBbUMsQ0FBQztBQUMxRSxPQUFPLEVBQUMsbUJBQW1CLElBQUksR0FBRyxFQUFDLE1BQU0scUNBQXFDLENBQUM7QUFDL0UsT0FBTyxFQUFDLHFCQUFxQixJQUFJLEVBQUUsRUFBQyxNQUFNLHVDQUF1QyxDQUFDO0FBQ2xGLE9BQU8sRUFBQyxrQkFBa0IsSUFBSSxFQUFFLEVBQUMsTUFBTSxvQ0FBb0MsQ0FBQztBQUM1RSxPQUFPLEVBQUMsb0JBQW9CLElBQUksRUFBRSxFQUFDLE1BQU0sc0NBQXNDLENBQUM7QUFDaEYsT0FBTyxFQUFDLG1CQUFtQixJQUFJLEVBQUUsRUFBQyxNQUFNLHFDQUFxQyxDQUFDO0FBQzlFLE9BQU8sRUFBQyxpQkFBaUIsSUFBSSxFQUFFLEVBQUMsTUFBTSxtQ0FBbUMsQ0FBQztBQUMxRSxPQUFPLEVBQUMsa0JBQWtCLElBQUksRUFBRSxFQUFDLE1BQU0sb0NBQW9DLENBQUM7QUFDNUUsT0FBTyxFQUFDLGtCQUFrQixJQUFJLEdBQUcsRUFBQyxNQUFNLG9DQUFvQyxDQUFDO0FBQzdFLE9BQU8sRUFBQyxvQkFBb0IsSUFBSSxHQUFHLEVBQUMsTUFBTSxzQ0FBc0MsQ0FBQztBQUNqRixPQUFPLEVBQUMsNkJBQTZCLElBQUksRUFBRSxFQUFDLE1BQU0sZ0RBQWdELENBQUM7QUFDbkcsT0FBTyxFQUFDLDJCQUEyQixJQUFJLEdBQUcsRUFBQyxNQUFNLDhDQUE4QyxDQUFDO0FBQ2hHLE9BQU8sRUFBQywrQkFBK0IsSUFBSSxHQUFHLEVBQUMsTUFBTSxtREFBbUQsQ0FBQztBQUN6RyxPQUFPLEVBQUMsc0JBQXNCLElBQUksR0FBRyxFQUFDLE1BQU0sd0NBQXdDLENBQUM7QUFDckYsT0FBTyxFQUFDLHdCQUF3QixJQUFJLEVBQUUsRUFBQyxNQUFNLDhEQUE4RCxDQUFDO0FBQzVHLE9BQU8sRUFBQywwQkFBMEIsSUFBSSxFQUFFLEVBQUMsTUFBTSwrQ0FBK0MsQ0FBQztBQUMvRixPQUFPLEVBQUMsbUJBQW1CLElBQUksRUFBRSxFQUFDLE1BQU0sd0NBQXdDLENBQUM7QUFDakYsT0FBTyxFQUFDLGFBQWEsSUFBSSxFQUFFLEVBQUMsTUFBTSxpQ0FBaUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogR2VuZXJhdGVkIGJ1bmRsZSBpbmRleC4gRG8gbm90IGVkaXQuXG4gKi9cblxuZXhwb3J0ICogZnJvbSAnLi9pbmRleCc7XG5cbmV4cG9ydCB7U2REZXNrdG9wQ2VsbENoaWxkcmVuVmlldyBhcyDJtWt9IGZyb20gJy4vc3JjL2xpYi9jb21wb25lbnRzL2Rlc2t0b3AtY2VsbC1jaGlsZHJlbi12aWV3L2Rlc2t0b3AtY2VsbC1jaGlsZHJlbi12aWV3LmNvbXBvbmVudCc7XG5leHBvcnQge1NkRGVza3RvcENlbGxWaWV3IGFzIMm1an0gZnJvbSAnLi9zcmMvbGliL2NvbXBvbmVudHMvZGVza3RvcC1jZWxsLXZpZXcvZGVza3RvcC1jZWxsLXZpZXcuY29tcG9uZW50JztcbmV4cG9ydCB7U2REZXNrdG9wQ29tbWFuZCBhcyDJtWx9IGZyb20gJy4vc3JjL2xpYi9jb21wb25lbnRzL2Rlc2t0b3AtY29tbWFuZC9kZXNrdG9wLWNvbW1hbmQuY29tcG9uZW50JztcbmV4cG9ydCB7U2REeW5hbWljQ29sdW1uIGFzIMm1b30gZnJvbSAnLi9zcmMvbGliL2NvbXBvbmVudHMvZHluYW1pYy1jb2x1bW4vZHluYW1pYy1jb2x1bW4uY29tcG9uZW50JztcbmV4cG9ydCB7U2RHcmlkRmlsdGVyIGFzIMm1Yn0gZnJvbSAnLi9zcmMvbGliL2NvbXBvbmVudHMvZ3JpZC1maWx0ZXIvZ3JpZC1maWx0ZXIuY29tcG9uZW50JztcbmV4cG9ydCB7U2RQb3B1cEV4cG9ydCBhcyDJtWV9IGZyb20gJy4vc3JjL2xpYi9jb21wb25lbnRzL3BvcHVwLWV4cG9ydC9wb3B1cC1leHBvcnQuY29tcG9uZW50JztcbmV4cG9ydCB7U2RQb3B1cEZpbHRlciBhcyDJtWN9IGZyb20gJy4vc3JjL2xpYi9jb21wb25lbnRzL3BvcHVwLWZpbHRlci9wb3B1cC1maWx0ZXIuY29tcG9uZW50JztcbmV4cG9ydCB7U2RQb3B1cEdyaWRDb25maWd1cmF0aW9uIGFzIMm1bn0gZnJvbSAnLi9zcmMvbGliL2NvbXBvbmVudHMvcG9wdXAtZ3JpZC1jb25maWd1cmF0aW9uL3BvcHVwLWdyaWQtY29uZmlndXJhdGlvbi5jb21wb25lbnQnO1xuZXhwb3J0IHtTZExldERpcmVjdGl2ZSBhcyDJtW19IGZyb20gJy4vc3JjL2xpYi9kaXJlY3RpdmVzL3NkLWxldC5kaXJlY3RpdmUnO1xuZXhwb3J0IHtNYXRQYWdpbmF0b3JJbnRsQ3JvIGFzIMm1YX0gZnJvbSAnLi9zcmMvbGliL2dyaWQtbWF0ZXJpYWwubW9kdWxlJztcbmV4cG9ydCB7R1JJRF9NQVRFUklBTF9DT05GSUcgYXMgybVnLElTZEdyaWRNYXRlcmlhbENvbmZpZ3VyYXRpb24gYXMgybVmfSBmcm9tICcuL3NyYy9saWIvbW9kZWxzL2dyaWQtY29uZmlndXJhdGlvbi5tb2RlbCc7XG5leHBvcnQge1NkQ29sdW1uQmFkZ2VQaXBlIGFzIMm1YmJ9IGZyb20gJy4vc3JjL2xpYi9waXBlcy9jb2x1bW4tYmFkZ2UucGlwZSc7XG5leHBvcnQge1NkQ29sdW1uQ2hpbGRyZW5GaWx0ZXJQaXBlIGFzIMm1cn0gZnJvbSAnLi9zcmMvbGliL3BpcGVzL2NvbHVtbi1jaGlsZHJlbi1maWx0ZXIucGlwZSc7XG5leHBvcnQge1NkQ29sdW1uSHRtbFRlbXBsYXRlUGlwZSBhcyDJtXl9IGZyb20gJy4vc3JjL2xpYi9waXBlcy9jb2x1bW4taHRtbC10ZW1wbGF0ZS5waXBlJztcbmV4cG9ydCB7U2RDb2x1bW5UaXRsZVBpcGUgYXMgybVzfSBmcm9tICcuL3NyYy9saWIvcGlwZXMvY29sdW1uLXRpdGxlLnBpcGUnO1xuZXhwb3J0IHtTZENvbHVtblRvb2x0aXBQaXBlIGFzIMm1YmF9IGZyb20gJy4vc3JjL2xpYi9waXBlcy9jb2x1bW4tdG9vbHRpcC5waXBlJztcbmV4cG9ydCB7U2RDb2x1bW5UcmFuc2Zvcm1QaXBlIGFzIMm1en0gZnJvbSAnLi9zcmMvbGliL3BpcGVzL2NvbHVtbi10cmFuc2Zvcm0ucGlwZSc7XG5leHBvcnQge1NkQ29sdW1uVmFsdWVzUGlwZSBhcyDJtXh9IGZyb20gJy4vc3JjL2xpYi9waXBlcy9jb2x1bW4tdmFsdWVzLnBpcGUnO1xuZXhwb3J0IHtTZENvbW1hbmREaXNhYmxlUGlwZSBhcyDJtXV9IGZyb20gJy4vc3JjL2xpYi9waXBlcy9jb21tYW5kLWRpc2FibGUucGlwZSc7XG5leHBvcnQge1NkQ29tbWFuZEZpbHRlclBpcGUgYXMgybV0fSBmcm9tICcuL3NyYy9saWIvcGlwZXMvY29tbWFuZC1maWx0ZXIucGlwZSc7XG5leHBvcnQge1NkQ29tbWFuZEljb25QaXBlIGFzIMm1dn0gZnJvbSAnLi9zcmMvbGliL3BpcGVzL2NvbW1hbmQtaWNvbi5waXBlJztcbmV4cG9ydCB7U2RDb21tYW5kVGl0bGVQaXBlIGFzIMm1d30gZnJvbSAnLi9zcmMvbGliL3BpcGVzL2NvbW1hbmQtdGl0bGUucGlwZSc7XG5leHBvcnQge1NkRmlsdGVyQ29sdW1uUGlwZSBhcyDJtWJjfSBmcm9tICcuL3NyYy9saWIvcGlwZXMvZmlsdGVyLWNvbHVtbi5waXBlJztcbmV4cG9ydCB7U2RGaWx0ZXJFeHRlcm5hbFBpcGUgYXMgybViZH0gZnJvbSAnLi9zcmMvbGliL3BpcGVzL2ZpbHRlci1leHRlcm5hbC5waXBlJztcbmV4cG9ydCB7U2RHcmlkQ29uZmlndXJhdGlvblJlc3VsdFBpcGUgYXMgybVxfSBmcm9tICcuL3NyYy9saWIvcGlwZXMvZ3JpZC1jb25maWd1cmF0aW9uLXJlc3VsdC5waXBlJztcbmV4cG9ydCB7U2RTZWxlY3Rpb25BY3Rpb25GaWx0ZXJQaXBlIGFzIMm1YmV9IGZyb20gJy4vc3JjL2xpYi9waXBlcy9zZWxlY3Rpb24tYWN0aW9uLWZpbHRlci5waXBlJztcbmV4cG9ydCB7U2RTZWxlY3Rpb25EaXNhYmxlU2VsZWN0QWxsUGlwZSBhcyDJtWJnfSBmcm9tICcuL3NyYy9saWIvcGlwZXMvc2VsZWN0aW9uLWRpc2FibGUtc2VsZWN0LWFsbC5waXBlJztcbmV4cG9ydCB7U2RTZWxlY3Rpb25EaXNhYmxlUGlwZSBhcyDJtWJmfSBmcm9tICcuL3NyYy9saWIvcGlwZXMvc2VsZWN0aW9uLWRpc2FibGUucGlwZSc7XG5leHBvcnQge1NkR2VuZXJhdGVkQ29sdW1uU2VydmljZSBhcyDJtXB9IGZyb20gJy4vc3JjL2xpYi9zZXJ2aWNlcy9nZW5lcmF0ZWQtY29sdW1uL2dlbmVyYXRlZC1jb2x1bW4uc2VydmljZSc7XG5leHBvcnQge1NkR3JpZENvbmZpZ3VyYXRpb25TZXJ2aWNlIGFzIMm1aH0gZnJvbSAnLi9zcmMvbGliL3NlcnZpY2VzL2dyaWQtY29uZmlndXJhdGlvbi5zZXJ2aWNlJztcbmV4cG9ydCB7U2RHcmlkRmlsdGVyU2VydmljZSBhcyDJtWR9IGZyb20gJy4vc3JjL2xpYi9zZXJ2aWNlcy9ncmlkLWZpbHRlci5zZXJ2aWNlJztcbmV4cG9ydCB7U2RHcmlkU2VydmljZSBhcyDJtWl9IGZyb20gJy4vc3JjL2xpYi9zZXJ2aWNlcy9ncmlkLnNlcnZpY2UnOyJdfQ==
|
package/esm2015/grid-material/src/lib/components/desktop-cell-view/desktop-cell-view.component.js
CHANGED
|
@@ -5,7 +5,7 @@ export class SdDesktopCellView {
|
|
|
5
5
|
SdDesktopCellView.decorators = [
|
|
6
6
|
{ type: Component, args: [{
|
|
7
7
|
selector: 'sd-desktop-cell-view',
|
|
8
|
-
template: "<ng-container *ngIf=\"column && item\">\r\n <ng-container *ngIf=\"column.htmlTemplate;else useDefaultView\">\r\n <div (click)=\"column.click && column.click(item[column.field], item)\" style=\"overflow-wrap: break-word;\"\r\n [ngClass]=\"{'cursor-pointer':column.click}\"\r\n [innerHTML]=\"(item[column.field] | columnHtmlTemplate:item:column) | safeHtml\">\r\n </div>\r\n </ng-container>\r\n <ng-template #useDefaultView>\r\n <ng-container *sdLet=\"item[column.field] | columnBadge:item:column as badge\">\r\n <ng-container *ngIf=\"column.type === 'string'\">\r\n <ng-container *ngIf=\"!!badge\">\r\n <div *ngIf=\"!column.badgeType\" class=\"c-badge\" style=\"overflow-wrap: break-word;\" matTooltipPosition=\"above\"\r\n [matTooltip]=\"item[column.field] | columnTooltip:item:column\"\r\n [class]=\"{'c-secondary': badge === 'normal', 'c-info': badge === 'info', 'c-success': badge === 'success', 'c-danger': badge === 'danger', 'c-warning': badge === 'warning'}\">\r\n <span *ngIf=\"column.click\" class=\"pointer\"\r\n (click)=\"column.click(item[column.field], item)\">{{item[column.field] |\r\n columnTransform:item:column}}</span>\r\n <ng-container *ngIf=\"!column.click\">{{item[column.field] | columnTransform:item:column}}</ng-container>\r\n </div>\r\n <div *ngIf=\"column.badgeType === 'circle'\" style=\"min-width: 150px\"\r\n class=\"c-badge-circle d-flex align-items-center\"\r\n [class]=\"{'c-unknown': !badge, 'c-secondary': badge === 'normal', 'c-info': badge === 'info', 'c-success': badge === 'success', 'c-danger': badge === 'danger', 'c-warning': badge === 'warning'}\">\r\n <span *ngIf=\"badge\" class=\"material-icons-round c-material-icon mr-4\">\r\n fiber_manual_record\r\n </span>\r\n <span *ngIf=\"!badge\" class=\"material-icons-outlined c-material-icon mr-4\">\r\n fiber_manual_record\r\n </span>\r\n {{item[column.field] | columnTransform:item:column}}\r\n </div>\r\n </ng-container>\r\n <ng-container *ngIf=\"!badge\">\r\n <div style=\"overflow-wrap: break-word;\" [matTooltip]=\"item[column.field] | columnTooltip:item:column\">\r\n <a *ngIf=\"column.click\" href=\"javascript:;\"\r\n (click)=\"column.click(item[column.field], item)\">{{item[column.field] | columnTransform:item:column}}</a>\r\n <ng-container *ngIf=\"!column.click\">{{item[column.field] | columnTransform:item:column}}</ng-container>\r\n </div>\r\n </ng-container>\r\n </ng-container>\r\n
|
|
8
|
+
template: "<ng-container *ngIf=\"column && item\">\r\n <ng-container *ngIf=\"column.htmlTemplate;else useDefaultView\">\r\n <div (click)=\"column.click && column.click(item[column.field], item)\" style=\"overflow-wrap: break-word;\"\r\n [ngClass]=\"{'cursor-pointer':column.click}\"\r\n [innerHTML]=\"(item[column.field] | columnHtmlTemplate:item:column) | safeHtml\">\r\n </div>\r\n </ng-container>\r\n <ng-template #useDefaultView>\r\n <ng-container *sdLet=\"item[column.field] | columnBadge:item:column as badge\">\r\n <ng-container *ngIf=\"column.type === 'string'\">\r\n <ng-container *ngIf=\"!!badge\">\r\n <div *ngIf=\"!column.badgeType\" class=\"c-badge\" style=\"overflow-wrap: break-word;\" matTooltipPosition=\"above\"\r\n [matTooltip]=\"item[column.field] | columnTooltip:item:column\"\r\n [class]=\"{'c-secondary': badge === 'normal', 'c-info': badge === 'info', 'c-success': badge === 'success', 'c-danger': badge === 'danger', 'c-warning': badge === 'warning'}\">\r\n <span *ngIf=\"column.click\" class=\"pointer\"\r\n (click)=\"column.click(item[column.field], item)\">{{item[column.field] |\r\n columnTransform:item:column}}</span>\r\n <ng-container *ngIf=\"!column.click\">{{item[column.field] | columnTransform:item:column}}</ng-container>\r\n </div>\r\n <div *ngIf=\"column.badgeType === 'circle'\" style=\"min-width: 150px\"\r\n class=\"c-badge-circle d-flex align-items-center\"\r\n [class]=\"{'c-unknown': !badge, 'c-secondary': badge === 'normal', 'c-info': badge === 'info', 'c-success': badge === 'success', 'c-danger': badge === 'danger', 'c-warning': badge === 'warning'}\">\r\n <span *ngIf=\"badge\" class=\"material-icons-round c-material-icon mr-4\">\r\n fiber_manual_record\r\n </span>\r\n <span *ngIf=\"!badge\" class=\"material-icons-outlined c-material-icon mr-4\">\r\n fiber_manual_record\r\n </span>\r\n {{item[column.field] | columnTransform:item:column}}\r\n </div>\r\n </ng-container>\r\n <ng-container *ngIf=\"!badge\">\r\n <div style=\"overflow-wrap: break-word;\" [matTooltip]=\"item[column.field] | columnTooltip:item:column\">\r\n <a *ngIf=\"column.click\" href=\"javascript:;\"\r\n (click)=\"column.click(item[column.field], item)\">{{item[column.field] | columnTransform:item:column}}</a>\r\n <ng-container *ngIf=\"!column.click\">{{item[column.field] | columnTransform:item:column}}</ng-container>\r\n </div>\r\n </ng-container>\r\n </ng-container>\r\n <div *ngIf=\"column.type === 'number'\">\r\n <a *ngIf=\"column.click\" href=\"javascript:;\"\r\n (click)=\"column.click(item[column.field], item)\">{{item[column.field] | columnTransform:item:column}}</a>\r\n <ng-container *ngIf=\"!column.click\">\r\n {{item[column.field] | columnTransform:item:column}}</ng-container>\r\n </div>\r\n <div *ngIf=\"column.type === 'date'\" matTooltipPosition=\"above\"\r\n [matTooltip]=\"item[column.field] | date:'dd/MM/yyyy'\">\r\n {{item[column.field] | sdTimeDifferent:'dd/MM/yyyy':column.option?.timeDifferent | async}}\r\n </div>\r\n <div *ngIf=\"column.type === 'datetime'\" matTooltipPosition=\"above\"\r\n [matTooltip]=\"item[column.field] | date:'dd/MM/yyyy HH:mm'\">\r\n {{item[column.field] | sdTimeDifferent:'dd/MM/yyyy HH:mm':column.option?.timeDifferent | async}}\r\n </div>\r\n <div *ngIf=\"column.type === 'time'\">\r\n {{item[column.field] | date:'HH:mm'}}\r\n </div>\r\n <div *ngIf=\"column.type === 'bool'\" class=\"align-middle text-center\">\r\n <ng-container *ngIf=\"!!badge\">\r\n <div *ngIf=\"!column.badgeType\" class=\"c-badge\" style=\"overflow-wrap: break-word;\" matTooltipPosition=\"above\"\r\n [matTooltip]=\"item[column.field] | columnTooltip:item:column\"\r\n [class]=\"{'c-secondary': badge === 'normal', 'c-info': badge === 'info', 'c-success': badge === 'success', 'c-danger': badge === 'danger', 'c-warning': badge === 'warning'}\">\r\n <span *ngIf=\"column.click\" class=\"pointer\"\r\n (click)=\"column.click(item[column.field], item)\">{{item[column.field] | columnTransform:item:column}}</span>\r\n <ng-container *ngIf=\"!column.click\">{{item[column.field] | columnTransform:item:column}}</ng-container>\r\n </div>\r\n <div *ngIf=\"column.badgeType === 'circle'\" style=\"min-width: 150px\"\r\n class=\"c-badge-circle d-flex align-items-center\"\r\n [class]=\"{'c-unknown': !badge, 'c-secondary': badge === 'normal', 'c-info': badge === 'info', 'c-success': badge === 'success', 'c-danger': badge === 'danger', 'c-warning': badge === 'warning'}\">\r\n <span *ngIf=\"badge\" class=\"material-icons-round c-material-icon mr-4\">\r\n fiber_manual_record\r\n </span>\r\n <span *ngIf=\"!badge\" class=\"material-icons-outlined c-material-icon mr-4\">\r\n fiber_manual_record\r\n </span>\r\n {{item[column.field] | columnTransform:item:column}}\r\n </div>\r\n </ng-container>\r\n <ng-container *ngIf=\"!badge\">\r\n <span *ngIf=\"item[column.field]\" class=\"font-weight-bold c-color-success\">{{item[column.field] | columnTransform:item:column}}</span>\r\n <span *ngIf=\"!item[column.field]\" class=\"font-weight-bold c-color-danger\">{{item[column.field] | columnTransform:item:column}}</span>\r\n </ng-container>\r\n </div>\r\n <div *ngIf=\"column.type === 'values'\">\r\n <ng-container *ngIf=\"item[column.field] | columnValues:column:key | async; $implicit as valueData\">\r\n <div\r\n *ngIf=\"valueData[column.option?.colorField] || valueData[column.option?.backgroundColorField]; else elseNoStatus\"\r\n class=\"c-badge\"\r\n [ngStyle]=\"{'color':valueData[column.option?.colorField], 'background-color': valueData[column.option?.backgroundColorField]}\">\r\n {{valueData[column.option?.displayField]}}\r\n </div>\r\n <ng-template #elseNoStatus>\r\n <div class=\"text-left\">\r\n {{valueData[column.option?.displayField]}}\r\n </div>\r\n </ng-template>\r\n </ng-container>\r\n </div>\r\n <div *ngIf=\"column.type === 'image'\" class=\"align-middle text-center\">\r\n <img *ngIf=\"item[column.field]\" [src]=\"item[column.field] | columnTransform:item:column\"\r\n [width]=\"column.option?.width\" [height]=\"column.option?.height\" style=\"margin: 5px 0;object-fit: contain;\"\r\n (click)=\"column.click && column.click(item[column.field], item)\" [ngClass]=\"{'pointer':column.click}\">\r\n <mat-icon *ngIf=\"!item[column.field]\" class=\"c-img\" [ngClass]=\"{'pointer':column.click}\"\r\n (click)=\"column.click && column.click(item[column.field], item)\">image</mat-icon>\r\n </div>\r\n </ng-container>\r\n <sd-desktop-cell-children-view *ngIf=\"column.type === 'children'\" [key]=\"key\" [item]=\"item\" [column]=\"column\">\r\n </sd-desktop-cell-children-view>\r\n </ng-template>\r\n</ng-container>",
|
|
9
9
|
styles: [".c-color-success{color:#4caf50}.c-color-danger{color:#f82c13}.c-img{font-size:30px;opacity:.5}.c-img.pointer:hover{opacity:.9}.c-badge{border-radius:20px;display:inline-block;margin-bottom:4px;padding:2px 12px;text-align:center}.c-badge.c-warning{background:#fff3e0;color:#ff9600}.c-badge.c-info{background:#e7e9ff;color:#2962ff}.c-badge.c-success{background:#e8f5e9;color:#4caf50}.c-badge.c-danger{background:#fee8e7;color:#f82c13}.c-badge.c-normal{background:rgba(0,0,0,.12);color:#000}.wes-status .c-material-icon{font-size:12px;height:12px;width:12px}.wes-status.text-secondary .c-material-icon{color:rgba(0,0,0,.5)}.c-badge-circle .c-material-icon{font-size:12px;height:12px;width:12px}.c-badge-circle.c-unknown{color:#212121}.c-badge-circle.c-unknown .c-material-icon{color:rgba(0,0,0,.5)}.c-badge-circle.c-secondary{color:#212121}.c-badge-circle.c-info{color:#2962ff}.c-badge-circle.c-success{color:#4caf50}.c-badge-circle.c-danger{color:#f82c13}.c-badge-circle.c-warning{color:#ff9600}"]
|
|
10
10
|
},] }
|
|
11
11
|
];
|
|
@@ -15,4 +15,4 @@ SdDesktopCellView.propDecorators = {
|
|
|
15
15
|
column: [{ type: Input }],
|
|
16
16
|
item: [{ type: Input }]
|
|
17
17
|
};
|
|
18
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
18
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGVza3RvcC1jZWxsLXZpZXcuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IkM6L1VzZXJzL3VzZXIvRG9jdW1lbnRzL2xpYi1jb3JlLXVpL3Byb2plY3RzL3NkLWNvcmUvZ3JpZC1tYXRlcmlhbC8iLCJzb3VyY2VzIjpbInNyYy9saWIvY29tcG9uZW50cy9kZXNrdG9wLWNlbGwtdmlldy9kZXNrdG9wLWNlbGwtdmlldy5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxLQUFLLEVBQWEsTUFBTSxlQUFlLENBQUM7QUFRNUQsTUFBTSxPQUFPLGlCQUFpQjtJQUk1QixnQkFDSSxDQUFDOzs7WUFWTixTQUFTLFNBQUM7Z0JBQ1QsUUFBUSxFQUFFLHNCQUFzQjtnQkFDaEMsdXlPQUFpRDs7YUFFbEQ7Ozs7a0JBRUUsS0FBSztxQkFDTCxLQUFLO21CQUNMLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIElucHV0LCBRdWVyeUxpc3QgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgU2RHcmlkTWF0ZXJpYWxDb2x1bW4gfSBmcm9tICcuLi8uLi9tb2RlbHMvZ3JpZC1jb2x1bW4ubW9kZWwnO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgc2VsZWN0b3I6ICdzZC1kZXNrdG9wLWNlbGwtdmlldycsXHJcbiAgdGVtcGxhdGVVcmw6ICcuL2Rlc2t0b3AtY2VsbC12aWV3LmNvbXBvbmVudC5odG1sJyxcclxuICBzdHlsZVVybHM6IFsnLi9kZXNrdG9wLWNlbGwtdmlldy5jb21wb25lbnQuc2NzcyddXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBTZERlc2t0b3BDZWxsVmlldyB7XHJcbiAgQElucHV0KCkga2V5OiBzdHJpbmc7XHJcbiAgQElucHV0KCkgY29sdW1uOiBTZEdyaWRNYXRlcmlhbENvbHVtbjtcclxuICBASW5wdXQoKSBpdGVtOiBhbnk7XHJcbiAgY29uc3RydWN0b3IoXHJcbiAgKSB7IH1cclxufVxyXG4iXX0=
|
|
@@ -0,0 +1,98 @@
|
|
|
1
|
+
var _subscription;
|
|
2
|
+
import { __classPrivateFieldGet } from "tslib";
|
|
3
|
+
import { Component, ViewChild, ChangeDetectorRef, Input, ChangeDetectionStrategy } from '@angular/core';
|
|
4
|
+
import { SdNotifyService } from '@sd-angular/core/notify';
|
|
5
|
+
import { SdTranslateService } from '@sd-angular/core/translate';
|
|
6
|
+
import { SdGridConfigurationService } from '../../services/grid-configuration.service';
|
|
7
|
+
import * as uuid from 'uuid';
|
|
8
|
+
import { SdGeneratedColumnService } from '../../services/generated-column/generated-column.service';
|
|
9
|
+
import { Subscription } from 'rxjs';
|
|
10
|
+
import { FormGroup } from '@angular/forms';
|
|
11
|
+
import { SdSideDrawer } from '@sd-angular/core/side-drawer';
|
|
12
|
+
export class SdDynamicColumn {
|
|
13
|
+
constructor(ref, generatedColumnService, notifyService, translateService, gridConfigurationService) {
|
|
14
|
+
this.ref = ref;
|
|
15
|
+
this.generatedColumnService = generatedColumnService;
|
|
16
|
+
this.notifyService = notifyService;
|
|
17
|
+
this.translateService = translateService;
|
|
18
|
+
this.gridConfigurationService = gridConfigurationService;
|
|
19
|
+
_subscription.set(this, new Subscription());
|
|
20
|
+
this.columnTypes = ['string', 'number', 'bool', 'date', 'datetime', 'time', 'values', 'children', 'children-col'];
|
|
21
|
+
this.form = new FormGroup({});
|
|
22
|
+
this.isDetail = false;
|
|
23
|
+
this.originColumns = [];
|
|
24
|
+
this.onDetail = (column) => {
|
|
25
|
+
this.detail = column || {
|
|
26
|
+
field: uuid.v4(),
|
|
27
|
+
title: '',
|
|
28
|
+
type: 'string',
|
|
29
|
+
isSystem: false,
|
|
30
|
+
useTemplate: false
|
|
31
|
+
};
|
|
32
|
+
this.form.markAsUntouched();
|
|
33
|
+
this.form.markAsPristine();
|
|
34
|
+
this.isDetail = true;
|
|
35
|
+
};
|
|
36
|
+
this.onSave = () => {
|
|
37
|
+
var _a;
|
|
38
|
+
const systemSetting = this.generatedColumnService.loadSystem(this.gridOption.config);
|
|
39
|
+
const setting = this.generatedColumnService.load((_a = this.gridOption) === null || _a === void 0 ? void 0 : _a.config);
|
|
40
|
+
if (this.detail.isSystem) {
|
|
41
|
+
if (!this.detail.id) {
|
|
42
|
+
systemSetting.set([...this.systemColumns, Object.assign(Object.assign({}, this.detail), { id: uuid.v4() })]);
|
|
43
|
+
}
|
|
44
|
+
else {
|
|
45
|
+
systemSetting.set([...this.systemColumns]);
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
else {
|
|
49
|
+
if (!this.detail.id) {
|
|
50
|
+
setting.set([...this.columns, Object.assign(Object.assign({}, this.detail), { id: uuid.v4() })]);
|
|
51
|
+
}
|
|
52
|
+
else {
|
|
53
|
+
setting.set([...this.columns]);
|
|
54
|
+
}
|
|
55
|
+
}
|
|
56
|
+
};
|
|
57
|
+
}
|
|
58
|
+
ngOnInit() {
|
|
59
|
+
var _a, _b, _c;
|
|
60
|
+
const systemSetting = this.generatedColumnService.loadSystem(this.gridOption.config);
|
|
61
|
+
const setting = this.generatedColumnService.load((_a = this.gridOption) === null || _a === void 0 ? void 0 : _a.config);
|
|
62
|
+
if (systemSetting) {
|
|
63
|
+
(_b = __classPrivateFieldGet(this, _subscription)) === null || _b === void 0 ? void 0 : _b.add(systemSetting.observer.subscribe(columns => {
|
|
64
|
+
this.systemColumns = columns;
|
|
65
|
+
}));
|
|
66
|
+
}
|
|
67
|
+
if (setting) {
|
|
68
|
+
(_c = __classPrivateFieldGet(this, _subscription)) === null || _c === void 0 ? void 0 : _c.add(setting.observer.subscribe(columns => {
|
|
69
|
+
this.columns = columns;
|
|
70
|
+
}));
|
|
71
|
+
}
|
|
72
|
+
this.originColumns = this.gridOption.columns.filter(e => e.type !== 'children' && e.type !== 'children-col');
|
|
73
|
+
}
|
|
74
|
+
ngOnDestroy() {
|
|
75
|
+
__classPrivateFieldGet(this, _subscription).unsubscribe();
|
|
76
|
+
}
|
|
77
|
+
}
|
|
78
|
+
_subscription = new WeakMap();
|
|
79
|
+
SdDynamicColumn.decorators = [
|
|
80
|
+
{ type: Component, args: [{
|
|
81
|
+
selector: 'sd-dynamic-column',
|
|
82
|
+
template: "<sd-side-drawer width=\"400px\">\r\n <div sdTitle>{{'Manage dynamic column' | sdTranslate}}</div>\r\n <ng-container sdBody>\r\n <ng-container *ngIf=\"!isDetail\">\r\n <ng-container *ngIf=\"systemColumns\">\r\n <div *ngFor=\"let column of systemColumns\" (click)=\"onDetail(column)\">\r\n {{column.title}}\r\n </div>\r\n </ng-container>\r\n <ng-container *ngIf=\"columns\">\r\n <div *ngFor=\"let column of columns\" (click)=\"onDetail(column)\">\r\n {{column.title}}\r\n </div>\r\n </ng-container>\r\n </ng-container>\r\n <ng-container *ngIf=\"isDetail\">\r\n <sd-select [form]=\"form\" [label]=\"'Apply for' | sdTranslate\" [(model)]=\"detail.isSystem\"\r\n [items]=\"[{code: true, name: 'All users'},{code: false, name: 'Only me'}]\" [disabled]=\"!!detail.id\" required></sd-select>\r\n <sd-input [form]=\"form\" [label]=\"'Column field' | sdTranslate\" [(model)]=\"detail.field\" [disabled]=\"!!detail.id\"\r\n required></sd-input>\r\n <sd-input [form]=\"form\" [label]=\"'Column title' | sdTranslate\" [(model)]=\"detail.title\" required></sd-input>\r\n <sd-input [form]=\"form\" [label]=\"'Column width' | sdTranslate\" [(model)]=\"detail.width\" type=\"number\" required>\r\n <ng-template sdInputSuffix>px</ng-template>\r\n </sd-input>\r\n <sd-select [form]=\"form\" [label]=\"'Column type' | sdTranslate\" [(model)]=\"detail.type\" [items]=\"columnTypes\"\r\n [disabled]=\"!!detail.id\" required></sd-select>\r\n <sd-select *ngIf=\"detail.type === 'children' || detail.type === 'children-col'\" [form]=\"form\"\r\n [label]=\"'Column fields' | sdTranslate\" [(model)]=\"detail.fields\" [items]=\"originColumns\" valueField=\"field\"\r\n displayField=\"title\" multiple></sd-select>\r\n <sd-select [form]=\"form\" [label]=\"'Use template' | sdTranslate\" [(model)]=\"detail.useTemplate\"\r\n [items]=\"[{code: true, name: 'Yes'},{code: false, name: 'No'}]\" required></sd-select>\r\n <sd-editor *ngIf=\"detail.useTemplate\" [form]=\"form\" [label]=\"'Html template' | sdTranslate\" [(model)]=\"detail.template\">\r\n </sd-editor>\r\n </ng-container>\r\n </ng-container>\r\n <div class=\"d-flex align-items-center justify-content-end\" sdFooter>\r\n <sd-button [title]=\"'Close' | sdTranslate\" (action)=\"sideDrawer.close()\"> </sd-button>\r\n <sd-button *ngIf=\"!isDetail\" [title]=\"'Create column' | sdTranslate\" color=\"primary\" class=\"mx-8\"\r\n (action)=\"onDetail()\">\r\n </sd-button>\r\n <sd-button *ngIf=\"isDetail\" [title]=\"'Save' | sdTranslate\" color=\"success\" class=\"mx-8\" (action)=\"onSave()\">\r\n </sd-button>\r\n </div>\r\n</sd-side-drawer>",
|
|
83
|
+
changeDetection: ChangeDetectionStrategy.OnPush,
|
|
84
|
+
styles: [".c-table{overflow:auto;position:relative}.c-table table{width:100%}.c-table .c-th{color:#000;font-size:14px;font-weight:500;line-height:20px}.c-container{min-height:200px;position:relative}.c-handle{color:#ccc;cursor:move}"]
|
|
85
|
+
},] }
|
|
86
|
+
];
|
|
87
|
+
SdDynamicColumn.ctorParameters = () => [
|
|
88
|
+
{ type: ChangeDetectorRef },
|
|
89
|
+
{ type: SdGeneratedColumnService },
|
|
90
|
+
{ type: SdNotifyService },
|
|
91
|
+
{ type: SdTranslateService },
|
|
92
|
+
{ type: SdGridConfigurationService }
|
|
93
|
+
];
|
|
94
|
+
SdDynamicColumn.propDecorators = {
|
|
95
|
+
sideDrawer: [{ type: ViewChild, args: [SdSideDrawer,] }],
|
|
96
|
+
gridOption: [{ type: Input }]
|
|
97
|
+
};
|
|
98
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dynamic-column.component.js","sourceRoot":"C:/Users/user/Documents/lib-core-ui/projects/sd-core/grid-material/","sources":["src/lib/components/dynamic-column/dynamic-column.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, ViewChild, ChangeDetectorRef, Input, ChangeDetectionStrategy, OnDestroy } from '@angular/core';\r\nimport { SdNotifyService } from '@sd-angular/core/notify';\r\nimport { SdTranslateService } from '@sd-angular/core/translate';\r\nimport { SdGridMaterialOption } from '../../models/grid-option.model';\r\nimport { SdGridConfigurationService } from '../../services/grid-configuration.service';\r\nimport * as uuid from 'uuid';\r\nimport { SdGeneratedColumnService } from '../../services/generated-column/generated-column.service';\r\nimport { Subscription } from 'rxjs';\r\nimport { SdGeneratedColumn } from '../../services/generated-column/generated-column.model';\r\nimport { FormGroup } from '@angular/forms';\r\nimport { SdSideDrawer } from '@sd-angular/core/side-drawer';\r\nimport { SdGridMaterialColumn } from '../../models/grid-column.model';\r\n\r\n@Component({\r\n  selector: 'sd-dynamic-column',\r\n  templateUrl: './dynamic-column.component.html',\r\n  styleUrls: ['./dynamic-column.component.scss'],\r\n  changeDetection: ChangeDetectionStrategy.OnPush\r\n})\r\nexport class SdDynamicColumn implements OnInit, OnDestroy {\r\n  @ViewChild(SdSideDrawer) sideDrawer: SdSideDrawer;\r\n  @Input() gridOption: SdGridMaterialOption;\r\n  systemColumns: SdGeneratedColumn[];\r\n  columns: SdGeneratedColumn[];\r\n  #subscription = new Subscription();\r\n  columnTypes = ['string', 'number', 'bool', 'date', 'datetime', 'time', 'values', 'children', 'children-col'];\r\n  form = new FormGroup({});\r\n  isDetail = false;\r\n  detail: SdGeneratedColumn;\r\n  originColumns: SdGridMaterialColumn[] = [];\r\n  constructor(\r\n    private ref: ChangeDetectorRef,\r\n    private generatedColumnService: SdGeneratedColumnService,\r\n    private notifyService: SdNotifyService,\r\n    private translateService: SdTranslateService,\r\n    private gridConfigurationService: SdGridConfigurationService) {\r\n  }\r\n\r\n  ngOnInit() {\r\n    const systemSetting = this.generatedColumnService.loadSystem(this.gridOption.config);\r\n    const setting = this.generatedColumnService.load(this.gridOption?.config);\r\n    if (systemSetting) {\r\n      this.#subscription?.add(systemSetting.observer.subscribe(columns => {\r\n        this.systemColumns = columns;\r\n      }));\r\n    }\r\n    if (setting) {\r\n      this.#subscription?.add(setting.observer.subscribe(columns => {\r\n        this.columns = columns;\r\n      }));\r\n    }\r\n    this.originColumns = this.gridOption.columns.filter(e => e.type !== 'children' && e.type !== 'children-col');\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this.#subscription.unsubscribe();\r\n  }\r\n\r\n  onDetail = (column?: SdGeneratedColumn) => {\r\n    this.detail = column || {\r\n      field: uuid.v4(),\r\n      title: '',\r\n      type: 'string',\r\n      isSystem: false,\r\n      useTemplate: false\r\n    };\r\n    this.form.markAsUntouched();\r\n    this.form.markAsPristine();\r\n    this.isDetail = true;\r\n  }\r\n\r\n  onSave = () => {\r\n    const systemSetting = this.generatedColumnService.loadSystem(this.gridOption.config);\r\n    const setting = this.generatedColumnService.load(this.gridOption?.config);\r\n    if (this.detail.isSystem) {\r\n      if (!this.detail.id) {\r\n        systemSetting.set([...this.systemColumns, {\r\n          ...this.detail,\r\n          id: uuid.v4()\r\n        }]);\r\n      } else {\r\n        systemSetting.set([...this.systemColumns]);\r\n      }\r\n    } else {\r\n      if (!this.detail.id) {\r\n        setting.set([...this.columns, {\r\n          ...this.detail,\r\n          id: uuid.v4()\r\n        }]);\r\n      } else {\r\n        setting.set([...this.columns]);\r\n      }\r\n    }\r\n  }\r\n}\r\n"]}
|
|
@@ -1,10 +1,12 @@
|
|
|
1
1
|
var _cache;
|
|
2
2
|
import { __awaiter, __classPrivateFieldGet, __classPrivateFieldSet } from "tslib";
|
|
3
|
-
import { Component, ViewChild, EventEmitter, ChangeDetectorRef, Input } from '@angular/core';
|
|
3
|
+
import { Component, ViewChild, EventEmitter, ChangeDetectorRef, Input, HostListener } from '@angular/core';
|
|
4
4
|
import { SdNotifyService } from '@sd-angular/core/notify';
|
|
5
5
|
import { SdTranslateService } from '@sd-angular/core/translate';
|
|
6
6
|
import { SdGridConfigurationService } from '../../services/grid-configuration.service';
|
|
7
7
|
import * as uuid from 'uuid';
|
|
8
|
+
// import { SdGridMaterialColumn } from '@sd-angular/core/grid-material';
|
|
9
|
+
import { moveItemInArray } from '@angular/cdk/drag-drop';
|
|
8
10
|
export class SdPopupGridConfiguration {
|
|
9
11
|
constructor(ref, notifyService, translateService, gridConfigurationService) {
|
|
10
12
|
this.ref = ref;
|
|
@@ -15,6 +17,7 @@ export class SdPopupGridConfiguration {
|
|
|
15
17
|
_cache.set(this, void 0);
|
|
16
18
|
this.isCreatingColumn = false;
|
|
17
19
|
this.selected = {};
|
|
20
|
+
this.disabledDrag = true;
|
|
18
21
|
this.open = () => __awaiter(this, void 0, void 0, function* () {
|
|
19
22
|
__classPrivateFieldSet(this, _cache, this.gridConfigurationService.init(this.key, this.gridOption));
|
|
20
23
|
this.configuration = yield __classPrivateFieldGet(this, _cache).get();
|
|
@@ -58,13 +61,26 @@ export class SdPopupGridConfiguration {
|
|
|
58
61
|
}
|
|
59
62
|
ngOnInit() {
|
|
60
63
|
}
|
|
64
|
+
mouseUp(event) {
|
|
65
|
+
this.disabledDrag = true;
|
|
66
|
+
}
|
|
67
|
+
dropTable(event) {
|
|
68
|
+
moveItemInArray(this.configuration.columns, event.previousIndex, event.currentIndex);
|
|
69
|
+
this.table.renderRows();
|
|
70
|
+
}
|
|
71
|
+
handleMouseDown() {
|
|
72
|
+
this.disabledDrag = false;
|
|
73
|
+
}
|
|
74
|
+
handleMouseUp() {
|
|
75
|
+
this.disabledDrag = true;
|
|
76
|
+
}
|
|
61
77
|
}
|
|
62
78
|
_cache = new WeakMap();
|
|
63
79
|
SdPopupGridConfiguration.decorators = [
|
|
64
80
|
{ type: Component, args: [{
|
|
65
81
|
selector: 'sd-popup-grid-configuration',
|
|
66
|
-
template: "<sd-modal width=\"sm\" [title]=\"'Configuration' | sdTranslate\" #modal>\r\n <sd-modal-body *ngIf=\"configuration\">\r\n <div *ngIf=\"!isCreatingColumn\" class=\"c-container\">\r\n <div class=\"c-table\" style=\"max-height:70vh\">\r\n <table mat-table [dataSource]=\"configuration.columns\">\r\n <ng-container matColumnDef=\"stt\">\r\n <th mat-header-cell class=\"c-th text-center px-5\" *matHeaderCellDef style=\"width:50px\">#\r\n </th>\r\n <td class=\"text-center px-5\" mat-cell *matCellDef=\"let item; let idx = index\">\r\n <
|
|
67
|
-
styles: [".c-table{overflow:auto;position:relative}.c-table table{width:100%}.c-table .c-th{color:#000;font-size:14px;font-weight:500;line-height:20px}.c-container{min-height:200px;position:relative}"]
|
|
82
|
+
template: "<sd-modal width=\"sm\" [title]=\"'Configuration' | sdTranslate\" #modal>\r\n <sd-modal-body *ngIf=\"configuration\">\r\n <div *ngIf=\"!isCreatingColumn\" class=\"c-container\">\r\n <div class=\"c-table\" style=\"max-height:70vh\">\r\n <table #table mat-table [dataSource]=\"configuration.columns\"\r\n cdkDropList\r\n [cdkDropListData]=\"configuration.columns\"\r\n (cdkDropListDropped)=\"dropTable($event)\">\r\n >\r\n <ng-container matColumnDef=\"stt\">\r\n <th mat-header-cell class=\"c-th text-center px-5\" *matHeaderCellDef style=\"width:50px\">#\r\n </th>\r\n <td class=\"text-center px-5\" mat-cell *matCellDef=\"let item; let idx = index\">\r\n <div class=\"c-handle\" (mousedown) = \"handleMouseDown()\" (mouseup)=\"handleMouseUp()\">\r\n <svg width=\"24px\" fill=\"currentColor\" viewBox=\"0 0 24 24\">\r\n <path d=\"M10 9h4V6h3l-5-5-5 5h3v3zm-1 1H6V7l-5 5 5 5v-3h3v-4zm14 2l-5-5v3h-3v4h3v3l5-5zm-9 3h-4v3H7l5 5 5-5h-3v-3z\"></path>\r\n <path d=\"M0 0h24v24H0z\" fill=\"none\"></path>\r\n </svg>\r\n </div>\r\n\r\n </td>\r\n </ng-container>\r\n <ng-container matColumnDef=\"title\">\r\n <th mat-header-cell class=\"c-th px-5\" *matHeaderCellDef>{{'Title' | sdTranslate}}\r\n </th>\r\n <td class=\"px-5\" mat-cell *matCellDef=\"let item;\">\r\n <sd-input [placeholder]=\"item?.origin?.title\" [(model)]=\"item.title\" disableErrorMessage></sd-input>\r\n </td>\r\n </ng-container>\r\n <ng-container matColumnDef=\"width\">\r\n <th mat-header-cell class=\"c-th px-5\" *matHeaderCellDef style=\"width:80px\">{{'Width' | sdTranslate}}\r\n </th>\r\n <td class=\"px-5\" mat-cell *matCellDef=\"let item;\">\r\n <!-- <span>{{item.width}}</span>\r\n <mat-slider\r\n step=\"1\"\r\n min=\"0\"\r\n [max]=\"+item?.origin?.width*3\"\r\n [(ngModel)]=\"+item.width\"\r\n aria-label=\"units\">\r\n </mat-slider> -->\r\n <sd-input [placeholder]=\"item?.origin?.width\" [(model)]=\"item.width\" disableErrorMessage></sd-input>\r\n </td>\r\n </ng-container>\r\n <ng-container matColumnDef=\"invisible\">\r\n <th mat-header-cell class=\"c-th text-center px-5\" *matHeaderCellDef style=\"width:80px\">{{'Hidden' |\r\n sdTranslate}}\r\n </th>\r\n <td class=\"text-center px-5\" mat-cell *matCellDef=\"let item;\">\r\n <mat-slide-toggle [(ngModel)]=\"item.invisible\" color=\"primary\">\r\n </mat-slide-toggle>\r\n </td>\r\n </ng-container>\r\n <ng-container matColumnDef=\"fixed\">\r\n <th mat-header-cell class=\"c-th text-center px-5\" *matHeaderCellDef style=\"width:80px\">{{'Freeze' |\r\n sdTranslate}}\r\n </th>\r\n <td class=\"text-center px-5\" mat-cell *matCellDef=\"let item;\">\r\n <mat-slide-toggle [(ngModel)]=\"item.fixed\" color=\"primary\"></mat-slide-toggle>\r\n </td>\r\n </ng-container>\r\n <tr mat-header-row *matHeaderRowDef=\"['stt', 'title', 'width', 'invisible', 'fixed']; sticky: true\"></tr>\r\n <tr mat-row *matRowDef=\"let row; columns: ['stt', 'title', 'width', 'invisible', 'fixed'];\" cdkDrag [cdkDragData]=\"row\" cdkDragLockAxis=\"y\" [cdkDragDisabled] = \"disabledDrag\"></tr>\r\n </table>\r\n </div>\r\n </div>\r\n <div *ngIf=\"isCreatingColumn\">\r\n <div class=\"c-table\" style=\"max-height:50vh\">\r\n <table mat-table [dataSource]=\"configuration.columns\">\r\n <ng-container matColumnDef=\"stt\">\r\n <th mat-header-cell class=\"c-th text-center px-5\" *matHeaderCellDef style=\"width:50px\">#\r\n </th>\r\n <td class=\"text-center px-5\" mat-cell *matCellDef=\"let item; let idx = index\">\r\n <sd-checkbox *ngIf=\"isCreatingColumn\" [(model)]=\"selected[item.origin?.field]\"></sd-checkbox>\r\n </td>\r\n </ng-container>\r\n <ng-container matColumnDef=\"title\">\r\n <th mat-header-cell class=\"c-th px-5\" *matHeaderCellDef>{{'Title' | sdTranslate}}\r\n </th>\r\n <td class=\"px-5\" mat-cell *matCellDef=\"let item;\">\r\n <span *ngIf=\"isCreatingColumn\">{{item.title || item?.origin?.title}}</span>\r\n </td>\r\n </ng-container>\r\n <tr mat-header-row *matHeaderRowDef=\"['stt', 'title']; sticky: true\"></tr>\r\n <tr mat-row *matRowDef=\"let row; columns: ['stt', 'title'];\"></tr>\r\n </table>\r\n </div>\r\n </div>\r\n </sd-modal-body>\r\n <sd-modal-footer>\r\n <ng-container *ngIf=\"!isCreatingColumn\">\r\n <!-- <sd-button class=\"mr-auto\" (action)=\"createColumn()\" [title]=\"'Create column' | sdTranslate\" color=\"info\"\r\n size=\"sm\">\r\n </sd-button> -->\r\n <sd-button class=\"mr-5\" (action)=\"onReset()\" [title]=\"'Default' | sdTranslate\" color=\"info\" size=\"sm\">\r\n </sd-button>\r\n <sd-button (action)=\"onSave()\" [title]=\"'Save' | sdTranslate\" type=\"fill\" color=\"info\" size=\"sm\">\r\n </sd-button>\r\n </ng-container>\r\n <ng-container *ngIf=\"isCreatingColumn\">\r\n <sd-button class=\"mr-auto\" (action)=\"isCreatingColumn = false\" [title]=\"'Cancel' | sdTranslate\" color=\"info\"\r\n size=\"sm\">\r\n </sd-button>\r\n <sd-button (action)=\"confirm()\" [title]=\"'Confirm' | sdTranslate\" type=\"fill\" color=\"info\" size=\"sm\">\r\n </sd-button>\r\n </ng-container>\r\n </sd-modal-footer>\r\n</sd-modal>",
|
|
83
|
+
styles: [".c-table{overflow:auto;position:relative}.c-table table{width:100%}.c-table .c-th{color:#000;font-size:14px;font-weight:500;line-height:20px}.c-container{min-height:200px;position:relative}.c-handle{color:#ccc;cursor:move}"]
|
|
68
84
|
},] }
|
|
69
85
|
];
|
|
70
86
|
SdPopupGridConfiguration.ctorParameters = () => [
|
|
@@ -76,6 +92,8 @@ SdPopupGridConfiguration.ctorParameters = () => [
|
|
|
76
92
|
SdPopupGridConfiguration.propDecorators = {
|
|
77
93
|
gridOption: [{ type: Input }],
|
|
78
94
|
key: [{ type: Input }],
|
|
79
|
-
modal: [{ type: ViewChild, args: ['modal',] }]
|
|
95
|
+
modal: [{ type: ViewChild, args: ['modal',] }],
|
|
96
|
+
table: [{ type: ViewChild, args: ['table',] }],
|
|
97
|
+
mouseUp: [{ type: HostListener, args: ['window:mouseup', ['$event'],] }]
|
|
80
98
|
};
|
|
81
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
99
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"popup-grid-configuration.component.js","sourceRoot":"C:/Users/user/Documents/lib-core-ui/projects/sd-core/grid-material/","sources":["src/lib/components/popup-grid-configuration/popup-grid-configuration.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, ViewChild, EventEmitter, ChangeDetectorRef, Input, HostListener } from '@angular/core';\r\nimport { SdModal } from '@sd-angular/core/modal';\r\nimport { SdNotifyService } from '@sd-angular/core/notify';\r\nimport { SdTranslateService } from '@sd-angular/core/translate';\r\nimport { SdGridMaterialOption } from '../../models/grid-option.model';\r\nimport { SdGridConfigurationResult, SdGridConfiguration, SdGridConfigurationCache, SdColumnConfiguration } from '../../models/grid-config.model';\r\nimport { SdGridConfigurationService } from '../../services/grid-configuration.service';\r\nimport * as uuid from 'uuid';\r\nimport { MatTable } from '@angular/material/table';\r\n// import { SdGridMaterialColumn } from '@sd-angular/core/grid-material';\r\nimport { CdkDragDrop, moveItemInArray } from '@angular/cdk/drag-drop';\r\nimport { SdGridMaterialColumn } from '../../models/grid-column.model';\r\n\r\n@Component({\r\n  selector: 'sd-popup-grid-configuration',\r\n  templateUrl: './popup-grid-configuration.component.html',\r\n  styleUrls: ['./popup-grid-configuration.component.scss']\r\n})\r\nexport class SdPopupGridConfiguration implements OnInit {\r\n  @Input() gridOption: SdGridMaterialOption;\r\n  @Input() key: string;\r\n  @ViewChild('modal') modal: SdModal;\r\n  @ViewChild('table') table: MatTable<SdGridMaterialColumn>;\r\n  readonly changes = new EventEmitter<SdGridConfigurationResult>();\r\n  #cache: SdGridConfigurationCache;\r\n  configuration: SdGridConfiguration;\r\n  isCreatingColumn = false;\r\n  selected: {\r\n    [key: string]: boolean;\r\n  } = {};\r\n  disabledDrag = true;\r\n  constructor(\r\n    private ref: ChangeDetectorRef,\r\n    private notifyService: SdNotifyService,\r\n    private translateService: SdTranslateService,\r\n    private gridConfigurationService: SdGridConfigurationService) {\r\n  }\r\n\r\n  ngOnInit() {\r\n  }\r\n  @HostListener('window:mouseup', ['$event'])\r\n  mouseUp(event) {\r\n    this.disabledDrag = true;\r\n  }\r\n  open = async () => {\r\n    this.#cache = this.gridConfigurationService.init(this.key, this.gridOption);\r\n    this.configuration = await this.#cache.get();\r\n    this.modal.open();\r\n  }\r\n\r\n  onSave = () => {\r\n    this.#cache.set(this.configuration);\r\n    this.modal.close();\r\n    this.ref.detectChanges();\r\n  }\r\n\r\n  onReset = async () => {\r\n    const { translate } = this.translateService;\r\n    this.notifyService.confirm(translate('Reset grid configuration to default')).then(() => {\r\n      this.#cache.remove();\r\n      this.modal.close();\r\n      this.ref.detectChanges();\r\n    });\r\n  }\r\n\r\n  createColumn = async () => {\r\n    this.selected = {};\r\n    this.isCreatingColumn = true;\r\n  }\r\n\r\n  confirm = async () => {\r\n    const generatedColumn: SdColumnConfiguration = {\r\n      origin: {\r\n        field: uuid.v4(),\r\n        title: 'Generated',\r\n        width: '300px'\r\n      },\r\n      fixed: false,\r\n      invisible: false,\r\n      title: 'Generated',\r\n      width: '300px',\r\n      isGeneratedColumn: true,\r\n      generatedColumns: this.configuration.columns.filter(e => this.selected[e.origin?.field]).map(e => e.origin?.field)\r\n    };\r\n    this.configuration.columns.push(generatedColumn);\r\n    this.configuration = this.#cache.set(this.configuration);\r\n    this.isCreatingColumn = false;\r\n  }\r\n\r\n  dropTable(event: CdkDragDrop<SdGridMaterialColumn[]>) {\r\n    moveItemInArray(this.configuration.columns, event.previousIndex, event.currentIndex);\r\n    this.table.renderRows();\r\n  }\r\n\r\n  handleMouseDown() {\r\n    this.disabledDrag = false;\r\n  }\r\n\r\n  handleMouseUp() {\r\n    this.disabledDrag = true;\r\n  }\r\n}\r\n"]}
|