feat : update avue 1.3.0

This commit is contained in:
smallwei 2018-04-29 23:57:59 +08:00
parent 64cdbaf07b
commit d8ff197cbc
14 changed files with 341 additions and 312 deletions

View File

@ -1,14 +1,18 @@
<template> <template>
<div class="pull-height animated" :class="{'zoomOutUp': isLock}"> <div class="pull-height animated" :class="{'zoomOutUp': isLock}">
<top></top>
<div class="index"> <div class="index">
<sidebar class="left pull-chheight"></sidebar> <sidebar class="left"></sidebar>
<div class="right"> <div class="right">
<tags ref="nav" class="nav"></tags> <div class="nav">
<top class="top"></top>
<tags></tags>
</div>
<div class="main">
<keep-alive> <keep-alive>
<router-view v-if="!$route.meta.keepAlive" class="main pull-chheight"></router-view> <router-view v-if="$route.meta.keepAlive"></router-view>
</keep-alive> </keep-alive>
<router-view v-if="$route.meta.keepAlive" class="main pull-chheight"></router-view> <router-view v-if="!$route.meta.keepAlive"></router-view>
</div>
</div> </div>
</div> </div>
</div> </div>
@ -40,23 +44,21 @@ export default {
<style lang="scss" scoped> <style lang="scss" scoped>
.index { .index {
display: flex; display: flex;
height: calc(100% - 60px);
padding: 0 0 20px 0;
position: relative; position: relative;
min-height: 100%; height: 100%;
background: #fff; background: #fff;
overflow: hidden; overflow: hidden;
.left:not(.el-menu--collapse) { .left {
width: 200px; width: 230px;
overflow-y: auto; overflow-y: auto;
} }
.right { .right {
padding-top: 42px; padding-top: 107px;
position: relative; position: relative;
flex: 1; flex: 1;
box-sizing: border-box;
} }
.main { .main {
height: 100%;
overflow-y: scroll; overflow-y: scroll;
} }
.nav { .nav {
@ -66,5 +68,8 @@ export default {
width: 100%; width: 100%;
z-index: 999; z-index: 999;
} }
.top {
margin-bottom: 2px;
}
} }
</style> </style>

View File

@ -1,16 +1,21 @@
<template> <template>
<el-menu unique-opened :default-active="nowTagValue" class="el-menu-vertical-demo" background-color="#495060" text-color="#c9cbd0" active-text-color="#fff" :collapse="isCollapse"> <div class="sidebar-container" :class="{'is-active':isCollapse}">
<sidebar-item :menu="menu" :show="!isCollapse"></sidebar-item> <logo :isCollapse="isCollapse"></logo>
<el-menu unique-opened :default-active="nowTagValue" class="el-menu-vertical-demo" mode="vertical" :show-timeout="200" background-color="#00142a" text-color="hsla(0,0%,100%,.65)" active-text-color="#409eff" :collapse="isCollapse">
<sidebar-item :menu="menu" :isCollapse="isCollapse"></sidebar-item>
</el-menu> </el-menu>
</div>
</template> </template>
<script> <script>
import MENU from "@/mock/menu"; import MENU from "@/mock/menu";
import { mapGetters } from "vuex";
import { setUrlPath } from "@/util/util"; import { setUrlPath } from "@/util/util";
import { mapGetters } from "vuex";
import SidebarItem from "./sidebarItem"; import SidebarItem from "./sidebarItem";
import logo from "./logo";
export default { export default {
name: "sidebar",
components: { SidebarItem, logo },
data() { data() {
return {}; return {};
}, },
@ -24,8 +29,7 @@ export default {
} }
}, },
mounted() {}, mounted() {},
methods: {}, methods: {}
components: { SidebarItem }
}; };
</script> </script>
<style lang="scss" scoped> <style lang="scss" scoped>

View File

@ -0,0 +1,73 @@
<template>
<div class="logo">
<transition name="fade">
<span v-if="isCollapse" class="logo_title is-bold is-active" key="0">Pig</span>
</transition>
<transition-group name="fade">
<template v-if="!isCollapse">
<span class="logo_title is-bold" key="1">Pig </span>
<span class="logo_subtitle" key="2">微服务快速开发框架</span>
</template>
</transition-group>
</div>
</template>
<script>
export default {
name: "logo",
data() {
return {};
},
props: ["isCollapse"],
computed: {},
created() {},
computed: {},
methods: {}
};
</script>
<style scoped="scoped" lang="scss">
.fade-leave-active {
transition: opacity 0.2s;
}
.fade-enter-active {
transition: opacity 2.5s;
}
.fade-enter,
.fade-leave-to {
opacity: 0;
}
.logo {
position: relative;
display: flex;
justify-content: center;
align-items: center;
width: 230px;
height: 64px;
line-height: 64px;
background: #002140;
color: #fdfdfd;
text-align: center;
font-size: 20px;
font-weight: 600;
overflow: hidden;
box-sizing: border-box;
}
.logo_title {
padding: 0 5px 0 0;
color: #409eff;
font-size: 28px;
&.is-bold {
font-weight: 700;
}
}
.is-active {
position: absolute;
top: 0;
left: 10px;
}
.logo_subtitle {
font-size: 16px;
padding-top: 5px;
}
</style>

View File

@ -5,17 +5,17 @@
<i :class="item.icon"></i> <i :class="item.icon"></i>
<span slot="title">{{item.label}}</span> <span slot="title">{{item.label}}</span>
</el-menu-item> </el-menu-item>
<el-submenu v-else :index="filterPath(item.name,index)" :key="item.name"> <el-submenu v-else :index="filterPath(item.label,index)" :key="item.label">
<template slot="title"> <template slot="title">
<i :class="item.icon"></i> <i :class="item.icon"></i>
<span slot="title" :class="{'el-menu--display':!show}">{{item.label}}</span> <span slot="title" :class="{'el-menu--display':isCollapse}">{{item.label}}</span>
</template> </template>
<template v-for="(child,cindex) in item.children"> <template v-for="(child,cindex) in item.children">
<el-menu-item :index="filterPath(child.path,cindex)" @click="open(child)" v-if="child.children.length==0" :key="cindex"> <el-menu-item :index="filterPath(child.path,cindex)" @click="open(child)" v-if="child.children.length==0" :key="cindex">
<i :class="child.icon"></i> <i :class="child.icon"></i>
<span slot="title">{{child.label}}</span> <span slot="title">{{child.label}}</span>
</el-menu-item> </el-menu-item>
<sidebar-item v-else :menu="[child]" :show="show" :key="cindex"></sidebar-item> <sidebar-item v-else :menu="[child]" :key="cindex" :isCollapse="isCollapse"></sidebar-item>
</template> </template>
</el-submenu> </el-submenu>
</template> </template>
@ -32,19 +32,20 @@ export default {
menu: { menu: {
type: Array type: Array
}, },
show: { isCollapse: {
type: Boolean type: Boolean
} }
}, },
created() {}, created() {},
mounted() {}, mounted() {},
computed: {},
methods: { methods: {
filterPath(path, index) { filterPath(path, index) {
return path == null ? index + "" : path; return path == null ? index + "" : path;
}, },
open(item) { open(item) {
this.$router.push({ this.$router.push({
path: resolveUrlPath(item.path, item.name), path: resolveUrlPath(item.path, item.label),
query: item.query query: item.query
}); });
} }

View File

@ -3,8 +3,8 @@
<!-- tag盒子 --> <!-- tag盒子 -->
<div class="tags-box" ref="tagBox"> <div class="tags-box" ref="tagBox">
<div class="tags-list" ref="tagsList" @mousewheel="hadelMousewheel" @mouseup="hadelMouseUp" @mousemove="hadelMouse" @mousedown="hadelMousestart" @touchup="hadelMouseUp" @touchmove="hadelMouse" @touchstart="hadelMousestart"> <div class="tags-list" ref="tagsList" @mousewheel="hadelMousewheel" @mouseup="hadelMouseUp" @mousemove="hadelMouse" @mousedown="hadelMousestart" @touchup="hadelMouseUp" @touchmove="hadelMouse" @touchstart="hadelMousestart">
<div ref="tagsPageOpened" class="tag-item" :name="item.value" @contextmenu.prevent="openMenu(item,$event)" v-for="(item,index) in tagList" :key="index" @click="openUrl(item)"> <div ref="tagsPageOpened" class="tag-item" :class="{'is-active':nowTagValue==item.value}" :name="item.value" @contextmenu.prevent="openMenu(item,$event)" v-for="(item,index) in tagList" :key="index" @click="openUrl(item)">
<span class="icon-yuan tag-item-icon" :class="{'is-active':nowTagValue==item.value}"></span> <span class="icon-yuan tag-item-icon"></span>
<span class="tag-text">{{item.label}}</span> <span class="tag-text">{{item.label}}</span>
<i class="el-icon-close tag-close" @click.stop="closeTag(item)" v-if="item.close"></i> <i class="el-icon-close tag-close" @click.stop="closeTag(item)" v-if="item.close"></i>
</div> </div>

View File

@ -1,7 +1,6 @@
<template> <template>
<div class="top"> <div class="top">
<div class="top-button is-left"> <div class="top-button is-left">
<top-logo></top-logo>
<div class="tags-breadcrumb"> <div class="tags-breadcrumb">
<i class="icon-navicon tag-collapse" :class="[{ 'tag-collapse_right': isCollapse }]" @click="showCollapse"></i> <i class="icon-navicon tag-collapse" :class="[{ 'tag-collapse_right': isCollapse }]" @click="showCollapse"></i>
</div> </div>
@ -10,7 +9,7 @@
<topMenu></topMenu> <topMenu></topMenu>
</h1> </h1>
<div class="top-button is-right"> <div class="top-button is-right">
<el-tooltip class="item" effect="dark" content="换肤" placement="bottom"> <el-tooltip class="item" effect="dark" content="主题色" placement="bottom">
<span class="top-item"> <span class="top-item">
<top-theme></top-theme> <top-theme></top-theme>
</span> </span>
@ -25,6 +24,9 @@
<i :class="isFullScren?'icon-tuichuquanping':'icon-quanping'" @click="handleScreen"></i> <i :class="isFullScren?'icon-tuichuquanping':'icon-quanping'" @click="handleScreen"></i>
</span> </span>
</el-tooltip> </el-tooltip>
<el-tooltip class="item" effect="dark" content="用户头像" placement="bottom">
<img class="top-userImg" :src="userInfo.avatar">
</el-tooltip>
<el-dropdown> <el-dropdown>
<span class="el-dropdown-link"> <span class="el-dropdown-link">
{{userInfo.username}} {{userInfo.username}}
@ -46,21 +48,17 @@
<el-dropdown-item @click.native="logout" divided>退出系统</el-dropdown-item> <el-dropdown-item @click.native="logout" divided>退出系统</el-dropdown-item>
</el-dropdown-menu> </el-dropdown-menu>
</el-dropdown> </el-dropdown>
<el-tooltip class="item" effect="dark" content="用户头像" placement="bottom">
<img class="top-userImg" :src="userInfo.avatar">
</el-tooltip>
</div> </div>
</div> </div>
</template> </template>
<script> <script>
import { mapState, mapGetters } from "vuex"; import { mapState, mapGetters } from "vuex";
import { fullscreenToggel, listenfullscreen } from "@/util/util"; import { fullscreenToggel, listenfullscreen } from "@/util/util";
import topLogo from "./top-logo";
import topLock from "./top-lock"; import topLock from "./top-lock";
import topMenu from "./top-menu"; import topMenu from "./top-menu";
import topTheme from "./top-theme"; import topTheme from "./top-theme";
export default { export default {
components: { topLock, topLogo, topMenu, topTheme }, components: { topLock, topMenu, topTheme },
name: "top", name: "top",
data() { data() {
return {}; return {};

View File

@ -1,40 +0,0 @@
<template>
<div class="pull-auto">
<div class="logo">
<span class="logo_title is-bold">Pig </span>
<span class="logo_subtitle"> 微服务快速开发框架</span>
</div>
</div>
</template>
<script>
export default {
name: "top-logo",
data() {
return {};
},
created() {},
computed: {},
methods: {}
};
</script>
<style scoped="scoped" lang="scss">
.logo {
display: flex;
align-items: center;
}
.logo_title {
padding: 0 8px 0 0;
color: #409eff;
line-height: 60px;
font-size: 28px;
font-style: italic;
&.is-bold {
font-weight: 700;
}
}
.logo_subtitle {
padding-top: 5px;
}
</style>

View File

@ -16,9 +16,9 @@ export default {
watch: { watch: {
theme(val, oldVal) { theme(val, oldVal) {
if (typeof val !== "string") return; if (typeof val !== "string") return;
const head = document.getElementsByTagName("head")[0];
const themeCluster = this.getThemeCluster(val.replace("#", "")); const themeCluster = this.getThemeCluster(val.replace("#", ""));
const originalCluster = this.getThemeCluster(oldVal.replace("#", "")); const originalCluster = this.getThemeCluster(oldVal.replace("#", ""));
console.log(themeCluster, originalCluster);
const getHandler = (variable, id) => { const getHandler = (variable, id) => {
return () => { return () => {
const originalCluster = this.getThemeCluster( const originalCluster = this.getThemeCluster(
@ -34,7 +34,7 @@ export default {
if (!styleTag) { if (!styleTag) {
styleTag = document.createElement("style"); styleTag = document.createElement("style");
styleTag.setAttribute("id", id); styleTag.setAttribute("id", id);
document.head.appendChild(styleTag); head.appendChild(styleTag);
} }
styleTag.innerText = newStyle; styleTag.innerText = newStyle;
}; };
@ -49,6 +49,30 @@ export default {
chalkHandler(); chalkHandler();
} }
const link = [].slice.call(
document.getElementsByTagName("head")[0].getElementsByTagName("link")
);
for (let i = link.length - 3; i < link.length; i++) {
const style = link[i];
this.getCSSString(style.href, innerText => {
const originalCluster = this.getThemeCluster(
ORIGINAL_THEME.replace("#", "")
);
const newStyle = this.updateStyle(
innerText,
originalCluster,
themeCluster
);
let styleTag = document.getElementById(i);
if (!styleTag) {
styleTag = document.createElement("style");
styleTag.id = i;
styleTag.innerText = newStyle;
head.appendChild(styleTag);
}
});
}
const styles = [].slice const styles = [].slice
.call(document.querySelectorAll("style")) .call(document.querySelectorAll("style"))
.filter(style => { .filter(style => {
@ -86,8 +110,10 @@ export default {
const xhr = new XMLHttpRequest(); const xhr = new XMLHttpRequest();
xhr.onreadystatechange = () => { xhr.onreadystatechange = () => {
if (xhr.readyState === 4 && xhr.status === 200) { if (xhr.readyState === 4 && xhr.status === 200) {
if (variable) {
this[variable] = xhr.responseText.replace(/@font-face{[^}]+}/, ""); this[variable] = xhr.responseText.replace(/@font-face{[^}]+}/, "");
callback(); }
callback(xhr.responseText);
} }
}; };
xhr.open("GET", url); xhr.open("GET", url);

View File

@ -15,9 +15,22 @@
user-select: none; user-select: none;
outline: none; outline: none;
}*/ }*/
.h1, .h2, .h3, .h4, .h5, .h6, h1, h2, h3, h4, h5, h6 {
.h1,
.h2,
.h3,
.h4,
.h5,
.h6,
h1,
h2,
h3,
h4,
h5,
h6 {
font-weight: 500; font-weight: 500;
} }
@include scrollBar(); @include scrollBar();
body, body,
div, div,
@ -46,8 +59,7 @@ td {
} }
body { body {
min-width: 1200px; min-width: 1300px;
color: #333;
font-family: "Helvetica Neue", Helvetica, "PingFang SC", "Microsoft YaHei"; font-family: "Helvetica Neue", Helvetica, "PingFang SC", "Microsoft YaHei";
line-height: 2; line-height: 2;
} }
@ -67,7 +79,6 @@ ul {
list-style: none; list-style: none;
} }
em { em {
font-style: normal; font-style: normal;
} }
@ -82,11 +93,13 @@ textarea {
textarea { textarea {
resize: none; resize: none;
} }
//禁用了文本的拖拉尤其在谷歌下 //禁用了文本的拖拉尤其在谷歌下
p { p {
text-align: justify; text-align: justify;
text-justify: distribute; text-justify: distribute;
} }
//为了使文本段落左右两边对齐 //为了使文本段落左右两边对齐
p { p {
word-wrap: break-word word-wrap: break-word
@ -100,8 +113,6 @@ i {
display: inline-block; display: inline-block;
} }
/*a:hover { color: #f60; text-decoration:none; }*/ /*a:hover { color: #f60; text-decoration:none; }*/
address, address,
@ -119,10 +130,8 @@ a {
display: inline-block; display: inline-block;
} }
/*a:link{color:#009;}*/ /*a:link{color:#009;}*/
/*a:visited{color:#800080;}*/ /*a:visited{color:#800080;}*/
a:hover, a:hover,
@ -135,9 +144,11 @@ table {
border-collapse: collapse; border-collapse: collapse;
border-spacing: 0; border-spacing: 0;
} }
.hidden { .hidden {
display: none; display: none;
} }
.padding { .padding {
padding: 0 !important; padding: 0 !important;
} }
@ -147,15 +158,18 @@ table {
} }
.pull-right { .pull-right {
float: right!important;; float: right !important;
;
} }
.pull-left { .pull-left {
float: left !important; float: left !important;
} }
.pull-center { .pull-center {
text-align: center; text-align: center;
} }
.pull-flex { .pull-flex {
display: flex; display: flex;
} }
@ -163,16 +177,17 @@ table {
.pull-overflow { .pull-overflow {
overflow: hidden; overflow: hidden;
} }
.pull-auto { .pull-auto {
height: auto; height: auto;
overflow: hidden; overflow: hidden;
} }
.pull-height { .pull-height {
height: 100%; height: 100%;
overflow: hidden;
} }
.pull-chheight{
height: calc( 100% - 60px );
}
.pull-fixed { .pull-fixed {
position: fixed; position: fixed;
left: 0; left: 0;
@ -182,6 +197,7 @@ table {
.text-white { .text-white {
color: #fff; color: #fff;
} }
.clearfix { .clearfix {
&:after { &:after {
visibility: hidden; visibility: hidden;
@ -191,9 +207,7 @@ table {
clear: both; clear: both;
height: 0; height: 0;
} }
} } //main-container全局样式
//main-container全局样式
.app-main { .app-main {
min-height: 100% min-height: 100%
} }

View File

@ -1,12 +1,15 @@
.el-dropdown-menu__item { .el-dropdown-menu__item {
font-size: 12px; font-size: 12px;
line-height: 28px; line-height: 28px;
} }
.el-loading-text{
text-align: center; .el-menu--horizontal {
border-bottom: none;
} }
.el-menu {
border-right: 0;
}
.el-menu--display, .el-menu--display,
.el-menu--display+.el-submenu__icon-arrow { .el-menu--display+.el-submenu__icon-arrow {

View File

@ -1,73 +1,19 @@
.sidebar-container {
background: #00142a;
transition: width .6s;
&.is-active {
width: 64px !important;
}
}
.hideSidebar { .el-menu-item.is-active {
.sidebar-container,.sidebar-container .el-menu { color: $mainBg !important;
width: 36px!important;
// overflow: inherit;
}
.main-container {
margin-left: 36px;
}
}
.hideSidebar {
.submenu-title-noDropdown {
padding-left: 10px!important;
position: relative;
span {
height: 0;
width: 0;
overflow: hidden;
visibility: hidden;
transition: opacity .3s cubic-bezier(.55, 0, .1, 1);
opacity: 0;
display: inline-block;
}
&:hover {
span {
display: block;
border-radius: 3px;
z-index: 1002;
width: 140px;
height: 56px;
visibility: visible;
position: absolute;
right: -145px;
text-align: left;
text-indent: 20px;
top: 0px;
background-color: $subMenuBg!important;
opacity: 1;
}
}
}
.el-submenu {
&>.el-submenu__title {
padding-left: 10px!important;
&>span {
display: none;
}
.el-submenu__icon-arrow {
display: none;
}
}
.nest-menu {
.el-submenu__icon-arrow {
display: block!important;
}
span {
display: inline-block!important;
}
}
}
} }
.nest-menu .el-submenu>.el-submenu__title, .nest-menu .el-submenu>.el-submenu__title,
.el-submenu .el-menu-item { .el-submenu .el-menu-item {
min-width: 180px!important; background-color: #021d3a !important;
background-color: $subMenuBg!important;
&:hover { &:hover {
background-color: $menuHover!important; background: #00142a !important;
} }
} }
.el-menu--collapse .el-menu .el-submenu{
min-width: 180px!important;
}

View File

@ -1,31 +1,34 @@
.tags-breadcrumb { .tags-breadcrumb {
display: flex; display: flex;
align-items: center; align-items: center;
padding: 0 16px; padding: 0 16px;
height: 50px; height: 50px;
} }
.tags-breadcrumb-list { .tags-breadcrumb-list {
padding: 0 15px; padding: 0 15px;
} }
.tag-collapse { .tag-collapse {
font-size: 36px !important; font-size: 36px !important;
} }
.tag-collapse.tag-collapse_right { .tag-collapse.tag-collapse_right {
transform: rotate(90deg); transform: rotate(90deg);
} }
.tags-container { .tags-container {
position: relative; position: relative;
box-sizing: border-box; box-sizing: border-box;
overflow: hidden; overflow: hidden;
box-shadow: 0 1px 4px rgba(0, 21, 41, .08);
.tags-box { .tags-box {
position: relative; position: relative;
box-sizing: border-box; box-sizing: border-box;
padding-right: 106px; padding-right: 106px;
width: 100%; width: 100%;
height: 40px; height: 40px;
background: #f0f0f0; background: #fff;
} }
.tags-list { .tags-list {
position: absolute; position: absolute;
@ -38,9 +41,6 @@
color: #eee; color: #eee;
font-size: 11px !important; font-size: 11px !important;
} }
.tag-item-icon.is-active{
color: $mainBg;
}
.tag-item { .tag-item {
position: relative; position: relative;
display: inline-block; display: inline-block;
@ -48,7 +48,7 @@
line-height: 30px; line-height: 30px;
margin: 2px 4px 2px 0; margin: 2px 4px 2px 0;
padding: 0 10px; padding: 0 10px;
border: 1px solid #e9eaec; border: 1px solid #eee;
border-radius: 3px; border-radius: 3px;
background: #fff; background: #fff;
color: #495060 !important; color: #495060 !important;
@ -57,6 +57,12 @@
opacity: 1; opacity: 1;
overflow: hidden; overflow: hidden;
cursor: pointer; cursor: pointer;
&.is-active {
.tag-item-icon {
color: $mainBg;
}
border-color : $mainBg;
}
} }
.tag-text { .tag-text {
margin-left: 8px; margin-left: 8px;
@ -80,11 +86,11 @@
box-shadow: -3px 0 15px 3px rgba(0, 0, 0, 0.1); box-shadow: -3px 0 15px 3px rgba(0, 0, 0, 0.1);
} }
} }
.contextmenu { .contextmenu {
margin: 0; margin: 0;
background: #fff; background: #fff;
z-index: 2; top: 64px;
position: fixed;
list-style-type: none; list-style-type: none;
padding: 5px 0; padding: 5px 0;
border-radius: 4px; border-radius: 4px;

View File

@ -1,11 +1,11 @@
.top { .top {
align-items: center; align-items: center;
background-color: #fff; background-color: #fff;
border-bottom:2px solid $menuBg; border-bottom: 1px solid #eee;
color: #333; color: rgba(0, 0, 0, .65);
display: flex; display: flex;
font-size: 18px; font-size: 18px;
height: 60px; height: 64px;
line-height: 1; line-height: 1;
padding: 0 10px; padding: 0 10px;
white-space: nowrap; white-space: nowrap;
@ -21,18 +21,20 @@
} }
.top-userImg { .top-userImg {
margin: 0 3px 0 10px; margin: 0 8px 0 10px;
padding: 2px; padding: 2px;
width: 35px; width: 30px;
height:35px; height: 30px;
border-radius: 100%; border-radius: 100%;
box-sizing: border-box; box-sizing: border-box;
border: 1px solid #eee; border: 1px solid #eee;
} }
.top-button { .top-button {
display: flex; display: flex;
align-items: center; align-items: center;
} }
.top-button>.top-item{
margin-right: 12px; .top-item {
margin-right: 8px;
} }

View File

@ -1,11 +1,2 @@
//sidebar
$menuBg:#495060;
$subMenuBg:#1f2d3d;
$menuHover:#001528;
//main //main
$mainBg: #4e97d9; $mainBg: #409eff;
$mainColor: #fff;
$mainDisBg: #d3d4d6;
$mainDisColor: #eee;