@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,376 @@
1
+ "use client";
2
+ import { useDeleteMultipleUsersMutation, useLazyGetusersQuery } from '../../../redux/api/userApi';
3
+ import Link from "next/link";
4
+ import { FilterMatchMode } from "primereact/api";
5
+ import { Button } from "primereact/button";
6
+ import { Column } from "primereact/column";
7
+ import {
8
+ DataTable,
9
+ DataTableFilterMeta,
10
+ DataTableStateEvent,
11
+ } from "primereact/datatable";
12
+ import { useEffect, useRef, useState } from "react";
13
+
14
+ import { CreateButton } from "../../../components/common/CreateButton";
15
+ import { FetchBaseQueryError } from "@reduxjs/toolkit/query";
16
+ import { Dialog } from "primereact/dialog";
17
+ import { Toast } from "primereact/toast";
18
+ import qs from "qs";
19
+ import { ERROR_MESSAGES } from '../../../constants/error-messages';
20
+
21
+ interface Users {
22
+ id: string;
23
+ fullName: string;
24
+ username: string;
25
+ email: string;
26
+ mobile: string;
27
+ // roles: string[];
28
+ }
29
+
30
+ interface ErrorResponseData {
31
+ message: string;
32
+ statusCode: number;
33
+ error: string;
34
+ }
35
+
36
+ export const UserListView = () => {
37
+ const toast = useRef<Toast>(null);
38
+ const [users, setUsers] = useState<Users[]>([]);
39
+ const [filters, setFilters] = useState<DataTableFilterMeta>({
40
+ fullName: { value: null, matchMode: FilterMatchMode.STARTS_WITH },
41
+ username: { value: null, matchMode: FilterMatchMode.STARTS_WITH },
42
+ email: { value: null, matchMode: FilterMatchMode.STARTS_WITH },
43
+ mobile: { value: null, matchMode: FilterMatchMode.STARTS_WITH },
44
+ // "roles.name": { value: null, matchMode: FilterMatchMode.STARTS_WITH },
45
+ });
46
+ const [first, setFirst] = useState(0);
47
+ const [rows, setRows] = useState(25);
48
+ const [totalRecords, setTotalRecords] = useState(0);
49
+ const [sortField, setSortField] = useState("");
50
+ const [sortOrder, setSortOrder] = useState(0);
51
+ const [selectedUsers, setSelectedUsers] = useState<Users[]>([]);
52
+ const [loading, setLoading] = useState<boolean>(true);
53
+ const [isDialogVisible, setDialogVisible] = useState(false);
54
+ const [triggerGetUser, { data: user, isLoading, error, isError }] = useLazyGetusersQuery();
55
+
56
+ const [
57
+ deleteManyUser,
58
+ {
59
+ isLoading: isUserDeleted,
60
+ isSuccess: isDeleteUserSuceess,
61
+ isError: isUserDeleteError,
62
+ error: UserDeleteError,
63
+ data: DeletedUser,
64
+ },
65
+ ] = useDeleteMultipleUsersMutation();
66
+
67
+
68
+ useEffect(() => {
69
+ if (user) {
70
+ setUsers(user?.data.records);
71
+ setTotalRecords(user?.data.meta?.totalRecords);
72
+ setLoading(false);
73
+ }
74
+ }, [user]);
75
+
76
+ // const initFilters = () => {
77
+ // setFilters(defaultFilters);
78
+ // setGlobalFilterValue('');
79
+ // };
80
+
81
+ // const clearFilter = () => {
82
+ // initFilters();
83
+ // };
84
+
85
+ useEffect(() => {
86
+ const queryData = {
87
+ offset: 0,
88
+ limit: 25,
89
+ populate: ['roles']
90
+ };
91
+ const queryString = qs.stringify(queryData, {
92
+ encodeValuesOnly: true
93
+ });
94
+ triggerGetUser(queryString);
95
+ setSelectedUsers([]);
96
+ }, [isDeleteUserSuceess]);
97
+
98
+ useEffect(() => {
99
+ if (isError || isUserDeleteError) {
100
+ setLoading(false);
101
+ let errorMessage = ERROR_MESSAGES.ERROR_OCCURED;
102
+
103
+ const errorToast = isError ? error : UserDeleteError;
104
+
105
+ if (isFetchBaseQueryErrorWithErrorResponse(errorToast)) {
106
+ errorMessage = `${errorToast.data.message}`;
107
+ } else {
108
+ errorMessage = ERROR_MESSAGES.SOMETHING_WRONG;
109
+ }
110
+
111
+ toast.current?.show({
112
+ severity: 'error',
113
+ summary: ERROR_MESSAGES.ERROR,
114
+ detail: errorMessage,
115
+ life: 3000,
116
+ //@ts-ignore
117
+ content: (props) => (
118
+ <div
119
+ className="flex flex-column align-items-left"
120
+ style={{ flex: "1" }}
121
+ >
122
+ <div className="flex align-items-center gap-2" >
123
+ <span className="font-bold text-900">{errorMessage}</span>
124
+ </div>
125
+ </div>
126
+ ),
127
+ });
128
+ }
129
+ }, [isError, isUserDeleteError]);
130
+
131
+ function isFetchBaseQueryErrorWithErrorResponse(error: any): error is FetchBaseQueryError & { data: ErrorResponseData } {
132
+ return error && typeof error === 'object' && 'data' in error && 'message' in error.data;
133
+ }
134
+
135
+ const onPageChange = (event: any) => {
136
+ setFirst(event.first);
137
+ setRows(event.rows);
138
+ setQueryString(event.first, event.rows, sortField, sortOrder, filters);
139
+ };
140
+
141
+ const onSort = (event: DataTableStateEvent) => {
142
+ const { sortField, sortOrder } = event;
143
+ const validSortOrder = sortOrder === 1 || sortOrder === -1 ? sortOrder : 0;
144
+ setSortField(sortField);
145
+ setSortOrder(validSortOrder);
146
+ setFirst(0);
147
+ setQueryString(
148
+ 0,
149
+ rows,
150
+ sortField,
151
+ sortOrder === 1 || sortOrder === -1 ? sortOrder : 0,
152
+ filters
153
+ );
154
+ };
155
+
156
+ const onSelectionChange = (event: any) => {
157
+ const value = event.value;
158
+ setSelectedUsers(value);
159
+ };
160
+
161
+ // Filter fuctions
162
+ const setQueryString = async (
163
+ offset?: number,
164
+ row?: number,
165
+ field?: string,
166
+ order?: number,
167
+ filterQuery?: any
168
+ ) => {
169
+
170
+ const formattedFilters: any = {};
171
+
172
+ Object.keys(filterQuery).forEach((field) => {
173
+ const filterValue = filterQuery[field].value;
174
+ const matchMode = filterQuery[field].matchMode;
175
+
176
+ if (filterValue !== null && filterValue !== undefined) {
177
+ let operator = matchMode;
178
+ switch (matchMode) {
179
+ case FilterMatchMode.CONTAINS:
180
+ operator = "$containsi";
181
+ break;
182
+ case FilterMatchMode.STARTS_WITH:
183
+ operator = "$startsWithi";
184
+ break;
185
+ case FilterMatchMode.EQUALS:
186
+ operator = "$eqi";
187
+ break;
188
+ case FilterMatchMode.NOT_CONTAINS:
189
+ operator = "$notContainsi";
190
+ break;
191
+ case FilterMatchMode.NOT_EQUALS:
192
+ operator = "$nei";
193
+ break;
194
+ case FilterMatchMode.ENDS_WITH:
195
+ operator = "$endsWithi";
196
+ break;
197
+ default:
198
+ operator = matchMode;
199
+ }
200
+
201
+ if (field.includes(".")) {
202
+ const fieldParts = field.split(".");
203
+ if (!formattedFilters[fieldParts[0]]) {
204
+ formattedFilters[fieldParts[0]] = {};
205
+ }
206
+ formattedFilters[fieldParts[0]][fieldParts[1]] = { [operator]: filterValue };
207
+ } else {
208
+ formattedFilters[field] = { [operator]: filterValue };
209
+ }
210
+ }
211
+ });
212
+
213
+ const queryData: any = {
214
+ offset: offset ?? first,
215
+ limit: row ?? rows,
216
+ populate: ['roles'],
217
+ filters: formattedFilters,
218
+ };
219
+
220
+ if (field) {
221
+ queryData.sort = [
222
+ `${field}:${order == 0 ? null : order == 1 ? "asc" : "desc"}`,
223
+ ];
224
+ }
225
+
226
+ const queryString = qs.stringify(queryData, {
227
+ encodeValuesOnly: true,
228
+ });
229
+
230
+ triggerGetUser(queryString);
231
+ };
232
+
233
+ const onFilter = (e: any) => {
234
+ setFilters(e.filters);
235
+ setQueryString(
236
+ 0,
237
+ rows,
238
+ sortField,
239
+ sortOrder === 1 || sortOrder === -1 ? sortOrder : 0,
240
+ e.filters
241
+ );
242
+ };
243
+
244
+ const detailsBodyTemplate = (product: Users) => {
245
+ return (
246
+ <Link
247
+ href={`${product.id}`}
248
+ rel="noopener noreferrer"
249
+ className="text-sm font-bold p-0"
250
+ style={{ color: "#12415D" }}
251
+ >
252
+ <i className="pi pi-pencil" style={{ fontSize: "1rem" }}></i>
253
+ </Link>
254
+ );
255
+ };
256
+
257
+ const deleteBulk = () => {
258
+ let deleteList: any = [];
259
+ selectedUsers.forEach((element: Users) => {
260
+ deleteList.push(element.id);
261
+ });
262
+ deleteManyUser(deleteList);
263
+ setDialogVisible(false);
264
+ };
265
+
266
+ const onDeleteClose = () => {
267
+ setDialogVisible(false);
268
+ setSelectedUsers([]);
269
+ }
270
+
271
+ return (
272
+ <div className="">
273
+ <Toast ref={toast} />
274
+ <div className="flex gap-3 mb-4">
275
+ <CreateButton />
276
+ {selectedUsers.length > 0 && <Button
277
+ type="button"
278
+ label="Delete"
279
+ size="small"
280
+ onClick={() => setDialogVisible(true)}
281
+ className="small-button"
282
+ severity="danger"
283
+ />}
284
+ </div>
285
+ <style>{`
286
+ .p-datatable .p-datatable-loading-overlay {
287
+ background-color: rgba(0, 0, 0, 0.0);
288
+ }
289
+ `}</style>
290
+ <DataTable
291
+ value={users}
292
+ lazy
293
+ tableStyle={{ minWidth: "60rem", margin: "auto" }}
294
+ size="small"
295
+ paginator
296
+ rows={rows}
297
+ rowsPerPageOptions={[10, 25, 50]}
298
+ dataKey="id"
299
+ filters={filters}
300
+ emptyMessage="No users found."
301
+ onFilter={onFilter}
302
+ filterDisplay="row"
303
+ totalRecords={totalRecords}
304
+ first={first}
305
+ onPage={onPageChange}
306
+ onSort={(e: DataTableStateEvent) => onSort(e)}
307
+ sortField={sortField}
308
+ sortOrder={sortOrder === 1 || sortOrder === -1 ? sortOrder : 0}
309
+ loading={loading || isLoading}
310
+ loadingIcon="pi pi-spinner"
311
+ selection={selectedUsers}
312
+ onSelectionChange={onSelectionChange}
313
+ selectionMode="multiple"
314
+ removableSort
315
+ >
316
+ <Column selectionMode="multiple" headerStyle={{ width: "3em" }} />
317
+ <Column field="id" header="ID" className="text-sm" sortable headerClassName="table-header-fs"></Column>
318
+ <Column
319
+ field="fullName"
320
+ header="Full Name"
321
+ className="text-sm"
322
+ sortable
323
+ filter
324
+ filterPlaceholder="Search user by full name"
325
+ style={{ minWidth: "12rem" }}
326
+ headerClassName="table-header-fs"
327
+ ></Column>
328
+ <Column
329
+ field="username"
330
+ header="Username"
331
+ className="text-sm"
332
+ sortable
333
+ filter
334
+ filterPlaceholder="Search user by username"
335
+ style={{ minWidth: "12rem" }}
336
+ headerClassName="table-header-fs"
337
+ ></Column>
338
+ <Column
339
+ field="email"
340
+ header="Email"
341
+ className="text-sm"
342
+ sortable
343
+ filter
344
+ filterPlaceholder="Search user by email"
345
+ style={{ minWidth: "12rem" }}
346
+ headerClassName="table-header-fs"
347
+ ></Column>
348
+ {/* <Column
349
+ field="roles.name"
350
+ header="Roles"
351
+ className="text-sm"
352
+ filter
353
+ filterPlaceholder="Search category by parent category"
354
+ style={{ minWidth: "12rem" }}
355
+ headerClassName="table-header-fs"
356
+ ></Column> */}
357
+ <Column body={detailsBodyTemplate}></Column>
358
+ </DataTable>
359
+ <Dialog
360
+ visible={isDialogVisible}
361
+ header="Confirm Delete"
362
+ modal
363
+ className="solid-confirm-dialog"
364
+ footer={() => (
365
+ <div className="flex justify-content-center">
366
+ <Button label="Yes" icon="pi pi-check" className='small-button' severity="danger" autoFocus onClick={deleteBulk} />
367
+ <Button label="No" icon="pi pi-times" className='small-button' onClick={onDeleteClose} />
368
+ </div>
369
+ )}
370
+ onHide={() => setDialogVisible(false)}
371
+ >
372
+ <p>Are you sure you want to delete the selected Users?</p>
373
+ </Dialog>
374
+ </div>
375
+ );
376
+ };
@@ -0,0 +1,57 @@
1
+ "use client"
2
+
3
+ import { handleError } from "../../helpers/ToastContainer";
4
+ import { signOut, useSession } from "next-auth/react";
5
+ import { useRouter } from "next/navigation";
6
+ import { useEffect, useState } from "react";
7
+ import { Layout } from "./Layout";
8
+ import { Dialog } from "primereact/dialog";
9
+ import { Divider } from "primereact/divider";
10
+ import SolidChangeForcePassword from "../auth/SolidChangeForcePassword";
11
+ import { ERROR_MESSAGES } from "../../constants/error-messages";
12
+
13
+ export const AdminLayout = ({ children }: { children: React.ReactNode }) => {
14
+ // const theme = useSelector((state: any) => state.theme.mode);
15
+ const { data: session, status } = useSession();
16
+ const [isForcePasswordChange, setIsForcePasswordChange] = useState(false)
17
+ useEffect(() => {
18
+ // @ts-expect-error: Handling potential case where 'data?.user?.user' might be undefined or null
19
+ if (session?.user?.user?.forcePasswordChange === true) {
20
+ setIsForcePasswordChange(true)
21
+ } else {
22
+ setIsForcePasswordChange(false)
23
+ }
24
+ }, [session])
25
+ // const pathname = usePathname();
26
+ const router = useRouter();
27
+ useEffect(() => {
28
+ if (status === "loading") return;
29
+ if (!session || session?.error === "RefreshAccessTokenError") {
30
+ handleError([ERROR_MESSAGES.SESSION_EXPIRED])
31
+ signOut({ callbackUrl: "/auth/login" });
32
+ }
33
+
34
+ }, [session, status])
35
+
36
+ return (
37
+ <Layout>
38
+ {/* <div className={`${process.env.NEXT_PUBLIC_ENABLE_CUSTOM_HEADER_FOOTER == "true" && 'header-margin-top'}`} style={{ minHeight: `${process.env.NEXT_PUBLIC_ENABLE_CUSTOM_HEADER_FOOTER == "true" ? 'calc(100vh - 70px)' : 'calc(100vh)'}` }}> */}
39
+
40
+ {/* <div className="min-h-full max-h-full flex flex-column relative flex-auto overflow-x-auto"> */}
41
+ {/* <DashboardHeader /> */}
42
+ {/* <SolidListingHeader></SolidListingHeader> */}
43
+ {/* {pathname.includes('all') && <ListingHeader />} */}
44
+ {/* <div className="flex flex-column flex-auto" style={{ backgroundColor: '#f6f6f9', padding: '1.5rem 1.5rem 1.5rem', }}> */}
45
+ {children}
46
+ {/* </div> */}
47
+ {/* </div> */}
48
+ {/* </div> */}
49
+ {isForcePasswordChange &&
50
+ <Dialog header="Change Default Password" className="solid-change-dialog" visible={isForcePasswordChange} closable={false} draggable={false} style={{ width: '25vw' }} onHide={() => setIsForcePasswordChange(false)}>
51
+ <Divider className="mt-0" />
52
+ <SolidChangeForcePassword />
53
+ </Dialog>
54
+ }
55
+ </Layout>
56
+ )
57
+ }
@@ -0,0 +1,65 @@
1
+ "use client";
2
+
3
+ import Link from "next/link";
4
+ import { usePathname } from "next/navigation";
5
+ import { useState } from "react";
6
+
7
+ const AdminSidebar = () => {
8
+ const pathname = usePathname();
9
+
10
+ const menuItem = [
11
+ {
12
+ name: "Dashboard",
13
+ url: "/admin/dashboard",
14
+ icon: "fas fa-tachometer-alt",
15
+ },
16
+ {
17
+ name: "Rooms",
18
+ url: "/admin/rooms",
19
+ icon: "fas fa-hotel",
20
+ },
21
+ {
22
+ name: "Bookings",
23
+ url: "/admin/bookings",
24
+ icon: "fas fa-receipt",
25
+ },
26
+ {
27
+ name: "Users",
28
+ url: "/admin/users",
29
+ icon: "fas fa-user",
30
+ },
31
+ {
32
+ name: "Reviews",
33
+ url: "/admin/reviews",
34
+ icon: "fas fa-star",
35
+ },
36
+ ];
37
+
38
+ const [activeMenuItem, setActiveMenuItem] = useState(pathname);
39
+
40
+ const handleMenuItemClick = (menuItem: string) => {
41
+ setActiveMenuItem(menuItem);
42
+ };
43
+
44
+ return (
45
+ <div className="list-group mt-5 pl-4">
46
+ {menuItem.map((menuItem, index) => (
47
+ <Link
48
+ key={index}
49
+ href={menuItem.url}
50
+ className={`fw-bold list-group-item list-group-item-action ${
51
+ activeMenuItem.includes(menuItem.url) ? "active" : ""
52
+ }`}
53
+ onClick={() => handleMenuItemClick(menuItem.url)}
54
+ aria-current={
55
+ activeMenuItem.includes(menuItem.url) ? "true" : "false"
56
+ }
57
+ >
58
+ <i className={`${menuItem.icon} fa-fw pe-2`}></i> {menuItem.name}
59
+ </Link>
60
+ ))}
61
+ </div>
62
+ );
63
+ };
64
+
65
+ export default AdminSidebar;
@@ -0,0 +1,104 @@
1
+ 'use client';
2
+
3
+ import { AppConfigProps, LayoutConfig, LayoutState } from '../../types';
4
+ import { PrimeReactContext } from 'primereact/api';
5
+ import { Button } from 'primereact/button';
6
+ import { RadioButton, RadioButtonChangeEvent } from 'primereact/radiobutton';
7
+ import { Sidebar } from 'primereact/sidebar';
8
+ import { classNames } from 'primereact/utils';
9
+ import { useContext, useEffect, useState } from 'react';
10
+ import { LayoutContext } from './context/layoutcontext';
11
+
12
+ const AppConfig = (props: AppConfigProps) => {
13
+ const [scales] = useState([12, 13, 14, 15, 16]);
14
+ const { layoutConfig, setLayoutConfig, layoutState, setLayoutState } = useContext(LayoutContext);
15
+ const { changeTheme } = useContext(PrimeReactContext);
16
+
17
+ const onConfigButtonClick = () => {
18
+ setLayoutState((prevState: LayoutState) => ({ ...prevState, configSidebarVisible: true }));
19
+ };
20
+
21
+ const onConfigSidebarHide = () => {
22
+ setLayoutState((prevState: LayoutState) => ({ ...prevState, configSidebarVisible: false }));
23
+ };
24
+
25
+ const changeInputStyle = (e: RadioButtonChangeEvent) => {
26
+ setLayoutConfig((prevState: LayoutConfig) => ({ ...prevState, inputStyle: e.value }));
27
+ };
28
+
29
+ const _changeTheme = (theme: string, colorScheme: string) => {
30
+ changeTheme?.(layoutConfig.theme, theme, 'theme-css', () => {
31
+ setLayoutConfig((prevState: LayoutConfig) => ({ ...prevState, theme, colorScheme }));
32
+ });
33
+ };
34
+
35
+ const decrementScale = () => {
36
+ setLayoutConfig((prevState: LayoutConfig) => ({ ...prevState, scale: prevState.scale - 1 }));
37
+ };
38
+
39
+ const incrementScale = () => {
40
+ setLayoutConfig((prevState: LayoutConfig) => ({ ...prevState, scale: prevState.scale + 1 }));
41
+ };
42
+
43
+ const applyScale = () => {
44
+ // document.documentElement.style.fontSize = layoutConfig.scale + 'px';
45
+ document.documentElement.style.fontSize = 15 + 'px';
46
+ };
47
+
48
+ useEffect(() => {
49
+ applyScale();
50
+ // eslint-disable-next-line react-hooks/exhaustive-deps
51
+ }, [layoutConfig.scale]);
52
+
53
+ return (
54
+ <>
55
+ {/* <button className="layout-config-button config-link" type="button" onClick={onConfigButtonClick}>
56
+ <i className="pi pi-cog"></i>
57
+ </button>
58
+
59
+ <Sidebar visible={layoutState.configSidebarVisible} onHide={onConfigSidebarHide} position="right" className="layout-config-sidebar w-20rem">
60
+ {!props.simple && (
61
+ <>
62
+ <h5>Scale</h5>
63
+ <div className="flex align-items-center">
64
+ <Button icon="pi pi-minus" type="button" onClick={decrementScale} rounded text className="w-2rem h-2rem mr-2" disabled={layoutConfig.scale === scales[0]}></Button>
65
+ <div className="flex gap-2 align-items-center">
66
+ {scales.map((item) => {
67
+ return <i className={classNames('pi pi-circle-fill', { 'text-primary-500': item === layoutConfig.scale, 'text-300': item !== layoutConfig.scale })} key={item}></i>;
68
+ })}
69
+ </div>
70
+ <Button icon="pi pi-plus" type="button" onClick={incrementScale} rounded text className="w-2rem h-2rem ml-2" disabled={layoutConfig.scale === scales[scales.length - 1]}></Button>
71
+ </div>
72
+
73
+ <h5>Input Style</h5>
74
+ <div className="flex">
75
+ <div className="field-radiobutton flex-1">
76
+ <RadioButton name="inputStyle" value={'outlined'} checked={layoutConfig.inputStyle === 'outlined'} onChange={(e) => changeInputStyle(e)} inputId="outlined_input"></RadioButton>
77
+ <label htmlFor="outlined_input">Outlined</label>
78
+ </div>
79
+ <div className="field-radiobutton flex-1">
80
+ <RadioButton name="inputStyle" value={'filled'} checked={layoutConfig.inputStyle === 'filled'} onChange={(e) => changeInputStyle(e)} inputId="filled_input"></RadioButton>
81
+ <label htmlFor="filled_input">Filled</label>
82
+ </div>
83
+ </div>
84
+ </>
85
+ )}
86
+ <h5>Appearance</h5>
87
+ <div className="grid">
88
+ <div className="col-3">
89
+ <button className="p-link w-2rem h-2rem" onClick={() => _changeTheme('solid-light-purple', 'light')}>
90
+ <img src="/images/layout/images/themes/lara-light-blue.png" className="w-2rem h-2rem" alt="Lara Light Blue" />
91
+ </button>
92
+ </div>
93
+ <div className="col-3">
94
+ <button className="p-link w-2rem h-2rem" onClick={() => _changeTheme('solid-dark-purple', 'dark')}>
95
+ <img src="/images/layout/images/themes/lara-dark-blue.png" className="w-2rem h-2rem" alt="Lara Dark Cyan" />
96
+ </button>
97
+ </div>
98
+ </div>
99
+ </Sidebar> */}
100
+ </>
101
+ );
102
+ };
103
+
104
+ export default AppConfig;