@sanity/orderable-document-list 0.0.10 → 1.0.0-v3-studio.2

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 (61) hide show
  1. package/LICENSE +1 -1
  2. package/README.md +135 -55
  3. package/lib/index.d.ts +31 -0
  4. package/lib/index.d.ts.map +1 -0
  5. package/lib/index.js +827 -30
  6. package/lib/index.js.map +1 -1
  7. package/lib/index.modern.js +818 -0
  8. package/lib/index.modern.js.map +1 -0
  9. package/package.json +57 -23
  10. package/src/{Document.js → Document.tsx} +30 -27
  11. package/src/{DocumentListQuery.js → DocumentListQuery.tsx} +27 -23
  12. package/src/{DocumentListWrapper.js → DocumentListWrapper.tsx} +24 -29
  13. package/src/DraggableList.tsx +304 -0
  14. package/src/{Feedback.js → Feedback.tsx} +2 -7
  15. package/src/OrderableContext.ts +7 -0
  16. package/src/{OrderableDocumentList.js → OrderableDocumentList.tsx} +23 -12
  17. package/src/desk-structure/{orderableDocumentListDeskItem.js → orderableDocumentListDeskItem.ts} +24 -10
  18. package/src/fields/{orderRankField.js → orderRankField.ts} +12 -10
  19. package/src/fields/{orderRankOrdering.js → orderRankOrdering.ts} +0 -0
  20. package/src/helpers/client.ts +5 -0
  21. package/src/helpers/constants.ts +1 -0
  22. package/src/helpers/{initialRank.js → initialRank.ts} +2 -2
  23. package/src/helpers/{reorderDocuments.js → reorderDocuments.ts} +33 -44
  24. package/src/helpers/{resetOrder.js → resetOrder.ts} +3 -8
  25. package/src/index.ts +9 -0
  26. package/.babelrc +0 -3
  27. package/.eslintignore +0 -1
  28. package/.eslintrc.js +0 -50
  29. package/lib/Document.js +0 -101
  30. package/lib/Document.js.map +0 -1
  31. package/lib/DocumentListQuery.js +0 -163
  32. package/lib/DocumentListQuery.js.map +0 -1
  33. package/lib/DocumentListWrapper.js +0 -107
  34. package/lib/DocumentListWrapper.js.map +0 -1
  35. package/lib/DraggableList.js +0 -314
  36. package/lib/DraggableList.js.map +0 -1
  37. package/lib/Feedback.js +0 -31
  38. package/lib/Feedback.js.map +0 -1
  39. package/lib/OrderableContext.js +0 -15
  40. package/lib/OrderableContext.js.map +0 -1
  41. package/lib/OrderableDocumentList.js +0 -103
  42. package/lib/OrderableDocumentList.js.map +0 -1
  43. package/lib/desk-structure/orderableDocumentListDeskItem.js +0 -57
  44. package/lib/desk-structure/orderableDocumentListDeskItem.js.map +0 -1
  45. package/lib/fields/orderRankField.js +0 -64
  46. package/lib/fields/orderRankField.js.map +0 -1
  47. package/lib/fields/orderRankOrdering.js +0 -19
  48. package/lib/fields/orderRankOrdering.js.map +0 -1
  49. package/lib/helpers/constants.js +0 -9
  50. package/lib/helpers/constants.js.map +0 -1
  51. package/lib/helpers/initialRank.js +0 -18
  52. package/lib/helpers/initialRank.js.map +0 -1
  53. package/lib/helpers/reorderDocuments.js +0 -131
  54. package/lib/helpers/reorderDocuments.js.map +0 -1
  55. package/lib/helpers/resetOrder.js +0 -62
  56. package/lib/helpers/resetOrder.js.map +0 -1
  57. package/sanity.json +0 -7
  58. package/src/DraggableList.js +0 -276
  59. package/src/OrderableContext.js +0 -3
  60. package/src/helpers/constants.js +0 -1
  61. package/src/index.js +0 -5
package/src/index.ts ADDED
@@ -0,0 +1,9 @@
1
+ import {orderRankField, RankFieldConfig} from './fields/orderRankField'
2
+ import {orderRankOrdering} from './fields/orderRankOrdering'
3
+ import {
4
+ orderableDocumentListDeskItem,
5
+ type OrderableListConfig,
6
+ } from './desk-structure/orderableDocumentListDeskItem'
7
+
8
+ export type {OrderableListConfig, RankFieldConfig}
9
+ export {orderRankField, orderRankOrdering, orderableDocumentListDeskItem}
package/.babelrc DELETED
@@ -1,3 +0,0 @@
1
- {
2
- "extends": "sanipack/babel"
3
- }
package/.eslintignore DELETED
@@ -1 +0,0 @@
1
- lib
package/.eslintrc.js DELETED
@@ -1,50 +0,0 @@
1
- module.exports = {
2
- root: true,
3
- parser: '@typescript-eslint/parser',
4
- env: {
5
- node: true,
6
- browser: true,
7
- },
8
- settings: {
9
- react: {version: '16.9.0'},
10
- },
11
- extends: [
12
- 'sanity',
13
- 'sanity/react',
14
- 'sanity/import',
15
- 'plugin:react-hooks/recommended',
16
- 'prettier',
17
- ],
18
- rules: {
19
- 'no-use-before-define': 'off',
20
- '@typescript-eslint/no-var-requires': 'off',
21
- 'import/no-extraneous-dependencies': 'off', // because of parts
22
- 'import/no-unresolved': ['error', {ignore: ['.*:.*']}], // because of parts
23
- 'prettier/prettier': [
24
- 'error',
25
- {
26
- semi: false,
27
- printWidth: 100,
28
- bracketSpacing: false,
29
- singleQuote: true,
30
- },
31
- ],
32
- 'sort-imports': 'off', // prefer import/order
33
- 'react/jsx-no-bind': [
34
- 1,
35
- {
36
- ignoreDOMComponents: true,
37
- },
38
- ],
39
- 'react/forbid-prop-types': [0],
40
- },
41
- plugins: ['prettier', 'react'],
42
- overrides: [
43
- {
44
- files: ['*.ts', '*.tsx'],
45
- rules: {
46
- 'no-undef': 'off',
47
- },
48
- },
49
- ],
50
- }
package/lib/Document.js DELETED
@@ -1,101 +0,0 @@
1
- "use strict";
2
-
3
- Object.defineProperty(exports, "__esModule", {
4
- value: true
5
- });
6
- exports.default = Document;
7
-
8
- var _propTypes = _interopRequireDefault(require("prop-types"));
9
-
10
- var _react = _interopRequireWildcard(require("react"));
11
-
12
- var _icons = require("@sanity/icons");
13
-
14
- var _ui = require("@sanity/ui");
15
-
16
- var _preview = _interopRequireDefault(require("part:@sanity/base/preview"));
17
-
18
- var _schema = _interopRequireDefault(require("part:@sanity/base/schema"));
19
-
20
- var _OrderableContext = require("./OrderableContext");
21
-
22
- 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); }
23
-
24
- 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; }
25
-
26
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
27
-
28
- // eslint-disable-next-line no-unused-vars
29
- function Document(_ref) {
30
- var doc = _ref.doc,
31
- increment = _ref.increment,
32
- entities = _ref.entities,
33
- handleSelect = _ref.handleSelect,
34
- index = _ref.index,
35
- isFirst = _ref.isFirst,
36
- isLast = _ref.isLast;
37
-
38
- var _useContext = (0, _react.useContext)(_OrderableContext.OrderableContext),
39
- showIncrements = _useContext.showIncrements;
40
-
41
- return /*#__PURE__*/_react.default.createElement(_ui.Flex, {
42
- align: "center"
43
- }, /*#__PURE__*/_react.default.createElement(_ui.Box, {
44
- paddingX: 3,
45
- style: {
46
- flexShrink: 0
47
- }
48
- }, /*#__PURE__*/_react.default.createElement(_ui.Text, {
49
- fontSize: 4
50
- }, /*#__PURE__*/_react.default.createElement(_icons.DragHandleIcon, null))), showIncrements && /*#__PURE__*/_react.default.createElement(_ui.Flex, {
51
- style: {
52
- flexShrink: 0
53
- },
54
- align: "center",
55
- gap: 1,
56
- paddingRight: 1
57
- }, /*#__PURE__*/_react.default.createElement(_ui.Button, {
58
- padding: 2,
59
- mode: "ghost",
60
- onClick: () => increment(index, index + -1, doc._id, entities),
61
- disabled: isFirst,
62
- icon: _icons.ChevronUpIcon
63
- }), /*#__PURE__*/_react.default.createElement(_ui.Button, {
64
- padding: 2,
65
- mode: "ghost",
66
- disabled: isLast,
67
- onClick: () => increment(index, index + 1, doc._id, entities),
68
- icon: _icons.ChevronDownIcon
69
- })), /*#__PURE__*/_react.default.createElement(_ui.Button, {
70
- style: {
71
- width: "100%"
72
- },
73
- padding: 2,
74
- mode: "bleed",
75
- onClick: e => handleSelect(doc._id, index, e.nativeEvent)
76
- }, /*#__PURE__*/_react.default.createElement(_ui.Flex, {
77
- flex: 1,
78
- align: "center"
79
- }, /*#__PURE__*/_react.default.createElement(_ui.Box, {
80
- flex: 1
81
- }, /*#__PURE__*/_react.default.createElement(_preview.default, {
82
- value: doc,
83
- type: _schema.default.get(doc._type)
84
- })))));
85
- }
86
-
87
- Document.propTypes = {
88
- doc: _propTypes.default.shape({
89
- _id: _propTypes.default.string,
90
- _type: _propTypes.default.string
91
- }).isRequired,
92
- entities: _propTypes.default.arrayOf(_propTypes.default.shape({
93
- _id: _propTypes.default.string
94
- }).isRequired).isRequired,
95
- handleSelect: _propTypes.default.func.isRequired,
96
- increment: _propTypes.default.func.isRequired,
97
- index: _propTypes.default.number.isRequired,
98
- isFirst: _propTypes.default.bool.isRequired,
99
- isLast: _propTypes.default.bool.isRequired
100
- };
101
- //# sourceMappingURL=Document.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"Document.js","names":["Document","doc","increment","entities","handleSelect","index","isFirst","isLast","useContext","OrderableContext","showIncrements","flexShrink","_id","ChevronUpIcon","ChevronDownIcon","width","e","nativeEvent","schema","get","_type","propTypes","PropTypes","shape","string","isRequired","arrayOf","func","number","bool"],"sources":["../src/Document.js"],"sourcesContent":["import PropTypes from 'prop-types'\n// eslint-disable-next-line no-unused-vars\nimport React, {useContext} from 'react'\nimport {DragHandleIcon, ChevronUpIcon, ChevronDownIcon} from '@sanity/icons'\nimport {Text, Flex, Box, Button} from '@sanity/ui'\nimport Preview from 'part:@sanity/base/preview'\nimport schema from 'part:@sanity/base/schema'\n\nimport {OrderableContext} from './OrderableContext'\n\nexport default function Document({doc, increment, entities, handleSelect, index, isFirst, isLast}) {\n const {showIncrements} = useContext(OrderableContext)\n\n return (\n <Flex align=\"center\">\n <Box paddingX={3} style={{flexShrink: 0}}>\n <Text fontSize={4}>\n <DragHandleIcon />\n </Text>\n </Box>\n {showIncrements && (\n <Flex style={{flexShrink: 0}} align=\"center\" gap={1} paddingRight={1}>\n <Button\n padding={2}\n mode=\"ghost\"\n onClick={() => increment(index, index + -1, doc._id, entities)}\n disabled={isFirst}\n icon={ChevronUpIcon}\n />\n <Button\n padding={2}\n mode=\"ghost\"\n disabled={isLast}\n onClick={() => increment(index, index + 1, doc._id, entities)}\n icon={ChevronDownIcon}\n />\n </Flex>\n )}\n <Button\n style={{width: `100%`}}\n padding={2}\n mode=\"bleed\"\n onClick={(e) => handleSelect(doc._id, index, e.nativeEvent)}\n >\n <Flex flex={1} align=\"center\">\n <Box flex={1}>\n <Preview value={doc} type={schema.get(doc._type)} />\n </Box>\n </Flex>\n </Button>\n </Flex>\n )\n}\n\nDocument.propTypes = {\n doc: PropTypes.shape({\n _id: PropTypes.string,\n _type: PropTypes.string,\n }).isRequired,\n entities: PropTypes.arrayOf(\n PropTypes.shape({\n _id: PropTypes.string,\n }).isRequired\n ).isRequired,\n handleSelect: PropTypes.func.isRequired,\n increment: PropTypes.func.isRequired,\n index: PropTypes.number.isRequired,\n isFirst: PropTypes.bool.isRequired,\n isLast: PropTypes.bool.isRequired,\n}\n"],"mappings":"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"}
@@ -1,163 +0,0 @@
1
- "use strict";
2
-
3
- Object.defineProperty(exports, "__esModule", {
4
- value: true
5
- });
6
- exports.default = DocumentListQuery;
7
-
8
- var _propTypes = _interopRequireDefault(require("prop-types"));
9
-
10
- var _react = _interopRequireWildcard(require("react"));
11
-
12
- var _client = _interopRequireDefault(require("part:@sanity/base/client"));
13
-
14
- var _ui = require("@sanity/ui");
15
-
16
- var _DraggableList = _interopRequireDefault(require("./DraggableList"));
17
-
18
- var _constants = require("./helpers/constants");
19
-
20
- var _Feedback = _interopRequireDefault(require("./Feedback"));
21
-
22
- 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); }
23
-
24
- 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; }
25
-
26
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
27
-
28
- 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); } }
29
-
30
- 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); }); }; }
31
-
32
- function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }
33
-
34
- 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."); }
35
-
36
- 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); }
37
-
38
- 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; }
39
-
40
- 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; }
41
-
42
- function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }
43
-
44
- var client = _client.default.withConfig({
45
- apiVersion: '2021-09-01'
46
- });
47
-
48
- function DocumentListQuery(_ref) {
49
- var type = _ref.type,
50
- filter = _ref.filter,
51
- params = _ref.params;
52
-
53
- var _useState = (0, _react.useState)(true),
54
- _useState2 = _slicedToArray(_useState, 2),
55
- isLoading = _useState2[0],
56
- setIsLoading = _useState2[1];
57
-
58
- var _useState3 = (0, _react.useState)(false),
59
- _useState4 = _slicedToArray(_useState3, 2),
60
- listIsUpdating = _useState4[0],
61
- setListIsUpdating = _useState4[1];
62
-
63
- var _useState5 = (0, _react.useState)([]),
64
- _useState6 = _slicedToArray(_useState5, 2),
65
- data = _useState6[0],
66
- setData = _useState6[1];
67
-
68
- (0, _react.useEffect)(() => {
69
- var query = "*[_type == $type ".concat(filter ? "&& ".concat(filter) : '', "]|order(@[$order] asc){\n _id, _type, ").concat(_constants.ORDER_FIELD_NAME, "\n }");
70
- var queryParams = Object.assign(params, {
71
- type,
72
- order: _constants.ORDER_FIELD_NAME
73
- });
74
- var subscription = null; // eslint-disable-next-line require-await
75
-
76
- var fetchData = /*#__PURE__*/function () {
77
- var _ref2 = _asyncToGenerator(function* () {
78
- client.fetch(query, queryParams).then(documents => {
79
- // Remove published document from list if draft also exists
80
- var filteredDocuments = documents.reduce((acc, cur) => {
81
- if (!cur._id.startsWith("drafts.")) {
82
- // eslint-disable-next-line max-nested-callbacks
83
- var alsoHasDraft = documents.some(doc => doc._id === "drafts.".concat(cur._id));
84
- return alsoHasDraft ? acc : [...acc, cur];
85
- }
86
-
87
- return [...acc, cur];
88
- }, []);
89
- setData(filteredDocuments);
90
-
91
- if (isLoading) {
92
- setIsLoading(false);
93
- }
94
- });
95
- });
96
-
97
- return function fetchData() {
98
- return _ref2.apply(this, arguments);
99
- };
100
- }();
101
-
102
- var prepareData = /*#__PURE__*/function () {
103
- var _ref3 = _asyncToGenerator(function* () {
104
- setIsLoading(true);
105
- yield fetchData();
106
-
107
- if (!subscription) {
108
- subscription = client.listen(query, queryParams).subscribe(() => fetchData());
109
- }
110
- });
111
-
112
- return function prepareData() {
113
- return _ref3.apply(this, arguments);
114
- };
115
- }(); // Get data but only if a document isn't being patched or we don't yet have data
116
-
117
-
118
- if (!listIsUpdating && !data.length) {
119
- prepareData();
120
- }
121
-
122
- return () => {
123
- var _subscription;
124
-
125
- return (_subscription = subscription) === null || _subscription === void 0 ? void 0 : _subscription.unsubscribe();
126
- };
127
- /* eslint-disable-next-line react-hooks/exhaustive-deps */
128
- }, [type]);
129
- var unorderedDataCount = (0, _react.useMemo)(() => data.length ? data.filter(doc => !doc[_constants.ORDER_FIELD_NAME]).length : 0, [data]);
130
- if (isLoading) return /*#__PURE__*/_react.default.createElement(_ui.Flex, {
131
- style: {
132
- width: "100%",
133
- height: "100%"
134
- },
135
- align: "center",
136
- justify: "center"
137
- }, /*#__PURE__*/_react.default.createElement(_ui.Spinner, null));
138
- return /*#__PURE__*/_react.default.createElement(_ui.Stack, {
139
- space: 1,
140
- style: {
141
- overflow: "scroll",
142
- height: "100%"
143
- }
144
- }, unorderedDataCount > 0 && /*#__PURE__*/_react.default.createElement(_Feedback.default, null, unorderedDataCount, "/", data.length, " Documents have no Order. Select", ' ', /*#__PURE__*/_react.default.createElement("strong", null, "Reset Order"), " from the Menu above to fix."), /*#__PURE__*/_react.default.createElement(_ui.Box, {
145
- padding: 1
146
- }, /*#__PURE__*/_react.default.createElement(_DraggableList.default, {
147
- data: data,
148
- type: type,
149
- listIsUpdating: listIsUpdating,
150
- setListIsUpdating: setListIsUpdating
151
- })));
152
- }
153
-
154
- DocumentListQuery.propTypes = {
155
- type: _propTypes.default.string.isRequired,
156
- filter: _propTypes.default.string,
157
- params: _propTypes.default.object
158
- };
159
- DocumentListQuery.defaultProps = {
160
- filter: "",
161
- params: {}
162
- };
163
- //# sourceMappingURL=DocumentListQuery.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"DocumentListQuery.js","names":["client","sanityClient","withConfig","apiVersion","DocumentListQuery","type","filter","params","useState","isLoading","setIsLoading","listIsUpdating","setListIsUpdating","data","setData","useEffect","query","ORDER_FIELD_NAME","queryParams","Object","assign","order","subscription","fetchData","fetch","then","documents","filteredDocuments","reduce","acc","cur","_id","startsWith","alsoHasDraft","some","doc","prepareData","listen","subscribe","length","unsubscribe","unorderedDataCount","useMemo","width","height","overflow","propTypes","PropTypes","string","isRequired","object","defaultProps"],"sources":["../src/DocumentListQuery.js"],"sourcesContent":["import PropTypes from 'prop-types'\nimport React, {useEffect, useState, useMemo} from 'react'\nimport sanityClient from 'part:@sanity/base/client'\nimport {Stack, Box, Flex, Spinner} from '@sanity/ui'\n\nimport DraggableList from './DraggableList'\nimport {ORDER_FIELD_NAME} from './helpers/constants'\nimport Feedback from './Feedback'\n\nconst client = sanityClient.withConfig({\n apiVersion: '2021-09-01',\n})\n\nexport default function DocumentListQuery({type, filter, params}) {\n const [isLoading, setIsLoading] = useState(true)\n const [listIsUpdating, setListIsUpdating] = useState(false)\n const [data, setData] = useState([])\n\n useEffect(() => {\n const query = `*[_type == $type ${filter ? `&& ${filter}` : ''}]|order(@[$order] asc){\n _id, _type, ${ORDER_FIELD_NAME}\n }`\n const queryParams = Object.assign(params, {type, order: ORDER_FIELD_NAME})\n let subscription = null\n\n // eslint-disable-next-line require-await\n const fetchData = async () => {\n client.fetch(query, queryParams).then((documents) => {\n // Remove published document from list if draft also exists\n const filteredDocuments = documents.reduce((acc, cur) => {\n if (!cur._id.startsWith(`drafts.`)) {\n // eslint-disable-next-line max-nested-callbacks\n const alsoHasDraft = documents.some((doc) => doc._id === `drafts.${cur._id}`)\n\n return alsoHasDraft ? acc : [...acc, cur]\n }\n\n return [...acc, cur]\n }, [])\n\n setData(filteredDocuments)\n\n if (isLoading) {\n setIsLoading(false)\n }\n })\n }\n\n const prepareData = async () => {\n setIsLoading(true)\n\n await fetchData()\n\n if (!subscription) {\n subscription = client.listen(query, queryParams).subscribe(() => fetchData())\n }\n }\n\n // Get data but only if a document isn't being patched or we don't yet have data\n if (!listIsUpdating && !data.length) {\n prepareData()\n }\n\n return () => subscription?.unsubscribe()\n /* eslint-disable-next-line react-hooks/exhaustive-deps */\n }, [type])\n\n const unorderedDataCount = useMemo(\n () => (data.length ? data.filter((doc) => !doc[ORDER_FIELD_NAME]).length : 0),\n [data]\n )\n\n if (isLoading)\n return (\n <Flex style={{width: `100%`, height: `100%`}} align=\"center\" justify=\"center\">\n <Spinner />\n </Flex>\n )\n\n return (\n <Stack space={1} style={{overflow: `scroll`, height: `100%`}}>\n {unorderedDataCount > 0 && (\n <Feedback>\n {unorderedDataCount}/{data.length} Documents have no Order. Select{' '}\n <strong>Reset Order</strong> from the Menu above to fix.\n </Feedback>\n )}\n <Box padding={1}>\n <DraggableList\n data={data}\n type={type}\n listIsUpdating={listIsUpdating}\n setListIsUpdating={setListIsUpdating}\n />\n </Box>\n </Stack>\n )\n}\n\nDocumentListQuery.propTypes = {\n type: PropTypes.string.isRequired,\n filter: PropTypes.string,\n params: PropTypes.object,\n}\n\nDocumentListQuery.defaultProps = {\n filter: ``,\n params: {},\n}\n"],"mappings":";;;;;;;AAAA;;AACA;;AACA;;AACA;;AAEA;;AACA;;AACA;;;;;;;;;;;;;;;;;;;;;;;;AAEA,IAAMA,MAAM,GAAGC,eAAA,CAAaC,UAAb,CAAwB;EACrCC,UAAU,EAAE;AADyB,CAAxB,CAAf;;AAIe,SAASC,iBAAT,OAAmD;EAAA,IAAvBC,IAAuB,QAAvBA,IAAuB;EAAA,IAAjBC,MAAiB,QAAjBA,MAAiB;EAAA,IAATC,MAAS,QAATA,MAAS;;EAChE,gBAAkC,IAAAC,eAAA,EAAS,IAAT,CAAlC;EAAA;EAAA,IAAOC,SAAP;EAAA,IAAkBC,YAAlB;;EACA,iBAA4C,IAAAF,eAAA,EAAS,KAAT,CAA5C;EAAA;EAAA,IAAOG,cAAP;EAAA,IAAuBC,iBAAvB;;EACA,iBAAwB,IAAAJ,eAAA,EAAS,EAAT,CAAxB;EAAA;EAAA,IAAOK,IAAP;EAAA,IAAaC,OAAb;;EAEA,IAAAC,gBAAA,EAAU,MAAM;IACd,IAAMC,KAAK,8BAAuBV,MAAM,gBAASA,MAAT,IAAoB,EAAjD,wDACKW,2BADL,YAAX;IAGA,IAAMC,WAAW,GAAGC,MAAM,CAACC,MAAP,CAAcb,MAAd,EAAsB;MAACF,IAAD;MAAOgB,KAAK,EAAEJ;IAAd,CAAtB,CAApB;IACA,IAAIK,YAAY,GAAG,IAAnB,CALc,CAOd;;IACA,IAAMC,SAAS;MAAA,8BAAG,aAAY;QAC5BvB,MAAM,CAACwB,KAAP,CAAaR,KAAb,EAAoBE,WAApB,EAAiCO,IAAjC,CAAuCC,SAAD,IAAe;UACnD;UACA,IAAMC,iBAAiB,GAAGD,SAAS,CAACE,MAAV,CAAiB,CAACC,GAAD,EAAMC,GAAN,KAAc;YACvD,IAAI,CAACA,GAAG,CAACC,GAAJ,CAAQC,UAAR,WAAL,EAAoC;cAClC;cACA,IAAMC,YAAY,GAAGP,SAAS,CAACQ,IAAV,CAAgBC,GAAD,IAASA,GAAG,CAACJ,GAAJ,sBAAsBD,GAAG,CAACC,GAA1B,CAAxB,CAArB;cAEA,OAAOE,YAAY,GAAGJ,GAAH,GAAS,CAAC,GAAGA,GAAJ,EAASC,GAAT,CAA5B;YACD;;YAED,OAAO,CAAC,GAAGD,GAAJ,EAASC,GAAT,CAAP;UACD,CATyB,EASvB,EATuB,CAA1B;UAWAhB,OAAO,CAACa,iBAAD,CAAP;;UAEA,IAAIlB,SAAJ,EAAe;YACbC,YAAY,CAAC,KAAD,CAAZ;UACD;QACF,CAlBD;MAmBD,CApBc;;MAAA,gBAATa,SAAS;QAAA;MAAA;IAAA,GAAf;;IAsBA,IAAMa,WAAW;MAAA,8BAAG,aAAY;QAC9B1B,YAAY,CAAC,IAAD,CAAZ;QAEA,MAAMa,SAAS,EAAf;;QAEA,IAAI,CAACD,YAAL,EAAmB;UACjBA,YAAY,GAAGtB,MAAM,CAACqC,MAAP,CAAcrB,KAAd,EAAqBE,WAArB,EAAkCoB,SAAlC,CAA4C,MAAMf,SAAS,EAA3D,CAAf;QACD;MACF,CARgB;;MAAA,gBAAXa,WAAW;QAAA;MAAA;IAAA,GAAjB,CA9Bc,CAwCd;;;IACA,IAAI,CAACzB,cAAD,IAAmB,CAACE,IAAI,CAAC0B,MAA7B,EAAqC;MACnCH,WAAW;IACZ;;IAED,OAAO;MAAA;;MAAA,wBAAMd,YAAN,kDAAM,cAAckB,WAAd,EAAN;IAAA,CAAP;IACA;EACD,CA/CD,EA+CG,CAACnC,IAAD,CA/CH;EAiDA,IAAMoC,kBAAkB,GAAG,IAAAC,cAAA,EACzB,MAAO7B,IAAI,CAAC0B,MAAL,GAAc1B,IAAI,CAACP,MAAL,CAAa6B,GAAD,IAAS,CAACA,GAAG,CAAClB,2BAAD,CAAzB,EAA6CsB,MAA3D,GAAoE,CADlD,EAEzB,CAAC1B,IAAD,CAFyB,CAA3B;EAKA,IAAIJ,SAAJ,EACE,oBACE,6BAAC,QAAD;IAAM,KAAK,EAAE;MAACkC,KAAK,QAAN;MAAgBC,MAAM;IAAtB,CAAb;IAA8C,KAAK,EAAC,QAApD;IAA6D,OAAO,EAAC;EAArE,gBACE,6BAAC,WAAD,OADF,CADF;EAMF,oBACE,6BAAC,SAAD;IAAO,KAAK,EAAE,CAAd;IAAiB,KAAK,EAAE;MAACC,QAAQ,UAAT;MAAqBD,MAAM;IAA3B;EAAxB,GACGH,kBAAkB,GAAG,CAArB,iBACC,6BAAC,iBAAD,QACGA,kBADH,OACwB5B,IAAI,CAAC0B,MAD7B,sCACqE,GADrE,eAEE,2DAFF,iCAFJ,eAOE,6BAAC,OAAD;IAAK,OAAO,EAAE;EAAd,gBACE,6BAAC,sBAAD;IACE,IAAI,EAAE1B,IADR;IAEE,IAAI,EAAER,IAFR;IAGE,cAAc,EAAEM,cAHlB;IAIE,iBAAiB,EAAEC;EAJrB,EADF,CAPF,CADF;AAkBD;;AAEDR,iBAAiB,CAAC0C,SAAlB,GAA8B;EAC5BzC,IAAI,EAAE0C,kBAAA,CAAUC,MAAV,CAAiBC,UADK;EAE5B3C,MAAM,EAAEyC,kBAAA,CAAUC,MAFU;EAG5BzC,MAAM,EAAEwC,kBAAA,CAAUG;AAHU,CAA9B;AAMA9C,iBAAiB,CAAC+C,YAAlB,GAAiC;EAC/B7C,MAAM,IADyB;EAE/BC,MAAM,EAAE;AAFuB,CAAjC"}
@@ -1,107 +0,0 @@
1
- "use strict";
2
-
3
- Object.defineProperty(exports, "__esModule", {
4
- value: true
5
- });
6
- exports.default = DocumentListWrapper;
7
-
8
- var _propTypes = _interopRequireDefault(require("prop-types"));
9
-
10
- var _react = _interopRequireWildcard(require("react"));
11
-
12
- var _schema = _interopRequireDefault(require("part:@sanity/base/schema"));
13
-
14
- var _ui = require("@sanity/ui");
15
-
16
- var _deskTool = require("@sanity/desk-tool");
17
-
18
- var _DocumentListQuery = _interopRequireDefault(require("./DocumentListQuery"));
19
-
20
- var _OrderableContext = require("./OrderableContext");
21
-
22
- var _constants = require("./helpers/constants");
23
-
24
- var _Feedback = _interopRequireDefault(require("./Feedback"));
25
-
26
- 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); }
27
-
28
- 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; }
29
-
30
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
31
-
32
- // 1. Validate first that the schema has been configured for ordering
33
- // 2. Setup context for showIncrements
34
- function DocumentListWrapper(_ref) {
35
- var type = _ref.type,
36
- filter = _ref.filter,
37
- params = _ref.params,
38
- showIncrements = _ref.showIncrements,
39
- resetOrderTransaction = _ref.resetOrderTransaction;
40
- var toast = (0, _ui.useToast)();
41
- (0, _react.useEffect)(() => {
42
- if (resetOrderTransaction !== null && resetOrderTransaction !== void 0 && resetOrderTransaction.title && resetOrderTransaction !== null && resetOrderTransaction !== void 0 && resetOrderTransaction.status) {
43
- toast.push(resetOrderTransaction);
44
- }
45
- /* eslint-disable-next-line react-hooks/exhaustive-deps */
46
-
47
- }, [resetOrderTransaction]);
48
- var schemaIsInvalid = (0, _react.useMemo)(() => {
49
- // Option not passed
50
- if (!type) {
51
- return /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, "No ", /*#__PURE__*/_react.default.createElement("code", null, "type"), " was configured");
52
- }
53
-
54
- var typeSchema = _schema.default.get(type); // Schema not found
55
-
56
-
57
- if (!typeSchema) {
58
- return /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, "Schema ", /*#__PURE__*/_react.default.createElement("code", null, type), " not found");
59
- } // Schema lacks an order field
60
-
61
-
62
- if (!typeSchema.fields.some(field => (field === null || field === void 0 ? void 0 : field.name) === _constants.ORDER_FIELD_NAME)) {
63
- return /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, "Schema ", /*#__PURE__*/_react.default.createElement("code", null, type), " must have an ", /*#__PURE__*/_react.default.createElement("code", null, "order"), " field of type", ' ', /*#__PURE__*/_react.default.createElement("code", null, "string"));
64
- } // Schema's order field is not a string
65
-
66
-
67
- if (typeSchema.fields.some(field => {
68
- var _field$type;
69
-
70
- return (field === null || field === void 0 ? void 0 : field.name) === _constants.ORDER_FIELD_NAME && (field === null || field === void 0 ? void 0 : (_field$type = field.type) === null || _field$type === void 0 ? void 0 : _field$type.name) !== 'string';
71
- })) {
72
- return /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement("code", null, _constants.ORDER_FIELD_NAME), " field on Schema ", /*#__PURE__*/_react.default.createElement("code", null, type), " must be", ' ', /*#__PURE__*/_react.default.createElement("code", null, "string"), " type");
73
- }
74
-
75
- return "";
76
- }, [type]);
77
-
78
- if (schemaIsInvalid) {
79
- return /*#__PURE__*/_react.default.createElement(_Feedback.default, null, schemaIsInvalid);
80
- }
81
-
82
- return /*#__PURE__*/_react.default.createElement(_OrderableContext.OrderableContext.Provider, {
83
- value: {
84
- showIncrements
85
- }
86
- }, /*#__PURE__*/_react.default.createElement(_DocumentListQuery.default, {
87
- type: type,
88
- filter: filter,
89
- params: params
90
- }));
91
- }
92
-
93
- DocumentListWrapper.propTypes = {
94
- showIncrements: _propTypes.default.bool.isRequired,
95
- type: _propTypes.default.string.isRequired,
96
- filter: _propTypes.default.string,
97
- params: _propTypes.default.object,
98
- resetOrderTransaction: _propTypes.default.shape({
99
- title: _propTypes.default.string,
100
- status: _propTypes.default.string
101
- }).isRequired
102
- };
103
- DocumentListWrapper.defaultProps = {
104
- filter: "",
105
- params: {}
106
- };
107
- //# sourceMappingURL=DocumentListWrapper.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"DocumentListWrapper.js","names":["DocumentListWrapper","type","filter","params","showIncrements","resetOrderTransaction","toast","useToast","useEffect","title","status","push","schemaIsInvalid","useMemo","typeSchema","schema","get","fields","some","field","name","ORDER_FIELD_NAME","propTypes","PropTypes","bool","isRequired","string","object","shape","defaultProps"],"sources":["../src/DocumentListWrapper.js"],"sourcesContent":["import PropTypes from 'prop-types'\nimport React, {useMemo, useEffect} from 'react'\nimport schema from 'part:@sanity/base/schema'\nimport {useToast} from '@sanity/ui'\nimport {PaneRouterContext} from '@sanity/desk-tool'\n\nimport DocumentListQuery from './DocumentListQuery'\nimport {OrderableContext} from './OrderableContext'\n\nimport {ORDER_FIELD_NAME} from './helpers/constants'\nimport Feedback from './Feedback'\n\n// 1. Validate first that the schema has been configured for ordering\n// 2. Setup context for showIncrements\nexport default function DocumentListWrapper({\n type,\n filter,\n params,\n showIncrements,\n resetOrderTransaction,\n}) {\n const toast = useToast()\n\n useEffect(() => {\n if (resetOrderTransaction?.title && resetOrderTransaction?.status) {\n toast.push(resetOrderTransaction)\n }\n /* eslint-disable-next-line react-hooks/exhaustive-deps */\n }, [resetOrderTransaction])\n\n const schemaIsInvalid = useMemo(() => {\n // Option not passed\n if (!type) {\n return (\n <>\n No <code>type</code> was configured\n </>\n )\n }\n\n const typeSchema = schema.get(type)\n\n // Schema not found\n if (!typeSchema) {\n return (\n <>\n Schema <code>{type}</code> not found\n </>\n )\n }\n\n // Schema lacks an order field\n if (!typeSchema.fields.some((field) => field?.name === ORDER_FIELD_NAME)) {\n return (\n <>\n Schema <code>{type}</code> must have an <code>order</code> field of type{' '}\n <code>string</code>\n </>\n )\n }\n\n // Schema's order field is not a string\n if (\n typeSchema.fields.some(\n (field) => field?.name === ORDER_FIELD_NAME && field?.type?.name !== 'string'\n )\n ) {\n return (\n <>\n <code>{ORDER_FIELD_NAME}</code> field on Schema <code>{type}</code> must be{' '}\n <code>string</code> type\n </>\n )\n }\n\n return ``\n }, [type])\n\n if (schemaIsInvalid) {\n return <Feedback>{schemaIsInvalid}</Feedback>\n }\n\n return (\n <OrderableContext.Provider value={{showIncrements}}>\n <DocumentListQuery type={type} filter={filter} params={params} />\n </OrderableContext.Provider>\n )\n}\n\nDocumentListWrapper.propTypes = {\n showIncrements: PropTypes.bool.isRequired,\n type: PropTypes.string.isRequired,\n filter: PropTypes.string,\n params: PropTypes.object,\n resetOrderTransaction: PropTypes.shape({\n title: PropTypes.string,\n status: PropTypes.string,\n }).isRequired,\n}\n\nDocumentListWrapper.defaultProps = {\n filter: ``,\n params: {},\n}\n"],"mappings":"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"}