@solidstarters/solid-core-ui 1.1.70 → 1.1.72

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 (609) hide show
  1. package/dist/components/CustomFooter/CustomFooter.tsx +264 -0
  2. package/dist/components/CustomFooter/FooterForm.tsx +19 -0
  3. package/dist/components/CustomHeader/CallIcon.tsx +20 -0
  4. package/dist/components/CustomHeader/CustomDropdown.tsx +175 -0
  5. package/dist/components/CustomHeader/CustomHeader.tsx +64 -0
  6. package/dist/components/CustomHeader/EmailIcon.tsx +12 -0
  7. package/dist/components/CustomHeader/HeaderCart.tsx +15 -0
  8. package/dist/components/CustomHeader/productNavData.tsx +180 -0
  9. package/dist/components/FormView/DetailsViews.tsx +46 -0
  10. package/dist/components/FormView/OrderAddressDetails.tsx +70 -0
  11. package/dist/components/FormView/OrderPaymentDetails.tsx +18 -0
  12. package/dist/components/FormView/OrderTableDetails.tsx +36 -0
  13. package/dist/components/FormView/OrderedProductDetail.tsx +22 -0
  14. package/dist/components/Svg/ExcelSvg.tsx +15 -0
  15. package/dist/components/Svg/FileSvg.tsx +19 -0
  16. package/dist/components/Svg/PDFSvg.tsx +15 -0
  17. package/dist/components/Svg/RightArrowSvg.d.ts +2 -0
  18. package/dist/components/Svg/RightArrowSvg.d.ts.map +1 -0
  19. package/dist/components/Svg/RightArrowSvg.js +5 -0
  20. package/dist/components/Svg/RightArrowSvg.js.map +1 -0
  21. package/dist/components/Svg/RightArrowSvg.tsx +9 -0
  22. package/dist/components/Tag/CustomTag.tsx +50 -0
  23. package/dist/components/auth/AuthLayout.js +3 -3
  24. package/dist/components/auth/AuthLayout.js.map +1 -1
  25. package/dist/components/auth/AuthLayout.tsx +140 -0
  26. package/dist/components/auth/ForgotPasswordThankYou.tsx +48 -0
  27. package/dist/components/auth/GoogleAuthChecking.tsx +60 -0
  28. package/dist/components/auth/Login.tsx +155 -0
  29. package/dist/components/auth/Register.tsx +239 -0
  30. package/dist/components/auth/SolidChangeForcePassword.tsx +145 -0
  31. package/dist/components/auth/SolidForgotPassword.tsx +125 -0
  32. package/dist/components/auth/SolidInitialLoginOtp.tsx +152 -0
  33. package/dist/components/auth/SolidInitiateRegisterOtp.tsx +141 -0
  34. package/dist/components/auth/SolidLogin.js +5 -5
  35. package/dist/components/auth/SolidLogin.js.map +1 -1
  36. package/dist/components/auth/SolidLogin.tsx +275 -0
  37. package/dist/components/auth/SolidOTPVerify.tsx +132 -0
  38. package/dist/components/auth/SolidRegister.js +4 -4
  39. package/dist/components/auth/SolidRegister.js.map +1 -1
  40. package/dist/components/auth/SolidRegister.tsx +348 -0
  41. package/dist/components/auth/SolidResetPassword.tsx +162 -0
  42. package/dist/components/common/AuthBanner.tsx +41 -0
  43. package/dist/components/common/AutoCompleteField.tsx +76 -0
  44. package/dist/components/common/BackButton.tsx +27 -0
  45. package/dist/components/common/CancelButton.tsx +48 -0
  46. package/dist/components/common/CodeEditor.tsx +26 -0
  47. package/dist/components/common/CreateButton.tsx +17 -0
  48. package/dist/components/common/DropzonePlaceholder.tsx +31 -0
  49. package/dist/components/common/DropzoneUpload.tsx +11 -0
  50. package/dist/components/common/FileReaderExt.tsx +20 -0
  51. package/dist/components/common/GeneralSettings.d.ts.map +1 -1
  52. package/dist/components/common/GeneralSettings.js +48 -48
  53. package/dist/components/common/GeneralSettings.js.map +1 -1
  54. package/dist/components/common/GeneralSettings.tsx +414 -0
  55. package/dist/components/common/HeaderDynamicTitles.tsx +13 -0
  56. package/dist/components/common/MarkdownViewer.tsx +16 -0
  57. package/dist/components/common/MultipleSelectAutoCompleteField.tsx +62 -0
  58. package/dist/components/common/NotFound.tsx +22 -0
  59. package/dist/components/common/SingleSelectAutoCompleteField.tsx +67 -0
  60. package/dist/components/common/SocialMediaLogin.tsx +53 -0
  61. package/dist/components/common/SolidAdmin.tsx +7 -0
  62. package/dist/components/common/SolidBreadcrumb.tsx +103 -0
  63. package/dist/components/common/SolidFormHeader.tsx +22 -0
  64. package/dist/components/common/SolidFormStepper.tsx +213 -0
  65. package/dist/components/common/SolidModuleHome.tsx +61 -0
  66. package/dist/components/common/SolidThemeLink.tsx +5 -0
  67. package/dist/components/common/SolidThemeProvider.tsx +44 -0
  68. package/dist/components/common/error.tsx +30 -0
  69. package/dist/components/core/chatter/SolidChatter.d.ts +7 -0
  70. package/dist/components/core/chatter/SolidChatter.d.ts.map +1 -0
  71. package/dist/components/core/chatter/SolidChatter.js +269 -0
  72. package/dist/components/core/chatter/SolidChatter.js.map +1 -0
  73. package/dist/components/core/chatter/SolidChatter.tsx +252 -0
  74. package/dist/components/core/chatter/SolidChatterDateDivider.d.ts +6 -0
  75. package/dist/components/core/chatter/SolidChatterDateDivider.d.ts.map +1 -0
  76. package/dist/components/core/chatter/SolidChatterDateDivider.js +7 -0
  77. package/dist/components/core/chatter/SolidChatterDateDivider.js.map +1 -0
  78. package/dist/components/core/chatter/SolidChatterDateDivider.tsx +16 -0
  79. package/dist/components/core/chatter/SolidChatterHeader.d.ts +17 -0
  80. package/dist/components/core/chatter/SolidChatterHeader.d.ts.map +1 -0
  81. package/dist/components/core/chatter/SolidChatterHeader.js +67 -0
  82. package/dist/components/core/chatter/SolidChatterHeader.js.map +1 -0
  83. package/dist/components/core/chatter/SolidChatterHeader.tsx +178 -0
  84. package/dist/components/core/chatter/SolidChatterMessageBox.d.ts +19 -0
  85. package/dist/components/core/chatter/SolidChatterMessageBox.d.ts.map +1 -0
  86. package/dist/components/core/chatter/SolidChatterMessageBox.js +46 -0
  87. package/dist/components/core/chatter/SolidChatterMessageBox.js.map +1 -0
  88. package/dist/components/core/chatter/SolidChatterMessageBox.tsx +165 -0
  89. package/dist/components/core/chatter/SolidMessageComposer.d.ts +7 -0
  90. package/dist/components/core/chatter/SolidMessageComposer.d.ts.map +1 -0
  91. package/dist/components/core/chatter/SolidMessageComposer.js +119 -0
  92. package/dist/components/core/chatter/SolidMessageComposer.js.map +1 -0
  93. package/dist/components/core/chatter/SolidMessageComposer.tsx +145 -0
  94. package/dist/components/core/chatter/chatter.module.css +70 -0
  95. package/dist/components/core/common/FilterComponent.tsx +434 -0
  96. package/dist/components/core/common/LoadDynamicJsxComponent.tsx +70 -0
  97. package/dist/components/core/common/SolidCreateButton.tsx +20 -0
  98. package/dist/components/core/common/SolidGlobalSearchElement.tsx +843 -0
  99. package/dist/components/core/common/SolidLayoutViews.tsx +87 -0
  100. package/dist/components/core/common/SolidListViewOptions.tsx +31 -0
  101. package/dist/components/core/common/SolidSaveCustomFilterForm.tsx +74 -0
  102. package/dist/components/core/common/SolidSearchBox.tsx +17 -0
  103. package/dist/components/core/common/SolidViewLayoutManager.d.ts +1 -1
  104. package/dist/components/core/common/SolidViewLayoutManager.ts +85 -0
  105. package/dist/components/core/extension/solid-core/emailTemplate/emailFormTypeChangeHandler.ts +18 -0
  106. package/dist/components/core/extension/solid-core/emailTemplate/emailFormTypeLoad.ts +18 -0
  107. package/dist/components/core/extension/solid-core/modelMetadata/list/GenerateModelCodeRowAction.tsx +59 -0
  108. package/dist/components/core/extension/solid-core/moduleMetadata/list/GenerateModuleCodeRowAction.tsx +38 -0
  109. package/dist/components/core/extension/solid-core/roleMetadata/RolePermissionsManyToManyFieldWidget.d.ts +2 -2
  110. package/dist/components/core/extension/solid-core/roleMetadata/RolePermissionsManyToManyFieldWidget.d.ts.map +1 -1
  111. package/dist/components/core/extension/solid-core/roleMetadata/RolePermissionsManyToManyFieldWidget.js.map +1 -1
  112. package/dist/components/core/extension/solid-core/roleMetadata/RolePermissionsManyToManyFieldWidget.tsx +123 -0
  113. package/dist/components/core/field/FieldListViewData.tsx +312 -0
  114. package/dist/components/core/filter/SolidFilterFields.tsx +128 -0
  115. package/dist/components/core/filter/SolidManyToOneFilterElement.tsx +60 -0
  116. package/dist/components/core/filter/SolidSelectionDynamicFilterElement.tsx +50 -0
  117. package/dist/components/core/filter/SolidSelectionStaticFilterElement.tsx +32 -0
  118. package/dist/components/core/filter/SolidVarInputsFilterElement.tsx +180 -0
  119. package/dist/components/core/filter/fields/SolidBigintField.tsx +9 -0
  120. package/dist/components/core/filter/fields/SolidBooleanField.tsx +50 -0
  121. package/dist/components/core/filter/fields/SolidComputedField.tsx +23 -0
  122. package/dist/components/core/filter/fields/SolidDateField.tsx +58 -0
  123. package/dist/components/core/filter/fields/SolidDatetimeField.tsx +51 -0
  124. package/dist/components/core/filter/fields/SolidDecimalField.tsx +9 -0
  125. package/dist/components/core/filter/fields/SolidExternalIdField.tsx +46 -0
  126. package/dist/components/core/filter/fields/SolidFloatField.tsx +9 -0
  127. package/dist/components/core/filter/fields/SolidIdField.tsx +46 -0
  128. package/dist/components/core/filter/fields/SolidIntField.tsx +56 -0
  129. package/dist/components/core/filter/fields/SolidLongTextField.tsx +9 -0
  130. package/dist/components/core/filter/fields/SolidMediaMultipleField.tsx +54 -0
  131. package/dist/components/core/filter/fields/SolidMediaSingleField.tsx +56 -0
  132. package/dist/components/core/filter/fields/SolidRelationField.tsx +13 -0
  133. package/dist/components/core/filter/fields/SolidRichTextField.tsx +9 -0
  134. package/dist/components/core/filter/fields/SolidSelectionDynamicField.tsx +46 -0
  135. package/dist/components/core/filter/fields/SolidSelectionStaticField.tsx +48 -0
  136. package/dist/components/core/filter/fields/SolidShortTextField.tsx +54 -0
  137. package/dist/components/core/filter/fields/SolidTimeField.tsx +45 -0
  138. package/dist/components/core/filter/fields/SolidUuidField.tsx +45 -0
  139. package/dist/components/core/filter/fields/relations/SolidRelationManyToOneField.tsx +80 -0
  140. package/dist/components/core/form/SolidFormLayouts.tsx +104 -0
  141. package/dist/components/core/form/SolidFormUserViewLayout.tsx +85 -0
  142. package/dist/components/core/form/SolidFormView.d.ts.map +1 -1
  143. package/dist/components/core/form/SolidFormView.js +53 -46
  144. package/dist/components/core/form/SolidFormView.js.map +1 -1
  145. package/dist/components/core/form/SolidFormView.tsx +1352 -0
  146. package/dist/components/core/form/fields/ISolidField.tsx +69 -0
  147. package/dist/components/core/form/fields/SolidBooleanField.d.ts +4 -1
  148. package/dist/components/core/form/fields/SolidBooleanField.d.ts.map +1 -1
  149. package/dist/components/core/form/fields/SolidBooleanField.js +80 -29
  150. package/dist/components/core/form/fields/SolidBooleanField.js.map +1 -1
  151. package/dist/components/core/form/fields/SolidBooleanField.tsx +269 -0
  152. package/dist/components/core/form/fields/SolidDateField.d.ts +3 -0
  153. package/dist/components/core/form/fields/SolidDateField.d.ts.map +1 -1
  154. package/dist/components/core/form/fields/SolidDateField.js +45 -25
  155. package/dist/components/core/form/fields/SolidDateField.js.map +1 -1
  156. package/dist/components/core/form/fields/SolidDateField.tsx +153 -0
  157. package/dist/components/core/form/fields/SolidDateTimeField.d.ts +3 -0
  158. package/dist/components/core/form/fields/SolidDateTimeField.d.ts.map +1 -1
  159. package/dist/components/core/form/fields/SolidDateTimeField.js +44 -25
  160. package/dist/components/core/form/fields/SolidDateTimeField.js.map +1 -1
  161. package/dist/components/core/form/fields/SolidDateTimeField.tsx +154 -0
  162. package/dist/components/core/form/fields/SolidDecimalField.d.ts +3 -0
  163. package/dist/components/core/form/fields/SolidDecimalField.d.ts.map +1 -1
  164. package/dist/components/core/form/fields/SolidDecimalField.js +41 -21
  165. package/dist/components/core/form/fields/SolidDecimalField.js.map +1 -1
  166. package/dist/components/core/form/fields/SolidDecimalField.tsx +155 -0
  167. package/dist/components/core/form/fields/SolidEmailField.d.ts +3 -0
  168. package/dist/components/core/form/fields/SolidEmailField.d.ts.map +1 -1
  169. package/dist/components/core/form/fields/SolidEmailField.js +41 -21
  170. package/dist/components/core/form/fields/SolidEmailField.js.map +1 -1
  171. package/dist/components/core/form/fields/SolidEmailField.tsx +168 -0
  172. package/dist/components/core/form/fields/SolidIntegerField.d.ts +3 -0
  173. package/dist/components/core/form/fields/SolidIntegerField.d.ts.map +1 -1
  174. package/dist/components/core/form/fields/SolidIntegerField.js +41 -21
  175. package/dist/components/core/form/fields/SolidIntegerField.js.map +1 -1
  176. package/dist/components/core/form/fields/SolidIntegerField.tsx +158 -0
  177. package/dist/components/core/form/fields/SolidJsonField.d.ts +4 -0
  178. package/dist/components/core/form/fields/SolidJsonField.d.ts.map +1 -1
  179. package/dist/components/core/form/fields/SolidJsonField.js +51 -15
  180. package/dist/components/core/form/fields/SolidJsonField.js.map +1 -1
  181. package/dist/components/core/form/fields/SolidJsonField.tsx +173 -0
  182. package/dist/components/core/form/fields/SolidLongTextField.d.ts +3 -2
  183. package/dist/components/core/form/fields/SolidLongTextField.d.ts.map +1 -1
  184. package/dist/components/core/form/fields/SolidLongTextField.js +33 -52
  185. package/dist/components/core/form/fields/SolidLongTextField.js.map +1 -1
  186. package/dist/components/core/form/fields/SolidLongTextField.tsx +161 -0
  187. package/dist/components/core/form/fields/SolidMediaMultipleField.d.ts +4 -0
  188. package/dist/components/core/form/fields/SolidMediaMultipleField.d.ts.map +1 -1
  189. package/dist/components/core/form/fields/SolidMediaMultipleField.js +262 -153
  190. package/dist/components/core/form/fields/SolidMediaMultipleField.js.map +1 -1
  191. package/dist/components/core/form/fields/SolidMediaMultipleField.tsx +639 -0
  192. package/dist/components/core/form/fields/SolidMediaSingleField.d.ts +4 -0
  193. package/dist/components/core/form/fields/SolidMediaSingleField.d.ts.map +1 -1
  194. package/dist/components/core/form/fields/SolidMediaSingleField.js +243 -149
  195. package/dist/components/core/form/fields/SolidMediaSingleField.js.map +1 -1
  196. package/dist/components/core/form/fields/SolidMediaSingleField.tsx +522 -0
  197. package/dist/components/core/form/fields/SolidPasswordField.d.ts +4 -0
  198. package/dist/components/core/form/fields/SolidPasswordField.d.ts.map +1 -1
  199. package/dist/components/core/form/fields/SolidPasswordField.js +50 -20
  200. package/dist/components/core/form/fields/SolidPasswordField.js.map +1 -1
  201. package/dist/components/core/form/fields/SolidPasswordField.tsx +187 -0
  202. package/dist/components/core/form/fields/SolidRelationField.tsx +54 -0
  203. package/dist/components/core/form/fields/SolidRichTextField.d.ts +4 -0
  204. package/dist/components/core/form/fields/SolidRichTextField.d.ts.map +1 -1
  205. package/dist/components/core/form/fields/SolidRichTextField.js +49 -20
  206. package/dist/components/core/form/fields/SolidRichTextField.js.map +1 -1
  207. package/dist/components/core/form/fields/SolidRichTextField.tsx +177 -0
  208. package/dist/components/core/form/fields/SolidSelectionDynamicField.d.ts +4 -0
  209. package/dist/components/core/form/fields/SolidSelectionDynamicField.d.ts.map +1 -1
  210. package/dist/components/core/form/fields/SolidSelectionDynamicField.js +88 -60
  211. package/dist/components/core/form/fields/SolidSelectionDynamicField.js.map +1 -1
  212. package/dist/components/core/form/fields/SolidSelectionDynamicField.tsx +204 -0
  213. package/dist/components/core/form/fields/SolidSelectionStaticField.d.ts +5 -1
  214. package/dist/components/core/form/fields/SolidSelectionStaticField.d.ts.map +1 -1
  215. package/dist/components/core/form/fields/SolidSelectionStaticField.js +88 -27
  216. package/dist/components/core/form/fields/SolidSelectionStaticField.js.map +1 -1
  217. package/dist/components/core/form/fields/SolidSelectionStaticField.tsx +272 -0
  218. package/dist/components/core/form/fields/SolidShortTextField.d.ts +4 -0
  219. package/dist/components/core/form/fields/SolidShortTextField.d.ts.map +1 -1
  220. package/dist/components/core/form/fields/SolidShortTextField.js +57 -26
  221. package/dist/components/core/form/fields/SolidShortTextField.js.map +1 -1
  222. package/dist/components/core/form/fields/SolidShortTextField.tsx +208 -0
  223. package/dist/components/core/form/fields/SolidTimeField.d.ts +3 -0
  224. package/dist/components/core/form/fields/SolidTimeField.d.ts.map +1 -1
  225. package/dist/components/core/form/fields/SolidTimeField.js +44 -22
  226. package/dist/components/core/form/fields/SolidTimeField.js.map +1 -1
  227. package/dist/components/core/form/fields/SolidTimeField.tsx +147 -0
  228. package/dist/components/core/form/fields/relations/SolidRelationManyToManyField.d.ts +4 -1
  229. package/dist/components/core/form/fields/relations/SolidRelationManyToManyField.d.ts.map +1 -1
  230. package/dist/components/core/form/fields/relations/SolidRelationManyToManyField.js +77 -19
  231. package/dist/components/core/form/fields/relations/SolidRelationManyToManyField.js.map +1 -1
  232. package/dist/components/core/form/fields/relations/SolidRelationManyToManyField.tsx +309 -0
  233. package/dist/components/core/form/fields/relations/SolidRelationManyToOneField.d.ts +5 -1
  234. package/dist/components/core/form/fields/relations/SolidRelationManyToOneField.d.ts.map +1 -1
  235. package/dist/components/core/form/fields/relations/SolidRelationManyToOneField.js +136 -107
  236. package/dist/components/core/form/fields/relations/SolidRelationManyToOneField.js.map +1 -1
  237. package/dist/components/core/form/fields/relations/SolidRelationManyToOneField.tsx +291 -0
  238. package/dist/components/core/form/fields/relations/SolidRelationOneToManyField.d.ts +5 -1
  239. package/dist/components/core/form/fields/relations/SolidRelationOneToManyField.d.ts.map +1 -1
  240. package/dist/components/core/form/fields/relations/SolidRelationOneToManyField.js +159 -107
  241. package/dist/components/core/form/fields/relations/SolidRelationOneToManyField.js.map +1 -1
  242. package/dist/components/core/form/fields/relations/SolidRelationOneToManyField.tsx +311 -0
  243. package/dist/components/core/form/fields/relations/widgets/SolidRelationManyToManyAutocompleteWidget.d.ts +1 -1
  244. package/dist/components/core/form/fields/relations/widgets/SolidRelationManyToManyCheckboxWidget.d.ts +1 -1
  245. package/dist/components/core/form/fields/relations/widgets/helpers/InlineRelationEntityDialog.tsx +33 -0
  246. package/dist/components/core/form/fields/relations/widgets/helpers/useRelationEntityHandler.ts +64 -0
  247. package/dist/components/core/form/fields/widgets/SolidBooleanCheckboxFieldWidget.d.ts +1 -1
  248. package/dist/components/core/form/fields/widgets/SolidBooleanSelectFieldWidget.d.ts +1 -1
  249. package/dist/components/core/form/fields/widgets/SolidFormFieldViewMediaMultipleWidget.d.ts +1 -1
  250. package/dist/components/core/form/fields/widgets/SolidFormFieldViewMediaSingleWidget.d.ts +1 -1
  251. package/dist/components/core/form/fields/widgets/SolidRelationFieldAvatarFormWidget.d.ts +3 -0
  252. package/dist/components/core/form/fields/widgets/SolidRelationFieldAvatarFormWidget.d.ts.map +1 -0
  253. package/dist/components/core/form/fields/widgets/SolidRelationFieldAvatarFormWidget.js +29 -0
  254. package/dist/components/core/form/fields/widgets/SolidRelationFieldAvatarFormWidget.js.map +1 -0
  255. package/dist/components/core/form/fields/widgets/SolidRelationFieldAvatarFormWidget.tsx +46 -0
  256. package/dist/components/core/form/fields/widgets/SolidSelectionStaticAutocompleteFieldWidget.d.ts +1 -1
  257. package/dist/components/core/form/fields/widgets/SolidSelectionStaticRadioFieldWidget.d.ts +1 -1
  258. package/dist/components/core/form/widgets/CustomHtml.d.ts +1 -1
  259. package/dist/components/core/form/widgets/CustomHtml.tsx +19 -0
  260. package/dist/components/core/kanban/KanbanBoard.tsx +131 -0
  261. package/dist/components/core/kanban/KanbanCard.tsx +255 -0
  262. package/dist/components/core/kanban/KanbanColumn.tsx +139 -0
  263. package/dist/components/core/kanban/KanbanUserViewLayout.tsx +85 -0
  264. package/dist/components/core/kanban/SolidKanbanView.tsx +803 -0
  265. package/dist/components/core/kanban/SolidKanbanViewConfigure.tsx +146 -0
  266. package/dist/components/core/kanban/SolidKanbanViewFields.tsx +164 -0
  267. package/dist/components/core/kanban/SolidManyToOneFilterElement.tsx +59 -0
  268. package/dist/components/core/kanban/SolidSelectionDynamicFilterElement.tsx +50 -0
  269. package/dist/components/core/kanban/SolidSelectionStaticFilterElement.tsx +32 -0
  270. package/dist/components/core/kanban/SolidVarInputsFilterElement.tsx +184 -0
  271. package/dist/components/core/kanban/kanban-fields/SolidBigintKanbanField.tsx +9 -0
  272. package/dist/components/core/kanban/kanban-fields/SolidBooleanKanbanField.tsx +13 -0
  273. package/dist/components/core/kanban/kanban-fields/SolidComputedKanbanField.tsx +23 -0
  274. package/dist/components/core/kanban/kanban-fields/SolidDateKanbanField.tsx +14 -0
  275. package/dist/components/core/kanban/kanban-fields/SolidDatetimeKanbanField.tsx +13 -0
  276. package/dist/components/core/kanban/kanban-fields/SolidDecimalKanbanField.tsx +9 -0
  277. package/dist/components/core/kanban/kanban-fields/SolidExternalIdKanbanField.tsx +12 -0
  278. package/dist/components/core/kanban/kanban-fields/SolidFloatKanbanField.tsx +9 -0
  279. package/dist/components/core/kanban/kanban-fields/SolidIdKanbanField.tsx +14 -0
  280. package/dist/components/core/kanban/kanban-fields/SolidIntKanbanField.tsx +20 -0
  281. package/dist/components/core/kanban/kanban-fields/SolidLongTextKanbanField.tsx +9 -0
  282. package/dist/components/core/kanban/kanban-fields/SolidMediaMultipleKanbanField.tsx +136 -0
  283. package/dist/components/core/kanban/kanban-fields/SolidMediaSingleKanbanField.tsx +158 -0
  284. package/dist/components/core/kanban/kanban-fields/SolidRelationKanbanField.tsx +13 -0
  285. package/dist/components/core/kanban/kanban-fields/SolidRichTextKanbanField.tsx +9 -0
  286. package/dist/components/core/kanban/kanban-fields/SolidSelectionDynamicKanbanField.tsx +13 -0
  287. package/dist/components/core/kanban/kanban-fields/SolidSelectionStaticKanbanField.tsx +14 -0
  288. package/dist/components/core/kanban/kanban-fields/SolidShortTextKanbanField.js +6 -6
  289. package/dist/components/core/kanban/kanban-fields/SolidShortTextKanbanField.js.map +1 -1
  290. package/dist/components/core/kanban/kanban-fields/SolidShortTextKanbanField.tsx +121 -0
  291. package/dist/components/core/kanban/kanban-fields/SolidTimeKanbanField.tsx +12 -0
  292. package/dist/components/core/kanban/kanban-fields/SolidUuidKanbanField.tsx +13 -0
  293. package/dist/components/core/kanban/kanban-fields/relations/SolidRelationManyToOneKanbanField.tsx +16 -0
  294. package/dist/components/core/list/ListViewRowActionPopup.tsx +42 -0
  295. package/dist/components/core/list/SolidListColumnSelector.tsx +167 -0
  296. package/dist/components/core/list/SolidListView.js +1 -1
  297. package/dist/components/core/list/SolidListView.js.map +1 -1
  298. package/dist/components/core/list/SolidListView.tsx +961 -0
  299. package/dist/components/core/list/SolidListViewColumn.tsx +162 -0
  300. package/dist/components/core/list/SolidListViewConfigure.tsx +198 -0
  301. package/dist/components/core/list/SolidListingHeader.tsx +42 -0
  302. package/dist/components/core/list/SolidManyToOneFilterElement.tsx +59 -0
  303. package/dist/components/core/list/SolidSelectionDynamicFilterElement.tsx +50 -0
  304. package/dist/components/core/list/SolidSelectionStaticFilterElement.tsx +32 -0
  305. package/dist/components/core/list/SolidTableRowCell.tsx +12 -0
  306. package/dist/components/core/list/SolidVarInputsFilterElement.tsx +184 -0
  307. package/dist/components/core/list/columns/SolidBigintColumn.tsx +9 -0
  308. package/dist/components/core/list/columns/SolidBooleanColumn.d.ts +2 -0
  309. package/dist/components/core/list/columns/SolidBooleanColumn.d.ts.map +1 -1
  310. package/dist/components/core/list/columns/SolidBooleanColumn.js +33 -2
  311. package/dist/components/core/list/columns/SolidBooleanColumn.js.map +1 -1
  312. package/dist/components/core/list/columns/SolidBooleanColumn.tsx +89 -0
  313. package/dist/components/core/list/columns/SolidComputedColumn.tsx +23 -0
  314. package/dist/components/core/list/columns/SolidDateColumn.d.ts.map +1 -1
  315. package/dist/components/core/list/columns/SolidDateColumn.js +27 -3
  316. package/dist/components/core/list/columns/SolidDateColumn.js.map +1 -1
  317. package/dist/components/core/list/columns/SolidDateColumn.tsx +90 -0
  318. package/dist/components/core/list/columns/SolidDatetimeColumn.d.ts.map +1 -1
  319. package/dist/components/core/list/columns/SolidDatetimeColumn.js +27 -3
  320. package/dist/components/core/list/columns/SolidDatetimeColumn.js.map +1 -1
  321. package/dist/components/core/list/columns/SolidDatetimeColumn.tsx +79 -0
  322. package/dist/components/core/list/columns/SolidDecimalColumn.tsx +9 -0
  323. package/dist/components/core/list/columns/SolidExternalIdColumn.d.ts.map +1 -1
  324. package/dist/components/core/list/columns/SolidExternalIdColumn.js +27 -3
  325. package/dist/components/core/list/columns/SolidExternalIdColumn.js.map +1 -1
  326. package/dist/components/core/list/columns/SolidExternalIdColumn.tsx +80 -0
  327. package/dist/components/core/list/columns/SolidFloatColumn.tsx +9 -0
  328. package/dist/components/core/list/columns/SolidIdColumn.d.ts.map +1 -1
  329. package/dist/components/core/list/columns/SolidIdColumn.js +27 -3
  330. package/dist/components/core/list/columns/SolidIdColumn.js.map +1 -1
  331. package/dist/components/core/list/columns/SolidIdColumn.tsx +79 -0
  332. package/dist/components/core/list/columns/SolidIntColumn.d.ts.map +1 -1
  333. package/dist/components/core/list/columns/SolidIntColumn.js +27 -3
  334. package/dist/components/core/list/columns/SolidIntColumn.js.map +1 -1
  335. package/dist/components/core/list/columns/SolidIntColumn.tsx +87 -0
  336. package/dist/components/core/list/columns/SolidLongTextColumn.tsx +9 -0
  337. package/dist/components/core/list/columns/SolidMediaMultipleColumn.d.ts +2 -0
  338. package/dist/components/core/list/columns/SolidMediaMultipleColumn.d.ts.map +1 -1
  339. package/dist/components/core/list/columns/SolidMediaMultipleColumn.js +48 -22
  340. package/dist/components/core/list/columns/SolidMediaMultipleColumn.js.map +1 -1
  341. package/dist/components/core/list/columns/SolidMediaMultipleColumn.tsx +100 -0
  342. package/dist/components/core/list/columns/SolidMediaSingleColumn.d.ts +2 -0
  343. package/dist/components/core/list/columns/SolidMediaSingleColumn.d.ts.map +1 -1
  344. package/dist/components/core/list/columns/SolidMediaSingleColumn.js +41 -13
  345. package/dist/components/core/list/columns/SolidMediaSingleColumn.js.map +1 -1
  346. package/dist/components/core/list/columns/SolidMediaSingleColumn.tsx +98 -0
  347. package/dist/components/core/list/columns/SolidRelationColumn.d.ts.map +1 -1
  348. package/dist/components/core/list/columns/SolidRelationColumn.js +7 -0
  349. package/dist/components/core/list/columns/SolidRelationColumn.js.map +1 -1
  350. package/dist/components/core/list/columns/SolidRelationColumn.tsx +20 -0
  351. package/dist/components/core/list/columns/SolidRichTextColumn.tsx +9 -0
  352. package/dist/components/core/list/columns/SolidSelectionDynamicColumn.d.ts.map +1 -1
  353. package/dist/components/core/list/columns/SolidSelectionDynamicColumn.js +27 -3
  354. package/dist/components/core/list/columns/SolidSelectionDynamicColumn.js.map +1 -1
  355. package/dist/components/core/list/columns/SolidSelectionDynamicColumn.tsx +80 -0
  356. package/dist/components/core/list/columns/SolidSelectionStaticColumn.d.ts.map +1 -1
  357. package/dist/components/core/list/columns/SolidSelectionStaticColumn.js +27 -3
  358. package/dist/components/core/list/columns/SolidSelectionStaticColumn.js.map +1 -1
  359. package/dist/components/core/list/columns/SolidSelectionStaticColumn.tsx +81 -0
  360. package/dist/components/core/list/columns/SolidShortTextColumn.d.ts +2 -0
  361. package/dist/components/core/list/columns/SolidShortTextColumn.d.ts.map +1 -1
  362. package/dist/components/core/list/columns/SolidShortTextColumn.js +16 -37
  363. package/dist/components/core/list/columns/SolidShortTextColumn.js.map +1 -1
  364. package/dist/components/core/list/columns/SolidShortTextColumn.tsx +103 -0
  365. package/dist/components/core/list/columns/SolidTimeColumn.d.ts.map +1 -1
  366. package/dist/components/core/list/columns/SolidTimeColumn.js +27 -3
  367. package/dist/components/core/list/columns/SolidTimeColumn.js.map +1 -1
  368. package/dist/components/core/list/columns/SolidTimeColumn.tsx +78 -0
  369. package/dist/components/core/list/columns/SolidUuidColumn.d.ts.map +1 -1
  370. package/dist/components/core/list/columns/SolidUuidColumn.js +27 -3
  371. package/dist/components/core/list/columns/SolidUuidColumn.js.map +1 -1
  372. package/dist/components/core/list/columns/SolidUuidColumn.tsx +79 -0
  373. package/dist/components/core/list/columns/relations/SolidRelationManyToManyColumn.d.ts +6 -0
  374. package/dist/components/core/list/columns/relations/SolidRelationManyToManyColumn.d.ts.map +1 -0
  375. package/dist/components/core/list/columns/relations/SolidRelationManyToManyColumn.js +70 -0
  376. package/dist/components/core/list/columns/relations/SolidRelationManyToManyColumn.js.map +1 -0
  377. package/dist/components/core/list/columns/relations/SolidRelationManyToManyColumn.tsx +110 -0
  378. package/dist/components/core/list/columns/relations/SolidRelationManyToOneColumn.d.ts +2 -0
  379. package/dist/components/core/list/columns/relations/SolidRelationManyToOneColumn.d.ts.map +1 -1
  380. package/dist/components/core/list/columns/relations/SolidRelationManyToOneColumn.js +42 -17
  381. package/dist/components/core/list/columns/relations/SolidRelationManyToOneColumn.js.map +1 -1
  382. package/dist/components/core/list/columns/relations/SolidRelationManyToOneColumn.tsx +95 -0
  383. package/dist/components/core/list/columns/relations/SolidRelationOneToManyColumn.d.ts +6 -0
  384. package/dist/components/core/list/columns/relations/SolidRelationOneToManyColumn.d.ts.map +1 -0
  385. package/dist/components/core/list/columns/relations/SolidRelationOneToManyColumn.js +70 -0
  386. package/dist/components/core/list/columns/relations/SolidRelationOneToManyColumn.js.map +1 -0
  387. package/dist/components/core/list/columns/relations/SolidRelationOneToManyColumn.tsx +111 -0
  388. package/dist/components/core/list/widgets/SolidRelationAvatarWidget.d.ts +4 -0
  389. package/dist/components/core/list/widgets/SolidRelationAvatarWidget.d.ts.map +1 -0
  390. package/dist/components/core/list/widgets/SolidRelationAvatarWidget.js +60 -0
  391. package/dist/components/core/list/widgets/SolidRelationAvatarWidget.js.map +1 -0
  392. package/dist/components/core/list/widgets/SolidRelationAvatarWidget.tsx +89 -0
  393. package/dist/components/core/list/widgets/SolidShortTextAvatarWidget.d.ts +3 -0
  394. package/dist/components/core/list/widgets/SolidShortTextAvatarWidget.d.ts.map +1 -0
  395. package/dist/components/core/list/widgets/SolidShortTextAvatarWidget.js +42 -0
  396. package/dist/components/core/list/widgets/SolidShortTextAvatarWidget.js.map +1 -0
  397. package/{src/components/core/list/widgets/SolidUserNameAvatarWidget.tsx → dist/components/core/list/widgets/SolidShortTextAvatarWidget.tsx} +18 -11
  398. package/dist/components/core/list/widgets/SolidShortTextFieldImageRenderModeWidget.d.ts +2 -1
  399. package/dist/components/core/list/widgets/SolidShortTextFieldImageRenderModeWidget.d.ts.map +1 -1
  400. package/dist/components/core/list/widgets/SolidShortTextFieldImageRenderModeWidget.js +4 -4
  401. package/dist/components/core/list/widgets/SolidShortTextFieldImageRenderModeWidget.js.map +1 -1
  402. package/dist/components/core/list/widgets/SolidShortTextFieldImageRenderModeWidget.tsx +21 -0
  403. package/dist/components/core/model/CreateModel.tsx +476 -0
  404. package/dist/components/core/model/FieldMetaData.tsx +193 -0
  405. package/dist/components/core/model/FieldMetaDataForm.js +1 -1
  406. package/dist/components/core/model/FieldMetaDataForm.js.map +1 -1
  407. package/dist/components/core/model/FieldMetaDataForm.tsx +3048 -0
  408. package/dist/components/core/model/FieldSelector.tsx +62 -0
  409. package/dist/components/core/model/ModelListViewData.tsx +383 -0
  410. package/dist/components/core/model/ModelMetaData.tsx +840 -0
  411. package/dist/components/core/module/CreateModule.tsx +620 -0
  412. package/dist/components/core/module/ModuleListViewData.tsx +429 -0
  413. package/dist/components/core/users/CreateUser.d.ts.map +1 -1
  414. package/dist/components/core/users/CreateUser.js +16 -16
  415. package/dist/components/core/users/CreateUser.js.map +1 -1
  416. package/dist/components/core/users/CreateUser.tsx +436 -0
  417. package/dist/components/core/users/CreateUserRole.tsx +211 -0
  418. package/dist/components/core/users/UserListView.tsx +374 -0
  419. package/dist/components/layout/AdminLayout.tsx +62 -0
  420. package/dist/components/layout/AdminSidebar.tsx +65 -0
  421. package/dist/components/layout/AppConfig.d.ts +1 -1
  422. package/dist/components/layout/AppConfig.tsx +104 -0
  423. package/dist/components/layout/AppSidebar.tsx +225 -0
  424. package/dist/components/layout/ButtonLoader.tsx +7 -0
  425. package/dist/components/layout/CustomPagination.tsx +55 -0
  426. package/dist/components/layout/DashboardHeader.tsx +89 -0
  427. package/dist/components/layout/FilterMenu.tsx +122 -0
  428. package/dist/components/layout/Footer.tsx +13 -0
  429. package/dist/components/layout/GlobalSearch.tsx +37 -0
  430. package/dist/components/layout/Header.tsx +8 -0
  431. package/dist/components/layout/Layout.d.ts +1 -1
  432. package/dist/components/layout/Layout.tsx +136 -0
  433. package/dist/components/layout/ListingHeader.tsx +204 -0
  434. package/dist/components/layout/Loader.tsx +16 -0
  435. package/dist/components/layout/UserSidebar.tsx +53 -0
  436. package/dist/components/layout/context/layoutcontext.d.ts +1 -1
  437. package/dist/components/layout/context/layoutcontext.tsx +52 -0
  438. package/dist/components/layout/navbar-one.tsx +258 -0
  439. package/dist/components/layout/navbar-two-menu.tsx +73 -0
  440. package/dist/components/layout/navbar-two.tsx +37 -0
  441. package/dist/components/layout/user-profile-menu.tsx +120 -0
  442. package/dist/components/layout/user-profile.tsx +7 -0
  443. package/dist/components/modelsComponents/filterIcon.tsx +9 -0
  444. package/dist/components/tables/DemoData.tsx +318 -0
  445. package/dist/components/tables/DynamicTable.tsx +56 -0
  446. package/dist/components/tables/ListViewTable.tsx +156 -0
  447. package/dist/declarations.d.ts +19 -0
  448. package/dist/helpers/AppTitle.tsx +12 -0
  449. package/dist/helpers/ToastContainer.tsx +93 -0
  450. package/dist/helpers/authHeader.ts +20 -0
  451. package/dist/helpers/countries.tsx +260 -0
  452. package/dist/helpers/downloadMediaFile.tsx +19 -0
  453. package/dist/helpers/getAcceptedFileTypes.tsx +22 -0
  454. package/dist/helpers/getRandomColors.d.ts +4 -0
  455. package/dist/helpers/getRandomColors.d.ts.map +1 -0
  456. package/dist/helpers/getRandomColors.js +63 -0
  457. package/dist/helpers/getRandomColors.js.map +1 -0
  458. package/dist/helpers/getRandomColors.tsx +68 -0
  459. package/dist/helpers/helpers.ts +40 -0
  460. package/dist/helpers/menu.tsx +670 -0
  461. package/dist/helpers/permissions.ts +19 -0
  462. package/dist/helpers/registry.d.ts.map +1 -1
  463. package/dist/helpers/registry.js +77 -35
  464. package/dist/helpers/registry.js.map +1 -1
  465. package/dist/helpers/registry.ts +173 -0
  466. package/dist/helpers/revalidate.ts +7 -0
  467. package/dist/index.d.ts +2 -1
  468. package/dist/index.d.ts.map +1 -1
  469. package/dist/index.js +1 -0
  470. package/dist/index.js.map +1 -1
  471. package/dist/index.ts +642 -0
  472. package/dist/nextAuth/authProviders.tsx +221 -0
  473. package/dist/nextAuth/refreshAccessToken.tsx +27 -0
  474. package/dist/redux/api/articleApi.ts +55 -0
  475. package/dist/redux/api/authApi.ts +131 -0
  476. package/dist/redux/api/automationApi.ts +55 -0
  477. package/dist/redux/api/categoryApi.tsx +46 -0
  478. package/dist/redux/api/cityApi.tsx +56 -0
  479. package/dist/redux/api/cmsBannerImageApi.tsx +55 -0
  480. package/dist/redux/api/countryApi.tsx +56 -0
  481. package/dist/redux/api/fetchBaseQuery.tsx +15 -0
  482. package/dist/redux/api/fieldApi.ts +78 -0
  483. package/dist/redux/api/mediaApi.ts +55 -0
  484. package/dist/redux/api/mediaStorageProviderApi.ts +55 -0
  485. package/dist/redux/api/menuApi.tsx +55 -0
  486. package/dist/redux/api/menuItemsApi.tsx +56 -0
  487. package/dist/redux/api/modelApi.ts +77 -0
  488. package/dist/redux/api/moduleApi.ts +72 -0
  489. package/dist/redux/api/orderAttributeApi.tsx +37 -0
  490. package/dist/redux/api/permissionApi.ts +32 -0
  491. package/dist/redux/api/pincodeApi.tsx +56 -0
  492. package/dist/redux/api/productData.tsx +87 -0
  493. package/dist/redux/api/radixExtraModelAttributeApi.tsx +37 -0
  494. package/dist/redux/api/radixModelMetadataApi.tsx +62 -0
  495. package/dist/redux/api/radixModelsApi.tsx +64 -0
  496. package/dist/redux/api/ratingApi.ts +55 -0
  497. package/dist/redux/api/reviewApi.ts +55 -0
  498. package/dist/redux/api/roleApi.ts +58 -0
  499. package/dist/redux/api/solidActionApi.ts +66 -0
  500. package/dist/redux/api/solidChatterMessageApi.d.ts +7 -0
  501. package/dist/redux/api/solidChatterMessageApi.d.ts.map +1 -0
  502. package/dist/redux/api/solidChatterMessageApi.js +29 -0
  503. package/dist/redux/api/solidChatterMessageApi.js.map +1 -0
  504. package/dist/redux/api/solidChatterMessageApi.ts +30 -0
  505. package/dist/redux/api/solidEntityApi.tsx +110 -0
  506. package/dist/redux/api/solidMenuApi.ts +71 -0
  507. package/dist/redux/api/solidSettingsApi.d.ts +2 -1
  508. package/dist/redux/api/solidSettingsApi.d.ts.map +1 -1
  509. package/dist/redux/api/solidSettingsApi.js +11 -1
  510. package/dist/redux/api/solidSettingsApi.js.map +1 -1
  511. package/dist/redux/api/solidSettingsApi.tsx +55 -0
  512. package/dist/redux/api/solidViewApi.ts +73 -0
  513. package/dist/redux/api/stateApi.tsx +56 -0
  514. package/dist/redux/api/tagApi.ts +55 -0
  515. package/dist/redux/api/tagGroupApi.tsx +55 -0
  516. package/dist/redux/api/testApi.ts +21 -0
  517. package/dist/redux/api/userApi.ts +120 -0
  518. package/dist/redux/features/authSlice.ts +19 -0
  519. package/dist/redux/features/dataViewSlice.ts +26 -0
  520. package/dist/redux/features/navbarSlice.ts +21 -0
  521. package/dist/redux/features/popupSlice.ts +27 -0
  522. package/dist/redux/features/themeSlice.ts +17 -0
  523. package/dist/redux/features/userSlice.ts +28 -0
  524. package/dist/resources/globals.css +59 -0
  525. package/dist/types/index.d.ts +60 -0
  526. package/dist/types/layout.d.ts +94 -0
  527. package/dist/types/next-auth.d.ts +0 -0
  528. package/dist/types/next.d.ts +46 -0
  529. package/dist/types/solid-core.d.ts +139 -0
  530. package/package.json +4 -3
  531. package/src/components/Svg/RightArrowSvg.tsx +9 -0
  532. package/src/components/auth/AuthLayout.tsx +3 -3
  533. package/src/components/auth/SolidLogin.tsx +6 -6
  534. package/src/components/auth/SolidRegister.tsx +5 -5
  535. package/src/components/common/GeneralSettings.tsx +293 -285
  536. package/src/components/core/chatter/SolidChatter.tsx +252 -0
  537. package/src/components/core/chatter/SolidChatterDateDivider.tsx +16 -0
  538. package/src/components/core/chatter/SolidChatterHeader.tsx +178 -0
  539. package/src/components/core/chatter/SolidChatterMessageBox.tsx +165 -0
  540. package/src/components/core/chatter/SolidMessageComposer.tsx +145 -0
  541. package/src/components/core/chatter/chatter.module.css +70 -0
  542. package/src/components/core/extension/solid-core/roleMetadata/RolePermissionsManyToManyFieldWidget.tsx +2 -2
  543. package/src/components/core/form/SolidFormView.tsx +166 -136
  544. package/src/components/core/form/fields/SolidBooleanField.tsx +170 -48
  545. package/src/components/core/form/fields/SolidDateField.tsx +86 -51
  546. package/src/components/core/form/fields/SolidDateTimeField.tsx +89 -52
  547. package/src/components/core/form/fields/SolidDecimalField.tsx +84 -49
  548. package/src/components/core/form/fields/SolidEmailField.tsx +90 -51
  549. package/src/components/core/form/fields/SolidIntegerField.tsx +86 -49
  550. package/src/components/core/form/fields/SolidJsonField.tsx +112 -42
  551. package/src/components/core/form/fields/SolidLongTextField.tsx +76 -117
  552. package/src/components/core/form/fields/SolidMediaMultipleField.tsx +474 -258
  553. package/src/components/core/form/fields/SolidMediaSingleField.tsx +408 -249
  554. package/src/components/core/form/fields/SolidPasswordField.tsx +112 -55
  555. package/src/components/core/form/fields/SolidRichTextField.tsx +105 -52
  556. package/src/components/core/form/fields/SolidSelectionDynamicField.tsx +138 -91
  557. package/src/components/core/form/fields/SolidSelectionStaticField.tsx +169 -37
  558. package/src/components/core/form/fields/SolidShortTextField.tsx +131 -74
  559. package/src/components/core/form/fields/SolidTimeField.tsx +85 -53
  560. package/src/components/core/form/fields/relations/SolidRelationManyToManyField.tsx +193 -30
  561. package/src/components/core/form/fields/relations/SolidRelationManyToOneField.tsx +206 -165
  562. package/src/components/core/form/fields/relations/SolidRelationOneToManyField.tsx +223 -142
  563. package/src/components/core/form/fields/widgets/SolidRelationFieldAvatarFormWidget.tsx +46 -0
  564. package/src/components/core/kanban/kanban-fields/SolidShortTextKanbanField.tsx +10 -10
  565. package/src/components/core/list/SolidListView.tsx +1 -1
  566. package/src/components/core/list/columns/SolidBooleanColumn.tsx +30 -2
  567. package/src/components/core/list/columns/SolidDateColumn.tsx +23 -8
  568. package/src/components/core/list/columns/SolidDatetimeColumn.tsx +24 -8
  569. package/src/components/core/list/columns/SolidExternalIdColumn.tsx +23 -8
  570. package/src/components/core/list/columns/SolidIdColumn.tsx +22 -7
  571. package/src/components/core/list/columns/SolidIntColumn.tsx +22 -7
  572. package/src/components/core/list/columns/SolidMediaMultipleColumn.tsx +68 -45
  573. package/src/components/core/list/columns/SolidMediaSingleColumn.tsx +48 -26
  574. package/src/components/core/list/columns/SolidRelationColumn.tsx +7 -0
  575. package/src/components/core/list/columns/SolidSelectionDynamicColumn.tsx +22 -7
  576. package/src/components/core/list/columns/SolidSelectionStaticColumn.tsx +24 -9
  577. package/src/components/core/list/columns/SolidShortTextColumn.tsx +26 -39
  578. package/src/components/core/list/columns/SolidTimeColumn.tsx +22 -7
  579. package/src/components/core/list/columns/SolidUuidColumn.tsx +22 -7
  580. package/src/components/core/list/columns/relations/SolidRelationManyToManyColumn.tsx +110 -0
  581. package/src/components/core/list/columns/relations/SolidRelationManyToOneColumn.tsx +43 -19
  582. package/src/components/core/list/columns/relations/SolidRelationOneToManyColumn.tsx +111 -0
  583. package/src/components/core/list/widgets/SolidRelationAvatarWidget.tsx +89 -0
  584. package/src/components/core/list/widgets/SolidShortTextAvatarWidget.tsx +59 -0
  585. package/src/components/core/list/widgets/SolidShortTextFieldImageRenderModeWidget.tsx +5 -3
  586. package/src/components/core/model/FieldMetaDataForm.tsx +1 -1
  587. package/src/components/core/users/CreateUser.tsx +173 -171
  588. package/src/helpers/getRandomColors.tsx +68 -0
  589. package/src/helpers/registry.ts +90 -38
  590. package/src/index.ts +1 -0
  591. package/src/redux/api/solidChatterMessageApi.ts +30 -0
  592. package/src/redux/api/solidSettingsApi.tsx +8 -0
  593. package/src/resources/globals.css +59 -0
  594. package/src/types/solid-core.d.ts +24 -16
  595. package/src/components/core/form/fields/relations/widgets/SolidRelationManyToManyAutocompleteWidget.tsx +0 -74
  596. package/src/components/core/form/fields/relations/widgets/SolidRelationManyToManyCheckboxWidget.tsx +0 -103
  597. package/src/components/core/form/fields/widgets/SolidBooleanCheckboxFieldWidget.tsx +0 -79
  598. package/src/components/core/form/fields/widgets/SolidBooleanSelectFieldWidget.tsx +0 -68
  599. package/src/components/core/form/fields/widgets/SolidFormFieldJsonViewModeWidget.tsx +0 -23
  600. package/src/components/core/form/fields/widgets/SolidFormFieldMediaViewModeWidget.tsx +0 -13
  601. package/src/components/core/form/fields/widgets/SolidFormFieldPasswordViewModeWidget.tsx +0 -23
  602. package/src/components/core/form/fields/widgets/SolidFormFieldRelationViewModeWidget.tsx +0 -32
  603. package/src/components/core/form/fields/widgets/SolidFormFieldRichTextViewModeWidget.tsx +0 -17
  604. package/src/components/core/form/fields/widgets/SolidFormFieldViewMediaMultipleWidget.tsx +0 -174
  605. package/src/components/core/form/fields/widgets/SolidFormFieldViewMediaSingleWidget.tsx +0 -115
  606. package/src/components/core/form/fields/widgets/SolidFormFieldViewModeWidget.tsx +0 -11
  607. package/src/components/core/form/fields/widgets/SolidSelectionStaticAutocompleteFieldWidget.tsx +0 -72
  608. package/src/components/core/form/fields/widgets/SolidSelectionStaticRadioFieldWidget.tsx +0 -72
  609. package/src/components/core/list/widgets/SolidShortTextFieldTextRenderModeWidget.tsx +0 -11
@@ -6,6 +6,8 @@ import { Schema } from "yup";
6
6
  import { FormikObject, ISolidField, SolidFieldProps } from "./ISolidField";
7
7
  import { Password } from "primereact/password";
8
8
  import { getExtensionComponent } from "@/helpers/registry";
9
+ import { SolidFormFieldWidgetProps } from "@/types/solid-core";
10
+ import { useState } from "react";
9
11
 
10
12
  export class SolidPasswordField implements ISolidField {
11
13
 
@@ -65,66 +67,121 @@ export class SolidPasswordField implements ISolidField {
65
67
  render(formik: FormikObject) {
66
68
  const fieldMetadata = this.fieldContext.fieldMetadata;
67
69
  const fieldLayoutInfo = this.fieldContext.field;
68
- const className = fieldLayoutInfo.attrs?.className || 'field col-12';
69
- const fieldLabel = fieldLayoutInfo.attrs.label ?? fieldMetadata.displayName;
70
- const fieldDescription = fieldLayoutInfo.attrs.description ?? fieldMetadata.description;
71
- const solidFormViewMetaData = this.fieldContext.solidFormViewMetaData;
72
- const showFieldLabel = fieldLayoutInfo?.attrs?.showLabel;
73
- const readOnlyPermission = this.fieldContext.readOnly;
74
-
75
70
  const isFormFieldValid = (formik: any, fieldName: string) => formik.touched[fieldName] && formik.errors[fieldName];
76
-
77
- const fieldDisabled = fieldLayoutInfo.attrs?.disabled;
78
- const fieldReadonly = fieldLayoutInfo.attrs?.readonly;
79
-
80
- const formDisabled = solidFormViewMetaData.data.solidView?.layout?.attrs?.disabled;
81
- const formReadonly = solidFormViewMetaData.data.solidView?.layout?.attrs?.readonly;
82
-
83
- const viewMode: string = this.fieldContext.viewMode;
84
- let DynamicWidget = getExtensionComponent("SolidFormFieldPasswordViewModeWidget");
85
- const widgetProps = {
86
- label: fieldLabel,
87
- value: formik.values[fieldLayoutInfo.attrs.name],
71
+ const className = fieldLayoutInfo.attrs?.className || 'field col-12';
72
+ let viewWidget = fieldLayoutInfo.attrs.viewWidget;
73
+ let editWidget = fieldLayoutInfo.attrs.editWidget;
74
+ if (!editWidget) {
75
+ editWidget = 'DefaultPasswordFormEditWidget';
76
+ }
77
+ if (!viewWidget) {
78
+ viewWidget = 'DefaultPasswordFormViewWidget';
88
79
  }
80
+ const viewMode: string = this.fieldContext.viewMode;
81
+
89
82
  return (
90
83
  <>
91
- {viewMode === "view" &&
92
- <div className={className}>
93
- {DynamicWidget && <DynamicWidget {...widgetProps} />}
94
- </div>
95
- }
96
- {viewMode === "edit" &&
97
- (
98
- <div className={className}>
99
- <div className="relative">
100
- <div className="flex flex-column gap-2 mt-4">
101
- {showFieldLabel != false &&
102
- <label htmlFor={fieldLayoutInfo.attrs.name} className="form-field-label">
103
- {fieldLabel}
104
- {fieldMetadata.required && <span className="text-red-500"> *</span>}
105
- </label>
106
- }
107
- <Password
108
- id={fieldLayoutInfo.attrs.name}
109
- name={fieldMetadata.name}
110
- value={formik.values[fieldLayoutInfo.attrs.name] || ''}
111
- onChange={(e) => this.fieldContext.onChange(e, 'onFieldChange')}
112
- onBlur={(e) => this.fieldContext.onBlur(e, 'onFieldBlur')}
113
- readOnly={formReadonly || fieldReadonly || readOnlyPermission}
114
- disabled={formDisabled || fieldDisabled}
115
- toggleMask
116
- />
117
-
84
+ <div className={className}>
85
+ {viewMode === "view" &&
86
+ this.renderExtensionRenderMode(viewWidget, formik)
87
+ }
88
+ {viewMode === "edit" &&
89
+ <>
90
+ {editWidget &&
91
+ this.renderExtensionRenderMode(editWidget, formik)
92
+ }
93
+ {isFormFieldValid(formik, fieldLayoutInfo.attrs.name) && (
94
+ <div className="absolute mt-1">
95
+ <Message severity="error" text={formik?.errors[fieldLayoutInfo.attrs.name]?.toString()} />
118
96
  </div>
119
- {isFormFieldValid(formik, fieldLayoutInfo.attrs.name) && (
120
- <div className="absolute mt-1">
121
- <Message severity="error" text={formik?.errors[fieldLayoutInfo.attrs.name]?.toString()} />
122
- </div>
123
- )}
124
- </div>
125
- </div>
126
- )}
97
+ )}
98
+ </>
99
+ }
100
+ </div>
127
101
  </>
128
102
  );
129
103
  }
130
- }
104
+
105
+ renderExtensionRenderMode(widget: string, formik: FormikObject) {
106
+ let DynamicWidget = getExtensionComponent(widget);
107
+ const widgetProps: SolidFormFieldWidgetProps = {
108
+ formik: formik,
109
+ fieldContext: this.fieldContext,
110
+ }
111
+ return (
112
+ <>
113
+ {DynamicWidget && <DynamicWidget {...widgetProps} />}
114
+ </>
115
+ )
116
+ }
117
+ }
118
+
119
+ export const DefaultPasswordFormEditWidget = ({ formik, fieldContext }: SolidFormFieldWidgetProps) => {
120
+ const fieldMetadata = fieldContext.fieldMetadata;
121
+ const fieldLayoutInfo = fieldContext.field;
122
+ const className = fieldLayoutInfo.attrs?.className || 'field col-12';
123
+ const fieldLabel = fieldLayoutInfo.attrs.label ?? fieldMetadata.displayName;
124
+ const fieldDescription = fieldLayoutInfo.attrs.description ?? fieldMetadata.description;
125
+ const solidFormViewMetaData = fieldContext.solidFormViewMetaData;
126
+ const showFieldLabel = fieldLayoutInfo?.attrs?.showLabel;
127
+ const readOnlyPermission = fieldContext.readOnly;
128
+
129
+ const isFormFieldValid = (formik: any, fieldName: string) => formik.touched[fieldName] && formik.errors[fieldName];
130
+
131
+ const fieldDisabled = fieldLayoutInfo.attrs?.disabled;
132
+ const fieldReadonly = fieldLayoutInfo.attrs?.readonly;
133
+
134
+ const formDisabled = solidFormViewMetaData.data.solidView?.layout?.attrs?.disabled;
135
+ const formReadonly = solidFormViewMetaData.data.solidView?.layout?.attrs?.readonly;
136
+
137
+
138
+ return (
139
+ <div className="relative">
140
+ <div className="flex flex-column gap-2 mt-4">
141
+ {showFieldLabel != false &&
142
+ <label htmlFor={fieldLayoutInfo.attrs.name} className="form-field-label">
143
+ {fieldLabel}
144
+ {fieldMetadata.required && <span className="text-red-500"> *</span>}
145
+ </label>
146
+ }
147
+ <Password
148
+ id={fieldLayoutInfo.attrs.name}
149
+ name={fieldMetadata.name}
150
+ value={formik.values[fieldLayoutInfo.attrs.name] || ''}
151
+ onChange={(e) => fieldContext.onChange(e, 'onFieldChange')}
152
+ onBlur={(e) => fieldContext.onBlur(e, 'onFieldBlur')}
153
+ readOnly={formReadonly || fieldReadonly || readOnlyPermission}
154
+ disabled={formDisabled || fieldDisabled}
155
+ toggleMask
156
+ />
157
+
158
+ </div>
159
+ </div>
160
+ );
161
+ }
162
+
163
+ export const DefaultPasswordFormViewWidget = ({ formik, fieldContext }: SolidFormFieldWidgetProps) => {
164
+ const fieldMetadata = fieldContext.fieldMetadata;
165
+ const fieldLayoutInfo = fieldContext.field;
166
+ const fieldLabel = fieldLayoutInfo.attrs.label ?? fieldMetadata.displayName;
167
+
168
+ const [isText, setIsText] = useState(false)
169
+ return (
170
+ <div className="mt-2 flex-column gap-2">
171
+ <p className="m-0 form-field-label font-medium">{fieldLabel}</p>
172
+ <div className="flex align-items-center gap-4">
173
+ <p className="m-0">
174
+ {isText ? formik.values[fieldLayoutInfo.attrs.name] : "••••••••"}
175
+ </p>
176
+ <i
177
+ className={`pi ${isText ? 'pi-eye' : 'pi-eye-slash'}`}
178
+ onClick={() => setIsText(!isText)}
179
+ style={{ cursor: 'pointer' }}
180
+ />
181
+ </div>
182
+
183
+ </div>
184
+ );
185
+ }
186
+
187
+
@@ -6,6 +6,7 @@ import * as Yup from 'yup';
6
6
  import { Schema } from "yup";
7
7
  import { FormikObject, ISolidField, SolidFieldProps } from "./ISolidField";
8
8
  import { getExtensionComponent } from "@/helpers/registry";
9
+ import { SolidFormFieldWidgetProps } from "@/types/solid-core";
9
10
 
10
11
  export class SolidRichTextField implements ISolidField {
11
12
 
@@ -58,67 +59,119 @@ export class SolidRichTextField implements ISolidField {
58
59
  render(formik: FormikObject) {
59
60
  const fieldMetadata = this.fieldContext.fieldMetadata;
60
61
  const fieldLayoutInfo = this.fieldContext.field;
62
+ const isFormFieldValid = (formik: any, fieldName: string) => formik.touched[fieldName] && formik.errors[fieldName];
61
63
  const className = fieldLayoutInfo.attrs?.className || 'field col-12';
62
- const fieldLabel = fieldLayoutInfo.attrs.label ?? fieldMetadata.displayName;
63
- const fieldDescription = fieldLayoutInfo.attrs.description ?? fieldMetadata.description;
64
- const solidFormViewMetaData = this.fieldContext.solidFormViewMetaData;
65
- const showFieldLabel = fieldLayoutInfo?.attrs?.showLabel;
66
- const readOnlyPermission = this.fieldContext.readOnly;
67
64
 
68
- const [text, setText] = useState();
69
-
70
- const isFormFieldValid = (formik: any, fieldName: string) => formik.touched[fieldName] && formik.errors[fieldName];
71
65
 
72
- const fieldDisabled = fieldLayoutInfo.attrs?.disabled;
73
- const fieldReadonly = fieldLayoutInfo.attrs?.readonly;
66
+ let viewWidget = fieldLayoutInfo.attrs.viewWidget;
67
+ let editWidget = fieldLayoutInfo.attrs.editWidget;
68
+ if (!editWidget) {
69
+ editWidget = 'DefaultRichTextFormEditWidget';
70
+ }
71
+ if (!viewWidget) {
72
+ viewWidget = 'DefaultRichTextFormViewWidget';
73
+ }
74
+ const viewMode: string = this.fieldContext.viewMode;
74
75
 
75
- const formDisabled = solidFormViewMetaData.data.solidView?.layout?.attrs?.disabled;
76
- const formReadonly = solidFormViewMetaData.data.solidView?.layout?.attrs?.readonly;
77
76
 
78
- const viewMode: string = this.fieldContext.viewMode;
79
- let DynamicWidget = getExtensionComponent("SolidFormFieldRichTextViewModeWidget");
80
- const widgetProps = {
81
- label: fieldLabel,
82
- value: formik.values[fieldLayoutInfo.attrs.name],
83
- }
84
77
  return (
85
78
  <>
86
- {viewMode === "view" &&
87
- <div className={className}>
88
- {DynamicWidget && <DynamicWidget {...widgetProps} />}
89
- </div>
90
- }
91
- {viewMode === "edit" &&
92
- (
93
- <div className={className}>
94
- <div className="relative">
95
- <div className="flex flex-column gap-2 mt-4">
96
- {showFieldLabel != false &&
97
- <label htmlFor={fieldLayoutInfo.attrs.name} className="form-field-label">{fieldLabel}
98
- {fieldMetadata.required && <span className="text-red-500"> *</span>}
99
- {/* &nbsp; {fieldDescription && <span className="form_field_help">({fieldDescription}) </span>} */}
100
- </label>
101
- }
102
- <Editor
103
- readOnly={formReadonly || fieldReadonly || readOnlyPermission}
104
- disabled={formDisabled || fieldDisabled}
105
- key={fieldLayoutInfo.attrs.name} // React will re-render the component whenever this value changes
106
- id={fieldLayoutInfo.attrs.name}
107
- value={formik.values[fieldLayoutInfo.attrs.name]}
108
- onTextChange={e => formik.setFieldValue(fieldLayoutInfo.attrs.name, e.htmlValue)}
109
- style={{ height: "320px" }}
110
- className="solid-custom-editor"
111
- />
79
+ <div className={className}>
80
+ {viewMode === "view" &&
81
+ this.renderExtensionRenderMode(viewWidget, formik)
82
+ }
83
+ {viewMode === "edit" &&
84
+ <>
85
+ {editWidget &&
86
+ this.renderExtensionRenderMode(editWidget, formik)
87
+ }
88
+ {isFormFieldValid(formik, fieldLayoutInfo.attrs.name) && (
89
+ <div className="absolute mt-1">
90
+ <Message severity="error" text={formik?.errors[fieldLayoutInfo.attrs.name]?.toString()} />
112
91
  </div>
113
- {isFormFieldValid(formik, fieldLayoutInfo.attrs.name) && (
114
- <div className="absolute mt-1">
115
- <Message severity="error" text={formik?.errors[fieldLayoutInfo.attrs.name]?.toString()} />
116
- </div>
117
- )}
118
- </div>
119
- </div>
120
- )}
92
+ )}
93
+ </>
94
+ }
95
+ </div>
121
96
  </>
122
97
  );
123
98
  }
99
+
100
+ renderExtensionRenderMode(widget: string, formik: FormikObject) {
101
+ let DynamicWidget = getExtensionComponent(widget);
102
+ const widgetProps: SolidFormFieldWidgetProps = {
103
+ formik: formik,
104
+ fieldContext: this.fieldContext,
105
+ }
106
+ return (
107
+ <>
108
+ {DynamicWidget && <DynamicWidget {...widgetProps} />}
109
+ </>
110
+ )
111
+ }
112
+ }
113
+
114
+
115
+
116
+ export const DefaultRichTextFormEditWidget = ({ formik, fieldContext }: SolidFormFieldWidgetProps) => {
117
+ const fieldMetadata = fieldContext.fieldMetadata;
118
+ const fieldLayoutInfo = fieldContext.field;
119
+ const className = fieldLayoutInfo.attrs?.className || 'field col-12';
120
+ const fieldLabel = fieldLayoutInfo.attrs.label ?? fieldMetadata.displayName;
121
+ const fieldDescription = fieldLayoutInfo.attrs.description ?? fieldMetadata.description;
122
+ const solidFormViewMetaData = fieldContext.solidFormViewMetaData;
123
+ const showFieldLabel = fieldLayoutInfo?.attrs?.showLabel;
124
+ const readOnlyPermission = fieldContext.readOnly;
125
+
126
+ const isFormFieldValid = (formik: any, fieldName: string) => formik.touched[fieldName] && formik.errors[fieldName];
127
+
128
+ const fieldDisabled = fieldLayoutInfo.attrs?.disabled;
129
+ const fieldReadonly = fieldLayoutInfo.attrs?.readonly;
130
+
131
+ const formDisabled = solidFormViewMetaData.data.solidView?.layout?.attrs?.disabled;
132
+ const formReadonly = solidFormViewMetaData.data.solidView?.layout?.attrs?.readonly;
133
+
134
+
135
+ return (
136
+ <div className="relative">
137
+ <div className="flex flex-column gap-2 mt-4">
138
+ {showFieldLabel != false &&
139
+ <label htmlFor={fieldLayoutInfo.attrs.name} className="form-field-label">{fieldLabel}
140
+ {fieldMetadata.required && <span className="text-red-500"> *</span>}
141
+ {/* &nbsp; {fieldDescription && <span className="form_field_help">({fieldDescription}) </span>} */}
142
+ </label>
143
+ }
144
+ <Editor
145
+ readOnly={formReadonly || fieldReadonly || readOnlyPermission}
146
+ disabled={formDisabled || fieldDisabled}
147
+ key={fieldLayoutInfo.attrs.name} // React will re-render the component whenever this value changes
148
+ id={fieldLayoutInfo.attrs.name}
149
+ value={formik.values[fieldLayoutInfo.attrs.name]}
150
+ onTextChange={e => formik.setFieldValue(fieldLayoutInfo.attrs.name, e.htmlValue)}
151
+ style={{ height: "320px" }}
152
+ className="solid-custom-editor"
153
+ />
154
+ </div>
155
+ </div>
156
+ );
157
+ }
158
+
159
+ export const DefaultRichTextFormViewWidget = ({ formik, fieldContext }: SolidFormFieldWidgetProps) => {
160
+ const fieldMetadata = fieldContext.fieldMetadata;
161
+ const fieldLayoutInfo = fieldContext.field;
162
+ const fieldLabel = fieldLayoutInfo.attrs.label ?? fieldMetadata.displayName;
163
+
164
+ const [isText, setIsText] = useState(false)
165
+ return (
166
+ <div>
167
+ <Editor
168
+ readOnly={true}
169
+ key={fieldLabel} // React will re-render the component whenever this value changes
170
+ id={fieldLabel}
171
+ value={formik.values[fieldLayoutInfo.attrs.name]}
172
+ style={{ height: "320px" }}
173
+ className="solid-custom-editor"
174
+ />
175
+ </div>
176
+ );
124
177
  }
@@ -8,6 +8,7 @@ import * as Yup from 'yup';
8
8
  import { Schema } from "yup";
9
9
  import { FormikObject, ISolidField, SolidFieldProps } from "./ISolidField";
10
10
  import { getExtensionComponent } from "@/helpers/registry";
11
+ import { SolidFormFieldWidgetProps } from "@/types/solid-core";
11
12
 
12
13
 
13
14
  export class SolidSelectionDynamicField implements ISolidField {
@@ -53,105 +54,151 @@ export class SolidSelectionDynamicField implements ISolidField {
53
54
  const fieldMetadata = this.fieldContext.fieldMetadata;
54
55
  const fieldLayoutInfo = this.fieldContext.field;
55
56
  const className = fieldLayoutInfo.attrs?.className || 'field col-12';
56
- const fieldLabel = fieldLayoutInfo.attrs.label ?? fieldMetadata.displayName;
57
- const fieldDescription = fieldLayoutInfo.attrs.description ?? fieldMetadata.description;
58
- const solidFormViewMetaData = this.fieldContext.solidFormViewMetaData;
59
- const showFieldLabel = fieldLayoutInfo?.attrs?.showLabel;
60
- const readOnlyPermission = this.fieldContext.readOnly;
61
-
62
- const fieldDisabled = fieldLayoutInfo.attrs?.disabled;
63
- const fieldReadonly = fieldLayoutInfo.attrs?.readonly;
64
-
65
- const formDisabled = solidFormViewMetaData.data.solidView?.layout?.attrs?.disabled;
66
- const formReadonly = solidFormViewMetaData.data.solidView?.layout?.attrs?.readonly;
67
- const whereClause = fieldLayoutInfo.attrs.whereClause;
68
-
69
- // selection dynamic specific code.
70
- const [triggerGetSelectionDynamicValues] = useLazyGetSelectionDynamicValuesQuery();
71
- const [selectionDynamicItems, setSelectionDynamicItems] = useState([]);
72
- const selectionDynamicSearch = async (event: AutoCompleteCompleteEvent) => {
73
-
74
- // Get the list view layout & metadata first.
75
- const queryData = {
76
- offset: 0,
77
- limit: 10,
78
- query: event.query,
79
- fieldId: fieldMetadata.id
80
- };
81
- if (whereClause) {
82
- queryData.query = whereClause;
83
- }
84
- let sdQs = qs.stringify(queryData, {
85
- encodeValuesOnly: true,
86
- encoder: (str, defaultEncoder, charset, type) => {
87
- if (type === 'key' || type === 'value') {
88
- if (str === queryData.query) return str;
89
- }
90
- return defaultEncoder(str);
91
- }
92
- });
93
- // TODO: do error handling here, possible errors like modelname is incorrect etc...
94
- const sdResponse = await triggerGetSelectionDynamicValues(sdQs);
95
-
96
- // TODO: if no data found then can we show no matching "entities", where entities can be replaced with the model plural name,
97
- const sdData = sdResponse.data.data;
98
-
99
- // @ts-ignore
100
- setSelectionDynamicItems(sdData);
101
- }
102
57
 
103
58
  const isFormFieldValid = (formik: any, fieldName: string) => formik.touched[fieldName] && formik.errors[fieldName];
104
59
 
105
- const viewMode: string = this.fieldContext.viewMode;
106
- let DynamicWidget = getExtensionComponent("SolidFormFieldViewModeWidget");
107
- const widgetProps = {
108
- label: fieldLabel,
109
- value: formik.values[fieldLayoutInfo.attrs.name] && formik.values[fieldLayoutInfo.attrs.name].value,
60
+ let viewWidget = fieldLayoutInfo.attrs.viewWidget;
61
+ let editWidget = fieldLayoutInfo.attrs.editWidget;
62
+ if (!editWidget) {
63
+ editWidget = 'DefaultSelectionDynamicFormEditWidget';
64
+ }
65
+ if (!viewWidget) {
66
+ viewWidget = 'DefaultSelectionDynamicFormViewWidget';
110
67
  }
68
+ const viewMode: string = this.fieldContext.viewMode;
111
69
  return (
112
70
  <>
113
- {viewMode === "view" &&
114
- <div className={className}>
115
- {DynamicWidget && <DynamicWidget {...widgetProps} />}
116
- </div>
117
- }
118
- {viewMode === "edit" &&
119
- (
120
-
121
- <div className={className}>
122
- <div className="relative">
123
- <div className="flex flex-column gap-2 mt-4">
124
- {showFieldLabel != false &&
125
- <label htmlFor={fieldLayoutInfo.attrs.name} className="form-field-label">{fieldLabel}
126
- {fieldMetadata.required && <span className="text-red-500"> *</span>}
127
- {/* &nbsp; {fieldDescription && <span className="form_field_help">({fieldDescription}) </span>} */}
128
- </label>
129
- }
130
- <AutoComplete
131
- readOnly={formReadonly || fieldReadonly || readOnlyPermission}
132
- disabled={formDisabled || fieldDisabled}
133
- {...formik.getFieldProps(fieldLayoutInfo.attrs.name)}
134
- id={fieldLayoutInfo.attrs.name}
135
- field="label"
136
- value={formik.values[fieldLayoutInfo.attrs.name] || ''}
137
- dropdown
138
- suggestions={selectionDynamicItems}
139
- completeMethod={selectionDynamicSearch}
140
- // onChange={(e) => updateInputs(index, e.value)} />
141
- // onChange={formik.handleChange}
142
- onChange={(e) => this.fieldContext.onChange(e, 'onFieldChange')}
143
- className="solid-standard-autocomplete"
144
- />
71
+ <div className={className}>
72
+ {viewMode === "view" &&
73
+ this.renderExtensionRenderMode(viewWidget, formik)
74
+ }
75
+ {viewMode === "edit" &&
76
+ <>
77
+ {editWidget &&
78
+ this.renderExtensionRenderMode(editWidget, formik)
79
+ }
80
+ {isFormFieldValid(formik, fieldLayoutInfo.attrs.name) && (
81
+ <div className="absolute mt-1">
82
+ <Message severity="error" text={formik?.errors[fieldLayoutInfo.attrs.name]?.toString()} />
145
83
  </div>
146
- {isFormFieldValid(formik, fieldLayoutInfo.attrs.name) && (
147
- <div className="absolute mt-1">
148
- <Message severity="error" text={formik?.errors[fieldLayoutInfo.attrs.name]?.toString()} />
149
- </div>
150
- )}
151
- </div>
152
- </div>
153
- )}
84
+ )}
85
+ </>
86
+ }
87
+ </div>
154
88
  </>
155
89
  );
156
90
  }
91
+ renderExtensionRenderMode(widget: string, formik: FormikObject) {
92
+ let DynamicWidget = getExtensionComponent(widget);
93
+ const widgetProps: SolidFormFieldWidgetProps = {
94
+ formik: formik,
95
+ fieldContext: this.fieldContext,
96
+ }
97
+ return (
98
+ <>
99
+ {DynamicWidget && <DynamicWidget {...widgetProps} />}
100
+ </>
101
+ )
102
+ }
157
103
  }
104
+
105
+
106
+
107
+
108
+ export const DefaultSelectionDynamicFormEditWidget = ({ formik, fieldContext }: SolidFormFieldWidgetProps) => {
109
+ const fieldMetadata = fieldContext.fieldMetadata;
110
+ const fieldLayoutInfo = fieldContext.field;
111
+ const className = fieldLayoutInfo.attrs?.className || 'field col-12';
112
+ const fieldLabel = fieldLayoutInfo.attrs.label ?? fieldMetadata.displayName;
113
+ const fieldDescription = fieldLayoutInfo.attrs.description ?? fieldMetadata.description;
114
+ const solidFormViewMetaData = fieldContext.solidFormViewMetaData;
115
+ const showFieldLabel = fieldLayoutInfo?.attrs?.showLabel;
116
+ const readOnlyPermission = fieldContext.readOnly;
117
+
118
+ const fieldDisabled = fieldLayoutInfo.attrs?.disabled;
119
+ const fieldReadonly = fieldLayoutInfo.attrs?.readonly;
120
+
121
+ const formDisabled = solidFormViewMetaData.data.solidView?.layout?.attrs?.disabled;
122
+ const formReadonly = solidFormViewMetaData.data.solidView?.layout?.attrs?.readonly;
123
+ const whereClause = fieldLayoutInfo.attrs.whereClause;
124
+
125
+ // selection dynamic specific code.
126
+ const [triggerGetSelectionDynamicValues] = useLazyGetSelectionDynamicValuesQuery();
127
+ const [selectionDynamicItems, setSelectionDynamicItems] = useState([]);
128
+ const selectionDynamicSearch = async (event: AutoCompleteCompleteEvent) => {
129
+
130
+ // Get the list view layout & metadata first.
131
+ const queryData = {
132
+ offset: 0,
133
+ limit: 10,
134
+ query: event.query,
135
+ fieldId: fieldMetadata.id
136
+ };
137
+ if (whereClause) {
138
+ queryData.query = whereClause;
139
+ }
140
+ let sdQs = qs.stringify(queryData, {
141
+ encodeValuesOnly: true,
142
+ encoder: (str, defaultEncoder, charset, type) => {
143
+ if (type === 'key' || type === 'value') {
144
+ if (str === queryData.query) return str;
145
+ }
146
+ return defaultEncoder(str);
147
+ }
148
+ });
149
+ // TODO: do error handling here, possible errors like modelname is incorrect etc...
150
+ const sdResponse = await triggerGetSelectionDynamicValues(sdQs);
151
+
152
+ // TODO: if no data found then can we show no matching "entities", where entities can be replaced with the model plural name,
153
+ const sdData = sdResponse.data.data;
154
+
155
+ // @ts-ignore
156
+ setSelectionDynamicItems(sdData);
157
+ }
158
+
159
+
160
+ return (
161
+ <div className="relative">
162
+ <div className="flex flex-column gap-2 mt-4">
163
+ {showFieldLabel != false &&
164
+ <label htmlFor={fieldLayoutInfo.attrs.name} className="form-field-label">{fieldLabel}
165
+ {fieldMetadata.required && <span className="text-red-500"> *</span>}
166
+ {/* &nbsp; {fieldDescription && <span className="form_field_help">({fieldDescription}) </span>} */}
167
+ </label>
168
+ }
169
+ <AutoComplete
170
+ readOnly={formReadonly || fieldReadonly || readOnlyPermission}
171
+ disabled={formDisabled || fieldDisabled}
172
+ {...formik.getFieldProps(fieldLayoutInfo.attrs.name)}
173
+ id={fieldLayoutInfo.attrs.name}
174
+ field="label"
175
+ value={formik.values[fieldLayoutInfo.attrs.name] || ''}
176
+ dropdown
177
+ suggestions={selectionDynamicItems}
178
+ completeMethod={selectionDynamicSearch}
179
+ // onChange={(e) => updateInputs(index, e.value)} />
180
+ // onChange={formik.handleChange}
181
+ onChange={(e) => fieldContext.onChange(e, 'onFieldChange')}
182
+ className="solid-standard-autocomplete"
183
+ />
184
+ </div>
185
+ </div>
186
+ );
187
+ }
188
+
189
+
190
+ export const DefaultSelectionDynamicFormViewWidget = ({ formik, fieldContext }: SolidFormFieldWidgetProps) => {
191
+
192
+ const fieldMetadata = fieldContext.fieldMetadata;
193
+ const fieldLayoutInfo = fieldContext.field;
194
+ const fieldLabel = fieldLayoutInfo.attrs.label ?? fieldMetadata.displayName;
195
+ const value =formik.values[fieldLayoutInfo.attrs.name];
196
+
197
+ return (
198
+ <div className="mt-2 flex-column gap-2">
199
+ <p className="m-0 form-field-label font-medium">{fieldLabel}</p>
200
+ <p className="m-0">{value && value.label && value.label}</p>
201
+ </div>
202
+ );
203
+ }
204
+