index.vue 4.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132
  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. // import { saveResumeInfo, resumeParser2 } from '@/api/recruit/personal/resume'
  36. // import { resumeParser2 } from '@/api/recruit/personal/resume'
  37. // import { envObj, baseUrl } from '@/utils/config'
  38. import resume from '../resume/index.vue'
  39. import { ref, shallowRef } from 'vue'
  40. import baseInfoEdit from './components/baseInfoEdit.vue'
  41. import avatarEdit from './components/avatarEdit.vue'
  42. import { data } from './testData.js'
  43. const showResumeList = ref(true)
  44. const handleResumeAnalysis = (url) => {
  45. if (!url) {
  46. return uni.showToast({ icon: 'none', title: '请选择要解析的简历' })
  47. }
  48. showResumeList.value = false
  49. // handleAnalysis(url)
  50. }
  51. const exampleList = {
  52. avatar: { text: '头像', id: 'avatar', path: 'avatarEdit' },
  53. person: { text: '基础信息', id: 'person', path: 'baseInfoEdit' },
  54. advantage: { text: '个人优势', id: 'advantage', path: 'advantage' },
  55. eduList: { text: '教育经历', id: 'eduList', path: '' },
  56. workList: { text: '工作经历', id: 'workList', path: '' },
  57. trainList: { text: '培训经历', id: 'trainList', path: '' },
  58. }
  59. const resumeTxt = ref([]) // 查看文本信息
  60. const formLIst = shallowRef([])
  61. const transformToLIst = async (result) => {
  62. formLIst.value = []
  63. if (result && Object.keys(result)) {
  64. if (result.resume?.rawText) resumeTxt.value = result.resume.rawText.split('\n') || []
  65. if (result.person?.advantage) result.advantage = result.person.advantage
  66. if (result.person?.avatar) result.avatar = result.person.avatar
  67. // obj
  68. const dealObjKeys = ['avatar', 'person', 'advantage']
  69. dealObjKeys.forEach(key => {
  70. if (result[key]) {
  71. const obj = {...exampleList[key]}
  72. obj.data = result[key]
  73. formLIst.value.push(obj)
  74. }
  75. })
  76. // arr
  77. const dealArrKeys = ['eduList', 'workList', 'trainList']
  78. dealArrKeys.forEach(key => {
  79. if (result[key]?.length) {
  80. for (let index = 0; index < result[key].length; index++) {
  81. const obj = {...exampleList[key]}
  82. obj.id = obj.id + '_' + index
  83. obj.text = result[key].length > 1 ? obj.text + (index+1) : obj.text
  84. obj.data = result[key][index]
  85. formLIst.value.push(obj)
  86. }
  87. }
  88. })
  89. }
  90. // console.log('formLIst:', formLIst.value)
  91. }
  92. const confirmRef = ref()
  93. const dialogContent = ref('')
  94. let delId = null
  95. const del = (item) => {
  96. dialogContent.value = `是否确认删除${item.text}?`
  97. delId = item.id
  98. confirmRef.value.open()
  99. }
  100. const handleConfirm = () => {
  101. formLIst.value = formLIst.value.filter(e => e.id !== delId)
  102. }
  103. const result = ref(JSON.parse(JSON.stringify(data)))
  104. const loading = ref(false)
  105. transformToLIst(result.value)
  106. // const handleAnalysis = async (url) => {
  107. // url = decodeURIComponent(url)
  108. // if (!url) return
  109. // showSelect.value = false
  110. // loading.value = true
  111. // // const baseUrl = envObj.previewUrl
  112. // // fileUrl.value = !url.includes('.pdf') ? `${baseUrl}/onlinePreview?url=${encodeURIComponent(Base64.encode(url))}` : url
  113. // try {
  114. // const data = await resumeParser2({ fileUrl: url })
  115. // result.value = data || {}
  116. // await transformToLIst(result.value)
  117. // } catch (error) {
  118. // console.log(error)
  119. // } finally {
  120. // loading.value = false
  121. // }
  122. // }
  123. </script>
  124. <style lang="scss" scoped>
  125. </style>