From 5e15de578dffaa00168e8cff66210826de1ac55b Mon Sep 17 00:00:00 2001 From: Your Name <123456> Date: 星期一, 27 六月 2022 16:33:04 +0800 Subject: [PATCH] '删除模块' --- /dev/null | 131 -------------------------------- .idea/inspectionProfiles/Project_Default.xml | 6 + .idea/vcs.xml | 6 + .idea/modules.xml | 8 ++ src/router/route.ts | 25 ------ .idea/gtqt.iml | 8 ++ src/views/login/component/account.vue | 2 .idea/.gitignore | 2 src/router/index.ts | 7 - .idea/misc.xml | 6 + 10 files changed, 40 insertions(+), 161 deletions(-) diff --git a/.idea/.gitignore b/.idea/.gitignore new file mode 100644 index 0000000..e7e9d11 --- /dev/null +++ b/.idea/.gitignore @@ -0,0 +1,2 @@ +# Default ignored files +/workspace.xml diff --git a/.idea/gtqt.iml b/.idea/gtqt.iml new file mode 100644 index 0000000..c956989 --- /dev/null +++ b/.idea/gtqt.iml @@ -0,0 +1,8 @@ +<?xml version="1.0" encoding="UTF-8"?> +<module type="WEB_MODULE" version="4"> + <component name="NewModuleRootManager"> + <content url="file://$MODULE_DIR$" /> + <orderEntry type="inheritedJdk" /> + <orderEntry type="sourceFolder" forTests="false" /> + </component> +</module> \ No newline at end of file diff --git a/.idea/inspectionProfiles/Project_Default.xml b/.idea/inspectionProfiles/Project_Default.xml new file mode 100644 index 0000000..03d9549 --- /dev/null +++ b/.idea/inspectionProfiles/Project_Default.xml @@ -0,0 +1,6 @@ +<component name="InspectionProjectProfileManager"> + <profile version="1.0"> + <option name="myName" value="Project Default" /> + <inspection_tool class="Eslint" enabled="true" level="WARNING" enabled_by_default="true" /> + </profile> +</component> \ No newline at end of file diff --git a/.idea/misc.xml b/.idea/misc.xml new file mode 100644 index 0000000..28a804d --- /dev/null +++ b/.idea/misc.xml @@ -0,0 +1,6 @@ +<?xml version="1.0" encoding="UTF-8"?> +<project version="4"> + <component name="JavaScriptSettings"> + <option name="languageLevel" value="ES6" /> + </component> +</project> \ No newline at end of file diff --git a/.idea/modules.xml b/.idea/modules.xml new file mode 100644 index 0000000..53ef2ba --- /dev/null +++ b/.idea/modules.xml @@ -0,0 +1,8 @@ +<?xml version="1.0" encoding="UTF-8"?> +<project version="4"> + <component name="ProjectModuleManager"> + <modules> + <module fileurl="file://$PROJECT_DIR$/.idea/gtqt.iml" filepath="$PROJECT_DIR$/.idea/gtqt.iml" /> + </modules> + </component> +</project> \ No newline at end of file diff --git a/.idea/vcs.xml b/.idea/vcs.xml new file mode 100644 index 0000000..94a25f7 --- /dev/null +++ b/.idea/vcs.xml @@ -0,0 +1,6 @@ +<?xml version="1.0" encoding="UTF-8"?> +<project version="4"> + <component name="VcsDirectoryMappings"> + <mapping directory="$PROJECT_DIR$" vcs="Git" /> + </component> +</project> \ No newline at end of file diff --git a/src/router/index.ts b/src/router/index.ts index 1554262..6776c5a 100644 --- a/src/router/index.ts +++ b/src/router/index.ts @@ -87,13 +87,12 @@ const storesRoutesList = useRoutesList(pinia); const { routesList } = storeToRefs(storesRoutesList); if (routesList.value.length === 0) { - if (isRequestRoutes) { + debugger // 后端控制路由:路由数据初始化,防止刷新时丢失 - await initBackEndControlRoutes(); + await initBackEndControlRoutes(); // 动态添加路由:防止非首页刷新时跳转回首页的问题 // 确保 addRoute() 时动态添加的路由已经被完全加载上去 - next({ ...to, replace: true }); - } + next({ ...to, replace: true }); } else { next(); } diff --git a/src/router/route.ts b/src/router/route.ts index 0177847..2cc9a9a 100644 --- a/src/router/route.ts +++ b/src/router/route.ts @@ -74,29 +74,4 @@ title: '登录', }, }, - { - path: '/dashboard', - name: 'dashboard', - component: () => import('/@/views/dashboard/index.vue'), - meta: { - title: '系统选择', - }, - }, - - { - path: '/visualizingDemo1', - name: 'visualizingDemo1', - component: () => import('/@/views/visualizing/demo1.vue'), - meta: { - title: 'message.router.visualizingLinkDemo1', - }, - }, - { - path: '/visualizingDemo2', - name: 'visualizingDemo2', - component: () => import('/@/views/visualizing/demo2.vue'), - meta: { - title: 'message.router.visualizingLinkDemo2', - }, - }, ]; diff --git a/src/views/chart/chart.scss b/src/views/chart/chart.scss deleted file mode 100644 index 32409e5..0000000 --- a/src/views/chart/chart.scss +++ /dev/null @@ -1,434 +0,0 @@ -.chart-scrollbar { - .chart-warp { - display: flex; - flex-direction: column; - height: 100%; - .chart-warp-bottom { - flex: 1; - overflow: hidden; - display: flex; - .big-data-down-left, - .big-data-down-right { - width: 30%; - display: flex; - flex-direction: column; - .flex-warp-item { - padding: 0 7.5px 15px 15px; - width: 100%; - height: 33.33%; - .flex-warp-item-box { - width: 100%; - height: 100%; - background: var(--el-color-white); - border: 1px solid var(--el-border-color-lighter); - border-radius: 4px; - display: flex; - flex-direction: column; - padding: 15px; - transition: all ease 0.3s; - &:hover { - box-shadow: 0 2px 12px 0 rgb(0 0 0 / 10%); - transition: all ease 0.3s; - } - .flex-title { - margin-bottom: 15px; - display: flex; - justify-content: space-between; - .flex-title-small { - font-size: 12px; - } - } - .flex-content { - flex: 1; - font-size: 12px; - } - .flex-content-overflow { - overflow: hidden; - } - } - } - } - .big-data-down-left { - color: var(--el-text-color-primary); - .sky { - display: flex; - align-items: center; - .sky-left { - font-size: 30px; - } - .sky-center { - flex: 1; - overflow: hidden; - padding: 0 10px; - font { - margin-right: 15px; - } - .span { - background: #22bc76; - border-radius: 2px; - padding: 0 5px; - color: var(--el-color-white); - } - } - .sky-right { - span { - font-size: 30px; - } - font { - font-size: 20px; - } - } - } - .sky-dd { - .sky-dl { - display: flex; - align-items: center; - height: 28px; - overflow: hidden; - div { - flex: 1; - overflow: hidden; - i { - font-size: 14px; - } - } - .tip { - overflow: hidden; - white-space: nowrap; - text-overflow: ellipsis; - } - } - .sky-dl-first { - color: var(--el-color-primary); - } - } - .d-states { - display: flex; - .d-states-item { - flex: 1; - display: flex; - align-items: center; - overflow: hidden; - i { - font-size: 20px; - height: 33px; - width: 33px; - line-height: 33px; - text-align: center; - border-radius: 100%; - flex-shrink: 1; - color: var(--el-color-white); - display: flex; - align-items: center; - justify-content: center; - } - .i-bg1 { - background: #22bc76; - } - .i-bg2 { - background: #e2356d; - } - .i-bg3 { - background: #43bbef; - } - .d-states-flex { - overflow: hidden; - padding: 0 10px 0; - .d-states-item-label { - color: var(--el-color-primary); - overflow: hidden; - white-space: nowrap; - text-overflow: ellipsis; - } - .d-states-item-value { - font-size: 14px; - text-align: center; - margin-top: 3px; - color: var(--el-color-primary); - } - } - } - } - .d-btn { - margin-top: 5px; - .d-btn-item { - border: 1px solid var(--el-color-primary); - display: flex; - width: 100%; - border-radius: 35px; - align-items: center; - padding: 5px; - margin-top: 15px; - cursor: pointer; - transition: all ease 0.3s; - color: var(--el-color-primary); - .d-btn-item-left { - font-size: 20px; - border: 1px solid var(--el-color-primary); - width: 25px; - height: 25px; - line-height: 25px; - border-radius: 100%; - text-align: center; - font-size: 14px; - } - .d-btn-item-center { - padding: 0 10px; - flex: 1; - } - .d-btn-item-eight { - text-align: right; - padding-right: 10px; - } - } - } - } - .big-data-down-center { - width: 40%; - display: flex; - flex-direction: column; - .big-data-down-center-one { - height: 66.67%; - padding: 0 7.5px 15px; - .big-data-down-center-one-content { - height: 100%; - background: var(--el-color-white); - padding: 15px; - border: 1px solid var(--el-border-color-lighter); - border-radius: 4px; - transition: all ease 0.3s; - &:hover { - box-shadow: 0 2px 12px 0 rgb(0 0 0 / 10%); - transition: all ease 0.3s; - } - } - } - .big-data-down-center-two { - padding: 0 7.5px 15px; - height: 33.33%; - .flex-warp-item-box { - width: 100%; - height: 100%; - background: var(--el-color-white); - display: flex; - flex-direction: column; - padding: 15px; - border: 1px solid var(--el-border-color-lighter); - border-radius: 4px; - transition: all ease 0.3s; - &:hover { - box-shadow: 0 2px 12px 0 rgb(0 0 0 / 10%); - transition: all ease 0.3s; - } - .flex-title { - margin-bottom: 15px; - color: var(--el-text-color-primary); - display: flex; - justify-content: space-between; - .flex-title-small { - font-size: 12px; - } - } - .flex-content { - flex: 1; - font-size: 12px; - display: flex; - height: calc(100% - 30px); - .flex-content-left { - display: flex; - flex-wrap: wrap; - width: 120px; - height: 100%; - .monitor-item { - width: 50%; - display: flex; - align-items: center; - .monitor-wave { - cursor: pointer; - width: 40px; - height: 40px; - position: relative; - background-color: var(--el-color-primary); - border-radius: 50%; - overflow: hidden; - text-align: center; - &::before, - &::after { - content: ''; - position: absolute; - left: 50%; - width: 40px; - height: 40px; - background: #f4f4f4; - animation: roateOne 10s linear infinite; - transform: translateX(-50%); - z-index: 1; - } - &::before { - bottom: 10px; - border-radius: 60%; - } - &::after { - bottom: 8px; - opacity: 0.7; - border-radius: 37%; - } - .monitor-z-index { - position: relative; - z-index: 2; - color: var(--el-color-primary); - display: flex; - align-items: center; - height: 100%; - justify-content: center; - } - } - @keyframes roateOne { - 0% { - transform: translate(-50%, 0) rotateZ(0deg); - } - 50% { - transform: translate(-50%, -2%) rotateZ(180deg); - } - 100% { - transform: translate(-50%, 0%) rotateZ(360deg); - } - } - .monitor-active { - background-color: #22bc76; - .monitor-z-index { - color: #22bc76; - } - } - } - } - .flex-content-right { - flex: 1; - } - } - } - } - } - .big-data-down-right { - .flex-warp-item { - padding: 0 15px 15px 7.5px; - .flex-title { - color: var(--el-text-color-primary); - } - .flex-content { - display: flex; - flex-direction: column; - .task { - display: flex; - height: 45px; - .task-item { - flex: 1; - color: var(--el-color-white); - display: flex; - justify-content: center; - .task-item-box { - position: relative; - width: 45px; - height: 45px; - overflow: hidden; - border-radius: 100%; - z-index: 0; - display: flex; - align-items: center; - flex-direction: column; - justify-content: center; - box-shadow: 0 10px 12px 0 rgba(0, 0, 0, 0.3); - &::before { - content: ''; - position: absolute; - z-index: -2; - left: -50%; - top: -50%; - width: 200%; - height: 200%; - background-repeat: no-repeat; - background-size: 50% 50%, 50% 50%; - background-position: 0 0, 100% 0, 100% 100%, 0 100%; - background-image: linear-gradient(#19d4ae, #19d4ae), linear-gradient(#5ab1ef, #5ab1ef), linear-gradient(#fa6e86, #fa6e86), - linear-gradient(#ffb980, #ffb980); - animation: rotate 2s linear infinite; - } - &::after { - content: ''; - position: absolute; - z-index: -1; - left: 1px; - top: 1px; - width: calc(100% - 2px); - height: calc(100% - 2px); - border-radius: 100%; - } - .task-item-value { - text-align: center; - font-size: 14px; - font-weight: bold; - } - .task-item-label { - text-align: center; - } - } - .task1 { - &::after { - background: #5492be; - } - } - .task2 { - &::after { - background: #43a177; - } - } - .task3 { - &::after { - background: #a76077; - } - } - } - .task-first-item { - flex-direction: column; - text-align: center; - color: var(--el-color-primary); - .task-first { - font-size: 20px; - } - } - } - .progress { - color: var(--el-text-color-primary); - display: flex; - flex-direction: column; - flex: 1; - justify-content: space-between; - margin-top: 15px; - .progress-item { - height: 33.33%; - display: flex; - align-items: center; - .progress-box { - flex: 1; - width: 100%; - margin-left: 10px; - ::v-deep(.el-progress__text) { - color: var(--el-text-color-primary); - font-size: 12px !important; - text-align: right; - } - ::v-deep(.el-progress-bar__outer) { - background-color: rgba(0, 0, 0, 0.1) !important; - } - ::v-deep(.el-progress-bar) { - margin-right: -22px !important; - } - } - } - } - } - } - } - } - } -} diff --git a/src/views/chart/chart.ts b/src/views/chart/chart.ts deleted file mode 100644 index 6d10fd6..0000000 --- a/src/views/chart/chart.ts +++ /dev/null @@ -1,59 +0,0 @@ -/** - * sky 天气 - * @returns 返回模拟数据 - */ -export const skyList = [ - { - v1: '时间', - v2: '天气', - v3: '温度', - v5: '降水', - v7: '风力', - type: 'title', - }, - { - v1: '今天', - v2: 'ele-Sunny', - v3: '20°/26°', - v5: '50%', - v7: '13m/s', - }, - { - v1: '明天', - v2: 'ele-Lightning', - v3: '20°/26°', - v5: '50%', - v7: '13m/s', - }, -]; - -/** - * 当前设置状态 - * @returns 返回模拟数据 - */ -export const dBtnList = [ - { - v2: '阳光玫瑰种植', - v3: '126天', - v4: '设备在线', - }, -]; - -/** - * 当前设备监测 - * @returns 返回模拟数据 - */ -export const chartData4List = [ - { - label: '温度', - }, - { - label: '光照', - }, - { - label: '湿度', - }, - { - label: '风力', - }, -]; diff --git a/src/views/chart/head.vue b/src/views/chart/head.vue deleted file mode 100644 index 82842e8..0000000 --- a/src/views/chart/head.vue +++ /dev/null @@ -1,107 +0,0 @@ -<template> - <div class="big-data-up mb15"> - <div class="up-left"> - <i class="el-icon-time mr5"></i> - <span>{{ time.txt }}</span> - </div> - <div class="up-center"> - <span>智慧农业系统平台</span> - </div> - </div> -</template> - -<script lang="ts"> -import { reactive, toRefs, onBeforeMount, onUnmounted, defineComponent } from 'vue'; -import { formatDate } from '/@/utils/formatTime'; - -export default defineComponent({ - name: 'chartHead', - setup() { - const state = reactive({ - time: { - txt: '', - fun: 0, - }, - }); - // 初始化时间 - const initTime = () => { - state.time.txt = formatDate(new Date(), 'YYYY-mm-dd HH:MM:SS WWW QQQQ'); - state.time.fun = window.setInterval(() => { - state.time.txt = formatDate(new Date(), 'YYYY-mm-dd HH:MM:SS WWW QQQQ'); - }, 1000); - }; - // 页面加载前 - onBeforeMount(() => { - initTime(); - }); - // 页面卸载时 - onUnmounted(() => { - window.clearInterval(state.time.fun); - }); - return { - ...toRefs(state), - }; - }, -}); -</script> - -<style scoped lang="scss"> -.big-data-up { - height: 55px; - width: 100%; - display: flex; - align-items: center; - padding: 0 15px; - color: var(--el-color-primary); - overflow: hidden; - position: relative; - .up-left { - position: absolute; - } - .up-center { - width: 100%; - display: flex; - justify-content: center; - font-size: 18px; - letter-spacing: 5px; - background-image: -webkit-linear-gradient( - left, - var(--el-color-primary), - var(--el-color-primary-light-3) 25%, - var(--el-color-primary) 50%, - var(--el-color-primary-light-3) 75%, - var(--el-color-primary) - ); - -webkit-text-fill-color: transparent; - -webkit-background-clip: text; - background-clip: text; - background-size: 200% 100%; - -webkit-animation: masked-animation-data-v-b02d8052 4s linear infinite; - animation: masked-animation-data-v-b02d8052 4s linear infinite; - -webkit-box-reflect: below -2px -webkit-gradient(linear, left top, left bottom, from(transparent), to(hsla(0, 0%, 100%, 0.1))); - position: relative; - @keyframes masked-animation { - 0% { - background-position: 0 0; - } - 100% { - background-position: -100% 0; - } - } - position: relative; - &::after { - content: ''; - width: 250px; - position: absolute; - bottom: -15px; - left: 50%; - transform: translateX(-50%); - border: 1px transparent solid; - border-image: linear-gradient(to right, var(--el-color-primary-light-9), var(--el-color-primary)) 1 10; - } - span { - cursor: pointer; - } - } -} -</style> diff --git a/src/views/chart/index.vue b/src/views/chart/index.vue deleted file mode 100644 index db3255e..0000000 --- a/src/views/chart/index.vue +++ /dev/null @@ -1,492 +0,0 @@ -<template> - <div class="chart-scrollbar layout-view-bg-white" :style="{ height: `calc(100vh - ${initTagViewHeight}` }"> - <div class="chart-warp"> - <div class="chart-warp-top"> - <ChartHead /> - </div> - <div class="chart-warp-bottom"> - <!-- 左边 --> - <div class="big-data-down-left"> - <div class="flex-warp-item"> - <div class="flex-warp-item-box"> - <div class="flex-title">天气预报</div> - <div class="flex-content"> - <div class="sky"> - <SvgIcon name="ele-Sunny" class="sky-left" /> - <div class="sky-center"> - <div class="mb2"> - <span>多云转晴</span> - <span>东南风</span> - <span class="span ml5">良</span> - </div> - </div> - <div class="sky-right"> - <span>25</span> - <span>°C</span> - </div> - </div> - <div class="sky-dd"> - <div class="sky-dl" v-for="(v, k) in skyList" :key="k" :class="{ 'sky-dl-first': k === 1 }"> - <div>{{ v.v1 }}</div> - <div v-if="v.type === 'title'">{{ v.v2 }}</div> - <div v-else> - <SvgIcon :name="v.v2" /> - </div> - <div>{{ v.v3 }}</div> - <div class="tip">{{ v.v5 }}</div> - <div>{{ v.v7 }}</div> - </div> - </div> - </div> - </div> - </div> - <div class="flex-warp-item"> - <div class="flex-warp-item-box"> - <div class="flex-title">当前设备状态</div> - <div class="flex-content flex-content-overflow"> - <div class="d-states"> - <div class="d-states-item"> - <SvgIcon name="ele-Odometer" class="i-bg1" /> - <div class="d-states-flex"> - <div class="d-states-item-label">园区设备数</div> - <div class="d-states-item-value">99</div> - </div> - </div> - <div class="d-states-item"> - <SvgIcon name="ele-FirstAidKit" class="i-bg2" /> - <div class="d-states-flex"> - <div class="d-states-item-label">预警设备数</div> - <div class="d-states-item-value">10</div> - </div> - </div> - <div class="d-states-item"> - <SvgIcon name="ele-VideoPlay" class="i-bg3" /> - <div class="d-states-flex"> - <div class="d-states-item-label">运行设备数</div> - <div class="d-states-item-value">20</div> - </div> - </div> - </div> - <div class="d-btn"> - <div class="d-btn-item" v-for="(v, k) in dBtnList" :key="k"> - <i class="d-btn-item-left el-icon-money"></i> - <div class="d-btn-item-center"> - <div>{{ v.v2 }}|{{ v.v3 }}</div> - </div> - <div class="d-btn-item-eight">{{ v.v4 }}</div> - </div> - </div> - </div> - </div> - </div> - <div class="flex-warp-item"> - <div class="flex-warp-item-box"> - <div class="flex-title">近30天预警总数</div> - <div class="flex-content"> - <div style="height: 100%" ref="chartsWarningRef"></div> - </div> - </div> - </div> - </div> - - <!-- 中间 --> - <div class="big-data-down-center"> - <div class="big-data-down-center-one"> - <div class="big-data-down-center-one-content"> - <div style="height: 100%" ref="chartsCenterOneRef"></div> - </div> - </div> - <div class="big-data-down-center-two"> - <div class="flex-warp-item-box"> - <div class="flex-title"> - <span>当前设备监测</span> - <span class="flex-title-small">单位:次</span> - </div> - <div class="flex-content"> - <div class="flex-content-left"> - <div class="monitor-item" v-for="(v, k) in chartData4List" :key="k"> - <div class="monitor-wave"> - <div class="monitor-z-index"> - <div class="monitor-item-label">{{ v.label }}</div> - </div> - </div> - </div> - </div> - <div class="flex-content-right"> - <div style="height: 100%" ref="chartsMonitorRef"></div> - </div> - </div> - </div> - </div> - </div> - - <!-- 右边 --> - <div class="big-data-down-right"> - <div class="flex-warp-item"> - <div class="flex-warp-item-box"> - <div class="flex-title"> - <span>近7天产品追溯扫码统计</span> - <span class="flex-title-small">单位:次</span> - </div> - <div class="flex-content"> - <div style="height: 100%" ref="chartsSevenDaysRef"></div> - </div> - </div> - </div> - <div class="flex-warp-item"> - <div class="flex-warp-item-box"> - <div class="flex-title">当前任务统计</div> - <div class="flex-content"> - <div class="task"> - <div class="task-item task-first-item"> - <div class="task-item-value task-first">25</div> - <div class="task-item-label">待办任务</div> - </div> - <div class="task-item"> - <div class="task-item-box task1"> - <div class="task-item-value">12</div> - <div class="task-item-label">施肥</div> - </div> - </div> - <div class="task-item"> - <div class="task-item-box task2"> - <div class="task-item-value">3</div> - <div class="task-item-label">施药</div> - </div> - </div> - <div class="task-item"> - <div class="task-item-box task3"> - <div class="task-item-value">5</div> - <div class="task-item-label">农事</div> - </div> - </div> - </div> - <div class="progress"> - <div class="progress-item"> - <span>施肥率</span> - <div class="progress-box"> - <el-progress :percentage="70" color="#43bdf0"></el-progress> - </div> - </div> - <div class="progress-item"> - <span>施药率</span> - <div class="progress-box"> - <el-progress :percentage="36" color="#43bdf0"></el-progress> - </div> - </div> - <div class="progress-item"> - <span>农事率</span> - <div class="progress-box"> - <el-progress :percentage="91" color="#43bdf0"></el-progress> - </div> - </div> - </div> - </div> - </div> - </div> - <div class="flex-warp-item"> - <div class="flex-warp-item-box"> - <div class="flex-title"> - <span>近7天投入品记录</span> - <span class="flex-title-small">单位:件</span> - </div> - <div class="flex-content"> - <div style="height: 100%" ref="chartsInvestmentRef"></div> - </div> - </div> - </div> - </div> - </div> - </div> - </div> -</template> - -<script lang="ts"> -import { toRefs, reactive, computed, onMounted, getCurrentInstance, watch, nextTick, onActivated, defineComponent } from 'vue'; -import ChartHead from '/@/views/chart/head.vue'; -import * as echarts from 'echarts'; -import 'echarts-wordcloud'; -import { storeToRefs } from 'pinia'; -import { useThemeConfig } from '/@/stores/themeConfig'; -import { useTagsViewRoutes } from '/@/stores/tagsViewRoutes'; -import { skyList, dBtnList, chartData4List } from '/@/views/chart/chart'; - -export default defineComponent({ - name: 'chartIndex', - components: { ChartHead }, - setup() { - const { proxy } = <any>getCurrentInstance(); - const storesThemeConfig = useThemeConfig(); - const storesTagsViewRoutes = useTagsViewRoutes(); - const { themeConfig } = storeToRefs(storesThemeConfig); - const { isTagsViewCurrenFull } = storeToRefs(storesTagsViewRoutes); - const state = reactive({ - skyList, - dBtnList, - chartData4List, - myCharts: [], - }); - // 设置主内容的高度 - const initTagViewHeight = computed(() => { - let { isTagsview } = themeConfig.value; - if (isTagsViewCurrenFull.value) { - return `30px`; - } else { - if (isTagsview) return `114px`; - else return `80px`; - } - }); - // 初始化中间图表1 - const initChartsCenterOne = () => { - const myChart = echarts.init(proxy.$refs.chartsCenterOneRef); - const option = { - grid: { - top: 15, - right: 15, - bottom: 20, - left: 30, - }, - tooltip: {}, - series: [ - { - type: 'wordCloud', - sizeRange: [12, 40], - rotationRange: [0, 0], - rotationStep: 45, - gridSize: Math.random() * 20 + 5, - shape: 'circle', - width: '100%', - height: '100%', - textStyle: { - fontFamily: 'sans-serif', - fontWeight: 'bold', - color: function () { - return `rgb(${[Math.round(Math.random() * 160), Math.round(Math.random() * 160), Math.round(Math.random() * 160)].join(',')})`; - }, - }, - data: [ - { name: 'vue-next-admin', value: 520 }, - { name: 'lyt', value: 520 }, - { name: 'next-admin', value: 500 }, - { name: '更名', value: 420 }, - { name: '智慧农业', value: 520 }, - { name: '男神', value: 2.64 }, - { name: '好身材', value: 4.03 }, - { name: '校草', value: 24.95 }, - { name: '酷', value: 4.04 }, - { name: '时尚', value: 5.27 }, - { name: '阳光活力', value: 5.8 }, - { name: '初恋', value: 3.09 }, - { name: '英俊潇洒', value: 24.71 }, - { name: '霸气', value: 6.33 }, - { name: '腼腆', value: 2.55 }, - { name: '蠢萌', value: 3.88 }, - { name: '青春', value: 8.04 }, - { name: '网红', value: 5.87 }, - { name: '萌', value: 6.97 }, - { name: '认真', value: 2.53 }, - { name: '古典', value: 2.49 }, - { name: '温柔', value: 3.91 }, - { name: '有个性', value: 3.25 }, - { name: '可爱', value: 9.93 }, - { name: '幽默诙谐', value: 3.65 }, - ], - }, - ], - }; - myChart.setOption(option); - (<any>state.myCharts).push(myChart); - }; - // 初始化近7天产品追溯扫码统计 - const initChartsSevenDays = () => { - const myChart = echarts.init(proxy.$refs.chartsSevenDaysRef); - const option = { - grid: { - top: 15, - right: 15, - bottom: 20, - left: 30, - }, - tooltip: { - trigger: 'axis', - }, - xAxis: { - type: 'category', - boundaryGap: false, - data: ['1天', '2天', '3天', '4天', '5天', '6天', '7天'], - }, - yAxis: { - type: 'value', - }, - series: [ - { - name: '邮件营销', - type: 'line', - stack: '总量', - data: [12, 32, 11, 34, 90, 23, 21], - }, - { - name: '联盟广告', - type: 'line', - stack: '总量', - data: [22, 82, 91, 24, 90, 30, 30], - }, - { - name: '视频广告', - type: 'line', - stack: '总量', - data: [50, 32, 18, 14, 90, 30, 50], - }, - ], - }; - myChart.setOption(option); - (<any>state.myCharts).push(myChart); - }; - // 初始化近30天预警总数 - const initChartsWarning = () => { - const myChart = echarts.init(proxy.$refs.chartsWarningRef); - const option = { - grid: { - top: 50, - right: 20, - bottom: 30, - left: 30, - }, - tooltip: { - trigger: 'item', - }, - series: [ - { - name: '面积模式', - type: 'pie', - radius: [20, 50], - center: ['50%', '50%'], - roseType: 'area', - itemStyle: { - borderRadius: 8, - }, - data: [ - { value: 40, name: '监测设备预警' }, - { value: 38, name: '天气预警' }, - { value: 32, name: '任务预警' }, - { value: 30, name: '病虫害预警' }, - ], - }, - ], - }; - myChart.setOption(option); - (<any>state.myCharts).push(myChart); - }; - // 初始化当前设备监测 - const initChartsMonitor = () => { - const myChart = echarts.init(proxy.$refs.chartsMonitorRef); - const option = { - grid: { - top: 15, - right: 15, - bottom: 20, - left: 30, - }, - tooltip: { - trigger: 'axis', - }, - xAxis: { - type: 'category', - boundaryGap: false, - data: ['02:00', '04:00', '06:00', '08:00', '10:00', '12:00', '14:00'], - }, - yAxis: { - type: 'value', - }, - series: [ - { - itemStyle: { - color: '#289df5', - borderColor: '#289df5', - areaStyle: { - type: 'default', - opacity: 0.1, - }, - }, - data: [20, 32, 31, 34, 12, 13, 20], - type: 'line', - areaStyle: {}, - }, - ], - }; - myChart.setOption(option); - (<any>state.myCharts).push(myChart); - }; - // 初始化近7天投入品记录 - const initChartsInvestment = () => { - const myChart = echarts.init(proxy.$refs.chartsInvestmentRef); - const option = { - grid: { - top: 15, - right: 15, - bottom: 20, - left: 30, - }, - tooltip: { - trigger: 'axis', - }, - xAxis: { - type: 'category', - data: ['1天', '2天', '3天', '4天', '5天', '6天', '7天'], - }, - yAxis: { - type: 'value', - }, - series: [ - { - data: [10, 20, 15, 80, 70, 11, 30], - type: 'bar', - }, - ], - }; - myChart.setOption(option); - (<any>state.myCharts).push(myChart); - }; - // 批量设置 echarts resize - const initEchartsResizeFun = () => { - nextTick(() => { - for (let i = 0; i < state.myCharts.length; i++) { - (<any>state.myCharts[i]).resize(); - } - }); - }; - // 批量设置 echarts resize - const initEchartsResize = () => { - window.addEventListener('resize', initEchartsResizeFun); - }; - // 页面加载时 - onMounted(() => { - initChartsCenterOne(); - initChartsSevenDays(); - initChartsWarning(); - initChartsMonitor(); - initChartsInvestment(); - initEchartsResize(); - }); - // 由于页面缓存原因,keep-alive - onActivated(() => { - initEchartsResizeFun(); - }); - // 监听 vuex 中的 tagsview 开启全屏变化,重新 resize 图表,防止不出现/大小不变等 - watch( - () => isTagsViewCurrenFull.value, - () => { - initEchartsResizeFun(); - } - ); - return { - initTagViewHeight, - ...toRefs(state), - }; - }, -}); -</script> - -<style scoped lang="scss"> -@import './chart.scss'; -</style> diff --git a/src/views/dashboard/index.vue b/src/views/dashboard/index.vue deleted file mode 100644 index 6b27d59..0000000 --- a/src/views/dashboard/index.vue +++ /dev/null @@ -1,35 +0,0 @@ -<template> - <div> - <button @click="toLink">跳转</button> - </div> -</template> - -<script lang="ts"> - import {useRoute, useRouter} from "vue-router"; - - export default { - name: "index", - setup() { - const route = useRoute(); - const router = useRouter(); - const toLink = () => { - if (route.query?.redirect) { - router.push('/dashboard'); - // router.push({ - // path: <string>route.query?.redirect, - // query: Object.keys(<string>route.query?.params).length > 0 ? JSON.parse(<string>route.query?.params) : '', - // }); - } else { - router.push('/'); - } - }; - return { - toLink, - } - } - } -</script> - -<style scoped> - -</style> diff --git a/src/views/login/component/account.vue b/src/views/login/component/account.vue index 29b40dd..20f58ed 100644 --- a/src/views/login/component/account.vue +++ b/src/views/login/component/account.vue @@ -105,7 +105,7 @@ Session.set('projectId','') Session.set('token', res.data.data.accessToken); Session.set('sign',res.data.data.id) - await initFrontEndControlRoutes(); + // await initBackEndControlRoutes(); signInSuccess(); }else{ state.loading.signIn = false diff --git a/src/views/make/noticeBar/index.vue b/src/views/make/noticeBar/index.vue deleted file mode 100644 index 2bb8730..0000000 --- a/src/views/make/noticeBar/index.vue +++ /dev/null @@ -1,164 +0,0 @@ -<template> - <div class="notice-bar-container"> - <el-card shadow="hover" header="滚动通知栏:默认"> - <NoticeBar - text="🎉🎉🔥基于vue3.x 、Typescript、vite、Element plus等,适配手机、平板、pc - 的后台开源免费模板库(vue2.x请切换vue-prev-admin分支),仓库地址:https://gitee.com/lyt-top/vue-next-admin" - /> - </el-card> - - <el-card shadow="hover" header="滚动通知栏:设置样式" class="mt15"> - <NoticeBar - text="🎉🎉🔥基于vue3.x 、Typescript、vite、Element plus等,适配手机、平板、pc - 的后台开源免费模板库(vue2.x请切换vue-prev-admin分支),仓库地址:https://gitee.com/lyt-top/vue-next-admin" - leftIcon="iconfont icon-tongzhi2" - rightIcon="ele-ArrowRight" - background="#ecf5ff" - color="#409eff" - /> - </el-card> - - <el-card shadow="hover" header="滚动通知栏:搭配 NoticeBar 和 Carousel 走马灯 组件可以实现垂直滚动的效果" class="mt15"> - <NoticeBar :scrollable="true"> - <el-carousel height="40px" direction="vertical" :autoplay="true" indicator-position="none" :interval="3000"> - <el-carousel-item v-for="v in noticeList" :key="v">{{ v }} </el-carousel-item> - </el-carousel> - </NoticeBar> - </el-card> - - <el-card shadow="hover" header="滚动通知栏:参数" class="mt15"> - <el-table :data="tableData" style="width: 100%"> - <el-table-column prop="a1" label="参数"> </el-table-column> - <el-table-column prop="a2" label="说明"> </el-table-column> - <el-table-column prop="a3" label="类型"> </el-table-column> - <el-table-column prop="a4" label="可选值"> </el-table-column> - <el-table-column prop="a5" label="默认值"> </el-table-column> - </el-table> - </el-card> - - <el-card shadow="hover" header="图标选择器(宽度自动):事件" class="mt15"> - <el-table :data="tableData1" style="width: 100%"> - <el-table-column prop="a1" label="事件名称"> </el-table-column> - <el-table-column prop="a2" label="说明"> </el-table-column> - <el-table-column prop="a3" label="类型"> </el-table-column> - <el-table-column prop="a4" label="回调参数"> </el-table-column> - </el-table> - </el-card> - </div> -</template> - -<script lang="ts"> -import { toRefs, reactive, defineComponent } from 'vue'; -import NoticeBar from '/@/components/noticeBar/index.vue'; - -export default defineComponent({ - name: 'makeNoticeBar', - components: { NoticeBar }, - setup() { - const state = reactive({ - noticeList: [ - '🎉🎉🔥基于vue3.x 、Typescript、vite、Element plus等', - '适配手机、平板、pc的后台开源免费模板库(vue2.x请切换vue-prev-admin分支)', - '仓库地址:https://gitee.com/lyt-top/vue-next-admin', - '演示地址:https://lyt-top.gitee.io/vue-next-admin-preview/#/login', - ], - tableData: [ - { - a1: 'mode', - a2: '通知栏模式,用于右侧 icon 图标点击', - a3: 'string', - a4: 'closeable / link', - a5: '', - }, - { - a1: 'text', - a2: '通知文本内容,scrollable 为 false 时生效', - a3: 'string', - a4: '', - a5: '', - }, - { - a1: 'color', - a2: '通知文本颜色', - a3: 'string', - a4: '', - a5: '#e6a23c', - }, - { - a1: 'background', - a2: '通知背景色', - a3: 'string', - a4: '', - a5: '#fdf6ec', - }, - { - a1: 'size', - a2: '字体大小,单位px', - a3: 'number / string', - a4: '', - a5: '14', - }, - { - a1: 'height', - a2: '通知栏高度,单位px', - a3: 'number / string', - a4: '', - a5: '40', - }, - { - a1: 'delay', - a2: '动画延迟时间 (s)', - a3: 'number / string', - a4: '', - a5: '1', - }, - { - a1: 'speed', - a2: '滚动速率 (px/s)', - a3: 'number / string', - a4: '', - a5: '100', - }, - { - a1: 'scrollable', - a2: '是否开启垂直滚动', - a3: 'boolean', - a4: 'true', - a5: 'false', - }, - { - a1: 'leftIcon', - a2: '自定义左侧图标', - a3: 'string', - a4: '', - a5: '', - }, - { - a1: 'rightIcon', - a2: '自定义右侧图标', - a3: 'string', - a4: '', - a5: '', - }, - ], - tableData1: [ - { - a1: 'close', - a2: '通知栏模式(mode)closeable 时回调事件', - a3: 'function', - a4: '', - }, - { - a1: 'link', - a2: '通知栏模式(mode)link 时回调事件', - a3: 'function', - a4: '', - }, - ], - }); - return { - ...toRefs(state), - }; - }, -}); -</script> diff --git a/src/views/make/selector/index.vue b/src/views/make/selector/index.vue deleted file mode 100644 index db7c34a..0000000 --- a/src/views/make/selector/index.vue +++ /dev/null @@ -1,126 +0,0 @@ -<template> - <div class="selector-container"> - <el-card shadow="hover" header="图标选择器(宽度自动):"> - <IconSelector @get="onGetIcon" @clear="onClearIcon" v-model="modelIcon" /> - </el-card> - - <el-card shadow="hover" header="图标选择器(宽度自动):参数" class="mt15"> - <el-table :data="tableData" style="width: 100%"> - <el-table-column prop="a1" label="参数"> </el-table-column> - <el-table-column prop="a2" label="说明"> </el-table-column> - <el-table-column prop="a3" label="类型"> </el-table-column> - <el-table-column prop="a4" label="可选值"> </el-table-column> - <el-table-column prop="a5" label="默认值"> </el-table-column> - </el-table> - </el-card> - - <el-card shadow="hover" header="图标选择器(宽度自动):事件" class="mt15"> - <el-table :data="tableData1" style="width: 100%"> - <el-table-column prop="a1" label="事件名称"> </el-table-column> - <el-table-column prop="a2" label="说明"> </el-table-column> - <el-table-column prop="a3" label="类型"> </el-table-column> - <el-table-column prop="a4" label="回调参数"> </el-table-column> - </el-table> - </el-card> - </div> -</template> - -<script lang="ts"> -import { toRefs, reactive, defineComponent } from 'vue'; -import IconSelector from '/@/components/iconSelector/index.vue'; - -export default defineComponent({ - name: 'makeSelector', - components: { IconSelector }, - setup() { - const state = reactive({ - modelIcon: '', - tableData: [ - { - a1: 'prepend', - a2: '输入框前置内容,只能字体图标', - a3: 'string', - a4: '', - a5: 'ele-Pointer', - }, - { - a1: 'placeholder', - a2: '输入框占位文本', - a3: 'string', - a4: '', - a5: '请输入内容搜索图标或者选择图标', - }, - { - a1: 'size', - a2: '尺寸', - a3: 'string', - a4: 'large / default / small', - a5: 'default', - }, - { - a1: 'title', - a2: '弹窗标题', - a3: 'string', - a4: '', - a5: '请选择图标', - }, - { - a1: 'type', - a2: 'icon 图标类型', - a3: 'string', - a4: 'ali / ele / awe / all', - a5: 'ele', - }, - { - a1: 'disabled', - a2: '禁用', - a3: 'boolean', - a4: 'true', - a5: 'false', - }, - { - a1: 'clearable', - a2: '是否可清空', - a3: 'boolean', - a4: 'false', - a5: 'true', - }, - { - a1: 'emptyDescription', - a2: '自定义空状态描述文字', - a3: 'String', - a4: '', - a5: '无相关图标', - }, - ], - tableData1: [ - { - a1: 'get', - a2: '获取当前点击的 icon 图标', - a3: 'function', - a4: '(icon: string)', - }, - { - a1: 'clear', - a2: '清空当前点击的 icon 图标', - a3: 'function', - a4: '(icon: string)', - }, - ], - }); - // 获取当前点击的 icon 图标 - const onGetIcon = (icon: string) => { - console.log(icon); - }; - // 清空当前点击的 icon 图标 - const onClearIcon = (icon: string) => { - console.log(icon); - }; - return { - onGetIcon, - onClearIcon, - ...toRefs(state), - }; - }, -}); -</script> diff --git a/src/views/make/svgDemo/index.vue b/src/views/make/svgDemo/index.vue deleted file mode 100644 index 36fd320..0000000 --- a/src/views/make/svgDemo/index.vue +++ /dev/null @@ -1,59 +0,0 @@ -<template> - <div class="svg-demo-container"> - <el-card shadow="hover" header="svgIcon:演示(支持本地svg)"> - <SvgIcon name="iconfont icon-shuju1" color="red" :size="30" /> - <SvgIcon name="ele-Trophy" color="var(--el-color-primary)" :size="30" /> - <SvgIcon name="fa fa-flag-checkered" color="#09f" :size="30" /> - <SvgIcon :name="logoMini" color="#09f" :size="30" /> - </el-card> - <el-card shadow="hover" header="svgIcon:参数" class="mt15"> - <el-table :data="tableData" style="width: 100%"> - <el-table-column prop="a1" label="参数"> </el-table-column> - <el-table-column prop="a2" label="说明"> </el-table-column> - <el-table-column prop="a3" label="类型"> </el-table-column> - <el-table-column prop="a4" label="可选值"> </el-table-column> - <el-table-column prop="a5" label="默认值"> </el-table-column> - </el-table> - </el-card> - </div> -</template> - -<script lang="ts"> -import { toRefs, reactive, defineComponent } from 'vue'; -import logoMini from '/@/assets/logo-mini.svg'; - -export default defineComponent({ - name: 'makeSvgDemo', - setup() { - const state = reactive({ - tableData: [ - { - a1: 'name', - a2: 'svg 图标组件名字 / svg 路径 url', - a3: 'string', - a4: '', - a5: '', - }, - { - a1: 'size', - a2: 'svg 大小', - a3: 'number', - a4: '', - a5: 14, - }, - { - a1: 'color', - a2: 'svg 颜色', - a3: 'string', - a4: '', - a5: '', - }, - ], - }); - return { - logoMini, - ...toRefs(state), - }; - }, -}); -</script> diff --git a/src/views/menu/menu1/menu11/index.vue b/src/views/menu/menu1/menu11/index.vue deleted file mode 100644 index 944beb8..0000000 --- a/src/views/menu/menu1/menu11/index.vue +++ /dev/null @@ -1,21 +0,0 @@ -<template> - <div> - <el-input v-model="val" placeholder="menu11:请输入内容测试路由缓存"></el-input> - </div> -</template> - -<script lang="ts"> -import { toRefs, reactive, defineComponent } from 'vue'; - -export default defineComponent({ - name: 'menu11', - setup() { - const state = reactive({ - val: '', - }); - return { - ...toRefs(state), - }; - }, -}); -</script> diff --git a/src/views/menu/menu1/menu12/menu121/index.vue b/src/views/menu/menu1/menu12/menu121/index.vue deleted file mode 100644 index 791130b..0000000 --- a/src/views/menu/menu1/menu12/menu121/index.vue +++ /dev/null @@ -1,21 +0,0 @@ -<template> - <div> - <el-input v-model="val" placeholder="menu121:请输入内容测试路由缓存"></el-input> - </div> -</template> - -<script lang="ts"> -import { toRefs, reactive, defineComponent } from 'vue'; - -export default defineComponent({ - name: 'menu121', - setup() { - const state = reactive({ - val: '', - }); - return { - ...toRefs(state), - }; - }, -}); -</script> diff --git a/src/views/menu/menu1/menu12/menu122/index.vue b/src/views/menu/menu1/menu12/menu122/index.vue deleted file mode 100644 index 3db8096..0000000 --- a/src/views/menu/menu1/menu12/menu122/index.vue +++ /dev/null @@ -1,21 +0,0 @@ -<template> - <div> - <el-input v-model="val" placeholder="menu122:请输入内容测试路由缓存"></el-input> - </div> -</template> - -<script lang="ts"> -import { toRefs, reactive, defineComponent } from 'vue'; - -export default defineComponent({ - name: 'menu122', - setup() { - const state = reactive({ - val: '', - }); - return { - ...toRefs(state), - }; - }, -}); -</script> diff --git a/src/views/menu/menu1/menu13/index.vue b/src/views/menu/menu1/menu13/index.vue deleted file mode 100644 index f984dcc..0000000 --- a/src/views/menu/menu1/menu13/index.vue +++ /dev/null @@ -1,27 +0,0 @@ -<template> - <div> - <el-input v-model="val" placeholder="menu13:请输入内容测试路由缓存"></el-input> - </div> -</template> - -<script lang="ts"> -import { toRefs, reactive, onActivated, onMounted, defineComponent } from 'vue'; - -export default defineComponent({ - name: 'menu13', - setup() { - const state = reactive({ - val: '', - }); - onMounted(() => { - console.log(2222); - }); - onActivated(() => { - console.log(1111); - }); - return { - ...toRefs(state), - }; - }, -}); -</script> diff --git a/src/views/menu/menu2/index.vue b/src/views/menu/menu2/index.vue deleted file mode 100644 index 0081506..0000000 --- a/src/views/menu/menu2/index.vue +++ /dev/null @@ -1,21 +0,0 @@ -<template> - <div> - <el-input v-model="val" placeholder="menu2:请输入内容测试路由缓存"></el-input> - </div> -</template> - -<script lang="ts"> -import { toRefs, reactive, defineComponent } from 'vue'; - -export default defineComponent({ - name: 'menu2', - setup() { - const state = reactive({ - val: '', - }); - return { - ...toRefs(state), - }; - }, -}); -</script> diff --git a/src/views/pages/awesome/index.vue b/src/views/pages/awesome/index.vue deleted file mode 100644 index 52b53bb..0000000 --- a/src/views/pages/awesome/index.vue +++ /dev/null @@ -1,87 +0,0 @@ -<template> - <div class="awesome-container"> - <el-card shadow="hover" :header="`fontawesome 字体图标(自动载入):${sheetsIconList.length - 24}个`"> - <el-row class="iconfont-row"> - <el-col :xs="12" :sm="8" :md="6" :lg="4" :xl="2" v-for="(v, k) in sheetsIconList" :key="k"> - <div class="iconfont-warp"> - <div class="flex-margin"> - <div class="iconfont-warp-value"> - <i :class="v" class="fa"></i> - </div> - <div class="iconfont-warp-label mt10">{{ v }}</div> - </div> - </div> - </el-col> - </el-row> - </el-card> - </div> -</template> - -<script lang="ts"> -import { toRefs, reactive, onMounted, defineComponent } from 'vue'; -import initIconfont from '/@/utils/getStyleSheets'; - -export default defineComponent({ - name: 'pagesAwesome', - setup() { - const state = reactive({ - sheetsIconList: [], - }); - // 初始化获取 css 样式,这里使用fontawesome的图标(记得加上前缀 `fa`),其它第三方请自行做判断 - const initGetStyleSheets = () => { - initIconfont.awe().then((res: any) => (state.sheetsIconList = res)); - }; - // 页面加载时 - onMounted(() => { - initGetStyleSheets(); - }); - return { - ...toRefs(state), - }; - }, -}); -</script> - -<style scoped lang="scss"> -.awesome-container { - .iconfont-row { - border-top: 1px solid var(--next-border-color-light); - border-left: 1px solid var(--next-border-color-light); - .iconfont-warp { - text-align: center; - border-right: 1px solid var(--next-border-color-light); - border-bottom: 1px solid var(--next-border-color-light); - height: 120px; - overflow: hidden; - display: flex; - transition: all 0.3s ease; - &:hover { - box-shadow: 0 2px 12px var(--next-color-dark-hover); - cursor: pointer; - transition: all 0.3s ease; - .iconfont-warp-value { - i { - color: var(--el-color-primary); - transition: all 0.3s ease; - } - } - .iconfont-warp-label { - color: var(--el-color-primary); - transition: all 0.3s ease; - } - } - .iconfont-warp-value { - i { - color: #606266; - font-size: 32px; - transition: all 0.3s ease; - } - } - .iconfont-warp-label { - color: #99a9bf; - transition: all 0.3s ease; - } - } - } -} -</style> diff --git a/src/views/pages/drag/index.vue b/src/views/pages/drag/index.vue deleted file mode 100644 index 1b79498..0000000 --- a/src/views/pages/drag/index.vue +++ /dev/null @@ -1,66 +0,0 @@ -<template> - <div class="drag-container"> - <el-card shadow="hover" header="拖动指令效果(v-drag)作用于 Dialog 对话框"> - <el-button type="primary" @click="dialogVisible = true" size="default"> - <el-icon> - <ele-Pointer /> - </el-icon> - 点击打开 Dialog - </el-button> - </el-card> - - <el-card shadow="hover" header="自定义div" class="mt15"> - <div class="drag-dom"> - <div class="drag-header"> - <el-button type="success" size="default" v-drag="['.drag-container .drag-dom', '.drag-container .drag-header']"> - <el-icon> - <ele-Pointer /> - </el-icon> - 按住进行拖动测试 - </el-button> - </div> - </div> - </el-card> - - <el-dialog v-model="dialogVisible" width="769px"> - <template #header> - <div v-drag="['.drag-container .el-dialog', '.drag-container .el-dialog__header']">拖动指令效果(v-drag)</div> - </template> - <p>鼠标放标题头进行 Dialog 对话框拖动</p> - <template #footer> - <span class="dialog-footer"> - <el-button @click="dialogVisible = false" size="default">取 消</el-button> - <el-button type="primary" @click="dialogVisible = false" size="default">确 定</el-button> - </span> - </template> - </el-dialog> - </div> -</template> - -<script lang="ts"> -import { toRefs, reactive, defineComponent } from 'vue'; - -export default defineComponent({ - name: 'pagesDrag', - setup() { - const state = reactive({ - dialogVisible: false, - }); - return { - ...toRefs(state), - }; - }, -}); -</script> - -<style scoped lang="scss"> -.drag-container { - .drag-dom { - position: relative; - display: inline-block; - .drag-header { - display: inline-block; - } - } -} -</style> diff --git a/src/views/pages/dynamicForm/index.vue b/src/views/pages/dynamicForm/index.vue deleted file mode 100644 index d6a7a68..0000000 --- a/src/views/pages/dynamicForm/index.vue +++ /dev/null @@ -1,204 +0,0 @@ -<template> - <div class="dynamic-form-container"> - <el-card shadow="hover" header="动态复杂表单"> - <el-form :model="form" ref="formRulesOneRef" size="default" label-width="100px" class="mt35"> - <el-row :gutter="35"> - <el-col - :xs="val.xs" - :sm="val.sm" - :md="val.md" - :lg="val.md" - :xl="val.xl" - class="mb20" - v-show="val.isShow" - v-for="(val, key) in formData" - :key="key" - > - <template v-if="val.type !== ''"> - <el-form-item - :label="val.label" - :prop="val.prop" - :rules="[{ required: val.required, message: `${val.label}不能为空`, trigger: val.type === 'input' ? 'blur' : 'change' }]" - v-if="val.type !== ''" - > - <el-input - v-model="form[val.prop]" - :placeholder="val.placeholder" - clearable - v-if="val.type === 'input'" - style="width: 100%" - :disabled="val.disabled" - ></el-input> - <el-date-picker - v-model="form[val.prop]" - type="date" - :placeholder="val.placeholder" - v-else-if="val.type === 'date'" - style="width: 100%" - :disabled="val.disabled" - > - </el-date-picker> - <el-select - v-model="form[val.prop]" - :placeholder="val.placeholder" - v-else-if="val.type === 'select'" - style="width: 100%" - :disabled="val.disabled" - > - <el-option v-for="item in val.options" :key="item.value" :label="item.label" :value="item.value"> </el-option> - </el-select> - <el-input - type="textarea" - v-model="form[val.prop]" - :placeholder="val.placeholder" - clearable - v-if="val.type === 'textarea'" - style="width: 100%" - :disabled="val.disabled" - ></el-input> - </el-form-item> - </template> - <template v-else> - <el-row :gutter="35" v-for="(v, k) in form.list" :key="k"> - <el-col :xs="24" :sm="12" :md="8" :lg="8" :xl="6" class="mb20"> - <el-form-item label="年度" :prop="`list[${k}].year`" :rules="[{ required: true, message: `年度不能为空`, trigger: 'blur' }]"> - <template #label> - <el-button type="primary" circle size="small" @click="onAddRow" v-if="k === 0"> - <el-icon> - <ele-Plus /> - </el-icon> - </el-button> - <el-button type="danger" circle size="small" @click="onDelRow(k)" v-else> - <el-icon> - <ele-Delete /> - </el-icon> - </el-button> - <span class="ml10">年度</span> - </template> - <el-input v-model="form.list[k].year" style="width: 100%" placeholder="请输入"> </el-input> - </el-form-item> - </el-col> - <el-col :xs="24" :sm="12" :md="8" :lg="8" :xl="6" class="mb20"> - <el-form-item label="月度" :prop="`list[${k}].month`" :rules="[{ required: true, message: `月度不能为空`, trigger: 'blur' }]"> - <el-input v-model="form.list[k].month" style="width: 100%" placeholder="请输入"> </el-input> - </el-form-item> - </el-col> - <el-col :xs="24" :sm="12" :md="8" :lg="8" :xl="6" class="mb20"> - <el-form-item label="日度" :prop="`list[${k}].day`" :rules="[{ required: true, message: `日度不能为空`, trigger: 'blur' }]"> - <el-input v-model="form.list[k].day" style="width: 100%" placeholder="请输入"> </el-input> - </el-form-item> - </el-col> - </el-row> - </template> - </el-col> - </el-row> - </el-form> - </el-card> - <el-row class="flex mt15"> - <div class="flex-margin"> - <el-button size="default" @click="onResetForm"> - <el-icon> - <ele-RefreshRight /> - </el-icon> - 重置表单 - </el-button> - <el-button size="default" type="primary" @click="onSubmitForm"> - <SvgIcon name="iconfont icon-shuxing" /> - 验证表单 - </el-button> - </div> - </el-row> - </div> -</template> - -<script lang="ts"> -import { toRefs, reactive, onMounted, getCurrentInstance, defineComponent } from 'vue'; -import { formData } from './mock'; - -// 定义接口来定义对象的类型 -interface FormDataOptions { - label: string; - value: string; -} -interface FormDataState { - label: string; - prop: string; - placeholder: string; - clearable: boolean; - disabled: boolean; - required: boolean; - type: string; - i18n: boolean; - i18nText: string; - isShow: boolean; - xs: number; - sm: number; - md: number; - lg: number; - xl: number; - options?: FormDataOptions[]; -} -interface DynamicFormState { - formData: FormDataState[]; - form: any; -} - -export default defineComponent({ - name: 'pagesDynamicForm', - setup() { - const { proxy } = <any>getCurrentInstance(); - const state = reactive<DynamicFormState>({ - formData, - form: { - name: '', - email: '', - autograph: '', - occupation: '', - list: [ - { - year: '', - month: '', - day: '', - }, - ], - remarks: '', - }, - }); - // 新增行 - const onAddRow = () => { - state.form.list.push({ - year: '', - month: '', - day: '', - }); - }; - // 删除行 - const onDelRow = (k: number) => { - state.form.list.splice(k, 1); - }; - // 表单验证 - const onSubmitForm = () => { - proxy.$refs.formRulesOneRef.validate((valid: boolean) => { - if (valid) { - proxy.$message.success('验证成功'); - } else { - return false; - } - }); - }; - // 重置表单 - const onResetForm = () => { - proxy.$refs.formRulesOneRef.resetFields(); - }; - // 页面加载时 - onMounted(() => {}); - return { - onAddRow, - onDelRow, - onSubmitForm, - onResetForm, - ...toRefs(state), - }; - }, -}); -</script> diff --git a/src/views/pages/dynamicForm/mock.ts b/src/views/pages/dynamicForm/mock.ts deleted file mode 100644 index 2293fe9..0000000 --- a/src/views/pages/dynamicForm/mock.ts +++ /dev/null @@ -1,119 +0,0 @@ -// 表单数据选项(自行扩展) -export const formData = [ - { - label: '姓名', - prop: 'name', - placeholder: '请输入姓名', - clearable: true, - disabled: false, - required: true, - type: 'input', - i18n: false, - i18nText: '', - isShow: true, - xs: 24, - sm: 12, - md: 8, - lg: 6, - xl: 4, - }, - { - label: '邮箱', - prop: 'email', - placeholder: '请输入用户邮箱', - clearable: true, - disabled: false, - required: true, - type: 'input', - i18n: false, - i18nText: '', - isShow: true, - xs: 24, - sm: 12, - md: 8, - lg: 6, - xl: 4, - }, - { - label: '登陆时间', - prop: 'autograph', - placeholder: '选择时间', - clearable: true, - disabled: false, - required: true, - type: 'date', - i18n: false, - i18nText: '', - isShow: true, - xs: 24, - sm: 12, - md: 8, - lg: 6, - xl: 4, - }, - { - label: '职务', - prop: 'occupation', - placeholder: '请选择职务', - clearable: true, - disabled: false, - required: true, - type: 'select', - i18n: false, - i18nText: '', - options: [ - { - label: '计算机 / 互联网 / 通信', - value: '1', - }, - { - label: '生产 / 工艺 / 制造', - value: '2', - }, - { - label: '医疗 / 护理 / 制药', - value: '3', - }, - ], - isShow: true, - xs: 24, - sm: 12, - md: 8, - lg: 6, - xl: 4, - }, - { - label: '', - prop: '', - placeholder: '', - clearable: true, - disabled: false, - required: true, - type: '', - i18n: false, - i18nText: '', - isShow: true, - xs: 24, - sm: 24, - md: 24, - lg: 24, - xl: 24, - }, - { - label: '备注', - prop: 'remarks', - placeholder: '请输入', - clearable: true, - disabled: false, - required: true, - type: 'textarea', - i18n: false, - i18nText: '', - isShow: true, - xs: 24, - sm: 24, - md: 24, - lg: 24, - xl: 24, - }, -]; diff --git a/src/views/pages/element/index.vue b/src/views/pages/element/index.vue deleted file mode 100644 index 0bb2454..0000000 --- a/src/views/pages/element/index.vue +++ /dev/null @@ -1,89 +0,0 @@ -<template> - <div class="element-container"> - <el-card shadow="hover" :header="`element plus 字体图标(自动载入,增加了 ele- 前缀,使用时:ele-Aim):${sheetsIconList.length}个`"> - <el-row class="iconfont-row"> - <el-col :xs="12" :sm="8" :md="6" :lg="4" :xl="2" v-for="(v, k) in sheetsIconList" :key="k"> - <div class="iconfont-warp"> - <div class="flex-margin"> - <div class="iconfont-warp-value"> - <SvgIcon :name="v" :size="30" /> - </div> - <div class="iconfont-warp-label mt10">{{ v }}</div> - </div> - </div> - </el-col> - </el-row> - </el-card> - </div> -</template> - -<script lang="ts"> -import { toRefs, reactive, onMounted, defineComponent } from 'vue'; -import initIconfont from '/@/utils/getStyleSheets'; - -export default defineComponent({ - name: 'pagesElement', - setup() { - const state = reactive({ - sheetsIconList: [], - }); - // 初始化获取 css 样式,获取 element plus 自带 svg 图标,增加了 ele- 前缀,使用时:ele-Aim - const initGetStyleSheets = () => { - initIconfont.ele().then((res: any) => { - state.sheetsIconList = res; - }); - }; - // 页面加载时 - onMounted(() => { - initGetStyleSheets(); - }); - return { - ...toRefs(state), - }; - }, -}); -</script> - -<style scoped lang="scss"> -.element-container { - .iconfont-row { - border-top: 1px solid var(--next-border-color-light); - border-left: 1px solid var(--next-border-color-light); - .iconfont-warp { - text-align: center; - border-right: 1px solid var(--next-border-color-light); - border-bottom: 1px solid var(--next-border-color-light); - height: 120px; - overflow: hidden; - display: flex; - transition: all 0.3s ease; - &:hover { - box-shadow: 0 2px 12px var(--next-color-dark-hover); - cursor: pointer; - transition: all 0.3s ease; - .iconfont-warp-value { - i { - color: var(--el-color-primary); - transition: all 0.3s ease; - } - } - .iconfont-warp-label { - color: var(--el-color-primary); - transition: all 0.3s ease; - } - } - .iconfont-warp-value { - i { - color: #606266; - font-size: 32px; - transition: all 0.3s ease; - } - } - .iconfont-warp-label { - color: #99a9bf; - transition: all 0.3s ease; - } - } - } -} -</style> diff --git a/src/views/pages/filtering/details.vue b/src/views/pages/filtering/details.vue deleted file mode 100644 index a2e5417..0000000 --- a/src/views/pages/filtering/details.vue +++ /dev/null @@ -1,39 +0,0 @@ -<template> - <div :style="{ height: `calc(100vh - ${initTagViewHeight}` }"> - <div class="layout-view-bg-white"> - <div class="w100 h100 flex"> - <div class="flex-margin color-primary">filtering-details 测试界面</div> - </div> - </div> - </div> -</template> - -<script lang="ts"> -import { computed, defineComponent } from 'vue'; -import { storeToRefs } from 'pinia'; -import { useThemeConfig } from '/@/stores/themeConfig'; -import { useTagsViewRoutes } from '/@/stores/tagsViewRoutes'; - -export default defineComponent({ - name: 'pagesFilteringDetails', - setup() { - const storesTagsViewRoutes = useTagsViewRoutes(); - const storesThemeConfig = useThemeConfig(); - const { themeConfig } = storeToRefs(storesThemeConfig); - const { isTagsViewCurrenFull } = storeToRefs(storesTagsViewRoutes); - // 设置主内容的高度 - const initTagViewHeight = computed(() => { - let { isTagsview } = themeConfig.value; - if (isTagsViewCurrenFull.value) { - return `30px`; - } else { - if (isTagsview) return `114px`; - else return `80px`; - } - }); - return { - initTagViewHeight, - }; - }, -}); -</script> diff --git a/src/views/pages/filtering/details1.vue b/src/views/pages/filtering/details1.vue deleted file mode 100644 index 2fde1b4..0000000 --- a/src/views/pages/filtering/details1.vue +++ /dev/null @@ -1,39 +0,0 @@ -<template> - <div :style="{ height: `calc(100vh - ${initTagViewHeight}` }"> - <div class="layout-view-bg-white"> - <div class="w100 h100 flex"> - <div class="flex-margin color-primary">测试界面</div> - </div> - </div> - </div> -</template> - -<script lang="ts"> -import { computed, defineComponent } from 'vue'; -import { storeToRefs } from 'pinia'; -import { useThemeConfig } from '/@/stores/themeConfig'; -import { useTagsViewRoutes } from '/@/stores/tagsViewRoutes'; - -export default defineComponent({ - name: 'pagesFilteringDetails1', - setup() { - const storesTagsViewRoutes = useTagsViewRoutes(); - const storesThemeConfig = useThemeConfig(); - const { themeConfig } = storeToRefs(storesThemeConfig); - const { isTagsViewCurrenFull } = storeToRefs(storesTagsViewRoutes); - // 设置主内容的高度 - const initTagViewHeight = computed(() => { - let { isTagsview } = themeConfig.value; - if (isTagsViewCurrenFull.value) { - return `30px`; - } else { - if (isTagsview) return `114px`; - else return `80px`; - } - }); - return { - initTagViewHeight, - }; - }, -}); -</script> diff --git a/src/views/pages/filtering/index.vue b/src/views/pages/filtering/index.vue deleted file mode 100644 index 7cb7ff5..0000000 --- a/src/views/pages/filtering/index.vue +++ /dev/null @@ -1,355 +0,0 @@ -<template> - <div class="filtering"> - <el-card - shadow="hover" - class="filtering-list br-top-no" - v-loading="tableData.loading" - element-loading-text="加载中..." - element-loading-background="rgba(255, 255, 255, 0.1)" - :class="{ 'min-h-360': tableData.data.length <= 0 }" - > - <div - v-for="(val, key) in filtering" - :key="key" - :ref=" - (el) => { - if (el) dlRefs[key] = el; - } - " - class="filtering-list-flex" - > - <div class="filtering-list-title">{{ val.title }}</div> - <div class="filtering-list-item" :style="{ height: val.isMore ? 'auto' : '50px' }"> - <span class="span" :class="v.active ? 'dd-active' : ''" v-for="(v, k) in val.children" :key="k" @click="onSelItem(val, v)">{{ - v.label - }}</span> - <div class="dd-more" v-if="val.isShowMore" @click="val.isMore = !val.isMore"> - <span>{{ val.isMore ? '收起' : '展开' }}</span> - <i :class="val.isMore ? 'el-icon-arrow-down' : 'el-icon-arrow-right'"></i> - </div> - </div> - </div> - <div class="flex-warp mt15 mb15" v-if="tableData.data.length > 0"> - <el-row :gutter="15"> - <el-col :xs="24" :sm="12" :md="8" :lg="6" :xl="4" class="mb15" v-for="(v, k) in tableData.data" :key="k" @click="onTableItemClick(v)"> - <div class="flex-warp-item"> - <div class="flex-warp-item-box"> - <div class="item-img"> - <img :src="v.img" /> - </div> - <div class="item-txt"> - <div class="item-txt-title">{{ v.title }}</div> - <div class="item-txt-other"> - <div style="width: 100%"> - <div class="item-txt-msg mb10"> - <span>评价 {{ v.evaluate }}</span> - <span class="ml10">收藏 {{ v.collection }}</span> - </div> - <div class="item-txt-msg item-txt-price"> - <span class="font-price"> - <span>¥</span> - <span class="font">{{ v.price }}</span> - </span> - <span>月销{{ v.monSales }}笔</span> - </div> - </div> - </div> - </div> - </div> - </div> - </el-col> - </el-row> - </div> - <div v-else class="filtering-no-data"> - <div class="no-data-box"> - <i class="el-icon-search"></i> - <div class="no-txt">暂无数据</div> - </div> - </div> - <template v-if="tableData.data.length > 0"> - <el-pagination - style="text-align: right" - background - @size-change="onHandleSizeChange" - @current-change="onHandleCurrentChange" - :page-sizes="[10, 20, 30]" - :current-page="tableData.param.pageNum" - :page-size="tableData.param.pageSize" - layout="total, sizes, prev, pager, next, jumper" - :total="tableData.total" - > - </el-pagination> - </template> - </el-card> - </div> -</template> - -<script lang="ts"> -import { ref, toRefs, reactive, onMounted, nextTick, defineComponent } from 'vue'; -import { useRouter } from 'vue-router'; -import { filtering, filterList } from './mock'; - -export default defineComponent({ - name: 'pagesFiltering', - setup() { - const dlRefs: any = ref([]); - const router = useRouter(); - const state = reactive({ - filtering, - tableData: { - data: filterList, - total: 99, - loading: false, - param: { - pageNum: 1, - pageSize: 10, - }, - }, - }); - // 页面加载时 - onMounted(() => { - initBtnToggle(); - window.onresize = () => { - initBtnToggle(); - }; - }); - // 初始化 `收起、展开` 按钮 - const initBtnToggle = () => { - nextTick(() => { - const els = dlRefs.value; - els.map((v: any, k: number) => { - v.scrollHeight < v.lastChild.scrollHeight ? (state.filtering[k].isShowMore = true) : (state.filtering[k].isShowMore = false); - }); - }); - }; - // 过滤当前选中的数据 - const onSelItem = (val: any, v: any) => { - val.children.map((v: any) => (v.active = false)); - v.active = true; - let arr = []; - state.filtering.map((item: any) => { - item.children.map((chil: any) => { - if (chil.active) { - arr.push({ - ...item, - children: [{ ...chil }], - }); - } - }); - }); - state.tableData.loading = true; - setTimeout(() => { - state.tableData.loading = false; - }, 500); - }; - // 当前列表项点击 - const onTableItemClick = (v: any) => { - if (v.id === 1) { - router.push({ - path: '/pages/filtering/details', - query: { id: v.id }, - }); - } else { - router.push({ - path: '/pages/filtering/details1', - query: { id: v.id }, - }); - } - }; - // 分页点击 - const onHandleSizeChange = (val: number) => { - state.tableData.param.pageSize = val; - }; - // 分页点击 - const onHandleCurrentChange = (val: number) => { - state.tableData.param.pageNum = val; - }; - return { - dlRefs, - onSelItem, - onTableItemClick, - onHandleSizeChange, - onHandleCurrentChange, - ...toRefs(state), - }; - }, -}); -</script> - -<style scoped lang="scss"> -.filtering { - .filtering-list { - overflow: hidden; - border-bottom: none !important; - .filtering-list-flex { - &:last-of-type { - .filtering-list-item { - border-bottom: none !important; - } - } - .filtering-list-title { - float: left; - width: 64px; - font-weight: 700; - position: relative; - color: #909399; - margin: 15px 0; - &:after { - content: ''; - position: absolute; - border: 1px solid #909399; - border-width: 0 1px 1px 0; - width: 4px; - height: 4px; - transform: rotate(-45deg) translateY(-50%); - right: 10px; - top: 50%; - } - } - .filtering-list-item { - border-bottom: 1px dotted var(--next-border-color-light); - margin-left: 64px; - overflow: hidden; - position: relative; - .span { - color: #8d8d91; - font-size: 14px; - float: left; - padding: 0 15px; - margin: 15px 0; - &:hover { - color: var(--el-color-primary); - cursor: pointer; - } - } - .dd-active { - color: var(--el-color-primary); - } - .dd-more { - font-size: 12px; - position: absolute; - right: 0; - top: 16px; - color: #a5a5a5; - &:hover { - cursor: pointer; - color: #8d8d91; - } - } - } - } - } - .br-top-no { - border-top: none; - .flex-warp { - display: flex; - flex-wrap: wrap; - align-content: flex-start; - margin: 0 -5px; - .flex-warp-item { - padding: 5px; - width: 100%; - height: 360px; - .flex-warp-item-box { - border: 1px solid var(--next-border-color-light); - width: 100%; - height: 100%; - border-radius: 2px; - display: flex; - flex-direction: column; - transition: all 0.3s ease; - &:hover { - cursor: pointer; - border: 1px solid var(--el-color-primary); - transition: all 0.3s ease; - box-shadow: 0 2px 12px 0 rgba(0, 0, 0, 0.03); - .item-txt-title { - color: var(--el-color-primary) !important; - transition: all 0.3s ease; - } - .item-img { - img { - transition: all 0.3s ease; - transform: translateZ(0) scale(1.05); - } - } - } - .item-img { - width: 100%; - height: 215px; - overflow: hidden; - img { - transition: all 0.3s ease; - width: 100%; - height: 100%; - } - } - .item-txt { - flex: 1; - padding: 15px; - display: flex; - flex-direction: column; - overflow: hidden; - .item-txt-title { - text-overflow: ellipsis; - overflow: hidden; - -webkit-line-clamp: 2; - -webkit-box-orient: vertical; - display: -webkit-box; - color: #666666; - transition: all 0.3s ease; - &:hover { - color: var(--el-color-primary); - text-decoration: underline; - transition: all 0.3s ease; - } - } - .item-txt-other { - flex: 1; - align-items: flex-end; - display: flex; - .item-txt-msg { - font-size: 12px; - color: #8d8d91; - } - .item-txt-price { - display: flex; - justify-content: space-between; - align-items: center; - .font-price { - color: #ff5000; - .font { - font-size: 22px; - } - } - } - } - } - } - } - } - ::v-deep(.el-card__body) { - height: 100%; - .filtering-no-data { - display: flex; - height: 100%; - .no-data-box { - color: #cccccc; - margin: auto; - i { - font-size: 70px; - } - .no-txt { - font-size: 14px; - text-align: center; - margin-top: 15px; - } - } - } - } - } - .min-h-360 { - height: 360px; - } -} -</style> diff --git a/src/views/pages/filtering/mock.ts b/src/views/pages/filtering/mock.ts deleted file mode 100644 index 22e0f38..0000000 --- a/src/views/pages/filtering/mock.ts +++ /dev/null @@ -1,201 +0,0 @@ -// 导航数据 -export const filtering = [ - { - title: '权限', - isMore: false, - isShowMore: false, - id: 0, - children: [ - { - id: '01', - label: '全部', - active: true, - }, - { - id: '02', - label: '普通用户', - active: false, - }, - { - id: '03', - label: '管理员', - active: false, - }, - ], - }, - { - title: '布局', - isMore: false, - isShowMore: false, - id: 1, - children: [ - { - id: 11, - label: '全部', - active: true, - }, - { - id: 12, - label: '默认', - active: false, - }, - { - id: 13, - label: '经典', - active: false, - }, - { - id: 14, - label: '横向', - active: false, - }, - { - id: 15, - label: '分栏', - active: false, - }, - ], - }, - { - title: '配置', - isMore: false, - isShowMore: false, - id: 2, - children: [ - { - id: 21, - label: '全部', - active: true, - }, - { - id: 22, - label: '开启 Breadcrumb', - active: false, - }, - { - id: 23, - label: '开启 Tags-View', - active: false, - }, - { - id: 24, - label: '固定 Header', - active: false, - }, - { - id: 25, - label: '侧边栏 Logo', - active: false, - }, - { - id: 26, - label: '开启折叠 NavMenu', - active: false, - }, - { - id: 27, - label: '开启一个 NavMenu 展开', - active: false, - }, - { - id: 28, - label: '登录用户头像', - active: false, - }, - ], - }, -]; - -// 列表数据 -export const filterList = [ - { - img: 'http://news.sznews.com/pic/2020-08/14/9d9c9a60-f0af-41aa-b617-683b07c87642.jpg', - title: '嘉陵江2020年第1号洪水”在嘉陵江支流涪江形成', - evaluate: (Math.random() * 10).toFixed(2), - collection: (Math.random() * 100).toFixed(2), - price: (Math.random() * 10).toFixed(2), - monSales: (Math.random() * 20).toFixed(2), - id: 1, - }, - { - img: 'http://www.sznews.com/news/pic/2020-08/13/0ea47d3c-feb9-4bd7-8597-a8a373aa6340c6ec12c7-3b33-4528-91a6-85ec8ca1df67_watermark.png', - title: '让《民法典》走近群众 盐田街道开展人民调解宣传活动', - evaluate: (Math.random() * 10).toFixed(2), - collection: (Math.random() * 100).toFixed(2), - price: (Math.random() * 10).toFixed(2), - monSales: (Math.random() * 20).toFixed(2), - id: 2, - }, - { - img: 'http://www.sznews.com/photo/pic/2020-08/12/a08d6eb0-1d53-4f76-a313-ad3e5d701f98.jpg', - title: '记者手记:可可西里,“挪”向“藏羚羊大产房”的14个半小时', - evaluate: (Math.random() * 10).toFixed(2), - collection: (Math.random() * 100).toFixed(2), - price: (Math.random() * 10).toFixed(2), - monSales: (Math.random() * 20).toFixed(2), - id: 3, - }, - { - img: 'http://www.sznews.com/photo/pic/2020-08/11/43cc0e14-9bca-45b9-9a8b-342e09d6a4c7.jpg', - title: '以优异成绩庆祝深圳经济特区建立40周年', - evaluate: (Math.random() * 10).toFixed(2), - collection: (Math.random() * 100).toFixed(2), - price: (Math.random() * 10).toFixed(2), - monSales: (Math.random() * 20).toFixed(2), - id: 4, - }, - { - img: 'http://www.sznews.com/photo/pic/2020-08/11/a4dc322b-68ec-40e6-8906-3124142c3e49.jpg', - title: '草原上的“太阳姑娘”', - evaluate: (Math.random() * 10).toFixed(2), - collection: (Math.random() * 100).toFixed(2), - price: (Math.random() * 10).toFixed(2), - monSales: (Math.random() * 20).toFixed(2), - id: 5, - }, - { - img: 'http://www.sznews.com/zhuanti/pic/2020-08/07/57f087b4-4812-46cc-adb9-ead73621284e.png', - title: '奇观天下|带你走进非洲野生动物观光第一目的地', - evaluate: (Math.random() * 10).toFixed(2), - collection: (Math.random() * 100).toFixed(2), - price: (Math.random() * 10).toFixed(2), - monSales: (Math.random() * 20).toFixed(2), - id: 6, - }, - { - img: 'http://news.sznews.com/pic/2020-09/02/t2_(101X54X600X335)7cd39301-d9cf-45f1-91c3-9575b1e5ce0e.jpg.2', - title: '五角大楼发布“中国军力报告” 华春莹: 罔顾事实,充满偏见', - evaluate: (Math.random() * 10).toFixed(2), - collection: (Math.random() * 100).toFixed(2), - price: (Math.random() * 10).toFixed(2), - monSales: (Math.random() * 20).toFixed(2), - id: 7, - }, - { - img: 'http://news.sznews.com/pic/2020-09/02/b8b41d9c-0508-4498-8d37-6e597493769f.jpg', - title: '最新地铁消息汇总:4号线北延、2号线三期、8号线一期等今年通车', - evaluate: (Math.random() * 10).toFixed(2), - collection: (Math.random() * 100).toFixed(2), - price: (Math.random() * 10).toFixed(2), - monSales: (Math.random() * 20).toFixed(2), - id: 8, - }, - { - img: 'http://www.sznews.com/photo/pic/2020-08/10/1635374c-f4d6-475c-ac47-1334176f365d.png', - title: '9月1日深圳新增5例无症状感染者!钟南山这段话冲上热搜!', - evaluate: (Math.random() * 10).toFixed(2), - collection: (Math.random() * 100).toFixed(2), - price: (Math.random() * 10).toFixed(2), - monSales: (Math.random() * 20).toFixed(2), - id: 9, - }, - { - img: 'http://www.sznews.com/news/pic/2020-08/13/646e5458-92b7-4636-9940-9b0799babfe1.png', - title: '全能“小福宝” 为文明社区建设添砖加瓦', - evaluate: (Math.random() * 10).toFixed(2), - collection: (Math.random() * 100).toFixed(2), - price: (Math.random() * 10).toFixed(2), - monSales: (Math.random() * 20).toFixed(2), - id: 10, - }, -]; diff --git a/src/views/pages/formAdapt/index.vue b/src/views/pages/formAdapt/index.vue deleted file mode 100644 index 3bbfe04..0000000 --- a/src/views/pages/formAdapt/index.vue +++ /dev/null @@ -1,114 +0,0 @@ -<template> - <div class="form-adapt-container"> - <el-card shadow="hover" header="表单自适应演示(改变窗口查看效果)"> - <el-form :model="form" size="default" label-width="100px" class="mt35 mb35"> - <el-row :gutter="35"> - <el-col :xs="24" :sm="12" :md="8" :lg="6" :xl="4" class="mb20"> - <el-form-item label="姓名"> - <el-input v-model="form.name" placeholder="请输入姓名" clearable></el-input> - </el-form-item> - </el-col> - <el-col :xs="24" :sm="12" :md="8" :lg="6" :xl="4" class="mb20"> - <el-form-item label="用户归属部门"> - <el-input v-model="form.email" placeholder="请输入用户归属部门" clearable></el-input> - </el-form-item> - </el-col> - <el-col :xs="24" :sm="12" :md="8" :lg="6" :xl="4" class="mb20"> - <el-form-item label="登陆账户名"> - <el-input v-model="form.autograph" placeholder="请输入登陆账户名" clearable></el-input> - </el-form-item> - </el-col> - <el-col :xs="24" :sm="12" :md="8" :lg="6" :xl="4" class="mb20"> - <el-form-item label="职务"> - <el-select v-model="form.occupation" placeholder="请选择职务" clearable class="w100"> - <el-option label="计算机 / 互联网 / 通信" value="1"></el-option> - <el-option label="生产 / 工艺 / 制造" value="2"></el-option> - <el-option label="医疗 / 护理 / 制药" value="3"></el-option> - </el-select> - </el-form-item> - </el-col> - <el-col :xs="24" :sm="12" :md="8" :lg="6" :xl="4" class="mb20"> - <el-form-item label="手机"> - <el-input v-model="form.phone" placeholder="请输入手机" clearable></el-input> - </el-form-item> - </el-col> - <el-col :xs="24" :sm="12" :md="8" :lg="6" :xl="4" class="mb20"> - <el-form-item label="性别"> - <el-select v-model="form.sex" placeholder="请选择性别" clearable class="w100"> - <el-option label="男" value="1"></el-option> - <el-option label="女" value="2"></el-option> - </el-select> - </el-form-item> - </el-col> - <el-col :xs="24" :sm="12" :md="8" :lg="6" :xl="4" class="mb20"> - <el-form-item label="登录密码"> - <el-input v-model="form.phone1" placeholder="请输入登录密码" clearable></el-input> - </el-form-item> - </el-col> - <el-col :xs="24" :sm="12" :md="8" :lg="6" :xl="4" class="mb20"> - <el-form-item label="权限角色"> - <el-input v-model="form.phone2" placeholder="请输入权限角色" clearable></el-input> - </el-form-item> - </el-col> - <el-col :xs="24" :sm="12" :md="8" :lg="6" :xl="4" class="mb20"> - <el-form-item label="创建用户"> - <el-input v-model="form.phone3" placeholder="请输入创建用户" clearable></el-input> - </el-form-item> - </el-col> - <el-col :xs="24" :sm="12" :md="8" :lg="6" :xl="4" class="mb20"> - <el-form-item label="修改用户"> - <el-input v-model="form.phone4" placeholder="请输入修改用户" clearable></el-input> - </el-form-item> - </el-col> - <el-col :xs="24" :sm="12" :md="8" :lg="6" :xl="4" class="mb20"> - <el-form-item label="所属用户"> - <el-input v-model="form.phone5" placeholder="请输入所属用户" clearable></el-input> - </el-form-item> - </el-col> - <el-col :xs="24" :sm="12" :md="8" :lg="6" :xl="4" class="mb20"> - <el-form-item label="所属部门"> - <el-input v-model="form.phone6" placeholder="请输入所属部门" clearable></el-input> - </el-form-item> - </el-col> - <el-col :xs="24" :sm="24" :md="24" :lg="24" :xl="24"> - <el-form-item> - <el-button type="primary"> - <SvgIcon name="iconfont icon-biaodan" /> - 更新个人信息 - </el-button> - </el-form-item> - </el-col> - </el-row> - </el-form> - </el-card> - </div> -</template> - -<script lang="ts"> -import { toRefs, reactive, defineComponent } from 'vue'; - -export default defineComponent({ - name: 'pagesFormAdapt', - setup() { - const state = reactive({ - form: { - name: '', - email: '', - autograph: '', - occupation: '', - phone: '', - sex: '', - phone1: '', - phone2: '', - phone3: '', - phone4: '', - phone5: '', - phone6: '', - }, - }); - return { - ...toRefs(state), - }; - }, -}); -</script> diff --git a/src/views/pages/formI18n/index.vue b/src/views/pages/formI18n/index.vue deleted file mode 100644 index b9fe6b8..0000000 --- a/src/views/pages/formI18n/index.vue +++ /dev/null @@ -1,59 +0,0 @@ -<template> - <div class="form-i18n-container"> - <el-card shadow="hover" header="表单国际化演示(不适用于动态项 form-item)"> - <div style="text-align: center; margin-top: 15px"> - <el-radio-group v-model="radio" size="default" @change="onRadioChange"> - <el-radio-button label="zh-cn">中文简体</el-radio-button> - <el-radio-button label="en">英文</el-radio-button> - <el-radio-button label="zh-tw">中文繁体</el-radio-button> - </el-radio-group> - </div> - <el-form :model="form" size="default" label-width="100px" class="mt35 mb35"> - <el-row :gutter="35"> - <el-col :xs="24" :sm="12" :md="8" :lg="8" :xl="8" class="mb20"> - <el-form-item :label="$t('message.formI18nLabel.name')"> - <el-input v-model="form.name" :placeholder="$t('message.formI18nPlaceholder.name')" clearable></el-input> - </el-form-item> - </el-col> - <el-col :xs="24" :sm="12" :md="8" :lg="8" :xl="8" class="mb20"> - <el-form-item :label="$t('message.formI18nLabel.email')"> - <el-input v-model="form.email" :placeholder="$t('message.formI18nPlaceholder.email')" clearable></el-input> - </el-form-item> - </el-col> - <el-col :xs="24" :sm="12" :md="8" :lg="8" :xl="8" class="mb20"> - <el-form-item :label="$t('message.formI18nLabel.autograph')"> - <el-input v-model="form.autograph" :placeholder="$t('message.formI18nPlaceholder.autograph')" clearable></el-input> - </el-form-item> - </el-col> - </el-row> - </el-form> - </el-card> - </div> -</template> - -<script lang="ts"> -import { toRefs, reactive, defineComponent, getCurrentInstance } from 'vue'; - -export default defineComponent({ - name: 'pagesFormI18n', - setup() { - const { proxy } = <any>getCurrentInstance(); - const state = reactive({ - radio: 'zh-cn', - form: { - name: '', - email: '', - autograph: '', - }, - }); - // 单选框改变时 - const onRadioChange = () => { - proxy.$i18n.locale = state.radio; - }; - return { - onRadioChange, - ...toRefs(state), - }; - }, -}); -</script> diff --git a/src/views/pages/formRules/component/formRulesOne.vue b/src/views/pages/formRules/component/formRulesOne.vue deleted file mode 100644 index ff9e568..0000000 --- a/src/views/pages/formRules/component/formRulesOne.vue +++ /dev/null @@ -1,68 +0,0 @@ -<template> - <div class="form-rules-one-container"> - <el-form :model="form" :rules="rules" ref="formRulesOneRef" size="default" label-width="100px" class="mt35"> - <el-row :gutter="35"> - <el-col :xs="24" :sm="12" :md="8" :lg="6" :xl="4" class="mb20"> - <el-form-item label="姓名" prop="name"> - <el-input v-model="form.name" placeholder="请输入姓名" clearable></el-input> - </el-form-item> - </el-col> - <el-col :xs="24" :sm="12" :md="8" :lg="6" :xl="4" class="mb20"> - <el-form-item label="邮箱" prop="email"> - <el-input v-model="form.email" placeholder="请输入用户邮箱" clearable></el-input> - </el-form-item> - </el-col> - <el-col :xs="24" :sm="12" :md="8" :lg="6" :xl="4" class="mb20"> - <el-form-item label="登陆账户名" prop="autograph"> - <el-input v-model="form.autograph" placeholder="请输入登陆账户名" clearable></el-input> - </el-form-item> - </el-col> - <el-col :xs="24" :sm="12" :md="8" :lg="6" :xl="4" class="mb20"> - <el-form-item label="职务" prop="occupation"> - <el-select v-model="form.occupation" placeholder="请选择职务" clearable class="w100"> - <el-option label="计算机 / 互联网 / 通信" value="1"></el-option> - <el-option label="生产 / 工艺 / 制造" value="2"></el-option> - <el-option label="医疗 / 护理 / 制药" value="3"></el-option> - </el-select> - </el-form-item> - </el-col> - </el-row> - </el-form> - </div> -</template> - -<script lang="ts"> -import { toRefs, reactive, onMounted, defineComponent } from 'vue'; - -export default defineComponent({ - name: 'pagesFormRulesOne', - props: { - data: { - type: Object, - default: () => {}, - }, - }, - setup(props) { - const state = reactive({ - form: { name: '', email: '', autograph: '', occupation: '' }, - rules: { - name: { required: true, message: '请输入姓名', trigger: 'blur' }, - email: { required: true, message: '请输入用户邮箱', trigger: 'blur' }, - autograph: { required: true, message: '请输入登陆账户名', trigger: 'blur' }, - occupation: { required: true, message: '请选择职务', trigger: 'change' }, - }, - }); - // 赋值回显 - const initForm = () => { - state.form = <any>props.data; - }; - // 页面加载时 - onMounted(() => { - initForm(); - }); - return { - ...toRefs(state), - }; - }, -}); -</script> diff --git a/src/views/pages/formRules/component/formRulesThree.vue b/src/views/pages/formRules/component/formRulesThree.vue deleted file mode 100644 index 145aed4..0000000 --- a/src/views/pages/formRules/component/formRulesThree.vue +++ /dev/null @@ -1,50 +0,0 @@ -<template> - <div class="form-rules-three-container"> - <el-form :model="form" :rules="rules" ref="formRulesThreeRef" size="default" label-width="100px" class="mt35"> - <el-row :gutter="35"> - <el-col :xs="24" :sm="12" :md="8" :lg="6" :xl="4" class="mb20"> - <el-form-item label="创建用户" prop="createUser"> - <el-input v-model="form.createUser" placeholder="请输入创建用户" clearable></el-input> - </el-form-item> - </el-col> - <el-col :xs="24" :sm="12" :md="8" :lg="6" :xl="4" class="mb20"> - <el-form-item label="修改用户" prop="editUser"> - <el-input v-model="form.editUser" placeholder="请输入修改用户" clearable></el-input> - </el-form-item> - </el-col> - <el-col :xs="24" :sm="12" :md="8" :lg="6" :xl="4" class="mb20"> - <el-form-item label="所属用户" prop="user"> - <el-input v-model="form.user" placeholder="请输入所属用户" clearable></el-input> - </el-form-item> - </el-col> - <el-col :xs="24" :sm="12" :md="8" :lg="6" :xl="4" class="mb20"> - <el-form-item label="所属部门" prop="department"> - <el-input v-model="form.department" placeholder="请输入所属部门" clearable></el-input> - </el-form-item> - </el-col> - </el-row> - </el-form> - </div> -</template> - -<script lang="ts"> -import { toRefs, reactive, defineComponent } from 'vue'; - -export default defineComponent({ - name: 'pagesFormRulesThree', - setup() { - const state = reactive({ - form: { createUser: '', editUser: '', user: '', department: '' }, - rules: { - createUser: { required: true, message: '请输入创建用户', trigger: 'blur' }, - editUser: { required: true, message: '请输入修改用户', trigger: 'blur' }, - user: { required: true, message: '请输入所属用户', trigger: 'blur' }, - department: { required: true, message: '请输入所属部门', trigger: 'blur' }, - }, - }); - return { - ...toRefs(state), - }; - }, -}); -</script> diff --git a/src/views/pages/formRules/component/formRulesTwo.vue b/src/views/pages/formRules/component/formRulesTwo.vue deleted file mode 100644 index fcb0604..0000000 --- a/src/views/pages/formRules/component/formRulesTwo.vue +++ /dev/null @@ -1,52 +0,0 @@ -<template> - <div class="form-rules-two-container"> - <el-form :model="form" :rules="rules" ref="formRulesTwoRef" size="default" label-width="100px" class="mt35"> - <el-row :gutter="35"> - <el-col :xs="24" :sm="12" :md="8" :lg="6" :xl="4" class="mb20"> - <el-form-item label="手机" prop="phone"> - <el-input v-model="form.phone" placeholder="请输入手机" clearable></el-input> - </el-form-item> - </el-col> - <el-col :xs="24" :sm="12" :md="8" :lg="6" :xl="4" class="mb20"> - <el-form-item label="性别"> - <el-select v-model="form.sex" placeholder="请选择性别" clearable class="w100"> - <el-option label="男" value="1"></el-option> - <el-option label="女" value="2"></el-option> - </el-select> - </el-form-item> - </el-col> - <el-col :xs="24" :sm="12" :md="8" :lg="6" :xl="4" class="mb20"> - <el-form-item label="登录密码" prop="password"> - <el-input v-model="form.password" placeholder="请输入登录密码" clearable></el-input> - </el-form-item> - </el-col> - <el-col :xs="24" :sm="12" :md="8" :lg="6" :xl="4" class="mb20"> - <el-form-item label="权限角色" prop="auth"> - <el-input v-model="form.auth" placeholder="请输入权限角色" clearable></el-input> - </el-form-item> - </el-col> - </el-row> - </el-form> - </div> -</template> - -<script lang="ts"> -import { toRefs, reactive, defineComponent } from 'vue'; - -export default defineComponent({ - name: 'pagesFormRulesTwo', - setup() { - const state = reactive({ - form: { phone: '', sex: '', password: '', auth: '' }, - rules: { - phone: { required: true, message: '请输入手机', trigger: 'blur' }, - password: { required: true, message: '请输入登录密码', trigger: 'blur' }, - auth: { required: true, message: '请输入权限角色', trigger: 'blur' }, - }, - }); - return { - ...toRefs(state), - }; - }, -}); -</script> diff --git a/src/views/pages/formRules/index.vue b/src/views/pages/formRules/index.vue deleted file mode 100644 index 9c24343..0000000 --- a/src/views/pages/formRules/index.vue +++ /dev/null @@ -1,80 +0,0 @@ -<template> - <div class="form-rules-container"> - <el-card shadow="hover" header="表单组件1"> <FormRulesOne :data="formRulesOneData" ref="pagesFormRulesOneRef" /></el-card> - <el-card shadow="hover" header="表单组件2" class="mt15"><FormRulesTwo ref="pagesFormRulesTwoRef" /> </el-card> - <el-card shadow="hover" header="表单组件3" class="mt15"> <FormRulesThree ref="pagesFormRulesThreeRef" /></el-card> - <el-row class="flex mt15"> - <div class="flex-margin"> - <el-button size="default" @click="onResetForm"> - <SvgIcon name="ele-RefreshRight" /> - 重置表单 - </el-button> - <el-button size="default" type="primary" @click="onSubmitForm"> - <SvgIcon name="iconfont icon-shuxing" /> - 验证表单 - </el-button> - </div> - </el-row> - </div> -</template> - -<script lang="ts"> -import { toRefs, reactive, defineComponent, getCurrentInstance } from 'vue'; -import { ElMessage } from 'element-plus'; -import FormRulesOne from '/@/views/pages/formRules/component/formRulesOne.vue'; -import FormRulesTwo from '/@/views/pages/formRules/component/formRulesTwo.vue'; -import FormRulesThree from '/@/views/pages/formRules/component/formRulesThree.vue'; - -export default defineComponent({ - name: 'pagesFormRules', - components: { - FormRulesOne, - FormRulesTwo, - FormRulesThree, - }, - setup() { - const { proxy } = <any>getCurrentInstance(); - const state = reactive({ - formRulesOneData: { - name: 'lyt', - email: 'lyt123@.com', - autograph: 'lyt123456', - occupation: '1', - }, - }); - // 表单组件验证 - const formRulesValidate = (pageRef: string, sonRef: string) => { - return new Promise((resolve) => { - proxy.$refs[pageRef].$refs[sonRef].validate((valid: boolean) => { - if (valid) resolve(valid); - }); - }); - }; - // 表单组件重置 - const formRulesResetFields = () => { - proxy.$refs.pagesFormRulesOneRef.$refs.formRulesOneRef.resetFields(); - proxy.$refs.pagesFormRulesTwoRef.$refs.formRulesTwoRef.resetFields(); - proxy.$refs.pagesFormRulesThreeRef.$refs.formRulesThreeRef.resetFields(); - }; - // 验证表单 - const onSubmitForm = () => { - Promise.all([ - formRulesValidate('pagesFormRulesOneRef', 'formRulesOneRef'), - formRulesValidate('pagesFormRulesTwoRef', 'formRulesTwoRef'), - formRulesValidate('pagesFormRulesThreeRef', 'formRulesThreeRef'), - ]).then(() => { - ElMessage.success('表单全部验证成功'); - }); - }; - // 重置表单 - const onResetForm = () => { - formRulesResetFields(); - }; - return { - onSubmitForm, - onResetForm, - ...toRefs(state), - }; - }, -}); -</script> diff --git a/src/views/pages/iocnfont/index.vue b/src/views/pages/iocnfont/index.vue deleted file mode 100644 index 48a44f9..0000000 --- a/src/views/pages/iocnfont/index.vue +++ /dev/null @@ -1,87 +0,0 @@ -<template> - <div class="iconfont-container"> - <el-card shadow="hover" :header="`iconfont 字体图标(自动载入):${sheetsIconList.length}个`"> - <el-row class="iconfont-row"> - <el-col :xs="12" :sm="8" :md="6" :lg="4" :xl="2" v-for="(v, k) in sheetsIconList" :key="k"> - <div class="iconfont-warp"> - <div class="flex-margin"> - <div class="iconfont-warp-value"> - <i :class="v" class="iconfont"></i> - </div> - <div class="iconfont-warp-label mt10">{{ v }}</div> - </div> - </div> - </el-col> - </el-row> - </el-card> - </div> -</template> - -<script lang="ts"> -import { toRefs, reactive, onMounted, defineComponent } from 'vue'; -import initIconfont from '/@/utils/getStyleSheets'; - -export default defineComponent({ - name: 'pagesIocnfont', - setup() { - const state = reactive({ - sheetsIconList: [], - }); - // 初始化获取 css 样式,这里使用阿里的图标(记得加上前缀 `iconfont`),其它第三方请自行做判断 - const initGetStyleSheets = () => { - initIconfont.ali().then((res: any) => (state.sheetsIconList = res)); - }; - // 页面加载时 - onMounted(() => { - initGetStyleSheets(); - }); - return { - ...toRefs(state), - }; - }, -}); -</script> - -<style scoped lang="scss"> -.iconfont-container { - .iconfont-row { - border-top: 1px solid var(--next-border-color-light); - border-left: 1px solid var(--next-border-color-light); - .iconfont-warp { - text-align: center; - border-right: 1px solid var(--next-border-color-light); - border-bottom: 1px solid var(--next-border-color-light); - height: 120px; - overflow: hidden; - display: flex; - transition: all 0.3s ease; - &:hover { - box-shadow: 0 2px 12px var(--next-color-dark-hover); - cursor: pointer; - transition: all 0.3s ease; - .iconfont-warp-value { - i { - color: var(--el-color-primary); - transition: all 0.3s ease; - } - } - .iconfont-warp-label { - color: var(--el-color-primary); - transition: all 0.3s ease; - } - } - .iconfont-warp-value { - i { - color: #606266; - font-size: 32px; - transition: all 0.3s ease; - } - } - .iconfont-warp-label { - color: #99a9bf; - transition: all 0.3s ease; - } - } - } -} -</style> diff --git a/src/views/pages/lazyImg/index.vue b/src/views/pages/lazyImg/index.vue deleted file mode 100644 index ad63f8a..0000000 --- a/src/views/pages/lazyImg/index.vue +++ /dev/null @@ -1,194 +0,0 @@ -<template> - <div class="lazy-img-container"> - <el-card shadow="hover" header="图片懒加载演示(F12 切换到 Network Img下进行图片加载查看)"> - <div class="flex-warp" v-if="tableData.data.length > 0"> - <el-row :gutter="15"> - <el-col :xs="24" :sm="12" :md="8" :lg="6" :xl="4" class="mb15" v-for="(v, k) in tableData.data" :key="k" @click="onTableItemClick(v)"> - <div class="flex-warp-item"> - <div class="flex-warp-item-box"> - <div class="item-img" v-loading="v.loading"> - <img :data-img="v.img" :data-key="k" :data-lazy-img-list="k" /> - </div> - <div class="item-txt"> - <div class="item-txt-title">{{ v.title }}</div> - <div class="item-txt-other"> - <div style="width: 100%"> - <div class="item-txt-msg mb10"> - <span>评价 {{ v.evaluate }}</span> - <span class="ml10">收藏 {{ v.collection }}</span> - </div> - <div class="item-txt-msg item-txt-price"> - <span class="font-price"> - <span>¥</span> - <span class="font">{{ v.price }}</span> - </span> - <span>月销{{ v.monSales }}笔</span> - </div> - </div> - </div> - </div> - </div> - </div> - </el-col> - </el-row> - </div> - <el-empty v-else description="暂无数据"></el-empty> - <template v-if="tableData.data.length > 0"> - <el-pagination - style="text-align: right" - background - @size-change="onHandleSizeChange" - @current-change="onHandleCurrentChange" - :page-sizes="[10, 20, 30]" - :current-page="tableData.param.pageNum" - :page-size="tableData.param.pageSize" - layout="total, sizes, prev, pager, next, jumper" - :total="tableData.total" - > - </el-pagination> - </template> - </el-card> - </div> -</template> - -<script lang="ts"> -import { toRefs, reactive, onMounted, defineComponent } from 'vue'; -import { useRouter } from 'vue-router'; -import other from '/@/utils/other'; -import { filterList } from './mock'; - -export default defineComponent({ - name: 'pagesListAdapt', - setup() { - const router = useRouter(); - const state = reactive({ - tableData: { - data: filterList, - total: 99, - loading: false, - param: { - pageNum: 1, - pageSize: 10, - }, - }, - }); - // 当前列表项点击 - const onTableItemClick = (v: any) => { - router.push({ - path: '/pages/filteringDetails', - query: { id: v.id }, - }); - }; - // 分页点击 - const onHandleSizeChange = (val: number) => { - state.tableData.param.pageSize = val; - }; - // 分页点击 - const onHandleCurrentChange = (val: number) => { - state.tableData.param.pageNum = val; - }; - // 页面加载时 - onMounted(() => { - other.lazyImg('[data-lazy-img-list]', state.tableData.data); - }); - return { - onTableItemClick, - onHandleSizeChange, - onHandleCurrentChange, - ...toRefs(state), - }; - }, -}); -</script> - -<style scoped lang="scss"> -.lazy-img-container { - .flex-warp { - display: flex; - flex-wrap: wrap; - align-content: flex-start; - margin: 0 -5px; - .flex-warp-item { - padding: 5px; - width: 100%; - height: 360px; - .flex-warp-item-box { - border: 1px solid var(--next-border-color-light); - width: 100%; - height: 100%; - border-radius: 2px; - display: flex; - flex-direction: column; - transition: all 0.3s ease; - &:hover { - cursor: pointer; - border: 1px solid var(--el-color-primary); - transition: all 0.3s ease; - box-shadow: 0 2px 12px 0 rgba(0, 0, 0, 0.03); - .item-txt-title { - color: var(--el-color-primary) !important; - transition: all 0.3s ease; - } - .item-img { - img { - transition: all 0.3s ease; - transform: translateZ(0) scale(1.05); - } - } - } - .item-img { - width: 100%; - height: 215px; - overflow: hidden; - img { - transition: all 0.3s ease; - width: 100%; - height: 100%; - } - } - .item-txt { - flex: 1; - padding: 15px; - display: flex; - flex-direction: column; - overflow: hidden; - .item-txt-title { - text-overflow: ellipsis; - overflow: hidden; - -webkit-line-clamp: 2; - -webkit-box-orient: vertical; - display: -webkit-box; - color: #666666; - transition: all 0.3s ease; - &:hover { - color: var(--el-color-primary); - text-decoration: underline; - transition: all 0.3s ease; - } - } - .item-txt-other { - flex: 1; - align-items: flex-end; - display: flex; - .item-txt-msg { - font-size: 12px; - color: #8d8d91; - } - .item-txt-price { - display: flex; - justify-content: space-between; - align-items: center; - .font-price { - color: #ff5000; - .font { - font-size: 22px; - } - } - } - } - } - } - } - } -} -</style> diff --git a/src/views/pages/lazyImg/mock.ts b/src/views/pages/lazyImg/mock.ts deleted file mode 100644 index 4eb3d29..0000000 --- a/src/views/pages/lazyImg/mock.ts +++ /dev/null @@ -1,313 +0,0 @@ -// 列表数据 -export const filterList = [ - { - img: 'https://news.sznews.com/pic/2021-03/09/e37326cc-4583-48f3-aa00-ecc2392d319d.jpg', - title: '36分钟,深圳平均通勤时间出炉!GDP10强城市中仅输杭州', - evaluate: (Math.random() * 10).toFixed(2), - collection: (Math.random() * 100).toFixed(2), - price: (Math.random() * 10).toFixed(2), - monSales: (Math.random() * 20).toFixed(2), - id: 1, - loading: true, - }, - { - img: 'http://news.sznews.com/pic/2021-03/09/78cf72b6-e2d9-459d-a368-470414a027f4679cf4ea-26fa-48c8-9fee-c2d092a91400.png', - title: '为爱而动,“红色鹊桥”三八妇女节交友联谊活动助力深圳女孩脱单', - evaluate: (Math.random() * 10).toFixed(2), - collection: (Math.random() * 100).toFixed(2), - price: (Math.random() * 10).toFixed(2), - monSales: (Math.random() * 20).toFixed(2), - id: 2, - loading: true, - }, - { - img: 'http://news.sznews.com/pic/2021-03/09/1faf3c6e-1250-4e6b-b072-4a331553e027.jpg', - title: '粤桂协作“背水一战” 解决广西大化县3.7万人饮水难题', - evaluate: (Math.random() * 10).toFixed(2), - collection: (Math.random() * 100).toFixed(2), - price: (Math.random() * 10).toFixed(2), - monSales: (Math.random() * 20).toFixed(2), - id: 3, - loading: true, - }, - { - img: 'https://news.sznews.com/pic/2021-03/09/9fcf6dd4-1e80-4497-bdc9-83dc7246d170.jpg.2', - title: '城镇就业女性平均薪酬6847元 女性职场渗透率提升', - evaluate: (Math.random() * 10).toFixed(2), - collection: (Math.random() * 100).toFixed(2), - price: (Math.random() * 10).toFixed(2), - monSales: (Math.random() * 20).toFixed(2), - id: 4, - loading: true, - }, - { - img: 'https://news.sznews.com/pic/2021-03/09/1bd78227-4126-4a43-bdf6-48ead6edd1bf.jpg.2', - title: '深圳:实现“从0到1”源头创新,推进大湾区综合性国家科学中心建设!', - evaluate: (Math.random() * 10).toFixed(2), - collection: (Math.random() * 100).toFixed(2), - price: (Math.random() * 10).toFixed(2), - monSales: (Math.random() * 20).toFixed(2), - id: 5, - loading: true, - }, - { - img: 'http://news.sznews.com/pic/2021-03/08/9ea943a3-3ae8-4f49-8296-711ec36ef8c6_watermark.png', - title: '煖声音第126期|愿你有诗酒趁年华的洒脱,也有岁月沉淀后的坚定从容', - evaluate: (Math.random() * 10).toFixed(2), - collection: (Math.random() * 100).toFixed(2), - price: (Math.random() * 10).toFixed(2), - monSales: (Math.random() * 20).toFixed(2), - id: 6, - loading: true, - }, - { - img: 'https://news.sznews.com/pic/2021-03/08/a95ba232-1422-4f7e-b85f-c61d486c8659.jpg.2', - title: '姐妹们一起来吐槽,最不能接受男人的缺点!', - evaluate: (Math.random() * 10).toFixed(2), - collection: (Math.random() * 100).toFixed(2), - price: (Math.random() * 10).toFixed(2), - monSales: (Math.random() * 20).toFixed(2), - id: 7, - loading: true, - }, - { - img: 'http://news.sznews.com/pic/2021-03/08/76816bf0-3899-4c7e-bc6e-079b5ba8725e.jpg', - title: '民生小事 | 手机遗落出租车 热心民警帮找回', - evaluate: (Math.random() * 10).toFixed(2), - collection: (Math.random() * 100).toFixed(2), - price: (Math.random() * 10).toFixed(2), - monSales: (Math.random() * 20).toFixed(2), - id: 8, - loading: true, - }, - { - img: 'https://news.sznews.com/pic/2021-03/08/28ed70d4-71f5-4abb-bf7b-0294bece9e43.jpg.2', - title: '“十三五”:深圳交上靓丽答卷 发展动力加快转换', - evaluate: (Math.random() * 10).toFixed(2), - collection: (Math.random() * 100).toFixed(2), - price: (Math.random() * 10).toFixed(2), - monSales: (Math.random() * 20).toFixed(2), - id: 9, - loading: true, - }, - { - img: 'http://news.sznews.com/pic/2021-03/05/d13ae31f-fd45-431a-b48e-c5895bbc193e.png', - title: '深圳湾公园一女子落水,三名男子接力及时施救', - evaluate: (Math.random() * 10).toFixed(2), - collection: (Math.random() * 100).toFixed(2), - price: (Math.random() * 10).toFixed(2), - monSales: (Math.random() * 20).toFixed(2), - id: 10, - loading: true, - }, - { - img: 'http://z0.sinaimg.cn/auto/resize?size=235_156&img=http://n.sinaimg.cn/spider20210704/653/w930h523/20210704/d5d2-krwipas6444058.jpg', - title: '36分钟,深圳平均通勤时间出炉!GDP10强城市中仅输杭州', - evaluate: (Math.random() * 10).toFixed(2), - collection: (Math.random() * 100).toFixed(2), - price: (Math.random() * 10).toFixed(2), - monSales: (Math.random() * 20).toFixed(2), - id: 1, - loading: true, - }, - { - img: 'http://z0.sinaimg.cn/auto/resize?size=235_156&img=http://n.sinaimg.cn/spider20210704/766/w930h636/20210704/b1ae-krwipas6332914.jpg', - title: '为爱而动,“红色鹊桥”三八妇女节交友联谊活动助力深圳女孩脱单', - evaluate: (Math.random() * 10).toFixed(2), - collection: (Math.random() * 100).toFixed(2), - price: (Math.random() * 10).toFixed(2), - monSales: (Math.random() * 20).toFixed(2), - id: 2, - loading: true, - }, - { - img: 'http://z0.sinaimg.cn/auto/resize?size=235_156&img=http://n.sinaimg.cn/spider20210704/750/w930h620/20210704/2886-krwipas6264821.jpg', - title: '粤桂协作“背水一战” 解决广西大化县3.7万人饮水难题', - evaluate: (Math.random() * 10).toFixed(2), - collection: (Math.random() * 100).toFixed(2), - price: (Math.random() * 10).toFixed(2), - monSales: (Math.random() * 20).toFixed(2), - id: 3, - loading: true, - }, - { - img: 'http://z0.sinaimg.cn/auto/resize?size=235_156&img=http://n.sinaimg.cn/spider20210704/750/w930h620/20210704/767c-krwipas6387862.jpg', - title: '城镇就业女性平均薪酬6847元 女性职场渗透率提升', - evaluate: (Math.random() * 10).toFixed(2), - collection: (Math.random() * 100).toFixed(2), - price: (Math.random() * 10).toFixed(2), - monSales: (Math.random() * 20).toFixed(2), - id: 4, - loading: true, - }, - { - img: 'http://z0.sinaimg.cn/auto/resize?size=235_156&img=http://n.sinaimg.cn/spider20210704/111/w1024h687/20210704/1f65-krwipas5871436.jpg', - title: '盛夏的那考河湿地公园!', - evaluate: (Math.random() * 10).toFixed(2), - collection: (Math.random() * 100).toFixed(2), - price: (Math.random() * 10).toFixed(2), - monSales: (Math.random() * 20).toFixed(2), - id: 5, - loading: true, - }, - { - img: 'http://z0.sinaimg.cn/auto/resize?size=235_156&img=http://n.sinaimg.cn/spider20210704/657/w930h527/20210704/7eae-krwipas5866609.jpg', - title: '煖声音第126期|愿你有诗酒趁年华的洒脱,也有岁月沉淀后的坚定从容', - evaluate: (Math.random() * 10).toFixed(2), - collection: (Math.random() * 100).toFixed(2), - price: (Math.random() * 10).toFixed(2), - monSales: (Math.random() * 20).toFixed(2), - id: 6, - loading: true, - }, - { - img: 'http://z0.sinaimg.cn/auto/resize?size=235_156&img=http://n.sinaimg.cn/spider20210703/760/w930h630/20210703/124e-krwipas5596390.jpg', - title: '姐妹们一起来吐槽,最不能接受男人的缺点!', - evaluate: (Math.random() * 10).toFixed(2), - collection: (Math.random() * 100).toFixed(2), - price: (Math.random() * 10).toFixed(2), - monSales: (Math.random() * 20).toFixed(2), - id: 7, - loading: true, - }, - { - img: 'http://z0.sinaimg.cn/auto/resize?size=235_156&img=http://n.sinaimg.cn/spider20210703/27/w930h697/20210703/9630-krwipas5514972.jpg', - title: '民生小事 | 手机遗落出租车 热心民警帮找回', - evaluate: (Math.random() * 10).toFixed(2), - collection: (Math.random() * 100).toFixed(2), - price: (Math.random() * 10).toFixed(2), - monSales: (Math.random() * 20).toFixed(2), - id: 8, - loading: true, - }, - { - img: 'http://z0.sinaimg.cn/auto/resize?size=235_156&img=http://n.sinaimg.cn/spider20210703/750/w930h620/20210703/2fe3-krwipas5388050.jpg', - title: '“十三五”:深圳交上靓丽答卷 发展动力加快转换', - evaluate: (Math.random() * 10).toFixed(2), - collection: (Math.random() * 100).toFixed(2), - price: (Math.random() * 10).toFixed(2), - monSales: (Math.random() * 20).toFixed(2), - id: 9, - loading: true, - }, - { - img: 'http://z0.sinaimg.cn/auto/resize?size=235_156&img=http://n.sinaimg.cn/spider20210703/724/w930h594/20210703/98b6-krwipas5234060.jpg', - title: '深圳湾公园一女子落水,三名男子接力及时施救', - evaluate: (Math.random() * 10).toFixed(2), - collection: (Math.random() * 100).toFixed(2), - price: (Math.random() * 10).toFixed(2), - monSales: (Math.random() * 20).toFixed(2), - id: 10, - loading: true, - }, - { - img: 'http://z0.sinaimg.cn/auto/resize?size=235_156&img=http://n.sinaimg.cn/spider20210703/750/w930h620/20210703/f765-krwipas5194727.jpg', - title: '36分钟,深圳平均通勤时间出炉!GDP10强城市中仅输杭州', - evaluate: (Math.random() * 10).toFixed(2), - collection: (Math.random() * 100).toFixed(2), - price: (Math.random() * 10).toFixed(2), - monSales: (Math.random() * 20).toFixed(2), - id: 1, - loading: true, - }, - { - img: 'http://z0.sinaimg.cn/auto/resize?size=235_156&img=http://n.sinaimg.cn/spider20210702/750/w930h620/20210702/5dde-krwipas4724976.jpg', - title: '为爱而动,“红色鹊桥”三八妇女节交友联谊活动助力深圳女孩脱单', - evaluate: (Math.random() * 10).toFixed(2), - collection: (Math.random() * 100).toFixed(2), - price: (Math.random() * 10).toFixed(2), - monSales: (Math.random() * 20).toFixed(2), - id: 2, - loading: true, - }, - { - img: 'http://z0.sinaimg.cn/auto/resize?size=235_156&img=http://n.sinaimg.cn/spider20210702/750/w930h620/20210702/f45e-krwipas4566804.jpg', - title: '粤桂协作“背水一战” 解决广西大化县3.7万人饮水难题', - evaluate: (Math.random() * 10).toFixed(2), - collection: (Math.random() * 100).toFixed(2), - price: (Math.random() * 10).toFixed(2), - monSales: (Math.random() * 20).toFixed(2), - id: 3, - loading: true, - }, - { - img: 'http://z0.sinaimg.cn/auto/resize?size=235_156&img=http://n.sinaimg.cn/spider20210702/750/w930h620/20210702/5579-krwipas4551382.jpg', - title: '城镇就业女性平均薪酬6847元 女性职场渗透率提升', - evaluate: (Math.random() * 10).toFixed(2), - collection: (Math.random() * 100).toFixed(2), - price: (Math.random() * 10).toFixed(2), - monSales: (Math.random() * 20).toFixed(2), - id: 4, - loading: true, - }, - { - img: 'http://z0.sinaimg.cn/auto/resize?size=235_156&img=http://n.sinaimg.cn/spider20210702/750/w930h620/20210702/7c75-krwipas4543661.jpg', - title: '深圳:实现“从0到1”源头创新,推进大湾区综合性国家科学中心建设!', - evaluate: (Math.random() * 10).toFixed(2), - collection: (Math.random() * 100).toFixed(2), - price: (Math.random() * 10).toFixed(2), - monSales: (Math.random() * 20).toFixed(2), - id: 5, - loading: true, - }, - { - img: 'http://z0.sinaimg.cn/auto/resize?size=235_156&img=http://n.sinaimg.cn/spider20210702/653/w930h523/20210702/ece2-krwipas4411140.jpg', - title: '煖声音第126期|愿你有诗酒趁年华的洒脱,也有岁月沉淀后的坚定从容', - evaluate: (Math.random() * 10).toFixed(2), - collection: (Math.random() * 100).toFixed(2), - price: (Math.random() * 10).toFixed(2), - monSales: (Math.random() * 20).toFixed(2), - id: 6, - loading: true, - }, - { - img: 'http://z0.sinaimg.cn/auto/resize?size=235_156&img=http://n.sinaimg.cn/spider20210702/750/w930h620/20210702/f5c2-krwipas4215211.jpg', - title: '姐妹们一起来吐槽,最不能接受男人的缺点!', - evaluate: (Math.random() * 10).toFixed(2), - collection: (Math.random() * 100).toFixed(2), - price: (Math.random() * 10).toFixed(2), - monSales: (Math.random() * 20).toFixed(2), - id: 7, - loading: true, - }, - { - img: 'http://z0.sinaimg.cn/auto/resize?size=235_156&img=http://n.sinaimg.cn/spider20210701/720/w930h590/20210701/eabc-krwipas3509204.jpg', - title: '民生小事 | 手机遗落出租车 热心民警帮找回', - evaluate: (Math.random() * 10).toFixed(2), - collection: (Math.random() * 100).toFixed(2), - price: (Math.random() * 10).toFixed(2), - monSales: (Math.random() * 20).toFixed(2), - id: 8, - loading: true, - }, - { - img: 'http://z0.sinaimg.cn/auto/resize?size=235_156&img=http://n.sinaimg.cn/spider20210701/797/w930h667/20210701/4667-krwipas3365057.jpg', - title: '“十三五”:深圳交上靓丽答卷 发展动力加快转换', - evaluate: (Math.random() * 10).toFixed(2), - collection: (Math.random() * 100).toFixed(2), - price: (Math.random() * 10).toFixed(2), - monSales: (Math.random() * 20).toFixed(2), - id: 9, - loading: true, - }, - { - img: 'http://z0.sinaimg.cn/auto/resize?size=235_156&img=http://n.sinaimg.cn/spider20210701/750/w930h620/20210701/baea-krwipas2976622.jpg', - title: '民众前往中共一大纪念馆参观', - evaluate: (Math.random() * 10).toFixed(2), - collection: (Math.random() * 100).toFixed(2), - price: (Math.random() * 10).toFixed(2), - monSales: (Math.random() * 20).toFixed(2), - id: 10, - loading: true, - }, - { - img: 'http://z0.sinaimg.cn/auto/resize?size=235_156&img=http://n.sinaimg.cn/spider20210630/617/w850h567/20210630/5c96-krwipas1819108.jpg', - title: '延吉灯光秀美轮美奂 市民徜徉璀璨夜景', - evaluate: (Math.random() * 10).toFixed(2), - collection: (Math.random() * 100).toFixed(2), - price: (Math.random() * 10).toFixed(2), - monSales: (Math.random() * 20).toFixed(2), - id: 10, - loading: true, - }, -]; diff --git a/src/views/pages/listAdapt/index.vue b/src/views/pages/listAdapt/index.vue deleted file mode 100644 index 15e27bc..0000000 --- a/src/views/pages/listAdapt/index.vue +++ /dev/null @@ -1,209 +0,0 @@ -<template> - <div class="list-adapt-container"> - <el-card shadow="hover" header="列表自适应演示(改变窗口查看效果)"> - <div class="flex-warp" v-if="tableData.data.length > 0"> - <el-row :gutter="15"> - <el-col :xs="24" :sm="12" :md="8" :lg="6" :xl="4" class="mb15" v-for="(v, k) in tableData.data" :key="k" @click="onTableItemClick(v)"> - <div class="flex-warp-item"> - <div class="flex-warp-item-box"> - <div class="item-img"> - <img :src="v.img" /> - </div> - <div class="item-txt"> - <div class="item-txt-title">{{ v.title }}</div> - <div class="item-txt-other"> - <div style="width: 100%"> - <div class="item-txt-msg mb10"> - <span>评价 {{ v.evaluate }}</span> - <span class="ml10">收藏 {{ v.collection }}</span> - </div> - <div class="item-txt-msg item-txt-price"> - <span class="font-price"> - <span>¥</span> - <span class="font">{{ v.price }}</span> - </span> - <span>月销{{ v.monSales }}笔</span> - </div> - </div> - </div> - </div> - </div> - </div> - </el-col> - </el-row> - </div> - <el-empty v-else description="暂无数据"></el-empty> - <template v-if="tableData.data.length > 0"> - <el-pagination - style="text-align: right" - background - @size-change="onHandleSizeChange" - @current-change="onHandleCurrentChange" - :page-sizes="[10, 20, 30]" - :current-page="tableData.param.pageNum" - :page-size="tableData.param.pageSize" - layout="total, sizes, prev, pager, next, jumper" - :total="tableData.total" - > - </el-pagination> - </template> - </el-card> - </div> -</template> - -<script lang="ts"> -import { toRefs, reactive, defineComponent } from 'vue'; -import { useRouter } from 'vue-router'; -import { filterList } from './mock'; - -// 定义接口来定义对象的类型 -interface ListAdaptRow { - img: string; - title: string; - evaluate: string; - collection: string; - price: string; - monSales: string; - id: number; -} -interface TableDataState { - tableData: { - data: Array<ListAdaptRow>; - total: number; - loading: boolean; - param: { - pageNum: number; - pageSize: number; - }; - }; -} - -export default defineComponent({ - name: 'pagesListAdapt', - setup() { - const router = useRouter(); - const state = reactive<TableDataState>({ - tableData: { - data: filterList, - total: 99, - loading: false, - param: { - pageNum: 1, - pageSize: 10, - }, - }, - }); - // 当前列表项点击 - const onTableItemClick = (v: ListAdaptRow) => { - router.push({ - path: '/pages/filteringDetails', - query: { id: v.id }, - }); - }; - // 分页点击 - const onHandleSizeChange = (val: number) => { - state.tableData.param.pageSize = val; - }; - // 分页点击 - const onHandleCurrentChange = (val: number) => { - state.tableData.param.pageNum = val; - }; - return { - onTableItemClick, - onHandleSizeChange, - onHandleCurrentChange, - ...toRefs(state), - }; - }, -}); -</script> - -<style scoped lang="scss"> -.flex-warp { - display: flex; - flex-wrap: wrap; - align-content: flex-start; - margin: 0 -5px; - .flex-warp-item { - padding: 5px; - width: 100%; - height: 360px; - .flex-warp-item-box { - border: 1px solid var(--next-border-color-light); - width: 100%; - height: 100%; - border-radius: 2px; - display: flex; - flex-direction: column; - transition: all 0.3s ease; - &:hover { - cursor: pointer; - border: 1px solid var(--el-color-primary); - transition: all 0.3s ease; - box-shadow: 0 2px 12px 0 rgba(0, 0, 0, 0.03); - .item-txt-title { - color: var(--el-color-primary) !important; - transition: all 0.3s ease; - } - .item-img { - img { - transition: all 0.3s ease; - transform: translateZ(0) scale(1.05); - } - } - } - .item-img { - width: 100%; - height: 215px; - overflow: hidden; - img { - transition: all 0.3s ease; - width: 100%; - height: 100%; - } - } - .item-txt { - flex: 1; - padding: 15px; - display: flex; - flex-direction: column; - overflow: hidden; - .item-txt-title { - text-overflow: ellipsis; - overflow: hidden; - -webkit-line-clamp: 2; - -webkit-box-orient: vertical; - display: -webkit-box; - color: #666666; - transition: all 0.3s ease; - &:hover { - color: var(--el-color-primary); - text-decoration: underline; - transition: all 0.3s ease; - } - } - .item-txt-other { - flex: 1; - align-items: flex-end; - display: flex; - .item-txt-msg { - font-size: 12px; - color: #8d8d91; - } - .item-txt-price { - display: flex; - justify-content: space-between; - align-items: center; - .font-price { - color: #ff5000; - .font { - font-size: 22px; - } - } - } - } - } - } - } -} -</style> diff --git a/src/views/pages/listAdapt/mock.ts b/src/views/pages/listAdapt/mock.ts deleted file mode 100644 index a31e9e3..0000000 --- a/src/views/pages/listAdapt/mock.ts +++ /dev/null @@ -1,93 +0,0 @@ -// 列表数据 -export const filterList = [ - { - img: 'https://news.sznews.com/pic/2021-03/09/e37326cc-4583-48f3-aa00-ecc2392d319d.jpg', - title: '36分钟,深圳平均通勤时间出炉!GDP10强城市中仅输杭州', - evaluate: (Math.random() * 10).toFixed(2), - collection: (Math.random() * 100).toFixed(2), - price: (Math.random() * 10).toFixed(2), - monSales: (Math.random() * 20).toFixed(2), - id: 1, - }, - { - img: 'http://news.sznews.com/pic/2021-03/09/78cf72b6-e2d9-459d-a368-470414a027f4679cf4ea-26fa-48c8-9fee-c2d092a91400.png', - title: '为爱而动,“红色鹊桥”三八妇女节交友联谊活动助力深圳女孩脱单', - evaluate: (Math.random() * 10).toFixed(2), - collection: (Math.random() * 100).toFixed(2), - price: (Math.random() * 10).toFixed(2), - monSales: (Math.random() * 20).toFixed(2), - id: 2, - }, - { - img: 'http://news.sznews.com/pic/2021-03/09/1faf3c6e-1250-4e6b-b072-4a331553e027.jpg', - title: '粤桂协作“背水一战” 解决广西大化县3.7万人饮水难题', - evaluate: (Math.random() * 10).toFixed(2), - collection: (Math.random() * 100).toFixed(2), - price: (Math.random() * 10).toFixed(2), - monSales: (Math.random() * 20).toFixed(2), - id: 3, - }, - { - img: 'https://news.sznews.com/pic/2021-03/09/9fcf6dd4-1e80-4497-bdc9-83dc7246d170.jpg.2', - title: '城镇就业女性平均薪酬6847元 女性职场渗透率提升', - evaluate: (Math.random() * 10).toFixed(2), - collection: (Math.random() * 100).toFixed(2), - price: (Math.random() * 10).toFixed(2), - monSales: (Math.random() * 20).toFixed(2), - id: 4, - }, - { - img: 'https://news.sznews.com/pic/2021-03/09/1bd78227-4126-4a43-bdf6-48ead6edd1bf.jpg.2', - title: '深圳:实现“从0到1”源头创新,推进大湾区综合性国家科学中心建设!', - evaluate: (Math.random() * 10).toFixed(2), - collection: (Math.random() * 100).toFixed(2), - price: (Math.random() * 10).toFixed(2), - monSales: (Math.random() * 20).toFixed(2), - id: 5, - }, - { - img: 'http://news.sznews.com/pic/2021-03/08/9ea943a3-3ae8-4f49-8296-711ec36ef8c6_watermark.png', - title: '煖声音第126期|愿你有诗酒趁年华的洒脱,也有岁月沉淀后的坚定从容', - evaluate: (Math.random() * 10).toFixed(2), - collection: (Math.random() * 100).toFixed(2), - price: (Math.random() * 10).toFixed(2), - monSales: (Math.random() * 20).toFixed(2), - id: 6, - }, - { - img: 'https://news.sznews.com/pic/2021-03/08/a95ba232-1422-4f7e-b85f-c61d486c8659.jpg.2', - title: '姐妹们一起来吐槽,最不能接受男人的缺点!', - evaluate: (Math.random() * 10).toFixed(2), - collection: (Math.random() * 100).toFixed(2), - price: (Math.random() * 10).toFixed(2), - monSales: (Math.random() * 20).toFixed(2), - id: 7, - }, - { - img: 'http://news.sznews.com/pic/2021-03/08/76816bf0-3899-4c7e-bc6e-079b5ba8725e.jpg', - title: '民生小事 | 手机遗落出租车 热心民警帮找回', - evaluate: (Math.random() * 10).toFixed(2), - collection: (Math.random() * 100).toFixed(2), - price: (Math.random() * 10).toFixed(2), - monSales: (Math.random() * 20).toFixed(2), - id: 8, - }, - { - img: 'https://news.sznews.com/pic/2021-03/08/28ed70d4-71f5-4abb-bf7b-0294bece9e43.jpg.2', - title: '“十三五”:深圳交上靓丽答卷 发展动力加快转换', - evaluate: (Math.random() * 10).toFixed(2), - collection: (Math.random() * 100).toFixed(2), - price: (Math.random() * 10).toFixed(2), - monSales: (Math.random() * 20).toFixed(2), - id: 9, - }, - { - img: 'http://news.sznews.com/pic/2021-03/05/d13ae31f-fd45-431a-b48e-c5895bbc193e.png', - title: '深圳湾公园一女子落水,三名男子接力及时施救', - evaluate: (Math.random() * 10).toFixed(2), - collection: (Math.random() * 100).toFixed(2), - price: (Math.random() * 10).toFixed(2), - monSales: (Math.random() * 20).toFixed(2), - id: 10, - }, -]; diff --git a/src/views/pages/preview/index.vue b/src/views/pages/preview/index.vue deleted file mode 100644 index ce3a771..0000000 --- a/src/views/pages/preview/index.vue +++ /dev/null @@ -1,28 +0,0 @@ -<template> - <div class="preview-container"> - <el-card shadow="hover" header="element-plus 大图预览"> - <el-image style="width: 100px; height: 100px; border-radius: 5px" :src="url" :preview-src-list="srcList" title="点击查看大图预览"> </el-image> - </el-card> - </div> -</template> - -<script lang="ts"> -import { toRefs, reactive, defineComponent } from 'vue'; - -export default defineComponent({ - name: 'pagesPreview', - setup() { - const state = reactive({ - url: 'https://ss0.bdstatic.com/70cFvHSh_Q1YnxGkpoWK1HF6hhy/it/u=1813762643,1914315241&fm=26&gp=0.jpg', - srcList: [ - 'https://ss0.bdstatic.com/70cFvHSh_Q1YnxGkpoWK1HF6hhy/it/u=1813762643,1914315241&fm=26&gp=0.jpg', - 'https://ss1.bdstatic.com/70cFuXSh_Q1YnxGkpoWK1HF6hhy/it/u=317673774,2961727727&fm=26&gp=0.jpg', - 'https://fuss10.elemecdn.com/1/8e/aeffeb4de74e2fde4bd74fc7b4486jpeg.jpeg', - ], - }); - return { - ...toRefs(state), - }; - }, -}); -</script> diff --git a/src/views/pages/steps/index.vue b/src/views/pages/steps/index.vue deleted file mode 100644 index becc196..0000000 --- a/src/views/pages/steps/index.vue +++ /dev/null @@ -1,51 +0,0 @@ -<template> - <div class="steps-container"> - <el-card shadow="hover" header="element-plus 步骤条"> - <el-steps :active="stepsActive"> - <el-step title="第一步"> - <template #icon> - <SvgIcon name="iconfont icon-0_round_solid" :size="20" /> - </template> - </el-step> - <el-step title="第二步"> - <template #icon> - <SvgIcon name="iconfont icon-2_round_solid" :size="20" /> - </template> - </el-step> - <el-step title="第三步"> - <template #icon> - <SvgIcon name="iconfont icon-3_round_solid" :size="20" /> - </template> - </el-step> - </el-steps> - <el-result icon="success" title="成功提示" subTitle="请根据提示进行操作" v-if="stepsActive === 1"> </el-result> - <el-result icon="warning" title="警告提示" subTitle="请根据提示进行操作" v-else-if="stepsActive === 2"> </el-result> - <el-result icon="error" title="错误提示" subTitle="请根据提示进行操作" v-else-if="stepsActive === 3"> </el-result> - <el-button @click="onNextSteps" size="default" class="mt15" type="primary"> - <SvgIcon name="iconfont icon-step" /> - 下一步 - </el-button> - </el-card> - </div> -</template> - -<script lang="ts"> -import { toRefs, reactive, defineComponent } from 'vue'; - -export default defineComponent({ - name: 'pagesSteps', - setup() { - const state = reactive({ - stepsActive: 1, - }); - // 下一步点击 - const onNextSteps = () => { - if (state.stepsActive++ > 2) state.stepsActive = 1; - }; - return { - onNextSteps, - ...toRefs(state), - }; - }, -}); -</script> diff --git a/src/views/pages/tableRules/index.vue b/src/views/pages/tableRules/index.vue deleted file mode 100644 index 2e17cde..0000000 --- a/src/views/pages/tableRules/index.vue +++ /dev/null @@ -1,129 +0,0 @@ -<template> - <el-card shadow="hover" header="表单表格验证"> - <el-form ref="tableRulesRef" :model="tableData" size="default"> - <el-table :data="tableData.data" border class="module-table-uncollected"> - <el-table-column - v-for="(item, index) in tableData.header" - :key="index" - show-overflow-tooltip - :prop="item.prop" - :width="item.width" - :label="item.label" - > - <template v-slot:header> - <span v-if="item.isRequired" class="color-danger">*</span> - <span class="pl5">{{ item.label }}</span> - <el-tooltip v-if="item.isTooltip" effect="dark" content="这是tooltip" placement="top"> - <i class="iconfont icon-quanxian" /> - </el-tooltip> - </template> - <template v-slot="scope"> - <el-form-item - :prop="`data.${scope.$index}.${item.prop}`" - :rules="[{ required: item.isRequired, message: '不能为空', trigger: `${item.type}` == 'input' ? 'blur' : 'change' }]" - > - <el-select v-if="item.type === 'select'" v-model="scope.row[item.prop]" placeholder="请选择"> - <el-option v-for="sel in tableData.option" :key="sel.id" :label="sel.label" :value="sel.value" /> - </el-select> - <el-date-picker - v-else-if="item.type === 'date'" - v-model="scope.row[item.prop]" - type="date" - placeholder="选择日期" - style="width: 100%" - /> - <el-input v-else-if="item.type === 'input'" v-model="scope.row[item.prop]" placeholder="请输入内容" /> - <el-input v-else-if="item.type === 'dialog'" v-model="scope.row[item.prop]" readonly placeholder="请输入内容"> - <template v-slot:suffix> - <i class="iconfont icon-shouye_dongtaihui" /> - </template> - </el-input> - </el-form-item> - </template> - </el-table-column> - </el-table> - </el-form> - <el-row class="flex mt15"> - <div class="flex-margin"> - <el-button size="default" type="success" @click="onValidate">表格验证</el-button> - <el-button size="default" type="primary" @click="onAddRow">新增一行</el-button> - </div> - </el-row> - </el-card> -</template> - -<script lang="ts"> -import { defineComponent, toRefs, reactive, ref } from 'vue'; -import { ElMessage } from 'element-plus'; - -// 定义接口来定义对象的类型 -interface TableHeader { - prop: string; - width: string | number; - label: string; - isRequired?: boolean; - isTooltip?: boolean; - type: string; -} -interface TableRulesState { - tableData: { - data: any[]; - header: TableHeader[]; - option: any[]; - }; -} - -export default defineComponent({ - name: 'pagesTableRules', - setup() { - const tableRulesRef = ref(); - const state = reactive<TableRulesState>({ - tableData: { - data: [], - header: [ - { prop: 'a1', width: '', label: '一级分类', isRequired: true, type: 'select' }, - { prop: 'a2', width: '', label: '二级分类', isRequired: true, type: 'select' }, - { prop: 'a3', width: '', label: '三级分类', isRequired: true, type: 'select' }, - { prop: 'a4', width: '', label: '四级分类', isRequired: true, type: 'date' }, - { prop: 'a5', width: '', label: '五级分类', isRequired: true, type: 'input' }, - { prop: 'a6', width: '', label: '六级分类', isTooltip: true, type: 'dialog' }, - { prop: 'a7', width: '', label: '演示级分类', type: 'input' }, - { prop: 'a8', width: '', label: '颜色是分类', type: 'input' }, - ], - option: [ - { value: '选项1', label: '黄金糕' }, - { value: '选项2', label: '双皮奶' }, - { value: '选项3', label: '蚵仔煎' }, - ], - }, - }); - // 表格验证 - const onValidate = () => { - if (state.tableData.data.length <= 0) return ElMessage.warning('请先点击增加一行'); - tableRulesRef.value.validate((valid: any) => { - if (!valid) return ElMessage.warning('表格项必填未填'); - ElMessage.success('全部验证通过'); - }); - }; - // 新增一行 - const onAddRow = () => { - state.tableData.data.push({ - a1: '', - a2: '', - a3: '', - a4: '', - a5: '', - a6: '', - a7: '', - a8: '', - }); - }; - return { - onValidate, - onAddRow, - tableRulesRef, - ...toRefs(state), - }; - }, -}); -</script> diff --git a/src/views/pages/tree/index.vue b/src/views/pages/tree/index.vue deleted file mode 100644 index afcc752..0000000 --- a/src/views/pages/tree/index.vue +++ /dev/null @@ -1,258 +0,0 @@ -<template> - <div class="tree-container"> - <el-card shadow="hover" header="element plus Tree 树形控件改成表格"> - <div v-loading="treeLoading"> - <div class="tree-head"> - <div class="tree-head-check"><el-checkbox v-model="treeCheckAll" @change="onCheckAllChange"></el-checkbox></div> - <div class="tree-head-one">商品 ID</div> - <div style="flex: 1; display: flex"> - <div class="tree-head-two">商品名称</div> - <div class="tree-head-three">描述</div> - </div> - </div> - <el-tree :data="treeTableData" show-checkbox node-key="id" ref="treeTable" :props="treeDefaultProps" @check="onCheckTree"> - <template #default="{ node, data }"> - <span class="tree-custom-node"> - <span style="flex: 1">{{ node.label }}</span> - <span v-if="data.isShow" style="flex: 1; display: flex"> - <span type="text" size="default" style="flex: 1">{{ data.label1 }}</span> - <span type="text" size="default" style="flex: 1">{{ data.label2 }}</span> - </span> - </span> - </template> - </el-tree> - </div> - <el-button @click="onSelect" class="mt15" size="default" type="primary"> - <SvgIcon name="iconfont icon-shuxingtu" /> - 选择元素 - </el-button> - </el-card> - </div> -</template> - -<script lang="ts"> -import { toRefs, reactive, onBeforeMount, getCurrentInstance, defineComponent } from 'vue'; -import { ElMessage } from 'element-plus'; - -// 定义接口来定义对象的类型 -interface TreeDataState { - id: number; - label: string; - label1: string; - label2: string; - isShow: boolean; - children?: TreeDataState[]; -} -interface TreeSate { - treeCheckAll: boolean; - treeLoading: boolean; - treeTableData: TreeDataState[]; - treeDefaultProps: { - children: string; - label: string; - }; - treeSelArr: TreeDataState[]; - treeLength: number; -} - -export default defineComponent({ - name: 'pagesTree', - setup() { - const { proxy } = <any>getCurrentInstance(); - const state = reactive<TreeSate>({ - treeCheckAll: false, - treeLoading: false, - treeTableData: [], - treeDefaultProps: { - children: 'children', - label: 'label', - }, - treeSelArr: [], - treeLength: 0, - }); - // 初始化树的长度 - const initTreeLengh = (arr: TreeDataState[]) => { - let count = 0; - arr.map((item) => { - if (item.children) { - count += item.children.length; - } - }); - state.treeLength = count + arr.length; - }; - // 全选改变时 - const onCheckAllChange = () => { - if (state.treeCheckAll) { - proxy.$refs.treeTable.setCheckedNodes(state.treeTableData); - } else { - proxy.$refs.treeTable.setCheckedKeys([]); - } - }; - // 节点选中状态发生变化时的回调 - const onCheckTree = () => { - state.treeSelArr = []; - state.treeSelArr = proxy.$refs.treeTable.getCheckedNodes(); - state.treeSelArr.length == state.treeLength ? (state.treeCheckAll = true) : (state.treeCheckAll = false); - }; - // 选择元素按钮 - const onSelect = () => { - let treeArr = proxy.$refs.treeTable.getCheckedNodes(); - if (treeArr.length <= 0) { - ElMessage.warning('请选择元素'); - return; - } else { - // console.log(proxy.$refs.treeTable.getCheckedNodes()); - } - }; - // 初始化树模拟数据 - const getTreeData = () => { - state.treeTableData = [ - { - id: 1, - label: '12987121', - label1: '好滋好味鸡蛋仔', - label2: '荷兰优质淡奶,奶香浓而不腻', - isShow: true, - children: [ - { - id: 11, - label: '一级 1-1', - label1: '好滋好味鸡蛋仔', - label2: '荷兰优质淡奶,奶香浓而不腻', - isShow: false, - }, - { - id: 12, - label: '一级 1-2', - label1: '好滋好味鸡蛋仔', - label2: '荷兰优质淡奶,奶香浓而不腻', - isShow: false, - }, - ], - }, - { - id: 2, - label: '12987122', - label1: '好滋好味鸡蛋仔', - label2: '荷兰优质淡奶,奶香浓而不腻', - isShow: true, - children: [ - { - id: 21, - label: '二级 2-1', - label1: '好滋好味鸡蛋仔', - label2: '荷兰优质淡奶,奶香浓而不腻', - isShow: false, - }, - { - id: 22, - label: '二级 2-2', - label1: '好滋好味鸡蛋仔', - label2: '荷兰优质淡奶,奶香浓而不腻', - isShow: false, - }, - ], - }, - { - id: 3, - label: '12987123', - label1: '好滋好味鸡蛋仔', - label2: '荷兰优质淡奶,奶香浓而不腻', - isShow: true, - children: [ - { - id: 31, - label: '二级 3-1', - label1: '好滋好味鸡蛋仔', - label2: '荷兰优质淡奶,奶香浓而不腻', - isShow: false, - }, - { - id: 32, - label: '二级 3-2', - label1: '好滋好味鸡蛋仔', - label2: '荷兰优质淡奶,奶香浓而不腻', - isShow: false, - }, - { - id: 33, - label: '二级 3-3', - label1: '好滋好味鸡蛋仔', - label2: '荷兰优质淡奶,奶香浓而不腻', - isShow: false, - }, - ], - }, - ]; - initTreeLengh(state.treeTableData); - }; - // 页面加载前 - onBeforeMount(() => { - getTreeData(); - }); - return { - getTreeData, - onCheckAllChange, - onCheckTree, - onSelect, - ...toRefs(state), - }; - }, -}); -</script> - -<style scoped lang="scss"> -.tree-container { - .tree-head { - height: 48px; - line-height: 48px; - border: 1px solid var(--next-border-color-light); - border-bottom: none; - display: flex; - padding-right: 8px; - font-weight: bold; - color: #909399; - .tree-head-check { - width: 38px; - text-align: right; - } - .tree-head-one, - .tree-head-two, - .tree-head-three { - flex: 1; - } - .tree-head-one { - padding-left: 8px; - } - } - .el-tree { - overflow: hidden; - border-bottom: 1px solid var(--next-border-color-light); - .tree-custom-node { - flex: 1; - display: flex; - align-items: center; - justify-content: space-between; - padding-right: 8px; - width: 100%; - } - &::v-deep(.el-tree-node) { - border: 1px solid var(--next-border-color-light); - border-bottom: none; - color: #606266; - .el-tree-node__content { - line-height: 57px !important; - height: 57px !important; - } - .el-tree-node__children { - .el-tree-node { - border: none; - } - .el-tree-node__content { - border-top: 1px solid var(--next-border-color-light); - } - } - } - } -} -</style> diff --git a/src/views/pages/waterfall/index.vue b/src/views/pages/waterfall/index.vue deleted file mode 100644 index 48b48ea..0000000 --- a/src/views/pages/waterfall/index.vue +++ /dev/null @@ -1,174 +0,0 @@ -<template> - <div class="waterfall-container"> - <el-card shadow="hover" header="瀑布屏(布局一)" class="mb15"> - <div class="waterfall-first"> - <div class="waterfall-first-item" v-for="v in 30" :key="v" v-waves> - <div class="w100 h100 flex"> - <span class="flex-margin">{{ v }}</span> - </div> - </div> - </div> - </el-card> - <el-card shadow="hover" header="瀑布屏(布局二)"> - <div class="waterfall-last"> - <div class="waterfall-last-item" v-for="v in 30" :key="v" v-waves="'light'"> - <div class="w100 h100 flex"> - <span class="flex-margin">{{ v }}</span> - </div> - </div> - </div> - </el-card> - </div> -</template> - -<script lang="ts"> -import { toRefs, reactive, defineComponent } from 'vue'; - -export default defineComponent({ - name: 'pagesWaterfall', - setup() { - const state = reactive({}); - return { - ...toRefs(state), - }; - }, -}); -</script> - -<style scoped lang="scss"> -.waterfall-container { - .waterfall-first { - display: grid; - grid-template-columns: repeat(auto-fill, minmax(188px, 1fr)); - grid-gap: 0.25em; - grid-auto-flow: row dense; - grid-auto-rows: 20px; - .waterfall-first-item { - width: 100%; - background: var(--el-color-primary); - color: var(--el-color-white); - transition: all 0.3s ease; - border-radius: 3px; - &:nth-of-type(3n + 1) { - grid-row: auto / span 5; - } - &:nth-of-type(3n + 2) { - grid-row: auto / span 6; - } - &:nth-of-type(3n + 3) { - grid-row: auto / span 8; - } - &:hover { - box-shadow: 0 2px 12px 0 rgb(0 0 0 / 10%); - transition: all 0.3s ease; - cursor: pointer; - } - } - } - .waterfall-last { - display: grid; - grid-gap: 0.25em; - grid-auto-flow: row dense; - grid-auto-rows: minmax(188px, 20vmin); - grid-template-columns: 1fr; - .waterfall-last-item { - height: 100%; - background: var(--el-color-primary); - color: var(--el-color-white); - transition: all 0.3s ease; - border-radius: 3px; - &:hover { - box-shadow: 0 2px 12px 0 rgb(0 0 0 / 10%); - transition: all 0.3s ease; - cursor: pointer; - } - } - } - @media (min-width: 576px) { - .waterfall-last { - grid-template-columns: repeat(7, 1fr); - .waterfall-last-item { - &:nth-of-type(9n + 9) { - grid-column: auto / span 2; - } - &:nth-of-type(9n + 8) { - grid-column: auto / span 2; - } - &:nth-of-type(9n + 7) { - grid-column: auto / span 3; - } - &:nth-of-type(9n + 6) { - grid-column: auto / span 2; - } - &:nth-of-type(9n + 5) { - grid-column: auto / span 3; - } - &:nth-of-type(9n + 4) { - grid-column: auto / span 2; - } - &:nth-of-type(9n + 3) { - grid-column: auto / span 3; - } - &:nth-of-type(9n + 2) { - grid-column: auto / span 2; - } - &:nth-of-type(9n + 1) { - grid-column: auto / span 2; - } - } - } - } - @media (min-width: 576px) and (min-width: 1024px) { - .waterfall-last { - grid-template-columns: repeat(14, 1fr); - .waterfall-last-item { - &:nth-of-type(15n + 15) { - grid-column: auto / span 3; - } - &:nth-of-type(15n + 14) { - grid-column: auto / span 3; - } - &:nth-of-type(15n + 13) { - grid-column: auto / span 2; - } - &:nth-of-type(15n + 12) { - grid-column: auto / span 3; - } - &:nth-of-type(15n + 11) { - grid-column: auto / span 3; - } - &:nth-of-type(15n + 10) { - grid-column: auto / span 2; - } - &:nth-of-type(15n + 9) { - grid-column: auto / span 3; - } - &:nth-of-type(15n + 8) { - grid-column: auto / span 3; - } - &:nth-of-type(15n + 7) { - grid-column: auto / span 3; - } - &:nth-of-type(15n + 6) { - grid-column: auto / span 3; - } - &:nth-of-type(15n + 5) { - grid-column: auto / span 3; - } - &:nth-of-type(15n + 4) { - grid-column: auto / span 3; - } - &:nth-of-type(15n + 3) { - grid-column: auto / span 3; - } - &:nth-of-type(15n + 2) { - grid-column: auto / span 3; - } - &:nth-of-type(15n + 1) { - grid-column: auto / span 2; - } - } - } - } -} -</style> diff --git a/src/views/pages/waves/index.vue b/src/views/pages/waves/index.vue deleted file mode 100644 index 405c71a..0000000 --- a/src/views/pages/waves/index.vue +++ /dev/null @@ -1,134 +0,0 @@ -<template> - <div class="preview-container"> - <el-card shadow="hover" header="波浪指令效果(v-waves)作用于 btn"> - <el-row class="mb10" style="color: #808080">可选参数 v-waves=" |light|red|orange|purple|green|teal"</el-row> - <div class="flex-warp"> - <div class="flex-warp-item"> - <div class="flex-warp-item-box"> - <el-button size="default" v-waves> - <SvgIcon name="iconfont icon-bolangnengshiyanchang" /> - 默认效果 - </el-button> - </div> - </div> - <div class="flex-warp-item"> - <div class="flex-warp-item-box"> - <el-button type="primary" size="default" v-waves="'light'"> - <SvgIcon name="iconfont icon-bolangnengshiyanchang" /> - light 效果 - </el-button> - </div> - </div> - <div class="flex-warp-item"> - <div class="flex-warp-item-box"> - <el-button type="success" size="default" v-waves="'red'"> - <SvgIcon name="iconfont icon-bolangnengshiyanchang" /> - red 效果 - </el-button> - </div> - </div> - <div class="flex-warp-item"> - <div class="flex-warp-item-box"> - <el-button type="info" size="default" v-waves="'orange'"> - <SvgIcon name="iconfont icon-bolangnengshiyanchang" /> - orange 效果 - </el-button> - </div> - </div> - <div class="flex-warp-item"> - <div class="flex-warp-item-box"> - <el-button type="warning" size="default" v-waves="'purple'"> - <SvgIcon name="iconfont icon-bolangnengshiyanchang" /> - purple 效果 - </el-button> - </div> - </div> - <div class="flex-warp-item"> - <div class="flex-warp-item-box"> - <el-button type="danger" size="default" v-waves="'green'"> - <SvgIcon name="iconfont icon-bolangnengshiyanchang" /> - green 效果 - </el-button> - </div> - </div> - <div class="flex-warp-item"> - <div class="flex-warp-item-box"> - <el-button type="primary" size="default" v-waves="'teal'"> - <SvgIcon name="iconfont icon-bolangnengshiyanchang" /> - teal 效果 - </el-button> - </div> - </div> - </div> - </el-card> - <el-card shadow="hover" header="波浪指令效果(v-waves)作用于 div" class="mt15"> - <div class="waterfall-first"> - <div class="waterfall-first-item" v-for="v in 12" :key="v" v-waves> - <div class="w100 h100 flex"> - <span class="flex-margin">{{ v }}</span> - </div> - </div> - </div> - </el-card> - </div> -</template> - -<script lang="ts"> -import { toRefs, reactive, defineComponent } from 'vue'; - -export default defineComponent({ - name: 'pagesWaves', - setup() { - const state = reactive({}); - return { - ...toRefs(state), - }; - }, -}); -</script> - -<style scoped lang="scss"> -.preview-container { - .flex-warp { - display: flex; - flex-wrap: wrap; - align-content: flex-start; - margin: 0 -5px; - .flex-warp-item { - padding: 5px; - .flex-warp-item-box { - width: 100%; - height: 100%; - } - } - } - .waterfall-first { - display: grid; - grid-template-columns: repeat(auto-fill, minmax(188px, 1fr)); - grid-gap: 0.25em; - grid-auto-flow: row dense; - grid-auto-rows: 20px; - .waterfall-first-item { - width: 100%; - background: var(--el-color-primary); - color: var(--el-color-white); - transition: all 0.3s ease; - border-radius: 3px; - &:nth-of-type(3n + 1) { - grid-row: auto / span 5; - } - &:nth-of-type(3n + 2) { - grid-row: auto / span 6; - } - &:nth-of-type(3n + 3) { - grid-row: auto / span 8; - } - &:hover { - box-shadow: 0 2px 12px 0 rgb(0 0 0 / 10%); - transition: all 0.3s ease; - cursor: pointer; - } - } - } -} -</style> diff --git a/src/views/pages/workflow/component/contextmenu/index.vue b/src/views/pages/workflow/component/contextmenu/index.vue deleted file mode 100644 index f55e06f..0000000 --- a/src/views/pages/workflow/component/contextmenu/index.vue +++ /dev/null @@ -1,107 +0,0 @@ -<template> - <transition name="el-zoom-in-center"> - <div - aria-hidden="true" - class="el-dropdown__popper el-popper is-light is-pure custom-contextmenu" - role="tooltip" - data-popper-placement="bottom" - :style="`top: ${dropdowns.y + 5}px;left: ${dropdowns.x}px;`" - :key="Math.random()" - v-show="isShow" - > - <ul class="el-dropdown-menu"> - <li - v-for="(v, k) in dropdownList" - class="el-dropdown-menu__item" - aria-disabled="false" - tabindex="-1" - :key="k" - @click="onCurrentClick(v.contextMenuClickId)" - > - <SvgIcon :name="v.icon" /> - <span>{{ v.txt }}{{ item.type === 'line' ? '线' : '节点' }}</span> - </li> - </ul> - <div class="el-popper__arrow" style="left: 10px"></div> - </div> - </transition> -</template> - -<script lang="ts"> -import { computed, defineComponent, reactive, toRefs, onMounted, onUnmounted } from 'vue'; - -export default defineComponent({ - name: 'pagesWorkflowContextmenu', - props: { - dropdown: { - type: Object, - }, - }, - setup(props, { emit }) { - const state = reactive({ - isShow: false, - dropdownList: [ - { contextMenuClickId: 0, txt: '删除', icon: 'ele-Delete' }, - { contextMenuClickId: 1, txt: '编辑', icon: 'ele-Edit' }, - ], - item: { - type: 'node', - }, - conn: {}, - }); - // 父级传过来的坐标 x,y 值 - const dropdowns = computed(() => { - return <any>props.dropdown; - }); - // 当前项菜单点击 - const onCurrentClick = (contextMenuClickId: number) => { - emit('current', Object.assign({}, { contextMenuClickId }, state.item), state.conn); - }; - // 打开右键菜单:判断是否固定,固定则不显示关闭按钮 - const openContextmenu = (item: any, conn = {}) => { - state.item = item; - state.conn = conn; - closeContextmenu(); - setTimeout(() => { - state.isShow = true; - }, 10); - }; - // 关闭右键菜单 - const closeContextmenu = () => { - state.isShow = false; - }; - // 监听页面监听进行右键菜单的关闭 - onMounted(() => { - document.body.addEventListener('click', closeContextmenu); - document.body.addEventListener('contextmenu', closeContextmenu); - }); - // 页面卸载时,移除右键菜单监听事件 - onUnmounted(() => { - document.body.removeEventListener('click', closeContextmenu); - document.body.removeEventListener('contextmenu', closeContextmenu); - }); - return { - dropdowns, - openContextmenu, - closeContextmenu, - onCurrentClick, - ...toRefs(state), - }; - }, -}); -</script> - -<style scoped lang="scss"> -.custom-contextmenu { - transform-origin: center top; - z-index: 2190; - position: fixed; - .el-dropdown-menu__item { - font-size: 12px !important; - white-space: nowrap; - i { - font-size: 12px !important; - } - } -} -</style> diff --git a/src/views/pages/workflow/component/drawer/index.vue b/src/views/pages/workflow/component/drawer/index.vue deleted file mode 100644 index 74478a2..0000000 --- a/src/views/pages/workflow/component/drawer/index.vue +++ /dev/null @@ -1,73 +0,0 @@ -<template> - <div> - <el-drawer :title="`${nodeData.type === 'line' ? '线' : '节点'}操作`" v-model="isOpen" size="320px"> - <el-scrollbar> - <Line v-if="nodeData.type === 'line'" @change="onLineChange" @close="close" ref="lineRef" /> - <Node v-else @submit="onNodeSubmit" @close="close" ref="nodeRef" /> - </el-scrollbar> - </el-drawer> - </div> -</template> - -<script lang="ts"> -import { defineComponent, reactive, toRefs, ref, nextTick } from 'vue'; -import Line from './line.vue'; -import Node from './node.vue'; - -// 定义接口来定义对象的类型 -interface WorkflowDrawerState { - isOpen: boolean; - nodeData: { - type: string; - }; - jsplumbConn: any; -} - -export default defineComponent({ - name: 'pagesWorkflowDrawer', - components: { Line, Node }, - setup(props, { emit }) { - const lineRef = ref(); - const nodeRef = ref(); - const state = reactive<WorkflowDrawerState>({ - isOpen: false, - nodeData: { - type: 'node', - }, - jsplumbConn: {}, - }); - // 打开抽屉 - const open = (item: any, conn: any) => { - state.isOpen = true; - state.jsplumbConn = conn; - state.nodeData = item; - nextTick(() => { - if (item.type === 'line') lineRef.value.getParentData(item); - else nodeRef.value.getParentData(item); - }); - }; - // 关闭 - const close = () => { - state.isOpen = false; - }; - // 线 label 内容改变时 - const onLineChange = (label: any) => { - state.jsplumbConn.label = label; - emit('label', state.jsplumbConn); - }; - // 节点内容改变时 - const onNodeSubmit = (data: object) => { - emit('node', data); - }; - return { - lineRef, - nodeRef, - open, - close, - onLineChange, - onNodeSubmit, - ...toRefs(state), - }; - }, -}); -</script> diff --git a/src/views/pages/workflow/component/drawer/line.vue b/src/views/pages/workflow/component/drawer/line.vue deleted file mode 100644 index a19c92a..0000000 --- a/src/views/pages/workflow/component/drawer/line.vue +++ /dev/null @@ -1,62 +0,0 @@ -<template> - <div class="pt15 pr15 pb15 pl15"> - <el-form :model="line" size="default" label-width="50px"> - <el-form-item label="来往"> - <el-input v-model="line.contact" placeholder="来往" clearable disabled></el-input> - </el-form-item> - <el-form-item label="类型"> - <el-input v-model="line.type" placeholder="类型" clearable disabled></el-input> - </el-form-item> - <el-form-item label="label"> - <el-input v-model="line.label" placeholder="请输入label内容" clearable></el-input> - </el-form-item> - <el-form-item> - <el-button @click="onLineTextReset"> - <SvgIcon name="ele-RefreshRight" /> - 重置 - </el-button> - <el-button @click="onLineTextChange" type="primary"> - <SvgIcon name="ele-Check" /> - 保存 - </el-button> - </el-form-item> - </el-form> - </div> -</template> - -<script lang="ts"> -import { defineComponent, reactive, toRefs } from 'vue'; - -// 定义接口来定义对象的类型 -interface WorkflowDrawerLineState { - line: any; -} - -export default defineComponent({ - name: 'pagesWorkflowDrawerLine', - setup(props, { emit }) { - const state = reactive<WorkflowDrawerLineState>({ - line: {}, - }); - // 获取父组件数据 - const getParentData = (data: object) => { - state.line = data; - }; - // 重置 - const onLineTextReset = () => { - state.line.label = ''; - }; - // 保存 - const onLineTextChange = () => { - emit('change', state.line.label); - emit('close'); - }; - return { - getParentData, - onLineTextReset, - onLineTextChange, - ...toRefs(state), - }; - }, -}); -</script> diff --git a/src/views/pages/workflow/component/drawer/node.vue b/src/views/pages/workflow/component/drawer/node.vue deleted file mode 100644 index b68ccde..0000000 --- a/src/views/pages/workflow/component/drawer/node.vue +++ /dev/null @@ -1,272 +0,0 @@ -<template> - <div class="workflow-drawer-node"> - <el-tabs type="border-card" v-model="tabsActive"> - <!-- 节点编辑 --> - <el-tab-pane label="节点编辑" name="1"> - <el-scrollbar> - <el-form :model="node" :rules="nodeRules" ref="nodeFormRef" size="default" label-width="80px" class="pt15 pr15 pb15 pl15"> - <el-form-item label="数据id" prop="id"> - <el-input v-model="node.id" placeholder="请输入数据id" clearable disabled></el-input> - </el-form-item> - <el-form-item label="节点id" prop="nodeId"> - <el-input v-model="node.nodeId" placeholder="请输入节点id" clearable disabled></el-input> - </el-form-item> - <el-form-item label="类型" prop="type"> - <el-input v-model="node.type" placeholder="请输入类型" clearable disabled></el-input> - </el-form-item> - <el-form-item label="left坐标" prop="left"> - <el-input v-model="node.left" placeholder="请输入left坐标" clearable disabled></el-input> - </el-form-item> - <el-form-item label="top坐标" prop="top"> - <el-input v-model="node.top" placeholder="请输入top坐标" clearable disabled></el-input> - </el-form-item> - <el-form-item label="icon图标" prop="icon"> - <el-input v-model="node.icon" placeholder="请输入icon图标" clearable></el-input> - </el-form-item> - <el-form-item label="名称" prop="name"> - <el-input v-model="node.name" placeholder="请输入名称" clearable></el-input> - </el-form-item> - <el-form-item> - <el-button class="mb15" @click="onNodeRefresh"> - <SvgIcon name="ele-RefreshRight" /> - 重置 - </el-button> - <el-button type="primary" class="mb15" @click="onNodeSubmit"> - <SvgIcon name="ele-Check" /> - 保存 - </el-button> - </el-form-item> - </el-form> - </el-scrollbar> - </el-tab-pane> - - <!-- 扩展表单 --> - <el-tab-pane label="扩展表单" name="2"> - <el-scrollbar> - <el-form :model="form" ref="extendFormRef" size="default" label-width="80px" class="pt15 pr15 pb15 pl15"> - <el-form-item - :label="val.label" - :prop="val.prop" - v-for="(val, key) in node.from" - :key="key" - :rules="[{ required: val.required, message: `${val.label}不能为空`, trigger: 'blur' }]" - > - <el-input - v-model="form[val.prop]" - :placeholder="val.placeholder" - clearable - v-if="val.type === 'input'" - :disabled="val.disabled" - ></el-input> - <el-select v-model="form[val.prop]" placeholder="请选择" v-if="val.type === 'select'" clearable :disabled="val.disabled"> - <el-option v-for="item in val.options" :key="item.value" :label="item.label" :value="item.value"> </el-option> - </el-select> - <el-checkbox-group v-model="form[val.prop]" v-if="val.type === 'checkbox'" :disabled="val.disabled"> - <el-checkbox label="美食推荐" name="type"></el-checkbox> - <el-checkbox label="统计分析" name="type"></el-checkbox> - </el-checkbox-group> - </el-form-item> - <el-form-item> - <el-button class="mb15" @click="onExtendRefresh"> - <SvgIcon name="ele-RefreshRight" /> - 重置 - </el-button> - <el-button type="primary" class="mb15" @click="onExtendSubmit" :loading="loading.extend"> - <SvgIcon name="ele-Check" /> - 保存 - </el-button> - </el-form-item> - </el-form> - </el-scrollbar> - </el-tab-pane> - - <!-- 图表可视化 --> - <el-tab-pane label="图表可视化" name="3"> - <el-scrollbar> - <div class="flex-content-right"> - <div style="height: 200px; width: 320px" ref="chartsMonitorRef"></div> - </div> - </el-scrollbar> - </el-tab-pane> - </el-tabs> - </div> -</template> - -<script lang="ts"> -import { defineComponent, reactive, toRefs, ref, nextTick, getCurrentInstance } from 'vue'; -import { ElMessage } from 'element-plus'; -import * as echarts from 'echarts'; - -// 定义接口来定义对象的类型 -interface WorkflowDrawerNodeState { - node: { [key: string]: any }; - nodeRules: any; - form: any; - tabsActive: string; - loading: { - extend: boolean; - }; -} - -export default defineComponent({ - name: 'pagesWorkflowDrawerNode', - setup(props, { emit }) { - const { proxy } = <any>getCurrentInstance(); - const nodeFormRef = ref(); - const extendFormRef = ref(); - const chartsMonitorRef = ref(); - const state = reactive<WorkflowDrawerNodeState>({ - node: {}, - nodeRules: { - id: [{ required: true, message: '请输入数据id', trigger: 'blur' }], - nodeId: [{ required: true, message: '请输入节点id', trigger: 'blur' }], - type: [{ required: true, message: '请输入类型', trigger: 'blur' }], - left: [{ required: true, message: '请输入left坐标', trigger: 'blur' }], - top: [{ required: true, message: '请输入top坐标', trigger: 'blur' }], - icon: [{ required: true, message: '请输入icon图标', trigger: 'blur' }], - name: [{ required: true, message: '请输入名称', trigger: 'blur' }], - }, - form: { - module: [], - }, - tabsActive: '1', - loading: { - extend: false, - }, - }); - // 获取父组件数据 - const getParentData = (data: object) => { - state.tabsActive = '1'; - state.node = data; - initChartsMonitor(); - }; - // 节点编辑-重置 - const onNodeRefresh = () => { - state.node.icon = ''; - state.node.name = ''; - }; - // 节点编辑-保存 - const onNodeSubmit = () => { - nodeFormRef.value.validate((valid: boolean) => { - if (valid) { - emit('submit', state.node); - emit('close'); - } else { - return false; - } - }); - }; - // 扩展表单-重置 - const onExtendRefresh = () => { - extendFormRef.value.resetFields(); - }; - // 扩展表单-保存 - const onExtendSubmit = () => { - extendFormRef.value.validate((valid: boolean) => { - if (valid) { - state.loading.extend = true; - setTimeout(() => { - state.loading.extend = false; - ElMessage.success('保存成功'); - emit('close'); - }, 1000); - } else { - return false; - } - }); - }; - // 图表可视化-初始化 - const initChartsMonitor = () => { - const myChart = echarts.init(proxy.$refs.chartsMonitorRef); - const numsOne = []; - const numsTwo = []; - for (let i = 0; i < 7; i++) { - numsOne.push(`${Math.floor(Math.random() * 52 + 10)}:${Math.floor(Math.random() * 52 + 1)}`); - numsTwo.push(Math.floor(Math.random() * 52 + 1)); - } - const option = { - grid: { - top: 50, - right: 30, - bottom: 30, - left: 50, - }, - tooltip: { - trigger: 'axis', - }, - xAxis: { - type: 'category', - boundaryGap: false, - data: numsOne, - }, - yAxis: { - type: 'value', - }, - series: [ - { - itemStyle: { - color: '#289df5', - borderColor: '#289df5', - areaStyle: { - type: 'default', - opacity: 0.1, - }, - }, - data: numsTwo, - type: 'line', - areaStyle: {}, - }, - ], - }; - myChart.setOption(option); - nextTick(() => { - myChart.resize(); - }); - }; - return { - nodeFormRef, - extendFormRef, - chartsMonitorRef, - getParentData, - onNodeRefresh, - onNodeSubmit, - onExtendRefresh, - onExtendSubmit, - ...toRefs(state), - }; - }, -}); -</script> - -<style scoped lang="scss"> -.workflow-drawer-node { - ::v-deep { - .el-tabs { - box-shadow: unset; - border: unset; - .el-tabs__nav { - display: flex; - width: 100%; - .el-tabs__item { - flex: 1; - padding: unset; - text-align: center; - &:first-of-type.is-active { - border-left-color: transparent; - } - &:last-of-type.is-active { - border-right-color: transparent; - } - } - } - .el-tabs__content { - padding: 0; - height: calc(100vh - 90px); - .el-tab-pane { - height: 100%; - } - } - } - } -} -</style> diff --git a/src/views/pages/workflow/component/tool/help.vue b/src/views/pages/workflow/component/tool/help.vue deleted file mode 100644 index 09198b5..0000000 --- a/src/views/pages/workflow/component/tool/help.vue +++ /dev/null @@ -1,39 +0,0 @@ -<template> - <div class="workflow-tool-help"> - <el-dialog v-model="isShow" width="769px"> - <template #header> - <div v-drag="['.workflow-tool-help .el-dialog', '.workflow-tool-help .el-dialog__header']">使用帮助</div> - </template> - <div>1、拖入:鼠标移入左侧导航中,鼠标形状改变时拖动到右侧网格状的视图中。</div> - <div class="mt10">2、移动:鼠标移入到视图中的某个节点元素,鼠标形状改变时拖动改变位置。</div> - <div class="mt10">3、连线:鼠标移入到视图中的某个节点元素的icon(图标),鼠标形状改变(变成"+"),按下鼠标左键进行拖线连接。</div> - <div class="mt10">4、节点:鼠标移入到视图中的某个节点元素,点击鼠标右键可进行删除、编辑节点。</div> - <div class="mt10 mb10">5、线条:鼠标移入到视图中的某个线条,线条颜色改变时,点击鼠标右键可进行删除、编辑线条。</div> - </el-dialog> - </div> -</template> - -<script lang="ts"> -import { defineComponent, reactive, toRefs } from 'vue'; -export default defineComponent({ - name: 'pagesWorkflowToolHelp', - setup() { - const state = reactive({ - isShow: false, - }); - // 打开弹窗 - const open = () => { - state.isShow = true; - }; - // 关闭弹窗 - const close = () => { - state.isShow = false; - }; - return { - open, - close, - ...toRefs(state), - }; - }, -}); -</script> diff --git a/src/views/pages/workflow/component/tool/index.vue b/src/views/pages/workflow/component/tool/index.vue deleted file mode 100644 index 2cb9940..0000000 --- a/src/views/pages/workflow/component/tool/index.vue +++ /dev/null @@ -1,79 +0,0 @@ -<template> - <div class="workflow-tool"> - <div class="pl15">{{ setToolTitle }}</div> - <div class="workflow-tool-right"> - <div class="workflow-tool-icon" v-for="(v, k) in toolList" :key="k" :title="v.title" @click="onToolClick(v.fnName)"> - <SvgIcon :name="v.icon" /> - </div> - </div> - </div> -</template> - -<script lang="ts"> -import { defineComponent, computed, reactive, toRefs } from 'vue'; -import { storeToRefs } from 'pinia'; -import { useThemeConfig } from '/@/stores/themeConfig'; - -export default defineComponent({ - name: 'pagesWorkflowTool', - setup(props, { emit }) { - const storesThemeConfig = useThemeConfig(); - const { themeConfig } = storeToRefs(storesThemeConfig); - const state = reactive({ - toolList: [ - { icon: 'ele-Help', title: '帮助', fnName: 'help' }, - { icon: 'ele-Download', title: '下载', fnName: 'download' }, - { icon: 'ele-Check', title: '提交', fnName: 'submit' }, - { icon: 'ele-DocumentCopy', title: '复制', fnName: 'copy' }, - { icon: 'ele-Delete', title: '删除', fnName: 'del' }, - { icon: 'ele-FullScreen', title: '全屏', fnName: 'fullscreen' }, - ], - }); - // 设置 tool 标题 - const setToolTitle = computed(() => { - let { globalTitle } = themeConfig.value; - return `${globalTitle}工作流`; - }); - // 顶部工具栏 - const onToolClick = (fnName: string) => { - emit('tool', fnName); - }; - return { - setToolTitle, - onToolClick, - ...toRefs(state), - }; - }, -}); -</script> - -<style scoped lang="scss"> -.workflow-tool { - height: 35px; - display: flex; - align-items: center; - border-bottom: 1px solid var(--el-border-color-light, #ebeef5); - color: var(--el-text-color-primary); - .workflow-tool-right { - flex: 1; - display: flex; - justify-content: flex-end; - } - &-icon { - padding: 0 10px; - cursor: pointer; - color: var(--next-bg-topBarColor); - height: 35px; - line-height: 35px; - display: flex; - align-items: center; - &:hover { - background: rgba(0, 0, 0, 0.04); - i { - display: inline-block; - animation: logoAnimation 0.3s ease-in-out; - } - } - } -} -</style> diff --git a/src/views/pages/workflow/index.vue b/src/views/pages/workflow/index.vue deleted file mode 100644 index a84e496..0000000 --- a/src/views/pages/workflow/index.vue +++ /dev/null @@ -1,693 +0,0 @@ -<template> - <div class="workflow-container"> - <div class="workflow-mask" v-if="isShow"></div> - <div class="layout-view-bg-white flex" :style="{ height: `calc(100vh - ${setViewHeight}` }"> - <div class="workflow"> - <!-- 顶部工具栏 --> - <Tool @tool="onToolClick" /> - - <!-- 左侧导航区 --> - <div class="workflow-content"> - <div class="workflow-left"> - <el-scrollbar> - <div - ref="leftNavRefs" - v-for="(val, key) in leftNavList" - :key="val.id" - :style="{ height: val.isOpen ? 'auto' : '50px', overflow: 'hidden' }" - class="workflow-left-id" - > - <div class="workflow-left-title" @click="onTitleClick(val)"> - <span>{{ val.title }}</span> - <SvgIcon :name="val.isOpen ? 'ele-ArrowDown' : 'ele-ArrowRight'" /> - </div> - <div class="workflow-left-item" v-for="(v, k) in val.children" :key="k" :data-name="v.name" :data-icon="v.icon" :data-id="v.id"> - <div class="workflow-left-item-icon"> - <SvgIcon :name="v.icon" class="workflow-icon-drag" /> - <div class="font10 pl5 name">{{ v.name }}</div> - </div> - </div> - </div> - </el-scrollbar> - </div> - - <!-- 右侧绘画区 --> - <div class="workflow-right" ref="workflowRightRef"> - <div - v-for="(v, k) in jsplumbData.nodeList" - :key="v.nodeId" - :id="v.nodeId" - :data-node-id="v.nodeId" - :class="v.class" - :style="{ left: v.left, top: v.top }" - @click="onItemCloneClick(k)" - @contextmenu.prevent="onContextmenu(v, k, $event)" - > - <div class="workflow-right-box" :class="{ 'workflow-right-active': jsPlumbNodeIndex === k }"> - <div class="workflow-left-item-icon"> - <SvgIcon :name="v.icon" class="workflow-icon-drag" /> - <div class="font10 pl5 name">{{ v.name }}</div> - </div> - </div> - </div> - </div> - </div> - </div> - </div> - - <!-- 节点右键菜单 --> - <Contextmenu :dropdown="dropdownNode" ref="contextmenuNodeRef" @current="onCurrentNodeClick" /> - <!-- 线右键菜单 --> - <Contextmenu :dropdown="dropdownLine" ref="contextmenuLineRef" @current="onCurrentLineClick" /> - <!-- 抽屉表单、线 --> - <Drawer ref="drawerRef" @label="setLineLabel" @node="setNodeContent" /> - - <!-- 顶部工具栏-帮助弹窗 --> - <Help ref="helpRef" /> - </div> -</template> - -<script lang="ts"> -import { defineComponent, toRefs, reactive, computed, onMounted, onUnmounted, nextTick, ref } from 'vue'; -import { ElMessage, ElMessageBox } from 'element-plus'; -import { jsPlumb } from 'jsplumb'; -import Sortable from 'sortablejs'; -import { storeToRefs } from 'pinia'; -import { useThemeConfig } from '/@/stores/themeConfig'; -import { useTagsViewRoutes } from '/@/stores/tagsViewRoutes'; -import Tool from './component/tool/index.vue'; -import Help from './component/tool/help.vue'; -import Contextmenu from './component/contextmenu/index.vue'; -import Drawer from './component/drawer/index.vue'; -import commonFunction from '/@/utils/commonFunction'; -import { leftNavList } from './js/mock'; -import { jsplumbDefaults, jsplumbMakeSource, jsplumbMakeTarget, jsplumbConnect } from './js/config'; - -// 定义接口来定义对象的类型 -interface NodeListState { - id: string | number; - nodeId: string | undefined; - class: HTMLElement | string; - left: number | string; - top: number | string; - icon: string; - name: string; -} -interface LineListState { - sourceId: string; - targetId: string; - label: string; -} -interface XyState { - x: string | number; - y: string | number; -} -interface WorkflowState { - workflowRightRef: HTMLDivElement | null; - leftNavRefs: any[]; - leftNavList: any[]; - dropdownNode: XyState; - dropdownLine: XyState; - isShow: boolean; - jsPlumb: any; - jsPlumbNodeIndex: null | number; - jsplumbDefaults: any; - jsplumbMakeSource: any; - jsplumbMakeTarget: any; - jsplumbConnect: any; - jsplumbData: { - nodeList: Array<NodeListState>; - lineList: Array<LineListState>; - }; -} - -export default defineComponent({ - name: 'pagesWorkflow', - components: { Tool, Contextmenu, Drawer, Help }, - setup() { - const contextmenuNodeRef = ref(); - const contextmenuLineRef = ref(); - const drawerRef = ref(); - const helpRef = ref(); - const stores = useTagsViewRoutes(); - const storesThemeConfig = useThemeConfig(); - const { themeConfig } = storeToRefs(storesThemeConfig); - const { isTagsViewCurrenFull } = storeToRefs(stores); - const { copyText } = commonFunction(); - const state = reactive<WorkflowState>({ - workflowRightRef: null as HTMLDivElement | null, - leftNavRefs: [], - leftNavList: [], - dropdownNode: { x: '', y: '' }, - dropdownLine: { x: '', y: '' }, - isShow: false, - jsPlumb: null, - jsPlumbNodeIndex: null, - jsplumbDefaults, - jsplumbMakeSource, - jsplumbMakeTarget, - jsplumbConnect, - jsplumbData: { - nodeList: [], - lineList: [], - }, - }); - // 设置 view 的高度 - const setViewHeight = computed(() => { - let { isTagsview } = themeConfig.value; - if (isTagsViewCurrenFull.value) { - return `30px`; - } else { - if (isTagsview) return `114px`; - else return `80px`; - } - }); - // 设置 宽度小于 768,不支持操 - const setClientWidth = () => { - const clientWidth = document.body.clientWidth; - clientWidth < 768 ? (state.isShow = true) : (state.isShow = false); - }; - // 左侧导航-数据初始化 - const initLeftNavList = () => { - state.leftNavList = leftNavList; - state.jsplumbData = { - nodeList: [ - { nodeId: 'huej738hbji', left: '148px', top: '93px', class: 'workflow-right-clone', icon: 'iconfont icon-gongju', name: '引擎', id: '11' }, - { - nodeId: '52kcszzyxrd', - left: '458px', - top: '203px', - class: 'workflow-right-clone', - icon: 'iconfont icon-shouye_dongtaihui', - name: '模版', - id: '12', - }, - { - nodeId: 'nltskl6k4me', - left: '164px', - top: '350px', - class: 'workflow-right-clone', - icon: 'iconfont icon-zhongduancanshuchaxun', - name: '名称', - id: '13', - }, - ], - lineList: [ - { sourceId: 'huej738hbji', targetId: '52kcszzyxrd', label: '传送' }, - { sourceId: 'huej738hbji', targetId: 'nltskl6k4me', label: '' }, - ], - }; - }; - // 左侧导航-初始化拖动 - const initSortable = () => { - state.leftNavRefs.forEach(v => { - Sortable.create(v as HTMLDivElement, { - group: { - name: 'vue-next-admin-1', - pull: 'clone', - put: false, - }, - animation: 0, - sort: false, - draggable: '.workflow-left-item', - forceFallback: true, - onEnd: function (evt: any) { - const { name, icon, id } = evt.clone.dataset; - const { layerX, layerY, clientX, clientY } = evt.originalEvent; - const el = state.workflowRightRef!; - const { x, y, width, height } = el.getBoundingClientRect(); - if (clientX < x || clientX > width + x || clientY < y || y > y + height) { - ElMessage.warning('请把节点拖入到画布中'); - } else { - // 节点id(唯一) - const nodeId = Math.random().toString(36).substr(2, 12); - // 处理节点数据 - const node = { - nodeId, - left: `${layerX - 40}px`, - top: `${layerY - 15}px`, - class: 'workflow-right-clone', - name, - icon, - id, - }; - // 右侧视图内容数组 - state.jsplumbData.nodeList.push(node); - // 元素加载完毕时 - nextTick(() => { - // 整个节点作为source或者target - state.jsPlumb.makeSource(nodeId, state.jsplumbMakeSource); - // // 整个节点作为source或者target - state.jsPlumb.makeTarget(nodeId, state.jsplumbMakeTarget, jsplumbConnect); - // 设置节点可以拖拽(此处为id值,非class) - state.jsPlumb.draggable(nodeId, { - containment: 'parent', - stop: (el: any) => { - state.jsplumbData.nodeList.forEach((v) => { - if (v.nodeId === el.el.id) { - // 节点x, y重新赋值,防止再次从左侧导航中拖拽节点时,x, y恢复默认 - v.left = `${el.pos[0]}px`; - v.top = `${el.pos[1]}px`; - } - }); - }, - }); - }); - } - }, - }); - }); - }; - // 初始化 jsPlumb - const initJsPlumb = () => { - (<any>jsPlumb).ready(() => { - state.jsPlumb = (<any>jsPlumb).getInstance({ - detachable: false, - Container: 'workflow-right', - }); - state.jsPlumb.fire('jsPlumbDemoLoaded', state.jsPlumb); - // 导入默认配置 - state.jsPlumb.importDefaults(state.jsplumbDefaults); - // 会使整个jsPlumb立即重绘。 - state.jsPlumb.setSuspendDrawing(false, true); - // 初始化节点、线的链接 - initJsPlumbConnection(); - // 点击线弹出右键菜单 - state.jsPlumb.bind('contextmenu', (conn: any, originalEvent: MouseEvent) => { - originalEvent.preventDefault(); - const { sourceId, targetId } = conn; - const { clientX, clientY } = originalEvent; - state.dropdownLine.x = clientX; - state.dropdownLine.y = clientY; - const v: any = state.jsplumbData.nodeList.find((v) => v.nodeId === targetId); - const line: any = state.jsplumbData.lineList.find((v) => v.sourceId === sourceId && v.targetId === targetId); - v.type = 'line'; - v.label = line.label; - contextmenuLineRef.value.openContextmenu(v, conn); - }); - // 连线之前 - state.jsPlumb.bind('beforeDrop', (conn: any) => { - const { sourceId, targetId } = conn; - const item = state.jsplumbData.lineList.find((v) => v.sourceId === sourceId && v.targetId === targetId); - if (item) { - ElMessage.warning('关系已存在,不可重复连接'); - return false; - } else { - return true; - } - }); - // 连线时 - state.jsPlumb.bind('connection', (conn: any) => { - const { sourceId, targetId } = conn; - state.jsplumbData.lineList.push({ - sourceId, - targetId, - label: '', - }); - }); - // 删除连线时回调函数 - state.jsPlumb.bind('connectionDetached', (conn: any) => { - const { sourceId, targetId } = conn; - state.jsplumbData.lineList = state.jsplumbData.lineList.filter((line) => { - if (line.sourceId == sourceId && line.targetId == targetId) { - return false; - } - return true; - }); - }); - }); - }; - // 初始化节点、线的链接 - const initJsPlumbConnection = () => { - // 节点 - state.jsplumbData.nodeList.forEach((v) => { - // 整个节点作为source或者target - state.jsPlumb.makeSource(v.nodeId, state.jsplumbMakeSource); - // 整个节点作为source或者target - state.jsPlumb.makeTarget(v.nodeId, state.jsplumbMakeTarget, jsplumbConnect); - // 设置节点可以拖拽(此处为id值,非class) - state.jsPlumb.draggable(v.nodeId, { - containment: 'parent', - stop: (el: any) => { - state.jsplumbData.nodeList.forEach((v) => { - if (v.nodeId === el.el.id) { - // 节点x, y重新赋值,防止再次从左侧导航中拖拽节点时,x, y恢复默认 - v.left = `${el.pos[0]}px`; - v.top = `${el.pos[1]}px`; - } - }); - }, - }); - }); - // 线 - state.jsplumbData.lineList.forEach((v) => { - state.jsPlumb.connect( - { - source: v.sourceId, - target: v.targetId, - label: v.label, - }, - state.jsplumbConnect - ); - }); - }; - // 左侧导航-菜单标题点击 - const onTitleClick = (val: any) => { - val.isOpen = !val.isOpen; - }; - // 右侧内容区-当前项点击 - const onItemCloneClick = (k: number) => { - state.jsPlumbNodeIndex = k; - }; - // 右侧内容区-当前项右键菜单点击 - const onContextmenu = (v: any, k: number, e: MouseEvent) => { - state.jsPlumbNodeIndex = k; - const { clientX, clientY } = e; - state.dropdownNode.x = clientX; - state.dropdownNode.y = clientY; - v.type = 'node'; - v.label = ''; - let item: any = {}; - state.leftNavList.forEach((l) => { - if (l.children) if (l.children.find((c: any) => c.id === v.id)) item = l.children.find((c: any) => c.id === v.id); - }); - v.from = item.form; - contextmenuNodeRef.value.openContextmenu(v); - }; - // 右侧内容区-当前项右键菜单点击回调(节点) - const onCurrentNodeClick = (item: any) => { - const { contextMenuClickId, nodeId } = item; - if (contextMenuClickId === 0) { - const nodeIndex = state.jsplumbData.nodeList.findIndex((item) => item.nodeId === nodeId); - state.jsplumbData.nodeList.splice(nodeIndex, 1); - state.jsPlumb.removeAllEndpoints(nodeId); - state.jsPlumbNodeIndex = null; - } else if (contextMenuClickId === 1) { - drawerRef.value.open(item); - } - }; - // 右侧内容区-当前项右键菜单点击回调(线) - const onCurrentLineClick = (item: any, conn: any) => { - const { contextMenuClickId } = item; - const { endpoints } = conn; - const intercourse: any = []; - endpoints.forEach((v: any) => { - intercourse.push({ - id: v.element.id, - innerText: v.element.innerText, - }); - }); - item.contact = `${intercourse[0].innerText}(${intercourse[0].id}) => ${intercourse[1].innerText}(${intercourse[1].id})`; - if (contextMenuClickId === 0) state.jsPlumb.deleteConnection(conn); - else if (contextMenuClickId === 1) drawerRef.value.open(item, conn); - }; - // 设置线的 label - const setLineLabel = (obj: any) => { - const { sourceId, targetId, label } = obj; - const conn = state.jsPlumb.getConnections({ - source: sourceId, - target: targetId, - })[0]; - conn.setLabel(label); - if (!label || label === '') { - conn.addClass('workflow-right-empty-label'); - } else { - conn.removeClass('workflow-right-empty-label'); - conn.addClass('workflow-right-label'); - } - state.jsplumbData.lineList.forEach((v) => { - if (v.sourceId === sourceId && v.targetId === targetId) v.label = label; - }); - }; - // 设置节点内容 - const setNodeContent = (obj: any) => { - const { nodeId, name, icon } = obj; - // 设置节点 name 与 icon - state.jsplumbData.nodeList.forEach((v) => { - if (v.nodeId === nodeId) { - v.name = name; - v.icon = icon; - } - }); - // 重绘 - nextTick(() => { - state.jsPlumb.setSuspendDrawing(false, true); - }); - }; - // 顶部工具栏-当前项点击 - const onToolClick = (fnName: String) => { - switch (fnName) { - case 'help': - onToolHelp(); - break; - case 'download': - onToolDownload(); - break; - case 'submit': - onToolSubmit(); - break; - case 'copy': - onToolCopy(); - break; - case 'del': - onToolDel(); - break; - case 'fullscreen': - onToolFullscreen(); - break; - } - }; - // 顶部工具栏-帮助 - const onToolHelp = () => { - nextTick(() => { - helpRef.value.open(); - }); - }; - // 顶部工具栏-下载 - const onToolDownload = () => { - const { globalTitle } = themeConfig.value; - const href = 'data:text/json;charset=utf-8,' + encodeURIComponent(JSON.stringify(state.jsplumbData, null, '\t')); - const aLink = document.createElement('a'); - aLink.setAttribute('href', href); - aLink.setAttribute('download', `${globalTitle}工作流.json`); - aLink.click(); - aLink.remove(); - ElMessage.success('下载成功'); - }; - // 顶部工具栏-提交 - const onToolSubmit = () => { - // console.log(state.jsplumbData); - ElMessage.success('数据提交成功'); - }; - // 顶部工具栏-复制 - const onToolCopy = () => { - copyText(JSON.stringify(state.jsplumbData)); - }; - // 顶部工具栏-删除 - const onToolDel = () => { - ElMessageBox.confirm('此操作将清空画布,是否继续?', '提示', { - confirmButtonText: '清空', - cancelButtonText: '取消', - }) - .then(() => { - state.jsplumbData.nodeList.forEach((v) => { - state.jsPlumb.removeAllEndpoints(v.nodeId); - }); - nextTick(() => { - state.jsplumbData = { - nodeList: [], - lineList: [], - }; - ElMessage.success('清空画布成功'); - }); - }) - .catch(() => {}); - }; - // 顶部工具栏-全屏 - const onToolFullscreen = () => { - stores.setCurrenFullscreen(true); - }; - // 页面加载时 - onMounted(async () => { - await initLeftNavList(); - initSortable(); - initJsPlumb(); - setClientWidth(); - window.addEventListener('resize', setClientWidth); - }); - // 页面卸载时 - onUnmounted(() => { - window.removeEventListener('resize', setClientWidth); - }); - return { - setViewHeight, - setClientWidth, - setLineLabel, - setNodeContent, - onTitleClick, - onItemCloneClick, - onContextmenu, - onCurrentNodeClick, - onCurrentLineClick, - contextmenuNodeRef, - contextmenuLineRef, - drawerRef, - helpRef, - onToolClick, - ...toRefs(state), - }; - }, -}); -</script> - -<style scoped lang="scss"> -.workflow-container { - position: relative; - .workflow { - display: flex; - height: 100%; - width: 100%; - flex-direction: column; - .workflow-content { - display: flex; - height: calc(100% - 35px); - .workflow-left { - width: 220px; - height: 100%; - border-right: 1px solid var(--el-border-color-light, #ebeef5); - ::v-deep(.el-collapse-item__content) { - padding-bottom: 0; - } - .workflow-left-title { - height: 50px; - display: flex; - align-items: center; - padding: 0 10px; - border-top: 1px solid var(--el-border-color-light, #ebeef5); - color: var(--el-text-color-primary); - cursor: default; - span { - flex: 1; - } - } - .workflow-left-item { - display: inline-block; - width: calc(50% - 15px); - position: relative; - cursor: move; - margin: 0 0 10px 10px; - .workflow-left-item-icon { - height: 35px; - display: flex; - align-items: center; - transition: all 0.3s ease; - padding: 5px 10px; - border: 1px dashed transparent; - background: var(--next-bg-color); - border-radius: 3px; - i, - .name { - color: var(--el-text-color-secondary); - transition: all 0.3s ease; - white-space: nowrap; - text-overflow: ellipsis; - overflow: hidden; - } - &:hover { - transition: all 0.3s ease; - border: 1px dashed var(--el-color-primary); - background: var(--el-color-primary-light-9); - border-radius: 5px; - i, - .name { - transition: all 0.3s ease; - color: var(--el-color-primary); - } - } - } - } - & .workflow-left-id:first-of-type { - .workflow-left-title { - border-top: none; - } - } - } - .workflow-right { - flex: 1; - position: relative; - overflow: hidden; - height: 100%; - background-image: linear-gradient(90deg, rgb(156 214 255 / 15%) 10%, rgba(0, 0, 0, 0) 10%), - linear-gradient(rgb(156 214 255 / 15%) 10%, rgba(0, 0, 0, 0) 10%); - background-size: 10px 10px; - .workflow-right-clone { - position: absolute; - .workflow-right-box { - height: 35px; - align-items: center; - color: var(--el-text-color-secondary); - padding: 0 10px; - border-radius: 3px; - cursor: move; - transition: all 0.3s ease; - min-width: 94.5px; - background: var(--el-color-white); - border: 1px solid var(--el-border-color-light, #ebeef5); - .workflow-left-item-icon { - display: flex; - align-items: center; - height: 35px; - } - &:hover { - border: 1px dashed var(--el-color-primary); - background: var(--el-color-primary-light-9); - transition: all 0.3s ease; - color: var(--el-color-primary); - i { - cursor: Crosshair; - } - } - } - .workflow-right-active { - border: 1px dashed var(--el-color-primary); - background: var(--el-color-primary-light-9); - color: var(--el-color-primary); - } - } - ::v-deep(.jtk-overlay):not(.aLabel) { - padding: 4px 10px; - border: 1px solid var(--el-border-color-light, #ebeef5) !important; - color: var(--el-text-color-secondary) !important; - background: var(--el-color-white) !important; - border-radius: 3px; - font-size: 10px; - } - ::v-deep(.jtk-overlay.workflow-right-empty-label) { - display: none; - } - } - } - } - .workflow-mask { - position: absolute; - top: 0; - right: 0; - bottom: 0; - left: 0; - &::after { - content: '手机版不支持 jsPlumb 操作'; - position: absolute; - top: 0; - right: 0; - bottom: 0; - left: 0; - z-index: 1; - background: rgba(255, 255, 255, 0.9); - color: #666666; - display: flex; - align-items: center; - justify-content: center; - } - } -} -</style> diff --git a/src/views/pages/workflow/js/config.ts b/src/views/pages/workflow/js/config.ts deleted file mode 100644 index 3784c02..0000000 --- a/src/views/pages/workflow/js/config.ts +++ /dev/null @@ -1,99 +0,0 @@ -// jsplumb 默认配置 -export const jsplumbDefaults = { - // 多个锚点 [源锚点,目标锚点] - Anchors: [ - 'Top', - 'TopCenter', - 'TopRight', - 'TopLeft', - 'Right', - 'RightMiddle', - 'Bottom', - 'BottomCenter', - 'BottomRight', - 'BottomLeft', - 'Left', - 'LeftMiddle', - ], - // 连线的容器id - Container: 'workflow-right', - // 设置链接线的形状,如直线或者曲线之类的。anchor可以去设置锚点的位置。可选值"<Bezier|Flowchart|StateMachine|Straight>" - Connector: ['Bezier', { curviness: 100 }], - // 节点是否可以用鼠标拖动使其断开,默认为true。即用鼠标链接上的连线,也可以使用鼠标拖动让其断开。设置成false,可以让其拖动也不会自动断开 - ConnectionsDetachable: false, - // 删除线的时候节点不删除 - DeleteEndpointsOnDetach: false, - // 每当添加或以其他方式创建 Endpoint 并且 jsPlumb 尚未给出任何明确的 Endpoint 定义时将使用 - Endpoint: ['Blank', { Overlays: '' }], - // 连接中源和目标端点的默认外观 - EndpointStyle: { fill: '#1879ffa1', outlineWidth: 1 }, - // jsPlumb 的内部日志记录是否打开 - LogEnabled: true, - // 连接器的默认外观 - PaintStyle: { - stroke: '#E0E3E7', - strokeWidth: 1, - outlineStroke: 'transparent', - outlineWidth: 10, - }, - // 用于配置任何可拖动元素的默认选项jsPlumb.draggable - DragOptions: { cursor: 'pointer', zIndex: 2000 }, - // 添加到连接器和端点的默认叠加层。已弃用:从 4.x 开始,将不支持此功能。并非所有叠加层都可以连接到连接器和端点。 - Overlays: [ - [ - 'Arrow', - { - width: 10, // 箭头尾部的宽度 - length: 8, // 从箭头的尾部到头部的距离 - location: 1, // 位置,建议使用0~1之间 - direction: 1, // 方向,默认值为1(表示向前),可选-1(表示向后) - foldback: 0.623, // 折回,也就是尾翼的角度,默认0.623,当为1时,为正三角 - }, - ], - [ - 'Label', - { - label: '', - location: 0.5, - cssClass: 'aLabel', - }, - ], - ], - // 默认渲染模式 svg、canvas - RenderMode: 'svg', - // 悬停状态下连接的默认外观 - HoverPaintStyle: { stroke: '#b0b2b5', strokeWidth: 1 }, - // 悬停状态下端点的默认外观 - EndpointHoverStyle: { fill: 'red' }, - // 端点和连接的默认范围。范围提供了对哪些端点可以连接到哪些其他端点的基本控制 - Scope: 'jsPlumb_DefaultScope', -}; - -// 整个节点作为source或者target -export const jsplumbMakeSource = { - // 设置可以拖拽的类名,只要鼠标移动到该类名上的DOM,就可以拖拽连线 - filter: '.workflow-icon-drag', - filterExclude: false, - anchor: 'Continuous', - // 是否允许自己连接自己 - allowLoopback: true, - maxConnections: -1, -}; - -// 整个节点作为source或者target -export const jsplumbMakeTarget = { - filter: '.workflow-icon-drag', - filterExclude: false, - // 是否允许自己连接自己 - anchor: 'Continuous', - allowLoopback: true, - dropOptions: { hoverClass: 'ef-drop-hover' }, -}; - -// 连线参数 -export const jsplumbConnect = { - isSource: true, - isTarget: true, - // 动态锚点、提供了4个方向 Continuous、AutoDefault - anchor: 'Continuous', -}; diff --git a/src/views/pages/workflow/js/mock.ts b/src/views/pages/workflow/js/mock.ts deleted file mode 100644 index 151c3ac..0000000 --- a/src/views/pages/workflow/js/mock.ts +++ /dev/null @@ -1,262 +0,0 @@ -// 左侧菜单导航数据 -export const leftNavList = [ - { - title: '工作流', - icon: 'iconfont icon-shouye', - isOpen: true, - id: '1', - children: [ - { - icon: 'iconfont icon-gongju', - name: '引擎', - id: '11', - form: [ - { - type: 'input', - label: '客户姓名', - prop: 'name', - placeholder: '请输入客户姓名', - required: true, - disabled: false, - }, - { - type: 'select', - label: '性别', - prop: 'sex', - placeholder: '请选择性别', - required: true, - disabled: false, - options: [ - { - value: '0', - label: '女', - }, - { - value: '1', - label: '男', - }, - ], - }, - { - type: 'input', - label: '员工编号', - prop: 'number', - placeholder: '请输入员工编号', - required: true, - disabled: false, - }, - { - type: 'input', - label: '办公电话', - prop: 'mobile', - placeholder: '请输入办公电话', - required: true, - disabled: false, - }, - { - type: 'select', - label: '权限分配', - prop: 'role', - placeholder: '请选择性别', - required: true, - disabled: false, - options: [ - { - value: '0', - label: '编辑权限', - }, - { - value: '1', - label: '删除权限', - }, - ], - }, - { - type: 'checkbox', - label: '模块选择', - prop: 'module', - placeholder: '请选择模块', - required: true, - disabled: false, - }, - ], - }, - { - icon: 'iconfont icon-shouye_dongtaihui', - name: '模版', - id: '12', - form: [ - { - type: 'input', - label: '等级', - prop: 'grade', - placeholder: '请输入等级', - required: true, - disabled: false, - }, - { - type: 'input', - label: '登记密码', - prop: 'password', - placeholder: '请输入登记密码', - required: true, - disabled: false, - }, - ], - }, - { - icon: 'iconfont icon-zhongduancanshuchaxun', - name: '名称', - id: '13', - form: [ - { - type: 'input', - label: '数据表', - prop: 'dataSheet', - placeholder: '请输入数据表', - required: true, - disabled: false, - }, - { - type: 'input', - label: '字段配置', - prop: 'field', - placeholder: '请输入字段配置', - required: true, - disabled: false, - }, - ], - }, - { - icon: 'iconfont icon-zhongduancanshu', - name: '版本', - id: '14', - form: [ - { - type: 'input', - label: '发布模板', - prop: 'publish', - placeholder: '请输入发布模板', - required: true, - disabled: false, - }, - ], - }, - { - icon: 'iconfont icon-bolangnengshiyanchang', - name: '建模', - id: '15', - form: [ - { - type: 'input', - label: '内容模板', - prop: 'content', - placeholder: '请输入内容模板', - required: true, - disabled: false, - }, - ], - }, - { - icon: 'iconfont icon-xingqiu', - name: '节点', - id: '16', - form: [ - { - type: 'input', - label: '活动名称6', - prop: 'name16', - }, - ], - }, - ], - }, - { - title: '流程', - isOpen: true, - icon: 'iconfont icon-caijian', - id: '2', - children: [ - { - icon: 'iconfont icon-fuwenben', - name: '实例', - id: '21', - form: [ - { - type: 'input', - label: '活动名称7', - prop: 'name21', - }, - ], - }, - { - icon: 'iconfont icon-fuwenbenkuang', - name: '轨迹', - id: '22', - form: [ - { - type: 'input', - label: '活动名称8', - prop: 'name22', - }, - ], - }, - { - icon: 'iconfont icon-shangchuan', - name: '数据', - id: '23', - form: [ - { - type: 'input', - label: '活动名称9', - prop: 'name23', - }, - ], - }, - ], - }, - { - title: '任务', - isOpen: true, - icon: 'iconfont icon-shuju', - id: '3', - children: [ - { - icon: 'iconfont icon-icon-', - name: '参与人', - id: '31', - form: [ - { - type: 'input', - label: '活动名称1', - prop: 'name31', - }, - ], - }, - { - icon: 'iconfont icon-gerenzhongxin', - name: '执行人', - id: '32', - form: [ - { - type: 'input', - label: '活动名称2', - prop: 'name32', - }, - ], - }, - { - icon: 'iconfont icon-fangkuang', - name: '工单', - id: '33', - form: [ - { - type: 'input', - label: '活动名称3', - prop: 'name33', - }, - ], - }, - ], - }, -]; diff --git a/src/views/params/common/details.vue b/src/views/params/common/details.vue deleted file mode 100644 index 9ba885e..0000000 --- a/src/views/params/common/details.vue +++ /dev/null @@ -1,52 +0,0 @@ -<template> - <div class="layout-view-bg-white flex" :style="{ height: `calc(100vh - ${setViewHeight}` }"> - <div class="flex-margin color-primary"> - <div>paramsCommonDetails</div> - <div class="mt10 mb10">路径:path: {{ params.path }}</div> - <div>参数:query: {{ params.query }}</div> - </div> - </div> -</template> - -<script lang="ts"> -import { defineComponent, toRefs, reactive, computed, onMounted } from 'vue'; -import { useRoute } from 'vue-router'; -import { storeToRefs } from 'pinia'; -import { useThemeConfig } from '/@/stores/themeConfig'; -import { useTagsViewRoutes } from '/@/stores/tagsViewRoutes'; - -export default defineComponent({ - name: 'paramsCommonDetails', - setup() { - const route = useRoute(); - const storesTagsViewRoutes = useTagsViewRoutes(); - const storesThemeConfig = useThemeConfig(); - const { themeConfig } = storeToRefs(storesThemeConfig); - const { isTagsViewCurrenFull } = storeToRefs(storesTagsViewRoutes); - const state = reactive({ - params: { - path: '', - query: '', - }, - }); - // 设置 view 的高度 - const setViewHeight = computed(() => { - let { isTagsview } = themeConfig.value; - if (isTagsViewCurrenFull.value) { - return `30px`; - } else { - if (isTagsview) return `114px`; - else return `80px`; - } - }); - // 页面加载时 - onMounted(() => { - state.params = <any>route; - }); - return { - setViewHeight, - ...toRefs(state), - }; - }, -}); -</script> diff --git a/src/views/params/common/index.vue b/src/views/params/common/index.vue deleted file mode 100644 index 733156c..0000000 --- a/src/views/params/common/index.vue +++ /dev/null @@ -1,100 +0,0 @@ -<template> - <div class="layout-view-bg-white flex" :style="{ height: `calc(100vh - ${setViewHeight}` }"> - <div class="flex-margin" style="width: 400px"> - <el-result icon="success" title="普通路由" subTitle="可 `开启 TagsView 共用` 进行单标签测试"> - <template #extra> - <el-alert type="success" :closable="false" class="mb30"> - <template #default> - <div>1、设置非国际化:格式:tagsViewName=xxx</div> - <br /> - <div>2、设置国际化:格式:tagsViewName=JSON.stringify({"zh-cn":"测试用","en":"test+page","zh-tw":"測試用"})</div> - <br /> - <div>3、设置国际化后,去顶栏切换语言查看演示效果</div> - <br /> - <div> - 4、 <a href="https://gitee.com/q7but" target="_black">感谢@q7but</a>、 - <a href="https://gitee.com/lyt-top/vue-next-admin/pulls/22/files" target="_black">!22 add 添加自定义 tagVIewName 拓展,支持国际化</a> - </div> - </template> - </el-alert> - <el-input v-model="tagsViewName" placeholder="请输入tagsView 名称" clearable class="mb15" style="width: 400px"></el-input> - <el-input v-model="value" placeholder="请输入路由参数 id 值" clearable style="width: 400px"></el-input> - <el-button type="primary" size="default" class="mt15" @click="onGoDetailsClick"> - <SvgIcon name="iconfont icon-putong" /> - 普通路由传参 - </el-button> - <el-button type="primary" size="default" class="mt15" @click="onChangeI18n"> - <SvgIcon name="iconfont icon-fuhao-zhongwen" /> - {{ tagsViewNameIsI18n ? '普通的演示' : '国际化演示' }} - </el-button> - </template> - </el-result> - </div> - </div> -</template> - -<script lang="ts"> -import { toRefs, reactive, computed, defineComponent } from 'vue'; -import { useRouter } from 'vue-router'; -import { storeToRefs } from 'pinia'; -import { useThemeConfig } from '/@/stores/themeConfig'; -import { useTagsViewRoutes } from '/@/stores/tagsViewRoutes'; - -export default defineComponent({ - name: 'paramsCommon', - setup() { - const storesTagsViewRoutes = useTagsViewRoutes(); - const storesThemeConfig = useThemeConfig(); - const { themeConfig } = storeToRefs(storesThemeConfig); - const { isTagsViewCurrenFull } = storeToRefs(storesTagsViewRoutes); - const state = reactive({ - value: '', - tagsViewName: '', - tagsViewNameIsI18n: false, - }); - const router = useRouter(); - // 设置 view 的高度 - const setViewHeight = computed(() => { - let { isTagsview } = themeConfig.value; - if (isTagsViewCurrenFull.value) { - return `30px`; - } else { - if (isTagsview) return `114px`; - else return `80px`; - } - }); - // 跳转到详情 - /** - * 设置 tagsView 名称: - * 传不同的 tagsViewName 值 - */ - const onGoDetailsClick = () => { - const params: any = { id: state.value }; - if (state.tagsViewName) params.tagsViewName = state.tagsViewName; - router.push({ - path: '/params/common/details', - query: params, - }); - state.value = ''; - }; - const onChangeI18n = () => { - state.tagsViewNameIsI18n = !state.tagsViewNameIsI18n; - if (state.tagsViewNameIsI18n) { - state.tagsViewName = JSON.stringify({ - 'zh-cn': '测试用', - en: 'test page', - 'zh-tw': '測試用', - }); - } else { - state.tagsViewName = '我是普通路由测试tagsViewName(非国际化)'; - } - }; - return { - setViewHeight, - onGoDetailsClick, - onChangeI18n, - ...toRefs(state), - }; - }, -}); -</script> diff --git a/src/views/params/dynamic/details.vue b/src/views/params/dynamic/details.vue deleted file mode 100644 index 7283ba1..0000000 --- a/src/views/params/dynamic/details.vue +++ /dev/null @@ -1,52 +0,0 @@ -<template> - <div class="layout-view-bg-white flex" :style="{ height: `calc(100vh - ${setViewHeight}` }"> - <div class="flex-margin color-primary"> - <div>paramsDynamicDetails</div> - <div class="mt10 mb10">路径:path: {{ params.path }}</div> - <div>参数:params: {{ params.params }}</div> - </div> - </div> -</template> - -<script lang="ts"> -import { defineComponent, toRefs, reactive, computed, onMounted } from 'vue'; -import { useRoute } from 'vue-router'; -import { storeToRefs } from 'pinia'; -import { useThemeConfig } from '/@/stores/themeConfig'; -import { useTagsViewRoutes } from '/@/stores/tagsViewRoutes'; - -export default defineComponent({ - name: 'paramsDynamicDetails', - setup() { - const storesTagsViewRoutes = useTagsViewRoutes(); - const storesThemeConfig = useThemeConfig(); - const { themeConfig } = storeToRefs(storesThemeConfig); - const { isTagsViewCurrenFull } = storeToRefs(storesTagsViewRoutes); - const route = useRoute(); - const state = reactive({ - params: { - path: '', - params: '', - }, - }); - // 设置 view 的高度 - const setViewHeight = computed(() => { - let { isTagsview } = themeConfig.value; - if (isTagsViewCurrenFull.value) { - return `30px`; - } else { - if (isTagsview) return `114px`; - else return `80px`; - } - }); - // 页面加载时 - onMounted(() => { - state.params = <any>route; - }); - return { - setViewHeight, - ...toRefs(state), - }; - }, -}); -</script> diff --git a/src/views/params/dynamic/index.vue b/src/views/params/dynamic/index.vue deleted file mode 100644 index 5c39f5d..0000000 --- a/src/views/params/dynamic/index.vue +++ /dev/null @@ -1,102 +0,0 @@ -<template> - <div class="layout-view-bg-white flex" :style="{ height: `calc(100vh - ${setViewHeight}` }"> - <div class="flex-margin" style="width: 400px"> - <el-result icon="warning" title="动态路由" subTitle="可 `开启 TagsView 共用` 进行单标签测试"> - <template #extra> - <el-alert type="success" :closable="false" class="mb30"> - <template #default> - <div>1、设置非国际化:格式:tagsViewName=xxx</div> - <br /> - <div>2、设置国际化:格式:tagsViewName=JSON.stringify({"zh-cn":"测试用","en":"test+page","zh-tw":"測試用"})</div> - <br /> - <div>3、设置国际化后,去顶栏切换语言查看演示效果</div> - <br /> - <div> - 4、 <a href="https://gitee.com/q7but" target="_black">感谢@q7but</a>、 - <a href="https://gitee.com/lyt-top/vue-next-admin/pulls/22/files" target="_black">!22 add 添加自定义 tagVIewName 拓展,支持国际化</a> - </div> - </template> - </el-alert> - <el-input v-model="tagsViewName" placeholder="请输入tagsView 名称" clearable class="mb15" style="width: 400px"></el-input> - <el-input v-model="value" placeholder="请输入路由参数id值" clearable style="width: 400px"></el-input> - <el-button type="primary" size="default" class="mt15" @click="onGoDetailsClick"> - <SvgIcon name="iconfont icon-dongtai" /> - 动态路由传参 - </el-button> - <el-button type="primary" size="default" class="mt15" @click="onChangeI18n"> - <SvgIcon name="iconfont icon-fuhao-zhongwen" /> - {{ tagsViewNameIsI18n ? '普通的演示' : '国际化演示' }} - </el-button> - </template> - </el-result> - </div> - </div> -</template> - -<script lang="ts"> -import { defineComponent, toRefs, reactive, computed } from 'vue'; -import { useRouter } from 'vue-router'; -import { ElMessage } from 'element-plus'; -import { storeToRefs } from 'pinia'; -import { useThemeConfig } from '/@/stores/themeConfig'; -import { useTagsViewRoutes } from '/@/stores/tagsViewRoutes'; - -export default defineComponent({ - name: 'paramsDynamic', - setup() { - const storesTagsViewRoutes = useTagsViewRoutes(); - const storesThemeConfig = useThemeConfig(); - const { themeConfig } = storeToRefs(storesThemeConfig); - const { isTagsViewCurrenFull } = storeToRefs(storesTagsViewRoutes); - const state = reactive({ - value: '', - tagsViewName: '', - tagsViewNameIsI18n: false, - }); - const router = useRouter(); - // 设置 view 的高度 - const setViewHeight = computed(() => { - let { isTagsview } = themeConfig.value; - if (isTagsViewCurrenFull.value) { - return `30px`; - } else { - if (isTagsview) return `114px`; - else return `80px`; - } - }); - // 跳转到详情 - const onGoDetailsClick = () => { - if (!state.tagsViewName) return ElMessage.warning('动态路由tagsViewName为必填,因为路由配置了'); - if (!state.value) return ElMessage.warning('路由参数id值为必填'); - // name 值为路由中的 name - router.push({ - name: 'paramsDynamicDetails', - params: { - t: 'vue-next-admin', - id: state.value, - tagsViewName: state.tagsViewName, - }, - }); - state.value = ''; - }; - const onChangeI18n = () => { - state.tagsViewNameIsI18n = !state.tagsViewNameIsI18n; - if (state.tagsViewNameIsI18n) { - state.tagsViewName = JSON.stringify({ - 'zh-cn': '我是动态路由', - en: 'Im dynamic routing', - 'zh-tw': '我是動態路由', - }); - } else { - state.tagsViewName = '我是动态路由测试tagsViewName(非国际化)'; - } - }; - return { - setViewHeight, - onGoDetailsClick, - onChangeI18n, - ...toRefs(state), - }; - }, -}); -</script> diff --git a/src/views/personal/index.vue b/src/views/personal/index.vue deleted file mode 100644 index 5a29dc7..0000000 --- a/src/views/personal/index.vue +++ /dev/null @@ -1,387 +0,0 @@ -<template> - <div class="personal"> - <el-row> - <!-- 个人信息 --> - <el-col :xs="24" :sm="16"> - <el-card shadow="hover" header="个人信息"> - <div class="personal-user"> - <div class="personal-user-left"> - <el-upload class="h100 personal-user-left-upload" action="https://jsonplaceholder.typicode.com/posts/" multiple :limit="1"> - <img src="https://ss0.bdstatic.com/70cFvHSh_Q1YnxGkpoWK1HF6hhy/it/u=1813762643,1914315241&fm=26&gp=0.jpg" /> - </el-upload> - </div> - <div class="personal-user-right"> - <el-row> - <el-col :span="24" class="personal-title mb18">{{ currentTime }},admin,生活变的再糟糕,也不妨碍我变得更好! </el-col> - <el-col :span="24"> - <el-row> - <el-col :xs="24" :sm="8" class="personal-item mb6"> - <div class="personal-item-label">昵称:</div> - <div class="personal-item-value">小柒</div> - </el-col> - <el-col :xs="24" :sm="16" class="personal-item mb6"> - <div class="personal-item-label">身份:</div> - <div class="personal-item-value">超级管理</div> - </el-col> - </el-row> - </el-col> - <el-col :span="24"> - <el-row> - <el-col :xs="24" :sm="8" class="personal-item mb6"> - <div class="personal-item-label">登录IP:</div> - <div class="personal-item-value">192.168.1.1</div> - </el-col> - <el-col :xs="24" :sm="16" class="personal-item mb6"> - <div class="personal-item-label">登录时间:</div> - <div class="personal-item-value">2021-02-05 18:47:26</div> - </el-col> - </el-row> - </el-col> - </el-row> - </div> - </div> - </el-card> - </el-col> - - <!-- 消息通知 --> - <el-col :xs="24" :sm="8" class="pl15 personal-info"> - <el-card shadow="hover"> - <template #header> - <span>消息通知</span> - <span class="personal-info-more">更多</span> - </template> - <div class="personal-info-box"> - <ul class="personal-info-ul"> - <li v-for="(v, k) in newsInfoList" :key="k" class="personal-info-li"> - <a :href="v.link" target="_block" class="personal-info-li-title">{{ v.title }}</a> - </li> - </ul> - </div> - </el-card> - </el-col> - - <!-- 营销推荐 --> - <el-col :span="24"> - <el-card shadow="hover" class="mt15" header="营销推荐"> - <el-row :gutter="15" class="personal-recommend-row"> - <el-col :sm="6" v-for="(v, k) in recommendList" :key="k" class="personal-recommend-col"> - <div class="personal-recommend" :style="{ 'background-color': v.bg }"> - <SvgIcon :name="v.icon" :size="70" :style="{ color: v.iconColor }" /> - <div class="personal-recommend-auto"> - <div>{{ v.title }}</div> - <div class="personal-recommend-msg">{{ v.msg }}</div> - </div> - </div> - </el-col> - </el-row> - </el-card> - </el-col> - - <!-- 更新信息 --> - <el-col :span="24"> - <el-card shadow="hover" class="mt15 personal-edit" header="更新信息"> - <div class="personal-edit-title">基本信息</div> - <el-form :model="personalForm" size="default" label-width="40px" class="mt35 mb35"> - <el-row :gutter="35"> - <el-col :xs="24" :sm="12" :md="8" :lg="6" :xl="4" class="mb20"> - <el-form-item label="昵称"> - <el-input v-model="personalForm.name" placeholder="请输入昵称" clearable></el-input> - </el-form-item> - </el-col> - <el-col :xs="24" :sm="12" :md="8" :lg="6" :xl="4" class="mb20"> - <el-form-item label="邮箱"> - <el-input v-model="personalForm.email" placeholder="请输入邮箱" clearable></el-input> - </el-form-item> - </el-col> - <el-col :xs="24" :sm="12" :md="8" :lg="6" :xl="4" class="mb20"> - <el-form-item label="签名"> - <el-input v-model="personalForm.autograph" placeholder="请输入签名" clearable></el-input> - </el-form-item> - </el-col> - <el-col :xs="24" :sm="12" :md="8" :lg="6" :xl="4" class="mb20"> - <el-form-item label="职业"> - <el-select v-model="personalForm.occupation" placeholder="请选择职业" clearable class="w100"> - <el-option label="计算机 / 互联网 / 通信" value="1"></el-option> - <el-option label="生产 / 工艺 / 制造" value="2"></el-option> - <el-option label="医疗 / 护理 / 制药" value="3"></el-option> - </el-select> - </el-form-item> - </el-col> - <el-col :xs="24" :sm="12" :md="8" :lg="6" :xl="4" class="mb20"> - <el-form-item label="手机"> - <el-input v-model="personalForm.phone" placeholder="请输入手机" clearable></el-input> - </el-form-item> - </el-col> - <el-col :xs="24" :sm="12" :md="8" :lg="6" :xl="4" class="mb20"> - <el-form-item label="性别"> - <el-select v-model="personalForm.sex" placeholder="请选择性别" clearable class="w100"> - <el-option label="男" value="1"></el-option> - <el-option label="女" value="2"></el-option> - </el-select> - </el-form-item> - </el-col> - <el-col :xs="24" :sm="24" :md="24" :lg="24" :xl="24"> - <el-form-item> - <el-button type="primary"> - <el-icon> - <ele-Position /> - </el-icon> - 更新个人信息 - </el-button> - </el-form-item> - </el-col> - </el-row> - </el-form> - <div class="personal-edit-title mb15">账号安全</div> - <div class="personal-edit-safe-box"> - <div class="personal-edit-safe-item"> - <div class="personal-edit-safe-item-left"> - <div class="personal-edit-safe-item-left-label">账户密码</div> - <div class="personal-edit-safe-item-left-value">当前密码强度:强</div> - </div> - <div class="personal-edit-safe-item-right"> - <el-button text type="primary">立即修改</el-button> - </div> - </div> - </div> - <div class="personal-edit-safe-box"> - <div class="personal-edit-safe-item"> - <div class="personal-edit-safe-item-left"> - <div class="personal-edit-safe-item-left-label">密保手机</div> - <div class="personal-edit-safe-item-left-value">已绑定手机:132****4108</div> - </div> - <div class="personal-edit-safe-item-right"> - <el-button text type="primary">立即修改</el-button> - </div> - </div> - </div> - <div class="personal-edit-safe-box"> - <div class="personal-edit-safe-item"> - <div class="personal-edit-safe-item-left"> - <div class="personal-edit-safe-item-left-label">密保问题</div> - <div class="personal-edit-safe-item-left-value">已设置密保问题,账号安全大幅度提升</div> - </div> - <div class="personal-edit-safe-item-right"> - <el-button text type="primary">立即设置</el-button> - </div> - </div> - </div> - <div class="personal-edit-safe-box"> - <div class="personal-edit-safe-item"> - <div class="personal-edit-safe-item-left"> - <div class="personal-edit-safe-item-left-label">绑定QQ</div> - <div class="personal-edit-safe-item-left-value">已绑定QQ:110****566</div> - </div> - <div class="personal-edit-safe-item-right"> - <el-button text type="primary">立即设置</el-button> - </div> - </div> - </div> - </el-card> - </el-col> - </el-row> - </div> -</template> - -<script lang="ts"> -import { toRefs, reactive, computed, defineComponent } from 'vue'; -import { formatAxis } from '/@/utils/formatTime'; -import { newsInfoList, recommendList } from './mock'; - -// 定义接口来定义对象的类型 -interface PersonalState { - newsInfoList: any; - recommendList: any; - personalForm: any; -} - -export default defineComponent({ - name: 'personal', - setup() { - const state = reactive<PersonalState>({ - newsInfoList, - recommendList, - personalForm: { - name: '', - email: '', - autograph: '', - occupation: '', - phone: '', - sex: '', - }, - }); - // 当前时间提示语 - const currentTime = computed(() => { - return formatAxis(new Date()); - }); - return { - currentTime, - ...toRefs(state), - }; - }, -}); -</script> - -<style scoped lang="scss"> -@import '../../theme/mixins/index.scss'; -.personal { - .personal-user { - height: 130px; - display: flex; - align-items: center; - .personal-user-left { - width: 100px; - height: 130px; - border-radius: 3px; - ::v-deep(.el-upload) { - height: 100%; - } - .personal-user-left-upload { - img { - width: 100%; - height: 100%; - border-radius: 3px; - } - &:hover { - img { - animation: logoAnimation 0.3s ease-in-out; - } - } - } - } - .personal-user-right { - flex: 1; - padding: 0 15px; - .personal-title { - font-size: 18px; - @include text-ellipsis(1); - } - .personal-item { - display: flex; - align-items: center; - font-size: 13px; - .personal-item-label { - color: var(--el-text-color-secondary); - @include text-ellipsis(1); - } - .personal-item-value { - @include text-ellipsis(1); - } - } - } - } - .personal-info { - .personal-info-more { - float: right; - color: var(--el-text-color-secondary); - font-size: 13px; - &:hover { - color: var(--el-color-primary); - cursor: pointer; - } - } - .personal-info-box { - height: 130px; - overflow: hidden; - .personal-info-ul { - list-style: none; - .personal-info-li { - font-size: 13px; - padding-bottom: 10px; - .personal-info-li-title { - display: inline-block; - @include text-ellipsis(1); - color: var(--el-text-color-secondary); - text-decoration: none; - } - & a:hover { - color: var(--el-color-primary); - cursor: pointer; - } - } - } - } - } - .personal-recommend-row { - .personal-recommend-col { - .personal-recommend { - position: relative; - height: 100px; - border-radius: 3px; - overflow: hidden; - cursor: pointer; - &:hover { - i { - right: 0px !important; - bottom: 0px !important; - transition: all ease 0.3s; - } - } - i { - position: absolute; - right: -10px; - bottom: -10px; - font-size: 70px; - transform: rotate(-30deg); - transition: all ease 0.3s; - } - .personal-recommend-auto { - padding: 15px; - position: absolute; - left: 0; - top: 5%; - color: var(--next-color-white); - .personal-recommend-msg { - font-size: 12px; - margin-top: 10px; - } - } - } - } - } - .personal-edit { - .personal-edit-title { - position: relative; - padding-left: 10px; - color: var(--el-text-color-regular); - &::after { - content: ''; - width: 2px; - height: 10px; - position: absolute; - left: 0; - top: 50%; - transform: translateY(-50%); - background: var(--el-color-primary); - } - } - .personal-edit-safe-box { - border-bottom: 1px solid var(--el-border-color-light, #ebeef5); - padding: 15px 0; - .personal-edit-safe-item { - width: 100%; - display: flex; - align-items: center; - justify-content: space-between; - .personal-edit-safe-item-left { - flex: 1; - overflow: hidden; - .personal-edit-safe-item-left-label { - color: var(--el-text-color-regular); - margin-bottom: 5px; - } - .personal-edit-safe-item-left-value { - color: var(--el-text-color-secondary); - @include text-ellipsis(1); - margin-right: 15px; - } - } - } - &:last-of-type { - padding-bottom: 0; - border-bottom: none; - } - } - } -} -</style> diff --git a/src/views/personal/mock.ts b/src/views/personal/mock.ts deleted file mode 100644 index ff57575..0000000 --- a/src/views/personal/mock.ts +++ /dev/null @@ -1,66 +0,0 @@ -/** - * 消息通知 - * @returns 返回模拟数据 - */ -export const newsInfoList: Array<object> = [ - { - title: '[发布] 2021年02月28日发布基于 vue3.x + vite v1.0.0 版本', - date: '02/28', - link: 'https://gitee.com/lyt-top/vue-next-admin', - }, - { - title: '[发布] 2021年04月15日发布 vue2.x + webpack 重构版本', - date: '04/15', - link: 'https://gitee.com/lyt-top/vue-next-admin/tree/vue-prev-admin/', - }, - { - title: '[重构] 2021年04月10日 重构 vue2.x + webpack v1.0.0 版本', - date: '04/10', - link: 'https://gitee.com/lyt-top/vue-next-admin/tree/vue-prev-admin/', - }, - { - title: '[预览] 2020年12月08日,基于 vue3.x 版本后台模板的预览', - date: '12/08', - link: 'http://lyt-top.gitee.io/vue-next-admin-preview/#/login', - }, - { - title: '[预览] 2020年11月15日,基于 vue2.x 版本后台模板的预览', - date: '11/15', - link: 'https://lyt-top.gitee.io/vue-prev-admin-preview/#/login', - }, -]; - -/** - * 营销推荐 - * @returns 返回模拟数据 - */ -export const recommendList: Array<object> = [ - { - title: '优惠券', - msg: '现金券、折扣券、营销必备', - icon: 'ele-Food', - bg: '#48D18D', - iconColor: '#64d89d', - }, - { - title: '多人拼团', - msg: '社交电商、开辟流量', - icon: 'ele-ShoppingCart', - bg: '#F95959', - iconColor: '#F86C6B', - }, - { - title: '分销中心', - msg: '轻松招募分销员,成功推广奖励', - icon: 'ele-School', - bg: '#8595F4', - iconColor: '#92A1F4', - }, - { - title: '秒杀', - msg: '超低价抢购引导更多销量', - icon: 'ele-AlarmClock', - bg: '#FEBB50', - iconColor: '#FDC566', - }, -]; diff --git a/src/views/test/index.vue b/src/views/test/index.vue deleted file mode 100644 index 827727e..0000000 --- a/src/views/test/index.vue +++ /dev/null @@ -1,13 +0,0 @@ -<template> - -</template> - -<script> - export default { - name: "index" - } -</script> - -<style scoped> - -</style> diff --git a/src/views/visualizing/demo1.vue b/src/views/visualizing/demo1.vue deleted file mode 100644 index cfc6166..0000000 --- a/src/views/visualizing/demo1.vue +++ /dev/null @@ -1,1278 +0,0 @@ -<template> - <div class="visualizing-demo1"> - <!-- 地图 --> - <div ref="visualizingDemo1" style="height: 100%"></div> - <div class="visualizing-container"> - <!-- 头部 --> - <div class="visualizing-container-head"> - <div class="visualizing-container-head-left"> - <div class="visualizing-container-head-left-text"> - <div class="visualizing-container-head-left-text-box">{{ time.txt }}</div> - </div> - </div> - <div class="visualizing-container-head-center"> - <div class="visualizing-container-head-center-box"> - <div class="visualizing-container-head-center-maintitle">深圳市xxx软件科技有限公司</div> - <div class="visualizing-container-head-center-subtitle">旅游经济</div> - </div> - </div> - <div class="visualizing-container-head-right"> - <div class="visualizing-container-head-right-text"> - <div class="visualizing-container-head-right-text-box">🌤 多云转晴东南风 26~30℃</div> - </div> - </div> - </div> - - <!-- 图表左侧 --> - <div class="visualizing-container-content-left"> - <div class="visualizing-container-content-left-flex"> - <div class="visualizing-container-title"> - <i class="el-icon-s-shop"></i> - <span>产业概况</span> - </div> - <hr class="visualizing-container-title-colorful" /> - <div ref="visualizingContentLeftTop" style="height: 100%"></div> - </div> - <div class="visualizing-container-content-left-flex"> - <div class="visualizing-container-title"> - <i class="el-icon-s-promotion"></i> - <span>A级风景区对比</span> - </div> - <hr class="visualizing-container-title-colorful" /> - <div ref="visualizingContentLeftBottom" style="height: 100%"></div> - </div> - </div> - - <!-- 图表中间 --> - <div class="visualizing-container-content-center"> - <div class="visualizing-container-content-center-bottom"> - <div class="visualizing-container-content-center-bottom-flex"> - <div class="visualizing-container-title"> - <i class="el-icon-s-custom"></i> - <span>游客过夜情况</span> - </div> - <hr class="visualizing-container-title-colorful" /> - <div ref="visualizingContentCenterTop" style="height: 100%"></div> - </div> - <div class="visualizing-container-content-center-bottom-flex"> - <div class="visualizing-container-title"> - <i class="el-icon-s-flag"></i> - <span>游客驻留时长</span> - </div> - <hr class="visualizing-container-title-colorful" /> - <div ref="visualizingContentCenterBottom" style="height: 100%"></div> - </div> - </div> - </div> - - <!-- 图表右侧 --> - <div class="visualizing-container-content-right"> - <div class="visualizing-container-content-right-flex"> - <div class="visualizing-container-title"> - <i class="el-icon-s-marketing"></i> - <span>当日游客趋势分析</span> - </div> - <hr class="visualizing-container-title-colorful" /> - <div ref="visualizingContentRightTop" style="height: 100%"></div> - </div> - <div class="visualizing-container-content-right-flex"> - <div class="visualizing-container-title"> - <i class="el-icon-s-data"></i> - <span>当月游客趋势分析</span> - </div> - <hr class="visualizing-container-title-colorful" /> - <div ref="visualizingContentRightBottom" style="height: 100%"></div> - </div> - </div> - </div> - </div> -</template> - -<script lang="ts"> -import { toRefs, reactive, onMounted, onUnmounted, getCurrentInstance, defineComponent } from 'vue'; -import * as echarts from 'echarts'; -import 'echarts/extension/bmap/bmap'; -import { formatDate } from '/@/utils/formatTime'; -import { NextLoading } from '/@/utils/loading'; -import { echartsMapList, echartsMapData, echartsMapImgs } from './mock/demo1'; - -// 定义接口来定义对象的类型 -interface Demo1State { - visualizingDemo1: any; - echartsMapList: any; - echartsMapData: any; - echartsMapImgs: any; - time: any; - myCharts: any[]; -} - -export default defineComponent({ - name: 'visualizingLinkDemo1', - setup() { - const { proxy } = <any>getCurrentInstance(); - const state = reactive<Demo1State>({ - visualizingDemo1: null, - echartsMapList, - echartsMapData, - echartsMapImgs, - time: { - txt: '', - fun: 0, - }, - myCharts: [], - }); - // 初始化时间 - const initTime = () => { - state.time.txt = formatDate(new Date(), 'YYYY-mm-dd HH:MM:SS WWW QQQQ ZZZ'); - state.time.fun = window.setInterval(() => { - state.time.txt = formatDate(new Date(), 'YYYY-mm-dd HH:MM:SS WWW QQQQ ZZZ'); - }, 1000); - }; - // echartsMap 将坐标信息和对应物理量的值合在一起 - const convertData = (data: any) => { - let res = []; - for (let i = 0; i < data.length; i++) { - let geoCoord = state.echartsMapData[data[i].name]; - if (geoCoord) { - res.push({ - name: data[i].name, - value: geoCoord.concat(data[i].value), - }); - } - } - return res; - }; - // 初始化 echartsMap(地图上的点) - const initEchartsMap = () => { - const myChart = echarts.init(<HTMLElement>state.visualizingDemo1); - const option = { - tooltip: { - trigger: 'item', - formatter(params: any) { - // 自定义鼠标放入样式 - let item = state.echartsMapImgs.find((v: any) => v.name === params.name); - let html = `<div style="width: 240px"> - <div style="display: flex; align-items: center"> - <img src="${item?.url}" style="width: 50px; height: 50px; border-radius: 100%; position: relative; border: 4px solid #ffffff; margin-left: -4px" /> - <div - style=" - background: #51c1ff; - width: 100%; - height: 32px; - margin-left: -14px; - display: flex; - align-items: center; - padding-left: 20px; - color: #fff; - " - > - ${item?.name} - </div> - </div> - <div style="margin-top: 10px; font-size: 12px"> - <div style="width: 61px"><i class="el-icon-location-information" style="margin-right: 5px"></i>地址:</div> - <div style="flex: 1; white-space: pre-wrap; word-break: break-all; margin-top: 5px; color: #333">${item?.add}</div> - </div> - <div style="margin-top: 10px; font-size: 12px"> - <div style="width: 61px"><i class="el-icon-chat-dot-round" style="margin-right: 5px"></i>概括:</div> - <div style="flex: 1; white-space: pre-wrap; word-break: break-all; margin-top: 5px; color: #333">${item?.dec}</div> - </div> - </div>`; - return html; - }, - }, - color: ['#ea7ccc'], - bmap: { - center: [114.064524, 22.549225], - zoom: 11, - roam: true, - mapStyle: {}, - }, - series: [ - { - name: '门票收入', - type: 'scatter', - coordinateSystem: 'bmap', - data: convertData(state.echartsMapList), - symbolSize: function (val: any) { - return val[2] / 10; - }, - encode: { - value: 2, - }, - label: { - formatter: '{b}', - position: 'right', - show: false, - }, - emphasis: { - label: { - show: true, - }, - }, - }, - { - name: '门票收入', - type: 'effectScatter', - coordinateSystem: 'bmap', - data: convertData( - state.echartsMapList - .sort(function (a: any, b: any) { - return b.value - a.value; - }) - .slice(0, 6) - ), - symbolSize: function (val: any) { - return val[2] / 10; - }, - encode: { - value: 2, - }, - showEffectOn: 'render', - rippleEffect: { - brushType: 'stroke', - }, - hoverAnimation: true, - label: { - formatter: '{b}', - position: 'right', - show: true, - }, - itemStyle: { - shadowBlur: 100, - shadowColor: '#333', - }, - zlevel: 1, - }, - ], - }; - myChart.setOption(option); - state.myCharts.push(myChart); - - // 地图 - const map = (<any>myChart).getModel().getComponent('bmap').getBMap(); - // BMAP_NORMAL_MAP :此地图类型展示普通街道视图 - // BMAP_PERSPECTIVE_MAP :此地图类型展示透视图像视图。(这个还不会用) - // BMAP_SATELLITE_MAP:卫星地图 (没有坐标, 绿绿的一片的卫星地图) - // BMAP_HYBRID_MAP:混合地图 (既有坐标,也是绿绿的一片的卫星地图) - // eslint-disable-next-line no-undef - map.setMapType(BMAP_SATELLITE_MAP); - // eslint-disable-next-line no-undef - let bdary = new BMap.Boundary(); - // 获取行政区域 - bdary.get('深圳', function (rs: any) { - // 行政区域的点有多少个 - let count = rs.boundaries.length; - for (let i = 0; i < count; i++) { - // eslint-disable-next-line no-undef - let ply = new BMap.Polygon(rs.boundaries[i], { - // 设置多边形边线线粗 - strokeWeight: 4, - // 设置多边形边线透明度0-1 - strokeOpacity: 1, - // 设置多边形边线样式为实线或虚线,取值 solid 或 dashed - StrokeStyle: 'dashed', - // 设置多边形边线颜色 - strokeColor: '#febb50', - // 设置多边形填充颜色 - fillColor: '', - }); - // 建立多边形覆盖物 - // 添加覆盖物 - map.addOverlay(ply); - // 调整视野 - map.setViewport(ply.getPath()); - } - // 初始化地图,设置中心点坐标和地图级别 - // new BMap.Point('深圳市', 11) - // eslint-disable-next-line no-undef - map.centerAndZoom(new BMap.Point(114.064524, 22.549225), 11); - }); - }; - // 产业概况 - const initVisualizingContentLeftTop = () => { - const myChart = echarts.init(proxy.$refs.visualizingContentLeftTop); - const option = { - grid: { - top: 50, - right: 0, - bottom: 50, - left: 30, - }, - tooltip: { - trigger: 'axis', - }, - xAxis: { - data: ['1月', '2月', '3月', '4月', '5月', '6月'], - axisLine: { - lineStyle: { - color: 'rgba(22, 207, 208, 0.1)', - width: 1, - }, - }, - axisTick: { - show: false, - }, - axisLabel: { - color: '#16cfd0', - }, - }, - yAxis: [ - { - type: 'value', - name: '价格', - axisLine: { - show: true, - lineStyle: { - color: 'rgba(22, 207, 208, 0.1)', - }, - }, - axisLabel: { - color: '#16cfd0', - }, - splitLine: { - show: true, - lineStyle: { - color: 'rgba(22, 207, 208, 0.3)', - }, - }, - splitArea: { - show: true, - areaStyle: { - color: 'rgba(22, 207, 208, 0.02)', - }, - }, - nameTextStyle: { - color: '#16cfd0', - }, - }, - ], - series: [ - { - name: '预购队列', - type: 'line', - data: [200, 85, 112, 275, 305, 415], - itemStyle: { - color: '#16cfd0', - }, - }, - { - name: '最新成交价', - type: 'line', - data: [50, 85, 22, 155, 170, 25], - itemStyle: { - color: '#febb50', - }, - }, - ], - }; - myChart.setOption(option); - state.myCharts.push(myChart); - }; - // A级风景区对比 - const initVisualizingContentLeftBottom = () => { - const myChart = echarts.init(proxy.$refs.visualizingContentLeftBottom); - const option = { - grid: { - top: 50, - right: 10, - bottom: 40, - left: 30, - }, - tooltip: { - trigger: 'axis', - }, - xAxis: { - type: 'category', - boundaryGap: false, - data: ['1月', '2月', '3月', '4月', '5月'], - axisLine: { - lineStyle: { - color: 'rgba(22, 207, 208, 0.1)', - width: 1, - }, - }, - axisTick: { - show: false, - }, - axisLabel: { - interval: 0, - color: '#16cfd0', - textStyle: { - fontSize: 10, - }, - }, - }, - yAxis: [ - { - type: 'value', - name: '销量', - axisLabel: { - color: '#16cfd0', - }, - splitLine: { - show: true, - lineStyle: { - color: 'rgba(22, 207, 208, 0.3)', - }, - }, - splitArea: { - show: true, - areaStyle: { - color: 'rgba(22, 207, 208, 0.02)', - }, - }, - nameTextStyle: { - color: '#16cfd0', - }, - }, - ], - series: [ - { - name: '客流', - type: 'line', - stack: '总量', - smooth: true, - lineStyle: { - width: 0, - }, - areaStyle: { - opacity: 0.8, - color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [ - { - offset: 0, - color: 'rgba(128, 255, 165)', - }, - { - offset: 1, - color: 'rgba(1, 191, 236)', - }, - ]), - }, - emphasis: { - focus: 'series', - }, - data: [140, 232, 101, 264, 90], - }, - { - name: '天数', - type: 'line', - stack: '总量', - smooth: true, - lineStyle: { - width: 0, - }, - areaStyle: { - opacity: 0.8, - color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [ - { - offset: 0, - color: 'rgba(0, 221, 255)', - }, - { - offset: 1, - color: 'rgba(77, 119, 255)', - }, - ]), - }, - emphasis: { - focus: 'series', - }, - data: [120, 282, 111, 234, 220], - }, - ], - }; - myChart.setOption(option); - state.myCharts.push(myChart); - }; - // 游客过夜情况 - const initVisualizingContentCenterTop = () => { - const myChart = echarts.init(proxy.$refs.visualizingContentCenterTop); - const min = 100; - const max = 1000; - const option = { - grid: { - top: 50, - right: 10, - bottom: 66, - left: 38, - }, - tooltip: { - trigger: 'axis', - axisPointer: { - type: 'shadow', - }, - }, - xAxis: [ - { - type: 'category', - data: ['地区', '地区', '地区', '地区', '地区', '地区', '地区', '地区', '地区', '地区'], - axisLabel: { - color: '#16cfd0', - textStyle: { - fontSize: 9, - }, - interval: 0, - rotate: -45, - }, - axisLine: { - lineStyle: { - color: 'rgba(22, 207, 208, 0.1)', - width: 1, - }, - }, - axisTick: { - show: false, - }, - }, - ], - yAxis: [ - { - type: 'value', - name: '天数', - nameGap: 25, - axisLine: { - show: true, - lineStyle: { - color: 'rgba(22, 207, 208, 0.1)', - }, - }, - axisLabel: { - color: '#16cfd0', - }, - splitLine: { - show: true, - lineStyle: { - color: 'rgba(22, 207, 208, 0.3)', - }, - }, - splitArea: { - show: true, - areaStyle: { - color: 'rgba(22, 207, 208, 0.02)', - }, - }, - nameTextStyle: { - color: '#16cfd0', - }, - }, - ], - series: [ - { - type: 'bar', - barWidth: 15, - itemStyle: { - normal: { - color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [ - { - offset: 0, - color: '#de682e', - }, - { - offset: 1, - color: '#ecc232', - }, - ]), - }, - }, - label: { - normal: { - show: true, - position: 'top', - formatter: function (param: any) { - if (param.value == max || param.value == min) { - return ''; - } - return param.value; - }, - textStyle: { - color: 'rgba(22, 207, 208, 0.8)', - fontSize: 10, - }, - }, - }, - markPoint: { - symbolSize: 30, - label: { - normal: { - textStyle: { - color: '#ffffff', - fontSize: 10, - }, - }, - }, - data: [ - { name: '年最低', value: min, xAxis: 0, yAxis: 100 }, - { name: '年最高', value: max, xAxis: 9, yAxis: 1000 }, - ], - }, - data: [100, 200, 300, 400, 500, 600, 700, 800, 900, 1000], - }, - ], - }; - myChart.setOption(option); - state.myCharts.push(myChart); - }; - // 游客驻留时长 - const initVisualizingContentCenterBottom = () => { - const myChart = echarts.init(proxy.$refs.visualizingContentCenterBottom); - const option = { - tooltip: { - trigger: 'axis', - axisPointer: { - type: 'shadow', - }, - }, - grid: { - top: 26, - right: 10, - bottom: 66, - left: 45, - }, - xAxis: { - type: 'value', - axisLabel: { - color: '#16cfd0', - }, - splitLine: { - show: true, - lineStyle: { - color: 'rgba(22, 207, 208, 0.3)', - }, - }, - }, - yAxis: { - type: 'category', - axisLabel: { - color: '#16cfd0', - }, - }, - series: [ - { - name: '已完成', - type: 'bar', - stack: 'total', - label: { - show: true, - }, - emphasis: { - focus: 'series', - }, - barWidth: 12, - itemStyle: { - label: { - show: true, - }, - labelLine: { - show: false, - }, - color: new echarts.graphic.LinearGradient(0, 0, 1, 0, [ - { offset: 0, color: 'rgba(7,165,255,0.2)' }, - { offset: 1, color: 'rgba(7,165,255,1)' }, - ]), - }, - }, - { - name: '进行中', - type: 'bar', - stack: 'total', - label: { - show: true, - }, - emphasis: { - focus: 'series', - }, - barWidth: 12, - itemStyle: { - label: { - show: true, - }, - labelLine: { - show: false, - }, - color: new echarts.graphic.LinearGradient(0, 0, 1, 0, [ - { offset: 0, color: 'rgba(41,244,236,0)' }, - { offset: 1, color: 'rgba(41,244,236,1)' }, - ]), - }, - }, - ], - dataset: { - source: [ - { status: '已签收', value1: 33, value2: 93 }, - { status: '配送中', value1: 53, value2: 32 }, - { status: '已出库', value1: 78, value2: 65 }, - { status: '采购中', value1: 12, value2: 35 }, - { status: '接单中', value1: 90, value2: 52 }, - ], - }, - }; - myChart.setOption(option); - state.myCharts.push(myChart); - }; - // 当日游客趋势分析 - const initVisualizingContentRightTop = () => { - const myChart = echarts.init(proxy.$refs.visualizingContentRightTop); - const option = { - grid: { - top: 50, - right: 30, - bottom: 50, - left: 20, - }, - tooltip: { - trigger: 'axis', - axisPointer: { - type: 'shadow', - }, - }, - xAxis: { - data: ['1月', '2月', '3月', '4月', '5月', '6月'], - axisLine: { - lineStyle: { - color: 'rgba(22, 207, 208, 0.5)', - width: 1, - }, - }, - axisTick: { - show: false, - }, - axisLabel: { - color: '#16cfd0', - }, - }, - yAxis: [ - { - type: 'value', - name: '亿元', - axisLine: { - show: true, - lineStyle: { - color: 'rgba(22, 207, 208, 0.1)', - }, - }, - axisLabel: { - color: '#16cfd0', - }, - splitLine: { - show: true, - lineStyle: { - color: 'rgba(22, 207, 208, 0.3)', - }, - }, - splitArea: { - show: true, - areaStyle: { - color: 'rgba(22, 207, 208, 0.02)', - }, - }, - nameTextStyle: { - color: '#16cfd0', - }, - }, - { - type: 'value', - name: '同比', - position: 'right', - axisLine: { - show: false, - }, - axisLabel: { - show: true, - formatter: '{value}%', - textStyle: { - color: '#16cfd0', - }, - }, - splitLine: { - show: false, - }, - axisTick: { - show: false, - }, - splitArea: { - show: true, - areaStyle: { - color: 'rgba(22, 207, 208, 0.02)', - }, - }, - nameTextStyle: { - color: '#16cfd0', - }, - }, - ], - series: [ - { - name: '销售水量', - type: 'line', - yAxisIndex: 1, - smooth: true, - showAllSymbol: true, - symbol: 'circle', - itemStyle: { - color: '#058cff', - }, - lineStyle: { - color: '#058cff', - }, - areaStyle: { - color: 'rgba(5,140,255, 0.2)', - }, - data: [4.2, 3.8, 4.8, 3.5, 2.9, 2.8], - }, - { - name: '主营业务', - type: 'bar', - barWidth: 15, - itemStyle: { - normal: { - color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [ - { - offset: 0, - color: '#00FFE3', - }, - { - offset: 1, - color: '#4693EC', - }, - ]), - }, - }, - data: [4.2, 3.8, 4.8, 3.5, 2.9, 2.8], - }, - ], - }; - myChart.setOption(option); - state.myCharts.push(myChart); - }; - // 当月游客趋势分析 - const initVisualizingContentRightBottom = () => { - const myChart = echarts.init(proxy.$refs.visualizingContentRightBottom); - const option = { - grid: { - top: 50, - right: 10, - bottom: 40, - left: 30, - }, - tooltip: { - trigger: 'axis', - }, - xAxis: { - data: ['1月', '2月', '3月', '4月', '5月', '6月'], - axisLine: { - lineStyle: { - color: 'rgba(22, 207, 208, 0.1)', - width: 1, - }, - }, - axisTick: { - show: false, - }, - axisLabel: { - color: '#16cfd0', - }, - }, - yAxis: [ - { - type: 'value', - name: '人数(万)', - axisLine: { - show: true, - lineStyle: { - color: 'rgba(22, 207, 208, 0.1)', - }, - }, - axisLabel: { - color: '#16cfd0', - }, - splitLine: { - show: true, - lineStyle: { - color: 'rgba(22, 207, 208, 0.3)', - }, - }, - splitArea: { - show: true, - areaStyle: { - color: 'rgba(22, 207, 208, 0.02)', - }, - }, - nameTextStyle: { - color: '#16cfd0', - }, - }, - ], - series: [ - { - name: '预购队列', - type: 'line', - data: [20, 15, 40, 55, 65, 85], - smooth: true, - itemStyle: { - color: '#EA7CCC', - }, - }, - { - name: '最新成交价', - type: 'line', - data: [30, 45, 65, 85, 60, 105], - smooth: true, - itemStyle: { - color: '#FAC958', - }, - }, - ], - }; - myChart.setOption(option); - state.myCharts.push(myChart); - }; - // 批量设置 echarts resize - const initEchartsResize = () => { - window.addEventListener('resize', () => { - for (let i = 0; i < state.myCharts.length; i++) { - state.myCharts[i].resize(); - } - }); - }; - // 页面加载时 - onMounted(async () => { - NextLoading.done(); - initTime(); - await initEchartsMap(); - await initVisualizingContentLeftTop(); - await initVisualizingContentLeftBottom(); - await initVisualizingContentCenterTop(); - await initVisualizingContentCenterBottom(); - await initVisualizingContentRightTop(); - await initVisualizingContentRightBottom(); - await initEchartsResize(); - }); - // 页面卸载时 - onUnmounted(() => { - window.clearInterval(state.time.fun); - }); - return { - ...toRefs(state), - }; - }, -}); -</script> - -<style scoped lang="scss"> -// 左右两侧图表宽度 -$lrWidth: 288px; -// 中部图表高度 -$cheight: 240px; -// 标题宽度 -$titleWidth: 240px; -.visualizing-demo1 { - height: 100%; - width: 100%; - position: relative; - ::v-deep(.BMap_cpyCtrl) { - display: none; - } - ::v-deep(.anchorBL) { - display: none; - } - .visualizing-container { - .visualizing-container-head { - height: 60px; - width: 100%; - position: absolute; - top: 0; - left: 0; - display: flex; - align-items: center; - color: #ffffff; - background: linear-gradient(to bottom, rgba(0, 0, 0, 0.9), rgba(0, 0, 0, 0.3), rgba(0, 0, 0, 0.02)); - z-index: 3; - .visualizing-container-head-left { - flex: 1; - position: relative; - height: 60px; - .visualizing-container-head-left-text { - position: relative; - z-index: 1; - font-size: 12px; - opacity: 0.6; - width: 93%; - padding-left: 15px; - top: 50%; - transform: translateY(-100%); - .visualizing-container-head-left-text-box { - width: 100%; - position: relative; - padding-left: 15px; - &::after { - content: ''; - height: 20px; - width: 100%; - position: absolute; - background: linear-gradient(to right, rgba(22, 207, 208, 0.1), rgba(22, 207, 208, 0.3)); - top: -1px; - left: 0; - transform: skew(30deg); - } - } - } - &::before, - &::after { - content: ''; - height: 3px; - background: linear-gradient(-90deg, #16cfd0, transparent); - position: absolute; - width: 100%; - } - &::before { - top: 1px; - right: 33px; - opacity: 0.8; - } - &::after { - top: 41px; - right: -2px; - } - } - .visualizing-container-head-center { - height: 60px; - font-size: 18px; - text-align: center; - display: flex; - flex-direction: column; - position: relative; - padding: 0 60px; - background: radial-gradient(rgba(0, 0, 0, 0.7) 5%, rgba(0, 0, 0, 0.5) 15%, rgba(0, 0, 0, 0.02) 70%); - .visualizing-container-head-center-box { - margin: auto; - position: relative; - z-index: 1; - .visualizing-container-head-center-maintitle { - position: relative; - &::before, - &::after { - content: ''; - position: absolute; - min-width: 21%; - height: 29px; - top: 2px; - opacity: 0.3; - border-top: 1px solid #16cfd0; - } - &::before { - left: -70px; - border-right: 2px solid #16cfd0; - transform: skew(50deg); - } - &::after { - right: -70px; - border-left: 2px solid #16cfd0; - transform: skew(-50deg); - } - } - .visualizing-container-head-center-subtitle { - font-size: 14px; - opacity: 0.8; - position: relative; - &::before, - &::after { - content: ''; - position: absolute; - min-width: 35%; - height: 23px; - bottom: 8px; - border-bottom: 2px solid #16cfd0; - } - &::before { - transform: skew(50deg); - left: -33px; - border-left: 3px solid #16cfd0; - border-image: linear-gradient(to right, #16cfd0, rgba(22, 207, 208, 0.02)) 1 10; - } - &::after { - transform: skew(-50deg); - right: -33px; - border-right: 3px solid #16cfd0; - border-image: linear-gradient(to left, rgba(22, 207, 208, 1), rgba(22, 207, 208, 0.02)) 1 10; - } - } - &::before, - &::after { - content: ''; - position: absolute; - width: 36px; - height: 17px; - top: -8px; - border-bottom: 2px solid rgba(22, 207, 208, 0.7); - } - &::before { - transform: skew(32deg); - left: -89px; - border-left: 3px solid rgba(22, 207, 208, 0.7); - } - &::after { - transform: skew(-32deg); - right: -89px; - border-right: 3px solid rgba(22, 207, 208, 0.7); - } - } - &::before, - &::after { - content: ''; - position: absolute; - min-width: 50%; - height: 15px; - bottom: 0px; - border-bottom: 4px solid #16cfd0; - } - &::before { - transform: skew(60deg); - left: 13px; - border-left: 5px solid #16cfd0; - } - &::after { - transform: skew(-60deg); - right: 13px; - border-right: 5px solid #16cfd0; - } - } - .visualizing-container-head-right { - flex: 1; - position: relative; - height: 60px; - .visualizing-container-head-right-text { - position: relative; - z-index: 1; - font-size: 12px; - opacity: 0.6; - width: 93%; - float: right; - text-align: right; - padding-right: 15px; - top: 50%; - transform: translateY(-100%); - .visualizing-container-head-right-text-box { - width: 100%; - position: relative; - padding-right: 15px; - &::after { - content: ''; - height: 20px; - width: 100%; - position: absolute; - background: linear-gradient(to left, rgba(22, 207, 208, 0.1), rgba(22, 207, 208, 0.3)); - top: -1px; - right: 0; - transform: skew(-30deg); - } - } - } - &::before, - &::after { - content: ''; - height: 3px; - background: linear-gradient(90deg, #16cfd0, transparent); - position: absolute; - width: 100%; - } - &::before { - top: 1px; - left: 33px; - opacity: 0.8; - } - &::after { - top: 41px; - left: -2px; - } - } - } - .visualizing-container-title { - max-width: $titleWidth; - font-size: 14px; - color: #ffffff; - opacity: 0.8; - padding: 0 5px; - border-bottom: 1px solid #ffffff; - border-image: linear-gradient(to right, #ffffff, rgba(22, 207, 208, 0.02)) 1 10; - position: relative; - i { - padding-right: 5px; - color: orange; - } - &::after { - content: ''; - position: absolute; - left: 0; - bottom: 0; - width: 1px; - height: 10px; - background: linear-gradient(to top, #ffffff, rgba(255, 255, 255, 0.5)); - } - } - .visualizing-container-title-colorful { - max-width: $titleWidth; - border: 0; - padding: 1px; - background: linear-gradient(135deg, red, orange, green, #16cfd0, purple); - --mask-image: repeating-linear-gradient(135deg, #000 0px, #000 1px, transparent 1px, transparent 4px); - -webkit-mask-image: var(--mask-image); - mask-image: var(--mask-image); - } - .visualizing-container-content-left { - width: $lrWidth; - height: 100%; - position: absolute; - top: 0; - left: 0; - background: linear-gradient(to right, rgba(0, 0, 0, 0.9), rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0.01)); - padding-top: 60px; - z-index: 2; - .visualizing-container-content-left-flex { - height: 50%; - display: flex; - flex-direction: column; - padding-left: 15px; - } - } - .visualizing-container-content-center { - width: 100%; - height: $cheight; - position: absolute; - bottom: 0; - left: 0; - background: linear-gradient(to top, rgba(0, 0, 0, 0.9), rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0.01)); - z-index: 1; - .visualizing-container-content-center-bottom { - width: calc(100% - #{$lrWidth * 2}); - height: $cheight; - left: $lrWidth; - bottom: 0; - position: absolute; - display: flex; - padding: 0 15px; - .visualizing-container-content-center-bottom-flex { - width: 50%; - padding: 0 15px; - } - } - } - .visualizing-container-content-right { - width: $lrWidth; - height: 100%; - position: absolute; - top: 0; - right: 0; - padding-top: 60px; - background: linear-gradient(to left, rgba(0, 0, 0, 0.9), rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0.01)); - z-index: 2; - .visualizing-container-content-right-flex { - height: 50%; - display: flex; - flex-direction: column; - padding-right: 15px; - } - } - } -} -</style> diff --git a/src/views/visualizing/demo2.vue b/src/views/visualizing/demo2.vue deleted file mode 100644 index 2e973fc..0000000 --- a/src/views/visualizing/demo2.vue +++ /dev/null @@ -1,1344 +0,0 @@ -<template> - <div class="visualizing-demo2"> - <!-- 顶部 --> - <div class="big-data-up"> - <div class="up-left"> - <SvgIcon name="ele-Timer" class="mr5" /> - <span>{{ time.txt }}</span> - </div> - <div class="up-center"> - <span>智慧农业系统平台</span> - </div> - <div class="up-right"> - <el-dropdown size="small"> - <span class="el-dropdown-link"> - {{ dropdownActive }} - <SvgIcon name="ele-ArrowDown" class="el-icon--right" /> - </span> - <template #dropdown> - <el-dropdown-menu> - <el-dropdown-item v-for="(v, k) in dropdownList" :key="k">{{ v.label }} </el-dropdown-item> - </el-dropdown-menu> - </template> - </el-dropdown> - <div class="ml15"> - <SvgIcon name="ele-Bell" class="mr5" /> - <span>消息</span> - </div> - <div class="ml15"> - <SvgIcon name="ele-User" class="mr5" /> - <span>个人</span> - </div> - <div class="ml15"> - <SvgIcon name="ele-SwitchButton" class="mr5" /> - <span>返回</span> - </div> - </div> - </div> - - <div class="big-data-down"> - <!-- 左边 --> - <div class="big-data-down-left"> - <div class="flex-warp-item"> - <div class="flex-warp-item-box"> - <div class="flex-title">天气预报</div> - <div class="flex-content flex-content-overflow"> - <div class="sky"> - <SvgIcon name="ele-Sunny" class="sky-left" /> - <div class="sky-center"> - <div class="mb2"> - <span class="font">多云转晴</span> - <span class="font">东南风</span> - <span>良</span> - </div> - <div class="sky-tip">温馨提示:多云转晴,南风转北风风力3级</div> - </div> - <div class="sky-right"> - <span>25</span> - <span class="font">°C</span> - </div> - </div> - <div class="sky-dd"> - <div class="sky-dl" v-for="(v, k) in skyList" :key="k" :class="{ 'sky-dl-first': k === 1 }"> - <div>{{ v.v1 }}</div> - <div v-if="v.type === 'title'">{{ v.v2 }}</div> - <div v-else> - <SvgIcon :name="v.v2" /> - </div> - <div>{{ v.v3 }}</div> - <div>{{ v.v4 }}</div> - <div class="tip">{{ v.v5 }}</div> - <div>{{ v.v6 }}</div> - <div>{{ v.v7 }}</div> - </div> - </div> - </div> - </div> - </div> - <div class="flex-warp-item"> - <div class="flex-warp-item-box"> - <div class="flex-title">当前设备状态</div> - <div class="flex-content flex-content-overflow"> - <div class="d-states"> - <div class="d-states-item"> - <SvgIcon name="ele-Odometer" class="i-bg1" /> - <div class="d-states-flex"> - <div class="d-states-item-label">园区设备数</div> - <div class="d-states-item-value">99</div> - </div> - </div> - <div class="d-states-item"> - <SvgIcon name="ele-FirstAidKit" class="i-bg2" /> - <div class="d-states-flex"> - <div class="d-states-item-label">预警设备数</div> - <div class="d-states-item-value">10</div> - </div> - </div> - <div class="d-states-item"> - <SvgIcon name="ele-VideoPlay" class="i-bg3" /> - <div class="d-states-flex"> - <div class="d-states-item-label">运行设备数</div> - <div class="d-states-item-value">20</div> - </div> - </div> - </div> - <div class="d-btn"> - <div class="d-btn-item" v-for="(v, k) in dBtnList" :key="k" :class="{ 'd-btn-active': dBtnActive === k }"> - <SvgIcon name="ele-Money" class="d-btn-item-left" /> - <div class="d-btn-item-center"> - <div>{{ v.v1 }}</div> - <div>{{ v.v2 }}|{{ v.v3 }}</div> - </div> - <div class="d-btn-item-eight">{{ v.v4 }}</div> - </div> - </div> - </div> - </div> - </div> - <div class="flex-warp-item"> - <div class="flex-warp-item-box"> - <div class="flex-title">近30天预警总数</div> - <div class="flex-content" ref="rightChartData1"></div> - </div> - </div> - </div> - - <!-- 中间 --> - <div class="big-data-down-center"> - <div class="big-data-down-center-one"> - <div class="big-data-down-center-one-content" ref="rightChartData5"> - <div ref="the3DEarth"></div> - <div :class="v.topLevelClass" v-for="(v, k) in earth3DBtnList" :key="k"> - <div class="circle" v-for="i in 4" :key="i"></div> - <div class="text-box"> - <SvgIcon :name="v.icon" /> - <div class="text">{{ v.label }}</div> - </div> - </div> - </div> - </div> - <div class="big-data-down-center-two"> - <div class="flex-warp-item-box"> - <div class="flex-title"> - <span>当前设备监测</span> - <span class="flex-title-small">单位:次</span> - </div> - <div class="flex-content"> - <div class="flex-content-left"> - <div class="monitor-item" v-for="(v, k) in chartData4List" :key="k"> - <div class="monitor-wave" :class="{ 'monitor-active': k === chartData4Index }"> - <div class="monitor-z-index"> - <div class="monitor-item-label">{{ v.label }}</div> - </div> - </div> - </div> - </div> - <div class="flex-content-right" ref="rightChartData4"></div> - </div> - </div> - </div> - </div> - - <!-- 右边 --> - <div class="big-data-down-right"> - <div class="flex-warp-item"> - <div class="flex-warp-item-box"> - <div class="flex-title"> - <span>近7天产品追溯扫码统计</span> - <span class="flex-title-small">单位:次</span> - </div> - <div class="flex-content" ref="rightChartData3"></div> - </div> - </div> - <div class="flex-warp-item"> - <div class="flex-warp-item-box"> - <div class="flex-title">当前任务统计</div> - <div class="flex-content"> - <div class="task"> - <div class="task-item task-first-item"> - <div class="task-item-value task-first">25</div> - <div class="task-item-label">待办任务</div> - </div> - <div class="task-item"> - <div class="task-item-box task1"> - <div class="task-item-value">12</div> - <div class="task-item-label">施肥</div> - </div> - </div> - <div class="task-item"> - <div class="task-item-box task2"> - <div class="task-item-value">3</div> - <div class="task-item-label">施药</div> - </div> - </div> - <div class="task-item"> - <div class="task-item-box task3"> - <div class="task-item-value">5</div> - <div class="task-item-label">农事</div> - </div> - </div> - <div class="task-item"> - <div class="task-item-box task4"> - <div class="task-item-value">3</div> - <div class="task-item-label">巡园</div> - </div> - </div> - <div class="task-item"> - <div class="task-item-box task5"> - <div class="task-item-value">2</div> - <div class="task-item-label">采集</div> - </div> - </div> - </div> - <div ref="rightChartData6" class="progress"></div> - </div> - </div> - </div> - <div class="flex-warp-item"> - <div class="flex-warp-item-box"> - <div class="flex-title"> - <span>近7天投入品记录</span> - <span class="flex-title-small">单位:件</span> - </div> - <div class="flex-content" ref="rightChartData2"></div> - </div> - </div> - </div> - </div> - </div> -</template> - -<script lang="ts"> -import { toRefs, reactive, onMounted, onUnmounted, getCurrentInstance, defineComponent } from 'vue'; -import * as echarts from 'echarts'; -import 'echarts-gl'; -import { formatDate } from '/@/utils/formatTime'; -import { NextLoading } from '/@/utils/loading'; -import { dropdownList, skyList, dBtnList, earth3DBtnList, chartData4List } from './mock/demo2'; -import worldImg from './images/world.jpg'; -import bathymetryImg from './images/bathymetry.jpg'; - -export default defineComponent({ - name: 'visualizingLinkDemo2', - setup() { - const { proxy } = getCurrentInstance() as any; - const state = reactive({ - time: { - txt: '', - fun: 0, - }, - dropdownList, - dropdownActive: '请选择', - skyList, - dBtnList, - chartData4Index: 0, - dBtnActive: 0, - earth3DBtnList, - chartData4List, - myCharts: [], - the3DEarth: null as HTMLDivElement | null, - }); - // 初始化时间 - const initTime = () => { - state.time.txt = formatDate(new Date(), 'YYYY-mm-dd HH:MM:SS WWW QQQQ ZZZ'); - state.time.fun = window.setInterval(() => { - state.time.txt = formatDate(new Date(), 'YYYY-mm-dd HH:MM:SS WWW QQQQ ZZZ'); - }, 1000); - }; - // 近30天预警总数 - const initRightChartData1 = () => { - const myChart = echarts.init(proxy.$refs.rightChartData1); - const option = { - tooltip: { - trigger: 'item', - }, - series: [ - { - name: '面积模式', - type: 'pie', - radius: [10, 60], - center: ['50%', '50%'], - roseType: 'area', - itemStyle: { - borderRadius: 5, - }, - data: [ - { name: '天气预警', value: 100 }, - { name: '病虫害预警', value: 50 }, - { name: '任务预警', value: 130 }, - { name: '监测设备预警', value: 62 }, - ], - label: { - color: '#c0d1f2', - }, - }, - ], - }; - myChart.setOption(option); - state.myCharts.push(myChart); - }; - // 当前设备监测 - const initRightChartData4 = () => { - const myChart = echarts.init(proxy.$refs.rightChartData4); - const option = { - grid: { - top: 10, - right: 10, - bottom: 20, - left: 30, - }, - tooltip: { - trigger: 'axis', - }, - xAxis: { - type: 'category', - boundaryGap: false, - data: ['1月', '2月', '3月', '4月', '5月', '6月'], - axisLine: { - lineStyle: { - color: 'rgba(22, 207, 208, 0.1)', - width: 1, - }, - }, - axisTick: { - show: false, - }, - axisLabel: { - interval: 0, - color: '#c0d1f2', - textStyle: { - fontSize: 10, - }, - }, - }, - yAxis: [ - { - type: 'value', - axisLabel: { - color: '#c0d1f2', - }, - splitLine: { - show: true, - lineStyle: { - color: 'rgba(22, 207, 208, 0.3)', - }, - }, - splitArea: { - show: true, - areaStyle: { - color: 'rgba(22, 207, 208, 0.02)', - }, - }, - nameTextStyle: { - color: '#16cfd0', - }, - }, - ], - series: [ - { - name: '温度', - type: 'line', - smooth: true, - lineStyle: { - width: 0, - }, - areaStyle: { - opacity: 0.8, - color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [ - { - offset: 0, - color: 'rgba(128, 255, 165)', - }, - { - offset: 1, - color: 'rgba(1, 191, 236)', - }, - ]), - }, - emphasis: { - focus: 'series', - }, - data: [140, 232, 101, 264, 90, 70], - }, - ], - }; - myChart.setOption(option); - state.myCharts.push(myChart); - }; - // 近7天产品追溯扫码统计 - const initRightChartData3 = () => { - const myChart = echarts.init(proxy.$refs.rightChartData3); - const option = { - grid: { - top: 10, - right: 0, - bottom: 20, - left: 30, - }, - tooltip: { - trigger: 'axis', - }, - xAxis: { - data: ['1月', '2月', '3月', '4月', '5月', '6月'], - axisLine: { - lineStyle: { - color: 'rgba(22, 207, 208, 0.1)', - width: 1, - }, - }, - axisTick: { - show: false, - }, - axisLabel: { - color: '#c0d1f2', - }, - }, - yAxis: [ - { - type: 'value', - axisLine: { - show: true, - lineStyle: { - color: 'rgba(22, 207, 208, 0.1)', - }, - }, - axisLabel: { - color: '#c0d1f2', - }, - splitLine: { - show: true, - lineStyle: { - color: 'rgba(22, 207, 208, 0.3)', - }, - }, - splitArea: { - show: true, - areaStyle: { - color: 'rgba(22, 207, 208, 0.02)', - }, - }, - nameTextStyle: { - color: '#16cfd0', - }, - }, - ], - series: [ - { - name: '预购队列', - type: 'line', - data: [200, 85, 112, 275, 305, 415], - itemStyle: { - color: '#16cfd0', - }, - }, - { - name: '最新成交价', - type: 'line', - data: [50, 85, 22, 155, 170, 25], - itemStyle: { - color: '#febb50', - }, - }, - ], - }; - myChart.setOption(option); - state.myCharts.push(myChart); - }; - // 当前任务统计 - const initRightChartData6 = () => { - const myChart = echarts.init(proxy.$refs.rightChartData6); - const option = { - tooltip: { - trigger: 'axis', - axisPointer: { - type: 'shadow', - }, - }, - grid: { - top: 20, - right: 50, - bottom: 0, - left: 80, - }, - xAxis: [ - { - splitLine: { - show: false, - }, - type: 'value', - show: false, - }, - ], - yAxis: [ - { - splitLine: { - show: false, - }, - axisLine: { - //y轴 - show: false, - }, - type: 'category', - axisTick: { - show: false, - }, - inverse: true, - data: ['施肥任务完成率', '施药任务完成率', '农事任务完成率'], - axisLabel: { - color: '#A7D6F4', - fontSize: 12, - }, - }, - ], - series: [ - { - name: '标准化', - type: 'bar', - barWidth: 10, // 柱子宽度 - label: { - show: true, - position: 'right', // 位置 - color: '#A7D6F4', - fontSize: 12, - distance: 15, // 距离 - formatter: '{c}%', // 这里是数据展示的时候显示的数据 - }, // 柱子上方的数值 - itemStyle: { - barBorderRadius: [0, 20, 20, 0], // 圆角(左上、右上、右下、左下) - - color: new echarts.graphic.LinearGradient( - 1, - 0, - 0, - 0, - [ - { - offset: 0, - color: '#51C5FD', - }, - { - offset: 1, - color: '#005BB1', - }, - ], - false - ), // 渐变 - }, - data: [75, 100, 60], - }, - ], - }; - myChart.setOption(option); - state.myCharts.push(myChart); - }; - // 近7天投入品记录 - const initRightChartData2 = () => { - const myChart = echarts.init(proxy.$refs.rightChartData2); - const option = { - grid: { - top: 10, - right: 0, - bottom: 20, - left: 30, - }, - tooltip: { - trigger: 'axis', - axisPointer: { - type: 'shadow', - }, - }, - xAxis: { - data: ['1月', '2月', '3月', '4月', '5月', '6月'], - axisLine: { - lineStyle: { - color: 'rgba(22, 207, 208, 0.5)', - width: 1, - }, - }, - axisTick: { - show: false, - }, - axisLabel: { - color: '#c0d1f2', - }, - }, - yAxis: [ - { - type: 'value', - axisLine: { - show: true, - lineStyle: { - color: 'rgba(22, 207, 208, 0.1)', - }, - }, - axisLabel: { - color: '#c0d1f2', - }, - splitLine: { - show: true, - lineStyle: { - color: 'rgba(22, 207, 208, 0.3)', - }, - }, - splitArea: { - show: true, - areaStyle: { - color: 'rgba(22, 207, 208, 0.02)', - }, - }, - nameTextStyle: { - color: '#16cfd0', - }, - }, - { - type: 'value', - position: 'right', - axisLine: { - show: false, - }, - axisLabel: { - show: true, - formatter: '{value}%', - textStyle: { - color: '#16cfd0', - }, - }, - splitLine: { - show: false, - }, - axisTick: { - show: false, - }, - splitArea: { - show: true, - areaStyle: { - color: 'rgba(22, 207, 208, 0.02)', - }, - }, - nameTextStyle: { - color: '#16cfd0', - }, - }, - ], - series: [ - { - name: '销售水量', - type: 'line', - yAxisIndex: 1, - smooth: true, - showAllSymbol: true, - symbol: 'circle', - itemStyle: { - color: '#058cff', - }, - lineStyle: { - color: '#058cff', - }, - areaStyle: { - color: 'rgba(5,140,255, 0.2)', - }, - data: [4.2, 3.8, 4.8, 3.5, 2.9, 2.8], - }, - { - name: '主营业务', - type: 'bar', - barWidth: 15, - itemStyle: { - normal: { - color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [ - { - offset: 0, - color: '#00FFE3', - }, - { - offset: 1, - color: '#4693EC', - }, - ]), - }, - }, - data: [4.2, 3.8, 4.8, 3.5, 2.9, 2.8], - }, - ], - }; - myChart.setOption(option); - state.myCharts.push(myChart); - }; - // 3DEarth 地图 - const init3DEarth = (globeRadius) => { - let el = state.the3DEarth!; - el.style.height = `${proxy.$refs.rightChartData5.offsetHeight}px`; - const myChart = echarts.init(el); - const option = { - globe: { - baseTexture: worldImg, - heightTexture: bathymetryImg, - shading: 'realistic', - light: { - ambient: { - intensity: 0.4, - }, - main: { - intensity: 0.4, - }, - }, - viewControl: { - autoRotate: true, - }, - postEffect: { - enable: true, - bloom: { - enable: true, - }, - }, - globeRadius, - }, - series: { - type: 'lines3D', - coordinateSystem: 'globe', - blendMode: 'lighter', - lineStyle: { - width: 1, - color: 'rgb(50, 50, 150)', - opacity: 0.1, - }, - data: [], - }, - }; - // 随机模拟攻击线 - let rodamData = function () { - let longitude = 105.18; - let longitude2 = Math.random() * 360 - 180; - let latitude = 37.51; - let latitude2 = Math.random() * 180 - 90; - return { - coords: [ - [longitude2, latitude2], - [longitude, latitude], - ], - value: (Math.random() * 3000).toFixed(2), - }; - }; - for (let i = 0; i < 150; i++) { - option.series.data = option.series.data.concat(rodamData()); - } - myChart.setOption(option); - }; - // 监听地球大小变化 - const initAddEventListener3DEarth = () => { - let w = document.body.clientWidth; - let globeRadius = 0; - if (w >= 1920) globeRadius = 100; - else if (w > 1200 && w < 1920) globeRadius = 70; - else if (w > 992 && w < 1200) globeRadius = 60; - else if (w > 768 && w < 992) globeRadius = 40; - else if (w < 768) globeRadius = 20; - init3DEarth(globeRadius); - }; - // 批量设置 echarts resize - const initEchartsResize = () => { - initAddEventListener3DEarth(); - window.addEventListener('resize', () => { - for (let i = 0; i < state.myCharts.length; i++) { - state.myCharts[i].resize(); - } - initAddEventListener3DEarth(); - }); - }; - // 页面加载时 - onMounted(async () => { - NextLoading.done(); - initTime(); - await initRightChartData1(); - await initRightChartData4(); - await initRightChartData3(); - await initRightChartData2(); - await initRightChartData6(); - await initEchartsResize(); - }); - // 页面卸载时 - onUnmounted(() => { - window.clearInterval(state.time.fun); - }); - return { - ...toRefs(state), - }; - }, -}); -</script> - -<style scoped lang="scss"> -.visualizing-demo2 { - height: 100%; - width: 100%; - overflow: hidden; - background: url(https://img-blog.csdnimg.cn/6267533849444025811bf0840f9366e3.png?x-oss-process=image/watermark,type_d3F5LXplbmhlaQ,shadow_50,text_Q1NETiBAbHl0LXRvcA==,size_20,color_FFFFFF,t_70,g_se,x_16); - background-size: 100% 100%; - display: flex; - flex-direction: column; - font-size: 13px; - .big-data-up { - height: 70px; - width: 100%; - display: flex; - align-items: center; - padding: 0 15px; - color: #43bdf0; - overflow: hidden; - .up-left { - width: 30%; - font-style: italic; - } - .up-center { - width: 40%; - display: flex; - justify-content: center; - font-size: 20px; - letter-spacing: 5px; - background-image: -webkit-linear-gradient(left, #43bdf0, #c0d1f2 25%, #43bdf0 50%, #c0d1f2 75%, #43bdf0); - -webkit-text-fill-color: transparent; - background-clip: text; - -webkit-background-clip: text; - background-size: 200% 100%; - animation: masked-animation 4s infinite linear; - -webkit-box-reflect: below -2px -webkit-gradient(linear, left top, left bottom, from(rgba(0, 0, 0, 0)), to(rgba(255, 255, 255, 0.1))); - @keyframes masked-animation { - 0% { - background-position: 0 0; - } - 100% { - background-position: -100% 0; - } - } - position: relative; - &::after { - content: ''; - width: 50%; - position: absolute; - bottom: -15px; - left: 50%; - transform: translateX(-50%); - border: 1px transparent solid; - border-image: linear-gradient(to right, rgba(0, 0, 0, 0.1), #43bdf0) 1 10; - } - span { - cursor: pointer; - } - } - .up-right { - width: 30%; - justify-content: flex-end; - display: flex; - align-items: center; - .ml15:hover { - cursor: pointer; - } - ::v-deep(.el-dropdown) { - font-size: 13px !important; - color: #43bdf0; - cursor: pointer; - } - } - } - .big-data-down { - flex: 1; - overflow: hidden; - display: flex; - .big-data-down-left, - .big-data-down-right { - width: 30%; - display: flex; - flex-direction: column; - .flex-warp-item { - padding: 0 7.5px 15px 15px; - width: 100%; - height: 33.33%; - .flex-warp-item-box { - width: 100%; - height: 100%; - background: rgba(22, 34, 58, 0.4); - display: flex; - flex-direction: column; - padding: 15px; - .flex-title { - margin-bottom: 15px; - color: #c0d1f2; - display: flex; - justify-content: space-between; - .flex-title-small { - font-size: 12px; - } - } - .flex-content { - flex: 1; - font-size: 12px; - } - .flex-content-overflow { - overflow: hidden; - } - } - } - } - .big-data-down-left { - color: #c0d1f2; - .sky { - display: flex; - align-items: center; - .sky-left { - font-size: 30px; - } - .sky-center { - flex: 1; - overflow: hidden; - padding: 0 10px; - .font { - margin-right: 15px; - background: unset !important; - border-radius: unset !important; - padding: unset !important; - } - span { - background: #22bc76; - border-radius: 2px; - padding: 0 5px; - } - .sky-tip { - overflow: hidden; - white-space: nowrap; - text-overflow: ellipsis; - } - } - .sky-right { - span { - font-size: 30px; - } - font { - font-size: 20px; - } - } - } - .sky-dd { - .sky-dl { - display: flex; - align-items: center; - height: 28px; - overflow: hidden; - div { - flex: 1; - overflow: hidden; - i { - font-size: 14px; - } - } - .tip { - overflow: hidden; - white-space: nowrap; - text-overflow: ellipsis; - } - &:hover { - background: rgba(0, 0, 0, 0.05); - cursor: default; - border-radius: 4px; - } - &:first-child:hover { - background: unset; - } - } - .sky-dl-first { - color: #43bdf0; - } - } - .d-states { - display: flex; - .d-states-item { - flex: 1; - display: flex; - align-items: center; - overflow: hidden; - i { - font-size: 20px; - height: 33px; - width: 33px; - line-height: 33px; - text-align: center; - border-radius: 100%; - flex-shrink: 1; - display: flex; - align-items: center; - justify-content: center; - } - .i-bg1 { - background: #22bc76; - } - .i-bg2 { - background: #e2356d; - } - .i-bg3 { - background: #43bbef; - } - .d-states-flex { - overflow: hidden; - padding: 0 10px 0; - .d-states-item-label { - color: #43bdf0; - overflow: hidden; - white-space: nowrap; - text-overflow: ellipsis; - } - .d-states-item-value { - font-size: 20px; - text-align: center; - } - } - } - } - .d-btn { - margin-top: 15px; - .d-btn-item { - border: 1px solid #c0d1f2; - display: flex; - width: 100%; - height: 35px; - border-radius: 35px; - align-items: center; - padding: 0 4px; - margin-top: 15px; - cursor: pointer; - transition: all ease 0.3s; - .d-btn-item-left { - font-size: 20px; - border: 1px solid #c0d1f2; - width: 25px; - height: 25px; - line-height: 25px; - border-radius: 100%; - text-align: center; - font-size: 14px; - } - .d-btn-item-center { - padding: 0 10px; - flex: 1; - } - .d-btn-item-eight { - text-align: right; - padding-right: 10px; - } - } - .d-btn-active { - transition: all ease 0.3s; - border: 1px solid #43bdf0; - color: #43bdf0; - .d-btn-item-left { - border: 1px solid #43bdf0; - } - } - } - } - .big-data-down-center { - width: 40%; - display: flex; - flex-direction: column; - .big-data-down-center-one { - height: 66.67%; - padding: 0 7.5px 15px; - .big-data-down-center-one-content { - height: 100%; - position: relative; - .fixed-top, - .fixed-right, - .fixed-bottom, - .fixed-left { - position: absolute; - width: 100px; - height: 100px; - display: flex; - cursor: pointer; - .circle { - position: absolute; - border-radius: 50%; - background: rgba(0, 0, 0, 0.01); - z-index: 10; - } - .text-box { - position: relative; - z-index: 11; - color: #c0d1f2; - margin: auto; - text-align: center; - font-size: 12px; - i { - font-size: 28px; - margin-bottom: 10px; - } - } - } - .fixed-top { - left: 20px; - top: 20px; - } - .fixed-right { - right: 20px; - top: 20px; - } - .fixed-bottom { - right: 20px; - bottom: 20px; - } - .fixed-left { - left: 20px; - bottom: 20px; - } - .circle:nth-of-type(1) { - width: 100px; - height: 95px; - animation: turnAround 6s infinite linear; - box-shadow: 0 0 1px 0 #869fe4, inset 0 0 10px 0 #869fe4; - } - .circle:nth-of-type(2) { - width: 95px; - height: 100px; - animation: turnAround 10s infinite linear; - box-shadow: 0 0 1px 0 #3397f2, inset 0 0 10px 0 #3397f2; - } - .circle:nth-of-type(3) { - width: 110px; - height: 100px; - animation: turnAround 5s infinite linear; - box-shadow: 0 0 1px 0 #3eaadc, inset 0 0 10px 0 #3eaadc; - } - .circle:nth-of-type(4) { - width: 100px; - height: 110px; - animation: turnAround 15s infinite linear; - box-shadow: 0 0 1px 0 #09f, inset 0 0 10px 0 #09f; - } - @keyframes turnAround { - 100% { - transform: rotate(360deg); - } - } - } - } - .big-data-down-center-two { - padding: 0 7.5px 15px; - height: 33.33%; - .flex-warp-item-box { - width: 100%; - height: 100%; - background: rgba(22, 34, 58, 0.4); - display: flex; - flex-direction: column; - padding: 15px; - .flex-title { - margin-bottom: 15px; - color: #c0d1f2; - display: flex; - justify-content: space-between; - .flex-title-small { - font-size: 12px; - } - } - .flex-content { - flex: 1; - font-size: 12px; - display: flex; - height: calc(100% - 30px); - .flex-content-left { - display: flex; - flex-wrap: wrap; - width: 120px; - height: 100%; - .monitor-item { - width: 50%; - display: flex; - align-items: center; - .monitor-wave { - cursor: pointer; - width: 40px; - height: 40px; - position: relative; - background-color: #43bdf0; - border-radius: 50%; - overflow: hidden; - text-align: center; - &::before, - &::after { - content: ''; - position: absolute; - left: 50%; - width: 40px; - height: 40px; - background: #f4f4f4; - animation: roateOne 10s linear infinite; - transform: translateX(-50%); - z-index: 1; - } - &::before { - bottom: 10px; - border-radius: 60%; - } - &::after { - bottom: 8px; - opacity: 0.7; - border-radius: 37%; - } - .monitor-z-index { - position: relative; - z-index: 2; - color: #4eb8ff; - display: flex; - align-items: center; - height: 100%; - justify-content: center; - font-weight: bold; - } - } - @keyframes roateOne { - 0% { - transform: translate(-50%, 0) rotateZ(0deg); - } - 50% { - transform: translate(-50%, -2%) rotateZ(180deg); - } - 100% { - transform: translate(-50%, 0%) rotateZ(360deg); - } - } - .monitor-active { - background-color: #22bc76; - .monitor-z-index { - color: #22bc76; - } - } - } - } - .flex-content-right { - flex: 1; - } - } - } - } - } - .big-data-down-right { - .flex-warp-item { - padding: 0 15px 15px 7.5px; - .flex-content { - display: flex; - flex-direction: column; - .task { - display: flex; - height: 45px; - .task-item { - flex: 1; - color: #c0d1f2; - display: flex; - justify-content: center; - .task-item-box { - position: relative; - width: 45px; - height: 45px; - overflow: hidden; - border-radius: 100%; - z-index: 0; - display: flex; - align-items: center; - flex-direction: column; - justify-content: center; - box-shadow: 0 10px 12px 0 rgba(0, 0, 0, 0.3); - &::before { - content: ''; - position: absolute; - z-index: -2; - left: -50%; - top: -50%; - width: 200%; - height: 200%; - background-repeat: no-repeat; - background-size: 50% 50%, 50% 50%; - background-position: 0 0, 100% 0, 100% 100%, 0 100%; - background-image: linear-gradient(#19d4ae, #19d4ae), linear-gradient(#5ab1ef, #5ab1ef), linear-gradient(#fa6e86, #fa6e86), - linear-gradient(#ffb980, #ffb980); - animation: rotate 2s linear infinite; - } - &::after { - content: ''; - position: absolute; - z-index: -1; - left: 1px; - top: 1px; - width: calc(100% - 2px); - height: calc(100% - 2px); - border-radius: 100%; - } - .task-item-value { - text-align: center; - font-size: 14px; - font-weight: bold; - } - .task-item-label { - text-align: center; - } - } - .task1 { - &::after { - background: #5492be; - } - } - .task2 { - &::after { - background: #43a177; - } - } - .task3 { - &::after { - background: #a76077; - } - } - .task4 { - &::after { - background: #b4825a; - } - } - .task5 { - &::after { - background: #74568f; - } - } - } - .task-first-item { - flex-direction: column; - text-align: center; - .task-first { - font-size: 20px; - } - } - } - } - } - .progress { - flex: 1; - } - } - } -} -</style> diff --git a/src/views/visualizing/images/bathymetry.jpg b/src/views/visualizing/images/bathymetry.jpg deleted file mode 100644 index 5f9eebe..0000000 --- a/src/views/visualizing/images/bathymetry.jpg +++ /dev/null Binary files differ diff --git a/src/views/visualizing/images/world.jpg b/src/views/visualizing/images/world.jpg deleted file mode 100644 index 22c7566..0000000 --- a/src/views/visualizing/images/world.jpg +++ /dev/null Binary files differ diff --git a/src/views/visualizing/mock/demo1.ts b/src/views/visualizing/mock/demo1.ts deleted file mode 100644 index 60fd944..0000000 --- a/src/views/visualizing/mock/demo1.ts +++ /dev/null @@ -1,51 +0,0 @@ -// 地图模拟数据 -export const echartsMapList: Array<object> = [ - { name: '深圳市人民政府', value: '100' }, - { name: '莲花山公园', value: '100' }, - { name: '世界之窗', value: '100' }, - { name: '华侨城欢乐谷', value: '100' }, - { name: '宝安区西乡', value: '100' }, -]; - -// 地图经纬度数据 -export const echartsMapData: object = { - 深圳市人民政府: [114.064524, 22.549225], - 莲花山公园: [114.0658, 22.560072], - 世界之窗: [113.979419, 22.540579], - 华侨城欢乐谷: [113.986066, 22.548056], - 宝安区西乡: [113.869053, 22.581714], -}; - -// 地图图片显示 -export const echartsMapImgs: Array<object> = [ - { - url: 'https://img1.baidu.com/it/u=4244861097,3561366422&fm=11&fmt=auto&gp=0.jpg', - name: '深圳市人民政府', - add: '深圳市福田区福中三路市民中心C区', - dec: '深圳市人民政府是根据《中华人民共和国地方各级人民代表大会和地方各级人民政府组织法》设立的,是深圳市人民代表大会的执行机关,是深圳市的国家行政机关。', - }, - { - url: 'https://img1.baidu.com/it/u=3793608028,4006842751&fm=26&fmt=auto&gp=0.jpg', - name: '莲花山公园', - add: '广东省深圳市福田区莲花街道莲花北社区红荔路6030号', - dec: '莲花山公园筹建于1992年10月10日 ,1997年6月23日正式对外局部开放。', - }, - { - url: 'https://img0.baidu.com/it/u=1406340112,1927292660&fm=26&fmt=auto&gp=0.jpg', - name: '世界之窗', - add: '深圳市南山区深南大道9037号', - dec: '这里,世界首座实景拍摄悬空式球幕影院“飞跃美利坚””,为游客提供集休闲放松于一体的都市时尚生活空间。', - }, - { - url: 'https://img0.baidu.com/it/u=3042342330,902556630&fm=26&fmt=auto&gp=0.jpg', - name: '华侨城欢乐谷', - add: '广东省深圳市南山区沙河街道星河街社区侨城西街1号', - dec: '深圳欢乐谷注重满足人们参与、体验的新型诱游需求,营造出自然、清新、活泼、惊奇、热烈、刺激的休闲旅游氛围。', - }, - { - url: 'https://img2.baidu.com/it/u=1075072079,1229283519&fm=11&fmt=auto&gp=0.jpg', - name: '宝安区西乡', - add: '西乡街道下辖25个社区', - dec: '西乡街道,隶属于广东省深圳市宝安区,位于宝安区西南部,东接石岩街道,南接新安街道,西至珠江口岸边,北接航城街道。', - }, -]; diff --git a/src/views/visualizing/mock/demo2.ts b/src/views/visualizing/mock/demo2.ts deleted file mode 100644 index 6b302b4..0000000 --- a/src/views/visualizing/mock/demo2.ts +++ /dev/null @@ -1,131 +0,0 @@ -// 顶部下来菜单 -export const dropdownList: Array<object> = [ - { - label: '广东省农业农村厅', - }, - { - label: '广西省农业农村厅', - }, - { - label: '四川省农业农村厅', - }, - { - label: '湖北省农业农村厅', - }, - { - label: '福建省农业农村厅', - }, - { - label: '山东省农业农村厅', - }, - { - label: '江西省农业农村厅', - }, -]; - -// sky 天气 -export const skyList: Array<object> = [ - { - v1: '时间', - v2: '天气', - v3: '温度', - v4: '湿度', - v5: '降水概率', - v6: '风向', - v7: '风力', - type: 'title', - }, - { - v1: '今天', - v2: 'ele-Sunny', - v3: '20°/26°', - v4: '80%', - v5: '50%', - v6: '东南风', - v7: '13m/s', - }, - { - v1: '明天', - v2: 'ele-Lightning', - v3: '20°/26°', - v4: '80%', - v5: '50%', - v6: '东南风', - v7: '13m/s', - }, - { - v1: '后天', - v2: 'ele-Sunny', - v3: '20°/26°', - v4: '80%', - v5: '50%', - v6: '东南风', - v7: '13m/s', - }, -]; - -// 当前设置状态 -export const dBtnList: Array<object> = [ - { - v1: '地块A-灌溉', - v2: '阳光玫瑰种植', - v3: '126天', - v4: '设备在线', - }, - { - v1: '地块B-收割', - v2: '阳光玫瑰种植', - v3: '360天', - v4: '设备预警', - }, -]; - -// 当前设备监测 -export const chartData4List: Array<object> = [ - { - label: '温度', - }, - { - label: '光照', - }, - { - label: '湿度', - }, - { - label: '风力', - }, - { - label: '张力', - }, - { - label: '气压', - }, -]; - -// 3DEarth 地图周围按钮组 -export const earth3DBtnList: Array<object> = [ - { - topLevelClass: 'fixed-top', - icon: 'ele-MagicStick', - label: '环境监测', - type: 0, - }, - { - topLevelClass: 'fixed-right', - icon: 'ele-MoonNight', - label: '精准管理', - type: 1, - }, - { - topLevelClass: 'fixed-bottom', - icon: 'ele-TrendCharts', - label: '数据报表', - type: 2, - }, - { - topLevelClass: 'fixed-left', - icon: 'ele-Van', - label: '产品追溯', - type: 3, - }, -]; -- Gitblit v1.9.2