@smartbit4all/ng-client 3.3.138 → 3.3.139
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/esm2020/lib/session/api/api/session.service.mjs +1 -1
- package/esm2020/lib/session/api/encoder.mjs +1 -1
- package/esm2020/lib/session/api/model/accountInfo.mjs +1 -1
- package/esm2020/lib/session/api/model/apiError.mjs +1 -1
- package/esm2020/lib/session/api/model/authenticationProviderData.mjs +1 -1
- package/esm2020/lib/session/api/model/getAuthenticationProvidersResponse.mjs +1 -1
- package/esm2020/lib/session/api/model/models.mjs +1 -1
- package/esm2020/lib/session/api/model/refreshSessionRequest.mjs +1 -1
- package/esm2020/lib/session/api/model/session.mjs +1 -1
- package/esm2020/lib/session/api/model/sessionInfoData.mjs +1 -1
- package/esm2020/lib/session/api/model/userActivityLog.mjs +1 -1
- package/esm2020/lib/session/api/param.mjs +1 -1
- package/esm2020/lib/session/api/variables.mjs +1 -1
- package/esm2020/lib/smart-client/smart-component-api-client.mjs +31 -34
- package/esm2020/lib/smart-component-layout/api/api/api.mjs +1 -1
- package/esm2020/lib/smart-component-layout/api/api/default.service.mjs +1 -1
- package/esm2020/lib/smart-component-layout/api/api.module.mjs +1 -1
- package/esm2020/lib/smart-component-layout/api/configuration.mjs +1 -1
- package/esm2020/lib/smart-component-layout/api/encoder.mjs +1 -1
- package/esm2020/lib/smart-component-layout/api/index.mjs +1 -1
- package/esm2020/lib/smart-component-layout/api/model/componentType.mjs +1 -1
- package/esm2020/lib/smart-component-layout/api/model/componentWidgetType.mjs +1 -1
- package/esm2020/lib/smart-component-layout/api/model/layoutDirection.mjs +1 -1
- package/esm2020/lib/smart-component-layout/api/model/models.mjs +1 -1
- package/esm2020/lib/smart-component-layout/api/model/smartComponentLayoutDefinition.mjs +1 -1
- package/esm2020/lib/smart-component-layout/api/model/smartComponentWidgetDefinition.mjs +1 -1
- package/esm2020/lib/smart-component-layout/api/param.mjs +1 -1
- package/esm2020/lib/smart-component-layout/api/variables.mjs +1 -1
- package/esm2020/lib/smart-component-layout/smart-component-layout-utility.mjs +9 -48
- package/esm2020/lib/smart-component-layout/smart-component-layout.component.mjs +28 -67
- package/esm2020/lib/smart-component-layout/smart-component-layout.module.mjs +5 -1
- package/esm2020/lib/smart-dialog/smartdialog.model.mjs +1 -1
- package/esm2020/lib/smart-dialog/smartdialog.module.mjs +5 -5
- package/esm2020/lib/smart-expandable-section/expandable-section.component.mjs +6 -12
- package/esm2020/lib/smart-expandable-section/expandable-section.model.mjs +1 -1
- package/esm2020/lib/smart-filter/api/filter/model/filterExpressionBoolOperator.mjs +1 -1
- package/esm2020/lib/smart-filter/api/filter/model/filterExpressionBuilderField.mjs +1 -1
- package/esm2020/lib/smart-filter/api/filter/model/filterExpressionBuilderGroup.mjs +1 -1
- package/esm2020/lib/smart-filter/api/filter/model/filterExpressionBuilderModel.mjs +1 -1
- package/esm2020/lib/smart-filter/api/filter/model/filterExpressionData.mjs +1 -1
- package/esm2020/lib/smart-filter/api/filter/model/filterExpressionDataType.mjs +1 -1
- package/esm2020/lib/smart-filter/api/filter/model/filterExpressionField.mjs +1 -1
- package/esm2020/lib/smart-filter/api/filter/model/filterExpressionFieldList.mjs +1 -1
- package/esm2020/lib/smart-filter/api/filter/model/filterExpressionFieldWidgetType.mjs +1 -2
- package/esm2020/lib/smart-filter/api/filter/model/filterExpressionList.mjs +1 -1
- package/esm2020/lib/smart-filter/api/filter/model/filterExpressionOperandData.mjs +1 -1
- package/esm2020/lib/smart-filter/api/filter/model/filterExpressionOperation.mjs +1 -1
- package/esm2020/lib/smart-filter/api/filter/model/filterExpressionOrderBy.mjs +1 -1
- package/esm2020/lib/smart-filter/smart-filter.module.mjs +5 -5
- package/esm2020/lib/smart-filter-editor/api/api/filter.service.mjs +1 -1
- package/esm2020/lib/smart-filter-editor/api/configuration.mjs +1 -1
- package/esm2020/lib/smart-filter-editor/api/encoder.mjs +1 -1
- package/esm2020/lib/smart-filter-editor/api/model/filterExpressionBoolOperator.mjs +1 -1
- package/esm2020/lib/smart-filter-editor/api/model/filterExpressionBuilderApiConfig.mjs +1 -1
- package/esm2020/lib/smart-filter-editor/api/model/filterExpressionBuilderField.mjs +1 -1
- package/esm2020/lib/smart-filter-editor/api/model/filterExpressionBuilderGroup.mjs +1 -1
- package/esm2020/lib/smart-filter-editor/api/model/filterExpressionBuilderModel.mjs +1 -1
- package/esm2020/lib/smart-filter-editor/api/model/filterExpressionBuilderUiModel.mjs +1 -1
- package/esm2020/lib/smart-filter-editor/api/model/filterExpressionData.mjs +1 -1
- package/esm2020/lib/smart-filter-editor/api/model/filterExpressionDataType.mjs +1 -1
- package/esm2020/lib/smart-filter-editor/api/model/filterExpressionField.mjs +1 -1
- package/esm2020/lib/smart-filter-editor/api/model/filterExpressionFieldEditor.mjs +1 -1
- package/esm2020/lib/smart-filter-editor/api/model/filterExpressionFieldList.mjs +1 -1
- package/esm2020/lib/smart-filter-editor/api/model/filterExpressionFieldWidgetType.mjs +1 -2
- package/esm2020/lib/smart-filter-editor/api/model/filterExpressionList.mjs +1 -1
- package/esm2020/lib/smart-filter-editor/api/model/filterExpressionOperandData.mjs +1 -1
- package/esm2020/lib/smart-filter-editor/api/model/filterExpressionOperation.mjs +1 -1
- package/esm2020/lib/smart-filter-editor/api/param.mjs +1 -1
- package/esm2020/lib/smart-filter-editor/api/variables.mjs +1 -1
- package/esm2020/lib/smart-filter-editor/smart-filter-editor.module.mjs +8 -1
- package/esm2020/lib/smart-form/api/model/smartMatrixModel.mjs +1 -1
- package/esm2020/lib/smart-form/api/model/smartWidgetDefinition.mjs +1 -1
- package/esm2020/lib/smart-form/projects.mjs +2 -1
- package/esm2020/lib/smart-form/services/smartform.layout-definition.service.mjs +3 -21
- package/esm2020/lib/smart-form/services/smartform.service.mjs +1 -6
- package/esm2020/lib/smart-form/smartform.component.mjs +3 -19
- package/esm2020/lib/smart-form/smartform.form-model.mjs +1 -1
- package/esm2020/lib/smart-form/smartform.module.mjs +157 -0
- package/esm2020/lib/smart-form/widgets/smartformwidget/smartformwidget.component.mjs +32 -118
- package/esm2020/lib/smart-grid/api/grid-api/api/api.mjs +1 -1
- package/esm2020/lib/smart-grid/api/grid-api/api/grid.service.mjs +1 -1
- package/esm2020/lib/smart-grid/api/grid-api/api.module.mjs +1 -1
- package/esm2020/lib/smart-grid/api/grid-api/configuration.mjs +1 -1
- package/esm2020/lib/smart-grid/api/grid-api/encoder.mjs +1 -1
- package/esm2020/lib/smart-grid/api/grid-api/index.mjs +1 -1
- package/esm2020/lib/smart-grid/api/grid-api/model/gridColumnContentType.mjs +1 -1
- package/esm2020/lib/smart-grid/api/grid-api/model/gridColumnMeta.mjs +1 -1
- package/esm2020/lib/smart-grid/api/grid-api/model/gridDataAccessConfig.mjs +1 -1
- package/esm2020/lib/smart-grid/api/grid-api/model/gridModel.mjs +1 -1
- package/esm2020/lib/smart-grid/api/grid-api/model/gridPage.mjs +1 -1
- package/esm2020/lib/smart-grid/api/grid-api/model/gridRow.mjs +1 -1
- package/esm2020/lib/smart-grid/api/grid-api/model/gridSelectionChange.mjs +1 -1
- package/esm2020/lib/smart-grid/api/grid-api/model/gridSelectionMode.mjs +1 -1
- package/esm2020/lib/smart-grid/api/grid-api/model/gridSelectionType.mjs +1 -1
- package/esm2020/lib/smart-grid/api/grid-api/model/gridServerModel.mjs +1 -1
- package/esm2020/lib/smart-grid/api/grid-api/model/gridUpdateData.mjs +1 -1
- package/esm2020/lib/smart-grid/api/grid-api/model/gridView.mjs +1 -1
- package/esm2020/lib/smart-grid/api/grid-api/model/gridViewDescriptor.mjs +1 -1
- package/esm2020/lib/smart-grid/api/grid-api/model/models.mjs +1 -1
- package/esm2020/lib/smart-grid/api/grid-api/param.mjs +1 -1
- package/esm2020/lib/smart-grid/api/grid-api/variables.mjs +1 -1
- package/esm2020/lib/smart-grid/smart-grid.component.mjs +11 -26
- package/esm2020/lib/smart-grid/smart-grid.module.mjs +6 -3
- package/esm2020/lib/smart-navbar/smart-navbar.module.mjs +5 -5
- package/esm2020/lib/smart-ng-client.module.mjs +8 -1
- package/esm2020/lib/smart-table/tables/table.mjs +4 -6
- package/esm2020/lib/smart-tree/smarttree-generic.service.mjs +13 -20
- package/esm2020/lib/smart-tree/smarttree.module.mjs +3 -11
- package/esm2020/lib/smart-tree/tree-api/api/tree.service.mjs +1 -1
- package/esm2020/lib/smart-tree/tree-api/configuration.mjs +1 -1
- package/esm2020/lib/smart-tree/tree-api/encoder.mjs +1 -1
- package/esm2020/lib/smart-tree/tree-api/param.mjs +1 -1
- package/esm2020/lib/smart-tree/tree-api/variables.mjs +1 -1
- package/esm2020/lib/view-context/api/api/api.mjs +1 -1
- package/esm2020/lib/view-context/api/api/view.service.mjs +1 -1
- package/esm2020/lib/view-context/api/api.module.mjs +1 -1
- package/esm2020/lib/view-context/api/configuration.mjs +1 -1
- package/esm2020/lib/view-context/api/encoder.mjs +1 -1
- package/esm2020/lib/view-context/api/index.mjs +1 -1
- package/esm2020/lib/view-context/api/model/closeResult.mjs +1 -1
- package/esm2020/lib/view-context/api/model/componentConstraint.mjs +1 -1
- package/esm2020/lib/view-context/api/model/componentModel.mjs +1 -1
- package/esm2020/lib/view-context/api/model/componentModelChange.mjs +1 -1
- package/esm2020/lib/view-context/api/model/dataChange.mjs +1 -1
- package/esm2020/lib/view-context/api/model/dataChangeEvent.mjs +1 -1
- package/esm2020/lib/view-context/api/model/dataChangeKind.mjs +1 -1
- package/esm2020/lib/view-context/api/model/downloadedFile.mjs +1 -1
- package/esm2020/lib/view-context/api/model/iconPosition.mjs +1 -1
- package/esm2020/lib/view-context/api/model/imageResource.mjs +1 -1
- package/esm2020/lib/view-context/api/model/link.mjs +1 -1
- package/esm2020/lib/view-context/api/model/messageData.mjs +1 -1
- package/esm2020/lib/view-context/api/model/messageOption.mjs +1 -1
- package/esm2020/lib/view-context/api/model/messageOptionType.mjs +1 -1
- package/esm2020/lib/view-context/api/model/messageResult.mjs +1 -1
- package/esm2020/lib/view-context/api/model/messageTextType.mjs +1 -1
- package/esm2020/lib/view-context/api/model/messageType.mjs +1 -1
- package/esm2020/lib/view-context/api/model/openPendingData.mjs +1 -1
- package/esm2020/lib/view-context/api/model/smartLinkData.mjs +1 -1
- package/esm2020/lib/view-context/api/model/style.mjs +1 -1
- package/esm2020/lib/view-context/api/model/uiAction.mjs +1 -1
- package/esm2020/lib/view-context/api/model/uiActionButtonDescriptor.mjs +1 -1
- package/esm2020/lib/view-context/api/model/uiActionButtonType.mjs +1 -1
- package/esm2020/lib/view-context/api/model/uiActionConstraint.mjs +1 -1
- package/esm2020/lib/view-context/api/model/uiActionDescriptor.mjs +1 -1
- package/esm2020/lib/view-context/api/model/uiActionDialogDescriptor.mjs +1 -1
- package/esm2020/lib/view-context/api/model/uiActionFeedbackType.mjs +1 -1
- package/esm2020/lib/view-context/api/model/uiActionInputType.mjs +1 -1
- package/esm2020/lib/view-context/api/model/uiActionRequest.mjs +1 -1
- package/esm2020/lib/view-context/api/model/uiActionTooltip.mjs +1 -1
- package/esm2020/lib/view-context/api/model/uiActionUploadDescriptor.mjs +1 -1
- package/esm2020/lib/view-context/api/model/valueSet.mjs +1 -1
- package/esm2020/lib/view-context/api/model/view.mjs +1 -1
- package/esm2020/lib/view-context/api/model/viewApiError.mjs +1 -1
- package/esm2020/lib/view-context/api/model/viewConstraint.mjs +1 -1
- package/esm2020/lib/view-context/api/model/viewContext.mjs +1 -1
- package/esm2020/lib/view-context/api/model/viewContextChange.mjs +1 -1
- package/esm2020/lib/view-context/api/model/viewContextData.mjs +1 -1
- package/esm2020/lib/view-context/api/model/viewContextUpdate.mjs +1 -1
- package/esm2020/lib/view-context/api/model/viewData.mjs +1 -1
- package/esm2020/lib/view-context/api/model/viewState.mjs +1 -1
- package/esm2020/lib/view-context/api/model/viewStateUpdate.mjs +1 -1
- package/esm2020/lib/view-context/api/model/viewType.mjs +1 -1
- package/esm2020/lib/view-context/api/param.mjs +1 -1
- package/esm2020/lib/view-context/api/variables.mjs +1 -1
- package/esm2020/lib/view-context/smart-ui-action/dialogs/ui-action-confirm-dialog/ui-action-confirm-dialog.component.mjs +12 -15
- package/esm2020/lib/view-context/smart-ui-action/dialogs/ui-action-confirm-dialog/ui-action-confirm-dialog.service.mjs +2 -2
- package/esm2020/lib/view-context/smart-ui-action/dialogs/ui-action-file-upload-dialog/ui-action-file-upload-dialog.component.mjs +10 -13
- package/esm2020/lib/view-context/smart-ui-action/dialogs/ui-action-file-upload-dialog/ui-action-file-upload-dialog.service.mjs +2 -2
- package/esm2020/lib/view-context/smart-ui-action/dialogs/ui-action-input-dialog/ui-action-input-dialog.component.mjs +11 -17
- package/esm2020/lib/view-context/smart-ui-action/dialogs/ui-action-input-dialog/ui-action-input-dialog.service.mjs +2 -2
- package/esm2020/lib/view-context/smart-ui-action/ui-action-toolbar.component.mjs +6 -11
- package/esm2020/lib/view-context/smart-ui-action/ui-action.model.mjs +1 -1
- package/esm2020/lib/view-context/smart-ui-action/ui-action.service.mjs +8 -14
- package/esm2020/lib/view-context/smart-view-context.module.mjs +10 -132
- package/esm2020/lib/view-context/smart-view-context.service.mjs +1 -8
- package/fesm2015/smartbit4all-ng-client.mjs +2842 -3076
- package/fesm2015/smartbit4all-ng-client.mjs.map +1 -1
- package/fesm2020/smartbit4all-ng-client.mjs +3561 -3787
- package/fesm2020/smartbit4all-ng-client.mjs.map +1 -1
- package/lib/smart-client/smart-component-api-client.d.ts +1 -2
- package/lib/smart-component-layout/api/model/smartComponentLayoutDefinition.d.ts +5 -3
- package/lib/smart-component-layout/api/model/smartComponentWidgetDefinition.d.ts +2 -2
- package/lib/smart-component-layout/smart-component-layout-utility.d.ts +3 -4
- package/lib/smart-component-layout/smart-component-layout.component.d.ts +6 -10
- package/lib/smart-component-layout/smart-component-layout.module.d.ts +6 -5
- package/lib/smart-dialog/smartdialog.model.d.ts +2 -2
- package/lib/smart-dialog/smartdialog.module.d.ts +2 -2
- package/lib/smart-expandable-section/expandable-section.model.d.ts +2 -4
- package/lib/smart-filter/api/filter/model/filterExpressionFieldWidgetType.d.ts +0 -1
- package/lib/smart-filter/smart-filter.module.d.ts +2 -2
- package/lib/smart-filter-editor/api/model/filterExpressionField.d.ts +0 -3
- package/lib/smart-filter-editor/api/model/filterExpressionFieldWidgetType.d.ts +0 -1
- package/lib/smart-filter-editor/smart-filter-editor.module.d.ts +5 -4
- package/lib/smart-form/api/model/smartWidgetDefinition.d.ts +1 -2
- package/lib/smart-form/projects.d.ts +1 -0
- package/lib/smart-form/services/smartform.layout-definition.service.d.ts +0 -1
- package/lib/smart-form/smartform.component.d.ts +2 -6
- package/lib/smart-form/smartform.form-model.d.ts +1 -17
- package/lib/smart-form/smartform.module.d.ts +35 -0
- package/lib/smart-form/widgets/smartformwidget/smartformwidget.component.d.ts +1 -31
- package/lib/smart-grid/api/grid-api/model/gridColumnMeta.d.ts +0 -4
- package/lib/smart-grid/api/grid-api/model/gridModel.d.ts +0 -2
- package/lib/smart-grid/api/grid-api/model/gridServerModel.d.ts +0 -2
- package/lib/smart-grid/smart-grid.component.d.ts +1 -2
- package/lib/smart-grid/smart-grid.module.d.ts +4 -3
- package/lib/smart-navbar/smart-navbar.module.d.ts +2 -2
- package/lib/smart-ng-client.module.d.ts +13 -12
- package/lib/smart-tree/smarttree-generic.service.d.ts +3 -2
- package/lib/view-context/api/model/uiAction.d.ts +0 -4
- package/lib/view-context/smart-ui-action/dialogs/ui-action-confirm-dialog/ui-action-confirm-dialog.component.d.ts +5 -5
- package/lib/view-context/smart-ui-action/dialogs/ui-action-confirm-dialog/ui-action-confirm-dialog.service.d.ts +1 -1
- package/lib/view-context/smart-ui-action/dialogs/ui-action-file-upload-dialog/ui-action-file-upload-dialog.component.d.ts +1 -1
- package/lib/view-context/smart-ui-action/dialogs/ui-action-file-upload-dialog/ui-action-file-upload-dialog.service.d.ts +1 -1
- package/lib/view-context/smart-ui-action/dialogs/ui-action-input-dialog/ui-action-input-dialog.component.d.ts +2 -2
- package/lib/view-context/smart-ui-action/dialogs/ui-action-input-dialog/ui-action-input-dialog.service.d.ts +1 -1
- package/lib/view-context/smart-ui-action/ui-action.model.d.ts +1 -1
- package/lib/view-context/smart-ui-action/ui-action.service.d.ts +3 -3
- package/lib/view-context/smart-view-context.module.d.ts +11 -34
- package/lib/view-context/smart-view-context.service.d.ts +0 -2
- package/package.json +1 -1
- package/smartbit4all-ng-client-3.3.139.tgz +0 -0
- package/src/lib/session/api/README.md +226 -226
- package/src/lib/smart-component-layout/api/README.md +226 -226
- package/src/lib/smart-filter-editor/api/README.md +226 -226
- package/src/lib/smart-grid/api/grid-api/README.md +226 -226
- package/src/lib/smart-tree/tree-api/README.md +226 -226
- package/src/lib/view-context/api/README.md +226 -226
- package/esm2020/lib/smart-filter-editor/api/model/smartFilterType.mjs +0 -17
- package/lib/smart-filter-editor/api/model/smartFilterType.d.ts +0 -15
- package/smartbit4all-ng-client-3.3.138.tgz +0 -0
|
@@ -2,10 +2,7 @@ import { Component, Input, ViewChildren, } from '@angular/core';
|
|
|
2
2
|
import { ComponentType, ComponentWidgetType, LayoutDirection, } from './api';
|
|
3
3
|
import { SmartFormWidgetDirection, } from '../smart-form/projects';
|
|
4
4
|
import { GridUiActionType, SmartLayoutDef, } from '../smart-grid/projects';
|
|
5
|
-
import { ExpandableSectionComponent, } from '../smart-expandable-section/projects';
|
|
6
5
|
import { Subject, takeUntil } from 'rxjs';
|
|
7
|
-
import { deepEqual } from 'fast-equals';
|
|
8
|
-
import { SmartComponentLayoutUtility } from './smart-component-layout-utility';
|
|
9
6
|
import * as i0 from "@angular/core";
|
|
10
7
|
import * as i1 from "../smart-form/projects";
|
|
11
8
|
import * as i2 from "../smart-expandable-section/expandable-section.component";
|
|
@@ -15,11 +12,10 @@ import * as i5 from "../smart-tree/smarttree.component";
|
|
|
15
12
|
import * as i6 from "../view-context/smart-ui-action/ui-action-toolbar.component";
|
|
16
13
|
import * as i7 from "@angular/common";
|
|
17
14
|
export class SmartComponentLayoutComponent {
|
|
18
|
-
constructor(layoutService
|
|
15
|
+
constructor(layoutService) {
|
|
19
16
|
this.layoutService = layoutService;
|
|
20
|
-
this.element = element;
|
|
21
|
-
this.renderer = renderer;
|
|
22
17
|
this._destroy$ = new Subject();
|
|
18
|
+
this.toolbarId = 'not_initialized_yet';
|
|
23
19
|
}
|
|
24
20
|
ngAfterViewInit() {
|
|
25
21
|
if (this.smartFormList?.first) {
|
|
@@ -54,29 +50,24 @@ export class SmartComponentLayoutComponent {
|
|
|
54
50
|
.subscribe((list) => {
|
|
55
51
|
this.setToolbarComponent(list.first);
|
|
56
52
|
});
|
|
57
|
-
this.
|
|
53
|
+
if (this.smartComponentLayout) {
|
|
54
|
+
this.setUp();
|
|
55
|
+
}
|
|
58
56
|
}
|
|
59
57
|
ngOnDestroy() {
|
|
60
58
|
this._destroy$.next();
|
|
61
59
|
this._destroy$.complete();
|
|
62
60
|
}
|
|
63
61
|
ngOnChanges(changes) {
|
|
64
|
-
this.
|
|
62
|
+
this.smartComponentLayout = changes['smartComponentLayout'].currentValue;
|
|
63
|
+
if (this.smartComponentLayout) {
|
|
64
|
+
this.setUp();
|
|
65
|
+
}
|
|
65
66
|
}
|
|
66
67
|
setUp() {
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
if (deepEqual(this.smartComponentLayout, this.currentLayout)) {
|
|
71
|
-
// no layout change, keep current state
|
|
72
|
-
this.smartComponentLayout = this.currentLayout;
|
|
73
|
-
return;
|
|
74
|
-
}
|
|
75
|
-
// layout changed, render, but save current
|
|
76
|
-
// this.currentLayout = JSON.parse(JSON.stringify(this.smartComponentLayout));
|
|
77
|
-
this.currentLayout = this.smartComponentLayout;
|
|
78
|
-
this.uuid = this.parentSmartComponent.uuid;
|
|
79
|
-
this.treeService = this.parentSmartComponent.smartTreeService;
|
|
68
|
+
this.parent = this.smartComponentLayout?.parentComponent;
|
|
69
|
+
this.uuid = this.parent.uuid;
|
|
70
|
+
this.treeService = this.parent.smartTreeService;
|
|
80
71
|
this.smartComponentLayout?.direction;
|
|
81
72
|
if (this.smartComponentLayout?.expandable) {
|
|
82
73
|
this.constructExpandableSection();
|
|
@@ -89,8 +80,7 @@ export class SmartComponentLayoutComponent {
|
|
|
89
80
|
this.constructGrid();
|
|
90
81
|
}
|
|
91
82
|
else if (this.smartComponentLayout.widget?.type === ComponentWidgetType.FILTER) {
|
|
92
|
-
|
|
93
|
-
// this.constructFilter();
|
|
83
|
+
this.constructFilter();
|
|
94
84
|
}
|
|
95
85
|
else if (this.smartComponentLayout.widget?.type === ComponentWidgetType.TREE) {
|
|
96
86
|
this.constructTree();
|
|
@@ -98,12 +88,8 @@ export class SmartComponentLayoutComponent {
|
|
|
98
88
|
else if (this.smartComponentLayout.widget?.type === ComponentWidgetType.TOOLBAR) {
|
|
99
89
|
this.constructToolbar();
|
|
100
90
|
}
|
|
101
|
-
|
|
102
|
-
// only top level component should call init actions
|
|
103
|
-
this.parentSmartComponent.initActions();
|
|
104
|
-
}
|
|
91
|
+
this.parent.initActions();
|
|
105
92
|
}
|
|
106
|
-
SmartComponentLayoutUtility.applyStyle(this.smartComponentLayout.style, this.element, this.renderer);
|
|
107
93
|
}
|
|
108
94
|
type() {
|
|
109
95
|
return ComponentType;
|
|
@@ -113,11 +99,8 @@ export class SmartComponentLayoutComponent {
|
|
|
113
99
|
data.expandable = false;
|
|
114
100
|
this.expandableSection = {
|
|
115
101
|
title: this.smartComponentLayout?.expandableSectionLabel ?? '',
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
['parentSmartComponent', this.parentSmartComponent],
|
|
119
|
-
['parentLayoutComponent', this.parentLayoutComponent],
|
|
120
|
-
]),
|
|
102
|
+
data,
|
|
103
|
+
inputName: 'smartComponentLayout',
|
|
121
104
|
customComponent: SmartComponentLayoutComponent,
|
|
122
105
|
};
|
|
123
106
|
}
|
|
@@ -127,7 +110,7 @@ export class SmartComponentLayoutComponent {
|
|
|
127
110
|
});
|
|
128
111
|
this.smartForm = {
|
|
129
112
|
direction: this.getFormLayout(),
|
|
130
|
-
componentModel: this.
|
|
113
|
+
componentModel: this.parent?.model,
|
|
131
114
|
widgets,
|
|
132
115
|
};
|
|
133
116
|
this.bindForm();
|
|
@@ -147,11 +130,8 @@ export class SmartComponentLayoutComponent {
|
|
|
147
130
|
}
|
|
148
131
|
}
|
|
149
132
|
bindForm() {
|
|
150
|
-
if (this.parentSmartComponent?.useQueryLists) {
|
|
151
|
-
return;
|
|
152
|
-
}
|
|
153
133
|
if (this.smartForm && this.smartFormComponent) {
|
|
154
|
-
this.
|
|
134
|
+
this.parent?.addForm(
|
|
155
135
|
// unique identifier for the form
|
|
156
136
|
`form_${this.makeid(5)}`, this.smartForm, this.smartFormComponent);
|
|
157
137
|
}
|
|
@@ -188,11 +168,8 @@ export class SmartComponentLayoutComponent {
|
|
|
188
168
|
}
|
|
189
169
|
}
|
|
190
170
|
bindGrid() {
|
|
191
|
-
if (this.parentSmartComponent?.useQueryLists) {
|
|
192
|
-
return;
|
|
193
|
-
}
|
|
194
171
|
if (this.smartGrid && this.smartGridComponent) {
|
|
195
|
-
this.smartGrid = this.
|
|
172
|
+
this.smartGrid = this.parent?.addGrid(this.smartGrid, {
|
|
196
173
|
rowUiActionType: GridUiActionType.POPUP_MENU,
|
|
197
174
|
}, false, this.smartGridComponent);
|
|
198
175
|
}
|
|
@@ -200,23 +177,14 @@ export class SmartComponentLayoutComponent {
|
|
|
200
177
|
setToolbarComponent(comp) {
|
|
201
178
|
this.toolbar = comp;
|
|
202
179
|
}
|
|
203
|
-
|
|
204
|
-
|
|
205
|
-
|
|
206
|
-
// `filter_${this.makeid(5)}`,
|
|
207
|
-
// this.smartComponentLayout?.widget?.filterExpressionFieldList,
|
|
208
|
-
// this.smartComponentLayout?.widget?.filterType,
|
|
209
|
-
// this.smartFilterComponent
|
|
210
|
-
// );
|
|
211
|
-
// }
|
|
180
|
+
constructFilter() {
|
|
181
|
+
this.smartFilter = this.smartComponentLayout.parentComponent.addFilter(`filter_${this.makeid(5)}`, this.smartComponentLayout?.widget?.filterExpressionFieldList, this.smartComponentLayout?.widget?.filterType, this.smartFilterComponent);
|
|
182
|
+
}
|
|
212
183
|
bindFilter() {
|
|
213
184
|
// TODO
|
|
214
185
|
}
|
|
215
186
|
constructTree() {
|
|
216
|
-
|
|
217
|
-
return;
|
|
218
|
-
}
|
|
219
|
-
this.parentSmartComponent.setUpDefaultTree(this.smartComponentLayout?.widget?.identifier);
|
|
187
|
+
this.parent.setUpDefaultTree(this.smartComponentLayout?.widget?.identifier);
|
|
220
188
|
this.treeService?.initialize();
|
|
221
189
|
}
|
|
222
190
|
constructToolbar() {
|
|
@@ -226,16 +194,12 @@ export class SmartComponentLayoutComponent {
|
|
|
226
194
|
}
|
|
227
195
|
}
|
|
228
196
|
}
|
|
229
|
-
SmartComponentLayoutComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: SmartComponentLayoutComponent, deps: [{ token: i1.SmartformLayoutDefinitionService }
|
|
230
|
-
SmartComponentLayoutComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.4.0", type: SmartComponentLayoutComponent, selector: "smart-component-layout", inputs: { smartComponentLayout: "smartComponentLayout"
|
|
197
|
+
SmartComponentLayoutComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: SmartComponentLayoutComponent, deps: [{ token: i1.SmartformLayoutDefinitionService }], target: i0.ɵɵFactoryTarget.Component });
|
|
198
|
+
SmartComponentLayoutComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.4.0", type: SmartComponentLayoutComponent, selector: "smart-component-layout", inputs: { smartComponentLayout: "smartComponentLayout" }, viewQueries: [{ propertyName: "smartFormList", predicate: ["form"], descendants: true }, { propertyName: "smartGridList", predicate: ["grid"], descendants: true }, { propertyName: "smartFilterList", predicate: ["filter"], descendants: true }, { propertyName: "toolbarList", predicate: ["toolbar"], descendants: true }, { propertyName: "components", predicate: SmartComponentLayoutComponent, descendants: true }], usesOnChanges: true, ngImport: i0, template: "<div *ngIf=\"smartComponentLayout?.expandable; then expandable; else normal\"> </div>\r\n\r\n<ng-template #expandable>\r\n <smart-expandable-section\r\n *ngIf=\"expandableSection\"\r\n [data]=\"expandableSection\"\r\n ></smart-expandable-section>\r\n</ng-template>\r\n\r\n<ng-template #normal>\r\n <div\r\n *ngIf=\"smartComponentLayout?.type === type().CONTAINER\"\r\n [ngClass]=\"smartComponentLayout?.direction ?? 'vertical'\"\r\n >\r\n <smart-component-layout\r\n *ngFor=\"let layout of smartComponentLayout?.components\"\r\n [smartComponentLayout]=\"layout\"\r\n ></smart-component-layout>\r\n </div>\r\n <smartform #form [smartForm]=\"smartForm\"></smartform>\r\n <smart-grid #grid [smartGrid]=\"smartGrid\" [uuid]=\"uuid!\"></smart-grid>\r\n <!-- <smart-filter #filter [filter]=\"smartFilter\"></smart-filter> -->\r\n <smart-tree *ngIf=\"treeService\" [treeService]=\"treeService!\"></smart-tree>\r\n <smart-ui-action-toolbar #toolbar [id]=\"toolbarId\"></smart-ui-action-toolbar>\r\n</ng-template>\r\n", styles: [".horizontal{display:flex;flex-direction:row}.vertical{display:flex;flex-direction:column}\n"], components: [{ type: i2.ExpandableSectionComponent, selector: "smart-expandable-section", inputs: ["data", "index"] }, { type: SmartComponentLayoutComponent, selector: "smart-component-layout", inputs: ["smartComponentLayout"] }, { type: i3.SmartformComponent, selector: "smartform", inputs: ["smartForm"] }, { type: i4.SmartGridComponent, selector: "smart-grid", inputs: ["smartGrid", "uuid", "dev"] }, { type: i5.SmartTreeComponent, selector: "smart-tree", inputs: ["treeStyle", "treeService"] }, { type: i6.UiActionToolbarComponent, selector: "smart-ui-action-toolbar", inputs: ["uiActionModels", "uiActionDescriptorService", "id"] }], directives: [{ type: i7.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i7.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { type: i7.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }] });
|
|
231
199
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: SmartComponentLayoutComponent, decorators: [{
|
|
232
200
|
type: Component,
|
|
233
|
-
args: [{ selector: 'smart-component-layout', template: "<div *ngIf=\"smartComponentLayout?.expandable; then expandable; else normal\"> </div>\r\n\r\n<ng-template #expandable>\r\n <smart-expandable-section\r\n *ngIf=\"expandableSection\"\r\n [data]=\"expandableSection\"\r\n ></smart-expandable-section>\r\n</ng-template>\r\n\r\n<ng-template #normal>\r\n <div\r\n *ngIf=\"smartComponentLayout?.type === type().CONTAINER\"\r\n [ngClass]=\"smartComponentLayout?.direction ?? 'vertical'\"\r\n >\r\n <smart-component-layout\r\n *ngFor=\"let layout of smartComponentLayout?.components\"\r\n [
|
|
234
|
-
}], ctorParameters: function () { return [{ type: i1.SmartformLayoutDefinitionService }
|
|
235
|
-
type: Input
|
|
236
|
-
}], parentLayoutComponent: [{
|
|
237
|
-
type: Input
|
|
238
|
-
}], parentSmartComponent: [{
|
|
201
|
+
args: [{ selector: 'smart-component-layout', template: "<div *ngIf=\"smartComponentLayout?.expandable; then expandable; else normal\"> </div>\r\n\r\n<ng-template #expandable>\r\n <smart-expandable-section\r\n *ngIf=\"expandableSection\"\r\n [data]=\"expandableSection\"\r\n ></smart-expandable-section>\r\n</ng-template>\r\n\r\n<ng-template #normal>\r\n <div\r\n *ngIf=\"smartComponentLayout?.type === type().CONTAINER\"\r\n [ngClass]=\"smartComponentLayout?.direction ?? 'vertical'\"\r\n >\r\n <smart-component-layout\r\n *ngFor=\"let layout of smartComponentLayout?.components\"\r\n [smartComponentLayout]=\"layout\"\r\n ></smart-component-layout>\r\n </div>\r\n <smartform #form [smartForm]=\"smartForm\"></smartform>\r\n <smart-grid #grid [smartGrid]=\"smartGrid\" [uuid]=\"uuid!\"></smart-grid>\r\n <!-- <smart-filter #filter [filter]=\"smartFilter\"></smart-filter> -->\r\n <smart-tree *ngIf=\"treeService\" [treeService]=\"treeService!\"></smart-tree>\r\n <smart-ui-action-toolbar #toolbar [id]=\"toolbarId\"></smart-ui-action-toolbar>\r\n</ng-template>\r\n", styles: [".horizontal{display:flex;flex-direction:row}.vertical{display:flex;flex-direction:column}\n"] }]
|
|
202
|
+
}], ctorParameters: function () { return [{ type: i1.SmartformLayoutDefinitionService }]; }, propDecorators: { smartComponentLayout: [{
|
|
239
203
|
type: Input
|
|
240
204
|
}], smartFormList: [{
|
|
241
205
|
type: ViewChildren,
|
|
@@ -249,11 +213,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImpor
|
|
|
249
213
|
}], toolbarList: [{
|
|
250
214
|
type: ViewChildren,
|
|
251
215
|
args: ['toolbar']
|
|
252
|
-
}], expandableComponents: [{
|
|
253
|
-
type: ViewChildren,
|
|
254
|
-
args: [ExpandableSectionComponent]
|
|
255
216
|
}], components: [{
|
|
256
217
|
type: ViewChildren,
|
|
257
218
|
args: [SmartComponentLayoutComponent]
|
|
258
219
|
}] } });
|
|
259
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"smart-component-layout.component.js","sourceRoot":"","sources":["../../../../../projects/smart-ng-client/src/lib/smart-component-layout/smart-component-layout.component.ts","../../../../../projects/smart-ng-client/src/lib/smart-component-layout/smart-component-layout.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  AfterViewInit,\r\n  Component,\r\n  ElementRef,\r\n  Input,\r\n  OnChanges,\r\n  OnDestroy,\r\n  OnInit,\r\n  QueryList,\r\n  Renderer2,\r\n  SimpleChanges,\r\n  ViewChild,\r\n  ViewChildren,\r\n} from '@angular/core';\r\nimport {\r\n  ComponentType,\r\n  ComponentWidgetType,\r\n  LayoutDirection,\r\n  SmartComponentLayoutDefinition,\r\n} from './api';\r\nimport {\r\n  SmartForm,\r\n  SmartFormWidgetDirection,\r\n  SmartformComponent,\r\n  SmartformLayoutDefinitionService,\r\n} from '../smart-form/projects';\r\nimport {\r\n  GridUiActionType,\r\n  SmartGrid,\r\n  SmartGridComponent,\r\n  SmartLayoutDef,\r\n} from '../smart-grid/projects';\r\nimport { SmartFilter, SmartFilterComponent } from '../smart-filter/projects';\r\nimport { SmarttreeGenericService } from '../smart-tree/projects';\r\nimport {\r\n  ExpandableSection,\r\n  ExpandableSectionComponent,\r\n} from '../smart-expandable-section/projects';\r\nimport { Subject, takeUntil } from 'rxjs';\r\nimport { UiActionToolbarComponent } from '../view-context/projects';\r\nimport { deepEqual } from 'fast-equals';\r\nimport { SmartComponentLayoutUtility } from './smart-component-layout-utility';\r\n\r\n@Component({\r\n  selector: 'smart-component-layout',\r\n  templateUrl: './smart-component-layout.component.html',\r\n  styleUrls: ['./smart-component-layout.component.css'],\r\n})\r\nexport class SmartComponentLayoutComponent implements AfterViewInit, OnDestroy, OnChanges {\r\n  protected _destroy$: Subject<void> = new Subject();\r\n\r\n  @Input() smartComponentLayout?: SmartComponentLayoutDefinition;\r\n  @Input() parentLayoutComponent?: SmartComponentLayoutComponent;\r\n  @Input() parentSmartComponent: any;\r\n\r\n  currentLayout?: SmartComponentLayoutDefinition;\r\n\r\n  uuid?: string;\r\n\r\n  @ViewChildren('form')\r\n  smartFormList!: QueryList<SmartformComponent>;\r\n  smartFormComponent?: SmartformComponent;\r\n  smartForm?: SmartForm;\r\n\r\n  @ViewChildren('grid')\r\n  smartGridList!: QueryList<SmartGridComponent>;\r\n  smartGridComponent?: SmartGridComponent;\r\n  smartGrid?: SmartGrid;\r\n\r\n  @ViewChildren('filter')\r\n  smartFilterList!: QueryList<SmartFilterComponent>;\r\n  smartFilterComponent?: SmartFilterComponent;\r\n  smartFilter?: SmartFilter;\r\n\r\n  @ViewChildren('toolbar')\r\n  toolbarList!: QueryList<UiActionToolbarComponent>;\r\n  toolbar?: UiActionToolbarComponent;\r\n  toolbarId?: string;\r\n\r\n  treeService?: SmarttreeGenericService;\r\n\r\n  expandableSection?: ExpandableSection<SmartComponentLayoutDefinition>;\r\n\r\n  @ViewChildren(ExpandableSectionComponent)\r\n  expandableComponents!: QueryList<ExpandableSectionComponent>;\r\n\r\n  @ViewChildren(SmartComponentLayoutComponent)\r\n  components!: QueryList<SmartComponentLayoutComponent>;\r\n\r\n  constructor(\r\n    private layoutService: SmartformLayoutDefinitionService,\r\n    private element?: ElementRef,\r\n    private renderer?: Renderer2\r\n  ) {}\r\n\r\n  ngAfterViewInit(): void {\r\n    if (this.smartFormList?.first) {\r\n      this.setFormComponent(this.smartFormList?.first);\r\n    }\r\n    this.smartFormList.changes\r\n      .pipe(takeUntil(this._destroy$))\r\n      .subscribe((list: QueryList<SmartformComponent>) => {\r\n        this.setFormComponent(list.first);\r\n      });\r\n\r\n    if (this.smartGridList?.first) {\r\n      this.setGridComponent(this.smartGridList?.first);\r\n    }\r\n    this.smartGridList.changes\r\n      .pipe(takeUntil(this._destroy$))\r\n      .subscribe((list: QueryList<SmartGridComponent>) => {\r\n        this.setGridComponent(list.first);\r\n      });\r\n\r\n    this.smartFilterList.changes\r\n      .pipe(takeUntil(this._destroy$))\r\n      .subscribe((list: QueryList<SmartFilterComponent>) => {\r\n        if (!this.smartFilterComponent) {\r\n          this.smartFilterComponent = list.first;\r\n          this.bindFilter();\r\n        }\r\n      });\r\n\r\n    if (this.toolbarList?.first) {\r\n      this.setToolbarComponent(this.toolbarList?.first);\r\n    }\r\n    this.toolbarList.changes\r\n      .pipe(takeUntil(this._destroy$))\r\n      .subscribe((list: QueryList<UiActionToolbarComponent>) => {\r\n        this.setToolbarComponent(list.first);\r\n      });\r\n    this.setUp();\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this._destroy$.next();\r\n    this._destroy$.complete();\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    this.setUp();\r\n  }\r\n\r\n  private setUp(): void {\r\n    if (!this.parentSmartComponent || !this.smartComponentLayout) {\r\n      return;\r\n    }\r\n    if (deepEqual(this.smartComponentLayout, this.currentLayout)) {\r\n      // no layout change, keep current state\r\n      this.smartComponentLayout = this.currentLayout;\r\n      return;\r\n    }\r\n    // layout changed, render, but save current\r\n    // this.currentLayout = JSON.parse(JSON.stringify(this.smartComponentLayout));\r\n    this.currentLayout = this.smartComponentLayout;\r\n\r\n    this.uuid = this.parentSmartComponent.uuid;\r\n    this.treeService = this.parentSmartComponent.smartTreeService;\r\n\r\n    this.smartComponentLayout?.direction;\r\n\r\n    if (this.smartComponentLayout?.expandable) {\r\n      this.constructExpandableSection();\r\n    } else if (this.smartComponentLayout?.type === ComponentType.FORM) {\r\n      this.constructForm();\r\n    } else if (this.smartComponentLayout?.type === ComponentType.WIDGET) {\r\n      if (this.smartComponentLayout.widget?.type === ComponentWidgetType.GRID) {\r\n        this.constructGrid();\r\n      } else if (this.smartComponentLayout.widget?.type === ComponentWidgetType.FILTER) {\r\n        console.warn('ComponentWidgetType.FILTER is not supported');\r\n        // this.constructFilter();\r\n      } else if (this.smartComponentLayout.widget?.type === ComponentWidgetType.TREE) {\r\n        this.constructTree();\r\n      } else if (this.smartComponentLayout.widget?.type === ComponentWidgetType.TOOLBAR) {\r\n        this.constructToolbar();\r\n      }\r\n      if (!this.parentLayoutComponent) {\r\n        // only top level component should call init actions\r\n        this.parentSmartComponent.initActions();\r\n      }\r\n    }\r\n\r\n    SmartComponentLayoutUtility.applyStyle(\r\n      this.smartComponentLayout.style,\r\n      this.element,\r\n      this.renderer\r\n    );\r\n  }\r\n\r\n  type(): typeof ComponentType {\r\n    return ComponentType;\r\n  }\r\n\r\n  constructExpandableSection(): void {\r\n    let data: SmartComponentLayoutDefinition = { ...this.smartComponentLayout! };\r\n    data.expandable = false;\r\n\r\n    this.expandableSection = {\r\n      title: this.smartComponentLayout?.expandableSectionLabel ?? '',\r\n      inputs: new Map<string, any>([\r\n        ['smartComponentLayout', data],\r\n        ['parentSmartComponent', this.parentSmartComponent],\r\n        ['parentLayoutComponent', this.parentLayoutComponent],\r\n      ]),\r\n      customComponent: SmartComponentLayoutComponent,\r\n    };\r\n  }\r\n\r\n  constructForm(): void {\r\n    const widgets = this.layoutService.render({\r\n      layoutDefinitions: this.smartComponentLayout?.form,\r\n    });\r\n\r\n    this.smartForm = {\r\n      direction: this.getFormLayout(),\r\n      componentModel: this.parentSmartComponent?.model,\r\n      widgets,\r\n    };\r\n\r\n    this.bindForm();\r\n  }\r\n\r\n  getFormLayout(): SmartFormWidgetDirection {\r\n    if (this.smartComponentLayout?.direction) {\r\n      return this.smartComponentLayout?.direction === LayoutDirection.HORIZONTAL\r\n        ? SmartFormWidgetDirection.ROW\r\n        : SmartFormWidgetDirection.COL;\r\n    }\r\n    return SmartFormWidgetDirection.COL;\r\n  }\r\n\r\n  setFormComponent(comp: SmartformComponent) {\r\n    if (!this.smartFormComponent) {\r\n      this.smartFormComponent = comp;\r\n      this.bindForm();\r\n    }\r\n  }\r\n\r\n  bindForm(): void {\r\n    if (this.parentSmartComponent?.useQueryLists) {\r\n      return;\r\n    }\r\n    if (this.smartForm && this.smartFormComponent) {\r\n      this.parentSmartComponent?.addForm(\r\n        // unique identifier for the form\r\n        `form_${this.makeid(5)}`,\r\n        this.smartForm,\r\n        this.smartFormComponent\r\n      );\r\n    }\r\n  }\r\n\r\n  makeid(length: number) {\r\n    let result = '';\r\n    const characters = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789';\r\n    const charactersLength = characters.length;\r\n    let counter = 0;\r\n    while (counter < length) {\r\n      result += characters.charAt(Math.floor(Math.random() * charactersLength));\r\n      counter += 1;\r\n    }\r\n    return result;\r\n  }\r\n\r\n  constructGrid(): void {\r\n    this.smartGrid = {\r\n      gridIdentifier: this.smartComponentLayout?.widget?.identifier!,\r\n      gridModel: {\r\n        page: {},\r\n      },\r\n      options: {\r\n        rowUiActionType: GridUiActionType.POPUP_MENU,\r\n      },\r\n      layoutDef: SmartLayoutDef.TABLE,\r\n      paginator: true,\r\n    };\r\n\r\n    this.bindGrid();\r\n  }\r\n\r\n  setGridComponent(comp: SmartGridComponent) {\r\n    if (!this.smartGridComponent) {\r\n      this.smartGridComponent = comp;\r\n      this.bindGrid();\r\n    }\r\n  }\r\n\r\n  bindGrid(): void {\r\n    if (this.parentSmartComponent?.useQueryLists) {\r\n      return;\r\n    }\r\n    if (this.smartGrid && this.smartGridComponent) {\r\n      this.smartGrid = this.parentSmartComponent?.addGrid(\r\n        this.smartGrid,\r\n        {\r\n          rowUiActionType: GridUiActionType.POPUP_MENU,\r\n        },\r\n        false,\r\n        this.smartGridComponent\r\n      );\r\n    }\r\n  }\r\n\r\n  setToolbarComponent(comp: UiActionToolbarComponent) {\r\n    this.toolbar = comp;\r\n  }\r\n\r\n  // NOT USED, DOESN'T WORK\r\n  // constructFilter(): void {\r\n  //   this.smartFilter = (this.smartComponentLayout!.parentComponent as any).addFilter(\r\n  //     `filter_${this.makeid(5)}`,\r\n  //     this.smartComponentLayout?.widget?.filterExpressionFieldList,\r\n  //     this.smartComponentLayout?.widget?.filterType,\r\n  //     this.smartFilterComponent\r\n  //   );\r\n  // }\r\n\r\n  bindFilter(): void {\r\n    // TODO\r\n  }\r\n\r\n  constructTree(): void {\r\n    if (this.parentSmartComponent?.useQueryLists) {\r\n      return;\r\n    }\r\n    this.parentSmartComponent.setUpDefaultTree(this.smartComponentLayout?.widget?.identifier);\r\n    this.treeService?.initialize();\r\n  }\r\n\r\n  constructToolbar(): void {\r\n    let toolbarId = this.smartComponentLayout?.widget?.identifier;\r\n    if (this.toolbarId !== toolbarId) {\r\n      this.toolbarId = toolbarId;\r\n    }\r\n  }\r\n}\r\n","<div *ngIf=\"smartComponentLayout?.expandable; then expandable; else normal\"> </div>\r\n\r\n<ng-template #expandable>\r\n  <smart-expandable-section\r\n    *ngIf=\"expandableSection\"\r\n    [data]=\"expandableSection\"\r\n  ></smart-expandable-section>\r\n</ng-template>\r\n\r\n<ng-template #normal>\r\n  <div\r\n    *ngIf=\"smartComponentLayout?.type === type().CONTAINER\"\r\n    [ngClass]=\"smartComponentLayout?.direction ?? 'vertical'\"\r\n  >\r\n    <smart-component-layout\r\n      *ngFor=\"let layout of smartComponentLayout?.components\"\r\n      [parentSmartComponent]=\"parentSmartComponent\"\r\n      [parentLayoutComponent]=\"this\"\r\n      [smartComponentLayout]=\"layout\"\r\n    ></smart-component-layout>\r\n  </div>\r\n  <smartform *ngIf=\"smartForm\" #form [smartForm]=\"smartForm\"></smartform>\r\n  <smart-grid *ngIf=\"smartGrid\" #grid [smartGrid]=\"smartGrid\" [uuid]=\"uuid!\"></smart-grid>\r\n  <!-- <smart-filter #filter [filter]=\"smartFilter\"></smart-filter> -->\r\n  <smart-tree *ngIf=\"treeService\" [treeService]=\"treeService!\"></smart-tree>\r\n  <smart-ui-action-toolbar *ngIf=\"!!toolbarId\" #toolbar [id]=\"toolbarId\"></smart-ui-action-toolbar>\r\n</ng-template>\r\n"]}
|
|
220
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"smart-component-layout.component.js","sourceRoot":"","sources":["../../../../../projects/smart-ng-client/src/lib/smart-component-layout/smart-component-layout.component.ts","../../../../../projects/smart-ng-client/src/lib/smart-component-layout/smart-component-layout.component.html"],"names":[],"mappings":"AAAA,OAAO,EAEL,SAAS,EACT,KAAK,EAOL,YAAY,GACb,MAAM,eAAe,CAAC;AACvB,OAAO,EACL,aAAa,EACb,mBAAmB,EACnB,eAAe,GAEhB,MAAM,OAAO,CAAC;AACf,OAAO,EAEL,wBAAwB,GAGzB,MAAM,wBAAwB,CAAC;AAChC,OAAO,EACL,gBAAgB,EAGhB,cAAc,GACf,MAAM,wBAAwB,CAAC;AAIhC,OAAO,EAAE,OAAO,EAAE,SAAS,EAAE,MAAM,MAAM,CAAC;;;;;;;;;AAQ1C,MAAM,OAAO,6BAA6B;IAmCxC,YAAoB,aAA+C;QAA/C,kBAAa,GAAb,aAAa,CAAkC;QAlCzD,cAAS,GAAkB,IAAI,OAAO,EAAE,CAAC;QAwBnD,cAAS,GAAY,qBAAqB,CAAC;IAU2B,CAAC;IAEvE,eAAe;QACb,IAAI,IAAI,CAAC,aAAa,EAAE,KAAK,EAAE;YAC7B,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,aAAa,EAAE,KAAK,CAAC,CAAC;SAClD;QACD,IAAI,CAAC,aAAa,CAAC,OAAO;aACvB,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;aAC/B,SAAS,CAAC,CAAC,IAAmC,EAAE,EAAE;YACjD,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QACpC,CAAC,CAAC,CAAC;QAEL,IAAI,IAAI,CAAC,aAAa,EAAE,KAAK,EAAE;YAC7B,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,aAAa,EAAE,KAAK,CAAC,CAAC;SAClD;QACD,IAAI,CAAC,aAAa,CAAC,OAAO;aACvB,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;aAC/B,SAAS,CAAC,CAAC,IAAmC,EAAE,EAAE;YACjD,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QACpC,CAAC,CAAC,CAAC;QAEL,IAAI,CAAC,eAAe,CAAC,OAAO;aACzB,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;aAC/B,SAAS,CAAC,CAAC,IAAqC,EAAE,EAAE;YACnD,IAAI,CAAC,IAAI,CAAC,oBAAoB,EAAE;gBAC9B,IAAI,CAAC,oBAAoB,GAAG,IAAI,CAAC,KAAK,CAAC;gBACvC,IAAI,CAAC,UAAU,EAAE,CAAC;aACnB;QACH,CAAC,CAAC,CAAC;QAEL,IAAI,IAAI,CAAC,WAAW,EAAE,KAAK,EAAE;YAC3B,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,WAAW,EAAE,KAAK,CAAC,CAAC;SACnD;QACD,IAAI,CAAC,WAAW,CAAC,OAAO;aACrB,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;aAC/B,SAAS,CAAC,CAAC,IAAyC,EAAE,EAAE;YACvD,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QACvC,CAAC,CAAC,CAAC;QAEL,IAAI,IAAI,CAAC,oBAAoB,EAAE;YAC7B,IAAI,CAAC,KAAK,EAAE,CAAC;SACd;IACH,CAAC;IAED,WAAW;QACT,IAAI,CAAC,SAAS,CAAC,IAAI,EAAE,CAAC;QACtB,IAAI,CAAC,SAAS,CAAC,QAAQ,EAAE,CAAC;IAC5B,CAAC;IAED,WAAW,CAAC,OAAsB;QAChC,IAAI,CAAC,oBAAoB,GAAG,OAAO,CAAC,sBAAsB,CAAC,CAAC,YAAY,CAAC;QAEzE,IAAI,IAAI,CAAC,oBAAoB,EAAE;YAC7B,IAAI,CAAC,KAAK,EAAE,CAAC;SACd;IACH,CAAC;IAEO,KAAK;QACX,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,oBAAoB,EAAE,eAAsB,CAAC;QAChE,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC;QAC7B,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,MAAM,CAAC,gBAAgB,CAAC;QAEhD,IAAI,CAAC,oBAAoB,EAAE,SAAS,CAAC;QAErC,IAAI,IAAI,CAAC,oBAAoB,EAAE,UAAU,EAAE;YACzC,IAAI,CAAC,0BAA0B,EAAE,CAAC;SACnC;aAAM,IAAI,IAAI,CAAC,oBAAoB,EAAE,IAAI,KAAK,aAAa,CAAC,IAAI,EAAE;YACjE,IAAI,CAAC,aAAa,EAAE,CAAC;SACtB;aAAM,IAAI,IAAI,CAAC,oBAAoB,EAAE,IAAI,KAAK,aAAa,CAAC,MAAM,EAAE;YACnE,IAAI,IAAI,CAAC,oBAAoB,CAAC,MAAM,EAAE,IAAI,KAAK,mBAAmB,CAAC,IAAI,EAAE;gBACvE,IAAI,CAAC,aAAa,EAAE,CAAC;aACtB;iBAAM,IAAI,IAAI,CAAC,oBAAoB,CAAC,MAAM,EAAE,IAAI,KAAK,mBAAmB,CAAC,MAAM,EAAE;gBAChF,IAAI,CAAC,eAAe,EAAE,CAAC;aACxB;iBAAM,IAAI,IAAI,CAAC,oBAAoB,CAAC,MAAM,EAAE,IAAI,KAAK,mBAAmB,CAAC,IAAI,EAAE;gBAC9E,IAAI,CAAC,aAAa,EAAE,CAAC;aACtB;iBAAM,IAAI,IAAI,CAAC,oBAAoB,CAAC,MAAM,EAAE,IAAI,KAAK,mBAAmB,CAAC,OAAO,EAAE;gBACjF,IAAI,CAAC,gBAAgB,EAAE,CAAC;aACzB;YACD,IAAI,CAAC,MAAM,CAAC,WAAW,EAAE,CAAC;SAC3B;IACH,CAAC;IAED,IAAI;QACF,OAAO,aAAa,CAAC;IACvB,CAAC;IAED,0BAA0B;QACxB,IAAI,IAAI,GAAmC,EAAE,GAAG,IAAI,CAAC,oBAAqB,EAAE,CAAC;QAC7E,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC;QAExB,IAAI,CAAC,iBAAiB,GAAG;YACvB,KAAK,EAAE,IAAI,CAAC,oBAAoB,EAAE,sBAAsB,IAAI,EAAE;YAC9D,IAAI;YACJ,SAAS,EAAE,sBAAsB;YACjC,eAAe,EAAE,6BAA6B;SAC/C,CAAC;IACJ,CAAC;IAED,aAAa;QACX,MAAM,OAAO,GAAG,IAAI,CAAC,aAAa,CAAC,MAAM,CAAC;YACxC,iBAAiB,EAAE,IAAI,CAAC,oBAAoB,EAAE,IAAI;SACnD,CAAC,CAAC;QAEH,IAAI,CAAC,SAAS,GAAG;YACf,SAAS,EAAE,IAAI,CAAC,aAAa,EAAE;YAC/B,cAAc,EAAE,IAAI,CAAC,MAAM,EAAE,KAAK;YAClC,OAAO;SACR,CAAC;QAEF,IAAI,CAAC,QAAQ,EAAE,CAAC;IAClB,CAAC;IAED,aAAa;QACX,IAAI,IAAI,CAAC,oBAAoB,EAAE,SAAS,EAAE;YACxC,OAAO,IAAI,CAAC,oBAAoB,EAAE,SAAS,KAAK,eAAe,CAAC,UAAU;gBACxE,CAAC,CAAC,wBAAwB,CAAC,GAAG;gBAC9B,CAAC,CAAC,wBAAwB,CAAC,GAAG,CAAC;SAClC;QACD,OAAO,wBAAwB,CAAC,GAAG,CAAC;IACtC,CAAC;IAED,gBAAgB,CAAC,IAAwB;QACvC,IAAI,CAAC,IAAI,CAAC,kBAAkB,EAAE;YAC5B,IAAI,CAAC,kBAAkB,GAAG,IAAI,CAAC;YAC/B,IAAI,CAAC,QAAQ,EAAE,CAAC;SACjB;IACH,CAAC;IAED,QAAQ;QACN,IAAI,IAAI,CAAC,SAAS,IAAI,IAAI,CAAC,kBAAkB,EAAE;YAC7C,IAAI,CAAC,MAAM,EAAE,OAAO;YAClB,iCAAiC;YACjC,QAAQ,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EACxB,IAAI,CAAC,SAAS,EACd,IAAI,CAAC,kBAAkB,CACxB,CAAC;SACH;IACH,CAAC;IAED,MAAM,CAAC,MAAc;QACnB,IAAI,MAAM,GAAG,EAAE,CAAC;QAChB,MAAM,UAAU,GAAG,gEAAgE,CAAC;QACpF,MAAM,gBAAgB,GAAG,UAAU,CAAC,MAAM,CAAC;QAC3C,IAAI,OAAO,GAAG,CAAC,CAAC;QAChB,OAAO,OAAO,GAAG,MAAM,EAAE;YACvB,MAAM,IAAI,UAAU,CAAC,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,MAAM,EAAE,GAAG,gBAAgB,CAAC,CAAC,CAAC;YAC1E,OAAO,IAAI,CAAC,CAAC;SACd;QACD,OAAO,MAAM,CAAC;IAChB,CAAC;IAED,aAAa;QACX,IAAI,CAAC,SAAS,GAAG;YACf,cAAc,EAAE,IAAI,CAAC,oBAAoB,EAAE,MAAM,EAAE,UAAW;YAC9D,SAAS,EAAE;gBACT,IAAI,EAAE,EAAE;aACT;YACD,OAAO,EAAE;gBACP,eAAe,EAAE,gBAAgB,CAAC,UAAU;aAC7C;YACD,SAAS,EAAE,cAAc,CAAC,KAAK;YAC/B,SAAS,EAAE,IAAI;SAChB,CAAC;QAEF,IAAI,CAAC,QAAQ,EAAE,CAAC;IAClB,CAAC;IAED,gBAAgB,CAAC,IAAwB;QACvC,IAAI,CAAC,IAAI,CAAC,kBAAkB,EAAE;YAC5B,IAAI,CAAC,kBAAkB,GAAG,IAAI,CAAC;YAC/B,IAAI,CAAC,QAAQ,EAAE,CAAC;SACjB;IACH,CAAC;IAED,QAAQ;QACN,IAAI,IAAI,CAAC,SAAS,IAAI,IAAI,CAAC,kBAAkB,EAAE;YAC7C,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,MAAM,EAAE,OAAO,CACnC,IAAI,CAAC,SAAS,EACd;gBACE,eAAe,EAAE,gBAAgB,CAAC,UAAU;aAC7C,EACD,KAAK,EACL,IAAI,CAAC,kBAAkB,CACxB,CAAC;SACH;IACH,CAAC;IAED,mBAAmB,CAAC,IAA8B;QAChD,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC;IACtB,CAAC;IAED,eAAe;QACb,IAAI,CAAC,WAAW,GAAI,IAAI,CAAC,oBAAqB,CAAC,eAAuB,CAAC,SAAS,CAC9E,UAAU,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAC1B,IAAI,CAAC,oBAAoB,EAAE,MAAM,EAAE,yBAAyB,EAC5D,IAAI,CAAC,oBAAoB,EAAE,MAAM,EAAE,UAAU,EAC7C,IAAI,CAAC,oBAAoB,CAC1B,CAAC;IACJ,CAAC;IAED,UAAU;QACR,OAAO;IACT,CAAC;IAED,aAAa;QACX,IAAI,CAAC,MAAM,CAAC,gBAAgB,CAAC,IAAI,CAAC,oBAAoB,EAAE,MAAM,EAAE,UAAU,CAAC,CAAC;QAC5E,IAAI,CAAC,WAAW,EAAE,UAAU,EAAE,CAAC;IACjC,CAAC;IAED,gBAAgB;QACd,IAAI,SAAS,GAAG,IAAI,CAAC,oBAAoB,EAAE,MAAM,EAAE,UAAU,CAAC;QAC9D,IAAI,IAAI,CAAC,SAAS,KAAK,SAAS,EAAE;YAChC,IAAI,CAAC,SAAS,GAAG,SAAS,CAAC;SAC5B;IACH,CAAC;;0HAzPU,6BAA6B;8GAA7B,6BAA6B,wcAgC1B,6BAA6B,qECzE7C,whCAyBA,0ODgBa,6BAA6B;2FAA7B,6BAA6B;kBALzC,SAAS;+BACE,wBAAwB;uHAOzB,oBAAoB;sBAA5B,KAAK;gBAKN,aAAa;sBADZ,YAAY;uBAAC,MAAM;gBAMpB,aAAa;sBADZ,YAAY;uBAAC,MAAM;gBAMpB,eAAe;sBADd,YAAY;uBAAC,QAAQ;gBAMtB,WAAW;sBADV,YAAY;uBAAC,SAAS;gBAWvB,UAAU;sBADT,YAAY;uBAAC,6BAA6B","sourcesContent":["import {\r\n  AfterViewInit,\r\n  Component,\r\n  Input,\r\n  OnChanges,\r\n  OnDestroy,\r\n  OnInit,\r\n  QueryList,\r\n  SimpleChanges,\r\n  ViewChild,\r\n  ViewChildren,\r\n} from '@angular/core';\r\nimport {\r\n  ComponentType,\r\n  ComponentWidgetType,\r\n  LayoutDirection,\r\n  SmartComponentLayoutDefinition,\r\n} from './api';\r\nimport {\r\n  SmartForm,\r\n  SmartFormWidgetDirection,\r\n  SmartformComponent,\r\n  SmartformLayoutDefinitionService,\r\n} from '../smart-form/projects';\r\nimport {\r\n  GridUiActionType,\r\n  SmartGrid,\r\n  SmartGridComponent,\r\n  SmartLayoutDef,\r\n} from '../smart-grid/projects';\r\nimport { SmartFilter, SmartFilterComponent } from '../smart-filter/projects';\r\nimport { SmarttreeGenericService } from '../smart-tree/projects';\r\nimport { ExpandableSection } from '../smart-expandable-section/projects';\r\nimport { Subject, takeUntil } from 'rxjs';\r\nimport { UiActionToolbarComponent } from '../view-context/projects';\r\n\r\n@Component({\r\n  selector: 'smart-component-layout',\r\n  templateUrl: './smart-component-layout.component.html',\r\n  styleUrls: ['./smart-component-layout.component.css'],\r\n})\r\nexport class SmartComponentLayoutComponent implements AfterViewInit, OnDestroy, OnChanges {\r\n  protected _destroy$: Subject<void> = new Subject();\r\n\r\n  @Input() smartComponentLayout?: SmartComponentLayoutDefinition;\r\n\r\n  uuid?: string;\r\n\r\n  @ViewChildren('form')\r\n  smartFormList!: QueryList<SmartformComponent>;\r\n  smartFormComponent?: SmartformComponent;\r\n  smartForm?: SmartForm;\r\n\r\n  @ViewChildren('grid')\r\n  smartGridList!: QueryList<SmartGridComponent>;\r\n  smartGridComponent?: SmartGridComponent;\r\n  smartGrid?: SmartGrid;\r\n\r\n  @ViewChildren('filter')\r\n  smartFilterList!: QueryList<SmartFilterComponent>;\r\n  smartFilterComponent?: SmartFilterComponent;\r\n  smartFilter?: SmartFilter;\r\n\r\n  @ViewChildren('toolbar')\r\n  toolbarList!: QueryList<UiActionToolbarComponent>;\r\n  toolbar?: UiActionToolbarComponent;\r\n  toolbarId?: string = 'not_initialized_yet';\r\n\r\n  parent?: any; //SmartComponent<any>\r\n  treeService?: SmarttreeGenericService;\r\n\r\n  expandableSection?: ExpandableSection<SmartComponentLayoutDefinition>;\r\n\r\n  @ViewChildren(SmartComponentLayoutComponent)\r\n  components!: QueryList<SmartComponentLayoutComponent>;\r\n\r\n  constructor(private layoutService: SmartformLayoutDefinitionService) {}\r\n\r\n  ngAfterViewInit(): void {\r\n    if (this.smartFormList?.first) {\r\n      this.setFormComponent(this.smartFormList?.first);\r\n    }\r\n    this.smartFormList.changes\r\n      .pipe(takeUntil(this._destroy$))\r\n      .subscribe((list: QueryList<SmartformComponent>) => {\r\n        this.setFormComponent(list.first);\r\n      });\r\n\r\n    if (this.smartGridList?.first) {\r\n      this.setGridComponent(this.smartGridList?.first);\r\n    }\r\n    this.smartGridList.changes\r\n      .pipe(takeUntil(this._destroy$))\r\n      .subscribe((list: QueryList<SmartGridComponent>) => {\r\n        this.setGridComponent(list.first);\r\n      });\r\n\r\n    this.smartFilterList.changes\r\n      .pipe(takeUntil(this._destroy$))\r\n      .subscribe((list: QueryList<SmartFilterComponent>) => {\r\n        if (!this.smartFilterComponent) {\r\n          this.smartFilterComponent = list.first;\r\n          this.bindFilter();\r\n        }\r\n      });\r\n\r\n    if (this.toolbarList?.first) {\r\n      this.setToolbarComponent(this.toolbarList?.first);\r\n    }\r\n    this.toolbarList.changes\r\n      .pipe(takeUntil(this._destroy$))\r\n      .subscribe((list: QueryList<UiActionToolbarComponent>) => {\r\n        this.setToolbarComponent(list.first);\r\n      });\r\n\r\n    if (this.smartComponentLayout) {\r\n      this.setUp();\r\n    }\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this._destroy$.next();\r\n    this._destroy$.complete();\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    this.smartComponentLayout = changes['smartComponentLayout'].currentValue;\r\n\r\n    if (this.smartComponentLayout) {\r\n      this.setUp();\r\n    }\r\n  }\r\n\r\n  private setUp(): void {\r\n    this.parent = this.smartComponentLayout?.parentComponent as any;\r\n    this.uuid = this.parent.uuid;\r\n    this.treeService = this.parent.smartTreeService;\r\n\r\n    this.smartComponentLayout?.direction;\r\n\r\n    if (this.smartComponentLayout?.expandable) {\r\n      this.constructExpandableSection();\r\n    } else if (this.smartComponentLayout?.type === ComponentType.FORM) {\r\n      this.constructForm();\r\n    } else if (this.smartComponentLayout?.type === ComponentType.WIDGET) {\r\n      if (this.smartComponentLayout.widget?.type === ComponentWidgetType.GRID) {\r\n        this.constructGrid();\r\n      } else if (this.smartComponentLayout.widget?.type === ComponentWidgetType.FILTER) {\r\n        this.constructFilter();\r\n      } else if (this.smartComponentLayout.widget?.type === ComponentWidgetType.TREE) {\r\n        this.constructTree();\r\n      } else if (this.smartComponentLayout.widget?.type === ComponentWidgetType.TOOLBAR) {\r\n        this.constructToolbar();\r\n      }\r\n      this.parent.initActions();\r\n    }\r\n  }\r\n\r\n  type(): typeof ComponentType {\r\n    return ComponentType;\r\n  }\r\n\r\n  constructExpandableSection(): void {\r\n    let data: SmartComponentLayoutDefinition = { ...this.smartComponentLayout! };\r\n    data.expandable = false;\r\n\r\n    this.expandableSection = {\r\n      title: this.smartComponentLayout?.expandableSectionLabel ?? '',\r\n      data,\r\n      inputName: 'smartComponentLayout',\r\n      customComponent: SmartComponentLayoutComponent,\r\n    };\r\n  }\r\n\r\n  constructForm(): void {\r\n    const widgets = this.layoutService.render({\r\n      layoutDefinitions: this.smartComponentLayout?.form,\r\n    });\r\n\r\n    this.smartForm = {\r\n      direction: this.getFormLayout(),\r\n      componentModel: this.parent?.model,\r\n      widgets,\r\n    };\r\n\r\n    this.bindForm();\r\n  }\r\n\r\n  getFormLayout(): SmartFormWidgetDirection {\r\n    if (this.smartComponentLayout?.direction) {\r\n      return this.smartComponentLayout?.direction === LayoutDirection.HORIZONTAL\r\n        ? SmartFormWidgetDirection.ROW\r\n        : SmartFormWidgetDirection.COL;\r\n    }\r\n    return SmartFormWidgetDirection.COL;\r\n  }\r\n\r\n  setFormComponent(comp: SmartformComponent) {\r\n    if (!this.smartFormComponent) {\r\n      this.smartFormComponent = comp;\r\n      this.bindForm();\r\n    }\r\n  }\r\n\r\n  bindForm(): void {\r\n    if (this.smartForm && this.smartFormComponent) {\r\n      this.parent?.addForm(\r\n        // unique identifier for the form\r\n        `form_${this.makeid(5)}`,\r\n        this.smartForm,\r\n        this.smartFormComponent\r\n      );\r\n    }\r\n  }\r\n\r\n  makeid(length: number) {\r\n    let result = '';\r\n    const characters = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789';\r\n    const charactersLength = characters.length;\r\n    let counter = 0;\r\n    while (counter < length) {\r\n      result += characters.charAt(Math.floor(Math.random() * charactersLength));\r\n      counter += 1;\r\n    }\r\n    return result;\r\n  }\r\n\r\n  constructGrid(): void {\r\n    this.smartGrid = {\r\n      gridIdentifier: this.smartComponentLayout?.widget?.identifier!,\r\n      gridModel: {\r\n        page: {},\r\n      },\r\n      options: {\r\n        rowUiActionType: GridUiActionType.POPUP_MENU,\r\n      },\r\n      layoutDef: SmartLayoutDef.TABLE,\r\n      paginator: true,\r\n    };\r\n\r\n    this.bindGrid();\r\n  }\r\n\r\n  setGridComponent(comp: SmartGridComponent) {\r\n    if (!this.smartGridComponent) {\r\n      this.smartGridComponent = comp;\r\n      this.bindGrid();\r\n    }\r\n  }\r\n\r\n  bindGrid(): void {\r\n    if (this.smartGrid && this.smartGridComponent) {\r\n      this.smartGrid = this.parent?.addGrid(\r\n        this.smartGrid,\r\n        {\r\n          rowUiActionType: GridUiActionType.POPUP_MENU,\r\n        },\r\n        false,\r\n        this.smartGridComponent\r\n      );\r\n    }\r\n  }\r\n\r\n  setToolbarComponent(comp: UiActionToolbarComponent) {\r\n    this.toolbar = comp;\r\n  }\r\n\r\n  constructFilter(): void {\r\n    this.smartFilter = (this.smartComponentLayout!.parentComponent as any).addFilter(\r\n      `filter_${this.makeid(5)}`,\r\n      this.smartComponentLayout?.widget?.filterExpressionFieldList,\r\n      this.smartComponentLayout?.widget?.filterType,\r\n      this.smartFilterComponent\r\n    );\r\n  }\r\n\r\n  bindFilter(): void {\r\n    // TODO\r\n  }\r\n\r\n  constructTree(): void {\r\n    this.parent.setUpDefaultTree(this.smartComponentLayout?.widget?.identifier);\r\n    this.treeService?.initialize();\r\n  }\r\n\r\n  constructToolbar(): void {\r\n    let toolbarId = this.smartComponentLayout?.widget?.identifier;\r\n    if (this.toolbarId !== toolbarId) {\r\n      this.toolbarId = toolbarId;\r\n    }\r\n  }\r\n}\r\n","<div *ngIf=\"smartComponentLayout?.expandable; then expandable; else normal\"> </div>\r\n\r\n<ng-template #expandable>\r\n  <smart-expandable-section\r\n    *ngIf=\"expandableSection\"\r\n    [data]=\"expandableSection\"\r\n  ></smart-expandable-section>\r\n</ng-template>\r\n\r\n<ng-template #normal>\r\n  <div\r\n    *ngIf=\"smartComponentLayout?.type === type().CONTAINER\"\r\n    [ngClass]=\"smartComponentLayout?.direction ?? 'vertical'\"\r\n  >\r\n    <smart-component-layout\r\n      *ngFor=\"let layout of smartComponentLayout?.components\"\r\n      [smartComponentLayout]=\"layout\"\r\n    ></smart-component-layout>\r\n  </div>\r\n  <smartform #form [smartForm]=\"smartForm\"></smartform>\r\n  <smart-grid #grid [smartGrid]=\"smartGrid\" [uuid]=\"uuid!\"></smart-grid>\r\n  <!-- <smart-filter #filter [filter]=\"smartFilter\"></smart-filter> -->\r\n  <smart-tree *ngIf=\"treeService\" [treeService]=\"treeService!\"></smart-tree>\r\n  <smart-ui-action-toolbar #toolbar [id]=\"toolbarId\"></smart-ui-action-toolbar>\r\n</ng-template>\r\n"]}
|
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
import { NgModule } from '@angular/core';
|
|
2
2
|
import { MatCommonModule } from '@angular/material/core';
|
|
3
3
|
import { BrowserModule } from '@angular/platform-browser';
|
|
4
|
+
import { SmartformModule } from '../smart-form/smartform.module';
|
|
4
5
|
import { SmartGridModule } from '../smart-grid/smart-grid.module';
|
|
5
6
|
import { SmartExpandableSectionModule } from '../smart-expandable-section/smart-expandable-section.module';
|
|
6
7
|
import { SmarttreeModule } from '../smart-tree/smarttree.module';
|
|
@@ -12,6 +13,7 @@ export class SmartComponentLayoutModule {
|
|
|
12
13
|
SmartComponentLayoutModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: SmartComponentLayoutModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
13
14
|
SmartComponentLayoutModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: SmartComponentLayoutModule, declarations: [SmartComponentLayoutComponent], imports: [BrowserModule,
|
|
14
15
|
MatCommonModule,
|
|
16
|
+
SmartformModule,
|
|
15
17
|
SmartGridModule,
|
|
16
18
|
SmartExpandableSectionModule,
|
|
17
19
|
SmarttreeModule,
|
|
@@ -19,6 +21,7 @@ SmartComponentLayoutModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.
|
|
|
19
21
|
SmartComponentLayoutModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: SmartComponentLayoutModule, providers: [], imports: [[
|
|
20
22
|
BrowserModule,
|
|
21
23
|
MatCommonModule,
|
|
24
|
+
SmartformModule,
|
|
22
25
|
SmartGridModule,
|
|
23
26
|
SmartExpandableSectionModule,
|
|
24
27
|
SmarttreeModule,
|
|
@@ -31,6 +34,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImpor
|
|
|
31
34
|
imports: [
|
|
32
35
|
BrowserModule,
|
|
33
36
|
MatCommonModule,
|
|
37
|
+
SmartformModule,
|
|
34
38
|
SmartGridModule,
|
|
35
39
|
SmartExpandableSectionModule,
|
|
36
40
|
SmarttreeModule,
|
|
@@ -40,4 +44,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImpor
|
|
|
40
44
|
providers: [],
|
|
41
45
|
}]
|
|
42
46
|
}] });
|
|
43
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
47
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic21hcnQtY29tcG9uZW50LWxheW91dC5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9zbWFydC1uZy1jbGllbnQvc3JjL2xpYi9zbWFydC1jb21wb25lbnQtbGF5b3V0L3NtYXJ0LWNvbXBvbmVudC1sYXlvdXQubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLHdCQUF3QixDQUFDO0FBQ3pELE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSwyQkFBMkIsQ0FBQztBQUMxRCxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sZ0NBQWdDLENBQUM7QUFDakUsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLGlDQUFpQyxDQUFDO0FBQ2xFLE9BQU8sRUFBRSw0QkFBNEIsRUFBRSxNQUFNLDZEQUE2RCxDQUFDO0FBQzNHLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSxnQ0FBZ0MsQ0FBQztBQUNqRSxPQUFPLEVBQUUsNkJBQTZCLEVBQUUsTUFBTSxvQ0FBb0MsQ0FBQztBQUNuRixPQUFPLEVBQUUsc0JBQXNCLEVBQUUsTUFBTSwyQ0FBMkMsQ0FBQzs7QUFnQm5GLE1BQU0sT0FBTywwQkFBMEI7O3VIQUExQiwwQkFBMEI7d0hBQTFCLDBCQUEwQixpQkFidEIsNkJBQTZCLGFBRTFDLGFBQWE7UUFDYixlQUFlO1FBQ2YsZUFBZTtRQUNmLGVBQWU7UUFDZiw0QkFBNEI7UUFDNUIsZUFBZTtRQUNmLHNCQUFzQixhQUVkLDZCQUE2Qjt3SEFHNUIsMEJBQTBCLGFBRjFCLEVBQUUsWUFWSjtZQUNQLGFBQWE7WUFDYixlQUFlO1lBQ2YsZUFBZTtZQUNmLGVBQWU7WUFDZiw0QkFBNEI7WUFDNUIsZUFBZTtZQUNmLHNCQUFzQjtTQUN2QjsyRkFJVSwwQkFBMEI7a0JBZHRDLFFBQVE7bUJBQUM7b0JBQ1IsWUFBWSxFQUFFLENBQUMsNkJBQTZCLENBQUM7b0JBQzdDLE9BQU8sRUFBRTt3QkFDUCxhQUFhO3dCQUNiLGVBQWU7d0JBQ2YsZUFBZTt3QkFDZixlQUFlO3dCQUNmLDRCQUE0Qjt3QkFDNUIsZUFBZTt3QkFDZixzQkFBc0I7cUJBQ3ZCO29CQUNELE9BQU8sRUFBRSxDQUFDLDZCQUE2QixDQUFDO29CQUN4QyxTQUFTLEVBQUUsRUFBRTtpQkFDZCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IE1hdENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2NvcmUnO1xyXG5pbXBvcnQgeyBCcm93c2VyTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvcGxhdGZvcm0tYnJvd3Nlcic7XHJcbmltcG9ydCB7IFNtYXJ0Zm9ybU1vZHVsZSB9IGZyb20gJy4uL3NtYXJ0LWZvcm0vc21hcnRmb3JtLm1vZHVsZSc7XHJcbmltcG9ydCB7IFNtYXJ0R3JpZE1vZHVsZSB9IGZyb20gJy4uL3NtYXJ0LWdyaWQvc21hcnQtZ3JpZC5tb2R1bGUnO1xyXG5pbXBvcnQgeyBTbWFydEV4cGFuZGFibGVTZWN0aW9uTW9kdWxlIH0gZnJvbSAnLi4vc21hcnQtZXhwYW5kYWJsZS1zZWN0aW9uL3NtYXJ0LWV4cGFuZGFibGUtc2VjdGlvbi5tb2R1bGUnO1xyXG5pbXBvcnQgeyBTbWFydHRyZWVNb2R1bGUgfSBmcm9tICcuLi9zbWFydC10cmVlL3NtYXJ0dHJlZS5tb2R1bGUnO1xyXG5pbXBvcnQgeyBTbWFydENvbXBvbmVudExheW91dENvbXBvbmVudCB9IGZyb20gJy4vc21hcnQtY29tcG9uZW50LWxheW91dC5jb21wb25lbnQnO1xyXG5pbXBvcnQgeyBTbWFydFZpZXdDb250ZXh0TW9kdWxlIH0gZnJvbSAnLi4vdmlldy1jb250ZXh0L3NtYXJ0LXZpZXctY29udGV4dC5tb2R1bGUnO1xyXG5cclxuQE5nTW9kdWxlKHtcclxuICBkZWNsYXJhdGlvbnM6IFtTbWFydENvbXBvbmVudExheW91dENvbXBvbmVudF0sXHJcbiAgaW1wb3J0czogW1xyXG4gICAgQnJvd3Nlck1vZHVsZSxcclxuICAgIE1hdENvbW1vbk1vZHVsZSxcclxuICAgIFNtYXJ0Zm9ybU1vZHVsZSxcclxuICAgIFNtYXJ0R3JpZE1vZHVsZSxcclxuICAgIFNtYXJ0RXhwYW5kYWJsZVNlY3Rpb25Nb2R1bGUsXHJcbiAgICBTbWFydHRyZWVNb2R1bGUsXHJcbiAgICBTbWFydFZpZXdDb250ZXh0TW9kdWxlLFxyXG4gIF0sXHJcbiAgZXhwb3J0czogW1NtYXJ0Q29tcG9uZW50TGF5b3V0Q29tcG9uZW50XSxcclxuICBwcm92aWRlcnM6IFtdLFxyXG59KVxyXG5leHBvcnQgY2xhc3MgU21hcnRDb21wb25lbnRMYXlvdXRNb2R1bGUge31cclxuIl19
|
|
@@ -13,4 +13,4 @@ export var SmartActionType;
|
|
|
13
13
|
SmartActionType[SmartActionType["SAVE"] = 5] = "SAVE";
|
|
14
14
|
SmartActionType[SmartActionType["OK"] = 6] = "OK";
|
|
15
15
|
})(SmartActionType || (SmartActionType = {}));
|
|
16
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
16
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic21hcnRkaWFsb2cubW9kZWwuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9zbWFydC1uZy1jbGllbnQvc3JjL2xpYi9zbWFydC1kaWFsb2cvc21hcnRkaWFsb2cubW9kZWwudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBY0E7Ozs7R0FJRztBQUNILE1BQU0sQ0FBTixJQUFZLGVBUVg7QUFSRCxXQUFZLGVBQWU7SUFDekIsbURBQUcsQ0FBQTtJQUNILHlEQUFNLENBQUE7SUFDTix5REFBTSxDQUFBO0lBQ04seURBQU0sQ0FBQTtJQUNOLHlEQUFNLENBQUE7SUFDTixxREFBSSxDQUFBO0lBQ0osaURBQUUsQ0FBQTtBQUNKLENBQUMsRUFSVyxlQUFlLEtBQWYsZUFBZSxRQVExQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFNtYXJ0Rm9ybSB9IGZyb20gJy4uL3NtYXJ0LWZvcm0vcHJvamVjdHMnO1xyXG5pbXBvcnQgeyBTbWFydFRhYmxlIH0gZnJvbSAnLi4vc21hcnQtdGFibGUvcHJvamVjdHMnO1xyXG5cclxuLyoqXHJcbiAqIFRoaXMgaW50ZXJmYWNlIGRlZmluZXMgdGhlIHNpemUgb2YgYSBkaWFsb2cuXHJcbiAqXHJcbiAqIEBhdXRob3IgUm9sYW5kIEbDqW55ZXNcclxuICovXHJcbmV4cG9ydCBpbnRlcmZhY2UgU21hcnREaWFsb2dTaXplIHtcclxuICB3aWR0aD86IG51bWJlcjtcclxuICBoZWlnaHQ/OiBudW1iZXI7XHJcbiAgZnVsbFNjcmVlbj86IGJvb2xlYW47XHJcbn1cclxuXHJcbi8qKlxyXG4gKiBUaGlzIGVudW0gaGVscHMgdG8gZGVmaW5lIHRoZSBhY3Rpb24gb2YgYSBkaWFsb2cuXHJcbiAqXHJcbiAqIEBhdXRob3IgUm9sYW5kIEbDqW55ZXNcclxuICovXHJcbmV4cG9ydCBlbnVtIFNtYXJ0QWN0aW9uVHlwZSB7XHJcbiAgQURELFxyXG4gIENSRUFURSxcclxuICBVUERBVEUsXHJcbiAgUkVNT1ZFLFxyXG4gIERFTEVURSxcclxuICBTQVZFLFxyXG4gIE9LLFxyXG59XHJcblxyXG4vKipcclxuICogVGhpcyBpbnRlcmZhY2UgZGVzY3JpYmVzIHRoZSBjb250ZW50IG9mIGEgZGlhbG9nLlxyXG4gKlxyXG4gKiBAYXV0aG9yIFJvbGFuZCBGw6lueWVzXHJcbiAqL1xyXG5leHBvcnQgaW50ZXJmYWNlIFNtYXJ0Q29udGVudCB7XHJcbiAgdGl0bGU6IHN0cmluZztcclxuICBkZXNjcmlwdGlvbj86IHN0cmluZztcclxufVxyXG5cclxuLyoqXHJcbiAqIFdpdGggdGhpcyBpbnRlcmZhY2UgYW55IGtpbmQgb2YgZGlhbG9ncyBjYW4gYmUgZWFzaWx5IGNyZWF0ZWQuXHJcbiAqXHJcbiAqIFlvdSBtdXN0IGNsb3NlIHRoZSBkaWFsb2cgbWFudWFsbHkhXHJcbiAqXHJcbiAqIEBwYXJhbSBzaXplIFJlcXVpcmVkLiBZb3UgY2FuIGRlZmluZSB0aGUgZGVzaXJlZCBzaXplIG9mIHRoZSBkaWFsb2dcclxuICogQHBhcmFtIGFjdGlvblR5cGUgUmVxdWlyZWQuIFRoZSBtYWluIGFjdGlvbiB0eXBlIG9mIHRoZSBkaWFsb2dcclxuICogQHBhcmFtIGNvbnRlbnQgUmVxdWlyZWQuIERlZmluZXMgdGhlIHRpdGxlIGFuZCB0aGUgZGVzY3JpcHRpb24gb2YgdGhlIGRpYWxvZ1xyXG4gKiBAcGFyYW0gZm9ybSBOb3QgcmVxdWlyZWQuIFlvdSBjYW4gcHJlc2VudCBhIGN1c3RvbSBhbmQgZHluYW1pYyBmb3JtLlxyXG4gKiBAcGFyYW0gdGFibGUgTm90IHJlcXVpcmVkLiBZb3UgY2FuIHByZXNlbnQgYSBjdXN0b20gdGFibGUuXHJcbiAqIEBwYXJhbSBva0NhbGxiYWNrIE5vdCByZXF1aXJlZC4gQSBjdXN0b20gY2FsbGJhY2sgZnVuY3Rpb24uXHJcbiAqIEBwYXJhbSBjbG9zZUNhbGxiYWNrIE5vdCByZXF1aXJlZC4gQSBjdXN0b20gY2FsbGJhY2sgZnVuY3Rpb24uXHJcbiAqIEBwYXJhbSBhY3Rpb25DYWxsYmFjayBSZXF1aXJlZC4gQSBjdXN0b20gYWN0aW9uIGNhbGxiYWNrIGZ1bmN0aW9uLlxyXG4gKiBAcGFyYW0gYWN0aW9uTGFiZWwgUmVxdWlyZWQuIFRoZSBuYW1lIG9mIHRoZSBhY3Rpb24gYnV0dG9uLlxyXG4gKlxyXG4gKiBAYXV0aG9yIFJvbGFuZCBGw6lueWVzXHJcbiAqL1xyXG5leHBvcnQgaW50ZXJmYWNlIFNtYXJ0RGlhbG9nRGF0YSB7XHJcbiAgc2l6ZTogU21hcnREaWFsb2dTaXplO1xyXG4gIGNvbnRlbnQ6IFNtYXJ0Q29udGVudDtcclxuICBjdXN0b21Db21wb25lbnQ/OiBhbnk7XHJcbiAgY3VzdG9tQ29tcG9uZW50SW5wdXRzPzogYW55O1xyXG4gIGFjdGlvblR5cGU/OiBTbWFydEFjdGlvblR5cGU7XHJcbiAgZm9ybT86IFNtYXJ0Rm9ybTtcclxuICB0YWJsZT86IFNtYXJ0VGFibGU8YW55PjtcclxuICBva0NhbGxiYWNrPzogKCkgPT4gdm9pZDtcclxuICBjYW5jZWxDYWxsYmFjaz86IChhcmdzOiBhbnlbXSkgPT4gdm9pZDtcclxuICBjbG9zZUNhbGxiYWNrPzogKGFyZ3M6IGFueVtdKSA9PiB2b2lkO1xyXG4gIGFjdGlvbkNhbGxiYWNrPzogKGFyZ3M6IGFueVtdKSA9PiB2b2lkO1xyXG4gIGFjdGlvbkxhYmVsPzogc3RyaW5nO1xyXG4gIG91dGxldHM/OiBhbnk7XHJcbn1cclxuIl19
|
|
@@ -4,9 +4,9 @@ import { MatDialogModule } from '@angular/material/dialog';
|
|
|
4
4
|
import { MatIconModule } from '@angular/material/icon';
|
|
5
5
|
import { MatCommonModule } from '@angular/material/core';
|
|
6
6
|
import { BrowserModule } from '@angular/platform-browser';
|
|
7
|
+
import { SmartformModule } from '../smart-form/projects';
|
|
7
8
|
import { SmarttableModule } from '../smart-table/projects';
|
|
8
9
|
import { SmartIconModule } from '../smart-icon/projects';
|
|
9
|
-
import { SmartViewContextModule } from '../view-context/smart-view-context.module';
|
|
10
10
|
import * as i0 from "@angular/core";
|
|
11
11
|
export class SmartdialogModule {
|
|
12
12
|
}
|
|
@@ -15,7 +15,7 @@ SmartdialogModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", versi
|
|
|
15
15
|
MatDialogModule,
|
|
16
16
|
MatCommonModule,
|
|
17
17
|
MatIconModule,
|
|
18
|
-
|
|
18
|
+
SmartformModule,
|
|
19
19
|
SmarttableModule,
|
|
20
20
|
SmartIconModule], exports: [SmartDialog] });
|
|
21
21
|
SmartdialogModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: SmartdialogModule, providers: [], imports: [[
|
|
@@ -23,7 +23,7 @@ SmartdialogModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", versi
|
|
|
23
23
|
MatDialogModule,
|
|
24
24
|
MatCommonModule,
|
|
25
25
|
MatIconModule,
|
|
26
|
-
|
|
26
|
+
SmartformModule,
|
|
27
27
|
SmarttableModule,
|
|
28
28
|
SmartIconModule,
|
|
29
29
|
]] });
|
|
@@ -36,7 +36,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImpor
|
|
|
36
36
|
MatDialogModule,
|
|
37
37
|
MatCommonModule,
|
|
38
38
|
MatIconModule,
|
|
39
|
-
|
|
39
|
+
SmartformModule,
|
|
40
40
|
SmarttableModule,
|
|
41
41
|
SmartIconModule,
|
|
42
42
|
],
|
|
@@ -45,4 +45,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImpor
|
|
|
45
45
|
providers: [],
|
|
46
46
|
}]
|
|
47
47
|
}] });
|
|
48
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
48
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic21hcnRkaWFsb2cubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvc21hcnQtbmctY2xpZW50L3NyYy9saWIvc21hcnQtZGlhbG9nL3NtYXJ0ZGlhbG9nLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsc0JBQXNCLEVBQUUsUUFBUSxFQUFFLGdCQUFnQixFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ25GLE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQztBQUN0RCxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sMEJBQTBCLENBQUM7QUFDM0QsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLHdCQUF3QixDQUFDO0FBQ3ZELE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQztBQUN6RCxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sMkJBQTJCLENBQUM7QUFDMUQsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLHdCQUF3QixDQUFDO0FBQ3pELE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLHlCQUF5QixDQUFDO0FBQzNELE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQzs7QUFpQnpELE1BQU0sT0FBTyxpQkFBaUI7OzhHQUFqQixpQkFBaUI7K0dBQWpCLGlCQUFpQixpQkFkYixXQUFXLGFBRXhCLGFBQWE7UUFDYixlQUFlO1FBQ2YsZUFBZTtRQUNmLGFBQWE7UUFDYixlQUFlO1FBQ2YsZ0JBQWdCO1FBQ2hCLGVBQWUsYUFFUCxXQUFXOytHQUlWLGlCQUFpQixhQUZqQixFQUFFLFlBWEo7WUFDUCxhQUFhO1lBQ2IsZUFBZTtZQUNmLGVBQWU7WUFDZixhQUFhO1lBQ2IsZUFBZTtZQUNmLGdCQUFnQjtZQUNoQixlQUFlO1NBQ2hCOzJGQUtVLGlCQUFpQjtrQkFmN0IsUUFBUTttQkFBQztvQkFDUixZQUFZLEVBQUUsQ0FBQyxXQUFXLENBQUM7b0JBQzNCLE9BQU8sRUFBRTt3QkFDUCxhQUFhO3dCQUNiLGVBQWU7d0JBQ2YsZUFBZTt3QkFDZixhQUFhO3dCQUNiLGVBQWU7d0JBQ2YsZ0JBQWdCO3dCQUNoQixlQUFlO3FCQUNoQjtvQkFDRCxPQUFPLEVBQUUsQ0FBQyxXQUFXLENBQUM7b0JBQ3RCLE9BQU8sRUFBRSxDQUFDLHNCQUFzQixFQUFFLGdCQUFnQixDQUFDO29CQUNuRCxTQUFTLEVBQUUsRUFBRTtpQkFDZCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENVU1RPTV9FTEVNRU5UU19TQ0hFTUEsIE5nTW9kdWxlLCBOT19FUlJPUlNfU0NIRU1BIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IFNtYXJ0RGlhbG9nIH0gZnJvbSAnLi9zbWFydGRpYWxvZy5jb21wb25lbnQnO1xyXG5pbXBvcnQgeyBNYXREaWFsb2dNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9kaWFsb2cnO1xyXG5pbXBvcnQgeyBNYXRJY29uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvaWNvbic7XHJcbmltcG9ydCB7IE1hdENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2NvcmUnO1xyXG5pbXBvcnQgeyBCcm93c2VyTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvcGxhdGZvcm0tYnJvd3Nlcic7XHJcbmltcG9ydCB7IFNtYXJ0Zm9ybU1vZHVsZSB9IGZyb20gJy4uL3NtYXJ0LWZvcm0vcHJvamVjdHMnO1xyXG5pbXBvcnQgeyBTbWFydHRhYmxlTW9kdWxlIH0gZnJvbSAnLi4vc21hcnQtdGFibGUvcHJvamVjdHMnO1xyXG5pbXBvcnQgeyBTbWFydEljb25Nb2R1bGUgfSBmcm9tICcuLi9zbWFydC1pY29uL3Byb2plY3RzJztcclxuXHJcbkBOZ01vZHVsZSh7XHJcbiAgZGVjbGFyYXRpb25zOiBbU21hcnREaWFsb2ddLFxyXG4gIGltcG9ydHM6IFtcclxuICAgIEJyb3dzZXJNb2R1bGUsXHJcbiAgICBNYXREaWFsb2dNb2R1bGUsXHJcbiAgICBNYXRDb21tb25Nb2R1bGUsXHJcbiAgICBNYXRJY29uTW9kdWxlLFxyXG4gICAgU21hcnRmb3JtTW9kdWxlLFxyXG4gICAgU21hcnR0YWJsZU1vZHVsZSxcclxuICAgIFNtYXJ0SWNvbk1vZHVsZSxcclxuICBdLFxyXG4gIGV4cG9ydHM6IFtTbWFydERpYWxvZ10sXHJcbiAgc2NoZW1hczogW0NVU1RPTV9FTEVNRU5UU19TQ0hFTUEsIE5PX0VSUk9SU19TQ0hFTUFdLFxyXG4gIHByb3ZpZGVyczogW10sXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBTbWFydGRpYWxvZ01vZHVsZSB7fVxyXG4iXX0=
|
|
@@ -34,18 +34,12 @@ export class ExpandableSectionComponent {
|
|
|
34
34
|
['sectionIndex', this.index],
|
|
35
35
|
]));
|
|
36
36
|
}
|
|
37
|
-
|
|
37
|
+
this.componentRef = this.cfService.createComponent(this.vcRef, this.data.customComponent, new Map([
|
|
38
|
+
[this.data.inputName ?? '', this.data.data],
|
|
38
39
|
['stateChange', this.stateChange],
|
|
39
40
|
['index', this.data.index],
|
|
40
41
|
['sectionIndex', this.index],
|
|
41
|
-
]);
|
|
42
|
-
if (this.data.inputName) {
|
|
43
|
-
inputs.set(this.data.inputName, this.data.data);
|
|
44
|
-
}
|
|
45
|
-
if (this.data.inputs) {
|
|
46
|
-
this.data.inputs.forEach((v, k) => inputs.set(k, v));
|
|
47
|
-
}
|
|
48
|
-
this.componentRef = this.cfService.createComponent(this.vcRef, this.data.customComponent, inputs);
|
|
42
|
+
]));
|
|
49
43
|
}
|
|
50
44
|
action(button, event) {
|
|
51
45
|
event.stopPropagation();
|
|
@@ -70,10 +64,10 @@ export class ExpandableSectionComponent {
|
|
|
70
64
|
}
|
|
71
65
|
}
|
|
72
66
|
ExpandableSectionComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: ExpandableSectionComponent, deps: [{ token: i1.ComponentFactoryService }], target: i0.ɵɵFactoryTarget.Component });
|
|
73
|
-
ExpandableSectionComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.4.0", type: ExpandableSectionComponent, selector: "smart-expandable-section", inputs: { data: "data", index: "index" }, viewQueries: [{ propertyName: "vcRef", first: true, predicate: ["renderComponent"], descendants: true, read: ViewContainerRef }, { propertyName: "vcRefheader", first: true, predicate: ["headerComponent"], descendants: true, read: ViewContainerRef }], ngImport: i0, template: "<div class=\"section-container\" [ngClass]=\"data.cssClass ?? ''\">\r\n
|
|
67
|
+
ExpandableSectionComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.4.0", type: ExpandableSectionComponent, selector: "smart-expandable-section", inputs: { data: "data", index: "index" }, viewQueries: [{ propertyName: "vcRef", first: true, predicate: ["renderComponent"], descendants: true, read: ViewContainerRef }, { propertyName: "vcRefheader", first: true, predicate: ["headerComponent"], descendants: true, read: ViewContainerRef }], ngImport: i0, template: "<div class=\"section-container\" [ngClass]=\"data.cssClass ?? ''\">\r\n <mat-expansion-panel\r\n [expanded]=\"data.isExpanded\"\r\n (opened)=\"onStateChange(true)\"\r\n (closed)=\"onStateChange(false)\"\r\n >\r\n <mat-expansion-panel-header *ngIf=\"data.headerComponent\">\r\n <ng-template #headerComponent></ng-template>\r\n </mat-expansion-panel-header>\r\n <mat-expansion-panel-header *ngIf=\"!data.headerComponent\">\r\n <mat-panel-title> {{ data.title }} </mat-panel-title>\r\n <div class=\"btn-container\" *ngIf=\"data.button\">\r\n <button\r\n *ngIf=\"data.button.type === type().BUTTON\"\r\n class=\"btn\"\r\n (click)=\"action(data.button, $event)\"\r\n mat-stroked-button\r\n >\r\n <smart-icon\r\n *ngIf=\"\r\n data.button.icon &&\r\n (!data.button.iconPosition ||\r\n data.button.iconPosition === position().PRE)\r\n \"\r\n [icon]=\"data.button.icon\"\r\n ></smart-icon>\r\n {{ data.button.label }}\r\n <smart-icon\r\n *ngIf=\"data.button.icon && data.button.iconPosition === position().POST\"\r\n [icon]=\"data.button.icon\"\r\n ></smart-icon>\r\n </button>\r\n <button\r\n *ngIf=\"data.button.type === type().MENU\"\r\n mat-button\r\n [matMenuTriggerFor]=\"menu\"\r\n (click)=\"$event.stopPropagation()\"\r\n color=\"{{ data.button.color }}\"\r\n >\r\n <smart-icon\r\n *ngIf=\"\r\n data.button.icon &&\r\n (!data.button.iconPosition ||\r\n data.button.iconPosition === position().PRE)\r\n \"\r\n [icon]=\"data.button.icon\"\r\n ></smart-icon\r\n >{{ data.button.label }}\r\n <smart-icon\r\n *ngIf=\"data.button.icon && data.button.iconPosition === position().POST\"\r\n [icon]=\"data.button.icon\"\r\n ></smart-icon>\r\n </button>\r\n <mat-menu #menu=\"matMenu\">\r\n <button\r\n *ngFor=\"let button of data.button.menuItemButtons\"\r\n (click)=\"customButtonClicked($event, button, data.index)\"\r\n mat-menu-item\r\n >\r\n <smart-icon\r\n *ngIf=\"\r\n button.icon &&\r\n (!button.iconPosition || button.iconPosition === position().PRE)\r\n \"\r\n [icon]=\"button.icon\"\r\n ></smart-icon\r\n >{{ button.label }}\r\n <smart-icon\r\n *ngIf=\"button.icon && button.iconPosition === position().POST\"\r\n [icon]=\"button.icon\"\r\n ></smart-icon>\r\n </button>\r\n </mat-menu>\r\n </div>\r\n </mat-expansion-panel-header>\r\n <ng-template #renderComponent></ng-template>\r\n </mat-expansion-panel>\r\n</div>\r\n", styles: [".section-container{margin-bottom:50px}:host::ng-deep .mat-expansion-panel-header{background:var(--primary-lighter-color)}:host::ng-deep .mat-expansion-panel-header-title{color:var(--primary-color)}:host::ng-deep .btn-container{margin:1em 3em 1em 1em}:host::ng-deep .btn{border-radius:24px}\n"], components: [{ type: i2.MatExpansionPanel, selector: "mat-expansion-panel", inputs: ["disabled", "expanded", "hideToggle", "togglePosition"], outputs: ["opened", "closed", "expandedChange", "afterExpand", "afterCollapse"], exportAs: ["matExpansionPanel"] }, { type: i2.MatExpansionPanelHeader, selector: "mat-expansion-panel-header", inputs: ["tabIndex", "expandedHeight", "collapsedHeight"] }, { type: i3.MatButton, selector: "button[mat-button], button[mat-raised-button], button[mat-icon-button], button[mat-fab], button[mat-mini-fab], button[mat-stroked-button], button[mat-flat-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { type: i4.SmartIconComponent, selector: "smart-icon", inputs: ["icon", "color"] }, { type: i5.MatMenu, selector: "mat-menu", exportAs: ["matMenu"] }, { type: i5.MatMenuItem, selector: "[mat-menu-item]", inputs: ["disabled", "disableRipple", "role"], exportAs: ["matMenuItem"] }], directives: [{ type: i6.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { type: i6.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i2.MatExpansionPanelTitle, selector: "mat-panel-title" }, { type: i5.MatMenuTrigger, selector: "[mat-menu-trigger-for], [matMenuTriggerFor]", exportAs: ["matMenuTrigger"] }, { type: i6.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }] });
|
|
74
68
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: ExpandableSectionComponent, decorators: [{
|
|
75
69
|
type: Component,
|
|
76
|
-
args: [{ selector: 'smart-expandable-section', template: "<div class=\"section-container\" [ngClass]=\"data.cssClass ?? ''\">\r\n
|
|
70
|
+
args: [{ selector: 'smart-expandable-section', template: "<div class=\"section-container\" [ngClass]=\"data.cssClass ?? ''\">\r\n <mat-expansion-panel\r\n [expanded]=\"data.isExpanded\"\r\n (opened)=\"onStateChange(true)\"\r\n (closed)=\"onStateChange(false)\"\r\n >\r\n <mat-expansion-panel-header *ngIf=\"data.headerComponent\">\r\n <ng-template #headerComponent></ng-template>\r\n </mat-expansion-panel-header>\r\n <mat-expansion-panel-header *ngIf=\"!data.headerComponent\">\r\n <mat-panel-title> {{ data.title }} </mat-panel-title>\r\n <div class=\"btn-container\" *ngIf=\"data.button\">\r\n <button\r\n *ngIf=\"data.button.type === type().BUTTON\"\r\n class=\"btn\"\r\n (click)=\"action(data.button, $event)\"\r\n mat-stroked-button\r\n >\r\n <smart-icon\r\n *ngIf=\"\r\n data.button.icon &&\r\n (!data.button.iconPosition ||\r\n data.button.iconPosition === position().PRE)\r\n \"\r\n [icon]=\"data.button.icon\"\r\n ></smart-icon>\r\n {{ data.button.label }}\r\n <smart-icon\r\n *ngIf=\"data.button.icon && data.button.iconPosition === position().POST\"\r\n [icon]=\"data.button.icon\"\r\n ></smart-icon>\r\n </button>\r\n <button\r\n *ngIf=\"data.button.type === type().MENU\"\r\n mat-button\r\n [matMenuTriggerFor]=\"menu\"\r\n (click)=\"$event.stopPropagation()\"\r\n color=\"{{ data.button.color }}\"\r\n >\r\n <smart-icon\r\n *ngIf=\"\r\n data.button.icon &&\r\n (!data.button.iconPosition ||\r\n data.button.iconPosition === position().PRE)\r\n \"\r\n [icon]=\"data.button.icon\"\r\n ></smart-icon\r\n >{{ data.button.label }}\r\n <smart-icon\r\n *ngIf=\"data.button.icon && data.button.iconPosition === position().POST\"\r\n [icon]=\"data.button.icon\"\r\n ></smart-icon>\r\n </button>\r\n <mat-menu #menu=\"matMenu\">\r\n <button\r\n *ngFor=\"let button of data.button.menuItemButtons\"\r\n (click)=\"customButtonClicked($event, button, data.index)\"\r\n mat-menu-item\r\n >\r\n <smart-icon\r\n *ngIf=\"\r\n button.icon &&\r\n (!button.iconPosition || button.iconPosition === position().PRE)\r\n \"\r\n [icon]=\"button.icon\"\r\n ></smart-icon\r\n >{{ button.label }}\r\n <smart-icon\r\n *ngIf=\"button.icon && button.iconPosition === position().POST\"\r\n [icon]=\"button.icon\"\r\n ></smart-icon>\r\n </button>\r\n </mat-menu>\r\n </div>\r\n </mat-expansion-panel-header>\r\n <ng-template #renderComponent></ng-template>\r\n </mat-expansion-panel>\r\n</div>\r\n", styles: [".section-container{margin-bottom:50px}:host::ng-deep .mat-expansion-panel-header{background:var(--primary-lighter-color)}:host::ng-deep .mat-expansion-panel-header-title{color:var(--primary-color)}:host::ng-deep .btn-container{margin:1em 3em 1em 1em}:host::ng-deep .btn{border-radius:24px}\n"] }]
|
|
77
71
|
}], ctorParameters: function () { return [{ type: i1.ComponentFactoryService }]; }, propDecorators: { data: [{
|
|
78
72
|
type: Input
|
|
79
73
|
}], index: [{
|
|
@@ -85,4 +79,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImpor
|
|
|
85
79
|
type: ViewChild,
|
|
86
80
|
args: ['headerComponent', { read: ViewContainerRef }]
|
|
87
81
|
}] } });
|
|
88
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"expandable-section.component.js","sourceRoot":"","sources":["../../../../../projects/smart-ng-client/src/lib/smart-expandable-section/expandable-section.component.ts","../../../../../projects/smart-ng-client/src/lib/smart-expandable-section/expandable-section.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ComponentRef, Input, OnInit, ViewChild, ViewContainerRef } from '@angular/core';\r\nimport { Subject } from 'rxjs';\r\nimport {\r\n  ExpandableSection,\r\n  ExpandableSectionButton,\r\n  ExpandableSectionButtonIconPosition,\r\n  ExpandableSectionButtonType,\r\n} from './expandable-section.model';\r\nimport { ComponentFactoryService } from '../component-factory-service/projects';\r\n\r\n@Component({\r\n  selector: 'smart-expandable-section',\r\n  templateUrl: './expandable-section.component.html',\r\n  styleUrls: ['./expandable-section.component.css'],\r\n})\r\nexport class ExpandableSectionComponent implements OnInit {\r\n  @Input() data!: ExpandableSection<any>;\r\n  @Input() index?: number;\r\n\r\n  @ViewChild('renderComponent', { read: ViewContainerRef })\r\n  vcRef?: ViewContainerRef;\r\n  componentRef?: ComponentRef<any>;\r\n\r\n  @ViewChild('headerComponent', { read: ViewContainerRef })\r\n  vcRefheader?: ViewContainerRef;\r\n\r\n  stateChange: Subject<ExpandableSection<any>> = new Subject();\r\n\r\n  constructor(private cfService: ComponentFactoryService) {}\r\n\r\n  onStateChange(isOpened: boolean): void {\r\n    this.data.isExpanded = isOpened;\r\n    this.stateChange.next(this.data);\r\n    if (this.data.stateChanged) {\r\n      this.data.stateChanged.next({\r\n        data: this.data.data,\r\n        isExpanded: isOpened,\r\n        index: this.data.index,\r\n      });\r\n    }\r\n  }\r\n\r\n  ngOnInit(): void {}\r\n\r\n  ngAfterViewInit() {\r\n    if (this.data.headerComponent) {\r\n      this.cfService.createComponent(\r\n        this.vcRefheader!,\r\n        this.data.headerComponent,\r\n        new Map<string, any>([\r\n          [this.data.headerInputName ?? '', this.data.headerData],\r\n          ['stateChange', this.stateChange],\r\n          ['index', this.data.index],\r\n          ['sectionIndex', this.index],\r\n        ])\r\n      );\r\n    }\r\n    let inputs = new Map<string, any>([\r\n      ['stateChange', this.stateChange],\r\n      ['index', this.data.index],\r\n      ['sectionIndex', this.index],\r\n    ]);\r\n    if (this.data.inputName) {\r\n      inputs.set(this.data.inputName, this.data.data);\r\n    }\r\n    if (this.data.inputs) {\r\n      this.data.inputs.forEach((v, k) => inputs.set(k, v));\r\n    }\r\n\r\n    this.componentRef = this.cfService.createComponent(\r\n      this.vcRef!,\r\n      this.data.customComponent,\r\n      inputs\r\n    );\r\n  }\r\n\r\n  action(button: ExpandableSectionButton, event: any) {\r\n    event.stopPropagation();\r\n    if (!button.callback) {\r\n      throw new Error(\r\n        `Button with name ${button.label} or icon ${button.icon} does not have a callback!`\r\n      );\r\n    }\r\n\r\n    button.callback(button.args);\r\n  }\r\n\r\n  setExpanded() {}\r\n\r\n  type(): typeof ExpandableSectionButtonType {\r\n    return ExpandableSectionButtonType;\r\n  }\r\n  position(): typeof ExpandableSectionButtonIconPosition {\r\n    return ExpandableSectionButtonIconPosition;\r\n  }\r\n\r\n  customButtonClicked(event: any, button: ExpandableSectionButton, element: any) {\r\n    event.stopPropagation();\r\n\r\n    if (!button.callback) {\r\n      throw new Error(\r\n        `Button with name ${button.label} or icon ${button.icon} does not have a callback!`\r\n      );\r\n    }\r\n    button.callback(button.args, element);\r\n  }\r\n}\r\n","<div class=\"section-container\" [ngClass]=\"data.cssClass ?? ''\">\r\n  <mat-expansion-panel\r\n    [expanded]=\"data.isExpanded\"\r\n    (opened)=\"onStateChange(true)\"\r\n    (closed)=\"onStateChange(false)\"\r\n    [disabled]=\"!!data.isDisabled\"\r\n  >\r\n    <mat-expansion-panel-header *ngIf=\"data.headerComponent\">\r\n      <ng-template #headerComponent></ng-template>\r\n    </mat-expansion-panel-header>\r\n    <mat-expansion-panel-header *ngIf=\"!data.headerComponent\">\r\n      <mat-panel-title> {{ data.title }} </mat-panel-title>\r\n      <div class=\"btn-container\" *ngIf=\"data.button\">\r\n        <button\r\n          *ngIf=\"data.button.type === type().BUTTON\"\r\n          class=\"btn\"\r\n          (click)=\"action(data.button, $event)\"\r\n          mat-stroked-button\r\n        >\r\n          <smart-icon\r\n            *ngIf=\"\r\n              data.button.icon &&\r\n              (!data.button.iconPosition || data.button.iconPosition === position().PRE)\r\n            \"\r\n            [icon]=\"data.button.icon\"\r\n          ></smart-icon>\r\n          {{ data.button.label }}\r\n          <smart-icon\r\n            *ngIf=\"data.button.icon && data.button.iconPosition === position().POST\"\r\n            [icon]=\"data.button.icon\"\r\n          ></smart-icon>\r\n        </button>\r\n        <button\r\n          *ngIf=\"data.button.type === type().MENU\"\r\n          mat-button\r\n          [matMenuTriggerFor]=\"menu\"\r\n          (click)=\"$event.stopPropagation()\"\r\n          color=\"{{ data.button.color }}\"\r\n        >\r\n          <smart-icon\r\n            *ngIf=\"\r\n              data.button.icon &&\r\n              (!data.button.iconPosition || data.button.iconPosition === position().PRE)\r\n            \"\r\n            [icon]=\"data.button.icon\"\r\n          ></smart-icon\r\n          >{{ data.button.label }}\r\n          <smart-icon\r\n            *ngIf=\"data.button.icon && data.button.iconPosition === position().POST\"\r\n            [icon]=\"data.button.icon\"\r\n          ></smart-icon>\r\n        </button>\r\n        <mat-menu #menu=\"matMenu\">\r\n          <button\r\n            *ngFor=\"let button of data.button.menuItemButtons\"\r\n            (click)=\"customButtonClicked($event, button, data.index)\"\r\n            mat-menu-item\r\n          >\r\n            <smart-icon\r\n              *ngIf=\"\r\n                button.icon && (!button.iconPosition || button.iconPosition === position().PRE)\r\n              \"\r\n              [icon]=\"button.icon\"\r\n            ></smart-icon\r\n            >{{ button.label }}\r\n            <smart-icon\r\n              *ngIf=\"button.icon && button.iconPosition === position().POST\"\r\n              [icon]=\"button.icon\"\r\n            ></smart-icon>\r\n          </button>\r\n        </mat-menu>\r\n      </div>\r\n    </mat-expansion-panel-header>\r\n    <ng-template #renderComponent></ng-template>\r\n  </mat-expansion-panel>\r\n</div>\r\n"]}
|
|
82
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"expandable-section.component.js","sourceRoot":"","sources":["../../../../../projects/smart-ng-client/src/lib/smart-expandable-section/expandable-section.component.ts","../../../../../projects/smart-ng-client/src/lib/smart-expandable-section/expandable-section.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ComponentRef, Input, OnInit, ViewChild, ViewContainerRef } from '@angular/core';\r\nimport { Subject } from 'rxjs';\r\nimport {\r\n  ExpandableSection,\r\n  ExpandableSectionButton,\r\n  ExpandableSectionButtonIconPosition,\r\n  ExpandableSectionButtonType,\r\n} from './expandable-section.model';\r\nimport { ComponentFactoryService } from '../component-factory-service/projects';\r\n\r\n@Component({\r\n  selector: 'smart-expandable-section',\r\n  templateUrl: './expandable-section.component.html',\r\n  styleUrls: ['./expandable-section.component.css'],\r\n})\r\nexport class ExpandableSectionComponent implements OnInit {\r\n  @Input() data!: ExpandableSection<any>;\r\n  @Input() index?: number;\r\n\r\n  @ViewChild('renderComponent', { read: ViewContainerRef })\r\n  vcRef?: ViewContainerRef;\r\n  componentRef?: ComponentRef<any>;\r\n\r\n  @ViewChild('headerComponent', { read: ViewContainerRef })\r\n  vcRefheader?: ViewContainerRef;\r\n\r\n  stateChange: Subject<ExpandableSection<any>> = new Subject();\r\n\r\n  constructor(private cfService: ComponentFactoryService) {}\r\n\r\n  onStateChange(isOpened: boolean): void {\r\n    this.data.isExpanded = isOpened;\r\n    this.stateChange.next(this.data);\r\n    if (this.data.stateChanged) {\r\n      this.data.stateChanged.next({\r\n        data: this.data.data,\r\n        isExpanded: isOpened,\r\n        index: this.data.index,\r\n      });\r\n    }\r\n  }\r\n\r\n  ngOnInit(): void {}\r\n\r\n  ngAfterViewInit() {\r\n    if (this.data.headerComponent) {\r\n      this.cfService.createComponent(\r\n        this.vcRefheader!,\r\n        this.data.headerComponent,\r\n        new Map<string, any>([\r\n          [this.data.headerInputName ?? '', this.data.headerData],\r\n          ['stateChange', this.stateChange],\r\n          ['index', this.data.index],\r\n          ['sectionIndex', this.index],\r\n        ])\r\n      );\r\n    }\r\n    this.componentRef = this.cfService.createComponent(\r\n      this.vcRef!,\r\n      this.data.customComponent,\r\n      new Map<string, any>([\r\n        [this.data.inputName ?? '', this.data.data],\r\n        ['stateChange', this.stateChange],\r\n        ['index', this.data.index],\r\n        ['sectionIndex', this.index],\r\n      ])\r\n    );\r\n  }\r\n\r\n  action(button: ExpandableSectionButton, event: any) {\r\n    event.stopPropagation();\r\n    if (!button.callback) {\r\n      throw new Error(\r\n        `Button with name ${button.label} or icon ${button.icon} does not have a callback!`\r\n      );\r\n    }\r\n\r\n    button.callback(button.args);\r\n  }\r\n\r\n  setExpanded() {}\r\n\r\n  type(): typeof ExpandableSectionButtonType {\r\n    return ExpandableSectionButtonType;\r\n  }\r\n  position(): typeof ExpandableSectionButtonIconPosition {\r\n    return ExpandableSectionButtonIconPosition;\r\n  }\r\n\r\n  customButtonClicked(event: any, button: ExpandableSectionButton, element: any) {\r\n    event.stopPropagation();\r\n\r\n    if (!button.callback) {\r\n      throw new Error(\r\n        `Button with name ${button.label} or icon ${button.icon} does not have a callback!`\r\n      );\r\n    }\r\n    button.callback(button.args, element);\r\n  }\r\n}\r\n","<div class=\"section-container\" [ngClass]=\"data.cssClass ?? ''\">\r\n    <mat-expansion-panel\r\n        [expanded]=\"data.isExpanded\"\r\n        (opened)=\"onStateChange(true)\"\r\n        (closed)=\"onStateChange(false)\"\r\n    >\r\n        <mat-expansion-panel-header *ngIf=\"data.headerComponent\">\r\n            <ng-template #headerComponent></ng-template>\r\n        </mat-expansion-panel-header>\r\n        <mat-expansion-panel-header *ngIf=\"!data.headerComponent\">\r\n            <mat-panel-title> {{ data.title }} </mat-panel-title>\r\n            <div class=\"btn-container\" *ngIf=\"data.button\">\r\n                <button\r\n                    *ngIf=\"data.button.type === type().BUTTON\"\r\n                    class=\"btn\"\r\n                    (click)=\"action(data.button, $event)\"\r\n                    mat-stroked-button\r\n                >\r\n                    <smart-icon\r\n                        *ngIf=\"\r\n                            data.button.icon &&\r\n                            (!data.button.iconPosition ||\r\n                                data.button.iconPosition === position().PRE)\r\n                        \"\r\n                        [icon]=\"data.button.icon\"\r\n                    ></smart-icon>\r\n                    {{ data.button.label }}\r\n                    <smart-icon\r\n                        *ngIf=\"data.button.icon && data.button.iconPosition === position().POST\"\r\n                        [icon]=\"data.button.icon\"\r\n                    ></smart-icon>\r\n                </button>\r\n                <button\r\n                    *ngIf=\"data.button.type === type().MENU\"\r\n                    mat-button\r\n                    [matMenuTriggerFor]=\"menu\"\r\n                    (click)=\"$event.stopPropagation()\"\r\n                    color=\"{{ data.button.color }}\"\r\n                >\r\n                    <smart-icon\r\n                        *ngIf=\"\r\n                            data.button.icon &&\r\n                            (!data.button.iconPosition ||\r\n                                data.button.iconPosition === position().PRE)\r\n                        \"\r\n                        [icon]=\"data.button.icon\"\r\n                    ></smart-icon\r\n                    >{{ data.button.label }}\r\n                    <smart-icon\r\n                        *ngIf=\"data.button.icon && data.button.iconPosition === position().POST\"\r\n                        [icon]=\"data.button.icon\"\r\n                    ></smart-icon>\r\n                </button>\r\n                <mat-menu #menu=\"matMenu\">\r\n                    <button\r\n                        *ngFor=\"let button of data.button.menuItemButtons\"\r\n                        (click)=\"customButtonClicked($event, button, data.index)\"\r\n                        mat-menu-item\r\n                    >\r\n                        <smart-icon\r\n                            *ngIf=\"\r\n                                button.icon &&\r\n                                (!button.iconPosition || button.iconPosition === position().PRE)\r\n                            \"\r\n                            [icon]=\"button.icon\"\r\n                        ></smart-icon\r\n                        >{{ button.label }}\r\n                        <smart-icon\r\n                            *ngIf=\"button.icon && button.iconPosition === position().POST\"\r\n                            [icon]=\"button.icon\"\r\n                        ></smart-icon>\r\n                    </button>\r\n                </mat-menu>\r\n            </div>\r\n        </mat-expansion-panel-header>\r\n        <ng-template #renderComponent></ng-template>\r\n    </mat-expansion-panel>\r\n</div>\r\n"]}
|