@smartbit4all/ng-client 3.3.138 → 3.3.140

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.
Files changed (234) hide show
  1. package/esm2020/lib/session/api/api/session.service.mjs +1 -1
  2. package/esm2020/lib/session/api/encoder.mjs +1 -1
  3. package/esm2020/lib/session/api/model/accountInfo.mjs +1 -1
  4. package/esm2020/lib/session/api/model/apiError.mjs +1 -1
  5. package/esm2020/lib/session/api/model/authenticationProviderData.mjs +1 -1
  6. package/esm2020/lib/session/api/model/getAuthenticationProvidersResponse.mjs +1 -1
  7. package/esm2020/lib/session/api/model/models.mjs +1 -1
  8. package/esm2020/lib/session/api/model/refreshSessionRequest.mjs +1 -1
  9. package/esm2020/lib/session/api/model/session.mjs +1 -1
  10. package/esm2020/lib/session/api/model/sessionInfoData.mjs +1 -1
  11. package/esm2020/lib/session/api/model/userActivityLog.mjs +1 -1
  12. package/esm2020/lib/session/api/param.mjs +1 -1
  13. package/esm2020/lib/session/api/variables.mjs +1 -1
  14. package/esm2020/lib/smart-client/smart-component-api-client.mjs +31 -34
  15. package/esm2020/lib/smart-component-layout/api/api/api.mjs +1 -1
  16. package/esm2020/lib/smart-component-layout/api/api/default.service.mjs +1 -1
  17. package/esm2020/lib/smart-component-layout/api/api.module.mjs +1 -1
  18. package/esm2020/lib/smart-component-layout/api/configuration.mjs +1 -1
  19. package/esm2020/lib/smart-component-layout/api/encoder.mjs +1 -1
  20. package/esm2020/lib/smart-component-layout/api/index.mjs +1 -1
  21. package/esm2020/lib/smart-component-layout/api/model/componentType.mjs +1 -1
  22. package/esm2020/lib/smart-component-layout/api/model/componentWidgetType.mjs +1 -1
  23. package/esm2020/lib/smart-component-layout/api/model/layoutDirection.mjs +1 -1
  24. package/esm2020/lib/smart-component-layout/api/model/models.mjs +1 -1
  25. package/esm2020/lib/smart-component-layout/api/model/smartComponentLayoutDefinition.mjs +1 -1
  26. package/esm2020/lib/smart-component-layout/api/model/smartComponentWidgetDefinition.mjs +1 -1
  27. package/esm2020/lib/smart-component-layout/api/param.mjs +1 -1
  28. package/esm2020/lib/smart-component-layout/api/variables.mjs +1 -1
  29. package/esm2020/lib/smart-component-layout/smart-component-layout-utility.mjs +9 -48
  30. package/esm2020/lib/smart-component-layout/smart-component-layout.component.mjs +28 -67
  31. package/esm2020/lib/smart-component-layout/smart-component-layout.module.mjs +5 -1
  32. package/esm2020/lib/smart-dialog/smartdialog.model.mjs +1 -1
  33. package/esm2020/lib/smart-dialog/smartdialog.module.mjs +5 -5
  34. package/esm2020/lib/smart-expandable-section/expandable-section.component.mjs +6 -12
  35. package/esm2020/lib/smart-expandable-section/expandable-section.model.mjs +1 -1
  36. package/esm2020/lib/smart-filter/api/filter/model/filterExpressionBoolOperator.mjs +1 -1
  37. package/esm2020/lib/smart-filter/api/filter/model/filterExpressionBuilderField.mjs +1 -1
  38. package/esm2020/lib/smart-filter/api/filter/model/filterExpressionBuilderGroup.mjs +1 -1
  39. package/esm2020/lib/smart-filter/api/filter/model/filterExpressionBuilderModel.mjs +1 -1
  40. package/esm2020/lib/smart-filter/api/filter/model/filterExpressionData.mjs +1 -1
  41. package/esm2020/lib/smart-filter/api/filter/model/filterExpressionDataType.mjs +1 -1
  42. package/esm2020/lib/smart-filter/api/filter/model/filterExpressionField.mjs +1 -1
  43. package/esm2020/lib/smart-filter/api/filter/model/filterExpressionFieldList.mjs +1 -1
  44. package/esm2020/lib/smart-filter/api/filter/model/filterExpressionFieldWidgetType.mjs +1 -2
  45. package/esm2020/lib/smart-filter/api/filter/model/filterExpressionList.mjs +1 -1
  46. package/esm2020/lib/smart-filter/api/filter/model/filterExpressionOperandData.mjs +1 -1
  47. package/esm2020/lib/smart-filter/api/filter/model/filterExpressionOperation.mjs +1 -1
  48. package/esm2020/lib/smart-filter/api/filter/model/filterExpressionOrderBy.mjs +1 -1
  49. package/esm2020/lib/smart-filter/smart-filter.module.mjs +5 -5
  50. package/esm2020/lib/smart-filter-editor/api/api/filter.service.mjs +1 -1
  51. package/esm2020/lib/smart-filter-editor/api/configuration.mjs +1 -1
  52. package/esm2020/lib/smart-filter-editor/api/encoder.mjs +1 -1
  53. package/esm2020/lib/smart-filter-editor/api/model/filterExpressionBoolOperator.mjs +1 -1
  54. package/esm2020/lib/smart-filter-editor/api/model/filterExpressionBuilderApiConfig.mjs +1 -1
  55. package/esm2020/lib/smart-filter-editor/api/model/filterExpressionBuilderField.mjs +1 -1
  56. package/esm2020/lib/smart-filter-editor/api/model/filterExpressionBuilderGroup.mjs +1 -1
  57. package/esm2020/lib/smart-filter-editor/api/model/filterExpressionBuilderModel.mjs +1 -1
  58. package/esm2020/lib/smart-filter-editor/api/model/filterExpressionBuilderUiModel.mjs +1 -1
  59. package/esm2020/lib/smart-filter-editor/api/model/filterExpressionData.mjs +1 -1
  60. package/esm2020/lib/smart-filter-editor/api/model/filterExpressionDataType.mjs +1 -1
  61. package/esm2020/lib/smart-filter-editor/api/model/filterExpressionField.mjs +1 -1
  62. package/esm2020/lib/smart-filter-editor/api/model/filterExpressionFieldEditor.mjs +1 -1
  63. package/esm2020/lib/smart-filter-editor/api/model/filterExpressionFieldList.mjs +1 -1
  64. package/esm2020/lib/smart-filter-editor/api/model/filterExpressionFieldWidgetType.mjs +1 -2
  65. package/esm2020/lib/smart-filter-editor/api/model/filterExpressionList.mjs +1 -1
  66. package/esm2020/lib/smart-filter-editor/api/model/filterExpressionOperandData.mjs +1 -1
  67. package/esm2020/lib/smart-filter-editor/api/model/filterExpressionOperation.mjs +1 -1
  68. package/esm2020/lib/smart-filter-editor/api/param.mjs +1 -1
  69. package/esm2020/lib/smart-filter-editor/api/variables.mjs +1 -1
  70. package/esm2020/lib/smart-filter-editor/smart-filter-editor.module.mjs +8 -1
  71. package/esm2020/lib/smart-form/api/model/smartFormWidgetType.mjs +1 -2
  72. package/esm2020/lib/smart-form/api/model/smartMatrixModel.mjs +1 -1
  73. package/esm2020/lib/smart-form/api/model/smartWidgetDefinition.mjs +1 -1
  74. package/esm2020/lib/smart-form/api/model/valueChangeMode.mjs +1 -1
  75. package/esm2020/lib/smart-form/projects.mjs +2 -1
  76. package/esm2020/lib/smart-form/services/smartform.layout-definition.service.mjs +3 -21
  77. package/esm2020/lib/smart-form/services/smartform.service.mjs +1 -6
  78. package/esm2020/lib/smart-form/smartform.component.mjs +3 -19
  79. package/esm2020/lib/smart-form/smartform.form-model.mjs +1 -1
  80. package/esm2020/lib/smart-form/smartform.module.mjs +157 -0
  81. package/esm2020/lib/smart-form/widgets/smartformwidget/smartformwidget.component.mjs +32 -118
  82. package/esm2020/lib/smart-grid/api/grid-api/api/api.mjs +1 -1
  83. package/esm2020/lib/smart-grid/api/grid-api/api/grid.service.mjs +1 -1
  84. package/esm2020/lib/smart-grid/api/grid-api/api.module.mjs +1 -1
  85. package/esm2020/lib/smart-grid/api/grid-api/configuration.mjs +1 -1
  86. package/esm2020/lib/smart-grid/api/grid-api/encoder.mjs +1 -1
  87. package/esm2020/lib/smart-grid/api/grid-api/index.mjs +1 -1
  88. package/esm2020/lib/smart-grid/api/grid-api/model/gridColumnContentType.mjs +1 -1
  89. package/esm2020/lib/smart-grid/api/grid-api/model/gridColumnMeta.mjs +1 -1
  90. package/esm2020/lib/smart-grid/api/grid-api/model/gridDataAccessConfig.mjs +1 -1
  91. package/esm2020/lib/smart-grid/api/grid-api/model/gridModel.mjs +1 -1
  92. package/esm2020/lib/smart-grid/api/grid-api/model/gridPage.mjs +1 -1
  93. package/esm2020/lib/smart-grid/api/grid-api/model/gridRow.mjs +1 -1
  94. package/esm2020/lib/smart-grid/api/grid-api/model/gridSelectionChange.mjs +1 -1
  95. package/esm2020/lib/smart-grid/api/grid-api/model/gridSelectionMode.mjs +1 -1
  96. package/esm2020/lib/smart-grid/api/grid-api/model/gridSelectionType.mjs +1 -1
  97. package/esm2020/lib/smart-grid/api/grid-api/model/gridServerModel.mjs +1 -1
  98. package/esm2020/lib/smart-grid/api/grid-api/model/gridUpdateData.mjs +1 -1
  99. package/esm2020/lib/smart-grid/api/grid-api/model/gridView.mjs +1 -1
  100. package/esm2020/lib/smart-grid/api/grid-api/model/gridViewDescriptor.mjs +1 -1
  101. package/esm2020/lib/smart-grid/api/grid-api/model/models.mjs +1 -1
  102. package/esm2020/lib/smart-grid/api/grid-api/param.mjs +1 -1
  103. package/esm2020/lib/smart-grid/api/grid-api/variables.mjs +1 -1
  104. package/esm2020/lib/smart-grid/smart-grid.component.mjs +11 -26
  105. package/esm2020/lib/smart-grid/smart-grid.module.mjs +6 -3
  106. package/esm2020/lib/smart-navbar/smart-navbar.module.mjs +5 -5
  107. package/esm2020/lib/smart-ng-client.module.mjs +8 -1
  108. package/esm2020/lib/smart-table/tables/table.mjs +4 -6
  109. package/esm2020/lib/smart-tree/smarttree-generic.service.mjs +13 -20
  110. package/esm2020/lib/smart-tree/smarttree.module.mjs +3 -11
  111. package/esm2020/lib/smart-tree/tree-api/api/tree.service.mjs +1 -1
  112. package/esm2020/lib/smart-tree/tree-api/configuration.mjs +1 -1
  113. package/esm2020/lib/smart-tree/tree-api/encoder.mjs +1 -1
  114. package/esm2020/lib/smart-tree/tree-api/param.mjs +1 -1
  115. package/esm2020/lib/smart-tree/tree-api/variables.mjs +1 -1
  116. package/esm2020/lib/view-context/api/api/api.mjs +1 -1
  117. package/esm2020/lib/view-context/api/api/view.service.mjs +1 -1
  118. package/esm2020/lib/view-context/api/api.module.mjs +1 -1
  119. package/esm2020/lib/view-context/api/configuration.mjs +1 -1
  120. package/esm2020/lib/view-context/api/encoder.mjs +1 -1
  121. package/esm2020/lib/view-context/api/index.mjs +1 -1
  122. package/esm2020/lib/view-context/api/model/closeResult.mjs +1 -1
  123. package/esm2020/lib/view-context/api/model/componentConstraint.mjs +1 -1
  124. package/esm2020/lib/view-context/api/model/componentModel.mjs +1 -1
  125. package/esm2020/lib/view-context/api/model/componentModelChange.mjs +1 -1
  126. package/esm2020/lib/view-context/api/model/dataChange.mjs +1 -1
  127. package/esm2020/lib/view-context/api/model/dataChangeEvent.mjs +1 -1
  128. package/esm2020/lib/view-context/api/model/dataChangeKind.mjs +1 -1
  129. package/esm2020/lib/view-context/api/model/downloadedFile.mjs +1 -1
  130. package/esm2020/lib/view-context/api/model/iconPosition.mjs +1 -1
  131. package/esm2020/lib/view-context/api/model/imageResource.mjs +1 -1
  132. package/esm2020/lib/view-context/api/model/link.mjs +1 -1
  133. package/esm2020/lib/view-context/api/model/messageData.mjs +1 -1
  134. package/esm2020/lib/view-context/api/model/messageOption.mjs +1 -1
  135. package/esm2020/lib/view-context/api/model/messageOptionType.mjs +1 -1
  136. package/esm2020/lib/view-context/api/model/messageResult.mjs +1 -1
  137. package/esm2020/lib/view-context/api/model/messageTextType.mjs +1 -1
  138. package/esm2020/lib/view-context/api/model/messageType.mjs +1 -1
  139. package/esm2020/lib/view-context/api/model/openPendingData.mjs +1 -1
  140. package/esm2020/lib/view-context/api/model/smartLinkData.mjs +1 -1
  141. package/esm2020/lib/view-context/api/model/style.mjs +1 -1
  142. package/esm2020/lib/view-context/api/model/uiAction.mjs +1 -1
  143. package/esm2020/lib/view-context/api/model/uiActionButtonDescriptor.mjs +1 -1
  144. package/esm2020/lib/view-context/api/model/uiActionButtonType.mjs +1 -1
  145. package/esm2020/lib/view-context/api/model/uiActionConstraint.mjs +1 -1
  146. package/esm2020/lib/view-context/api/model/uiActionDescriptor.mjs +1 -1
  147. package/esm2020/lib/view-context/api/model/uiActionDialogDescriptor.mjs +1 -1
  148. package/esm2020/lib/view-context/api/model/uiActionFeedbackType.mjs +1 -1
  149. package/esm2020/lib/view-context/api/model/uiActionInputType.mjs +1 -1
  150. package/esm2020/lib/view-context/api/model/uiActionRequest.mjs +1 -1
  151. package/esm2020/lib/view-context/api/model/uiActionTooltip.mjs +1 -1
  152. package/esm2020/lib/view-context/api/model/uiActionUploadDescriptor.mjs +1 -1
  153. package/esm2020/lib/view-context/api/model/valueSet.mjs +1 -1
  154. package/esm2020/lib/view-context/api/model/view.mjs +1 -1
  155. package/esm2020/lib/view-context/api/model/viewApiError.mjs +1 -1
  156. package/esm2020/lib/view-context/api/model/viewConstraint.mjs +1 -1
  157. package/esm2020/lib/view-context/api/model/viewContext.mjs +1 -1
  158. package/esm2020/lib/view-context/api/model/viewContextChange.mjs +1 -1
  159. package/esm2020/lib/view-context/api/model/viewContextData.mjs +1 -1
  160. package/esm2020/lib/view-context/api/model/viewContextUpdate.mjs +1 -1
  161. package/esm2020/lib/view-context/api/model/viewData.mjs +1 -1
  162. package/esm2020/lib/view-context/api/model/viewState.mjs +1 -1
  163. package/esm2020/lib/view-context/api/model/viewStateUpdate.mjs +1 -1
  164. package/esm2020/lib/view-context/api/model/viewType.mjs +1 -1
  165. package/esm2020/lib/view-context/api/param.mjs +1 -1
  166. package/esm2020/lib/view-context/api/variables.mjs +1 -1
  167. package/esm2020/lib/view-context/smart-ui-action/dialogs/ui-action-confirm-dialog/ui-action-confirm-dialog.component.mjs +12 -15
  168. package/esm2020/lib/view-context/smart-ui-action/dialogs/ui-action-confirm-dialog/ui-action-confirm-dialog.service.mjs +2 -2
  169. package/esm2020/lib/view-context/smart-ui-action/dialogs/ui-action-file-upload-dialog/ui-action-file-upload-dialog.component.mjs +10 -13
  170. package/esm2020/lib/view-context/smart-ui-action/dialogs/ui-action-file-upload-dialog/ui-action-file-upload-dialog.service.mjs +2 -2
  171. package/esm2020/lib/view-context/smart-ui-action/dialogs/ui-action-input-dialog/ui-action-input-dialog.component.mjs +11 -17
  172. package/esm2020/lib/view-context/smart-ui-action/dialogs/ui-action-input-dialog/ui-action-input-dialog.service.mjs +2 -2
  173. package/esm2020/lib/view-context/smart-ui-action/ui-action-toolbar.component.mjs +6 -11
  174. package/esm2020/lib/view-context/smart-ui-action/ui-action.model.mjs +1 -1
  175. package/esm2020/lib/view-context/smart-ui-action/ui-action.service.mjs +8 -14
  176. package/esm2020/lib/view-context/smart-view-context.module.mjs +10 -132
  177. package/esm2020/lib/view-context/smart-view-context.service.mjs +1 -8
  178. package/fesm2015/smartbit4all-ng-client.mjs +2842 -3077
  179. package/fesm2015/smartbit4all-ng-client.mjs.map +1 -1
  180. package/fesm2020/smartbit4all-ng-client.mjs +3561 -3788
  181. package/fesm2020/smartbit4all-ng-client.mjs.map +1 -1
  182. package/lib/smart-client/smart-component-api-client.d.ts +1 -2
  183. package/lib/smart-component-layout/api/model/smartComponentLayoutDefinition.d.ts +5 -3
  184. package/lib/smart-component-layout/api/model/smartComponentWidgetDefinition.d.ts +2 -2
  185. package/lib/smart-component-layout/smart-component-layout-utility.d.ts +3 -4
  186. package/lib/smart-component-layout/smart-component-layout.component.d.ts +6 -10
  187. package/lib/smart-component-layout/smart-component-layout.module.d.ts +6 -5
  188. package/lib/smart-dialog/smartdialog.model.d.ts +2 -2
  189. package/lib/smart-dialog/smartdialog.module.d.ts +2 -2
  190. package/lib/smart-expandable-section/expandable-section.model.d.ts +2 -4
  191. package/lib/smart-filter/api/filter/model/filterExpressionFieldWidgetType.d.ts +0 -1
  192. package/lib/smart-filter/smart-filter.module.d.ts +2 -2
  193. package/lib/smart-filter-editor/api/model/filterExpressionField.d.ts +0 -3
  194. package/lib/smart-filter-editor/api/model/filterExpressionFieldWidgetType.d.ts +0 -1
  195. package/lib/smart-filter-editor/smart-filter-editor.module.d.ts +5 -4
  196. package/lib/smart-form/api/model/smartFormWidgetType.d.ts +1 -2
  197. package/lib/smart-form/api/model/smartMatrixModel.d.ts +0 -1
  198. package/lib/smart-form/api/model/smartWidgetDefinition.d.ts +0 -8
  199. package/lib/smart-form/projects.d.ts +1 -0
  200. package/lib/smart-form/services/smartform.layout-definition.service.d.ts +0 -1
  201. package/lib/smart-form/smartform.component.d.ts +2 -6
  202. package/lib/smart-form/smartform.form-model.d.ts +1 -17
  203. package/lib/smart-form/smartform.module.d.ts +35 -0
  204. package/lib/smart-form/widgets/smartformwidget/smartformwidget.component.d.ts +1 -31
  205. package/lib/smart-grid/api/grid-api/model/gridColumnMeta.d.ts +0 -4
  206. package/lib/smart-grid/api/grid-api/model/gridModel.d.ts +0 -2
  207. package/lib/smart-grid/api/grid-api/model/gridServerModel.d.ts +0 -2
  208. package/lib/smart-grid/smart-grid.component.d.ts +1 -2
  209. package/lib/smart-grid/smart-grid.module.d.ts +4 -3
  210. package/lib/smart-navbar/smart-navbar.module.d.ts +2 -2
  211. package/lib/smart-ng-client.module.d.ts +13 -12
  212. package/lib/smart-tree/smarttree-generic.service.d.ts +3 -2
  213. package/lib/view-context/api/model/uiAction.d.ts +0 -4
  214. package/lib/view-context/smart-ui-action/dialogs/ui-action-confirm-dialog/ui-action-confirm-dialog.component.d.ts +5 -5
  215. package/lib/view-context/smart-ui-action/dialogs/ui-action-confirm-dialog/ui-action-confirm-dialog.service.d.ts +1 -1
  216. package/lib/view-context/smart-ui-action/dialogs/ui-action-file-upload-dialog/ui-action-file-upload-dialog.component.d.ts +1 -1
  217. package/lib/view-context/smart-ui-action/dialogs/ui-action-file-upload-dialog/ui-action-file-upload-dialog.service.d.ts +1 -1
  218. package/lib/view-context/smart-ui-action/dialogs/ui-action-input-dialog/ui-action-input-dialog.component.d.ts +2 -2
  219. package/lib/view-context/smart-ui-action/dialogs/ui-action-input-dialog/ui-action-input-dialog.service.d.ts +1 -1
  220. package/lib/view-context/smart-ui-action/ui-action.model.d.ts +1 -1
  221. package/lib/view-context/smart-ui-action/ui-action.service.d.ts +3 -3
  222. package/lib/view-context/smart-view-context.module.d.ts +11 -34
  223. package/lib/view-context/smart-view-context.service.d.ts +0 -2
  224. package/package.json +1 -1
  225. package/smartbit4all-ng-client-3.3.140.tgz +0 -0
  226. package/src/lib/session/api/README.md +226 -226
  227. package/src/lib/smart-component-layout/api/README.md +226 -226
  228. package/src/lib/smart-filter-editor/api/README.md +226 -226
  229. package/src/lib/smart-grid/api/grid-api/README.md +226 -226
  230. package/src/lib/smart-tree/tree-api/README.md +226 -226
  231. package/src/lib/view-context/api/README.md +226 -226
  232. package/esm2020/lib/smart-filter-editor/api/model/smartFilterType.mjs +0 -17
  233. package/lib/smart-filter-editor/api/model/smartFilterType.d.ts +0 -15
  234. 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, element, renderer) {
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.setUp();
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.setUp();
62
+ this.smartComponentLayout = changes['smartComponentLayout'].currentValue;
63
+ if (this.smartComponentLayout) {
64
+ this.setUp();
65
+ }
65
66
  }
66
67
  setUp() {
67
- if (!this.parentSmartComponent || !this.smartComponentLayout) {
68
- return;
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
- console.warn('ComponentWidgetType.FILTER is not supported');
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
- if (!this.parentLayoutComponent) {
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
- inputs: new Map([
117
- ['smartComponentLayout', data],
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.parentSmartComponent?.model,
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.parentSmartComponent?.addForm(
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.parentSmartComponent?.addGrid(this.smartGrid, {
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
- // NOT USED, DOESN'T WORK
204
- // constructFilter(): void {
205
- // this.smartFilter = (this.smartComponentLayout!.parentComponent as any).addFilter(
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
- if (this.parentSmartComponent?.useQueryLists) {
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 }, { token: i0.ElementRef }, { token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Component });
230
- SmartComponentLayoutComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.4.0", type: SmartComponentLayoutComponent, selector: "smart-component-layout", inputs: { smartComponentLayout: "smartComponentLayout", parentLayoutComponent: "parentLayoutComponent", parentSmartComponent: "parentSmartComponent" }, 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: "expandableComponents", predicate: ExpandableSectionComponent, 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 [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", 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", "parentLayoutComponent", "parentSmartComponent"] }, { 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"] }] });
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 [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", styles: [".horizontal{display:flex;flex-direction:row}.vertical{display:flex;flex-direction:column}\n"] }]
234
- }], ctorParameters: function () { return [{ type: i1.SmartformLayoutDefinitionService }, { type: i0.ElementRef }, { type: i0.Renderer2 }]; }, propDecorators: { smartComponentLayout: [{
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":"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","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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic21hcnQtY29tcG9uZW50LWxheW91dC5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9zbWFydC1uZy1jbGllbnQvc3JjL2xpYi9zbWFydC1jb21wb25lbnQtbGF5b3V0L3NtYXJ0LWNvbXBvbmVudC1sYXlvdXQubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLHdCQUF3QixDQUFDO0FBQ3pELE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSwyQkFBMkIsQ0FBQztBQUMxRCxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0saUNBQWlDLENBQUM7QUFDbEUsT0FBTyxFQUFFLDRCQUE0QixFQUFFLE1BQU0sNkRBQTZELENBQUM7QUFDM0csT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLGdDQUFnQyxDQUFDO0FBQ2pFLE9BQU8sRUFBRSw2QkFBNkIsRUFBRSxNQUFNLG9DQUFvQyxDQUFDO0FBQ25GLE9BQU8sRUFBRSxzQkFBc0IsRUFBRSxNQUFNLDJDQUEyQyxDQUFDOztBQWVuRixNQUFNLE9BQU8sMEJBQTBCOzt1SEFBMUIsMEJBQTBCO3dIQUExQiwwQkFBMEIsaUJBWnRCLDZCQUE2QixhQUUxQyxhQUFhO1FBQ2IsZUFBZTtRQUNmLGVBQWU7UUFDZiw0QkFBNEI7UUFDNUIsZUFBZTtRQUNmLHNCQUFzQixhQUVkLDZCQUE2Qjt3SEFHNUIsMEJBQTBCLGFBRjFCLEVBQUUsWUFUSjtZQUNQLGFBQWE7WUFDYixlQUFlO1lBQ2YsZUFBZTtZQUNmLDRCQUE0QjtZQUM1QixlQUFlO1lBQ2Ysc0JBQXNCO1NBQ3ZCOzJGQUlVLDBCQUEwQjtrQkFidEMsUUFBUTttQkFBQztvQkFDUixZQUFZLEVBQUUsQ0FBQyw2QkFBNkIsQ0FBQztvQkFDN0MsT0FBTyxFQUFFO3dCQUNQLGFBQWE7d0JBQ2IsZUFBZTt3QkFDZixlQUFlO3dCQUNmLDRCQUE0Qjt3QkFDNUIsZUFBZTt3QkFDZixzQkFBc0I7cUJBQ3ZCO29CQUNELE9BQU8sRUFBRSxDQUFDLDZCQUE2QixDQUFDO29CQUN4QyxTQUFTLEVBQUUsRUFBRTtpQkFDZCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IE1hdENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2NvcmUnO1xyXG5pbXBvcnQgeyBCcm93c2VyTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvcGxhdGZvcm0tYnJvd3Nlcic7XHJcbmltcG9ydCB7IFNtYXJ0R3JpZE1vZHVsZSB9IGZyb20gJy4uL3NtYXJ0LWdyaWQvc21hcnQtZ3JpZC5tb2R1bGUnO1xyXG5pbXBvcnQgeyBTbWFydEV4cGFuZGFibGVTZWN0aW9uTW9kdWxlIH0gZnJvbSAnLi4vc21hcnQtZXhwYW5kYWJsZS1zZWN0aW9uL3NtYXJ0LWV4cGFuZGFibGUtc2VjdGlvbi5tb2R1bGUnO1xyXG5pbXBvcnQgeyBTbWFydHRyZWVNb2R1bGUgfSBmcm9tICcuLi9zbWFydC10cmVlL3NtYXJ0dHJlZS5tb2R1bGUnO1xyXG5pbXBvcnQgeyBTbWFydENvbXBvbmVudExheW91dENvbXBvbmVudCB9IGZyb20gJy4vc21hcnQtY29tcG9uZW50LWxheW91dC5jb21wb25lbnQnO1xyXG5pbXBvcnQgeyBTbWFydFZpZXdDb250ZXh0TW9kdWxlIH0gZnJvbSAnLi4vdmlldy1jb250ZXh0L3NtYXJ0LXZpZXctY29udGV4dC5tb2R1bGUnO1xyXG5cclxuQE5nTW9kdWxlKHtcclxuICBkZWNsYXJhdGlvbnM6IFtTbWFydENvbXBvbmVudExheW91dENvbXBvbmVudF0sXHJcbiAgaW1wb3J0czogW1xyXG4gICAgQnJvd3Nlck1vZHVsZSxcclxuICAgIE1hdENvbW1vbk1vZHVsZSxcclxuICAgIFNtYXJ0R3JpZE1vZHVsZSxcclxuICAgIFNtYXJ0RXhwYW5kYWJsZVNlY3Rpb25Nb2R1bGUsXHJcbiAgICBTbWFydHRyZWVNb2R1bGUsXHJcbiAgICBTbWFydFZpZXdDb250ZXh0TW9kdWxlLFxyXG4gIF0sXHJcbiAgZXhwb3J0czogW1NtYXJ0Q29tcG9uZW50TGF5b3V0Q29tcG9uZW50XSxcclxuICBwcm92aWRlcnM6IFtdLFxyXG59KVxyXG5leHBvcnQgY2xhc3MgU21hcnRDb21wb25lbnRMYXlvdXRNb2R1bGUge31cclxuIl19
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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic21hcnRkaWFsb2cubW9kZWwuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9zbWFydC1uZy1jbGllbnQvc3JjL2xpYi9zbWFydC1kaWFsb2cvc21hcnRkaWFsb2cubW9kZWwudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBY0E7Ozs7R0FJRztBQUNILE1BQU0sQ0FBTixJQUFZLGVBUVg7QUFSRCxXQUFZLGVBQWU7SUFDekIsbURBQUcsQ0FBQTtJQUNILHlEQUFNLENBQUE7SUFDTix5REFBTSxDQUFBO0lBQ04seURBQU0sQ0FBQTtJQUNOLHlEQUFNLENBQUE7SUFDTixxREFBSSxDQUFBO0lBQ0osaURBQUUsQ0FBQTtBQUNKLENBQUMsRUFSVyxlQUFlLEtBQWYsZUFBZSxRQVExQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFNtYXJ0Rm9ybSB9IGZyb20gJy4uL3NtYXJ0LWZvcm0vc21hcnRmb3JtLm1vZGVsJztcclxuaW1wb3J0IHsgU21hcnRUYWJsZSB9IGZyb20gJy4uL3NtYXJ0LXRhYmxlL3NtYXJ0dGFibGUubW9kZWwnO1xyXG5cclxuLyoqXHJcbiAqIFRoaXMgaW50ZXJmYWNlIGRlZmluZXMgdGhlIHNpemUgb2YgYSBkaWFsb2cuXHJcbiAqXHJcbiAqIEBhdXRob3IgUm9sYW5kIEbDqW55ZXNcclxuICovXHJcbmV4cG9ydCBpbnRlcmZhY2UgU21hcnREaWFsb2dTaXplIHtcclxuICB3aWR0aD86IG51bWJlcjtcclxuICBoZWlnaHQ/OiBudW1iZXI7XHJcbiAgZnVsbFNjcmVlbj86IGJvb2xlYW47XHJcbn1cclxuXHJcbi8qKlxyXG4gKiBUaGlzIGVudW0gaGVscHMgdG8gZGVmaW5lIHRoZSBhY3Rpb24gb2YgYSBkaWFsb2cuXHJcbiAqXHJcbiAqIEBhdXRob3IgUm9sYW5kIEbDqW55ZXNcclxuICovXHJcbmV4cG9ydCBlbnVtIFNtYXJ0QWN0aW9uVHlwZSB7XHJcbiAgQURELFxyXG4gIENSRUFURSxcclxuICBVUERBVEUsXHJcbiAgUkVNT1ZFLFxyXG4gIERFTEVURSxcclxuICBTQVZFLFxyXG4gIE9LLFxyXG59XHJcblxyXG4vKipcclxuICogVGhpcyBpbnRlcmZhY2UgZGVzY3JpYmVzIHRoZSBjb250ZW50IG9mIGEgZGlhbG9nLlxyXG4gKlxyXG4gKiBAYXV0aG9yIFJvbGFuZCBGw6lueWVzXHJcbiAqL1xyXG5leHBvcnQgaW50ZXJmYWNlIFNtYXJ0Q29udGVudCB7XHJcbiAgdGl0bGU6IHN0cmluZztcclxuICBkZXNjcmlwdGlvbj86IHN0cmluZztcclxufVxyXG5cclxuLyoqXHJcbiAqIFdpdGggdGhpcyBpbnRlcmZhY2UgYW55IGtpbmQgb2YgZGlhbG9ncyBjYW4gYmUgZWFzaWx5IGNyZWF0ZWQuXHJcbiAqXHJcbiAqIFlvdSBtdXN0IGNsb3NlIHRoZSBkaWFsb2cgbWFudWFsbHkhXHJcbiAqXHJcbiAqIEBwYXJhbSBzaXplIFJlcXVpcmVkLiBZb3UgY2FuIGRlZmluZSB0aGUgZGVzaXJlZCBzaXplIG9mIHRoZSBkaWFsb2dcclxuICogQHBhcmFtIGFjdGlvblR5cGUgUmVxdWlyZWQuIFRoZSBtYWluIGFjdGlvbiB0eXBlIG9mIHRoZSBkaWFsb2dcclxuICogQHBhcmFtIGNvbnRlbnQgUmVxdWlyZWQuIERlZmluZXMgdGhlIHRpdGxlIGFuZCB0aGUgZGVzY3JpcHRpb24gb2YgdGhlIGRpYWxvZ1xyXG4gKiBAcGFyYW0gZm9ybSBOb3QgcmVxdWlyZWQuIFlvdSBjYW4gcHJlc2VudCBhIGN1c3RvbSBhbmQgZHluYW1pYyBmb3JtLlxyXG4gKiBAcGFyYW0gdGFibGUgTm90IHJlcXVpcmVkLiBZb3UgY2FuIHByZXNlbnQgYSBjdXN0b20gdGFibGUuXHJcbiAqIEBwYXJhbSBva0NhbGxiYWNrIE5vdCByZXF1aXJlZC4gQSBjdXN0b20gY2FsbGJhY2sgZnVuY3Rpb24uXHJcbiAqIEBwYXJhbSBjbG9zZUNhbGxiYWNrIE5vdCByZXF1aXJlZC4gQSBjdXN0b20gY2FsbGJhY2sgZnVuY3Rpb24uXHJcbiAqIEBwYXJhbSBhY3Rpb25DYWxsYmFjayBSZXF1aXJlZC4gQSBjdXN0b20gYWN0aW9uIGNhbGxiYWNrIGZ1bmN0aW9uLlxyXG4gKiBAcGFyYW0gYWN0aW9uTGFiZWwgUmVxdWlyZWQuIFRoZSBuYW1lIG9mIHRoZSBhY3Rpb24gYnV0dG9uLlxyXG4gKlxyXG4gKiBAYXV0aG9yIFJvbGFuZCBGw6lueWVzXHJcbiAqL1xyXG5leHBvcnQgaW50ZXJmYWNlIFNtYXJ0RGlhbG9nRGF0YSB7XHJcbiAgc2l6ZTogU21hcnREaWFsb2dTaXplO1xyXG4gIGNvbnRlbnQ6IFNtYXJ0Q29udGVudDtcclxuICBjdXN0b21Db21wb25lbnQ/OiBhbnk7XHJcbiAgY3VzdG9tQ29tcG9uZW50SW5wdXRzPzogYW55O1xyXG4gIGFjdGlvblR5cGU/OiBTbWFydEFjdGlvblR5cGU7XHJcbiAgZm9ybT86IFNtYXJ0Rm9ybTtcclxuICB0YWJsZT86IFNtYXJ0VGFibGU8YW55PjtcclxuICBva0NhbGxiYWNrPzogKCkgPT4gdm9pZDtcclxuICBjYW5jZWxDYWxsYmFjaz86IChhcmdzOiBhbnlbXSkgPT4gdm9pZDtcclxuICBjbG9zZUNhbGxiYWNrPzogKGFyZ3M6IGFueVtdKSA9PiB2b2lkO1xyXG4gIGFjdGlvbkNhbGxiYWNrPzogKGFyZ3M6IGFueVtdKSA9PiB2b2lkO1xyXG4gIGFjdGlvbkxhYmVsPzogc3RyaW5nO1xyXG4gIG91dGxldHM/OiBhbnk7XHJcbn1cclxuIl19
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
- SmartViewContextModule,
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
- SmartViewContextModule,
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
- SmartViewContextModule,
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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic21hcnRkaWFsb2cubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvc21hcnQtbmctY2xpZW50L3NyYy9saWIvc21hcnQtZGlhbG9nL3NtYXJ0ZGlhbG9nLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsc0JBQXNCLEVBQUUsUUFBUSxFQUFFLGdCQUFnQixFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ25GLE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQztBQUN0RCxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sMEJBQTBCLENBQUM7QUFDM0QsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLHdCQUF3QixDQUFDO0FBQ3ZELE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQztBQUN6RCxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sMkJBQTJCLENBQUM7QUFDMUQsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0seUJBQXlCLENBQUM7QUFDM0QsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLHdCQUF3QixDQUFDO0FBQ3pELE9BQU8sRUFBRSxzQkFBc0IsRUFBRSxNQUFNLDJDQUEyQyxDQUFDOztBQWlCbkYsTUFBTSxPQUFPLGlCQUFpQjs7OEdBQWpCLGlCQUFpQjsrR0FBakIsaUJBQWlCLGlCQWRiLFdBQVcsYUFFeEIsYUFBYTtRQUNiLGVBQWU7UUFDZixlQUFlO1FBQ2YsYUFBYTtRQUNiLHNCQUFzQjtRQUN0QixnQkFBZ0I7UUFDaEIsZUFBZSxhQUVQLFdBQVc7K0dBSVYsaUJBQWlCLGFBRmpCLEVBQUUsWUFYSjtZQUNQLGFBQWE7WUFDYixlQUFlO1lBQ2YsZUFBZTtZQUNmLGFBQWE7WUFDYixzQkFBc0I7WUFDdEIsZ0JBQWdCO1lBQ2hCLGVBQWU7U0FDaEI7MkZBS1UsaUJBQWlCO2tCQWY3QixRQUFRO21CQUFDO29CQUNSLFlBQVksRUFBRSxDQUFDLFdBQVcsQ0FBQztvQkFDM0IsT0FBTyxFQUFFO3dCQUNQLGFBQWE7d0JBQ2IsZUFBZTt3QkFDZixlQUFlO3dCQUNmLGFBQWE7d0JBQ2Isc0JBQXNCO3dCQUN0QixnQkFBZ0I7d0JBQ2hCLGVBQWU7cUJBQ2hCO29CQUNELE9BQU8sRUFBRSxDQUFDLFdBQVcsQ0FBQztvQkFDdEIsT0FBTyxFQUFFLENBQUMsc0JBQXNCLEVBQUUsZ0JBQWdCLENBQUM7b0JBQ25ELFNBQVMsRUFBRSxFQUFFO2lCQUNkIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ1VTVE9NX0VMRU1FTlRTX1NDSEVNQSwgTmdNb2R1bGUsIE5PX0VSUk9SU19TQ0hFTUEgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgU21hcnREaWFsb2cgfSBmcm9tICcuL3NtYXJ0ZGlhbG9nLmNvbXBvbmVudCc7XHJcbmltcG9ydCB7IE1hdERpYWxvZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2RpYWxvZyc7XHJcbmltcG9ydCB7IE1hdEljb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9pY29uJztcclxuaW1wb3J0IHsgTWF0Q29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvY29yZSc7XHJcbmltcG9ydCB7IEJyb3dzZXJNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9wbGF0Zm9ybS1icm93c2VyJztcclxuaW1wb3J0IHsgU21hcnR0YWJsZU1vZHVsZSB9IGZyb20gJy4uL3NtYXJ0LXRhYmxlL3Byb2plY3RzJztcclxuaW1wb3J0IHsgU21hcnRJY29uTW9kdWxlIH0gZnJvbSAnLi4vc21hcnQtaWNvbi9wcm9qZWN0cyc7XHJcbmltcG9ydCB7IFNtYXJ0Vmlld0NvbnRleHRNb2R1bGUgfSBmcm9tICcuLi92aWV3LWNvbnRleHQvc21hcnQtdmlldy1jb250ZXh0Lm1vZHVsZSc7XHJcblxyXG5ATmdNb2R1bGUoe1xyXG4gIGRlY2xhcmF0aW9uczogW1NtYXJ0RGlhbG9nXSxcclxuICBpbXBvcnRzOiBbXHJcbiAgICBCcm93c2VyTW9kdWxlLFxyXG4gICAgTWF0RGlhbG9nTW9kdWxlLFxyXG4gICAgTWF0Q29tbW9uTW9kdWxlLFxyXG4gICAgTWF0SWNvbk1vZHVsZSxcclxuICAgIFNtYXJ0Vmlld0NvbnRleHRNb2R1bGUsXHJcbiAgICBTbWFydHRhYmxlTW9kdWxlLFxyXG4gICAgU21hcnRJY29uTW9kdWxlLFxyXG4gIF0sXHJcbiAgZXhwb3J0czogW1NtYXJ0RGlhbG9nXSxcclxuICBzY2hlbWFzOiBbQ1VTVE9NX0VMRU1FTlRTX1NDSEVNQSwgTk9fRVJST1JTX1NDSEVNQV0sXHJcbiAgcHJvdmlkZXJzOiBbXSxcclxufSlcclxuZXhwb3J0IGNsYXNzIFNtYXJ0ZGlhbG9nTW9kdWxlIHt9XHJcbiJdfQ==
48
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic21hcnRkaWFsb2cubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvc21hcnQtbmctY2xpZW50L3NyYy9saWIvc21hcnQtZGlhbG9nL3NtYXJ0ZGlhbG9nLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsc0JBQXNCLEVBQUUsUUFBUSxFQUFFLGdCQUFnQixFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ25GLE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQztBQUN0RCxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sMEJBQTBCLENBQUM7QUFDM0QsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLHdCQUF3QixDQUFDO0FBQ3ZELE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQztBQUN6RCxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sMkJBQTJCLENBQUM7QUFDMUQsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLHdCQUF3QixDQUFDO0FBQ3pELE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLHlCQUF5QixDQUFDO0FBQzNELE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQzs7QUFpQnpELE1BQU0sT0FBTyxpQkFBaUI7OzhHQUFqQixpQkFBaUI7K0dBQWpCLGlCQUFpQixpQkFkYixXQUFXLGFBRXhCLGFBQWE7UUFDYixlQUFlO1FBQ2YsZUFBZTtRQUNmLGFBQWE7UUFDYixlQUFlO1FBQ2YsZ0JBQWdCO1FBQ2hCLGVBQWUsYUFFUCxXQUFXOytHQUlWLGlCQUFpQixhQUZqQixFQUFFLFlBWEo7WUFDUCxhQUFhO1lBQ2IsZUFBZTtZQUNmLGVBQWU7WUFDZixhQUFhO1lBQ2IsZUFBZTtZQUNmLGdCQUFnQjtZQUNoQixlQUFlO1NBQ2hCOzJGQUtVLGlCQUFpQjtrQkFmN0IsUUFBUTttQkFBQztvQkFDUixZQUFZLEVBQUUsQ0FBQyxXQUFXLENBQUM7b0JBQzNCLE9BQU8sRUFBRTt3QkFDUCxhQUFhO3dCQUNiLGVBQWU7d0JBQ2YsZUFBZTt3QkFDZixhQUFhO3dCQUNiLGVBQWU7d0JBQ2YsZ0JBQWdCO3dCQUNoQixlQUFlO3FCQUNoQjtvQkFDRCxPQUFPLEVBQUUsQ0FBQyxXQUFXLENBQUM7b0JBQ3RCLE9BQU8sRUFBRSxDQUFDLHNCQUFzQixFQUFFLGdCQUFnQixDQUFDO29CQUNuRCxTQUFTLEVBQUUsRUFBRTtpQkFDZCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENVU1RPTV9FTEVNRU5UU19TQ0hFTUEsIE5nTW9kdWxlLCBOT19FUlJPUlNfU0NIRU1BIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IFNtYXJ0RGlhbG9nIH0gZnJvbSAnLi9zbWFydGRpYWxvZy5jb21wb25lbnQnO1xyXG5pbXBvcnQgeyBNYXREaWFsb2dNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9kaWFsb2cnO1xyXG5pbXBvcnQgeyBNYXRJY29uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvaWNvbic7XHJcbmltcG9ydCB7IE1hdENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2NvcmUnO1xyXG5pbXBvcnQgeyBCcm93c2VyTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvcGxhdGZvcm0tYnJvd3Nlcic7XHJcbmltcG9ydCB7IFNtYXJ0Zm9ybU1vZHVsZSB9IGZyb20gJy4uL3NtYXJ0LWZvcm0vcHJvamVjdHMnO1xyXG5pbXBvcnQgeyBTbWFydHRhYmxlTW9kdWxlIH0gZnJvbSAnLi4vc21hcnQtdGFibGUvcHJvamVjdHMnO1xyXG5pbXBvcnQgeyBTbWFydEljb25Nb2R1bGUgfSBmcm9tICcuLi9zbWFydC1pY29uL3Byb2plY3RzJztcclxuXHJcbkBOZ01vZHVsZSh7XHJcbiAgZGVjbGFyYXRpb25zOiBbU21hcnREaWFsb2ddLFxyXG4gIGltcG9ydHM6IFtcclxuICAgIEJyb3dzZXJNb2R1bGUsXHJcbiAgICBNYXREaWFsb2dNb2R1bGUsXHJcbiAgICBNYXRDb21tb25Nb2R1bGUsXHJcbiAgICBNYXRJY29uTW9kdWxlLFxyXG4gICAgU21hcnRmb3JtTW9kdWxlLFxyXG4gICAgU21hcnR0YWJsZU1vZHVsZSxcclxuICAgIFNtYXJ0SWNvbk1vZHVsZSxcclxuICBdLFxyXG4gIGV4cG9ydHM6IFtTbWFydERpYWxvZ10sXHJcbiAgc2NoZW1hczogW0NVU1RPTV9FTEVNRU5UU19TQ0hFTUEsIE5PX0VSUk9SU19TQ0hFTUFdLFxyXG4gIHByb3ZpZGVyczogW10sXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBTbWFydGRpYWxvZ01vZHVsZSB7fVxyXG4iXX0=
@@ -34,18 +34,12 @@ export class ExpandableSectionComponent {
34
34
  ['sectionIndex', this.index],
35
35
  ]));
36
36
  }
37
- let inputs = new Map([
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 <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", 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"] }] });
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 <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", 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"] }]
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"]}