UNPKG

@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" />

175 lines (172 loc) 8.18 kB
import { defineComponent, computed, reactive, toRefs, onMounted, watch, openBlock, createElementBlock, normalizeClass, createElementVNode, Fragment, renderList, normalizeStyle, toDisplayString, unref, createBlock, withCtx, createCommentVNode } from 'vue'; import { FpiElRolling } from '@ued_fpi/element-plus-expand'; import dayjs from 'dayjs'; import '../common/BasicNoData/index.mjs'; import { useThemeHook } from '../../../utils.mjs'; import { getSingleCityRank } from './api/index.mjs'; import _BasicNoData from '../common/BasicNoData/index.vue.mjs'; const _hoisted_1 = ["src"]; const clsfix = "dv-aims-same-and-current-period-rank"; const _sfc_main = /* @__PURE__ */ defineComponent({ __name: "index", props: { isUseBuiltInApi: { type: Boolean, default: true }, apiParams: { default: () => ({ gridCode: "0101000000", factorCode: "cieq", time: dayjs().subtract(1, "hour").valueOf(), timeType: "year" }) }, data: {} }, setup(__props) { const props = __props; const { isDark } = useThemeHook(); const listConfig = computed(() => { return [ { name: "区域", prop: "groupName", width: "110px" }, { name: "本期", prop: "rank", width: "82px" }, { name: "同期", prop: "samePeriodRank", width: "82px" }, { name: "改善幅度", prop: "change", width: "100px" } ]; }); const state = reactive({ listData: [], scrollTime: 5 }); const { listData, scrollTime } = toRefs(state); const handlerData = (data) => { state.listData = data.map((item) => { let change = ""; let changeColor = ""; let changeDarkImage = ""; let changeWhiteImage = ""; const changeNum = -Number(item.change); if (changeNum > 0) { change = `+${changeNum}`; changeColor = "var(--dv-color-success)"; changeDarkImage = new URL("", self.location); changeWhiteImage = new URL("", self.location); } else if (changeNum < 0) { change = `${changeNum}`; changeColor = "var(--dv-color-danger)"; changeDarkImage = new URL("", self.location); changeWhiteImage = new URL("", self.location); } else if (changeNum === 0) { change = "持平"; changeColor = "var(--dv-color-index)"; changeDarkImage = new URL("", self.location); changeWhiteImage = new URL("", self.location); } else { change = "--"; changeColor = "var(--dv-color-text-primary)"; } return { ...item, change, changeColor, changeDarkImage, changeWhiteImage }; }); state.scrollTime = state.listData.length * 1.25; }; const fetchData = () => { getSingleCityRank(props.apiParams).then((res) => { if (res.data) { handlerData(res.data); } }); }; onMounted(() => { if (props.isUseBuiltInApi) fetchData(); }); watch(() => props.apiParams, () => { if (props.isUseBuiltInApi) fetchData(); }, { deep: true }); watch(() => props.data, () => { if (props.data && !props.isUseBuiltInApi) handlerData(props.data); }, { deep: false, immediate: true }); return (_ctx, _cache) => { return openBlock(), createElementBlock("div", { class: normalizeClass(`${clsfix}-container`) }, [ createElementVNode("ul", { class: normalizeClass(`${clsfix}-list-header`) }, [ (openBlock(true), createElementBlock(Fragment, null, renderList(listConfig.value, (item) => { return openBlock(), createElementBlock("li", { key: item.prop, style: normalizeStyle({ width: item.width }) }, toDisplayString(item.name), 5); }), 128)) ], 2), unref(listData) && unref(listData).length ? (openBlock(), createBlock(unref(FpiElRolling), { key: 0, style: { "height": "calc(100% - 32px)" }, direction: "y", "scroll-able": "", time: unref(scrollTime) }, { default: withCtx(() => [ createElementVNode("ul", { class: normalizeClass(`${clsfix}-list-content`) }, [ (openBlock(true), createElementBlock(Fragment, null, renderList(unref(listData), (item, index) => { return openBlock(), createElementBlock("li", { key: index }, [ (openBlock(true), createElementBlock(Fragment, null, renderList(listConfig.value, (innerItem) => { return openBlock(), createElementBlock("div", { key: `${item.groupName}_${innerItem.prop}`, style: normalizeStyle({ width: innerItem.width }) }, [ innerItem.prop !== "change" ? (openBlock(), createElementBlock("div", { key: 0, class: normalizeClass(innerItem.prop) }, toDisplayString(item[innerItem.prop]), 3)) : (openBlock(), createElementBlock("div", { key: 1, class: normalizeClass(innerItem.prop) }, [ createElementVNode("span", { class: "text", style: normalizeStyle({ color: item.changeColor }) }, toDisplayString(item.change), 5), item.change !== "--" ? (openBlock(), createElementBlock("img", { key: 0, src: unref(isDark) ? item.changeDarkImage : item.changeWhiteImage }, null, 8, _hoisted_1)) : createCommentVNode("", true) ], 2)) ], 4); }), 128)) ]); }), 128)) ], 2) ]), _: 1 }, 8, ["time"])) : (openBlock(), createBlock(unref(_BasicNoData), { key: 1 })) ], 2); }; } }); export { _sfc_main as default };