@ued_fpi/data-visual
Version:
<br /> <br /> <div style="text-align:center"> <b style="font-size:30px">@ued_fpi/data-visual</b> <p>基于Vite4+TypeScript的Vue3大屏组件库开发框架</p> <img style="display:inline" src="https://img.shields.io/npm/v/@ued_fpi/data-visual" />
92 lines (87 loc) • 3.86 kB
JavaScript
;
Object.defineProperties(exports, { __esModule: { value: true }, [Symbol.toStringTag]: { value: 'Module' } });
const intelligentLight = require('./images/intelligent-light.png.js');
const intelligent = require('./images/intelligent.png.js');
const monitorLight = require('./images/monitor-light.png.js');
const monitor = require('./images/monitor.png.js');
const otherLight = require('./images/other-light.png.js');
const other = require('./images/other.png.js');
const reportLight = require('./images/report-light.png.js');
const report = require('./images/report.png.js');
const vue = require('vue');
const dayjs = require('dayjs');
const request = require('../../service/request.js');
const utils = require('../../../utils.js');
const hooks = require('../../utils/hooks.js');
const _hoisted_1 = { class: "dv-ipes-event-month" };
const _hoisted_2 = ["src"];
const _hoisted_3 = { class: "info" };
const _hoisted_4 = { class: "title" };
const _hoisted_5 = { class: "bottom" };
const _hoisted_6 = { class: "value" };
const _hoisted_7 = /* @__PURE__ */ vue.createElementVNode("span", { class: "divider" }, "/", -1);
const _hoisted_8 = { class: "percent" };
const __default__ = {
name: "DvIpesEventMonth",
title: "本月新增事件"
};
const _sfc_main = /* @__PURE__ */ vue.defineComponent({
...__default__,
props: {
categoryCode: { default: "sec_control" },
beginTime: { default: +dayjs().startOf("M") },
endTime: { default: +dayjs() }
},
setup(__props) {
const props = __props;
const { isDark } = utils.useThemeHook();
const eventData = vue.ref();
const getImg = (key) => {
return new URL((/* #__PURE__ */ Object.assign({"./images/intelligent-light.png": intelligentLight.default,"./images/intelligent.png": intelligent.default,"./images/monitor-light.png": monitorLight.default,"./images/monitor.png": monitor.default,"./images/other-light.png": otherLight.default,"./images/other.png": other.default,"./images/report-light.png": reportLight.default,"./images/report.png": report.default}))[`./images/${key}.png`], self.location).href;
};
const iconArr = ["monitor", "intelligent", "report", "other"];
async function getData() {
try {
const { data } = await request.default({
method: "get",
url: "/ipes-data-aggregation-server/api/v1/common/task-charge",
params: props
});
eventData.value = data.map((e, index) => {
return Object.assign(e, {
key: index > 3 ? iconArr[3] : iconArr[index]
});
});
} catch (error) {
console.log(error);
}
}
vue.onMounted(() => {
getData();
});
hooks.setIntervalData(getData, 5 * 60 * 1e3);
return (_ctx, _cache) => {
return vue.openBlock(), vue.createElementBlock("div", _hoisted_1, [
(vue.openBlock(true), vue.createElementBlock(vue.Fragment, null, vue.renderList(eventData.value, (item) => {
return vue.openBlock(), vue.createElementBlock("div", {
key: item.key,
class: vue.normalizeClass(["security-box", item.key])
}, [
vue.createElementVNode("img", {
src: getImg(item.key + (vue.unref(isDark) ? "" : "-light"))
}, null, 8, _hoisted_2),
vue.createElementVNode("div", _hoisted_3, [
vue.createElementVNode("div", _hoisted_4, vue.toDisplayString(item.taskTypeName), 1),
vue.createElementVNode("div", _hoisted_5, [
vue.createElementVNode("span", _hoisted_6, vue.toDisplayString(item.curMonthIncreaseNum), 1),
_hoisted_7,
vue.createElementVNode("span", _hoisted_8, vue.toDisplayString(item.disposeRate), 1)
])
])
], 2);
}), 128))
]);
};
}
});
exports.default = _sfc_main;