123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166 |
- <!-- 分享职位 -->
- <template>
- <div
- style="background-color: #f0f0f0; width: 100vw;"
- >
- <v-card
- class="py-3 px-5"
- style="background-color: #fff; overflow: auto;"
- :style="{'width': windowWidth > 750 ? '750px' : '100vw', 'margin': windowWidth > 750 ? '5px auto' : '0 auto'}"
- >
- <div v-if="!Object.keys(info).length">加载失败</div>
- <div>
- <div class="d-flex justify-space-between">
- <h2 class="JobName ellipsis">{{ info.name }}</h2>
- <span class="salary">{{ info.payFrom }}-{{ info.payTo }}/{{ positionInfo.payName }}</span>
- </div>
- <div class="d-flex justify-space-between mt-4">
- <div>
- <div class="banner-tags">
- <div v-for="k in desc" :key="k.mdi" class="mr-10">
- <v-icon color="var(--color-666)" size="20">{{ k.mdi }}</v-icon>
- <span class="f-w-600 ml-1">{{ positionInfo[k.value] }}</span>
- </div>
- </div>
- <div class="my-4 mb-3" v-if="info?.tagList">
- <v-chip size="small" class="mr-1 mb-1" color="primary" label v-for="(k, i) in info.tagList" :key="i">{{ k }}</v-chip>
- </div>
- </div>
- <v-btn
- class="button-item radius mb-3"
- color="warning"
- variant="outlined"
- prepend-icon="mdi-heart-outline"
- @click="null"
- >{{ $t('position.collection') }}</v-btn>
- </div>
- <v-divider></v-divider>
- <div class="mt-3 mb-1 f-w-600">{{ $t('position.jobResponsibilities') }}</div>
- <div class="requirement" v-html="info.content?.replace(/\n/g, '</br>')"></div>
- <div class="mt-3 mb-1 f-w-600">{{ $t('position.jobRequirements') }}</div>
- <div class="requirement" v-html="info.requirement?.replace(/\n/g, '</br>')"></div>
- <v-divider class="my-3"></v-divider>
- <div class="contact">
- <div class="float-left d-flex align-center">
- <v-img :src="info.contact?.avatar || 'https://minio.citupro.com/dev/menduner/7.png'" :width="45" style="height: 45px;"></v-img>
- <div class="ml-2">
- <div class="contact-name">{{ info.contact?.name }}</div>
- <div class="contact-info">{{ info.enterprise?.name }} · {{ info.contact?.postNameCn }}</div>
- </div>
- </div>
- </div>
- <v-divider class="my-3"></v-divider>
- <div>
- <h4>{{ $t('position.address') }}</h4>
- <div class="mt-1">
- <v-icon size="25" color="primary">mdi-map-marker</v-icon>
- <span style="color: var(--color-666);font-size: 15px;">{{ info.address }}</span>
- </div>
- </div>
- <div class="mt-3 text-center">
- <v-btn class="mr-2 radius button-item" color="success" variant="outlined">{{ $t('position.communicate') }}</v-btn>
- <v-btn class="radius button-item" :disabled="delivery" color="primary" @click="handleDelivery">{{ delivery ? $t('position.delivered') : $t('position.submitResume') }}</v-btn>
- </div>
- </div>
- </v-card>
- </div>
- </template>
- <script setup>
- import { onMounted, onUnmounted, ref } from 'vue';
- import { getPositionDetails } from '@/api/position'
- import { dealDictObjData } from '@/utils/position'
- defineOptions({name: 'recruit-personal-shareJob-index'})
- // 组件挂载后添加事件监听器
- onMounted(() => {
- window.addEventListener('resize', updateWindowSize)
- })
- // 组件卸载前移除事件监听器
- onUnmounted(() => {
- window.removeEventListener('resize', updateWindowSize)
- })
- // 获取路由参数
- const queryParams = new URLSearchParams(window.location.search)
- const jobId = queryParams.get('jobId') || ''
- const sharedById = queryParams.get('sharedById') || ''
- const sharedByName = queryParams.get('sharedByName') || ''
- const sharedByPhone = queryParams.get('sharedByPhone') || ''
- const file = queryParams.get('file') || ''
- console.log(jobId, sharedById, sharedByName, sharedByPhone, file)
- // 职位详情
- const info = ref({})
- const positionInfo = ref({})
- const getPositionDetail = async () => {
- const data = await getPositionDetails({ id: jobId })
- info.value = data
- positionInfo.value = { ...dealDictObjData({}, info.value), ...info.value }
- }
- getPositionDetail()
- const desc = [
- { mdi: 'mdi-map-marker-outline', value: 'areaName' },
- { mdi: 'mdi-school-outline', value: 'eduName' },
- { mdi: 'mdi-clock-time-ten-outline', value: 'expName' }
- ]
- // 监听窗口大小变化事件
- const windowWidth = ref(window.innerWidth)
- const updateWindowSize = async () => {
- windowWidth.value = window.innerWidth
- // windowHeight.value = window.innerHeight
- // console.log('windowWidth', windowWidth.value)
- }
- </script>
- <style lang="scss" scoped>
- .f-w-600 { font-weight: 600; }
- .radius { border-radius: 8px; }
- .salary {
- color: var(--v-error-base);
- line-height: 41px;
- font-weight: 600;
- height: auto;
- display: inline-block;
- vertical-align: sub;
- }
- .JobName {
- color: #37576c;
- font-size: 28px;
- margin-right: 30px;
- margin-top: 1px;
- // max-width: 45%;
- vertical-align: middle;
- flex: 1;
- }
- .banner-tags { display: flex; flex-wrap: wrap; }
- .requirement {
- white-space: pre-wrap;
- word-break: break-all;
- line-height: 28px;
- color: var(--color-333);
- font-size: 15px;
- text-align: justify;
- letter-spacing: 0;
- }
- .contact {
- height: 60px;
- line-height: 60px;
- padding: 0 10px;
- }
- .contact-name {
- font-size: 20px;
- font-weight: 500;
- color: var(--color-222);
- line-height: 28px;
- }
- .contact-info {
- font-size: 15px;
- color: var(--color-666);
- line-height: 21px;
- margin-top: 8px;
- }
- .button-item {
- min-width: 110px;
- height: 36px
- }
- </style>
|