@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.
Files changed (635) hide show
  1. package/_ats/ATS_ActionProcessor/ATS_ActionProcessor.d.ts +17 -0
  2. package/_ats/ATS_ActionProcessor/ATS_ActionProcessor.js +52 -0
  3. package/_ats/ATS_ActionProcessor/ATS_ActionProcessor.scss +43 -0
  4. package/_ats/ATS_AppConfigEditor/ATS_AppConfigEditor.d.ts +25 -0
  5. package/_ats/ATS_AppConfigEditor/ATS_AppConfigEditor.js +88 -0
  6. package/_ats/ATS_AppConfigEditor/ATS_AppConfigEditor.scss +117 -0
  7. package/_ats/ATS_CollectionUpgrades/ATS_CollectionUpgrades.d.ts +17 -0
  8. package/_ats/ATS_CollectionUpgrades/ATS_CollectionUpgrades.js +45 -0
  9. package/_ats/ATS_CollectionUpgrades/ATS_CollectionUpgrades.scss +24 -0
  10. package/_ats/ATS_CrudOperations/ATS_CrudOperations.d.ts +29 -0
  11. package/_ats/ATS_CrudOperations/ATS_CrudOperations.js +93 -0
  12. package/_ats/ATS_CrudOperations/ATS_CrudOperations.scss +46 -0
  13. package/_ats/ATS_CrudOperations/ui-components.d.ts +24 -0
  14. package/_ats/ATS_CrudOperations/ui-components.js +11 -0
  15. package/_ats/ATS_EditableItem/ATS_EditableItem.d.ts +16 -0
  16. package/_ats/ATS_EditableItem/ATS_EditableItem.js +48 -0
  17. package/_ats/ATS_IDBCacheComparison/ATS_IDBCacheComparison.d.ts +18 -0
  18. package/_ats/ATS_IDBCacheComparison/ATS_IDBCacheComparison.js +28 -0
  19. package/_ats/ATS_IDBCacheComparison/ATS_IDBCacheComparison.scss +7 -0
  20. package/_ats/ATS_IDBCacheComparison/Component_CollectionGrid.d.ts +23 -0
  21. package/_ats/ATS_IDBCacheComparison/Component_CollectionGrid.js +66 -0
  22. package/_ats/ATS_IDBCacheComparison/Component_CollectionGrid.scss +52 -0
  23. package/_ats/ATS_IDBCacheComparison/Dialog_IDBCacheComparison.d.ts +17 -0
  24. package/_ats/ATS_IDBCacheComparison/Dialog_IDBCacheComparison.js +30 -0
  25. package/_ats/ATS_IDBCacheComparison/Dialog_IDBCacheComparison.scss +25 -0
  26. package/_ats/ATS_Printables/ATS_AbstractPrintable.d.ts +16 -0
  27. package/_ats/ATS_Printables/ATS_AbstractPrintable.js +37 -0
  28. package/_ats/ATS_Printables/ATS_Printable.d.ts +13 -0
  29. package/_ats/ATS_Printables/ATS_Printable.js +45 -0
  30. package/_ats/ATS_Printables/ATS_Printable.scss +40 -0
  31. package/_ats/ATS_ProtoComponent/ATS_ProtoComponent.d.ts +33 -0
  32. package/_ats/ATS_ProtoComponent/ATS_ProtoComponent.js +80 -0
  33. package/_ats/ATS_ProtoComponent/ATS_ProtoComponent.scss +19 -0
  34. package/_ats/ATS_SyncEnv/ATS_SyncEnv.d.ts +51 -0
  35. package/_ats/ATS_SyncEnv/ATS_SyncEnv.js +215 -0
  36. package/_ats/ATS_SyncEnv/ATS_SyncEnv.scss +172 -0
  37. package/_ats/ATS_Toaster/ATS_Toaster.d.ts +23 -0
  38. package/_ats/ATS_Toaster/ATS_Toaster.js +48 -0
  39. package/_ats/ATS_Toaster/ATS_Toaster.scss +2 -0
  40. package/_ats/ATS_Toaster/index.d.ts +1 -0
  41. package/_ats/ATS_Toaster/index.js +1 -0
  42. package/_ats/dialogs/Dialog_ActionProcessorConfirmation/Dialog_ActionProcessorConfirmation.d.ts +18 -0
  43. package/_ats/dialogs/Dialog_ActionProcessorConfirmation/Dialog_ActionProcessorConfirmation.js +41 -0
  44. package/_ats/dialogs/Dialog_ActionProcessorConfirmation/Dialog_ActionProcessorConfirmation.scss +71 -0
  45. package/_ats/dialogs/index.d.ts +1 -0
  46. package/_ats/dialogs/index.js +1 -0
  47. package/_ats/index.d.ts +8 -0
  48. package/_ats/index.js +8 -0
  49. package/_entity/app-config/ModuleFE_AppConfig.d.ts +24 -0
  50. package/_entity/app-config/ModuleFE_AppConfig.js +52 -0
  51. package/_entity/app-config/index.d.ts +2 -0
  52. package/_entity/app-config/index.js +2 -0
  53. package/_entity/app-config/module-pack.d.ts +1 -0
  54. package/_entity/app-config/module-pack.js +2 -0
  55. package/_entity/editable-test/ModuleFE_EditableTest.d.ts +11 -0
  56. package/_entity/editable-test/ModuleFE_EditableTest.js +12 -0
  57. package/_entity/editable-test/index.d.ts +2 -0
  58. package/_entity/editable-test/index.js +2 -0
  59. package/_entity/editable-test/module-pack.d.ts +1 -0
  60. package/_entity/editable-test/module-pack.js +2 -0
  61. package/_entity/editable-test/ui-components.d.ts +37 -0
  62. package/_entity/editable-test/ui-components.js +21 -0
  63. package/_entity.d.ts +2 -0
  64. package/_entity.js +2 -0
  65. package/_to-refactor/MenuAndButton.d.ts +1 -0
  66. package/_to-refactor/MenuAndButton.js +87 -0
  67. package/behavior-functions/index.d.ts +1 -0
  68. package/behavior-functions/index.js +1 -0
  69. package/behavior-functions/scroll-into-view.d.ts +6 -0
  70. package/behavior-functions/scroll-into-view.js +55 -0
  71. package/component-modules/ModuleFE_Dialog.d.ts +27 -0
  72. package/component-modules/ModuleFE_Dialog.js +48 -0
  73. package/component-modules/ModuleFE_Notifications.d.ts +45 -0
  74. package/component-modules/ModuleFE_Notifications.js +133 -0
  75. package/component-modules/ModuleFE_Toaster.d.ts +28 -0
  76. package/component-modules/ModuleFE_Toaster.js +97 -0
  77. package/component-modules/mouse-interactivity/ModuleFE_MouseInteractivity.d.ts +9 -0
  78. package/component-modules/mouse-interactivity/ModuleFE_MouseInteractivity.js +35 -0
  79. package/component-modules/mouse-interactivity/helper-functions.d.ts +108 -0
  80. package/component-modules/mouse-interactivity/helper-functions.js +339 -0
  81. package/component-modules/mouse-interactivity/index.d.ts +3 -0
  82. package/component-modules/mouse-interactivity/index.js +3 -0
  83. package/component-modules/mouse-interactivity/types.d.ts +37 -0
  84. package/component-modules/mouse-interactivity/types.js +2 -0
  85. package/components/ActionButton.d.ts +7 -0
  86. package/components/ActionButton.js +29 -0
  87. package/components/AwaitModules/AwaitModules.d.ts +40 -0
  88. package/components/AwaitModules/AwaitModules.js +95 -0
  89. package/components/AwaitModules/AwaitModules.scss +53 -0
  90. package/components/AwaitSync/AwaitSync.d.ts +18 -0
  91. package/components/AwaitSync/AwaitSync.js +25 -0
  92. package/components/AwaitSync/AwaitSync.scss +13 -0
  93. package/components/Button/ATS_Button.d.ts +21 -0
  94. package/components/Button/ATS_Button.js +66 -0
  95. package/components/Button/ATS_Button.scss +19 -0
  96. package/components/Button/Button.d.ts +40 -0
  97. package/components/Button/Button.js +94 -0
  98. package/components/Button/Button.scss +151 -0
  99. package/components/FrameLayout/FrameLayout.d.ts +7 -0
  100. package/components/FrameLayout/FrameLayout.js +10 -0
  101. package/components/FrameLayout/FrameLayout.scss +5 -0
  102. package/components/FrameLayout/index.d.ts +1 -0
  103. package/components/FrameLayout/index.js +1 -0
  104. package/components/GenericDropDown/GenericDropDownV3.d.ts +108 -0
  105. package/components/GenericDropDown/GenericDropDownV3.js +98 -0
  106. package/components/GenericDropDown/index.d.ts +1 -0
  107. package/components/GenericDropDown/index.js +1 -0
  108. package/components/GenericRenderer/Component_GenericRenderer.d.ts +15 -0
  109. package/components/GenericRenderer/Component_GenericRenderer.js +13 -0
  110. package/components/HeightBounder.d.ts +11 -0
  111. package/components/HeightBounder.js +25 -0
  112. package/components/Label/ATS_Label.d.ts +12 -0
  113. package/components/Label/ATS_Label.js +34 -0
  114. package/components/Label/ATS_Label.scss +24 -0
  115. package/components/Label/Label.d.ts +30 -0
  116. package/components/Label/Label.js +84 -0
  117. package/components/Label/Label.scss +89 -0
  118. package/components/Layouts/Layouts.d.ts +38 -0
  119. package/components/Layouts/Layouts.js +56 -0
  120. package/components/Layouts/_Layouts.scss +53 -0
  121. package/components/Layouts/_Layouts_.scss +69 -0
  122. package/components/Layouts/index.d.ts +1 -0
  123. package/components/Layouts/index.js +21 -0
  124. package/components/Page_ItemsEditor/Page_ItemsEditor.d.ts +66 -0
  125. package/components/Page_ItemsEditor/Page_ItemsEditor.js +134 -0
  126. package/components/Page_ItemsEditor/Page_ItemsEditor.scss +104 -0
  127. package/components/Page_ItemsEditor/defaults/ItemEditor_DefaultFilter/ItemEditor_DefaultFilter.d.ts +16 -0
  128. package/components/Page_ItemsEditor/defaults/ItemEditor_DefaultFilter/ItemEditor_DefaultFilter.js +15 -0
  129. package/components/Page_ItemsEditor/defaults/ItemEditor_DefaultFilter/ItemEditor_DefaultFilter.scss +4 -0
  130. package/components/Page_ItemsEditor/defaults/ItemEditor_DefaultFilter/index.d.ts +1 -0
  131. package/components/Page_ItemsEditor/defaults/ItemEditor_DefaultFilter/index.js +1 -0
  132. package/components/Page_ItemsEditor/defaults/ItemEditor_ListRenderer/ItemEditor_DefaultList.d.ts +26 -0
  133. package/components/Page_ItemsEditor/defaults/ItemEditor_ListRenderer/ItemEditor_DefaultList.js +68 -0
  134. package/components/Page_ItemsEditor/defaults/ItemEditor_ListRenderer/ItemEditor_DefaultList.scss +4 -0
  135. package/components/Page_ItemsEditor/defaults/ItemEditor_ListRenderer/index.d.ts +1 -0
  136. package/components/Page_ItemsEditor/defaults/ItemEditor_ListRenderer/index.js +1 -0
  137. package/components/Page_ItemsEditor/index.d.ts +1 -0
  138. package/components/Page_ItemsEditor/index.js +1 -0
  139. package/components/Page_ItemsEditor/types.d.ts +4 -0
  140. package/components/Page_ItemsEditor/types.js +1 -0
  141. package/components/RelativeLayout/RelativeLayout.d.ts +7 -0
  142. package/components/RelativeLayout/RelativeLayout.js +10 -0
  143. package/components/RelativeLayout/RelativeLayout.scss +3 -0
  144. package/components/RelativeLayout/index.d.ts +1 -0
  145. package/components/RelativeLayout/index.js +1 -0
  146. package/components/Show.d.ts +20 -0
  147. package/components/Show.js +30 -0
  148. package/components/TS_AppTools/TS_AppTools.d.ts +30 -0
  149. package/components/TS_AppTools/TS_AppTools.js +144 -0
  150. package/components/TS_AppTools/TS_AppTools.scss +193 -0
  151. package/components/TS_AppTools/TS_AppTools_Default.d.ts +7 -0
  152. package/components/TS_AppTools/TS_AppTools_Default.js +16 -0
  153. package/components/TS_AppTools/index.d.ts +2 -0
  154. package/components/TS_AppTools/index.js +22 -0
  155. package/components/TS_AppTools/types.d.ts +19 -0
  156. package/components/TS_AppTools/types.js +6 -0
  157. package/components/TS_ButtonGroup/TS_ButtonGroup.d.ts +12 -0
  158. package/components/TS_ButtonGroup/TS_ButtonGroup.js +94 -0
  159. package/components/TS_ButtonGroup/TS_ButtonGroup.scss +58 -0
  160. package/components/TS_ButtonGroup/index.d.ts +2 -0
  161. package/components/TS_ButtonGroup/index.js +2 -0
  162. package/components/TS_ButtonGroup/types.d.ts +38 -0
  163. package/components/TS_ButtonGroup/types.js +1 -0
  164. package/components/TS_ButtonLoader/TS_ButtonLoader.d.ts +5 -0
  165. package/components/TS_ButtonLoader/TS_ButtonLoader.js +8 -0
  166. package/components/TS_ButtonLoader/TS_ButtonLoader.scss +63 -0
  167. package/components/TS_ButtonLoader/index.d.ts +1 -0
  168. package/components/TS_ButtonLoader/index.js +1 -0
  169. package/components/TS_Card/TS_Card.d.ts +7 -0
  170. package/components/TS_Card/TS_Card.js +14 -0
  171. package/components/TS_Card/TS_Card.scss +7 -0
  172. package/components/TS_Card/index.d.ts +1 -0
  173. package/components/TS_Card/index.js +1 -0
  174. package/components/TS_Checkbox/ATS_CheckboxV2.d.ts +3 -0
  175. package/components/TS_Checkbox/ATS_CheckboxV2.js +30 -0
  176. package/components/TS_Checkbox/ATS_CheckboxV2.scss +4 -0
  177. package/components/TS_Checkbox/TS_Checkbox.d.ts +48 -0
  178. package/components/TS_Checkbox/TS_Checkbox.js +46 -0
  179. package/components/TS_Checkbox/TS_Checkbox.scss +62 -0
  180. package/components/TS_Checkbox/TS_CheckboxV2.d.ts +37 -0
  181. package/components/TS_Checkbox/TS_CheckboxV2.js +53 -0
  182. package/components/TS_Checkbox/TS_CheckboxV2.scss +97 -0
  183. package/components/TS_Checkbox/index.d.ts +1 -0
  184. package/components/TS_Checkbox/index.js +21 -0
  185. package/components/TS_CheckboxGroup/ATS_CheckboxGroup.d.ts +19 -0
  186. package/components/TS_CheckboxGroup/ATS_CheckboxGroup.js +89 -0
  187. package/components/TS_CheckboxGroup/ATS_CheckboxGroup.scss +6 -0
  188. package/components/TS_CheckboxGroup/TS_CheckboxGroup.d.ts +35 -0
  189. package/components/TS_CheckboxGroup/TS_CheckboxGroup.js +47 -0
  190. package/components/TS_CheckboxGroup/TS_CheckboxGroup.scss +32 -0
  191. package/components/TS_CheckboxGroup/index.d.ts +1 -0
  192. package/components/TS_CheckboxGroup/index.js +1 -0
  193. package/components/TS_CollapsableContainer/TS_CollapsableContainer.d.ts +44 -0
  194. package/components/TS_CollapsableContainer/TS_CollapsableContainer.js +80 -0
  195. package/components/TS_CollapsableContainer/TS_CollapsableContainer.scss +47 -0
  196. package/components/TS_CollapsableContainer/index.d.ts +1 -0
  197. package/components/TS_CollapsableContainer/index.js +1 -0
  198. package/components/TS_CollapsableContainerV2/TS_CollapsableContainerV2.d.ts +36 -0
  199. package/components/TS_CollapsableContainerV2/TS_CollapsableContainerV2.js +46 -0
  200. package/components/TS_CollapsableContainerV2/TS_CollapsableContainerV2.scss +66 -0
  201. package/components/TS_CollapsableContainerV2/ats.d.ts +3 -0
  202. package/components/TS_CollapsableContainerV2/ats.js +39 -0
  203. package/components/TS_CollapsableContainerV2/ats.scss +35 -0
  204. package/components/TS_CollapsableContainerV2/index.d.ts +2 -0
  205. package/components/TS_CollapsableContainerV2/index.js +2 -0
  206. package/components/TS_ComponentTransition/TS_ComponentTransition.d.ts +25 -0
  207. package/components/TS_ComponentTransition/TS_ComponentTransition.js +65 -0
  208. package/components/TS_ComponentTransition/index.d.ts +1 -0
  209. package/components/TS_ComponentTransition/index.js +1 -0
  210. package/components/TS_CopyToClipboard/TS_CopyToClipboard.d.ts +4 -0
  211. package/components/TS_CopyToClipboard/TS_CopyToClipboard.js +11 -0
  212. package/components/TS_CopyToClipboard/index.d.ts +1 -0
  213. package/components/TS_CopyToClipboard/index.js +21 -0
  214. package/components/TS_Dialog/TS_Dialog.d.ts +89 -0
  215. package/components/TS_Dialog/TS_Dialog.js +140 -0
  216. package/components/TS_Dialog/TS_Dialog.scss +116 -0
  217. package/components/TS_Dialog/TS_DialogOverlay.d.ts +15 -0
  218. package/components/TS_Dialog/TS_DialogOverlay.js +48 -0
  219. package/components/TS_Dialog/TS_DialogOverlay.scss +41 -0
  220. package/components/TS_Dialog/TS_SimpleDialog.d.ts +21 -0
  221. package/components/TS_Dialog/TS_SimpleDialog.js +37 -0
  222. package/components/TS_Dialog/TS_SimpleDialog.scss +5 -0
  223. package/components/TS_Dialog/TS_SimpleDialogue.d.ts +28 -0
  224. package/components/TS_Dialog/TS_SimpleDialogue.js +38 -0
  225. package/components/TS_Dialog/index.d.ts +2 -0
  226. package/components/TS_Dialog/index.js +22 -0
  227. package/components/TS_DragAndDrop/TS_DragAndDrop.d.ts +48 -0
  228. package/components/TS_DragAndDrop/TS_DragAndDrop.js +105 -0
  229. package/components/TS_DragAndDrop/TS_DragAndDrop.scss +61 -0
  230. package/components/TS_DragAndDrop/index.d.ts +1 -0
  231. package/components/TS_DragAndDrop/index.js +21 -0
  232. package/components/TS_Dropdown/TS_DropDown.d.ts +120 -0
  233. package/components/TS_Dropdown/TS_DropDown.js +332 -0
  234. package/components/TS_Dropdown/TS_DropDown.scss +134 -0
  235. package/components/TS_Dropdown/index.d.ts +1 -0
  236. package/components/TS_Dropdown/index.js +21 -0
  237. package/components/TS_EditableContent/TS_EditableContent.d.ts +19 -0
  238. package/components/TS_EditableContent/TS_EditableContent.js +32 -0
  239. package/components/TS_EditableContent/types.d.ts +4 -0
  240. package/components/TS_EditableContent/types.js +1 -0
  241. package/components/TS_EditableItemComponent/TS_EditableItemComponent.d.ts +23 -0
  242. package/components/TS_EditableItemComponent/TS_EditableItemComponent.js +47 -0
  243. package/components/TS_EditableItemController/TS_EditableItemController.d.ts +36 -0
  244. package/components/TS_EditableItemController/TS_EditableItemController.js +54 -0
  245. package/components/TS_EditableItemController/TS_EditableItemController.scss +3 -0
  246. package/components/TS_EditableItemController/index.d.ts +1 -0
  247. package/components/TS_EditableItemController/index.js +1 -0
  248. package/components/TS_EditableItemControllerProto/TS_EditableItemControllerProto.d.ts +32 -0
  249. package/components/TS_EditableItemControllerProto/TS_EditableItemControllerProto.js +53 -0
  250. package/components/TS_EditableItemControllerProto/TS_EditableItemControllerProto.scss +3 -0
  251. package/components/TS_EditableItemControllerProto/index.d.ts +1 -0
  252. package/components/TS_EditableItemControllerProto/index.js +1 -0
  253. package/components/TS_EditableItemStatus/TS_EditableItemStatus.d.ts +20 -0
  254. package/components/TS_EditableItemStatus/TS_EditableItemStatus.js +34 -0
  255. package/components/TS_EditableText/TS_EditableText.d.ts +57 -0
  256. package/components/TS_EditableText/TS_EditableText.js +100 -0
  257. package/components/TS_EditableText/TS_EditableText.scss +90 -0
  258. package/components/TS_EditableText/index.d.ts +1 -0
  259. package/components/TS_EditableText/index.js +1 -0
  260. package/components/TS_ErrorBoundary/TS_ErrorBoundary.d.ts +54 -0
  261. package/components/TS_ErrorBoundary/TS_ErrorBoundary.js +103 -0
  262. package/components/TS_ErrorBoundary/TS_ErrorBoundary.scss +95 -0
  263. package/components/TS_ErrorBoundary/index.d.ts +1 -0
  264. package/components/TS_ErrorBoundary/index.js +21 -0
  265. package/components/TS_Form/TS_Form.d.ts +9 -0
  266. package/components/TS_Form/TS_Form.js +11 -0
  267. package/components/TS_Form/TS_Form.scss +0 -0
  268. package/components/TS_Form/consts.d.ts +1 -0
  269. package/components/TS_Form/consts.js +1 -0
  270. package/components/TS_Form/index.d.ts +3 -0
  271. package/components/TS_Form/index.js +3 -0
  272. package/components/TS_Form/types.d.ts +13 -0
  273. package/components/TS_Form/types.js +1 -0
  274. package/components/TS_GridTableProto/TS_GridTableProto.d.ts +18 -0
  275. package/components/TS_GridTableProto/TS_GridTableProto.js +22 -0
  276. package/components/TS_GridTableProto/TS_GridTableProto.scss +4 -0
  277. package/components/TS_GridTableProto/index.d.ts +1 -0
  278. package/components/TS_GridTableProto/index.js +1 -0
  279. package/components/TS_Input/ATS_TextArea.d.ts +14 -0
  280. package/components/TS_Input/ATS_TextArea.js +24 -0
  281. package/components/TS_Input/ATS_TextArea.scss +24 -0
  282. package/components/TS_Input/TS_BaseInput.d.ts +44 -0
  283. package/components/TS_Input/TS_BaseInput.js +47 -0
  284. package/components/TS_Input/TS_Input.d.ts +24 -0
  285. package/components/TS_Input/TS_Input.js +53 -0
  286. package/components/TS_Input/TS_Input.scss +64 -0
  287. package/components/TS_Input/TS_TextArea.d.ts +14 -0
  288. package/components/TS_Input/TS_TextArea.js +72 -0
  289. package/components/TS_Input/TS_TextArea.scss +41 -0
  290. package/components/TS_Input/index.d.ts +4 -0
  291. package/components/TS_Input/index.js +25 -0
  292. package/components/TS_JSONViewer/TS_JSONViewer.d.ts +18 -0
  293. package/components/TS_JSONViewer/TS_JSONViewer.js +64 -0
  294. package/components/TS_JSONViewer/TS_JSONViewer.scss +87 -0
  295. package/components/TS_JSONViewer/types.d.ts +10 -0
  296. package/components/TS_JSONViewer/types.js +1 -0
  297. package/components/TS_Link/TS_Link.d.ts +15 -0
  298. package/components/TS_Link/TS_Link.js +36 -0
  299. package/components/TS_Link/TS_Link.scss +32 -0
  300. package/components/TS_Link/index.d.ts +1 -0
  301. package/components/TS_Link/index.js +21 -0
  302. package/components/TS_ListOrganizer/TS_ListOrganizer.d.ts +33 -0
  303. package/components/TS_ListOrganizer/TS_ListOrganizer.js +64 -0
  304. package/components/TS_ListOrganizer/TS_ListOrganizer.scss +37 -0
  305. package/components/TS_ListOrganizer/index.d.ts +1 -0
  306. package/components/TS_ListOrganizer/index.js +21 -0
  307. package/components/TS_Loader/TS_Loader.d.ts +6 -0
  308. package/components/TS_Loader/TS_Loader.js +9 -0
  309. package/components/TS_Loader/TS_Loader.scss +71 -0
  310. package/components/TS_Loader/index.d.ts +1 -0
  311. package/components/TS_Loader/index.js +1 -0
  312. package/components/TS_MemoryMonitor/TS_MemoryMonitor.d.ts +10 -0
  313. package/components/TS_MemoryMonitor/TS_MemoryMonitor.js +48 -0
  314. package/components/TS_MemoryMonitor/TS_MemoryMonitor.scss +31 -0
  315. package/components/TS_MemoryMonitor/index.d.ts +1 -0
  316. package/components/TS_MemoryMonitor/index.js +21 -0
  317. package/components/TS_MouseInteractivity/TS_PopUp/TS_PopUp.d.ts +9 -0
  318. package/components/TS_MouseInteractivity/TS_PopUp/TS_PopUp.js +28 -0
  319. package/components/TS_MouseInteractivity/TS_PopUp/TS_PopUp.scss +53 -0
  320. package/components/TS_MouseInteractivity/TS_Tooltip/TS_ToolTip.d.ts +12 -0
  321. package/components/TS_MouseInteractivity/TS_Tooltip/TS_ToolTip.js +65 -0
  322. package/components/TS_MouseInteractivity/TS_Tooltip/TS_ToolTip.scss +46 -0
  323. package/components/TS_MouseInteractivity/base/TS_MouseInteractivity.d.ts +18 -0
  324. package/components/TS_MouseInteractivity/base/TS_MouseInteractivity.js +100 -0
  325. package/components/TS_MouseInteractivity/index.d.ts +2 -0
  326. package/components/TS_MouseInteractivity/index.js +22 -0
  327. package/components/TS_MultiSelect/TS_MultiSelect.scss +34 -0
  328. package/components/TS_MultiSelect/TS_MultiSelect_V2.d.ts +36 -0
  329. package/components/TS_MultiSelect/TS_MultiSelect_V2.js +41 -0
  330. package/components/TS_MultiSelect/index.d.ts +1 -0
  331. package/components/TS_MultiSelect/index.js +21 -0
  332. package/components/TS_Notifications/TS_Notifications.d.ts +22 -0
  333. package/components/TS_Notifications/TS_Notifications.js +96 -0
  334. package/components/TS_Notifications/TS_Notifications.scss +120 -0
  335. package/components/TS_Notifications/genericNotificationAction.d.ts +8 -0
  336. package/components/TS_Notifications/genericNotificationAction.js +16 -0
  337. package/components/TS_Notifications/index.d.ts +2 -0
  338. package/components/TS_Notifications/index.js +2 -0
  339. package/components/TS_Overlay/TS_Overlay.d.ts +12 -0
  340. package/components/TS_Overlay/TS_Overlay.js +32 -0
  341. package/components/TS_Overlay/TS_Overlay.scss +41 -0
  342. package/components/TS_Overlay/index.d.ts +1 -0
  343. package/components/TS_Overlay/index.js +21 -0
  344. package/components/TS_Printable/TS_Printable.d.ts +13 -0
  345. package/components/TS_Printable/TS_Printable.js +20 -0
  346. package/components/TS_Printable/TS_Printable.scss +47 -0
  347. package/components/TS_Printable/index.d.ts +1 -0
  348. package/components/TS_Printable/index.js +21 -0
  349. package/components/TS_ProgressBar/TS_ProgressBar.d.ts +22 -0
  350. package/components/TS_ProgressBar/TS_ProgressBar.js +47 -0
  351. package/components/TS_ProgressBar/TS_ProgressBar.scss +79 -0
  352. package/components/TS_ProgressBar/index.d.ts +1 -0
  353. package/components/TS_ProgressBar/index.js +1 -0
  354. package/components/TS_PropRenderer/TS_PropRenderer.d.ts +18 -0
  355. package/components/TS_PropRenderer/TS_PropRenderer.js +36 -0
  356. package/components/TS_PropRenderer/TS_PropRenderer.scss +19 -0
  357. package/components/TS_PropRenderer/index.d.ts +1 -0
  358. package/components/TS_PropRenderer/index.js +1 -0
  359. package/components/TS_Radio/TS_Radio.d.ts +34 -0
  360. package/components/TS_Radio/TS_Radio.js +49 -0
  361. package/components/TS_Radio/TS_Radio.scss +68 -0
  362. package/components/TS_Radio/index.d.ts +1 -0
  363. package/components/TS_Radio/index.js +1 -0
  364. package/components/TS_ReadMore/TS_ReadMore.d.ts +26 -0
  365. package/components/TS_ReadMore/TS_ReadMore.js +86 -0
  366. package/components/TS_ReadMore/TS_ReadMore.scss +36 -0
  367. package/components/TS_ReadMore/index.d.ts +1 -0
  368. package/components/TS_ReadMore/index.js +1 -0
  369. package/components/TS_Slider/TS_Slider.d.ts +26 -0
  370. package/components/TS_Slider/TS_Slider.js +42 -0
  371. package/components/TS_Slider/TS_Slider.scss +68 -0
  372. package/components/TS_Slider/index.d.ts +1 -0
  373. package/components/TS_Slider/index.js +1 -0
  374. package/components/TS_Space/TS_Space.d.ts +8 -0
  375. package/components/TS_Space/TS_Space.js +8 -0
  376. package/components/TS_Space/index.d.ts +1 -0
  377. package/components/TS_Space/index.js +1 -0
  378. package/components/TS_Space/ts-space.scss +3 -0
  379. package/components/TS_Table/TS_Table.d.ts +42 -0
  380. package/components/TS_Table/TS_Table.js +74 -0
  381. package/components/TS_Table/TS_Table.scss +51 -0
  382. package/components/TS_Table/index.d.ts +1 -0
  383. package/components/TS_Table/index.js +21 -0
  384. package/components/TS_Tabs/TS_Tabs.d.ts +55 -0
  385. package/components/TS_Tabs/TS_Tabs.js +102 -0
  386. package/components/TS_Tabs/TS_Tabs.scss +103 -0
  387. package/components/TS_Tabs/index.d.ts +1 -0
  388. package/components/TS_Tabs/index.js +21 -0
  389. package/components/TS_Toaster/TS_Toast.d.ts +5 -0
  390. package/components/TS_Toaster/TS_Toast.js +9 -0
  391. package/components/TS_Toaster/TS_Toast.scss +80 -0
  392. package/components/TS_Toaster/TS_ToastOverlay.d.ts +16 -0
  393. package/components/TS_Toaster/TS_ToastOverlay.js +26 -0
  394. package/components/TS_Toaster/TS_ToastOverlay.scss +33 -0
  395. package/components/TS_Toaster/index.d.ts +2 -0
  396. package/components/TS_Toaster/index.js +22 -0
  397. package/components/TS_Toggle/ATS_Toggle.d.ts +11 -0
  398. package/components/TS_Toggle/ATS_Toggle.js +18 -0
  399. package/components/TS_Toggle/TS_Toggle.d.ts +21 -0
  400. package/components/TS_Toggle/TS_Toggle.js +26 -0
  401. package/components/TS_Toggle/TS_Toggle.scss +56 -0
  402. package/components/TS_Toggle/index.d.ts +2 -0
  403. package/components/TS_Toggle/index.js +2 -0
  404. package/components/TS_Toggler/TS_Toggler.d.ts +23 -0
  405. package/components/TS_Toggler/TS_Toggler.js +50 -0
  406. package/components/TS_Toggler/TS_Toggler.scss +83 -0
  407. package/components/TS_Toggler/index.d.ts +1 -0
  408. package/components/TS_Toggler/index.js +1 -0
  409. package/components/TS_Tree/SimpleTreeNodeRenderer.d.ts +9 -0
  410. package/components/TS_Tree/SimpleTreeNodeRenderer.js +53 -0
  411. package/components/TS_Tree/TS_Tree.d.ts +68 -0
  412. package/components/TS_Tree/TS_Tree.js +174 -0
  413. package/components/TS_Tree/TS_Tree.scss +44 -0
  414. package/components/TS_Tree/index.d.ts +3 -0
  415. package/components/TS_Tree/index.js +23 -0
  416. package/components/TS_Tree/types.d.ts +4 -0
  417. package/components/TS_Tree/types.js +21 -0
  418. package/components/TS_V2_Input/TS_InputV2.d.ts +93 -0
  419. package/components/TS_V2_Input/TS_InputV2.js +220 -0
  420. package/components/TS_V2_Input/index.d.ts +1 -0
  421. package/components/TS_V2_Input/index.js +21 -0
  422. package/components/TS_V2_TextArea/TS_BaseInput.d.ts +42 -0
  423. package/components/TS_V2_TextArea/TS_BaseInput.js +46 -0
  424. package/components/TS_V2_TextArea/TS_TextAreaV2.d.ts +78 -0
  425. package/components/TS_V2_TextArea/TS_TextAreaV2.js +178 -0
  426. package/components/TS_V2_TextArea/TS_TextAreaV2.scss +49 -0
  427. package/components/TS_V2_TextArea/index.d.ts +2 -0
  428. package/components/TS_V2_TextArea/index.js +22 -0
  429. package/components/TS_VirtualizedList/TS_VirtualizedList.d.ts +14 -0
  430. package/components/TS_VirtualizedList/TS_VirtualizedList.js +22 -0
  431. package/components/TS_VirtualizedList/index.d.ts +1 -0
  432. package/components/TS_VirtualizedList/index.js +1 -0
  433. package/components/Video/Video.d.ts +16 -0
  434. package/components/Video/Video.js +40 -0
  435. package/components/Video/VideoDialog.d.ts +20 -0
  436. package/components/Video/VideoDialog.js +44 -0
  437. package/components/Video/VideoDialog.scss +31 -0
  438. package/components/Video/types.d.ts +20 -0
  439. package/components/Video/types.js +1 -0
  440. package/components/_TS_MultiSelect/DBItemDropDownMultiSelector.d.ts +57 -0
  441. package/components/_TS_MultiSelect/DBItemDropDownMultiSelector.js +63 -0
  442. package/components/adapter/Adapter.d.ts +139 -0
  443. package/components/adapter/Adapter.js +259 -0
  444. package/components/adapter/BaseRenderer.d.ts +24 -0
  445. package/components/adapter/BaseRenderer.js +31 -0
  446. package/components/ats-group.d.ts +2 -0
  447. package/components/ats-group.js +14 -0
  448. package/components/form/Form.d.ts +24 -0
  449. package/components/form/Form.js +34 -0
  450. package/components/form/types.d.ts +23 -0
  451. package/components/form/types.js +21 -0
  452. package/components/formv3/FormV3.d.ts +25 -0
  453. package/components/formv3/FormV3.js +23 -0
  454. package/components/formv3/types.d.ts +29 -0
  455. package/components/formv3/types.js +1 -0
  456. package/components/treeicons.d.ts +10 -0
  457. package/components/treeicons.js +3 -0
  458. package/components/types.d.ts +23 -0
  459. package/components/types.js +22 -0
  460. package/components/utils.d.ts +1 -0
  461. package/components/utils.js +7 -0
  462. package/consts.d.ts +2 -0
  463. package/consts.js +2 -0
  464. package/core/AppPage.d.ts +11 -0
  465. package/core/AppPage.js +52 -0
  466. package/core/AppPageV2.d.ts +9 -0
  467. package/core/AppPageV2.js +53 -0
  468. package/core/AppWrapper.d.ts +4 -0
  469. package/core/AppWrapper.js +34 -0
  470. package/core/ComponentAsync.d.ts +16 -0
  471. package/core/ComponentAsync.js +64 -0
  472. package/core/ComponentBase.d.ts +28 -0
  473. package/core/ComponentBase.js +152 -0
  474. package/core/ComponentSync.d.ts +13 -0
  475. package/core/ComponentSync.js +49 -0
  476. package/core/Controller.d.ts +13 -0
  477. package/core/Controller.js +28 -0
  478. package/core/IndexedDB.d.ts +42 -0
  479. package/core/IndexedDB.js +259 -0
  480. package/core/IndexedDBV3.d.ts +43 -0
  481. package/core/IndexedDBV3.js +259 -0
  482. package/core/IndexedDBV4/IndexedDB_Database.d.ts +20 -0
  483. package/core/IndexedDBV4/IndexedDB_Database.js +268 -0
  484. package/core/IndexedDBV4/IndexedDB_Store.d.ts +34 -0
  485. package/core/IndexedDBV4/IndexedDB_Store.js +207 -0
  486. package/core/IndexedDBV4/ModuleFE_IDBManager.d.ts +11 -0
  487. package/core/IndexedDBV4/ModuleFE_IDBManager.js +19 -0
  488. package/core/IndexedDBV4/types.d.ts +16 -0
  489. package/core/IndexedDBV4/types.js +1 -0
  490. package/core/SimpleScriptInjector.d.ts +13 -0
  491. package/core/SimpleScriptInjector.js +42 -0
  492. package/core/Thunder.d.ts +37 -0
  493. package/core/Thunder.js +139 -0
  494. package/core/ThunderstormDefaultApp.d.ts +12 -0
  495. package/core/ThunderstormDefaultApp.js +29 -0
  496. package/core/consts.d.ts +6 -0
  497. package/core/consts.js +2 -0
  498. package/core/db-api-gen/consts.d.ts +22 -0
  499. package/core/db-api-gen/consts.js +25 -0
  500. package/core/db-api-gen/db-def.d.ts +9 -0
  501. package/core/db-api-gen/db-def.js +16 -0
  502. package/core/db-api-gen/types.d.ts +23 -0
  503. package/core/db-api-gen/types.js +3 -0
  504. package/core/proto-component/ProtoComponent.d.ts +57 -0
  505. package/core/proto-component/ProtoComponent.js +73 -0
  506. package/core/proto-component/UrlState.d.ts +42 -0
  507. package/core/proto-component/UrlState.js +59 -0
  508. package/core/proto-component/index.d.ts +2 -0
  509. package/core/proto-component/index.js +2 -0
  510. package/core/proto-component/types.d.ts +25 -0
  511. package/core/proto-component/types.js +15 -0
  512. package/core/thunder-dispatcher.d.ts +13 -0
  513. package/core/thunder-dispatcher.js +69 -0
  514. package/core/thunder-helpers.d.ts +7 -0
  515. package/core/thunder-helpers.js +171 -0
  516. package/core/thunder-modulepack.d.ts +3 -0
  517. package/core/thunder-modulepack.js +34 -0
  518. package/core/typed-api.d.ts +6 -0
  519. package/core/typed-api.js +41 -0
  520. package/core/types.d.ts +6 -0
  521. package/core/types.js +1 -0
  522. package/editable-item.d.ts +7 -0
  523. package/editable-item.js +7 -0
  524. package/index.d.ts +112 -0
  525. package/index.js +134 -0
  526. package/modules/ModuleFE_BaseTheme.d.ts +18 -0
  527. package/modules/ModuleFE_BaseTheme.js +27 -0
  528. package/modules/ModuleFE_BroadcastChannel/ModuleFE_BroadcastChannel.d.ts +20 -0
  529. package/modules/ModuleFE_BroadcastChannel/ModuleFE_BroadcastChannel.js +66 -0
  530. package/modules/ModuleFE_BrowserHistory.d.ts +46 -0
  531. package/modules/ModuleFE_BrowserHistory.js +165 -0
  532. package/modules/ModuleFE_BrowserHistoryV2.d.ts +43 -0
  533. package/modules/ModuleFE_BrowserHistoryV2.js +113 -0
  534. package/modules/ModuleFE_CSVParser.d.ts +12 -0
  535. package/modules/ModuleFE_CSVParser.js +52 -0
  536. package/modules/ModuleFE_CollectionActions.d.ts +10 -0
  537. package/modules/ModuleFE_CollectionActions.js +18 -0
  538. package/modules/ModuleFE_ConnectivityModule.d.ts +15 -0
  539. package/modules/ModuleFE_ConnectivityModule.js +31 -0
  540. package/modules/ModuleFE_ForceUpgrade.d.ts +20 -0
  541. package/modules/ModuleFE_ForceUpgrade.js +54 -0
  542. package/modules/ModuleFE_LocalStorage.d.ts +46 -0
  543. package/modules/ModuleFE_LocalStorage.js +179 -0
  544. package/modules/ModuleFE_Locale.d.ts +44 -0
  545. package/modules/ModuleFE_Locale.js +83 -0
  546. package/modules/ModuleFE_Print.d.ts +16 -0
  547. package/modules/ModuleFE_Print.js +116 -0
  548. package/modules/ModuleFE_StorageCleaner.d.ts +17 -0
  549. package/modules/ModuleFE_StorageCleaner.js +90 -0
  550. package/modules/ModuleFE_Thunderstorm.d.ts +31 -0
  551. package/modules/ModuleFE_Thunderstorm.js +122 -0
  552. package/modules/ModuleFE_Utils/ModuleFE_Utils.d.ts +29 -0
  553. package/modules/ModuleFE_Utils/ModuleFE_Utils.js +43 -0
  554. package/modules/ModuleFE_Window.d.ts +19 -0
  555. package/modules/ModuleFE_Window.js +42 -0
  556. package/modules/ModuleFE_WindowMessenger.d.ts +62 -0
  557. package/modules/ModuleFE_WindowMessenger.js +128 -0
  558. package/modules/action-processor/ModuleFE_ActionProcessor.d.ts +9 -0
  559. package/modules/action-processor/ModuleFE_ActionProcessor.js +14 -0
  560. package/modules/archiving/ModuleFE_Archiving.d.ts +8 -0
  561. package/modules/archiving/ModuleFE_Archiving.js +15 -0
  562. package/modules/clearWebsiteDataDispatcher.d.ts +5 -0
  563. package/modules/clearWebsiteDataDispatcher.js +2 -0
  564. package/modules/component-loader/ReactEntryComponentInjector.d.ts +23 -0
  565. package/modules/component-loader/ReactEntryComponentInjector.js +59 -0
  566. package/modules/component-loader/entry-component-loading-module.d.ts +7 -0
  567. package/modules/component-loader/entry-component-loading-module.js +52 -0
  568. package/modules/component-loader/index.d.ts +2 -0
  569. package/modules/component-loader/index.js +2 -0
  570. package/modules/db-api-gen/ModuleFE_BaseApi.d.ts +45 -0
  571. package/modules/db-api-gen/ModuleFE_BaseApi.js +152 -0
  572. package/modules/db-api-gen/ModuleFE_BaseDB.d.ts +146 -0
  573. package/modules/db-api-gen/ModuleFE_BaseDB.js +433 -0
  574. package/modules/db-api-gen/types.d.ts +13 -0
  575. package/modules/db-api-gen/types.js +6 -0
  576. package/modules/http/ModuleFE_XHR.d.ts +20 -0
  577. package/modules/http/ModuleFE_XHR.js +175 -0
  578. package/modules/routing/LocationChangeListener.d.ts +6 -0
  579. package/modules/routing/LocationChangeListener.js +15 -0
  580. package/modules/routing/ModuleFE_Routing.d.ts +30 -0
  581. package/modules/routing/ModuleFE_Routing.js +122 -0
  582. package/modules/routing/ModuleFE_RoutingV2.d.ts +25 -0
  583. package/modules/routing/ModuleFE_RoutingV2.js +143 -0
  584. package/modules/routing/index.d.ts +5 -0
  585. package/modules/routing/index.js +5 -0
  586. package/modules/routing/route.d.ts +22 -0
  587. package/modules/routing/route.js +83 -0
  588. package/modules/routing/types.d.ts +20 -0
  589. package/modules/routing/types.js +1 -0
  590. package/modules/sync-env/ModuleFE_SyncEnvV2.d.ts +8 -0
  591. package/modules/sync-env/ModuleFE_SyncEnvV2.js +18 -0
  592. package/modules/sync-manager/ModuleFE_SyncManager.d.ts +59 -0
  593. package/modules/sync-manager/ModuleFE_SyncManager.js +378 -0
  594. package/modules/sync-manager/ModuleFE_SyncManager_CSV.d.ts +11 -0
  595. package/modules/sync-manager/ModuleFE_SyncManager_CSV.js +121 -0
  596. package/package.json +107 -0
  597. package/server-info/Button_VersionUpdate.d.ts +15 -0
  598. package/server-info/Button_VersionUpdate.js +29 -0
  599. package/server-info/Button_VersionUpdate.scss +29 -0
  600. package/server-info/ModuleFE_ServerInfo.d.ts +26 -0
  601. package/server-info/ModuleFE_ServerInfo.js +73 -0
  602. package/server-info/index.d.ts +2 -0
  603. package/server-info/index.js +2 -0
  604. package/shared.d.ts +1 -0
  605. package/shared.js +21 -0
  606. package/styles/declaration/basic.scss +155 -0
  607. package/styles/declaration/mixins.scss +58 -0
  608. package/styles/impl/basic.scss +141 -0
  609. package/styles/impl/icons.scss +34 -0
  610. package/styles.scss +40 -0
  611. package/utils/EditableItem.d.ts +240 -0
  612. package/utils/EditableItem.js +552 -0
  613. package/utils/console/LogClient_ConsoleInterceptor.d.ts +5 -0
  614. package/utils/console/LogClient_ConsoleInterceptor.js +70 -0
  615. package/utils/perform-action/genereteToasts.d.ts +3 -0
  616. package/utils/perform-action/genereteToasts.js +14 -0
  617. package/utils/perform-action/index.d.ts +2 -0
  618. package/utils/perform-action/index.js +2 -0
  619. package/utils/perform-action/notification-dispatchers.d.ts +6 -0
  620. package/utils/perform-action/notification-dispatchers.js +2 -0
  621. package/utils/perform-action/performAction.d.ts +34 -0
  622. package/utils/perform-action/performAction.js +77 -0
  623. package/utils/perform-action/resolve-dependency-toast/ResolveDependencyToast.d.ts +8 -0
  624. package/utils/perform-action/resolve-dependency-toast/ResolveDependencyToast.js +11 -0
  625. package/utils/perform-action/resolve-dependency-toast/ResolveDependencyToast.scss +12 -0
  626. package/utils/tools.d.ts +31 -0
  627. package/utils/tools.js +138 -0
  628. package/utils/types.d.ts +3 -0
  629. package/utils/types.js +1 -0
  630. package/widgets/FieldEditor.d.ts +29 -0
  631. package/widgets/FieldEditor.js +47 -0
  632. package/widgets/FieldEditorClick.d.ts +33 -0
  633. package/widgets/FieldEditorClick.js +49 -0
  634. package/widgets/FieldEditorWithButtons.d.ts +32 -0
  635. 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,4 @@
1
+ import { EditableItem } from '../../utils/EditableItem.js';
2
+ export type EditableRef<Item> = {
3
+ editable: EditableItem<Item>;
4
+ };
@@ -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
+ }