@rchemist/listgrid 0.2.6

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 (592) hide show
  1. package/LICENSE +201 -0
  2. package/README.md +343 -0
  3. package/dist/adapters/next/NextListGridProvider.d.ts +5 -0
  4. package/dist/adapters/next/NextListGridProvider.js +7 -0
  5. package/dist/adapters/next/NextRouterAdapter.d.ts +2 -0
  6. package/dist/adapters/next/NextRouterAdapter.js +34 -0
  7. package/dist/adapters/next/NextUrlStateAdapter.d.ts +2 -0
  8. package/dist/adapters/next/NextUrlStateAdapter.js +31 -0
  9. package/dist/adapters/next/index.d.ts +4 -0
  10. package/dist/adapters/next/index.js +12 -0
  11. package/dist/index.d.ts +1 -0
  12. package/dist/index.js +3 -0
  13. package/dist/listgrid/api/ApiClient.d.ts +20 -0
  14. package/dist/listgrid/api/ApiClient.js +32 -0
  15. package/dist/listgrid/api/index.d.ts +4 -0
  16. package/dist/listgrid/api/index.js +2 -0
  17. package/dist/listgrid/api/types.d.ts +21 -0
  18. package/dist/listgrid/api/types.js +30 -0
  19. package/dist/listgrid/auth/AuthContext.d.ts +12 -0
  20. package/dist/listgrid/auth/AuthContext.js +25 -0
  21. package/dist/listgrid/auth/SessionProvider.d.ts +4 -0
  22. package/dist/listgrid/auth/SessionProvider.js +16 -0
  23. package/dist/listgrid/auth/index.d.ts +6 -0
  24. package/dist/listgrid/auth/index.js +17 -0
  25. package/dist/listgrid/auth/types.d.ts +15 -0
  26. package/dist/listgrid/auth/types.js +12 -0
  27. package/dist/listgrid/common/func.d.ts +16 -0
  28. package/dist/listgrid/common/func.js +351 -0
  29. package/dist/listgrid/common/type.d.ts +35 -0
  30. package/dist/listgrid/common/type.js +46 -0
  31. package/dist/listgrid/components/api/ApiSpecificationButton.d.ts +5 -0
  32. package/dist/listgrid/components/api/ApiSpecificationButton.js +16 -0
  33. package/dist/listgrid/components/api/Type.d.ts +23 -0
  34. package/dist/listgrid/components/api/Type.js +8 -0
  35. package/dist/listgrid/components/api/ViewApiSpecification.d.ts +2 -0
  36. package/dist/listgrid/components/api/ViewApiSpecification.js +32 -0
  37. package/dist/listgrid/components/fields/ApplyFullAddressFields.d.ts +45 -0
  38. package/dist/listgrid/components/fields/ApplyFullAddressFields.js +177 -0
  39. package/dist/listgrid/components/fields/BirthdayField.d.ts +39 -0
  40. package/dist/listgrid/components/fields/BirthdayField.js +205 -0
  41. package/dist/listgrid/components/fields/BooleanField.d.ts +38 -0
  42. package/dist/listgrid/components/fields/BooleanField.js +141 -0
  43. package/dist/listgrid/components/fields/CheckboxField.d.ts +23 -0
  44. package/dist/listgrid/components/fields/CheckboxField.js +33 -0
  45. package/dist/listgrid/components/fields/ColorField.d.ts +18 -0
  46. package/dist/listgrid/components/fields/ColorField.js +63 -0
  47. package/dist/listgrid/components/fields/ColorPresetField.d.ts +19 -0
  48. package/dist/listgrid/components/fields/ColorPresetField.js +56 -0
  49. package/dist/listgrid/components/fields/CustomOptionField.d.ts +45 -0
  50. package/dist/listgrid/components/fields/CustomOptionField.js +176 -0
  51. package/dist/listgrid/components/fields/DateField.d.ts +34 -0
  52. package/dist/listgrid/components/fields/DateField.js +116 -0
  53. package/dist/listgrid/components/fields/DatetimeField.d.ts +29 -0
  54. package/dist/listgrid/components/fields/DatetimeField.js +93 -0
  55. package/dist/listgrid/components/fields/EmailField.d.ts +37 -0
  56. package/dist/listgrid/components/fields/EmailField.js +144 -0
  57. package/dist/listgrid/components/fields/FileField.d.ts +36 -0
  58. package/dist/listgrid/components/fields/FileField.js +157 -0
  59. package/dist/listgrid/components/fields/HtmlField.d.ts +24 -0
  60. package/dist/listgrid/components/fields/HtmlField.js +70 -0
  61. package/dist/listgrid/components/fields/ImageField.d.ts +34 -0
  62. package/dist/listgrid/components/fields/ImageField.js +125 -0
  63. package/dist/listgrid/components/fields/InlineMapField.d.ts +40 -0
  64. package/dist/listgrid/components/fields/InlineMapField.js +85 -0
  65. package/dist/listgrid/components/fields/LinkField.d.ts +26 -0
  66. package/dist/listgrid/components/fields/LinkField.js +61 -0
  67. package/dist/listgrid/components/fields/ManyToOneField.d.ts +80 -0
  68. package/dist/listgrid/components/fields/ManyToOneField.js +416 -0
  69. package/dist/listgrid/components/fields/MappedJoinField.d.ts +16 -0
  70. package/dist/listgrid/components/fields/MappedJoinField.js +29 -0
  71. package/dist/listgrid/components/fields/MarkdownField.d.ts +20 -0
  72. package/dist/listgrid/components/fields/MarkdownField.js +58 -0
  73. package/dist/listgrid/components/fields/MessageViewField.d.ts +20 -0
  74. package/dist/listgrid/components/fields/MessageViewField.js +27 -0
  75. package/dist/listgrid/components/fields/MonthField.d.ts +25 -0
  76. package/dist/listgrid/components/fields/MonthField.js +68 -0
  77. package/dist/listgrid/components/fields/MultiSelectField.d.ts +59 -0
  78. package/dist/listgrid/components/fields/MultiSelectField.js +74 -0
  79. package/dist/listgrid/components/fields/MultipleAssetField.d.ts +31 -0
  80. package/dist/listgrid/components/fields/MultipleAssetField.js +200 -0
  81. package/dist/listgrid/components/fields/NumberField.d.ts +54 -0
  82. package/dist/listgrid/components/fields/NumberField.js +216 -0
  83. package/dist/listgrid/components/fields/PasswordField.d.ts +23 -0
  84. package/dist/listgrid/components/fields/PasswordField.js +70 -0
  85. package/dist/listgrid/components/fields/PhoneNumberField.d.ts +39 -0
  86. package/dist/listgrid/components/fields/PhoneNumberField.js +91 -0
  87. package/dist/listgrid/components/fields/Preset.d.ts +68 -0
  88. package/dist/listgrid/components/fields/Preset.js +306 -0
  89. package/dist/listgrid/components/fields/ProfileField.d.ts +14 -0
  90. package/dist/listgrid/components/fields/ProfileField.js +25 -0
  91. package/dist/listgrid/components/fields/QrField.d.ts +21 -0
  92. package/dist/listgrid/components/fields/QrField.js +31 -0
  93. package/dist/listgrid/components/fields/RuleField.d.ts +11 -0
  94. package/dist/listgrid/components/fields/RuleField.js +24 -0
  95. package/dist/listgrid/components/fields/SelectField.d.ts +223 -0
  96. package/dist/listgrid/components/fields/SelectField.js +379 -0
  97. package/dist/listgrid/components/fields/SelectFieldRenderer.d.ts +35 -0
  98. package/dist/listgrid/components/fields/SelectFieldRenderer.js +363 -0
  99. package/dist/listgrid/components/fields/StatusChangeReasonModal.d.ts +18 -0
  100. package/dist/listgrid/components/fields/StatusChangeReasonModal.js +25 -0
  101. package/dist/listgrid/components/fields/StringField.d.ts +34 -0
  102. package/dist/listgrid/components/fields/StringField.js +131 -0
  103. package/dist/listgrid/components/fields/TagField.d.ts +35 -0
  104. package/dist/listgrid/components/fields/TagField.js +75 -0
  105. package/dist/listgrid/components/fields/TelephoneNumberField.d.ts +35 -0
  106. package/dist/listgrid/components/fields/TelephoneNumberField.js +121 -0
  107. package/dist/listgrid/components/fields/TextareaField.d.ts +27 -0
  108. package/dist/listgrid/components/fields/TextareaField.js +47 -0
  109. package/dist/listgrid/components/fields/TimeField.d.ts +21 -0
  110. package/dist/listgrid/components/fields/TimeField.js +40 -0
  111. package/dist/listgrid/components/fields/XrefAvailableDateMappingField.d.ts +22 -0
  112. package/dist/listgrid/components/fields/XrefAvailableDateMappingField.js +39 -0
  113. package/dist/listgrid/components/fields/XrefMappingField.d.ts +30 -0
  114. package/dist/listgrid/components/fields/XrefMappingField.js +59 -0
  115. package/dist/listgrid/components/fields/XrefPreferMappingField.d.ts +30 -0
  116. package/dist/listgrid/components/fields/XrefPreferMappingField.js +53 -0
  117. package/dist/listgrid/components/fields/XrefPriceMappingField.d.ts +33 -0
  118. package/dist/listgrid/components/fields/XrefPriceMappingField.js +56 -0
  119. package/dist/listgrid/components/fields/YearField.d.ts +32 -0
  120. package/dist/listgrid/components/fields/YearField.js +99 -0
  121. package/dist/listgrid/components/fields/abstract/AbstractDateField.d.ts +33 -0
  122. package/dist/listgrid/components/fields/abstract/AbstractDateField.js +61 -0
  123. package/dist/listgrid/components/fields/abstract/AbstractManyToOneField.d.ts +97 -0
  124. package/dist/listgrid/components/fields/abstract/AbstractManyToOneField.js +50 -0
  125. package/dist/listgrid/components/fields/abstract/CheckButtonValidationField.d.ts +22 -0
  126. package/dist/listgrid/components/fields/abstract/CheckButtonValidationField.js +92 -0
  127. package/dist/listgrid/components/fields/abstract/FormField.d.ts +250 -0
  128. package/dist/listgrid/components/fields/abstract/FormField.js +606 -0
  129. package/dist/listgrid/components/fields/abstract/ListableFormField.d.ts +140 -0
  130. package/dist/listgrid/components/fields/abstract/ListableFormField.js +285 -0
  131. package/dist/listgrid/components/fields/abstract/OptionalField.d.ts +96 -0
  132. package/dist/listgrid/components/fields/abstract/OptionalField.js +310 -0
  133. package/dist/listgrid/components/fields/abstract/index.d.ts +6 -0
  134. package/dist/listgrid/components/fields/abstract/index.js +12 -0
  135. package/dist/listgrid/components/fields/address/AddressFieldView.d.ts +9 -0
  136. package/dist/listgrid/components/fields/address/AddressFieldView.js +92 -0
  137. package/dist/listgrid/components/fields/address/AddressMapField.d.ts +33 -0
  138. package/dist/listgrid/components/fields/address/AddressMapField.js +49 -0
  139. package/dist/listgrid/components/fields/address/KakaoMap.d.ts +10 -0
  140. package/dist/listgrid/components/fields/address/KakaoMap.js +50 -0
  141. package/dist/listgrid/components/fields/address/PostCodeSelector.d.ts +9 -0
  142. package/dist/listgrid/components/fields/address/PostCodeSelector.js +125 -0
  143. package/dist/listgrid/components/fields/contentasset/ContentAssetField.d.ts +61 -0
  144. package/dist/listgrid/components/fields/contentasset/ContentAssetField.js +80 -0
  145. package/dist/listgrid/components/fields/contentasset/ContentAssetItem.d.ts +17 -0
  146. package/dist/listgrid/components/fields/contentasset/ContentAssetItem.js +67 -0
  147. package/dist/listgrid/components/fields/contentasset/components/AddContentDialog.d.ts +11 -0
  148. package/dist/listgrid/components/fields/contentasset/components/AddContentDialog.js +68 -0
  149. package/dist/listgrid/components/fields/contentasset/components/ContentAssetItemUI.d.ts +30 -0
  150. package/dist/listgrid/components/fields/contentasset/components/ContentAssetItemUI.js +38 -0
  151. package/dist/listgrid/components/fields/contentasset/hooks/useContentAsset.d.ts +36 -0
  152. package/dist/listgrid/components/fields/contentasset/hooks/useContentAsset.js +188 -0
  153. package/dist/listgrid/components/fields/contentasset/index.d.ts +2 -0
  154. package/dist/listgrid/components/fields/contentasset/index.js +1 -0
  155. package/dist/listgrid/components/fields/contentasset/types.d.ts +50 -0
  156. package/dist/listgrid/components/fields/contentasset/types.js +48 -0
  157. package/dist/listgrid/components/fields/filter/DatetimeFilter.d.ts +7 -0
  158. package/dist/listgrid/components/fields/filter/DatetimeFilter.js +46 -0
  159. package/dist/listgrid/components/fields/filter/NumberFilter.d.ts +7 -0
  160. package/dist/listgrid/components/fields/filter/NumberFilter.js +74 -0
  161. package/dist/listgrid/components/fields/rule/RuleBasedFieldView.d.ts +15 -0
  162. package/dist/listgrid/components/fields/rule/RuleBasedFieldView.js +351 -0
  163. package/dist/listgrid/components/fields/rule/RuleBasedSelector.d.ts +13 -0
  164. package/dist/listgrid/components/fields/rule/RuleBasedSelector.js +75 -0
  165. package/dist/listgrid/components/fields/rule/RuleCondition.d.ts +14 -0
  166. package/dist/listgrid/components/fields/rule/RuleCondition.js +173 -0
  167. package/dist/listgrid/components/fields/rule/RuleFieldRenderer.d.ts +7 -0
  168. package/dist/listgrid/components/fields/rule/RuleFieldRenderer.js +21 -0
  169. package/dist/listgrid/components/fields/rule/RuleFieldView.d.ts +7 -0
  170. package/dist/listgrid/components/fields/rule/RuleFieldView.js +28 -0
  171. package/dist/listgrid/components/fields/rule/Type.d.ts +54 -0
  172. package/dist/listgrid/components/fields/rule/Type.js +72 -0
  173. package/dist/listgrid/components/fields/view/CardManyToOneView.d.ts +93 -0
  174. package/dist/listgrid/components/fields/view/CardManyToOneView.js +409 -0
  175. package/dist/listgrid/components/fields/view/CopyableTextView.d.ts +11 -0
  176. package/dist/listgrid/components/fields/view/CopyableTextView.js +44 -0
  177. package/dist/listgrid/components/fields/view/DynamicSelectFieldView.d.ts +28 -0
  178. package/dist/listgrid/components/fields/view/DynamicSelectFieldView.js +119 -0
  179. package/dist/listgrid/components/fields/view/LinkFieldView.d.ts +14 -0
  180. package/dist/listgrid/components/fields/view/LinkFieldView.js +41 -0
  181. package/dist/listgrid/components/fields/view/ManyToOneListView.d.ts +8 -0
  182. package/dist/listgrid/components/fields/view/ManyToOneListView.js +25 -0
  183. package/dist/listgrid/components/fields/view/ManyToOneMultiFilterView.d.ts +12 -0
  184. package/dist/listgrid/components/fields/view/ManyToOneMultiFilterView.js +142 -0
  185. package/dist/listgrid/components/fields/view/ManyToOneView.d.ts +8 -0
  186. package/dist/listgrid/components/fields/view/ManyToOneView.js +322 -0
  187. package/dist/listgrid/components/fields/view/MultipleAssetUpload.d.ts +7 -0
  188. package/dist/listgrid/components/fields/view/MultipleAssetUpload.js +47 -0
  189. package/dist/listgrid/components/fields/view/PhoneNumberFieldView.d.ts +19 -0
  190. package/dist/listgrid/components/fields/view/PhoneNumberFieldView.js +82 -0
  191. package/dist/listgrid/components/fields/view/PhoneNumberListView.d.ts +9 -0
  192. package/dist/listgrid/components/fields/view/PhoneNumberListView.js +49 -0
  193. package/dist/listgrid/components/fields/view/SelectBoxManyToOneView.d.ts +47 -0
  194. package/dist/listgrid/components/fields/view/SelectBoxManyToOneView.js +286 -0
  195. package/dist/listgrid/components/fields/view/SmsModal.d.ts +6 -0
  196. package/dist/listgrid/components/fields/view/SmsModal.js +124 -0
  197. package/dist/listgrid/components/fields/view/TreeSelectView.d.ts +11 -0
  198. package/dist/listgrid/components/fields/view/TreeSelectView.js +118 -0
  199. package/dist/listgrid/components/fields/view/XrefAvailableDateMappingView.d.ts +19 -0
  200. package/dist/listgrid/components/fields/view/XrefAvailableDateMappingView.js +305 -0
  201. package/dist/listgrid/components/fields/view/XrefMappingView.d.ts +16 -0
  202. package/dist/listgrid/components/fields/view/XrefMappingView.js +173 -0
  203. package/dist/listgrid/components/fields/view/XrefPiceMappingView.d.ts +19 -0
  204. package/dist/listgrid/components/fields/view/XrefPiceMappingView.js +319 -0
  205. package/dist/listgrid/components/fields/view/XrefPreferMappingView.d.ts +19 -0
  206. package/dist/listgrid/components/fields/view/XrefPreferMappingView.js +261 -0
  207. package/dist/listgrid/components/fields/view/XrefPriorityMappingView.d.ts +19 -0
  208. package/dist/listgrid/components/fields/view/XrefPriorityMappingView.js +180 -0
  209. package/dist/listgrid/components/form/FieldRenderer.d.ts +23 -0
  210. package/dist/listgrid/components/form/FieldRenderer.js +292 -0
  211. package/dist/listgrid/components/form/SubCollectionRenderer.d.ts +22 -0
  212. package/dist/listgrid/components/form/SubCollectionRenderer.js +46 -0
  213. package/dist/listgrid/components/form/ViewEntityForm.d.ts +14 -0
  214. package/dist/listgrid/components/form/ViewEntityForm.js +124 -0
  215. package/dist/listgrid/components/form/ViewFieldGroup.d.ts +27 -0
  216. package/dist/listgrid/components/form/ViewFieldGroup.js +164 -0
  217. package/dist/listgrid/components/form/ViewTab.d.ts +24 -0
  218. package/dist/listgrid/components/form/ViewTab.js +68 -0
  219. package/dist/listgrid/components/form/ViewTabPanel.d.ts +14 -0
  220. package/dist/listgrid/components/form/ViewTabPanel.js +32 -0
  221. package/dist/listgrid/components/form/context/EntityFormThemeContext.d.ts +52 -0
  222. package/dist/listgrid/components/form/context/EntityFormThemeContext.js +129 -0
  223. package/dist/listgrid/components/form/context/index.d.ts +1 -0
  224. package/dist/listgrid/components/form/context/index.js +1 -0
  225. package/dist/listgrid/components/form/hooks/useAlertManager.d.ts +12 -0
  226. package/dist/listgrid/components/form/hooks/useAlertManager.js +103 -0
  227. package/dist/listgrid/components/form/hooks/useEntityFormAutoSave.d.ts +23 -0
  228. package/dist/listgrid/components/form/hooks/useEntityFormAutoSave.js +145 -0
  229. package/dist/listgrid/components/form/hooks/useEntityFormInitializer.d.ts +24 -0
  230. package/dist/listgrid/components/form/hooks/useEntityFormInitializer.js +109 -0
  231. package/dist/listgrid/components/form/hooks/useEntityFormLogic.d.ts +63 -0
  232. package/dist/listgrid/components/form/hooks/useEntityFormLogic.js +513 -0
  233. package/dist/listgrid/components/form/hooks/useEntityFormSave.d.ts +28 -0
  234. package/dist/listgrid/components/form/hooks/useEntityFormSave.js +89 -0
  235. package/dist/listgrid/components/form/hooks/useEntityFormTitle.d.ts +12 -0
  236. package/dist/listgrid/components/form/hooks/useEntityFormTitle.js +53 -0
  237. package/dist/listgrid/components/form/themes/defaultTheme.d.ts +11 -0
  238. package/dist/listgrid/components/form/themes/defaultTheme.js +129 -0
  239. package/dist/listgrid/components/form/themes/index.d.ts +1 -0
  240. package/dist/listgrid/components/form/themes/index.js +1 -0
  241. package/dist/listgrid/components/form/types/ViewEntityForm.types.d.ts +169 -0
  242. package/dist/listgrid/components/form/types/ViewEntityForm.types.js +1 -0
  243. package/dist/listgrid/components/form/types/ViewEntityFormAlerts.types.d.ts +26 -0
  244. package/dist/listgrid/components/form/types/ViewEntityFormAlerts.types.js +1 -0
  245. package/dist/listgrid/components/form/types/ViewEntityFormButtons.types.d.ts +49 -0
  246. package/dist/listgrid/components/form/types/ViewEntityFormButtons.types.js +1 -0
  247. package/dist/listgrid/components/form/types/ViewEntityFormTheme.types.d.ts +518 -0
  248. package/dist/listgrid/components/form/types/ViewEntityFormTheme.types.js +1 -0
  249. package/dist/listgrid/components/form/ui/AlertItem.d.ts +7 -0
  250. package/dist/listgrid/components/form/ui/AlertItem.js +18 -0
  251. package/dist/listgrid/components/form/ui/CreateStepButtons.d.ts +25 -0
  252. package/dist/listgrid/components/form/ui/CreateStepButtons.js +18 -0
  253. package/dist/listgrid/components/form/ui/CreateStepView.d.ts +39 -0
  254. package/dist/listgrid/components/form/ui/CreateStepView.js +50 -0
  255. package/dist/listgrid/components/form/ui/ViewEntityError.d.ts +13 -0
  256. package/dist/listgrid/components/form/ui/ViewEntityError.js +90 -0
  257. package/dist/listgrid/components/form/ui/ViewEntityFormAlerts.d.ts +3 -0
  258. package/dist/listgrid/components/form/ui/ViewEntityFormAlerts.js +24 -0
  259. package/dist/listgrid/components/form/ui/ViewEntityFormButtons.d.ts +24 -0
  260. package/dist/listgrid/components/form/ui/ViewEntityFormButtons.js +208 -0
  261. package/dist/listgrid/components/form/ui/ViewEntityFormErrors.d.ts +25 -0
  262. package/dist/listgrid/components/form/ui/ViewEntityFormErrors.js +9 -0
  263. package/dist/listgrid/components/form/ui/ViewEntityFormFields.d.ts +38 -0
  264. package/dist/listgrid/components/form/ui/ViewEntityFormFields.js +25 -0
  265. package/dist/listgrid/components/form/ui/ViewEntityFormSkeleton.d.ts +16 -0
  266. package/dist/listgrid/components/form/ui/ViewEntityFormSkeleton.js +79 -0
  267. package/dist/listgrid/components/form/ui/ViewEntityFormTitle.d.ts +15 -0
  268. package/dist/listgrid/components/form/ui/ViewEntityFormTitle.js +21 -0
  269. package/dist/listgrid/components/form/ui/ViewFieldError.d.ts +5 -0
  270. package/dist/listgrid/components/form/ui/ViewFieldError.js +12 -0
  271. package/dist/listgrid/components/form/ui/ViewHelpIcon.d.ts +5 -0
  272. package/dist/listgrid/components/form/ui/ViewHelpIcon.js +13 -0
  273. package/dist/listgrid/components/form/ui/ViewHelpText.d.ts +5 -0
  274. package/dist/listgrid/components/form/ui/ViewHelpText.js +10 -0
  275. package/dist/listgrid/components/form/ui/buttons/ClosePopupButton.d.ts +8 -0
  276. package/dist/listgrid/components/form/ui/buttons/ClosePopupButton.js +32 -0
  277. package/dist/listgrid/components/form/ui/buttons/DeleteButton.d.ts +2 -0
  278. package/dist/listgrid/components/form/ui/buttons/DeleteButton.js +101 -0
  279. package/dist/listgrid/components/form/ui/buttons/ListButton.d.ts +2 -0
  280. package/dist/listgrid/components/form/ui/buttons/ListButton.js +55 -0
  281. package/dist/listgrid/components/form/ui/buttons/SaveButton.d.ts +2 -0
  282. package/dist/listgrid/components/form/ui/buttons/SaveButton.js +55 -0
  283. package/dist/listgrid/components/helper/FieldRendererHelper.d.ts +23 -0
  284. package/dist/listgrid/components/helper/FieldRendererHelper.js +27 -0
  285. package/dist/listgrid/components/helper/ShowNotifications.d.ts +13 -0
  286. package/dist/listgrid/components/helper/ShowNotifications.js +58 -0
  287. package/dist/listgrid/components/list/AdvancedSearchForm.d.ts +17 -0
  288. package/dist/listgrid/components/list/AdvancedSearchForm.js +113 -0
  289. package/dist/listgrid/components/list/AdvancedSearchFormV2.d.ts +19 -0
  290. package/dist/listgrid/components/list/AdvancedSearchFormV2.js +347 -0
  291. package/dist/listgrid/components/list/ListGridHeader.d.ts +2 -0
  292. package/dist/listgrid/components/list/ListGridHeader.js +21 -0
  293. package/dist/listgrid/components/list/QuickSearchBar.d.ts +22 -0
  294. package/dist/listgrid/components/list/QuickSearchBar.js +17 -0
  295. package/dist/listgrid/components/list/RowItem.d.ts +2 -0
  296. package/dist/listgrid/components/list/RowItem.js +70 -0
  297. package/dist/listgrid/components/list/SubCollectionButtons.d.ts +2 -0
  298. package/dist/listgrid/components/list/SubCollectionButtons.js +36 -0
  299. package/dist/listgrid/components/list/ViewFieldSelector.d.ts +10 -0
  300. package/dist/listgrid/components/list/ViewFieldSelector.js +48 -0
  301. package/dist/listgrid/components/list/ViewListGrid.d.ts +2 -0
  302. package/dist/listgrid/components/list/ViewListGrid.js +359 -0
  303. package/dist/listgrid/components/list/context/EntityFormScopeContext.d.ts +39 -0
  304. package/dist/listgrid/components/list/context/EntityFormScopeContext.js +75 -0
  305. package/dist/listgrid/components/list/context/ListGridThemeContext.d.ts +70 -0
  306. package/dist/listgrid/components/list/context/ListGridThemeContext.js +157 -0
  307. package/dist/listgrid/components/list/context/index.d.ts +2 -0
  308. package/dist/listgrid/components/list/context/index.js +1 -0
  309. package/dist/listgrid/components/list/hooks/searchFormUrlSync.d.ts +42 -0
  310. package/dist/listgrid/components/list/hooks/searchFormUrlSync.js +212 -0
  311. package/dist/listgrid/components/list/hooks/urlStateParsers.d.ts +63 -0
  312. package/dist/listgrid/components/list/hooks/urlStateParsers.js +241 -0
  313. package/dist/listgrid/components/list/hooks/useCardSubCollectionData.d.ts +34 -0
  314. package/dist/listgrid/components/list/hooks/useCardSubCollectionData.js +181 -0
  315. package/dist/listgrid/components/list/hooks/useListGridHeader.d.ts +6 -0
  316. package/dist/listgrid/components/list/hooks/useListGridHeader.js +92 -0
  317. package/dist/listgrid/components/list/hooks/useListGridLogic.d.ts +2 -0
  318. package/dist/listgrid/components/list/hooks/useListGridLogic.js +625 -0
  319. package/dist/listgrid/components/list/hooks/useListGridUrlState.d.ts +45 -0
  320. package/dist/listgrid/components/list/hooks/useListGridUrlState.js +131 -0
  321. package/dist/listgrid/components/list/hooks/useQuickSearchBar.d.ts +22 -0
  322. package/dist/listgrid/components/list/hooks/useQuickSearchBar.js +104 -0
  323. package/dist/listgrid/components/list/hooks/useSubCollectionExpansion.d.ts +21 -0
  324. package/dist/listgrid/components/list/hooks/useSubCollectionExpansion.js +62 -0
  325. package/dist/listgrid/components/list/themes/defaultListGridTheme.d.ts +14 -0
  326. package/dist/listgrid/components/list/themes/defaultListGridTheme.js +169 -0
  327. package/dist/listgrid/components/list/themes/index.d.ts +4 -0
  328. package/dist/listgrid/components/list/themes/index.js +4 -0
  329. package/dist/listgrid/components/list/themes/variants/mainTheme.d.ts +8 -0
  330. package/dist/listgrid/components/list/themes/variants/mainTheme.js +37 -0
  331. package/dist/listgrid/components/list/themes/variants/modalTheme.d.ts +8 -0
  332. package/dist/listgrid/components/list/themes/variants/modalTheme.js +47 -0
  333. package/dist/listgrid/components/list/themes/variants/subCollectionTheme.d.ts +8 -0
  334. package/dist/listgrid/components/list/themes/variants/subCollectionTheme.js +101 -0
  335. package/dist/listgrid/components/list/types/ListGridHeader.types.d.ts +35 -0
  336. package/dist/listgrid/components/list/types/ListGridHeader.types.js +3 -0
  337. package/dist/listgrid/components/list/types/RowItem.types.d.ts +57 -0
  338. package/dist/listgrid/components/list/types/RowItem.types.js +1 -0
  339. package/dist/listgrid/components/list/types/SubCollectionButtons.type.d.ts +29 -0
  340. package/dist/listgrid/components/list/types/SubCollectionButtons.type.js +1 -0
  341. package/dist/listgrid/components/list/types/ViewListGrid.types.d.ts +152 -0
  342. package/dist/listgrid/components/list/types/ViewListGrid.types.js +2 -0
  343. package/dist/listgrid/components/list/types/ViewListGridTheme.types.d.ts +374 -0
  344. package/dist/listgrid/components/list/types/ViewListGridTheme.types.js +1 -0
  345. package/dist/listgrid/components/list/ui/CardFieldRenderer.d.ts +31 -0
  346. package/dist/listgrid/components/list/ui/CardFieldRenderer.js +71 -0
  347. package/dist/listgrid/components/list/ui/CardFieldSection.d.ts +27 -0
  348. package/dist/listgrid/components/list/ui/CardFieldSection.js +108 -0
  349. package/dist/listgrid/components/list/ui/CardItem.d.ts +28 -0
  350. package/dist/listgrid/components/list/ui/CardItem.js +376 -0
  351. package/dist/listgrid/components/list/ui/CardSubCollectionModal.d.ts +38 -0
  352. package/dist/listgrid/components/list/ui/CardSubCollectionModal.js +80 -0
  353. package/dist/listgrid/components/list/ui/CardSubCollectionView.d.ts +44 -0
  354. package/dist/listgrid/components/list/ui/CardSubCollectionView.js +238 -0
  355. package/dist/listgrid/components/list/ui/DataTransferModal.d.ts +12 -0
  356. package/dist/listgrid/components/list/ui/DataTransferModal.js +10 -0
  357. package/dist/listgrid/components/list/ui/EntireChecker.d.ts +11 -0
  358. package/dist/listgrid/components/list/ui/EntireChecker.js +46 -0
  359. package/dist/listgrid/components/list/ui/FieldSelector.d.ts +11 -0
  360. package/dist/listgrid/components/list/ui/FieldSelector.js +40 -0
  361. package/dist/listgrid/components/list/ui/FilterButton.d.ts +7 -0
  362. package/dist/listgrid/components/list/ui/FilterButton.js +5 -0
  363. package/dist/listgrid/components/list/ui/FilterDropdown.d.ts +15 -0
  364. package/dist/listgrid/components/list/ui/FilterDropdown.js +106 -0
  365. package/dist/listgrid/components/list/ui/FilterView.d.ts +12 -0
  366. package/dist/listgrid/components/list/ui/FilterView.js +22 -0
  367. package/dist/listgrid/components/list/ui/HeaderActionButtons.d.ts +10 -0
  368. package/dist/listgrid/components/list/ui/HeaderActionButtons.js +39 -0
  369. package/dist/listgrid/components/list/ui/HeaderField.d.ts +19 -0
  370. package/dist/listgrid/components/list/ui/HeaderField.js +32 -0
  371. package/dist/listgrid/components/list/ui/HeaderFieldFilter.d.ts +14 -0
  372. package/dist/listgrid/components/list/ui/HeaderFieldFilter.js +166 -0
  373. package/dist/listgrid/components/list/ui/HeaderTitle.d.ts +4 -0
  374. package/dist/listgrid/components/list/ui/HeaderTitle.js +13 -0
  375. package/dist/listgrid/components/list/ui/InlineSubCollectionView.d.ts +30 -0
  376. package/dist/listgrid/components/list/ui/InlineSubCollectionView.js +260 -0
  377. package/dist/listgrid/components/list/ui/MemoizedFilterField.d.ts +14 -0
  378. package/dist/listgrid/components/list/ui/MemoizedFilterField.js +67 -0
  379. package/dist/listgrid/components/list/ui/QuickSearchInput.d.ts +9 -0
  380. package/dist/listgrid/components/list/ui/QuickSearchInput.js +17 -0
  381. package/dist/listgrid/components/list/ui/SearchBarActions.d.ts +19 -0
  382. package/dist/listgrid/components/list/ui/SearchBarActions.js +39 -0
  383. package/dist/listgrid/components/list/ui/SortField.d.ts +8 -0
  384. package/dist/listgrid/components/list/ui/SortField.js +42 -0
  385. package/dist/listgrid/components/list/ui/SubCollectionInlineView.d.ts +23 -0
  386. package/dist/listgrid/components/list/ui/SubCollectionInlineView.js +47 -0
  387. package/dist/listgrid/components/list/ui/SubCollectionModal.d.ts +15 -0
  388. package/dist/listgrid/components/list/ui/SubCollectionModal.js +34 -0
  389. package/dist/listgrid/components/list/ui/SubCollectionViewModal.d.ts +13 -0
  390. package/dist/listgrid/components/list/ui/SubCollectionViewModal.js +33 -0
  391. package/dist/listgrid/components/list/ui/SyncTopScrollbar.d.ts +18 -0
  392. package/dist/listgrid/components/list/ui/SyncTopScrollbar.js +91 -0
  393. package/dist/listgrid/components/list/ui/TableSubCollectionView.d.ts +25 -0
  394. package/dist/listgrid/components/list/ui/TableSubCollectionView.js +213 -0
  395. package/dist/listgrid/components/list/ui/ViewColumn.d.ts +2 -0
  396. package/dist/listgrid/components/list/ui/ViewColumn.js +56 -0
  397. package/dist/listgrid/components/list/ui/ViewListGridSkeleton.d.ts +20 -0
  398. package/dist/listgrid/components/list/ui/ViewListGridSkeleton.js +82 -0
  399. package/dist/listgrid/components/list/ui/ViewRows.d.ts +15 -0
  400. package/dist/listgrid/components/list/ui/ViewRows.js +283 -0
  401. package/dist/listgrid/components/list/ui/buttons/CacheClearButton.d.ts +9 -0
  402. package/dist/listgrid/components/list/ui/buttons/CacheClearButton.js +35 -0
  403. package/dist/listgrid/components/list/ui/buttons/CreateButton.d.ts +13 -0
  404. package/dist/listgrid/components/list/ui/buttons/CreateButton.js +13 -0
  405. package/dist/listgrid/components/list/ui/buttons/PriorityButton.d.ts +11 -0
  406. package/dist/listgrid/components/list/ui/buttons/PriorityButton.js +49 -0
  407. package/dist/listgrid/components/list/ui/headerFilterStore.d.ts +8 -0
  408. package/dist/listgrid/components/list/ui/headerFilterStore.js +13 -0
  409. package/dist/listgrid/components/list/utils/mappedByFieldFilter.d.ts +21 -0
  410. package/dist/listgrid/components/list/utils/mappedByFieldFilter.js +54 -0
  411. package/dist/listgrid/components/list/utils/performanceLogger.d.ts +48 -0
  412. package/dist/listgrid/components/list/utils/performanceLogger.js +67 -0
  413. package/dist/listgrid/components/revision/RevisionField.d.ts +13 -0
  414. package/dist/listgrid/components/revision/RevisionField.js +194 -0
  415. package/dist/listgrid/config/AdvancedSearchOpenCache.d.ts +3 -0
  416. package/dist/listgrid/config/AdvancedSearchOpenCache.js +48 -0
  417. package/dist/listgrid/config/CardSubCollectionField.d.ts +133 -0
  418. package/dist/listgrid/config/CardSubCollectionField.js +164 -0
  419. package/dist/listgrid/config/CommonType.d.ts +4 -0
  420. package/dist/listgrid/config/CommonType.js +15 -0
  421. package/dist/listgrid/config/Config.d.ts +251 -0
  422. package/dist/listgrid/config/Config.js +299 -0
  423. package/dist/listgrid/config/EntityField.d.ts +148 -0
  424. package/dist/listgrid/config/EntityField.js +1 -0
  425. package/dist/listgrid/config/EntityFieldGroup.d.ts +37 -0
  426. package/dist/listgrid/config/EntityFieldGroup.js +55 -0
  427. package/dist/listgrid/config/EntityForm.d.ts +101 -0
  428. package/dist/listgrid/config/EntityForm.js +859 -0
  429. package/dist/listgrid/config/EntityFormButton.d.ts +56 -0
  430. package/dist/listgrid/config/EntityFormButton.js +42 -0
  431. package/dist/listgrid/config/EntityFormMethod.d.ts +32 -0
  432. package/dist/listgrid/config/EntityFormMethod.js +152 -0
  433. package/dist/listgrid/config/EntityFormTypes.d.ts +62 -0
  434. package/dist/listgrid/config/EntityFormTypes.js +1 -0
  435. package/dist/listgrid/config/EntityItem.d.ts +86 -0
  436. package/dist/listgrid/config/EntityItem.js +1 -0
  437. package/dist/listgrid/config/EntityTab.d.ts +26 -0
  438. package/dist/listgrid/config/EntityTab.js +68 -0
  439. package/dist/listgrid/config/InlineSubCollectionField.d.ts +184 -0
  440. package/dist/listgrid/config/InlineSubCollectionField.js +194 -0
  441. package/dist/listgrid/config/ListGrid.d.ts +56 -0
  442. package/dist/listgrid/config/ListGrid.js +183 -0
  443. package/dist/listgrid/config/ListGridViewFieldCache.d.ts +3 -0
  444. package/dist/listgrid/config/ListGridViewFieldCache.js +53 -0
  445. package/dist/listgrid/config/OnChangeEntityForm.d.ts +43 -0
  446. package/dist/listgrid/config/OnChangeEntityForm.js +266 -0
  447. package/dist/listgrid/config/RuntimeConfig.d.ts +18 -0
  448. package/dist/listgrid/config/RuntimeConfig.js +22 -0
  449. package/dist/listgrid/config/SubCollectionField.d.ts +119 -0
  450. package/dist/listgrid/config/SubCollectionField.js +241 -0
  451. package/dist/listgrid/config/TableSubCollectionField.d.ts +66 -0
  452. package/dist/listgrid/config/TableSubCollectionField.js +132 -0
  453. package/dist/listgrid/config/form/EntityFormActions.d.ts +69 -0
  454. package/dist/listgrid/config/form/EntityFormActions.js +459 -0
  455. package/dist/listgrid/config/form/EntityFormBase.d.ts +204 -0
  456. package/dist/listgrid/config/form/EntityFormBase.js +526 -0
  457. package/dist/listgrid/config/form/EntityFormData.d.ts +32 -0
  458. package/dist/listgrid/config/form/EntityFormData.js +184 -0
  459. package/dist/listgrid/config/form/EntityFormExtensions.d.ts +37 -0
  460. package/dist/listgrid/config/form/EntityFormExtensions.js +105 -0
  461. package/dist/listgrid/config/form/EntityFormValidation.d.ts +28 -0
  462. package/dist/listgrid/config/form/EntityFormValidation.js +128 -0
  463. package/dist/listgrid/extensions/EntityFormExtension.types.d.ts +52 -0
  464. package/dist/listgrid/extensions/EntityFormExtension.types.js +19 -0
  465. package/dist/listgrid/extensions/FieldExtensions.d.ts +5 -0
  466. package/dist/listgrid/extensions/FieldExtensions.js +21 -0
  467. package/dist/listgrid/form/SearchForm.d.ts +153 -0
  468. package/dist/listgrid/form/SearchForm.js +689 -0
  469. package/dist/listgrid/form/TagsInput/types.d.ts +133 -0
  470. package/dist/listgrid/form/TagsInput/types.js +1 -0
  471. package/dist/listgrid/form/Type.d.ts +50 -0
  472. package/dist/listgrid/form/Type.js +95 -0
  473. package/dist/listgrid/index.d.ts +205 -0
  474. package/dist/listgrid/index.js +244 -0
  475. package/dist/listgrid/loading/index.d.ts +6 -0
  476. package/dist/listgrid/loading/index.js +17 -0
  477. package/dist/listgrid/menu/MenuPermissionChecker.d.ts +15 -0
  478. package/dist/listgrid/menu/MenuPermissionChecker.js +15 -0
  479. package/dist/listgrid/menu/index.d.ts +1 -0
  480. package/dist/listgrid/menu/index.js +1 -0
  481. package/dist/listgrid/message/MessageProvider.d.ts +19 -0
  482. package/dist/listgrid/message/MessageProvider.js +62 -0
  483. package/dist/listgrid/message/index.d.ts +1 -0
  484. package/dist/listgrid/message/index.js +1 -0
  485. package/dist/listgrid/misc/index.d.ts +64 -0
  486. package/dist/listgrid/misc/index.js +478 -0
  487. package/dist/listgrid/router/RouterProvider.d.ts +12 -0
  488. package/dist/listgrid/router/RouterProvider.js +34 -0
  489. package/dist/listgrid/router/index.d.ts +3 -0
  490. package/dist/listgrid/router/index.js +1 -0
  491. package/dist/listgrid/router/types.d.ts +34 -0
  492. package/dist/listgrid/router/types.js +6 -0
  493. package/dist/listgrid/store/index.d.ts +24 -0
  494. package/dist/listgrid/store/index.js +40 -0
  495. package/dist/listgrid/transfer/DataExportProcessor.d.ts +18 -0
  496. package/dist/listgrid/transfer/DataExportProcessor.js +102 -0
  497. package/dist/listgrid/transfer/DataExportService.d.ts +37 -0
  498. package/dist/listgrid/transfer/DataExportService.js +225 -0
  499. package/dist/listgrid/transfer/DataExporter.d.ts +10 -0
  500. package/dist/listgrid/transfer/DataExporter.js +85 -0
  501. package/dist/listgrid/transfer/DataImportDescription.d.ts +8 -0
  502. package/dist/listgrid/transfer/DataImportDescription.js +18 -0
  503. package/dist/listgrid/transfer/DataImportProcessor.d.ts +24 -0
  504. package/dist/listgrid/transfer/DataImportProcessor.js +59 -0
  505. package/dist/listgrid/transfer/DataImportResultView.d.ts +13 -0
  506. package/dist/listgrid/transfer/DataImportResultView.js +64 -0
  507. package/dist/listgrid/transfer/DataImportSample.d.ts +10 -0
  508. package/dist/listgrid/transfer/DataImportSample.js +105 -0
  509. package/dist/listgrid/transfer/DataImporter.d.ts +8 -0
  510. package/dist/listgrid/transfer/DataImporter.js +335 -0
  511. package/dist/listgrid/transfer/DynamicDataImporter.d.ts +4 -0
  512. package/dist/listgrid/transfer/DynamicDataImporter.js +13 -0
  513. package/dist/listgrid/transfer/ExcelPasswordField.d.ts +9 -0
  514. package/dist/listgrid/transfer/ExcelPasswordField.js +23 -0
  515. package/dist/listgrid/transfer/Provider/ExcelProvider.d.ts +24 -0
  516. package/dist/listgrid/transfer/Provider/ExcelProvider.js +194 -0
  517. package/dist/listgrid/transfer/Type.d.ts +176 -0
  518. package/dist/listgrid/transfer/Type.js +568 -0
  519. package/dist/listgrid/ui/GlobalModalManager.d.ts +22 -0
  520. package/dist/listgrid/ui/GlobalModalManager.js +65 -0
  521. package/dist/listgrid/ui/UIProvider.d.ts +151 -0
  522. package/dist/listgrid/ui/UIProvider.js +292 -0
  523. package/dist/listgrid/ui/index.d.ts +2 -0
  524. package/dist/listgrid/ui/index.js +2 -0
  525. package/dist/listgrid/urlState/UrlStateProvider.d.ts +8 -0
  526. package/dist/listgrid/urlState/UrlStateProvider.js +20 -0
  527. package/dist/listgrid/urlState/index.d.ts +4 -0
  528. package/dist/listgrid/urlState/index.js +2 -0
  529. package/dist/listgrid/urlState/types.d.ts +21 -0
  530. package/dist/listgrid/urlState/types.js +14 -0
  531. package/dist/listgrid/utils/BooleanUtil.d.ts +1 -0
  532. package/dist/listgrid/utils/BooleanUtil.js +9 -0
  533. package/dist/listgrid/utils/CompareUtil.d.ts +7 -0
  534. package/dist/listgrid/utils/CompareUtil.js +87 -0
  535. package/dist/listgrid/utils/PhoneUtil.d.ts +19 -0
  536. package/dist/listgrid/utils/PhoneUtil.js +38 -0
  537. package/dist/listgrid/utils/RequestUtil.d.ts +6 -0
  538. package/dist/listgrid/utils/RequestUtil.js +6 -0
  539. package/dist/listgrid/utils/StringUtil.d.ts +32 -0
  540. package/dist/listgrid/utils/StringUtil.js +316 -0
  541. package/dist/listgrid/utils/classNames.d.ts +21 -0
  542. package/dist/listgrid/utils/classNames.js +29 -0
  543. package/dist/listgrid/utils/cn.d.ts +12 -0
  544. package/dist/listgrid/utils/cn.js +15 -0
  545. package/dist/listgrid/utils/hash.d.ts +1 -0
  546. package/dist/listgrid/utils/hash.js +15 -0
  547. package/dist/listgrid/utils/i18n.d.ts +16 -0
  548. package/dist/listgrid/utils/i18n.js +31 -0
  549. package/dist/listgrid/utils/index.d.ts +10 -0
  550. package/dist/listgrid/utils/index.js +17 -0
  551. package/dist/listgrid/utils/jsonUtils.d.ts +4 -0
  552. package/dist/listgrid/utils/jsonUtils.js +77 -0
  553. package/dist/listgrid/utils/lazy.d.ts +10 -0
  554. package/dist/listgrid/utils/lazy.js +13 -0
  555. package/dist/listgrid/utils/simpleCrypt.d.ts +4 -0
  556. package/dist/listgrid/utils/simpleCrypt.js +79 -0
  557. package/dist/listgrid/validations/CustomValidation.d.ts +8 -0
  558. package/dist/listgrid/validations/CustomValidation.js +10 -0
  559. package/dist/listgrid/validations/EmailValidation.d.ts +4 -0
  560. package/dist/listgrid/validations/EmailValidation.js +7 -0
  561. package/dist/listgrid/validations/IpAddressValidation.d.ts +26 -0
  562. package/dist/listgrid/validations/IpAddressValidation.js +57 -0
  563. package/dist/listgrid/validations/MinMaxNumberValidation.d.ts +14 -0
  564. package/dist/listgrid/validations/MinMaxNumberValidation.js +28 -0
  565. package/dist/listgrid/validations/PasswordValidation.d.ts +4 -0
  566. package/dist/listgrid/validations/PasswordValidation.js +7 -0
  567. package/dist/listgrid/validations/PhoneNumberValidation.d.ts +12 -0
  568. package/dist/listgrid/validations/PhoneNumberValidation.js +24 -0
  569. package/dist/listgrid/validations/RegexFormularValidation.d.ts +7 -0
  570. package/dist/listgrid/validations/RegexFormularValidation.js +28 -0
  571. package/dist/listgrid/validations/RegexValidation.d.ts +8 -0
  572. package/dist/listgrid/validations/RegexValidation.js +17 -0
  573. package/dist/listgrid/validations/RequiredValidation.d.ts +7 -0
  574. package/dist/listgrid/validations/RequiredValidation.js +12 -0
  575. package/dist/listgrid/validations/StringValidation.d.ts +17 -0
  576. package/dist/listgrid/validations/StringValidation.js +33 -0
  577. package/dist/listgrid/validations/TelephoneNumberValidation.d.ts +12 -0
  578. package/dist/listgrid/validations/TelephoneNumberValidation.js +24 -0
  579. package/dist/listgrid/validations/Validation.d.ts +63 -0
  580. package/dist/listgrid/validations/Validation.js +72 -0
  581. package/dist/listgrid/view/ViewEntityFormWrapper.d.ts +16 -0
  582. package/dist/listgrid/view/ViewEntityFormWrapper.js +98 -0
  583. package/dist/listgrid/view/ViewListGridWrapper.d.ts +10 -0
  584. package/dist/listgrid/view/ViewListGridWrapper.js +96 -0
  585. package/dist/styles/base.css +116 -0
  586. package/dist/styles/components.css +1404 -0
  587. package/dist/styles/layouts.css +3206 -0
  588. package/dist/styles/primitives.css +1542 -0
  589. package/dist/styles/tokens.css +218 -0
  590. package/dist/styles.css +6486 -0
  591. package/docs/PRIMITIVES.md +271 -0
  592. package/package.json +201 -0
@@ -0,0 +1,124 @@
1
+ 'use client';
2
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
3
+ // Static imports for core components
4
+ import { ViewEntityFormTitle } from './ui/ViewEntityFormTitle';
5
+ import { ViewEntityFormButtons } from './ui/ViewEntityFormButtons';
6
+ import { ViewEntityFormSkeleton } from './ui/ViewEntityFormSkeleton';
7
+ import { Tab } from '@headlessui/react';
8
+ // Dynamic imports to reduce bundle size
9
+ import { dynamic } from '../../utils/lazy';
10
+ import { useEntityFormLogic } from './hooks/useEntityFormLogic';
11
+ import { clearAllToasts } from '../../message';
12
+ // Theme system
13
+ import { useEntityFormTheme } from './context/EntityFormThemeContext';
14
+ // Lazy load heavy components
15
+ const ViewEntityFormErrors = dynamic(() => import('./ui/ViewEntityFormErrors').then((mod) => ({ default: mod.ViewEntityFormErrors })), {
16
+ loading: () => _jsx("div", { className: "rcm-skeleton-placeholder-xs" }),
17
+ });
18
+ const ViewEntityFormAlerts = dynamic(() => import('./ui/ViewEntityFormAlerts').then((mod) => ({ default: mod.ViewEntityFormAlerts })), {
19
+ loading: () => _jsx("div", { className: "rcm-skeleton-placeholder-xs" }),
20
+ });
21
+ const ViewTab = dynamic(() => import('./ViewTab').then((mod) => ({ default: mod.ViewTab })), {
22
+ loading: () => _jsx("div", { className: "rcm-skeleton-placeholder-tab" }),
23
+ });
24
+ const ViewTabPanel = dynamic(() => import('./ViewTabPanel').then((mod) => ({ default: mod.ViewTabPanel })), {
25
+ loading: () => _jsx("div", { className: "rcm-skeleton-placeholder-panel" }),
26
+ });
27
+ const SafePerfectScrollbar = dynamic(() => import('../../ui').then((mod) => ({ default: mod.SafePerfectScrollbar })), {
28
+ ssr: false,
29
+ loading: () => _jsx("div", { className: "rcm-skeleton-placeholder-fill" }),
30
+ });
31
+ const CreateStepView = dynamic(() => import('./ui/CreateStepView').then((mod) => ({ default: mod.CreateStepView })), {
32
+ loading: () => _jsx("div", { className: "rcm-skeleton-placeholder-md" }),
33
+ });
34
+ const CreateStepButtons = dynamic(() => import('./ui/CreateStepButtons').then((mod) => ({ default: mod.CreateStepButtons })), {
35
+ loading: () => _jsx("div", { className: "rcm-skeleton-placeholder-lg" }),
36
+ });
37
+ /**
38
+ * ViewEntityForm component (render-only structure)
39
+ * - All state/handlers/logic are managed by the useEntityFormLogic hook.
40
+ * - This component is responsible only for rendering structure.
41
+ *
42
+ * ViewEntityForm 컴포넌트 (최소 렌더링 구조)
43
+ * - 모든 상태/핸들러/로직은 useEntityFormLogic 훅에서 관리
44
+ * - 이 컴포넌트는 렌더링 구조만 담당
45
+ *
46
+ * @param props {ViewEntityFormProps} - EntityForm 렌더링에 필요한 모든 속성
47
+ * @returns {JSX.Element|null} - 렌더링 결과 또는 로딩 상태
48
+ */
49
+ export const ViewEntityForm = (props) => {
50
+ // useEntityFormLogic 훅에서 모든 상태/핸들러/로직을 일괄 관리
51
+ // All state/handlers/logic are managed by the useEntityFormLogic hook
52
+ const { entityForm, tabIndex, setTabIndex, cacheKey, loadingError, initialized, errors, notifications, title, selectedTabIndex, setSelectedTabIndex, currentStep, setCurrentStep, showStepper, setShowStepper, tabs, isSubCollectionEntity, isInlineMode, readonly, session, useCreateStep, maxStep, createStepFields, buttons, headerAreaContent, setEntityForm, onClickSaveButton, resetEntityForm, } = useEntityFormLogic(props);
53
+ // 테마 시스템에서 클래스 가져오기
54
+ const { classNames, cn, createStepButtonPosition } = useEntityFormTheme();
55
+ // 로딩/에러/초기화 미완료/필수 데이터 미존재 시 로딩 UI만 표시
56
+ // Show loading UI if loading, error, not initialized, or required data is missing
57
+ const loading = loadingError || !initialized || !entityForm || !tabs || tabs.length === 0;
58
+ if (loading) {
59
+ return (_jsx(ViewEntityFormSkeleton, { ...(entityForm !== undefined ? { entityForm } : {}), inlineMode: isInlineMode, subCollectionEntity: isSubCollectionEntity }));
60
+ }
61
+ // 버튼 위치 결정 (기본값: header)
62
+ // 인라인 모드에서는 탭 영역 옆에 버튼 배치
63
+ const buttonPosition = props.buttonPosition ?? 'header';
64
+ const showButtonsInHeader = buttonPosition === 'header' && !isInlineMode;
65
+ const showButtonsInTabRow = isInlineMode;
66
+ return (_jsxs("div", { id: `view-entity-form-${entityForm.name}${isSubCollectionEntity ? '-sub' : ''}`, className: classNames.root, children: [_jsxs("div", { className: "rcm-form-sticky-header", children: [_jsxs("div", { className: cn('rcm-form-header', classNames.header?.container), children: [_jsx("div", { className: cn('rcm-form-header-title', classNames.header?.titleWrapper), children: _jsx(ViewEntityFormTitle, { title: title, ...(props.hideTitle !== undefined ? { hideTitle: props.hideTitle } : {}) }) }), showButtonsInHeader && (_jsx("div", { className: cn('rcm-form-header-buttons', classNames.header?.buttonWrapper), children: _jsx(ViewEntityFormButtons, { buttons: buttons }) }))] }), headerAreaContent && (_jsx("div", { className: cn('rcm-form-header-area', classNames.headerArea?.container), children: headerAreaContent }))] }), useCreateStep && entityForm && (_jsx(CreateStepView, { currentStep: currentStep, setCurrentStep: setCurrentStep, maxStep: maxStep, entityForm: entityForm, setEntityForm: setEntityForm, onClickSaveButton: onClickSaveButton, showStepper: showStepper, setShowStepper: setShowStepper, session: session ?? undefined, buttonPosition: createStepButtonPosition ?? 'top' })), _jsx(SafePerfectScrollbar, { className: cn('rcm-form-scroll-container', classNames.panel?.scrollContainer), children: _jsx("div", { className: cn('rcm-form-layout-wrapper', classNames.panel?.layoutWrapper), children: _jsx("div", { className: cn(isInlineMode ? 'rcm-form-panel rcm-form-panel-inline' : 'rcm-form-panel', classNames.panel?.container), children: _jsxs("div", { className: cn('rcm-form-panel-inner', classNames.panel?.inner), children: [_jsx(ViewEntityFormAlerts, { alertMessages: entityForm.getAlertMessages(), onRemove: (key) => {
67
+ const updatedForm = entityForm.clone().removeAlertMessage(key);
68
+ setEntityForm(updatedForm);
69
+ }, onTabChange: (tabId) => {
70
+ // tab id로 tab index 찾기
71
+ const index = tabs.findIndex((tab) => tab.id === tabId);
72
+ if (index !== -1) {
73
+ setSelectedTabIndex(index);
74
+ setTabIndex(tabId);
75
+ }
76
+ }, onFieldFocus: (fieldName) => {
77
+ // 필드가 있는 탭 찾기
78
+ const field = entityForm.getField(fieldName);
79
+ if (field) {
80
+ const fieldTabId = field.getTabId();
81
+ if (fieldTabId) {
82
+ const tabIdx = tabs.findIndex((tab) => tab.id === fieldTabId);
83
+ if (tabIdx !== -1) {
84
+ setSelectedTabIndex(tabIdx);
85
+ setTabIndex(fieldTabId);
86
+ // 필드로 스크롤 (약간의 지연 후)
87
+ setTimeout(() => {
88
+ const fieldElement = document.querySelector(`[data-field-name="${fieldName}"]`);
89
+ if (fieldElement) {
90
+ fieldElement.scrollIntoView({ behavior: 'smooth', block: 'center' });
91
+ // 포커스 효과 추가 (선택사항)
92
+ fieldElement.classList.add('rcm-field-focus-ring');
93
+ setTimeout(() => {
94
+ fieldElement.classList.remove('rcm-field-focus-ring');
95
+ }, 2000);
96
+ }
97
+ }, 100);
98
+ }
99
+ }
100
+ }
101
+ } }), _jsx(ViewEntityFormErrors, { errors: errors, entityErrorMap: entityForm.getErrorMap(), notifications: notifications, onTabChange: (tabIndex) => {
102
+ clearAllToasts();
103
+ setSelectedTabIndex(tabIndex);
104
+ if (tabs[tabIndex]) {
105
+ setTabIndex(tabs[tabIndex].id);
106
+ }
107
+ }, tabs: tabs, entityForm: entityForm }), _jsxs(Tab.Group, { selectedIndex: selectedTabIndex, onChange: (index) => {
108
+ clearAllToasts();
109
+ setSelectedTabIndex(index);
110
+ }, children: [showButtonsInTabRow && (_jsxs("div", { className: `rcm-form-tab-row ${tabs.length > 1 ? 'rcm-form-tab-row-border' : ''}`, children: [_jsx("div", { className: "rcm-form-tab-row-tabs", children: tabs.length > 1 && (_jsx(Tab.List, { className: cn('rcm-tab-list-inline', useCreateStep ? 'rcm-hide' : undefined), children: tabs.map((tab, index) => (_jsx(ViewTab, { id: tab.id, label: tab.label, tabIndex: tabIndex, description: tab.description, entityForm: entityForm, createStepFields: createStepFields, setTabIndex: setTabIndex }, `${index}_${cacheKey}_tab`))) })) }), _jsx("div", { className: "rcm-form-tab-buttons", children: _jsx(ViewEntityFormButtons, { buttons: buttons }) })] })), !showButtonsInTabRow && tabs.length > 1 && (_jsx(SafePerfectScrollbar, { className: cn(useCreateStep ? 'rcm-hide' : 'rcm-tab-scroll'), children: _jsx(Tab.List, { className: cn('rcm-tab-list', classNames.tabs?.list), children: (function () {
111
+ const tabsView = [];
112
+ tabs.forEach((tab, index) => {
113
+ tabsView.push(_jsx(ViewTab, { id: tab.id, label: tab.label, tabIndex: tabIndex, description: tab.description, entityForm: entityForm, createStepFields: createStepFields, setTabIndex: setTabIndex }, `${index}_${cacheKey}_tab`));
114
+ });
115
+ return tabsView;
116
+ })() }) })), _jsx(Tab.Panels, { children: (function () {
117
+ const panels = [];
118
+ tabs.forEach((tab, index) => {
119
+ panels.push(_jsx(ViewTabPanel, { id: tab.id, tabIndex: tabIndex, readonly: readonly, subCollectionEntity: isSubCollectionEntity, session: session ?? undefined, createStepFields: createStepFields, entityForm: entityForm, setEntityForm: setEntityForm, resetEntityForm: resetEntityForm, hideMappedByFields: props.hideMappedByFields }, `${index}_${cacheKey}`));
120
+ });
121
+ return panels;
122
+ })() })] }), !showButtonsInTabRow && (_jsxs("div", { className: cn('rcm-form-footer', classNames.footer?.container), children: [useCreateStep && createStepButtonPosition === 'bottom' && entityForm && (_jsx(CreateStepButtons, { currentStep: currentStep, maxStep: maxStep, entityForm: entityForm, setEntityForm: setEntityForm, setCurrentStep: setCurrentStep, onClickSaveButton: onClickSaveButton, session: session ?? undefined })), !showButtonsInHeader &&
123
+ !(useCreateStep && createStepButtonPosition === 'bottom') && (_jsx(ViewEntityFormButtons, { buttons: buttons }))] }))] }) }) }) })] }));
124
+ };
@@ -0,0 +1,27 @@
1
+ import { EntityFormManageable } from './types/ViewEntityForm.types';
2
+ import { Session } from '../../auth/types';
3
+ /**
4
+ * ViewFieldGroup component
5
+ * - Renders a group of fields and sub-collections for a given tab/group in EntityForm.
6
+ * - Handles collapsible panels, help text, and readonly/sub-collection logic.
7
+ *
8
+ * ViewFieldGroup 컴포넌트
9
+ * - EntityForm의 탭/그룹별 필드 및 서브콜렉션을 렌더링합니다.
10
+ * - 접기/펼치기, 도움말, 읽기전용/서브콜렉션 로직을 처리합니다.
11
+ *
12
+ * @param props {ViewFieldGroupProps} - 탭/그룹/EntityForm 정보 등
13
+ * @returns {JSX.Element|null} - 렌더링 결과 또는 null
14
+ */
15
+ interface ViewFieldGroupProps extends EntityFormManageable {
16
+ groupId: string;
17
+ tabId: string;
18
+ readonly: boolean;
19
+ subCollectionEntity?: boolean;
20
+ session?: Session;
21
+ createStepFields?: string[];
22
+ resetEntityForm?: (delay?: number, preserveState?: boolean) => Promise<void>;
23
+ /** MappedBy field name for hiding parent reference fields in SubCollection */
24
+ hideMappedByFields?: string;
25
+ }
26
+ export declare const ViewFieldGroup: ({ entityForm, setEntityForm, readonly, subCollectionEntity, session, createStepFields, hideMappedByFields, ...props }: ViewFieldGroupProps) => import("react/jsx-runtime").JSX.Element | null;
27
+ export {};
@@ -0,0 +1,164 @@
1
+ 'use client';
2
+ import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
3
+ import { useEffect, useMemo, useState } from 'react';
4
+ import { FormField, FULL_WIDTH_FIELD_TYPES } from '../fields/abstract';
5
+ import { FieldRenderer } from './FieldRenderer';
6
+ import { isEmpty } from '../../utils';
7
+ import { SubCollectionRenderer } from './SubCollectionRenderer';
8
+ import { getTranslation } from '../../utils/i18n';
9
+ import { isBlank } from '../../utils/StringUtil';
10
+ import { ViewHelpIcon } from './ui/ViewHelpIcon';
11
+ import { useEntityFormTheme } from './context/EntityFormThemeContext';
12
+ /**
13
+ * Determine grid col-span class based on field layout type.
14
+ * Uses library-owned `rcm-col-span-full` (defined in base.css) instead of
15
+ * Tailwind's `col-span-full` — the host's Tailwind content scanner does not
16
+ * include @rchemist/listgrid sources in node_modules, so Tailwind utilities
17
+ * placed inside library JSX never get generated.
18
+ */
19
+ function getFieldColSpanClass(field) {
20
+ if (field.layout === 'full')
21
+ return 'rcm-col-span-full';
22
+ if (field.layout === 'half')
23
+ return '';
24
+ // auto: FULL_WIDTH_FIELD_TYPES get full width
25
+ if (FULL_WIDTH_FIELD_TYPES.includes(field.type))
26
+ return 'rcm-col-span-full';
27
+ return '';
28
+ }
29
+ export const ViewFieldGroup = ({ entityForm, setEntityForm, readonly, subCollectionEntity, session, createStepFields, hideMappedByFields, ...props }) => {
30
+ const { classNames, cn } = useEntityFormTheme();
31
+ // 현재 그룹의 필드, 서브콜렉션, 그룹 정보 상태
32
+ // State for fields, sub-collections, and group info in this group
33
+ const [fields, setFields] = useState();
34
+ const [subCollections, setSubCollections] = useState();
35
+ const [fieldGroup, setFieldGroup] = useState();
36
+ const [open, setOpen] = useState(true); // 패널 열림/닫힘 상태
37
+ const [collapsable, setCollapsable] = useState(true); // 접기/펼치기 가능 여부
38
+ /**
39
+ * Filter fields based on hideMappedByFields (mappedBy field name)
40
+ * SubCollection에서 부모 참조 필드 자동 숨김 처리
41
+ *
42
+ * Filters out:
43
+ * - Exact mappedBy field (e.g., "studentId", "enrollment.student.id")
44
+ * - Base field without Id/.id suffix (e.g., "student" from "studentId", "enrollment.student" from "enrollment.student.id")
45
+ * - Nested patterns (e.g., "student.name", "enrollment.student.name")
46
+ *
47
+ * 예시:
48
+ * - mappedBy="studentId" → studentId, student, student.* 숨김
49
+ * - mappedBy="enrollment.student.id" → enrollment.student.id, enrollment.student, enrollment.student.* 숨김
50
+ */
51
+ const filteredFields = useMemo(() => {
52
+ if (!fields || !hideMappedByFields || hideMappedByFields.trim() === '') {
53
+ return fields;
54
+ }
55
+ const mappedBy = hideMappedByFields.trim();
56
+ // Generate patterns to exclude
57
+ const patternsToExclude = new Set();
58
+ // 1. Exact mappedBy field (e.g., "studentId", "enrollment.student.id")
59
+ patternsToExclude.add(mappedBy);
60
+ // 2. Base field without Id/.id suffix
61
+ let baseField = mappedBy;
62
+ // Handle "studentId" format (camelCase Id suffix)
63
+ if (mappedBy.endsWith('Id')) {
64
+ baseField = mappedBy.slice(0, -2);
65
+ }
66
+ // Handle "enrollment.student.id" format (dot notation .id suffix)
67
+ else if (mappedBy.endsWith('.id')) {
68
+ baseField = mappedBy.slice(0, -3);
69
+ }
70
+ patternsToExclude.add(baseField);
71
+ // 3. Nested pattern prefix (e.g., "student.", "enrollment.student.")
72
+ const nestedPattern = `${baseField}.`;
73
+ return fields.filter((field) => {
74
+ if (!(field instanceof FormField)) {
75
+ return true; // Keep non-FormField items
76
+ }
77
+ const fieldName = field.getName();
78
+ // Exact match - exclude
79
+ if (patternsToExclude.has(fieldName)) {
80
+ return false;
81
+ }
82
+ // Nested pattern match - exclude (e.g., student.name, enrollment.student.name)
83
+ if (fieldName.startsWith(nestedPattern)) {
84
+ return false;
85
+ }
86
+ return true;
87
+ });
88
+ }, [fields, hideMappedByFields]);
89
+ useEffect(() => {
90
+ // 마운트 시 필드/서브콜렉션/그룹 정보 비동기 조회
91
+ // On mount, fetch fields, sub-collections, and group info asynchronously
92
+ (async () => {
93
+ const fieldInfo = await entityForm?.getVisibleFields(props.tabId, props.groupId, session, createStepFields);
94
+ setFieldGroup(fieldInfo?.fieldGroup);
95
+ setFields(fieldInfo?.fields ?? []);
96
+ // fieldGroup의 config.open 값으로 초기 상태 설정
97
+ // Set initial state based on fieldGroup's config.open value
98
+ if (fieldInfo?.fieldGroup) {
99
+ setOpen(fieldInfo.fieldGroup.config?.open ?? true);
100
+ }
101
+ const collectionInfo = await entityForm?.getVisibleCollections(props.tabId, props.groupId, session);
102
+ setSubCollections(collectionInfo?.collections ?? []);
103
+ let collapsable = false;
104
+ // 두 개 이상의 fieldGroup이 있고, 현재 그룹이 hidden이 아니면 접기/펼치기 활성화
105
+ // Enable collapsible if there are multiple fieldGroups and this group is not hidden
106
+ const fieldGroups = entityForm.getTab(props.tabId)?.fieldGroups ?? [];
107
+ if (fieldGroups.length > 1) {
108
+ for (const fieldGroup of fieldGroups) {
109
+ if (fieldGroup.id !== props.groupId &&
110
+ (await entityForm.isViewableFieldGroup({
111
+ tabId: props.tabId,
112
+ fieldGroupId: fieldGroup.id,
113
+ createStepFields,
114
+ }))) {
115
+ collapsable = true;
116
+ break;
117
+ }
118
+ }
119
+ }
120
+ setCollapsable(collapsable);
121
+ })();
122
+ }, []);
123
+ // 필드 또는 서브콜렉션이 하나라도 있으면 표시 (필터링된 필드 기준)
124
+ // Show if there is at least one field or sub-collection (using filtered fields)
125
+ const showFields = !isEmpty(filteredFields);
126
+ const showCollections = entityForm?.id !== undefined && !isEmpty(subCollections);
127
+ // 그룹 정보가 없거나, 표시할 필드/서브콜렉션이 없으면 렌더링하지 않음
128
+ // If no group info or nothing to show, do not render
129
+ if (fieldGroup === undefined || !(showFields || showCollections))
130
+ return null;
131
+ const { t } = getTranslation();
132
+ const helpText = fieldGroup.description ? t(fieldGroup.description) : '';
133
+ // SubCollection 인라인 모드: 컴팩트한 패널 박스 스타일
134
+ // SubCollection inline mode: compact panel box style
135
+ const containerClass = subCollectionEntity
136
+ ? 'rcm-fieldgroup-subcollection'
137
+ : cn('rcm-fieldgroup', classNames.fieldGroup?.container);
138
+ return (_jsx(_Fragment, { children: _jsxs("div", { className: containerClass, children: [_jsx("div", { className: cn(open ? 'rcm-fieldgroup-header' : '', subCollectionEntity ? '' : classNames.fieldGroup?.header), children: _jsx("div", { className: "rcm-row-between", children: _jsxs("h5", { className: cn('rcm-fieldgroup-title', subCollectionEntity ? '' : classNames.fieldGroup?.title), children: [fieldGroup.label, _jsxs("div", { className: cn('rcm-row rcm-gap-sm', subCollectionEntity ? '' : classNames.fieldGroup?.actions), children: [!isBlank(helpText) && _jsx(ViewHelpIcon, { helpText: helpText }), collapsable && (_jsx("span", { className: cn('rcm-fieldgroup-collapse', subCollectionEntity ? '' : classNames.fieldGroup?.collapseToggle), onClick: () => {
139
+ setOpen(!open);
140
+ }, children: _jsx("div", { className: open ? '' : 'rcm-rotate-180', children: _jsx("svg", { xmlns: "http://www.w3.org/2000/svg", width: "12", height: "12", viewBox: "0 0 24 24", fill: "none", children: _jsx("path", { stroke: "#5B6B79", strokeLinecap: "round", strokeLinejoin: "round", strokeMiterlimit: "10", strokeWidth: "1.5", d: "M19.92 15.05L13.4 8.53c-.77-.77-2.03-.77-2.8 0l-6.52 6.52" }) }) }) }))] })] }) }) }), open && (_jsxs("div", { className: cn(subCollectionEntity ? 'rcm-stack' : 'rcm-field-grid', subCollectionEntity ? undefined : classNames.fieldGroup?.content), children: [filteredFields?.map((field, index) => {
141
+ if (field instanceof FormField) {
142
+ if (readonly) {
143
+ field.withReadOnly(true);
144
+ }
145
+ // If the previous field has lineBreak, force this field to start at column 1
146
+ const prevField = index > 0 ? filteredFields?.[index - 1] : null;
147
+ const forceNewRow = prevField instanceof FormField && prevField.lineBreak;
148
+ const colSpanClass = getFieldColSpanClass(field);
149
+ const className = forceNewRow ? `${colSpanClass} rcm-col-start-1-lg` : colSpanClass;
150
+ return (_jsx("div", { className: className, children: _jsx(FieldRenderer, { field: field, entityForm: entityForm, ...(setEntityForm !== undefined ? { setEntityForm } : {}), ...(subCollectionEntity !== undefined ? { subCollectionEntity } : {}), ...(session !== undefined ? { session } : {}), ...(props.resetEntityForm !== undefined
151
+ ? { resetEntityForm: props.resetEntityForm }
152
+ : {}) }) }, field.getName()));
153
+ }
154
+ else {
155
+ return null;
156
+ }
157
+ }), showCollections &&
158
+ subCollections?.map((collection) => {
159
+ if (readonly) {
160
+ collection.withReadOnly(true);
161
+ }
162
+ return (_jsx("div", { className: "rcm-col-span-full", children: _jsx(SubCollectionRenderer, { entityForm: entityForm, collection: collection, ...(session !== undefined ? { session } : {}) }) }, `subCollection_${collection.getName()}_${entityForm.id}`));
163
+ })] }))] }) }));
164
+ };
@@ -0,0 +1,24 @@
1
+ import React from 'react';
2
+ import { TabIndexable } from './types/ViewEntityForm.types';
3
+ import { EntityForm } from '../../config/EntityForm';
4
+ /**
5
+ * ViewTab component
6
+ * - Renders a single tab button for EntityForm's tab navigation.
7
+ * - Handles tab selection, description tooltip, and dynamic field group visibility.
8
+ *
9
+ * ViewTab 컴포넌트
10
+ * - EntityForm의 탭 네비게이션에서 단일 탭 버튼을 렌더링합니다.
11
+ * - 탭 선택, 설명 툴팁, 동적 필드 그룹 표시를 처리합니다.
12
+ *
13
+ * @param props {ViewTabProps} - 탭 정보, 인덱스, EntityForm 인스턴스 등
14
+ * @returns {JSX.Element|null} - 렌더링 결과 또는 null
15
+ */
16
+ interface ViewTabProps extends TabIndexable {
17
+ id: string;
18
+ label: string;
19
+ description?: string | React.ReactNode;
20
+ entityForm: EntityForm;
21
+ createStepFields?: string[];
22
+ }
23
+ export declare const ViewTab: ({ id, tabIndex, label, setTabIndex, entityForm, createStepFields, ...props }: ViewTabProps) => import("react/jsx-runtime").JSX.Element;
24
+ export {};
@@ -0,0 +1,68 @@
1
+ 'use client';
2
+ import { jsx as _jsx } from "react/jsx-runtime";
3
+ import { Fragment, useEffect, useState } from 'react';
4
+ import { Tab } from '@headlessui/react';
5
+ import { Tooltip } from '../../ui';
6
+ import { getTranslation } from '../../utils/i18n';
7
+ import { useEntityFormTheme } from './context/EntityFormThemeContext';
8
+ export const ViewTab = ({ id, tabIndex, label, setTabIndex, entityForm, createStepFields, ...props }) => {
9
+ const { classNames, cn } = useEntityFormTheme();
10
+ // 현재 탭에서 표시할 필드 그룹 id 목록
11
+ // List of field group ids to display in this tab
12
+ const [groups, setGroups] = useState([]);
13
+ useEffect(() => {
14
+ // 탭이 마운트될 때, 표시 가능한 필드 그룹 목록을 비동기로 조회
15
+ // On mount, fetch viewable field groups for this tab asynchronously
16
+ (async () => {
17
+ const viewableFieldGroups = await entityForm.getViewableFieldGroups({
18
+ tabId: id,
19
+ createStepFields,
20
+ });
21
+ setGroups(viewableFieldGroups);
22
+ })();
23
+ }, [id, createStepFields?.join(','), entityForm]); // tabIndex 의존성 제거, createStepFields를 문자열로 변환
24
+ // CreateStep에서 필드가 없는 탭은 숨김 처리하되 null 반환하지 않음
25
+ // 이렇게 해야 Tab.Group의 selectedIndex가 깨지지 않음
26
+ const hasContent = groups.length > 0;
27
+ const { t } = getTranslation();
28
+ // description이 string이면 번역, 아니면 그대로 사용
29
+ // If description is a string, translate it; otherwise, use as is
30
+ let description = undefined;
31
+ if (props.description !== undefined) {
32
+ if (typeof props.description === 'string') {
33
+ description = t(props.description);
34
+ }
35
+ else {
36
+ description = props.description;
37
+ }
38
+ }
39
+ /**
40
+ * ShowButton
41
+ * - 실제 탭 버튼 렌더링 및 선택 처리
42
+ * - 선택 시 스타일 강조, 클릭 시 setTabIndex 호출
43
+ *
44
+ * 실제로는 headlessui의 Tab 컴포넌트와 연동됨
45
+ *
46
+ * @param selected {boolean} - 현재 탭이 선택되었는지 여부
47
+ * @returns {JSX.Element} - 버튼 렌더링
48
+ */
49
+ function ShowButton(selected) {
50
+ // primitive + data-state: rcm-tab 기본 + [data-state="selected"|"disabled"]
51
+ let buttonClass = cn('rcm-tab', classNames.tabs?.tab);
52
+ if (selected) {
53
+ buttonClass = cn(buttonClass, classNames.tabs?.tabSelected);
54
+ }
55
+ if (!hasContent) {
56
+ buttonClass = cn(buttonClass, classNames.tabs?.tabDisabled);
57
+ }
58
+ const dataState = !hasContent ? 'disabled' : selected ? 'selected' : undefined;
59
+ return (_jsx("div", { style: { display: hasContent ? 'block' : 'none' }, children: _jsx("button", { className: buttonClass, "data-state": dataState, onClick: () => {
60
+ if (hasContent) {
61
+ setTabIndex?.(id);
62
+ }
63
+ }, disabled: !hasContent, children: label }) }));
64
+ }
65
+ // description이 있으면 Tooltip으로 감싸서 렌더링, 없으면 바로 버튼 렌더링
66
+ // If description exists, wrap with Tooltip; otherwise, render button directly
67
+ return (_jsx(Tab, { as: Fragment, children: ({ selected }) => description === undefined ? (ShowButton(selected)) : (_jsx(Tooltip, { label: description, children: ShowButton(selected) })) }));
68
+ };
@@ -0,0 +1,14 @@
1
+ import { EntityFormManageable, TabIndexable } from './types/ViewEntityForm.types';
2
+ import { Session } from '../../auth/types';
3
+ interface ViewTabPanelProps extends TabIndexable, EntityFormManageable {
4
+ id: string;
5
+ readonly: boolean;
6
+ subCollectionEntity?: boolean;
7
+ session?: Session;
8
+ createStepFields?: string[];
9
+ resetEntityForm?: (delay?: number, preserveState?: boolean) => Promise<void>;
10
+ /** MappedBy field name for hiding parent reference fields in SubCollection */
11
+ hideMappedByFields?: string;
12
+ }
13
+ export declare const ViewTabPanel: ({ id, tabIndex, entityForm, setEntityForm, readonly, subCollectionEntity, session, createStepFields, resetEntityForm, hideMappedByFields, ...props }: ViewTabPanelProps) => import("react/jsx-runtime").JSX.Element;
14
+ export {};
@@ -0,0 +1,32 @@
1
+ 'use client';
2
+ import { jsx as _jsx } from "react/jsx-runtime";
3
+ import { Tab } from '@headlessui/react';
4
+ import { useEffect, useState } from 'react';
5
+ import { ViewFieldGroup } from './ViewFieldGroup';
6
+ import { useEntityFormTheme } from './context/EntityFormThemeContext';
7
+ export const ViewTabPanel = ({ id, tabIndex, entityForm, setEntityForm, readonly, subCollectionEntity, session, createStepFields, resetEntityForm, hideMappedByFields, ...props }) => {
8
+ const { classNames, cn } = useEntityFormTheme();
9
+ const [groups, setGroups] = useState([]);
10
+ useEffect(() => {
11
+ setGroups([]);
12
+ (async () => {
13
+ const viewableFieldGroups = await entityForm.getViewableFieldGroups({
14
+ tabId: id,
15
+ createStepFields,
16
+ });
17
+ setGroups(viewableFieldGroups);
18
+ })();
19
+ }, [id, createStepFields?.join(','), entityForm]); // tabIndex 의존성 제거, createStepFields를 문자열로 변환하여 안정적인 비교
20
+ // Tab.Group에서 자동으로 활성화/비활성화되므로 별도의 조건 체크 제거
21
+ // Tab.Group automatically handles activation/deactivation, so remove separate condition check
22
+ if (groups.length === 0) {
23
+ return (_jsx(Tab.Panel, { className: classNames.tabPanel?.panel, unmount: false, children: _jsx("div", { className: cn('p-4 text-gray-500 dark:text-gray-400', classNames.tabPanel?.empty), children: "\uC774 \uB2E8\uACC4\uC5D0\uC11C\uB294 \uD45C\uC2DC\uD560 \uB0B4\uC6A9\uC774 \uC5C6\uC2B5\uB2C8\uB2E4." }) }));
24
+ }
25
+ return (_jsx(Tab.Panel, { className: classNames.tabPanel?.panel, unmount: false, children: _jsx("div", { className: cn('pt-2 md:pt-3', classNames.tabPanel?.content), children: (function () {
26
+ const panels = [];
27
+ groups.forEach((group, index) => {
28
+ panels.push(_jsx("div", { children: _jsx(ViewFieldGroup, { tabId: id, groupId: group, readonly: readonly, ...(subCollectionEntity !== undefined ? { subCollectionEntity } : {}), entityForm: entityForm, ...(setEntityForm !== undefined ? { setEntityForm } : {}), ...(session !== undefined ? { session } : {}), ...(createStepFields !== undefined ? { createStepFields } : {}), ...(resetEntityForm !== undefined ? { resetEntityForm } : {}), ...(hideMappedByFields !== undefined ? { hideMappedByFields } : {}) }, index) }, `${group}-${index}-${createStepFields ? createStepFields?.join(',') : ''}`));
29
+ });
30
+ return panels;
31
+ })() }) }));
32
+ };
@@ -0,0 +1,52 @@
1
+ import React from 'react';
2
+ import { EntityFormThemeContextValue, EntityFormThemeProviderProps } from '../types/ViewEntityFormTheme.types';
3
+ /**
4
+ * EntityForm 테마 컨텍스트
5
+ * ViewEntityForm과 하위 컴포넌트에서 스타일을 커스터마이징하는데 사용
6
+ */
7
+ declare const EntityFormThemeContext: React.Context<EntityFormThemeContextValue>;
8
+ /**
9
+ * EntityForm 테마 Provider
10
+ *
11
+ * 사이트별로 다른 테마를 적용할 때 사용합니다.
12
+ * 기본 테마에 커스텀 테마를 deep merge합니다.
13
+ *
14
+ * @example
15
+ * ```tsx
16
+ * // 사이트 A의 layout.tsx
17
+ * import { EntityFormThemeProvider } from '../../../listgrid-compat';
18
+ *
19
+ * const siteATheme = {
20
+ * header: { container: 'mt-2 bg-blue-50 rounded-lg p-4' },
21
+ * title: { text: 'text-2xl font-medium text-blue-800' },
22
+ * buttons: { save: 'btn bg-blue-600 text-white hover:bg-blue-700' },
23
+ * };
24
+ *
25
+ * export default function RootLayout({ children }) {
26
+ * return (
27
+ * <EntityFormThemeProvider theme={siteATheme}>
28
+ * {children}
29
+ * </EntityFormThemeProvider>
30
+ * );
31
+ * }
32
+ * ```
33
+ */
34
+ export declare const EntityFormThemeProvider: React.FC<EntityFormThemeProviderProps>;
35
+ /**
36
+ * EntityForm 테마 훅
37
+ *
38
+ * ViewEntityForm의 하위 컴포넌트에서 테마 클래스를 가져올 때 사용합니다.
39
+ *
40
+ * @example
41
+ * ```tsx
42
+ * const { classNames, cn } = useEntityFormTheme();
43
+ *
44
+ * return (
45
+ * <div className={cn('flex items-center', classNames.header?.container)}>
46
+ * ...
47
+ * </div>
48
+ * );
49
+ * ```
50
+ */
51
+ export declare const useEntityFormTheme: () => EntityFormThemeContextValue;
52
+ export { EntityFormThemeContext };
@@ -0,0 +1,129 @@
1
+ 'use client';
2
+ 'use client';
3
+ import { jsx as _jsx } from "react/jsx-runtime";
4
+ import { createContext, useContext, useMemo } from 'react';
5
+ import { cn as cnUtil } from '../../../utils/cn';
6
+ import { defaultEntityFormTheme } from '../themes/defaultTheme';
7
+ /**
8
+ * 두 객체를 깊게 병합하는 유틸리티
9
+ * 커스텀 테마가 기본 테마를 오버라이드
10
+ */
11
+ const deepMerge = (base, override) => {
12
+ if (!override)
13
+ return base;
14
+ const result = { ...base };
15
+ for (const key in override) {
16
+ if (Object.prototype.hasOwnProperty.call(override, key)) {
17
+ const baseValue = base[key];
18
+ const overrideValue = override[key];
19
+ if (baseValue &&
20
+ overrideValue &&
21
+ typeof baseValue === 'object' &&
22
+ typeof overrideValue === 'object' &&
23
+ !Array.isArray(baseValue) &&
24
+ !Array.isArray(overrideValue)) {
25
+ // 중첩 객체 병합
26
+ result[key] = deepMerge(baseValue, overrideValue);
27
+ }
28
+ else if (overrideValue !== undefined) {
29
+ // 값 오버라이드
30
+ result[key] = overrideValue;
31
+ }
32
+ }
33
+ }
34
+ return result;
35
+ };
36
+ /**
37
+ * EntityForm 테마 컨텍스트
38
+ * ViewEntityForm과 하위 컴포넌트에서 스타일을 커스터마이징하는데 사용
39
+ */
40
+ const EntityFormThemeContext = createContext({
41
+ classNames: defaultEntityFormTheme,
42
+ cn: (base, custom) => (custom ? cnUtil(base, custom) : base),
43
+ getFieldRenderer: () => undefined,
44
+ createStepButtonPosition: 'top',
45
+ });
46
+ /**
47
+ * EntityForm 테마 Provider
48
+ *
49
+ * 사이트별로 다른 테마를 적용할 때 사용합니다.
50
+ * 기본 테마에 커스텀 테마를 deep merge합니다.
51
+ *
52
+ * @example
53
+ * ```tsx
54
+ * // 사이트 A의 layout.tsx
55
+ * import { EntityFormThemeProvider } from '../../../listgrid-compat';
56
+ *
57
+ * const siteATheme = {
58
+ * header: { container: 'mt-2 bg-blue-50 rounded-lg p-4' },
59
+ * title: { text: 'text-2xl font-medium text-blue-800' },
60
+ * buttons: { save: 'btn bg-blue-600 text-white hover:bg-blue-700' },
61
+ * };
62
+ *
63
+ * export default function RootLayout({ children }) {
64
+ * return (
65
+ * <EntityFormThemeProvider theme={siteATheme}>
66
+ * {children}
67
+ * </EntityFormThemeProvider>
68
+ * );
69
+ * }
70
+ * ```
71
+ */
72
+ export const EntityFormThemeProvider = ({ theme, fieldRenderers, buttonLabels, stepperRenderer, createStepButtonPosition, children, }) => {
73
+ const value = useMemo(() => {
74
+ // 기본 테마와 커스텀 테마를 deep merge
75
+ const mergedClassNames = deepMerge(defaultEntityFormTheme, theme);
76
+ const base = {
77
+ classNames: mergedClassNames,
78
+ cn: (base, custom) => {
79
+ if (!custom)
80
+ return base;
81
+ return cnUtil(base, custom);
82
+ },
83
+ getFieldRenderer: (fieldName) => {
84
+ return fieldRenderers?.[fieldName];
85
+ },
86
+ };
87
+ if (fieldRenderers !== undefined)
88
+ base.fieldRenderers = fieldRenderers;
89
+ if (buttonLabels !== undefined)
90
+ base.buttonLabels = buttonLabels;
91
+ if (stepperRenderer !== undefined)
92
+ base.stepperRenderer = stepperRenderer;
93
+ if (createStepButtonPosition !== undefined) {
94
+ base.createStepButtonPosition = createStepButtonPosition;
95
+ }
96
+ return base;
97
+ }, [theme, fieldRenderers, buttonLabels, stepperRenderer, createStepButtonPosition]);
98
+ return (_jsx(EntityFormThemeContext.Provider, { value: value, children: children }));
99
+ };
100
+ /**
101
+ * EntityForm 테마 훅
102
+ *
103
+ * ViewEntityForm의 하위 컴포넌트에서 테마 클래스를 가져올 때 사용합니다.
104
+ *
105
+ * @example
106
+ * ```tsx
107
+ * const { classNames, cn } = useEntityFormTheme();
108
+ *
109
+ * return (
110
+ * <div className={cn('flex items-center', classNames.header?.container)}>
111
+ * ...
112
+ * </div>
113
+ * );
114
+ * ```
115
+ */
116
+ export const useEntityFormTheme = () => {
117
+ const context = useContext(EntityFormThemeContext);
118
+ if (!context) {
119
+ // Context가 없으면 기본값 반환 (Provider 없이도 동작)
120
+ return {
121
+ classNames: defaultEntityFormTheme,
122
+ cn: (base, custom) => (custom ? cnUtil(base, custom) : base),
123
+ getFieldRenderer: () => undefined,
124
+ createStepButtonPosition: 'top',
125
+ };
126
+ }
127
+ return context;
128
+ };
129
+ export { EntityFormThemeContext };
@@ -0,0 +1 @@
1
+ export { EntityFormThemeProvider, useEntityFormTheme, EntityFormThemeContext, } from './EntityFormThemeContext';