@nocobase/plugin-multi-app-share-collection 0.9.2-alpha.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (41) hide show
  1. package/client.d.ts +4 -0
  2. package/client.js +30 -0
  3. package/lib/client/TableTransfer.d.ts +3 -0
  4. package/lib/client/TableTransfer.js +500 -0
  5. package/lib/client/index.d.ts +2 -0
  6. package/lib/client/index.js +122 -0
  7. package/lib/client/locale/pt-BR.d.ts +13 -0
  8. package/lib/client/locale/pt-BR.js +19 -0
  9. package/lib/client/locale/zh-CN.d.ts +13 -0
  10. package/lib/client/locale/zh-CN.js +19 -0
  11. package/lib/client/utils.d.ts +4 -0
  12. package/lib/client/utils.js +25 -0
  13. package/lib/index.d.ts +1 -0
  14. package/lib/index.js +13 -0
  15. package/lib/server/collections/applications.d.ts +6 -0
  16. package/lib/server/collections/applications.js +27 -0
  17. package/lib/server/collections/collections.d.ts +6 -0
  18. package/lib/server/collections/collections.js +27 -0
  19. package/lib/server/index.d.ts +1 -0
  20. package/lib/server/index.js +13 -0
  21. package/lib/server/migrations/20230319111111-update-apps-collections.d.ts +4 -0
  22. package/lib/server/migrations/20230319111111-update-apps-collections.js +106 -0
  23. package/lib/server/plugin.d.ts +9 -0
  24. package/lib/server/plugin.js +408 -0
  25. package/package.json +12 -0
  26. package/server.d.ts +4 -0
  27. package/server.js +30 -0
  28. package/src/client/TableTransfer.tsx +388 -0
  29. package/src/client/index.tsx +86 -0
  30. package/src/client/locale/pt-BR.ts +13 -0
  31. package/src/client/locale/zh-CN.ts +13 -0
  32. package/src/client/utils.tsx +11 -0
  33. package/src/index.ts +1 -0
  34. package/src/server/__tests__/collection-sync.test.ts +489 -0
  35. package/src/server/__tests__/index.ts +25 -0
  36. package/src/server/collections/.gitkeep +0 -0
  37. package/src/server/collections/applications.ts +17 -0
  38. package/src/server/collections/collections.ts +17 -0
  39. package/src/server/index.ts +1 -0
  40. package/src/server/migrations/20230319111111-update-apps-collections.ts +67 -0
  41. package/src/server/plugin.ts +331 -0
package/client.d.ts ADDED
@@ -0,0 +1,4 @@
1
+ // @ts-nocheck
2
+ export * from './lib/client';
3
+ export { default } from './lib/client';
4
+
package/client.js ADDED
@@ -0,0 +1,30 @@
1
+ "use strict";
2
+
3
+ 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); }
4
+
5
+ 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; }
6
+
7
+ var _index = _interopRequireWildcard(require("./lib/client"));
8
+
9
+ Object.defineProperty(exports, "__esModule", {
10
+ value: true
11
+ });
12
+ var _exportNames = {};
13
+ Object.defineProperty(exports, "default", {
14
+ enumerable: true,
15
+ get: function get() {
16
+ return _index.default;
17
+ }
18
+ });
19
+
20
+ Object.keys(_index).forEach(function (key) {
21
+ if (key === "default" || key === "__esModule") return;
22
+ if (Object.prototype.hasOwnProperty.call(_exportNames, key)) return;
23
+ if (key in exports && exports[key] === _index[key]) return;
24
+ Object.defineProperty(exports, key, {
25
+ enumerable: true,
26
+ get: function get() {
27
+ return _index[key];
28
+ }
29
+ });
30
+ });
@@ -0,0 +1,3 @@
1
+ import React from 'react';
2
+ export declare const TableTransfer: React.ForwardRefExoticComponent<Pick<Partial<any>, string | number | symbol> & React.RefAttributes<unknown>>;
3
+ export default TableTransfer;
@@ -0,0 +1,500 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.default = exports.TableTransfer = void 0;
7
+ function _css() {
8
+ const data = require("@emotion/css");
9
+ _css = function _css() {
10
+ return data;
11
+ };
12
+ return data;
13
+ }
14
+ function _react() {
15
+ const data = require("@formily/react");
16
+ _react = function _react() {
17
+ return data;
18
+ };
19
+ return data;
20
+ }
21
+ function _client() {
22
+ const data = require("@nocobase/client");
23
+ _client = function _client() {
24
+ return data;
25
+ };
26
+ return data;
27
+ }
28
+ function _client2() {
29
+ const data = require("@nocobase/utils/client");
30
+ _client2 = function _client2() {
31
+ return data;
32
+ };
33
+ return data;
34
+ }
35
+ function _antd() {
36
+ const data = require("antd");
37
+ _antd = function _antd() {
38
+ return data;
39
+ };
40
+ return data;
41
+ }
42
+ function _debounce() {
43
+ const data = _interopRequireDefault(require("lodash/debounce"));
44
+ _debounce = function _debounce() {
45
+ return data;
46
+ };
47
+ return data;
48
+ }
49
+ function _uniq() {
50
+ const data = _interopRequireDefault(require("lodash/uniq"));
51
+ _uniq = function _uniq() {
52
+ return data;
53
+ };
54
+ return data;
55
+ }
56
+ function _react2() {
57
+ const data = _interopRequireWildcard(require("react"));
58
+ _react2 = function _react2() {
59
+ return data;
60
+ };
61
+ return data;
62
+ }
63
+ function _reactI18next() {
64
+ const data = require("react-i18next");
65
+ _reactI18next = function _reactI18next() {
66
+ return data;
67
+ };
68
+ return data;
69
+ }
70
+ 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); }
71
+ 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; }
72
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
73
+ function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
74
+ function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
75
+ function _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
76
+ function _toPropertyKey(arg) { var key = _toPrimitive(arg, "string"); return typeof key === "symbol" ? key : String(key); }
77
+ function _toPrimitive(input, hint) { if (typeof input !== "object" || input === null) return input; var prim = input[Symbol.toPrimitive]; if (prim !== undefined) { var res = prim.call(input, hint || "default"); if (typeof res !== "object") return res; throw new TypeError("@@toPrimitive must return a primitive value."); } return (hint === "string" ? String : Number)(input); }
78
+ function _createForOfIteratorHelper(o, allowArrayLike) { var it = typeof Symbol !== "undefined" && o[Symbol.iterator] || o["@@iterator"]; if (!it) { if (Array.isArray(o) || (it = _unsupportedIterableToArray(o)) || allowArrayLike && o && typeof o.length === "number") { if (it) o = it; var i = 0; var F = function F() {}; return { s: F, n: function n() { if (i >= o.length) return { done: true }; return { done: false, value: o[i++] }; }, e: function e(_e2) { throw _e2; }, f: F }; } throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } var normalCompletion = true, didErr = false, err; return { s: function s() { it = it.call(o); }, n: function n() { var step = it.next(); normalCompletion = step.done; return step; }, e: function e(_e3) { didErr = true; err = _e3; }, f: function f() { try { if (!normalCompletion && it.return != null) it.return(); } finally { if (didErr) throw err; } } }; }
79
+ function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }
80
+ 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."); }
81
+ 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); }
82
+ 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; }
83
+ function _iterableToArrayLimit(arr, i) { var _i = null == arr ? null : "undefined" != typeof Symbol && arr[Symbol.iterator] || arr["@@iterator"]; if (null != _i) { var _s, _e, _x, _r, _arr = [], _n = !0, _d = !1; try { if (_x = (_i = _i.call(arr)).next, 0 === i) { if (Object(_i) !== _i) return; _n = !1; } else for (; !(_n = (_s = _x.call(_i)).done) && (_arr.push(_s.value), _arr.length !== i); _n = !0); } catch (err) { _d = !0, _e = err; } finally { try { if (!_n && null != _i.return && (_r = _i.return(), Object(_r) !== _r)) return; } finally { if (_d) throw _e; } } return _arr; } }
84
+ function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }
85
+ const excludeCollections = ['users', 'roles', 'applications'];
86
+ const useCollectionsGraph = ({
87
+ removed = []
88
+ }) => {
89
+ const _useCollectionManager = (0, _client().useCollectionManager)(),
90
+ collections = _useCollectionManager.collections;
91
+ const findAddable = (0, _react2().useCallback)(name => {
92
+ return _client2().CollectionsGraph.connectedNodes({
93
+ collections,
94
+ nodes: [name],
95
+ excludes: excludeCollections
96
+ }).filter(name => removed.includes(name));
97
+ }, [removed]);
98
+ const findRemovable = (0, _react2().useCallback)(name => {
99
+ return _client2().CollectionsGraph.connectedNodes({
100
+ collections,
101
+ nodes: [name],
102
+ excludes: excludeCollections,
103
+ direction: 'reverse'
104
+ }).filter(name => !removed.includes(name));
105
+ }, [removed]);
106
+ return {
107
+ findAddable,
108
+ findRemovable
109
+ };
110
+ };
111
+ const useCollections = () => {
112
+ var _res2$data, _res3$data;
113
+ const record = (0, _client().useRecord)();
114
+ const _useState = (0, _react2().useState)([]),
115
+ _useState2 = _slicedToArray(_useState, 2),
116
+ selected = _useState2[0],
117
+ setSelected = _useState2[1];
118
+ const res1 = (0, _client().useRequest)({
119
+ url: `applications/${record.name}/collectionBlacklist:list`,
120
+ params: {
121
+ paginate: false,
122
+ params: {
123
+ fields: ['name']
124
+ }
125
+ }
126
+ }, {
127
+ onSuccess(data) {
128
+ var _data$data;
129
+ setSelected((_data$data = data.data) === null || _data$data === void 0 ? void 0 : _data$data.map(data => data.name));
130
+ }
131
+ });
132
+ const res2 = (0, _client().useRequest)({
133
+ url: `collections`,
134
+ params: {
135
+ fields: ['name', 'title', 'hidden', 'category.name', 'category.color', 'category.sort'],
136
+ sort: 'sort',
137
+ paginate: false
138
+ }
139
+ });
140
+ const res3 = (0, _client().useRequest)({
141
+ url: `collectionCategories`,
142
+ params: {
143
+ sort: 'sort',
144
+ paginate: false
145
+ }
146
+ });
147
+ return {
148
+ loading: res1.loading || res2.loading || res3.loading,
149
+ collections: (((_res2$data = res2.data) === null || _res2$data === void 0 ? void 0 : _res2$data.data) || []).filter(item => !item.hidden && !excludeCollections.includes(item.name)),
150
+ removed: selected,
151
+ setSelected,
152
+ categories: (((_res3$data = res3.data) === null || _res3$data === void 0 ? void 0 : _res3$data.data) || []).map(cat => ({
153
+ label: cat.name,
154
+ value: cat.name
155
+ }))
156
+ };
157
+ };
158
+ const includes = (text, s) => {
159
+ const values = Array.isArray(s) ? s : [s];
160
+ var _iterator = _createForOfIteratorHelper(values),
161
+ _step;
162
+ try {
163
+ for (_iterator.s(); !(_step = _iterator.n()).done;) {
164
+ const val = _step.value;
165
+ if (text.toLowerCase().includes(val)) {
166
+ return true;
167
+ }
168
+ }
169
+ } catch (err) {
170
+ _iterator.e(err);
171
+ } finally {
172
+ _iterator.f();
173
+ }
174
+ return false;
175
+ };
176
+ const useRemovedDataSource = ({
177
+ collections,
178
+ removed
179
+ }) => {
180
+ const _useState3 = (0, _react2().useState)({
181
+ name: '',
182
+ category: []
183
+ }),
184
+ _useState4 = _slicedToArray(_useState3, 2),
185
+ filter = _useState4[0],
186
+ setFilter = _useState4[1];
187
+ const dataSource = (0, _react2().useMemo)(() => {
188
+ return collections.filter(collection => {
189
+ const name = collection.name,
190
+ title = collection.title,
191
+ _collection$category = collection.category,
192
+ category = _collection$category === void 0 ? [] : _collection$category;
193
+ const results = [removed.includes(collection.name)];
194
+ if (filter.name) {
195
+ results.push(includes(name, filter.name) || includes(title, filter.name));
196
+ }
197
+ if (filter.category.length > 0) {
198
+ results.push(category.some(item => includes(item.name, filter.category)));
199
+ }
200
+ return !results.includes(false);
201
+ });
202
+ }, [collections, removed, filter]);
203
+ const setNameFilter = (0, _react2().useMemo)(() => (0, _debounce().default)(name => {
204
+ setFilter(_objectSpread(_objectSpread({}, filter), {}, {
205
+ name
206
+ }));
207
+ }, 300), []);
208
+ return {
209
+ dataSource,
210
+ setNameFilter,
211
+ setCategoryFilter: category => {
212
+ setFilter(_objectSpread(_objectSpread({}, filter), {}, {
213
+ category
214
+ }));
215
+ }
216
+ };
217
+ };
218
+ const useAddedDataSource = ({
219
+ collections,
220
+ removed
221
+ }) => {
222
+ const _useState5 = (0, _react2().useState)({
223
+ name: '',
224
+ category: []
225
+ }),
226
+ _useState6 = _slicedToArray(_useState5, 2),
227
+ filter = _useState6[0],
228
+ setFilter = _useState6[1];
229
+ const dataSource = collections.filter(collection => {
230
+ const name = collection.name,
231
+ title = collection.title,
232
+ _collection$category2 = collection.category,
233
+ category = _collection$category2 === void 0 ? [] : _collection$category2;
234
+ const results = [!removed.includes(collection.name)];
235
+ if (filter.name) {
236
+ results.push(includes(name, filter.name) || includes(title, filter.name));
237
+ }
238
+ if (filter.category.length > 0) {
239
+ results.push(category.some(item => includes(item.name, filter.category)));
240
+ }
241
+ return !results.includes(false);
242
+ });
243
+ const setNameFilter = (0, _react2().useMemo)(() => (0, _debounce().default)(name => {
244
+ setFilter(_objectSpread(_objectSpread({}, filter), {}, {
245
+ name
246
+ }));
247
+ }, 300), []);
248
+ return {
249
+ dataSource,
250
+ setNameFilter,
251
+ setCategoryFilter: category => {
252
+ setFilter(_objectSpread(_objectSpread({}, filter), {}, {
253
+ category
254
+ }));
255
+ }
256
+ };
257
+ };
258
+ const TableTransfer = (0, _react().connect)(props => {
259
+ const onChange = props.onChange;
260
+ const _useCollections = useCollections(),
261
+ loading = _useCollections.loading,
262
+ collections = _useCollections.collections,
263
+ categories = _useCollections.categories,
264
+ removed = _useCollections.removed,
265
+ setSelected = _useCollections.setSelected;
266
+ const _useState7 = (0, _react2().useState)([]),
267
+ _useState8 = _slicedToArray(_useState7, 2),
268
+ selectedRowKeys1 = _useState8[0],
269
+ setSelectedRowKeys1 = _useState8[1];
270
+ const _useState9 = (0, _react2().useState)([]),
271
+ _useState10 = _slicedToArray(_useState9, 2),
272
+ selectedRowKeys2 = _useState10[0],
273
+ setSelectedRowKeys2 = _useState10[1];
274
+ const _useCollectionsGraph = useCollectionsGraph({
275
+ removed
276
+ }),
277
+ findAddable = _useCollectionsGraph.findAddable,
278
+ findRemovable = _useCollectionsGraph.findRemovable;
279
+ const addedDataSource = useAddedDataSource({
280
+ collections,
281
+ removed
282
+ });
283
+ const removedDataSource = useRemovedDataSource({
284
+ collections,
285
+ removed
286
+ });
287
+ const _useTranslation = (0, _reactI18next().useTranslation)('multi-app-share-collection'),
288
+ t = _useTranslation.t;
289
+ const columns = (0, _react2().useMemo)(() => [{
290
+ title: t('Collection display name'),
291
+ dataIndex: 'title'
292
+ }, {
293
+ title: t('Collection name'),
294
+ dataIndex: 'name'
295
+ }, {
296
+ title: t('Collection category'),
297
+ dataIndex: 'category',
298
+ render: categories => categories.map(category => _react2().default.createElement(_antd().Tag, {
299
+ color: category.color
300
+ }, category.name))
301
+ }], []);
302
+ if (loading) {
303
+ return _react2().default.createElement(_antd().Spin, null);
304
+ }
305
+ return _react2().default.createElement("div", null, _react2().default.createElement(_antd().Row, {
306
+ gutter: 24,
307
+ className: (0, _css().css)`
308
+ .ant-table-tbody > tr.ant-table-row:hover > td {
309
+ background: #e6f7ff;
310
+ cursor: pointer;
311
+ }
312
+ `
313
+ }, _react2().default.createElement(_antd().Col, {
314
+ span: 12
315
+ }, _react2().default.createElement("div", {
316
+ className: (0, _css().css)`
317
+ display: flex;
318
+ justify-content: space-between;
319
+ align-items: center;
320
+ width: 100%;
321
+ margin-bottom: 8px;
322
+ `
323
+ }, _react2().default.createElement("strong", {
324
+ style: {
325
+ fontSize: 16
326
+ }
327
+ }, t('Unshared collections')), _react2().default.createElement(_antd().Input.Group, {
328
+ compact: true,
329
+ style: {
330
+ width: 360
331
+ }
332
+ }, _react2().default.createElement(_antd().Select, {
333
+ onChange: value => {
334
+ removedDataSource.setCategoryFilter(value);
335
+ },
336
+ mode: 'multiple',
337
+ style: {
338
+ width: '35%'
339
+ },
340
+ size: 'middle',
341
+ placeholder: t('All categories'),
342
+ options: categories,
343
+ allowClear: true
344
+ }), _react2().default.createElement(_antd().Input, {
345
+ onChange: e => removedDataSource.setNameFilter(e.target.value),
346
+ style: {
347
+ width: '65%'
348
+ },
349
+ placeholder: t('Enter name or title...'),
350
+ allowClear: true
351
+ }))), _react2().default.createElement(_antd().Table, {
352
+ bordered: true,
353
+ rowKey: 'name',
354
+ rowSelection: {
355
+ type: 'checkbox',
356
+ selectedRowKeys: selectedRowKeys1,
357
+ onChange(selectedRowKeys) {
358
+ const values = removed.filter(s => !selectedRowKeys.includes(s));
359
+ setSelected(values);
360
+ onChange(values);
361
+ setSelectedRowKeys1([]);
362
+ }
363
+ },
364
+ pagination: false,
365
+ size: 'small',
366
+ columns: columns,
367
+ // dataSource={collections.filter((collection) => removed.includes(collection.name))}
368
+ dataSource: removedDataSource.dataSource,
369
+ scroll: {
370
+ y: 'calc(100vh - 260px)'
371
+ },
372
+ onRow: ({
373
+ name,
374
+ disabled
375
+ }) => ({
376
+ onClick: () => {
377
+ if (disabled) return;
378
+ const adding = findAddable(name);
379
+ const change = () => {
380
+ const values = removed.filter(s => !adding.includes(s));
381
+ setSelected(values);
382
+ onChange(values);
383
+ };
384
+ if (adding.length === 1) {
385
+ return change();
386
+ }
387
+ _antd().Modal.confirm({
388
+ title: t('Are you sure to add the following collections?'),
389
+ width: '60%',
390
+ content: _react2().default.createElement("div", null, _react2().default.createElement(_antd().Table, {
391
+ size: 'small',
392
+ columns: columns,
393
+ dataSource: collections.filter(collection => adding.includes(collection.name)),
394
+ pagination: false,
395
+ scroll: {
396
+ y: '60vh'
397
+ }
398
+ })),
399
+ onOk() {
400
+ change();
401
+ }
402
+ });
403
+ }
404
+ })
405
+ })), _react2().default.createElement(_antd().Col, {
406
+ span: 12
407
+ }, _react2().default.createElement("div", {
408
+ className: (0, _css().css)`
409
+ display: flex;
410
+ justify-content: space-between;
411
+ align-items: center;
412
+ width: 100%;
413
+ margin-bottom: 8px;
414
+ `
415
+ }, _react2().default.createElement("strong", {
416
+ style: {
417
+ fontSize: 16
418
+ }
419
+ }, t('Shared collections')), _react2().default.createElement(_antd().Input.Group, {
420
+ compact: true,
421
+ style: {
422
+ width: 360
423
+ }
424
+ }, _react2().default.createElement(_antd().Select, {
425
+ onChange: value => {
426
+ addedDataSource.setCategoryFilter(value);
427
+ },
428
+ mode: 'multiple',
429
+ style: {
430
+ width: '35%'
431
+ },
432
+ size: 'middle',
433
+ placeholder: t('All categories'),
434
+ options: categories,
435
+ allowClear: true
436
+ }), _react2().default.createElement(_antd().Input, {
437
+ onChange: e => addedDataSource.setNameFilter(e.target.value),
438
+ style: {
439
+ width: '65%'
440
+ },
441
+ placeholder: t('Enter name or title...'),
442
+ allowClear: true
443
+ }))), _react2().default.createElement(_antd().Table, {
444
+ bordered: true,
445
+ rowKey: 'name',
446
+ rowSelection: {
447
+ type: 'checkbox',
448
+ selectedRowKeys: selectedRowKeys2,
449
+ onChange(selectedRowKeys) {
450
+ const values = (0, _uniq().default)(removed.concat(selectedRowKeys));
451
+ setSelected(values);
452
+ onChange(values);
453
+ setSelectedRowKeys2([]);
454
+ }
455
+ },
456
+ pagination: false,
457
+ size: 'small',
458
+ columns: columns,
459
+ dataSource: addedDataSource.dataSource,
460
+ // dataSource={collections.filter((collection) => !selected.includes(collection.name))}
461
+ scroll: {
462
+ y: 'calc(100vh - 260px)'
463
+ },
464
+ onRow: ({
465
+ name
466
+ }) => ({
467
+ onClick: () => {
468
+ const removing = findRemovable(name);
469
+ const change = () => {
470
+ removed.push(...removing);
471
+ const values = (0, _uniq().default)([...removed]);
472
+ setSelected(values);
473
+ onChange(values);
474
+ };
475
+ if (removing.length === 1) {
476
+ return change();
477
+ }
478
+ _antd().Modal.confirm({
479
+ title: t('Are you sure to remove the following collections?'),
480
+ width: '60%',
481
+ content: _react2().default.createElement("div", null, _react2().default.createElement(_antd().Table, {
482
+ size: 'small',
483
+ columns: columns,
484
+ dataSource: collections.filter(collection => removing.includes(collection.name)),
485
+ pagination: false,
486
+ scroll: {
487
+ y: '60vh'
488
+ }
489
+ })),
490
+ onOk() {
491
+ change();
492
+ }
493
+ });
494
+ }
495
+ })
496
+ }))));
497
+ });
498
+ exports.TableTransfer = TableTransfer;
499
+ var _default = TableTransfer;
500
+ exports.default = _default;
@@ -0,0 +1,2 @@
1
+ declare const _default: (props: any) => JSX.Element;
2
+ export default _default;
@@ -0,0 +1,122 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.default = void 0;
7
+ function _react() {
8
+ const data = require("@formily/react");
9
+ _react = function _react() {
10
+ return data;
11
+ };
12
+ return data;
13
+ }
14
+ function _client() {
15
+ const data = require("@nocobase/client");
16
+ _client = function _client() {
17
+ return data;
18
+ };
19
+ return data;
20
+ }
21
+ function _client2() {
22
+ const data = require("@nocobase/plugin-multi-app-manager/client");
23
+ _client2 = function _client2() {
24
+ return data;
25
+ };
26
+ return data;
27
+ }
28
+ function _antd() {
29
+ const data = require("antd");
30
+ _antd = function _antd() {
31
+ return data;
32
+ };
33
+ return data;
34
+ }
35
+ function _react2() {
36
+ const data = _interopRequireDefault(require("react"));
37
+ _react2 = function _react2() {
38
+ return data;
39
+ };
40
+ return data;
41
+ }
42
+ var _TableTransfer = require("./TableTransfer");
43
+ var _utils = require("./utils");
44
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
45
+ 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); } }
46
+ 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); }); }; }
47
+ const useShareCollectionAction = () => {
48
+ const form = (0, _react().useForm)();
49
+ const ctx = (0, _client().useActionContext)();
50
+ const api = (0, _client().useAPIClient)();
51
+ const record = (0, _client().useRecord)();
52
+ return {
53
+ run() {
54
+ return _asyncToGenerator(function* () {
55
+ console.log(form.values.names);
56
+ yield api.request({
57
+ url: `applications/${record.name}/collectionBlacklist`,
58
+ data: form.values.names,
59
+ method: 'post'
60
+ });
61
+ ctx.setVisible(false);
62
+ form.reset();
63
+ _antd().message.success('Saved successfully');
64
+ })();
65
+ }
66
+ };
67
+ };
68
+ const updateSchema = _client2().tableActionColumnSchema.properties.update;
69
+ const deleteSchema = _client2().tableActionColumnSchema.properties.delete;
70
+ delete _client2().tableActionColumnSchema.properties.update;
71
+ delete _client2().tableActionColumnSchema.properties.delete;
72
+ _client2().tableActionColumnSchema.properties['collection'] = {
73
+ type: 'void',
74
+ title: (0, _utils.i18nText)('Share collections'),
75
+ 'x-component': 'Action.Link',
76
+ 'x-component-props': {},
77
+ properties: {
78
+ drawer: {
79
+ type: 'void',
80
+ 'x-component': 'Action.Drawer',
81
+ 'x-component-props': {
82
+ width: '95vw'
83
+ },
84
+ 'x-decorator': 'Form',
85
+ title: (0, _utils.i18nText)('Share collections'),
86
+ properties: {
87
+ names: {
88
+ type: 'array',
89
+ 'x-component': _TableTransfer.TableTransfer,
90
+ 'x-decorator': 'FormItem'
91
+ },
92
+ footer: {
93
+ type: 'void',
94
+ 'x-component': 'Action.Drawer.Footer',
95
+ properties: {
96
+ cancel: {
97
+ title: '{{t("Cancel")}}',
98
+ 'x-component': 'Action',
99
+ 'x-component-props': {
100
+ useAction: '{{ cm.useCancelAction }}'
101
+ }
102
+ },
103
+ submit: {
104
+ title: '{{t("Submit")}}',
105
+ 'x-component': 'Action',
106
+ 'x-component-props': {
107
+ type: 'primary',
108
+ useAction: useShareCollectionAction
109
+ }
110
+ }
111
+ }
112
+ }
113
+ }
114
+ }
115
+ }
116
+ };
117
+ _client2().tableActionColumnSchema.properties.update = updateSchema;
118
+ _client2().tableActionColumnSchema.properties.delete = deleteSchema;
119
+ var _default = props => {
120
+ return _react2().default.createElement(_react2().default.Fragment, null, props.children);
121
+ };
122
+ exports.default = _default;
@@ -0,0 +1,13 @@
1
+ declare const _default: {
2
+ 'Share collections': string;
3
+ 'Unshared collections': string;
4
+ 'Shared collections': string;
5
+ 'All categories': string;
6
+ 'Enter name or title...': string;
7
+ 'Are you sure to add the following collections?': string;
8
+ 'Are you sure to remove the following collections?': string;
9
+ 'Collection display name': string;
10
+ 'Collection name': string;
11
+ 'Collection category': string;
12
+ };
13
+ export default _default;