edit.vue 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412
  1. <template>
  2. <div>
  3. <el-button type="default" size="mini" @click="onShow">{{$t('编 辑')}}</el-button>
  4. <el-drawer :title="$t(`编辑员工`)" direction="rtl" append-to-body :visible.sync="dialogFormVisible" size="800px" @close="$refs.form.clearValidate()" :show-close="false">
  5. <div class="drawer__panel">
  6. <el-row :gutter="20">
  7. <el-form :model="form" size="small" :rules="rules" ref="form" label-position="right" :label-width="tool.onlyZh('100px')">
  8. <el-row>
  9. <el-col :span="24">
  10. <el-form-item :label="$t(`编号`)+':'" prop="hrcode">
  11. <el-input v-model="form.hrcode" :placeholder="$t(`编号`)" autocomplete="off"></el-input>
  12. </el-form-item>
  13. </el-col>
  14. <el-col :span="24">
  15. <el-form-item :label="$t(`性别`)">
  16. <el-select v-model="form.sex" style="width:100%" :placeholder="$t('请选择')">
  17. <el-option
  18. v-for="item in sys_options"
  19. :key="item.index"
  20. :label="$t(item.value)"
  21. :value="item.value">
  22. </el-option>
  23. </el-select>
  24. </el-form-item>
  25. </el-col>
  26. <el-col :span="24">
  27. <el-form-item :label="$t(`姓名`)+':'" prop="name">
  28. <el-input v-model="form.name" :placeholder="$t(`姓名`)" autocomplete="off"></el-input>
  29. </el-form-item>
  30. </el-col>
  31. <el-col :span="24">
  32. <el-form-item :label="$t(`电子邮箱`)+':'" prop="email">
  33. <el-input v-model="form.email" :placeholder="$t(`电子邮箱`)" autocomplete="off"></el-input>
  34. </el-form-item>
  35. </el-col>
  36. <el-col :span="24">
  37. <el-form-item :label="$t(`身份证号`)+':'">
  38. <el-input v-model="form.idcard" :placeholder="$t(`身份证号`)" autocomplete="off"></el-input>
  39. </el-form-item>
  40. </el-col>
  41. <el-col :span="24">
  42. <el-form-item :label="$t(`部门`)+':'" prop="depname">
  43. <el-popover
  44. placement="bottom"
  45. width="400"
  46. trigger="click"
  47. v-model="visible">
  48. <el-tree
  49. :data="deplist"
  50. node-key="id"
  51. default-expand-all
  52. highlight-current
  53. :expand-on-click-node="false"
  54. @node-click="nodeClick"
  55. >
  56. <span class="custom-tree-node" slot-scope="{ node, data }">
  57. <span>{{ node.label }}</span>
  58. </span>
  59. </el-tree>
  60. <el-input slot="reference" v-model="form.depname" readonly :placeholder="$t('请选择')" autocomplete="off"></el-input>
  61. </el-popover>
  62. </el-form-item>
  63. </el-col>
  64. <el-col :span="24">
  65. <el-form-item :label="$t(`办公电话`)+':'">
  66. <el-input v-model="form.officetelephone" :placeholder="$t(`办公电话`)" autocomplete="off"></el-input>
  67. </el-form-item>
  68. </el-col>
  69. <el-col :span="24">
  70. <el-form-item :label="$t(`职位`)+':'">
  71. <el-input v-model="form.position" :placeholder="$t(`职位`)" autocomplete="off"></el-input>
  72. </el-form-item>
  73. </el-col>
  74. <el-col :span="24">
  75. <el-form-item :label="$t(`汇报对象`)+':'">
  76. <selectMenber :reporthrname="form.reporthrname" @selectMenber="selectMenber" @clearMenber="form.reporthrname = '';form.reporthrid = ''"></selectMenber>
  77. </el-form-item>
  78. </el-col>
  79. <el-col :span="24" >
  80. <el-form-item :label="$t(`状态`)+':'">
  81. <el-radio-group v-model="form.status">
  82. <el-radio :label="0">{{ $t('在职') }}</el-radio>
  83. <el-radio :label="1">{{ $t('离职') }}</el-radio>
  84. </el-radio-group>
  85. </el-form-item>
  86. </el-col>
  87. </el-row>
  88. <el-row>
  89. <el-col :span="5" style="height:51px">
  90. <el-form-item>
  91. <el-checkbox v-model="form.isleader" :false-label="0" :true-label="1">{{ $t('是否部门负责人') }}</el-checkbox>
  92. </el-form-item>
  93. </el-col>
  94. <el-col :span="5">
  95. <el-form-item>
  96. <el-checkbox v-model="form.isworker" :false-label="0" :true-label="1">{{ $t('是否服务人员') }}</el-checkbox>
  97. </el-form-item>
  98. </el-col>
  99. <el-col :span="5">
  100. <el-form-item>
  101. <el-checkbox v-model="form.isuppictured" :false-label="0" :true-label="1">{{ $t('是否上图员') }}</el-checkbox>
  102. </el-form-item>
  103. </el-col>
  104. <el-col :span="5">
  105. <el-form-item>
  106. <el-checkbox v-model="form.issalehr" :false-label="0" :true-label="1" disabled>{{ $t('是否业务员') }}</el-checkbox>
  107. </el-form-item>
  108. </el-col>
  109. </el-row>
  110. <el-row v-if="form.issalehr == '1'">
  111. <el-col :span="24">
  112. <el-form-item :label="$t('业务员')" style="font-weight: bold">
  113. <addSalers :name="form.name" @salerInfo="salerInfo" :data="salerList"></addSalers>
  114. </el-form-item>
  115. </el-col>
  116. </el-row>
  117. <el-row v-if="form.issalehr == '1'">
  118. <el-col :span="23" :offset="1">
  119. <tableNewLayout :layout="tablecols" :data="salerList" :opwidth="200" height="450px" :width="true" :custom="true" fixedName="operation">
  120. <template v-slot:customcol="scope">
  121. <p v-if="scope.column.columnname == 'iseditprice '">
  122. {{scope.column.data.iseditprice == '1' ? $t('是'):$t('否') }}
  123. </p>
  124. <p v-else>{{$t(scope.column.data[scope.column.columnname])}}</p>
  125. </template>
  126. <template v-slot:opreation="scope">
  127. <el-button type="text" disabled>{{$t('删 除')}}</el-button>
  128. </template>
  129. </tableNewLayout>
  130. </el-col>
  131. </el-row>
  132. </el-form>
  133. </el-row>
  134. </div>
  135. <div class="fixed__btn__panel">
  136. <el-button size="small" @click="dialogFormVisible = false" class="normal-btn-width">{{$t('取 消')}}</el-button>
  137. <el-button size="small" type="primary" @click="onSubmit" class="normal-btn-width">{{$t('确 定')}}</el-button>
  138. </div>
  139. </el-drawer>
  140. </div>
  141. </template>
  142. <script>
  143. import {mapGetters} from 'vuex'
  144. import selectMenber from '@/components/selectMenber/index.vue'
  145. import areaList from "@/HManagement/marketing2/saler/area/modules/areaList";
  146. import addSalers from "@/HManagement/department/staff/list/modules/addSalers";
  147. export default {
  148. components:{
  149. selectMenber,
  150. areaList,
  151. addSalers
  152. },
  153. computed:{
  154. ...mapGetters({
  155. sys_options:'sys_options'
  156. })
  157. },
  158. data () {
  159. return {
  160. dialogFormVisible:false,
  161. visible:false,
  162. rules:{
  163. hrcode: [
  164. { required: true, message: this.$t('请输入员工编码'), trigger: 'blur' },
  165. ],
  166. name: [
  167. { required: true, message: this.$t('请输入员工姓名'), trigger: 'blur' },
  168. ],
  169. depname: [
  170. { required: true, message: this.$t('请选择部门'), trigger: 'change' },
  171. ],
  172. tradefield: [
  173. { required: true, message: this.$t('请选择报备领域'), trigger: 'blur,change' },
  174. ],
  175. phonenumber: [
  176. { required: true, message: this.$t('请输入员工电话'), trigger: 'blur' },
  177. { pattern:/^1[3-9]\d{9}$/, message: this.$t('请输入正确手机号码'),trigger: 'blur' }
  178. ],
  179. email:[
  180. { pattern:/^\w+([-+.]\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*$/, message: this.$t('请输入正确邮箱'),trigger: 'blur' }
  181. ],
  182. discountrate: [
  183. { required: true, message: this.$t('请输入最低授权折扣'), trigger: 'blur' },
  184. { pattern:/^[0-9]+\.{0,1}[0-9]{0,2}$/,message: this.$t('只能输入数值'),trigger: 'blur'},
  185. ],
  186. },
  187. form:{
  188. "hrid":0,
  189. "hrcode":"",
  190. "name":"",
  191. "sex":0,
  192. "phonenumber":"",
  193. "officetelephone":"",
  194. "idcard":"",
  195. "email":"",
  196. "birthday":"",
  197. "remarks":"",
  198. "departmentid":"",
  199. "isleader":"",
  200. "position":"",
  201. "reporthrid":"",
  202. "userid":"0",
  203. "statue":0,
  204. 'isuppictured':'0',
  205. 'reporthrname':'',
  206. 'issalehr':'0',
  207. "salearea": []
  208. },
  209. value:[],
  210. deplist:[],
  211. pointValue:'',
  212. issalehr:'',
  213. tradefields:[],
  214. tablecols:[],
  215. list:[],
  216. salerList:[]
  217. }
  218. },
  219. methods:{
  220. async query_hrMain () {
  221. const res = await this.$api.requested({
  222. "classname": "webmanage.hr.hr",
  223. "method": "query_hrMain",
  224. "content": {
  225. "hrid":this.$route.query.id
  226. }
  227. })
  228. this.form = Object.assign({},this.form, res.data)
  229. /*this.form.discountrate = Math.round((this.form.discountrate*100)*100)/100*/
  230. this.issalehr = this.form.issalehr
  231. this.salerList = res.data.salearea.map(item=>{
  232. return {
  233. "name":this.form.name,
  234. "areaname":item.areaname,
  235. "discountrate":Math.round((item.discountrate * 100)*100)/100,
  236. "iseditprice":item.iseditprice,
  237. "sa_saleareaid":item.sa_saleareaid
  238. }
  239. })
  240. },
  241. areaLists(val){
  242. if (this.form.areaname == ''){
  243. this.form.areaname = val[0].areaname
  244. this.form.sa_saleareaid = val[0].sa_saleareaid
  245. this.form.discountrate = ''
  246. }
  247. },
  248. async department () {
  249. const res = await this.$api.requested({
  250. "classname": "webmanage.department.department",
  251. "method": "querydepartment",
  252. "content": {
  253. }
  254. })
  255. // 数据格式转换成elementui-tree所需的格式
  256. this.deplist = this.createMenu(res.data)
  257. },
  258. createMenu (array) {
  259. var that = this
  260. let arr = []
  261. function convertToElementTree(node) {
  262. // 新节点
  263. var elNode = {
  264. label: node["depname"],
  265. parentid:node['parentid'],
  266. departmentid:node["departmentid"],
  267. value:node["departmentid"],
  268. remarks:node["remarks"],
  269. isused:node["isused"],
  270. changedate:node['changedate'],
  271. changeby:node['changeby'],
  272. createdate:node['createdate'],
  273. createby:node['createby'],
  274. depno:node['depno'],
  275. children: []
  276. }
  277. if (node.subdep && node.subdep.length > 0) {
  278. // 如果存在子节点
  279. for (var index = 0; index < node.subdep.length; index++) {
  280. // 遍历子节点, 把每个子节点看做一颗独立的树, 传入递归构造子树, 并把结果放回到新node的children中
  281. elNode.children.push(convertToElementTree(node.subdep[index]));
  282. }
  283. }
  284. return elNode;
  285. }
  286. array.forEach((element) => {
  287. arr.push(convertToElementTree(element))
  288. });
  289. return arr
  290. },
  291. onShow () {
  292. this.list = []
  293. this.salerList = []
  294. this.query_hrMain()
  295. this.department()
  296. this.$store.dispatch('optiontypeselect','tradefield').then(res=>{
  297. this.tradefields = res.data
  298. })
  299. this.$store.dispatch('optiontypeselect','sex')
  300. this.dialogFormVisible = true
  301. },
  302. selectDep (data) {
  303. let obj = {
  304. depname:data.label,
  305. departmentid:data.departmentid
  306. }
  307. this.form = Object.assign({},this.form,obj)
  308. this.showTree = !this.showTree
  309. this.issalehr = this.form.issalehr
  310. },
  311. onSubmit () {
  312. this.$refs['form'].validate(async (valid) => {
  313. if (!valid) return false;
  314. /*this.form.discountrate = (this.form.discountrate /100).toFixed(4)*/
  315. this.form.salearea = this.salerList.map(item=>{
  316. return {
  317. "sa_saleareaid": item.sa_saleareaid,
  318. "discountrate": (item.discountrate/100).toFixed(4),
  319. "iseditprice": item.iseditprice
  320. }
  321. })
  322. const res = await this.$api.requested({
  323. "classname": "webmanage.hr.hr",
  324. "method": "insertormodify_hr",
  325. "content": this.form
  326. })
  327. if (res.code === 0) return this.$notify({
  328. title: this.$t('失败'),
  329. message: res.msg,
  330. type: 'error'
  331. });
  332. this.$notify({
  333. title: this.$t('成功'),
  334. message: this.$t('编辑成功'),
  335. type: 'success'
  336. });
  337. this.dialogFormVisible = false
  338. this.$emit('onSuccess')
  339. });
  340. },
  341. // 监听汇报对象选择
  342. selectMenber (data) {
  343. this.form.reporthrid = data.hrid
  344. },
  345. nodeClick(val){
  346. this.pointValue = val.departmentid
  347. this.visible = false
  348. this.selectDep(val)
  349. },
  350. selectArea(val){
  351. this.form.areaname = val.label
  352. this.form.sa_saleareaid = val.sa_saleareaid
  353. },
  354. discountrateChange(val){
  355. if (val < 0){
  356. this.form.discountrate = 1
  357. }else if(val > 100){
  358. this.form.discountrate = 100
  359. }else {
  360. this.form.discountrate = Math.round(val * 100)/100
  361. }
  362. },
  363. salerInfo(val){
  364. console.log(val,'创建的任务')
  365. /* this.list.push(newList)*/
  366. this.list = this.salerList
  367. /*this.list.splice(-1,0,val)*/
  368. this.list.push(val)
  369. console.log(this.list,'list表格数据')
  370. this.salerList = []
  371. this.salerList = this.list.map(item=>{
  372. console.log(item.iseditprice)
  373. return {
  374. "name":this.form.name,
  375. "areaname":item.areaname,
  376. "discountrate":item.discountrate,
  377. "iseditprice":item.iseditprice,
  378. "sa_saleareaid":item.sa_saleareaid
  379. }
  380. })
  381. console.log(this.salerList,'salerList')
  382. }
  383. },
  384. created() {
  385. this.tablecols = this.tool.tabelCol(this.$route.name).salerTable.tablecols
  386. }
  387. }
  388. </script>
  389. <style>
  390. .custom-tree-node {
  391. flex: 1;
  392. display: flex;
  393. align-items: center;
  394. justify-content: space-between;
  395. font-size: 14px;
  396. padding-right: 8px;
  397. background: none;
  398. }
  399. </style>
  400. <style scoped>
  401. .mb-30{
  402. margin-bottom:12px
  403. }
  404. </style>