index.vue 2.1 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374
  1. <template>
  2. <view class="">
  3. <u-picker :show="show" :title="title" :columns="columns" keyName="label" ref="uPicker"
  4. @confirm="recyclePersonConfirm" @change="recyclePersonChange" @cancel='close'></u-picker>
  5. </view>
  6. </template>
  7. <script>
  8. export default {
  9. name: 'personPicker',
  10. data() {
  11. return {
  12. show: false,
  13. columns: [],
  14. }
  15. },
  16. props: {
  17. title: {
  18. type: String,
  19. default: '请选择',
  20. },
  21. },
  22. emits: ['selectPerson'],
  23. methods: {
  24. open() {
  25. this.show = true;
  26. this.recyclePersonClick();
  27. },
  28. close() {
  29. this.columns = [];
  30. this.show = false;
  31. },
  32. recyclePersonConfirm({ columnIndex, value, values,index }) {
  33. this.$emit('selectPerson', value[value.length - 1] ? value[value.length - 1] : value[value.length - 2]);
  34. this.close();
  35. },
  36. recyclePersonChange(e) {
  37. const {
  38. columnIndex,
  39. value,
  40. values,
  41. picker = this.$refs.uPicker
  42. } = e
  43. // 当前项不是用户,且有子级,添加下一层
  44. if(!value[columnIndex].isUser){
  45. picker.setColumnValues(columnIndex+1, value[columnIndex].children);
  46. }else{
  47. // 当前是用户且同等级的其他项有子级,则添加下一层空数据
  48. values[columnIndex].forEach((item, index) => {
  49. if(!item.isUser){
  50. picker.setColumnValues(columnIndex+1, []);
  51. }
  52. })
  53. }
  54. },
  55. recyclePersonClick() {
  56. uni.$u.api.getCustomerManagerAllList().then(res => {
  57. this.columns = [res.data] || [];
  58. // 如果第一层只有一个选项,自动处理下一层级
  59. if (res.data && res.data.length === 1) {
  60. // 如果当前项不是用户且有子级,添加下一层
  61. if (!res.data[0].isUser && res.data[0].children && res.data[0].children.length > 0) {
  62. this.columns.push(res.data[0].children);
  63. }
  64. }
  65. })
  66. },
  67. }
  68. }
  69. </script>
  70. <style lang="scss" scoped>
  71. </style>