@maxelms/create-plugin-cli 1.1.0

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.
Files changed (274) hide show
  1. package/README.en.md +36 -0
  2. package/README.md +12 -0
  3. package/bin/build.js +29 -0
  4. package/bin/compress.js +35 -0
  5. package/bin/copy.js +39 -0
  6. package/bin/index.js +53 -0
  7. package/configuration-schema.json +829 -0
  8. package/lib/index.d.ts +21 -0
  9. package/lib/index.js +242 -0
  10. package/lib/utils.d.ts +18 -0
  11. package/lib/utils.js +114 -0
  12. package/package.json +50 -0
  13. package/templates/jQuery-micro-app/package.json.tpl +19 -0
  14. package/templates/jQuery-micro-app/src/README.md +5 -0
  15. package/templates/jQuery-micro-app/src/configuration.json +30 -0
  16. package/templates/jQuery-micro-app/src/index.html +17 -0
  17. package/templates/jQuery-micro-app/src/main.js.tpl +31 -0
  18. package/templates/jQuery-micro-app/src/manifest.json.tpl +9 -0
  19. package/templates/jQuery-micro-app/src/style.css +11 -0
  20. package/templates/maxelms-navigation/.babelrc +7 -0
  21. package/templates/maxelms-navigation/.gitignore.tpl +23 -0
  22. package/templates/maxelms-navigation/README.md +15 -0
  23. package/templates/maxelms-navigation/global.d.ts +2 -0
  24. package/templates/maxelms-navigation/index.html +16 -0
  25. package/templates/maxelms-navigation/package.json +65 -0
  26. package/templates/maxelms-navigation/patches/live2d-widget@3.1.4.patch +4534 -0
  27. package/templates/maxelms-navigation/pnpm-lock.yaml +7993 -0
  28. package/templates/maxelms-navigation/src/App.tsx +47 -0
  29. package/templates/maxelms-navigation/src/components/Actions/ColorPicker.tsx +86 -0
  30. package/templates/maxelms-navigation/src/components/Actions/SwitchApps.tsx +83 -0
  31. package/templates/maxelms-navigation/src/components/Actions/index.tsx +95 -0
  32. package/templates/maxelms-navigation/src/components/Cutie.tsx +24 -0
  33. package/templates/maxelms-navigation/src/components/Enterprises.tsx +46 -0
  34. package/templates/maxelms-navigation/src/components/Logo.tsx +29 -0
  35. package/templates/maxelms-navigation/src/components/Menus/MenuPanel.tsx +55 -0
  36. package/templates/maxelms-navigation/src/components/Menus/index.tsx +50 -0
  37. package/templates/maxelms-navigation/src/components/Search.tsx +77 -0
  38. package/templates/maxelms-navigation/src/imgs/corp-admin.svg +1 -0
  39. package/templates/maxelms-navigation/src/imgs/saas-admin.svg +1 -0
  40. package/templates/maxelms-navigation/src/imgs/skin.svg +1 -0
  41. package/templates/maxelms-navigation/src/imgs/tenant-admin.svg +1 -0
  42. package/templates/maxelms-navigation/src/imgs/user-center.svg +1 -0
  43. package/templates/maxelms-navigation/src/index.tsx +14 -0
  44. package/templates/maxelms-navigation/src/interface.ts +27 -0
  45. package/templates/maxelms-navigation/src/style.less.tpl +278 -0
  46. package/templates/maxelms-navigation/src/utils.ts.tpl +40 -0
  47. package/templates/maxelms-navigation/tsconfig.json +111 -0
  48. package/templates/maxelms-navigation/webpack.config.js +119 -0
  49. package/templates/maxelms-script/.babelrc +5 -0
  50. package/templates/maxelms-script/.gitignore.tpl +23 -0
  51. package/templates/maxelms-script/README.md +0 -0
  52. package/templates/maxelms-script/global.d.ts +2 -0
  53. package/templates/maxelms-script/index.html +10 -0
  54. package/templates/maxelms-script/package.json.tpl +55 -0
  55. package/templates/maxelms-script/pnpm-lock.yaml +7699 -0
  56. package/templates/maxelms-script/src/App.tsx +15 -0
  57. package/templates/maxelms-script/src/index.tsx +15 -0
  58. package/templates/maxelms-script/src/style.less.tpl +8 -0
  59. package/templates/maxelms-script/src/utils.ts.tpl +2 -0
  60. package/templates/maxelms-script/tsconfig.json +111 -0
  61. package/templates/maxelms-script/webpack.config.js +92 -0
  62. package/templates/maxelms-style/.gitignore.tpl +38 -0
  63. package/templates/maxelms-style/README.md +0 -0
  64. package/templates/maxelms-style/index.css +3 -0
  65. package/templates/maxelms-style/index.less +4 -0
  66. package/templates/maxelms-style/package.json.tpl +17 -0
  67. package/templates/playground/dist/main.css +2 -0
  68. package/templates/playground/dist/main.js +2 -0
  69. package/templates/playground/dist/main.js.LICENSE.txt +52 -0
  70. package/templates/playground/dist/playground.html +1 -0
  71. package/templates/playground/dist/react-dom.production.min.js +2 -0
  72. package/templates/playground/dist/react-dom.production.min.js.LICENSE.txt +8 -0
  73. package/templates/playground/dist/react.production.min.js +2 -0
  74. package/templates/playground/dist/react.production.min.js.LICENSE.txt +8 -0
  75. package/templates/playground/dist/zone.umd.min.js +2 -0
  76. package/templates/playground/dist/zone.umd.min.js.LICENSE.txt +29 -0
  77. package/templates/project/package.json +17 -0
  78. package/templates/react-micro-app/.babelrc +6 -0
  79. package/templates/react-micro-app/.gitignore.tpl +23 -0
  80. package/templates/react-micro-app/README.md +5 -0
  81. package/templates/react-micro-app/manifest.json.tpl +21 -0
  82. package/templates/react-micro-app/package.json.tpl +53 -0
  83. package/templates/react-micro-app/public/configuration.json +30 -0
  84. package/templates/react-micro-app/public/index.html +10 -0
  85. package/templates/react-micro-app/src/components/NoMatch.tsx +15 -0
  86. package/templates/react-micro-app/src/context/masterContext.ts +11 -0
  87. package/templates/react-micro-app/src/index.tsx +52 -0
  88. package/templates/react-micro-app/src/layouts/BasicLayout.less +16 -0
  89. package/templates/react-micro-app/src/layouts/BasicLayout.tsx +21 -0
  90. package/templates/react-micro-app/src/pages/Home/index.less +15 -0
  91. package/templates/react-micro-app/src/pages/Home/index.tsx +33 -0
  92. package/templates/react-micro-app/src/pages/List/index.less +12 -0
  93. package/templates/react-micro-app/src/pages/List/index.tsx +12 -0
  94. package/templates/react-micro-app/src/pages/New/index.less +12 -0
  95. package/templates/react-micro-app/src/pages/New/index.tsx +12 -0
  96. package/templates/react-micro-app/src/pages/View/index.less +12 -0
  97. package/templates/react-micro-app/src/pages/View/index.tsx +12 -0
  98. package/templates/react-micro-app/src/public-path.js +4 -0
  99. package/templates/react-micro-app/src/router.tsx +44 -0
  100. package/templates/react-micro-app/tsconfig.json +102 -0
  101. package/templates/react-micro-app/typings.d.ts +11 -0
  102. package/templates/react-micro-app/webpack.config.js.tpl +178 -0
  103. package/templates/react-micro-app-umi/.editorconfig +16 -0
  104. package/templates/react-micro-app-umi/.env +1 -0
  105. package/templates/react-micro-app-umi/.gitignore.tpl +23 -0
  106. package/templates/react-micro-app-umi/.prettierignore +8 -0
  107. package/templates/react-micro-app-umi/.prettierrc +11 -0
  108. package/templates/react-micro-app-umi/.umirc.ts.tpl +31 -0
  109. package/templates/react-micro-app-umi/README.md +5 -0
  110. package/templates/react-micro-app-umi/manifest.json.tpl +21 -0
  111. package/templates/react-micro-app-umi/package.json.tpl +42 -0
  112. package/templates/react-micro-app-umi/public/basicConfiguration.json +30 -0
  113. package/templates/react-micro-app-umi/public/configuration.json +30 -0
  114. package/templates/react-micro-app-umi/src/layout/BasicLayout.tsx +16 -0
  115. package/templates/react-micro-app-umi/src/pages/about.tsx +11 -0
  116. package/templates/react-micro-app-umi/src/pages/home.tsx +19 -0
  117. package/templates/react-micro-app-umi/tsconfig.json +36 -0
  118. package/templates/react-micro-app-umi/typings.d.ts +8 -0
  119. package/templates/react-micro-button/.gitignore.tpl +23 -0
  120. package/templates/react-micro-button/README.md +5 -0
  121. package/templates/react-micro-button/configuration/Configuration.tsx +113 -0
  122. package/templates/react-micro-button/configuration/index.css +8 -0
  123. package/templates/react-micro-button/configuration/index.tsx +6 -0
  124. package/templates/react-micro-button/manifest.json.tpl +3 -0
  125. package/templates/react-micro-button/package.json.tpl +49 -0
  126. package/templates/react-micro-button/postcss.config.js +5 -0
  127. package/templates/react-micro-button/public/basicConfiguration.json +30 -0
  128. package/templates/react-micro-button/public/configuration.html +10 -0
  129. package/templates/react-micro-button/public/configuration.json +30 -0
  130. package/templates/react-micro-button/public/index.html +10 -0
  131. package/templates/react-micro-button/src/App.tsx +41 -0
  132. package/templates/react-micro-button/src/app.less +0 -0
  133. package/templates/react-micro-button/src/index.less +0 -0
  134. package/templates/react-micro-button/src/index.tsx +30 -0
  135. package/templates/react-micro-button/tsconfig.json +11 -0
  136. package/templates/react-micro-button/webpack.config.js.tpl +150 -0
  137. package/templates/react-micro-field/.babelrc +5 -0
  138. package/templates/react-micro-field/.gitignore.tpl +23 -0
  139. package/templates/react-micro-field/README.md +5 -0
  140. package/templates/react-micro-field/configuration/Configuration.tsx +113 -0
  141. package/templates/react-micro-field/configuration/index.css +8 -0
  142. package/templates/react-micro-field/configuration/index.tsx +6 -0
  143. package/templates/react-micro-field/manifest.json.tpl +7 -0
  144. package/templates/react-micro-field/package.json.tpl +50 -0
  145. package/templates/react-micro-field/postcss.config.js +5 -0
  146. package/templates/react-micro-field/public/basicConfiguration.json +30 -0
  147. package/templates/react-micro-field/public/configuration.html +10 -0
  148. package/templates/react-micro-field/public/configuration.json +30 -0
  149. package/templates/react-micro-field/public/index.html +10 -0
  150. package/templates/react-micro-field/src/App.tsx.tpl +51 -0
  151. package/templates/react-micro-field/src/index.tsx +29 -0
  152. package/templates/react-micro-field/src/style.less.tpl +12 -0
  153. package/templates/react-micro-field/tsconfig.json +11 -0
  154. package/templates/react-micro-field/webpack.config.js.tpl +157 -0
  155. package/templates/react-micro-field-umi/.editorconfig +16 -0
  156. package/templates/react-micro-field-umi/.gitignore.tpl +24 -0
  157. package/templates/react-micro-field-umi/.prettierignore +8 -0
  158. package/templates/react-micro-field-umi/.prettierrc +11 -0
  159. package/templates/react-micro-field-umi/README.md +5 -0
  160. package/templates/react-micro-field-umi/config/config.ts.tpl +41 -0
  161. package/templates/react-micro-field-umi/config/plugin.ts +18 -0
  162. package/templates/react-micro-field-umi/manifest.json.tpl +7 -0
  163. package/templates/react-micro-field-umi/package.json.tpl +48 -0
  164. package/templates/react-micro-field-umi/public/basicConfiguration.json +30 -0
  165. package/templates/react-micro-field-umi/public/configuration.json +30 -0
  166. package/templates/react-micro-field-umi/src/app.tsx +46 -0
  167. package/templates/react-micro-field-umi/src/global.tsx +0 -0
  168. package/templates/react-micro-field-umi/src/hooks/masterProps.ts +33 -0
  169. package/templates/react-micro-field-umi/src/layouts/BasicLayout.tsx +17 -0
  170. package/templates/react-micro-field-umi/src/pages/configuration/index.tsx +90 -0
  171. package/templates/react-micro-field-umi/src/pages/index.tsx.tpl +54 -0
  172. package/templates/react-micro-field-umi/src/pages/interface.ts +12 -0
  173. package/templates/react-micro-field-umi/src/pages/style.less.tpl +15 -0
  174. package/templates/react-micro-field-umi/src/public-path.js +5 -0
  175. package/templates/react-micro-field-umi/tsconfig.json +37 -0
  176. package/templates/react-micro-field-umi/typings.d.ts +10 -0
  177. package/templates/react-micro-plugin/.babelrc +5 -0
  178. package/templates/react-micro-plugin/.gitignore.tpl +23 -0
  179. package/templates/react-micro-plugin/README.md +5 -0
  180. package/templates/react-micro-plugin/configuration/Configuration.tsx +114 -0
  181. package/templates/react-micro-plugin/configuration/index.css +8 -0
  182. package/templates/react-micro-plugin/configuration/index.tsx +6 -0
  183. package/templates/react-micro-plugin/manifest.json.tpl +3 -0
  184. package/templates/react-micro-plugin/package.json.tpl +50 -0
  185. package/templates/react-micro-plugin/postcss.config.js +5 -0
  186. package/templates/react-micro-plugin/public/configuration.html +10 -0
  187. package/templates/react-micro-plugin/public/configuration.json +30 -0
  188. package/templates/react-micro-plugin/public/index.html +10 -0
  189. package/templates/react-micro-plugin/src/App.tsx.tpl +32 -0
  190. package/templates/react-micro-plugin/src/index.tsx +29 -0
  191. package/templates/react-micro-plugin/src/style.less.tpl +12 -0
  192. package/templates/react-micro-plugin/tsconfig.json +11 -0
  193. package/templates/react-micro-plugin/webpack.config.js.tpl +156 -0
  194. package/templates/react-micro-plugin-umi/.editorconfig +16 -0
  195. package/templates/react-micro-plugin-umi/.gitignore.tpl +24 -0
  196. package/templates/react-micro-plugin-umi/.prettierignore +8 -0
  197. package/templates/react-micro-plugin-umi/.prettierrc +11 -0
  198. package/templates/react-micro-plugin-umi/README.md +5 -0
  199. package/templates/react-micro-plugin-umi/config/config.ts +29 -0
  200. package/templates/react-micro-plugin-umi/config/plugin.ts +18 -0
  201. package/templates/react-micro-plugin-umi/manifest.json.tpl +3 -0
  202. package/templates/react-micro-plugin-umi/package.json.tpl +48 -0
  203. package/templates/react-micro-plugin-umi/public/configuration.json +30 -0
  204. package/templates/react-micro-plugin-umi/src/app.tsx +46 -0
  205. package/templates/react-micro-plugin-umi/src/global.tsx +0 -0
  206. package/templates/react-micro-plugin-umi/src/hooks/masterProps.ts +34 -0
  207. package/templates/react-micro-plugin-umi/src/layouts/BasicLayout.tsx +17 -0
  208. package/templates/react-micro-plugin-umi/src/pages/configuration/index.tsx +113 -0
  209. package/templates/react-micro-plugin-umi/src/pages/index.tsx +21 -0
  210. package/templates/react-micro-plugin-umi/src/public-path.js +5 -0
  211. package/templates/react-micro-plugin-umi/tsconfig.json +37 -0
  212. package/templates/react-micro-plugin-umi/typings.d.ts +10 -0
  213. package/templates/vue-micro-app/.gitignore.tpl +23 -0
  214. package/templates/vue-micro-app/README.md +5 -0
  215. package/templates/vue-micro-app/babel.config.js +15 -0
  216. package/templates/vue-micro-app/manifest.json.tpl +21 -0
  217. package/templates/vue-micro-app/package.json.tpl +54 -0
  218. package/templates/vue-micro-app/public/configuration.json +30 -0
  219. package/templates/vue-micro-app/public/favicon.ico +0 -0
  220. package/templates/vue-micro-app/public/index.html +10 -0
  221. package/templates/vue-micro-app/src/App.vue +35 -0
  222. package/templates/vue-micro-app/src/assets/logo.png +0 -0
  223. package/templates/vue-micro-app/src/components/HelloWorld.vue +32 -0
  224. package/templates/vue-micro-app/src/main.js +80 -0
  225. package/templates/vue-micro-app/src/public-path.js +5 -0
  226. package/templates/vue-micro-app/src/routes.js +19 -0
  227. package/templates/vue-micro-app/src/views/About.vue +13 -0
  228. package/templates/vue-micro-app/src/views/Home.vue +21 -0
  229. package/templates/vue-micro-app/vue.config.js.tpl +35 -0
  230. package/templates/vue-micro-button/.gitignore.tpl +23 -0
  231. package/templates/vue-micro-button/README.md +5 -0
  232. package/templates/vue-micro-button/babel.config.js +8 -0
  233. package/templates/vue-micro-button/configuration/App.vue +78 -0
  234. package/templates/vue-micro-button/configuration/main.js +11 -0
  235. package/templates/vue-micro-button/manifest.json.tpl +3 -0
  236. package/templates/vue-micro-button/package.json.tpl +51 -0
  237. package/templates/vue-micro-button/public/basicConfiguration.json +30 -0
  238. package/templates/vue-micro-button/public/configuration.html +10 -0
  239. package/templates/vue-micro-button/public/configuration.json +30 -0
  240. package/templates/vue-micro-button/public/index.html +12 -0
  241. package/templates/vue-micro-button/src/App.vue +46 -0
  242. package/templates/vue-micro-button/src/main.js +44 -0
  243. package/templates/vue-micro-button/vue.config.js.tpl +51 -0
  244. package/templates/vue-micro-field/.gitignore.tpl +23 -0
  245. package/templates/vue-micro-field/README.md +5 -0
  246. package/templates/vue-micro-field/babel.config.js +8 -0
  247. package/templates/vue-micro-field/configuration/App.vue +78 -0
  248. package/templates/vue-micro-field/configuration/main.js +11 -0
  249. package/templates/vue-micro-field/manifest.json.tpl +7 -0
  250. package/templates/vue-micro-field/package.json.tpl +53 -0
  251. package/templates/vue-micro-field/public/basicConfiguration.json +30 -0
  252. package/templates/vue-micro-field/public/configuration.html +10 -0
  253. package/templates/vue-micro-field/public/configuration.json +30 -0
  254. package/templates/vue-micro-field/public/index.html +10 -0
  255. package/templates/vue-micro-field/scripts/compress.js +32 -0
  256. package/templates/vue-micro-field/src/App.vue.tpl +55 -0
  257. package/templates/vue-micro-field/src/main.js +38 -0
  258. package/templates/vue-micro-field/src/style.less.tpl +16 -0
  259. package/templates/vue-micro-field/vue.config.js.tpl +51 -0
  260. package/templates/vue-micro-plugin/.gitignore.tpl +23 -0
  261. package/templates/vue-micro-plugin/README.md +24 -0
  262. package/templates/vue-micro-plugin/babel.config.js +8 -0
  263. package/templates/vue-micro-plugin/configuration/App.vue +100 -0
  264. package/templates/vue-micro-plugin/configuration/main.js +11 -0
  265. package/templates/vue-micro-plugin/manifest.json.tpl +3 -0
  266. package/templates/vue-micro-plugin/package.json.tpl +56 -0
  267. package/templates/vue-micro-plugin/public/configuration.html +10 -0
  268. package/templates/vue-micro-plugin/public/configuration.json +30 -0
  269. package/templates/vue-micro-plugin/public/index.html +10 -0
  270. package/templates/vue-micro-plugin/scripts/compress.js +32 -0
  271. package/templates/vue-micro-plugin/src/App.vue.tpl +42 -0
  272. package/templates/vue-micro-plugin/src/main.js +38 -0
  273. package/templates/vue-micro-plugin/src/style.less.tpl +16 -0
  274. package/templates/vue-micro-plugin/vue.config.js.tpl +53 -0
@@ -0,0 +1,46 @@
1
+ <template>
2
+ <div id="app">
3
+ <!-- 集成在 apaas 中时会走该逻辑 -->
4
+ <span v-if="buttonName" @click="visible = true">{{buttonName}}</span>
5
+ <!-- 由于独立开发时没有 apaas 传递的上下文数据,会渲染一个按钮辅助开发 -->
6
+ <button v-if="!buttonName" @click="visible = true">自定义按钮</button>
7
+ <el-dialog
8
+ append-to-body
9
+ title="弹窗"
10
+ width="30%"
11
+ :visible.sync="visible"
12
+ >
13
+ <span>可以在此处编写弹出层 UI 逻辑</span>
14
+ <span slot="footer" class="dialog-footer">
15
+ <el-button @click="visible = false">取 消</el-button>
16
+ <el-button type="primary" @click="visible = false">确 定</el-button>
17
+ </span>
18
+ </el-dialog>
19
+ </div>
20
+ </template>
21
+
22
+ <script>
23
+
24
+ export default {
25
+ name: 'App',
26
+ data() {
27
+ return {
28
+ visible: false,
29
+ buttonName: this.$root?.masterProps?.originalButtonProps?.name,
30
+ }
31
+ },
32
+ components: {
33
+
34
+ },
35
+ methods: {
36
+
37
+ },
38
+ created() {
39
+
40
+ }
41
+ }
42
+ </script>
43
+
44
+ <style>
45
+
46
+ </style>
@@ -0,0 +1,44 @@
1
+ import Vue from 'vue'
2
+ import ElementUI from 'element-ui';
3
+ import { registerPlugin, poweredByMaxelms } from '@max-kit/max-api'
4
+ import App from './App.vue'
5
+ import 'element-ui/lib/theme-chalk/index.css';
6
+
7
+ Vue.use(ElementUI);
8
+
9
+ Vue.config.productionTip = false
10
+
11
+ window.__SINGLETON_MODE__ = true
12
+
13
+ const vms = {}
14
+
15
+ const container = '#micro-button-root';
16
+
17
+ const render = (props) => {
18
+ const { containerId } = props || {}
19
+ vms[containerId] = new Vue({
20
+ data: {
21
+ masterProps: props || {}
22
+ },
23
+ render: h => h(App),
24
+ }).$mount(containerId ? `#${containerId} ${container}` : container)
25
+ }
26
+
27
+ if (poweredByMaxelms) {
28
+ registerPlugin({
29
+ mount(props) {
30
+ render(props)
31
+ },
32
+ update(props) {
33
+ if (vms[props.containerId]) {
34
+ vms[props.containerId].masterProps = props
35
+ }
36
+ },
37
+ unmount(props) {
38
+ vms[props.containerId]?.$destroy?.()
39
+ vms[props.containerId] = null
40
+ }
41
+ });
42
+ } else {
43
+ render()
44
+ }
@@ -0,0 +1,51 @@
1
+ const path = require('path');
2
+ const CopyWebpackPlugin = require('copy-webpack-plugin');
3
+
4
+ module.exports = {
5
+ pages: {
6
+ index: {
7
+ entry: "src/main.js",
8
+ template: "public/index.html",
9
+ filename: "index.html",
10
+ title: "Maxelms Plugin",
11
+ },
12
+ <% if (configurationType === 'html') {%>
13
+ configuration: {
14
+ entry: "configuration/main.js",
15
+ template: "public/configuration.html",
16
+ filename: "configuration.html",
17
+ title: "Maxelms Plugin Configurations",
18
+ },
19
+ <% } %>
20
+ },
21
+ publicPath: './',
22
+ css: {
23
+ extract: true,
24
+ },
25
+ productionSourceMap: false,
26
+ devServer: {
27
+ headers: {
28
+ "Access-Control-Allow-Origin": "*",
29
+ },
30
+ port: 8080,
31
+ // open: ['/', '/playground.html'],
32
+ // contentBase: path.join(__dirname, 'examples/'),
33
+ },
34
+ chainWebpack: (config) => {
35
+ config.module
36
+ .rule('fonts')
37
+ .test(/.(ttf|otf|eot|woff|woff2)$/)
38
+ .use('url-loader')
39
+ .loader('url-loader')
40
+ .tap(() => ({ name: '/fonts/[name].[hash:8].[ext]' }))
41
+ .end()
42
+ },
43
+ configureWebpack: {
44
+ plugins: [
45
+ new CopyWebpackPlugin([
46
+ { from: 'README.md' },
47
+ { from: 'manifest.json' },
48
+ ]),
49
+ ]
50
+ },
51
+ };
@@ -0,0 +1,23 @@
1
+ # See https://help.github.com/articles/ignoring-files/ for more about ignoring files.
2
+
3
+ # dependencies
4
+ /node_modules
5
+ /npm-debug.log*
6
+ /yarn-error.log
7
+ /yarn.lock
8
+ /package-lock.json
9
+
10
+ # production
11
+ /dist
12
+
13
+ # misc
14
+ .DS_Store
15
+
16
+ # umi
17
+ /src/.umi
18
+ /src/.umi-production
19
+ /src/.umi-test
20
+ /.env.local
21
+ /dist.maxplugin
22
+ /dist.zip
23
+ /.vscode
@@ -0,0 +1,5 @@
1
+ # Maxelms Custom Field
2
+
3
+ ## 功能介绍
4
+
5
+ ## 使用说明
@@ -0,0 +1,8 @@
1
+ module.exports = {
2
+ presets: [
3
+ '@vue/cli-plugin-babel/preset'
4
+ ],
5
+ plugins: [
6
+ '@babel/plugin-proposal-optional-chaining'
7
+ ]
8
+ }
@@ -0,0 +1,78 @@
1
+ <template>
2
+ <el-form label-position="top" :model="form">
3
+ <el-form-item label="是否禁用">
4
+ <el-switch v-model="form.disabled"></el-switch>
5
+ </el-form-item>
6
+ <el-form-item label="最大长度">
7
+ <el-input-number v-model="form.maxLength"></el-input-number>
8
+ </el-form-item>
9
+ <el-form-item label="控件大小">
10
+ <el-select v-model="form.size">
11
+ <el-option label="small" value="small"></el-option>
12
+ <el-option label="default" value="default"></el-option>
13
+ <el-option label="large" value="large"></el-option>
14
+ </el-select>
15
+ </el-form-item>
16
+ <el-form-item label="占位符">
17
+ <el-input v-model="form.placeholder"></el-input>
18
+ </el-form-item>
19
+ <el-form-item label="label">
20
+ <el-input v-model="form.label"></el-input>
21
+ </el-form-item>
22
+ </el-form>
23
+ </template>
24
+
25
+ <script>
26
+ import { PluginChannel } from '@max-kit/max-api'
27
+
28
+ export default {
29
+ name: 'App',
30
+ data() {
31
+ return {
32
+ form: {
33
+ size: 'default',
34
+ disabled: false,
35
+ placeholder: '',
36
+ maxLength: 1,
37
+ label: '',
38
+ },
39
+ pluginChannel: null
40
+ };
41
+ },
42
+ mounted() {
43
+ this.pluginChannel = new PluginChannel({
44
+ init: this.initConfigs
45
+ })
46
+ },
47
+ beforeDestroy() {
48
+ this.pluginChannel && this.pluginChannel.destroy()
49
+ },
50
+ methods: {
51
+ initConfigs (configs) {
52
+ if (!configs || typeof configs !== 'object') return
53
+ this.form = {
54
+ ...this.form,
55
+ ...configs
56
+ }
57
+ }
58
+ },
59
+ watch: {
60
+ // 表单变化是,提交配置信息
61
+ form: {
62
+ handler() {
63
+ const config = { ...this.form };
64
+ this.pluginChannel.update(config);
65
+ },
66
+ deep: true,
67
+ },
68
+ },
69
+ }
70
+ </script>
71
+
72
+ <style lang="scss">
73
+ #app {
74
+ font-family: Avenir, Helvetica, Arial, sans-serif;
75
+ -webkit-font-smoothing: antialiased;
76
+ -moz-osx-font-smoothing: grayscale;
77
+ }
78
+ </style>
@@ -0,0 +1,11 @@
1
+
2
+ import Vue from 'vue'
3
+ import App from './App.vue'
4
+ import ElementUI from 'element-ui';
5
+ import 'element-ui/lib/theme-chalk/index.css';
6
+
7
+ Vue.use(ElementUI);
8
+
9
+ new Vue({
10
+ render: h => h(App),
11
+ }).$mount('#root')
@@ -0,0 +1,7 @@
1
+ {
2
+ "configurationType": "<%= configurationType %>",
3
+ "fieldTypes": ["TEXT"],
4
+ "deviceTypes": ["mobile", "pc"],
5
+ "bizTypes": ["standard-object", "cform", "approval"],
6
+ "slotTypes": ["table-cell", "form-item"]
7
+ }
@@ -0,0 +1,53 @@
1
+ {
2
+ "name": "<%= pluginName %>",
3
+ "version": "0.1.0",
4
+ "private": true,
5
+ "scripts": {
6
+ "serve": "vue-cli-service serve",
7
+ "start": "vue-cli-service serve",
8
+ "build": "vue-cli-service build && maxelms-plugin-cli -c",
9
+ "lint": "vue-cli-service lint"
10
+ },
11
+ "dependencies": {
12
+ "@max-kit/max-api": "1.0.1",
13
+ "core-js": "3.6.5",
14
+ "element-ui": "2.15.6",
15
+ "vue": "2.6.11"
16
+ },
17
+ "devDependencies": {
18
+ "@maxelms/create-plugin-cli": "<%= cliVersion %>",
19
+ "@vue/cli-plugin-babel": "4.5.0",
20
+ "@vue/cli-plugin-eslint": "4.5.0",
21
+ "@vue/cli-service": "4.5.0",
22
+ "archiver": "5.3.1",
23
+ "babel-eslint": "10.1.0",
24
+ "copy-webpack-plugin": "5.1.1",
25
+ "less": "4.1.3",
26
+ "less-loader": "5.0.0",
27
+ "eslint": "6.7.2",
28
+ "eslint-plugin-vue": "6.2.2",
29
+ "sass": "1.47.0",
30
+ "sass-loader": "8.0.2",
31
+ "url-loader": "2.2.0",
32
+ "vue-template-compiler": "2.6.11"
33
+ },
34
+ "eslintConfig": {
35
+ "root": true,
36
+ "env": {
37
+ "node": true
38
+ },
39
+ "extends": [
40
+ "plugin:vue/essential",
41
+ "eslint:recommended"
42
+ ],
43
+ "parserOptions": {
44
+ "parser": "babel-eslint"
45
+ },
46
+ "rules": {}
47
+ },
48
+ "browserslist": [
49
+ "> 1%",
50
+ "last 2 versions",
51
+ "not dead"
52
+ ]
53
+ }
@@ -0,0 +1,30 @@
1
+ {
2
+ "propName1": {
3
+ "label": "配置项一",
4
+ "type": "string",
5
+ "defaultValue": "配置项内容"
6
+ },
7
+ "propName2": {
8
+ "label": "配置项二",
9
+ "type": "number",
10
+ "defaultValue": 350
11
+ },
12
+ "propName3": {
13
+ "label": "配置项三",
14
+ "type": "select",
15
+ "options": [
16
+ {
17
+ "label": "选项1",
18
+ "value": "option1"
19
+ },
20
+ {
21
+ "label": "选项2",
22
+ "value": "option2"
23
+ },
24
+ {
25
+ "label": "选项3",
26
+ "value": "option3"
27
+ }
28
+ ]
29
+ }
30
+ }
@@ -0,0 +1,10 @@
1
+ <!DOCTYPE html>
2
+ <html>
3
+ <head>
4
+ <meta charset="utf-8" />
5
+ <title>Maxelms 字段组件</title>
6
+ </head>
7
+ <body>
8
+ <div id="root"></div>
9
+ </body>
10
+ </html>
@@ -0,0 +1,30 @@
1
+ {
2
+ "propName1": {
3
+ "label": "配置项一",
4
+ "type": "string",
5
+ "defaultValue": "配置项内容"
6
+ },
7
+ "propName2": {
8
+ "label": "配置项二",
9
+ "type": "number",
10
+ "defaultValue": 350
11
+ },
12
+ "propName3": {
13
+ "label": "配置项三",
14
+ "type": "select",
15
+ "options": [
16
+ {
17
+ "label": "选项1",
18
+ "value": "option1"
19
+ },
20
+ {
21
+ "label": "选项2",
22
+ "value": "option2"
23
+ },
24
+ {
25
+ "label": "选项3",
26
+ "value": "option3"
27
+ }
28
+ ]
29
+ }
30
+ }
@@ -0,0 +1,10 @@
1
+ <!DOCTYPE html>
2
+ <html>
3
+ <head>
4
+ <meta charset="utf-8" />
5
+ <title>Maxelms 字段组件</title>
6
+ </head>
7
+ <body>
8
+ <div id="root"></div>
9
+ </body>
10
+ </html>
@@ -0,0 +1,32 @@
1
+ const fs = require('fs');
2
+ const archiver = require('archiver');
3
+
4
+ const distDir = 'dist'
5
+ if (fs.existsSync(distDir)) {
6
+ if (fs.existsSync('dist.maxplugin')) {
7
+ fs.unlinkSync('dist.maxplugin')
8
+ }
9
+
10
+ const output = fs.createWriteStream('dist.maxplugin');
11
+ const archive = archiver('zip', {
12
+ zlib: { level: 9 }
13
+ });
14
+
15
+ output.on('close', function() {
16
+ console.log('Compress completed!');
17
+ });
18
+
19
+ archive.on('error', function(err) {
20
+ console.log('Compress failed!');
21
+ throw err;
22
+ });
23
+
24
+ archive.pipe(output);
25
+
26
+
27
+ archive.directory('dist/', 'dist');
28
+
29
+ archive.finalize();
30
+ } else {
31
+ console.log('No dist directory found!');
32
+ }
@@ -0,0 +1,55 @@
1
+ <template>
2
+ <div>
3
+ <div class="maxelms-customize-component-<%= timestamp %>">
4
+ <input
5
+ :style="{width: `${width}px`}"
6
+ :value="value"
7
+ :disabled="disabled"
8
+ :placeholder="placeholder"
9
+ @input="change"
10
+ />
11
+ </div>
12
+ </div>
13
+ </template>
14
+
15
+ <script>
16
+
17
+ export default {
18
+ name: 'App',
19
+ components: {
20
+ },
21
+ methods: {
22
+ change(e) {
23
+ this.onChange && this.onChange({
24
+ text: null,
25
+ value: e.target.value
26
+ })
27
+ }
28
+ },
29
+ computed: {
30
+ /** value、onChange 是字段组件作为表单受控组件的必要属性 */
31
+ value () {
32
+ return this.$root?.masterProps?.value?.value || "欢迎使用 Maxelms 字段组件"
33
+ },
34
+ onChange () {
35
+ return this.$root?.masterProps?.onChange
36
+ },
37
+ /** 是否禁用 */
38
+ disabled () {
39
+ return this.$root?.masterProps?.configurations?.propName3
40
+ },
41
+ /** 控件宽度 */
42
+ width () {
43
+ return this.$root?.masterProps?.configurations?.propName2 || 350
44
+ },
45
+ /** 提示文本 */
46
+ placeholder () {
47
+ return this.$root?.masterProps?.configurations?.propName1
48
+ },
49
+ },
50
+ }
51
+ </script>
52
+
53
+ <style lang="less">
54
+ @import "./style.less";
55
+ </style>
@@ -0,0 +1,38 @@
1
+ import Vue from 'vue'
2
+ import { registerPlugin, poweredByMaxelms } from '@max-kit/max-api'
3
+ import App from './App.vue'
4
+
5
+ Vue.config.productionTip = false
6
+
7
+ window.__SINGLETON_MODE__ = true
8
+
9
+ const vms = {}
10
+
11
+ const render = (props) => {
12
+ const { containerId } = props || {}
13
+ vms[containerId] = new Vue({
14
+ data: {
15
+ masterProps: props || {}
16
+ },
17
+ render: h => h(App),
18
+ }).$mount(containerId ? `#${containerId} #root` : '#root')
19
+ }
20
+
21
+ if (poweredByMaxelms) {
22
+ registerPlugin({
23
+ mount(props) {
24
+ render(props)
25
+ },
26
+ update(props) {
27
+ if (vms[props.containerId]) {
28
+ vms[props.containerId].masterProps = props
29
+ }
30
+ },
31
+ unmount(props) {
32
+ vms[props.containerId]?.$destroy?.()
33
+ vms[props.containerId] = null
34
+ }
35
+ });
36
+ } else {
37
+ render()
38
+ }
@@ -0,0 +1,16 @@
1
+
2
+ @prefixCls: maxelms-customize-component-<%= timestamp %>;
3
+
4
+ .@{prefixCls} {
5
+ display: flex;
6
+ align-items: center;
7
+ justify-content: center;
8
+ flex-direction: column;
9
+ input {
10
+ width: 300px;
11
+ text-align: center;
12
+ }
13
+ img {
14
+ width: 350px;
15
+ }
16
+ }
@@ -0,0 +1,51 @@
1
+ const path = require('path');
2
+ const CopyWebpackPlugin = require('copy-webpack-plugin');
3
+
4
+ module.exports = {
5
+ pages: {
6
+ index: {
7
+ entry: "src/main.js",
8
+ template: "public/index.html",
9
+ filename: "index.html",
10
+ title: "Maxelms Plugin",
11
+ },
12
+ <% if (configurationType === 'html') {%>
13
+ configuration: {
14
+ entry: "configuration/main.js",
15
+ template: "public/configuration.html",
16
+ filename: "configuration.html",
17
+ title: "Maxelms Plugin Configurations",
18
+ },
19
+ <% } %>
20
+ },
21
+ publicPath: './',
22
+ css: {
23
+ extract: true,
24
+ },
25
+ productionSourceMap: false,
26
+ devServer: {
27
+ headers: {
28
+ "Access-Control-Allow-Origin": "*",
29
+ },
30
+ port: 8080,
31
+ open: ['/', '/playground.html'],
32
+ contentBase: path.join(__dirname, 'examples/'),
33
+ },
34
+ chainWebpack: (config) => {
35
+ config.module
36
+ .rule('fonts')
37
+ .test(/.(ttf|otf|eot|woff|woff2)$/)
38
+ .use('url-loader')
39
+ .loader('url-loader')
40
+ .tap(() => ({ name: '/fonts/[name].[hash:8].[ext]' }))
41
+ .end()
42
+ },
43
+ configureWebpack: {
44
+ plugins: [
45
+ new CopyWebpackPlugin([
46
+ { from: 'README.md' },
47
+ { from: 'manifest.json' },
48
+ ]),
49
+ ]
50
+ },
51
+ };
@@ -0,0 +1,23 @@
1
+ # See https://help.github.com/articles/ignoring-files/ for more about ignoring files.
2
+
3
+ # dependencies
4
+ /node_modules
5
+ /npm-debug.log*
6
+ /yarn-error.log
7
+ /yarn.lock
8
+ /package-lock.json
9
+
10
+ # production
11
+ /dist
12
+
13
+ # misc
14
+ .DS_Store
15
+
16
+ # umi
17
+ /src/.umi
18
+ /src/.umi-production
19
+ /src/.umi-test
20
+ /.env.local
21
+ /dist.maxplugin
22
+ /dist.zip
23
+ /.vscode
@@ -0,0 +1,24 @@
1
+ # vue-p2
2
+
3
+ ## Project setup
4
+ ```
5
+ pnpm install
6
+ ```
7
+
8
+ ### Compiles and hot-reloads for development
9
+ ```
10
+ pnpm run serve
11
+ ```
12
+
13
+ ### Compiles and minifies for production
14
+ ```
15
+ pnpm run build
16
+ ```
17
+
18
+ ### Lints and fixes files
19
+ ```
20
+ pnpm run lint
21
+ ```
22
+
23
+ ### Customize configuration
24
+ See [Configuration Reference](https://cli.vuejs.org/config/).
@@ -0,0 +1,8 @@
1
+ module.exports = {
2
+ presets: [
3
+ '@vue/cli-plugin-babel/preset'
4
+ ],
5
+ plugins: [
6
+ '@babel/plugin-proposal-optional-chaining'
7
+ ]
8
+ }