@byline/ui 0.9.3
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 +373 -0
- package/README.md +17 -0
- package/dist/admin/components/admin-account/change-password.d.ts +9 -0
- package/dist/admin/components/admin-account/change-password.d.ts.map +1 -0
- package/dist/admin/components/admin-account/change-password.js +192 -0
- package/dist/admin/components/admin-account/change-password.module.js +8 -0
- package/dist/admin/components/admin-account/change-password_module.css +27 -0
- package/dist/admin/components/admin-account/container.d.ts +30 -0
- package/dist/admin/components/admin-account/container.d.ts.map +1 -0
- package/dist/admin/components/admin-account/container.js +299 -0
- package/dist/admin/components/admin-account/container.module.js +28 -0
- package/dist/admin/components/admin-account/container_module.css +106 -0
- package/dist/admin/components/admin-account/update.d.ts +9 -0
- package/dist/admin/components/admin-account/update.d.ts.map +1 -0
- package/dist/admin/components/admin-account/update.js +207 -0
- package/dist/admin/components/admin-account/update.module.js +8 -0
- package/dist/admin/components/admin-account/update_module.css +27 -0
- package/dist/admin/components/admin-permissions/inspector.d.ts +5 -0
- package/dist/admin/components/admin-permissions/inspector.d.ts.map +1 -0
- package/dist/admin/components/admin-permissions/inspector.js +284 -0
- package/dist/admin/components/admin-permissions/inspector.module.js +56 -0
- package/dist/admin/components/admin-permissions/inspector_module.css +238 -0
- package/dist/admin/components/admin-roles/create.d.ts +8 -0
- package/dist/admin/components/admin-roles/create.d.ts.map +1 -0
- package/dist/admin/components/admin-roles/create.js +177 -0
- package/dist/admin/components/admin-roles/create.module.js +8 -0
- package/dist/admin/components/admin-roles/create_module.css +27 -0
- package/dist/admin/components/admin-roles/permissions.d.ts +11 -0
- package/dist/admin/components/admin-roles/permissions.d.ts.map +1 -0
- package/dist/admin/components/admin-roles/permissions.js +303 -0
- package/dist/admin/components/admin-roles/permissions.module.js +44 -0
- package/dist/admin/components/admin-roles/permissions_module.css +192 -0
- package/dist/admin/components/admin-roles/update.d.ts +9 -0
- package/dist/admin/components/admin-roles/update.d.ts.map +1 -0
- package/dist/admin/components/admin-roles/update.js +166 -0
- package/dist/admin/components/admin-roles/update.module.js +8 -0
- package/dist/admin/components/admin-roles/update_module.css +27 -0
- package/dist/admin/components/admin-users/create.d.ts +9 -0
- package/dist/admin/components/admin-users/create.d.ts.map +1 -0
- package/dist/admin/components/admin-users/create.js +268 -0
- package/dist/admin/components/admin-users/create.module.js +10 -0
- package/dist/admin/components/admin-users/create_module.css +45 -0
- package/dist/admin/components/admin-users/roles.d.ts +12 -0
- package/dist/admin/components/admin-users/roles.d.ts.map +1 -0
- package/dist/admin/components/admin-users/roles.js +148 -0
- package/dist/admin/components/admin-users/roles.module.js +18 -0
- package/dist/admin/components/admin-users/roles_module.css +75 -0
- package/dist/admin/components/admin-users/set-password.d.ts +9 -0
- package/dist/admin/components/admin-users/set-password.d.ts.map +1 -0
- package/dist/admin/components/admin-users/set-password.js +170 -0
- package/dist/admin/components/admin-users/set-password.module.js +9 -0
- package/dist/admin/components/admin-users/set-password_module.css +31 -0
- package/dist/admin/components/admin-users/update.d.ts +9 -0
- package/dist/admin/components/admin-users/update.d.ts.map +1 -0
- package/dist/admin/components/admin-users/update.js +254 -0
- package/dist/admin/components/admin-users/update.module.js +9 -0
- package/dist/admin/components/admin-users/update_module.css +34 -0
- package/dist/admin/components/auth/sign-in-form.d.ts +14 -0
- package/dist/admin/components/auth/sign-in-form.d.ts.map +1 -0
- package/dist/admin/components/auth/sign-in-form.js +107 -0
- package/dist/admin/components/auth/sign-in-form.module.js +10 -0
- package/dist/admin/components/auth/sign-in-form_module.css +35 -0
- package/dist/admin/components/collections/diff-modal.d.ts +23 -0
- package/dist/admin/components/collections/diff-modal.d.ts.map +1 -0
- package/dist/admin/components/collections/diff-modal.js +147 -0
- package/dist/admin/components/collections/diff-modal.module.js +14 -0
- package/dist/admin/components/collections/diff-modal_module.css +56 -0
- package/dist/admin/components/collections/status-badge.d.ts +26 -0
- package/dist/admin/components/collections/status-badge.d.ts.map +1 -0
- package/dist/admin/components/collections/status-badge.js +35 -0
- package/dist/admin/components/collections/status-badge.module.js +7 -0
- package/dist/admin/components/collections/status-badge_module.css +20 -0
- package/dist/admin/group.d.ts +28 -0
- package/dist/admin/group.d.ts.map +1 -0
- package/dist/admin/group.js +14 -0
- package/dist/admin/group.module.js +6 -0
- package/dist/admin/group_module.css +19 -0
- package/dist/admin/row.d.ts +26 -0
- package/dist/admin/row.d.ts.map +1 -0
- package/dist/admin/row.js +8 -0
- package/dist/admin/row.module.js +5 -0
- package/dist/admin/row_module.css +18 -0
- package/dist/admin/tabs.d.ts +33 -0
- package/dist/admin/tabs.d.ts.map +1 -0
- package/dist/admin/tabs.js +34 -0
- package/dist/admin/tabs.module.js +10 -0
- package/dist/admin/tabs_module.css +68 -0
- package/dist/dnd/draggable-sortable/demo/draggable-list-demo.js +105 -0
- package/dist/dnd/draggable-sortable/demo/draggable-list-demo.module.js +12 -0
- package/dist/dnd/draggable-sortable/demo/draggable-list-demo_module.css +39 -0
- package/dist/dnd/draggable-sortable/draggable-sortable-item/index.d.ts +19 -0
- package/dist/dnd/draggable-sortable/draggable-sortable-item/index.d.ts.map +1 -0
- package/dist/dnd/draggable-sortable/draggable-sortable-item/index.js +27 -0
- package/dist/dnd/draggable-sortable/draggable-sortable-item/types.d.ts +25 -0
- package/dist/dnd/draggable-sortable/draggable-sortable-item/types.d.ts.map +1 -0
- package/dist/dnd/draggable-sortable/draggable-sortable-item/types.js +1 -0
- package/dist/dnd/draggable-sortable/draggable-sortable.d.ts +17 -0
- package/dist/dnd/draggable-sortable/draggable-sortable.d.ts.map +1 -0
- package/dist/dnd/draggable-sortable/draggable-sortable.js +46 -0
- package/dist/dnd/draggable-sortable/index.d.ts +5 -0
- package/dist/dnd/draggable-sortable/index.d.ts.map +1 -0
- package/dist/dnd/draggable-sortable/index.js +4 -0
- package/dist/dnd/draggable-sortable/types.d.ts +26 -0
- package/dist/dnd/draggable-sortable/types.d.ts.map +1 -0
- package/dist/dnd/draggable-sortable/types.js +1 -0
- package/dist/dnd/draggable-sortable/use-draggable-sortable/index.d.ts +16 -0
- package/dist/dnd/draggable-sortable/use-draggable-sortable/index.d.ts.map +1 -0
- package/dist/dnd/draggable-sortable/use-draggable-sortable/index.js +28 -0
- package/dist/dnd/draggable-sortable/use-draggable-sortable/types.d.ts +23 -0
- package/dist/dnd/draggable-sortable/use-draggable-sortable/types.d.ts.map +1 -0
- package/dist/dnd/draggable-sortable/use-draggable-sortable/types.js +1 -0
- package/dist/dnd/draggable-sortable/utils.d.ts +14 -0
- package/dist/dnd/draggable-sortable/utils.d.ts.map +1 -0
- package/dist/dnd/draggable-sortable/utils.js +10 -0
- package/dist/fields/array/array-field.d.ts +15 -0
- package/dist/fields/array/array-field.d.ts.map +1 -0
- package/dist/fields/array/array-field.js +176 -0
- package/dist/fields/array/array-field.module.js +11 -0
- package/dist/fields/array/array-field_module.css +32 -0
- package/dist/fields/blocks/blocks-field.d.ts +14 -0
- package/dist/fields/blocks/blocks-field.d.ts.map +1 -0
- package/dist/fields/blocks/blocks-field.js +244 -0
- package/dist/fields/blocks/blocks-field.module.js +26 -0
- package/dist/fields/blocks/blocks-field_module.css +107 -0
- package/dist/fields/checkbox/checkbox-field.d.ts +17 -0
- package/dist/fields/checkbox/checkbox-field.d.ts.map +1 -0
- package/dist/fields/checkbox/checkbox-field.js +27 -0
- package/dist/fields/column-formatter.d.ts +21 -0
- package/dist/fields/column-formatter.d.ts.map +1 -0
- package/dist/fields/column-formatter.js +15 -0
- package/dist/fields/date-time-formatter.d.ts +17 -0
- package/dist/fields/date-time-formatter.d.ts.map +1 -0
- package/dist/fields/date-time-formatter.js +8 -0
- package/dist/fields/datetime/datetime-field.d.ts +17 -0
- package/dist/fields/datetime/datetime-field.d.ts.map +1 -0
- package/dist/fields/datetime/datetime-field.js +37 -0
- package/dist/fields/datetime/datetime-field.module.js +5 -0
- package/dist/fields/datetime/datetime-field_module.css +4 -0
- package/dist/fields/draggable-context-menu.d.ts +7 -0
- package/dist/fields/draggable-context-menu.d.ts.map +1 -0
- package/dist/fields/draggable-context-menu.js +83 -0
- package/dist/fields/draggable-context-menu.module.js +15 -0
- package/dist/fields/draggable-context-menu_module.css +91 -0
- package/dist/fields/field-helpers.d.ts +27 -0
- package/dist/fields/field-helpers.d.ts.map +1 -0
- package/dist/fields/field-helpers.js +48 -0
- package/dist/fields/field-renderer.d.ts +31 -0
- package/dist/fields/field-renderer.d.ts.map +1 -0
- package/dist/fields/field-renderer.js +189 -0
- package/dist/fields/field-renderer.module.js +8 -0
- package/dist/fields/field-renderer_module.css +11 -0
- package/dist/fields/file/file-field.d.ts +18 -0
- package/dist/fields/file/file-field.d.ts.map +1 -0
- package/dist/fields/file/file-field.js +125 -0
- package/dist/fields/file/file-field.module.js +13 -0
- package/dist/fields/file/file-field_module.css +64 -0
- package/dist/fields/group/group-field.d.ts +16 -0
- package/dist/fields/group/group-field.d.ts.map +1 -0
- package/dist/fields/group/group-field.js +59 -0
- package/dist/fields/group/group-field.module.js +9 -0
- package/dist/fields/group/group-field_module.css +27 -0
- package/dist/fields/image/image-field.d.ts +20 -0
- package/dist/fields/image/image-field.d.ts.map +1 -0
- package/dist/fields/image/image-field.js +198 -0
- package/dist/fields/image/image-field.module.js +21 -0
- package/dist/fields/image/image-field_module.css +96 -0
- package/dist/fields/image/image-upload-field.d.ts +22 -0
- package/dist/fields/image/image-upload-field.d.ts.map +1 -0
- package/dist/fields/image/image-upload-field.js +187 -0
- package/dist/fields/image/image-upload-field.module.js +19 -0
- package/dist/fields/image/image-upload-field_module.css +92 -0
- package/dist/fields/local-date-time.d.ts +28 -0
- package/dist/fields/local-date-time.d.ts.map +1 -0
- package/dist/fields/local-date-time.js +49 -0
- package/dist/fields/locale-badge.d.ts +19 -0
- package/dist/fields/locale-badge.d.ts.map +1 -0
- package/dist/fields/locale-badge.js +10 -0
- package/dist/fields/locale-badge.module.js +5 -0
- package/dist/fields/locale-badge_module.css +27 -0
- package/dist/fields/numerical/numerical-field.d.ts +19 -0
- package/dist/fields/numerical/numerical-field.d.ts.map +1 -0
- package/dist/fields/numerical/numerical-field.js +73 -0
- package/dist/fields/relation/relation-display.d.ts +41 -0
- package/dist/fields/relation/relation-display.d.ts.map +1 -0
- package/dist/fields/relation/relation-display.js +58 -0
- package/dist/fields/relation/relation-display.module.js +9 -0
- package/dist/fields/relation/relation-display_module.css +21 -0
- package/dist/fields/relation/relation-field.d.ts +19 -0
- package/dist/fields/relation/relation-field.d.ts.map +1 -0
- package/dist/fields/relation/relation-field.js +133 -0
- package/dist/fields/relation/relation-field.module.js +13 -0
- package/dist/fields/relation/relation-field_module.css +62 -0
- package/dist/fields/relation/relation-picker.d.ts +50 -0
- package/dist/fields/relation/relation-picker.d.ts.map +1 -0
- package/dist/fields/relation/relation-picker.js +233 -0
- package/dist/fields/relation/relation-picker.module.js +26 -0
- package/dist/fields/relation/relation-picker_module.css +124 -0
- package/dist/fields/relation/relation-summary.d.ts +32 -0
- package/dist/fields/relation/relation-summary.d.ts.map +1 -0
- package/dist/fields/relation/relation-summary.js +50 -0
- package/dist/fields/relation/relation-summary.module.js +11 -0
- package/dist/fields/relation/relation-summary_module.css +37 -0
- package/dist/fields/select/select-field.d.ts +17 -0
- package/dist/fields/select/select-field.d.ts.map +1 -0
- package/dist/fields/select/select-field.js +42 -0
- package/dist/fields/select/select-field.module.js +5 -0
- package/dist/fields/select/select-field_module.css +4 -0
- package/dist/fields/sortable-item.d.ts +16 -0
- package/dist/fields/sortable-item.d.ts.map +1 -0
- package/dist/fields/sortable-item.js +80 -0
- package/dist/fields/sortable-item.module.js +22 -0
- package/dist/fields/sortable-item_module.css +124 -0
- package/dist/fields/text/text-field.d.ts +21 -0
- package/dist/fields/text/text-field.d.ts.map +1 -0
- package/dist/fields/text/text-field.js +104 -0
- package/dist/fields/text/text-field.module.js +6 -0
- package/dist/fields/text/text-field_module.css +5 -0
- package/dist/fields/text-area/text-area-field.d.ts +21 -0
- package/dist/fields/text-area/text-area-field.d.ts.map +1 -0
- package/dist/fields/text-area/text-area-field.js +105 -0
- package/dist/fields/text-area/text-area-field.module.js +6 -0
- package/dist/fields/text-area/text-area-field_module.css +5 -0
- package/dist/fields/use-field-change-handler.d.ts +24 -0
- package/dist/fields/use-field-change-handler.d.ts.map +1 -0
- package/dist/fields/use-field-change-handler.js +52 -0
- package/dist/forms/document-actions.d.ts +14 -0
- package/dist/forms/document-actions.d.ts.map +1 -0
- package/dist/forms/document-actions.js +153 -0
- package/dist/forms/document-actions.module.js +18 -0
- package/dist/forms/document-actions_module.css +66 -0
- package/dist/forms/form-context.d.ts +78 -0
- package/dist/forms/form-context.d.ts.map +1 -0
- package/dist/forms/form-context.js +420 -0
- package/dist/forms/form-renderer.d.ts +66 -0
- package/dist/forms/form-renderer.d.ts.map +1 -0
- package/dist/forms/form-renderer.js +555 -0
- package/dist/forms/form-renderer.module.js +46 -0
- package/dist/forms/form-renderer_module.css +242 -0
- package/dist/forms/navigation-guard.d.ts +55 -0
- package/dist/forms/navigation-guard.d.ts.map +1 -0
- package/dist/forms/navigation-guard.js +22 -0
- package/dist/forms/path-widget.d.ts +33 -0
- package/dist/forms/path-widget.d.ts.map +1 -0
- package/dist/forms/path-widget.js +101 -0
- package/dist/forms/path-widget.module.js +8 -0
- package/dist/forms/path-widget_module.css +29 -0
- package/dist/forms/upload-executor.d.ts +58 -0
- package/dist/forms/upload-executor.d.ts.map +1 -0
- package/dist/forms/upload-executor.js +92 -0
- package/dist/react.d.ts +55 -0
- package/dist/react.d.ts.map +1 -0
- package/dist/react.js +48 -0
- package/dist/services/admin-services-context.d.ts +17 -0
- package/dist/services/admin-services-context.d.ts.map +1 -0
- package/dist/services/admin-services-context.js +13 -0
- package/dist/services/admin-services-types.d.ts +130 -0
- package/dist/services/admin-services-types.d.ts.map +1 -0
- package/dist/services/admin-services-types.js +1 -0
- package/dist/services/field-services-context.d.ts +17 -0
- package/dist/services/field-services-context.d.ts.map +1 -0
- package/dist/services/field-services-context.js +13 -0
- package/dist/services/field-services-types.d.ts +64 -0
- package/dist/services/field-services-types.d.ts.map +1 -0
- package/dist/services/field-services-types.js +1 -0
- package/package.json +133 -0
- package/src/admin/components/admin-account/change-password.module.css +40 -0
- package/src/admin/components/admin-account/change-password.tsx +232 -0
- package/src/admin/components/admin-account/container.module.css +158 -0
- package/src/admin/components/admin-account/container.tsx +230 -0
- package/src/admin/components/admin-account/update.module.css +40 -0
- package/src/admin/components/admin-account/update.tsx +263 -0
- package/src/admin/components/admin-permissions/inspector.module.css +326 -0
- package/src/admin/components/admin-permissions/inspector.tsx +298 -0
- package/src/admin/components/admin-roles/create.module.css +40 -0
- package/src/admin/components/admin-roles/create.tsx +218 -0
- package/src/admin/components/admin-roles/permissions.module.css +279 -0
- package/src/admin/components/admin-roles/permissions.tsx +396 -0
- package/src/admin/components/admin-roles/update.module.css +40 -0
- package/src/admin/components/admin-roles/update.tsx +218 -0
- package/src/admin/components/admin-users/create.module.css +63 -0
- package/src/admin/components/admin-users/create.tsx +323 -0
- package/src/admin/components/admin-users/roles.module.css +119 -0
- package/src/admin/components/admin-users/roles.tsx +172 -0
- package/src/admin/components/admin-users/set-password.module.css +46 -0
- package/src/admin/components/admin-users/set-password.tsx +199 -0
- package/src/admin/components/admin-users/update.module.css +49 -0
- package/src/admin/components/admin-users/update.tsx +328 -0
- package/src/admin/components/auth/sign-in-form.module.css +53 -0
- package/src/admin/components/auth/sign-in-form.tsx +118 -0
- package/src/admin/components/collections/diff-modal.module.css +79 -0
- package/src/admin/components/collections/diff-modal.tsx +171 -0
- package/src/admin/components/collections/status-badge.module.css +31 -0
- package/src/admin/components/collections/status-badge.tsx +69 -0
- package/src/admin/group.module.css +41 -0
- package/src/admin/group.tsx +40 -0
- package/src/admin/row.module.css +32 -0
- package/src/admin/row.tsx +33 -0
- package/src/admin/tabs.module.css +107 -0
- package/src/admin/tabs.tsx +74 -0
- package/src/declarations.d.ts +4 -0
- package/src/dnd/draggable-sortable/demo/draggable-list-demo.module.css +65 -0
- package/src/dnd/draggable-sortable/demo/draggable-list-demo.tsx +117 -0
- package/src/dnd/draggable-sortable/draggable-sortable-item/index.tsx +54 -0
- package/src/dnd/draggable-sortable/draggable-sortable-item/types.ts +30 -0
- package/src/dnd/draggable-sortable/draggable-sortable.tsx +86 -0
- package/src/dnd/draggable-sortable/index.ts +5 -0
- package/src/dnd/draggable-sortable/types.ts +24 -0
- package/src/dnd/draggable-sortable/use-draggable-sortable/index.tsx +50 -0
- package/src/dnd/draggable-sortable/use-draggable-sortable/types.ts +25 -0
- package/src/dnd/draggable-sortable/utils.ts +29 -0
- package/src/fields/array/array-field.module.css +48 -0
- package/src/fields/array/array-field.tsx +266 -0
- package/src/fields/blocks/blocks-field.module.css +148 -0
- package/src/fields/blocks/blocks-field.tsx +312 -0
- package/src/fields/checkbox/checkbox-field.tsx +53 -0
- package/src/fields/column-formatter.tsx +31 -0
- package/src/fields/date-time-formatter.tsx +22 -0
- package/src/fields/datetime/datetime-field.module.css +13 -0
- package/src/fields/datetime/datetime-field.tsx +54 -0
- package/src/fields/draggable-context-menu.module.css +127 -0
- package/src/fields/draggable-context-menu.tsx +85 -0
- package/src/fields/field-helpers.ts +66 -0
- package/src/fields/field-renderer.module.css +22 -0
- package/src/fields/field-renderer.tsx +255 -0
- package/src/fields/file/file-field.module.css +88 -0
- package/src/fields/file/file-field.tsx +107 -0
- package/src/fields/group/group-field.module.css +43 -0
- package/src/fields/group/group-field.tsx +84 -0
- package/src/fields/image/image-field.module.css +129 -0
- package/src/fields/image/image-field.tsx +212 -0
- package/src/fields/image/image-upload-field.module.css +123 -0
- package/src/fields/image/image-upload-field.tsx +270 -0
- package/src/fields/local-date-time.tsx +88 -0
- package/src/fields/locale-badge.module.css +37 -0
- package/src/fields/locale-badge.tsx +32 -0
- package/src/fields/numerical/numerical-field.tsx +112 -0
- package/src/fields/relation/relation-display.module.css +36 -0
- package/src/fields/relation/relation-display.tsx +130 -0
- package/src/fields/relation/relation-field.module.css +83 -0
- package/src/fields/relation/relation-field.tsx +202 -0
- package/src/fields/relation/relation-picker.module.css +168 -0
- package/src/fields/relation/relation-picker.tsx +325 -0
- package/src/fields/relation/relation-summary.module.css +55 -0
- package/src/fields/relation/relation-summary.tsx +123 -0
- package/src/fields/select/select-field.module.css +13 -0
- package/src/fields/select/select-field.tsx +56 -0
- package/src/fields/sortable-item.module.css +167 -0
- package/src/fields/sortable-item.tsx +101 -0
- package/src/fields/text/text-field.module.css +13 -0
- package/src/fields/text/text-field.tsx +146 -0
- package/src/fields/text-area/text-area-field.module.css +13 -0
- package/src/fields/text-area/text-area-field.tsx +147 -0
- package/src/fields/use-field-change-handler.ts +112 -0
- package/src/forms/document-actions.module.css +94 -0
- package/src/forms/document-actions.tsx +149 -0
- package/src/forms/form-context.tsx +620 -0
- package/src/forms/form-renderer.module.css +318 -0
- package/src/forms/form-renderer.tsx +786 -0
- package/src/forms/navigation-guard.tsx +98 -0
- package/src/forms/path-widget.module.css +41 -0
- package/src/forms/path-widget.test.tsx +217 -0
- package/src/forms/path-widget.tsx +141 -0
- package/src/forms/upload-executor.ts +190 -0
- package/src/react.ts +79 -0
- package/src/services/admin-services-context.tsx +35 -0
- package/src/services/admin-services-types.ts +177 -0
- package/src/services/field-services-context.tsx +35 -0
- package/src/services/field-services-types.ts +68 -0
|
@@ -0,0 +1,96 @@
|
|
|
1
|
+
:is(.header-qe_E_5, .byline-field-image-header) {
|
|
2
|
+
align-items: baseline;
|
|
3
|
+
gap: var(--spacing-8);
|
|
4
|
+
margin-bottom: .25rem;
|
|
5
|
+
display: flex;
|
|
6
|
+
}
|
|
7
|
+
|
|
8
|
+
:is(.label-NX4rr4, .byline-field-image-label) {
|
|
9
|
+
color: var(--gray-100);
|
|
10
|
+
font-size: var(--font-size-sm);
|
|
11
|
+
font-weight: var(--font-weight-medium);
|
|
12
|
+
}
|
|
13
|
+
|
|
14
|
+
:is(.help-M8XvYp, .byline-field-image-help) {
|
|
15
|
+
color: var(--gray-400);
|
|
16
|
+
font-size: var(--font-size-xs);
|
|
17
|
+
margin-top: .125rem;
|
|
18
|
+
}
|
|
19
|
+
|
|
20
|
+
:is(.remove-ib7eKx, .byline-field-image-remove) {
|
|
21
|
+
color: var(--red-500);
|
|
22
|
+
font-size: var(--font-size-xs);
|
|
23
|
+
cursor: pointer;
|
|
24
|
+
background: none;
|
|
25
|
+
border: none;
|
|
26
|
+
padding: 0;
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
:is(.remove-ib7eKx:hover, .byline-field-image-remove:hover) {
|
|
30
|
+
color: var(--red-400);
|
|
31
|
+
text-underline-offset: 2px;
|
|
32
|
+
text-decoration: underline;
|
|
33
|
+
}
|
|
34
|
+
|
|
35
|
+
:is(.empty-b8pdoJ, .byline-field-image-empty) {
|
|
36
|
+
color: var(--gray-500);
|
|
37
|
+
font-size: var(--font-size-xs);
|
|
38
|
+
font-style: italic;
|
|
39
|
+
}
|
|
40
|
+
|
|
41
|
+
:is(.tile-izbLn0, .byline-field-image-tile) {
|
|
42
|
+
gap: var(--spacing-16);
|
|
43
|
+
padding: var(--spacing-8);
|
|
44
|
+
border: var(--border-width-thin) var(--border-style-solid) var(--primary-500);
|
|
45
|
+
border-radius: var(--border-radius-md);
|
|
46
|
+
margin-top: .25rem;
|
|
47
|
+
display: flex;
|
|
48
|
+
}
|
|
49
|
+
|
|
50
|
+
:is(.preview-wrap-Cjr0PD, .byline-field-image-preview-wrap) {
|
|
51
|
+
position: relative;
|
|
52
|
+
}
|
|
53
|
+
|
|
54
|
+
:is(.preview-DIASGB, .byline-field-image-preview) {
|
|
55
|
+
border: var(--border-width-thin) var(--border-style-solid) var(--gray-600);
|
|
56
|
+
border-radius: var(--border-radius-sm);
|
|
57
|
+
object-fit: contain;
|
|
58
|
+
min-width: 4rem;
|
|
59
|
+
min-height: 4rem;
|
|
60
|
+
max-height: 10rem;
|
|
61
|
+
}
|
|
62
|
+
|
|
63
|
+
:is(.preview-svg-sCwreb, .byline-field-image-preview-svg) {
|
|
64
|
+
width: 271px;
|
|
65
|
+
height: 159px;
|
|
66
|
+
max-height: none;
|
|
67
|
+
}
|
|
68
|
+
|
|
69
|
+
:is(.pending-s6X_52, .byline-field-image-pending) {
|
|
70
|
+
background-color: oklch(from var(--yellow-600) l c h / .9);
|
|
71
|
+
color: var(--yellow-100);
|
|
72
|
+
font-size: .6rem;
|
|
73
|
+
font-weight: var(--font-weight-medium);
|
|
74
|
+
border-radius: var(--border-radius-sm);
|
|
75
|
+
padding: .125rem .375rem;
|
|
76
|
+
position: absolute;
|
|
77
|
+
top: .25rem;
|
|
78
|
+
left: .25rem;
|
|
79
|
+
}
|
|
80
|
+
|
|
81
|
+
:is(.meta-uHyKiu, .byline-field-image-meta) {
|
|
82
|
+
color: var(--gray-200);
|
|
83
|
+
font-size: var(--font-size-xs);
|
|
84
|
+
flex-direction: column;
|
|
85
|
+
gap: .125rem;
|
|
86
|
+
display: flex;
|
|
87
|
+
}
|
|
88
|
+
|
|
89
|
+
:is(.meta-key-eR6iRU, .byline-field-image-meta-key) {
|
|
90
|
+
font-weight: var(--font-weight-semibold);
|
|
91
|
+
}
|
|
92
|
+
|
|
93
|
+
:is(.meta-pending-lEdTAj, .byline-field-image-meta-pending) {
|
|
94
|
+
color: var(--yellow-400);
|
|
95
|
+
}
|
|
96
|
+
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* This Source Code is subject to the terms of the Mozilla Public
|
|
3
|
+
* License, v. 2.0. If a copy of the MPL was not distributed with this
|
|
4
|
+
* file, You can obtain one at http://mozilla.org/MPL/2.0/.
|
|
5
|
+
*
|
|
6
|
+
* Copyright (c) Infonomic Company Limited
|
|
7
|
+
*/
|
|
8
|
+
import { type ImageField as FieldType, type PendingStoredFileValue, type StoredFileValue } from '@byline/core';
|
|
9
|
+
interface ImageUploadFieldProps {
|
|
10
|
+
field: FieldType;
|
|
11
|
+
/** Collection path used to build the upload URL (e.g. `'media'`). */
|
|
12
|
+
collectionPath: string;
|
|
13
|
+
/** Field path in the form (e.g. `'image'` or `'content.0.image'`). */
|
|
14
|
+
fieldPath: string;
|
|
15
|
+
/** Called with the PendingStoredFileValue for immediate preview. */
|
|
16
|
+
onUploaded: (value: StoredFileValue | PendingStoredFileValue) => void;
|
|
17
|
+
/** Optional accepted-file MIME types string for the native file input. */
|
|
18
|
+
accept?: string;
|
|
19
|
+
}
|
|
20
|
+
export declare const ImageUploadField: ({ field: _field, collectionPath, fieldPath, onUploaded, accept, }: ImageUploadFieldProps) => import("react").JSX.Element;
|
|
21
|
+
export {};
|
|
22
|
+
//# sourceMappingURL=image-upload-field.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"image-upload-field.d.ts","sourceRoot":"","sources":["../../../src/fields/image/image-upload-field.tsx"],"names":[],"mappings":"AAAA;;;;;;GAMG;AAgBH,OAAO,EAEL,KAAK,UAAU,IAAI,SAAS,EAC5B,KAAK,sBAAsB,EAC3B,KAAK,eAAe,EACrB,MAAM,cAAc,CAAA;AAUrB,UAAU,qBAAqB;IAC7B,KAAK,EAAE,SAAS,CAAA;IAChB,qEAAqE;IACrE,cAAc,EAAE,MAAM,CAAA;IACtB,sEAAsE;IACtE,SAAS,EAAE,MAAM,CAAA;IACjB,oEAAoE;IACpE,UAAU,EAAE,CAAC,KAAK,EAAE,eAAe,GAAG,sBAAsB,KAAK,IAAI,CAAA;IACrE,0EAA0E;IAC1E,MAAM,CAAC,EAAE,MAAM,CAAA;CAChB;AAQD,eAAO,MAAM,gBAAgB,GAAI,mEAM9B,qBAAqB,gCAgNvB,CAAA"}
|
|
@@ -0,0 +1,187 @@
|
|
|
1
|
+
import { Fragment, jsx, jsxs } from "react/jsx-runtime";
|
|
2
|
+
import { useCallback, useRef, useState } from "react";
|
|
3
|
+
import { createPendingStoredFileValue } from "@byline/core";
|
|
4
|
+
import classnames from "classnames";
|
|
5
|
+
import { useFormContext } from "../../forms/form-context.js";
|
|
6
|
+
import image_upload_field_module from "./image-upload-field.module.js";
|
|
7
|
+
const ImageUploadField = ({ field: _field, collectionPath, fieldPath, onUploaded, accept = 'image/*' })=>{
|
|
8
|
+
const inputRef = useRef(null);
|
|
9
|
+
const [status, setStatus] = useState('idle');
|
|
10
|
+
const [errorMessage, setErrorMessage] = useState(null);
|
|
11
|
+
const [isDragOver, setIsDragOver] = useState(false);
|
|
12
|
+
const { addPendingUpload } = useFormContext();
|
|
13
|
+
const handleFileSelected = useCallback((file)=>{
|
|
14
|
+
setStatus('processing');
|
|
15
|
+
setErrorMessage(null);
|
|
16
|
+
if (!file.type.startsWith('image/')) {
|
|
17
|
+
setStatus('error');
|
|
18
|
+
setErrorMessage('Please select an image file.');
|
|
19
|
+
return;
|
|
20
|
+
}
|
|
21
|
+
const previewUrl = URL.createObjectURL(file);
|
|
22
|
+
const img = new Image();
|
|
23
|
+
img.onload = ()=>{
|
|
24
|
+
const w = img.naturalWidth;
|
|
25
|
+
const h = img.naturalHeight;
|
|
26
|
+
const dimensions = w > 0 && h > 0 ? {
|
|
27
|
+
width: w,
|
|
28
|
+
height: h
|
|
29
|
+
} : void 0;
|
|
30
|
+
const pendingValue = createPendingStoredFileValue(file, previewUrl, dimensions);
|
|
31
|
+
addPendingUpload(fieldPath, {
|
|
32
|
+
file,
|
|
33
|
+
previewUrl,
|
|
34
|
+
collectionPath
|
|
35
|
+
});
|
|
36
|
+
setStatus('idle');
|
|
37
|
+
onUploaded(pendingValue);
|
|
38
|
+
};
|
|
39
|
+
img.onerror = ()=>{
|
|
40
|
+
URL.revokeObjectURL(previewUrl);
|
|
41
|
+
setStatus('error');
|
|
42
|
+
setErrorMessage('Could not read image. Please try a different file.');
|
|
43
|
+
};
|
|
44
|
+
img.src = previewUrl;
|
|
45
|
+
}, [
|
|
46
|
+
collectionPath,
|
|
47
|
+
fieldPath,
|
|
48
|
+
addPendingUpload,
|
|
49
|
+
onUploaded
|
|
50
|
+
]);
|
|
51
|
+
const handleFileChange = useCallback((e)=>{
|
|
52
|
+
const file = e.target.files?.[0];
|
|
53
|
+
if (file) handleFileSelected(file);
|
|
54
|
+
e.target.value = '';
|
|
55
|
+
}, [
|
|
56
|
+
handleFileSelected
|
|
57
|
+
]);
|
|
58
|
+
const handleBrowseClick = useCallback(()=>{
|
|
59
|
+
inputRef.current?.click();
|
|
60
|
+
}, []);
|
|
61
|
+
const handleDragOver = useCallback((e)=>{
|
|
62
|
+
e.preventDefault();
|
|
63
|
+
setIsDragOver(true);
|
|
64
|
+
}, []);
|
|
65
|
+
const handleDragLeave = useCallback((e)=>{
|
|
66
|
+
e.preventDefault();
|
|
67
|
+
setIsDragOver(false);
|
|
68
|
+
}, []);
|
|
69
|
+
const handleDrop = useCallback((e)=>{
|
|
70
|
+
e.preventDefault();
|
|
71
|
+
setIsDragOver(false);
|
|
72
|
+
const file = e.dataTransfer.files?.[0];
|
|
73
|
+
if (file) handleFileSelected(file);
|
|
74
|
+
}, [
|
|
75
|
+
handleFileSelected
|
|
76
|
+
]);
|
|
77
|
+
const isProcessing = 'processing' === status;
|
|
78
|
+
return /*#__PURE__*/ jsxs("div", {
|
|
79
|
+
className: classnames('byline-field-image-upload', image_upload_field_module.root),
|
|
80
|
+
children: [
|
|
81
|
+
/*#__PURE__*/ jsx("input", {
|
|
82
|
+
ref: inputRef,
|
|
83
|
+
type: "file",
|
|
84
|
+
accept: accept,
|
|
85
|
+
className: classnames('byline-field-image-upload-input', image_upload_field_module.input),
|
|
86
|
+
onChange: handleFileChange,
|
|
87
|
+
disabled: isProcessing,
|
|
88
|
+
"aria-hidden": "true",
|
|
89
|
+
tabIndex: -1
|
|
90
|
+
}),
|
|
91
|
+
/*#__PURE__*/ jsx("div", {
|
|
92
|
+
role: "button",
|
|
93
|
+
tabIndex: 0,
|
|
94
|
+
"aria-label": "Upload image — drag and drop or click to browse",
|
|
95
|
+
onDragOver: handleDragOver,
|
|
96
|
+
onDragLeave: handleDragLeave,
|
|
97
|
+
onDrop: handleDrop,
|
|
98
|
+
onClick: handleBrowseClick,
|
|
99
|
+
onKeyDown: (e)=>{
|
|
100
|
+
if ('Enter' === e.key || ' ' === e.key) {
|
|
101
|
+
e.preventDefault();
|
|
102
|
+
handleBrowseClick();
|
|
103
|
+
}
|
|
104
|
+
},
|
|
105
|
+
className: classnames('byline-field-image-upload-zone', image_upload_field_module.zone, isDragOver && !isProcessing && [
|
|
106
|
+
'byline-field-image-upload-zone-active',
|
|
107
|
+
image_upload_field_module["zone-active"]
|
|
108
|
+
], isProcessing && [
|
|
109
|
+
'byline-field-image-upload-zone-busy',
|
|
110
|
+
image_upload_field_module["zone-busy"]
|
|
111
|
+
]),
|
|
112
|
+
children: isProcessing ? /*#__PURE__*/ jsxs(Fragment, {
|
|
113
|
+
children: [
|
|
114
|
+
/*#__PURE__*/ jsxs("svg", {
|
|
115
|
+
className: classnames('byline-field-image-upload-spinner', image_upload_field_module.spinner),
|
|
116
|
+
xmlns: "http://www.w3.org/2000/svg",
|
|
117
|
+
fill: "none",
|
|
118
|
+
viewBox: "0 0 24 24",
|
|
119
|
+
"aria-hidden": "true",
|
|
120
|
+
children: [
|
|
121
|
+
/*#__PURE__*/ jsx("circle", {
|
|
122
|
+
style: {
|
|
123
|
+
opacity: 0.25
|
|
124
|
+
},
|
|
125
|
+
cx: "12",
|
|
126
|
+
cy: "12",
|
|
127
|
+
r: "10",
|
|
128
|
+
stroke: "currentColor",
|
|
129
|
+
strokeWidth: "4"
|
|
130
|
+
}),
|
|
131
|
+
/*#__PURE__*/ jsx("path", {
|
|
132
|
+
style: {
|
|
133
|
+
opacity: 0.75
|
|
134
|
+
},
|
|
135
|
+
fill: "currentColor",
|
|
136
|
+
d: "M4 12a8 8 0 018-8V0C5.373 0 0 5.373 0 12h4z"
|
|
137
|
+
})
|
|
138
|
+
]
|
|
139
|
+
}),
|
|
140
|
+
/*#__PURE__*/ jsx("span", {
|
|
141
|
+
className: classnames('byline-field-image-upload-label', image_upload_field_module.label),
|
|
142
|
+
children: "Processing…"
|
|
143
|
+
})
|
|
144
|
+
]
|
|
145
|
+
}) : /*#__PURE__*/ jsxs(Fragment, {
|
|
146
|
+
children: [
|
|
147
|
+
/*#__PURE__*/ jsx("svg", {
|
|
148
|
+
xmlns: "http://www.w3.org/2000/svg",
|
|
149
|
+
className: classnames('byline-field-image-upload-icon', image_upload_field_module.icon),
|
|
150
|
+
fill: "none",
|
|
151
|
+
viewBox: "0 0 24 24",
|
|
152
|
+
stroke: "currentColor",
|
|
153
|
+
strokeWidth: 1.5,
|
|
154
|
+
"aria-hidden": "true",
|
|
155
|
+
children: /*#__PURE__*/ jsx("path", {
|
|
156
|
+
strokeLinecap: "round",
|
|
157
|
+
strokeLinejoin: "round",
|
|
158
|
+
d: "M3 16.5v2.25A2.25 2.25 0 005.25 21h13.5A2.25 2.25 0 0021 18.75V16.5m-13.5-9L12 3m0 0l4.5 4.5M12 3v13.5"
|
|
159
|
+
})
|
|
160
|
+
}),
|
|
161
|
+
/*#__PURE__*/ jsxs("span", {
|
|
162
|
+
className: classnames('byline-field-image-upload-label', image_upload_field_module.label),
|
|
163
|
+
children: [
|
|
164
|
+
"Drop image here or",
|
|
165
|
+
' ',
|
|
166
|
+
/*#__PURE__*/ jsx("span", {
|
|
167
|
+
className: classnames('byline-field-image-upload-action', image_upload_field_module.action),
|
|
168
|
+
children: "browse"
|
|
169
|
+
})
|
|
170
|
+
]
|
|
171
|
+
}),
|
|
172
|
+
/*#__PURE__*/ jsx("span", {
|
|
173
|
+
className: classnames('byline-field-image-upload-hint', image_upload_field_module.hint),
|
|
174
|
+
children: "JPEG, PNG, WebP, GIF, SVG, AVIF"
|
|
175
|
+
})
|
|
176
|
+
]
|
|
177
|
+
})
|
|
178
|
+
}),
|
|
179
|
+
'error' === status && errorMessage && /*#__PURE__*/ jsx("p", {
|
|
180
|
+
className: classnames('byline-field-image-upload-error', image_upload_field_module.error),
|
|
181
|
+
role: "alert",
|
|
182
|
+
children: errorMessage
|
|
183
|
+
})
|
|
184
|
+
]
|
|
185
|
+
});
|
|
186
|
+
};
|
|
187
|
+
export { ImageUploadField };
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import "./image-upload-field_module.css";
|
|
2
|
+
const image_upload_field_module = {
|
|
3
|
+
root: "root-RQ8s0u",
|
|
4
|
+
input: "input-DnqmLy",
|
|
5
|
+
zone: "zone-ZQQueP",
|
|
6
|
+
"zone-active": "zone-active-GgYY5w",
|
|
7
|
+
zoneActive: "zone-active-GgYY5w",
|
|
8
|
+
"zone-busy": "zone-busy-QscsjT",
|
|
9
|
+
zoneBusy: "zone-busy-QscsjT",
|
|
10
|
+
spinner: "spinner-vgmURt",
|
|
11
|
+
"byline-image-upload-spin": "byline-image-upload-spin-PnC9WU",
|
|
12
|
+
bylineImageUploadSpin: "byline-image-upload-spin-PnC9WU",
|
|
13
|
+
icon: "icon-ZueG4I",
|
|
14
|
+
label: "label-jdwMD2",
|
|
15
|
+
action: "action-g1CZcT",
|
|
16
|
+
hint: "hint-WOpqdr",
|
|
17
|
+
error: "error-bRg83I"
|
|
18
|
+
};
|
|
19
|
+
export default image_upload_field_module;
|
|
@@ -0,0 +1,92 @@
|
|
|
1
|
+
:is(.root-RQ8s0u, .byline-field-image-upload) {
|
|
2
|
+
margin-top: .25rem;
|
|
3
|
+
}
|
|
4
|
+
|
|
5
|
+
:is(.input-DnqmLy, .byline-field-image-upload-input) {
|
|
6
|
+
clip: rect(0, 0, 0, 0);
|
|
7
|
+
white-space: nowrap;
|
|
8
|
+
border: 0;
|
|
9
|
+
width: 1px;
|
|
10
|
+
height: 1px;
|
|
11
|
+
margin: -1px;
|
|
12
|
+
padding: 0;
|
|
13
|
+
position: absolute;
|
|
14
|
+
overflow: hidden;
|
|
15
|
+
}
|
|
16
|
+
|
|
17
|
+
:is(.zone-ZQQueP, .byline-field-image-upload-zone) {
|
|
18
|
+
justify-content: center;
|
|
19
|
+
align-items: center;
|
|
20
|
+
gap: var(--spacing-8);
|
|
21
|
+
border: 2px dashed var(--gray-600);
|
|
22
|
+
border-radius: var(--border-radius-lg);
|
|
23
|
+
color: var(--gray-400);
|
|
24
|
+
text-align: center;
|
|
25
|
+
cursor: pointer;
|
|
26
|
+
-webkit-user-select: none;
|
|
27
|
+
user-select: none;
|
|
28
|
+
flex-direction: column;
|
|
29
|
+
padding: 1.5rem 1rem;
|
|
30
|
+
transition: color .15s, background-color .15s, border-color .15s;
|
|
31
|
+
display: flex;
|
|
32
|
+
}
|
|
33
|
+
|
|
34
|
+
:is(.zone-ZQQueP:hover, .byline-field-image-upload-zone:hover) {
|
|
35
|
+
border-color: var(--primary-500);
|
|
36
|
+
background-color: oklch(from var(--primary-900) l c h / .1);
|
|
37
|
+
}
|
|
38
|
+
|
|
39
|
+
:is(.zone-active-GgYY5w, .byline-field-image-upload-zone-active) {
|
|
40
|
+
border-color: var(--primary-400);
|
|
41
|
+
background-color: oklch(from var(--primary-900) l c h / .2);
|
|
42
|
+
color: var(--primary-300);
|
|
43
|
+
}
|
|
44
|
+
|
|
45
|
+
:is(.zone-busy-QscsjT, .byline-field-image-upload-zone-busy) {
|
|
46
|
+
border-color: var(--gray-700);
|
|
47
|
+
background-color: oklch(from var(--canvas-800) l c h / .5);
|
|
48
|
+
color: var(--gray-600);
|
|
49
|
+
cursor: not-allowed;
|
|
50
|
+
}
|
|
51
|
+
|
|
52
|
+
:is(.spinner-vgmURt, .byline-field-image-upload-spinner) {
|
|
53
|
+
width: 1.5rem;
|
|
54
|
+
height: 1.5rem;
|
|
55
|
+
color: var(--primary-400);
|
|
56
|
+
animation: 1s linear infinite byline-image-upload-spin-PnC9WU;
|
|
57
|
+
}
|
|
58
|
+
|
|
59
|
+
@keyframes byline-image-upload-spin-PnC9WU {
|
|
60
|
+
to {
|
|
61
|
+
transform: rotate(360deg);
|
|
62
|
+
}
|
|
63
|
+
}
|
|
64
|
+
|
|
65
|
+
:is(.icon-ZueG4I, .byline-field-image-upload-icon) {
|
|
66
|
+
opacity: .6;
|
|
67
|
+
width: 1.75rem;
|
|
68
|
+
height: 1.75rem;
|
|
69
|
+
}
|
|
70
|
+
|
|
71
|
+
:is(.label-jdwMD2, .byline-field-image-upload-label) {
|
|
72
|
+
font-size: var(--font-size-xs);
|
|
73
|
+
font-weight: var(--font-weight-medium);
|
|
74
|
+
}
|
|
75
|
+
|
|
76
|
+
:is(.action-g1CZcT, .byline-field-image-upload-action) {
|
|
77
|
+
color: var(--primary-400);
|
|
78
|
+
text-underline-offset: 2px;
|
|
79
|
+
text-decoration: underline;
|
|
80
|
+
}
|
|
81
|
+
|
|
82
|
+
:is(.hint-WOpqdr, .byline-field-image-upload-hint) {
|
|
83
|
+
color: var(--gray-500);
|
|
84
|
+
font-size: .65rem;
|
|
85
|
+
}
|
|
86
|
+
|
|
87
|
+
:is(.error-bRg83I, .byline-field-image-upload-error) {
|
|
88
|
+
color: var(--red-400);
|
|
89
|
+
font-size: var(--font-size-xs);
|
|
90
|
+
margin-top: .375rem;
|
|
91
|
+
}
|
|
92
|
+
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
interface LocalDateTimeProps {
|
|
2
|
+
value: string | Date | null | undefined;
|
|
3
|
+
mode?: 'datetime' | 'date';
|
|
4
|
+
className?: string;
|
|
5
|
+
fallback?: string;
|
|
6
|
+
}
|
|
7
|
+
/**
|
|
8
|
+
* Client-side date/time formatter that displays dates in the user's local timezone.
|
|
9
|
+
*
|
|
10
|
+
* This component avoids hydration mismatches by:
|
|
11
|
+
* 1. Rendering a placeholder on the server/initial render
|
|
12
|
+
* 2. Updating to the correctly formatted date after hydration
|
|
13
|
+
*
|
|
14
|
+
* Use this instead of formatDateTime when you need to display dates
|
|
15
|
+
* in the user's local timezone rather than UTC.
|
|
16
|
+
*/
|
|
17
|
+
export declare function LocalDateTime({ value, mode, className, fallback, }: LocalDateTimeProps): React.JSX.Element;
|
|
18
|
+
/**
|
|
19
|
+
* Formats a date string to the user's local timezone.
|
|
20
|
+
*
|
|
21
|
+
* WARNING: Only use this in client components where hydration
|
|
22
|
+
* mismatches are acceptable or managed. For most cases, prefer
|
|
23
|
+
* the <LocalDateTime /> component.
|
|
24
|
+
*/
|
|
25
|
+
export declare function formatLocalDateTime(value: string | Date | null | undefined): string;
|
|
26
|
+
export declare function formatLocalDate(value: string | Date | null | undefined): string;
|
|
27
|
+
export {};
|
|
28
|
+
//# sourceMappingURL=local-date-time.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"local-date-time.d.ts","sourceRoot":"","sources":["../../src/fields/local-date-time.tsx"],"names":[],"mappings":"AAmBA,UAAU,kBAAkB;IAC1B,KAAK,EAAE,MAAM,GAAG,IAAI,GAAG,IAAI,GAAG,SAAS,CAAA;IACvC,IAAI,CAAC,EAAE,UAAU,GAAG,MAAM,CAAA;IAC1B,SAAS,CAAC,EAAE,MAAM,CAAA;IAClB,QAAQ,CAAC,EAAE,MAAM,CAAA;CAClB;AAED;;;;;;;;;GASG;AACH,wBAAgB,aAAa,CAAC,EAC5B,KAAK,EACL,IAAiB,EACjB,SAAS,EACT,QAAc,GACf,EAAE,kBAAkB,GAAG,KAAK,CAAC,GAAG,CAAC,OAAO,CAyBxC;AAED;;;;;;GAMG;AACH,wBAAgB,mBAAmB,CAAC,KAAK,EAAE,MAAM,GAAG,IAAI,GAAG,IAAI,GAAG,SAAS,GAAG,MAAM,CAKnF;AAED,wBAAgB,eAAe,CAAC,KAAK,EAAE,MAAM,GAAG,IAAI,GAAG,IAAI,GAAG,SAAS,GAAG,MAAM,CAK/E"}
|
|
@@ -0,0 +1,49 @@
|
|
|
1
|
+
"use client";
|
|
2
|
+
import { jsx } from "react/jsx-runtime";
|
|
3
|
+
import { useEffect, useState } from "react";
|
|
4
|
+
const dateTimeFormatter = new Intl.DateTimeFormat(void 0, {
|
|
5
|
+
year: 'numeric',
|
|
6
|
+
month: 'short',
|
|
7
|
+
day: '2-digit',
|
|
8
|
+
hour: 'numeric',
|
|
9
|
+
minute: 'numeric'
|
|
10
|
+
});
|
|
11
|
+
const dateFormatter = new Intl.DateTimeFormat(void 0, {
|
|
12
|
+
year: 'numeric',
|
|
13
|
+
month: 'short',
|
|
14
|
+
day: '2-digit'
|
|
15
|
+
});
|
|
16
|
+
function LocalDateTime({ value, mode = 'datetime', className, fallback = '—' }) {
|
|
17
|
+
const [formattedDate, setFormattedDate] = useState(null);
|
|
18
|
+
useEffect(()=>{
|
|
19
|
+
if (null == value) return void setFormattedDate(null);
|
|
20
|
+
const date = 'string' == typeof value ? Date.parse(value) : value.getTime();
|
|
21
|
+
if (Number.isNaN(date)) return void setFormattedDate('Error');
|
|
22
|
+
const formatter = 'datetime' === mode ? dateTimeFormatter : dateFormatter;
|
|
23
|
+
setFormattedDate(formatter.format(date));
|
|
24
|
+
}, [
|
|
25
|
+
value,
|
|
26
|
+
mode
|
|
27
|
+
]);
|
|
28
|
+
if (null === formattedDate) return /*#__PURE__*/ jsx("span", {
|
|
29
|
+
className: className,
|
|
30
|
+
children: value ? '...' : fallback
|
|
31
|
+
});
|
|
32
|
+
return /*#__PURE__*/ jsx("span", {
|
|
33
|
+
className: className,
|
|
34
|
+
children: formattedDate
|
|
35
|
+
});
|
|
36
|
+
}
|
|
37
|
+
function formatLocalDateTime(value) {
|
|
38
|
+
if (null == value) return '—';
|
|
39
|
+
const date = 'string' == typeof value ? Date.parse(value) : value.getTime();
|
|
40
|
+
if (Number.isNaN(date)) return 'Error';
|
|
41
|
+
return dateTimeFormatter.format(date);
|
|
42
|
+
}
|
|
43
|
+
function formatLocalDate(value) {
|
|
44
|
+
if (null == value) return '—';
|
|
45
|
+
const date = 'string' == typeof value ? Date.parse(value) : value.getTime();
|
|
46
|
+
if (Number.isNaN(date)) return 'Error';
|
|
47
|
+
return dateFormatter.format(date);
|
|
48
|
+
}
|
|
49
|
+
export { LocalDateTime, formatLocalDate, formatLocalDateTime };
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* This Source Code is subject to the terms of the Mozilla Public
|
|
3
|
+
* License, v. 2.0. If a copy of the MPL was not distributed with this
|
|
4
|
+
* file, You can obtain one at http://mozilla.org/MPL/2.0/.
|
|
5
|
+
*
|
|
6
|
+
* Copyright (c) Infonomic Company Limited
|
|
7
|
+
*/
|
|
8
|
+
export interface LocaleBadgeProps {
|
|
9
|
+
locale: string;
|
|
10
|
+
}
|
|
11
|
+
/**
|
|
12
|
+
* Small inline badge shown next to the label of a field that has
|
|
13
|
+
* `localized: true` in its schema definition. Indicates which locale
|
|
14
|
+
* the editor is currently working in.
|
|
15
|
+
*
|
|
16
|
+
* Stable override handle: `.byline-locale-badge`.
|
|
17
|
+
*/
|
|
18
|
+
export declare const LocaleBadge: ({ locale }: LocaleBadgeProps) => import("react").JSX.Element;
|
|
19
|
+
//# sourceMappingURL=locale-badge.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"locale-badge.d.ts","sourceRoot":"","sources":["../../src/fields/locale-badge.tsx"],"names":[],"mappings":"AAAA;;;;;;GAMG;AAMH,MAAM,WAAW,gBAAgB;IAC/B,MAAM,EAAE,MAAM,CAAA;CACf;AAED;;;;;;GAMG;AACH,eAAO,MAAM,WAAW,GAAI,YAAY,gBAAgB,gCAQvD,CAAA"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import { jsx } from "react/jsx-runtime";
|
|
2
|
+
import classnames from "classnames";
|
|
3
|
+
import locale_badge_module from "./locale-badge.module.js";
|
|
4
|
+
const LocaleBadge = ({ locale })=>/*#__PURE__*/ jsx("span", {
|
|
5
|
+
"aria-hidden": "true",
|
|
6
|
+
title: `Localised — editing ${locale.toUpperCase()} content`,
|
|
7
|
+
className: classnames('byline-locale-badge', locale_badge_module.badge),
|
|
8
|
+
children: locale
|
|
9
|
+
});
|
|
10
|
+
export { LocaleBadge };
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
:is(.badge-w0AW86, .byline-locale-badge) {
|
|
2
|
+
border: var(--border-width-thin) var(--border-style-solid) var(--yellow-400);
|
|
3
|
+
border-radius: var(--border-radius-sm);
|
|
4
|
+
background-color: var(--yellow-100);
|
|
5
|
+
color: var(--yellow-800);
|
|
6
|
+
font-size: .6rem;
|
|
7
|
+
font-weight: var(--font-weight-semibold);
|
|
8
|
+
letter-spacing: var(--letter-spacing-wide);
|
|
9
|
+
text-transform: uppercase;
|
|
10
|
+
pointer-events: none;
|
|
11
|
+
-webkit-user-select: none;
|
|
12
|
+
user-select: none;
|
|
13
|
+
vertical-align: middle;
|
|
14
|
+
align-items: center;
|
|
15
|
+
gap: .125rem;
|
|
16
|
+
margin-left: .375rem;
|
|
17
|
+
padding: .125rem .375rem;
|
|
18
|
+
line-height: 1;
|
|
19
|
+
display: inline-flex;
|
|
20
|
+
}
|
|
21
|
+
|
|
22
|
+
:is(:is([data-theme="dark"], .dark) .badge-w0AW86, :is([data-theme="dark"], .dark) .byline-locale-badge) {
|
|
23
|
+
border-color: var(--yellow-700);
|
|
24
|
+
background-color: oklch(from var(--yellow-900) l c h / .4);
|
|
25
|
+
color: var(--yellow-400);
|
|
26
|
+
}
|
|
27
|
+
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* This Source Code is subject to the terms of the Mozilla Public
|
|
3
|
+
* License, v. 2.0. If a copy of the MPL was not distributed with this
|
|
4
|
+
* file, You can obtain one at http://mozilla.org/MPL/2.0/.
|
|
5
|
+
*
|
|
6
|
+
* Copyright (c) Infonomic Company Limited
|
|
7
|
+
*/
|
|
8
|
+
import type { DecimalField, FieldComponentSlots, FloatField, IntegerField } from '@byline/core';
|
|
9
|
+
export declare const NumericalField: ({ field, value, defaultValue, onChange, id, path, components, }: {
|
|
10
|
+
field: IntegerField | FloatField | DecimalField;
|
|
11
|
+
value?: string | number | null;
|
|
12
|
+
defaultValue?: string | number | null;
|
|
13
|
+
onChange?: (value: string) => void;
|
|
14
|
+
id?: string;
|
|
15
|
+
path?: string;
|
|
16
|
+
/** Optional UI component slot overrides from the admin config. */
|
|
17
|
+
components?: FieldComponentSlots;
|
|
18
|
+
}) => import("react").JSX.Element;
|
|
19
|
+
//# sourceMappingURL=numerical-field.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"numerical-field.d.ts","sourceRoot":"","sources":["../../../src/fields/numerical/numerical-field.tsx"],"names":[],"mappings":"AAAA;;;;;;GAMG;AAEH,OAAO,KAAK,EACV,YAAY,EAEZ,mBAAmB,EACnB,UAAU,EACV,YAAY,EACb,MAAM,cAAc,CAAA;AAKrB,eAAO,MAAM,cAAc,GAAI,iEAQ5B;IACD,KAAK,EAAE,YAAY,GAAG,UAAU,GAAG,YAAY,CAAA;IAC/C,KAAK,CAAC,EAAE,MAAM,GAAG,MAAM,GAAG,IAAI,CAAA;IAC9B,YAAY,CAAC,EAAE,MAAM,GAAG,MAAM,GAAG,IAAI,CAAA;IACrC,QAAQ,CAAC,EAAE,CAAC,KAAK,EAAE,MAAM,KAAK,IAAI,CAAA;IAClC,EAAE,CAAC,EAAE,MAAM,CAAA;IACX,IAAI,CAAC,EAAE,MAAM,CAAA;IACb,kEAAkE;IAClE,UAAU,CAAC,EAAE,mBAAmB,CAAA;CACjC,gCA2EA,CAAA"}
|
|
@@ -0,0 +1,73 @@
|
|
|
1
|
+
import { jsx, jsxs } from "react/jsx-runtime";
|
|
2
|
+
import { Input } from "@infonomic/uikit/react";
|
|
3
|
+
import { useFieldError, useFieldValue } from "../../forms/form-context.js";
|
|
4
|
+
const NumericalField = ({ field, value, defaultValue, onChange, id, path, components })=>{
|
|
5
|
+
const fieldPath = path ?? field.name;
|
|
6
|
+
const fieldError = useFieldError(fieldPath);
|
|
7
|
+
const fieldValue = useFieldValue(fieldPath);
|
|
8
|
+
const incomingValue = value ?? fieldValue ?? defaultValue ?? '';
|
|
9
|
+
const htmlId = id ?? fieldPath;
|
|
10
|
+
const displayValue = null == incomingValue ? '' : String(incomingValue);
|
|
11
|
+
const slots = components;
|
|
12
|
+
const CustomLabel = slots?.Label;
|
|
13
|
+
const CustomHelpText = slots?.HelpText;
|
|
14
|
+
const CustomField = slots?.Field;
|
|
15
|
+
const BeforeField = slots?.beforeField;
|
|
16
|
+
const AfterField = slots?.afterField;
|
|
17
|
+
const slotBaseProps = {
|
|
18
|
+
field: field,
|
|
19
|
+
path: fieldPath,
|
|
20
|
+
value: incomingValue,
|
|
21
|
+
error: fieldError,
|
|
22
|
+
id: htmlId
|
|
23
|
+
};
|
|
24
|
+
const hasCustomLabel = !!CustomLabel;
|
|
25
|
+
const suppressInputLabel = hasCustomLabel;
|
|
26
|
+
const suppressInputHelpText = !!CustomHelpText;
|
|
27
|
+
const renderLabel = ()=>{
|
|
28
|
+
if (hasCustomLabel) return /*#__PURE__*/ jsx(CustomLabel, {
|
|
29
|
+
...slotBaseProps,
|
|
30
|
+
label: field.label,
|
|
31
|
+
required: !field.optional
|
|
32
|
+
});
|
|
33
|
+
return null;
|
|
34
|
+
};
|
|
35
|
+
const renderInput = ()=>{
|
|
36
|
+
if (CustomField) return /*#__PURE__*/ jsx(CustomField, {
|
|
37
|
+
...slotBaseProps,
|
|
38
|
+
onChange: (v)=>onChange?.(v),
|
|
39
|
+
defaultValue: defaultValue,
|
|
40
|
+
placeholder: field.placeholder
|
|
41
|
+
});
|
|
42
|
+
return /*#__PURE__*/ jsx(Input, {
|
|
43
|
+
type: "number",
|
|
44
|
+
id: htmlId,
|
|
45
|
+
name: field.name,
|
|
46
|
+
label: suppressInputLabel ? void 0 : field.label,
|
|
47
|
+
required: !field.optional,
|
|
48
|
+
helpText: suppressInputHelpText ? void 0 : field.helpText,
|
|
49
|
+
value: displayValue,
|
|
50
|
+
onChange: (e)=>onChange?.(e.target.value),
|
|
51
|
+
error: null != fieldError,
|
|
52
|
+
errorText: fieldError
|
|
53
|
+
});
|
|
54
|
+
};
|
|
55
|
+
return /*#__PURE__*/ jsxs("div", {
|
|
56
|
+
className: `byline-field-${field.type} ${field.name}`,
|
|
57
|
+
children: [
|
|
58
|
+
renderLabel(),
|
|
59
|
+
BeforeField && /*#__PURE__*/ jsx(BeforeField, {
|
|
60
|
+
...slotBaseProps
|
|
61
|
+
}),
|
|
62
|
+
renderInput(),
|
|
63
|
+
AfterField && /*#__PURE__*/ jsx(AfterField, {
|
|
64
|
+
...slotBaseProps
|
|
65
|
+
}),
|
|
66
|
+
CustomHelpText && /*#__PURE__*/ jsx(CustomHelpText, {
|
|
67
|
+
...slotBaseProps,
|
|
68
|
+
helpText: field.helpText
|
|
69
|
+
})
|
|
70
|
+
]
|
|
71
|
+
});
|
|
72
|
+
};
|
|
73
|
+
export { NumericalField };
|