From 1e857671cbc8332f95ce19b2ec5db204ad5bcd58 Mon Sep 17 00:00:00 2001
From: yangzhq68909 <993367776@qq.com>
Date: Mon, 14 Oct 2024 15:22:41 +0800
Subject: [PATCH] =?UTF-8?q?=E4=B8=8A=E4=BC=A0=E9=99=84=E4=BB=B6=E5=8F=8A?=
=?UTF-8?q?=E5=9B=9E=E6=98=BE?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
---
bpm/leaveApplication/index.vue | 38 +-
pages/leave/application.vue | 115 +-
pages/useredit/useredit.vue | 15 +-
unpackage/dist/dev/app-plus/app-service.js | 7315 ++++++++++-------
unpackage/dist/dev/app-plus/app.css | 276 +
.../dev/app-plus/pages/leave/application.css | 294 +-
6 files changed, 4992 insertions(+), 3061 deletions(-)
diff --git a/bpm/leaveApplication/index.vue b/bpm/leaveApplication/index.vue
index 8271a3a..28b9626 100644
--- a/bpm/leaveApplication/index.vue
+++ b/bpm/leaveApplication/index.vue
@@ -44,7 +44,7 @@
请假天数:
- {{info.qjdays}}
+ {{info.days}}
@@ -64,6 +64,12 @@
{{info.reason}}
+
+
+ 附件:
+
+
+
@@ -106,13 +112,26 @@
watch,
onMounted
} from 'vue'
+ import {
+ imgUrl
+ } from '@/utils/index.js';
const props = defineProps({
dataId: {
type: String,
default: ''
},
})
-
+ const imageValue = ref([])
+ const imageStyles = {
+ width: 64,
+ height: 64,
+ border: {
+ color: "#dce7e1",
+ width: 2,
+ style: 'dashed',
+ radius: '2px'
+ }
+ }
const info = ref({})
// 申请信息
const qjQueryById = () => {
@@ -121,10 +140,23 @@
}).then((res) => {
if (res.success) {
info.value = res.result.records[0]
+
+ // 构造 imageValue 数组
+ imageValue.value = info.value.path.split(',').map(path => {
+ const name = path.split('/').pop(); // 获取文件名
+ const extname = name.split('.').pop(); // 获取文件扩展名并转换为大写
+ return {
+ name,
+ extname,
+ url: imgUrl(path)
+ };
+ });
+ console.log('---',imageValue.value)
}
})
- }
+ }
+
/**审批步骤*/
const extActFlowData = () => {
extActFlowDataApi({
diff --git a/pages/leave/application.vue b/pages/leave/application.vue
index 7103f4e..0f6e77b 100644
--- a/pages/leave/application.vue
+++ b/pages/leave/application.vue
@@ -68,17 +68,22 @@
请假地点:
-
+
+
+
+
+ 请假事由:
+
+
+
+
+
+ 上传附件:
+
+
-
-
- 请假事由:
-
-
-
+
提交
@@ -146,11 +151,41 @@
const address = ref('')
/**请假事由*/
const reason = ref('')
-
+ /**附件路径*/
+ const path = ref([])
+ const baseUrl = import.meta.env.VITE_REQUEST_BASE_URL + '/jeecg-boot/sys/common/upload/'
+ const imageStyles = {
+ width: 64,
+ height: 64,
+ border: {
+ color: "#dce7e1",
+ width: 2,
+ style: 'dashed',
+ radius: '2px'
+ }
+ }
onLoad(() => {
loadData()
})
+ const select = (e) => {
+ const tempFilePaths = e.tempFilePaths
+ for (let i = 0; i < e.tempFilePaths.length; i++) {
+ let photoPath = '职工请假/' + store.userinfo.orgCode + '/' + store.userinfo.realname
+ uni.uploadFile({
+ url: baseUrl,
+ filePath: e.tempFilePaths[i],
+ name: 'file',
+ formData: {
+ appPath: photoPath
+ },
+ success: (res) => {
+ path.value.push(JSON.parse(res.data).message)
+ }
+ });
+ }
+ }
+
const qjAdd = () => {
if (!phone.value.trim()) return proxy.$toast('请输入联系方式')
if (!type.value) return proxy.$toast('请选择请假类型')
@@ -172,7 +207,8 @@
examineleader: typeArr.value[typeIndex.value].username,
address: address.value,
reason: reason.value,
- zwcj: zwcj.value,
+ zwmc: zwcj.value,
+ path: path.value.toString()
}).then((res) => {
if (res.success) {
startMutilProcess(res.message)
@@ -181,6 +217,7 @@
}
})
}
+
const startMutilProcess = (id) => {
startMutilProcessApi({
flowCode: "dev_cxc_qxj",
@@ -300,60 +337,4 @@
color: #333333;
}
}
-
- .reason {
- background-color: #fff;
- margin-top: 20rpx;
-
- height: 290rpx;
- padding: 30rpx;
-
- .title {
- font-size: 28rpx;
- color: #333333;
-
- }
-
- textarea {
- width: 100%;
- margin-top: 20rpx;
- }
- }
-
-
- // .progress_box {
- // background-color: #fff;
- // margin-top: 20rpx;
- // padding: 30rpx;
-
- // .title {
- // font-size: 28rpx;
- // color: #333333;
- // }
-
- // .avatar {
- // width: 78rpx;
- // height: 78rpx;
- // border-radius: 38rpx;
- // background-color: #333333;
- // margin-top: 30rpx;
- // }
-
- // text {
- // font-size: 24rpx;
- // color: #333333;
- // margin-top: 10rpx;
- // }
-
- // .line {
- // width: 91rpx;
- // height: 17rpx;
- // margin: 0 40rpx;
- // }
- // }
-
- .lines {
- height: 20rpx;
- background-color: #F8F8F8;
- }
\ No newline at end of file
diff --git a/pages/useredit/useredit.vue b/pages/useredit/useredit.vue
index fd636a8..6807193 100644
--- a/pages/useredit/useredit.vue
+++ b/pages/useredit/useredit.vue
@@ -54,7 +54,7 @@
import {
useStore
} from '@/store';
- const baseUrl = import.meta.env.VITE_REQUEST_BASE_URL + '/jeecg-boot'
+ const baseUrl = import.meta.env.VITE_REQUEST_BASE_URL + '/jeecg-boot/sys/common/upload'
const store = useStore()
const jump = (url) => {
@@ -65,23 +65,23 @@
})
}
const chooseAvatar = () => {
-
uni.chooseImage({
count: 1,
success: (chooseImageRes) => {
const tempFilePaths = chooseImageRes.tempFilePaths;
+ const photoPath = '用户头像/' + store.userinfo.realname
uni.uploadFile({
- url: baseUrl + '/sys/common/upload', //仅为示例,非真实的接口地址
+ url: baseUrl, //仅为示例,非真实的接口地址
filePath: tempFilePaths[0],
name: 'file',
- header: {
- "X-Access-Token": store.token
+ formData: {
+ appPath: photoPath
},
- success: (uploadFileRes) => {
+ success: (res) => {
uni.showLoading({
title: '上传中...'
})
- form.avatar = JSON.parse(uploadFileRes.data).message
+ form.avatar = JSON.parse(res.data).message
userEditApi({
avatar: form.avatar,
id: store.userinfo.id
@@ -134,7 +134,6 @@
frontColor: "#ffffff",
backgroundColor: '#bebebe'
})
-
})
diff --git a/unpackage/dist/dev/app-plus/app-service.js b/unpackage/dist/dev/app-plus/app-service.js
index 6021b59..aa73af6 100644
--- a/unpackage/dist/dev/app-plus/app-service.js
+++ b/unpackage/dist/dev/app-plus/app-service.js
@@ -1754,7 +1754,7 @@ This will fail in production.`);
}
return target;
};
- const _sfc_main$N = {
+ const _sfc_main$Q = {
__name: "login",
setup(__props) {
const store = useStore();
@@ -1895,7 +1895,7 @@ This will fail in production.`);
};
}
};
- const PagesLoginLogin = /* @__PURE__ */ _export_sfc(_sfc_main$N, [["__scopeId", "data-v-e4e4508d"], ["__file", "D:/projects/cxc-szcx-uniapp/pages/login/login.vue"]]);
+ const PagesLoginLogin = /* @__PURE__ */ _export_sfc(_sfc_main$Q, [["__scopeId", "data-v-e4e4508d"], ["__file", "D:/projects/cxc-szcx-uniapp/pages/login/login.vue"]]);
const fontData = [
{
"font_class": "arrow-down",
@@ -2546,7 +2546,7 @@ This will fail in production.`);
const reg = /^[0-9]*$/g;
return typeof val === "number" || reg.test(val) ? val + "px" : val;
};
- const _sfc_main$M = {
+ const _sfc_main$P = {
name: "UniIcons",
emits: ["click"],
props: {
@@ -2600,7 +2600,7 @@ This will fail in production.`);
}
}
};
- function _sfc_render$b(_ctx, _cache, $props, $setup, $data, $options) {
+ function _sfc_render$e(_ctx, _cache, $props, $setup, $data, $options) {
return vue.openBlock(), vue.createElementBlock(
"text",
{
@@ -2615,7 +2615,7 @@ This will fail in production.`);
/* CLASS, STYLE */
);
}
- const __easycom_1$1 = /* @__PURE__ */ _export_sfc(_sfc_main$M, [["render", _sfc_render$b], ["__scopeId", "data-v-d31e1c47"], ["__file", "D:/projects/cxc-szcx-uniapp/uni_modules/uni-icons/components/uni-icons/uni-icons.vue"]]);
+ const __easycom_1$1 = /* @__PURE__ */ _export_sfc(_sfc_main$P, [["render", _sfc_render$e], ["__scopeId", "data-v-d31e1c47"], ["__file", "D:/projects/cxc-szcx-uniapp/uni_modules/uni-icons/components/uni-icons/uni-icons.vue"]]);
let Calendar$1 = class Calendar {
constructor({
selected,
@@ -2971,7 +2971,7 @@ This will fail in production.`);
}
return value;
}
- const _sfc_main$L = {
+ const _sfc_main$O = {
props: {
weeks: {
type: Object,
@@ -3005,7 +3005,7 @@ This will fail in production.`);
}
}
};
- function _sfc_render$a(_ctx, _cache, $props, $setup, $data, $options) {
+ function _sfc_render$d(_ctx, _cache, $props, $setup, $data, $options) {
return vue.openBlock(), vue.createElementBlock(
"view",
{
@@ -3061,7 +3061,7 @@ This will fail in production.`);
/* CLASS, NEED_HYDRATION */
);
}
- const calendarItem = /* @__PURE__ */ _export_sfc(_sfc_main$L, [["render", _sfc_render$a], ["__scopeId", "data-v-3c762a01"], ["__file", "D:/projects/cxc-szcx-uniapp/uni_modules/uni-datetime-picker/components/uni-datetime-picker/calendar-item.vue"]]);
+ const calendarItem = /* @__PURE__ */ _export_sfc(_sfc_main$O, [["render", _sfc_render$d], ["__scopeId", "data-v-3c762a01"], ["__file", "D:/projects/cxc-szcx-uniapp/uni_modules/uni-datetime-picker/components/uni-datetime-picker/calendar-item.vue"]]);
const isObject = (val) => val !== null && typeof val === "object";
const defaultDelimiters = ["{", "}"];
class BaseFormatter {
@@ -3420,7 +3420,7 @@ This will fail in production.`);
const {
t: t$3
} = initVueI18n(i18nMessages);
- const _sfc_main$K = {
+ const _sfc_main$N = {
name: "UniDatetimePicker",
data() {
return {
@@ -4024,7 +4024,7 @@ This will fail in production.`);
}
}
};
- function _sfc_render$9(_ctx, _cache, $props, $setup, $data, $options) {
+ function _sfc_render$c(_ctx, _cache, $props, $setup, $data, $options) {
return vue.openBlock(), vue.createElementBlock("view", { class: "uni-datetime-picker" }, [
vue.createElementVNode("view", {
onClick: _cache[0] || (_cache[0] = (...args) => $options.initTimePicker && $options.initTimePicker(...args))
@@ -4301,11 +4301,11 @@ This will fail in production.`);
)) : vue.createCommentVNode("v-if", true)
]);
}
- const TimePicker = /* @__PURE__ */ _export_sfc(_sfc_main$K, [["render", _sfc_render$9], ["__scopeId", "data-v-1d532b70"], ["__file", "D:/projects/cxc-szcx-uniapp/uni_modules/uni-datetime-picker/components/uni-datetime-picker/time-picker.vue"]]);
+ const TimePicker = /* @__PURE__ */ _export_sfc(_sfc_main$N, [["render", _sfc_render$c], ["__scopeId", "data-v-1d532b70"], ["__file", "D:/projects/cxc-szcx-uniapp/uni_modules/uni-datetime-picker/components/uni-datetime-picker/time-picker.vue"]]);
const {
t: t$2
} = initVueI18n(i18nMessages);
- const _sfc_main$J = {
+ const _sfc_main$M = {
components: {
calendarItem,
timePicker: TimePicker
@@ -4786,7 +4786,7 @@ This will fail in production.`);
}
}
};
- function _sfc_render$8(_ctx, _cache, $props, $setup, $data, $options) {
+ function _sfc_render$b(_ctx, _cache, $props, $setup, $data, $options) {
const _component_calendar_item = vue.resolveComponent("calendar-item");
const _component_time_picker = vue.resolveComponent("time-picker");
const _component_uni_icons = resolveEasycom(vue.resolveDynamicComponent("uni-icons"), __easycom_1$1);
@@ -5070,8 +5070,8 @@ This will fail in production.`);
/* NEED_HYDRATION */
);
}
- const Calendar = /* @__PURE__ */ _export_sfc(_sfc_main$J, [["render", _sfc_render$8], ["__scopeId", "data-v-1d379219"], ["__file", "D:/projects/cxc-szcx-uniapp/uni_modules/uni-datetime-picker/components/uni-datetime-picker/calendar.vue"]]);
- const _sfc_main$I = {
+ const Calendar = /* @__PURE__ */ _export_sfc(_sfc_main$M, [["render", _sfc_render$b], ["__scopeId", "data-v-1d379219"], ["__file", "D:/projects/cxc-szcx-uniapp/uni_modules/uni-datetime-picker/components/uni-datetime-picker/calendar.vue"]]);
+ const _sfc_main$L = {
name: "UniDatetimePicker",
options: {
virtualHost: true
@@ -5727,7 +5727,7 @@ This will fail in production.`);
}
}
};
- function _sfc_render$7(_ctx, _cache, $props, $setup, $data, $options) {
+ function _sfc_render$a(_ctx, _cache, $props, $setup, $data, $options) {
const _component_uni_icons = resolveEasycom(vue.resolveDynamicComponent("uni-icons"), __easycom_1$1);
const _component_time_picker = vue.resolveComponent("time-picker");
const _component_Calendar = vue.resolveComponent("Calendar");
@@ -6071,8 +6071,8 @@ This will fail in production.`);
}, null, 8, ["date", "defTime", "start-date", "end-date", "selectableTimes", "startPlaceholder", "endPlaceholder", "default-value", "pleStatus", "range", "hasTime", "hideSecond", "onConfirm", "onMaskClose", "onChange"])) : vue.createCommentVNode("v-if", true)
]);
}
- const __easycom_0$3 = /* @__PURE__ */ _export_sfc(_sfc_main$I, [["render", _sfc_render$7], ["__scopeId", "data-v-9802168a"], ["__file", "D:/projects/cxc-szcx-uniapp/uni_modules/uni-datetime-picker/components/uni-datetime-picker/uni-datetime-picker.vue"]]);
- const _sfc_main$H = {
+ const __easycom_0$4 = /* @__PURE__ */ _export_sfc(_sfc_main$L, [["render", _sfc_render$a], ["__scopeId", "data-v-9802168a"], ["__file", "D:/projects/cxc-szcx-uniapp/uni_modules/uni-datetime-picker/components/uni-datetime-picker/uni-datetime-picker.vue"]]);
+ const _sfc_main$K = {
name: "UniDrawer",
components: {},
emits: ["change"],
@@ -6144,7 +6144,7 @@ This will fail in production.`);
}
}
};
- function _sfc_render$6(_ctx, _cache, $props, $setup, $data, $options) {
+ function _sfc_render$9(_ctx, _cache, $props, $setup, $data, $options) {
return $data.visibleSync ? (vue.openBlock(), vue.createElementBlock(
"view",
{
@@ -6180,7 +6180,7 @@ This will fail in production.`);
/* CLASS, NEED_HYDRATION */
)) : vue.createCommentVNode("v-if", true);
}
- const __easycom_2$1 = /* @__PURE__ */ _export_sfc(_sfc_main$H, [["render", _sfc_render$6], ["__scopeId", "data-v-f7c32d22"], ["__file", "D:/projects/cxc-szcx-uniapp/uni_modules/uni-drawer/components/uni-drawer/uni-drawer.vue"]]);
+ const __easycom_2$1 = /* @__PURE__ */ _export_sfc(_sfc_main$K, [["render", _sfc_render$9], ["__scopeId", "data-v-f7c32d22"], ["__file", "D:/projects/cxc-szcx-uniapp/uni_modules/uni-drawer/components/uni-drawer/uni-drawer.vue"]]);
function taskListApi(config) {
return https({
url: "/act/task/list",
@@ -6400,7 +6400,7 @@ This will fail in production.`);
data: config
});
}
- const _sfc_main$G = {
+ const _sfc_main$J = {
__name: "customNav",
setup(__props) {
vue.useCssVars((_ctx) => ({
@@ -6419,7 +6419,7 @@ This will fail in production.`);
};
}
};
- const customNav = /* @__PURE__ */ _export_sfc(_sfc_main$G, [["__scopeId", "data-v-420daeb5"], ["__file", "D:/projects/cxc-szcx-uniapp/bpm/customNav.vue"]]);
+ const customNav = /* @__PURE__ */ _export_sfc(_sfc_main$J, [["__scopeId", "data-v-420daeb5"], ["__file", "D:/projects/cxc-szcx-uniapp/bpm/customNav.vue"]]);
const baseurl = "http://10.75.166.174:8080/jeecg-boot/sys/common/static/";
const toast = (title, icon, duration) => {
uni.showToast({
@@ -6637,7 +6637,7 @@ This will fail in production.`);
const imgUrl = (url) => {
return baseurl + `/${url}`;
};
- const _sfc_main$F = {
+ const _sfc_main$I = {
__name: "index",
setup(__props) {
vue.useCssVars((_ctx) => ({
@@ -6826,7 +6826,7 @@ This will fail in production.`);
getlist();
});
return (_ctx, _cache) => {
- const _component_uni_datetime_picker = resolveEasycom(vue.resolveDynamicComponent("uni-datetime-picker"), __easycom_0$3);
+ const _component_uni_datetime_picker = resolveEasycom(vue.resolveDynamicComponent("uni-datetime-picker"), __easycom_0$4);
const _component_uni_icons = resolveEasycom(vue.resolveDynamicComponent("uni-icons"), __easycom_1$1);
const _component_uni_drawer = resolveEasycom(vue.resolveDynamicComponent("uni-drawer"), __easycom_2$1);
return vue.openBlock(), vue.createElementBlock(
@@ -7147,8 +7147,8 @@ This will fail in production.`);
};
}
};
- const PagesTabIndex = /* @__PURE__ */ _export_sfc(_sfc_main$F, [["__scopeId", "data-v-ae0729d5"], ["__file", "D:/projects/cxc-szcx-uniapp/pages/tab/index.vue"]]);
- const _sfc_main$E = {
+ const PagesTabIndex = /* @__PURE__ */ _export_sfc(_sfc_main$I, [["__scopeId", "data-v-ae0729d5"], ["__file", "D:/projects/cxc-szcx-uniapp/pages/tab/index.vue"]]);
+ const _sfc_main$H = {
__name: "office",
setup(__props) {
vue.useCssVars((_ctx) => ({
@@ -7275,8 +7275,8 @@ This will fail in production.`);
};
}
};
- const PagesTabOffice = /* @__PURE__ */ _export_sfc(_sfc_main$E, [["__scopeId", "data-v-305a3c9f"], ["__file", "D:/projects/cxc-szcx-uniapp/pages/tab/office.vue"]]);
- const _sfc_main$D = {
+ const PagesTabOffice = /* @__PURE__ */ _export_sfc(_sfc_main$H, [["__scopeId", "data-v-305a3c9f"], ["__file", "D:/projects/cxc-szcx-uniapp/pages/tab/office.vue"]]);
+ const _sfc_main$G = {
__name: "dataCom",
props: {
title: {
@@ -7386,8 +7386,8 @@ This will fail in production.`);
};
}
};
- const dataCom = /* @__PURE__ */ _export_sfc(_sfc_main$D, [["__scopeId", "data-v-92a54120"], ["__file", "D:/projects/cxc-szcx-uniapp/bpm/dataCom.vue"]]);
- const _sfc_main$C = {
+ const dataCom = /* @__PURE__ */ _export_sfc(_sfc_main$G, [["__scopeId", "data-v-92a54120"], ["__file", "D:/projects/cxc-szcx-uniapp/bpm/dataCom.vue"]]);
+ const _sfc_main$F = {
__name: "product",
setup(__props) {
vue.useCssVars((_ctx) => ({
@@ -7546,7 +7546,7 @@ This will fail in production.`);
};
}
};
- const PagesTabProduct = /* @__PURE__ */ _export_sfc(_sfc_main$C, [["__scopeId", "data-v-6ccf0546"], ["__file", "D:/projects/cxc-szcx-uniapp/pages/tab/product.vue"]]);
+ const PagesTabProduct = /* @__PURE__ */ _export_sfc(_sfc_main$F, [["__scopeId", "data-v-6ccf0546"], ["__file", "D:/projects/cxc-szcx-uniapp/pages/tab/product.vue"]]);
const { registerUTSInterface, initUTSProxyClass, initUTSProxyFunction, initUTSPackageName, initUTSIndexClassName, initUTSClassName } = uni;
const name = "wuwxStepCounter";
const moduleName = "计步器(兼容Android和iOS)";
@@ -7556,7 +7556,7 @@ This will fail in production.`);
const pkg = /* @__PURE__ */ initUTSPackageName(name, is_uni_modules);
const cls = /* @__PURE__ */ initUTSIndexClassName(name, is_uni_modules);
const startStepCountingUpdates = /* @__PURE__ */ initUTSProxyFunction(false, { moduleName, moduleType, errMsg, main: true, package: pkg, class: cls, name: "startStepCountingUpdatesByJs", params: [{ "name": "options", "type": "UTSSDKModulesWuwxStepCounterStartStepCountingUpdatesOptionsJSONObject" }], return: "" });
- const _sfc_main$B = {
+ const _sfc_main$E = {
__name: "my",
setup(__props) {
const store = useStore();
@@ -7841,8 +7841,8 @@ This will fail in production.`);
};
}
};
- const PagesTabMy = /* @__PURE__ */ _export_sfc(_sfc_main$B, [["__scopeId", "data-v-2086c871"], ["__file", "D:/projects/cxc-szcx-uniapp/pages/tab/my.vue"]]);
- const _sfc_main$A = {
+ const PagesTabMy = /* @__PURE__ */ _export_sfc(_sfc_main$E, [["__scopeId", "data-v-2086c871"], ["__file", "D:/projects/cxc-szcx-uniapp/pages/tab/my.vue"]]);
+ const _sfc_main$D = {
__name: "tasklistCom",
props: {
taskArr: {
@@ -7953,8 +7953,8 @@ This will fail in production.`);
};
}
};
- const tasklistCom = /* @__PURE__ */ _export_sfc(_sfc_main$A, [["__scopeId", "data-v-a83f61d7"], ["__file", "D:/projects/cxc-szcx-uniapp/bpm/tasklistCom.vue"]]);
- const _sfc_main$z = {
+ const tasklistCom = /* @__PURE__ */ _export_sfc(_sfc_main$D, [["__scopeId", "data-v-a83f61d7"], ["__file", "D:/projects/cxc-szcx-uniapp/bpm/tasklistCom.vue"]]);
+ const _sfc_main$C = {
__name: "index",
setup(__props) {
const store = useStore();
@@ -8077,7 +8077,7 @@ This will fail in production.`);
};
}
};
- const PagesTaskIndex = /* @__PURE__ */ _export_sfc(_sfc_main$z, [["__scopeId", "data-v-3dabfb60"], ["__file", "D:/projects/cxc-szcx-uniapp/pages/task/index.vue"]]);
+ const PagesTaskIndex = /* @__PURE__ */ _export_sfc(_sfc_main$C, [["__scopeId", "data-v-3dabfb60"], ["__file", "D:/projects/cxc-szcx-uniapp/pages/task/index.vue"]]);
class MPAnimation {
constructor(options, _this) {
this.options = options;
@@ -8190,7 +8190,7 @@ This will fail in production.`);
clearTimeout(_this.timer);
return new MPAnimation(option, _this);
}
- const _sfc_main$y = {
+ const _sfc_main$B = {
name: "uniTransition",
emits: ["click", "change"],
props: {
@@ -8441,7 +8441,7 @@ This will fail in production.`);
}
}
};
- function _sfc_render$5(_ctx, _cache, $props, $setup, $data, $options) {
+ function _sfc_render$8(_ctx, _cache, $props, $setup, $data, $options) {
return vue.withDirectives((vue.openBlock(), vue.createElementBlock("view", {
ref: "ani",
animation: $data.animationData,
@@ -8454,8 +8454,8 @@ This will fail in production.`);
[vue.vShow, $data.isShow]
]);
}
- const __easycom_0$2 = /* @__PURE__ */ _export_sfc(_sfc_main$y, [["render", _sfc_render$5], ["__file", "D:/projects/cxc-szcx-uniapp/uni_modules/uni-transition/components/uni-transition/uni-transition.vue"]]);
- const _sfc_main$x = {
+ const __easycom_0$3 = /* @__PURE__ */ _export_sfc(_sfc_main$B, [["render", _sfc_render$8], ["__file", "D:/projects/cxc-szcx-uniapp/uni_modules/uni-transition/components/uni-transition/uni-transition.vue"]]);
+ const _sfc_main$A = {
name: "uniPopup",
components: {},
emits: ["change", "maskClick"],
@@ -8805,8 +8805,8 @@ This will fail in production.`);
}
}
};
- function _sfc_render$4(_ctx, _cache, $props, $setup, $data, $options) {
- const _component_uni_transition = resolveEasycom(vue.resolveDynamicComponent("uni-transition"), __easycom_0$2);
+ function _sfc_render$7(_ctx, _cache, $props, $setup, $data, $options) {
+ const _component_uni_transition = resolveEasycom(vue.resolveDynamicComponent("uni-transition"), __easycom_0$3);
return $data.showPopup ? (vue.openBlock(), vue.createElementBlock(
"view",
{
@@ -8865,8 +8865,8 @@ This will fail in production.`);
/* CLASS */
)) : vue.createCommentVNode("v-if", true);
}
- const __easycom_2 = /* @__PURE__ */ _export_sfc(_sfc_main$x, [["render", _sfc_render$4], ["__scopeId", "data-v-4dd3c44b"], ["__file", "D:/projects/cxc-szcx-uniapp/uni_modules/uni-popup/components/uni-popup/uni-popup.vue"]]);
- const _sfc_main$w = {
+ const __easycom_2 = /* @__PURE__ */ _export_sfc(_sfc_main$A, [["render", _sfc_render$7], ["__scopeId", "data-v-4dd3c44b"], ["__file", "D:/projects/cxc-szcx-uniapp/uni_modules/uni-popup/components/uni-popup/uni-popup.vue"]]);
+ const _sfc_main$z = {
__name: "handle",
setup(__props) {
const store = useStore();
@@ -9154,8 +9154,8 @@ This will fail in production.`);
};
}
};
- const PagesTaskHandle = /* @__PURE__ */ _export_sfc(_sfc_main$w, [["__scopeId", "data-v-aeec6874"], ["__file", "D:/projects/cxc-szcx-uniapp/pages/task/handle.vue"]]);
- const _sfc_main$v = {
+ const PagesTaskHandle = /* @__PURE__ */ _export_sfc(_sfc_main$z, [["__scopeId", "data-v-aeec6874"], ["__file", "D:/projects/cxc-szcx-uniapp/pages/task/handle.vue"]]);
+ const _sfc_main$y = {
__name: "message_list",
setup(__props) {
const store = useStore();
@@ -9224,8 +9224,8 @@ This will fail in production.`);
};
}
};
- const PagesTalkMessage_list = /* @__PURE__ */ _export_sfc(_sfc_main$v, [["__scopeId", "data-v-e2a9a302"], ["__file", "D:/projects/cxc-szcx-uniapp/pages/talk/message_list.vue"]]);
- const _sfc_main$u = {
+ const PagesTalkMessage_list = /* @__PURE__ */ _export_sfc(_sfc_main$y, [["__scopeId", "data-v-e2a9a302"], ["__file", "D:/projects/cxc-szcx-uniapp/pages/talk/message_list.vue"]]);
+ const _sfc_main$x = {
__name: "conversation",
setup(__props) {
const store = useStore();
@@ -9300,8 +9300,8 @@ This will fail in production.`);
};
}
};
- const PagesTalkConversation = /* @__PURE__ */ _export_sfc(_sfc_main$u, [["__scopeId", "data-v-696a96aa"], ["__file", "D:/projects/cxc-szcx-uniapp/pages/talk/conversation.vue"]]);
- const _sfc_main$t = {
+ const PagesTalkConversation = /* @__PURE__ */ _export_sfc(_sfc_main$x, [["__scopeId", "data-v-696a96aa"], ["__file", "D:/projects/cxc-szcx-uniapp/pages/talk/conversation.vue"]]);
+ const _sfc_main$w = {
__name: "system",
setup(__props) {
const store = useStore();
@@ -9343,8 +9343,8 @@ This will fail in production.`);
};
}
};
- const PagesTalkSystem = /* @__PURE__ */ _export_sfc(_sfc_main$t, [["__scopeId", "data-v-5621beca"], ["__file", "D:/projects/cxc-szcx-uniapp/pages/talk/system.vue"]]);
- const _sfc_main$s = {
+ const PagesTalkSystem = /* @__PURE__ */ _export_sfc(_sfc_main$w, [["__scopeId", "data-v-5621beca"], ["__file", "D:/projects/cxc-szcx-uniapp/pages/talk/system.vue"]]);
+ const _sfc_main$v = {
__name: "index",
setup(__props) {
vue.useCssVars((_ctx) => ({
@@ -9591,8 +9591,8 @@ This will fail in production.`);
};
}
};
- const PagesDocumentIndex = /* @__PURE__ */ _export_sfc(_sfc_main$s, [["__scopeId", "data-v-ae7a950b"], ["__file", "D:/projects/cxc-szcx-uniapp/pages/document/index.vue"]]);
- const _sfc_main$r = {
+ const PagesDocumentIndex = /* @__PURE__ */ _export_sfc(_sfc_main$v, [["__scopeId", "data-v-ae7a950b"], ["__file", "D:/projects/cxc-szcx-uniapp/pages/document/index.vue"]]);
+ const _sfc_main$u = {
__name: "detail",
setup(__props) {
const store = useStore();
@@ -9660,8 +9660,8 @@ This will fail in production.`);
};
}
};
- const PagesDocumentDetail = /* @__PURE__ */ _export_sfc(_sfc_main$r, [["__scopeId", "data-v-2c024c80"], ["__file", "D:/projects/cxc-szcx-uniapp/pages/document/detail.vue"]]);
- const _sfc_main$q = {
+ const PagesDocumentDetail = /* @__PURE__ */ _export_sfc(_sfc_main$u, [["__scopeId", "data-v-2c024c80"], ["__file", "D:/projects/cxc-szcx-uniapp/pages/document/detail.vue"]]);
+ const _sfc_main$t = {
__name: "index",
setup(__props) {
const store = useStore();
@@ -9782,8 +9782,8 @@ This will fail in production.`);
};
}
};
- const PagesMeetingIndex = /* @__PURE__ */ _export_sfc(_sfc_main$q, [["__scopeId", "data-v-f3707b27"], ["__file", "D:/projects/cxc-szcx-uniapp/pages/meeting/index.vue"]]);
- const _sfc_main$p = {
+ const PagesMeetingIndex = /* @__PURE__ */ _export_sfc(_sfc_main$t, [["__scopeId", "data-v-f3707b27"], ["__file", "D:/projects/cxc-szcx-uniapp/pages/meeting/index.vue"]]);
+ const _sfc_main$s = {
__name: "detail",
setup(__props) {
const store = useStore();
@@ -9874,2909 +9874,7 @@ This will fail in production.`);
};
}
};
- const PagesMeetingDetail = /* @__PURE__ */ _export_sfc(_sfc_main$p, [["__scopeId", "data-v-ee2c785f"], ["__file", "D:/projects/cxc-szcx-uniapp/pages/meeting/detail.vue"]]);
- function qjAddApi(config) {
- return https({
- url: "/CxcQxj/cxcQxj/add",
- method: "post",
- data: config
- });
- }
- function queryZwmcAndExaApi(username) {
- return https({
- url: "/CxcQxj/cxcQxj/queryZwmcByUsername",
- method: "get",
- data: {
- username
- }
- });
- }
- function qjQueryByIdApi(config) {
- return https({
- url: "/CxcQxj/cxcQxj/queryById",
- method: "get",
- data: config
- });
- }
- function queryDepByCode(code) {
- return https({
- url: "/sys/sysDepart/queryDepNameByDepCode",
- method: "get",
- data: {
- code
- }
- });
- }
- function obj2strClass(obj) {
- let classess = "";
- for (let key in obj) {
- const val = obj[key];
- if (val) {
- classess += `${key} `;
- }
- }
- return classess;
- }
- function obj2strStyle(obj) {
- let style = "";
- for (let key in obj) {
- const val = obj[key];
- style += `${key}:${val};`;
- }
- return style;
- }
- const _sfc_main$o = {
- name: "uni-easyinput",
- emits: [
- "click",
- "iconClick",
- "update:modelValue",
- "input",
- "focus",
- "blur",
- "confirm",
- "clear",
- "eyes",
- "change",
- "keyboardheightchange"
- ],
- model: {
- prop: "modelValue",
- event: "update:modelValue"
- },
- options: {
- virtualHost: true
- },
- inject: {
- form: {
- from: "uniForm",
- default: null
- },
- formItem: {
- from: "uniFormItem",
- default: null
- }
- },
- props: {
- name: String,
- value: [Number, String],
- modelValue: [Number, String],
- type: {
- type: String,
- default: "text"
- },
- clearable: {
- type: Boolean,
- default: true
- },
- autoHeight: {
- type: Boolean,
- default: false
- },
- placeholder: {
- type: String,
- default: " "
- },
- placeholderStyle: String,
- focus: {
- type: Boolean,
- default: false
- },
- disabled: {
- type: Boolean,
- default: false
- },
- maxlength: {
- type: [Number, String],
- default: 140
- },
- confirmType: {
- type: String,
- default: "done"
- },
- clearSize: {
- type: [Number, String],
- default: 24
- },
- inputBorder: {
- type: Boolean,
- default: true
- },
- prefixIcon: {
- type: String,
- default: ""
- },
- suffixIcon: {
- type: String,
- default: ""
- },
- trim: {
- type: [Boolean, String],
- default: false
- },
- cursorSpacing: {
- type: Number,
- default: 0
- },
- passwordIcon: {
- type: Boolean,
- default: true
- },
- adjustPosition: {
- type: Boolean,
- default: true
- },
- primaryColor: {
- type: String,
- default: "#2979ff"
- },
- styles: {
- type: Object,
- default() {
- return {
- color: "#333",
- backgroundColor: "#fff",
- disableColor: "#F7F6F6",
- borderColor: "#e5e5e5"
- };
- }
- },
- errorMessage: {
- type: [String, Boolean],
- default: ""
- }
- },
- data() {
- return {
- focused: false,
- val: "",
- showMsg: "",
- border: false,
- isFirstBorder: false,
- showClearIcon: false,
- showPassword: false,
- focusShow: false,
- localMsg: "",
- isEnter: false
- // 用于判断当前是否是使用回车操作
- };
- },
- computed: {
- // 输入框内是否有值
- isVal() {
- const val = this.val;
- if (val || val === 0) {
- return true;
- }
- return false;
- },
- msg() {
- return this.localMsg || this.errorMessage;
- },
- // 因为uniapp的input组件的maxlength组件必须要数值,这里转为数值,用户可以传入字符串数值
- inputMaxlength() {
- return Number(this.maxlength);
- },
- // 处理外层样式的style
- boxStyle() {
- return `color:${this.inputBorder && this.msg ? "#e43d33" : this.styles.color};`;
- },
- // input 内容的类和样式处理
- inputContentClass() {
- return obj2strClass({
- "is-input-border": this.inputBorder,
- "is-input-error-border": this.inputBorder && this.msg,
- "is-textarea": this.type === "textarea",
- "is-disabled": this.disabled,
- "is-focused": this.focusShow
- });
- },
- inputContentStyle() {
- const focusColor = this.focusShow ? this.primaryColor : this.styles.borderColor;
- const borderColor = this.inputBorder && this.msg ? "#dd524d" : focusColor;
- return obj2strStyle({
- "border-color": borderColor || "#e5e5e5",
- "background-color": this.disabled ? this.styles.disableColor : this.styles.backgroundColor
- });
- },
- // input右侧样式
- inputStyle() {
- const paddingRight = this.type === "password" || this.clearable || this.prefixIcon ? "" : "10px";
- return obj2strStyle({
- "padding-right": paddingRight,
- "padding-left": this.prefixIcon ? "" : "10px"
- });
- }
- },
- watch: {
- value(newVal) {
- if (newVal === null) {
- this.val = "";
- return;
- }
- this.val = newVal;
- },
- modelValue(newVal) {
- if (newVal === null) {
- this.val = "";
- return;
- }
- this.val = newVal;
- },
- focus(newVal) {
- this.$nextTick(() => {
- this.focused = this.focus;
- this.focusShow = this.focus;
- });
- }
- },
- created() {
- this.init();
- if (this.form && this.formItem) {
- this.$watch("formItem.errMsg", (newVal) => {
- this.localMsg = newVal;
- });
- }
- },
- mounted() {
- this.$nextTick(() => {
- this.focused = this.focus;
- this.focusShow = this.focus;
- });
- },
- methods: {
- /**
- * 初始化变量值
- */
- init() {
- if (this.value || this.value === 0) {
- this.val = this.value;
- } else if (this.modelValue || this.modelValue === 0 || this.modelValue === "") {
- this.val = this.modelValue;
- } else {
- this.val = "";
- }
- },
- /**
- * 点击图标时触发
- * @param {Object} type
- */
- onClickIcon(type) {
- this.$emit("iconClick", type);
- },
- /**
- * 显示隐藏内容,密码框时生效
- */
- onEyes() {
- this.showPassword = !this.showPassword;
- this.$emit("eyes", this.showPassword);
- },
- /**
- * 输入时触发
- * @param {Object} event
- */
- onInput(event) {
- let value = event.detail.value;
- if (this.trim) {
- if (typeof this.trim === "boolean" && this.trim) {
- value = this.trimStr(value);
- }
- if (typeof this.trim === "string") {
- value = this.trimStr(value, this.trim);
- }
- }
- if (this.errMsg)
- this.errMsg = "";
- this.val = value;
- this.$emit("input", value);
- this.$emit("update:modelValue", value);
- },
- /**
- * 外部调用方法
- * 获取焦点时触发
- * @param {Object} event
- */
- onFocus() {
- this.$nextTick(() => {
- this.focused = true;
- });
- this.$emit("focus", null);
- },
- _Focus(event) {
- this.focusShow = true;
- this.$emit("focus", event);
- },
- /**
- * 外部调用方法
- * 失去焦点时触发
- * @param {Object} event
- */
- onBlur() {
- this.focused = false;
- this.$emit("blur", null);
- },
- _Blur(event) {
- event.detail.value;
- this.focusShow = false;
- this.$emit("blur", event);
- if (this.isEnter === false) {
- this.$emit("change", this.val);
- }
- if (this.form && this.formItem) {
- const { validateTrigger } = this.form;
- if (validateTrigger === "blur") {
- this.formItem.onFieldChange();
- }
- }
- },
- /**
- * 按下键盘的发送键
- * @param {Object} e
- */
- onConfirm(e2) {
- this.$emit("confirm", this.val);
- this.isEnter = true;
- this.$emit("change", this.val);
- this.$nextTick(() => {
- this.isEnter = false;
- });
- },
- /**
- * 清理内容
- * @param {Object} event
- */
- onClear(event) {
- this.val = "";
- this.$emit("input", "");
- this.$emit("update:modelValue", "");
- this.$emit("clear");
- },
- /**
- * 键盘高度发生变化的时候触发此事件
- * 兼容性:微信小程序2.7.0+、App 3.1.0+
- * @param {Object} event
- */
- onkeyboardheightchange(event) {
- this.$emit("keyboardheightchange", event);
- },
- /**
- * 去除空格
- */
- trimStr(str, pos = "both") {
- if (pos === "both") {
- return str.trim();
- } else if (pos === "left") {
- return str.trimLeft();
- } else if (pos === "right") {
- return str.trimRight();
- } else if (pos === "start") {
- return str.trimStart();
- } else if (pos === "end") {
- return str.trimEnd();
- } else if (pos === "all") {
- return str.replace(/\s+/g, "");
- } else if (pos === "none") {
- return str;
- }
- return str;
- }
- }
- };
- function _sfc_render$3(_ctx, _cache, $props, $setup, $data, $options) {
- const _component_uni_icons = resolveEasycom(vue.resolveDynamicComponent("uni-icons"), __easycom_1$1);
- return vue.openBlock(), vue.createElementBlock(
- "view",
- {
- class: vue.normalizeClass(["uni-easyinput", { "uni-easyinput-error": $options.msg }]),
- style: vue.normalizeStyle($options.boxStyle)
- },
- [
- vue.createElementVNode(
- "view",
- {
- class: vue.normalizeClass(["uni-easyinput__content", $options.inputContentClass]),
- style: vue.normalizeStyle($options.inputContentStyle)
- },
- [
- $props.prefixIcon ? (vue.openBlock(), vue.createBlock(_component_uni_icons, {
- key: 0,
- class: "content-clear-icon",
- type: $props.prefixIcon,
- color: "#c0c4cc",
- onClick: _cache[0] || (_cache[0] = ($event) => $options.onClickIcon("prefix")),
- size: "22"
- }, null, 8, ["type"])) : vue.createCommentVNode("v-if", true),
- vue.renderSlot(_ctx.$slots, "left", {}, void 0, true),
- $props.type === "textarea" ? (vue.openBlock(), vue.createElementBlock("textarea", {
- key: 1,
- class: vue.normalizeClass(["uni-easyinput__content-textarea", { "input-padding": $props.inputBorder }]),
- name: $props.name,
- value: $data.val,
- placeholder: $props.placeholder,
- placeholderStyle: $props.placeholderStyle,
- disabled: $props.disabled,
- "placeholder-class": "uni-easyinput__placeholder-class",
- maxlength: $options.inputMaxlength,
- focus: $data.focused,
- autoHeight: $props.autoHeight,
- "cursor-spacing": $props.cursorSpacing,
- "adjust-position": $props.adjustPosition,
- onInput: _cache[1] || (_cache[1] = (...args) => $options.onInput && $options.onInput(...args)),
- onBlur: _cache[2] || (_cache[2] = (...args) => $options._Blur && $options._Blur(...args)),
- onFocus: _cache[3] || (_cache[3] = (...args) => $options._Focus && $options._Focus(...args)),
- onConfirm: _cache[4] || (_cache[4] = (...args) => $options.onConfirm && $options.onConfirm(...args)),
- onKeyboardheightchange: _cache[5] || (_cache[5] = (...args) => $options.onkeyboardheightchange && $options.onkeyboardheightchange(...args))
- }, null, 42, ["name", "value", "placeholder", "placeholderStyle", "disabled", "maxlength", "focus", "autoHeight", "cursor-spacing", "adjust-position"])) : (vue.openBlock(), vue.createElementBlock("input", {
- key: 2,
- type: $props.type === "password" ? "text" : $props.type,
- class: "uni-easyinput__content-input",
- style: vue.normalizeStyle($options.inputStyle),
- name: $props.name,
- value: $data.val,
- password: !$data.showPassword && $props.type === "password",
- placeholder: $props.placeholder,
- placeholderStyle: $props.placeholderStyle,
- "placeholder-class": "uni-easyinput__placeholder-class",
- disabled: $props.disabled,
- maxlength: $options.inputMaxlength,
- focus: $data.focused,
- confirmType: $props.confirmType,
- "cursor-spacing": $props.cursorSpacing,
- "adjust-position": $props.adjustPosition,
- onFocus: _cache[6] || (_cache[6] = (...args) => $options._Focus && $options._Focus(...args)),
- onBlur: _cache[7] || (_cache[7] = (...args) => $options._Blur && $options._Blur(...args)),
- onInput: _cache[8] || (_cache[8] = (...args) => $options.onInput && $options.onInput(...args)),
- onConfirm: _cache[9] || (_cache[9] = (...args) => $options.onConfirm && $options.onConfirm(...args)),
- onKeyboardheightchange: _cache[10] || (_cache[10] = (...args) => $options.onkeyboardheightchange && $options.onkeyboardheightchange(...args))
- }, null, 44, ["type", "name", "value", "password", "placeholder", "placeholderStyle", "disabled", "maxlength", "focus", "confirmType", "cursor-spacing", "adjust-position"])),
- $props.type === "password" && $props.passwordIcon ? (vue.openBlock(), vue.createElementBlock(
- vue.Fragment,
- { key: 3 },
- [
- vue.createCommentVNode(" 开启密码时显示小眼睛 "),
- $options.isVal ? (vue.openBlock(), vue.createBlock(_component_uni_icons, {
- key: 0,
- class: vue.normalizeClass(["content-clear-icon", { "is-textarea-icon": $props.type === "textarea" }]),
- type: $data.showPassword ? "eye-slash-filled" : "eye-filled",
- size: 22,
- color: $data.focusShow ? $props.primaryColor : "#c0c4cc",
- onClick: $options.onEyes
- }, null, 8, ["class", "type", "color", "onClick"])) : vue.createCommentVNode("v-if", true)
- ],
- 64
- /* STABLE_FRAGMENT */
- )) : vue.createCommentVNode("v-if", true),
- $props.suffixIcon ? (vue.openBlock(), vue.createElementBlock(
- vue.Fragment,
- { key: 4 },
- [
- $props.suffixIcon ? (vue.openBlock(), vue.createBlock(_component_uni_icons, {
- key: 0,
- class: "content-clear-icon",
- type: $props.suffixIcon,
- color: "#c0c4cc",
- onClick: _cache[11] || (_cache[11] = ($event) => $options.onClickIcon("suffix")),
- size: "22"
- }, null, 8, ["type"])) : vue.createCommentVNode("v-if", true)
- ],
- 64
- /* STABLE_FRAGMENT */
- )) : (vue.openBlock(), vue.createElementBlock(
- vue.Fragment,
- { key: 5 },
- [
- $props.clearable && $options.isVal && !$props.disabled && $props.type !== "textarea" ? (vue.openBlock(), vue.createBlock(_component_uni_icons, {
- key: 0,
- class: vue.normalizeClass(["content-clear-icon", { "is-textarea-icon": $props.type === "textarea" }]),
- type: "clear",
- size: $props.clearSize,
- color: $options.msg ? "#dd524d" : $data.focusShow ? $props.primaryColor : "#c0c4cc",
- onClick: $options.onClear
- }, null, 8, ["class", "size", "color", "onClick"])) : vue.createCommentVNode("v-if", true)
- ],
- 64
- /* STABLE_FRAGMENT */
- )),
- vue.renderSlot(_ctx.$slots, "right", {}, void 0, true)
- ],
- 6
- /* CLASS, STYLE */
- )
- ],
- 6
- /* CLASS, STYLE */
- );
- }
- const __easycom_1 = /* @__PURE__ */ _export_sfc(_sfc_main$o, [["render", _sfc_render$3], ["__scopeId", "data-v-09fd5285"], ["__file", "D:/projects/cxc-szcx-uniapp/uni_modules/uni-easyinput/components/uni-easyinput/uni-easyinput.vue"]]);
- function isString(data) {
- return typeof data === "string";
- }
- function paging(data, PAGENUM = 50) {
- if (!Array.isArray(data) || !data.length)
- return data;
- const pages2 = [];
- data.forEach((item, index) => {
- const i2 = Math.floor(index / PAGENUM);
- if (!pages2[i2]) {
- pages2[i2] = [];
- }
- pages2[i2].push(item);
- });
- return pages2;
- }
- const _sfc_main$n = /* @__PURE__ */ vue.defineComponent({
- __name: "data-select-item",
- props: {
- node: {
- type: Object,
- default: () => ({})
- },
- choseParent: {
- type: Boolean,
- default: true
- },
- dataLabel: {
- type: String,
- default: "name"
- },
- dataValue: {
- type: String,
- default: "value"
- },
- dataChildren: {
- type: String,
- default: "children"
- },
- border: {
- type: Boolean,
- default: false
- },
- linkage: {
- type: Boolean,
- default: false
- },
- lazyLoadChildren: {
- type: Boolean,
- default: false
- },
- level: {
- type: Number,
- default: 0
- }
- },
- setup(__props) {
- const { nodeClick, nameClick, loadNode, initData, addNode } = vue.inject("nodeFn");
- const props = __props;
- const listData = vue.ref([]);
- const clearTimerList = vue.ref([]);
- const loadingArr = vue.ref([]);
- vue.watchEffect(() => {
- if (props.node.showChildren && props.node[props.dataChildren] && props.node[props.dataChildren].length) {
- resetClearTimerList();
- renderTree(props.node[props.dataChildren]);
- }
- });
- function resetClearTimerList() {
- const list = [...clearTimerList.value];
- clearTimerList.value = [];
- list.forEach((fn) => fn());
- }
- function renderTree(arr) {
- const pagingArr = paging(arr);
- listData.value = (pagingArr == null ? void 0 : pagingArr[0]) || [];
- lazyRenderList(pagingArr, 1);
- }
- function lazyRenderList(arr, startIndex) {
- for (let i2 = startIndex; i2 < arr.length; i2++) {
- let timer = null;
- timer = setTimeout(() => {
- listData.value.push(...arr[i2]);
- }, i2 * 500);
- clearTimerList.push(() => clearTimeout(timer));
- }
- }
- function handleNameClick(node) {
- var _a;
- if (!node.visible)
- return;
- if (!((_a = node[props.dataChildren]) == null ? void 0 : _a.length) && props.lazyLoadChildren) {
- loadingArr.value.push(node[props.dataValue].toString());
- loadNode(node).then((res) => {
- addNode(node, initData(res, node.visible));
- }).finally(() => {
- loadingArr.value = [];
- });
- } else {
- nameClick(node);
- }
- }
- return (_ctx, _cache) => {
- const _component_uni_icons = resolveEasycom(vue.resolveDynamicComponent("uni-icons"), __easycom_1$1);
- return vue.openBlock(), vue.createElementBlock(
- "view",
- {
- class: vue.normalizeClass(["customthree-tree-select-content", {
- border: __props.border && __props.node[__props.dataChildren] && __props.node[__props.dataChildren].length && __props.node.showChildren
- }]),
- style: vue.normalizeStyle({ marginLeft: `${__props.level ? 14 : 0}px` })
- },
- [
- __props.node.visible ? (vue.openBlock(), vue.createElementBlock("view", {
- key: 0,
- class: "custom-tree-select-item"
- }, [
- vue.createElementVNode("view", { class: "item-content" }, [
- vue.createElementVNode("view", {
- class: "left",
- onClick: _cache[0] || (_cache[0] = vue.withModifiers(($event) => handleNameClick(__props.node), ["stop"]))
- }, [
- vue.createElementVNode("view", { class: "icon-group" }, [
- __props.node[__props.dataChildren] && __props.node[__props.dataChildren].length ? (vue.openBlock(), vue.createElementBlock(
- "view",
- {
- key: 0,
- class: vue.normalizeClass(["right-icon", { active: __props.node.showChildren }])
- },
- [
- vue.createVNode(_component_uni_icons, {
- type: "right",
- size: "14",
- color: "#333"
- })
- ],
- 2
- /* CLASS */
- )) : (vue.openBlock(), vue.createElementBlock("view", {
- key: 1,
- class: "smallcircle-filled"
- }, [
- vue.createVNode(_component_uni_icons, {
- class: "smallcircle-filled-icon",
- type: "smallcircle-filled",
- size: "10",
- color: "#333"
- })
- ]))
- ]),
- loadingArr.value.includes(__props.node[props.dataValue].toString()) ? (vue.openBlock(), vue.createElementBlock("view", {
- key: 0,
- class: "loading-icon-box"
- }, [
- vue.createVNode(_component_uni_icons, {
- class: "loading-icon",
- type: "spinner-cycle",
- size: "14",
- color: "#333"
- })
- ])) : vue.createCommentVNode("v-if", true),
- vue.createElementVNode(
- "view",
- {
- class: "name",
- style: vue.normalizeStyle(__props.node.disabled ? "color: #999" : "")
- },
- [
- vue.createElementVNode(
- "text",
- null,
- vue.toDisplayString(__props.node[__props.dataLabel]),
- 1
- /* TEXT */
- )
- ],
- 4
- /* STYLE */
- )
- ]),
- __props.choseParent || !__props.choseParent && !__props.node[__props.dataChildren] || !__props.choseParent && __props.node[__props.dataChildren] && !__props.node[__props.dataChildren].length ? (vue.openBlock(), vue.createElementBlock(
- "view",
- {
- key: 0,
- class: vue.normalizeClass(["check-box", { disabled: __props.node.disabled }]),
- onClick: _cache[1] || (_cache[1] = vue.withModifiers(($event) => !__props.node.disabled && vue.unref(nodeClick)(__props.node), ["stop"]))
- },
- [
- !__props.node.checked && __props.node.partChecked && __props.linkage ? (vue.openBlock(), vue.createElementBlock("view", {
- key: 0,
- class: "part-checked"
- })) : vue.createCommentVNode("v-if", true),
- __props.node.checked ? (vue.openBlock(), vue.createBlock(_component_uni_icons, {
- key: 1,
- type: "checkmarkempty",
- size: "18",
- color: __props.node.disabled ? "#333" : "#007aff"
- }, null, 8, ["color"])) : vue.createCommentVNode("v-if", true)
- ],
- 2
- /* CLASS */
- )) : vue.createCommentVNode("v-if", true)
- ])
- ])) : vue.createCommentVNode("v-if", true),
- __props.node.showChildren && __props.node[__props.dataChildren] && __props.node[__props.dataChildren].length ? (vue.openBlock(), vue.createElementBlock("view", { key: 1 }, [
- (vue.openBlock(true), vue.createElementBlock(
- vue.Fragment,
- null,
- vue.renderList(listData.value, (item) => {
- return vue.openBlock(), vue.createBlock(dataSelectItem, {
- key: item[__props.dataValue],
- node: item,
- dataLabel: __props.dataLabel,
- dataValue: __props.dataValue,
- dataChildren: __props.dataChildren,
- choseParent: __props.choseParent,
- lazyLoadChildren: __props.lazyLoadChildren,
- border: __props.border,
- linkage: __props.linkage,
- level: __props.level + 1
- }, null, 8, ["node", "dataLabel", "dataValue", "dataChildren", "choseParent", "lazyLoadChildren", "border", "linkage", "level"]);
- }),
- 128
- /* KEYED_FRAGMENT */
- ))
- ])) : vue.createCommentVNode("v-if", true)
- ],
- 6
- /* CLASS, STYLE */
- );
- };
- }
- });
- const dataSelectItem = /* @__PURE__ */ _export_sfc(_sfc_main$n, [["__scopeId", "data-v-3a65eef7"], ["__file", "D:/projects/cxc-szcx-uniapp/components/treeSelect/data-select-item.vue"]]);
- const _sfc_main$m = /* @__PURE__ */ vue.defineComponent({
- __name: "treeSelect",
- props: {
- canSelectAll: {
- type: Boolean,
- default: false
- },
- safeArea: {
- type: Boolean,
- default: true
- },
- search: {
- type: Boolean,
- default: false
- },
- clearResetSearch: {
- type: Boolean,
- default: false
- },
- animation: {
- type: Boolean,
- default: true
- },
- "is-mask-click": {
- type: Boolean,
- default: true
- },
- "mask-background-color": {
- type: String,
- default: "rgba(0,0,0,0.4)"
- },
- "background-color": {
- type: String,
- default: "none"
- },
- "safe-area": {
- type: Boolean,
- default: true
- },
- choseParent: {
- type: Boolean,
- default: false
- },
- placeholder: {
- type: String,
- default: "请选择"
- },
- confirmText: {
- type: String,
- default: "确认"
- },
- confirmTextColor: {
- type: String,
- default: "#007aff"
- },
- dataSource: {
- type: Array,
- default: () => []
- },
- dataLabel: {
- type: String,
- default: "name"
- },
- dataValue: {
- type: String,
- default: "id"
- },
- dataChildren: {
- type: String,
- default: "children"
- },
- linkage: {
- type: Boolean,
- default: false
- },
- removeLinkage: {
- type: Boolean,
- default: true
- },
- clearable: {
- type: Boolean,
- default: false
- },
- mutiple: {
- type: Boolean,
- default: false
- },
- disabled: {
- type: Boolean,
- default: false
- },
- deleteSource: {
- type: Boolean,
- default: false
- },
- showChildren: {
- type: Boolean,
- default: false
- },
- border: {
- type: Boolean,
- default: false
- },
- lazyLoadChildren: {
- type: Boolean,
- default: false
- },
- load: {
- type: Function,
- default: function() {
- }
- },
- modelValue: {
- type: [Array, String],
- default: () => []
- }
- },
- emits: ["update:modelValue", "change", "maskClick", "select-change", "removeSelect"],
- setup(__props, { emit: __emit }) {
- const props = __props;
- const emits = __emit;
- const contentHeight = vue.ref("500px");
- const treeData = vue.ref([]);
- const filterTreeData = vue.ref([]);
- const clearTimerList = vue.ref([]);
- const selectedListBaseinfo = vue.ref([]);
- const showPopup = vue.ref(false);
- const isSelectedAll = vue.ref(false);
- const scrollTop = vue.ref(0);
- const searchStr = vue.ref("");
- const popup = vue.ref(null);
- const partCheckedSet = /* @__PURE__ */ new Set();
- vue.provide("nodeFn", {
- nodeClick: handleNodeClick,
- nameClick: handleHideChildren,
- loadNode: props.load,
- initData,
- addNode
- });
- const selectList = vue.computed(() => {
- const newVal = props.modelValue === null ? "" : props.modelValue;
- return isString(newVal) ? newVal.length ? newVal.split(",") : [] : newVal.map((item) => item.toString());
- });
- vue.onMounted(() => {
- getContentHeight(uni.getSystemInfoSync());
- });
- function getContentHeight({ screenHeight }) {
- contentHeight.value = `${Math.floor(screenHeight * 0.7)}px`;
- }
- vue.watch(
- () => props.dataSource,
- (newVal) => {
- if (newVal) {
- treeData.value = initData(newVal);
- if (showPopup.value) {
- resetClearTimerList();
- renderTree(treeData.value);
- }
- }
- },
- { immediate: true, deep: true }
- );
- vue.watch(
- () => props.modelValue,
- (newVal) => {
- const ids = newVal ? Array.isArray(newVal) ? newVal : newVal.split(",") : [];
- changeStatus(treeData.value, ids, true);
- filterTreeData.value.length && changeStatus(filterTreeData.value, ids);
- },
- { immediate: true }
- );
- function goTop() {
- scrollTop.val = 10;
- vue.nextTick(() => {
- scrollTop.value = 0;
- });
- }
- function handleSearch(isClear = false) {
- resetClearTimerList();
- if (isClear) {
- if (props.clearResetSearch) {
- renderTree(treeData.value);
- }
- } else {
- renderTree(searchValue(searchStr.value, treeData.value));
- }
- goTop();
- uni.hideKeyboard();
- }
- function searchValue(str, arr) {
- const res = [];
- arr.forEach((item) => {
- var _a, _b;
- if (item.visible) {
- if (item[props.dataLabel].toString().toLowerCase().indexOf(str.toLowerCase()) > -1) {
- res.push(item);
- } else {
- if ((_a = item[props.dataChildren]) == null ? void 0 : _a.length) {
- const data = searchValue(str, item[props.dataChildren]);
- if (data == null ? void 0 : data.length) {
- if (str && !item.showChildren && ((_b = item[props.dataChildren]) == null ? void 0 : _b.length)) {
- item.showChildren = true;
- }
- res.push({
- ...item,
- [props.dataChildren]: data
- });
- }
- }
- }
- }
- });
- return res;
- }
- async function open2() {
- if (props.disabled)
- return;
- showPopup.value = true;
- popup.value.open();
- renderTree(treeData.value);
- }
- function close() {
- popup.value.close();
- }
- function change(data) {
- if (!data.show) {
- resetClearTimerList();
- searchStr.value = "";
- showPopup.value = false;
- }
- emits("change", data);
- }
- function maskClick() {
- emits("maskClick");
- }
- function initData(arr, parentVisible) {
- var _a;
- if (!Array.isArray(arr))
- return [];
- const res = [];
- for (let i2 = 0; i2 < arr.length; i2++) {
- const obj = {
- [props.dataLabel]: arr[i2][props.dataLabel],
- [props.dataValue]: arr[i2][props.dataValue]
- };
- obj.checked = selectList.value.includes(arr[i2][props.dataValue].toString());
- obj.disabled = Boolean(arr[i2].disabled);
- obj.partChecked = Boolean(arr[i2].partChecked === void 0 ? false : arr[i2].partChecked);
- obj.partChecked && obj.partCheckedSet.add(obj[props.dataValue]);
- !obj.partChecked && (isSelectedAll.value = false);
- const parentVisibleState = parentVisible === void 0 ? true : parentVisible;
- const curVisibleState = arr[i2].visible === void 0 ? true : Boolean(arr[i2].visible);
- if (parentVisibleState === curVisibleState) {
- obj.visible = parentVisibleState;
- } else if (!parentVisibleState || !curVisibleState) {
- obj.visible = false;
- } else {
- obj.visible = true;
- }
- obj.showChildren = "showChildren" in arr[i2] && arr[i2].showChildren != void 0 ? arr[i2].showChildren : props.showChildren;
- if (arr[i2].visible && !arr[i2].disabled && !arr[i2].checked) {
- isSelectedAll.value = false;
- }
- if ((_a = arr[i2][props.dataChildren]) == null ? void 0 : _a.length) {
- obj[props.dataChildren] = initData(arr[i2][props.dataChildren], obj.visible);
- }
- res.push(obj);
- }
- return res;
- }
- function addNode(node, children) {
- getReflectNode(node, treeData.value)[props.dataChildren] = children;
- handleHideChildren(node);
- }
- function resetClearTimerList() {
- const list = [...clearTimerList.value];
- clearTimerList.value = [];
- list.forEach((fn) => fn());
- }
- function renderTree(arr) {
- const pagingArr = paging(arr);
- filterTreeData.value = (pagingArr == null ? void 0 : pagingArr[0]) || [];
- lazyRenderList(pagingArr, 1);
- }
- function lazyRenderList(arr, startIndex) {
- for (let i2 = startIndex; i2 < arr.length; i2++) {
- let timer = null;
- timer = setTimeout(() => {
- filterTreeData.value.push(...arr[i2]);
- }, i2 * 500);
- clearTimerList.push(() => clearTimeout(timer));
- }
- }
- function changeStatus(list, ids, needEmit = false) {
- var _a;
- const arr = [...list];
- let flag = true;
- needEmit && (selectedListBaseinfo.value = []);
- while (arr.length) {
- const item = arr.shift();
- if (ids.includes(item[props.dataValue].toString())) {
- item.checked = true;
- item.partChecked = false;
- partCheckedSet.delete(item[props.dataValue]);
- needEmit && selectedListBaseinfo.value.push(item);
- } else {
- item.checked = false;
- if (item.visible && !item.disabled) {
- flag = false;
- }
- if (partCheckedSet.has(item[props.dataValue])) {
- item.partChecked = true;
- } else {
- item.partChecked = false;
- }
- }
- if ((_a = item[props.dataChildren]) == null ? void 0 : _a.length) {
- arr.push(...item[props.dataChildren]);
- }
- }
- isSelectedAll.value = flag;
- needEmit && emits("select-change", [...selectedListBaseinfo.value]);
- }
- function removeSelectedItem(node) {
- isSelectedAll.value = false;
- if (props.linkage) {
- handleNodeClick(node, false);
- emits("removeSelect", node);
- } else {
- const emitData = selectList.value.filter((item) => item !== node[props.dataValue].toString());
- emits("removeSelect", node);
- emits("update:modelValue", isString(props.modelValue) ? emitData.join(",") : emitData);
- }
- }
- function getReflectNode(node, arr) {
- var _a;
- const array = [...arr];
- while (array.length) {
- const item = array.shift();
- if (item[props.dataValue] === node[props.dataValue]) {
- return item;
- }
- if ((_a = item[props.dataChildren]) == null ? void 0 : _a.length) {
- array.push(...item[props.dataChildren]);
- }
- }
- return {};
- }
- function getChildren(node) {
- var _a;
- if (!((_a = node[props.dataChildren]) == null ? void 0 : _a.length))
- return [];
- const res = node[props.dataChildren].reduce((pre, val) => {
- if (val.visible) {
- return [...pre, val];
- }
- return pre;
- }, []);
- for (let i2 = 0; i2 < node[props.dataChildren].length; i2++) {
- res.push(...getChildren(node[props.dataChildren][i2]));
- }
- return res;
- }
- function getParentNode(target, arr) {
- var _a;
- let res = [];
- for (let i2 = 0; i2 < arr.length; i2++) {
- if (arr[i2][props.dataValue] === target[props.dataValue]) {
- return true;
- }
- if ((_a = arr[i2][props.dataChildren]) == null ? void 0 : _a.length) {
- const childRes = getParentNode(target, arr[i2][props.dataChildren]);
- if (typeof childRes === "boolean" && childRes) {
- res = [arr[i2]];
- } else if (Array.isArray(childRes) && childRes.length) {
- res = [...childRes, arr[i2]];
- }
- }
- }
- return res;
- }
- function handleNodeClick(data, status) {
- const node = getReflectNode(data, treeData.value);
- node.checked = typeof status === "boolean" ? status : !node.checked;
- node.partChecked = false;
- partCheckedSet.delete(node[props.dataValue]);
- if (!props.mutiple) {
- let emitData = [];
- if (node.checked) {
- emitData = [node[props.dataValue].toString()];
- }
- emits("update:modelValue", isString(props.modelValue) ? emitData.join(",") : emitData);
- } else {
- if (!props.linkage) {
- let emitData = null;
- if (node.checked) {
- emitData = Array.from(/* @__PURE__ */ new Set([...selectList.value, node[props.dataValue].toString()]));
- } else {
- emitData = selectList.value.filter((id) => id !== node[props.dataValue].toString());
- }
- emits("update:modelValue", isString(props.modelValue) ? emitData.join(",") : emitData);
- } else {
- let emitData = [...selectList.value];
- const parentNodes = getParentNode(node, treeData.value);
- const childrenVal = getChildren(node).filter((item) => !item.disabled);
- if (node.checked) {
- emitData = Array.from(/* @__PURE__ */ new Set([...emitData, node[props.dataValue].toString()]));
- if (childrenVal.length) {
- emitData = Array.from(
- /* @__PURE__ */ new Set([...emitData, ...childrenVal.map((item) => item[props.dataValue].toString())])
- );
- childrenVal.forEach((childNode) => {
- childNode.partChecked = false;
- partCheckedSet.delete(childNode[props.dataValue]);
- });
- }
- if (parentNodes.length) {
- let flag = false;
- while (parentNodes.length) {
- const item = parentNodes.shift();
- if (!item.disabled) {
- if (flag) {
- item.partChecked = true;
- partCheckedSet.add(item[props.dataValue]);
- } else {
- const allChecked = item[props.dataChildren].filter((node2) => node2.visible && !node2.disabled).every((node2) => node2.checked);
- if (allChecked) {
- item.checked = true;
- item.partChecked = false;
- partCheckedSet.delete(item[props.dataValue]);
- emitData = Array.from(/* @__PURE__ */ new Set([...emitData, item[props.dataValue].toString()]));
- } else {
- item.partChecked = true;
- partCheckedSet.add(item[props.dataValue]);
- flag = true;
- }
- }
- }
- }
- }
- } else {
- emitData = emitData.filter((id) => id !== node[props.dataValue].toString());
- if (childrenVal.length) {
- childrenVal.forEach((childNode) => {
- emitData = emitData.filter((id) => id !== childNode[props.dataValue].toString());
- });
- }
- if (parentNodes.length) {
- parentNodes.forEach((parentNode) => {
- if (emitData.includes(parentNode[props.dataValue].toString())) {
- parentNode.checked = false;
- }
- emitData = emitData.filter((id) => id !== parentNode[props.dataValue].toString());
- const hasChecked = parentNode[props.dataChildren].filter((node2) => node2.visible && !node2.disabled).some((node2) => node2.checked || node2.partChecked);
- parentNode.partChecked = hasChecked;
- if (hasChecked) {
- partCheckedSet.add(parentNode[props.dataValue]);
- } else {
- partCheckedSet.delete(parentNode[props.dataValue]);
- }
- });
- }
- }
- emits("update:modelValue", isString(props.modelValue) ? emitData.join(",") : emitData);
- }
- }
- }
- function handleHideChildren(node) {
- const status = !node.showChildren;
- getReflectNode(node, treeData.value).showChildren = status;
- getReflectNode(node, filterTreeData.value).showChildren = status;
- }
- function handleSelectAll() {
- isSelectedAll.value = !isSelectedAll.value;
- if (isSelectedAll.value) {
- if (!props.mutiple) {
- uni.showToast({
- title: "单选模式下不能全选",
- icon: "none",
- duration: 1e3
- });
- return;
- }
- let emitData = [];
- treeData.value.forEach((item) => {
- var _a;
- if (item.visible || item.disabled && item.checked) {
- emitData = Array.from(/* @__PURE__ */ new Set([...emitData, item[props.dataValue].toString()]));
- if ((_a = item[props.dataChildren]) == null ? void 0 : _a.length) {
- emitData = Array.from(
- /* @__PURE__ */ new Set([
- ...emitData,
- ...getChildren(item).filter((item2) => !item2.disabled || item2.disabled && item2.checked).map((item2) => item2[props.dataValue].toString())
- ])
- );
- }
- }
- });
- emits("update:modelValue", isString(props.modelValue) ? emitData.join(",") : emitData);
- } else {
- clearSelectList();
- }
- }
- function clearSelectList() {
- if (props.disabled)
- return;
- partCheckedSet.clear();
- const emitData = [];
- selectedListBaseinfo.value.forEach((node) => {
- if (node.visible && node.checked && node.disabled) {
- emitData.push(node[props.dataValue]);
- }
- });
- emits("update:modelValue", isString(props.modelValue) ? emitData.join(",") : emitData);
- }
- return (_ctx, _cache) => {
- const _component_uni_icons = resolveEasycom(vue.resolveDynamicComponent("uni-icons"), __easycom_1$1);
- const _component_uni_easyinput = resolveEasycom(vue.resolveDynamicComponent("uni-easyinput"), __easycom_1);
- const _component_uni_popup = resolveEasycom(vue.resolveDynamicComponent("uni-popup"), __easycom_2);
- return vue.openBlock(), vue.createElementBlock(
- vue.Fragment,
- null,
- [
- vue.createElementVNode(
- "view",
- {
- class: vue.normalizeClass(["select-list", { disabled: __props.disabled }, { active: selectList.value.length }]),
- onClick: open2
- },
- [
- vue.createElementVNode("view", { class: "left" }, [
- selectList.value.length ? (vue.openBlock(), vue.createElementBlock("view", {
- key: 0,
- class: "select-items"
- }, [
- (vue.openBlock(true), vue.createElementBlock(
- vue.Fragment,
- null,
- vue.renderList(selectedListBaseinfo.value, (item) => {
- return vue.openBlock(), vue.createElementBlock("view", {
- class: "select-item",
- key: item[__props.dataValue]
- }, [
- vue.createElementVNode("view", { class: "name" }, [
- vue.createElementVNode(
- "text",
- null,
- vue.toDisplayString(item[__props.dataLabel]),
- 1
- /* TEXT */
- )
- ]),
- !__props.disabled && !item.disabled && __props.deleteSource ? (vue.openBlock(), vue.createElementBlock("view", {
- key: 0,
- class: "close",
- onClick: vue.withModifiers(($event) => removeSelectedItem(item), ["stop"])
- }, [
- vue.createVNode(_component_uni_icons, {
- type: "closeempty",
- size: "16",
- color: "#999"
- })
- ], 8, ["onClick"])) : vue.createCommentVNode("v-if", true)
- ]);
- }),
- 128
- /* KEYED_FRAGMENT */
- ))
- ])) : (vue.openBlock(), vue.createElementBlock("view", {
- key: 1,
- class: "no-data"
- }, [
- vue.createElementVNode(
- "text",
- null,
- vue.toDisplayString(__props.placeholder),
- 1
- /* TEXT */
- )
- ]))
- ]),
- vue.createElementVNode("view", null, [
- !selectList.value.length || !__props.clearable ? (vue.openBlock(), vue.createBlock(_component_uni_icons, {
- key: 0,
- type: "bottom",
- color: "#333333"
- })) : vue.createCommentVNode("v-if", true),
- vue.createElementVNode("view", {
- onClick: _cache[0] || (_cache[0] = vue.withModifiers(() => {
- }, ["stop"]))
- }, [
- selectList.value.length && __props.clearable ? (vue.openBlock(), vue.createBlock(_component_uni_icons, {
- key: 0,
- type: "clear",
- size: "24",
- color: "#c0c4cc",
- onClick: clearSelectList
- })) : vue.createCommentVNode("v-if", true)
- ])
- ])
- ],
- 2
- /* CLASS */
- ),
- vue.createVNode(_component_uni_popup, {
- ref_key: "popup",
- ref: popup,
- animation: __props.animation,
- "is-mask-click": _ctx.isMaskClick,
- "mask-background-color": _ctx.maskBackgroundColor,
- "background-color": _ctx.backgroundColor,
- "safe-area": __props.safeArea,
- type: "bottom",
- onChange: change,
- onMaskClick: maskClick
- }, {
- default: vue.withCtx(() => [
- vue.createElementVNode(
- "view",
- {
- class: "popup-content",
- style: vue.normalizeStyle({ height: contentHeight.value })
- },
- [
- vue.createElementVNode("view", { class: "title" }, [
- __props.mutiple && __props.canSelectAll ? (vue.openBlock(), vue.createElementBlock("view", {
- key: 0,
- class: "left",
- onClick: handleSelectAll
- }, [
- vue.createElementVNode(
- "text",
- null,
- vue.toDisplayString(isSelectedAll.value ? "取消全选" : "全选"),
- 1
- /* TEXT */
- )
- ])) : vue.createCommentVNode("v-if", true),
- vue.createElementVNode("view", { class: "center" }, [
- vue.createElementVNode(
- "text",
- null,
- vue.toDisplayString(__props.placeholder),
- 1
- /* TEXT */
- )
- ]),
- vue.createElementVNode(
- "view",
- {
- class: "right",
- style: vue.normalizeStyle({ color: __props.confirmTextColor }),
- onClick: close
- },
- [
- vue.createElementVNode(
- "text",
- null,
- vue.toDisplayString(__props.confirmText),
- 1
- /* TEXT */
- )
- ],
- 4
- /* STYLE */
- )
- ]),
- __props.search ? (vue.openBlock(), vue.createElementBlock("view", {
- key: 0,
- class: "search-box"
- }, [
- vue.createVNode(_component_uni_easyinput, {
- maxlength: -1,
- prefixIcon: "search",
- placeholder: "搜索",
- modelValue: searchStr.value,
- "onUpdate:modelValue": _cache[1] || (_cache[1] = ($event) => searchStr.value = $event),
- "confirm-type": "search",
- onConfirm: _cache[2] || (_cache[2] = ($event) => handleSearch(false)),
- onClear: _cache[3] || (_cache[3] = ($event) => handleSearch(true))
- }, null, 8, ["modelValue"]),
- vue.createElementVNode("button", {
- type: "primary",
- size: "mini",
- class: "search-btn",
- onClick: _cache[4] || (_cache[4] = ($event) => handleSearch(false))
- }, "搜索")
- ])) : vue.createCommentVNode("v-if", true),
- treeData.value.length ? (vue.openBlock(), vue.createElementBlock("view", {
- key: 1,
- class: "select-content"
- }, [
- vue.createElementVNode("scroll-view", {
- class: "scroll-view-box",
- "scroll-top": scrollTop.value,
- "scroll-y": "true",
- onTouchmove: _cache[5] || (_cache[5] = vue.withModifiers(() => {
- }, ["stop"]))
- }, [
- !filterTreeData.value.length ? (vue.openBlock(), vue.createElementBlock("view", {
- key: 0,
- class: "no-data center"
- }, [
- vue.createElementVNode("text", null, "暂无数据")
- ])) : vue.createCommentVNode("v-if", true),
- (vue.openBlock(true), vue.createElementBlock(
- vue.Fragment,
- null,
- vue.renderList(filterTreeData.value, (item) => {
- return vue.openBlock(), vue.createBlock(dataSelectItem, {
- key: item[__props.dataValue],
- node: item,
- dataLabel: __props.dataLabel,
- dataValue: __props.dataValue,
- dataChildren: __props.dataChildren,
- choseParent: __props.choseParent,
- border: __props.border,
- linkage: __props.linkage,
- lazyLoadChildren: __props.lazyLoadChildren
- }, null, 8, ["node", "dataLabel", "dataValue", "dataChildren", "choseParent", "border", "linkage", "lazyLoadChildren"]);
- }),
- 128
- /* KEYED_FRAGMENT */
- )),
- vue.createElementVNode("view", { class: "sentry" })
- ], 40, ["scroll-top"])
- ])) : (vue.openBlock(), vue.createElementBlock("view", {
- key: 2,
- class: "no-data center"
- }, [
- vue.createElementVNode("text", null, "暂无数据")
- ]))
- ],
- 4
- /* STYLE */
- )
- ]),
- _: 1
- /* STABLE */
- }, 8, ["animation", "is-mask-click", "mask-background-color", "background-color", "safe-area"])
- ],
- 64
- /* STABLE_FRAGMENT */
- );
- };
- }
- });
- const treeSelect = /* @__PURE__ */ _export_sfc(_sfc_main$m, [["__scopeId", "data-v-0328d33e"], ["__file", "D:/projects/cxc-szcx-uniapp/components/treeSelect/treeSelect.vue"]]);
- const _sfc_main$l = {
- __name: "application",
- setup(__props) {
- const store = useStore();
- const {
- proxy
- } = vue.getCurrentInstance();
- const realname = vue.ref(store.userinfo.realname);
- const depart = vue.ref("");
- const phone = vue.ref(store.userinfo.phone);
- const type = vue.ref("");
- const dataSource = vue.ref([]);
- const beginTime = vue.ref("");
- const chooseStart = (e2) => {
- beginTime.value = e2.detail.value;
- };
- const endTime = vue.ref("");
- const chooseEnd = (e2) => {
- endTime.value = e2.detail.value;
- };
- const typeArr = vue.ref([]);
- const typeIndex = vue.ref(null);
- const ifShow = vue.ref(true);
- const zwcj = vue.ref("");
- const address = vue.ref("");
- const reason = vue.ref("");
- onLoad(() => {
- loadData();
- });
- const qjAdd = () => {
- if (!phone.value.trim())
- return proxy.$toast("请输入联系方式");
- if (!type.value)
- return proxy.$toast("请选择请假类型");
- if (!beginTime.value)
- return proxy.$toast("请选择开始时间");
- if (!endTime.value)
- return proxy.$toast("请选择结束时间");
- if (ifShow.value) {
- if (typeIndex.value == null) {
- return proxy.$toast("请选择审批领导");
- }
- }
- if (!address.value.trim())
- return proxy.$toast("请输入请假地点");
- if (!reason.value.trim())
- return proxy.$toast("请输入请假事由");
- qjAddApi({
- username: store.userinfo.username,
- phone: phone.value,
- type: type.value,
- begintime: beginTime.value,
- endtime: endTime.value,
- examineleader: typeArr.value[typeIndex.value].username,
- address: address.value,
- reason: reason.value,
- zwcj: zwcj.value
- }).then((res) => {
- if (res.success) {
- startMutilProcess(res.message);
- } else {
- proxy.$toast(res.message);
- }
- });
- };
- const startMutilProcess = (id) => {
- startMutilProcessApi({
- flowCode: "dev_cxc_qxj",
- id,
- formUrl: "modules/qxj/modules/CxcQxjBpmModel",
- formUrlMobile: "leaveApplication"
- //对应main.js里全局注册createApp()里的 app.component('leaveApplication',index)
- }).then((res) => {
- if (res.success) {
- proxy.$toast(res.message);
- setTimeout(() => {
- uni.navigateBack();
- }, 2e3);
- }
- }).catch((err) => {
- formatAppLog("log", "at pages/leave/application.vue:198", err);
- });
- };
- const loadData = () => {
- getCategoryItemsApi("1838487445813645313").then((res) => {
- if (res.success) {
- dataSource.value = res.result;
- }
- });
- queryDepByCode(store.userinfo.orgCode).then((res) => {
- if (res.success) {
- depart.value = res.result;
- }
- });
- queryZwmcAndExaApi(store.userinfo.username).then((res) => {
- if (res.success) {
- typeArr.value = res.result.list;
- zwcj.value = res.result.zwmc;
- if (zwcj.value == "单位专家" || zwcj.value == "正职" || zwcj.value == "高级主管") {
- ifShow.value = false;
- }
- } else {
- proxy.$toast(res.message);
- }
- });
- };
- const bindType = (e2) => {
- typeIndex.value = e2.detail.value;
- };
- return (_ctx, _cache) => {
- const _component_uni_icons = resolveEasycom(vue.resolveDynamicComponent("uni-icons"), __easycom_1$1);
- return vue.openBlock(), vue.createElementBlock(
- "view",
- {
- class: vue.normalizeClass({ "gray": vue.unref(store).isgray == 1 })
- },
- [
- vue.createElementVNode("view", { class: "form" }, [
- vue.createElementVNode("view", { class: "f-row aic jcb input_box" }, [
- vue.createElementVNode("view", { class: "title" }, " 职工姓名: "),
- vue.withDirectives(vue.createElementVNode(
- "input",
- {
- "onUpdate:modelValue": _cache[0] || (_cache[0] = ($event) => realname.value = $event),
- disabled: ""
- },
- null,
- 512
- /* NEED_PATCH */
- ), [
- [vue.vModelText, realname.value]
- ])
- ]),
- vue.createElementVNode("view", { class: "f-row aic jcb input_box" }, [
- vue.createElementVNode("view", { class: "title" }, " 工作单位: "),
- vue.withDirectives(vue.createElementVNode(
- "input",
- {
- "onUpdate:modelValue": _cache[1] || (_cache[1] = ($event) => depart.value = $event),
- disabled: ""
- },
- null,
- 512
- /* NEED_PATCH */
- ), [
- [vue.vModelText, depart.value]
- ])
- ]),
- vue.createElementVNode("view", { class: "f-row aic jcb input_box" }, [
- vue.createElementVNode("view", { class: "title" }, " 联系方式: "),
- vue.withDirectives(vue.createElementVNode(
- "input",
- {
- "onUpdate:modelValue": _cache[2] || (_cache[2] = ($event) => phone.value = $event)
- },
- null,
- 512
- /* NEED_PATCH */
- ), [
- [vue.vModelText, phone.value]
- ])
- ]),
- vue.createElementVNode("view", { class: "f-row aic jcb input_box" }, [
- vue.createElementVNode("view", { class: "title" }, " 请假类型: "),
- vue.createVNode(treeSelect, {
- dataSource: dataSource.value,
- modelValue: type.value,
- "onUpdate:modelValue": _cache[3] || (_cache[3] = ($event) => type.value = $event),
- dataValue: "name"
- }, null, 8, ["dataSource", "modelValue"])
- ]),
- vue.createElementVNode("picker", {
- mode: "date",
- fields: "day",
- onChange: chooseStart,
- value: beginTime.value
- }, [
- vue.createElementVNode("view", { class: "f-row aic jcb box" }, [
- vue.createElementVNode("view", { class: "title" }, " 开始时间: "),
- vue.createElementVNode("view", { class: "f-row aic" }, [
- vue.createElementVNode(
- "view",
- {
- class: vue.normalizeClass([{ "choose": !beginTime.value }, { "choosed": beginTime.value }])
- },
- vue.toDisplayString(beginTime.value ? beginTime.value : "请选择"),
- 3
- /* TEXT, CLASS */
- ),
- vue.createVNode(_component_uni_icons, {
- type: "bottom",
- color: "#333333"
- })
- ])
- ])
- ], 40, ["value"]),
- vue.createElementVNode("picker", {
- mode: "date",
- fields: "day",
- onChange: chooseEnd,
- value: endTime.value
- }, [
- vue.createElementVNode("view", { class: "f-row aic jcb box" }, [
- vue.createElementVNode("view", { class: "title" }, " 截止时间: "),
- vue.createElementVNode("view", { class: "f-row aic" }, [
- vue.createElementVNode(
- "view",
- {
- class: vue.normalizeClass([{ "choose": !endTime.value }, { "choosed": endTime.value }])
- },
- vue.toDisplayString(endTime.value ? endTime.value : "请选择"),
- 3
- /* TEXT, CLASS */
- ),
- vue.createVNode(_component_uni_icons, {
- type: "bottom",
- color: "#333333"
- })
- ])
- ])
- ], 40, ["value"]),
- ifShow.value ? (vue.openBlock(), vue.createElementBlock("picker", {
- key: 0,
- onChange: bindType,
- value: typeIndex.value,
- range: typeArr.value,
- "range-key": "realname"
- }, [
- vue.createElementVNode("view", { class: "f-row aic jcb box" }, [
- vue.createElementVNode("view", { class: "title" }, " 审批领导: "),
- vue.createElementVNode("view", { class: "f-row aic" }, [
- vue.createElementVNode(
- "view",
- {
- class: vue.normalizeClass([{ "choose": typeIndex.value == null }, { "choosed": typeIndex.value != null }])
- },
- vue.toDisplayString(typeIndex.value != null ? typeArr.value[typeIndex.value].realname : "请选择"),
- 3
- /* TEXT, CLASS */
- ),
- vue.createVNode(_component_uni_icons, {
- type: "bottom",
- color: "#333333"
- })
- ])
- ])
- ], 40, ["value", "range"])) : vue.createCommentVNode("v-if", true),
- vue.createElementVNode("view", { class: "f-row aic jcb input_box" }, [
- vue.createElementVNode("view", { class: "title" }, " 请假地点: "),
- vue.withDirectives(vue.createElementVNode(
- "input",
- {
- "onUpdate:modelValue": _cache[4] || (_cache[4] = ($event) => address.value = $event),
- type: "text",
- placeholder: "请输入",
- "placeholder-style": "font-size: 28rpx;color: #999999;"
- },
- null,
- 512
- /* NEED_PATCH */
- ), [
- [vue.vModelText, address.value]
- ])
- ])
- ]),
- vue.createElementVNode("view", { class: "reason f-col" }, [
- vue.createElementVNode("view", { class: "title" }, " 请假事由: "),
- vue.withDirectives(vue.createElementVNode(
- "textarea",
- {
- "onUpdate:modelValue": _cache[5] || (_cache[5] = ($event) => reason.value = $event),
- placeholder: "请输入请假事由",
- "placeholder-style": "font-size: 28rpx;color: #999999;",
- cols: "30",
- rows: "10"
- },
- null,
- 512
- /* NEED_PATCH */
- ), [
- [vue.vModelText, reason.value]
- ])
- ]),
- vue.createElementVNode("view", { class: "btn f-col aic" }, [
- vue.createElementVNode("view", { onClick: qjAdd }, " 提交 ")
- ])
- ],
- 2
- /* CLASS */
- );
- };
- }
- };
- const PagesLeaveApplication = /* @__PURE__ */ _export_sfc(_sfc_main$l, [["__scopeId", "data-v-f12ae642"], ["__file", "D:/projects/cxc-szcx-uniapp/pages/leave/application.vue"]]);
- const _sfc_main$k = {
- __name: "index",
- setup(__props) {
- const store = useStore();
- const back = () => {
- uni.navigateBack();
- };
- return (_ctx, _cache) => {
- const _component_uni_icons = resolveEasycom(vue.resolveDynamicComponent("uni-icons"), __easycom_1$1);
- return vue.openBlock(), vue.createElementBlock(
- "view",
- {
- class: vue.normalizeClass(["content", { "gray": vue.unref(store).isgray == 1 }])
- },
- [
- vue.createVNode(customNav, null, {
- default: vue.withCtx(() => [
- vue.createElementVNode("view", { class: "nav_box f-row aic" }, [
- vue.createElementVNode("view", {
- class: "back",
- onClick: back
- }, [
- vue.createVNode(_component_uni_icons, {
- type: "left",
- size: "20",
- color: "#fff"
- })
- ]),
- vue.createElementVNode("view", { class: "avatar" }, [
- vue.createElementVNode("image", {
- src: vue.unref(store).userinfo.avatar,
- mode: ""
- }, null, 8, ["src"])
- ]),
- vue.createElementVNode("view", { class: "f-col" }, [
- vue.createElementVNode(
- "view",
- { class: "name" },
- vue.toDisplayString(vue.unref(store).userinfo.realname),
- 1
- /* TEXT */
- ),
- vue.createElementVNode(
- "view",
- { class: "position" },
- vue.toDisplayString(vue.unref(store).role),
- 1
- /* TEXT */
- )
- ])
- ])
- ]),
- _: 1
- /* STABLE */
- }),
- vue.createElementVNode("view", { class: "time_box f-row aic jcb" }, [
- vue.createElementVNode("view", { class: "box" }, [
- vue.createElementVNode("view", { class: "time f-row aic" }, [
- vue.createElementVNode("view", { class: "" }, " 上班 9:30 "),
- vue.createElementVNode("image", {
- src: "/static/checkin/chenggong.png",
- mode: ""
- })
- ]),
- vue.createElementVNode("view", { class: "text" }, " 重庆市渝北区上弯路 ")
- ]),
- vue.createElementVNode("view", { class: "box" }, [
- vue.createElementVNode("view", { class: "time f-row aic" }, [
- vue.createElementVNode("view", { class: "" }, " 下班 16:30 "),
- vue.createElementVNode("image", {
- src: "/static/checkin/shibai.png",
- mode: ""
- })
- ]),
- vue.createElementVNode("view", { class: "text" }, " 打卡已超时 ")
- ])
- ]),
- vue.createElementVNode("view", { class: "checkin" }, [
- vue.createElementVNode("view", { class: "f-col aic" }, [
- vue.createElementVNode("view", { class: "status f-col aic" }, [
- vue.createCommentVNode(' \r\n \r\n '),
- vue.createElementVNode("image", {
- src: "/static/checkin/position4.png",
- mode: ""
- }),
- vue.createElementVNode("text", null, "打卡失败")
- ]),
- vue.createElementVNode("view", {
- class: vue.normalizeClass(["circle", "f-col", "aic", "out", "check", "success", "fail"])
- }, [
- vue.createElementVNode("view", { class: "title" }, " 上班打卡 "),
- vue.createElementVNode("view", { class: "time" }, " 9:00 "),
- vue.createElementVNode("view", { class: "ontime" }, " 已超时 ")
- ])
- ])
- ])
- ],
- 2
- /* CLASS */
- );
- };
- }
- };
- const PagesCheckinIndex = /* @__PURE__ */ _export_sfc(_sfc_main$k, [["__scopeId", "data-v-1410bd6b"], ["__file", "D:/projects/cxc-szcx-uniapp/pages/checkin/index.vue"]]);
- const _sfc_main$j = {
- __name: "useredit",
- setup(__props) {
- const baseUrl2 = "http://10.75.166.174:8080/jeecg-boot";
- const store = useStore();
- const chooseAvatar = () => {
- uni.chooseImage({
- count: 1,
- success: (chooseImageRes) => {
- const tempFilePaths = chooseImageRes.tempFilePaths;
- uni.uploadFile({
- url: baseUrl2 + "/sys/common/upload",
- //仅为示例,非真实的接口地址
- filePath: tempFilePaths[0],
- name: "file",
- header: {
- "X-Access-Token": store.token
- },
- success: (uploadFileRes) => {
- uni.showLoading({
- title: "上传中..."
- });
- form.avatar = JSON.parse(uploadFileRes.data).message;
- userEditApi({
- avatar: form.avatar,
- id: store.userinfo.id
- }).then((res) => {
- if (res) {
- uni.showToast({
- title: res,
- icon: "success",
- duration: 2e3
- });
- }
- }).catch((err) => {
- formatAppLog("log", "at pages/useredit/useredit.vue:97", err);
- });
- },
- fail(err) {
- formatAppLog("log", "at pages/useredit/useredit.vue:101", "图片上传出错", err);
- }
- });
- }
- });
- };
- const form = vue.reactive({
- avatar: "",
- realname: "",
- phone: ""
- });
- const loginout = () => {
- uni.showModal({
- title: "退出登录",
- content: "您确认要退出登录吗?",
- success(res) {
- if (res.confirm) {
- uni.removeStorageSync("token");
- uni.removeStorageSync("user");
- uni.removeStorageSync("role");
- uni.removeStorageSync("logintime");
- uni.reLaunch({
- url: "/pages/login/login"
- });
- }
- }
- });
- };
- onLoad(() => {
- uni.setNavigationBarColor({
- frontColor: "#ffffff",
- backgroundColor: "#bebebe"
- });
- });
- return (_ctx, _cache) => {
- const _component_uni_icons = resolveEasycom(vue.resolveDynamicComponent("uni-icons"), __easycom_1$1);
- return vue.openBlock(), vue.createElementBlock(
- vue.Fragment,
- null,
- [
- vue.createElementVNode(
- "view",
- {
- class: vue.normalizeClass(["content", { "gray": vue.unref(store).isgray == 1 }])
- },
- [
- vue.createElementVNode("view", { class: "box" }, [
- vue.createElementVNode("view", null, "头像"),
- vue.createElementVNode("view", { style: { "display": "flex", "align-items": "center" } }, [
- vue.createElementVNode("button", {
- class: "head-btn",
- onClick: chooseAvatar
- }, [
- !form.avatar ? (vue.openBlock(), vue.createElementBlock("image", {
- key: 0,
- class: "head-img",
- src: vue.unref(imgUrl)(vue.unref(store).userinfo.avatar),
- mode: ""
- }, null, 8, ["src"])) : (vue.openBlock(), vue.createElementBlock("image", {
- key: 1,
- class: "head-img",
- src: vue.unref(imgUrl)(form.avatar)
- }, null, 8, ["src"]))
- ]),
- vue.createVNode(_component_uni_icons, {
- type: "right",
- size: "24"
- })
- ])
- ]),
- vue.createElementVNode("view", {
- class: "box",
- style: { "padding-top": "30rpx", "padding-bottom": "30rpx" }
- }, [
- vue.createElementVNode("view", null, "姓名"),
- vue.withDirectives(vue.createElementVNode(
- "input",
- {
- disabled: "",
- style: { "text-align": "right" },
- type: "nickname",
- "placeholder-style": "font-size: 32rpx;color: #999999;",
- "onUpdate:modelValue": _cache[0] || (_cache[0] = ($event) => vue.unref(store).userinfo.realname = $event),
- placeholder: "请输入姓名"
- },
- null,
- 512
- /* NEED_PATCH */
- ), [
- [vue.vModelText, vue.unref(store).userinfo.realname]
- ])
- ]),
- vue.createElementVNode("view", {
- class: "box",
- style: { "padding-top": "30rpx", "padding-bottom": "30rpx" }
- }, [
- vue.createElementVNode("view", null, "手机号"),
- vue.withDirectives(vue.createElementVNode(
- "input",
- {
- disabled: "",
- style: { "text-align": "right" },
- type: "nickname",
- "onUpdate:modelValue": _cache[1] || (_cache[1] = ($event) => vue.unref(store).userinfo.phone = $event),
- placeholder: "请输入手机号",
- "placeholder-style": "font-size: 32rpx;color: #999999;"
- },
- null,
- 512
- /* NEED_PATCH */
- ), [
- [vue.vModelText, vue.unref(store).userinfo.phone]
- ])
- ]),
- vue.createElementVNode("view", {
- class: "box",
- style: { "padding-top": "30rpx", "padding-bottom": "30rpx" }
- }, [
- vue.createElementVNode("view", null, "劳动合同号"),
- vue.withDirectives(vue.createElementVNode(
- "input",
- {
- style: { "text-align": "right" },
- type: "nickname",
- disabled: "",
- "onUpdate:modelValue": _cache[2] || (_cache[2] = ($event) => vue.unref(store).userinfo.workNo = $event),
- placeholder: "请输入劳动合同号",
- "placeholder-style": "font-size: 32rpx;color: #999999;"
- },
- null,
- 512
- /* NEED_PATCH */
- ), [
- [vue.vModelText, vue.unref(store).userinfo.workNo]
- ])
- ])
- ],
- 2
- /* CLASS */
- ),
- vue.createElementVNode("view", { class: "line" }),
- vue.createElementVNode("view", {
- class: "btn",
- onClick: loginout
- }, " 退出登录 ")
- ],
- 64
- /* STABLE_FRAGMENT */
- );
- };
- }
- };
- const PagesUsereditUseredit = /* @__PURE__ */ _export_sfc(_sfc_main$j, [["__scopeId", "data-v-503dd57f"], ["__file", "D:/projects/cxc-szcx-uniapp/pages/useredit/useredit.vue"]]);
- const _sfc_main$i = {
- __name: "address",
- setup(__props) {
- const store = useStore();
- const jump = (url) => {
- beforeJump(url, () => {
- uni.navigateTo({
- url
- });
- });
- };
- return (_ctx, _cache) => {
- return vue.openBlock(), vue.createElementBlock(
- "view",
- {
- class: vue.normalizeClass(["content", { "gray": vue.unref(store).isgray == 1 }])
- },
- [
- vue.createElementVNode("view", { class: "list" }, [
- (vue.openBlock(), vue.createElementBlock(
- vue.Fragment,
- null,
- vue.renderList(2, (item, i2) => {
- return vue.createElementVNode("view", {
- class: "item",
- key: i2
- }, [
- vue.createElementVNode("view", { class: "province f-row aic" }, [
- vue.createElementVNode("view", { class: "" }, " 浙江省,杭州市 "),
- vue.createElementVNode("image", {
- src: "/static/my/default.png",
- mode: ""
- })
- ]),
- vue.createElementVNode("view", { class: "address f-row jcb" }, [
- vue.createElementVNode("view", { class: "" }, " 重庆 重庆市 渝北区 龙溪街道花卉园东路黄金 宝高级住宅小区 "),
- vue.createElementVNode("image", {
- src: "/static/my/edit.png",
- mode: ""
- })
- ]),
- vue.createElementVNode("view", { class: "set f-row aic jcb" }, [
- vue.createElementVNode("view", { class: "f-row aic" }, [
- vue.createCommentVNode(' '),
- vue.createElementVNode("image", {
- src: "/static/login/nocheck.png",
- mode: ""
- }),
- vue.createTextVNode(" 设为默认地址 ")
- ]),
- vue.createElementVNode("view", { class: "" }, " 删除 ")
- ])
- ]);
- }),
- 64
- /* STABLE_FRAGMENT */
- ))
- ]),
- vue.createElementVNode("view", { class: "btn f-col aic" }, [
- vue.createElementVNode("view", {
- class: "",
- onClick: _cache[0] || (_cache[0] = ($event) => jump("/pages/useredit/add_address"))
- }, " +添加收货地址 ")
- ])
- ],
- 2
- /* CLASS */
- );
- };
- }
- };
- const PagesUsereditAddress = /* @__PURE__ */ _export_sfc(_sfc_main$i, [["__scopeId", "data-v-4bd9b73b"], ["__file", "D:/projects/cxc-szcx-uniapp/pages/useredit/address.vue"]]);
- const _sfc_main$h = {
- __name: "add_address",
- setup(__props) {
- const store = useStore();
- return (_ctx, _cache) => {
- return vue.openBlock(), vue.createElementBlock(
- "view",
- {
- class: vue.normalizeClass(["content", { "gray": vue.unref(store).isgray == 1 }])
- },
- [
- vue.createElementVNode("view", { class: "area f-row jcb" }, [
- vue.createElementVNode("view", { class: "title topic" }, " 所在地区 "),
- vue.createElementVNode("input", {
- type: "text",
- placeholder: "省、市、区、街道"
- })
- ]),
- vue.createElementVNode("view", { class: "area f-row jcb" }, [
- vue.createElementVNode("view", { class: "title topic" }, " 详细地址 "),
- vue.createElementVNode("textarea", { placeholder: "小区楼栋/乡村名称" })
- ]),
- vue.createElementVNode("view", { class: "area f-row jcb" }, [
- vue.createElementVNode("view", { class: "title" }, " 设为默认地址 "),
- vue.createElementVNode("image", {
- src: "/static/login/checked.png",
- mode: ""
- }),
- vue.createCommentVNode(' ')
- ]),
- vue.createElementVNode("view", { class: "btn f-col aic" }, [
- vue.createElementVNode("view", { class: "" }, " 保存 ")
- ])
- ],
- 2
- /* CLASS */
- );
- };
- }
- };
- const PagesUsereditAdd_address = /* @__PURE__ */ _export_sfc(_sfc_main$h, [["__scopeId", "data-v-f1271877"], ["__file", "D:/projects/cxc-szcx-uniapp/pages/useredit/add_address.vue"]]);
- const _sfc_main$g = {
- __name: "addressbook",
- setup(__props) {
- const store = useStore();
- return (_ctx, _cache) => {
- return vue.openBlock(), vue.createElementBlock(
- "view",
- {
- class: vue.normalizeClass({ "gray": vue.unref(store).isgray == 1 })
- },
- [
- vue.createElementVNode("view", { class: "list" }, [
- (vue.openBlock(), vue.createElementBlock(
- vue.Fragment,
- null,
- vue.renderList(4, (item, i2) => {
- return vue.createElementVNode("view", {
- class: "item f-row aic jcb",
- key: i2
- }, [
- vue.createElementVNode("view", { class: "user f-row aic" }, [
- vue.createElementVNode("image", {
- src: "",
- mode: ""
- }),
- vue.createElementVNode("view", { class: "name_job" }, [
- vue.createElementVNode("view", { class: "name" }, " 我是晴天 "),
- vue.createElementVNode("view", { class: "job" }, " 销售部-销售总监 ")
- ])
- ]),
- vue.createElementVNode("view", { class: "btn" }, " 电话联系 ")
- ]);
- }),
- 64
- /* STABLE_FRAGMENT */
- ))
- ])
- ],
- 2
- /* CLASS */
- );
- };
- }
- };
- const PagesUsereditAddressbook = /* @__PURE__ */ _export_sfc(_sfc_main$g, [["__scopeId", "data-v-c0e791d9"], ["__file", "D:/projects/cxc-szcx-uniapp/pages/useredit/addressbook.vue"]]);
- const _sfc_main$f = {
- __name: "extendCom",
- props: {
- title: {
- type: String,
- default: ""
- },
- img: {
- type: String,
- default: ""
- },
- list: {
- type: Array,
- default: function() {
- return [];
- }
- },
- // selfArrquery: {
- // type: Array,
- // default: function() {
- // return []
- // }
- // },
- total: {
- type: Number,
- default: 0
- }
- },
- setup(__props) {
- vue.useCssVars((_ctx) => ({
- "e40cd242-moreHeight": moreHeight.value
- }));
- const props = __props;
- const open2 = vue.ref(false);
- const moreHeight = vue.ref(null);
- const CurrentInstance = vue.getCurrentInstance();
- vue.watch(() => props.list, () => {
- vue.nextTick(() => {
- uni.createSelectorQuery().in(CurrentInstance.proxy).select(".item_box").boundingClientRect((data) => {
- moreHeight.value = (data == null ? void 0 : data.height) + "px";
- formatAppLog("log", "at bpm/extendCom.vue:82", "moreHeight", moreHeight.value);
- }).exec();
- });
- }, {
- immediate: true
- });
- const tolist = (title) => {
- let id = null;
- beforeJump("/pages/task/index", () => {
- if (props.title == "待办事项") {
- id = 0;
- }
- if (props.title == "已办事项") {
- id = 2;
- }
- if (props.title == "本人发起") {
- return uni.navigateTo({
- url: `/pages/task/self?title=${title}`
- });
- }
- uni.navigateTo({
- url: `/pages/task/index?id=${id}&title=${title}`
- });
- });
- };
- return (_ctx, _cache) => {
- return vue.openBlock(), vue.createElementBlock("view", { class: "content" }, [
- vue.createElementVNode("view", { class: "todo f-col aic" }, [
- vue.createElementVNode("view", { class: "f-col aic" }, [
- vue.createElementVNode("view", {
- class: "title_box f-row aic jcb",
- onClick: _cache[0] || (_cache[0] = ($event) => tolist(""))
- }, [
- vue.createElementVNode("view", { class: "title f-row aic" }, [
- vue.createElementVNode("image", {
- src: `/static/my/${__props.img}.png`,
- mode: ""
- }, null, 8, ["src"]),
- vue.createTextVNode(
- " " + vue.toDisplayString(__props.title),
- 1
- /* TEXT */
- )
- ]),
- vue.createElementVNode(
- "view",
- { class: "num" },
- vue.toDisplayString(__props.total),
- 1
- /* TEXT */
- )
- ]),
- __props.list.length ? (vue.openBlock(), vue.createElementBlock("view", {
- key: 0,
- class: "list"
- }, [
- vue.createElementVNode(
- "view",
- {
- class: vue.normalizeClass(["box", { "close": __props.list.length > 5 && open2.value }])
- },
- [
- vue.createElementVNode("view", { class: "item_box" }, [
- (vue.openBlock(true), vue.createElementBlock(
- vue.Fragment,
- null,
- vue.renderList(__props.list, (item, i2) => {
- return vue.openBlock(), vue.createElementBlock("view", {
- onClick: ($event) => tolist(item.title),
- class: "item f-row aic",
- key: i2
- }, [
- vue.createElementVNode(
- "view",
- { class: "" },
- vue.toDisplayString(item.title),
- 1
- /* TEXT */
- ),
- vue.createElementVNode(
- "text",
- null,
- vue.toDisplayString(item.num),
- 1
- /* TEXT */
- )
- ], 8, ["onClick"]);
- }),
- 128
- /* KEYED_FRAGMENT */
- ))
- ])
- ],
- 2
- /* CLASS */
- ),
- vue.withDirectives(vue.createElementVNode(
- "view",
- {
- class: "more",
- onClick: _cache[1] || (_cache[1] = ($event) => open2.value = !open2.value)
- },
- vue.toDisplayString(!open2.value ? "显示更多" : "收起"),
- 513
- /* TEXT, NEED_PATCH */
- ), [
- [vue.vShow, __props.list.length > 5]
- ])
- ])) : vue.createCommentVNode("v-if", true)
- ])
- ])
- ]);
- };
- }
- };
- const extendCom = /* @__PURE__ */ _export_sfc(_sfc_main$f, [["__scopeId", "data-v-e40cd242"], ["__file", "D:/projects/cxc-szcx-uniapp/bpm/extendCom.vue"]]);
- const _sfc_main$e = {
- __name: "todotask",
- setup(__props) {
- const store = useStore();
- onLoad(() => {
- taskList();
- taskHistoryList();
- myApplyProcessList();
- });
- const todoArr = vue.ref([]);
- const todoTotal = vue.ref(0);
- const taskList = () => {
- taskListApi({
- pageNo: 1,
- pageSize: 4,
- _t: (/* @__PURE__ */ new Date()).getTime()
- }).then((res) => {
- var _a, _b, _c, _d;
- if (res == null ? void 0 : res.success) {
- if (((_a = res == null ? void 0 : res.result) == null ? void 0 : _a.total) > 4) {
- taskListApi({
- pageNo: 1,
- pageSize: (_b = res == null ? void 0 : res.result) == null ? void 0 : _b.total,
- _t: (/* @__PURE__ */ new Date()).getTime()
- }).then((res1) => {
- var _a2, _b2;
- if (res1 == null ? void 0 : res1.success) {
- todoArr.value = [...todoArr.value, ...handleData((_a2 = res1 == null ? void 0 : res1.result) == null ? void 0 : _a2.records)];
- todoTotal.value = (_b2 = res1 == null ? void 0 : res1.result) == null ? void 0 : _b2.total;
- }
- }).catch((err) => {
- formatAppLog("log", "at pages/task/todotask.vue:53", "err", err);
- });
- } else {
- todoArr.value = [...todoArr.value, ...handleData((_c = res == null ? void 0 : res.result) == null ? void 0 : _c.records)];
- todoTotal.value = (_d = res == null ? void 0 : res.result) == null ? void 0 : _d.total;
- }
- }
- }).catch((err) => {
- formatAppLog("log", "at pages/task/todotask.vue:62", err);
- });
- };
- const doneArr = vue.ref([]);
- const doneTotal = vue.ref(0);
- const taskHistoryList = () => {
- taskHistoryListApi({
- pageNo: 1,
- pageSize: 4,
- _t: (/* @__PURE__ */ new Date()).getTime()
- }).then((res) => {
- if (res.success) {
- if (res.result.total > 4) {
- taskHistoryListApi({
- pageNo: 1,
- pageSize: res.result.total,
- _t: (/* @__PURE__ */ new Date()).getTime()
- }).then((res1) => {
- if (res1.success) {
- doneArr.value = [...doneArr.value, ...handleData(res1.result.records)];
- doneTotal.value = res1.result.total;
- }
- }).catch((err) => {
- formatAppLog("log", "at pages/task/todotask.vue:87", err);
- });
- } else {
- doneArr.value = [...doneArr.value, ...handleData(res.result.records)];
- doneTotal.value = res.result.total;
- }
- }
- }).catch((err) => {
- formatAppLog("log", "at pages/task/todotask.vue:96", err);
- });
- };
- const selfArr = vue.ref([]);
- const selfTotal = vue.ref(0);
- vue.ref([]);
- const myApplyProcessList = () => {
- myApplyProcessListApi({
- pageNo: 1,
- pageSize: 4,
- _t: (/* @__PURE__ */ new Date()).getTime()
- }).then((res) => {
- if (res.success) {
- if (res.result.total > 4) {
- myApplyProcessListApi({
- pageNo: 1,
- pageSize: res.result.total,
- _t: (/* @__PURE__ */ new Date()).getTime()
- }).then((res1) => {
- if (res1.success) {
- selfArr.value = [...selfArr.value, ...handleData(res1.result.records)];
- selfTotal.value = res1.result.total;
- }
- }).catch((err) => {
- formatAppLog("log", "at pages/task/todotask.vue:122", err);
- });
- } else {
- selfArr.value = [...selfArr.value, ...handleData(res.result.records)];
- selfTotal.value = res.result.total;
- }
- }
- }).catch((err) => {
- formatAppLog("log", "at pages/task/todotask.vue:132", err);
- });
- };
- const handleData = (titlearr) => {
- let titleArr = titlearr.length ? titlearr.map((item) => item.processDefinitionName || item.prcocessDefinitionName) : [];
- let res = titleArr.reduce((obj, title) => {
- if (title in obj) {
- obj[title]++;
- } else {
- obj[title] = 1;
- }
- return obj;
- }, {});
- return Object.entries(res).map(([k, v2]) => ({
- title: k,
- num: v2
- }));
- };
- return (_ctx, _cache) => {
- return vue.openBlock(), vue.createElementBlock(
- "view",
- {
- class: vue.normalizeClass(["content", { "gray": vue.unref(store).isgray == 1 }])
- },
- [
- vue.createVNode(extendCom, {
- title: "待办事项",
- img: "todo",
- list: todoArr.value,
- total: todoTotal.value
- }, null, 8, ["list", "total"]),
- vue.createVNode(extendCom, {
- title: "已办事项",
- img: "done",
- list: doneArr.value,
- total: doneTotal.value
- }, null, 8, ["list", "total"]),
- vue.createVNode(extendCom, {
- title: "本人发起",
- img: "self",
- list: selfArr.value,
- total: selfTotal.value
- }, null, 8, ["list", "total"])
- ],
- 2
- /* CLASS */
- );
- };
- }
- };
- const PagesTaskTodotask = /* @__PURE__ */ _export_sfc(_sfc_main$e, [["__file", "D:/projects/cxc-szcx-uniapp/pages/task/todotask.vue"]]);
- const _sfc_main$d = {
- __name: "safeCom",
- setup(__props) {
- const jump = (url) => {
- beforeJump(url, () => {
- uni.navigateTo({
- url
- });
- });
- };
- return (_ctx, _cache) => {
- return vue.openBlock(), vue.createElementBlock("view", { class: "list f-row aic jcb" }, [
- (vue.openBlock(), vue.createElementBlock(
- vue.Fragment,
- null,
- vue.renderList(20, (item, i2) => {
- return vue.createElementVNode("view", {
- class: "item",
- key: i2,
- onClick: _cache[0] || (_cache[0] = ($event) => jump("/pages/safe/detail"))
- }, [
- vue.createElementVNode("view", { class: "" }, [
- vue.createElementVNode("image", {
- src: "",
- mode: ""
- })
- ]),
- vue.createElementVNode("view", { class: "text" }, " 五月天“突然好想你”线上演唱会精彩回放 ")
- ]);
- }),
- 64
- /* STABLE_FRAGMENT */
- ))
- ]);
- };
- }
- };
- const safeCom = /* @__PURE__ */ _export_sfc(_sfc_main$d, [["__scopeId", "data-v-982fcf41"], ["__file", "D:/projects/cxc-szcx-uniapp/bpm/safeCom.vue"]]);
- const _sfc_main$c = {
- __name: "manage",
- setup(__props) {
- const store = useStore();
- const showicon = vue.ref(true);
- const searchKey = vue.ref("");
- return (_ctx, _cache) => {
- const _component_uni_icons = resolveEasycom(vue.resolveDynamicComponent("uni-icons"), __easycom_1$1);
- return vue.openBlock(), vue.createElementBlock(
- "view",
- {
- class: vue.normalizeClass(["content", { "gray": vue.unref(store).isgray == 1 }])
- },
- [
- vue.createVNode(customNav, null, {
- default: vue.withCtx(() => [
- vue.createElementVNode("view", { class: "nav_box f-row aic jcb" }, [
- vue.createElementVNode("view", {
- class: "back f-row aic",
- onClick: _cache[0] || (_cache[0] = (...args) => _ctx.back && _ctx.back(...args))
- }, [
- vue.createVNode(_component_uni_icons, {
- type: "left",
- size: "20",
- color: "#fff"
- })
- ]),
- vue.createElementVNode("view", { class: "search f-row aic" }, [
- vue.withDirectives(vue.createElementVNode(
- "input",
- {
- type: "text",
- "onUpdate:modelValue": _cache[1] || (_cache[1] = ($event) => searchKey.value = $event),
- onConfirm: _cache[2] || (_cache[2] = (...args) => _ctx.search && _ctx.search(...args)),
- onBlur: _cache[3] || (_cache[3] = ($event) => showicon.value = !searchKey.value),
- onFocus: _cache[4] || (_cache[4] = ($event) => showicon.value = false)
- },
- null,
- 544
- /* NEED_HYDRATION, NEED_PATCH */
- ), [
- [vue.vModelText, searchKey.value]
- ]),
- showicon.value ? (vue.openBlock(), vue.createElementBlock("view", {
- key: 0,
- class: "f-row aic"
- }, [
- vue.createElementVNode("image", {
- src: "/static/search.png",
- mode: ""
- }),
- vue.createElementVNode("text", null, "搜索")
- ])) : vue.createCommentVNode("v-if", true)
- ])
- ])
- ]),
- _: 1
- /* STABLE */
- }),
- vue.createElementVNode("view", { class: "" }, [
- vue.createVNode(safeCom)
- ])
- ],
- 2
- /* CLASS */
- );
- };
- }
- };
- const PagesSafeManage = /* @__PURE__ */ _export_sfc(_sfc_main$c, [["__scopeId", "data-v-dc2f4615"], ["__file", "D:/projects/cxc-szcx-uniapp/pages/safe/manage.vue"]]);
- const _sfc_main$b = {
- __name: "index",
- setup(__props) {
- const store = useStore();
- const shishiArr = vue.ref([]);
- const productArr = vue.ref([]);
- onLoad((options) => {
- shishiArr.value = JSON.parse(options.shishi);
- productArr.value = JSON.parse(options.product);
- });
- return (_ctx, _cache) => {
- return vue.openBlock(), vue.createElementBlock(
- "view",
- {
- class: vue.normalizeClass(["f-col", "aic", { "gray": vue.unref(store).isgray == 1 }])
- },
- [
- vue.createVNode(dataCom, {
- title: "实时输差",
- list: shishiArr.value
- }, null, 8, ["list"]),
- vue.createVNode(dataCom, {
- title: "偏远计量点",
- list: shishiArr.value
- }, null, 8, ["list"]),
- vue.createVNode(dataCom, {
- title: "生产实时数据",
- list: productArr.value
- }, null, 8, ["list"])
- ],
- 2
- /* CLASS */
- );
- };
- }
- };
- const PagesProductIndex = /* @__PURE__ */ _export_sfc(_sfc_main$b, [["__file", "D:/projects/cxc-szcx-uniapp/pages/product/index.vue"]]);
- const en = {
- "uni-load-more.contentdown": "Pull up to show more",
- "uni-load-more.contentrefresh": "loading...",
- "uni-load-more.contentnomore": "No more data"
- };
- const zhHans = {
- "uni-load-more.contentdown": "上拉显示更多",
- "uni-load-more.contentrefresh": "正在加载...",
- "uni-load-more.contentnomore": "没有更多数据了"
- };
- const zhHant = {
- "uni-load-more.contentdown": "上拉顯示更多",
- "uni-load-more.contentrefresh": "正在加載...",
- "uni-load-more.contentnomore": "沒有更多數據了"
- };
- const messages = {
- en,
- "zh-Hans": zhHans,
- "zh-Hant": zhHant
- };
- let platform;
- setTimeout(() => {
- platform = uni.getSystemInfoSync().platform;
- }, 16);
- const {
- t: t$1
- } = initVueI18n(messages);
- const _sfc_main$a = {
- name: "UniLoadMore",
- emits: ["clickLoadMore"],
- props: {
- status: {
- // 上拉的状态:more-loading前;loading-loading中;noMore-没有更多了
- type: String,
- default: "more"
- },
- showIcon: {
- type: Boolean,
- default: true
- },
- iconType: {
- type: String,
- default: "auto"
- },
- iconSize: {
- type: Number,
- default: 24
- },
- color: {
- type: String,
- default: "#777777"
- },
- contentText: {
- type: Object,
- default() {
- return {
- contentdown: "",
- contentrefresh: "",
- contentnomore: ""
- };
- }
- },
- showText: {
- type: Boolean,
- default: true
- }
- },
- data() {
- return {
- webviewHide: false,
- platform,
- imgBase64: ""
- };
- },
- computed: {
- iconSnowWidth() {
- return (Math.floor(this.iconSize / 24) || 1) * 2;
- },
- contentdownText() {
- return this.contentText.contentdown || t$1("uni-load-more.contentdown");
- },
- contentrefreshText() {
- return this.contentText.contentrefresh || t$1("uni-load-more.contentrefresh");
- },
- contentnomoreText() {
- return this.contentText.contentnomore || t$1("uni-load-more.contentnomore");
- }
- },
- mounted() {
- var pages2 = getCurrentPages();
- var page = pages2[pages2.length - 1];
- var currentWebview = page.$getAppWebview();
- currentWebview.addEventListener("hide", () => {
- this.webviewHide = true;
- });
- currentWebview.addEventListener("show", () => {
- this.webviewHide = false;
- });
- },
- methods: {
- onClick() {
- this.$emit("clickLoadMore", {
- detail: {
- status: this.status
- }
- });
- }
- }
- };
- function _sfc_render$2(_ctx, _cache, $props, $setup, $data, $options) {
- return vue.openBlock(), vue.createElementBlock("view", {
- class: "uni-load-more",
- onClick: _cache[0] || (_cache[0] = (...args) => $options.onClick && $options.onClick(...args))
- }, [
- !$data.webviewHide && ($props.iconType === "circle" || $props.iconType === "auto" && $data.platform === "android") && $props.status === "loading" && $props.showIcon ? (vue.openBlock(), vue.createElementBlock(
- "view",
- {
- key: 0,
- style: vue.normalizeStyle({ width: $props.iconSize + "px", height: $props.iconSize + "px" }),
- class: "uni-load-more__img uni-load-more__img--android-MP"
- },
- [
- vue.createElementVNode(
- "view",
- {
- class: "uni-load-more__img-icon",
- style: vue.normalizeStyle({ borderTopColor: $props.color, borderTopWidth: $props.iconSize / 12 })
- },
- null,
- 4
- /* STYLE */
- ),
- vue.createElementVNode(
- "view",
- {
- class: "uni-load-more__img-icon",
- style: vue.normalizeStyle({ borderTopColor: $props.color, borderTopWidth: $props.iconSize / 12 })
- },
- null,
- 4
- /* STYLE */
- ),
- vue.createElementVNode(
- "view",
- {
- class: "uni-load-more__img-icon",
- style: vue.normalizeStyle({ borderTopColor: $props.color, borderTopWidth: $props.iconSize / 12 })
- },
- null,
- 4
- /* STYLE */
- )
- ],
- 4
- /* STYLE */
- )) : !$data.webviewHide && $props.status === "loading" && $props.showIcon ? (vue.openBlock(), vue.createElementBlock(
- "view",
- {
- key: 1,
- style: vue.normalizeStyle({ width: $props.iconSize + "px", height: $props.iconSize + "px" }),
- class: "uni-load-more__img uni-load-more__img--ios-H5"
- },
- [
- vue.createElementVNode("image", {
- src: $data.imgBase64,
- mode: "widthFix"
- }, null, 8, ["src"])
- ],
- 4
- /* STYLE */
- )) : vue.createCommentVNode("v-if", true),
- $props.showText ? (vue.openBlock(), vue.createElementBlock(
- "text",
- {
- key: 2,
- class: "uni-load-more__text",
- style: vue.normalizeStyle({ color: $props.color })
- },
- vue.toDisplayString($props.status === "more" ? $options.contentdownText : $props.status === "loading" ? $options.contentrefreshText : $options.contentnomoreText),
- 5
- /* TEXT, STYLE */
- )) : vue.createCommentVNode("v-if", true)
- ]);
- }
- const __easycom_0$1 = /* @__PURE__ */ _export_sfc(_sfc_main$a, [["render", _sfc_render$2], ["__scopeId", "data-v-9245e42c"], ["__file", "D:/projects/cxc-szcx-uniapp/uni_modules/uni-load-more/components/uni-load-more/uni-load-more.vue"]]);
+ const PagesMeetingDetail = /* @__PURE__ */ _export_sfc(_sfc_main$s, [["__scopeId", "data-v-ee2c785f"], ["__file", "D:/projects/cxc-szcx-uniapp/pages/meeting/detail.vue"]]);
const pages = [
{
path: "pages/login/login",
@@ -13028,7 +10126,7 @@ This will fail in production.`);
uniIdRouter
};
var define_process_env_UNI_SECURE_NETWORK_CONFIG_default = [];
- function t(e2) {
+ function t$1(e2) {
return e2 && e2.__esModule && Object.prototype.hasOwnProperty.call(e2, "default") ? e2.default : e2;
}
function n(e2, t2, n2) {
@@ -15309,7 +12407,7 @@ ${i3}
}(t3), t3);
};
};
- }), xs = t(Cs);
+ }), xs = t$1(Cs);
const Os = "manual";
function Es(e2) {
return { props: { localdata: { type: Array, default: () => [] }, options: { type: [Object, Array], default: () => ({}) }, spaceInfo: { type: Object, default: () => ({}) }, collection: { type: [String, Array], default: "" }, action: { type: String, default: "" }, field: { type: String, default: "" }, orderby: { type: String, default: "" }, where: { type: [String, Object], default: "" }, pageData: { type: String, default: "add" }, pageCurrent: { type: Number, default: 1 }, pageSize: { type: Number, default: 20 }, getcount: { type: [Boolean, String], default: false }, gettree: { type: [Boolean, String], default: false }, gettreepath: { type: [Boolean, String], default: false }, startwith: { type: String, default: "" }, limitlevel: { type: Number, default: 10 }, groupby: { type: String, default: "" }, groupField: { type: String, default: "" }, distinct: { type: [Boolean, String], default: false }, foreignKey: { type: String, default: "" }, loadtime: { type: String, default: "auto" }, manual: { type: Boolean, default: false } }, data: () => ({ mixinDatacomLoading: false, mixinDatacomHasMore: false, mixinDatacomResData: [], mixinDatacomErrorMessage: "", mixinDatacomPage: {}, mixinDatacomError: null }), created() {
@@ -15716,6 +12814,4263 @@ ${i3}
} }), bs(Bs), Bs.addInterceptor = N, Bs.removeInterceptor = D, Bs.interceptObject = F;
})();
var Ws = Bs;
+ const ERR_MSG_OK = "chooseAndUploadFile:ok";
+ const ERR_MSG_FAIL = "chooseAndUploadFile:fail";
+ function chooseImage(opts) {
+ const {
+ count,
+ sizeType = ["original", "compressed"],
+ sourceType,
+ extension
+ } = opts;
+ return new Promise((resolve, reject) => {
+ uni.chooseImage({
+ count,
+ sizeType,
+ sourceType,
+ extension,
+ success(res) {
+ resolve(normalizeChooseAndUploadFileRes(res, "image"));
+ },
+ fail(res) {
+ reject({
+ errMsg: res.errMsg.replace("chooseImage:fail", ERR_MSG_FAIL)
+ });
+ }
+ });
+ });
+ }
+ function chooseVideo(opts) {
+ const {
+ count,
+ camera,
+ compressed,
+ maxDuration,
+ sourceType,
+ extension
+ } = opts;
+ return new Promise((resolve, reject) => {
+ uni.chooseVideo({
+ camera,
+ compressed,
+ maxDuration,
+ sourceType,
+ extension,
+ success(res) {
+ const {
+ tempFilePath,
+ duration,
+ size,
+ height,
+ width
+ } = res;
+ resolve(normalizeChooseAndUploadFileRes({
+ errMsg: "chooseVideo:ok",
+ tempFilePaths: [tempFilePath],
+ tempFiles: [{
+ name: res.tempFile && res.tempFile.name || "",
+ path: tempFilePath,
+ size,
+ type: res.tempFile && res.tempFile.type || "",
+ width,
+ height,
+ duration,
+ fileType: "video",
+ cloudPath: ""
+ }]
+ }, "video"));
+ },
+ fail(res) {
+ reject({
+ errMsg: res.errMsg.replace("chooseVideo:fail", ERR_MSG_FAIL)
+ });
+ }
+ });
+ });
+ }
+ function chooseAll(opts) {
+ const {
+ count,
+ extension
+ } = opts;
+ return new Promise((resolve, reject) => {
+ let chooseFile = uni.chooseFile;
+ if (typeof wx !== "undefined" && typeof wx.chooseMessageFile === "function") {
+ chooseFile = wx.chooseMessageFile;
+ }
+ if (typeof chooseFile !== "function") {
+ return reject({
+ errMsg: ERR_MSG_FAIL + " 请指定 type 类型,该平台仅支持选择 image 或 video。"
+ });
+ }
+ chooseFile({
+ type: "all",
+ count,
+ extension,
+ success(res) {
+ resolve(normalizeChooseAndUploadFileRes(res));
+ },
+ fail(res) {
+ reject({
+ errMsg: res.errMsg.replace("chooseFile:fail", ERR_MSG_FAIL)
+ });
+ }
+ });
+ });
+ }
+ function normalizeChooseAndUploadFileRes(res, fileType) {
+ res.tempFiles.forEach((item, index) => {
+ if (!item.name) {
+ item.name = item.path.substring(item.path.lastIndexOf("/") + 1);
+ }
+ if (fileType) {
+ item.fileType = fileType;
+ }
+ item.cloudPath = Date.now() + "_" + index + item.name.substring(item.name.lastIndexOf("."));
+ });
+ if (!res.tempFilePaths) {
+ res.tempFilePaths = res.tempFiles.map((file) => file.path);
+ }
+ return res;
+ }
+ function uploadCloudFiles(files, max = 5, onUploadProgress) {
+ files = JSON.parse(JSON.stringify(files));
+ const len = files.length;
+ let count = 0;
+ let self2 = this;
+ return new Promise((resolve) => {
+ while (count < max) {
+ next();
+ }
+ function next() {
+ let cur = count++;
+ if (cur >= len) {
+ !files.find((item) => !item.url && !item.errMsg) && resolve(files);
+ return;
+ }
+ const fileItem = files[cur];
+ const index = self2.files.findIndex((v2) => v2.uuid === fileItem.uuid);
+ fileItem.url = "";
+ delete fileItem.errMsg;
+ Ws.uploadFile({
+ filePath: fileItem.path,
+ cloudPath: fileItem.cloudPath,
+ fileType: fileItem.fileType,
+ onUploadProgress: (res) => {
+ res.index = index;
+ onUploadProgress && onUploadProgress(res);
+ }
+ }).then((res) => {
+ fileItem.url = res.fileID;
+ fileItem.index = index;
+ if (cur < len) {
+ next();
+ }
+ }).catch((res) => {
+ fileItem.errMsg = res.errMsg || res.message;
+ fileItem.index = index;
+ if (cur < len) {
+ next();
+ }
+ });
+ }
+ });
+ }
+ function uploadFiles(choosePromise, {
+ onChooseFile,
+ onUploadProgress
+ }) {
+ return choosePromise.then((res) => {
+ if (onChooseFile) {
+ const customChooseRes = onChooseFile(res);
+ if (typeof customChooseRes !== "undefined") {
+ return Promise.resolve(customChooseRes).then((chooseRes) => typeof chooseRes === "undefined" ? res : chooseRes);
+ }
+ }
+ return res;
+ }).then((res) => {
+ if (res === false) {
+ return {
+ errMsg: ERR_MSG_OK,
+ tempFilePaths: [],
+ tempFiles: []
+ };
+ }
+ return res;
+ });
+ }
+ function chooseAndUploadFile(opts = {
+ type: "all"
+ }) {
+ if (opts.type === "image") {
+ return uploadFiles(chooseImage(opts), opts);
+ } else if (opts.type === "video") {
+ return uploadFiles(chooseVideo(opts), opts);
+ }
+ return uploadFiles(chooseAll(opts), opts);
+ }
+ const get_file_ext = (name2) => {
+ const last_len = name2.lastIndexOf(".");
+ const len = name2.length;
+ return {
+ name: name2.substring(0, last_len),
+ ext: name2.substring(last_len + 1, len)
+ };
+ };
+ const get_extname = (fileExtname) => {
+ if (!Array.isArray(fileExtname)) {
+ let extname = fileExtname.replace(/(\[|\])/g, "");
+ return extname.split(",");
+ } else {
+ return fileExtname;
+ }
+ };
+ const get_files_and_is_max = (res, _extname) => {
+ let filePaths = [];
+ let files = [];
+ if (!_extname || _extname.length === 0) {
+ return {
+ filePaths,
+ files
+ };
+ }
+ res.tempFiles.forEach((v2) => {
+ let fileFullName = get_file_ext(v2.name);
+ const extname = fileFullName.ext.toLowerCase();
+ if (_extname.indexOf(extname) !== -1) {
+ files.push(v2);
+ filePaths.push(v2.path);
+ }
+ });
+ if (files.length !== res.tempFiles.length) {
+ uni.showToast({
+ title: `当前选择了${res.tempFiles.length}个文件 ,${res.tempFiles.length - files.length} 个文件格式不正确`,
+ icon: "none",
+ duration: 5e3
+ });
+ }
+ return {
+ filePaths,
+ files
+ };
+ };
+ const get_file_info = (filepath) => {
+ return new Promise((resolve, reject) => {
+ uni.getImageInfo({
+ src: filepath,
+ success(res) {
+ resolve(res);
+ },
+ fail(err) {
+ reject(err);
+ }
+ });
+ });
+ };
+ const get_file_data = async (files, type = "image") => {
+ let fileFullName = get_file_ext(files.name);
+ const extname = fileFullName.ext.toLowerCase();
+ let filedata = {
+ name: files.name,
+ uuid: files.uuid,
+ extname: extname || "",
+ cloudPath: files.cloudPath,
+ fileType: files.fileType,
+ thumbTempFilePath: files.thumbTempFilePath,
+ url: files.path || files.path,
+ size: files.size,
+ //单位是字节
+ image: {},
+ path: files.path,
+ video: {}
+ };
+ if (type === "image") {
+ const imageinfo = await get_file_info(files.path);
+ delete filedata.video;
+ filedata.image.width = imageinfo.width;
+ filedata.image.height = imageinfo.height;
+ filedata.image.location = imageinfo.path;
+ } else {
+ delete filedata.image;
+ }
+ return filedata;
+ };
+ const _sfc_main$r = {
+ name: "uploadImage",
+ emits: ["uploadFiles", "choose", "delFile"],
+ props: {
+ filesList: {
+ type: Array,
+ default() {
+ return [];
+ }
+ },
+ disabled: {
+ type: Boolean,
+ default: false
+ },
+ disablePreview: {
+ type: Boolean,
+ default: false
+ },
+ limit: {
+ type: [Number, String],
+ default: 9
+ },
+ imageStyles: {
+ type: Object,
+ default() {
+ return {
+ width: "auto",
+ height: "auto",
+ border: {}
+ };
+ }
+ },
+ delIcon: {
+ type: Boolean,
+ default: true
+ },
+ readonly: {
+ type: Boolean,
+ default: false
+ }
+ },
+ computed: {
+ styles() {
+ let styles = {
+ width: "auto",
+ height: "auto",
+ border: {}
+ };
+ return Object.assign(styles, this.imageStyles);
+ },
+ boxStyle() {
+ const {
+ width = "auto",
+ height = "auto"
+ } = this.styles;
+ let obj = {};
+ if (height === "auto") {
+ if (width !== "auto") {
+ obj.height = this.value2px(width);
+ obj["padding-top"] = 0;
+ } else {
+ obj.height = 0;
+ }
+ } else {
+ obj.height = this.value2px(height);
+ obj["padding-top"] = 0;
+ }
+ if (width === "auto") {
+ if (height !== "auto") {
+ obj.width = this.value2px(height);
+ } else {
+ obj.width = "33.3%";
+ }
+ } else {
+ obj.width = this.value2px(width);
+ }
+ let classles = "";
+ for (let i2 in obj) {
+ classles += `${i2}:${obj[i2]};`;
+ }
+ return classles;
+ },
+ borderStyle() {
+ let {
+ border
+ } = this.styles;
+ let obj = {};
+ const widthDefaultValue = 1;
+ const radiusDefaultValue = 3;
+ if (typeof border === "boolean") {
+ obj.border = border ? "1px #eee solid" : "none";
+ } else {
+ let width = border && border.width || widthDefaultValue;
+ width = this.value2px(width);
+ let radius = border && border.radius || radiusDefaultValue;
+ radius = this.value2px(radius);
+ obj = {
+ "border-width": width,
+ "border-style": border && border.style || "solid",
+ "border-color": border && border.color || "#eee",
+ "border-radius": radius
+ };
+ }
+ let classles = "";
+ for (let i2 in obj) {
+ classles += `${i2}:${obj[i2]};`;
+ }
+ return classles;
+ }
+ },
+ methods: {
+ uploadFiles(item, index) {
+ this.$emit("uploadFiles", item);
+ },
+ choose() {
+ this.$emit("choose");
+ },
+ delFile(index) {
+ this.$emit("delFile", index);
+ },
+ prviewImage(img, index) {
+ let urls = [];
+ if (Number(this.limit) === 1 && this.disablePreview && !this.disabled) {
+ this.$emit("choose");
+ }
+ if (this.disablePreview)
+ return;
+ this.filesList.forEach((i2) => {
+ urls.push(i2.url);
+ });
+ uni.previewImage({
+ urls,
+ current: index
+ });
+ },
+ value2px(value) {
+ if (typeof value === "number") {
+ value += "px";
+ } else {
+ if (value.indexOf("%") === -1) {
+ value = value.indexOf("px") !== -1 ? value : value + "px";
+ }
+ }
+ return value;
+ }
+ }
+ };
+ function _sfc_render$6(_ctx, _cache, $props, $setup, $data, $options) {
+ return vue.openBlock(), vue.createElementBlock("view", { class: "uni-file-picker__container" }, [
+ (vue.openBlock(true), vue.createElementBlock(
+ vue.Fragment,
+ null,
+ vue.renderList($props.filesList, (item, index) => {
+ return vue.openBlock(), vue.createElementBlock(
+ "view",
+ {
+ class: "file-picker__box",
+ key: index,
+ style: vue.normalizeStyle($options.boxStyle)
+ },
+ [
+ vue.createElementVNode(
+ "view",
+ {
+ class: "file-picker__box-content",
+ style: vue.normalizeStyle($options.borderStyle)
+ },
+ [
+ vue.createElementVNode("image", {
+ class: "file-image",
+ src: item.url,
+ mode: "aspectFill",
+ onClick: vue.withModifiers(($event) => $options.prviewImage(item, index), ["stop"])
+ }, null, 8, ["src", "onClick"]),
+ $props.delIcon && !$props.readonly ? (vue.openBlock(), vue.createElementBlock("view", {
+ key: 0,
+ class: "icon-del-box",
+ onClick: vue.withModifiers(($event) => $options.delFile(index), ["stop"])
+ }, [
+ vue.createElementVNode("view", { class: "icon-del" }),
+ vue.createElementVNode("view", { class: "icon-del rotate" })
+ ], 8, ["onClick"])) : vue.createCommentVNode("v-if", true),
+ item.progress && item.progress !== 100 || item.progress === 0 ? (vue.openBlock(), vue.createElementBlock("view", {
+ key: 1,
+ class: "file-picker__progress"
+ }, [
+ vue.createElementVNode("progress", {
+ class: "file-picker__progress-item",
+ percent: item.progress === -1 ? 0 : item.progress,
+ "stroke-width": "4",
+ backgroundColor: item.errMsg ? "#ff5a5f" : "#EBEBEB"
+ }, null, 8, ["percent", "backgroundColor"])
+ ])) : vue.createCommentVNode("v-if", true),
+ item.errMsg ? (vue.openBlock(), vue.createElementBlock("view", {
+ key: 2,
+ class: "file-picker__mask",
+ onClick: vue.withModifiers(($event) => $options.uploadFiles(item, index), ["stop"])
+ }, " 点击重试 ", 8, ["onClick"])) : vue.createCommentVNode("v-if", true)
+ ],
+ 4
+ /* STYLE */
+ )
+ ],
+ 4
+ /* STYLE */
+ );
+ }),
+ 128
+ /* KEYED_FRAGMENT */
+ )),
+ $props.filesList.length < $props.limit && !$props.readonly ? (vue.openBlock(), vue.createElementBlock(
+ "view",
+ {
+ key: 0,
+ class: "file-picker__box",
+ style: vue.normalizeStyle($options.boxStyle)
+ },
+ [
+ vue.createElementVNode(
+ "view",
+ {
+ class: "file-picker__box-content is-add",
+ style: vue.normalizeStyle($options.borderStyle),
+ onClick: _cache[0] || (_cache[0] = (...args) => $options.choose && $options.choose(...args))
+ },
+ [
+ vue.renderSlot(_ctx.$slots, "default", {}, () => [
+ vue.createElementVNode("view", { class: "icon-add" }),
+ vue.createElementVNode("view", { class: "icon-add rotate" })
+ ], true)
+ ],
+ 4
+ /* STYLE */
+ )
+ ],
+ 4
+ /* STYLE */
+ )) : vue.createCommentVNode("v-if", true)
+ ]);
+ }
+ const uploadImage = /* @__PURE__ */ _export_sfc(_sfc_main$r, [["render", _sfc_render$6], ["__scopeId", "data-v-bdfc07e0"], ["__file", "D:/projects/cxc-szcx-uniapp/uni_modules/uni-file-picker/components/uni-file-picker/upload-image.vue"]]);
+ const _sfc_main$q = {
+ name: "uploadFile",
+ emits: ["uploadFiles", "choose", "delFile"],
+ props: {
+ filesList: {
+ type: Array,
+ default() {
+ return [];
+ }
+ },
+ delIcon: {
+ type: Boolean,
+ default: true
+ },
+ limit: {
+ type: [Number, String],
+ default: 9
+ },
+ showType: {
+ type: String,
+ default: ""
+ },
+ listStyles: {
+ type: Object,
+ default() {
+ return {
+ // 是否显示边框
+ border: true,
+ // 是否显示分隔线
+ dividline: true,
+ // 线条样式
+ borderStyle: {}
+ };
+ }
+ },
+ readonly: {
+ type: Boolean,
+ default: false
+ }
+ },
+ computed: {
+ list() {
+ let files = [];
+ this.filesList.forEach((v2) => {
+ files.push(v2);
+ });
+ return files;
+ },
+ styles() {
+ let styles = {
+ border: true,
+ dividline: true,
+ "border-style": {}
+ };
+ return Object.assign(styles, this.listStyles);
+ },
+ borderStyle() {
+ let {
+ borderStyle,
+ border
+ } = this.styles;
+ let obj = {};
+ if (!border) {
+ obj.border = "none";
+ } else {
+ let width = borderStyle && borderStyle.width || 1;
+ width = this.value2px(width);
+ let radius = borderStyle && borderStyle.radius || 5;
+ radius = this.value2px(radius);
+ obj = {
+ "border-width": width,
+ "border-style": borderStyle && borderStyle.style || "solid",
+ "border-color": borderStyle && borderStyle.color || "#eee",
+ "border-radius": radius
+ };
+ }
+ let classles = "";
+ for (let i2 in obj) {
+ classles += `${i2}:${obj[i2]};`;
+ }
+ return classles;
+ },
+ borderLineStyle() {
+ let obj = {};
+ let {
+ borderStyle
+ } = this.styles;
+ if (borderStyle && borderStyle.color) {
+ obj["border-color"] = borderStyle.color;
+ }
+ if (borderStyle && borderStyle.width) {
+ let width = borderStyle && borderStyle.width || 1;
+ let style = borderStyle && borderStyle.style || 0;
+ if (typeof width === "number") {
+ width += "px";
+ } else {
+ width = width.indexOf("px") ? width : width + "px";
+ }
+ obj["border-width"] = width;
+ if (typeof style === "number") {
+ style += "px";
+ } else {
+ style = style.indexOf("px") ? style : style + "px";
+ }
+ obj["border-top-style"] = style;
+ }
+ let classles = "";
+ for (let i2 in obj) {
+ classles += `${i2}:${obj[i2]};`;
+ }
+ return classles;
+ }
+ },
+ methods: {
+ uploadFiles(item, index) {
+ this.$emit("uploadFiles", {
+ item,
+ index
+ });
+ },
+ choose() {
+ this.$emit("choose");
+ },
+ delFile(index) {
+ this.$emit("delFile", index);
+ },
+ value2px(value) {
+ if (typeof value === "number") {
+ value += "px";
+ } else {
+ value = value.indexOf("px") !== -1 ? value : value + "px";
+ }
+ return value;
+ }
+ }
+ };
+ function _sfc_render$5(_ctx, _cache, $props, $setup, $data, $options) {
+ return vue.openBlock(), vue.createElementBlock("view", { class: "uni-file-picker__files" }, [
+ !$props.readonly ? (vue.openBlock(), vue.createElementBlock("view", {
+ key: 0,
+ class: "files-button",
+ onClick: _cache[0] || (_cache[0] = (...args) => $options.choose && $options.choose(...args))
+ }, [
+ vue.renderSlot(_ctx.$slots, "default", {}, void 0, true)
+ ])) : vue.createCommentVNode("v-if", true),
+ vue.createCommentVNode(` :class="{'is-text-box':showType === 'list'}" `),
+ $options.list.length > 0 ? (vue.openBlock(), vue.createElementBlock(
+ "view",
+ {
+ key: 1,
+ class: "uni-file-picker__lists is-text-box",
+ style: vue.normalizeStyle($options.borderStyle)
+ },
+ [
+ vue.createCommentVNode(" ,'is-list-card':showType === 'list-card' "),
+ (vue.openBlock(true), vue.createElementBlock(
+ vue.Fragment,
+ null,
+ vue.renderList($options.list, (item, index) => {
+ return vue.openBlock(), vue.createElementBlock(
+ "view",
+ {
+ class: vue.normalizeClass(["uni-file-picker__lists-box", {
+ "files-border": index !== 0 && $options.styles.dividline
+ }]),
+ key: index,
+ style: vue.normalizeStyle(index !== 0 && $options.styles.dividline && $options.borderLineStyle)
+ },
+ [
+ vue.createElementVNode("view", { class: "uni-file-picker__item" }, [
+ vue.createCommentVNode(` :class="{'is-text-image':showType === 'list'}" `),
+ vue.createCommentVNode(' \r\n \r\n '),
+ vue.createElementVNode(
+ "view",
+ { class: "files__name" },
+ vue.toDisplayString(item.name),
+ 1
+ /* TEXT */
+ ),
+ $props.delIcon && !$props.readonly ? (vue.openBlock(), vue.createElementBlock("view", {
+ key: 0,
+ class: "icon-del-box icon-files",
+ onClick: ($event) => $options.delFile(index)
+ }, [
+ vue.createElementVNode("view", { class: "icon-del icon-files" }),
+ vue.createElementVNode("view", { class: "icon-del rotate" })
+ ], 8, ["onClick"])) : vue.createCommentVNode("v-if", true)
+ ]),
+ item.progress && item.progress !== 100 || item.progress === 0 ? (vue.openBlock(), vue.createElementBlock("view", {
+ key: 0,
+ class: "file-picker__progress"
+ }, [
+ vue.createElementVNode("progress", {
+ class: "file-picker__progress-item",
+ percent: item.progress === -1 ? 0 : item.progress,
+ "stroke-width": "4",
+ backgroundColor: item.errMsg ? "#ff5a5f" : "#EBEBEB"
+ }, null, 8, ["percent", "backgroundColor"])
+ ])) : vue.createCommentVNode("v-if", true),
+ item.status === "error" ? (vue.openBlock(), vue.createElementBlock("view", {
+ key: 1,
+ class: "file-picker__mask",
+ onClick: vue.withModifiers(($event) => $options.uploadFiles(item, index), ["stop"])
+ }, " 点击重试 ", 8, ["onClick"])) : vue.createCommentVNode("v-if", true)
+ ],
+ 6
+ /* CLASS, STYLE */
+ );
+ }),
+ 128
+ /* KEYED_FRAGMENT */
+ ))
+ ],
+ 4
+ /* STYLE */
+ )) : vue.createCommentVNode("v-if", true)
+ ]);
+ }
+ const uploadFile = /* @__PURE__ */ _export_sfc(_sfc_main$q, [["render", _sfc_render$5], ["__scopeId", "data-v-a54939c6"], ["__file", "D:/projects/cxc-szcx-uniapp/uni_modules/uni-file-picker/components/uni-file-picker/upload-file.vue"]]);
+ const _sfc_main$p = {
+ name: "uniFilePicker",
+ components: {
+ uploadImage,
+ uploadFile
+ },
+ options: {
+ virtualHost: true
+ },
+ emits: ["select", "success", "fail", "progress", "delete", "update:modelValue", "input"],
+ props: {
+ modelValue: {
+ type: [Array, Object],
+ default() {
+ return [];
+ }
+ },
+ value: {
+ type: [Array, Object],
+ default() {
+ return [];
+ }
+ },
+ disabled: {
+ type: Boolean,
+ default: false
+ },
+ disablePreview: {
+ type: Boolean,
+ default: false
+ },
+ delIcon: {
+ type: Boolean,
+ default: true
+ },
+ // 自动上传
+ autoUpload: {
+ type: Boolean,
+ default: true
+ },
+ // 最大选择个数 ,h5只能限制单选或是多选
+ limit: {
+ type: [Number, String],
+ default: 9
+ },
+ // 列表样式 grid | list | list-card
+ mode: {
+ type: String,
+ default: "grid"
+ },
+ // 选择文件类型 image/video/all
+ fileMediatype: {
+ type: String,
+ default: "image"
+ },
+ // 文件类型筛选
+ fileExtname: {
+ type: [Array, String],
+ default() {
+ return [];
+ }
+ },
+ title: {
+ type: String,
+ default: ""
+ },
+ listStyles: {
+ type: Object,
+ default() {
+ return {
+ // 是否显示边框
+ border: true,
+ // 是否显示分隔线
+ dividline: true,
+ // 线条样式
+ borderStyle: {}
+ };
+ }
+ },
+ imageStyles: {
+ type: Object,
+ default() {
+ return {
+ width: "auto",
+ height: "auto"
+ };
+ }
+ },
+ readonly: {
+ type: Boolean,
+ default: false
+ },
+ returnType: {
+ type: String,
+ default: "array"
+ },
+ sizeType: {
+ type: Array,
+ default() {
+ return ["original", "compressed"];
+ }
+ },
+ sourceType: {
+ type: Array,
+ default() {
+ return ["album", "camera"];
+ }
+ },
+ provider: {
+ type: String,
+ default: ""
+ // 默认上传到 unicloud 内置存储 extStorage 扩展存储
+ }
+ },
+ data() {
+ return {
+ files: [],
+ localValue: []
+ };
+ },
+ watch: {
+ value: {
+ handler(newVal, oldVal) {
+ this.setValue(newVal, oldVal);
+ },
+ immediate: true
+ },
+ modelValue: {
+ handler(newVal, oldVal) {
+ this.setValue(newVal, oldVal);
+ },
+ immediate: true
+ }
+ },
+ computed: {
+ filesList() {
+ let files = [];
+ this.files.forEach((v2) => {
+ files.push(v2);
+ });
+ return files;
+ },
+ showType() {
+ if (this.fileMediatype === "image") {
+ return this.mode;
+ }
+ return "list";
+ },
+ limitLength() {
+ if (this.returnType === "object") {
+ return 1;
+ }
+ if (!this.limit) {
+ return 1;
+ }
+ if (this.limit >= 9) {
+ return 9;
+ }
+ return this.limit;
+ }
+ },
+ created() {
+ if (!(Ws.config && Ws.config.provider)) {
+ this.noSpace = true;
+ Ws.chooseAndUploadFile = chooseAndUploadFile;
+ }
+ this.form = this.getForm("uniForms");
+ this.formItem = this.getForm("uniFormsItem");
+ if (this.form && this.formItem) {
+ if (this.formItem.name) {
+ this.rename = this.formItem.name;
+ this.form.inputChildrens.push(this);
+ }
+ }
+ },
+ methods: {
+ /**
+ * 公开用户使用,清空文件
+ * @param {Object} index
+ */
+ clearFiles(index) {
+ if (index !== 0 && !index) {
+ this.files = [];
+ this.$nextTick(() => {
+ this.setEmit();
+ });
+ } else {
+ this.files.splice(index, 1);
+ }
+ this.$nextTick(() => {
+ this.setEmit();
+ });
+ },
+ /**
+ * 公开用户使用,继续上传
+ */
+ upload() {
+ let files = [];
+ this.files.forEach((v2, index) => {
+ if (v2.status === "ready" || v2.status === "error") {
+ files.push(Object.assign({}, v2));
+ }
+ });
+ return this.uploadFiles(files);
+ },
+ async setValue(newVal, oldVal) {
+ const newData = async (v2) => {
+ const reg = /cloud:\/\/([\w.]+\/?)\S*/;
+ let url = "";
+ if (v2.fileID) {
+ url = v2.fileID;
+ } else {
+ url = v2.url;
+ }
+ if (reg.test(url)) {
+ v2.fileID = url;
+ v2.url = await this.getTempFileURL(url);
+ }
+ if (v2.url)
+ v2.path = v2.url;
+ return v2;
+ };
+ if (this.returnType === "object") {
+ if (newVal) {
+ await newData(newVal);
+ } else {
+ newVal = {};
+ }
+ } else {
+ if (!newVal)
+ newVal = [];
+ for (let i2 = 0; i2 < newVal.length; i2++) {
+ let v2 = newVal[i2];
+ await newData(v2);
+ }
+ }
+ this.localValue = newVal;
+ if (this.form && this.formItem && !this.is_reset) {
+ this.is_reset = false;
+ this.formItem.setValue(this.localValue);
+ }
+ let filesData = Object.keys(newVal).length > 0 ? newVal : [];
+ this.files = [].concat(filesData);
+ },
+ /**
+ * 选择文件
+ */
+ choose() {
+ if (this.disabled)
+ return;
+ if (this.files.length >= Number(this.limitLength) && this.showType !== "grid" && this.returnType === "array") {
+ uni.showToast({
+ title: `您最多选择 ${this.limitLength} 个文件`,
+ icon: "none"
+ });
+ return;
+ }
+ this.chooseFiles();
+ },
+ /**
+ * 选择文件并上传
+ */
+ chooseFiles() {
+ const _extname = get_extname(this.fileExtname);
+ Ws.chooseAndUploadFile({
+ type: this.fileMediatype,
+ compressed: false,
+ sizeType: this.sizeType,
+ sourceType: this.sourceType,
+ // TODO 如果为空,video 有问题
+ extension: _extname.length > 0 ? _extname : void 0,
+ count: this.limitLength - this.files.length,
+ //默认9
+ onChooseFile: this.chooseFileCallback,
+ onUploadProgress: (progressEvent) => {
+ this.setProgress(progressEvent, progressEvent.index);
+ }
+ }).then((result) => {
+ this.setSuccessAndError(result.tempFiles);
+ }).catch((err) => {
+ formatAppLog("log", "at uni_modules/uni-file-picker/components/uni-file-picker/uni-file-picker.vue:364", "选择失败", err);
+ });
+ },
+ /**
+ * 选择文件回调
+ * @param {Object} res
+ */
+ async chooseFileCallback(res) {
+ const _extname = get_extname(this.fileExtname);
+ const is_one = Number(this.limitLength) === 1 && this.disablePreview && !this.disabled || this.returnType === "object";
+ if (is_one) {
+ this.files = [];
+ }
+ let {
+ filePaths,
+ files
+ } = get_files_and_is_max(res, _extname);
+ if (!(_extname && _extname.length > 0)) {
+ filePaths = res.tempFilePaths;
+ files = res.tempFiles;
+ }
+ let currentData = [];
+ for (let i2 = 0; i2 < files.length; i2++) {
+ if (this.limitLength - this.files.length <= 0)
+ break;
+ files[i2].uuid = Date.now();
+ let filedata = await get_file_data(files[i2], this.fileMediatype);
+ filedata.progress = 0;
+ filedata.status = "ready";
+ this.files.push(filedata);
+ currentData.push({
+ ...filedata,
+ file: files[i2]
+ });
+ }
+ this.$emit("select", {
+ tempFiles: currentData,
+ tempFilePaths: filePaths
+ });
+ res.tempFiles = files;
+ if (!this.autoUpload || this.noSpace) {
+ res.tempFiles = [];
+ }
+ res.tempFiles.forEach((fileItem, index) => {
+ this.provider && (fileItem.provider = this.provider);
+ const fileNameSplit = fileItem.name.split(".");
+ const ext = fileNameSplit.pop();
+ const fileName = fileNameSplit.join(".").replace(/[\s\/\?<>\\:\*\|":]/g, "_");
+ fileItem.cloudPath = fileName + "_" + Date.now() + "_" + index + "." + ext;
+ });
+ },
+ /**
+ * 批传
+ * @param {Object} e
+ */
+ uploadFiles(files) {
+ files = [].concat(files);
+ return uploadCloudFiles.call(this, files, 5, (res) => {
+ this.setProgress(res, res.index, true);
+ }).then((result) => {
+ this.setSuccessAndError(result);
+ return result;
+ }).catch((err) => {
+ formatAppLog("log", "at uni_modules/uni-file-picker/components/uni-file-picker/uni-file-picker.vue:437", err);
+ });
+ },
+ /**
+ * 成功或失败
+ */
+ async setSuccessAndError(res, fn) {
+ let successData = [];
+ let errorData = [];
+ let tempFilePath = [];
+ let errorTempFilePath = [];
+ for (let i2 = 0; i2 < res.length; i2++) {
+ const item = res[i2];
+ const index = item.uuid ? this.files.findIndex((p2) => p2.uuid === item.uuid) : item.index;
+ if (index === -1 || !this.files)
+ break;
+ if (item.errMsg === "request:fail") {
+ this.files[index].url = item.path;
+ this.files[index].status = "error";
+ this.files[index].errMsg = item.errMsg;
+ errorData.push(this.files[index]);
+ errorTempFilePath.push(this.files[index].url);
+ } else {
+ this.files[index].errMsg = "";
+ this.files[index].fileID = item.url;
+ const reg = /cloud:\/\/([\w.]+\/?)\S*/;
+ if (reg.test(item.url)) {
+ this.files[index].url = await this.getTempFileURL(item.url);
+ } else {
+ this.files[index].url = item.url;
+ }
+ this.files[index].status = "success";
+ this.files[index].progress += 1;
+ successData.push(this.files[index]);
+ tempFilePath.push(this.files[index].fileID);
+ }
+ }
+ if (successData.length > 0) {
+ this.setEmit();
+ this.$emit("success", {
+ tempFiles: this.backObject(successData),
+ tempFilePaths: tempFilePath
+ });
+ }
+ if (errorData.length > 0) {
+ this.$emit("fail", {
+ tempFiles: this.backObject(errorData),
+ tempFilePaths: errorTempFilePath
+ });
+ }
+ },
+ /**
+ * 获取进度
+ * @param {Object} progressEvent
+ * @param {Object} index
+ * @param {Object} type
+ */
+ setProgress(progressEvent, index, type) {
+ this.files.length;
+ const percentCompleted = Math.round(progressEvent.loaded * 100 / progressEvent.total);
+ let idx = index;
+ if (!type) {
+ idx = this.files.findIndex((p2) => p2.uuid === progressEvent.tempFile.uuid);
+ }
+ if (idx === -1 || !this.files[idx])
+ return;
+ this.files[idx].progress = percentCompleted - 1;
+ this.$emit("progress", {
+ index: idx,
+ progress: parseInt(percentCompleted),
+ tempFile: this.files[idx]
+ });
+ },
+ /**
+ * 删除文件
+ * @param {Object} index
+ */
+ delFile(index) {
+ this.$emit("delete", {
+ index,
+ tempFile: this.files[index],
+ tempFilePath: this.files[index].url
+ });
+ this.files.splice(index, 1);
+ this.$nextTick(() => {
+ this.setEmit();
+ });
+ },
+ /**
+ * 获取文件名和后缀
+ * @param {Object} name
+ */
+ getFileExt(name2) {
+ const last_len = name2.lastIndexOf(".");
+ const len = name2.length;
+ return {
+ name: name2.substring(0, last_len),
+ ext: name2.substring(last_len + 1, len)
+ };
+ },
+ /**
+ * 处理返回事件
+ */
+ setEmit() {
+ let data = [];
+ if (this.returnType === "object") {
+ data = this.backObject(this.files)[0];
+ this.localValue = data ? data : null;
+ } else {
+ data = this.backObject(this.files);
+ if (!this.localValue) {
+ this.localValue = [];
+ }
+ this.localValue = [...data];
+ }
+ this.$emit("update:modelValue", this.localValue);
+ },
+ /**
+ * 处理返回参数
+ * @param {Object} files
+ */
+ backObject(files) {
+ let newFilesData = [];
+ files.forEach((v2) => {
+ newFilesData.push({
+ extname: v2.extname,
+ fileType: v2.fileType,
+ image: v2.image,
+ name: v2.name,
+ path: v2.path,
+ size: v2.size,
+ fileID: v2.fileID,
+ url: v2.url,
+ // 修改删除一个文件后不能再上传的bug, #694
+ uuid: v2.uuid,
+ status: v2.status,
+ cloudPath: v2.cloudPath
+ });
+ });
+ return newFilesData;
+ },
+ async getTempFileURL(fileList) {
+ fileList = {
+ fileList: [].concat(fileList)
+ };
+ const urls = await Ws.getTempFileURL(fileList);
+ return urls.fileList[0].tempFileURL || "";
+ },
+ /**
+ * 获取父元素实例
+ */
+ getForm(name2 = "uniForms") {
+ let parent = this.$parent;
+ let parentName = parent.$options.name;
+ while (parentName !== name2) {
+ parent = parent.$parent;
+ if (!parent)
+ return false;
+ parentName = parent.$options.name;
+ }
+ return parent;
+ }
+ }
+ };
+ function _sfc_render$4(_ctx, _cache, $props, $setup, $data, $options) {
+ const _component_upload_image = vue.resolveComponent("upload-image");
+ const _component_upload_file = vue.resolveComponent("upload-file");
+ return vue.openBlock(), vue.createElementBlock("view", { class: "uni-file-picker" }, [
+ $props.title ? (vue.openBlock(), vue.createElementBlock("view", {
+ key: 0,
+ class: "uni-file-picker__header"
+ }, [
+ vue.createElementVNode(
+ "text",
+ { class: "file-title" },
+ vue.toDisplayString($props.title),
+ 1
+ /* TEXT */
+ ),
+ vue.createElementVNode(
+ "text",
+ { class: "file-count" },
+ vue.toDisplayString($options.filesList.length) + "/" + vue.toDisplayString($options.limitLength),
+ 1
+ /* TEXT */
+ )
+ ])) : vue.createCommentVNode("v-if", true),
+ $props.fileMediatype === "image" && $options.showType === "grid" ? (vue.openBlock(), vue.createBlock(_component_upload_image, {
+ key: 1,
+ readonly: $props.readonly,
+ "image-styles": $props.imageStyles,
+ "files-list": $options.filesList,
+ limit: $options.limitLength,
+ disablePreview: $props.disablePreview,
+ delIcon: $props.delIcon,
+ onUploadFiles: $options.uploadFiles,
+ onChoose: $options.choose,
+ onDelFile: $options.delFile
+ }, {
+ default: vue.withCtx(() => [
+ vue.renderSlot(_ctx.$slots, "default", {}, () => [
+ vue.createElementVNode("view", { class: "is-add" }, [
+ vue.createElementVNode("view", { class: "icon-add" }),
+ vue.createElementVNode("view", { class: "icon-add rotate" })
+ ])
+ ], true)
+ ]),
+ _: 3
+ /* FORWARDED */
+ }, 8, ["readonly", "image-styles", "files-list", "limit", "disablePreview", "delIcon", "onUploadFiles", "onChoose", "onDelFile"])) : vue.createCommentVNode("v-if", true),
+ $props.fileMediatype !== "image" || $options.showType !== "grid" ? (vue.openBlock(), vue.createBlock(_component_upload_file, {
+ key: 2,
+ readonly: $props.readonly,
+ "list-styles": $props.listStyles,
+ "files-list": $options.filesList,
+ showType: $options.showType,
+ delIcon: $props.delIcon,
+ onUploadFiles: $options.uploadFiles,
+ onChoose: $options.choose,
+ onDelFile: $options.delFile
+ }, {
+ default: vue.withCtx(() => [
+ vue.renderSlot(_ctx.$slots, "default", {}, () => [
+ vue.createElementVNode("button", {
+ type: "primary",
+ size: "mini"
+ }, "选择文件")
+ ], true)
+ ]),
+ _: 3
+ /* FORWARDED */
+ }, 8, ["readonly", "list-styles", "files-list", "showType", "delIcon", "onUploadFiles", "onChoose", "onDelFile"])) : vue.createCommentVNode("v-if", true)
+ ]);
+ }
+ const __easycom_0$2 = /* @__PURE__ */ _export_sfc(_sfc_main$p, [["render", _sfc_render$4], ["__scopeId", "data-v-6223573f"], ["__file", "D:/projects/cxc-szcx-uniapp/uni_modules/uni-file-picker/components/uni-file-picker/uni-file-picker.vue"]]);
+ function qjAddApi(config) {
+ return https({
+ url: "/CxcQxj/cxcQxj/add",
+ method: "post",
+ data: config
+ });
+ }
+ function queryZwmcAndExaApi(username) {
+ return https({
+ url: "/CxcQxj/cxcQxj/queryZwmcByUsername",
+ method: "get",
+ data: {
+ username
+ }
+ });
+ }
+ function qjQueryByIdApi(config) {
+ return https({
+ url: "/CxcQxj/cxcQxj/queryById",
+ method: "get",
+ data: config
+ });
+ }
+ function queryDepByCode(code) {
+ return https({
+ url: "/sys/sysDepart/queryDepNameByDepCode",
+ method: "get",
+ data: {
+ code
+ }
+ });
+ }
+ function obj2strClass(obj) {
+ let classess = "";
+ for (let key in obj) {
+ const val = obj[key];
+ if (val) {
+ classess += `${key} `;
+ }
+ }
+ return classess;
+ }
+ function obj2strStyle(obj) {
+ let style = "";
+ for (let key in obj) {
+ const val = obj[key];
+ style += `${key}:${val};`;
+ }
+ return style;
+ }
+ const _sfc_main$o = {
+ name: "uni-easyinput",
+ emits: [
+ "click",
+ "iconClick",
+ "update:modelValue",
+ "input",
+ "focus",
+ "blur",
+ "confirm",
+ "clear",
+ "eyes",
+ "change",
+ "keyboardheightchange"
+ ],
+ model: {
+ prop: "modelValue",
+ event: "update:modelValue"
+ },
+ options: {
+ virtualHost: true
+ },
+ inject: {
+ form: {
+ from: "uniForm",
+ default: null
+ },
+ formItem: {
+ from: "uniFormItem",
+ default: null
+ }
+ },
+ props: {
+ name: String,
+ value: [Number, String],
+ modelValue: [Number, String],
+ type: {
+ type: String,
+ default: "text"
+ },
+ clearable: {
+ type: Boolean,
+ default: true
+ },
+ autoHeight: {
+ type: Boolean,
+ default: false
+ },
+ placeholder: {
+ type: String,
+ default: " "
+ },
+ placeholderStyle: String,
+ focus: {
+ type: Boolean,
+ default: false
+ },
+ disabled: {
+ type: Boolean,
+ default: false
+ },
+ maxlength: {
+ type: [Number, String],
+ default: 140
+ },
+ confirmType: {
+ type: String,
+ default: "done"
+ },
+ clearSize: {
+ type: [Number, String],
+ default: 24
+ },
+ inputBorder: {
+ type: Boolean,
+ default: true
+ },
+ prefixIcon: {
+ type: String,
+ default: ""
+ },
+ suffixIcon: {
+ type: String,
+ default: ""
+ },
+ trim: {
+ type: [Boolean, String],
+ default: false
+ },
+ cursorSpacing: {
+ type: Number,
+ default: 0
+ },
+ passwordIcon: {
+ type: Boolean,
+ default: true
+ },
+ adjustPosition: {
+ type: Boolean,
+ default: true
+ },
+ primaryColor: {
+ type: String,
+ default: "#2979ff"
+ },
+ styles: {
+ type: Object,
+ default() {
+ return {
+ color: "#333",
+ backgroundColor: "#fff",
+ disableColor: "#F7F6F6",
+ borderColor: "#e5e5e5"
+ };
+ }
+ },
+ errorMessage: {
+ type: [String, Boolean],
+ default: ""
+ }
+ },
+ data() {
+ return {
+ focused: false,
+ val: "",
+ showMsg: "",
+ border: false,
+ isFirstBorder: false,
+ showClearIcon: false,
+ showPassword: false,
+ focusShow: false,
+ localMsg: "",
+ isEnter: false
+ // 用于判断当前是否是使用回车操作
+ };
+ },
+ computed: {
+ // 输入框内是否有值
+ isVal() {
+ const val = this.val;
+ if (val || val === 0) {
+ return true;
+ }
+ return false;
+ },
+ msg() {
+ return this.localMsg || this.errorMessage;
+ },
+ // 因为uniapp的input组件的maxlength组件必须要数值,这里转为数值,用户可以传入字符串数值
+ inputMaxlength() {
+ return Number(this.maxlength);
+ },
+ // 处理外层样式的style
+ boxStyle() {
+ return `color:${this.inputBorder && this.msg ? "#e43d33" : this.styles.color};`;
+ },
+ // input 内容的类和样式处理
+ inputContentClass() {
+ return obj2strClass({
+ "is-input-border": this.inputBorder,
+ "is-input-error-border": this.inputBorder && this.msg,
+ "is-textarea": this.type === "textarea",
+ "is-disabled": this.disabled,
+ "is-focused": this.focusShow
+ });
+ },
+ inputContentStyle() {
+ const focusColor = this.focusShow ? this.primaryColor : this.styles.borderColor;
+ const borderColor = this.inputBorder && this.msg ? "#dd524d" : focusColor;
+ return obj2strStyle({
+ "border-color": borderColor || "#e5e5e5",
+ "background-color": this.disabled ? this.styles.disableColor : this.styles.backgroundColor
+ });
+ },
+ // input右侧样式
+ inputStyle() {
+ const paddingRight = this.type === "password" || this.clearable || this.prefixIcon ? "" : "10px";
+ return obj2strStyle({
+ "padding-right": paddingRight,
+ "padding-left": this.prefixIcon ? "" : "10px"
+ });
+ }
+ },
+ watch: {
+ value(newVal) {
+ if (newVal === null) {
+ this.val = "";
+ return;
+ }
+ this.val = newVal;
+ },
+ modelValue(newVal) {
+ if (newVal === null) {
+ this.val = "";
+ return;
+ }
+ this.val = newVal;
+ },
+ focus(newVal) {
+ this.$nextTick(() => {
+ this.focused = this.focus;
+ this.focusShow = this.focus;
+ });
+ }
+ },
+ created() {
+ this.init();
+ if (this.form && this.formItem) {
+ this.$watch("formItem.errMsg", (newVal) => {
+ this.localMsg = newVal;
+ });
+ }
+ },
+ mounted() {
+ this.$nextTick(() => {
+ this.focused = this.focus;
+ this.focusShow = this.focus;
+ });
+ },
+ methods: {
+ /**
+ * 初始化变量值
+ */
+ init() {
+ if (this.value || this.value === 0) {
+ this.val = this.value;
+ } else if (this.modelValue || this.modelValue === 0 || this.modelValue === "") {
+ this.val = this.modelValue;
+ } else {
+ this.val = "";
+ }
+ },
+ /**
+ * 点击图标时触发
+ * @param {Object} type
+ */
+ onClickIcon(type) {
+ this.$emit("iconClick", type);
+ },
+ /**
+ * 显示隐藏内容,密码框时生效
+ */
+ onEyes() {
+ this.showPassword = !this.showPassword;
+ this.$emit("eyes", this.showPassword);
+ },
+ /**
+ * 输入时触发
+ * @param {Object} event
+ */
+ onInput(event) {
+ let value = event.detail.value;
+ if (this.trim) {
+ if (typeof this.trim === "boolean" && this.trim) {
+ value = this.trimStr(value);
+ }
+ if (typeof this.trim === "string") {
+ value = this.trimStr(value, this.trim);
+ }
+ }
+ if (this.errMsg)
+ this.errMsg = "";
+ this.val = value;
+ this.$emit("input", value);
+ this.$emit("update:modelValue", value);
+ },
+ /**
+ * 外部调用方法
+ * 获取焦点时触发
+ * @param {Object} event
+ */
+ onFocus() {
+ this.$nextTick(() => {
+ this.focused = true;
+ });
+ this.$emit("focus", null);
+ },
+ _Focus(event) {
+ this.focusShow = true;
+ this.$emit("focus", event);
+ },
+ /**
+ * 外部调用方法
+ * 失去焦点时触发
+ * @param {Object} event
+ */
+ onBlur() {
+ this.focused = false;
+ this.$emit("blur", null);
+ },
+ _Blur(event) {
+ event.detail.value;
+ this.focusShow = false;
+ this.$emit("blur", event);
+ if (this.isEnter === false) {
+ this.$emit("change", this.val);
+ }
+ if (this.form && this.formItem) {
+ const { validateTrigger } = this.form;
+ if (validateTrigger === "blur") {
+ this.formItem.onFieldChange();
+ }
+ }
+ },
+ /**
+ * 按下键盘的发送键
+ * @param {Object} e
+ */
+ onConfirm(e2) {
+ this.$emit("confirm", this.val);
+ this.isEnter = true;
+ this.$emit("change", this.val);
+ this.$nextTick(() => {
+ this.isEnter = false;
+ });
+ },
+ /**
+ * 清理内容
+ * @param {Object} event
+ */
+ onClear(event) {
+ this.val = "";
+ this.$emit("input", "");
+ this.$emit("update:modelValue", "");
+ this.$emit("clear");
+ },
+ /**
+ * 键盘高度发生变化的时候触发此事件
+ * 兼容性:微信小程序2.7.0+、App 3.1.0+
+ * @param {Object} event
+ */
+ onkeyboardheightchange(event) {
+ this.$emit("keyboardheightchange", event);
+ },
+ /**
+ * 去除空格
+ */
+ trimStr(str, pos = "both") {
+ if (pos === "both") {
+ return str.trim();
+ } else if (pos === "left") {
+ return str.trimLeft();
+ } else if (pos === "right") {
+ return str.trimRight();
+ } else if (pos === "start") {
+ return str.trimStart();
+ } else if (pos === "end") {
+ return str.trimEnd();
+ } else if (pos === "all") {
+ return str.replace(/\s+/g, "");
+ } else if (pos === "none") {
+ return str;
+ }
+ return str;
+ }
+ }
+ };
+ function _sfc_render$3(_ctx, _cache, $props, $setup, $data, $options) {
+ const _component_uni_icons = resolveEasycom(vue.resolveDynamicComponent("uni-icons"), __easycom_1$1);
+ return vue.openBlock(), vue.createElementBlock(
+ "view",
+ {
+ class: vue.normalizeClass(["uni-easyinput", { "uni-easyinput-error": $options.msg }]),
+ style: vue.normalizeStyle($options.boxStyle)
+ },
+ [
+ vue.createElementVNode(
+ "view",
+ {
+ class: vue.normalizeClass(["uni-easyinput__content", $options.inputContentClass]),
+ style: vue.normalizeStyle($options.inputContentStyle)
+ },
+ [
+ $props.prefixIcon ? (vue.openBlock(), vue.createBlock(_component_uni_icons, {
+ key: 0,
+ class: "content-clear-icon",
+ type: $props.prefixIcon,
+ color: "#c0c4cc",
+ onClick: _cache[0] || (_cache[0] = ($event) => $options.onClickIcon("prefix")),
+ size: "22"
+ }, null, 8, ["type"])) : vue.createCommentVNode("v-if", true),
+ vue.renderSlot(_ctx.$slots, "left", {}, void 0, true),
+ $props.type === "textarea" ? (vue.openBlock(), vue.createElementBlock("textarea", {
+ key: 1,
+ class: vue.normalizeClass(["uni-easyinput__content-textarea", { "input-padding": $props.inputBorder }]),
+ name: $props.name,
+ value: $data.val,
+ placeholder: $props.placeholder,
+ placeholderStyle: $props.placeholderStyle,
+ disabled: $props.disabled,
+ "placeholder-class": "uni-easyinput__placeholder-class",
+ maxlength: $options.inputMaxlength,
+ focus: $data.focused,
+ autoHeight: $props.autoHeight,
+ "cursor-spacing": $props.cursorSpacing,
+ "adjust-position": $props.adjustPosition,
+ onInput: _cache[1] || (_cache[1] = (...args) => $options.onInput && $options.onInput(...args)),
+ onBlur: _cache[2] || (_cache[2] = (...args) => $options._Blur && $options._Blur(...args)),
+ onFocus: _cache[3] || (_cache[3] = (...args) => $options._Focus && $options._Focus(...args)),
+ onConfirm: _cache[4] || (_cache[4] = (...args) => $options.onConfirm && $options.onConfirm(...args)),
+ onKeyboardheightchange: _cache[5] || (_cache[5] = (...args) => $options.onkeyboardheightchange && $options.onkeyboardheightchange(...args))
+ }, null, 42, ["name", "value", "placeholder", "placeholderStyle", "disabled", "maxlength", "focus", "autoHeight", "cursor-spacing", "adjust-position"])) : (vue.openBlock(), vue.createElementBlock("input", {
+ key: 2,
+ type: $props.type === "password" ? "text" : $props.type,
+ class: "uni-easyinput__content-input",
+ style: vue.normalizeStyle($options.inputStyle),
+ name: $props.name,
+ value: $data.val,
+ password: !$data.showPassword && $props.type === "password",
+ placeholder: $props.placeholder,
+ placeholderStyle: $props.placeholderStyle,
+ "placeholder-class": "uni-easyinput__placeholder-class",
+ disabled: $props.disabled,
+ maxlength: $options.inputMaxlength,
+ focus: $data.focused,
+ confirmType: $props.confirmType,
+ "cursor-spacing": $props.cursorSpacing,
+ "adjust-position": $props.adjustPosition,
+ onFocus: _cache[6] || (_cache[6] = (...args) => $options._Focus && $options._Focus(...args)),
+ onBlur: _cache[7] || (_cache[7] = (...args) => $options._Blur && $options._Blur(...args)),
+ onInput: _cache[8] || (_cache[8] = (...args) => $options.onInput && $options.onInput(...args)),
+ onConfirm: _cache[9] || (_cache[9] = (...args) => $options.onConfirm && $options.onConfirm(...args)),
+ onKeyboardheightchange: _cache[10] || (_cache[10] = (...args) => $options.onkeyboardheightchange && $options.onkeyboardheightchange(...args))
+ }, null, 44, ["type", "name", "value", "password", "placeholder", "placeholderStyle", "disabled", "maxlength", "focus", "confirmType", "cursor-spacing", "adjust-position"])),
+ $props.type === "password" && $props.passwordIcon ? (vue.openBlock(), vue.createElementBlock(
+ vue.Fragment,
+ { key: 3 },
+ [
+ vue.createCommentVNode(" 开启密码时显示小眼睛 "),
+ $options.isVal ? (vue.openBlock(), vue.createBlock(_component_uni_icons, {
+ key: 0,
+ class: vue.normalizeClass(["content-clear-icon", { "is-textarea-icon": $props.type === "textarea" }]),
+ type: $data.showPassword ? "eye-slash-filled" : "eye-filled",
+ size: 22,
+ color: $data.focusShow ? $props.primaryColor : "#c0c4cc",
+ onClick: $options.onEyes
+ }, null, 8, ["class", "type", "color", "onClick"])) : vue.createCommentVNode("v-if", true)
+ ],
+ 64
+ /* STABLE_FRAGMENT */
+ )) : vue.createCommentVNode("v-if", true),
+ $props.suffixIcon ? (vue.openBlock(), vue.createElementBlock(
+ vue.Fragment,
+ { key: 4 },
+ [
+ $props.suffixIcon ? (vue.openBlock(), vue.createBlock(_component_uni_icons, {
+ key: 0,
+ class: "content-clear-icon",
+ type: $props.suffixIcon,
+ color: "#c0c4cc",
+ onClick: _cache[11] || (_cache[11] = ($event) => $options.onClickIcon("suffix")),
+ size: "22"
+ }, null, 8, ["type"])) : vue.createCommentVNode("v-if", true)
+ ],
+ 64
+ /* STABLE_FRAGMENT */
+ )) : (vue.openBlock(), vue.createElementBlock(
+ vue.Fragment,
+ { key: 5 },
+ [
+ $props.clearable && $options.isVal && !$props.disabled && $props.type !== "textarea" ? (vue.openBlock(), vue.createBlock(_component_uni_icons, {
+ key: 0,
+ class: vue.normalizeClass(["content-clear-icon", { "is-textarea-icon": $props.type === "textarea" }]),
+ type: "clear",
+ size: $props.clearSize,
+ color: $options.msg ? "#dd524d" : $data.focusShow ? $props.primaryColor : "#c0c4cc",
+ onClick: $options.onClear
+ }, null, 8, ["class", "size", "color", "onClick"])) : vue.createCommentVNode("v-if", true)
+ ],
+ 64
+ /* STABLE_FRAGMENT */
+ )),
+ vue.renderSlot(_ctx.$slots, "right", {}, void 0, true)
+ ],
+ 6
+ /* CLASS, STYLE */
+ )
+ ],
+ 6
+ /* CLASS, STYLE */
+ );
+ }
+ const __easycom_1 = /* @__PURE__ */ _export_sfc(_sfc_main$o, [["render", _sfc_render$3], ["__scopeId", "data-v-09fd5285"], ["__file", "D:/projects/cxc-szcx-uniapp/uni_modules/uni-easyinput/components/uni-easyinput/uni-easyinput.vue"]]);
+ function isString(data) {
+ return typeof data === "string";
+ }
+ function paging(data, PAGENUM = 50) {
+ if (!Array.isArray(data) || !data.length)
+ return data;
+ const pages2 = [];
+ data.forEach((item, index) => {
+ const i2 = Math.floor(index / PAGENUM);
+ if (!pages2[i2]) {
+ pages2[i2] = [];
+ }
+ pages2[i2].push(item);
+ });
+ return pages2;
+ }
+ const _sfc_main$n = /* @__PURE__ */ vue.defineComponent({
+ __name: "data-select-item",
+ props: {
+ node: {
+ type: Object,
+ default: () => ({})
+ },
+ choseParent: {
+ type: Boolean,
+ default: true
+ },
+ dataLabel: {
+ type: String,
+ default: "name"
+ },
+ dataValue: {
+ type: String,
+ default: "value"
+ },
+ dataChildren: {
+ type: String,
+ default: "children"
+ },
+ border: {
+ type: Boolean,
+ default: false
+ },
+ linkage: {
+ type: Boolean,
+ default: false
+ },
+ lazyLoadChildren: {
+ type: Boolean,
+ default: false
+ },
+ level: {
+ type: Number,
+ default: 0
+ }
+ },
+ setup(__props) {
+ const { nodeClick, nameClick, loadNode, initData, addNode } = vue.inject("nodeFn");
+ const props = __props;
+ const listData = vue.ref([]);
+ const clearTimerList = vue.ref([]);
+ const loadingArr = vue.ref([]);
+ vue.watchEffect(() => {
+ if (props.node.showChildren && props.node[props.dataChildren] && props.node[props.dataChildren].length) {
+ resetClearTimerList();
+ renderTree(props.node[props.dataChildren]);
+ }
+ });
+ function resetClearTimerList() {
+ const list = [...clearTimerList.value];
+ clearTimerList.value = [];
+ list.forEach((fn) => fn());
+ }
+ function renderTree(arr) {
+ const pagingArr = paging(arr);
+ listData.value = (pagingArr == null ? void 0 : pagingArr[0]) || [];
+ lazyRenderList(pagingArr, 1);
+ }
+ function lazyRenderList(arr, startIndex) {
+ for (let i2 = startIndex; i2 < arr.length; i2++) {
+ let timer = null;
+ timer = setTimeout(() => {
+ listData.value.push(...arr[i2]);
+ }, i2 * 500);
+ clearTimerList.push(() => clearTimeout(timer));
+ }
+ }
+ function handleNameClick(node) {
+ var _a;
+ if (!node.visible)
+ return;
+ if (!((_a = node[props.dataChildren]) == null ? void 0 : _a.length) && props.lazyLoadChildren) {
+ loadingArr.value.push(node[props.dataValue].toString());
+ loadNode(node).then((res) => {
+ addNode(node, initData(res, node.visible));
+ }).finally(() => {
+ loadingArr.value = [];
+ });
+ } else {
+ nameClick(node);
+ }
+ }
+ return (_ctx, _cache) => {
+ const _component_uni_icons = resolveEasycom(vue.resolveDynamicComponent("uni-icons"), __easycom_1$1);
+ return vue.openBlock(), vue.createElementBlock(
+ "view",
+ {
+ class: vue.normalizeClass(["customthree-tree-select-content", {
+ border: __props.border && __props.node[__props.dataChildren] && __props.node[__props.dataChildren].length && __props.node.showChildren
+ }]),
+ style: vue.normalizeStyle({ marginLeft: `${__props.level ? 14 : 0}px` })
+ },
+ [
+ __props.node.visible ? (vue.openBlock(), vue.createElementBlock("view", {
+ key: 0,
+ class: "custom-tree-select-item"
+ }, [
+ vue.createElementVNode("view", { class: "item-content" }, [
+ vue.createElementVNode("view", {
+ class: "left",
+ onClick: _cache[0] || (_cache[0] = vue.withModifiers(($event) => handleNameClick(__props.node), ["stop"]))
+ }, [
+ vue.createElementVNode("view", { class: "icon-group" }, [
+ __props.node[__props.dataChildren] && __props.node[__props.dataChildren].length ? (vue.openBlock(), vue.createElementBlock(
+ "view",
+ {
+ key: 0,
+ class: vue.normalizeClass(["right-icon", { active: __props.node.showChildren }])
+ },
+ [
+ vue.createVNode(_component_uni_icons, {
+ type: "right",
+ size: "14",
+ color: "#333"
+ })
+ ],
+ 2
+ /* CLASS */
+ )) : (vue.openBlock(), vue.createElementBlock("view", {
+ key: 1,
+ class: "smallcircle-filled"
+ }, [
+ vue.createVNode(_component_uni_icons, {
+ class: "smallcircle-filled-icon",
+ type: "smallcircle-filled",
+ size: "10",
+ color: "#333"
+ })
+ ]))
+ ]),
+ loadingArr.value.includes(__props.node[props.dataValue].toString()) ? (vue.openBlock(), vue.createElementBlock("view", {
+ key: 0,
+ class: "loading-icon-box"
+ }, [
+ vue.createVNode(_component_uni_icons, {
+ class: "loading-icon",
+ type: "spinner-cycle",
+ size: "14",
+ color: "#333"
+ })
+ ])) : vue.createCommentVNode("v-if", true),
+ vue.createElementVNode(
+ "view",
+ {
+ class: "name",
+ style: vue.normalizeStyle(__props.node.disabled ? "color: #999" : "")
+ },
+ [
+ vue.createElementVNode(
+ "text",
+ null,
+ vue.toDisplayString(__props.node[__props.dataLabel]),
+ 1
+ /* TEXT */
+ )
+ ],
+ 4
+ /* STYLE */
+ )
+ ]),
+ __props.choseParent || !__props.choseParent && !__props.node[__props.dataChildren] || !__props.choseParent && __props.node[__props.dataChildren] && !__props.node[__props.dataChildren].length ? (vue.openBlock(), vue.createElementBlock(
+ "view",
+ {
+ key: 0,
+ class: vue.normalizeClass(["check-box", { disabled: __props.node.disabled }]),
+ onClick: _cache[1] || (_cache[1] = vue.withModifiers(($event) => !__props.node.disabled && vue.unref(nodeClick)(__props.node), ["stop"]))
+ },
+ [
+ !__props.node.checked && __props.node.partChecked && __props.linkage ? (vue.openBlock(), vue.createElementBlock("view", {
+ key: 0,
+ class: "part-checked"
+ })) : vue.createCommentVNode("v-if", true),
+ __props.node.checked ? (vue.openBlock(), vue.createBlock(_component_uni_icons, {
+ key: 1,
+ type: "checkmarkempty",
+ size: "18",
+ color: __props.node.disabled ? "#333" : "#007aff"
+ }, null, 8, ["color"])) : vue.createCommentVNode("v-if", true)
+ ],
+ 2
+ /* CLASS */
+ )) : vue.createCommentVNode("v-if", true)
+ ])
+ ])) : vue.createCommentVNode("v-if", true),
+ __props.node.showChildren && __props.node[__props.dataChildren] && __props.node[__props.dataChildren].length ? (vue.openBlock(), vue.createElementBlock("view", { key: 1 }, [
+ (vue.openBlock(true), vue.createElementBlock(
+ vue.Fragment,
+ null,
+ vue.renderList(listData.value, (item) => {
+ return vue.openBlock(), vue.createBlock(dataSelectItem, {
+ key: item[__props.dataValue],
+ node: item,
+ dataLabel: __props.dataLabel,
+ dataValue: __props.dataValue,
+ dataChildren: __props.dataChildren,
+ choseParent: __props.choseParent,
+ lazyLoadChildren: __props.lazyLoadChildren,
+ border: __props.border,
+ linkage: __props.linkage,
+ level: __props.level + 1
+ }, null, 8, ["node", "dataLabel", "dataValue", "dataChildren", "choseParent", "lazyLoadChildren", "border", "linkage", "level"]);
+ }),
+ 128
+ /* KEYED_FRAGMENT */
+ ))
+ ])) : vue.createCommentVNode("v-if", true)
+ ],
+ 6
+ /* CLASS, STYLE */
+ );
+ };
+ }
+ });
+ const dataSelectItem = /* @__PURE__ */ _export_sfc(_sfc_main$n, [["__scopeId", "data-v-3a65eef7"], ["__file", "D:/projects/cxc-szcx-uniapp/components/treeSelect/data-select-item.vue"]]);
+ const _sfc_main$m = /* @__PURE__ */ vue.defineComponent({
+ __name: "treeSelect",
+ props: {
+ canSelectAll: {
+ type: Boolean,
+ default: false
+ },
+ safeArea: {
+ type: Boolean,
+ default: true
+ },
+ search: {
+ type: Boolean,
+ default: false
+ },
+ clearResetSearch: {
+ type: Boolean,
+ default: false
+ },
+ animation: {
+ type: Boolean,
+ default: true
+ },
+ "is-mask-click": {
+ type: Boolean,
+ default: true
+ },
+ "mask-background-color": {
+ type: String,
+ default: "rgba(0,0,0,0.4)"
+ },
+ "background-color": {
+ type: String,
+ default: "none"
+ },
+ "safe-area": {
+ type: Boolean,
+ default: true
+ },
+ choseParent: {
+ type: Boolean,
+ default: false
+ },
+ placeholder: {
+ type: String,
+ default: "请选择"
+ },
+ confirmText: {
+ type: String,
+ default: "确认"
+ },
+ confirmTextColor: {
+ type: String,
+ default: "#007aff"
+ },
+ dataSource: {
+ type: Array,
+ default: () => []
+ },
+ dataLabel: {
+ type: String,
+ default: "name"
+ },
+ dataValue: {
+ type: String,
+ default: "id"
+ },
+ dataChildren: {
+ type: String,
+ default: "children"
+ },
+ linkage: {
+ type: Boolean,
+ default: false
+ },
+ removeLinkage: {
+ type: Boolean,
+ default: true
+ },
+ clearable: {
+ type: Boolean,
+ default: false
+ },
+ mutiple: {
+ type: Boolean,
+ default: false
+ },
+ disabled: {
+ type: Boolean,
+ default: false
+ },
+ deleteSource: {
+ type: Boolean,
+ default: false
+ },
+ showChildren: {
+ type: Boolean,
+ default: false
+ },
+ border: {
+ type: Boolean,
+ default: false
+ },
+ lazyLoadChildren: {
+ type: Boolean,
+ default: false
+ },
+ load: {
+ type: Function,
+ default: function() {
+ }
+ },
+ modelValue: {
+ type: [Array, String],
+ default: () => []
+ }
+ },
+ emits: ["update:modelValue", "change", "maskClick", "select-change", "removeSelect"],
+ setup(__props, { emit: __emit }) {
+ const props = __props;
+ const emits = __emit;
+ const contentHeight = vue.ref("500px");
+ const treeData = vue.ref([]);
+ const filterTreeData = vue.ref([]);
+ const clearTimerList = vue.ref([]);
+ const selectedListBaseinfo = vue.ref([]);
+ const showPopup = vue.ref(false);
+ const isSelectedAll = vue.ref(false);
+ const scrollTop = vue.ref(0);
+ const searchStr = vue.ref("");
+ const popup = vue.ref(null);
+ const partCheckedSet = /* @__PURE__ */ new Set();
+ vue.provide("nodeFn", {
+ nodeClick: handleNodeClick,
+ nameClick: handleHideChildren,
+ loadNode: props.load,
+ initData,
+ addNode
+ });
+ const selectList = vue.computed(() => {
+ const newVal = props.modelValue === null ? "" : props.modelValue;
+ return isString(newVal) ? newVal.length ? newVal.split(",") : [] : newVal.map((item) => item.toString());
+ });
+ vue.onMounted(() => {
+ getContentHeight(uni.getSystemInfoSync());
+ });
+ function getContentHeight({ screenHeight }) {
+ contentHeight.value = `${Math.floor(screenHeight * 0.7)}px`;
+ }
+ vue.watch(
+ () => props.dataSource,
+ (newVal) => {
+ if (newVal) {
+ treeData.value = initData(newVal);
+ if (showPopup.value) {
+ resetClearTimerList();
+ renderTree(treeData.value);
+ }
+ }
+ },
+ { immediate: true, deep: true }
+ );
+ vue.watch(
+ () => props.modelValue,
+ (newVal) => {
+ const ids = newVal ? Array.isArray(newVal) ? newVal : newVal.split(",") : [];
+ changeStatus(treeData.value, ids, true);
+ filterTreeData.value.length && changeStatus(filterTreeData.value, ids);
+ },
+ { immediate: true }
+ );
+ function goTop() {
+ scrollTop.val = 10;
+ vue.nextTick(() => {
+ scrollTop.value = 0;
+ });
+ }
+ function handleSearch(isClear = false) {
+ resetClearTimerList();
+ if (isClear) {
+ if (props.clearResetSearch) {
+ renderTree(treeData.value);
+ }
+ } else {
+ renderTree(searchValue(searchStr.value, treeData.value));
+ }
+ goTop();
+ uni.hideKeyboard();
+ }
+ function searchValue(str, arr) {
+ const res = [];
+ arr.forEach((item) => {
+ var _a, _b;
+ if (item.visible) {
+ if (item[props.dataLabel].toString().toLowerCase().indexOf(str.toLowerCase()) > -1) {
+ res.push(item);
+ } else {
+ if ((_a = item[props.dataChildren]) == null ? void 0 : _a.length) {
+ const data = searchValue(str, item[props.dataChildren]);
+ if (data == null ? void 0 : data.length) {
+ if (str && !item.showChildren && ((_b = item[props.dataChildren]) == null ? void 0 : _b.length)) {
+ item.showChildren = true;
+ }
+ res.push({
+ ...item,
+ [props.dataChildren]: data
+ });
+ }
+ }
+ }
+ }
+ });
+ return res;
+ }
+ async function open2() {
+ if (props.disabled)
+ return;
+ showPopup.value = true;
+ popup.value.open();
+ renderTree(treeData.value);
+ }
+ function close() {
+ popup.value.close();
+ }
+ function change(data) {
+ if (!data.show) {
+ resetClearTimerList();
+ searchStr.value = "";
+ showPopup.value = false;
+ }
+ emits("change", data);
+ }
+ function maskClick() {
+ emits("maskClick");
+ }
+ function initData(arr, parentVisible) {
+ var _a;
+ if (!Array.isArray(arr))
+ return [];
+ const res = [];
+ for (let i2 = 0; i2 < arr.length; i2++) {
+ const obj = {
+ [props.dataLabel]: arr[i2][props.dataLabel],
+ [props.dataValue]: arr[i2][props.dataValue]
+ };
+ obj.checked = selectList.value.includes(arr[i2][props.dataValue].toString());
+ obj.disabled = Boolean(arr[i2].disabled);
+ obj.partChecked = Boolean(arr[i2].partChecked === void 0 ? false : arr[i2].partChecked);
+ obj.partChecked && obj.partCheckedSet.add(obj[props.dataValue]);
+ !obj.partChecked && (isSelectedAll.value = false);
+ const parentVisibleState = parentVisible === void 0 ? true : parentVisible;
+ const curVisibleState = arr[i2].visible === void 0 ? true : Boolean(arr[i2].visible);
+ if (parentVisibleState === curVisibleState) {
+ obj.visible = parentVisibleState;
+ } else if (!parentVisibleState || !curVisibleState) {
+ obj.visible = false;
+ } else {
+ obj.visible = true;
+ }
+ obj.showChildren = "showChildren" in arr[i2] && arr[i2].showChildren != void 0 ? arr[i2].showChildren : props.showChildren;
+ if (arr[i2].visible && !arr[i2].disabled && !arr[i2].checked) {
+ isSelectedAll.value = false;
+ }
+ if ((_a = arr[i2][props.dataChildren]) == null ? void 0 : _a.length) {
+ obj[props.dataChildren] = initData(arr[i2][props.dataChildren], obj.visible);
+ }
+ res.push(obj);
+ }
+ return res;
+ }
+ function addNode(node, children) {
+ getReflectNode(node, treeData.value)[props.dataChildren] = children;
+ handleHideChildren(node);
+ }
+ function resetClearTimerList() {
+ const list = [...clearTimerList.value];
+ clearTimerList.value = [];
+ list.forEach((fn) => fn());
+ }
+ function renderTree(arr) {
+ const pagingArr = paging(arr);
+ filterTreeData.value = (pagingArr == null ? void 0 : pagingArr[0]) || [];
+ lazyRenderList(pagingArr, 1);
+ }
+ function lazyRenderList(arr, startIndex) {
+ for (let i2 = startIndex; i2 < arr.length; i2++) {
+ let timer = null;
+ timer = setTimeout(() => {
+ filterTreeData.value.push(...arr[i2]);
+ }, i2 * 500);
+ clearTimerList.push(() => clearTimeout(timer));
+ }
+ }
+ function changeStatus(list, ids, needEmit = false) {
+ var _a;
+ const arr = [...list];
+ let flag = true;
+ needEmit && (selectedListBaseinfo.value = []);
+ while (arr.length) {
+ const item = arr.shift();
+ if (ids.includes(item[props.dataValue].toString())) {
+ item.checked = true;
+ item.partChecked = false;
+ partCheckedSet.delete(item[props.dataValue]);
+ needEmit && selectedListBaseinfo.value.push(item);
+ } else {
+ item.checked = false;
+ if (item.visible && !item.disabled) {
+ flag = false;
+ }
+ if (partCheckedSet.has(item[props.dataValue])) {
+ item.partChecked = true;
+ } else {
+ item.partChecked = false;
+ }
+ }
+ if ((_a = item[props.dataChildren]) == null ? void 0 : _a.length) {
+ arr.push(...item[props.dataChildren]);
+ }
+ }
+ isSelectedAll.value = flag;
+ needEmit && emits("select-change", [...selectedListBaseinfo.value]);
+ }
+ function removeSelectedItem(node) {
+ isSelectedAll.value = false;
+ if (props.linkage) {
+ handleNodeClick(node, false);
+ emits("removeSelect", node);
+ } else {
+ const emitData = selectList.value.filter((item) => item !== node[props.dataValue].toString());
+ emits("removeSelect", node);
+ emits("update:modelValue", isString(props.modelValue) ? emitData.join(",") : emitData);
+ }
+ }
+ function getReflectNode(node, arr) {
+ var _a;
+ const array = [...arr];
+ while (array.length) {
+ const item = array.shift();
+ if (item[props.dataValue] === node[props.dataValue]) {
+ return item;
+ }
+ if ((_a = item[props.dataChildren]) == null ? void 0 : _a.length) {
+ array.push(...item[props.dataChildren]);
+ }
+ }
+ return {};
+ }
+ function getChildren(node) {
+ var _a;
+ if (!((_a = node[props.dataChildren]) == null ? void 0 : _a.length))
+ return [];
+ const res = node[props.dataChildren].reduce((pre, val) => {
+ if (val.visible) {
+ return [...pre, val];
+ }
+ return pre;
+ }, []);
+ for (let i2 = 0; i2 < node[props.dataChildren].length; i2++) {
+ res.push(...getChildren(node[props.dataChildren][i2]));
+ }
+ return res;
+ }
+ function getParentNode(target, arr) {
+ var _a;
+ let res = [];
+ for (let i2 = 0; i2 < arr.length; i2++) {
+ if (arr[i2][props.dataValue] === target[props.dataValue]) {
+ return true;
+ }
+ if ((_a = arr[i2][props.dataChildren]) == null ? void 0 : _a.length) {
+ const childRes = getParentNode(target, arr[i2][props.dataChildren]);
+ if (typeof childRes === "boolean" && childRes) {
+ res = [arr[i2]];
+ } else if (Array.isArray(childRes) && childRes.length) {
+ res = [...childRes, arr[i2]];
+ }
+ }
+ }
+ return res;
+ }
+ function handleNodeClick(data, status) {
+ const node = getReflectNode(data, treeData.value);
+ node.checked = typeof status === "boolean" ? status : !node.checked;
+ node.partChecked = false;
+ partCheckedSet.delete(node[props.dataValue]);
+ if (!props.mutiple) {
+ let emitData = [];
+ if (node.checked) {
+ emitData = [node[props.dataValue].toString()];
+ }
+ emits("update:modelValue", isString(props.modelValue) ? emitData.join(",") : emitData);
+ } else {
+ if (!props.linkage) {
+ let emitData = null;
+ if (node.checked) {
+ emitData = Array.from(/* @__PURE__ */ new Set([...selectList.value, node[props.dataValue].toString()]));
+ } else {
+ emitData = selectList.value.filter((id) => id !== node[props.dataValue].toString());
+ }
+ emits("update:modelValue", isString(props.modelValue) ? emitData.join(",") : emitData);
+ } else {
+ let emitData = [...selectList.value];
+ const parentNodes = getParentNode(node, treeData.value);
+ const childrenVal = getChildren(node).filter((item) => !item.disabled);
+ if (node.checked) {
+ emitData = Array.from(/* @__PURE__ */ new Set([...emitData, node[props.dataValue].toString()]));
+ if (childrenVal.length) {
+ emitData = Array.from(
+ /* @__PURE__ */ new Set([...emitData, ...childrenVal.map((item) => item[props.dataValue].toString())])
+ );
+ childrenVal.forEach((childNode) => {
+ childNode.partChecked = false;
+ partCheckedSet.delete(childNode[props.dataValue]);
+ });
+ }
+ if (parentNodes.length) {
+ let flag = false;
+ while (parentNodes.length) {
+ const item = parentNodes.shift();
+ if (!item.disabled) {
+ if (flag) {
+ item.partChecked = true;
+ partCheckedSet.add(item[props.dataValue]);
+ } else {
+ const allChecked = item[props.dataChildren].filter((node2) => node2.visible && !node2.disabled).every((node2) => node2.checked);
+ if (allChecked) {
+ item.checked = true;
+ item.partChecked = false;
+ partCheckedSet.delete(item[props.dataValue]);
+ emitData = Array.from(/* @__PURE__ */ new Set([...emitData, item[props.dataValue].toString()]));
+ } else {
+ item.partChecked = true;
+ partCheckedSet.add(item[props.dataValue]);
+ flag = true;
+ }
+ }
+ }
+ }
+ }
+ } else {
+ emitData = emitData.filter((id) => id !== node[props.dataValue].toString());
+ if (childrenVal.length) {
+ childrenVal.forEach((childNode) => {
+ emitData = emitData.filter((id) => id !== childNode[props.dataValue].toString());
+ });
+ }
+ if (parentNodes.length) {
+ parentNodes.forEach((parentNode) => {
+ if (emitData.includes(parentNode[props.dataValue].toString())) {
+ parentNode.checked = false;
+ }
+ emitData = emitData.filter((id) => id !== parentNode[props.dataValue].toString());
+ const hasChecked = parentNode[props.dataChildren].filter((node2) => node2.visible && !node2.disabled).some((node2) => node2.checked || node2.partChecked);
+ parentNode.partChecked = hasChecked;
+ if (hasChecked) {
+ partCheckedSet.add(parentNode[props.dataValue]);
+ } else {
+ partCheckedSet.delete(parentNode[props.dataValue]);
+ }
+ });
+ }
+ }
+ emits("update:modelValue", isString(props.modelValue) ? emitData.join(",") : emitData);
+ }
+ }
+ }
+ function handleHideChildren(node) {
+ const status = !node.showChildren;
+ getReflectNode(node, treeData.value).showChildren = status;
+ getReflectNode(node, filterTreeData.value).showChildren = status;
+ }
+ function handleSelectAll() {
+ isSelectedAll.value = !isSelectedAll.value;
+ if (isSelectedAll.value) {
+ if (!props.mutiple) {
+ uni.showToast({
+ title: "单选模式下不能全选",
+ icon: "none",
+ duration: 1e3
+ });
+ return;
+ }
+ let emitData = [];
+ treeData.value.forEach((item) => {
+ var _a;
+ if (item.visible || item.disabled && item.checked) {
+ emitData = Array.from(/* @__PURE__ */ new Set([...emitData, item[props.dataValue].toString()]));
+ if ((_a = item[props.dataChildren]) == null ? void 0 : _a.length) {
+ emitData = Array.from(
+ /* @__PURE__ */ new Set([
+ ...emitData,
+ ...getChildren(item).filter((item2) => !item2.disabled || item2.disabled && item2.checked).map((item2) => item2[props.dataValue].toString())
+ ])
+ );
+ }
+ }
+ });
+ emits("update:modelValue", isString(props.modelValue) ? emitData.join(",") : emitData);
+ } else {
+ clearSelectList();
+ }
+ }
+ function clearSelectList() {
+ if (props.disabled)
+ return;
+ partCheckedSet.clear();
+ const emitData = [];
+ selectedListBaseinfo.value.forEach((node) => {
+ if (node.visible && node.checked && node.disabled) {
+ emitData.push(node[props.dataValue]);
+ }
+ });
+ emits("update:modelValue", isString(props.modelValue) ? emitData.join(",") : emitData);
+ }
+ return (_ctx, _cache) => {
+ const _component_uni_icons = resolveEasycom(vue.resolveDynamicComponent("uni-icons"), __easycom_1$1);
+ const _component_uni_easyinput = resolveEasycom(vue.resolveDynamicComponent("uni-easyinput"), __easycom_1);
+ const _component_uni_popup = resolveEasycom(vue.resolveDynamicComponent("uni-popup"), __easycom_2);
+ return vue.openBlock(), vue.createElementBlock(
+ vue.Fragment,
+ null,
+ [
+ vue.createElementVNode(
+ "view",
+ {
+ class: vue.normalizeClass(["select-list", { disabled: __props.disabled }, { active: selectList.value.length }]),
+ onClick: open2
+ },
+ [
+ vue.createElementVNode("view", { class: "left" }, [
+ selectList.value.length ? (vue.openBlock(), vue.createElementBlock("view", {
+ key: 0,
+ class: "select-items"
+ }, [
+ (vue.openBlock(true), vue.createElementBlock(
+ vue.Fragment,
+ null,
+ vue.renderList(selectedListBaseinfo.value, (item) => {
+ return vue.openBlock(), vue.createElementBlock("view", {
+ class: "select-item",
+ key: item[__props.dataValue]
+ }, [
+ vue.createElementVNode("view", { class: "name" }, [
+ vue.createElementVNode(
+ "text",
+ null,
+ vue.toDisplayString(item[__props.dataLabel]),
+ 1
+ /* TEXT */
+ )
+ ]),
+ !__props.disabled && !item.disabled && __props.deleteSource ? (vue.openBlock(), vue.createElementBlock("view", {
+ key: 0,
+ class: "close",
+ onClick: vue.withModifiers(($event) => removeSelectedItem(item), ["stop"])
+ }, [
+ vue.createVNode(_component_uni_icons, {
+ type: "closeempty",
+ size: "16",
+ color: "#999"
+ })
+ ], 8, ["onClick"])) : vue.createCommentVNode("v-if", true)
+ ]);
+ }),
+ 128
+ /* KEYED_FRAGMENT */
+ ))
+ ])) : (vue.openBlock(), vue.createElementBlock("view", {
+ key: 1,
+ class: "no-data"
+ }, [
+ vue.createElementVNode(
+ "text",
+ null,
+ vue.toDisplayString(__props.placeholder),
+ 1
+ /* TEXT */
+ )
+ ]))
+ ]),
+ vue.createElementVNode("view", null, [
+ !selectList.value.length || !__props.clearable ? (vue.openBlock(), vue.createBlock(_component_uni_icons, {
+ key: 0,
+ type: "bottom",
+ color: "#333333"
+ })) : vue.createCommentVNode("v-if", true),
+ vue.createElementVNode("view", {
+ onClick: _cache[0] || (_cache[0] = vue.withModifiers(() => {
+ }, ["stop"]))
+ }, [
+ selectList.value.length && __props.clearable ? (vue.openBlock(), vue.createBlock(_component_uni_icons, {
+ key: 0,
+ type: "clear",
+ size: "24",
+ color: "#c0c4cc",
+ onClick: clearSelectList
+ })) : vue.createCommentVNode("v-if", true)
+ ])
+ ])
+ ],
+ 2
+ /* CLASS */
+ ),
+ vue.createVNode(_component_uni_popup, {
+ ref_key: "popup",
+ ref: popup,
+ animation: __props.animation,
+ "is-mask-click": _ctx.isMaskClick,
+ "mask-background-color": _ctx.maskBackgroundColor,
+ "background-color": _ctx.backgroundColor,
+ "safe-area": __props.safeArea,
+ type: "bottom",
+ onChange: change,
+ onMaskClick: maskClick
+ }, {
+ default: vue.withCtx(() => [
+ vue.createElementVNode(
+ "view",
+ {
+ class: "popup-content",
+ style: vue.normalizeStyle({ height: contentHeight.value })
+ },
+ [
+ vue.createElementVNode("view", { class: "title" }, [
+ __props.mutiple && __props.canSelectAll ? (vue.openBlock(), vue.createElementBlock("view", {
+ key: 0,
+ class: "left",
+ onClick: handleSelectAll
+ }, [
+ vue.createElementVNode(
+ "text",
+ null,
+ vue.toDisplayString(isSelectedAll.value ? "取消全选" : "全选"),
+ 1
+ /* TEXT */
+ )
+ ])) : vue.createCommentVNode("v-if", true),
+ vue.createElementVNode("view", { class: "center" }, [
+ vue.createElementVNode(
+ "text",
+ null,
+ vue.toDisplayString(__props.placeholder),
+ 1
+ /* TEXT */
+ )
+ ]),
+ vue.createElementVNode(
+ "view",
+ {
+ class: "right",
+ style: vue.normalizeStyle({ color: __props.confirmTextColor }),
+ onClick: close
+ },
+ [
+ vue.createElementVNode(
+ "text",
+ null,
+ vue.toDisplayString(__props.confirmText),
+ 1
+ /* TEXT */
+ )
+ ],
+ 4
+ /* STYLE */
+ )
+ ]),
+ __props.search ? (vue.openBlock(), vue.createElementBlock("view", {
+ key: 0,
+ class: "search-box"
+ }, [
+ vue.createVNode(_component_uni_easyinput, {
+ maxlength: -1,
+ prefixIcon: "search",
+ placeholder: "搜索",
+ modelValue: searchStr.value,
+ "onUpdate:modelValue": _cache[1] || (_cache[1] = ($event) => searchStr.value = $event),
+ "confirm-type": "search",
+ onConfirm: _cache[2] || (_cache[2] = ($event) => handleSearch(false)),
+ onClear: _cache[3] || (_cache[3] = ($event) => handleSearch(true))
+ }, null, 8, ["modelValue"]),
+ vue.createElementVNode("button", {
+ type: "primary",
+ size: "mini",
+ class: "search-btn",
+ onClick: _cache[4] || (_cache[4] = ($event) => handleSearch(false))
+ }, "搜索")
+ ])) : vue.createCommentVNode("v-if", true),
+ treeData.value.length ? (vue.openBlock(), vue.createElementBlock("view", {
+ key: 1,
+ class: "select-content"
+ }, [
+ vue.createElementVNode("scroll-view", {
+ class: "scroll-view-box",
+ "scroll-top": scrollTop.value,
+ "scroll-y": "true",
+ onTouchmove: _cache[5] || (_cache[5] = vue.withModifiers(() => {
+ }, ["stop"]))
+ }, [
+ !filterTreeData.value.length ? (vue.openBlock(), vue.createElementBlock("view", {
+ key: 0,
+ class: "no-data center"
+ }, [
+ vue.createElementVNode("text", null, "暂无数据")
+ ])) : vue.createCommentVNode("v-if", true),
+ (vue.openBlock(true), vue.createElementBlock(
+ vue.Fragment,
+ null,
+ vue.renderList(filterTreeData.value, (item) => {
+ return vue.openBlock(), vue.createBlock(dataSelectItem, {
+ key: item[__props.dataValue],
+ node: item,
+ dataLabel: __props.dataLabel,
+ dataValue: __props.dataValue,
+ dataChildren: __props.dataChildren,
+ choseParent: __props.choseParent,
+ border: __props.border,
+ linkage: __props.linkage,
+ lazyLoadChildren: __props.lazyLoadChildren
+ }, null, 8, ["node", "dataLabel", "dataValue", "dataChildren", "choseParent", "border", "linkage", "lazyLoadChildren"]);
+ }),
+ 128
+ /* KEYED_FRAGMENT */
+ )),
+ vue.createElementVNode("view", { class: "sentry" })
+ ], 40, ["scroll-top"])
+ ])) : (vue.openBlock(), vue.createElementBlock("view", {
+ key: 2,
+ class: "no-data center"
+ }, [
+ vue.createElementVNode("text", null, "暂无数据")
+ ]))
+ ],
+ 4
+ /* STYLE */
+ )
+ ]),
+ _: 1
+ /* STABLE */
+ }, 8, ["animation", "is-mask-click", "mask-background-color", "background-color", "safe-area"])
+ ],
+ 64
+ /* STABLE_FRAGMENT */
+ );
+ };
+ }
+ });
+ const treeSelect = /* @__PURE__ */ _export_sfc(_sfc_main$m, [["__scopeId", "data-v-0328d33e"], ["__file", "D:/projects/cxc-szcx-uniapp/components/treeSelect/treeSelect.vue"]]);
+ const _sfc_main$l = {
+ __name: "application",
+ setup(__props) {
+ const store = useStore();
+ const {
+ proxy
+ } = vue.getCurrentInstance();
+ const realname = vue.ref(store.userinfo.realname);
+ const depart = vue.ref("");
+ const phone = vue.ref(store.userinfo.phone);
+ const type = vue.ref("");
+ const dataSource = vue.ref([]);
+ const beginTime = vue.ref("");
+ const chooseStart = (e2) => {
+ beginTime.value = e2.detail.value;
+ };
+ const endTime = vue.ref("");
+ const chooseEnd = (e2) => {
+ endTime.value = e2.detail.value;
+ };
+ const typeArr = vue.ref([]);
+ const typeIndex = vue.ref(null);
+ const ifShow = vue.ref(true);
+ const zwcj = vue.ref("");
+ const address = vue.ref("");
+ const reason = vue.ref("");
+ const path = vue.ref([]);
+ const baseUrl2 = "http://10.75.166.174:8080/jeecg-boot/sys/common/upload/";
+ const imageStyles = {
+ width: 64,
+ height: 64,
+ border: {
+ color: "#dce7e1",
+ width: 2,
+ style: "dashed",
+ radius: "2px"
+ }
+ };
+ onLoad(() => {
+ loadData();
+ });
+ const select = (e2) => {
+ e2.tempFilePaths;
+ for (let i2 = 0; i2 < e2.tempFilePaths.length; i2++) {
+ let photoPath = "职工请假/" + store.userinfo.orgCode + "/" + store.userinfo.realname;
+ uni.uploadFile({
+ url: baseUrl2,
+ filePath: e2.tempFilePaths[i2],
+ name: "file",
+ formData: {
+ appPath: photoPath
+ },
+ success: (res) => {
+ path.value.push(JSON.parse(res.data).message);
+ }
+ });
+ }
+ };
+ const qjAdd = () => {
+ if (!phone.value.trim())
+ return proxy.$toast("请输入联系方式");
+ if (!type.value)
+ return proxy.$toast("请选择请假类型");
+ if (!beginTime.value)
+ return proxy.$toast("请选择开始时间");
+ if (!endTime.value)
+ return proxy.$toast("请选择结束时间");
+ if (ifShow.value) {
+ if (typeIndex.value == null) {
+ return proxy.$toast("请选择审批领导");
+ }
+ }
+ if (!address.value.trim())
+ return proxy.$toast("请输入请假地点");
+ if (!reason.value.trim())
+ return proxy.$toast("请输入请假事由");
+ qjAddApi({
+ username: store.userinfo.username,
+ phone: phone.value,
+ type: type.value,
+ begintime: beginTime.value,
+ endtime: endTime.value,
+ examineleader: typeArr.value[typeIndex.value].username,
+ address: address.value,
+ reason: reason.value,
+ zwmc: zwcj.value,
+ path: path.value.toString()
+ }).then((res) => {
+ if (res.success) {
+ startMutilProcess(res.message);
+ } else {
+ proxy.$toast(res.message);
+ }
+ });
+ };
+ const startMutilProcess = (id) => {
+ startMutilProcessApi({
+ flowCode: "dev_cxc_qxj",
+ id,
+ formUrl: "modules/qxj/modules/CxcQxjBpmModel",
+ formUrlMobile: "leaveApplication"
+ //对应main.js里全局注册createApp()里的 app.component('leaveApplication',index)
+ }).then((res) => {
+ if (res.success) {
+ proxy.$toast(res.message);
+ setTimeout(() => {
+ uni.navigateBack();
+ }, 2e3);
+ }
+ }).catch((err) => {
+ formatAppLog("log", "at pages/leave/application.vue:235", err);
+ });
+ };
+ const loadData = () => {
+ getCategoryItemsApi("1838487445813645313").then((res) => {
+ if (res.success) {
+ dataSource.value = res.result;
+ }
+ });
+ queryDepByCode(store.userinfo.orgCode).then((res) => {
+ if (res.success) {
+ depart.value = res.result;
+ }
+ });
+ queryZwmcAndExaApi(store.userinfo.username).then((res) => {
+ if (res.success) {
+ typeArr.value = res.result.list;
+ zwcj.value = res.result.zwmc;
+ if (zwcj.value == "单位专家" || zwcj.value == "正职" || zwcj.value == "高级主管") {
+ ifShow.value = false;
+ }
+ } else {
+ proxy.$toast(res.message);
+ }
+ });
+ };
+ const bindType = (e2) => {
+ typeIndex.value = e2.detail.value;
+ };
+ return (_ctx, _cache) => {
+ const _component_uni_icons = resolveEasycom(vue.resolveDynamicComponent("uni-icons"), __easycom_1$1);
+ const _component_uni_file_picker = resolveEasycom(vue.resolveDynamicComponent("uni-file-picker"), __easycom_0$2);
+ return vue.openBlock(), vue.createElementBlock(
+ "view",
+ {
+ class: vue.normalizeClass({ "gray": vue.unref(store).isgray == 1 })
+ },
+ [
+ vue.createElementVNode("view", { class: "form" }, [
+ vue.createElementVNode("view", { class: "f-row aic jcb input_box" }, [
+ vue.createElementVNode("view", { class: "title" }, " 职工姓名: "),
+ vue.withDirectives(vue.createElementVNode(
+ "input",
+ {
+ "onUpdate:modelValue": _cache[0] || (_cache[0] = ($event) => realname.value = $event),
+ disabled: ""
+ },
+ null,
+ 512
+ /* NEED_PATCH */
+ ), [
+ [vue.vModelText, realname.value]
+ ])
+ ]),
+ vue.createElementVNode("view", { class: "f-row aic jcb input_box" }, [
+ vue.createElementVNode("view", { class: "title" }, " 工作单位: "),
+ vue.withDirectives(vue.createElementVNode(
+ "input",
+ {
+ "onUpdate:modelValue": _cache[1] || (_cache[1] = ($event) => depart.value = $event),
+ disabled: ""
+ },
+ null,
+ 512
+ /* NEED_PATCH */
+ ), [
+ [vue.vModelText, depart.value]
+ ])
+ ]),
+ vue.createElementVNode("view", { class: "f-row aic jcb input_box" }, [
+ vue.createElementVNode("view", { class: "title" }, " 联系方式: "),
+ vue.withDirectives(vue.createElementVNode(
+ "input",
+ {
+ "onUpdate:modelValue": _cache[2] || (_cache[2] = ($event) => phone.value = $event)
+ },
+ null,
+ 512
+ /* NEED_PATCH */
+ ), [
+ [vue.vModelText, phone.value]
+ ])
+ ]),
+ vue.createElementVNode("view", { class: "f-row aic jcb input_box" }, [
+ vue.createElementVNode("view", { class: "title" }, " 请假类型: "),
+ vue.createVNode(treeSelect, {
+ dataSource: dataSource.value,
+ modelValue: type.value,
+ "onUpdate:modelValue": _cache[3] || (_cache[3] = ($event) => type.value = $event),
+ dataValue: "name"
+ }, null, 8, ["dataSource", "modelValue"])
+ ]),
+ vue.createElementVNode("picker", {
+ mode: "date",
+ fields: "day",
+ onChange: chooseStart,
+ value: beginTime.value
+ }, [
+ vue.createElementVNode("view", { class: "f-row aic jcb box" }, [
+ vue.createElementVNode("view", { class: "title" }, " 开始时间: "),
+ vue.createElementVNode("view", { class: "f-row aic" }, [
+ vue.createElementVNode(
+ "view",
+ {
+ class: vue.normalizeClass([{ "choose": !beginTime.value }, { "choosed": beginTime.value }])
+ },
+ vue.toDisplayString(beginTime.value ? beginTime.value : "请选择"),
+ 3
+ /* TEXT, CLASS */
+ ),
+ vue.createVNode(_component_uni_icons, {
+ type: "bottom",
+ color: "#333333"
+ })
+ ])
+ ])
+ ], 40, ["value"]),
+ vue.createElementVNode("picker", {
+ mode: "date",
+ fields: "day",
+ onChange: chooseEnd,
+ value: endTime.value
+ }, [
+ vue.createElementVNode("view", { class: "f-row aic jcb box" }, [
+ vue.createElementVNode("view", { class: "title" }, " 截止时间: "),
+ vue.createElementVNode("view", { class: "f-row aic" }, [
+ vue.createElementVNode(
+ "view",
+ {
+ class: vue.normalizeClass([{ "choose": !endTime.value }, { "choosed": endTime.value }])
+ },
+ vue.toDisplayString(endTime.value ? endTime.value : "请选择"),
+ 3
+ /* TEXT, CLASS */
+ ),
+ vue.createVNode(_component_uni_icons, {
+ type: "bottom",
+ color: "#333333"
+ })
+ ])
+ ])
+ ], 40, ["value"]),
+ ifShow.value ? (vue.openBlock(), vue.createElementBlock("picker", {
+ key: 0,
+ onChange: bindType,
+ value: typeIndex.value,
+ range: typeArr.value,
+ "range-key": "realname"
+ }, [
+ vue.createElementVNode("view", { class: "f-row aic jcb box" }, [
+ vue.createElementVNode("view", { class: "title" }, " 审批领导: "),
+ vue.createElementVNode("view", { class: "f-row aic" }, [
+ vue.createElementVNode(
+ "view",
+ {
+ class: vue.normalizeClass([{ "choose": typeIndex.value == null }, { "choosed": typeIndex.value != null }])
+ },
+ vue.toDisplayString(typeIndex.value != null ? typeArr.value[typeIndex.value].realname : "请选择"),
+ 3
+ /* TEXT, CLASS */
+ ),
+ vue.createVNode(_component_uni_icons, {
+ type: "bottom",
+ color: "#333333"
+ })
+ ])
+ ])
+ ], 40, ["value", "range"])) : vue.createCommentVNode("v-if", true),
+ vue.createElementVNode("view", { class: "f-row aic jcb input_box" }, [
+ vue.createElementVNode("view", { class: "title" }, " 请假地点: "),
+ vue.withDirectives(vue.createElementVNode(
+ "input",
+ {
+ "onUpdate:modelValue": _cache[4] || (_cache[4] = ($event) => address.value = $event),
+ placeholder: "请输入",
+ "nplaceholder-style": "font-size: 28rpx;color: #999999;"
+ },
+ null,
+ 512
+ /* NEED_PATCH */
+ ), [
+ [vue.vModelText, address.value]
+ ])
+ ]),
+ vue.createElementVNode("view", { class: "f-row aic jcb input_box" }, [
+ vue.createElementVNode("view", { class: "title" }, " 请假事由: "),
+ vue.withDirectives(vue.createElementVNode(
+ "input",
+ {
+ "onUpdate:modelValue": _cache[5] || (_cache[5] = ($event) => reason.value = $event),
+ placeholder: "请输入",
+ "placeholder-style": "font-size: 28rpx;color: #999999;"
+ },
+ null,
+ 512
+ /* NEED_PATCH */
+ ), [
+ [vue.vModelText, reason.value]
+ ])
+ ]),
+ vue.createElementVNode("view", { class: "f-row aic jcb input_box" }, [
+ vue.createElementVNode("view", { class: "title" }, " 上传附件: "),
+ vue.createVNode(_component_uni_file_picker, {
+ onSelect: select,
+ "image-styles": imageStyles
+ })
+ ])
+ ]),
+ vue.createElementVNode("view", { class: "btn f-col aic" }, [
+ vue.createElementVNode("view", { onClick: qjAdd }, " 提交 ")
+ ])
+ ],
+ 2
+ /* CLASS */
+ );
+ };
+ }
+ };
+ const PagesLeaveApplication = /* @__PURE__ */ _export_sfc(_sfc_main$l, [["__scopeId", "data-v-f12ae642"], ["__file", "D:/projects/cxc-szcx-uniapp/pages/leave/application.vue"]]);
+ const _sfc_main$k = {
+ __name: "index",
+ setup(__props) {
+ const store = useStore();
+ const back = () => {
+ uni.navigateBack();
+ };
+ return (_ctx, _cache) => {
+ const _component_uni_icons = resolveEasycom(vue.resolveDynamicComponent("uni-icons"), __easycom_1$1);
+ return vue.openBlock(), vue.createElementBlock(
+ "view",
+ {
+ class: vue.normalizeClass(["content", { "gray": vue.unref(store).isgray == 1 }])
+ },
+ [
+ vue.createVNode(customNav, null, {
+ default: vue.withCtx(() => [
+ vue.createElementVNode("view", { class: "nav_box f-row aic" }, [
+ vue.createElementVNode("view", {
+ class: "back",
+ onClick: back
+ }, [
+ vue.createVNode(_component_uni_icons, {
+ type: "left",
+ size: "20",
+ color: "#fff"
+ })
+ ]),
+ vue.createElementVNode("view", { class: "avatar" }, [
+ vue.createElementVNode("image", {
+ src: vue.unref(store).userinfo.avatar,
+ mode: ""
+ }, null, 8, ["src"])
+ ]),
+ vue.createElementVNode("view", { class: "f-col" }, [
+ vue.createElementVNode(
+ "view",
+ { class: "name" },
+ vue.toDisplayString(vue.unref(store).userinfo.realname),
+ 1
+ /* TEXT */
+ ),
+ vue.createElementVNode(
+ "view",
+ { class: "position" },
+ vue.toDisplayString(vue.unref(store).role),
+ 1
+ /* TEXT */
+ )
+ ])
+ ])
+ ]),
+ _: 1
+ /* STABLE */
+ }),
+ vue.createElementVNode("view", { class: "time_box f-row aic jcb" }, [
+ vue.createElementVNode("view", { class: "box" }, [
+ vue.createElementVNode("view", { class: "time f-row aic" }, [
+ vue.createElementVNode("view", { class: "" }, " 上班 9:30 "),
+ vue.createElementVNode("image", {
+ src: "/static/checkin/chenggong.png",
+ mode: ""
+ })
+ ]),
+ vue.createElementVNode("view", { class: "text" }, " 重庆市渝北区上弯路 ")
+ ]),
+ vue.createElementVNode("view", { class: "box" }, [
+ vue.createElementVNode("view", { class: "time f-row aic" }, [
+ vue.createElementVNode("view", { class: "" }, " 下班 16:30 "),
+ vue.createElementVNode("image", {
+ src: "/static/checkin/shibai.png",
+ mode: ""
+ })
+ ]),
+ vue.createElementVNode("view", { class: "text" }, " 打卡已超时 ")
+ ])
+ ]),
+ vue.createElementVNode("view", { class: "checkin" }, [
+ vue.createElementVNode("view", { class: "f-col aic" }, [
+ vue.createElementVNode("view", { class: "status f-col aic" }, [
+ vue.createCommentVNode(' \r\n \r\n '),
+ vue.createElementVNode("image", {
+ src: "/static/checkin/position4.png",
+ mode: ""
+ }),
+ vue.createElementVNode("text", null, "打卡失败")
+ ]),
+ vue.createElementVNode("view", {
+ class: vue.normalizeClass(["circle", "f-col", "aic", "out", "check", "success", "fail"])
+ }, [
+ vue.createElementVNode("view", { class: "title" }, " 上班打卡 "),
+ vue.createElementVNode("view", { class: "time" }, " 9:00 "),
+ vue.createElementVNode("view", { class: "ontime" }, " 已超时 ")
+ ])
+ ])
+ ])
+ ],
+ 2
+ /* CLASS */
+ );
+ };
+ }
+ };
+ const PagesCheckinIndex = /* @__PURE__ */ _export_sfc(_sfc_main$k, [["__scopeId", "data-v-1410bd6b"], ["__file", "D:/projects/cxc-szcx-uniapp/pages/checkin/index.vue"]]);
+ const _sfc_main$j = {
+ __name: "useredit",
+ setup(__props) {
+ const baseUrl2 = "http://10.75.166.174:8080/jeecg-boot/sys/common/upload";
+ const store = useStore();
+ const chooseAvatar = () => {
+ uni.chooseImage({
+ count: 1,
+ success: (chooseImageRes) => {
+ const tempFilePaths = chooseImageRes.tempFilePaths;
+ const photoPath = "用户头像/" + store.userinfo.realname;
+ uni.uploadFile({
+ url: baseUrl2,
+ //仅为示例,非真实的接口地址
+ filePath: tempFilePaths[0],
+ name: "file",
+ formData: {
+ appPath: photoPath
+ },
+ success: (res) => {
+ uni.showLoading({
+ title: "上传中..."
+ });
+ form.avatar = JSON.parse(res.data).message;
+ userEditApi({
+ avatar: form.avatar,
+ id: store.userinfo.id
+ }).then((res2) => {
+ if (res2) {
+ uni.showToast({
+ title: res2,
+ icon: "success",
+ duration: 2e3
+ });
+ }
+ }).catch((err) => {
+ formatAppLog("log", "at pages/useredit/useredit.vue:97", err);
+ });
+ },
+ fail(err) {
+ formatAppLog("log", "at pages/useredit/useredit.vue:101", "图片上传出错", err);
+ }
+ });
+ }
+ });
+ };
+ const form = vue.reactive({
+ avatar: "",
+ realname: "",
+ phone: ""
+ });
+ const loginout = () => {
+ uni.showModal({
+ title: "退出登录",
+ content: "您确认要退出登录吗?",
+ success(res) {
+ if (res.confirm) {
+ uni.removeStorageSync("token");
+ uni.removeStorageSync("user");
+ uni.removeStorageSync("role");
+ uni.removeStorageSync("logintime");
+ uni.reLaunch({
+ url: "/pages/login/login"
+ });
+ }
+ }
+ });
+ };
+ onLoad(() => {
+ uni.setNavigationBarColor({
+ frontColor: "#ffffff",
+ backgroundColor: "#bebebe"
+ });
+ });
+ return (_ctx, _cache) => {
+ const _component_uni_icons = resolveEasycom(vue.resolveDynamicComponent("uni-icons"), __easycom_1$1);
+ return vue.openBlock(), vue.createElementBlock(
+ vue.Fragment,
+ null,
+ [
+ vue.createElementVNode(
+ "view",
+ {
+ class: vue.normalizeClass(["content", { "gray": vue.unref(store).isgray == 1 }])
+ },
+ [
+ vue.createElementVNode("view", { class: "box" }, [
+ vue.createElementVNode("view", null, "头像"),
+ vue.createElementVNode("view", { style: { "display": "flex", "align-items": "center" } }, [
+ vue.createElementVNode("button", {
+ class: "head-btn",
+ onClick: chooseAvatar
+ }, [
+ !form.avatar ? (vue.openBlock(), vue.createElementBlock("image", {
+ key: 0,
+ class: "head-img",
+ src: vue.unref(imgUrl)(vue.unref(store).userinfo.avatar),
+ mode: ""
+ }, null, 8, ["src"])) : (vue.openBlock(), vue.createElementBlock("image", {
+ key: 1,
+ class: "head-img",
+ src: vue.unref(imgUrl)(form.avatar)
+ }, null, 8, ["src"]))
+ ]),
+ vue.createVNode(_component_uni_icons, {
+ type: "right",
+ size: "24"
+ })
+ ])
+ ]),
+ vue.createElementVNode("view", {
+ class: "box",
+ style: { "padding-top": "30rpx", "padding-bottom": "30rpx" }
+ }, [
+ vue.createElementVNode("view", null, "姓名"),
+ vue.withDirectives(vue.createElementVNode(
+ "input",
+ {
+ disabled: "",
+ style: { "text-align": "right" },
+ type: "nickname",
+ "placeholder-style": "font-size: 32rpx;color: #999999;",
+ "onUpdate:modelValue": _cache[0] || (_cache[0] = ($event) => vue.unref(store).userinfo.realname = $event),
+ placeholder: "请输入姓名"
+ },
+ null,
+ 512
+ /* NEED_PATCH */
+ ), [
+ [vue.vModelText, vue.unref(store).userinfo.realname]
+ ])
+ ]),
+ vue.createElementVNode("view", {
+ class: "box",
+ style: { "padding-top": "30rpx", "padding-bottom": "30rpx" }
+ }, [
+ vue.createElementVNode("view", null, "手机号"),
+ vue.withDirectives(vue.createElementVNode(
+ "input",
+ {
+ disabled: "",
+ style: { "text-align": "right" },
+ type: "nickname",
+ "onUpdate:modelValue": _cache[1] || (_cache[1] = ($event) => vue.unref(store).userinfo.phone = $event),
+ placeholder: "请输入手机号",
+ "placeholder-style": "font-size: 32rpx;color: #999999;"
+ },
+ null,
+ 512
+ /* NEED_PATCH */
+ ), [
+ [vue.vModelText, vue.unref(store).userinfo.phone]
+ ])
+ ]),
+ vue.createElementVNode("view", {
+ class: "box",
+ style: { "padding-top": "30rpx", "padding-bottom": "30rpx" }
+ }, [
+ vue.createElementVNode("view", null, "劳动合同号"),
+ vue.withDirectives(vue.createElementVNode(
+ "input",
+ {
+ style: { "text-align": "right" },
+ type: "nickname",
+ disabled: "",
+ "onUpdate:modelValue": _cache[2] || (_cache[2] = ($event) => vue.unref(store).userinfo.workNo = $event),
+ placeholder: "请输入劳动合同号",
+ "placeholder-style": "font-size: 32rpx;color: #999999;"
+ },
+ null,
+ 512
+ /* NEED_PATCH */
+ ), [
+ [vue.vModelText, vue.unref(store).userinfo.workNo]
+ ])
+ ])
+ ],
+ 2
+ /* CLASS */
+ ),
+ vue.createElementVNode("view", { class: "line" }),
+ vue.createElementVNode("view", {
+ class: "btn",
+ onClick: loginout
+ }, " 退出登录 ")
+ ],
+ 64
+ /* STABLE_FRAGMENT */
+ );
+ };
+ }
+ };
+ const PagesUsereditUseredit = /* @__PURE__ */ _export_sfc(_sfc_main$j, [["__scopeId", "data-v-503dd57f"], ["__file", "D:/projects/cxc-szcx-uniapp/pages/useredit/useredit.vue"]]);
+ const _sfc_main$i = {
+ __name: "address",
+ setup(__props) {
+ const store = useStore();
+ const jump = (url) => {
+ beforeJump(url, () => {
+ uni.navigateTo({
+ url
+ });
+ });
+ };
+ return (_ctx, _cache) => {
+ return vue.openBlock(), vue.createElementBlock(
+ "view",
+ {
+ class: vue.normalizeClass(["content", { "gray": vue.unref(store).isgray == 1 }])
+ },
+ [
+ vue.createElementVNode("view", { class: "list" }, [
+ (vue.openBlock(), vue.createElementBlock(
+ vue.Fragment,
+ null,
+ vue.renderList(2, (item, i2) => {
+ return vue.createElementVNode("view", {
+ class: "item",
+ key: i2
+ }, [
+ vue.createElementVNode("view", { class: "province f-row aic" }, [
+ vue.createElementVNode("view", { class: "" }, " 浙江省,杭州市 "),
+ vue.createElementVNode("image", {
+ src: "/static/my/default.png",
+ mode: ""
+ })
+ ]),
+ vue.createElementVNode("view", { class: "address f-row jcb" }, [
+ vue.createElementVNode("view", { class: "" }, " 重庆 重庆市 渝北区 龙溪街道花卉园东路黄金 宝高级住宅小区 "),
+ vue.createElementVNode("image", {
+ src: "/static/my/edit.png",
+ mode: ""
+ })
+ ]),
+ vue.createElementVNode("view", { class: "set f-row aic jcb" }, [
+ vue.createElementVNode("view", { class: "f-row aic" }, [
+ vue.createCommentVNode(' '),
+ vue.createElementVNode("image", {
+ src: "/static/login/nocheck.png",
+ mode: ""
+ }),
+ vue.createTextVNode(" 设为默认地址 ")
+ ]),
+ vue.createElementVNode("view", { class: "" }, " 删除 ")
+ ])
+ ]);
+ }),
+ 64
+ /* STABLE_FRAGMENT */
+ ))
+ ]),
+ vue.createElementVNode("view", { class: "btn f-col aic" }, [
+ vue.createElementVNode("view", {
+ class: "",
+ onClick: _cache[0] || (_cache[0] = ($event) => jump("/pages/useredit/add_address"))
+ }, " +添加收货地址 ")
+ ])
+ ],
+ 2
+ /* CLASS */
+ );
+ };
+ }
+ };
+ const PagesUsereditAddress = /* @__PURE__ */ _export_sfc(_sfc_main$i, [["__scopeId", "data-v-4bd9b73b"], ["__file", "D:/projects/cxc-szcx-uniapp/pages/useredit/address.vue"]]);
+ const _sfc_main$h = {
+ __name: "add_address",
+ setup(__props) {
+ const store = useStore();
+ return (_ctx, _cache) => {
+ return vue.openBlock(), vue.createElementBlock(
+ "view",
+ {
+ class: vue.normalizeClass(["content", { "gray": vue.unref(store).isgray == 1 }])
+ },
+ [
+ vue.createElementVNode("view", { class: "area f-row jcb" }, [
+ vue.createElementVNode("view", { class: "title topic" }, " 所在地区 "),
+ vue.createElementVNode("input", {
+ type: "text",
+ placeholder: "省、市、区、街道"
+ })
+ ]),
+ vue.createElementVNode("view", { class: "area f-row jcb" }, [
+ vue.createElementVNode("view", { class: "title topic" }, " 详细地址 "),
+ vue.createElementVNode("textarea", { placeholder: "小区楼栋/乡村名称" })
+ ]),
+ vue.createElementVNode("view", { class: "area f-row jcb" }, [
+ vue.createElementVNode("view", { class: "title" }, " 设为默认地址 "),
+ vue.createElementVNode("image", {
+ src: "/static/login/checked.png",
+ mode: ""
+ }),
+ vue.createCommentVNode(' ')
+ ]),
+ vue.createElementVNode("view", { class: "btn f-col aic" }, [
+ vue.createElementVNode("view", { class: "" }, " 保存 ")
+ ])
+ ],
+ 2
+ /* CLASS */
+ );
+ };
+ }
+ };
+ const PagesUsereditAdd_address = /* @__PURE__ */ _export_sfc(_sfc_main$h, [["__scopeId", "data-v-f1271877"], ["__file", "D:/projects/cxc-szcx-uniapp/pages/useredit/add_address.vue"]]);
+ const _sfc_main$g = {
+ __name: "addressbook",
+ setup(__props) {
+ const store = useStore();
+ return (_ctx, _cache) => {
+ return vue.openBlock(), vue.createElementBlock(
+ "view",
+ {
+ class: vue.normalizeClass({ "gray": vue.unref(store).isgray == 1 })
+ },
+ [
+ vue.createElementVNode("view", { class: "list" }, [
+ (vue.openBlock(), vue.createElementBlock(
+ vue.Fragment,
+ null,
+ vue.renderList(4, (item, i2) => {
+ return vue.createElementVNode("view", {
+ class: "item f-row aic jcb",
+ key: i2
+ }, [
+ vue.createElementVNode("view", { class: "user f-row aic" }, [
+ vue.createElementVNode("image", {
+ src: "",
+ mode: ""
+ }),
+ vue.createElementVNode("view", { class: "name_job" }, [
+ vue.createElementVNode("view", { class: "name" }, " 我是晴天 "),
+ vue.createElementVNode("view", { class: "job" }, " 销售部-销售总监 ")
+ ])
+ ]),
+ vue.createElementVNode("view", { class: "btn" }, " 电话联系 ")
+ ]);
+ }),
+ 64
+ /* STABLE_FRAGMENT */
+ ))
+ ])
+ ],
+ 2
+ /* CLASS */
+ );
+ };
+ }
+ };
+ const PagesUsereditAddressbook = /* @__PURE__ */ _export_sfc(_sfc_main$g, [["__scopeId", "data-v-c0e791d9"], ["__file", "D:/projects/cxc-szcx-uniapp/pages/useredit/addressbook.vue"]]);
+ const _sfc_main$f = {
+ __name: "extendCom",
+ props: {
+ title: {
+ type: String,
+ default: ""
+ },
+ img: {
+ type: String,
+ default: ""
+ },
+ list: {
+ type: Array,
+ default: function() {
+ return [];
+ }
+ },
+ // selfArrquery: {
+ // type: Array,
+ // default: function() {
+ // return []
+ // }
+ // },
+ total: {
+ type: Number,
+ default: 0
+ }
+ },
+ setup(__props) {
+ vue.useCssVars((_ctx) => ({
+ "e40cd242-moreHeight": moreHeight.value
+ }));
+ const props = __props;
+ const open2 = vue.ref(false);
+ const moreHeight = vue.ref(null);
+ const CurrentInstance = vue.getCurrentInstance();
+ vue.watch(() => props.list, () => {
+ vue.nextTick(() => {
+ uni.createSelectorQuery().in(CurrentInstance.proxy).select(".item_box").boundingClientRect((data) => {
+ moreHeight.value = (data == null ? void 0 : data.height) + "px";
+ formatAppLog("log", "at bpm/extendCom.vue:82", "moreHeight", moreHeight.value);
+ }).exec();
+ });
+ }, {
+ immediate: true
+ });
+ const tolist = (title) => {
+ let id = null;
+ beforeJump("/pages/task/index", () => {
+ if (props.title == "待办事项") {
+ id = 0;
+ }
+ if (props.title == "已办事项") {
+ id = 2;
+ }
+ if (props.title == "本人发起") {
+ return uni.navigateTo({
+ url: `/pages/task/self?title=${title}`
+ });
+ }
+ uni.navigateTo({
+ url: `/pages/task/index?id=${id}&title=${title}`
+ });
+ });
+ };
+ return (_ctx, _cache) => {
+ return vue.openBlock(), vue.createElementBlock("view", { class: "content" }, [
+ vue.createElementVNode("view", { class: "todo f-col aic" }, [
+ vue.createElementVNode("view", { class: "f-col aic" }, [
+ vue.createElementVNode("view", {
+ class: "title_box f-row aic jcb",
+ onClick: _cache[0] || (_cache[0] = ($event) => tolist(""))
+ }, [
+ vue.createElementVNode("view", { class: "title f-row aic" }, [
+ vue.createElementVNode("image", {
+ src: `/static/my/${__props.img}.png`,
+ mode: ""
+ }, null, 8, ["src"]),
+ vue.createTextVNode(
+ " " + vue.toDisplayString(__props.title),
+ 1
+ /* TEXT */
+ )
+ ]),
+ vue.createElementVNode(
+ "view",
+ { class: "num" },
+ vue.toDisplayString(__props.total),
+ 1
+ /* TEXT */
+ )
+ ]),
+ __props.list.length ? (vue.openBlock(), vue.createElementBlock("view", {
+ key: 0,
+ class: "list"
+ }, [
+ vue.createElementVNode(
+ "view",
+ {
+ class: vue.normalizeClass(["box", { "close": __props.list.length > 5 && open2.value }])
+ },
+ [
+ vue.createElementVNode("view", { class: "item_box" }, [
+ (vue.openBlock(true), vue.createElementBlock(
+ vue.Fragment,
+ null,
+ vue.renderList(__props.list, (item, i2) => {
+ return vue.openBlock(), vue.createElementBlock("view", {
+ onClick: ($event) => tolist(item.title),
+ class: "item f-row aic",
+ key: i2
+ }, [
+ vue.createElementVNode(
+ "view",
+ { class: "" },
+ vue.toDisplayString(item.title),
+ 1
+ /* TEXT */
+ ),
+ vue.createElementVNode(
+ "text",
+ null,
+ vue.toDisplayString(item.num),
+ 1
+ /* TEXT */
+ )
+ ], 8, ["onClick"]);
+ }),
+ 128
+ /* KEYED_FRAGMENT */
+ ))
+ ])
+ ],
+ 2
+ /* CLASS */
+ ),
+ vue.withDirectives(vue.createElementVNode(
+ "view",
+ {
+ class: "more",
+ onClick: _cache[1] || (_cache[1] = ($event) => open2.value = !open2.value)
+ },
+ vue.toDisplayString(!open2.value ? "显示更多" : "收起"),
+ 513
+ /* TEXT, NEED_PATCH */
+ ), [
+ [vue.vShow, __props.list.length > 5]
+ ])
+ ])) : vue.createCommentVNode("v-if", true)
+ ])
+ ])
+ ]);
+ };
+ }
+ };
+ const extendCom = /* @__PURE__ */ _export_sfc(_sfc_main$f, [["__scopeId", "data-v-e40cd242"], ["__file", "D:/projects/cxc-szcx-uniapp/bpm/extendCom.vue"]]);
+ const _sfc_main$e = {
+ __name: "todotask",
+ setup(__props) {
+ const store = useStore();
+ onLoad(() => {
+ taskList();
+ taskHistoryList();
+ myApplyProcessList();
+ });
+ const todoArr = vue.ref([]);
+ const todoTotal = vue.ref(0);
+ const taskList = () => {
+ taskListApi({
+ pageNo: 1,
+ pageSize: 4,
+ _t: (/* @__PURE__ */ new Date()).getTime()
+ }).then((res) => {
+ var _a, _b, _c, _d;
+ if (res == null ? void 0 : res.success) {
+ if (((_a = res == null ? void 0 : res.result) == null ? void 0 : _a.total) > 4) {
+ taskListApi({
+ pageNo: 1,
+ pageSize: (_b = res == null ? void 0 : res.result) == null ? void 0 : _b.total,
+ _t: (/* @__PURE__ */ new Date()).getTime()
+ }).then((res1) => {
+ var _a2, _b2;
+ if (res1 == null ? void 0 : res1.success) {
+ todoArr.value = [...todoArr.value, ...handleData((_a2 = res1 == null ? void 0 : res1.result) == null ? void 0 : _a2.records)];
+ todoTotal.value = (_b2 = res1 == null ? void 0 : res1.result) == null ? void 0 : _b2.total;
+ }
+ }).catch((err) => {
+ formatAppLog("log", "at pages/task/todotask.vue:53", "err", err);
+ });
+ } else {
+ todoArr.value = [...todoArr.value, ...handleData((_c = res == null ? void 0 : res.result) == null ? void 0 : _c.records)];
+ todoTotal.value = (_d = res == null ? void 0 : res.result) == null ? void 0 : _d.total;
+ }
+ }
+ }).catch((err) => {
+ formatAppLog("log", "at pages/task/todotask.vue:62", err);
+ });
+ };
+ const doneArr = vue.ref([]);
+ const doneTotal = vue.ref(0);
+ const taskHistoryList = () => {
+ taskHistoryListApi({
+ pageNo: 1,
+ pageSize: 4,
+ _t: (/* @__PURE__ */ new Date()).getTime()
+ }).then((res) => {
+ if (res.success) {
+ if (res.result.total > 4) {
+ taskHistoryListApi({
+ pageNo: 1,
+ pageSize: res.result.total,
+ _t: (/* @__PURE__ */ new Date()).getTime()
+ }).then((res1) => {
+ if (res1.success) {
+ doneArr.value = [...doneArr.value, ...handleData(res1.result.records)];
+ doneTotal.value = res1.result.total;
+ }
+ }).catch((err) => {
+ formatAppLog("log", "at pages/task/todotask.vue:87", err);
+ });
+ } else {
+ doneArr.value = [...doneArr.value, ...handleData(res.result.records)];
+ doneTotal.value = res.result.total;
+ }
+ }
+ }).catch((err) => {
+ formatAppLog("log", "at pages/task/todotask.vue:96", err);
+ });
+ };
+ const selfArr = vue.ref([]);
+ const selfTotal = vue.ref(0);
+ vue.ref([]);
+ const myApplyProcessList = () => {
+ myApplyProcessListApi({
+ pageNo: 1,
+ pageSize: 4,
+ _t: (/* @__PURE__ */ new Date()).getTime()
+ }).then((res) => {
+ if (res.success) {
+ if (res.result.total > 4) {
+ myApplyProcessListApi({
+ pageNo: 1,
+ pageSize: res.result.total,
+ _t: (/* @__PURE__ */ new Date()).getTime()
+ }).then((res1) => {
+ if (res1.success) {
+ selfArr.value = [...selfArr.value, ...handleData(res1.result.records)];
+ selfTotal.value = res1.result.total;
+ }
+ }).catch((err) => {
+ formatAppLog("log", "at pages/task/todotask.vue:122", err);
+ });
+ } else {
+ selfArr.value = [...selfArr.value, ...handleData(res.result.records)];
+ selfTotal.value = res.result.total;
+ }
+ }
+ }).catch((err) => {
+ formatAppLog("log", "at pages/task/todotask.vue:132", err);
+ });
+ };
+ const handleData = (titlearr) => {
+ let titleArr = titlearr.length ? titlearr.map((item) => item.processDefinitionName || item.prcocessDefinitionName) : [];
+ let res = titleArr.reduce((obj, title) => {
+ if (title in obj) {
+ obj[title]++;
+ } else {
+ obj[title] = 1;
+ }
+ return obj;
+ }, {});
+ return Object.entries(res).map(([k, v2]) => ({
+ title: k,
+ num: v2
+ }));
+ };
+ return (_ctx, _cache) => {
+ return vue.openBlock(), vue.createElementBlock(
+ "view",
+ {
+ class: vue.normalizeClass(["content", { "gray": vue.unref(store).isgray == 1 }])
+ },
+ [
+ vue.createVNode(extendCom, {
+ title: "待办事项",
+ img: "todo",
+ list: todoArr.value,
+ total: todoTotal.value
+ }, null, 8, ["list", "total"]),
+ vue.createVNode(extendCom, {
+ title: "已办事项",
+ img: "done",
+ list: doneArr.value,
+ total: doneTotal.value
+ }, null, 8, ["list", "total"]),
+ vue.createVNode(extendCom, {
+ title: "本人发起",
+ img: "self",
+ list: selfArr.value,
+ total: selfTotal.value
+ }, null, 8, ["list", "total"])
+ ],
+ 2
+ /* CLASS */
+ );
+ };
+ }
+ };
+ const PagesTaskTodotask = /* @__PURE__ */ _export_sfc(_sfc_main$e, [["__file", "D:/projects/cxc-szcx-uniapp/pages/task/todotask.vue"]]);
+ const _sfc_main$d = {
+ __name: "safeCom",
+ setup(__props) {
+ const jump = (url) => {
+ beforeJump(url, () => {
+ uni.navigateTo({
+ url
+ });
+ });
+ };
+ return (_ctx, _cache) => {
+ return vue.openBlock(), vue.createElementBlock("view", { class: "list f-row aic jcb" }, [
+ (vue.openBlock(), vue.createElementBlock(
+ vue.Fragment,
+ null,
+ vue.renderList(20, (item, i2) => {
+ return vue.createElementVNode("view", {
+ class: "item",
+ key: i2,
+ onClick: _cache[0] || (_cache[0] = ($event) => jump("/pages/safe/detail"))
+ }, [
+ vue.createElementVNode("view", { class: "" }, [
+ vue.createElementVNode("image", {
+ src: "",
+ mode: ""
+ })
+ ]),
+ vue.createElementVNode("view", { class: "text" }, " 五月天“突然好想你”线上演唱会精彩回放 ")
+ ]);
+ }),
+ 64
+ /* STABLE_FRAGMENT */
+ ))
+ ]);
+ };
+ }
+ };
+ const safeCom = /* @__PURE__ */ _export_sfc(_sfc_main$d, [["__scopeId", "data-v-982fcf41"], ["__file", "D:/projects/cxc-szcx-uniapp/bpm/safeCom.vue"]]);
+ const _sfc_main$c = {
+ __name: "manage",
+ setup(__props) {
+ const store = useStore();
+ const showicon = vue.ref(true);
+ const searchKey = vue.ref("");
+ return (_ctx, _cache) => {
+ const _component_uni_icons = resolveEasycom(vue.resolveDynamicComponent("uni-icons"), __easycom_1$1);
+ return vue.openBlock(), vue.createElementBlock(
+ "view",
+ {
+ class: vue.normalizeClass(["content", { "gray": vue.unref(store).isgray == 1 }])
+ },
+ [
+ vue.createVNode(customNav, null, {
+ default: vue.withCtx(() => [
+ vue.createElementVNode("view", { class: "nav_box f-row aic jcb" }, [
+ vue.createElementVNode("view", {
+ class: "back f-row aic",
+ onClick: _cache[0] || (_cache[0] = (...args) => _ctx.back && _ctx.back(...args))
+ }, [
+ vue.createVNode(_component_uni_icons, {
+ type: "left",
+ size: "20",
+ color: "#fff"
+ })
+ ]),
+ vue.createElementVNode("view", { class: "search f-row aic" }, [
+ vue.withDirectives(vue.createElementVNode(
+ "input",
+ {
+ type: "text",
+ "onUpdate:modelValue": _cache[1] || (_cache[1] = ($event) => searchKey.value = $event),
+ onConfirm: _cache[2] || (_cache[2] = (...args) => _ctx.search && _ctx.search(...args)),
+ onBlur: _cache[3] || (_cache[3] = ($event) => showicon.value = !searchKey.value),
+ onFocus: _cache[4] || (_cache[4] = ($event) => showicon.value = false)
+ },
+ null,
+ 544
+ /* NEED_HYDRATION, NEED_PATCH */
+ ), [
+ [vue.vModelText, searchKey.value]
+ ]),
+ showicon.value ? (vue.openBlock(), vue.createElementBlock("view", {
+ key: 0,
+ class: "f-row aic"
+ }, [
+ vue.createElementVNode("image", {
+ src: "/static/search.png",
+ mode: ""
+ }),
+ vue.createElementVNode("text", null, "搜索")
+ ])) : vue.createCommentVNode("v-if", true)
+ ])
+ ])
+ ]),
+ _: 1
+ /* STABLE */
+ }),
+ vue.createElementVNode("view", { class: "" }, [
+ vue.createVNode(safeCom)
+ ])
+ ],
+ 2
+ /* CLASS */
+ );
+ };
+ }
+ };
+ const PagesSafeManage = /* @__PURE__ */ _export_sfc(_sfc_main$c, [["__scopeId", "data-v-dc2f4615"], ["__file", "D:/projects/cxc-szcx-uniapp/pages/safe/manage.vue"]]);
+ const _sfc_main$b = {
+ __name: "index",
+ setup(__props) {
+ const store = useStore();
+ const shishiArr = vue.ref([]);
+ const productArr = vue.ref([]);
+ onLoad((options) => {
+ shishiArr.value = JSON.parse(options.shishi);
+ productArr.value = JSON.parse(options.product);
+ });
+ return (_ctx, _cache) => {
+ return vue.openBlock(), vue.createElementBlock(
+ "view",
+ {
+ class: vue.normalizeClass(["f-col", "aic", { "gray": vue.unref(store).isgray == 1 }])
+ },
+ [
+ vue.createVNode(dataCom, {
+ title: "实时输差",
+ list: shishiArr.value
+ }, null, 8, ["list"]),
+ vue.createVNode(dataCom, {
+ title: "偏远计量点",
+ list: shishiArr.value
+ }, null, 8, ["list"]),
+ vue.createVNode(dataCom, {
+ title: "生产实时数据",
+ list: productArr.value
+ }, null, 8, ["list"])
+ ],
+ 2
+ /* CLASS */
+ );
+ };
+ }
+ };
+ const PagesProductIndex = /* @__PURE__ */ _export_sfc(_sfc_main$b, [["__file", "D:/projects/cxc-szcx-uniapp/pages/product/index.vue"]]);
+ const en = {
+ "uni-load-more.contentdown": "Pull up to show more",
+ "uni-load-more.contentrefresh": "loading...",
+ "uni-load-more.contentnomore": "No more data"
+ };
+ const zhHans = {
+ "uni-load-more.contentdown": "上拉显示更多",
+ "uni-load-more.contentrefresh": "正在加载...",
+ "uni-load-more.contentnomore": "没有更多数据了"
+ };
+ const zhHant = {
+ "uni-load-more.contentdown": "上拉顯示更多",
+ "uni-load-more.contentrefresh": "正在加載...",
+ "uni-load-more.contentnomore": "沒有更多數據了"
+ };
+ const messages = {
+ en,
+ "zh-Hans": zhHans,
+ "zh-Hant": zhHant
+ };
+ let platform;
+ setTimeout(() => {
+ platform = uni.getSystemInfoSync().platform;
+ }, 16);
+ const {
+ t
+ } = initVueI18n(messages);
+ const _sfc_main$a = {
+ name: "UniLoadMore",
+ emits: ["clickLoadMore"],
+ props: {
+ status: {
+ // 上拉的状态:more-loading前;loading-loading中;noMore-没有更多了
+ type: String,
+ default: "more"
+ },
+ showIcon: {
+ type: Boolean,
+ default: true
+ },
+ iconType: {
+ type: String,
+ default: "auto"
+ },
+ iconSize: {
+ type: Number,
+ default: 24
+ },
+ color: {
+ type: String,
+ default: "#777777"
+ },
+ contentText: {
+ type: Object,
+ default() {
+ return {
+ contentdown: "",
+ contentrefresh: "",
+ contentnomore: ""
+ };
+ }
+ },
+ showText: {
+ type: Boolean,
+ default: true
+ }
+ },
+ data() {
+ return {
+ webviewHide: false,
+ platform,
+ imgBase64: ""
+ };
+ },
+ computed: {
+ iconSnowWidth() {
+ return (Math.floor(this.iconSize / 24) || 1) * 2;
+ },
+ contentdownText() {
+ return this.contentText.contentdown || t("uni-load-more.contentdown");
+ },
+ contentrefreshText() {
+ return this.contentText.contentrefresh || t("uni-load-more.contentrefresh");
+ },
+ contentnomoreText() {
+ return this.contentText.contentnomore || t("uni-load-more.contentnomore");
+ }
+ },
+ mounted() {
+ var pages2 = getCurrentPages();
+ var page = pages2[pages2.length - 1];
+ var currentWebview = page.$getAppWebview();
+ currentWebview.addEventListener("hide", () => {
+ this.webviewHide = true;
+ });
+ currentWebview.addEventListener("show", () => {
+ this.webviewHide = false;
+ });
+ },
+ methods: {
+ onClick() {
+ this.$emit("clickLoadMore", {
+ detail: {
+ status: this.status
+ }
+ });
+ }
+ }
+ };
+ function _sfc_render$2(_ctx, _cache, $props, $setup, $data, $options) {
+ return vue.openBlock(), vue.createElementBlock("view", {
+ class: "uni-load-more",
+ onClick: _cache[0] || (_cache[0] = (...args) => $options.onClick && $options.onClick(...args))
+ }, [
+ !$data.webviewHide && ($props.iconType === "circle" || $props.iconType === "auto" && $data.platform === "android") && $props.status === "loading" && $props.showIcon ? (vue.openBlock(), vue.createElementBlock(
+ "view",
+ {
+ key: 0,
+ style: vue.normalizeStyle({ width: $props.iconSize + "px", height: $props.iconSize + "px" }),
+ class: "uni-load-more__img uni-load-more__img--android-MP"
+ },
+ [
+ vue.createElementVNode(
+ "view",
+ {
+ class: "uni-load-more__img-icon",
+ style: vue.normalizeStyle({ borderTopColor: $props.color, borderTopWidth: $props.iconSize / 12 })
+ },
+ null,
+ 4
+ /* STYLE */
+ ),
+ vue.createElementVNode(
+ "view",
+ {
+ class: "uni-load-more__img-icon",
+ style: vue.normalizeStyle({ borderTopColor: $props.color, borderTopWidth: $props.iconSize / 12 })
+ },
+ null,
+ 4
+ /* STYLE */
+ ),
+ vue.createElementVNode(
+ "view",
+ {
+ class: "uni-load-more__img-icon",
+ style: vue.normalizeStyle({ borderTopColor: $props.color, borderTopWidth: $props.iconSize / 12 })
+ },
+ null,
+ 4
+ /* STYLE */
+ )
+ ],
+ 4
+ /* STYLE */
+ )) : !$data.webviewHide && $props.status === "loading" && $props.showIcon ? (vue.openBlock(), vue.createElementBlock(
+ "view",
+ {
+ key: 1,
+ style: vue.normalizeStyle({ width: $props.iconSize + "px", height: $props.iconSize + "px" }),
+ class: "uni-load-more__img uni-load-more__img--ios-H5"
+ },
+ [
+ vue.createElementVNode("image", {
+ src: $data.imgBase64,
+ mode: "widthFix"
+ }, null, 8, ["src"])
+ ],
+ 4
+ /* STYLE */
+ )) : vue.createCommentVNode("v-if", true),
+ $props.showText ? (vue.openBlock(), vue.createElementBlock(
+ "text",
+ {
+ key: 2,
+ class: "uni-load-more__text",
+ style: vue.normalizeStyle({ color: $props.color })
+ },
+ vue.toDisplayString($props.status === "more" ? $options.contentdownText : $props.status === "loading" ? $options.contentrefreshText : $options.contentnomoreText),
+ 5
+ /* TEXT, STYLE */
+ )) : vue.createCommentVNode("v-if", true)
+ ]);
+ }
+ const __easycom_0$1 = /* @__PURE__ */ _export_sfc(_sfc_main$a, [["render", _sfc_render$2], ["__scopeId", "data-v-9245e42c"], ["__file", "D:/projects/cxc-szcx-uniapp/uni_modules/uni-load-more/components/uni-load-more/uni-load-more.vue"]]);
const dataPicker = {
props: {
localdata: {
@@ -17708,6 +19063,17 @@ ${i3}
},
setup(__props) {
const props = __props;
+ const imageValue = vue.ref([]);
+ const imageStyles = {
+ width: 64,
+ height: 64,
+ border: {
+ color: "#dce7e1",
+ width: 2,
+ style: "dashed",
+ radius: "2px"
+ }
+ };
const info = vue.ref({});
const qjQueryById = () => {
qjQueryByIdApi({
@@ -17715,6 +19081,16 @@ ${i3}
}).then((res) => {
if (res.success) {
info.value = res.result.records[0];
+ imageValue.value = info.value.path.split(",").map((path) => {
+ const name2 = path.split("/").pop();
+ const extname = name2.split(".").pop();
+ return {
+ name: name2,
+ extname,
+ url: imgUrl(path)
+ };
+ });
+ formatAppLog("log", "at bpm/leaveApplication/index.vue:154", "---", imageValue.value);
}
});
};
@@ -17743,6 +19119,7 @@ ${i3}
extActFlowData();
});
return (_ctx, _cache) => {
+ const _component_uni_file_picker = resolveEasycom(vue.resolveDynamicComponent("uni-file-picker"), __easycom_0$2);
return vue.openBlock(), vue.createElementBlock(
vue.Fragment,
null,
@@ -17815,7 +19192,7 @@ ${i3}
vue.createElementVNode(
"text",
null,
- vue.toDisplayString(info.value.qjdays),
+ vue.toDisplayString(info.value.days),
1
/* TEXT */
)
@@ -17849,6 +19226,14 @@ ${i3}
1
/* TEXT */
)
+ ]),
+ vue.createElementVNode("view", { class: "info f-row aic jcb" }, [
+ vue.createElementVNode("view", null, " 附件: "),
+ vue.createVNode(_component_uni_file_picker, {
+ modelValue: imageValue.value,
+ "onUpdate:modelValue": _cache[0] || (_cache[0] = ($event) => imageValue.value = $event),
+ "image-styles": imageStyles
+ }, null, 8, ["modelValue"])
])
])
]),
diff --git a/unpackage/dist/dev/app-plus/app.css b/unpackage/dist/dev/app-plus/app.css
index 92762f7..ffdb580 100644
--- a/unpackage/dist/dev/app-plus/app.css
+++ b/unpackage/dist/dev/app-plus/app.css
@@ -49,6 +49,282 @@
.aic {
align-items: center;
}
+/**
+ * 这里是uni-app内置的常用样式变量
+ *
+ * uni-app 官方扩展插件及插件市场(https://ext.dcloud.net.cn)上很多三方插件均使用了这些样式变量
+ * 如果你是插件开发者,建议你使用scss预处理,并在插件代码中直接使用这些变量(无需 import 这个文件),方便用户通过搭积木的方式开发整体风格一致的App
+ *
+ */
+/**
+ * 如果你是App开发者(插件使用者),你可以通过修改这些变量来定制自己的插件主题,实现自定义主题功能
+ *
+ * 如果你的项目同样使用了scss预处理,你也可以直接在你的 scss 代码中使用如下变量,同时无需 import 这个文件
+ */
+/* 颜色变量 */
+/* 行为相关颜色 */
+/* 文字基本颜色 */
+/* 背景颜色 */
+/* 边框颜色 */
+/* 尺寸变量 */
+/* 文字尺寸 */
+/* 图片尺寸 */
+/* Border Radius */
+/* 水平间距 */
+/* 垂直间距 */
+/* 透明度 */
+/* 文章场景相关 */
+.uni-file-picker__container[data-v-bdfc07e0] {
+ display: flex;
+ box-sizing: border-box;
+ flex-wrap: wrap;
+ margin: -5px;
+}
+.file-picker__box[data-v-bdfc07e0] {
+ position: relative;
+ width: 33.3%;
+ height: 0;
+ padding-top: 33.33%;
+ box-sizing: border-box;
+}
+.file-picker__box-content[data-v-bdfc07e0] {
+ position: absolute;
+ top: 0;
+ right: 0;
+ bottom: 0;
+ left: 0;
+ margin: 5px;
+ border: 1px #eee solid;
+ border-radius: 5px;
+ overflow: hidden;
+}
+.file-picker__progress[data-v-bdfc07e0] {
+ position: absolute;
+ bottom: 0;
+ left: 0;
+ right: 0;
+ /* border: 1px red solid; */
+ z-index: 2;
+}
+.file-picker__progress-item[data-v-bdfc07e0] {
+ width: 100%;
+}
+.file-picker__mask[data-v-bdfc07e0] {
+ display: flex;
+ justify-content: center;
+ align-items: center;
+ position: absolute;
+ right: 0;
+ top: 0;
+ bottom: 0;
+ left: 0;
+ color: #fff;
+ font-size: 12px;
+ background-color: rgba(0, 0, 0, 0.4);
+}
+.file-image[data-v-bdfc07e0] {
+ width: 100%;
+ height: 100%;
+}
+.is-add[data-v-bdfc07e0] {
+ display: flex;
+ align-items: center;
+ justify-content: center;
+}
+.icon-add[data-v-bdfc07e0] {
+ width: 50px;
+ height: 5px;
+ background-color: #f1f1f1;
+ border-radius: 2px;
+}
+.rotate[data-v-bdfc07e0] {
+ position: absolute;
+ transform: rotate(90deg);
+}
+.icon-del-box[data-v-bdfc07e0] {
+ display: flex;
+ align-items: center;
+ justify-content: center;
+ position: absolute;
+ top: 3px;
+ right: 3px;
+ height: 26px;
+ width: 26px;
+ border-radius: 50%;
+ background-color: rgba(0, 0, 0, 0.5);
+ z-index: 2;
+ transform: rotate(-45deg);
+}
+.icon-del[data-v-bdfc07e0] {
+ width: 15px;
+ height: 2px;
+ background-color: #fff;
+ border-radius: 2px;
+}
+/**
+ * 这里是uni-app内置的常用样式变量
+ *
+ * uni-app 官方扩展插件及插件市场(https://ext.dcloud.net.cn)上很多三方插件均使用了这些样式变量
+ * 如果你是插件开发者,建议你使用scss预处理,并在插件代码中直接使用这些变量(无需 import 这个文件),方便用户通过搭积木的方式开发整体风格一致的App
+ *
+ */
+/**
+ * 如果你是App开发者(插件使用者),你可以通过修改这些变量来定制自己的插件主题,实现自定义主题功能
+ *
+ * 如果你的项目同样使用了scss预处理,你也可以直接在你的 scss 代码中使用如下变量,同时无需 import 这个文件
+ */
+/* 颜色变量 */
+/* 行为相关颜色 */
+/* 文字基本颜色 */
+/* 背景颜色 */
+/* 边框颜色 */
+/* 尺寸变量 */
+/* 文字尺寸 */
+/* 图片尺寸 */
+/* Border Radius */
+/* 水平间距 */
+/* 垂直间距 */
+/* 透明度 */
+/* 文章场景相关 */
+.uni-file-picker__files[data-v-a54939c6] {
+ display: flex;
+ flex-direction: column;
+ justify-content: flex-start;
+}
+.uni-file-picker__lists[data-v-a54939c6] {
+ position: relative;
+ margin-top: 5px;
+ overflow: hidden;
+}
+.file-picker__mask[data-v-a54939c6] {
+ display: flex;
+ justify-content: center;
+ align-items: center;
+ position: absolute;
+ right: 0;
+ top: 0;
+ bottom: 0;
+ left: 0;
+ color: #fff;
+ font-size: 14px;
+ background-color: rgba(0, 0, 0, 0.4);
+}
+.uni-file-picker__lists-box[data-v-a54939c6] {
+ position: relative;
+}
+.uni-file-picker__item[data-v-a54939c6] {
+ display: flex;
+ align-items: center;
+ padding: 8px 10px;
+ padding-right: 5px;
+ padding-left: 10px;
+}
+.files-border[data-v-a54939c6] {
+ border-top: 1px #eee solid;
+}
+.files__name[data-v-a54939c6] {
+ flex: 1;
+ font-size: 14px;
+ color: #666;
+ margin-right: 25px;
+ word-break: break-all;
+ word-wrap: break-word;
+}
+.icon-files[data-v-a54939c6] {
+ position: static;
+ background-color: initial;
+}
+.is-list-card[data-v-a54939c6] {
+ border: 1px #eee solid;
+ margin-bottom: 5px;
+ border-radius: 5px;
+ box-shadow: 0 0 2px 0px rgba(0, 0, 0, 0.1);
+ padding: 5px;
+}
+.files__image[data-v-a54939c6] {
+ width: 40px;
+ height: 40px;
+ margin-right: 10px;
+}
+.header-image[data-v-a54939c6] {
+ width: 100%;
+ height: 100%;
+}
+.is-text-box[data-v-a54939c6] {
+ border: 1px #eee solid;
+ border-radius: 5px;
+}
+.is-text-image[data-v-a54939c6] {
+ width: 25px;
+ height: 25px;
+ margin-left: 5px;
+}
+.rotate[data-v-a54939c6] {
+ position: absolute;
+ transform: rotate(90deg);
+}
+.icon-del-box[data-v-a54939c6] {
+ display: flex;
+ margin: auto 0;
+ align-items: center;
+ justify-content: center;
+ position: absolute;
+ top: 0px;
+ bottom: 0;
+ right: 5px;
+ height: 26px;
+ width: 26px;
+ z-index: 2;
+ transform: rotate(-45deg);
+}
+.icon-del[data-v-a54939c6] {
+ width: 15px;
+ height: 1px;
+ background-color: #333;
+}
+
+.uni-file-picker[data-v-6223573f] {
+
+ box-sizing: border-box;
+ overflow: hidden;
+ width: 100%;
+
+ flex: 1;
+}
+.uni-file-picker__header[data-v-6223573f] {
+ padding-top: 5px;
+ padding-bottom: 10px;
+
+ display: flex;
+
+ justify-content: space-between;
+}
+.file-title[data-v-6223573f] {
+ font-size: 14px;
+ color: #333;
+}
+.file-count[data-v-6223573f] {
+ font-size: 14px;
+ color: #999;
+}
+.is-add[data-v-6223573f] {
+
+ display: flex;
+
+ align-items: center;
+ justify-content: center;
+}
+.icon-add[data-v-6223573f] {
+ width: 50px;
+ height: 5px;
+ background-color: #f1f1f1;
+ border-radius: 2px;
+}
+.rotate[data-v-6223573f] {
+ position: absolute;
+ transform: rotate(90deg);
+}
+
/**
* 这里是uni-app内置的常用样式变量
*
diff --git a/unpackage/dist/dev/app-plus/pages/leave/application.css b/unpackage/dist/dev/app-plus/pages/leave/application.css
index 928ce8c..acb1fba 100644
--- a/unpackage/dist/dev/app-plus/pages/leave/application.css
+++ b/unpackage/dist/dev/app-plus/pages/leave/application.css
@@ -530,6 +530,282 @@
text-decoration: none;
text-align: center;
}
+/**
+ * 这里是uni-app内置的常用样式变量
+ *
+ * uni-app 官方扩展插件及插件市场(https://ext.dcloud.net.cn)上很多三方插件均使用了这些样式变量
+ * 如果你是插件开发者,建议你使用scss预处理,并在插件代码中直接使用这些变量(无需 import 这个文件),方便用户通过搭积木的方式开发整体风格一致的App
+ *
+ */
+/**
+ * 如果你是App开发者(插件使用者),你可以通过修改这些变量来定制自己的插件主题,实现自定义主题功能
+ *
+ * 如果你的项目同样使用了scss预处理,你也可以直接在你的 scss 代码中使用如下变量,同时无需 import 这个文件
+ */
+/* 颜色变量 */
+/* 行为相关颜色 */
+/* 文字基本颜色 */
+/* 背景颜色 */
+/* 边框颜色 */
+/* 尺寸变量 */
+/* 文字尺寸 */
+/* 图片尺寸 */
+/* Border Radius */
+/* 水平间距 */
+/* 垂直间距 */
+/* 透明度 */
+/* 文章场景相关 */
+.uni-file-picker__container[data-v-bdfc07e0] {
+ display: flex;
+ box-sizing: border-box;
+ flex-wrap: wrap;
+ margin: -5px;
+}
+.file-picker__box[data-v-bdfc07e0] {
+ position: relative;
+ width: 33.3%;
+ height: 0;
+ padding-top: 33.33%;
+ box-sizing: border-box;
+}
+.file-picker__box-content[data-v-bdfc07e0] {
+ position: absolute;
+ top: 0;
+ right: 0;
+ bottom: 0;
+ left: 0;
+ margin: 5px;
+ border: 1px #eee solid;
+ border-radius: 5px;
+ overflow: hidden;
+}
+.file-picker__progress[data-v-bdfc07e0] {
+ position: absolute;
+ bottom: 0;
+ left: 0;
+ right: 0;
+ /* border: 1px red solid; */
+ z-index: 2;
+}
+.file-picker__progress-item[data-v-bdfc07e0] {
+ width: 100%;
+}
+.file-picker__mask[data-v-bdfc07e0] {
+ display: flex;
+ justify-content: center;
+ align-items: center;
+ position: absolute;
+ right: 0;
+ top: 0;
+ bottom: 0;
+ left: 0;
+ color: #fff;
+ font-size: 12px;
+ background-color: rgba(0, 0, 0, 0.4);
+}
+.file-image[data-v-bdfc07e0] {
+ width: 100%;
+ height: 100%;
+}
+.is-add[data-v-bdfc07e0] {
+ display: flex;
+ align-items: center;
+ justify-content: center;
+}
+.icon-add[data-v-bdfc07e0] {
+ width: 50px;
+ height: 5px;
+ background-color: #f1f1f1;
+ border-radius: 2px;
+}
+.rotate[data-v-bdfc07e0] {
+ position: absolute;
+ transform: rotate(90deg);
+}
+.icon-del-box[data-v-bdfc07e0] {
+ display: flex;
+ align-items: center;
+ justify-content: center;
+ position: absolute;
+ top: 3px;
+ right: 3px;
+ height: 26px;
+ width: 26px;
+ border-radius: 50%;
+ background-color: rgba(0, 0, 0, 0.5);
+ z-index: 2;
+ transform: rotate(-45deg);
+}
+.icon-del[data-v-bdfc07e0] {
+ width: 15px;
+ height: 2px;
+ background-color: #fff;
+ border-radius: 2px;
+}
+/**
+ * 这里是uni-app内置的常用样式变量
+ *
+ * uni-app 官方扩展插件及插件市场(https://ext.dcloud.net.cn)上很多三方插件均使用了这些样式变量
+ * 如果你是插件开发者,建议你使用scss预处理,并在插件代码中直接使用这些变量(无需 import 这个文件),方便用户通过搭积木的方式开发整体风格一致的App
+ *
+ */
+/**
+ * 如果你是App开发者(插件使用者),你可以通过修改这些变量来定制自己的插件主题,实现自定义主题功能
+ *
+ * 如果你的项目同样使用了scss预处理,你也可以直接在你的 scss 代码中使用如下变量,同时无需 import 这个文件
+ */
+/* 颜色变量 */
+/* 行为相关颜色 */
+/* 文字基本颜色 */
+/* 背景颜色 */
+/* 边框颜色 */
+/* 尺寸变量 */
+/* 文字尺寸 */
+/* 图片尺寸 */
+/* Border Radius */
+/* 水平间距 */
+/* 垂直间距 */
+/* 透明度 */
+/* 文章场景相关 */
+.uni-file-picker__files[data-v-a54939c6] {
+ display: flex;
+ flex-direction: column;
+ justify-content: flex-start;
+}
+.uni-file-picker__lists[data-v-a54939c6] {
+ position: relative;
+ margin-top: 5px;
+ overflow: hidden;
+}
+.file-picker__mask[data-v-a54939c6] {
+ display: flex;
+ justify-content: center;
+ align-items: center;
+ position: absolute;
+ right: 0;
+ top: 0;
+ bottom: 0;
+ left: 0;
+ color: #fff;
+ font-size: 14px;
+ background-color: rgba(0, 0, 0, 0.4);
+}
+.uni-file-picker__lists-box[data-v-a54939c6] {
+ position: relative;
+}
+.uni-file-picker__item[data-v-a54939c6] {
+ display: flex;
+ align-items: center;
+ padding: 8px 10px;
+ padding-right: 5px;
+ padding-left: 10px;
+}
+.files-border[data-v-a54939c6] {
+ border-top: 1px #eee solid;
+}
+.files__name[data-v-a54939c6] {
+ flex: 1;
+ font-size: 14px;
+ color: #666;
+ margin-right: 25px;
+ word-break: break-all;
+ word-wrap: break-word;
+}
+.icon-files[data-v-a54939c6] {
+ position: static;
+ background-color: initial;
+}
+.is-list-card[data-v-a54939c6] {
+ border: 1px #eee solid;
+ margin-bottom: 5px;
+ border-radius: 5px;
+ box-shadow: 0 0 2px 0px rgba(0, 0, 0, 0.1);
+ padding: 5px;
+}
+.files__image[data-v-a54939c6] {
+ width: 40px;
+ height: 40px;
+ margin-right: 10px;
+}
+.header-image[data-v-a54939c6] {
+ width: 100%;
+ height: 100%;
+}
+.is-text-box[data-v-a54939c6] {
+ border: 1px #eee solid;
+ border-radius: 5px;
+}
+.is-text-image[data-v-a54939c6] {
+ width: 25px;
+ height: 25px;
+ margin-left: 5px;
+}
+.rotate[data-v-a54939c6] {
+ position: absolute;
+ transform: rotate(90deg);
+}
+.icon-del-box[data-v-a54939c6] {
+ display: flex;
+ margin: auto 0;
+ align-items: center;
+ justify-content: center;
+ position: absolute;
+ top: 0px;
+ bottom: 0;
+ right: 5px;
+ height: 26px;
+ width: 26px;
+ z-index: 2;
+ transform: rotate(-45deg);
+}
+.icon-del[data-v-a54939c6] {
+ width: 15px;
+ height: 1px;
+ background-color: #333;
+}
+
+.uni-file-picker[data-v-6223573f] {
+
+ box-sizing: border-box;
+ overflow: hidden;
+ width: 100%;
+
+ flex: 1;
+}
+.uni-file-picker__header[data-v-6223573f] {
+ padding-top: 5px;
+ padding-bottom: 10px;
+
+ display: flex;
+
+ justify-content: space-between;
+}
+.file-title[data-v-6223573f] {
+ font-size: 14px;
+ color: #333;
+}
+.file-count[data-v-6223573f] {
+ font-size: 14px;
+ color: #999;
+}
+.is-add[data-v-6223573f] {
+
+ display: flex;
+
+ align-items: center;
+ justify-content: center;
+}
+.icon-add[data-v-6223573f] {
+ width: 50px;
+ height: 5px;
+ background-color: #f1f1f1;
+ border-radius: 2px;
+}
+.rotate[data-v-6223573f] {
+ position: absolute;
+ transform: rotate(90deg);
+}
+
/**
* 这里是uni-app内置的常用样式变量
*
@@ -1044,22 +1320,4 @@ body {
.form .choosed[data-v-f12ae642] {
font-size: 0.875rem;
color: #333333;
-}
-.reason[data-v-f12ae642] {
- background-color: #fff;
- margin-top: 0.625rem;
- height: 9.0625rem;
- padding: 0.9375rem;
-}
-.reason .title[data-v-f12ae642] {
- font-size: 0.875rem;
- color: #333333;
-}
-.reason uni-textarea[data-v-f12ae642] {
- width: 100%;
- margin-top: 0.625rem;
-}
-.lines[data-v-f12ae642] {
- height: 0.625rem;
- background-color: #F8F8F8;
}
\ No newline at end of file