system-clients 3.1.108-aode → 3.1.109-aodeToV4

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -0,0 +1,211 @@
1
+ <template>
2
+ <div :class="style" v-show="companyshow">
3
+ <label class="font_normal_body">公&emsp;&emsp;司</label>
4
+ <right-tree @re-res="getorg"
5
+ :mustselect="mustselect"
6
+ :initresid='initres.org'></right-tree>
7
+ </div>
8
+ <div :class="style" v-show="departmentshow">
9
+ <label class="font_normal_body">部&emsp;&emsp;门</label>
10
+ <res-select restype='department' v-ref:department
11
+ @res-select="getdep"
12
+ :parentresid="depresid"
13
+ :specialquery="specialquery"
14
+ :initresid='initres.dep'
15
+ :mustselect="mustselect"
16
+ :is-mul="mul">
17
+ </res-select>
18
+ </div>
19
+ <div :class="style" v-show="operatorshow && (!cascade)">
20
+ <label class="font_normal_body">人&emsp;&emsp;员</label>
21
+ <res-select restype='user'
22
+ @res-select="getuser"
23
+ :parentresid="depresid"
24
+ :initresid='initres.user'
25
+ :mustselect="mustselect"
26
+ :is-mul="mul">
27
+ </res-select>
28
+ </div>
29
+ <div :class="style" v-show="operatorshow && cascade">
30
+ <label class="font_normal_body">人&emsp;&emsp;员</label>
31
+ <res-select restype='user'
32
+ @res-select="getuser"
33
+ :parentresid="userresid"
34
+ :initresid='initres.user'
35
+ :mustselect="mustselect"
36
+ :is-mul="mul">
37
+ </res-select>
38
+ </div>
39
+ <div :class="style " v-if="sliceareashow" >
40
+ <label class="font_normal_body">片&emsp;&emsp;区</label>
41
+ <v-select :value.sync="slice_area" v-model="slice_area" @change='getarea'
42
+ :options='sliceArea' placeholder='片区/管理站' filer-key="name"
43
+ close-on-select v-ref:slice>
44
+ </v-select>
45
+ </div>
46
+ </template>
47
+ <script>
48
+ import plugin from '../../plugins/GetLoginInfoService'
49
+ import { HttpResetClass } from 'vue-client'
50
+ export default {
51
+ title: '资源选择测试',
52
+ props: {
53
+ style: {
54
+ type: String,
55
+ default: 'col-sm-2 form-group'
56
+ },
57
+ mul: {
58
+ type: Boolean,
59
+ default: true
60
+ },
61
+ //是否只查询营业厅
62
+ specialquery: {
63
+ type: Boolean,
64
+ default: false
65
+ },
66
+ //初始值
67
+ initres: {
68
+ type: Object,
69
+ default: null,
70
+ },
71
+ showComponent:{
72
+ default:['company','department','operator','slicearea']
73
+ },
74
+ //人员是否和部门关联
75
+ cascade: {
76
+ type: Boolean,
77
+ default: true
78
+ },
79
+ selectin: {
80
+ type: Boolean,
81
+ default: true
82
+ }
83
+ },
84
+ data () {
85
+ return {
86
+ orgresid:[this.$login.f.orgid],
87
+ depresid:[],
88
+ userresid:[],
89
+ operatorsid: [],
90
+ sliceArea: [],
91
+ slice_area:[],
92
+ companyshow:false,
93
+ departmentshow:false,
94
+ operatorshow:false,
95
+ sliceareashow:false,
96
+ mustselect:false,
97
+ obj:{
98
+ orgnames:[],
99
+ depnames:[],
100
+ operatornames:[]
101
+ }
102
+ }
103
+ },
104
+ ready () {
105
+ if(this.$login.r.includes('部门默认选中')&& this.selectin){
106
+ this.initres.dep = [this.$login.f.depids]
107
+ }
108
+ if(this.$login.r.includes('人员默认选中')&& this.selectin){
109
+ this.initres.user = [this.$login.f.id]
110
+ if(this.$login.r.includes('人员强制选中')){
111
+ this.mustselect = true
112
+ }
113
+ }
114
+ this.initComponent();
115
+ this.initAreas(this.$login.f.orgid)
116
+ },
117
+ methods:{
118
+ initComponent(){
119
+ let self=this;
120
+ this.showComponent.find((item)=>{
121
+ switch(item){
122
+ case 'company': self.companyshow=true; break;
123
+ case 'department': self.departmentshow=true; break;
124
+ case 'operator': self.operatorshow=true; break;
125
+ case 'slicearea': self.sliceareashow=true; break;
126
+ }
127
+ })
128
+ },
129
+ // 初始化片区
130
+ async initAreas (val) {
131
+ if (val) {
132
+ let http = new HttpResetClass()
133
+ let getAllArea = await http.load('POST', '/rs/search', {
134
+ source: 'this.getParentByType($organization$).getAllChildrens().where(row.getType() == $zone$)',
135
+ userid: this.$login.f.id
136
+ }, {resolveMsg: null, rejectMsg: '获取片区出错!!!'})
137
+ let arr = getAllArea.data.filter((res) => {
138
+ if(Array.isArray(val)){
139
+ for (let i = 0; i <val.length ; i++) {
140
+ if(res.parentid == val[i]){
141
+ return true
142
+ }
143
+ }
144
+ }
145
+ return res.parentid == val
146
+ })
147
+ this.sliceArea = []
148
+ this.slice_area = []
149
+ arr.forEach((res) => {
150
+ this.sliceArea.push({label: res.name, value: {name: res.name, code:res.number}})
151
+ })
152
+ }
153
+ },
154
+ returnOrg(ids){
155
+ let limit = this.$login.r.includes('数据授权限定')
156
+
157
+ let condition;
158
+ if(this.depresid.length > 0)
159
+ condition = plugin.convertToIn(this.depresid);
160
+ else
161
+ condition = this.$login.f.orgid;
162
+ if(this.userresid.length > 0){
163
+ condition += plugin.convertToIn(this.userresid);
164
+ } else {
165
+ if (limit) {
166
+ let depids = []
167
+ for (let row of this.$refs.department.resoptions) {
168
+ depids.push(row.value)
169
+ }
170
+ let depid = depids.length ? plugin.convertToIn(depids) : `('')`
171
+ condition += depid;
172
+ }
173
+ }
174
+ if(ids && ids.length > 0){
175
+ condition += plugin.convertToIn(ids);
176
+ }
177
+ if(this.slice_area.length>0){
178
+ condition += "'" + this.slice_area[0].name+"'"
179
+ }
180
+ this.$dispatch('re-res',condition,this.obj)
181
+ },
182
+ getorg (obj) {
183
+ this.depresid=obj.resids
184
+ this.obj.orgnames = obj.res
185
+ this.initAreas(obj.resids)
186
+ this.returnOrg();
187
+ },
188
+ getdep(obj,val) {
189
+ this.obj.depnames = val
190
+ this.userresid=obj
191
+ this.returnOrg();
192
+ },
193
+ getuser(obj,val) {
194
+ this.obj.operatornames = val
195
+ this.operatorsid = obj
196
+ this.returnOrg(obj);
197
+ },
198
+ getarea(val) {
199
+ this.slice_area=val
200
+ if(this.operatorsid){
201
+ this.returnOrg(this.operatorsid);
202
+ }else{
203
+ this.returnOrg();
204
+ }
205
+ }
206
+ },
207
+ watch: {
208
+
209
+ }
210
+ }
211
+ </script>
@@ -1,150 +1,153 @@
1
- <template>
2
- <v-select :options='resoptions' placeholder='请选择'
3
- :value.sync="selectres"
4
- :multiple="isMul"
5
- search="true"
6
- :close-on-select="!isMul"
7
- @change="resChange"
8
- >
9
- </v-select>
10
- </template>
11
- <script>
12
- import {HttpResetClass} from 'vue-client'
13
-
14
- export default {
15
- title: '资源选择',
16
- props: {
17
-
18
- //资源类型
19
- restype:'',
20
- //资源数据
21
- resObj:{},
22
- isMul: {
23
- type: Boolean,
24
- default: true
25
- },
26
- //资源初始化数据
27
- initresid: {
28
- type: Array,
29
- default() { return [] },
30
- },
31
- //父层id
32
- parentresid: {
33
- type: Array,
34
- default() { return [] },
35
- },
36
- },
37
- data () {
38
- return {
39
- //资源数据
40
- resObj:{},
41
- //资源数据列表
42
- resoptions:[],
43
- //选中资源数据
44
- selectres: [],
45
- }
46
- },
47
- ready () {
48
- //获取资源列表
49
- this.getResList()
50
- },
51
- methods:{
52
- //树形结构变成list
53
- findById(val) {
54
- if(val){
55
- if(this.checkidres(val)){
56
- this.treetoList(val,'')
57
- }else if(val.children.length>0){
58
- for (let value of val.children) {
59
- this.findById(value)
60
- }
61
- }
62
- }
63
- },
64
- //树形结构变成list
65
- treetoList(val,parentname) {
66
- for (let value of val.children) {
67
- this.ergodicList(value,parentname)
68
- }
69
- },
70
- //找到跟节点
71
- ergodicList (val,parentname) {
72
- if(val.children.length > 0 ){
73
- parentname=parentname+val.name
74
- this.treetoList(val,parentname)
75
- }else {
76
- //截取组织机构【组织机构】
77
- if(this.restype=='organization'){
78
- parentname=parentname.replace("组织机构","")
79
- this.resoptions.push({label: val.name+' - '+parentname, value: val.id})
80
- }else{
81
- this.resoptions.push({label: val.name, value: val.id})
82
- }
83
- }
84
- },
85
- //检查id是否存在
86
- checkidres(val){
87
- let flag=false
88
- //如果没传值得话 不过滤
89
- if(this.parentresid.length==0&&this.restype=='organization'){
90
- flag=true
91
- }
92
- this.parentresid.forEach((item) => {
93
- if(item==val.id){
94
- flag=true
95
- }
96
- })
97
- return flag;
98
- },
99
- //资源改变
100
- resChange(val){
101
- let orgnames=[]
102
- Object.keys(this.resoptions).forEach((key) => {
103
- if(this.selectres.includes(this.resoptions[key].value))
104
- orgnames.push(this.resoptions[key].label)
105
- })
106
- console.log('资源改变。。', val, orgnames)
107
- this.$dispatch('res-select', this.selectres, orgnames)
108
- },
109
- //获取资源数据
110
- async getResList() {
111
-
112
- let http = new HttpResetClass()
113
-
114
- let req = await http.load('POST', '/rs/search', {data: {
115
- source: `tool.getFullTree(this.getRights().where(row.getType()==$${this.restype}$))`,
116
- userid: this.$login.f.id
117
- }}, {resolveMsg: null, rejectMsg: '获取组织结构数据出错'})
118
- this.resObj=req.data[0]
119
- this.dealdata()
120
- },
121
- dealdata(){
122
- this.resoptions=[]
123
- this.findById(this.resObj);
124
- //赋值资源数据
125
- let arryselect=[]
126
- this.resoptions.forEach((item) => {
127
- if(this.initresid.length>0){
128
- this.initresid.forEach((init) => {
129
- if(item.value==init){
130
- arryselect.push(item.value)
131
- }
132
- })
133
- }
134
- })
135
- //赋值资源选中初始值
136
- this.selectres=arryselect
137
- }
138
- },
139
- watch: {
140
- //监听初始化资源id
141
- 'initresid.length'(){
142
- this.dealdata()
143
- },
144
- //监听初始化资源id
145
- 'parentresid'(){
146
- this.dealdata()
147
- },
148
- },
149
- }
150
- </script>
1
+ <template>
2
+ <v-select :options='resoptions' placeholder='请选择'
3
+ :value.sync="selectres"
4
+ :multiple="isMul"
5
+ search="true"
6
+ :close-on-select="!isMul"
7
+ @change="resChange"
8
+ >
9
+ </v-select>
10
+ </template>
11
+ <script>
12
+ import {HttpResetClass} from 'vue-client'
13
+
14
+ export default {
15
+ title: '资源选择',
16
+ props: {
17
+
18
+ //资源类型
19
+ restype:'',
20
+ //资源数据
21
+ resObj:{},
22
+ isMul: {
23
+ type: Boolean,
24
+ default: true
25
+ },
26
+ //资源初始化数据
27
+ initresid: {
28
+ type: Array,
29
+ default() { return [] },
30
+ },
31
+ //父层id
32
+ parentresid: {
33
+ type: Array,
34
+ default() { return [] },
35
+ },
36
+ },
37
+ data () {
38
+ return {
39
+ //资源数据
40
+ resObj:{},
41
+ //资源数据列表
42
+ resoptions:[],
43
+ //选中资源数据
44
+ selectres: [],
45
+ }
46
+ },
47
+ ready () {
48
+ //获取资源列表
49
+ this.getResList()
50
+ },
51
+ methods:{
52
+ //树形结构变成list
53
+ findById(val) {
54
+ if(val){
55
+ if(this.checkidres(val)){
56
+ this.treetoList(val,'')
57
+ }else if(val.children.length>0){
58
+ for (let value of val.children) {
59
+ this.findById(value)
60
+ }
61
+ }
62
+ }
63
+ },
64
+ //树形结构变成list
65
+ treetoList(val,parentname) {
66
+ for (let value of val.children) {
67
+ this.ergodicList(value,parentname)
68
+ }
69
+ },
70
+ //找到跟节点
71
+ ergodicList (val,parentname) {
72
+ if(val.children.length > 0 ){
73
+ if (val.name !== '组织机构' && parentname !== '资源管理'){
74
+ this.resoptions.push({label: parentname === '组织机构' ? val.name : val.name+' - '+parentname, value: val.id})
75
+ }
76
+ parentname=parentname+val.name
77
+ this.treetoList(val,parentname)
78
+ }else {
79
+ //截取组织机构【组织机构】
80
+ if(this.restype=='organization'){
81
+ parentname=parentname.replace("组织机构","")
82
+ this.resoptions.push({label: val.name+' - '+parentname, value: val.id})
83
+ }else{
84
+ this.resoptions.push({label: val.name, value: val.id})
85
+ }
86
+ }
87
+ },
88
+ //检查id是否存在
89
+ checkidres(val){
90
+ let flag=false
91
+ //如果没传值得话 不过滤
92
+ if(this.parentresid.length==0&&this.restype=='organization'){
93
+ flag=true
94
+ }
95
+ this.parentresid.forEach((item) => {
96
+ if(item==val.id){
97
+ flag=true
98
+ }
99
+ })
100
+ return flag;
101
+ },
102
+ //资源改变
103
+ resChange(val){
104
+ let orgnames=[]
105
+ Object.keys(this.resoptions).forEach((key) => {
106
+ if(this.selectres.includes(this.resoptions[key].value))
107
+ orgnames.push(this.resoptions[key].label)
108
+ })
109
+ console.log('资源改变。。', val, orgnames)
110
+ this.$dispatch('res-select', this.selectres, orgnames)
111
+ },
112
+ //获取资源数据
113
+ async getResList() {
114
+
115
+ let http = new HttpResetClass()
116
+
117
+ let req = await http.load('POST', '/rs/search', {data: {
118
+ source: `tool.getFullTree(this.getRights().where(row.getType()==$${this.restype}$))`,
119
+ userid: this.$login.f.id
120
+ }}, {resolveMsg: null, rejectMsg: '获取组织结构数据出错'})
121
+ this.resObj=req.data[0]
122
+ this.dealdata()
123
+ },
124
+ dealdata(){
125
+ this.resoptions=[]
126
+ this.findById(this.resObj);
127
+ //赋值资源数据
128
+ let arryselect=[]
129
+ this.resoptions.forEach((item) => {
130
+ if(this.initresid.length>0){
131
+ this.initresid.forEach((init) => {
132
+ if(item.value==init){
133
+ arryselect.push(item.value)
134
+ }
135
+ })
136
+ }
137
+ })
138
+ //赋值资源选中初始值
139
+ this.selectres=arryselect
140
+ }
141
+ },
142
+ watch: {
143
+ //监听初始化资源id
144
+ 'initresid.length'(){
145
+ this.dealdata()
146
+ },
147
+ //监听初始化资源id
148
+ 'parentresid'(){
149
+ this.dealdata()
150
+ },
151
+ },
152
+ }
153
+ </script>