288 lines
7.1 KiB
Vue
288 lines
7.1 KiB
Vue
<template>
|
||
<div class="layout-header-warp">
|
||
<div class="layout-header">
|
||
<div class="layout-header-top">
|
||
<div class="layout-header-top-left">
|
||
<span class="welcome-msg">您好,欢迎来到农业产业服务平台</span>
|
||
<div class="left-link">
|
||
<div class="iconfont icon-bigScreen"></div>
|
||
<span>数据大屏</span>
|
||
</div>
|
||
<div class="left-link">
|
||
<div class="iconfont icon-operation" style="font-size: 12px"></div>
|
||
<span>产业运营管理</span>
|
||
</div>
|
||
</div>
|
||
<div class="layout-header-top-right">
|
||
<span>商家中心</span>
|
||
<span @click="toUserCenter">个人中心</span>
|
||
<span @click="toHome" class="back-home">
|
||
<div class="iconfont icon-home" style="font-size: 12px"></div>
|
||
<span>返回首页</span>
|
||
</span>
|
||
</div>
|
||
</div>
|
||
<div class="layout-header-bottom">
|
||
<div class="layout-header-bottom-left">
|
||
<div class="layout-header-bottom-search">
|
||
<div class="title">
|
||
<img :src="getAssetsFile('images/logo.png')" />
|
||
</div>
|
||
<div class="search-warp">
|
||
<el-input v-model="keyword" placeholder="请输入关键词进行搜索"></el-input>
|
||
<el-button type="primary" @click="Search">搜索</el-button>
|
||
</div>
|
||
</div>
|
||
</div>
|
||
<div class="layout-header-bottom-right">
|
||
<div class="layout-header-bottom-right-qr">
|
||
<div class="layout-header-bottom-right-qr-img">
|
||
<img :src="qrImg" alt="" />
|
||
<p>下载数农App</p>
|
||
</div>
|
||
<div class="layout-header-bottom-right-qr-img">
|
||
<img :src="qrImg" alt="" />
|
||
<p>打开数农小程序</p>
|
||
</div>
|
||
</div>
|
||
</div>
|
||
</div>
|
||
<div class="layout-header-menu">
|
||
<el-menu ellipsis class="layout-header-bottom-menu" mode="horizontal">
|
||
<app-link v-for="(item, index) in meuns" :key="index" :to="item.path">
|
||
<el-menu-item active-text-color="#25BF82">{{ item.label }}</el-menu-item>
|
||
</app-link>
|
||
</el-menu>
|
||
</div>
|
||
</div>
|
||
</div>
|
||
</template>
|
||
|
||
<script setup name="layout-header">
|
||
import { ref } from 'vue';
|
||
import { qrImg } from './base64img';
|
||
import AppLink from '../Menu/Link.vue';
|
||
import { useRouter } from 'vue-router';
|
||
import { getAssetsFile } from '@/utils';
|
||
|
||
const router = useRouter();
|
||
|
||
const keyword = ref('');
|
||
|
||
const meuns = ref([
|
||
{
|
||
label: '智慧种植',
|
||
path: '/sub-operation-service/ecommerce',
|
||
},
|
||
{
|
||
label: '农事服务',
|
||
path: '/sub-operation-service/ecommerce',
|
||
},
|
||
{
|
||
label: '涉农金融',
|
||
path: '/sub-operation-service/ecommerce',
|
||
},
|
||
{
|
||
label: '电商交易',
|
||
path: '/sub-operation-service/ecommerce',
|
||
},
|
||
{
|
||
label: '分拣包装',
|
||
path: '/sub-operation-service/ecommerce',
|
||
},
|
||
{
|
||
label: '仓储物流',
|
||
path: '/sub-operation-service/ecommerce',
|
||
},
|
||
{
|
||
label: '公共品牌运营',
|
||
path: '/sub-operation-service/ecommerce',
|
||
},
|
||
]);
|
||
|
||
function Search() {
|
||
console.log(keyword.value, 'search');
|
||
}
|
||
|
||
const toHome = () => {
|
||
console.info('toHome', router);
|
||
router.push('/sub-operation-service/home');
|
||
};
|
||
|
||
const toUserCenter = () => {
|
||
router.push('/sub-operation-service/userCenter');
|
||
};
|
||
</script>
|
||
|
||
<style lang="scss" scoped>
|
||
.layout-header-warp {
|
||
width: 100%;
|
||
text-align: center;
|
||
background: $color-fff;
|
||
.layout-header-menu {
|
||
width: 100%;
|
||
::v-deep() {
|
||
.el-menu {
|
||
justify-content: space-around;
|
||
border: none !important;
|
||
}
|
||
.el-menu-item {
|
||
font-size: 24px;
|
||
}
|
||
.el-menu-item:hover {
|
||
background: none !important;
|
||
color: $color-main;
|
||
}
|
||
.el-menu-item:active {
|
||
background: none !important;
|
||
color: $color-main;
|
||
}
|
||
}
|
||
}
|
||
}
|
||
.layout {
|
||
// width: 100%;
|
||
// height: 100%;
|
||
// box-sizing: border-box;
|
||
&-header {
|
||
width: 1200px;
|
||
height: 206px;
|
||
overflow: hidden;
|
||
margin: auto;
|
||
&-top {
|
||
display: flex;
|
||
height: 44px;
|
||
justify-content: space-between;
|
||
align-items: center;
|
||
padding: 0 32px;
|
||
&-left {
|
||
line-height: 36px;
|
||
.welcome-msg {
|
||
font-size: 12px;
|
||
color: $color-5a;
|
||
}
|
||
.left-link {
|
||
color: $color-main;
|
||
margin: 0 10px;
|
||
font-size: 12px;
|
||
cursor: pointer;
|
||
display: inline-block;
|
||
.iconfont {
|
||
color: $color-main;
|
||
display: inline-block;
|
||
margin-right: 2px;
|
||
}
|
||
.iconfont,
|
||
span {
|
||
vertical-align: middle;
|
||
}
|
||
}
|
||
}
|
||
&-right {
|
||
span {
|
||
color: $color-000;
|
||
margin-left: 25px;
|
||
line-height: 36px;
|
||
font-size: 12px;
|
||
text-align: center;
|
||
cursor: pointer;
|
||
&:nth-child(1) {
|
||
margin-left: 0;
|
||
}
|
||
|
||
&.back-home {
|
||
.iconfont {
|
||
display: inline-block;
|
||
vertical-align: middle;
|
||
color: $color-main;
|
||
}
|
||
span {
|
||
margin-left: 6px;
|
||
display: inline-block;
|
||
vertical-align: middle;
|
||
}
|
||
color: $color-main;
|
||
}
|
||
}
|
||
}
|
||
}
|
||
&-bottom {
|
||
display: flex;
|
||
padding: 20px 32px 0;
|
||
&-left {
|
||
flex-grow: 1;
|
||
display: flex;
|
||
flex-direction: column;
|
||
justify-content: space-between;
|
||
width: calc(100% - 300px);
|
||
.layout-header-bottom-search {
|
||
display: flex;
|
||
align-items: center;
|
||
.title {
|
||
font-size: 45px;
|
||
white-space: nowrap;
|
||
}
|
||
.search-warp {
|
||
width: 100%;
|
||
padding-left: 36px;
|
||
position: relative;
|
||
.el-input {
|
||
flex-grow: 1;
|
||
height: 50px;
|
||
font-size: 18px;
|
||
width: 100%;
|
||
:deep(.el-input__wrapper) {
|
||
padding-right: 100px;
|
||
}
|
||
}
|
||
|
||
.el-button {
|
||
position: absolute;
|
||
right: 8px;
|
||
top: 50%;
|
||
transform: translateY(-50%);
|
||
font-size: 18px;
|
||
padding: 0 24px;
|
||
height: 42px;
|
||
}
|
||
}
|
||
}
|
||
.layout-header-bottom-menu {
|
||
justify-content: space-around;
|
||
border: none;
|
||
.el-menu-item {
|
||
font-size: 24px;
|
||
}
|
||
}
|
||
}
|
||
&-right {
|
||
margin-top: -10px;
|
||
width: 240px;
|
||
padding-left: 20px;
|
||
p {
|
||
text-align: center;
|
||
}
|
||
&-qr {
|
||
display: flex;
|
||
justify-content: space-between;
|
||
&-img {
|
||
img {
|
||
width: 48px;
|
||
height: 48px;
|
||
}
|
||
p {
|
||
text-align: center;
|
||
}
|
||
}
|
||
}
|
||
}
|
||
}
|
||
}
|
||
&-main {
|
||
width: 100%;
|
||
height: calc(100% - 206px);
|
||
background-color: #f8f8f8;
|
||
}
|
||
}
|
||
</style>
|