index.ts 3.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161
  1. import type { Component } from 'vue';
  2. import { markRaw } from 'vue';
  3. // 辅助函数:自动导入展示组件和编辑组件
  4. // const createComponentMap = (name: string) => ({
  5. // pages: defineAsyncComponent(() => import(`@/views/diy/pccomponents/pages/${name}.vue`)),
  6. // edit: defineAsyncComponent(() => import(`@/views/diy/pccomponents/edit/${name}-edit.vue`))
  7. // });
  8. const createComponentMap = (name: string) => ({
  9. pagePath: `./pages/${name}.vue`,
  10. editPath: `./edit/${name}-edit.vue`,
  11. fid: 1
  12. });
  13. // 组件列表配置
  14. export const componentImportConfigs: any = [
  15. {
  16. name: '头部组件',
  17. icon: 'iconfont iconfuwenbenpc',
  18. id: 1,
  19. enabled: true,
  20. ...createComponentMap('head')
  21. },
  22. {
  23. name: '文本标题',
  24. icon: 'iconfont iconbiaotipc',
  25. id: 2,
  26. enabled: true,
  27. ...createComponentMap('textTitle')
  28. },
  29. {
  30. name: '图文导航',
  31. icon: 'iconfont icontuwendaohangpc',
  32. id: 3,
  33. enabled: true,
  34. ...createComponentMap('navigation')
  35. },
  36. {
  37. name: '图片魔方',
  38. icon: 'iconfont iconmofangpc',
  39. id: 4,
  40. enabled: true,
  41. ...createComponentMap('imageCube')
  42. },
  43. {
  44. name: '活动魔方',
  45. icon: 'iconfont iconmofangpc',
  46. enabled: true,
  47. id: 5
  48. },
  49. {
  50. name: '轮播图',
  51. icon: 'iconfont icona-tupianzhanbopc302',
  52. enabled: true,
  53. id: 6,
  54. ...createComponentMap('carousel')
  55. },
  56. {
  57. name: '文章咨询',
  58. icon: 'iconfont icongonggaopc',
  59. enabled: true,
  60. id: 7,
  61. ...createComponentMap('article')
  62. },
  63. {
  64. name: '品牌组件',
  65. icon: 'iconfont iconmiaoshashangpin',
  66. enabled: true,
  67. id: 8,
  68. ...createComponentMap('brand')
  69. },
  70. {
  71. name: '图文广告',
  72. icon: 'iconfont icontupiandaohangpc',
  73. enabled: true,
  74. id: 9,
  75. ...createComponentMap('advert')
  76. },
  77. {
  78. name: '楼层组件',
  79. icon: 'iconfont iconshangpinliebiaopc',
  80. enabled: true,
  81. id: 10,
  82. ...createComponentMap('floor')
  83. },
  84. {
  85. name: '商品组件',
  86. icon: 'iconfont icona-shangpintuijianpc30',
  87. enabled: true,
  88. id: 11,
  89. ...createComponentMap('goods')
  90. },
  91. {
  92. name: '多商品组',
  93. icon: 'iconfont iconduoshangpinzupc',
  94. enabled: true,
  95. id: 12,
  96. ...createComponentMap('goodsList')
  97. },
  98. {
  99. name: '发现组件',
  100. icon: 'iconfont iconjifenshangpinpc',
  101. enabled: true,
  102. id: 13,
  103. ...createComponentMap('discover')
  104. },
  105. {
  106. name: '热区',
  107. icon: 'iconfont iconrequpc',
  108. enabled: true,
  109. id: 14,
  110. ...createComponentMap('hot')
  111. }
  112. ];
  113. /**
  114. * 加载所有组件
  115. * @returns 组件配置列表
  116. */
  117. export async function loadDiyComponents(): Promise<any[]> {
  118. const components: any[] = [];
  119. const loadPromises = componentImportConfigs
  120. .filter((config: any) => config.enabled !== false)
  121. .map(async (config: any) => {
  122. try {
  123. const [pageModule, editModule] = await Promise.all([import(/* @vite-ignore */ config.pagePath), import(/* @vite-ignore */ config.editPath)]);
  124. return {
  125. name: config.name,
  126. icon: config.icon,
  127. fid: config.fid,
  128. id: config.id,
  129. components: markRaw(pageModule.default),
  130. edit: markRaw(editModule.default),
  131. enabled: true
  132. } as any;
  133. } catch (error) {
  134. console.warn(`加载组件失败:${config.name}`, error);
  135. return null;
  136. }
  137. });
  138. const results = await Promise.all(loadPromises);
  139. return results.filter((item): item is any => item !== null);
  140. }
  141. /**
  142. * 获取组件分组配置
  143. * @param components 组件列表
  144. * @returns 分组后的组件配置
  145. */
  146. export function getComponentGroups(components: any[]): any[] {
  147. return [
  148. {
  149. name: '基础组件',
  150. list: components,
  151. id: 1
  152. }
  153. // 后续可扩展多个分组,如:营销组件、商品组件等
  154. ];
  155. }