@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.
- package/LICENSE +201 -0
- package/README.md +343 -0
- package/dist/adapters/next/NextListGridProvider.d.ts +5 -0
- package/dist/adapters/next/NextListGridProvider.js +7 -0
- package/dist/adapters/next/NextRouterAdapter.d.ts +2 -0
- package/dist/adapters/next/NextRouterAdapter.js +34 -0
- package/dist/adapters/next/NextUrlStateAdapter.d.ts +2 -0
- package/dist/adapters/next/NextUrlStateAdapter.js +31 -0
- package/dist/adapters/next/index.d.ts +4 -0
- package/dist/adapters/next/index.js +12 -0
- package/dist/index.d.ts +1 -0
- package/dist/index.js +3 -0
- package/dist/listgrid/api/ApiClient.d.ts +20 -0
- package/dist/listgrid/api/ApiClient.js +32 -0
- package/dist/listgrid/api/index.d.ts +4 -0
- package/dist/listgrid/api/index.js +2 -0
- package/dist/listgrid/api/types.d.ts +21 -0
- package/dist/listgrid/api/types.js +30 -0
- package/dist/listgrid/auth/AuthContext.d.ts +12 -0
- package/dist/listgrid/auth/AuthContext.js +25 -0
- package/dist/listgrid/auth/SessionProvider.d.ts +4 -0
- package/dist/listgrid/auth/SessionProvider.js +16 -0
- package/dist/listgrid/auth/index.d.ts +6 -0
- package/dist/listgrid/auth/index.js +17 -0
- package/dist/listgrid/auth/types.d.ts +15 -0
- package/dist/listgrid/auth/types.js +12 -0
- package/dist/listgrid/common/func.d.ts +16 -0
- package/dist/listgrid/common/func.js +351 -0
- package/dist/listgrid/common/type.d.ts +35 -0
- package/dist/listgrid/common/type.js +46 -0
- package/dist/listgrid/components/api/ApiSpecificationButton.d.ts +5 -0
- package/dist/listgrid/components/api/ApiSpecificationButton.js +16 -0
- package/dist/listgrid/components/api/Type.d.ts +23 -0
- package/dist/listgrid/components/api/Type.js +8 -0
- package/dist/listgrid/components/api/ViewApiSpecification.d.ts +2 -0
- package/dist/listgrid/components/api/ViewApiSpecification.js +32 -0
- package/dist/listgrid/components/fields/ApplyFullAddressFields.d.ts +45 -0
- package/dist/listgrid/components/fields/ApplyFullAddressFields.js +177 -0
- package/dist/listgrid/components/fields/BirthdayField.d.ts +39 -0
- package/dist/listgrid/components/fields/BirthdayField.js +205 -0
- package/dist/listgrid/components/fields/BooleanField.d.ts +38 -0
- package/dist/listgrid/components/fields/BooleanField.js +141 -0
- package/dist/listgrid/components/fields/CheckboxField.d.ts +23 -0
- package/dist/listgrid/components/fields/CheckboxField.js +33 -0
- package/dist/listgrid/components/fields/ColorField.d.ts +18 -0
- package/dist/listgrid/components/fields/ColorField.js +63 -0
- package/dist/listgrid/components/fields/ColorPresetField.d.ts +19 -0
- package/dist/listgrid/components/fields/ColorPresetField.js +56 -0
- package/dist/listgrid/components/fields/CustomOptionField.d.ts +45 -0
- package/dist/listgrid/components/fields/CustomOptionField.js +176 -0
- package/dist/listgrid/components/fields/DateField.d.ts +34 -0
- package/dist/listgrid/components/fields/DateField.js +116 -0
- package/dist/listgrid/components/fields/DatetimeField.d.ts +29 -0
- package/dist/listgrid/components/fields/DatetimeField.js +93 -0
- package/dist/listgrid/components/fields/EmailField.d.ts +37 -0
- package/dist/listgrid/components/fields/EmailField.js +144 -0
- package/dist/listgrid/components/fields/FileField.d.ts +36 -0
- package/dist/listgrid/components/fields/FileField.js +157 -0
- package/dist/listgrid/components/fields/HtmlField.d.ts +24 -0
- package/dist/listgrid/components/fields/HtmlField.js +70 -0
- package/dist/listgrid/components/fields/ImageField.d.ts +34 -0
- package/dist/listgrid/components/fields/ImageField.js +125 -0
- package/dist/listgrid/components/fields/InlineMapField.d.ts +40 -0
- package/dist/listgrid/components/fields/InlineMapField.js +85 -0
- package/dist/listgrid/components/fields/LinkField.d.ts +26 -0
- package/dist/listgrid/components/fields/LinkField.js +61 -0
- package/dist/listgrid/components/fields/ManyToOneField.d.ts +80 -0
- package/dist/listgrid/components/fields/ManyToOneField.js +416 -0
- package/dist/listgrid/components/fields/MappedJoinField.d.ts +16 -0
- package/dist/listgrid/components/fields/MappedJoinField.js +29 -0
- package/dist/listgrid/components/fields/MarkdownField.d.ts +20 -0
- package/dist/listgrid/components/fields/MarkdownField.js +58 -0
- package/dist/listgrid/components/fields/MessageViewField.d.ts +20 -0
- package/dist/listgrid/components/fields/MessageViewField.js +27 -0
- package/dist/listgrid/components/fields/MonthField.d.ts +25 -0
- package/dist/listgrid/components/fields/MonthField.js +68 -0
- package/dist/listgrid/components/fields/MultiSelectField.d.ts +59 -0
- package/dist/listgrid/components/fields/MultiSelectField.js +74 -0
- package/dist/listgrid/components/fields/MultipleAssetField.d.ts +31 -0
- package/dist/listgrid/components/fields/MultipleAssetField.js +200 -0
- package/dist/listgrid/components/fields/NumberField.d.ts +54 -0
- package/dist/listgrid/components/fields/NumberField.js +216 -0
- package/dist/listgrid/components/fields/PasswordField.d.ts +23 -0
- package/dist/listgrid/components/fields/PasswordField.js +70 -0
- package/dist/listgrid/components/fields/PhoneNumberField.d.ts +39 -0
- package/dist/listgrid/components/fields/PhoneNumberField.js +91 -0
- package/dist/listgrid/components/fields/Preset.d.ts +68 -0
- package/dist/listgrid/components/fields/Preset.js +306 -0
- package/dist/listgrid/components/fields/ProfileField.d.ts +14 -0
- package/dist/listgrid/components/fields/ProfileField.js +25 -0
- package/dist/listgrid/components/fields/QrField.d.ts +21 -0
- package/dist/listgrid/components/fields/QrField.js +31 -0
- package/dist/listgrid/components/fields/RuleField.d.ts +11 -0
- package/dist/listgrid/components/fields/RuleField.js +24 -0
- package/dist/listgrid/components/fields/SelectField.d.ts +223 -0
- package/dist/listgrid/components/fields/SelectField.js +379 -0
- package/dist/listgrid/components/fields/SelectFieldRenderer.d.ts +35 -0
- package/dist/listgrid/components/fields/SelectFieldRenderer.js +363 -0
- package/dist/listgrid/components/fields/StatusChangeReasonModal.d.ts +18 -0
- package/dist/listgrid/components/fields/StatusChangeReasonModal.js +25 -0
- package/dist/listgrid/components/fields/StringField.d.ts +34 -0
- package/dist/listgrid/components/fields/StringField.js +131 -0
- package/dist/listgrid/components/fields/TagField.d.ts +35 -0
- package/dist/listgrid/components/fields/TagField.js +75 -0
- package/dist/listgrid/components/fields/TelephoneNumberField.d.ts +35 -0
- package/dist/listgrid/components/fields/TelephoneNumberField.js +121 -0
- package/dist/listgrid/components/fields/TextareaField.d.ts +27 -0
- package/dist/listgrid/components/fields/TextareaField.js +47 -0
- package/dist/listgrid/components/fields/TimeField.d.ts +21 -0
- package/dist/listgrid/components/fields/TimeField.js +40 -0
- package/dist/listgrid/components/fields/XrefAvailableDateMappingField.d.ts +22 -0
- package/dist/listgrid/components/fields/XrefAvailableDateMappingField.js +39 -0
- package/dist/listgrid/components/fields/XrefMappingField.d.ts +30 -0
- package/dist/listgrid/components/fields/XrefMappingField.js +59 -0
- package/dist/listgrid/components/fields/XrefPreferMappingField.d.ts +30 -0
- package/dist/listgrid/components/fields/XrefPreferMappingField.js +53 -0
- package/dist/listgrid/components/fields/XrefPriceMappingField.d.ts +33 -0
- package/dist/listgrid/components/fields/XrefPriceMappingField.js +56 -0
- package/dist/listgrid/components/fields/YearField.d.ts +32 -0
- package/dist/listgrid/components/fields/YearField.js +99 -0
- package/dist/listgrid/components/fields/abstract/AbstractDateField.d.ts +33 -0
- package/dist/listgrid/components/fields/abstract/AbstractDateField.js +61 -0
- package/dist/listgrid/components/fields/abstract/AbstractManyToOneField.d.ts +97 -0
- package/dist/listgrid/components/fields/abstract/AbstractManyToOneField.js +50 -0
- package/dist/listgrid/components/fields/abstract/CheckButtonValidationField.d.ts +22 -0
- package/dist/listgrid/components/fields/abstract/CheckButtonValidationField.js +92 -0
- package/dist/listgrid/components/fields/abstract/FormField.d.ts +250 -0
- package/dist/listgrid/components/fields/abstract/FormField.js +606 -0
- package/dist/listgrid/components/fields/abstract/ListableFormField.d.ts +140 -0
- package/dist/listgrid/components/fields/abstract/ListableFormField.js +285 -0
- package/dist/listgrid/components/fields/abstract/OptionalField.d.ts +96 -0
- package/dist/listgrid/components/fields/abstract/OptionalField.js +310 -0
- package/dist/listgrid/components/fields/abstract/index.d.ts +6 -0
- package/dist/listgrid/components/fields/abstract/index.js +12 -0
- package/dist/listgrid/components/fields/address/AddressFieldView.d.ts +9 -0
- package/dist/listgrid/components/fields/address/AddressFieldView.js +92 -0
- package/dist/listgrid/components/fields/address/AddressMapField.d.ts +33 -0
- package/dist/listgrid/components/fields/address/AddressMapField.js +49 -0
- package/dist/listgrid/components/fields/address/KakaoMap.d.ts +10 -0
- package/dist/listgrid/components/fields/address/KakaoMap.js +50 -0
- package/dist/listgrid/components/fields/address/PostCodeSelector.d.ts +9 -0
- package/dist/listgrid/components/fields/address/PostCodeSelector.js +125 -0
- package/dist/listgrid/components/fields/contentasset/ContentAssetField.d.ts +61 -0
- package/dist/listgrid/components/fields/contentasset/ContentAssetField.js +80 -0
- package/dist/listgrid/components/fields/contentasset/ContentAssetItem.d.ts +17 -0
- package/dist/listgrid/components/fields/contentasset/ContentAssetItem.js +67 -0
- package/dist/listgrid/components/fields/contentasset/components/AddContentDialog.d.ts +11 -0
- package/dist/listgrid/components/fields/contentasset/components/AddContentDialog.js +68 -0
- package/dist/listgrid/components/fields/contentasset/components/ContentAssetItemUI.d.ts +30 -0
- package/dist/listgrid/components/fields/contentasset/components/ContentAssetItemUI.js +38 -0
- package/dist/listgrid/components/fields/contentasset/hooks/useContentAsset.d.ts +36 -0
- package/dist/listgrid/components/fields/contentasset/hooks/useContentAsset.js +188 -0
- package/dist/listgrid/components/fields/contentasset/index.d.ts +2 -0
- package/dist/listgrid/components/fields/contentasset/index.js +1 -0
- package/dist/listgrid/components/fields/contentasset/types.d.ts +50 -0
- package/dist/listgrid/components/fields/contentasset/types.js +48 -0
- package/dist/listgrid/components/fields/filter/DatetimeFilter.d.ts +7 -0
- package/dist/listgrid/components/fields/filter/DatetimeFilter.js +46 -0
- package/dist/listgrid/components/fields/filter/NumberFilter.d.ts +7 -0
- package/dist/listgrid/components/fields/filter/NumberFilter.js +74 -0
- package/dist/listgrid/components/fields/rule/RuleBasedFieldView.d.ts +15 -0
- package/dist/listgrid/components/fields/rule/RuleBasedFieldView.js +351 -0
- package/dist/listgrid/components/fields/rule/RuleBasedSelector.d.ts +13 -0
- package/dist/listgrid/components/fields/rule/RuleBasedSelector.js +75 -0
- package/dist/listgrid/components/fields/rule/RuleCondition.d.ts +14 -0
- package/dist/listgrid/components/fields/rule/RuleCondition.js +173 -0
- package/dist/listgrid/components/fields/rule/RuleFieldRenderer.d.ts +7 -0
- package/dist/listgrid/components/fields/rule/RuleFieldRenderer.js +21 -0
- package/dist/listgrid/components/fields/rule/RuleFieldView.d.ts +7 -0
- package/dist/listgrid/components/fields/rule/RuleFieldView.js +28 -0
- package/dist/listgrid/components/fields/rule/Type.d.ts +54 -0
- package/dist/listgrid/components/fields/rule/Type.js +72 -0
- package/dist/listgrid/components/fields/view/CardManyToOneView.d.ts +93 -0
- package/dist/listgrid/components/fields/view/CardManyToOneView.js +409 -0
- package/dist/listgrid/components/fields/view/CopyableTextView.d.ts +11 -0
- package/dist/listgrid/components/fields/view/CopyableTextView.js +44 -0
- package/dist/listgrid/components/fields/view/DynamicSelectFieldView.d.ts +28 -0
- package/dist/listgrid/components/fields/view/DynamicSelectFieldView.js +119 -0
- package/dist/listgrid/components/fields/view/LinkFieldView.d.ts +14 -0
- package/dist/listgrid/components/fields/view/LinkFieldView.js +41 -0
- package/dist/listgrid/components/fields/view/ManyToOneListView.d.ts +8 -0
- package/dist/listgrid/components/fields/view/ManyToOneListView.js +25 -0
- package/dist/listgrid/components/fields/view/ManyToOneMultiFilterView.d.ts +12 -0
- package/dist/listgrid/components/fields/view/ManyToOneMultiFilterView.js +142 -0
- package/dist/listgrid/components/fields/view/ManyToOneView.d.ts +8 -0
- package/dist/listgrid/components/fields/view/ManyToOneView.js +322 -0
- package/dist/listgrid/components/fields/view/MultipleAssetUpload.d.ts +7 -0
- package/dist/listgrid/components/fields/view/MultipleAssetUpload.js +47 -0
- package/dist/listgrid/components/fields/view/PhoneNumberFieldView.d.ts +19 -0
- package/dist/listgrid/components/fields/view/PhoneNumberFieldView.js +82 -0
- package/dist/listgrid/components/fields/view/PhoneNumberListView.d.ts +9 -0
- package/dist/listgrid/components/fields/view/PhoneNumberListView.js +49 -0
- package/dist/listgrid/components/fields/view/SelectBoxManyToOneView.d.ts +47 -0
- package/dist/listgrid/components/fields/view/SelectBoxManyToOneView.js +286 -0
- package/dist/listgrid/components/fields/view/SmsModal.d.ts +6 -0
- package/dist/listgrid/components/fields/view/SmsModal.js +124 -0
- package/dist/listgrid/components/fields/view/TreeSelectView.d.ts +11 -0
- package/dist/listgrid/components/fields/view/TreeSelectView.js +118 -0
- package/dist/listgrid/components/fields/view/XrefAvailableDateMappingView.d.ts +19 -0
- package/dist/listgrid/components/fields/view/XrefAvailableDateMappingView.js +305 -0
- package/dist/listgrid/components/fields/view/XrefMappingView.d.ts +16 -0
- package/dist/listgrid/components/fields/view/XrefMappingView.js +173 -0
- package/dist/listgrid/components/fields/view/XrefPiceMappingView.d.ts +19 -0
- package/dist/listgrid/components/fields/view/XrefPiceMappingView.js +319 -0
- package/dist/listgrid/components/fields/view/XrefPreferMappingView.d.ts +19 -0
- package/dist/listgrid/components/fields/view/XrefPreferMappingView.js +261 -0
- package/dist/listgrid/components/fields/view/XrefPriorityMappingView.d.ts +19 -0
- package/dist/listgrid/components/fields/view/XrefPriorityMappingView.js +180 -0
- package/dist/listgrid/components/form/FieldRenderer.d.ts +23 -0
- package/dist/listgrid/components/form/FieldRenderer.js +292 -0
- package/dist/listgrid/components/form/SubCollectionRenderer.d.ts +22 -0
- package/dist/listgrid/components/form/SubCollectionRenderer.js +46 -0
- package/dist/listgrid/components/form/ViewEntityForm.d.ts +14 -0
- package/dist/listgrid/components/form/ViewEntityForm.js +124 -0
- package/dist/listgrid/components/form/ViewFieldGroup.d.ts +27 -0
- package/dist/listgrid/components/form/ViewFieldGroup.js +164 -0
- package/dist/listgrid/components/form/ViewTab.d.ts +24 -0
- package/dist/listgrid/components/form/ViewTab.js +68 -0
- package/dist/listgrid/components/form/ViewTabPanel.d.ts +14 -0
- package/dist/listgrid/components/form/ViewTabPanel.js +32 -0
- package/dist/listgrid/components/form/context/EntityFormThemeContext.d.ts +52 -0
- package/dist/listgrid/components/form/context/EntityFormThemeContext.js +129 -0
- package/dist/listgrid/components/form/context/index.d.ts +1 -0
- package/dist/listgrid/components/form/context/index.js +1 -0
- package/dist/listgrid/components/form/hooks/useAlertManager.d.ts +12 -0
- package/dist/listgrid/components/form/hooks/useAlertManager.js +103 -0
- package/dist/listgrid/components/form/hooks/useEntityFormAutoSave.d.ts +23 -0
- package/dist/listgrid/components/form/hooks/useEntityFormAutoSave.js +145 -0
- package/dist/listgrid/components/form/hooks/useEntityFormInitializer.d.ts +24 -0
- package/dist/listgrid/components/form/hooks/useEntityFormInitializer.js +109 -0
- package/dist/listgrid/components/form/hooks/useEntityFormLogic.d.ts +63 -0
- package/dist/listgrid/components/form/hooks/useEntityFormLogic.js +513 -0
- package/dist/listgrid/components/form/hooks/useEntityFormSave.d.ts +28 -0
- package/dist/listgrid/components/form/hooks/useEntityFormSave.js +89 -0
- package/dist/listgrid/components/form/hooks/useEntityFormTitle.d.ts +12 -0
- package/dist/listgrid/components/form/hooks/useEntityFormTitle.js +53 -0
- package/dist/listgrid/components/form/themes/defaultTheme.d.ts +11 -0
- package/dist/listgrid/components/form/themes/defaultTheme.js +129 -0
- package/dist/listgrid/components/form/themes/index.d.ts +1 -0
- package/dist/listgrid/components/form/themes/index.js +1 -0
- package/dist/listgrid/components/form/types/ViewEntityForm.types.d.ts +169 -0
- package/dist/listgrid/components/form/types/ViewEntityForm.types.js +1 -0
- package/dist/listgrid/components/form/types/ViewEntityFormAlerts.types.d.ts +26 -0
- package/dist/listgrid/components/form/types/ViewEntityFormAlerts.types.js +1 -0
- package/dist/listgrid/components/form/types/ViewEntityFormButtons.types.d.ts +49 -0
- package/dist/listgrid/components/form/types/ViewEntityFormButtons.types.js +1 -0
- package/dist/listgrid/components/form/types/ViewEntityFormTheme.types.d.ts +518 -0
- package/dist/listgrid/components/form/types/ViewEntityFormTheme.types.js +1 -0
- package/dist/listgrid/components/form/ui/AlertItem.d.ts +7 -0
- package/dist/listgrid/components/form/ui/AlertItem.js +18 -0
- package/dist/listgrid/components/form/ui/CreateStepButtons.d.ts +25 -0
- package/dist/listgrid/components/form/ui/CreateStepButtons.js +18 -0
- package/dist/listgrid/components/form/ui/CreateStepView.d.ts +39 -0
- package/dist/listgrid/components/form/ui/CreateStepView.js +50 -0
- package/dist/listgrid/components/form/ui/ViewEntityError.d.ts +13 -0
- package/dist/listgrid/components/form/ui/ViewEntityError.js +90 -0
- package/dist/listgrid/components/form/ui/ViewEntityFormAlerts.d.ts +3 -0
- package/dist/listgrid/components/form/ui/ViewEntityFormAlerts.js +24 -0
- package/dist/listgrid/components/form/ui/ViewEntityFormButtons.d.ts +24 -0
- package/dist/listgrid/components/form/ui/ViewEntityFormButtons.js +208 -0
- package/dist/listgrid/components/form/ui/ViewEntityFormErrors.d.ts +25 -0
- package/dist/listgrid/components/form/ui/ViewEntityFormErrors.js +9 -0
- package/dist/listgrid/components/form/ui/ViewEntityFormFields.d.ts +38 -0
- package/dist/listgrid/components/form/ui/ViewEntityFormFields.js +25 -0
- package/dist/listgrid/components/form/ui/ViewEntityFormSkeleton.d.ts +16 -0
- package/dist/listgrid/components/form/ui/ViewEntityFormSkeleton.js +79 -0
- package/dist/listgrid/components/form/ui/ViewEntityFormTitle.d.ts +15 -0
- package/dist/listgrid/components/form/ui/ViewEntityFormTitle.js +21 -0
- package/dist/listgrid/components/form/ui/ViewFieldError.d.ts +5 -0
- package/dist/listgrid/components/form/ui/ViewFieldError.js +12 -0
- package/dist/listgrid/components/form/ui/ViewHelpIcon.d.ts +5 -0
- package/dist/listgrid/components/form/ui/ViewHelpIcon.js +13 -0
- package/dist/listgrid/components/form/ui/ViewHelpText.d.ts +5 -0
- package/dist/listgrid/components/form/ui/ViewHelpText.js +10 -0
- package/dist/listgrid/components/form/ui/buttons/ClosePopupButton.d.ts +8 -0
- package/dist/listgrid/components/form/ui/buttons/ClosePopupButton.js +32 -0
- package/dist/listgrid/components/form/ui/buttons/DeleteButton.d.ts +2 -0
- package/dist/listgrid/components/form/ui/buttons/DeleteButton.js +101 -0
- package/dist/listgrid/components/form/ui/buttons/ListButton.d.ts +2 -0
- package/dist/listgrid/components/form/ui/buttons/ListButton.js +55 -0
- package/dist/listgrid/components/form/ui/buttons/SaveButton.d.ts +2 -0
- package/dist/listgrid/components/form/ui/buttons/SaveButton.js +55 -0
- package/dist/listgrid/components/helper/FieldRendererHelper.d.ts +23 -0
- package/dist/listgrid/components/helper/FieldRendererHelper.js +27 -0
- package/dist/listgrid/components/helper/ShowNotifications.d.ts +13 -0
- package/dist/listgrid/components/helper/ShowNotifications.js +58 -0
- package/dist/listgrid/components/list/AdvancedSearchForm.d.ts +17 -0
- package/dist/listgrid/components/list/AdvancedSearchForm.js +113 -0
- package/dist/listgrid/components/list/AdvancedSearchFormV2.d.ts +19 -0
- package/dist/listgrid/components/list/AdvancedSearchFormV2.js +347 -0
- package/dist/listgrid/components/list/ListGridHeader.d.ts +2 -0
- package/dist/listgrid/components/list/ListGridHeader.js +21 -0
- package/dist/listgrid/components/list/QuickSearchBar.d.ts +22 -0
- package/dist/listgrid/components/list/QuickSearchBar.js +17 -0
- package/dist/listgrid/components/list/RowItem.d.ts +2 -0
- package/dist/listgrid/components/list/RowItem.js +70 -0
- package/dist/listgrid/components/list/SubCollectionButtons.d.ts +2 -0
- package/dist/listgrid/components/list/SubCollectionButtons.js +36 -0
- package/dist/listgrid/components/list/ViewFieldSelector.d.ts +10 -0
- package/dist/listgrid/components/list/ViewFieldSelector.js +48 -0
- package/dist/listgrid/components/list/ViewListGrid.d.ts +2 -0
- package/dist/listgrid/components/list/ViewListGrid.js +359 -0
- package/dist/listgrid/components/list/context/EntityFormScopeContext.d.ts +39 -0
- package/dist/listgrid/components/list/context/EntityFormScopeContext.js +75 -0
- package/dist/listgrid/components/list/context/ListGridThemeContext.d.ts +70 -0
- package/dist/listgrid/components/list/context/ListGridThemeContext.js +157 -0
- package/dist/listgrid/components/list/context/index.d.ts +2 -0
- package/dist/listgrid/components/list/context/index.js +1 -0
- package/dist/listgrid/components/list/hooks/searchFormUrlSync.d.ts +42 -0
- package/dist/listgrid/components/list/hooks/searchFormUrlSync.js +212 -0
- package/dist/listgrid/components/list/hooks/urlStateParsers.d.ts +63 -0
- package/dist/listgrid/components/list/hooks/urlStateParsers.js +241 -0
- package/dist/listgrid/components/list/hooks/useCardSubCollectionData.d.ts +34 -0
- package/dist/listgrid/components/list/hooks/useCardSubCollectionData.js +181 -0
- package/dist/listgrid/components/list/hooks/useListGridHeader.d.ts +6 -0
- package/dist/listgrid/components/list/hooks/useListGridHeader.js +92 -0
- package/dist/listgrid/components/list/hooks/useListGridLogic.d.ts +2 -0
- package/dist/listgrid/components/list/hooks/useListGridLogic.js +625 -0
- package/dist/listgrid/components/list/hooks/useListGridUrlState.d.ts +45 -0
- package/dist/listgrid/components/list/hooks/useListGridUrlState.js +131 -0
- package/dist/listgrid/components/list/hooks/useQuickSearchBar.d.ts +22 -0
- package/dist/listgrid/components/list/hooks/useQuickSearchBar.js +104 -0
- package/dist/listgrid/components/list/hooks/useSubCollectionExpansion.d.ts +21 -0
- package/dist/listgrid/components/list/hooks/useSubCollectionExpansion.js +62 -0
- package/dist/listgrid/components/list/themes/defaultListGridTheme.d.ts +14 -0
- package/dist/listgrid/components/list/themes/defaultListGridTheme.js +169 -0
- package/dist/listgrid/components/list/themes/index.d.ts +4 -0
- package/dist/listgrid/components/list/themes/index.js +4 -0
- package/dist/listgrid/components/list/themes/variants/mainTheme.d.ts +8 -0
- package/dist/listgrid/components/list/themes/variants/mainTheme.js +37 -0
- package/dist/listgrid/components/list/themes/variants/modalTheme.d.ts +8 -0
- package/dist/listgrid/components/list/themes/variants/modalTheme.js +47 -0
- package/dist/listgrid/components/list/themes/variants/subCollectionTheme.d.ts +8 -0
- package/dist/listgrid/components/list/themes/variants/subCollectionTheme.js +101 -0
- package/dist/listgrid/components/list/types/ListGridHeader.types.d.ts +35 -0
- package/dist/listgrid/components/list/types/ListGridHeader.types.js +3 -0
- package/dist/listgrid/components/list/types/RowItem.types.d.ts +57 -0
- package/dist/listgrid/components/list/types/RowItem.types.js +1 -0
- package/dist/listgrid/components/list/types/SubCollectionButtons.type.d.ts +29 -0
- package/dist/listgrid/components/list/types/SubCollectionButtons.type.js +1 -0
- package/dist/listgrid/components/list/types/ViewListGrid.types.d.ts +152 -0
- package/dist/listgrid/components/list/types/ViewListGrid.types.js +2 -0
- package/dist/listgrid/components/list/types/ViewListGridTheme.types.d.ts +374 -0
- package/dist/listgrid/components/list/types/ViewListGridTheme.types.js +1 -0
- package/dist/listgrid/components/list/ui/CardFieldRenderer.d.ts +31 -0
- package/dist/listgrid/components/list/ui/CardFieldRenderer.js +71 -0
- package/dist/listgrid/components/list/ui/CardFieldSection.d.ts +27 -0
- package/dist/listgrid/components/list/ui/CardFieldSection.js +108 -0
- package/dist/listgrid/components/list/ui/CardItem.d.ts +28 -0
- package/dist/listgrid/components/list/ui/CardItem.js +376 -0
- package/dist/listgrid/components/list/ui/CardSubCollectionModal.d.ts +38 -0
- package/dist/listgrid/components/list/ui/CardSubCollectionModal.js +80 -0
- package/dist/listgrid/components/list/ui/CardSubCollectionView.d.ts +44 -0
- package/dist/listgrid/components/list/ui/CardSubCollectionView.js +238 -0
- package/dist/listgrid/components/list/ui/DataTransferModal.d.ts +12 -0
- package/dist/listgrid/components/list/ui/DataTransferModal.js +10 -0
- package/dist/listgrid/components/list/ui/EntireChecker.d.ts +11 -0
- package/dist/listgrid/components/list/ui/EntireChecker.js +46 -0
- package/dist/listgrid/components/list/ui/FieldSelector.d.ts +11 -0
- package/dist/listgrid/components/list/ui/FieldSelector.js +40 -0
- package/dist/listgrid/components/list/ui/FilterButton.d.ts +7 -0
- package/dist/listgrid/components/list/ui/FilterButton.js +5 -0
- package/dist/listgrid/components/list/ui/FilterDropdown.d.ts +15 -0
- package/dist/listgrid/components/list/ui/FilterDropdown.js +106 -0
- package/dist/listgrid/components/list/ui/FilterView.d.ts +12 -0
- package/dist/listgrid/components/list/ui/FilterView.js +22 -0
- package/dist/listgrid/components/list/ui/HeaderActionButtons.d.ts +10 -0
- package/dist/listgrid/components/list/ui/HeaderActionButtons.js +39 -0
- package/dist/listgrid/components/list/ui/HeaderField.d.ts +19 -0
- package/dist/listgrid/components/list/ui/HeaderField.js +32 -0
- package/dist/listgrid/components/list/ui/HeaderFieldFilter.d.ts +14 -0
- package/dist/listgrid/components/list/ui/HeaderFieldFilter.js +166 -0
- package/dist/listgrid/components/list/ui/HeaderTitle.d.ts +4 -0
- package/dist/listgrid/components/list/ui/HeaderTitle.js +13 -0
- package/dist/listgrid/components/list/ui/InlineSubCollectionView.d.ts +30 -0
- package/dist/listgrid/components/list/ui/InlineSubCollectionView.js +260 -0
- package/dist/listgrid/components/list/ui/MemoizedFilterField.d.ts +14 -0
- package/dist/listgrid/components/list/ui/MemoizedFilterField.js +67 -0
- package/dist/listgrid/components/list/ui/QuickSearchInput.d.ts +9 -0
- package/dist/listgrid/components/list/ui/QuickSearchInput.js +17 -0
- package/dist/listgrid/components/list/ui/SearchBarActions.d.ts +19 -0
- package/dist/listgrid/components/list/ui/SearchBarActions.js +39 -0
- package/dist/listgrid/components/list/ui/SortField.d.ts +8 -0
- package/dist/listgrid/components/list/ui/SortField.js +42 -0
- package/dist/listgrid/components/list/ui/SubCollectionInlineView.d.ts +23 -0
- package/dist/listgrid/components/list/ui/SubCollectionInlineView.js +47 -0
- package/dist/listgrid/components/list/ui/SubCollectionModal.d.ts +15 -0
- package/dist/listgrid/components/list/ui/SubCollectionModal.js +34 -0
- package/dist/listgrid/components/list/ui/SubCollectionViewModal.d.ts +13 -0
- package/dist/listgrid/components/list/ui/SubCollectionViewModal.js +33 -0
- package/dist/listgrid/components/list/ui/SyncTopScrollbar.d.ts +18 -0
- package/dist/listgrid/components/list/ui/SyncTopScrollbar.js +91 -0
- package/dist/listgrid/components/list/ui/TableSubCollectionView.d.ts +25 -0
- package/dist/listgrid/components/list/ui/TableSubCollectionView.js +213 -0
- package/dist/listgrid/components/list/ui/ViewColumn.d.ts +2 -0
- package/dist/listgrid/components/list/ui/ViewColumn.js +56 -0
- package/dist/listgrid/components/list/ui/ViewListGridSkeleton.d.ts +20 -0
- package/dist/listgrid/components/list/ui/ViewListGridSkeleton.js +82 -0
- package/dist/listgrid/components/list/ui/ViewRows.d.ts +15 -0
- package/dist/listgrid/components/list/ui/ViewRows.js +283 -0
- package/dist/listgrid/components/list/ui/buttons/CacheClearButton.d.ts +9 -0
- package/dist/listgrid/components/list/ui/buttons/CacheClearButton.js +35 -0
- package/dist/listgrid/components/list/ui/buttons/CreateButton.d.ts +13 -0
- package/dist/listgrid/components/list/ui/buttons/CreateButton.js +13 -0
- package/dist/listgrid/components/list/ui/buttons/PriorityButton.d.ts +11 -0
- package/dist/listgrid/components/list/ui/buttons/PriorityButton.js +49 -0
- package/dist/listgrid/components/list/ui/headerFilterStore.d.ts +8 -0
- package/dist/listgrid/components/list/ui/headerFilterStore.js +13 -0
- package/dist/listgrid/components/list/utils/mappedByFieldFilter.d.ts +21 -0
- package/dist/listgrid/components/list/utils/mappedByFieldFilter.js +54 -0
- package/dist/listgrid/components/list/utils/performanceLogger.d.ts +48 -0
- package/dist/listgrid/components/list/utils/performanceLogger.js +67 -0
- package/dist/listgrid/components/revision/RevisionField.d.ts +13 -0
- package/dist/listgrid/components/revision/RevisionField.js +194 -0
- package/dist/listgrid/config/AdvancedSearchOpenCache.d.ts +3 -0
- package/dist/listgrid/config/AdvancedSearchOpenCache.js +48 -0
- package/dist/listgrid/config/CardSubCollectionField.d.ts +133 -0
- package/dist/listgrid/config/CardSubCollectionField.js +164 -0
- package/dist/listgrid/config/CommonType.d.ts +4 -0
- package/dist/listgrid/config/CommonType.js +15 -0
- package/dist/listgrid/config/Config.d.ts +251 -0
- package/dist/listgrid/config/Config.js +299 -0
- package/dist/listgrid/config/EntityField.d.ts +148 -0
- package/dist/listgrid/config/EntityField.js +1 -0
- package/dist/listgrid/config/EntityFieldGroup.d.ts +37 -0
- package/dist/listgrid/config/EntityFieldGroup.js +55 -0
- package/dist/listgrid/config/EntityForm.d.ts +101 -0
- package/dist/listgrid/config/EntityForm.js +859 -0
- package/dist/listgrid/config/EntityFormButton.d.ts +56 -0
- package/dist/listgrid/config/EntityFormButton.js +42 -0
- package/dist/listgrid/config/EntityFormMethod.d.ts +32 -0
- package/dist/listgrid/config/EntityFormMethod.js +152 -0
- package/dist/listgrid/config/EntityFormTypes.d.ts +62 -0
- package/dist/listgrid/config/EntityFormTypes.js +1 -0
- package/dist/listgrid/config/EntityItem.d.ts +86 -0
- package/dist/listgrid/config/EntityItem.js +1 -0
- package/dist/listgrid/config/EntityTab.d.ts +26 -0
- package/dist/listgrid/config/EntityTab.js +68 -0
- package/dist/listgrid/config/InlineSubCollectionField.d.ts +184 -0
- package/dist/listgrid/config/InlineSubCollectionField.js +194 -0
- package/dist/listgrid/config/ListGrid.d.ts +56 -0
- package/dist/listgrid/config/ListGrid.js +183 -0
- package/dist/listgrid/config/ListGridViewFieldCache.d.ts +3 -0
- package/dist/listgrid/config/ListGridViewFieldCache.js +53 -0
- package/dist/listgrid/config/OnChangeEntityForm.d.ts +43 -0
- package/dist/listgrid/config/OnChangeEntityForm.js +266 -0
- package/dist/listgrid/config/RuntimeConfig.d.ts +18 -0
- package/dist/listgrid/config/RuntimeConfig.js +22 -0
- package/dist/listgrid/config/SubCollectionField.d.ts +119 -0
- package/dist/listgrid/config/SubCollectionField.js +241 -0
- package/dist/listgrid/config/TableSubCollectionField.d.ts +66 -0
- package/dist/listgrid/config/TableSubCollectionField.js +132 -0
- package/dist/listgrid/config/form/EntityFormActions.d.ts +69 -0
- package/dist/listgrid/config/form/EntityFormActions.js +459 -0
- package/dist/listgrid/config/form/EntityFormBase.d.ts +204 -0
- package/dist/listgrid/config/form/EntityFormBase.js +526 -0
- package/dist/listgrid/config/form/EntityFormData.d.ts +32 -0
- package/dist/listgrid/config/form/EntityFormData.js +184 -0
- package/dist/listgrid/config/form/EntityFormExtensions.d.ts +37 -0
- package/dist/listgrid/config/form/EntityFormExtensions.js +105 -0
- package/dist/listgrid/config/form/EntityFormValidation.d.ts +28 -0
- package/dist/listgrid/config/form/EntityFormValidation.js +128 -0
- package/dist/listgrid/extensions/EntityFormExtension.types.d.ts +52 -0
- package/dist/listgrid/extensions/EntityFormExtension.types.js +19 -0
- package/dist/listgrid/extensions/FieldExtensions.d.ts +5 -0
- package/dist/listgrid/extensions/FieldExtensions.js +21 -0
- package/dist/listgrid/form/SearchForm.d.ts +153 -0
- package/dist/listgrid/form/SearchForm.js +689 -0
- package/dist/listgrid/form/TagsInput/types.d.ts +133 -0
- package/dist/listgrid/form/TagsInput/types.js +1 -0
- package/dist/listgrid/form/Type.d.ts +50 -0
- package/dist/listgrid/form/Type.js +95 -0
- package/dist/listgrid/index.d.ts +205 -0
- package/dist/listgrid/index.js +244 -0
- package/dist/listgrid/loading/index.d.ts +6 -0
- package/dist/listgrid/loading/index.js +17 -0
- package/dist/listgrid/menu/MenuPermissionChecker.d.ts +15 -0
- package/dist/listgrid/menu/MenuPermissionChecker.js +15 -0
- package/dist/listgrid/menu/index.d.ts +1 -0
- package/dist/listgrid/menu/index.js +1 -0
- package/dist/listgrid/message/MessageProvider.d.ts +19 -0
- package/dist/listgrid/message/MessageProvider.js +62 -0
- package/dist/listgrid/message/index.d.ts +1 -0
- package/dist/listgrid/message/index.js +1 -0
- package/dist/listgrid/misc/index.d.ts +64 -0
- package/dist/listgrid/misc/index.js +478 -0
- package/dist/listgrid/router/RouterProvider.d.ts +12 -0
- package/dist/listgrid/router/RouterProvider.js +34 -0
- package/dist/listgrid/router/index.d.ts +3 -0
- package/dist/listgrid/router/index.js +1 -0
- package/dist/listgrid/router/types.d.ts +34 -0
- package/dist/listgrid/router/types.js +6 -0
- package/dist/listgrid/store/index.d.ts +24 -0
- package/dist/listgrid/store/index.js +40 -0
- package/dist/listgrid/transfer/DataExportProcessor.d.ts +18 -0
- package/dist/listgrid/transfer/DataExportProcessor.js +102 -0
- package/dist/listgrid/transfer/DataExportService.d.ts +37 -0
- package/dist/listgrid/transfer/DataExportService.js +225 -0
- package/dist/listgrid/transfer/DataExporter.d.ts +10 -0
- package/dist/listgrid/transfer/DataExporter.js +85 -0
- package/dist/listgrid/transfer/DataImportDescription.d.ts +8 -0
- package/dist/listgrid/transfer/DataImportDescription.js +18 -0
- package/dist/listgrid/transfer/DataImportProcessor.d.ts +24 -0
- package/dist/listgrid/transfer/DataImportProcessor.js +59 -0
- package/dist/listgrid/transfer/DataImportResultView.d.ts +13 -0
- package/dist/listgrid/transfer/DataImportResultView.js +64 -0
- package/dist/listgrid/transfer/DataImportSample.d.ts +10 -0
- package/dist/listgrid/transfer/DataImportSample.js +105 -0
- package/dist/listgrid/transfer/DataImporter.d.ts +8 -0
- package/dist/listgrid/transfer/DataImporter.js +335 -0
- package/dist/listgrid/transfer/DynamicDataImporter.d.ts +4 -0
- package/dist/listgrid/transfer/DynamicDataImporter.js +13 -0
- package/dist/listgrid/transfer/ExcelPasswordField.d.ts +9 -0
- package/dist/listgrid/transfer/ExcelPasswordField.js +23 -0
- package/dist/listgrid/transfer/Provider/ExcelProvider.d.ts +24 -0
- package/dist/listgrid/transfer/Provider/ExcelProvider.js +194 -0
- package/dist/listgrid/transfer/Type.d.ts +176 -0
- package/dist/listgrid/transfer/Type.js +568 -0
- package/dist/listgrid/ui/GlobalModalManager.d.ts +22 -0
- package/dist/listgrid/ui/GlobalModalManager.js +65 -0
- package/dist/listgrid/ui/UIProvider.d.ts +151 -0
- package/dist/listgrid/ui/UIProvider.js +292 -0
- package/dist/listgrid/ui/index.d.ts +2 -0
- package/dist/listgrid/ui/index.js +2 -0
- package/dist/listgrid/urlState/UrlStateProvider.d.ts +8 -0
- package/dist/listgrid/urlState/UrlStateProvider.js +20 -0
- package/dist/listgrid/urlState/index.d.ts +4 -0
- package/dist/listgrid/urlState/index.js +2 -0
- package/dist/listgrid/urlState/types.d.ts +21 -0
- package/dist/listgrid/urlState/types.js +14 -0
- package/dist/listgrid/utils/BooleanUtil.d.ts +1 -0
- package/dist/listgrid/utils/BooleanUtil.js +9 -0
- package/dist/listgrid/utils/CompareUtil.d.ts +7 -0
- package/dist/listgrid/utils/CompareUtil.js +87 -0
- package/dist/listgrid/utils/PhoneUtil.d.ts +19 -0
- package/dist/listgrid/utils/PhoneUtil.js +38 -0
- package/dist/listgrid/utils/RequestUtil.d.ts +6 -0
- package/dist/listgrid/utils/RequestUtil.js +6 -0
- package/dist/listgrid/utils/StringUtil.d.ts +32 -0
- package/dist/listgrid/utils/StringUtil.js +316 -0
- package/dist/listgrid/utils/classNames.d.ts +21 -0
- package/dist/listgrid/utils/classNames.js +29 -0
- package/dist/listgrid/utils/cn.d.ts +12 -0
- package/dist/listgrid/utils/cn.js +15 -0
- package/dist/listgrid/utils/hash.d.ts +1 -0
- package/dist/listgrid/utils/hash.js +15 -0
- package/dist/listgrid/utils/i18n.d.ts +16 -0
- package/dist/listgrid/utils/i18n.js +31 -0
- package/dist/listgrid/utils/index.d.ts +10 -0
- package/dist/listgrid/utils/index.js +17 -0
- package/dist/listgrid/utils/jsonUtils.d.ts +4 -0
- package/dist/listgrid/utils/jsonUtils.js +77 -0
- package/dist/listgrid/utils/lazy.d.ts +10 -0
- package/dist/listgrid/utils/lazy.js +13 -0
- package/dist/listgrid/utils/simpleCrypt.d.ts +4 -0
- package/dist/listgrid/utils/simpleCrypt.js +79 -0
- package/dist/listgrid/validations/CustomValidation.d.ts +8 -0
- package/dist/listgrid/validations/CustomValidation.js +10 -0
- package/dist/listgrid/validations/EmailValidation.d.ts +4 -0
- package/dist/listgrid/validations/EmailValidation.js +7 -0
- package/dist/listgrid/validations/IpAddressValidation.d.ts +26 -0
- package/dist/listgrid/validations/IpAddressValidation.js +57 -0
- package/dist/listgrid/validations/MinMaxNumberValidation.d.ts +14 -0
- package/dist/listgrid/validations/MinMaxNumberValidation.js +28 -0
- package/dist/listgrid/validations/PasswordValidation.d.ts +4 -0
- package/dist/listgrid/validations/PasswordValidation.js +7 -0
- package/dist/listgrid/validations/PhoneNumberValidation.d.ts +12 -0
- package/dist/listgrid/validations/PhoneNumberValidation.js +24 -0
- package/dist/listgrid/validations/RegexFormularValidation.d.ts +7 -0
- package/dist/listgrid/validations/RegexFormularValidation.js +28 -0
- package/dist/listgrid/validations/RegexValidation.d.ts +8 -0
- package/dist/listgrid/validations/RegexValidation.js +17 -0
- package/dist/listgrid/validations/RequiredValidation.d.ts +7 -0
- package/dist/listgrid/validations/RequiredValidation.js +12 -0
- package/dist/listgrid/validations/StringValidation.d.ts +17 -0
- package/dist/listgrid/validations/StringValidation.js +33 -0
- package/dist/listgrid/validations/TelephoneNumberValidation.d.ts +12 -0
- package/dist/listgrid/validations/TelephoneNumberValidation.js +24 -0
- package/dist/listgrid/validations/Validation.d.ts +63 -0
- package/dist/listgrid/validations/Validation.js +72 -0
- package/dist/listgrid/view/ViewEntityFormWrapper.d.ts +16 -0
- package/dist/listgrid/view/ViewEntityFormWrapper.js +98 -0
- package/dist/listgrid/view/ViewListGridWrapper.d.ts +10 -0
- package/dist/listgrid/view/ViewListGridWrapper.js +96 -0
- package/dist/styles/base.css +116 -0
- package/dist/styles/components.css +1404 -0
- package/dist/styles/layouts.css +3206 -0
- package/dist/styles/primitives.css +1542 -0
- package/dist/styles/tokens.css +218 -0
- package/dist/styles.css +6486 -0
- package/docs/PRIMITIVES.md +271 -0
- 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';
|