forked from ruoyi/RuoYi-Vue
		
	若依 2.1
This commit is contained in:
		
							
								
								
									
										423
									
								
								ruoyi-ui/src/utils/generator/config.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										423
									
								
								ruoyi-ui/src/utils/generator/config.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,423 @@ | ||||
| export const formConf = { | ||||
|   formRef: 'elForm', | ||||
|   formModel: 'formData', | ||||
|   size: 'medium', | ||||
|   labelPosition: 'right', | ||||
|   labelWidth: 100, | ||||
|   formRules: 'rules', | ||||
|   gutter: 15, | ||||
|   disabled: false, | ||||
|   span: 24, | ||||
|   formBtns: true | ||||
| } | ||||
|  | ||||
| export const inputComponents = [ | ||||
|   { | ||||
|     label: '单行文本', | ||||
|     tag: 'el-input', | ||||
|     tagIcon: 'input', | ||||
|     placeholder: '请输入', | ||||
|     defaultValue: undefined, | ||||
|     span: 24, | ||||
|     labelWidth: null, | ||||
|     style: { width: '100%' }, | ||||
|     clearable: true, | ||||
|     prepend: '', | ||||
|     append: '', | ||||
|     'prefix-icon': '', | ||||
|     'suffix-icon': '', | ||||
|     maxlength: null, | ||||
|     'show-word-limit': false, | ||||
|     readonly: false, | ||||
|     disabled: false, | ||||
|     required: true, | ||||
|     regList: [], | ||||
|     changeTag: true, | ||||
|     document: 'https://element.eleme.cn/#/zh-CN/component/input' | ||||
|   }, | ||||
|   { | ||||
|     label: '多行文本', | ||||
|     tag: 'el-input', | ||||
|     tagIcon: 'textarea', | ||||
|     type: 'textarea', | ||||
|     placeholder: '请输入', | ||||
|     defaultValue: undefined, | ||||
|     span: 24, | ||||
|     labelWidth: null, | ||||
|     autosize: { | ||||
|       minRows: 4, | ||||
|       maxRows: 4 | ||||
|     }, | ||||
|     style: { width: '100%' }, | ||||
|     maxlength: null, | ||||
|     'show-word-limit': false, | ||||
|     readonly: false, | ||||
|     disabled: false, | ||||
|     required: true, | ||||
|     regList: [], | ||||
|     changeTag: true, | ||||
|     document: 'https://element.eleme.cn/#/zh-CN/component/input' | ||||
|   }, | ||||
|   { | ||||
|     label: '密码', | ||||
|     tag: 'el-input', | ||||
|     tagIcon: 'password', | ||||
|     placeholder: '请输入', | ||||
|     defaultValue: undefined, | ||||
|     span: 24, | ||||
|     'show-password': true, | ||||
|     labelWidth: null, | ||||
|     style: { width: '100%' }, | ||||
|     clearable: true, | ||||
|     prepend: '', | ||||
|     append: '', | ||||
|     'prefix-icon': '', | ||||
|     'suffix-icon': '', | ||||
|     maxlength: null, | ||||
|     'show-word-limit': false, | ||||
|     readonly: false, | ||||
|     disabled: false, | ||||
|     required: true, | ||||
|     regList: [], | ||||
|     changeTag: true, | ||||
|     document: 'https://element.eleme.cn/#/zh-CN/component/input' | ||||
|   }, | ||||
|   { | ||||
|     label: '计数器', | ||||
|     tag: 'el-input-number', | ||||
|     tagIcon: 'number', | ||||
|     placeholder: '', | ||||
|     defaultValue: undefined, | ||||
|     span: 24, | ||||
|     labelWidth: null, | ||||
|     min: undefined, | ||||
|     max: undefined, | ||||
|     step: undefined, | ||||
|     'step-strictly': false, | ||||
|     precision: undefined, | ||||
|     'controls-position': '', | ||||
|     disabled: false, | ||||
|     required: true, | ||||
|     regList: [], | ||||
|     changeTag: true, | ||||
|     document: 'https://element.eleme.cn/#/zh-CN/component/input-number' | ||||
|   } | ||||
| ] | ||||
|  | ||||
| export const selectComponents = [ | ||||
|   { | ||||
|     label: '下拉选择', | ||||
|     tag: 'el-select', | ||||
|     tagIcon: 'select', | ||||
|     placeholder: '请选择', | ||||
|     defaultValue: undefined, | ||||
|     span: 24, | ||||
|     labelWidth: null, | ||||
|     style: { width: '100%' }, | ||||
|     clearable: true, | ||||
|     disabled: false, | ||||
|     required: true, | ||||
|     filterable: false, | ||||
|     multiple: false, | ||||
|     options: [{ | ||||
|       label: '选项一', | ||||
|       value: 1 | ||||
|     }, { | ||||
|       label: '选项二', | ||||
|       value: 2 | ||||
|     }], | ||||
|     regList: [], | ||||
|     changeTag: true, | ||||
|     document: 'https://element.eleme.cn/#/zh-CN/component/select' | ||||
|   }, | ||||
|   { | ||||
|     label: '级联选择', | ||||
|     tag: 'el-cascader', | ||||
|     tagIcon: 'cascader', | ||||
|     placeholder: '请选择', | ||||
|     defaultValue: [], | ||||
|     span: 24, | ||||
|     labelWidth: null, | ||||
|     style: { width: '100%' }, | ||||
|     props: { | ||||
|       props: { | ||||
|         multiple: false | ||||
|       } | ||||
|     }, | ||||
|     'show-all-levels': true, | ||||
|     disabled: false, | ||||
|     clearable: true, | ||||
|     filterable: false, | ||||
|     required: true, | ||||
|     options: [{ | ||||
|       id: 1, | ||||
|       value: 1, | ||||
|       label: '选项1', | ||||
|       children: [{ | ||||
|         id: 2, | ||||
|         value: 2, | ||||
|         label: '选项1-1' | ||||
|       }] | ||||
|     }], | ||||
|     dataType: 'dynamic', | ||||
|     labelKey: 'label', | ||||
|     valueKey: 'value', | ||||
|     childrenKey: 'children', | ||||
|     separator: '/', | ||||
|     regList: [], | ||||
|     changeTag: true, | ||||
|     document: 'https://element.eleme.cn/#/zh-CN/component/cascader' | ||||
|   }, | ||||
|   { | ||||
|     label: '单选框组', | ||||
|     tag: 'el-radio-group', | ||||
|     tagIcon: 'radio', | ||||
|     defaultValue: undefined, | ||||
|     span: 24, | ||||
|     labelWidth: null, | ||||
|     style: {}, | ||||
|     optionType: 'default', | ||||
|     border: false, | ||||
|     size: 'medium', | ||||
|     disabled: false, | ||||
|     required: true, | ||||
|     options: [{ | ||||
|       label: '选项一', | ||||
|       value: 1 | ||||
|     }, { | ||||
|       label: '选项二', | ||||
|       value: 2 | ||||
|     }], | ||||
|     regList: [], | ||||
|     changeTag: true, | ||||
|     document: 'https://element.eleme.cn/#/zh-CN/component/radio' | ||||
|   }, | ||||
|   { | ||||
|     label: '多选框组', | ||||
|     tag: 'el-checkbox-group', | ||||
|     tagIcon: 'checkbox', | ||||
|     defaultValue: [], | ||||
|     span: 24, | ||||
|     labelWidth: null, | ||||
|     style: {}, | ||||
|     optionType: 'default', | ||||
|     border: false, | ||||
|     size: 'medium', | ||||
|     disabled: false, | ||||
|     required: true, | ||||
|     options: [{ | ||||
|       label: '选项一', | ||||
|       value: 1 | ||||
|     }, { | ||||
|       label: '选项二', | ||||
|       value: 2 | ||||
|     }], | ||||
|     regList: [], | ||||
|     changeTag: true, | ||||
|     document: 'https://element.eleme.cn/#/zh-CN/component/checkbox' | ||||
|   }, | ||||
|   { | ||||
|     label: '开关', | ||||
|     tag: 'el-switch', | ||||
|     tagIcon: 'switch', | ||||
|     defaultValue: false, | ||||
|     span: 24, | ||||
|     labelWidth: null, | ||||
|     style: {}, | ||||
|     disabled: false, | ||||
|     required: true, | ||||
|     'active-text': '', | ||||
|     'inactive-text': '', | ||||
|     'active-color': null, | ||||
|     'inactive-color': null, | ||||
|     'active-value': true, | ||||
|     'inactive-value': false, | ||||
|     regList: [], | ||||
|     changeTag: true, | ||||
|     document: 'https://element.eleme.cn/#/zh-CN/component/switch' | ||||
|   }, | ||||
|   { | ||||
|     label: '滑块', | ||||
|     tag: 'el-slider', | ||||
|     tagIcon: 'slider', | ||||
|     defaultValue: null, | ||||
|     span: 24, | ||||
|     labelWidth: null, | ||||
|     disabled: false, | ||||
|     required: true, | ||||
|     min: 0, | ||||
|     max: 100, | ||||
|     step: 1, | ||||
|     'show-stops': false, | ||||
|     range: false, | ||||
|     regList: [], | ||||
|     changeTag: true, | ||||
|     document: 'https://element.eleme.cn/#/zh-CN/component/slider' | ||||
|   }, | ||||
|   { | ||||
|     label: '时间选择', | ||||
|     tag: 'el-time-picker', | ||||
|     tagIcon: 'time', | ||||
|     placeholder: '请选择', | ||||
|     defaultValue: null, | ||||
|     span: 24, | ||||
|     labelWidth: null, | ||||
|     style: { width: '100%' }, | ||||
|     disabled: false, | ||||
|     clearable: true, | ||||
|     required: true, | ||||
|     'picker-options': { | ||||
|       selectableRange: '00:00:00-23:59:59' | ||||
|     }, | ||||
|     format: 'HH:mm:ss', | ||||
|     'value-format': 'HH:mm:ss', | ||||
|     regList: [], | ||||
|     changeTag: true, | ||||
|     document: 'https://element.eleme.cn/#/zh-CN/component/time-picker' | ||||
|   }, | ||||
|   { | ||||
|     label: '时间范围', | ||||
|     tag: 'el-time-picker', | ||||
|     tagIcon: 'time-range', | ||||
|     defaultValue: null, | ||||
|     span: 24, | ||||
|     labelWidth: null, | ||||
|     style: { width: '100%' }, | ||||
|     disabled: false, | ||||
|     clearable: true, | ||||
|     required: true, | ||||
|     'is-range': true, | ||||
|     'range-separator': '至', | ||||
|     'start-placeholder': '开始时间', | ||||
|     'end-placeholder': '结束时间', | ||||
|     format: 'HH:mm:ss', | ||||
|     'value-format': 'HH:mm:ss', | ||||
|     regList: [], | ||||
|     changeTag: true, | ||||
|     document: 'https://element.eleme.cn/#/zh-CN/component/time-picker' | ||||
|   }, | ||||
|   { | ||||
|     label: '日期选择', | ||||
|     tag: 'el-date-picker', | ||||
|     tagIcon: 'date', | ||||
|     placeholder: '请选择', | ||||
|     defaultValue: null, | ||||
|     type: 'date', | ||||
|     span: 24, | ||||
|     labelWidth: null, | ||||
|     style: { width: '100%' }, | ||||
|     disabled: false, | ||||
|     clearable: true, | ||||
|     required: true, | ||||
|     format: 'yyyy-MM-dd', | ||||
|     'value-format': 'yyyy-MM-dd', | ||||
|     readonly: false, | ||||
|     regList: [], | ||||
|     changeTag: true, | ||||
|     document: 'https://element.eleme.cn/#/zh-CN/component/date-picker' | ||||
|   }, | ||||
|   { | ||||
|     label: '日期范围', | ||||
|     tag: 'el-date-picker', | ||||
|     tagIcon: 'date-range', | ||||
|     defaultValue: null, | ||||
|     span: 24, | ||||
|     labelWidth: null, | ||||
|     style: { width: '100%' }, | ||||
|     type: 'daterange', | ||||
|     'range-separator': '至', | ||||
|     'start-placeholder': '开始日期', | ||||
|     'end-placeholder': '结束日期', | ||||
|     disabled: false, | ||||
|     clearable: true, | ||||
|     required: true, | ||||
|     format: 'yyyy-MM-dd', | ||||
|     'value-format': 'yyyy-MM-dd', | ||||
|     readonly: false, | ||||
|     regList: [], | ||||
|     changeTag: true, | ||||
|     document: 'https://element.eleme.cn/#/zh-CN/component/date-picker' | ||||
|   }, | ||||
|   { | ||||
|     label: '评分', | ||||
|     tag: 'el-rate', | ||||
|     tagIcon: 'rate', | ||||
|     defaultValue: 0, | ||||
|     span: 24, | ||||
|     labelWidth: null, | ||||
|     style: {}, | ||||
|     max: 5, | ||||
|     'allow-half': false, | ||||
|     'show-text': false, | ||||
|     'show-score': false, | ||||
|     disabled: false, | ||||
|     required: true, | ||||
|     regList: [], | ||||
|     changeTag: true, | ||||
|     document: 'https://element.eleme.cn/#/zh-CN/component/rate' | ||||
|   }, | ||||
|   { | ||||
|     label: '颜色选择', | ||||
|     tag: 'el-color-picker', | ||||
|     tagIcon: 'color', | ||||
|     defaultValue: null, | ||||
|     labelWidth: null, | ||||
|     'show-alpha': false, | ||||
|     'color-format': '', | ||||
|     disabled: false, | ||||
|     required: true, | ||||
|     size: 'medium', | ||||
|     regList: [], | ||||
|     changeTag: true, | ||||
|     document: 'https://element.eleme.cn/#/zh-CN/component/color-picker' | ||||
|   }, | ||||
|   { | ||||
|     label: '上传', | ||||
|     tag: 'el-upload', | ||||
|     tagIcon: 'upload', | ||||
|     action: 'https://jsonplaceholder.typicode.com/posts/', | ||||
|     defaultValue: null, | ||||
|     labelWidth: null, | ||||
|     disabled: false, | ||||
|     required: true, | ||||
|     accept: '', | ||||
|     name: 'file', | ||||
|     'auto-upload': true, | ||||
|     showTip: false, | ||||
|     buttonText: '点击上传', | ||||
|     fileSize: 2, | ||||
|     sizeUnit: 'MB', | ||||
|     'list-type': 'text', | ||||
|     multiple: false, | ||||
|     regList: [], | ||||
|     changeTag: true, | ||||
|     document: 'https://element.eleme.cn/#/zh-CN/component/upload' | ||||
|   } | ||||
| ] | ||||
|  | ||||
| export const layoutComponents = [ | ||||
|   { | ||||
|     layout: 'rowFormItem', | ||||
|     tagIcon: 'row', | ||||
|     type: 'default', | ||||
|     justify: 'start', | ||||
|     align: 'top', | ||||
|     label: '行容器', | ||||
|     layoutTree: true, | ||||
|     children: [], | ||||
|     document: 'https://element.eleme.cn/#/zh-CN/component/layout' | ||||
|   } | ||||
| ] | ||||
|  | ||||
| // 组件rule的触发方式,无触发方式的组件不生成rule | ||||
| export const trigger = { | ||||
|   'el-input': 'blur', | ||||
|   'el-input-number': 'blur', | ||||
|   'el-select': 'change', | ||||
|   'el-radio-group': 'change', | ||||
|   'el-checkbox-group': 'change', | ||||
|   'el-cascader': 'change', | ||||
|   'el-time-picker': 'change', | ||||
|   'el-date-picker': 'change', | ||||
|   'el-rate': 'change' | ||||
| } | ||||
							
								
								
									
										18
									
								
								ruoyi-ui/src/utils/generator/css.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										18
									
								
								ruoyi-ui/src/utils/generator/css.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,18 @@ | ||||
| const styles = { | ||||
|   'el-rate': '.el-rate{display: inline-block; vertical-align: text-top;}', | ||||
|   'el-upload': '.el-upload__tip{line-height: 1.2;}' | ||||
| } | ||||
|  | ||||
| function addCss(cssList, el) { | ||||
|   const css = styles[el.tag] | ||||
|   css && cssList.indexOf(css) === -1 && cssList.push(css) | ||||
|   if (el.children) { | ||||
|     el.children.forEach(el2 => addCss(cssList, el2)) | ||||
|   } | ||||
| } | ||||
|  | ||||
| export function makeUpCss(conf) { | ||||
|   const cssList = [] | ||||
|   conf.fields.forEach(el => addCss(cssList, el)) | ||||
|   return cssList.join('\n') | ||||
| } | ||||
							
								
								
									
										29
									
								
								ruoyi-ui/src/utils/generator/drawingDefalut.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										29
									
								
								ruoyi-ui/src/utils/generator/drawingDefalut.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,29 @@ | ||||
| export default [ | ||||
|   { | ||||
|     layout: 'colFormItem', | ||||
|     tagIcon: 'input', | ||||
|     label: '手机号', | ||||
|     vModel: 'mobile', | ||||
|     formId: 6, | ||||
|     tag: 'el-input', | ||||
|     placeholder: '请输入手机号', | ||||
|     defaultValue: '', | ||||
|     span: 24, | ||||
|     style: { width: '100%' }, | ||||
|     clearable: true, | ||||
|     prepend: '', | ||||
|     append: '', | ||||
|     'prefix-icon': 'el-icon-mobile', | ||||
|     'suffix-icon': '', | ||||
|     maxlength: 11, | ||||
|     'show-word-limit': true, | ||||
|     readonly: false, | ||||
|     disabled: false, | ||||
|     required: true, | ||||
|     changeTag: true, | ||||
|     regList: [{ | ||||
|       pattern: '/^1(3|4|5|7|8|9)\\d{9}$/', | ||||
|       message: '手机号格式错误' | ||||
|     }] | ||||
|   } | ||||
| ] | ||||
							
								
								
									
										338
									
								
								ruoyi-ui/src/utils/generator/html.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										338
									
								
								ruoyi-ui/src/utils/generator/html.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,338 @@ | ||||
| /* eslint-disable max-len */ | ||||
| import { trigger } from './config' | ||||
|  | ||||
| let confGlobal | ||||
| let someSpanIsNot24 | ||||
|  | ||||
| export function dialogWrapper(str) { | ||||
|   return `<el-dialog v-bind="$attrs" v-on="$listeners" @open="onOpen" @close="onClose" title="Dialog Titile"> | ||||
|     ${str} | ||||
|     <div slot="footer"> | ||||
|       <el-button @click="close">取消</el-button> | ||||
|       <el-button type="primary" @click="handelConfirm">确定</el-button> | ||||
|     </div> | ||||
|   </el-dialog>` | ||||
| } | ||||
|  | ||||
| export function vueTemplate(str) { | ||||
|   return `<template> | ||||
|     <div> | ||||
|       ${str} | ||||
|     </div> | ||||
|   </template>` | ||||
| } | ||||
|  | ||||
| export function vueScript(str) { | ||||
|   return `<script> | ||||
|     ${str} | ||||
|   </script>` | ||||
| } | ||||
|  | ||||
| export function cssStyle(cssStr) { | ||||
|   return `<style> | ||||
|     ${cssStr} | ||||
|   </style>` | ||||
| } | ||||
|  | ||||
| function buildFormTemplate(conf, child, type) { | ||||
|   let labelPosition = '' | ||||
|   if (conf.labelPosition !== 'right') { | ||||
|     labelPosition = `label-position="${conf.labelPosition}"` | ||||
|   } | ||||
|   const disabled = conf.disabled ? `:disabled="${conf.disabled}"` : '' | ||||
|   let str = `<el-form ref="${conf.formRef}" :model="${conf.formModel}" :rules="${conf.formRules}" size="${conf.size}" ${disabled} label-width="${conf.labelWidth}px" ${labelPosition}> | ||||
|       ${child} | ||||
|       ${buildFromBtns(conf, type)} | ||||
|     </el-form>` | ||||
|   if (someSpanIsNot24) { | ||||
|     str = `<el-row :gutter="${conf.gutter}"> | ||||
|         ${str} | ||||
|       </el-row>` | ||||
|   } | ||||
|   return str | ||||
| } | ||||
|  | ||||
| function buildFromBtns(conf, type) { | ||||
|   let str = '' | ||||
|   if (conf.formBtns && type === 'file') { | ||||
|     str = `<el-form-item size="large"> | ||||
|           <el-button type="primary" @click="submitForm">提交</el-button> | ||||
|           <el-button @click="resetForm">重置</el-button> | ||||
|         </el-form-item>` | ||||
|     if (someSpanIsNot24) { | ||||
|       str = `<el-col :span="24"> | ||||
|           ${str} | ||||
|         </el-col>` | ||||
|     } | ||||
|   } | ||||
|   return str | ||||
| } | ||||
|  | ||||
| // span不为24的用el-col包裹 | ||||
| function colWrapper(element, str) { | ||||
|   if (someSpanIsNot24 || element.span !== 24) { | ||||
|     return `<el-col :span="${element.span}"> | ||||
|       ${str} | ||||
|     </el-col>` | ||||
|   } | ||||
|   return str | ||||
| } | ||||
|  | ||||
| const layouts = { | ||||
|   colFormItem(element) { | ||||
|     let labelWidth = '' | ||||
|     if (element.labelWidth && element.labelWidth !== confGlobal.labelWidth) { | ||||
|       labelWidth = `label-width="${element.labelWidth}px"` | ||||
|     } | ||||
|     const required = !trigger[element.tag] && element.required ? 'required' : '' | ||||
|     const tagDom = tags[element.tag] ? tags[element.tag](element) : null | ||||
|     let str = `<el-form-item ${labelWidth} label="${element.label}" prop="${element.vModel}" ${required}> | ||||
|         ${tagDom} | ||||
|       </el-form-item>` | ||||
|     str = colWrapper(element, str) | ||||
|     return str | ||||
|   }, | ||||
|   rowFormItem(element) { | ||||
|     const type = element.type === 'default' ? '' : `type="${element.type}"` | ||||
|     const justify = element.type === 'default' ? '' : `justify="${element.justify}"` | ||||
|     const align = element.type === 'default' ? '' : `align="${element.align}"` | ||||
|     const gutter = element.gutter ? `gutter="${element.gutter}"` : '' | ||||
|     const children = element.children.map(el => layouts[el.layout](el)) | ||||
|     let str = `<el-row ${type} ${justify} ${align} ${gutter}> | ||||
|       ${children.join('\n')} | ||||
|     </el-row>` | ||||
|     str = colWrapper(element, str) | ||||
|     return str | ||||
|   } | ||||
| } | ||||
|  | ||||
| const tags = { | ||||
|   'el-input': el => { | ||||
|     const { | ||||
|       disabled, vModel, clearable, placeholder, width | ||||
|     } = attrBuilder(el) | ||||
|     const maxlength = el.maxlength ? `:maxlength="${el.maxlength}"` : '' | ||||
|     const showWordLimit = el['show-word-limit'] ? 'show-word-limit' : '' | ||||
|     const readonly = el.readonly ? 'readonly' : '' | ||||
|     const prefixIcon = el['prefix-icon'] ? `prefix-icon='${el['prefix-icon']}'` : '' | ||||
|     const suffixIcon = el['suffix-icon'] ? `suffix-icon='${el['suffix-icon']}'` : '' | ||||
|     const showPassword = el['show-password'] ? 'show-password' : '' | ||||
|     const type = el.type ? `type="${el.type}"` : '' | ||||
|     const autosize = el.autosize && el.autosize.minRows | ||||
|       ? `:autosize="{minRows: ${el.autosize.minRows}, maxRows: ${el.autosize.maxRows}}"` | ||||
|       : '' | ||||
|     let child = buildElInputChild(el) | ||||
|  | ||||
|     if (child) child = `\n${child}\n` // 换行 | ||||
|     return `<${el.tag} ${vModel} ${type} ${placeholder} ${maxlength} ${showWordLimit} ${readonly} ${disabled} ${clearable} ${prefixIcon} ${suffixIcon} ${showPassword} ${autosize} ${width}>${child}</${el.tag}>` | ||||
|   }, | ||||
|   'el-input-number': el => { | ||||
|     const { disabled, vModel, placeholder } = attrBuilder(el) | ||||
|     const controlsPosition = el['controls-position'] ? `controls-position=${el['controls-position']}` : '' | ||||
|     const min = el.min ? `:min='${el.min}'` : '' | ||||
|     const max = el.max ? `:max='${el.max}'` : '' | ||||
|     const step = el.step ? `:step='${el.step}'` : '' | ||||
|     const stepStrictly = el['step-strictly'] ? 'step-strictly' : '' | ||||
|     const precision = el.precision ? `:precision='${el.precision}'` : '' | ||||
|  | ||||
|     return `<${el.tag} ${vModel} ${placeholder} ${step} ${stepStrictly} ${precision} ${controlsPosition} ${min} ${max} ${disabled}></${el.tag}>` | ||||
|   }, | ||||
|   'el-select': el => { | ||||
|     const { | ||||
|       disabled, vModel, clearable, placeholder, width | ||||
|     } = attrBuilder(el) | ||||
|     const filterable = el.filterable ? 'filterable' : '' | ||||
|     const multiple = el.multiple ? 'multiple' : '' | ||||
|     let child = buildElSelectChild(el) | ||||
|  | ||||
|     if (child) child = `\n${child}\n` // 换行 | ||||
|     return `<${el.tag} ${vModel} ${placeholder} ${disabled} ${multiple} ${filterable} ${clearable} ${width}>${child}</${el.tag}>` | ||||
|   }, | ||||
|   'el-radio-group': el => { | ||||
|     const { disabled, vModel } = attrBuilder(el) | ||||
|     const size = `size="${el.size}"` | ||||
|     let child = buildElRadioGroupChild(el) | ||||
|  | ||||
|     if (child) child = `\n${child}\n` // 换行 | ||||
|     return `<${el.tag} ${vModel} ${size} ${disabled}>${child}</${el.tag}>` | ||||
|   }, | ||||
|   'el-checkbox-group': el => { | ||||
|     const { disabled, vModel } = attrBuilder(el) | ||||
|     const size = `size="${el.size}"` | ||||
|     const min = el.min ? `:min="${el.min}"` : '' | ||||
|     const max = el.max ? `:max="${el.max}"` : '' | ||||
|     let child = buildElCheckboxGroupChild(el) | ||||
|  | ||||
|     if (child) child = `\n${child}\n` // 换行 | ||||
|     return `<${el.tag} ${vModel} ${min} ${max} ${size} ${disabled}>${child}</${el.tag}>` | ||||
|   }, | ||||
|   'el-switch': el => { | ||||
|     const { disabled, vModel } = attrBuilder(el) | ||||
|     const activeText = el['active-text'] ? `active-text="${el['active-text']}"` : '' | ||||
|     const inactiveText = el['inactive-text'] ? `inactive-text="${el['inactive-text']}"` : '' | ||||
|     const activeColor = el['active-color'] ? `active-color="${el['active-color']}"` : '' | ||||
|     const inactiveColor = el['inactive-color'] ? `inactive-color="${el['inactive-color']}"` : '' | ||||
|     const activeValue = el['active-value'] !== true ? `:active-value='${JSON.stringify(el['active-value'])}'` : '' | ||||
|     const inactiveValue = el['inactive-value'] !== false ? `:inactive-value='${JSON.stringify(el['inactive-value'])}'` : '' | ||||
|  | ||||
|     return `<${el.tag} ${vModel} ${activeText} ${inactiveText} ${activeColor} ${inactiveColor} ${activeValue} ${inactiveValue} ${disabled}></${el.tag}>` | ||||
|   }, | ||||
|   'el-cascader': el => { | ||||
|     const { | ||||
|       disabled, vModel, clearable, placeholder, width | ||||
|     } = attrBuilder(el) | ||||
|     const options = el.options ? `:options="${el.vModel}Options"` : '' | ||||
|     const props = el.props ? `:props="${el.vModel}Props"` : '' | ||||
|     const showAllLevels = el['show-all-levels'] ? '' : ':show-all-levels="false"' | ||||
|     const filterable = el.filterable ? 'filterable' : '' | ||||
|     const separator = el.separator === '/' ? '' : `separator="${el.separator}"` | ||||
|  | ||||
|     return `<${el.tag} ${vModel} ${options} ${props} ${width} ${showAllLevels} ${placeholder} ${separator} ${filterable} ${clearable} ${disabled}></${el.tag}>` | ||||
|   }, | ||||
|   'el-slider': el => { | ||||
|     const { disabled, vModel } = attrBuilder(el) | ||||
|     const min = el.min ? `:min='${el.min}'` : '' | ||||
|     const max = el.max ? `:max='${el.max}'` : '' | ||||
|     const step = el.step ? `:step='${el.step}'` : '' | ||||
|     const range = el.range ? 'range' : '' | ||||
|     const showStops = el['show-stops'] ? `:show-stops="${el['show-stops']}"` : '' | ||||
|  | ||||
|     return `<${el.tag} ${min} ${max} ${step} ${vModel} ${range} ${showStops} ${disabled}></${el.tag}>` | ||||
|   }, | ||||
|   'el-time-picker': el => { | ||||
|     const { | ||||
|       disabled, vModel, clearable, placeholder, width | ||||
|     } = attrBuilder(el) | ||||
|     const startPlaceholder = el['start-placeholder'] ? `start-placeholder="${el['start-placeholder']}"` : '' | ||||
|     const endPlaceholder = el['end-placeholder'] ? `end-placeholder="${el['end-placeholder']}"` : '' | ||||
|     const rangeSeparator = el['range-separator'] ? `range-separator="${el['range-separator']}"` : '' | ||||
|     const isRange = el['is-range'] ? 'is-range' : '' | ||||
|     const format = el.format ? `format="${el.format}"` : '' | ||||
|     const valueFormat = el['value-format'] ? `value-format="${el['value-format']}"` : '' | ||||
|     const pickerOptions = el['picker-options'] ? `:picker-options='${JSON.stringify(el['picker-options'])}'` : '' | ||||
|  | ||||
|     return `<${el.tag} ${vModel} ${isRange} ${format} ${valueFormat} ${pickerOptions} ${width} ${placeholder} ${startPlaceholder} ${endPlaceholder} ${rangeSeparator} ${clearable} ${disabled}></${el.tag}>` | ||||
|   }, | ||||
|   'el-date-picker': el => { | ||||
|     const { | ||||
|       disabled, vModel, clearable, placeholder, width | ||||
|     } = attrBuilder(el) | ||||
|     const startPlaceholder = el['start-placeholder'] ? `start-placeholder="${el['start-placeholder']}"` : '' | ||||
|     const endPlaceholder = el['end-placeholder'] ? `end-placeholder="${el['end-placeholder']}"` : '' | ||||
|     const rangeSeparator = el['range-separator'] ? `range-separator="${el['range-separator']}"` : '' | ||||
|     const format = el.format ? `format="${el.format}"` : '' | ||||
|     const valueFormat = el['value-format'] ? `value-format="${el['value-format']}"` : '' | ||||
|     const type = el.type === 'date' ? '' : `type="${el.type}"` | ||||
|     const readonly = el.readonly ? 'readonly' : '' | ||||
|  | ||||
|     return `<${el.tag} ${type} ${vModel} ${format} ${valueFormat} ${width} ${placeholder} ${startPlaceholder} ${endPlaceholder} ${rangeSeparator} ${clearable} ${readonly} ${disabled}></${el.tag}>` | ||||
|   }, | ||||
|   'el-rate': el => { | ||||
|     const { disabled, vModel } = attrBuilder(el) | ||||
|     const max = el.max ? `:max='${el.max}'` : '' | ||||
|     const allowHalf = el['allow-half'] ? 'allow-half' : '' | ||||
|     const showText = el['show-text'] ? 'show-text' : '' | ||||
|     const showScore = el['show-score'] ? 'show-score' : '' | ||||
|  | ||||
|     return `<${el.tag} ${vModel} ${allowHalf} ${showText} ${showScore} ${disabled}></${el.tag}>` | ||||
|   }, | ||||
|   'el-color-picker': el => { | ||||
|     const { disabled, vModel } = attrBuilder(el) | ||||
|     const size = `size="${el.size}"` | ||||
|     const showAlpha = el['show-alpha'] ? 'show-alpha' : '' | ||||
|     const colorFormat = el['color-format'] ? `color-format="${el['color-format']}"` : '' | ||||
|  | ||||
|     return `<${el.tag} ${vModel} ${size} ${showAlpha} ${colorFormat} ${disabled}></${el.tag}>` | ||||
|   }, | ||||
|   'el-upload': el => { | ||||
|     const disabled = el.disabled ? ':disabled=\'true\'' : '' | ||||
|     const action = el.action ? `:action="${el.vModel}Action"` : '' | ||||
|     const multiple = el.multiple ? 'multiple' : '' | ||||
|     const listType = el['list-type'] !== 'text' ? `list-type="${el['list-type']}"` : '' | ||||
|     const accept = el.accept ? `accept="${el.accept}"` : '' | ||||
|     const name = el.name !== 'file' ? `name="${el.name}"` : '' | ||||
|     const autoUpload = el['auto-upload'] === false ? ':auto-upload="false"' : '' | ||||
|     const beforeUpload = `:before-upload="${el.vModel}BeforeUpload"` | ||||
|     const fileList = `:file-list="${el.vModel}fileList"` | ||||
|     const ref = `ref="${el.vModel}"` | ||||
|     let child = buildElUploadChild(el) | ||||
|  | ||||
|     if (child) child = `\n${child}\n` // 换行 | ||||
|     return `<${el.tag} ${ref} ${fileList} ${action} ${autoUpload} ${multiple} ${beforeUpload} ${listType} ${accept} ${name} ${disabled}>${child}</${el.tag}>` | ||||
|   } | ||||
| } | ||||
|  | ||||
| function attrBuilder(el) { | ||||
|   return { | ||||
|     vModel: `v-model="${confGlobal.formModel}.${el.vModel}"`, | ||||
|     clearable: el.clearable ? 'clearable' : '', | ||||
|     placeholder: el.placeholder ? `placeholder="${el.placeholder}"` : '', | ||||
|     width: el.style && el.style.width ? ':style="{width: \'100%\'}"' : '', | ||||
|     disabled: el.disabled ? ':disabled=\'true\'' : '' | ||||
|   } | ||||
| } | ||||
|  | ||||
| // el-input innerHTML | ||||
| function buildElInputChild(conf) { | ||||
|   const children = [] | ||||
|   if (conf.prepend) { | ||||
|     children.push(`<template slot="prepend">${conf.prepend}</template>`) | ||||
|   } | ||||
|   if (conf.append) { | ||||
|     children.push(`<template slot="append">${conf.append}</template>`) | ||||
|   } | ||||
|   return children.join('\n') | ||||
| } | ||||
|  | ||||
| function buildElSelectChild(conf) { | ||||
|   const children = [] | ||||
|   if (conf.options && conf.options.length) { | ||||
|     children.push(`<el-option v-for="(item, index) in ${conf.vModel}Options" :key="index" :label="item.label" :value="item.value" :disabled="item.disabled"></el-option>`) | ||||
|   } | ||||
|   return children.join('\n') | ||||
| } | ||||
|  | ||||
| function buildElRadioGroupChild(conf) { | ||||
|   const children = [] | ||||
|   if (conf.options && conf.options.length) { | ||||
|     const tag = conf.optionType === 'button' ? 'el-radio-button' : 'el-radio' | ||||
|     const border = conf.border ? 'border' : '' | ||||
|     children.push(`<${tag} v-for="(item, index) in ${conf.vModel}Options" :key="index" :label="item.value" :disabled="item.disabled" ${border}>{{item.label}}</${tag}>`) | ||||
|   } | ||||
|   return children.join('\n') | ||||
| } | ||||
|  | ||||
| function buildElCheckboxGroupChild(conf) { | ||||
|   const children = [] | ||||
|   if (conf.options && conf.options.length) { | ||||
|     const tag = conf.optionType === 'button' ? 'el-checkbox-button' : 'el-checkbox' | ||||
|     const border = conf.border ? 'border' : '' | ||||
|     children.push(`<${tag} v-for="(item, index) in ${conf.vModel}Options" :key="index" :label="item.value" :disabled="item.disabled" ${border}>{{item.label}}</${tag}>`) | ||||
|   } | ||||
|   return children.join('\n') | ||||
| } | ||||
|  | ||||
| function buildElUploadChild(conf) { | ||||
|   const list = [] | ||||
|   if (conf['list-type'] === 'picture-card') list.push('<i class="el-icon-plus"></i>') | ||||
|   else list.push(`<el-button size="small" type="primary" icon="el-icon-upload">${conf.buttonText}</el-button>`) | ||||
|   if (conf.showTip) list.push(`<div slot="tip" class="el-upload__tip">只能上传不超过 ${conf.fileSize}${conf.sizeUnit} 的${conf.accept}文件</div>`) | ||||
|   return list.join('\n') | ||||
| } | ||||
|  | ||||
| export function makeUpHtml(conf, type) { | ||||
|   const htmlList = [] | ||||
|   confGlobal = conf | ||||
|   someSpanIsNot24 = conf.fields.some(item => item.span !== 24) | ||||
|   conf.fields.forEach(el => { | ||||
|     htmlList.push(layouts[el.layout](el)) | ||||
|   }) | ||||
|   const htmlStr = htmlList.join('\n') | ||||
|  | ||||
|   let temp = buildFormTemplate(conf, htmlStr, type) | ||||
|   if (type === 'dialog') { | ||||
|     temp = dialogWrapper(temp) | ||||
|   } | ||||
|   confGlobal = null | ||||
|   return temp | ||||
| } | ||||
							
								
								
									
										1
									
								
								ruoyi-ui/src/utils/generator/icon.json
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								ruoyi-ui/src/utils/generator/icon.json
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1 @@ | ||||
| ["platform-eleme","eleme","delete-solid","delete","s-tools","setting","user-solid","user","phone","phone-outline","more","more-outline","star-on","star-off","s-goods","goods","warning","warning-outline","question","info","remove","circle-plus","success","error","zoom-in","zoom-out","remove-outline","circle-plus-outline","circle-check","circle-close","s-help","help","minus","plus","check","close","picture","picture-outline","picture-outline-round","upload","upload2","download","camera-solid","camera","video-camera-solid","video-camera","message-solid","bell","s-cooperation","s-order","s-platform","s-fold","s-unfold","s-operation","s-promotion","s-home","s-release","s-ticket","s-management","s-open","s-shop","s-marketing","s-flag","s-comment","s-finance","s-claim","s-custom","s-opportunity","s-data","s-check","s-grid","menu","share","d-caret","caret-left","caret-right","caret-bottom","caret-top","bottom-left","bottom-right","back","right","bottom","top","top-left","top-right","arrow-left","arrow-right","arrow-down","arrow-up","d-arrow-left","d-arrow-right","video-pause","video-play","refresh","refresh-right","refresh-left","finished","sort","sort-up","sort-down","rank","loading","view","c-scale-to-original","date","edit","edit-outline","folder","folder-opened","folder-add","folder-remove","folder-delete","folder-checked","tickets","document-remove","document-delete","document-copy","document-checked","document","document-add","printer","paperclip","takeaway-box","search","monitor","attract","mobile","scissors","umbrella","headset","brush","mouse","coordinate","magic-stick","reading","data-line","data-board","pie-chart","data-analysis","collection-tag","film","suitcase","suitcase-1","receiving","collection","files","notebook-1","notebook-2","toilet-paper","office-building","school","table-lamp","house","no-smoking","smoking","shopping-cart-full","shopping-cart-1","shopping-cart-2","shopping-bag-1","shopping-bag-2","sold-out","sell","present","box","bank-card","money","coin","wallet","discount","price-tag","news","guide","male","female","thumb","cpu","link","connection","open","turn-off","set-up","chat-round","chat-line-round","chat-square","chat-dot-round","chat-dot-square","chat-line-square","message","postcard","position","turn-off-microphone","microphone","close-notification","bangzhu","time","odometer","crop","aim","switch-button","full-screen","copy-document","mic","stopwatch","medal-1","medal","trophy","trophy-1","first-aid-kit","discover","place","location","location-outline","location-information","add-location","delete-location","map-location","alarm-clock","timer","watch-1","watch","lock","unlock","key","service","mobile-phone","bicycle","truck","ship","basketball","football","soccer","baseball","wind-power","light-rain","lightning","heavy-rain","sunrise","sunrise-1","sunset","sunny","cloudy","partly-cloudy","cloudy-and-sunny","moon","moon-night","dish","dish-1","food","chicken","fork-spoon","knife-fork","burger","tableware","sugar","dessert","ice-cream","hot-water","water-cup","coffee-cup","cold-drink","goblet","goblet-full","goblet-square","goblet-square-full","refrigerator","grape","watermelon","cherry","apple","pear","orange","coffee","ice-tea","ice-drink","milk-tea","potato-strips","lollipop","ice-cream-square","ice-cream-round"] | ||||
							
								
								
									
										236
									
								
								ruoyi-ui/src/utils/generator/js.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										236
									
								
								ruoyi-ui/src/utils/generator/js.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,236 @@ | ||||
| import { isArray } from 'util' | ||||
| import { exportDefault, titleCase } from '@/utils/index' | ||||
| import { trigger } from './config' | ||||
|  | ||||
| const units = { | ||||
|   KB: '1024', | ||||
|   MB: '1024 / 1024', | ||||
|   GB: '1024 / 1024 / 1024' | ||||
| } | ||||
| let confGlobal | ||||
| const inheritAttrs = { | ||||
|   file: '', | ||||
|   dialog: 'inheritAttrs: false,' | ||||
| } | ||||
|  | ||||
|  | ||||
| export function makeUpJs(conf, type) { | ||||
|   confGlobal = conf = JSON.parse(JSON.stringify(conf)) | ||||
|   const dataList = [] | ||||
|   const ruleList = [] | ||||
|   const optionsList = [] | ||||
|   const propsList = [] | ||||
|   const methodList = mixinMethod(type) | ||||
|   const uploadVarList = [] | ||||
|  | ||||
|   conf.fields.forEach(el => { | ||||
|     buildAttributes(el, dataList, ruleList, optionsList, methodList, propsList, uploadVarList) | ||||
|   }) | ||||
|  | ||||
|   const script = buildexport( | ||||
|     conf, | ||||
|     type, | ||||
|     dataList.join('\n'), | ||||
|     ruleList.join('\n'), | ||||
|     optionsList.join('\n'), | ||||
|     uploadVarList.join('\n'), | ||||
|     propsList.join('\n'), | ||||
|     methodList.join('\n') | ||||
|   ) | ||||
|   confGlobal = null | ||||
|   return script | ||||
| } | ||||
|  | ||||
| function buildAttributes(el, dataList, ruleList, optionsList, methodList, propsList, uploadVarList) { | ||||
|   buildData(el, dataList) | ||||
|   buildRules(el, ruleList) | ||||
|  | ||||
|   if (el.options && el.options.length) { | ||||
|     buildOptions(el, optionsList) | ||||
|     if (el.dataType === 'dynamic') { | ||||
|       const model = `${el.vModel}Options` | ||||
|       const options = titleCase(model) | ||||
|       buildOptionMethod(`get${options}`, model, methodList) | ||||
|     } | ||||
|   } | ||||
|  | ||||
|   if (el.props && el.props.props) { | ||||
|     buildProps(el, propsList) | ||||
|   } | ||||
|  | ||||
|   if (el.action && el.tag === 'el-upload') { | ||||
|     uploadVarList.push( | ||||
|       `${el.vModel}Action: '${el.action}', | ||||
|       ${el.vModel}fileList: [],` | ||||
|     ) | ||||
|     methodList.push(buildBeforeUpload(el)) | ||||
|     if (!el['auto-upload']) { | ||||
|       methodList.push(buildSubmitUpload(el)) | ||||
|     } | ||||
|   } | ||||
|  | ||||
|   if (el.children) { | ||||
|     el.children.forEach(el2 => { | ||||
|       buildAttributes(el2, dataList, ruleList, optionsList, methodList, propsList, uploadVarList) | ||||
|     }) | ||||
|   } | ||||
| } | ||||
|  | ||||
| function mixinMethod(type) { | ||||
|   const list = []; const | ||||
|     minxins = { | ||||
|       file: confGlobal.formBtns ? { | ||||
|         submitForm: `submitForm() { | ||||
|         this.$refs['${confGlobal.formRef}'].validate(valid => { | ||||
|           if(!valid) return | ||||
|           // TODO 提交表单 | ||||
|         }) | ||||
|       },`, | ||||
|         resetForm: `resetForm() { | ||||
|         this.$refs['${confGlobal.formRef}'].resetFields() | ||||
|       },` | ||||
|       } : null, | ||||
|       dialog: { | ||||
|         onOpen: 'onOpen() {},', | ||||
|         onClose: `onClose() { | ||||
|         this.$refs['${confGlobal.formRef}'].resetFields() | ||||
|       },`, | ||||
|         close: `close() { | ||||
|         this.$emit('update:visible', false) | ||||
|       },`, | ||||
|         handelConfirm: `handelConfirm() { | ||||
|         this.$refs['${confGlobal.formRef}'].validate(valid => { | ||||
|           if(!valid) return | ||||
|           this.close() | ||||
|         }) | ||||
|       },` | ||||
|       } | ||||
|     } | ||||
|  | ||||
|   const methods = minxins[type] | ||||
|   if (methods) { | ||||
|     Object.keys(methods).forEach(key => { | ||||
|       list.push(methods[key]) | ||||
|     }) | ||||
|   } | ||||
|  | ||||
|   return list | ||||
| } | ||||
|  | ||||
| function buildData(conf, dataList) { | ||||
|   if (conf.vModel === undefined) return | ||||
|   let defaultValue | ||||
|   if (typeof (conf.defaultValue) === 'string' && !conf.multiple) { | ||||
|     defaultValue = `'${conf.defaultValue}'` | ||||
|   } else { | ||||
|     defaultValue = `${JSON.stringify(conf.defaultValue)}` | ||||
|   } | ||||
|   dataList.push(`${conf.vModel}: ${defaultValue},`) | ||||
| } | ||||
|  | ||||
| function buildRules(conf, ruleList) { | ||||
|   if (conf.vModel === undefined) return | ||||
|   const rules = [] | ||||
|   if (trigger[conf.tag]) { | ||||
|     if (conf.required) { | ||||
|       const type = isArray(conf.defaultValue) ? 'type: \'array\',' : '' | ||||
|       let message = isArray(conf.defaultValue) ? `请至少选择一个${conf.vModel}` : conf.placeholder | ||||
|       if (message === undefined) message = `${conf.label}不能为空` | ||||
|       rules.push(`{ required: true, ${type} message: '${message}', trigger: '${trigger[conf.tag]}' }`) | ||||
|     } | ||||
|     if (conf.regList && isArray(conf.regList)) { | ||||
|       conf.regList.forEach(item => { | ||||
|         if (item.pattern) { | ||||
|           rules.push(`{ pattern: ${eval(item.pattern)}, message: '${item.message}', trigger: '${trigger[conf.tag]}' }`) | ||||
|         } | ||||
|       }) | ||||
|     } | ||||
|     ruleList.push(`${conf.vModel}: [${rules.join(',')}],`) | ||||
|   } | ||||
| } | ||||
|  | ||||
| function buildOptions(conf, optionsList) { | ||||
|   if (conf.vModel === undefined) return | ||||
|   if (conf.dataType === 'dynamic') { conf.options = [] } | ||||
|   const str = `${conf.vModel}Options: ${JSON.stringify(conf.options)},` | ||||
|   optionsList.push(str) | ||||
| } | ||||
|  | ||||
| function buildProps(conf, propsList) { | ||||
|   if (conf.dataType === 'dynamic') { | ||||
|     conf.valueKey !== 'value' && (conf.props.props.value = conf.valueKey) | ||||
|     conf.labelKey !== 'label' && (conf.props.props.label = conf.labelKey) | ||||
|     conf.childrenKey !== 'children' && (conf.props.props.children = conf.childrenKey) | ||||
|   } | ||||
|   const str = `${conf.vModel}Props: ${JSON.stringify(conf.props.props)},` | ||||
|   propsList.push(str) | ||||
| } | ||||
|  | ||||
| function buildBeforeUpload(conf) { | ||||
|   const unitNum = units[conf.sizeUnit]; let rightSizeCode = ''; let acceptCode = ''; const | ||||
|     returnList = [] | ||||
|   if (conf.fileSize) { | ||||
|     rightSizeCode = `let isRightSize = file.size / ${unitNum} < ${conf.fileSize} | ||||
|     if(!isRightSize){ | ||||
|       this.$message.error('文件大小超过 ${conf.fileSize}${conf.sizeUnit}') | ||||
|     }` | ||||
|     returnList.push('isRightSize') | ||||
|   } | ||||
|   if (conf.accept) { | ||||
|     acceptCode = `let isAccept = new RegExp('${conf.accept}').test(file.type) | ||||
|     if(!isAccept){ | ||||
|       this.$message.error('应该选择${conf.accept}类型的文件') | ||||
|     }` | ||||
|     returnList.push('isAccept') | ||||
|   } | ||||
|   const str = `${conf.vModel}BeforeUpload(file) { | ||||
|     ${rightSizeCode} | ||||
|     ${acceptCode} | ||||
|     return ${returnList.join('&&')} | ||||
|   },` | ||||
|   return returnList.length ? str : '' | ||||
| } | ||||
|  | ||||
| function buildSubmitUpload(conf) { | ||||
|   const str = `submitUpload() { | ||||
|     this.$refs['${conf.vModel}'].submit() | ||||
|   },` | ||||
|   return str | ||||
| } | ||||
|  | ||||
| function buildOptionMethod(methodName, model, methodList) { | ||||
|   const str = `${methodName}() { | ||||
|     // TODO 发起请求获取数据 | ||||
|     this.${model} | ||||
|   },` | ||||
|   methodList.push(str) | ||||
| } | ||||
|  | ||||
| function buildexport(conf, type, data, rules, selectOptions, uploadVar, props, methods) { | ||||
|   const str = `${exportDefault}{ | ||||
|   ${inheritAttrs[type]} | ||||
|   components: {}, | ||||
|   props: [], | ||||
|   data () { | ||||
|     return { | ||||
|       ${conf.formModel}: { | ||||
|         ${data} | ||||
|       }, | ||||
|       ${conf.formRules}: { | ||||
|         ${rules} | ||||
|       }, | ||||
|       ${uploadVar} | ||||
|       ${selectOptions} | ||||
|       ${props} | ||||
|     } | ||||
|   }, | ||||
|   computed: {}, | ||||
|   watch: {}, | ||||
|   created () {}, | ||||
|   mounted () {}, | ||||
|   methods: { | ||||
|     ${methods} | ||||
|   } | ||||
| }` | ||||
|   return str | ||||
| } | ||||
							
								
								
									
										121
									
								
								ruoyi-ui/src/utils/generator/render.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										121
									
								
								ruoyi-ui/src/utils/generator/render.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,121 @@ | ||||
| import { makeMap } from '@/utils/index' | ||||
|  | ||||
| // 参考https://github.com/vuejs/vue/blob/v2.6.10/src/platforms/web/server/util.js | ||||
| const isAttr = makeMap( | ||||
|   'accept,accept-charset,accesskey,action,align,alt,async,autocomplete,' | ||||
|   + 'autofocus,autoplay,autosave,bgcolor,border,buffered,challenge,charset,' | ||||
|   + 'checked,cite,class,code,codebase,color,cols,colspan,content,http-equiv,' | ||||
|   + 'name,contenteditable,contextmenu,controls,coords,data,datetime,default,' | ||||
|   + 'defer,dir,dirname,disabled,download,draggable,dropzone,enctype,method,for,' | ||||
|   + 'form,formaction,headers,height,hidden,high,href,hreflang,http-equiv,' | ||||
|   + 'icon,id,ismap,itemprop,keytype,kind,label,lang,language,list,loop,low,' | ||||
|   + 'manifest,max,maxlength,media,method,GET,POST,min,multiple,email,file,' | ||||
|   + 'muted,name,novalidate,open,optimum,pattern,ping,placeholder,poster,' | ||||
|   + 'preload,radiogroup,readonly,rel,required,reversed,rows,rowspan,sandbox,' | ||||
|   + 'scope,scoped,seamless,selected,shape,size,type,text,password,sizes,span,' | ||||
|   + 'spellcheck,src,srcdoc,srclang,srcset,start,step,style,summary,tabindex,' | ||||
|   + 'target,title,type,usemap,value,width,wrap' | ||||
| ) | ||||
|  | ||||
| function vModel(self, dataObject, defaultValue) { | ||||
|   dataObject.props.value = defaultValue | ||||
|  | ||||
|   dataObject.on.input = val => { | ||||
|     self.$emit('input', val) | ||||
|   } | ||||
| } | ||||
|  | ||||
| const componentChild = { | ||||
|   'el-input': { | ||||
|     prepend(h, conf, key) { | ||||
|       return <template slot="prepend">{conf[key]}</template> | ||||
|     }, | ||||
|     append(h, conf, key) { | ||||
|       return <template slot="append">{conf[key]}</template> | ||||
|     } | ||||
|   }, | ||||
|   'el-select': { | ||||
|     options(h, conf, key) { | ||||
|       const list = [] | ||||
|       conf.options.forEach(item => { | ||||
|         list.push(<el-option label={item.label} value={item.value} disabled={item.disabled}></el-option>) | ||||
|       }) | ||||
|       return list | ||||
|     } | ||||
|   }, | ||||
|   'el-radio-group': { | ||||
|     options(h, conf, key) { | ||||
|       const list = [] | ||||
|       conf.options.forEach(item => { | ||||
|         if (conf.optionType === 'button') list.push(<el-radio-button label={item.value}>{item.label}</el-radio-button>) | ||||
|         else list.push(<el-radio label={item.value} border={conf.border}>{item.label}</el-radio>) | ||||
|       }) | ||||
|       return list | ||||
|     } | ||||
|   }, | ||||
|   'el-checkbox-group': { | ||||
|     options(h, conf, key) { | ||||
|       const list = [] | ||||
|       conf.options.forEach(item => { | ||||
|         if (conf.optionType === 'button') { | ||||
|           list.push(<el-checkbox-button label={item.value}>{item.label}</el-checkbox-button>) | ||||
|         } else { | ||||
|           list.push(<el-checkbox label={item.value} border={conf.border}>{item.label}</el-checkbox>) | ||||
|         } | ||||
|       }) | ||||
|       return list | ||||
|     } | ||||
|   }, | ||||
|   'el-upload': { | ||||
|     'list-type': (h, conf, key) => { | ||||
|       const list = [] | ||||
|       if (conf['list-type'] === 'picture-card') { | ||||
|         list.push(<i class="el-icon-plus"></i>) | ||||
|       } else { | ||||
|         list.push(<el-button size="small" type="primary" icon="el-icon-upload">{conf.buttonText}</el-button>) | ||||
|       } | ||||
|       if (conf.showTip) { | ||||
|         list.push(<div slot="tip" class="el-upload__tip">只能上传不超过 {conf.fileSize}{conf.sizeUnit} 的{conf.accept}文件</div>) | ||||
|       } | ||||
|       return list | ||||
|     } | ||||
|   } | ||||
| } | ||||
|  | ||||
| export default { | ||||
|   render(h) { | ||||
|     const dataObject = { | ||||
|       attrs: {}, | ||||
|       props: {}, | ||||
|       on: {}, | ||||
|       style: {} | ||||
|     } | ||||
|     const confClone = JSON.parse(JSON.stringify(this.conf)) | ||||
|     const children = [] | ||||
|  | ||||
|     const childObjs = componentChild[confClone.tag] | ||||
|     if (childObjs) { | ||||
|       Object.keys(childObjs).forEach(key => { | ||||
|         const childFunc = childObjs[key] | ||||
|         if (confClone[key]) { | ||||
|           children.push(childFunc(h, confClone, key)) | ||||
|         } | ||||
|       }) | ||||
|     } | ||||
|  | ||||
|     Object.keys(confClone).forEach(key => { | ||||
|       const val = confClone[key] | ||||
|       if (key === 'vModel') { | ||||
|         vModel(this, dataObject, confClone.defaultValue) | ||||
|       } else if (dataObject[key]) { | ||||
|         dataObject[key] = val | ||||
|       } else if (!isAttr(key)) { | ||||
|         dataObject.props[key] = val | ||||
|       } else { | ||||
|         dataObject.attrs[key] = val | ||||
|       } | ||||
|     }) | ||||
|     return h(this.conf.tag, dataObject, children) | ||||
|   }, | ||||
|   props: ['conf'] | ||||
| } | ||||
		Reference in New Issue
	
	Block a user
	 RuoYi
					RuoYi