@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/src/watermark.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"watermark.js","sources":["../../../../packages/utils/src/watermark.ts"],"sourcesContent":["interface SettingsType {\n /** 水印总体的id */\n id?: string\n /** 小水印的id前缀 */\n prefix?: string\n /** 水印文案 */\n text?: string\n /** 水印起始位置x轴坐标 */\n x?: number\n /** 水印起始位置Y轴坐标 */\n y?: number\n /** 水印行数 */\n rows?: number\n /** 水印列数 */\n cols?: number\n /** 水印x轴间隔 */\n x_space?: number\n /** 水印y轴间隔 */\n y_space?: number\n /** 水印字体 */\n font?: string\n /** 水印字体颜色 */\n color?: string\n /** 水印字体大小 */\n fontsize?: string\n /** 水印透明度,要求设置在大于等于0.005 */\n alpha?: number\n /** 水印宽度 */\n width?: number\n /** 水印长度 */\n height?: number\n /** 水印倾斜度数 */\n angle?: number\n /** 水印的总体宽度(默认值:body的scrollWidth和clientWidth的较大值) */\n parent_width?: number\n /** 水印的总体高度(默认值:body的scrollHeight和clientHeight的较大值) */\n parent_height?: number\n /** 水印插件挂载的父元素element,不输入则默认挂在body */\n parent_node?: HTMLElement | null\n /** 是否监控,true: 不可删除水印; false: 可删水印 */\n monitor?: boolean\n}\n\n// 默认配置\nconst initialSettings: Required<SettingsType> = {\n id: 'wm_div_id',\n prefix: 'mask_div_id',\n text: '测试水印',\n x: 0,\n y: 0,\n rows: 0,\n cols: 0,\n width: 0,\n height: 0,\n x_space: 100,\n y_space: 40,\n font: '微软雅黑',\n color: 'black',\n fontsize: '18px',\n alpha: 0.15,\n angle: 15,\n parent_width: 0,\n parent_height: 0,\n parent_node: null,\n monitor: true,\n}\n\nfunction calculateTextDimensions(text: string, font: string, fontSize: string): { width: number, height: number } {\n const canvas = document.createElement('canvas')\n const context = canvas.getContext('2d')\n if (!context) {\n return { width: 100, height: 100 }\n }\n\n context.font = `${fontSize} ${font}`\n const metrics = context.measureText(text.trim())\n const fontSizeNum = Number.parseFloat(fontSize)\n\n // 移除 DPI 缩放,直接使用原始值\n const height = (metrics.actualBoundingBoxAscent !== undefined && metrics.actualBoundingBoxDescent !== undefined)\n ? (metrics.actualBoundingBoxAscent + metrics.actualBoundingBoxDescent)\n : fontSizeNum\n\n return {\n width: Math.ceil(metrics.width),\n height: Math.ceil(height),\n }\n}\n\nexport function watermark() {\n const globalSetting: Required<SettingsType> = { ...initialSettings }\n let forceRemove = false\n const watermarkDom = new MutationObserver(domChangeCallback)\n const resizeObserver = new ResizeObserver(() => {\n if (!forceRemove) {\n loadMark(globalSetting)\n }\n })\n\n // 计算水印布局\n function calculateWatermarkLayout(pageWidth: number, pageHeight: number) {\n const availableWidth = pageWidth - globalSetting.x\n const availableHeight = pageHeight - globalSetting.y\n\n // 使用固定间距\n const x_space = globalSetting.x_space || 20 // 如果未设置则使用默认值\n const y_space = globalSetting.y_space || 20 // 如果未设置则使用默认值\n\n // 计算能容纳的行数和列数\n const cols = Math.ceil(availableWidth / (globalSetting.width + x_space))\n const rows = Math.ceil(availableHeight / (globalSetting.height + y_space))\n\n return {\n cols,\n rows,\n x_space,\n y_space,\n }\n }\n\n // 创建水印元素\n function createWatermarkElement(x: number, y: number, index: number): HTMLElement {\n const maskDiv = document.createElement('div')\n maskDiv.textContent = globalSetting.text\n maskDiv.id = `${globalSetting.prefix}${index}`\n\n maskDiv.style.cssText = `\n transform: rotate(-${globalSetting.angle}deg);\n position: absolute;\n left: ${x}px;\n top: ${y}px;\n overflow: hidden;\n z-index: 9999999;\n opacity: ${globalSetting.alpha};\n font-size: ${globalSetting.fontsize};\n font-family: ${globalSetting.font};\n color: ${globalSetting.color};\n text-align: center;\n width: ${globalSetting.width}px;\n height: ${globalSetting.height}px;\n line-height: ${globalSetting.height}px;\n display: flex;\n align-items: center;\n justify-content: center;\n user-select: none;\n visibility: visible;\n `.replace(/\\s+/g, ' ').trim()\n\n return maskDiv\n }\n\n // 加载水印\n function loadMark(settings: Partial<SettingsType>) {\n removeMark()\n Object.assign(globalSetting, settings)\n\n if ((globalSetting.width === 0 && globalSetting.height === 0) || globalSetting.width === 0 || globalSetting.height === 0) {\n // 计算文本尺寸\n const textDimensions = calculateTextDimensions(\n globalSetting.text,\n globalSetting.font,\n globalSetting.fontsize,\n )\n const padding = 10\n if (globalSetting.width === 0) {\n globalSetting.width = textDimensions.width + padding\n }\n if (globalSetting.height === 0) {\n globalSetting.height = textDimensions.height + padding\n }\n }\n\n const parentElement = globalSetting.parent_node || document.body\n const pageWidth = Math.max(parentElement.scrollWidth, parentElement.clientWidth)\n const pageHeight = Math.max(parentElement.scrollHeight, parentElement.clientHeight)\n\n const watermarkContainer = document.createElement('div')\n watermarkContainer.id = globalSetting.id\n\n // 处理父元素定位\n if (parentElement.closest('body') && getComputedStyle(parentElement).position === 'static') {\n parentElement.style.position = 'relative'\n }\n\n watermarkContainer.style.cssText = `\n pointer-events: none;\n display: block;\n position: absolute;\n top: 0;\n left: 0;\n width: 100%;\n height: 100%;\n z-index: 9999999;\n overflow: hidden;\n `.replace(/\\s+/g, ' ').trim()\n\n const shadowRoot = watermarkContainer.attachShadow ? watermarkContainer.attachShadow({ mode: 'open' }) : watermarkContainer\n\n parentElement.appendChild(watermarkContainer)\n\n const { cols, rows, x_space, y_space } = calculateWatermarkLayout(pageWidth, pageHeight)\n globalSetting.cols = cols\n globalSetting.rows = rows\n globalSetting.x_space = x_space\n globalSetting.y_space = y_space\n\n const fragment = document.createDocumentFragment()\n for (let i = 0; i < rows; i++) {\n const y = globalSetting.y + (globalSetting.height + y_space) * i\n for (let j = 0; j < cols; j++) {\n const x = globalSetting.x + (globalSetting.width + x_space) * j\n fragment.appendChild(createWatermarkElement(x, y, i * cols + j))\n }\n }\n shadowRoot.appendChild(fragment)\n\n if (globalSetting.monitor) {\n // 监听父元素大小变化\n resizeObserver.observe(parentElement)\n\n // 监听水印容器及其子元素\n const config: MutationObserverInit = {\n attributes: true, // 监听属性变化\n childList: true, // 监听子元素变化\n subtree: true, // 监听子树变化\n characterData: true, // 监听文本内容变化\n }\n\n // 监听水印容器\n watermarkDom.observe(watermarkContainer, config)\n\n // 如果使用了 Shadow DOM,还需要监听 shadowRoot 内的元素\n if (shadowRoot !== watermarkContainer) {\n watermarkDom.observe(shadowRoot, config)\n }\n }\n }\n\n // 移除水印\n function removeMark() {\n const watermarkElement = document.getElementById(globalSetting.id)\n watermarkDom.disconnect()\n if (watermarkElement) {\n watermarkElement.parentNode?.removeChild(watermarkElement)\n }\n }\n\n // 监听DOM变化\n function domChangeCallback(records: MutationRecord[]) {\n if (forceRemove) {\n forceRemove = false\n return\n }\n\n const watermarkElement = document.getElementById(globalSetting.id)\n if (!watermarkElement) {\n // 如果水印容器被删除,重新创建\n loadMark(globalSetting)\n return\n }\n\n // 检查是否有任何修改\n const hasChanges = records.some((record) => {\n // 检查元素是否被删除或添加\n if (record.type === 'childList') {\n return true\n }\n\n // 检查属性是否被修改\n if (record.type === 'attributes') {\n return true\n }\n\n // 检查文本内容是否被修改\n if (record.type === 'characterData') {\n return true\n }\n\n return false\n })\n\n if (hasChanges) {\n loadMark(globalSetting)\n }\n }\n\n return {\n addMark: loadMark,\n removeMark: () => {\n forceRemove = true\n // 删除这行,不重置全局配置\n // Object.assign(globalSetting, initialSettings)\n removeMark()\n },\n }\n}\n"],"names":["initialSettings","id","prefix","text","x","y","rows","cols","width","height","x_space","y_space","font","color","fontsize","alpha","angle","parent_width","parent_height","parent_node","monitor","calculateTextDimensions","fontSize","canvas","document","createElement","context","getContext","metrics","measureText","trim","fontSizeNum","Number","parseFloat","actualBoundingBoxAscent","actualBoundingBoxDescent","Math","ceil","watermark","globalSetting","forceRemove","watermarkDom","MutationObserver","domChangeCallback","resizeObserver","ResizeObserver","loadMark","calculateWatermarkLayout","pageWidth","pageHeight","availableWidth","availableHeight","createWatermarkElement","index","maskDiv","textContent","style","cssText","replace","settings","removeMark","Object","assign","textDimensions","padding","parentElement","body","max","scrollWidth","clientWidth","scrollHeight","clientHeight","watermarkContainer","closest","getComputedStyle","position","shadowRoot","attachShadow","mode","appendChild","fragment","createDocumentFragment","i","j","observe","config","attributes","childList","subtree","characterData","watermarkElement","getElementById","disconnect","parentNode","removeChild","records","hasChanges","some","record","type","addMark"],"mappings":"AA4CA,MAAMA,eAA0C,GAAA;AAC9CC,EAAAA,EAAI,EAAA,WAAA;AACJC,EAAAA,MAAQ,EAAA,aAAA;AACRC,EAAAA,IAAM,EAAA,0BAAA;AACNC,EAAAA,CAAG,EAAA,CAAA;AACHC,EAAAA,CAAG,EAAA,CAAA;AACHC,EAAAA,IAAM,EAAA,CAAA;AACNC,EAAAA,IAAM,EAAA,CAAA;AACNC,EAAAA,KAAO,EAAA,CAAA;AACPC,EAAAA,MAAQ,EAAA,CAAA;AACRC,EAAAA,OAAS,EAAA,GAAA;AACTC,EAAAA,OAAS,EAAA,EAAA;AACTC,EAAAA,IAAM,EAAA,0BAAA;AACNC,EAAAA,KAAO,EAAA,OAAA;AACPC,EAAAA,QAAU,EAAA,MAAA;AACVC,EAAAA,KAAO,EAAA,IAAA;AACPC,EAAAA,KAAO,EAAA,EAAA;AACPC,EAAAA,YAAc,EAAA,CAAA;AACdC,EAAAA,aAAe,EAAA,CAAA;AACfC,EAAAA,WAAa,EAAA,IAAA;AACbC,EAAAA,OAAS,EAAA;AACX,CAAA;AAEA,SAASC,uBAAAA,CAAwBlB,IAAc,EAAAS,IAAA,EAAcU,QAAqD,EAAA;AAC1G,EAAA,MAAAC,MAAA,GAASC,QAAS,CAAAC,aAAA,CAAc,QAAQ,CAAA;AACxC,EAAA,MAAAC,OAAA,GAAUH,MAAO,CAAAI,UAAA,CAAW,IAAI,CAAA;EACtC,IAAI,CAACD,OAAS,EAAA;IACZ,OAAO;AAAElB,MAAAA,KAAA,EAAO,GAAK;AAAAC,MAAAA,MAAA,EAAQ;KAAI;AACnC;AAEAiB,EAAAA,OAAA,CAAQd,IAAO,GAAA,GAAGU,QAAQ,CAAA,CAAA,EAAIV,IAAI,CAAA,CAAA;EAClC,MAAMgB,OAAU,GAAAF,OAAA,CAAQG,WAAY,CAAA1B,IAAA,CAAK2B,MAAM,CAAA;AACzC,EAAA,MAAAC,WAAA,GAAcC,MAAO,CAAAC,UAAA,CAAWX,QAAQ,CAAA;EAGxC,MAAAb,MAAA,GAAUmB,OAAQ,CAAAM,uBAAA,KAA4B,MAAa,IAAAN,OAAA,CAAQO,6BAA6B,MACjG,GAAAP,OAAA,CAAQM,uBAA0B,GAAAN,OAAA,CAAQO,wBAC3C,GAAAJ,WAAA;EAEG,OAAA;IACLvB,KAAO,EAAA4B,IAAA,CAAKC,IAAK,CAAAT,OAAA,CAAQpB,KAAK,CAAA;AAC9BC,IAAAA,MAAA,EAAQ2B,IAAK,CAAAC,IAAA,CAAK5B,MAAM;GAC1B;AACF;AAEO,SAAS6B,SAAYA,GAAA;AACpB,EAAA,MAAAC,aAAA,GAAwC;IAAE,GAAGvC;GAAgB;EACnE,IAAIwC,WAAc,GAAA,KAAA;AACZ,EAAA,MAAAC,YAAA,GAAe,IAAIC,gBAAA,CAAiBC,iBAAiB,CAAA;AACrD,EAAA,MAAAC,cAAA,GAAiB,IAAIC,cAAA,CAAe,MAAM;IAC9C,IAAI,CAACL,WAAa,EAAA;MAChBM,QAAA,CAASP,aAAa,CAAA;AACxB;AACF,GAAC,CAAA;AAGQ,EAAA,SAAAQ,wBAAAA,CAAyBC,WAAmBC,UAAoB,EAAA;AACjE,IAAA,MAAAC,cAAA,GAAiBF,YAAYT,aAAc,CAAAnC,CAAA;AAC3C,IAAA,MAAA+C,eAAA,GAAkBF,aAAaV,aAAc,CAAAlC,CAAA;AAG7C,IAAA,MAAAK,OAAA,GAAU6B,cAAc7B,OAAW,IAAA,EAAA;AACnC,IAAA,MAAAC,OAAA,GAAU4B,cAAc5B,OAAW,IAAA,EAAA;AAGzC,IAAA,MAAMJ,OAAO6B,IAAK,CAAAC,IAAA,CAAKa,cAAkB,IAAAX,aAAA,CAAc/B,QAAQE,OAAQ,CAAA,CAAA;AACvE,IAAA,MAAMJ,OAAO8B,IAAK,CAAAC,IAAA,CAAKc,eAAmB,IAAAZ,aAAA,CAAc9B,SAASE,OAAQ,CAAA,CAAA;IAElE,OAAA;MACLJ,IAAA;MACAD,IAAA;MACAI,OAAA;AACAC,MAAAA;KACF;AACF;AAGS,EAAA,SAAAyC,sBAAAA,CAAuBhD,CAAW,EAAAC,CAAA,EAAWgD,KAA4B,EAAA;AAC1E,IAAA,MAAAC,OAAA,GAAU9B,QAAS,CAAAC,aAAA,CAAc,KAAK,CAAA;AAC5C6B,IAAAA,OAAA,CAAQC,cAAchB,aAAc,CAAApC,IAAA;IACpCmD,OAAA,CAAQrD,EAAK,GAAA,CAAA,EAAGsC,aAAc,CAAArC,MAAM,CAAGmD,EAAAA,KAAK,CAAA,CAAA;AAE5CC,IAAAA,OAAA,CAAQE,MAAMC,OAAU,GAAA;AAAA,6BACGlB,EAAAA,cAAcvB,KAAK,CAAA;AAAA;AAAA,gBAAA,EAEhCZ,CAAC,CAAA;AAAA,eAAA,EACFC,CAAC,CAAA;AAAA;AAAA;AAAA,mBAGGkC,EAAAA,cAAcxB,KAAK,CAAA;AAAA,qBACjBwB,EAAAA,cAAczB,QAAQ,CAAA;AAAA,uBACpByB,EAAAA,cAAc3B,IAAI,CAAA;AAAA,iBACxB2B,EAAAA,cAAc1B,KAAK,CAAA;AAAA;AAAA,iBAEnB0B,EAAAA,cAAc/B,KAAK,CAAA;AAAA,kBAClB+B,EAAAA,cAAc9B,MAAM,CAAA;AAAA,uBACf8B,EAAAA,cAAc9B,MAAM,CAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,MAAA,CAAA,CAMrCiD,OAAQ,CAAA,MAAA,EAAQ,GAAG,CAAA,CAAE5B,IAAK,EAAA;AAEvB,IAAA,OAAAwB,OAAA;AACT;EAGA,SAASR,SAASa,QAAiC,EAAA;AACtCC,IAAAA,UAAA,EAAA;AACJC,IAAAA,MAAA,CAAAC,MAAA,CAAOvB,eAAeoB,QAAQ,CAAA;IAEhC,IAAApB,aAAA,CAAc/B,KAAU,KAAA,CAAA,IAAK+B,aAAc,CAAA9B,MAAA,KAAW,CAAM,IAAA8B,aAAA,CAAc/B,KAAU,KAAA,CAAA,IAAK+B,aAAc,CAAA9B,MAAA,KAAW,CAAG,EAAA;AAExH,MAAA,MAAMsD,cAAiB,GAAA1C,uBAAA,CACrBkB,aAAc,CAAApC,IAAA,EACdoC,aAAc,CAAA3B,IAAA,EACd2B,aAAc,CAAAzB,QAChB,CAAA;MACA,MAAMkD,OAAU,GAAA,EAAA;AACZ,MAAA,IAAAzB,aAAA,CAAc/B,UAAU,CAAG,EAAA;AACf+B,QAAAA,aAAA,CAAA/B,KAAA,GAAQuD,eAAevD,KAAQ,GAAAwD,OAAA;AAC/C;AACI,MAAA,IAAAzB,aAAA,CAAc9B,WAAW,CAAG,EAAA;AAChB8B,QAAAA,aAAA,CAAA9B,MAAA,GAASsD,eAAetD,MAAS,GAAAuD,OAAA;AACjD;AACF;IAEM,MAAAC,aAAA,GAAgB1B,aAAc,CAAApB,WAAA,IAAeK,QAAS,CAAA0C,IAAA;AAC5D,IAAA,MAAMlB,YAAYZ,IAAK,CAAA+B,GAAA,CAAIF,aAAc,CAAAG,WAAA,EAAaH,cAAcI,WAAW,CAAA;AAC/E,IAAA,MAAMpB,aAAab,IAAK,CAAA+B,GAAA,CAAIF,aAAc,CAAAK,YAAA,EAAcL,cAAcM,YAAY,CAAA;AAE5E,IAAA,MAAAC,kBAAA,GAAqBhD,QAAS,CAAAC,aAAA,CAAc,KAAK,CAAA;AACvD+C,IAAAA,kBAAA,CAAmBvE,KAAKsC,aAAc,CAAAtC,EAAA;AAGlC,IAAA,IAAAgE,aAAA,CAAcQ,QAAQ,MAAM,CAAA,IAAKC,iBAAiBT,aAAa,CAAA,CAAEU,aAAa,QAAU,EAAA;AAC1FV,MAAAA,aAAA,CAAcT,MAAMmB,QAAW,GAAA,UAAA;AACjC;AAEAH,IAAAA,kBAAA,CAAmBhB,MAAMC,OAAU,GAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,MAAA,CAAA,CAU/BC,OAAQ,CAAA,MAAA,EAAQ,GAAG,CAAA,CAAE5B,IAAK,EAAA;IAExB,MAAA8C,UAAA,GAAaJ,mBAAmBK,YAAe,GAAAL,kBAAA,CAAmBK,aAAa;AAAEC,MAAAA,IAAA,EAAM;KAAQ,CAAI,GAAAN,kBAAA;AAEzGP,IAAAA,aAAA,CAAcc,YAAYP,kBAAkB,CAAA;IAEtC,MAAA;MAAEjE;MAAMD,IAAM;MAAAI,OAAA;AAASC,MAAAA;AAAQ,KAAI,GAAAoC,wBAAA,CAAyBC,WAAWC,UAAU,CAAA;IACvFV,aAAA,CAAchC,IAAO,GAAAA,IAAA;IACrBgC,aAAA,CAAcjC,IAAO,GAAAA,IAAA;IACrBiC,aAAA,CAAc7B,OAAU,GAAAA,OAAA;IACxB6B,aAAA,CAAc5B,OAAU,GAAAA,OAAA;AAElB,IAAA,MAAAqE,QAAA,GAAWxD,SAASyD,sBAAuB,EAAA;IACjD,KAAA,IAASC,CAAI,GAAA,CAAA,EAAGA,CAAI,GAAA5E,IAAA,EAAM4E,CAAK,EAAA,EAAA;AAC7B,MAAA,MAAM7E,CAAI,GAAAkC,aAAA,CAAclC,CAAK,GAAA,CAAAkC,aAAA,CAAc9B,SAASE,OAAW,IAAAuE,CAAA;MAC/D,KAAA,IAASC,CAAI,GAAA,CAAA,EAAGA,CAAI,GAAA5E,IAAA,EAAM4E,CAAK,EAAA,EAAA;AAC7B,QAAA,MAAM/E,CAAI,GAAAmC,aAAA,CAAcnC,CAAK,GAAA,CAAAmC,aAAA,CAAc/B,QAAQE,OAAW,IAAAyE,CAAA;AAC9DH,QAAAA,QAAA,CAASD,YAAY3B,sBAAuB,CAAAhD,CAAA,EAAGC,GAAG6E,CAAI,GAAA3E,IAAA,GAAO4E,CAAC,CAAC,CAAA;AACjE;AACF;AACAP,IAAAA,UAAA,CAAWG,YAAYC,QAAQ,CAAA;IAE/B,IAAIzC,cAAcnB,OAAS,EAAA;AAEzBwB,MAAAA,cAAA,CAAewC,QAAQnB,aAAa,CAAA;AAGpC,MAAA,MAAMoB,MAA+B,GAAA;AACnCC,QAAAA,UAAY,EAAA,IAAA;AAAA;AACZC,QAAAA,SAAW,EAAA,IAAA;AAAA;AACXC,QAAAA,OAAS,EAAA,IAAA;AAAA;AACTC,QAAAA,aAAe,EAAA;AAAA;OACjB;AAGahD,MAAAA,YAAA,CAAA2C,OAAA,CAAQZ,oBAAoBa,MAAM,CAAA;MAG/C,IAAIT,eAAeJ,kBAAoB,EAAA;AACxB/B,QAAAA,YAAA,CAAA2C,OAAA,CAAQR,YAAYS,MAAM,CAAA;AACzC;AACF;AACF;EAGA,SAASzB,UAAaA,GAAA;IACpB,MAAM8B,gBAAmB,GAAAlE,QAAA,CAASmE,cAAe,CAAApD,aAAA,CAActC,EAAE,CAAA;IACjEwC,YAAA,CAAamD,UAAW,EAAA;AACxB,IAAA,IAAIF,gBAAkB,EAAA;AACHA,MAAAA,gBAAA,CAAAG,UAAA,EAAYC,YAAYJ,gBAAgB,CAAA;AAC3D;AACF;EAGA,SAAS/C,kBAAkBoD,OAA2B,EAAA;AACpD,IAAA,IAAIvD,WAAa,EAAA;AACDA,MAAAA,WAAA,GAAA,KAAA;AACd,MAAA;AACF;IAEA,MAAMkD,gBAAmB,GAAAlE,QAAA,CAASmE,cAAe,CAAApD,aAAA,CAActC,EAAE,CAAA;IACjE,IAAI,CAACyF,gBAAkB,EAAA;MAErB5C,QAAA,CAASP,aAAa,CAAA;AACtB,MAAA;AACF;AAGA,IAAA,MAAMyD,UAAa,GAAAD,OAAA,CAAQE,IAAK,CAACC,MAAW,IAAA;AAEtC,MAAA,IAAAA,MAAA,CAAOC,SAAS,WAAa,EAAA;AACxB,QAAA,OAAA,IAAA;AACT;AAGI,MAAA,IAAAD,MAAA,CAAOC,SAAS,YAAc,EAAA;AACzB,QAAA,OAAA,IAAA;AACT;AAGI,MAAA,IAAAD,MAAA,CAAOC,SAAS,eAAiB,EAAA;AAC5B,QAAA,OAAA,IAAA;AACT;AAEO,MAAA,OAAA,KAAA;AACT,KAAC,CAAA;AAED,IAAA,IAAIH,UAAY,EAAA;MACdlD,QAAA,CAASP,aAAa,CAAA;AACxB;AACF;EAEO,OAAA;AACL6D,IAAAA,OAAS,EAAAtD,QAAA;IACTc,YAAYA,MAAM;AACFpB,MAAAA,WAAA,GAAA,IAAA;AAGHoB,MAAAA,UAAA,EAAA;AACb;GACF;AACF;;;;"}
|
|
1
|
+
{"version":3,"file":"watermark.js","sources":["../../../../packages/utils/src/watermark.ts"],"sourcesContent":["interface SettingsType {\n /** 水印总体的id */\n id?: string\n /** 小水印的id前缀 */\n prefix?: string\n /** 水印文案 */\n text?: string\n /** 水印起始位置x轴坐标 */\n x?: number\n /** 水印起始位置Y轴坐标 */\n y?: number\n /** 水印行数 */\n rows?: number\n /** 水印列数 */\n cols?: number\n /** 水印x轴间隔 */\n x_space?: number\n /** 水印y轴间隔 */\n y_space?: number\n /** 水印字体 */\n font?: string\n /** 水印字体颜色 */\n color?: string\n /** 水印字体大小 */\n fontsize?: string\n /** 水印透明度,要求设置在大于等于0.005 */\n alpha?: number\n /** 水印宽度 */\n width?: number\n /** 水印长度 */\n height?: number\n /** 水印倾斜度数 */\n angle?: number\n /** 水印的总体宽度(默认值:body的scrollWidth和clientWidth的较大值) */\n parent_width?: number\n /** 水印的总体高度(默认值:body的scrollHeight和clientHeight的较大值) */\n parent_height?: number\n /** 水印插件挂载的父元素element,不输入则默认挂在body */\n parent_node?: HTMLElement | null\n /** 是否监控,true: 不可删除水印; false: 可删水印 */\n monitor?: boolean\n}\n\n// 默认配置\nconst initialSettings: Required<SettingsType> = {\n id: 'wm_div_id',\n prefix: 'mask_div_id',\n text: '测试水印',\n x: 0,\n y: 0,\n rows: 0,\n cols: 0,\n width: 0,\n height: 0,\n x_space: 100,\n y_space: 40,\n font: '微软雅黑',\n color: 'black',\n fontsize: '18px',\n alpha: 0.15,\n angle: 15,\n parent_width: 0,\n parent_height: 0,\n parent_node: null,\n monitor: true,\n}\n\nfunction calculateTextDimensions(text: string, font: string, fontSize: string): { width: number, height: number } {\n const canvas = document.createElement('canvas')\n const context = canvas.getContext('2d')\n if (!context) {\n return { width: 100, height: 100 }\n }\n\n context.font = `${fontSize} ${font}`\n const metrics = context.measureText(text.trim())\n const fontSizeNum = Number.parseFloat(fontSize)\n\n // 移除 DPI 缩放,直接使用原始值\n const height = (metrics.actualBoundingBoxAscent !== undefined && metrics.actualBoundingBoxDescent !== undefined)\n ? (metrics.actualBoundingBoxAscent + metrics.actualBoundingBoxDescent)\n : fontSizeNum\n\n return {\n width: Math.ceil(metrics.width),\n height: Math.ceil(height),\n }\n}\n\nexport function watermark() {\n const globalSetting: Required<SettingsType> = { ...initialSettings }\n let forceRemove = false\n const watermarkDom = new MutationObserver(domChangeCallback)\n const resizeObserver = new ResizeObserver(() => {\n if (!forceRemove) {\n loadMark(globalSetting)\n }\n })\n\n // 计算水印布局\n function calculateWatermarkLayout(pageWidth: number, pageHeight: number) {\n const availableWidth = pageWidth - globalSetting.x\n const availableHeight = pageHeight - globalSetting.y\n\n // 使用固定间距\n const x_space = globalSetting.x_space || 20 // 如果未设置则使用默认值\n const y_space = globalSetting.y_space || 20 // 如果未设置则使用默认值\n\n // 计算能容纳的行数和列数\n const cols = Math.ceil(availableWidth / (globalSetting.width + x_space))\n const rows = Math.ceil(availableHeight / (globalSetting.height + y_space))\n\n return {\n cols,\n rows,\n x_space,\n y_space,\n }\n }\n\n // 创建水印元素\n function createWatermarkElement(x: number, y: number, index: number): HTMLElement {\n const maskDiv = document.createElement('div')\n maskDiv.textContent = globalSetting.text\n maskDiv.id = `${globalSetting.prefix}${index}`\n\n maskDiv.style.cssText = `\n transform: rotate(-${globalSetting.angle}deg);\n position: absolute;\n left: ${x}px;\n top: ${y}px;\n overflow: hidden;\n z-index: 9999999;\n opacity: ${globalSetting.alpha};\n font-size: ${globalSetting.fontsize};\n font-family: ${globalSetting.font};\n color: ${globalSetting.color};\n text-align: center;\n width: ${globalSetting.width}px;\n height: ${globalSetting.height}px;\n line-height: ${globalSetting.height}px;\n display: flex;\n align-items: center;\n justify-content: center;\n user-select: none;\n visibility: visible;\n `.replace(/\\s+/g, ' ').trim()\n\n return maskDiv\n }\n\n // 加载水印\n function loadMark(settings: Partial<SettingsType>) {\n removeMark()\n Object.assign(globalSetting, settings)\n\n if ((globalSetting.width === 0 && globalSetting.height === 0) || globalSetting.width === 0 || globalSetting.height === 0) {\n // 计算文本尺寸\n const textDimensions = calculateTextDimensions(\n globalSetting.text,\n globalSetting.font,\n globalSetting.fontsize,\n )\n const padding = 10\n if (globalSetting.width === 0) {\n globalSetting.width = textDimensions.width + padding\n }\n if (globalSetting.height === 0) {\n globalSetting.height = textDimensions.height + padding\n }\n }\n\n const parentElement = globalSetting.parent_node || document.body\n const pageWidth = Math.max(parentElement.scrollWidth, parentElement.clientWidth)\n const pageHeight = Math.max(parentElement.scrollHeight, parentElement.clientHeight)\n\n const watermarkContainer = document.createElement('div')\n watermarkContainer.id = globalSetting.id\n\n // 处理父元素定位\n if (parentElement.closest('body') && getComputedStyle(parentElement).position === 'static') {\n parentElement.style.position = 'relative'\n }\n\n watermarkContainer.style.cssText = `\n pointer-events: none;\n display: block;\n position: absolute;\n top: 0;\n left: 0;\n width: 100%;\n height: 100%;\n z-index: 9999999;\n overflow: hidden;\n `.replace(/\\s+/g, ' ').trim()\n\n const shadowRoot = watermarkContainer.attachShadow ? watermarkContainer.attachShadow({ mode: 'open' }) : watermarkContainer\n\n parentElement.appendChild(watermarkContainer)\n\n const { cols, rows, x_space, y_space } = calculateWatermarkLayout(pageWidth, pageHeight)\n globalSetting.cols = cols\n globalSetting.rows = rows\n globalSetting.x_space = x_space\n globalSetting.y_space = y_space\n\n const fragment = document.createDocumentFragment()\n for (let i = 0; i < rows; i++) {\n const y = globalSetting.y + (globalSetting.height + y_space) * i\n for (let j = 0; j < cols; j++) {\n const x = globalSetting.x + (globalSetting.width + x_space) * j\n fragment.appendChild(createWatermarkElement(x, y, i * cols + j))\n }\n }\n shadowRoot.appendChild(fragment)\n\n if (globalSetting.monitor) {\n // 监听父元素大小变化\n resizeObserver.observe(parentElement)\n\n // 监听水印容器及其子元素\n const config: MutationObserverInit = {\n attributes: true, // 监听属性变化\n childList: true, // 监听子元素变化\n subtree: true, // 监听子树变化\n characterData: true, // 监听文本内容变化\n }\n\n // 监听水印容器\n watermarkDom.observe(watermarkContainer, config)\n\n // 如果使用了 Shadow DOM,还需要监听 shadowRoot 内的元素\n if (shadowRoot !== watermarkContainer) {\n watermarkDom.observe(shadowRoot, config)\n }\n }\n }\n\n // 移除水印\n function removeMark() {\n const watermarkElement = document.getElementById(globalSetting.id)\n watermarkDom.disconnect()\n if (watermarkElement) {\n watermarkElement.parentNode?.removeChild(watermarkElement)\n }\n }\n\n // 监听DOM变化\n function domChangeCallback(records: MutationRecord[]) {\n if (forceRemove) {\n forceRemove = false\n return\n }\n\n const watermarkElement = document.getElementById(globalSetting.id)\n if (!watermarkElement) {\n // 如果水印容器被删除,重新创建\n loadMark(globalSetting)\n return\n }\n\n // 检查是否有任何修改\n const hasChanges = records.some((record) => {\n // 检查元素是否被删除或添加\n if (record.type === 'childList') {\n return true\n }\n\n // 检查属性是否被修改\n if (record.type === 'attributes') {\n return true\n }\n\n // 检查文本内容是否被修改\n if (record.type === 'characterData') {\n return true\n }\n\n return false\n })\n\n if (hasChanges) {\n loadMark(globalSetting)\n }\n }\n\n return {\n addMark: loadMark,\n removeMark: () => {\n forceRemove = true\n // 删除这行,不重置全局配置\n // Object.assign(globalSetting, initialSettings)\n removeMark()\n },\n }\n}\n"],"names":["initialSettings","id","prefix","text","x","y","rows","cols","width","height","x_space","y_space","font","color","fontsize","alpha","angle","parent_width","parent_height","parent_node","monitor","watermark","globalSetting","forceRemove","watermarkDom","MutationObserver","records","document","getElementById","loadMark","some","record","type","resizeObserver","ResizeObserver","createWatermarkElement","index","maskDiv","createElement","textContent","style","cssText","replace","trim","settings","removeMark","Object","assign","textDimensions","fontSize","context","getContext","metrics","measureText","fontSizeNum","Number","parseFloat","actualBoundingBoxAscent","actualBoundingBoxDescent","Math","ceil","calculateTextDimensions","padding","parentElement","body","pageWidth","max","scrollWidth","clientWidth","pageHeight","scrollHeight","clientHeight","watermarkContainer","closest","getComputedStyle","position","shadowRoot","attachShadow","mode","appendChild","availableWidth","availableHeight","calculateWatermarkLayout","fragment","createDocumentFragment","i","j","observe","config","attributes","childList","subtree","characterData","watermarkElement","disconnect","parentNode","removeChild","addMark"],"mappings":"AA4CA,MAAMA,EAA0C,CAC9CC,GAAI,YACJC,OAAQ,cACRC,KAAM,OACNC,EAAG,EACHC,EAAG,EACHC,KAAM,EACNC,KAAM,EACNC,MAAO,EACPC,OAAQ,EACRC,QAAS,IACTC,QAAS,GACTC,KAAM,OACNC,MAAO,QACPC,SAAU,OACVC,MAAO,IACPC,MAAO,GACPC,aAAc,EACdC,cAAe,EACfC,YAAa,KACbC,SAAS,GAyBJ,SAASC,IACR,MAAAC,EAAwC,IAAKtB,GACnD,IAAIuB,GAAc,EACZ,MAAAC,EAAe,IAAIC,kBA4JzB,SAA2BC,GACzB,GAAIH,EAEF,YADcA,GAAA,GAKhB,IADyBI,SAASC,eAAeN,EAAcrB,IAI7D,YADA4B,EAASP,GAKQI,EAAQI,MAAMC,GAEX,cAAhBA,EAAOC,OAKS,eAAhBD,EAAOC,MAKS,kBAAhBD,EAAOC,SAQXH,EAASP,EAEb,IA/LMW,EAAiB,IAAIC,gBAAe,KACnCX,GACHM,EAASP,EACX,IAyBO,SAAAa,EAAuB/B,EAAWC,EAAW+B,GAC9C,MAAAC,EAAUV,SAASW,cAAc,OA0BhC,OAzBPD,EAAQE,YAAcjB,EAAcnB,KACpCkC,EAAQpC,GAAK,GAAGqB,EAAcpB,SAASkC,IAEvCC,EAAQG,MAAMC,QAAU,kCACGnB,EAAcN,8DAE3BZ,wBACDC,sFAGIiB,EAAcP,gCACZO,EAAcR,qCACZQ,EAAcV,2BACpBU,EAAcT,2DAEdS,EAAcd,+BACbc,EAAcb,qCACTa,EAAcb,gLAM/BiC,QAAQ,OAAQ,KAAKC,OAElBN,CACT,CAGA,SAASR,EAASe,GAIX,GAHMC,IACJC,OAAAC,OAAOzB,EAAesB,GAEA,IAAxBtB,EAAcd,OAAwC,IAAzBc,EAAcb,QAAyC,IAAxBa,EAAcd,OAAwC,IAAzBc,EAAcb,OAAc,CAExH,MAAMuC,EA3FZ,SAAiC7C,EAAcS,EAAcqC,GACrD,MACAC,EADSvB,SAASW,cAAc,UACfa,WAAW,MAClC,IAAKD,EACH,MAAO,CAAE1C,MAAO,IAAKC,OAAQ,KAG/ByC,EAAQtC,KAAO,GAAGqC,KAAYrC,IAC9B,MAAMwC,EAAUF,EAAQG,YAAYlD,EAAKwC,QACnCW,EAAcC,OAAOC,WAAWP,GAGhCxC,OAA8C,IAApC2C,EAAQK,8BAA8E,IAArCL,EAAQM,yBACpEN,EAAQK,wBAA0BL,EAAQM,yBAC3CJ,EAEG,MAAA,CACL9C,MAAOmD,KAAKC,KAAKR,EAAQ5C,OACzBC,OAAQkD,KAAKC,KAAKnD,GAEtB,CAuE6BoD,CACrBvC,EAAcnB,KACdmB,EAAcV,KACdU,EAAcR,UAEVgD,EAAU,GACY,IAAxBxC,EAAcd,QACFc,EAAAd,MAAQwC,EAAexC,MAAQsD,GAElB,IAAzBxC,EAAcb,SACFa,EAAAb,OAASuC,EAAevC,OAASqD,EAEnD,CAEM,MAAAC,EAAgBzC,EAAcH,aAAeQ,SAASqC,KACtDC,EAAYN,KAAKO,IAAIH,EAAcI,YAAaJ,EAAcK,aAC9DC,EAAaV,KAAKO,IAAIH,EAAcO,aAAcP,EAAcQ,cAEhEC,EAAqB7C,SAASW,cAAc,OAClDkC,EAAmBvE,GAAKqB,EAAcrB,GAGlC8D,EAAcU,QAAQ,SAAwD,WAA7CC,iBAAiBX,GAAeY,WACnEZ,EAAcvB,MAAMmC,SAAW,YAGjCH,EAAmBhC,MAAMC,QAAU,wPAU/BC,QAAQ,OAAQ,KAAKC,OAEnB,MAAAiC,EAAaJ,EAAmBK,aAAeL,EAAmBK,aAAa,CAAEC,KAAM,SAAYN,EAEzGT,EAAcgB,YAAYP,GAEpB,MAAAjE,KAAEA,OAAMD,EAAMI,QAAAA,EAAAC,QAASA,GApGtB,SAAyBsD,EAAmBI,GAC7C,MAAAW,EAAiBf,EAAY3C,EAAclB,EAC3C6E,EAAkBZ,EAAa/C,EAAcjB,EAG7CK,EAAUY,EAAcZ,SAAW,GACnCC,EAAUW,EAAcX,SAAW,GAMlC,MAAA,CACLJ,KAJWoD,KAAKC,KAAKoB,GAAkB1D,EAAcd,MAAQE,IAK7DJ,KAJWqD,KAAKC,KAAKqB,GAAmB3D,EAAcb,OAASE,IAK/DD,UACAC,UAEJ,CAkF2CuE,CAAyBjB,EAAWI,GAC7E/C,EAAcf,KAAOA,EACrBe,EAAchB,KAAOA,EACrBgB,EAAcZ,QAAUA,EACxBY,EAAcX,QAAUA,EAElB,MAAAwE,EAAWxD,SAASyD,yBAC1B,IAAA,IAASC,EAAI,EAAGA,EAAI/E,EAAM+E,IAAK,CAC7B,MAAMhF,EAAIiB,EAAcjB,GAAKiB,EAAcb,OAASE,GAAW0E,EAC/D,IAAA,IAASC,EAAI,EAAGA,EAAI/E,EAAM+E,IAAK,CAC7B,MAAMlF,EAAIkB,EAAclB,GAAKkB,EAAcd,MAAQE,GAAW4E,EAC9DH,EAASJ,YAAY5C,EAAuB/B,EAAGC,EAAGgF,EAAI9E,EAAO+E,GAC/D,CACF,CAGA,GAFAV,EAAWG,YAAYI,GAEnB7D,EAAcF,QAAS,CAEzBa,EAAesD,QAAQxB,GAGvB,MAAMyB,EAA+B,CACnCC,YAAY,EACZC,WAAW,EACXC,SAAS,EACTC,eAAe,GAIJpE,EAAA+D,QAAQf,EAAoBgB,GAGrCZ,IAAeJ,GACJhD,EAAA+D,QAAQX,EAAYY,EAErC,CACF,CAGA,SAAS3C,IACP,MAAMgD,EAAmBlE,SAASC,eAAeN,EAAcrB,IAC/DuB,EAAasE,aACTD,GACeA,EAAAE,YAAYC,YAAYH,EAE7C,CAyCO,MAAA,CACLI,QAASpE,EACTgB,WAAYA,KACItB,GAAA,EAGHsB,GAAA,EAGjB"}
|
package/lib/index.js
CHANGED
|
@@ -1,41 +1,2 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
var argoLog = require('./src/argo-log.js');
|
|
4
|
-
var dateTransfer = require('./src/date-transfer.js');
|
|
5
|
-
var device = require('./src/device.js');
|
|
6
|
-
var fileOperations = require('./src/file-operations.js');
|
|
7
|
-
var json = require('./src/json.js');
|
|
8
|
-
var ossUploader = require('./src/oss-uploader.js');
|
|
9
|
-
var storage = require('./src/storage.js');
|
|
10
|
-
var types = require('./src/types.js');
|
|
11
|
-
var useApi = require('./src/use-api.js');
|
|
12
|
-
var watermark = require('./src/watermark.js');
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
exports.ArgoLog = argoLog.ArgoLog;
|
|
17
|
-
exports.formatDuration = dateTransfer.formatDuration;
|
|
18
|
-
exports.getDeviceType = device.getDeviceType;
|
|
19
|
-
exports.isAndroid = device.isAndroid;
|
|
20
|
-
exports.isIOS = device.isIOS;
|
|
21
|
-
exports.isMobile = device.isMobile;
|
|
22
|
-
exports.createVideoUploader = fileOperations.createVideoUploader;
|
|
23
|
-
exports.downloadFile = fileOperations.downloadFile;
|
|
24
|
-
exports.JsonToExcel = json.JsonToExcel;
|
|
25
|
-
exports.excelToJson = json.excelToJson;
|
|
26
|
-
exports.OssError = ossUploader.OssError;
|
|
27
|
-
exports.OssUploader = ossUploader.OssUploader;
|
|
28
|
-
exports.generateSignedUrl = ossUploader.generateSignedUrl;
|
|
29
|
-
exports.uploadFile = ossUploader.uploadFile;
|
|
30
|
-
exports.Storage = storage.Storage;
|
|
31
|
-
exports.isBoolean = types.isBoolean;
|
|
32
|
-
exports.isElement = types.isElement;
|
|
33
|
-
exports.isImageByMimeType = types.isImageByMimeType;
|
|
34
|
-
exports.isJSONString = types.isJSONString;
|
|
35
|
-
exports.isNumber = types.isNumber;
|
|
36
|
-
exports.isPlainObject = types.isPlainObject;
|
|
37
|
-
exports.isUndefined = types.isUndefined;
|
|
38
|
-
exports.isWindow = types.isWindow;
|
|
39
|
-
exports.ApiService = useApi.ApiService;
|
|
40
|
-
exports.watermark = watermark.watermark;
|
|
1
|
+
"use strict";var e=require("./src/argo-log.js"),r=require("./src/date-transfer.js"),s=require("./src/device.js"),o=require("./src/file-operations.js"),i=require("./src/json.js"),t=require("./src/oss-uploader.js"),p=require("./src/set-guid.js"),a=require("./src/storage.js"),n=require("./src/types.js"),d=require("./src/use-api.js"),x=require("./src/watermark.js");exports.ArgoLog=e.ArgoLog,exports.formatDuration=r.formatDuration,exports.getDeviceType=s.getDeviceType,exports.isAndroid=s.isAndroid,exports.isIOS=s.isIOS,exports.isMobile=s.isMobile,exports.createVideoUploader=o.createVideoUploader,exports.downloadFile=o.downloadFile,exports.JsonToExcel=i.JsonToExcel,exports.excelToJson=i.excelToJson,exports.OssError=t.OssError,exports.OssUploader=t.OssUploader,exports.generateSignedUrl=t.generateSignedUrl,exports.uploadFile=t.uploadFile,exports.setGuid=p.setGuid,exports.Storage=a.Storage,exports.isBoolean=n.isBoolean,exports.isElement=n.isElement,exports.isImageByMimeType=n.isImageByMimeType,exports.isJSONString=n.isJSONString,exports.isNumber=n.isNumber,exports.isPlainObject=n.isPlainObject,exports.isUndefined=n.isUndefined,exports.isWindow=n.isWindow,exports.ApiService=d.ApiService,exports.watermark=x.watermark;
|
|
41
2
|
//# sourceMappingURL=index.js.map
|
package/lib/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/lib/src/argo-log.js
CHANGED
|
@@ -1,80 +1,2 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
var AnsJavascriptSdk = require('ans-javascript-sdk');
|
|
4
|
-
|
|
5
|
-
var __defProp = Object.defineProperty;
|
|
6
|
-
var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, {
|
|
7
|
-
enumerable: true,
|
|
8
|
-
configurable: true,
|
|
9
|
-
writable: true,
|
|
10
|
-
value
|
|
11
|
-
}) : obj[key] = value;
|
|
12
|
-
var __publicField = (obj, key, value) => __defNormalProp(obj, typeof key !== "symbol" ? key + "" : key, value);
|
|
13
|
-
const _ArgoLog = class _ArgoLog {
|
|
14
|
-
constructor(envConfig) {
|
|
15
|
-
__publicField(this, "AnalysysAgent", null);
|
|
16
|
-
__publicField(this, "track", (name, opt) => {
|
|
17
|
-
try {
|
|
18
|
-
if (!this.AnalysysAgent) {
|
|
19
|
-
console.warn("[ArgoLog] SDK \u672A\u521D\u59CB\u5316");
|
|
20
|
-
return;
|
|
21
|
-
}
|
|
22
|
-
if (!name) {
|
|
23
|
-
console.warn("[ArgoLog] track: name is required");
|
|
24
|
-
return;
|
|
25
|
-
}
|
|
26
|
-
this.AnalysysAgent.track(name, opt);
|
|
27
|
-
} catch (error) {
|
|
28
|
-
console.warn("[ArgoLog] track failed:", error);
|
|
29
|
-
}
|
|
30
|
-
});
|
|
31
|
-
__publicField(this, "setProfile", info => {
|
|
32
|
-
try {
|
|
33
|
-
if (!info) {
|
|
34
|
-
console.warn("[ArgoLog] setProfile: info is required");
|
|
35
|
-
return;
|
|
36
|
-
}
|
|
37
|
-
this.AnalysysAgent.profileSet(info);
|
|
38
|
-
} catch (error) {
|
|
39
|
-
console.warn("[ArgoLog] setProfile failed:", error);
|
|
40
|
-
}
|
|
41
|
-
});
|
|
42
|
-
__publicField(this, "setAlias", code => {
|
|
43
|
-
try {
|
|
44
|
-
if (!code) {
|
|
45
|
-
console.warn("[ArgoLog] setAlias: code is required");
|
|
46
|
-
return;
|
|
47
|
-
}
|
|
48
|
-
this.AnalysysAgent.alias(code);
|
|
49
|
-
} catch (error) {
|
|
50
|
-
console.warn("[ArgoLog] setAlias failed:", error);
|
|
51
|
-
}
|
|
52
|
-
});
|
|
53
|
-
try {
|
|
54
|
-
if (typeof window === "undefined") {
|
|
55
|
-
console.warn("[ArgoLog] \u4EC5\u652F\u6301\u6D4F\u89C8\u5668\u73AF\u5883");
|
|
56
|
-
return this;
|
|
57
|
-
}
|
|
58
|
-
const configKey = JSON.stringify(envConfig);
|
|
59
|
-
const existingInstance = _ArgoLog.instances.get(configKey);
|
|
60
|
-
if (existingInstance) {
|
|
61
|
-
return existingInstance;
|
|
62
|
-
}
|
|
63
|
-
if (!envConfig) {
|
|
64
|
-
console.error("envConfig is required");
|
|
65
|
-
return this;
|
|
66
|
-
}
|
|
67
|
-
this.AnalysysAgent = AnsJavascriptSdk;
|
|
68
|
-
this.AnalysysAgent.init(envConfig);
|
|
69
|
-
_ArgoLog.instances.set(configKey, this);
|
|
70
|
-
} catch (error) {
|
|
71
|
-
console.warn("[ArgoLog] Init failed:", error);
|
|
72
|
-
}
|
|
73
|
-
return this;
|
|
74
|
-
}
|
|
75
|
-
};
|
|
76
|
-
__publicField(_ArgoLog, "instances", /* @__PURE__ */new Map());
|
|
77
|
-
let ArgoLog = _ArgoLog;
|
|
78
|
-
|
|
79
|
-
exports.ArgoLog = ArgoLog;
|
|
1
|
+
"use strict";var e=Object.defineProperty,t=(t,r,s)=>((t,r,s)=>r in t?e(t,r,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[r]=s)(t,"symbol"!=typeof r?r+"":r,s);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),s=e.instances.get(t);if(s)return s;if(!r)return console.error("envConfig is required"),this;import("ans-javascript-sdk").then((s=>{this.AnalysysAgent=s.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 s=r;exports.ArgoLog=s;
|
|
80
2
|
//# sourceMappingURL=argo-log.js.map
|
package/lib/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":"uKA0BO,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/lib/src/date-transfer.js
CHANGED
|
@@ -1,36 +1,2 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
function formatDuration(ms) {
|
|
4
|
-
const seconds = Math.floor(ms / 1e3);
|
|
5
|
-
const minutes = Math.floor(seconds / 60);
|
|
6
|
-
const hours = Math.floor(minutes / 60);
|
|
7
|
-
const days = Math.floor(hours / 24);
|
|
8
|
-
const pad = num => num.toString().padStart(2, "0");
|
|
9
|
-
if (hours < 1) {
|
|
10
|
-
const mm = pad(minutes % 60);
|
|
11
|
-
const ss = pad(seconds % 60);
|
|
12
|
-
return `${mm}:${ss}`;
|
|
13
|
-
}
|
|
14
|
-
if (days < 1) {
|
|
15
|
-
const hh = pad(hours);
|
|
16
|
-
const mm = pad(minutes % 60);
|
|
17
|
-
const ss = pad(seconds % 60);
|
|
18
|
-
return `${hh}:${mm}:${ss}`;
|
|
19
|
-
}
|
|
20
|
-
const remainingHours = hours % 24;
|
|
21
|
-
const remainingMinutes = minutes % 60;
|
|
22
|
-
const parts = [];
|
|
23
|
-
if (days > 0) {
|
|
24
|
-
parts.push(`${days}\u5929`);
|
|
25
|
-
}
|
|
26
|
-
if (remainingHours > 0) {
|
|
27
|
-
parts.push(`${remainingHours}\u5C0F\u65F6`);
|
|
28
|
-
}
|
|
29
|
-
if (remainingMinutes > 0) {
|
|
30
|
-
parts.push(`${remainingMinutes}\u5206\u949F`);
|
|
31
|
-
}
|
|
32
|
-
return parts.join("");
|
|
33
|
-
}
|
|
34
|
-
|
|
35
|
-
exports.formatDuration = formatDuration;
|
|
1
|
+
"use strict";exports.formatDuration=function(t){const o=Math.floor(t/1e3),r=Math.floor(o/60),n=Math.floor(r/60),u=Math.floor(n/24),a=t=>t.toString().padStart(2,"0");if(n<1){return`${a(r%60)}:${a(o%60)}`}if(u<1){return`${a(n)}:${a(r%60)}:${a(o%60)}`}const f=n%24,s=r%60,$=[];return u>0&&$.push(`${u}天`),f>0&&$.push(`${f}小时`),s>0&&$.push(`${s}分钟`),$.join("")};
|
|
36
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":["
|
|
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":["ms","seconds","Math","floor","minutes","hours","days","pad","num","toString","padStart","remainingHours","remainingMinutes","parts","push","join"],"mappings":"oCAUO,SAAwBA,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/lib/src/device.js
CHANGED
|
@@ -1,28 +1,2 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
function getDeviceType() {
|
|
4
|
-
const userAgent = navigator.userAgent;
|
|
5
|
-
if (/iPhone|iPad|iPod|iOS/i.test(userAgent)) {
|
|
6
|
-
return "iOS";
|
|
7
|
-
} else if (/Android/i.test(userAgent)) {
|
|
8
|
-
return "Android";
|
|
9
|
-
} else {
|
|
10
|
-
return "desktop";
|
|
11
|
-
}
|
|
12
|
-
}
|
|
13
|
-
function isMobile() {
|
|
14
|
-
const deviceType = getDeviceType();
|
|
15
|
-
return deviceType === "iOS" || deviceType === "Android";
|
|
16
|
-
}
|
|
17
|
-
function isIOS() {
|
|
18
|
-
return /iPhone|iPad|iPod|iOS/i.test(navigator.userAgent);
|
|
19
|
-
}
|
|
20
|
-
function isAndroid() {
|
|
21
|
-
return /Android/i.test(navigator.userAgent);
|
|
22
|
-
}
|
|
23
|
-
|
|
24
|
-
exports.getDeviceType = getDeviceType;
|
|
25
|
-
exports.isAndroid = isAndroid;
|
|
26
|
-
exports.isIOS = isIOS;
|
|
27
|
-
exports.isMobile = isMobile;
|
|
1
|
+
"use strict";function i(){const i=navigator.userAgent;return/iPhone|iPad|iPod|iOS/i.test(i)?"iOS":/Android/i.test(i)?"Android":"desktop"}exports.getDeviceType=i,exports.isAndroid=function(){return/Android/i.test(navigator.userAgent)},exports.isIOS=function(){return/iPhone|iPad|iPod|iOS/i.test(navigator.userAgent)},exports.isMobile=function(){const t=i();return"iOS"===t||"Android"===t};
|
|
28
2
|
//# sourceMappingURL=device.js.map
|
package/lib/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","
|
|
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","deviceType"],"mappings":"aAIO,SAASA,IACd,MAAMC,EAAYC,UAAUD,UAExB,MAAA,wBAAwBE,KAAKF,GACxB,MAEA,WAAWE,KAAKF,GAChB,UAGA,SAEX,2CAoBO,WACE,MAAA,WAAWE,KAAKD,UAAUD,UACnC,gBATO,WACE,MAAA,wBAAwBE,KAAKD,UAAUD,UAChD,mBAVO,WACL,MAAMG,EAAaJ,IACZ,MAAe,QAAfI,GAAuC,YAAfA,CACjC"}
|
|
@@ -1,108 +1,2 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
async function loadScript(src) {
|
|
4
|
-
return new Promise((resolve, reject) => {
|
|
5
|
-
try {
|
|
6
|
-
const script = document.createElement("script");
|
|
7
|
-
script.src = src;
|
|
8
|
-
script.onload = () => {
|
|
9
|
-
resolve();
|
|
10
|
-
};
|
|
11
|
-
script.onerror = () => {
|
|
12
|
-
reject(new Error(`Failed to load script from ${src}`));
|
|
13
|
-
};
|
|
14
|
-
document.head.appendChild(script);
|
|
15
|
-
} catch (error) {
|
|
16
|
-
console.error("loadScript error:", error);
|
|
17
|
-
reject(error);
|
|
18
|
-
}
|
|
19
|
-
});
|
|
20
|
-
}
|
|
21
|
-
async function initAliyunSDK() {
|
|
22
|
-
try {
|
|
23
|
-
await loadScript("https://gosspublic.alicdn.com/aliyun-oss-sdk.min.js");
|
|
24
|
-
await loadScript("https://cdnfile.yaomaitong.cn/cdn/js/aliyun-upload-sdk1.3.1.min.js");
|
|
25
|
-
if (!window.AliyunUpload) {
|
|
26
|
-
throw new Error("SDK \u52A0\u8F7D\u6210\u529F\u4F46\u672A\u627E\u5230 AliyunUpload \u5BF9\u8C61");
|
|
27
|
-
}
|
|
28
|
-
} catch (error) {
|
|
29
|
-
console.error("\u65E0\u6CD5\u52A0\u8F7D\u963F\u91CC\u4E91\u4E0A\u4F20SDK:", error);
|
|
30
|
-
throw error;
|
|
31
|
-
}
|
|
32
|
-
}
|
|
33
|
-
async function createVideoUploader(options) {
|
|
34
|
-
if (typeof window === "undefined") {
|
|
35
|
-
throw new TypeError("VideoUploader \u53EA\u80FD\u5728\u6D4F\u89C8\u5668\u73AF\u5883\u4E2D\u4F7F\u7528");
|
|
36
|
-
}
|
|
37
|
-
if (!window.AliyunUpload) {
|
|
38
|
-
await initAliyunSDK();
|
|
39
|
-
}
|
|
40
|
-
let currentResolve = null;
|
|
41
|
-
let currentReject = null;
|
|
42
|
-
const uploader = new window.AliyunUpload.Vod({
|
|
43
|
-
// 上传进度回调
|
|
44
|
-
onUploadProgress: options.onUploadProgress,
|
|
45
|
-
// 上传凭证过期回调
|
|
46
|
-
onUploadTokenExpired: options.onUploadTokenExpired || (() => {}),
|
|
47
|
-
// 开始上传回调,用于设置上传凭证和地址
|
|
48
|
-
onUploadstarted: async uploadInfo => {
|
|
49
|
-
try {
|
|
50
|
-
const {
|
|
51
|
-
uploadAuth,
|
|
52
|
-
uploadAddress,
|
|
53
|
-
videoId
|
|
54
|
-
} = (await options.onUploadstarted?.(uploadInfo)) || {};
|
|
55
|
-
if (uploadAuth && uploadAddress && videoId) {
|
|
56
|
-
uploader.setUploadAuthAndAddress(uploadInfo, uploadAuth, uploadAddress, videoId);
|
|
57
|
-
}
|
|
58
|
-
} catch (error) {
|
|
59
|
-
console.error("onUploadstarted error: ", error);
|
|
60
|
-
throw error;
|
|
61
|
-
}
|
|
62
|
-
},
|
|
63
|
-
// 上传成功回调
|
|
64
|
-
onUploadSucceed: uploadInfo => {
|
|
65
|
-
currentResolve?.(uploadInfo);
|
|
66
|
-
},
|
|
67
|
-
// 上传失败回调
|
|
68
|
-
onUploadFailed: (info, code, message) => {
|
|
69
|
-
console.log("info: ", info);
|
|
70
|
-
currentReject?.(new Error(`${message} ${code}`));
|
|
71
|
-
}
|
|
72
|
-
});
|
|
73
|
-
const upload = async file => {
|
|
74
|
-
return new Promise((resolve, reject) => {
|
|
75
|
-
currentResolve = resolve;
|
|
76
|
-
currentReject = reject;
|
|
77
|
-
const userData = JSON.stringify({
|
|
78
|
-
Vod: {
|
|
79
|
-
UserData: {
|
|
80
|
-
IsShowWaterMark: "false",
|
|
81
|
-
// 不显示水印
|
|
82
|
-
Priority: "7"
|
|
83
|
-
// 上传优先级
|
|
84
|
-
}
|
|
85
|
-
}
|
|
86
|
-
});
|
|
87
|
-
uploader.addFile(file, null, null, null, userData);
|
|
88
|
-
uploader.startUpload();
|
|
89
|
-
});
|
|
90
|
-
};
|
|
91
|
-
return {
|
|
92
|
-
uploader,
|
|
93
|
-
upload
|
|
94
|
-
};
|
|
95
|
-
}
|
|
96
|
-
function downloadFile(url, fileName) {
|
|
97
|
-
const link = document.createElement("a");
|
|
98
|
-
link.download = fileName;
|
|
99
|
-
link.style.display = "none";
|
|
100
|
-
link.href = url;
|
|
101
|
-
document.body.appendChild(link);
|
|
102
|
-
link.click();
|
|
103
|
-
document.body.removeChild(link);
|
|
104
|
-
}
|
|
105
|
-
|
|
106
|
-
exports.createVideoUploader = createVideoUploader;
|
|
107
|
-
exports.downloadFile = downloadFile;
|
|
1
|
+
"use strict";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)}}))}exports.createVideoUploader=async function(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 t=JSON.stringify({Vod:{UserData:{IsShowWaterMark:"false",Priority:"7"}}});d.addFile(o,null,null,null,t),d.startUpload()}))}},exports.downloadFile=function(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)};
|
|
108
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","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","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,6BA2CAd,eAA0CgB,GAEpC,GAAkB,oBAAXC,OACH,MAAA,IAAIC,UAAU,6BAIjBD,OAAOE,oBAjDdnB,iBACM,IAIE,SAHEC,EAAW,6DACXA,EAAW,uEAEZgB,OAAOE,aACJ,MAAA,IAAIR,MAAM,sCAGbG,GAEC,MADEC,QAAAD,MAAM,gBAAiBA,GACzBA,CACR,CACF,CAqCUM,GAIR,IAAIC,EAA8D,KAC9DC,EAAgD,KAGpD,MAAMC,EAAW,IAAIN,OAAOE,aAAaK,IAAI,CAE3CC,iBAAkBT,EAAQS,iBAE1BC,qBAAsBV,EAAQU,sBAAyB,MAAO,GAE9DC,gBAAiB3B,UACX,IACI,MAAA4B,WAAEA,EAAYC,cAAAA,EAAAC,QAAeA,SAAkBd,EAAQW,kBAAkBI,KAAe,CAAC,EAC3FH,GAAcC,GAAiBC,GACjCP,EAASS,wBAAwBD,EAAYH,EAAYC,EAAeC,SAGrEhB,GAEC,MADEC,QAAAD,MAAM,0BAA2BA,GACnCA,CACR,GAGFmB,gBAAkBF,IAChBV,IAAiBU,EAAU,EAG7BG,eAAgBA,CAACC,EAAWC,EAAcC,KAChCtB,QAAAuB,IAAI,SAAUH,GACtBb,IAAgB,IAAIX,MAAM,GAAG0B,KAAWD,KAAO,IA+B5C,MAAA,CACLb,WACAgB,OAxBavC,SACN,IAAIG,SAAQ,CAACC,EAASC,KACVgB,EAAAjB,EACDkB,EAAAjB,EAGV,MAAAmC,EAAWC,KAAKC,UAAU,CAC9BlB,IAAK,CACHmB,SAAU,CACRC,gBAAiB,QACjBC,SAAU,QAMhBtB,EAASuB,QAAQC,EAAM,KAAM,KAAM,KAAMP,GACzCjB,EAASyB,aAAY,IAS3B,uBAOgB,SAAaC,EAAaC,GAClC,MAAAC,EAAO5C,SAASC,cAAc,KACpC2C,EAAKC,SAAWF,EAChBC,EAAKE,MAAMC,QAAU,OACrBH,EAAKI,KAAON,EACH1C,SAAAiD,KAAK3C,YAAYsC,GAC1BA,EAAKM,QACIlD,SAAAiD,KAAKE,YAAYP,EAC5B"}
|
package/lib/src/json.js
CHANGED
|
@@ -1,70 +1,2 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
var xlsx = require('xlsx');
|
|
4
|
-
|
|
5
|
-
function JsonToExcel() {
|
|
6
|
-
let title = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : "";
|
|
7
|
-
let json = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : [];
|
|
8
|
-
let merge = arguments.length > 2 ? arguments[2] : undefined;
|
|
9
|
-
try {
|
|
10
|
-
if (!json.length) {
|
|
11
|
-
return;
|
|
12
|
-
}
|
|
13
|
-
const worksheet = xlsx.utils.aoa_to_sheet(json);
|
|
14
|
-
if (merge) {
|
|
15
|
-
worksheet["!merges"] = merge;
|
|
16
|
-
}
|
|
17
|
-
const workbook = xlsx.utils.book_new();
|
|
18
|
-
xlsx.utils.book_append_sheet(workbook, worksheet, "");
|
|
19
|
-
xlsx.writeFile(workbook, `${title}.xlsx`);
|
|
20
|
-
} catch (e) {
|
|
21
|
-
console.log("e: ", e);
|
|
22
|
-
return new Error("\u6570\u636E\u5BFC\u51FA\u5931\u8D25");
|
|
23
|
-
}
|
|
24
|
-
}
|
|
25
|
-
function excelToJson(file, cb, start) {
|
|
26
|
-
return new Promise((resolve, reject) => {
|
|
27
|
-
const reader = new FileReader();
|
|
28
|
-
reader.readAsArrayBuffer(file);
|
|
29
|
-
reader.onload = e => {
|
|
30
|
-
const data = e.target?.result;
|
|
31
|
-
const workbook = xlsx.read(data, {
|
|
32
|
-
type: "binary"
|
|
33
|
-
});
|
|
34
|
-
const json = [];
|
|
35
|
-
for (const sheet in workbook.Sheets) {
|
|
36
|
-
if (Object.prototype.hasOwnProperty.call(workbook.Sheets, sheet)) {
|
|
37
|
-
let arr = [];
|
|
38
|
-
const fromTo = workbook.Sheets[sheet]["!ref"] || "";
|
|
39
|
-
const end = fromTo.split(":");
|
|
40
|
-
const space = start + end[1].toString();
|
|
41
|
-
arr = arr.concat(xlsx.utils.sheet_to_json(workbook.Sheets[sheet], {
|
|
42
|
-
header: 1,
|
|
43
|
-
range: start ? space : fromTo
|
|
44
|
-
}));
|
|
45
|
-
const titleArr = arr[0];
|
|
46
|
-
arr.shift();
|
|
47
|
-
const excelJsonArr = arr.map(item => {
|
|
48
|
-
const obj = {};
|
|
49
|
-
titleArr.forEach((titleItem, index) => {
|
|
50
|
-
obj[titleItem] = item[index];
|
|
51
|
-
});
|
|
52
|
-
return obj;
|
|
53
|
-
});
|
|
54
|
-
json.push(...excelJsonArr);
|
|
55
|
-
}
|
|
56
|
-
}
|
|
57
|
-
if (cb) {
|
|
58
|
-
cb(json);
|
|
59
|
-
}
|
|
60
|
-
resolve(json);
|
|
61
|
-
};
|
|
62
|
-
reader.onerror = e => {
|
|
63
|
-
reject(e);
|
|
64
|
-
};
|
|
65
|
-
});
|
|
66
|
-
}
|
|
67
|
-
|
|
68
|
-
exports.JsonToExcel = JsonToExcel;
|
|
69
|
-
exports.excelToJson = excelToJson;
|
|
1
|
+
"use strict";var e=require("xlsx");exports.JsonToExcel=function(){let t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:"",o=arguments.length>1&&void 0!==arguments[1]?arguments[1]:[],r=arguments.length>2?arguments[2]:void 0;try{if(!o.length)return;const n=e.utils.aoa_to_sheet(o);r&&(n["!merges"]=r);const s=e.utils.book_new();e.utils.book_append_sheet(s,n,""),e.writeFile(s,`${t}.xlsx`)}catch(e){return console.log("e: ",e),new Error("数据导出失败")}},exports.excelToJson=function(t,o,r){return new Promise(((n,s)=>{const l=new FileReader;l.readAsArrayBuffer(t),l.onload=t=>{const s=t.target?.result,l=e.read(s,{type:"binary"}),c=[];for(const t in l.Sheets)if(Object.prototype.hasOwnProperty.call(l.Sheets,t)){let o=[];const n=l.Sheets[t]["!ref"]||"",s=n.split(":"),i=r+s[1].toString();o=o.concat(e.utils.sheet_to_json(l.Sheets[t],{header:1,range:r?i:n}));const a=o[0];o.shift();const h=o.map((e=>{const t={};return a.forEach(((o,r)=>{t[o]=e[r]})),t}));c.push(...h)}o&&o(c),n(c)},l.onerror=e=>{s(e)}}))};
|
|
70
2
|
//# sourceMappingURL=json.js.map
|
package/lib/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":["
|
|
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":["title","arguments","length","undefined","json","merge","worksheet","utils","aoa_to_sheet","workbook","book_new","book_append_sheet","writeFile","e","console","log","Error","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":"uDASO,WAAgF,IAA3DA,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,EAAAA,MAAMC,aAAaJ,GACjCC,IACFC,EAAU,WAAaD,GAGnB,MAAAI,EAAWF,QAAMG,WACjBH,EAAAA,MAAAI,kBAAkBF,EAAUH,EAAW,IACnCM,EAAAA,UAAAH,EAAU,GAAGT,gBAElBa,GAEE,OADCC,QAAAC,IAAI,MAAOF,GACZ,IAAIG,MAAM,SACnB,CACF,sBAQgB,SAAYC,EAAYC,EAA2BC,GACjE,OAAO,IAAIC,SAAQ,CAACC,EAASC,KACrB,MAAAC,EAAS,IAAIC,WACnBD,EAAOE,kBAAkBR,GAClBM,EAAAG,OAAUb,IACT,MAAAc,EAAOd,EAAEe,QAAQC,OACjBpB,EAAWqB,EAAKA,KAAAH,EAAM,CAAEI,KAAM,WAE9B3B,EAAc,GACT,IAAA,MAAA4B,KAASvB,EAASwB,OAC3B,GAAIC,OAAOC,UAAUC,eAAeC,KAAK5B,EAASwB,OAAQD,GAAQ,CAChE,IAAIM,EAAkB,GACtB,MAAMC,EAAS9B,EAASwB,OAAOD,GAAO,SAAW,GAC3CQ,EAAMD,EAAOE,MAAM,KACnBC,EAAQvB,EAAQqB,EAAI,GAAGG,WAC7BL,EAAMA,EAAIM,OAAOrC,EAAAA,MAAMsC,cAAcpC,EAASwB,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,IAEJjD,EAAAqD,QAAQP,EACf,CAEEhC,GACFA,EAAGd,GAELiB,EAAQjB,EAAI,EAEPmB,EAAAmC,QAAW7C,IAChBS,EAAOT,EAAC,CACV,GAEJ"}
|