@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.
Files changed (503) hide show
  1. package/LICENSE +21 -0
  2. package/README.adoc +35 -0
  3. package/compiled/common.js +2 -0
  4. package/compiled/index.js +21 -0
  5. package/compiled/migrations/initial.js +8 -0
  6. package/compiled/types/cr.js +131 -0
  7. package/compiled/types/index.js +8 -0
  8. package/compiled/types/item.js +22 -0
  9. package/compiled/types/proposal.js +21 -0
  10. package/compiled/types/register.js +25 -0
  11. package/compiled/types/registry.js +10 -0
  12. package/compiled/types/stakeholder.js +34 -0
  13. package/compiled/types/util.js +3 -0
  14. package/compiled/types/views.js +2 -0
  15. package/compiled/views/AnnotatedChange.js +57 -0
  16. package/compiled/views/BrowserCtx.js +19 -0
  17. package/compiled/views/FilterCriteria/CRITERIA_CONFIGURATION.js +110 -0
  18. package/compiled/views/FilterCriteria/criteriaGroupToQueryExpression.js +40 -0
  19. package/compiled/views/FilterCriteria/criteriaGroupToSummary.js +47 -0
  20. package/compiled/views/FilterCriteria/criteriaToNodes.js +89 -0
  21. package/compiled/views/FilterCriteria/index.js +75 -0
  22. package/compiled/views/FilterCriteria/models.js +28 -0
  23. package/compiled/views/FilterCriteria/mutateGroup.js +53 -0
  24. package/compiled/views/GenericRelatedItemView.js +147 -0
  25. package/compiled/views/RegisterStakeholder.js +19 -0
  26. package/compiled/views/RegisterVersion.js +20 -0
  27. package/compiled/views/SearchQuery.js +58 -0
  28. package/compiled/views/change-request/ChangeRequestContext.js +30 -0
  29. package/compiled/views/change-request/Proposals.js +185 -0
  30. package/compiled/views/change-request/objectChangeset.js +189 -0
  31. package/compiled/views/detail/ChangeRequest/Proposal.js +144 -0
  32. package/compiled/views/detail/ChangeRequest/index.js +140 -0
  33. package/compiled/views/detail/ChangeRequest/transitions.js +418 -0
  34. package/compiled/views/detail/CustomView/index.js +32 -0
  35. package/compiled/views/detail/RegisterHome/index.js +70 -0
  36. package/compiled/views/detail/RegisterItem/RelatedItems.d.ts +14 -0
  37. package/compiled/views/detail/RegisterItem/RelatedItems.js +28 -0
  38. package/compiled/views/detail/RegisterItem/RelatedItems.js.map +1 -0
  39. package/compiled/views/detail/RegisterItem/SupersedingItemMenu.js +27 -0
  40. package/compiled/views/detail/RegisterItem/index.js +277 -0
  41. package/compiled/views/detail/RegisterItem/index.js.map +1 -0
  42. package/compiled/views/detail/RegisterMeta/RegisterMetaForm.js +135 -0
  43. package/compiled/views/detail/RegisterMeta/index.js +61 -0
  44. package/compiled/views/detail/index.js +11 -0
  45. package/compiled/views/diffing/InlineDiff.js +20 -0
  46. package/compiled/views/diffing/StructuredDiff.js +38 -0
  47. package/compiled/views/hooks/useCustomView.js +14 -0
  48. package/compiled/views/hooks/useItemClassConfig.js +14 -0
  49. package/compiled/views/hooks/useItemRef.js +26 -0
  50. package/compiled/views/hooks/useSingleRegisterItemData.js +21 -0
  51. package/compiled/views/index.js +142 -0
  52. package/compiled/views/itemPathUtils.js +115 -0
  53. package/compiled/views/itemQueryUtils.js +42 -0
  54. package/compiled/views/protocolRegistry.js +24 -0
  55. package/compiled/views/sidebar/Browse/index.js +278 -0
  56. package/compiled/views/sidebar/Export/index.js +47 -0
  57. package/compiled/views/sidebar/ListItem.js +23 -0
  58. package/compiled/views/sidebar/Registration/index.js +114 -0
  59. package/compiled/views/sidebar/Search/index.js +100 -0
  60. package/compiled/views/sidebar/index.js +73 -0
  61. package/compiled/views/util.js +63 -0
  62. package/dependencies-local/extension-kit/SettingsContext.d.ts +8 -0
  63. package/dependencies-local/extension-kit/SettingsContext.js +19 -0
  64. package/dependencies-local/extension-kit/SettingsContext.js.map +1 -0
  65. package/dependencies-local/extension-kit/context.d.ts +11 -0
  66. package/dependencies-local/extension-kit/context.js +133 -0
  67. package/dependencies-local/extension-kit/context.js.map +1 -0
  68. package/dependencies-local/extension-kit/i18n/ContextProvider.d.ts +9 -0
  69. package/dependencies-local/extension-kit/i18n/ContextProvider.js +33 -0
  70. package/dependencies-local/extension-kit/i18n/ContextProvider.js.map +1 -0
  71. package/dependencies-local/extension-kit/i18n/context.d.ts +9 -0
  72. package/dependencies-local/extension-kit/i18n/context.js +23 -0
  73. package/dependencies-local/extension-kit/i18n/context.js.map +1 -0
  74. package/dependencies-local/extension-kit/i18n/types.d.ts +10 -0
  75. package/dependencies-local/extension-kit/i18n/types.js.map +1 -0
  76. package/dependencies-local/extension-kit/i18n/widgets.d.ts +16 -0
  77. package/dependencies-local/extension-kit/i18n/widgets.js +56 -0
  78. package/dependencies-local/extension-kit/i18n/widgets.js.map +1 -0
  79. package/dependencies-local/extension-kit/index.d.ts +3 -0
  80. package/dependencies-local/extension-kit/index.js +78 -0
  81. package/dependencies-local/extension-kit/index.js.map +1 -0
  82. package/dependencies-local/extension-kit/object-specs/index.d.ts +2 -0
  83. package/dependencies-local/extension-kit/object-specs/index.js +22 -0
  84. package/dependencies-local/extension-kit/object-specs/index.js.map +1 -0
  85. package/dependencies-local/extension-kit/object-specs/paneron-object.d.ts +6 -0
  86. package/dependencies-local/extension-kit/object-specs/paneron-object.js +161 -0
  87. package/dependencies-local/extension-kit/object-specs/paneron-object.js.map +1 -0
  88. package/dependencies-local/extension-kit/object-specs/ser-des.d.ts +31 -0
  89. package/dependencies-local/extension-kit/object-specs/ser-des.js +187 -0
  90. package/dependencies-local/extension-kit/object-specs/ser-des.js.map +1 -0
  91. package/dependencies-local/extension-kit/object-specs/yaml/custom-bool.d.ts +2 -0
  92. package/dependencies-local/extension-kit/object-specs/yaml/custom-bool.js +42 -0
  93. package/dependencies-local/extension-kit/object-specs/yaml/custom-bool.js.map +1 -0
  94. package/dependencies-local/extension-kit/object-specs/yaml/custom-timestamp.d.ts +3 -0
  95. package/dependencies-local/extension-kit/object-specs/yaml/custom-timestamp.js +110 -0
  96. package/dependencies-local/extension-kit/object-specs/yaml/custom-timestamp.js.map +1 -0
  97. package/dependencies-local/extension-kit/object-specs/yaml/index.d.ts +9 -0
  98. package/dependencies-local/extension-kit/object-specs/yaml/index.js +36 -0
  99. package/dependencies-local/extension-kit/object-specs/yaml/index.js.map +1 -0
  100. package/dependencies-local/extension-kit/object-specs/yaml/schema.d.ts +3 -0
  101. package/dependencies-local/extension-kit/object-specs/yaml/schema.js +26 -0
  102. package/dependencies-local/extension-kit/object-specs/yaml/schema.js.map +1 -0
  103. package/dependencies-local/extension-kit/package.json +53 -0
  104. package/dependencies-local/extension-kit/settings.d.ts +6 -0
  105. package/dependencies-local/extension-kit/settings.js +11 -0
  106. package/dependencies-local/extension-kit/settings.js.map +1 -0
  107. package/dependencies-local/extension-kit/types/binary-invocation.d.ts +31 -0
  108. package/dependencies-local/extension-kit/types/binary-invocation.js.map +1 -0
  109. package/dependencies-local/extension-kit/types/buffers.d.ts +17 -0
  110. package/dependencies-local/extension-kit/types/buffers.js +5 -0
  111. package/dependencies-local/extension-kit/types/buffers.js.map +1 -0
  112. package/dependencies-local/extension-kit/types/changes.d.ts +37 -0
  113. package/dependencies-local/extension-kit/types/changes.js +5 -0
  114. package/dependencies-local/extension-kit/types/changes.js.map +1 -0
  115. package/dependencies-local/extension-kit/types/data.d.ts +54 -0
  116. package/dependencies-local/extension-kit/types/data.js +5 -0
  117. package/dependencies-local/extension-kit/types/data.js.map +1 -0
  118. package/dependencies-local/extension-kit/types/dialogs.d.ts +15 -0
  119. package/dependencies-local/extension-kit/types/dialogs.js +5 -0
  120. package/dependencies-local/extension-kit/types/dialogs.js.map +1 -0
  121. package/dependencies-local/extension-kit/types/extension-maker.d.ts +17 -0
  122. package/dependencies-local/extension-kit/types/extension-maker.js +5 -0
  123. package/dependencies-local/extension-kit/types/extension-maker.js.map +1 -0
  124. package/dependencies-local/extension-kit/types/extension.d.ts +27 -0
  125. package/dependencies-local/extension-kit/types/extension.js +5 -0
  126. package/dependencies-local/extension-kit/types/extension.js.map +1 -0
  127. package/dependencies-local/extension-kit/types/index.d.ts +3 -0
  128. package/dependencies-local/extension-kit/types/index.js +41 -0
  129. package/dependencies-local/extension-kit/types/index.js.map +1 -0
  130. package/dependencies-local/extension-kit/types/indexes.d.ts +6 -0
  131. package/dependencies-local/extension-kit/types/indexes.js +15 -0
  132. package/dependencies-local/extension-kit/types/indexes.js.map +1 -0
  133. package/dependencies-local/extension-kit/types/migrations.d.ts +15 -0
  134. package/dependencies-local/extension-kit/types/migrations.js +5 -0
  135. package/dependencies-local/extension-kit/types/migrations.js.map +1 -0
  136. package/dependencies-local/extension-kit/types/object-spec.d.ts +108 -0
  137. package/dependencies-local/extension-kit/types/object-spec.js +23 -0
  138. package/dependencies-local/extension-kit/types/object-spec.js.map +1 -0
  139. package/dependencies-local/extension-kit/types/objects.d.ts +18 -0
  140. package/dependencies-local/extension-kit/types/objects.js +5 -0
  141. package/dependencies-local/extension-kit/types/objects.js.map +1 -0
  142. package/dependencies-local/extension-kit/types/progress.d.ts +5 -0
  143. package/dependencies-local/extension-kit/types/progress.js +5 -0
  144. package/dependencies-local/extension-kit/types/progress.js.map +1 -0
  145. package/dependencies-local/extension-kit/types/renderer.d.ts +495 -0
  146. package/dependencies-local/extension-kit/types/renderer.js +5 -0
  147. package/dependencies-local/extension-kit/types/renderer.js.map +1 -0
  148. package/dependencies-local/extension-kit/useDebounce.d.ts +2 -0
  149. package/dependencies-local/extension-kit/useDebounce.js +27 -0
  150. package/dependencies-local/extension-kit/useDebounce.js.map +1 -0
  151. package/dependencies-local/extension-kit/usePersistentStateReducer.d.ts +35 -0
  152. package/dependencies-local/extension-kit/usePersistentStateReducer.js +91 -0
  153. package/dependencies-local/extension-kit/usePersistentStateReducer.js.map +1 -0
  154. package/dependencies-local/extension-kit/useTimeTravelingPersistentStateReducer.d.ts +48 -0
  155. package/dependencies-local/extension-kit/useTimeTravelingPersistentStateReducer.js +116 -0
  156. package/dependencies-local/extension-kit/useTimeTravelingPersistentStateReducer.js.map +1 -0
  157. package/dependencies-local/extension-kit/util.d.ts +8 -0
  158. package/dependencies-local/extension-kit/util.js +21 -0
  159. package/dependencies-local/extension-kit/util.js.map +1 -0
  160. package/dependencies-local/extension-kit/widgets/ErrorState.d.ts +8 -0
  161. package/dependencies-local/extension-kit/widgets/ErrorState.js +44 -0
  162. package/dependencies-local/extension-kit/widgets/ErrorState.js.map +1 -0
  163. package/dependencies-local/extension-kit/widgets/Grid.d.ts +41 -0
  164. package/dependencies-local/extension-kit/widgets/Grid.js +213 -0
  165. package/dependencies-local/extension-kit/widgets/Grid.js.map +1 -0
  166. package/dependencies-local/extension-kit/widgets/HelpTooltip.d.ts +18 -0
  167. package/dependencies-local/extension-kit/widgets/HelpTooltip.js +84 -0
  168. package/dependencies-local/extension-kit/widgets/HelpTooltip.js.map +1 -0
  169. package/dependencies-local/extension-kit/widgets/ItemCount.d.ts +19 -0
  170. package/dependencies-local/extension-kit/widgets/ItemCount.js +78 -0
  171. package/dependencies-local/extension-kit/widgets/ItemCount.js.map +1 -0
  172. package/dependencies-local/extension-kit/widgets/List.d.ts +40 -0
  173. package/dependencies-local/extension-kit/widgets/List.js +191 -0
  174. package/dependencies-local/extension-kit/widgets/List.js.map +1 -0
  175. package/dependencies-local/extension-kit/widgets/Navbar.d.ts +20 -0
  176. package/dependencies-local/extension-kit/widgets/Navbar.js +75 -0
  177. package/dependencies-local/extension-kit/widgets/Navbar.js.map +1 -0
  178. package/dependencies-local/extension-kit/widgets/SearchResultList.d.ts +24 -0
  179. package/dependencies-local/extension-kit/widgets/SearchResultList.js +201 -0
  180. package/dependencies-local/extension-kit/widgets/SearchResultList.js.map +1 -0
  181. package/dependencies-local/extension-kit/widgets/Sidebar/Block.d.ts +21 -0
  182. package/dependencies-local/extension-kit/widgets/Sidebar/Block.js +94 -0
  183. package/dependencies-local/extension-kit/widgets/Sidebar/Block.js.map +1 -0
  184. package/dependencies-local/extension-kit/widgets/Sidebar/BlockStateButtonGroup.d.ts +6 -0
  185. package/dependencies-local/extension-kit/widgets/Sidebar/BlockStateButtonGroup.js +22 -0
  186. package/dependencies-local/extension-kit/widgets/Sidebar/BlockStateButtonGroup.js.map +1 -0
  187. package/dependencies-local/extension-kit/widgets/Sidebar/PropertyView.d.ts +28 -0
  188. package/dependencies-local/extension-kit/widgets/Sidebar/PropertyView.js +148 -0
  189. package/dependencies-local/extension-kit/widgets/Sidebar/PropertyView.js.map +1 -0
  190. package/dependencies-local/extension-kit/widgets/Sidebar/index.d.ts +27 -0
  191. package/dependencies-local/extension-kit/widgets/Sidebar/index.js +178 -0
  192. package/dependencies-local/extension-kit/widgets/Sidebar/index.js.map +1 -0
  193. package/dependencies-local/extension-kit/widgets/TabbedWorkspace/SuperSidebar.d.ts +13 -0
  194. package/dependencies-local/extension-kit/widgets/TabbedWorkspace/SuperSidebar.js +82 -0
  195. package/dependencies-local/extension-kit/widgets/TabbedWorkspace/SuperSidebar.js.map +1 -0
  196. package/dependencies-local/extension-kit/widgets/TabbedWorkspace/context.d.ts +10 -0
  197. package/dependencies-local/extension-kit/widgets/TabbedWorkspace/context.js +168 -0
  198. package/dependencies-local/extension-kit/widgets/TabbedWorkspace/context.js.map +1 -0
  199. package/dependencies-local/extension-kit/widgets/TabbedWorkspace/detail.d.ts +9 -0
  200. package/dependencies-local/extension-kit/widgets/TabbedWorkspace/detail.js +66 -0
  201. package/dependencies-local/extension-kit/widgets/TabbedWorkspace/detail.js.map +1 -0
  202. package/dependencies-local/extension-kit/widgets/TabbedWorkspace/index.d.ts +33 -0
  203. package/dependencies-local/extension-kit/widgets/TabbedWorkspace/index.js +204 -0
  204. package/dependencies-local/extension-kit/widgets/TabbedWorkspace/index.js.map +1 -0
  205. package/dependencies-local/extension-kit/widgets/TabbedWorkspace/types.d.ts +74 -0
  206. package/dependencies-local/extension-kit/widgets/TabbedWorkspace/types.js +5 -0
  207. package/dependencies-local/extension-kit/widgets/TabbedWorkspace/types.js.map +1 -0
  208. package/dependencies-local/extension-kit/widgets/TabbedWorkspace/util.d.ts +1 -0
  209. package/dependencies-local/extension-kit/widgets/TabbedWorkspace/util.js +14 -0
  210. package/dependencies-local/extension-kit/widgets/TabbedWorkspace/util.js.map +1 -0
  211. package/dependencies-local/extension-kit/widgets/Workspace.d.ts +38 -0
  212. package/dependencies-local/extension-kit/widgets/Workspace.js +99 -0
  213. package/dependencies-local/extension-kit/widgets/Workspace.js.map +1 -0
  214. package/dependencies-local/extension-kit/widgets/panels/PanelSeparator.d.ts +12 -0
  215. package/dependencies-local/extension-kit/widgets/panels/PanelSeparator.js +57 -0
  216. package/dependencies-local/extension-kit/widgets/panels/PanelSeparator.js.map +1 -0
  217. package/dependencies-local/extension-kit/widgets/panels/index.d.ts +28 -0
  218. package/dependencies-local/extension-kit/widgets/panels/index.js +169 -0
  219. package/dependencies-local/extension-kit/widgets/panels/index.js.map +1 -0
  220. package/dist/common.d.ts +1 -0
  221. package/dist/common.js.map +1 -0
  222. package/dist/index.d.ts +6 -0
  223. package/dist/index.js.map +1 -0
  224. package/dist/migrations/initial.d.ts +3 -0
  225. package/dist/migrations/initial.js.map +1 -0
  226. package/dist/package.json +56 -0
  227. package/dist/types/cr.d.ts +216 -0
  228. package/dist/types/cr.js.map +1 -0
  229. package/dist/types/index.d.ts +7 -0
  230. package/dist/types/index.js.map +1 -0
  231. package/dist/types/item.d.ts +59 -0
  232. package/dist/types/item.js.map +1 -0
  233. package/dist/types/proposal.d.ts +64 -0
  234. package/dist/types/proposal.js.map +1 -0
  235. package/dist/types/register.d.ts +18 -0
  236. package/dist/types/register.js.map +1 -0
  237. package/dist/types/registry.d.ts +15 -0
  238. package/dist/types/registry.js.map +1 -0
  239. package/dist/types/stakeholder.d.ts +58 -0
  240. package/dist/types/stakeholder.js.map +1 -0
  241. package/dist/types/util.d.ts +21 -0
  242. package/dist/types/util.js +5 -0
  243. package/dist/types/util.js.map +1 -0
  244. package/dist/types/views.d.ts +157 -0
  245. package/dist/types/views.js +5 -0
  246. package/dist/types/views.js.map +1 -0
  247. package/dist/views/AnnotatedChange.d.ts +7 -0
  248. package/dist/views/AnnotatedChange.js.map +1 -0
  249. package/dist/views/BrowserCtx.d.ts +73 -0
  250. package/dist/views/BrowserCtx.js.map +1 -0
  251. package/dist/views/FilterCriteria/CRITERIA_CONFIGURATION.d.ts +17 -0
  252. package/dist/views/FilterCriteria/CRITERIA_CONFIGURATION.js.map +1 -0
  253. package/dist/views/FilterCriteria/criteriaGroupToQueryExpression.d.ts +6 -0
  254. package/dist/views/FilterCriteria/criteriaGroupToQueryExpression.js.map +1 -0
  255. package/dist/views/FilterCriteria/criteriaGroupToSummary.d.ts +5 -0
  256. package/dist/views/FilterCriteria/criteriaGroupToSummary.js.map +1 -0
  257. package/dist/views/FilterCriteria/criteriaToNodes.d.ts +24 -0
  258. package/dist/views/FilterCriteria/criteriaToNodes.js.map +1 -0
  259. package/dist/views/FilterCriteria/index.d.ts +23 -0
  260. package/dist/views/FilterCriteria/index.js.map +1 -0
  261. package/dist/views/FilterCriteria/models.d.ts +68 -0
  262. package/dist/views/FilterCriteria/models.js.map +1 -0
  263. package/dist/views/FilterCriteria/mutateGroup.d.ts +17 -0
  264. package/dist/views/FilterCriteria/mutateGroup.js.map +1 -0
  265. package/dist/views/GenericRelatedItemView.d.ts +6 -0
  266. package/dist/views/GenericRelatedItemView.js.map +1 -0
  267. package/dist/views/RegisterStakeholder.d.ts +9 -0
  268. package/dist/views/RegisterStakeholder.js.map +1 -0
  269. package/dist/views/RegisterVersion.d.ts +9 -0
  270. package/dist/views/RegisterVersion.js.map +1 -0
  271. package/dist/views/SearchQuery.d.ts +13 -0
  272. package/dist/views/SearchQuery.js.map +1 -0
  273. package/dist/views/change-request/ChangeRequestContext.d.ts +20 -0
  274. package/dist/views/change-request/ChangeRequestContext.js.map +1 -0
  275. package/dist/views/change-request/Proposals.d.ts +21 -0
  276. package/dist/views/change-request/Proposals.js.map +1 -0
  277. package/dist/views/change-request/objectChangeset.d.ts +31 -0
  278. package/dist/views/change-request/objectChangeset.js.map +1 -0
  279. package/dist/views/detail/ChangeRequest/Proposal.d.ts +0 -0
  280. package/dist/views/detail/ChangeRequest/Proposal.js.map +1 -0
  281. package/dist/views/detail/ChangeRequest/index.d.ts +13 -0
  282. package/dist/views/detail/ChangeRequest/index.js.map +1 -0
  283. package/dist/views/detail/ChangeRequest/transitions.d.ts +28 -0
  284. package/dist/views/detail/ChangeRequest/transitions.js.map +1 -0
  285. package/dist/views/detail/CustomView/index.d.ts +13 -0
  286. package/dist/views/detail/CustomView/index.js.map +1 -0
  287. package/dist/views/detail/RegisterHome/index.d.ts +5 -0
  288. package/dist/views/detail/RegisterHome/index.js.map +1 -0
  289. package/dist/views/detail/RegisterItem/RelatedItems.d.ts +14 -0
  290. package/{views → dist/views}/detail/RegisterItem/RelatedItems.js +5 -5
  291. package/dist/views/detail/RegisterItem/RelatedItems.js.map +1 -0
  292. package/dist/views/detail/RegisterItem/SupersedingItemMenu.js.map +1 -0
  293. package/dist/views/detail/RegisterItem/index.d.ts +13 -0
  294. package/{views → dist/views}/detail/RegisterItem/index.js +3 -2
  295. package/dist/views/detail/RegisterItem/index.js.map +1 -0
  296. package/dist/views/detail/RegisterMeta/RegisterMetaForm.d.ts +10 -0
  297. package/dist/views/detail/RegisterMeta/RegisterMetaForm.js.map +1 -0
  298. package/dist/views/detail/RegisterMeta/index.d.ts +10 -0
  299. package/dist/views/detail/RegisterMeta/index.js.map +1 -0
  300. package/dist/views/detail/index.d.ts +1 -0
  301. package/dist/views/detail/index.js.map +1 -0
  302. package/dist/views/diffing/InlineDiff.d.ts +12 -0
  303. package/dist/views/diffing/InlineDiff.js.map +1 -0
  304. package/dist/views/diffing/StructuredDiff.d.ts +11 -0
  305. package/dist/views/diffing/StructuredDiff.js.map +1 -0
  306. package/dist/views/hooks/useCustomView.d.ts +3 -0
  307. package/dist/views/hooks/useCustomView.js.map +1 -0
  308. package/dist/views/hooks/useItemClassConfig.d.ts +3 -0
  309. package/dist/views/hooks/useItemClassConfig.js.map +1 -0
  310. package/dist/views/hooks/useItemRef.d.ts +3 -0
  311. package/dist/views/hooks/useItemRef.js.map +1 -0
  312. package/dist/views/hooks/useSingleRegisterItemData.d.ts +3 -0
  313. package/dist/views/hooks/useSingleRegisterItemData.js.map +1 -0
  314. package/dist/views/index.d.ts +7 -0
  315. package/dist/views/index.js.map +1 -0
  316. package/dist/views/itemPathUtils.d.ts +52 -0
  317. package/dist/views/itemPathUtils.js.map +1 -0
  318. package/dist/views/itemQueryUtils.d.ts +11 -0
  319. package/dist/views/itemQueryUtils.js.map +1 -0
  320. package/dist/views/protocolRegistry.d.ts +12 -0
  321. package/dist/views/protocolRegistry.js.map +1 -0
  322. package/dist/views/sidebar/Browse/index.d.ts +11 -0
  323. package/dist/views/sidebar/Browse/index.js.map +1 -0
  324. package/dist/views/sidebar/Export/index.d.ts +5 -0
  325. package/dist/views/sidebar/Export/index.js.map +1 -0
  326. package/dist/views/sidebar/ListItem.d.ts +10 -0
  327. package/dist/views/sidebar/ListItem.js.map +1 -0
  328. package/dist/views/sidebar/Registration/index.d.ts +5 -0
  329. package/dist/views/sidebar/Registration/index.js.map +1 -0
  330. package/dist/views/sidebar/Search/index.d.ts +18 -0
  331. package/dist/views/sidebar/Search/index.js.map +1 -0
  332. package/dist/views/sidebar/index.d.ts +6 -0
  333. package/dist/views/sidebar/index.js.map +1 -0
  334. package/dist/views/util.d.ts +36 -0
  335. package/dist/views/util.js.map +1 -0
  336. package/package.json +2 -1
  337. package/react-visual-diff.d.ts +9 -0
  338. package/views/detail/RegisterItem/RelatedItems.js.map +0 -1
  339. package/views/detail/RegisterItem/index.js.map +0 -1
  340. /package/{common.d.ts → compiled/common.d.ts} +0 -0
  341. /package/{common.js.map → compiled/common.js.map} +0 -0
  342. /package/{index.d.ts → compiled/index.d.ts} +0 -0
  343. /package/{index.js.map → compiled/index.js.map} +0 -0
  344. /package/{migrations → compiled/migrations}/initial.d.ts +0 -0
  345. /package/{migrations → compiled/migrations}/initial.js.map +0 -0
  346. /package/{types → compiled/types}/cr.d.ts +0 -0
  347. /package/{types → compiled/types}/cr.js.map +0 -0
  348. /package/{types → compiled/types}/index.d.ts +0 -0
  349. /package/{types → compiled/types}/index.js.map +0 -0
  350. /package/{types → compiled/types}/item.d.ts +0 -0
  351. /package/{types → compiled/types}/item.js.map +0 -0
  352. /package/{types → compiled/types}/proposal.d.ts +0 -0
  353. /package/{types → compiled/types}/proposal.js.map +0 -0
  354. /package/{types → compiled/types}/register.d.ts +0 -0
  355. /package/{types → compiled/types}/register.js.map +0 -0
  356. /package/{types → compiled/types}/registry.d.ts +0 -0
  357. /package/{types → compiled/types}/registry.js.map +0 -0
  358. /package/{types → compiled/types}/stakeholder.d.ts +0 -0
  359. /package/{types → compiled/types}/stakeholder.js.map +0 -0
  360. /package/{types → compiled/types}/util.d.ts +0 -0
  361. /package/{types → compiled/types}/util.js.map +0 -0
  362. /package/{types → compiled/types}/views.d.ts +0 -0
  363. /package/{types → compiled/types}/views.js.map +0 -0
  364. /package/{views → compiled/views}/AnnotatedChange.d.ts +0 -0
  365. /package/{views → compiled/views}/AnnotatedChange.js.map +0 -0
  366. /package/{views → compiled/views}/BrowserCtx.d.ts +0 -0
  367. /package/{views → compiled/views}/BrowserCtx.js.map +0 -0
  368. /package/{views → compiled/views}/FilterCriteria/CRITERIA_CONFIGURATION.d.ts +0 -0
  369. /package/{views → compiled/views}/FilterCriteria/CRITERIA_CONFIGURATION.js.map +0 -0
  370. /package/{views → compiled/views}/FilterCriteria/criteriaGroupToQueryExpression.d.ts +0 -0
  371. /package/{views → compiled/views}/FilterCriteria/criteriaGroupToQueryExpression.js.map +0 -0
  372. /package/{views → compiled/views}/FilterCriteria/criteriaGroupToSummary.d.ts +0 -0
  373. /package/{views → compiled/views}/FilterCriteria/criteriaGroupToSummary.js.map +0 -0
  374. /package/{views → compiled/views}/FilterCriteria/criteriaToNodes.d.ts +0 -0
  375. /package/{views → compiled/views}/FilterCriteria/criteriaToNodes.js.map +0 -0
  376. /package/{views → compiled/views}/FilterCriteria/index.d.ts +0 -0
  377. /package/{views → compiled/views}/FilterCriteria/index.js.map +0 -0
  378. /package/{views → compiled/views}/FilterCriteria/models.d.ts +0 -0
  379. /package/{views → compiled/views}/FilterCriteria/models.js.map +0 -0
  380. /package/{views → compiled/views}/FilterCriteria/mutateGroup.d.ts +0 -0
  381. /package/{views → compiled/views}/FilterCriteria/mutateGroup.js.map +0 -0
  382. /package/{views → compiled/views}/GenericRelatedItemView.d.ts +0 -0
  383. /package/{views → compiled/views}/GenericRelatedItemView.js.map +0 -0
  384. /package/{views → compiled/views}/RegisterStakeholder.d.ts +0 -0
  385. /package/{views → compiled/views}/RegisterStakeholder.js.map +0 -0
  386. /package/{views → compiled/views}/RegisterVersion.d.ts +0 -0
  387. /package/{views → compiled/views}/RegisterVersion.js.map +0 -0
  388. /package/{views → compiled/views}/SearchQuery.d.ts +0 -0
  389. /package/{views → compiled/views}/SearchQuery.js.map +0 -0
  390. /package/{views → compiled/views}/change-request/ChangeRequestContext.d.ts +0 -0
  391. /package/{views → compiled/views}/change-request/ChangeRequestContext.js.map +0 -0
  392. /package/{views → compiled/views}/change-request/Proposals.d.ts +0 -0
  393. /package/{views → compiled/views}/change-request/Proposals.js.map +0 -0
  394. /package/{views → compiled/views}/change-request/objectChangeset.d.ts +0 -0
  395. /package/{views → compiled/views}/change-request/objectChangeset.js.map +0 -0
  396. /package/{views → compiled/views}/detail/ChangeRequest/Proposal.d.ts +0 -0
  397. /package/{views → compiled/views}/detail/ChangeRequest/Proposal.js.map +0 -0
  398. /package/{views → compiled/views}/detail/ChangeRequest/index.d.ts +0 -0
  399. /package/{views → compiled/views}/detail/ChangeRequest/index.js.map +0 -0
  400. /package/{views → compiled/views}/detail/ChangeRequest/transitions.d.ts +0 -0
  401. /package/{views → compiled/views}/detail/ChangeRequest/transitions.js.map +0 -0
  402. /package/{views → compiled/views}/detail/CustomView/index.d.ts +0 -0
  403. /package/{views → compiled/views}/detail/CustomView/index.js.map +0 -0
  404. /package/{views → compiled/views}/detail/RegisterHome/index.d.ts +0 -0
  405. /package/{views → compiled/views}/detail/RegisterHome/index.js.map +0 -0
  406. /package/{views → compiled/views}/detail/RegisterItem/SupersedingItemMenu.d.ts +0 -0
  407. /package/{views → compiled/views}/detail/RegisterItem/SupersedingItemMenu.js.map +0 -0
  408. /package/{views → compiled/views}/detail/RegisterItem/index.d.ts +0 -0
  409. /package/{views → compiled/views}/detail/RegisterMeta/RegisterMetaForm.d.ts +0 -0
  410. /package/{views → compiled/views}/detail/RegisterMeta/RegisterMetaForm.js.map +0 -0
  411. /package/{views → compiled/views}/detail/RegisterMeta/index.d.ts +0 -0
  412. /package/{views → compiled/views}/detail/RegisterMeta/index.js.map +0 -0
  413. /package/{views → compiled/views}/detail/index.d.ts +0 -0
  414. /package/{views → compiled/views}/detail/index.js.map +0 -0
  415. /package/{views → compiled/views}/diffing/InlineDiff.d.ts +0 -0
  416. /package/{views → compiled/views}/diffing/InlineDiff.js.map +0 -0
  417. /package/{views → compiled/views}/diffing/StructuredDiff.d.ts +0 -0
  418. /package/{views → compiled/views}/diffing/StructuredDiff.js.map +0 -0
  419. /package/{views → compiled/views}/hooks/useCustomView.d.ts +0 -0
  420. /package/{views → compiled/views}/hooks/useCustomView.js.map +0 -0
  421. /package/{views → compiled/views}/hooks/useItemClassConfig.d.ts +0 -0
  422. /package/{views → compiled/views}/hooks/useItemClassConfig.js.map +0 -0
  423. /package/{views → compiled/views}/hooks/useItemRef.d.ts +0 -0
  424. /package/{views → compiled/views}/hooks/useItemRef.js.map +0 -0
  425. /package/{views → compiled/views}/hooks/useSingleRegisterItemData.d.ts +0 -0
  426. /package/{views → compiled/views}/hooks/useSingleRegisterItemData.js.map +0 -0
  427. /package/{views → compiled/views}/index.d.ts +0 -0
  428. /package/{views → compiled/views}/index.js.map +0 -0
  429. /package/{views → compiled/views}/itemPathUtils.d.ts +0 -0
  430. /package/{views → compiled/views}/itemPathUtils.js.map +0 -0
  431. /package/{views → compiled/views}/itemQueryUtils.d.ts +0 -0
  432. /package/{views → compiled/views}/itemQueryUtils.js.map +0 -0
  433. /package/{views → compiled/views}/protocolRegistry.d.ts +0 -0
  434. /package/{views → compiled/views}/protocolRegistry.js.map +0 -0
  435. /package/{views → compiled/views}/sidebar/Browse/index.d.ts +0 -0
  436. /package/{views → compiled/views}/sidebar/Browse/index.js.map +0 -0
  437. /package/{views → compiled/views}/sidebar/Export/index.d.ts +0 -0
  438. /package/{views → compiled/views}/sidebar/Export/index.js.map +0 -0
  439. /package/{views → compiled/views}/sidebar/ListItem.d.ts +0 -0
  440. /package/{views → compiled/views}/sidebar/ListItem.js.map +0 -0
  441. /package/{views → compiled/views}/sidebar/Registration/index.d.ts +0 -0
  442. /package/{views → compiled/views}/sidebar/Registration/index.js.map +0 -0
  443. /package/{views → compiled/views}/sidebar/Search/index.d.ts +0 -0
  444. /package/{views → compiled/views}/sidebar/Search/index.js.map +0 -0
  445. /package/{views → compiled/views}/sidebar/index.d.ts +0 -0
  446. /package/{views → compiled/views}/sidebar/index.js.map +0 -0
  447. /package/{views → compiled/views}/util.d.ts +0 -0
  448. /package/{views → compiled/views}/util.js.map +0 -0
  449. /package/{types/util.js → dependencies-local/extension-kit/i18n/types.js} +0 -0
  450. /package/{types/views.js → dependencies-local/extension-kit/types/binary-invocation.js} +0 -0
  451. /package/{common.js → dist/common.js} +0 -0
  452. /package/{index.js → dist/index.js} +0 -0
  453. /package/{migrations → dist/migrations}/initial.js +0 -0
  454. /package/{types → dist/types}/cr.js +0 -0
  455. /package/{types → dist/types}/index.js +0 -0
  456. /package/{types → dist/types}/item.js +0 -0
  457. /package/{types → dist/types}/proposal.js +0 -0
  458. /package/{types → dist/types}/register.js +0 -0
  459. /package/{types → dist/types}/registry.js +0 -0
  460. /package/{types → dist/types}/stakeholder.js +0 -0
  461. /package/{views → dist/views}/AnnotatedChange.js +0 -0
  462. /package/{views → dist/views}/BrowserCtx.js +0 -0
  463. /package/{views → dist/views}/FilterCriteria/CRITERIA_CONFIGURATION.js +0 -0
  464. /package/{views → dist/views}/FilterCriteria/criteriaGroupToQueryExpression.js +0 -0
  465. /package/{views → dist/views}/FilterCriteria/criteriaGroupToSummary.js +0 -0
  466. /package/{views → dist/views}/FilterCriteria/criteriaToNodes.js +0 -0
  467. /package/{views → dist/views}/FilterCriteria/index.js +0 -0
  468. /package/{views → dist/views}/FilterCriteria/models.js +0 -0
  469. /package/{views → dist/views}/FilterCriteria/mutateGroup.js +0 -0
  470. /package/{views → dist/views}/GenericRelatedItemView.js +0 -0
  471. /package/{views → dist/views}/RegisterStakeholder.js +0 -0
  472. /package/{views → dist/views}/RegisterVersion.js +0 -0
  473. /package/{views → dist/views}/SearchQuery.js +0 -0
  474. /package/{views → dist/views}/change-request/ChangeRequestContext.js +0 -0
  475. /package/{views → dist/views}/change-request/Proposals.js +0 -0
  476. /package/{views → dist/views}/change-request/objectChangeset.js +0 -0
  477. /package/{views → dist/views}/detail/ChangeRequest/Proposal.js +0 -0
  478. /package/{views → dist/views}/detail/ChangeRequest/index.js +0 -0
  479. /package/{views → dist/views}/detail/ChangeRequest/transitions.js +0 -0
  480. /package/{views → dist/views}/detail/CustomView/index.js +0 -0
  481. /package/{views → dist/views}/detail/RegisterHome/index.js +0 -0
  482. /package/{views/detail/RegisterItem/RelatedItems.d.ts → dist/views/detail/RegisterItem/SupersedingItemMenu.d.ts} +0 -0
  483. /package/{views → dist/views}/detail/RegisterItem/SupersedingItemMenu.js +0 -0
  484. /package/{views → dist/views}/detail/RegisterMeta/RegisterMetaForm.js +0 -0
  485. /package/{views → dist/views}/detail/RegisterMeta/index.js +0 -0
  486. /package/{views → dist/views}/detail/index.js +0 -0
  487. /package/{views → dist/views}/diffing/InlineDiff.js +0 -0
  488. /package/{views → dist/views}/diffing/StructuredDiff.js +0 -0
  489. /package/{views → dist/views}/hooks/useCustomView.js +0 -0
  490. /package/{views → dist/views}/hooks/useItemClassConfig.js +0 -0
  491. /package/{views → dist/views}/hooks/useItemRef.js +0 -0
  492. /package/{views → dist/views}/hooks/useSingleRegisterItemData.js +0 -0
  493. /package/{views → dist/views}/index.js +0 -0
  494. /package/{views → dist/views}/itemPathUtils.js +0 -0
  495. /package/{views → dist/views}/itemQueryUtils.js +0 -0
  496. /package/{views → dist/views}/protocolRegistry.js +0 -0
  497. /package/{views → dist/views}/sidebar/Browse/index.js +0 -0
  498. /package/{views → dist/views}/sidebar/Export/index.js +0 -0
  499. /package/{views → dist/views}/sidebar/ListItem.js +0 -0
  500. /package/{views → dist/views}/sidebar/Registration/index.js +0 -0
  501. /package/{views → dist/views}/sidebar/Search/index.js +0 -0
  502. /package/{views → dist/views}/sidebar/index.js +0 -0
  503. /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