@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.
- package/client.d.ts +4 -0
- package/client.js +30 -0
- package/lib/client/TableTransfer.d.ts +3 -0
- package/lib/client/TableTransfer.js +500 -0
- package/lib/client/index.d.ts +2 -0
- package/lib/client/index.js +122 -0
- package/lib/client/locale/pt-BR.d.ts +13 -0
- package/lib/client/locale/pt-BR.js +19 -0
- package/lib/client/locale/zh-CN.d.ts +13 -0
- package/lib/client/locale/zh-CN.js +19 -0
- package/lib/client/utils.d.ts +4 -0
- package/lib/client/utils.js +25 -0
- package/lib/index.d.ts +1 -0
- package/lib/index.js +13 -0
- package/lib/server/collections/applications.d.ts +6 -0
- package/lib/server/collections/applications.js +27 -0
- package/lib/server/collections/collections.d.ts +6 -0
- package/lib/server/collections/collections.js +27 -0
- package/lib/server/index.d.ts +1 -0
- package/lib/server/index.js +13 -0
- package/lib/server/migrations/20230319111111-update-apps-collections.d.ts +4 -0
- package/lib/server/migrations/20230319111111-update-apps-collections.js +106 -0
- package/lib/server/plugin.d.ts +9 -0
- package/lib/server/plugin.js +408 -0
- package/package.json +12 -0
- package/server.d.ts +4 -0
- package/server.js +30 -0
- package/src/client/TableTransfer.tsx +388 -0
- package/src/client/index.tsx +86 -0
- package/src/client/locale/pt-BR.ts +13 -0
- package/src/client/locale/zh-CN.ts +13 -0
- package/src/client/utils.tsx +11 -0
- package/src/index.ts +1 -0
- package/src/server/__tests__/collection-sync.test.ts +489 -0
- package/src/server/__tests__/index.ts +25 -0
- package/src/server/collections/.gitkeep +0 -0
- package/src/server/collections/applications.ts +17 -0
- package/src/server/collections/collections.ts +17 -0
- package/src/server/index.ts +1 -0
- package/src/server/migrations/20230319111111-update-apps-collections.ts +67 -0
- package/src/server/plugin.ts +331 -0
package/client.d.ts
ADDED
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,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,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;
|