@qxs-bns/utils 0.0.18 → 0.0.19
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/es/index.js +1 -10
- package/es/index.js.map +1 -1
- package/es/src/argo-log.js +1 -77
- package/es/src/argo-log.js.map +1 -1
- package/es/src/date-transfer.js +1 -33
- package/es/src/date-transfer.js.map +1 -1
- package/es/src/device.js +1 -22
- package/es/src/device.js.map +1 -1
- package/es/src/file-operations.js +1 -104
- package/es/src/file-operations.js.map +1 -1
- package/es/src/json.js +1 -66
- package/es/src/json.js.map +1 -1
- package/es/src/oss-uploader.js +1 -114
- package/es/src/oss-uploader.js.map +1 -1
- package/es/src/set-guid.js +2 -0
- package/es/src/set-guid.js.map +1 -0
- package/es/src/storage.js +1 -112
- package/es/src/storage.js.map +1 -1
- package/es/src/types.js +1 -37
- package/es/src/types.js.map +1 -1
- package/es/src/use-api.js +1 -64
- package/es/src/use-api.js.map +1 -1
- package/es/src/watermark.js +1 -208
- package/es/src/watermark.js.map +1 -1
- package/lib/index.js +1 -40
- package/lib/index.js.map +1 -1
- package/lib/src/argo-log.js +1 -79
- package/lib/src/argo-log.js.map +1 -1
- package/lib/src/date-transfer.js +1 -35
- package/lib/src/date-transfer.js.map +1 -1
- package/lib/src/device.js +1 -27
- package/lib/src/device.js.map +1 -1
- package/lib/src/file-operations.js +1 -107
- package/lib/src/file-operations.js.map +1 -1
- package/lib/src/json.js +1 -69
- package/lib/src/json.js.map +1 -1
- package/lib/src/oss-uploader.js +1 -119
- package/lib/src/oss-uploader.js.map +1 -1
- package/lib/src/set-guid.js +2 -0
- package/lib/src/set-guid.js.map +1 -0
- package/lib/src/storage.js +1 -114
- package/lib/src/storage.js.map +1 -1
- package/lib/src/types.js +1 -46
- package/lib/src/types.js.map +1 -1
- package/lib/src/use-api.js +1 -66
- package/lib/src/use-api.js.map +1 -1
- package/lib/src/watermark.js +1 -210
- package/lib/src/watermark.js.map +1 -1
- package/package.json +9 -1
- package/types/index.d.ts +1 -0
- package/types/index.d.ts.map +1 -1
- package/types/src/argo-log.d.ts.map +1 -1
- package/types/src/set-guid.d.ts +5 -0
- package/types/src/set-guid.d.ts.map +1 -0
- package/types/tsconfig.tsbuildinfo +1 -1
package/es/index.js
CHANGED
|
@@ -1,11 +1,2 @@
|
|
|
1
|
-
export
|
|
2
|
-
export { formatDuration } from './src/date-transfer.js';
|
|
3
|
-
export { getDeviceType, isAndroid, isIOS, isMobile } from './src/device.js';
|
|
4
|
-
export { createVideoUploader, downloadFile } from './src/file-operations.js';
|
|
5
|
-
export { JsonToExcel, excelToJson } from './src/json.js';
|
|
6
|
-
export { OssError, OssUploader, generateSignedUrl, uploadFile } from './src/oss-uploader.js';
|
|
7
|
-
export { Storage } from './src/storage.js';
|
|
8
|
-
export { isBoolean, isElement, isImageByMimeType, isJSONString, isNumber, isPlainObject, isUndefined, isWindow } from './src/types.js';
|
|
9
|
-
export { ApiService } from './src/use-api.js';
|
|
10
|
-
export { watermark } from './src/watermark.js';
|
|
1
|
+
export{ArgoLog}from"./src/argo-log.js";export{formatDuration}from"./src/date-transfer.js";export{getDeviceType,isAndroid,isIOS,isMobile}from"./src/device.js";export{createVideoUploader,downloadFile}from"./src/file-operations.js";export{JsonToExcel,excelToJson}from"./src/json.js";export{OssError,OssUploader,generateSignedUrl,uploadFile}from"./src/oss-uploader.js";export{setGuid}from"./src/set-guid.js";export{Storage}from"./src/storage.js";export{isBoolean,isElement,isImageByMimeType,isJSONString,isNumber,isPlainObject,isUndefined,isWindow}from"./src/types.js";export{ApiService}from"./src/use-api.js";export{watermark}from"./src/watermark.js";
|
|
11
2
|
//# sourceMappingURL=index.js.map
|
package/es/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sources":[],"sourcesContent":[],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"index.js","sources":[],"sourcesContent":[],"names":[],"mappings":""}
|
package/es/src/argo-log.js
CHANGED
|
@@ -1,78 +1,2 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
var __defProp = Object.defineProperty;
|
|
4
|
-
var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, {
|
|
5
|
-
enumerable: true,
|
|
6
|
-
configurable: true,
|
|
7
|
-
writable: true,
|
|
8
|
-
value
|
|
9
|
-
}) : obj[key] = value;
|
|
10
|
-
var __publicField = (obj, key, value) => __defNormalProp(obj, typeof key !== "symbol" ? key + "" : key, value);
|
|
11
|
-
const _ArgoLog = class _ArgoLog {
|
|
12
|
-
constructor(envConfig) {
|
|
13
|
-
__publicField(this, "AnalysysAgent", null);
|
|
14
|
-
__publicField(this, "track", (name, opt) => {
|
|
15
|
-
try {
|
|
16
|
-
if (!this.AnalysysAgent) {
|
|
17
|
-
console.warn("[ArgoLog] SDK \u672A\u521D\u59CB\u5316");
|
|
18
|
-
return;
|
|
19
|
-
}
|
|
20
|
-
if (!name) {
|
|
21
|
-
console.warn("[ArgoLog] track: name is required");
|
|
22
|
-
return;
|
|
23
|
-
}
|
|
24
|
-
this.AnalysysAgent.track(name, opt);
|
|
25
|
-
} catch (error) {
|
|
26
|
-
console.warn("[ArgoLog] track failed:", error);
|
|
27
|
-
}
|
|
28
|
-
});
|
|
29
|
-
__publicField(this, "setProfile", info => {
|
|
30
|
-
try {
|
|
31
|
-
if (!info) {
|
|
32
|
-
console.warn("[ArgoLog] setProfile: info is required");
|
|
33
|
-
return;
|
|
34
|
-
}
|
|
35
|
-
this.AnalysysAgent.profileSet(info);
|
|
36
|
-
} catch (error) {
|
|
37
|
-
console.warn("[ArgoLog] setProfile failed:", error);
|
|
38
|
-
}
|
|
39
|
-
});
|
|
40
|
-
__publicField(this, "setAlias", code => {
|
|
41
|
-
try {
|
|
42
|
-
if (!code) {
|
|
43
|
-
console.warn("[ArgoLog] setAlias: code is required");
|
|
44
|
-
return;
|
|
45
|
-
}
|
|
46
|
-
this.AnalysysAgent.alias(code);
|
|
47
|
-
} catch (error) {
|
|
48
|
-
console.warn("[ArgoLog] setAlias failed:", error);
|
|
49
|
-
}
|
|
50
|
-
});
|
|
51
|
-
try {
|
|
52
|
-
if (typeof window === "undefined") {
|
|
53
|
-
console.warn("[ArgoLog] \u4EC5\u652F\u6301\u6D4F\u89C8\u5668\u73AF\u5883");
|
|
54
|
-
return this;
|
|
55
|
-
}
|
|
56
|
-
const configKey = JSON.stringify(envConfig);
|
|
57
|
-
const existingInstance = _ArgoLog.instances.get(configKey);
|
|
58
|
-
if (existingInstance) {
|
|
59
|
-
return existingInstance;
|
|
60
|
-
}
|
|
61
|
-
if (!envConfig) {
|
|
62
|
-
console.error("envConfig is required");
|
|
63
|
-
return this;
|
|
64
|
-
}
|
|
65
|
-
this.AnalysysAgent = AnsJavascriptSdk;
|
|
66
|
-
this.AnalysysAgent.init(envConfig);
|
|
67
|
-
_ArgoLog.instances.set(configKey, this);
|
|
68
|
-
} catch (error) {
|
|
69
|
-
console.warn("[ArgoLog] Init failed:", error);
|
|
70
|
-
}
|
|
71
|
-
return this;
|
|
72
|
-
}
|
|
73
|
-
};
|
|
74
|
-
__publicField(_ArgoLog, "instances", /* @__PURE__ */new Map());
|
|
75
|
-
let ArgoLog = _ArgoLog;
|
|
76
|
-
|
|
77
|
-
export { ArgoLog };
|
|
1
|
+
var e=Object.defineProperty,t=(t,r,n)=>((t,r,n)=>r in t?e(t,r,{enumerable:!0,configurable:!0,writable:!0,value:n}):t[r]=n)(t,"symbol"!=typeof r?r+"":r,n);const r=class e{constructor(r){t(this,"AnalysysAgent",null),t(this,"track",((e,t)=>{try{if(!this.AnalysysAgent)return void console.warn("[ArgoLog] SDK 未初始化");if(!e)return void console.warn("[ArgoLog] track: name is required");this.AnalysysAgent.track(e,t)}catch(e){console.warn("[ArgoLog] track failed:",e)}})),t(this,"setProfile",(e=>{try{if(!e)return void console.warn("[ArgoLog] setProfile: info is required");this.AnalysysAgent.profileSet(e)}catch(e){console.warn("[ArgoLog] setProfile failed:",e)}})),t(this,"setAlias",(e=>{try{if(!e)return void console.warn("[ArgoLog] setAlias: code is required");this.AnalysysAgent.alias(e)}catch(e){console.warn("[ArgoLog] setAlias failed:",e)}}));try{if("undefined"==typeof window)return console.warn("[ArgoLog] 仅支持浏览器环境"),this;const t=JSON.stringify(r),n=e.instances.get(t);if(n)return n;if(!r)return console.error("envConfig is required"),this;import("ans-javascript-sdk").then((n=>{this.AnalysysAgent=n.default,this.AnalysysAgent.init(r),e.instances.set(t,this)})).catch((e=>{console.warn("[ArgoLog] SDK 加载失败:",e)}))}catch(e){console.warn("[ArgoLog] Init failed:",e)}return this}};t(r,"instances",new Map);let n=r;export{n as ArgoLog};
|
|
78
2
|
//# sourceMappingURL=argo-log.js.map
|
package/es/src/argo-log.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"argo-log.js","sources":["../../../../packages/utils/src/argo-log.ts"],"sourcesContent":["
|
|
1
|
+
{"version":3,"file":"argo-log.js","sources":["../../../../packages/utils/src/argo-log.ts"],"sourcesContent":["// 定义配置项的类型别名\nexport interface EnvironmentConfig {\n encryptType?: number\n debugMode?: number\n appkey: string\n uploadURL: string\n autoProfile?: boolean\n autoTrack?: boolean\n}\n\n/**\n * ArgoLog 类 - 用于处理埋点统计的工具类\n *\n * @class ArgoLog\n * @description 基于 AnalysysAgent SDK 封装的埋点工具类,提供了埋点追踪、用户画像设置和用户别名设置等功能\n * @example\n * ```typescript\n * const argoLog = new ArgoLog({\n * appkey: 'your-app-key',\n * uploadURL: 'your-upload-url'\n * });\n *\n * // 追踪事件\n * argoLog.track('event_name', { key: 'value' });\n * ```\n */\nexport class ArgoLog<T = EnvironmentConfig> {\n private static instances = new Map<string, ArgoLog<any>>()\n private AnalysysAgent: any | null = null\n\n constructor(envConfig: T) {\n try {\n // 检查是否为浏览器环境\n if (typeof window === 'undefined') {\n console.warn('[ArgoLog] 仅支持浏览器环境')\n return this\n }\n\n const configKey = JSON.stringify(envConfig)\n const existingInstance = ArgoLog.instances.get(configKey)\n\n if (existingInstance) {\n return existingInstance\n }\n\n if (!envConfig) {\n console.error('envConfig is required')\n return this\n }\n\n // 动态导入 SDK\n import('ans-javascript-sdk').then((module) => {\n this.AnalysysAgent = module.default\n this.AnalysysAgent.init(envConfig)\n ArgoLog.instances.set(configKey, this)\n }).catch((error) => {\n console.warn('[ArgoLog] SDK 加载失败:', error)\n })\n }\n catch (error) {\n console.warn('[ArgoLog] Init failed:', error)\n }\n\n return this\n }\n\n track = (name: string, opt?: Record<string, any>): void => {\n try {\n if (!this.AnalysysAgent) {\n console.warn('[ArgoLog] SDK 未初始化')\n return\n }\n if (!name) {\n console.warn('[ArgoLog] track: name is required')\n return\n }\n this.AnalysysAgent.track(name, opt)\n }\n catch (error) {\n console.warn('[ArgoLog] track failed:', error)\n }\n }\n\n setProfile = (info: Record<string, any>): void => {\n try {\n if (!info) {\n console.warn('[ArgoLog] setProfile: info is required')\n return\n }\n this.AnalysysAgent.profileSet(info)\n }\n catch (error) {\n console.warn('[ArgoLog] setProfile failed:', error)\n }\n }\n\n setAlias = (code: string): void => {\n try {\n if (!code) {\n console.warn('[ArgoLog] setAlias: code is required')\n return\n }\n this.AnalysysAgent.alias(code)\n }\n catch (error) {\n console.warn('[ArgoLog] setAlias failed:', error)\n }\n }\n}\n"],"names":["_ArgoLog","constructor","envConfig","__publicField","this","name","opt","AnalysysAgent","console","warn","track","error","info","profileSet","code","alias","window","configKey","JSON","stringify","existingInstance","instances","get","import","then","module","default","init","set","catch","Map","ArgoLog"],"mappings":"0JA0BO,MAAMA,EAAN,MAAMA,EAIXC,WAAAA,CAAYC,GAFZC,EAAAC,KAAQ,gBAA4B,MAsC5BD,EAAAC,KAAA,SAAA,CAACC,EAAcC,KACjB,IACE,IAACF,KAAKG,cAER,YADAC,QAAQC,KAAK,sBAGf,IAAKJ,EAEH,YADAG,QAAQC,KAAK,qCAGVL,KAAAG,cAAcG,MAAML,EAAMC,SAE1BK,GACGH,QAAAC,KAAK,0BAA2BE,EAC1C,KAGFR,EAAAC,KAAA,cAAcQ,IACR,IACF,IAAKA,EAEH,YADAJ,QAAQC,KAAK,0CAGVL,KAAAG,cAAcM,WAAWD,SAEzBD,GACGH,QAAAC,KAAK,+BAAgCE,EAC/C,KAGFR,EAAAC,KAAA,YAAYU,IACN,IACF,IAAKA,EAEH,YADAN,QAAQC,KAAK,wCAGVL,KAAAG,cAAcQ,MAAMD,SAEpBH,GACGH,QAAAC,KAAK,6BAA8BE,EAC7C,KA3EI,IAEE,GAAkB,oBAAXK,OAEF,OADPR,QAAQC,KAAK,sBACNL,KAGH,MAAAa,EAAYC,KAAKC,UAAUjB,GAC3BkB,EAAmBpB,EAAQqB,UAAUC,IAAIL,GAE/C,GAAIG,EACK,OAAAA,EAGT,IAAKlB,EAEI,OADPM,QAAQG,MAAM,yBACPP,KAITmB,OAAO,sBAAsBC,MAAMC,IACjCrB,KAAKG,cAAgBkB,EAAOC,QACvBtB,KAAAG,cAAcoB,KAAKzB,GAChBF,EAAAqB,UAAUO,IAAIX,EAAWb,KAAI,IACpCyB,OAAOlB,IACAH,QAAAC,KAAK,sBAAuBE,EAAK,UAGtCA,GACGH,QAAAC,KAAK,yBAA0BE,EACzC,CAEO,OAAAP,IACT,GArCAD,EADWH,EACI,YAAY,IAAI8B,KAD1B,IAAMC,EAAN/B"}
|
package/es/src/date-transfer.js
CHANGED
|
@@ -1,34 +1,2 @@
|
|
|
1
|
-
function
|
|
2
|
-
const seconds = Math.floor(ms / 1e3);
|
|
3
|
-
const minutes = Math.floor(seconds / 60);
|
|
4
|
-
const hours = Math.floor(minutes / 60);
|
|
5
|
-
const days = Math.floor(hours / 24);
|
|
6
|
-
const pad = num => num.toString().padStart(2, "0");
|
|
7
|
-
if (hours < 1) {
|
|
8
|
-
const mm = pad(minutes % 60);
|
|
9
|
-
const ss = pad(seconds % 60);
|
|
10
|
-
return `${mm}:${ss}`;
|
|
11
|
-
}
|
|
12
|
-
if (days < 1) {
|
|
13
|
-
const hh = pad(hours);
|
|
14
|
-
const mm = pad(minutes % 60);
|
|
15
|
-
const ss = pad(seconds % 60);
|
|
16
|
-
return `${hh}:${mm}:${ss}`;
|
|
17
|
-
}
|
|
18
|
-
const remainingHours = hours % 24;
|
|
19
|
-
const remainingMinutes = minutes % 60;
|
|
20
|
-
const parts = [];
|
|
21
|
-
if (days > 0) {
|
|
22
|
-
parts.push(`${days}\u5929`);
|
|
23
|
-
}
|
|
24
|
-
if (remainingHours > 0) {
|
|
25
|
-
parts.push(`${remainingHours}\u5C0F\u65F6`);
|
|
26
|
-
}
|
|
27
|
-
if (remainingMinutes > 0) {
|
|
28
|
-
parts.push(`${remainingMinutes}\u5206\u949F`);
|
|
29
|
-
}
|
|
30
|
-
return parts.join("");
|
|
31
|
-
}
|
|
32
|
-
|
|
33
|
-
export { formatDuration };
|
|
1
|
+
function t(t){const o=Math.floor(t/1e3),r=Math.floor(o/60),n=Math.floor(r/60),$=Math.floor(n/24),f=t=>t.toString().padStart(2,"0");if(n<1){return`${f(r%60)}:${f(o%60)}`}if($<1){return`${f(n)}:${f(r%60)}:${f(o%60)}`}const h=n%24,u=r%60,a=[];return $>0&&a.push(`${$}天`),h>0&&a.push(`${h}小时`),u>0&&a.push(`${u}分钟`),a.join("")}export{t as formatDuration};
|
|
34
2
|
//# sourceMappingURL=date-transfer.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"date-transfer.js","sources":["../../../../packages/utils/src/date-transfer.ts"],"sourcesContent":["/**\n * 智能格式化毫秒时间\n * @param ms 毫秒数\n * @returns 格式化后的时间字符串\n *\n * 规则:\n * 1. 小于1小时:显示 MM:SS\n * 2. 小于24小时:显示 HH:MM:SS\n * 3. 大于等于24小时:显示 x天x小时x分钟\n */\nexport function formatDuration(ms: number): string {\n const seconds = Math.floor(ms / 1000)\n const minutes = Math.floor(seconds / 60)\n const hours = Math.floor(minutes / 60)\n const days = Math.floor(hours / 24)\n\n const pad = (num: number) => num.toString().padStart(2, '0')\n\n // 如果时间小于1小时,返回 MM:SS\n if (hours < 1) {\n const mm = pad(minutes % 60)\n const ss = pad(seconds % 60)\n return `${mm}:${ss}`\n }\n\n // 如果时间小于24小时,返回 HH:MM:SS\n if (days < 1) {\n const hh = pad(hours)\n const mm = pad(minutes % 60)\n const ss = pad(seconds % 60)\n return `${hh}:${mm}:${ss}`\n }\n\n // 如果时间大于等于24小时,返回 x天x小时x分钟\n const remainingHours = hours % 24\n const remainingMinutes = minutes % 60\n\n const parts: string[] = []\n if (days > 0) {\n parts.push(`${days}天`)\n }\n if (remainingHours > 0) {\n parts.push(`${remainingHours}小时`)\n }\n if (remainingMinutes > 0) {\n parts.push(`${remainingMinutes}分钟`)\n }\n\n return parts.join('')\n}\n"],"names":["formatDuration","ms","seconds","Math","floor","minutes","hours","days","pad","num","toString","padStart","
|
|
1
|
+
{"version":3,"file":"date-transfer.js","sources":["../../../../packages/utils/src/date-transfer.ts"],"sourcesContent":["/**\n * 智能格式化毫秒时间\n * @param ms 毫秒数\n * @returns 格式化后的时间字符串\n *\n * 规则:\n * 1. 小于1小时:显示 MM:SS\n * 2. 小于24小时:显示 HH:MM:SS\n * 3. 大于等于24小时:显示 x天x小时x分钟\n */\nexport function formatDuration(ms: number): string {\n const seconds = Math.floor(ms / 1000)\n const minutes = Math.floor(seconds / 60)\n const hours = Math.floor(minutes / 60)\n const days = Math.floor(hours / 24)\n\n const pad = (num: number) => num.toString().padStart(2, '0')\n\n // 如果时间小于1小时,返回 MM:SS\n if (hours < 1) {\n const mm = pad(minutes % 60)\n const ss = pad(seconds % 60)\n return `${mm}:${ss}`\n }\n\n // 如果时间小于24小时,返回 HH:MM:SS\n if (days < 1) {\n const hh = pad(hours)\n const mm = pad(minutes % 60)\n const ss = pad(seconds % 60)\n return `${hh}:${mm}:${ss}`\n }\n\n // 如果时间大于等于24小时,返回 x天x小时x分钟\n const remainingHours = hours % 24\n const remainingMinutes = minutes % 60\n\n const parts: string[] = []\n if (days > 0) {\n parts.push(`${days}天`)\n }\n if (remainingHours > 0) {\n parts.push(`${remainingHours}小时`)\n }\n if (remainingMinutes > 0) {\n parts.push(`${remainingMinutes}分钟`)\n }\n\n return parts.join('')\n}\n"],"names":["formatDuration","ms","seconds","Math","floor","minutes","hours","days","pad","num","toString","padStart","remainingHours","remainingMinutes","parts","push","join"],"mappings":"AAUO,SAASA,EAAeC,GAC7B,MAAMC,EAAUC,KAAKC,MAAMH,EAAK,KAC1BI,EAAUF,KAAKC,MAAMF,EAAU,IAC/BI,EAAQH,KAAKC,MAAMC,EAAU,IAC7BE,EAAOJ,KAAKC,MAAME,EAAQ,IAE1BE,EAAOC,GAAgBA,EAAIC,WAAWC,SAAS,EAAG,KAGxD,GAAIL,EAAQ,EAAG,CAGN,MAAA,GAFIE,EAAIH,EAAU,OACdG,EAAIN,EAAU,KAE3B,CAGA,GAAIK,EAAO,EAAG,CAIZ,MAAO,GAHIC,EAAIF,MACJE,EAAIH,EAAU,OACdG,EAAIN,EAAU,KAE3B,CAGA,MAAMU,EAAiBN,EAAQ,GACzBO,EAAmBR,EAAU,GAE7BS,EAAkB,GAWjB,OAVHP,EAAO,GACHO,EAAAC,KAAK,GAAGR,MAEZK,EAAiB,GACbE,EAAAC,KAAK,GAAGH,OAEZC,EAAmB,GACfC,EAAAC,KAAK,GAAGF,OAGTC,EAAME,KAAK,GACpB"}
|
package/es/src/device.js
CHANGED
|
@@ -1,23 +1,2 @@
|
|
|
1
|
-
function
|
|
2
|
-
const userAgent = navigator.userAgent;
|
|
3
|
-
if (/iPhone|iPad|iPod|iOS/i.test(userAgent)) {
|
|
4
|
-
return "iOS";
|
|
5
|
-
} else if (/Android/i.test(userAgent)) {
|
|
6
|
-
return "Android";
|
|
7
|
-
} else {
|
|
8
|
-
return "desktop";
|
|
9
|
-
}
|
|
10
|
-
}
|
|
11
|
-
function isMobile() {
|
|
12
|
-
const deviceType = getDeviceType();
|
|
13
|
-
return deviceType === "iOS" || deviceType === "Android";
|
|
14
|
-
}
|
|
15
|
-
function isIOS() {
|
|
16
|
-
return /iPhone|iPad|iPod|iOS/i.test(navigator.userAgent);
|
|
17
|
-
}
|
|
18
|
-
function isAndroid() {
|
|
19
|
-
return /Android/i.test(navigator.userAgent);
|
|
20
|
-
}
|
|
21
|
-
|
|
22
|
-
export { getDeviceType, isAndroid, isIOS, isMobile };
|
|
1
|
+
function n(){const n=navigator.userAgent;return/iPhone|iPad|iPod|iOS/i.test(n)?"iOS":/Android/i.test(n)?"Android":"desktop"}function t(){const t=n();return"iOS"===t||"Android"===t}function i(){return/iPhone|iPad|iPod|iOS/i.test(navigator.userAgent)}function o(){return/Android/i.test(navigator.userAgent)}export{n as getDeviceType,o as isAndroid,i as isIOS,t as isMobile};
|
|
23
2
|
//# sourceMappingURL=device.js.map
|
package/es/src/device.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"device.js","sources":["../../../../packages/utils/src/device.ts"],"sourcesContent":["/**\n * 获取设备类型\n * @returns {string} 设备类型: \"iOS\", \"Android\" 或 \"desktop\"\n */\nexport function getDeviceType() {\n const userAgent = navigator.userAgent\n\n if (/iPhone|iPad|iPod|iOS/i.test(userAgent)) {\n return 'iOS'\n }\n else if (/Android/i.test(userAgent)) {\n return 'Android'\n }\n else {\n return 'desktop'\n }\n}\n\n/**\n * 判断是否是移动端\n */\nexport function isMobile() {\n const deviceType = getDeviceType()\n return deviceType === 'iOS' || deviceType === 'Android'\n}\n\n/**\n * 判断是否是ios\n */\nexport function isIOS() {\n return /iPhone|iPad|iPod|iOS/i.test(navigator.userAgent)\n}\n\n/**\n * 判断是否是安卓\n */\nexport function isAndroid() {\n return /Android/i.test(navigator.userAgent)\n}\n"],"names":["getDeviceType","userAgent","navigator","test","isMobile","deviceType","isIOS","isAndroid"],"mappings":"AAIO,SAASA,
|
|
1
|
+
{"version":3,"file":"device.js","sources":["../../../../packages/utils/src/device.ts"],"sourcesContent":["/**\n * 获取设备类型\n * @returns {string} 设备类型: \"iOS\", \"Android\" 或 \"desktop\"\n */\nexport function getDeviceType() {\n const userAgent = navigator.userAgent\n\n if (/iPhone|iPad|iPod|iOS/i.test(userAgent)) {\n return 'iOS'\n }\n else if (/Android/i.test(userAgent)) {\n return 'Android'\n }\n else {\n return 'desktop'\n }\n}\n\n/**\n * 判断是否是移动端\n */\nexport function isMobile() {\n const deviceType = getDeviceType()\n return deviceType === 'iOS' || deviceType === 'Android'\n}\n\n/**\n * 判断是否是ios\n */\nexport function isIOS() {\n return /iPhone|iPad|iPod|iOS/i.test(navigator.userAgent)\n}\n\n/**\n * 判断是否是安卓\n */\nexport function isAndroid() {\n return /Android/i.test(navigator.userAgent)\n}\n"],"names":["getDeviceType","userAgent","navigator","test","isMobile","deviceType","isIOS","isAndroid"],"mappings":"AAIO,SAASA,IACd,MAAMC,EAAYC,UAAUD,UAExB,MAAA,wBAAwBE,KAAKF,GACxB,MAEA,WAAWE,KAAKF,GAChB,UAGA,SAEX,CAKO,SAASG,IACd,MAAMC,EAAaL,IACZ,MAAe,QAAfK,GAAuC,YAAfA,CACjC,CAKO,SAASC,IACP,MAAA,wBAAwBH,KAAKD,UAAUD,UAChD,CAKO,SAASM,IACP,MAAA,WAAWJ,KAAKD,UAAUD,UACnC"}
|
|
@@ -1,105 +1,2 @@
|
|
|
1
|
-
async function
|
|
2
|
-
return new Promise((resolve, reject) => {
|
|
3
|
-
try {
|
|
4
|
-
const script = document.createElement("script");
|
|
5
|
-
script.src = src;
|
|
6
|
-
script.onload = () => {
|
|
7
|
-
resolve();
|
|
8
|
-
};
|
|
9
|
-
script.onerror = () => {
|
|
10
|
-
reject(new Error(`Failed to load script from ${src}`));
|
|
11
|
-
};
|
|
12
|
-
document.head.appendChild(script);
|
|
13
|
-
} catch (error) {
|
|
14
|
-
console.error("loadScript error:", error);
|
|
15
|
-
reject(error);
|
|
16
|
-
}
|
|
17
|
-
});
|
|
18
|
-
}
|
|
19
|
-
async function initAliyunSDK() {
|
|
20
|
-
try {
|
|
21
|
-
await loadScript("https://gosspublic.alicdn.com/aliyun-oss-sdk.min.js");
|
|
22
|
-
await loadScript("https://cdnfile.yaomaitong.cn/cdn/js/aliyun-upload-sdk1.3.1.min.js");
|
|
23
|
-
if (!window.AliyunUpload) {
|
|
24
|
-
throw new Error("SDK \u52A0\u8F7D\u6210\u529F\u4F46\u672A\u627E\u5230 AliyunUpload \u5BF9\u8C61");
|
|
25
|
-
}
|
|
26
|
-
} catch (error) {
|
|
27
|
-
console.error("\u65E0\u6CD5\u52A0\u8F7D\u963F\u91CC\u4E91\u4E0A\u4F20SDK:", error);
|
|
28
|
-
throw error;
|
|
29
|
-
}
|
|
30
|
-
}
|
|
31
|
-
async function createVideoUploader(options) {
|
|
32
|
-
if (typeof window === "undefined") {
|
|
33
|
-
throw new TypeError("VideoUploader \u53EA\u80FD\u5728\u6D4F\u89C8\u5668\u73AF\u5883\u4E2D\u4F7F\u7528");
|
|
34
|
-
}
|
|
35
|
-
if (!window.AliyunUpload) {
|
|
36
|
-
await initAliyunSDK();
|
|
37
|
-
}
|
|
38
|
-
let currentResolve = null;
|
|
39
|
-
let currentReject = null;
|
|
40
|
-
const uploader = new window.AliyunUpload.Vod({
|
|
41
|
-
// 上传进度回调
|
|
42
|
-
onUploadProgress: options.onUploadProgress,
|
|
43
|
-
// 上传凭证过期回调
|
|
44
|
-
onUploadTokenExpired: options.onUploadTokenExpired || (() => {}),
|
|
45
|
-
// 开始上传回调,用于设置上传凭证和地址
|
|
46
|
-
onUploadstarted: async uploadInfo => {
|
|
47
|
-
try {
|
|
48
|
-
const {
|
|
49
|
-
uploadAuth,
|
|
50
|
-
uploadAddress,
|
|
51
|
-
videoId
|
|
52
|
-
} = (await options.onUploadstarted?.(uploadInfo)) || {};
|
|
53
|
-
if (uploadAuth && uploadAddress && videoId) {
|
|
54
|
-
uploader.setUploadAuthAndAddress(uploadInfo, uploadAuth, uploadAddress, videoId);
|
|
55
|
-
}
|
|
56
|
-
} catch (error) {
|
|
57
|
-
console.error("onUploadstarted error: ", error);
|
|
58
|
-
throw error;
|
|
59
|
-
}
|
|
60
|
-
},
|
|
61
|
-
// 上传成功回调
|
|
62
|
-
onUploadSucceed: uploadInfo => {
|
|
63
|
-
currentResolve?.(uploadInfo);
|
|
64
|
-
},
|
|
65
|
-
// 上传失败回调
|
|
66
|
-
onUploadFailed: (info, code, message) => {
|
|
67
|
-
console.log("info: ", info);
|
|
68
|
-
currentReject?.(new Error(`${message} ${code}`));
|
|
69
|
-
}
|
|
70
|
-
});
|
|
71
|
-
const upload = async file => {
|
|
72
|
-
return new Promise((resolve, reject) => {
|
|
73
|
-
currentResolve = resolve;
|
|
74
|
-
currentReject = reject;
|
|
75
|
-
const userData = JSON.stringify({
|
|
76
|
-
Vod: {
|
|
77
|
-
UserData: {
|
|
78
|
-
IsShowWaterMark: "false",
|
|
79
|
-
// 不显示水印
|
|
80
|
-
Priority: "7"
|
|
81
|
-
// 上传优先级
|
|
82
|
-
}
|
|
83
|
-
}
|
|
84
|
-
});
|
|
85
|
-
uploader.addFile(file, null, null, null, userData);
|
|
86
|
-
uploader.startUpload();
|
|
87
|
-
});
|
|
88
|
-
};
|
|
89
|
-
return {
|
|
90
|
-
uploader,
|
|
91
|
-
upload
|
|
92
|
-
};
|
|
93
|
-
}
|
|
94
|
-
function downloadFile(url, fileName) {
|
|
95
|
-
const link = document.createElement("a");
|
|
96
|
-
link.download = fileName;
|
|
97
|
-
link.style.display = "none";
|
|
98
|
-
link.href = url;
|
|
99
|
-
document.body.appendChild(link);
|
|
100
|
-
link.click();
|
|
101
|
-
document.body.removeChild(link);
|
|
102
|
-
}
|
|
103
|
-
|
|
104
|
-
export { createVideoUploader, downloadFile };
|
|
1
|
+
async function o(o){return new Promise(((n,e)=>{try{const r=document.createElement("script");r.src=o,r.onload=()=>{n()},r.onerror=()=>{e(new Error(`Failed to load script from ${o}`))},document.head.appendChild(r)}catch(o){console.error("loadScript error:",o),e(o)}}))}async function n(n){if("undefined"==typeof window)throw new TypeError("VideoUploader 只能在浏览器环境中使用");window.AliyunUpload||await async function(){try{if(await o("https://gosspublic.alicdn.com/aliyun-oss-sdk.min.js"),await o("https://cdnfile.yaomaitong.cn/cdn/js/aliyun-upload-sdk1.3.1.min.js"),!window.AliyunUpload)throw new Error("SDK 加载成功但未找到 AliyunUpload 对象")}catch(o){throw console.error("无法加载阿里云上传SDK:",o),o}}();let e=null,r=null;const d=new window.AliyunUpload.Vod({onUploadProgress:n.onUploadProgress,onUploadTokenExpired:n.onUploadTokenExpired||(()=>{}),onUploadstarted:async o=>{try{const{uploadAuth:e,uploadAddress:r,videoId:a}=await(n.onUploadstarted?.(o))||{};e&&r&&a&&d.setUploadAuthAndAddress(o,e,r,a)}catch(o){throw console.error("onUploadstarted error: ",o),o}},onUploadSucceed:o=>{e?.(o)},onUploadFailed:(o,n,e)=>{console.log("info: ",o),r?.(new Error(`${e} ${n}`))}});return{uploader:d,upload:async o=>new Promise(((n,a)=>{e=n,r=a;const l=JSON.stringify({Vod:{UserData:{IsShowWaterMark:"false",Priority:"7"}}});d.addFile(o,null,null,null,l),d.startUpload()}))}}function e(o,n){const e=document.createElement("a");e.download=n,e.style.display="none",e.href=o,document.body.appendChild(e),e.click(),document.body.removeChild(e)}export{n as createVideoUploader,e as downloadFile};
|
|
105
2
|
//# sourceMappingURL=file-operations.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"file-operations.js","sources":["../../../../packages/utils/src/file-operations.ts"],"sourcesContent":["/// <reference types=\"vite/client\" />\n\ndeclare global {\n interface Window {\n AliyunUpload: any\n OSS: any\n }\n}\n\nasync function loadScript(src: string): Promise<void> {\n return new Promise((resolve, reject) => {\n try {\n const script = document.createElement('script')\n script.src = src\n script.onload = () => {\n resolve()\n }\n script.onerror = () => {\n reject(new Error(`Failed to load script from ${src}`))\n }\n document.head.appendChild(script)\n }\n catch (error) {\n console.error('loadScript error:', error)\n reject(error)\n }\n })\n}\nasync function initAliyunSDK() {\n try {\n await loadScript('https://gosspublic.alicdn.com/aliyun-oss-sdk.min.js')\n await loadScript('https://cdnfile.yaomaitong.cn/cdn/js/aliyun-upload-sdk1.3.1.min.js')\n\n if (!window.AliyunUpload) {\n throw new Error('SDK 加载成功但未找到 AliyunUpload 对象')\n }\n }\n catch (error) {\n console.error('无法加载阿里云上传SDK:', error)\n throw error\n }\n}\n\nexport interface UploadInfo {\n file: File\n videoId?: string\n}\n\ninterface VideoUploadOptions {\n onUploadFailed?: (uploadInfo: any, code: string, message: string) => void\n onUploadSucceed?: (uploadInfo: any) => void\n onUploadProgress?: (uploadInfo: UploadInfo, totalSize: number, percent: number) => void\n onUploadTokenExpired?: (response: any) => void\n onUploadstarted?: (uploadInfo: UploadInfo) => Promise<{ uploadAuth: string, uploadAddress: string, videoId: string }>\n}\n\ninterface VideoUploadResult {\n videoId: string\n uploadInfo: any\n}\nexport interface IVideoUploader {\n uploader: any\n upload: (file: File) => Promise<VideoUploadResult>\n}\n\n/**\n * 创建阿里云视频上传器实例\n * @param options - 上传配置选项,包含各种回调函数\n * @returns 返回一个包含上传器实例和上传方法的对象\n */\nexport async function createVideoUploader(options: VideoUploadOptions): Promise<IVideoUploader> {\n // 检查是否在浏览器环境中运行\n if (typeof window === 'undefined') {\n throw new TypeError('VideoUploader 只能在浏览器环境中使用')\n }\n\n // 如果阿里云SDK未加载,则初始化SDK\n if (!window.AliyunUpload) {\n await initAliyunSDK()\n }\n\n // 声明Promise的resolve和reject函数,用于控制上传过程\n let currentResolve: ((value: VideoUploadResult) => void) | null = null\n let currentReject: ((reason: any) => void) | null = null\n\n // 创建阿里云上传实例\n const uploader = new window.AliyunUpload.Vod({\n // 上传进度回调\n onUploadProgress: options.onUploadProgress,\n // 上传凭证过期回调\n onUploadTokenExpired: options.onUploadTokenExpired || (() => {}),\n // 开始上传回调,用于设置上传凭证和地址\n onUploadstarted: async (uploadInfo: UploadInfo) => {\n try {\n const { uploadAuth, uploadAddress, videoId } = await options.onUploadstarted?.(uploadInfo) || {}\n if (uploadAuth && uploadAddress && videoId) {\n uploader.setUploadAuthAndAddress(uploadInfo, uploadAuth, uploadAddress, videoId)\n }\n }\n catch (error) {\n console.error('onUploadstarted error: ', error)\n throw error\n }\n },\n // 上传成功回调\n onUploadSucceed: (uploadInfo: any) => {\n currentResolve?.(uploadInfo)\n },\n // 上传失败回调\n onUploadFailed: (info: any, code: string, message: string) => {\n console.log('info: ', info)\n currentReject?.(new Error(`${message} ${code}`))\n },\n })\n\n /**\n * 上传文件方法\n * @param file - 要上传的文件对象\n * @returns Promise,解析为上传结果\n */\n const upload = async (file: File): Promise<VideoUploadResult> => {\n return new Promise((resolve, reject) => {\n currentResolve = resolve\n currentReject = reject\n\n // 设置上传的用户自定义数据\n const userData = JSON.stringify({\n Vod: {\n UserData: {\n IsShowWaterMark: 'false', // 不显示水印\n Priority: '7', // 上传优先级\n },\n },\n })\n\n // 添加文件到上传队列并开始上传\n uploader.addFile(file, null, null, null, userData)\n uploader.startUpload()\n })\n }\n\n // 返回上传器实例和上传方法\n return {\n uploader,\n upload,\n }\n}\n\n/**\n * 下载文件,创建一个隐藏的链接元素,设置下载属性并触发点击事件,然后移除该链接元素\n * @param url - 文件的URL\n * @param fileName - 文件的名称\n */\nexport function downloadFile(url: string, fileName: string) {\n const link = document.createElement('a')\n link.download = fileName\n link.style.display = 'none'\n link.href = url\n document.body.appendChild(link)\n link.click()\n document.body.removeChild(link)\n}\n"],"names":["loadScript","src","Promise","resolve","reject","script","document","createElement","onload","onerror","Error","head","appendChild","error","console","
|
|
1
|
+
{"version":3,"file":"file-operations.js","sources":["../../../../packages/utils/src/file-operations.ts"],"sourcesContent":["/// <reference types=\"vite/client\" />\n\ndeclare global {\n interface Window {\n AliyunUpload: any\n OSS: any\n }\n}\n\nasync function loadScript(src: string): Promise<void> {\n return new Promise((resolve, reject) => {\n try {\n const script = document.createElement('script')\n script.src = src\n script.onload = () => {\n resolve()\n }\n script.onerror = () => {\n reject(new Error(`Failed to load script from ${src}`))\n }\n document.head.appendChild(script)\n }\n catch (error) {\n console.error('loadScript error:', error)\n reject(error)\n }\n })\n}\nasync function initAliyunSDK() {\n try {\n await loadScript('https://gosspublic.alicdn.com/aliyun-oss-sdk.min.js')\n await loadScript('https://cdnfile.yaomaitong.cn/cdn/js/aliyun-upload-sdk1.3.1.min.js')\n\n if (!window.AliyunUpload) {\n throw new Error('SDK 加载成功但未找到 AliyunUpload 对象')\n }\n }\n catch (error) {\n console.error('无法加载阿里云上传SDK:', error)\n throw error\n }\n}\n\nexport interface UploadInfo {\n file: File\n videoId?: string\n}\n\ninterface VideoUploadOptions {\n onUploadFailed?: (uploadInfo: any, code: string, message: string) => void\n onUploadSucceed?: (uploadInfo: any) => void\n onUploadProgress?: (uploadInfo: UploadInfo, totalSize: number, percent: number) => void\n onUploadTokenExpired?: (response: any) => void\n onUploadstarted?: (uploadInfo: UploadInfo) => Promise<{ uploadAuth: string, uploadAddress: string, videoId: string }>\n}\n\ninterface VideoUploadResult {\n videoId: string\n uploadInfo: any\n}\nexport interface IVideoUploader {\n uploader: any\n upload: (file: File) => Promise<VideoUploadResult>\n}\n\n/**\n * 创建阿里云视频上传器实例\n * @param options - 上传配置选项,包含各种回调函数\n * @returns 返回一个包含上传器实例和上传方法的对象\n */\nexport async function createVideoUploader(options: VideoUploadOptions): Promise<IVideoUploader> {\n // 检查是否在浏览器环境中运行\n if (typeof window === 'undefined') {\n throw new TypeError('VideoUploader 只能在浏览器环境中使用')\n }\n\n // 如果阿里云SDK未加载,则初始化SDK\n if (!window.AliyunUpload) {\n await initAliyunSDK()\n }\n\n // 声明Promise的resolve和reject函数,用于控制上传过程\n let currentResolve: ((value: VideoUploadResult) => void) | null = null\n let currentReject: ((reason: any) => void) | null = null\n\n // 创建阿里云上传实例\n const uploader = new window.AliyunUpload.Vod({\n // 上传进度回调\n onUploadProgress: options.onUploadProgress,\n // 上传凭证过期回调\n onUploadTokenExpired: options.onUploadTokenExpired || (() => {}),\n // 开始上传回调,用于设置上传凭证和地址\n onUploadstarted: async (uploadInfo: UploadInfo) => {\n try {\n const { uploadAuth, uploadAddress, videoId } = await options.onUploadstarted?.(uploadInfo) || {}\n if (uploadAuth && uploadAddress && videoId) {\n uploader.setUploadAuthAndAddress(uploadInfo, uploadAuth, uploadAddress, videoId)\n }\n }\n catch (error) {\n console.error('onUploadstarted error: ', error)\n throw error\n }\n },\n // 上传成功回调\n onUploadSucceed: (uploadInfo: any) => {\n currentResolve?.(uploadInfo)\n },\n // 上传失败回调\n onUploadFailed: (info: any, code: string, message: string) => {\n console.log('info: ', info)\n currentReject?.(new Error(`${message} ${code}`))\n },\n })\n\n /**\n * 上传文件方法\n * @param file - 要上传的文件对象\n * @returns Promise,解析为上传结果\n */\n const upload = async (file: File): Promise<VideoUploadResult> => {\n return new Promise((resolve, reject) => {\n currentResolve = resolve\n currentReject = reject\n\n // 设置上传的用户自定义数据\n const userData = JSON.stringify({\n Vod: {\n UserData: {\n IsShowWaterMark: 'false', // 不显示水印\n Priority: '7', // 上传优先级\n },\n },\n })\n\n // 添加文件到上传队列并开始上传\n uploader.addFile(file, null, null, null, userData)\n uploader.startUpload()\n })\n }\n\n // 返回上传器实例和上传方法\n return {\n uploader,\n upload,\n }\n}\n\n/**\n * 下载文件,创建一个隐藏的链接元素,设置下载属性并触发点击事件,然后移除该链接元素\n * @param url - 文件的URL\n * @param fileName - 文件的名称\n */\nexport function downloadFile(url: string, fileName: string) {\n const link = document.createElement('a')\n link.download = fileName\n link.style.display = 'none'\n link.href = url\n document.body.appendChild(link)\n link.click()\n document.body.removeChild(link)\n}\n"],"names":["async","loadScript","src","Promise","resolve","reject","script","document","createElement","onload","onerror","Error","head","appendChild","error","console","createVideoUploader","options","window","TypeError","AliyunUpload","initAliyunSDK","currentResolve","currentReject","uploader","Vod","onUploadProgress","onUploadTokenExpired","onUploadstarted","uploadAuth","uploadAddress","videoId","uploadInfo","setUploadAuthAndAddress","onUploadSucceed","onUploadFailed","info","code","message","log","upload","userData","JSON","stringify","UserData","IsShowWaterMark","Priority","addFile","file","startUpload","downloadFile","url","fileName","link","download","style","display","href","body","click","removeChild"],"mappings":"AASAA,eAAeC,EAAWC,GACxB,OAAO,IAAIC,SAAQ,CAACC,EAASC,KACvB,IACI,MAAAC,EAASC,SAASC,cAAc,UACtCF,EAAOJ,IAAMA,EACbI,EAAOG,OAAS,KACNL,GAAA,EAEVE,EAAOI,QAAU,KACfL,EAAO,IAAIM,MAAM,8BAA8BT,KAAM,EAE9CK,SAAAK,KAAKC,YAAYP,SAErBQ,GACGC,QAAAD,MAAM,oBAAqBA,GACnCT,EAAOS,EACT,IAEJ,CA2CAd,eAAsBgB,EAAoBC,GAEpC,GAAkB,oBAAXC,OACH,MAAA,IAAIC,UAAU,6BAIjBD,OAAOE,oBAjDdpB,iBACM,IAIE,SAHEC,EAAW,6DACXA,EAAW,uEAEZiB,OAAOE,aACJ,MAAA,IAAIT,MAAM,sCAGbG,GAEC,MADEC,QAAAD,MAAM,gBAAiBA,GACzBA,CACR,CACF,CAqCUO,GAIR,IAAIC,EAA8D,KAC9DC,EAAgD,KAGpD,MAAMC,EAAW,IAAIN,OAAOE,aAAaK,IAAI,CAE3CC,iBAAkBT,EAAQS,iBAE1BC,qBAAsBV,EAAQU,sBAAyB,MAAO,GAE9DC,gBAAiB5B,UACX,IACI,MAAA6B,WAAEA,EAAYC,cAAAA,EAAAC,QAAeA,SAAkBd,EAAQW,kBAAkBI,KAAe,CAAC,EAC3FH,GAAcC,GAAiBC,GACjCP,EAASS,wBAAwBD,EAAYH,EAAYC,EAAeC,SAGrEjB,GAEC,MADEC,QAAAD,MAAM,0BAA2BA,GACnCA,CACR,GAGFoB,gBAAkBF,IAChBV,IAAiBU,EAAU,EAG7BG,eAAgBA,CAACC,EAAWC,EAAcC,KAChCvB,QAAAwB,IAAI,SAAUH,GACtBb,IAAgB,IAAIZ,MAAM,GAAG2B,KAAWD,KAAO,IA+B5C,MAAA,CACLb,WACAgB,OAxBaxC,SACN,IAAIG,SAAQ,CAACC,EAASC,KACViB,EAAAlB,EACDmB,EAAAlB,EAGV,MAAAoC,EAAWC,KAAKC,UAAU,CAC9BlB,IAAK,CACHmB,SAAU,CACRC,gBAAiB,QACjBC,SAAU,QAMhBtB,EAASuB,QAAQC,EAAM,KAAM,KAAM,KAAMP,GACzCjB,EAASyB,aAAY,IAS3B,CAOgB,SAAAC,EAAaC,EAAaC,GAClC,MAAAC,EAAO9C,SAASC,cAAc,KACpC6C,EAAKC,SAAWF,EAChBC,EAAKE,MAAMC,QAAU,OACrBH,EAAKI,KAAON,EACH5C,SAAAmD,KAAK7C,YAAYwC,GAC1BA,EAAKM,QACIpD,SAAAmD,KAAKE,YAAYP,EAC5B"}
|
package/es/src/json.js
CHANGED
|
@@ -1,67 +1,2 @@
|
|
|
1
|
-
import {
|
|
2
|
-
|
|
3
|
-
function JsonToExcel() {
|
|
4
|
-
let title = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : "";
|
|
5
|
-
let json = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : [];
|
|
6
|
-
let merge = arguments.length > 2 ? arguments[2] : undefined;
|
|
7
|
-
try {
|
|
8
|
-
if (!json.length) {
|
|
9
|
-
return;
|
|
10
|
-
}
|
|
11
|
-
const worksheet = utils.aoa_to_sheet(json);
|
|
12
|
-
if (merge) {
|
|
13
|
-
worksheet["!merges"] = merge;
|
|
14
|
-
}
|
|
15
|
-
const workbook = utils.book_new();
|
|
16
|
-
utils.book_append_sheet(workbook, worksheet, "");
|
|
17
|
-
writeFile(workbook, `${title}.xlsx`);
|
|
18
|
-
} catch (e) {
|
|
19
|
-
console.log("e: ", e);
|
|
20
|
-
return new Error("\u6570\u636E\u5BFC\u51FA\u5931\u8D25");
|
|
21
|
-
}
|
|
22
|
-
}
|
|
23
|
-
function excelToJson(file, cb, start) {
|
|
24
|
-
return new Promise((resolve, reject) => {
|
|
25
|
-
const reader = new FileReader();
|
|
26
|
-
reader.readAsArrayBuffer(file);
|
|
27
|
-
reader.onload = e => {
|
|
28
|
-
const data = e.target?.result;
|
|
29
|
-
const workbook = read(data, {
|
|
30
|
-
type: "binary"
|
|
31
|
-
});
|
|
32
|
-
const json = [];
|
|
33
|
-
for (const sheet in workbook.Sheets) {
|
|
34
|
-
if (Object.prototype.hasOwnProperty.call(workbook.Sheets, sheet)) {
|
|
35
|
-
let arr = [];
|
|
36
|
-
const fromTo = workbook.Sheets[sheet]["!ref"] || "";
|
|
37
|
-
const end = fromTo.split(":");
|
|
38
|
-
const space = start + end[1].toString();
|
|
39
|
-
arr = arr.concat(utils.sheet_to_json(workbook.Sheets[sheet], {
|
|
40
|
-
header: 1,
|
|
41
|
-
range: start ? space : fromTo
|
|
42
|
-
}));
|
|
43
|
-
const titleArr = arr[0];
|
|
44
|
-
arr.shift();
|
|
45
|
-
const excelJsonArr = arr.map(item => {
|
|
46
|
-
const obj = {};
|
|
47
|
-
titleArr.forEach((titleItem, index) => {
|
|
48
|
-
obj[titleItem] = item[index];
|
|
49
|
-
});
|
|
50
|
-
return obj;
|
|
51
|
-
});
|
|
52
|
-
json.push(...excelJsonArr);
|
|
53
|
-
}
|
|
54
|
-
}
|
|
55
|
-
if (cb) {
|
|
56
|
-
cb(json);
|
|
57
|
-
}
|
|
58
|
-
resolve(json);
|
|
59
|
-
};
|
|
60
|
-
reader.onerror = e => {
|
|
61
|
-
reject(e);
|
|
62
|
-
};
|
|
63
|
-
});
|
|
64
|
-
}
|
|
65
|
-
|
|
66
|
-
export { JsonToExcel, excelToJson };
|
|
1
|
+
import{utils as e,writeFile as t,read as o}from"xlsx";function r(){let o=arguments.length>0&&void 0!==arguments[0]?arguments[0]:"",r=arguments.length>1&&void 0!==arguments[1]?arguments[1]:[],n=arguments.length>2?arguments[2]:void 0;try{if(!r.length)return;const s=e.aoa_to_sheet(r);n&&(s["!merges"]=n);const c=e.book_new();e.book_append_sheet(c,s,""),t(c,`${o}.xlsx`)}catch(e){return console.log("e: ",e),new Error("数据导出失败")}}function n(t,r,n){return new Promise(((s,c)=>{const a=new FileReader;a.readAsArrayBuffer(t),a.onload=t=>{const c=t.target?.result,a=o(c,{type:"binary"}),h=[];for(const t in a.Sheets)if(Object.prototype.hasOwnProperty.call(a.Sheets,t)){let o=[];const r=a.Sheets[t]["!ref"]||"",s=r.split(":"),c=n+s[1].toString();o=o.concat(e.sheet_to_json(a.Sheets[t],{header:1,range:n?c:r}));const l=o[0];o.shift();const i=o.map((e=>{const t={};return l.forEach(((o,r)=>{t[o]=e[r]})),t}));h.push(...i)}r&&r(h),s(h)},a.onerror=e=>{c(e)}}))}export{r as JsonToExcel,n as excelToJson};
|
|
67
2
|
//# sourceMappingURL=json.js.map
|
package/es/src/json.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"json.js","sources":["../../../../packages/utils/src/json.ts"],"sourcesContent":["import { read, utils, writeFile } from 'xlsx'\n\n/**\n * 将JSON数据导出为Excel文件\n * @param title - Excel文件的标题\n * @param json - JSON数据\n * @param merge - 合并单元格的配置\n * @returns 如果JSON数据为空,则返回undefined,否则返回Excel文件的名称\n */\nexport function JsonToExcel(title = '', json: (string | number)[][] = [], merge?: any) {\n try {\n if (!json.length) {\n return\n }\n // 创建worksheet\n const worksheet = utils.aoa_to_sheet(json)\n if (merge) {\n worksheet['!merges'] = merge\n }\n // 新建空workbook,加入worksheet\n const workbook = utils.book_new()\n utils.book_append_sheet(workbook, worksheet, '')\n writeFile(workbook, `${title}.xlsx`)\n }\n catch (e) {\n console.log('e: ', e)\n return new Error('数据导出失败')\n }\n}\n\n/**\n * 将Excel数据转换为JSON\n * @param file - Excel文件\n * @param cb - 转换完成后的回调函数\n * @param start - 开始行号\n */\nexport function excelToJson(file: File, cb: (json: any[]) => void, start: number): Promise<any[]> {\n return new Promise((resolve, reject) => {\n const reader = new FileReader()\n reader.readAsArrayBuffer(file)\n reader.onload = (e) => {\n const data = e.target?.result\n const workbook = read(data, { type: 'binary' })\n // 遍历每张表读取\n const json: any[] = []\n for (const sheet in workbook.Sheets) {\n if (Object.prototype.hasOwnProperty.call(workbook.Sheets, sheet)) {\n let arr: string[][] = []\n const fromTo = workbook.Sheets[sheet]['!ref'] || ''\n const end = fromTo.split(':')\n const space = start + end[1].toString()\n arr = arr.concat(utils.sheet_to_json(workbook.Sheets[sheet], { header: 1, range: start ? space : fromTo }))\n const titleArr = arr[0]\n arr.shift()\n const excelJsonArr = arr.map((item) => {\n const obj: {\n [key: string]: any\n } = {}\n titleArr.forEach((titleItem: string, index: number) => {\n obj[titleItem] = item[index]\n })\n return obj\n })\n json.push(...excelJsonArr)\n }\n }\n if (cb) {\n cb(json)\n }\n resolve(json)\n }\n reader.onerror = (e) => {\n reject(e)\n }\n })\n}\n"],"names":["JsonToExcel","title","arguments","length","undefined","json","merge","worksheet","utils","aoa_to_sheet","workbook","book_new","book_append_sheet","writeFile","e","console","log","Error","excelToJson","file","cb","start","Promise","resolve","reject","reader","FileReader","readAsArrayBuffer","onload","data","target","result","read","type","sheet","Sheets","Object","prototype","hasOwnProperty","call","arr","fromTo","end","split","space","toString","concat","sheet_to_json","header","range","titleArr","shift","excelJsonArr","map","item","obj","forEach","titleItem","index","push","onerror"],"mappings":"
|
|
1
|
+
{"version":3,"file":"json.js","sources":["../../../../packages/utils/src/json.ts"],"sourcesContent":["import { read, utils, writeFile } from 'xlsx'\n\n/**\n * 将JSON数据导出为Excel文件\n * @param title - Excel文件的标题\n * @param json - JSON数据\n * @param merge - 合并单元格的配置\n * @returns 如果JSON数据为空,则返回undefined,否则返回Excel文件的名称\n */\nexport function JsonToExcel(title = '', json: (string | number)[][] = [], merge?: any) {\n try {\n if (!json.length) {\n return\n }\n // 创建worksheet\n const worksheet = utils.aoa_to_sheet(json)\n if (merge) {\n worksheet['!merges'] = merge\n }\n // 新建空workbook,加入worksheet\n const workbook = utils.book_new()\n utils.book_append_sheet(workbook, worksheet, '')\n writeFile(workbook, `${title}.xlsx`)\n }\n catch (e) {\n console.log('e: ', e)\n return new Error('数据导出失败')\n }\n}\n\n/**\n * 将Excel数据转换为JSON\n * @param file - Excel文件\n * @param cb - 转换完成后的回调函数\n * @param start - 开始行号\n */\nexport function excelToJson(file: File, cb: (json: any[]) => void, start: number): Promise<any[]> {\n return new Promise((resolve, reject) => {\n const reader = new FileReader()\n reader.readAsArrayBuffer(file)\n reader.onload = (e) => {\n const data = e.target?.result\n const workbook = read(data, { type: 'binary' })\n // 遍历每张表读取\n const json: any[] = []\n for (const sheet in workbook.Sheets) {\n if (Object.prototype.hasOwnProperty.call(workbook.Sheets, sheet)) {\n let arr: string[][] = []\n const fromTo = workbook.Sheets[sheet]['!ref'] || ''\n const end = fromTo.split(':')\n const space = start + end[1].toString()\n arr = arr.concat(utils.sheet_to_json(workbook.Sheets[sheet], { header: 1, range: start ? space : fromTo }))\n const titleArr = arr[0]\n arr.shift()\n const excelJsonArr = arr.map((item) => {\n const obj: {\n [key: string]: any\n } = {}\n titleArr.forEach((titleItem: string, index: number) => {\n obj[titleItem] = item[index]\n })\n return obj\n })\n json.push(...excelJsonArr)\n }\n }\n if (cb) {\n cb(json)\n }\n resolve(json)\n }\n reader.onerror = (e) => {\n reject(e)\n }\n })\n}\n"],"names":["JsonToExcel","title","arguments","length","undefined","json","merge","worksheet","utils","aoa_to_sheet","workbook","book_new","book_append_sheet","writeFile","e","console","log","Error","excelToJson","file","cb","start","Promise","resolve","reject","reader","FileReader","readAsArrayBuffer","onload","data","target","result","read","type","sheet","Sheets","Object","prototype","hasOwnProperty","call","arr","fromTo","end","split","space","toString","concat","sheet_to_json","header","range","titleArr","shift","excelJsonArr","map","item","obj","forEach","titleItem","index","push","onerror"],"mappings":"sDASO,SAASA,IAAuE,IAA3DC,EAAQC,UAAAC,OAAA,QAAAC,IAAAF,UAAA,GAAAA,UAAA,GAAA,GAAIG,EAA8BH,UAAAC,OAAA,QAAAC,IAAAF,UAAA,GAAAA,UAAA,GAAA,GAAII,EAAaJ,UAAAC,OAAAD,EAAAA,kBAAAE,EACjF,IACE,IAACC,EAAKF,OACR,OAGI,MAAAI,EAAYC,EAAMC,aAAaJ,GACjCC,IACFC,EAAU,WAAaD,GAGnB,MAAAI,EAAWF,EAAMG,WACjBH,EAAAI,kBAAkBF,EAAUH,EAAW,IACnCM,EAAAH,EAAU,GAAGT,gBAElBa,GAEE,OADCC,QAAAC,IAAI,MAAOF,GACZ,IAAIG,MAAM,SACnB,CACF,CAQgB,SAAAC,EAAYC,EAAYC,EAA2BC,GACjE,OAAO,IAAIC,SAAQ,CAACC,EAASC,KACrB,MAAAC,EAAS,IAAIC,WACnBD,EAAOE,kBAAkBR,GAClBM,EAAAG,OAAUd,IACT,MAAAe,EAAOf,EAAEgB,QAAQC,OACjBrB,EAAWsB,EAAKH,EAAM,CAAEI,KAAM,WAE9B5B,EAAc,GACT,IAAA,MAAA6B,KAASxB,EAASyB,OAC3B,GAAIC,OAAOC,UAAUC,eAAeC,KAAK7B,EAASyB,OAAQD,GAAQ,CAChE,IAAIM,EAAkB,GACtB,MAAMC,EAAS/B,EAASyB,OAAOD,GAAO,SAAW,GAC3CQ,EAAMD,EAAOE,MAAM,KACnBC,EAAQvB,EAAQqB,EAAI,GAAGG,WAC7BL,EAAMA,EAAIM,OAAOtC,EAAMuC,cAAcrC,EAASyB,OAAOD,GAAQ,CAAEc,OAAQ,EAAGC,MAAO5B,EAAQuB,EAAQH,KAC3F,MAAAS,EAAWV,EAAI,GACrBA,EAAIW,QACJ,MAAMC,EAAeZ,EAAIa,KAAKC,IAC5B,MAAMC,EAEF,CAAC,EAIE,OAHEL,EAAAM,SAAQ,CAACC,EAAmBC,KAC/BH,EAAAE,GAAaH,EAAKI,EAAK,IAEtBH,CAAA,IAEJlD,EAAAsD,QAAQP,EACf,CAEEhC,GACFA,EAAGf,GAELkB,EAAQlB,EAAI,EAEPoB,EAAAmC,QAAW9C,IAChBU,EAAOV,EAAC,CACV,GAEJ"}
|
package/es/src/oss-uploader.js
CHANGED
|
@@ -1,115 +1,2 @@
|
|
|
1
|
-
import
|
|
2
|
-
|
|
3
|
-
var __defProp = Object.defineProperty;
|
|
4
|
-
var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, {
|
|
5
|
-
enumerable: true,
|
|
6
|
-
configurable: true,
|
|
7
|
-
writable: true,
|
|
8
|
-
value
|
|
9
|
-
}) : obj[key] = value;
|
|
10
|
-
var __publicField = (obj, key, value) => __defNormalProp(obj, typeof key !== "symbol" ? key + "" : key, value);
|
|
11
|
-
class OssError extends Error {
|
|
12
|
-
constructor(message) {
|
|
13
|
-
super(message);
|
|
14
|
-
this.name = "OssError";
|
|
15
|
-
}
|
|
16
|
-
}
|
|
17
|
-
const ossConfig = {
|
|
18
|
-
accessKeyId: "",
|
|
19
|
-
accessKeySecret: "",
|
|
20
|
-
stsToken: "",
|
|
21
|
-
secure: true,
|
|
22
|
-
bucket: "yao-file-daily",
|
|
23
|
-
region: "oss-cn-hangzhou",
|
|
24
|
-
cors: true,
|
|
25
|
-
useFetch: false,
|
|
26
|
-
timeout: 6e4,
|
|
27
|
-
headers: {
|
|
28
|
-
"Access-Control-Allow-Origin": "*",
|
|
29
|
-
"Access-Control-Allow-Methods": "GET, POST, PUT, DELETE",
|
|
30
|
-
"Access-Control-Allow-Headers": "*"
|
|
31
|
-
}
|
|
32
|
-
};
|
|
33
|
-
class OssUploader {
|
|
34
|
-
// 获取凭证
|
|
35
|
-
static async getOssCredentials(getCredentials) {
|
|
36
|
-
const credentials = await getCredentials();
|
|
37
|
-
if (!credentials) {
|
|
38
|
-
throw new OssError("\u83B7\u53D6\u51ED\u8BC1\u5931\u8D25");
|
|
39
|
-
}
|
|
40
|
-
return {
|
|
41
|
-
accessKeyId: credentials.accessKeyId,
|
|
42
|
-
accessKeySecret: credentials.accessKeySecret,
|
|
43
|
-
securityToken: credentials.securityToken
|
|
44
|
-
};
|
|
45
|
-
}
|
|
46
|
-
// 修改初始化方法
|
|
47
|
-
static async initOssClient(getCredentials, args) {
|
|
48
|
-
const diff = Date.now() - this.createTokenTime;
|
|
49
|
-
if (!ossConfig.accessKeyId || diff > this.expireTime) {
|
|
50
|
-
try {
|
|
51
|
-
const {
|
|
52
|
-
accessKeyId,
|
|
53
|
-
accessKeySecret,
|
|
54
|
-
securityToken: stsToken
|
|
55
|
-
} = await this.getOssCredentials(getCredentials);
|
|
56
|
-
Object.assign(ossConfig, {
|
|
57
|
-
accessKeyId,
|
|
58
|
-
accessKeySecret,
|
|
59
|
-
stsToken,
|
|
60
|
-
...args,
|
|
61
|
-
refreshSTSToken: async () => {
|
|
62
|
-
return await this.getOssCredentials(getCredentials);
|
|
63
|
-
},
|
|
64
|
-
refreshSTSTokenInterval: 3e5
|
|
65
|
-
});
|
|
66
|
-
this.createTokenTime = Date.now();
|
|
67
|
-
this.client = new OSS(ossConfig);
|
|
68
|
-
} catch (error) {
|
|
69
|
-
throw new OssError(error instanceof Error ? error.message : String(error));
|
|
70
|
-
}
|
|
71
|
-
}
|
|
72
|
-
}
|
|
73
|
-
// 修改上传方法
|
|
74
|
-
static async uploadFile(opts) {
|
|
75
|
-
const {
|
|
76
|
-
file,
|
|
77
|
-
onProgress = () => {},
|
|
78
|
-
path = "ksh/pdf",
|
|
79
|
-
getCredentials,
|
|
80
|
-
...rest
|
|
81
|
-
} = opts;
|
|
82
|
-
await this.initOssClient(getCredentials, rest);
|
|
83
|
-
try {
|
|
84
|
-
const result = await this.client.multipartUpload(`${path}/${file.name}`, file, {
|
|
85
|
-
progress(p) {
|
|
86
|
-
onProgress({
|
|
87
|
-
percent: Math.round(p * 100)
|
|
88
|
-
});
|
|
89
|
-
}
|
|
90
|
-
});
|
|
91
|
-
return result;
|
|
92
|
-
} catch (error) {
|
|
93
|
-
throw new OssError(error instanceof Error ? error.message : String(error));
|
|
94
|
-
}
|
|
95
|
-
}
|
|
96
|
-
// 修改生成签名URL方法
|
|
97
|
-
static async generateSignedUrl(objectKey, getCredentials, args) {
|
|
98
|
-
await this.initOssClient(getCredentials, args);
|
|
99
|
-
try {
|
|
100
|
-
return await this.client.signatureUrl(objectKey, {
|
|
101
|
-
expires: 60 * 60
|
|
102
|
-
});
|
|
103
|
-
} catch (error) {
|
|
104
|
-
throw new OssError(error instanceof Error ? error.message : String(error));
|
|
105
|
-
}
|
|
106
|
-
}
|
|
107
|
-
}
|
|
108
|
-
__publicField(OssUploader, "client");
|
|
109
|
-
__publicField(OssUploader, "createTokenTime", 0);
|
|
110
|
-
__publicField(OssUploader, "expireTime", 15 * 60 * 1e3);
|
|
111
|
-
const uploadFile = OssUploader.uploadFile.bind(OssUploader);
|
|
112
|
-
const generateSignedUrl = OssUploader.generateSignedUrl.bind(OssUploader);
|
|
113
|
-
|
|
114
|
-
export { OssError, OssUploader, generateSignedUrl, uploadFile };
|
|
1
|
+
import e from"ali-oss";var s=Object.defineProperty,t=(e,t,r)=>((e,t,r)=>t in e?s(e,t,{enumerable:!0,configurable:!0,writable:!0,value:r}):e[t]=r)(e,"symbol"!=typeof t?t+"":t,r);class r extends Error{constructor(e){super(e),this.name="OssError"}}const n={accessKeyId:"",accessKeySecret:"",stsToken:"",secure:!0,bucket:"yao-file-daily",region:"oss-cn-hangzhou",cors:!0,useFetch:!1,timeout:6e4,headers:{"Access-Control-Allow-Origin":"*","Access-Control-Allow-Methods":"GET, POST, PUT, DELETE","Access-Control-Allow-Headers":"*"}};class c{static async getOssCredentials(e){const s=await e();if(!s)throw new r("获取凭证失败");return{accessKeyId:s.accessKeyId,accessKeySecret:s.accessKeySecret,securityToken:s.securityToken}}static async initOssClient(s,t){const c=Date.now()-this.createTokenTime;if(!n.accessKeyId||c>this.expireTime)try{const{accessKeyId:r,accessKeySecret:c,securityToken:i}=await this.getOssCredentials(s);Object.assign(n,{accessKeyId:r,accessKeySecret:c,stsToken:i,...t,refreshSTSToken:async()=>await this.getOssCredentials(s),refreshSTSTokenInterval:3e5}),this.createTokenTime=Date.now(),this.client=new e(n)}catch(e){throw new r(e instanceof Error?e.message:String(e))}}static async uploadFile(e){const{file:s,onProgress:t=()=>{},path:n="ksh/pdf",getCredentials:c,...i}=e;await this.initOssClient(c,i);try{return await this.client.multipartUpload(`${n}/${s.name}`,s,{progress(e){t({percent:Math.round(100*e)})}})}catch(e){throw new r(e instanceof Error?e.message:String(e))}}static async generateSignedUrl(e,s,t){await this.initOssClient(s,t);try{return await this.client.signatureUrl(e,{expires:3600})}catch(e){throw new r(e instanceof Error?e.message:String(e))}}}t(c,"client"),t(c,"createTokenTime",0),t(c,"expireTime",9e5);const i=c.uploadFile.bind(c),a=c.generateSignedUrl.bind(c);export{r as OssError,c as OssUploader,a as generateSignedUrl,i as uploadFile};
|
|
115
2
|
//# sourceMappingURL=oss-uploader.js.map
|