index.vue 8.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276
  1. <template>
  2. <div>
  3. <template-page v-if="!isShowMemberDetail" ref="pageRef" :get-list="getList" :table-attributes="tableAttributes" :table-events="tableEvents" :operationColumnWidth="200"
  4. :options-evens-group="optionsEvensGroup" :moreParameters="moreParameters" :column-parsing="columnParsing"
  5. :operation="operation()" :exportList="exportList">
  6. <el-dialog title="" width="500px" custom-class="diy-dialog" append-to-body :modal="true" :visible.sync="formDialog"
  7. :show-close="true" :close-on-click-modal="false" :modal-append-to-body="false" :before-close="formCancel">
  8. <zj-form-container ref="formRef" :form-data="formData" :styleSwitch="false">
  9. <zj-form-module :title="formDialogTitles[formDialogType]" label-width="100px" :showPackUp="false"
  10. :form-data="formData" :form-items="formItems">
  11. </zj-form-module>
  12. </zj-form-container>
  13. <div slot="footer" class="dialog-footer">
  14. <el-button size="mini" @click="formCancel">取 消</el-button>
  15. <el-button size="mini" @click="formConfirm" type="primary">确 定</el-button>
  16. </div>
  17. </el-dialog>
  18. <!-- 入驻网点 -->
  19. <el-dialog title="设为工程师" :visible.sync="dialogVisible" @close="websitList = []" width="40%" :close-on-click-modal="false" :modal-append-to-body="false">
  20. <el-form ref="workerForm" :model="workerForm" label-width="110px" size="small" label-position="left">
  21. <el-row :gutter="20">
  22. <el-col :span="24">
  23. <el-form-item label="入驻网点" :required="true">
  24. <el-select v-model="workerForm.websitId" placeholder="请选择" style="width: 100%;">
  25. <el-option
  26. v-for="item in websitList"
  27. :key="item.websitId"
  28. :label="item.name"
  29. :value="item.websitId">
  30. </el-option>
  31. </el-select>
  32. </el-form-item>
  33. </el-col>
  34. <el-col :span="24">
  35. <el-form-item label="姓名" :required="true">
  36. <el-input v-model="workerForm.name" placeholder="请输入"></el-input>
  37. </el-form-item>
  38. </el-col>
  39. <el-col :span="24">
  40. <el-form-item label="银行卡号">
  41. <el-input v-model="workerForm.bankAccount" placeholder="请输入"></el-input>
  42. </el-form-item>
  43. </el-col>
  44. <el-col :span="24">
  45. <el-form-item label="身份证号码" :required="true">
  46. <el-input v-model="workerForm.idCard" placeholder="请输入"></el-input>
  47. </el-form-item>
  48. </el-col>
  49. <el-col :span="24">
  50. <el-form-item label="身份证正面照" :required="true">
  51. <ImageUpload :fileList="fileList" :limit="1" :isEdit="true" />
  52. </el-form-item>
  53. </el-col>
  54. <el-col :span="24" v-for="(item,index) in imgList" :key="index">
  55. <el-form-item :label="item.dictValue" :required="true">
  56. <ImageUpload :fileList="item.imgs" :limit="1" :isEdit="true" />
  57. </el-form-item>
  58. </el-col>
  59. </el-row>
  60. </el-form>
  61. <div slot="footer" class="dialog-footer">
  62. <el-button @click="dialogVisible = false">取 消</el-button>
  63. <el-button type="primary" @click="memberInner()">确定</el-button>
  64. </div>
  65. </el-dialog>
  66. </template-page>
  67. <div class="detail" v-if="isShowMemberDetail">
  68. <MemberDetail :user="queryUser" @backListFromDetail="backListFromMemberDetail" />
  69. </div>
  70. </div>
  71. </template>
  72. <script>
  73. import TemplatePage from '@/components/template/template-page-1.vue'
  74. import import_mixin from '@/components/template/import_mixin.js'
  75. import ImageUpload from '@/components/file-upload'
  76. import { required, mobileRequired, mobile } from '@/components/template/rules_verify.js'
  77. import { memberListPageV2,memberPageExport, memberAudit, memberInner, getWebsit } from "@/api/customerManagement";
  78. import MemberDetail from "@/components/Mall/Member/member-detail";
  79. import request from '@/utils/request'
  80. import operation_mixin from '@/components/template/operation_mixin.js'
  81. export default {
  82. components: { TemplatePage, MemberDetail, ImageUpload },
  83. mixins: [import_mixin,operation_mixin],
  84. data() {
  85. return {
  86. // 事件组合
  87. optionsEvensGroup: [],
  88. // 表格属性
  89. tableAttributes: {
  90. // 启用勾选列
  91. selectColumn: false
  92. },
  93. // 表格事件
  94. tableEvents: {
  95. 'selection-change': this.selectionChange
  96. },
  97. // 勾选选中行
  98. recordSelected: [],
  99. /** 表单变量 */
  100. formDialogType: 0,
  101. formDialogTitles: [],
  102. formDialog: false,
  103. dialogVisible: false,
  104. formData: {
  105. storageName: '',
  106. storageMobile: '',
  107. storageAddress: '',
  108. },
  109. websitList: [],
  110. workerForm: {
  111. websitId: '',
  112. userId: '',
  113. idCard: '',
  114. name: '',
  115. bankAccount: ''
  116. },
  117. queryUser: {}, // 查询
  118. fileList: [],
  119. imgList: []
  120. }
  121. },
  122. computed: {
  123. // 更多参数
  124. moreParameters() {
  125. return []
  126. },
  127. formItems() {
  128. },
  129. isShowMemberDetail() {
  130. return this.queryUser.hasOwnProperty('userId')
  131. }
  132. },
  133. created(){
  134. this.getImgList()
  135. },
  136. methods: {
  137. // 列表请求函数
  138. getList: memberListPageV2,
  139. // 列表导出函数
  140. exportList: memberPageExport,
  141. // 表格列解析渲染数据更改
  142. columnParsing(item, defaultData) {
  143. return defaultData
  144. },
  145. // 监听勾选变化
  146. selectionChange(data) {
  147. this.recordSelected = data
  148. },
  149. // 详情返回显示列表
  150. backListFromMemberDetail() {
  151. this.queryUser = {}
  152. },
  153. getImgList(){
  154. request({
  155. url: `/dictCompany/page`,
  156. method: 'post',
  157. data: { pageNum: 1, pageSize: -1, params: [{param: "a.dict_type", compare: "=", value: "WORKER_IMG"}] }
  158. }).then(res=>{
  159. this.imgList = res.data.records.filter(item=>{
  160. return item.imgs = []
  161. })
  162. })
  163. },
  164. // 表格操作列
  165. operation() {
  166. return this.operationBtn({
  167. detail: {
  168. btnType: 'text',
  169. click: ({ row, index, column }) => {
  170. this.queryUser = row
  171. }
  172. },
  173. setWorker: {
  174. btnType: 'text',
  175. prompt: '请确认是否设为工程师?',
  176. click: ({ row, index, column }) => {
  177. this.workerForm.userId = row.userId
  178. getWebsit({type: 'C'}).then(res => {
  179. this.websitList = res.data
  180. this.dialogVisible = true
  181. })
  182. }
  183. },
  184. setService: {
  185. btnType: 'text',
  186. prompt: '请确认是否设为分销员?',
  187. click: ({ row, index, column }) => {
  188. memberInner({
  189. type: 'SERVICE',
  190. userId: row.userId
  191. }).then(res => {
  192. if (res.code == 200) {
  193. this.$message({ type: 'success', message: '设为分销员成功!' })
  194. this.$refs.pageRef.refreshList()
  195. } else {
  196. this.$message.error(res.msg);
  197. }
  198. })
  199. }
  200. },
  201. })
  202. },
  203. addData() {
  204. this.formDialogType = 0
  205. this.openForm()
  206. },
  207. openForm() {
  208. this.formDialog = true;
  209. },
  210. formCancel() {
  211. this.$refs.formRef.$refs.inlineForm.clearValidate()
  212. this.$data.formData = this.$options.data().formData
  213. this.formDialog = false
  214. },
  215. memberInner(){
  216. let workerImgs = []
  217. for(var i = 0;i < this.imgList.length;i++){
  218. if(this.imgList[i].imgs.length == 0){
  219. return this.$message({ type: 'error', message: '请上传' + this.imgList[i].dictValue +'!' })
  220. break;
  221. }else{
  222. workerImgs.push({
  223. imgName: this.imgList[i].dictValue,
  224. imgUrl: this.imgList[i].imgs.length>0?this.imgList[i].imgs[0].url:''
  225. })
  226. }
  227. }
  228. if(!this.workerForm.websitId){
  229. return this.$message({ type: 'error', message: '请选择入驻网点!'})
  230. }else if(!this.workerForm.name){
  231. return this.$message({ type: 'error', message: '请输入姓名!' })
  232. }else if(!this.workerForm.idCard){
  233. return this.$message({ type: 'error', message: '请输入身份证号码!' })
  234. }else if(!/^\d{6}(18|19|20)\d{2}(0\d|10|11|12)([0-2]\d|30|31)\d{3}[\dXx]$/g.test(this.workerForm.idCard)){
  235. return this.$message({ type: 'error', message: '请输入正确的身份证号码!' })
  236. }else if(this.fileList.length == 0){
  237. return this.$message({ type: 'error', message: '请上传身份证正面照!' })
  238. }
  239. memberInner({
  240. type: 'WORKER',
  241. userId: this.workerForm.userId,
  242. websitId: this.workerForm.websitId,
  243. name: this.workerForm.name,
  244. idCard: this.workerForm.idCard,
  245. bankAccount: this.workerForm.bankAccount,
  246. idCardImg: this.fileList.map(item => item.url).join(","),
  247. workerImgs
  248. }).then(res => {
  249. this.dialogVisible = false
  250. this.$message({ type: 'success', message: '设置工程师成功!' })
  251. this.$refs.pageRef.refreshList()
  252. })
  253. },
  254. formConfirm() {
  255. this.$refs.formRef.validate((valid, invalidFields, errLabels) => {
  256. if (valid) {
  257. ([addMember, editMember][this.formDialogType])(this.formData).then(res => {
  258. this.$message({ type: 'success', message: `${this.formDialogTitles[this.formDialogType]}成功!` })
  259. this.formCancel()
  260. this.$refs.pageRef.refreshList()
  261. })
  262. }
  263. })
  264. }
  265. }
  266. }
  267. </script>
  268. <style lang="scss" scoped>
  269. .detail{
  270. padding: 20px;
  271. box-sizing: border-box;
  272. }
  273. </style>