canopycms 0.0.0
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/README.md +404 -0
- package/dist/__integration__/fixtures/content-seeds.d.ts +43 -0
- package/dist/__integration__/fixtures/content-seeds.d.ts.map +1 -0
- package/dist/__integration__/fixtures/content-seeds.js +99 -0
- package/dist/__integration__/fixtures/content-seeds.js.map +1 -0
- package/dist/__integration__/fixtures/schemas.d.ts +12 -0
- package/dist/__integration__/fixtures/schemas.d.ts.map +1 -0
- package/dist/__integration__/fixtures/schemas.js +65 -0
- package/dist/__integration__/fixtures/schemas.js.map +1 -0
- package/dist/__integration__/test-utils/api-client.d.ts +123 -0
- package/dist/__integration__/test-utils/api-client.d.ts.map +1 -0
- package/dist/__integration__/test-utils/api-client.js +118 -0
- package/dist/__integration__/test-utils/api-client.js.map +1 -0
- package/dist/__integration__/test-utils/multi-user.d.ts +25 -0
- package/dist/__integration__/test-utils/multi-user.d.ts.map +1 -0
- package/dist/__integration__/test-utils/multi-user.js +105 -0
- package/dist/__integration__/test-utils/multi-user.js.map +1 -0
- package/dist/__integration__/test-utils/test-workspace.d.ts +25 -0
- package/dist/__integration__/test-utils/test-workspace.d.ts.map +1 -0
- package/dist/__integration__/test-utils/test-workspace.js +102 -0
- package/dist/__integration__/test-utils/test-workspace.js.map +1 -0
- package/dist/ai/generate.d.ts +31 -0
- package/dist/ai/generate.d.ts.map +1 -0
- package/dist/ai/generate.js +277 -0
- package/dist/ai/generate.js.map +1 -0
- package/dist/ai/handler.d.ts +38 -0
- package/dist/ai/handler.d.ts.map +1 -0
- package/dist/ai/handler.js +99 -0
- package/dist/ai/handler.js.map +1 -0
- package/dist/ai/index.d.ts +13 -0
- package/dist/ai/index.d.ts.map +1 -0
- package/dist/ai/index.js +10 -0
- package/dist/ai/index.js.map +1 -0
- package/dist/ai/json-to-markdown.d.ts +15 -0
- package/dist/ai/json-to-markdown.d.ts.map +1 -0
- package/dist/ai/json-to-markdown.js +318 -0
- package/dist/ai/json-to-markdown.js.map +1 -0
- package/dist/ai/resolve-branch.d.ts +13 -0
- package/dist/ai/resolve-branch.d.ts.map +1 -0
- package/dist/ai/resolve-branch.js +27 -0
- package/dist/ai/resolve-branch.js.map +1 -0
- package/dist/ai/types.d.ts +133 -0
- package/dist/ai/types.d.ts.map +1 -0
- package/dist/ai/types.js +14 -0
- package/dist/ai/types.js.map +1 -0
- package/dist/api/__test__/mock-client.d.ts +194 -0
- package/dist/api/__test__/mock-client.d.ts.map +1 -0
- package/dist/api/__test__/mock-client.js +322 -0
- package/dist/api/__test__/mock-client.js.map +1 -0
- package/dist/api/assets.d.ts +52 -0
- package/dist/api/assets.d.ts.map +1 -0
- package/dist/api/assets.js +106 -0
- package/dist/api/assets.js.map +1 -0
- package/dist/api/branch-merge.d.ts +28 -0
- package/dist/api/branch-merge.d.ts.map +1 -0
- package/dist/api/branch-merge.js +87 -0
- package/dist/api/branch-merge.js.map +1 -0
- package/dist/api/branch-review.d.ts +42 -0
- package/dist/api/branch-review.d.ts.map +1 -0
- package/dist/api/branch-review.js +102 -0
- package/dist/api/branch-review.js.map +1 -0
- package/dist/api/branch-status.d.ts +81 -0
- package/dist/api/branch-status.d.ts.map +1 -0
- package/dist/api/branch-status.js +125 -0
- package/dist/api/branch-status.js.map +1 -0
- package/dist/api/branch-withdraw.d.ts +18 -0
- package/dist/api/branch-withdraw.d.ts.map +1 -0
- package/dist/api/branch-withdraw.js +64 -0
- package/dist/api/branch-withdraw.js.map +1 -0
- package/dist/api/branch.d.ts +188 -0
- package/dist/api/branch.d.ts.map +1 -0
- package/dist/api/branch.js +381 -0
- package/dist/api/branch.js.map +1 -0
- package/dist/api/client.d.ts +289 -0
- package/dist/api/client.d.ts.map +1 -0
- package/dist/api/client.js +412 -0
- package/dist/api/client.js.map +1 -0
- package/dist/api/comments.d.ts +84 -0
- package/dist/api/comments.d.ts.map +1 -0
- package/dist/api/comments.js +142 -0
- package/dist/api/comments.js.map +1 -0
- package/dist/api/content.d.ts +154 -0
- package/dist/api/content.d.ts.map +1 -0
- package/dist/api/content.js +308 -0
- package/dist/api/content.js.map +1 -0
- package/dist/api/entries.d.ts +155 -0
- package/dist/api/entries.d.ts.map +1 -0
- package/dist/api/entries.js +466 -0
- package/dist/api/entries.js.map +1 -0
- package/dist/api/github-sync.d.ts +22 -0
- package/dist/api/github-sync.d.ts.map +1 -0
- package/dist/api/github-sync.js +121 -0
- package/dist/api/github-sync.js.map +1 -0
- package/dist/api/groups.d.ts +91 -0
- package/dist/api/groups.d.ts.map +1 -0
- package/dist/api/groups.js +270 -0
- package/dist/api/groups.js.map +1 -0
- package/dist/api/guards.d.ts +58 -0
- package/dist/api/guards.d.ts.map +1 -0
- package/dist/api/guards.js +166 -0
- package/dist/api/guards.js.map +1 -0
- package/dist/api/index.d.ts +18 -0
- package/dist/api/index.d.ts.map +1 -0
- package/dist/api/index.js +8 -0
- package/dist/api/index.js.map +1 -0
- package/dist/api/permissions.d.ts +278 -0
- package/dist/api/permissions.d.ts.map +1 -0
- package/dist/api/permissions.js +257 -0
- package/dist/api/permissions.js.map +1 -0
- package/dist/api/reference-options.d.ts +27 -0
- package/dist/api/reference-options.d.ts.map +1 -0
- package/dist/api/reference-options.js +88 -0
- package/dist/api/reference-options.js.map +1 -0
- package/dist/api/resolve-references.d.ts +32 -0
- package/dist/api/resolve-references.d.ts.map +1 -0
- package/dist/api/resolve-references.js +77 -0
- package/dist/api/resolve-references.js.map +1 -0
- package/dist/api/route-builder.d.ts +120 -0
- package/dist/api/route-builder.d.ts.map +1 -0
- package/dist/api/route-builder.js +108 -0
- package/dist/api/route-builder.js.map +1 -0
- package/dist/api/schema.d.ts +713 -0
- package/dist/api/schema.d.ts.map +1 -0
- package/dist/api/schema.js +656 -0
- package/dist/api/schema.js.map +1 -0
- package/dist/api/settings-helpers.d.ts +33 -0
- package/dist/api/settings-helpers.d.ts.map +1 -0
- package/dist/api/settings-helpers.js +61 -0
- package/dist/api/settings-helpers.js.map +1 -0
- package/dist/api/types.d.ts +37 -0
- package/dist/api/types.d.ts.map +1 -0
- package/dist/api/types.js +2 -0
- package/dist/api/types.js.map +1 -0
- package/dist/api/user.d.ts +9 -0
- package/dist/api/user.d.ts.map +1 -0
- package/dist/api/user.js +34 -0
- package/dist/api/user.js.map +1 -0
- package/dist/api/validators.d.ts +85 -0
- package/dist/api/validators.d.ts.map +1 -0
- package/dist/api/validators.js +160 -0
- package/dist/api/validators.js.map +1 -0
- package/dist/asset-store.d.ts +32 -0
- package/dist/asset-store.d.ts.map +1 -0
- package/dist/asset-store.js +84 -0
- package/dist/asset-store.js.map +1 -0
- package/dist/auth/cache.d.ts +8 -0
- package/dist/auth/cache.d.ts.map +1 -0
- package/dist/auth/cache.js +8 -0
- package/dist/auth/cache.js.map +1 -0
- package/dist/auth/caching-auth-plugin.d.ts +42 -0
- package/dist/auth/caching-auth-plugin.d.ts.map +1 -0
- package/dist/auth/caching-auth-plugin.js +78 -0
- package/dist/auth/caching-auth-plugin.js.map +1 -0
- package/dist/auth/context-helpers.d.ts +31 -0
- package/dist/auth/context-helpers.d.ts.map +1 -0
- package/dist/auth/context-helpers.js +53 -0
- package/dist/auth/context-helpers.js.map +1 -0
- package/dist/auth/file-based-auth-cache.d.ts +46 -0
- package/dist/auth/file-based-auth-cache.d.ts.map +1 -0
- package/dist/auth/file-based-auth-cache.js +226 -0
- package/dist/auth/file-based-auth-cache.js.map +1 -0
- package/dist/auth/index.d.ts +6 -0
- package/dist/auth/index.d.ts.map +1 -0
- package/dist/auth/index.js +2 -0
- package/dist/auth/index.js.map +1 -0
- package/dist/auth/plugin.d.ts +48 -0
- package/dist/auth/plugin.d.ts.map +1 -0
- package/dist/auth/plugin.js +2 -0
- package/dist/auth/plugin.js.map +1 -0
- package/dist/auth/types.d.ts +36 -0
- package/dist/auth/types.d.ts.map +1 -0
- package/dist/auth/types.js +2 -0
- package/dist/auth/types.js.map +1 -0
- package/dist/authorization/branch.d.ts +29 -0
- package/dist/authorization/branch.d.ts.map +1 -0
- package/dist/authorization/branch.js +67 -0
- package/dist/authorization/branch.js.map +1 -0
- package/dist/authorization/content.d.ts +38 -0
- package/dist/authorization/content.d.ts.map +1 -0
- package/dist/authorization/content.js +65 -0
- package/dist/authorization/content.js.map +1 -0
- package/dist/authorization/groups/index.d.ts +6 -0
- package/dist/authorization/groups/index.d.ts.map +1 -0
- package/dist/authorization/groups/index.js +6 -0
- package/dist/authorization/groups/index.js.map +1 -0
- package/dist/authorization/groups/loader.d.ts +24 -0
- package/dist/authorization/groups/loader.d.ts.map +1 -0
- package/dist/authorization/groups/loader.js +98 -0
- package/dist/authorization/groups/loader.js.map +1 -0
- package/dist/authorization/groups/schema.d.ts +67 -0
- package/dist/authorization/groups/schema.d.ts.map +1 -0
- package/dist/authorization/groups/schema.js +31 -0
- package/dist/authorization/groups/schema.js.map +1 -0
- package/dist/authorization/helpers.d.ts +35 -0
- package/dist/authorization/helpers.d.ts.map +1 -0
- package/dist/authorization/helpers.js +42 -0
- package/dist/authorization/helpers.js.map +1 -0
- package/dist/authorization/index.d.ts +36 -0
- package/dist/authorization/index.d.ts.map +1 -0
- package/dist/authorization/index.js +42 -0
- package/dist/authorization/index.js.map +1 -0
- package/dist/authorization/path.d.ts +29 -0
- package/dist/authorization/path.d.ts.map +1 -0
- package/dist/authorization/path.js +71 -0
- package/dist/authorization/path.js.map +1 -0
- package/dist/authorization/permissions/index.d.ts +6 -0
- package/dist/authorization/permissions/index.d.ts.map +1 -0
- package/dist/authorization/permissions/index.js +6 -0
- package/dist/authorization/permissions/index.js.map +1 -0
- package/dist/authorization/permissions/loader.d.ts +33 -0
- package/dist/authorization/permissions/loader.d.ts.map +1 -0
- package/dist/authorization/permissions/loader.js +85 -0
- package/dist/authorization/permissions/loader.js.map +1 -0
- package/dist/authorization/permissions/schema.d.ts +133 -0
- package/dist/authorization/permissions/schema.d.ts.map +1 -0
- package/dist/authorization/permissions/schema.js +56 -0
- package/dist/authorization/permissions/schema.js.map +1 -0
- package/dist/authorization/test-utils.d.ts +14 -0
- package/dist/authorization/test-utils.d.ts.map +1 -0
- package/dist/authorization/test-utils.js +13 -0
- package/dist/authorization/test-utils.js.map +1 -0
- package/dist/authorization/types.d.ts +55 -0
- package/dist/authorization/types.d.ts.map +1 -0
- package/dist/authorization/types.js +8 -0
- package/dist/authorization/types.js.map +1 -0
- package/dist/authorization/validation.d.ts +32 -0
- package/dist/authorization/validation.d.ts.map +1 -0
- package/dist/authorization/validation.js +53 -0
- package/dist/authorization/validation.js.map +1 -0
- package/dist/branch-metadata.d.ts +52 -0
- package/dist/branch-metadata.d.ts.map +1 -0
- package/dist/branch-metadata.js +125 -0
- package/dist/branch-metadata.js.map +1 -0
- package/dist/branch-registry.d.ts +44 -0
- package/dist/branch-registry.d.ts.map +1 -0
- package/dist/branch-registry.js +129 -0
- package/dist/branch-registry.js.map +1 -0
- package/dist/branch-schema-cache.d.ts +60 -0
- package/dist/branch-schema-cache.d.ts.map +1 -0
- package/dist/branch-schema-cache.js +142 -0
- package/dist/branch-schema-cache.js.map +1 -0
- package/dist/branch-workspace.d.ts +25 -0
- package/dist/branch-workspace.d.ts.map +1 -0
- package/dist/branch-workspace.js +87 -0
- package/dist/branch-workspace.js.map +1 -0
- package/dist/build/generate-ai-content.d.ts +28 -0
- package/dist/build/generate-ai-content.d.ts.map +1 -0
- package/dist/build/generate-ai-content.js +56 -0
- package/dist/build/generate-ai-content.js.map +1 -0
- package/dist/build/index.d.ts +8 -0
- package/dist/build/index.d.ts.map +1 -0
- package/dist/build/index.js +7 -0
- package/dist/build/index.js.map +1 -0
- package/dist/build-mode.d.ts +12 -0
- package/dist/build-mode.d.ts.map +1 -0
- package/dist/build-mode.js +25 -0
- package/dist/build-mode.js.map +1 -0
- package/dist/cli/generate-ai-content.d.ts +13 -0
- package/dist/cli/generate-ai-content.d.ts.map +1 -0
- package/dist/cli/generate-ai-content.js +78 -0
- package/dist/cli/generate-ai-content.js.map +1 -0
- package/dist/cli/init.d.ts +34 -0
- package/dist/cli/init.d.ts.map +1 -0
- package/dist/cli/init.js +372 -0
- package/dist/cli/init.js.map +1 -0
- package/dist/cli/templates.d.ts +20 -0
- package/dist/cli/templates.d.ts.map +1 -0
- package/dist/cli/templates.js +38 -0
- package/dist/cli/templates.js.map +1 -0
- package/dist/client.d.ts +11 -0
- package/dist/client.d.ts.map +1 -0
- package/dist/client.js +11 -0
- package/dist/client.js.map +1 -0
- package/dist/comment-store.d.ts +94 -0
- package/dist/comment-store.d.ts.map +1 -0
- package/dist/comment-store.js +234 -0
- package/dist/comment-store.js.map +1 -0
- package/dist/config/flatten.d.ts +29 -0
- package/dist/config/flatten.d.ts.map +1 -0
- package/dist/config/flatten.js +153 -0
- package/dist/config/flatten.js.map +1 -0
- package/dist/config/helpers.d.ts +48 -0
- package/dist/config/helpers.d.ts.map +1 -0
- package/dist/config/helpers.js +138 -0
- package/dist/config/helpers.js.map +1 -0
- package/dist/config/index.d.ts +21 -0
- package/dist/config/index.d.ts.map +1 -0
- package/dist/config/index.js +23 -0
- package/dist/config/index.js.map +1 -0
- package/dist/config/schemas/collection.d.ts +94 -0
- package/dist/config/schemas/collection.d.ts.map +1 -0
- package/dist/config/schemas/collection.js +57 -0
- package/dist/config/schemas/collection.js.map +1 -0
- package/dist/config/schemas/config.d.ts +304 -0
- package/dist/config/schemas/config.d.ts.map +1 -0
- package/dist/config/schemas/config.js +70 -0
- package/dist/config/schemas/config.js.map +1 -0
- package/dist/config/schemas/field.d.ts +276 -0
- package/dist/config/schemas/field.d.ts.map +1 -0
- package/dist/config/schemas/field.js +90 -0
- package/dist/config/schemas/field.js.map +1 -0
- package/dist/config/schemas/media.d.ts +48 -0
- package/dist/config/schemas/media.d.ts.map +1 -0
- package/dist/config/schemas/media.js +26 -0
- package/dist/config/schemas/media.js.map +1 -0
- package/dist/config/schemas/permissions.d.ts +76 -0
- package/dist/config/schemas/permissions.d.ts.map +1 -0
- package/dist/config/schemas/permissions.js +17 -0
- package/dist/config/schemas/permissions.js.map +1 -0
- package/dist/config/types.d.ts +272 -0
- package/dist/config/types.d.ts.map +1 -0
- package/dist/config/types.js +24 -0
- package/dist/config/types.js.map +1 -0
- package/dist/config/validation.d.ts +19 -0
- package/dist/config/validation.d.ts.map +1 -0
- package/dist/config/validation.js +66 -0
- package/dist/config/validation.js.map +1 -0
- package/dist/config-test.d.ts +18 -0
- package/dist/config-test.d.ts.map +1 -0
- package/dist/config-test.js +42 -0
- package/dist/config-test.js.map +1 -0
- package/dist/config.d.ts +10 -0
- package/dist/config.d.ts.map +1 -0
- package/dist/config.js +11 -0
- package/dist/config.js.map +1 -0
- package/dist/content-id-index.d.ts +152 -0
- package/dist/content-id-index.d.ts.map +1 -0
- package/dist/content-id-index.js +416 -0
- package/dist/content-id-index.js.map +1 -0
- package/dist/content-reader.d.ts +36 -0
- package/dist/content-reader.d.ts.map +1 -0
- package/dist/content-reader.js +149 -0
- package/dist/content-reader.js.map +1 -0
- package/dist/content-store.d.ts +129 -0
- package/dist/content-store.d.ts.map +1 -0
- package/dist/content-store.js +611 -0
- package/dist/content-store.js.map +1 -0
- package/dist/context.d.ts +44 -0
- package/dist/context.d.ts.map +1 -0
- package/dist/context.js +69 -0
- package/dist/context.js.map +1 -0
- package/dist/editor/BranchManager.d.ts +62 -0
- package/dist/editor/BranchManager.d.ts.map +1 -0
- package/dist/editor/BranchManager.js +87 -0
- package/dist/editor/BranchManager.js.map +1 -0
- package/dist/editor/BranchManager.stories.d.ts +8 -0
- package/dist/editor/BranchManager.stories.d.ts.map +1 -0
- package/dist/editor/BranchManager.stories.js +74 -0
- package/dist/editor/BranchManager.stories.js.map +1 -0
- package/dist/editor/CanopyEditor.d.ts +10 -0
- package/dist/editor/CanopyEditor.d.ts.map +1 -0
- package/dist/editor/CanopyEditor.js +20 -0
- package/dist/editor/CanopyEditor.js.map +1 -0
- package/dist/editor/CanopyEditor.stories.d.ts +7 -0
- package/dist/editor/CanopyEditor.stories.d.ts.map +1 -0
- package/dist/editor/CanopyEditor.stories.js +99 -0
- package/dist/editor/CanopyEditor.stories.js.map +1 -0
- package/dist/editor/CanopyEditorPage.d.ts +12 -0
- package/dist/editor/CanopyEditorPage.d.ts.map +1 -0
- package/dist/editor/CanopyEditorPage.js +13 -0
- package/dist/editor/CanopyEditorPage.js.map +1 -0
- package/dist/editor/CommentsPanel.d.ts +21 -0
- package/dist/editor/CommentsPanel.d.ts.map +1 -0
- package/dist/editor/CommentsPanel.js +77 -0
- package/dist/editor/CommentsPanel.js.map +1 -0
- package/dist/editor/CommentsPanel.stories.d.ts +10 -0
- package/dist/editor/CommentsPanel.stories.d.ts.map +1 -0
- package/dist/editor/CommentsPanel.stories.js +175 -0
- package/dist/editor/CommentsPanel.stories.js.map +1 -0
- package/dist/editor/Editor.d.ts +72 -0
- package/dist/editor/Editor.d.ts.map +1 -0
- package/dist/editor/Editor.js +568 -0
- package/dist/editor/Editor.js.map +1 -0
- package/dist/editor/Editor.stories.d.ts +7 -0
- package/dist/editor/Editor.stories.d.ts.map +1 -0
- package/dist/editor/Editor.stories.js +95 -0
- package/dist/editor/Editor.stories.js.map +1 -0
- package/dist/editor/EditorPanes.d.ts +11 -0
- package/dist/editor/EditorPanes.d.ts.map +1 -0
- package/dist/editor/EditorPanes.js +99 -0
- package/dist/editor/EditorPanes.js.map +1 -0
- package/dist/editor/EditorPanes.stories.d.ts +7 -0
- package/dist/editor/EditorPanes.stories.d.ts.map +1 -0
- package/dist/editor/EditorPanes.stories.js +116 -0
- package/dist/editor/EditorPanes.stories.js.map +1 -0
- package/dist/editor/EntryNavigator.d.ts +48 -0
- package/dist/editor/EntryNavigator.d.ts.map +1 -0
- package/dist/editor/EntryNavigator.js +331 -0
- package/dist/editor/EntryNavigator.js.map +1 -0
- package/dist/editor/EntryNavigator.stories.d.ts +8 -0
- package/dist/editor/EntryNavigator.stories.d.ts.map +1 -0
- package/dist/editor/EntryNavigator.stories.js +42 -0
- package/dist/editor/EntryNavigator.stories.js.map +1 -0
- package/dist/editor/FormRenderer.d.ts +34 -0
- package/dist/editor/FormRenderer.d.ts.map +1 -0
- package/dist/editor/FormRenderer.js +127 -0
- package/dist/editor/FormRenderer.js.map +1 -0
- package/dist/editor/FormRenderer.stories.d.ts +7 -0
- package/dist/editor/FormRenderer.stories.d.ts.map +1 -0
- package/dist/editor/FormRenderer.stories.js +115 -0
- package/dist/editor/FormRenderer.stories.js.map +1 -0
- package/dist/editor/GroupManager.d.ts +7 -0
- package/dist/editor/GroupManager.d.ts.map +1 -0
- package/dist/editor/GroupManager.js +7 -0
- package/dist/editor/GroupManager.js.map +1 -0
- package/dist/editor/GroupManager.stories.d.ts +19 -0
- package/dist/editor/GroupManager.stories.d.ts.map +1 -0
- package/dist/editor/GroupManager.stories.js +265 -0
- package/dist/editor/GroupManager.stories.js.map +1 -0
- package/dist/editor/PermissionManager.d.ts +9 -0
- package/dist/editor/PermissionManager.d.ts.map +1 -0
- package/dist/editor/PermissionManager.js +9 -0
- package/dist/editor/PermissionManager.js.map +1 -0
- package/dist/editor/PermissionManager.stories.d.ts +20 -0
- package/dist/editor/PermissionManager.stories.d.ts.map +1 -0
- package/dist/editor/PermissionManager.stories.js +506 -0
- package/dist/editor/PermissionManager.stories.js.map +1 -0
- package/dist/editor/canopy-path.d.ts +17 -0
- package/dist/editor/canopy-path.d.ts.map +1 -0
- package/dist/editor/canopy-path.js +49 -0
- package/dist/editor/canopy-path.js.map +1 -0
- package/dist/editor/client-reference-resolver.d.ts +18 -0
- package/dist/editor/client-reference-resolver.d.ts.map +1 -0
- package/dist/editor/client-reference-resolver.js +87 -0
- package/dist/editor/client-reference-resolver.js.map +1 -0
- package/dist/editor/comments/BranchComments.d.ts +27 -0
- package/dist/editor/comments/BranchComments.d.ts.map +1 -0
- package/dist/editor/comments/BranchComments.js +26 -0
- package/dist/editor/comments/BranchComments.js.map +1 -0
- package/dist/editor/comments/EntryComments.d.ts +26 -0
- package/dist/editor/comments/EntryComments.d.ts.map +1 -0
- package/dist/editor/comments/EntryComments.js +26 -0
- package/dist/editor/comments/EntryComments.js.map +1 -0
- package/dist/editor/comments/FieldWrapper.d.ts +32 -0
- package/dist/editor/comments/FieldWrapper.d.ts.map +1 -0
- package/dist/editor/comments/FieldWrapper.js +41 -0
- package/dist/editor/comments/FieldWrapper.js.map +1 -0
- package/dist/editor/comments/FieldWrapper.stories.d.ts +10 -0
- package/dist/editor/comments/FieldWrapper.stories.d.ts.map +1 -0
- package/dist/editor/comments/FieldWrapper.stories.js +173 -0
- package/dist/editor/comments/FieldWrapper.stories.js.map +1 -0
- package/dist/editor/comments/InlineCommentThread.d.ts +23 -0
- package/dist/editor/comments/InlineCommentThread.d.ts.map +1 -0
- package/dist/editor/comments/InlineCommentThread.js +82 -0
- package/dist/editor/comments/InlineCommentThread.js.map +1 -0
- package/dist/editor/comments/ThreadCarousel.d.ts +110 -0
- package/dist/editor/comments/ThreadCarousel.d.ts.map +1 -0
- package/dist/editor/comments/ThreadCarousel.js +223 -0
- package/dist/editor/comments/ThreadCarousel.js.map +1 -0
- package/dist/editor/components/ConfirmDeleteModal.d.ts +15 -0
- package/dist/editor/components/ConfirmDeleteModal.d.ts.map +1 -0
- package/dist/editor/components/ConfirmDeleteModal.js +11 -0
- package/dist/editor/components/ConfirmDeleteModal.js.map +1 -0
- package/dist/editor/components/EditorContext.d.ts +35 -0
- package/dist/editor/components/EditorContext.d.ts.map +1 -0
- package/dist/editor/components/EditorContext.js +19 -0
- package/dist/editor/components/EditorContext.js.map +1 -0
- package/dist/editor/components/EditorFooter.d.ts +20 -0
- package/dist/editor/components/EditorFooter.d.ts.map +1 -0
- package/dist/editor/components/EditorFooter.js +15 -0
- package/dist/editor/components/EditorFooter.js.map +1 -0
- package/dist/editor/components/EditorHeader.d.ts +166 -0
- package/dist/editor/components/EditorHeader.d.ts.map +1 -0
- package/dist/editor/components/EditorHeader.js +99 -0
- package/dist/editor/components/EditorHeader.js.map +1 -0
- package/dist/editor/components/EditorSidebar.d.ts +76 -0
- package/dist/editor/components/EditorSidebar.d.ts.map +1 -0
- package/dist/editor/components/EditorSidebar.js +40 -0
- package/dist/editor/components/EditorSidebar.js.map +1 -0
- package/dist/editor/components/EntryCreateModal.d.ts +27 -0
- package/dist/editor/components/EntryCreateModal.d.ts.map +1 -0
- package/dist/editor/components/EntryCreateModal.js +78 -0
- package/dist/editor/components/EntryCreateModal.js.map +1 -0
- package/dist/editor/components/RenameEntryModal.d.ts +18 -0
- package/dist/editor/components/RenameEntryModal.d.ts.map +1 -0
- package/dist/editor/components/RenameEntryModal.js +62 -0
- package/dist/editor/components/RenameEntryModal.js.map +1 -0
- package/dist/editor/components/UserBadge.d.ts +28 -0
- package/dist/editor/components/UserBadge.d.ts.map +1 -0
- package/dist/editor/components/UserBadge.js +93 -0
- package/dist/editor/components/UserBadge.js.map +1 -0
- package/dist/editor/components/index.d.ts +4 -0
- package/dist/editor/components/index.d.ts.map +1 -0
- package/dist/editor/components/index.js +6 -0
- package/dist/editor/components/index.js.map +1 -0
- package/dist/editor/context/ApiClientContext.d.ts +33 -0
- package/dist/editor/context/ApiClientContext.d.ts.map +1 -0
- package/dist/editor/context/ApiClientContext.js +43 -0
- package/dist/editor/context/ApiClientContext.js.map +1 -0
- package/dist/editor/context/EditorStateContext.d.ts +93 -0
- package/dist/editor/context/EditorStateContext.d.ts.map +1 -0
- package/dist/editor/context/EditorStateContext.js +143 -0
- package/dist/editor/context/EditorStateContext.js.map +1 -0
- package/dist/editor/context/index.d.ts +20 -0
- package/dist/editor/context/index.d.ts.map +1 -0
- package/dist/editor/context/index.js +20 -0
- package/dist/editor/context/index.js.map +1 -0
- package/dist/editor/editor-config.d.ts +14 -0
- package/dist/editor/editor-config.d.ts.map +1 -0
- package/dist/editor/editor-config.js +79 -0
- package/dist/editor/editor-config.js.map +1 -0
- package/dist/editor/editor-utils.d.ts +92 -0
- package/dist/editor/editor-utils.d.ts.map +1 -0
- package/dist/editor/editor-utils.js +238 -0
- package/dist/editor/editor-utils.js.map +1 -0
- package/dist/editor/env.d.ts +5 -0
- package/dist/editor/env.d.ts.map +1 -0
- package/dist/editor/env.js +5 -0
- package/dist/editor/env.js.map +1 -0
- package/dist/editor/fields/BlockField.d.ts +19 -0
- package/dist/editor/fields/BlockField.d.ts.map +1 -0
- package/dist/editor/fields/BlockField.js +86 -0
- package/dist/editor/fields/BlockField.js.map +1 -0
- package/dist/editor/fields/BlockField.stories.d.ts +7 -0
- package/dist/editor/fields/BlockField.stories.d.ts.map +1 -0
- package/dist/editor/fields/BlockField.stories.js +50 -0
- package/dist/editor/fields/BlockField.stories.js.map +1 -0
- package/dist/editor/fields/CodeField.d.ts +12 -0
- package/dist/editor/fields/CodeField.d.ts.map +1 -0
- package/dist/editor/fields/CodeField.js +11 -0
- package/dist/editor/fields/CodeField.js.map +1 -0
- package/dist/editor/fields/MarkdownField.d.ts +11 -0
- package/dist/editor/fields/MarkdownField.d.ts.map +1 -0
- package/dist/editor/fields/MarkdownField.js +94 -0
- package/dist/editor/fields/MarkdownField.js.map +1 -0
- package/dist/editor/fields/ObjectField.d.ts +15 -0
- package/dist/editor/fields/ObjectField.d.ts.map +1 -0
- package/dist/editor/fields/ObjectField.js +12 -0
- package/dist/editor/fields/ObjectField.js.map +1 -0
- package/dist/editor/fields/ReferenceField.d.ts +20 -0
- package/dist/editor/fields/ReferenceField.d.ts.map +1 -0
- package/dist/editor/fields/ReferenceField.js +66 -0
- package/dist/editor/fields/ReferenceField.js.map +1 -0
- package/dist/editor/fields/SelectField.d.ts +18 -0
- package/dist/editor/fields/SelectField.d.ts.map +1 -0
- package/dist/editor/fields/SelectField.js +17 -0
- package/dist/editor/fields/SelectField.js.map +1 -0
- package/dist/editor/fields/TextField.d.ts +11 -0
- package/dist/editor/fields/TextField.d.ts.map +1 -0
- package/dist/editor/fields/TextField.js +10 -0
- package/dist/editor/fields/TextField.js.map +1 -0
- package/dist/editor/fields/ToggleField.d.ts +12 -0
- package/dist/editor/fields/ToggleField.d.ts.map +1 -0
- package/dist/editor/fields/ToggleField.js +10 -0
- package/dist/editor/fields/ToggleField.js.map +1 -0
- package/dist/editor/fields/fields.stories.d.ts +8 -0
- package/dist/editor/fields/fields.stories.d.ts.map +1 -0
- package/dist/editor/fields/fields.stories.js +34 -0
- package/dist/editor/fields/fields.stories.js.map +1 -0
- package/dist/editor/group-manager/ExternalGroupsTab.d.ts +16 -0
- package/dist/editor/group-manager/ExternalGroupsTab.d.ts.map +1 -0
- package/dist/editor/group-manager/ExternalGroupsTab.js +16 -0
- package/dist/editor/group-manager/ExternalGroupsTab.js.map +1 -0
- package/dist/editor/group-manager/GroupCard.d.ts +24 -0
- package/dist/editor/group-manager/GroupCard.d.ts.map +1 -0
- package/dist/editor/group-manager/GroupCard.js +9 -0
- package/dist/editor/group-manager/GroupCard.js.map +1 -0
- package/dist/editor/group-manager/GroupForm.d.ts +15 -0
- package/dist/editor/group-manager/GroupForm.d.ts.map +1 -0
- package/dist/editor/group-manager/GroupForm.js +7 -0
- package/dist/editor/group-manager/GroupForm.js.map +1 -0
- package/dist/editor/group-manager/InternalGroupsTab.d.ts +26 -0
- package/dist/editor/group-manager/InternalGroupsTab.d.ts.map +1 -0
- package/dist/editor/group-manager/InternalGroupsTab.js +18 -0
- package/dist/editor/group-manager/InternalGroupsTab.js.map +1 -0
- package/dist/editor/group-manager/MemberList.d.ts +23 -0
- package/dist/editor/group-manager/MemberList.d.ts.map +1 -0
- package/dist/editor/group-manager/MemberList.js +13 -0
- package/dist/editor/group-manager/MemberList.js.map +1 -0
- package/dist/editor/group-manager/hooks/useExternalGroupSearch.d.ts +16 -0
- package/dist/editor/group-manager/hooks/useExternalGroupSearch.d.ts.map +1 -0
- package/dist/editor/group-manager/hooks/useExternalGroupSearch.js +43 -0
- package/dist/editor/group-manager/hooks/useExternalGroupSearch.js.map +1 -0
- package/dist/editor/group-manager/hooks/useGroupState.d.ts +24 -0
- package/dist/editor/group-manager/hooks/useGroupState.d.ts.map +1 -0
- package/dist/editor/group-manager/hooks/useGroupState.js +97 -0
- package/dist/editor/group-manager/hooks/useGroupState.js.map +1 -0
- package/dist/editor/group-manager/hooks/useUserSearch.d.ts +20 -0
- package/dist/editor/group-manager/hooks/useUserSearch.d.ts.map +1 -0
- package/dist/editor/group-manager/hooks/useUserSearch.js +60 -0
- package/dist/editor/group-manager/hooks/useUserSearch.js.map +1 -0
- package/dist/editor/group-manager/index.d.ts +14 -0
- package/dist/editor/group-manager/index.d.ts.map +1 -0
- package/dist/editor/group-manager/index.js +71 -0
- package/dist/editor/group-manager/index.js.map +1 -0
- package/dist/editor/group-manager/types.d.ts +24 -0
- package/dist/editor/group-manager/types.d.ts.map +1 -0
- package/dist/editor/group-manager/types.js +5 -0
- package/dist/editor/group-manager/types.js.map +1 -0
- package/dist/editor/hooks/__test__/test-utils.d.ts +129 -0
- package/dist/editor/hooks/__test__/test-utils.d.ts.map +1 -0
- package/dist/editor/hooks/__test__/test-utils.js +157 -0
- package/dist/editor/hooks/__test__/test-utils.js.map +1 -0
- package/dist/editor/hooks/index.d.ts +12 -0
- package/dist/editor/hooks/index.d.ts.map +1 -0
- package/dist/editor/hooks/index.js +15 -0
- package/dist/editor/hooks/index.js.map +1 -0
- package/dist/editor/hooks/useBranchActions.d.ts +34 -0
- package/dist/editor/hooks/useBranchActions.d.ts.map +1 -0
- package/dist/editor/hooks/useBranchActions.js +95 -0
- package/dist/editor/hooks/useBranchActions.js.map +1 -0
- package/dist/editor/hooks/useBranchManager.d.ts +88 -0
- package/dist/editor/hooks/useBranchManager.d.ts.map +1 -0
- package/dist/editor/hooks/useBranchManager.js +245 -0
- package/dist/editor/hooks/useBranchManager.js.map +1 -0
- package/dist/editor/hooks/useCommentSystem.d.ts +93 -0
- package/dist/editor/hooks/useCommentSystem.d.ts.map +1 -0
- package/dist/editor/hooks/useCommentSystem.js +240 -0
- package/dist/editor/hooks/useCommentSystem.js.map +1 -0
- package/dist/editor/hooks/useDraftManager.d.ts +64 -0
- package/dist/editor/hooks/useDraftManager.d.ts.map +1 -0
- package/dist/editor/hooks/useDraftManager.js +228 -0
- package/dist/editor/hooks/useDraftManager.js.map +1 -0
- package/dist/editor/hooks/useEditorLayout.d.ts +34 -0
- package/dist/editor/hooks/useEditorLayout.d.ts.map +1 -0
- package/dist/editor/hooks/useEditorLayout.js +52 -0
- package/dist/editor/hooks/useEditorLayout.js.map +1 -0
- package/dist/editor/hooks/useEntryManager.d.ts +66 -0
- package/dist/editor/hooks/useEntryManager.d.ts.map +1 -0
- package/dist/editor/hooks/useEntryManager.js +305 -0
- package/dist/editor/hooks/useEntryManager.js.map +1 -0
- package/dist/editor/hooks/useGroupManager.d.ts +43 -0
- package/dist/editor/hooks/useGroupManager.d.ts.map +1 -0
- package/dist/editor/hooks/useGroupManager.js +122 -0
- package/dist/editor/hooks/useGroupManager.js.map +1 -0
- package/dist/editor/hooks/usePermissionManager.d.ts +40 -0
- package/dist/editor/hooks/usePermissionManager.d.ts.map +1 -0
- package/dist/editor/hooks/usePermissionManager.js +94 -0
- package/dist/editor/hooks/usePermissionManager.js.map +1 -0
- package/dist/editor/hooks/useReferenceResolution.d.ts +47 -0
- package/dist/editor/hooks/useReferenceResolution.d.ts.map +1 -0
- package/dist/editor/hooks/useReferenceResolution.js +207 -0
- package/dist/editor/hooks/useReferenceResolution.js.map +1 -0
- package/dist/editor/hooks/useSchemaManager.d.ts +46 -0
- package/dist/editor/hooks/useSchemaManager.d.ts.map +1 -0
- package/dist/editor/hooks/useSchemaManager.js +235 -0
- package/dist/editor/hooks/useSchemaManager.js.map +1 -0
- package/dist/editor/hooks/useUserContext.d.ts +22 -0
- package/dist/editor/hooks/useUserContext.d.ts.map +1 -0
- package/dist/editor/hooks/useUserContext.js +49 -0
- package/dist/editor/hooks/useUserContext.js.map +1 -0
- package/dist/editor/hooks/useUserMetadata.d.ts +16 -0
- package/dist/editor/hooks/useUserMetadata.d.ts.map +1 -0
- package/dist/editor/hooks/useUserMetadata.js +55 -0
- package/dist/editor/hooks/useUserMetadata.js.map +1 -0
- package/dist/editor/permission-manager/GroupSelector.d.ts +13 -0
- package/dist/editor/permission-manager/GroupSelector.d.ts.map +1 -0
- package/dist/editor/permission-manager/GroupSelector.js +22 -0
- package/dist/editor/permission-manager/GroupSelector.js.map +1 -0
- package/dist/editor/permission-manager/PermissionEditor.d.ts +34 -0
- package/dist/editor/permission-manager/PermissionEditor.d.ts.map +1 -0
- package/dist/editor/permission-manager/PermissionEditor.js +30 -0
- package/dist/editor/permission-manager/PermissionEditor.js.map +1 -0
- package/dist/editor/permission-manager/PermissionLevelBadge.d.ts +16 -0
- package/dist/editor/permission-manager/PermissionLevelBadge.d.ts.map +1 -0
- package/dist/editor/permission-manager/PermissionLevelBadge.js +22 -0
- package/dist/editor/permission-manager/PermissionLevelBadge.js.map +1 -0
- package/dist/editor/permission-manager/PermissionTree.d.ts +37 -0
- package/dist/editor/permission-manager/PermissionTree.d.ts.map +1 -0
- package/dist/editor/permission-manager/PermissionTree.js +45 -0
- package/dist/editor/permission-manager/PermissionTree.js.map +1 -0
- package/dist/editor/permission-manager/UserSelector.d.ts +16 -0
- package/dist/editor/permission-manager/UserSelector.d.ts.map +1 -0
- package/dist/editor/permission-manager/UserSelector.js +14 -0
- package/dist/editor/permission-manager/UserSelector.js.map +1 -0
- package/dist/editor/permission-manager/constants.d.ts +12 -0
- package/dist/editor/permission-manager/constants.d.ts.map +1 -0
- package/dist/editor/permission-manager/constants.js +9 -0
- package/dist/editor/permission-manager/constants.js.map +1 -0
- package/dist/editor/permission-manager/hooks/useGroupsAndUsers.d.ts +30 -0
- package/dist/editor/permission-manager/hooks/useGroupsAndUsers.d.ts.map +1 -0
- package/dist/editor/permission-manager/hooks/useGroupsAndUsers.js +102 -0
- package/dist/editor/permission-manager/hooks/useGroupsAndUsers.js.map +1 -0
- package/dist/editor/permission-manager/hooks/usePermissionTree.d.ts +41 -0
- package/dist/editor/permission-manager/hooks/usePermissionTree.d.ts.map +1 -0
- package/dist/editor/permission-manager/hooks/usePermissionTree.js +125 -0
- package/dist/editor/permission-manager/hooks/usePermissionTree.js.map +1 -0
- package/dist/editor/permission-manager/index.d.ts +14 -0
- package/dist/editor/permission-manager/index.d.ts.map +1 -0
- package/dist/editor/permission-manager/index.js +125 -0
- package/dist/editor/permission-manager/index.js.map +1 -0
- package/dist/editor/permission-manager/types.d.ts +53 -0
- package/dist/editor/permission-manager/types.d.ts.map +1 -0
- package/dist/editor/permission-manager/types.js +5 -0
- package/dist/editor/permission-manager/types.js.map +1 -0
- package/dist/editor/permission-manager/utils.d.ts +60 -0
- package/dist/editor/permission-manager/utils.d.ts.map +1 -0
- package/dist/editor/permission-manager/utils.js +152 -0
- package/dist/editor/permission-manager/utils.js.map +1 -0
- package/dist/editor/preview-bridge.d.ts +64 -0
- package/dist/editor/preview-bridge.d.ts.map +1 -0
- package/dist/editor/preview-bridge.js +225 -0
- package/dist/editor/preview-bridge.js.map +1 -0
- package/dist/editor/schema-editor/CollectionEditor.d.ts +53 -0
- package/dist/editor/schema-editor/CollectionEditor.d.ts.map +1 -0
- package/dist/editor/schema-editor/CollectionEditor.js +220 -0
- package/dist/editor/schema-editor/CollectionEditor.js.map +1 -0
- package/dist/editor/schema-editor/EntryTypeEditor.d.ts +39 -0
- package/dist/editor/schema-editor/EntryTypeEditor.d.ts.map +1 -0
- package/dist/editor/schema-editor/EntryTypeEditor.js +161 -0
- package/dist/editor/schema-editor/EntryTypeEditor.js.map +1 -0
- package/dist/editor/schema-editor/index.d.ts +10 -0
- package/dist/editor/schema-editor/index.d.ts.map +1 -0
- package/dist/editor/schema-editor/index.js +10 -0
- package/dist/editor/schema-editor/index.js.map +1 -0
- package/dist/editor/setup-test-dom.d.ts +1 -0
- package/dist/editor/setup-test-dom.d.ts.map +1 -0
- package/dist/editor/setup-test-dom.js +12 -0
- package/dist/editor/setup-test-dom.js.map +1 -0
- package/dist/editor/test-setup.d.ts +6 -0
- package/dist/editor/test-setup.d.ts.map +1 -0
- package/dist/editor/test-setup.js +34 -0
- package/dist/editor/test-setup.js.map +1 -0
- package/dist/editor/theme.d.ts +165 -0
- package/dist/editor/theme.d.ts.map +1 -0
- package/dist/editor/theme.js +66 -0
- package/dist/editor/theme.js.map +1 -0
- package/dist/editor/utils/env.d.ts +23 -0
- package/dist/editor/utils/env.d.ts.map +1 -0
- package/dist/editor/utils/env.js +38 -0
- package/dist/editor/utils/env.js.map +1 -0
- package/dist/entry-schema-registry.d.ts +44 -0
- package/dist/entry-schema-registry.d.ts.map +1 -0
- package/dist/entry-schema-registry.js +101 -0
- package/dist/entry-schema-registry.js.map +1 -0
- package/dist/entry-schema.d.ts +74 -0
- package/dist/entry-schema.d.ts.map +1 -0
- package/dist/entry-schema.js +5 -0
- package/dist/entry-schema.js.map +1 -0
- package/dist/git-manager.d.ts +144 -0
- package/dist/git-manager.d.ts.map +1 -0
- package/dist/git-manager.js +563 -0
- package/dist/git-manager.js.map +1 -0
- package/dist/github-service.d.ts +93 -0
- package/dist/github-service.d.ts.map +1 -0
- package/dist/github-service.js +228 -0
- package/dist/github-service.js.map +1 -0
- package/dist/http/handler.d.ts +57 -0
- package/dist/http/handler.d.ts.map +1 -0
- package/dist/http/handler.js +197 -0
- package/dist/http/handler.js.map +1 -0
- package/dist/http/index.d.ts +7 -0
- package/dist/http/index.d.ts.map +1 -0
- package/dist/http/index.js +4 -0
- package/dist/http/index.js.map +1 -0
- package/dist/http/router.d.ts +49 -0
- package/dist/http/router.d.ts.map +1 -0
- package/dist/http/router.js +100 -0
- package/dist/http/router.js.map +1 -0
- package/dist/http/types.d.ts +34 -0
- package/dist/http/types.d.ts.map +1 -0
- package/dist/http/types.js +7 -0
- package/dist/http/types.js.map +1 -0
- package/dist/id.d.ts +17 -0
- package/dist/id.d.ts.map +1 -0
- package/dist/id.js +20 -0
- package/dist/id.js.map +1 -0
- package/dist/index.d.ts +11 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +9 -0
- package/dist/index.js.map +1 -0
- package/dist/operating-mode/client-safe-strategy.d.ts +57 -0
- package/dist/operating-mode/client-safe-strategy.d.ts.map +1 -0
- package/dist/operating-mode/client-safe-strategy.js +154 -0
- package/dist/operating-mode/client-safe-strategy.js.map +1 -0
- package/dist/operating-mode/client-unsafe-strategy.d.ts +26 -0
- package/dist/operating-mode/client-unsafe-strategy.d.ts.map +1 -0
- package/dist/operating-mode/client-unsafe-strategy.js +234 -0
- package/dist/operating-mode/client-unsafe-strategy.js.map +1 -0
- package/dist/operating-mode/client.d.ts +13 -0
- package/dist/operating-mode/client.d.ts.map +1 -0
- package/dist/operating-mode/client.js +11 -0
- package/dist/operating-mode/client.js.map +1 -0
- package/dist/operating-mode/index.d.ts +28 -0
- package/dist/operating-mode/index.d.ts.map +1 -0
- package/dist/operating-mode/index.js +28 -0
- package/dist/operating-mode/index.js.map +1 -0
- package/dist/operating-mode/types.d.ts +130 -0
- package/dist/operating-mode/types.d.ts.map +1 -0
- package/dist/operating-mode/types.js +9 -0
- package/dist/operating-mode/types.js.map +1 -0
- package/dist/paths/branch.d.ts +45 -0
- package/dist/paths/branch.d.ts.map +1 -0
- package/dist/paths/branch.js +84 -0
- package/dist/paths/branch.js.map +1 -0
- package/dist/paths/index.d.ts +22 -0
- package/dist/paths/index.d.ts.map +1 -0
- package/dist/paths/index.js +30 -0
- package/dist/paths/index.js.map +1 -0
- package/dist/paths/normalize-server.d.ts +20 -0
- package/dist/paths/normalize-server.d.ts.map +1 -0
- package/dist/paths/normalize-server.js +35 -0
- package/dist/paths/normalize-server.js.map +1 -0
- package/dist/paths/normalize.d.ts +59 -0
- package/dist/paths/normalize.d.ts.map +1 -0
- package/dist/paths/normalize.js +96 -0
- package/dist/paths/normalize.js.map +1 -0
- package/dist/paths/resolve.d.ts +30 -0
- package/dist/paths/resolve.d.ts.map +1 -0
- package/dist/paths/resolve.js +51 -0
- package/dist/paths/resolve.js.map +1 -0
- package/dist/paths/test-utils.d.ts +24 -0
- package/dist/paths/test-utils.d.ts.map +1 -0
- package/dist/paths/test-utils.js +23 -0
- package/dist/paths/test-utils.js.map +1 -0
- package/dist/paths/types.d.ts +72 -0
- package/dist/paths/types.d.ts.map +1 -0
- package/dist/paths/types.js +13 -0
- package/dist/paths/types.js.map +1 -0
- package/dist/paths/validation.d.ts +181 -0
- package/dist/paths/validation.d.ts.map +1 -0
- package/dist/paths/validation.js +322 -0
- package/dist/paths/validation.js.map +1 -0
- package/dist/reference-resolver.d.ts +58 -0
- package/dist/reference-resolver.d.ts.map +1 -0
- package/dist/reference-resolver.js +118 -0
- package/dist/reference-resolver.js.map +1 -0
- package/dist/schema/index.d.ts +18 -0
- package/dist/schema/index.d.ts.map +1 -0
- package/dist/schema/index.js +19 -0
- package/dist/schema/index.js.map +1 -0
- package/dist/schema/meta-loader.d.ts +73 -0
- package/dist/schema/meta-loader.d.ts.map +1 -0
- package/dist/schema/meta-loader.js +273 -0
- package/dist/schema/meta-loader.js.map +1 -0
- package/dist/schema/resolver.d.ts +42 -0
- package/dist/schema/resolver.d.ts.map +1 -0
- package/dist/schema/resolver.js +70 -0
- package/dist/schema/resolver.js.map +1 -0
- package/dist/schema/schema-store-types.d.ts +48 -0
- package/dist/schema/schema-store-types.d.ts.map +1 -0
- package/dist/schema/schema-store-types.js +8 -0
- package/dist/schema/schema-store-types.js.map +1 -0
- package/dist/schema/schema-store.d.ts +249 -0
- package/dist/schema/schema-store.d.ts.map +1 -0
- package/dist/schema/schema-store.js +624 -0
- package/dist/schema/schema-store.js.map +1 -0
- package/dist/schema/types.d.ts +30 -0
- package/dist/schema/types.d.ts.map +1 -0
- package/dist/schema/types.js +5 -0
- package/dist/schema/types.js.map +1 -0
- package/dist/server.d.ts +11 -0
- package/dist/server.d.ts.map +1 -0
- package/dist/server.js +10 -0
- package/dist/server.js.map +1 -0
- package/dist/services.d.ts +94 -0
- package/dist/services.d.ts.map +1 -0
- package/dist/services.js +251 -0
- package/dist/services.js.map +1 -0
- package/dist/settings-branch-utils.d.ts +21 -0
- package/dist/settings-branch-utils.d.ts.map +1 -0
- package/dist/settings-branch-utils.js +33 -0
- package/dist/settings-branch-utils.js.map +1 -0
- package/dist/settings-workspace.d.ts +30 -0
- package/dist/settings-workspace.d.ts.map +1 -0
- package/dist/settings-workspace.js +137 -0
- package/dist/settings-workspace.js.map +1 -0
- package/dist/task-queue/index.d.ts +3 -0
- package/dist/task-queue/index.d.ts.map +1 -0
- package/dist/task-queue/index.js +2 -0
- package/dist/task-queue/index.js.map +1 -0
- package/dist/task-queue/task-queue.d.ts +81 -0
- package/dist/task-queue/task-queue.d.ts.map +1 -0
- package/dist/task-queue/task-queue.js +434 -0
- package/dist/task-queue/task-queue.js.map +1 -0
- package/dist/task-queue/types.d.ts +39 -0
- package/dist/task-queue/types.d.ts.map +1 -0
- package/dist/task-queue/types.js +2 -0
- package/dist/task-queue/types.js.map +1 -0
- package/dist/test-utils/api-test-helpers.d.ts +238 -0
- package/dist/test-utils/api-test-helpers.d.ts.map +1 -0
- package/dist/test-utils/api-test-helpers.js +347 -0
- package/dist/test-utils/api-test-helpers.js.map +1 -0
- package/dist/test-utils/console-spy.d.ts +56 -0
- package/dist/test-utils/console-spy.d.ts.map +1 -0
- package/dist/test-utils/console-spy.js +81 -0
- package/dist/test-utils/console-spy.js.map +1 -0
- package/dist/test-utils/git-helpers.d.ts +21 -0
- package/dist/test-utils/git-helpers.d.ts.map +1 -0
- package/dist/test-utils/git-helpers.js +23 -0
- package/dist/test-utils/git-helpers.js.map +1 -0
- package/dist/test-utils/index.d.ts +5 -0
- package/dist/test-utils/index.d.ts.map +1 -0
- package/dist/test-utils/index.js +4 -0
- package/dist/test-utils/index.js.map +1 -0
- package/dist/types.d.ts +46 -0
- package/dist/types.d.ts.map +1 -0
- package/dist/types.js +2 -0
- package/dist/types.js.map +1 -0
- package/dist/user.d.ts +62 -0
- package/dist/user.d.ts.map +1 -0
- package/dist/user.js +69 -0
- package/dist/user.js.map +1 -0
- package/dist/utils/debug.d.ts +44 -0
- package/dist/utils/debug.d.ts.map +1 -0
- package/dist/utils/debug.js +99 -0
- package/dist/utils/debug.js.map +1 -0
- package/dist/utils/error.d.ts +63 -0
- package/dist/utils/error.d.ts.map +1 -0
- package/dist/utils/error.js +79 -0
- package/dist/utils/error.js.map +1 -0
- package/dist/utils/format.d.ts +8 -0
- package/dist/utils/format.d.ts.map +1 -0
- package/dist/utils/format.js +13 -0
- package/dist/utils/format.js.map +1 -0
- package/dist/validation/deletion-checker.d.ts +66 -0
- package/dist/validation/deletion-checker.d.ts.map +1 -0
- package/dist/validation/deletion-checker.js +163 -0
- package/dist/validation/deletion-checker.js.map +1 -0
- package/dist/validation/field-traversal.d.ts +62 -0
- package/dist/validation/field-traversal.d.ts.map +1 -0
- package/dist/validation/field-traversal.js +95 -0
- package/dist/validation/field-traversal.js.map +1 -0
- package/dist/validation/reference-validator.d.ts +45 -0
- package/dist/validation/reference-validator.d.ts.map +1 -0
- package/dist/validation/reference-validator.js +140 -0
- package/dist/validation/reference-validator.js.map +1 -0
- package/dist/worker/cms-worker.d.ts +122 -0
- package/dist/worker/cms-worker.d.ts.map +1 -0
- package/dist/worker/cms-worker.js +660 -0
- package/dist/worker/cms-worker.js.map +1 -0
- package/dist/worker/task-queue-config.d.ts +11 -0
- package/dist/worker/task-queue-config.d.ts.map +1 -0
- package/dist/worker/task-queue-config.js +24 -0
- package/dist/worker/task-queue-config.js.map +1 -0
- package/dist/worker/task-queue.d.ts +18 -0
- package/dist/worker/task-queue.d.ts.map +1 -0
- package/dist/worker/task-queue.js +20 -0
- package/dist/worker/task-queue.js.map +1 -0
- package/package.json +144 -0
- package/src/__integration__/errors/invalid-content.test.ts +238 -0
- package/src/__integration__/errors/permission-denied.test.ts +220 -0
- package/src/__integration__/fixtures/content-seeds.ts +105 -0
- package/src/__integration__/fixtures/schemas.ts +67 -0
- package/src/__integration__/initialization/prod-sim-init.test.ts +139 -0
- package/src/__integration__/permissions/path-permissions.test.ts +314 -0
- package/src/__integration__/permissions/role-permissions.test.ts +354 -0
- package/src/__integration__/permissions/settings-branch-isolation.test.ts +317 -0
- package/src/__integration__/settings/groups-api.test.ts +403 -0
- package/src/__integration__/test-utils/api-client.ts +167 -0
- package/src/__integration__/test-utils/multi-user.ts +129 -0
- package/src/__integration__/test-utils/test-workspace.ts +130 -0
- package/src/__integration__/user/user-context.test.ts +174 -0
- package/src/__integration__/validation/input-validation.test.ts +166 -0
- package/src/__integration__/workflows/api-editing-workflow.test.ts +244 -0
- package/src/__integration__/workflows/conflict-resolution.test.ts +259 -0
- package/src/__integration__/workflows/editing-workflow.test.ts +205 -0
- package/src/__integration__/workflows/review-workflow.test.ts +260 -0
- package/src/ai/__tests__/build.integration.test.ts +224 -0
- package/src/ai/__tests__/generate.integration.test.ts +495 -0
- package/src/ai/__tests__/handler.integration.test.ts +212 -0
- package/src/ai/__tests__/json-to-markdown.test.ts +553 -0
- package/src/ai/generate.ts +410 -0
- package/src/ai/handler.ts +123 -0
- package/src/ai/index.ts +26 -0
- package/src/ai/json-to-markdown.ts +424 -0
- package/src/ai/resolve-branch.ts +34 -0
- package/src/ai/types.ts +160 -0
- package/src/api/AGENTS.md +81 -0
- package/src/api/__test__/mock-client.ts +404 -0
- package/src/api/assets.test.ts +140 -0
- package/src/api/assets.ts +154 -0
- package/src/api/branch-merge.test.ts +163 -0
- package/src/api/branch-merge.ts +113 -0
- package/src/api/branch-review.test.ts +297 -0
- package/src/api/branch-review.ts +136 -0
- package/src/api/branch-status.test.ts +85 -0
- package/src/api/branch-status.ts +153 -0
- package/src/api/branch-withdraw.test.ts +146 -0
- package/src/api/branch-withdraw.ts +81 -0
- package/src/api/branch-workflow.integration.test.ts +578 -0
- package/src/api/branch.test.ts +620 -0
- package/src/api/branch.ts +492 -0
- package/src/api/client.test.ts +349 -0
- package/src/api/client.ts +506 -0
- package/src/api/comments.test.ts +285 -0
- package/src/api/comments.ts +210 -0
- package/src/api/content.test.ts +345 -0
- package/src/api/content.ts +454 -0
- package/src/api/entries.test.ts +1339 -0
- package/src/api/entries.ts +650 -0
- package/src/api/github-sync.ts +144 -0
- package/src/api/groups.test.ts +1013 -0
- package/src/api/groups.ts +375 -0
- package/src/api/guards.test.ts +533 -0
- package/src/api/guards.ts +271 -0
- package/src/api/index.ts +87 -0
- package/src/api/permissions.test.ts +766 -0
- package/src/api/permissions.ts +334 -0
- package/src/api/reference-options.ts +118 -0
- package/src/api/resolve-references.ts +107 -0
- package/src/api/route-builder.ts +289 -0
- package/src/api/schema.test.ts +840 -0
- package/src/api/schema.ts +936 -0
- package/src/api/security.test.ts +233 -0
- package/src/api/settings-helpers.ts +84 -0
- package/src/api/types.ts +40 -0
- package/src/api/user.test.ts +127 -0
- package/src/api/user.ts +42 -0
- package/src/api/validators.test.ts +275 -0
- package/src/api/validators.ts +176 -0
- package/src/asset-store.test.ts +37 -0
- package/src/asset-store.ts +110 -0
- package/src/auth/cache.ts +7 -0
- package/src/auth/caching-auth-plugin.test.ts +154 -0
- package/src/auth/caching-auth-plugin.ts +109 -0
- package/src/auth/context-helpers.ts +75 -0
- package/src/auth/file-based-auth-cache.test.ts +257 -0
- package/src/auth/file-based-auth-cache.ts +279 -0
- package/src/auth/index.ts +12 -0
- package/src/auth/plugin.ts +51 -0
- package/src/auth/types.ts +38 -0
- package/src/authorization/__tests__/branch.test.ts +260 -0
- package/src/authorization/__tests__/content.test.ts +142 -0
- package/src/authorization/__tests__/path.test.ts +133 -0
- package/src/authorization/__tests__/permissions-loader.test.ts +200 -0
- package/src/authorization/branch.ts +94 -0
- package/src/authorization/content.ts +93 -0
- package/src/authorization/groups/index.ts +11 -0
- package/src/authorization/groups/loader.ts +127 -0
- package/src/authorization/groups/schema.ts +48 -0
- package/src/authorization/helpers.ts +48 -0
- package/src/authorization/index.ts +84 -0
- package/src/authorization/path.ts +112 -0
- package/src/authorization/permissions/index.ts +11 -0
- package/src/authorization/permissions/loader.ts +116 -0
- package/src/authorization/permissions/schema.ts +66 -0
- package/src/authorization/test-utils.ts +15 -0
- package/src/authorization/types.ts +66 -0
- package/src/authorization/validation.test.ts +100 -0
- package/src/authorization/validation.ts +62 -0
- package/src/branch-metadata.test.ts +168 -0
- package/src/branch-metadata.ts +166 -0
- package/src/branch-registry.test.ts +248 -0
- package/src/branch-registry.ts +152 -0
- package/src/branch-schema-cache.test.ts +275 -0
- package/src/branch-schema-cache.ts +189 -0
- package/src/branch-workspace.test.ts +183 -0
- package/src/branch-workspace.ts +124 -0
- package/src/build/generate-ai-content.ts +78 -0
- package/src/build/index.ts +8 -0
- package/src/build-mode.ts +27 -0
- package/src/cli/generate-ai-content.ts +100 -0
- package/src/cli/init.test.ts +240 -0
- package/src/cli/init.ts +457 -0
- package/src/cli/templates/Dockerfile.cms.template +19 -0
- package/src/cli/templates/canopy.ts.template +55 -0
- package/src/cli/templates/canopycms.config.ts.template +11 -0
- package/src/cli/templates/deploy-cms.yml.template +27 -0
- package/src/cli/templates/edit-page.tsx.template +32 -0
- package/src/cli/templates/route.ts.template +12 -0
- package/src/cli/templates/schemas.ts.template +16 -0
- package/src/cli/templates.ts +47 -0
- package/src/client.ts +12 -0
- package/src/comment-store.test.ts +442 -0
- package/src/comment-store.ts +301 -0
- package/src/config/__tests__/config.test.ts +513 -0
- package/src/config/flatten.ts +174 -0
- package/src/config/helpers.ts +167 -0
- package/src/config/index.ts +86 -0
- package/src/config/schemas/collection.ts +67 -0
- package/src/config/schemas/config.ts +77 -0
- package/src/config/schemas/field.ts +108 -0
- package/src/config/schemas/media.ts +27 -0
- package/src/config/schemas/permissions.ts +21 -0
- package/src/config/types.ts +321 -0
- package/src/config/validation.ts +70 -0
- package/src/config-test.ts +65 -0
- package/src/config.ts +11 -0
- package/src/content-id-index.test.ts +512 -0
- package/src/content-id-index.ts +479 -0
- package/src/content-reader.test.ts +478 -0
- package/src/content-reader.ts +214 -0
- package/src/content-store.test.ts +1126 -0
- package/src/content-store.ts +793 -0
- package/src/context.ts +111 -0
- package/src/editor/BranchManager.stories.tsx +80 -0
- package/src/editor/BranchManager.test.tsx +324 -0
- package/src/editor/BranchManager.tsx +461 -0
- package/src/editor/CanopyEditor.stories.tsx +128 -0
- package/src/editor/CanopyEditor.test.tsx +81 -0
- package/src/editor/CanopyEditor.tsx +73 -0
- package/src/editor/CanopyEditorPage.test.tsx +59 -0
- package/src/editor/CanopyEditorPage.tsx +25 -0
- package/src/editor/CommentsPanel.stories.tsx +184 -0
- package/src/editor/CommentsPanel.tsx +338 -0
- package/src/editor/Editor.integration.test.tsx +227 -0
- package/src/editor/Editor.stories.tsx +119 -0
- package/src/editor/Editor.tsx +1221 -0
- package/src/editor/EditorPanes.stories.tsx +256 -0
- package/src/editor/EditorPanes.test.tsx +77 -0
- package/src/editor/EditorPanes.tsx +180 -0
- package/src/editor/EntryNavigator.stories.tsx +65 -0
- package/src/editor/EntryNavigator.test.tsx +598 -0
- package/src/editor/EntryNavigator.tsx +665 -0
- package/src/editor/FormRenderer.stories.tsx +212 -0
- package/src/editor/FormRenderer.test.tsx +194 -0
- package/src/editor/FormRenderer.tsx +432 -0
- package/src/editor/GroupManager.stories.tsx +301 -0
- package/src/editor/GroupManager.test.tsx +682 -0
- package/src/editor/GroupManager.tsx +9 -0
- package/src/editor/PermissionManager.stories.tsx +539 -0
- package/src/editor/PermissionManager.test.tsx +864 -0
- package/src/editor/PermissionManager.tsx +12 -0
- package/src/editor/canopy-path.test.ts +23 -0
- package/src/editor/canopy-path.ts +52 -0
- package/src/editor/client-reference-resolver.ts +118 -0
- package/src/editor/comments/BranchComments.tsx +93 -0
- package/src/editor/comments/EntryComments.tsx +94 -0
- package/src/editor/comments/FieldWrapper.stories.tsx +210 -0
- package/src/editor/comments/FieldWrapper.tsx +129 -0
- package/src/editor/comments/InlineCommentThread.test.tsx +384 -0
- package/src/editor/comments/InlineCommentThread.tsx +246 -0
- package/src/editor/comments/ThreadCarousel.test.tsx +393 -0
- package/src/editor/comments/ThreadCarousel.tsx +525 -0
- package/src/editor/components/ConfirmDeleteModal.tsx +49 -0
- package/src/editor/components/EditorContext.tsx +49 -0
- package/src/editor/components/EditorFooter.tsx +47 -0
- package/src/editor/components/EditorHeader.tsx +492 -0
- package/src/editor/components/EditorSidebar.tsx +193 -0
- package/src/editor/components/EntryCreateModal.tsx +193 -0
- package/src/editor/components/RenameEntryModal.tsx +152 -0
- package/src/editor/components/UserBadge.test.tsx +274 -0
- package/src/editor/components/UserBadge.tsx +240 -0
- package/src/editor/components/index.ts +6 -0
- package/src/editor/context/ApiClientContext.tsx +56 -0
- package/src/editor/context/EditorStateContext.tsx +221 -0
- package/src/editor/context/index.ts +40 -0
- package/src/editor/editor-config.test.ts +385 -0
- package/src/editor/editor-config.ts +94 -0
- package/src/editor/editor-utils.test.ts +772 -0
- package/src/editor/editor-utils.ts +303 -0
- package/src/editor/env.ts +4 -0
- package/src/editor/fields/BlockField.stories.tsx +79 -0
- package/src/editor/fields/BlockField.tsx +267 -0
- package/src/editor/fields/CodeField.tsx +41 -0
- package/src/editor/fields/MarkdownField.tsx +205 -0
- package/src/editor/fields/ObjectField.tsx +71 -0
- package/src/editor/fields/ReferenceField.tsx +138 -0
- package/src/editor/fields/SelectField.tsx +76 -0
- package/src/editor/fields/TextField.tsx +35 -0
- package/src/editor/fields/ToggleField.tsx +37 -0
- package/src/editor/fields/fields.stories.tsx +40 -0
- package/src/editor/group-manager/ExternalGroupsTab.tsx +114 -0
- package/src/editor/group-manager/GroupCard.tsx +102 -0
- package/src/editor/group-manager/GroupForm.tsx +66 -0
- package/src/editor/group-manager/InternalGroupsTab.tsx +147 -0
- package/src/editor/group-manager/MemberList.tsx +184 -0
- package/src/editor/group-manager/hooks/useExternalGroupSearch.ts +63 -0
- package/src/editor/group-manager/hooks/useGroupState.ts +134 -0
- package/src/editor/group-manager/hooks/useUserSearch.ts +84 -0
- package/src/editor/group-manager/index.tsx +210 -0
- package/src/editor/group-manager/types.ts +28 -0
- package/src/editor/hooks/README.md +26 -0
- package/src/editor/hooks/__test__/test-utils.tsx +183 -0
- package/src/editor/hooks/index.ts +23 -0
- package/src/editor/hooks/useBranchActions.test.tsx +267 -0
- package/src/editor/hooks/useBranchActions.tsx +121 -0
- package/src/editor/hooks/useBranchManager.test.tsx +391 -0
- package/src/editor/hooks/useBranchManager.tsx +326 -0
- package/src/editor/hooks/useCommentSystem.test.ts +615 -0
- package/src/editor/hooks/useCommentSystem.ts +347 -0
- package/src/editor/hooks/useDraftManager.test.ts +375 -0
- package/src/editor/hooks/useDraftManager.ts +259 -0
- package/src/editor/hooks/useEditorLayout.test.ts +147 -0
- package/src/editor/hooks/useEditorLayout.ts +67 -0
- package/src/editor/hooks/useEntryManager.test.ts +588 -0
- package/src/editor/hooks/useEntryManager.ts +387 -0
- package/src/editor/hooks/useGroupManager.test.ts +277 -0
- package/src/editor/hooks/useGroupManager.ts +139 -0
- package/src/editor/hooks/usePermissionManager.test.ts +211 -0
- package/src/editor/hooks/usePermissionManager.ts +113 -0
- package/src/editor/hooks/useReferenceResolution.ts +248 -0
- package/src/editor/hooks/useSchemaManager.test.ts +370 -0
- package/src/editor/hooks/useSchemaManager.ts +310 -0
- package/src/editor/hooks/useUserContext.tsx +57 -0
- package/src/editor/hooks/useUserMetadata.test.ts +191 -0
- package/src/editor/hooks/useUserMetadata.ts +71 -0
- package/src/editor/permission-manager/GroupSelector.tsx +73 -0
- package/src/editor/permission-manager/PermissionEditor.tsx +321 -0
- package/src/editor/permission-manager/PermissionLevelBadge.tsx +53 -0
- package/src/editor/permission-manager/PermissionTree.tsx +237 -0
- package/src/editor/permission-manager/UserSelector.tsx +95 -0
- package/src/editor/permission-manager/constants.tsx +18 -0
- package/src/editor/permission-manager/hooks/useGroupsAndUsers.ts +153 -0
- package/src/editor/permission-manager/hooks/usePermissionTree.ts +200 -0
- package/src/editor/permission-manager/index.tsx +294 -0
- package/src/editor/permission-manager/types.ts +58 -0
- package/src/editor/permission-manager/utils.ts +179 -0
- package/src/editor/preview-bridge.test.tsx +50 -0
- package/src/editor/preview-bridge.tsx +294 -0
- package/src/editor/schema-editor/CollectionEditor.test.tsx +238 -0
- package/src/editor/schema-editor/CollectionEditor.tsx +520 -0
- package/src/editor/schema-editor/EntryTypeEditor.test.tsx +215 -0
- package/src/editor/schema-editor/EntryTypeEditor.tsx +367 -0
- package/src/editor/schema-editor/index.ts +19 -0
- package/src/editor/setup-test-dom.ts +10 -0
- package/src/editor/test-setup.ts +33 -0
- package/src/editor/theme.tsx +119 -0
- package/src/editor/utils/env.ts +39 -0
- package/src/entry-schema-registry.test.ts +281 -0
- package/src/entry-schema-registry.ts +121 -0
- package/src/entry-schema.ts +84 -0
- package/src/git-manager.test.ts +552 -0
- package/src/git-manager.ts +667 -0
- package/src/github-service.test.ts +312 -0
- package/src/github-service.ts +295 -0
- package/src/http/handler.test.ts +275 -0
- package/src/http/handler.ts +280 -0
- package/src/http/index.ts +11 -0
- package/src/http/router.ts +164 -0
- package/src/http/types.ts +44 -0
- package/src/id.test.ts +48 -0
- package/src/id.ts +22 -0
- package/src/index.ts +26 -0
- package/src/operating-mode/__tests__/strategies.test.ts +511 -0
- package/src/operating-mode/client-safe-strategy.ts +184 -0
- package/src/operating-mode/client-unsafe-strategy.ts +303 -0
- package/src/operating-mode/client.ts +13 -0
- package/src/operating-mode/index.ts +34 -0
- package/src/operating-mode/types.ts +186 -0
- package/src/paths/__tests__/branch.test.ts +53 -0
- package/src/paths/__tests__/normalize.test.ts +141 -0
- package/src/paths/__tests__/resolve.test.ts +207 -0
- package/src/paths/__tests__/validation.test.ts +61 -0
- package/src/paths/branch.ts +115 -0
- package/src/paths/index.ts +73 -0
- package/src/paths/normalize-server.ts +40 -0
- package/src/paths/normalize.ts +107 -0
- package/src/paths/resolve.ts +61 -0
- package/src/paths/test-utils.ts +37 -0
- package/src/paths/types.ts +68 -0
- package/src/paths/validation.test.ts +480 -0
- package/src/paths/validation.ts +391 -0
- package/src/reference-resolver.test.ts +107 -0
- package/src/reference-resolver.ts +157 -0
- package/src/schema/index.ts +29 -0
- package/src/schema/meta-loader.ts +366 -0
- package/src/schema/resolver.ts +83 -0
- package/src/schema/schema-store-types.ts +56 -0
- package/src/schema/schema-store.test.ts +816 -0
- package/src/schema/schema-store.ts +795 -0
- package/src/schema/types.ts +33 -0
- package/src/schema-meta-loader.test.ts +447 -0
- package/src/server.ts +15 -0
- package/src/services.test.ts +559 -0
- package/src/services.ts +373 -0
- package/src/settings-branch-utils.ts +53 -0
- package/src/settings-workspace.ts +156 -0
- package/src/task-queue/README.md +144 -0
- package/src/task-queue/index.ts +14 -0
- package/src/task-queue/task-queue.test.ts +524 -0
- package/src/task-queue/task-queue.ts +514 -0
- package/src/task-queue/types.ts +41 -0
- package/src/test-utils/api-test-helpers.ts +445 -0
- package/src/test-utils/console-spy.test.ts +14 -0
- package/src/test-utils/console-spy.ts +125 -0
- package/src/test-utils/git-helpers.ts +31 -0
- package/src/test-utils/index.ts +4 -0
- package/src/types.ts +54 -0
- package/src/user.ts +118 -0
- package/src/utils/debug.test.ts +114 -0
- package/src/utils/debug.ts +127 -0
- package/src/utils/error.test.ts +92 -0
- package/src/utils/error.ts +83 -0
- package/src/utils/format.ts +12 -0
- package/src/validation/__tests__/field-traversal.test.ts +263 -0
- package/src/validation/deletion-checker.ts +234 -0
- package/src/validation/field-traversal.ts +146 -0
- package/src/validation/reference-validator.ts +168 -0
- package/src/worker/cms-worker-rebase.test.ts +473 -0
- package/src/worker/cms-worker.ts +777 -0
- package/src/worker/integration.test.ts +289 -0
- package/src/worker/task-queue-config.ts +25 -0
- package/src/worker/task-queue.test.ts +452 -0
- package/src/worker/task-queue.ts +58 -0
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
'use client';
|
|
2
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
3
|
+
import { ActionIcon, Badge, Group, Paper, Text, Tooltip } from '@mantine/core';
|
|
4
|
+
import { IconEdit, IconTrash } from '@tabler/icons-react';
|
|
5
|
+
import { MemberList } from './MemberList';
|
|
6
|
+
export const GroupCard = ({ group, onEdit, onDelete, onAddMember, onRemoveMember, onGetUserMetadata, showUserSearch, searchQuery, searchResults, isSearching, searchError, onSearchQueryChange, onShowSearch, onHideSearch, canSearch, }) => {
|
|
7
|
+
return (_jsxs(Paper, { withBorder: true, p: "sm", mb: "xs", children: [_jsxs(Group, { justify: "space-between", mb: "sm", children: [_jsxs("div", { style: { flex: 1 }, children: [_jsxs(Group, { gap: "xs", children: [_jsx(Text, { size: "sm", fw: 500, children: group.name }), _jsxs(Badge, { size: "sm", variant: "light", children: [group.members?.length || 0, " members"] })] }), _jsxs(Text, { size: "xs", c: "dimmed", mt: 4, children: ["ID: ", group.id] }), group.description && (_jsx(Text, { size: "xs", c: "dimmed", mt: 4, children: group.description }))] }), _jsxs(Group, { gap: "xs", children: [_jsx(Tooltip, { label: "Edit group", children: _jsx(ActionIcon, { size: "sm", variant: "subtle", onClick: () => onEdit(group), children: _jsx(IconEdit, { size: 16 }) }) }), _jsx(Tooltip, { label: "Delete group", children: _jsx(ActionIcon, { size: "sm", variant: "subtle", color: "red", onClick: () => onDelete(group.id), children: _jsx(IconTrash, { size: 16 }) }) })] })] }), _jsx(MemberList, { groupId: group.id, members: group.members || [], onRemoveMember: onRemoveMember, onAddMember: onAddMember, onGetUserMetadata: onGetUserMetadata, showUserSearch: showUserSearch, searchQuery: searchQuery, searchResults: searchResults, isSearching: isSearching, searchError: searchError, onSearchQueryChange: onSearchQueryChange, onShowSearch: onShowSearch, onHideSearch: onHideSearch, canSearch: canSearch })] }));
|
|
8
|
+
};
|
|
9
|
+
//# sourceMappingURL=GroupCard.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"GroupCard.js","sourceRoot":"","sources":["../../../src/editor/group-manager/GroupCard.tsx"],"names":[],"mappings":"AAAA,YAAY,CAAA;;AAOZ,OAAO,EAAE,UAAU,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,EAAE,IAAI,EAAE,OAAO,EAAE,MAAM,eAAe,CAAA;AAC9E,OAAO,EAAE,QAAQ,EAAE,SAAS,EAAE,MAAM,qBAAqB,CAAA;AAEzD,OAAO,EAAE,UAAU,EAAE,MAAM,cAAc,CAAA;AAqBzC,MAAM,CAAC,MAAM,SAAS,GAA6B,CAAC,EAClD,KAAK,EACL,MAAM,EACN,QAAQ,EACR,WAAW,EACX,cAAc,EACd,iBAAiB,EACjB,cAAc,EACd,WAAW,EACX,aAAa,EACb,WAAW,EACX,WAAW,EACX,mBAAmB,EACnB,YAAY,EACZ,YAAY,EACZ,SAAS,GACV,EAAE,EAAE;IACH,OAAO,CACL,MAAC,KAAK,IAAC,UAAU,QAAC,CAAC,EAAC,IAAI,EAAC,EAAE,EAAC,IAAI,aAC9B,MAAC,KAAK,IAAC,OAAO,EAAC,eAAe,EAAC,EAAE,EAAC,IAAI,aACpC,eAAK,KAAK,EAAE,EAAE,IAAI,EAAE,CAAC,EAAE,aACrB,MAAC,KAAK,IAAC,GAAG,EAAC,IAAI,aACb,KAAC,IAAI,IAAC,IAAI,EAAC,IAAI,EAAC,EAAE,EAAE,GAAG,YACpB,KAAK,CAAC,IAAI,GACN,EACP,MAAC,KAAK,IAAC,IAAI,EAAC,IAAI,EAAC,OAAO,EAAC,OAAO,aAC7B,KAAK,CAAC,OAAO,EAAE,MAAM,IAAI,CAAC,gBACrB,IACF,EACR,MAAC,IAAI,IAAC,IAAI,EAAC,IAAI,EAAC,CAAC,EAAC,QAAQ,EAAC,EAAE,EAAE,CAAC,qBACzB,KAAK,CAAC,EAAE,IACR,EACN,KAAK,CAAC,WAAW,IAAI,CACpB,KAAC,IAAI,IAAC,IAAI,EAAC,IAAI,EAAC,CAAC,EAAC,QAAQ,EAAC,EAAE,EAAE,CAAC,YAC7B,KAAK,CAAC,WAAW,GACb,CACR,IACG,EACN,MAAC,KAAK,IAAC,GAAG,EAAC,IAAI,aACb,KAAC,OAAO,IAAC,KAAK,EAAC,YAAY,YACzB,KAAC,UAAU,IAAC,IAAI,EAAC,IAAI,EAAC,OAAO,EAAC,QAAQ,EAAC,OAAO,EAAE,GAAG,EAAE,CAAC,MAAM,CAAC,KAAK,CAAC,YACjE,KAAC,QAAQ,IAAC,IAAI,EAAE,EAAE,GAAI,GACX,GACL,EACV,KAAC,OAAO,IAAC,KAAK,EAAC,cAAc,YAC3B,KAAC,UAAU,IAAC,IAAI,EAAC,IAAI,EAAC,OAAO,EAAC,QAAQ,EAAC,KAAK,EAAC,KAAK,EAAC,OAAO,EAAE,GAAG,EAAE,CAAC,QAAQ,CAAC,KAAK,CAAC,EAAE,CAAC,YAClF,KAAC,SAAS,IAAC,IAAI,EAAE,EAAE,GAAI,GACZ,GACL,IACJ,IACF,EAER,KAAC,UAAU,IACT,OAAO,EAAE,KAAK,CAAC,EAAE,EACjB,OAAO,EAAE,KAAK,CAAC,OAAO,IAAI,EAAE,EAC5B,cAAc,EAAE,cAAc,EAC9B,WAAW,EAAE,WAAW,EACxB,iBAAiB,EAAE,iBAAiB,EACpC,cAAc,EAAE,cAAc,EAC9B,WAAW,EAAE,WAAW,EACxB,aAAa,EAAE,aAAa,EAC5B,WAAW,EAAE,WAAW,EACxB,WAAW,EAAE,WAAW,EACxB,mBAAmB,EAAE,mBAAmB,EACxC,YAAY,EAAE,YAAY,EAC1B,YAAY,EAAE,YAAY,EAC1B,SAAS,EAAE,SAAS,GACpB,IACI,CACT,CAAA;AACH,CAAC,CAAA"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Modal form for creating/editing groups
|
|
3
|
+
*/
|
|
4
|
+
import React from 'react';
|
|
5
|
+
import type { InternalGroup, GroupFormData } from './types';
|
|
6
|
+
export interface GroupFormProps {
|
|
7
|
+
isOpen: boolean;
|
|
8
|
+
editingGroup: InternalGroup | null;
|
|
9
|
+
formData: GroupFormData;
|
|
10
|
+
onFormChange: (data: Partial<GroupFormData>) => void;
|
|
11
|
+
onSave: () => void;
|
|
12
|
+
onClose: () => void;
|
|
13
|
+
}
|
|
14
|
+
export declare const GroupForm: React.FC<GroupFormProps>;
|
|
15
|
+
//# sourceMappingURL=GroupForm.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"GroupForm.d.ts","sourceRoot":"","sources":["../../../src/editor/group-manager/GroupForm.tsx"],"names":[],"mappings":"AAEA;;GAEG;AAEH,OAAO,KAAK,MAAM,OAAO,CAAA;AAEzB,OAAO,KAAK,EAAE,aAAa,EAAE,aAAa,EAAE,MAAM,SAAS,CAAA;AAE3D,MAAM,WAAW,cAAc;IAC7B,MAAM,EAAE,OAAO,CAAA;IACf,YAAY,EAAE,aAAa,GAAG,IAAI,CAAA;IAClC,QAAQ,EAAE,aAAa,CAAA;IACvB,YAAY,EAAE,CAAC,IAAI,EAAE,OAAO,CAAC,aAAa,CAAC,KAAK,IAAI,CAAA;IACpD,MAAM,EAAE,MAAM,IAAI,CAAA;IAClB,OAAO,EAAE,MAAM,IAAI,CAAA;CACpB;AAED,eAAO,MAAM,SAAS,EAAE,KAAK,CAAC,EAAE,CAAC,cAAc,CA8C9C,CAAA"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
'use client';
|
|
2
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
3
|
+
import { Button, Group, Modal, Paper, Stack, Text, TextInput, Textarea } from '@mantine/core';
|
|
4
|
+
export const GroupForm = ({ isOpen, editingGroup, formData, onFormChange, onSave, onClose, }) => {
|
|
5
|
+
return (_jsx(Modal, { opened: isOpen, onClose: onClose, title: editingGroup ? 'Edit Group' : 'Create Group', children: _jsxs(Stack, { gap: "md", children: [editingGroup && (_jsxs("div", { children: [_jsx(Text, { size: "sm", fw: 500, mb: 4, children: "ID (system-generated)" }), _jsx(Paper, { p: "xs", withBorder: true, bg: "gray.0", children: _jsx(Text, { size: "sm", ff: "monospace", c: "dimmed", children: editingGroup.id }) })] })), _jsx(TextInput, { label: "Group Name", placeholder: "e.g., Content Editors", value: formData.name, onChange: (e) => onFormChange({ name: e.target.value }), required: true }), _jsx(Textarea, { label: "Description", placeholder: "Optional description", value: formData.description, onChange: (e) => onFormChange({ description: e.target.value }), rows: 3 }), _jsxs(Group, { justify: "flex-end", gap: "sm", children: [_jsx(Button, { variant: "subtle", onClick: onClose, children: "Cancel" }), _jsx(Button, { onClick: onSave, children: editingGroup ? 'Save' : 'Create' })] })] }) }));
|
|
6
|
+
};
|
|
7
|
+
//# sourceMappingURL=GroupForm.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"GroupForm.js","sourceRoot":"","sources":["../../../src/editor/group-manager/GroupForm.tsx"],"names":[],"mappings":"AAAA,YAAY,CAAA;;AAOZ,OAAO,EAAE,MAAM,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,EAAE,IAAI,EAAE,SAAS,EAAE,QAAQ,EAAE,MAAM,eAAe,CAAA;AAY7F,MAAM,CAAC,MAAM,SAAS,GAA6B,CAAC,EAClD,MAAM,EACN,YAAY,EACZ,QAAQ,EACR,YAAY,EACZ,MAAM,EACN,OAAO,GACR,EAAE,EAAE;IACH,OAAO,CACL,KAAC,KAAK,IAAC,MAAM,EAAE,MAAM,EAAE,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,YAAY,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,cAAc,YAC1F,MAAC,KAAK,IAAC,GAAG,EAAC,IAAI,aACZ,YAAY,IAAI,CACf,0BACE,KAAC,IAAI,IAAC,IAAI,EAAC,IAAI,EAAC,EAAE,EAAE,GAAG,EAAE,EAAE,EAAE,CAAC,sCAEvB,EACP,KAAC,KAAK,IAAC,CAAC,EAAC,IAAI,EAAC,UAAU,QAAC,EAAE,EAAC,QAAQ,YAClC,KAAC,IAAI,IAAC,IAAI,EAAC,IAAI,EAAC,EAAE,EAAC,WAAW,EAAC,CAAC,EAAC,QAAQ,YACtC,YAAY,CAAC,EAAE,GACX,GACD,IACJ,CACP,EACD,KAAC,SAAS,IACR,KAAK,EAAC,YAAY,EAClB,WAAW,EAAC,uBAAuB,EACnC,KAAK,EAAE,QAAQ,CAAC,IAAI,EACpB,QAAQ,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,YAAY,CAAC,EAAE,IAAI,EAAE,CAAC,CAAC,MAAM,CAAC,KAAK,EAAE,CAAC,EACvD,QAAQ,SACR,EACF,KAAC,QAAQ,IACP,KAAK,EAAC,aAAa,EACnB,WAAW,EAAC,sBAAsB,EAClC,KAAK,EAAE,QAAQ,CAAC,WAAW,EAC3B,QAAQ,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,YAAY,CAAC,EAAE,WAAW,EAAE,CAAC,CAAC,MAAM,CAAC,KAAK,EAAE,CAAC,EAC9D,IAAI,EAAE,CAAC,GACP,EACF,MAAC,KAAK,IAAC,OAAO,EAAC,UAAU,EAAC,GAAG,EAAC,IAAI,aAChC,KAAC,MAAM,IAAC,OAAO,EAAC,QAAQ,EAAC,OAAO,EAAE,OAAO,uBAEhC,EACT,KAAC,MAAM,IAAC,OAAO,EAAE,MAAM,YAAG,YAAY,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,QAAQ,GAAU,IAC9D,IACF,GACF,CACT,CAAA;AACH,CAAC,CAAA"}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Internal groups tab component
|
|
3
|
+
*/
|
|
4
|
+
import React from 'react';
|
|
5
|
+
import type { InternalGroup, UserSearchResult, CanopyGroupId, CanopyUserId } from './types';
|
|
6
|
+
export interface InternalGroupsTabProps {
|
|
7
|
+
groups: InternalGroup[];
|
|
8
|
+
canEdit: boolean;
|
|
9
|
+
onCreateGroup: () => void;
|
|
10
|
+
onEditGroup: (group: InternalGroup) => void;
|
|
11
|
+
onDeleteGroup: (groupId: CanopyGroupId) => void;
|
|
12
|
+
onAddMember: (groupId: CanopyGroupId, userId: CanopyUserId) => void;
|
|
13
|
+
onRemoveMember: (groupId: CanopyGroupId, userId: CanopyUserId) => void;
|
|
14
|
+
onGetUserMetadata?: (userId: string) => Promise<UserSearchResult | null>;
|
|
15
|
+
activeSearchGroupId: string | null;
|
|
16
|
+
searchQuery: string;
|
|
17
|
+
searchResults: UserSearchResult[];
|
|
18
|
+
isSearching: boolean;
|
|
19
|
+
searchError: string | null;
|
|
20
|
+
onSearchQueryChange: (query: string) => void;
|
|
21
|
+
onShowSearch: (groupId: string) => void;
|
|
22
|
+
onHideSearch: () => void;
|
|
23
|
+
canSearch: boolean;
|
|
24
|
+
}
|
|
25
|
+
export declare const InternalGroupsTab: React.FC<InternalGroupsTabProps>;
|
|
26
|
+
//# sourceMappingURL=InternalGroupsTab.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"InternalGroupsTab.d.ts","sourceRoot":"","sources":["../../../src/editor/group-manager/InternalGroupsTab.tsx"],"names":[],"mappings":"AAEA;;GAEG;AAEH,OAAO,KAAK,MAAM,OAAO,CAAA;AAGzB,OAAO,KAAK,EAAE,aAAa,EAAE,gBAAgB,EAAE,aAAa,EAAE,YAAY,EAAE,MAAM,SAAS,CAAA;AAG3F,MAAM,WAAW,sBAAsB;IACrC,MAAM,EAAE,aAAa,EAAE,CAAA;IACvB,OAAO,EAAE,OAAO,CAAA;IAChB,aAAa,EAAE,MAAM,IAAI,CAAA;IACzB,WAAW,EAAE,CAAC,KAAK,EAAE,aAAa,KAAK,IAAI,CAAA;IAC3C,aAAa,EAAE,CAAC,OAAO,EAAE,aAAa,KAAK,IAAI,CAAA;IAC/C,WAAW,EAAE,CAAC,OAAO,EAAE,aAAa,EAAE,MAAM,EAAE,YAAY,KAAK,IAAI,CAAA;IACnE,cAAc,EAAE,CAAC,OAAO,EAAE,aAAa,EAAE,MAAM,EAAE,YAAY,KAAK,IAAI,CAAA;IACtE,iBAAiB,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,KAAK,OAAO,CAAC,gBAAgB,GAAG,IAAI,CAAC,CAAA;IAExE,mBAAmB,EAAE,MAAM,GAAG,IAAI,CAAA;IAClC,WAAW,EAAE,MAAM,CAAA;IACnB,aAAa,EAAE,gBAAgB,EAAE,CAAA;IACjC,WAAW,EAAE,OAAO,CAAA;IACpB,WAAW,EAAE,MAAM,GAAG,IAAI,CAAA;IAC1B,mBAAmB,EAAE,CAAC,KAAK,EAAE,MAAM,KAAK,IAAI,CAAA;IAC5C,YAAY,EAAE,CAAC,OAAO,EAAE,MAAM,KAAK,IAAI,CAAA;IACvC,YAAY,EAAE,MAAM,IAAI,CAAA;IACxB,SAAS,EAAE,OAAO,CAAA;CACnB;AAED,eAAO,MAAM,iBAAiB,EAAE,KAAK,CAAC,EAAE,CAAC,sBAAsB,CAiH9D,CAAA"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
'use client';
|
|
2
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
3
|
+
import { Button, Group, Paper, ScrollArea, Stack, Text } from '@mantine/core';
|
|
4
|
+
import { IconPlus, IconUsers } from '@tabler/icons-react';
|
|
5
|
+
import { GroupCard } from './GroupCard';
|
|
6
|
+
export const InternalGroupsTab = ({ groups, canEdit, onCreateGroup, onEditGroup, onDeleteGroup, onAddMember, onRemoveMember, onGetUserMetadata, activeSearchGroupId, searchQuery, searchResults, isSearching, searchError, onSearchQueryChange, onShowSearch, onHideSearch, canSearch, }) => {
|
|
7
|
+
// Read-only view
|
|
8
|
+
if (!canEdit) {
|
|
9
|
+
return (_jsx("div", { style: {
|
|
10
|
+
flex: 1,
|
|
11
|
+
overflow: 'auto',
|
|
12
|
+
paddingTop: 'var(--mantine-spacing-md)',
|
|
13
|
+
}, children: groups.length === 0 ? (_jsxs(Paper, { withBorder: true, p: "md", style: { textAlign: 'center' }, children: [_jsx(IconUsers, { size: 32, color: "gray", style: { margin: '0 auto', marginBottom: 8 } }), _jsx(Text, { size: "sm", c: "dimmed", children: "No internal groups" })] })) : (_jsx(Stack, { gap: "xs", pb: "md", children: groups.map((group) => (_jsx(Paper, { withBorder: true, p: "sm", children: _jsxs(Group, { justify: "space-between", children: [_jsxs("div", { children: [_jsx(Text, { size: "sm", fw: 500, children: group.name }), group.description && (_jsx(Text, { size: "xs", c: "dimmed", children: group.description }))] }), _jsxs(Text, { size: "sm", variant: "light", children: [group.members?.length || 0, " members"] })] }) }, group.id))) })) }));
|
|
14
|
+
}
|
|
15
|
+
// Editable view
|
|
16
|
+
return (_jsx(ScrollArea, { style: { height: '100%' }, pt: "md", children: _jsxs(Stack, { gap: "sm", pb: "md", children: [_jsxs(Group, { justify: "space-between", mb: "xs", children: [_jsx(Text, { size: "sm", fw: 500, c: "dimmed", children: "Manage your internal groups" }), _jsx(Button, { size: "xs", variant: "light", leftSection: _jsx(IconPlus, { size: 14 }), onClick: onCreateGroup, children: "Create Group" })] }), groups.length === 0 ? (_jsxs(Paper, { withBorder: true, p: "md", style: { textAlign: 'center' }, children: [_jsx(IconUsers, { size: 32, color: "gray", style: { margin: '0 auto', marginBottom: 8 } }), _jsx(Text, { size: "sm", c: "dimmed", children: "No internal groups yet. Create one to get started." })] })) : (groups.map((group) => (_jsx(GroupCard, { group: group, onEdit: onEditGroup, onDelete: onDeleteGroup, onAddMember: onAddMember, onRemoveMember: onRemoveMember, onGetUserMetadata: onGetUserMetadata, showUserSearch: activeSearchGroupId === group.id, searchQuery: searchQuery, searchResults: searchResults, isSearching: isSearching, searchError: searchError, onSearchQueryChange: onSearchQueryChange, onShowSearch: () => onShowSearch(group.id), onHideSearch: onHideSearch, canSearch: canSearch }, group.id))))] }) }));
|
|
17
|
+
};
|
|
18
|
+
//# sourceMappingURL=InternalGroupsTab.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"InternalGroupsTab.js","sourceRoot":"","sources":["../../../src/editor/group-manager/InternalGroupsTab.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Member list component with user search for adding members
|
|
3
|
+
*/
|
|
4
|
+
import React from 'react';
|
|
5
|
+
import type { UserSearchResult, CanopyGroupId, CanopyUserId } from './types';
|
|
6
|
+
export interface MemberListProps {
|
|
7
|
+
groupId: CanopyGroupId;
|
|
8
|
+
members: CanopyUserId[];
|
|
9
|
+
onRemoveMember: (groupId: CanopyGroupId, userId: CanopyUserId) => void;
|
|
10
|
+
onAddMember: (groupId: CanopyGroupId, userId: CanopyUserId) => void;
|
|
11
|
+
onGetUserMetadata?: (userId: string) => Promise<UserSearchResult | null>;
|
|
12
|
+
showUserSearch: boolean;
|
|
13
|
+
searchQuery: string;
|
|
14
|
+
searchResults: UserSearchResult[];
|
|
15
|
+
isSearching: boolean;
|
|
16
|
+
searchError: string | null;
|
|
17
|
+
onSearchQueryChange: (query: string) => void;
|
|
18
|
+
onShowSearch: () => void;
|
|
19
|
+
onHideSearch: () => void;
|
|
20
|
+
canSearch: boolean;
|
|
21
|
+
}
|
|
22
|
+
export declare const MemberList: React.FC<MemberListProps>;
|
|
23
|
+
//# sourceMappingURL=MemberList.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"MemberList.d.ts","sourceRoot":"","sources":["../../../src/editor/group-manager/MemberList.tsx"],"names":[],"mappings":"AAEA;;GAEG;AAEH,OAAO,KAAK,MAAM,OAAO,CAAA;AAazB,OAAO,KAAK,EAAE,gBAAgB,EAAE,aAAa,EAAE,YAAY,EAAE,MAAM,SAAS,CAAA;AAG5E,MAAM,WAAW,eAAe;IAC9B,OAAO,EAAE,aAAa,CAAA;IACtB,OAAO,EAAE,YAAY,EAAE,CAAA;IACvB,cAAc,EAAE,CAAC,OAAO,EAAE,aAAa,EAAE,MAAM,EAAE,YAAY,KAAK,IAAI,CAAA;IACtE,WAAW,EAAE,CAAC,OAAO,EAAE,aAAa,EAAE,MAAM,EAAE,YAAY,KAAK,IAAI,CAAA;IACnE,iBAAiB,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,KAAK,OAAO,CAAC,gBAAgB,GAAG,IAAI,CAAC,CAAA;IAExE,cAAc,EAAE,OAAO,CAAA;IACvB,WAAW,EAAE,MAAM,CAAA;IACnB,aAAa,EAAE,gBAAgB,EAAE,CAAA;IACjC,WAAW,EAAE,OAAO,CAAA;IACpB,WAAW,EAAE,MAAM,GAAG,IAAI,CAAA;IAC1B,mBAAmB,EAAE,CAAC,KAAK,EAAE,MAAM,KAAK,IAAI,CAAA;IAC5C,YAAY,EAAE,MAAM,IAAI,CAAA;IACxB,YAAY,EAAE,MAAM,IAAI,CAAA;IACxB,SAAS,EAAE,OAAO,CAAA;CACnB;AAED,eAAO,MAAM,UAAU,EAAE,KAAK,CAAC,EAAE,CAAC,eAAe,CA+IhD,CAAA"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
'use client';
|
|
2
|
+
import { jsx as _jsx, Fragment as _Fragment, jsxs as _jsxs } from "react/jsx-runtime";
|
|
3
|
+
import { ActionIcon, Badge, Button, Group, Loader, Paper, Stack, Text, TextInput, } from '@mantine/core';
|
|
4
|
+
import { IconSearch, IconX } from '@tabler/icons-react';
|
|
5
|
+
import { UserBadge } from '../components/UserBadge';
|
|
6
|
+
export const MemberList = ({ groupId, members, onRemoveMember, onAddMember, onGetUserMetadata, showUserSearch, searchQuery, searchResults, isSearching, searchError, onSearchQueryChange, onShowSearch, onHideSearch, canSearch, }) => {
|
|
7
|
+
const handleAddMember = (userId) => {
|
|
8
|
+
onAddMember(groupId, userId);
|
|
9
|
+
onHideSearch();
|
|
10
|
+
};
|
|
11
|
+
return (_jsxs("div", { children: [_jsx(Text, { size: "xs", fw: 500, mb: 4, children: "Members" }), _jsx(Group, { gap: "xs", mb: "xs", children: members.length > 0 ? (members.map((userId) => onGetUserMetadata ? (_jsx(UserBadge, { userId: userId, getUserMetadata: onGetUserMetadata, variant: "avatar-name", size: "xs", badgeVariant: "filled", color: "blue", onRemove: () => onRemoveMember(groupId, userId), showEmailTooltip: true }, userId)) : (_jsx(Badge, { variant: "filled", color: "blue", pr: 3, rightSection: _jsx(ActionIcon, { size: "xs", color: "blue", radius: "xl", variant: "transparent", onClick: () => onRemoveMember(groupId, userId), children: _jsx(IconX, { size: 10, style: { color: 'white' } }) }), children: userId }, userId)))) : (_jsx(Text, { size: "xs", c: "dimmed", children: "No members" })) }), showUserSearch ? (_jsx(Paper, { withBorder: true, p: "sm", mt: "xs", children: _jsxs(Stack, { gap: "xs", children: [_jsx(TextInput, { placeholder: "Search users by name or email...", value: searchQuery, onChange: (e) => onSearchQueryChange(e.target.value), "aria-label": "Search users by name or email", size: "xs" }), isSearching && _jsx(Loader, { size: "xs" }), searchError && (_jsx(Text, { size: "xs", c: "red", children: searchError })), searchResults.length > 0 && (_jsx(Stack, { gap: 4, children: searchResults.map((user) => (_jsx(Paper, { p: "xs", withBorder: true, style: { cursor: 'pointer' }, onClick: () => handleAddMember(user.id), children: onGetUserMetadata ? (_jsx(UserBadge, { userId: user.id, getUserMetadata: onGetUserMetadata, variant: "full", size: "sm", cachedUser: user, showEmailTooltip: false })) : (_jsxs(_Fragment, { children: [_jsx(Text, { size: "sm", fw: 500, children: user.name }), _jsx(Text, { size: "xs", c: "dimmed", children: user.email })] })) }, user.id))) })), searchQuery.trim() && !isSearching && searchResults.length === 0 && (_jsx(Text, { size: "xs", c: "dimmed", children: "No users found" })), _jsx(Button, { size: "xs", variant: "subtle", onClick: onHideSearch, children: "Cancel" })] }) })) : (_jsx(Button, { size: "xs", variant: "subtle", leftSection: _jsx(IconSearch, { size: 14 }), onClick: onShowSearch, disabled: !canSearch, children: "Add Member" }))] }));
|
|
12
|
+
};
|
|
13
|
+
//# sourceMappingURL=MemberList.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"MemberList.js","sourceRoot":"","sources":["../../../src/editor/group-manager/MemberList.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Hook for external group search functionality
|
|
3
|
+
*/
|
|
4
|
+
import type { ExternalGroup } from '../types';
|
|
5
|
+
export interface UseExternalGroupSearchOptions {
|
|
6
|
+
onSearchExternalGroups?: (query: string) => Promise<ExternalGroup[]>;
|
|
7
|
+
}
|
|
8
|
+
export interface UseExternalGroupSearchResult {
|
|
9
|
+
searchQuery: string;
|
|
10
|
+
searchResults: ExternalGroup[];
|
|
11
|
+
isSearching: boolean;
|
|
12
|
+
searchError: string | null;
|
|
13
|
+
setSearchQuery: (query: string) => void;
|
|
14
|
+
}
|
|
15
|
+
export declare function useExternalGroupSearch({ onSearchExternalGroups, }: UseExternalGroupSearchOptions): UseExternalGroupSearchResult;
|
|
16
|
+
//# sourceMappingURL=useExternalGroupSearch.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useExternalGroupSearch.d.ts","sourceRoot":"","sources":["../../../../src/editor/group-manager/hooks/useExternalGroupSearch.ts"],"names":[],"mappings":"AAAA;;GAEG;AAGH,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,UAAU,CAAA;AAE7C,MAAM,WAAW,6BAA6B;IAC5C,sBAAsB,CAAC,EAAE,CAAC,KAAK,EAAE,MAAM,KAAK,OAAO,CAAC,aAAa,EAAE,CAAC,CAAA;CACrE;AAED,MAAM,WAAW,4BAA4B;IAC3C,WAAW,EAAE,MAAM,CAAA;IACnB,aAAa,EAAE,aAAa,EAAE,CAAA;IAC9B,WAAW,EAAE,OAAO,CAAA;IACpB,WAAW,EAAE,MAAM,GAAG,IAAI,CAAA;IAC1B,cAAc,EAAE,CAAC,KAAK,EAAE,MAAM,KAAK,IAAI,CAAA;CACxC;AAED,wBAAgB,sBAAsB,CAAC,EACrC,sBAAsB,GACvB,EAAE,6BAA6B,GAAG,4BAA4B,CAyC9D"}
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Hook for external group search functionality
|
|
3
|
+
*/
|
|
4
|
+
import { useState, useEffect } from 'react';
|
|
5
|
+
export function useExternalGroupSearch({ onSearchExternalGroups, }) {
|
|
6
|
+
const [searchQuery, setSearchQuery] = useState('');
|
|
7
|
+
const [searchResults, setSearchResults] = useState([]);
|
|
8
|
+
const [isSearching, setIsSearching] = useState(false);
|
|
9
|
+
const [searchError, setSearchError] = useState(null);
|
|
10
|
+
// Debounced external group search
|
|
11
|
+
useEffect(() => {
|
|
12
|
+
if (!searchQuery.trim()) {
|
|
13
|
+
setSearchResults([]);
|
|
14
|
+
return;
|
|
15
|
+
}
|
|
16
|
+
const timer = setTimeout(() => {
|
|
17
|
+
if (onSearchExternalGroups) {
|
|
18
|
+
setIsSearching(true);
|
|
19
|
+
setSearchError(null);
|
|
20
|
+
onSearchExternalGroups(searchQuery)
|
|
21
|
+
.then((results) => {
|
|
22
|
+
setSearchResults(results);
|
|
23
|
+
setSearchError(null);
|
|
24
|
+
})
|
|
25
|
+
.catch((err) => {
|
|
26
|
+
console.error('External group search failed:', err);
|
|
27
|
+
setSearchError('Failed to search external groups. Please try again.');
|
|
28
|
+
setSearchResults([]);
|
|
29
|
+
})
|
|
30
|
+
.finally(() => setIsSearching(false));
|
|
31
|
+
}
|
|
32
|
+
}, 300);
|
|
33
|
+
return () => clearTimeout(timer);
|
|
34
|
+
}, [searchQuery, onSearchExternalGroups]);
|
|
35
|
+
return {
|
|
36
|
+
searchQuery,
|
|
37
|
+
searchResults,
|
|
38
|
+
isSearching,
|
|
39
|
+
searchError,
|
|
40
|
+
setSearchQuery,
|
|
41
|
+
};
|
|
42
|
+
}
|
|
43
|
+
//# sourceMappingURL=useExternalGroupSearch.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useExternalGroupSearch.js","sourceRoot":"","sources":["../../../../src/editor/group-manager/hooks/useExternalGroupSearch.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,OAAO,EAAE,QAAQ,EAAE,SAAS,EAAE,MAAM,OAAO,CAAA;AAe3C,MAAM,UAAU,sBAAsB,CAAC,EACrC,sBAAsB,GACQ;IAC9B,MAAM,CAAC,WAAW,EAAE,cAAc,CAAC,GAAG,QAAQ,CAAC,EAAE,CAAC,CAAA;IAClD,MAAM,CAAC,aAAa,EAAE,gBAAgB,CAAC,GAAG,QAAQ,CAAkB,EAAE,CAAC,CAAA;IACvE,MAAM,CAAC,WAAW,EAAE,cAAc,CAAC,GAAG,QAAQ,CAAC,KAAK,CAAC,CAAA;IACrD,MAAM,CAAC,WAAW,EAAE,cAAc,CAAC,GAAG,QAAQ,CAAgB,IAAI,CAAC,CAAA;IAEnE,kCAAkC;IAClC,SAAS,CAAC,GAAG,EAAE;QACb,IAAI,CAAC,WAAW,CAAC,IAAI,EAAE,EAAE,CAAC;YACxB,gBAAgB,CAAC,EAAE,CAAC,CAAA;YACpB,OAAM;QACR,CAAC;QAED,MAAM,KAAK,GAAG,UAAU,CAAC,GAAG,EAAE;YAC5B,IAAI,sBAAsB,EAAE,CAAC;gBAC3B,cAAc,CAAC,IAAI,CAAC,CAAA;gBACpB,cAAc,CAAC,IAAI,CAAC,CAAA;gBACpB,sBAAsB,CAAC,WAAW,CAAC;qBAChC,IAAI,CAAC,CAAC,OAAO,EAAE,EAAE;oBAChB,gBAAgB,CAAC,OAAO,CAAC,CAAA;oBACzB,cAAc,CAAC,IAAI,CAAC,CAAA;gBACtB,CAAC,CAAC;qBACD,KAAK,CAAC,CAAC,GAAG,EAAE,EAAE;oBACb,OAAO,CAAC,KAAK,CAAC,+BAA+B,EAAE,GAAG,CAAC,CAAA;oBACnD,cAAc,CAAC,qDAAqD,CAAC,CAAA;oBACrE,gBAAgB,CAAC,EAAE,CAAC,CAAA;gBACtB,CAAC,CAAC;qBACD,OAAO,CAAC,GAAG,EAAE,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC,CAAA;YACzC,CAAC;QACH,CAAC,EAAE,GAAG,CAAC,CAAA;QAEP,OAAO,GAAG,EAAE,CAAC,YAAY,CAAC,KAAK,CAAC,CAAA;IAClC,CAAC,EAAE,CAAC,WAAW,EAAE,sBAAsB,CAAC,CAAC,CAAA;IAEzC,OAAO;QACL,WAAW;QACX,aAAa;QACb,WAAW;QACX,WAAW;QACX,cAAc;KACf,CAAA;AACH,CAAC"}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Hook for managing internal group state
|
|
3
|
+
*/
|
|
4
|
+
import type { InternalGroup, CanopyGroupId, CanopyUserId } from '../types';
|
|
5
|
+
export interface UseGroupStateOptions {
|
|
6
|
+
initialGroups: InternalGroup[];
|
|
7
|
+
onSave?: (groups: InternalGroup[]) => Promise<void>;
|
|
8
|
+
}
|
|
9
|
+
export interface UseGroupStateResult {
|
|
10
|
+
groups: InternalGroup[];
|
|
11
|
+
isDirty: boolean;
|
|
12
|
+
isSaving: boolean;
|
|
13
|
+
error: string | null;
|
|
14
|
+
setError: (error: string | null) => void;
|
|
15
|
+
createGroup: (name: string, description: string) => void;
|
|
16
|
+
updateGroup: (groupId: CanopyGroupId, name: string, description: string) => void;
|
|
17
|
+
deleteGroup: (groupId: CanopyGroupId) => void;
|
|
18
|
+
addMember: (groupId: CanopyGroupId, userId: CanopyUserId) => void;
|
|
19
|
+
removeMember: (groupId: CanopyGroupId, userId: CanopyUserId) => void;
|
|
20
|
+
save: () => Promise<void>;
|
|
21
|
+
discard: () => void;
|
|
22
|
+
}
|
|
23
|
+
export declare function useGroupState({ initialGroups, onSave, }: UseGroupStateOptions): UseGroupStateResult;
|
|
24
|
+
//# sourceMappingURL=useGroupState.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useGroupState.d.ts","sourceRoot":"","sources":["../../../../src/editor/group-manager/hooks/useGroupState.ts"],"names":[],"mappings":"AAAA;;GAEG;AAGH,OAAO,KAAK,EAAE,aAAa,EAAE,aAAa,EAAE,YAAY,EAAE,MAAM,UAAU,CAAA;AAE1E,MAAM,WAAW,oBAAoB;IACnC,aAAa,EAAE,aAAa,EAAE,CAAA;IAC9B,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,aAAa,EAAE,KAAK,OAAO,CAAC,IAAI,CAAC,CAAA;CACpD;AAED,MAAM,WAAW,mBAAmB;IAClC,MAAM,EAAE,aAAa,EAAE,CAAA;IACvB,OAAO,EAAE,OAAO,CAAA;IAChB,QAAQ,EAAE,OAAO,CAAA;IACjB,KAAK,EAAE,MAAM,GAAG,IAAI,CAAA;IACpB,QAAQ,EAAE,CAAC,KAAK,EAAE,MAAM,GAAG,IAAI,KAAK,IAAI,CAAA;IACxC,WAAW,EAAE,CAAC,IAAI,EAAE,MAAM,EAAE,WAAW,EAAE,MAAM,KAAK,IAAI,CAAA;IACxD,WAAW,EAAE,CAAC,OAAO,EAAE,aAAa,EAAE,IAAI,EAAE,MAAM,EAAE,WAAW,EAAE,MAAM,KAAK,IAAI,CAAA;IAChF,WAAW,EAAE,CAAC,OAAO,EAAE,aAAa,KAAK,IAAI,CAAA;IAC7C,SAAS,EAAE,CAAC,OAAO,EAAE,aAAa,EAAE,MAAM,EAAE,YAAY,KAAK,IAAI,CAAA;IACjE,YAAY,EAAE,CAAC,OAAO,EAAE,aAAa,EAAE,MAAM,EAAE,YAAY,KAAK,IAAI,CAAA;IACpE,IAAI,EAAE,MAAM,OAAO,CAAC,IAAI,CAAC,CAAA;IACzB,OAAO,EAAE,MAAM,IAAI,CAAA;CACpB;AAED,wBAAgB,aAAa,CAAC,EAC5B,aAAa,EACb,MAAM,GACP,EAAE,oBAAoB,GAAG,mBAAmB,CAuG5C"}
|
|
@@ -0,0 +1,97 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Hook for managing internal group state
|
|
3
|
+
*/
|
|
4
|
+
import { useState, useEffect, useCallback } from 'react';
|
|
5
|
+
export function useGroupState({ initialGroups, onSave, }) {
|
|
6
|
+
const [groups, setGroups] = useState(initialGroups);
|
|
7
|
+
const [isDirty, setIsDirty] = useState(false);
|
|
8
|
+
const [isSaving, setIsSaving] = useState(false);
|
|
9
|
+
const [error, setError] = useState(null);
|
|
10
|
+
// Sync groups when prop changes
|
|
11
|
+
useEffect(() => {
|
|
12
|
+
setGroups(initialGroups);
|
|
13
|
+
setIsDirty(false);
|
|
14
|
+
}, [initialGroups]);
|
|
15
|
+
const createGroup = useCallback((name, description) => {
|
|
16
|
+
const newGroup = {
|
|
17
|
+
id: '',
|
|
18
|
+
name,
|
|
19
|
+
description,
|
|
20
|
+
members: [],
|
|
21
|
+
};
|
|
22
|
+
setGroups((prev) => [...prev, newGroup]);
|
|
23
|
+
setIsDirty(true);
|
|
24
|
+
}, []);
|
|
25
|
+
const updateGroup = useCallback((groupId, name, description) => {
|
|
26
|
+
setGroups((prev) => prev.map((g) => (g.id === groupId ? { ...g, name, description } : g)));
|
|
27
|
+
setIsDirty(true);
|
|
28
|
+
}, []);
|
|
29
|
+
const deleteGroup = useCallback((groupId) => {
|
|
30
|
+
setGroups((prev) => prev.filter((g) => g.id !== groupId));
|
|
31
|
+
setIsDirty(true);
|
|
32
|
+
}, []);
|
|
33
|
+
const addMember = useCallback((groupId, userId) => {
|
|
34
|
+
setGroups((prev) => prev.map((g) => {
|
|
35
|
+
if (g.id === groupId) {
|
|
36
|
+
const members = g.members || [];
|
|
37
|
+
if (!members.includes(userId)) {
|
|
38
|
+
return { ...g, members: [...members, userId] };
|
|
39
|
+
}
|
|
40
|
+
}
|
|
41
|
+
return g;
|
|
42
|
+
}));
|
|
43
|
+
setIsDirty(true);
|
|
44
|
+
}, []);
|
|
45
|
+
const removeMember = useCallback((groupId, userId) => {
|
|
46
|
+
setGroups((prev) => prev.map((g) => {
|
|
47
|
+
if (g.id === groupId) {
|
|
48
|
+
const members = (g.members || []).filter((m) => m !== userId);
|
|
49
|
+
return { ...g, members };
|
|
50
|
+
}
|
|
51
|
+
return g;
|
|
52
|
+
}));
|
|
53
|
+
setIsDirty(true);
|
|
54
|
+
}, []);
|
|
55
|
+
const save = useCallback(async () => {
|
|
56
|
+
if (!onSave)
|
|
57
|
+
return;
|
|
58
|
+
// Validate that Admins group is not empty
|
|
59
|
+
const adminsGroup = groups.find((g) => g.id === 'Admins');
|
|
60
|
+
if (!adminsGroup || !adminsGroup.members || adminsGroup.members.length === 0) {
|
|
61
|
+
setError('Cannot remove the last admin. At least one admin is required.');
|
|
62
|
+
return;
|
|
63
|
+
}
|
|
64
|
+
setIsSaving(true);
|
|
65
|
+
setError(null);
|
|
66
|
+
try {
|
|
67
|
+
await onSave(groups);
|
|
68
|
+
setIsDirty(false);
|
|
69
|
+
}
|
|
70
|
+
catch (err) {
|
|
71
|
+
setError(err instanceof Error ? err.message : 'Failed to save groups');
|
|
72
|
+
}
|
|
73
|
+
finally {
|
|
74
|
+
setIsSaving(false);
|
|
75
|
+
}
|
|
76
|
+
}, [onSave, groups]);
|
|
77
|
+
const discard = useCallback(() => {
|
|
78
|
+
setGroups(initialGroups);
|
|
79
|
+
setIsDirty(false);
|
|
80
|
+
setError(null);
|
|
81
|
+
}, [initialGroups]);
|
|
82
|
+
return {
|
|
83
|
+
groups,
|
|
84
|
+
isDirty,
|
|
85
|
+
isSaving,
|
|
86
|
+
error,
|
|
87
|
+
setError,
|
|
88
|
+
createGroup,
|
|
89
|
+
updateGroup,
|
|
90
|
+
deleteGroup,
|
|
91
|
+
addMember,
|
|
92
|
+
removeMember,
|
|
93
|
+
save,
|
|
94
|
+
discard,
|
|
95
|
+
};
|
|
96
|
+
}
|
|
97
|
+
//# sourceMappingURL=useGroupState.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useGroupState.js","sourceRoot":"","sources":["../../../../src/editor/group-manager/hooks/useGroupState.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Hook for user search functionality
|
|
3
|
+
*/
|
|
4
|
+
import type { UserSearchResult } from '../types';
|
|
5
|
+
export interface UseUserSearchOptions {
|
|
6
|
+
onSearchUsers?: (query: string, limit?: number) => Promise<UserSearchResult[]>;
|
|
7
|
+
}
|
|
8
|
+
export interface UseUserSearchResult {
|
|
9
|
+
searchQuery: string;
|
|
10
|
+
searchResults: UserSearchResult[];
|
|
11
|
+
isSearching: boolean;
|
|
12
|
+
searchError: string | null;
|
|
13
|
+
activeGroupId: string | null;
|
|
14
|
+
setSearchQuery: (query: string) => void;
|
|
15
|
+
showSearch: (groupId: string) => void;
|
|
16
|
+
hideSearch: () => void;
|
|
17
|
+
clearSearch: () => void;
|
|
18
|
+
}
|
|
19
|
+
export declare function useUserSearch({ onSearchUsers }: UseUserSearchOptions): UseUserSearchResult;
|
|
20
|
+
//# sourceMappingURL=useUserSearch.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useUserSearch.d.ts","sourceRoot":"","sources":["../../../../src/editor/group-manager/hooks/useUserSearch.ts"],"names":[],"mappings":"AAAA;;GAEG;AAGH,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,UAAU,CAAA;AAEhD,MAAM,WAAW,oBAAoB;IACnC,aAAa,CAAC,EAAE,CAAC,KAAK,EAAE,MAAM,EAAE,KAAK,CAAC,EAAE,MAAM,KAAK,OAAO,CAAC,gBAAgB,EAAE,CAAC,CAAA;CAC/E;AAED,MAAM,WAAW,mBAAmB;IAClC,WAAW,EAAE,MAAM,CAAA;IACnB,aAAa,EAAE,gBAAgB,EAAE,CAAA;IACjC,WAAW,EAAE,OAAO,CAAA;IACpB,WAAW,EAAE,MAAM,GAAG,IAAI,CAAA;IAC1B,aAAa,EAAE,MAAM,GAAG,IAAI,CAAA;IAC5B,cAAc,EAAE,CAAC,KAAK,EAAE,MAAM,KAAK,IAAI,CAAA;IACvC,UAAU,EAAE,CAAC,OAAO,EAAE,MAAM,KAAK,IAAI,CAAA;IACrC,UAAU,EAAE,MAAM,IAAI,CAAA;IACtB,WAAW,EAAE,MAAM,IAAI,CAAA;CACxB;AAED,wBAAgB,aAAa,CAAC,EAAE,aAAa,EAAE,EAAE,oBAAoB,GAAG,mBAAmB,CA4D1F"}
|
|
@@ -0,0 +1,60 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Hook for user search functionality
|
|
3
|
+
*/
|
|
4
|
+
import { useState, useEffect, useCallback } from 'react';
|
|
5
|
+
export function useUserSearch({ onSearchUsers }) {
|
|
6
|
+
const [searchQuery, setSearchQuery] = useState('');
|
|
7
|
+
const [searchResults, setSearchResults] = useState([]);
|
|
8
|
+
const [isSearching, setIsSearching] = useState(false);
|
|
9
|
+
const [searchError, setSearchError] = useState(null);
|
|
10
|
+
const [activeGroupId, setActiveGroupId] = useState(null);
|
|
11
|
+
// Debounced user search
|
|
12
|
+
useEffect(() => {
|
|
13
|
+
if (!activeGroupId || !searchQuery.trim())
|
|
14
|
+
return;
|
|
15
|
+
const timer = setTimeout(() => {
|
|
16
|
+
if (onSearchUsers) {
|
|
17
|
+
setIsSearching(true);
|
|
18
|
+
setSearchError(null);
|
|
19
|
+
onSearchUsers(searchQuery, 10)
|
|
20
|
+
.then((results) => {
|
|
21
|
+
setSearchResults(results);
|
|
22
|
+
setSearchError(null);
|
|
23
|
+
})
|
|
24
|
+
.catch((err) => {
|
|
25
|
+
console.error('User search failed:', err);
|
|
26
|
+
setSearchError('Failed to search users. Please try again.');
|
|
27
|
+
setSearchResults([]);
|
|
28
|
+
})
|
|
29
|
+
.finally(() => setIsSearching(false));
|
|
30
|
+
}
|
|
31
|
+
}, 300);
|
|
32
|
+
return () => clearTimeout(timer);
|
|
33
|
+
}, [searchQuery, onSearchUsers, activeGroupId]);
|
|
34
|
+
const showSearch = useCallback((groupId) => {
|
|
35
|
+
setActiveGroupId(groupId);
|
|
36
|
+
}, []);
|
|
37
|
+
const hideSearch = useCallback(() => {
|
|
38
|
+
setActiveGroupId(null);
|
|
39
|
+
setSearchQuery('');
|
|
40
|
+
setSearchResults([]);
|
|
41
|
+
setSearchError(null);
|
|
42
|
+
}, []);
|
|
43
|
+
const clearSearch = useCallback(() => {
|
|
44
|
+
setSearchQuery('');
|
|
45
|
+
setSearchResults([]);
|
|
46
|
+
setSearchError(null);
|
|
47
|
+
}, []);
|
|
48
|
+
return {
|
|
49
|
+
searchQuery,
|
|
50
|
+
searchResults,
|
|
51
|
+
isSearching,
|
|
52
|
+
searchError,
|
|
53
|
+
activeGroupId,
|
|
54
|
+
setSearchQuery,
|
|
55
|
+
showSearch,
|
|
56
|
+
hideSearch,
|
|
57
|
+
clearSearch,
|
|
58
|
+
};
|
|
59
|
+
}
|
|
60
|
+
//# sourceMappingURL=useUserSearch.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useUserSearch.js","sourceRoot":"","sources":["../../../../src/editor/group-manager/hooks/useUserSearch.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,OAAO,EAAE,QAAQ,EAAE,SAAS,EAAE,WAAW,EAAE,MAAM,OAAO,CAAA;AAmBxD,MAAM,UAAU,aAAa,CAAC,EAAE,aAAa,EAAwB;IACnE,MAAM,CAAC,WAAW,EAAE,cAAc,CAAC,GAAG,QAAQ,CAAC,EAAE,CAAC,CAAA;IAClD,MAAM,CAAC,aAAa,EAAE,gBAAgB,CAAC,GAAG,QAAQ,CAAqB,EAAE,CAAC,CAAA;IAC1E,MAAM,CAAC,WAAW,EAAE,cAAc,CAAC,GAAG,QAAQ,CAAC,KAAK,CAAC,CAAA;IACrD,MAAM,CAAC,WAAW,EAAE,cAAc,CAAC,GAAG,QAAQ,CAAgB,IAAI,CAAC,CAAA;IACnE,MAAM,CAAC,aAAa,EAAE,gBAAgB,CAAC,GAAG,QAAQ,CAAgB,IAAI,CAAC,CAAA;IAEvE,wBAAwB;IACxB,SAAS,CAAC,GAAG,EAAE;QACb,IAAI,CAAC,aAAa,IAAI,CAAC,WAAW,CAAC,IAAI,EAAE;YAAE,OAAM;QAEjD,MAAM,KAAK,GAAG,UAAU,CAAC,GAAG,EAAE;YAC5B,IAAI,aAAa,EAAE,CAAC;gBAClB,cAAc,CAAC,IAAI,CAAC,CAAA;gBACpB,cAAc,CAAC,IAAI,CAAC,CAAA;gBACpB,aAAa,CAAC,WAAW,EAAE,EAAE,CAAC;qBAC3B,IAAI,CAAC,CAAC,OAAO,EAAE,EAAE;oBAChB,gBAAgB,CAAC,OAAO,CAAC,CAAA;oBACzB,cAAc,CAAC,IAAI,CAAC,CAAA;gBACtB,CAAC,CAAC;qBACD,KAAK,CAAC,CAAC,GAAG,EAAE,EAAE;oBACb,OAAO,CAAC,KAAK,CAAC,qBAAqB,EAAE,GAAG,CAAC,CAAA;oBACzC,cAAc,CAAC,2CAA2C,CAAC,CAAA;oBAC3D,gBAAgB,CAAC,EAAE,CAAC,CAAA;gBACtB,CAAC,CAAC;qBACD,OAAO,CAAC,GAAG,EAAE,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC,CAAA;YACzC,CAAC;QACH,CAAC,EAAE,GAAG,CAAC,CAAA;QAEP,OAAO,GAAG,EAAE,CAAC,YAAY,CAAC,KAAK,CAAC,CAAA;IAClC,CAAC,EAAE,CAAC,WAAW,EAAE,aAAa,EAAE,aAAa,CAAC,CAAC,CAAA;IAE/C,MAAM,UAAU,GAAG,WAAW,CAAC,CAAC,OAAe,EAAE,EAAE;QACjD,gBAAgB,CAAC,OAAO,CAAC,CAAA;IAC3B,CAAC,EAAE,EAAE,CAAC,CAAA;IAEN,MAAM,UAAU,GAAG,WAAW,CAAC,GAAG,EAAE;QAClC,gBAAgB,CAAC,IAAI,CAAC,CAAA;QACtB,cAAc,CAAC,EAAE,CAAC,CAAA;QAClB,gBAAgB,CAAC,EAAE,CAAC,CAAA;QACpB,cAAc,CAAC,IAAI,CAAC,CAAA;IACtB,CAAC,EAAE,EAAE,CAAC,CAAA;IAEN,MAAM,WAAW,GAAG,WAAW,CAAC,GAAG,EAAE;QACnC,cAAc,CAAC,EAAE,CAAC,CAAA;QAClB,gBAAgB,CAAC,EAAE,CAAC,CAAA;QACpB,cAAc,CAAC,IAAI,CAAC,CAAA;IACtB,CAAC,EAAE,EAAE,CAAC,CAAA;IAEN,OAAO;QACL,WAAW;QACX,aAAa;QACb,WAAW;QACX,WAAW;QACX,aAAa;QACb,cAAc;QACd,UAAU;QACV,UAAU;QACV,WAAW;KACZ,CAAA;AACH,CAAC"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* GroupManager - Main component for managing internal and external groups.
|
|
3
|
+
*
|
|
4
|
+
* This component provides a tabbed UI for managing internal groups with
|
|
5
|
+
* member assignment, and browsing external groups from the organization.
|
|
6
|
+
*/
|
|
7
|
+
import React from 'react';
|
|
8
|
+
import type { GroupManagerProps } from './types';
|
|
9
|
+
export declare const GroupManager: React.FC<GroupManagerProps>;
|
|
10
|
+
export type { GroupManagerProps, InternalGroup } from './types';
|
|
11
|
+
export { useGroupState } from './hooks/useGroupState';
|
|
12
|
+
export { useUserSearch } from './hooks/useUserSearch';
|
|
13
|
+
export { useExternalGroupSearch } from './hooks/useExternalGroupSearch';
|
|
14
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/editor/group-manager/index.tsx"],"names":[],"mappings":"AAEA;;;;;GAKG;AAEH,OAAO,KAAgC,MAAM,OAAO,CAAA;AAGpD,OAAO,KAAK,EAAE,iBAAiB,EAAgC,MAAM,SAAS,CAAA;AAQ9E,eAAO,MAAM,YAAY,EAAE,KAAK,CAAC,EAAE,CAAC,iBAAiB,CAuLpD,CAAA;AAGD,YAAY,EAAE,iBAAiB,EAAE,aAAa,EAAE,MAAM,SAAS,CAAA;AAC/D,OAAO,EAAE,aAAa,EAAE,MAAM,uBAAuB,CAAA;AACrD,OAAO,EAAE,aAAa,EAAE,MAAM,uBAAuB,CAAA;AACrD,OAAO,EAAE,sBAAsB,EAAE,MAAM,gCAAgC,CAAA"}
|
|
@@ -0,0 +1,71 @@
|
|
|
1
|
+
'use client';
|
|
2
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
3
|
+
/**
|
|
4
|
+
* GroupManager - Main component for managing internal and external groups.
|
|
5
|
+
*
|
|
6
|
+
* This component provides a tabbed UI for managing internal groups with
|
|
7
|
+
* member assignment, and browsing external groups from the organization.
|
|
8
|
+
*/
|
|
9
|
+
import { useState, useCallback } from 'react';
|
|
10
|
+
import { Alert, Button, Group, Loader, Stack, Tabs, Text } from '@mantine/core';
|
|
11
|
+
import { IconAlertCircle } from '@tabler/icons-react';
|
|
12
|
+
import { useGroupState } from './hooks/useGroupState';
|
|
13
|
+
import { useUserSearch } from './hooks/useUserSearch';
|
|
14
|
+
import { useExternalGroupSearch } from './hooks/useExternalGroupSearch';
|
|
15
|
+
import { InternalGroupsTab } from './InternalGroupsTab';
|
|
16
|
+
import { ExternalGroupsTab } from './ExternalGroupsTab';
|
|
17
|
+
import { GroupForm } from './GroupForm';
|
|
18
|
+
export const GroupManager = ({ internalGroups: initialInternalGroups, loading = false, canEdit, onSave, onSearchUsers, onGetUserMetadata, onSearchExternalGroups, onClose: _, }) => {
|
|
19
|
+
// Group state management
|
|
20
|
+
const { groups, isDirty, isSaving, error, setError, createGroup, updateGroup, deleteGroup, addMember, removeMember, save, discard, } = useGroupState({
|
|
21
|
+
initialGroups: initialInternalGroups,
|
|
22
|
+
onSave,
|
|
23
|
+
});
|
|
24
|
+
// User search for adding members
|
|
25
|
+
const userSearch = useUserSearch({ onSearchUsers });
|
|
26
|
+
// External group search
|
|
27
|
+
const externalGroupSearch = useExternalGroupSearch({ onSearchExternalGroups });
|
|
28
|
+
// Modal state for creating/editing groups
|
|
29
|
+
const [isModalOpen, setIsModalOpen] = useState(false);
|
|
30
|
+
const [editingGroup, setEditingGroup] = useState(null);
|
|
31
|
+
const [formData, setFormData] = useState({
|
|
32
|
+
name: '',
|
|
33
|
+
description: '',
|
|
34
|
+
});
|
|
35
|
+
const handleCreateGroup = useCallback(() => {
|
|
36
|
+
setEditingGroup(null);
|
|
37
|
+
setFormData({ name: '', description: '' });
|
|
38
|
+
setIsModalOpen(true);
|
|
39
|
+
}, []);
|
|
40
|
+
const handleEditGroup = useCallback((group) => {
|
|
41
|
+
setEditingGroup(group);
|
|
42
|
+
setFormData({ name: group.name, description: group.description || '' });
|
|
43
|
+
setIsModalOpen(true);
|
|
44
|
+
}, []);
|
|
45
|
+
const handleSaveModal = useCallback(() => {
|
|
46
|
+
if (!formData.name.trim()) {
|
|
47
|
+
setError('Group name is required');
|
|
48
|
+
return;
|
|
49
|
+
}
|
|
50
|
+
if (editingGroup) {
|
|
51
|
+
updateGroup(editingGroup.id, formData.name, formData.description);
|
|
52
|
+
}
|
|
53
|
+
else {
|
|
54
|
+
createGroup(formData.name, formData.description);
|
|
55
|
+
}
|
|
56
|
+
setIsModalOpen(false);
|
|
57
|
+
setError(null);
|
|
58
|
+
}, [formData, editingGroup, updateGroup, createGroup, setError]);
|
|
59
|
+
const handleFormChange = useCallback((data) => {
|
|
60
|
+
setFormData((prev) => ({ ...prev, ...data }));
|
|
61
|
+
}, []);
|
|
62
|
+
const handleAddMember = useCallback((groupId, userId) => {
|
|
63
|
+
addMember(groupId, userId);
|
|
64
|
+
userSearch.hideSearch();
|
|
65
|
+
}, [addMember, userSearch]);
|
|
66
|
+
return (_jsxs(Stack, { h: "100%", style: { display: 'flex', flexDirection: 'column' }, gap: 0, children: [!canEdit && (_jsx(Alert, { icon: _jsx(IconAlertCircle, { size: 16 }), color: "yellow", mb: "sm", title: "Read-only", children: "You need admin access to manage groups." })), error && (_jsx(Alert, { icon: _jsx(IconAlertCircle, { size: 16 }), color: "red", mb: "sm", title: "Error", withCloseButton: true, onClose: () => setError(null), children: error })), loading ? (_jsxs(Group, { justify: "center", py: "xl", children: [_jsx(Loader, { size: "md" }), _jsx(Text, { size: "sm", c: "dimmed", children: "Loading groups..." })] })) : (_jsxs(Tabs, { defaultValue: "internal", style: { flex: 1, display: 'flex', flexDirection: 'column' }, children: [_jsxs(Tabs.List, { children: [_jsx(Tabs.Tab, { value: "internal", children: "Internal Groups" }), _jsx(Tabs.Tab, { value: "external", children: "External Groups" })] }), _jsx(Tabs.Panel, { value: "internal", style: { flex: 1, overflow: 'auto' }, children: _jsx(InternalGroupsTab, { groups: groups, canEdit: canEdit, onCreateGroup: handleCreateGroup, onEditGroup: handleEditGroup, onDeleteGroup: deleteGroup, onAddMember: handleAddMember, onRemoveMember: removeMember, onGetUserMetadata: onGetUserMetadata, activeSearchGroupId: userSearch.activeGroupId, searchQuery: userSearch.searchQuery, searchResults: userSearch.searchResults, isSearching: userSearch.isSearching, searchError: userSearch.searchError, onSearchQueryChange: userSearch.setSearchQuery, onShowSearch: userSearch.showSearch, onHideSearch: userSearch.hideSearch, canSearch: !!onSearchUsers }) }), _jsx(Tabs.Panel, { value: "external", style: { flex: 1, overflow: 'auto' }, children: _jsx(ExternalGroupsTab, { canEdit: canEdit, searchQuery: externalGroupSearch.searchQuery, searchResults: externalGroupSearch.searchResults, isSearching: externalGroupSearch.isSearching, searchError: externalGroupSearch.searchError, onSearchQueryChange: externalGroupSearch.setSearchQuery, canSearch: !!onSearchExternalGroups }) })] })), canEdit && isDirty && (_jsxs(Group, { justify: "flex-end", py: "sm", gap: "sm", style: { borderTop: '1px solid var(--mantine-color-gray-3)' }, children: [_jsx(Button, { variant: "subtle", color: "neutral", onClick: discard, disabled: isSaving, children: "Discard Changes" }), _jsx(Button, { onClick: save, loading: isSaving, disabled: isSaving, children: "Save Groups" })] })), _jsx(GroupForm, { isOpen: isModalOpen, editingGroup: editingGroup, formData: formData, onFormChange: handleFormChange, onSave: handleSaveModal, onClose: () => setIsModalOpen(false) })] }));
|
|
67
|
+
};
|
|
68
|
+
export { useGroupState } from './hooks/useGroupState';
|
|
69
|
+
export { useUserSearch } from './hooks/useUserSearch';
|
|
70
|
+
export { useExternalGroupSearch } from './hooks/useExternalGroupSearch';
|
|
71
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/editor/group-manager/index.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Type definitions for GroupManager module
|
|
3
|
+
*/
|
|
4
|
+
import type { UserSearchResult, GroupMetadata } from '../../auth/types';
|
|
5
|
+
import type { CanopyGroupId, CanopyUserId } from '../../types';
|
|
6
|
+
import type { InternalGroup } from '../../authorization';
|
|
7
|
+
import type { ExternalGroup } from '../../api/groups';
|
|
8
|
+
export type { UserSearchResult, GroupMetadata, InternalGroup, ExternalGroup };
|
|
9
|
+
export type { CanopyGroupId, CanopyUserId };
|
|
10
|
+
export interface GroupManagerProps {
|
|
11
|
+
internalGroups: InternalGroup[];
|
|
12
|
+
loading?: boolean;
|
|
13
|
+
canEdit: boolean;
|
|
14
|
+
onSave?: (groups: InternalGroup[]) => Promise<void>;
|
|
15
|
+
onSearchUsers?: (query: string, limit?: number) => Promise<UserSearchResult[]>;
|
|
16
|
+
onGetUserMetadata?: (userId: string) => Promise<UserSearchResult | null>;
|
|
17
|
+
onSearchExternalGroups?: (query: string) => Promise<ExternalGroup[]>;
|
|
18
|
+
onClose?: () => void;
|
|
19
|
+
}
|
|
20
|
+
export interface GroupFormData {
|
|
21
|
+
name: string;
|
|
22
|
+
description: string;
|
|
23
|
+
}
|
|
24
|
+
//# sourceMappingURL=types.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../src/editor/group-manager/types.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,OAAO,KAAK,EAAE,gBAAgB,EAAE,aAAa,EAAE,MAAM,kBAAkB,CAAA;AACvE,OAAO,KAAK,EAAE,aAAa,EAAE,YAAY,EAAE,MAAM,aAAa,CAAA;AAC9D,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAA;AACxD,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,kBAAkB,CAAA;AAGrD,YAAY,EAAE,gBAAgB,EAAE,aAAa,EAAE,aAAa,EAAE,aAAa,EAAE,CAAA;AAC7E,YAAY,EAAE,aAAa,EAAE,YAAY,EAAE,CAAA;AAE3C,MAAM,WAAW,iBAAiB;IAChC,cAAc,EAAE,aAAa,EAAE,CAAA;IAC/B,OAAO,CAAC,EAAE,OAAO,CAAA;IACjB,OAAO,EAAE,OAAO,CAAA;IAChB,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,aAAa,EAAE,KAAK,OAAO,CAAC,IAAI,CAAC,CAAA;IACnD,aAAa,CAAC,EAAE,CAAC,KAAK,EAAE,MAAM,EAAE,KAAK,CAAC,EAAE,MAAM,KAAK,OAAO,CAAC,gBAAgB,EAAE,CAAC,CAAA;IAC9E,iBAAiB,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,KAAK,OAAO,CAAC,gBAAgB,GAAG,IAAI,CAAC,CAAA;IACxE,sBAAsB,CAAC,EAAE,CAAC,KAAK,EAAE,MAAM,KAAK,OAAO,CAAC,aAAa,EAAE,CAAC,CAAA;IACpE,OAAO,CAAC,EAAE,MAAM,IAAI,CAAA;CACrB;AAED,MAAM,WAAW,aAAa;IAC5B,IAAI,EAAE,MAAM,CAAA;IACZ,WAAW,EAAE,MAAM,CAAA;CACpB"}
|