driverMsg-add-or-update.vue 8.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246
  1. <template>
  2. <el-dialog
  3. :title="!dataForm.id ? '新增' : '修改'"
  4. :close-on-click-modal="false"
  5. :visible.sync="visible" width="70%">
  6. <el-form :model="dataFormD" :rules="dataRule" ref="dataForm" @keyup.enter.native="dataFormSubmit()" label-width="200px">
  7. <el-form-item label="驾驶员所属公司" prop="fleetCompanyId">
  8. <el-select v-model="dataFormD.fleetCompanyId" placeholder="请选择">
  9. <el-option
  10. v-for="item in optionsProjectTypeItem"
  11. :key="item.id"
  12. :label="item.companyName"
  13. :value="item.id">
  14. </el-option>
  15. </el-select>
  16. </el-form-item>
  17. <el-form-item label="驾驶员姓名" prop="name">
  18. <el-input v-model="dataFormD.name" placeholder="驾驶员姓名"></el-input>
  19. </el-form-item>
  20. <el-form-item label="性别" prop="sex">
  21. <!-- <el-input v-model="dataForm.sex" placeholder="性别(0男/1女)"></el-input>-->
  22. <el-radio-group style="margin-left: 20px;" v-model="dataFormD.sex">
  23. <el-radio :label="0">男</el-radio>
  24. <el-radio :label="1">女</el-radio>
  25. </el-radio-group>
  26. </el-form-item>
  27. <el-form-item label="出生日期" prop="birthday">
  28. <!-- <el-input v-model="dataForm.birthday" placeholder="出生日期"></el-input>-->
  29. <el-date-picker
  30. style="width: 100%"
  31. value-format="yyyy-MM-dd HH:mm:ss"
  32. v-model="dataFormD.birthday"
  33. type="date"
  34. placeholder="出生日期">
  35. </el-date-picker>
  36. </el-form-item>
  37. <el-form-item label="准驾车型" prop="allowDriverCar">
  38. <el-input v-model="dataFormD.allowDriverCar" placeholder="准驾车型"></el-input>
  39. </el-form-item>
  40. <el-form-item label="初次领证日期" prop="firstCertificateDate">
  41. <!-- <el-input v-model="dataForm.firstCertificateDate" placeholder="初次领证日期"></el-input>-->
  42. <el-date-picker
  43. style="width: 100%"
  44. value-format="yyyy-MM-dd HH:mm:ss"
  45. v-model="dataFormD.firstCertificateDate"
  46. type="date"
  47. placeholder="初次领证日期">
  48. </el-date-picker>
  49. </el-form-item>
  50. <el-form-item label="身份证号" prop="idcarNum">
  51. <el-input v-model="dataFormD.idcarNum" placeholder="身份证号"></el-input>
  52. </el-form-item>
  53. <el-form-item label="联系电话" prop="tel">
  54. <el-input v-model="dataFormD.tel" placeholder="联系电话"></el-input>
  55. </el-form-item>
  56. <el-form-item label="家庭住址" prop="address">
  57. <el-input v-model="dataFormD.address" placeholder="家庭住址"></el-input>
  58. </el-form-item>
  59. <br>
  60. <el-form-item label="个人照片" prop="resumePic">
  61. <el-upload
  62. style="width: 300px"
  63. :action="uploadImgUrl"
  64. :before-remove="beforeRemove"
  65. :on-remove="(res,file)=>{handleRemove(2,res,file)}"
  66. :on-success="(res,file)=>{handleSuccess(1,res,file)}"
  67. multiple
  68. :limit="1"
  69. :headers="headers"
  70. :on-exceed="handleExceed">
  71. <el-button size="small" type="primary">点击上传</el-button>
  72. <el-button size="small" type="primary" v-if="dataFormD.resumePic" @click="preview(1)">预览</el-button>
  73. </el-upload>
  74. </el-form-item>
  75. <el-form-item label="驾驶证照片" prop="drivingPic">
  76. <el-upload
  77. style="width: 300px"
  78. :action="uploadImgUrl"
  79. :before-remove="beforeRemove"
  80. :on-remove="(res,file)=>{handleRemove(2,res,file)}"
  81. :on-success="(res,file)=>{handleSuccess(2,res,file)}"
  82. multiple
  83. :limit="1"
  84. :headers="headers"
  85. :on-exceed="handleExceed">
  86. <el-button size="small" type="primary">点击上传</el-button>
  87. <el-button size="small" type="primary" v-if="dataFormD.drivingPic" @click="preview(2)">预览</el-button>
  88. </el-upload>
  89. </el-form-item>
  90. </el-form>
  91. <span slot="footer" class="dialog-footer">
  92. <el-button @click="visible = false">取消</el-button>
  93. <el-button type="primary" @click="dataFormSubmit()">确定</el-button>
  94. </span>
  95. </el-dialog>
  96. </template>
  97. <script>
  98. import { company, lookOver, preservation } from '@/api/fleet/driverMsg'
  99. import { getToken } from '@/utils/auth'
  100. export default {
  101. props: {
  102. dataForm: {
  103. type: Object,
  104. require: false
  105. }
  106. },
  107. data () {
  108. return {
  109. visible: false,
  110. dataFormD:{},
  111. uploadImgUrl: process.env.VUE_APP_BASE_API + '/common/upload', // 上传的图片服务器地址
  112. headers: {
  113. Authorization: 'Bearer ' + getToken()
  114. },
  115. dataRule: {
  116. fleetCompanyId: [
  117. {required: true, message: '请选择驾驶员所属公司id', trigger: 'blur'}
  118. ],
  119. name: [
  120. {required: true, message: '请输入驾驶员姓名', trigger: 'blur'}
  121. ],
  122. idcarNum: [
  123. {required: true, message: '请输入身份证号', trigger: 'blur'}
  124. ],
  125. tel: [
  126. {required: true, message: '请输入联系电话', trigger: 'blur'}
  127. ]
  128. },
  129. optionsProjectTypeItem: [],
  130. fileList: [],
  131. uploadHeaders: {
  132. // localStorage.setItem('token', data.token)
  133. token: localStorage.getItem('token')
  134. },
  135. uploadURL: 'http://test.echepei.com/api/admin/fleet/carManage/uplodaImgForDrivingLicense'
  136. }
  137. },
  138. methods: {
  139. preview(actid){
  140. if (actid === 1){
  141. window.open(this.dataFormD.resumePic)
  142. }else {
  143. window.open(this.dataFormD.drivingPic)
  144. }
  145. },
  146. handlePreview(file) {
  147. this.$message.success('如需预览请点击预览');
  148. },
  149. handleExceed(files, fileList) {
  150. this.$message.warning(`当前限制选择 1 个文件件`);
  151. },
  152. beforeRemove(file, fileList) {
  153. return this.$confirm(`确定移除 ${ file.name }?`);
  154. },
  155. init () {
  156. this.visible = true
  157. this.needCondition()
  158. console.log(this.dataForm)
  159. if (this.dataForm.id) {
  160. lookOver(this.dataForm.id).then(data => {
  161. console.log(data)
  162. this.dataFormD = data.data
  163. this.fTmsorderbillsattachs = data.data.fTmsorderbillsattachs
  164. this.optionsProjectTypeItem = data.data.fleetCompanyMsg
  165. if (data.data.fleetCompanyMsg){
  166. this.handleSelect()
  167. }
  168. })
  169. }else {
  170. this.dataFormD = {}
  171. }
  172. },
  173. // 获取下拉选项
  174. needCondition () {
  175. company().then(data => {
  176. console.log(data)
  177. if (data && data.code === 200) {
  178. this.optionsProjectTypeItem = data.rows
  179. } else {
  180. this.$message.error(data.msg)
  181. }
  182. })
  183. },
  184. // 图片上传回调
  185. handleSuccess (response,res,file) {
  186. console.log(response)
  187. if (response === 2){
  188. console.log("22222")
  189. this.dataFormD.drivingPic = res.url
  190. console.log(this.dataFormD.drivingPic)
  191. }else {
  192. console.log("11111")
  193. this.dataFormD.resumePic = res.url
  194. }
  195. },
  196. // 文件列表移除文件时的钩子
  197. handleRemove (actid,file, fileList) {
  198. if (actid === 1){
  199. this.dataForm.resumePic = ''
  200. }else {
  201. this.dataForm.drivingPic = ''
  202. }
  203. },
  204. // 表单提交
  205. dataFormSubmit () {
  206. console.log(this.dataFormD)
  207. this.$refs['dataForm'].validate((valid) => {
  208. if (valid) {
  209. preservation(this.dataFormD).then(data=>{
  210. if (data && data.code === 200) {
  211. this.$message({
  212. message: '操作成功',
  213. type: 'success',
  214. duration: 1500,
  215. onClose: () => {
  216. this.visible = false
  217. this.$emit('refreshDataList')
  218. }
  219. })
  220. } else {
  221. this.$message.error(data.msg)
  222. }
  223. })
  224. }
  225. })
  226. }
  227. }
  228. }
  229. </script>
  230. <style scoped>
  231. .el-form-item {
  232. width: 49%;
  233. margin-bottom: 20px;
  234. display: inline-block;
  235. }
  236. .el-select {
  237. display: block;
  238. }
  239. .upload-demo {
  240. margin-left: 50px;
  241. }
  242. </style>