yitisheng-new-web/src/views/other/testCultural.vue

287 lines
13 KiB
Vue

<template>
<LeftNav />
<div class="main-container wrap main-fullScreen main-div" style="height: unset;">
<el-row :gutter="20">
<!-- 左侧 院校列表-->
<el-col :xs="12" :sm="12">
<el-card class="box-card">
<div class="filterTable">
<div class="filterTitle flexWrap">
<div class="flex-item-75">
<div class="searchSchool">
<el-input v-model="state.selectForm.schoolName" maxlength="24" show-word-limit
style="max-width: 230px;height: 40px;line-height: 40px;"
placeholder="请输入院校或专业名称" class="input-with-select" />
<el-button :icon="Search" @click="reloadSchoolList"
style="border-left: none;height: 40px;line-height: 40px;" />
</div>
</div>
</div>
</div>
<el-divider />
<!--clearable-->
<div class="schoolList">
<div class="schoolItem" v-for="item in state.schoolList"
@click="showSchoolInfo(item.schoolCode)">
<div class="schoolLogo">
<img :src="item.schoolIcon"
v-if="item.schoolIcon != null && item.schoolIcon != undefined" />
<img v-else src="@/assets/images/school/school_default.png">
</div>
<div class="schoolInfo">
<div class="schoolTitle">
<h3 class="schoolName">
{{ item.schoolName }}
<span class="province" v-if="item.province">{{ item.province }}{{ item.city }}{{
item.area }}</span>
</h3>
</div>
<div class="schoolTags">
<span v-for="tag in item.tagsList">{{ tag }}</span>
</div>
</div>
</div>
</div>
<el-skeleton :loading="state.loading" style="padding-top: 25px;"></el-skeleton>
<div class="page">
<el-pagination background @current-change="handlePage" :current-page="state.current"
:page-size="state.size" :total="state.total" layout="total, prev, pager, next,jumper" />
</div>
</el-card>
</el-col>
<!-- 右侧 功能广告-->
<el-col :xs="12" :sm="12">
<div class="page-right" style="width: 300px">
选择左侧院校
</div>
</el-col>
</el-row>
</div>
</template>
<script setup lang="ts">
import { reactive } from 'vue'
import apiConstant from "@/utils/ApiConstant";
import axiosInstance from '@/utils/http';
import { SchoolEntity } from "@/types";
import { Search } from '@element-plus/icons-vue';
import LeftNav from "@/components/LeftNav.vue";
import StaticConstant from '@/utils/StaticConstant';
document.title = '找大学|' + import.meta.env.VITE_PROGRAM_TYPE;
//激活的tabs页
const state = reactive({
selectForm: {
schoolName: '',
current: 1,
pageSize: 10,
} as any,
schoolList: [] as Array<SchoolEntity>,
size: 10,
total: 0,
current: 1,
loading: false,//加载中? true 加载/false 关闭
})
getSchoolList()
//获取学校列表
function getSchoolList() {
state.loading = true;
state.schoolList = []
axiosInstance({
url: apiConstant.School.searchSchoolList,
method: 'get',
params: {
schoolName: state.selectForm.schoolName,
pageNum: state.selectForm.current,
pageSize: state.selectForm.pageSize,
addressList: state.selectForm.addressList,
tagsList: state.selectForm.tagsList,
schoolNatureList: state.selectForm.schoolNatureList
},
showLoading: false,//是否显示加载图标
}).then((response) => {
return response?.data
}).then((data) => {
state.loading = false;
if (data.success) {
let dataResult = data.result
console.log(dataResult)
let tags = []
if (dataResult.records != null && dataResult.records != undefined) {
for (let i = 0; i < dataResult.records.length; i++) {
tags = []
let dre = dataResult.records[i]
if (dataResult.records[i].tagsList != null && dataResult.records[i].tagsList != undefined) {
tags.push(...dre.tagsList)
}
dataResult.records[i].tagsList = tags
}
}
state.schoolList = dataResult.records
state.selectForm.current = data.result.current
state.selectForm.pageSize = data.result.size
state.total = data.result.total
}
}).catch((error: any) => {
console.log(error);
}).finally(() => {
});
}
function reloadSchoolList() {
state.selectForm.current = 1
state.schoolList = []
getSchoolList()
}
const handlePage = (page: number) => {
if (page) {
state.selectForm.current = page
getSchoolList()
}
}
const showSchoolInfo = (schoolCode: string) => {
window.open(schoolCode, '_self')
}
</script>
<style scoped lang="scss">
//标签页样式
.demo-tabs>.el-tabs__content {
padding: 32px;
color: #6b778c;
font-size: 32px;
font-weight: 600;
}
//自定义输入框 样式
/** 默认样式 */
.input-border-style {
border: 1px solid #eee !important;
border-radius: 6px !important;
}
:deep(.el-input__wrapper) {
background: none !important;
}
</style>
<!--学校列表-->
<style scoped lang="scss">
.schoolList {
.schoolItem:hover {
color: #3491FA
}
.schoolItem:last-child {
border-bottom: none;
}
.schoolItem {
display: flex;
justify-content: flex-start;
align-items: center;
padding: 20px;
cursor: pointer;
border-bottom: 1px solid #eee;
position: relative;
.schoolLogo {
margin-right: 20px;
img {
width: 60px;
height: 60px;
}
}
.schoolInfo {
.schoolTitle {
margin-bottom: 18px;
.schoolName {
color: #333;
font-size: 18px;
height: 25px;
line-height: 25px;
margin: 0 20px 0 0;
transition: all .3s;
display: flex;
align-items: center;
.province {
height: 26px;
line-height: 24px;
font-size: 12px;
border: 1px solid #eee;
color: #555;
display: inline-block;
padding: 0 10px;
margin: 0 20px 0 15px;
}
}
.schoolName:hover {
color: #3491FA
}
}
.schoolTags {
span {
display: inline-block;
color: #555;
padding-right: 10px;
margin-right: 10px;
border-right: 1px solid #c5c5c5;
line-height: 15px;
}
span:last-child {
border: none;
}
}
}
}
}
.page-right {
.box-card {
border-radius: 12px;
}
.card-header {
display: flex;
justify-content: space-between;
align-items: center;
color: red;
}
:deep(.el-card__header) {
padding: 6px 12px 12px 12px;
background-color: #4cc8ff;
height: 30px;
span {
width: 100px;
height: 16px;
background-size: cover;
background-image: url(data:image/png;base64,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);
}
}
.item {
border-radius: 12px;
}
:deep(.el-card__body) {
padding: 0;
}
}
</style>