work.vue 8.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281
  1. <template>
  2. <view class="personal">
  3. <view class="body-input u-flex-col u-row-center" >
  4. <text class="input-title">公司名称</text>
  5. <u--input disabledColor="#fff" customStyle="padding:0 !important" type="text" placeholder="请填写您的公司名称" border
  6. placeholderClass='input-style' v-model="job_experience.company_name"></u--input>
  7. </view>
  8. <view class="body-input u-flex-col u-row-center" @click="tohangye">
  9. <text class="input-title">公司行业</text>
  10. <u--input :disabled="true" disabledColor="#fff" customStyle="padding:0 !important" type="text"
  11. placeholder="请选择您的公司行业" border placeholderClass='input-style' suffixIcon="arrow-right"
  12. suffixIconStyle="font-size: 32rpx;font-weight: 400;color: #CACACA;"
  13. v-model="job_experience.industry"></u--input>
  14. </view>
  15. <view class="body-input u-flex-col u-row-center">
  16. <text class="input-title">所属部门</text>
  17. <u--input disabledColor="#fff" customStyle="padding:0 !important" type="text" placeholder="请填写您的所属部门" border
  18. placeholderClass='input-style' v-model="job_experience.department"></u--input>
  19. </view>
  20. <view class="body-input u-flex-col u-row-center" >
  21. <text class="input-title">职位名称</text>
  22. <u--input disabledColor="#fff" customStyle="padding:0 !important" type="text"
  23. placeholder="请填写您的的职位名称" border placeholderClass='input-style'
  24. v-model="job_experience.job_name"></u--input>
  25. </view>
  26. <view class="body-input u-flex-col u-row-center">
  27. <text class="input-title">在职时间</text>
  28. <view class="u-flex u-row-between" style="margin-top: 20rpx;">
  29. <view class="" @click="entryShow = true">
  30. <u--input :disabled="true" disabledColor="#fff" customStyle="padding:0 !important" type="text"
  31. placeholder="入职时间" border placeholderClass='input-style'
  32. v-model="job_experience.start_time"></u--input>
  33. </view>
  34. <view class="">-</view>
  35. <view class="" @click="dimissionShow = true">
  36. <u--input :disabled="true" disabledColor="#fff" customStyle="padding:0 !important" type="text"
  37. placeholder="离职时间" inputAlign="center" border placeholderClass='input-style'
  38. v-model="job_experience.end_time"></u--input>
  39. </view>
  40. </view>
  41. </view>
  42. <view class="body-input u-flex-col u-row-center">
  43. <text class="input-title">离职原因</text>
  44. <u--input disabledColor="#fff" customStyle="padding:0 !important" type="text" placeholder="请填写您的离职原因" border
  45. placeholderClass='input-style'
  46. v-model="job_experience.level_reason"></u--input>
  47. </view>
  48. <view class="body-input u-flex-col u-row-center" >
  49. <text class="input-title">工作内容</text>
  50. <u--input disabledColor="#fff" customStyle="padding:0 !important" type="text"
  51. placeholder="请填写您的工作内容" border placeholderClass='input-style'
  52. v-model="job_experience.work_content"></u--input>
  53. </view>
  54. <view class="body-input u-flex-col u-row-center">
  55. <view class="">选填内容</view>
  56. <text class="input-title">下属人数</text>
  57. <u--input disabledColor="#fff" customStyle="padding:0 !important" type="text" placeholder="请填写(选填)" border
  58. placeholderClass='input-style' v-model="job_experience.underling_count"></u--input>
  59. </view>
  60. <view class="body-input u-flex-col u-row-center">
  61. <text class="input-title">汇报对象</text>
  62. <u--input disabledColor="#fff" customStyle="padding:0 !important" type="text"
  63. placeholder="请填写(选填)" border placeholderClass='input-style' v-model="job_experience.report_to"></u--input>
  64. </view>
  65. <view class="u-flex u-row-between">
  66. <view class="button1">
  67. 删除
  68. </view>
  69. <view class="button" @click="next">
  70. 保存
  71. </view>
  72. </view>
  73. <u-datetime-picker title="入职时间" :minDate="minDate1" @confirm="entryConfirm" :show="entryShow" mode="date"
  74. @cancel='entryShow = false'></u-datetime-picker>
  75. <u-datetime-picker title="离职时间" :minDate="minDate" @confirm="dimissionConfirm" :show="dimissionShow" mode="date"
  76. @cancel='dimissionShow = false'></u-datetime-picker>
  77. </view>
  78. </template>
  79. <script setup>
  80. import {
  81. get_category_industry
  82. } from "@/units/inquire.js"
  83. export default {
  84. data() {
  85. return {
  86. entryShow: false,
  87. dimissionShow: false,
  88. industryShow: false,
  89. minDate: "",
  90. minDate1: "",
  91. job_experience: {
  92. industry: "", //公司行业名称
  93. industry_id: "", //公司行业id
  94. company_name: "", //公司名称
  95. start_time: "", //在职时间
  96. end_time: "", //离职时间
  97. department: "", //所属部门
  98. job_name: "",//工作名称
  99. level_reason: "", //离职原因
  100. work_content: "", //工作内容
  101. underling_count:"",
  102. report_to:""
  103. }
  104. }
  105. },
  106. onLoad(opsition) {
  107. this.minDate = Number(new Date('2000-01-01'));
  108. this.minDate1 = Number(new Date('1980-01-01'));
  109. },
  110. methods: {
  111. getdata(item) {
  112. console.log(item);
  113. },
  114. tohangye() {
  115. uni.navigateTo({
  116. url: "../pagesA/change-hangye1",
  117. events: {
  118. changehangye: (res) => {
  119. this.job_experience.industry_first = res[0].id
  120. this.job_experience.industry_id = res[1].id
  121. this.job_experience.industry = res[1].name
  122. }
  123. }
  124. })
  125. },
  126. async entryConfirm(e) {
  127. const timeFormat = uni.$u.timeFormat;
  128. console.log(e.value);
  129. let timeValue = await timeFormat(e.value, 'yyyy-mm-dd');
  130. this.job_experience.start_time = timeValue;
  131. this.entryShow = false
  132. },
  133. async dimissionConfirm(e) {
  134. const timeFormat = uni.$u.timeFormat;
  135. let timeValue = await timeFormat(e.value, 'yyyy-mm-dd');
  136. this.job_experience.end_time = timeValue;
  137. this.dimissionShow = false
  138. },
  139. return1() {
  140. uni.navigateBack()
  141. },
  142. next(){
  143. if (!this.job_experience.company_name) {
  144. this.$u.toast("请填写公司名称")
  145. return
  146. }
  147. if (!this.job_experience.industry) {
  148. this.$u.toast("请选择您的公司行业")
  149. return
  150. }
  151. if (!this.job_experience.department) {
  152. this.$u.toast("请填写您的所属部门")
  153. return
  154. }
  155. if (!this.job_experience.job_name) {
  156. this.$u.toast("请填写您的职业名称")
  157. return
  158. }
  159. if (!this.job_experience.start_time) {
  160. this.$u.toast("请选择入职时间")
  161. return
  162. }
  163. if (!this.job_experience.end_time) {
  164. this.$u.toast("请选择离职时间")
  165. return
  166. }
  167. if (!this.job_experience.level_reason) {
  168. this.$u.toast("请填写离职原因")
  169. return
  170. }
  171. if (!this.job_experience.work_content) {
  172. this.$u.toast("请填写工作内容")
  173. return
  174. }
  175. let pre = "job_experience"
  176. let nObj = Object.keys(this.job_experience).reduce((a, c) => (a[`${pre}.${c}`] = this.job_experience[c],
  177. a), {});
  178. uni.setStorageSync("job_experience", nObj)
  179. console.log(this);
  180. const eventChannel = this.getOpenerEventChannel();
  181. eventChannel.emit('work', nObj);
  182. uni.navigateBack()
  183. }
  184. }
  185. }
  186. </script>
  187. <style lang="scss">
  188. .button1 {
  189. width: 256rpx;
  190. background: #F3F3F3;
  191. border-radius: 12rpx;
  192. margin-right: 24rpx;
  193. padding: 20rpx 50rpx;
  194. font-size: 32rpx;
  195. font-family: PingFangSC-Medium, PingFang SC;
  196. font-weight: 500;
  197. color: #333333;
  198. text-align: center;
  199. height: 88rpx !important;
  200. box-sizing: border-box;
  201. }
  202. .btn {
  203. background: #0C66C2;
  204. border-radius: 16rpx;
  205. font-size: 32rpx;
  206. font-family: PingFangSC-Regular, PingFang SC;
  207. font-weight: 400;
  208. color: #FFFFFF;
  209. width: 310rpx;
  210. height: 84rpx;
  211. line-height: 84rpx;
  212. text-align: center;
  213. margin-top: 24rpx;
  214. }
  215. //个人信息
  216. .personal {
  217. width: 750rpx;
  218. background: #FFFFFF;
  219. border-radius: 28rpx 28rpx 0rpx 0rpx;
  220. margin-top: -40rpx;
  221. position: relative;
  222. z-index: 99;
  223. padding: 40rpx 32rpx 0;
  224. margin-bottom: 60rpx;
  225. box-sizing: border-box;
  226. .title {
  227. font-size: 48rpx;
  228. font-family: PingFangSC-Medium, PingFang SC;
  229. font-weight: 500;
  230. color: #222222;
  231. }
  232. .titleb {
  233. font-size: 26rpx;
  234. font-family: PingFangSC-Regular, PingFang SC;
  235. font-weight: 400;
  236. color: #777777;
  237. margin-top: 20rpx;
  238. }
  239. .body-input {
  240. height: 150rpx;
  241. border-bottom: 2rpx solid #F4F4F4;
  242. .input-title {
  243. font-size: 26rpx;
  244. font-family: PingFangSC-Regular, PingFang SC;
  245. font-weight: 400;
  246. color: #888888;
  247. margin-top: 30rpx;
  248. box-sizing: border-box;
  249. }
  250. .input-style {
  251. font-size: 32rpx;
  252. font-family: PingFangSC-Regular, PingFang SC;
  253. font-weight: 400;
  254. color: #CACACA;
  255. }
  256. }
  257. .button {
  258. width: 686rpx;
  259. height: 88rpx !important;
  260. background: #0C66C2;
  261. border-radius: 12rpx;
  262. font-size: 32rpx;
  263. font-family: PingFangSC-Medium, PingFang SC;
  264. font-weight: 500;
  265. color: #FFFFFF;
  266. line-height: 88rpx;
  267. text-align: center;
  268. }
  269. }
  270. </style>