| | |
| | | |
| | | |
| | | /** |
| | | * 通用js方法封装处理 |
| | | * Copyright (c) 2019 ruoyi |
| | | */ |
| | | import dayjs from "dayjs"; |
| | | |
| | | // 日期格式化 |
| | | export function parseTime(time, pattern) { |
| | | if (arguments.length === 0 || !time) { |
| | | return null |
| | | return null; |
| | | } |
| | | const format = pattern || '{y}-{m}-{d} {h}:{i}:{s}' |
| | | let date |
| | | if (typeof time === 'object') { |
| | | date = time |
| | | const format = pattern || "{y}-{m}-{d} {h}:{i}:{s}"; |
| | | let date; |
| | | if (typeof time === "object") { |
| | | date = time; |
| | | } else { |
| | | if ((typeof time === 'string') && (/^[0-9]+$/.test(time))) { |
| | | time = parseInt(time) |
| | | } else if (typeof time === 'string') { |
| | | time = time.replace(new RegExp(/-/gm), '/').replace('T', ' ').replace(new RegExp(/\.[\d]{3}/gm), ''); |
| | | if (typeof time === "string" && /^[0-9]+$/.test(time)) { |
| | | time = parseInt(time); |
| | | } else if (typeof time === "string") { |
| | | time = time |
| | | .replace(new RegExp(/-/gm), "/") |
| | | .replace("T", " ") |
| | | .replace(new RegExp(/\.[\d]{3}/gm), ""); |
| | | } |
| | | if ((typeof time === 'number') && (time.toString().length === 10)) { |
| | | time = time * 1000 |
| | | if (typeof time === "number" && time.toString().length === 10) { |
| | | time = time * 1000; |
| | | } |
| | | date = new Date(time) |
| | | date = new Date(time); |
| | | } |
| | | const formatObj = { |
| | | y: date.getFullYear(), |
| | |
| | | h: date.getHours(), |
| | | i: date.getMinutes(), |
| | | s: date.getSeconds(), |
| | | a: date.getDay() |
| | | } |
| | | a: date.getDay(), |
| | | }; |
| | | const time_str = format.replace(/{(y|m|d|h|i|s|a)+}/g, (result, key) => { |
| | | let value = formatObj[key] |
| | | let value = formatObj[key]; |
| | | // Note: getDay() returns 0 on Sunday |
| | | if (key === 'a') { return ['日', '一', '二', '三', '四', '五', '六'][value] } |
| | | if (result.length > 0 && value < 10) { |
| | | value = '0' + value |
| | | if (key === "a") { |
| | | return ["日", "一", "二", "三", "四", "五", "六"][value]; |
| | | } |
| | | return value || 0 |
| | | }) |
| | | return time_str |
| | | if (result.length > 0 && value < 10) { |
| | | value = "0" + value; |
| | | } |
| | | return value || 0; |
| | | }); |
| | | return time_str; |
| | | } |
| | | // 出院/入院天数计算 |
| | | export function daysBetween(dateString) { |
| | | // 将输入的日期字符串转换为Date对象 |
| | | var startDate = new Date(dateString); |
| | | // 获取当前日期 |
| | | var currentDate = new Date(); |
| | | // 计算两个日期之间的时间差(毫秒) |
| | | var differenceInTime = currentDate - startDate; |
| | | // 将时间差转换为天数 |
| | | var differenceInDays = differenceInTime / (1000 * 3600 * 24); |
| | | // 返回天数,四舍五入到最接近的整数 |
| | | return Math.round(differenceInDays); |
| | | } |
| | | // 过滤器 |
| | | export function formatTime(val) { |
| | | if (val) { |
| | | return dayjs(val).format("YYYY-MM-DD"); |
| | | } else { |
| | | return ""; |
| | | } |
| | | } |
| | | |
| | | // 表单重置 |
| | |
| | | // 添加日期范围 |
| | | export function addDateRange(params, dateRange, propName) { |
| | | let search = params; |
| | | search.params = typeof (search.params) === 'object' && search.params !== null && !Array.isArray(search.params) ? search.params : {}; |
| | | search.params = |
| | | typeof search.params === "object" && |
| | | search.params !== null && |
| | | !Array.isArray(search.params) |
| | | ? search.params |
| | | : {}; |
| | | dateRange = Array.isArray(dateRange) ? dateRange : []; |
| | | if (typeof (propName) === 'undefined') { |
| | | search.params['beginTime'] = dateRange[0]; |
| | | search.params['endTime'] = dateRange[1]; |
| | | if (typeof propName === "undefined") { |
| | | search.params["beginTime"] = dateRange[0]; |
| | | search.params["endTime"] = dateRange[1]; |
| | | } else { |
| | | search.params['begin' + propName] = dateRange[0]; |
| | | search.params['end' + propName] = dateRange[1]; |
| | | search.params["begin" + propName] = dateRange[0]; |
| | | search.params["end" + propName] = dateRange[1]; |
| | | } |
| | | return search; |
| | | } |
| | |
| | | } |
| | | var actions = []; |
| | | Object.keys(datas).some((key) => { |
| | | if (datas[key].value == ('' + value)) { |
| | | if (datas[key].value == "" + value) { |
| | | actions.push(datas[key].label); |
| | | return true; |
| | | } |
| | | }) |
| | | }); |
| | | if (actions.length === 0) { |
| | | actions.push(value); |
| | | } |
| | | return actions.join(''); |
| | | return actions.join(""); |
| | | } |
| | | |
| | | // 回显数据字典(字符串、数组) |
| | | export function selectDictLabels(datas, value, separator) { |
| | | if (value === undefined || value.length ===0) { |
| | | if (value === undefined || value.length === 0) { |
| | | return ""; |
| | | } |
| | | if (Array.isArray(value)) { |
| | |
| | | Object.keys(value.split(currentSeparator)).some((val) => { |
| | | var match = false; |
| | | Object.keys(datas).some((key) => { |
| | | if (datas[key].value == ('' + temp[val])) { |
| | | if (datas[key].value == "" + temp[val]) { |
| | | actions.push(datas[key].label + currentSeparator); |
| | | match = true; |
| | | } |
| | | }) |
| | | }); |
| | | if (!match) { |
| | | actions.push(temp[val] + currentSeparator); |
| | | } |
| | | }) |
| | | return actions.join('').substring(0, actions.join('').length - 1); |
| | | }); |
| | | return actions.join("").substring(0, actions.join("").length - 1); |
| | | } |
| | | |
| | | // 字符串格式化(%s ) |
| | | export function sprintf(str) { |
| | | var args = arguments, flag = true, i = 1; |
| | | var args = arguments, |
| | | flag = true, |
| | | i = 1; |
| | | str = str.replace(/%s/g, function () { |
| | | var arg = args[i++]; |
| | | if (typeof arg === 'undefined') { |
| | | if (typeof arg === "undefined") { |
| | | flag = false; |
| | | return ''; |
| | | return ""; |
| | | } |
| | | return arg; |
| | | }); |
| | | return flag ? str : ''; |
| | | return flag ? str : ""; |
| | | } |
| | | |
| | | // 转换字符串,undefined,null等转化为"" |
| | |
| | | } |
| | | } |
| | | return source; |
| | | }; |
| | | } |
| | | |
| | | /** |
| | | * 构造树型结构数据 |
| | |
| | | */ |
| | | export function handleTree(data, id, parentId, children) { |
| | | let config = { |
| | | id: id || 'id', |
| | | parentId: parentId || 'parentId', |
| | | childrenList: children || 'children' |
| | | id: id || "id", |
| | | parentId: parentId || "parentId", |
| | | childrenList: children || "children", |
| | | }; |
| | | |
| | | var childrenListMap = {}; |
| | |
| | | } |
| | | |
| | | /** |
| | | * 参数处理 |
| | | * @param {*} params 参数 |
| | | */ |
| | | * 参数处理 |
| | | * @param {*} params 参数 |
| | | */ |
| | | export function tansParams(params) { |
| | | let result = '' |
| | | let result = ""; |
| | | for (const propName of Object.keys(params)) { |
| | | const value = params[propName]; |
| | | var part = encodeURIComponent(propName) + "="; |
| | | if (value !== null && value !== "" && typeof (value) !== "undefined") { |
| | | if (typeof value === 'object') { |
| | | if (value !== null && value !== "" && typeof value !== "undefined") { |
| | | if (typeof value === "object") { |
| | | for (const key of Object.keys(value)) { |
| | | if (value[key] !== null && value[key] !== "" && typeof (value[key]) !== 'undefined') { |
| | | let params = propName + '[' + key + ']'; |
| | | if ( |
| | | value[key] !== null && |
| | | value[key] !== "" && |
| | | typeof value[key] !== "undefined" |
| | | ) { |
| | | let params = propName + "[" + key + "]"; |
| | | var subPart = encodeURIComponent(params) + "="; |
| | | result += subPart + encodeURIComponent(value[key]) + "&"; |
| | | } |
| | |
| | | } |
| | | } |
| | | } |
| | | return result |
| | | return result; |
| | | } |
| | | |
| | | // 验证是否为blob格式 |