ylyx-cli 1.0.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.
- package/README.md +184 -0
- package/bin/ylyx.js +95 -0
- package/lib/generator.js +192 -0
- package/lib/index.js +113 -0
- package/lib/interactive.js +87 -0
- package/lib/remote.js +179 -0
- package/lib/template.js +174 -0
- package/lib/utils.js +134 -0
- package/package.json +56 -0
- package/templates/react-app/files/README.md +23 -0
- package/templates/react-app/files/package.json +29 -0
- package/templates/react-app/files/public/index.html +11 -0
- package/templates/react-app/files/src/App.css +15 -0
- package/templates/react-app/files/src/App.js +15 -0
- package/templates/react-app/files/src/index.css +10 -0
- package/templates/react-app/files/src/index.js +11 -0
- package/templates/react-app/template.json +12 -0
- package/templates/react-component/files/Component.module.css +5 -0
- package/templates/react-component/files/Component.tsx +31 -0
- package/templates/react-component/files/index.ts +2 -0
- package/templates/react-component/template.json +49 -0
- package/templates/vue-app/files/.editorconfig +14 -0
- package/templates/vue-app/files/.env.development +21 -0
- package/templates/vue-app/files/.env.production +18 -0
- package/templates/vue-app/files/.eslintignore +5 -0
- package/templates/vue-app/files/.eslintrc.js +267 -0
- package/templates/vue-app/files/.prettierignore +12 -0
- package/templates/vue-app/files/.travis.yml +5 -0
- package/templates/vue-app/files/.vscode/extensions.json +7 -0
- package/templates/vue-app/files/.vscode/settings.json +39 -0
- package/templates/vue-app/files/LICENSE +191 -0
- package/templates/vue-app/files/README.md +87 -0
- package/templates/vue-app/files/babel.config.js +11 -0
- package/templates/vue-app/files/jest.config.js +24 -0
- package/templates/vue-app/files/package.json +136 -0
- package/templates/vue-app/files/plopfile.js +7 -0
- package/templates/vue-app/files/postcss.config.js +5 -0
- package/templates/vue-app/files/prettier.config.js +36 -0
- package/templates/vue-app/files/public/default.js +26 -0
- package/templates/vue-app/files/public/favicon.ico +0 -0
- package/templates/vue-app/files/public/index.html +26 -0
- package/templates/vue-app/files/src/App.vue +54 -0
- package/templates/vue-app/files/src/api/bigDataV/index.js +198 -0
- package/templates/vue-app/files/src/api/data.js +42 -0
- package/templates/vue-app/files/src/api/dataArchive/index.js +186 -0
- package/templates/vue-app/files/src/api/generator/genConfig.js +16 -0
- package/templates/vue-app/files/src/api/generator/generator.js +32 -0
- package/templates/vue-app/files/src/api/indexManagement/index.js +39 -0
- package/templates/vue-app/files/src/api/institutionMonitor/index.js +396 -0
- package/templates/vue-app/files/src/api/institutionSet/index.js +120 -0
- package/templates/vue-app/files/src/api/login.js +44 -0
- package/templates/vue-app/files/src/api/selfStatistics/index.js +50 -0
- package/templates/vue-app/files/src/api/system/code.js +15 -0
- package/templates/vue-app/files/src/api/system/dict.js +34 -0
- package/templates/vue-app/files/src/api/system/dictDetail.js +52 -0
- package/templates/vue-app/files/src/api/system/equipment.js +35 -0
- package/templates/vue-app/files/src/api/system/examManage.js +49 -0
- package/templates/vue-app/files/src/api/system/examProject.js +48 -0
- package/templates/vue-app/files/src/api/system/hosModel.js +35 -0
- package/templates/vue-app/files/src/api/system/hospital.js +88 -0
- package/templates/vue-app/files/src/api/system/job.js +40 -0
- package/templates/vue-app/files/src/api/system/menu.js +67 -0
- package/templates/vue-app/files/src/api/system/model.js +42 -0
- package/templates/vue-app/files/src/api/system/risConfig.js +9 -0
- package/templates/vue-app/files/src/api/system/role.js +64 -0
- package/templates/vue-app/files/src/api/system/sysSet.js +19 -0
- package/templates/vue-app/files/src/api/system/timing.js +41 -0
- package/templates/vue-app/files/src/api/system/user.js +121 -0
- package/templates/vue-app/files/src/api/tools/alipay.js +25 -0
- package/templates/vue-app/files/src/api/tools/email.js +24 -0
- package/templates/vue-app/files/src/api/tools/localStorage.js +27 -0
- package/templates/vue-app/files/src/api/tools/qiniu.js +40 -0
- package/templates/vue-app/files/src/assets/401_images/401.gif +0 -0
- package/templates/vue-app/files/src/assets/404_images/404.png +0 -0
- package/templates/vue-app/files/src/assets/404_images/404_cloud.png +0 -0
- package/templates/vue-app/files/src/assets/css/font-awesome.css +2342 -0
- package/templates/vue-app/files/src/assets/css/font-awesome.min.css +2336 -0
- package/templates/vue-app/files/src/assets/fonts/FontAwesome.otf +0 -0
- package/templates/vue-app/files/src/assets/fonts/fontawesome-webfont.eot +0 -0
- package/templates/vue-app/files/src/assets/fonts/fontawesome-webfont.svg +2671 -0
- package/templates/vue-app/files/src/assets/fonts/fontawesome-webfont.ttf +0 -0
- package/templates/vue-app/files/src/assets/fonts/fontawesome-webfont.woff +0 -0
- package/templates/vue-app/files/src/assets/fonts/fontawesome-webfont.woff2 +0 -0
- package/templates/vue-app/files/src/assets/icons/index.js +9 -0
- package/templates/vue-app/files/src/assets/icons/svg/Steve-Jobs.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/achive.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/alipay.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/anq.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/app.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/archive.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/backup.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/chain.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/chart.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/codeConsole.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/dashboard.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/database.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/date.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/deploy.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/dept.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/dev.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/develop.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/dictionary.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/doc.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/download.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/edit.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/education.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/email.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/equSet.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/error.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/exit-fullscreen.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/fullscreen.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/fwb.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/github.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/goBack.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/gonggao.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/hospital.svg +2 -0
- package/templates/vue-app/files/src/assets/icons/svg/hospital1.svg +2 -0
- package/templates/vue-app/files/src/assets/icons/svg/hospitalTotal.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/icon.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/image.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/index.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/international.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/ipvisits.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/java.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/link.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/list.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/lock.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/log.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/login.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/loginOne.svg +35 -0
- package/templates/vue-app/files/src/assets/icons/svg/loginOneWhite.svg +19 -0
- package/templates/vue-app/files/src/assets/icons/svg/loginOr.svg +93 -0
- package/templates/vue-app/files/src/assets/icons/svg/loginUp.svg +96 -0
- package/templates/vue-app/files/src/assets/icons/svg/markdown.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/menu.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/message.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/mnt.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/money.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/monitor.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/nested.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/network.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/offline.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/online.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/password.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/people.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/peoples.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/perSet.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/permission.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/phone.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/piechart.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/qiniu.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/redis.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/resetpassword.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/resetpassword1.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/role.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/search.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/server.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/shopping.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/size.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/skill.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/source.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/sqlMonitor.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/statistical.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/swagger.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/sys-tools.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/system.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/system1.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/tab.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/teams.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/theme.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/timing.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/tools.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/tree-table.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/tree.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/unlock.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/user.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/user1.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/validCode.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/visits.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/web.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/wechat.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/weixin.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/zujian.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svgo.yml +21 -0
- package/templates/vue-app/files/src/assets/images/archive.png +0 -0
- package/templates/vue-app/files/src/assets/images/archive_icon.png +0 -0
- package/templates/vue-app/files/src/assets/images/avatar.png +0 -0
- package/templates/vue-app/files/src/assets/images/background.jpg +0 -0
- package/templates/vue-app/files/src/assets/images/bg.png +0 -0
- package/templates/vue-app/files/src/assets/images/gongan.png +0 -0
- package/templates/vue-app/files/src/assets/images/hospital_icon.png +0 -0
- package/templates/vue-app/files/src/assets/images/location.png +0 -0
- package/templates/vue-app/files/src/assets/images/logintitle.jpg +0 -0
- package/templates/vue-app/files/src/assets/images/logo-copy1.png +0 -0
- package/templates/vue-app/files/src/assets/images/logo.png +0 -0
- package/templates/vue-app/files/src/assets/images/logoBg.png +0 -0
- package/templates/vue-app/files/src/assets/images/offline-bg.png +0 -0
- package/templates/vue-app/files/src/assets/images/position.png +0 -0
- package/templates/vue-app/files/src/assets/images/qualityBg.jpg +0 -0
- package/templates/vue-app/files/src/assets/images/self-bg.png +0 -0
- package/templates/vue-app/files/src/assets/images/self-bg2.png +0 -0
- package/templates/vue-app/files/src/assets/images/triAngel.png +0 -0
- package/templates/vue-app/files/src/assets/images/triAngelNormal.png +0 -0
- package/templates/vue-app/files/src/assets/styles/btn.scss +103 -0
- package/templates/vue-app/files/src/assets/styles/eladmin.scss +124 -0
- package/templates/vue-app/files/src/assets/styles/element-ui.scss +217 -0
- package/templates/vue-app/files/src/assets/styles/element-variables.scss +31 -0
- package/templates/vue-app/files/src/assets/styles/global.scss +73 -0
- package/templates/vue-app/files/src/assets/styles/index.scss +220 -0
- package/templates/vue-app/files/src/assets/styles/mixin.scss +60 -0
- package/templates/vue-app/files/src/assets/styles/publicStyle.scss +224 -0
- package/templates/vue-app/files/src/assets/styles/sidebar.scss +239 -0
- package/templates/vue-app/files/src/assets/styles/transition.scss +48 -0
- package/templates/vue-app/files/src/assets/styles/variables.scss +44 -0
- package/templates/vue-app/files/src/common/flexible.js +145 -0
- package/templates/vue-app/files/src/components/Breadcrumb/index.vue +87 -0
- package/templates/vue-app/files/src/components/Crud/CRUD.operation.vue +248 -0
- package/templates/vue-app/files/src/components/Crud/Pagination.vue +20 -0
- package/templates/vue-app/files/src/components/Crud/RR.operation.vue +39 -0
- package/templates/vue-app/files/src/components/Crud/UD.operation.vue +106 -0
- package/templates/vue-app/files/src/components/Crud/crud.js +907 -0
- package/templates/vue-app/files/src/components/Crud/user/UR.operation.vue +154 -0
- package/templates/vue-app/files/src/components/DateRangePicker/index.vue +42 -0
- package/templates/vue-app/files/src/components/DateRangePickerProhibitNext/index.vue +42 -0
- package/templates/vue-app/files/src/components/DateRangePickerProhibitTodayNext/index.vue +48 -0
- package/templates/vue-app/files/src/components/Dict/Dict.js +31 -0
- package/templates/vue-app/files/src/components/Dict/index.js +29 -0
- package/templates/vue-app/files/src/components/Doc/index.vue +16 -0
- package/templates/vue-app/files/src/components/Echarts/BarChart.vue +115 -0
- package/templates/vue-app/files/src/components/Echarts/Category.vue +768 -0
- package/templates/vue-app/files/src/components/Echarts/Funnel.vue +120 -0
- package/templates/vue-app/files/src/components/Echarts/Gauge.vue +74 -0
- package/templates/vue-app/files/src/components/Echarts/Graph.vue +101 -0
- package/templates/vue-app/files/src/components/Echarts/HeatMap.vue +301 -0
- package/templates/vue-app/files/src/components/Echarts/Line3D.vue +110 -0
- package/templates/vue-app/files/src/components/Echarts/PieChart.vue +84 -0
- package/templates/vue-app/files/src/components/Echarts/Point.vue +161 -0
- package/templates/vue-app/files/src/components/Echarts/RadarChart.vue +123 -0
- package/templates/vue-app/files/src/components/Echarts/Rich.vue +160 -0
- package/templates/vue-app/files/src/components/Echarts/Sankey.vue +114 -0
- package/templates/vue-app/files/src/components/Echarts/Scatter.vue +192 -0
- package/templates/vue-app/files/src/components/Echarts/Sunburst.vue +127 -0
- package/templates/vue-app/files/src/components/Echarts/ThemeRiver.vue +233 -0
- package/templates/vue-app/files/src/components/Echarts/WordCloud.vue +201 -0
- package/templates/vue-app/files/src/components/GithubCorner/index.vue +55 -0
- package/templates/vue-app/files/src/components/Hamburger/index.vue +44 -0
- package/templates/vue-app/files/src/components/HeaderSearch/index.vue +196 -0
- package/templates/vue-app/files/src/components/IconSelect/index.vue +74 -0
- package/templates/vue-app/files/src/components/IconSelect/requireIcons.js +10 -0
- package/templates/vue-app/files/src/components/Iframe/index.vue +30 -0
- package/templates/vue-app/files/src/components/JavaEdit/index.vue +78 -0
- package/templates/vue-app/files/src/components/Pagination/index.vue +100 -0
- package/templates/vue-app/files/src/components/PanThumb/index.vue +149 -0
- package/templates/vue-app/files/src/components/ParentView/index.vue +3 -0
- package/templates/vue-app/files/src/components/Permission/index.js +13 -0
- package/templates/vue-app/files/src/components/Permission/permission.js +21 -0
- package/templates/vue-app/files/src/components/RightPanel/index.vue +149 -0
- package/templates/vue-app/files/src/components/Screenfull/index.vue +60 -0
- package/templates/vue-app/files/src/components/SizeSelect/index.vue +60 -0
- package/templates/vue-app/files/src/components/SvgIcon/index.vue +66 -0
- package/templates/vue-app/files/src/components/ThemePicker/index.vue +177 -0
- package/templates/vue-app/files/src/components/UploadExcel/index.vue +149 -0
- package/templates/vue-app/files/src/components/WaterMark/setWaterMark.js +68 -0
- package/templates/vue-app/files/src/components/WaterMark/waterMark.vue +69 -0
- package/templates/vue-app/files/src/components/Xgplayer/index.vue +49 -0
- package/templates/vue-app/files/src/components/YamlEdit/index.vue +81 -0
- package/templates/vue-app/files/src/layout/components/AppMain.vue +67 -0
- package/templates/vue-app/files/src/layout/components/Navbar.vue +209 -0
- package/templates/vue-app/files/src/layout/components/Settings/index.vue +125 -0
- package/templates/vue-app/files/src/layout/components/Sidebar/FixiOSBug.js +26 -0
- package/templates/vue-app/files/src/layout/components/Sidebar/Item.vue +29 -0
- package/templates/vue-app/files/src/layout/components/Sidebar/Link.vue +35 -0
- package/templates/vue-app/files/src/layout/components/Sidebar/Logo.vue +93 -0
- package/templates/vue-app/files/src/layout/components/Sidebar/SidebarItem.vue +104 -0
- package/templates/vue-app/files/src/layout/components/Sidebar/index.vue +79 -0
- package/templates/vue-app/files/src/layout/components/TagsView/ScrollPane.vue +90 -0
- package/templates/vue-app/files/src/layout/components/TagsView/index.vue +299 -0
- package/templates/vue-app/files/src/layout/components/index.js +5 -0
- package/templates/vue-app/files/src/layout/index.vue +119 -0
- package/templates/vue-app/files/src/layout/mixin/ResizeHandler.js +45 -0
- package/templates/vue-app/files/src/main.js +89 -0
- package/templates/vue-app/files/src/mixins/crud.js +348 -0
- package/templates/vue-app/files/src/router/index.js +156 -0
- package/templates/vue-app/files/src/router/routers.js +203 -0
- package/templates/vue-app/files/src/settings.js +57 -0
- package/templates/vue-app/files/src/store/getters.js +29 -0
- package/templates/vue-app/files/src/store/index.js +25 -0
- package/templates/vue-app/files/src/store/modules/api.js +33 -0
- package/templates/vue-app/files/src/store/modules/app.js +55 -0
- package/templates/vue-app/files/src/store/modules/permission.js +79 -0
- package/templates/vue-app/files/src/store/modules/register.js +17 -0
- package/templates/vue-app/files/src/store/modules/settings.js +46 -0
- package/templates/vue-app/files/src/store/modules/tagsView.js +168 -0
- package/templates/vue-app/files/src/store/modules/user.js +119 -0
- package/templates/vue-app/files/src/utils/auth.js +18 -0
- package/templates/vue-app/files/src/utils/base64ToFile.js +27 -0
- package/templates/vue-app/files/src/utils/clipboard.js +36 -0
- package/templates/vue-app/files/src/utils/datetime.js +289 -0
- package/templates/vue-app/files/src/utils/getBlobFile.js +10 -0
- package/templates/vue-app/files/src/utils/getTime.js +29 -0
- package/templates/vue-app/files/src/utils/index.js +520 -0
- package/templates/vue-app/files/src/utils/permission.js +29 -0
- package/templates/vue-app/files/src/utils/pinyin.js +450 -0
- package/templates/vue-app/files/src/utils/request.js +139 -0
- package/templates/vue-app/files/src/utils/rsaEncrypt.js +37 -0
- package/templates/vue-app/files/src/utils/shortcuts.js +210 -0
- package/templates/vue-app/files/src/utils/upload.js +12 -0
- package/templates/vue-app/files/src/utils/validate.js +262 -0
- package/templates/vue-app/files/src/views/components/Echarts.vue +124 -0
- package/templates/vue-app/files/src/views/components/Editor.vue +75 -0
- package/templates/vue-app/files/src/views/components/MarkDown.vue +44 -0
- package/templates/vue-app/files/src/views/components/UVideo.vue +37 -0
- package/templates/vue-app/files/src/views/components/YamlEdit.vue +206 -0
- package/templates/vue-app/files/src/views/components/camera/camera.vue +115 -0
- package/templates/vue-app/files/src/views/components/camera/cameraTest.vue +158 -0
- package/templates/vue-app/files/src/views/components/excel/upload-excel.vue +41 -0
- package/templates/vue-app/files/src/views/components/icons/element-icons.js +74 -0
- package/templates/vue-app/files/src/views/components/icons/index.vue +106 -0
- package/templates/vue-app/files/src/views/components/icons/svg-icons.js +10 -0
- package/templates/vue-app/files/src/views/components/scroll/index.vue +107 -0
- package/templates/vue-app/files/src/views/components/scrollFull/index.vue +99 -0
- package/templates/vue-app/files/src/views/dashboard/LineChart.vue +138 -0
- package/templates/vue-app/files/src/views/dashboard/PanelGroup.vue +173 -0
- package/templates/vue-app/files/src/views/dashboard/mixins/resize.js +57 -0
- package/templates/vue-app/files/src/views/dataArchive/delTable.vue +354 -0
- package/templates/vue-app/files/src/views/dataArchive/exportDetail.vue +121 -0
- package/templates/vue-app/files/src/views/dataArchive/exportList.vue +160 -0
- package/templates/vue-app/files/src/views/dataArchive/index.vue +2104 -0
- package/templates/vue-app/files/src/views/features/401.vue +83 -0
- package/templates/vue-app/files/src/views/features/404.vue +226 -0
- package/templates/vue-app/files/src/views/features/redirect.vue +12 -0
- package/templates/vue-app/files/src/views/generator/config.vue +348 -0
- package/templates/vue-app/files/src/views/generator/index.vue +143 -0
- package/templates/vue-app/files/src/views/generator/preview.vue +39 -0
- package/templates/vue-app/files/src/views/home.vue +80 -0
- package/templates/vue-app/files/src/views/indexManagement/index.vue +422 -0
- package/templates/vue-app/files/src/views/indexManagement/other.vue +286 -0
- package/templates/vue-app/files/src/views/institutionMonitor/components/LineChart.vue +191 -0
- package/templates/vue-app/files/src/views/institutionMonitor/index.scss +339 -0
- package/templates/vue-app/files/src/views/institutionMonitor/index.vue +1385 -0
- package/templates/vue-app/files/src/views/institutionMonitor/mixins/resize.js +57 -0
- package/templates/vue-app/files/src/views/institutionMonitor/monitorDetail/checkProjectCode.vue +267 -0
- package/templates/vue-app/files/src/views/institutionMonitor/monitorDetail/imageAbnormalMonitor.vue +361 -0
- package/templates/vue-app/files/src/views/institutionMonitor/monitorDetail/index.vue +686 -0
- package/templates/vue-app/files/src/views/institutionMonitor/monitorDetail/leakageAnomaly.vue +270 -0
- package/templates/vue-app/files/src/views/institutionMonitor/monitorDetail/moveMonitore.vue +114 -0
- package/templates/vue-app/files/src/views/institutionMonitor/monitorDetail/qualityMonitore.vue +338 -0
- package/templates/vue-app/files/src/views/institutionSet/cloudSet.vue +534 -0
- package/templates/vue-app/files/src/views/institutionSet/index.vue +2550 -0
- package/templates/vue-app/files/src/views/login.vue +243 -0
- package/templates/vue-app/files/src/views/qualityLogin.vue +280 -0
- package/templates/vue-app/files/src/views/selfStatistics/components/LineChart.vue +296 -0
- package/templates/vue-app/files/src/views/selfStatistics/hospitalDetail/index.vue +533 -0
- package/templates/vue-app/files/src/views/selfStatistics/index.scss +447 -0
- package/templates/vue-app/files/src/views/selfStatistics/index.vue +903 -0
- package/templates/vue-app/files/src/views/selfStatistics/mixins/resize.js +57 -0
- package/templates/vue-app/files/src/views/selfStatistics/monitorDetail/index.vue +285 -0
- package/templates/vue-app/files/src/views/selfStatistics/offlineDetail/index.vue +104 -0
- package/templates/vue-app/files/src/views/selfStatistics/selfActiveDetail/index.vue +104 -0
- package/templates/vue-app/files/src/views/selfStatistics/selfMonitorDetail/index.vue +420 -0
- package/templates/vue-app/files/src/views/selfStatistics/setWaterMark/setWaterMark.js +68 -0
- package/templates/vue-app/files/src/views/selfStatistics/setWaterMark/waterMark.vue +69 -0
- package/templates/vue-app/files/src/views/system/dept/index.vue +144 -0
- package/templates/vue-app/files/src/views/system/dict/dictDetail.vue +146 -0
- package/templates/vue-app/files/src/views/system/dict/index.vue +159 -0
- package/templates/vue-app/files/src/views/system/examModality/index.vue +174 -0
- package/templates/vue-app/files/src/views/system/examPart/index.vue +184 -0
- package/templates/vue-app/files/src/views/system/examProject/index.vue +321 -0
- package/templates/vue-app/files/src/views/system/examine/index.vue +66 -0
- package/templates/vue-app/files/src/views/system/job/index.vue +119 -0
- package/templates/vue-app/files/src/views/system/job/module/form.vue +72 -0
- package/templates/vue-app/files/src/views/system/job/module/header.vue +48 -0
- package/templates/vue-app/files/src/views/system/menu/index.vue +327 -0
- package/templates/vue-app/files/src/views/system/model/index.vue +285 -0
- package/templates/vue-app/files/src/views/system/role/index.vue +434 -0
- package/templates/vue-app/files/src/views/system/sysSet/index.vue +84 -0
- package/templates/vue-app/files/src/views/system/timing/index.vue +289 -0
- package/templates/vue-app/files/src/views/system/timing/log.vue +143 -0
- package/templates/vue-app/files/src/views/system/user/admin.vue +414 -0
- package/templates/vue-app/files/src/views/system/user/center/updateEmail.vue +146 -0
- package/templates/vue-app/files/src/views/system/user/center/updatePass.vue +168 -0
- package/templates/vue-app/files/src/views/system/user/center.vue +140 -0
- package/templates/vue-app/files/src/views/system/user/index.vue +972 -0
- package/templates/vue-app/files/src/views/systemSet/role/index.vue +314 -0
- package/templates/vue-app/files/src/views/systemSet/user/admin.vue +414 -0
- package/templates/vue-app/files/src/views/systemSet/user/center/updateEmail.vue +146 -0
- package/templates/vue-app/files/src/views/systemSet/user/center/updatePass.vue +115 -0
- package/templates/vue-app/files/src/views/systemSet/user/center.vue +351 -0
- package/templates/vue-app/files/src/views/systemSet/user/index.vue +928 -0
- package/templates/vue-app/files/src/views/tools/aliPay/config.vue +102 -0
- package/templates/vue-app/files/src/views/tools/aliPay/index.vue +48 -0
- package/templates/vue-app/files/src/views/tools/aliPay/toPay.vue +91 -0
- package/templates/vue-app/files/src/views/tools/email/config.vue +91 -0
- package/templates/vue-app/files/src/views/tools/email/index.vue +42 -0
- package/templates/vue-app/files/src/views/tools/email/send.vue +159 -0
- package/templates/vue-app/files/src/views/tools/storage/index.vue +35 -0
- package/templates/vue-app/files/src/views/tools/storage/local/index.vue +207 -0
- package/templates/vue-app/files/src/views/tools/storage/qiniu/form.vue +108 -0
- package/templates/vue-app/files/src/views/tools/storage/qiniu/index.vue +241 -0
- package/templates/vue-app/files/src/views/tools/swagger/index.vue +14 -0
- package/templates/vue-app/files/vue.config.js +173 -0
- package/templates/vue-app/template.json +30 -0
package/README.md
ADDED
|
@@ -0,0 +1,184 @@
|
|
|
1
|
+
# YLYX CLI - 项目脚手架工具
|
|
2
|
+
|
|
3
|
+
公司内部使用的项目脚手架工具,快速生成项目初始结构和代码模板。
|
|
4
|
+
|
|
5
|
+
## 功能特性
|
|
6
|
+
|
|
7
|
+
- 🚀 快速生成项目代码
|
|
8
|
+
- 📦 模板化管理,易于维护和扩展
|
|
9
|
+
- ⚙️ 支持自定义变量和配置
|
|
10
|
+
- ☁️ 支持云端模板(GitHub/GitLab)
|
|
11
|
+
- 📝 交互式命令行界面
|
|
12
|
+
|
|
13
|
+
## 安装
|
|
14
|
+
|
|
15
|
+
### 全局安装
|
|
16
|
+
|
|
17
|
+
```bash
|
|
18
|
+
npm install -g @ylyx/cli
|
|
19
|
+
```
|
|
20
|
+
|
|
21
|
+
### 使用 npx(推荐,无需安装)
|
|
22
|
+
|
|
23
|
+
```bash
|
|
24
|
+
# 使用 npx 直接运行
|
|
25
|
+
npx @ylyx/cli create
|
|
26
|
+
|
|
27
|
+
# 生成项目
|
|
28
|
+
npx @ylyx/cli generate react-app -n my-project -o ./my-project
|
|
29
|
+
|
|
30
|
+
# 安装远程模板
|
|
31
|
+
npx @ylyx/cli install owner/repo
|
|
32
|
+
```
|
|
33
|
+
|
|
34
|
+
### 本地开发
|
|
35
|
+
|
|
36
|
+
```bash
|
|
37
|
+
git clone <repository>
|
|
38
|
+
cd ylyx-cli
|
|
39
|
+
npm install
|
|
40
|
+
npm link # 链接到全局,可以本地测试
|
|
41
|
+
```
|
|
42
|
+
|
|
43
|
+
## 使用方法
|
|
44
|
+
|
|
45
|
+
### 快速开始
|
|
46
|
+
|
|
47
|
+
使用交互式方式创建新项目(推荐):
|
|
48
|
+
|
|
49
|
+
```bash
|
|
50
|
+
ylyx create
|
|
51
|
+
```
|
|
52
|
+
|
|
53
|
+
或者直接指定模板和项目名:
|
|
54
|
+
|
|
55
|
+
```bash
|
|
56
|
+
# 创建一个 React 项目
|
|
57
|
+
ylyx generate react-app -n my-project -o ./my-project
|
|
58
|
+
```
|
|
59
|
+
|
|
60
|
+
### 查看可用模板
|
|
61
|
+
|
|
62
|
+
```bash
|
|
63
|
+
ylyx list
|
|
64
|
+
```
|
|
65
|
+
|
|
66
|
+
### 安装远程模板
|
|
67
|
+
|
|
68
|
+
从 GitHub/GitLab 安装模板:
|
|
69
|
+
|
|
70
|
+
```bash
|
|
71
|
+
# 使用简写格式(GitHub)
|
|
72
|
+
ylyx install owner/repo
|
|
73
|
+
|
|
74
|
+
# 使用完整 URL
|
|
75
|
+
ylyx install https://github.com/owner/repo
|
|
76
|
+
|
|
77
|
+
# 指定分支和模板名
|
|
78
|
+
ylyx install owner/repo -b develop -n my-template
|
|
79
|
+
```
|
|
80
|
+
|
|
81
|
+
### 添加本地模板
|
|
82
|
+
|
|
83
|
+
```bash
|
|
84
|
+
ylyx add template-name /path/to/template
|
|
85
|
+
```
|
|
86
|
+
|
|
87
|
+
### 查看模板详情
|
|
88
|
+
|
|
89
|
+
```bash
|
|
90
|
+
ylyx info template-name
|
|
91
|
+
```
|
|
92
|
+
|
|
93
|
+
## 云端模板
|
|
94
|
+
|
|
95
|
+
模板可以放在 Git 仓库中(如 GitHub、GitLab),使用 `ylyx install` 命令安装。
|
|
96
|
+
|
|
97
|
+
### 模板仓库要求
|
|
98
|
+
|
|
99
|
+
模板仓库需要包含以下结构:
|
|
100
|
+
|
|
101
|
+
```
|
|
102
|
+
your-template/
|
|
103
|
+
template.json # 模板配置文件(可选)
|
|
104
|
+
files/ # 模板文件目录
|
|
105
|
+
...
|
|
106
|
+
```
|
|
107
|
+
|
|
108
|
+
### 示例
|
|
109
|
+
|
|
110
|
+
```bash
|
|
111
|
+
# 从 GitHub 安装模板
|
|
112
|
+
ylyx install github-user/react-template
|
|
113
|
+
|
|
114
|
+
# 从私有仓库安装(需要配置 SSH 密钥)
|
|
115
|
+
ylyx install git@github.com:company/templates.git
|
|
116
|
+
|
|
117
|
+
# 指定分支
|
|
118
|
+
ylyx install owner/repo -b v2.0
|
|
119
|
+
```
|
|
120
|
+
|
|
121
|
+
## 模板配置
|
|
122
|
+
|
|
123
|
+
模板应放在 `templates/` 目录下,结构如下:
|
|
124
|
+
|
|
125
|
+
```
|
|
126
|
+
templates/
|
|
127
|
+
template-name/
|
|
128
|
+
template.json # 模板配置文件
|
|
129
|
+
files/ # 模板文件目录
|
|
130
|
+
example.js
|
|
131
|
+
example.css
|
|
132
|
+
```
|
|
133
|
+
|
|
134
|
+
### template.json 配置示例
|
|
135
|
+
|
|
136
|
+
```json
|
|
137
|
+
{
|
|
138
|
+
"name": "template-name",
|
|
139
|
+
"description": "模板描述",
|
|
140
|
+
"version": "1.0.0",
|
|
141
|
+
"variables": {
|
|
142
|
+
"projectName": {
|
|
143
|
+
"type": "input",
|
|
144
|
+
"message": "请输入项目名称",
|
|
145
|
+
"default": "my-project"
|
|
146
|
+
}
|
|
147
|
+
},
|
|
148
|
+
"processFiles": ["package.json", "README.md", "*.json"],
|
|
149
|
+
"skipFiles": ["**/*.vue", "**/*.js"]
|
|
150
|
+
}
|
|
151
|
+
```
|
|
152
|
+
|
|
153
|
+
## 配置文件
|
|
154
|
+
|
|
155
|
+
可以在项目根目录创建 `.ylyxrc.json` 配置文件:
|
|
156
|
+
|
|
157
|
+
```json
|
|
158
|
+
{
|
|
159
|
+
"templatesDir": "./templates",
|
|
160
|
+
"outputDir": "./src",
|
|
161
|
+
"defaultVariables": {
|
|
162
|
+
"author": "Your Name",
|
|
163
|
+
"company": "YLYX"
|
|
164
|
+
}
|
|
165
|
+
}
|
|
166
|
+
```
|
|
167
|
+
|
|
168
|
+
## 示例
|
|
169
|
+
|
|
170
|
+
### 生成完整项目
|
|
171
|
+
|
|
172
|
+
```bash
|
|
173
|
+
# 生成 React 项目
|
|
174
|
+
ylyx generate react-app -n my-react-app -o ./my-react-app
|
|
175
|
+
|
|
176
|
+
# 生成后进入目录并安装依赖
|
|
177
|
+
cd my-react-app
|
|
178
|
+
npm install
|
|
179
|
+
npm start
|
|
180
|
+
```
|
|
181
|
+
|
|
182
|
+
## License
|
|
183
|
+
|
|
184
|
+
ISC
|
package/bin/ylyx.js
ADDED
|
@@ -0,0 +1,95 @@
|
|
|
1
|
+
#!/usr/bin/env node
|
|
2
|
+
|
|
3
|
+
const { program } = require('commander');
|
|
4
|
+
const { generate } = require('../lib/index');
|
|
5
|
+
const { listTemplates, getTemplateInfo, addTemplate } = require('../lib/template');
|
|
6
|
+
const { interactiveCreate } = require('../lib/interactive');
|
|
7
|
+
const pkg = require('../package.json');
|
|
8
|
+
|
|
9
|
+
program.name('ylyx').description('公司内部代码生成模板脚手架工具').version(pkg.version);
|
|
10
|
+
|
|
11
|
+
program
|
|
12
|
+
.command('create')
|
|
13
|
+
.description('交互式创建代码(推荐)')
|
|
14
|
+
.action(async () => {
|
|
15
|
+
await interactiveCreate();
|
|
16
|
+
});
|
|
17
|
+
|
|
18
|
+
program
|
|
19
|
+
.command('generate <template-name>')
|
|
20
|
+
.alias('g')
|
|
21
|
+
.description('使用指定模板生成代码')
|
|
22
|
+
.option('-o, --output <path>', '输出目录(默认:当前目录)', './')
|
|
23
|
+
.option('-n, --name <name>', '项目名称')
|
|
24
|
+
.action(async (templateName, options) => {
|
|
25
|
+
try {
|
|
26
|
+
let variables = {};
|
|
27
|
+
|
|
28
|
+
if (options.vars) {
|
|
29
|
+
try {
|
|
30
|
+
variables = JSON.parse(options.vars);
|
|
31
|
+
} catch (e) {
|
|
32
|
+
console.error('❌ 变量格式错误,请使用有效的JSON格式');
|
|
33
|
+
process.exit(1);
|
|
34
|
+
}
|
|
35
|
+
}
|
|
36
|
+
|
|
37
|
+
if (options.name) {
|
|
38
|
+
variables.projectName = options.name;
|
|
39
|
+
variables.name = options.name;
|
|
40
|
+
}
|
|
41
|
+
|
|
42
|
+
await generate(templateName, {
|
|
43
|
+
outputDir: options.output || './',
|
|
44
|
+
variables,
|
|
45
|
+
});
|
|
46
|
+
} catch (error) {
|
|
47
|
+
console.error('❌ 生成失败:', error.message);
|
|
48
|
+
process.exit(1);
|
|
49
|
+
}
|
|
50
|
+
});
|
|
51
|
+
|
|
52
|
+
program
|
|
53
|
+
.command('list')
|
|
54
|
+
.alias('ls')
|
|
55
|
+
.description('列出所有可用模板')
|
|
56
|
+
.action(() => {
|
|
57
|
+
listTemplates();
|
|
58
|
+
});
|
|
59
|
+
|
|
60
|
+
program
|
|
61
|
+
.command('info <template-name>')
|
|
62
|
+
.description('查看模板详情')
|
|
63
|
+
.action((templateName) => {
|
|
64
|
+
getTemplateInfo(templateName);
|
|
65
|
+
});
|
|
66
|
+
|
|
67
|
+
program
|
|
68
|
+
.command('add <template-name> <template-path>')
|
|
69
|
+
.description('添加本地模板')
|
|
70
|
+
.action((templateName, templatePath) => {
|
|
71
|
+
addTemplate(templateName, templatePath);
|
|
72
|
+
});
|
|
73
|
+
|
|
74
|
+
program
|
|
75
|
+
.command('install <repo-url>')
|
|
76
|
+
.alias('i')
|
|
77
|
+
.description('从 Git 仓库安装远程模板')
|
|
78
|
+
.option('-n, --name <name>', '模板名称(默认使用仓库名)')
|
|
79
|
+
.option('-b, --branch <branch>', '分支名称(默认: main)', 'main')
|
|
80
|
+
.action(async (repoUrl, options) => {
|
|
81
|
+
try {
|
|
82
|
+
const { installRemoteTemplate } = require('../lib/remote');
|
|
83
|
+
await installRemoteTemplate(repoUrl, options.branch, options.name);
|
|
84
|
+
} catch (error) {
|
|
85
|
+
console.error('❌ 安装失败:', error.message);
|
|
86
|
+
process.exit(1);
|
|
87
|
+
}
|
|
88
|
+
});
|
|
89
|
+
|
|
90
|
+
program.parse(process.argv);
|
|
91
|
+
|
|
92
|
+
// 如果没有提供任何命令,显示帮助信息
|
|
93
|
+
if (!process.argv.slice(2).length) {
|
|
94
|
+
program.outputHelp();
|
|
95
|
+
}
|
package/lib/generator.js
ADDED
|
@@ -0,0 +1,192 @@
|
|
|
1
|
+
const fs = require('fs-extra');
|
|
2
|
+
const path = require('path');
|
|
3
|
+
const handlebars = require('handlebars');
|
|
4
|
+
const glob = require('glob');
|
|
5
|
+
const { minimatch } = require('minimatch');
|
|
6
|
+
const { registerHandlebarsHelpers, log } = require('./utils');
|
|
7
|
+
|
|
8
|
+
// 注册 Handlebars 辅助函数
|
|
9
|
+
registerHandlebarsHelpers(handlebars);
|
|
10
|
+
|
|
11
|
+
/**
|
|
12
|
+
* 判断文件是否需要 Handlebars 处理
|
|
13
|
+
*/
|
|
14
|
+
function shouldProcessFile(filePath, templateConfig = {}) {
|
|
15
|
+
const filePathNormalized = filePath.replace(/\\/g, '/'); // 统一使用正斜杠
|
|
16
|
+
|
|
17
|
+
// 如果配置了 skipFiles(黑名单),先检查是否应该跳过
|
|
18
|
+
if (templateConfig.skipFiles && Array.isArray(templateConfig.skipFiles)) {
|
|
19
|
+
const shouldSkip = templateConfig.skipFiles.some((pattern) => {
|
|
20
|
+
if (typeof pattern === 'string') {
|
|
21
|
+
return minimatch(filePathNormalized, pattern, { matchBase: true });
|
|
22
|
+
}
|
|
23
|
+
return false;
|
|
24
|
+
});
|
|
25
|
+
if (shouldSkip) {
|
|
26
|
+
return false; // 在黑名单中,不处理
|
|
27
|
+
}
|
|
28
|
+
}
|
|
29
|
+
|
|
30
|
+
// 如果配置了 processFiles(白名单),只处理列表中的文件
|
|
31
|
+
if (templateConfig.processFiles && Array.isArray(templateConfig.processFiles)) {
|
|
32
|
+
const inWhitelist = templateConfig.processFiles.some((pattern) => {
|
|
33
|
+
if (typeof pattern === 'string') {
|
|
34
|
+
// 支持通配符匹配,使用 matchBase 以便匹配文件名
|
|
35
|
+
return minimatch(filePathNormalized, pattern, { matchBase: true });
|
|
36
|
+
}
|
|
37
|
+
return false;
|
|
38
|
+
});
|
|
39
|
+
return inWhitelist; // 在白名单中返回 true,不在返回 false
|
|
40
|
+
}
|
|
41
|
+
|
|
42
|
+
// 默认策略:只处理常见的配置文件和文档文件
|
|
43
|
+
// 跳过代码文件(可能包含 Vue/React 模板语法)
|
|
44
|
+
const processExtensions = ['.json', '.md', '.html', '.txt', '.yml', '.yaml', '.env'];
|
|
45
|
+
const processBasenames = ['.gitignore', '.editorconfig', '.prettierignore', '.eslintignore'];
|
|
46
|
+
const skipExtensions = ['.vue', '.js', '.ts', '.jsx', '.tsx', '.css', '.scss', '.less', '.sass', '.styl'];
|
|
47
|
+
|
|
48
|
+
const ext = path.extname(filePath).toLowerCase();
|
|
49
|
+
const basename = path.basename(filePath).toLowerCase();
|
|
50
|
+
|
|
51
|
+
// 如果文件扩展名在跳过列表中,不处理
|
|
52
|
+
if (skipExtensions.includes(ext)) {
|
|
53
|
+
return false;
|
|
54
|
+
}
|
|
55
|
+
|
|
56
|
+
// 如果文件扩展名或文件名在处理列表中,处理
|
|
57
|
+
if (processExtensions.includes(ext) || processBasenames.includes(basename)) {
|
|
58
|
+
return true;
|
|
59
|
+
}
|
|
60
|
+
|
|
61
|
+
// 默认不处理(安全起见,避免破坏代码文件)
|
|
62
|
+
return false;
|
|
63
|
+
}
|
|
64
|
+
|
|
65
|
+
/**
|
|
66
|
+
* 处理文件内容,替换模板变量
|
|
67
|
+
*/
|
|
68
|
+
function processFileContent(content, variables) {
|
|
69
|
+
try {
|
|
70
|
+
const template = handlebars.compile(content, { noEscape: true, strict: false });
|
|
71
|
+
return template(variables);
|
|
72
|
+
} catch (e) {
|
|
73
|
+
// 如果处理失败,返回原内容(避免因为 Vue 模板语法等导致失败)
|
|
74
|
+
// 注意:这个函数只应该在 shouldProcessFile 返回 true 时调用
|
|
75
|
+
// 如果还是失败了(比如文件中有复杂语法),返回原内容
|
|
76
|
+
return content;
|
|
77
|
+
}
|
|
78
|
+
}
|
|
79
|
+
|
|
80
|
+
/**
|
|
81
|
+
* 处理文件名,替换模板变量
|
|
82
|
+
*/
|
|
83
|
+
function processFileName(fileName, variables) {
|
|
84
|
+
try {
|
|
85
|
+
// 使用 Handlebars 处理文件名,支持 helper 函数
|
|
86
|
+
const template = handlebars.compile(fileName, { noEscape: true, strict: false });
|
|
87
|
+
return template(variables);
|
|
88
|
+
} catch (e) {
|
|
89
|
+
// 如果 Handlebars 编译失败,尝试简单字符串替换
|
|
90
|
+
let result = fileName;
|
|
91
|
+
Object.keys(variables).forEach((key) => {
|
|
92
|
+
if (typeof variables[key] === 'string') {
|
|
93
|
+
const pattern = new RegExp(`\\{\\{${key}\\}\\}`, 'g');
|
|
94
|
+
result = result.replace(pattern, variables[key]);
|
|
95
|
+
}
|
|
96
|
+
});
|
|
97
|
+
return result;
|
|
98
|
+
}
|
|
99
|
+
}
|
|
100
|
+
|
|
101
|
+
/**
|
|
102
|
+
* 获取模板文件列表
|
|
103
|
+
*/
|
|
104
|
+
function getTemplateFiles(templatePath) {
|
|
105
|
+
const filesDir = path.join(templatePath, 'files');
|
|
106
|
+
|
|
107
|
+
if (!fs.existsSync(filesDir)) {
|
|
108
|
+
throw new Error(`模板文件目录不存在: ${filesDir}`);
|
|
109
|
+
}
|
|
110
|
+
|
|
111
|
+
// 使用 glob 匹配所有文件(排除 node_modules 等)
|
|
112
|
+
// 在 Windows 上,glob 需要正斜杠路径
|
|
113
|
+
const pattern = path.join(filesDir, '**', '*').replace(/\\/g, '/');
|
|
114
|
+
const files = glob.sync(pattern, {
|
|
115
|
+
dot: true,
|
|
116
|
+
nodir: true,
|
|
117
|
+
ignore: ['**/node_modules/**', '**/.git/**'],
|
|
118
|
+
});
|
|
119
|
+
|
|
120
|
+
return files.map((file) => {
|
|
121
|
+
// glob 返回的是绝对路径
|
|
122
|
+
return {
|
|
123
|
+
absolutePath: file,
|
|
124
|
+
relativePath: path.relative(filesDir, file),
|
|
125
|
+
};
|
|
126
|
+
});
|
|
127
|
+
}
|
|
128
|
+
|
|
129
|
+
/**
|
|
130
|
+
* 生成代码文件
|
|
131
|
+
*/
|
|
132
|
+
async function generateFiles(templatePath, outputDir, variables, templateConfig = {}) {
|
|
133
|
+
const files = getTemplateFiles(templatePath);
|
|
134
|
+
|
|
135
|
+
if (files.length === 0) {
|
|
136
|
+
log.warn('模板中没有找到文件');
|
|
137
|
+
return;
|
|
138
|
+
}
|
|
139
|
+
|
|
140
|
+
log.info(`开始生成 ${files.length} 个文件...\n`);
|
|
141
|
+
|
|
142
|
+
for (const file of files) {
|
|
143
|
+
try {
|
|
144
|
+
// 读取文件内容
|
|
145
|
+
const content = fs.readFileSync(file.absolutePath, 'utf-8');
|
|
146
|
+
|
|
147
|
+
// 判断是否需要 Handlebars 处理
|
|
148
|
+
// 默认只处理配置文件(如 .json, .md),跳过代码文件(如 .vue, .js)避免冲突
|
|
149
|
+
const needProcess = shouldProcessFile(file.relativePath, templateConfig);
|
|
150
|
+
const processedContent = needProcess ? processFileContent(content, variables) : content;
|
|
151
|
+
|
|
152
|
+
// 处理文件名
|
|
153
|
+
let processedFileName = file.relativePath;
|
|
154
|
+
|
|
155
|
+
// 如果配置了 fileMappings,优先使用映射
|
|
156
|
+
if (templateConfig.fileMappings) {
|
|
157
|
+
const fileName = path.basename(file.relativePath);
|
|
158
|
+
const dirName = path.dirname(file.relativePath);
|
|
159
|
+
if (templateConfig.fileMappings[fileName]) {
|
|
160
|
+
const mappedName = processFileName(templateConfig.fileMappings[fileName], variables);
|
|
161
|
+
processedFileName = dirName !== '.' ? path.join(dirName, mappedName) : mappedName;
|
|
162
|
+
} else {
|
|
163
|
+
processedFileName = processFileName(file.relativePath, variables);
|
|
164
|
+
}
|
|
165
|
+
} else {
|
|
166
|
+
processedFileName = processFileName(file.relativePath, variables);
|
|
167
|
+
}
|
|
168
|
+
|
|
169
|
+
// 生成目标文件路径
|
|
170
|
+
const targetPath = path.join(outputDir, processedFileName);
|
|
171
|
+
const targetDir = path.dirname(targetPath);
|
|
172
|
+
|
|
173
|
+
// 确保目录存在
|
|
174
|
+
fs.ensureDirSync(targetDir);
|
|
175
|
+
|
|
176
|
+
// 写入文件
|
|
177
|
+
fs.writeFileSync(targetPath, processedContent, 'utf-8');
|
|
178
|
+
|
|
179
|
+
log.success(`生成: ${processedFileName}`);
|
|
180
|
+
} catch (e) {
|
|
181
|
+
log.error(`处理文件失败 ${file.relativePath}: ${e.message}`);
|
|
182
|
+
throw e;
|
|
183
|
+
}
|
|
184
|
+
}
|
|
185
|
+
|
|
186
|
+
console.log('');
|
|
187
|
+
log.success('代码生成完成!');
|
|
188
|
+
}
|
|
189
|
+
|
|
190
|
+
module.exports = {
|
|
191
|
+
generateFiles,
|
|
192
|
+
};
|
package/lib/index.js
ADDED
|
@@ -0,0 +1,113 @@
|
|
|
1
|
+
const fs = require('fs-extra');
|
|
2
|
+
const path = require('path');
|
|
3
|
+
const inquirer = require('inquirer');
|
|
4
|
+
const { getTemplateConfig } = require('./template');
|
|
5
|
+
const { generateFiles } = require('./generator');
|
|
6
|
+
const { getOutputDir, log } = require('./utils');
|
|
7
|
+
|
|
8
|
+
/**
|
|
9
|
+
* 生成代码
|
|
10
|
+
*/
|
|
11
|
+
async function generate(templateName, options = {}) {
|
|
12
|
+
try {
|
|
13
|
+
// 获取模板配置
|
|
14
|
+
const templateConfig = getTemplateConfig(templateName);
|
|
15
|
+
const templatePath = templateConfig.path;
|
|
16
|
+
|
|
17
|
+
// 准备变量
|
|
18
|
+
let variables = { ...(options.variables || {}) };
|
|
19
|
+
|
|
20
|
+
// 如果模板定义了变量但用户没有提供,使用交互式收集
|
|
21
|
+
if (templateConfig.variables && Object.keys(templateConfig.variables).length > 0) {
|
|
22
|
+
const missingVars = Object.keys(templateConfig.variables).filter((key) => !(key in variables));
|
|
23
|
+
|
|
24
|
+
if (missingVars.length > 0) {
|
|
25
|
+
const prompts = missingVars.map((key) => {
|
|
26
|
+
const config = templateConfig.variables[key];
|
|
27
|
+
return {
|
|
28
|
+
type: config.type || 'input',
|
|
29
|
+
name: key,
|
|
30
|
+
message: config.message || `请输入 ${key}`,
|
|
31
|
+
default: config.default,
|
|
32
|
+
choices: config.choices,
|
|
33
|
+
validate: config.validate,
|
|
34
|
+
};
|
|
35
|
+
});
|
|
36
|
+
|
|
37
|
+
const answers = await inquirer.prompt(prompts);
|
|
38
|
+
variables = { ...variables, ...answers };
|
|
39
|
+
}
|
|
40
|
+
}
|
|
41
|
+
|
|
42
|
+
// 应用变量替换规则
|
|
43
|
+
if (templateConfig.replacements) {
|
|
44
|
+
Object.entries(templateConfig.replacements).forEach(([key, value]) => {
|
|
45
|
+
if (typeof value === 'string' && value.includes('{{')) {
|
|
46
|
+
// 使用 Handlebars 处理替换规则
|
|
47
|
+
const handlebars = require('handlebars');
|
|
48
|
+
const { registerHandlebarsHelpers } = require('./utils');
|
|
49
|
+
registerHandlebarsHelpers(handlebars);
|
|
50
|
+
const template = handlebars.compile(value, { noEscape: true });
|
|
51
|
+
variables[key] = template(variables);
|
|
52
|
+
} else {
|
|
53
|
+
variables[key] = value;
|
|
54
|
+
}
|
|
55
|
+
});
|
|
56
|
+
}
|
|
57
|
+
|
|
58
|
+
// 添加一些常用的辅助变量
|
|
59
|
+
if (variables.name) {
|
|
60
|
+
const { camelCase, pascalCase, kebabCase, snakeCase } = require('./utils');
|
|
61
|
+
variables.nameCamel = camelCase(variables.name);
|
|
62
|
+
variables.namePascal = pascalCase(variables.name);
|
|
63
|
+
variables.nameKebab = kebabCase(variables.name);
|
|
64
|
+
variables.nameSnake = snakeCase(variables.name);
|
|
65
|
+
}
|
|
66
|
+
|
|
67
|
+
// 为 React 组件添加 className 辅助变量
|
|
68
|
+
if (variables.componentName) {
|
|
69
|
+
const { pascalCase, kebabCase } = require('./utils');
|
|
70
|
+
const componentNameKebab = kebabCase(variables.componentName);
|
|
71
|
+
const useCSS = variables.useCSS || 'none';
|
|
72
|
+
|
|
73
|
+
// 根据样式方案生成 className 属性字符串(完整的 JSX 属性)
|
|
74
|
+
if (useCSS === 'modules') {
|
|
75
|
+
variables.classNameAttr = "className={`${styles.container} ${className || ''}`}";
|
|
76
|
+
} else if (useCSS === 'css') {
|
|
77
|
+
variables.classNameAttr = `className={\`${componentNameKebab} \${className || ''}\`}`;
|
|
78
|
+
} else {
|
|
79
|
+
variables.classNameAttr = 'className={className}';
|
|
80
|
+
}
|
|
81
|
+
|
|
82
|
+
// 生成导入语句
|
|
83
|
+
if (useCSS === 'modules') {
|
|
84
|
+
variables.cssImport = `import styles from './${componentNameKebab}.module.css';`;
|
|
85
|
+
} else if (useCSS === 'styled') {
|
|
86
|
+
variables.cssImport = "import styled from 'styled-components';";
|
|
87
|
+
} else if (useCSS === 'css') {
|
|
88
|
+
variables.cssImport = `import './${componentNameKebab}.css';`;
|
|
89
|
+
} else {
|
|
90
|
+
variables.cssImport = '';
|
|
91
|
+
}
|
|
92
|
+
|
|
93
|
+
variables.componentNamePascal = pascalCase(variables.componentName);
|
|
94
|
+
variables.componentNameKebab = componentNameKebab;
|
|
95
|
+
}
|
|
96
|
+
|
|
97
|
+
// 确定输出目录
|
|
98
|
+
const outputDir = getOutputDir(options.outputDir);
|
|
99
|
+
fs.ensureDirSync(outputDir);
|
|
100
|
+
|
|
101
|
+
// 生成文件
|
|
102
|
+
await generateFiles(templatePath, outputDir, variables, templateConfig);
|
|
103
|
+
|
|
104
|
+
log.success(`代码已生成到: ${outputDir}`);
|
|
105
|
+
} catch (error) {
|
|
106
|
+
log.error(`生成失败: ${error.message}`);
|
|
107
|
+
throw error;
|
|
108
|
+
}
|
|
109
|
+
}
|
|
110
|
+
|
|
111
|
+
module.exports = {
|
|
112
|
+
generate,
|
|
113
|
+
};
|
|
@@ -0,0 +1,87 @@
|
|
|
1
|
+
const inquirer = require('inquirer');
|
|
2
|
+
const { generate } = require('./index');
|
|
3
|
+
const { listTemplates } = require('./template');
|
|
4
|
+
const { log } = require('./utils');
|
|
5
|
+
|
|
6
|
+
/**
|
|
7
|
+
* 交互式创建代码
|
|
8
|
+
*/
|
|
9
|
+
async function interactiveCreate() {
|
|
10
|
+
try {
|
|
11
|
+
// 获取模板列表(不打印)
|
|
12
|
+
const templates = listTemplates(false);
|
|
13
|
+
|
|
14
|
+
if (templates.length === 0) {
|
|
15
|
+
log.error('没有可用的模板');
|
|
16
|
+
return;
|
|
17
|
+
}
|
|
18
|
+
|
|
19
|
+
// 选择模板
|
|
20
|
+
const { templateName } = await inquirer.prompt([
|
|
21
|
+
{
|
|
22
|
+
type: 'list',
|
|
23
|
+
name: 'templateName',
|
|
24
|
+
message: '请选择模板',
|
|
25
|
+
choices: templates.map((t) => ({
|
|
26
|
+
name: `${t.name} - ${t.config.description || '无描述'}`,
|
|
27
|
+
value: t.name,
|
|
28
|
+
})),
|
|
29
|
+
},
|
|
30
|
+
]);
|
|
31
|
+
|
|
32
|
+
// 获取模板配置
|
|
33
|
+
const { getTemplateConfig } = require('./template');
|
|
34
|
+
const templateConfig = getTemplateConfig(templateName);
|
|
35
|
+
|
|
36
|
+
// 收集变量
|
|
37
|
+
const variables = {};
|
|
38
|
+
|
|
39
|
+
if (templateConfig.variables) {
|
|
40
|
+
const prompts = Object.entries(templateConfig.variables).map(([key, config]) => {
|
|
41
|
+
return {
|
|
42
|
+
type: config.type || 'input',
|
|
43
|
+
name: key,
|
|
44
|
+
message: config.message || `请输入 ${key}`,
|
|
45
|
+
default: config.default,
|
|
46
|
+
when:
|
|
47
|
+
config.when !== undefined
|
|
48
|
+
? (answers) => {
|
|
49
|
+
if (typeof config.when === 'function') {
|
|
50
|
+
return config.when(answers);
|
|
51
|
+
}
|
|
52
|
+
return config.when;
|
|
53
|
+
}
|
|
54
|
+
: undefined,
|
|
55
|
+
choices: config.choices,
|
|
56
|
+
validate: config.validate,
|
|
57
|
+
};
|
|
58
|
+
});
|
|
59
|
+
|
|
60
|
+
const answers = await inquirer.prompt(prompts);
|
|
61
|
+
Object.assign(variables, answers);
|
|
62
|
+
}
|
|
63
|
+
|
|
64
|
+
// 询问输出目录
|
|
65
|
+
const { outputDir } = await inquirer.prompt([
|
|
66
|
+
{
|
|
67
|
+
type: 'input',
|
|
68
|
+
name: 'outputDir',
|
|
69
|
+
message: '输出目录',
|
|
70
|
+
default: './',
|
|
71
|
+
},
|
|
72
|
+
]);
|
|
73
|
+
|
|
74
|
+
// 生成代码
|
|
75
|
+
await generate(templateName, {
|
|
76
|
+
outputDir,
|
|
77
|
+
variables,
|
|
78
|
+
});
|
|
79
|
+
} catch (error) {
|
|
80
|
+
log.error(`创建失败: ${error.message}`);
|
|
81
|
+
process.exit(1);
|
|
82
|
+
}
|
|
83
|
+
}
|
|
84
|
+
|
|
85
|
+
module.exports = {
|
|
86
|
+
interactiveCreate,
|
|
87
|
+
};
|