// var baseUrl = "/crm"; var baseUrl = ""; // 详情窗口-高度 var detailHeight = '80%'; // 详情窗口-宽度 var detailWidth = '90%'; // layui.config({ // // defaultTheme: 'theme-colorful', // 默认主题 // // version: true, // 加载模块不缓存 // maxTabNum: 30, // 最大打开的Tab数量 // base: baseUrl + "/static/layui/lay/modules/" // }).use(['admin'], function() { // var $ = layui.jquery; // var layer = layui.layer; // var admin = layui.admin; // // }); // 非空判断 function isEmpty(obj){ return typeof obj == "undefined" || obj == null || obj === ""; } function emptyShow(d) { return isEmpty(d)?"--":d; } function eq(o1, o2) { if (!isEmpty(o1) && !isEmpty(o2)) { return o1===o2; } if (isEmpty(o1) && isEmpty(o2)) { return true; } return o1 === o2; } // 时间 ==>> 字符串 function dateToStr(date) { var time = new Date(date); var y = time.getFullYear(); var M = time.getMonth() + 1; M = M < 10 ? ("0" + M) : M; var d = time.getDate(); d = d < 10 ? ("0" + d) : d; var h = time.getHours(); h = h < 10 ? ("0" + h) : h; var m = time.getMinutes(); m = m < 10 ? ("0" + m) : m; var s = time.getSeconds(); s = s < 10 ? ("0" + s) : s; return y + "-" + M + "-" + d + " " + h + ":" + m + ":" + s; } // 时间 ==>> 字符串 function dateToStr2(date) { var time = new Date(date); var y = time.getFullYear(); var M = time.getMonth() + 1; M = M < 10 ? ("0" + M) : M; var d = time.getDate(); d = d < 10 ? ("0" + d) : d; var h = time.getHours(); h = h < 10 ? ("0" + h) : h; var m = time.getMinutes(); m = m < 10 ? ("0" + m) : m; var s = time.getSeconds(); s = s < 10 ? ("0" + s) : s; return y + "" + "" + M + "" + d + "" + h + "" + "" + m + "" + s; } // 字符串 ===>> 时间 function strToDate(str) { var t = Date.parse(str); if (!isNaN(t)) { return new Date(Date.parse(str.replace(/-/g, "/"))); } else { return null; } } // 清理对象null值 function reObject(data) { for (var obj in data) { if (data[obj]===null){ delete data[obj]; } } return data; } /** * disabled 属性转换 */ function convertDisabled(el, param) { el.each(function () { $(this).attr("disabled", param); }); } // 清除表单 function clearFormVal(el) { $(':input', el) .val('') .removeAttr('checked') .removeAttr('selected'); } // url键值对 function urlParam(key) { var query = window.location.search.substring(1); var vars = query.split("&"); for (var i=0;i=0; i--){ if(arr[i][key] === val){ arr.splice(i,1); } } } var popupRight; var cstmrByMore; var orderByMore; var planByMore; var priQuoteByMore; var reimburseOnlineByMore; function getQueryVariable(variable) { var query = window.location.search.substring(1); var vars = query.split("&"); for (var i=0;i { // console.log(p); uploadProgress(p)//回调上传进度 }, // 设置并发上传的分片数量。 parallel: 4, // 设置分片大小。默认值为1 MB,最小值为100 KB。 partSize: 1024 * 1024, // headers, // 自定义元数据,通过HeadObject接口可以获取Object的元数据。 meta: {year: 2020, people: "test"}, mime: "text/plain", }; return await client.multipartUpload(filename, file, {...options}); } //获取OSS文件URL function getObjectUrl(filepath) { var client = getOssClient() if (client == null) { return null; } const domain = filepath.match(/^(?:https?:\/\/)?(?:[^@\n]+@)?(?:www\.)?([^:\/\n]+)/im)[0] + "/";//域名部分 // 配置响应头实现通过URL访问时自动下载文件,并设置下载后的文件名。 const filename = filepath.split(domain)[1]; const response = { "content-disposition": `attachment; filename=${encodeURIComponent( filename )}`, }; // 填写Object完整路径。Object完整路径中不能包含Bucket名称。 const url = client.signatureUrl(filename,{response}); return url; }