@riboseinc/paneron-registry-kit 2.0.0 → 2.0.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE +21 -0
- package/README.adoc +35 -0
- package/compiled/common.js +2 -0
- package/compiled/index.js +21 -0
- package/compiled/migrations/initial.js +8 -0
- package/compiled/types/cr.js +131 -0
- package/compiled/types/index.js +8 -0
- package/compiled/types/item.js +22 -0
- package/compiled/types/proposal.js +21 -0
- package/compiled/types/register.js +25 -0
- package/compiled/types/registry.js +10 -0
- package/compiled/types/stakeholder.js +34 -0
- package/compiled/types/util.js +3 -0
- package/compiled/types/views.js +2 -0
- package/compiled/views/AnnotatedChange.js +57 -0
- package/compiled/views/BrowserCtx.js +19 -0
- package/compiled/views/FilterCriteria/CRITERIA_CONFIGURATION.js +110 -0
- package/compiled/views/FilterCriteria/criteriaGroupToQueryExpression.js +40 -0
- package/compiled/views/FilterCriteria/criteriaGroupToSummary.js +47 -0
- package/compiled/views/FilterCriteria/criteriaToNodes.js +89 -0
- package/compiled/views/FilterCriteria/index.js +75 -0
- package/compiled/views/FilterCriteria/models.js +28 -0
- package/compiled/views/FilterCriteria/mutateGroup.js +53 -0
- package/compiled/views/GenericRelatedItemView.js +147 -0
- package/compiled/views/RegisterStakeholder.js +19 -0
- package/compiled/views/RegisterVersion.js +20 -0
- package/compiled/views/SearchQuery.js +58 -0
- package/compiled/views/change-request/ChangeRequestContext.js +30 -0
- package/compiled/views/change-request/Proposals.js +185 -0
- package/compiled/views/change-request/objectChangeset.js +189 -0
- package/compiled/views/detail/ChangeRequest/Proposal.js +144 -0
- package/compiled/views/detail/ChangeRequest/index.js +140 -0
- package/compiled/views/detail/ChangeRequest/transitions.js +418 -0
- package/compiled/views/detail/CustomView/index.js +32 -0
- package/compiled/views/detail/RegisterHome/index.js +70 -0
- package/compiled/views/detail/RegisterItem/RelatedItems.d.ts +14 -0
- package/compiled/views/detail/RegisterItem/RelatedItems.js +28 -0
- package/compiled/views/detail/RegisterItem/RelatedItems.js.map +1 -0
- package/compiled/views/detail/RegisterItem/SupersedingItemMenu.js +27 -0
- package/compiled/views/detail/RegisterItem/index.js +277 -0
- package/compiled/views/detail/RegisterItem/index.js.map +1 -0
- package/compiled/views/detail/RegisterMeta/RegisterMetaForm.js +135 -0
- package/compiled/views/detail/RegisterMeta/index.js +61 -0
- package/compiled/views/detail/index.js +11 -0
- package/compiled/views/diffing/InlineDiff.js +20 -0
- package/compiled/views/diffing/StructuredDiff.js +38 -0
- package/compiled/views/hooks/useCustomView.js +14 -0
- package/compiled/views/hooks/useItemClassConfig.js +14 -0
- package/compiled/views/hooks/useItemRef.js +26 -0
- package/compiled/views/hooks/useSingleRegisterItemData.js +21 -0
- package/compiled/views/index.js +142 -0
- package/compiled/views/itemPathUtils.js +115 -0
- package/compiled/views/itemQueryUtils.js +42 -0
- package/compiled/views/protocolRegistry.js +24 -0
- package/compiled/views/sidebar/Browse/index.js +278 -0
- package/compiled/views/sidebar/Export/index.js +47 -0
- package/compiled/views/sidebar/ListItem.js +23 -0
- package/compiled/views/sidebar/Registration/index.js +114 -0
- package/compiled/views/sidebar/Search/index.js +100 -0
- package/compiled/views/sidebar/index.js +73 -0
- package/compiled/views/util.js +63 -0
- package/dependencies-local/extension-kit/SettingsContext.d.ts +8 -0
- package/dependencies-local/extension-kit/SettingsContext.js +19 -0
- package/dependencies-local/extension-kit/SettingsContext.js.map +1 -0
- package/dependencies-local/extension-kit/context.d.ts +11 -0
- package/dependencies-local/extension-kit/context.js +133 -0
- package/dependencies-local/extension-kit/context.js.map +1 -0
- package/dependencies-local/extension-kit/i18n/ContextProvider.d.ts +9 -0
- package/dependencies-local/extension-kit/i18n/ContextProvider.js +33 -0
- package/dependencies-local/extension-kit/i18n/ContextProvider.js.map +1 -0
- package/dependencies-local/extension-kit/i18n/context.d.ts +9 -0
- package/dependencies-local/extension-kit/i18n/context.js +23 -0
- package/dependencies-local/extension-kit/i18n/context.js.map +1 -0
- package/dependencies-local/extension-kit/i18n/types.d.ts +10 -0
- package/dependencies-local/extension-kit/i18n/types.js.map +1 -0
- package/dependencies-local/extension-kit/i18n/widgets.d.ts +16 -0
- package/dependencies-local/extension-kit/i18n/widgets.js +56 -0
- package/dependencies-local/extension-kit/i18n/widgets.js.map +1 -0
- package/dependencies-local/extension-kit/index.d.ts +3 -0
- package/dependencies-local/extension-kit/index.js +78 -0
- package/dependencies-local/extension-kit/index.js.map +1 -0
- package/dependencies-local/extension-kit/object-specs/index.d.ts +2 -0
- package/dependencies-local/extension-kit/object-specs/index.js +22 -0
- package/dependencies-local/extension-kit/object-specs/index.js.map +1 -0
- package/dependencies-local/extension-kit/object-specs/paneron-object.d.ts +6 -0
- package/dependencies-local/extension-kit/object-specs/paneron-object.js +161 -0
- package/dependencies-local/extension-kit/object-specs/paneron-object.js.map +1 -0
- package/dependencies-local/extension-kit/object-specs/ser-des.d.ts +31 -0
- package/dependencies-local/extension-kit/object-specs/ser-des.js +187 -0
- package/dependencies-local/extension-kit/object-specs/ser-des.js.map +1 -0
- package/dependencies-local/extension-kit/object-specs/yaml/custom-bool.d.ts +2 -0
- package/dependencies-local/extension-kit/object-specs/yaml/custom-bool.js +42 -0
- package/dependencies-local/extension-kit/object-specs/yaml/custom-bool.js.map +1 -0
- package/dependencies-local/extension-kit/object-specs/yaml/custom-timestamp.d.ts +3 -0
- package/dependencies-local/extension-kit/object-specs/yaml/custom-timestamp.js +110 -0
- package/dependencies-local/extension-kit/object-specs/yaml/custom-timestamp.js.map +1 -0
- package/dependencies-local/extension-kit/object-specs/yaml/index.d.ts +9 -0
- package/dependencies-local/extension-kit/object-specs/yaml/index.js +36 -0
- package/dependencies-local/extension-kit/object-specs/yaml/index.js.map +1 -0
- package/dependencies-local/extension-kit/object-specs/yaml/schema.d.ts +3 -0
- package/dependencies-local/extension-kit/object-specs/yaml/schema.js +26 -0
- package/dependencies-local/extension-kit/object-specs/yaml/schema.js.map +1 -0
- package/dependencies-local/extension-kit/package.json +53 -0
- package/dependencies-local/extension-kit/settings.d.ts +6 -0
- package/dependencies-local/extension-kit/settings.js +11 -0
- package/dependencies-local/extension-kit/settings.js.map +1 -0
- package/dependencies-local/extension-kit/types/binary-invocation.d.ts +31 -0
- package/dependencies-local/extension-kit/types/binary-invocation.js.map +1 -0
- package/dependencies-local/extension-kit/types/buffers.d.ts +17 -0
- package/dependencies-local/extension-kit/types/buffers.js +5 -0
- package/dependencies-local/extension-kit/types/buffers.js.map +1 -0
- package/dependencies-local/extension-kit/types/changes.d.ts +37 -0
- package/dependencies-local/extension-kit/types/changes.js +5 -0
- package/dependencies-local/extension-kit/types/changes.js.map +1 -0
- package/dependencies-local/extension-kit/types/data.d.ts +54 -0
- package/dependencies-local/extension-kit/types/data.js +5 -0
- package/dependencies-local/extension-kit/types/data.js.map +1 -0
- package/dependencies-local/extension-kit/types/dialogs.d.ts +15 -0
- package/dependencies-local/extension-kit/types/dialogs.js +5 -0
- package/dependencies-local/extension-kit/types/dialogs.js.map +1 -0
- package/dependencies-local/extension-kit/types/extension-maker.d.ts +17 -0
- package/dependencies-local/extension-kit/types/extension-maker.js +5 -0
- package/dependencies-local/extension-kit/types/extension-maker.js.map +1 -0
- package/dependencies-local/extension-kit/types/extension.d.ts +27 -0
- package/dependencies-local/extension-kit/types/extension.js +5 -0
- package/dependencies-local/extension-kit/types/extension.js.map +1 -0
- package/dependencies-local/extension-kit/types/index.d.ts +3 -0
- package/dependencies-local/extension-kit/types/index.js +41 -0
- package/dependencies-local/extension-kit/types/index.js.map +1 -0
- package/dependencies-local/extension-kit/types/indexes.d.ts +6 -0
- package/dependencies-local/extension-kit/types/indexes.js +15 -0
- package/dependencies-local/extension-kit/types/indexes.js.map +1 -0
- package/dependencies-local/extension-kit/types/migrations.d.ts +15 -0
- package/dependencies-local/extension-kit/types/migrations.js +5 -0
- package/dependencies-local/extension-kit/types/migrations.js.map +1 -0
- package/dependencies-local/extension-kit/types/object-spec.d.ts +108 -0
- package/dependencies-local/extension-kit/types/object-spec.js +23 -0
- package/dependencies-local/extension-kit/types/object-spec.js.map +1 -0
- package/dependencies-local/extension-kit/types/objects.d.ts +18 -0
- package/dependencies-local/extension-kit/types/objects.js +5 -0
- package/dependencies-local/extension-kit/types/objects.js.map +1 -0
- package/dependencies-local/extension-kit/types/progress.d.ts +5 -0
- package/dependencies-local/extension-kit/types/progress.js +5 -0
- package/dependencies-local/extension-kit/types/progress.js.map +1 -0
- package/dependencies-local/extension-kit/types/renderer.d.ts +495 -0
- package/dependencies-local/extension-kit/types/renderer.js +5 -0
- package/dependencies-local/extension-kit/types/renderer.js.map +1 -0
- package/dependencies-local/extension-kit/useDebounce.d.ts +2 -0
- package/dependencies-local/extension-kit/useDebounce.js +27 -0
- package/dependencies-local/extension-kit/useDebounce.js.map +1 -0
- package/dependencies-local/extension-kit/usePersistentStateReducer.d.ts +35 -0
- package/dependencies-local/extension-kit/usePersistentStateReducer.js +91 -0
- package/dependencies-local/extension-kit/usePersistentStateReducer.js.map +1 -0
- package/dependencies-local/extension-kit/useTimeTravelingPersistentStateReducer.d.ts +48 -0
- package/dependencies-local/extension-kit/useTimeTravelingPersistentStateReducer.js +116 -0
- package/dependencies-local/extension-kit/useTimeTravelingPersistentStateReducer.js.map +1 -0
- package/dependencies-local/extension-kit/util.d.ts +8 -0
- package/dependencies-local/extension-kit/util.js +21 -0
- package/dependencies-local/extension-kit/util.js.map +1 -0
- package/dependencies-local/extension-kit/widgets/ErrorState.d.ts +8 -0
- package/dependencies-local/extension-kit/widgets/ErrorState.js +44 -0
- package/dependencies-local/extension-kit/widgets/ErrorState.js.map +1 -0
- package/dependencies-local/extension-kit/widgets/Grid.d.ts +41 -0
- package/dependencies-local/extension-kit/widgets/Grid.js +213 -0
- package/dependencies-local/extension-kit/widgets/Grid.js.map +1 -0
- package/dependencies-local/extension-kit/widgets/HelpTooltip.d.ts +18 -0
- package/dependencies-local/extension-kit/widgets/HelpTooltip.js +84 -0
- package/dependencies-local/extension-kit/widgets/HelpTooltip.js.map +1 -0
- package/dependencies-local/extension-kit/widgets/ItemCount.d.ts +19 -0
- package/dependencies-local/extension-kit/widgets/ItemCount.js +78 -0
- package/dependencies-local/extension-kit/widgets/ItemCount.js.map +1 -0
- package/dependencies-local/extension-kit/widgets/List.d.ts +40 -0
- package/dependencies-local/extension-kit/widgets/List.js +191 -0
- package/dependencies-local/extension-kit/widgets/List.js.map +1 -0
- package/dependencies-local/extension-kit/widgets/Navbar.d.ts +20 -0
- package/dependencies-local/extension-kit/widgets/Navbar.js +75 -0
- package/dependencies-local/extension-kit/widgets/Navbar.js.map +1 -0
- package/dependencies-local/extension-kit/widgets/SearchResultList.d.ts +24 -0
- package/dependencies-local/extension-kit/widgets/SearchResultList.js +201 -0
- package/dependencies-local/extension-kit/widgets/SearchResultList.js.map +1 -0
- package/dependencies-local/extension-kit/widgets/Sidebar/Block.d.ts +21 -0
- package/dependencies-local/extension-kit/widgets/Sidebar/Block.js +94 -0
- package/dependencies-local/extension-kit/widgets/Sidebar/Block.js.map +1 -0
- package/dependencies-local/extension-kit/widgets/Sidebar/BlockStateButtonGroup.d.ts +6 -0
- package/dependencies-local/extension-kit/widgets/Sidebar/BlockStateButtonGroup.js +22 -0
- package/dependencies-local/extension-kit/widgets/Sidebar/BlockStateButtonGroup.js.map +1 -0
- package/dependencies-local/extension-kit/widgets/Sidebar/PropertyView.d.ts +28 -0
- package/dependencies-local/extension-kit/widgets/Sidebar/PropertyView.js +148 -0
- package/dependencies-local/extension-kit/widgets/Sidebar/PropertyView.js.map +1 -0
- package/dependencies-local/extension-kit/widgets/Sidebar/index.d.ts +27 -0
- package/dependencies-local/extension-kit/widgets/Sidebar/index.js +178 -0
- package/dependencies-local/extension-kit/widgets/Sidebar/index.js.map +1 -0
- package/dependencies-local/extension-kit/widgets/TabbedWorkspace/SuperSidebar.d.ts +13 -0
- package/dependencies-local/extension-kit/widgets/TabbedWorkspace/SuperSidebar.js +82 -0
- package/dependencies-local/extension-kit/widgets/TabbedWorkspace/SuperSidebar.js.map +1 -0
- package/dependencies-local/extension-kit/widgets/TabbedWorkspace/context.d.ts +10 -0
- package/dependencies-local/extension-kit/widgets/TabbedWorkspace/context.js +168 -0
- package/dependencies-local/extension-kit/widgets/TabbedWorkspace/context.js.map +1 -0
- package/dependencies-local/extension-kit/widgets/TabbedWorkspace/detail.d.ts +9 -0
- package/dependencies-local/extension-kit/widgets/TabbedWorkspace/detail.js +66 -0
- package/dependencies-local/extension-kit/widgets/TabbedWorkspace/detail.js.map +1 -0
- package/dependencies-local/extension-kit/widgets/TabbedWorkspace/index.d.ts +33 -0
- package/dependencies-local/extension-kit/widgets/TabbedWorkspace/index.js +204 -0
- package/dependencies-local/extension-kit/widgets/TabbedWorkspace/index.js.map +1 -0
- package/dependencies-local/extension-kit/widgets/TabbedWorkspace/types.d.ts +74 -0
- package/dependencies-local/extension-kit/widgets/TabbedWorkspace/types.js +5 -0
- package/dependencies-local/extension-kit/widgets/TabbedWorkspace/types.js.map +1 -0
- package/dependencies-local/extension-kit/widgets/TabbedWorkspace/util.d.ts +1 -0
- package/dependencies-local/extension-kit/widgets/TabbedWorkspace/util.js +14 -0
- package/dependencies-local/extension-kit/widgets/TabbedWorkspace/util.js.map +1 -0
- package/dependencies-local/extension-kit/widgets/Workspace.d.ts +38 -0
- package/dependencies-local/extension-kit/widgets/Workspace.js +99 -0
- package/dependencies-local/extension-kit/widgets/Workspace.js.map +1 -0
- package/dependencies-local/extension-kit/widgets/panels/PanelSeparator.d.ts +12 -0
- package/dependencies-local/extension-kit/widgets/panels/PanelSeparator.js +57 -0
- package/dependencies-local/extension-kit/widgets/panels/PanelSeparator.js.map +1 -0
- package/dependencies-local/extension-kit/widgets/panels/index.d.ts +28 -0
- package/dependencies-local/extension-kit/widgets/panels/index.js +169 -0
- package/dependencies-local/extension-kit/widgets/panels/index.js.map +1 -0
- package/dist/common.d.ts +1 -0
- package/dist/common.js.map +1 -0
- package/dist/index.d.ts +6 -0
- package/dist/index.js.map +1 -0
- package/dist/migrations/initial.d.ts +3 -0
- package/dist/migrations/initial.js.map +1 -0
- package/dist/package.json +56 -0
- package/dist/types/cr.d.ts +216 -0
- package/dist/types/cr.js.map +1 -0
- package/dist/types/index.d.ts +7 -0
- package/dist/types/index.js.map +1 -0
- package/dist/types/item.d.ts +59 -0
- package/dist/types/item.js.map +1 -0
- package/dist/types/proposal.d.ts +64 -0
- package/dist/types/proposal.js.map +1 -0
- package/dist/types/register.d.ts +18 -0
- package/dist/types/register.js.map +1 -0
- package/dist/types/registry.d.ts +15 -0
- package/dist/types/registry.js.map +1 -0
- package/dist/types/stakeholder.d.ts +58 -0
- package/dist/types/stakeholder.js.map +1 -0
- package/dist/types/util.d.ts +21 -0
- package/dist/types/util.js +5 -0
- package/dist/types/util.js.map +1 -0
- package/dist/types/views.d.ts +157 -0
- package/dist/types/views.js +5 -0
- package/dist/types/views.js.map +1 -0
- package/dist/views/AnnotatedChange.d.ts +7 -0
- package/dist/views/AnnotatedChange.js.map +1 -0
- package/dist/views/BrowserCtx.d.ts +73 -0
- package/dist/views/BrowserCtx.js.map +1 -0
- package/dist/views/FilterCriteria/CRITERIA_CONFIGURATION.d.ts +17 -0
- package/dist/views/FilterCriteria/CRITERIA_CONFIGURATION.js.map +1 -0
- package/dist/views/FilterCriteria/criteriaGroupToQueryExpression.d.ts +6 -0
- package/dist/views/FilterCriteria/criteriaGroupToQueryExpression.js.map +1 -0
- package/dist/views/FilterCriteria/criteriaGroupToSummary.d.ts +5 -0
- package/dist/views/FilterCriteria/criteriaGroupToSummary.js.map +1 -0
- package/dist/views/FilterCriteria/criteriaToNodes.d.ts +24 -0
- package/dist/views/FilterCriteria/criteriaToNodes.js.map +1 -0
- package/dist/views/FilterCriteria/index.d.ts +23 -0
- package/dist/views/FilterCriteria/index.js.map +1 -0
- package/dist/views/FilterCriteria/models.d.ts +68 -0
- package/dist/views/FilterCriteria/models.js.map +1 -0
- package/dist/views/FilterCriteria/mutateGroup.d.ts +17 -0
- package/dist/views/FilterCriteria/mutateGroup.js.map +1 -0
- package/dist/views/GenericRelatedItemView.d.ts +6 -0
- package/dist/views/GenericRelatedItemView.js.map +1 -0
- package/dist/views/RegisterStakeholder.d.ts +9 -0
- package/dist/views/RegisterStakeholder.js.map +1 -0
- package/dist/views/RegisterVersion.d.ts +9 -0
- package/dist/views/RegisterVersion.js.map +1 -0
- package/dist/views/SearchQuery.d.ts +13 -0
- package/dist/views/SearchQuery.js.map +1 -0
- package/dist/views/change-request/ChangeRequestContext.d.ts +20 -0
- package/dist/views/change-request/ChangeRequestContext.js.map +1 -0
- package/dist/views/change-request/Proposals.d.ts +21 -0
- package/dist/views/change-request/Proposals.js.map +1 -0
- package/dist/views/change-request/objectChangeset.d.ts +31 -0
- package/dist/views/change-request/objectChangeset.js.map +1 -0
- package/dist/views/detail/ChangeRequest/Proposal.d.ts +0 -0
- package/dist/views/detail/ChangeRequest/Proposal.js.map +1 -0
- package/dist/views/detail/ChangeRequest/index.d.ts +13 -0
- package/dist/views/detail/ChangeRequest/index.js.map +1 -0
- package/dist/views/detail/ChangeRequest/transitions.d.ts +28 -0
- package/dist/views/detail/ChangeRequest/transitions.js.map +1 -0
- package/dist/views/detail/CustomView/index.d.ts +13 -0
- package/dist/views/detail/CustomView/index.js.map +1 -0
- package/dist/views/detail/RegisterHome/index.d.ts +5 -0
- package/dist/views/detail/RegisterHome/index.js.map +1 -0
- package/dist/views/detail/RegisterItem/RelatedItems.d.ts +14 -0
- package/{views → dist/views}/detail/RegisterItem/RelatedItems.js +5 -5
- package/dist/views/detail/RegisterItem/RelatedItems.js.map +1 -0
- package/dist/views/detail/RegisterItem/SupersedingItemMenu.js.map +1 -0
- package/dist/views/detail/RegisterItem/index.d.ts +13 -0
- package/{views → dist/views}/detail/RegisterItem/index.js +3 -2
- package/dist/views/detail/RegisterItem/index.js.map +1 -0
- package/dist/views/detail/RegisterMeta/RegisterMetaForm.d.ts +10 -0
- package/dist/views/detail/RegisterMeta/RegisterMetaForm.js.map +1 -0
- package/dist/views/detail/RegisterMeta/index.d.ts +10 -0
- package/dist/views/detail/RegisterMeta/index.js.map +1 -0
- package/dist/views/detail/index.d.ts +1 -0
- package/dist/views/detail/index.js.map +1 -0
- package/dist/views/diffing/InlineDiff.d.ts +12 -0
- package/dist/views/diffing/InlineDiff.js.map +1 -0
- package/dist/views/diffing/StructuredDiff.d.ts +11 -0
- package/dist/views/diffing/StructuredDiff.js.map +1 -0
- package/dist/views/hooks/useCustomView.d.ts +3 -0
- package/dist/views/hooks/useCustomView.js.map +1 -0
- package/dist/views/hooks/useItemClassConfig.d.ts +3 -0
- package/dist/views/hooks/useItemClassConfig.js.map +1 -0
- package/dist/views/hooks/useItemRef.d.ts +3 -0
- package/dist/views/hooks/useItemRef.js.map +1 -0
- package/dist/views/hooks/useSingleRegisterItemData.d.ts +3 -0
- package/dist/views/hooks/useSingleRegisterItemData.js.map +1 -0
- package/dist/views/index.d.ts +7 -0
- package/dist/views/index.js.map +1 -0
- package/dist/views/itemPathUtils.d.ts +52 -0
- package/dist/views/itemPathUtils.js.map +1 -0
- package/dist/views/itemQueryUtils.d.ts +11 -0
- package/dist/views/itemQueryUtils.js.map +1 -0
- package/dist/views/protocolRegistry.d.ts +12 -0
- package/dist/views/protocolRegistry.js.map +1 -0
- package/dist/views/sidebar/Browse/index.d.ts +11 -0
- package/dist/views/sidebar/Browse/index.js.map +1 -0
- package/dist/views/sidebar/Export/index.d.ts +5 -0
- package/dist/views/sidebar/Export/index.js.map +1 -0
- package/dist/views/sidebar/ListItem.d.ts +10 -0
- package/dist/views/sidebar/ListItem.js.map +1 -0
- package/dist/views/sidebar/Registration/index.d.ts +5 -0
- package/dist/views/sidebar/Registration/index.js.map +1 -0
- package/dist/views/sidebar/Search/index.d.ts +18 -0
- package/dist/views/sidebar/Search/index.js.map +1 -0
- package/dist/views/sidebar/index.d.ts +6 -0
- package/dist/views/sidebar/index.js.map +1 -0
- package/dist/views/util.d.ts +36 -0
- package/dist/views/util.js.map +1 -0
- package/package.json +2 -1
- package/react-visual-diff.d.ts +9 -0
- package/views/detail/RegisterItem/RelatedItems.js.map +0 -1
- package/views/detail/RegisterItem/index.js.map +0 -1
- /package/{common.d.ts → compiled/common.d.ts} +0 -0
- /package/{common.js.map → compiled/common.js.map} +0 -0
- /package/{index.d.ts → compiled/index.d.ts} +0 -0
- /package/{index.js.map → compiled/index.js.map} +0 -0
- /package/{migrations → compiled/migrations}/initial.d.ts +0 -0
- /package/{migrations → compiled/migrations}/initial.js.map +0 -0
- /package/{types → compiled/types}/cr.d.ts +0 -0
- /package/{types → compiled/types}/cr.js.map +0 -0
- /package/{types → compiled/types}/index.d.ts +0 -0
- /package/{types → compiled/types}/index.js.map +0 -0
- /package/{types → compiled/types}/item.d.ts +0 -0
- /package/{types → compiled/types}/item.js.map +0 -0
- /package/{types → compiled/types}/proposal.d.ts +0 -0
- /package/{types → compiled/types}/proposal.js.map +0 -0
- /package/{types → compiled/types}/register.d.ts +0 -0
- /package/{types → compiled/types}/register.js.map +0 -0
- /package/{types → compiled/types}/registry.d.ts +0 -0
- /package/{types → compiled/types}/registry.js.map +0 -0
- /package/{types → compiled/types}/stakeholder.d.ts +0 -0
- /package/{types → compiled/types}/stakeholder.js.map +0 -0
- /package/{types → compiled/types}/util.d.ts +0 -0
- /package/{types → compiled/types}/util.js.map +0 -0
- /package/{types → compiled/types}/views.d.ts +0 -0
- /package/{types → compiled/types}/views.js.map +0 -0
- /package/{views → compiled/views}/AnnotatedChange.d.ts +0 -0
- /package/{views → compiled/views}/AnnotatedChange.js.map +0 -0
- /package/{views → compiled/views}/BrowserCtx.d.ts +0 -0
- /package/{views → compiled/views}/BrowserCtx.js.map +0 -0
- /package/{views → compiled/views}/FilterCriteria/CRITERIA_CONFIGURATION.d.ts +0 -0
- /package/{views → compiled/views}/FilterCriteria/CRITERIA_CONFIGURATION.js.map +0 -0
- /package/{views → compiled/views}/FilterCriteria/criteriaGroupToQueryExpression.d.ts +0 -0
- /package/{views → compiled/views}/FilterCriteria/criteriaGroupToQueryExpression.js.map +0 -0
- /package/{views → compiled/views}/FilterCriteria/criteriaGroupToSummary.d.ts +0 -0
- /package/{views → compiled/views}/FilterCriteria/criteriaGroupToSummary.js.map +0 -0
- /package/{views → compiled/views}/FilterCriteria/criteriaToNodes.d.ts +0 -0
- /package/{views → compiled/views}/FilterCriteria/criteriaToNodes.js.map +0 -0
- /package/{views → compiled/views}/FilterCriteria/index.d.ts +0 -0
- /package/{views → compiled/views}/FilterCriteria/index.js.map +0 -0
- /package/{views → compiled/views}/FilterCriteria/models.d.ts +0 -0
- /package/{views → compiled/views}/FilterCriteria/models.js.map +0 -0
- /package/{views → compiled/views}/FilterCriteria/mutateGroup.d.ts +0 -0
- /package/{views → compiled/views}/FilterCriteria/mutateGroup.js.map +0 -0
- /package/{views → compiled/views}/GenericRelatedItemView.d.ts +0 -0
- /package/{views → compiled/views}/GenericRelatedItemView.js.map +0 -0
- /package/{views → compiled/views}/RegisterStakeholder.d.ts +0 -0
- /package/{views → compiled/views}/RegisterStakeholder.js.map +0 -0
- /package/{views → compiled/views}/RegisterVersion.d.ts +0 -0
- /package/{views → compiled/views}/RegisterVersion.js.map +0 -0
- /package/{views → compiled/views}/SearchQuery.d.ts +0 -0
- /package/{views → compiled/views}/SearchQuery.js.map +0 -0
- /package/{views → compiled/views}/change-request/ChangeRequestContext.d.ts +0 -0
- /package/{views → compiled/views}/change-request/ChangeRequestContext.js.map +0 -0
- /package/{views → compiled/views}/change-request/Proposals.d.ts +0 -0
- /package/{views → compiled/views}/change-request/Proposals.js.map +0 -0
- /package/{views → compiled/views}/change-request/objectChangeset.d.ts +0 -0
- /package/{views → compiled/views}/change-request/objectChangeset.js.map +0 -0
- /package/{views → compiled/views}/detail/ChangeRequest/Proposal.d.ts +0 -0
- /package/{views → compiled/views}/detail/ChangeRequest/Proposal.js.map +0 -0
- /package/{views → compiled/views}/detail/ChangeRequest/index.d.ts +0 -0
- /package/{views → compiled/views}/detail/ChangeRequest/index.js.map +0 -0
- /package/{views → compiled/views}/detail/ChangeRequest/transitions.d.ts +0 -0
- /package/{views → compiled/views}/detail/ChangeRequest/transitions.js.map +0 -0
- /package/{views → compiled/views}/detail/CustomView/index.d.ts +0 -0
- /package/{views → compiled/views}/detail/CustomView/index.js.map +0 -0
- /package/{views → compiled/views}/detail/RegisterHome/index.d.ts +0 -0
- /package/{views → compiled/views}/detail/RegisterHome/index.js.map +0 -0
- /package/{views → compiled/views}/detail/RegisterItem/SupersedingItemMenu.d.ts +0 -0
- /package/{views → compiled/views}/detail/RegisterItem/SupersedingItemMenu.js.map +0 -0
- /package/{views → compiled/views}/detail/RegisterItem/index.d.ts +0 -0
- /package/{views → compiled/views}/detail/RegisterMeta/RegisterMetaForm.d.ts +0 -0
- /package/{views → compiled/views}/detail/RegisterMeta/RegisterMetaForm.js.map +0 -0
- /package/{views → compiled/views}/detail/RegisterMeta/index.d.ts +0 -0
- /package/{views → compiled/views}/detail/RegisterMeta/index.js.map +0 -0
- /package/{views → compiled/views}/detail/index.d.ts +0 -0
- /package/{views → compiled/views}/detail/index.js.map +0 -0
- /package/{views → compiled/views}/diffing/InlineDiff.d.ts +0 -0
- /package/{views → compiled/views}/diffing/InlineDiff.js.map +0 -0
- /package/{views → compiled/views}/diffing/StructuredDiff.d.ts +0 -0
- /package/{views → compiled/views}/diffing/StructuredDiff.js.map +0 -0
- /package/{views → compiled/views}/hooks/useCustomView.d.ts +0 -0
- /package/{views → compiled/views}/hooks/useCustomView.js.map +0 -0
- /package/{views → compiled/views}/hooks/useItemClassConfig.d.ts +0 -0
- /package/{views → compiled/views}/hooks/useItemClassConfig.js.map +0 -0
- /package/{views → compiled/views}/hooks/useItemRef.d.ts +0 -0
- /package/{views → compiled/views}/hooks/useItemRef.js.map +0 -0
- /package/{views → compiled/views}/hooks/useSingleRegisterItemData.d.ts +0 -0
- /package/{views → compiled/views}/hooks/useSingleRegisterItemData.js.map +0 -0
- /package/{views → compiled/views}/index.d.ts +0 -0
- /package/{views → compiled/views}/index.js.map +0 -0
- /package/{views → compiled/views}/itemPathUtils.d.ts +0 -0
- /package/{views → compiled/views}/itemPathUtils.js.map +0 -0
- /package/{views → compiled/views}/itemQueryUtils.d.ts +0 -0
- /package/{views → compiled/views}/itemQueryUtils.js.map +0 -0
- /package/{views → compiled/views}/protocolRegistry.d.ts +0 -0
- /package/{views → compiled/views}/protocolRegistry.js.map +0 -0
- /package/{views → compiled/views}/sidebar/Browse/index.d.ts +0 -0
- /package/{views → compiled/views}/sidebar/Browse/index.js.map +0 -0
- /package/{views → compiled/views}/sidebar/Export/index.d.ts +0 -0
- /package/{views → compiled/views}/sidebar/Export/index.js.map +0 -0
- /package/{views → compiled/views}/sidebar/ListItem.d.ts +0 -0
- /package/{views → compiled/views}/sidebar/ListItem.js.map +0 -0
- /package/{views → compiled/views}/sidebar/Registration/index.d.ts +0 -0
- /package/{views → compiled/views}/sidebar/Registration/index.js.map +0 -0
- /package/{views → compiled/views}/sidebar/Search/index.d.ts +0 -0
- /package/{views → compiled/views}/sidebar/Search/index.js.map +0 -0
- /package/{views → compiled/views}/sidebar/index.d.ts +0 -0
- /package/{views → compiled/views}/sidebar/index.js.map +0 -0
- /package/{views → compiled/views}/util.d.ts +0 -0
- /package/{views → compiled/views}/util.js.map +0 -0
- /package/{types/util.js → dependencies-local/extension-kit/i18n/types.js} +0 -0
- /package/{types/views.js → dependencies-local/extension-kit/types/binary-invocation.js} +0 -0
- /package/{common.js → dist/common.js} +0 -0
- /package/{index.js → dist/index.js} +0 -0
- /package/{migrations → dist/migrations}/initial.js +0 -0
- /package/{types → dist/types}/cr.js +0 -0
- /package/{types → dist/types}/index.js +0 -0
- /package/{types → dist/types}/item.js +0 -0
- /package/{types → dist/types}/proposal.js +0 -0
- /package/{types → dist/types}/register.js +0 -0
- /package/{types → dist/types}/registry.js +0 -0
- /package/{types → dist/types}/stakeholder.js +0 -0
- /package/{views → dist/views}/AnnotatedChange.js +0 -0
- /package/{views → dist/views}/BrowserCtx.js +0 -0
- /package/{views → dist/views}/FilterCriteria/CRITERIA_CONFIGURATION.js +0 -0
- /package/{views → dist/views}/FilterCriteria/criteriaGroupToQueryExpression.js +0 -0
- /package/{views → dist/views}/FilterCriteria/criteriaGroupToSummary.js +0 -0
- /package/{views → dist/views}/FilterCriteria/criteriaToNodes.js +0 -0
- /package/{views → dist/views}/FilterCriteria/index.js +0 -0
- /package/{views → dist/views}/FilterCriteria/models.js +0 -0
- /package/{views → dist/views}/FilterCriteria/mutateGroup.js +0 -0
- /package/{views → dist/views}/GenericRelatedItemView.js +0 -0
- /package/{views → dist/views}/RegisterStakeholder.js +0 -0
- /package/{views → dist/views}/RegisterVersion.js +0 -0
- /package/{views → dist/views}/SearchQuery.js +0 -0
- /package/{views → dist/views}/change-request/ChangeRequestContext.js +0 -0
- /package/{views → dist/views}/change-request/Proposals.js +0 -0
- /package/{views → dist/views}/change-request/objectChangeset.js +0 -0
- /package/{views → dist/views}/detail/ChangeRequest/Proposal.js +0 -0
- /package/{views → dist/views}/detail/ChangeRequest/index.js +0 -0
- /package/{views → dist/views}/detail/ChangeRequest/transitions.js +0 -0
- /package/{views → dist/views}/detail/CustomView/index.js +0 -0
- /package/{views → dist/views}/detail/RegisterHome/index.js +0 -0
- /package/{views/detail/RegisterItem/RelatedItems.d.ts → dist/views/detail/RegisterItem/SupersedingItemMenu.d.ts} +0 -0
- /package/{views → dist/views}/detail/RegisterItem/SupersedingItemMenu.js +0 -0
- /package/{views → dist/views}/detail/RegisterMeta/RegisterMetaForm.js +0 -0
- /package/{views → dist/views}/detail/RegisterMeta/index.js +0 -0
- /package/{views → dist/views}/detail/index.js +0 -0
- /package/{views → dist/views}/diffing/InlineDiff.js +0 -0
- /package/{views → dist/views}/diffing/StructuredDiff.js +0 -0
- /package/{views → dist/views}/hooks/useCustomView.js +0 -0
- /package/{views → dist/views}/hooks/useItemClassConfig.js +0 -0
- /package/{views → dist/views}/hooks/useItemRef.js +0 -0
- /package/{views → dist/views}/hooks/useSingleRegisterItemData.js +0 -0
- /package/{views → dist/views}/index.js +0 -0
- /package/{views → dist/views}/itemPathUtils.js +0 -0
- /package/{views → dist/views}/itemQueryUtils.js +0 -0
- /package/{views → dist/views}/protocolRegistry.js +0 -0
- /package/{views → dist/views}/sidebar/Browse/index.js +0 -0
- /package/{views → dist/views}/sidebar/Export/index.js +0 -0
- /package/{views → dist/views}/sidebar/ListItem.js +0 -0
- /package/{views → dist/views}/sidebar/Registration/index.js +0 -0
- /package/{views → dist/views}/sidebar/Search/index.js +0 -0
- /package/{views → dist/views}/sidebar/index.js +0 -0
- /package/{views → dist/views}/util.js +0 -0
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { useContext } from 'react';
|
|
2
|
+
import { BrowserCtx } from '../BrowserCtx';
|
|
3
|
+
export default function useItemClassConfig(clsID) {
|
|
4
|
+
const { itemClasses } = useContext(BrowserCtx);
|
|
5
|
+
const clsConfig = itemClasses[clsID];
|
|
6
|
+
return {
|
|
7
|
+
value: clsConfig,
|
|
8
|
+
errors: [],
|
|
9
|
+
refresh: () => void 0,
|
|
10
|
+
isUpdating: false,
|
|
11
|
+
_reqCounter: 0,
|
|
12
|
+
};
|
|
13
|
+
}
|
|
14
|
+
//# sourceMappingURL=useItemClassConfig.js.map
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
import { useContext } from 'react';
|
|
2
|
+
import { BrowserCtx } from '../BrowserCtx';
|
|
3
|
+
import { itemPathToItemRef } from '../itemPathUtils';
|
|
4
|
+
export default function useItemRef(itemPath) {
|
|
5
|
+
const { subregisters } = useContext(BrowserCtx);
|
|
6
|
+
try {
|
|
7
|
+
const value = itemPathToItemRef(subregisters !== undefined, itemPath);
|
|
8
|
+
return {
|
|
9
|
+
value,
|
|
10
|
+
isUpdating: false,
|
|
11
|
+
refresh: () => void 0,
|
|
12
|
+
_reqCounter: 0,
|
|
13
|
+
errors: [],
|
|
14
|
+
};
|
|
15
|
+
}
|
|
16
|
+
catch (e) {
|
|
17
|
+
return {
|
|
18
|
+
value: undefined,
|
|
19
|
+
isUpdating: false,
|
|
20
|
+
refresh: () => void 0,
|
|
21
|
+
_reqCounter: 0,
|
|
22
|
+
errors: [`${e.toString?.() ?? e}`],
|
|
23
|
+
};
|
|
24
|
+
}
|
|
25
|
+
}
|
|
26
|
+
//# sourceMappingURL=useItemRef.js.map
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import { useContext } from 'react';
|
|
2
|
+
import { BrowserCtx } from '../BrowserCtx';
|
|
3
|
+
import { itemRefToItemPath } from '../itemPathUtils';
|
|
4
|
+
export default function useSingleRegisterItemData(ref) {
|
|
5
|
+
const { useRegisterItemData } = useContext(BrowserCtx);
|
|
6
|
+
const itemPath = ref ? itemRefToItemPath(ref) : 'NONEXISTENT_ITEM';
|
|
7
|
+
const itemResponse = useRegisterItemData({ itemPaths: [itemPath] });
|
|
8
|
+
const itemResponseValue = itemResponse.value[itemPath];
|
|
9
|
+
const itemData = itemResponseValue?.data ?? null;
|
|
10
|
+
const errMsg = "Item data cannot be loaded";
|
|
11
|
+
return {
|
|
12
|
+
value: itemData,
|
|
13
|
+
errors: itemData === null
|
|
14
|
+
? [errMsg, ...itemResponse.errors]
|
|
15
|
+
: itemResponse.errors,
|
|
16
|
+
isUpdating: itemResponse.isUpdating,
|
|
17
|
+
_reqCounter: itemResponse._reqCounter,
|
|
18
|
+
refresh: itemResponse.refresh,
|
|
19
|
+
};
|
|
20
|
+
}
|
|
21
|
+
//# sourceMappingURL=useSingleRegisterItemData.js.map
|
|
@@ -0,0 +1,142 @@
|
|
|
1
|
+
/** @jsx jsx */
|
|
2
|
+
/** @jsxFrag React.Fragment */
|
|
3
|
+
import React, { useContext, useState, useMemo } from 'react';
|
|
4
|
+
import { jsx, css } from '@emotion/react';
|
|
5
|
+
import { DatasetContext } from '@riboseinc/paneron-extension-kit/context';
|
|
6
|
+
import TabbedWorkspace from '@riboseinc/paneron-extension-kit/widgets/TabbedWorkspace';
|
|
7
|
+
import { makeContextProvider as makeTabbedWorkspaceContextProvider, TabbedWorkspaceContext, } from '@riboseinc/paneron-extension-kit/widgets/TabbedWorkspace/context';
|
|
8
|
+
import { isRegisterItem, isRegisterMetadata, isInternalItemReference, } from '../types';
|
|
9
|
+
import { REGISTER_METADATA_FILENAME } from '../common';
|
|
10
|
+
import GenericRelatedItemView from './GenericRelatedItemView';
|
|
11
|
+
import { sidebarConfig, sidebarIDs } from './sidebar';
|
|
12
|
+
import { BrowserCtx } from './BrowserCtx';
|
|
13
|
+
import { _getRelatedClass } from './util';
|
|
14
|
+
import RegisterHome from './detail/RegisterHome';
|
|
15
|
+
import protocolRegistry, { Protocols } from './protocolRegistry';
|
|
16
|
+
import { ChangeRequestContext, ChangeRequestContextProvider, } from './change-request/ChangeRequestContext';
|
|
17
|
+
import { itemPathInCR, itemPathToItemRefLike } from './itemPathUtils';
|
|
18
|
+
export { GenericRelatedItemView };
|
|
19
|
+
const TabbedWorkspaceContextProvider = makeTabbedWorkspaceContextProvider('Browse', sidebarIDs, protocolRegistry);
|
|
20
|
+
export const RegistryView = function (props) {
|
|
21
|
+
return (jsx(TabbedWorkspaceContextProvider, { stateKey: "main-registry-view" },
|
|
22
|
+
jsx(BrowserCtxProvider, { ...props },
|
|
23
|
+
jsx(RegistryWorkspace, null))));
|
|
24
|
+
};
|
|
25
|
+
const RegistryWorkspace = function () {
|
|
26
|
+
const { changeRequest: activeChangeRequest } = useContext(ChangeRequestContext);
|
|
27
|
+
const { spawnTab } = useContext(TabbedWorkspaceContext);
|
|
28
|
+
const globalMode = useMemo((() => activeChangeRequest
|
|
29
|
+
? {
|
|
30
|
+
content: jsx(React.Fragment, null, "Viewing register as proposed\u2009\u2014\u2009contents shown may differ from version in effect"),
|
|
31
|
+
intent: 'danger',
|
|
32
|
+
onClick: () => spawnTab(`${Protocols.CHANGE_REQUEST}:/proposals/${activeChangeRequest.id}/main.yaml`),
|
|
33
|
+
}
|
|
34
|
+
: undefined), [activeChangeRequest?.id]);
|
|
35
|
+
return jsx(TabbedWorkspace, { css: css `flex: 1 1 auto;`, sidebarConfig: sidebarConfig, sidebarIDs: sidebarIDs, newTabPrompt: jsx(RegisterHome, null), globalMode: globalMode });
|
|
36
|
+
};
|
|
37
|
+
const BrowserCtxProvider = function ({ itemClassConfiguration, subregisters, keyExpression, defaultSearchCriteria, customViews, children, }) {
|
|
38
|
+
const { useObjectData, useRemoteUsername } = useContext(DatasetContext);
|
|
39
|
+
const { focusedTabURI, spawnTab } = useContext(TabbedWorkspaceContext);
|
|
40
|
+
const selectedItemPath = focusedTabURI && focusedTabURI.startsWith(`${Protocols.ITEM_DETAILS}:`)
|
|
41
|
+
? focusedTabURI.split(':')[1]
|
|
42
|
+
: null;
|
|
43
|
+
const selectedItemRef = selectedItemPath
|
|
44
|
+
? itemPathToItemRefLike(subregisters !== undefined, selectedItemPath)
|
|
45
|
+
: null;
|
|
46
|
+
const maybeSelectedRegisterItemData = useObjectData({
|
|
47
|
+
objectPaths: selectedItemPath ? [selectedItemPath] : [],
|
|
48
|
+
}).value.data[selectedItemPath ?? ''];
|
|
49
|
+
const selectedRegisterItem = isInternalItemReference(selectedItemRef)
|
|
50
|
+
? maybeSelectedRegisterItemData &&
|
|
51
|
+
isRegisterItem(maybeSelectedRegisterItemData)
|
|
52
|
+
? {
|
|
53
|
+
item: maybeSelectedRegisterItemData,
|
|
54
|
+
ref: selectedItemRef,
|
|
55
|
+
itemClass: itemClassConfiguration[selectedItemRef.classID],
|
|
56
|
+
}
|
|
57
|
+
: undefined
|
|
58
|
+
: null;
|
|
59
|
+
// TODO: Confirm that end extensions using RegistryKit can’t just import hooks
|
|
60
|
+
// from RegistryKit and we really have to pass this to them via context
|
|
61
|
+
// TODO: Why not use useObjectData directly? Since register item paths
|
|
62
|
+
// are just object paths. The casting here is optimistic, since an item at given path
|
|
63
|
+
// may not be a RegisterItem.
|
|
64
|
+
const useRegisterItemData = (opts) => {
|
|
65
|
+
// Original item path mapped to its potential alternative path in current CR,
|
|
66
|
+
// if the item is clarified or added in it.
|
|
67
|
+
// TODO(perf): Access CR data and check whether the item is affected instead of blindly trying CR paths
|
|
68
|
+
const pathsToRequest = {};
|
|
69
|
+
const { changeRequest: activeChangeRequest } = useContext(ChangeRequestContext);
|
|
70
|
+
for (const givenItemPath of opts.itemPaths) {
|
|
71
|
+
pathsToRequest[givenItemPath] = givenItemPath;
|
|
72
|
+
// Don’t use CR alternative path for any path that is already explicitly in-CR.
|
|
73
|
+
// TODO(perf): move out of the loop what’s possible, use map-reduce maybe too
|
|
74
|
+
if (!opts.ignoreActiveCR && !givenItemPath.startsWith('/proposals') && activeChangeRequest?.id) {
|
|
75
|
+
pathsToRequest[itemPathInCR(givenItemPath, activeChangeRequest.id)] = givenItemPath;
|
|
76
|
+
}
|
|
77
|
+
}
|
|
78
|
+
const result = useObjectData({
|
|
79
|
+
objectPaths: Object.keys(pathsToRequest),
|
|
80
|
+
});
|
|
81
|
+
const itemData = {};
|
|
82
|
+
for (const [alternativePath, itemPath] of Object.entries(pathsToRequest)) {
|
|
83
|
+
const data = result.value.data[alternativePath]
|
|
84
|
+
?? result.value.data[itemPath]
|
|
85
|
+
?? null;
|
|
86
|
+
if (isRegisterItem(data) || data === null) {
|
|
87
|
+
itemData[itemPath] = data;
|
|
88
|
+
}
|
|
89
|
+
}
|
|
90
|
+
// Convert dates
|
|
91
|
+
// const parsedData: Record<string, RegisterItem<any> | null> = Object.entries(result.value.data).
|
|
92
|
+
// map(([ path, data ]) => {
|
|
93
|
+
// return {
|
|
94
|
+
// [path]: data !== null
|
|
95
|
+
// ? {
|
|
96
|
+
// ...data,
|
|
97
|
+
// dateAccepted: parseISO(data!.dateAccepted as unknown as string),
|
|
98
|
+
// }
|
|
99
|
+
// : null,
|
|
100
|
+
// };
|
|
101
|
+
// }).
|
|
102
|
+
// reduce((p, c) => ({ ...p, ...c }), {});
|
|
103
|
+
return {
|
|
104
|
+
...result,
|
|
105
|
+
value: itemData,
|
|
106
|
+
};
|
|
107
|
+
};
|
|
108
|
+
// Register data
|
|
109
|
+
const registerMetadataReq = useObjectData({
|
|
110
|
+
objectPaths: [REGISTER_METADATA_FILENAME],
|
|
111
|
+
});
|
|
112
|
+
const maybeRegisterMetadata = registerMetadataReq.value.data?.[REGISTER_METADATA_FILENAME] ??
|
|
113
|
+
(registerMetadataReq.isUpdating ? undefined : null);
|
|
114
|
+
const registerMetadata = !maybeRegisterMetadata || isRegisterMetadata(maybeRegisterMetadata)
|
|
115
|
+
? maybeRegisterMetadata
|
|
116
|
+
: null;
|
|
117
|
+
const remoteUsername = useRemoteUsername().value.username;
|
|
118
|
+
const stakeholder = remoteUsername
|
|
119
|
+
? (registerMetadata?.stakeholders ?? []).
|
|
120
|
+
find(s => s.gitServerUsername === remoteUsername)
|
|
121
|
+
: undefined;
|
|
122
|
+
// Active CR
|
|
123
|
+
const [activeChangeRequestID, setActiveChangeRequestID] = useState(null);
|
|
124
|
+
const getRelatedClass = _getRelatedClass(itemClassConfiguration);
|
|
125
|
+
return (jsx(BrowserCtx.Provider, { value: {
|
|
126
|
+
stakeholder,
|
|
127
|
+
registerMetadata,
|
|
128
|
+
subregisters,
|
|
129
|
+
itemClasses: itemClassConfiguration,
|
|
130
|
+
jumpTo: spawnTab,
|
|
131
|
+
selectedRegisterItem,
|
|
132
|
+
activeChangeRequestID,
|
|
133
|
+
setActiveChangeRequestID,
|
|
134
|
+
useRegisterItemData,
|
|
135
|
+
getRelatedItemClassConfiguration: getRelatedClass,
|
|
136
|
+
customViews: customViews ?? [],
|
|
137
|
+
keyExpression,
|
|
138
|
+
defaultSearchCriteria,
|
|
139
|
+
} },
|
|
140
|
+
jsx(ChangeRequestContextProvider, { changeRequestID: activeChangeRequestID }, children)));
|
|
141
|
+
};
|
|
142
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1,115 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Returns dataset-relative path to a register item,
|
|
3
|
+
* given structured item reference.
|
|
4
|
+
*
|
|
5
|
+
* Optionally makes path include given change request contents.
|
|
6
|
+
*/
|
|
7
|
+
export function itemRefToItemPath({ subregisterID, classID, itemID }, inCRWithID) {
|
|
8
|
+
return `${incompleteItemRefToItemPathPrefix({ subregisterID, classID }, inCRWithID)}/${itemID}.yaml`;
|
|
9
|
+
}
|
|
10
|
+
/**
|
|
11
|
+
* Returns dataset-relative prefix to a register item,
|
|
12
|
+
* given structured item reference without `itemID`.
|
|
13
|
+
*
|
|
14
|
+
* Optionally makes path include given change request contents.
|
|
15
|
+
*/
|
|
16
|
+
export function incompleteItemRefToItemPathPrefix({ subregisterID, classID }, inCRWithID) {
|
|
17
|
+
const itemWithClass = `${classID}`;
|
|
18
|
+
const fullPath = subregisterID
|
|
19
|
+
? `subregisters/${subregisterID}/${itemWithClass}`
|
|
20
|
+
: itemWithClass;
|
|
21
|
+
const maybeInCR = inCRWithID !== undefined
|
|
22
|
+
? `/proposals/${inCRWithID}/items/${fullPath}`
|
|
23
|
+
: `/${fullPath}`;
|
|
24
|
+
return maybeInCR;
|
|
25
|
+
}
|
|
26
|
+
/**
|
|
27
|
+
* Attempts to return a structured register item reference
|
|
28
|
+
* given a dataset-relative item path.
|
|
29
|
+
* If some components are missing, returns an incomplete reference.
|
|
30
|
+
*/
|
|
31
|
+
export function itemPathToItemRefLike(hasSubregisters, itemPath) {
|
|
32
|
+
const pathNormalized = itemPath.trim()
|
|
33
|
+
? stripLeadingSlash(itemPathNotInCR(itemPath))
|
|
34
|
+
: undefined;
|
|
35
|
+
const pathParts = pathNormalized?.split('/') ?? [];
|
|
36
|
+
const subregisterID = hasSubregisters && pathParts.length >= 1
|
|
37
|
+
? pathParts[1]
|
|
38
|
+
: undefined;
|
|
39
|
+
const classID = hasSubregisters
|
|
40
|
+
? pathParts.length >= 3
|
|
41
|
+
? pathParts[2]
|
|
42
|
+
: undefined
|
|
43
|
+
: pathParts.length >= 1
|
|
44
|
+
? pathParts[0]
|
|
45
|
+
: undefined;
|
|
46
|
+
const itemID = (hasSubregisters && pathParts.length === 4) ||
|
|
47
|
+
(!hasSubregisters && pathParts.length === 2)
|
|
48
|
+
? pathParts[pathParts.length - 1].split('.')[0]
|
|
49
|
+
: undefined;
|
|
50
|
+
return { subregisterID, classID, itemID };
|
|
51
|
+
}
|
|
52
|
+
/** Returns just register item ID, given dataset-relative path. */
|
|
53
|
+
export function itemPathToItemID(objPath) {
|
|
54
|
+
const objPathComponents = objPath?.split('/');
|
|
55
|
+
const selectedItemID = objPathComponents !== undefined
|
|
56
|
+
? objPathComponents[objPathComponents.length - 1].split('.')[0]
|
|
57
|
+
: undefined;
|
|
58
|
+
return selectedItemID;
|
|
59
|
+
}
|
|
60
|
+
/**
|
|
61
|
+
* Attempts to return a structured register item reference
|
|
62
|
+
* given a dataset-relative item path.
|
|
63
|
+
* If some components are missing, throws an Error.
|
|
64
|
+
*/
|
|
65
|
+
export function itemPathToItemRef(hasSubregisters, itemPath) {
|
|
66
|
+
const maybeRef = itemPathToItemRefLike(hasSubregisters, itemPath);
|
|
67
|
+
if (maybeRef.classID && maybeRef.itemID) {
|
|
68
|
+
return maybeRef;
|
|
69
|
+
}
|
|
70
|
+
else {
|
|
71
|
+
console.error("Internal item reference cannot be constructed from given item path, got", maybeRef, itemPath, hasSubregisters, "from", itemPath);
|
|
72
|
+
throw new Error("Internal item reference cannot be constructed from given item path");
|
|
73
|
+
}
|
|
74
|
+
}
|
|
75
|
+
const CR_ITEM_PREFIX_REGEX = /^proposals\/(?<crID>\p{Hex_Digit}{8}(?:-\p{Hex_Digit}{4}){3}-\p{Hex_Digit}{12})\/items\//u;
|
|
76
|
+
/**
|
|
77
|
+
* If given item path indicates that it is within any CR, returns respective CR ID.
|
|
78
|
+
* Otherwise, returns `null`.
|
|
79
|
+
*/
|
|
80
|
+
export function getCRIDFromProposedItemPath(givenItemPath) {
|
|
81
|
+
return stripLeadingSlash(givenItemPath).match(CR_ITEM_PREFIX_REGEX)?.groups?.crID ?? null;
|
|
82
|
+
}
|
|
83
|
+
/**
|
|
84
|
+
* Given an item path, returns path relative to specified CR ID
|
|
85
|
+
* (even if the path is already relative to another CR ID).
|
|
86
|
+
*/
|
|
87
|
+
export function itemPathInCR(givenItemPath, crID) {
|
|
88
|
+
// Remove any CR prefix from given path
|
|
89
|
+
// TODO(perf): Don’t do if prefix matches CR ID already specified?
|
|
90
|
+
// TODO: Validate given path actually looks like a register item path and throw?
|
|
91
|
+
const normalized = stripLeadingSlash(givenItemPath).replace(CR_ITEM_PREFIX_REGEX, '');
|
|
92
|
+
return `/proposals/${crID}/items/${normalized}`;
|
|
93
|
+
}
|
|
94
|
+
/**
|
|
95
|
+
* Returns given item path in register-relative form,
|
|
96
|
+
* even if the path is given within proposal contents.
|
|
97
|
+
*/
|
|
98
|
+
export function itemPathNotInCR(givenItemPath) {
|
|
99
|
+
const normalized = stripLeadingSlash(givenItemPath).replace(CR_ITEM_PREFIX_REGEX, '');
|
|
100
|
+
return `/${normalized}`;
|
|
101
|
+
}
|
|
102
|
+
function stripLeadingSlash(aPath) {
|
|
103
|
+
return aPath.replace(/^\//, '');
|
|
104
|
+
}
|
|
105
|
+
/** Converts a change request ID to dataset-relative path to respective main.yaml. */
|
|
106
|
+
export function crIDToCRPath(crID) {
|
|
107
|
+
return `/proposals/${crID}/main.yaml`;
|
|
108
|
+
}
|
|
109
|
+
/** Extracts change request ID from dataset-relative path to its main.yaml. */
|
|
110
|
+
export function crPathToCRID(crPath) {
|
|
111
|
+
return (stripLeadingSlash(crPath).
|
|
112
|
+
replace('proposals/', '').
|
|
113
|
+
split('/')[0]);
|
|
114
|
+
}
|
|
115
|
+
//# sourceMappingURL=itemPathUtils.js.map
|
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
import { itemPathInCR } from './itemPathUtils';
|
|
2
|
+
// TODO: Should it be three path components? Probably four
|
|
3
|
+
const REGISTER_ITEM_QUERY = `
|
|
4
|
+
objPath.startsWith("/subregisters/") || (
|
|
5
|
+
objPath.split("/").length === 3 &&
|
|
6
|
+
!objPath.startsWith("/proposals/")
|
|
7
|
+
)
|
|
8
|
+
`;
|
|
9
|
+
/**
|
|
10
|
+
* Returns a query that matches given register item object path
|
|
11
|
+
* depending on how it appears in given change request.
|
|
12
|
+
*
|
|
13
|
+
* For additions, object path would be full in-proposal path
|
|
14
|
+
* (the item doesn’t exist in the register “normally”), so we want to match that.
|
|
15
|
+
* For clarifications, object path we want to match is normal
|
|
16
|
+
*/
|
|
17
|
+
function getItemInCRQuery(cr) {
|
|
18
|
+
//const affectedItemPathsQuoted: string[] = Object.entries(withCR.items).
|
|
19
|
+
// filter(([, proposal]) => proposal.type === 'clarification' || proposal.type === 'addition').
|
|
20
|
+
// map(([itemPath, proposal]) => proposal.type === 'clarification' ? `"${itemPath}"` : `/proposals/${withCR.id}/items/${itemPath}`);
|
|
21
|
+
const affectedItemPathsQuoted = Object.entries(cr.items).
|
|
22
|
+
filter(([, proposal]) => proposal.type !== 'amendment').
|
|
23
|
+
map(([itemPath,]) => `"${itemPathInCR(itemPath, cr.id)}"`);
|
|
24
|
+
return `[${affectedItemPathsQuoted.join(',')}].indexOf(objPath) >= 0`;
|
|
25
|
+
}
|
|
26
|
+
/**
|
|
27
|
+
* Returns a query criteria for use with filtered indexes
|
|
28
|
+
* by combining given `queryExpression` with base query that matches only
|
|
29
|
+
* objects corresponding to register items.
|
|
30
|
+
*
|
|
31
|
+
* `withCR` should be set to active CR, and would make the query
|
|
32
|
+
* additionally match clarified/added register items that did not yet make it
|
|
33
|
+
* into the register proper.
|
|
34
|
+
*/
|
|
35
|
+
export function getRegisterItemQuery(queryExpression, withCR) {
|
|
36
|
+
const baseQuery = withCR
|
|
37
|
+
? `(${getItemInCRQuery(withCR)}) || (${REGISTER_ITEM_QUERY})`
|
|
38
|
+
: REGISTER_ITEM_QUERY;
|
|
39
|
+
// console.debug("CR QUERY", baseQuery);
|
|
40
|
+
return `return (${baseQuery}) && (${queryExpression.trim()})`;
|
|
41
|
+
}
|
|
42
|
+
//# sourceMappingURL=itemQueryUtils.js.map
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import RegisterItem from './detail/RegisterItem';
|
|
2
|
+
import RegisterMeta from './detail/RegisterMeta';
|
|
3
|
+
import ChangeRequest from './detail/ChangeRequest';
|
|
4
|
+
import CustomView from './detail/CustomView';
|
|
5
|
+
export const Protocols = {
|
|
6
|
+
ITEM_DETAILS: 'itemdetails',
|
|
7
|
+
REGISTER_META: 'registermeta',
|
|
8
|
+
CHANGE_REQUEST: 'changerequest',
|
|
9
|
+
CUSTOM_VIEW: 'customview',
|
|
10
|
+
};
|
|
11
|
+
export const protocols = Object.values(Protocols);
|
|
12
|
+
export function isValidProtocol(val) {
|
|
13
|
+
return protocols.indexOf(val) >= 0;
|
|
14
|
+
}
|
|
15
|
+
// TODO: Implement proper registration pattern rather than registering
|
|
16
|
+
// these in a centralized manner.
|
|
17
|
+
const protocolRegistry = {
|
|
18
|
+
[Protocols.ITEM_DETAILS]: RegisterItem,
|
|
19
|
+
[Protocols.REGISTER_META]: RegisterMeta,
|
|
20
|
+
[Protocols.CHANGE_REQUEST]: ChangeRequest,
|
|
21
|
+
[Protocols.CUSTOM_VIEW]: CustomView,
|
|
22
|
+
};
|
|
23
|
+
export default protocolRegistry;
|
|
24
|
+
//# sourceMappingURL=protocolRegistry.js.map
|
|
@@ -0,0 +1,278 @@
|
|
|
1
|
+
/** @jsx jsx */
|
|
2
|
+
/** @jsxFrag React.Fragment */
|
|
3
|
+
import React, { useContext, useEffect } from 'react';
|
|
4
|
+
import { jsx, css } from '@emotion/react';
|
|
5
|
+
import { Button, Menu, MenuItem, MenuDivider, Tree } from '@blueprintjs/core';
|
|
6
|
+
import { Popover2 } from '@blueprintjs/popover2';
|
|
7
|
+
import { DatasetContext } from '@riboseinc/paneron-extension-kit/context';
|
|
8
|
+
import { TabbedWorkspaceContext } from '@riboseinc/paneron-extension-kit/widgets/TabbedWorkspace/context';
|
|
9
|
+
import makeSearchResultList from '@riboseinc/paneron-extension-kit/widgets/SearchResultList';
|
|
10
|
+
import criteriaGroupToQueryExpression from '../../FilterCriteria/criteriaGroupToQueryExpression';
|
|
11
|
+
import CRITERIA_CONFIGURATION from '../../FilterCriteria/CRITERIA_CONFIGURATION';
|
|
12
|
+
import { itemRefToItemPath } from '../../itemPathUtils';
|
|
13
|
+
import { getRegisterItemQuery } from '../../itemQueryUtils';
|
|
14
|
+
import { ChangeRequestContext } from '../../change-request/ChangeRequestContext';
|
|
15
|
+
import { updateCRObjectChangeset } from '../../change-request/objectChangeset';
|
|
16
|
+
import { BrowserCtx } from '../../BrowserCtx';
|
|
17
|
+
import ListItem from '../ListItem';
|
|
18
|
+
import { Protocols } from '../../protocolRegistry';
|
|
19
|
+
const Browse = function ({ stateName, onOpenItem, className, style }) {
|
|
20
|
+
const { performOperation, updateObjects, makeRandomID, usePersistentDatasetStateReducer } = useContext(DatasetContext);
|
|
21
|
+
const { spawnTab, focusedTabURI } = useContext(TabbedWorkspaceContext);
|
|
22
|
+
const { keyExpression, itemClasses, subregisters } = useContext(BrowserCtx);
|
|
23
|
+
const { changeRequest: activeCR, canEdit: activeCRIsEditable } = useContext(ChangeRequestContext);
|
|
24
|
+
const [state, dispatch,] = usePersistentDatasetStateReducer(stateName ?? 'browse-sidebar', undefined, function valdateState(loadedValue) {
|
|
25
|
+
function validateFolderID(foldID) {
|
|
26
|
+
return foldID !== undefined &&
|
|
27
|
+
(foldID === null || (foldID.startsWith('by-item-class/') ||
|
|
28
|
+
foldID.startsWith('by-subregister/')));
|
|
29
|
+
}
|
|
30
|
+
return (validateFolderID(loadedValue.enteredFolderID) &&
|
|
31
|
+
validateFolderID(loadedValue.selectedFolderID) &&
|
|
32
|
+
loadedValue.selectedItemPath !== undefined);
|
|
33
|
+
}, (prevState, action) => {
|
|
34
|
+
switch (action.type) {
|
|
35
|
+
case 'select-folder':
|
|
36
|
+
if (prevState.enteredFolderID !== null) {
|
|
37
|
+
return prevState;
|
|
38
|
+
}
|
|
39
|
+
else {
|
|
40
|
+
return {
|
|
41
|
+
...prevState,
|
|
42
|
+
selectedFolderID: action.payload.id,
|
|
43
|
+
};
|
|
44
|
+
}
|
|
45
|
+
case 'enter-folder':
|
|
46
|
+
if (prevState.enteredFolderID === null) {
|
|
47
|
+
return {
|
|
48
|
+
...prevState,
|
|
49
|
+
selectedFolderID: action.payload.id,
|
|
50
|
+
enteredFolderID: action.payload.id,
|
|
51
|
+
};
|
|
52
|
+
}
|
|
53
|
+
else {
|
|
54
|
+
return prevState;
|
|
55
|
+
}
|
|
56
|
+
case 'exit-folder':
|
|
57
|
+
if (prevState.enteredFolderID !== null) {
|
|
58
|
+
return {
|
|
59
|
+
...prevState,
|
|
60
|
+
enteredFolderID: null,
|
|
61
|
+
selectedItemPath: null,
|
|
62
|
+
};
|
|
63
|
+
}
|
|
64
|
+
else {
|
|
65
|
+
return prevState;
|
|
66
|
+
}
|
|
67
|
+
case 'select-item':
|
|
68
|
+
if (prevState.enteredFolderID && prevState.selectedFolderID) {
|
|
69
|
+
return {
|
|
70
|
+
...prevState,
|
|
71
|
+
selectedItemPath: action.payload.itemPath,
|
|
72
|
+
};
|
|
73
|
+
}
|
|
74
|
+
else {
|
|
75
|
+
return prevState;
|
|
76
|
+
}
|
|
77
|
+
default:
|
|
78
|
+
throw new Error("Unexpected browse state");
|
|
79
|
+
}
|
|
80
|
+
}, {
|
|
81
|
+
selectedFolderID: null,
|
|
82
|
+
enteredFolderID: null,
|
|
83
|
+
selectedItemPath: null,
|
|
84
|
+
}, null);
|
|
85
|
+
// If currently focused tab changed, select corresponding item in view
|
|
86
|
+
useEffect(() => {
|
|
87
|
+
if (focusedTabURI) {
|
|
88
|
+
const [proto, itemPath] = focusedTabURI.split(':');
|
|
89
|
+
// TODO: also check entered folder?
|
|
90
|
+
if (proto === Protocols.ITEM_DETAILS) {
|
|
91
|
+
dispatch({ type: 'select-item', payload: { itemPath } });
|
|
92
|
+
}
|
|
93
|
+
}
|
|
94
|
+
}, [focusedTabURI]);
|
|
95
|
+
async function handleAdd(classID, subregisterID) {
|
|
96
|
+
if (!updateObjects || !makeRandomID || !activeCRIsEditable || !activeCR) {
|
|
97
|
+
throw new Error("Unable to create item: likely current proposal is not editable or dataset is read-only");
|
|
98
|
+
}
|
|
99
|
+
if (subregisters && !subregisterID) {
|
|
100
|
+
throw new Error("Unable to create item: register uses subregisters, but subregister ID was not provided");
|
|
101
|
+
}
|
|
102
|
+
const clsConfig = itemClasses[classID];
|
|
103
|
+
if (!clsConfig) {
|
|
104
|
+
throw new Error("Unable to generate new item data: item class configuration is missing");
|
|
105
|
+
}
|
|
106
|
+
const initialItemData = clsConfig?.defaults ?? {};
|
|
107
|
+
const itemID = await makeRandomID();
|
|
108
|
+
const ref = { classID, itemID, subregisterID };
|
|
109
|
+
const registerItem = {
|
|
110
|
+
id: itemID,
|
|
111
|
+
dateAccepted: new Date(),
|
|
112
|
+
status: 'valid',
|
|
113
|
+
data: initialItemData,
|
|
114
|
+
};
|
|
115
|
+
const itemPath = itemRefToItemPath(ref);
|
|
116
|
+
await updateObjects({
|
|
117
|
+
commitMessage: `propose to add new ${ref.classID}`,
|
|
118
|
+
objectChangeset: updateCRObjectChangeset(activeCR, { [itemPath]: { type: 'addition' } }, { [itemPath]: registerItem }),
|
|
119
|
+
_dangerouslySkipValidation: true,
|
|
120
|
+
});
|
|
121
|
+
spawnTab(`${Protocols.ITEM_DETAILS}:${itemRefToItemPath(ref, activeCR.id)}`);
|
|
122
|
+
}
|
|
123
|
+
if (state.enteredFolderID !== null) {
|
|
124
|
+
// If we are in a folder, show a tree with a single element
|
|
125
|
+
// indicating currently entered folder
|
|
126
|
+
// followed by windowed search result list
|
|
127
|
+
// with query according to the folder (item class, subregister)
|
|
128
|
+
let criteria;
|
|
129
|
+
let folderInfo;
|
|
130
|
+
if (state.enteredFolderID.startsWith('by-item-class/')) {
|
|
131
|
+
const classID = state.enteredFolderID.split('/')[1];
|
|
132
|
+
const clsConfig = itemClasses[classID];
|
|
133
|
+
folderInfo = {
|
|
134
|
+
title: clsConfig?.meta?.title ?? classID,
|
|
135
|
+
moreMenu: clsConfig
|
|
136
|
+
? jsx(ItemClassMenu, { cfg: itemClasses[classID], onCreate: !subregisters && activeCRIsEditable && performOperation
|
|
137
|
+
? () => performOperation('generating new item', handleAdd)(classID)
|
|
138
|
+
: undefined })
|
|
139
|
+
: undefined,
|
|
140
|
+
};
|
|
141
|
+
criteria = {
|
|
142
|
+
require: 'all',
|
|
143
|
+
criteria: [
|
|
144
|
+
{
|
|
145
|
+
key: 'item-class',
|
|
146
|
+
query: CRITERIA_CONFIGURATION['item-class'].toQuery({ classID }, { itemClasses, subregisters }),
|
|
147
|
+
},
|
|
148
|
+
],
|
|
149
|
+
};
|
|
150
|
+
}
|
|
151
|
+
else if (subregisters && state.enteredFolderID.startsWith('by-subregister/')) {
|
|
152
|
+
const subregisterID = state.enteredFolderID.split('/')[1];
|
|
153
|
+
const subregConfig = subregisters[subregisterID];
|
|
154
|
+
folderInfo = {
|
|
155
|
+
title: subregConfig?.title ?? subregisterID,
|
|
156
|
+
moreMenu: subregConfig
|
|
157
|
+
? jsx(SubregisterMenu, { cfg: subregConfig, itemClasses: itemClasses, onCreate: activeCRIsEditable && performOperation
|
|
158
|
+
? (clsID) => performOperation('generating new item', handleAdd)(clsID, subregisterID)
|
|
159
|
+
: undefined })
|
|
160
|
+
: undefined,
|
|
161
|
+
};
|
|
162
|
+
criteria = {
|
|
163
|
+
require: 'all',
|
|
164
|
+
criteria: [
|
|
165
|
+
{
|
|
166
|
+
key: 'subregister',
|
|
167
|
+
query: CRITERIA_CONFIGURATION['subregister'].toQuery({ subregisterID }, { itemClasses, subregisters }),
|
|
168
|
+
},
|
|
169
|
+
],
|
|
170
|
+
};
|
|
171
|
+
}
|
|
172
|
+
else {
|
|
173
|
+
folderInfo = { title: '' };
|
|
174
|
+
criteria = { require: 'all', criteria: [] };
|
|
175
|
+
}
|
|
176
|
+
const queryExpression = criteriaGroupToQueryExpression(criteria);
|
|
177
|
+
return (jsx("div", { css: css `display: flex; flex-flow: column nowrap;`, className: className, style: style },
|
|
178
|
+
jsx(Tree, { css: css `flex: 0;`, onNodeClick: () => dispatch({ type: 'select-item', payload: { itemPath: null } }), onNodeCollapse: () => dispatch({ type: 'exit-folder' }), onNodeDoubleClick: () => dispatch({ type: 'exit-folder' }), contents: [{
|
|
179
|
+
id: 'opened-class',
|
|
180
|
+
isSelected: state.selectedItemPath === null,
|
|
181
|
+
isExpanded: true,
|
|
182
|
+
hasCaret: true,
|
|
183
|
+
icon: 'folder-open',
|
|
184
|
+
label: folderInfo.title,
|
|
185
|
+
secondaryLabel: folderInfo.moreMenu ? jsx(MoreMenu, null, folderInfo.moreMenu) : undefined,
|
|
186
|
+
}] }),
|
|
187
|
+
jsx("div", { css: css `flex: 1;` },
|
|
188
|
+
jsx(SearchResultList, { queryExpression: getRegisterItemQuery(queryExpression, activeCR ?? undefined), keyExpression: keyExpression, selectedItemPath: state.selectedItemPath, onSelectItem: itemPath => dispatch({ type: 'select-item', payload: { itemPath } }), onOpenItem: onOpenItem ?? (itemPath => spawnTab(`${Protocols.ITEM_DETAILS}:${itemPath}`)) }))));
|
|
189
|
+
}
|
|
190
|
+
else {
|
|
191
|
+
// If we are *not* in a folder, show a list of available folders/views
|
|
192
|
+
// (item classes, subregisters)
|
|
193
|
+
const contents = [{
|
|
194
|
+
id: 'by-item-class',
|
|
195
|
+
isExpanded: true,
|
|
196
|
+
hasCaret: false,
|
|
197
|
+
icon: 'filter',
|
|
198
|
+
label: "By item class",
|
|
199
|
+
disabled: true,
|
|
200
|
+
nodeData: { folderID: null },
|
|
201
|
+
}, ...Object.entries(itemClasses).map(([classID, classConfig]) => ({
|
|
202
|
+
isSelected: state.selectedFolderID === `by-item-class/${classID}`,
|
|
203
|
+
id: classID,
|
|
204
|
+
isExpanded: false,
|
|
205
|
+
icon: 'folder-close',
|
|
206
|
+
hasCaret: true,
|
|
207
|
+
label: classConfig.meta.title,
|
|
208
|
+
nodeData: { folderID: `by-item-class/${classID}` },
|
|
209
|
+
secondaryLabel: jsx(MoreMenu, null,
|
|
210
|
+
jsx(ItemClassMenu, { cfg: classConfig, onCreate: !subregisters && activeCRIsEditable && performOperation
|
|
211
|
+
? () => performOperation('generating new item', handleAdd)(classID)
|
|
212
|
+
: undefined })),
|
|
213
|
+
})), ...(subregisters
|
|
214
|
+
? [{
|
|
215
|
+
id: 'by-subregister',
|
|
216
|
+
isExpanded: true,
|
|
217
|
+
hasCaret: false,
|
|
218
|
+
disabled: true,
|
|
219
|
+
icon: 'filter',
|
|
220
|
+
label: "By subregister",
|
|
221
|
+
nodeData: { folderID: null },
|
|
222
|
+
}, ...Object.entries(subregisters).map(([subregisterID, subregisterConfig]) => ({
|
|
223
|
+
isSelected: state.selectedFolderID === `by-subregister/${subregisterID}`,
|
|
224
|
+
id: subregisterID,
|
|
225
|
+
isExpanded: false,
|
|
226
|
+
icon: 'folder-close',
|
|
227
|
+
hasCaret: true,
|
|
228
|
+
label: subregisterConfig.title,
|
|
229
|
+
nodeData: { folderID: `by-subregister/${subregisterID}` },
|
|
230
|
+
secondaryLabel: jsx(MoreMenu, null,
|
|
231
|
+
jsx(SubregisterMenu, { cfg: subregisterConfig, itemClasses: itemClasses, onCreate: activeCRIsEditable && performOperation
|
|
232
|
+
? (clsID) => performOperation('generating new item', handleAdd)(clsID, subregisterID)
|
|
233
|
+
: undefined })),
|
|
234
|
+
}))]
|
|
235
|
+
: [])
|
|
236
|
+
];
|
|
237
|
+
if (subregisters) {
|
|
238
|
+
contents.push();
|
|
239
|
+
}
|
|
240
|
+
return (jsx(Tree, { css: css `flex: 1;`, className: className, onNodeClick: node => node.nodeData?.folderID
|
|
241
|
+
? dispatch({ type: 'select-folder', payload: { id: node.nodeData.folderID } })
|
|
242
|
+
: void 0, onNodeExpand: node => node.nodeData?.folderID
|
|
243
|
+
? dispatch({ type: 'enter-folder', payload: { id: node.nodeData.folderID } })
|
|
244
|
+
: void 0, onNodeDoubleClick: node => node.nodeData?.folderID
|
|
245
|
+
? dispatch({ type: 'enter-folder', payload: { id: node.nodeData.folderID } })
|
|
246
|
+
: void 0, contents: contents }));
|
|
247
|
+
}
|
|
248
|
+
};
|
|
249
|
+
const MoreMenu = function ({ children }) {
|
|
250
|
+
return (jsx(Popover2, { minimal: true, content: jsx(React.Fragment, null, children) },
|
|
251
|
+
jsx(Button, { icon: "more", small: true, minimal: true })));
|
|
252
|
+
};
|
|
253
|
+
const SubregisterMenu = function ({ cfg, itemClasses, onCreate }) {
|
|
254
|
+
return (jsx(Menu, null,
|
|
255
|
+
jsx(MenuDivider, { title: `Item classes in ${cfg.title}` }),
|
|
256
|
+
cfg.itemClasses.map(classID => jsx(MenuItem, { text: itemClasses[classID]?.meta?.title ?? classID, key: classID },
|
|
257
|
+
jsx(ItemClassMenu, { cfg: itemClasses[classID], onCreate: onCreate ? () => onCreate(classID) : undefined })))));
|
|
258
|
+
};
|
|
259
|
+
const ItemClassMenu = function ({ cfg, onCreate }) {
|
|
260
|
+
return (jsx(Menu, null,
|
|
261
|
+
jsx(MenuDivider, { title: "About this class" }),
|
|
262
|
+
jsx(MenuItem, { multiline: true, disabled: true, css: css `max-width: 400px`, text: cfg.meta.description }),
|
|
263
|
+
onCreate
|
|
264
|
+
? jsx(React.Fragment, null,
|
|
265
|
+
jsx(MenuDivider, { title: "Quick actions" }),
|
|
266
|
+
jsx(MenuItem, { text: "Propose new", intent: "primary", onClick: onCreate, icon: "plus" }))
|
|
267
|
+
: null));
|
|
268
|
+
};
|
|
269
|
+
const SearchResultList = makeSearchResultList(ListItem, (objPath) => ({
|
|
270
|
+
name: 'reg. item',
|
|
271
|
+
iconProps: {
|
|
272
|
+
icon: 'document',
|
|
273
|
+
title: objPath,
|
|
274
|
+
htmlTitle: `Icon for item at ${objPath}`
|
|
275
|
+
}
|
|
276
|
+
}));
|
|
277
|
+
export default Browse;
|
|
278
|
+
//# sourceMappingURL=index.js.map
|