@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,332 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
/*
|
|
3
|
+
* Thunderstorm is a full web app framework!
|
|
4
|
+
*
|
|
5
|
+
* Typescript & Express backend infrastructure that natively runs on firebase function
|
|
6
|
+
* Typescript & React frontend infrastructure
|
|
7
|
+
*
|
|
8
|
+
* Copyright (C) 2020 Adam van der Kruk aka TacB0sS
|
|
9
|
+
*
|
|
10
|
+
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
11
|
+
* you may not use this file except in compliance with the License.
|
|
12
|
+
* You may obtain a copy of the License at
|
|
13
|
+
*
|
|
14
|
+
* http://www.apache.org/licenses/LICENSE-2.0
|
|
15
|
+
*
|
|
16
|
+
* Unless required by applicable law or agreed to in writing, software
|
|
17
|
+
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
18
|
+
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
19
|
+
* See the License for the specific language governing permissions and
|
|
20
|
+
* limitations under the License.
|
|
21
|
+
*/
|
|
22
|
+
import * as React from 'react';
|
|
23
|
+
import { BadImplementationException, clamp, debounce, resolveContent, voidFunction } from '@nu-art/ts-common';
|
|
24
|
+
import { _className, stopPropagation } from '../../utils/tools.js';
|
|
25
|
+
import { Adapter, } from '../adapter/Adapter.js';
|
|
26
|
+
import { TS_Overlay } from '../TS_Overlay/index.js';
|
|
27
|
+
import { TS_Tree } from '../TS_Tree/index.js';
|
|
28
|
+
import { ComponentSync } from '../../core/ComponentSync.js';
|
|
29
|
+
import { TS_Input } from '../TS_Input/index.js';
|
|
30
|
+
import './TS_DropDown.scss';
|
|
31
|
+
import { LL_V_L } from '../Layouts/index.js';
|
|
32
|
+
import { convertToHTMLDataAttributes, getErrorTooltip, resolveEditableError } from '../types.js';
|
|
33
|
+
export class TS_DropDown extends ComponentSync {
|
|
34
|
+
// ######################## Static ########################
|
|
35
|
+
static prepareEditable = (mandatoryProps) => {
|
|
36
|
+
return (props) => _jsx(TS_DropDown, { ...resolveContent(mandatoryProps), ...props, error: resolveEditableError(props), onSelected: (item) => props.onSelected ? props.onSelected(item) : props.editable.updateObj({ [props.prop]: item }), selected: props.editable.item[props.prop] });
|
|
37
|
+
};
|
|
38
|
+
static prepareSelectable = (mandatoryProps) => {
|
|
39
|
+
return (props) => _jsx(TS_DropDown, { ...resolveContent(mandatoryProps), ...props });
|
|
40
|
+
};
|
|
41
|
+
static prepare = (mandatoryProps) => {
|
|
42
|
+
return {
|
|
43
|
+
editable: this.prepareEditable(mandatoryProps),
|
|
44
|
+
selectable: this.prepareSelectable(mandatoryProps)
|
|
45
|
+
};
|
|
46
|
+
};
|
|
47
|
+
static defaultRenderSearch = (dropDown) => _jsx(TS_Input, { type: "text", value: dropDown.props.inputValue, onChange: (filterText) => dropDown.reDeriveState({ filterText }), focus: true, placeholder: dropDown.props.placeholder && !dropDown.state.hidePlaceholderOnOpen ? dropDown.props.placeholder : '',
|
|
48
|
+
// onAccept={(value, ev) => {
|
|
49
|
+
// const filterText = dropDown.state.filterText;
|
|
50
|
+
// if (filterText) {
|
|
51
|
+
// dropDown.setState({open: false}, () => dropDown.props.onNoMatchingSelectionForString?.(filterText, dropDown.state.adapter.data, ev));
|
|
52
|
+
// } else
|
|
53
|
+
// dropDown.onSelected(dropDown.state.adapter.data[0]);
|
|
54
|
+
// }}
|
|
55
|
+
onCancel: () => dropDown.reDeriveState({ open: false, filterText: undefined }), onKeyDown: dropDown.inputKeyEventHandler });
|
|
56
|
+
static defaultProps = {
|
|
57
|
+
renderSearch: TS_DropDown.defaultRenderSearch,
|
|
58
|
+
};
|
|
59
|
+
// ######################## Life Cycle ########################
|
|
60
|
+
constructor(props) {
|
|
61
|
+
super(props);
|
|
62
|
+
}
|
|
63
|
+
deriveStateFromProps(nextProps, state) {
|
|
64
|
+
const nextState = this.state ? { ...this.state } : {};
|
|
65
|
+
const nextAdapter = typeof nextProps.adapter === 'function' ? nextProps.adapter(state?.filterText) : nextProps.adapter;
|
|
66
|
+
const prevAdapter = typeof this.props.adapter === 'function' ? this.props.adapter(state?.filterText) : this.props.adapter;
|
|
67
|
+
nextState.error = nextProps.error;
|
|
68
|
+
nextState.selected = nextProps.selected;
|
|
69
|
+
nextState.filterText ??= nextProps.inputValue;
|
|
70
|
+
nextState.dropDownRef = nextProps.innerRef ?? this.state?.dropDownRef ?? React.createRef();
|
|
71
|
+
nextState.treeContainerRef = state?.treeContainerRef ?? React.createRef();
|
|
72
|
+
nextState.className = nextProps.className;
|
|
73
|
+
nextState.treeResizeObserver ??= new ResizeObserver(() => debounce(() => this.onTreeResize(), 5));
|
|
74
|
+
nextState.hidePlaceholderOnOpen = nextProps.hidePlaceholderOnOpen;
|
|
75
|
+
if (!nextState.adapter || (nextAdapter.data !== prevAdapter.data) || (state?.filterText !== nextState.filterText) || nextProps.queryFilter) {
|
|
76
|
+
nextState.adapter = this.createAdapter(nextAdapter, nextProps.limitItems, state?.filterText, nextProps.queryFilter);
|
|
77
|
+
nextState.focusedItem = undefined;
|
|
78
|
+
}
|
|
79
|
+
return {
|
|
80
|
+
open: state?.open,
|
|
81
|
+
error: nextState.error,
|
|
82
|
+
adapter: nextState.adapter,
|
|
83
|
+
selected: nextState.selected,
|
|
84
|
+
hidePlaceholderOnOpen: nextState.hidePlaceholderOnOpen,
|
|
85
|
+
hover: state?.hover,
|
|
86
|
+
filterText: state?.filterText,
|
|
87
|
+
dropDownRef: nextState.dropDownRef,
|
|
88
|
+
focusedItem: nextState.focusedItem,
|
|
89
|
+
treeContainerRef: nextState.treeContainerRef,
|
|
90
|
+
className: nextState.className,
|
|
91
|
+
treeResizeObserver: nextState.treeResizeObserver,
|
|
92
|
+
disabled: !!nextProps.disabled,
|
|
93
|
+
};
|
|
94
|
+
}
|
|
95
|
+
onTreeResize = () => {
|
|
96
|
+
const treeContainer = this.state.treeContainerRef.current;
|
|
97
|
+
const ddContainer = this.state.dropDownRef.current;
|
|
98
|
+
if (!treeContainer || !ddContainer)
|
|
99
|
+
return;
|
|
100
|
+
const ddRect = ddContainer.getBoundingClientRect();
|
|
101
|
+
const treeRect = treeContainer.getBoundingClientRect();
|
|
102
|
+
const rightBoundary = window.innerWidth - 20;
|
|
103
|
+
const leftBoundary = 20;
|
|
104
|
+
//Not overflowing screen right - nothing to fix
|
|
105
|
+
if (!(treeRect.right > rightBoundary))
|
|
106
|
+
return;
|
|
107
|
+
//Align to DD right, if it won't overflow screen left
|
|
108
|
+
const newXPos = ddRect.x + ddRect.width;
|
|
109
|
+
if (newXPos - treeRect.width >= leftBoundary) {
|
|
110
|
+
//Set align on right
|
|
111
|
+
treeContainer.style.removeProperty('left');
|
|
112
|
+
treeContainer.style.right = `${window.innerWidth - newXPos}px`;
|
|
113
|
+
return;
|
|
114
|
+
}
|
|
115
|
+
//Align the tree to rightBoundary
|
|
116
|
+
treeContainer.style.removeProperty('left');
|
|
117
|
+
treeContainer.style.right = '20px';
|
|
118
|
+
};
|
|
119
|
+
componentDidUpdate() {
|
|
120
|
+
if (!this.state.open)
|
|
121
|
+
return;
|
|
122
|
+
const treeContainer = this.state.treeContainerRef.current;
|
|
123
|
+
if (!treeContainer)
|
|
124
|
+
return;
|
|
125
|
+
this.state.treeResizeObserver.observe(treeContainer);
|
|
126
|
+
}
|
|
127
|
+
// ######################## Logic ########################
|
|
128
|
+
getBoundingParent() {
|
|
129
|
+
if (!this.props.boundingParentSelector)
|
|
130
|
+
return undefined;
|
|
131
|
+
return this.state.dropDownRef.current?.closest(this.props.boundingParentSelector);
|
|
132
|
+
}
|
|
133
|
+
closeList = (e, selectedItem, action) => {
|
|
134
|
+
if (this.state.disabled)
|
|
135
|
+
return;
|
|
136
|
+
if (e)
|
|
137
|
+
stopPropagation(e);
|
|
138
|
+
this.setState({
|
|
139
|
+
open: false,
|
|
140
|
+
filterText: undefined,
|
|
141
|
+
focusedItem: undefined,
|
|
142
|
+
selected: selectedItem === null ? undefined : selectedItem || this.state.selected
|
|
143
|
+
}, action);
|
|
144
|
+
};
|
|
145
|
+
onSelected = (item, e) => {
|
|
146
|
+
this.closeList(e, item, () => this.props.onSelected(item));
|
|
147
|
+
};
|
|
148
|
+
inputKeyEventHandler = (e, disableIfOpen = false) => {
|
|
149
|
+
if (disableIfOpen)
|
|
150
|
+
return;
|
|
151
|
+
if (this.props.inputEventHandler)
|
|
152
|
+
return this.setState(() => {
|
|
153
|
+
return this.props.inputEventHandler ? this.props.inputEventHandler(this.state, e) : this.state;
|
|
154
|
+
});
|
|
155
|
+
if (!this.state.open) {
|
|
156
|
+
if (e.key === 'Enter' || e.key === 'ArrowDown')
|
|
157
|
+
this.setState({ open: true });
|
|
158
|
+
return;
|
|
159
|
+
}
|
|
160
|
+
if (e.key === 'Enter') {
|
|
161
|
+
e.persist();
|
|
162
|
+
if (this.state.focusedItem) {
|
|
163
|
+
return this.onSelected(this.state.focusedItem);
|
|
164
|
+
}
|
|
165
|
+
const filterText = this.state.filterText;
|
|
166
|
+
if (filterText) {
|
|
167
|
+
this.closeList(e, null, () => this.props.onNoMatchingSelectionForString?.(filterText, this.state.adapter.data, e));
|
|
168
|
+
}
|
|
169
|
+
else
|
|
170
|
+
this.onSelected(this.state.adapter.data[0], e);
|
|
171
|
+
}
|
|
172
|
+
if (e.key === 'Escape')
|
|
173
|
+
return this.closeList(e);
|
|
174
|
+
if (e.key === 'ArrowDown' || e.key === 'ArrowUp') {
|
|
175
|
+
let index = this.state.focusedItem ? this.state.adapter.data.indexOf(this.state.focusedItem) + (e.key === 'ArrowDown' ? 1 : -1) : 0;
|
|
176
|
+
index = clamp(0, index, this.state.adapter.data.length - 1);
|
|
177
|
+
this.setState({ focusedItem: this.state.adapter.data[index] });
|
|
178
|
+
}
|
|
179
|
+
};
|
|
180
|
+
createAdapter(adapterToClone, limit, filterText, queryFilter) {
|
|
181
|
+
//If no change to data
|
|
182
|
+
if (!(filterText && this.props.filter) && !limit && !queryFilter)
|
|
183
|
+
return adapterToClone;
|
|
184
|
+
let data = adapterToClone.data;
|
|
185
|
+
//If queryFilter
|
|
186
|
+
if (queryFilter) {
|
|
187
|
+
data = data.filter((item) => queryFilter(item));
|
|
188
|
+
}
|
|
189
|
+
//If filtering
|
|
190
|
+
if (filterText && this.props.filter)
|
|
191
|
+
data = this.props.filter.filterSort(data, filterText);
|
|
192
|
+
//If limiting
|
|
193
|
+
if (limit)
|
|
194
|
+
data = limit ? data.slice(0, limit) : data;
|
|
195
|
+
const adapter = adapterToClone.clone(new Adapter(data));
|
|
196
|
+
adapter.data = data;
|
|
197
|
+
return adapter;
|
|
198
|
+
}
|
|
199
|
+
getChildrenContainerMaxHeight = (dropdownRef, dir) => {
|
|
200
|
+
const rect = dropdownRef.current?.getBoundingClientRect();
|
|
201
|
+
if (!rect) {
|
|
202
|
+
this.logWarning('getChildrenContainerMaxHeight - No Rect!!');
|
|
203
|
+
return 0;
|
|
204
|
+
}
|
|
205
|
+
const boundingParent = this.getBoundingParent();
|
|
206
|
+
if (boundingParent) {
|
|
207
|
+
const boundingRect = boundingParent.getBoundingClientRect();
|
|
208
|
+
return (dir === 'bottom' ? (boundingRect.bottom - rect.bottom - 20) : (rect.top - boundingRect.top - 20));
|
|
209
|
+
}
|
|
210
|
+
return (dir === 'bottom' ? (window.innerHeight - rect.bottom - 20) : (rect.top - 20));
|
|
211
|
+
};
|
|
212
|
+
getChildrenContainerPosX = (dropdownRef) => {
|
|
213
|
+
const rect = dropdownRef.current.getBoundingClientRect();
|
|
214
|
+
return rect.x;
|
|
215
|
+
};
|
|
216
|
+
getChildrenContainerPosY = (dropdownRef, dir) => {
|
|
217
|
+
const rect = dropdownRef.current.getBoundingClientRect();
|
|
218
|
+
if (dir === 'bottom') {
|
|
219
|
+
return rect.bottom;
|
|
220
|
+
}
|
|
221
|
+
return window.innerHeight - rect.top;
|
|
222
|
+
};
|
|
223
|
+
getChildrenContainerWidth = (dropdownRef) => {
|
|
224
|
+
const rect = dropdownRef.current.getBoundingClientRect();
|
|
225
|
+
return rect.right - rect.left;
|
|
226
|
+
};
|
|
227
|
+
// ######################## Render ########################
|
|
228
|
+
render() {
|
|
229
|
+
const className = _className('ts-dropdown', this.state.className, this.state.open ? 'open' : undefined, this.state.disabled ? 'disabled' : undefined);
|
|
230
|
+
return (_jsxs("div", { className: className, id: this.props.id, ref: this.state.dropDownRef, tabIndex: this.props.tabIndex, onFocus: this.addKeyboardListener, onBlur: this.removeKeyboardListener, ...getErrorTooltip(this.props.error, this.props.showErrorTooltip), ...convertToHTMLDataAttributes(this.state.error, 'error'), children: [this.renderHeader(), _jsx(TS_Overlay, { flat: false, showOverlay: !!this.state.open, onClickOverlay: this.closeList, children: this.renderTree() })] }));
|
|
231
|
+
}
|
|
232
|
+
renderHeader = () => {
|
|
233
|
+
const className = _className('ts-dropdown__header', this.props.disabled ? 'disabled' : undefined);
|
|
234
|
+
return (_jsxs("div", { className: className, onClick: (e) => {
|
|
235
|
+
stopPropagation(e);
|
|
236
|
+
if (this.state.disabled) {
|
|
237
|
+
return;
|
|
238
|
+
}
|
|
239
|
+
this.state.open ? this.closeList(e) : this.setState({ open: true });
|
|
240
|
+
}, children: [this.renderSelectedOrFilterInput(), this.state.open && this.props.caret ? this.props.caret?.close : this.props.caret?.open] }));
|
|
241
|
+
};
|
|
242
|
+
renderTree = () => {
|
|
243
|
+
if (!this.state.open)
|
|
244
|
+
return '';
|
|
245
|
+
if (this.props.showNothingWithoutFilterText && !this.state.filterText?.length)
|
|
246
|
+
return '';
|
|
247
|
+
let className = 'ts-dropdown__items-container';
|
|
248
|
+
// const treeKeyEventHandler = treeKeyEventHandlerResolver(this.props.id);
|
|
249
|
+
const style = {};
|
|
250
|
+
if (this.state?.dropDownRef.current) {
|
|
251
|
+
//Get container data
|
|
252
|
+
const containerData = {
|
|
253
|
+
posX: this.getChildrenContainerPosX(this.state.dropDownRef),
|
|
254
|
+
posY: this.getChildrenContainerPosY(this.state.dropDownRef, 'bottom'),
|
|
255
|
+
width: this.getChildrenContainerWidth(this.state.dropDownRef),
|
|
256
|
+
maxHeight: this.getChildrenContainerMaxHeight(this.state.dropDownRef, 'bottom'),
|
|
257
|
+
};
|
|
258
|
+
//Set initial top
|
|
259
|
+
style.top = containerData.posY;
|
|
260
|
+
//If not enough space at the bottom, re-calculate for top display
|
|
261
|
+
if (containerData.maxHeight < 100) {
|
|
262
|
+
containerData.maxHeight = this.getChildrenContainerMaxHeight(this.state.dropDownRef, 'top');
|
|
263
|
+
containerData.posY = this.getChildrenContainerPosY(this.state.dropDownRef, 'top');
|
|
264
|
+
className += ' inverted';
|
|
265
|
+
delete style.top;
|
|
266
|
+
style.bottom = containerData.posY;
|
|
267
|
+
}
|
|
268
|
+
//Set style attributes
|
|
269
|
+
style.position = 'absolute';
|
|
270
|
+
style.left = containerData.posX;
|
|
271
|
+
style.maxHeight = containerData.maxHeight;
|
|
272
|
+
// style.width = containerData.width;
|
|
273
|
+
//Contain the max and min width of the tree
|
|
274
|
+
style.minWidth = containerData.width;
|
|
275
|
+
style.maxWidth = window.innerWidth - 40;
|
|
276
|
+
// @ts-ignore
|
|
277
|
+
style['--dd-width'] = `${containerData.width}px`;
|
|
278
|
+
}
|
|
279
|
+
if (!this.state.adapter.data)
|
|
280
|
+
throw new BadImplementationException('No data provided to TS_DropDown!');
|
|
281
|
+
if ((!this.props.filter || !this.props.showNothingWithoutFilterText || this.state.filterText?.length) && this.state.adapter.data.length === 0) {
|
|
282
|
+
if (this.props.noOptionsRenderer)
|
|
283
|
+
return _jsx("div", { className: "ts-dropdown__empty", style: style, children: (typeof this.props.noOptionsRenderer === 'function' ? this.props.noOptionsRenderer(this.state.filterText) : this.props.noOptionsRenderer) });
|
|
284
|
+
return _jsx("div", { className: "ts-dropdown__empty", style: style, children: "No options" });
|
|
285
|
+
}
|
|
286
|
+
return _jsxs(LL_V_L, { className: className, style: style, innerRef: this.state.treeContainerRef, children: [this.props.canUnselect && _jsx("div", { className: 'ts-dropdown__unselect-item', onClick: (e) => this.onSelected(undefined, e), children: this.props.unselectLabel ? this.props.unselectLabel : 'Unselect' }), _jsx(TS_Tree, { adapter: this.state.adapter, selectedItem: this.state.focusedItem, onNodeClicked: (path, item) => this.onSelected(item), className: 'ts-dropdown__items', scrollSelectedIntoView: true, containerRef: this.state.treeContainerRef })] });
|
|
287
|
+
};
|
|
288
|
+
renderSelectedItem = (selected) => {
|
|
289
|
+
if (this.props.selectedItemRenderer)
|
|
290
|
+
return this.props.selectedItemRenderer(selected);
|
|
291
|
+
if (selected === undefined)
|
|
292
|
+
return _jsx("div", { className: "ts-dropdown__placeholder", children: this.props.placeholder || '' });
|
|
293
|
+
const adapter = typeof this.props.adapter === 'function' ? this.props.adapter(this.state.filterText) : this.props.adapter;
|
|
294
|
+
const Renderer = adapter.treeNodeRenderer;
|
|
295
|
+
const node = {
|
|
296
|
+
propKey: 'string',
|
|
297
|
+
path: 'string',
|
|
298
|
+
item: 'any',
|
|
299
|
+
adapter: adapter,
|
|
300
|
+
expandToggler: (e, expxand) => {
|
|
301
|
+
},
|
|
302
|
+
expandFromNode: voidFunction,
|
|
303
|
+
onClick: (e) => {
|
|
304
|
+
},
|
|
305
|
+
expanded: true,
|
|
306
|
+
focused: false,
|
|
307
|
+
selected: true
|
|
308
|
+
};
|
|
309
|
+
return _jsx("div", { className: 'ts-dropdown__selected', onContextMenu: this.props.onContextMenu, children: _jsx(Renderer, { item: selected, node: node }) });
|
|
310
|
+
};
|
|
311
|
+
renderSelectedOrFilterInput = () => {
|
|
312
|
+
if (!this.state.open || (!this.props.filter && typeof this.props.adapter !== 'function')) {
|
|
313
|
+
return this.renderSelectedItem(this.state.selected);
|
|
314
|
+
}
|
|
315
|
+
return this.props.renderSearch(this);
|
|
316
|
+
};
|
|
317
|
+
// ######################## To Remove ########################
|
|
318
|
+
// TODO: THIS IS ALL DUPLICATE SHIT... DELETE ONCE TREE CAN PROPAGATE THE KEYBOARD EVENTS
|
|
319
|
+
addKeyboardListener = () => {
|
|
320
|
+
const onKeyboardEventListener = this.inputKeyEventHandler;
|
|
321
|
+
if (!onKeyboardEventListener)
|
|
322
|
+
return;
|
|
323
|
+
this.state.dropDownRef.current?.addEventListener('keydown', this.keyboardEventHandler);
|
|
324
|
+
};
|
|
325
|
+
removeKeyboardListener = () => {
|
|
326
|
+
const onKeyboardEventListener = this.inputKeyEventHandler;
|
|
327
|
+
if (!onKeyboardEventListener)
|
|
328
|
+
return;
|
|
329
|
+
this.state.dropDownRef.current?.removeEventListener('keydown', this.keyboardEventHandler);
|
|
330
|
+
};
|
|
331
|
+
keyboardEventHandler = (e) => this.state.dropDownRef.current && this.inputKeyEventHandler(e, this.state.open);
|
|
332
|
+
}
|
|
@@ -0,0 +1,134 @@
|
|
|
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
|
+
@use "../../styles/declaration/basic" as *;
|
|
22
|
+
|
|
23
|
+
.ts-dropdown {
|
|
24
|
+
position: relative;
|
|
25
|
+
isolation: isolate;
|
|
26
|
+
z-index: 0;
|
|
27
|
+
flex-shrink: 0;
|
|
28
|
+
|
|
29
|
+
//Children - header
|
|
30
|
+
.ts-dropdown__header {
|
|
31
|
+
@extend %match_parent;
|
|
32
|
+
height: 30px;
|
|
33
|
+
background: white;
|
|
34
|
+
border-radius: 5px;
|
|
35
|
+
border: 1px solid #4fa7ff;
|
|
36
|
+
display: flex;
|
|
37
|
+
z-index: 20 !important;
|
|
38
|
+
|
|
39
|
+
.ts-input {
|
|
40
|
+
@extend %match_height;
|
|
41
|
+
background-color: transparent;
|
|
42
|
+
border: none;
|
|
43
|
+
padding-block: 0;
|
|
44
|
+
|
|
45
|
+
&:focus-visible {
|
|
46
|
+
outline: none;
|
|
47
|
+
}
|
|
48
|
+
}
|
|
49
|
+
|
|
50
|
+
|
|
51
|
+
.ts-dropdown__placeholder,
|
|
52
|
+
.ts-dropdown__selected {
|
|
53
|
+
@extend %match_height;
|
|
54
|
+
flex-grow: 1;
|
|
55
|
+
font-size: 16px;
|
|
56
|
+
display: flex;
|
|
57
|
+
justify-content: flex-start;
|
|
58
|
+
align-items: center;
|
|
59
|
+
padding-inline: 4px;
|
|
60
|
+
}
|
|
61
|
+
}
|
|
62
|
+
|
|
63
|
+
.ts-dropdown__empty {
|
|
64
|
+
background: white;
|
|
65
|
+
border-radius: 0 0 4px 4px;
|
|
66
|
+
border: 1px solid #4fa7ff;
|
|
67
|
+
padding: 5px;
|
|
68
|
+
position: absolute;
|
|
69
|
+
text-align: center;
|
|
70
|
+
}
|
|
71
|
+
|
|
72
|
+
//Children - items
|
|
73
|
+
.ts-overlay {
|
|
74
|
+
z-index: 10 !important;
|
|
75
|
+
}
|
|
76
|
+
|
|
77
|
+
.ts-overlay__child {
|
|
78
|
+
z-index: 15 !important;
|
|
79
|
+
position: static;
|
|
80
|
+
}
|
|
81
|
+
|
|
82
|
+
.ts-dropdown__items-container {
|
|
83
|
+
//Colors
|
|
84
|
+
background: white;
|
|
85
|
+
|
|
86
|
+
//Border
|
|
87
|
+
border: 1px solid #4fa7ff;
|
|
88
|
+
border-radius: 0 0 5px 5px;
|
|
89
|
+
|
|
90
|
+
overflow-y: auto;
|
|
91
|
+
overflow-x: hidden;
|
|
92
|
+
|
|
93
|
+
.ts-dropdown__unselect-item {
|
|
94
|
+
width: 100%;
|
|
95
|
+
padding: 5px;
|
|
96
|
+
font-size: 18px;
|
|
97
|
+
border-bottom: 2px dotted black;
|
|
98
|
+
|
|
99
|
+
&:hover {
|
|
100
|
+
background: cornsilk;
|
|
101
|
+
}
|
|
102
|
+
}
|
|
103
|
+
|
|
104
|
+
.ts-tree {
|
|
105
|
+
//Dimensions
|
|
106
|
+
width: 100%;
|
|
107
|
+
min-height: 10px;
|
|
108
|
+
|
|
109
|
+
|
|
110
|
+
.ts-tree__children-container {
|
|
111
|
+
margin: 0;
|
|
112
|
+
|
|
113
|
+
.ts-tree__node {
|
|
114
|
+
padding: 5px;
|
|
115
|
+
}
|
|
116
|
+
}
|
|
117
|
+
}
|
|
118
|
+
|
|
119
|
+
&.inverted {
|
|
120
|
+
padding-top: 0;
|
|
121
|
+
padding-bottom: 3px;
|
|
122
|
+
border-radius: 5px 5px 0 0;
|
|
123
|
+
}
|
|
124
|
+
}
|
|
125
|
+
|
|
126
|
+
|
|
127
|
+
&.open {
|
|
128
|
+
z-index: 1;
|
|
129
|
+
}
|
|
130
|
+
|
|
131
|
+
&.disabled {
|
|
132
|
+
cursor: not-allowed;
|
|
133
|
+
}
|
|
134
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from './TS_DropDown.js';
|
|
@@ -0,0 +1,21 @@
|
|
|
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
|
+
export * from './TS_DropDown.js';
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import { ReactNode } from 'react';
|
|
2
|
+
import { DBProto } from '@nu-art/ts-common';
|
|
3
|
+
import { Controller, Props_Controller } from '../../core/Controller.js';
|
|
4
|
+
import { InferState } from '../../utils/types.js';
|
|
5
|
+
import { EditableRef } from './types.js';
|
|
6
|
+
type _State<Item> = EditableRef<Item> & {
|
|
7
|
+
tag?: string;
|
|
8
|
+
};
|
|
9
|
+
export type EditableContentType<Opt> = Opt extends DBProto<any> ? Opt['uiType'] : Opt;
|
|
10
|
+
export declare abstract class TS_EditableContent<Opt, P = {}, S = {}, ItemType extends EditableContentType<Opt> = EditableContentType<Opt>, Props extends P & EditableRef<ItemType> & Props_Controller = P & EditableRef<ItemType> & Props_Controller, State extends S & _State<ItemType> = S & _State<ItemType>> extends Controller<Props, State> {
|
|
11
|
+
shouldReDeriveState(nextProps: Readonly<Props>): boolean;
|
|
12
|
+
shouldComponentUpdate(nextProps: Readonly<Props>, nextState: Readonly<State>, nextContext: any): boolean;
|
|
13
|
+
protected deriveStateFromProps(nextProps: Props, state: State): InferState<this>;
|
|
14
|
+
protected renderProp(label: string, render: ReactNode, className?: string): import("react/jsx-runtime").JSX.Element;
|
|
15
|
+
protected renderPropVertical(label: string, render: ReactNode, className?: string): import("react/jsx-runtime").JSX.Element;
|
|
16
|
+
protected renderPropHorizontal(label: string, render: ReactNode, className?: string): import("react/jsx-runtime").JSX.Element;
|
|
17
|
+
item: () => Partial<ItemType>;
|
|
18
|
+
}
|
|
19
|
+
export {};
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
2
|
+
import { TS_PropRenderer } from '../TS_PropRenderer/index.js';
|
|
3
|
+
import { Controller } from '../../core/Controller.js';
|
|
4
|
+
export class TS_EditableContent extends Controller {
|
|
5
|
+
shouldReDeriveState(nextProps) {
|
|
6
|
+
// if (!this.state)
|
|
7
|
+
// throw new BadImplementationException(`Check if you have overridden 'deriveStateFromProps' without calling super.`);
|
|
8
|
+
if (this.state.tag !== nextProps.editable.tag)
|
|
9
|
+
return true;
|
|
10
|
+
return super.shouldReDeriveState(nextProps);
|
|
11
|
+
}
|
|
12
|
+
shouldComponentUpdate(nextProps, nextState, nextContext) {
|
|
13
|
+
if (this.state.tag !== nextState.editable.tag)
|
|
14
|
+
return true;
|
|
15
|
+
return super.shouldComponentUpdate(nextProps, nextState, nextContext);
|
|
16
|
+
}
|
|
17
|
+
deriveStateFromProps(nextProps, state) {
|
|
18
|
+
state.editable = nextProps.editable;
|
|
19
|
+
state.tag = nextProps.editable.tag;
|
|
20
|
+
return state;
|
|
21
|
+
}
|
|
22
|
+
renderProp(label, render, className) {
|
|
23
|
+
return this.renderPropVertical(label, render, className);
|
|
24
|
+
}
|
|
25
|
+
renderPropVertical(label, render, className) {
|
|
26
|
+
return (_jsx(TS_PropRenderer.Vertical, { label: label, className: className, children: render }));
|
|
27
|
+
}
|
|
28
|
+
renderPropHorizontal(label, render, className) {
|
|
29
|
+
return (_jsx(TS_PropRenderer.Horizontal, { label: label, className: className, children: render }));
|
|
30
|
+
}
|
|
31
|
+
item = () => this.state.editable.item;
|
|
32
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import { ReactNode } from 'react';
|
|
2
|
+
import { Controller, Props_Controller } from '../../core/Controller.js';
|
|
3
|
+
import { DBProto } from '@nu-art/ts-common';
|
|
4
|
+
import { InferProps, InferState } from '../../utils/types.js';
|
|
5
|
+
import { EditableRef } from '../TS_EditableContent/types.js';
|
|
6
|
+
type _State<Item> = EditableRef<Item> & {
|
|
7
|
+
tag?: string;
|
|
8
|
+
};
|
|
9
|
+
export declare abstract class TS_EditableItemComponent<ItemType, P = {}, S = {}, Props extends P & EditableRef<ItemType> & Props_Controller = P & EditableRef<ItemType> & Props_Controller, State extends S & _State<ItemType> = S & _State<ItemType>> extends Controller<Props, State> {
|
|
10
|
+
shouldReDeriveState(nextProps: Readonly<Props>): boolean;
|
|
11
|
+
shouldComponentUpdate(nextProps: Readonly<Props>, nextState: Readonly<State>, nextContext: any): boolean;
|
|
12
|
+
protected deriveStateFromProps(nextProps: Props, state: State): State;
|
|
13
|
+
protected renderProp(label: string, render: ReactNode, className?: string): import("react/jsx-runtime").JSX.Element;
|
|
14
|
+
item: () => Partial<ItemType>;
|
|
15
|
+
}
|
|
16
|
+
export declare abstract class TS_EditableItemComponentProto<Proto extends DBProto<any>, P = {}, S = {}, UI_Type extends Proto['uiType'] = Proto['uiType'], Props extends P & EditableRef<UI_Type> & Props_Controller = P & EditableRef<UI_Type> & Props_Controller, State extends S & _State<UI_Type> = S & _State<UI_Type>> extends Controller<Props, State> {
|
|
17
|
+
shouldReDeriveState(nextProps: Readonly<InferProps<this>>): boolean;
|
|
18
|
+
shouldComponentUpdate(nextProps: Readonly<Props>, nextState: Readonly<State>, nextContext: any): boolean;
|
|
19
|
+
protected deriveStateFromProps(nextProps: InferProps<this>, state: InferState<this>): InferState<this>;
|
|
20
|
+
protected renderProp(label: string, render: ReactNode, className?: string): import("react/jsx-runtime").JSX.Element;
|
|
21
|
+
item: () => Partial<UI_Type>;
|
|
22
|
+
}
|
|
23
|
+
export {};
|
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
2
|
+
import { Controller } from '../../core/Controller.js';
|
|
3
|
+
import { TS_PropRenderer } from '../TS_PropRenderer/index.js';
|
|
4
|
+
export class TS_EditableItemComponent extends Controller {
|
|
5
|
+
shouldReDeriveState(nextProps) {
|
|
6
|
+
// if (!this.state)
|
|
7
|
+
// throw new BadImplementationException(`Check if you have overridden 'deriveStateFromProps' without calling super.`);
|
|
8
|
+
if (this.state.tag !== nextProps.editable.tag)
|
|
9
|
+
return true;
|
|
10
|
+
return super.shouldReDeriveState(nextProps);
|
|
11
|
+
}
|
|
12
|
+
shouldComponentUpdate(nextProps, nextState, nextContext) {
|
|
13
|
+
if (this.state.tag !== nextState.editable.tag)
|
|
14
|
+
return true;
|
|
15
|
+
return super.shouldComponentUpdate(nextProps, nextState, nextContext);
|
|
16
|
+
}
|
|
17
|
+
deriveStateFromProps(nextProps, state) {
|
|
18
|
+
state.editable = nextProps.editable;
|
|
19
|
+
state.tag = nextProps.editable.tag;
|
|
20
|
+
return state;
|
|
21
|
+
}
|
|
22
|
+
renderProp(label, render, className) {
|
|
23
|
+
return (_jsx(TS_PropRenderer.Vertical, { label: label, className: className, children: render }));
|
|
24
|
+
}
|
|
25
|
+
item = () => this.state.editable.item;
|
|
26
|
+
}
|
|
27
|
+
export class TS_EditableItemComponentProto extends Controller {
|
|
28
|
+
shouldReDeriveState(nextProps) {
|
|
29
|
+
if (this.state.tag !== nextProps.editable.tag)
|
|
30
|
+
return true;
|
|
31
|
+
return super.shouldReDeriveState(nextProps);
|
|
32
|
+
}
|
|
33
|
+
shouldComponentUpdate(nextProps, nextState, nextContext) {
|
|
34
|
+
if (this.state.tag !== nextState.editable.tag)
|
|
35
|
+
return true;
|
|
36
|
+
return super.shouldComponentUpdate(nextProps, nextState, nextContext);
|
|
37
|
+
}
|
|
38
|
+
deriveStateFromProps(nextProps, state) {
|
|
39
|
+
state.editable = nextProps.editable;
|
|
40
|
+
state.tag = nextProps.editable.tag;
|
|
41
|
+
return state;
|
|
42
|
+
}
|
|
43
|
+
renderProp(label, render, className) {
|
|
44
|
+
return (_jsx(TS_PropRenderer.Vertical, { label: label, className: className, children: render }));
|
|
45
|
+
}
|
|
46
|
+
item = () => this.state.editable.item;
|
|
47
|
+
}
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
import * as React from 'react';
|
|
2
|
+
import './TS_EditableItemController.scss';
|
|
3
|
+
import { DB_Object, DBProto, ResolvableContent } from '@nu-art/ts-common';
|
|
4
|
+
import { Editable_SaveAction } from '../../utils/EditableItem.js';
|
|
5
|
+
import { ModuleFE_BaseApi } from '../../modules/db-api-gen/ModuleFE_BaseApi.js';
|
|
6
|
+
import { Props_ItemsEditor } from '../Page_ItemsEditor/index.js';
|
|
7
|
+
import { ComponentSync } from '../../core/ComponentSync.js';
|
|
8
|
+
import { EditableRef } from '../TS_EditableContent/types.js';
|
|
9
|
+
export type TemplatingProps_EditableItemController<Proto extends DBProto<any>, EditorProps extends object = object> = {
|
|
10
|
+
module: ModuleFE_BaseApi<Proto>;
|
|
11
|
+
onError?: (item: Partial<Proto['uiType']>, err: Error) => any | Promise<any>;
|
|
12
|
+
onSave?: (err: Proto['uiType']) => any | Promise<any>;
|
|
13
|
+
autoSave?: ResolvableContent<boolean, [Readonly<Proto['uiType']>]>;
|
|
14
|
+
saveAction?: Editable_SaveAction<Proto['uiType']>;
|
|
15
|
+
editor: React.ComponentType<EditableRef<Proto['uiType']> & EditorProps>;
|
|
16
|
+
createInitialInstance?: () => Readonly<Partial<Proto['uiType']>>;
|
|
17
|
+
editorProps?: EditorProps;
|
|
18
|
+
};
|
|
19
|
+
export type Props_EditableItemController<Proto extends DBProto<any>, EditorProps extends object = object> = TemplatingProps_EditableItemController<Proto, EditorProps> & {
|
|
20
|
+
item?: Readonly<Partial<Proto['uiType']>> | string;
|
|
21
|
+
};
|
|
22
|
+
/**
|
|
23
|
+
* Item_EditorController class handles the editing of a specific db item
|
|
24
|
+
* and encapsulate logic to load the item from the local cache and uses the EditableItem to
|
|
25
|
+
* and TS_EditableContent for rendering and editing the db item.
|
|
26
|
+
*
|
|
27
|
+
* @template Proto - The database prototype def to be edited
|
|
28
|
+
* @template Props - The Props this class component takes
|
|
29
|
+
*/
|
|
30
|
+
export declare class TS_EditableItemController<Proto extends DBProto<any>, EditorProps extends object = object, Props extends Props_EditableItemController<Proto, EditorProps> = Props_EditableItemController<Proto, EditorProps>> extends ComponentSync<Props, EditableRef<Proto['uiType']>> {
|
|
31
|
+
static DefaultAutoSave: (item?: Partial<DB_Object>) => boolean;
|
|
32
|
+
constructor(p: Props);
|
|
33
|
+
private __onItemUpdated;
|
|
34
|
+
protected deriveStateFromProps(nextProps: Props & Props_ItemsEditor<Proto>, state?: Partial<EditableRef<Proto['uiType']>>): (EditableRef<Proto['uiType']>);
|
|
35
|
+
render(): import("react/jsx-runtime").JSX.Element;
|
|
36
|
+
}
|