@smartbit4all/ng-client 4.2.172 → 4.3.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +386 -386
- package/esm2022/lib/component-factory-service/component-factory-service.module.mjs +1 -1
- package/esm2022/lib/component-factory-service/component-factory-service.service.mjs +1 -1
- package/esm2022/lib/component-factory-service/projects.mjs +1 -1
- package/esm2022/lib/session/api/api/api.mjs +1 -1
- package/esm2022/lib/session/api/index.mjs +1 -1
- package/esm2022/lib/session/api/model/models.mjs +1 -1
- package/esm2022/lib/session/api/model/session.mjs +1 -1
- package/esm2022/lib/session/api/model/sessionInfoData.mjs +1 -1
- package/esm2022/lib/session/cookie-service/smart-cookie.service.mjs +1 -1
- package/esm2022/lib/session/projects.mjs +1 -1
- package/esm2022/lib/session/smart-error-catching.interceptor.mjs +1 -1
- package/esm2022/lib/session/smart-header-maintainer.interceptor.mjs +1 -1
- package/esm2022/lib/session/smart-session-handler.service.mjs +1 -1
- package/esm2022/lib/session/smart-session.module.mjs +1 -1
- package/esm2022/lib/session/smart-session.service.mjs +1 -1
- package/esm2022/lib/session/smart-timer/smart-session-timer.component.mjs +3 -3
- package/esm2022/lib/session/smart-timer/smart-session-timer.service.mjs +1 -1
- package/esm2022/lib/shared/projects.mjs +1 -1
- package/esm2022/lib/shared/shared.module.mjs +1 -1
- package/esm2022/lib/shared/smart-tooltip.directive.mjs +1 -1
- package/esm2022/lib/shared/smarttable.date-pipe.mjs +1 -1
- package/esm2022/lib/smart-client/projects.mjs +1 -1
- package/esm2022/lib/smart-client/smart-authentication.service.mjs +1 -1
- package/esm2022/lib/smart-client/smart-component-api-client.mjs +12 -2
- package/esm2022/lib/smart-client/smart-file-uploader/smart-file-uploader.component.mjs +3 -3
- package/esm2022/lib/smart-client/smart.component.mjs +1 -1
- package/esm2022/lib/smart-client/smart.service.mjs +1 -1
- package/esm2022/lib/smart-component-layout/api/api/api.mjs +1 -1
- package/esm2022/lib/smart-component-layout/api/api/default.service.mjs +1 -1
- package/esm2022/lib/smart-component-layout/api/api.module.mjs +1 -1
- package/esm2022/lib/smart-component-layout/api/configuration.mjs +1 -1
- package/esm2022/lib/smart-component-layout/api/encoder.mjs +1 -1
- package/esm2022/lib/smart-component-layout/api/index.mjs +1 -1
- package/esm2022/lib/smart-component-layout/api/model/componentType.mjs +1 -1
- package/esm2022/lib/smart-component-layout/api/model/componentWidgetType.mjs +1 -1
- package/esm2022/lib/smart-component-layout/api/model/layoutDefinitionDescriptor.mjs +1 -1
- package/esm2022/lib/smart-component-layout/api/model/layoutDirection.mjs +1 -1
- package/esm2022/lib/smart-component-layout/api/model/models.mjs +1 -1
- package/esm2022/lib/smart-component-layout/api/model/smartComponentLayoutDefinition.mjs +1 -1
- package/esm2022/lib/smart-component-layout/api/model/smartComponentWidgetDefinition.mjs +1 -1
- package/esm2022/lib/smart-component-layout/api/model/toolbarProperties.mjs +1 -1
- package/esm2022/lib/smart-component-layout/api/param.mjs +1 -1
- package/esm2022/lib/smart-component-layout/api/variables.mjs +1 -1
- package/esm2022/lib/smart-component-layout/projects.mjs +1 -1
- package/esm2022/lib/smart-component-layout/smart-component-layout-utility.mjs +1 -1
- package/esm2022/lib/smart-component-layout/smart-component-layout.component.mjs +3 -3
- package/esm2022/lib/smart-component-layout/smart-component-layout.module.mjs +1 -1
- package/esm2022/lib/smart-diagram/api/api/api.mjs +1 -1
- package/esm2022/lib/smart-diagram/api/api/diagramService.service.mjs +1 -1
- package/esm2022/lib/smart-diagram/api/api.module.mjs +1 -1
- package/esm2022/lib/smart-diagram/api/configuration.mjs +1 -1
- package/esm2022/lib/smart-diagram/api/encoder.mjs +1 -1
- package/esm2022/lib/smart-diagram/api/index.mjs +1 -1
- package/esm2022/lib/smart-diagram/api/model/diagramColor.mjs +1 -1
- package/esm2022/lib/smart-diagram/api/model/diagramDataContainer.mjs +1 -1
- package/esm2022/lib/smart-diagram/api/model/diagramDataItem.mjs +1 -1
- package/esm2022/lib/smart-diagram/api/model/diagramDataSet.mjs +1 -1
- package/esm2022/lib/smart-diagram/api/model/diagramDescriptor.mjs +1 -1
- package/esm2022/lib/smart-diagram/api/model/diagramModel.mjs +1 -1
- package/esm2022/lib/smart-diagram/api/model/diagramShape.mjs +1 -1
- package/esm2022/lib/smart-diagram/api/model/drawTime.mjs +1 -1
- package/esm2022/lib/smart-diagram/api/model/labelText.mjs +1 -1
- package/esm2022/lib/smart-diagram/api/model/models.mjs +1 -1
- package/esm2022/lib/smart-diagram/api/param.mjs +1 -1
- package/esm2022/lib/smart-diagram/api/variables.mjs +1 -1
- package/esm2022/lib/smart-diagram/component/default-smart-diagram-options.provider.mjs +1 -1
- package/esm2022/lib/smart-diagram/component/smart-diagram.component.mjs +22 -22
- package/esm2022/lib/smart-diagram/component/smart-diagram.module.mjs +1 -1
- package/esm2022/lib/smart-diagram/component/smart-diagram.util.mjs +1 -1
- package/esm2022/lib/smart-diagram/projects.mjs +1 -1
- package/esm2022/lib/smart-dialog/projects.mjs +1 -1
- package/esm2022/lib/smart-dialog/smartdialog.component.mjs +3 -3
- package/esm2022/lib/smart-dialog/smartdialog.model.mjs +1 -1
- package/esm2022/lib/smart-dialog/smartdialog.module.mjs +1 -1
- package/esm2022/lib/smart-dialog/smartdialog.service.mjs +1 -1
- package/esm2022/lib/smart-expandable-section/expandable-section.component.mjs +3 -3
- package/esm2022/lib/smart-expandable-section/expandable-section.model.mjs +1 -1
- package/esm2022/lib/smart-expandable-section/projects.mjs +1 -1
- package/esm2022/lib/smart-expandable-section/smart-expandable-section.module.mjs +1 -1
- package/esm2022/lib/smart-expandable-section/smart-expandable-section.service.mjs +1 -1
- package/esm2022/lib/smart-filter/api/filter/model/filterExpressionBoolOperator.mjs +1 -1
- package/esm2022/lib/smart-filter/api/filter/model/filterExpressionBuilderField.mjs +1 -1
- package/esm2022/lib/smart-filter/api/filter/model/filterExpressionBuilderGroup.mjs +1 -1
- package/esm2022/lib/smart-filter/api/filter/model/filterExpressionBuilderModel.mjs +1 -1
- package/esm2022/lib/smart-filter/api/filter/model/filterExpressionData.mjs +1 -1
- package/esm2022/lib/smart-filter/api/filter/model/filterExpressionDataType.mjs +1 -1
- package/esm2022/lib/smart-filter/api/filter/model/filterExpressionField.mjs +1 -1
- package/esm2022/lib/smart-filter/api/filter/model/filterExpressionFieldList.mjs +1 -1
- package/esm2022/lib/smart-filter/api/filter/model/filterExpressionFieldWidgetType.mjs +1 -1
- package/esm2022/lib/smart-filter/api/filter/model/filterExpressionList.mjs +1 -1
- package/esm2022/lib/smart-filter/api/filter/model/filterExpressionOperandData.mjs +1 -1
- package/esm2022/lib/smart-filter/api/filter/model/filterExpressionOperation.mjs +1 -1
- package/esm2022/lib/smart-filter/api/filter/model/filterExpressionOrderBy.mjs +1 -1
- package/esm2022/lib/smart-filter/api/filter/model/model.mjs +1 -1
- package/esm2022/lib/smart-filter/api/filter/model/searchIndexObjectDefinitionData.mjs +1 -1
- package/esm2022/lib/smart-filter/api/filter/model/searchIndexPropertyDefinitionData.mjs +1 -1
- package/esm2022/lib/smart-filter/api/value/model/value.mjs +1 -1
- package/esm2022/lib/smart-filter/projects.mjs +1 -1
- package/esm2022/lib/smart-filter/smart-filter/components/smart-filter-expression-field/smart-filter-expression-field.component.mjs +1 -1
- package/esm2022/lib/smart-filter/smart-filter/components/smart-filter-simple/components/smart-filter-simple-field/smart-filter-simple-field.component.mjs +3 -3
- package/esm2022/lib/smart-filter/smart-filter/components/smart-filter-simple/smart-filter-simple.component.mjs +3 -3
- package/esm2022/lib/smart-filter/smart-filter/smart-filter.component.mjs +3 -3
- package/esm2022/lib/smart-filter/smart-filter/smart-filter.service.mjs +1 -1
- package/esm2022/lib/smart-filter/smart-filter.model.mjs +1 -1
- package/esm2022/lib/smart-filter/smart-filter.module.mjs +1 -1
- package/esm2022/lib/smart-filter-editor/api/api/filter.service.mjs +1 -1
- package/esm2022/lib/smart-filter-editor/api/configuration.mjs +1 -1
- package/esm2022/lib/smart-filter-editor/api/encoder.mjs +1 -1
- package/esm2022/lib/smart-filter-editor/api/model/filterExpressionBoolOperator.mjs +1 -1
- package/esm2022/lib/smart-filter-editor/api/model/filterExpressionBuilderApiConfig.mjs +1 -1
- package/esm2022/lib/smart-filter-editor/api/model/filterExpressionBuilderField.mjs +1 -1
- package/esm2022/lib/smart-filter-editor/api/model/filterExpressionBuilderGroup.mjs +1 -1
- package/esm2022/lib/smart-filter-editor/api/model/filterExpressionBuilderModel.mjs +1 -1
- package/esm2022/lib/smart-filter-editor/api/model/filterExpressionBuilderUiModel.mjs +1 -1
- package/esm2022/lib/smart-filter-editor/api/model/filterExpressionData.mjs +1 -1
- package/esm2022/lib/smart-filter-editor/api/model/filterExpressionDataType.mjs +1 -1
- package/esm2022/lib/smart-filter-editor/api/model/filterExpressionField.mjs +1 -1
- package/esm2022/lib/smart-filter-editor/api/model/filterExpressionFieldEditor.mjs +1 -1
- package/esm2022/lib/smart-filter-editor/api/model/filterExpressionFieldList.mjs +1 -1
- package/esm2022/lib/smart-filter-editor/api/model/filterExpressionFieldWidgetType.mjs +1 -1
- package/esm2022/lib/smart-filter-editor/api/model/filterExpressionList.mjs +1 -1
- package/esm2022/lib/smart-filter-editor/api/model/filterExpressionOperandData.mjs +1 -1
- package/esm2022/lib/smart-filter-editor/api/model/filterExpressionOperation.mjs +1 -1
- package/esm2022/lib/smart-filter-editor/api/model/filterExpressionOrderBy.mjs +1 -1
- package/esm2022/lib/smart-filter-editor/api/model/smartFilterType.mjs +1 -1
- package/esm2022/lib/smart-filter-editor/api/param.mjs +1 -1
- package/esm2022/lib/smart-filter-editor/api/variables.mjs +1 -1
- package/esm2022/lib/smart-filter-editor/filterExpressionBuilderApiActions.mjs +1 -1
- package/esm2022/lib/smart-filter-editor/project.mjs +1 -1
- package/esm2022/lib/smart-filter-editor/smart-filter-editor-content/components/smart-filter-expression-item/smart-filter-expression-item.component.mjs +3 -3
- package/esm2022/lib/smart-filter-editor/smart-filter-editor-content/components/smart-filter-expression-items/smart-filter-expression-items.component.mjs +3 -3
- package/esm2022/lib/smart-filter-editor/smart-filter-editor-content/smart-filter-editor-content.component.mjs +3 -3
- package/esm2022/lib/smart-filter-editor/smart-filter-editor.model.mjs +1 -1
- package/esm2022/lib/smart-filter-editor/smart-filter-editor.module.mjs +1 -1
- package/esm2022/lib/smart-filter-editor/smart-filter-editor.service.mjs +1 -1
- package/esm2022/lib/smart-filter-editor/smart-filter-params/components/smart-filter-param/smart-filter-param.component.mjs +3 -3
- package/esm2022/lib/smart-filter-editor/smart-filter-params/smart-filter-params.component.mjs +3 -3
- package/esm2022/lib/smart-form/api/model/dateFieldProperties.mjs +1 -1
- package/esm2022/lib/smart-form/api/model/models.mjs +1 -1
- package/esm2022/lib/smart-form/api/model/multiFileUploaderProperties.mjs +1 -1
- package/esm2022/lib/smart-form/api/model/selectionDefinition.mjs +1 -1
- package/esm2022/lib/smart-form/api/model/smartFormWidgetType.mjs +1 -1
- package/esm2022/lib/smart-form/api/model/smartWidgetDefinition.mjs +1 -1
- package/esm2022/lib/smart-form/api/model/valueChangeMode.mjs +1 -1
- package/esm2022/lib/smart-form/highlightMacthingString-pipe.mjs +1 -1
- package/esm2022/lib/smart-form/projects.mjs +1 -1
- package/esm2022/lib/smart-form/services/smartform.layout-definition.service.mjs +1 -1
- package/esm2022/lib/smart-form/services/smartform.service.mjs +1 -1
- package/esm2022/lib/smart-form/smartfileuploader/large-file-snack-bar/large-file-snack-bar.component.mjs +3 -3
- package/esm2022/lib/smart-form/smartfileuploader/smartfileuploader.component.mjs +3 -3
- package/esm2022/lib/smart-form/smartfileuploader/smartfileuploader.model.mjs +1 -1
- package/esm2022/lib/smart-form/smartform.component.mjs +3 -3
- package/esm2022/lib/smart-form/smartform.form-model.mjs +1 -1
- package/esm2022/lib/smart-form/smartform.model.mjs +1 -1
- package/esm2022/lib/smart-form/widgets/components/smart-file-editor/smart-file-editor.component.mjs +3 -3
- package/esm2022/lib/smart-form/widgets/components/smart-month-picker/smart-month-picker.component.mjs +3 -3
- package/esm2022/lib/smart-form/widgets/components/smart-multi-file-editor/smart-multi-file-editor.component.mjs +3 -3
- package/esm2022/lib/smart-form/widgets/directives/comparable-dropdown.directive.mjs +1 -1
- package/esm2022/lib/smart-form/widgets/directives/comparable-multiselect.directive.mjs +1 -1
- package/esm2022/lib/smart-form/widgets/smartformwidget/smartformwidget.component.mjs +3 -3
- package/esm2022/lib/smart-form/widgets/smartformwidget/sortable-widget/sortable-widget.component.mjs +3 -3
- package/esm2022/lib/smart-form/widgets/smartformwidget/trackCaps.directive.mjs +1 -1
- package/esm2022/lib/smart-grid/api/grid-api/api/api.mjs +1 -1
- package/esm2022/lib/smart-grid/api/grid-api/api/grid.service.mjs +1 -1
- package/esm2022/lib/smart-grid/api/grid-api/api.module.mjs +1 -1
- package/esm2022/lib/smart-grid/api/grid-api/configuration.mjs +1 -1
- package/esm2022/lib/smart-grid/api/grid-api/encoder.mjs +1 -1
- package/esm2022/lib/smart-grid/api/grid-api/index.mjs +1 -1
- package/esm2022/lib/smart-grid/api/grid-api/model/gridColumnContentType.mjs +1 -1
- package/esm2022/lib/smart-grid/api/grid-api/model/gridColumnMeta.mjs +1 -1
- package/esm2022/lib/smart-grid/api/grid-api/model/gridDataAccessConfig.mjs +1 -1
- package/esm2022/lib/smart-grid/api/grid-api/model/gridExportDescriptor.mjs +1 -1
- package/esm2022/lib/smart-grid/api/grid-api/model/gridModel.mjs +1 -1
- package/esm2022/lib/smart-grid/api/grid-api/model/gridPage.mjs +1 -1
- package/esm2022/lib/smart-grid/api/grid-api/model/gridRow.mjs +1 -1
- package/esm2022/lib/smart-grid/api/grid-api/model/gridSelectionChange.mjs +1 -1
- package/esm2022/lib/smart-grid/api/grid-api/model/gridSelectionMode.mjs +1 -1
- package/esm2022/lib/smart-grid/api/grid-api/model/gridSelectionType.mjs +1 -1
- package/esm2022/lib/smart-grid/api/grid-api/model/gridServerModel.mjs +1 -1
- package/esm2022/lib/smart-grid/api/grid-api/model/gridUpdateData.mjs +1 -1
- package/esm2022/lib/smart-grid/api/grid-api/model/gridView.mjs +1 -1
- package/esm2022/lib/smart-grid/api/grid-api/model/gridViewDescriptor.mjs +1 -1
- package/esm2022/lib/smart-grid/api/grid-api/model/models.mjs +1 -1
- package/esm2022/lib/smart-grid/api/grid-api/param.mjs +1 -1
- package/esm2022/lib/smart-grid/api/grid-api/variables.mjs +1 -1
- package/esm2022/lib/smart-grid/components/expandable-grid/expandable-grid.component.mjs +3 -3
- package/esm2022/lib/smart-grid/components/generic-component/expanded-row-renderer.component.mjs +3 -3
- package/esm2022/lib/smart-grid/components/smart-grid-card/smart-grid-card.component.mjs +3 -3
- package/esm2022/lib/smart-grid/components/table-layout-definer/table-layout-definer.component.mjs +3 -3
- package/esm2022/lib/smart-grid/models/model.mjs +1 -1
- package/esm2022/lib/smart-grid/projects.mjs +1 -1
- package/esm2022/lib/smart-grid/smart-grid-toolbar-util.mjs +1 -1
- package/esm2022/lib/smart-grid/smart-grid.component.mjs +3 -3
- package/esm2022/lib/smart-grid/smart-grid.module.mjs +1 -1
- package/esm2022/lib/smart-grid/smart-grid.service.mjs +1 -1
- package/esm2022/lib/smart-icon/projects.mjs +1 -1
- package/esm2022/lib/smart-icon/smart-icon/smart-icon.component.mjs +3 -3
- package/esm2022/lib/smart-icon/smart-icon/ui-badge/ui-badge.component.mjs +3 -3
- package/esm2022/lib/smart-icon/smart-icon/ui-badge/ui-badge.directive.mjs +1 -1
- package/esm2022/lib/smart-icon/smart-icon.module.mjs +1 -1
- package/esm2022/lib/smart-icon/smart-icon.service.mjs +1 -1
- package/esm2022/lib/smart-map/abstract-map.mjs +1 -1
- package/esm2022/lib/smart-map/api/api/api.mjs +1 -1
- package/esm2022/lib/smart-map/api/api/geoMap.service.mjs +1 -1
- package/esm2022/lib/smart-map/api/api.module.mjs +1 -1
- package/esm2022/lib/smart-map/api/configuration.mjs +1 -1
- package/esm2022/lib/smart-map/api/encoder.mjs +1 -1
- package/esm2022/lib/smart-map/api/index.mjs +1 -1
- package/esm2022/lib/smart-map/api/model/gPSPosition.mjs +1 -1
- package/esm2022/lib/smart-map/api/model/gPSRoute.mjs +1 -1
- package/esm2022/lib/smart-map/api/model/geoMapChange.mjs +1 -1
- package/esm2022/lib/smart-map/api/model/geoMapDataLoadingMode.mjs +1 -1
- package/esm2022/lib/smart-map/api/model/geoMapDataSourceDescriptor.mjs +1 -1
- package/esm2022/lib/smart-map/api/model/geoMapDataSourceType.mjs +1 -1
- package/esm2022/lib/smart-map/api/model/geoMapEditingSession.mjs +1 -1
- package/esm2022/lib/smart-map/api/model/geoMapInteraction.mjs +1 -1
- package/esm2022/lib/smart-map/api/model/geoMapItem.mjs +1 -1
- package/esm2022/lib/smart-map/api/model/geoMapItemKind.mjs +1 -1
- package/esm2022/lib/smart-map/api/model/geoMapLayer.mjs +1 -1
- package/esm2022/lib/smart-map/api/model/geoMapLayerChange.mjs +1 -1
- package/esm2022/lib/smart-map/api/model/geoMapLayerDescriptor.mjs +1 -1
- package/esm2022/lib/smart-map/api/model/geoMapModel.mjs +1 -1
- package/esm2022/lib/smart-map/api/model/geoMapOperationMode.mjs +1 -1
- package/esm2022/lib/smart-map/api/model/geoMapSelectionMode.mjs +1 -1
- package/esm2022/lib/smart-map/api/model/geoMapServerModel.mjs +1 -1
- package/esm2022/lib/smart-map/api/model/geoMapTextType.mjs +1 -1
- package/esm2022/lib/smart-map/api/model/geoMapViewState.mjs +1 -1
- package/esm2022/lib/smart-map/api/model/geoMapViewport.mjs +1 -1
- package/esm2022/lib/smart-map/api/model/models.mjs +1 -1
- package/esm2022/lib/smart-map/api/param.mjs +1 -1
- package/esm2022/lib/smart-map/api/variables.mjs +1 -1
- package/esm2022/lib/smart-map/api-default/api-default.mjs +1 -1
- package/esm2022/lib/smart-map/impl/google-map.mjs +1 -1
- package/esm2022/lib/smart-map/impl/leaflet-map.mjs +1 -1
- package/esm2022/lib/smart-map/projects.mjs +1 -1
- package/esm2022/lib/smart-map/smart-map.component.mjs +3 -3
- package/esm2022/lib/smart-map/smart-map.module.mjs +1 -1
- package/esm2022/lib/smart-map/smart-map.types.mjs +1 -1
- package/esm2022/lib/smart-navbar/projects.mjs +1 -1
- package/esm2022/lib/smart-navbar/smart-navbar.component.mjs +3 -3
- package/esm2022/lib/smart-navbar/smart-navbar.model.mjs +1 -1
- package/esm2022/lib/smart-navbar/smart-navbar.module.mjs +1 -1
- package/esm2022/lib/smart-navbar/smart-navbar.service.mjs +1 -1
- package/esm2022/lib/smart-navigation/projects.mjs +1 -1
- package/esm2022/lib/smart-navigation/smart-navigation.interface.mjs +1 -1
- package/esm2022/lib/smart-navigation/smart-navigation.module.mjs +1 -1
- package/esm2022/lib/smart-navigation/smart-navigation.service.mjs +1 -1
- package/esm2022/lib/smart-ng-client.module.mjs +1 -1
- package/esm2022/lib/smart-ng-client.service.mjs +1 -1
- package/esm2022/lib/smart-subject/projects.mjs +1 -1
- package/esm2022/lib/smart-subject/smart-subject.mjs +1 -1
- package/esm2022/lib/smart-tab-group/projects.mjs +1 -1
- package/esm2022/lib/smart-tab-group/smart-tab-group.component.mjs +3 -3
- package/esm2022/lib/smart-tab-group/smart-tab-group.module.mjs +1 -1
- package/esm2022/lib/smart-tab-group/smart-tab-group.service.mjs +1 -1
- package/esm2022/lib/smart-tab-group/tab-content/tab-content.component.mjs +3 -3
- package/esm2022/lib/smart-tab-group/tab-group-simplified/tab-group.component.mjs +3 -3
- package/esm2022/lib/smart-tab-group/tabTile.model.mjs +1 -1
- package/esm2022/lib/smart-table/components/default-actions-popup/default-actions-popup.component.mjs +3 -3
- package/esm2022/lib/smart-table/components/loading/loading.component.mjs +3 -3
- package/esm2022/lib/smart-table/directives/mat-context-menu-trigger-for.directive.mjs +1 -1
- package/esm2022/lib/smart-table/projects.mjs +1 -1
- package/esm2022/lib/smart-table/smarttable.component.mjs +3 -3
- package/esm2022/lib/smart-table/smarttable.model.mjs +1 -1
- package/esm2022/lib/smart-table/smarttable.module.mjs +1 -1
- package/esm2022/lib/smart-table/smarttable.service.mjs +1 -1
- package/esm2022/lib/smart-table/tables/material-table/material-table.component.mjs +3 -3
- package/esm2022/lib/smart-table/tables/mobile-table/mobile-table.component.mjs +3 -3
- package/esm2022/lib/smart-table/tables/table.mjs +1 -1
- package/esm2022/lib/smart-tree/projects.mjs +1 -1
- package/esm2022/lib/smart-tree/smarttree-generic.service.mjs +1 -1
- package/esm2022/lib/smart-tree/smarttree.component.mjs +3 -3
- package/esm2022/lib/smart-tree/smarttree.model.mjs +1 -1
- package/esm2022/lib/smart-tree/smarttree.module.mjs +1 -1
- package/esm2022/lib/smart-tree/smarttree.node.model.mjs +1 -1
- package/esm2022/lib/smart-tree/smarttree.service.interface.mjs +1 -1
- package/esm2022/lib/smart-tree/smarttree.service.mjs +1 -1
- package/esm2022/lib/smart-tree/tree-api/api/tree.service.mjs +1 -1
- package/esm2022/lib/smart-tree/tree-api/configuration.mjs +1 -1
- package/esm2022/lib/smart-tree/tree-api/encoder.mjs +1 -1
- package/esm2022/lib/smart-tree/tree-api/param.mjs +1 -1
- package/esm2022/lib/smart-tree/tree-api/variables.mjs +1 -1
- package/esm2022/lib/smart-validation/named-validator.service.mjs +1 -1
- package/esm2022/lib/smart-validation/projects.mjs +1 -1
- package/esm2022/lib/smart-validation/smart-validation.module.mjs +1 -1
- package/esm2022/lib/smart-validation/smart-validation.types.mjs +1 -1
- package/esm2022/lib/view-context/api/api/view.service.mjs +1 -1
- package/esm2022/lib/view-context/api/api-default/binaryData.mjs +1 -1
- package/esm2022/lib/view-context/api/api-default/invocationError.mjs +1 -1
- package/esm2022/lib/view-context/api/api-default/invocationRequest.mjs +1 -1
- package/esm2022/lib/view-context/api/model/models.mjs +1 -1
- package/esm2022/lib/view-context/api/model/smartLinkData.mjs +1 -1
- package/esm2022/lib/view-context/api/model/uiAction.mjs +1 -1
- package/esm2022/lib/view-context/api/model/uiActionDefinition.mjs +1 -1
- package/esm2022/lib/view-context/api/model/uiActionSchedule.mjs +1 -1
- package/esm2022/lib/view-context/invalid-fields-snack-bar/invalid-fields-snack-bar.component.mjs +3 -3
- package/esm2022/lib/view-context/message-dialog/message-dialog.component.mjs +3 -3
- package/esm2022/lib/view-context/projects.mjs +1 -1
- package/esm2022/lib/view-context/property-definition-data.mjs +1 -1
- package/esm2022/lib/view-context/smart-ui-action/components/menu/menu.component.mjs +3 -3
- package/esm2022/lib/view-context/smart-ui-action/components/menu/menu.constants.mjs +1 -1
- package/esm2022/lib/view-context/smart-ui-action/components/menu/menu.service.mjs +1 -1
- package/esm2022/lib/view-context/smart-ui-action/components/success-snack-bar/success-snack-bar.component.mjs +3 -3
- package/esm2022/lib/view-context/smart-ui-action/components/upload-widget/photo-capture-widget/photo-capture-widget.component.mjs +3 -3
- package/esm2022/lib/view-context/smart-ui-action/components/upload-widget/prime-file-uploader/prime-file-uploader.component.mjs +3 -3
- package/esm2022/lib/view-context/smart-ui-action/components/upload-widget/upload-widget.component.mjs +3 -3
- package/esm2022/lib/view-context/smart-ui-action/components/upload-widget/upload-widget.utils.mjs +1 -1
- package/esm2022/lib/view-context/smart-ui-action/components/upload-widget/voice-record-widget/voice-record-widget.component.mjs +3 -3
- package/esm2022/lib/view-context/smart-ui-action/dialogs/ui-action-confirm-dialog/ui-action-confirm-dialog.component.mjs +3 -3
- package/esm2022/lib/view-context/smart-ui-action/dialogs/ui-action-confirm-dialog/ui-action-confirm-dialog.service.mjs +1 -1
- package/esm2022/lib/view-context/smart-ui-action/dialogs/ui-action-dialog-button/ui-action-dialog-button.component.mjs +3 -3
- package/esm2022/lib/view-context/smart-ui-action/dialogs/ui-action-file-upload-dialog/ui-action-file-upload-dialog.component.mjs +3 -3
- package/esm2022/lib/view-context/smart-ui-action/dialogs/ui-action-file-upload-dialog/ui-action-file-upload-dialog.service.mjs +1 -1
- package/esm2022/lib/view-context/smart-ui-action/dialogs/ui-action-input-dialog/ui-action-input-dialog.component.mjs +3 -3
- package/esm2022/lib/view-context/smart-ui-action/dialogs/ui-action-input-dialog/ui-action-input-dialog.service.mjs +1 -1
- package/esm2022/lib/view-context/smart-ui-action/ui-action-button/ui-action-button.component.mjs +3 -3
- package/esm2022/lib/view-context/smart-ui-action/ui-action-toolbar.component.mjs +3 -3
- package/esm2022/lib/view-context/smart-ui-action/ui-action.descriptor.service.mjs +1 -1
- package/esm2022/lib/view-context/smart-ui-action/ui-action.model.mjs +1 -1
- package/esm2022/lib/view-context/smart-ui-action/ui-action.service.mjs +1 -1
- package/esm2022/lib/view-context/smart-view-context-dialog.service.mjs +2 -1
- package/esm2022/lib/view-context/smart-view-context-error-dialog/smart-view-context-error-dialog.component.mjs +3 -3
- package/esm2022/lib/view-context/smart-view-context-error-dialog/smart-view-context-error-dialog.service.mjs +1 -1
- package/esm2022/lib/view-context/smart-view-context.interceptor.mjs +1 -1
- package/esm2022/lib/view-context/smart-view-context.model.mjs +1 -1
- package/esm2022/lib/view-context/smart-view-context.module.mjs +1 -1
- package/esm2022/lib/view-context/smart-view-context.service.mjs +1 -1
- package/esm2022/lib/view-context/smart-view-redirect/smart-view-redirect.mjs +1 -1
- package/esm2022/lib/view-context/utility/componentLibrary.mjs +1 -1
- package/esm2022/lib/view-context/utility/smart-object-utility.mjs +1 -1
- package/esm2022/lib/view-context/utility/smart-style-utility.mjs +1 -1
- package/esm2022/lib/view-context/value-api/api/api.mjs +1 -1
- package/esm2022/lib/view-context/value-api/api/value.service.mjs +1 -1
- package/esm2022/lib/view-context/value-api/api.module.mjs +1 -1
- package/esm2022/lib/view-context/value-api/configuration.mjs +1 -1
- package/esm2022/lib/view-context/value-api/encoder.mjs +1 -1
- package/esm2022/lib/view-context/value-api/index.mjs +1 -1
- package/esm2022/lib/view-context/value-api/model/genericValue.mjs +1 -1
- package/esm2022/lib/view-context/value-api/model/models.mjs +1 -1
- package/esm2022/lib/view-context/value-api/model/value.mjs +1 -1
- package/esm2022/lib/view-context/value-api/model/valueSetData.mjs +1 -1
- package/esm2022/lib/view-context/value-api/model/valueSetDefinition.mjs +1 -1
- package/esm2022/lib/view-context/value-api/model/valueSetDefinitionData.mjs +1 -1
- package/esm2022/lib/view-context/value-api/model/valueSetDefinitionIdentifier.mjs +1 -1
- package/esm2022/lib/view-context/value-api/model/valueSetDefinitionKind.mjs +1 -1
- package/esm2022/lib/view-context/value-api/model/valueSetExpression.mjs +1 -1
- package/esm2022/lib/view-context/value-api/model/valueSetOperand.mjs +1 -1
- package/esm2022/lib/view-context/value-api/model/valueSetOperation.mjs +1 -1
- package/esm2022/lib/view-context/value-api/param.mjs +1 -1
- package/esm2022/lib/view-context/value-api/variables.mjs +1 -1
- package/esm2022/projects.mjs +1 -1
- package/fesm2022/smartbit4all-ng-client.mjs +141 -130
- package/fesm2022/smartbit4all-ng-client.mjs.map +1 -1
- package/lib/smart-client/smart-component-api-client.d.ts +3 -1
- package/package.json +1 -1
- package/smartbit4all-ng-client-4.3.1.tgz +0 -0
- package/smartbit4all-ng-client-4.2.172.tgz +0 -0
|
@@ -169,11 +169,11 @@ export class SmartformComponent {
|
|
|
169
169
|
return [];
|
|
170
170
|
}
|
|
171
171
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: SmartformComponent, deps: [{ token: i1.SmartFormService }, { token: COMPONENT_LIBRARY }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
172
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.11", type: SmartformComponent, selector: "smartform", inputs: { smartForm: "smartForm" }, providers: [SmartFormService], viewQueries: [{ propertyName: "smartWidgetsQL", predicate: SmartformwidgetComponent, descendants: true }], usesOnChanges: true, ngImport: i0, template: "<form *ngIf=\"smartForm\" (keydown)=\"keyDownFunction($event)\" [formGroup]=\"form\" class=\"flex form\">\n <h2 *ngIf=\"smartForm.name\">\n {{ smartForm.name }}\n </h2>\n <div [ngClass]=\"smartForm.direction === direction.ROW ? 'row' : 'col'\">\n <div *ngFor=\"let widget of smartForm.widgets\" class=\"item\">\n <smartformwidget\n *ngIf=\"widget.isVisible === undefined ? true : widget.isVisible\"\n [widgetInstance]=\"widget\"\n [form]=\"form\"\n class=\"grid-item\"\n [onBlur]=\"onBlurSubject\"\n [onValueChange]=\"onValueChangeSubject\"\n [blurSophisticatedValueChange]=\"blurSophisticatedValueChange\"\n [sophisticatedValueChange]=\"sophisticatedValueChange\"\n class=\"{{ widget.key }}\"\n [labelColor]=\"smartForm.labelTheme\"\n (valueCleared)=\"submitForm(true)\"\n ></smartformwidget>\n </div>\n </div>\n</form>\n", styles: [".col{display:flex;flex-direction:column;gap:.25em}.row{display:flex;flex-wrap:wrap;gap:.25em}.grid-item{text-align:left}.item{flex:1}.item ::ng-deep .p-inputtext{width:100%!important;min-height:45px}.item ::ng-deep p-inputnumber,.item ::ng-deep .p-inputnumber{width:100%!important;height:45px!important}.item ::ng-deep .p-dropdown,.item ::ng-deep .p-multiselect{width:100%!important}.item ::ng-deep p-overlay{z-index:1002}.item ::ng-deep .p-chips{width:100%!important;height:45px!important}\n"], dependencies: [{ kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i3.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i3.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "component", type: i4.SmartformwidgetComponent, selector: "smartformwidget", inputs: ["form", "widgetInstance", "onBlur", "onValueChange", "labelColor", "sophisticatedValueChange", "blurSophisticatedValueChange"], outputs: ["valueCleared"] }] }); }
|
|
172
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.11", type: SmartformComponent, selector: "smartform", inputs: { smartForm: "smartForm" }, providers: [SmartFormService], viewQueries: [{ propertyName: "smartWidgetsQL", predicate: SmartformwidgetComponent, descendants: true }], usesOnChanges: true, ngImport: i0, template: "<form *ngIf=\"smartForm\" (keydown)=\"keyDownFunction($event)\" [formGroup]=\"form\" class=\"flex form\">\r\n <h2 *ngIf=\"smartForm.name\">\r\n {{ smartForm.name }}\r\n </h2>\r\n <div [ngClass]=\"smartForm.direction === direction.ROW ? 'row' : 'col'\">\r\n <div *ngFor=\"let widget of smartForm.widgets\" class=\"item\">\r\n <smartformwidget\r\n *ngIf=\"widget.isVisible === undefined ? true : widget.isVisible\"\r\n [widgetInstance]=\"widget\"\r\n [form]=\"form\"\r\n class=\"grid-item\"\r\n [onBlur]=\"onBlurSubject\"\r\n [onValueChange]=\"onValueChangeSubject\"\r\n [blurSophisticatedValueChange]=\"blurSophisticatedValueChange\"\r\n [sophisticatedValueChange]=\"sophisticatedValueChange\"\r\n class=\"{{ widget.key }}\"\r\n [labelColor]=\"smartForm.labelTheme\"\r\n (valueCleared)=\"submitForm(true)\"\r\n ></smartformwidget>\r\n </div>\r\n </div>\r\n</form>\r\n", styles: [".col{display:flex;flex-direction:column;gap:.25em}.row{display:flex;flex-wrap:wrap;gap:.25em}.grid-item{text-align:left}.item{flex:1}.item ::ng-deep .p-inputtext{width:100%!important;min-height:45px}.item ::ng-deep p-inputnumber,.item ::ng-deep .p-inputnumber{width:100%!important;height:45px!important}.item ::ng-deep .p-dropdown,.item ::ng-deep .p-multiselect{width:100%!important}.item ::ng-deep p-overlay{z-index:1002}.item ::ng-deep .p-chips{width:100%!important;height:45px!important}\n"], dependencies: [{ kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i3.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i3.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "component", type: i4.SmartformwidgetComponent, selector: "smartformwidget", inputs: ["form", "widgetInstance", "onBlur", "onValueChange", "labelColor", "sophisticatedValueChange", "blurSophisticatedValueChange"], outputs: ["valueCleared"] }] }); }
|
|
173
173
|
}
|
|
174
174
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: SmartformComponent, decorators: [{
|
|
175
175
|
type: Component,
|
|
176
|
-
args: [{ selector: 'smartform', providers: [SmartFormService], template: "<form *ngIf=\"smartForm\" (keydown)=\"keyDownFunction($event)\" [formGroup]=\"form\" class=\"flex form\">\n <h2 *ngIf=\"smartForm.name\">\n {{ smartForm.name }}\n </h2>\n <div [ngClass]=\"smartForm.direction === direction.ROW ? 'row' : 'col'\">\n <div *ngFor=\"let widget of smartForm.widgets\" class=\"item\">\n <smartformwidget\n *ngIf=\"widget.isVisible === undefined ? true : widget.isVisible\"\n [widgetInstance]=\"widget\"\n [form]=\"form\"\n class=\"grid-item\"\n [onBlur]=\"onBlurSubject\"\n [onValueChange]=\"onValueChangeSubject\"\n [blurSophisticatedValueChange]=\"blurSophisticatedValueChange\"\n [sophisticatedValueChange]=\"sophisticatedValueChange\"\n class=\"{{ widget.key }}\"\n [labelColor]=\"smartForm.labelTheme\"\n (valueCleared)=\"submitForm(true)\"\n ></smartformwidget>\n </div>\n </div>\n</form>\n", styles: [".col{display:flex;flex-direction:column;gap:.25em}.row{display:flex;flex-wrap:wrap;gap:.25em}.grid-item{text-align:left}.item{flex:1}.item ::ng-deep .p-inputtext{width:100%!important;min-height:45px}.item ::ng-deep p-inputnumber,.item ::ng-deep .p-inputnumber{width:100%!important;height:45px!important}.item ::ng-deep .p-dropdown,.item ::ng-deep .p-multiselect{width:100%!important}.item ::ng-deep p-overlay{z-index:1002}.item ::ng-deep .p-chips{width:100%!important;height:45px!important}\n"] }]
|
|
176
|
+
args: [{ selector: 'smartform', providers: [SmartFormService], template: "<form *ngIf=\"smartForm\" (keydown)=\"keyDownFunction($event)\" [formGroup]=\"form\" class=\"flex form\">\r\n <h2 *ngIf=\"smartForm.name\">\r\n {{ smartForm.name }}\r\n </h2>\r\n <div [ngClass]=\"smartForm.direction === direction.ROW ? 'row' : 'col'\">\r\n <div *ngFor=\"let widget of smartForm.widgets\" class=\"item\">\r\n <smartformwidget\r\n *ngIf=\"widget.isVisible === undefined ? true : widget.isVisible\"\r\n [widgetInstance]=\"widget\"\r\n [form]=\"form\"\r\n class=\"grid-item\"\r\n [onBlur]=\"onBlurSubject\"\r\n [onValueChange]=\"onValueChangeSubject\"\r\n [blurSophisticatedValueChange]=\"blurSophisticatedValueChange\"\r\n [sophisticatedValueChange]=\"sophisticatedValueChange\"\r\n class=\"{{ widget.key }}\"\r\n [labelColor]=\"smartForm.labelTheme\"\r\n (valueCleared)=\"submitForm(true)\"\r\n ></smartformwidget>\r\n </div>\r\n </div>\r\n</form>\r\n", styles: [".col{display:flex;flex-direction:column;gap:.25em}.row{display:flex;flex-wrap:wrap;gap:.25em}.grid-item{text-align:left}.item{flex:1}.item ::ng-deep .p-inputtext{width:100%!important;min-height:45px}.item ::ng-deep p-inputnumber,.item ::ng-deep .p-inputnumber{width:100%!important;height:45px!important}.item ::ng-deep .p-dropdown,.item ::ng-deep .p-multiselect{width:100%!important}.item ::ng-deep p-overlay{z-index:1002}.item ::ng-deep .p-chips{width:100%!important;height:45px!important}\n"] }]
|
|
177
177
|
}], ctorParameters: () => [{ type: i1.SmartFormService }, { type: i5.ComponentLibrary, decorators: [{
|
|
178
178
|
type: Inject,
|
|
179
179
|
args: [COMPONENT_LIBRARY]
|
|
@@ -183,4 +183,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImpo
|
|
|
183
183
|
type: ViewChildren,
|
|
184
184
|
args: [SmartformwidgetComponent]
|
|
185
185
|
}] } });
|
|
186
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"smartform.component.js","sourceRoot":"","sources":["../../../../../projects/smart-ng-client/src/lib/smart-form/smartform.component.ts","../../../../../projects/smart-ng-client/src/lib/smart-form/smartform.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  Inject,\n  Input,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  QueryList,\n  SimpleChanges,\n  ViewChildren,\n} from '@angular/core';\nimport { UntypedFormGroup } from '@angular/forms';\nimport { Subject, takeUntil } from 'rxjs';\nimport { SmartSubject } from '../smart-subject/projects';\nimport { SmartFormWidgetDirection, SmartFormWidgetType } from './api';\nimport { SmartFormService } from './services/smartform.service';\nimport { SmartForm, SmartFormInvalidFields, SophisticatedValueChange } from './smartform.model';\n// import { UiActionToolbarComponent } from '../view-context/smart-ui-action/ui-action-toolbar.component';\nimport { UiActionToolbarComponent } from '../view-context/smart-ui-action/ui-action-toolbar.component';\nimport { COMPONENT_LIBRARY, ComponentLibrary } from '../view-context/utility/componentLibrary';\nimport { SmartFormWidget } from './smartform.form-model';\nimport { SmartformwidgetComponent } from './widgets/smartformwidget/smartformwidget.component';\n\n@Component({\n  selector: 'smartform',\n  templateUrl: './smartform.component.html',\n  styleUrls: ['./smartform.component.css'],\n  providers: [SmartFormService],\n})\nexport class SmartformComponent implements OnInit, OnDestroy, OnChanges {\n  private _destroy$: Subject<void> = new Subject();\n\n  @Input() smartForm?: SmartForm;\n  onBlurSubject?: Subject<any>;\n  onValueChangeSubject?: Subject<any>;\n  originalWidgets: SmartFormWidget<any>[] = [];\n\n  sophisticatedValueChange: Subject<SophisticatedValueChange> = new SmartSubject(this._destroy$);\n  blurSophisticatedValueChange: Subject<SophisticatedValueChange> = new SmartSubject(\n    this._destroy$\n  );\n\n  form!: UntypedFormGroup;\n\n  direction = SmartFormWidgetDirection;\n\n  @ViewChildren(SmartformwidgetComponent)\n  smartWidgetsQL?: QueryList<SmartformwidgetComponent>;\n\n  constructor(\n    private service: SmartFormService,\n    @Inject(COMPONENT_LIBRARY) public compLib: ComponentLibrary\n  ) {}\n  ngOnChanges(changes: SimpleChanges): void {\n    this.smartForm = changes['smartForm'].currentValue;\n    this.originalWidgets = [];\n    if (this.smartForm) {\n      this.constructForm();\n    }\n  }\n  ngOnInit(): void {\n    if (this.smartForm) {\n      this.constructForm();\n    }\n    this.onBlurSubject = new SmartSubject(this._destroy$);\n  }\n\n  // ngAfterViewInit(): void {\n  //   if (this.smartWidgetsQL) {\n  //     this.handleQueryList(this.smartWidgetsQL, (widget) => {\n  //       // ???\n  //     });\n  //   }\n  // }\n\n  // // TODO this is a duplicate from SmartFormApiClient -> move it to a utility\n  // protected handleQueryList<T>(ql: QueryList<T>, handler: (el: T) => void) {\n  //   ql.forEach((el) => handler(el));\n  //   ql.changes\n  //     .pipe(takeUntil(this._destroy$))\n  //     .subscribe((list) => (list as QueryList<T>).forEach((el) => handler(el)));\n  // }\n\n  refresh(): void {\n    this.service.setValuesFromModel();\n  }\n\n  constructForm(): void {\n    if (!this.smartForm) {\n      throw new Error('Smartform has not been defined!');\n    }\n\n    if (this.smartForm.useOnValueChangeEvent && !this.onValueChangeSubject) {\n      this.onValueChangeSubject = new SmartSubject(this._destroy$);\n    }\n\n    this.service.smartForm = this.smartForm;\n    if (!this.originalWidgets || this.originalWidgets.length === 0) {\n      this.originalWidgets = this.smartForm.widgets;\n    }\n    this.service.setValuesFromModel(this.originalWidgets, this.compLib);\n    this.service.applyConstraints(this.originalWidgets);\n    this.smartForm.widgets = this.service.filterWidgetsByVisibility(this.originalWidgets);\n    this.form = this.service.toFormGroup(this.compLib);\n\n    if (this.smartForm.translateService) {\n      this.smartForm.translateService.onLangChange.pipe(takeUntil(this._destroy$)).subscribe(() => {\n        this.translateWidgets(this.smartForm!.widgets);\n      });\n      this.translateWidgets(this.smartForm.widgets);\n    }\n  }\n\n  private async translateWidgets(widgets: SmartFormWidget<any>[]): Promise<void> {\n    await this.service.translateWidgets(this.smartForm!.widgets);\n    this.markAllWidgetsForChangeDetection();\n  }\n\n  public markAllWidgetsForChangeDetection() {\n    this.getAllSmartWidgets().forEach((widget) => widget.changeDetector.markForCheck());\n  }\n  private getAllSmartWidgets(): SmartformwidgetComponent[] {\n    const result: SmartformwidgetComponent[] = [];\n    this.smartWidgetsQL?.forEach((widget) => {\n      result.push(...this.getChildWidgets(widget));\n    });\n    return result;\n  }\n\n  private getChildWidgets(widget: SmartformwidgetComponent): SmartformwidgetComponent[] {\n    if (widget.widgetInstance.type == SmartFormWidgetType.CONTAINER) {\n      const result: SmartformwidgetComponent[] = [];\n      widget.childrenWidgetsQL?.forEach((child) => result.push(...this.getChildWidgets(child)));\n      return result;\n    } else {\n      return [widget];\n    }\n  }\n\n  ngOnDestroy(): void {\n    this._destroy$.next();\n    this._destroy$.complete();\n  }\n\n  getForm(): UntypedFormGroup {\n    return this.form;\n  }\n\n  getInvalidFields(): SmartFormInvalidFields {\n    let invalidFields: SmartFormInvalidFields = {\n      invalidFieldKeys: [],\n      invalidFieldNames: [],\n    };\n    if (this.form) {\n      for (const control of Object.keys(this.form.controls)) {\n        if (!this.form.controls[control].valid) {\n          let widget = this.service.getSmartFormWidgetByKey(control);\n          if (\n            widget &&\n            widget.type !== SmartFormWidgetType.CONTAINER &&\n            widget.type !== SmartFormWidgetType.INDICATOR &&\n            widget.type !== SmartFormWidgetType.LABEL &&\n            widget.type !== SmartFormWidgetType.FILE_UPLOADER &&\n            widget.type !== SmartFormWidgetType.IMAGE &&\n            widget.type !== SmartFormWidgetType.SVG &&\n            widget.type !== SmartFormWidgetType.DIVIDER &&\n            widget.type !== SmartFormWidgetType.BUTTON &&\n            widget.type !== SmartFormWidgetType.COMPONENT &&\n            widget.type !== SmartFormWidgetType.YOUTUBE_PLAYER &&\n            !widget.isDisabled\n          ) {\n            invalidFields.invalidFieldNames.push(widget.label);\n            invalidFields.invalidFieldKeys.push(widget.key);\n          }\n        }\n      }\n    }\n    return invalidFields;\n  }\n\n  submitForm(validate = true): SmartForm {\n    if (validate) {\n      this.smartForm!.invalidFields = undefined;\n\n      if (this.form && this.form.invalid) {\n        for (const control of Object.keys(this.form.controls)) {\n          this.form.controls[control].markAsTouched();\n          this.form.controls[control].markAsDirty();\n          // this.form.controls[control].setValue(value);\n        }\n\n        this.smartForm!.invalidFields = this.getInvalidFields();\n        this.markAllWidgetsForChangeDetection();\n        return this.smartForm!;\n      }\n    }\n    return this.service.toSmartForm(this.form);\n  }\n\n  keyDownFunction(event: any): void {\n    if (event.keyCode === 13 && this.smartForm!.submitOnEnter) {\n      this.smartForm!.submitOnEnter();\n    }\n  }\n\n  getModel(): any {\n    return this.service.getModel(this.form);\n  }\n\n  getToolbars(): UiActionToolbarComponent[] {\n    if (this.smartWidgetsQL) {\n      let toolbars = this.smartWidgetsQL\n        .filter((widget) => widget.toolbar !== undefined && widget.toolbar !== null)\n        .map((widget) => widget.toolbar!);\n      if (toolbars) {\n        return toolbars;\n      }\n    }\n    return [];\n  }\n}\n","<form *ngIf=\"smartForm\" (keydown)=\"keyDownFunction($event)\" [formGroup]=\"form\" class=\"flex form\">\n  <h2 *ngIf=\"smartForm.name\">\n    {{ smartForm.name }}\n  </h2>\n  <div [ngClass]=\"smartForm.direction === direction.ROW ? 'row' : 'col'\">\n    <div *ngFor=\"let widget of smartForm.widgets\" class=\"item\">\n      <smartformwidget\n        *ngIf=\"widget.isVisible === undefined ? true : widget.isVisible\"\n        [widgetInstance]=\"widget\"\n        [form]=\"form\"\n        class=\"grid-item\"\n        [onBlur]=\"onBlurSubject\"\n        [onValueChange]=\"onValueChangeSubject\"\n        [blurSophisticatedValueChange]=\"blurSophisticatedValueChange\"\n        [sophisticatedValueChange]=\"sophisticatedValueChange\"\n        class=\"{{ widget.key }}\"\n        [labelColor]=\"smartForm.labelTheme\"\n        (valueCleared)=\"submitForm(true)\"\n      ></smartformwidget>\n    </div>\n  </div>\n</form>\n"]}
|
|
186
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"smartform.component.js","sourceRoot":"","sources":["../../../../../projects/smart-ng-client/src/lib/smart-form/smartform.component.ts","../../../../../projects/smart-ng-client/src/lib/smart-form/smartform.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  Inject,\r\n  Input,\r\n  OnChanges,\r\n  OnDestroy,\r\n  OnInit,\r\n  QueryList,\r\n  SimpleChanges,\r\n  ViewChildren,\r\n} from '@angular/core';\r\nimport { UntypedFormGroup } from '@angular/forms';\r\nimport { Subject, takeUntil } from 'rxjs';\r\nimport { SmartSubject } from '../smart-subject/projects';\r\nimport { SmartFormWidgetDirection, SmartFormWidgetType } from './api';\r\nimport { SmartFormService } from './services/smartform.service';\r\nimport { SmartForm, SmartFormInvalidFields, SophisticatedValueChange } from './smartform.model';\r\n// import { UiActionToolbarComponent } from '../view-context/smart-ui-action/ui-action-toolbar.component';\r\nimport { UiActionToolbarComponent } from '../view-context/smart-ui-action/ui-action-toolbar.component';\r\nimport { COMPONENT_LIBRARY, ComponentLibrary } from '../view-context/utility/componentLibrary';\r\nimport { SmartFormWidget } from './smartform.form-model';\r\nimport { SmartformwidgetComponent } from './widgets/smartformwidget/smartformwidget.component';\r\n\r\n@Component({\r\n  selector: 'smartform',\r\n  templateUrl: './smartform.component.html',\r\n  styleUrls: ['./smartform.component.css'],\r\n  providers: [SmartFormService],\r\n})\r\nexport class SmartformComponent implements OnInit, OnDestroy, OnChanges {\r\n  private _destroy$: Subject<void> = new Subject();\r\n\r\n  @Input() smartForm?: SmartForm;\r\n  onBlurSubject?: Subject<any>;\r\n  onValueChangeSubject?: Subject<any>;\r\n  originalWidgets: SmartFormWidget<any>[] = [];\r\n\r\n  sophisticatedValueChange: Subject<SophisticatedValueChange> = new SmartSubject(this._destroy$);\r\n  blurSophisticatedValueChange: Subject<SophisticatedValueChange> = new SmartSubject(\r\n    this._destroy$\r\n  );\r\n\r\n  form!: UntypedFormGroup;\r\n\r\n  direction = SmartFormWidgetDirection;\r\n\r\n  @ViewChildren(SmartformwidgetComponent)\r\n  smartWidgetsQL?: QueryList<SmartformwidgetComponent>;\r\n\r\n  constructor(\r\n    private service: SmartFormService,\r\n    @Inject(COMPONENT_LIBRARY) public compLib: ComponentLibrary\r\n  ) {}\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    this.smartForm = changes['smartForm'].currentValue;\r\n    this.originalWidgets = [];\r\n    if (this.smartForm) {\r\n      this.constructForm();\r\n    }\r\n  }\r\n  ngOnInit(): void {\r\n    if (this.smartForm) {\r\n      this.constructForm();\r\n    }\r\n    this.onBlurSubject = new SmartSubject(this._destroy$);\r\n  }\r\n\r\n  // ngAfterViewInit(): void {\r\n  //   if (this.smartWidgetsQL) {\r\n  //     this.handleQueryList(this.smartWidgetsQL, (widget) => {\r\n  //       // ???\r\n  //     });\r\n  //   }\r\n  // }\r\n\r\n  // // TODO this is a duplicate from SmartFormApiClient -> move it to a utility\r\n  // protected handleQueryList<T>(ql: QueryList<T>, handler: (el: T) => void) {\r\n  //   ql.forEach((el) => handler(el));\r\n  //   ql.changes\r\n  //     .pipe(takeUntil(this._destroy$))\r\n  //     .subscribe((list) => (list as QueryList<T>).forEach((el) => handler(el)));\r\n  // }\r\n\r\n  refresh(): void {\r\n    this.service.setValuesFromModel();\r\n  }\r\n\r\n  constructForm(): void {\r\n    if (!this.smartForm) {\r\n      throw new Error('Smartform has not been defined!');\r\n    }\r\n\r\n    if (this.smartForm.useOnValueChangeEvent && !this.onValueChangeSubject) {\r\n      this.onValueChangeSubject = new SmartSubject(this._destroy$);\r\n    }\r\n\r\n    this.service.smartForm = this.smartForm;\r\n    if (!this.originalWidgets || this.originalWidgets.length === 0) {\r\n      this.originalWidgets = this.smartForm.widgets;\r\n    }\r\n    this.service.setValuesFromModel(this.originalWidgets, this.compLib);\r\n    this.service.applyConstraints(this.originalWidgets);\r\n    this.smartForm.widgets = this.service.filterWidgetsByVisibility(this.originalWidgets);\r\n    this.form = this.service.toFormGroup(this.compLib);\r\n\r\n    if (this.smartForm.translateService) {\r\n      this.smartForm.translateService.onLangChange.pipe(takeUntil(this._destroy$)).subscribe(() => {\r\n        this.translateWidgets(this.smartForm!.widgets);\r\n      });\r\n      this.translateWidgets(this.smartForm.widgets);\r\n    }\r\n  }\r\n\r\n  private async translateWidgets(widgets: SmartFormWidget<any>[]): Promise<void> {\r\n    await this.service.translateWidgets(this.smartForm!.widgets);\r\n    this.markAllWidgetsForChangeDetection();\r\n  }\r\n\r\n  public markAllWidgetsForChangeDetection() {\r\n    this.getAllSmartWidgets().forEach((widget) => widget.changeDetector.markForCheck());\r\n  }\r\n  private getAllSmartWidgets(): SmartformwidgetComponent[] {\r\n    const result: SmartformwidgetComponent[] = [];\r\n    this.smartWidgetsQL?.forEach((widget) => {\r\n      result.push(...this.getChildWidgets(widget));\r\n    });\r\n    return result;\r\n  }\r\n\r\n  private getChildWidgets(widget: SmartformwidgetComponent): SmartformwidgetComponent[] {\r\n    if (widget.widgetInstance.type == SmartFormWidgetType.CONTAINER) {\r\n      const result: SmartformwidgetComponent[] = [];\r\n      widget.childrenWidgetsQL?.forEach((child) => result.push(...this.getChildWidgets(child)));\r\n      return result;\r\n    } else {\r\n      return [widget];\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  getForm(): UntypedFormGroup {\r\n    return this.form;\r\n  }\r\n\r\n  getInvalidFields(): SmartFormInvalidFields {\r\n    let invalidFields: SmartFormInvalidFields = {\r\n      invalidFieldKeys: [],\r\n      invalidFieldNames: [],\r\n    };\r\n    if (this.form) {\r\n      for (const control of Object.keys(this.form.controls)) {\r\n        if (!this.form.controls[control].valid) {\r\n          let widget = this.service.getSmartFormWidgetByKey(control);\r\n          if (\r\n            widget &&\r\n            widget.type !== SmartFormWidgetType.CONTAINER &&\r\n            widget.type !== SmartFormWidgetType.INDICATOR &&\r\n            widget.type !== SmartFormWidgetType.LABEL &&\r\n            widget.type !== SmartFormWidgetType.FILE_UPLOADER &&\r\n            widget.type !== SmartFormWidgetType.IMAGE &&\r\n            widget.type !== SmartFormWidgetType.SVG &&\r\n            widget.type !== SmartFormWidgetType.DIVIDER &&\r\n            widget.type !== SmartFormWidgetType.BUTTON &&\r\n            widget.type !== SmartFormWidgetType.COMPONENT &&\r\n            widget.type !== SmartFormWidgetType.YOUTUBE_PLAYER &&\r\n            !widget.isDisabled\r\n          ) {\r\n            invalidFields.invalidFieldNames.push(widget.label);\r\n            invalidFields.invalidFieldKeys.push(widget.key);\r\n          }\r\n        }\r\n      }\r\n    }\r\n    return invalidFields;\r\n  }\r\n\r\n  submitForm(validate = true): SmartForm {\r\n    if (validate) {\r\n      this.smartForm!.invalidFields = undefined;\r\n\r\n      if (this.form && this.form.invalid) {\r\n        for (const control of Object.keys(this.form.controls)) {\r\n          this.form.controls[control].markAsTouched();\r\n          this.form.controls[control].markAsDirty();\r\n          // this.form.controls[control].setValue(value);\r\n        }\r\n\r\n        this.smartForm!.invalidFields = this.getInvalidFields();\r\n        this.markAllWidgetsForChangeDetection();\r\n        return this.smartForm!;\r\n      }\r\n    }\r\n    return this.service.toSmartForm(this.form);\r\n  }\r\n\r\n  keyDownFunction(event: any): void {\r\n    if (event.keyCode === 13 && this.smartForm!.submitOnEnter) {\r\n      this.smartForm!.submitOnEnter();\r\n    }\r\n  }\r\n\r\n  getModel(): any {\r\n    return this.service.getModel(this.form);\r\n  }\r\n\r\n  getToolbars(): UiActionToolbarComponent[] {\r\n    if (this.smartWidgetsQL) {\r\n      let toolbars = this.smartWidgetsQL\r\n        .filter((widget) => widget.toolbar !== undefined && widget.toolbar !== null)\r\n        .map((widget) => widget.toolbar!);\r\n      if (toolbars) {\r\n        return toolbars;\r\n      }\r\n    }\r\n    return [];\r\n  }\r\n}\r\n","<form *ngIf=\"smartForm\" (keydown)=\"keyDownFunction($event)\" [formGroup]=\"form\" class=\"flex form\">\r\n  <h2 *ngIf=\"smartForm.name\">\r\n    {{ smartForm.name }}\r\n  </h2>\r\n  <div [ngClass]=\"smartForm.direction === direction.ROW ? 'row' : 'col'\">\r\n    <div *ngFor=\"let widget of smartForm.widgets\" class=\"item\">\r\n      <smartformwidget\r\n        *ngIf=\"widget.isVisible === undefined ? true : widget.isVisible\"\r\n        [widgetInstance]=\"widget\"\r\n        [form]=\"form\"\r\n        class=\"grid-item\"\r\n        [onBlur]=\"onBlurSubject\"\r\n        [onValueChange]=\"onValueChangeSubject\"\r\n        [blurSophisticatedValueChange]=\"blurSophisticatedValueChange\"\r\n        [sophisticatedValueChange]=\"sophisticatedValueChange\"\r\n        class=\"{{ widget.key }}\"\r\n        [labelColor]=\"smartForm.labelTheme\"\r\n        (valueCleared)=\"submitForm(true)\"\r\n      ></smartformwidget>\r\n    </div>\r\n  </div>\r\n</form>\r\n"]}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
export {};
|
|
2
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"smartform.form-model.js","sourceRoot":"","sources":["../../../../../projects/smart-ng-client/src/lib/smart-form/smartform.form-model.ts"],"names":[],"mappings":"","sourcesContent":["import { QuillModules } from 'ngx-quill';\nimport {\n  DateFieldProperties,\n  FileUploaderProperties,\n  MultiFileUploaderProperties,\n  ImageProperties,\n  SelectionDefinition,\n  SmartFormInputMode,\n  SmartFormWidgetDirection,\n  SmartFormWidgetType,\n  SmartWidgetHint,\n  SortDefinition,\n  TextFieldProperties,\n  ValueChangeMode,\n} from './api';\nimport {\n  SmartFormTextFieldButton,\n  SmartFormWidgetWidth,\n  SmartIndicator,\n  SmartValidator,\n  ToggleLabelPosition,\n} from './smartform.model';\nimport { ImageResource, Style } from '../view-context/api';\n\nexport declare type SmartFormWidget<T> =\n  | SmartTextField<T>\n  | SmartTextFieldNumber<T>\n  | SmartTextFieldChips<T>\n  | SmartTextFieldLookup<T>\n  | SmartTextBox<T>\n  | SmartSelect<T>\n  | SmartSelectMultiple<T>\n  | SmartCheckBox<T>\n  | SmartCheckBox2<T>\n  | SmartRadioButton<T>\n  | SmartDatePicker<T>\n  | SmartDateTimePicker<T>\n  | SmartContainer<T>\n  | SmartLabel\n  | SmartTime<T>\n  | SmartToggle<T>\n  | SmartIndicatorItem\n  | SmartFileUploader\n  | SmartMultiFileUploader\n  | SmartImage\n  | SmartDivider\n  | SmartButton\n  | SmartFormInlineComponent\n  | SmartRichText\n  | SmartSortable<T>\n  | SmartMatrix\n  | SmartYoutubePlayer\n  | SmartMonthPicker\n  | SmartSvg;\n\nexport interface SmartTextField<T> {\n  type: SmartFormWidgetType.TEXT_FIELD;\n  key: string;\n  valueChangeMode?: ValueChangeMode;\n  label: string;\n  originalLabel?: string;\n  showLabel?: boolean;\n  value?: T;\n  placeholder?: string;\n  originalPlaceholder?: string;\n  minWidth?: SmartFormWidgetWidth | number | number;\n  isDisabled?: boolean;\n  isReadonly?: boolean;\n  prefix?: string;\n  suffix?: string;\n  validators?: SmartValidator[];\n  cssClass?: string;\n  cssLabelClass?: string;\n  labelPositionClass?: string;\n  isFloatLabel?: boolean;\n  style?: Style;\n  labelStyle?: Style;\n  isPassword?: boolean;\n  textFieldButton?: SmartFormTextFieldButton;\n  capsLockWarning?: string;\n  capsLockWarningIcon?: string;\n  isVisible?: boolean;\n  mask?: string;\n  error?: string;\n  icon?: string;\n  iconColor?: string;\n  iconPosition?: 'PRE' | 'POST';\n  errorIcon?: string;\n  errorIconColor?: string;\n  serverErrorMessage?: string;\n  serverErrorIcon?: string;\n  serverErrorColor?: string;\n  valueList?: SmartItem<T>[];\n  selection?: SelectionDefinition;\n  filterErrorMessage?: string;\n  hint?: SmartWidgetHint;\n  maxLength?: number;\n  showCharacterLimitSuffix?: boolean;\n  toolbarId?: string;\n  inputMode?: SmartFormInputMode;\n  textFieldProperties?: TextFieldProperties;\n}\n\nexport interface SmartTextFieldNumber<T> {\n  type: SmartFormWidgetType.TEXT_FIELD_NUMBER;\n  key: string;\n  valueChangeMode?: ValueChangeMode;\n  label: string;\n  originalLabel?: string;\n  showLabel?: boolean;\n  value?: T;\n  placeholder?: string;\n  originalPlaceholder?: string;\n  minWidth?: SmartFormWidgetWidth | number | number;\n  isDisabled?: boolean;\n  isReadonly?: boolean;\n  prefix?: string;\n  suffix?: string;\n  validators?: SmartValidator[];\n  cssClass?: string;\n  cssLabelClass?: string;\n  labelPositionClass?: string;\n  isFloatLabel?: boolean;\n  style?: Style;\n  labelStyle?: Style;\n  textFieldButton?: SmartFormTextFieldButton;\n  isVisible?: boolean;\n  minValues?: number;\n  maxValues?: number;\n  error?: string;\n  icon?: string;\n  iconColor?: string;\n  errorIcon?: string;\n  errorIconColor?: string;\n  serverErrorMessage?: string;\n  serverErrorIcon?: string;\n  serverErrorColor?: string;\n  hint?: SmartWidgetHint;\n}\n\nexport interface SmartTextFieldChips<T> {\n  type: SmartFormWidgetType.TEXT_FIELD_CHIPS;\n  key: string;\n  valueChangeMode?: ValueChangeMode;\n  label: string;\n  originalLabel?: string;\n  showLabel?: boolean;\n  value?: T;\n  placeholder?: string;\n  originalPlaceholder?: string;\n  minWidth?: SmartFormWidgetWidth | number;\n  isDisabled?: boolean;\n  isReadonly?: boolean;\n  validators?: SmartValidator[];\n  cssClass?: string;\n  cssLabelClass?: string;\n  labelPositionClass?: string;\n  isFloatLabel?: boolean;\n  style?: Style;\n  labelStyle?: Style;\n  isVisible?: boolean;\n  error?: string;\n  errorIcon?: string;\n  errorIconColor?: string;\n  serverErrorMessage?: string;\n  serverErrorIcon?: string;\n  serverErrorColor?: string;\n  valueList: SmartItem<T>[];\n  minValues?: number;\n  maxValues?: number;\n  hint?: SmartWidgetHint;\n}\nexport interface SmartTextFieldLookup<T> {\n  type: SmartFormWidgetType.TEXT_FIELD_LOOKUP;\n  key: string;\n  valueChangeMode?: ValueChangeMode;\n  label: string;\n  originalLabel?: string;\n  showLabel?: boolean;\n  value?: T;\n  placeholder?: string;\n  originalPlaceholder?: string;\n  minWidth?: SmartFormWidgetWidth | number;\n  isDisabled?: boolean;\n  isReadonly?: boolean;\n  validators?: SmartValidator[];\n  cssClass?: string;\n  cssLabelClass?: string;\n  labelPositionClass?: string;\n  isFloatLabel?: boolean;\n  style?: Style;\n  labelStyle?: Style;\n  isVisible?: boolean;\n  error?: string;\n  errorIcon?: string;\n  errorIconColor?: string;\n  serverErrorMessage?: string;\n  serverErrorIcon?: string;\n  serverErrorColor?: string;\n  minValues?: number;\n  maxValues?: number;\n  hint?: SmartWidgetHint;\n  toolbarId?: string;\n}\nexport interface SmartTextBox<T> {\n  type: SmartFormWidgetType.TEXT_BOX;\n  key: string;\n  valueChangeMode?: ValueChangeMode;\n  label: string;\n  originalLabel?: string;\n  showLabel?: boolean;\n  value?: T;\n  placeholder?: string;\n  originalPlaceholder?: string;\n  minWidth?: SmartFormWidgetWidth | number;\n  isDisabled?: boolean;\n  isReadonly?: boolean;\n  validators?: SmartValidator[];\n  cssClass?: string;\n  cssLabelClass?: string;\n  labelPositionClass?: string;\n  isFloatLabel?: boolean;\n  style?: Style;\n  labelStyle?: Style;\n  isVisible?: boolean;\n  error?: string;\n  errorIcon?: string;\n  errorIconColor?: string;\n  serverErrorMessage?: string;\n  serverErrorIcon?: string;\n  serverErrorColor?: string;\n  hint?: SmartWidgetHint;\n  maxLength?: number;\n  showCharacterLimitSuffix?: boolean;\n}\nexport interface SmartSelect<T> {\n  type: SmartFormWidgetType.SELECT;\n  key: string;\n  valueChangeMode?: ValueChangeMode;\n  label: string;\n  originalLabel?: string;\n  showLabel?: boolean;\n  placeholder?: string;\n  value?: T;\n  minWidth?: SmartFormWidgetWidth | number;\n  isDisabled?: boolean;\n  isReadonly?: boolean;\n  validators?: SmartValidator[];\n  cssClass?: string;\n  cssLabelClass?: string;\n  labelPositionClass?: string;\n  isFloatLabel?: boolean;\n  style?: Style;\n  labelStyle?: Style;\n  isVisible?: boolean;\n  error?: string;\n  errorIcon?: string;\n  errorIconColor?: string;\n  serverErrorMessage?: string;\n  serverErrorIcon?: string;\n  serverErrorColor?: string;\n  valueList: SmartItems<T>[];\n  selection?: SelectionDefinition;\n  hint?: SmartWidgetHint;\n  compareWith?: (o1: any, o2: any) => boolean;\n}\nexport interface SmartSelectMultiple<T> {\n  type: SmartFormWidgetType.SELECT_MULTIPLE;\n  key: string;\n  valueChangeMode?: ValueChangeMode;\n  label: string;\n  originalLabel?: string;\n  showLabel?: boolean;\n  value?: T;\n  minWidth?: SmartFormWidgetWidth | number;\n  isDisabled?: boolean;\n  isReadonly?: boolean;\n  validators?: SmartValidator[];\n  cssClass?: string;\n  cssLabelClass?: string;\n  labelPositionClass?: string;\n  isFloatLabel?: boolean;\n  style?: Style;\n  labelStyle?: Style;\n  placeholder?: string;\n  isVisible?: boolean;\n  error?: string;\n  errorIcon?: string;\n  errorIconColor?: string;\n  serverErrorMessage?: string;\n  serverErrorIcon?: string;\n  serverErrorColor?: string;\n  valueList: SmartItems<T>[];\n  selection?: SelectionDefinition;\n  hint?: SmartWidgetHint;\n  compareWith?: (o1: any, o2: any) => boolean;\n}\nexport interface SmartCheckBox<T> {\n  type: SmartFormWidgetType.CHECK_BOX;\n  key: string;\n  valueChangeMode?: ValueChangeMode;\n  label: string;\n  originalLabel?: string;\n  showLabel?: boolean;\n  value?: T;\n  minWidth?: SmartFormWidgetWidth | number;\n  isDisabled?: boolean;\n  isReadonly?: boolean;\n  validators?: SmartValidator[];\n  cssClass?: string;\n  cssLabelClass?: string;\n  labelPositionClass?: string;\n  isFloatLabel?: boolean;\n  style?: Style;\n  labelStyle?: Style;\n  isVisible?: boolean;\n  error?: string;\n  errorIcon?: string;\n  errorIconColor?: string;\n  serverErrorMessage?: string;\n  serverErrorIcon?: string;\n  serverErrorColor?: string;\n  selection?: SelectionDefinition;\n  direction?: SmartFormWidgetDirection;\n  hint?: SmartWidgetHint;\n}\nexport interface SmartCheckBox2<T> {\n  type: SmartFormWidgetType.CHECK_BOX_2;\n  key: string;\n  valueChangeMode?: ValueChangeMode;\n  label: string;\n  originalLabel?: string;\n  showLabel?: boolean;\n  value?: T;\n  minWidth?: SmartFormWidgetWidth | number;\n  isDisabled?: boolean;\n  isReadonly?: boolean;\n  validators?: SmartValidator[];\n  cssClass?: string;\n  cssLabelClass?: string;\n  labelPositionClass?: string;\n  isFloatLabel?: boolean;\n  style?: Style;\n  labelStyle?: Style;\n  isVisible?: boolean;\n  error?: string;\n  errorIcon?: string;\n  errorIconColor?: string;\n  serverErrorMessage?: string;\n  serverErrorIcon?: string;\n  serverErrorColor?: string;\n  valueList: SmartItem<T>[];\n  selection?: SelectionDefinition;\n  direction?: SmartFormWidgetDirection;\n  hint?: SmartWidgetHint;\n}\nexport interface SmartRadioButton<T> {\n  type: SmartFormWidgetType.RADIO_BUTTON;\n  key: string;\n  valueChangeMode?: ValueChangeMode;\n  label: string;\n  originalLabel?: string;\n  showLabel?: boolean;\n  value?: T;\n  minWidth?: SmartFormWidgetWidth | number;\n  isDisabled?: boolean;\n  isReadonly?: boolean;\n  validators?: SmartValidator[];\n  cssClass?: string;\n  cssLabelClass?: string;\n  labelPositionClass?: string;\n  isFloatLabel?: boolean;\n  style?: Style;\n  labelStyle?: Style;\n  isVisible?: boolean;\n  error?: string;\n  errorIcon?: string;\n  errorIconColor?: string;\n  serverErrorMessage?: string;\n  serverErrorIcon?: string;\n  serverErrorColor?: string;\n  valueList: SmartItem<T>[];\n  selection?: SelectionDefinition;\n  direction?: SmartFormWidgetDirection;\n  hint?: SmartWidgetHint;\n}\nexport interface SmartDatePicker<T> {\n  type: SmartFormWidgetType.DATE_PICKER;\n  key: string;\n  valueChangeMode?: ValueChangeMode;\n  label: string;\n  originalLabel?: string;\n  showLabel?: boolean;\n  value?: T;\n  placeholder?: string;\n  minWidth?: SmartFormWidgetWidth | number;\n  isDisabled?: boolean;\n  isReadonly?: boolean;\n  validators?: SmartValidator[];\n  cssClass?: string;\n  cssLabelClass?: string;\n  labelPositionClass?: string;\n  isFloatLabel?: boolean;\n  style?: Style;\n  labelStyle?: Style;\n  isVisible?: boolean;\n  error?: string;\n  errorIcon?: string;\n  errorIconColor?: string;\n  serverErrorMessage?: string;\n  serverErrorIcon?: string;\n  serverErrorColor?: string;\n  dateFormatHint?: string;\n  dateFieldProperties?: DateFieldProperties;\n  filter?: (d: Date | null) => boolean;\n  hint?: SmartWidgetHint;\n}\nexport interface SmartDateTimePicker<T> {\n  type: SmartFormWidgetType.DATE_TIME_PICKER;\n  key: string;\n  valueChangeMode?: ValueChangeMode;\n  label: string;\n  originalLabel?: string;\n  showLabel?: boolean;\n  value?: T;\n  placeholder?: string;\n  minWidth?: SmartFormWidgetWidth | number;\n  isDisabled?: boolean;\n  isReadonly?: boolean;\n  validators?: SmartValidator[];\n  cssClass?: string;\n  cssLabelClass?: string;\n  labelPositionClass?: string;\n  isFloatLabel?: boolean;\n  style?: Style;\n  labelStyle?: Style;\n  isVisible?: boolean;\n  error?: string;\n  errorIcon?: string;\n  errorIconColor?: string;\n  serverErrorMessage?: string;\n  serverErrorIcon?: string;\n  serverErrorColor?: string;\n  dateFormatHint?: string;\n  dateFieldProperties?: DateFieldProperties;\n  filter?: (d: Date | null) => boolean;\n  hint?: SmartWidgetHint;\n}\nexport interface SmartContainer<T> {\n  key?: string;\n  valueChangeMode?: ValueChangeMode;\n  type: SmartFormWidgetType.CONTAINER;\n  isVisible?: boolean;\n  valueList: SmartFormWidget<T>[];\n  direction?: SmartFormWidgetDirection;\n  cssClass?: string;\n  style?: Style;\n}\nexport interface SmartLabel {\n  key?: string;\n  valueChangeMode?: ValueChangeMode;\n  type: SmartFormWidgetType.LABEL;\n  isVisible?: boolean;\n  cssClass?: string;\n  style?: Style;\n  labelStyle?: Style;\n  label: string;\n  originalLabel?: string;\n  widgetDescription?: string;\n  minWidth?: SmartFormWidgetWidth | number;\n  markAsRequired?: boolean;\n}\nexport interface SmartTime<T> {\n  type: SmartFormWidgetType.TIME;\n  key: string;\n  valueChangeMode?: ValueChangeMode;\n  value?: T;\n  placeholder?: string;\n  label: string;\n  originalLabel?: string;\n  showLabel?: boolean;\n  minWidth?: SmartFormWidgetWidth | number;\n  isVisible?: boolean;\n  cssClass?: string;\n  cssLabelClass?: string;\n  labelPositionClass?: string;\n  isFloatLabel?: boolean;\n  style?: Style;\n  labelStyle?: Style;\n  isDisabled?: boolean;\n  isReadonly?: boolean;\n  validators?: SmartValidator[];\n  error?: string;\n  errorIcon?: string;\n  errorIconColor?: string;\n  serverErrorMessage?: string;\n  serverErrorIcon?: string;\n  serverErrorColor?: string;\n  hint?: SmartWidgetHint;\n}\nexport interface SmartToggle<T> {\n  type: SmartFormWidgetType.TOGGLE;\n  key: string;\n  valueChangeMode?: ValueChangeMode;\n  value?: T;\n  placeholder?: string;\n  label: string;\n  originalLabel?: string;\n  showLabel?: boolean;\n  isVisible?: boolean;\n  cssClass?: string;\n  cssLabelClass?: string;\n  labelPositionClass?: string;\n  isFloatLabel?: boolean;\n  style?: Style;\n  labelStyle?: Style;\n  isDisabled?: boolean;\n  isReadonly?: boolean;\n  toggleLabelPosition?: ToggleLabelPosition;\n  validators?: SmartValidator[];\n  error?: string;\n  errorIcon?: string;\n  errorIconColor?: string;\n  serverErrorMessage?: string;\n  serverErrorIcon?: string;\n  serverErrorColor?: string;\n  hint?: SmartWidgetHint;\n}\nexport interface SmartIndicatorItem {\n  type: SmartFormWidgetType.INDICATOR;\n  key: string;\n  valueChangeMode?: ValueChangeMode;\n  label: string;\n  originalLabel?: string;\n  showLabel?: boolean;\n  indicator: SmartIndicator;\n  isVisible?: boolean;\n  cssClass?: string;\n  cssLabelClass?: string;\n  labelPositionClass?: string;\n  isFloatLabel?: boolean;\n  style?: Style;\n  labelStyle?: Style;\n}\n\nexport declare type SmartItems<T> = SmartItem<T> | SmartItemGroup<T>;\n\nexport interface SmartItem<T> {\n  type: SmartFormWidgetType.ITEM;\n  key: string;\n  valueChangeMode?: ValueChangeMode;\n  label: string;\n  cssLabelClass?: string;\n  labelPositionClass?: string;\n  isFloatLabel?: boolean;\n  style?: Style;\n  labelStyle?: Style;\n  originalLabel?: string;\n  value?: T;\n  isDisabled?: boolean;\n  icon?: string;\n  iconColor?: string;\n  imageUrl?: string;\n}\nexport interface SmartItemGroup<T> {\n  type: SmartFormWidgetType.ITEM_GROUP;\n  key: string;\n  valueChangeMode?: ValueChangeMode;\n  label: string;\n  cssLabelClass?: string;\n  labelPositionClass?: string;\n  isFloatLabel?: boolean;\n  style?: Style;\n  labelStyle?: Style;\n  originalLabel?: string;\n  isDisabled?: boolean;\n  valueList: SmartItem<T>[];\n}\n\nexport interface SmartFileUploader {\n  type: SmartFormWidgetType.FILE_UPLOADER;\n  value?: any;\n  key: string;\n  valueChangeMode?: ValueChangeMode;\n  label: string;\n  isDisabled?: boolean;\n  validators?: SmartValidator[];\n  originalLabel?: string;\n  showLabel?: boolean;\n  isVisible?: boolean;\n  cssClass?: string;\n  cssLabelClass?: string;\n  labelPositionClass?: string;\n  isFloatLabel?: boolean;\n  style?: Style;\n  labelStyle?: Style;\n  fileFormats?: string[];\n  maxSizeMb?: number;\n  i18n?: any;\n  fileUploaderProperties?: FileUploaderProperties;\n  toolbarId?: string;\n}\n\nexport interface SmartMultiFileUploader {\n  type: SmartFormWidgetType.MULTI_FILE_UPLOADER;\n  value?: any;\n  key: string;\n  valueChangeMode?: ValueChangeMode;\n  label: string;\n  isDisabled?: boolean;\n  validators?: SmartValidator[];\n  originalLabel?: string;\n  showLabel?: boolean;\n  isVisible?: boolean;\n  cssClass?: string;\n  cssLabelClass?: string;\n  labelPositionClass?: string;\n  isFloatLabel?: boolean;\n  style?: Style;\n  labelStyle?: Style;\n  fileFormats?: string[];\n  maxSizeMb?: number;\n  i18n?: any;\n  multiFileUploaderProperties?: MultiFileUploaderProperties;\n  toolbarId?: string;\n}\n\nexport interface SmartImage {\n  type: SmartFormWidgetType.IMAGE;\n  key: string;\n  valueChangeMode?: ValueChangeMode;\n  label: string;\n  originalLabel?: string;\n  showLabel?: boolean;\n  isVisible?: boolean;\n  cssClass?: string;\n  cssLabelClass?: string;\n  labelPositionClass?: string;\n  isFloatLabel?: boolean;\n  style?: Style;\n  labelStyle?: Style;\n  value?: ImageResource;\n  imageCss?: string;\n  imageProperties?: ImageProperties;\n}\n\nexport interface SmartDivider {\n  type: SmartFormWidgetType.DIVIDER;\n  key: string;\n  valueChangeMode?: ValueChangeMode;\n  label: string;\n  originalLabel?: string;\n  showLabel?: boolean;\n  isVisible?: boolean;\n  cssClass?: string;\n  cssLabelClass?: string;\n  labelPositionClass?: string;\n  isFloatLabel?: boolean;\n  style?: Style;\n  labelStyle?: Style;\n  value?: string;\n}\n\nexport interface SmartButton {\n  type: SmartFormWidgetType.BUTTON;\n  key: string;\n  valueChangeMode?: ValueChangeMode;\n  label: string;\n  originalLabel?: string;\n  showLabel?: boolean;\n  isVisible?: boolean;\n  cssClass?: string;\n  cssLabelClass?: string;\n  labelPositionClass?: string;\n  isFloatLabel?: boolean;\n  style?: Style;\n  labelStyle?: Style;\n  value?: string;\n  uiAction?: any;\n  uiActionDescriptor: any;\n  callback: ((uiAction: any) => void) | ((key: string) => void);\n}\nexport interface SmartFormInlineComponent {\n  type: SmartFormWidgetType.COMPONENT;\n  key: string;\n  valueChangeMode?: ValueChangeMode;\n  label: string;\n  originalLabel?: string;\n  showLabel?: boolean;\n  isVisible?: boolean;\n  cssClass?: string;\n  cssLabelClass?: string;\n  labelPositionClass?: string;\n  isFloatLabel?: boolean;\n  style?: Style;\n  labelStyle?: Style;\n  component: any;\n  input: Map<string, any>;\n}\n\nexport interface SmartRichText {\n  type: SmartFormWidgetType.RICH_TEXT;\n  key: string;\n  valueChangeMode?: ValueChangeMode;\n  label: string;\n  value?: string;\n  originalLabel?: string;\n  placeholder?: string;\n  originalPlaceholder?: string;\n  quillModules: QuillModules;\n  showLabel?: boolean;\n  isVisible?: boolean;\n  cssClass?: string;\n  cssLabelClass?: string;\n  labelPositionClass?: string;\n  isFloatLabel?: boolean;\n  style?: Style;\n  labelStyle?: Style;\n  isDisabled?: boolean;\n  isReadonly?: boolean;\n  validators?: SmartValidator[];\n  error?: string;\n  errorIcon?: string;\n  errorIconColor?: string;\n  serverErrorMessage?: string;\n  serverErrorIcon?: string;\n  serverErrorColor?: string;\n  hint?: SmartWidgetHint;\n  maxLength?: number;\n  showCharacterLimitSuffix?: boolean;\n}\n\nexport interface SmartSortable<T> {\n  type: SmartFormWidgetType.SORTABLE;\n  key: string;\n  valueChangeMode?: ValueChangeMode;\n  label: string;\n  value?: string;\n  originalLabel?: string;\n  showLabel?: boolean;\n  isVisible?: boolean;\n  cssClass?: string;\n  cssLabelClass?: string;\n  labelPositionClass?: string;\n  isFloatLabel?: boolean;\n  style?: Style;\n  labelStyle?: Style;\n  isDisabled?: boolean;\n  isReadonly?: boolean;\n  error?: string;\n  errorIcon?: string;\n  errorIconColor?: string;\n  serverErrorMessage?: string;\n  serverErrorIcon?: string;\n  serverErrorColor?: string;\n  validators?: SmartValidator[];\n  valueList?: SmartItem<T>[];\n  isMultiple?: boolean;\n  hint?: SmartWidgetHint;\n  icon?: string;\n  sortDefinition: SortDefinition;\n}\n\nexport interface SmartMatrix {\n  type: SmartFormWidgetType.MATRIX;\n  key: string;\n  valueChangeMode?: ValueChangeMode;\n  label: string;\n  value?: any;\n  originalLabel?: string;\n  showLabel?: boolean;\n  isVisible?: boolean;\n  cssClass?: string;\n  cssLabelClass?: string;\n  labelPositionClass?: string;\n  isFloatLabel?: boolean;\n  style?: Style;\n  labelStyle?: Style;\n  isDisabled?: boolean;\n  isReadonly?: boolean;\n  error?: string;\n  errorIcon?: string;\n  errorIconColor?: string;\n  serverErrorMessage?: string;\n  serverErrorIcon?: string;\n  serverErrorColor?: string;\n  validators?: SmartValidator[];\n  isMultiple?: boolean;\n  hint?: SmartWidgetHint;\n  button?: SmartMatrixButton;\n}\n\nexport interface SmartMatrixButton {\n  iconCode?: string;\n  callback: (widget: SmartFormWidget<any>, row: any) => any;\n  color?: string;\n}\n\nexport interface SmartYoutubePlayer {\n  key?: string;\n  valueChangeMode?: ValueChangeMode;\n  type: SmartFormWidgetType.YOUTUBE_PLAYER;\n  link?: string;\n  videoId?: string;\n  height?: number;\n  width?: number;\n  startSeconds?: number | 0;\n  endSeconds?: number;\n  cssClass?: string;\n  cssLabelClass?: string;\n  labelPositionClass?: string;\n  isFloatLabel?: boolean;\n  style?: Style;\n  labelStyle?: Style;\n  isVisible?: boolean;\n  label?: string;\n  validators?: SmartValidator[];\n  hint?: SmartWidgetHint;\n  showLabel?: boolean;\n}\n\nexport interface SmartMonthPicker {\n  key: string;\n  valueChangeMode?: ValueChangeMode;\n  type: SmartFormWidgetType.MONTH_PICKER;\n  value?: string;\n  validators?: SmartValidator[];\n  label: string;\n  showLabel?: boolean;\n  error?: string;\n  errorIcon?: string;\n  errorIconColor?: string;\n  serverErrorMessage?: string;\n  serverErrorIcon?: string;\n  serverErrorColor?: string;\n  cssClass?: string;\n  cssLabelClass?: string;\n  labelPositionClass?: string;\n  isFloatLabel?: boolean;\n  style?: Style;\n  labelStyle?: Style;\n  isVisible?: boolean;\n  isDisabled?: boolean;\n  originalLabel?: string;\n  hint?: SmartWidgetHint;\n}\nexport interface SmartSvg {\n  type: SmartFormWidgetType.SVG;\n  key: string;\n  valueChangeMode?: ValueChangeMode;\n  label: string;\n  originalLabel?: string;\n  showLabel?: boolean;\n  isVisible?: boolean;\n  cssClass?: string;\n  cssLabelClass?: string;\n  labelPositionClass?: string;\n  isFloatLabel?: boolean;\n  style?: Style;\n  labelStyle?: Style;\n  value?: string;\n  minWidth?: SmartFormWidgetWidth | number;\n}\n"]}
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"smartform.form-model.js","sourceRoot":"","sources":["../../../../../projects/smart-ng-client/src/lib/smart-form/smartform.form-model.ts"],"names":[],"mappings":"","sourcesContent":["import { QuillModules } from 'ngx-quill';\r\nimport {\r\n  DateFieldProperties,\r\n  FileUploaderProperties,\r\n  MultiFileUploaderProperties,\r\n  ImageProperties,\r\n  SelectionDefinition,\r\n  SmartFormInputMode,\r\n  SmartFormWidgetDirection,\r\n  SmartFormWidgetType,\r\n  SmartWidgetHint,\r\n  SortDefinition,\r\n  TextFieldProperties,\r\n  ValueChangeMode,\r\n} from './api';\r\nimport {\r\n  SmartFormTextFieldButton,\r\n  SmartFormWidgetWidth,\r\n  SmartIndicator,\r\n  SmartValidator,\r\n  ToggleLabelPosition,\r\n} from './smartform.model';\r\nimport { ImageResource, Style } from '../view-context/api';\r\n\r\nexport declare type SmartFormWidget<T> =\r\n  | SmartTextField<T>\r\n  | SmartTextFieldNumber<T>\r\n  | SmartTextFieldChips<T>\r\n  | SmartTextFieldLookup<T>\r\n  | SmartTextBox<T>\r\n  | SmartSelect<T>\r\n  | SmartSelectMultiple<T>\r\n  | SmartCheckBox<T>\r\n  | SmartCheckBox2<T>\r\n  | SmartRadioButton<T>\r\n  | SmartDatePicker<T>\r\n  | SmartDateTimePicker<T>\r\n  | SmartContainer<T>\r\n  | SmartLabel\r\n  | SmartTime<T>\r\n  | SmartToggle<T>\r\n  | SmartIndicatorItem\r\n  | SmartFileUploader\r\n  | SmartMultiFileUploader\r\n  | SmartImage\r\n  | SmartDivider\r\n  | SmartButton\r\n  | SmartFormInlineComponent\r\n  | SmartRichText\r\n  | SmartSortable<T>\r\n  | SmartMatrix\r\n  | SmartYoutubePlayer\r\n  | SmartMonthPicker\r\n  | SmartSvg;\r\n\r\nexport interface SmartTextField<T> {\r\n  type: SmartFormWidgetType.TEXT_FIELD;\r\n  key: string;\r\n  valueChangeMode?: ValueChangeMode;\r\n  label: string;\r\n  originalLabel?: string;\r\n  showLabel?: boolean;\r\n  value?: T;\r\n  placeholder?: string;\r\n  originalPlaceholder?: string;\r\n  minWidth?: SmartFormWidgetWidth | number | number;\r\n  isDisabled?: boolean;\r\n  isReadonly?: boolean;\r\n  prefix?: string;\r\n  suffix?: string;\r\n  validators?: SmartValidator[];\r\n  cssClass?: string;\r\n  cssLabelClass?: string;\r\n  labelPositionClass?: string;\r\n  isFloatLabel?: boolean;\r\n  style?: Style;\r\n  labelStyle?: Style;\r\n  isPassword?: boolean;\r\n  textFieldButton?: SmartFormTextFieldButton;\r\n  capsLockWarning?: string;\r\n  capsLockWarningIcon?: string;\r\n  isVisible?: boolean;\r\n  mask?: string;\r\n  error?: string;\r\n  icon?: string;\r\n  iconColor?: string;\r\n  iconPosition?: 'PRE' | 'POST';\r\n  errorIcon?: string;\r\n  errorIconColor?: string;\r\n  serverErrorMessage?: string;\r\n  serverErrorIcon?: string;\r\n  serverErrorColor?: string;\r\n  valueList?: SmartItem<T>[];\r\n  selection?: SelectionDefinition;\r\n  filterErrorMessage?: string;\r\n  hint?: SmartWidgetHint;\r\n  maxLength?: number;\r\n  showCharacterLimitSuffix?: boolean;\r\n  toolbarId?: string;\r\n  inputMode?: SmartFormInputMode;\r\n  textFieldProperties?: TextFieldProperties;\r\n}\r\n\r\nexport interface SmartTextFieldNumber<T> {\r\n  type: SmartFormWidgetType.TEXT_FIELD_NUMBER;\r\n  key: string;\r\n  valueChangeMode?: ValueChangeMode;\r\n  label: string;\r\n  originalLabel?: string;\r\n  showLabel?: boolean;\r\n  value?: T;\r\n  placeholder?: string;\r\n  originalPlaceholder?: string;\r\n  minWidth?: SmartFormWidgetWidth | number | number;\r\n  isDisabled?: boolean;\r\n  isReadonly?: boolean;\r\n  prefix?: string;\r\n  suffix?: string;\r\n  validators?: SmartValidator[];\r\n  cssClass?: string;\r\n  cssLabelClass?: string;\r\n  labelPositionClass?: string;\r\n  isFloatLabel?: boolean;\r\n  style?: Style;\r\n  labelStyle?: Style;\r\n  textFieldButton?: SmartFormTextFieldButton;\r\n  isVisible?: boolean;\r\n  minValues?: number;\r\n  maxValues?: number;\r\n  error?: string;\r\n  icon?: string;\r\n  iconColor?: string;\r\n  errorIcon?: string;\r\n  errorIconColor?: string;\r\n  serverErrorMessage?: string;\r\n  serverErrorIcon?: string;\r\n  serverErrorColor?: string;\r\n  hint?: SmartWidgetHint;\r\n}\r\n\r\nexport interface SmartTextFieldChips<T> {\r\n  type: SmartFormWidgetType.TEXT_FIELD_CHIPS;\r\n  key: string;\r\n  valueChangeMode?: ValueChangeMode;\r\n  label: string;\r\n  originalLabel?: string;\r\n  showLabel?: boolean;\r\n  value?: T;\r\n  placeholder?: string;\r\n  originalPlaceholder?: string;\r\n  minWidth?: SmartFormWidgetWidth | number;\r\n  isDisabled?: boolean;\r\n  isReadonly?: boolean;\r\n  validators?: SmartValidator[];\r\n  cssClass?: string;\r\n  cssLabelClass?: string;\r\n  labelPositionClass?: string;\r\n  isFloatLabel?: boolean;\r\n  style?: Style;\r\n  labelStyle?: Style;\r\n  isVisible?: boolean;\r\n  error?: string;\r\n  errorIcon?: string;\r\n  errorIconColor?: string;\r\n  serverErrorMessage?: string;\r\n  serverErrorIcon?: string;\r\n  serverErrorColor?: string;\r\n  valueList: SmartItem<T>[];\r\n  minValues?: number;\r\n  maxValues?: number;\r\n  hint?: SmartWidgetHint;\r\n}\r\nexport interface SmartTextFieldLookup<T> {\r\n  type: SmartFormWidgetType.TEXT_FIELD_LOOKUP;\r\n  key: string;\r\n  valueChangeMode?: ValueChangeMode;\r\n  label: string;\r\n  originalLabel?: string;\r\n  showLabel?: boolean;\r\n  value?: T;\r\n  placeholder?: string;\r\n  originalPlaceholder?: string;\r\n  minWidth?: SmartFormWidgetWidth | number;\r\n  isDisabled?: boolean;\r\n  isReadonly?: boolean;\r\n  validators?: SmartValidator[];\r\n  cssClass?: string;\r\n  cssLabelClass?: string;\r\n  labelPositionClass?: string;\r\n  isFloatLabel?: boolean;\r\n  style?: Style;\r\n  labelStyle?: Style;\r\n  isVisible?: boolean;\r\n  error?: string;\r\n  errorIcon?: string;\r\n  errorIconColor?: string;\r\n  serverErrorMessage?: string;\r\n  serverErrorIcon?: string;\r\n  serverErrorColor?: string;\r\n  minValues?: number;\r\n  maxValues?: number;\r\n  hint?: SmartWidgetHint;\r\n  toolbarId?: string;\r\n}\r\nexport interface SmartTextBox<T> {\r\n  type: SmartFormWidgetType.TEXT_BOX;\r\n  key: string;\r\n  valueChangeMode?: ValueChangeMode;\r\n  label: string;\r\n  originalLabel?: string;\r\n  showLabel?: boolean;\r\n  value?: T;\r\n  placeholder?: string;\r\n  originalPlaceholder?: string;\r\n  minWidth?: SmartFormWidgetWidth | number;\r\n  isDisabled?: boolean;\r\n  isReadonly?: boolean;\r\n  validators?: SmartValidator[];\r\n  cssClass?: string;\r\n  cssLabelClass?: string;\r\n  labelPositionClass?: string;\r\n  isFloatLabel?: boolean;\r\n  style?: Style;\r\n  labelStyle?: Style;\r\n  isVisible?: boolean;\r\n  error?: string;\r\n  errorIcon?: string;\r\n  errorIconColor?: string;\r\n  serverErrorMessage?: string;\r\n  serverErrorIcon?: string;\r\n  serverErrorColor?: string;\r\n  hint?: SmartWidgetHint;\r\n  maxLength?: number;\r\n  showCharacterLimitSuffix?: boolean;\r\n}\r\nexport interface SmartSelect<T> {\r\n  type: SmartFormWidgetType.SELECT;\r\n  key: string;\r\n  valueChangeMode?: ValueChangeMode;\r\n  label: string;\r\n  originalLabel?: string;\r\n  showLabel?: boolean;\r\n  placeholder?: string;\r\n  value?: T;\r\n  minWidth?: SmartFormWidgetWidth | number;\r\n  isDisabled?: boolean;\r\n  isReadonly?: boolean;\r\n  validators?: SmartValidator[];\r\n  cssClass?: string;\r\n  cssLabelClass?: string;\r\n  labelPositionClass?: string;\r\n  isFloatLabel?: boolean;\r\n  style?: Style;\r\n  labelStyle?: Style;\r\n  isVisible?: boolean;\r\n  error?: string;\r\n  errorIcon?: string;\r\n  errorIconColor?: string;\r\n  serverErrorMessage?: string;\r\n  serverErrorIcon?: string;\r\n  serverErrorColor?: string;\r\n  valueList: SmartItems<T>[];\r\n  selection?: SelectionDefinition;\r\n  hint?: SmartWidgetHint;\r\n  compareWith?: (o1: any, o2: any) => boolean;\r\n}\r\nexport interface SmartSelectMultiple<T> {\r\n  type: SmartFormWidgetType.SELECT_MULTIPLE;\r\n  key: string;\r\n  valueChangeMode?: ValueChangeMode;\r\n  label: string;\r\n  originalLabel?: string;\r\n  showLabel?: boolean;\r\n  value?: T;\r\n  minWidth?: SmartFormWidgetWidth | number;\r\n  isDisabled?: boolean;\r\n  isReadonly?: boolean;\r\n  validators?: SmartValidator[];\r\n  cssClass?: string;\r\n  cssLabelClass?: string;\r\n  labelPositionClass?: string;\r\n  isFloatLabel?: boolean;\r\n  style?: Style;\r\n  labelStyle?: Style;\r\n  placeholder?: string;\r\n  isVisible?: boolean;\r\n  error?: string;\r\n  errorIcon?: string;\r\n  errorIconColor?: string;\r\n  serverErrorMessage?: string;\r\n  serverErrorIcon?: string;\r\n  serverErrorColor?: string;\r\n  valueList: SmartItems<T>[];\r\n  selection?: SelectionDefinition;\r\n  hint?: SmartWidgetHint;\r\n  compareWith?: (o1: any, o2: any) => boolean;\r\n}\r\nexport interface SmartCheckBox<T> {\r\n  type: SmartFormWidgetType.CHECK_BOX;\r\n  key: string;\r\n  valueChangeMode?: ValueChangeMode;\r\n  label: string;\r\n  originalLabel?: string;\r\n  showLabel?: boolean;\r\n  value?: T;\r\n  minWidth?: SmartFormWidgetWidth | number;\r\n  isDisabled?: boolean;\r\n  isReadonly?: boolean;\r\n  validators?: SmartValidator[];\r\n  cssClass?: string;\r\n  cssLabelClass?: string;\r\n  labelPositionClass?: string;\r\n  isFloatLabel?: boolean;\r\n  style?: Style;\r\n  labelStyle?: Style;\r\n  isVisible?: boolean;\r\n  error?: string;\r\n  errorIcon?: string;\r\n  errorIconColor?: string;\r\n  serverErrorMessage?: string;\r\n  serverErrorIcon?: string;\r\n  serverErrorColor?: string;\r\n  selection?: SelectionDefinition;\r\n  direction?: SmartFormWidgetDirection;\r\n  hint?: SmartWidgetHint;\r\n}\r\nexport interface SmartCheckBox2<T> {\r\n  type: SmartFormWidgetType.CHECK_BOX_2;\r\n  key: string;\r\n  valueChangeMode?: ValueChangeMode;\r\n  label: string;\r\n  originalLabel?: string;\r\n  showLabel?: boolean;\r\n  value?: T;\r\n  minWidth?: SmartFormWidgetWidth | number;\r\n  isDisabled?: boolean;\r\n  isReadonly?: boolean;\r\n  validators?: SmartValidator[];\r\n  cssClass?: string;\r\n  cssLabelClass?: string;\r\n  labelPositionClass?: string;\r\n  isFloatLabel?: boolean;\r\n  style?: Style;\r\n  labelStyle?: Style;\r\n  isVisible?: boolean;\r\n  error?: string;\r\n  errorIcon?: string;\r\n  errorIconColor?: string;\r\n  serverErrorMessage?: string;\r\n  serverErrorIcon?: string;\r\n  serverErrorColor?: string;\r\n  valueList: SmartItem<T>[];\r\n  selection?: SelectionDefinition;\r\n  direction?: SmartFormWidgetDirection;\r\n  hint?: SmartWidgetHint;\r\n}\r\nexport interface SmartRadioButton<T> {\r\n  type: SmartFormWidgetType.RADIO_BUTTON;\r\n  key: string;\r\n  valueChangeMode?: ValueChangeMode;\r\n  label: string;\r\n  originalLabel?: string;\r\n  showLabel?: boolean;\r\n  value?: T;\r\n  minWidth?: SmartFormWidgetWidth | number;\r\n  isDisabled?: boolean;\r\n  isReadonly?: boolean;\r\n  validators?: SmartValidator[];\r\n  cssClass?: string;\r\n  cssLabelClass?: string;\r\n  labelPositionClass?: string;\r\n  isFloatLabel?: boolean;\r\n  style?: Style;\r\n  labelStyle?: Style;\r\n  isVisible?: boolean;\r\n  error?: string;\r\n  errorIcon?: string;\r\n  errorIconColor?: string;\r\n  serverErrorMessage?: string;\r\n  serverErrorIcon?: string;\r\n  serverErrorColor?: string;\r\n  valueList: SmartItem<T>[];\r\n  selection?: SelectionDefinition;\r\n  direction?: SmartFormWidgetDirection;\r\n  hint?: SmartWidgetHint;\r\n}\r\nexport interface SmartDatePicker<T> {\r\n  type: SmartFormWidgetType.DATE_PICKER;\r\n  key: string;\r\n  valueChangeMode?: ValueChangeMode;\r\n  label: string;\r\n  originalLabel?: string;\r\n  showLabel?: boolean;\r\n  value?: T;\r\n  placeholder?: string;\r\n  minWidth?: SmartFormWidgetWidth | number;\r\n  isDisabled?: boolean;\r\n  isReadonly?: boolean;\r\n  validators?: SmartValidator[];\r\n  cssClass?: string;\r\n  cssLabelClass?: string;\r\n  labelPositionClass?: string;\r\n  isFloatLabel?: boolean;\r\n  style?: Style;\r\n  labelStyle?: Style;\r\n  isVisible?: boolean;\r\n  error?: string;\r\n  errorIcon?: string;\r\n  errorIconColor?: string;\r\n  serverErrorMessage?: string;\r\n  serverErrorIcon?: string;\r\n  serverErrorColor?: string;\r\n  dateFormatHint?: string;\r\n  dateFieldProperties?: DateFieldProperties;\r\n  filter?: (d: Date | null) => boolean;\r\n  hint?: SmartWidgetHint;\r\n}\r\nexport interface SmartDateTimePicker<T> {\r\n  type: SmartFormWidgetType.DATE_TIME_PICKER;\r\n  key: string;\r\n  valueChangeMode?: ValueChangeMode;\r\n  label: string;\r\n  originalLabel?: string;\r\n  showLabel?: boolean;\r\n  value?: T;\r\n  placeholder?: string;\r\n  minWidth?: SmartFormWidgetWidth | number;\r\n  isDisabled?: boolean;\r\n  isReadonly?: boolean;\r\n  validators?: SmartValidator[];\r\n  cssClass?: string;\r\n  cssLabelClass?: string;\r\n  labelPositionClass?: string;\r\n  isFloatLabel?: boolean;\r\n  style?: Style;\r\n  labelStyle?: Style;\r\n  isVisible?: boolean;\r\n  error?: string;\r\n  errorIcon?: string;\r\n  errorIconColor?: string;\r\n  serverErrorMessage?: string;\r\n  serverErrorIcon?: string;\r\n  serverErrorColor?: string;\r\n  dateFormatHint?: string;\r\n  dateFieldProperties?: DateFieldProperties;\r\n  filter?: (d: Date | null) => boolean;\r\n  hint?: SmartWidgetHint;\r\n}\r\nexport interface SmartContainer<T> {\r\n  key?: string;\r\n  valueChangeMode?: ValueChangeMode;\r\n  type: SmartFormWidgetType.CONTAINER;\r\n  isVisible?: boolean;\r\n  valueList: SmartFormWidget<T>[];\r\n  direction?: SmartFormWidgetDirection;\r\n  cssClass?: string;\r\n  style?: Style;\r\n}\r\nexport interface SmartLabel {\r\n  key?: string;\r\n  valueChangeMode?: ValueChangeMode;\r\n  type: SmartFormWidgetType.LABEL;\r\n  isVisible?: boolean;\r\n  cssClass?: string;\r\n  style?: Style;\r\n  labelStyle?: Style;\r\n  label: string;\r\n  originalLabel?: string;\r\n  widgetDescription?: string;\r\n  minWidth?: SmartFormWidgetWidth | number;\r\n  markAsRequired?: boolean;\r\n}\r\nexport interface SmartTime<T> {\r\n  type: SmartFormWidgetType.TIME;\r\n  key: string;\r\n  valueChangeMode?: ValueChangeMode;\r\n  value?: T;\r\n  placeholder?: string;\r\n  label: string;\r\n  originalLabel?: string;\r\n  showLabel?: boolean;\r\n  minWidth?: SmartFormWidgetWidth | number;\r\n  isVisible?: boolean;\r\n  cssClass?: string;\r\n  cssLabelClass?: string;\r\n  labelPositionClass?: string;\r\n  isFloatLabel?: boolean;\r\n  style?: Style;\r\n  labelStyle?: Style;\r\n  isDisabled?: boolean;\r\n  isReadonly?: boolean;\r\n  validators?: SmartValidator[];\r\n  error?: string;\r\n  errorIcon?: string;\r\n  errorIconColor?: string;\r\n  serverErrorMessage?: string;\r\n  serverErrorIcon?: string;\r\n  serverErrorColor?: string;\r\n  hint?: SmartWidgetHint;\r\n}\r\nexport interface SmartToggle<T> {\r\n  type: SmartFormWidgetType.TOGGLE;\r\n  key: string;\r\n  valueChangeMode?: ValueChangeMode;\r\n  value?: T;\r\n  placeholder?: string;\r\n  label: string;\r\n  originalLabel?: string;\r\n  showLabel?: boolean;\r\n  isVisible?: boolean;\r\n  cssClass?: string;\r\n  cssLabelClass?: string;\r\n  labelPositionClass?: string;\r\n  isFloatLabel?: boolean;\r\n  style?: Style;\r\n  labelStyle?: Style;\r\n  isDisabled?: boolean;\r\n  isReadonly?: boolean;\r\n  toggleLabelPosition?: ToggleLabelPosition;\r\n  validators?: SmartValidator[];\r\n  error?: string;\r\n  errorIcon?: string;\r\n  errorIconColor?: string;\r\n  serverErrorMessage?: string;\r\n  serverErrorIcon?: string;\r\n  serverErrorColor?: string;\r\n  hint?: SmartWidgetHint;\r\n}\r\nexport interface SmartIndicatorItem {\r\n  type: SmartFormWidgetType.INDICATOR;\r\n  key: string;\r\n  valueChangeMode?: ValueChangeMode;\r\n  label: string;\r\n  originalLabel?: string;\r\n  showLabel?: boolean;\r\n  indicator: SmartIndicator;\r\n  isVisible?: boolean;\r\n  cssClass?: string;\r\n  cssLabelClass?: string;\r\n  labelPositionClass?: string;\r\n  isFloatLabel?: boolean;\r\n  style?: Style;\r\n  labelStyle?: Style;\r\n}\r\n\r\nexport declare type SmartItems<T> = SmartItem<T> | SmartItemGroup<T>;\r\n\r\nexport interface SmartItem<T> {\r\n  type: SmartFormWidgetType.ITEM;\r\n  key: string;\r\n  valueChangeMode?: ValueChangeMode;\r\n  label: string;\r\n  cssLabelClass?: string;\r\n  labelPositionClass?: string;\r\n  isFloatLabel?: boolean;\r\n  style?: Style;\r\n  labelStyle?: Style;\r\n  originalLabel?: string;\r\n  value?: T;\r\n  isDisabled?: boolean;\r\n  icon?: string;\r\n  iconColor?: string;\r\n  imageUrl?: string;\r\n}\r\nexport interface SmartItemGroup<T> {\r\n  type: SmartFormWidgetType.ITEM_GROUP;\r\n  key: string;\r\n  valueChangeMode?: ValueChangeMode;\r\n  label: string;\r\n  cssLabelClass?: string;\r\n  labelPositionClass?: string;\r\n  isFloatLabel?: boolean;\r\n  style?: Style;\r\n  labelStyle?: Style;\r\n  originalLabel?: string;\r\n  isDisabled?: boolean;\r\n  valueList: SmartItem<T>[];\r\n}\r\n\r\nexport interface SmartFileUploader {\r\n  type: SmartFormWidgetType.FILE_UPLOADER;\r\n  value?: any;\r\n  key: string;\r\n  valueChangeMode?: ValueChangeMode;\r\n  label: string;\r\n  isDisabled?: boolean;\r\n  validators?: SmartValidator[];\r\n  originalLabel?: string;\r\n  showLabel?: boolean;\r\n  isVisible?: boolean;\r\n  cssClass?: string;\r\n  cssLabelClass?: string;\r\n  labelPositionClass?: string;\r\n  isFloatLabel?: boolean;\r\n  style?: Style;\r\n  labelStyle?: Style;\r\n  fileFormats?: string[];\r\n  maxSizeMb?: number;\r\n  i18n?: any;\r\n  fileUploaderProperties?: FileUploaderProperties;\r\n  toolbarId?: string;\r\n}\r\n\r\nexport interface SmartMultiFileUploader {\r\n  type: SmartFormWidgetType.MULTI_FILE_UPLOADER;\r\n  value?: any;\r\n  key: string;\r\n  valueChangeMode?: ValueChangeMode;\r\n  label: string;\r\n  isDisabled?: boolean;\r\n  validators?: SmartValidator[];\r\n  originalLabel?: string;\r\n  showLabel?: boolean;\r\n  isVisible?: boolean;\r\n  cssClass?: string;\r\n  cssLabelClass?: string;\r\n  labelPositionClass?: string;\r\n  isFloatLabel?: boolean;\r\n  style?: Style;\r\n  labelStyle?: Style;\r\n  fileFormats?: string[];\r\n  maxSizeMb?: number;\r\n  i18n?: any;\r\n  multiFileUploaderProperties?: MultiFileUploaderProperties;\r\n  toolbarId?: string;\r\n}\r\n\r\nexport interface SmartImage {\r\n  type: SmartFormWidgetType.IMAGE;\r\n  key: string;\r\n  valueChangeMode?: ValueChangeMode;\r\n  label: string;\r\n  originalLabel?: string;\r\n  showLabel?: boolean;\r\n  isVisible?: boolean;\r\n  cssClass?: string;\r\n  cssLabelClass?: string;\r\n  labelPositionClass?: string;\r\n  isFloatLabel?: boolean;\r\n  style?: Style;\r\n  labelStyle?: Style;\r\n  value?: ImageResource;\r\n  imageCss?: string;\r\n  imageProperties?: ImageProperties;\r\n}\r\n\r\nexport interface SmartDivider {\r\n  type: SmartFormWidgetType.DIVIDER;\r\n  key: string;\r\n  valueChangeMode?: ValueChangeMode;\r\n  label: string;\r\n  originalLabel?: string;\r\n  showLabel?: boolean;\r\n  isVisible?: boolean;\r\n  cssClass?: string;\r\n  cssLabelClass?: string;\r\n  labelPositionClass?: string;\r\n  isFloatLabel?: boolean;\r\n  style?: Style;\r\n  labelStyle?: Style;\r\n  value?: string;\r\n}\r\n\r\nexport interface SmartButton {\r\n  type: SmartFormWidgetType.BUTTON;\r\n  key: string;\r\n  valueChangeMode?: ValueChangeMode;\r\n  label: string;\r\n  originalLabel?: string;\r\n  showLabel?: boolean;\r\n  isVisible?: boolean;\r\n  cssClass?: string;\r\n  cssLabelClass?: string;\r\n  labelPositionClass?: string;\r\n  isFloatLabel?: boolean;\r\n  style?: Style;\r\n  labelStyle?: Style;\r\n  value?: string;\r\n  uiAction?: any;\r\n  uiActionDescriptor: any;\r\n  callback: ((uiAction: any) => void) | ((key: string) => void);\r\n}\r\nexport interface SmartFormInlineComponent {\r\n  type: SmartFormWidgetType.COMPONENT;\r\n  key: string;\r\n  valueChangeMode?: ValueChangeMode;\r\n  label: string;\r\n  originalLabel?: string;\r\n  showLabel?: boolean;\r\n  isVisible?: boolean;\r\n  cssClass?: string;\r\n  cssLabelClass?: string;\r\n  labelPositionClass?: string;\r\n  isFloatLabel?: boolean;\r\n  style?: Style;\r\n  labelStyle?: Style;\r\n  component: any;\r\n  input: Map<string, any>;\r\n}\r\n\r\nexport interface SmartRichText {\r\n  type: SmartFormWidgetType.RICH_TEXT;\r\n  key: string;\r\n  valueChangeMode?: ValueChangeMode;\r\n  label: string;\r\n  value?: string;\r\n  originalLabel?: string;\r\n  placeholder?: string;\r\n  originalPlaceholder?: string;\r\n  quillModules: QuillModules;\r\n  showLabel?: boolean;\r\n  isVisible?: boolean;\r\n  cssClass?: string;\r\n  cssLabelClass?: string;\r\n  labelPositionClass?: string;\r\n  isFloatLabel?: boolean;\r\n  style?: Style;\r\n  labelStyle?: Style;\r\n  isDisabled?: boolean;\r\n  isReadonly?: boolean;\r\n  validators?: SmartValidator[];\r\n  error?: string;\r\n  errorIcon?: string;\r\n  errorIconColor?: string;\r\n  serverErrorMessage?: string;\r\n  serverErrorIcon?: string;\r\n  serverErrorColor?: string;\r\n  hint?: SmartWidgetHint;\r\n  maxLength?: number;\r\n  showCharacterLimitSuffix?: boolean;\r\n}\r\n\r\nexport interface SmartSortable<T> {\r\n  type: SmartFormWidgetType.SORTABLE;\r\n  key: string;\r\n  valueChangeMode?: ValueChangeMode;\r\n  label: string;\r\n  value?: string;\r\n  originalLabel?: string;\r\n  showLabel?: boolean;\r\n  isVisible?: boolean;\r\n  cssClass?: string;\r\n  cssLabelClass?: string;\r\n  labelPositionClass?: string;\r\n  isFloatLabel?: boolean;\r\n  style?: Style;\r\n  labelStyle?: Style;\r\n  isDisabled?: boolean;\r\n  isReadonly?: boolean;\r\n  error?: string;\r\n  errorIcon?: string;\r\n  errorIconColor?: string;\r\n  serverErrorMessage?: string;\r\n  serverErrorIcon?: string;\r\n  serverErrorColor?: string;\r\n  validators?: SmartValidator[];\r\n  valueList?: SmartItem<T>[];\r\n  isMultiple?: boolean;\r\n  hint?: SmartWidgetHint;\r\n  icon?: string;\r\n  sortDefinition: SortDefinition;\r\n}\r\n\r\nexport interface SmartMatrix {\r\n  type: SmartFormWidgetType.MATRIX;\r\n  key: string;\r\n  valueChangeMode?: ValueChangeMode;\r\n  label: string;\r\n  value?: any;\r\n  originalLabel?: string;\r\n  showLabel?: boolean;\r\n  isVisible?: boolean;\r\n  cssClass?: string;\r\n  cssLabelClass?: string;\r\n  labelPositionClass?: string;\r\n  isFloatLabel?: boolean;\r\n  style?: Style;\r\n  labelStyle?: Style;\r\n  isDisabled?: boolean;\r\n  isReadonly?: boolean;\r\n  error?: string;\r\n  errorIcon?: string;\r\n  errorIconColor?: string;\r\n  serverErrorMessage?: string;\r\n  serverErrorIcon?: string;\r\n  serverErrorColor?: string;\r\n  validators?: SmartValidator[];\r\n  isMultiple?: boolean;\r\n  hint?: SmartWidgetHint;\r\n  button?: SmartMatrixButton;\r\n}\r\n\r\nexport interface SmartMatrixButton {\r\n  iconCode?: string;\r\n  callback: (widget: SmartFormWidget<any>, row: any) => any;\r\n  color?: string;\r\n}\r\n\r\nexport interface SmartYoutubePlayer {\r\n  key?: string;\r\n  valueChangeMode?: ValueChangeMode;\r\n  type: SmartFormWidgetType.YOUTUBE_PLAYER;\r\n  link?: string;\r\n  videoId?: string;\r\n  height?: number;\r\n  width?: number;\r\n  startSeconds?: number | 0;\r\n  endSeconds?: number;\r\n  cssClass?: string;\r\n  cssLabelClass?: string;\r\n  labelPositionClass?: string;\r\n  isFloatLabel?: boolean;\r\n  style?: Style;\r\n  labelStyle?: Style;\r\n  isVisible?: boolean;\r\n  label?: string;\r\n  validators?: SmartValidator[];\r\n  hint?: SmartWidgetHint;\r\n  showLabel?: boolean;\r\n}\r\n\r\nexport interface SmartMonthPicker {\r\n  key: string;\r\n  valueChangeMode?: ValueChangeMode;\r\n  type: SmartFormWidgetType.MONTH_PICKER;\r\n  value?: string;\r\n  validators?: SmartValidator[];\r\n  label: string;\r\n  showLabel?: boolean;\r\n  error?: string;\r\n  errorIcon?: string;\r\n  errorIconColor?: string;\r\n  serverErrorMessage?: string;\r\n  serverErrorIcon?: string;\r\n  serverErrorColor?: string;\r\n  cssClass?: string;\r\n  cssLabelClass?: string;\r\n  labelPositionClass?: string;\r\n  isFloatLabel?: boolean;\r\n  style?: Style;\r\n  labelStyle?: Style;\r\n  isVisible?: boolean;\r\n  isDisabled?: boolean;\r\n  originalLabel?: string;\r\n  hint?: SmartWidgetHint;\r\n}\r\nexport interface SmartSvg {\r\n  type: SmartFormWidgetType.SVG;\r\n  key: string;\r\n  valueChangeMode?: ValueChangeMode;\r\n  label: string;\r\n  originalLabel?: string;\r\n  showLabel?: boolean;\r\n  isVisible?: boolean;\r\n  cssClass?: string;\r\n  cssLabelClass?: string;\r\n  labelPositionClass?: string;\r\n  isFloatLabel?: boolean;\r\n  style?: Style;\r\n  labelStyle?: Style;\r\n  value?: string;\r\n  minWidth?: SmartFormWidgetWidth | number;\r\n}\r\n"]}
|
|
@@ -35,4 +35,4 @@ export var SmartWidgetHintPosition;
|
|
|
35
35
|
SmartWidgetHintPosition[SmartWidgetHintPosition["UNDER_LABEL"] = 0] = "UNDER_LABEL";
|
|
36
36
|
SmartWidgetHintPosition[SmartWidgetHintPosition["UNDER_INPUT"] = 1] = "UNDER_INPUT";
|
|
37
37
|
})(SmartWidgetHintPosition || (SmartWidgetHintPosition = {}));
|
|
38
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
38
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic21hcnRmb3JtLm1vZGVsLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvc21hcnQtbmctY2xpZW50L3NyYy9saWIvc21hcnQtZm9ybS9zbWFydGZvcm0ubW9kZWwudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBMkJBLE1BQU0sQ0FBTixJQUFZLG9CQUtYO0FBTEQsV0FBWSxvQkFBb0I7SUFDOUIsbUVBQVcsQ0FBQTtJQUNYLHFFQUFZLENBQUE7SUFDWixtRUFBVyxDQUFBO0lBQ1gsK0VBQWlCLENBQUE7QUFDbkIsQ0FBQyxFQUxXLG9CQUFvQixLQUFwQixvQkFBb0IsUUFLL0I7QUFFRCxNQUFNLENBQU4sSUFBWSxvQ0FHWDtBQUhELFdBQVksb0NBQW9DO0lBQzlDLDZGQUFHLENBQUE7SUFDSCwrRkFBSSxDQUFBO0FBQ04sQ0FBQyxFQUhXLG9DQUFvQyxLQUFwQyxvQ0FBb0MsUUFHL0M7QUFXRCxNQUFNLENBQU4sSUFBWSxtQkFHWDtBQUhELFdBQVksbUJBQW1CO0lBQzdCLHdDQUFpQixDQUFBO0lBQ2pCLHNDQUFlLENBQUE7QUFDakIsQ0FBQyxFQUhXLG1CQUFtQixLQUFuQixtQkFBbUIsUUFHOUI7QUEwQkQsTUFBTSxDQUFOLElBQVksa0JBYVg7QUFiRCxXQUFZLGtCQUFrQjtJQUM1QixxQkFBcUI7SUFDckIsMkNBQXFCLENBQUE7SUFDckIsK0NBQXlCLENBQUE7SUFDekIscUNBQWUsQ0FBQTtJQUNmLGlDQUFXLENBQUE7SUFDWCw2Q0FBdUIsQ0FBQTtJQUN2QixpQ0FBVyxDQUFBO0lBQ1gsNkNBQXVCLENBQUE7SUFDdkIseUNBQW1CLENBQUE7SUFDbkIsNkRBQXVDLENBQUE7SUFDdkMsb0JBQW9CO0lBQ3BCLDREQUFzQyxDQUFBO0FBQ3hDLENBQUMsRUFiVyxrQkFBa0IsS0FBbEIsa0JBQWtCLFFBYTdCO0FBNENELE1BQU0sQ0FBTixJQUFZLHVCQUdYO0FBSEQsV0FBWSx1QkFBdUI7SUFDakMsbUZBQVcsQ0FBQTtJQUNYLG1GQUFXLENBQUE7QUFDYixDQUFDLEVBSFcsdUJBQXVCLEtBQXZCLHVCQUF1QixRQUdsQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFZhbGlkYXRvckZuIH0gZnJvbSBcIkBhbmd1bGFyL2Zvcm1zXCI7XHJcbmltcG9ydCB7IFNtYXJ0Rm9ybVdpZGdldCB9IGZyb20gXCIuL3NtYXJ0Zm9ybS5mb3JtLW1vZGVsXCI7XHJcbmltcG9ydCB7IFNtYXJ0Rm9ybVdpZGdldERpcmVjdGlvbiB9IGZyb20gXCIuL2FwaVwiO1xyXG5pbXBvcnQgeyBTbWFydFRyYW5zbGF0ZVNlcnZpY2UgfSBmcm9tIFwiLi4vdmlldy1jb250ZXh0L3NtYXJ0LXZpZXctY29udGV4dC5tb2RlbFwiO1xyXG5pbXBvcnQgeyBOYW1lZFZhbGlkYXRvciB9IGZyb20gXCIuLi92aWV3LWNvbnRleHQvYXBpXCI7XHJcblxyXG5leHBvcnQgaW50ZXJmYWNlIFNvcGhpc3RpY2F0ZWRWYWx1ZUNoYW5nZSB7XHJcbiAga2V5OiBzdHJpbmc7XHJcbiAgdmFsdWU6IGFueTtcclxuICBraW5kOiBcImJhc2ljXCIgfCBcInNlbGVjdGlvblwiO1xyXG59XHJcblxyXG5leHBvcnQgaW50ZXJmYWNlIFNtYXJ0Rm9ybUNvbXBvbmVudENvbnN0cmFpbnQge1xyXG4gIC8qKlxyXG4gICAqIFRoZSBkYXRhIG5hbWUgdG8gaWRlbnRpZnkgdGhlIHJlbGF0ZWQgY29tcG9uZW50IG9yIGNvbXBvbmVuZXRzLiBJZiBpdCBpcyBhIHBhdGggdGhlIGZvcm1hdCBpcyB0aGUgZm9sbG93aW5nIC0gZGF0YVNoZWV0LmZpZWxkLlxyXG4gICAqL1xyXG4gIGRhdGFOYW1lPzogc3RyaW5nO1xyXG4gIHZpc2libGU/OiBib29sZWFuO1xyXG4gIG1hbmRhdG9yeT86IGJvb2xlYW47XHJcbiAgZW5hYmxlZD86IGJvb2xlYW47XHJcbiAgbWF4PzogbnVtYmVyO1xyXG4gIG1heExlbmd0aD86IG51bWJlcjtcclxuICBtaW4/OiBudW1iZXI7XHJcbiAgbWluTGVuZ3RoPzogbnVtYmVyO1xyXG4gIG5hbWVkVmFsaWRhdG9ycz86IEFycmF5PE5hbWVkVmFsaWRhdG9yPjtcclxufVxyXG5cclxuZXhwb3J0IGVudW0gU21hcnRGb3JtV2lkZ2V0V2lkdGgge1xyXG4gIFNNQUxMID0gMTUwLFxyXG4gIE1FRElVTSA9IDI1MCxcclxuICBMQVJHRSA9IDM1MCxcclxuICBFWFRSQV9MQVJHRSA9IDQ1MCxcclxufVxyXG5cclxuZXhwb3J0IGVudW0gU21hcnRGb3JtVGV4dEZpZWxkQnV0dG9uSWNvblBvc2l0aW9uIHtcclxuICBQUkUsXHJcbiAgUE9TVCxcclxufVxyXG5cclxuZXhwb3J0IGludGVyZmFjZSBTbWFydEZvcm1UZXh0RmllbGRCdXR0b24ge1xyXG4gIGljb24/OiBzdHJpbmc7XHJcbiAgaWNvblBvc2l0aW9uPzogU21hcnRGb3JtVGV4dEZpZWxkQnV0dG9uSWNvblBvc2l0aW9uO1xyXG4gIGxhYmVsPzogc3RyaW5nO1xyXG4gIGNhbGxiYWNrOiAod2lkZ2V0OiBTbWFydEZvcm1XaWRnZXQ8YW55PikgPT4gYW55O1xyXG4gIGNvbG9yPzogc3RyaW5nO1xyXG4gIGljb25Db2xvcj86IHN0cmluZztcclxufVxyXG5cclxuZXhwb3J0IGVudW0gVG9nZ2xlTGFiZWxQb3NpdGlvbiB7XHJcbiAgQkVGT1JFID0gXCJiZWZvcmVcIixcclxuICBBRlRFUiA9IFwiYWZ0ZXJcIixcclxufVxyXG5cclxuZXhwb3J0IGludGVyZmFjZSBTbWFydEZvcm1JbnZhbGlkRmllbGRzIHtcclxuICBpbnZhbGlkRmllbGROYW1lczogc3RyaW5nW107XHJcbiAgaW52YWxpZEZpZWxkS2V5czogc3RyaW5nW107XHJcbn1cclxuXHJcbmV4cG9ydCBpbnRlcmZhY2UgU21hcnRJbmRpY2F0b3Ige1xyXG4gIGluZGljYXRlUHJvcGVydHk6IHN0cmluZztcclxuICBpbmRpY2F0b3JMZW5ndGg6IG51bWJlcjtcclxuICBpbmRpY2F0b3JTdGF0dXNMYWJlbHM6IHN0cmluZ1tdO1xyXG4gIG9yaWdpbmFsSW5kaWNhdG9yU3RhdHVzTGFiZWxzPzogc3RyaW5nW107XHJcbiAgaW5kaWNhdG9yVmFsdWU6IG51bWJlcjtcclxuICBjaGFuZ2VJbmRpY2F0b3JTdGF0dXM6ICh2YWx1ZVRvQ2hlY2s6IHN0cmluZykgPT4gbnVtYmVyO1xyXG59XHJcblxyXG5leHBvcnQgaW50ZXJmYWNlIFNtYXJ0VmFsaWRhdG9yIHtcclxuICB2YWxpZGF0b3I6IFZhbGlkYXRvckZuO1xyXG4gIGlzQ3VzdG9tPzogYm9vbGVhbjtcclxuICBlcnJvck1lc3NhZ2U/OiBzdHJpbmc7XHJcbiAgb3JpZ2luYWxFcnJvck1lc3NhZ2U/OiBzdHJpbmc7XHJcbiAgbmFtZTogU21hcnRWYWxpZGF0b3JOYW1lIHwgc3RyaW5nO1xyXG4gIGljb24/OiBzdHJpbmc7XHJcbiAgaWNvbkNvbG9yPzogc3RyaW5nO1xyXG59XHJcblxyXG5leHBvcnQgZW51bSBTbWFydFZhbGlkYXRvck5hbWUge1xyXG4gIC8vIEFuZ3VsYXIgdmFsaWRhdG9yc1xyXG4gIHJlcXVpcmVkID0gXCJyZXF1aXJlZFwiLFxyXG4gIHJlcXVpcmVkVHJ1ZSA9IFwicmVxdWlyZWRcIixcclxuICBlbWFpbCA9IFwiZW1haWxcIixcclxuICBtYXggPSBcIm1heFwiLFxyXG4gIG1heExlbmd0aCA9IFwibWF4bGVuZ3RoXCIsXHJcbiAgbWluID0gXCJtaW5cIixcclxuICBtaW5MZW5ndGggPSBcIm1pbmxlbmd0aFwiLFxyXG4gIHBhdHRlcm4gPSBcInBhdHRlcm5cIixcclxuICBwYXNzd29yZFZhbGlkYXRvciA9IFwicGFzc3dvcmRWYWxpZGF0b3JcIixcclxuICAvLyBDdXN0b20gdmFsaWRhdG9yc1xyXG4gIGZpZWxkTWF0Y2hpbmdWYWxpZGF0b3IgPSBcImZpZWxkc01hdGNoXCIsXHJcbn1cclxuXHJcbi8qKlxyXG4gKiBEeW5hbWljIGZvcm1zIGNhbiBiZSBlYXNpbHkgZGVmaW5lZCB3aXRoIHRoaXMgaW50ZXJmYWNlLlxyXG4gKlxyXG4gKiBAcGFyYW0gbmFtZSBUaGUgbmFtZSBvZiB0aGUgZm9ybVxyXG4gKiBAcGFyYW0gd2lkZ2V0cyBUaGUgd2lkZ2V0cyBwcmVzZW50ZWQgaW4gdGhlIGZvcm1cclxuICpcclxuICogQGF1dGhvciBSb2xhbmQgRsOpbnllc1xyXG4gKi9cclxuZXhwb3J0IGludGVyZmFjZSBTbWFydEZvcm0ge1xyXG4gIG5hbWU/OiBzdHJpbmc7XHJcbiAgZGlyZWN0aW9uOiBTbWFydEZvcm1XaWRnZXREaXJlY3Rpb247XHJcbiAgd2lkZ2V0czogU21hcnRGb3JtV2lkZ2V0PGFueT5bXTtcclxuICBjb21wb25lbnRNb2RlbD86IGFueTtcclxuICB1c2VPbkJsdXJFdmVudD86IGJvb2xlYW47XHJcbiAgdXNlT25WYWx1ZUNoYW5nZUV2ZW50PzogYm9vbGVhbjtcclxuICBzaG93TGFiZWw/OiBib29sZWFuO1xyXG4gIHN1Ym1pdE9uRW50ZXI/OiAoKSA9PiB2b2lkO1xyXG4gIGxhYmVsVGhlbWU/OiBzdHJpbmc7XHJcbiAgdmFsaWRhdG9ycz86IFNtYXJ0VmFsaWRhdG9yW107XHJcbiAgdHJhbnNsYXRlU2VydmljZT86IFNtYXJ0VHJhbnNsYXRlU2VydmljZTtcclxuICBpbnZhbGlkRmllbGRzPzogU21hcnRGb3JtSW52YWxpZEZpZWxkcztcclxufVxyXG5cclxuZXhwb3J0IGludGVyZmFjZSBWYWx1ZSB7XHJcbiAgLyoqXHJcbiAgICogVGhlIHVyaSB0aGUgb2JqZWN0IG9mIHRoZSB2YWx1ZSBjYW4gYmUgYWNjZXNzZWQuXHJcbiAgICovXHJcbiAgb2JqZWN0VXJpOiBzdHJpbmc7XHJcbiAgLyoqXHJcbiAgICogVGhlIGxvZ2ljYWwgY29kZSBvZiB0aGUgc2VsZWN0YWJsZSB2YWx1ZS5cclxuICAgKi9cclxuICBjb2RlPzogc3RyaW5nO1xyXG4gIC8qKlxyXG4gICAqIFRoZSBzdHJpbmcgdmFsdWUgdGhhdCBjYW4gYmUgc2hvd24gb24gdWkuIEl0IG1pZ2h0IGJlIGEgbGFiZWwgY29kZSBvciB0aGUgZXhhY3QgbGFiZWwuXHJcbiAgICovXHJcbiAgZGlzcGxheVZhbHVlOiBzdHJpbmc7XHJcbiAgLyoqXHJcbiAgICogVGhlIGNvZGUgb2YgaWNvbiB0aGF0IGNhbiBiZSBhc3NvY2lhdGllZCB3aXRoIHRoZSB2YWx1ZS4gSXQgbWF5IGJlIGEgdXJpLlxyXG4gICAqL1xyXG4gIGljb25Db2RlPzogc3RyaW5nO1xyXG59XHJcblxyXG5leHBvcnQgZW51bSBTbWFydFdpZGdldEhpbnRQb3NpdGlvbiB7XHJcbiAgVU5ERVJfTEFCRUwsXHJcbiAgVU5ERVJfSU5QVVQsXHJcbn1cclxuXHJcbmV4cG9ydCBpbnRlcmZhY2UgU21hcnRXaWRnZXRIaW50Q29uZmlnIHtcclxuICBwb3NpdGlvbjogU21hcnRXaWRnZXRIaW50UG9zaXRpb247XHJcbn1cclxuIl19
|
package/esm2022/lib/smart-form/widgets/components/smart-file-editor/smart-file-editor.component.mjs
CHANGED
|
@@ -152,7 +152,7 @@ export class SmartFileEditorComponent {
|
|
|
152
152
|
useExisting: forwardRef(() => SmartFileEditorComponent),
|
|
153
153
|
multi: true,
|
|
154
154
|
},
|
|
155
|
-
], viewQueries: [{ propertyName: "toolbar", first: true, predicate: ["toolbar"], descendants: true }], ngImport: i0, template: "@if (widgetInstance && widgetInstance.fileUploaderProperties) {\n<h4\n *ngIf=\"widgetInstance.showLabel\"\n class=\"labelContainer {{ widgetInstance.cssLabelClass ?? '' }}\"\n [ngClass]=\"getLabelNgClass()\"\n [ngStyle]=\"getLabelStyle()\"\n>\n {{ widgetInstance.label }}\n</h4>\n\n<div class=\"fileEditorComponent\">\n @if (widgetInstance.value && !isTypeSupported(widgetInstance.value)) {\n <div class=\"errorMessage\">\n <smart-icon [icon]=\"errorIcon\" [color]=\"'var(--warninig-color)'\"></smart-icon>\n <span> Unsupported widgetInstance.value type for this widget.</span>\n </div>\n } @else if (!widgetInstance.value || fileToChange) {\n <smart-upload-widget\n class=\"widgetContent {{ widgetInstance.cssClass ?? '' }}\"\n [ngClass]=\"getNgClass()\"\n [ngStyle]=\"getStyle()\"\n [uploadDescriptor]=\"widgetInstance.fileUploaderProperties.uploadDescriptor!\"\n [isMultiple]=\"false\"\n [isDisabled]=\"widgetInstance.isDisabled\"\n (uploadFilesEvent)=\"upload($event)\"\n />\n }\n\n <div\n [ngClass]=\"{ disabledWidget: widgetInstance.isDisabled }\"\n class=\"uploadedFileContainer\"\n [style.display]=\"\n widgetInstance.value && isTypeSupported(widgetInstance.value) ? 'block' : 'none'\n \"\n >\n <div class=\"uploadedFile\">\n <smart-icon class=\"uploadedFileIcon\" [icon]=\"fileIcon\"></smart-icon>\n\n <div class=\"fileData\">\n <div class=\"fileDataContainer\">\n <span class=\"fileName\">{{ widgetInstance.value?.fileName }}</span>\n <span class=\"fileSize\">{{ formatSize(widgetInstance.value?.size) }}</span>\n </div>\n </div>\n\n <div class=\"fileActions\">\n <smart-ui-action-toolbar [id]=\"widgetInstance.toolbarId\" #toolbar></smart-ui-action-toolbar>\n\n @if (!fileToChange) {\n <ui-action-button\n class=\"changeButton\"\n (actionClick)=\"change(widgetInstance.value)\"\n [disabled]=\"widgetInstance.isDisabled\"\n [descriptor]=\"changeButton\"\n >\n </ui-action-button>\n } @else {\n <ui-action-button\n class=\"removeIcon\"\n (actionClick)=\"cancelChange()\"\n [descriptor]=\"removeButton\"\n ></ui-action-button>\n }\n </div>\n </div>\n </div>\n</div>\n}\n", styles: [":host{--border-color: #a6aabd60;--warninig-color: #be2d2e;--def-border-radius: .5rem;width:100%}.fileEditorComponent{border:2px dashed var(--border-color);border-radius:var(--def-border-radius)}.fileEditorComponent ::ng-deep smartfileuploader ::ng-deep .container{border:unset;border-radius:unset}.uploadedFileContainer{display:flex;flex-direction:column}.uploadedFile{display:flex;flex-direction:row;justify-content:flex-start;align-items:center;padding:1rem;gap:1rem}.fileEditorComponent:has(::ng-deep prime-file-uploader) ::ng-deep .uploadedFile,.fileEditorComponent:has(::ng-deep smartfileuploader) ::ng-deep .uploadedFile{border-top:1px solid #e0e0e0}.fileSize{display:flex;flex-direction:row;font-size:smaller}.fileData{flex:1;display:flex;flex-direction:column}.fileDataContainer{display:flex;flex-direction:column;justify-content:flex-end;width:fit-content}.fileActions{display:flex;flex-direction:row;justify-content:flex-end;gap:.5rem}.fileActions ::ng-deep button{border:unset}.fileActions ::ng-deep button:hover{border:unset}.removeIcon ::ng-deep mat-icon{color:var(--warninig-color)}smart-icon ::ng-deep mat-icon{font-size:3rem;width:unset;height:unset}.uploadedFileIcon{width:3rem;display:flex;justify-content:center}:host ::ng-deep .p-fileupload-content{border:unset;border-radius:var(--def-border-radius)}smart-icon ::ng-deep .pi{font-size:2rem!important}.fileEditorComponent:has(::ng-deep .errorMessage){border-color:var(--warninig-color)}.errorMessage{padding:1rem;font-size:1.5rem;color:var(--warninig-color);display:flex;flex-direction:row;align-items:center;gap:1rem}:host ::ng-deep .disabledWidget ::ng-deep .changeButton *,:host ::ng-deep .disabledWidget ::ng-deep .fileData *{opacity:.7}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "component", type: i2.SmartIconComponent, selector: "smart-icon", inputs: ["icon", "color", "imageResource"] }, { kind: "component", type: i3.UiActionToolbarComponent, selector: "smart-ui-action-toolbar", inputs: ["uiActionModels", "uiActionDescriptorService", "id", "scrollOnWrap", "toolbarPropertes"] }, { kind: "component", type: i4.UiActionButtonComponent, selector: "ui-action-button", inputs: ["disabled", "descriptor", "code", "addedCssClass", "addBasicClasses"], outputs: ["actionClick", "actionDoubleClick"] }, { kind: "component", type: i5.UploadWidgetComponent, selector: "smart-upload-widget", inputs: ["uploadDescriptor", "isMultiple", "isDisabled"], outputs: ["uploadFilesEvent"] }] }); }
|
|
155
|
+
], viewQueries: [{ propertyName: "toolbar", first: true, predicate: ["toolbar"], descendants: true }], ngImport: i0, template: "@if (widgetInstance && widgetInstance.fileUploaderProperties) {\r\n<h4\r\n *ngIf=\"widgetInstance.showLabel\"\r\n class=\"labelContainer {{ widgetInstance.cssLabelClass ?? '' }}\"\r\n [ngClass]=\"getLabelNgClass()\"\r\n [ngStyle]=\"getLabelStyle()\"\r\n>\r\n {{ widgetInstance.label }}\r\n</h4>\r\n\r\n<div class=\"fileEditorComponent\">\r\n @if (widgetInstance.value && !isTypeSupported(widgetInstance.value)) {\r\n <div class=\"errorMessage\">\r\n <smart-icon [icon]=\"errorIcon\" [color]=\"'var(--warninig-color)'\"></smart-icon>\r\n <span> Unsupported widgetInstance.value type for this widget.</span>\r\n </div>\r\n } @else if (!widgetInstance.value || fileToChange) {\r\n <smart-upload-widget\r\n class=\"widgetContent {{ widgetInstance.cssClass ?? '' }}\"\r\n [ngClass]=\"getNgClass()\"\r\n [ngStyle]=\"getStyle()\"\r\n [uploadDescriptor]=\"widgetInstance.fileUploaderProperties.uploadDescriptor!\"\r\n [isMultiple]=\"false\"\r\n [isDisabled]=\"widgetInstance.isDisabled\"\r\n (uploadFilesEvent)=\"upload($event)\"\r\n />\r\n }\r\n\r\n <div\r\n [ngClass]=\"{ disabledWidget: widgetInstance.isDisabled }\"\r\n class=\"uploadedFileContainer\"\r\n [style.display]=\"\r\n widgetInstance.value && isTypeSupported(widgetInstance.value) ? 'block' : 'none'\r\n \"\r\n >\r\n <div class=\"uploadedFile\">\r\n <smart-icon class=\"uploadedFileIcon\" [icon]=\"fileIcon\"></smart-icon>\r\n\r\n <div class=\"fileData\">\r\n <div class=\"fileDataContainer\">\r\n <span class=\"fileName\">{{ widgetInstance.value?.fileName }}</span>\r\n <span class=\"fileSize\">{{ formatSize(widgetInstance.value?.size) }}</span>\r\n </div>\r\n </div>\r\n\r\n <div class=\"fileActions\">\r\n <smart-ui-action-toolbar [id]=\"widgetInstance.toolbarId\" #toolbar></smart-ui-action-toolbar>\r\n\r\n @if (!fileToChange) {\r\n <ui-action-button\r\n class=\"changeButton\"\r\n (actionClick)=\"change(widgetInstance.value)\"\r\n [disabled]=\"widgetInstance.isDisabled\"\r\n [descriptor]=\"changeButton\"\r\n >\r\n </ui-action-button>\r\n } @else {\r\n <ui-action-button\r\n class=\"removeIcon\"\r\n (actionClick)=\"cancelChange()\"\r\n [descriptor]=\"removeButton\"\r\n ></ui-action-button>\r\n }\r\n </div>\r\n </div>\r\n </div>\r\n</div>\r\n}\r\n", styles: [":host{--border-color: #a6aabd60;--warninig-color: #be2d2e;--def-border-radius: .5rem;width:100%}.fileEditorComponent{border:2px dashed var(--border-color);border-radius:var(--def-border-radius)}.fileEditorComponent ::ng-deep smartfileuploader ::ng-deep .container{border:unset;border-radius:unset}.uploadedFileContainer{display:flex;flex-direction:column}.uploadedFile{display:flex;flex-direction:row;justify-content:flex-start;align-items:center;padding:1rem;gap:1rem}.fileEditorComponent:has(::ng-deep prime-file-uploader) ::ng-deep .uploadedFile,.fileEditorComponent:has(::ng-deep smartfileuploader) ::ng-deep .uploadedFile{border-top:1px solid #e0e0e0}.fileSize{display:flex;flex-direction:row;font-size:smaller}.fileData{flex:1;display:flex;flex-direction:column}.fileDataContainer{display:flex;flex-direction:column;justify-content:flex-end;width:fit-content}.fileActions{display:flex;flex-direction:row;justify-content:flex-end;gap:.5rem}.fileActions ::ng-deep button{border:unset}.fileActions ::ng-deep button:hover{border:unset}.removeIcon ::ng-deep mat-icon{color:var(--warninig-color)}smart-icon ::ng-deep mat-icon{font-size:3rem;width:unset;height:unset}.uploadedFileIcon{width:3rem;display:flex;justify-content:center}:host ::ng-deep .p-fileupload-content{border:unset;border-radius:var(--def-border-radius)}smart-icon ::ng-deep .pi{font-size:2rem!important}.fileEditorComponent:has(::ng-deep .errorMessage){border-color:var(--warninig-color)}.errorMessage{padding:1rem;font-size:1.5rem;color:var(--warninig-color);display:flex;flex-direction:row;align-items:center;gap:1rem}:host ::ng-deep .disabledWidget ::ng-deep .changeButton *,:host ::ng-deep .disabledWidget ::ng-deep .fileData *{opacity:.7}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "component", type: i2.SmartIconComponent, selector: "smart-icon", inputs: ["icon", "color", "imageResource"] }, { kind: "component", type: i3.UiActionToolbarComponent, selector: "smart-ui-action-toolbar", inputs: ["uiActionModels", "uiActionDescriptorService", "id", "scrollOnWrap", "toolbarPropertes"] }, { kind: "component", type: i4.UiActionButtonComponent, selector: "ui-action-button", inputs: ["disabled", "descriptor", "code", "addedCssClass", "addBasicClasses"], outputs: ["actionClick", "actionDoubleClick"] }, { kind: "component", type: i5.UploadWidgetComponent, selector: "smart-upload-widget", inputs: ["uploadDescriptor", "isMultiple", "isDisabled"], outputs: ["uploadFilesEvent"] }] }); }
|
|
156
156
|
}
|
|
157
157
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: SmartFileEditorComponent, decorators: [{
|
|
158
158
|
type: Component,
|
|
@@ -162,7 +162,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImpo
|
|
|
162
162
|
useExisting: forwardRef(() => SmartFileEditorComponent),
|
|
163
163
|
multi: true,
|
|
164
164
|
},
|
|
165
|
-
], template: "@if (widgetInstance && widgetInstance.fileUploaderProperties) {\n<h4\n *ngIf=\"widgetInstance.showLabel\"\n class=\"labelContainer {{ widgetInstance.cssLabelClass ?? '' }}\"\n [ngClass]=\"getLabelNgClass()\"\n [ngStyle]=\"getLabelStyle()\"\n>\n {{ widgetInstance.label }}\n</h4>\n\n<div class=\"fileEditorComponent\">\n @if (widgetInstance.value && !isTypeSupported(widgetInstance.value)) {\n <div class=\"errorMessage\">\n <smart-icon [icon]=\"errorIcon\" [color]=\"'var(--warninig-color)'\"></smart-icon>\n <span> Unsupported widgetInstance.value type for this widget.</span>\n </div>\n } @else if (!widgetInstance.value || fileToChange) {\n <smart-upload-widget\n class=\"widgetContent {{ widgetInstance.cssClass ?? '' }}\"\n [ngClass]=\"getNgClass()\"\n [ngStyle]=\"getStyle()\"\n [uploadDescriptor]=\"widgetInstance.fileUploaderProperties.uploadDescriptor!\"\n [isMultiple]=\"false\"\n [isDisabled]=\"widgetInstance.isDisabled\"\n (uploadFilesEvent)=\"upload($event)\"\n />\n }\n\n <div\n [ngClass]=\"{ disabledWidget: widgetInstance.isDisabled }\"\n class=\"uploadedFileContainer\"\n [style.display]=\"\n widgetInstance.value && isTypeSupported(widgetInstance.value) ? 'block' : 'none'\n \"\n >\n <div class=\"uploadedFile\">\n <smart-icon class=\"uploadedFileIcon\" [icon]=\"fileIcon\"></smart-icon>\n\n <div class=\"fileData\">\n <div class=\"fileDataContainer\">\n <span class=\"fileName\">{{ widgetInstance.value?.fileName }}</span>\n <span class=\"fileSize\">{{ formatSize(widgetInstance.value?.size) }}</span>\n </div>\n </div>\n\n <div class=\"fileActions\">\n <smart-ui-action-toolbar [id]=\"widgetInstance.toolbarId\" #toolbar></smart-ui-action-toolbar>\n\n @if (!fileToChange) {\n <ui-action-button\n class=\"changeButton\"\n (actionClick)=\"change(widgetInstance.value)\"\n [disabled]=\"widgetInstance.isDisabled\"\n [descriptor]=\"changeButton\"\n >\n </ui-action-button>\n } @else {\n <ui-action-button\n class=\"removeIcon\"\n (actionClick)=\"cancelChange()\"\n [descriptor]=\"removeButton\"\n ></ui-action-button>\n }\n </div>\n </div>\n </div>\n</div>\n}\n", styles: [":host{--border-color: #a6aabd60;--warninig-color: #be2d2e;--def-border-radius: .5rem;width:100%}.fileEditorComponent{border:2px dashed var(--border-color);border-radius:var(--def-border-radius)}.fileEditorComponent ::ng-deep smartfileuploader ::ng-deep .container{border:unset;border-radius:unset}.uploadedFileContainer{display:flex;flex-direction:column}.uploadedFile{display:flex;flex-direction:row;justify-content:flex-start;align-items:center;padding:1rem;gap:1rem}.fileEditorComponent:has(::ng-deep prime-file-uploader) ::ng-deep .uploadedFile,.fileEditorComponent:has(::ng-deep smartfileuploader) ::ng-deep .uploadedFile{border-top:1px solid #e0e0e0}.fileSize{display:flex;flex-direction:row;font-size:smaller}.fileData{flex:1;display:flex;flex-direction:column}.fileDataContainer{display:flex;flex-direction:column;justify-content:flex-end;width:fit-content}.fileActions{display:flex;flex-direction:row;justify-content:flex-end;gap:.5rem}.fileActions ::ng-deep button{border:unset}.fileActions ::ng-deep button:hover{border:unset}.removeIcon ::ng-deep mat-icon{color:var(--warninig-color)}smart-icon ::ng-deep mat-icon{font-size:3rem;width:unset;height:unset}.uploadedFileIcon{width:3rem;display:flex;justify-content:center}:host ::ng-deep .p-fileupload-content{border:unset;border-radius:var(--def-border-radius)}smart-icon ::ng-deep .pi{font-size:2rem!important}.fileEditorComponent:has(::ng-deep .errorMessage){border-color:var(--warninig-color)}.errorMessage{padding:1rem;font-size:1.5rem;color:var(--warninig-color);display:flex;flex-direction:row;align-items:center;gap:1rem}:host ::ng-deep .disabledWidget ::ng-deep .changeButton *,:host ::ng-deep .disabledWidget ::ng-deep .fileData *{opacity:.7}\n"] }]
|
|
165
|
+
], template: "@if (widgetInstance && widgetInstance.fileUploaderProperties) {\r\n<h4\r\n *ngIf=\"widgetInstance.showLabel\"\r\n class=\"labelContainer {{ widgetInstance.cssLabelClass ?? '' }}\"\r\n [ngClass]=\"getLabelNgClass()\"\r\n [ngStyle]=\"getLabelStyle()\"\r\n>\r\n {{ widgetInstance.label }}\r\n</h4>\r\n\r\n<div class=\"fileEditorComponent\">\r\n @if (widgetInstance.value && !isTypeSupported(widgetInstance.value)) {\r\n <div class=\"errorMessage\">\r\n <smart-icon [icon]=\"errorIcon\" [color]=\"'var(--warninig-color)'\"></smart-icon>\r\n <span> Unsupported widgetInstance.value type for this widget.</span>\r\n </div>\r\n } @else if (!widgetInstance.value || fileToChange) {\r\n <smart-upload-widget\r\n class=\"widgetContent {{ widgetInstance.cssClass ?? '' }}\"\r\n [ngClass]=\"getNgClass()\"\r\n [ngStyle]=\"getStyle()\"\r\n [uploadDescriptor]=\"widgetInstance.fileUploaderProperties.uploadDescriptor!\"\r\n [isMultiple]=\"false\"\r\n [isDisabled]=\"widgetInstance.isDisabled\"\r\n (uploadFilesEvent)=\"upload($event)\"\r\n />\r\n }\r\n\r\n <div\r\n [ngClass]=\"{ disabledWidget: widgetInstance.isDisabled }\"\r\n class=\"uploadedFileContainer\"\r\n [style.display]=\"\r\n widgetInstance.value && isTypeSupported(widgetInstance.value) ? 'block' : 'none'\r\n \"\r\n >\r\n <div class=\"uploadedFile\">\r\n <smart-icon class=\"uploadedFileIcon\" [icon]=\"fileIcon\"></smart-icon>\r\n\r\n <div class=\"fileData\">\r\n <div class=\"fileDataContainer\">\r\n <span class=\"fileName\">{{ widgetInstance.value?.fileName }}</span>\r\n <span class=\"fileSize\">{{ formatSize(widgetInstance.value?.size) }}</span>\r\n </div>\r\n </div>\r\n\r\n <div class=\"fileActions\">\r\n <smart-ui-action-toolbar [id]=\"widgetInstance.toolbarId\" #toolbar></smart-ui-action-toolbar>\r\n\r\n @if (!fileToChange) {\r\n <ui-action-button\r\n class=\"changeButton\"\r\n (actionClick)=\"change(widgetInstance.value)\"\r\n [disabled]=\"widgetInstance.isDisabled\"\r\n [descriptor]=\"changeButton\"\r\n >\r\n </ui-action-button>\r\n } @else {\r\n <ui-action-button\r\n class=\"removeIcon\"\r\n (actionClick)=\"cancelChange()\"\r\n [descriptor]=\"removeButton\"\r\n ></ui-action-button>\r\n }\r\n </div>\r\n </div>\r\n </div>\r\n</div>\r\n}\r\n", styles: [":host{--border-color: #a6aabd60;--warninig-color: #be2d2e;--def-border-radius: .5rem;width:100%}.fileEditorComponent{border:2px dashed var(--border-color);border-radius:var(--def-border-radius)}.fileEditorComponent ::ng-deep smartfileuploader ::ng-deep .container{border:unset;border-radius:unset}.uploadedFileContainer{display:flex;flex-direction:column}.uploadedFile{display:flex;flex-direction:row;justify-content:flex-start;align-items:center;padding:1rem;gap:1rem}.fileEditorComponent:has(::ng-deep prime-file-uploader) ::ng-deep .uploadedFile,.fileEditorComponent:has(::ng-deep smartfileuploader) ::ng-deep .uploadedFile{border-top:1px solid #e0e0e0}.fileSize{display:flex;flex-direction:row;font-size:smaller}.fileData{flex:1;display:flex;flex-direction:column}.fileDataContainer{display:flex;flex-direction:column;justify-content:flex-end;width:fit-content}.fileActions{display:flex;flex-direction:row;justify-content:flex-end;gap:.5rem}.fileActions ::ng-deep button{border:unset}.fileActions ::ng-deep button:hover{border:unset}.removeIcon ::ng-deep mat-icon{color:var(--warninig-color)}smart-icon ::ng-deep mat-icon{font-size:3rem;width:unset;height:unset}.uploadedFileIcon{width:3rem;display:flex;justify-content:center}:host ::ng-deep .p-fileupload-content{border:unset;border-radius:var(--def-border-radius)}smart-icon ::ng-deep .pi{font-size:2rem!important}.fileEditorComponent:has(::ng-deep .errorMessage){border-color:var(--warninig-color)}.errorMessage{padding:1rem;font-size:1.5rem;color:var(--warninig-color);display:flex;flex-direction:row;align-items:center;gap:1rem}:host ::ng-deep .disabledWidget ::ng-deep .changeButton *,:host ::ng-deep .disabledWidget ::ng-deep .fileData *{opacity:.7}\n"] }]
|
|
166
166
|
}], ctorParameters: () => [{ type: i0.ChangeDetectorRef }, { type: i6.ComponentLibrary, decorators: [{
|
|
167
167
|
type: Inject,
|
|
168
168
|
args: [COMPONENT_LIBRARY]
|
|
@@ -176,4 +176,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImpo
|
|
|
176
176
|
}], uploadFilesEvent: [{
|
|
177
177
|
type: Output
|
|
178
178
|
}] } });
|
|
179
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"smart-file-editor.component.js","sourceRoot":"","sources":["../../../../../../../../projects/smart-ng-client/src/lib/smart-form/widgets/components/smart-file-editor/smart-file-editor.component.ts","../../../../../../../../projects/smart-ng-client/src/lib/smart-form/widgets/components/smart-file-editor/smart-file-editor.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectorRef,\n  Component,\n  EventEmitter,\n  forwardRef,\n  Inject,\n  Input,\n  Optional,\n  Output,\n  ViewChild,\n} from '@angular/core';\nimport { SmartFileUploader } from '../../../smartform.form-model';\nimport { SmartStyleUtility } from '../../../../view-context/utility/smart-style-utility';\nimport {\n  IconPosition,\n  UiAction,\n  UiActionButtonType,\n  UiActionDescriptor,\n  UiActionUploadDescriptor,\n} from '../../../../view-context/api/model/models';\nimport {\n  COMPONENT_LIBRARY,\n  ComponentLibrary,\n} from '../../../../view-context/utility/componentLibrary';\nimport { UiActionToolbarComponent } from '../../../../view-context/smart-ui-action/ui-action-toolbar.component';\nimport { UploadWidgetUtils } from '../../../../view-context/smart-ui-action/components/upload-widget/upload-widget.utils';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\n\n@Component({\n  selector: 'smart-file-editor',\n  templateUrl: './smart-file-editor.component.html',\n  styleUrl: './smart-file-editor.component.css',\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => SmartFileEditorComponent),\n      multi: true,\n    },\n  ],\n})\nexport class SmartFileEditorComponent implements ControlValueAccessor {\n  @ViewChild('toolbar') toolbar!: UiActionToolbarComponent;\n\n  private _widgetInstance!: SmartFileUploader;\n\n  @Input()\n  get widgetInstance(): SmartFileUploader {\n    return this._widgetInstance;\n  }\n  set widgetInstance(value: SmartFileUploader) {\n    if (value) {\n      this.clone(value);\n    }\n  }\n\n  @Output() uploadFilesEvent = new EventEmitter<{\n    files: any[];\n    uiAction: UiAction;\n    uploadDescriptor?: UiActionUploadDescriptor;\n  }>();\n\n  fileToChange?: any;\n\n  constructor(\n    private cdr: ChangeDetectorRef,\n    @Inject(COMPONENT_LIBRARY) @Optional() public compLib?: ComponentLibrary\n  ) {}\n\n  private clone(value: SmartFileUploader) {\n    this._widgetInstance =\n      typeof structuredClone === 'function'\n        ? structuredClone(value)\n        : JSON.parse(JSON.stringify(value));\n\n    if (!this._widgetInstance.fileUploaderProperties?.undoIcon) {\n      this._widgetInstance.fileUploaderProperties = {\n        ...(this._widgetInstance.fileUploaderProperties ?? {}),\n        undoIcon: { identifier: 'undo' },\n      };\n    }\n\n    this.cdr.markForCheck();\n  }\n\n  upload(event: any): void {\n    if (!event.files || event.files.length == 0) {\n      return;\n    }\n\n    const props = this._widgetInstance.fileUploaderProperties!;\n    const uiAction = this.fileToChange\n      ? props.changeAction ?? props.uploadAction\n      : props.uploadAction;\n\n    this.uploadFilesEvent.emit({\n      files: event.files,\n      uiAction: uiAction!,\n      uploadDescriptor: event.uploadDescriptor,\n    });\n\n    this.onChange(this._widgetInstance.value);\n    this.fileToChange = undefined;\n  }\n\n  change(file: any): void {\n    this.fileToChange = file;\n  }\n\n  cancelChange(): void {\n    this.fileToChange = undefined;\n  }\n\n  isTypeSupported(value: any): boolean {\n    return !!(value && !Array.isArray(value) && 'dataUri' in value);\n  }\n\n  formatSize(bytes: number): string {\n    return UploadWidgetUtils.formatSize(bytes);\n  }\n\n  // ---- Smart form widget functions ----\n  getLabelNgClass(): { [className: string]: boolean } {\n    return this._widgetInstance?.labelStyle\n      ? SmartStyleUtility.getNgClasses(this._widgetInstance.labelStyle)\n      : {};\n  }\n\n  getLabelStyle(): { [key: string]: string | number } {\n    return this._widgetInstance?.labelStyle\n      ? SmartStyleUtility.getNgStyles(this._widgetInstance.labelStyle)\n      : {};\n  }\n\n  getNgClass(): { [className: string]: boolean } {\n    return SmartStyleUtility.getNgClasses(this._widgetInstance?.style);\n  }\n\n  getStyle(): { [key: string]: string | number } {\n    if (!this._widgetInstance.style) {\n      this._widgetInstance.style = {\n        classesToAdd: [],\n        classesToRemove: [],\n        style: {},\n      };\n    }\n\n    if (!('width' in this._widgetInstance.style.style) && 'minWidth' in this._widgetInstance) {\n      this._widgetInstance.style.style['width'] = `${this._widgetInstance.minWidth}px`;\n    }\n\n    return SmartStyleUtility.getNgStyles(this._widgetInstance.style);\n  }\n\n  // ---- ControlValueAccessor implementation ----\n\n  onChange = (value: any) => {};\n  onTouched = () => {};\n  isDisabled = false;\n\n  writeValue(value: any): void {\n    if (value !== undefined && this._widgetInstance) {\n      this._widgetInstance.value = value;\n      this.cdr.markForCheck();\n    }\n  }\n\n  registerOnChange(fn: any): void {\n    this.onChange = fn;\n  }\n\n  registerOnTouched(fn: any): void {\n    this.onTouched = fn;\n  }\n\n  setDisabledState?(isDisabled: boolean): void {\n    this.isDisabled = isDisabled;\n  }\n\n  // ---- UI getters ----\n\n  get fileIcon(): string {\n    return this.compLib == ComponentLibrary.PRIMENG ? 'file' : 'insert_drive_file';\n  }\n\n  get changeButton(): UiActionDescriptor {\n    var props = this._widgetInstance.fileUploaderProperties!;\n    var baseAction = props.changeAction ?? props.uploadAction!;\n\n    var changeDescriptor = {\n      ...(baseAction.descriptor ?? {}),\n      title: '',\n      color: 'primary',\n      type: UiActionButtonType.ICON,\n      icon: this.compLib === ComponentLibrary.PRIMENG ? 'sync' : 'sync_alt',\n      iconPosition: IconPosition.PRE,\n    };\n\n    return changeDescriptor;\n  }\n\n  get removeButton(): UiActionDescriptor {\n    var changeButton = this.changeButton;\n\n    return {\n      title: '',\n      color: changeButton.color,\n      type: changeButton.type,\n      iconResource: this._widgetInstance.fileUploaderProperties!.undoIcon,\n      iconPosition: IconPosition.PRE,\n    };\n  }\n\n  get errorIcon(): string {\n    return this.compLib == ComponentLibrary.PRIMENG ? 'exclamation-circle' : 'error';\n  }\n\n  get toolbarComponent(): UiActionToolbarComponent {\n    return this.toolbar;\n  }\n}\n","@if (widgetInstance && widgetInstance.fileUploaderProperties) {\n<h4\n  *ngIf=\"widgetInstance.showLabel\"\n  class=\"labelContainer {{ widgetInstance.cssLabelClass ?? '' }}\"\n  [ngClass]=\"getLabelNgClass()\"\n  [ngStyle]=\"getLabelStyle()\"\n>\n  {{ widgetInstance.label }}\n</h4>\n\n<div class=\"fileEditorComponent\">\n  @if (widgetInstance.value && !isTypeSupported(widgetInstance.value)) {\n  <div class=\"errorMessage\">\n    <smart-icon [icon]=\"errorIcon\" [color]=\"'var(--warninig-color)'\"></smart-icon>\n    <span> Unsupported widgetInstance.value type for this widget.</span>\n  </div>\n  } @else if (!widgetInstance.value || fileToChange) {\n  <smart-upload-widget\n    class=\"widgetContent {{ widgetInstance.cssClass ?? '' }}\"\n    [ngClass]=\"getNgClass()\"\n    [ngStyle]=\"getStyle()\"\n    [uploadDescriptor]=\"widgetInstance.fileUploaderProperties.uploadDescriptor!\"\n    [isMultiple]=\"false\"\n    [isDisabled]=\"widgetInstance.isDisabled\"\n    (uploadFilesEvent)=\"upload($event)\"\n  />\n  }\n\n  <div\n    [ngClass]=\"{ disabledWidget: widgetInstance.isDisabled }\"\n    class=\"uploadedFileContainer\"\n    [style.display]=\"\n      widgetInstance.value && isTypeSupported(widgetInstance.value) ? 'block' : 'none'\n    \"\n  >\n    <div class=\"uploadedFile\">\n      <smart-icon class=\"uploadedFileIcon\" [icon]=\"fileIcon\"></smart-icon>\n\n      <div class=\"fileData\">\n        <div class=\"fileDataContainer\">\n          <span class=\"fileName\">{{ widgetInstance.value?.fileName }}</span>\n          <span class=\"fileSize\">{{ formatSize(widgetInstance.value?.size) }}</span>\n        </div>\n      </div>\n\n      <div class=\"fileActions\">\n        <smart-ui-action-toolbar [id]=\"widgetInstance.toolbarId\" #toolbar></smart-ui-action-toolbar>\n\n        @if (!fileToChange) {\n        <ui-action-button\n          class=\"changeButton\"\n          (actionClick)=\"change(widgetInstance.value)\"\n          [disabled]=\"widgetInstance.isDisabled\"\n          [descriptor]=\"changeButton\"\n        >\n        </ui-action-button>\n        } @else {\n        <ui-action-button\n          class=\"removeIcon\"\n          (actionClick)=\"cancelChange()\"\n          [descriptor]=\"removeButton\"\n        ></ui-action-button>\n        }\n      </div>\n    </div>\n  </div>\n</div>\n}\n"]}
|
|
179
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"smart-file-editor.component.js","sourceRoot":"","sources":["../../../../../../../../projects/smart-ng-client/src/lib/smart-form/widgets/components/smart-file-editor/smart-file-editor.component.ts","../../../../../../../../projects/smart-ng-client/src/lib/smart-form/widgets/components/smart-file-editor/smart-file-editor.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  ChangeDetectorRef,\r\n  Component,\r\n  EventEmitter,\r\n  forwardRef,\r\n  Inject,\r\n  Input,\r\n  Optional,\r\n  Output,\r\n  ViewChild,\r\n} from '@angular/core';\r\nimport { SmartFileUploader } from '../../../smartform.form-model';\r\nimport { SmartStyleUtility } from '../../../../view-context/utility/smart-style-utility';\r\nimport {\r\n  IconPosition,\r\n  UiAction,\r\n  UiActionButtonType,\r\n  UiActionDescriptor,\r\n  UiActionUploadDescriptor,\r\n} from '../../../../view-context/api/model/models';\r\nimport {\r\n  COMPONENT_LIBRARY,\r\n  ComponentLibrary,\r\n} from '../../../../view-context/utility/componentLibrary';\r\nimport { UiActionToolbarComponent } from '../../../../view-context/smart-ui-action/ui-action-toolbar.component';\r\nimport { UploadWidgetUtils } from '../../../../view-context/smart-ui-action/components/upload-widget/upload-widget.utils';\r\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\r\n\r\n@Component({\r\n  selector: 'smart-file-editor',\r\n  templateUrl: './smart-file-editor.component.html',\r\n  styleUrl: './smart-file-editor.component.css',\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      useExisting: forwardRef(() => SmartFileEditorComponent),\r\n      multi: true,\r\n    },\r\n  ],\r\n})\r\nexport class SmartFileEditorComponent implements ControlValueAccessor {\r\n  @ViewChild('toolbar') toolbar!: UiActionToolbarComponent;\r\n\r\n  private _widgetInstance!: SmartFileUploader;\r\n\r\n  @Input()\r\n  get widgetInstance(): SmartFileUploader {\r\n    return this._widgetInstance;\r\n  }\r\n  set widgetInstance(value: SmartFileUploader) {\r\n    if (value) {\r\n      this.clone(value);\r\n    }\r\n  }\r\n\r\n  @Output() uploadFilesEvent = new EventEmitter<{\r\n    files: any[];\r\n    uiAction: UiAction;\r\n    uploadDescriptor?: UiActionUploadDescriptor;\r\n  }>();\r\n\r\n  fileToChange?: any;\r\n\r\n  constructor(\r\n    private cdr: ChangeDetectorRef,\r\n    @Inject(COMPONENT_LIBRARY) @Optional() public compLib?: ComponentLibrary\r\n  ) {}\r\n\r\n  private clone(value: SmartFileUploader) {\r\n    this._widgetInstance =\r\n      typeof structuredClone === 'function'\r\n        ? structuredClone(value)\r\n        : JSON.parse(JSON.stringify(value));\r\n\r\n    if (!this._widgetInstance.fileUploaderProperties?.undoIcon) {\r\n      this._widgetInstance.fileUploaderProperties = {\r\n        ...(this._widgetInstance.fileUploaderProperties ?? {}),\r\n        undoIcon: { identifier: 'undo' },\r\n      };\r\n    }\r\n\r\n    this.cdr.markForCheck();\r\n  }\r\n\r\n  upload(event: any): void {\r\n    if (!event.files || event.files.length == 0) {\r\n      return;\r\n    }\r\n\r\n    const props = this._widgetInstance.fileUploaderProperties!;\r\n    const uiAction = this.fileToChange\r\n      ? props.changeAction ?? props.uploadAction\r\n      : props.uploadAction;\r\n\r\n    this.uploadFilesEvent.emit({\r\n      files: event.files,\r\n      uiAction: uiAction!,\r\n      uploadDescriptor: event.uploadDescriptor,\r\n    });\r\n\r\n    this.onChange(this._widgetInstance.value);\r\n    this.fileToChange = undefined;\r\n  }\r\n\r\n  change(file: any): void {\r\n    this.fileToChange = file;\r\n  }\r\n\r\n  cancelChange(): void {\r\n    this.fileToChange = undefined;\r\n  }\r\n\r\n  isTypeSupported(value: any): boolean {\r\n    return !!(value && !Array.isArray(value) && 'dataUri' in value);\r\n  }\r\n\r\n  formatSize(bytes: number): string {\r\n    return UploadWidgetUtils.formatSize(bytes);\r\n  }\r\n\r\n  // ---- Smart form widget functions ----\r\n  getLabelNgClass(): { [className: string]: boolean } {\r\n    return this._widgetInstance?.labelStyle\r\n      ? SmartStyleUtility.getNgClasses(this._widgetInstance.labelStyle)\r\n      : {};\r\n  }\r\n\r\n  getLabelStyle(): { [key: string]: string | number } {\r\n    return this._widgetInstance?.labelStyle\r\n      ? SmartStyleUtility.getNgStyles(this._widgetInstance.labelStyle)\r\n      : {};\r\n  }\r\n\r\n  getNgClass(): { [className: string]: boolean } {\r\n    return SmartStyleUtility.getNgClasses(this._widgetInstance?.style);\r\n  }\r\n\r\n  getStyle(): { [key: string]: string | number } {\r\n    if (!this._widgetInstance.style) {\r\n      this._widgetInstance.style = {\r\n        classesToAdd: [],\r\n        classesToRemove: [],\r\n        style: {},\r\n      };\r\n    }\r\n\r\n    if (!('width' in this._widgetInstance.style.style) && 'minWidth' in this._widgetInstance) {\r\n      this._widgetInstance.style.style['width'] = `${this._widgetInstance.minWidth}px`;\r\n    }\r\n\r\n    return SmartStyleUtility.getNgStyles(this._widgetInstance.style);\r\n  }\r\n\r\n  // ---- ControlValueAccessor implementation ----\r\n\r\n  onChange = (value: any) => {};\r\n  onTouched = () => {};\r\n  isDisabled = false;\r\n\r\n  writeValue(value: any): void {\r\n    if (value !== undefined && this._widgetInstance) {\r\n      this._widgetInstance.value = value;\r\n      this.cdr.markForCheck();\r\n    }\r\n  }\r\n\r\n  registerOnChange(fn: any): void {\r\n    this.onChange = fn;\r\n  }\r\n\r\n  registerOnTouched(fn: any): void {\r\n    this.onTouched = fn;\r\n  }\r\n\r\n  setDisabledState?(isDisabled: boolean): void {\r\n    this.isDisabled = isDisabled;\r\n  }\r\n\r\n  // ---- UI getters ----\r\n\r\n  get fileIcon(): string {\r\n    return this.compLib == ComponentLibrary.PRIMENG ? 'file' : 'insert_drive_file';\r\n  }\r\n\r\n  get changeButton(): UiActionDescriptor {\r\n    var props = this._widgetInstance.fileUploaderProperties!;\r\n    var baseAction = props.changeAction ?? props.uploadAction!;\r\n\r\n    var changeDescriptor = {\r\n      ...(baseAction.descriptor ?? {}),\r\n      title: '',\r\n      color: 'primary',\r\n      type: UiActionButtonType.ICON,\r\n      icon: this.compLib === ComponentLibrary.PRIMENG ? 'sync' : 'sync_alt',\r\n      iconPosition: IconPosition.PRE,\r\n    };\r\n\r\n    return changeDescriptor;\r\n  }\r\n\r\n  get removeButton(): UiActionDescriptor {\r\n    var changeButton = this.changeButton;\r\n\r\n    return {\r\n      title: '',\r\n      color: changeButton.color,\r\n      type: changeButton.type,\r\n      iconResource: this._widgetInstance.fileUploaderProperties!.undoIcon,\r\n      iconPosition: IconPosition.PRE,\r\n    };\r\n  }\r\n\r\n  get errorIcon(): string {\r\n    return this.compLib == ComponentLibrary.PRIMENG ? 'exclamation-circle' : 'error';\r\n  }\r\n\r\n  get toolbarComponent(): UiActionToolbarComponent {\r\n    return this.toolbar;\r\n  }\r\n}\r\n","@if (widgetInstance && widgetInstance.fileUploaderProperties) {\r\n<h4\r\n  *ngIf=\"widgetInstance.showLabel\"\r\n  class=\"labelContainer {{ widgetInstance.cssLabelClass ?? '' }}\"\r\n  [ngClass]=\"getLabelNgClass()\"\r\n  [ngStyle]=\"getLabelStyle()\"\r\n>\r\n  {{ widgetInstance.label }}\r\n</h4>\r\n\r\n<div class=\"fileEditorComponent\">\r\n  @if (widgetInstance.value && !isTypeSupported(widgetInstance.value)) {\r\n  <div class=\"errorMessage\">\r\n    <smart-icon [icon]=\"errorIcon\" [color]=\"'var(--warninig-color)'\"></smart-icon>\r\n    <span> Unsupported widgetInstance.value type for this widget.</span>\r\n  </div>\r\n  } @else if (!widgetInstance.value || fileToChange) {\r\n  <smart-upload-widget\r\n    class=\"widgetContent {{ widgetInstance.cssClass ?? '' }}\"\r\n    [ngClass]=\"getNgClass()\"\r\n    [ngStyle]=\"getStyle()\"\r\n    [uploadDescriptor]=\"widgetInstance.fileUploaderProperties.uploadDescriptor!\"\r\n    [isMultiple]=\"false\"\r\n    [isDisabled]=\"widgetInstance.isDisabled\"\r\n    (uploadFilesEvent)=\"upload($event)\"\r\n  />\r\n  }\r\n\r\n  <div\r\n    [ngClass]=\"{ disabledWidget: widgetInstance.isDisabled }\"\r\n    class=\"uploadedFileContainer\"\r\n    [style.display]=\"\r\n      widgetInstance.value && isTypeSupported(widgetInstance.value) ? 'block' : 'none'\r\n    \"\r\n  >\r\n    <div class=\"uploadedFile\">\r\n      <smart-icon class=\"uploadedFileIcon\" [icon]=\"fileIcon\"></smart-icon>\r\n\r\n      <div class=\"fileData\">\r\n        <div class=\"fileDataContainer\">\r\n          <span class=\"fileName\">{{ widgetInstance.value?.fileName }}</span>\r\n          <span class=\"fileSize\">{{ formatSize(widgetInstance.value?.size) }}</span>\r\n        </div>\r\n      </div>\r\n\r\n      <div class=\"fileActions\">\r\n        <smart-ui-action-toolbar [id]=\"widgetInstance.toolbarId\" #toolbar></smart-ui-action-toolbar>\r\n\r\n        @if (!fileToChange) {\r\n        <ui-action-button\r\n          class=\"changeButton\"\r\n          (actionClick)=\"change(widgetInstance.value)\"\r\n          [disabled]=\"widgetInstance.isDisabled\"\r\n          [descriptor]=\"changeButton\"\r\n        >\r\n        </ui-action-button>\r\n        } @else {\r\n        <ui-action-button\r\n          class=\"removeIcon\"\r\n          (actionClick)=\"cancelChange()\"\r\n          [descriptor]=\"removeButton\"\r\n        ></ui-action-button>\r\n        }\r\n      </div>\r\n    </div>\r\n  </div>\r\n</div>\r\n}\r\n"]}
|
|
@@ -64,7 +64,7 @@ export class SmartMonthPickerComponent {
|
|
|
64
64
|
deps: [MAT_DATE_LOCALE, MAT_MOMENT_DATE_ADAPTER_OPTIONS],
|
|
65
65
|
},
|
|
66
66
|
{ provide: MAT_DATE_FORMATS, useValue: YEARH_MONTH_FORMAT },
|
|
67
|
-
], ngImport: i0, template: "<div class=\"smart-month-picker-container\">\n <mat-form-field appearance=\"outline\">\n <input\n matInput\n [matDatepicker]=\"dp\"\n placeholder=\"Month and Year\"\n [formControl]=\"date\"\n (input)=\"handleChange($event)\"\n />\n <mat-datepicker-toggle matSuffix [for]=\"dp\"></mat-datepicker-toggle>\n <mat-datepicker\n #dp\n startView=\"multi-year\"\n (monthSelected)=\"chosenMonthHandler($event, dp)\"\n panelClass=\"example-month-picker\"\n >\n </mat-datepicker>\n </mat-form-field>\n <div class=\"smart-month-picker-hint\">\n <mat-hint\n *ngIf=\"\n !widgetInstance?.hint || widgetInstance?.hint?.position === SmartWidgetHintPosition.INPUT\n \"\n >{{ widgetInstance.hint?.text }}</mat-hint\n >\n </div>\n</div>\n", styles: [""], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "component", type: i3.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i3.MatHint, selector: "mat-hint", inputs: ["align", "id"] }, { kind: "directive", type: i3.MatSuffix, selector: "[matSuffix], [matIconSuffix], [matTextSuffix]", inputs: ["matTextSuffix"] }, { kind: "directive", type: i4.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly"], exportAs: ["matInput"] }, { kind: "component", type: i5.MatDatepicker, selector: "mat-datepicker", exportAs: ["matDatepicker"] }, { kind: "directive", type: i5.MatDatepickerInput, selector: "input[matDatepicker]", inputs: ["matDatepicker", "min", "max", "matDatepickerFilter"], exportAs: ["matDatepickerInput"] }, { kind: "component", type: i5.MatDatepickerToggle, selector: "mat-datepicker-toggle", inputs: ["for", "tabIndex", "aria-label", "disabled", "disableRipple"], exportAs: ["matDatepickerToggle"] }] }); }
|
|
67
|
+
], ngImport: i0, template: "<div class=\"smart-month-picker-container\">\r\n <mat-form-field appearance=\"outline\">\r\n <input\r\n matInput\r\n [matDatepicker]=\"dp\"\r\n placeholder=\"Month and Year\"\r\n [formControl]=\"date\"\r\n (input)=\"handleChange($event)\"\r\n />\r\n <mat-datepicker-toggle matSuffix [for]=\"dp\"></mat-datepicker-toggle>\r\n <mat-datepicker\r\n #dp\r\n startView=\"multi-year\"\r\n (monthSelected)=\"chosenMonthHandler($event, dp)\"\r\n panelClass=\"example-month-picker\"\r\n >\r\n </mat-datepicker>\r\n </mat-form-field>\r\n <div class=\"smart-month-picker-hint\">\r\n <mat-hint\r\n *ngIf=\"\r\n !widgetInstance?.hint || widgetInstance?.hint?.position === SmartWidgetHintPosition.INPUT\r\n \"\r\n >{{ widgetInstance.hint?.text }}</mat-hint\r\n >\r\n </div>\r\n</div>\r\n", styles: [""], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "component", type: i3.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i3.MatHint, selector: "mat-hint", inputs: ["align", "id"] }, { kind: "directive", type: i3.MatSuffix, selector: "[matSuffix], [matIconSuffix], [matTextSuffix]", inputs: ["matTextSuffix"] }, { kind: "directive", type: i4.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly"], exportAs: ["matInput"] }, { kind: "component", type: i5.MatDatepicker, selector: "mat-datepicker", exportAs: ["matDatepicker"] }, { kind: "directive", type: i5.MatDatepickerInput, selector: "input[matDatepicker]", inputs: ["matDatepicker", "min", "max", "matDatepickerFilter"], exportAs: ["matDatepickerInput"] }, { kind: "component", type: i5.MatDatepickerToggle, selector: "mat-datepicker-toggle", inputs: ["for", "tabIndex", "aria-label", "disabled", "disableRipple"], exportAs: ["matDatepickerToggle"] }] }); }
|
|
68
68
|
}
|
|
69
69
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: SmartMonthPickerComponent, decorators: [{
|
|
70
70
|
type: Component,
|
|
@@ -75,10 +75,10 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImpo
|
|
|
75
75
|
deps: [MAT_DATE_LOCALE, MAT_MOMENT_DATE_ADAPTER_OPTIONS],
|
|
76
76
|
},
|
|
77
77
|
{ provide: MAT_DATE_FORMATS, useValue: YEARH_MONTH_FORMAT },
|
|
78
|
-
], template: "<div class=\"smart-month-picker-container\">\n <mat-form-field appearance=\"outline\">\n <input\n matInput\n [matDatepicker]=\"dp\"\n placeholder=\"Month and Year\"\n [formControl]=\"date\"\n (input)=\"handleChange($event)\"\n />\n <mat-datepicker-toggle matSuffix [for]=\"dp\"></mat-datepicker-toggle>\n <mat-datepicker\n #dp\n startView=\"multi-year\"\n (monthSelected)=\"chosenMonthHandler($event, dp)\"\n panelClass=\"example-month-picker\"\n >\n </mat-datepicker>\n </mat-form-field>\n <div class=\"smart-month-picker-hint\">\n <mat-hint\n *ngIf=\"\n !widgetInstance?.hint || widgetInstance?.hint?.position === SmartWidgetHintPosition.INPUT\n \"\n >{{ widgetInstance.hint?.text }}</mat-hint\n >\n </div>\n</div>\n" }]
|
|
78
|
+
], template: "<div class=\"smart-month-picker-container\">\r\n <mat-form-field appearance=\"outline\">\r\n <input\r\n matInput\r\n [matDatepicker]=\"dp\"\r\n placeholder=\"Month and Year\"\r\n [formControl]=\"date\"\r\n (input)=\"handleChange($event)\"\r\n />\r\n <mat-datepicker-toggle matSuffix [for]=\"dp\"></mat-datepicker-toggle>\r\n <mat-datepicker\r\n #dp\r\n startView=\"multi-year\"\r\n (monthSelected)=\"chosenMonthHandler($event, dp)\"\r\n panelClass=\"example-month-picker\"\r\n >\r\n </mat-datepicker>\r\n </mat-form-field>\r\n <div class=\"smart-month-picker-hint\">\r\n <mat-hint\r\n *ngIf=\"\r\n !widgetInstance?.hint || widgetInstance?.hint?.position === SmartWidgetHintPosition.INPUT\r\n \"\r\n >{{ widgetInstance.hint?.text }}</mat-hint\r\n >\r\n </div>\r\n</div>\r\n" }]
|
|
79
79
|
}], propDecorators: { widgetInstance: [{
|
|
80
80
|
type: Input
|
|
81
81
|
}], valueChange: [{
|
|
82
82
|
type: Output
|
|
83
83
|
}] } });
|
|
84
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
84
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"smart-month-picker.component.js","sourceRoot":"","sources":["../../../../../../../../projects/smart-ng-client/src/lib/smart-form/widgets/components/smart-month-picker/smart-month-picker.component.ts","../../../../../../../../projects/smart-ng-client/src/lib/smart-form/widgets/components/smart-month-picker/smart-month-picker.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,KAAK,EAAU,MAAM,EAAE,MAAM,eAAe,CAAC;AAC/E,OAAO,EAAE,kBAAkB,EAAa,MAAM,gBAAgB,CAAC;AAC/D,OAAO,EACL,+BAA+B,EAC/B,iBAAiB,GAClB,MAAM,kCAAkC,CAAC;AAC1C,OAAO,EAAE,WAAW,EAAE,gBAAgB,EAAE,eAAe,EAAE,MAAM,wBAAwB,CAAC;AAIxF,OAAO,MAAM,MAAM,QAAQ,CAAC;AAG5B,OAAO,EAAmB,2BAA2B,EAAE,MAAM,cAAc,CAAC;;;;;;;AAE5E,MAAM,CAAC,MAAM,kBAAkB,GAAG;IAChC,KAAK,EAAE;QACL,SAAS,EAAE,SAAS;KACrB;IACD,OAAO,EAAE;QACP,SAAS,EAAE,SAAS,IAAI,SAAS;QACjC,cAAc,EAAE,UAAU;QAC1B,aAAa,EAAE,IAAI;QACnB,kBAAkB,EAAE,WAAW;KAChC;CACF,CAAC;AAeF,MAAM,OAAO,yBAAyB;IAbtC;QAeY,gBAAW,GAAG,IAAI,YAAY,EAAE,CAAC;QAE3C,4BAAuB,GAAG,2BAA2B,CAAC;KAqCvD;IAnCC,QAAQ;QACN,uEAAuE;QACvE,oDAAoD;QACpD,sCAAsC;QACtC,gDAAgD;QAChD,WAAW;QACX,2CAA2C;QAC3C,4CAA4C;QAC5C,IAAI;QAEJ,MAAM,CAAC,IAAI,CAAC,cAAc,CAAC,KAAK,IAAI,EAAE,CAAC,CAAC;QAExC,IAAI,IAAI,CAAC,cAAc,CAAC,KAAK,EAAE,CAAC;YAC9B,IAAI,WAAW,GAAG,MAAM,CAAC,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC;YACpD,IAAI,CAAC,IAAI,GAAG,IAAI,kBAAkB,CAAC,WAAW,CAAC,CAAC;QAClD,CAAC;aAAM,CAAC;YACN,8BAA8B;YAC9B,IAAI,CAAC,IAAI,GAAG,IAAI,kBAAkB,CAAC,EAAE,CAAC,CAAC;QACzC,CAAC;IACH,CAAC;IAED,kBAAkB,CAAC,MAAc,EAAE,UAAiC;QAClE,qCAAqC;QACrC,mCAAmC;QACnC,iCAAiC;QAEjC,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC;QAE3B,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QAC9B,UAAU,CAAC,KAAK,EAAE,CAAC;IACrB,CAAC;IAED,YAAY,CAAC,KAAU;QACrB,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IACzC,CAAC;+GAxCU,yBAAyB;mGAAzB,yBAAyB,wIATzB;YACT;gBACE,OAAO,EAAE,WAAW;gBACpB,QAAQ,EAAE,iBAAiB;gBAC3B,IAAI,EAAE,CAAC,eAAe,EAAE,+BAA+B,CAAC;aACzD;YACD,EAAE,OAAO,EAAE,gBAAgB,EAAE,QAAQ,EAAE,kBAAkB,EAAE;SAC5D,0BCtCH,q2BA2BA;;4FDaa,yBAAyB;kBAbrC,SAAS;+BACE,wBAAwB,aAGvB;wBACT;4BACE,OAAO,EAAE,WAAW;4BACpB,QAAQ,EAAE,iBAAiB;4BAC3B,IAAI,EAAE,CAAC,eAAe,EAAE,+BAA+B,CAAC;yBACzD;wBACD,EAAE,OAAO,EAAE,gBAAgB,EAAE,QAAQ,EAAE,kBAAkB,EAAE;qBAC5D;8BAGQ,cAAc;sBAAtB,KAAK;gBACI,WAAW;sBAApB,MAAM","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output } from '@angular/core';\r\nimport { UntypedFormControl, FormGroup } from '@angular/forms';\r\nimport {\r\n  MAT_MOMENT_DATE_ADAPTER_OPTIONS,\r\n  MomentDateAdapter,\r\n} from '@angular/material-moment-adapter';\r\nimport { DateAdapter, MAT_DATE_FORMATS, MAT_DATE_LOCALE } from '@angular/material/core';\r\nimport { Moment } from 'moment';\r\nimport { SmartMonthPicker } from '../../../smartform.form-model';\r\nimport { MatDatepicker } from '@angular/material/datepicker';\r\nimport moment from 'moment';\r\nimport { Y } from '@angular/cdk/keycodes';\r\nimport { SmartValidator, SmartWidgetHintPosition } from '../../../smartform.model';\r\nimport { SmartWidgetHint, SmartWidgetHintPositionEnum } from '../../../api';\r\n\r\nexport const YEARH_MONTH_FORMAT = {\r\n  parse: {\r\n    dateInput: 'MM/YYYY',\r\n  },\r\n  display: {\r\n    dateInput: 'MM/YYYY' || 'YYYY/MM',\r\n    monthYearLabel: 'MMM YYYY',\r\n    dateA11yLabel: 'LL',\r\n    monthYearA11yLabel: 'MMMM YYYY',\r\n  },\r\n};\r\n\r\n@Component({\r\n  selector: 'lib-smart-month-picker',\r\n  templateUrl: './smart-month-picker.component.html',\r\n  styleUrls: ['./smart-month-picker.component.css'],\r\n  providers: [\r\n    {\r\n      provide: DateAdapter,\r\n      useClass: MomentDateAdapter,\r\n      deps: [MAT_DATE_LOCALE, MAT_MOMENT_DATE_ADAPTER_OPTIONS],\r\n    },\r\n    { provide: MAT_DATE_FORMATS, useValue: YEARH_MONTH_FORMAT },\r\n  ],\r\n})\r\nexport class SmartMonthPickerComponent implements OnInit {\r\n  @Input() widgetInstance!: SmartMonthPicker;\r\n  @Output() valueChange = new EventEmitter();\r\n  date!: UntypedFormControl;\r\n  SmartWidgetHintPosition = SmartWidgetHintPositionEnum;\r\n\r\n  ngOnInit(): void {\r\n    // if (this.widgetInstance.value && this.widgetInstance.value.length) {\r\n    //   let date = new Date(this.widgetInstance.value);\r\n    //   let valueInMoment = moment(date);\r\n    //   this.date = new FormControl(valueInMoment);\r\n    // } else {\r\n    //   this.date = new FormControl(moment());\r\n    //   this.valueChange.next(this.date.value);\r\n    // }\r\n\r\n    moment(this.widgetInstance.value || '');\r\n\r\n    if (this.widgetInstance.value) {\r\n      let momemtValue = moment(this.widgetInstance.value);\r\n      this.date = new UntypedFormControl(momemtValue);\r\n    } else {\r\n      // let momemtValue = moment();\r\n      this.date = new UntypedFormControl('');\r\n    }\r\n  }\r\n\r\n  chosenMonthHandler(moment: Moment, datepicker: MatDatepicker<Moment>) {\r\n    // const ctrlValue = this.date.value;\r\n    // ctrlValue.month(moment.month());\r\n    // ctrlValue.year(moment.year());\r\n\r\n    this.date.setValue(moment);\r\n\r\n    this.valueChange.next(moment);\r\n    datepicker.close();\r\n  }\r\n\r\n  handleChange(event: any): void {\r\n    this.valueChange.next(this.date.value);\r\n  }\r\n}\r\n","<div class=\"smart-month-picker-container\">\r\n  <mat-form-field appearance=\"outline\">\r\n    <input\r\n      matInput\r\n      [matDatepicker]=\"dp\"\r\n      placeholder=\"Month and Year\"\r\n      [formControl]=\"date\"\r\n      (input)=\"handleChange($event)\"\r\n    />\r\n    <mat-datepicker-toggle matSuffix [for]=\"dp\"></mat-datepicker-toggle>\r\n    <mat-datepicker\r\n      #dp\r\n      startView=\"multi-year\"\r\n      (monthSelected)=\"chosenMonthHandler($event, dp)\"\r\n      panelClass=\"example-month-picker\"\r\n    >\r\n    </mat-datepicker>\r\n  </mat-form-field>\r\n  <div class=\"smart-month-picker-hint\">\r\n    <mat-hint\r\n      *ngIf=\"\r\n        !widgetInstance?.hint || widgetInstance?.hint?.position === SmartWidgetHintPosition.INPUT\r\n      \"\r\n      >{{ widgetInstance.hint?.text }}</mat-hint\r\n    >\r\n  </div>\r\n</div>\r\n"]}
|