onlineResume.vue 31 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094
  1. <template>
  2. <view class="online-resume" :style="{ paddingTop: (12 + statusBarHeight + 88 - 60) + 'px' }">
  3. <!-- 固定顶部导航栏 -->
  4. <view class="fixed-nav" :style="{ paddingTop: (12 + statusBarHeight) + 'px' }">
  5. <view class="navbar">
  6. <view class="navbar-content">
  7. <view class="navbar-left" @click="goBack">
  8. <u-icon name="arrow-leftward" size="38" color="#333"></u-icon>
  9. </view>
  10. <view class="navbar-title">在线简历</view>
  11. <view class="navbar-right"></view>
  12. </view>
  13. </view>
  14. </view>
  15. <!-- 用户信息区域 -->
  16. <view class="user-profile">
  17. <view class="avatar-container">
  18. <image src="../../static/logo.png" class="user-avatar" mode="aspectFill"></image>
  19. <view class="edit-avatar-icon" @click="goToBasicInfo">
  20. <image src="../../static/images/index/Combined-Shape.svg" style="width: 32rpx;height: 32rpx;" mode=""></image>
  21. </view>
  22. </view>
  23. <view class="user-name">罗维靖</view>
  24. <view class="user-info">8年经验·33岁·硕士·男</view>
  25. <view class="contact-info">
  26. <view class="contact-item">
  27. <image src="../../static/images/index/phone.svg" style="width: 24rpx;height: 24rpx;" mode=""></image>
  28. <text class="contact-text">188******39</text>
  29. </view>
  30. <view class="contact-item">
  31. <image src="../../static/images/index/wx.svg" style="width: 24rpx;height: 24rpx;" mode=""></image>
  32. <text class="contact-text">188******39</text>
  33. </view>
  34. </view>
  35. <view class="availability">
  36. <text class="status-text">离职 & 随时到岗</text>
  37. <view class="status-dot"></view>
  38. </view>
  39. </view>
  40. <!-- 内容区域 -->
  41. <view class="content-section">
  42. <!-- 跨境电商工作经验 -->
  43. <view class="switch-section">
  44. <view class="switch-left">
  45. <view class="flex justify-between">
  46. <view class="switch-title">是否有跨境电商工作经验</view>
  47. <view class="template-text">不同简历模版</view>
  48. </view>
  49. <view class="section-status" v-if="hasEcommerceExperience">
  50. 是,有跨境电商工作经验
  51. </view>
  52. </view>
  53. <u-switch v-model="hasEcommerceExperience" active-color="#007AFF" size="60"></u-switch>
  54. </view>
  55. <!-- 个人优势 -->
  56. <view class="section-item">
  57. <view class="section-header">
  58. <view class="section-title">个人优势</view>
  59. <view class="edit-icon">
  60. <image src="../../static/images/index/Combined-Shape.svg" style="width: 48rpx;height: 48rpx;" mode=""></image>
  61. </view>
  62. </view>
  63. <view class="advantage-content">
  64. 这是个人编辑的个人优势区域这是个人编辑的个人优势区域这是个人编辑的个人优势区域这是个人编辑的个人优势区域... 展示三行
  65. </view>
  66. </view>
  67. <!-- 全职期望卡片 -->
  68. <view class="expectation-card">
  69. <view class="card-header">
  70. <view class="header-left">
  71. <image src="../../static/images/index/lingdai.svg" class="header-icon" />
  72. <text class="header-title">全职期望</text>
  73. </view>
  74. <text class="progress-text">2/3</text>
  75. </view>
  76. <view class="job-list">
  77. <view class="job-item">
  78. <view class="job-info">
  79. <view>
  80. <text class="job-title">亚马逊运营总监</text>
  81. <view @click="goToPreferenceSetting('亚马逊运营总监')">
  82. <view class="preference-btn">
  83. <text>设置求职偏好</text>
  84. </view>
  85. <u-icon name="arrow-right" color="rgba(29, 33, 41, 1)" size="28"></u-icon>
  86. </view>
  87. </view>
  88. <text class="job-details">30-40K・不限</text>
  89. <text class="job-location">深圳</text>
  90. </view>
  91. </view>
  92. <view class="job-item">
  93. <view class="job-info">
  94. <view>
  95. <text class="job-title">TikTok运营总监</text>
  96. <view @click="goToPreferenceSetting('TikTok运营总监')">
  97. <view class="preference-btn">
  98. <text>设置求职偏好</text>
  99. </view>
  100. <u-icon name="arrow-right" color="rgba(29, 33, 41, 1)" size="28"></u-icon>
  101. </view>
  102. </view>
  103. <text class="job-details">30-40K・精品铺货</text>
  104. <text class="job-location">深圳</text>
  105. </view>
  106. </view>
  107. </view>
  108. <view class="add-expectation-btn" @click="addExpectation">
  109. <text>添加求职期望</text>
  110. </view>
  111. </view>
  112. <!-- 工作经历 -->
  113. <view class="work-experience-section">
  114. <view class="section-header">
  115. <view class="section-title">
  116. <text class="required-mark">*</text>
  117. <text class="required-title">工作经历</text>
  118. <view class="section-desc">请填写专属跨境行业的工作经验</view>
  119. </view>
  120. <view class="edit-icon" @click="goToWorkExperience">
  121. <image src="../../static/images/index/Combined-Shape.svg" style="width: 48rpx;height: 48rpx;" mode=""></image>
  122. </view>
  123. </view>
  124. <view class="experience-list">
  125. <view class="experience-item">
  126. <view class="company-logo">
  127. <image src="../../static/images/index/changsha.svg" class="logo-img" mode="aspectFit"></image>
  128. </view>
  129. <view class="experience-content">
  130. <view class="job-info-row">
  131. <view class="job-title">资深亚马逊运营</view>
  132. <view class="job-department">运营部</view>
  133. </view>
  134. <view class="company-period-row">
  135. <view class="company-name">深圳市世迪贸易科技有限公司</view>
  136. <view class="work-period">2019.02-至今</view>
  137. </view>
  138. <view class="job-description">
  139. 负责Amazon英国、欧洲站、制定推广与销售计划,达成团队要求的销售业绩;做好数据的统计分析工作,收集、分析市场信息,竞争对手状况,并根据产品销售与排名变化,及时制定和调整产品的销售...
  140. </view>
  141. <view class="skill-tags">
  142. <view class="tag">精品铺货</view>
  143. <view class="tag">独立站</view>
  144. <view class="tag">3C数码</view>
  145. <view class="tag">品类运营</view>
  146. </view>
  147. </view>
  148. </view>
  149. <view class="experience-item">
  150. <view class="company-logo">
  151. <image src="../../static/images/index/changsha.svg" class="logo-img" mode="aspectFit"></image>
  152. </view>
  153. <view class="experience-content">
  154. <view class="job-info-row">
  155. <view class="job-title">高级ebay运营</view>
  156. <view class="job-department">运营部</view>
  157. </view>
  158. <view class="company-period-row">
  159. <view class="company-name">深圳市世迪贸易科技有限公司</view>
  160. <view class="work-period">2018.01-2019.01</view>
  161. </view>
  162. <view class="job-description">
  163. 负责Amazon英国、欧洲站、制定推广与销售计划,达成团队要求的销售业绩;做好数据的统计分析工作,收集、分析市场信息,竞争对手状况,并根据产品销售与排名变化,及时制定和调整产品的销售....
  164. </view>
  165. <view class="skill-tags">
  166. <view class="tag">精品铺货</view>
  167. <view class="tag">独立站</view>
  168. <view class="tag">3C数码</view>
  169. <view class="tag">品类运营</view>
  170. </view>
  171. </view>
  172. </view>
  173. <view class="experience-item">
  174. <view class="company-logo">
  175. <image src="../../static/images/index/changsha.svg" class="logo-img" mode="aspectFit"></image>
  176. </view>
  177. <view class="experience-content">
  178. <view class="job-info-row">
  179. <view class="job-title">高级产品开发经理</view>
  180. <view class="job-department">产品开发部</view>
  181. </view>
  182. <view class="company-period-row">
  183. <view class="company-name">深圳虾皮科技有限公司</view>
  184. <view class="work-period">2023.04 -至今</view>
  185. </view>
  186. <view class="job-description">
  187. 这是简历填写的内容这是简历填写的内容这是简历填写的内容这是简历填写的内容这是简历填写的内容这是简历填写的内容这是简历填写的内容这是简历填写的内容这是简历填写的内容这是简历填写的内容这是简历填写的内容这是简历填写的内容这是简历填写的内容...
  188. </view>
  189. <view class="skill-tags">
  190. <view class="tag">技能标签</view>
  191. <view class="tag">技能标签</view>
  192. <view class="tag">技能标签</view>
  193. <view class="tag">技能标签</view>
  194. <view class="tag">技能标签</view>
  195. <view class="tag">技能标签</view>
  196. </view>
  197. </view>
  198. </view>
  199. </view>
  200. </view>
  201. <!-- 教育经历 -->
  202. <view class="education-section">
  203. <view class="section-header">
  204. <view class="section-title">
  205. <text>教育经历</text>
  206. </view>
  207. <view class="edit-icon">
  208. <image src="../../static/images/index/Combined-Shape.svg" style="width: 48rpx;height: 48rpx;" mode=""></image>
  209. </view>
  210. </view>
  211. <view class="education-list">
  212. <view class="education-item">
  213. <view class="school-logo">
  214. <image src="../../static/images/index/wuhan.svg" class="logo-img" mode="aspectFit"></image>
  215. </view>
  216. <view class="education-content">
  217. <view class="school-name">武汉工程大学</view>
  218. <view class="degree-info">硕士 • 高分子化学与物理 • 2014-2017</view>
  219. <view class="education-description">
  220. 这是简历填写的内容这是简历填写的内容内容这是简历填写的内是简历填写的内容这是简历填写的内容...
  221. </view>
  222. </view>
  223. </view>
  224. <view class="education-item">
  225. <view class="school-logo">
  226. <image src="../../static/images/index/wuhan.svg" class="logo-img" mode="aspectFit"></image>
  227. </view>
  228. <view class="education-content">
  229. <view class="school-name">武汉工程大学</view>
  230. <view class="degree-info">硕士 • 高分子化学与物理 • 2014-2017</view>
  231. <view class="education-description">
  232. 这是简历填写的内容这是简历填写的内容这是简的内容这是的内容这是简历填写的内容这是简历填写的内容...
  233. </view>
  234. </view>
  235. </view>
  236. </view>
  237. </view>
  238. <!-- 技能 -->
  239. <view class="skills-section">
  240. <view class="section-header">
  241. <view class="section-title">
  242. <text>技能</text>
  243. </view>
  244. <view class="edit-icon" @click="goToJobSkills">
  245. <image src="../../static/images/index/Combined-Shape.svg" style="width: 48rpx;height: 48rpx;" mode=""></image>
  246. </view>
  247. </view>
  248. <view class="skills-grid">
  249. <view class="skill-tag">Design & Creative</view>
  250. <view class="skill-tag">Wireframing UX</view>
  251. <view class="skill-tag">Figma</view>
  252. <view class="skill-tag">UI Design</view>
  253. <view class="skill-tag">Prototype</view>
  254. <view class="skill-tag">Adobe XD</view>
  255. <view class="skill-tag">UX Design</view>
  256. <view class="skill-tag">Front End</view>
  257. </view>
  258. </view>
  259. </view>
  260. </view>
  261. </template>
  262. <script>
  263. export default {
  264. data() {
  265. return {
  266. statusBarHeight: 0, // 状态栏高度
  267. hasEcommerceExperience: true
  268. }
  269. },
  270. onLoad() {
  271. // 获取状态栏高度
  272. let systemInfo = uni.getSystemInfoSync();
  273. this.statusBarHeight = systemInfo.statusBarHeight || 0;
  274. },
  275. methods: {
  276. goBack() {
  277. uni.navigateBack();
  278. },
  279. addExpectation() {
  280. uni.navigateTo({
  281. url: '/package/jobIntention/addExpectation'
  282. })
  283. },
  284. goToPreferenceSetting(jobTitle) {
  285. uni.navigateTo({
  286. url: `/package/jobIntention/preferenceSetting?jobTitle=${encodeURIComponent(jobTitle)}`
  287. })
  288. },
  289. goToJobSkills() {
  290. uni.navigateTo({
  291. url: '/package/jobIntention/jobSkills'
  292. })
  293. },
  294. goToWorkExperience() {
  295. // 获取业务类型数据
  296. const businessTypes = this.getBusinessTypes()
  297. console.log('传递给工作经历页面的业务类型:', businessTypes)
  298. console.log('当前hasEcommerceExperience状态:', this.hasEcommerceExperience)
  299. uni.navigateTo({
  300. url: `/pages/my/workExperience?businessTypes=${encodeURIComponent(JSON.stringify(businessTypes))}`
  301. })
  302. },
  303. goToBasicInfo() {
  304. console.log('1111111');
  305. uni.navigateTo({
  306. url: '/package/jobIntention/basicInfo'
  307. })
  308. },
  309. getBusinessTypes() {
  310. // 根据是否有跨境电商经验返回业务类型
  311. if (this.hasEcommerceExperience) {
  312. return ['cross-border-ecommerce']
  313. } else {
  314. return []
  315. }
  316. }
  317. },
  318. watch: {
  319. hasEcommerceExperience(newVal, oldVal) {
  320. console.log('hasEcommerceExperience 变化:', oldVal, '->', newVal)
  321. // 只有有效的布尔值才保存到缓存
  322. if (typeof newVal === 'boolean') {
  323. uni.setStorageSync('hasEcommerceExperience', newVal)
  324. }
  325. }
  326. },
  327. mounted() {
  328. console.log('页面加载时 hasEcommerceExperience:', this.hasEcommerceExperience)
  329. // 检查是否有缓存的数据
  330. const cachedValue = uni.getStorageSync('hasEcommerceExperience')
  331. if (cachedValue !== null && cachedValue !== undefined && cachedValue !== '') {
  332. console.log('从缓存读取 hasEcommerceExperience:', cachedValue)
  333. this.hasEcommerceExperience = cachedValue
  334. } else {
  335. console.log('缓存中没有有效值,使用默认值:', this.hasEcommerceExperience)
  336. // 清除无效的缓存
  337. uni.removeStorageSync('hasEcommerceExperience')
  338. }
  339. // 监听偏好设置更新
  340. uni.$on('preferenceUpdated', (data) => {
  341. console.log('偏好设置已更新:', data)
  342. // 这里可以更新对应的职位偏好显示
  343. uni.showToast({
  344. title: `${data.jobTitle}偏好已更新`,
  345. icon: 'success'
  346. })
  347. })
  348. // 监听技能设置更新
  349. uni.$on('skillsUpdated', (data) => {
  350. console.log('技能设置已更新:', data)
  351. // 这里可以更新对应的技能显示
  352. uni.showToast({
  353. title: `${data.jobTitle}技能已更新`,
  354. icon: 'success'
  355. })
  356. })
  357. },
  358. beforeDestroy() {
  359. // 移除事件监听
  360. uni.$off('preferenceUpdated')
  361. uni.$off('skillsUpdated')
  362. }
  363. }
  364. </script>
  365. <style lang="scss" scoped>
  366. .online-resume {
  367. // background-color: #F2F6FC;
  368. min-height: 100vh;
  369. // padding-top 已改为动态计算,在模板中通过 :style 设置
  370. }
  371. .fixed-nav {
  372. position: fixed;
  373. top: 0;
  374. left: 0;
  375. right: 0;
  376. z-index: 9999;
  377. background-color: #ffffff;
  378. padding: 0 32rpx;
  379. // padding-top 已改为动态计算,在模板中通过 :style 设置
  380. }
  381. // 顶部导航栏
  382. .navbar {
  383. background: #fff;
  384. height: 88rpx;
  385. padding: 0 8rpx;
  386. // padding: 80rpx 0 40rpx 0; // 已移除,因为现在是固定导航栏
  387. .navbar-content {
  388. display: flex;
  389. align-items: center;
  390. justify-content: space-between;
  391. padding: 0 30rpx;
  392. height: 60rpx;
  393. .navbar-left {
  394. width: 60rpx;
  395. height: 60rpx;
  396. display: flex;
  397. align-items: center;
  398. justify-content: center;
  399. }
  400. .navbar-title {
  401. color: rgba(23, 23, 37, 1);
  402. font-family: DM Sans;
  403. font-size: 38rpx;
  404. font-weight: 700;
  405. line-height: 52rpx;
  406. letter-spacing: 0%;
  407. text-align: center;
  408. }
  409. .navbar-right {
  410. width: 60rpx;
  411. height: 60rpx;
  412. }
  413. }
  414. }
  415. // 用户信息区域
  416. .user-profile {
  417. background: #fff;
  418. padding: 60rpx 30rpx 40rpx;
  419. text-align: center;
  420. border-bottom: 2px solid rgba(227, 231, 236, 1);
  421. .avatar-container {
  422. position: relative;
  423. display: inline-block;
  424. margin-bottom: 30rpx;
  425. .user-avatar {
  426. width: 180rpx;
  427. height: 180rpx;
  428. border-radius: 50%;
  429. }
  430. .edit-avatar-icon {
  431. position: absolute;
  432. bottom: 10rpx;
  433. right: 10rpx;
  434. width: 48rpx;
  435. height: 48rpx;
  436. background: #fff;
  437. border-radius: 50%;
  438. display: flex;
  439. align-items: center;
  440. justify-content: center;
  441. box-shadow: 0 2rpx 8rpx rgba(0,0,0,0.1);
  442. }
  443. }
  444. .user-name {
  445. color: rgba(21, 21, 23, 1);
  446. font-family: DM Sans;
  447. font-size: 24px;
  448. font-weight: 700;
  449. line-height: 26px;
  450. letter-spacing: 0%;
  451. text-align: center;
  452. }
  453. .user-info {
  454. color: rgba(102, 112, 122, 1);
  455. font-family: DM Sans;
  456. font-size: 28rpx;
  457. line-height: 44rpx;
  458. font-weight: 400;
  459. letter-spacing: 0%;
  460. text-align: center;
  461. margin: 30rpx auto;
  462. }
  463. .contact-info {
  464. display: flex;
  465. justify-content: center;
  466. gap: 40rpx;
  467. margin-bottom: 30rpx;
  468. .contact-item {
  469. display: flex;
  470. align-items: center;
  471. gap: 10rpx;
  472. .contact-text {
  473. color: rgba(116, 116, 116, 1);
  474. font-family: DM Sans;
  475. font-size: 16rpx;
  476. font-weight: 400;
  477. line-height: 20rpx;
  478. letter-spacing: 0%;
  479. text-align: center;
  480. }
  481. }
  482. }
  483. .availability {
  484. display: flex;
  485. align-items: center;
  486. justify-content: center;
  487. gap: 10rpx;
  488. .status-text {
  489. color: rgba(156, 164, 171, 1);
  490. font-family: DM Sans;
  491. font-size: 24rpx;
  492. font-weight: 400;
  493. line-height: 32rpx;
  494. letter-spacing: 0%;
  495. text-align: left;
  496. }
  497. .status-dot {
  498. width: 18rpx;
  499. height: 18rpx;
  500. background: rgba(0, 204, 154, 1);
  501. border-radius: 50%;
  502. }
  503. }
  504. }
  505. // 内容区域
  506. .content-section {
  507. // background: #F2F6FC;
  508. padding: 30rpx;
  509. // 开关部分样式
  510. .switch-section {
  511. display: flex;
  512. align-items: center;
  513. justify-content: space-between;
  514. background: #fff;
  515. border-radius: 12rpx;
  516. padding: 24rpx;
  517. margin-bottom: 16rpx;
  518. .switch-left {
  519. flex: 1;
  520. .switch-title {
  521. color: rgba(21, 22, 26, 1);
  522. font-family: DM Sans;
  523. font-size: 28rpx;
  524. font-weight: 500;
  525. line-height: 52rpx;
  526. letter-spacing: 0%;
  527. text-align: left;
  528. margin-bottom: 12rpx;
  529. }
  530. .template-text {
  531. color: rgba(153, 153, 153, 1);
  532. font-family: DM Sans;
  533. font-size: 20rpx;
  534. font-weight: 400;
  535. line-height: 52rpx;
  536. letter-spacing: 0%;
  537. text-align: right;
  538. }
  539. .section-status {
  540. color: rgba(1, 107, 246, 1);
  541. font-family: DM Sans;
  542. font-size: 24rpx;
  543. font-weight: 400;
  544. line-height: 40rpx;
  545. letter-spacing: 0%;
  546. text-align: left;
  547. }
  548. }
  549. }
  550. .section-item {
  551. background: #fff;
  552. border-radius: 16rpx;
  553. padding: 30rpx;
  554. margin-bottom: 20rpx;
  555. box-sizing: border-box;
  556. border: 1px solid rgba(227, 231, 236, 1);
  557. border-radius: 12px;
  558. .section-header {
  559. display: flex;
  560. align-items: center;
  561. justify-content: space-between;
  562. margin-bottom: 20rpx;
  563. .section-title {
  564. color: rgba(23, 23, 37, 1);
  565. font-family: Inter;
  566. font-size: 32rpx;
  567. font-weight: 600;
  568. line-height: 48rpx;
  569. letter-spacing: 0%;
  570. text-align: left;
  571. }
  572. .template-text {
  573. color: rgba(120, 130, 138, 1);
  574. font-family: DM Sans;
  575. font-size: 24rpx;
  576. font-weight: 400;
  577. line-height: 32rpx;
  578. letter-spacing: 0%;
  579. text-align: left;
  580. }
  581. .edit-icon {
  582. width: 40rpx;
  583. height: 40rpx;
  584. display: flex;
  585. align-items: center;
  586. justify-content: center;
  587. }
  588. }
  589. .section-status {
  590. font-size: 28rpx;
  591. color: #007AFF;
  592. font-weight: 500;
  593. }
  594. .advantage-content {
  595. font-size: 14px;
  596. color: #666;
  597. line-height: 1.6;
  598. }
  599. }
  600. // 全职期望卡片样式
  601. .expectation-card {
  602. background: #ffffff;
  603. border-radius: 12rpx;
  604. padding: 30rpx;
  605. margin-bottom: 20rpx;
  606. box-sizing: border-box;
  607. border: 0.5px solid rgba(227, 231, 236, 1);
  608. border-radius: 6px;
  609. background: rgba(253, 253, 253, 1);
  610. .card-header {
  611. display: flex;
  612. justify-content: space-between;
  613. align-items: center;
  614. .header-left {
  615. display: flex;
  616. align-items: center;
  617. .header-icon {
  618. width: 40rpx;
  619. height: 40rpx;
  620. margin-right: 20rpx;
  621. }
  622. .header-title {
  623. color: rgba(29, 33, 41, 1);
  624. font-family: DM Sans;
  625. font-size: 28rpx;
  626. font-weight: 500;
  627. line-height: 16px;
  628. letter-spacing: 0%;
  629. text-align: left;
  630. }
  631. }
  632. .progress-text {
  633. font-family: DM Sans;
  634. font-size: 24rpx;
  635. font-weight: 700;
  636. line-height: 13px;
  637. letter-spacing: 0%;
  638. text-align: right;
  639. }
  640. }
  641. .job-list {
  642. margin-bottom: 10rpx;
  643. .job-item {
  644. display: flex;
  645. justify-content: space-between;
  646. align-items: center;
  647. padding: 20rpx 0;
  648. &:last-child {
  649. border-bottom: none;
  650. }
  651. .job-info {
  652. flex: 1;
  653. > view:first-child {
  654. display: flex;
  655. justify-content: space-between;
  656. align-items: center;
  657. margin-bottom: 4rpx;
  658. }
  659. .job-title {
  660. color: rgba(29, 33, 41, 1);
  661. font-family: DM Sans;
  662. font-size: 28rpx;
  663. font-weight: 500;
  664. line-height: 16px;
  665. letter-spacing: 0%;
  666. text-align: left;
  667. }
  668. .job-details {
  669. display: block;
  670. font-size: 24rpx;
  671. color: rgba(153, 153, 153, 1);
  672. margin-bottom: 4rpx;
  673. }
  674. .job-location {
  675. font-size: 24rpx;
  676. color: rgba(153, 153, 153, 1);
  677. }
  678. }
  679. .preference-btn {
  680. display: flex;
  681. align-items: center;
  682. padding: 8rpx;
  683. border: 0.5rpx solid #007AFF;
  684. border-radius: 12rpx;
  685. margin-right: 10rpx;
  686. text {
  687. font-size: 18rpx;
  688. color: #007AFF;
  689. }
  690. }
  691. .job-info > view:first-child > view:last-child {
  692. display: flex;
  693. align-items: center;
  694. }
  695. }
  696. }
  697. .add-expectation-btn {
  698. width: 100%;
  699. height: 70rpx;
  700. border: 1rpx solid #007AFF;
  701. border-radius: 42rpx;
  702. display: flex;
  703. align-items: center;
  704. justify-content: center;
  705. text {
  706. font-size: 28rpx;
  707. color: #007AFF;
  708. font-weight: 500;
  709. }
  710. }
  711. }
  712. // 工作经历部分样式
  713. .work-experience-section {
  714. background: #fff;
  715. border-radius: 12px;
  716. padding: 30rpx;
  717. margin-bottom: 20rpx;
  718. box-sizing: border-box;
  719. border: 1px solid rgba(1, 107, 246, 1);
  720. .section-header {
  721. display: flex;
  722. align-items: center;
  723. justify-content: space-between;
  724. margin-bottom: 30rpx;
  725. .section-title {
  726. display: flex;
  727. align-items: center;
  728. .required-mark {
  729. color: #FF3B30;
  730. font-size: 18px;
  731. font-weight: 600;
  732. margin-right: 8rpx;
  733. }
  734. .required-title {
  735. font-family: DM Sans;
  736. font-size: 28rpx;
  737. font-weight: 700;
  738. line-height: 52rpx;
  739. letter-spacing: 0%;
  740. text-align: left;
  741. margin-right: 12rpx;
  742. }
  743. text {
  744. color: rgba(23, 23, 37, 1);
  745. font-family: Inter;
  746. font-size: 20px;
  747. font-weight: 600;
  748. line-height: 24px;
  749. }
  750. }
  751. .section-desc {
  752. color: rgba(1, 107, 246, 1);
  753. font-family: DM Sans;
  754. font-size: 20rpx;
  755. font-weight: 400;
  756. line-height: 44rpx;
  757. letter-spacing: 0%;
  758. text-align: left;
  759. }
  760. }
  761. .experience-list {
  762. .experience-item {
  763. display: flex;
  764. padding: 24rpx 0;
  765. border-bottom: 1rpx solid #F0F0F0;
  766. &:last-child {
  767. border-bottom: none;
  768. }
  769. .company-logo {
  770. width: 90rpx;
  771. height: 90rpx;
  772. margin-right: 24rpx;
  773. flex-shrink: 0;
  774. border-radius: 8px;
  775. background: rgba(246, 246, 246, 1);
  776. .logo-img {
  777. width: 100%;
  778. height: 100%;
  779. border-radius: 8rpx;
  780. }
  781. }
  782. .experience-content {
  783. flex: 1;
  784. .job-info-row {
  785. display: flex;
  786. align-items: center;
  787. margin-bottom: 4rpx;
  788. }
  789. .job-title {
  790. color: rgba(23, 23, 37, 1);
  791. font-family: DM Sans;
  792. font-size: 28rpx;
  793. font-weight: 400;
  794. line-height: 44rpx;
  795. letter-spacing: 0%;
  796. text-align: left;
  797. margin-right: 12rpx;
  798. }
  799. .job-department {
  800. color: rgba(120, 130, 138, 1);
  801. font-family: DM Sans;
  802. font-size: 20rpx;
  803. font-weight: 400;
  804. line-height: 44rpx;
  805. letter-spacing: 0%;
  806. text-align: left;
  807. }
  808. .company-period-row {
  809. display: flex;
  810. align-items: center;
  811. justify-content: flex-start;
  812. margin-bottom: 12rpx;
  813. gap: 12rpx;
  814. padding: 12rpx 0;
  815. }
  816. .company-name {
  817. color: rgba(120, 130, 138, 1);
  818. font-family: DM Sans;
  819. font-size: 20rpx;
  820. font-weight: 400;
  821. line-height: 10px;
  822. letter-spacing: 0.5%;
  823. text-align: left;
  824. }
  825. .work-period {
  826. color: rgba(120, 130, 138, 1);
  827. font-family: DM Sans;
  828. font-size: 20rpx;
  829. font-weight: 400;
  830. line-height: 10px;
  831. letter-spacing: 0.5%;
  832. text-align: left;
  833. }
  834. .job-description {
  835. color: rgba(120, 130, 138, 1);
  836. font-family: DM Sans;
  837. font-size: 16rpx;
  838. font-weight: 400;
  839. line-height: 24rpx;
  840. letter-spacing: 0%;
  841. text-align: left;
  842. }
  843. .skill-tags {
  844. display: flex;
  845. flex-wrap: wrap;
  846. gap: 8rpx;
  847. margin-top: 12rpx;
  848. .tag {
  849. background: rgba(153, 153, 153, 0.1);
  850. border-radius: 12rpx;
  851. padding: 6rpx;
  852. color: rgba(102, 102, 102, 1);
  853. font-family: DM Sans;
  854. font-size: 16rpx;
  855. font-weight: 400;
  856. letter-spacing: 0%;
  857. text-align: left;
  858. }
  859. }
  860. }
  861. }
  862. }
  863. }
  864. // 教育经历部分样式
  865. .education-section {
  866. background: #fff;
  867. border-radius: 12px;
  868. padding: 30rpx;
  869. margin-bottom: 20rpx;
  870. box-sizing: border-box;
  871. border: 1px solid rgba(227, 231, 236, 1);
  872. .section-header {
  873. display: flex;
  874. align-items: center;
  875. justify-content: space-between;
  876. margin-bottom: 30rpx;
  877. .section-title {
  878. text {
  879. color: rgba(23, 23, 37, 1);
  880. font-family: Inter;
  881. font-size: 20px;
  882. font-weight: 600;
  883. line-height: 24px;
  884. }
  885. }
  886. }
  887. .education-list {
  888. .education-item {
  889. display: flex;
  890. padding: 24rpx 0;
  891. border-bottom: 1rpx solid #F0F0F0;
  892. &:last-child {
  893. border-bottom: none;
  894. }
  895. .school-logo {
  896. width: 90rpx;
  897. height: 90rpx;
  898. margin-right: 24rpx;
  899. flex-shrink: 0;
  900. border-radius: 8px;
  901. background: rgba(246, 246, 246, 1);
  902. .logo-img {
  903. width: 100%;
  904. height: 100%;
  905. border-radius: 8rpx;
  906. }
  907. }
  908. .education-content {
  909. flex: 1;
  910. .school-name {
  911. color: rgba(23, 23, 37, 1);
  912. font-family: DM Sans;
  913. font-size: 18px;
  914. font-weight: 400;
  915. line-height: 22px;
  916. letter-spacing: 0%;
  917. text-align: left;
  918. }
  919. .degree-info {
  920. color: rgba(120, 130, 138, 1);
  921. font-family: DM Sans;
  922. font-size: 20rpx;
  923. font-weight: 500;
  924. line-height: 24px;
  925. letter-spacing: 0%;
  926. text-align: left;
  927. padding: 12rpx 0;
  928. }
  929. .education-description {
  930. color: rgba(120, 130, 138, 1);
  931. font-family: DM Sans;
  932. font-size: 20rpx;
  933. font-weight: 400;
  934. line-height: 16px;
  935. letter-spacing: 0%;
  936. text-align: left;
  937. }
  938. }
  939. }
  940. }
  941. }
  942. // 技能部分样式
  943. .skills-section {
  944. background: #fff;
  945. border-radius: 12px;
  946. padding: 30rpx;
  947. margin-bottom: 20rpx;
  948. box-sizing: border-box;
  949. border: 1px solid rgba(227, 231, 236, 1);
  950. .section-header {
  951. display: flex;
  952. align-items: center;
  953. justify-content: space-between;
  954. margin-bottom: 30rpx;
  955. .section-title {
  956. text {
  957. color: rgba(23, 23, 37, 1);
  958. font-family: Inter;
  959. font-size: 20px;
  960. font-weight: 600;
  961. line-height: 24px;
  962. }
  963. }
  964. }
  965. .skills-grid {
  966. display: flex;
  967. flex-wrap: wrap;
  968. gap: 16rpx;
  969. .skill-tag {
  970. padding: 32rpx;
  971. border: 1px solid rgba(236, 241, 246, 1);
  972. border-radius: 64rpx;
  973. color: rgba(23, 23, 37, 1);
  974. font-family: DM Sans;
  975. font-size: 14px;
  976. font-weight: 400;
  977. line-height: 20px;
  978. letter-spacing: 0.5%;
  979. text-align: right;
  980. }
  981. }
  982. }
  983. }
  984. </style>