From 5e15de578dffaa00168e8cff66210826de1ac55b Mon Sep 17 00:00:00 2001
From: Your Name <123456>
Date: Mon, 27 Jun 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