@sanity/cross-dataset-duplicator 0.3.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 (55) hide show
  1. package/.babelrc +3 -0
  2. package/.eslintignore +1 -0
  3. package/LICENSE +21 -0
  4. package/README.md +101 -0
  5. package/config.dist.json +4 -0
  6. package/lib/actions/DuplicateToAction.js +59 -0
  7. package/lib/actions/DuplicateToAction.js.map +1 -0
  8. package/lib/actions/index.js +38 -0
  9. package/lib/actions/index.js.map +1 -0
  10. package/lib/components/CrossDatasetDuplicator.js +107 -0
  11. package/lib/components/CrossDatasetDuplicator.js.map +1 -0
  12. package/lib/components/DuplicatorQuery.js +113 -0
  13. package/lib/components/DuplicatorQuery.js.map +1 -0
  14. package/lib/components/DuplicatorTool.js +557 -0
  15. package/lib/components/DuplicatorTool.js.map +1 -0
  16. package/lib/components/Feedback.js +27 -0
  17. package/lib/components/Feedback.js.map +1 -0
  18. package/lib/components/ResetSecret.js +43 -0
  19. package/lib/components/ResetSecret.js.map +1 -0
  20. package/lib/components/SelectButtons.js +109 -0
  21. package/lib/components/SelectButtons.js.map +1 -0
  22. package/lib/components/StatusBadge.js +87 -0
  23. package/lib/components/StatusBadge.js.map +1 -0
  24. package/lib/helpers/clientConfig.js +11 -0
  25. package/lib/helpers/clientConfig.js.map +1 -0
  26. package/lib/helpers/constants.js +9 -0
  27. package/lib/helpers/constants.js.map +1 -0
  28. package/lib/helpers/getDocumentsInArray.js +80 -0
  29. package/lib/helpers/getDocumentsInArray.js.map +1 -0
  30. package/lib/helpers/index.js +30 -0
  31. package/lib/helpers/index.js.map +1 -0
  32. package/lib/index.js +24 -0
  33. package/lib/index.js.map +1 -0
  34. package/lib/tool/index.js +24 -0
  35. package/lib/tool/index.js.map +1 -0
  36. package/lib/types/index.js +2 -0
  37. package/lib/types/index.js.map +1 -0
  38. package/package.json +71 -0
  39. package/sanity.json +16 -0
  40. package/src/actions/DuplicateToAction.tsx +22 -0
  41. package/src/actions/index.ts +22 -0
  42. package/src/components/CrossDatasetDuplicator.tsx +100 -0
  43. package/src/components/DuplicatorQuery.tsx +93 -0
  44. package/src/components/DuplicatorTool.tsx +460 -0
  45. package/src/components/Feedback.tsx +18 -0
  46. package/src/components/ResetSecret.tsx +27 -0
  47. package/src/components/SelectButtons.tsx +80 -0
  48. package/src/components/StatusBadge.tsx +97 -0
  49. package/src/helpers/clientConfig.ts +1 -0
  50. package/src/helpers/constants.ts +1 -0
  51. package/src/helpers/getDocumentsInArray.ts +74 -0
  52. package/src/helpers/index.ts +23 -0
  53. package/src/index.js +7 -0
  54. package/src/tool/index.ts +13 -0
  55. package/src/types/index.ts +10 -0
@@ -0,0 +1,43 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.default = ResetSecret;
7
+
8
+ var _react = _interopRequireDefault(require("react"));
9
+
10
+ var _ui = require("@sanity/ui");
11
+
12
+ var _client = _interopRequireDefault(require("part:@sanity/base/client"));
13
+
14
+ var _clientConfig = require("../helpers/clientConfig");
15
+
16
+ var _constants = require("../helpers/constants");
17
+
18
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
19
+
20
+ var client = _client.default.withConfig(_clientConfig.clientConfig);
21
+
22
+ function handleClick() {
23
+ client.delete({
24
+ query: "*[_id == \"secrets.".concat(_constants.SECRET_NAMESPACE, "\"]")
25
+ });
26
+ }
27
+
28
+ function ResetSecret() {
29
+ return /*#__PURE__*/_react.default.createElement(_ui.Flex, {
30
+ align: "center",
31
+ justify: "flex-end",
32
+ paddingX: [2, 2, 2, 5],
33
+ paddingY: 5
34
+ }, /*#__PURE__*/_react.default.createElement(_ui.Button, {
35
+ text: "Reset Secret",
36
+ onClick: () => handleClick(),
37
+ mode: "ghost",
38
+ tone: "critical",
39
+ fontSize: 1,
40
+ padding: 2
41
+ }));
42
+ }
43
+ //# sourceMappingURL=ResetSecret.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../src/components/ResetSecret.tsx"],"names":["client","sanityClient","withConfig","clientConfig","handleClick","delete","query","SECRET_NAMESPACE","ResetSecret"],"mappings":";;;;;;;AAAA;;AACA;;AACA;;AAEA;;AACA;;;;AAEA,IAAMA,MAAM,GAAGC,gBAAaC,UAAb,CAAwBC,0BAAxB,CAAf;;AAEA,SAASC,WAAT,GAAuB;AACrBJ,EAAAA,MAAM,CAACK,MAAP,CAAc;AAACC,IAAAA,KAAK,+BAAuBC,2BAAvB;AAAN,GAAd;AACD;;AAEc,SAASC,WAAT,GAAuB;AACpC,sBACE,6BAAC,QAAD;AAAM,IAAA,KAAK,EAAC,QAAZ;AAAqB,IAAA,OAAO,EAAC,UAA7B;AAAwC,IAAA,QAAQ,EAAE,CAAC,CAAD,EAAI,CAAJ,EAAO,CAAP,EAAU,CAAV,CAAlD;AAAgE,IAAA,QAAQ,EAAE;AAA1E,kBACE,6BAAC,UAAD;AACE,IAAA,IAAI,EAAC,cADP;AAEE,IAAA,OAAO,EAAE,MAAMJ,WAAW,EAF5B;AAGE,IAAA,IAAI,EAAC,OAHP;AAIE,IAAA,IAAI,EAAC,UAJP;AAKE,IAAA,QAAQ,EAAE,CALZ;AAME,IAAA,OAAO,EAAE;AANX,IADF,CADF;AAYD","sourcesContent":["import React from 'react'\nimport {Button, Flex} from '@sanity/ui'\nimport sanityClient from 'part:@sanity/base/client'\n\nimport { clientConfig } from '../helpers/clientConfig'\nimport { SECRET_NAMESPACE } from '../helpers/constants'\n\nconst client = sanityClient.withConfig(clientConfig)\n\nfunction handleClick() {\n client.delete({query: `*[_id == \"secrets.${SECRET_NAMESPACE}\"]`})\n}\n\nexport default function ResetSecret() {\n return (\n <Flex align=\"center\" justify=\"flex-end\" paddingX={[2, 2, 2, 5]} paddingY={5}>\n <Button\n text=\"Reset Secret\"\n onClick={() => handleClick()}\n mode=\"ghost\"\n tone=\"critical\"\n fontSize={1}\n padding={2}\n />\n </Flex>\n )\n}\n"],"file":"ResetSecret.js"}
@@ -0,0 +1,109 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.default = SelectButtons;
7
+
8
+ var _react = _interopRequireWildcard(require("react"));
9
+
10
+ var _ui = require("@sanity/ui");
11
+
12
+ var _helpers = require("../helpers");
13
+
14
+ function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
15
+
16
+ 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; }
17
+
18
+ function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }
19
+
20
+ function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
21
+
22
+ function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
23
+
24
+ function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }
25
+
26
+ function _iterableToArrayLimit(arr, i) { var _i = arr == null ? null : typeof Symbol !== "undefined" && arr[Symbol.iterator] || arr["@@iterator"]; if (_i == null) return; var _arr = []; var _n = true; var _d = false; var _s, _e; try { for (_i = _i.call(arr); !(_n = (_s = _i.next()).done); _n = true) { _arr.push(_s.value); if (i && _arr.length === i) break; } } catch (err) { _d = true; _e = err; } finally { try { if (!_n && _i["return"] != null) _i["return"](); } finally { if (_d) throw _e; } } return _arr; }
27
+
28
+ function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }
29
+
30
+ var buttons = ["All", "None", null, "New", "Existing", "Older", null, "Documents", "Assets"];
31
+
32
+ function SelectButtons(props) {
33
+ var payload = props.payload,
34
+ setPayload = props.setPayload;
35
+
36
+ var _useState = (0, _react.useState)([]),
37
+ _useState2 = _slicedToArray(_useState, 2),
38
+ disabledActions = _useState2[0],
39
+ setDisabledActions = _useState2[1]; // Set intiial disabled button
40
+
41
+
42
+ (0, _react.useEffect)(() => {
43
+ if (!(disabledActions !== null && disabledActions !== void 0 && disabledActions.length) && payload.every(item => item.include)) {
44
+ setDisabledActions(["ALL"]);
45
+ }
46
+ }, []);
47
+
48
+ function handleSelectButton() {
49
+ var action = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : "";
50
+ if (!action || !payload.length) return;
51
+ var newPayload = [...payload];
52
+
53
+ switch (action) {
54
+ case 'ALL':
55
+ newPayload.map(item => item.include = true);
56
+ break;
57
+
58
+ case 'NONE':
59
+ newPayload.map(item => item.include = false);
60
+ break;
61
+
62
+ case 'NEW':
63
+ newPayload.map(item => item.include = Boolean(item.status === 'CREATE'));
64
+ break;
65
+
66
+ case 'EXISTING':
67
+ newPayload.map(item => item.include = Boolean(item.status === 'EXISTS'));
68
+ break;
69
+
70
+ case 'OLDER':
71
+ newPayload.map(item => item.include = Boolean(item.status === 'OVERWRITE'));
72
+ break;
73
+
74
+ case 'ASSETS':
75
+ newPayload.map(item => item.include = (0, _helpers.typeIsAsset)(item.doc._type));
76
+ break;
77
+
78
+ case 'DOCUMENTS':
79
+ newPayload.map(item => item.include = !(0, _helpers.typeIsAsset)(item.doc._type));
80
+ break;
81
+
82
+ default:
83
+ break;
84
+ }
85
+
86
+ setDisabledActions([action]);
87
+ setPayload(newPayload);
88
+ }
89
+
90
+ return /*#__PURE__*/_react.default.createElement(_ui.Card, {
91
+ padding: 1,
92
+ radius: 3,
93
+ shadow: 1
94
+ }, /*#__PURE__*/_react.default.createElement(_ui.Flex, {
95
+ gap: 2
96
+ }, buttons.map((action, actionIndex) => action ? /*#__PURE__*/_react.default.createElement(_ui.Button, {
97
+ key: action,
98
+ fontSize: 1,
99
+ mode: "bleed",
100
+ padding: 2,
101
+ text: action,
102
+ disabled: disabledActions.includes(action.toUpperCase()),
103
+ onClick: () => handleSelectButton(action.toUpperCase())
104
+ }) : /*#__PURE__*/_react.default.createElement(_ui.Card, {
105
+ key: "divider-".concat(actionIndex),
106
+ borderLeft: true
107
+ }))));
108
+ }
109
+ //# sourceMappingURL=SelectButtons.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../src/components/SelectButtons.tsx"],"names":["buttons","SelectButtons","props","payload","setPayload","disabledActions","setDisabledActions","length","every","item","include","handleSelectButton","action","newPayload","map","Boolean","status","doc","_type","actionIndex","includes","toUpperCase"],"mappings":"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","sourcesContent":["import React, {useState, useEffect} from 'react'\nimport {Button, Card, Flex} from '@sanity/ui'\nimport {typeIsAsset} from '../helpers'\nimport {PayloadItem} from '../types'\n\nconst buttons = [`All`, `None`, null, `New`, `Existing`, `Older`, null, `Documents`, `Assets`]\n\ntype SelectButtonsProps = {\n payload: PayloadItem[]\n setPayload: Function\n}\n\nexport default function SelectButtons(props: SelectButtonsProps) {\n const {payload, setPayload} = props\n const [disabledActions, setDisabledActions] = useState([])\n\n // Set intiial disabled button\n useEffect(() => {\n if (!disabledActions?.length && payload.every((item) => item.include)) {\n setDisabledActions([`ALL`])\n }\n }, [])\n\n function handleSelectButton(action = ``) {\n if (!action || !payload.length) return\n\n const newPayload = [...payload]\n\n switch (action) {\n case 'ALL':\n newPayload.map((item) => (item.include = true))\n break\n case 'NONE':\n newPayload.map((item) => (item.include = false))\n break\n case 'NEW':\n newPayload.map((item) => (item.include = Boolean(item.status === 'CREATE')))\n break\n case 'EXISTING':\n newPayload.map((item) => (item.include = Boolean(item.status === 'EXISTS')))\n break\n case 'OLDER':\n newPayload.map((item) => (item.include = Boolean(item.status === 'OVERWRITE')))\n break\n case 'ASSETS':\n newPayload.map((item) => (item.include = typeIsAsset(item.doc._type)))\n break\n case 'DOCUMENTS':\n newPayload.map((item) => (item.include = !typeIsAsset(item.doc._type)))\n break\n default:\n break\n }\n\n setDisabledActions([action])\n setPayload(newPayload)\n }\n\n return (\n <Card padding={1} radius={3} shadow={1}>\n <Flex gap={2}>\n {buttons.map((action, actionIndex) =>\n action ? (\n <Button\n key={action}\n fontSize={1}\n mode=\"bleed\"\n padding={2}\n text={action}\n disabled={disabledActions.includes(action.toUpperCase())}\n onClick={() => handleSelectButton(action.toUpperCase())}\n />\n ) : (\n <Card key={`divider-${actionIndex}`} borderLeft />\n )\n )}\n </Flex>\n </Card>\n )\n}\n"],"file":"SelectButtons.js"}
@@ -0,0 +1,87 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.default = StatusBadge;
7
+
8
+ var _react = _interopRequireDefault(require("react"));
9
+
10
+ var _ui = require("@sanity/ui");
11
+
12
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
13
+
14
+ var documentTones = {
15
+ EXISTS: "primary",
16
+ OVERWRITE: "critical",
17
+ UPDATE: "caution",
18
+ CREATE: "positive"
19
+ };
20
+ var assetTones = {
21
+ EXISTS: "critical",
22
+ OVERWRITE: "critical",
23
+ UPDATE: "critical",
24
+ CREATE: "positive"
25
+ };
26
+ var documentMessages = {
27
+ // Only happens once document is copied the first time, and _updatedAt is the same
28
+ EXISTS: "This document already exists at the Destination with the same ID with the same Updated time.",
29
+ // Is true immediately after transaction as _updatedAt is updated by API after mutation
30
+ // Is also true if the document at the destination has been manually modified
31
+ // Presently, the plugin doesn't actually compare the two documents
32
+ OVERWRITE: "A newer version of this document exists at the Destination, and it will be overwritten with this version.",
33
+ // Document at destination is older
34
+ UPDATE: "An older version of this document exists at the Destination, and it will be overwritten with this version.",
35
+ // Document at destination doesn't exist
36
+ CREATE: "This document will be created at the destination."
37
+ };
38
+ var assetMessages = {
39
+ EXISTS: "This Asset already exists at the Destination",
40
+ OVERWRITE: "This Asset already exists at the Destination",
41
+ UPDATE: "This Asset already exists at the Destination",
42
+ CREATE: "This Asset does not yet exist at the Destination"
43
+ };
44
+ var assetStatus = {
45
+ EXISTS: "RE-UPLOAD",
46
+ OVERWRITE: "RE-UPLOAD",
47
+ UPDATE: "RE-UPLOAD",
48
+ CREATE: "UPLOAD"
49
+ };
50
+
51
+ function StatusBadge(props) {
52
+ var status = props.status,
53
+ isAsset = props.isAsset;
54
+ var badgeTone = isAsset ? assetTones[status] : documentTones[status];
55
+
56
+ if (!badgeTone) {
57
+ return /*#__PURE__*/_react.default.createElement(_ui.Badge, {
58
+ muted: true,
59
+ padding: 2,
60
+ fontSize: 1,
61
+ mode: "outline"
62
+ }, "Checking...");
63
+ }
64
+
65
+ var badgeText = isAsset ? assetMessages[status] : documentMessages[status];
66
+ var badgeStatus = isAsset ? assetStatus[status] : status;
67
+ return /*#__PURE__*/_react.default.createElement(_ui.Tooltip, {
68
+ content: /*#__PURE__*/_react.default.createElement(_ui.Box, {
69
+ padding: 3,
70
+ style: {
71
+ maxWidth: 200
72
+ }
73
+ }, /*#__PURE__*/_react.default.createElement(_ui.Text, {
74
+ size: 1
75
+ }, badgeText)),
76
+ fallbackPlacements: ['right', 'left'],
77
+ placement: "top",
78
+ portal: true
79
+ }, /*#__PURE__*/_react.default.createElement(_ui.Badge, {
80
+ muted: true,
81
+ padding: 2,
82
+ fontSize: 1,
83
+ tone: badgeTone,
84
+ mode: "outline"
85
+ }, badgeStatus));
86
+ }
87
+ //# sourceMappingURL=StatusBadge.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../src/components/StatusBadge.tsx"],"names":["documentTones","EXISTS","OVERWRITE","UPDATE","CREATE","assetTones","documentMessages","assetMessages","assetStatus","StatusBadge","props","status","isAsset","badgeTone","badgeText","badgeStatus","maxWidth"],"mappings":";;;;;;;AAAA;;AACA;;;;AAUA,IAAMA,aAA0B,GAAG;AACjCC,EAAAA,MAAM,WAD2B;AAEjCC,EAAAA,SAAS,YAFwB;AAGjCC,EAAAA,MAAM,WAH2B;AAIjCC,EAAAA,MAAM;AAJ2B,CAAnC;AAOA,IAAMC,UAAuB,GAAG;AAC9BJ,EAAAA,MAAM,YADwB;AAE9BC,EAAAA,SAAS,YAFqB;AAG9BC,EAAAA,MAAM,YAHwB;AAI9BC,EAAAA,MAAM;AAJwB,CAAhC;AAcA,IAAME,gBAA8B,GAAG;AACrC;AACAL,EAAAA,MAAM,gGAF+B;AAGrC;AACA;AACA;AACAC,EAAAA,SAAS,6GAN4B;AAOrC;AACAC,EAAAA,MAAM,8GAR+B;AASrC;AACAC,EAAAA,MAAM;AAV+B,CAAvC;AAaA,IAAMG,aAA2B,GAAG;AAClCN,EAAAA,MAAM,gDAD4B;AAElCC,EAAAA,SAAS,gDAFyB;AAGlCC,EAAAA,MAAM,gDAH4B;AAIlCC,EAAAA,MAAM;AAJ4B,CAApC;AAOA,IAAMI,WAAyB,GAAG;AAChCP,EAAAA,MAAM,aAD0B;AAEhCC,EAAAA,SAAS,aAFuB;AAGhCC,EAAAA,MAAM,aAH0B;AAIhCC,EAAAA,MAAM;AAJ0B,CAAlC;;AAYe,SAASK,WAAT,CAAqBC,KAArB,EAA8C;AAC3D,MAAOC,MAAP,GAA0BD,KAA1B,CAAOC,MAAP;AAAA,MAAeC,OAAf,GAA0BF,KAA1B,CAAeE,OAAf;AAEA,MAAMC,SAAS,GAAGD,OAAO,GAAGP,UAAU,CAACM,MAAD,CAAb,GAAwBX,aAAa,CAACW,MAAD,CAA9D;;AAEA,MAAI,CAACE,SAAL,EAAgB;AACd,wBACE,6BAAC,SAAD;AAAO,MAAA,KAAK,MAAZ;AAAa,MAAA,OAAO,EAAE,CAAtB;AAAyB,MAAA,QAAQ,EAAE,CAAnC;AAAsC,MAAA,IAAI,EAAC;AAA3C,qBADF;AAKD;;AAED,MAAMC,SAAS,GAAGF,OAAO,GAAGL,aAAa,CAACI,MAAD,CAAhB,GAA2BL,gBAAgB,CAACK,MAAD,CAApE;AACA,MAAMI,WAAW,GAAGH,OAAO,GAAGJ,WAAW,CAACG,MAAD,CAAd,GAAyBA,MAApD;AAEA,sBACE,6BAAC,WAAD;AACE,IAAA,OAAO,eACL,6BAAC,OAAD;AAAK,MAAA,OAAO,EAAE,CAAd;AAAiB,MAAA,KAAK,EAAE;AAACK,QAAAA,QAAQ,EAAE;AAAX;AAAxB,oBACE,6BAAC,QAAD;AAAM,MAAA,IAAI,EAAE;AAAZ,OAAgBF,SAAhB,CADF,CAFJ;AAME,IAAA,kBAAkB,EAAE,CAAC,OAAD,EAAU,MAAV,CANtB;AAOE,IAAA,SAAS,EAAC,KAPZ;AAQE,IAAA,MAAM;AARR,kBAUE,6BAAC,SAAD;AAAO,IAAA,KAAK,MAAZ;AAAa,IAAA,OAAO,EAAE,CAAtB;AAAyB,IAAA,QAAQ,EAAE,CAAnC;AAAsC,IAAA,IAAI,EAAED,SAA5C;AAAuD,IAAA,IAAI,EAAC;AAA5D,KACGE,WADH,CAVF,CADF;AAgBD","sourcesContent":["import React from 'react'\nimport {Box, Text, Badge, Tooltip} from '@sanity/ui'\nimport type {BadgeTone} from '@sanity/ui'\n\ntype StatusTones = {\n EXISTS: BadgeTone\n OVERWRITE: BadgeTone\n UPDATE: BadgeTone\n CREATE: BadgeTone\n}\n\nconst documentTones: StatusTones = {\n EXISTS: `primary`,\n OVERWRITE: `critical`,\n UPDATE: `caution`,\n CREATE: `positive`,\n}\n\nconst assetTones: StatusTones = {\n EXISTS: `critical`,\n OVERWRITE: `critical`,\n UPDATE: `critical`,\n CREATE: `positive`,\n}\n\ntype messageTypes = {\n EXISTS: string\n OVERWRITE: string\n UPDATE: string\n CREATE: string\n}\n\nconst documentMessages: messageTypes = {\n // Only happens once document is copied the first time, and _updatedAt is the same\n EXISTS: `This document already exists at the Destination with the same ID with the same Updated time.`,\n // Is true immediately after transaction as _updatedAt is updated by API after mutation\n // Is also true if the document at the destination has been manually modified\n // Presently, the plugin doesn't actually compare the two documents\n OVERWRITE: `A newer version of this document exists at the Destination, and it will be overwritten with this version.`,\n // Document at destination is older\n UPDATE: `An older version of this document exists at the Destination, and it will be overwritten with this version.`,\n // Document at destination doesn't exist\n CREATE: `This document will be created at the destination.`,\n}\n\nconst assetMessages: messageTypes = {\n EXISTS: `This Asset already exists at the Destination`,\n OVERWRITE: `This Asset already exists at the Destination`,\n UPDATE: `This Asset already exists at the Destination`,\n CREATE: `This Asset does not yet exist at the Destination`,\n}\n\nconst assetStatus: messageTypes = {\n EXISTS: `RE-UPLOAD`,\n OVERWRITE: `RE-UPLOAD`,\n UPDATE: `RE-UPLOAD`,\n CREATE: `UPLOAD`,\n}\n\ntype StatusBadgeProps = {\n status: 'EXISTS' | 'OVERWRITE' | 'UPDATE' | 'CREATE' | undefined\n isAsset: boolean\n}\n\nexport default function StatusBadge(props: StatusBadgeProps) {\n const {status, isAsset} = props\n\n const badgeTone = isAsset ? assetTones[status] : documentTones[status]\n \n if (!badgeTone) {\n return (\n <Badge muted padding={2} fontSize={1} mode=\"outline\">\n Checking...\n </Badge>\n )\n }\n \n const badgeText = isAsset ? assetMessages[status] : documentMessages[status]\n const badgeStatus = isAsset ? assetStatus[status] : status\n\n return (\n <Tooltip\n content={\n <Box padding={3} style={{maxWidth: 200}}>\n <Text size={1}>{badgeText}</Text>\n </Box>\n }\n fallbackPlacements={['right', 'left']}\n placement=\"top\"\n portal\n >\n <Badge muted padding={2} fontSize={1} tone={badgeTone} mode=\"outline\">\n {badgeStatus}\n </Badge>\n </Tooltip>\n )\n}\n"],"file":"StatusBadge.js"}
@@ -0,0 +1,11 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.clientConfig = void 0;
7
+ var clientConfig = {
8
+ apiVersion: "2021-05-19"
9
+ };
10
+ exports.clientConfig = clientConfig;
11
+ //# sourceMappingURL=clientConfig.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../src/helpers/clientConfig.ts"],"names":["clientConfig","apiVersion"],"mappings":";;;;;;AAAO,IAAMA,YAAY,GAAG;AAACC,EAAAA,UAAU;AAAX,CAArB","sourcesContent":["export const clientConfig = {apiVersion: `2021-05-19`}"],"file":"clientConfig.js"}
@@ -0,0 +1,9 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.SECRET_NAMESPACE = void 0;
7
+ var SECRET_NAMESPACE = "CrossDatasetDuplicator";
8
+ exports.SECRET_NAMESPACE = SECRET_NAMESPACE;
9
+ //# sourceMappingURL=constants.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../src/helpers/constants.ts"],"names":["SECRET_NAMESPACE"],"mappings":";;;;;;AAAO,IAAMA,gBAAgB,2BAAtB","sourcesContent":["export const SECRET_NAMESPACE = `CrossDatasetDuplicator`"],"file":"constants.js"}
@@ -0,0 +1,80 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.getDocumentsInArray = getDocumentsInArray;
7
+
8
+ var _mutator = require("@sanity/mutator");
9
+
10
+ function asyncGeneratorStep(gen, resolve, reject, _next, _throw, key, arg) { try { var info = gen[key](arg); var value = info.value; } catch (error) { reject(error); return; } if (info.done) { resolve(value); } else { Promise.resolve(value).then(_next, _throw); } }
11
+
12
+ function _asyncToGenerator(fn) { return function () { var self = this, args = arguments; return new Promise(function (resolve, reject) { var gen = fn.apply(self, args); function _next(value) { asyncGeneratorStep(gen, resolve, reject, _next, _throw, "next", value); } function _throw(err) { asyncGeneratorStep(gen, resolve, reject, _next, _throw, "throw", err); } _next(undefined); }); }; }
13
+
14
+ // Recursively fetch Documents from an array of _id's and their references
15
+ // Heavy use of Set is to avoid recursively querying for id's already in the payload
16
+ function getDocumentsInArray(_x, _x2, _x3) {
17
+ return _getDocumentsInArray.apply(this, arguments);
18
+ }
19
+
20
+ function _getDocumentsInArray() {
21
+ _getDocumentsInArray = _asyncToGenerator(function* (fetchIds, client, currentIds) {
22
+ var collection = []; // Find initial docs
23
+
24
+ var data = yield client.fetch("*[_id in $fetchIds]", {
25
+ fetchIds: fetchIds !== null && fetchIds !== void 0 ? fetchIds : []
26
+ });
27
+
28
+ if (!(data !== null && data !== void 0 && data.length)) {
29
+ return [];
30
+ }
31
+
32
+ var localCurrentIds = currentIds !== null && currentIds !== void 0 ? currentIds : new Set(); // Find new ids in the returned data
33
+ // Unless we started with an empty set, get the _ids from the data
34
+
35
+ var newDataIds = new Set(data.map(dataDoc => dataDoc._id).filter(id => currentIds !== null && currentIds !== void 0 && currentIds.size ? !localCurrentIds.has(id) : Boolean(id)));
36
+
37
+ if (newDataIds.size) {
38
+ collection.push(...data);
39
+ localCurrentIds.add(...newDataIds); // Check new data for more references
40
+
41
+ yield Promise.all(data.map( /*#__PURE__*/function () {
42
+ var _ref = _asyncToGenerator(function* (doc) {
43
+ var expr = ".._ref";
44
+ var references = (0, _mutator.extract)(expr, doc);
45
+
46
+ if (references.length) {
47
+ // Find references not already in the Collection
48
+ var newReferenceIds = new Set(references.filter(refId => !localCurrentIds.has(refId)));
49
+
50
+ if (newReferenceIds.size) {
51
+ // Recusive query for new documents
52
+ var referenceDocs = yield getDocumentsInArray(Array.from(newReferenceIds), client, localCurrentIds);
53
+
54
+ if (referenceDocs !== null && referenceDocs !== void 0 && referenceDocs.length) {
55
+ collection.push(...referenceDocs);
56
+ }
57
+ }
58
+ }
59
+ });
60
+
61
+ return function (_x4) {
62
+ return _ref.apply(this, arguments);
63
+ };
64
+ }()));
65
+ } // Create a unique array of objects from collection
66
+ // Set() wasn't working for unique id's ¯\_(ツ)_/¯
67
+
68
+
69
+ var uniqueCollection = collection.filter(Boolean).reduce((acc, cur) => {
70
+ if (acc.some(doc => doc._id === cur._id)) {
71
+ return acc;
72
+ }
73
+
74
+ return [...acc, cur];
75
+ }, []);
76
+ return uniqueCollection;
77
+ });
78
+ return _getDocumentsInArray.apply(this, arguments);
79
+ }
80
+ //# sourceMappingURL=getDocumentsInArray.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../src/helpers/getDocumentsInArray.ts"],"names":["getDocumentsInArray","fetchIds","client","currentIds","collection","data","fetch","length","localCurrentIds","Set","newDataIds","map","dataDoc","_id","filter","id","size","has","Boolean","push","add","Promise","all","doc","expr","references","newReferenceIds","refId","referenceDocs","Array","from","uniqueCollection","reduce","acc","cur","some"],"mappings":";;;;;;;AAAA;;;;;;AAGA;AACA;SACsBA,mB;;;;;2CAAf,WACLC,QADK,EAELC,MAFK,EAGLC,UAHK,EAIL;AACA,QAAMC,UAAU,GAAG,EAAnB,CADA,CAGA;;AACA,QAAMC,IAAsB,SAASH,MAAM,CAACI,KAAP,wBAAoC;AACvEL,MAAAA,QAAQ,EAAEA,QAAF,aAAEA,QAAF,cAAEA,QAAF,GAAc;AADiD,KAApC,CAArC;;AAIA,QAAI,EAACI,IAAD,aAACA,IAAD,eAACA,IAAI,CAAEE,MAAP,CAAJ,EAAmB;AACjB,aAAO,EAAP;AACD;;AAED,QAAMC,eAAe,GAAGL,UAAH,aAAGA,UAAH,cAAGA,UAAH,GAAiB,IAAIM,GAAJ,EAAtC,CAZA,CAcA;AACA;;AACA,QAAMC,UAAuB,GAAG,IAAID,GAAJ,CAC9BJ,IAAI,CACDM,GADH,CACQC,OAAD,IAAaA,OAAO,CAACC,GAD5B,EAEGC,MAFH,CAEWC,EAAD,IAASZ,UAAU,SAAV,IAAAA,UAAU,WAAV,IAAAA,UAAU,CAAEa,IAAZ,GAAmB,CAACR,eAAe,CAACS,GAAhB,CAAoBF,EAApB,CAApB,GAA8CG,OAAO,CAACH,EAAD,CAFxE,CAD8B,CAAhC;;AAMA,QAAIL,UAAU,CAACM,IAAf,EAAqB;AACnBZ,MAAAA,UAAU,CAACe,IAAX,CAAgB,GAAGd,IAAnB;AACAG,MAAAA,eAAe,CAACY,GAAhB,CAAoB,GAAGV,UAAvB,EAFmB,CAInB;;AACA,YAAMW,OAAO,CAACC,GAAR,CACJjB,IAAI,CAACM,GAAL;AAAA,qCAAS,WAAOY,GAAP,EAAe;AACtB,cAAMC,IAAI,WAAV;AACA,cAAMC,UAAU,GAAG,sBAAQD,IAAR,EAAcD,GAAd,CAAnB;;AAEA,cAAIE,UAAU,CAAClB,MAAf,EAAuB;AACrB;AACA,gBAAMmB,eAAe,GAAG,IAAIjB,GAAJ,CAAQgB,UAAU,CAACX,MAAX,CAAmBa,KAAD,IAAW,CAACnB,eAAe,CAACS,GAAhB,CAAoBU,KAApB,CAA9B,CAAR,CAAxB;;AAEA,gBAAID,eAAe,CAACV,IAApB,EAA0B;AACxB;AACA,kBAAMY,aAAa,SAAS5B,mBAAmB,CAC7C6B,KAAK,CAACC,IAAN,CAAWJ,eAAX,CAD6C,EAE7CxB,MAF6C,EAG7CM,eAH6C,CAA/C;;AAMA,kBAAIoB,aAAJ,aAAIA,aAAJ,eAAIA,aAAa,CAAErB,MAAnB,EAA2B;AACzBH,gBAAAA,UAAU,CAACe,IAAX,CAAgB,GAAGS,aAAnB;AACD;AACF;AACF;AACF,SArBD;;AAAA;AAAA;AAAA;AAAA,UADI,CAAN;AAwBD,KAnDD,CAqDA;AACA;;;AACA,QAAMG,gBAAgB,GAAG3B,UAAU,CAACU,MAAX,CAAkBI,OAAlB,EAA2Bc,MAA3B,CAAkC,CAACC,GAAD,EAAMC,GAAN,KAAc;AACvE,UAAID,GAAG,CAACE,IAAJ,CAAUZ,GAAD,IAASA,GAAG,CAACV,GAAJ,KAAYqB,GAAG,CAACrB,GAAlC,CAAJ,EAA4C;AAC1C,eAAOoB,GAAP;AACD;;AAED,aAAO,CAAC,GAAGA,GAAJ,EAASC,GAAT,CAAP;AACD,KANwB,EAMtB,EANsB,CAAzB;AAQA,WAAOH,gBAAP;AACD,G","sourcesContent":["import {extract} from '@sanity/mutator'\nimport {SanityDocument} from '../types'\n\n// Recursively fetch Documents from an array of _id's and their references\n// Heavy use of Set is to avoid recursively querying for id's already in the payload\nexport async function getDocumentsInArray(\n fetchIds: string[],\n client: any,\n currentIds?: Set<string>\n) {\n const collection = []\n\n // Find initial docs\n const data: SanityDocument[] = await client.fetch(`*[_id in $fetchIds]`, {\n fetchIds: fetchIds ?? [],\n })\n\n if (!data?.length) {\n return []\n }\n\n const localCurrentIds = currentIds ?? new Set()\n \n // Find new ids in the returned data\n // Unless we started with an empty set, get the _ids from the data\n const newDataIds: Set<string> = new Set(\n data\n .map((dataDoc) => dataDoc._id)\n .filter((id) => (currentIds?.size ? !localCurrentIds.has(id) : Boolean(id)))\n )\n\n if (newDataIds.size) {\n collection.push(...data)\n localCurrentIds.add(...newDataIds)\n\n // Check new data for more references\n await Promise.all(\n data.map(async (doc) => {\n const expr = `.._ref`\n const references = extract(expr, doc)\n\n if (references.length) {\n // Find references not already in the Collection\n const newReferenceIds = new Set(references.filter((refId) => !localCurrentIds.has(refId)))\n\n if (newReferenceIds.size) {\n // Recusive query for new documents\n const referenceDocs = await getDocumentsInArray(\n Array.from(newReferenceIds),\n client,\n localCurrentIds\n )\n\n if (referenceDocs?.length) {\n collection.push(...referenceDocs)\n }\n }\n }\n })\n )\n }\n\n // Create a unique array of objects from collection\n // Set() wasn't working for unique id's ¯\\_(ツ)_/¯\n const uniqueCollection = collection.filter(Boolean).reduce((acc, cur) => {\n if (acc.some((doc) => doc._id === cur._id)) {\n return acc\n }\n\n return [...acc, cur]\n }, []) \n\n return uniqueCollection\n}\n"],"file":"getDocumentsInArray.js"}
@@ -0,0 +1,30 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.createInitialMessage = createInitialMessage;
7
+ exports.stickyStyles = void 0;
8
+ exports.typeIsAsset = typeIsAsset;
9
+
10
+ function typeIsAsset() {
11
+ var type = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : "";
12
+ if (!type) return false;
13
+ return ['sanity.imageAsset', 'sanity.fileAsset'].includes(type);
14
+ }
15
+
16
+ function createInitialMessage() {
17
+ var docCount = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 0;
18
+ var refsCount = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 0;
19
+ var message = [docCount === 1 ? "This Document contains" : "These ".concat(docCount, " Documents contain"), refsCount === 1 ? "1 Reference." : "".concat(refsCount, " References."), refsCount === 1 ? "That Document" : "Those Documents", "may have References too. If referenced Documents do not exist at the target Destination, this transaction will fail."];
20
+ return message.join(" ");
21
+ }
22
+
23
+ var stickyStyles = {
24
+ position: 'sticky',
25
+ top: 0,
26
+ zIndex: 100,
27
+ backgroundColor: "rgba(255,255,255,0.95)"
28
+ };
29
+ exports.stickyStyles = stickyStyles;
30
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../src/helpers/index.ts"],"names":["typeIsAsset","type","includes","createInitialMessage","docCount","refsCount","message","join","stickyStyles","position","top","zIndex","backgroundColor"],"mappings":";;;;;;;;;AAAO,SAASA,WAAT,GAAgC;AAAA,MAAXC,IAAW;AACrC,MAAI,CAACA,IAAL,EAAW,OAAO,KAAP;AAEX,SAAO,CAAC,mBAAD,EAAsB,kBAAtB,EAA0CC,QAA1C,CAAmDD,IAAnD,CAAP;AACD;;AAEM,SAASE,oBAAT,GAA2D;AAAA,MAA7BC,QAA6B,uEAAlB,CAAkB;AAAA,MAAfC,SAAe,uEAAH,CAAG;AAChE,MAAMC,OAAO,GAAG,CACdF,QAAQ,KAAK,CAAb,8CAAqDA,QAArD,uBADc,EAEdC,SAAS,KAAK,CAAd,8BAAsCA,SAAtC,iBAFc,EAGdA,SAAS,KAAK,CAAd,sCAHc,yHAAhB;AAOA,SAAOC,OAAO,CAACC,IAAR,KAAP;AACD;;AAEM,IAAMC,YAAY,GAAG;AAC1BC,EAAAA,QAAQ,EAAE,QADgB;AAE1BC,EAAAA,GAAG,EAAE,CAFqB;AAG1BC,EAAAA,MAAM,EAAE,GAHkB;AAI1BC,EAAAA,eAAe;AAJW,CAArB","sourcesContent":["export function typeIsAsset(type = ``) {\n if (!type) return false\n\n return ['sanity.imageAsset', 'sanity.fileAsset'].includes(type)\n}\n\nexport function createInitialMessage(docCount = 0, refsCount = 0) {\n const message = [\n docCount === 1 ? `This Document contains` : `These ${docCount} Documents contain`,\n refsCount === 1 ? `1 Reference.` : `${refsCount} References.`,\n refsCount === 1 ? `That Document` : `Those Documents`,\n `may have References too. If referenced Documents do not exist at the target Destination, this transaction will fail.`\n ]\n\n return message.join(` `)\n}\n\nexport const stickyStyles = {\n position: 'sticky',\n top: 0,\n zIndex: 100,\n backgroundColor: `rgba(255,255,255,0.95)`,\n}"],"file":"index.js"}
package/lib/index.js ADDED
@@ -0,0 +1,24 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ Object.defineProperty(exports, "CrossDatasetDuplicator", {
7
+ enumerable: true,
8
+ get: function get() {
9
+ return _CrossDatasetDuplicator.default;
10
+ }
11
+ });
12
+ Object.defineProperty(exports, "DuplicateToAction", {
13
+ enumerable: true,
14
+ get: function get() {
15
+ return _DuplicateToAction.default;
16
+ }
17
+ });
18
+
19
+ var _DuplicateToAction = _interopRequireDefault(require("./actions/DuplicateToAction"));
20
+
21
+ var _CrossDatasetDuplicator = _interopRequireDefault(require("./components/CrossDatasetDuplicator"));
22
+
23
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
24
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/index.js"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;AAAA;;AACA","sourcesContent":["import DuplicateToAction from \"./actions/DuplicateToAction\";\nimport CrossDatasetDuplicator from \"./components/CrossDatasetDuplicator\";\n\nexport {\n DuplicateToAction,\n CrossDatasetDuplicator\n}"],"file":"index.js"}
@@ -0,0 +1,24 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.default = void 0;
7
+
8
+ var _icons = require("@sanity/icons");
9
+
10
+ var _crossDatasetDuplicator = _interopRequireDefault(require("config:@sanity/cross-dataset-duplicator"));
11
+
12
+ var _CrossDatasetDuplicator = _interopRequireDefault(require("../components/CrossDatasetDuplicator"));
13
+
14
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
15
+
16
+ var _default = _crossDatasetDuplicator.default !== null && _crossDatasetDuplicator.default !== void 0 && _crossDatasetDuplicator.default.tool ? {
17
+ title: 'Duplicator',
18
+ name: 'duplicator',
19
+ icon: _icons.LaunchIcon,
20
+ component: _CrossDatasetDuplicator.default
21
+ } : null;
22
+
23
+ exports.default = _default;
24
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../src/tool/index.ts"],"names":["config","tool","title","name","icon","LaunchIcon","component","CrossDatasetDuplicator"],"mappings":";;;;;;;AAAA;;AACA;;AAEA;;;;eAEeA,0HAAQC,IAAR,GACX;AACEC,EAAAA,KAAK,EAAE,YADT;AAEEC,EAAAA,IAAI,EAAE,YAFR;AAGEC,EAAAA,IAAI,EAAEC,iBAHR;AAIEC,EAAAA,SAAS,EAAEC;AAJb,CADW,GAOX,I","sourcesContent":["import {LaunchIcon} from '@sanity/icons'\nimport config from 'config:@sanity/cross-dataset-duplicator'\n\nimport CrossDatasetDuplicator from '../components/CrossDatasetDuplicator'\n\nexport default config?.tool\n ? {\n title: 'Duplicator',\n name: 'duplicator',\n icon: LaunchIcon,\n component: CrossDatasetDuplicator,\n }\n : null\n"],"file":"index.js"}
@@ -0,0 +1,2 @@
1
+ "use strict";
2
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":[],"names":[],"mappings":"","sourcesContent":[],"file":"index.js"}
package/package.json ADDED
@@ -0,0 +1,71 @@
1
+ {
2
+ "name": "@sanity/cross-dataset-duplicator",
3
+ "version": "0.3.0",
4
+ "description": "Empower content editors to migrate Documents and Assets between Sanity Projects and Datasets from inside Sanity Studio",
5
+ "main": "lib/index.js",
6
+ "scripts": {
7
+ "build": "sanipack build",
8
+ "watch": "sanipack build --watch",
9
+ "_postinstall": "husky install",
10
+ "prepublishOnly": "pinst --disable && sanipack build && sanipack verify",
11
+ "postpublish": "pinst --enable",
12
+ "lint": "eslint .",
13
+ "lint:fix": "eslint . --fix"
14
+ },
15
+ "husky": {
16
+ "hooks": {
17
+ "pre-commit": "npm run lint:fix"
18
+ }
19
+ },
20
+ "repository": {
21
+ "type": "git",
22
+ "url": "git+ssh://git@github.com/@sanity-io/cross-dataset-duplicator.git"
23
+ },
24
+ "keywords": [
25
+ "sanity",
26
+ "sanity-plugin"
27
+ ],
28
+ "author": "Sanity.io <hello@sanity.io>",
29
+ "license": "MIT",
30
+ "dependencies": {
31
+ "@sanity/icons": "^1.2.5",
32
+ "@sanity/mutator": "^2.13.0",
33
+ "@sanity/ui": "^0.36.15",
34
+ "async": "^3.2.1",
35
+ "dset": "^3.1.0",
36
+ "husky": "^7.0.1",
37
+ "prop-types": "15.7.2",
38
+ "sanity-secrets": "^0.0.6",
39
+ "styled-components": "^5.3.3"
40
+ },
41
+ "devDependencies": {
42
+ "eslint": "7.31.0",
43
+ "eslint-config-prettier": "^8.3.0",
44
+ "eslint-config-sanity": "5.1.0",
45
+ "eslint-plugin-react": "^7.24.0",
46
+ "pinst": "^2.1.6",
47
+ "prettier": "^2.3.2",
48
+ "sanipack": "^2.1.0"
49
+ },
50
+ "peerDependencies": {
51
+ "react": "^17.0.0"
52
+ },
53
+ "bugs": {
54
+ "url": "https://github.com/@sanity-io/cross-dataset-duplicator/issues"
55
+ },
56
+ "homepage": "https://github.com/@sanity-io/cross-dataset-duplicator#readme",
57
+ "prettier": {
58
+ "semi": false,
59
+ "printWidth": 100,
60
+ "bracketSpacing": false,
61
+ "singleQuote": true
62
+ },
63
+ "eslintConfig": {
64
+ "parser": "sanipack/babel/eslint-parser",
65
+ "extends": [
66
+ "sanity",
67
+ "sanity/react",
68
+ "prettier"
69
+ ]
70
+ }
71
+ }
package/sanity.json ADDED
@@ -0,0 +1,16 @@
1
+ {
2
+ "paths": {
3
+ "source": "./src",
4
+ "compiled": "./lib"
5
+ },
6
+ "parts": [
7
+ {
8
+ "implements": "part:@sanity/base/tool",
9
+ "path": "tool/index"
10
+ },
11
+ {
12
+ "implements": "part:@sanity/base/document-actions/resolver",
13
+ "path": "actions/index"
14
+ }
15
+ ]
16
+ }
@@ -0,0 +1,22 @@
1
+ import React, {useState} from 'react'
2
+ import {LaunchIcon} from '@sanity/icons'
3
+
4
+ import CrossDatasetDuplicator from '../components/CrossDatasetDuplicator'
5
+
6
+ export default function DuplicateToAction({draft, published, onComplete}) {
7
+ const [dialogOpen, setDialogOpen] = useState(false)
8
+
9
+ return {
10
+ disabled: draft,
11
+ title: draft ? `Document must be Published to begin` : null,
12
+ label: 'Duplicate to...',
13
+ dialog: dialogOpen && published && {
14
+ type: 'modal',
15
+ title: 'Cross Dataset Duplicator',
16
+ content: <CrossDatasetDuplicator docs={[published]} mode="action" />,
17
+ onClose: () => onComplete(),
18
+ },
19
+ onHandle: () => setDialogOpen(true),
20
+ icon: LaunchIcon,
21
+ }
22
+ }
@@ -0,0 +1,22 @@
1
+ import defaultResolve, {DuplicateAction} from 'part:@sanity/base/document-actions'
2
+ import config from 'config:@sanity/cross-dataset-duplicator'
3
+
4
+ import DuplicateToAction from './DuplicateToAction'
5
+
6
+ export default function resolveDocumentActions(props) {
7
+ const duplicatorTypes = config?.types ?? []
8
+ const defaultActions = defaultResolve(props)
9
+
10
+ // Insert 'Duplicate to...' after 'Duplicate' only on config'd types
11
+ if (duplicatorTypes.includes(props?.type)) {
12
+ return defaultActions.reduce((acc, cur) => {
13
+ if (cur === DuplicateAction) {
14
+ return [...acc, cur, DuplicateToAction]
15
+ }
16
+
17
+ return [...acc, cur]
18
+ }, [])
19
+ }
20
+
21
+ return defaultActions
22
+ }