@nu-art/thunderstorm-frontend 0.400.5
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/_ats/ATS_ActionProcessor/ATS_ActionProcessor.d.ts +17 -0
- package/_ats/ATS_ActionProcessor/ATS_ActionProcessor.js +52 -0
- package/_ats/ATS_ActionProcessor/ATS_ActionProcessor.scss +43 -0
- package/_ats/ATS_AppConfigEditor/ATS_AppConfigEditor.d.ts +25 -0
- package/_ats/ATS_AppConfigEditor/ATS_AppConfigEditor.js +88 -0
- package/_ats/ATS_AppConfigEditor/ATS_AppConfigEditor.scss +117 -0
- package/_ats/ATS_CollectionUpgrades/ATS_CollectionUpgrades.d.ts +17 -0
- package/_ats/ATS_CollectionUpgrades/ATS_CollectionUpgrades.js +45 -0
- package/_ats/ATS_CollectionUpgrades/ATS_CollectionUpgrades.scss +24 -0
- package/_ats/ATS_CrudOperations/ATS_CrudOperations.d.ts +29 -0
- package/_ats/ATS_CrudOperations/ATS_CrudOperations.js +93 -0
- package/_ats/ATS_CrudOperations/ATS_CrudOperations.scss +46 -0
- package/_ats/ATS_CrudOperations/ui-components.d.ts +24 -0
- package/_ats/ATS_CrudOperations/ui-components.js +11 -0
- package/_ats/ATS_EditableItem/ATS_EditableItem.d.ts +16 -0
- package/_ats/ATS_EditableItem/ATS_EditableItem.js +48 -0
- package/_ats/ATS_IDBCacheComparison/ATS_IDBCacheComparison.d.ts +18 -0
- package/_ats/ATS_IDBCacheComparison/ATS_IDBCacheComparison.js +28 -0
- package/_ats/ATS_IDBCacheComparison/ATS_IDBCacheComparison.scss +7 -0
- package/_ats/ATS_IDBCacheComparison/Component_CollectionGrid.d.ts +23 -0
- package/_ats/ATS_IDBCacheComparison/Component_CollectionGrid.js +66 -0
- package/_ats/ATS_IDBCacheComparison/Component_CollectionGrid.scss +52 -0
- package/_ats/ATS_IDBCacheComparison/Dialog_IDBCacheComparison.d.ts +17 -0
- package/_ats/ATS_IDBCacheComparison/Dialog_IDBCacheComparison.js +30 -0
- package/_ats/ATS_IDBCacheComparison/Dialog_IDBCacheComparison.scss +25 -0
- package/_ats/ATS_Printables/ATS_AbstractPrintable.d.ts +16 -0
- package/_ats/ATS_Printables/ATS_AbstractPrintable.js +37 -0
- package/_ats/ATS_Printables/ATS_Printable.d.ts +13 -0
- package/_ats/ATS_Printables/ATS_Printable.js +45 -0
- package/_ats/ATS_Printables/ATS_Printable.scss +40 -0
- package/_ats/ATS_ProtoComponent/ATS_ProtoComponent.d.ts +33 -0
- package/_ats/ATS_ProtoComponent/ATS_ProtoComponent.js +80 -0
- package/_ats/ATS_ProtoComponent/ATS_ProtoComponent.scss +19 -0
- package/_ats/ATS_SyncEnv/ATS_SyncEnv.d.ts +51 -0
- package/_ats/ATS_SyncEnv/ATS_SyncEnv.js +215 -0
- package/_ats/ATS_SyncEnv/ATS_SyncEnv.scss +172 -0
- package/_ats/ATS_Toaster/ATS_Toaster.d.ts +23 -0
- package/_ats/ATS_Toaster/ATS_Toaster.js +48 -0
- package/_ats/ATS_Toaster/ATS_Toaster.scss +2 -0
- package/_ats/ATS_Toaster/index.d.ts +1 -0
- package/_ats/ATS_Toaster/index.js +1 -0
- package/_ats/dialogs/Dialog_ActionProcessorConfirmation/Dialog_ActionProcessorConfirmation.d.ts +18 -0
- package/_ats/dialogs/Dialog_ActionProcessorConfirmation/Dialog_ActionProcessorConfirmation.js +41 -0
- package/_ats/dialogs/Dialog_ActionProcessorConfirmation/Dialog_ActionProcessorConfirmation.scss +71 -0
- package/_ats/dialogs/index.d.ts +1 -0
- package/_ats/dialogs/index.js +1 -0
- package/_ats/index.d.ts +8 -0
- package/_ats/index.js +8 -0
- package/_entity/app-config/ModuleFE_AppConfig.d.ts +24 -0
- package/_entity/app-config/ModuleFE_AppConfig.js +52 -0
- package/_entity/app-config/index.d.ts +2 -0
- package/_entity/app-config/index.js +2 -0
- package/_entity/app-config/module-pack.d.ts +1 -0
- package/_entity/app-config/module-pack.js +2 -0
- package/_entity/editable-test/ModuleFE_EditableTest.d.ts +11 -0
- package/_entity/editable-test/ModuleFE_EditableTest.js +12 -0
- package/_entity/editable-test/index.d.ts +2 -0
- package/_entity/editable-test/index.js +2 -0
- package/_entity/editable-test/module-pack.d.ts +1 -0
- package/_entity/editable-test/module-pack.js +2 -0
- package/_entity/editable-test/ui-components.d.ts +37 -0
- package/_entity/editable-test/ui-components.js +21 -0
- package/_entity.d.ts +2 -0
- package/_entity.js +2 -0
- package/_to-refactor/MenuAndButton.d.ts +1 -0
- package/_to-refactor/MenuAndButton.js +87 -0
- package/behavior-functions/index.d.ts +1 -0
- package/behavior-functions/index.js +1 -0
- package/behavior-functions/scroll-into-view.d.ts +6 -0
- package/behavior-functions/scroll-into-view.js +55 -0
- package/component-modules/ModuleFE_Dialog.d.ts +27 -0
- package/component-modules/ModuleFE_Dialog.js +48 -0
- package/component-modules/ModuleFE_Notifications.d.ts +45 -0
- package/component-modules/ModuleFE_Notifications.js +133 -0
- package/component-modules/ModuleFE_Toaster.d.ts +28 -0
- package/component-modules/ModuleFE_Toaster.js +97 -0
- package/component-modules/mouse-interactivity/ModuleFE_MouseInteractivity.d.ts +9 -0
- package/component-modules/mouse-interactivity/ModuleFE_MouseInteractivity.js +35 -0
- package/component-modules/mouse-interactivity/helper-functions.d.ts +108 -0
- package/component-modules/mouse-interactivity/helper-functions.js +339 -0
- package/component-modules/mouse-interactivity/index.d.ts +3 -0
- package/component-modules/mouse-interactivity/index.js +3 -0
- package/component-modules/mouse-interactivity/types.d.ts +37 -0
- package/component-modules/mouse-interactivity/types.js +2 -0
- package/components/ActionButton.d.ts +7 -0
- package/components/ActionButton.js +29 -0
- package/components/AwaitModules/AwaitModules.d.ts +40 -0
- package/components/AwaitModules/AwaitModules.js +95 -0
- package/components/AwaitModules/AwaitModules.scss +53 -0
- package/components/AwaitSync/AwaitSync.d.ts +18 -0
- package/components/AwaitSync/AwaitSync.js +25 -0
- package/components/AwaitSync/AwaitSync.scss +13 -0
- package/components/Button/ATS_Button.d.ts +21 -0
- package/components/Button/ATS_Button.js +66 -0
- package/components/Button/ATS_Button.scss +19 -0
- package/components/Button/Button.d.ts +40 -0
- package/components/Button/Button.js +94 -0
- package/components/Button/Button.scss +151 -0
- package/components/FrameLayout/FrameLayout.d.ts +7 -0
- package/components/FrameLayout/FrameLayout.js +10 -0
- package/components/FrameLayout/FrameLayout.scss +5 -0
- package/components/FrameLayout/index.d.ts +1 -0
- package/components/FrameLayout/index.js +1 -0
- package/components/GenericDropDown/GenericDropDownV3.d.ts +108 -0
- package/components/GenericDropDown/GenericDropDownV3.js +98 -0
- package/components/GenericDropDown/index.d.ts +1 -0
- package/components/GenericDropDown/index.js +1 -0
- package/components/GenericRenderer/Component_GenericRenderer.d.ts +15 -0
- package/components/GenericRenderer/Component_GenericRenderer.js +13 -0
- package/components/HeightBounder.d.ts +11 -0
- package/components/HeightBounder.js +25 -0
- package/components/Label/ATS_Label.d.ts +12 -0
- package/components/Label/ATS_Label.js +34 -0
- package/components/Label/ATS_Label.scss +24 -0
- package/components/Label/Label.d.ts +30 -0
- package/components/Label/Label.js +84 -0
- package/components/Label/Label.scss +89 -0
- package/components/Layouts/Layouts.d.ts +38 -0
- package/components/Layouts/Layouts.js +56 -0
- package/components/Layouts/_Layouts.scss +53 -0
- package/components/Layouts/_Layouts_.scss +69 -0
- package/components/Layouts/index.d.ts +1 -0
- package/components/Layouts/index.js +21 -0
- package/components/Page_ItemsEditor/Page_ItemsEditor.d.ts +66 -0
- package/components/Page_ItemsEditor/Page_ItemsEditor.js +134 -0
- package/components/Page_ItemsEditor/Page_ItemsEditor.scss +104 -0
- package/components/Page_ItemsEditor/defaults/ItemEditor_DefaultFilter/ItemEditor_DefaultFilter.d.ts +16 -0
- package/components/Page_ItemsEditor/defaults/ItemEditor_DefaultFilter/ItemEditor_DefaultFilter.js +15 -0
- package/components/Page_ItemsEditor/defaults/ItemEditor_DefaultFilter/ItemEditor_DefaultFilter.scss +4 -0
- package/components/Page_ItemsEditor/defaults/ItemEditor_DefaultFilter/index.d.ts +1 -0
- package/components/Page_ItemsEditor/defaults/ItemEditor_DefaultFilter/index.js +1 -0
- package/components/Page_ItemsEditor/defaults/ItemEditor_ListRenderer/ItemEditor_DefaultList.d.ts +26 -0
- package/components/Page_ItemsEditor/defaults/ItemEditor_ListRenderer/ItemEditor_DefaultList.js +68 -0
- package/components/Page_ItemsEditor/defaults/ItemEditor_ListRenderer/ItemEditor_DefaultList.scss +4 -0
- package/components/Page_ItemsEditor/defaults/ItemEditor_ListRenderer/index.d.ts +1 -0
- package/components/Page_ItemsEditor/defaults/ItemEditor_ListRenderer/index.js +1 -0
- package/components/Page_ItemsEditor/index.d.ts +1 -0
- package/components/Page_ItemsEditor/index.js +1 -0
- package/components/Page_ItemsEditor/types.d.ts +4 -0
- package/components/Page_ItemsEditor/types.js +1 -0
- package/components/RelativeLayout/RelativeLayout.d.ts +7 -0
- package/components/RelativeLayout/RelativeLayout.js +10 -0
- package/components/RelativeLayout/RelativeLayout.scss +3 -0
- package/components/RelativeLayout/index.d.ts +1 -0
- package/components/RelativeLayout/index.js +1 -0
- package/components/Show.d.ts +20 -0
- package/components/Show.js +30 -0
- package/components/TS_AppTools/TS_AppTools.d.ts +30 -0
- package/components/TS_AppTools/TS_AppTools.js +144 -0
- package/components/TS_AppTools/TS_AppTools.scss +193 -0
- package/components/TS_AppTools/TS_AppTools_Default.d.ts +7 -0
- package/components/TS_AppTools/TS_AppTools_Default.js +16 -0
- package/components/TS_AppTools/index.d.ts +2 -0
- package/components/TS_AppTools/index.js +22 -0
- package/components/TS_AppTools/types.d.ts +19 -0
- package/components/TS_AppTools/types.js +6 -0
- package/components/TS_ButtonGroup/TS_ButtonGroup.d.ts +12 -0
- package/components/TS_ButtonGroup/TS_ButtonGroup.js +94 -0
- package/components/TS_ButtonGroup/TS_ButtonGroup.scss +58 -0
- package/components/TS_ButtonGroup/index.d.ts +2 -0
- package/components/TS_ButtonGroup/index.js +2 -0
- package/components/TS_ButtonGroup/types.d.ts +38 -0
- package/components/TS_ButtonGroup/types.js +1 -0
- package/components/TS_ButtonLoader/TS_ButtonLoader.d.ts +5 -0
- package/components/TS_ButtonLoader/TS_ButtonLoader.js +8 -0
- package/components/TS_ButtonLoader/TS_ButtonLoader.scss +63 -0
- package/components/TS_ButtonLoader/index.d.ts +1 -0
- package/components/TS_ButtonLoader/index.js +1 -0
- package/components/TS_Card/TS_Card.d.ts +7 -0
- package/components/TS_Card/TS_Card.js +14 -0
- package/components/TS_Card/TS_Card.scss +7 -0
- package/components/TS_Card/index.d.ts +1 -0
- package/components/TS_Card/index.js +1 -0
- package/components/TS_Checkbox/ATS_CheckboxV2.d.ts +3 -0
- package/components/TS_Checkbox/ATS_CheckboxV2.js +30 -0
- package/components/TS_Checkbox/ATS_CheckboxV2.scss +4 -0
- package/components/TS_Checkbox/TS_Checkbox.d.ts +48 -0
- package/components/TS_Checkbox/TS_Checkbox.js +46 -0
- package/components/TS_Checkbox/TS_Checkbox.scss +62 -0
- package/components/TS_Checkbox/TS_CheckboxV2.d.ts +37 -0
- package/components/TS_Checkbox/TS_CheckboxV2.js +53 -0
- package/components/TS_Checkbox/TS_CheckboxV2.scss +97 -0
- package/components/TS_Checkbox/index.d.ts +1 -0
- package/components/TS_Checkbox/index.js +21 -0
- package/components/TS_CheckboxGroup/ATS_CheckboxGroup.d.ts +19 -0
- package/components/TS_CheckboxGroup/ATS_CheckboxGroup.js +89 -0
- package/components/TS_CheckboxGroup/ATS_CheckboxGroup.scss +6 -0
- package/components/TS_CheckboxGroup/TS_CheckboxGroup.d.ts +35 -0
- package/components/TS_CheckboxGroup/TS_CheckboxGroup.js +47 -0
- package/components/TS_CheckboxGroup/TS_CheckboxGroup.scss +32 -0
- package/components/TS_CheckboxGroup/index.d.ts +1 -0
- package/components/TS_CheckboxGroup/index.js +1 -0
- package/components/TS_CollapsableContainer/TS_CollapsableContainer.d.ts +44 -0
- package/components/TS_CollapsableContainer/TS_CollapsableContainer.js +80 -0
- package/components/TS_CollapsableContainer/TS_CollapsableContainer.scss +47 -0
- package/components/TS_CollapsableContainer/index.d.ts +1 -0
- package/components/TS_CollapsableContainer/index.js +1 -0
- package/components/TS_CollapsableContainerV2/TS_CollapsableContainerV2.d.ts +36 -0
- package/components/TS_CollapsableContainerV2/TS_CollapsableContainerV2.js +46 -0
- package/components/TS_CollapsableContainerV2/TS_CollapsableContainerV2.scss +66 -0
- package/components/TS_CollapsableContainerV2/ats.d.ts +3 -0
- package/components/TS_CollapsableContainerV2/ats.js +39 -0
- package/components/TS_CollapsableContainerV2/ats.scss +35 -0
- package/components/TS_CollapsableContainerV2/index.d.ts +2 -0
- package/components/TS_CollapsableContainerV2/index.js +2 -0
- package/components/TS_ComponentTransition/TS_ComponentTransition.d.ts +25 -0
- package/components/TS_ComponentTransition/TS_ComponentTransition.js +65 -0
- package/components/TS_ComponentTransition/index.d.ts +1 -0
- package/components/TS_ComponentTransition/index.js +1 -0
- package/components/TS_CopyToClipboard/TS_CopyToClipboard.d.ts +4 -0
- package/components/TS_CopyToClipboard/TS_CopyToClipboard.js +11 -0
- package/components/TS_CopyToClipboard/index.d.ts +1 -0
- package/components/TS_CopyToClipboard/index.js +21 -0
- package/components/TS_Dialog/TS_Dialog.d.ts +89 -0
- package/components/TS_Dialog/TS_Dialog.js +140 -0
- package/components/TS_Dialog/TS_Dialog.scss +116 -0
- package/components/TS_Dialog/TS_DialogOverlay.d.ts +15 -0
- package/components/TS_Dialog/TS_DialogOverlay.js +48 -0
- package/components/TS_Dialog/TS_DialogOverlay.scss +41 -0
- package/components/TS_Dialog/TS_SimpleDialog.d.ts +21 -0
- package/components/TS_Dialog/TS_SimpleDialog.js +37 -0
- package/components/TS_Dialog/TS_SimpleDialog.scss +5 -0
- package/components/TS_Dialog/TS_SimpleDialogue.d.ts +28 -0
- package/components/TS_Dialog/TS_SimpleDialogue.js +38 -0
- package/components/TS_Dialog/index.d.ts +2 -0
- package/components/TS_Dialog/index.js +22 -0
- package/components/TS_DragAndDrop/TS_DragAndDrop.d.ts +48 -0
- package/components/TS_DragAndDrop/TS_DragAndDrop.js +105 -0
- package/components/TS_DragAndDrop/TS_DragAndDrop.scss +61 -0
- package/components/TS_DragAndDrop/index.d.ts +1 -0
- package/components/TS_DragAndDrop/index.js +21 -0
- package/components/TS_Dropdown/TS_DropDown.d.ts +120 -0
- package/components/TS_Dropdown/TS_DropDown.js +332 -0
- package/components/TS_Dropdown/TS_DropDown.scss +134 -0
- package/components/TS_Dropdown/index.d.ts +1 -0
- package/components/TS_Dropdown/index.js +21 -0
- package/components/TS_EditableContent/TS_EditableContent.d.ts +19 -0
- package/components/TS_EditableContent/TS_EditableContent.js +32 -0
- package/components/TS_EditableContent/types.d.ts +4 -0
- package/components/TS_EditableContent/types.js +1 -0
- package/components/TS_EditableItemComponent/TS_EditableItemComponent.d.ts +23 -0
- package/components/TS_EditableItemComponent/TS_EditableItemComponent.js +47 -0
- package/components/TS_EditableItemController/TS_EditableItemController.d.ts +36 -0
- package/components/TS_EditableItemController/TS_EditableItemController.js +54 -0
- package/components/TS_EditableItemController/TS_EditableItemController.scss +3 -0
- package/components/TS_EditableItemController/index.d.ts +1 -0
- package/components/TS_EditableItemController/index.js +1 -0
- package/components/TS_EditableItemControllerProto/TS_EditableItemControllerProto.d.ts +32 -0
- package/components/TS_EditableItemControllerProto/TS_EditableItemControllerProto.js +53 -0
- package/components/TS_EditableItemControllerProto/TS_EditableItemControllerProto.scss +3 -0
- package/components/TS_EditableItemControllerProto/index.d.ts +1 -0
- package/components/TS_EditableItemControllerProto/index.js +1 -0
- package/components/TS_EditableItemStatus/TS_EditableItemStatus.d.ts +20 -0
- package/components/TS_EditableItemStatus/TS_EditableItemStatus.js +34 -0
- package/components/TS_EditableText/TS_EditableText.d.ts +57 -0
- package/components/TS_EditableText/TS_EditableText.js +100 -0
- package/components/TS_EditableText/TS_EditableText.scss +90 -0
- package/components/TS_EditableText/index.d.ts +1 -0
- package/components/TS_EditableText/index.js +1 -0
- package/components/TS_ErrorBoundary/TS_ErrorBoundary.d.ts +54 -0
- package/components/TS_ErrorBoundary/TS_ErrorBoundary.js +103 -0
- package/components/TS_ErrorBoundary/TS_ErrorBoundary.scss +95 -0
- package/components/TS_ErrorBoundary/index.d.ts +1 -0
- package/components/TS_ErrorBoundary/index.js +21 -0
- package/components/TS_Form/TS_Form.d.ts +9 -0
- package/components/TS_Form/TS_Form.js +11 -0
- package/components/TS_Form/TS_Form.scss +0 -0
- package/components/TS_Form/consts.d.ts +1 -0
- package/components/TS_Form/consts.js +1 -0
- package/components/TS_Form/index.d.ts +3 -0
- package/components/TS_Form/index.js +3 -0
- package/components/TS_Form/types.d.ts +13 -0
- package/components/TS_Form/types.js +1 -0
- package/components/TS_GridTableProto/TS_GridTableProto.d.ts +18 -0
- package/components/TS_GridTableProto/TS_GridTableProto.js +22 -0
- package/components/TS_GridTableProto/TS_GridTableProto.scss +4 -0
- package/components/TS_GridTableProto/index.d.ts +1 -0
- package/components/TS_GridTableProto/index.js +1 -0
- package/components/TS_Input/ATS_TextArea.d.ts +14 -0
- package/components/TS_Input/ATS_TextArea.js +24 -0
- package/components/TS_Input/ATS_TextArea.scss +24 -0
- package/components/TS_Input/TS_BaseInput.d.ts +44 -0
- package/components/TS_Input/TS_BaseInput.js +47 -0
- package/components/TS_Input/TS_Input.d.ts +24 -0
- package/components/TS_Input/TS_Input.js +53 -0
- package/components/TS_Input/TS_Input.scss +64 -0
- package/components/TS_Input/TS_TextArea.d.ts +14 -0
- package/components/TS_Input/TS_TextArea.js +72 -0
- package/components/TS_Input/TS_TextArea.scss +41 -0
- package/components/TS_Input/index.d.ts +4 -0
- package/components/TS_Input/index.js +25 -0
- package/components/TS_JSONViewer/TS_JSONViewer.d.ts +18 -0
- package/components/TS_JSONViewer/TS_JSONViewer.js +64 -0
- package/components/TS_JSONViewer/TS_JSONViewer.scss +87 -0
- package/components/TS_JSONViewer/types.d.ts +10 -0
- package/components/TS_JSONViewer/types.js +1 -0
- package/components/TS_Link/TS_Link.d.ts +15 -0
- package/components/TS_Link/TS_Link.js +36 -0
- package/components/TS_Link/TS_Link.scss +32 -0
- package/components/TS_Link/index.d.ts +1 -0
- package/components/TS_Link/index.js +21 -0
- package/components/TS_ListOrganizer/TS_ListOrganizer.d.ts +33 -0
- package/components/TS_ListOrganizer/TS_ListOrganizer.js +64 -0
- package/components/TS_ListOrganizer/TS_ListOrganizer.scss +37 -0
- package/components/TS_ListOrganizer/index.d.ts +1 -0
- package/components/TS_ListOrganizer/index.js +21 -0
- package/components/TS_Loader/TS_Loader.d.ts +6 -0
- package/components/TS_Loader/TS_Loader.js +9 -0
- package/components/TS_Loader/TS_Loader.scss +71 -0
- package/components/TS_Loader/index.d.ts +1 -0
- package/components/TS_Loader/index.js +1 -0
- package/components/TS_MemoryMonitor/TS_MemoryMonitor.d.ts +10 -0
- package/components/TS_MemoryMonitor/TS_MemoryMonitor.js +48 -0
- package/components/TS_MemoryMonitor/TS_MemoryMonitor.scss +31 -0
- package/components/TS_MemoryMonitor/index.d.ts +1 -0
- package/components/TS_MemoryMonitor/index.js +21 -0
- package/components/TS_MouseInteractivity/TS_PopUp/TS_PopUp.d.ts +9 -0
- package/components/TS_MouseInteractivity/TS_PopUp/TS_PopUp.js +28 -0
- package/components/TS_MouseInteractivity/TS_PopUp/TS_PopUp.scss +53 -0
- package/components/TS_MouseInteractivity/TS_Tooltip/TS_ToolTip.d.ts +12 -0
- package/components/TS_MouseInteractivity/TS_Tooltip/TS_ToolTip.js +65 -0
- package/components/TS_MouseInteractivity/TS_Tooltip/TS_ToolTip.scss +46 -0
- package/components/TS_MouseInteractivity/base/TS_MouseInteractivity.d.ts +18 -0
- package/components/TS_MouseInteractivity/base/TS_MouseInteractivity.js +100 -0
- package/components/TS_MouseInteractivity/index.d.ts +2 -0
- package/components/TS_MouseInteractivity/index.js +22 -0
- package/components/TS_MultiSelect/TS_MultiSelect.scss +34 -0
- package/components/TS_MultiSelect/TS_MultiSelect_V2.d.ts +36 -0
- package/components/TS_MultiSelect/TS_MultiSelect_V2.js +41 -0
- package/components/TS_MultiSelect/index.d.ts +1 -0
- package/components/TS_MultiSelect/index.js +21 -0
- package/components/TS_Notifications/TS_Notifications.d.ts +22 -0
- package/components/TS_Notifications/TS_Notifications.js +96 -0
- package/components/TS_Notifications/TS_Notifications.scss +120 -0
- package/components/TS_Notifications/genericNotificationAction.d.ts +8 -0
- package/components/TS_Notifications/genericNotificationAction.js +16 -0
- package/components/TS_Notifications/index.d.ts +2 -0
- package/components/TS_Notifications/index.js +2 -0
- package/components/TS_Overlay/TS_Overlay.d.ts +12 -0
- package/components/TS_Overlay/TS_Overlay.js +32 -0
- package/components/TS_Overlay/TS_Overlay.scss +41 -0
- package/components/TS_Overlay/index.d.ts +1 -0
- package/components/TS_Overlay/index.js +21 -0
- package/components/TS_Printable/TS_Printable.d.ts +13 -0
- package/components/TS_Printable/TS_Printable.js +20 -0
- package/components/TS_Printable/TS_Printable.scss +47 -0
- package/components/TS_Printable/index.d.ts +1 -0
- package/components/TS_Printable/index.js +21 -0
- package/components/TS_ProgressBar/TS_ProgressBar.d.ts +22 -0
- package/components/TS_ProgressBar/TS_ProgressBar.js +47 -0
- package/components/TS_ProgressBar/TS_ProgressBar.scss +79 -0
- package/components/TS_ProgressBar/index.d.ts +1 -0
- package/components/TS_ProgressBar/index.js +1 -0
- package/components/TS_PropRenderer/TS_PropRenderer.d.ts +18 -0
- package/components/TS_PropRenderer/TS_PropRenderer.js +36 -0
- package/components/TS_PropRenderer/TS_PropRenderer.scss +19 -0
- package/components/TS_PropRenderer/index.d.ts +1 -0
- package/components/TS_PropRenderer/index.js +1 -0
- package/components/TS_Radio/TS_Radio.d.ts +34 -0
- package/components/TS_Radio/TS_Radio.js +49 -0
- package/components/TS_Radio/TS_Radio.scss +68 -0
- package/components/TS_Radio/index.d.ts +1 -0
- package/components/TS_Radio/index.js +1 -0
- package/components/TS_ReadMore/TS_ReadMore.d.ts +26 -0
- package/components/TS_ReadMore/TS_ReadMore.js +86 -0
- package/components/TS_ReadMore/TS_ReadMore.scss +36 -0
- package/components/TS_ReadMore/index.d.ts +1 -0
- package/components/TS_ReadMore/index.js +1 -0
- package/components/TS_Slider/TS_Slider.d.ts +26 -0
- package/components/TS_Slider/TS_Slider.js +42 -0
- package/components/TS_Slider/TS_Slider.scss +68 -0
- package/components/TS_Slider/index.d.ts +1 -0
- package/components/TS_Slider/index.js +1 -0
- package/components/TS_Space/TS_Space.d.ts +8 -0
- package/components/TS_Space/TS_Space.js +8 -0
- package/components/TS_Space/index.d.ts +1 -0
- package/components/TS_Space/index.js +1 -0
- package/components/TS_Space/ts-space.scss +3 -0
- package/components/TS_Table/TS_Table.d.ts +42 -0
- package/components/TS_Table/TS_Table.js +74 -0
- package/components/TS_Table/TS_Table.scss +51 -0
- package/components/TS_Table/index.d.ts +1 -0
- package/components/TS_Table/index.js +21 -0
- package/components/TS_Tabs/TS_Tabs.d.ts +55 -0
- package/components/TS_Tabs/TS_Tabs.js +102 -0
- package/components/TS_Tabs/TS_Tabs.scss +103 -0
- package/components/TS_Tabs/index.d.ts +1 -0
- package/components/TS_Tabs/index.js +21 -0
- package/components/TS_Toaster/TS_Toast.d.ts +5 -0
- package/components/TS_Toaster/TS_Toast.js +9 -0
- package/components/TS_Toaster/TS_Toast.scss +80 -0
- package/components/TS_Toaster/TS_ToastOverlay.d.ts +16 -0
- package/components/TS_Toaster/TS_ToastOverlay.js +26 -0
- package/components/TS_Toaster/TS_ToastOverlay.scss +33 -0
- package/components/TS_Toaster/index.d.ts +2 -0
- package/components/TS_Toaster/index.js +22 -0
- package/components/TS_Toggle/ATS_Toggle.d.ts +11 -0
- package/components/TS_Toggle/ATS_Toggle.js +18 -0
- package/components/TS_Toggle/TS_Toggle.d.ts +21 -0
- package/components/TS_Toggle/TS_Toggle.js +26 -0
- package/components/TS_Toggle/TS_Toggle.scss +56 -0
- package/components/TS_Toggle/index.d.ts +2 -0
- package/components/TS_Toggle/index.js +2 -0
- package/components/TS_Toggler/TS_Toggler.d.ts +23 -0
- package/components/TS_Toggler/TS_Toggler.js +50 -0
- package/components/TS_Toggler/TS_Toggler.scss +83 -0
- package/components/TS_Toggler/index.d.ts +1 -0
- package/components/TS_Toggler/index.js +1 -0
- package/components/TS_Tree/SimpleTreeNodeRenderer.d.ts +9 -0
- package/components/TS_Tree/SimpleTreeNodeRenderer.js +53 -0
- package/components/TS_Tree/TS_Tree.d.ts +68 -0
- package/components/TS_Tree/TS_Tree.js +174 -0
- package/components/TS_Tree/TS_Tree.scss +44 -0
- package/components/TS_Tree/index.d.ts +3 -0
- package/components/TS_Tree/index.js +23 -0
- package/components/TS_Tree/types.d.ts +4 -0
- package/components/TS_Tree/types.js +21 -0
- package/components/TS_V2_Input/TS_InputV2.d.ts +93 -0
- package/components/TS_V2_Input/TS_InputV2.js +220 -0
- package/components/TS_V2_Input/index.d.ts +1 -0
- package/components/TS_V2_Input/index.js +21 -0
- package/components/TS_V2_TextArea/TS_BaseInput.d.ts +42 -0
- package/components/TS_V2_TextArea/TS_BaseInput.js +46 -0
- package/components/TS_V2_TextArea/TS_TextAreaV2.d.ts +78 -0
- package/components/TS_V2_TextArea/TS_TextAreaV2.js +178 -0
- package/components/TS_V2_TextArea/TS_TextAreaV2.scss +49 -0
- package/components/TS_V2_TextArea/index.d.ts +2 -0
- package/components/TS_V2_TextArea/index.js +22 -0
- package/components/TS_VirtualizedList/TS_VirtualizedList.d.ts +14 -0
- package/components/TS_VirtualizedList/TS_VirtualizedList.js +22 -0
- package/components/TS_VirtualizedList/index.d.ts +1 -0
- package/components/TS_VirtualizedList/index.js +1 -0
- package/components/Video/Video.d.ts +16 -0
- package/components/Video/Video.js +40 -0
- package/components/Video/VideoDialog.d.ts +20 -0
- package/components/Video/VideoDialog.js +44 -0
- package/components/Video/VideoDialog.scss +31 -0
- package/components/Video/types.d.ts +20 -0
- package/components/Video/types.js +1 -0
- package/components/_TS_MultiSelect/DBItemDropDownMultiSelector.d.ts +57 -0
- package/components/_TS_MultiSelect/DBItemDropDownMultiSelector.js +63 -0
- package/components/adapter/Adapter.d.ts +139 -0
- package/components/adapter/Adapter.js +259 -0
- package/components/adapter/BaseRenderer.d.ts +24 -0
- package/components/adapter/BaseRenderer.js +31 -0
- package/components/ats-group.d.ts +2 -0
- package/components/ats-group.js +14 -0
- package/components/form/Form.d.ts +24 -0
- package/components/form/Form.js +34 -0
- package/components/form/types.d.ts +23 -0
- package/components/form/types.js +21 -0
- package/components/formv3/FormV3.d.ts +25 -0
- package/components/formv3/FormV3.js +23 -0
- package/components/formv3/types.d.ts +29 -0
- package/components/formv3/types.js +1 -0
- package/components/treeicons.d.ts +10 -0
- package/components/treeicons.js +3 -0
- package/components/types.d.ts +23 -0
- package/components/types.js +22 -0
- package/components/utils.d.ts +1 -0
- package/components/utils.js +7 -0
- package/consts.d.ts +2 -0
- package/consts.js +2 -0
- package/core/AppPage.d.ts +11 -0
- package/core/AppPage.js +52 -0
- package/core/AppPageV2.d.ts +9 -0
- package/core/AppPageV2.js +53 -0
- package/core/AppWrapper.d.ts +4 -0
- package/core/AppWrapper.js +34 -0
- package/core/ComponentAsync.d.ts +16 -0
- package/core/ComponentAsync.js +64 -0
- package/core/ComponentBase.d.ts +28 -0
- package/core/ComponentBase.js +152 -0
- package/core/ComponentSync.d.ts +13 -0
- package/core/ComponentSync.js +49 -0
- package/core/Controller.d.ts +13 -0
- package/core/Controller.js +28 -0
- package/core/IndexedDB.d.ts +42 -0
- package/core/IndexedDB.js +259 -0
- package/core/IndexedDBV3.d.ts +43 -0
- package/core/IndexedDBV3.js +259 -0
- package/core/IndexedDBV4/IndexedDB_Database.d.ts +20 -0
- package/core/IndexedDBV4/IndexedDB_Database.js +268 -0
- package/core/IndexedDBV4/IndexedDB_Store.d.ts +34 -0
- package/core/IndexedDBV4/IndexedDB_Store.js +207 -0
- package/core/IndexedDBV4/ModuleFE_IDBManager.d.ts +11 -0
- package/core/IndexedDBV4/ModuleFE_IDBManager.js +19 -0
- package/core/IndexedDBV4/types.d.ts +16 -0
- package/core/IndexedDBV4/types.js +1 -0
- package/core/SimpleScriptInjector.d.ts +13 -0
- package/core/SimpleScriptInjector.js +42 -0
- package/core/Thunder.d.ts +37 -0
- package/core/Thunder.js +139 -0
- package/core/ThunderstormDefaultApp.d.ts +12 -0
- package/core/ThunderstormDefaultApp.js +29 -0
- package/core/consts.d.ts +6 -0
- package/core/consts.js +2 -0
- package/core/db-api-gen/consts.d.ts +22 -0
- package/core/db-api-gen/consts.js +25 -0
- package/core/db-api-gen/db-def.d.ts +9 -0
- package/core/db-api-gen/db-def.js +16 -0
- package/core/db-api-gen/types.d.ts +23 -0
- package/core/db-api-gen/types.js +3 -0
- package/core/proto-component/ProtoComponent.d.ts +57 -0
- package/core/proto-component/ProtoComponent.js +73 -0
- package/core/proto-component/UrlState.d.ts +42 -0
- package/core/proto-component/UrlState.js +59 -0
- package/core/proto-component/index.d.ts +2 -0
- package/core/proto-component/index.js +2 -0
- package/core/proto-component/types.d.ts +25 -0
- package/core/proto-component/types.js +15 -0
- package/core/thunder-dispatcher.d.ts +13 -0
- package/core/thunder-dispatcher.js +69 -0
- package/core/thunder-helpers.d.ts +7 -0
- package/core/thunder-helpers.js +171 -0
- package/core/thunder-modulepack.d.ts +3 -0
- package/core/thunder-modulepack.js +34 -0
- package/core/typed-api.d.ts +6 -0
- package/core/typed-api.js +41 -0
- package/core/types.d.ts +6 -0
- package/core/types.js +1 -0
- package/editable-item.d.ts +7 -0
- package/editable-item.js +7 -0
- package/index.d.ts +112 -0
- package/index.js +134 -0
- package/modules/ModuleFE_BaseTheme.d.ts +18 -0
- package/modules/ModuleFE_BaseTheme.js +27 -0
- package/modules/ModuleFE_BroadcastChannel/ModuleFE_BroadcastChannel.d.ts +20 -0
- package/modules/ModuleFE_BroadcastChannel/ModuleFE_BroadcastChannel.js +66 -0
- package/modules/ModuleFE_BrowserHistory.d.ts +46 -0
- package/modules/ModuleFE_BrowserHistory.js +165 -0
- package/modules/ModuleFE_BrowserHistoryV2.d.ts +43 -0
- package/modules/ModuleFE_BrowserHistoryV2.js +113 -0
- package/modules/ModuleFE_CSVParser.d.ts +12 -0
- package/modules/ModuleFE_CSVParser.js +52 -0
- package/modules/ModuleFE_CollectionActions.d.ts +10 -0
- package/modules/ModuleFE_CollectionActions.js +18 -0
- package/modules/ModuleFE_ConnectivityModule.d.ts +15 -0
- package/modules/ModuleFE_ConnectivityModule.js +31 -0
- package/modules/ModuleFE_ForceUpgrade.d.ts +20 -0
- package/modules/ModuleFE_ForceUpgrade.js +54 -0
- package/modules/ModuleFE_LocalStorage.d.ts +46 -0
- package/modules/ModuleFE_LocalStorage.js +179 -0
- package/modules/ModuleFE_Locale.d.ts +44 -0
- package/modules/ModuleFE_Locale.js +83 -0
- package/modules/ModuleFE_Print.d.ts +16 -0
- package/modules/ModuleFE_Print.js +116 -0
- package/modules/ModuleFE_StorageCleaner.d.ts +17 -0
- package/modules/ModuleFE_StorageCleaner.js +90 -0
- package/modules/ModuleFE_Thunderstorm.d.ts +31 -0
- package/modules/ModuleFE_Thunderstorm.js +122 -0
- package/modules/ModuleFE_Utils/ModuleFE_Utils.d.ts +29 -0
- package/modules/ModuleFE_Utils/ModuleFE_Utils.js +43 -0
- package/modules/ModuleFE_Window.d.ts +19 -0
- package/modules/ModuleFE_Window.js +42 -0
- package/modules/ModuleFE_WindowMessenger.d.ts +62 -0
- package/modules/ModuleFE_WindowMessenger.js +128 -0
- package/modules/action-processor/ModuleFE_ActionProcessor.d.ts +9 -0
- package/modules/action-processor/ModuleFE_ActionProcessor.js +14 -0
- package/modules/archiving/ModuleFE_Archiving.d.ts +8 -0
- package/modules/archiving/ModuleFE_Archiving.js +15 -0
- package/modules/clearWebsiteDataDispatcher.d.ts +5 -0
- package/modules/clearWebsiteDataDispatcher.js +2 -0
- package/modules/component-loader/ReactEntryComponentInjector.d.ts +23 -0
- package/modules/component-loader/ReactEntryComponentInjector.js +59 -0
- package/modules/component-loader/entry-component-loading-module.d.ts +7 -0
- package/modules/component-loader/entry-component-loading-module.js +52 -0
- package/modules/component-loader/index.d.ts +2 -0
- package/modules/component-loader/index.js +2 -0
- package/modules/db-api-gen/ModuleFE_BaseApi.d.ts +45 -0
- package/modules/db-api-gen/ModuleFE_BaseApi.js +152 -0
- package/modules/db-api-gen/ModuleFE_BaseDB.d.ts +146 -0
- package/modules/db-api-gen/ModuleFE_BaseDB.js +433 -0
- package/modules/db-api-gen/types.d.ts +13 -0
- package/modules/db-api-gen/types.js +6 -0
- package/modules/http/ModuleFE_XHR.d.ts +20 -0
- package/modules/http/ModuleFE_XHR.js +175 -0
- package/modules/routing/LocationChangeListener.d.ts +6 -0
- package/modules/routing/LocationChangeListener.js +15 -0
- package/modules/routing/ModuleFE_Routing.d.ts +30 -0
- package/modules/routing/ModuleFE_Routing.js +122 -0
- package/modules/routing/ModuleFE_RoutingV2.d.ts +25 -0
- package/modules/routing/ModuleFE_RoutingV2.js +143 -0
- package/modules/routing/index.d.ts +5 -0
- package/modules/routing/index.js +5 -0
- package/modules/routing/route.d.ts +22 -0
- package/modules/routing/route.js +83 -0
- package/modules/routing/types.d.ts +20 -0
- package/modules/routing/types.js +1 -0
- package/modules/sync-env/ModuleFE_SyncEnvV2.d.ts +8 -0
- package/modules/sync-env/ModuleFE_SyncEnvV2.js +18 -0
- package/modules/sync-manager/ModuleFE_SyncManager.d.ts +59 -0
- package/modules/sync-manager/ModuleFE_SyncManager.js +378 -0
- package/modules/sync-manager/ModuleFE_SyncManager_CSV.d.ts +11 -0
- package/modules/sync-manager/ModuleFE_SyncManager_CSV.js +121 -0
- package/package.json +107 -0
- package/server-info/Button_VersionUpdate.d.ts +15 -0
- package/server-info/Button_VersionUpdate.js +29 -0
- package/server-info/Button_VersionUpdate.scss +29 -0
- package/server-info/ModuleFE_ServerInfo.d.ts +26 -0
- package/server-info/ModuleFE_ServerInfo.js +73 -0
- package/server-info/index.d.ts +2 -0
- package/server-info/index.js +2 -0
- package/shared.d.ts +1 -0
- package/shared.js +21 -0
- package/styles/declaration/basic.scss +155 -0
- package/styles/declaration/mixins.scss +58 -0
- package/styles/impl/basic.scss +141 -0
- package/styles/impl/icons.scss +34 -0
- package/styles.scss +40 -0
- package/utils/EditableItem.d.ts +240 -0
- package/utils/EditableItem.js +552 -0
- package/utils/console/LogClient_ConsoleInterceptor.d.ts +5 -0
- package/utils/console/LogClient_ConsoleInterceptor.js +70 -0
- package/utils/perform-action/genereteToasts.d.ts +3 -0
- package/utils/perform-action/genereteToasts.js +14 -0
- package/utils/perform-action/index.d.ts +2 -0
- package/utils/perform-action/index.js +2 -0
- package/utils/perform-action/notification-dispatchers.d.ts +6 -0
- package/utils/perform-action/notification-dispatchers.js +2 -0
- package/utils/perform-action/performAction.d.ts +34 -0
- package/utils/perform-action/performAction.js +77 -0
- package/utils/perform-action/resolve-dependency-toast/ResolveDependencyToast.d.ts +8 -0
- package/utils/perform-action/resolve-dependency-toast/ResolveDependencyToast.js +11 -0
- package/utils/perform-action/resolve-dependency-toast/ResolveDependencyToast.scss +12 -0
- package/utils/tools.d.ts +31 -0
- package/utils/tools.js +138 -0
- package/utils/types.d.ts +3 -0
- package/utils/types.js +1 -0
- package/widgets/FieldEditor.d.ts +29 -0
- package/widgets/FieldEditor.js +47 -0
- package/widgets/FieldEditorClick.d.ts +33 -0
- package/widgets/FieldEditorClick.js +49 -0
- package/widgets/FieldEditorWithButtons.d.ts +32 -0
- package/widgets/FieldEditorWithButtons.js +42 -0
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
import * as React from 'react';
|
|
2
|
+
export type FeedbackOptions = {
|
|
3
|
+
type: 'toast';
|
|
4
|
+
successContent?: React.ReactNode;
|
|
5
|
+
failContent?: React.ReactNode;
|
|
6
|
+
duration?: number;
|
|
7
|
+
} | {
|
|
8
|
+
type: 'notification';
|
|
9
|
+
notificationLabels?: string | {
|
|
10
|
+
inProgress: string;
|
|
11
|
+
failed?: string | ((e: any) => string);
|
|
12
|
+
success?: string;
|
|
13
|
+
};
|
|
14
|
+
};
|
|
15
|
+
/**
|
|
16
|
+
* #performAction
|
|
17
|
+
* use this function to execute any async action that requires a feedback.
|
|
18
|
+
* @param action the action to execute.
|
|
19
|
+
* @param feedbackOptions feedback options to determine which kind of feedback to present
|
|
20
|
+
* @param additionalData !Optional! any additional data the notification/toast might need
|
|
21
|
+
* @param throwBackError !Optional! if true, will throw error back outside the action
|
|
22
|
+
*/
|
|
23
|
+
export declare function performAction(action: () => Promise<any>, feedbackOptions: FeedbackOptions, additionalData?: any, throwBackError?: boolean, skipToast?: boolean): Promise<void>;
|
|
24
|
+
export declare const asyncHandler: {
|
|
25
|
+
notification: (title: string | {
|
|
26
|
+
inProgress: string;
|
|
27
|
+
failed?: string | ((e: any) => string);
|
|
28
|
+
success?: string;
|
|
29
|
+
}, action: () => Promise<any>) => Promise<void>;
|
|
30
|
+
toast: {
|
|
31
|
+
simple: (action: () => Promise<any>, successMessage?: React.ReactNode, errorMessage?: React.ReactNode) => Promise<void>;
|
|
32
|
+
onSuccess: (action: () => Promise<any>, successMessage?: React.ReactNode) => Promise<void>;
|
|
33
|
+
};
|
|
34
|
+
};
|
|
@@ -0,0 +1,77 @@
|
|
|
1
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
2
|
+
import { genericNotificationAction } from '../../components/TS_Notifications/index.js';
|
|
3
|
+
import { ToastBuilder } from '../../component-modules/ModuleFE_Toaster.js';
|
|
4
|
+
import { generateErrorToastContent } from './genereteToasts.js';
|
|
5
|
+
const Default_Toast_Duration = 4000;
|
|
6
|
+
const Successful_Action_Default_Label = 'Action Preformed Successfully';
|
|
7
|
+
const Failed_Action_Default_Label = 'Action Failed';
|
|
8
|
+
/**
|
|
9
|
+
* #performAction
|
|
10
|
+
* use this function to execute any async action that requires a feedback.
|
|
11
|
+
* @param action the action to execute.
|
|
12
|
+
* @param feedbackOptions feedback options to determine which kind of feedback to present
|
|
13
|
+
* @param additionalData !Optional! any additional data the notification/toast might need
|
|
14
|
+
* @param throwBackError !Optional! if true, will throw error back outside the action
|
|
15
|
+
*/
|
|
16
|
+
export async function performAction(action, feedbackOptions, additionalData, throwBackError = false, skipToast = false) {
|
|
17
|
+
switch (feedbackOptions.type) {
|
|
18
|
+
case 'notification':
|
|
19
|
+
if (feedbackOptions.notificationLabels) {
|
|
20
|
+
await genericNotificationAction(action, feedbackOptions.notificationLabels);
|
|
21
|
+
}
|
|
22
|
+
else {
|
|
23
|
+
console.error('cannot use notification as feedback without labels');
|
|
24
|
+
}
|
|
25
|
+
break;
|
|
26
|
+
case 'toast':
|
|
27
|
+
try {
|
|
28
|
+
const content = feedbackOptions.successContent ??
|
|
29
|
+
_jsx("div", { children: Successful_Action_Default_Label });
|
|
30
|
+
await action();
|
|
31
|
+
new ToastBuilder()
|
|
32
|
+
.setContent(content)
|
|
33
|
+
.setDuration(feedbackOptions.duration ?? Default_Toast_Duration)
|
|
34
|
+
.show();
|
|
35
|
+
}
|
|
36
|
+
catch (err) {
|
|
37
|
+
if (!skipToast) {
|
|
38
|
+
const content = feedbackOptions.failContent ??
|
|
39
|
+
_jsx("div", { children: Failed_Action_Default_Label });
|
|
40
|
+
new ToastBuilder()
|
|
41
|
+
.setContent(generateErrorToastContent(err, content, additionalData))
|
|
42
|
+
.setDuration(feedbackOptions.duration ? feedbackOptions.duration : Default_Toast_Duration).show();
|
|
43
|
+
}
|
|
44
|
+
if (throwBackError)
|
|
45
|
+
throw err;
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
}
|
|
49
|
+
export const asyncHandler = {
|
|
50
|
+
notification: async (title, action) => {
|
|
51
|
+
return genericNotificationAction(action, title);
|
|
52
|
+
},
|
|
53
|
+
toast: {
|
|
54
|
+
simple: async (action, successMessage = Successful_Action_Default_Label, errorMessage = Failed_Action_Default_Label) => {
|
|
55
|
+
try {
|
|
56
|
+
await action();
|
|
57
|
+
new ToastBuilder()
|
|
58
|
+
.setContent(successMessage)
|
|
59
|
+
.setDuration(Default_Toast_Duration)
|
|
60
|
+
.show();
|
|
61
|
+
}
|
|
62
|
+
catch (err) {
|
|
63
|
+
new ToastBuilder()
|
|
64
|
+
.setContent(errorMessage)
|
|
65
|
+
.setDuration(Default_Toast_Duration).show();
|
|
66
|
+
throw err;
|
|
67
|
+
}
|
|
68
|
+
},
|
|
69
|
+
onSuccess: async (action, successMessage = Successful_Action_Default_Label) => {
|
|
70
|
+
await action();
|
|
71
|
+
new ToastBuilder()
|
|
72
|
+
.setContent(successMessage)
|
|
73
|
+
.setDuration(Default_Toast_Duration)
|
|
74
|
+
.show();
|
|
75
|
+
}
|
|
76
|
+
}
|
|
77
|
+
};
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { UniqueId } from '@nu-art/ts-common';
|
|
2
|
+
import './ResolveDependencyToast.scss';
|
|
3
|
+
type Props = {
|
|
4
|
+
deletedEntity: string;
|
|
5
|
+
dependencyConflicts: UniqueId[];
|
|
6
|
+
};
|
|
7
|
+
export default function ResolveDependencyToast(props: Props): import("react/jsx-runtime").JSX.Element;
|
|
8
|
+
export {};
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import { dispatch_onDeleteConflicts } from '../notification-dispatchers.js';
|
|
3
|
+
import './ResolveDependencyToast.scss';
|
|
4
|
+
import { ModuleFE_Toaster } from '../../../component-modules/ModuleFE_Toaster.js';
|
|
5
|
+
export default function ResolveDependencyToast(props) {
|
|
6
|
+
const renderResolveDependenciesPanel = () => {
|
|
7
|
+
dispatch_onDeleteConflicts.dispatchUI(props.deletedEntity, props.dependencyConflicts);
|
|
8
|
+
ModuleFE_Toaster.hideToast();
|
|
9
|
+
};
|
|
10
|
+
return (_jsxs("div", { className: 'item-dependency-toast', children: [_jsx("div", { children: "Entity has dependencies." }), _jsxs("div", { onClick: () => renderResolveDependenciesPanel(), children: [_jsx("span", { className: 'click-here-label', children: "Click here" }), " to resolve"] })] }));
|
|
11
|
+
}
|
package/utils/tools.d.ts
ADDED
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
import { Browser } from '@nu-art/thunderstorm-shared/consts';
|
|
2
|
+
import * as React from 'react';
|
|
3
|
+
import { DependencyList, Dispatch, EffectCallback, SetStateAction } from 'react';
|
|
4
|
+
export declare function browserType(): Browser;
|
|
5
|
+
export declare function base64ToBlob(imageAsBase64: string): Promise<Blob>;
|
|
6
|
+
export declare function stringToArrayBuffer(stringToConvert: string): ArrayBuffer;
|
|
7
|
+
export declare function stringToUint8Array(stringToConvert: string): Uint8Array<ArrayBuffer>;
|
|
8
|
+
export declare function convertBase64ToFile(fileName: string, base64: string, _mimeType?: string): File;
|
|
9
|
+
export declare function readFileAs_ArrayBuffer(file: File): Promise<ArrayBuffer>;
|
|
10
|
+
export declare const readFileContent: typeof readFileAs_ArrayBuffer;
|
|
11
|
+
export declare function readFileAs_BinaryString(file: File): Promise<string>;
|
|
12
|
+
export declare function readFileAs_DataURL(file: File): Promise<string>;
|
|
13
|
+
export declare function readFileAs_Text(file: File): Promise<string>;
|
|
14
|
+
export declare function _className(...classes: (string | boolean | undefined)[]): string;
|
|
15
|
+
export declare function HOOK(fc: React.FC, props?: any): React.ReactNode;
|
|
16
|
+
export declare function HOOK_useState<S>(initialState: S | (() => S)): [S, Dispatch<SetStateAction<S>>];
|
|
17
|
+
export declare function HOOK_useEffect<S>(effect: EffectCallback, deps?: DependencyList): void;
|
|
18
|
+
export declare const HOOK_useEffectAsync: (action: () => Promise<void>, deps?: DependencyList, destructor?: () => void) => void;
|
|
19
|
+
/**
|
|
20
|
+
* Prevents default behaviour and stops propagation
|
|
21
|
+
* @param e MouseEvent | React.MouseEvent | KeyboardEvent | React.KeyboardEvent
|
|
22
|
+
*/
|
|
23
|
+
export declare const stopPropagation: (e: MouseEvent | React.MouseEvent | KeyboardEvent | React.KeyboardEvent) => void;
|
|
24
|
+
type MouseClickActions = {
|
|
25
|
+
left?: () => void;
|
|
26
|
+
middle?: () => void;
|
|
27
|
+
right?: () => void;
|
|
28
|
+
};
|
|
29
|
+
export declare const mouseEventHandler: (e: React.MouseEvent | MouseEvent, actions: MouseClickActions) => void | undefined;
|
|
30
|
+
export declare const stringReplacer: (_content: string, _toReplace: string, replacer: (match: string, i: number) => JSX.Element) => React.ReactNode[];
|
|
31
|
+
export {};
|
package/utils/tools.js
ADDED
|
@@ -0,0 +1,138 @@
|
|
|
1
|
+
/*
|
|
2
|
+
* Thunderstorm is a full web app framework!
|
|
3
|
+
*
|
|
4
|
+
* Typescript & Express backend infrastructure that natively runs on firebase function
|
|
5
|
+
* Typescript & React frontend infrastructure
|
|
6
|
+
*
|
|
7
|
+
* Copyright (C) 2020 Adam van der Kruk aka TacB0sS
|
|
8
|
+
*
|
|
9
|
+
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
10
|
+
* you may not use this file except in compliance with the License.
|
|
11
|
+
* You may obtain a copy of the License at
|
|
12
|
+
*
|
|
13
|
+
* http://www.apache.org/licenses/LICENSE-2.0
|
|
14
|
+
*
|
|
15
|
+
* Unless required by applicable law or agreed to in writing, software
|
|
16
|
+
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
17
|
+
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
18
|
+
* See the License for the specific language governing permissions and
|
|
19
|
+
* limitations under the License.
|
|
20
|
+
*/
|
|
21
|
+
import { BadImplementationException, filterInstances, ImplementationMissingException } from '@nu-art/ts-common';
|
|
22
|
+
import * as React from 'react';
|
|
23
|
+
export function browserType() {
|
|
24
|
+
if (navigator?.vendor.includes('Google')) {
|
|
25
|
+
return 'chrome';
|
|
26
|
+
}
|
|
27
|
+
throw new BadImplementationException('No matching browser detected');
|
|
28
|
+
}
|
|
29
|
+
export async function base64ToBlob(imageAsBase64) {
|
|
30
|
+
return (await fetch(imageAsBase64)).blob();
|
|
31
|
+
}
|
|
32
|
+
export function stringToArrayBuffer(stringToConvert) {
|
|
33
|
+
return stringToUint8Array(stringToConvert).buffer;
|
|
34
|
+
}
|
|
35
|
+
export function stringToUint8Array(stringToConvert) {
|
|
36
|
+
let n = stringToConvert.length;
|
|
37
|
+
const u8arr = new Uint8Array(n);
|
|
38
|
+
while (n--) {
|
|
39
|
+
u8arr[n] = stringToConvert.charCodeAt(n);
|
|
40
|
+
}
|
|
41
|
+
return u8arr;
|
|
42
|
+
}
|
|
43
|
+
//data:image/jpeg;base64,<!-- Base64 data -->
|
|
44
|
+
export function convertBase64ToFile(fileName, base64, _mimeType) {
|
|
45
|
+
const arr = base64.split(',');
|
|
46
|
+
const match = arr[0].match(/:(.*?);/);
|
|
47
|
+
const mimeType = (match && match[1]) || (_mimeType && _mimeType);
|
|
48
|
+
if (!mimeType)
|
|
49
|
+
throw new ImplementationMissingException('Could not extract mime type from data...');
|
|
50
|
+
const stringAsBase64 = atob(arr[1]);
|
|
51
|
+
const u8arr = stringToUint8Array(stringAsBase64);
|
|
52
|
+
return new File([u8arr], fileName, { type: mimeType });
|
|
53
|
+
}
|
|
54
|
+
function readFileContentImpl(file, format) {
|
|
55
|
+
return new Promise((resolve, reject) => {
|
|
56
|
+
const reader = new FileReader();
|
|
57
|
+
reader.onload = () => {
|
|
58
|
+
resolve(reader.result);
|
|
59
|
+
};
|
|
60
|
+
reader.onerror = reject;
|
|
61
|
+
switch (format) {
|
|
62
|
+
case 'array-buffer':
|
|
63
|
+
reader.readAsArrayBuffer(file);
|
|
64
|
+
break;
|
|
65
|
+
case 'binary':
|
|
66
|
+
reader.readAsBinaryString(file);
|
|
67
|
+
break;
|
|
68
|
+
case 'data-url':
|
|
69
|
+
reader.readAsDataURL(file);
|
|
70
|
+
break;
|
|
71
|
+
case 'string':
|
|
72
|
+
reader.readAsText(file);
|
|
73
|
+
break;
|
|
74
|
+
}
|
|
75
|
+
});
|
|
76
|
+
}
|
|
77
|
+
export async function readFileAs_ArrayBuffer(file) {
|
|
78
|
+
return readFileContentImpl(file, 'array-buffer');
|
|
79
|
+
}
|
|
80
|
+
export const readFileContent = readFileAs_ArrayBuffer;
|
|
81
|
+
export async function readFileAs_BinaryString(file) {
|
|
82
|
+
return readFileContentImpl(file, 'binary');
|
|
83
|
+
}
|
|
84
|
+
export async function readFileAs_DataURL(file) {
|
|
85
|
+
return readFileContentImpl(file, 'data-url');
|
|
86
|
+
}
|
|
87
|
+
export async function readFileAs_Text(file) {
|
|
88
|
+
return readFileContentImpl(file, 'string');
|
|
89
|
+
}
|
|
90
|
+
export function _className(...classes) {
|
|
91
|
+
return filterInstances(classes.filter(c => !!c)).join(' ');
|
|
92
|
+
}
|
|
93
|
+
export function HOOK(fc, props) {
|
|
94
|
+
return fc(props);
|
|
95
|
+
}
|
|
96
|
+
export function HOOK_useState(initialState) {
|
|
97
|
+
return React.useState(initialState);
|
|
98
|
+
}
|
|
99
|
+
export function HOOK_useEffect(effect, deps) {
|
|
100
|
+
return React.useEffect(effect, deps);
|
|
101
|
+
}
|
|
102
|
+
export const HOOK_useEffectAsync = (action, deps, destructor) => {
|
|
103
|
+
React.useEffect(() => {
|
|
104
|
+
(action)();
|
|
105
|
+
return destructor;
|
|
106
|
+
}, deps);
|
|
107
|
+
};
|
|
108
|
+
/**
|
|
109
|
+
* Prevents default behaviour and stops propagation
|
|
110
|
+
* @param e MouseEvent | React.MouseEvent | KeyboardEvent | React.KeyboardEvent
|
|
111
|
+
*/
|
|
112
|
+
export const stopPropagation = (e) => {
|
|
113
|
+
e.preventDefault();
|
|
114
|
+
e.stopPropagation();
|
|
115
|
+
};
|
|
116
|
+
export const mouseEventHandler = (e, actions) => {
|
|
117
|
+
const key = e.button === 0 ? 'left' : (e.button === 1 ? 'middle' : 'right');
|
|
118
|
+
return actions[key]?.();
|
|
119
|
+
};
|
|
120
|
+
export const stringReplacer = (_content, _toReplace, replacer) => {
|
|
121
|
+
const toRet = [];
|
|
122
|
+
let i = 0;
|
|
123
|
+
// eslint-disable-next-line no-constant-condition
|
|
124
|
+
while (true) {
|
|
125
|
+
const content = _content.toLowerCase();
|
|
126
|
+
const toReplace = _toReplace.toLowerCase();
|
|
127
|
+
const index = content.indexOf(toReplace);
|
|
128
|
+
if (index === -1) {
|
|
129
|
+
toRet.push(_content);
|
|
130
|
+
return toRet;
|
|
131
|
+
}
|
|
132
|
+
toRet.push(_content.slice(0, index));
|
|
133
|
+
_content = _content.slice(index);
|
|
134
|
+
toRet.push(replacer(_content.slice(0, toReplace.length), i));
|
|
135
|
+
_content = _content.slice(toReplace.length);
|
|
136
|
+
i++;
|
|
137
|
+
}
|
|
138
|
+
};
|
package/utils/types.d.ts
ADDED
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
export type InferProps<Component extends React.Component<any>> = Component extends React.Component<infer Props> ? Props : never;
|
|
2
|
+
export type InferState<Component extends React.Component<any, any>> = Component extends React.Component<any, infer State> ? State : never;
|
|
3
|
+
export type DefaultProps<Component extends React.Component<any>> = Partial<InferProps<Component>>;
|
package/utils/types.js
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
import { HTMLProps, ReactNode } from 'react';
|
|
2
|
+
import { StorageKey } from '../modules/ModuleFE_LocalStorage.js';
|
|
3
|
+
import { ComponentSync } from '../core/ComponentSync.js';
|
|
4
|
+
import { TS_InputProps } from '../components/TS_Input/TS_Input.js';
|
|
5
|
+
import { InputType } from '../components/TS_Input/TS_BaseInput.js';
|
|
6
|
+
export type FieldEditorInputProps<K extends string | number> = Omit<TS_InputProps<K>, 'onChange' | 'value' | 'onAccept' | 'type' | 'id'>;
|
|
7
|
+
export type EditorType = 'input' | 'textarea';
|
|
8
|
+
export type FieldEditorProps = {
|
|
9
|
+
isEditing: boolean;
|
|
10
|
+
value?: string;
|
|
11
|
+
editorType?: EditorType;
|
|
12
|
+
type: InputType;
|
|
13
|
+
storageKey: StorageKey<string>;
|
|
14
|
+
inputProps?: FieldEditorInputProps<any>;
|
|
15
|
+
labelProps?: HTMLProps<HTMLDivElement> | ((value: string) => ReactNode);
|
|
16
|
+
onAccept?: () => void;
|
|
17
|
+
onCancel?: () => void;
|
|
18
|
+
onBlur?: () => void;
|
|
19
|
+
id: string;
|
|
20
|
+
};
|
|
21
|
+
export declare class FieldEditor extends ComponentSync<FieldEditorProps> {
|
|
22
|
+
constructor(props: FieldEditorProps);
|
|
23
|
+
protected deriveStateFromProps(nextProps: FieldEditorProps): any;
|
|
24
|
+
onChange: (value: string) => void;
|
|
25
|
+
private renderInput;
|
|
26
|
+
renderArea: (value: string) => import("react/jsx-runtime").JSX.Element;
|
|
27
|
+
private renderLabel;
|
|
28
|
+
render(): string | number | boolean | Iterable<ReactNode> | import("react/jsx-runtime").JSX.Element | null | undefined;
|
|
29
|
+
}
|
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
2
|
+
import { ComponentSync } from '../core/ComponentSync.js';
|
|
3
|
+
import { TS_Input } from '../components/TS_Input/TS_Input.js';
|
|
4
|
+
import { TS_TextArea } from '../components/TS_Input/TS_TextArea.js';
|
|
5
|
+
export class FieldEditor extends ComponentSync {
|
|
6
|
+
constructor(props) {
|
|
7
|
+
super(props);
|
|
8
|
+
const prevValue = this.props.storageKey.get();
|
|
9
|
+
if (!prevValue) {
|
|
10
|
+
// this.logDebug(`FieldEditor: ${this.props.value}`);
|
|
11
|
+
this.props.storageKey.set(this.props.value || '');
|
|
12
|
+
}
|
|
13
|
+
}
|
|
14
|
+
deriveStateFromProps(nextProps) {
|
|
15
|
+
return {};
|
|
16
|
+
}
|
|
17
|
+
onChange = (value) => {
|
|
18
|
+
// this.logDebug(`input onChange: ${value}`);
|
|
19
|
+
this.props.storageKey.set(value);
|
|
20
|
+
this.forceUpdate();
|
|
21
|
+
};
|
|
22
|
+
renderInput = (value) => {
|
|
23
|
+
// @ts-ignore
|
|
24
|
+
return (_jsx(TS_Input, { ...this.props.inputProps, focus: true, id: this.props.id, type: this.props.type, onAccept: this.props.onAccept, value: value, onChange: this.onChange }));
|
|
25
|
+
};
|
|
26
|
+
renderArea = (value) => {
|
|
27
|
+
// @ts-ignore
|
|
28
|
+
return (_jsx(TS_TextArea, { ...this.props.inputProps, focus: true, id: this.props.id, type: this.props.type, onAccept: this.props.onAccept, value: value, onChange: this.onChange }));
|
|
29
|
+
};
|
|
30
|
+
renderLabel = () => {
|
|
31
|
+
const label = this.props.value || this.props.inputProps?.placeholder || '';
|
|
32
|
+
if (typeof this.props.labelProps === 'function')
|
|
33
|
+
return this.props.labelProps(label);
|
|
34
|
+
return _jsx("div", { ...this.props.labelProps, children: label });
|
|
35
|
+
};
|
|
36
|
+
render() {
|
|
37
|
+
const value = this.props.storageKey.get() || '';
|
|
38
|
+
if (!this.props.isEditing)
|
|
39
|
+
return this.renderLabel();
|
|
40
|
+
switch (this.props.editorType || 'input') {
|
|
41
|
+
case 'input':
|
|
42
|
+
return this.renderInput(value);
|
|
43
|
+
case 'textarea':
|
|
44
|
+
return this.renderArea(value);
|
|
45
|
+
}
|
|
46
|
+
}
|
|
47
|
+
}
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
import { HTMLProps, ReactNode } from 'react';
|
|
2
|
+
import { EditorType, FieldEditorInputProps } from './FieldEditor.js';
|
|
3
|
+
import { ComponentSync } from '../core/ComponentSync.js';
|
|
4
|
+
import { StorageKey } from '../modules/ModuleFE_LocalStorage.js';
|
|
5
|
+
import { InputType } from '../components/TS_Input/TS_BaseInput.js';
|
|
6
|
+
type State = {
|
|
7
|
+
isEditing: boolean;
|
|
8
|
+
storageKey: StorageKey<string>;
|
|
9
|
+
};
|
|
10
|
+
export type FieldEditorClickProps = {
|
|
11
|
+
clicks?: 1 | 2;
|
|
12
|
+
inputProps?: FieldEditorInputProps<any>;
|
|
13
|
+
labelProps?: HTMLProps<HTMLDivElement> | ((value: string) => ReactNode);
|
|
14
|
+
editorType?: EditorType;
|
|
15
|
+
type: InputType;
|
|
16
|
+
id: string;
|
|
17
|
+
onAccept: (value: string) => void;
|
|
18
|
+
value?: string;
|
|
19
|
+
};
|
|
20
|
+
export declare class FieldEditorClick extends ComponentSync<FieldEditorClickProps, State> {
|
|
21
|
+
private createStorageKey;
|
|
22
|
+
protected deriveStateFromProps(nextProps: FieldEditorClickProps): {
|
|
23
|
+
storageKey: StorageKey<string>;
|
|
24
|
+
isEditing: boolean;
|
|
25
|
+
};
|
|
26
|
+
componentDidUpdate(prevProps: Readonly<FieldEditorClickProps>, prevState: Readonly<State>): void;
|
|
27
|
+
private handleSave;
|
|
28
|
+
private startEdit;
|
|
29
|
+
private endEdit;
|
|
30
|
+
keyPressed: (e: KeyboardEvent) => void;
|
|
31
|
+
render(): import("react/jsx-runtime").JSX.Element;
|
|
32
|
+
}
|
|
33
|
+
export {};
|
|
@@ -0,0 +1,49 @@
|
|
|
1
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
2
|
+
import { FieldEditor } from './FieldEditor.js';
|
|
3
|
+
import { ComponentSync } from '../core/ComponentSync.js';
|
|
4
|
+
import { StorageKey } from '../modules/ModuleFE_LocalStorage.js';
|
|
5
|
+
export class FieldEditorClick extends ComponentSync {
|
|
6
|
+
createStorageKey() {
|
|
7
|
+
return new StorageKey(`editable-label-controller-${this.props.id}`);
|
|
8
|
+
}
|
|
9
|
+
deriveStateFromProps(nextProps) {
|
|
10
|
+
return {
|
|
11
|
+
storageKey: this.createStorageKey(),
|
|
12
|
+
isEditing: false,
|
|
13
|
+
};
|
|
14
|
+
}
|
|
15
|
+
componentDidUpdate(prevProps, prevState) {
|
|
16
|
+
let storageKey = prevState.storageKey;
|
|
17
|
+
if (prevProps.id !== this.props.id) {
|
|
18
|
+
storageKey = this.createStorageKey();
|
|
19
|
+
this.setState({ storageKey: storageKey });
|
|
20
|
+
}
|
|
21
|
+
const prevValue = storageKey.get();
|
|
22
|
+
if (!prevValue)
|
|
23
|
+
storageKey.set(this.props.value || '');
|
|
24
|
+
}
|
|
25
|
+
handleSave = () => {
|
|
26
|
+
this.props.onAccept(this.state.storageKey.get() ?? '');
|
|
27
|
+
this.endEdit();
|
|
28
|
+
};
|
|
29
|
+
startEdit = () => {
|
|
30
|
+
if (this.state.isEditing)
|
|
31
|
+
return;
|
|
32
|
+
addEventListener('keydown', this.keyPressed);
|
|
33
|
+
this.state.storageKey.set(this.props.value || '');
|
|
34
|
+
this.setState({ isEditing: true });
|
|
35
|
+
};
|
|
36
|
+
endEdit = () => {
|
|
37
|
+
removeEventListener('keydown', this.keyPressed);
|
|
38
|
+
this.logDebug('endEdit');
|
|
39
|
+
this.state.storageKey.delete();
|
|
40
|
+
this.setState({ isEditing: false });
|
|
41
|
+
};
|
|
42
|
+
keyPressed = (e) => {
|
|
43
|
+
if (e.code === 'Escape')
|
|
44
|
+
this.endEdit();
|
|
45
|
+
};
|
|
46
|
+
render() {
|
|
47
|
+
return (_jsx("div", { style: { width: '100%' }, onClick: this.props.clicks === 1 ? this.startEdit : undefined, onDoubleClick: this.props.clicks === undefined || this.props.clicks === 2 ? this.startEdit : undefined, onBlur: () => this.handleSave(), ...this.props.labelProps, children: _jsx(FieldEditor, { id: this.props.id, type: this.props.type, editorType: this.props.editorType, isEditing: this.state.isEditing, inputProps: this.props.inputProps, labelProps: this.props.labelProps, onCancel: this.endEdit, onAccept: this.handleSave, storageKey: this.state.storageKey, value: this.props.value }) }));
|
|
48
|
+
}
|
|
49
|
+
}
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
import { HTMLProps } from 'react';
|
|
2
|
+
import { FieldEditorInputProps } from './FieldEditor.js';
|
|
3
|
+
import { StorageKey } from '../modules/ModuleFE_LocalStorage.js';
|
|
4
|
+
import { ComponentSync } from '../core/ComponentSync.js';
|
|
5
|
+
import { InputType } from '../components/TS_Input/TS_BaseInput.js';
|
|
6
|
+
type State = {
|
|
7
|
+
isEditing: boolean;
|
|
8
|
+
storageKey: StorageKey<string>;
|
|
9
|
+
};
|
|
10
|
+
type Props = {
|
|
11
|
+
inputProps: FieldEditorInputProps<any>;
|
|
12
|
+
labelProps?: HTMLProps<HTMLDivElement>;
|
|
13
|
+
type: InputType;
|
|
14
|
+
id: string;
|
|
15
|
+
onAccept: (value: string) => void;
|
|
16
|
+
value?: string;
|
|
17
|
+
};
|
|
18
|
+
export declare class FieldEditorWithButtons extends ComponentSync<Props, State> {
|
|
19
|
+
private createStorageKey;
|
|
20
|
+
protected deriveStateFromProps(nextProps: Props): {
|
|
21
|
+
storageKey: StorageKey<string>;
|
|
22
|
+
isEditing: boolean;
|
|
23
|
+
};
|
|
24
|
+
componentDidUpdate(prevProps: Readonly<Props>, prevState: Readonly<State>): void;
|
|
25
|
+
handleEdit: () => void;
|
|
26
|
+
handleSave: () => void;
|
|
27
|
+
handleCancel: () => void;
|
|
28
|
+
render(): import("react/jsx-runtime").JSX.Element;
|
|
29
|
+
private renderEditButton;
|
|
30
|
+
private renderControlButtons;
|
|
31
|
+
}
|
|
32
|
+
export {};
|
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import { FieldEditor } from './FieldEditor.js';
|
|
3
|
+
import { StorageKey } from '../modules/ModuleFE_LocalStorage.js';
|
|
4
|
+
import { ComponentSync } from '../core/ComponentSync.js';
|
|
5
|
+
export class FieldEditorWithButtons extends ComponentSync {
|
|
6
|
+
createStorageKey() {
|
|
7
|
+
return new StorageKey(`editable-label-controller-${this.props.id}`);
|
|
8
|
+
}
|
|
9
|
+
deriveStateFromProps(nextProps) {
|
|
10
|
+
return {
|
|
11
|
+
storageKey: this.createStorageKey(),
|
|
12
|
+
isEditing: false,
|
|
13
|
+
};
|
|
14
|
+
}
|
|
15
|
+
componentDidUpdate(prevProps, prevState) {
|
|
16
|
+
if (prevProps.id !== this.props.id) {
|
|
17
|
+
this.setState({ storageKey: this.createStorageKey() });
|
|
18
|
+
}
|
|
19
|
+
}
|
|
20
|
+
handleEdit = () => {
|
|
21
|
+
// Save the state's value in case of cancellation.
|
|
22
|
+
this.setState({ isEditing: true });
|
|
23
|
+
};
|
|
24
|
+
handleSave = () => {
|
|
25
|
+
this.props.onAccept(this.state.storageKey.get() ?? '');
|
|
26
|
+
this.handleCancel();
|
|
27
|
+
};
|
|
28
|
+
handleCancel = () => {
|
|
29
|
+
this.state.storageKey.delete();
|
|
30
|
+
this.setState({ isEditing: false });
|
|
31
|
+
};
|
|
32
|
+
render() {
|
|
33
|
+
const { isEditing } = this.state;
|
|
34
|
+
return (_jsxs("div", { className: `ll_h_c`, style: { justifyContent: 'space-between' }, children: [_jsx("div", { children: _jsx(FieldEditor, { id: this.props.id, type: this.props.type, isEditing: this.state.isEditing, inputProps: this.props.inputProps, labelProps: this.props.labelProps, onAccept: this.handleSave, onCancel: this.handleCancel, storageKey: this.state.storageKey, value: this.props.value }) }), isEditing ? this.renderControlButtons() : this.renderEditButton()] }));
|
|
35
|
+
}
|
|
36
|
+
renderEditButton = () => {
|
|
37
|
+
return _jsx("button", { onClick: this.handleEdit, children: "Edit" });
|
|
38
|
+
};
|
|
39
|
+
renderControlButtons = () => {
|
|
40
|
+
return _jsxs("div", { children: [_jsx("button", { onClick: this.handleSave, children: "Save" }), _jsx("button", { onClick: this.handleCancel, children: "Cancel" })] });
|
|
41
|
+
};
|
|
42
|
+
}
|