253 lines
8.8 KiB
Vue
253 lines
8.8 KiB
Vue
<route lang="json5" type="page">
|
|
{
|
|
style: {
|
|
navigationStyle: 'custom',
|
|
},
|
|
}
|
|
</route>
|
|
|
|
<template>
|
|
<z-paging
|
|
ref="paging"
|
|
use-virtual-list
|
|
:force-close-inner-list="true"
|
|
cell-height-mode="dynamic"
|
|
@virtualListChange="virtualListChange"
|
|
@query="queryList"
|
|
:auto-show-system-loading="true"
|
|
:safe-area-inset-bottom="true"
|
|
>
|
|
<template #top>
|
|
<view class="relative">
|
|
<Navbar
|
|
safeAreaInsetTop
|
|
bg-color="transparent"
|
|
:bordered="false"
|
|
left-arrow
|
|
title="查扩缩招"
|
|
@click-left="navigatorBack"
|
|
/>
|
|
<view class="custom-background h-[200rpx] w-full absolute top-0 left-0 z-[-1]"></view>
|
|
</view>
|
|
<drop-menu ref="dropMenuRef">
|
|
<drop-menu-item
|
|
:key="item.id"
|
|
:title="item.title"
|
|
custom-class="flex items-center"
|
|
v-for="item in subMenu"
|
|
:activation="item.activation"
|
|
>
|
|
<Region
|
|
:defaultValue="regionKeyInfo"
|
|
@changeName="handleRegionChange"
|
|
@change="handleRegionChangeCode"
|
|
class="custom-check-group"
|
|
v-if="item.id === 1"
|
|
/>
|
|
<Nature
|
|
:defaultValue="natureKeyInfo"
|
|
@changeName="handleNatureChange"
|
|
@change="handleNatureChangeCode"
|
|
class="custom-check-group"
|
|
v-if="item.id === 2"
|
|
/>
|
|
<UniType
|
|
:defaultValue="uniTypeKeyInfo"
|
|
@change-name="handleUniTypeChange"
|
|
@change="handleUniTypeChangeCode"
|
|
class="custom-check-group"
|
|
v-if="item.id === 3"
|
|
/>
|
|
<view class="flex items-center justify-between px-[16rpx] pb-[32rpx]">
|
|
<view class="cancel-btn" @click="handleClear">清空</view>
|
|
<view class="submit-btn" @click="handleCheck">查看</view>
|
|
</view>
|
|
</drop-menu-item>
|
|
</drop-menu>
|
|
|
|
<view class="px-32rpx">
|
|
<view class="flex items-center justify-between input-wrapper-class">
|
|
<input
|
|
v-model="searchParams.collegeName"
|
|
placeholder="请输入院校名称"
|
|
confirm-type="done"
|
|
input-mode="numeric"
|
|
class="flex-auto"
|
|
/>
|
|
<view class="text-[#1580FF] text-[24rpx] search-text" @click="handleConfirm">查询</view>
|
|
</view>
|
|
</view>
|
|
<view class="bg-[#F8F8F8] h-[16rpx] mt-[40rpx]"></view>
|
|
</template>
|
|
<view class="px-[32rpx] pt-[32rpx]">
|
|
<view
|
|
class="bg-[#F7F7F7] flex items-center justify-between text-[20rpx] text-[#333] px-[28rpx] py-[16rpx] sticky top-0"
|
|
>
|
|
<view class="flex-auto text-[24rpx] font-semibold">院校</view>
|
|
<view class="w-[96rpx] text-center px-[16rpx] text-[24rpx] font-semibold">招生专业</view>
|
|
<view class="w-[116rpx] text-center px-[16rpx] text-[24rpx] font-semibold">
|
|
{{ tModel.year }}计划
|
|
</view>
|
|
<view class="w-[86rpx] text-center pl-[16rpx] text-[24rpx] font-semibold">
|
|
较{{ tModel.year - 1 }}
|
|
</view>
|
|
</view>
|
|
|
|
<view
|
|
class="item-wrapper"
|
|
:id="`zp-id-${item.zp_index}`"
|
|
:key="item.zp_index"
|
|
v-for="(item, index) in lineList"
|
|
>
|
|
<view class="flex items-center justify-between text-[20rpx] text-[#333] py-[16rpx]">
|
|
<view class="flex-1 flex items-center">
|
|
<image :src="item.logo" mode="scaleToFill" class="w-[72rpx] h-[72rpx] mr-[6rpx]" />
|
|
<view class="ml-[6rpx]">
|
|
<view class="text-[32rpx] font-semibold truncate max-w-[200rpx]">
|
|
{{ item.name }}
|
|
</view>
|
|
<view class="mt-[6rpx] text-[22rpx]">
|
|
<text class="mr-[16rpx]">{{ item.provinceName }}</text>
|
|
<text>排名:{{ item.rank }}</text>
|
|
</view>
|
|
</view>
|
|
</view>
|
|
<view class="w-[96rpx] text-center px-[16rpx] text-[24rpx]">{{ item.planCount }}</view>
|
|
<view class="w-[116rpx] text-center px-[16rpx] text-[24rpx]">{{ item.newPlan }}人</view>
|
|
<view class="w-[86rpx] text-center pl-[16rpx] pr-[28rpx] text-[24rpx]">
|
|
<text v-if="item.newPlan - item.oldPlan === 0">相同</text>
|
|
<view v-else class="flex items-center justify-center gap-[10rpx]">
|
|
<text>{{ item.newPlan - item.oldPlan }}</text>
|
|
<image
|
|
v-if="item.newPlan - item.oldPlan < 0"
|
|
src=""
|
|
mode="scaleToFill"
|
|
class="w-[16rpx] h-[16rpx]"
|
|
/>
|
|
<image
|
|
v-if="item.newPlan - item.oldPlan > 0"
|
|
src=""
|
|
mode="scaleToFill"
|
|
class="w-[16rpx] h-[16rpx]"
|
|
/>
|
|
</view>
|
|
</view>
|
|
</view>
|
|
</view>
|
|
</view>
|
|
</z-paging>
|
|
</template>
|
|
|
|
<script lang="ts" setup>
|
|
import Navbar from '@/pages-sub/components/navbar/Navbar.vue'
|
|
import { useUserStore } from '@/store'
|
|
import DropMenu from '@/pages-sub/components/drop-menu/DropMenu.vue'
|
|
import DropMenuItem from '@/pages-sub/components/drop-menu/DropMenuItem.vue'
|
|
import Region from '@/pages-sub/home/components/Region.vue'
|
|
import UniType from '@/pages-sub/home/components/UniType.vue'
|
|
import Nature from '@/pages-sub/home/components/Nature.vue'
|
|
|
|
import { getAdmissionTrends } from '@/service/index/api'
|
|
|
|
const userStore = useUserStore()
|
|
|
|
const searchParams = ref({
|
|
locationName: [],
|
|
type: [],
|
|
searchNature: [],
|
|
collegeName: '',
|
|
})
|
|
|
|
const handleConfirm = () => {
|
|
paging.value.reload()
|
|
}
|
|
|
|
const navigatorBack = () => {
|
|
uni.navigateBack()
|
|
}
|
|
|
|
const handleNatureChangeCode = (val) => {
|
|
natureKeyInfo.value = val
|
|
}
|
|
const handleUniTypeChangeCode = (val) => {
|
|
uniTypeKeyInfo.value = val
|
|
}
|
|
|
|
const handleRegionChangeCode = (val) => {
|
|
regionKeyInfo.value = val
|
|
}
|
|
|
|
const handleRegionChange = (val) => {
|
|
searchParams.value.locationName = val
|
|
subMenu.value[0].activation = val.length !== 0
|
|
}
|
|
const handleNatureChange = (val) => {
|
|
searchParams.value.searchNature = val
|
|
subMenu.value[1].activation = val.length !== 0
|
|
}
|
|
|
|
const handleUniTypeChange = (val) => {
|
|
searchParams.value.type = val
|
|
subMenu.value[2].activation = val.length !== 0
|
|
}
|
|
|
|
const lineList = ref([])
|
|
const tModel = ref({ year: 0 })
|
|
|
|
const paging = ref(null)
|
|
const queryList = (page: number, pageSize: number) => {
|
|
getAdmissionTrends({
|
|
pageIndex: page,
|
|
pageSize,
|
|
locationCode: userStore.userInfo.estimatedAchievement.provinceCode,
|
|
provinceName: searchParams.value.locationName,
|
|
utype: searchParams.value.type,
|
|
nature: searchParams.value.searchNature,
|
|
keyword: searchParams.value.collegeName,
|
|
}).then((res) => {
|
|
if (res.code === 200) {
|
|
paging.value.complete((res.result as { rows: any[] }).rows)
|
|
tModel.value.year = (res.result as { tModel: { year: number } }).tModel.year
|
|
} else {
|
|
paging.value.complete([])
|
|
}
|
|
})
|
|
}
|
|
const virtualListChange = (_vList) => {
|
|
lineList.value = _vList
|
|
}
|
|
|
|
const subMenu = ref([
|
|
{ id: 1, title: '省份', activation: false },
|
|
{ id: 2, title: '层次', activation: false },
|
|
{ id: 3, title: '类别', activation: false },
|
|
])
|
|
|
|
const dropMenuRef = ref()
|
|
const regionKeyInfo = ref([]) // 省份信息
|
|
const uniTypeKeyInfo = ref([]) // 层次信息
|
|
const natureKeyInfo = ref([]) // 类型信息
|
|
|
|
const handleClear = () => {
|
|
regionKeyInfo.value = []
|
|
uniTypeKeyInfo.value = []
|
|
natureKeyInfo.value = []
|
|
subMenu.value.forEach((item) => {
|
|
item.activation = false
|
|
})
|
|
dropMenuRef.value.closeDropMenu()
|
|
}
|
|
|
|
const handleCheck = () => {
|
|
dropMenuRef.value.closeDropMenu()
|
|
handleConfirm()
|
|
}
|
|
</script>
|
|
|
|
<style lang="scss" scoped>
|
|
@import '@/pages-sub/home/styles/navbar-background.scss';
|
|
@import '@/pages-sub/home/styles/search-input.scss';
|
|
@import '@/pages-sub/home/styles/grid-checkbox.scss';
|
|
@import '@/pages-sub/home/styles/picker-view-btn.scss';
|
|
</style>
|