@minto-ai/tools 1.0.3 → 1.0.33

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/README.md CHANGED
@@ -806,37 +806,8 @@ console.log(uuid) // 输出类似于 "1gann4cq9b6r"
806
806
  | `XLS` | `xls` | Excel 工作簿 |
807
807
  | `XLSX` | `xlsx` | Excel 工作簿 (XML 格式) |
808
808
 
809
- #### `FileItemFeedTypeEnum`
810
-
811
- 一个枚举类型,用于表示文件喂养类型
812
-
813
- | 枚举键名 | 值 | 描述 |
814
- | ------------- | ---- | ----------------------------- |
815
- | `ALL` | ` ` | 所有类型内容 |
816
- | `DOCUMENT` | `0` | 文档类型内容 |
817
- | `TEXT` | `1` | 纯文本内容 |
818
- | `IMG` | `2` | 图片类型内容 |
819
- | `VIDEO` | `3` | 视频类型内容 |
820
- | `PPT` | `4` | 幻灯片(PPT)类型内容 |
821
- | `QA` | `5` | 问答(QA)类型内容 |
822
- | `AUDIO` | `6` | 音频类型内容 |
823
- | `MUSIC` | `7` | 音乐类型内容 |
824
- | `AUTOHTML` | `8` | 自动生成的 HTML 内容 |
825
- | `TWEET` | `9` | 社交媒体推文(Tweet)类型内容 |
826
- | `COMIC_STRIP` | `10` | 漫画(Comic Strip)类型内容 |
827
-
828
809
  ### 类型
829
810
 
830
- #### `IFileItem`
831
-
832
- `IFileItem` 是一个用于描述文件信息的接口,包含文件的基本信息和相关 URL。
833
- | 属性名 | 类型 | 描述 |
834
- |----------|-----------|---------------------|
835
- | `title` | `string` | 文件的标题或名称,用于显示。 |
836
- | `viewUrl` | `string` | 文件在Obs服务器上原始地址 |
837
- |`createTime`|`string`|文件创建时间|
838
- |`feedType`|`FileItemFeedType`|文件喂养类型|
839
-
840
811
  #### `FileSuffix`
841
812
 
842
813
  `FileSuffix` 是一个基于 `FileSuffixEnum` 枚举的类型别名,用于表示文件后缀。
@@ -857,10 +828,6 @@ console.log(uuid) // 输出类似于 "1gann4cq9b6r"
857
828
 
858
829
  `DocumentFileSuffix` 是一个基于 `DocumentFileSuffixEnum` 枚举的类型别名,用于表示文档文件后缀。
859
830
 
860
- #### `FileItemFeedType`
861
-
862
- `FileItemFeedType` 是一个基于 `FileItemFeedTypeEnum` 枚举的类型别名,用于表示文件类型。
863
-
864
831
  ### `getFileSuffix`
865
832
 
866
833
  > `function getFileSuffix(filePath: string): FileSuffix`
@@ -1099,90 +1066,6 @@ console.log(getFileIcon('/path/to/file.pdf')) // 返回 pdfIcon 的路径
1099
1066
  console.log(getFileIcon('/path/to/file.txt')) // 返回 txtIcon 的路径
1100
1067
  ```
1101
1068
 
1102
- ### `getFileItemSuffix`
1103
-
1104
- > `function getFileItemSuffix(fileItem: IFileItem): FileSuffix`
1105
-
1106
- 从文件实例中提取文件类型后缀。该函数内部包含多种逻辑,可以直接调用或根据需求进行修改。
1107
-
1108
- #### 参数
1109
-
1110
- - `fileItem(IFileItem)`: 文件实例,包含文件的基本信息和路径。
1111
-
1112
- #### 返回
1113
-
1114
- `(FileSuffix)`: 文件类型后缀。如果无法提取有效后缀,则返回空字符串。
1115
-
1116
- #### 示例
1117
-
1118
- ```typescript
1119
- import { getFileItemSuffix } from '@minto-ai/tools'
1120
-
1121
- console.log(
1122
- getFileItemSuffix({
1123
- title: 'pdf文件',
1124
- viewUrl: '/path/to/file.pdf',
1125
- createTime: '2024-03-19 20:37:30'
1126
- })
1127
- ) // 返回 "pdf"
1128
- ```
1129
-
1130
- ### `getFileItemIcon`
1131
-
1132
- > `function getFileItemIcon(fileItem: IFileItem): string`
1133
-
1134
- 从文件实例中提取文件类型图标。该函数通过文件实例的后缀获取对应的图标。
1135
-
1136
- #### 参数
1137
-
1138
- - `fileItem (IFileItem)`: 文件实例,包含文件的基本信息和路径。
1139
-
1140
- #### 返回
1141
-
1142
- `(string)`: 文件类型的图标路径。如果无法提取有效后缀,则返回默认图标路径。
1143
-
1144
- #### 示例
1145
-
1146
- ```typescript
1147
- import { getFileItemIcon } from '@minto-ai/tools'
1148
-
1149
- console.log(
1150
- getFileItemIcon({
1151
- title: 'image文件',
1152
- viewUrl: '/path/to/image.jpg',
1153
- createTime: '2024-03-19 20:37:30'
1154
- })
1155
- ) // image图标
1156
- ```
1157
-
1158
- ### `getFileFeedType`
1159
-
1160
- > `function getFileFeedType(filePath: string): FileItemFeedType | undefined`
1161
-
1162
- 根据文件路径获取`feedType`。该函数通过文件路径提取文件后缀,并根据预定义的映射关系返回对应的`feedType`(`FileItemFeedTypeEnum`)。
1163
-
1164
- #### 参数
1165
-
1166
- - `filePath (string)`: 文件路径,例如 `/path/to/file.txt`。
1167
-
1168
- #### 返回
1169
-
1170
- `(FileItemFeedType | undefined)`: 如果文件后缀无法识别,则返回 `undefined`。
1171
-
1172
- #### 例子
1173
-
1174
- ```typescript
1175
- import { getFileFeedType } from '@minto-ai/tools'
1176
-
1177
- const filePath1 = 'https://example.com/image.jpg'
1178
- const filePath2 = 'https://example.com/document.pdf'
1179
- const filePath3 = 'https://example.com/unknown.file'
1180
-
1181
- console.log(getFileFeedType(filePath1)) // 输出: FileItemFeedTypeEnum.IMG
1182
- console.log(getFileFeedType(filePath2)) // 输出: FileItemFeedTypeEnum.TEXT
1183
- console.log(getFileFeedType(filePath3)) // 输出: undefined
1184
- ```
1185
-
1186
1069
  ### `singleDownloadFile`
1187
1070
 
1188
1071
  > `function singleDownloadFile(filePath: string, fileName?: string): Promise<void>`
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1 @@
1
+ export {};
@@ -22,7 +22,6 @@ declare const FileSuffixEnum: {
22
22
  readonly WAV: "wav";
23
23
  readonly TXT: "txt";
24
24
  readonly HTML: "html";
25
- readonly NULL: "";
26
25
  };
27
26
  /**
28
27
  * 图片后缀类型枚举
@@ -61,21 +60,4 @@ declare const DocumentFileSuffixEnum: {
61
60
  readonly XLS: "xls";
62
61
  readonly XLSX: "xlsx";
63
62
  };
64
- /**
65
- * feedType类型枚举
66
- */
67
- declare const FileItemFeedTypeEnum: {
68
- readonly ALL: "";
69
- readonly DOCUMENT: 0;
70
- readonly TEXT: 1;
71
- readonly IMG: 2;
72
- readonly VIDEO: 3;
73
- readonly PPT: 4;
74
- readonly QA: 5;
75
- readonly AUDIO: 6;
76
- readonly MUSIC: 7;
77
- readonly AUTOHTML: 8;
78
- readonly TWEET: 9;
79
- readonly COMIC_STRIP: 10;
80
- };
81
- export { DocumentFileSuffixEnum, FileItemFeedTypeEnum, FileSuffixEnum, ImageFileSuffixEnum, PptFileSuffixEnum, VideoFileSuffixEnum, };
63
+ export { DocumentFileSuffixEnum, FileSuffixEnum, ImageFileSuffixEnum, PptFileSuffixEnum, VideoFileSuffixEnum, };
@@ -1,3 +1,2 @@
1
- declare const fileSuffixRegex: RegExp;
2
- declare const fileNameRegex: RegExp;
3
- export { fileNameRegex, fileSuffixRegex };
1
+ declare const filePathRegex: RegExp;
2
+ export { filePathRegex };
@@ -1,10 +1,7 @@
1
- import { DocumentFileSuffix, FileItemFeedType, FileSuffix, IFileItem, ImageFileSuffix, PptFileSuffix, VideoFileSuffix } from './types';
1
+ import { DocumentFileSuffix, FileSuffix, ImageFileSuffix, PptFileSuffix, VideoFileSuffix } from './types';
2
2
  import { default as batchDownloadFile } from './batch-download-file';
3
- import { FileItemFeedTypeEnum, FileSuffixEnum, ImageFileSuffixEnum } from './extends/enum';
4
- import { default as getFileFeedType } from './get-file-feed-type';
3
+ import { FileSuffixEnum, ImageFileSuffixEnum } from './extends/enum';
5
4
  import { default as getFileIcon } from './get-file-icon';
6
- import { default as getFileItemIcon } from './get-file-item-icon';
7
- import { default as getFileItemSuffix } from './get-file-item-suffix';
8
5
  import { default as getFileName } from './get-file-name';
9
6
  import { default as getFileSuffix } from './get-file-suffix';
10
7
  import { default as getFileSuffixIcon } from './get-file-suffix-icon';
@@ -15,5 +12,5 @@ import { default as isImageFilePath } from './is-image-file-path';
15
12
  import { default as isPptFilePath } from './is-ppt-file-path';
16
13
  import { default as isVideoFilePath } from './is-video-file-path';
17
14
  import { default as singleDownloadFile } from './single-download-file';
18
- export type { DocumentFileSuffix, FileItemFeedType, FileSuffix, IFileItem, ImageFileSuffix, PptFileSuffix, VideoFileSuffix, };
19
- export { batchDownloadFile, FileItemFeedTypeEnum, FileSuffixEnum, getFileFeedType, getFileIcon, getFileItemIcon, getFileItemSuffix, getFileName, getFileSuffix, getFileSuffixIcon, getFileTitle, ImageFileSuffixEnum, isDocumentFilePath, isFilePath, isImageFilePath, isPptFilePath, isVideoFilePath, singleDownloadFile, };
15
+ export type { DocumentFileSuffix, FileSuffix, ImageFileSuffix, PptFileSuffix, VideoFileSuffix, };
16
+ export { batchDownloadFile, FileSuffixEnum, getFileIcon, getFileName, getFileSuffix, getFileSuffixIcon, getFileTitle, ImageFileSuffixEnum, isDocumentFilePath, isFilePath, isImageFilePath, isPptFilePath, isVideoFilePath, singleDownloadFile, };
@@ -0,0 +1,8 @@
1
+ /**
2
+ * 判断是否是有效的文档文件路径(包含doc、docx、pdf、txt、xls、xlsx)
3
+ *
4
+ * @param filePath 文件路径
5
+ * @returns 是否是有效的文档文件路径
6
+ */
7
+ declare function isMusicFilePath(filePath: string): boolean;
8
+ export default isMusicFilePath;
@@ -1,18 +1,7 @@
1
- import { DocumentFileSuffixEnum, FileItemFeedTypeEnum, FileSuffixEnum, ImageFileSuffixEnum, PptFileSuffixEnum, VideoFileSuffixEnum } from '../extends/enum';
1
+ import { DocumentFileSuffixEnum, FileSuffixEnum, ImageFileSuffixEnum, PptFileSuffixEnum, VideoFileSuffixEnum } from '../extends/enum';
2
2
  type FileSuffix = (typeof FileSuffixEnum)[keyof typeof FileSuffixEnum];
3
3
  type ImageFileSuffix = (typeof ImageFileSuffixEnum)[keyof typeof ImageFileSuffixEnum];
4
4
  type VideoFileSuffix = (typeof VideoFileSuffixEnum)[keyof typeof VideoFileSuffixEnum];
5
5
  type PptFileSuffix = (typeof PptFileSuffixEnum)[keyof typeof PptFileSuffixEnum];
6
6
  type DocumentFileSuffix = (typeof DocumentFileSuffixEnum)[keyof typeof DocumentFileSuffixEnum];
7
- type FileItemFeedType = (typeof FileItemFeedTypeEnum)[keyof typeof FileItemFeedTypeEnum];
8
- /**
9
- * 明塗内部文件对象
10
- */
11
- interface IFileItem {
12
- title: string;
13
- viewUrl?: string;
14
- previewUrl?: string;
15
- createTime?: string;
16
- feedType?: FileItemFeedType;
17
- }
18
- export type { DocumentFileSuffix, FileItemFeedType, FileSuffix, IFileItem, ImageFileSuffix, PptFileSuffix, VideoFileSuffix, };
7
+ export type { DocumentFileSuffix, FileSuffix, ImageFileSuffix, PptFileSuffix, VideoFileSuffix, };
package/dist/index.js CHANGED
@@ -67,7 +67,7 @@ function beParsedAsNumber(value) {
67
67
  return Number.NaN;
68
68
  }
69
69
  function canBeParsedAsNumber(value) {
70
- return /^-?\d+\.\d+$/.test(String(value));
70
+ return !Number.isNaN(Number.parseFloat(String(value))) && Number.isFinite(Number(value));
71
71
  }
72
72
  function isArray(value) {
73
73
  return Array.isArray(value);
@@ -120,8 +120,7 @@ const FileSuffixEnum = {
120
120
  MP3: "mp3",
121
121
  WAV: "wav",
122
122
  TXT: "txt",
123
- HTML: "html",
124
- NULL: ""
123
+ HTML: "html"
125
124
  };
126
125
  const ImageFileSuffixEnum = {
127
126
  JPG: FileSuffixEnum.JPG,
@@ -148,29 +147,15 @@ const DocumentFileSuffixEnum = {
148
147
  XLS: FileSuffixEnum.XLS,
149
148
  XLSX: FileSuffixEnum.XLSX
150
149
  };
151
- const FileItemFeedTypeEnum = {
152
- ALL: "",
153
- DOCUMENT: 0,
154
- TEXT: 1,
155
- IMG: 2,
156
- VIDEO: 3,
157
- PPT: 4,
158
- QA: 5,
159
- AUDIO: 6,
160
- MUSIC: 7,
161
- AUTOHTML: 8,
162
- TWEET: 9,
163
- COMIC_STRIP: 10
164
- };
165
- const fileSuffixRegex = new RegExp(`\\.(${Object.values(FileSuffixEnum).join("|")})$`, "i");
166
- const fileNameRegex = /([^/]*)$/;
150
+ const filePathRegex = new RegExp(`(.*?)([^/.]*?)(\\.(${Object.values(FileSuffixEnum).join("|")}))?$`, "i");
167
151
  function getFileSuffix(filePath) {
168
- const matchResult = filePath.match(fileSuffixRegex);
169
- return matchResult ? matchResult[1].toLowerCase() : "";
152
+ var _a, _b;
153
+ const matchResult = filePath.match(filePathRegex);
154
+ return ((_b = (_a = matchResult == null ? void 0 : matchResult[4]) == null ? void 0 : _a.toLowerCase) == null ? void 0 : _b.call(_a)) ?? "";
170
155
  }
171
156
  function getFileTitle(filePath) {
172
- const matchResult = filePath.match(fileNameRegex);
173
- return matchResult ? matchResult[1].replace(fileSuffixRegex, "") : "";
157
+ const matchResult = filePath.match(filePathRegex);
158
+ return matchResult ? matchResult[3] : "";
174
159
  }
175
160
  function getFileName(filePath) {
176
161
  const fileTitle = getFileTitle(filePath);
@@ -221,29 +206,6 @@ async function batchDownloadFile(fileList, zipName) {
221
206
  const hasZip = zipName.lastIndexOf(".zip") === zipName.length - 4;
222
207
  FileSaver.saveAs(zipData, `${hasZip ? zipName : `${zipName}.zip`}`);
223
208
  }
224
- const FILE_SUFFIX_TO_FEED_TYPE_MAPPING = [
225
- {
226
- suffixes: Object.values(ImageFileSuffixEnum),
227
- feedType: FileItemFeedTypeEnum.IMG
228
- },
229
- {
230
- suffixes: Object.values(VideoFileSuffixEnum),
231
- feedType: FileItemFeedTypeEnum.VIDEO
232
- },
233
- {
234
- suffixes: Object.values(PptFileSuffixEnum),
235
- feedType: FileItemFeedTypeEnum.PPT
236
- },
237
- {
238
- suffixes: Object.values(DocumentFileSuffixEnum),
239
- feedType: FileItemFeedTypeEnum.TEXT
240
- }
241
- ];
242
- function getFileFeedType(filePath) {
243
- var _a;
244
- const fileSuffix = getFileSuffix(filePath);
245
- return (_a = FILE_SUFFIX_TO_FEED_TYPE_MAPPING.find(({ suffixes }) => suffixes.includes(fileSuffix))) == null ? void 0 : _a.feedType;
246
- }
247
209
  const defaultIcon = "";
248
210
  const excelIcon = "";
249
211
  const htmlIcon = "";
@@ -292,47 +254,37 @@ function getFileIcon(filePath) {
292
254
  const fileSuffix = getFileSuffix(filePath);
293
255
  return getFileSuffixIcon(fileSuffix);
294
256
  }
295
- function getFileItemSuffix(fileItem) {
296
- const { title, viewUrl } = fileItem;
297
- let fileSuffix = "";
298
- [title, viewUrl].filter(Boolean).some((path) => {
299
- if (!checkEmpty(getFileSuffix(path))) {
300
- fileSuffix += `${getFileSuffix(path)}`;
301
- return true;
302
- }
257
+ function isFilePath(filePath) {
258
+ if (checkEmpty(filePath)) {
303
259
  return false;
304
- });
305
- return fileSuffix;
306
- }
307
- function getFileItemIcon(fileItem) {
308
- const fileSuffix = getFileItemSuffix(fileItem);
309
- const fileIcon = getFileSuffixIcon(fileSuffix);
310
- return fileIcon;
260
+ }
261
+ return !!filePathRegex.test(filePath);
311
262
  }
312
263
  function isDocumentFilePath(filePath) {
313
- if (!filePath)
264
+ if (!isFilePath(filePath)) {
314
265
  return false;
266
+ }
315
267
  const fileSuffix = getFileSuffix(filePath);
316
268
  return Object.values(DocumentFileSuffixEnum).includes(fileSuffix);
317
269
  }
318
- function isFilePath(filePath) {
319
- return !!getFileSuffix(filePath);
320
- }
321
270
  function isImageFilePath(filePath) {
322
- if (!filePath)
271
+ if (!isFilePath(filePath)) {
323
272
  return false;
273
+ }
324
274
  const fileSuffix = getFileSuffix(filePath);
325
275
  return Object.values(ImageFileSuffixEnum).includes(fileSuffix);
326
276
  }
327
277
  function isPptFilePath(filePath) {
328
- if (!filePath)
278
+ if (!isFilePath(filePath)) {
329
279
  return false;
280
+ }
330
281
  const fileSuffix = getFileSuffix(filePath);
331
282
  return Object.values(PptFileSuffixEnum).includes(fileSuffix);
332
283
  }
333
284
  function isVideoFilePath(filePath) {
334
- if (!filePath)
285
+ if (!isFilePath(filePath)) {
335
286
  return false;
287
+ }
336
288
  const fileSuffix = getFileSuffix(filePath);
337
289
  return Object.values(VideoFileSuffixEnum).includes(fileSuffix);
338
290
  }
@@ -506,7 +458,6 @@ function createWorker(fun) {
506
458
  return worker;
507
459
  }
508
460
  export {
509
- FileItemFeedTypeEnum,
510
461
  FileSuffixEnum,
511
462
  ImageFileSuffixEnum,
512
463
  add,
@@ -527,10 +478,7 @@ export {
527
478
  deepFreeze,
528
479
  divide,
529
480
  getDecimalPlaces,
530
- getFileFeedType,
531
481
  getFileIcon,
532
- getFileItemIcon,
533
- getFileItemSuffix,
534
482
  getFileName,
535
483
  getFileSuffix,
536
484
  getFileSuffixIcon,
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "@minto-ai/tools",
3
3
  "type": "module",
4
- "version": "1.0.3",
4
+ "version": "1.0.33",
5
5
  "description": "明途公共工具库",
6
6
  "author": "hcc",
7
7
  "license": "ISC",
@@ -1,9 +0,0 @@
1
- import { FileItemFeedType } from './types';
2
- /**
3
- * 根据文件路径获取文件类型
4
- *
5
- * @param filePath 文件路径
6
- * @returns 文件类型(FileItemFeedTypeEnum)或 undefined(如果无法识别)
7
- */
8
- declare function getFileFeedType(filePath: string): FileItemFeedType | undefined;
9
- export default getFileFeedType;
@@ -1,9 +0,0 @@
1
- import { IFileItem } from './types';
2
- /**
3
- * 根据文件的后缀文件类型获取文件类型图标
4
- *
5
- * @param fileItem 文件实例
6
- * @returns 文件图标
7
- */
8
- declare function getFileItemIcon(fileItem: IFileItem): string;
9
- export default getFileItemIcon;
@@ -1,9 +0,0 @@
1
- import { FileSuffix, IFileItem } from './types';
2
- /**
3
- * 获取文件类型后缀,内部包含各种逻辑,可直接调用和修改
4
- *
5
- * @param fileItem 文件实例
6
- * @returns 文件类型后缀
7
- */
8
- declare function getFileItemSuffix(fileItem: IFileItem): FileSuffix;
9
- export default getFileItemSuffix;