download.ts 24 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840
  1. import { cdn, upCdn } from '@/services/api';
  2. import { checkData } from '@/services/utils';
  3. import axios from 'axios';
  4. // import { MessagePlugin } from 'tdesign-vue-next';
  5. import { useUser } from '@/services/user';
  6. import JSZip from 'jszip';
  7. import { Pen, getGlobalColor, isShowChild } from '@meta2d/core';
  8. export const img_cdn = 'https://assets.le5lecdn.com';
  9. export const img_upCdn = 'https://drive.le5lecdn.com';
  10. const { user, signout } = useUser();
  11. const components = [
  12. 'inputDom',
  13. 'selectDom',
  14. 'menuDom',
  15. 'headMenuDom',
  16. 'sliderVerifyDom',
  17. 'dropdownDom',
  18. 'flvPlayerDom',
  19. 'countdown',
  20. 'swiperDom',
  21. 'threeDSence',
  22. 'rtspPlayerDom',
  23. 'timeline',
  24. 'swiperline',
  25. 'tab',
  26. 'radio',
  27. 'checkbox',
  28. 'calendar',
  29. 'indicator',
  30. 'progress',
  31. 'pagination',
  32. 'steps',
  33. 'notification',
  34. 'list',
  35. 'tree',
  36. 'rockerSwitch',
  37. 'roundSwitch',
  38. 'breadcrumb',
  39. 'transferSwitch',
  40. 'pie3D',
  41. 'hikVideo',
  42. 'thermometer',
  43. 'watermeter',
  44. 'indicatorLight',
  45. 'toggleSwitch',
  46. 'knifeSwitch',
  47. 'compass',
  48. 'thermometer1',
  49. 'airSwitch',
  50. 'waterTank',
  51. ];
  52. export const getDownloadList = (meta2dData: any, path: string = 'v') => {
  53. const lists = new Set();
  54. //TODO 加一个type区分是数据/还是接口
  55. //背景图片
  56. // const meta2dData = meta2d.data();
  57. let img = meta2dData.bkImage;
  58. if (img) {
  59. if (
  60. img.startsWith('/') ||
  61. img.startsWith(img_cdn) ||
  62. img.startsWith(img_upCdn)
  63. ) {
  64. let _img = img.replace(img_cdn, '').replace(img_upCdn, '');
  65. if (_img.startsWith('/v/')) {
  66. _img = _img.slice(2);
  67. }
  68. lists.add({
  69. url: img,
  70. path: `/view/projects/${path}` + _img,
  71. });
  72. meta2dData.bkImage = `/view/projects/${path}` + _img;
  73. }
  74. }
  75. //图片图元(image strokeImage backgroundImage)
  76. const imageKeys = ['image', 'strokeImage', 'backgroundImage'];
  77. const images: string[] = [];
  78. for (const pen of meta2dData.pens) {
  79. for (const i of imageKeys) {
  80. const image = pen[i];
  81. if (image) {
  82. if (
  83. image.startsWith('/') ||
  84. image.startsWith(img_cdn) ||
  85. image.startsWith(img_upCdn)
  86. ) {
  87. // 只考虑相对路径下的 image ,绝对路径图片无需下载
  88. let _img = image.replace(img_cdn, '').replace(img_upCdn, '');
  89. if (_img.startsWith('/v/')) {
  90. _img = _img.slice(2);
  91. }
  92. if (!images.includes(image)) {
  93. // let _img = image.replace(cdn, '').replace(upCdn, '');
  94. lists.add({
  95. url: image,
  96. path: `/view/projects/${path}` + _img,
  97. });
  98. }
  99. pen[i] = `/view/projects/${path}` + _img;
  100. }
  101. }
  102. }
  103. }
  104. if(path === 'v'){ //iframe嵌入的页面无需再次下载
  105. //其他文件
  106. const files = [
  107. '/view/assets/index.js',
  108. '/view/assets/index.css',
  109. '/view/css/index.css',
  110. '/view/css/t/font_2395018_nng9x1qhat.css',
  111. '/view/css/t/font_2073009_teagntehxt.css',
  112. '/view/js/marked.min.js',
  113. '/view/js/echarts.min.js',
  114. '/view/js/lcjs.iife.js',
  115. '/view/js/highcharts.js',
  116. '/view/js/highcharts-more.js',
  117. '/view/js/r.js',
  118. '/view/index.html',
  119. '/view/favicon.ico',
  120. '/view/view.conf',
  121. '/view/离线部署包使用说明.pdf',
  122. ];
  123. files.forEach((file) => {
  124. lists.add({
  125. url: (cdn ? cdn : '') + file,
  126. path: file,
  127. });
  128. });
  129. }
  130. //数据
  131. // const data: any = meta2d.data();
  132. if (meta2dData._id) delete meta2dData._id;
  133. if (meta2dData.id) delete meta2dData.id;
  134. if ((meta2dData as any).image) delete (meta2dData as any).image;
  135. checkData(meta2dData);
  136. lists.add({
  137. data: JSON.stringify(meta2dData)
  138. .replaceAll(img_cdn, '')
  139. .replaceAll(img_upCdn, ''),
  140. path: `/view/projects/${path}/data`,
  141. });
  142. return lists;
  143. };
  144. export const getPayList = (meta2dData: any) => {
  145. const pngs = new Set<string>();
  146. const jsPens = new Set<string>();
  147. const iotPens = new Set<string>();
  148. const svgPens = new Set<string>();
  149. for (const pen of meta2dData.pens) {
  150. if (pen.image) {
  151. if (
  152. pen.image.startsWith(`${img_cdn}/png/`) ||
  153. pen.image.startsWith('/png/')
  154. ) {
  155. pngs.add(pen.image.replace(img_cdn, ''));
  156. }
  157. } else if (pen.subClassName && pen.fullname) {
  158. if(!['箭头','拓扑图未分类'].includes(pen.subClassName)){
  159. jsPens.add(pen.name);
  160. }
  161. } else if (components.includes(pen.name)) {
  162. iotPens.add(pen.name);
  163. } else if (pen.svgUrl) {
  164. if (
  165. pen.svgUrl.startsWith(`${img_cdn}/svg/`) ||
  166. pen.svgUrl.startsWith('/svg/')
  167. ) {
  168. svgPens.add(pen.svgUrl.replace(img_cdn, ''));
  169. }
  170. }
  171. }
  172. if (![...svgPens].length) {
  173. //判断是否为老数据
  174. if (meta2dData.paths) {
  175. let keys = [];
  176. for (let key of Object.keys(meta2dData.paths)) {
  177. let path = meta2dData.paths[key];
  178. if (
  179. path.indexOf('-1.18Zm4-1') !== -1 ||
  180. path.indexOf('-1.19Zm4-1') !== -1 ||
  181. path.indexOf('2.85ZM') !== -1 ||
  182. path.indexOf('-1-2.39.3') !== -1
  183. ) {
  184. keys.push(key);
  185. }
  186. }
  187. let flag = meta2dData.pens.some(
  188. (pen) => pen.name === 'svgPath' && keys.includes(pen.pathId)
  189. );
  190. if (flag) {
  191. svgPens.add('*'); //需要购买所有
  192. }
  193. }
  194. }
  195. return {
  196. pngs: [...pngs],
  197. jsPens: [...jsPens],
  198. iotPens: [...iotPens],
  199. svgPens: [...svgPens],
  200. };
  201. };
  202. //获取已购买
  203. export const getComponentPurchased = async (list: any) => {
  204. let _list = [];
  205. list.pngs.forEach((item) => {
  206. _list.push({
  207. type: '图片图元',
  208. name: item,
  209. });
  210. });
  211. list.jsPens.forEach((item) => {
  212. _list.push({
  213. type: 'JS线性图元',
  214. name: item,
  215. });
  216. });
  217. list.iotPens.forEach((item) => {
  218. _list.push({
  219. type: '控件',
  220. name: item,
  221. });
  222. });
  223. if ([...list.svgPens].includes('*')) {
  224. _list.push({
  225. type: 'SVG线性图元',
  226. });
  227. } else {
  228. list.svgPens.forEach((item) => {
  229. _list.push({
  230. type: 'SVG线性图元',
  231. name: item,
  232. });
  233. });
  234. }
  235. if(!_list.length){
  236. return [];
  237. }
  238. const res: any = await axios.post('/api/paid/2d/component?pageSize=1000', {
  239. list: _list,
  240. });
  241. if (res.error) {
  242. return [];
  243. }
  244. // let purchasedPngs = res.list.filter((item) => list.pngs.has(item));
  245. // let purchasedJs = res.list.filter((item) => list.jsPens.has(item));
  246. // let purchasedIot = res.list.filter((item) => list.iotPens.has(item));
  247. // let purchasedSvg = res.list.filter((item) => list.svgPens.has(item));
  248. // let price =
  249. // ([...list.pngs].length - purchasedPngs.length) * 50 +
  250. // ([...list.jsPens].length - purchasedJs.length) * 10 +
  251. // ([...list.iotPens].length - purchasedIot.length) * 70+
  252. // ([...list.svgPens].length - purchasedSvg.length) * 10;
  253. return res.list;
  254. };
  255. export const get2dComponentJs = async (names: string[] = components) => {
  256. let list = [];
  257. names.forEach((item) => {
  258. list.push({
  259. type: '控件',
  260. name: item,
  261. });
  262. });
  263. const res: any = await axios.post(
  264. '/api/2d-component.js',
  265. {
  266. // list,
  267. },
  268. {
  269. responseType: 'blob',
  270. }
  271. );
  272. return res;
  273. };
  274. export const getTemPngs = async (names: string[]) => {
  275. const res: any = await axios.post('/api/file/presign', {
  276. names,
  277. });
  278. return res;
  279. };
  280. export const getGoods = async () => {
  281. const res: any = await axios.get('/api/goods/2d/component/types');
  282. // console.log("res",res);
  283. return res;
  284. };
  285. export const getDeployGoods = async () => {
  286. const ret:any = await axios.post('/api/goods/list',{
  287. type:'私有部署'
  288. });
  289. return ret.list;
  290. }
  291. export enum Frame {
  292. vue2,
  293. vue3,
  294. react,
  295. html,
  296. }
  297. // export const _preFrameDownload = async (type: Frame) => {
  298. // frameFlag = type;
  299. // // MessagePlugin.info('正在下载打包中,可能需要几分钟,请耐心等待...');
  300. // zip3D(
  301. // type === Frame.vue3 ? 'toVue3' : type === Frame.vue2 ? 'toVue2' : 'toReact'
  302. // );
  303. // zip2D(
  304. // type === Frame.vue3
  305. // ? 'downloadVue3'
  306. // : type === Frame.vue2
  307. // ? 'downloadVue2'
  308. // : 'downloadReact'
  309. // );
  310. // const data: any = meta2d.data();
  311. // if (data._id) delete data._id;
  312. // if (data.id) delete data.id;
  313. // if (data.image) delete data.image;
  314. // data.userId = user.id;
  315. // checkData(data);
  316. // const [{ default: JSZip }, { saveAs }] = await Promise.all([
  317. // import('jszip'),
  318. // import('file-saver'),
  319. // ]);
  320. // const zip = new JSZip();
  321. // let _fileName =
  322. // (data.name && data.name.replace(/\//g, '_').replace(/:/g, '_')) ||
  323. // 'le5le.meta2d';
  324. // //处理付费svg
  325. // if (Object.keys(data.paths).length >= 3) {
  326. // //简单判断有无svg图元
  327. // const res: any = await axios.post('/api/paid/2d/component?pageSize=1000', {
  328. // type: 'SVG线性图元',
  329. // });
  330. // if (res.list.length === 1 && !res.list[0].name) {
  331. // //已经购买全部
  332. // for (let key of Object.keys(data.paths)) {
  333. // let path = data.paths[key];
  334. // if (
  335. // path.indexOf('-1.18Zm4-1') !== -1 ||
  336. // path.indexOf('-1.19Zm4-1') !== -1 ||
  337. // path.indexOf('2.85ZM') !== -1 ||
  338. // path.indexOf('-1-2.39.3') !== -1
  339. // ) {
  340. // data.paths[key] = '';
  341. // }
  342. // }
  343. // } else {
  344. // //购买部分
  345. // let purchasedList = res.list.map((i) => i.name);
  346. // data.pens.forEach((pen) => {
  347. // if (pen.name === 'svgPath' && pen.svgUrl) {
  348. // if (purchasedList.includes(pen.svgUrl.replace(img_cdn, ''))) {
  349. // pen.pathId = null;
  350. // }
  351. // }
  352. // });
  353. // }
  354. // }
  355. // const _zip: any = zip.folder(`${_fileName}`);
  356. // _zip.file(
  357. // `${
  358. // type === Frame.vue3
  359. // ? 'meta2d-vue3'
  360. // : type === Frame.vue2
  361. // ? 'meta2d-vue2'
  362. // : 'meta2d-react'
  363. // }/public/json/data.json`,
  364. // JSON.stringify(data).replaceAll(img_cdn, '').replaceAll(img_upCdn, '')
  365. // );
  366. // await Promise.all([
  367. // zipJs(_zip),
  368. // zipBkImg(_zip),
  369. // zipImages(_zip, meta2d.store.data.pens),
  370. // type === Frame.vue3
  371. // ? zipVue3Files(_zip)
  372. // : type === Frame.vue2
  373. // ? zipVue2Files(_zip)
  374. // : zipReactFiles(_zip),
  375. // zipIotPens(_zip),
  376. // ]);
  377. // const blob = await zip.generateAsync({ type: 'blob' });
  378. // saveAs(blob, `${_fileName}.zip`);
  379. // frameFlag = -1;
  380. // };
  381. // async function zipIotPens(zip: JSZip) {
  382. // //处理控件
  383. // const js = await get2dComponentJs();
  384. // zip.file(
  385. // `${
  386. // frameFlag === Frame.vue3
  387. // ? 'meta2d-vue3'
  388. // : frameFlag === Frame.vue2
  389. // ? 'meta2d-vue2'
  390. // : 'meta2d-react'
  391. // }/public/js/2d-components.js`,
  392. // js,
  393. // { createFolders: true }
  394. // );
  395. // const res: Blob = await axios.get( cdn+'/view/js/r.js', {
  396. // responseType: 'blob',
  397. // });
  398. // zip.file(
  399. // `${
  400. // frameFlag === Frame.vue3
  401. // ? 'meta2d-vue3'
  402. // : frameFlag === Frame.vue2
  403. // ? 'meta2d-vue2'
  404. // : 'meta2d-react'
  405. // }/public/js/r.js`,
  406. // res,
  407. // { createFolders: true }
  408. // );
  409. // }
  410. // async function zipJs(zip: JSZip) {
  411. // const files = ['/view/js/marked.min.js', '/view/js/lcjs.iife.js'];
  412. // await Promise.all(
  413. // files.map(async (filePath) => {
  414. // const res: Blob = await axios.get(cdn+filePath, {
  415. // responseType: 'blob',
  416. // });
  417. // zip.file(
  418. // `${
  419. // frameFlag === Frame.vue3
  420. // ? 'meta2d-vue3'
  421. // : frameFlag === Frame.vue2
  422. // ? 'meta2d-vue2'
  423. // : 'meta2d-react'
  424. // }/public` + filePath.replace('/view', ''),
  425. // res,
  426. // { createFolders: true }
  427. // );
  428. // })
  429. // );
  430. // }
  431. export async function zipBkImg(zip: JSZip) {
  432. let img = meta2d.store.data.bkImage;
  433. if (img) {
  434. if (img.startsWith('/') || img.startsWith(img_cdn) || img.startsWith(img_upCdn)) {
  435. const pngs = await getTemPngs([img.replace(img_cdn, '').replace(img_upCdn, '')]);
  436. await zipImage(zip, img, pngs[img.replace(img_cdn, '').replace(img_upCdn, '')]);
  437. }
  438. }
  439. }
  440. async function zipImage(zip: JSZip, image: string, temImage?: string) {
  441. const res: Blob = await axios.get(temImage || image, {
  442. responseType: 'blob',
  443. // params: {
  444. // isZip: true,
  445. // },
  446. });
  447. zip.file(
  448. (cdn ? image.replace(cdn, '').replace(upCdn, '') : image),
  449. res,
  450. {
  451. createFolders: true,
  452. }
  453. );
  454. }
  455. // const zip3D = (name: string) => {
  456. // const pen_3d = meta2d.store.data.pens.filter(
  457. // (pen) =>
  458. // pen.name === 'iframe' &&
  459. // (pen.tags.includes('meta3d') || pen.iframe.indexOf('/3d') !== -1)
  460. // );
  461. // if (pen_3d && pen_3d.length) {
  462. // //存在3d场景
  463. // pen_3d.forEach((pen) => {
  464. // //发送消息
  465. // // let params = queryURLParams(pen.iframe.split('?')[1]);
  466. // (
  467. // pen.calculative.singleton.div.children[0] as HTMLIFrameElement
  468. // ).contentWindow.postMessage(
  469. // JSON.stringify({
  470. // type: 1,
  471. // name,
  472. // // id: params.id,
  473. // }),
  474. // '*'
  475. // );
  476. // });
  477. // }
  478. // };
  479. // const zip2D = (name: string) => {
  480. // const pen_2d = meta2d.store.data.pens.filter(
  481. // (pen) =>
  482. // pen.name === 'iframe' &&
  483. // (pen.iframe.indexOf('2d.le5le.com') !== -1 ||
  484. // pen.iframe.indexOf('/2d') !== -1 || pen.iframe.indexOf('data=2d') !== -1 ||
  485. // pen.iframe.indexOf('v.le5le.com') !== -1 ||
  486. // pen.iframe.indexOf('/view/v') !== -1 ||pen.iframe.indexOf('data=v') !== -1||
  487. // pen.iframe.indexOf('/preview') !== -1)
  488. // );
  489. // if (pen_2d && pen_2d.length) {
  490. // //存在3d场景
  491. // pen_2d.forEach((pen) => {
  492. // //发送消息
  493. // // let params = queryURLParams(pen.iframe.split('?')[1]);
  494. // (
  495. // pen.calculative.singleton.div.children[0] as HTMLIFrameElement
  496. // ).contentWindow.postMessage(
  497. // JSON.stringify({
  498. // name,
  499. // type: 1,
  500. // }),
  501. // '*'
  502. // );
  503. // });
  504. // }
  505. // };
  506. /**
  507. * 图片放到 zip 里
  508. * @param pens 可以是非具有 calculative 的 pen
  509. */
  510. export async function zipImages(zip: JSZip, pens: Pen[]) {
  511. if (!pens) {
  512. return;
  513. }
  514. // 不止 image 上有图片, strokeImage ,backgroundImage 也有图片
  515. const imageKeys = [
  516. {
  517. string: 'image',
  518. },
  519. { string: 'strokeImage' },
  520. { string: 'backgroundImage' },
  521. ] as const;
  522. const images: string[] = [];
  523. for (const pen of pens) {
  524. for (const i of imageKeys) {
  525. const image = pen[i.string];
  526. if (image) {
  527. // HTMLImageElement 无法精确控制图片格式
  528. if (
  529. image.startsWith('/') ||
  530. image.startsWith(cdn) ||
  531. image.startsWith(upCdn)
  532. ) {
  533. // 只考虑相对路径下的 image ,绝对路径图片无需下载
  534. if (!images.includes(image)) {
  535. images.push(image);
  536. }
  537. }
  538. }
  539. }
  540. // 无需递归遍历子节点,现在所有的节点都在外层
  541. }
  542. //付费pngs
  543. const pngs = await getTemPngs(
  544. images.map((i) => i.replace(img_cdn, '').replace(img_upCdn, ''))
  545. );
  546. await Promise.all(
  547. images.map((image) =>
  548. zipImage(zip, image, pngs[image.replace(img_cdn, '').replace(img_upCdn, '')])
  549. )
  550. );
  551. }
  552. //新
  553. // async function zipVue3Files(zip: JSZip) {
  554. // const files = [
  555. // '/view/meta2d-vue3/src/components/Meta2d.vue',
  556. // '/view/meta2d-vue3/src/App.vue',
  557. // '/view/meta2d-vue3/src/main.js',
  558. // '/view/meta2d-vue3/src/style.css',
  559. // '/view/meta2d-vue3/index.html',
  560. // '/view/meta2d-vue3/package.json',
  561. // '/view/meta2d-vue3/README.md',
  562. // '/view/meta2d-vue3/vite.config.js',
  563. // ] as const;
  564. // // 文件同时加载
  565. // await Promise.all(files.map((filePath) => zipFile(zip, filePath)));
  566. // }
  567. // async function zipVue2Files(zip: JSZip) {
  568. // const files = [
  569. // '/view/meta2d-vue2/src/components/Meta2d.vue',
  570. // '/view/meta2d-vue2/src/App.vue',
  571. // '/view/meta2d-vue2/src/main.js',
  572. // // '/view/meta2d-vue2/src/style.css',
  573. // '/view/meta2d-vue2/public/index.html',
  574. // '/view/meta2d-vue2/package.json',
  575. // '/view/meta2d-vue2/README.md',
  576. // // '/view/meta2d-vue3/vite.config.js',
  577. // ] as const;
  578. // // 文件同时加载
  579. // await Promise.all(files.map((filePath) => zipFile(zip, filePath)));
  580. // }
  581. // async function zipReactFiles(zip: JSZip) {
  582. // const files = [
  583. // '/view/meta2d-react/src/index.css',
  584. // '/view/meta2d-react/src/index.js',
  585. // '/view/meta2d-react/src/Meta2d.css',
  586. // '/view/meta2d-react/src/Meta2d.jsx',
  587. // '/view/meta2d-react/package.json',
  588. // '/view/meta2d-react/README.md',
  589. // '/view/meta2d-react/public/index.html',
  590. // ] as const;
  591. // // 文件同时加载
  592. // await Promise.all(files.map((filePath) => zipFile(zip, filePath)));
  593. // }
  594. // async function zipFile(zip: JSZip, filePath: string) {
  595. // const res: Blob = await axios.get(
  596. // (cdn ? cdn + '/v' : import.meta.env.BASE_URL.slice(0, -1)) + filePath,
  597. // {
  598. // responseType: 'blob',
  599. // }
  600. // );
  601. // zip.file(filePath.replace('/view', ''), res, { createFolders: true });
  602. // }
  603. export const getFrameDownloadList =(meta2dData: any, path: string = 'v',type:Frame, flag_3d=false) => {
  604. const lists = new Set();
  605. let img = meta2dData.bkImage;
  606. if (img) {
  607. if (
  608. img.startsWith('/') ||
  609. img.startsWith(img_cdn) ||
  610. img.startsWith(img_upCdn)
  611. ) {
  612. let _img = img.replace(img_cdn, '').replace(img_upCdn, '');
  613. if (_img.startsWith('/v/')) {
  614. _img = _img.slice(2);
  615. }
  616. lists.add({
  617. url: img,
  618. path: (`${
  619. type === Frame.vue3
  620. ? 'meta2d-vue3'
  621. : type === Frame.vue2
  622. ? 'meta2d-vue2'
  623. : 'meta2d-react'
  624. }/public`) + _img,
  625. });
  626. meta2dData.bkImage = _img;
  627. }
  628. }
  629. //图片图元(image strokeImage backgroundImage)
  630. const imageKeys = ['image', 'strokeImage', 'backgroundImage'];
  631. const images: string[] = [];
  632. for (const pen of meta2dData.pens) {
  633. for (const i of imageKeys) {
  634. const image = pen[i];
  635. if (image) {
  636. if (
  637. image.startsWith('/') ||
  638. image.startsWith(img_cdn) ||
  639. image.startsWith(img_upCdn)
  640. ) {
  641. // 只考虑相对路径下的 image ,绝对路径图片无需下载
  642. let _img = image.replace(img_cdn, '').replace(img_upCdn, '');
  643. if (_img.startsWith('/v/')) {
  644. _img = _img.slice(2);
  645. }
  646. let path = (`${
  647. type === Frame.vue3
  648. ? 'meta2d-vue3'
  649. : type === Frame.vue2
  650. ? 'meta2d-vue2'
  651. : 'meta2d-react'
  652. }/public`) + _img
  653. if (!images.includes(image)) {
  654. // let _img = image.replace(cdn, '').replace(upCdn, '');
  655. lists.add({
  656. url: image,
  657. path,
  658. });
  659. }
  660. pen[i] = _img;
  661. }
  662. }
  663. }
  664. }
  665. let folderName =type===Frame.vue3?'meta2d-vue3':type===Frame.vue2?'meta2d-vue2': 'meta2d-react';
  666. if(path === 'v'){ //iframe嵌入的页面无需再次下载
  667. //其他文件
  668. let files = [];
  669. let files_3d = [];
  670. switch (type) {
  671. case Frame.vue3:
  672. files =[
  673. '/view/meta2d-vue3/src/router/index.ts',
  674. '/view/meta2d-vue3/src/views/2d/Meta2d.vue',
  675. '/view/meta2d-vue3/src/App.vue',
  676. '/view/meta2d-vue3/src/main.ts',
  677. '/view/meta2d-vue3/src/style.css',
  678. '/view/meta2d-vue3/index.html',
  679. '/view/meta2d-vue3/package.json',
  680. '/view/meta2d-vue3/README.md',
  681. '/view/meta2d-vue3/tsconfig.json',
  682. '/view/meta2d-vue3/tsconfig.node.json',
  683. '/view/meta2d-vue3/vite.config.ts',
  684. ];
  685. if(flag_3d){
  686. //存在3d场景
  687. files_3d.push(...[
  688. '/meta2d-vue3/src/plugins/meta3d/index.ts',
  689. '/meta2d-vue3/src/plugins/meta3d/meta3d.css',
  690. '/meta2d-vue3/src/plugins/meta3d/meta3d.js',
  691. // '/view/meta2d-vue3/src/views/3d/Meta3d.vue',
  692. '/meta2d-vue3/public/meta3d/js/draco_decoder_gltf.js',
  693. '/meta2d-vue3/public/meta3d/js/draco_decoder_gltf.wasm',
  694. '/meta2d-vue3/public/meta3d/js/draco_wasm_wrapper_gltf.js',
  695. ]);
  696. files.push( '/view/meta2d-vue3/src/views/3d/Meta3d.vue',)
  697. }
  698. break;
  699. case Frame.vue2:
  700. files =[
  701. '/view/meta2d-vue2/src/router/index.js',
  702. '/view/meta2d-vue2/src/views/2d/Meta2d.vue',
  703. '/view/meta2d-vue2/src/App.vue',
  704. '/view/meta2d-vue2/src/main.js',
  705. '/view/meta2d-vue2/index.html',
  706. '/view/meta2d-vue2/package.json',
  707. '/view/meta2d-vue2/README.md',
  708. '/view/meta2d-vue2/vite.config.js'
  709. ];
  710. if(flag_3d){
  711. files_3d.push(...[
  712. '/meta2d-vue2/src/plugins/meta3d/index.js',
  713. '/meta2d-vue2/src/plugins/meta3d/meta3d.css',
  714. '/meta2d-vue2/src/plugins/meta3d/meta3d.js',
  715. // '/meta2d-vue2/src/views/3d/Meta3d.vue',
  716. '/meta2d-vue2/public/meta3d/js/draco_decoder_gltf.js',
  717. '/meta2d-vue2/public/meta3d/js/draco_decoder_gltf.wasm',
  718. '/meta2d-vue2/public/meta3d/js/draco_wasm_wrapper_gltf.js',
  719. ]);
  720. files.push( '/view/meta2d-vue2/src/views/3d/Meta3d.vue',)
  721. }
  722. break;
  723. case Frame.react:
  724. files =[
  725. '/view/meta2d-react/src/router/index.tsx',
  726. '/view/meta2d-react/src/views/2d/Meta2d.tsx',
  727. '/view/meta2d-react/src/App.tsx',
  728. '/view/meta2d-react/src/index.css',
  729. '/view/meta2d-react/src/main.tsx',
  730. '/view/meta2d-react/index.html',
  731. '/view/meta2d-react/package.json',
  732. '/view/meta2d-react/README.md',
  733. '/view/meta2d-react/tsconfig.json',
  734. '/view/meta2d-react/tsconfig.node.json',
  735. '/view/meta2d-react/vite.config.ts',
  736. ];
  737. if(flag_3d){
  738. files_3d.push(...[
  739. '/meta2d-react/src/plugins/meta3d/index.ts',
  740. '/meta2d-react/src/plugins/meta3d/meta3d.css',
  741. '/meta2d-react/src/plugins/meta3d/meta3d.js',
  742. // '/meta2d-react/src/views/3d/Meta3d.tsx',
  743. '/meta2d-react/public/meta3d/js/draco_decoder_gltf.js',
  744. '/meta2d-react/public/meta3d/js/draco_decoder_gltf.wasm',
  745. '/meta2d-react/public/meta3d/js/draco_wasm_wrapper_gltf.js',
  746. ]);
  747. files.push('/view/meta2d-react/src/views/3d/Meta3d.tsx',)
  748. }
  749. break;
  750. default:
  751. break;
  752. }
  753. files.forEach((file) => {
  754. lists.add({
  755. url: (cdn ? cdn + '/v' : import.meta.env.BASE_URL.slice(0, -1)) + file,
  756. path: file.replace('/view', ''),
  757. });
  758. });
  759. if(flag_3d){
  760. files_3d.forEach((file) => {
  761. lists.add({
  762. url: (cdn ? cdn + '/v' : import.meta.env.BASE_URL.slice(0, -1)) + '/view/meta3d/'+file.split('/meta3d/')[1],
  763. path: file,
  764. });
  765. })
  766. }
  767. let jsFiles = [
  768. '/view/js/marked.min.js',
  769. // '/view/js/echarts.min.js',
  770. '/view/js/lcjs.iife.js',
  771. // '/view/js/highcharts.js',
  772. // '/view/js/highcharts-more.js',
  773. '/view/js/r.js',
  774. '/view/icon/font_2395018_nng9x1qhat.css',
  775. '/view/icon/font_2073009_teagntehxt.css',
  776. ]
  777. jsFiles.forEach((file) => {
  778. lists.add({
  779. url: (cdn ? cdn + '/v' : import.meta.env.BASE_URL.slice(0, -1))+ file,
  780. path:`/${folderName}/public${file.replace('/view', '')}`,
  781. });
  782. });
  783. }
  784. //图纸数据
  785. if (meta2dData._id) delete meta2dData._id;
  786. if (meta2dData.id) delete meta2dData.id;
  787. if ((meta2dData as any).image) delete (meta2dData as any).image;
  788. lists.add({
  789. data: JSON.stringify(meta2dData)
  790. .replaceAll(img_cdn, '')
  791. .replaceAll(img_upCdn, ''),
  792. path: `/${folderName}/public/json/${path}.json`,
  793. });
  794. return lists;
  795. };