@solidstarters/solid-core-ui 1.1.211 → 1.1.212

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 (373) hide show
  1. package/dist/components/Svg/DevDocs.tsx +9 -0
  2. package/dist/components/Svg/DocsSvg.tsx +9 -0
  3. package/dist/components/Svg/ExcelSvg.tsx +15 -0
  4. package/dist/components/Svg/FieldSvg.tsx +9 -0
  5. package/dist/components/Svg/FileSvg.tsx +18 -0
  6. package/dist/components/Svg/HomePageModuleSvg.tsx +179 -0
  7. package/dist/components/Svg/ModelSvg.tsx +9 -0
  8. package/dist/components/Svg/ModuleSvg.tsx +9 -0
  9. package/dist/components/Svg/PDFSvg.tsx +15 -0
  10. package/dist/components/Svg/RightArrowSvg.tsx +9 -0
  11. package/dist/components/Svg/SettingsSvg.tsx +9 -0
  12. package/dist/components/auth/AuthLayout.tsx +223 -0
  13. package/dist/components/auth/ForgotPasswordThankYou.tsx +33 -0
  14. package/dist/components/auth/GoogleAuthChecking.tsx +63 -0
  15. package/dist/components/auth/SolidChangeForcePassword.tsx +222 -0
  16. package/dist/components/auth/SolidForgotPassword.tsx +127 -0
  17. package/dist/components/auth/SolidInitialLoginOtp.tsx +271 -0
  18. package/dist/components/auth/SolidInitiateRegisterOtp.tsx +218 -0
  19. package/dist/components/auth/SolidLogin.d.ts.map +1 -1
  20. package/dist/components/auth/SolidLogin.js +14 -8
  21. package/dist/components/auth/SolidLogin.js.map +1 -1
  22. package/dist/components/auth/SolidLogin.tsx +428 -0
  23. package/dist/components/auth/SolidOTPVerify.tsx +133 -0
  24. package/dist/components/auth/SolidRegister.tsx +454 -0
  25. package/dist/components/auth/SolidResetPassword.tsx +194 -0
  26. package/dist/components/common/AuthBanner.tsx +41 -0
  27. package/dist/components/common/AutoCompleteField.tsx +79 -0
  28. package/dist/components/common/BackButton.tsx +72 -0
  29. package/dist/components/common/CancelButton.tsx +61 -0
  30. package/dist/components/common/CodeEditor.tsx +38 -0
  31. package/dist/components/common/CreateButton.tsx +17 -0
  32. package/dist/components/common/DownloadProgressToast.tsx +55 -0
  33. package/dist/components/common/DropzonePlaceholder.tsx +31 -0
  34. package/dist/components/common/DropzoneUpload.tsx +11 -0
  35. package/dist/components/common/FileReaderExt.tsx +20 -0
  36. package/dist/components/common/GeneralSettings.tsx +1225 -0
  37. package/dist/components/common/HeaderDynamicTitles.tsx +13 -0
  38. package/dist/components/common/MarkdownViewer.tsx +84 -0
  39. package/dist/components/common/MultipleSelectAutoCompleteField.tsx +64 -0
  40. package/dist/components/common/NotFound.tsx +22 -0
  41. package/dist/components/common/SingleSelectAutoCompleteField.tsx +73 -0
  42. package/dist/components/common/SocialMediaLogin.tsx +53 -0
  43. package/dist/components/common/SolidAdmin.tsx +6 -0
  44. package/dist/components/common/SolidBreadcrumb.tsx +129 -0
  45. package/dist/components/common/SolidExport.tsx +563 -0
  46. package/dist/components/common/SolidExportStepper.tsx +135 -0
  47. package/dist/components/common/SolidFieldTooltip.tsx +23 -0
  48. package/dist/components/common/SolidFormHeader.tsx +25 -0
  49. package/dist/components/common/SolidFormStepper.tsx +350 -0
  50. package/dist/components/common/SolidModuleHome.tsx +128 -0
  51. package/dist/components/common/SolidPopupContainer.tsx +37 -0
  52. package/dist/components/common/SolidSettings/LlmSettings/AnthropicProviderComponent.tsx +45 -0
  53. package/dist/components/common/SolidSettings/LlmSettings/OpenAiProviderComponent.tsx +45 -0
  54. package/dist/components/common/SolidSettings/SettingDropzoneActivePlaceholder.tsx +20 -0
  55. package/dist/components/common/SolidSettings/SettingsImageRemoveButton.tsx +15 -0
  56. package/dist/components/common/SolidSettings/SolidUploadedImage.tsx +16 -0
  57. package/dist/components/common/SolidThemeLink.tsx +6 -0
  58. package/dist/components/common/SolidThemeProvider.tsx +44 -0
  59. package/dist/components/common/StepperArrows/ActiveArrowStep.tsx +18 -0
  60. package/dist/components/common/StepperArrows/ActiveBeforeStepArrow.tsx +18 -0
  61. package/dist/components/common/StepperArrows/InactiveStepArrow.tsx +19 -0
  62. package/dist/components/common/error.tsx +30 -0
  63. package/dist/components/common/useHandleFormCustomButtonClick.ts +40 -0
  64. package/dist/components/common/useHandleListCustomButtonClick.ts +42 -0
  65. package/dist/components/core/chatter/SolidChatter.tsx +248 -0
  66. package/dist/components/core/chatter/SolidChatterAuditMessage.tsx +35 -0
  67. package/dist/components/core/chatter/SolidChatterCustomMessage.tsx +46 -0
  68. package/dist/components/core/chatter/SolidChatterDateDivider.tsx +16 -0
  69. package/dist/components/core/chatter/SolidChatterHeader.tsx +218 -0
  70. package/dist/components/core/chatter/SolidChatterMessageBox.tsx +163 -0
  71. package/dist/components/core/chatter/SolidMessageComposer.tsx +146 -0
  72. package/dist/components/core/common/AvatarWidget.tsx +55 -0
  73. package/dist/components/core/common/DateFieldViewComponent.tsx +36 -0
  74. package/dist/components/core/common/FilterComponent.tsx +458 -0
  75. package/dist/components/core/common/LoadDynamicJsxComponent.tsx +70 -0
  76. package/dist/components/core/common/PDFViewer.tsx +117 -0
  77. package/dist/components/core/common/SolidAccountSettings/SolidAccountSettings.tsx +89 -0
  78. package/dist/components/core/common/SolidAccountSettings/SolidChangePassword.tsx +188 -0
  79. package/dist/components/core/common/SolidAccountSettings/SolidNotifications.tsx +139 -0
  80. package/dist/components/core/common/SolidAccountSettings/SolidPersonalInfo.tsx +311 -0
  81. package/dist/components/core/common/SolidCreateButton.tsx +48 -0
  82. package/dist/components/core/common/SolidGenericImport/DocumentSvg.tsx +15 -0
  83. package/dist/components/core/common/SolidGenericImport/SolidGenericImport.tsx +64 -0
  84. package/dist/components/core/common/SolidGenericImport/SolidImportDropzone.tsx +125 -0
  85. package/dist/components/core/common/SolidGenericImport/SolidImportInstructions.tsx +122 -0
  86. package/dist/components/core/common/SolidGenericImport/SolidImportStepper.tsx +217 -0
  87. package/dist/components/core/common/SolidGenericImport/SolidImportTransaction.tsx +205 -0
  88. package/dist/components/core/common/SolidGenericImport/SolidImportTransactionStatus.tsx +158 -0
  89. package/dist/components/core/common/SolidGenericImport/SolidImportWrapper.tsx +29 -0
  90. package/dist/components/core/common/SolidGlobalSearchElement.tsx +1470 -0
  91. package/dist/components/core/common/SolidLayoutViews.tsx +87 -0
  92. package/dist/components/core/common/SolidListViewOptions.tsx +31 -0
  93. package/dist/components/core/common/SolidLoaders/SolidCircularLoader.tsx +7 -0
  94. package/dist/components/core/common/SolidPasswordHelperText.tsx +34 -0
  95. package/dist/components/core/common/SolidSaveCustomFilterForm.tsx +75 -0
  96. package/dist/components/core/common/SolidSearchBox.tsx +17 -0
  97. package/dist/components/core/common/SolidViewLayoutManager.ts +421 -0
  98. package/dist/components/core/common/SolidXAiIframe.tsx +77 -0
  99. package/dist/components/core/dashboard/SolidDashboard.tsx +332 -0
  100. package/dist/components/core/dashboard/SolidDashboardBody.tsx +117 -0
  101. package/dist/components/core/dashboard/SolidDashboardFilterRequired.tsx +28 -0
  102. package/dist/components/core/dashboard/SolidDashboardHeader.tsx +10 -0
  103. package/dist/components/core/dashboard/SolidDashboardLoading.tsx +55 -0
  104. package/dist/components/core/dashboard/SolidDashboardNotAvailable.tsx +32 -0
  105. package/dist/components/core/dashboard/SolidDashboardRenderError.tsx +29 -0
  106. package/dist/components/core/dashboard/SolidDashboardVariable.tsx +256 -0
  107. package/dist/components/core/dashboard/SolidQuestionRenderer.tsx +78 -0
  108. package/dist/components/core/dashboard/chart-renderers/ChartJsRenderer.tsx +18 -0
  109. package/dist/components/core/dashboard/chart-renderers/PrimeReactDatatableRenderer.tsx +54 -0
  110. package/dist/components/core/dashboard/chart-renderers/init-chartjs.ts +25 -0
  111. package/dist/components/core/dashboard/dashboard-utils.ts +39 -0
  112. package/dist/components/core/extension/solid-core/CustomIcon/StatusIcon.tsx +17 -0
  113. package/dist/components/core/extension/solid-core/dashboardQuestion/ChartFormPreviewWidget.tsx +36 -0
  114. package/dist/components/core/extension/solid-core/emailTemplate/emailFormTypeChangeHandler.ts +18 -0
  115. package/dist/components/core/extension/solid-core/emailTemplate/emailFormTypeLoad.ts +18 -0
  116. package/dist/components/core/extension/solid-core/modelMetadata/list/DeleteModelRowAction.tsx +114 -0
  117. package/dist/components/core/extension/solid-core/modelMetadata/list/GenerateModelCodeRowAction.tsx +213 -0
  118. package/dist/components/core/extension/solid-core/moduleMetadata/list/DeleteModuleRowAction.tsx +138 -0
  119. package/dist/components/core/extension/solid-core/moduleMetadata/list/GenerateModuleCodeRowAction.tsx +209 -0
  120. package/dist/components/core/extension/solid-core/roleMetadata/RolePermissionsManyToManyFieldWidget.tsx +131 -0
  121. package/dist/components/core/field/FieldListViewData.tsx +313 -0
  122. package/dist/components/core/filter/SolidBooleanFilterElement.tsx +30 -0
  123. package/dist/components/core/filter/SolidFilterFields.tsx +131 -0
  124. package/dist/components/core/filter/SolidManyToManyFilterElement.tsx +64 -0
  125. package/dist/components/core/filter/SolidManyToOneFilterElement.tsx +61 -0
  126. package/dist/components/core/filter/SolidSelectionDynamicFilterElement.tsx +50 -0
  127. package/dist/components/core/filter/SolidSelectionStaticFilterElement.tsx +32 -0
  128. package/dist/components/core/filter/SolidVarInputsFilterElement.tsx +209 -0
  129. package/dist/components/core/filter/fields/SolidBigintField.tsx +9 -0
  130. package/dist/components/core/filter/fields/SolidBooleanField.tsx +68 -0
  131. package/dist/components/core/filter/fields/SolidComputedField.tsx +23 -0
  132. package/dist/components/core/filter/fields/SolidDateField.tsx +63 -0
  133. package/dist/components/core/filter/fields/SolidDatetimeField.tsx +54 -0
  134. package/dist/components/core/filter/fields/SolidDecimalField.tsx +9 -0
  135. package/dist/components/core/filter/fields/SolidExternalIdField.tsx +52 -0
  136. package/dist/components/core/filter/fields/SolidFloatField.tsx +9 -0
  137. package/dist/components/core/filter/fields/SolidIdField.tsx +46 -0
  138. package/dist/components/core/filter/fields/SolidIntField.tsx +61 -0
  139. package/dist/components/core/filter/fields/SolidLongTextField.tsx +9 -0
  140. package/dist/components/core/filter/fields/SolidMediaMultipleField.tsx +60 -0
  141. package/dist/components/core/filter/fields/SolidMediaSingleField.tsx +62 -0
  142. package/dist/components/core/filter/fields/SolidRelationField.tsx +17 -0
  143. package/dist/components/core/filter/fields/SolidRichTextField.tsx +9 -0
  144. package/dist/components/core/filter/fields/SolidSelectionDynamicField.tsx +52 -0
  145. package/dist/components/core/filter/fields/SolidSelectionStaticField.tsx +54 -0
  146. package/dist/components/core/filter/fields/SolidShortTextField.tsx +60 -0
  147. package/dist/components/core/filter/fields/SolidTimeField.tsx +48 -0
  148. package/dist/components/core/filter/fields/SolidUuidField.tsx +51 -0
  149. package/dist/components/core/filter/fields/relations/SolidRelationManyToManyField.tsx +62 -0
  150. package/dist/components/core/filter/fields/relations/SolidRelationManyToOneField.tsx +84 -0
  151. package/dist/components/core/form/SolidFormActionHeader.tsx +497 -0
  152. package/dist/components/core/form/SolidFormFieldRender.tsx +53 -0
  153. package/dist/components/core/form/SolidFormFieldRenderExtension.tsx +26 -0
  154. package/dist/components/core/form/SolidFormFooter.tsx +162 -0
  155. package/dist/components/core/form/SolidFormLayouts.tsx +104 -0
  156. package/dist/components/core/form/SolidFormUserViewLayout.tsx +84 -0
  157. package/dist/components/core/form/SolidFormView.tsx +1856 -0
  158. package/dist/components/core/form/SolidFormViewContextMenuHeaderButton.tsx +52 -0
  159. package/dist/components/core/form/SolidFormViewNormalHeaderButton.tsx +52 -0
  160. package/dist/components/core/form/SolidFormViewShimmerLoading.tsx +109 -0
  161. package/dist/components/core/form/fields/ISolidField.tsx +71 -0
  162. package/dist/components/core/form/fields/SolidBooleanField.tsx +434 -0
  163. package/dist/components/core/form/fields/SolidDateField.tsx +247 -0
  164. package/dist/components/core/form/fields/SolidDateTimeField.tsx +229 -0
  165. package/dist/components/core/form/fields/SolidDecimalField.tsx +171 -0
  166. package/dist/components/core/form/fields/SolidEmailField.tsx +176 -0
  167. package/dist/components/core/form/fields/SolidIntegerField.tsx +282 -0
  168. package/dist/components/core/form/fields/SolidJsonField.tsx +185 -0
  169. package/dist/components/core/form/fields/SolidLongTextField.tsx +618 -0
  170. package/dist/components/core/form/fields/SolidMediaMultipleField.tsx +663 -0
  171. package/dist/components/core/form/fields/SolidMediaSingleField.tsx +547 -0
  172. package/dist/components/core/form/fields/SolidPasswordField.tsx +390 -0
  173. package/dist/components/core/form/fields/SolidRelationField.tsx +56 -0
  174. package/dist/components/core/form/fields/SolidRichTextField.tsx +188 -0
  175. package/dist/components/core/form/fields/SolidSelectionDynamicField.tsx +340 -0
  176. package/dist/components/core/form/fields/SolidSelectionStaticField.tsx +462 -0
  177. package/dist/components/core/form/fields/SolidShortTextField.tsx +399 -0
  178. package/dist/components/core/form/fields/SolidTimeField.tsx +245 -0
  179. package/dist/components/core/form/fields/relations/SolidRelationManyToManyField.tsx +453 -0
  180. package/dist/components/core/form/fields/relations/SolidRelationManyToOneField.tsx +1036 -0
  181. package/dist/components/core/form/fields/relations/SolidRelationOneToManyField.tsx +627 -0
  182. package/dist/components/core/form/fields/relations/widgets/helpers/InlineRelationEntityDialog.tsx +38 -0
  183. package/dist/components/core/form/fields/relations/widgets/helpers/useRelationEntityHandler.ts +64 -0
  184. package/dist/components/core/form/fields/widgets/SolidAiInteractionMessageFieldFormWidget.tsx +135 -0
  185. package/dist/components/core/form/fields/widgets/SolidAiInteractionMetadataFieldFormWidget.tsx +144 -0
  186. package/dist/components/core/form/fields/widgets/SolidIconEditWidget.tsx +265 -0
  187. package/dist/components/core/form/fields/widgets/SolidIconViewWidget.tsx +32 -0
  188. package/dist/components/core/form/fields/widgets/SolidRelationFieldAvatarFormWidget.tsx +50 -0
  189. package/dist/components/core/form/fields/widgets/SolidS3FileViewerWidget.tsx +222 -0
  190. package/dist/components/core/form/fields/widgets/SolidShortTextFieldAvatarWidget.tsx +70 -0
  191. package/dist/components/core/form/widgets/CustomHtml.tsx +20 -0
  192. package/dist/components/core/kanban/KanbanBoard.tsx +150 -0
  193. package/dist/components/core/kanban/KanbanCard.tsx +279 -0
  194. package/dist/components/core/kanban/KanbanColumn.tsx +139 -0
  195. package/dist/components/core/kanban/KanbanUserViewLayout.tsx +84 -0
  196. package/dist/components/core/kanban/SolidKanbanView.tsx +894 -0
  197. package/dist/components/core/kanban/SolidKanbanViewConfigure.tsx +154 -0
  198. package/dist/components/core/kanban/SolidKanbanViewFields.tsx +164 -0
  199. package/dist/components/core/kanban/SolidManyToOneFilterElement.tsx +59 -0
  200. package/dist/components/core/kanban/SolidSelectionDynamicFilterElement.tsx +50 -0
  201. package/dist/components/core/kanban/SolidSelectionStaticFilterElement.tsx +32 -0
  202. package/dist/components/core/kanban/SolidVarInputsFilterElement.tsx +184 -0
  203. package/dist/components/core/kanban/kanban-fields/SolidBigintKanbanField.tsx +9 -0
  204. package/dist/components/core/kanban/kanban-fields/SolidBooleanKanbanField.tsx +16 -0
  205. package/dist/components/core/kanban/kanban-fields/SolidComputedKanbanField.tsx +23 -0
  206. package/dist/components/core/kanban/kanban-fields/SolidDateKanbanField.tsx +14 -0
  207. package/dist/components/core/kanban/kanban-fields/SolidDatetimeKanbanField.tsx +13 -0
  208. package/dist/components/core/kanban/kanban-fields/SolidDecimalKanbanField.tsx +9 -0
  209. package/dist/components/core/kanban/kanban-fields/SolidExternalIdKanbanField.tsx +12 -0
  210. package/dist/components/core/kanban/kanban-fields/SolidFloatKanbanField.tsx +9 -0
  211. package/dist/components/core/kanban/kanban-fields/SolidIdKanbanField.tsx +14 -0
  212. package/dist/components/core/kanban/kanban-fields/SolidIntKanbanField.tsx +20 -0
  213. package/dist/components/core/kanban/kanban-fields/SolidLongTextKanbanField.tsx +9 -0
  214. package/dist/components/core/kanban/kanban-fields/SolidMediaMultipleKanbanField.tsx +140 -0
  215. package/dist/components/core/kanban/kanban-fields/SolidMediaSingleKanbanField.tsx +164 -0
  216. package/dist/components/core/kanban/kanban-fields/SolidRelationKanbanField.tsx +13 -0
  217. package/dist/components/core/kanban/kanban-fields/SolidRichTextKanbanField.tsx +9 -0
  218. package/dist/components/core/kanban/kanban-fields/SolidSelectionDynamicKanbanField.tsx +14 -0
  219. package/dist/components/core/kanban/kanban-fields/SolidSelectionStaticKanbanField.tsx +14 -0
  220. package/dist/components/core/kanban/kanban-fields/SolidShortTextKanbanField.tsx +121 -0
  221. package/dist/components/core/kanban/kanban-fields/SolidTimeKanbanField.tsx +12 -0
  222. package/dist/components/core/kanban/kanban-fields/SolidUuidKanbanField.tsx +13 -0
  223. package/dist/components/core/kanban/kanban-fields/relations/SolidRelationManyToOneKanbanField.tsx +16 -0
  224. package/dist/components/core/list/ListViewRowActionPopup.tsx +41 -0
  225. package/dist/components/core/list/SolidColumnSelector/SolidListColumnSelector.tsx +242 -0
  226. package/dist/components/core/list/SolidEmptyListViewPlaceholder.tsx +111 -0
  227. package/dist/components/core/list/SolidListView.tsx +2007 -0
  228. package/dist/components/core/list/SolidListViewColumn.tsx +165 -0
  229. package/dist/components/core/list/SolidListViewConfigure.tsx +339 -0
  230. package/dist/components/core/list/SolidListViewHeaderButton.tsx +31 -0
  231. package/dist/components/core/list/SolidListViewHeaderContextMenuButton.tsx +30 -0
  232. package/dist/components/core/list/SolidListViewRowButtonContextMenu.tsx +41 -0
  233. package/dist/components/core/list/SolidListViewShimmerLoading.tsx +78 -0
  234. package/dist/components/core/list/SolidListingHeader.tsx +42 -0
  235. package/dist/components/core/list/SolidManyToOneFilterElement.tsx +60 -0
  236. package/dist/components/core/list/SolidSelectionDynamicFilterElement.tsx +50 -0
  237. package/dist/components/core/list/SolidSelectionStaticFilterElement.tsx +32 -0
  238. package/dist/components/core/list/SolidTableRowCell.tsx +35 -0
  239. package/dist/components/core/list/SolidVarInputsFilterElement.tsx +184 -0
  240. package/dist/components/core/list/columns/SolidBigintColumn.tsx +9 -0
  241. package/dist/components/core/list/columns/SolidBooleanColumn.tsx +90 -0
  242. package/dist/components/core/list/columns/SolidComputedColumn.tsx +27 -0
  243. package/dist/components/core/list/columns/SolidDateColumn.tsx +90 -0
  244. package/dist/components/core/list/columns/SolidDatetimeColumn.tsx +79 -0
  245. package/dist/components/core/list/columns/SolidDecimalColumn.tsx +9 -0
  246. package/dist/components/core/list/columns/SolidExternalIdColumn.tsx +80 -0
  247. package/dist/components/core/list/columns/SolidFloatColumn.tsx +9 -0
  248. package/dist/components/core/list/columns/SolidIdColumn.tsx +79 -0
  249. package/dist/components/core/list/columns/SolidIntColumn.tsx +87 -0
  250. package/dist/components/core/list/columns/SolidLongTextColumn.tsx +9 -0
  251. package/dist/components/core/list/columns/SolidMediaMultipleColumn.tsx +301 -0
  252. package/dist/components/core/list/columns/SolidMediaSingleColumn.tsx +170 -0
  253. package/dist/components/core/list/columns/SolidRelationColumn.tsx +21 -0
  254. package/dist/components/core/list/columns/SolidRichTextColumn.tsx +9 -0
  255. package/dist/components/core/list/columns/SolidSelectionDynamicColumn.tsx +80 -0
  256. package/dist/components/core/list/columns/SolidSelectionStaticColumn.tsx +81 -0
  257. package/dist/components/core/list/columns/SolidShortTextColumn.tsx +160 -0
  258. package/dist/components/core/list/columns/SolidTimeColumn.tsx +78 -0
  259. package/dist/components/core/list/columns/SolidUuidColumn.tsx +79 -0
  260. package/dist/components/core/list/columns/relations/SolidRelationManyToManyColumn.tsx +106 -0
  261. package/dist/components/core/list/columns/relations/SolidRelationManyToOneColumn.tsx +117 -0
  262. package/dist/components/core/list/columns/relations/SolidRelationOneToManyColumn.tsx +110 -0
  263. package/dist/components/core/list/widgets/SolidManyToManyRelationAvatarListWidget.tsx +30 -0
  264. package/dist/components/core/list/widgets/SolidManyToOneRelationAvatarListWidget.tsx +30 -0
  265. package/dist/components/core/list/widgets/SolidShortTextAvatarWidget.tsx +70 -0
  266. package/dist/components/core/list/widgets/SolidShortTextFieldImageRenderModeWidget.tsx +21 -0
  267. package/dist/components/core/locales/SolidChatterLocaleTabView.tsx +91 -0
  268. package/dist/components/core/locales/SolidLocale.tsx +127 -0
  269. package/dist/components/core/model/CreateModel.tsx +495 -0
  270. package/dist/components/core/model/FieldMetaData.tsx +263 -0
  271. package/dist/components/core/model/FieldMetaDataForm.tsx +3509 -0
  272. package/dist/components/core/model/FieldSelector.tsx +62 -0
  273. package/dist/components/core/model/ModelListViewData.tsx +384 -0
  274. package/dist/components/core/model/ModelMetaData.tsx +921 -0
  275. package/dist/components/core/module/CreateModule.tsx +617 -0
  276. package/dist/components/core/module/ModuleListViewData.tsx +431 -0
  277. package/dist/components/core/solid-ai/SolidAiMainWrapper.tsx +8 -0
  278. package/dist/components/core/solid-ai/SolidXAIIcon.tsx +37 -0
  279. package/dist/components/core/users/CreateUser.tsx +467 -0
  280. package/dist/components/core/users/CreateUserRole.tsx +212 -0
  281. package/dist/components/core/users/UserListView.tsx +376 -0
  282. package/dist/components/layout/AdminLayout.tsx +57 -0
  283. package/dist/components/layout/AdminSidebar.tsx +65 -0
  284. package/dist/components/layout/AppConfig.tsx +104 -0
  285. package/dist/components/layout/AppSidebar.tsx +232 -0
  286. package/dist/components/layout/ButtonLoader.tsx +7 -0
  287. package/dist/components/layout/CustomPagination.tsx +55 -0
  288. package/dist/components/layout/DashboardHeader.tsx +89 -0
  289. package/dist/components/layout/FilterMenu.tsx +122 -0
  290. package/dist/components/layout/Footer.tsx +13 -0
  291. package/dist/components/layout/GlobalSearch.tsx +37 -0
  292. package/dist/components/layout/Header.tsx +8 -0
  293. package/dist/components/layout/Layout.tsx +205 -0
  294. package/dist/components/layout/ListingHeader.tsx +204 -0
  295. package/dist/components/layout/Loader.tsx +16 -0
  296. package/dist/components/layout/UserSidebar.tsx +53 -0
  297. package/dist/components/layout/context/layoutcontext.tsx +52 -0
  298. package/dist/components/layout/navbar-one.tsx +258 -0
  299. package/dist/components/layout/navbar-two-menu.tsx +72 -0
  300. package/dist/components/layout/navbar-two.tsx +37 -0
  301. package/dist/components/layout/user-profile-menu.tsx +213 -0
  302. package/dist/components/layout/user-profile.tsx +7 -0
  303. package/dist/components/modelsComponents/filterIcon.tsx +9 -0
  304. package/dist/constants/error-messages.ts +238 -0
  305. package/dist/declarations.d.ts +22 -0
  306. package/dist/helpers/AppTitle.tsx +12 -0
  307. package/dist/helpers/ToastContainer.tsx +94 -0
  308. package/dist/helpers/autoCompleteVirtualScroll.ts +41 -0
  309. package/dist/helpers/countries.tsx +260 -0
  310. package/dist/helpers/downloadFileWithProgress.ts +91 -0
  311. package/dist/helpers/downloadMediaFile.tsx +21 -0
  312. package/dist/helpers/getAcceptedFileTypes.tsx +22 -0
  313. package/dist/helpers/getRandomColors.tsx +68 -0
  314. package/dist/helpers/helpers.ts +61 -0
  315. package/dist/helpers/hydrateRelationRules.ts +120 -0
  316. package/dist/helpers/permissions.ts +7 -0
  317. package/dist/helpers/registry.ts +337 -0
  318. package/dist/helpers/resendOtpHelper.tsx +5 -0
  319. package/dist/helpers/revalidate.ts +7 -0
  320. package/dist/helpers/rolesHelper.ts +17 -0
  321. package/dist/helpers/solidIcons.tsx +1831 -0
  322. package/dist/helpers/updatePasswordField.ts +41 -0
  323. package/dist/index.ts +421 -0
  324. package/dist/nextAuth/authProviders.d.ts.map +1 -1
  325. package/dist/nextAuth/authProviders.js +6 -5
  326. package/dist/nextAuth/authProviders.js.map +1 -1
  327. package/dist/nextAuth/authProviders.tsx +232 -0
  328. package/dist/nextAuth/handleLogout.tsx +39 -0
  329. package/dist/nextAuth/refreshAccessToken.tsx +28 -0
  330. package/dist/redux/api/aiInteractionApi.ts +59 -0
  331. package/dist/redux/api/authApi.ts +131 -0
  332. package/dist/redux/api/dashboardApi.ts +56 -0
  333. package/dist/redux/api/dashboardQuestionApi.ts +17 -0
  334. package/dist/redux/api/exportTemplateApi.tsx +59 -0
  335. package/dist/redux/api/fetchBaseQuery.tsx +118 -0
  336. package/dist/redux/api/fieldApi.ts +86 -0
  337. package/dist/redux/api/importTransactionApi.tsx +69 -0
  338. package/dist/redux/api/mediaApi.ts +55 -0
  339. package/dist/redux/api/mediaStorageProviderApi.ts +55 -0
  340. package/dist/redux/api/modelApi.ts +80 -0
  341. package/dist/redux/api/moduleApi.ts +72 -0
  342. package/dist/redux/api/permissionApi.ts +32 -0
  343. package/dist/redux/api/pincodeApi.tsx +56 -0
  344. package/dist/redux/api/roleApi.ts +58 -0
  345. package/dist/redux/api/solidActionApi.ts +66 -0
  346. package/dist/redux/api/solidChatterMessageApi.ts +25 -0
  347. package/dist/redux/api/solidEntityApi.tsx +164 -0
  348. package/dist/redux/api/solidMenuApi.ts +71 -0
  349. package/dist/redux/api/solidServiceApi.ts +31 -0
  350. package/dist/redux/api/solidSettingsApi.tsx +83 -0
  351. package/dist/redux/api/solidViewApi.ts +73 -0
  352. package/dist/redux/api/stateApi.tsx +56 -0
  353. package/dist/redux/api/testApi.ts +21 -0
  354. package/dist/redux/api/userApi.ts +135 -0
  355. package/dist/redux/features/authSlice.ts +19 -0
  356. package/dist/redux/features/dataViewSlice.ts +26 -0
  357. package/dist/redux/features/navbarSlice.ts +21 -0
  358. package/dist/redux/features/popupSlice.ts +37 -0
  359. package/dist/redux/features/settingsSlice.ts +60 -0
  360. package/dist/redux/features/themeSlice.ts +17 -0
  361. package/dist/redux/features/userSlice.ts +28 -0
  362. package/dist/redux/hooks/useSolidPopup.ts +20 -0
  363. package/dist/redux/store/defaultStoreConfig.ts +62 -0
  364. package/dist/styles.ts +4 -0
  365. package/dist/types/handlebars.d.ts +4 -0
  366. package/dist/types/index.d.ts +76 -0
  367. package/dist/types/layout.d.ts +94 -0
  368. package/dist/types/next-auth.d.ts +0 -0
  369. package/dist/types/next.d.ts +46 -0
  370. package/dist/types/solid-core.d.ts +320 -0
  371. package/package.json +1 -1
  372. package/src/components/auth/SolidLogin.tsx +26 -13
  373. package/src/nextAuth/authProviders.tsx +9 -5
@@ -0,0 +1,618 @@
1
+ 'use client';
2
+ import { InputTextarea } from "primereact/inputtextarea";
3
+ import { Message } from "primereact/message";
4
+ import * as Yup from 'yup';
5
+ import { FormikObject, ISolidField, SolidFieldProps } from "./ISolidField";
6
+ // import { Editor } from "primereact/editor";
7
+ import { useEffect, useRef, useState } from "react";
8
+ import { getExtensionComponent } from "../../../../helpers/registry";
9
+ import { SolidFormFieldWidgetProps } from "../../../../types/solid-core";
10
+ import { SolidFieldTooltip } from "../../../../components/common/SolidFieldTooltip";
11
+ import Editor from '@monaco-editor/react';
12
+ import { Calendar } from "primereact/calendar";
13
+ import { Dropdown } from "primereact/dropdown";
14
+ import { InputText } from "primereact/inputtext";
15
+ import { Button } from "primereact/button";
16
+ import { ERROR_MESSAGES } from "../../../../constants/error-messages";
17
+
18
+
19
+ export class SolidLongTextField implements ISolidField {
20
+
21
+ private fieldContext: SolidFieldProps;
22
+
23
+ constructor(fieldContext: SolidFieldProps) {
24
+ this.fieldContext = fieldContext;
25
+ }
26
+
27
+ updateFormData(value: any, formData: FormData): any {
28
+ const fieldLayoutInfo = this.fieldContext.field;
29
+ if (value !== undefined && value !== null) {
30
+ formData.append(fieldLayoutInfo.attrs.name, value);
31
+ }
32
+ }
33
+
34
+ initialValue(): any {
35
+ const fieldName = this.fieldContext.field.attrs.name;
36
+ const fieldDefaultValue = this.fieldContext?.fieldMetadata?.defaultValue;
37
+
38
+ const existingValue = this.fieldContext.data[fieldName];
39
+
40
+ return existingValue !== undefined && existingValue !== null ? existingValue : fieldDefaultValue || '';
41
+ }
42
+
43
+ validationSchema(): Yup.Schema {
44
+ let schema: Yup.StringSchema<string | null | undefined> = Yup.string();
45
+
46
+ const fieldMetadata = this.fieldContext.fieldMetadata;
47
+ const fieldLayoutInfo = this.fieldContext.field;
48
+ const fieldLabel = fieldLayoutInfo.attrs.label ?? fieldMetadata.displayName;
49
+
50
+ // 1. required
51
+ if (fieldMetadata.required) {
52
+ schema = schema.required(ERROR_MESSAGES.FIELD_REUQIRED(fieldLabel));
53
+ } else {
54
+ schema = schema.nullable(); // Allow null when not required
55
+ }
56
+ // 2. length (min/max)
57
+ if (fieldMetadata.min && fieldMetadata.min > 0) {
58
+ schema = schema.min(fieldMetadata.min, ERROR_MESSAGES.FIELD_MINIMUM_CHARACTER(fieldLabel,fieldMetadata.min));
59
+ }
60
+ if (fieldMetadata.max && fieldMetadata.max > 0) {
61
+ schema = schema.max(fieldMetadata.max, ERROR_MESSAGES.FIELD_MAXIMUM_CHARACTER(fieldLabel,fieldMetadata.max));
62
+ }
63
+ // 3. regular expression
64
+ if (fieldMetadata.regexPattern) {
65
+ const regexPatternNotMatchingErrorMsg = fieldMetadata.regexPatternNotMatchingErrorMsg ?? `${fieldLabel} has invalid data.`
66
+ schema = schema.matches(fieldMetadata.regexPattern, regexPatternNotMatchingErrorMsg);
67
+ }
68
+
69
+ return schema;
70
+ }
71
+
72
+ render(formik: FormikObject) {
73
+ const fieldLayoutInfo = this.fieldContext.field;
74
+ const className = fieldLayoutInfo.attrs?.className || 'field col-12';
75
+ const isFormFieldValid = (formik: any, fieldName: string) => formik.touched[fieldName] && formik.errors[fieldName];
76
+
77
+ let viewWidget = fieldLayoutInfo.attrs.viewWidget;
78
+ let editWidget = fieldLayoutInfo.attrs.editWidget;
79
+ if (!editWidget) {
80
+ editWidget = 'DefaultLongTextFormEditWidget';
81
+ }
82
+ if (!viewWidget) {
83
+ viewWidget = 'DefaultShortTextFormViewWidget';
84
+ }
85
+ const viewMode: string = this.fieldContext.viewMode;
86
+
87
+ return (
88
+ <>
89
+ <div className={className}>
90
+
91
+ {viewMode === "view" &&
92
+ this.renderExtensionRenderMode(viewWidget, formik)
93
+ }
94
+ {viewMode === "edit" && (
95
+ <>
96
+ {editWidget &&
97
+ this.renderExtensionRenderMode(editWidget, formik)
98
+ }
99
+ </>
100
+ )
101
+ }
102
+ </div>
103
+ </>
104
+ );
105
+ }
106
+
107
+ renderExtensionRenderMode(widget: string, formik: FormikObject) {
108
+ let DynamicWidget = getExtensionComponent(widget);
109
+ const widgetProps: SolidFormFieldWidgetProps = {
110
+ formik: formik,
111
+ fieldContext: this.fieldContext,
112
+ }
113
+ return (
114
+ <>
115
+ {DynamicWidget && <DynamicWidget {...widgetProps} />}
116
+ </>
117
+ )
118
+ }
119
+
120
+ }
121
+
122
+ export const DefaultLongTextFormEditWidget = ({ formik, fieldContext }: SolidFormFieldWidgetProps) => {
123
+
124
+ const fieldMetadata = fieldContext.fieldMetadata;
125
+ const fieldLayoutInfo = fieldContext.field;
126
+ const fieldLabel = fieldLayoutInfo.attrs.label ?? fieldMetadata.displayName;
127
+ const solidFormViewMetaData = fieldContext.solidFormViewMetaData;
128
+ const showFieldLabel = fieldLayoutInfo?.attrs?.showLabel;
129
+ const readOnlyPermission = fieldContext.readOnly;
130
+
131
+
132
+ const fieldDisabled = fieldLayoutInfo.attrs?.disabled;
133
+ const fieldReadonly = fieldLayoutInfo.attrs?.readonly;
134
+
135
+ const formDisabled = solidFormViewMetaData.data.solidView?.layout?.attrs?.disabled;
136
+ const formReadonly = solidFormViewMetaData.data.solidView?.layout?.attrs?.readonly;
137
+ const isFormFieldValid = (formik: any, fieldName: string) => formik.touched[fieldName] && formik.errors[fieldName];
138
+
139
+ return (
140
+ <div className="relative">
141
+ <div className="flex flex-column gap-2 mt-1 sm:mt-2 md:mt-3 lg:mt-4">
142
+ {showFieldLabel != false &&
143
+ <label htmlFor={fieldLayoutInfo.attrs.name} className="form-field-label">{fieldLabel}
144
+ {fieldMetadata.required && <span className="text-red-500"> *</span>}
145
+ <SolidFieldTooltip fieldContext={fieldContext} />
146
+ {/* &nbsp; {fieldDescription && <span>({fieldDescription}) </span>} */}
147
+ </label>
148
+ }
149
+ <InputTextarea
150
+ readOnly={formReadonly || fieldReadonly || readOnlyPermission}
151
+ disabled={formDisabled || fieldDisabled}
152
+ id={fieldLayoutInfo.attrs.name}
153
+ aria-describedby={`${fieldLayoutInfo.attrs.name}-help`}
154
+ // onChange={formik.handleChange}
155
+ onChange={(e) => fieldContext.onChange(e, 'onFieldChange')}
156
+ value={formik.values[fieldLayoutInfo.attrs.name] || ''}
157
+ rows={5}
158
+ cols={30}
159
+ />
160
+ </div>
161
+ {isFormFieldValid(formik, fieldLayoutInfo.attrs.name) && (
162
+ <div className="absolute mt-1">
163
+ <Message severity="error" text={formik?.errors[fieldLayoutInfo.attrs.name]?.toString()} />
164
+ </div>
165
+ )}
166
+ </div>
167
+ );
168
+ }
169
+
170
+ export const DynamicJsonEditorFormViewWidget = ({ formik, fieldContext }: SolidFormFieldWidgetProps) => {
171
+ const fieldMetadata = fieldContext.fieldMetadata;
172
+ const fieldLayoutInfo = fieldContext.field;
173
+ const fieldLabel = fieldLayoutInfo.attrs.label ?? fieldMetadata.displayName;
174
+
175
+ const readOnly = fieldLayoutInfo.attrs?.readonly || fieldContext.readOnly;
176
+ const disabled = fieldLayoutInfo.attrs?.disabled;
177
+
178
+ // Default to SQL
179
+ const language = fieldLayoutInfo.attrs.editorLanguage || 'ts';
180
+
181
+ const value = formik.values[fieldLayoutInfo.attrs.name] || '';
182
+
183
+ const isFormFieldValid = (formik: any, fieldName: string) =>
184
+ formik.touched[fieldName] && formik.errors[fieldName];
185
+
186
+ // Sample schema, this comes from the metadata...
187
+ // {
188
+ // key1: {
189
+ // required: true,
190
+ // type: "string",
191
+ // },
192
+ // key2: {
193
+ // required: true,
194
+ // type: "selectionStatic",
195
+ // allowedValues: [
196
+ // "selection static val 1",
197
+ // "selection static val 2",
198
+ // "selection static val 3",
199
+ // "selection static val 4",
200
+ // ],
201
+ // },
202
+ // };
203
+ const fieldJsonSchema = fieldLayoutInfo.attrs?.jsonSchema;
204
+ if (!fieldJsonSchema) {
205
+ return <Message severity="error" text="Field Layout Attributes are missing jsonSchema, cannot render with widget jsonEditor without specifying the schema." />
206
+ }
207
+ const [data, setData] = useState(JSON.parse(value || '[]'));
208
+
209
+ const renderInput = (value: any, key: string, index: number) => {
210
+ // @ts-ignore
211
+ const meta: any = fieldJsonSchema[key];
212
+ if (!meta) return null;
213
+
214
+ if (meta.type === "string" || meta.type === "shortText") {
215
+ return (
216
+ <InputText value={value} readOnly disabled />
217
+ );
218
+ }
219
+ if (meta.type === "longText") {
220
+ return (
221
+ <InputTextarea value={value} rows={10} cols={100} readOnly />
222
+ );
223
+ }
224
+ if (meta.type === "date" || meta.type === "datetime") {
225
+ return (
226
+ <Calendar
227
+ value={value ? new Date(value) : null}
228
+ showTime={meta.type === "datetime"}
229
+ dateFormat="yy-mm-dd"
230
+ readOnlyInput
231
+ disabled
232
+ />
233
+ );
234
+ }
235
+
236
+ if (meta.type === "selectionStatic") {
237
+ return (
238
+ <Dropdown
239
+ value={value}
240
+ // @ts-ignore
241
+ options={meta.allowedValues.map((v) => ({ label: v, value: v }))}
242
+ placeholder="Select..."
243
+ readOnly
244
+ disabled
245
+ />
246
+ );
247
+ }
248
+
249
+ return null;
250
+ };
251
+
252
+ return (
253
+ <div className="mt-4">
254
+ {fieldLayoutInfo?.attrs?.showLabel !== false && (
255
+ <label className="form-field-label mb-10">
256
+ {fieldLabel}
257
+ {fieldMetadata.required && <span className="text-red-500"> *</span>}
258
+ <SolidFieldTooltip fieldContext={fieldContext} />
259
+ </label>
260
+ )}
261
+
262
+ <div className="p-4 border-round surface-card shadow-1">
263
+
264
+ <div className="flex flex-column gap-2">
265
+ {
266
+ // @ts-ignore
267
+ data.map((row, idx) => (
268
+ <div
269
+ key={idx}
270
+ className={`flex ${fieldLayoutInfo.attrs?.className ? `flex-${fieldLayoutInfo.attrs?.className}` : 'flex-row'} border-1 border-round p-3 gap-2`}
271
+ >
272
+ {Object.keys(fieldJsonSchema).map((key) => (
273
+ <div key={key} className="flex flex-column gap-1">
274
+ <label>{key.charAt(0).toUpperCase() + key.slice(1)}</label>
275
+ {
276
+ // @ts-ignore
277
+ renderInput(row[key], key, idx)
278
+ }
279
+ </div>
280
+ ))}
281
+
282
+ </div>
283
+ ))
284
+ }
285
+ </div>
286
+
287
+ </div>
288
+ </div>
289
+ );
290
+ }
291
+
292
+ export const DynamicJsonEditorFormEditWidget = ({ formik, fieldContext }: SolidFormFieldWidgetProps) => {
293
+ const fieldMetadata = fieldContext.fieldMetadata;
294
+ const fieldLayoutInfo = fieldContext.field;
295
+ const fieldLabel = fieldLayoutInfo.attrs.label ?? fieldMetadata.displayName;
296
+
297
+ const readOnly = fieldLayoutInfo.attrs?.readonly || fieldContext.readOnly;
298
+ const disabled = fieldLayoutInfo.attrs?.disabled;
299
+
300
+ // Default to SQL
301
+ const language = fieldLayoutInfo.attrs.editorLanguage || 'ts';
302
+
303
+ const value = formik.values[fieldLayoutInfo.attrs.name] || '';
304
+
305
+ const isFormFieldValid = (formik: any, fieldName: string) =>
306
+ formik.touched[fieldName] && formik.errors[fieldName];
307
+
308
+ // Sample schema, this comes from the metadata...
309
+ // {
310
+ // key1: {
311
+ // required: true,
312
+ // type: "string",
313
+ // },
314
+ // key2: {
315
+ // required: true,
316
+ // type: "selectionStatic",
317
+ // allowedValues: [
318
+ // "selection static val 1",
319
+ // "selection static val 2",
320
+ // "selection static val 3",
321
+ // "selection static val 4",
322
+ // ],
323
+ // },
324
+ // };
325
+ const fieldJsonSchema = fieldLayoutInfo.attrs?.jsonSchema;
326
+ if (!fieldJsonSchema) {
327
+ return <Message severity="error" text="Field Layout Attributes are missing jsonSchema, cannot render with widget jsonEditor without specifying the schema." />
328
+ }
329
+ const [data, setData] = useState(JSON.parse(value || '[]'));
330
+
331
+ const handleAllChange = (updated: any) => {
332
+ setData(updated);
333
+ formik.setFieldValue(fieldLayoutInfo.attrs.name, JSON.stringify(updated));
334
+ }
335
+
336
+ const handleChange = (index: number, key: string, value: any) => {
337
+ const updated = [...data];
338
+ // @ts-ignore
339
+ updated[index][key] = value;
340
+ handleAllChange(updated);
341
+ };
342
+
343
+ const handleAdd = () => {
344
+ const newItem = {};
345
+ Object.keys(fieldJsonSchema).forEach((key) => {
346
+ // @ts-ignore
347
+ newItem[key] = "";
348
+ });
349
+ // @ts-ignore
350
+ handleAllChange([...data, newItem]);
351
+ };
352
+
353
+ const handleRemove = (index: number) => {
354
+ const updated = [...data];
355
+ updated.splice(index, 1);
356
+ handleAllChange(updated);
357
+ };
358
+
359
+ const renderInput = (value: any, key: string, index: number) => {
360
+ // @ts-ignore
361
+ const meta: any = fieldJsonSchema[key];
362
+ if (!meta) return null;
363
+
364
+ if (meta.type === "string" || meta.type === "shortText") {
365
+ return (
366
+ <InputText
367
+ value={value}
368
+ onChange={(e) => handleChange(index, key, e.target.value)}
369
+ disabled={!!disabled}
370
+ readOnly={!!readOnly}
371
+ />
372
+ );
373
+ }
374
+
375
+ if (meta.type === "longText") {
376
+ return (
377
+ <InputTextarea
378
+ onChange={(e) => handleChange(index, key, e.target.value)}
379
+ value={value}
380
+ rows={10}
381
+ cols={100}
382
+ />
383
+ );
384
+ }
385
+
386
+ if (meta.type === "date" || meta.type === "datetime") {
387
+ return (
388
+ <Calendar
389
+ value={value ? new Date(value) : null}
390
+ onChange={(e) => handleChange(index, key, e.value)}
391
+ showTime={meta.type === "datetime"}
392
+ dateFormat="yy-mm-dd"
393
+ disabled={!!disabled}
394
+ readOnlyInput={!!readOnly}
395
+ />
396
+ );
397
+ }
398
+
399
+ if (meta.type === "selectionStatic") {
400
+ return (
401
+ <Dropdown
402
+ value={value}
403
+ // @ts-ignore
404
+ options={meta.allowedValues.map((v) => ({ label: v, value: v }))}
405
+ onChange={(e) => handleChange(index, key, e.value)}
406
+ placeholder="Select..."
407
+ disabled={!!disabled}
408
+ readOnly={!!readOnly}
409
+ />
410
+ );
411
+ }
412
+
413
+ return null;
414
+ };
415
+
416
+ return (
417
+ <div className="mt-4">
418
+ {fieldLayoutInfo?.attrs?.showLabel !== false && (
419
+ <label className="form-field-label mb-10">
420
+ {fieldLabel}
421
+ {fieldMetadata.required && <span className="text-red-500"> *</span>}
422
+ <SolidFieldTooltip fieldContext={fieldContext} />
423
+ </label>
424
+ )}
425
+
426
+ <div className="p-4 border-round surface-card shadow-1">
427
+ <div className="flex justify-content-between align-items-center mb-3">
428
+ {!disabled && !readOnly ? (
429
+ <Button
430
+ type="button"
431
+ label="Add"
432
+ icon="pi pi-plus"
433
+ onClick={handleAdd}
434
+ />
435
+ ) : null}
436
+ </div>
437
+
438
+ <div className="flex flex-column gap-2">
439
+ {
440
+ // @ts-ignore
441
+ data.map((row, idx) => (
442
+ <div
443
+ key={idx}
444
+ className={`flex ${fieldLayoutInfo.attrs?.className ? `flex-${fieldLayoutInfo.attrs?.className}` : 'flex-row'} border-1 border-round p-3 gap-2`}
445
+ >
446
+ <div className="flex gap-3 align-items-center">
447
+ {Object.keys(fieldJsonSchema).map((key) => (
448
+ <div key={key} className="flex flex-column gap-1">
449
+ <label>{key.charAt(0).toUpperCase() + key.slice(1)}</label>
450
+ {
451
+ // @ts-ignore
452
+ renderInput(row[key], key, idx)
453
+ }
454
+ </div>
455
+ ))}
456
+ </div>
457
+ {!disabled && !readOnly ? (
458
+ <Button
459
+ type="button"
460
+ icon="pi pi-minus"
461
+ className="ml-2 h-2rem w-2rem rounded-circle"
462
+ onClick={() => handleRemove(idx)}
463
+ />
464
+ ) : null}
465
+ </div>
466
+ ))
467
+ }
468
+ </div>
469
+
470
+ {
471
+ fieldLayoutInfo.attrs?.jsonSchemaShowPreview &&
472
+ <pre className="mt-4 bg-gray-100 p-3 border-round overflow-auto">
473
+ {JSON.stringify(data, null, 2)}
474
+ </pre>
475
+ }
476
+ </div>
477
+ </div>
478
+ );
479
+ };
480
+
481
+ export const CodeEditorFormEditWidget = ({ formik, fieldContext }: SolidFormFieldWidgetProps) => {
482
+ const fieldMetadata = fieldContext.fieldMetadata;
483
+ const fieldLayoutInfo = fieldContext.field;
484
+ const fieldLabel = fieldLayoutInfo.attrs.label ?? fieldMetadata.displayName;
485
+
486
+ const readOnly = fieldLayoutInfo.attrs?.readonly || fieldContext.readOnly;
487
+ const disabled = fieldLayoutInfo.attrs?.disabled;
488
+
489
+ // Default to SQL
490
+ const language = fieldLayoutInfo.attrs.editorLanguage || 'ts';
491
+
492
+ const value = formik.values[fieldLayoutInfo.attrs.name] || '';
493
+
494
+ const isFormFieldValid = (formik: any, fieldName: string) =>
495
+ formik.touched[fieldName] && formik.errors[fieldName];
496
+
497
+ return (
498
+ <div className="mt-4">
499
+ {fieldLayoutInfo?.attrs?.showLabel !== false && (
500
+ <label className="form-field-label mb-10">
501
+ {fieldLabel}
502
+ {fieldMetadata.required && <span className="text-red-500"> *</span>}
503
+ <SolidFieldTooltip fieldContext={fieldContext} />
504
+ </label>
505
+ )}
506
+
507
+ <div className="border border-gray-300 rounded overflow-hidden">
508
+ <Editor
509
+ height="200px"
510
+ defaultLanguage={language}
511
+ value={value}
512
+ onChange={(val) => formik.setFieldValue(fieldLayoutInfo.attrs.name, val)}
513
+ options={{
514
+ readOnly,
515
+ minimap: { enabled: false },
516
+ lineNumbers: 'on',
517
+ fontSize: 14,
518
+ scrollBeyondLastLine: false,
519
+ }}
520
+ />
521
+ </div>
522
+
523
+ {isFormFieldValid(formik, fieldLayoutInfo.attrs.name) && (
524
+ <div className="mt-1">
525
+ <Message text={formik.errors[fieldLayoutInfo.attrs.name]?.toString()} />
526
+ </div>
527
+ )}
528
+ </div>
529
+ );
530
+ };
531
+
532
+ export const DynamicSelectionStaticEditWidget = ({
533
+ formik,
534
+ fieldContext,
535
+ }: SolidFormFieldWidgetProps) => {
536
+ const fieldLayoutInfo = fieldContext.field;
537
+ const fieldJsonSchema = fieldLayoutInfo.attrs.jsonSchema;
538
+ const name = fieldLayoutInfo.attrs.name;
539
+ const readOnly = fieldLayoutInfo.attrs?.readonly || fieldContext.readOnly;
540
+ const disabled = fieldLayoutInfo.attrs?.disabled;
541
+
542
+ const value = formik.values[name] || "{}";
543
+ const [data, setData] = useState(JSON.parse(value || "{}"));
544
+
545
+ const handleChange = (key: string, value: any) => {
546
+ const updated = { ...data, [key]: value };
547
+ setData(updated);
548
+ formik.setFieldValue(name, JSON.stringify(updated));
549
+ };
550
+
551
+ const renderInput = (key: string) => {
552
+ const meta: any = fieldJsonSchema[key];
553
+ const val = data[key];
554
+
555
+ if (meta?.type === "selectionStatic") {
556
+ return (
557
+ <Dropdown
558
+ value={val}
559
+ options={meta.allowedValues.map((v:any) => ({
560
+ label: v,
561
+ value: v,
562
+ }))}
563
+ onChange={(e) => handleChange(key, e.value)}
564
+ placeholder={meta.placeHolder || "Select..."}
565
+ disabled={!!disabled}
566
+ readOnly={!!readOnly}
567
+ className="w-full"
568
+ />
569
+ );
570
+ }
571
+
572
+ return null;
573
+ };
574
+ const shouldShowField = (key: string) => {
575
+ const meta = fieldJsonSchema[key];
576
+
577
+ if (!meta?.visibility) return true; // default show
578
+
579
+ if (meta.visibility === "parent") {
580
+ const parentKey = Object.keys(fieldJsonSchema)[0]; // assume first field is parent
581
+ return !!data[parentKey]; // show only if parent has value
582
+ }
583
+
584
+ return true;
585
+ };
586
+
587
+ return (
588
+ <div className="flex gap-3 align-items-center">
589
+ {Object.keys(fieldJsonSchema).map((key) => {
590
+ const meta: any = fieldJsonSchema[key];
591
+ if (!shouldShowField(key)) return null;
592
+ return (
593
+ <div key={key} className={"flex flex-column gap-2 " + (meta.className || '')}>
594
+ {/*load prime header icon and headerText */}
595
+ {(meta.headerText || meta.headerIcon) && (
596
+ <div className="flex align-items-center gap-2">
597
+ {meta.headerIcon && <i className={meta.headerIcon}></i>}
598
+ <span className="font-semibold form-field-label font-medium">
599
+ {meta.headerText ?? key}
600
+ </span>
601
+ </div>
602
+ )}
603
+ {/* Notes below input */}
604
+ {meta.noteText && (
605
+ <small className="text-secondary mt-2">{meta.noteText}</small>
606
+ )}
607
+ {/*load note here */}
608
+ <label className="form-field-label font-medium">{key.charAt(0).toUpperCase() + key.slice(1)} {meta.required && <span className="text-red-500">*</span>}</label>
609
+ <div className="w-full mt-1 flex flex-row gap-2">
610
+ {renderInput(key)}
611
+ </div>
612
+ </div>
613
+ );
614
+ })}
615
+ </div>
616
+ );
617
+ };
618
+