index.vue 4.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133
  1. <!-- -->
  2. <template>
  3. <view>
  4. <resume v-if="showResumeList" resumeAnalysis @submit="handleResumeAnalysis"></resume>
  5. <view v-if="formLIst?.length">
  6. <uni-card v-for="item of formLIst" :key="item.id" :id="item.id">
  7. <uni-section :title="item.text" type="line">
  8. <template v-slot:right>
  9. <view v-if="item.path !== 'baseInfoEdit'" style="color: #e64340;" @click="del(item)">删除</view>
  10. </template>
  11. <avatarEdit v-if="item.path === 'avatarEdit'" ref="componentRef" :id="item.id" :data="item.data" />
  12. <baseInfoEdit v-if="item.path === 'baseInfoEdit'" ref="componentRef" :id="item.id" :data="item.data" />
  13. </uni-section>
  14. </uni-card>
  15. </view>
  16. <view v-else>
  17. <view v-if="loading">加载中...</view>
  18. <view v-else>加载失败</view>
  19. </view>
  20. <!-- 确认框 -->
  21. <uni-popup ref="confirmRef" type="dialog">
  22. <uni-popup-dialog
  23. type="warn"
  24. cancelText="取消"
  25. confirmText="确认"
  26. title="系统提示"
  27. :content="dialogContent"
  28. @confirm="handleConfirm"
  29. @close="null"
  30. ></uni-popup-dialog>
  31. </uni-popup>
  32. </view>
  33. </template>
  34. <script setup>
  35. defineOptions({name: 'resumeAnalysis-index'})
  36. // import { saveResumeInfo, resumeParser2 } from '@/api/recruit/personal/resume'
  37. // import { resumeParser2 } from '@/api/recruit/personal/resume'
  38. // import { envObj, baseUrl } from '@/utils/config'
  39. import resume from '../resume/index.vue'
  40. import { ref, shallowRef } from 'vue'
  41. import baseInfoEdit from './components/baseInfoEdit.vue'
  42. import avatarEdit from './components/avatarEdit.vue'
  43. import { data } from './testData.js'
  44. const showResumeList = ref(true)
  45. const handleResumeAnalysis = (url) => {
  46. if (!url) {
  47. return uni.showToast({ icon: 'none', title: '请选择要解析的简历' })
  48. }
  49. showResumeList.value = false
  50. // handleAnalysis(url)
  51. }
  52. const exampleList = {
  53. avatar: { text: '头像', id: 'avatar', path: 'avatarEdit' },
  54. person: { text: '基础信息', id: 'person', path: 'baseInfoEdit' },
  55. advantage: { text: '个人优势', id: 'advantage', path: 'advantage' },
  56. eduList: { text: '教育经历', id: 'eduList', path: '' },
  57. workList: { text: '工作经历', id: 'workList', path: '' },
  58. trainList: { text: '培训经历', id: 'trainList', path: '' },
  59. }
  60. const resumeTxt = ref([]) // 查看文本信息
  61. const formLIst = shallowRef([])
  62. const transformToLIst = async (result) => {
  63. formLIst.value = []
  64. if (result && Object.keys(result)) {
  65. if (result.resume?.rawText) resumeTxt.value = result.resume.rawText.split('\n') || []
  66. if (result.person?.advantage) result.advantage = result.person.advantage
  67. if (result.person?.avatar) result.avatar = result.person.avatar
  68. // obj
  69. const dealObjKeys = ['avatar', 'person', 'advantage']
  70. dealObjKeys.forEach(key => {
  71. if (result[key]) {
  72. const obj = {...exampleList[key]}
  73. obj.data = result[key]
  74. formLIst.value.push(obj)
  75. }
  76. })
  77. // arr
  78. const dealArrKeys = ['eduList', 'workList', 'trainList']
  79. dealArrKeys.forEach(key => {
  80. if (result[key]?.length) {
  81. for (let index = 0; index < result[key].length; index++) {
  82. const obj = {...exampleList[key]}
  83. obj.id = obj.id + '_' + index
  84. obj.text = result[key].length > 1 ? obj.text + (index+1) : obj.text
  85. obj.data = result[key][index]
  86. formLIst.value.push(obj)
  87. }
  88. }
  89. })
  90. }
  91. // console.log('formLIst:', formLIst.value)
  92. }
  93. const confirmRef = ref()
  94. const dialogContent = ref('')
  95. let delId = null
  96. const del = (item) => {
  97. dialogContent.value = `是否确认删除${item.text}?`
  98. delId = item.id
  99. confirmRef.value.open()
  100. }
  101. const handleConfirm = () => {
  102. formLIst.value = formLIst.value.filter(e => e.id !== delId)
  103. }
  104. const result = ref(JSON.parse(JSON.stringify(data)))
  105. const loading = ref(false)
  106. transformToLIst(result.value)
  107. // const handleAnalysis = async (url) => {
  108. // url = decodeURIComponent(url)
  109. // if (!url) return
  110. // showSelect.value = false
  111. // loading.value = true
  112. // // const baseUrl = envObj.previewUrl
  113. // // fileUrl.value = !url.includes('.pdf') ? `${baseUrl}/onlinePreview?url=${encodeURIComponent(Base64.encode(url))}` : url
  114. // try {
  115. // const data = await resumeParser2({ fileUrl: url })
  116. // result.value = data || {}
  117. // await transformToLIst(result.value)
  118. // } catch (error) {
  119. // console.log(error)
  120. // } finally {
  121. // loading.value = false
  122. // }
  123. // }
  124. </script>
  125. <style lang="scss" scoped>
  126. </style>