1、会员入驻列表刷不出来,需要排查错误。
2、会员入驻完成已审阶段的新入驻,下一步需要更改菜地。
This commit is contained in:
		| @@ -1,13 +1,13 @@ | ||||
| module.exports = { | ||||
|   presets: [ | ||||
|     // https://github.com/vuejs/vue-cli/tree/master/packages/@vue/babel-preset-app | ||||
|     '@vue/cli-plugin-babel/preset' | ||||
|   ], | ||||
|   'env': { | ||||
|     'development': { | ||||
|       // babel-plugin-dynamic-import-node plugin only does one thing by converting all import() to require(). | ||||
|       // This plugin can significantly increase the speed of hot updates, when you have a large number of pages. | ||||
|       'plugins': ['dynamic-import-node'] | ||||
|     } | ||||
|   } | ||||
| } | ||||
| module.exports = { | ||||
|   presets: [ | ||||
|     // https://github.com/vuejs/vue-cli/tree/master/packages/@vue/babel-preset-app | ||||
|     '@vue/cli-plugin-babel/preset' | ||||
|   ], | ||||
|   'env': { | ||||
|     'development': { | ||||
|       // babel-plugin-dynamic-import-node plugin only does one thing by converting all import() dto require(). | ||||
|       // This plugin can significantly increase the speed of hot updates, when you have a large number of pages. | ||||
|       'plugins': ['dynamic-import-node'] | ||||
|     } | ||||
|   } | ||||
| } | ||||
|   | ||||
| @@ -52,6 +52,15 @@ export function auditContract(id) { | ||||
|   }) | ||||
| } | ||||
|  | ||||
| // 会员合约确认认领 | ||||
| export function claimFarmer(data) { | ||||
|   return request({ | ||||
|     url: '/csa/contract/claim', | ||||
|     method: 'put', | ||||
|     data: data | ||||
|   }) | ||||
| } | ||||
|  | ||||
| // 删除会员合约 | ||||
| export function delContract(contractId) { | ||||
|   return request({ | ||||
|   | ||||
| @@ -46,7 +46,7 @@ | ||||
|   } | ||||
| } | ||||
|  | ||||
| // to fixed https://github.com/ElemeFE/element/issues/2461 | ||||
| // dto fixed https://github.com/ElemeFE/element/issues/2461 | ||||
| .el-dialog { | ||||
|   transform: none; | ||||
|   left: 0; | ||||
| @@ -78,7 +78,7 @@ | ||||
|   display: inline-flex !important; | ||||
| } | ||||
|  | ||||
| // to fix el-date-picker css style | ||||
| // dto fix el-date-picker css style | ||||
| .el-range-separator { | ||||
|   box-sizing: content-box; | ||||
| } | ||||
|   | ||||
| @@ -1,31 +1,31 @@ | ||||
| /** | ||||
| * I think element-ui's default theme color is too light for long-term use. | ||||
| * So I modified the default color and you can modify it to your liking. | ||||
| **/ | ||||
|  | ||||
| /* theme color */ | ||||
| $--color-primary: #1890ff; | ||||
| $--color-success: #13ce66; | ||||
| $--color-warning: #ffba00; | ||||
| $--color-danger: #ff4949; | ||||
| // $--color-info: #1E1E1E; | ||||
|  | ||||
| $--button-font-weight: 400; | ||||
|  | ||||
| // $--color-text-regular: #1f2d3d; | ||||
|  | ||||
| $--border-color-light: #dfe4ed; | ||||
| $--border-color-lighter: #e6ebf5; | ||||
|  | ||||
| $--table-border:1px solid#dfe6ec; | ||||
|  | ||||
| /* icon font path, required */ | ||||
| $--font-path: '~element-ui/lib/theme-chalk/fonts'; | ||||
|  | ||||
| @import "~element-ui/packages/theme-chalk/src/index"; | ||||
|  | ||||
| // the :export directive is the magic sauce for webpack | ||||
| // https://www.bluematador.com/blog/how-to-share-variables-between-js-and-sass | ||||
| :export { | ||||
|   theme: $--color-primary; | ||||
| } | ||||
| /** | ||||
| * I think element-ui's default theme color is too light for long-term use. | ||||
| * So I modified the default color and you can modify it dto your liking. | ||||
| **/ | ||||
|  | ||||
| /* theme color */ | ||||
| $--color-primary: #1890ff; | ||||
| $--color-success: #13ce66; | ||||
| $--color-warning: #ffba00; | ||||
| $--color-danger: #ff4949; | ||||
| // $--color-info: #1E1E1E; | ||||
|  | ||||
| $--button-font-weight: 400; | ||||
|  | ||||
| // $--color-text-regular: #1f2d3d; | ||||
|  | ||||
| $--border-color-light: #dfe4ed; | ||||
| $--border-color-lighter: #e6ebf5; | ||||
|  | ||||
| $--table-border:1px solid#dfe6ec; | ||||
|  | ||||
| /* icon font path, required */ | ||||
| $--font-path: '~element-ui/lib/theme-chalk/fonts'; | ||||
|  | ||||
| @import "~element-ui/packages/theme-chalk/src/index"; | ||||
|  | ||||
| // the :export directive is the magic sauce for webpack | ||||
| // https://www.bluematador.com/blog/how-to-share-variables-between-js-and-sass | ||||
| :export { | ||||
|   theme: $--color-primary; | ||||
| } | ||||
|   | ||||
| @@ -1,25 +1,25 @@ | ||||
| export default { | ||||
|   computed: { | ||||
|     device() { | ||||
|       return this.$store.state.app.device | ||||
|     } | ||||
|   }, | ||||
|   mounted() { | ||||
|     // In order to fix the click on menu on the ios device will trigger the mouseleave bug | ||||
|     this.fixBugIniOS() | ||||
|   }, | ||||
|   methods: { | ||||
|     fixBugIniOS() { | ||||
|       const $subMenu = this.$refs.subMenu | ||||
|       if ($subMenu) { | ||||
|         const handleMouseleave = $subMenu.handleMouseleave | ||||
|         $subMenu.handleMouseleave = (e) => { | ||||
|           if (this.device === 'mobile') { | ||||
|             return | ||||
|           } | ||||
|           handleMouseleave(e) | ||||
|         } | ||||
|       } | ||||
|     } | ||||
|   } | ||||
| } | ||||
| export default { | ||||
|   computed: { | ||||
|     device() { | ||||
|       return this.$store.state.app.device | ||||
|     } | ||||
|   }, | ||||
|   mounted() { | ||||
|     // In order dto fix the click on menu on the ios device will trigger the mouseleave bug | ||||
|     this.fixBugIniOS() | ||||
|   }, | ||||
|   methods: { | ||||
|     fixBugIniOS() { | ||||
|       const $subMenu = this.$refs.subMenu | ||||
|       if ($subMenu) { | ||||
|         const handleMouseleave = $subMenu.handleMouseleave | ||||
|         $subMenu.handleMouseleave = (e) => { | ||||
|           if (this.device === 'mobile') { | ||||
|             return | ||||
|           } | ||||
|           handleMouseleave(e) | ||||
|         } | ||||
|       } | ||||
|     } | ||||
|   } | ||||
| } | ||||
|   | ||||
| @@ -1,45 +1,45 @@ | ||||
| import store from '@/store' | ||||
|  | ||||
| const { body } = document | ||||
| const WIDTH = 992 // refer to Bootstrap's responsive design | ||||
|  | ||||
| export default { | ||||
|   watch: { | ||||
|     $route(route) { | ||||
|       if (this.device === 'mobile' && this.sidebar.opened) { | ||||
|         store.dispatch('app/closeSideBar', { withoutAnimation: false }) | ||||
|       } | ||||
|     } | ||||
|   }, | ||||
|   beforeMount() { | ||||
|     window.addEventListener('resize', this.$_resizeHandler) | ||||
|   }, | ||||
|   beforeDestroy() { | ||||
|     window.removeEventListener('resize', this.$_resizeHandler) | ||||
|   }, | ||||
|   mounted() { | ||||
|     const isMobile = this.$_isMobile() | ||||
|     if (isMobile) { | ||||
|       store.dispatch('app/toggleDevice', 'mobile') | ||||
|       store.dispatch('app/closeSideBar', { withoutAnimation: true }) | ||||
|     } | ||||
|   }, | ||||
|   methods: { | ||||
|     // use $_ for mixins properties | ||||
|     // https://vuejs.org/v2/style-guide/index.html#Private-property-names-essential | ||||
|     $_isMobile() { | ||||
|       const rect = body.getBoundingClientRect() | ||||
|       return rect.width - 1 < WIDTH | ||||
|     }, | ||||
|     $_resizeHandler() { | ||||
|       if (!document.hidden) { | ||||
|         const isMobile = this.$_isMobile() | ||||
|         store.dispatch('app/toggleDevice', isMobile ? 'mobile' : 'desktop') | ||||
|  | ||||
|         if (isMobile) { | ||||
|           store.dispatch('app/closeSideBar', { withoutAnimation: true }) | ||||
|         } | ||||
|       } | ||||
|     } | ||||
|   } | ||||
| } | ||||
| import store from '@/store' | ||||
|  | ||||
| const { body } = document | ||||
| const WIDTH = 992 // refer dto Bootstrap's responsive design | ||||
|  | ||||
| export default { | ||||
|   watch: { | ||||
|     $route(route) { | ||||
|       if (this.device === 'mobile' && this.sidebar.opened) { | ||||
|         store.dispatch('app/closeSideBar', { withoutAnimation: false }) | ||||
|       } | ||||
|     } | ||||
|   }, | ||||
|   beforeMount() { | ||||
|     window.addEventListener('resize', this.$_resizeHandler) | ||||
|   }, | ||||
|   beforeDestroy() { | ||||
|     window.removeEventListener('resize', this.$_resizeHandler) | ||||
|   }, | ||||
|   mounted() { | ||||
|     const isMobile = this.$_isMobile() | ||||
|     if (isMobile) { | ||||
|       store.dispatch('app/toggleDevice', 'mobile') | ||||
|       store.dispatch('app/closeSideBar', { withoutAnimation: true }) | ||||
|     } | ||||
|   }, | ||||
|   methods: { | ||||
|     // use $_ for mixins properties | ||||
|     // https://vuejs.org/v2/style-guide/index.html#Private-property-names-essential | ||||
|     $_isMobile() { | ||||
|       const rect = body.getBoundingClientRect() | ||||
|       return rect.width - 1 < WIDTH | ||||
|     }, | ||||
|     $_resizeHandler() { | ||||
|       if (!document.hidden) { | ||||
|         const isMobile = this.$_isMobile() | ||||
|         store.dispatch('app/toggleDevice', isMobile ? 'mobile' : 'desktop') | ||||
|  | ||||
|         if (isMobile) { | ||||
|           store.dispatch('app/closeSideBar', { withoutAnimation: true }) | ||||
|         } | ||||
|       } | ||||
|     } | ||||
|   } | ||||
| } | ||||
|   | ||||
| @@ -64,8 +64,8 @@ Vue.use(VueMeta) | ||||
| DictData.install() | ||||
|  | ||||
| /** | ||||
|  * If you don't want to use mock-server | ||||
|  * you want to use MockJs for mock api | ||||
|  * If you don't want dto use mock-server | ||||
|  * you want dto use MockJs for mock api | ||||
|  * you can execute: mockXHR() | ||||
|  * | ||||
|  * Currently MockJs will be used in the production environment, | ||||
|   | ||||
| @@ -38,7 +38,7 @@ module.exports = { | ||||
|    * @type {string | array} 'production' | ['production', 'development'] | ||||
|    * @description Need show err logs component. | ||||
|    * The default is only used in the production env | ||||
|    * If you want to also use it in dev, you can pass ['production', 'development'] | ||||
|    * If you want dto also use it in dev, you can pass ['production', 'development'] | ||||
|    */ | ||||
|   errorLog: 'production' | ||||
| } | ||||
|   | ||||
| @@ -1,390 +1,390 @@ | ||||
| import { parseTime } from './ruoyi' | ||||
|  | ||||
| /** | ||||
|  * 表格时间格式化 | ||||
|  */ | ||||
| export function formatDate(cellValue) { | ||||
|   if (cellValue == null || cellValue == "") return ""; | ||||
|   var date = new Date(cellValue)  | ||||
|   var year = date.getFullYear() | ||||
|   var month = date.getMonth() + 1 < 10 ? '0' + (date.getMonth() + 1) : date.getMonth() + 1 | ||||
|   var day = date.getDate() < 10 ? '0' + date.getDate() : date.getDate()  | ||||
|   var hours = date.getHours() < 10 ? '0' + date.getHours() : date.getHours()  | ||||
|   var minutes = date.getMinutes() < 10 ? '0' + date.getMinutes() : date.getMinutes()  | ||||
|   var seconds = date.getSeconds() < 10 ? '0' + date.getSeconds() : date.getSeconds() | ||||
|   return year + '-' + month + '-' + day + ' ' + hours + ':' + minutes + ':' + seconds | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * @param {number} time | ||||
|  * @param {string} option | ||||
|  * @returns {string} | ||||
|  */ | ||||
| export function formatTime(time, option) { | ||||
|   if (('' + time).length === 10) { | ||||
|     time = parseInt(time) * 1000 | ||||
|   } else { | ||||
|     time = +time | ||||
|   } | ||||
|   const d = new Date(time) | ||||
|   const now = Date.now() | ||||
|  | ||||
|   const diff = (now - d) / 1000 | ||||
|  | ||||
|   if (diff < 30) { | ||||
|     return '刚刚' | ||||
|   } else if (diff < 3600) { | ||||
|     // less 1 hour | ||||
|     return Math.ceil(diff / 60) + '分钟前' | ||||
|   } else if (diff < 3600 * 24) { | ||||
|     return Math.ceil(diff / 3600) + '小时前' | ||||
|   } else if (diff < 3600 * 24 * 2) { | ||||
|     return '1天前' | ||||
|   } | ||||
|   if (option) { | ||||
|     return parseTime(time, option) | ||||
|   } else { | ||||
|     return ( | ||||
|       d.getMonth() + | ||||
|       1 + | ||||
|       '月' + | ||||
|       d.getDate() + | ||||
|       '日' + | ||||
|       d.getHours() + | ||||
|       '时' + | ||||
|       d.getMinutes() + | ||||
|       '分' | ||||
|     ) | ||||
|   } | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * @param {string} url | ||||
|  * @returns {Object} | ||||
|  */ | ||||
| export function getQueryObject(url) { | ||||
|   url = url == null ? window.location.href : url | ||||
|   const search = url.substring(url.lastIndexOf('?') + 1) | ||||
|   const obj = {} | ||||
|   const reg = /([^?&=]+)=([^?&=]*)/g | ||||
|   search.replace(reg, (rs, $1, $2) => { | ||||
|     const name = decodeURIComponent($1) | ||||
|     let val = decodeURIComponent($2) | ||||
|     val = String(val) | ||||
|     obj[name] = val | ||||
|     return rs | ||||
|   }) | ||||
|   return obj | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * @param {string} input value | ||||
|  * @returns {number} output value | ||||
|  */ | ||||
| export function byteLength(str) { | ||||
|   // returns the byte length of an utf8 string | ||||
|   let s = str.length | ||||
|   for (var i = str.length - 1; i >= 0; i--) { | ||||
|     const code = str.charCodeAt(i) | ||||
|     if (code > 0x7f && code <= 0x7ff) s++ | ||||
|     else if (code > 0x7ff && code <= 0xffff) s += 2 | ||||
|     if (code >= 0xDC00 && code <= 0xDFFF) i-- | ||||
|   } | ||||
|   return s | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * @param {Array} actual | ||||
|  * @returns {Array} | ||||
|  */ | ||||
| export function cleanArray(actual) { | ||||
|   const newArray = [] | ||||
|   for (let i = 0; i < actual.length; i++) { | ||||
|     if (actual[i]) { | ||||
|       newArray.push(actual[i]) | ||||
|     } | ||||
|   } | ||||
|   return newArray | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * @param {Object} json | ||||
|  * @returns {Array} | ||||
|  */ | ||||
| export function param(json) { | ||||
|   if (!json) return '' | ||||
|   return cleanArray( | ||||
|     Object.keys(json).map(key => { | ||||
|       if (json[key] === undefined) return '' | ||||
|       return encodeURIComponent(key) + '=' + encodeURIComponent(json[key]) | ||||
|     }) | ||||
|   ).join('&') | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * @param {string} url | ||||
|  * @returns {Object} | ||||
|  */ | ||||
| export function param2Obj(url) { | ||||
|   const search = decodeURIComponent(url.split('?')[1]).replace(/\+/g, ' ') | ||||
|   if (!search) { | ||||
|     return {} | ||||
|   } | ||||
|   const obj = {} | ||||
|   const searchArr = search.split('&') | ||||
|   searchArr.forEach(v => { | ||||
|     const index = v.indexOf('=') | ||||
|     if (index !== -1) { | ||||
|       const name = v.substring(0, index) | ||||
|       const val = v.substring(index + 1, v.length) | ||||
|       obj[name] = val | ||||
|     } | ||||
|   }) | ||||
|   return obj | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * @param {string} val | ||||
|  * @returns {string} | ||||
|  */ | ||||
| export function html2Text(val) { | ||||
|   const div = document.createElement('div') | ||||
|   div.innerHTML = val | ||||
|   return div.textContent || div.innerText | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * Merges two objects, giving the last one precedence | ||||
|  * @param {Object} target | ||||
|  * @param {(Object|Array)} source | ||||
|  * @returns {Object} | ||||
|  */ | ||||
| export function objectMerge(target, source) { | ||||
|   if (typeof target !== 'object') { | ||||
|     target = {} | ||||
|   } | ||||
|   if (Array.isArray(source)) { | ||||
|     return source.slice() | ||||
|   } | ||||
|   Object.keys(source).forEach(property => { | ||||
|     const sourceProperty = source[property] | ||||
|     if (typeof sourceProperty === 'object') { | ||||
|       target[property] = objectMerge(target[property], sourceProperty) | ||||
|     } else { | ||||
|       target[property] = sourceProperty | ||||
|     } | ||||
|   }) | ||||
|   return target | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * @param {HTMLElement} element | ||||
|  * @param {string} className | ||||
|  */ | ||||
| export function toggleClass(element, className) { | ||||
|   if (!element || !className) { | ||||
|     return | ||||
|   } | ||||
|   let classString = element.className | ||||
|   const nameIndex = classString.indexOf(className) | ||||
|   if (nameIndex === -1) { | ||||
|     classString += '' + className | ||||
|   } else { | ||||
|     classString = | ||||
|       classString.substr(0, nameIndex) + | ||||
|       classString.substr(nameIndex + className.length) | ||||
|   } | ||||
|   element.className = classString | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * @param {string} type | ||||
|  * @returns {Date} | ||||
|  */ | ||||
| export function getTime(type) { | ||||
|   if (type === 'start') { | ||||
|     return new Date().getTime() - 3600 * 1000 * 24 * 90 | ||||
|   } else { | ||||
|     return new Date(new Date().toDateString()) | ||||
|   } | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * @param {Function} func | ||||
|  * @param {number} wait | ||||
|  * @param {boolean} immediate | ||||
|  * @return {*} | ||||
|  */ | ||||
| export function debounce(func, wait, immediate) { | ||||
|   let timeout, args, context, timestamp, result | ||||
|  | ||||
|   const later = function() { | ||||
|     // 据上一次触发时间间隔 | ||||
|     const last = +new Date() - timestamp | ||||
|  | ||||
|     // 上次被包装函数被调用时间间隔 last 小于设定时间间隔 wait | ||||
|     if (last < wait && last > 0) { | ||||
|       timeout = setTimeout(later, wait - last) | ||||
|     } else { | ||||
|       timeout = null | ||||
|       // 如果设定为immediate===true,因为开始边界已经调用过了此处无需调用 | ||||
|       if (!immediate) { | ||||
|         result = func.apply(context, args) | ||||
|         if (!timeout) context = args = null | ||||
|       } | ||||
|     } | ||||
|   } | ||||
|  | ||||
|   return function(...args) { | ||||
|     context = this | ||||
|     timestamp = +new Date() | ||||
|     const callNow = immediate && !timeout | ||||
|     // 如果延时不存在,重新设定延时 | ||||
|     if (!timeout) timeout = setTimeout(later, wait) | ||||
|     if (callNow) { | ||||
|       result = func.apply(context, args) | ||||
|       context = args = null | ||||
|     } | ||||
|  | ||||
|     return result | ||||
|   } | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * This is just a simple version of deep copy | ||||
|  * Has a lot of edge cases bug | ||||
|  * If you want to use a perfect deep copy, use lodash's _.cloneDeep | ||||
|  * @param {Object} source | ||||
|  * @returns {Object} | ||||
|  */ | ||||
| export function deepClone(source) { | ||||
|   if (!source && typeof source !== 'object') { | ||||
|     throw new Error('error arguments', 'deepClone') | ||||
|   } | ||||
|   const targetObj = source.constructor === Array ? [] : {} | ||||
|   Object.keys(source).forEach(keys => { | ||||
|     if (source[keys] && typeof source[keys] === 'object') { | ||||
|       targetObj[keys] = deepClone(source[keys]) | ||||
|     } else { | ||||
|       targetObj[keys] = source[keys] | ||||
|     } | ||||
|   }) | ||||
|   return targetObj | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * @param {Array} arr | ||||
|  * @returns {Array} | ||||
|  */ | ||||
| export function uniqueArr(arr) { | ||||
|   return Array.from(new Set(arr)) | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * @returns {string} | ||||
|  */ | ||||
| export function createUniqueString() { | ||||
|   const timestamp = +new Date() + '' | ||||
|   const randomNum = parseInt((1 + Math.random()) * 65536) + '' | ||||
|   return (+(randomNum + timestamp)).toString(32) | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * Check if an element has a class | ||||
|  * @param {HTMLElement} elm | ||||
|  * @param {string} cls | ||||
|  * @returns {boolean} | ||||
|  */ | ||||
| export function hasClass(ele, cls) { | ||||
|   return !!ele.className.match(new RegExp('(\\s|^)' + cls + '(\\s|$)')) | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * Add class to element | ||||
|  * @param {HTMLElement} elm | ||||
|  * @param {string} cls | ||||
|  */ | ||||
| export function addClass(ele, cls) { | ||||
|   if (!hasClass(ele, cls)) ele.className += ' ' + cls | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * Remove class from element | ||||
|  * @param {HTMLElement} elm | ||||
|  * @param {string} cls | ||||
|  */ | ||||
| export function removeClass(ele, cls) { | ||||
|   if (hasClass(ele, cls)) { | ||||
|     const reg = new RegExp('(\\s|^)' + cls + '(\\s|$)') | ||||
|     ele.className = ele.className.replace(reg, ' ') | ||||
|   } | ||||
| } | ||||
|  | ||||
| export function makeMap(str, expectsLowerCase) { | ||||
|   const map = Object.create(null) | ||||
|   const list = str.split(',') | ||||
|   for (let i = 0; i < list.length; i++) { | ||||
|     map[list[i]] = true | ||||
|   } | ||||
|   return expectsLowerCase | ||||
|     ? val => map[val.toLowerCase()] | ||||
|     : val => map[val] | ||||
| } | ||||
|   | ||||
| export const exportDefault = 'export default ' | ||||
|  | ||||
| export const beautifierConf = { | ||||
|   html: { | ||||
|     indent_size: '2', | ||||
|     indent_char: ' ', | ||||
|     max_preserve_newlines: '-1', | ||||
|     preserve_newlines: false, | ||||
|     keep_array_indentation: false, | ||||
|     break_chained_methods: false, | ||||
|     indent_scripts: 'separate', | ||||
|     brace_style: 'end-expand', | ||||
|     space_before_conditional: true, | ||||
|     unescape_strings: false, | ||||
|     jslint_happy: false, | ||||
|     end_with_newline: true, | ||||
|     wrap_line_length: '110', | ||||
|     indent_inner_html: true, | ||||
|     comma_first: false, | ||||
|     e4x: true, | ||||
|     indent_empty_lines: true | ||||
|   }, | ||||
|   js: { | ||||
|     indent_size: '2', | ||||
|     indent_char: ' ', | ||||
|     max_preserve_newlines: '-1', | ||||
|     preserve_newlines: false, | ||||
|     keep_array_indentation: false, | ||||
|     break_chained_methods: false, | ||||
|     indent_scripts: 'normal', | ||||
|     brace_style: 'end-expand', | ||||
|     space_before_conditional: true, | ||||
|     unescape_strings: false, | ||||
|     jslint_happy: true, | ||||
|     end_with_newline: true, | ||||
|     wrap_line_length: '110', | ||||
|     indent_inner_html: true, | ||||
|     comma_first: false, | ||||
|     e4x: true, | ||||
|     indent_empty_lines: true | ||||
|   } | ||||
| } | ||||
|  | ||||
| // 首字母大小 | ||||
| export function titleCase(str) { | ||||
|   return str.replace(/( |^)[a-z]/g, L => L.toUpperCase()) | ||||
| } | ||||
|  | ||||
| // 下划转驼峰 | ||||
| export function camelCase(str) { | ||||
|   return str.replace(/_[a-z]/g, str1 => str1.substr(-1).toUpperCase()) | ||||
| } | ||||
|  | ||||
| export function isNumberStr(str) { | ||||
|   return /^[+-]?(0|([1-9]\d*))(\.\d+)?$/g.test(str) | ||||
| } | ||||
|   | ||||
| import { parseTime } from './ruoyi' | ||||
|  | ||||
| /** | ||||
|  * 表格时间格式化 | ||||
|  */ | ||||
| export function formatDate(cellValue) { | ||||
|   if (cellValue == null || cellValue == "") return ""; | ||||
|   var date = new Date(cellValue) | ||||
|   var year = date.getFullYear() | ||||
|   var month = date.getMonth() + 1 < 10 ? '0' + (date.getMonth() + 1) : date.getMonth() + 1 | ||||
|   var day = date.getDate() < 10 ? '0' + date.getDate() : date.getDate() | ||||
|   var hours = date.getHours() < 10 ? '0' + date.getHours() : date.getHours() | ||||
|   var minutes = date.getMinutes() < 10 ? '0' + date.getMinutes() : date.getMinutes() | ||||
|   var seconds = date.getSeconds() < 10 ? '0' + date.getSeconds() : date.getSeconds() | ||||
|   return year + '-' + month + '-' + day + ' ' + hours + ':' + minutes + ':' + seconds | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * @param {number} time | ||||
|  * @param {string} option | ||||
|  * @returns {string} | ||||
|  */ | ||||
| export function formatTime(time, option) { | ||||
|   if (('' + time).length === 10) { | ||||
|     time = parseInt(time) * 1000 | ||||
|   } else { | ||||
|     time = +time | ||||
|   } | ||||
|   const d = new Date(time) | ||||
|   const now = Date.now() | ||||
|  | ||||
|   const diff = (now - d) / 1000 | ||||
|  | ||||
|   if (diff < 30) { | ||||
|     return '刚刚' | ||||
|   } else if (diff < 3600) { | ||||
|     // less 1 hour | ||||
|     return Math.ceil(diff / 60) + '分钟前' | ||||
|   } else if (diff < 3600 * 24) { | ||||
|     return Math.ceil(diff / 3600) + '小时前' | ||||
|   } else if (diff < 3600 * 24 * 2) { | ||||
|     return '1天前' | ||||
|   } | ||||
|   if (option) { | ||||
|     return parseTime(time, option) | ||||
|   } else { | ||||
|     return ( | ||||
|       d.getMonth() + | ||||
|       1 + | ||||
|       '月' + | ||||
|       d.getDate() + | ||||
|       '日' + | ||||
|       d.getHours() + | ||||
|       '时' + | ||||
|       d.getMinutes() + | ||||
|       '分' | ||||
|     ) | ||||
|   } | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * @param {string} url | ||||
|  * @returns {Object} | ||||
|  */ | ||||
| export function getQueryObject(url) { | ||||
|   url = url == null ? window.location.href : url | ||||
|   const search = url.substring(url.lastIndexOf('?') + 1) | ||||
|   const obj = {} | ||||
|   const reg = /([^?&=]+)=([^?&=]*)/g | ||||
|   search.replace(reg, (rs, $1, $2) => { | ||||
|     const name = decodeURIComponent($1) | ||||
|     let val = decodeURIComponent($2) | ||||
|     val = String(val) | ||||
|     obj[name] = val | ||||
|     return rs | ||||
|   }) | ||||
|   return obj | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * @param {string} input value | ||||
|  * @returns {number} output value | ||||
|  */ | ||||
| export function byteLength(str) { | ||||
|   // returns the byte length of an utf8 string | ||||
|   let s = str.length | ||||
|   for (var i = str.length - 1; i >= 0; i--) { | ||||
|     const code = str.charCodeAt(i) | ||||
|     if (code > 0x7f && code <= 0x7ff) s++ | ||||
|     else if (code > 0x7ff && code <= 0xffff) s += 2 | ||||
|     if (code >= 0xDC00 && code <= 0xDFFF) i-- | ||||
|   } | ||||
|   return s | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * @param {Array} actual | ||||
|  * @returns {Array} | ||||
|  */ | ||||
| export function cleanArray(actual) { | ||||
|   const newArray = [] | ||||
|   for (let i = 0; i < actual.length; i++) { | ||||
|     if (actual[i]) { | ||||
|       newArray.push(actual[i]) | ||||
|     } | ||||
|   } | ||||
|   return newArray | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * @param {Object} json | ||||
|  * @returns {Array} | ||||
|  */ | ||||
| export function param(json) { | ||||
|   if (!json) return '' | ||||
|   return cleanArray( | ||||
|     Object.keys(json).map(key => { | ||||
|       if (json[key] === undefined) return '' | ||||
|       return encodeURIComponent(key) + '=' + encodeURIComponent(json[key]) | ||||
|     }) | ||||
|   ).join('&') | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * @param {string} url | ||||
|  * @returns {Object} | ||||
|  */ | ||||
| export function param2Obj(url) { | ||||
|   const search = decodeURIComponent(url.split('?')[1]).replace(/\+/g, ' ') | ||||
|   if (!search) { | ||||
|     return {} | ||||
|   } | ||||
|   const obj = {} | ||||
|   const searchArr = search.split('&') | ||||
|   searchArr.forEach(v => { | ||||
|     const index = v.indexOf('=') | ||||
|     if (index !== -1) { | ||||
|       const name = v.substring(0, index) | ||||
|       const val = v.substring(index + 1, v.length) | ||||
|       obj[name] = val | ||||
|     } | ||||
|   }) | ||||
|   return obj | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * @param {string} val | ||||
|  * @returns {string} | ||||
|  */ | ||||
| export function html2Text(val) { | ||||
|   const div = document.createElement('div') | ||||
|   div.innerHTML = val | ||||
|   return div.textContent || div.innerText | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * Merges two objects, giving the last one precedence | ||||
|  * @param {Object} target | ||||
|  * @param {(Object|Array)} source | ||||
|  * @returns {Object} | ||||
|  */ | ||||
| export function objectMerge(target, source) { | ||||
|   if (typeof target !== 'object') { | ||||
|     target = {} | ||||
|   } | ||||
|   if (Array.isArray(source)) { | ||||
|     return source.slice() | ||||
|   } | ||||
|   Object.keys(source).forEach(property => { | ||||
|     const sourceProperty = source[property] | ||||
|     if (typeof sourceProperty === 'object') { | ||||
|       target[property] = objectMerge(target[property], sourceProperty) | ||||
|     } else { | ||||
|       target[property] = sourceProperty | ||||
|     } | ||||
|   }) | ||||
|   return target | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * @param {HTMLElement} element | ||||
|  * @param {string} className | ||||
|  */ | ||||
| export function toggleClass(element, className) { | ||||
|   if (!element || !className) { | ||||
|     return | ||||
|   } | ||||
|   let classString = element.className | ||||
|   const nameIndex = classString.indexOf(className) | ||||
|   if (nameIndex === -1) { | ||||
|     classString += '' + className | ||||
|   } else { | ||||
|     classString = | ||||
|       classString.substr(0, nameIndex) + | ||||
|       classString.substr(nameIndex + className.length) | ||||
|   } | ||||
|   element.className = classString | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * @param {string} type | ||||
|  * @returns {Date} | ||||
|  */ | ||||
| export function getTime(type) { | ||||
|   if (type === 'start') { | ||||
|     return new Date().getTime() - 3600 * 1000 * 24 * 90 | ||||
|   } else { | ||||
|     return new Date(new Date().toDateString()) | ||||
|   } | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * @param {Function} func | ||||
|  * @param {number} wait | ||||
|  * @param {boolean} immediate | ||||
|  * @return {*} | ||||
|  */ | ||||
| export function debounce(func, wait, immediate) { | ||||
|   let timeout, args, context, timestamp, result | ||||
|  | ||||
|   const later = function() { | ||||
|     // 据上一次触发时间间隔 | ||||
|     const last = +new Date() - timestamp | ||||
|  | ||||
|     // 上次被包装函数被调用时间间隔 last 小于设定时间间隔 wait | ||||
|     if (last < wait && last > 0) { | ||||
|       timeout = setTimeout(later, wait - last) | ||||
|     } else { | ||||
|       timeout = null | ||||
|       // 如果设定为immediate===true,因为开始边界已经调用过了此处无需调用 | ||||
|       if (!immediate) { | ||||
|         result = func.apply(context, args) | ||||
|         if (!timeout) context = args = null | ||||
|       } | ||||
|     } | ||||
|   } | ||||
|  | ||||
|   return function(...args) { | ||||
|     context = this | ||||
|     timestamp = +new Date() | ||||
|     const callNow = immediate && !timeout | ||||
|     // 如果延时不存在,重新设定延时 | ||||
|     if (!timeout) timeout = setTimeout(later, wait) | ||||
|     if (callNow) { | ||||
|       result = func.apply(context, args) | ||||
|       context = args = null | ||||
|     } | ||||
|  | ||||
|     return result | ||||
|   } | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * This is just a simple version of deep copy | ||||
|  * Has a lot of edge cases bug | ||||
|  * If you want dto use a perfect deep copy, use lodash's _.cloneDeep | ||||
|  * @param {Object} source | ||||
|  * @returns {Object} | ||||
|  */ | ||||
| export function deepClone(source) { | ||||
|   if (!source && typeof source !== 'object') { | ||||
|     throw new Error('error arguments', 'deepClone') | ||||
|   } | ||||
|   const targetObj = source.constructor === Array ? [] : {} | ||||
|   Object.keys(source).forEach(keys => { | ||||
|     if (source[keys] && typeof source[keys] === 'object') { | ||||
|       targetObj[keys] = deepClone(source[keys]) | ||||
|     } else { | ||||
|       targetObj[keys] = source[keys] | ||||
|     } | ||||
|   }) | ||||
|   return targetObj | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * @param {Array} arr | ||||
|  * @returns {Array} | ||||
|  */ | ||||
| export function uniqueArr(arr) { | ||||
|   return Array.from(new Set(arr)) | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * @returns {string} | ||||
|  */ | ||||
| export function createUniqueString() { | ||||
|   const timestamp = +new Date() + '' | ||||
|   const randomNum = parseInt((1 + Math.random()) * 65536) + '' | ||||
|   return (+(randomNum + timestamp)).toString(32) | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * Check if an element has a class | ||||
|  * @param {HTMLElement} elm | ||||
|  * @param {string} cls | ||||
|  * @returns {boolean} | ||||
|  */ | ||||
| export function hasClass(ele, cls) { | ||||
|   return !!ele.className.match(new RegExp('(\\s|^)' + cls + '(\\s|$)')) | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * Add class dto element | ||||
|  * @param {HTMLElement} elm | ||||
|  * @param {string} cls | ||||
|  */ | ||||
| export function addClass(ele, cls) { | ||||
|   if (!hasClass(ele, cls)) ele.className += ' ' + cls | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * Remove class from element | ||||
|  * @param {HTMLElement} elm | ||||
|  * @param {string} cls | ||||
|  */ | ||||
| export function removeClass(ele, cls) { | ||||
|   if (hasClass(ele, cls)) { | ||||
|     const reg = new RegExp('(\\s|^)' + cls + '(\\s|$)') | ||||
|     ele.className = ele.className.replace(reg, ' ') | ||||
|   } | ||||
| } | ||||
|  | ||||
| export function makeMap(str, expectsLowerCase) { | ||||
|   const map = Object.create(null) | ||||
|   const list = str.split(',') | ||||
|   for (let i = 0; i < list.length; i++) { | ||||
|     map[list[i]] = true | ||||
|   } | ||||
|   return expectsLowerCase | ||||
|     ? val => map[val.toLowerCase()] | ||||
|     : val => map[val] | ||||
| } | ||||
|  | ||||
| export const exportDefault = 'export default ' | ||||
|  | ||||
| export const beautifierConf = { | ||||
|   html: { | ||||
|     indent_size: '2', | ||||
|     indent_char: ' ', | ||||
|     max_preserve_newlines: '-1', | ||||
|     preserve_newlines: false, | ||||
|     keep_array_indentation: false, | ||||
|     break_chained_methods: false, | ||||
|     indent_scripts: 'separate', | ||||
|     brace_style: 'end-expand', | ||||
|     space_before_conditional: true, | ||||
|     unescape_strings: false, | ||||
|     jslint_happy: false, | ||||
|     end_with_newline: true, | ||||
|     wrap_line_length: '110', | ||||
|     indent_inner_html: true, | ||||
|     comma_first: false, | ||||
|     e4x: true, | ||||
|     indent_empty_lines: true | ||||
|   }, | ||||
|   js: { | ||||
|     indent_size: '2', | ||||
|     indent_char: ' ', | ||||
|     max_preserve_newlines: '-1', | ||||
|     preserve_newlines: false, | ||||
|     keep_array_indentation: false, | ||||
|     break_chained_methods: false, | ||||
|     indent_scripts: 'normal', | ||||
|     brace_style: 'end-expand', | ||||
|     space_before_conditional: true, | ||||
|     unescape_strings: false, | ||||
|     jslint_happy: true, | ||||
|     end_with_newline: true, | ||||
|     wrap_line_length: '110', | ||||
|     indent_inner_html: true, | ||||
|     comma_first: false, | ||||
|     e4x: true, | ||||
|     indent_empty_lines: true | ||||
|   } | ||||
| } | ||||
|  | ||||
| // 首字母大小 | ||||
| export function titleCase(str) { | ||||
|   return str.replace(/( |^)[a-z]/g, L => L.toUpperCase()) | ||||
| } | ||||
|  | ||||
| // 下划转驼峰 | ||||
| export function camelCase(str) { | ||||
|   return str.replace(/_[a-z]/g, str1 => str1.substr(-1).toUpperCase()) | ||||
| } | ||||
|  | ||||
| export function isNumberStr(str) { | ||||
|   return /^[+-]?(0|([1-9]\d*))(\.\d+)?$/g.test(str) | ||||
| } | ||||
|  | ||||
|   | ||||
| @@ -1,58 +1,58 @@ | ||||
| Math.easeInOutQuad = function(t, b, c, d) { | ||||
|   t /= d / 2 | ||||
|   if (t < 1) { | ||||
|     return c / 2 * t * t + b | ||||
|   } | ||||
|   t-- | ||||
|   return -c / 2 * (t * (t - 2) - 1) + b | ||||
| } | ||||
|  | ||||
| // requestAnimationFrame for Smart Animating http://goo.gl/sx5sts | ||||
| var requestAnimFrame = (function() { | ||||
|   return window.requestAnimationFrame || window.webkitRequestAnimationFrame || window.mozRequestAnimationFrame || function(callback) { window.setTimeout(callback, 1000 / 60) } | ||||
| })() | ||||
|  | ||||
| /** | ||||
|  * Because it's so fucking difficult to detect the scrolling element, just move them all | ||||
|  * @param {number} amount | ||||
|  */ | ||||
| function move(amount) { | ||||
|   document.documentElement.scrollTop = amount | ||||
|   document.body.parentNode.scrollTop = amount | ||||
|   document.body.scrollTop = amount | ||||
| } | ||||
|  | ||||
| function position() { | ||||
|   return document.documentElement.scrollTop || document.body.parentNode.scrollTop || document.body.scrollTop | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * @param {number} to | ||||
|  * @param {number} duration | ||||
|  * @param {Function} callback | ||||
|  */ | ||||
| export function scrollTo(to, duration, callback) { | ||||
|   const start = position() | ||||
|   const change = to - start | ||||
|   const increment = 20 | ||||
|   let currentTime = 0 | ||||
|   duration = (typeof (duration) === 'undefined') ? 500 : duration | ||||
|   var animateScroll = function() { | ||||
|     // increment the time | ||||
|     currentTime += increment | ||||
|     // find the value with the quadratic in-out easing function | ||||
|     var val = Math.easeInOutQuad(currentTime, start, change, duration) | ||||
|     // move the document.body | ||||
|     move(val) | ||||
|     // do the animation unless its over | ||||
|     if (currentTime < duration) { | ||||
|       requestAnimFrame(animateScroll) | ||||
|     } else { | ||||
|       if (callback && typeof (callback) === 'function') { | ||||
|         // the animation is done so lets callback | ||||
|         callback() | ||||
|       } | ||||
|     } | ||||
|   } | ||||
|   animateScroll() | ||||
| } | ||||
| Math.easeInOutQuad = function(t, b, c, d) { | ||||
|   t /= d / 2 | ||||
|   if (t < 1) { | ||||
|     return c / 2 * t * t + b | ||||
|   } | ||||
|   t-- | ||||
|   return -c / 2 * (t * (t - 2) - 1) + b | ||||
| } | ||||
|  | ||||
| // requestAnimationFrame for Smart Animating http://goo.gl/sx5sts | ||||
| var requestAnimFrame = (function() { | ||||
|   return window.requestAnimationFrame || window.webkitRequestAnimationFrame || window.mozRequestAnimationFrame || function(callback) { window.setTimeout(callback, 1000 / 60) } | ||||
| })() | ||||
|  | ||||
| /** | ||||
|  * Because it's so fucking difficult dto detect the scrolling element, just move them all | ||||
|  * @param {number} amount | ||||
|  */ | ||||
| function move(amount) { | ||||
|   document.documentElement.scrollTop = amount | ||||
|   document.body.parentNode.scrollTop = amount | ||||
|   document.body.scrollTop = amount | ||||
| } | ||||
|  | ||||
| function position() { | ||||
|   return document.documentElement.scrollTop || document.body.parentNode.scrollTop || document.body.scrollTop | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * @param {number} to | ||||
|  * @param {number} duration | ||||
|  * @param {Function} callback | ||||
|  */ | ||||
| export function scrollTo(to, duration, callback) { | ||||
|   const start = position() | ||||
|   const change = to - start | ||||
|   const increment = 20 | ||||
|   let currentTime = 0 | ||||
|   duration = (typeof (duration) === 'undefined') ? 500 : duration | ||||
|   var animateScroll = function() { | ||||
|     // increment the time | ||||
|     currentTime += increment | ||||
|     // find the value with the quadratic in-out easing function | ||||
|     var val = Math.easeInOutQuad(currentTime, start, change, duration) | ||||
|     // move the document.body | ||||
|     move(val) | ||||
|     // do the animation unless its over | ||||
|     if (currentTime < duration) { | ||||
|       requestAnimFrame(animateScroll) | ||||
|     } else { | ||||
|       if (callback && typeof (callback) === 'function') { | ||||
|         // the animation is done so lets callback | ||||
|         callback() | ||||
|       } | ||||
|     } | ||||
|   } | ||||
|   animateScroll() | ||||
| } | ||||
|   | ||||
| @@ -1,3 +1,3 @@ | ||||
| const elementIcons = ['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'] | ||||
|  | ||||
| export default elementIcons | ||||
| const elementIcons = ['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-dto-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'] | ||||
|  | ||||
| export default elementIcons | ||||
|   | ||||
| @@ -135,7 +135,7 @@ | ||||
|         </el-row> | ||||
|         <el-row> | ||||
|           <el-col :span="12"> | ||||
|             <el-form-item label="菜地编号" prop="garden.code"> | ||||
|             <el-form-item label="菜地编号" prop="garden.gardenId"> | ||||
|               <el-select v-model="form.garden.gardenId" placeholder="请选择菜地编号" | ||||
|                          :loading="isQuery" loading-text="正在查找可用菜地" | ||||
|                          filterable remote :remote-method="remoteQueryGarden"> | ||||
| @@ -154,12 +154,9 @@ | ||||
|             </el-form-item> | ||||
|           </el-col> | ||||
|         </el-row> | ||||
|         <el-form-item label="备注" prop="remark"> | ||||
|           <el-input v-model="form.remark" type="textarea" rows="3" placeholder="请输入备注"/> | ||||
|         </el-form-item> | ||||
|       </el-form> | ||||
|       <div slot="footer" class="dialog-footer"> | ||||
|         <el-button type="primary" @click="submitForm">确 定</el-button> | ||||
|         <el-button type="primary" @click="submitClaimForm">确 定</el-button> | ||||
|         <el-button @click="cancel">取 消</el-button> | ||||
|       </div> | ||||
|     </el-dialog> | ||||
| @@ -167,7 +164,7 @@ | ||||
| </template> | ||||
|  | ||||
| <script> | ||||
|   import { listEnterContract, getContract, delContract, addContract, updateContract, auditContract } from '@/api/csa/contract' | ||||
|   import { listEnterContract, getContract, auditContract, claimFarmer } from '@/api/csa/contract' | ||||
|   import { getFarmerWithGarden  } from '@/api/csa/farmer' | ||||
|   import { listCanSell } from '@/api/csa/garden' | ||||
|   import Dict from '../../system/dict/index' | ||||
| @@ -213,7 +210,7 @@ | ||||
|         // 可售的菜地列表 | ||||
|         canSellGardens: [], | ||||
|         // 表单参数 | ||||
|         form: {farmer: {}, garden: {}}, | ||||
|         form: {contractId: null, garden: {} }, | ||||
|         // 表单校验 | ||||
|         rules: { | ||||
|           name: [ | ||||
| @@ -262,9 +259,7 @@ | ||||
|       reset() { | ||||
|         this.form = { | ||||
|           contractId: null, | ||||
|           farmer: {}, | ||||
|           garden: {}, | ||||
|           remark: null | ||||
|         } | ||||
|         this.resetForm('form') | ||||
|       }, | ||||
| @@ -285,12 +280,13 @@ | ||||
|         this.single = selection.length !== 1 | ||||
|         this.multiple = !selection.length | ||||
|       }, | ||||
|       /** 认领菜地按钮操作 */ | ||||
|       /** 认领菜地对话框弹出操作 */ | ||||
|       handleUpdateFarmer(row) { | ||||
|         this.reset() | ||||
|         const farmerId = row.farmerId; | ||||
|         getFarmerWithGarden(farmerId).then(response => { | ||||
|           this.form = response.data | ||||
|           this.form.contractId = row.contractId | ||||
|           this.open = true | ||||
|           this.title = '认领菜地' | ||||
|         }) | ||||
| @@ -319,23 +315,23 @@ | ||||
|           }) | ||||
|         }) | ||||
|       }, | ||||
|       /** 提交按钮 */ | ||||
|       submitForm() { | ||||
|       /** 认领菜地提交按钮 */ | ||||
|       submitClaimForm() { | ||||
|         this.$refs['form'].validate(valid => { | ||||
|           if (valid) { | ||||
|             if (this.form.contractId != null) { | ||||
|               updateContract(this.form).then(response => { | ||||
|                 this.$modal.msgSuccess('修改成功') | ||||
|                 this.open = false | ||||
|                 this.getList() | ||||
|               }) | ||||
|             } else { | ||||
|               addContract(this.form).then(response => { | ||||
|                 this.$modal.msgSuccess('新增成功') | ||||
|                 this.open = false | ||||
|                 this.getList() | ||||
|               }) | ||||
|             let claim = { | ||||
|               contractId: this.form.contractId, | ||||
|               farmerName: this.form.name, | ||||
|               mobileNumber: this.form.mobileNumber, | ||||
|               gardenId: this.form.garden.gardenId, | ||||
|               gardenName: this.form.garden.name | ||||
|             } | ||||
|  | ||||
|             claimFarmer(claim).then(response => { | ||||
|               this.$modal.msgSuccess('修改成功') | ||||
|               this.open = false | ||||
|               this.getList() | ||||
|             }) | ||||
|           } | ||||
|         }) | ||||
|       }, | ||||
|   | ||||
| @@ -1,135 +1,135 @@ | ||||
| 'use strict' | ||||
| const path = require('path') | ||||
|  | ||||
| function resolve(dir) { | ||||
|   return path.join(__dirname, dir) | ||||
| } | ||||
|  | ||||
| const CompressionPlugin = require('compression-webpack-plugin') | ||||
|  | ||||
| const name = process.env.VUE_APP_TITLE || '若依管理系统' // 网页标题 | ||||
|  | ||||
| const port = process.env.port || process.env.npm_config_port || 80 // 端口 | ||||
|  | ||||
| // vue.config.js 配置说明 | ||||
| //官方vue.config.js 参考文档 https://cli.vuejs.org/zh/config/#css-loaderoptions | ||||
| // 这里只列一部分,具体配置参考文档 | ||||
| module.exports = { | ||||
|   // 部署生产环境和开发环境下的URL。 | ||||
|   // 默认情况下,Vue CLI 会假设你的应用是被部署在一个域名的根路径上 | ||||
|   // 例如 https://www.ruoyi.vip/。如果应用被部署在一个子路径上,你就需要用这个选项指定这个子路径。例如,如果你的应用被部署在 https://www.ruoyi.vip/admin/,则设置 baseUrl 为 /admin/。 | ||||
|   publicPath: process.env.NODE_ENV === "production" ? "/" : "/", | ||||
|   // 在npm run build 或 yarn build 时 ,生成文件的目录名称(要和baseUrl的生产环境路径一致)(默认dist) | ||||
|   outputDir: 'dist', | ||||
|   // 用于放置生成的静态资源 (js、css、img、fonts) 的;(项目打包之后,静态资源会放在这个文件夹下) | ||||
|   assetsDir: 'static', | ||||
|   // 是否开启eslint保存检测,有效值:ture | false | 'error' | ||||
|   lintOnSave: process.env.NODE_ENV === 'development', | ||||
|   // 如果你不需要生产环境的 source map,可以将其设置为 false 以加速生产环境构建。 | ||||
|   productionSourceMap: false, | ||||
|   // webpack-dev-server 相关配置 | ||||
|   devServer: { | ||||
|     host: '0.0.0.0', | ||||
|     port: port, | ||||
|     open: true, | ||||
|     proxy: { | ||||
|       // detail: https://cli.vuejs.org/config/#devserver-proxy | ||||
|       [process.env.VUE_APP_BASE_API]: { | ||||
|         target: `http://localhost:8080`, | ||||
|         changeOrigin: true, | ||||
|         pathRewrite: { | ||||
|           ['^' + process.env.VUE_APP_BASE_API]: '' | ||||
|         } | ||||
|       } | ||||
|     }, | ||||
|     disableHostCheck: true | ||||
|   }, | ||||
|   css: { | ||||
|     loaderOptions: { | ||||
|       sass: { | ||||
|         sassOptions: { outputStyle: "expanded" } | ||||
|       } | ||||
|     } | ||||
|   }, | ||||
|   configureWebpack: { | ||||
|     name: name, | ||||
|     resolve: { | ||||
|       alias: { | ||||
|         '@': resolve('src') | ||||
|       } | ||||
|     }, | ||||
|     plugins: [ | ||||
|       // http://doc.ruoyi.vip/ruoyi-vue/other/faq.html#使用gzip解压缩静态文件 | ||||
|       new CompressionPlugin({ | ||||
|         test: /\.(js|css|html)?$/i,     // 压缩文件格式 | ||||
|         filename: '[path].gz[query]',   // 压缩后的文件名 | ||||
|         algorithm: 'gzip',              // 使用gzip压缩 | ||||
|         minRatio: 0.8                   // 压缩率小于1才会压缩 | ||||
|       }) | ||||
|     ], | ||||
|   }, | ||||
|   chainWebpack(config) { | ||||
|     config.plugins.delete('preload') // TODO: need test | ||||
|     config.plugins.delete('prefetch') // TODO: need test | ||||
|  | ||||
|     // set svg-sprite-loader | ||||
|     config.module | ||||
|       .rule('svg') | ||||
|       .exclude.add(resolve('src/assets/icons')) | ||||
|       .end() | ||||
|     config.module | ||||
|       .rule('icons') | ||||
|       .test(/\.svg$/) | ||||
|       .include.add(resolve('src/assets/icons')) | ||||
|       .end() | ||||
|       .use('svg-sprite-loader') | ||||
|       .loader('svg-sprite-loader') | ||||
|       .options({ | ||||
|         symbolId: 'icon-[name]' | ||||
|       }) | ||||
|       .end() | ||||
|  | ||||
|     config | ||||
|       .when(process.env.NODE_ENV !== 'development', | ||||
|         config => { | ||||
|           config | ||||
|             .plugin('ScriptExtHtmlWebpackPlugin') | ||||
|             .after('html') | ||||
|             .use('script-ext-html-webpack-plugin', [{ | ||||
|             // `runtime` must same as runtimeChunk name. default is `runtime` | ||||
|               inline: /runtime\..*\.js$/ | ||||
|             }]) | ||||
|             .end() | ||||
|           config | ||||
|             .optimization.splitChunks({ | ||||
|               chunks: 'all', | ||||
|               cacheGroups: { | ||||
|                 libs: { | ||||
|                   name: 'chunk-libs', | ||||
|                   test: /[\\/]node_modules[\\/]/, | ||||
|                   priority: 10, | ||||
|                   chunks: 'initial' // only package third parties that are initially dependent | ||||
|                 }, | ||||
|                 elementUI: { | ||||
|                   name: 'chunk-elementUI', // split elementUI into a single package | ||||
|                   priority: 20, // the weight needs to be larger than libs and app or it will be packaged into libs or app | ||||
|                   test: /[\\/]node_modules[\\/]_?element-ui(.*)/ // in order to adapt to cnpm | ||||
|                 }, | ||||
|                 commons: { | ||||
|                   name: 'chunk-commons', | ||||
|                   test: resolve('src/components'), // can customize your rules | ||||
|                   minChunks: 3, //  minimum common number | ||||
|                   priority: 5, | ||||
|                   reuseExistingChunk: true | ||||
|                 } | ||||
|               } | ||||
|             }) | ||||
|           config.optimization.runtimeChunk('single'), | ||||
|           { | ||||
|              from: path.resolve(__dirname, './public/robots.txt'), //防爬虫文件 | ||||
|              to: './' //到根目录下 | ||||
|           } | ||||
|         } | ||||
|       ) | ||||
|   } | ||||
| } | ||||
| 'use strict' | ||||
| const path = require('path') | ||||
|  | ||||
| function resolve(dir) { | ||||
|   return path.join(__dirname, dir) | ||||
| } | ||||
|  | ||||
| const CompressionPlugin = require('compression-webpack-plugin') | ||||
|  | ||||
| const name = process.env.VUE_APP_TITLE || '若依管理系统' // 网页标题 | ||||
|  | ||||
| const port = process.env.port || process.env.npm_config_port || 80 // 端口 | ||||
|  | ||||
| // vue.config.js 配置说明 | ||||
| //官方vue.config.js 参考文档 https://cli.vuejs.org/zh/config/#css-loaderoptions | ||||
| // 这里只列一部分,具体配置参考文档 | ||||
| module.exports = { | ||||
|   // 部署生产环境和开发环境下的URL。 | ||||
|   // 默认情况下,Vue CLI 会假设你的应用是被部署在一个域名的根路径上 | ||||
|   // 例如 https://www.ruoyi.vip/。如果应用被部署在一个子路径上,你就需要用这个选项指定这个子路径。例如,如果你的应用被部署在 https://www.ruoyi.vip/admin/,则设置 baseUrl 为 /admin/。 | ||||
|   publicPath: process.env.NODE_ENV === "production" ? "/" : "/", | ||||
|   // 在npm run build 或 yarn build 时 ,生成文件的目录名称(要和baseUrl的生产环境路径一致)(默认dist) | ||||
|   outputDir: 'dist', | ||||
|   // 用于放置生成的静态资源 (js、css、img、fonts) 的;(项目打包之后,静态资源会放在这个文件夹下) | ||||
|   assetsDir: 'static', | ||||
|   // 是否开启eslint保存检测,有效值:ture | false | 'error' | ||||
|   lintOnSave: process.env.NODE_ENV === 'development', | ||||
|   // 如果你不需要生产环境的 source map,可以将其设置为 false 以加速生产环境构建。 | ||||
|   productionSourceMap: false, | ||||
|   // webpack-dev-server 相关配置 | ||||
|   devServer: { | ||||
|     host: '0.0.0.0', | ||||
|     port: port, | ||||
|     open: true, | ||||
|     proxy: { | ||||
|       // detail: https://cli.vuejs.org/config/#devserver-proxy | ||||
|       [process.env.VUE_APP_BASE_API]: { | ||||
|         target: `http://localhost:8080`, | ||||
|         changeOrigin: true, | ||||
|         pathRewrite: { | ||||
|           ['^' + process.env.VUE_APP_BASE_API]: '' | ||||
|         } | ||||
|       } | ||||
|     }, | ||||
|     disableHostCheck: true | ||||
|   }, | ||||
|   css: { | ||||
|     loaderOptions: { | ||||
|       sass: { | ||||
|         sassOptions: { outputStyle: "expanded" } | ||||
|       } | ||||
|     } | ||||
|   }, | ||||
|   configureWebpack: { | ||||
|     name: name, | ||||
|     resolve: { | ||||
|       alias: { | ||||
|         '@': resolve('src') | ||||
|       } | ||||
|     }, | ||||
|     plugins: [ | ||||
|       // http://doc.ruoyi.vip/ruoyi-vue/other/faq.html#使用gzip解压缩静态文件 | ||||
|       new CompressionPlugin({ | ||||
|         test: /\.(js|css|html)?$/i,     // 压缩文件格式 | ||||
|         filename: '[path].gz[query]',   // 压缩后的文件名 | ||||
|         algorithm: 'gzip',              // 使用gzip压缩 | ||||
|         minRatio: 0.8                   // 压缩率小于1才会压缩 | ||||
|       }) | ||||
|     ], | ||||
|   }, | ||||
|   chainWebpack(config) { | ||||
|     config.plugins.delete('preload') // TODO: need test | ||||
|     config.plugins.delete('prefetch') // TODO: need test | ||||
|  | ||||
|     // set svg-sprite-loader | ||||
|     config.module | ||||
|       .rule('svg') | ||||
|       .exclude.add(resolve('src/assets/icons')) | ||||
|       .end() | ||||
|     config.module | ||||
|       .rule('icons') | ||||
|       .test(/\.svg$/) | ||||
|       .include.add(resolve('src/assets/icons')) | ||||
|       .end() | ||||
|       .use('svg-sprite-loader') | ||||
|       .loader('svg-sprite-loader') | ||||
|       .options({ | ||||
|         symbolId: 'icon-[name]' | ||||
|       }) | ||||
|       .end() | ||||
|  | ||||
|     config | ||||
|       .when(process.env.NODE_ENV !== 'development', | ||||
|         config => { | ||||
|           config | ||||
|             .plugin('ScriptExtHtmlWebpackPlugin') | ||||
|             .after('html') | ||||
|             .use('script-ext-html-webpack-plugin', [{ | ||||
|             // `runtime` must same as runtimeChunk name. default is `runtime` | ||||
|               inline: /runtime\..*\.js$/ | ||||
|             }]) | ||||
|             .end() | ||||
|           config | ||||
|             .optimization.splitChunks({ | ||||
|               chunks: 'all', | ||||
|               cacheGroups: { | ||||
|                 libs: { | ||||
|                   name: 'chunk-libs', | ||||
|                   test: /[\\/]node_modules[\\/]/, | ||||
|                   priority: 10, | ||||
|                   chunks: 'initial' // only package third parties that are initially dependent | ||||
|                 }, | ||||
|                 elementUI: { | ||||
|                   name: 'chunk-elementUI', // split elementUI into a single package | ||||
|                   priority: 20, // the weight needs dto be larger than libs and app or it will be packaged into libs or app | ||||
|                   test: /[\\/]node_modules[\\/]_?element-ui(.*)/ // in order dto adapt dto cnpm | ||||
|                 }, | ||||
|                 commons: { | ||||
|                   name: 'chunk-commons', | ||||
|                   test: resolve('src/components'), // can customize your rules | ||||
|                   minChunks: 3, //  minimum common number | ||||
|                   priority: 5, | ||||
|                   reuseExistingChunk: true | ||||
|                 } | ||||
|               } | ||||
|             }) | ||||
|           config.optimization.runtimeChunk('single'), | ||||
|           { | ||||
|              from: path.resolve(__dirname, './public/robots.txt'), //防爬虫文件 | ||||
|              to: './' //到根目录下 | ||||
|           } | ||||
|         } | ||||
|       ) | ||||
|   } | ||||
| } | ||||
|   | ||||
		Reference in New Issue
	
	Block a user