@riboseinc/paneron-registry-kit 2.0.0-dev9 → 2.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (179) hide show
  1. package/common.d.ts +1 -1
  2. package/common.js +1 -1
  3. package/common.js.map +1 -1
  4. package/index.d.ts +3 -3
  5. package/index.js +3 -3
  6. package/index.js.map +1 -1
  7. package/package.json +26 -19
  8. package/types/cr.d.ts +216 -0
  9. package/types/cr.js +175 -0
  10. package/types/cr.js.map +1 -0
  11. package/types/index.d.ts +1 -0
  12. package/types/index.js +19 -0
  13. package/types/index.js.map +1 -1
  14. package/types/item.d.ts +13 -3
  15. package/types/item.js +11 -1
  16. package/types/item.js.map +1 -1
  17. package/types/proposal.d.ts +31 -14
  18. package/types/proposal.js +1 -1
  19. package/types/proposal.js.map +1 -1
  20. package/types/register.d.ts +6 -5
  21. package/types/register.js +19 -1
  22. package/types/register.js.map +1 -1
  23. package/types/registry.d.ts +8 -3
  24. package/types/registry.js +8 -1
  25. package/types/registry.js.map +1 -1
  26. package/types/stakeholder.d.ts +40 -16
  27. package/types/stakeholder.js +47 -3
  28. package/types/stakeholder.js.map +1 -1
  29. package/types/views.d.ts +98 -24
  30. package/types/views.js.map +1 -1
  31. package/views/AnnotatedChange.d.ts +7 -0
  32. package/views/AnnotatedChange.js +91 -0
  33. package/views/AnnotatedChange.js.map +1 -0
  34. package/views/BrowserCtx.d.ts +66 -2
  35. package/views/BrowserCtx.js +13 -2
  36. package/views/BrowserCtx.js.map +1 -1
  37. package/views/FilterCriteria/CRITERIA_CONFIGURATION.d.ts +13 -1
  38. package/views/FilterCriteria/CRITERIA_CONFIGURATION.js +178 -85
  39. package/views/FilterCriteria/CRITERIA_CONFIGURATION.js.map +1 -1
  40. package/views/FilterCriteria/criteriaGroupToQueryExpression.d.ts +4 -0
  41. package/views/FilterCriteria/criteriaGroupToQueryExpression.js +10 -3
  42. package/views/FilterCriteria/criteriaGroupToQueryExpression.js.map +1 -1
  43. package/views/FilterCriteria/criteriaGroupToSummary.js +7 -7
  44. package/views/FilterCriteria/criteriaGroupToSummary.js.map +1 -1
  45. package/views/FilterCriteria/criteriaToNodes.d.ts +9 -0
  46. package/views/FilterCriteria/criteriaToNodes.js +42 -28
  47. package/views/FilterCriteria/criteriaToNodes.js.map +1 -1
  48. package/views/FilterCriteria/index.d.ts +1 -0
  49. package/views/FilterCriteria/index.js +29 -21
  50. package/views/FilterCriteria/index.js.map +1 -1
  51. package/views/FilterCriteria/models.d.ts +29 -2
  52. package/views/FilterCriteria/models.js +17 -10
  53. package/views/FilterCriteria/models.js.map +1 -1
  54. package/views/FilterCriteria/mutateGroup.d.ts +4 -1
  55. package/views/FilterCriteria/mutateGroup.js +4 -3
  56. package/views/FilterCriteria/mutateGroup.js.map +1 -1
  57. package/views/GenericRelatedItemView.d.ts +1 -1
  58. package/views/GenericRelatedItemView.js +142 -102
  59. package/views/GenericRelatedItemView.js.map +1 -1
  60. package/views/RegisterStakeholder.d.ts +9 -0
  61. package/views/RegisterStakeholder.js +40 -0
  62. package/views/RegisterStakeholder.js.map +1 -0
  63. package/views/RegisterVersion.d.ts +9 -0
  64. package/views/RegisterVersion.js +41 -0
  65. package/views/RegisterVersion.js.map +1 -0
  66. package/views/SearchQuery.d.ts +13 -0
  67. package/views/SearchQuery.js +137 -0
  68. package/views/SearchQuery.js.map +1 -0
  69. package/views/change-request/ChangeRequestContext.d.ts +20 -0
  70. package/views/change-request/ChangeRequestContext.js +56 -0
  71. package/views/change-request/ChangeRequestContext.js.map +1 -0
  72. package/views/change-request/Proposals.d.ts +21 -0
  73. package/views/change-request/Proposals.js +331 -0
  74. package/views/change-request/Proposals.js.map +1 -0
  75. package/views/change-request/objectChangeset.d.ts +31 -0
  76. package/views/change-request/objectChangeset.js +229 -0
  77. package/views/change-request/objectChangeset.js.map +1 -0
  78. package/views/detail/ChangeRequest/Proposal.d.ts +0 -0
  79. package/views/detail/ChangeRequest/Proposal.js +142 -0
  80. package/views/detail/ChangeRequest/Proposal.js.map +1 -0
  81. package/views/detail/ChangeRequest/index.d.ts +13 -0
  82. package/views/detail/ChangeRequest/index.js +207 -0
  83. package/views/detail/ChangeRequest/index.js.map +1 -0
  84. package/views/detail/ChangeRequest/transitions.d.ts +28 -0
  85. package/views/detail/ChangeRequest/transitions.js +530 -0
  86. package/views/detail/ChangeRequest/transitions.js.map +1 -0
  87. package/views/detail/CustomView/index.d.ts +13 -0
  88. package/views/detail/CustomView/index.js +68 -0
  89. package/views/detail/CustomView/index.js.map +1 -0
  90. package/views/detail/RegisterHome/index.d.ts +5 -0
  91. package/views/detail/RegisterHome/index.js +128 -0
  92. package/views/detail/RegisterHome/index.js.map +1 -0
  93. package/views/detail/RegisterItem/RelatedItems.d.ts +13 -0
  94. package/views/detail/RegisterItem/RelatedItems.js +61 -0
  95. package/views/detail/RegisterItem/RelatedItems.js.map +1 -0
  96. package/views/detail/RegisterItem/SupersedingItemMenu.d.ts +13 -0
  97. package/views/detail/RegisterItem/SupersedingItemMenu.js +56 -0
  98. package/views/detail/RegisterItem/SupersedingItemMenu.js.map +1 -0
  99. package/views/detail/RegisterItem/index.d.ts +13 -0
  100. package/views/detail/RegisterItem/index.js +356 -0
  101. package/views/detail/RegisterItem/index.js.map +1 -0
  102. package/views/detail/RegisterMeta/RegisterMetaForm.d.ts +10 -0
  103. package/views/detail/RegisterMeta/RegisterMetaForm.js +331 -0
  104. package/views/detail/RegisterMeta/RegisterMetaForm.js.map +1 -0
  105. package/views/detail/RegisterMeta/index.d.ts +10 -0
  106. package/views/detail/RegisterMeta/index.js +111 -0
  107. package/views/detail/RegisterMeta/index.js.map +1 -0
  108. package/views/detail/index.d.ts +1 -0
  109. package/views/detail/index.js +24 -0
  110. package/views/detail/index.js.map +1 -0
  111. package/views/diffing/InlineDiff.d.ts +12 -0
  112. package/views/diffing/InlineDiff.js +58 -0
  113. package/views/diffing/InlineDiff.js.map +1 -0
  114. package/views/diffing/StructuredDiff.d.ts +11 -0
  115. package/views/diffing/StructuredDiff.js +65 -0
  116. package/views/diffing/StructuredDiff.js.map +1 -0
  117. package/views/hooks/useCustomView.d.ts +3 -0
  118. package/views/hooks/useCustomView.js +24 -0
  119. package/views/hooks/useCustomView.js.map +1 -0
  120. package/views/hooks/useItemClassConfig.d.ts +3 -0
  121. package/views/hooks/useItemClassConfig.js +24 -0
  122. package/views/hooks/useItemClassConfig.js.map +1 -0
  123. package/views/hooks/useItemRef.d.ts +3 -0
  124. package/views/hooks/useItemRef.js +39 -0
  125. package/views/hooks/useItemRef.js.map +1 -0
  126. package/views/hooks/useSingleRegisterItemData.d.ts +3 -0
  127. package/views/hooks/useSingleRegisterItemData.js +32 -0
  128. package/views/hooks/useSingleRegisterItemData.js.map +1 -0
  129. package/views/index.d.ts +2 -2
  130. package/views/index.js +161 -130
  131. package/views/index.js.map +1 -1
  132. package/views/itemPathUtils.d.ts +45 -2
  133. package/views/itemPathUtils.js +101 -14
  134. package/views/itemPathUtils.js.map +1 -1
  135. package/views/itemQueryUtils.d.ts +11 -0
  136. package/views/itemQueryUtils.js +48 -0
  137. package/views/itemQueryUtils.js.map +1 -0
  138. package/views/protocolRegistry.d.ts +12 -0
  139. package/views/protocolRegistry.js +42 -0
  140. package/views/protocolRegistry.js.map +1 -0
  141. package/views/sidebar/Browse/index.d.ts +11 -0
  142. package/views/sidebar/Browse/index.js +453 -0
  143. package/views/sidebar/Browse/index.js.map +1 -0
  144. package/views/sidebar/Export/index.d.ts +5 -0
  145. package/views/sidebar/Export/index.js +94 -0
  146. package/views/sidebar/Export/index.js.map +1 -0
  147. package/views/sidebar/ListItem.d.ts +10 -0
  148. package/views/sidebar/ListItem.js +43 -0
  149. package/views/sidebar/ListItem.js.map +1 -0
  150. package/views/sidebar/Registration/index.d.ts +5 -0
  151. package/views/sidebar/Registration/index.js +163 -0
  152. package/views/sidebar/Registration/index.js.map +1 -0
  153. package/views/sidebar/Search/index.d.ts +18 -0
  154. package/views/sidebar/Search/index.js +177 -0
  155. package/views/sidebar/Search/index.js.map +1 -0
  156. package/views/sidebar/index.d.ts +6 -0
  157. package/views/sidebar/index.js +104 -0
  158. package/views/sidebar/index.js.map +1 -0
  159. package/views/util.d.ts +29 -5
  160. package/views/util.js +92 -6
  161. package/views/util.js.map +1 -1
  162. package/views/ChangeRequest.d.ts +0 -12
  163. package/views/ChangeRequest.js +0 -689
  164. package/views/ChangeRequest.js.map +0 -1
  165. package/views/ItemBrowser.d.ts +0 -12
  166. package/views/ItemBrowser.js +0 -258
  167. package/views/ItemBrowser.js.map +0 -1
  168. package/views/ItemDetails.d.ts +0 -14
  169. package/views/ItemDetails.js +0 -128
  170. package/views/ItemDetails.js.map +0 -1
  171. package/views/MainView.d.ts +0 -8
  172. package/views/MainView.js +0 -34
  173. package/views/MainView.js.map +0 -1
  174. package/views/RegisterInformation.d.ts +0 -7
  175. package/views/RegisterInformation.js +0 -264
  176. package/views/RegisterInformation.js.map +0 -1
  177. package/views/RegisterItemGrid.d.ts +0 -25
  178. package/views/RegisterItemGrid.js +0 -276
  179. package/views/RegisterItemGrid.js.map +0 -1
@@ -0,0 +1,68 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.default = void 0;
7
+
8
+ var _react = _interopRequireDefault(require("react"));
9
+
10
+ var _react2 = require("@emotion/react");
11
+
12
+ var _core = require("@blueprintjs/core");
13
+
14
+ var _useCustomView = _interopRequireDefault(require("../../hooks/useCustomView"));
15
+
16
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
17
+
18
+ /** @jsx jsx */
19
+
20
+ /** @jsxFrag React.Fragment */
21
+ const CustomViewMain = function ({
22
+ uri
23
+ }) {
24
+ const [viewID, ...pathComponents] = uri.split('/');
25
+ const {
26
+ value: view
27
+ } = (0, _useCustomView.default)(viewID);
28
+
29
+ const fallbackView = () => (0, _react2.jsx)(_core.NonIdealState, {
30
+ icon: "heart-broken",
31
+ title: "Unable to show this view",
32
+ description: `Custom view ${uri} cannot be displayed (not found in registry configuration)`
33
+ });
34
+
35
+ const View = (view === null || view === void 0 ? void 0 : view.view) ?? fallbackView;
36
+ return (0, _react2.jsx)(View, {
37
+ path: pathComponents.join('/')
38
+ });
39
+ };
40
+
41
+ const CustomViewTitle = function ({
42
+ uri
43
+ }) {
44
+ const {
45
+ value: view
46
+ } = (0, _useCustomView.default)(uri);
47
+ return (0, _react2.jsx)(_react.default.Fragment, null, (view === null || view === void 0 ? void 0 : view.label) ?? 'unknown view');
48
+ };
49
+
50
+ var _default = {
51
+ main: CustomViewMain,
52
+ title: CustomViewTitle,
53
+ plainTitle: async () => "custom view"
54
+ }; // function useCRData(id: string | undefined): ValueHook<ChangeRequest | undefined> {
55
+ // const { useObjectData } = useContext(DatasetContext);
56
+ // const objectPath = `change-requests/${id ?? 'NONEXISTENT_CR_ID'}.yaml`;
57
+ // const crDataResp = useObjectData({ objectPaths: [objectPath] });
58
+ // const crData = crDataResp.value.data?.[objectPath] as ChangeRequest | null;
59
+ // return {
60
+ // value: crData ?? undefined,
61
+ // isUpdating: crDataResp.isUpdating,
62
+ // errors: crDataResp.errors,
63
+ // refresh: crDataResp.refresh,
64
+ // _reqCounter: crDataResp._reqCounter,
65
+ // };
66
+ // }
67
+
68
+ exports.default = _default;
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/views/detail/CustomView/index.tsx"],"names":[],"mappings":"AAAA,eAAe;AACf,8BAA8B;AAE9B,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,EAAE,GAAG,EAAE,MAAM,gBAAgB,CAAC;AACrC,OAAO,EAAE,aAAa,EAAE,MAAM,mBAAmB,CAAC;AAClD,OAAO,aAAa,MAAM,2BAA2B,CAAC;AAGtD,MAAM,cAAc,GAA8B,UAAU,EAAE,GAAG,EAAE;IACjE,MAAM,CAAC,MAAM,EAAE,GAAG,cAAc,CAAC,GAAG,GAAG,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;IACnD,MAAM,EAAE,KAAK,EAAE,IAAI,EAAE,GAAG,aAAa,CAAC,MAAM,CAAC,CAAC;IAC9C,MAAM,YAAY,GAAG,CAAC,GAAG,EAAE,CAAC,IAAC,aAAa,IACxC,IAAI,EAAC,cAAc,EACnB,KAAK,EAAC,0BAA0B,EAChC,WAAW,EAAE,eAAe,GAAG,4DAA4D,GAC3F,CAAC,CAAC;IACJ,MAAM,IAAI,GAAG,IAAI,EAAE,IAAI,IAAI,YAAY,CAAC;IACxC,OAAO,IAAC,IAAI,IAAC,IAAI,EAAE,cAAc,CAAC,IAAI,CAAC,GAAG,CAAC,GAAI,CAAC;AAClD,CAAC,CAAC;AAGF,MAAM,eAAe,GAA8B,UAAU,EAAE,GAAG,EAAE;IAClE,MAAM,EAAE,KAAK,EAAE,IAAI,EAAE,GAAG,aAAa,CAAC,GAAG,CAAC,CAAC;IAC3C,OAAO,0BAAG,IAAI,EAAE,KAAK,IAAI,cAAc,CAAI,CAAC;AAC9C,CAAC,CAAA;AAGD,eAAe,EAAE,IAAI,EAAE,cAAc,EAAE,KAAK,EAAE,eAAe,EAAE,UAAU,EAAE,KAAK,IAAI,EAAE,CAAC,aAAa,EAAE,CAAC;AAGvG,qFAAqF;AACrF,0DAA0D;AAC1D,4EAA4E;AAC5E,qEAAqE;AACrE,gFAAgF;AAChF,aAAa;AACb,kCAAkC;AAClC,yCAAyC;AACzC,iCAAiC;AACjC,mCAAmC;AACnC,2CAA2C;AAC3C,OAAO;AACP,IAAI","sourcesContent":["/** @jsx jsx */\n/** @jsxFrag React.Fragment */\n\nimport React from 'react';\nimport { jsx } from '@emotion/react';\nimport { NonIdealState } from '@blueprintjs/core';\nimport useCustomView from '../../hooks/useCustomView';\n\n\nconst CustomViewMain: React.FC<{ uri: string }> = function ({ uri }) {\n const [viewID, ...pathComponents] = uri.split('/');\n const { value: view } = useCustomView(viewID);\n const fallbackView = (() => <NonIdealState\n icon=\"heart-broken\"\n title=\"Unable to show this view\"\n description={`Custom view ${uri} cannot be displayed (not found in registry configuration)`}\n />);\n const View = view?.view ?? fallbackView;\n return <View path={pathComponents.join('/')} />;\n};\n\n\nconst CustomViewTitle: React.FC<{ uri: string }> = function ({ uri }) {\n const { value: view } = useCustomView(uri);\n return <>{view?.label ?? 'unknown view'}</>;\n}\n\n\nexport default { main: CustomViewMain, title: CustomViewTitle, plainTitle: async () => \"custom view\" };\n\n\n// function useCRData(id: string | undefined): ValueHook<ChangeRequest | undefined> {\n// const { useObjectData } = useContext(DatasetContext);\n// const objectPath = `change-requests/${id ?? 'NONEXISTENT_CR_ID'}.yaml`;\n// const crDataResp = useObjectData({ objectPaths: [objectPath] });\n// const crData = crDataResp.value.data?.[objectPath] as ChangeRequest | null;\n// return {\n// value: crData ?? undefined,\n// isUpdating: crDataResp.isUpdating,\n// errors: crDataResp.errors,\n// refresh: crDataResp.refresh,\n// _reqCounter: crDataResp._reqCounter,\n// };\n// }\n"]}
@@ -0,0 +1,5 @@
1
+ /** @jsx jsx */
2
+ /** @jsxFrag React.Fragment */
3
+ import React from 'react';
4
+ declare const RegisterHome: React.VoidFunctionComponent<Record<never, never>>;
5
+ export default RegisterHome;
@@ -0,0 +1,128 @@
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 _context = require("@riboseinc/paneron-extension-kit/context");
15
+
16
+ var _context2 = require("@riboseinc/paneron-extension-kit/widgets/TabbedWorkspace/context");
17
+
18
+ var _BrowserCtx = require("../../BrowserCtx");
19
+
20
+ var _RegisterStakeholder = require("../../RegisterStakeholder");
21
+
22
+ var _objectChangeset = require("../../change-request/objectChangeset");
23
+
24
+ var _protocolRegistry = require("../../protocolRegistry");
25
+
26
+ var _itemPathUtils = require("../../itemPathUtils");
27
+
28
+ function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function (nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
29
+
30
+ function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || typeof obj !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && 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; }
31
+
32
+ /** @jsx jsx */
33
+
34
+ /** @jsxFrag React.Fragment */
35
+ //import { Helmet } from 'react-helmet';
36
+ const RegisterHome = function () {
37
+ var _stakeholder$gitServe, _registerMetadata$ver;
38
+
39
+ const {
40
+ spawnTab
41
+ } = (0, _react.useContext)(_context2.TabbedWorkspaceContext);
42
+ const {
43
+ customViews,
44
+ registerMetadata,
45
+ stakeholder
46
+ } = (0, _react.useContext)(_BrowserCtx.BrowserCtx);
47
+ const {
48
+ makeRandomID,
49
+ updateObjects,
50
+ performOperation
51
+ } = (0, _react.useContext)(_context.DatasetContext);
52
+ const [newProposalIdea, setNewProposalIdea] = (0, _react.useState)('');
53
+ const registerVersion = registerMetadata === null || registerMetadata === void 0 ? void 0 : registerMetadata.version;
54
+ const canCreateCR = stakeholder && stakeholder.role && ((_stakeholder$gitServe = stakeholder.gitServerUsername) === null || _stakeholder$gitServe === void 0 ? void 0 : _stakeholder$gitServe.trim()) !== '' && makeRandomID && updateObjects && ((registerVersion === null || registerVersion === void 0 ? void 0 : registerVersion.id) ?? '').trim() !== '';
55
+
56
+ async function createCR(justification) {
57
+ if (canCreateCR) {
58
+ const id = await makeRandomID();
59
+ await updateObjects({
60
+ commitMessage: "start new proposal",
61
+ objectChangeset: (0, _objectChangeset.newCRObjectChangeset)(id, justification, registerVersion, stakeholder.gitServerUsername)
62
+ });
63
+ return id;
64
+ } else {
65
+ throw new Error("Unable to create proposal: read-only dataset");
66
+ }
67
+ }
68
+
69
+ async function handleNewProposal() {
70
+ if (newProposalIdea) {
71
+ const crID = await performOperation("creating proposal", createCR)(newProposalIdea);
72
+ setNewProposalIdea('');
73
+ spawnTab(`${_protocolRegistry.Protocols.CHANGE_REQUEST}:${(0, _itemPathUtils.crIDToCRPath)(crID)}`);
74
+ }
75
+ }
76
+
77
+ const menu = (0, _react2.jsx)(_core.Menu, {
78
+ css: (0, _react2.css)`margin: 10px;`
79
+ }, (0, _react2.jsx)(_core.MenuDivider, {
80
+ title: "Quick links"
81
+ }), customViews.map((cv, _) => (0, _react2.jsx)(_core.MenuItem, {
82
+ key: cv.id,
83
+ text: cv.label,
84
+ title: cv.description,
85
+ icon: cv.icon,
86
+ onClick: () => spawnTab(`${_protocolRegistry.Protocols.CUSTOM_VIEW}:${cv.id}/index`)
87
+ })), customViews.length > 0 ? (0, _react2.jsx)(_core.MenuDivider, null) : null, (0, _react2.jsx)(_core.MenuItem, {
88
+ text: `Propose a change to version ${(registerMetadata === null || registerMetadata === void 0 ? void 0 : (_registerMetadata$ver = registerMetadata.version) === null || _registerMetadata$ver === void 0 ? void 0 : _registerMetadata$ver.id) ?? '(missing)'}`,
89
+ disabled: !canCreateCR,
90
+ icon: "lightbulb",
91
+ title: canCreateCR ? "A blank proposal will be created and opened in a new tab." : undefined
92
+ }, (0, _react2.jsx)(_core.InputGroup, {
93
+ value: newProposalIdea || undefined,
94
+ placeholder: "Your idea\u2026",
95
+ title: "Justification draft (you can change this later)",
96
+ onChange: evt => setNewProposalIdea(evt.currentTarget.value),
97
+ rightElement: (0, _react2.jsx)(_core.Button, {
98
+ small: true,
99
+ intent: newProposalIdea ? 'primary' : undefined,
100
+ disabled: !newProposalIdea,
101
+ onClick: handleNewProposal,
102
+ icon: "tick"
103
+ })
104
+ })), (0, _react2.jsx)(_core.MenuItem, {
105
+ text: "View register metadata",
106
+ icon: "properties",
107
+ onClick: () => spawnTab(_protocolRegistry.Protocols.REGISTER_META)
108
+ }));
109
+ const intro = (0, _react2.jsx)(_core.Callout, {
110
+ intent: "primary",
111
+ css: (0, _react2.css)`text-align: left;`
112
+ }, stakeholder ? (0, _react2.jsx)(_react.default.Fragment, null, "You are working as ", (0, _RegisterStakeholder.registerStakeholderPlain)(stakeholder)) : (0, _react2.jsx)(_react.default.Fragment, null, "Your remote username is not in the list of stakeholders"));
113
+ const greeting = registerMetadata ? (0, _react2.jsx)(_core.NonIdealState, {
114
+ title: `Welcome to ${registerMetadata.name}`,
115
+ description: (0, _react2.jsx)(_react.default.Fragment, null, intro, menu)
116
+ }) : registerMetadata === undefined ? (0, _react2.jsx)(_core.NonIdealState, {
117
+ icon: (0, _react2.jsx)(_core.Spinner, null),
118
+ description: "Loading register information\u2026"
119
+ }) : (0, _react2.jsx)(_core.NonIdealState, {
120
+ icon: "heart-broken",
121
+ title: "Register metadata is missing or invalid.",
122
+ description: (0, _react2.jsx)(_react.default.Fragment, null, menu)
123
+ });
124
+ return greeting;
125
+ };
126
+
127
+ var _default = RegisterHome;
128
+ exports.default = _default;
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/views/detail/RegisterHome/index.tsx"],"names":[],"mappings":"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","sourcesContent":["/** @jsx jsx */\n/** @jsxFrag React.Fragment */\n\nimport React, { useContext, useState } from 'react';\n//import { Helmet } from 'react-helmet';\nimport { jsx, css } from '@emotion/react';\nimport { Menu, MenuDivider, MenuItem, InputGroup, Button, NonIdealState, Spinner, Callout } from '@blueprintjs/core';\nimport { DatasetContext } from '@riboseinc/paneron-extension-kit/context';\nimport { TabbedWorkspaceContext } from '@riboseinc/paneron-extension-kit/widgets/TabbedWorkspace/context';\nimport { BrowserCtx } from '../../BrowserCtx';\nimport { registerStakeholderPlain } from '../../RegisterStakeholder';\nimport { newCRObjectChangeset } from '../../change-request/objectChangeset';\n\nimport { Protocols } from '../../protocolRegistry';\nimport { crIDToCRPath } from '../../itemPathUtils';\n\n\nconst RegisterHome: React.VoidFunctionComponent<Record<never, never>> =\nfunction () {\n const { spawnTab } = useContext(TabbedWorkspaceContext);\n const { customViews, registerMetadata, stakeholder } = useContext(BrowserCtx);\n const { makeRandomID, updateObjects, performOperation } = useContext(DatasetContext);\n\n const [ newProposalIdea, setNewProposalIdea ] = useState<string>('');\n\n const registerVersion = registerMetadata?.version;\n const canCreateCR = (\n stakeholder &&\n stakeholder.role &&\n stakeholder.gitServerUsername?.trim() !== '' &&\n makeRandomID &&\n updateObjects &&\n (registerVersion?.id ?? '').trim() !== '');\n\n async function createCR(justification: string): Promise<string> {\n if (canCreateCR) {\n const id = await makeRandomID();\n await updateObjects({\n commitMessage: \"start new proposal\",\n objectChangeset: newCRObjectChangeset(\n id,\n justification,\n registerVersion!,\n stakeholder.gitServerUsername!,\n ),\n });\n return id;\n } else {\n throw new Error(\"Unable to create proposal: read-only dataset\");\n }\n }\n\n async function handleNewProposal() {\n if (newProposalIdea) {\n const crID = await performOperation(\"creating proposal\", createCR)(newProposalIdea);\n setNewProposalIdea('');\n spawnTab(`${Protocols.CHANGE_REQUEST}:${crIDToCRPath(crID)}`);\n }\n }\n\n const menu = (\n <Menu css={css`margin: 10px;`}>\n <MenuDivider title=\"Quick links\" />\n {customViews.map((cv, _) => \n <MenuItem\n key={cv.id}\n text={cv.label}\n title={cv.description}\n icon={cv.icon}\n onClick={() => spawnTab(`${Protocols.CUSTOM_VIEW}:${cv.id}/index`)}\n />\n )}\n {customViews.length > 0 ? <MenuDivider /> : null}\n\n <MenuItem\n text={`Propose a change to version ${registerMetadata?.version?.id ?? '(missing)'}`}\n disabled={!canCreateCR}\n icon=\"lightbulb\"\n title={canCreateCR\n ? \"A blank proposal will be created and opened in a new tab.\"\n : undefined}>\n <InputGroup\n value={newProposalIdea || undefined}\n placeholder=\"Your idea…\"\n title=\"Justification draft (you can change this later)\"\n onChange={evt => setNewProposalIdea(evt.currentTarget.value)}\n rightElement={\n <Button\n small\n intent={newProposalIdea ? 'primary': undefined}\n disabled={!newProposalIdea}\n onClick={handleNewProposal}\n icon=\"tick\"\n />\n }\n />\n </MenuItem>\n <MenuItem\n text=\"View register metadata\"\n icon=\"properties\"\n onClick={() => spawnTab(Protocols.REGISTER_META)}\n />\n </Menu>\n );\n\n const intro = <Callout intent=\"primary\" css={css`text-align: left;`}>\n {stakeholder\n ? <>You are working as {registerStakeholderPlain(stakeholder)}</>\n : <>Your remote username is not in the list of stakeholders</>}\n </Callout>\n\n const greeting = registerMetadata\n ? <NonIdealState\n title={`Welcome to ${registerMetadata.name}`}\n description={<>\n {intro}\n {menu}\n </>}\n />\n : registerMetadata === undefined\n ? <NonIdealState\n icon={<Spinner />}\n description=\"Loading register information…\"\n />\n : <NonIdealState\n icon=\"heart-broken\"\n title=\"Register metadata is missing or invalid.\"\n description={<>\n {menu}\n </>}\n />;\n\n return greeting;\n}\n\nexport default RegisterHome;\n"]}
@@ -0,0 +1,13 @@
1
+ /** @jsx jsx */
2
+ /** @jsxFrag React.Fragment */
3
+ import React from 'react';
4
+ import type { InternalItemReference } from '../../../types';
5
+ /**
6
+ * Shows a list of related items .
7
+ */
8
+ export declare const RelatedItems: React.FC<{
9
+ itemRefs: InternalItemReference[];
10
+ onChange?: (newItemRefs: InternalItemReference[]) => void;
11
+ className?: string;
12
+ }>;
13
+ export default RelatedItems;
@@ -0,0 +1,61 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.default = exports.RelatedItems = void 0;
7
+
8
+ var _immutabilityHelper = _interopRequireDefault(require("immutability-helper"));
9
+
10
+ var _react = require("@emotion/react");
11
+
12
+ var _core = require("@blueprintjs/core");
13
+
14
+ var _GenericRelatedItemView = _interopRequireDefault(require("../../GenericRelatedItemView"));
15
+
16
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
17
+
18
+ /** @jsx jsx */
19
+
20
+ /** @jsxFrag React.Fragment */
21
+
22
+ /**
23
+ * Shows a list of related items .
24
+ */
25
+ const RelatedItems = function ({
26
+ itemRefs,
27
+ onChange,
28
+ className
29
+ }) {
30
+ function handleRemoveItemAtIdx(idx) {
31
+ onChange === null || onChange === void 0 ? void 0 : onChange((0, _immutabilityHelper.default)(itemRefs, {
32
+ $splice: [[idx, 1]]
33
+ }));
34
+ }
35
+
36
+ function handleUpdateItemAtIdx(idx, ref) {
37
+ onChange === null || onChange === void 0 ? void 0 : onChange((0, _immutabilityHelper.default)(itemRefs, {
38
+ $splice: [[idx, 0, ref]]
39
+ }));
40
+ }
41
+
42
+ return (0, _react.jsx)(_core.ControlGroup // TODO: Workaround for BP3 bug with border radius in ControlGroup with a single child; remove if fixed:
43
+ , {
44
+ // TODO: Workaround for BP3 bug with border radius in ControlGroup with a single child; remove if fixed:
45
+ vertical: itemRefs.length > 0,
46
+ className: className
47
+ }, itemRefs.map((itemRef, idx) => (0, _react.jsx)(_GenericRelatedItemView.default, {
48
+ itemRef: itemRef,
49
+ key: idx,
50
+ onClear: onChange ? () => handleRemoveItemAtIdx(idx) : undefined,
51
+ onChange: onChange ? newRef => handleUpdateItemAtIdx(idx, newRef) : undefined
52
+ })), onChange ? (0, _react.jsx)(_GenericRelatedItemView.default, {
53
+ onChange: newRef => onChange((0, _immutabilityHelper.default)(itemRefs, {
54
+ $push: [newRef]
55
+ }))
56
+ }) : null);
57
+ };
58
+
59
+ exports.RelatedItems = RelatedItems;
60
+ var _default = RelatedItems;
61
+ exports.default = _default;
@@ -0,0 +1 @@
1
+ {"version":3,"file":"RelatedItems.js","sourceRoot":"","sources":["../../../../src/views/detail/RegisterItem/RelatedItems.tsx"],"names":[],"mappings":"AAAA,eAAe;AACf,8BAA8B;AAE9B,OAAO,MAAM,MAAM,qBAAqB,CAAC;AAEzC,OAAO,EAAE,GAAG,EAAE,MAAM,gBAAgB,CAAC;AACrC,OAAO,EAAE,YAAY,EAAE,MAAM,mBAAmB,CAAC;AAEjD,OAAO,sBAAsB,MAAM,8BAA8B,CAAC;AAGlE;;GAEG;AACH,MAAM,CAAC,MAAM,YAAY,GAIpB,UAAU,EAAE,QAAQ,EAAE,QAAQ,EAAE,SAAS,EAAE;IAC9C,SAAS,qBAAqB,CAAC,GAAW;QACxC,QAAQ,EAAE,CAAC,MAAM,CAAC,QAAQ,EAAE,EAAE,OAAO,EAAE,CAAC,CAAC,GAAG,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;IACxD,CAAC;IACD,SAAS,qBAAqB,CAAC,GAAW,EAAE,GAA0B;QACpE,QAAQ,EAAE,CAAC,MAAM,CAAC,QAAQ,EAAE,EAAE,OAAO,EAAE,CAAC,CAAC,GAAG,EAAE,CAAC,EAAE,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;IAC7D,CAAC;IACD,OAAO,CACL,IAAC,YAAY;IAET,wGAAwG;;QAAxG,wGAAwG;QACxG,QAAQ,EAAE,QAAQ,CAAC,MAAM,GAAG,CAAC,EAE7B,SAAS,EAAE,SAAS;QACrB,QAAQ,CAAC,GAAG,CAAC,CAAC,OAAO,EAAE,GAAG,EAAE,EAAE,CAC7B,IAAC,sBAAsB,IACrB,OAAO,EAAE,OAAO,EAChB,GAAG,EAAE,GAAG,EACR,OAAO,EAAE,QAAQ;gBACf,CAAC,CAAC,GAAG,EAAE,CAAC,qBAAqB,CAAC,GAAG,CAAC;gBAClC,CAAC,CAAC,SAAS,EACb,QAAQ,EAAE,QAAQ;gBAChB,CAAC,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,qBAAqB,CAAC,GAAG,EAAE,MAAM,CAAC;gBAChD,CAAC,CAAC,SAAS,GACb,CACH;QAGA,QAAQ;YACP,CAAC,CAAC,IAAC,sBAAsB,IACrB,QAAQ,EAAE,MAAM,CAAC,EAAE,CAAC,QAAS,CAAC,MAAM,CAClC,QAAQ,EACR,EAAE,KAAK,EAAE,CAAC,MAAM,CAAC,EAAE,CACpB,CAAC,GACF;YACJ,CAAC,CAAC,IAAI,CACK,CAChB,CAAC;AACJ,CAAC,CAAC;AAGF,eAAe,YAAY,CAAC","sourcesContent":["/** @jsx jsx */\n/** @jsxFrag React.Fragment */\n\nimport update from 'immutability-helper';\nimport React from 'react';\nimport { jsx } from '@emotion/react';\nimport { ControlGroup } from '@blueprintjs/core';\nimport type { InternalItemReference } from '../../../types';\nimport GenericRelatedItemView from '../../GenericRelatedItemView';\n\n\n/**\n * Shows a list of related items .\n */\nexport const RelatedItems: React.FC<{\n itemRefs: InternalItemReference[],\n onChange?: (newItemRefs: InternalItemReference[]) => void,\n className?: string,\n}> = function ({ itemRefs, onChange, className }) {\n function handleRemoveItemAtIdx(idx: number) {\n onChange?.(update(itemRefs, { $splice: [[idx, 1]] }));\n }\n function handleUpdateItemAtIdx(idx: number, ref: InternalItemReference) {\n onChange?.(update(itemRefs, { $splice: [[idx, 0, ref]] }));\n }\n return (\n <ControlGroup\n\n // TODO: Workaround for BP3 bug with border radius in ControlGroup with a single child; remove if fixed:\n vertical={itemRefs.length > 0}\n\n className={className}>\n {itemRefs.map((itemRef, idx) =>\n <GenericRelatedItemView\n itemRef={itemRef}\n key={idx}\n onClear={onChange\n ? () => handleRemoveItemAtIdx(idx)\n : undefined}\n onChange={onChange\n ? (newRef) => handleUpdateItemAtIdx(idx, newRef)\n : undefined}\n />\n )}\n\n {/* New item placeholder */}\n {onChange\n ? <GenericRelatedItemView\n onChange={newRef => onChange!(update(\n itemRefs,\n { $push: [newRef] },\n ))}\n />\n : null}\n </ControlGroup>\n );\n};\n\n\nexport default RelatedItems;\n"]}
@@ -0,0 +1,13 @@
1
+ /** @jsx jsx */
2
+ /** @jsxFrag React.Fragment */
3
+ import React from 'react';
4
+ import type { InternalItemReference } from '../../../types';
5
+ /**
6
+ * Shows a list of related items .
7
+ */
8
+ export declare const RelatedItems: React.FC<{
9
+ itemRefs: InternalItemReference[];
10
+ onChange?: (newItemRefs: InternalItemReference[]) => void;
11
+ className?: string;
12
+ }>;
13
+ export default RelatedItems;
@@ -0,0 +1,56 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.default = exports.RelatedItems = void 0;
7
+
8
+ var _immutabilityHelper = _interopRequireDefault(require("immutability-helper"));
9
+
10
+ var _react = require("@emotion/react");
11
+
12
+ var _GenericRelatedItemView = _interopRequireDefault(require("../../GenericRelatedItemView"));
13
+
14
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
15
+
16
+ /** @jsx jsx */
17
+
18
+ /** @jsxFrag React.Fragment */
19
+
20
+ /**
21
+ * Shows a list of related items .
22
+ */
23
+ const RelatedItems = function ({
24
+ itemRefs,
25
+ onChange,
26
+ className
27
+ }) {
28
+ function handleRemoveItemAtIdx(idx) {
29
+ onChange === null || onChange === void 0 ? void 0 : onChange((0, _immutabilityHelper.default)(itemRefs, {
30
+ $splice: [[idx, 1]]
31
+ }));
32
+ }
33
+
34
+ function handleUpdateItemAtIdx(idx, ref) {
35
+ onChange === null || onChange === void 0 ? void 0 : onChange((0, _immutabilityHelper.default)(itemRefs, {
36
+ $splice: [[idx, 0, ref]]
37
+ }));
38
+ }
39
+
40
+ return (0, _react.jsx)("div", {
41
+ className: className
42
+ }, itemRefs.map((itemRef, idx) => (0, _react.jsx)(_GenericRelatedItemView.default, {
43
+ itemRef: itemRef,
44
+ key: idx,
45
+ onClear: onChange ? () => handleRemoveItemAtIdx(idx) : undefined,
46
+ onChange: onChange ? newRef => handleUpdateItemAtIdx(idx, newRef) : undefined
47
+ })), onChange ? (0, _react.jsx)(_GenericRelatedItemView.default, {
48
+ onChange: newRef => onChange((0, _immutabilityHelper.default)(itemRefs, {
49
+ $push: [newRef]
50
+ }))
51
+ }) : null);
52
+ };
53
+
54
+ exports.RelatedItems = RelatedItems;
55
+ var _default = RelatedItems;
56
+ exports.default = _default;
@@ -0,0 +1 @@
1
+ {"version":3,"file":"SupersedingItemMenu.js","sourceRoot":"","sources":["../../../../src/views/detail/RegisterItem/SupersedingItemMenu.tsx"],"names":[],"mappings":"AAAA,eAAe;AACf,8BAA8B;AAE9B,OAAO,MAAM,MAAM,qBAAqB,CAAC;AAEzC,OAAO,EAAE,GAAG,EAAE,MAAM,gBAAgB,CAAC;AAErC,OAAO,sBAAsB,MAAM,8BAA8B,CAAC;AAGlE;;GAEG;AACH,MAAM,CAAC,MAAM,YAAY,GAIpB,UAAU,EAAE,QAAQ,EAAE,QAAQ,EAAE,SAAS,EAAE;IAC9C,SAAS,qBAAqB,CAAC,GAAW;QACxC,QAAQ,EAAE,CAAC,MAAM,CAAC,QAAQ,EAAE,EAAE,OAAO,EAAE,CAAC,CAAC,GAAG,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;IACxD,CAAC;IACD,SAAS,qBAAqB,CAAC,GAAW,EAAE,GAA0B;QACpE,QAAQ,EAAE,CAAC,MAAM,CAAC,QAAQ,EAAE,EAAE,OAAO,EAAE,CAAC,CAAC,GAAG,EAAE,CAAC,EAAE,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;IAC7D,CAAC;IACD,OAAO,aAAK,SAAS,EAAE,SAAS;QAC7B,QAAQ,CAAC,GAAG,CAAC,CAAC,OAAO,EAAE,GAAG,EAAE,EAAE,CAC7B,IAAC,sBAAsB,IACrB,OAAO,EAAE,OAAO,EAChB,GAAG,EAAE,GAAG,EACR,OAAO,EAAE,QAAQ;gBACf,CAAC,CAAC,GAAG,EAAE,CAAC,qBAAqB,CAAC,GAAG,CAAC;gBAClC,CAAC,CAAC,SAAS,EACb,QAAQ,EAAE,QAAQ;gBAChB,CAAC,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,qBAAqB,CAAC,GAAG,EAAE,MAAM,CAAC;gBAChD,CAAC,CAAC,SAAS,GACb,CACH;QAGA,QAAQ;YACP,CAAC,CAAC,IAAC,sBAAsB,IACrB,QAAQ,EAAE,MAAM,CAAC,EAAE,CAAC,QAAS,CAAC,MAAM,CAClC,QAAQ,EACR,EAAE,KAAK,EAAE,CAAC,MAAM,CAAC,EAAE,CACpB,CAAC,GACF;YACJ,CAAC,CAAC,IAAI,CACJ,CAAC;AACT,CAAC,CAAC;AAGF,eAAe,YAAY,CAAC","sourcesContent":["/** @jsx jsx */\n/** @jsxFrag React.Fragment */\n\nimport update from 'immutability-helper';\nimport React from 'react';\nimport { jsx } from '@emotion/react';\nimport type { InternalItemReference } from '../../../types';\nimport GenericRelatedItemView from '../../GenericRelatedItemView';\n\n\n/**\n * Shows a list of related items .\n */\nexport const RelatedItems: React.FC<{\n itemRefs: InternalItemReference[],\n onChange?: (newItemRefs: InternalItemReference[]) => void,\n className?: string,\n}> = function ({ itemRefs, onChange, className }) {\n function handleRemoveItemAtIdx(idx: number) {\n onChange?.(update(itemRefs, { $splice: [[idx, 1]] }));\n }\n function handleUpdateItemAtIdx(idx: number, ref: InternalItemReference) {\n onChange?.(update(itemRefs, { $splice: [[idx, 0, ref]] }));\n }\n return <div className={className}>\n {itemRefs.map((itemRef, idx) =>\n <GenericRelatedItemView\n itemRef={itemRef}\n key={idx}\n onClear={onChange\n ? () => handleRemoveItemAtIdx(idx)\n : undefined}\n onChange={onChange\n ? (newRef) => handleUpdateItemAtIdx(idx, newRef)\n : undefined}\n />\n )}\n\n {/* New item placeholder */}\n {onChange\n ? <GenericRelatedItemView\n onChange={newRef => onChange!(update(\n itemRefs,\n { $push: [newRef] },\n ))}\n />\n : null}\n </div>;\n};\n\n\nexport default RelatedItems;\n"]}
@@ -0,0 +1,13 @@
1
+ /** @jsx jsx */
2
+ /** @jsxFrag React.Fragment */
3
+ import React from 'react';
4
+ declare const _default: {
5
+ main: React.FC<{
6
+ uri: string;
7
+ inProposalWithID?: string | undefined;
8
+ }>;
9
+ title: React.FC<{
10
+ uri: string;
11
+ }>;
12
+ };
13
+ export default _default;