@nocobase/plugin-file-manager 2.1.0-alpha.40 → 2.1.0-alpha.45
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/dist/client/867ada653cd02a3e.mjs +6 -0
- package/dist/client/876.ca16d7a6e6387862.js +11 -0
- package/dist/client/index.js +1 -1
- package/dist/client/locale/index.d.ts +1 -1
- package/dist/client/previewer/filePreviewTypes.d.ts +1 -1
- package/dist/client/templates/file.d.ts +1 -1
- package/dist/client-v2/125.0b8eef1f19b87042.js +10 -0
- package/dist/client-v2/867ada653cd02a3e.mjs +6 -0
- package/dist/client-v2/876.22cd8e41ac8631ed.js +11 -0
- package/dist/client-v2/{942.9dc2d49980a4dd9e.js → 942.f36d807d763a1b53.js} +1 -1
- package/dist/client-v2/index.d.ts +2 -0
- package/dist/client-v2/index.js +1 -1
- package/dist/{shared → client-v2}/previewer/filePreviewTypes.d.ts +4 -0
- package/dist/externalVersion.js +9 -9
- package/dist/locale/de-DE.json +3 -0
- package/dist/locale/en-US.json +3 -0
- package/dist/locale/es-ES.json +3 -0
- package/dist/locale/fr-FR.json +3 -0
- package/dist/locale/hu-HU.json +4 -1
- package/dist/locale/id-ID.json +4 -1
- package/dist/locale/it-IT.json +3 -0
- package/dist/locale/ja-JP.json +3 -0
- package/dist/locale/ko-KR.json +3 -0
- package/dist/locale/nl-NL.json +3 -0
- package/dist/locale/pt-BR.json +3 -0
- package/dist/locale/ru-RU.json +3 -0
- package/dist/locale/tr-TR.json +3 -0
- package/dist/locale/uk-UA.json +3 -0
- package/dist/locale/vi-VN.json +4 -1
- package/dist/locale/zh-CN.json +3 -0
- package/dist/locale/zh-TW.json +3 -0
- package/dist/node_modules/@aws-sdk/client-s3/package.json +1 -1
- package/dist/node_modules/@aws-sdk/lib-storage/package.json +1 -1
- package/dist/node_modules/ali-oss/package.json +1 -1
- package/dist/node_modules/cos-nodejs-sdk-v5/package.json +1 -1
- package/dist/node_modules/mime-match/package.json +1 -1
- package/dist/node_modules/mime-types/package.json +1 -1
- package/dist/node_modules/mkdirp/package.json +1 -1
- package/dist/node_modules/url-join/package.json +1 -1
- package/dist/server/commands/repair-filenames.d.ts +55 -0
- package/dist/server/commands/repair-filenames.js +283 -0
- package/dist/server/server.d.ts +1 -0
- package/dist/server/server.js +4 -0
- package/dist/server/storages/ali-oss.d.ts +3 -1
- package/dist/server/storages/ali-oss.js +23 -2
- package/dist/server/storages/index.d.ts +3 -0
- package/dist/server/storages/index.js +6 -0
- package/dist/server/storages/local.d.ts +2 -0
- package/dist/server/storages/local.js +18 -0
- package/dist/server/storages/s3.d.ts +2 -0
- package/dist/server/storages/s3.js +26 -0
- package/dist/server/storages/tx-cos.d.ts +2 -0
- package/dist/server/storages/tx-cos.js +27 -0
- package/dist/server/utils.js +12 -2
- package/package.json +4 -2
- package/dist/client-v2/125.01d5562df948d974.js +0 -10
- package/dist/shared/locale.d.ts +0 -9
- package/dist/shared/locale.js +0 -36
- package/dist/shared/previewer/filePreviewTypes.js +0 -459
|
@@ -52,6 +52,12 @@ class StorageType {
|
|
|
52
52
|
return {};
|
|
53
53
|
}
|
|
54
54
|
static filenameKey;
|
|
55
|
+
async exists(record) {
|
|
56
|
+
throw new Error(`Storage type "${this.storage.type}" does not support object existence checks`);
|
|
57
|
+
}
|
|
58
|
+
async copy(source, target) {
|
|
59
|
+
throw new Error(`Storage type "${this.storage.type}" does not support object copy`);
|
|
60
|
+
}
|
|
55
61
|
getFileKey(record) {
|
|
56
62
|
return (0, import_utils2.getFileKey)(record);
|
|
57
63
|
}
|
|
@@ -27,6 +27,8 @@ export default class extends StorageType {
|
|
|
27
27
|
};
|
|
28
28
|
};
|
|
29
29
|
make(): multer.StorageEngine;
|
|
30
|
+
exists(record: AttachmentModel): Promise<boolean>;
|
|
31
|
+
copy(source: AttachmentModel, target: AttachmentModel): Promise<void>;
|
|
30
32
|
delete(records: AttachmentModel[]): Promise<[number, AttachmentModel[]]>;
|
|
31
33
|
getFileURL(file: AttachmentModel, preview?: boolean): Promise<any>;
|
|
32
34
|
getFileStream(file: AttachmentModel): Promise<{
|
|
@@ -96,6 +96,24 @@ class local_default extends import__.StorageType {
|
|
|
96
96
|
filename: (0, import_utils2.diskFilenameGetter)(this.storage)
|
|
97
97
|
});
|
|
98
98
|
}
|
|
99
|
+
async exists(record) {
|
|
100
|
+
try {
|
|
101
|
+
await import_promises.default.stat(resolveSafePath(getDocumentRoot(this.storage), record.path, record.filename));
|
|
102
|
+
return true;
|
|
103
|
+
} catch (error) {
|
|
104
|
+
if (error.code === "ENOENT") {
|
|
105
|
+
return false;
|
|
106
|
+
}
|
|
107
|
+
throw error;
|
|
108
|
+
}
|
|
109
|
+
}
|
|
110
|
+
async copy(source, target) {
|
|
111
|
+
const documentRoot = getDocumentRoot(this.storage);
|
|
112
|
+
const sourcePath = resolveSafePath(documentRoot, source.path, source.filename);
|
|
113
|
+
const targetPath = resolveSafePath(documentRoot, target.path, target.filename);
|
|
114
|
+
await import_promises.default.mkdir(import_path.default.dirname(targetPath), { recursive: true });
|
|
115
|
+
await import_promises.default.copyFile(sourcePath, targetPath);
|
|
116
|
+
}
|
|
99
117
|
async delete(records) {
|
|
100
118
|
const documentRoot = getDocumentRoot(this.storage);
|
|
101
119
|
let count = 0;
|
|
@@ -32,5 +32,7 @@ export default class extends StorageType {
|
|
|
32
32
|
deleteS3Objects(bucketName: string, objects: string[]): Promise<{
|
|
33
33
|
Deleted: any[];
|
|
34
34
|
}>;
|
|
35
|
+
exists(record: AttachmentModel): Promise<boolean>;
|
|
36
|
+
copy(source: AttachmentModel, target: AttachmentModel): Promise<void>;
|
|
35
37
|
delete(records: AttachmentModel[]): Promise<[number, AttachmentModel[]]>;
|
|
36
38
|
}
|
|
@@ -173,6 +173,32 @@ class s3_default extends import__.StorageType {
|
|
|
173
173
|
Deleted
|
|
174
174
|
};
|
|
175
175
|
}
|
|
176
|
+
async exists(record) {
|
|
177
|
+
try {
|
|
178
|
+
await this.client.send(
|
|
179
|
+
new import_client_s3.HeadObjectCommand({
|
|
180
|
+
Bucket: this.storage.options.bucket,
|
|
181
|
+
Key: this.getFileKey(record)
|
|
182
|
+
})
|
|
183
|
+
);
|
|
184
|
+
return true;
|
|
185
|
+
} catch (error) {
|
|
186
|
+
if (["NotFound", "NoSuchKey", "NoSuchBucket"].includes(error.name)) {
|
|
187
|
+
return false;
|
|
188
|
+
}
|
|
189
|
+
throw error;
|
|
190
|
+
}
|
|
191
|
+
}
|
|
192
|
+
async copy(source, target) {
|
|
193
|
+
const sourceKey = this.getFileKey(source);
|
|
194
|
+
await this.client.send(
|
|
195
|
+
new import_client_s3.CopyObjectCommand({
|
|
196
|
+
Bucket: this.storage.options.bucket,
|
|
197
|
+
Key: this.getFileKey(target),
|
|
198
|
+
CopySource: `${this.storage.options.bucket}/${sourceKey.split("/").map((segment) => encodeURIComponent(segment)).join("/")}`
|
|
199
|
+
})
|
|
200
|
+
);
|
|
201
|
+
}
|
|
176
202
|
async delete(records) {
|
|
177
203
|
const { Deleted } = await this.deleteS3Objects(
|
|
178
204
|
this.storage.options.bucket,
|
|
@@ -36,6 +36,8 @@ export default class extends StorageType {
|
|
|
36
36
|
};
|
|
37
37
|
static filenameKey: string;
|
|
38
38
|
make(): TxCosStorage;
|
|
39
|
+
exists(record: AttachmentModel): Promise<boolean>;
|
|
40
|
+
copy(source: AttachmentModel, target: AttachmentModel): Promise<void>;
|
|
39
41
|
delete(records: AttachmentModel[]): Promise<[number, AttachmentModel[]]>;
|
|
40
42
|
}
|
|
41
43
|
export {};
|
|
@@ -160,6 +160,33 @@ class tx_cos_default extends import__.StorageType {
|
|
|
160
160
|
filename: (0, import_utils.cloudFilenameGetter)(this.storage)
|
|
161
161
|
});
|
|
162
162
|
}
|
|
163
|
+
async exists(record) {
|
|
164
|
+
const { cos } = this.make();
|
|
165
|
+
try {
|
|
166
|
+
await (0, import_util.promisify)(cos.headObject).call(cos, {
|
|
167
|
+
Region: this.storage.options.Region,
|
|
168
|
+
Bucket: this.storage.options.Bucket,
|
|
169
|
+
Key: (0, import_utils.getFileKey)(record)
|
|
170
|
+
});
|
|
171
|
+
return true;
|
|
172
|
+
} catch (error) {
|
|
173
|
+
if (["NoSuchKey", "NotFound"].includes(error.name)) {
|
|
174
|
+
return false;
|
|
175
|
+
}
|
|
176
|
+
throw error;
|
|
177
|
+
}
|
|
178
|
+
}
|
|
179
|
+
async copy(source, target) {
|
|
180
|
+
const { cos } = this.make();
|
|
181
|
+
const sourceKey = (0, import_utils.getFileKey)(source);
|
|
182
|
+
const copySource = `${this.storage.options.Bucket}.cos.${this.storage.options.Region}.myqcloud.com/${sourceKey.split("/").map((segment) => encodeURIComponent(segment)).join("/")}`;
|
|
183
|
+
await (0, import_util.promisify)(cos.putObjectCopy).call(cos, {
|
|
184
|
+
Region: this.storage.options.Region,
|
|
185
|
+
Bucket: this.storage.options.Bucket,
|
|
186
|
+
Key: (0, import_utils.getFileKey)(target),
|
|
187
|
+
CopySource: copySource
|
|
188
|
+
});
|
|
189
|
+
}
|
|
163
190
|
async delete(records) {
|
|
164
191
|
const { cos } = this.make();
|
|
165
192
|
const { Deleted } = await (0, import_util.promisify)(cos.deleteMultipleObject).call(cos, {
|
package/dist/server/utils.js
CHANGED
|
@@ -49,6 +49,13 @@ var import_utils = require("@nocobase/utils");
|
|
|
49
49
|
var import_crypto = __toESM(require("crypto"));
|
|
50
50
|
var import_path = __toESM(require("path"));
|
|
51
51
|
var import_url_join = __toESM(require("url-join"));
|
|
52
|
+
const INVALID_FILENAME_CHARS = /* @__PURE__ */ new Set(["<", ">", "?", "*", "|", ":", '"', "\\", "/"]);
|
|
53
|
+
function sanitizeFilename(value) {
|
|
54
|
+
return Array.from(value).map((char) => {
|
|
55
|
+
const code = char.charCodeAt(0);
|
|
56
|
+
return code < 32 || code === 127 || INVALID_FILENAME_CHARS.has(char) ? "-" : char;
|
|
57
|
+
}).join("");
|
|
58
|
+
}
|
|
52
59
|
function normalizeOriginalname(file) {
|
|
53
60
|
const originalname = file == null ? void 0 : file.originalname;
|
|
54
61
|
if (!originalname) {
|
|
@@ -57,6 +64,9 @@ function normalizeOriginalname(file) {
|
|
|
57
64
|
if (Buffer.isBuffer(originalname)) {
|
|
58
65
|
return originalname.toString("utf8");
|
|
59
66
|
}
|
|
67
|
+
if (Array.from(originalname).some((char) => char.charCodeAt(0) > 255)) {
|
|
68
|
+
return originalname;
|
|
69
|
+
}
|
|
60
70
|
const decoded = Buffer.from(originalname, "binary").toString("utf8");
|
|
61
71
|
if (decoded.includes("\uFFFD")) {
|
|
62
72
|
return originalname;
|
|
@@ -65,13 +75,13 @@ function normalizeOriginalname(file) {
|
|
|
65
75
|
}
|
|
66
76
|
function getFilename(req, file, cb) {
|
|
67
77
|
const originalname = normalizeOriginalname(file);
|
|
68
|
-
const baseName = import_path.default.basename(originalname
|
|
78
|
+
const baseName = import_path.default.basename(sanitizeFilename(originalname), import_path.default.extname(originalname));
|
|
69
79
|
cb(null, `${baseName}-${(0, import_utils.uid)(6)}${import_path.default.extname(originalname)}`);
|
|
70
80
|
}
|
|
71
81
|
function getOriginalFilename(file) {
|
|
72
82
|
const originalname = normalizeOriginalname(file);
|
|
73
83
|
const extname = import_path.default.extname(originalname);
|
|
74
|
-
const baseName = import_path.default.basename(originalname
|
|
84
|
+
const baseName = import_path.default.basename(sanitizeFilename(originalname), extname);
|
|
75
85
|
return `${baseName}${extname}`;
|
|
76
86
|
}
|
|
77
87
|
const cloudFilenameGetter = (storage) => (req, file, cb) => {
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@nocobase/plugin-file-manager",
|
|
3
|
-
"version": "2.1.0-alpha.
|
|
3
|
+
"version": "2.1.0-alpha.45",
|
|
4
4
|
"displayName": "File manager",
|
|
5
5
|
"displayName.ru-RU": "Менеджер файлов",
|
|
6
6
|
"displayName.zh-CN": "文件管理器",
|
|
@@ -34,6 +34,7 @@
|
|
|
34
34
|
"multer": "^1.4.5-lts.2",
|
|
35
35
|
"multer-s3": "^3.0.1",
|
|
36
36
|
"multistream": "^4.1.0",
|
|
37
|
+
"pdfjs-dist": "^5.3.31",
|
|
37
38
|
"react": "^18.2.0",
|
|
38
39
|
"react-i18next": "^11.15.1",
|
|
39
40
|
"supertest": "^6.1.6",
|
|
@@ -49,6 +50,7 @@
|
|
|
49
50
|
"@nocobase/database": "2.x",
|
|
50
51
|
"@nocobase/flow-engine": "2.x",
|
|
51
52
|
"@nocobase/plugin-data-source-main": "2.x",
|
|
53
|
+
"@nocobase/plugin-data-source-manager": "2.x",
|
|
52
54
|
"@nocobase/plugin-environment-variables": "2.x",
|
|
53
55
|
"@nocobase/server": "2.x",
|
|
54
56
|
"@nocobase/test": "2.x",
|
|
@@ -58,5 +60,5 @@
|
|
|
58
60
|
"Collections",
|
|
59
61
|
"Collection fields"
|
|
60
62
|
],
|
|
61
|
-
"gitHead": "
|
|
63
|
+
"gitHead": "e9e24987e12d0ad10a5db8815b1e1b7b447f1938"
|
|
62
64
|
}
|
|
@@ -1,10 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* This file is part of the NocoBase (R) project.
|
|
3
|
-
* Copyright (c) 2020-2024 NocoBase Co., Ltd.
|
|
4
|
-
* Authors: NocoBase Team.
|
|
5
|
-
*
|
|
6
|
-
* This project is dual-licensed under AGPL-3.0 and NocoBase Commercial License.
|
|
7
|
-
* For more information, please refer to: https://www.nocobase.com/agreement.
|
|
8
|
-
*/
|
|
9
|
-
|
|
10
|
-
"use strict";(self.webpackChunk_nocobase_plugin_file_manager_client_v2=self.webpackChunk_nocobase_plugin_file_manager_client_v2||[]).push([["125"],{212:function(e,t,r){r.r(t),r.d(t,{DisplayPreviewFieldModel:function(){return P}});var n=r(477),o=r(485),l=r(694),a=r(59),i=r(773),c=r(155),u=r.n(c),s=r(953),f=r(348);function p(e,t){(null==t||t>e.length)&&(t=e.length);for(var r=0,n=Array(t);r<t;r++)n[r]=e[r];return n}function b(e,t,r,n,o,l,a){try{var i=e[l](a),c=i.value}catch(e){r(e);return}i.done?t(c):Promise.resolve(c).then(n,o)}function y(e,t,r){return t in e?Object.defineProperty(e,t,{value:r,enumerable:!0,configurable:!0,writable:!0}):e[t]=r,e}function d(e){return(d=Object.setPrototypeOf?Object.getPrototypeOf:function(e){return e.__proto__||Object.getPrototypeOf(e)})(e)}function h(e,t){return null!=t&&"u">typeof Symbol&&t[Symbol.hasInstance]?!!t[Symbol.hasInstance](e):e instanceof t}function m(e){for(var t=1;t<arguments.length;t++){var r=null!=arguments[t]?arguments[t]:{},n=Object.keys(r);"function"==typeof Object.getOwnPropertySymbols&&(n=n.concat(Object.getOwnPropertySymbols(r).filter(function(e){return Object.getOwnPropertyDescriptor(r,e).enumerable}))),n.forEach(function(t){y(e,t,r[t])})}return e}function v(e,t){return t=null!=t?t:{},Object.getOwnPropertyDescriptors?Object.defineProperties(e,Object.getOwnPropertyDescriptors(t)):(function(e){var t=Object.keys(e);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(e);t.push.apply(t,r)}return t})(Object(t)).forEach(function(r){Object.defineProperty(e,r,Object.getOwnPropertyDescriptor(t,r))}),e}function w(e,t){return(w=Object.setPrototypeOf||function(e,t){return e.__proto__=t,e})(e,t)}function g(e,t){return function(e){if(Array.isArray(e))return e}(e)||function(e,t){var r,n,o=null==e?null:"u">typeof Symbol&&e[Symbol.iterator]||e["@@iterator"];if(null!=o){var l=[],a=!0,i=!1;try{for(o=o.call(e);!(a=(r=o.next()).done)&&(l.push(r.value),!t||l.length!==t);a=!0);}catch(e){i=!0,n=e}finally{try{a||null==o.return||o.return()}finally{if(i)throw n}}return l}}(e,t)||function(e,t){if(e){if("string"==typeof e)return p(e,t);var r=Object.prototype.toString.call(e).slice(8,-1);if("Object"===r&&e.constructor&&(r=e.constructor.name),"Map"===r||"Set"===r)return Array.from(r);if("Arguments"===r||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(r))return p(e,t)}}(e,t)||function(){throw TypeError("Invalid attempt to destructure non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}()}function O(){try{var e=!Boolean.prototype.valueOf.call(Reflect.construct(Boolean,[],function(){}))}catch(e){}return(O=function(){return!!e})()}function j(){var e,t,r=(e=["\n .ant-image-img {\n border: 1px solid #d9d9d9;\n padding: 2px;\n }\n "],t||(t=e.slice(0)),Object.freeze(Object.defineProperties(e,{raw:{value:Object.freeze(t)}})));return j=function(){return r},r}var k=function(e){var t=e.file,r=e.size,o=e.showFileName,l=e.onClick,i=(0,f._H)(t),c=(0,f.q)(i);if(!c)return null;var s=(0,f.WP)(i,c),p=(0,f._Y)(i,c),b=(0,f.qk)(i)||p,y=u().createElement("div",{className:(0,n.css)(j())},u().createElement(a.Image,{src:b,fallback:p,width:r,height:r,preview:!1,style:{borderRadius:4,objectFit:"cover",boxShadow:"0 0 0 2px #fff"}}));return u().createElement("div",{onClick:l,style:{textAlign:"center",width:r,wordBreak:"break-all",cursor:l?"pointer":"default"}},y,o&&u().createElement(a.Tooltip,{title:s},u().createElement("div",{style:{fontSize:12,marginTop:4,overflow:"hidden",textOverflow:"ellipsis",whiteSpace:"nowrap",width:"100%"}},s)))},S=function(e){var t=e.value,r=void 0===t?[]:t,n=e.size,o=void 0===n?28:n,l=e.showFileName,c=(0,s.useTranslation)().t,p=g(u().useState(0),2),y=p[0],d=p[1],h=g(u().useState(!1),2),m=h[0],v=h[1],w=u().useMemo(function(){return(0,i.castArray)(r).filter(Boolean).map(f._H).filter(function(e){return(0,f.q)(e)})},[r]);u().useEffect(function(){y>=w.length&&w.length&&d(0)},[y,w.length]),u().useEffect(function(){!w.length&&m&&v(!1)},[w.length,m]);var O=u().useCallback(function(e){var t;return(t=function(){var t,r,n,o,l,i,u;return function(e,t){var r,n,o,l={label:0,sent:function(){if(1&o[0])throw o[1];return o[1]},trys:[],ops:[]},a=Object.create(("function"==typeof Iterator?Iterator:Object).prototype),i=Object.defineProperty;return i(a,"next",{value:c(0)}),i(a,"throw",{value:c(1)}),i(a,"return",{value:c(2)}),"function"==typeof Symbol&&i(a,Symbol.iterator,{value:function(){return this}}),a;function c(i){return function(c){var u=[i,c];if(r)throw TypeError("Generator is already executing.");for(;a&&(a=0,u[0]&&(l=0)),l;)try{if(r=1,n&&(o=2&u[0]?n.return:u[0]?n.throw||((o=n.return)&&o.call(n),0):n.next)&&!(o=o.call(n,u[1])).done)return o;switch(n=0,o&&(u=[2&u[0],o.value]),u[0]){case 0:case 1:o=u;break;case 4:return l.label++,{value:u[1],done:!1};case 5:l.label++,n=u[1],u=[0];continue;case 7:u=l.ops.pop(),l.trys.pop();continue;default:if(!(o=(o=l.trys).length>0&&o[o.length-1])&&(6===u[0]||2===u[0])){l=0;continue}if(3===u[0]&&(!o||u[1]>o[0]&&u[1]<o[3])){l.label=u[1];break}if(6===u[0]&&l.label<o[1]){l.label=o[1],o=u;break}if(o&&l.label<o[2]){l.label=o[2],l.ops.push(u);break}o[2]&&l.ops.pop(),l.trys.pop();continue}u=t.call(e,l)}catch(e){u=[6,e],n=0}finally{r=o=0}if(5&u[0])throw u[1];return{value:u[0]?u[1]:void 0,done:!0}}}}(this,function(s){switch(s.label){case 0:if(!(t=e||w[y])||!(r=t.url||t.preview))return[2];n=(0,f.ub)(t,r),s.label=1;case 1:return s.trys.push([1,4,5,6]),[4,fetch(r)];case 2:if(!(i=s.sent()).ok)throw Error("Download failed with status ".concat(i.status));return[4,i.blob()];case 3:return u=s.sent(),o=URL.createObjectURL(u),(l=document.createElement("a")).href=o,l.download=n,document.body.appendChild(l),l.click(),[3,6];case 4:return console.error("File download failed:",s.sent()),a.message.error(c("file-manager:File download failed")),[3,6];case 5:return l&&l.remove(),o&&setTimeout(function(){URL.revokeObjectURL(o)},1e3),[7];case 6:return[2]}})},function(){var e=this,r=arguments;return new Promise(function(n,o){var l=t.apply(e,r);function a(e){b(l,n,o,a,i,"next",e)}function i(e){b(l,n,o,a,i,"throw",e)}a(void 0)})})()},[y,w,c]),j=u().useCallback(function(e){d(e),v(!0)},[]),S=u().useCallback(function(e){e<0||e>=w.length||d(e)},[w.length]);return u().createElement(u().Fragment,null,u().createElement(a.Space,{wrap:!0},w.map(function(e,t){return u().createElement(k,{file:e,size:o,key:t,showFileName:l,onClick:function(){return j(t)}})})),w[y]?u().createElement(f.Mo,{open:m,file:w[y],index:y,list:w,onOpenChange:v,onClose:function(){return v(!1)},onSwitchIndex:S,onDownload:O}):null)},P=function(e){var t;if("function"!=typeof e&&null!==e)throw TypeError("Super expression must either be null or a function");function r(){var e,t,n;if(!(this instanceof r))throw TypeError("Cannot call a class as a function");return t=r,n=arguments,t=d(t),y(e=function(e,t){var r;if(t&&("object"==((r=t)&&"u">typeof Symbol&&r.constructor===Symbol?"symbol":typeof r)||"function"==typeof t))return t;if(void 0===e)throw ReferenceError("this hasn't been initialised - super() hasn't been called");return e}(this,O()?Reflect.construct(t,n||[],d(this).constructor):t.apply(this,n)),"disableTitleField",!0),e}return r.prototype=Object.create(e&&e.prototype,{constructor:{value:r,writable:!0,configurable:!0}}),e&&w(r,e),t=[{key:"render",value:function(){var e=this,t=this.props,r=t.value,n=t.titleField,o=t.template,l=t.target;return n&&"file"!==o&&"attachments"!==l?(0,i.castArray)(r).flatMap(function(t,r){var o=null==t?void 0:t[n],l=o?u().createElement(S,v(m({key:r},e.props),{value:(0,i.castArray)(o).filter(Boolean)})):u().createElement("span",{key:r},"N/A");return 0===r?[l]:[u().createElement("span",{key:"sep-".concat(r)},", "),l]}):u().createElement(S,v(m({},this.props),{value:(0,i.castArray)(r).filter(Boolean)}))}}],function(e,t){for(var r=0;r<t.length;r++){var n=t[r];n.enumerable=n.enumerable||!1,n.configurable=!0,"value"in n&&(n.writable=!0),Object.defineProperty(e,n.key,n)}}(r.prototype,t),r}(o.FieldModel);P.registerFlow({key:"previewReadPrettySetting",sort:500,title:(0,l.tExpr)("Preview Settings"),steps:{size:{title:(0,l.tExpr)("Size"),uiMode:function(e){var t=e.t;return{type:"select",key:"size",props:{options:[{value:300,label:t("Large")},{value:100,label:t("Middle")},{value:28,label:t("Small")}]}}},hideInSettings:function(e){return h(e.model.parent,o.TableColumnModel)},defaultParams:function(e){return{size:h(e.model.parent,o.DetailsItemModel)?100:28}},handler:function(e,t){e.model.setProps("size",t.size)}},showFileName:{title:(0,l.tExpr)("Show file name"),uiMode:{type:"switch",key:"showFileName"},hideInSettings:function(e){return h(e.model.parent,o.TableColumnModel)},defaultParams:{showFileName:!1},handler:function(e,t){e.model.setProps("showFileName",t.showFileName)}}}}),P.define({label:(0,l.tExpr)("Preview")}),l.DisplayItemModel.bindModelToInterface("DisplayPreviewFieldModel",["url","attachment","attachmentURL","m2m","m2o","o2o","o2m","oho","obo","mbm"],{isDefault:!0,when:function(e,t){return!t.targetCollection||"file"===t.targetCollection.template}})}}]);
|
package/dist/shared/locale.d.ts
DELETED
|
@@ -1,9 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* This file is part of the NocoBase (R) project.
|
|
3
|
-
* Copyright (c) 2020-2024 NocoBase Co., Ltd.
|
|
4
|
-
* Authors: NocoBase Team.
|
|
5
|
-
*
|
|
6
|
-
* This project is dual-licensed under AGPL-3.0 and NocoBase Commercial License.
|
|
7
|
-
* For more information, please refer to: https://www.nocobase.com/agreement.
|
|
8
|
-
*/
|
|
9
|
-
export declare const NAMESPACE = "file-manager";
|
package/dist/shared/locale.js
DELETED
|
@@ -1,36 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* This file is part of the NocoBase (R) project.
|
|
3
|
-
* Copyright (c) 2020-2024 NocoBase Co., Ltd.
|
|
4
|
-
* Authors: NocoBase Team.
|
|
5
|
-
*
|
|
6
|
-
* This project is dual-licensed under AGPL-3.0 and NocoBase Commercial License.
|
|
7
|
-
* For more information, please refer to: https://www.nocobase.com/agreement.
|
|
8
|
-
*/
|
|
9
|
-
|
|
10
|
-
var __defProp = Object.defineProperty;
|
|
11
|
-
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
12
|
-
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
13
|
-
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
14
|
-
var __export = (target, all) => {
|
|
15
|
-
for (var name in all)
|
|
16
|
-
__defProp(target, name, { get: all[name], enumerable: true });
|
|
17
|
-
};
|
|
18
|
-
var __copyProps = (to, from, except, desc) => {
|
|
19
|
-
if (from && typeof from === "object" || typeof from === "function") {
|
|
20
|
-
for (let key of __getOwnPropNames(from))
|
|
21
|
-
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
22
|
-
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
23
|
-
}
|
|
24
|
-
return to;
|
|
25
|
-
};
|
|
26
|
-
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
27
|
-
var locale_exports = {};
|
|
28
|
-
__export(locale_exports, {
|
|
29
|
-
NAMESPACE: () => NAMESPACE
|
|
30
|
-
});
|
|
31
|
-
module.exports = __toCommonJS(locale_exports);
|
|
32
|
-
const NAMESPACE = "file-manager";
|
|
33
|
-
// Annotate the CommonJS export names for ESM import in node:
|
|
34
|
-
0 && (module.exports = {
|
|
35
|
-
NAMESPACE
|
|
36
|
-
});
|