From 533cdc5d40a9bc24f0f10618508a1fe944d4e014 Mon Sep 17 00:00:00 2001 From: zuozhengqing <a13193816592@163.com> Date: 星期二, 09 一月 2024 17:01:16 +0800 Subject: [PATCH] Merge branch 'dev' of ssh://192.168.5.5:29418/web/crm-web into dev --- src/views/sales/quotation/AddQuotationDialog.vue | 4 src/views/sales/masterOrder/AddMasterOrderDialog.vue | 20 ++++ src/api/date.js | 210 ++++++++++++++++++++++++++++++++++++++++++++++++++++ 3 files changed, 231 insertions(+), 3 deletions(-) diff --git a/src/api/date.js b/src/api/date.js new file mode 100644 index 0000000..c7ea884 --- /dev/null +++ b/src/api/date.js @@ -0,0 +1,210 @@ +export default (() => { + const getDateObj = ms => { + const now = ms ? new Date(ms) : new Date() + const y = now.getFullYear() + let m = now.getMonth() + 1 + m = m > 9 ? m : '0' + m + let d = now.getDate() + d = d > 9 ? d : '0' + d + return { y, m, d } + } + // 鑾峰彇褰撳墠鏃ユ湡 + const getCurrentDate = ms => { + const dateObj = getDateObj(ms) + return '' + dateObj.y + '-' + dateObj.m + '-' + dateObj.d + } + //鑾峰彇褰撳墠 鍓嶅悗N澶╃殑鏃堕棿 + const getDateStr = (AddDayCount = 0) => { + let dd = new Date() + dd.setDate(dd.getDate() + AddDayCount) + let y = dd.getFullYear() + let m = (dd.getMonth() + 1) < 10 ? '0' + (dd.getMonth() + 1) : (dd.getMonth() + 1) //鑾峰彇褰撳墠鏈堜唤鐨勬棩鏈燂紝涓嶈冻10琛�0 + let d = dd.getDate() < 10 ? '0' + dd.getDate() : dd.getDate() //鑾峰彇褰撳墠鍑犲彿锛屼笉瓒�10琛�0 + return y + '-' + m + '-' + d + } + //鑾峰彇鏌愪釜鏃ユ湡 鍓嶅悗N澶╃殑鏃堕棿 + const getDateDay2 = (time, AddDayCount) => { + if (time) { + let dd = new Date(time) + dd.setDate(dd.getDate() + AddDayCount) + let y = dd.getFullYear() + let m = (dd.getMonth() + 1) < 10 ? '0' + (dd.getMonth() + 1) : (dd.getMonth() + 1) //鑾峰彇褰撳墠鏈堜唤鐨勬棩鏈燂紝涓嶈冻10琛�0 + let d = dd.getDate() < 10 ? '0' + dd.getDate() : dd.getDate() //鑾峰彇褰撳墠鍑犲彿锛屼笉瓒�10琛�0 + return y + '-' + m + '-' + d + } else { + return '--' + } + } + //鑾峰彇褰撳墠骞翠唤 + const getCurrentYear = ms => { + const dateObj = getDateObj(ms) + return '' + dateObj.y + } + // 鑾峰彇褰撳墠鏈堜唤 + const getCurrentMonth = ms => { + const dateObj = getDateObj(ms) + return '' + dateObj.y + '-' + dateObj.m + } + // 鑾峰彇涓婃湀鏈堜唤 + const getPreviousMonth = ms => { + const dateObj = getDateObj(ms) + const b = dateObj.m - 1 > 0 + let y = b ? dateObj.y : dateObj.y - 1 + let m = b ? dateObj.m - 1 : 12 + m = m > 9 ? m : '0' + m + return '' + y + '-' + m + } + // 鑾峰彇涓嬫湀鏈堜唤 + const getNextMonth = ms => { + const dateObj = getDateObj(ms) + const b = dateObj.m - (-1) != 13; + let y = b ? dateObj.y : dateObj.y + 1 + let m = b ? dateObj.m - (-1) : 1 + m = m > 9 ? m : '0' + m + return '' + y + '-' + m + } + // 鏍煎紡鍖栨椂闂� ==> yyyy-mm-dd + const formatDate = (value, str) => { + if (value) { + let date_arr = value.split(str) + let m = date_arr[1].length == 1 && date_arr[1] < 10 ? '0' + date_arr[1] : date_arr[1] + let d = date_arr[2].length == 1 && date_arr[2] < 10 ? '0' + date_arr[2] : date_arr[2] + return date_arr[0] + '-' + m + '-' + d + } else { + return '--' + } + } + const getK = value => { + if (value) { + let date = new Date(value) + return date + } else { + let v = new Date().getTime() + return v + } + } + //杞负鏃堕棿鎴� + const formatTime = value => { + if (value) { + let date = new Date(value) + return date.getTime() + } + } + const formatDate2 = (time, format = 'YY-MM-DD hh:mm:ss') => { + if (time) { + let date = time ? new Date(time) : new Date() + let year = date.getFullYear(), + month = date.getMonth() + 1, //鏈堜唤鏄粠0寮�濮嬬殑 + day = date.getDate(), + hour = date.getHours(), + min = date.getMinutes(), + sec = date.getSeconds() + let preArr = Array.apply(null, Array(10)).map(function (elem, index) { + return '0' + index + }) //寮�涓暱搴︿负10鐨勬暟缁� 鏍煎紡涓� 00 01 02 03 + + let newTime = format + .replace(/YY/g, year) + .replace(/MM/g, preArr[month] || month) + .replace(/DD/g, preArr[day] || day) + .replace(/hh/g, preArr[hour] || hour) + .replace(/mm/g, preArr[min] || min) + .replace(/ss/g, preArr[sec] || sec) + + return newTime + } else { + return '--' + } + } + + const getLastDay = dateStr => { + dateStr = dateStr || getCurrentMonth() + let nextMonthMS = new Date(getNextMonth(new Date(dateStr).getTime())).getTime() + return getCurrentDate(new Date(nextMonthMS - 1000 * 60 * 60 * 24).getTime()) + } + + // 瀵规瘮鏃堕棿 + const compareTime = (date1, date2) => { + let d1_date1 = new Date(date1), + d1_date2 = new Date(date2); + let time_span1 = d1_date1.getTime(), + time_span2 = d1_date2.getTime(); + return time_span1 - time_span2; + } + //鏍煎紡yy-mm month1灏忕殑 month2澶х殑 + const intervalMonth = (month1, month2) => { + let yearMonth, number; + let year1 = Number(getCurrentYear(month1)); + let year2 = Number(getCurrentYear(month2)); + if (year1 != year2) { + yearMonth = (year2 - year1) * 12; + } else { + yearMonth = 0; + } + let min = Number(month1.split('-')[1]); + let max = Number(month2.split('-')[1]); + if (min < max) { + number = max - min + yearMonth + 1 + } else { + number = yearMonth - (min - max) + 1 + } + return Number(number); + } + //鑾峰彇瀛e害鐨勬椂闂� val 渚嬪 yyyy,1 鏈�缁堢粨鏋� yyyy-mm-dd,yyyy-mm-dd + const qurterDay = (val) => { + let value; + let num = val.split(',')[1] + if (num == 1) { + value = val.split(',')[0] + '-01-01,' + val.split(',')[0] + '-03-31' + } else if (num == 2) { + value = val.split(',')[0] + '-04-30,' + val.split(',')[0] + '-06-30' + } else if (num == 3) { + value = val.split(',')[0] + '-07-31,' + val.split(',')[0] + '-09-30' + } else if (num == 4) { + value = val.split(',')[0] + '-10-30,' + val.split(',')[0] + '-12-31' + } + return [value, num]; + } + //鑾峰彇鏌愭湀鏈�鍚庝竴澶� + const getMonthLastDay = (dateStr) => { + let dateObj = getNextMonth(dateStr) + let date = getDateDay2(dateObj + '-01', -1) + return date + } + /*鑾峰彇褰撳墠鏃ユ湡*/ + const getWeekdayTime = (value) => { + let d = new Date(value) + let week = d.getDay() + let weekday = '' + if (week == 0) + weekday = '鏄熸湡鏃�' + else if (week == 1) + weekday = '鏄熸湡涓�' + else if (week == 2) + weekday = '鏄熸湡浜�' + else if (week == 3) + weekday = '鏄熸湡涓�' + else if (week == 4) + weekday = '鏄熸湡鍥�' + else if (week == 5) + weekday = '鏄熸湡浜�' + else if (week == 6) + weekday = '鏄熸湡鍏�' + return weekday + } + //璁$畻褰撳墠鏃堕棿鍒颁粖澶╃粨鏉熸椂杩樺墿澶氬皯 姣 + const getRestOfDayTime = () => { + let x = new Date(); + x.setHours(0, 0, 0, 0); + let y = new Date(); + return 24 * 3600 * 1000 - (y.getTime() - x.getTime()) + } + /* 鐢ㄤ簬鏈堟棩杩欑闇�瑕佸姞鍓嶇疆0鐨勬柟娉� + * @param num 闇�瑕佸姞0鐨勫弬鏁� string | number + * @return 缁撴灉 濮嬬粓淇濊瘉缁撴灉涓哄瓧绗︿覆 string + */ + const paddingZero = (num) => { + return num < 10 ? "0" + num : String(num) + } + return { paddingZero, getDateObj, getCurrentDate, getDateStr, getDateDay2, getCurrentYear, getCurrentMonth, getPreviousMonth, getNextMonth, formatDate, formatDate2, formatTime, getK, compareTime, getLastDay, intervalMonth, getMonthLastDay, qurterDay, getWeekdayTime, getRestOfDayTime } +})() diff --git a/src/views/sales/masterOrder/AddMasterOrderDialog.vue b/src/views/sales/masterOrder/AddMasterOrderDialog.vue index 0d94b5f..86d34d6 100644 --- a/src/views/sales/masterOrder/AddMasterOrderDialog.vue +++ b/src/views/sales/masterOrder/AddMasterOrderDialog.vue @@ -101,7 +101,9 @@ <el-date-picker v-model="editConfig.infomation.start_time" value-format="yyyy-MM-dd HH:mm:ss" + :picker-options="pickerOptions" style="width: 100%" + @change="checkDate(editConfig.infomation.start_time,editConfig.infomation.end_time)" type="datetime" placeholder="閫夋嫨鏃ユ湡" > @@ -113,7 +115,9 @@ <el-date-picker v-model="editConfig.infomation.end_time" value-format="yyyy-MM-dd HH:mm:ss" + :picker-options="pickerOptions" type="datetime" + @change="checkDate(editConfig.infomation.start_time,editConfig.infomation.end_time)" style="width: 100%" placeholder="閫夋嫨鏃ユ湡" > @@ -188,6 +192,8 @@ import { getAddMasterOrder, getUpdateMasterOrder } from "@/api/sales/masterOrder" import SelectClientDialog from "@/views/other/commonDialog/SelectClientDialog" import codeMixin from "@/components/makepager/mixin/codeMixin" +import NewDate from "@/api/date"; +const { compareTime } = NewDate; export default { name: "QuotationDialog", mixins: [codeMixin], @@ -228,7 +234,12 @@ infomation: {} }, clientId: this.editCommonConfig.infomation.client_id, - objCode: { name: "", page: 0, pageSize: 0, type: "閿�鍞�诲崟缂栫爜", codeStandID: "" } + objCode: { name: "", page: 0, pageSize: 0, type: "閿�鍞�诲崟缂栫爜", codeStandID: "" }, + pickerOptions: { + disabledDate(time) { + return time.getTime() < new Date().getTime() - 86400000; + }, + }, } }, created() { @@ -244,6 +255,13 @@ } }, methods: { + checkDate(start,end){ + if(start&&end){ + if (compareTime(start, end) > 0) { + this.$message.error('鏈嶅姟鎴鏃堕棿瑕佹櫄浜庢湇鍔″紑濮嬫椂闂达紒') + } + } + }, formInfo() { this.objCode.codeStandID = "" if (this.editConfig.infomation.codeStandID) { diff --git a/src/views/sales/quotation/AddQuotationDialog.vue b/src/views/sales/quotation/AddQuotationDialog.vue index c08cbe4..8684bc1 100644 --- a/src/views/sales/quotation/AddQuotationDialog.vue +++ b/src/views/sales/quotation/AddQuotationDialog.vue @@ -527,8 +527,8 @@ this.$message.error("浜у搧鍚嶇О涓嶈兘涓虹┖") } else { for (let i = 0; i < this.tableData.length; i++) { - if (this.tableData[i].cost || Number(this.tableData[i].cost) == 0) { - let reg = /^\+?[1-9]\d*$/ + if (this.tableData[i].cost) { + let reg =/(^[1-9]([0-9]+)?(\.[0-9]{1,2})?$)|(^(0){1}$)|(^[0-9]\.[0-9]([0-9])?$)/; if (!reg.test(this.tableData[i].cost)) { this.$message.error("鎴愭湰鍗曚环闇�瑕佸~鍐欏ぇ浜�0鐨�2浣嶅皬鏁帮紒") return true -- Gitblit v1.8.0