@smartbit4all/ng-client 4.2.60 → 4.2.62
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/esm2022/lib/smart-form/widgets/smartformwidget/smartformwidget.component.mjs +95 -113
- 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-ng-client.module.mjs +1 -1
- package/esm2022/lib/view-context/api/api/api.mjs +1 -1
- package/esm2022/lib/view-context/api/api/view.service.mjs +1 -1
- package/esm2022/lib/view-context/api/api.module.mjs +1 -1
- package/esm2022/lib/view-context/api/configuration.mjs +1 -1
- package/esm2022/lib/view-context/api/encoder.mjs +1 -1
- package/esm2022/lib/view-context/api/index.mjs +1 -1
- package/esm2022/lib/view-context/api/model/clipboardData.mjs +1 -1
- package/esm2022/lib/view-context/api/model/closeResult.mjs +1 -1
- package/esm2022/lib/view-context/api/model/componentConstraint.mjs +1 -1
- package/esm2022/lib/view-context/api/model/componentModel.mjs +1 -1
- package/esm2022/lib/view-context/api/model/componentModelChange.mjs +1 -1
- package/esm2022/lib/view-context/api/model/dataChange.mjs +1 -1
- package/esm2022/lib/view-context/api/model/dataChangeEvent.mjs +1 -1
- package/esm2022/lib/view-context/api/model/dataChangeKind.mjs +1 -1
- package/esm2022/lib/view-context/api/model/deviceInfo.mjs +1 -1
- package/esm2022/lib/view-context/api/model/downloadedFile.mjs +1 -1
- package/esm2022/lib/view-context/api/model/iconPosition.mjs +1 -1
- package/esm2022/lib/view-context/api/model/imageResource.mjs +1 -1
- package/esm2022/lib/view-context/api/model/link.mjs +1 -1
- package/esm2022/lib/view-context/api/model/messageData.mjs +1 -1
- package/esm2022/lib/view-context/api/model/messageOption.mjs +1 -1
- package/esm2022/lib/view-context/api/model/messageOptionType.mjs +1 -1
- package/esm2022/lib/view-context/api/model/messageResult.mjs +1 -1
- package/esm2022/lib/view-context/api/model/messageTextType.mjs +1 -1
- package/esm2022/lib/view-context/api/model/messageType.mjs +1 -1
- package/esm2022/lib/view-context/api/model/namedValidator.mjs +1 -1
- package/esm2022/lib/view-context/api/model/openPendingData.mjs +1 -1
- package/esm2022/lib/view-context/api/model/serverRequestExecutionStat.mjs +1 -1
- package/esm2022/lib/view-context/api/model/serverRequestTrack.mjs +1 -1
- package/esm2022/lib/view-context/api/model/serverRequestType.mjs +1 -1
- package/esm2022/lib/view-context/api/model/statisticRecord.mjs +1 -1
- package/esm2022/lib/view-context/api/model/style.mjs +1 -1
- package/esm2022/lib/view-context/api/model/uiAction.mjs +1 -1
- package/esm2022/lib/view-context/api/model/uiActionButtonDescriptor.mjs +1 -1
- package/esm2022/lib/view-context/api/model/uiActionButtonType.mjs +1 -1
- package/esm2022/lib/view-context/api/model/uiActionConstraint.mjs +1 -1
- package/esm2022/lib/view-context/api/model/uiActionDialogDescriptor.mjs +1 -1
- package/esm2022/lib/view-context/api/model/uiActionFeedbackType.mjs +1 -1
- package/esm2022/lib/view-context/api/model/uiActionInputType.mjs +1 -1
- package/esm2022/lib/view-context/api/model/uiActionRequest.mjs +1 -1
- package/esm2022/lib/view-context/api/model/uiActionTooltip.mjs +1 -1
- package/esm2022/lib/view-context/api/model/valueSet.mjs +1 -1
- package/esm2022/lib/view-context/api/model/viewApiError.mjs +1 -1
- package/esm2022/lib/view-context/api/model/viewConstraint.mjs +1 -1
- package/esm2022/lib/view-context/api/model/viewContext.mjs +1 -1
- package/esm2022/lib/view-context/api/model/viewContextChange.mjs +1 -1
- package/esm2022/lib/view-context/api/model/viewContextData.mjs +1 -1
- package/esm2022/lib/view-context/api/model/viewContextUpdate.mjs +1 -1
- package/esm2022/lib/view-context/api/model/viewPlaceholder.mjs +1 -1
- package/esm2022/lib/view-context/api/model/viewState.mjs +1 -1
- package/esm2022/lib/view-context/api/model/viewStateUpdate.mjs +1 -1
- package/esm2022/lib/view-context/api/model/viewType.mjs +1 -1
- package/esm2022/lib/view-context/api/param.mjs +1 -1
- package/esm2022/lib/view-context/api/variables.mjs +1 -1
- package/esm2022/lib/view-context/projects.mjs +2 -1
- package/esm2022/lib/view-context/smart-ui-action/components/menu/menu.component.mjs +121 -0
- package/esm2022/lib/view-context/smart-ui-action/components/menu/menu.service.mjs +21 -0
- package/esm2022/lib/view-context/smart-ui-action/ui-action-button/ui-action-button.component.mjs +21 -9
- package/esm2022/lib/view-context/smart-ui-action/ui-action-toolbar.component.mjs +11 -6
- package/esm2022/lib/view-context/smart-view-context.module.mjs +18 -5
- package/esm2022/src/lib/smart-chart/smart-chart/smart-chart2/api/api/api.mjs +1 -1
- package/esm2022/src/lib/smart-chart/smart-chart/smart-chart2/api/api.module.mjs +1 -1
- package/esm2022/src/lib/smart-chart/smart-chart/smart-chart2/api/configuration.mjs +1 -1
- package/esm2022/src/lib/smart-chart/smart-chart/smart-chart2/api/index.mjs +1 -1
- package/esm2022/src/lib/smart-chart/smart-chart/smart-chart2/api/model/diagramColor.mjs +1 -1
- package/esm2022/src/lib/smart-chart/smart-chart/smart-chart2/api/model/diagramDataContainer.mjs +1 -1
- package/esm2022/src/lib/smart-chart/smart-chart/smart-chart2/api/model/diagramDataItem.mjs +1 -1
- package/esm2022/src/lib/smart-chart/smart-chart/smart-chart2/api/model/diagramDataSet.mjs +1 -1
- package/esm2022/src/lib/smart-chart/smart-chart/smart-chart2/api/model/diagramDataSetConstructionInstruction.mjs +1 -1
- package/esm2022/src/lib/smart-chart/smart-chart/smart-chart2/api/model/diagramDescriptor.mjs +1 -1
- package/esm2022/src/lib/smart-chart/smart-chart/smart-chart2/api/model/diagramShape.mjs +1 -1
- package/esm2022/src/lib/smart-chart/smart-chart/smart-chart2/api/model/diagramUiModel.mjs +1 -1
- package/esm2022/src/lib/smart-chart/smart-chart/smart-chart2/api/model/drawTime.mjs +1 -1
- package/esm2022/src/lib/smart-chart/smart-chart/smart-chart2/api/model/labelText.mjs +1 -1
- package/esm2022/src/lib/smart-chart/smart-chart/smart-chart2/api/model/models.mjs +1 -1
- package/esm2022/src/lib/smart-chart/smart-chart/smart-chart2/api/param.mjs +1 -1
- package/esm2022/src/lib/smart-chart/smart-chart/smart-chart2/api/variables.mjs +1 -1
- package/fesm2022/smartbit4all-ng-client-src-lib-smart-chart.mjs.map +1 -1
- package/fesm2022/smartbit4all-ng-client.mjs +340 -201
- package/fesm2022/smartbit4all-ng-client.mjs.map +1 -1
- package/lib/smart-form/widgets/smartformwidget/smartformwidget.component.d.ts +15 -15
- package/lib/view-context/projects.d.ts +1 -0
- package/lib/view-context/smart-ui-action/components/menu/menu.component.d.ts +32 -0
- package/lib/view-context/smart-ui-action/components/menu/menu.service.d.ts +8 -0
- package/lib/view-context/smart-ui-action/ui-action-button/ui-action-button.component.d.ts +13 -9
- package/lib/view-context/smart-view-context.module.d.ts +47 -44
- package/package.json +1 -1
- package/smartbit4all-ng-client-4.2.62.tgz +0 -0
- package/smartbit4all-ng-client-4.2.60.tgz +0 -0
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
export {};
|
|
2
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmlld0NvbnRleHQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9zbWFydC1uZy1jbGllbnQvc3JjL2xpYi92aWV3LWNvbnRleHQvYXBpL21vZGVsL3ZpZXdDb250ZXh0LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcclxuICogVmlldyBBUElcclxuICogVmlldyBBUElcclxuICpcclxuICogVGhlIHZlcnNpb24gb2YgdGhlIE9wZW5BUEkgZG9jdW1lbnQ6IDEuMC4wXHJcbiAqIENvbnRhY3Q6IGluZm9AaXQ0YWxsLmh1XHJcbiAqXHJcbiAqIE5PVEU6IFRoaXMgY2xhc3MgaXMgYXV0byBnZW5lcmF0ZWQgYnkgT3BlbkFQSSBHZW5lcmF0b3IgKGh0dHBzOi8vb3BlbmFwaS1nZW5lcmF0b3IudGVjaCkuXHJcbiAqIGh0dHBzOi8vb3BlbmFwaS1nZW5lcmF0b3IudGVjaFxyXG4gKiBEbyBub3QgZWRpdCB0aGUgY2xhc3MgbWFudWFsbHkuXHJcbiAqL1xyXG5pbXBvcnQgeyBTZXJ2ZXJSZXF1ZXN0VHJhY2sgfSBmcm9tICcuL3NlcnZlclJlcXVlc3RUcmFjayc7XHJcbmltcG9ydCB7IERvd25sb2FkZWRGaWxlIH0gZnJvbSAnLi9kb3dubG9hZGVkRmlsZSc7XHJcbmltcG9ydCB7IE9wZW5QZW5kaW5nRGF0YSB9IGZyb20gJy4vb3BlblBlbmRpbmdEYXRhJztcclxuaW1wb3J0IHsgQ2xpcGJvYXJkRGF0YSB9IGZyb20gJy4vY2xpcGJvYXJkRGF0YSc7XHJcbmltcG9ydCB7IERldmljZUluZm8gfSBmcm9tICcuL2RldmljZUluZm8nO1xyXG5pbXBvcnQgeyBWaWV3IH0gZnJvbSAnLi92aWV3JztcclxuaW1wb3J0IHsgTGluayB9IGZyb20gJy4vbGluayc7XHJcblxyXG5cclxuLyoqXHJcbiAqIFRoZSBzYW1lIHNlc3Npb24gY2FuIGJlIHZhbGlkIC8gdXNlZCBpbiBtdWx0aXBsZSBVSXMsIHRoaXMgb2JqZWN0IHJlcHJlc2VudHMgYSBVSS5cclxuICovXHJcbmV4cG9ydCBpbnRlcmZhY2UgVmlld0NvbnRleHQgeyBcclxuICAgIHVyaTogc3RyaW5nO1xyXG4gICAgdXVpZD86IHN0cmluZztcclxuICAgIHZpZXdzOiBBcnJheTxWaWV3PjtcclxuICAgIGxpbmtzOiBBcnJheTxMaW5rPjtcclxuICAgIGRvd25sb2FkczogQXJyYXk8RG93bmxvYWRlZEZpbGU+O1xyXG4gICAgY2xpcGJvYXJkRGF0YT86IEFycmF5PENsaXBib2FyZERhdGE+O1xyXG4gICAgb3BlblBlbmRpbmdEYXRhPzogT3BlblBlbmRpbmdEYXRhO1xyXG4gICAgY3VycmVudFJlcXVlc3Q/OiBTZXJ2ZXJSZXF1ZXN0VHJhY2s7XHJcbiAgICBkZXZpY2VJbmZvPzogRGV2aWNlSW5mbztcclxufVxyXG5cclxuIl19
|
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
export {};
|
|
2
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmlld0NvbnRleHRDaGFuZ2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9zbWFydC1uZy1jbGllbnQvc3JjL2xpYi92aWV3LWNvbnRleHQvYXBpL21vZGVsL3ZpZXdDb250ZXh0Q2hhbmdlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcclxuICogVmlldyBBUElcclxuICogVmlldyBBUElcclxuICpcclxuICogVGhlIHZlcnNpb24gb2YgdGhlIE9wZW5BUEkgZG9jdW1lbnQ6IDEuMC4wXHJcbiAqIENvbnRhY3Q6IGluZm9AaXQ0YWxsLmh1XHJcbiAqXHJcbiAqIE5PVEU6IFRoaXMgY2xhc3MgaXMgYXV0byBnZW5lcmF0ZWQgYnkgT3BlbkFQSSBHZW5lcmF0b3IgKGh0dHBzOi8vb3BlbmFwaS1nZW5lcmF0b3IudGVjaCkuXHJcbiAqIGh0dHBzOi8vb3BlbmFwaS1nZW5lcmF0b3IudGVjaFxyXG4gKiBEbyBub3QgZWRpdCB0aGUgY2xhc3MgbWFudWFsbHkuXHJcbiAqL1xyXG5pbXBvcnQgeyBDb21wb25lbnRNb2RlbENoYW5nZSB9IGZyb20gJy4vY29tcG9uZW50TW9kZWxDaGFuZ2UnO1xyXG5pbXBvcnQgeyBWaWV3Q29udGV4dERhdGEgfSBmcm9tICcuL3ZpZXdDb250ZXh0RGF0YSc7XHJcblxyXG5cclxuLyoqXHJcbiAqIFRoZSBzYW1lIHNlc3Npb24gY2FuIGJlIHZhbGlkIC8gdXNlZCBpbiBtdWx0aXBsZSBVSXMsIHRoaXMgb2JqZWN0IHJlcHJlc2VudHMgYSBVSS5cclxuICovXHJcbmV4cG9ydCBpbnRlcmZhY2UgVmlld0NvbnRleHRDaGFuZ2UgeyBcclxuICAgIHZpZXdDb250ZXh0OiBWaWV3Q29udGV4dERhdGE7XHJcbiAgICBjaGFuZ2VzOiBBcnJheTxDb21wb25lbnRNb2RlbENoYW5nZT47XHJcbiAgICAvKipcclxuICAgICAqIElmIHRoZSBzZXJ2ZXIgY2FsbCBpcyB3cmFwcGVkIGluc2lkZSB0aGlzIFZpZXdDb250ZXh0Q2hhbmdlLCB0aGVuIHRoaXMgZmllbGQgd2lsbCBjb250YWluIHRoZSByZXN1bHQgb2YgdGhlIG9yaWdpbmFsIGNhbGwuIFxyXG4gICAgICovXHJcbiAgICByZXN1bHQ/OiBvYmplY3Q7XHJcbn1cclxuXHJcbiJdfQ==
|
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
export {};
|
|
2
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmlld0NvbnRleHREYXRhLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvc21hcnQtbmctY2xpZW50L3NyYy9saWIvdmlldy1jb250ZXh0L2FwaS9tb2RlbC92aWV3Q29udGV4dERhdGEudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxyXG4gKiBWaWV3IEFQSVxyXG4gKiBWaWV3IEFQSVxyXG4gKlxyXG4gKiBUaGUgdmVyc2lvbiBvZiB0aGUgT3BlbkFQSSBkb2N1bWVudDogMS4wLjBcclxuICogQ29udGFjdDogaW5mb0BpdDRhbGwuaHVcclxuICpcclxuICogTk9URTogVGhpcyBjbGFzcyBpcyBhdXRvIGdlbmVyYXRlZCBieSBPcGVuQVBJIEdlbmVyYXRvciAoaHR0cHM6Ly9vcGVuYXBpLWdlbmVyYXRvci50ZWNoKS5cclxuICogaHR0cHM6Ly9vcGVuYXBpLWdlbmVyYXRvci50ZWNoXHJcbiAqIERvIG5vdCBlZGl0IHRoZSBjbGFzcyBtYW51YWxseS5cclxuICovXHJcbmltcG9ydCB7IERvd25sb2FkZWRGaWxlIH0gZnJvbSAnLi9kb3dubG9hZGVkRmlsZSc7XHJcbmltcG9ydCB7IFZpZXdEYXRhIH0gZnJvbSAnLi92aWV3RGF0YSc7XHJcbmltcG9ydCB7IENsaXBib2FyZERhdGEgfSBmcm9tICcuL2NsaXBib2FyZERhdGEnO1xyXG5pbXBvcnQgeyBMaW5rIH0gZnJvbSAnLi9saW5rJztcclxuXHJcblxyXG4vKipcclxuICogVGhlIHNhbWUgc2Vzc2lvbiBjYW4gYmUgdmFsaWQgLyB1c2VkIGluIG11bHRpcGxlIFVJcywgdGhpcyBvYmplY3QgcmVwcmVzZW50cyBhIFVJLlxyXG4gKi9cclxuZXhwb3J0IGludGVyZmFjZSBWaWV3Q29udGV4dERhdGEgeyBcclxuICAgIHV1aWQ/OiBzdHJpbmc7XHJcbiAgICB2aWV3czogQXJyYXk8Vmlld0RhdGE+O1xyXG4gICAgbGlua3M6IEFycmF5PExpbms+O1xyXG4gICAgZG93bmxvYWRzOiBBcnJheTxEb3dubG9hZGVkRmlsZT47XHJcbiAgICBjbGlwYm9hcmREYXRhOiBBcnJheTxDbGlwYm9hcmREYXRhPjtcclxufVxyXG5cclxuIl19
|
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
export {};
|
|
2
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmlld0NvbnRleHRVcGRhdGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9zbWFydC1uZy1jbGllbnQvc3JjL2xpYi92aWV3LWNvbnRleHQvYXBpL21vZGVsL3ZpZXdDb250ZXh0VXBkYXRlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcclxuICogVmlldyBBUElcclxuICogVmlldyBBUElcclxuICpcclxuICogVGhlIHZlcnNpb24gb2YgdGhlIE9wZW5BUEkgZG9jdW1lbnQ6IDEuMC4wXHJcbiAqIENvbnRhY3Q6IGluZm9AaXQ0YWxsLmh1XHJcbiAqXHJcbiAqIE5PVEU6IFRoaXMgY2xhc3MgaXMgYXV0byBnZW5lcmF0ZWQgYnkgT3BlbkFQSSBHZW5lcmF0b3IgKGh0dHBzOi8vb3BlbmFwaS1nZW5lcmF0b3IudGVjaCkuXHJcbiAqIGh0dHBzOi8vb3BlbmFwaS1nZW5lcmF0b3IudGVjaFxyXG4gKiBEbyBub3QgZWRpdCB0aGUgY2xhc3MgbWFudWFsbHkuXHJcbiAqL1xyXG5pbXBvcnQgeyBWaWV3U3RhdGVVcGRhdGUgfSBmcm9tICcuL3ZpZXdTdGF0ZVVwZGF0ZSc7XHJcbmltcG9ydCB7IERldmljZUluZm8gfSBmcm9tICcuL2RldmljZUluZm8nO1xyXG5cclxuXHJcbi8qKlxyXG4gKiBTdGF0ZSB1cGRhdGUgb2YgYSBWaWV3Q29udGV4dC5cclxuICovXHJcbmV4cG9ydCBpbnRlcmZhY2UgVmlld0NvbnRleHRVcGRhdGUgeyBcclxuICAgIC8qKlxyXG4gICAgICogVmlld0NvbnRleHRcXCdzIHVuaXF1ZSBpZGVudGlmaWVyLlxyXG4gICAgICovXHJcbiAgICB1dWlkPzogc3RyaW5nO1xyXG4gICAgdXBkYXRlcz86IEFycmF5PFZpZXdTdGF0ZVVwZGF0ZT47XHJcbiAgICBkZXZpY2VJbmZvPzogRGV2aWNlSW5mbztcclxufVxyXG5cclxuIl19
|
|
@@ -10,4 +10,4 @@
|
|
|
10
10
|
* Do not edit the class manually.
|
|
11
11
|
*/
|
|
12
12
|
export {};
|
|
13
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
13
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmlld1BsYWNlaG9sZGVyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvc21hcnQtbmctY2xpZW50L3NyYy9saWIvdmlldy1jb250ZXh0L2FwaS9tb2RlbC92aWV3UGxhY2Vob2xkZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7Ozs7Ozs7Ozs7R0FVRyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxyXG4gKiBWaWV3IEFQSVxyXG4gKiBWaWV3IEFQSVxyXG4gKlxyXG4gKiBUaGUgdmVyc2lvbiBvZiB0aGUgT3BlbkFQSSBkb2N1bWVudDogMS4wLjBcclxuICogQ29udGFjdDogaW5mb0BpdDRhbGwuaHVcclxuICpcclxuICogTk9URTogVGhpcyBjbGFzcyBpcyBhdXRvIGdlbmVyYXRlZCBieSBPcGVuQVBJIEdlbmVyYXRvciAoaHR0cHM6Ly9vcGVuYXBpLWdlbmVyYXRvci50ZWNoKS5cclxuICogaHR0cHM6Ly9vcGVuYXBpLWdlbmVyYXRvci50ZWNoXHJcbiAqIERvIG5vdCBlZGl0IHRoZSBjbGFzcyBtYW51YWxseS5cclxuICovXHJcblxyXG5cclxuLyoqXHJcbiAqIFRoaXMgb2JqZWN0IGlzIGEgcGxhY2Vob2xkZXIgZm9yIHRoZSB2aWV3LCB0eXBpY2FsbHkgZm9yIGNsb3NlZCBjaGlsZHJlbiB2aWV3cyAgc28gdGhlc2UgYXJlIG5vdCBzYXZlZCBpbiBWaWV3Q29udGV4dCBvYmplY3QsIGtlZXBpbmcgaXRcXCdzIHNpemUgcmVhc29uYWJsZS4gXHJcbiAqL1xyXG5leHBvcnQgaW50ZXJmYWNlIFZpZXdQbGFjZWhvbGRlciB7IFxyXG4gICAgLyoqXHJcbiAgICAgKiBVbmlxdWUgaWRlbnRpZmllciBvZiB0aGUgVmlldy5cclxuICAgICAqL1xyXG4gICAgdXVpZD86IHN0cmluZztcclxuICAgIGNsb3NlZENoaWxkcmVuVmlld3M6IEFycmF5PFZpZXdQbGFjZWhvbGRlcj47XHJcbn1cclxuXHJcbiJdfQ==
|
|
@@ -19,4 +19,4 @@ export var ViewState;
|
|
|
19
19
|
ViewState["TO_CLOSE"] = "to_close";
|
|
20
20
|
ViewState["CLOSED"] = "closed";
|
|
21
21
|
})(ViewState || (ViewState = {}));
|
|
22
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
22
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmlld1N0YXRlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvc21hcnQtbmctY2xpZW50L3NyYy9saWIvdmlldy1jb250ZXh0L2FwaS9tb2RlbC92aWV3U3RhdGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7Ozs7Ozs7Ozs7R0FVRztBQUdILE1BQU0sQ0FBTixJQUFZLFNBUVg7QUFSRCxXQUFZLFNBQVM7SUFDakIsMENBQTZCLENBQUE7SUFDN0IsZ0NBQW1CLENBQUE7SUFDbkIsOEJBQWlCLENBQUE7SUFDakIsNENBQStCLENBQUE7SUFDL0IsOENBQWlDLENBQUE7SUFDakMsa0NBQXFCLENBQUE7SUFDckIsOEJBQWlCLENBQUE7QUFDckIsQ0FBQyxFQVJXLFNBQVMsS0FBVCxTQUFTLFFBUXBCIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXHJcbiAqIFZpZXcgQVBJXHJcbiAqIFZpZXcgQVBJXHJcbiAqXHJcbiAqIFRoZSB2ZXJzaW9uIG9mIHRoZSBPcGVuQVBJIGRvY3VtZW50OiAxLjAuMFxyXG4gKiBDb250YWN0OiBpbmZvQGl0NGFsbC5odVxyXG4gKlxyXG4gKiBOT1RFOiBUaGlzIGNsYXNzIGlzIGF1dG8gZ2VuZXJhdGVkIGJ5IE9wZW5BUEkgR2VuZXJhdG9yIChodHRwczovL29wZW5hcGktZ2VuZXJhdG9yLnRlY2gpLlxyXG4gKiBodHRwczovL29wZW5hcGktZ2VuZXJhdG9yLnRlY2hcclxuICogRG8gbm90IGVkaXQgdGhlIGNsYXNzIG1hbnVhbGx5LlxyXG4gKi9cclxuXHJcblxyXG5leHBvcnQgZW51bSBWaWV3U3RhdGUge1xyXG4gICAgT1BFTl9QRU5ESU5HID0gJ29wZW5fcGVuZGluZycsXHJcbiAgICBUT19PUEVOID0gJ3RvX29wZW4nLFxyXG4gICAgT1BFTkVEID0gJ29wZW5lZCcsXHJcbiAgICBDTE9TRV9QRU5ESU5HID0gJ2Nsb3NlX3BlbmRpbmcnLFxyXG4gICAgQ0xPU0VfQVBQUk9WRUQgPSAnY2xvc2VfYXBwcm92ZWQnLFxyXG4gICAgVE9fQ0xPU0UgPSAndG9fY2xvc2UnLFxyXG4gICAgQ0xPU0VEID0gJ2Nsb3NlZCdcclxufVxyXG5cclxuIl19
|
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
export {};
|
|
2
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmlld1N0YXRlVXBkYXRlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvc21hcnQtbmctY2xpZW50L3NyYy9saWIvdmlldy1jb250ZXh0L2FwaS9tb2RlbC92aWV3U3RhdGVVcGRhdGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxyXG4gKiBWaWV3IEFQSVxyXG4gKiBWaWV3IEFQSVxyXG4gKlxyXG4gKiBUaGUgdmVyc2lvbiBvZiB0aGUgT3BlbkFQSSBkb2N1bWVudDogMS4wLjBcclxuICogQ29udGFjdDogaW5mb0BpdDRhbGwuaHVcclxuICpcclxuICogTk9URTogVGhpcyBjbGFzcyBpcyBhdXRvIGdlbmVyYXRlZCBieSBPcGVuQVBJIEdlbmVyYXRvciAoaHR0cHM6Ly9vcGVuYXBpLWdlbmVyYXRvci50ZWNoKS5cclxuICogaHR0cHM6Ly9vcGVuYXBpLWdlbmVyYXRvci50ZWNoXHJcbiAqIERvIG5vdCBlZGl0IHRoZSBjbGFzcyBtYW51YWxseS5cclxuICovXHJcbmltcG9ydCB7IFZpZXdTdGF0ZSB9IGZyb20gJy4vdmlld1N0YXRlJztcclxuXHJcblxyXG4vKipcclxuICogU3RhdGUgdXBkYXRlIG9mIGEgdmlldy5cclxuICovXHJcbmV4cG9ydCBpbnRlcmZhY2UgVmlld1N0YXRlVXBkYXRlIHsgXHJcbiAgICAvKipcclxuICAgICAqIFZpZXdDb250ZXh0XFwncyB1bmlxdWUgaWRlbnRpZmllci5cclxuICAgICAqL1xyXG4gICAgdXVpZD86IHN0cmluZztcclxuICAgIHN0YXRlPzogVmlld1N0YXRlO1xyXG59XHJcblxyXG5cclxuXHJcbiJdfQ==
|
|
@@ -15,4 +15,4 @@ export var ViewType;
|
|
|
15
15
|
ViewType["DIALOG"] = "dialog";
|
|
16
16
|
ViewType["EMBEDDED"] = "embedded";
|
|
17
17
|
})(ViewType || (ViewType = {}));
|
|
18
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
18
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmlld1R5cGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9zbWFydC1uZy1jbGllbnQvc3JjL2xpYi92aWV3LWNvbnRleHQvYXBpL21vZGVsL3ZpZXdUeXBlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOzs7Ozs7Ozs7O0dBVUc7QUFHSCxNQUFNLENBQU4sSUFBWSxRQUlYO0FBSkQsV0FBWSxRQUFRO0lBQ2hCLDZCQUFpQixDQUFBO0lBQ2pCLDZCQUFpQixDQUFBO0lBQ2pCLGlDQUFxQixDQUFBO0FBQ3pCLENBQUMsRUFKVyxRQUFRLEtBQVIsUUFBUSxRQUluQiIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxyXG4gKiBWaWV3IEFQSVxyXG4gKiBWaWV3IEFQSVxyXG4gKlxyXG4gKiBUaGUgdmVyc2lvbiBvZiB0aGUgT3BlbkFQSSBkb2N1bWVudDogMS4wLjBcclxuICogQ29udGFjdDogaW5mb0BpdDRhbGwuaHVcclxuICpcclxuICogTk9URTogVGhpcyBjbGFzcyBpcyBhdXRvIGdlbmVyYXRlZCBieSBPcGVuQVBJIEdlbmVyYXRvciAoaHR0cHM6Ly9vcGVuYXBpLWdlbmVyYXRvci50ZWNoKS5cclxuICogaHR0cHM6Ly9vcGVuYXBpLWdlbmVyYXRvci50ZWNoXHJcbiAqIERvIG5vdCBlZGl0IHRoZSBjbGFzcyBtYW51YWxseS5cclxuICovXHJcblxyXG5cclxuZXhwb3J0IGVudW0gVmlld1R5cGUge1xyXG4gICAgTk9STUFMID0gJ25vcm1hbCcsXHJcbiAgICBESUFMT0cgPSAnZGlhbG9nJyxcclxuICAgIEVNQkVEREVEID0gJ2VtYmVkZGVkJ1xyXG59XHJcblxyXG4iXX0=
|
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
export {};
|
|
2
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGFyYW0uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9zbWFydC1uZy1jbGllbnQvc3JjL2xpYi92aWV3LWNvbnRleHQvYXBpL3BhcmFtLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcclxuICogU3RhbmRhcmQgcGFyYW1ldGVyIHN0eWxlcyBkZWZpbmVkIGJ5IE9wZW5BUEkgc3BlY1xyXG4gKi9cclxuZXhwb3J0IHR5cGUgU3RhbmRhcmRQYXJhbVN0eWxlID1cclxuICB8ICdtYXRyaXgnXHJcbiAgfCAnbGFiZWwnXHJcbiAgfCAnZm9ybSdcclxuICB8ICdzaW1wbGUnXHJcbiAgfCAnc3BhY2VEZWxpbWl0ZWQnXHJcbiAgfCAncGlwZURlbGltaXRlZCdcclxuICB8ICdkZWVwT2JqZWN0J1xyXG4gIDtcclxuXHJcbi8qKlxyXG4gKiBUaGUgT3BlbkFQSSBzdGFuZGFyZCB7QGxpbmsgU3RhbmRhcmRQYXJhbVN0eWxlfXMgbWF5IGJlIGV4dGVuZGVkIGJ5IGN1c3RvbSBzdHlsZXMgYnkgdGhlIHVzZXIuXHJcbiAqL1xyXG5leHBvcnQgdHlwZSBQYXJhbVN0eWxlID0gU3RhbmRhcmRQYXJhbVN0eWxlIHwgc3RyaW5nO1xyXG5cclxuLyoqXHJcbiAqIFN0YW5kYXJkIHBhcmFtZXRlciBsb2NhdGlvbnMgZGVmaW5lZCBieSBPcGVuQVBJIHNwZWNcclxuICovXHJcbmV4cG9ydCB0eXBlIFBhcmFtTG9jYXRpb24gPSAncXVlcnknIHwgJ2hlYWRlcicgfCAncGF0aCcgfCAnY29va2llJztcclxuXHJcbi8qKlxyXG4gKiBTdGFuZGFyZCB0eXBlcyBhcyBkZWZpbmVkIGluIDxhIGhyZWY9XCJodHRwczovL3N3YWdnZXIuaW8vc3BlY2lmaWNhdGlvbi8jZGF0YS10eXBlc1wiPk9wZW5BUEkgU3BlY2lmaWNhdGlvbjogRGF0YSBUeXBlczwvYT5cclxuICovXHJcbmV4cG9ydCB0eXBlIFN0YW5kYXJkRGF0YVR5cGUgPVxyXG4gIHwgXCJpbnRlZ2VyXCJcclxuICB8IFwibnVtYmVyXCJcclxuICB8IFwiYm9vbGVhblwiXHJcbiAgfCBcInN0cmluZ1wiXHJcbiAgfCBcIm9iamVjdFwiXHJcbiAgfCBcImFycmF5XCJcclxuICA7XHJcblxyXG4vKipcclxuICogU3RhbmRhcmQge0BsaW5rIERhdGFUeXBlfXMgcGx1cyB5b3VyIG93biB0eXBlcy9jbGFzc2VzLlxyXG4gKi9cclxuZXhwb3J0IHR5cGUgRGF0YVR5cGUgPSBTdGFuZGFyZERhdGFUeXBlIHwgc3RyaW5nO1xyXG5cclxuLyoqXHJcbiAqIFN0YW5kYXJkIGZvcm1hdHMgYXMgZGVmaW5lZCBpbiA8YSBocmVmPVwiaHR0cHM6Ly9zd2FnZ2VyLmlvL3NwZWNpZmljYXRpb24vI2RhdGEtdHlwZXNcIj5PcGVuQVBJIFNwZWNpZmljYXRpb246IERhdGEgVHlwZXM8L2E+XHJcbiAqL1xyXG5leHBvcnQgdHlwZSBTdGFuZGFyZERhdGFGb3JtYXQgPVxyXG4gIHwgXCJpbnQzMlwiXHJcbiAgfCBcImludDY0XCJcclxuICB8IFwiZmxvYXRcIlxyXG4gIHwgXCJkb3VibGVcIlxyXG4gIHwgXCJieXRlXCJcclxuICB8IFwiYmluYXJ5XCJcclxuICB8IFwiZGF0ZVwiXHJcbiAgfCBcImRhdGUtdGltZVwiXHJcbiAgfCBcInBhc3N3b3JkXCJcclxuICA7XHJcblxyXG5leHBvcnQgdHlwZSBEYXRhRm9ybWF0ID0gU3RhbmRhcmREYXRhRm9ybWF0IHwgc3RyaW5nO1xyXG5cclxuLyoqXHJcbiAqIFRoZSBwYXJhbWV0ZXIgdG8gZW5jb2RlLlxyXG4gKi9cclxuZXhwb3J0IGludGVyZmFjZSBQYXJhbSB7XHJcbiAgbmFtZTogc3RyaW5nO1xyXG4gIHZhbHVlOiB1bmtub3duO1xyXG4gIGluOiBQYXJhbUxvY2F0aW9uO1xyXG4gIHN0eWxlOiBQYXJhbVN0eWxlLFxyXG4gIGV4cGxvZGU6IGJvb2xlYW47XHJcbiAgZGF0YVR5cGU6IERhdGFUeXBlO1xyXG4gIGRhdGFGb3JtYXQ6IERhdGFGb3JtYXQgfCB1bmRlZmluZWQ7XHJcbn1cclxuIl19
|
|
@@ -6,4 +6,4 @@ export const COLLECTION_FORMATS = {
|
|
|
6
6
|
'ssv': ' ',
|
|
7
7
|
'pipes': '|'
|
|
8
8
|
};
|
|
9
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
9
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmFyaWFibGVzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvc21hcnQtbmctY2xpZW50L3NyYy9saWIvdmlldy1jb250ZXh0L2FwaS92YXJpYWJsZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUUvQyxNQUFNLENBQUMsTUFBTSxTQUFTLEdBQUcsSUFBSSxjQUFjLENBQVMsVUFBVSxDQUFDLENBQUM7QUFDaEUsTUFBTSxDQUFDLE1BQU0sa0JBQWtCLEdBQUc7SUFDOUIsS0FBSyxFQUFFLEdBQUc7SUFDVixLQUFLLEVBQUUsS0FBSztJQUNaLEtBQUssRUFBRSxHQUFHO0lBQ1YsT0FBTyxFQUFFLEdBQUc7Q0FDZixDQUFBIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSW5qZWN0aW9uVG9rZW4gfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuXHJcbmV4cG9ydCBjb25zdCBCQVNFX1BBVEggPSBuZXcgSW5qZWN0aW9uVG9rZW48c3RyaW5nPignYmFzZVBhdGgnKTtcclxuZXhwb3J0IGNvbnN0IENPTExFQ1RJT05fRk9STUFUUyA9IHtcclxuICAgICdjc3YnOiAnLCcsXHJcbiAgICAndHN2JzogJyAgICcsXHJcbiAgICAnc3N2JzogJyAnLFxyXG4gICAgJ3BpcGVzJzogJ3wnXHJcbn1cclxuIl19
|
|
@@ -20,4 +20,5 @@ export * from './smart-ui-action/dialogs/ui-action-file-upload-dialog/photo-capt
|
|
|
20
20
|
export * from './smart-ui-action/dialogs/ui-action-file-upload-dialog/voice-record-widget/voice-record-widget.component';
|
|
21
21
|
export * from './smart-ui-action/ui-action-button/ui-action-button.component';
|
|
22
22
|
export * from './smart-ui-action/components/action-badge/action-badge.component';
|
|
23
|
-
|
|
23
|
+
export * from './smart-ui-action/components/menu/menu.component';
|
|
24
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJvamVjdHMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9zbWFydC1uZy1jbGllbnQvc3JjL2xpYi92aWV3LWNvbnRleHQvcHJvamVjdHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFFSCxjQUFjLDhCQUE4QixDQUFDO0FBQzdDLGNBQWMsNEJBQTRCLENBQUM7QUFDM0MsY0FBYyw2QkFBNkIsQ0FBQztBQUM1QyxjQUFjLDJDQUEyQyxDQUFDO0FBQzFELGNBQWMsYUFBYSxDQUFDO0FBQzVCLGNBQWMsK0NBQStDLENBQUM7QUFDOUQsY0FBYyxxQ0FBcUMsQ0FBQztBQUNwRCxjQUFjLG1DQUFtQyxDQUFDO0FBQ2xELGNBQWMsZ0RBQWdELENBQUM7QUFDL0QsY0FBYyxxRkFBcUYsQ0FBQztBQUNwRyxjQUFjLHVGQUF1RixDQUFDO0FBQ3RHLGNBQWMsaUZBQWlGLENBQUM7QUFDaEcsY0FBYyxtRkFBbUYsQ0FBQztBQUNsRyxjQUFjLHFGQUFxRixDQUFDO0FBQ3BHLGNBQWMsNEJBQTRCLENBQUM7QUFDM0MsY0FBYyw0R0FBNEcsQ0FBQztBQUMzSCxjQUFjLDBHQUEwRyxDQUFDO0FBQ3pILGNBQWMsK0RBQStELENBQUM7QUFDOUUsY0FBYyxrRUFBa0UsQ0FBQztBQUNqRixjQUFjLGtEQUFrRCxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLypcclxuICogUHVibGljIEFQSSBTdXJmYWNlIG9mIHNtYXJ0LXZpZXctY29udGV4dFxyXG4gKi9cclxuXHJcbmV4cG9ydCAqIGZyb20gJy4vc21hcnQtdmlldy1jb250ZXh0LnNlcnZpY2UnO1xyXG5leHBvcnQgKiBmcm9tICcuL3NtYXJ0LXZpZXctY29udGV4dC5tb2RlbCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vc21hcnQtdmlldy1jb250ZXh0Lm1vZHVsZSc7XHJcbmV4cG9ydCAqIGZyb20gJy4vc21hcnQtdmlldy1yZWRpcmVjdC9zbWFydC12aWV3LXJlZGlyZWN0JztcclxuZXhwb3J0ICogZnJvbSAnLi9hcGkvaW5kZXgnO1xyXG5leHBvcnQgKiBmcm9tICcuL3NtYXJ0LXVpLWFjdGlvbi91aS1hY3Rpb24tdG9vbGJhci5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL3NtYXJ0LXVpLWFjdGlvbi91aS1hY3Rpb24uc2VydmljZSc7XHJcbmV4cG9ydCAqIGZyb20gJy4vc21hcnQtdWktYWN0aW9uL3VpLWFjdGlvbi5tb2RlbCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vc21hcnQtdWktYWN0aW9uL3VpLWFjdGlvbi5kZXNjcmlwdG9yLnNlcnZpY2UnO1xyXG5leHBvcnQgKiBmcm9tICcuL3NtYXJ0LXVpLWFjdGlvbi9kaWFsb2dzL3VpLWFjdGlvbi1jb25maXJtLWRpYWxvZy91aS1hY3Rpb24tY29uZmlybS1kaWFsb2cuc2VydmljZSc7XHJcbmV4cG9ydCAqIGZyb20gJy4vc21hcnQtdWktYWN0aW9uL2RpYWxvZ3MvdWktYWN0aW9uLWNvbmZpcm0tZGlhbG9nL3VpLWFjdGlvbi1jb25maXJtLWRpYWxvZy5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL3NtYXJ0LXVpLWFjdGlvbi9kaWFsb2dzL3VpLWFjdGlvbi1pbnB1dC1kaWFsb2cvdWktYWN0aW9uLWlucHV0LWRpYWxvZy5zZXJ2aWNlJztcclxuZXhwb3J0ICogZnJvbSAnLi9zbWFydC11aS1hY3Rpb24vZGlhbG9ncy91aS1hY3Rpb24taW5wdXQtZGlhbG9nL3VpLWFjdGlvbi1pbnB1dC1kaWFsb2cuY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9zbWFydC11aS1hY3Rpb24vZGlhbG9ncy91aS1hY3Rpb24tZGlhbG9nLWJ1dHRvbi91aS1hY3Rpb24tZGlhbG9nLWJ1dHRvbi5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL3V0aWxpdHkvY29tcG9uZW50TGlicmFyeSc7XHJcbmV4cG9ydCAqIGZyb20gJy4vc21hcnQtdWktYWN0aW9uL2RpYWxvZ3MvdWktYWN0aW9uLWZpbGUtdXBsb2FkLWRpYWxvZy9waG90by1jYXB0dXJlLXdpZGdldC9waG90by1jYXB0dXJlLXdpZGdldC5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL3NtYXJ0LXVpLWFjdGlvbi9kaWFsb2dzL3VpLWFjdGlvbi1maWxlLXVwbG9hZC1kaWFsb2cvdm9pY2UtcmVjb3JkLXdpZGdldC92b2ljZS1yZWNvcmQtd2lkZ2V0LmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vc21hcnQtdWktYWN0aW9uL3VpLWFjdGlvbi1idXR0b24vdWktYWN0aW9uLWJ1dHRvbi5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL3NtYXJ0LXVpLWFjdGlvbi9jb21wb25lbnRzL2FjdGlvbi1iYWRnZS9hY3Rpb24tYmFkZ2UuY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9zbWFydC11aS1hY3Rpb24vY29tcG9uZW50cy9tZW51L21lbnUuY29tcG9uZW50JztcclxuIl19
|
|
@@ -0,0 +1,121 @@
|
|
|
1
|
+
import { Component, EventEmitter, HostListener, Inject, Input, Optional, Output, ViewChild, ViewChildren, } from '@angular/core';
|
|
2
|
+
import { Subject, takeUntil } from 'rxjs';
|
|
3
|
+
import { COMPONENT_LIBRARY, ComponentLibrary } from '../../../utility/componentLibrary';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
import * as i1 from "./menu.service";
|
|
6
|
+
import * as i2 from "@angular/common";
|
|
7
|
+
import * as i3 from "../../../../smart-icon/smart-icon/smart-icon.component";
|
|
8
|
+
import * as i4 from "../../ui-action-button/ui-action-button.component";
|
|
9
|
+
import * as i5 from "../../../utility/componentLibrary";
|
|
10
|
+
export class MenuComponent {
|
|
11
|
+
constructor(menuService, compLib) {
|
|
12
|
+
this.menuService = menuService;
|
|
13
|
+
this.compLib = compLib;
|
|
14
|
+
this.subActions = [];
|
|
15
|
+
this.isSubmenu = false;
|
|
16
|
+
this.actionClick = new EventEmitter();
|
|
17
|
+
this.destroy$ = new Subject();
|
|
18
|
+
this.visible = false;
|
|
19
|
+
this.submenuOpenMap = new Map();
|
|
20
|
+
this.alignLeft = false;
|
|
21
|
+
this.compLib = compLib ?? ComponentLibrary.PRIMENG;
|
|
22
|
+
if (this.compLib === ComponentLibrary.PRIMENG) {
|
|
23
|
+
this.icon = 'chevron-right';
|
|
24
|
+
}
|
|
25
|
+
else if (this.compLib === ComponentLibrary.MATERIAL) {
|
|
26
|
+
this.icon = 'chevron_right';
|
|
27
|
+
}
|
|
28
|
+
}
|
|
29
|
+
ngOnInit() {
|
|
30
|
+
this.menuService
|
|
31
|
+
.getCloseSignal()
|
|
32
|
+
.pipe(takeUntil(this.destroy$))
|
|
33
|
+
.subscribe(() => {
|
|
34
|
+
this.visible = false;
|
|
35
|
+
this.submenuComponents?.forEach((submenu) => (submenu.visible = false));
|
|
36
|
+
});
|
|
37
|
+
}
|
|
38
|
+
ngOnDestroy() {
|
|
39
|
+
this.destroy$.next();
|
|
40
|
+
this.destroy$.complete();
|
|
41
|
+
}
|
|
42
|
+
onActionClick(action) {
|
|
43
|
+
if (!action.disabled) {
|
|
44
|
+
this.actionClick.emit(action);
|
|
45
|
+
this.menuService.closeAllMenus();
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
onMenuClick(event) {
|
|
49
|
+
event.stopPropagation();
|
|
50
|
+
}
|
|
51
|
+
onDocumentClick(event) {
|
|
52
|
+
this.visible = false;
|
|
53
|
+
this.submenuComponents.forEach((submenu) => (submenu.visible = false));
|
|
54
|
+
}
|
|
55
|
+
toggleMenu() {
|
|
56
|
+
if (!this.isSubmenu) {
|
|
57
|
+
this.menuService.closeAllMenus();
|
|
58
|
+
}
|
|
59
|
+
this.visible = !this.visible;
|
|
60
|
+
this.adjustAlignment();
|
|
61
|
+
}
|
|
62
|
+
openSubmenu(action) {
|
|
63
|
+
this.submenuComponents.forEach((submenu) => {
|
|
64
|
+
submenu.visible = false;
|
|
65
|
+
});
|
|
66
|
+
let submenuComp = this.getSubmenuComponentForAction(action);
|
|
67
|
+
if (submenuComp && !submenuComp.visible) {
|
|
68
|
+
submenuComp.toggleMenu();
|
|
69
|
+
}
|
|
70
|
+
}
|
|
71
|
+
getSubmenuComponentForAction(action) {
|
|
72
|
+
let submenuActions = this.subActions.filter((a) => a.subActions && a.subActions.length > 0);
|
|
73
|
+
let index = submenuActions.findIndex((a) => a.code === action.code);
|
|
74
|
+
if (index === -1)
|
|
75
|
+
return undefined;
|
|
76
|
+
return this.submenuComponents.toArray()[index];
|
|
77
|
+
}
|
|
78
|
+
adjustAlignment(retries = 10) {
|
|
79
|
+
if (!this.menuRef?.nativeElement) {
|
|
80
|
+
if (retries > 0) {
|
|
81
|
+
setTimeout(() => this.adjustAlignment(retries - 1), 10);
|
|
82
|
+
}
|
|
83
|
+
return;
|
|
84
|
+
}
|
|
85
|
+
const rect = this.menuRef.nativeElement.getBoundingClientRect();
|
|
86
|
+
const overflowRight = rect.right > window.innerWidth;
|
|
87
|
+
this.alignLeft = overflowRight;
|
|
88
|
+
}
|
|
89
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: MenuComponent, deps: [{ token: i1.UiMenuService }, { token: COMPONENT_LIBRARY, optional: true }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
90
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.11", type: MenuComponent, selector: "ui-tiered-menu", inputs: { subActions: "subActions", triggerAction: "triggerAction", isSubmenu: "isSubmenu" }, outputs: { actionClick: "actionClick" }, host: { listeners: { "click": "onMenuClick($event)", "document:click": "onDocumentClick($event)" } }, viewQueries: [{ propertyName: "menuRef", first: true, predicate: ["menuContainer"], descendants: true }, { propertyName: "submenuComponents", predicate: ["submenu"], descendants: true }], ngImport: i0, template: "@if (triggerAction) {\r\n<ui-action-button\r\n [descriptor]=\"triggerAction.descriptor!\"\r\n [disabled]=\"!!triggerAction.disabled\"\r\n (actionClick)=\"toggleMenu()\"\r\n>\r\n</ui-action-button>\r\n} @if (visible) {\r\n<ul class=\"ui-tiered-menu\" #menuContainer [ngClass]=\"{ 'align-left': alignLeft }\">\r\n <li *ngFor=\"let action of subActions\" [class.disabled]=\"action.disabled\">\r\n <ng-template #actionButtonTemplate>\r\n <ui-action-button\r\n [descriptor]=\"action.descriptor!\"\r\n [disabled]=\"!!action.disabled\"\r\n (actionClick)=\"!action.subActions?.length && onActionClick(action)\"\r\n ></ui-action-button>\r\n </ng-template>\r\n\r\n @if(action.subActions && action.subActions.length){\r\n\r\n <div class=\"submenu\" #submenuWrapper (mouseenter)=\"openSubmenu(action)\">\r\n <ng-container *ngTemplateOutlet=\"actionButtonTemplate\"></ng-container>\r\n <smart-icon icon=\"chevron-right\" color=\"black\"></smart-icon>\r\n <ui-tiered-menu\r\n #submenu\r\n [isSubmenu]=\"true\"\r\n [subActions]=\"action.subActions\"\r\n (actionClick)=\"actionClick.emit($event)\"\r\n ></ui-tiered-menu>\r\n </div>\r\n\r\n }@else {\r\n <ng-container *ngTemplateOutlet=\"actionButtonTemplate\"></ng-container>\r\n }\r\n </li>\r\n</ul>\r\n}\r\n", styles: [":host{position:relative;display:inline-block}.ui-tiered-menu{position:absolute;top:100%;left:0;list-style:none;padding-left:0;margin:0;background:#fff;width:fit-content;box-shadow:2px 2px 8px #0003;z-index:1000;border-radius:5px;padding:.1rem}.ui-tiered-menu ::ng-deep button{background-color:#fff;box-shadow:unset;border:unset;border-radius:unset;color:#000;width:100%;justify-content:flex-start}.ui-tiered-menu ::ng-deep button:hover{background-color:#f1f5f9}.ui-tiered-menu ::ng-deep ui-badge{width:100%}.ui-tiered-menu>li{position:relative}.submenu{display:flex;flex-direction:row;justify-content:space-between;align-items:center}.submenu ::ng-deep ui-action-button{flex:1}.disabled{color:#aaa;cursor:not-allowed}.ui-tiered-menu ui-tiered-menu{position:absolute;top:0;left:100%;margin-left:2px;z-index:1000;background:#fff;border:1px solid #ccc;box-shadow:2px 2px 8px #0003;visibility:visible}smart-icon{align-content:center}.ui-tiered-menu.align-left{position:absolute;top:0;left:auto;right:100%}\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.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i3.SmartIconComponent, selector: "smart-icon", inputs: ["icon", "color"] }, { kind: "component", type: i4.UiActionButtonComponent, selector: "ui-action-button", inputs: ["disabled", "descriptor", "code", "addedCssClass"], outputs: ["actionClick", "actionDoubleClick"] }, { kind: "component", type: MenuComponent, selector: "ui-tiered-menu", inputs: ["subActions", "triggerAction", "isSubmenu"], outputs: ["actionClick"] }] }); }
|
|
91
|
+
}
|
|
92
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: MenuComponent, decorators: [{
|
|
93
|
+
type: Component,
|
|
94
|
+
args: [{ selector: 'ui-tiered-menu', template: "@if (triggerAction) {\r\n<ui-action-button\r\n [descriptor]=\"triggerAction.descriptor!\"\r\n [disabled]=\"!!triggerAction.disabled\"\r\n (actionClick)=\"toggleMenu()\"\r\n>\r\n</ui-action-button>\r\n} @if (visible) {\r\n<ul class=\"ui-tiered-menu\" #menuContainer [ngClass]=\"{ 'align-left': alignLeft }\">\r\n <li *ngFor=\"let action of subActions\" [class.disabled]=\"action.disabled\">\r\n <ng-template #actionButtonTemplate>\r\n <ui-action-button\r\n [descriptor]=\"action.descriptor!\"\r\n [disabled]=\"!!action.disabled\"\r\n (actionClick)=\"!action.subActions?.length && onActionClick(action)\"\r\n ></ui-action-button>\r\n </ng-template>\r\n\r\n @if(action.subActions && action.subActions.length){\r\n\r\n <div class=\"submenu\" #submenuWrapper (mouseenter)=\"openSubmenu(action)\">\r\n <ng-container *ngTemplateOutlet=\"actionButtonTemplate\"></ng-container>\r\n <smart-icon icon=\"chevron-right\" color=\"black\"></smart-icon>\r\n <ui-tiered-menu\r\n #submenu\r\n [isSubmenu]=\"true\"\r\n [subActions]=\"action.subActions\"\r\n (actionClick)=\"actionClick.emit($event)\"\r\n ></ui-tiered-menu>\r\n </div>\r\n\r\n }@else {\r\n <ng-container *ngTemplateOutlet=\"actionButtonTemplate\"></ng-container>\r\n }\r\n </li>\r\n</ul>\r\n}\r\n", styles: [":host{position:relative;display:inline-block}.ui-tiered-menu{position:absolute;top:100%;left:0;list-style:none;padding-left:0;margin:0;background:#fff;width:fit-content;box-shadow:2px 2px 8px #0003;z-index:1000;border-radius:5px;padding:.1rem}.ui-tiered-menu ::ng-deep button{background-color:#fff;box-shadow:unset;border:unset;border-radius:unset;color:#000;width:100%;justify-content:flex-start}.ui-tiered-menu ::ng-deep button:hover{background-color:#f1f5f9}.ui-tiered-menu ::ng-deep ui-badge{width:100%}.ui-tiered-menu>li{position:relative}.submenu{display:flex;flex-direction:row;justify-content:space-between;align-items:center}.submenu ::ng-deep ui-action-button{flex:1}.disabled{color:#aaa;cursor:not-allowed}.ui-tiered-menu ui-tiered-menu{position:absolute;top:0;left:100%;margin-left:2px;z-index:1000;background:#fff;border:1px solid #ccc;box-shadow:2px 2px 8px #0003;visibility:visible}smart-icon{align-content:center}.ui-tiered-menu.align-left{position:absolute;top:0;left:auto;right:100%}\n"] }]
|
|
95
|
+
}], ctorParameters: () => [{ type: i1.UiMenuService }, { type: i5.ComponentLibrary, decorators: [{
|
|
96
|
+
type: Inject,
|
|
97
|
+
args: [COMPONENT_LIBRARY]
|
|
98
|
+
}, {
|
|
99
|
+
type: Optional
|
|
100
|
+
}] }], propDecorators: { menuRef: [{
|
|
101
|
+
type: ViewChild,
|
|
102
|
+
args: ['menuContainer', { static: false }]
|
|
103
|
+
}], submenuComponents: [{
|
|
104
|
+
type: ViewChildren,
|
|
105
|
+
args: ['submenu']
|
|
106
|
+
}], subActions: [{
|
|
107
|
+
type: Input
|
|
108
|
+
}], triggerAction: [{
|
|
109
|
+
type: Input
|
|
110
|
+
}], isSubmenu: [{
|
|
111
|
+
type: Input
|
|
112
|
+
}], actionClick: [{
|
|
113
|
+
type: Output
|
|
114
|
+
}], onMenuClick: [{
|
|
115
|
+
type: HostListener,
|
|
116
|
+
args: ['click', ['$event']]
|
|
117
|
+
}], onDocumentClick: [{
|
|
118
|
+
type: HostListener,
|
|
119
|
+
args: ['document:click', ['$event']]
|
|
120
|
+
}] } });
|
|
121
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"menu.component.js","sourceRoot":"","sources":["../../../../../../../../projects/smart-ng-client/src/lib/view-context/smart-ui-action/components/menu/menu.component.ts","../../../../../../../../projects/smart-ng-client/src/lib/view-context/smart-ui-action/components/menu/menu.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  ElementRef,\r\n  EventEmitter,\r\n  HostListener,\r\n  Inject,\r\n  Input,\r\n  Optional,\r\n  Output,\r\n  QueryList,\r\n  ViewChild,\r\n  ViewChildren,\r\n} from '@angular/core';\r\nimport { UiAction } from '../../../api';\r\nimport { Subject, takeUntil } from 'rxjs';\r\nimport { UiMenuService } from './menu.service';\r\nimport { COMPONENT_LIBRARY, ComponentLibrary } from '../../../utility/componentLibrary';\r\n\r\n@Component({\r\n  selector: 'ui-tiered-menu',\r\n  templateUrl: './menu.component.html',\r\n  styleUrl: './menu.component.css',\r\n})\r\nexport class MenuComponent {\r\n  @ViewChild('menuContainer', { static: false }) menuRef!: ElementRef;\r\n  @ViewChildren('submenu') submenuComponents!: QueryList<MenuComponent>;\r\n\r\n  @Input() subActions: UiAction[] = [];\r\n  @Input() triggerAction!: UiAction;\r\n  @Input() isSubmenu: boolean = false;\r\n\r\n  @Output() actionClick = new EventEmitter<UiAction>();\r\n\r\n  private destroy$ = new Subject<void>();\r\n  visible = false;\r\n  icon!: string;\r\n  submenuOpenMap = new Map<UiAction, boolean>();\r\n  alignLeft = false;\r\n\r\n  constructor(\r\n    private menuService: UiMenuService,\r\n    @Inject(COMPONENT_LIBRARY) @Optional() public compLib?: ComponentLibrary\r\n  ) {\r\n    this.compLib = compLib ?? ComponentLibrary.PRIMENG;\r\n\r\n    if (this.compLib === ComponentLibrary.PRIMENG) {\r\n      this.icon = 'chevron-right';\r\n    } else if (this.compLib === ComponentLibrary.MATERIAL) {\r\n      this.icon = 'chevron_right';\r\n    }\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    this.menuService\r\n      .getCloseSignal()\r\n      .pipe(takeUntil(this.destroy$))\r\n      .subscribe(() => {\r\n        this.visible = false;\r\n        this.submenuComponents?.forEach((submenu) => (submenu.visible = false));\r\n      });\r\n  }\r\n  ngOnDestroy(): void {\r\n    this.destroy$.next();\r\n    this.destroy$.complete();\r\n  }\r\n\r\n  onActionClick(action: UiAction) {\r\n    if (!action.disabled) {\r\n      this.actionClick.emit(action);\r\n      this.menuService.closeAllMenus();\r\n    }\r\n  }\r\n\r\n  @HostListener('click', ['$event'])\r\n  onMenuClick(event: Event) {\r\n    event.stopPropagation();\r\n  }\r\n\r\n  @HostListener('document:click', ['$event'])\r\n  onDocumentClick(event: Event) {\r\n    this.visible = false;\r\n    this.submenuComponents.forEach((submenu) => (submenu.visible = false));\r\n  }\r\n\r\n  toggleMenu() {\r\n    if (!this.isSubmenu) {\r\n      this.menuService.closeAllMenus();\r\n    }\r\n    this.visible = !this.visible;\r\n    this.adjustAlignment();\r\n  }\r\n\r\n  openSubmenu(action: UiAction) {\r\n    this.submenuComponents.forEach((submenu) => {\r\n      submenu.visible = false;\r\n    });\r\n\r\n    let submenuComp = this.getSubmenuComponentForAction(action);\r\n\r\n    if (submenuComp && !submenuComp.visible) {\r\n      submenuComp.toggleMenu();\r\n    }\r\n  }\r\n\r\n  private getSubmenuComponentForAction(action: UiAction): MenuComponent | undefined {\r\n    let submenuActions = this.subActions.filter((a) => a.subActions && a.subActions.length > 0);\r\n    let index = submenuActions.findIndex((a) => a.code === action.code);\r\n    if (index === -1) return undefined;\r\n    return this.submenuComponents.toArray()[index];\r\n  }\r\n\r\n  adjustAlignment(retries: number = 10) {\r\n    if (!this.menuRef?.nativeElement) {\r\n      if (retries > 0) {\r\n        setTimeout(() => this.adjustAlignment(retries - 1), 10);\r\n      }\r\n      return;\r\n    }\r\n\r\n    const rect = this.menuRef.nativeElement.getBoundingClientRect();\r\n    const overflowRight = rect.right > window.innerWidth;\r\n\r\n    this.alignLeft = overflowRight;\r\n  }\r\n}\r\n","@if (triggerAction) {\r\n<ui-action-button\r\n  [descriptor]=\"triggerAction.descriptor!\"\r\n  [disabled]=\"!!triggerAction.disabled\"\r\n  (actionClick)=\"toggleMenu()\"\r\n>\r\n</ui-action-button>\r\n} @if (visible) {\r\n<ul class=\"ui-tiered-menu\" #menuContainer [ngClass]=\"{ 'align-left': alignLeft }\">\r\n  <li *ngFor=\"let action of subActions\" [class.disabled]=\"action.disabled\">\r\n    <ng-template #actionButtonTemplate>\r\n      <ui-action-button\r\n        [descriptor]=\"action.descriptor!\"\r\n        [disabled]=\"!!action.disabled\"\r\n        (actionClick)=\"!action.subActions?.length && onActionClick(action)\"\r\n      ></ui-action-button>\r\n    </ng-template>\r\n\r\n    @if(action.subActions && action.subActions.length){\r\n\r\n    <div class=\"submenu\" #submenuWrapper (mouseenter)=\"openSubmenu(action)\">\r\n      <ng-container *ngTemplateOutlet=\"actionButtonTemplate\"></ng-container>\r\n      <smart-icon icon=\"chevron-right\" color=\"black\"></smart-icon>\r\n      <ui-tiered-menu\r\n        #submenu\r\n        [isSubmenu]=\"true\"\r\n        [subActions]=\"action.subActions\"\r\n        (actionClick)=\"actionClick.emit($event)\"\r\n      ></ui-tiered-menu>\r\n    </div>\r\n\r\n    }@else {\r\n    <ng-container *ngTemplateOutlet=\"actionButtonTemplate\"></ng-container>\r\n    }\r\n  </li>\r\n</ul>\r\n}\r\n"]}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import { Injectable } from '@angular/core';
|
|
2
|
+
import { Subject } from 'rxjs';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
export class UiMenuService {
|
|
5
|
+
constructor() {
|
|
6
|
+
this.closeMenus$ = new Subject();
|
|
7
|
+
}
|
|
8
|
+
closeAllMenus() {
|
|
9
|
+
this.closeMenus$.next();
|
|
10
|
+
}
|
|
11
|
+
getCloseSignal() {
|
|
12
|
+
return this.closeMenus$.asObservable();
|
|
13
|
+
}
|
|
14
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: UiMenuService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
15
|
+
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: UiMenuService, providedIn: 'root' }); }
|
|
16
|
+
}
|
|
17
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: UiMenuService, decorators: [{
|
|
18
|
+
type: Injectable,
|
|
19
|
+
args: [{ providedIn: 'root' }]
|
|
20
|
+
}] });
|
|
21
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWVudS5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvc21hcnQtbmctY2xpZW50L3NyYy9saWIvdmlldy1jb250ZXh0L3NtYXJ0LXVpLWFjdGlvbi9jb21wb25lbnRzL21lbnUvbWVudS5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDM0MsT0FBTyxFQUFFLE9BQU8sRUFBRSxNQUFNLE1BQU0sQ0FBQzs7QUFHL0IsTUFBTSxPQUFPLGFBQWE7SUFEMUI7UUFFVSxnQkFBVyxHQUFHLElBQUksT0FBTyxFQUFRLENBQUM7S0FTM0M7SUFQQyxhQUFhO1FBQ1gsSUFBSSxDQUFDLFdBQVcsQ0FBQyxJQUFJLEVBQUUsQ0FBQztJQUMxQixDQUFDO0lBRUQsY0FBYztRQUNaLE9BQU8sSUFBSSxDQUFDLFdBQVcsQ0FBQyxZQUFZLEVBQUUsQ0FBQztJQUN6QyxDQUFDOytHQVRVLGFBQWE7bUhBQWIsYUFBYSxjQURBLE1BQU07OzRGQUNuQixhQUFhO2tCQUR6QixVQUFVO21CQUFDLEVBQUUsVUFBVSxFQUFFLE1BQU0sRUFBRSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdGFibGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgU3ViamVjdCB9IGZyb20gJ3J4anMnO1xyXG5cclxuQEluamVjdGFibGUoeyBwcm92aWRlZEluOiAncm9vdCcgfSlcclxuZXhwb3J0IGNsYXNzIFVpTWVudVNlcnZpY2Uge1xyXG4gIHByaXZhdGUgY2xvc2VNZW51cyQgPSBuZXcgU3ViamVjdDx2b2lkPigpO1xyXG5cclxuICBjbG9zZUFsbE1lbnVzKCkge1xyXG4gICAgdGhpcy5jbG9zZU1lbnVzJC5uZXh0KCk7XHJcbiAgfVxyXG5cclxuICBnZXRDbG9zZVNpZ25hbCgpIHtcclxuICAgIHJldHVybiB0aGlzLmNsb3NlTWVudXMkLmFzT2JzZXJ2YWJsZSgpO1xyXG4gIH1cclxufVxyXG4iXX0=
|
package/esm2022/lib/view-context/smart-ui-action/ui-action-button/ui-action-button.component.mjs
CHANGED
|
@@ -15,10 +15,11 @@ export class UiActionButtonComponent {
|
|
|
15
15
|
constructor(changeDetector, compLib) {
|
|
16
16
|
this.changeDetector = changeDetector;
|
|
17
17
|
this._destroy$ = new Subject();
|
|
18
|
-
this.componentLibrary = ComponentLibrary;
|
|
19
|
-
this.pressedButtonActive = true;
|
|
20
18
|
this.actionClick = new EventEmitter();
|
|
21
19
|
this.actionDoubleClick = new EventEmitter();
|
|
20
|
+
this.componentLibrary = ComponentLibrary;
|
|
21
|
+
this.pressedButtonActive = true;
|
|
22
|
+
this.menuOpened = false;
|
|
22
23
|
this.compLib = compLib ?? ComponentLibrary.PRIMENG;
|
|
23
24
|
}
|
|
24
25
|
ngOnInit() {
|
|
@@ -26,16 +27,27 @@ export class UiActionButtonComponent {
|
|
|
26
27
|
throw new Error('UiActionButtonComponent: "descriptor" input is required but was not provided.');
|
|
27
28
|
}
|
|
28
29
|
}
|
|
30
|
+
ngOnChanges(changes) {
|
|
31
|
+
if (changes['descriptor'] && this.descriptor) {
|
|
32
|
+
this.mainActionModel = {
|
|
33
|
+
descriptor: this.descriptor,
|
|
34
|
+
uiAction: {
|
|
35
|
+
descriptor: this.descriptor,
|
|
36
|
+
code: this.code,
|
|
37
|
+
disabled: this.disabled ?? false,
|
|
38
|
+
},
|
|
39
|
+
};
|
|
40
|
+
}
|
|
41
|
+
}
|
|
29
42
|
ngOnDestroy() {
|
|
30
43
|
this._destroy$.next();
|
|
31
44
|
this._destroy$.complete();
|
|
32
45
|
}
|
|
33
|
-
async onActionClicked(event) {
|
|
46
|
+
async onActionClicked(event, model) {
|
|
34
47
|
event.stopPropagation();
|
|
35
48
|
this.actionClick.emit({
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
descriptor: this.descriptor,
|
|
49
|
+
code: model.uiAction.code,
|
|
50
|
+
descriptor: model.descriptor,
|
|
39
51
|
});
|
|
40
52
|
}
|
|
41
53
|
onActionDoubleClicked(event) {
|
|
@@ -107,11 +119,11 @@ export class UiActionButtonComponent {
|
|
|
107
119
|
}
|
|
108
120
|
}
|
|
109
121
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: UiActionButtonComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: COMPONENT_LIBRARY, optional: true }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
110
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.11", type: UiActionButtonComponent, selector: "ui-action-button", inputs: { disabled: "disabled", descriptor: "descriptor", code: "code", addedCssClass: "addedCssClass" }, outputs: { actionClick: "actionClick", actionDoubleClick: "actionDoubleClick" }, ngImport: i0, template: "<ng-template #buttonTemplate>\r\n @if(compLib === componentLibrary.PRIMENG) {\r\n <button\r\n pButton\r\n pRipple\r\n [smartTooltip]=\"descriptor.tooltip\"\r\n [disabled]=\"!!disabled\"\r\n (click)=\"onActionClicked($event)\"\r\n (dblclick)=\"onActionDoubleClicked($event)\"\r\n [autofocus]=\"false\"\r\n [ngClass]=\"getType()\"\r\n class=\"{{ getbtnClass() }} {{ addedCssClass }}\"\r\n type=\"button\"\r\n >\r\n <div *ngIf=\"isOnlyIcon(); then iconOnly; else text\"></div>\r\n <ng-template #iconOnly>\r\n <smart-icon\r\n *ngIf=\"descriptor.icon\"\r\n [icon]=\"descriptor.icon\"\r\n [color]=\"descriptor.iconColor ?? descriptor.color\"\r\n ></smart-icon>\r\n </ng-template>\r\n <ng-template #text>\r\n <smart-icon\r\n *ngIf=\"descriptor.icon && descriptor.iconPosition === iconPosition().PRE\"\r\n [icon]=\"descriptor.icon\"\r\n [color]=\"descriptor.iconColor ?? descriptor.color\"\r\n ></smart-icon>\r\n {{ descriptor.title }}\r\n <smart-icon\r\n *ngIf=\"descriptor.icon && descriptor.iconPosition === iconPosition().POST\"\r\n [icon]=\"descriptor.icon\"\r\n [color]=\"descriptor.iconColor ?? descriptor.color\"\r\n ></smart-icon>\r\n </ng-template>\r\n </button>\r\n } @else {\r\n <button\r\n mat-button\r\n [smartTooltip]=\"descriptor.tooltip\"\r\n [color]=\"descriptor.color\"\r\n [disabled]=\"!!disabled\"\r\n (click)=\"onActionClicked($event)\"\r\n (dblclick)=\"onActionDoubleClicked($event)\"\r\n [ngClass]=\"getType()\"\r\n class=\"{{ getbtnClass() }} {{ addedCssClass }}\"\r\n type=\"button\"\r\n >\r\n <div *ngIf=\"isOnlyIcon(); then iconOnly; else text\"></div>\r\n <ng-template #iconOnly>\r\n <smart-icon\r\n *ngIf=\"descriptor.icon\"\r\n [icon]=\"descriptor.icon\"\r\n [color]=\"descriptor.iconColor ?? descriptor.color\"\r\n ></smart-icon>\r\n </ng-template>\r\n <ng-template #text>\r\n <smart-icon\r\n *ngIf=\"descriptor.icon && descriptor.iconPosition === iconPosition().PRE\"\r\n [icon]=\"descriptor.icon\"\r\n [color]=\"descriptor.iconColor ?? descriptor.color\"\r\n ></smart-icon>\r\n {{ descriptor.title }}\r\n <smart-icon\r\n *ngIf=\"descriptor.icon && descriptor.iconPosition === iconPosition().POST\"\r\n [icon]=\"descriptor.icon\"\r\n [color]=\"descriptor.iconColor ?? descriptor.color\"\r\n ></smart-icon>\r\n </ng-template>\r\n </button>\r\n }\r\n</ng-template>\r\n
|
|
122
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.11", type: UiActionButtonComponent, selector: "ui-action-button", inputs: { disabled: "disabled", descriptor: "descriptor", code: "code", addedCssClass: "addedCssClass" }, outputs: { actionClick: "actionClick", actionDoubleClick: "actionDoubleClick" }, usesOnChanges: true, ngImport: i0, template: "<ng-container *ngTemplateOutlet=\"buttonWithBadge\"></ng-container>\r\n\r\n<ng-template #buttonWithBadge>\r\n @if (descriptor && descriptor.badge) {\r\n <ui-badge [descriptor]=\"descriptor.badge\">\r\n <ng-container *ngTemplateOutlet=\"buttonTemplate\"></ng-container>\r\n </ui-badge>\r\n } @else {\r\n <ng-container *ngTemplateOutlet=\"buttonTemplate\"></ng-container>\r\n }\r\n</ng-template>\r\n\r\n<ng-template #buttonTemplate>\r\n @if(compLib === componentLibrary.PRIMENG) {\r\n <button\r\n pButton\r\n pRipple\r\n [smartTooltip]=\"descriptor.tooltip\"\r\n [disabled]=\"!!disabled\"\r\n (click)=\"onActionClicked($event, mainActionModel)\"\r\n (dblclick)=\"onActionDoubleClicked($event)\"\r\n [autofocus]=\"false\"\r\n [ngClass]=\"getType()\"\r\n class=\"{{ getbtnClass() }} {{ addedCssClass }}\"\r\n type=\"button\"\r\n >\r\n <div *ngIf=\"isOnlyIcon(); then iconOnly; else text\"></div>\r\n <ng-template #iconOnly>\r\n <smart-icon\r\n *ngIf=\"descriptor.icon\"\r\n [icon]=\"descriptor.icon\"\r\n [color]=\"descriptor.iconColor ?? descriptor.color\"\r\n ></smart-icon>\r\n </ng-template>\r\n <ng-template #text>\r\n <smart-icon\r\n *ngIf=\"descriptor.icon && descriptor.iconPosition === iconPosition().PRE\"\r\n [icon]=\"descriptor.icon\"\r\n [color]=\"descriptor.iconColor ?? descriptor.color\"\r\n ></smart-icon>\r\n {{ descriptor.title }}\r\n <smart-icon\r\n *ngIf=\"descriptor.icon && descriptor.iconPosition === iconPosition().POST\"\r\n [icon]=\"descriptor.icon\"\r\n [color]=\"descriptor.iconColor ?? descriptor.color\"\r\n ></smart-icon>\r\n </ng-template>\r\n </button>\r\n } @else {\r\n <button\r\n mat-button\r\n [smartTooltip]=\"descriptor.tooltip\"\r\n [color]=\"descriptor.color\"\r\n [disabled]=\"!!disabled\"\r\n (click)=\"onActionClicked($event, mainActionModel)\"\r\n (dblclick)=\"onActionDoubleClicked($event)\"\r\n [ngClass]=\"getType()\"\r\n class=\"{{ getbtnClass() }} {{ addedCssClass }}\"\r\n type=\"button\"\r\n >\r\n <div *ngIf=\"isOnlyIcon(); then iconOnly; else text\"></div>\r\n <ng-template #iconOnly>\r\n <smart-icon\r\n *ngIf=\"descriptor.icon\"\r\n [icon]=\"descriptor.icon\"\r\n [color]=\"descriptor.iconColor ?? descriptor.color\"\r\n ></smart-icon>\r\n </ng-template>\r\n <ng-template #text>\r\n <smart-icon\r\n *ngIf=\"descriptor.icon && descriptor.iconPosition === iconPosition().PRE\"\r\n [icon]=\"descriptor.icon\"\r\n [color]=\"descriptor.iconColor ?? descriptor.color\"\r\n ></smart-icon>\r\n {{ descriptor.title }}\r\n <smart-icon\r\n *ngIf=\"descriptor.icon && descriptor.iconPosition === iconPosition().POST\"\r\n [icon]=\"descriptor.icon\"\r\n [color]=\"descriptor.iconColor ?? descriptor.color\"\r\n ></smart-icon>\r\n </ng-template>\r\n </button>\r\n }\r\n</ng-template>\r\n", styles: [":host ::ng-deep button{display:flex;gap:1rem;align-items:center;justify-content:center;line-height:1;padding:.75rem 1rem}:host{height:fit-content;width:fit-content;padding:unset;margin:unset}\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.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i2.MatButton, selector: " button[mat-button], button[mat-raised-button], button[mat-flat-button], button[mat-stroked-button] ", exportAs: ["matButton"] }, { kind: "directive", type: i3.ButtonDirective, selector: "[pButton]", inputs: ["iconPos", "loadingIcon", "label", "icon", "loading", "severity", "raised", "rounded", "text", "outlined", "size", "plain"] }, { kind: "component", type: i4.SmartIconComponent, selector: "smart-icon", inputs: ["icon", "color"] }, { kind: "directive", type: i5.SmartTooltipDirective, selector: "[smartTooltip]", inputs: ["smartTooltip"] }, { kind: "component", type: i6.ActionBadgeComponent, selector: "ui-badge", inputs: ["descriptor", "inputValue"] }] }); }
|
|
111
123
|
}
|
|
112
124
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: UiActionButtonComponent, decorators: [{
|
|
113
125
|
type: Component,
|
|
114
|
-
args: [{ selector: 'ui-action-button', template: "<ng-template #buttonTemplate>\r\n @if(compLib === componentLibrary.PRIMENG) {\r\n <button\r\n pButton\r\n pRipple\r\n [smartTooltip]=\"descriptor.tooltip\"\r\n [disabled]=\"!!disabled\"\r\n (click)=\"onActionClicked($event)\"\r\n (dblclick)=\"onActionDoubleClicked($event)\"\r\n [autofocus]=\"false\"\r\n [ngClass]=\"getType()\"\r\n class=\"{{ getbtnClass() }} {{ addedCssClass }}\"\r\n type=\"button\"\r\n >\r\n <div *ngIf=\"isOnlyIcon(); then iconOnly; else text\"></div>\r\n <ng-template #iconOnly>\r\n <smart-icon\r\n *ngIf=\"descriptor.icon\"\r\n [icon]=\"descriptor.icon\"\r\n [color]=\"descriptor.iconColor ?? descriptor.color\"\r\n ></smart-icon>\r\n </ng-template>\r\n <ng-template #text>\r\n <smart-icon\r\n *ngIf=\"descriptor.icon && descriptor.iconPosition === iconPosition().PRE\"\r\n [icon]=\"descriptor.icon\"\r\n [color]=\"descriptor.iconColor ?? descriptor.color\"\r\n ></smart-icon>\r\n {{ descriptor.title }}\r\n <smart-icon\r\n *ngIf=\"descriptor.icon && descriptor.iconPosition === iconPosition().POST\"\r\n [icon]=\"descriptor.icon\"\r\n [color]=\"descriptor.iconColor ?? descriptor.color\"\r\n ></smart-icon>\r\n </ng-template>\r\n </button>\r\n } @else {\r\n <button\r\n mat-button\r\n [smartTooltip]=\"descriptor.tooltip\"\r\n [color]=\"descriptor.color\"\r\n [disabled]=\"!!disabled\"\r\n (click)=\"onActionClicked($event)\"\r\n (dblclick)=\"onActionDoubleClicked($event)\"\r\n [ngClass]=\"getType()\"\r\n class=\"{{ getbtnClass() }} {{ addedCssClass }}\"\r\n type=\"button\"\r\n >\r\n <div *ngIf=\"isOnlyIcon(); then iconOnly; else text\"></div>\r\n <ng-template #iconOnly>\r\n <smart-icon\r\n *ngIf=\"descriptor.icon\"\r\n [icon]=\"descriptor.icon\"\r\n [color]=\"descriptor.iconColor ?? descriptor.color\"\r\n ></smart-icon>\r\n </ng-template>\r\n <ng-template #text>\r\n <smart-icon\r\n *ngIf=\"descriptor.icon && descriptor.iconPosition === iconPosition().PRE\"\r\n [icon]=\"descriptor.icon\"\r\n [color]=\"descriptor.iconColor ?? descriptor.color\"\r\n ></smart-icon>\r\n {{ descriptor.title }}\r\n <smart-icon\r\n *ngIf=\"descriptor.icon && descriptor.iconPosition === iconPosition().POST\"\r\n [icon]=\"descriptor.icon\"\r\n [color]=\"descriptor.iconColor ?? descriptor.color\"\r\n ></smart-icon>\r\n </ng-template>\r\n </button>\r\n }\r\n</ng-template>\r\n
|
|
126
|
+
args: [{ selector: 'ui-action-button', template: "<ng-container *ngTemplateOutlet=\"buttonWithBadge\"></ng-container>\r\n\r\n<ng-template #buttonWithBadge>\r\n @if (descriptor && descriptor.badge) {\r\n <ui-badge [descriptor]=\"descriptor.badge\">\r\n <ng-container *ngTemplateOutlet=\"buttonTemplate\"></ng-container>\r\n </ui-badge>\r\n } @else {\r\n <ng-container *ngTemplateOutlet=\"buttonTemplate\"></ng-container>\r\n }\r\n</ng-template>\r\n\r\n<ng-template #buttonTemplate>\r\n @if(compLib === componentLibrary.PRIMENG) {\r\n <button\r\n pButton\r\n pRipple\r\n [smartTooltip]=\"descriptor.tooltip\"\r\n [disabled]=\"!!disabled\"\r\n (click)=\"onActionClicked($event, mainActionModel)\"\r\n (dblclick)=\"onActionDoubleClicked($event)\"\r\n [autofocus]=\"false\"\r\n [ngClass]=\"getType()\"\r\n class=\"{{ getbtnClass() }} {{ addedCssClass }}\"\r\n type=\"button\"\r\n >\r\n <div *ngIf=\"isOnlyIcon(); then iconOnly; else text\"></div>\r\n <ng-template #iconOnly>\r\n <smart-icon\r\n *ngIf=\"descriptor.icon\"\r\n [icon]=\"descriptor.icon\"\r\n [color]=\"descriptor.iconColor ?? descriptor.color\"\r\n ></smart-icon>\r\n </ng-template>\r\n <ng-template #text>\r\n <smart-icon\r\n *ngIf=\"descriptor.icon && descriptor.iconPosition === iconPosition().PRE\"\r\n [icon]=\"descriptor.icon\"\r\n [color]=\"descriptor.iconColor ?? descriptor.color\"\r\n ></smart-icon>\r\n {{ descriptor.title }}\r\n <smart-icon\r\n *ngIf=\"descriptor.icon && descriptor.iconPosition === iconPosition().POST\"\r\n [icon]=\"descriptor.icon\"\r\n [color]=\"descriptor.iconColor ?? descriptor.color\"\r\n ></smart-icon>\r\n </ng-template>\r\n </button>\r\n } @else {\r\n <button\r\n mat-button\r\n [smartTooltip]=\"descriptor.tooltip\"\r\n [color]=\"descriptor.color\"\r\n [disabled]=\"!!disabled\"\r\n (click)=\"onActionClicked($event, mainActionModel)\"\r\n (dblclick)=\"onActionDoubleClicked($event)\"\r\n [ngClass]=\"getType()\"\r\n class=\"{{ getbtnClass() }} {{ addedCssClass }}\"\r\n type=\"button\"\r\n >\r\n <div *ngIf=\"isOnlyIcon(); then iconOnly; else text\"></div>\r\n <ng-template #iconOnly>\r\n <smart-icon\r\n *ngIf=\"descriptor.icon\"\r\n [icon]=\"descriptor.icon\"\r\n [color]=\"descriptor.iconColor ?? descriptor.color\"\r\n ></smart-icon>\r\n </ng-template>\r\n <ng-template #text>\r\n <smart-icon\r\n *ngIf=\"descriptor.icon && descriptor.iconPosition === iconPosition().PRE\"\r\n [icon]=\"descriptor.icon\"\r\n [color]=\"descriptor.iconColor ?? descriptor.color\"\r\n ></smart-icon>\r\n {{ descriptor.title }}\r\n <smart-icon\r\n *ngIf=\"descriptor.icon && descriptor.iconPosition === iconPosition().POST\"\r\n [icon]=\"descriptor.icon\"\r\n [color]=\"descriptor.iconColor ?? descriptor.color\"\r\n ></smart-icon>\r\n </ng-template>\r\n </button>\r\n }\r\n</ng-template>\r\n", styles: [":host ::ng-deep button{display:flex;gap:1rem;align-items:center;justify-content:center;line-height:1;padding:.75rem 1rem}:host{height:fit-content;width:fit-content;padding:unset;margin:unset}\n"] }]
|
|
115
127
|
}], ctorParameters: () => [{ type: i0.ChangeDetectorRef }, { type: i7.ComponentLibrary, decorators: [{
|
|
116
128
|
type: Inject,
|
|
117
129
|
args: [COMPONENT_LIBRARY]
|
|
@@ -130,4 +142,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImpo
|
|
|
130
142
|
}], actionDoubleClick: [{
|
|
131
143
|
type: Output
|
|
132
144
|
}] } });
|
|
133
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ui-action-button.component.js","sourceRoot":"","sources":["../../../../../../../projects/smart-ng-client/src/lib/view-context/smart-ui-action/ui-action-button/ui-action-button.component.ts","../../../../../../../projects/smart-ng-client/src/lib/view-context/smart-ui-action/ui-action-button/ui-action-button.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  ChangeDetectorRef,\r\n  Component,\r\n  EventEmitter,\r\n  Inject,\r\n  Input,\r\n  OnDestroy,\r\n  OnInit,\r\n  Optional,\r\n  Output,\r\n} from '@angular/core';\r\nimport { UiActionModel } from '../ui-action.model';\r\nimport { TooltipPosition } from '@angular/material/tooltip';\r\nimport { Subject } from 'rxjs';\r\nimport { COMPONENT_LIBRARY, ComponentLibrary } from '../../utility/componentLibrary';\r\nimport { UiActionButtonType } from '../../api/model/uiActionButtonType';\r\nimport { IconPosition } from '../../api/model/iconPosition';\r\nimport { UiActionTooltipTooltipPositionEnum } from '../../api/model/uiActionTooltip';\r\nimport { UiActionDescriptor } from '../../api';\r\n\r\n@Component({\r\n  selector: 'ui-action-button',\r\n  templateUrl: './ui-action-button.component.html',\r\n  styleUrl: './ui-action-button.component.css',\r\n})\r\nexport class UiActionButtonComponent implements OnInit, OnDestroy {\r\n  private _destroy$: Subject<void> = new Subject();\r\n\r\n  componentLibrary = ComponentLibrary;\r\n  compLib: ComponentLibrary;\r\n\r\n  pressedButtonActive: boolean = true;\r\n\r\n  @Input() disabled?: boolean;\r\n  @Input() descriptor!: UiActionDescriptor;\r\n  @Input() code?: string;\r\n  @Input() addedCssClass?: string;\r\n\r\n  @Output() actionClick = new EventEmitter<{\r\n    event: any;\r\n    descriptor: UiActionDescriptor;\r\n    code?: string;\r\n  }>();\r\n  @Output() actionDoubleClick = new EventEmitter<{\r\n    event: any;\r\n    descriptor: UiActionDescriptor;\r\n    code?: string;\r\n  }>();\r\n\r\n  constructor(\r\n    public changeDetector: ChangeDetectorRef,\r\n    @Inject(COMPONENT_LIBRARY) @Optional() compLib?: ComponentLibrary\r\n  ) {\r\n    this.compLib = compLib ?? ComponentLibrary.PRIMENG;\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    if (!this.descriptor) {\r\n      throw new Error(\r\n        'UiActionButtonComponent: \"descriptor\" input is required but was not provided.'\r\n      );\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  async onActionClicked(event: any): Promise<void> {\r\n    event.stopPropagation();\r\n    this.actionClick.emit({\r\n      event,\r\n      code: this.code,\r\n      descriptor: this.descriptor,\r\n    });\r\n  }\r\n\r\n  onActionDoubleClicked(event: any): void {\r\n    event.stopPropagation();\r\n    this.actionDoubleClick.emit({\r\n      event,\r\n      code: this.code,\r\n      descriptor: this.descriptor,\r\n    });\r\n  }\r\n\r\n  iconPosition(): typeof IconPosition {\r\n    return IconPosition;\r\n  }\r\n\r\n  isOnlyIcon(): boolean {\r\n    return (\r\n      this.descriptor?.type === UiActionButtonType.ICON ||\r\n      this.descriptor?.type === UiActionButtonType.MINI_FAB ||\r\n      this.descriptor?.type === UiActionButtonType.FAB\r\n    );\r\n  }\r\n\r\n  getbtnClass(): string {\r\n    if (this.descriptor.color) {\r\n      return 'p-button-' + this.descriptor?.color;\r\n    }\r\n    return '';\r\n  }\r\n\r\n  getType(): any {\r\n    if (this.compLib === ComponentLibrary.PRIMENG) {\r\n      switch (this.descriptor.type) {\r\n        case UiActionButtonType.NORMAL:\r\n          return {\r\n            'p-button-text': true,\r\n            'p-button-rounded': true,\r\n          };\r\n        case UiActionButtonType.FLAT:\r\n          return { 'p-button-raised': true, 'p-button-rounded': true };\r\n        case UiActionButtonType.RAISED:\r\n          return { 'p-button-raised': true, 'p-button-rounded': true };\r\n        case UiActionButtonType.STROKED:\r\n          return { 'p-button-outlined': true, 'p-button-rounded': true };\r\n        case UiActionButtonType.MINI_FAB:\r\n          return { 'p-button-rounded': true, 'p-button-text': true, 'p-button-raised': true };\r\n        default:\r\n          return {\r\n            'p-button-text': true,\r\n            'p-button-raised': true,\r\n            'p-button-rounded': true,\r\n            'p-button-outlined': true,\r\n          };\r\n      }\r\n    } else {\r\n      switch (this.descriptor.type) {\r\n        case UiActionButtonType.NORMAL:\r\n          return 'mat-mdc-button';\r\n        case UiActionButtonType.FLAT:\r\n          return 'mat-mdc-flat-button';\r\n        case UiActionButtonType.RAISED:\r\n          return 'mat-mdc-raised-button';\r\n        case UiActionButtonType.STROKED:\r\n          return 'mat-mdc-stroked-button';\r\n        case UiActionButtonType.ICON:\r\n          return 'mat-mdc-icon-button';\r\n        case UiActionButtonType.MINI_FAB:\r\n          return 'mat-mdc-mini-fab';\r\n        case UiActionButtonType.FAB:\r\n          return 'mat-mdc-fab';\r\n        default:\r\n          return `mat-button`;\r\n      }\r\n    }\r\n  }\r\n}\r\n","<ng-template #buttonTemplate>\r\n  @if(compLib === componentLibrary.PRIMENG) {\r\n  <button\r\n    pButton\r\n    pRipple\r\n    [smartTooltip]=\"descriptor.tooltip\"\r\n    [disabled]=\"!!disabled\"\r\n    (click)=\"onActionClicked($event)\"\r\n    (dblclick)=\"onActionDoubleClicked($event)\"\r\n    [autofocus]=\"false\"\r\n    [ngClass]=\"getType()\"\r\n    class=\"{{ getbtnClass() }} {{ addedCssClass }}\"\r\n    type=\"button\"\r\n  >\r\n    <div *ngIf=\"isOnlyIcon(); then iconOnly; else text\"></div>\r\n    <ng-template #iconOnly>\r\n      <smart-icon\r\n        *ngIf=\"descriptor.icon\"\r\n        [icon]=\"descriptor.icon\"\r\n        [color]=\"descriptor.iconColor ?? descriptor.color\"\r\n      ></smart-icon>\r\n    </ng-template>\r\n    <ng-template #text>\r\n      <smart-icon\r\n        *ngIf=\"descriptor.icon && descriptor.iconPosition === iconPosition().PRE\"\r\n        [icon]=\"descriptor.icon\"\r\n        [color]=\"descriptor.iconColor ?? descriptor.color\"\r\n      ></smart-icon>\r\n      {{ descriptor.title }}\r\n      <smart-icon\r\n        *ngIf=\"descriptor.icon && descriptor.iconPosition === iconPosition().POST\"\r\n        [icon]=\"descriptor.icon\"\r\n        [color]=\"descriptor.iconColor ?? descriptor.color\"\r\n      ></smart-icon>\r\n    </ng-template>\r\n  </button>\r\n  } @else {\r\n  <button\r\n    mat-button\r\n    [smartTooltip]=\"descriptor.tooltip\"\r\n    [color]=\"descriptor.color\"\r\n    [disabled]=\"!!disabled\"\r\n    (click)=\"onActionClicked($event)\"\r\n    (dblclick)=\"onActionDoubleClicked($event)\"\r\n    [ngClass]=\"getType()\"\r\n    class=\"{{ getbtnClass() }} {{ addedCssClass }}\"\r\n    type=\"button\"\r\n  >\r\n    <div *ngIf=\"isOnlyIcon(); then iconOnly; else text\"></div>\r\n    <ng-template #iconOnly>\r\n      <smart-icon\r\n        *ngIf=\"descriptor.icon\"\r\n        [icon]=\"descriptor.icon\"\r\n        [color]=\"descriptor.iconColor ?? descriptor.color\"\r\n      ></smart-icon>\r\n    </ng-template>\r\n    <ng-template #text>\r\n      <smart-icon\r\n        *ngIf=\"descriptor.icon && descriptor.iconPosition === iconPosition().PRE\"\r\n        [icon]=\"descriptor.icon\"\r\n        [color]=\"descriptor.iconColor ?? descriptor.color\"\r\n      ></smart-icon>\r\n      {{ descriptor.title }}\r\n      <smart-icon\r\n        *ngIf=\"descriptor.icon && descriptor.iconPosition === iconPosition().POST\"\r\n        [icon]=\"descriptor.icon\"\r\n        [color]=\"descriptor.iconColor ?? descriptor.color\"\r\n      ></smart-icon>\r\n    </ng-template>\r\n  </button>\r\n  }\r\n</ng-template>\r\n\r\n@if (descriptor && descriptor.badge) {\r\n\r\n<ui-badge [descriptor]=\"descriptor.badge\">\r\n  <ng-container *ngTemplateOutlet=\"buttonTemplate\"></ng-container>\r\n</ui-badge>\r\n} @else {\r\n\r\n<ng-container *ngTemplateOutlet=\"buttonTemplate\"></ng-container>\r\n}\r\n"]}
|
|
145
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ui-action-button.component.js","sourceRoot":"","sources":["../../../../../../../projects/smart-ng-client/src/lib/view-context/smart-ui-action/ui-action-button/ui-action-button.component.ts","../../../../../../../projects/smart-ng-client/src/lib/view-context/smart-ui-action/ui-action-button/ui-action-button.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  ChangeDetectorRef,\r\n  Component,\r\n  ElementRef,\r\n  EventEmitter,\r\n  Inject,\r\n  Input,\r\n  OnDestroy,\r\n  OnInit,\r\n  Optional,\r\n  Output,\r\n  SimpleChanges,\r\n  ViewChild,\r\n} from '@angular/core';\r\nimport { UiActionModel } from '../ui-action.model';\r\nimport { Subject } from 'rxjs';\r\nimport { COMPONENT_LIBRARY, ComponentLibrary } from '../../utility/componentLibrary';\r\nimport { UiActionButtonType } from '../../api/model/uiActionButtonType';\r\nimport { IconPosition } from '../../api/model/iconPosition';\r\nimport { UiAction, UiActionDescriptor } from '../../api';\r\n\r\n@Component({\r\n  selector: 'ui-action-button',\r\n  templateUrl: './ui-action-button.component.html',\r\n  styleUrl: './ui-action-button.component.css',\r\n})\r\nexport class UiActionButtonComponent implements OnInit, OnDestroy {\r\n  private _destroy$: Subject<void> = new Subject();\r\n\r\n  @Input() disabled?: boolean;\r\n  @Input() descriptor!: UiActionDescriptor;\r\n  @Input() code?: string;\r\n  @Input() addedCssClass?: string;\r\n\r\n  @Output() actionClick = new EventEmitter<{\r\n    descriptor?: UiActionDescriptor;\r\n    code?: string;\r\n    uiAction?: UiAction;\r\n  }>();\r\n  @Output() actionDoubleClick = new EventEmitter<{\r\n    event: any;\r\n    descriptor?: UiActionDescriptor;\r\n    code?: string;\r\n  }>();\r\n\r\n  componentLibrary = ComponentLibrary;\r\n  compLib: ComponentLibrary;\r\n  mainActionModel!: UiActionModel;\r\n\r\n  pressedButtonActive: boolean = true;\r\n  menuOpened: boolean = false;\r\n\r\n  constructor(\r\n    public changeDetector: ChangeDetectorRef,\r\n    @Inject(COMPONENT_LIBRARY) @Optional() compLib?: ComponentLibrary\r\n  ) {\r\n    this.compLib = compLib ?? ComponentLibrary.PRIMENG;\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    if (!this.descriptor) {\r\n      throw new Error(\r\n        'UiActionButtonComponent: \"descriptor\" input is required but was not provided.'\r\n      );\r\n    }\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    if (changes['descriptor'] && this.descriptor) {\r\n      this.mainActionModel = {\r\n        descriptor: this.descriptor,\r\n        uiAction: {\r\n          descriptor: this.descriptor,\r\n          code: this.code,\r\n          disabled: this.disabled ?? false,\r\n        },\r\n      } as UiActionModel;\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  async onActionClicked(event: any, model: UiActionModel): Promise<void> {\r\n    event.stopPropagation();\r\n    this.actionClick.emit({\r\n      code: model.uiAction.code,\r\n      descriptor: model.descriptor!,\r\n    });\r\n  }\r\n\r\n  onActionDoubleClicked(event: any): void {\r\n    event.stopPropagation();\r\n    this.actionDoubleClick.emit({\r\n      event,\r\n      code: this.code,\r\n      descriptor: this.descriptor,\r\n    });\r\n  }\r\n\r\n  iconPosition(): typeof IconPosition {\r\n    return IconPosition;\r\n  }\r\n\r\n  isOnlyIcon(): boolean {\r\n    return (\r\n      this.descriptor?.type === UiActionButtonType.ICON ||\r\n      this.descriptor?.type === UiActionButtonType.MINI_FAB ||\r\n      this.descriptor?.type === UiActionButtonType.FAB\r\n    );\r\n  }\r\n\r\n  getbtnClass(): string {\r\n    if (this.descriptor.color) {\r\n      return 'p-button-' + this.descriptor?.color;\r\n    }\r\n    return '';\r\n  }\r\n\r\n  getType(): any {\r\n    if (this.compLib === ComponentLibrary.PRIMENG) {\r\n      switch (this.descriptor.type) {\r\n        case UiActionButtonType.NORMAL:\r\n          return {\r\n            'p-button-text': true,\r\n            'p-button-rounded': true,\r\n          };\r\n        case UiActionButtonType.FLAT:\r\n          return { 'p-button-raised': true, 'p-button-rounded': true };\r\n        case UiActionButtonType.RAISED:\r\n          return { 'p-button-raised': true, 'p-button-rounded': true };\r\n        case UiActionButtonType.STROKED:\r\n          return { 'p-button-outlined': true, 'p-button-rounded': true };\r\n        case UiActionButtonType.MINI_FAB:\r\n          return { 'p-button-rounded': true, 'p-button-text': true, 'p-button-raised': true };\r\n        default:\r\n          return {\r\n            'p-button-text': true,\r\n            'p-button-raised': true,\r\n            'p-button-rounded': true,\r\n            'p-button-outlined': true,\r\n          };\r\n      }\r\n    } else {\r\n      switch (this.descriptor.type) {\r\n        case UiActionButtonType.NORMAL:\r\n          return 'mat-mdc-button';\r\n        case UiActionButtonType.FLAT:\r\n          return 'mat-mdc-flat-button';\r\n        case UiActionButtonType.RAISED:\r\n          return 'mat-mdc-raised-button';\r\n        case UiActionButtonType.STROKED:\r\n          return 'mat-mdc-stroked-button';\r\n        case UiActionButtonType.ICON:\r\n          return 'mat-mdc-icon-button';\r\n        case UiActionButtonType.MINI_FAB:\r\n          return 'mat-mdc-mini-fab';\r\n        case UiActionButtonType.FAB:\r\n          return 'mat-mdc-fab';\r\n        default:\r\n          return `mat-button`;\r\n      }\r\n    }\r\n  }\r\n}\r\n","<ng-container *ngTemplateOutlet=\"buttonWithBadge\"></ng-container>\r\n\r\n<ng-template #buttonWithBadge>\r\n  @if (descriptor && descriptor.badge) {\r\n  <ui-badge [descriptor]=\"descriptor.badge\">\r\n    <ng-container *ngTemplateOutlet=\"buttonTemplate\"></ng-container>\r\n  </ui-badge>\r\n  } @else {\r\n  <ng-container *ngTemplateOutlet=\"buttonTemplate\"></ng-container>\r\n  }\r\n</ng-template>\r\n\r\n<ng-template #buttonTemplate>\r\n  @if(compLib === componentLibrary.PRIMENG) {\r\n  <button\r\n    pButton\r\n    pRipple\r\n    [smartTooltip]=\"descriptor.tooltip\"\r\n    [disabled]=\"!!disabled\"\r\n    (click)=\"onActionClicked($event, mainActionModel)\"\r\n    (dblclick)=\"onActionDoubleClicked($event)\"\r\n    [autofocus]=\"false\"\r\n    [ngClass]=\"getType()\"\r\n    class=\"{{ getbtnClass() }} {{ addedCssClass }}\"\r\n    type=\"button\"\r\n  >\r\n    <div *ngIf=\"isOnlyIcon(); then iconOnly; else text\"></div>\r\n    <ng-template #iconOnly>\r\n      <smart-icon\r\n        *ngIf=\"descriptor.icon\"\r\n        [icon]=\"descriptor.icon\"\r\n        [color]=\"descriptor.iconColor ?? descriptor.color\"\r\n      ></smart-icon>\r\n    </ng-template>\r\n    <ng-template #text>\r\n      <smart-icon\r\n        *ngIf=\"descriptor.icon && descriptor.iconPosition === iconPosition().PRE\"\r\n        [icon]=\"descriptor.icon\"\r\n        [color]=\"descriptor.iconColor ?? descriptor.color\"\r\n      ></smart-icon>\r\n      {{ descriptor.title }}\r\n      <smart-icon\r\n        *ngIf=\"descriptor.icon && descriptor.iconPosition === iconPosition().POST\"\r\n        [icon]=\"descriptor.icon\"\r\n        [color]=\"descriptor.iconColor ?? descriptor.color\"\r\n      ></smart-icon>\r\n    </ng-template>\r\n  </button>\r\n  } @else {\r\n  <button\r\n    mat-button\r\n    [smartTooltip]=\"descriptor.tooltip\"\r\n    [color]=\"descriptor.color\"\r\n    [disabled]=\"!!disabled\"\r\n    (click)=\"onActionClicked($event, mainActionModel)\"\r\n    (dblclick)=\"onActionDoubleClicked($event)\"\r\n    [ngClass]=\"getType()\"\r\n    class=\"{{ getbtnClass() }} {{ addedCssClass }}\"\r\n    type=\"button\"\r\n  >\r\n    <div *ngIf=\"isOnlyIcon(); then iconOnly; else text\"></div>\r\n    <ng-template #iconOnly>\r\n      <smart-icon\r\n        *ngIf=\"descriptor.icon\"\r\n        [icon]=\"descriptor.icon\"\r\n        [color]=\"descriptor.iconColor ?? descriptor.color\"\r\n      ></smart-icon>\r\n    </ng-template>\r\n    <ng-template #text>\r\n      <smart-icon\r\n        *ngIf=\"descriptor.icon && descriptor.iconPosition === iconPosition().PRE\"\r\n        [icon]=\"descriptor.icon\"\r\n        [color]=\"descriptor.iconColor ?? descriptor.color\"\r\n      ></smart-icon>\r\n      {{ descriptor.title }}\r\n      <smart-icon\r\n        *ngIf=\"descriptor.icon && descriptor.iconPosition === iconPosition().POST\"\r\n        [icon]=\"descriptor.icon\"\r\n        [color]=\"descriptor.iconColor ?? descriptor.color\"\r\n      ></smart-icon>\r\n    </ng-template>\r\n  </button>\r\n  }\r\n</ng-template>\r\n"]}
|