1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
| <template>
| <div>
| <Cascader
| v-model="selectDep"
| :data="department"
| :load-data="loadData"
| @on-change="handleChangeDep"
| @on-visible-change="handleVisibleChange"
| change-on-select
| :size="size"
| :transfer="transfer"
| :transfer-class-name="transferClassName"
| :disabled="disabled"
| :filterable="filterable"
| :clearable="clearable"
| :placeholder="placeholder"
| ></Cascader>
| </div>
| </template>
|
| <script>
| import { initDepartment, loadDepartment } from "@/api/index";
| export default {
| name: "departmentChoose",
| props: {
| size: String,
| transfer: {
| type: Boolean,
| default: false,
| },
| disabled: {
| type: Boolean,
| default: false,
| },
| filterable: {
| type: Boolean,
| default: true,
| },
| clearable: {
| type: Boolean,
| default: true,
| },
| placeholder: {
| type: String,
| default: "请选择或输入搜索部门",
| },
| transferClassName: String,
| },
| data() {
| return {
| selectDep: [],
| department: [],
| };
| },
| methods: {
| initDepartmentData() {
| initDepartment().then((res) => {
| if (res.success) {
| res.result.forEach(function (e) {
| if (e.isParent) {
| e.value = e.id;
| e.label = e.title;
| e.loading = false;
| e.children = [];
| } else {
| e.value = e.id;
| e.label = e.title;
| }
| if (e.status == -1) {
| e.label = "[已禁用] " + e.label;
| e.disabled = true;
| }
| });
| this.department = res.result;
| }
| });
| },
| loadData(item, callback) {
| item.loading = true;
| loadDepartment(item.value).then((res) => {
| item.loading = false;
| if (res.success) {
| res.result.forEach(function (e) {
| if (e.isParent) {
| e.value = e.id;
| e.label = e.title;
| e.loading = false;
| e.children = [];
| } else {
| e.value = e.id;
| e.label = e.title;
| }
| if (e.status == -1) {
| e.label = "[已禁用] " + e.label;
| e.disabled = true;
| }
| });
| item.children = res.result;
| callback();
| }
| });
| },
| handleChangeDep(value, selectedData) {
| let departmentId = "";
| // 获取最后一个值
| if (value && value.length > 0) {
| departmentId = value[value.length - 1];
| }
| this.$emit("on-change", departmentId);
| },
| handleVisibleChange(status) {
| this.$emit("on-visible-change", status);
| },
| clearSelect() {
| this.selectDep = [];
| this.$emit("on-change", "");
| },
| },
| mounted() {
| this.initDepartmentData();
| },
| };
| </script>
|
| <style lang="less">
| </style>
|
|