centaline-data-driven 1.3.7 → 1.3.10

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.
@@ -45,7 +45,8 @@ const paths = {
45
45
  "dynamicContact": "./src/centaline/dynamicContact/index.js",//联系人电话
46
46
  "dynamicLayout": "./src/centaline/dynamicLayout/index.js",//Layout组件
47
47
  "browseVideo": "./src/centaline/browseVideo/index.js",//确认框组件
48
- "dynamicViewerFile": "./src/centaline/dynamicViewerFile/index.js",//确认框组件
48
+ "browseIframe": "./src/centaline/browseIframe/index.js",//URL弹层
49
+ "dynamicViewerFile": "./src/centaline/dynamicViewerFile/index.js",//图片预览框组件
49
50
  },
50
51
  "plugs": {
51
52
  "api": "./src/centaline/api/index.js",//调用API插件
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "centaline-data-driven",
3
- "version": "1.3.07",
3
+ "version": "1.3.10",
4
4
  "description": "ccai",
5
5
  "author": "hjc <3226136347@qq.com>",
6
6
  "private": false,
@@ -1,6 +1,6 @@
1
1
  <template>
2
2
  <div style="width:100%;height:100%;">
3
- <iframe :src="src" ref="iframe" id="iframe1" name="iframe1" style="width:100%;height:100%;"></iframe>
3
+ <iframe :src="src" ref="iframe" style="width:100%;height:99%;" frameborder="0" @load="sendMessage()"></iframe>
4
4
  </div>
5
5
  </template>
6
6
  <script>
@@ -11,12 +11,58 @@
11
11
  },
12
12
  data() {
13
13
  return {
14
-
15
14
  };
16
15
  },
17
- mounted () {
16
+ mounted () {
17
+ window.addEventListener('message', this.handleMessage);
18
18
  },
19
19
  methods: {
20
+ sendMessage () {
21
+ let token= this.getCookie("token");
22
+ this.$refs.iframe.contentWindow.postMessage({
23
+ functionName: 'cookie',
24
+ params: {
25
+ success: true,
26
+ data: token,
27
+ }
28
+ }, '*');
29
+ },
30
+ handleMessage (event) {
31
+ var self=this;
32
+ var data = event.data;
33
+ switch (data.functionName) {
34
+ case 'new':
35
+ self.$emit('new',data.params.data);
36
+ break
37
+ case 'update':
38
+ self.$emit('update');
39
+ break
40
+ case 'delete':
41
+ self.$emit('delete');
42
+ break
43
+ case 'refresh':
44
+ self.$emit('refreshParent');
45
+ break
46
+ case 'close':
47
+ self.$emit('closeDialog');
48
+ break
49
+ case 'title':
50
+ self.$parent.vmodel.title=data.params.data;
51
+ break
52
+ }
53
+ },
54
+ getCookie(c_name){
55
+ if (document.cookie.length>0){
56
+ let c_start=document.cookie.indexOf(c_name + "=")
57
+ if (c_start!=-1){
58
+ c_start=c_start + c_name.length+1
59
+ let c_end=document.cookie.indexOf(";",c_start)
60
+ if (c_end==-1) c_end=document.cookie.length
61
+ return unescape(document.cookie.substring(c_start,c_end))
62
+ }
63
+ }
64
+ return ""
65
+ },
20
66
  }
21
67
  }
22
68
  </script>
@@ -15,7 +15,6 @@
15
15
  },
16
16
  methods: {
17
17
  close() {
18
- //this.dialogTableVisible = false;
19
18
  this.$emit('close', this);
20
19
  if (this.vmodel.content[0].on && typeof this.vmodel.content[0].on["closeDialog"] === "function") {
21
20
  this.vmodel.content[0].on["closeDialog"]();
@@ -25,7 +24,7 @@
25
24
  //ev.cancelBubble = true;
26
25
  //ev.stopPropagation();
27
26
  //ev.preventDefault();
28
- }
27
+ },
29
28
  },
30
29
  mounted() {
31
30
  //this.$el.parentNode.removeChild(this.$el);
@@ -206,7 +205,7 @@
206
205
  ]
207
206
  )
208
207
  ])
209
- }
208
+ },
210
209
  }
211
210
  </script>
212
211
  <style scoped>
@@ -22,7 +22,6 @@
22
22
  mounted() {
23
23
  this.$common.dialogList = this;
24
24
  this.overflow = document.body.style.overflow;
25
- window.addEventListener('message', this.handleMessage)
26
25
  },
27
26
  computed: {
28
27
  zindex: function () {
@@ -61,30 +60,6 @@
61
60
  document.removeEventListener("touchmove", mo, false);
62
61
  }
63
62
  },
64
- handleMessage (event) {
65
- var self=this;
66
- var data = event.data;
67
- switch (data.functionName) {
68
- case 'new':
69
- self.$children[0].vmodel.content[0].on.new(data.params.data);
70
- break
71
- case 'update':
72
- self.$children[0].vmodel.content[0].on.update();
73
- break
74
- case 'delete':
75
- self.$children[0].vmodel.content[0].on.delete();
76
- break
77
- case 'refresh':
78
- self.$children[0].vmodel.content[0].on.refreshParent();
79
- break
80
- case 'close':
81
- self.$children[0].vmodel.content[0].on.closeDialog();
82
- break
83
- case 'title':
84
- self.$children[0].vmodel.title=data.params.data;
85
- break
86
- }
87
- },
88
63
  }
89
64
  }
90
65
  </script>
@@ -28,26 +28,33 @@
28
28
  ></template>
29
29
  </el-carousel>
30
30
 
31
- <div class="hous-img" style="position: absolute; bottom: 0; z-index: 9">
32
- <div
33
- class="img-i"
34
- v-for="(item, index) in newMediaAlbums"
35
- :key="index"
36
- >
37
- <img :src="getDefaultUrl(item)" @click="handleClick(index)" />
38
- <div class="img-bot">
39
- <div>
40
- <img
41
- :src="item.albumSmallImageUrl"
42
- v-if="
43
- item.albumSmallImageUrl && item.albumSmallImageUrl != ''
44
- "
45
- alt=""
46
- class="img-icon"
47
- @click="handleClick(index)"
31
+ <div
32
+ class="hous-img"
33
+ style="position: absolute; bottom: 0; z-index: 9"
34
+ v-if="newMediaAlbums.length > 1"
35
+ >
36
+ <div class="img-i">
37
+ <div class="slide-tabs tabs-3x">
38
+ <template v-for="(item, index) in newMediaAlbums">
39
+ <input
40
+ type="radio"
41
+ :id="'radio-' + index.toString()"
42
+ name="MediaAlbums"
43
+ :label="index"
44
+ :value="index"
45
+ :key="index + 1"
46
+ v-model="activeAlbumsIndex"
48
47
  />
49
- <span @click="handleClick(index)">{{ item.albumName }}</span>
50
- </div>
48
+ <label
49
+ class="tab1"
50
+ :for="'radio-' + index.toString()"
51
+ :label="index"
52
+ :value="index"
53
+ @click="handleClick(index)"
54
+ >{{ item.albumName }}</label
55
+ >
56
+ </template>
57
+ <span class="glider"></span>
51
58
  </div>
52
59
  </div>
53
60
  </div> </template
@@ -78,7 +85,7 @@ export default {
78
85
  methods: {
79
86
  init() {
80
87
  var self = this;
81
- this.newMediaAlbums =this.mediaAlbums || [];
88
+ this.newMediaAlbums = this.mediaAlbums || [];
82
89
  this.albumsList = this.newMediaAlbums[0];
83
90
  self.$forceUpdate();
84
91
  },
@@ -175,36 +182,93 @@ export default {
175
182
  .hous-img {
176
183
  margin-top: 10px;
177
184
  width: 100%;
185
+ text-align: center;
178
186
  overflow-x: hidden;
179
187
  overflow-y: hidden;
180
188
  white-space: nowrap;
189
+ background-color: #fff;
190
+ opacity: 0.8;
181
191
  .img-i {
182
- position: relative;
183
- width: 80px;
184
- height: 44px;
192
+ width: auto;
193
+ height: 20px;
185
194
  margin-right: 10px;
186
195
  display: inline-block;
196
+ opacity: 0.8;
197
+ //background-color: rgba(0, 0, 0, 0.5);
198
+ -webkit-border-radius: 13px;
199
+ -moz-border-radius: 13px;
200
+ border-radius: 13px;
187
201
  img {
188
202
  width: 100%;
189
203
  height: 100%;
190
204
  }
191
- .img-bot {
192
- width: 100%;
193
- height: 16px;
194
- background: rgba(0, 0, 0, 0.5);
195
- color: #fff;
196
- position: absolute;
197
- bottom: 0;
198
- font-weight: Bold;
199
- .img-icon {
200
- width: 12px;
201
- height: 12px;
202
- margin: 0 5px;
203
- margin: 0 5px;
204
- vertical-align: -1.5px;
205
- }
206
- }
205
+
206
+
207
207
  }
208
+
209
+ .slide-tabs {
210
+ display: flex;
211
+ position: relative;
212
+ border: 1px solid #3d3d3d;
213
+ border-radius: 10px;
214
+ width: auto;
215
+ overflow: hidden;
216
+ font-weight: Bold;
217
+ opacity:1;
218
+ background: rgb(24 24 24);
219
+ }
220
+
221
+ .slide-tabs * {
222
+ z-index: 2;
223
+ }
224
+
225
+ .slide-tabs input[type="radio"] {
226
+ display: none;
227
+ }
228
+
229
+ .slide-tabs .tab1 {
230
+ display: flex;
231
+ align-items: center;
232
+ justify-content: center;
233
+ border-radius: 9px;
234
+ height: 18px;
235
+ font-size: 12px;
236
+ color: #fff;
237
+ cursor: pointer;
238
+ }
239
+
240
+ .slide-tabs .glider {
241
+ display: flex;
242
+ position: absolute;
243
+ border-radius: 9px;
244
+ height: 18px;
245
+ background:#f73638;
246
+ z-index: 1;
247
+ transition: 0.25s ease-out;
248
+ }
249
+ /*降低 z-index */
250
+
251
+ .slide-tabs input[type="radio"]:checked + label {
252
+ color: #fff;
253
+ }
254
+ /*按需修改当前项颜色*/
255
+ .slide-tabs input[type="radio"]:nth-of-type(1):checked ~ .glider {
256
+ transform: translateX(0%);
257
+ }
258
+
259
+ .slide-tabs input[type="radio"]:nth-of-type(2):checked ~ .glider {
260
+ transform: translateX(100%);
261
+ }
262
+
263
+ .slide-tabs input[type="radio"]:nth-of-type(3):checked ~ .glider {
264
+ transform: translateX(200%);
265
+ }
266
+
267
+ .slide-tabs.tabs-3x .tab1,
268
+ .slide-tabs.tabs-3x .glider {
269
+ width: 50px;
270
+ }
208
271
  }
209
272
  }
273
+
210
274
  </style>
@@ -983,38 +983,28 @@ export default {
983
983
  clickNextHandler() {
984
984
  let key = "chanceID";
985
985
  if (this.parentModel && this.parentModel.$refs.table) {
986
- let oldValue =
987
- this.parentModel.$refs.table.model.listData[
988
- this.parentModel.$refs.table.model.selectIndex
989
- ][key];
986
+ let oldValue = this.parentModel.$refs.table.model.listData[this.parentModel.$refs.table.model.selectIndex][key];
990
987
  this.parentModel.$refs.table.rowKeyDownHandle(null, 1);
991
- let newValue =
992
- this.parentModel.$refs.table.model.listData[
993
- this.parentModel.$refs.table.model.selectIndex
994
- ][key];
988
+ let newValue = this.parentModel.$refs.table.model.listData[this.parentModel.$refs.table.model.selectIndex][key];
995
989
  if (oldValue !== newValue) {
996
- let parm = this.apiParam;
990
+ let parm = this.$common.cloneObject(this.apiParam);
997
991
  parm[key] = newValue;
998
- this.loaderObj.Detail(this.api, parm, this.load);
992
+ // this.loaderObj.Detail(this.api, parm, this.load);
993
+ this.$common.getDataDrivenOpts().handler.refreshPropertyDetailRET(parm,this.parentModel);
999
994
  }
1000
995
  }
1001
996
  },
1002
997
  clickPrevHandler() {
1003
998
  let key = "chanceID";
1004
999
  if (this.parentModel && this.parentModel.$refs.table) {
1005
- let oldValue =
1006
- this.parentModel.$refs.table.model.listData[
1007
- this.parentModel.$refs.table.model.selectIndex
1008
- ][key];
1000
+ let oldValue = this.parentModel.$refs.table.model.listData[this.parentModel.$refs.table.model.selectIndex][key];
1009
1001
  this.parentModel.$refs.table.rowKeyDownHandle(null, -1);
1010
- let newValue =
1011
- this.parentModel.$refs.table.model.listData[
1012
- this.parentModel.$refs.table.model.selectIndex
1013
- ][key];
1002
+ let newValue = this.parentModel.$refs.table.model.listData[this.parentModel.$refs.table.model.selectIndex][key];
1014
1003
  if (oldValue !== newValue) {
1015
- let parm = this.apiParam;
1004
+ let parm = this.$common.cloneObject(this.apiParam);
1016
1005
  parm[key] = newValue;
1017
- this.loaderObj.Detail(this.api, parm, this.load);
1006
+ // this.loaderObj.Detail(this.api, parm, this.load);
1007
+ this.$common.getDataDrivenOpts().handler.refreshPropertyDetailRET(parm,this.parentModel);
1018
1008
  }
1019
1009
  }
1020
1010
  },
@@ -184,11 +184,13 @@ export default {
184
184
  var index = MediaAlbum[0].medias.findIndex(
185
185
  (v) => v.mediaID === file.source.mediaID
186
186
  );
187
+ debugger;
187
188
  var width = parseInt(window.document.body.clientWidth * 0.8);
189
+ var height = parseInt(window.document.body.clientHeight * 0.8);
188
190
  width = width > 1160 ? 1160 : width;
189
191
  var dialogOption = {
190
192
  title: this.model.label || "预览媒体",
191
- pane: self.$common.getParentPane(self),
193
+ //pane: self.$common.getParentPane(self),
192
194
  content: [
193
195
  {
194
196
  component: "ct-viewerfile",
@@ -200,9 +202,7 @@ export default {
200
202
  // width: self.modelPhotoselect.router.pageWidth + 'px',
201
203
  // height: self.modelPhotoselect.router.pageHeight+'px',
202
204
  width: width + "px",
203
- height:
204
- parseInt(window.document.body.clientHeight * 0.8).toString() +
205
- "px",
205
+ height: height + "px",
206
206
  },
207
207
  on: {
208
208
  handlePhoto(photoList) {},
@@ -769,6 +769,7 @@
769
769
  title: field.pageTitle,
770
770
  pane: self.$common.getParentPane(self),
771
771
  content: [{
772
+ component: 'ct-iframe',
772
773
  attrs: {
773
774
  src: submitData[field.submitListField],
774
775
  width: field.dialogWidth + 'px',
@@ -803,7 +804,7 @@
803
804
  },
804
805
  closeDialog() {
805
806
  self.$common.closeDialog(dialogOption.dialog);
806
- }
807
+ },
807
808
  }
808
809
  }]
809
810
  };
@@ -446,9 +446,9 @@ html {
446
446
  .magnify-toolbar {
447
447
  display: inline-block;
448
448
  background-color: rgba(0, 0, 0, 0.5);
449
- -webkit-border-radius: 5px 5px 0 0;
450
- -moz-border-radius: 5px 5px 0 0;
451
- border-radius: 5px 5px 0 0;
449
+ -webkit-border-radius: 5px;
450
+ -moz-border-radius: 5px;
451
+ border-radius: 5px;
452
452
  }
453
453
  .magnify-toolbar .magnify-btn {
454
454
  margin: 15px 20px;
@@ -460,7 +460,9 @@ html {
460
460
  .magnify-btn-close:hover {
461
461
  color: #fff;
462
462
  }
463
-
463
+ .viewerMenu{
464
+ border-right: solid 2px #e6e6e6 !important;
465
+ }
464
466
  .viewerMenu .el-submenu__title,
465
467
  .viewerMenu .el-submenu .el-menu-item {
466
468
  height: 30px;