@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,178 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
exports.default = void 0;
|
|
7
|
+
|
|
8
|
+
var _core = require("@blueprintjs/core");
|
|
9
|
+
|
|
10
|
+
var _react = require("@emotion/react");
|
|
11
|
+
|
|
12
|
+
var _react2 = _interopRequireWildcard(require("react"));
|
|
13
|
+
|
|
14
|
+
var _Block = _interopRequireDefault(require("./Block"));
|
|
15
|
+
|
|
16
|
+
var _BlockStateButtonGroup = _interopRequireDefault(require("./BlockStateButtonGroup"));
|
|
17
|
+
|
|
18
|
+
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
|
19
|
+
|
|
20
|
+
function _getRequireWildcardCache() { if (typeof WeakMap !== "function") return null; var cache = new WeakMap(); _getRequireWildcardCache = function () { return cache; }; return cache; }
|
|
21
|
+
|
|
22
|
+
function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } if (obj === null || typeof obj !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
|
|
23
|
+
|
|
24
|
+
/** @jsx jsx */
|
|
25
|
+
|
|
26
|
+
/** @jsxFrag React.Fragment */
|
|
27
|
+
function makeSidebar(persistentReducer) {
|
|
28
|
+
const Sidebar = function ({
|
|
29
|
+
title,
|
|
30
|
+
stateKey,
|
|
31
|
+
blocks,
|
|
32
|
+
representsSelection,
|
|
33
|
+
className
|
|
34
|
+
}) {
|
|
35
|
+
const withOtherBlocksCollapsed = (0, _react2.useCallback)(blockKey => {
|
|
36
|
+
return blocks.map(b => ({
|
|
37
|
+
[b.key]: b.nonCollapsible !== true && b.key !== blockKey ? false : true
|
|
38
|
+
})).reduce((prev, curr) => Object.assign(Object.assign({}, prev), curr));
|
|
39
|
+
}, [blocks]);
|
|
40
|
+
const [state, dispatch, stateLoaded] = persistentReducer(stateKey, undefined, undefined, (prevState, action) => {
|
|
41
|
+
switch (action.type) {
|
|
42
|
+
case 'expand-all':
|
|
43
|
+
return {
|
|
44
|
+
blockState: blocks.map(b => ({
|
|
45
|
+
[b.key]: true
|
|
46
|
+
})).reduce((prev, curr) => Object.assign(Object.assign({}, prev), curr))
|
|
47
|
+
};
|
|
48
|
+
|
|
49
|
+
case 'collapse-all':
|
|
50
|
+
return {
|
|
51
|
+
blockState: blocks.map(b => ({
|
|
52
|
+
[b.key]: b.nonCollapsible !== true ? false : true
|
|
53
|
+
})).reduce((prev, curr) => Object.assign(Object.assign({}, prev), curr))
|
|
54
|
+
};
|
|
55
|
+
|
|
56
|
+
case 'reset-state':
|
|
57
|
+
return {
|
|
58
|
+
blockState: blocks.map(b => ({
|
|
59
|
+
[b.key]: b.collapsedByDefault === true ? false : true
|
|
60
|
+
})).reduce((prev, curr) => Object.assign(Object.assign({}, prev), curr))
|
|
61
|
+
};
|
|
62
|
+
|
|
63
|
+
case 'expand-one':
|
|
64
|
+
return {
|
|
65
|
+
blockState: Object.assign(Object.assign({}, prevState.blockState), {
|
|
66
|
+
[action.payload.blockKey]: true
|
|
67
|
+
})
|
|
68
|
+
};
|
|
69
|
+
|
|
70
|
+
case 'collapse-one':
|
|
71
|
+
return {
|
|
72
|
+
blockState: Object.assign(Object.assign({}, prevState.blockState), {
|
|
73
|
+
[action.payload.blockKey]: false
|
|
74
|
+
})
|
|
75
|
+
};
|
|
76
|
+
|
|
77
|
+
case 'collapse-others':
|
|
78
|
+
return {
|
|
79
|
+
blockState: withOtherBlocksCollapsed(action.payload.blockKey)
|
|
80
|
+
};
|
|
81
|
+
|
|
82
|
+
default:
|
|
83
|
+
throw new Error("Unexpected sidebar state");
|
|
84
|
+
}
|
|
85
|
+
}, {
|
|
86
|
+
blockState: blocks.map(b => ({
|
|
87
|
+
[b.key]: b.collapsedByDefault === true ? false : true
|
|
88
|
+
})).reduce((prev, curr) => Object.assign(Object.assign({}, prev), curr))
|
|
89
|
+
}, null);
|
|
90
|
+
|
|
91
|
+
function hasOthersCollapsed(blockKey) {
|
|
92
|
+
// Using JSON.stringify for quick and dirty object structure comparison.
|
|
93
|
+
return JSON.stringify(withOtherBlocksCollapsed(blockKey)) === JSON.stringify(state.blockState);
|
|
94
|
+
}
|
|
95
|
+
|
|
96
|
+
const collapsibleBlocks = (0, _react2.useMemo)(() => blocks.filter(block => block.nonCollapsible !== true), [blocks]);
|
|
97
|
+
const hasCollapsibleBlocks = collapsibleBlocks.length > 0; // Single blocks are styled so that they occupy the entire sidebar.
|
|
98
|
+
|
|
99
|
+
const isSingleBlock = blocks.length === 1;
|
|
100
|
+
return (0, _react.jsx)("div", {
|
|
101
|
+
css: (0, _react.css)`display: flex; flex-flow: column nowrap;`,
|
|
102
|
+
className: `${_core.Classes.ELEVATION_1} ${className !== null && className !== void 0 ? className : ''}`
|
|
103
|
+
}, (0, _react.jsx)("div", {
|
|
104
|
+
css: (0, _react.css)`
|
|
105
|
+
height: 24px; background: ${representsSelection ? _core.Colors.BLUE2 : _core.Colors.GRAY1};
|
|
106
|
+
color: white; display: flex; flex-flow: row nowrap; align-items: center;
|
|
107
|
+
overflow: hidden;
|
|
108
|
+
font-variation-settings: 'GRAD' 500;
|
|
109
|
+
`
|
|
110
|
+
}, (0, _react.jsx)("div", {
|
|
111
|
+
css: (0, _react.css)`
|
|
112
|
+
flex: 1;
|
|
113
|
+
padding: 5px 10px;
|
|
114
|
+
font-weight: bold; white-space: nowrap;
|
|
115
|
+
overflow: hidden; text-overflow: ellipsis;
|
|
116
|
+
`
|
|
117
|
+
}, title), hasCollapsibleBlocks ? (0, _react.jsx)(_BlockStateButtonGroup.default, null, (0, _react.jsx)(_core.Button, {
|
|
118
|
+
small: true,
|
|
119
|
+
title: "Expand all blocks",
|
|
120
|
+
icon: "expand-all",
|
|
121
|
+
onClick: () => dispatch({
|
|
122
|
+
type: 'expand-all'
|
|
123
|
+
})
|
|
124
|
+
}), (0, _react.jsx)(_core.Button, {
|
|
125
|
+
small: true,
|
|
126
|
+
title: "Collapse all blocks",
|
|
127
|
+
icon: "collapse-all",
|
|
128
|
+
onClick: () => dispatch({
|
|
129
|
+
type: 'collapse-all'
|
|
130
|
+
})
|
|
131
|
+
}), (0, _react.jsx)(_core.Button, {
|
|
132
|
+
small: true,
|
|
133
|
+
title: "Restore default collapsed state",
|
|
134
|
+
icon: "reset",
|
|
135
|
+
onClick: () => dispatch({
|
|
136
|
+
type: 'reset-state'
|
|
137
|
+
})
|
|
138
|
+
})) : null), (0, _react.jsx)("div", {
|
|
139
|
+
css: (0, _react.css)`
|
|
140
|
+
flex: 1;
|
|
141
|
+
overflow-x: hidden;
|
|
142
|
+
overflow-y: auto;
|
|
143
|
+
background: ${_core.Colors.LIGHT_GRAY1};
|
|
144
|
+
position: relative;
|
|
145
|
+
`
|
|
146
|
+
}, stateLoaded ? (0, _react.jsx)(_react2.default.Fragment, null, blocks.map((b, idx) => (0, _react.jsx)(_Block.default, {
|
|
147
|
+
key: idx,
|
|
148
|
+
css: (0, _react.css)`${isSingleBlock ? 'position: absolute; inset: 0;' : ''}`,
|
|
149
|
+
expanded: isSingleBlock || b.nonCollapsible || state.blockState[b.key],
|
|
150
|
+
block: b,
|
|
151
|
+
onCollapseOthers: !isSingleBlock && collapsibleBlocks.filter(_b => _b.key !== b.key).length > 0 && !hasOthersCollapsed(b.key) ? () => dispatch({
|
|
152
|
+
type: 'collapse-others',
|
|
153
|
+
payload: {
|
|
154
|
+
blockKey: b.key
|
|
155
|
+
}
|
|
156
|
+
}) : undefined,
|
|
157
|
+
onCollapse: !isSingleBlock && b.nonCollapsible !== true && state.blockState[b.key] ? () => dispatch({
|
|
158
|
+
type: 'collapse-one',
|
|
159
|
+
payload: {
|
|
160
|
+
blockKey: b.key
|
|
161
|
+
}
|
|
162
|
+
}) : undefined,
|
|
163
|
+
onExpand: !state.blockState[b.key] && b.nonCollapsible !== true ? () => dispatch({
|
|
164
|
+
type: 'expand-one',
|
|
165
|
+
payload: {
|
|
166
|
+
blockKey: b.key
|
|
167
|
+
}
|
|
168
|
+
}) : undefined
|
|
169
|
+
})), (0, _react.jsx)("div", {
|
|
170
|
+
css: (0, _react.css)`font-size: 40px; text-align: center; color: ${_core.Colors.LIGHT_GRAY4}`
|
|
171
|
+
}, "\u2014 \u2767 \u2014")) : null));
|
|
172
|
+
};
|
|
173
|
+
|
|
174
|
+
return Sidebar;
|
|
175
|
+
}
|
|
176
|
+
|
|
177
|
+
var _default = makeSidebar;
|
|
178
|
+
exports.default = _default;
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/widgets/Sidebar/index.tsx"],"names":[],"mappings":"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","sourcesContent":["/** @jsx jsx */\n/** @jsxFrag React.Fragment */\n\nimport { Button, Classes, Colors } from '@blueprintjs/core';\nimport { jsx, css } from '@emotion/react';\nimport React, { useMemo, useCallback } from 'react';\nimport type { PersistentStateReducerHook } from '../../usePersistentStateReducer';\nimport SidebarBlock, { SidebarBlockConfig } from './Block';\nimport BlockStateButtonGroup from './BlockStateButtonGroup';\n\n\ninterface State {\n blockState: { [blockTitle: string]: boolean } \n}\n\ntype Action =\n | { type: 'expand-all' | 'collapse-all' | 'reset-state' }\n | { type: 'collapse-one' | 'expand-one' | 'collapse-others', payload: { blockKey: string } };\n\nexport interface SidebarProps {\n stateKey: string\n title: string | JSX.Element\n blocks: SidebarBlockConfig[]\n\n representsSelection?: boolean\n /* Indicate via styling that sidebar is displaying details for a selected item. */\n\n className?: string \n}\n\nfunction makeSidebar(\n persistentReducer: PersistentStateReducerHook<State, Action>,\n) {\n const Sidebar: React.FC<SidebarProps> =\n function ({ title, stateKey, blocks, representsSelection, className }) {\n const withOtherBlocksCollapsed = useCallback((blockKey: string) => {\n return blocks.\n map(b => ({ [b.key]: b.nonCollapsible !== true && b.key !== blockKey ? false : true })).\n reduce((prev, curr) => ({ ...prev, ...curr }));\n }, [blocks]);\n\n const [ state, dispatch, stateLoaded ] = persistentReducer(\n stateKey,\n undefined,\n undefined,\n (prevState, action) => {\n switch (action.type) {\n case 'expand-all':\n return { blockState: blocks.\n map(b => ({ [b.key]: true })).\n reduce((prev, curr) => ({ ...prev, ...curr })) };\n case 'collapse-all':\n return { blockState: blocks.\n map(b => ({ [b.key]: b.nonCollapsible !== true ? false : true })).\n reduce((prev, curr) => ({ ...prev, ...curr })) };\n case 'reset-state':\n return { blockState: blocks.\n map(b => ({ [b.key]: b.collapsedByDefault === true ? false : true })).\n reduce((prev, curr) => ({ ...prev, ...curr })) };\n case 'expand-one':\n return { blockState: { ...prevState.blockState, [action.payload.blockKey]: true } };\n case 'collapse-one':\n return { blockState: { ...prevState.blockState, [action.payload.blockKey]: false } };\n case 'collapse-others':\n return { blockState: withOtherBlocksCollapsed(action.payload.blockKey) };\n default:\n throw new Error(\"Unexpected sidebar state\");\n }\n },\n {\n blockState:\n blocks.\n map(b => ({ [b.key]: b.collapsedByDefault === true ? false : true })).\n reduce((prev, curr) => ({ ...prev, ...curr })),\n },\n null);\n\n function hasOthersCollapsed(blockKey: string): boolean {\n // Using JSON.stringify for quick and dirty object structure comparison.\n return JSON.stringify(withOtherBlocksCollapsed(blockKey)) === JSON.stringify(state.blockState);\n }\n\n const collapsibleBlocks = useMemo(\n () => blocks.filter(block => block.nonCollapsible !== true),\n [blocks]);\n\n const hasCollapsibleBlocks = collapsibleBlocks.length > 0;\n\n // Single blocks are styled so that they occupy the entire sidebar.\n const isSingleBlock = blocks.length === 1;\n\n return (\n <div\n css={css`display: flex; flex-flow: column nowrap;`}\n className={`${Classes.ELEVATION_1} ${className ?? ''}`}>\n <div css={css`\n height: 24px; background: ${representsSelection ? Colors.BLUE2 : Colors.GRAY1};\n color: white; display: flex; flex-flow: row nowrap; align-items: center;\n overflow: hidden;\n font-variation-settings: 'GRAD' 500;\n `}>\n\n <div css={css`\n flex: 1;\n padding: 5px 10px;\n font-weight: bold; white-space: nowrap;\n overflow: hidden; text-overflow: ellipsis;\n `}>\n {title}\n </div>\n\n {hasCollapsibleBlocks\n ? <BlockStateButtonGroup>\n <Button\n small\n title=\"Expand all blocks\"\n icon=\"expand-all\"\n onClick={() => dispatch({ type: 'expand-all' })}\n />\n <Button\n small\n title=\"Collapse all blocks\"\n icon=\"collapse-all\"\n onClick={() => dispatch({ type: 'collapse-all' })}\n />\n <Button\n small\n title=\"Restore default collapsed state\"\n icon=\"reset\"\n onClick={() => dispatch({ type: 'reset-state' })}\n />\n </BlockStateButtonGroup>\n : null}\n </div>\n <div css={css`\n flex: 1;\n overflow-x: hidden;\n overflow-y: auto;\n background: ${Colors.LIGHT_GRAY1};\n position: relative;\n `}>\n {stateLoaded\n ? <>\n {blocks.map((b, idx) =>\n <SidebarBlock\n key={idx}\n css={css`${isSingleBlock\n ? 'position: absolute; inset: 0;'\n : ''}`}\n expanded={isSingleBlock || b.nonCollapsible || state.blockState[b.key]}\n block={b}\n onCollapseOthers={\n !isSingleBlock &&\n collapsibleBlocks.filter(_b => _b.key !== b.key).length > 0 &&\n !hasOthersCollapsed(b.key)\n ? () => dispatch({ type: 'collapse-others', payload: { blockKey: b.key } })\n : undefined\n }\n onCollapse={!isSingleBlock && b.nonCollapsible !== true && state.blockState[b.key]\n ? () => dispatch({ type: 'collapse-one', payload: { blockKey: b.key } })\n : undefined}\n onExpand={!state.blockState[b.key] && b.nonCollapsible !== true\n ? () => dispatch({ type: 'expand-one', payload: { blockKey: b.key } })\n : undefined}\n />\n )}\n <div css={css`font-size: 40px; text-align: center; color: ${Colors.LIGHT_GRAY4}`}>— ❧ —</div>\n </>\n : null}\n </div>\n </div>\n );\n }\n\n return Sidebar;\n}\n\n\nexport default makeSidebar;\n"]}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
/** @jsx jsx */
|
|
2
|
+
/** @jsxFrag React.Fragment */
|
|
3
|
+
import React from 'react';
|
|
4
|
+
import { SuperSidebarConfig } from './types';
|
|
5
|
+
interface SuperSidebarProps<SidebarID extends string> {
|
|
6
|
+
config: SuperSidebarConfig<SidebarID>;
|
|
7
|
+
sidebarIDs: readonly SidebarID[];
|
|
8
|
+
selectedSidebarID: SidebarID;
|
|
9
|
+
onSelectSidebar?: (id: SidebarID) => void;
|
|
10
|
+
className?: string;
|
|
11
|
+
}
|
|
12
|
+
declare const SuperSidebar: React.FC<SuperSidebarProps<any>>;
|
|
13
|
+
export default SuperSidebar;
|
|
@@ -0,0 +1,82 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
exports.default = void 0;
|
|
7
|
+
|
|
8
|
+
var _react = _interopRequireWildcard(require("react"));
|
|
9
|
+
|
|
10
|
+
var _react2 = require("@emotion/react");
|
|
11
|
+
|
|
12
|
+
var _core = require("@blueprintjs/core");
|
|
13
|
+
|
|
14
|
+
var _styled = _interopRequireDefault(require("@emotion/styled"));
|
|
15
|
+
|
|
16
|
+
var _context = require("../../context");
|
|
17
|
+
|
|
18
|
+
var _Sidebar = _interopRequireDefault(require("../Sidebar"));
|
|
19
|
+
|
|
20
|
+
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
|
21
|
+
|
|
22
|
+
function _getRequireWildcardCache() { if (typeof WeakMap !== "function") return null; var cache = new WeakMap(); _getRequireWildcardCache = function () { return cache; }; return cache; }
|
|
23
|
+
|
|
24
|
+
function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } if (obj === null || typeof obj !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
|
|
25
|
+
|
|
26
|
+
/** @jsx jsx */
|
|
27
|
+
|
|
28
|
+
/** @jsxFrag React.Fragment */
|
|
29
|
+
const SuperSidebar = function ({
|
|
30
|
+
config,
|
|
31
|
+
sidebarIDs,
|
|
32
|
+
selectedSidebarID,
|
|
33
|
+
onSelectSidebar,
|
|
34
|
+
className
|
|
35
|
+
}) {
|
|
36
|
+
const {
|
|
37
|
+
usePersistentDatasetStateReducer
|
|
38
|
+
} = (0, _react.useContext)(_context.DatasetContext);
|
|
39
|
+
const sidebarEls = (0, _react.useMemo)(() => Object.entries(config).map(([sid, sconf]) => {
|
|
40
|
+
const Sidebar = (0, _Sidebar.default)(usePersistentDatasetStateReducer);
|
|
41
|
+
return {
|
|
42
|
+
[sid]: (0, _react2.jsx)(Sidebar, {
|
|
43
|
+
css: (0, _react2.css)`z-index: 5`,
|
|
44
|
+
title: sconf.title,
|
|
45
|
+
stateKey: sid,
|
|
46
|
+
blocks: sconf.blocks
|
|
47
|
+
})
|
|
48
|
+
};
|
|
49
|
+
}).reduce((prev, curr) => Object.assign(Object.assign({}, prev), curr)), []);
|
|
50
|
+
return (0, _react2.jsx)(_react.default.Fragment, null, (0, _react2.jsx)("div", {
|
|
51
|
+
css: (0, _react2.css)`
|
|
52
|
+
width: 250px; position: relative;
|
|
53
|
+
& > :first-child { position: absolute; inset: 0; }
|
|
54
|
+
background: ${_core.Colors.LIGHT_GRAY4};
|
|
55
|
+
`
|
|
56
|
+
}, sidebarEls[selectedSidebarID]), sidebarIDs.length > 1 ? (0, _react2.jsx)(_core.ButtonGroup, {
|
|
57
|
+
vertical: true,
|
|
58
|
+
className: className
|
|
59
|
+
}, sidebarIDs.map(sid => {
|
|
60
|
+
const Icon = config[sid].icon;
|
|
61
|
+
return (0, _react2.jsx)(SidebarButton, {
|
|
62
|
+
key: sid,
|
|
63
|
+
icon: (0, _react2.jsx)(Icon, null),
|
|
64
|
+
active: selectedSidebarID === sid,
|
|
65
|
+
onClick: onSelectSidebar ? () => onSelectSidebar(sid) : undefined,
|
|
66
|
+
disabled: !onSelectSidebar
|
|
67
|
+
});
|
|
68
|
+
})) : null);
|
|
69
|
+
};
|
|
70
|
+
|
|
71
|
+
var _default = SuperSidebar;
|
|
72
|
+
exports.default = _default;
|
|
73
|
+
const StyledSidebarButton = (0, _styled.default)(_core.Button)`
|
|
74
|
+
border-radius: 0 !important;
|
|
75
|
+
`;
|
|
76
|
+
|
|
77
|
+
const SidebarButton = function (props) {
|
|
78
|
+
return (0, _react2.jsx)(StyledSidebarButton, Object.assign({
|
|
79
|
+
minimal: true,
|
|
80
|
+
large: true
|
|
81
|
+
}, props));
|
|
82
|
+
};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"SuperSidebar.js","sourceRoot":"","sources":["../../../src/widgets/TabbedWorkspace/SuperSidebar.tsx"],"names":[],"mappings":"AAAA,eAAe;AACf,8BAA8B;AAE9B,OAAO,KAAK,EAAE,EAAE,UAAU,EAAE,OAAO,EAAE,MAAM,OAAO,CAAC;AACnD,OAAO,EAAE,GAAG,EAAE,GAAG,EAAE,MAAM,gBAAgB,CAAC;AAC1C,OAAO,EAAE,MAAM,EAAE,WAAW,EAAe,MAAM,EAAE,MAAM,mBAAmB,CAAC;AAC7E,OAAO,MAAM,MAAM,iBAAiB,CAAC;AAErC,OAAO,EAAE,cAAc,EAAE,MAAM,eAAe,CAAC;AAC/C,OAAO,WAAW,MAAM,YAAY,CAAC;AAWrC,MAAM,YAAY,GAClB,UAAU,EAAE,MAAM,EAAE,UAAU,EAAE,iBAAiB,EAAE,eAAe,EAAE,SAAS,EAAE;IAC7E,MAAM,EAAE,gCAAgC,EAAE,GAAG,UAAU,CAAC,cAAc,CAAC,CAAC;IAExE,MAAM,UAAU,GAAG,OAAO,CACxB,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC;QAC3B,GAAG,CAAC,CAAC,CAAC,GAAG,EAAE,KAAK,CAAC,EAAE,EAAE;QACnB,MAAM,OAAO,GAAG,WAAW,CAAC,gCAAgC,CAAC,CAAC;QAC9D,OAAO;YACL,CAAC,GAAG,CAAC,EACH,IAAC,OAAO,IACN,GAAG,EAAE,GAAG,CAAA,YAAY,EACpB,KAAK,EAAE,KAAK,CAAC,KAAK,EAClB,QAAQ,EAAE,GAAG,EACb,MAAM,EAAE,KAAK,CAAC,MAAM,GACpB;SACL,CAAC;IACJ,CAAC,CAAC;QACF,MAAM,CAAC,CAAC,IAAI,EAAE,IAAI,EAAE,EAAE,CAAC,iCAAM,IAAI,GAAK,IAAI,EAAG,CAAgC,CAAC,EAChF,EAAE,CAAC,CAAC;IAEN,OAAO,CACL;QACE,aAAK,GAAG,EAAE,GAAG,CAAA;;;wBAGK,MAAM,CAAC,WAAW;SACjC,IACA,UAAU,CAAC,iBAAiB,CAAC,CAC1B;QACL,UAAU,CAAC,MAAM,GAAG,CAAC;YACpB,CAAC,CAAC,IAAC,WAAW,IAAC,QAAQ,QAAC,SAAS,EAAE,SAAS,IACvC,UAAU,CAAC,GAAG,CAAC,GAAG,CAAC,EAAE;gBACpB,MAAM,IAAI,GAAG,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC;gBAC9B,OAAO,IAAC,aAAa,IACnB,GAAG,EAAE,GAAG,EACR,IAAI,EAAE,IAAC,IAAI,OAAG,EACd,MAAM,EAAE,iBAAiB,KAAK,GAAG,EACjC,OAAO,EAAE,eAAe,CAAC,CAAC,CAAC,GAAG,EAAE,CAAC,eAAe,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,SAAS,EACjE,QAAQ,EAAE,CAAC,eAAe,GAC1B,CAAA;YACJ,CAAC,CAAC,CACU;YAChB,CAAC,CAAC,IAAI,CACP,CACJ,CAAC;AACJ,CAAC,CAAC;AAEF,eAAe,YAAY,CAAC;AAE5B,MAAM,mBAAmB,GAAG,MAAM,CAAC,MAAM,CAAC,CAAA;;CAEzC,CAAC;AAEF,MAAM,aAAa,GAA0B,UAAU,KAAK;IAC1D,OAAO,IAAC,mBAAmB,kBAAC,OAAO,QAAC,KAAK,UAAK,KAAK,EAAI,CAAC;AAC1D,CAAC,CAAC","sourcesContent":["/** @jsx jsx */\n/** @jsxFrag React.Fragment */\n\nimport React, { useContext, useMemo } from 'react';\nimport { jsx, css } from '@emotion/react';\nimport { Button, ButtonGroup, ButtonProps, Colors } from '@blueprintjs/core';\nimport styled from '@emotion/styled';\n\nimport { DatasetContext } from '../../context';\nimport makeSidebar from '../Sidebar';\nimport { SuperSidebarConfig } from './types';\n\n\ninterface SuperSidebarProps<SidebarID extends string> {\n config: SuperSidebarConfig<SidebarID>\n sidebarIDs: readonly SidebarID[]\n selectedSidebarID: SidebarID\n onSelectSidebar?: (id: SidebarID) => void \n className?: string\n}\nconst SuperSidebar: React.FC<SuperSidebarProps<any>> =\nfunction ({ config, sidebarIDs, selectedSidebarID, onSelectSidebar, className }) {\n const { usePersistentDatasetStateReducer } = useContext(DatasetContext);\n\n const sidebarEls = useMemo(\n (() => Object.entries(config).\n map(([sid, sconf]) => {\n const Sidebar = makeSidebar(usePersistentDatasetStateReducer);\n return {\n [sid]:\n <Sidebar\n css={css`z-index: 5`}\n title={sconf.title}\n stateKey={sid}\n blocks={sconf.blocks}\n />\n };\n }).\n reduce((prev, curr) => ({ ...prev, ...curr })) as Record<string, JSX.Element>),\n []);\n\n return (\n <>\n <div css={css`\n width: 250px; position: relative;\n & > :first-child { position: absolute; inset: 0; }\n background: ${Colors.LIGHT_GRAY4};\n `}>\n {sidebarEls[selectedSidebarID]}\n </div>\n {sidebarIDs.length > 1\n ? <ButtonGroup vertical className={className}>\n {sidebarIDs.map(sid => {\n const Icon = config[sid].icon;\n return <SidebarButton\n key={sid}\n icon={<Icon />}\n active={selectedSidebarID === sid}\n onClick={onSelectSidebar ? () => onSelectSidebar(sid) : undefined}\n disabled={!onSelectSidebar}\n />\n })}\n </ButtonGroup>\n : null}\n </>\n );\n};\n\nexport default SuperSidebar;\n\nconst StyledSidebarButton = styled(Button)`\n border-radius: 0 !important;\n`;\n\nconst SidebarButton: React.FC<ButtonProps> = function (props) {\n return <StyledSidebarButton minimal large {...props} />;\n};\n"]}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
/** @jsx jsx */
|
|
2
|
+
import React from 'react';
|
|
3
|
+
import type { TabbedWorkspaceContext as TabbedWorkspaceContextSpec, ProtocolRegistry } from './types';
|
|
4
|
+
export declare const TabbedWorkspaceContext: React.Context<TabbedWorkspaceContextSpec<any, any>>;
|
|
5
|
+
export declare function makeContextProvider<Proto extends string, SidebarID extends string>(initialSidebarID: SidebarID, sidebarIDs: readonly SidebarID[], protocolConfiguration: ProtocolRegistry<Proto>): React.FC<TabbedWorkspaceContextProviderProps>;
|
|
6
|
+
export interface TabbedWorkspaceContextProviderProps {
|
|
7
|
+
stateKey: string;
|
|
8
|
+
onFocusedTabChange?: (newFocusedTabURI: string | undefined) => void;
|
|
9
|
+
}
|
|
10
|
+
export declare const SPECIAL_TAB_IDX: Record<'new', number>;
|
|
@@ -0,0 +1,168 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
exports.makeContextProvider = makeContextProvider;
|
|
7
|
+
exports.SPECIAL_TAB_IDX = exports.TabbedWorkspaceContext = void 0;
|
|
8
|
+
|
|
9
|
+
var _react = require("react");
|
|
10
|
+
|
|
11
|
+
var _react2 = require("@emotion/react");
|
|
12
|
+
|
|
13
|
+
var _context = require("../../context");
|
|
14
|
+
|
|
15
|
+
/** @jsx jsx */
|
|
16
|
+
const initialState = {
|
|
17
|
+
detailTabURIs: [],
|
|
18
|
+
focusedTabIdx: 0,
|
|
19
|
+
selectedSidebarID: ''
|
|
20
|
+
};
|
|
21
|
+
const TabbedWorkspaceContext = (0, _react.createContext)({
|
|
22
|
+
spawnTab: () => void 0,
|
|
23
|
+
protocolConfiguration: {},
|
|
24
|
+
state: initialState,
|
|
25
|
+
dispatch: () => void 0
|
|
26
|
+
});
|
|
27
|
+
exports.TabbedWorkspaceContext = TabbedWorkspaceContext;
|
|
28
|
+
|
|
29
|
+
function makeContextProvider(initialSidebarID, sidebarIDs, protocolConfiguration) {
|
|
30
|
+
const initialState = {
|
|
31
|
+
detailTabURIs: [],
|
|
32
|
+
focusedTabIdx: SPECIAL_TAB_IDX.new,
|
|
33
|
+
selectedSidebarID: initialSidebarID
|
|
34
|
+
};
|
|
35
|
+
|
|
36
|
+
function reducer(prevState, action) {
|
|
37
|
+
switch (action.type) {
|
|
38
|
+
case 'focus-sidebar':
|
|
39
|
+
return Object.assign(Object.assign({}, prevState), {
|
|
40
|
+
selectedSidebarID: action.payload.id
|
|
41
|
+
});
|
|
42
|
+
|
|
43
|
+
case 'spawn-tab':
|
|
44
|
+
{
|
|
45
|
+
const detailTabURIs = [...prevState.detailTabURIs];
|
|
46
|
+
const existingTabIdx = detailTabURIs.indexOf(action.payload.uri);
|
|
47
|
+
|
|
48
|
+
if (existingTabIdx >= 0) {
|
|
49
|
+
return Object.assign(Object.assign({}, prevState), {
|
|
50
|
+
focusedTabIdx: existingTabIdx
|
|
51
|
+
});
|
|
52
|
+
} else {
|
|
53
|
+
const idxToInsertAt = prevState.focusedTabIdx >= 0 ? prevState.focusedTabIdx + 1 : 0;
|
|
54
|
+
detailTabURIs.splice(idxToInsertAt, 0, action.payload.uri);
|
|
55
|
+
return Object.assign(Object.assign({}, prevState), {
|
|
56
|
+
detailTabURIs,
|
|
57
|
+
focusedTabIdx: idxToInsertAt
|
|
58
|
+
});
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
|
|
62
|
+
case 'focus-tab':
|
|
63
|
+
return Object.assign(Object.assign({}, prevState), {
|
|
64
|
+
focusedTabIdx: action.payload.idx
|
|
65
|
+
});
|
|
66
|
+
|
|
67
|
+
case 'navigate-focused-tab':
|
|
68
|
+
const existingTabIdx = prevState.detailTabURIs.indexOf(action.payload.uri);
|
|
69
|
+
|
|
70
|
+
if (existingTabIdx >= 0) {
|
|
71
|
+
return Object.assign(Object.assign({}, prevState), {
|
|
72
|
+
focusedTabIdx: existingTabIdx
|
|
73
|
+
});
|
|
74
|
+
} else if (prevState.detailTabURIs[prevState.focusedTabIdx]) {
|
|
75
|
+
const detailTabURIs = [...prevState.detailTabURIs];
|
|
76
|
+
detailTabURIs[prevState.focusedTabIdx] = action.payload.uri;
|
|
77
|
+
return Object.assign(Object.assign({}, prevState), {
|
|
78
|
+
detailTabURIs
|
|
79
|
+
});
|
|
80
|
+
} else {
|
|
81
|
+
return prevState;
|
|
82
|
+
}
|
|
83
|
+
|
|
84
|
+
case 'close-tab':
|
|
85
|
+
{
|
|
86
|
+
const detailTabURIs = [...prevState.detailTabURIs];
|
|
87
|
+
const closedFocused = action.payload.idx === prevState.focusedTabIdx;
|
|
88
|
+
detailTabURIs.splice(action.payload.idx, 1);
|
|
89
|
+
const focusedTabIdx = closedFocused ? detailTabURIs.length > 0 // If a focused tab is closed and there are any tabs left, switch to previous tab
|
|
90
|
+
? action.payload.idx > 0 ? action.payload.idx - 1 : 0 : SPECIAL_TAB_IDX.new : prevState.focusedTabIdx > action.payload.idx // If a tab before focused tab is closed, adjust focused index to maintain tab selection
|
|
91
|
+
? prevState.focusedTabIdx - 1 : prevState.focusedTabIdx;
|
|
92
|
+
return Object.assign(Object.assign({}, prevState), {
|
|
93
|
+
detailTabURIs,
|
|
94
|
+
focusedTabIdx
|
|
95
|
+
});
|
|
96
|
+
}
|
|
97
|
+
// TODO: Reducer knows how to move tabs, but we want to hook up a nice drag-and-drop mechanism.
|
|
98
|
+
|
|
99
|
+
case 'move-tab':
|
|
100
|
+
{
|
|
101
|
+
const detailTabURIs = [...prevState.detailTabURIs];
|
|
102
|
+
const tab = detailTabURIs.splice(action.payload.sourceIdx, 1)[0];
|
|
103
|
+
|
|
104
|
+
if (tab) {
|
|
105
|
+
detailTabURIs.splice(action.payload.destinationIdx, 0, tab);
|
|
106
|
+
}
|
|
107
|
+
|
|
108
|
+
return Object.assign(Object.assign({}, prevState), {
|
|
109
|
+
detailTabURIs
|
|
110
|
+
});
|
|
111
|
+
}
|
|
112
|
+
|
|
113
|
+
default:
|
|
114
|
+
throw new Error("Invalid action");
|
|
115
|
+
}
|
|
116
|
+
}
|
|
117
|
+
|
|
118
|
+
function validateState(state) {
|
|
119
|
+
var _a;
|
|
120
|
+
|
|
121
|
+
return ((_a = state.detailTabURIs) === null || _a === void 0 ? void 0 : _a.map) !== undefined && typeof state.selectedSidebarID === 'string' && sidebarIDs.indexOf(state.selectedSidebarID) >= 0;
|
|
122
|
+
}
|
|
123
|
+
|
|
124
|
+
const TabbedWorkspaceContextProvider = function ({
|
|
125
|
+
stateKey,
|
|
126
|
+
onFocusedTabChange,
|
|
127
|
+
children
|
|
128
|
+
}) {
|
|
129
|
+
const {
|
|
130
|
+
usePersistentDatasetStateReducer
|
|
131
|
+
} = (0, _react.useContext)(_context.DatasetContext);
|
|
132
|
+
const [state, dispatch] = usePersistentDatasetStateReducer(stateKey, undefined, validateState, reducer, initialState, null);
|
|
133
|
+
const focusedTabURI = state.focusedTabIdx >= 0 ? state.detailTabURIs[state.focusedTabIdx] : undefined;
|
|
134
|
+
(0, _react.useEffect)(() => {
|
|
135
|
+
if (onFocusedTabChange) {
|
|
136
|
+
onFocusedTabChange(focusedTabURI);
|
|
137
|
+
}
|
|
138
|
+
}, [focusedTabURI]);
|
|
139
|
+
const ctx = {
|
|
140
|
+
spawnTab: uri => dispatch({
|
|
141
|
+
type: 'spawn-tab',
|
|
142
|
+
payload: {
|
|
143
|
+
uri
|
|
144
|
+
}
|
|
145
|
+
}),
|
|
146
|
+
navigateFocusedTab: uri => dispatch({
|
|
147
|
+
type: 'navigate-focused-tab',
|
|
148
|
+
payload: {
|
|
149
|
+
uri
|
|
150
|
+
}
|
|
151
|
+
}),
|
|
152
|
+
protocolConfiguration,
|
|
153
|
+
focusedTabURI,
|
|
154
|
+
state,
|
|
155
|
+
dispatch
|
|
156
|
+
};
|
|
157
|
+
return (0, _react2.jsx)(TabbedWorkspaceContext.Provider, {
|
|
158
|
+
value: ctx
|
|
159
|
+
}, children);
|
|
160
|
+
};
|
|
161
|
+
|
|
162
|
+
return TabbedWorkspaceContextProvider;
|
|
163
|
+
}
|
|
164
|
+
|
|
165
|
+
const SPECIAL_TAB_IDX = {
|
|
166
|
+
new: -2
|
|
167
|
+
};
|
|
168
|
+
exports.SPECIAL_TAB_IDX = SPECIAL_TAB_IDX;
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"context.js","sourceRoot":"","sources":["../../../src/widgets/TabbedWorkspace/context.tsx"],"names":[],"mappings":"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","sourcesContent":["/** @jsx jsx */\n\nimport React, { createContext, useContext, useEffect } from 'react';\nimport { jsx } from '@emotion/react';\nimport { DatasetContext } from '../../context';\nimport { PersistentStateReducerHook } from '../../usePersistentStateReducer';\nimport type { TabbedWorkspaceContext as TabbedWorkspaceContextSpec, Action, ProtocolRegistry, State } from './types';\n\n\nconst initialState: State<''> = {\n detailTabURIs: [],\n focusedTabIdx: 0,\n selectedSidebarID: '',\n}\n\n\nexport const TabbedWorkspaceContext = createContext<TabbedWorkspaceContextSpec<any, any>>({\n spawnTab: () => void 0,\n protocolConfiguration: {},\n state: initialState,\n dispatch: () => void 0,\n});\n\n\nexport function makeContextProvider\n<Proto extends string, SidebarID extends string>(\n initialSidebarID: SidebarID,\n sidebarIDs: readonly SidebarID[],\n protocolConfiguration: ProtocolRegistry<Proto>,\n):\nReact.FC<TabbedWorkspaceContextProviderProps> {\n\n const initialState: State<SidebarID> = {\n detailTabURIs: [],\n focusedTabIdx: SPECIAL_TAB_IDX.new,\n selectedSidebarID: initialSidebarID,\n }\n\n function reducer(prevState: State<SidebarID>, action: Action<SidebarID>): State<SidebarID> {\n switch (action.type) {\n\n case 'focus-sidebar':\n return {\n ...prevState,\n selectedSidebarID: action.payload.id,\n };\n\n case 'spawn-tab': {\n const detailTabURIs = [ ...prevState.detailTabURIs ];\n const existingTabIdx = detailTabURIs.indexOf(action.payload.uri);\n if (existingTabIdx >= 0) {\n return {\n ...prevState,\n focusedTabIdx: existingTabIdx,\n };\n } else {\n const idxToInsertAt = prevState.focusedTabIdx >= 0\n ? prevState.focusedTabIdx + 1\n : 0;\n detailTabURIs.splice(idxToInsertAt, 0, action.payload.uri);\n return {\n ...prevState,\n detailTabURIs,\n focusedTabIdx: idxToInsertAt,\n };\n }\n }\n\n case 'focus-tab':\n return {\n ...prevState,\n focusedTabIdx: action.payload.idx,\n };\n\n case 'navigate-focused-tab':\n const existingTabIdx = prevState.detailTabURIs.indexOf(action.payload.uri);\n if (existingTabIdx >= 0) {\n return {\n ...prevState,\n focusedTabIdx: existingTabIdx,\n };\n } else if (prevState.detailTabURIs[prevState.focusedTabIdx]) {\n const detailTabURIs = [ ...prevState.detailTabURIs ];\n detailTabURIs[prevState.focusedTabIdx] = action.payload.uri;\n return {\n ...prevState,\n detailTabURIs,\n };\n } else {\n return prevState;\n }\n\n case 'close-tab': {\n const detailTabURIs = [ ...prevState.detailTabURIs ];\n const closedFocused = action.payload.idx === prevState.focusedTabIdx;\n\n detailTabURIs.splice(action.payload.idx, 1);\n\n const focusedTabIdx = closedFocused\n ? detailTabURIs.length > 0\n // If a focused tab is closed and there are any tabs left, switch to previous tab\n ? action.payload.idx > 0\n ? action.payload.idx - 1\n : 0\n : SPECIAL_TAB_IDX.new\n : prevState.focusedTabIdx > action.payload.idx\n // If a tab before focused tab is closed, adjust focused index to maintain tab selection\n ? prevState.focusedTabIdx - 1\n : prevState.focusedTabIdx;\n\n return {\n ...prevState,\n detailTabURIs,\n focusedTabIdx,\n };\n }\n\n // TODO: Reducer knows how to move tabs, but we want to hook up a nice drag-and-drop mechanism.\n case 'move-tab': {\n const detailTabURIs = [ ...prevState.detailTabURIs ];\n const tab = detailTabURIs.splice(action.payload.sourceIdx, 1)[0];\n if (tab) {\n detailTabURIs.splice(action.payload.destinationIdx, 0, tab);\n }\n return {\n ...prevState,\n detailTabURIs,\n };\n }\n\n default:\n throw new Error(\"Invalid action\");\n }\n }\n\n function validateState(state: Partial<State<any>>): state is State<any> {\n return (\n state.detailTabURIs?.map !== undefined &&\n typeof state.selectedSidebarID === 'string' &&\n sidebarIDs.indexOf(state.selectedSidebarID as any) >= 0\n );\n }\n\n const TabbedWorkspaceContextProvider:\n React.FC<TabbedWorkspaceContextProviderProps> =\n function ({ stateKey, onFocusedTabChange, children }) {\n\n const { usePersistentDatasetStateReducer } = useContext(DatasetContext);\n\n const [ state, dispatch ] =\n (usePersistentDatasetStateReducer as PersistentStateReducerHook<State<SidebarID>, Action<SidebarID>>)(\n stateKey,\n undefined,\n validateState,\n reducer,\n initialState,\n null);\n\n const focusedTabURI: string | undefined =\n state.focusedTabIdx >= 0\n ? state.detailTabURIs[state.focusedTabIdx]\n : undefined;\n\n useEffect(() => {\n if (onFocusedTabChange) {\n onFocusedTabChange(focusedTabURI);\n }\n }, [focusedTabURI]);\n\n const ctx: TabbedWorkspaceContextSpec<Proto, SidebarID> = {\n spawnTab: uri => dispatch({ type: 'spawn-tab', payload: { uri } }),\n navigateFocusedTab: uri => dispatch({ type: 'navigate-focused-tab', payload: { uri }}),\n protocolConfiguration,\n focusedTabURI,\n state,\n dispatch,\n };\n\n return (\n <TabbedWorkspaceContext.Provider value={ctx}>\n {children}\n </TabbedWorkspaceContext.Provider>\n );\n\n };\n\n return TabbedWorkspaceContextProvider;\n}\n\n\nexport interface TabbedWorkspaceContextProviderProps {\n stateKey: string\n onFocusedTabChange?: (newFocusedTabURI: string | undefined) => void\n}\n\n\nexport const SPECIAL_TAB_IDX: Record<'new', number> = {\n new: -2,\n};\n"]}
|
|
@@ -0,0 +1,66 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
exports.DetailTabTitle = exports.DetailTab = void 0;
|
|
7
|
+
|
|
8
|
+
var _react = _interopRequireWildcard(require("react"));
|
|
9
|
+
|
|
10
|
+
var _react2 = require("@emotion/react");
|
|
11
|
+
|
|
12
|
+
var _core = require("@blueprintjs/core");
|
|
13
|
+
|
|
14
|
+
var _context = require("./context");
|
|
15
|
+
|
|
16
|
+
function _getRequireWildcardCache() { if (typeof WeakMap !== "function") return null; var cache = new WeakMap(); _getRequireWildcardCache = function () { return cache; }; return cache; }
|
|
17
|
+
|
|
18
|
+
function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } if (obj === null || typeof obj !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
|
|
19
|
+
|
|
20
|
+
/** @jsx jsx */
|
|
21
|
+
|
|
22
|
+
/** @jsxFrag React.Fragment */
|
|
23
|
+
const DetailTab = function ({
|
|
24
|
+
uri
|
|
25
|
+
}) {
|
|
26
|
+
const {
|
|
27
|
+
protocolConfiguration
|
|
28
|
+
} = (0, _react.useContext)(_context.TabbedWorkspaceContext);
|
|
29
|
+
const [proto, _path] = uri.split(':');
|
|
30
|
+
const protoConf = protocolConfiguration[proto];
|
|
31
|
+
|
|
32
|
+
if (protoConf) {
|
|
33
|
+
const View = protoConf.main;
|
|
34
|
+
return (0, _react2.jsx)(View, {
|
|
35
|
+
uri: _path
|
|
36
|
+
});
|
|
37
|
+
} else {
|
|
38
|
+
return (0, _react2.jsx)(_core.NonIdealState, {
|
|
39
|
+
icon: "heart-broken",
|
|
40
|
+
description: `Unknown protocol ${proto}`
|
|
41
|
+
});
|
|
42
|
+
}
|
|
43
|
+
};
|
|
44
|
+
|
|
45
|
+
exports.DetailTab = DetailTab;
|
|
46
|
+
|
|
47
|
+
const DetailTabTitle = function ({
|
|
48
|
+
uri
|
|
49
|
+
}) {
|
|
50
|
+
const {
|
|
51
|
+
protocolConfiguration
|
|
52
|
+
} = (0, _react.useContext)(_context.TabbedWorkspaceContext);
|
|
53
|
+
const [proto, _path] = uri.split(':');
|
|
54
|
+
const protoConf = protocolConfiguration[proto];
|
|
55
|
+
|
|
56
|
+
if (protoConf) {
|
|
57
|
+
const View = protoConf.title;
|
|
58
|
+
return (0, _react2.jsx)(View, {
|
|
59
|
+
uri: _path
|
|
60
|
+
});
|
|
61
|
+
} else {
|
|
62
|
+
return (0, _react2.jsx)(_react.default.Fragment, null, uri);
|
|
63
|
+
}
|
|
64
|
+
};
|
|
65
|
+
|
|
66
|
+
exports.DetailTabTitle = DetailTabTitle;
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"detail.js","sourceRoot":"","sources":["../../../src/widgets/TabbedWorkspace/detail.tsx"],"names":[],"mappings":"AAAA,eAAe;AACf,8BAA8B;AAE9B,OAAO,KAAK,EAAE,EAAE,UAAU,EAAE,MAAM,OAAO,CAAC;AAC1C,OAAO,EAAE,GAAG,EAAE,MAAM,gBAAgB,CAAC;AACrC,OAAO,EAAE,aAAa,EAAE,MAAM,mBAAmB,CAAC;AAClD,OAAO,EAAE,sBAAsB,EAAE,MAAM,WAAW,CAAC;AAGnD,MAAM,CAAC,MAAM,SAAS,GAA8B,UAAU,EAAE,GAAG,EAAE;IACnE,MAAM,EAAE,qBAAqB,EAAE,GAAG,UAAU,CAAC,sBAAsB,CAAC,CAAC;IACrE,MAAM,CAAC,KAAK,EAAE,KAAK,CAAC,GAAG,GAAG,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;IACtC,MAAM,SAAS,GAAG,qBAAqB,CAAC,KAAK,CAAC,CAAC;IAC/C,IAAI,SAAS,EAAE;QACb,MAAM,IAAI,GAAG,SAAS,CAAC,IAAI,CAAC;QAC5B,OAAO,IAAC,IAAI,IAAC,GAAG,EAAE,KAAK,GAAI,CAAC;KAC7B;SAAM;QACL,OAAO,IAAC,aAAa,IAAC,IAAI,EAAC,cAAc,EAAC,WAAW,EAAE,oBAAoB,KAAK,EAAE,GAAI,CAAA;KACvF;AACH,CAAC,CAAC;AAGF,MAAM,CAAC,MAAM,cAAc,GAA8B,UAAU,EAAE,GAAG,EAAE;IACxE,MAAM,EAAE,qBAAqB,EAAE,GAAG,UAAU,CAAC,sBAAsB,CAAC,CAAC;IACrE,MAAM,CAAC,KAAK,EAAE,KAAK,CAAC,GAAG,GAAG,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;IACtC,MAAM,SAAS,GAAG,qBAAqB,CAAC,KAAK,CAAC,CAAC;IAC/C,IAAI,SAAS,EAAE;QACb,MAAM,IAAI,GAAG,SAAS,CAAC,KAAK,CAAC;QAC7B,OAAO,IAAC,IAAI,IAAC,GAAG,EAAE,KAAK,GAAI,CAAC;KAC7B;SAAM;QACL,OAAO,0BAAG,GAAG,CAAI,CAAC;KACnB;AACH,CAAC,CAAC","sourcesContent":["/** @jsx jsx */\n/** @jsxFrag React.Fragment */\n\nimport React, { useContext } from 'react';\nimport { jsx } from '@emotion/react';\nimport { NonIdealState } from '@blueprintjs/core';\nimport { TabbedWorkspaceContext } from './context';\n\n\nexport const DetailTab: React.FC<{ uri: string }> = function ({ uri }) {\n const { protocolConfiguration } = useContext(TabbedWorkspaceContext);\n const [proto, _path] = uri.split(':');\n const protoConf = protocolConfiguration[proto];\n if (protoConf) {\n const View = protoConf.main;\n return <View uri={_path} />;\n } else {\n return <NonIdealState icon=\"heart-broken\" description={`Unknown protocol ${proto}`} />\n }\n};\n\n\nexport const DetailTabTitle: React.FC<{ uri: string }> = function ({ uri }) {\n const { protocolConfiguration } = useContext(TabbedWorkspaceContext);\n const [proto, _path] = uri.split(':');\n const protoConf = protocolConfiguration[proto];\n if (protoConf) {\n const View = protoConf.title;\n return <View uri={_path} />;\n } else {\n return <>{uri}</>;\n }\n};\n\n"]}
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
/** @jsx jsx */
|
|
2
|
+
/** @jsxFrag React.Fragment */
|
|
3
|
+
import React from 'react';
|
|
4
|
+
import { WorkspaceProps } from '../Workspace';
|
|
5
|
+
import { SuperSidebarConfig } from './types';
|
|
6
|
+
/**
|
|
7
|
+
* Wraps Workspace, adding tabbed GUI features.
|
|
8
|
+
* Use inside TabbedWorkspaceContextProvider.
|
|
9
|
+
*/
|
|
10
|
+
export interface TabbedWorkspaceProps<SidebarID extends string> {
|
|
11
|
+
/**
|
|
12
|
+
* Configuration for individual sidebars, keyed by internal sidebar ID.
|
|
13
|
+
* If there is more than one sidebar, sidebar selector is shown.
|
|
14
|
+
*/
|
|
15
|
+
sidebarConfig: SuperSidebarConfig<SidebarID>;
|
|
16
|
+
/**
|
|
17
|
+
* Sidebar IDs as a list. This is used to order sidebars.
|
|
18
|
+
* TODO: Eliminate in favor of using weights or another way of ordering?
|
|
19
|
+
*/
|
|
20
|
+
sidebarIDs: readonly SidebarID[];
|
|
21
|
+
/**
|
|
22
|
+
* “Home” view shown by default when there are no tabs
|
|
23
|
+
* or when explicitly invoked by the user.
|
|
24
|
+
*/
|
|
25
|
+
newTabPrompt: JSX.Element;
|
|
26
|
+
/** Set global mode bar for the workspace. */
|
|
27
|
+
globalMode?: WorkspaceProps['globalMode'];
|
|
28
|
+
/** Set the status bar for the workspace. */
|
|
29
|
+
statusBar?: WorkspaceProps['statusBar'];
|
|
30
|
+
className?: string;
|
|
31
|
+
}
|
|
32
|
+
declare const TabbedWorkspace: React.VoidFunctionComponent<TabbedWorkspaceProps<any>>;
|
|
33
|
+
export default TabbedWorkspace;
|