cms-chenhj-ui 2.0.34 → 2.0.36
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.
- package/cms-chenhj-ui.common.js +1326 -1315
- package/cms-chenhj-ui.common.js.map +1 -1
- package/cms-chenhj-ui.css +1 -1
- package/cms-chenhj-ui.umd.js +1533 -1522
- package/cms-chenhj-ui.umd.js.map +1 -1
- package/cms-chenhj-ui.umd.min.js +3 -3
- package/cms-chenhj-ui.umd.min.js.map +1 -1
- package/package.json +1 -1
package/cms-chenhj-ui.common.js
CHANGED
|
@@ -598,7 +598,7 @@ var component = (0,componentNormalizer/* default */.A)(
|
|
|
598
598
|
__webpack_require__.r(__webpack_exports__);
|
|
599
599
|
/* harmony import */ var _baseConfig__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(649);
|
|
600
600
|
|
|
601
|
-
const View = () => Promise.resolve(/* import() */).then(__webpack_require__.bind(__webpack_require__,
|
|
601
|
+
const View = () => Promise.resolve(/* import() */).then(__webpack_require__.bind(__webpack_require__, 7524));
|
|
602
602
|
const langData = {
|
|
603
603
|
// 内容编辑
|
|
604
604
|
textContent: "请输入文本内容",
|
|
@@ -1183,6 +1183,140 @@ var component = (0,componentNormalizer/* default */.A)(
|
|
|
1183
1183
|
|
|
1184
1184
|
/***/ }),
|
|
1185
1185
|
|
|
1186
|
+
/***/ 450:
|
|
1187
|
+
/***/ (function(__unused_webpack_module, __webpack_exports__, __webpack_require__) {
|
|
1188
|
+
|
|
1189
|
+
"use strict";
|
|
1190
|
+
// ESM COMPAT FLAG
|
|
1191
|
+
__webpack_require__.r(__webpack_exports__);
|
|
1192
|
+
|
|
1193
|
+
// EXPORTS
|
|
1194
|
+
__webpack_require__.d(__webpack_exports__, {
|
|
1195
|
+
"default": function() { return /* binding */ View; }
|
|
1196
|
+
});
|
|
1197
|
+
|
|
1198
|
+
;// ./node_modules/thread-loader/dist/cjs.js!./node_modules/babel-loader/lib/index.js??clonedRuleSet-40.use[1]!./node_modules/babel-loader/lib/index.js??clonedRuleSet-41.use!./node_modules/@vue/vue-loader-v15/lib/loaders/templateLoader.js??ruleSet[1].rules[4]!./node_modules/@vue/vue-loader-v15/lib/index.js??vue-loader-options!./package/cms-richText/View.vue?vue&type=template&id=982cf5e8&scoped=true
|
|
1199
|
+
var render = function render() {
|
|
1200
|
+
var _vm = this,
|
|
1201
|
+
_c = _vm._self._c;
|
|
1202
|
+
return _c('BaseComp', _vm._b({
|
|
1203
|
+
attrs: {
|
|
1204
|
+
"data": _vm.data,
|
|
1205
|
+
"nowCompId": _vm.nowCompId,
|
|
1206
|
+
"isOpcacity": _vm.isOpcacity,
|
|
1207
|
+
"lang": _vm.lang
|
|
1208
|
+
},
|
|
1209
|
+
on: {
|
|
1210
|
+
"getConfigData": _vm.getConfigData
|
|
1211
|
+
}
|
|
1212
|
+
}, 'BaseComp', _vm.$attrs, false), [_c('section', {
|
|
1213
|
+
class: {
|
|
1214
|
+
'cmhk-home_main': _vm.showCmhkMain
|
|
1215
|
+
}
|
|
1216
|
+
}, [_c('div', [_c('div', {
|
|
1217
|
+
staticClass: "inner"
|
|
1218
|
+
}, [_c('p', {
|
|
1219
|
+
staticClass: "cms-ht",
|
|
1220
|
+
domProps: {
|
|
1221
|
+
"innerHTML": _vm._s(_vm.configData.input1)
|
|
1222
|
+
}
|
|
1223
|
+
})])])])]);
|
|
1224
|
+
};
|
|
1225
|
+
var staticRenderFns = [];
|
|
1226
|
+
|
|
1227
|
+
// EXTERNAL MODULE: ./package/baseComp.vue + 5 modules
|
|
1228
|
+
var baseComp = __webpack_require__(4272);
|
|
1229
|
+
;// ./node_modules/thread-loader/dist/cjs.js!./node_modules/babel-loader/lib/index.js??clonedRuleSet-40.use[1]!./node_modules/babel-loader/lib/index.js??clonedRuleSet-41.use!./node_modules/@vue/vue-loader-v15/lib/index.js??vue-loader-options!./package/cms-richText/View.vue?vue&type=script&lang=js
|
|
1230
|
+
|
|
1231
|
+
/* harmony default export */ var Viewvue_type_script_lang_js = ({
|
|
1232
|
+
name: "cms-richText",
|
|
1233
|
+
components: {
|
|
1234
|
+
BaseComp: baseComp["default"]
|
|
1235
|
+
},
|
|
1236
|
+
props: {
|
|
1237
|
+
data: {
|
|
1238
|
+
type: Object,
|
|
1239
|
+
default: () => {
|
|
1240
|
+
return {};
|
|
1241
|
+
}
|
|
1242
|
+
},
|
|
1243
|
+
nowCompId: {
|
|
1244
|
+
type: [String, Number],
|
|
1245
|
+
default: ""
|
|
1246
|
+
},
|
|
1247
|
+
isOpcacity: {
|
|
1248
|
+
type: Boolean,
|
|
1249
|
+
default: true
|
|
1250
|
+
},
|
|
1251
|
+
lang: {
|
|
1252
|
+
type: String,
|
|
1253
|
+
default: "zh-HK"
|
|
1254
|
+
},
|
|
1255
|
+
showCmhkMain: {
|
|
1256
|
+
type: Boolean,
|
|
1257
|
+
default: true
|
|
1258
|
+
}
|
|
1259
|
+
},
|
|
1260
|
+
data() {
|
|
1261
|
+
return {
|
|
1262
|
+
configData: {},
|
|
1263
|
+
messFold: false
|
|
1264
|
+
};
|
|
1265
|
+
},
|
|
1266
|
+
mounted() {},
|
|
1267
|
+
watch: {},
|
|
1268
|
+
methods: {
|
|
1269
|
+
getConfigData(configData) {
|
|
1270
|
+
this.configData = configData;
|
|
1271
|
+
},
|
|
1272
|
+
foldMessText() {
|
|
1273
|
+
this.messFold = !this.messFold;
|
|
1274
|
+
},
|
|
1275
|
+
decodeJumpUrl(url) {
|
|
1276
|
+
if (!url) return;
|
|
1277
|
+
top.location.href = url;
|
|
1278
|
+
}
|
|
1279
|
+
}
|
|
1280
|
+
});
|
|
1281
|
+
;// ./package/cms-richText/View.vue?vue&type=script&lang=js
|
|
1282
|
+
/* harmony default export */ var cms_richText_Viewvue_type_script_lang_js = (Viewvue_type_script_lang_js);
|
|
1283
|
+
;// ./node_modules/mini-css-extract-plugin/dist/loader.js??clonedRuleSet-22.use[0]!./node_modules/css-loader/dist/cjs.js??clonedRuleSet-22.use[1]!./node_modules/@vue/vue-loader-v15/lib/loaders/stylePostLoader.js!./node_modules/postcss-loader/dist/cjs.js??clonedRuleSet-22.use[2]!./node_modules/sass-loader/dist/cjs.js??clonedRuleSet-22.use[3]!./node_modules/sass-loader/dist/cjs.js??clonedRuleSet-42.use[0]!./node_modules/@vue/vue-loader-v15/lib/index.js??vue-loader-options!./package/cms-richText/View.vue?vue&type=style&index=0&id=982cf5e8&prod&lang=scss&scoped=true
|
|
1284
|
+
// extracted by mini-css-extract-plugin
|
|
1285
|
+
|
|
1286
|
+
;// ./package/cms-richText/View.vue?vue&type=style&index=0&id=982cf5e8&prod&lang=scss&scoped=true
|
|
1287
|
+
|
|
1288
|
+
;// ./node_modules/mini-css-extract-plugin/dist/loader.js??clonedRuleSet-22.use[0]!./node_modules/css-loader/dist/cjs.js??clonedRuleSet-22.use[1]!./node_modules/@vue/vue-loader-v15/lib/loaders/stylePostLoader.js!./node_modules/postcss-loader/dist/cjs.js??clonedRuleSet-22.use[2]!./node_modules/sass-loader/dist/cjs.js??clonedRuleSet-22.use[3]!./node_modules/sass-loader/dist/cjs.js??clonedRuleSet-42.use[0]!./node_modules/@vue/vue-loader-v15/lib/index.js??vue-loader-options!./package/cms-richText/View.vue?vue&type=style&index=1&id=982cf5e8&prod&lang=scss
|
|
1289
|
+
// extracted by mini-css-extract-plugin
|
|
1290
|
+
|
|
1291
|
+
;// ./package/cms-richText/View.vue?vue&type=style&index=1&id=982cf5e8&prod&lang=scss
|
|
1292
|
+
|
|
1293
|
+
// EXTERNAL MODULE: ./node_modules/@vue/vue-loader-v15/lib/runtime/componentNormalizer.js
|
|
1294
|
+
var componentNormalizer = __webpack_require__(1656);
|
|
1295
|
+
;// ./package/cms-richText/View.vue
|
|
1296
|
+
|
|
1297
|
+
|
|
1298
|
+
|
|
1299
|
+
;
|
|
1300
|
+
|
|
1301
|
+
|
|
1302
|
+
|
|
1303
|
+
/* normalize component */
|
|
1304
|
+
|
|
1305
|
+
var component = (0,componentNormalizer/* default */.A)(
|
|
1306
|
+
cms_richText_Viewvue_type_script_lang_js,
|
|
1307
|
+
render,
|
|
1308
|
+
staticRenderFns,
|
|
1309
|
+
false,
|
|
1310
|
+
null,
|
|
1311
|
+
"982cf5e8",
|
|
1312
|
+
null
|
|
1313
|
+
|
|
1314
|
+
)
|
|
1315
|
+
|
|
1316
|
+
/* harmony default export */ var View = (component.exports);
|
|
1317
|
+
|
|
1318
|
+
/***/ }),
|
|
1319
|
+
|
|
1186
1320
|
/***/ 492:
|
|
1187
1321
|
/***/ (function(module) {
|
|
1188
1322
|
|
|
@@ -2140,134 +2274,6 @@ module.exports = function (it) {
|
|
|
2140
2274
|
};
|
|
2141
2275
|
|
|
2142
2276
|
|
|
2143
|
-
/***/ }),
|
|
2144
|
-
|
|
2145
|
-
/***/ 864:
|
|
2146
|
-
/***/ (function(__unused_webpack_module, __webpack_exports__, __webpack_require__) {
|
|
2147
|
-
|
|
2148
|
-
"use strict";
|
|
2149
|
-
// ESM COMPAT FLAG
|
|
2150
|
-
__webpack_require__.r(__webpack_exports__);
|
|
2151
|
-
|
|
2152
|
-
// EXPORTS
|
|
2153
|
-
__webpack_require__.d(__webpack_exports__, {
|
|
2154
|
-
"default": function() { return /* binding */ View; }
|
|
2155
|
-
});
|
|
2156
|
-
|
|
2157
|
-
;// ./node_modules/thread-loader/dist/cjs.js!./node_modules/babel-loader/lib/index.js??clonedRuleSet-40.use[1]!./node_modules/babel-loader/lib/index.js??clonedRuleSet-41.use!./node_modules/@vue/vue-loader-v15/lib/loaders/templateLoader.js??ruleSet[1].rules[4]!./node_modules/@vue/vue-loader-v15/lib/index.js??vue-loader-options!./package/cms-richText/View.vue?vue&type=template&id=1960dc6c&scoped=true
|
|
2158
|
-
var render = function render() {
|
|
2159
|
-
var _vm = this,
|
|
2160
|
-
_c = _vm._self._c;
|
|
2161
|
-
return _c('BaseComp', _vm._b({
|
|
2162
|
-
attrs: {
|
|
2163
|
-
"data": _vm.data,
|
|
2164
|
-
"nowCompId": _vm.nowCompId,
|
|
2165
|
-
"isOpcacity": _vm.isOpcacity,
|
|
2166
|
-
"lang": _vm.lang
|
|
2167
|
-
},
|
|
2168
|
-
on: {
|
|
2169
|
-
"getConfigData": _vm.getConfigData
|
|
2170
|
-
}
|
|
2171
|
-
}, 'BaseComp', _vm.$attrs, false), [_c('section', {
|
|
2172
|
-
staticClass: "cmhk-home_main"
|
|
2173
|
-
}, [_c('div', [_c('div', {
|
|
2174
|
-
staticClass: "inner"
|
|
2175
|
-
}, [_c('p', {
|
|
2176
|
-
staticClass: "cms-ht",
|
|
2177
|
-
domProps: {
|
|
2178
|
-
"innerHTML": _vm._s(_vm.configData.input1)
|
|
2179
|
-
}
|
|
2180
|
-
})])])])]);
|
|
2181
|
-
};
|
|
2182
|
-
var staticRenderFns = [];
|
|
2183
|
-
|
|
2184
|
-
// EXTERNAL MODULE: ./package/baseComp.vue + 5 modules
|
|
2185
|
-
var baseComp = __webpack_require__(4272);
|
|
2186
|
-
;// ./node_modules/thread-loader/dist/cjs.js!./node_modules/babel-loader/lib/index.js??clonedRuleSet-40.use[1]!./node_modules/babel-loader/lib/index.js??clonedRuleSet-41.use!./node_modules/@vue/vue-loader-v15/lib/index.js??vue-loader-options!./package/cms-richText/View.vue?vue&type=script&lang=js
|
|
2187
|
-
|
|
2188
|
-
/* harmony default export */ var Viewvue_type_script_lang_js = ({
|
|
2189
|
-
name: "cms-richText",
|
|
2190
|
-
components: {
|
|
2191
|
-
BaseComp: baseComp["default"]
|
|
2192
|
-
},
|
|
2193
|
-
props: {
|
|
2194
|
-
data: {
|
|
2195
|
-
type: Object,
|
|
2196
|
-
default: () => {
|
|
2197
|
-
return {};
|
|
2198
|
-
}
|
|
2199
|
-
},
|
|
2200
|
-
nowCompId: {
|
|
2201
|
-
type: [String, Number],
|
|
2202
|
-
default: ""
|
|
2203
|
-
},
|
|
2204
|
-
isOpcacity: {
|
|
2205
|
-
type: Boolean,
|
|
2206
|
-
default: true
|
|
2207
|
-
},
|
|
2208
|
-
lang: {
|
|
2209
|
-
type: String,
|
|
2210
|
-
default: "zh-HK"
|
|
2211
|
-
}
|
|
2212
|
-
},
|
|
2213
|
-
data() {
|
|
2214
|
-
return {
|
|
2215
|
-
configData: {},
|
|
2216
|
-
messFold: false
|
|
2217
|
-
};
|
|
2218
|
-
},
|
|
2219
|
-
mounted() {},
|
|
2220
|
-
watch: {},
|
|
2221
|
-
methods: {
|
|
2222
|
-
getConfigData(configData) {
|
|
2223
|
-
this.configData = configData;
|
|
2224
|
-
},
|
|
2225
|
-
foldMessText() {
|
|
2226
|
-
this.messFold = !this.messFold;
|
|
2227
|
-
},
|
|
2228
|
-
decodeJumpUrl(url) {
|
|
2229
|
-
if (!url) return;
|
|
2230
|
-
top.location.href = url;
|
|
2231
|
-
}
|
|
2232
|
-
}
|
|
2233
|
-
});
|
|
2234
|
-
;// ./package/cms-richText/View.vue?vue&type=script&lang=js
|
|
2235
|
-
/* harmony default export */ var cms_richText_Viewvue_type_script_lang_js = (Viewvue_type_script_lang_js);
|
|
2236
|
-
;// ./node_modules/mini-css-extract-plugin/dist/loader.js??clonedRuleSet-22.use[0]!./node_modules/css-loader/dist/cjs.js??clonedRuleSet-22.use[1]!./node_modules/@vue/vue-loader-v15/lib/loaders/stylePostLoader.js!./node_modules/postcss-loader/dist/cjs.js??clonedRuleSet-22.use[2]!./node_modules/sass-loader/dist/cjs.js??clonedRuleSet-22.use[3]!./node_modules/sass-loader/dist/cjs.js??clonedRuleSet-42.use[0]!./node_modules/@vue/vue-loader-v15/lib/index.js??vue-loader-options!./package/cms-richText/View.vue?vue&type=style&index=0&id=1960dc6c&prod&lang=scss&scoped=true
|
|
2237
|
-
// extracted by mini-css-extract-plugin
|
|
2238
|
-
|
|
2239
|
-
;// ./package/cms-richText/View.vue?vue&type=style&index=0&id=1960dc6c&prod&lang=scss&scoped=true
|
|
2240
|
-
|
|
2241
|
-
;// ./node_modules/mini-css-extract-plugin/dist/loader.js??clonedRuleSet-22.use[0]!./node_modules/css-loader/dist/cjs.js??clonedRuleSet-22.use[1]!./node_modules/@vue/vue-loader-v15/lib/loaders/stylePostLoader.js!./node_modules/postcss-loader/dist/cjs.js??clonedRuleSet-22.use[2]!./node_modules/sass-loader/dist/cjs.js??clonedRuleSet-22.use[3]!./node_modules/sass-loader/dist/cjs.js??clonedRuleSet-42.use[0]!./node_modules/@vue/vue-loader-v15/lib/index.js??vue-loader-options!./package/cms-richText/View.vue?vue&type=style&index=1&id=1960dc6c&prod&lang=scss
|
|
2242
|
-
// extracted by mini-css-extract-plugin
|
|
2243
|
-
|
|
2244
|
-
;// ./package/cms-richText/View.vue?vue&type=style&index=1&id=1960dc6c&prod&lang=scss
|
|
2245
|
-
|
|
2246
|
-
// EXTERNAL MODULE: ./node_modules/@vue/vue-loader-v15/lib/runtime/componentNormalizer.js
|
|
2247
|
-
var componentNormalizer = __webpack_require__(1656);
|
|
2248
|
-
;// ./package/cms-richText/View.vue
|
|
2249
|
-
|
|
2250
|
-
|
|
2251
|
-
|
|
2252
|
-
;
|
|
2253
|
-
|
|
2254
|
-
|
|
2255
|
-
|
|
2256
|
-
/* normalize component */
|
|
2257
|
-
|
|
2258
|
-
var component = (0,componentNormalizer/* default */.A)(
|
|
2259
|
-
cms_richText_Viewvue_type_script_lang_js,
|
|
2260
|
-
render,
|
|
2261
|
-
staticRenderFns,
|
|
2262
|
-
false,
|
|
2263
|
-
null,
|
|
2264
|
-
"1960dc6c",
|
|
2265
|
-
null
|
|
2266
|
-
|
|
2267
|
-
)
|
|
2268
|
-
|
|
2269
|
-
/* harmony default export */ var View = (component.exports);
|
|
2270
|
-
|
|
2271
2277
|
/***/ }),
|
|
2272
2278
|
|
|
2273
2279
|
/***/ 911:
|
|
@@ -10640,8 +10646,8 @@ var map = {
|
|
|
10640
10646
|
"./cms-banner/index.js": 1739,
|
|
10641
10647
|
"./cms-button": 2209,
|
|
10642
10648
|
"./cms-button/": 2209,
|
|
10643
|
-
"./cms-button/View":
|
|
10644
|
-
"./cms-button/View.vue":
|
|
10649
|
+
"./cms-button/View": 4018,
|
|
10650
|
+
"./cms-button/View.vue": 4018,
|
|
10645
10651
|
"./cms-button/index": 2209,
|
|
10646
10652
|
"./cms-button/index.js": 2209,
|
|
10647
10653
|
"./cms-cells": 1630,
|
|
@@ -10653,8 +10659,8 @@ var map = {
|
|
|
10653
10659
|
"./cms-column": 3923,
|
|
10654
10660
|
"./cms-column-card": 5340,
|
|
10655
10661
|
"./cms-column-card/": 5340,
|
|
10656
|
-
"./cms-column-card/View":
|
|
10657
|
-
"./cms-column-card/View.vue":
|
|
10662
|
+
"./cms-column-card/View": 2159,
|
|
10663
|
+
"./cms-column-card/View.vue": 2159,
|
|
10658
10664
|
"./cms-column-card/index": 5340,
|
|
10659
10665
|
"./cms-column-card/index.js": 5340,
|
|
10660
10666
|
"./cms-column/": 3923,
|
|
@@ -10748,8 +10754,8 @@ var map = {
|
|
|
10748
10754
|
"./cms-question/index.js": 2269,
|
|
10749
10755
|
"./cms-richText": 7616,
|
|
10750
10756
|
"./cms-richText/": 7616,
|
|
10751
|
-
"./cms-richText/View":
|
|
10752
|
-
"./cms-richText/View.vue":
|
|
10757
|
+
"./cms-richText/View": 450,
|
|
10758
|
+
"./cms-richText/View.vue": 450,
|
|
10753
10759
|
"./cms-richText/index": 7616,
|
|
10754
10760
|
"./cms-richText/index.js": 7616,
|
|
10755
10761
|
"./cms-servePlan-tab": 1373,
|
|
@@ -10783,8 +10789,8 @@ var map = {
|
|
|
10783
10789
|
"./cms-termsAndConditions/index.js": 9387,
|
|
10784
10790
|
"./cms-text": 394,
|
|
10785
10791
|
"./cms-text/": 394,
|
|
10786
|
-
"./cms-text/View":
|
|
10787
|
-
"./cms-text/View.vue":
|
|
10792
|
+
"./cms-text/View": 7524,
|
|
10793
|
+
"./cms-text/View.vue": 7524,
|
|
10788
10794
|
"./cms-text/index": 394,
|
|
10789
10795
|
"./cms-text/index.js": 394,
|
|
10790
10796
|
"./cms-threeScroll": 4670,
|
|
@@ -11266,465 +11272,10 @@ module.exports = function (object, names) {
|
|
|
11266
11272
|
/***/ }),
|
|
11267
11273
|
|
|
11268
11274
|
/***/ 1861:
|
|
11269
|
-
/***/ (function(
|
|
11275
|
+
/***/ (function(module) {
|
|
11270
11276
|
|
|
11271
11277
|
"use strict";
|
|
11272
|
-
|
|
11273
|
-
__webpack_require__.r(__webpack_exports__);
|
|
11274
|
-
|
|
11275
|
-
// EXPORTS
|
|
11276
|
-
__webpack_require__.d(__webpack_exports__, {
|
|
11277
|
-
"default": function() { return /* binding */ View; }
|
|
11278
|
-
});
|
|
11279
|
-
|
|
11280
|
-
// EXTERNAL MODULE: ./node_modules/core-js/modules/es.iterator.constructor.js
|
|
11281
|
-
var es_iterator_constructor = __webpack_require__(8111);
|
|
11282
|
-
// EXTERNAL MODULE: ./node_modules/core-js/modules/es.iterator.drop.js
|
|
11283
|
-
var es_iterator_drop = __webpack_require__(9314);
|
|
11284
|
-
;// ./node_modules/thread-loader/dist/cjs.js!./node_modules/babel-loader/lib/index.js??clonedRuleSet-40.use[1]!./node_modules/babel-loader/lib/index.js??clonedRuleSet-41.use!./node_modules/@vue/vue-loader-v15/lib/loaders/templateLoader.js??ruleSet[1].rules[4]!./node_modules/@vue/vue-loader-v15/lib/index.js??vue-loader-options!./package/cms-column-card/View.vue?vue&type=template&id=2380364b&scoped=true
|
|
11285
|
-
|
|
11286
|
-
|
|
11287
|
-
|
|
11288
|
-
|
|
11289
|
-
var render = function render() {
|
|
11290
|
-
var _vm = this,
|
|
11291
|
-
_c = _vm._self._c;
|
|
11292
|
-
return _c('BaseComp', _vm._b({
|
|
11293
|
-
attrs: {
|
|
11294
|
-
"data": _vm.data,
|
|
11295
|
-
"nowCompId": _vm.nowCompId,
|
|
11296
|
-
"isOpcacity": _vm.isOpcacity,
|
|
11297
|
-
"isMask": false,
|
|
11298
|
-
"lang": _vm.lang,
|
|
11299
|
-
"showDel": false
|
|
11300
|
-
},
|
|
11301
|
-
on: {
|
|
11302
|
-
"getConfigData": _vm.getConfigData
|
|
11303
|
-
}
|
|
11304
|
-
}, 'BaseComp', _vm.$attrs, false), [_vm.isConfigPage ? _c('div', {
|
|
11305
|
-
staticClass: "main_drag hoverBorderClass",
|
|
11306
|
-
style: _vm.cardContainerStyle,
|
|
11307
|
-
attrs: {
|
|
11308
|
-
"id": `cardTarget${_vm.data.componentId}`
|
|
11309
|
-
},
|
|
11310
|
-
on: {
|
|
11311
|
-
"dragover": _vm.dragover,
|
|
11312
|
-
"dragend": function ($event) {
|
|
11313
|
-
_vm.showAddCom = false;
|
|
11314
|
-
},
|
|
11315
|
-
"drop": _vm.drop
|
|
11316
|
-
}
|
|
11317
|
-
}, [_c('Draggable', {
|
|
11318
|
-
staticStyle: {
|
|
11319
|
-
"position": "relative"
|
|
11320
|
-
},
|
|
11321
|
-
attrs: {
|
|
11322
|
-
"group": _vm.groupConfigForMain,
|
|
11323
|
-
"chosen-class": "chosen",
|
|
11324
|
-
"force-fallback": "true",
|
|
11325
|
-
"animation": "1000",
|
|
11326
|
-
"move": _vm.onMove
|
|
11327
|
-
},
|
|
11328
|
-
on: {
|
|
11329
|
-
"start": _vm.onStart,
|
|
11330
|
-
"end": function ($event) {
|
|
11331
|
-
_vm.showAddCom = false;
|
|
11332
|
-
}
|
|
11333
|
-
},
|
|
11334
|
-
model: {
|
|
11335
|
-
value: _vm.data.childList,
|
|
11336
|
-
callback: function ($$v) {
|
|
11337
|
-
_vm.$set(_vm.data, "childList", $$v);
|
|
11338
|
-
},
|
|
11339
|
-
expression: "data.childList"
|
|
11340
|
-
}
|
|
11341
|
-
}, [_vm._l(_vm.data.childList, function (item, index) {
|
|
11342
|
-
return _c('div', {
|
|
11343
|
-
key: item.componentId,
|
|
11344
|
-
staticStyle: {
|
|
11345
|
-
"position": "relative"
|
|
11346
|
-
}
|
|
11347
|
-
}, [_vm.showAddCom ? _c('div', {
|
|
11348
|
-
staticClass: "up_insert",
|
|
11349
|
-
attrs: {
|
|
11350
|
-
"id": `${item.componentId}-cardTargetup`
|
|
11351
|
-
}
|
|
11352
|
-
}, [_c('i', {
|
|
11353
|
-
staticClass: "icon-up",
|
|
11354
|
-
attrs: {
|
|
11355
|
-
"id": `${item.componentId}-upi`
|
|
11356
|
-
}
|
|
11357
|
-
}), _c('span', {
|
|
11358
|
-
attrs: {
|
|
11359
|
-
"id": `${item.componentId}-upspan`
|
|
11360
|
-
}
|
|
11361
|
-
}, [_vm._v("插入组件")])]) : _vm._e(), _c(item.cmsCompName, {
|
|
11362
|
-
tag: "component",
|
|
11363
|
-
style: {
|
|
11364
|
-
marginTop: _vm.showAddCom && index == 0 ? '20px' : '0px'
|
|
11365
|
-
},
|
|
11366
|
-
attrs: {
|
|
11367
|
-
"data": item,
|
|
11368
|
-
"lang": _vm.lang,
|
|
11369
|
-
"isOpcacity": _vm.isOpcacity,
|
|
11370
|
-
"nowCompId": _vm.nowCompId
|
|
11371
|
-
}
|
|
11372
|
-
})], 1);
|
|
11373
|
-
}), _vm.showAddCom ? _c('div', {
|
|
11374
|
-
staticClass: "up_insert insert_bottom",
|
|
11375
|
-
style: {
|
|
11376
|
-
bottom: _vm.data.childList.length ? '0px' : '-24px'
|
|
11377
|
-
},
|
|
11378
|
-
attrs: {
|
|
11379
|
-
"id": `-cardTargetdown`
|
|
11380
|
-
}
|
|
11381
|
-
}, [_c('i', {
|
|
11382
|
-
staticClass: "icon-up"
|
|
11383
|
-
}), _c('span', [_vm._v("插入组件")])]) : _vm._e()], 2)], 1) : _c('cms-view', _vm._b({
|
|
11384
|
-
style: _vm.cardContainerStyle,
|
|
11385
|
-
attrs: {
|
|
11386
|
-
"data": _vm.data.childList,
|
|
11387
|
-
"lang": _vm.lang,
|
|
11388
|
-
"isOpcacity": false,
|
|
11389
|
-
"showCmhkMain": false
|
|
11390
|
-
}
|
|
11391
|
-
}, 'cms-view', _vm.$attrs, false))], 1);
|
|
11392
|
-
};
|
|
11393
|
-
var staticRenderFns = [];
|
|
11394
|
-
|
|
11395
|
-
;// ./package/cms-column-card/View.vue?vue&type=template&id=2380364b&scoped=true
|
|
11396
|
-
|
|
11397
|
-
// EXTERNAL MODULE: ./node_modules/core-js/modules/es.array.push.js
|
|
11398
|
-
var es_array_push = __webpack_require__(4114);
|
|
11399
|
-
// EXTERNAL MODULE: ./package/baseComp.vue + 5 modules
|
|
11400
|
-
var baseComp = __webpack_require__(4272);
|
|
11401
|
-
// EXTERNAL MODULE: ./node_modules/vuedraggable/dist/vuedraggable.umd.js
|
|
11402
|
-
var vuedraggable_umd = __webpack_require__(1527);
|
|
11403
|
-
var vuedraggable_umd_default = /*#__PURE__*/__webpack_require__.n(vuedraggable_umd);
|
|
11404
|
-
// EXTERNAL MODULE: ./package/baseConfig.js
|
|
11405
|
-
var baseConfig = __webpack_require__(649);
|
|
11406
|
-
// EXTERNAL MODULE: ./src/views/standard_page.js
|
|
11407
|
-
var standard_page = __webpack_require__(8134);
|
|
11408
|
-
;// ./node_modules/thread-loader/dist/cjs.js!./node_modules/babel-loader/lib/index.js??clonedRuleSet-40.use[1]!./node_modules/babel-loader/lib/index.js??clonedRuleSet-41.use!./node_modules/@vue/vue-loader-v15/lib/index.js??vue-loader-options!./package/cms-column-card/View.vue?vue&type=script&lang=js
|
|
11409
|
-
|
|
11410
|
-
|
|
11411
|
-
|
|
11412
|
-
|
|
11413
|
-
|
|
11414
|
-
|
|
11415
|
-
/* harmony default export */ var Viewvue_type_script_lang_js = ({
|
|
11416
|
-
name: "cms-column-card",
|
|
11417
|
-
components: {
|
|
11418
|
-
BaseComp: baseComp["default"],
|
|
11419
|
-
Draggable: (vuedraggable_umd_default())
|
|
11420
|
-
},
|
|
11421
|
-
props: {
|
|
11422
|
-
data: {
|
|
11423
|
-
type: Object,
|
|
11424
|
-
default: () => {
|
|
11425
|
-
return {};
|
|
11426
|
-
}
|
|
11427
|
-
},
|
|
11428
|
-
nowCompId: {
|
|
11429
|
-
type: [String, Number],
|
|
11430
|
-
default: ""
|
|
11431
|
-
},
|
|
11432
|
-
isOpcacity: {
|
|
11433
|
-
type: Boolean,
|
|
11434
|
-
default: true
|
|
11435
|
-
},
|
|
11436
|
-
lang: {
|
|
11437
|
-
type: String,
|
|
11438
|
-
default: "zh-HK"
|
|
11439
|
-
},
|
|
11440
|
-
isMobile: {
|
|
11441
|
-
type: Boolean,
|
|
11442
|
-
default: false
|
|
11443
|
-
},
|
|
11444
|
-
mobileLayout: {
|
|
11445
|
-
type: String,
|
|
11446
|
-
default: ""
|
|
11447
|
-
}
|
|
11448
|
-
},
|
|
11449
|
-
data() {
|
|
11450
|
-
return {
|
|
11451
|
-
configData: {},
|
|
11452
|
-
messFold: true,
|
|
11453
|
-
showAddCom: false,
|
|
11454
|
-
temporaryList: []
|
|
11455
|
-
};
|
|
11456
|
-
},
|
|
11457
|
-
computed: {
|
|
11458
|
-
isConfigPage() {
|
|
11459
|
-
return this.$EventBus && this.isOpcacity;
|
|
11460
|
-
},
|
|
11461
|
-
groupConfigForMain() {
|
|
11462
|
-
return {
|
|
11463
|
-
name: "task",
|
|
11464
|
-
pull: true,
|
|
11465
|
-
// A列表的元素可以被拖出
|
|
11466
|
-
put: (to, from, dragEl) => {
|
|
11467
|
-
console.log(from.el.classList);
|
|
11468
|
-
if (from.el.classList.contains("main_drag")) {
|
|
11469
|
-
const dataId = this.findFirstComponentKey(dragEl);
|
|
11470
|
-
const allowedComponents = ["cms-text", "cms-image", "cms-video", "cms-button", "cms-richText", "cms-column"];
|
|
11471
|
-
console.log("allowedComponents", dataId);
|
|
11472
|
-
if (dataId === "cms-column") {
|
|
11473
|
-
if (!this.checkColumnNestingLevel()) {
|
|
11474
|
-
console.log("cms-column 嵌套层级超出限制");
|
|
11475
|
-
return false;
|
|
11476
|
-
}
|
|
11477
|
-
}
|
|
11478
|
-
return allowedComponents.includes(dataId);
|
|
11479
|
-
}
|
|
11480
|
-
return true;
|
|
11481
|
-
}
|
|
11482
|
-
};
|
|
11483
|
-
},
|
|
11484
|
-
// 卡片容器样式
|
|
11485
|
-
cardContainerStyle() {
|
|
11486
|
-
return {
|
|
11487
|
-
backgroundImage: this.configData.backgroundImage ? `url('${this.configData.backgroundImage}')` : "none",
|
|
11488
|
-
backgroundSize: "cover",
|
|
11489
|
-
backgroundRepeat: "no-repeat",
|
|
11490
|
-
backgroundPosition: "center center",
|
|
11491
|
-
height: this.getContainerHeight(),
|
|
11492
|
-
border: this.getContainerBorder(),
|
|
11493
|
-
borderRadius: this.getContainerBorderRadius(),
|
|
11494
|
-
backgroundColor: this.configData.backgroundColor || "transparent",
|
|
11495
|
-
boxShadow: this.configData.boxShadow || "none"
|
|
11496
|
-
};
|
|
11497
|
-
}
|
|
11498
|
-
},
|
|
11499
|
-
mounted() {
|
|
11500
|
-
if (this.$EventBus) {
|
|
11501
|
-
this.$EventBus.$on("handleDragEnd", () => {
|
|
11502
|
-
this.showAddCom = false;
|
|
11503
|
-
});
|
|
11504
|
-
}
|
|
11505
|
-
},
|
|
11506
|
-
watch: {},
|
|
11507
|
-
methods: {
|
|
11508
|
-
findFirstComponentKey(root) {
|
|
11509
|
-
var _root$querySelector;
|
|
11510
|
-
if (!root) return null;
|
|
11511
|
-
|
|
11512
|
-
// 若起点自身就有
|
|
11513
|
-
if (root.nodeType === 1 && root.hasAttribute("component-key")) {
|
|
11514
|
-
return root.getAttribute("component-key");
|
|
11515
|
-
}
|
|
11516
|
-
|
|
11517
|
-
// 向下查找第一个匹配的后代
|
|
11518
|
-
const el = (_root$querySelector = root.querySelector) === null || _root$querySelector === void 0 ? void 0 : _root$querySelector.call(root, "[component-key]");
|
|
11519
|
-
return el ? el.getAttribute("component-key") : null;
|
|
11520
|
-
},
|
|
11521
|
-
// 获取容器高度
|
|
11522
|
-
getContainerHeight() {
|
|
11523
|
-
if (this.configData.heightType === "fixed") {
|
|
11524
|
-
return `${this.configData.fixedHeight}px`;
|
|
11525
|
-
}
|
|
11526
|
-
return this.isMobile && this.mobileLayout == "vertical" ? "auto" : "100%";
|
|
11527
|
-
},
|
|
11528
|
-
// 获取容器边框
|
|
11529
|
-
getContainerBorder() {
|
|
11530
|
-
if (this.configData.borderWidth) {
|
|
11531
|
-
return `${this.configData.borderWidth}px ${this.configData.borderStyle} ${this.configData.borderColor}`;
|
|
11532
|
-
}
|
|
11533
|
-
return "none";
|
|
11534
|
-
},
|
|
11535
|
-
// 获取容器圆角
|
|
11536
|
-
getContainerBorderRadius() {
|
|
11537
|
-
if (this.configData.borderRadius) {
|
|
11538
|
-
return `${this.configData.borderRadius}px`;
|
|
11539
|
-
}
|
|
11540
|
-
return "0";
|
|
11541
|
-
},
|
|
11542
|
-
getConfigData(configData) {
|
|
11543
|
-
this.configData = configData;
|
|
11544
|
-
},
|
|
11545
|
-
foldMessText() {
|
|
11546
|
-
this.messFold = !this.messFold;
|
|
11547
|
-
},
|
|
11548
|
-
decodeJumpUrl(url) {
|
|
11549
|
-
if (!url) return;
|
|
11550
|
-
top.location.href = url;
|
|
11551
|
-
},
|
|
11552
|
-
onStart(evt) {
|
|
11553
|
-
console.log("drag start in column-card", evt);
|
|
11554
|
-
this.showAddCom = true;
|
|
11555
|
-
},
|
|
11556
|
-
// 限制拖拽的组件类型
|
|
11557
|
-
onMove(evt) {
|
|
11558
|
-
const {
|
|
11559
|
-
draggedContext
|
|
11560
|
-
} = evt;
|
|
11561
|
-
|
|
11562
|
-
// 允许的组件类型
|
|
11563
|
-
const allowedComponents = ["cms-text", "cms-image", "cms-video", "cms-button", "cms-richText", "cms-column" // 允许拖入 cms-column
|
|
11564
|
-
];
|
|
11565
|
-
|
|
11566
|
-
// 如果是从外部拖入的组件
|
|
11567
|
-
if (draggedContext && draggedContext.element) {
|
|
11568
|
-
const componentType = draggedContext.element.cmsCompName;
|
|
11569
|
-
if (componentType && !allowedComponents.includes(componentType)) {
|
|
11570
|
-
console.log("draggedContext.element", draggedContext.element);
|
|
11571
|
-
console.log(`组件类型 ${componentType} 不允许拖入 column-card`);
|
|
11572
|
-
return false;
|
|
11573
|
-
}
|
|
11574
|
-
|
|
11575
|
-
// 特殊处理 cms-column:检查嵌套层级
|
|
11576
|
-
if (componentType === "cms-column") {
|
|
11577
|
-
if (!this.checkColumnNestingLevel()) {
|
|
11578
|
-
console.log("cms-column 嵌套层级超出限制");
|
|
11579
|
-
return false;
|
|
11580
|
-
}
|
|
11581
|
-
}
|
|
11582
|
-
}
|
|
11583
|
-
return true;
|
|
11584
|
-
},
|
|
11585
|
-
// 检查 cms-column 嵌套层级
|
|
11586
|
-
checkColumnNestingLevel() {
|
|
11587
|
-
// 检查当前 column-card 是否已经在 cms-column 内部
|
|
11588
|
-
let parent = this.$parent;
|
|
11589
|
-
let columnDepth = 0;
|
|
11590
|
-
while (parent) {
|
|
11591
|
-
// 检查父组件是否是 cms-column 或包含 cms-column
|
|
11592
|
-
if (parent.$options.name === "cms-column" || parent.$data && parent.$data.data && parent.$data.data.cmsCompName === "cms-column") {
|
|
11593
|
-
columnDepth++;
|
|
11594
|
-
}
|
|
11595
|
-
|
|
11596
|
-
// 如果已经有一层 cms-column,则不允许再嵌套
|
|
11597
|
-
if (columnDepth >= 2) {
|
|
11598
|
-
console.log(`检测到 cms-column 嵌套层级: ${columnDepth}, 超出限制`);
|
|
11599
|
-
return false;
|
|
11600
|
-
}
|
|
11601
|
-
parent = parent.$parent;
|
|
11602
|
-
}
|
|
11603
|
-
console.log(`cms-column 嵌套层级检查通过: ${columnDepth}`);
|
|
11604
|
-
return true;
|
|
11605
|
-
},
|
|
11606
|
-
// 处理拖拽悬停
|
|
11607
|
-
dragover(e) {
|
|
11608
|
-
e.preventDefault();
|
|
11609
|
-
this.showAddCom = true;
|
|
11610
|
-
},
|
|
11611
|
-
// 处理拖拽放置
|
|
11612
|
-
drop(e) {
|
|
11613
|
-
e.preventDefault();
|
|
11614
|
-
const componentKey = e.dataTransfer.getData("componentKey");
|
|
11615
|
-
let temporaryId = "";
|
|
11616
|
-
this.temporaryList = e.dataTransfer.getData("temporaryList") ? JSON.parse(e.dataTransfer.getData("temporaryList")) : [];
|
|
11617
|
-
console.log("cms-colum-card-drop", componentKey, this.temporaryList);
|
|
11618
|
-
if (!componentKey) return;
|
|
11619
|
-
const isTemporaryItem = e.dataTransfer.getData("isTemporaryItem");
|
|
11620
|
-
const isTemporary = isTemporaryItem === "true";
|
|
11621
|
-
if (isTemporary) {
|
|
11622
|
-
temporaryId = (0,standard_page/* getCopyTemplateCompConfig */.L7)(this.temporaryList, componentKey).cmsCompName;
|
|
11623
|
-
}
|
|
11624
|
-
const componentType = isTemporary ? temporaryId : componentKey;
|
|
11625
|
-
// 允许的组件类型
|
|
11626
|
-
const allowedComponents = ["cms-text", "cms-image", "cms-video", "cms-button", "cms-richText", "cms-column" // 允许拖入 cms-column
|
|
11627
|
-
];
|
|
11628
|
-
|
|
11629
|
-
// 检查组件类型是否允许
|
|
11630
|
-
if (!allowedComponents.includes(componentType)) {
|
|
11631
|
-
console.log(`组件类型 ${componentType} 不允许拖入 column-card`);
|
|
11632
|
-
this.$message && this.$message.warning(`该组件类型不支持拖入卡片容器`);
|
|
11633
|
-
this.showAddCom = false;
|
|
11634
|
-
return;
|
|
11635
|
-
}
|
|
11636
|
-
|
|
11637
|
-
// 特殊处理 cms-column:检查嵌套层级
|
|
11638
|
-
if (componentType === "cms-column") {
|
|
11639
|
-
if (!this.checkColumnNestingLevel()) {
|
|
11640
|
-
console.log("cms-column 嵌套层级超出限制");
|
|
11641
|
-
this.$message && this.$message.warning(`cms-column 只能嵌套一层`);
|
|
11642
|
-
this.showAddCom = false;
|
|
11643
|
-
return;
|
|
11644
|
-
}
|
|
11645
|
-
}
|
|
11646
|
-
this.addOneComp(e, componentKey);
|
|
11647
|
-
},
|
|
11648
|
-
// 添加组件到卡片容器
|
|
11649
|
-
addOneComp(e, componentKey) {
|
|
11650
|
-
this.showAddCom = false;
|
|
11651
|
-
console.log("drop to column-card", componentKey);
|
|
11652
|
-
|
|
11653
|
-
// 动态导入组件配置
|
|
11654
|
-
let initCompData;
|
|
11655
|
-
try {
|
|
11656
|
-
const isTemporaryItem = e.dataTransfer.getData("isTemporaryItem");
|
|
11657
|
-
const isTemporary = isTemporaryItem === "true";
|
|
11658
|
-
if (isTemporary) {
|
|
11659
|
-
initCompData = (0,standard_page/* getCopyTemplateCompConfig */.L7)(this.temporaryList, componentKey);
|
|
11660
|
-
} else {
|
|
11661
|
-
initCompData = __webpack_require__(1640)(`./${componentKey}`).default.settings(componentKey);
|
|
11662
|
-
}
|
|
11663
|
-
if (!isTemporary) {
|
|
11664
|
-
initCompData = {
|
|
11665
|
-
...initCompData,
|
|
11666
|
-
styleConfig: {
|
|
11667
|
-
pc: componentKey == "cms-text" ? [...(0,baseConfig.styleBaseConfig)(16, 16, 0, 0, "px")] : [...(0,baseConfig.styleBaseConfig)(0, 0, 0, 0, "px")],
|
|
11668
|
-
mb: componentKey == "cms-text" ? [...(0,baseConfig.styleBaseConfig)(12, 12, 0, 0, "px")] : [...(0,baseConfig.styleBaseConfig)(0, 0, 0, 0, "px")]
|
|
11669
|
-
}
|
|
11670
|
-
};
|
|
11671
|
-
}
|
|
11672
|
-
} catch (error) {
|
|
11673
|
-
console.error(`无法加载组件 ${componentKey}:`, error);
|
|
11674
|
-
this.$message && this.$message.error(`组件加载失败`);
|
|
11675
|
-
return;
|
|
11676
|
-
}
|
|
11677
|
-
const toElementId = e.toElement.id;
|
|
11678
|
-
if (toElementId === `cardTarget${this.data.componentId}` || toElementId.includes("cardTargetdown")) {
|
|
11679
|
-
// 添加到卡片容器末尾
|
|
11680
|
-
this.data.childList.push(initCompData);
|
|
11681
|
-
} else if (toElementId.includes("cardTargetup")) {
|
|
11682
|
-
// 插入到指定位置
|
|
11683
|
-
const underComponentId = toElementId.split("-cardTargetup")[0];
|
|
11684
|
-
const index = this.data.childList.findIndex(item => item.componentId === underComponentId);
|
|
11685
|
-
if (index !== -1) {
|
|
11686
|
-
this.data.childList.splice(index, 0, initCompData);
|
|
11687
|
-
}
|
|
11688
|
-
}
|
|
11689
|
-
|
|
11690
|
-
// 触发数据更新
|
|
11691
|
-
this.$emit("update:data", this.data);
|
|
11692
|
-
if (componentKey === "cms-column") {
|
|
11693
|
-
this.$EventBus.$emit("handleNowComp", initCompData);
|
|
11694
|
-
}
|
|
11695
|
-
}
|
|
11696
|
-
}
|
|
11697
|
-
});
|
|
11698
|
-
;// ./package/cms-column-card/View.vue?vue&type=script&lang=js
|
|
11699
|
-
/* harmony default export */ var cms_column_card_Viewvue_type_script_lang_js = (Viewvue_type_script_lang_js);
|
|
11700
|
-
;// ./node_modules/mini-css-extract-plugin/dist/loader.js??clonedRuleSet-22.use[0]!./node_modules/css-loader/dist/cjs.js??clonedRuleSet-22.use[1]!./node_modules/@vue/vue-loader-v15/lib/loaders/stylePostLoader.js!./node_modules/postcss-loader/dist/cjs.js??clonedRuleSet-22.use[2]!./node_modules/sass-loader/dist/cjs.js??clonedRuleSet-22.use[3]!./node_modules/sass-loader/dist/cjs.js??clonedRuleSet-42.use[0]!./node_modules/@vue/vue-loader-v15/lib/index.js??vue-loader-options!./package/cms-column-card/View.vue?vue&type=style&index=0&id=2380364b&prod&lang=scss&scoped=true
|
|
11701
|
-
// extracted by mini-css-extract-plugin
|
|
11702
|
-
|
|
11703
|
-
;// ./package/cms-column-card/View.vue?vue&type=style&index=0&id=2380364b&prod&lang=scss&scoped=true
|
|
11704
|
-
|
|
11705
|
-
// EXTERNAL MODULE: ./node_modules/@vue/vue-loader-v15/lib/runtime/componentNormalizer.js
|
|
11706
|
-
var componentNormalizer = __webpack_require__(1656);
|
|
11707
|
-
;// ./package/cms-column-card/View.vue
|
|
11708
|
-
|
|
11709
|
-
|
|
11710
|
-
|
|
11711
|
-
;
|
|
11712
|
-
|
|
11713
|
-
|
|
11714
|
-
/* normalize component */
|
|
11715
|
-
|
|
11716
|
-
var component = (0,componentNormalizer/* default */.A)(
|
|
11717
|
-
cms_column_card_Viewvue_type_script_lang_js,
|
|
11718
|
-
render,
|
|
11719
|
-
staticRenderFns,
|
|
11720
|
-
false,
|
|
11721
|
-
null,
|
|
11722
|
-
"2380364b",
|
|
11723
|
-
null
|
|
11724
|
-
|
|
11725
|
-
)
|
|
11726
|
-
|
|
11727
|
-
/* harmony default export */ var View = (component.exports);
|
|
11278
|
+
module.exports = "";
|
|
11728
11279
|
|
|
11729
11280
|
/***/ }),
|
|
11730
11281
|
|
|
@@ -12740,6 +12291,470 @@ test[TO_STRING_TAG] = 'z';
|
|
|
12740
12291
|
module.exports = String(test) === '[object z]';
|
|
12741
12292
|
|
|
12742
12293
|
|
|
12294
|
+
/***/ }),
|
|
12295
|
+
|
|
12296
|
+
/***/ 2159:
|
|
12297
|
+
/***/ (function(__unused_webpack_module, __webpack_exports__, __webpack_require__) {
|
|
12298
|
+
|
|
12299
|
+
"use strict";
|
|
12300
|
+
// ESM COMPAT FLAG
|
|
12301
|
+
__webpack_require__.r(__webpack_exports__);
|
|
12302
|
+
|
|
12303
|
+
// EXPORTS
|
|
12304
|
+
__webpack_require__.d(__webpack_exports__, {
|
|
12305
|
+
"default": function() { return /* binding */ View; }
|
|
12306
|
+
});
|
|
12307
|
+
|
|
12308
|
+
// EXTERNAL MODULE: ./node_modules/core-js/modules/es.iterator.constructor.js
|
|
12309
|
+
var es_iterator_constructor = __webpack_require__(8111);
|
|
12310
|
+
// EXTERNAL MODULE: ./node_modules/core-js/modules/es.iterator.drop.js
|
|
12311
|
+
var es_iterator_drop = __webpack_require__(9314);
|
|
12312
|
+
;// ./node_modules/thread-loader/dist/cjs.js!./node_modules/babel-loader/lib/index.js??clonedRuleSet-40.use[1]!./node_modules/babel-loader/lib/index.js??clonedRuleSet-41.use!./node_modules/@vue/vue-loader-v15/lib/loaders/templateLoader.js??ruleSet[1].rules[4]!./node_modules/@vue/vue-loader-v15/lib/index.js??vue-loader-options!./package/cms-column-card/View.vue?vue&type=template&id=155a8242&scoped=true
|
|
12313
|
+
|
|
12314
|
+
|
|
12315
|
+
|
|
12316
|
+
|
|
12317
|
+
var render = function render() {
|
|
12318
|
+
var _vm = this,
|
|
12319
|
+
_c = _vm._self._c;
|
|
12320
|
+
return _c('BaseComp', _vm._b({
|
|
12321
|
+
attrs: {
|
|
12322
|
+
"data": _vm.data,
|
|
12323
|
+
"nowCompId": _vm.nowCompId,
|
|
12324
|
+
"isOpcacity": _vm.isOpcacity,
|
|
12325
|
+
"isMask": false,
|
|
12326
|
+
"lang": _vm.lang,
|
|
12327
|
+
"showDel": false
|
|
12328
|
+
},
|
|
12329
|
+
on: {
|
|
12330
|
+
"getConfigData": _vm.getConfigData
|
|
12331
|
+
}
|
|
12332
|
+
}, 'BaseComp', _vm.$attrs, false), [_vm.isConfigPage ? _c('div', {
|
|
12333
|
+
staticClass: "main_drag hoverBorderClass",
|
|
12334
|
+
style: _vm.cardContainerStyle,
|
|
12335
|
+
attrs: {
|
|
12336
|
+
"id": `cardTarget${_vm.data.componentId}`
|
|
12337
|
+
},
|
|
12338
|
+
on: {
|
|
12339
|
+
"dragover": _vm.dragover,
|
|
12340
|
+
"dragend": function ($event) {
|
|
12341
|
+
_vm.showAddCom = false;
|
|
12342
|
+
},
|
|
12343
|
+
"drop": _vm.drop
|
|
12344
|
+
}
|
|
12345
|
+
}, [_c('Draggable', {
|
|
12346
|
+
staticStyle: {
|
|
12347
|
+
"position": "relative"
|
|
12348
|
+
},
|
|
12349
|
+
attrs: {
|
|
12350
|
+
"group": _vm.groupConfigForMain,
|
|
12351
|
+
"chosen-class": "chosen",
|
|
12352
|
+
"force-fallback": "true",
|
|
12353
|
+
"animation": "1000",
|
|
12354
|
+
"move": _vm.onMove
|
|
12355
|
+
},
|
|
12356
|
+
on: {
|
|
12357
|
+
"start": _vm.onStart,
|
|
12358
|
+
"end": function ($event) {
|
|
12359
|
+
_vm.showAddCom = false;
|
|
12360
|
+
}
|
|
12361
|
+
},
|
|
12362
|
+
model: {
|
|
12363
|
+
value: _vm.data.childList,
|
|
12364
|
+
callback: function ($$v) {
|
|
12365
|
+
_vm.$set(_vm.data, "childList", $$v);
|
|
12366
|
+
},
|
|
12367
|
+
expression: "data.childList"
|
|
12368
|
+
}
|
|
12369
|
+
}, [_vm._l(_vm.data.childList, function (item, index) {
|
|
12370
|
+
return _c('div', {
|
|
12371
|
+
key: item.componentId,
|
|
12372
|
+
staticStyle: {
|
|
12373
|
+
"position": "relative"
|
|
12374
|
+
}
|
|
12375
|
+
}, [_vm.showAddCom ? _c('div', {
|
|
12376
|
+
staticClass: "up_insert",
|
|
12377
|
+
attrs: {
|
|
12378
|
+
"id": `${item.componentId}-cardTargetup`
|
|
12379
|
+
}
|
|
12380
|
+
}, [_c('i', {
|
|
12381
|
+
staticClass: "icon-up",
|
|
12382
|
+
attrs: {
|
|
12383
|
+
"id": `${item.componentId}-upi`
|
|
12384
|
+
}
|
|
12385
|
+
}), _c('span', {
|
|
12386
|
+
attrs: {
|
|
12387
|
+
"id": `${item.componentId}-upspan`
|
|
12388
|
+
}
|
|
12389
|
+
}, [_vm._v("插入组件")])]) : _vm._e(), _c(item.cmsCompName, {
|
|
12390
|
+
tag: "component",
|
|
12391
|
+
style: {
|
|
12392
|
+
marginTop: _vm.showAddCom && index == 0 ? '20px' : '0px'
|
|
12393
|
+
},
|
|
12394
|
+
attrs: {
|
|
12395
|
+
"data": item,
|
|
12396
|
+
"lang": _vm.lang,
|
|
12397
|
+
"isOpcacity": _vm.isOpcacity,
|
|
12398
|
+
"nowCompId": _vm.nowCompId,
|
|
12399
|
+
"showCmhkMain": false
|
|
12400
|
+
}
|
|
12401
|
+
})], 1);
|
|
12402
|
+
}), _vm.showAddCom ? _c('div', {
|
|
12403
|
+
staticClass: "up_insert insert_bottom",
|
|
12404
|
+
style: {
|
|
12405
|
+
bottom: _vm.data.childList.length ? '0px' : '-24px'
|
|
12406
|
+
},
|
|
12407
|
+
attrs: {
|
|
12408
|
+
"id": `-cardTargetdown`
|
|
12409
|
+
}
|
|
12410
|
+
}, [_c('i', {
|
|
12411
|
+
staticClass: "icon-up"
|
|
12412
|
+
}), _c('span', [_vm._v("插入组件")])]) : _vm._e()], 2)], 1) : _c('cms-view', _vm._b({
|
|
12413
|
+
style: _vm.cardContainerStyle,
|
|
12414
|
+
attrs: {
|
|
12415
|
+
"data": _vm.data.childList,
|
|
12416
|
+
"lang": _vm.lang,
|
|
12417
|
+
"isOpcacity": false,
|
|
12418
|
+
"showCmhkMain": false
|
|
12419
|
+
}
|
|
12420
|
+
}, 'cms-view', _vm.$attrs, false))], 1);
|
|
12421
|
+
};
|
|
12422
|
+
var staticRenderFns = [];
|
|
12423
|
+
|
|
12424
|
+
;// ./package/cms-column-card/View.vue?vue&type=template&id=155a8242&scoped=true
|
|
12425
|
+
|
|
12426
|
+
// EXTERNAL MODULE: ./node_modules/core-js/modules/es.array.push.js
|
|
12427
|
+
var es_array_push = __webpack_require__(4114);
|
|
12428
|
+
// EXTERNAL MODULE: ./package/baseComp.vue + 5 modules
|
|
12429
|
+
var baseComp = __webpack_require__(4272);
|
|
12430
|
+
// EXTERNAL MODULE: ./node_modules/vuedraggable/dist/vuedraggable.umd.js
|
|
12431
|
+
var vuedraggable_umd = __webpack_require__(1527);
|
|
12432
|
+
var vuedraggable_umd_default = /*#__PURE__*/__webpack_require__.n(vuedraggable_umd);
|
|
12433
|
+
// EXTERNAL MODULE: ./package/baseConfig.js
|
|
12434
|
+
var baseConfig = __webpack_require__(649);
|
|
12435
|
+
// EXTERNAL MODULE: ./src/views/standard_page.js
|
|
12436
|
+
var standard_page = __webpack_require__(8134);
|
|
12437
|
+
;// ./node_modules/thread-loader/dist/cjs.js!./node_modules/babel-loader/lib/index.js??clonedRuleSet-40.use[1]!./node_modules/babel-loader/lib/index.js??clonedRuleSet-41.use!./node_modules/@vue/vue-loader-v15/lib/index.js??vue-loader-options!./package/cms-column-card/View.vue?vue&type=script&lang=js
|
|
12438
|
+
|
|
12439
|
+
|
|
12440
|
+
|
|
12441
|
+
|
|
12442
|
+
|
|
12443
|
+
|
|
12444
|
+
/* harmony default export */ var Viewvue_type_script_lang_js = ({
|
|
12445
|
+
name: "cms-column-card",
|
|
12446
|
+
components: {
|
|
12447
|
+
BaseComp: baseComp["default"],
|
|
12448
|
+
Draggable: (vuedraggable_umd_default())
|
|
12449
|
+
},
|
|
12450
|
+
props: {
|
|
12451
|
+
data: {
|
|
12452
|
+
type: Object,
|
|
12453
|
+
default: () => {
|
|
12454
|
+
return {};
|
|
12455
|
+
}
|
|
12456
|
+
},
|
|
12457
|
+
nowCompId: {
|
|
12458
|
+
type: [String, Number],
|
|
12459
|
+
default: ""
|
|
12460
|
+
},
|
|
12461
|
+
isOpcacity: {
|
|
12462
|
+
type: Boolean,
|
|
12463
|
+
default: true
|
|
12464
|
+
},
|
|
12465
|
+
lang: {
|
|
12466
|
+
type: String,
|
|
12467
|
+
default: "zh-HK"
|
|
12468
|
+
},
|
|
12469
|
+
isMobile: {
|
|
12470
|
+
type: Boolean,
|
|
12471
|
+
default: false
|
|
12472
|
+
},
|
|
12473
|
+
mobileLayout: {
|
|
12474
|
+
type: String,
|
|
12475
|
+
default: ""
|
|
12476
|
+
}
|
|
12477
|
+
},
|
|
12478
|
+
data() {
|
|
12479
|
+
return {
|
|
12480
|
+
configData: {},
|
|
12481
|
+
messFold: true,
|
|
12482
|
+
showAddCom: false,
|
|
12483
|
+
temporaryList: []
|
|
12484
|
+
};
|
|
12485
|
+
},
|
|
12486
|
+
computed: {
|
|
12487
|
+
isConfigPage() {
|
|
12488
|
+
return this.$EventBus && this.isOpcacity;
|
|
12489
|
+
},
|
|
12490
|
+
groupConfigForMain() {
|
|
12491
|
+
return {
|
|
12492
|
+
name: "task",
|
|
12493
|
+
pull: true,
|
|
12494
|
+
// A列表的元素可以被拖出
|
|
12495
|
+
put: (to, from, dragEl) => {
|
|
12496
|
+
console.log(from.el.classList);
|
|
12497
|
+
if (from.el.classList.contains("main_drag")) {
|
|
12498
|
+
const dataId = this.findFirstComponentKey(dragEl);
|
|
12499
|
+
const allowedComponents = ["cms-text", "cms-image", "cms-video", "cms-button", "cms-richText", "cms-column"];
|
|
12500
|
+
console.log("allowedComponents", dataId);
|
|
12501
|
+
if (dataId === "cms-column") {
|
|
12502
|
+
if (!this.checkColumnNestingLevel()) {
|
|
12503
|
+
console.log("cms-column 嵌套层级超出限制");
|
|
12504
|
+
return false;
|
|
12505
|
+
}
|
|
12506
|
+
}
|
|
12507
|
+
return allowedComponents.includes(dataId);
|
|
12508
|
+
}
|
|
12509
|
+
return true;
|
|
12510
|
+
}
|
|
12511
|
+
};
|
|
12512
|
+
},
|
|
12513
|
+
// 卡片容器样式
|
|
12514
|
+
cardContainerStyle() {
|
|
12515
|
+
return {
|
|
12516
|
+
backgroundImage: this.configData.backgroundImage ? `url('${this.configData.backgroundImage}')` : "none",
|
|
12517
|
+
backgroundSize: "cover",
|
|
12518
|
+
backgroundRepeat: "no-repeat",
|
|
12519
|
+
backgroundPosition: "center center",
|
|
12520
|
+
height: this.getContainerHeight(),
|
|
12521
|
+
border: this.getContainerBorder(),
|
|
12522
|
+
borderRadius: this.getContainerBorderRadius(),
|
|
12523
|
+
backgroundColor: this.configData.backgroundColor || "transparent",
|
|
12524
|
+
boxShadow: this.configData.boxShadow || "none"
|
|
12525
|
+
};
|
|
12526
|
+
}
|
|
12527
|
+
},
|
|
12528
|
+
mounted() {
|
|
12529
|
+
if (this.$EventBus) {
|
|
12530
|
+
this.$EventBus.$on("handleDragEnd", () => {
|
|
12531
|
+
this.showAddCom = false;
|
|
12532
|
+
});
|
|
12533
|
+
}
|
|
12534
|
+
},
|
|
12535
|
+
watch: {},
|
|
12536
|
+
methods: {
|
|
12537
|
+
findFirstComponentKey(root) {
|
|
12538
|
+
var _root$querySelector;
|
|
12539
|
+
if (!root) return null;
|
|
12540
|
+
|
|
12541
|
+
// 若起点自身就有
|
|
12542
|
+
if (root.nodeType === 1 && root.hasAttribute("component-key")) {
|
|
12543
|
+
return root.getAttribute("component-key");
|
|
12544
|
+
}
|
|
12545
|
+
|
|
12546
|
+
// 向下查找第一个匹配的后代
|
|
12547
|
+
const el = (_root$querySelector = root.querySelector) === null || _root$querySelector === void 0 ? void 0 : _root$querySelector.call(root, "[component-key]");
|
|
12548
|
+
return el ? el.getAttribute("component-key") : null;
|
|
12549
|
+
},
|
|
12550
|
+
// 获取容器高度
|
|
12551
|
+
getContainerHeight() {
|
|
12552
|
+
if (this.configData.heightType === "fixed") {
|
|
12553
|
+
return `${this.configData.fixedHeight}px`;
|
|
12554
|
+
}
|
|
12555
|
+
return this.isMobile && this.mobileLayout == "vertical" ? "auto" : "100%";
|
|
12556
|
+
},
|
|
12557
|
+
// 获取容器边框
|
|
12558
|
+
getContainerBorder() {
|
|
12559
|
+
if (this.configData.borderWidth) {
|
|
12560
|
+
return `${this.configData.borderWidth}px ${this.configData.borderStyle} ${this.configData.borderColor}`;
|
|
12561
|
+
}
|
|
12562
|
+
return "none";
|
|
12563
|
+
},
|
|
12564
|
+
// 获取容器圆角
|
|
12565
|
+
getContainerBorderRadius() {
|
|
12566
|
+
if (this.configData.borderRadius) {
|
|
12567
|
+
return `${this.configData.borderRadius}px`;
|
|
12568
|
+
}
|
|
12569
|
+
return "0";
|
|
12570
|
+
},
|
|
12571
|
+
getConfigData(configData) {
|
|
12572
|
+
this.configData = configData;
|
|
12573
|
+
},
|
|
12574
|
+
foldMessText() {
|
|
12575
|
+
this.messFold = !this.messFold;
|
|
12576
|
+
},
|
|
12577
|
+
decodeJumpUrl(url) {
|
|
12578
|
+
if (!url) return;
|
|
12579
|
+
top.location.href = url;
|
|
12580
|
+
},
|
|
12581
|
+
onStart(evt) {
|
|
12582
|
+
console.log("drag start in column-card", evt);
|
|
12583
|
+
this.showAddCom = true;
|
|
12584
|
+
},
|
|
12585
|
+
// 限制拖拽的组件类型
|
|
12586
|
+
onMove(evt) {
|
|
12587
|
+
const {
|
|
12588
|
+
draggedContext
|
|
12589
|
+
} = evt;
|
|
12590
|
+
|
|
12591
|
+
// 允许的组件类型
|
|
12592
|
+
const allowedComponents = ["cms-text", "cms-image", "cms-video", "cms-button", "cms-richText", "cms-column" // 允许拖入 cms-column
|
|
12593
|
+
];
|
|
12594
|
+
|
|
12595
|
+
// 如果是从外部拖入的组件
|
|
12596
|
+
if (draggedContext && draggedContext.element) {
|
|
12597
|
+
const componentType = draggedContext.element.cmsCompName;
|
|
12598
|
+
if (componentType && !allowedComponents.includes(componentType)) {
|
|
12599
|
+
console.log("draggedContext.element", draggedContext.element);
|
|
12600
|
+
console.log(`组件类型 ${componentType} 不允许拖入 column-card`);
|
|
12601
|
+
return false;
|
|
12602
|
+
}
|
|
12603
|
+
|
|
12604
|
+
// 特殊处理 cms-column:检查嵌套层级
|
|
12605
|
+
if (componentType === "cms-column") {
|
|
12606
|
+
if (!this.checkColumnNestingLevel()) {
|
|
12607
|
+
console.log("cms-column 嵌套层级超出限制");
|
|
12608
|
+
return false;
|
|
12609
|
+
}
|
|
12610
|
+
}
|
|
12611
|
+
}
|
|
12612
|
+
return true;
|
|
12613
|
+
},
|
|
12614
|
+
// 检查 cms-column 嵌套层级
|
|
12615
|
+
checkColumnNestingLevel() {
|
|
12616
|
+
// 检查当前 column-card 是否已经在 cms-column 内部
|
|
12617
|
+
let parent = this.$parent;
|
|
12618
|
+
let columnDepth = 0;
|
|
12619
|
+
while (parent) {
|
|
12620
|
+
// 检查父组件是否是 cms-column 或包含 cms-column
|
|
12621
|
+
if (parent.$options.name === "cms-column" || parent.$data && parent.$data.data && parent.$data.data.cmsCompName === "cms-column") {
|
|
12622
|
+
columnDepth++;
|
|
12623
|
+
}
|
|
12624
|
+
|
|
12625
|
+
// 如果已经有一层 cms-column,则不允许再嵌套
|
|
12626
|
+
if (columnDepth >= 2) {
|
|
12627
|
+
console.log(`检测到 cms-column 嵌套层级: ${columnDepth}, 超出限制`);
|
|
12628
|
+
return false;
|
|
12629
|
+
}
|
|
12630
|
+
parent = parent.$parent;
|
|
12631
|
+
}
|
|
12632
|
+
console.log(`cms-column 嵌套层级检查通过: ${columnDepth}`);
|
|
12633
|
+
return true;
|
|
12634
|
+
},
|
|
12635
|
+
// 处理拖拽悬停
|
|
12636
|
+
dragover(e) {
|
|
12637
|
+
e.preventDefault();
|
|
12638
|
+
this.showAddCom = true;
|
|
12639
|
+
},
|
|
12640
|
+
// 处理拖拽放置
|
|
12641
|
+
drop(e) {
|
|
12642
|
+
e.preventDefault();
|
|
12643
|
+
const componentKey = e.dataTransfer.getData("componentKey");
|
|
12644
|
+
let temporaryId = "";
|
|
12645
|
+
this.temporaryList = e.dataTransfer.getData("temporaryList") ? JSON.parse(e.dataTransfer.getData("temporaryList")) : [];
|
|
12646
|
+
console.log("cms-colum-card-drop", componentKey, this.temporaryList);
|
|
12647
|
+
if (!componentKey) return;
|
|
12648
|
+
const isTemporaryItem = e.dataTransfer.getData("isTemporaryItem");
|
|
12649
|
+
const isTemporary = isTemporaryItem === "true";
|
|
12650
|
+
if (isTemporary) {
|
|
12651
|
+
temporaryId = (0,standard_page/* getCopyTemplateCompConfig */.L7)(this.temporaryList, componentKey).cmsCompName;
|
|
12652
|
+
}
|
|
12653
|
+
const componentType = isTemporary ? temporaryId : componentKey;
|
|
12654
|
+
// 允许的组件类型
|
|
12655
|
+
const allowedComponents = ["cms-text", "cms-image", "cms-video", "cms-button", "cms-richText", "cms-column" // 允许拖入 cms-column
|
|
12656
|
+
];
|
|
12657
|
+
|
|
12658
|
+
// 检查组件类型是否允许
|
|
12659
|
+
if (!allowedComponents.includes(componentType)) {
|
|
12660
|
+
console.log(`组件类型 ${componentType} 不允许拖入 column-card`);
|
|
12661
|
+
this.$message && this.$message.warning(`该组件类型不支持拖入卡片容器`);
|
|
12662
|
+
this.showAddCom = false;
|
|
12663
|
+
return;
|
|
12664
|
+
}
|
|
12665
|
+
|
|
12666
|
+
// 特殊处理 cms-column:检查嵌套层级
|
|
12667
|
+
if (componentType === "cms-column") {
|
|
12668
|
+
if (!this.checkColumnNestingLevel()) {
|
|
12669
|
+
console.log("cms-column 嵌套层级超出限制");
|
|
12670
|
+
this.$message && this.$message.warning(`cms-column 只能嵌套一层`);
|
|
12671
|
+
this.showAddCom = false;
|
|
12672
|
+
return;
|
|
12673
|
+
}
|
|
12674
|
+
}
|
|
12675
|
+
this.addOneComp(e, componentKey);
|
|
12676
|
+
},
|
|
12677
|
+
// 添加组件到卡片容器
|
|
12678
|
+
addOneComp(e, componentKey) {
|
|
12679
|
+
this.showAddCom = false;
|
|
12680
|
+
console.log("drop to column-card", componentKey);
|
|
12681
|
+
|
|
12682
|
+
// 动态导入组件配置
|
|
12683
|
+
let initCompData;
|
|
12684
|
+
try {
|
|
12685
|
+
const isTemporaryItem = e.dataTransfer.getData("isTemporaryItem");
|
|
12686
|
+
const isTemporary = isTemporaryItem === "true";
|
|
12687
|
+
if (isTemporary) {
|
|
12688
|
+
initCompData = (0,standard_page/* getCopyTemplateCompConfig */.L7)(this.temporaryList, componentKey);
|
|
12689
|
+
} else {
|
|
12690
|
+
initCompData = __webpack_require__(1640)(`./${componentKey}`).default.settings(componentKey);
|
|
12691
|
+
}
|
|
12692
|
+
if (!isTemporary) {
|
|
12693
|
+
initCompData = {
|
|
12694
|
+
...initCompData,
|
|
12695
|
+
styleConfig: {
|
|
12696
|
+
pc: componentKey == "cms-text" ? [...(0,baseConfig.styleBaseConfig)(16, 16, 0, 0, "px")] : [...(0,baseConfig.styleBaseConfig)(0, 0, 0, 0, "px")],
|
|
12697
|
+
mb: componentKey == "cms-text" ? [...(0,baseConfig.styleBaseConfig)(12, 12, 0, 0, "px")] : [...(0,baseConfig.styleBaseConfig)(0, 0, 0, 0, "px")]
|
|
12698
|
+
}
|
|
12699
|
+
};
|
|
12700
|
+
}
|
|
12701
|
+
} catch (error) {
|
|
12702
|
+
console.error(`无法加载组件 ${componentKey}:`, error);
|
|
12703
|
+
this.$message && this.$message.error(`组件加载失败`);
|
|
12704
|
+
return;
|
|
12705
|
+
}
|
|
12706
|
+
const toElementId = e.toElement.id;
|
|
12707
|
+
if (toElementId === `cardTarget${this.data.componentId}` || toElementId.includes("cardTargetdown")) {
|
|
12708
|
+
// 添加到卡片容器末尾
|
|
12709
|
+
this.data.childList.push(initCompData);
|
|
12710
|
+
} else if (toElementId.includes("cardTargetup")) {
|
|
12711
|
+
// 插入到指定位置
|
|
12712
|
+
const underComponentId = toElementId.split("-cardTargetup")[0];
|
|
12713
|
+
const index = this.data.childList.findIndex(item => item.componentId === underComponentId);
|
|
12714
|
+
if (index !== -1) {
|
|
12715
|
+
this.data.childList.splice(index, 0, initCompData);
|
|
12716
|
+
}
|
|
12717
|
+
}
|
|
12718
|
+
|
|
12719
|
+
// 触发数据更新
|
|
12720
|
+
this.$emit("update:data", this.data);
|
|
12721
|
+
if (componentKey === "cms-column") {
|
|
12722
|
+
this.$EventBus.$emit("handleNowComp", initCompData);
|
|
12723
|
+
}
|
|
12724
|
+
}
|
|
12725
|
+
}
|
|
12726
|
+
});
|
|
12727
|
+
;// ./package/cms-column-card/View.vue?vue&type=script&lang=js
|
|
12728
|
+
/* harmony default export */ var cms_column_card_Viewvue_type_script_lang_js = (Viewvue_type_script_lang_js);
|
|
12729
|
+
;// ./node_modules/mini-css-extract-plugin/dist/loader.js??clonedRuleSet-22.use[0]!./node_modules/css-loader/dist/cjs.js??clonedRuleSet-22.use[1]!./node_modules/@vue/vue-loader-v15/lib/loaders/stylePostLoader.js!./node_modules/postcss-loader/dist/cjs.js??clonedRuleSet-22.use[2]!./node_modules/sass-loader/dist/cjs.js??clonedRuleSet-22.use[3]!./node_modules/sass-loader/dist/cjs.js??clonedRuleSet-42.use[0]!./node_modules/@vue/vue-loader-v15/lib/index.js??vue-loader-options!./package/cms-column-card/View.vue?vue&type=style&index=0&id=155a8242&prod&lang=scss&scoped=true
|
|
12730
|
+
// extracted by mini-css-extract-plugin
|
|
12731
|
+
|
|
12732
|
+
;// ./package/cms-column-card/View.vue?vue&type=style&index=0&id=155a8242&prod&lang=scss&scoped=true
|
|
12733
|
+
|
|
12734
|
+
// EXTERNAL MODULE: ./node_modules/@vue/vue-loader-v15/lib/runtime/componentNormalizer.js
|
|
12735
|
+
var componentNormalizer = __webpack_require__(1656);
|
|
12736
|
+
;// ./package/cms-column-card/View.vue
|
|
12737
|
+
|
|
12738
|
+
|
|
12739
|
+
|
|
12740
|
+
;
|
|
12741
|
+
|
|
12742
|
+
|
|
12743
|
+
/* normalize component */
|
|
12744
|
+
|
|
12745
|
+
var component = (0,componentNormalizer/* default */.A)(
|
|
12746
|
+
cms_column_card_Viewvue_type_script_lang_js,
|
|
12747
|
+
render,
|
|
12748
|
+
staticRenderFns,
|
|
12749
|
+
false,
|
|
12750
|
+
null,
|
|
12751
|
+
"155a8242",
|
|
12752
|
+
null
|
|
12753
|
+
|
|
12754
|
+
)
|
|
12755
|
+
|
|
12756
|
+
/* harmony default export */ var View = (component.exports);
|
|
12757
|
+
|
|
12743
12758
|
/***/ }),
|
|
12744
12759
|
|
|
12745
12760
|
/***/ 2195:
|
|
@@ -12766,7 +12781,7 @@ module.exports = function (it) {
|
|
|
12766
12781
|
__webpack_require__.r(__webpack_exports__);
|
|
12767
12782
|
/* harmony import */ var _baseConfig__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(649);
|
|
12768
12783
|
|
|
12769
|
-
const View = () => Promise.resolve(/* import() */).then(__webpack_require__.bind(__webpack_require__,
|
|
12784
|
+
const View = () => Promise.resolve(/* import() */).then(__webpack_require__.bind(__webpack_require__, 4018));
|
|
12770
12785
|
const langData = {
|
|
12771
12786
|
// 文字设置
|
|
12772
12787
|
buttonText: "按钮文字",
|
|
@@ -12777,7 +12792,7 @@ const langData = {
|
|
|
12777
12792
|
fontColor: "#ffffff",
|
|
12778
12793
|
fontWeight: "normal",
|
|
12779
12794
|
// 样式控制
|
|
12780
|
-
backgroundColor: "#
|
|
12795
|
+
backgroundColor: "#2f85ff",
|
|
12781
12796
|
borderRadius: 30,
|
|
12782
12797
|
borderWidth: 1,
|
|
12783
12798
|
borderStyle: "solid",
|
|
@@ -12840,11 +12855,11 @@ const configDataType = (0,_baseConfig__WEBPACK_IMPORTED_MODULE_0__.getLangDataTy
|
|
|
12840
12855
|
data.borderColor = "#409eff";
|
|
12841
12856
|
// data.wrapperBackgroundColor = "#fff";
|
|
12842
12857
|
} else if (value == "bg-gray") {
|
|
12843
|
-
data.backgroundColor = "#
|
|
12844
|
-
data.fontColor = "#
|
|
12858
|
+
data.backgroundColor = "#fff";
|
|
12859
|
+
data.fontColor = "#191919";
|
|
12845
12860
|
data.borderWidth = 1;
|
|
12846
12861
|
data.borderStyle = "solid";
|
|
12847
|
-
data.borderColor = "#
|
|
12862
|
+
data.borderColor = "#888888";
|
|
12848
12863
|
// data.wrapperBackgroundColor = "#979797";
|
|
12849
12864
|
}
|
|
12850
12865
|
}
|
|
@@ -28162,6 +28177,286 @@ module.exports = function isAbsoluteURL(url) {
|
|
|
28162
28177
|
|
|
28163
28178
|
/***/ }),
|
|
28164
28179
|
|
|
28180
|
+
/***/ 4018:
|
|
28181
|
+
/***/ (function(__unused_webpack_module, __webpack_exports__, __webpack_require__) {
|
|
28182
|
+
|
|
28183
|
+
"use strict";
|
|
28184
|
+
// ESM COMPAT FLAG
|
|
28185
|
+
__webpack_require__.r(__webpack_exports__);
|
|
28186
|
+
|
|
28187
|
+
// EXPORTS
|
|
28188
|
+
__webpack_require__.d(__webpack_exports__, {
|
|
28189
|
+
"default": function() { return /* binding */ View; }
|
|
28190
|
+
});
|
|
28191
|
+
|
|
28192
|
+
;// ./node_modules/thread-loader/dist/cjs.js!./node_modules/babel-loader/lib/index.js??clonedRuleSet-40.use[1]!./node_modules/babel-loader/lib/index.js??clonedRuleSet-41.use!./node_modules/@vue/vue-loader-v15/lib/loaders/templateLoader.js??ruleSet[1].rules[4]!./node_modules/@vue/vue-loader-v15/lib/index.js??vue-loader-options!./package/cms-button/View.vue?vue&type=template&id=12ff304e&scoped=true
|
|
28193
|
+
var render = function render() {
|
|
28194
|
+
var _vm = this,
|
|
28195
|
+
_c = _vm._self._c;
|
|
28196
|
+
return _c('BaseComp', _vm._b({
|
|
28197
|
+
attrs: {
|
|
28198
|
+
"data": _vm.data,
|
|
28199
|
+
"nowCompId": _vm.nowCompId,
|
|
28200
|
+
"isOpcacity": _vm.isOpcacity,
|
|
28201
|
+
"lang": _vm.lang
|
|
28202
|
+
},
|
|
28203
|
+
on: {
|
|
28204
|
+
"getConfigData": _vm.getConfigData
|
|
28205
|
+
}
|
|
28206
|
+
}, 'BaseComp', _vm.$attrs, false), [_c('section', {
|
|
28207
|
+
staticClass: "cms-button-container",
|
|
28208
|
+
class: [`align-${_vm.configData.textAlign || 'center'}`, _vm.configData.customClass || ''],
|
|
28209
|
+
style: _vm.containerStyle
|
|
28210
|
+
}, [_c('button', {
|
|
28211
|
+
staticClass: "cms-button",
|
|
28212
|
+
class: ['cms-button-element', {
|
|
28213
|
+
'has-link': _vm.configData.linkUrl,
|
|
28214
|
+
'hover-effect': _vm.configData.hoverEffect
|
|
28215
|
+
}],
|
|
28216
|
+
style: _vm.buttonStyle,
|
|
28217
|
+
attrs: {
|
|
28218
|
+
"disabled": _vm.configData.disabled
|
|
28219
|
+
},
|
|
28220
|
+
on: {
|
|
28221
|
+
"click": _vm.handleClick
|
|
28222
|
+
}
|
|
28223
|
+
}, [_vm._v(" " + _vm._s(_vm.configData.buttonText) + " "), _c('i', {
|
|
28224
|
+
staticClass: "el-icon-arrow-right el-icon--right"
|
|
28225
|
+
})])])]);
|
|
28226
|
+
};
|
|
28227
|
+
var staticRenderFns = [];
|
|
28228
|
+
|
|
28229
|
+
// EXTERNAL MODULE: ./node_modules/core-js/modules/es.iterator.constructor.js
|
|
28230
|
+
var es_iterator_constructor = __webpack_require__(8111);
|
|
28231
|
+
// EXTERNAL MODULE: ./node_modules/core-js/modules/es.iterator.for-each.js
|
|
28232
|
+
var es_iterator_for_each = __webpack_require__(7588);
|
|
28233
|
+
// EXTERNAL MODULE: ./package/baseComp.vue + 5 modules
|
|
28234
|
+
var baseComp = __webpack_require__(4272);
|
|
28235
|
+
;// ./node_modules/thread-loader/dist/cjs.js!./node_modules/babel-loader/lib/index.js??clonedRuleSet-40.use[1]!./node_modules/babel-loader/lib/index.js??clonedRuleSet-41.use!./node_modules/@vue/vue-loader-v15/lib/index.js??vue-loader-options!./package/cms-button/View.vue?vue&type=script&lang=js
|
|
28236
|
+
|
|
28237
|
+
|
|
28238
|
+
|
|
28239
|
+
|
|
28240
|
+
|
|
28241
|
+
/* harmony default export */ var Viewvue_type_script_lang_js = ({
|
|
28242
|
+
name: "cms-button",
|
|
28243
|
+
components: {
|
|
28244
|
+
BaseComp: baseComp["default"]
|
|
28245
|
+
},
|
|
28246
|
+
props: {
|
|
28247
|
+
data: {
|
|
28248
|
+
type: Object,
|
|
28249
|
+
default: () => {
|
|
28250
|
+
return {};
|
|
28251
|
+
}
|
|
28252
|
+
},
|
|
28253
|
+
nowCompId: {
|
|
28254
|
+
type: [String, Number],
|
|
28255
|
+
default: ""
|
|
28256
|
+
},
|
|
28257
|
+
isOpcacity: {
|
|
28258
|
+
type: Boolean,
|
|
28259
|
+
default: true
|
|
28260
|
+
},
|
|
28261
|
+
lang: {
|
|
28262
|
+
type: String,
|
|
28263
|
+
default: "zh-HK"
|
|
28264
|
+
}
|
|
28265
|
+
},
|
|
28266
|
+
data() {
|
|
28267
|
+
return {
|
|
28268
|
+
configData: {},
|
|
28269
|
+
// 默认配置数据
|
|
28270
|
+
defaultConfig: {
|
|
28271
|
+
// 文字设置
|
|
28272
|
+
buttonText: "按钮文字",
|
|
28273
|
+
textAlign: "center",
|
|
28274
|
+
fontSize: 16,
|
|
28275
|
+
fontColor: "#ffffff",
|
|
28276
|
+
fontWeight: "normal",
|
|
28277
|
+
// 样式控制
|
|
28278
|
+
backgroundColor: "#2f85ff",
|
|
28279
|
+
borderRadius: 30,
|
|
28280
|
+
borderWidth: 1,
|
|
28281
|
+
borderStyle: "solid",
|
|
28282
|
+
borderColor: "#409eff",
|
|
28283
|
+
// 空间布局
|
|
28284
|
+
paddingTop: 12,
|
|
28285
|
+
paddingBottom: 12,
|
|
28286
|
+
paddingLeft: 20,
|
|
28287
|
+
paddingRight: 20,
|
|
28288
|
+
marginTop: 0,
|
|
28289
|
+
marginBottom: 0,
|
|
28290
|
+
marginLeft: 0,
|
|
28291
|
+
marginRight: 0,
|
|
28292
|
+
// 交互功能
|
|
28293
|
+
linkUrl: "",
|
|
28294
|
+
linkTarget: "_self",
|
|
28295
|
+
disabled: false,
|
|
28296
|
+
// 高级配置
|
|
28297
|
+
customClass: "",
|
|
28298
|
+
customStyle: "",
|
|
28299
|
+
hoverEffect: false,
|
|
28300
|
+
// 尺寸设置
|
|
28301
|
+
buttonWidth: "300",
|
|
28302
|
+
buttonHeight: "48",
|
|
28303
|
+
minWidth: 80,
|
|
28304
|
+
minHeight: 36
|
|
28305
|
+
}
|
|
28306
|
+
};
|
|
28307
|
+
},
|
|
28308
|
+
mounted() {
|
|
28309
|
+
this.initConfigData();
|
|
28310
|
+
},
|
|
28311
|
+
watch: {
|
|
28312
|
+
configData: {
|
|
28313
|
+
handler() {
|
|
28314
|
+
this.updateStyles();
|
|
28315
|
+
},
|
|
28316
|
+
deep: true
|
|
28317
|
+
}
|
|
28318
|
+
},
|
|
28319
|
+
computed: {
|
|
28320
|
+
// 容器样式
|
|
28321
|
+
containerStyle() {
|
|
28322
|
+
const config = {
|
|
28323
|
+
...this.defaultConfig,
|
|
28324
|
+
...this.configData
|
|
28325
|
+
};
|
|
28326
|
+
return {
|
|
28327
|
+
backgroundColor: config.wrapperBackgroundColor,
|
|
28328
|
+
textAlign: config.textAlign,
|
|
28329
|
+
margin: `${config.marginTop}px ${config.marginRight}px ${config.marginBottom}px ${config.marginLeft}px`,
|
|
28330
|
+
...this.parseCustomStyle(config.customStyle)
|
|
28331
|
+
};
|
|
28332
|
+
},
|
|
28333
|
+
// 按钮样式
|
|
28334
|
+
buttonStyle() {
|
|
28335
|
+
const config = {
|
|
28336
|
+
...this.defaultConfig,
|
|
28337
|
+
...this.configData
|
|
28338
|
+
};
|
|
28339
|
+
return {
|
|
28340
|
+
// 文字样式
|
|
28341
|
+
fontSize: `${config.fontSize}px`,
|
|
28342
|
+
color: config.fontColor,
|
|
28343
|
+
fontWeight: config.fontWeight,
|
|
28344
|
+
// 背景和边框
|
|
28345
|
+
backgroundColor: config.backgroundColor ? config.backgroundColor : "transparent",
|
|
28346
|
+
borderRadius: `${config.borderRadius}px`,
|
|
28347
|
+
border: config.borderWidth ? `${config.borderWidth}px ${config.borderStyle} ${config.borderColor}` : "none",
|
|
28348
|
+
// 内边距
|
|
28349
|
+
padding: `${config.paddingTop}px ${config.paddingRight}px ${config.paddingBottom}px ${config.paddingLeft}px`,
|
|
28350
|
+
// 尺寸
|
|
28351
|
+
width: config.buttonWidth === "auto" ? "auto" : `${config.buttonWidth}px`,
|
|
28352
|
+
height: config.buttonHeight === "auto" ? "auto" : `${config.buttonHeight}px`,
|
|
28353
|
+
minWidth: `${config.minWidth}px`,
|
|
28354
|
+
minHeight: `${config.minHeight}px`,
|
|
28355
|
+
// 交互效果
|
|
28356
|
+
cursor: config.linkUrl ? "pointer" : "default",
|
|
28357
|
+
opacity: config.disabled ? 0.6 : 1,
|
|
28358
|
+
transition: config.hoverEffect ? "all 0.3s ease" : "none",
|
|
28359
|
+
// 基础样式
|
|
28360
|
+
outline: "none",
|
|
28361
|
+
textDecoration: "none",
|
|
28362
|
+
display: "inline-block",
|
|
28363
|
+
textAlign: "center",
|
|
28364
|
+
verticalAlign: "middle",
|
|
28365
|
+
userSelect: "none",
|
|
28366
|
+
whiteSpace: "nowrap"
|
|
28367
|
+
};
|
|
28368
|
+
}
|
|
28369
|
+
},
|
|
28370
|
+
methods: {
|
|
28371
|
+
// 初始化配置数据
|
|
28372
|
+
initConfigData() {
|
|
28373
|
+
this.configData = {
|
|
28374
|
+
...this.defaultConfig,
|
|
28375
|
+
...this.configData
|
|
28376
|
+
};
|
|
28377
|
+
},
|
|
28378
|
+
// 获取配置数据
|
|
28379
|
+
getConfigData(configData) {
|
|
28380
|
+
this.configData = {
|
|
28381
|
+
...this.defaultConfig,
|
|
28382
|
+
...configData
|
|
28383
|
+
};
|
|
28384
|
+
this.updateStyles();
|
|
28385
|
+
},
|
|
28386
|
+
// 更新样式
|
|
28387
|
+
updateStyles() {
|
|
28388
|
+
this.$nextTick(() => {
|
|
28389
|
+
this.$forceUpdate();
|
|
28390
|
+
});
|
|
28391
|
+
},
|
|
28392
|
+
// 处理点击事件
|
|
28393
|
+
handleClick() {
|
|
28394
|
+
if (this.configData.disabled) {
|
|
28395
|
+
return;
|
|
28396
|
+
}
|
|
28397
|
+
if (this.configData.linkUrl) {
|
|
28398
|
+
const target = this.configData.linkTarget || "_self";
|
|
28399
|
+
if (target === "_blank") {
|
|
28400
|
+
window.open(this.configData.linkUrl, "_blank");
|
|
28401
|
+
} else {
|
|
28402
|
+
window.location.href = this.configData.linkUrl;
|
|
28403
|
+
}
|
|
28404
|
+
}
|
|
28405
|
+
},
|
|
28406
|
+
// 解析自定义样式
|
|
28407
|
+
parseCustomStyle(customStyle) {
|
|
28408
|
+
if (!customStyle) return {};
|
|
28409
|
+
try {
|
|
28410
|
+
const styles = {};
|
|
28411
|
+
const declarations = customStyle.split(";");
|
|
28412
|
+
declarations.forEach(declaration => {
|
|
28413
|
+
const [property, value] = declaration.split(":");
|
|
28414
|
+
if (property && value) {
|
|
28415
|
+
const camelCaseProperty = property.trim().replace(/-([a-z])/g, g => g[1].toUpperCase());
|
|
28416
|
+
styles[camelCaseProperty] = value.trim();
|
|
28417
|
+
}
|
|
28418
|
+
});
|
|
28419
|
+
return styles;
|
|
28420
|
+
} catch (error) {
|
|
28421
|
+
console.warn("解析自定义样式失败:", error);
|
|
28422
|
+
return {};
|
|
28423
|
+
}
|
|
28424
|
+
}
|
|
28425
|
+
}
|
|
28426
|
+
});
|
|
28427
|
+
;// ./package/cms-button/View.vue?vue&type=script&lang=js
|
|
28428
|
+
/* harmony default export */ var cms_button_Viewvue_type_script_lang_js = (Viewvue_type_script_lang_js);
|
|
28429
|
+
;// ./node_modules/mini-css-extract-plugin/dist/loader.js??clonedRuleSet-22.use[0]!./node_modules/css-loader/dist/cjs.js??clonedRuleSet-22.use[1]!./node_modules/@vue/vue-loader-v15/lib/loaders/stylePostLoader.js!./node_modules/postcss-loader/dist/cjs.js??clonedRuleSet-22.use[2]!./node_modules/sass-loader/dist/cjs.js??clonedRuleSet-22.use[3]!./node_modules/sass-loader/dist/cjs.js??clonedRuleSet-42.use[0]!./node_modules/@vue/vue-loader-v15/lib/index.js??vue-loader-options!./package/cms-button/View.vue?vue&type=style&index=0&id=12ff304e&prod&lang=scss&scoped=true
|
|
28430
|
+
// extracted by mini-css-extract-plugin
|
|
28431
|
+
|
|
28432
|
+
;// ./package/cms-button/View.vue?vue&type=style&index=0&id=12ff304e&prod&lang=scss&scoped=true
|
|
28433
|
+
|
|
28434
|
+
// EXTERNAL MODULE: ./node_modules/@vue/vue-loader-v15/lib/runtime/componentNormalizer.js
|
|
28435
|
+
var componentNormalizer = __webpack_require__(1656);
|
|
28436
|
+
;// ./package/cms-button/View.vue
|
|
28437
|
+
|
|
28438
|
+
|
|
28439
|
+
|
|
28440
|
+
;
|
|
28441
|
+
|
|
28442
|
+
|
|
28443
|
+
/* normalize component */
|
|
28444
|
+
|
|
28445
|
+
var component = (0,componentNormalizer/* default */.A)(
|
|
28446
|
+
cms_button_Viewvue_type_script_lang_js,
|
|
28447
|
+
render,
|
|
28448
|
+
staticRenderFns,
|
|
28449
|
+
false,
|
|
28450
|
+
null,
|
|
28451
|
+
"12ff304e",
|
|
28452
|
+
null
|
|
28453
|
+
|
|
28454
|
+
)
|
|
28455
|
+
|
|
28456
|
+
/* harmony default export */ var View = (component.exports);
|
|
28457
|
+
|
|
28458
|
+
/***/ }),
|
|
28459
|
+
|
|
28165
28460
|
/***/ 4024:
|
|
28166
28461
|
/***/ (function(__unused_webpack_module, __webpack_exports__, __webpack_require__) {
|
|
28167
28462
|
|
|
@@ -29054,14 +29349,6 @@ module.exports = (function () {
|
|
|
29054
29349
|
})();
|
|
29055
29350
|
|
|
29056
29351
|
|
|
29057
|
-
/***/ }),
|
|
29058
|
-
|
|
29059
|
-
/***/ 4242:
|
|
29060
|
-
/***/ (function(module) {
|
|
29061
|
-
|
|
29062
|
-
"use strict";
|
|
29063
|
-
module.exports = "";
|
|
29064
|
-
|
|
29065
29352
|
/***/ }),
|
|
29066
29353
|
|
|
29067
29354
|
/***/ 4261:
|
|
@@ -41479,9 +41766,9 @@ var map = {
|
|
|
41479
41766
|
"./cms-activityCountdown/View.vue": 4084,
|
|
41480
41767
|
"./cms-activityTime/View.vue": 8322,
|
|
41481
41768
|
"./cms-banner/View.vue": 6815,
|
|
41482
|
-
"./cms-button/View.vue":
|
|
41769
|
+
"./cms-button/View.vue": 4018,
|
|
41483
41770
|
"./cms-cells/View.vue": 5700,
|
|
41484
|
-
"./cms-column-card/View.vue":
|
|
41771
|
+
"./cms-column-card/View.vue": 2159,
|
|
41485
41772
|
"./cms-column/View.vue": 7855,
|
|
41486
41773
|
"./cms-description/View.vue": 3203,
|
|
41487
41774
|
"./cms-dynamic-comp/View.vue": 2809,
|
|
@@ -41497,12 +41784,12 @@ var map = {
|
|
|
41497
41784
|
"./cms-prodCustomization/View.vue": 1470,
|
|
41498
41785
|
"./cms-productDetails/View.vue": 4110,
|
|
41499
41786
|
"./cms-question/View.vue": 4024,
|
|
41500
|
-
"./cms-richText/View.vue":
|
|
41787
|
+
"./cms-richText/View.vue": 450,
|
|
41501
41788
|
"./cms-servePlan-tab/View.vue": 8502,
|
|
41502
41789
|
"./cms-servePlan-text/View.vue": 448,
|
|
41503
41790
|
"./cms-tab/View.vue": 4685,
|
|
41504
41791
|
"./cms-termsAndConditions/View.vue": 5060,
|
|
41505
|
-
"./cms-text/View.vue":
|
|
41792
|
+
"./cms-text/View.vue": 7524,
|
|
41506
41793
|
"./cms-threeScroll/View.vue": 517,
|
|
41507
41794
|
"./cms-titleCenter/View.vue": 1429,
|
|
41508
41795
|
"./cms-titleLeft/View.vue": 7874,
|
|
@@ -41940,7 +42227,7 @@ module.exports = "
|
|
|
41940
42227
|
__webpack_require__.r(__webpack_exports__);
|
|
41941
42228
|
/* harmony import */ var _baseConfig__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(649);
|
|
41942
42229
|
|
|
41943
|
-
const View = () => Promise.resolve(/* import() */).then(__webpack_require__.bind(__webpack_require__,
|
|
42230
|
+
const View = () => Promise.resolve(/* import() */).then(__webpack_require__.bind(__webpack_require__, 2159));
|
|
41944
42231
|
|
|
41945
42232
|
// 默认配置数据
|
|
41946
42233
|
const langData = {
|
|
@@ -43578,427 +43865,6 @@ module.exports = function (object, key, method) {
|
|
|
43578
43865
|
};
|
|
43579
43866
|
|
|
43580
43867
|
|
|
43581
|
-
/***/ }),
|
|
43582
|
-
|
|
43583
|
-
/***/ 6757:
|
|
43584
|
-
/***/ (function(__unused_webpack_module, __webpack_exports__, __webpack_require__) {
|
|
43585
|
-
|
|
43586
|
-
"use strict";
|
|
43587
|
-
// ESM COMPAT FLAG
|
|
43588
|
-
__webpack_require__.r(__webpack_exports__);
|
|
43589
|
-
|
|
43590
|
-
// EXPORTS
|
|
43591
|
-
__webpack_require__.d(__webpack_exports__, {
|
|
43592
|
-
"default": function() { return /* binding */ View; }
|
|
43593
|
-
});
|
|
43594
|
-
|
|
43595
|
-
;// ./node_modules/thread-loader/dist/cjs.js!./node_modules/babel-loader/lib/index.js??clonedRuleSet-40.use[1]!./node_modules/babel-loader/lib/index.js??clonedRuleSet-41.use!./node_modules/@vue/vue-loader-v15/lib/loaders/templateLoader.js??ruleSet[1].rules[4]!./node_modules/@vue/vue-loader-v15/lib/index.js??vue-loader-options!./package/cms-text/View.vue?vue&type=template&id=877468fe&scoped=true
|
|
43596
|
-
var render = function render() {
|
|
43597
|
-
var _vm = this,
|
|
43598
|
-
_c = _vm._self._c;
|
|
43599
|
-
return _c('BaseComp', _vm._b({
|
|
43600
|
-
attrs: {
|
|
43601
|
-
"data": _vm.data,
|
|
43602
|
-
"nowCompId": _vm.nowCompId,
|
|
43603
|
-
"isOpcacity": _vm.isOpcacity,
|
|
43604
|
-
"lang": _vm.lang
|
|
43605
|
-
},
|
|
43606
|
-
on: {
|
|
43607
|
-
"getConfigData": _vm.getConfigData
|
|
43608
|
-
}
|
|
43609
|
-
}, 'BaseComp', _vm.$attrs, false), [_c('section', {
|
|
43610
|
-
staticClass: "cms-text-container",
|
|
43611
|
-
class: [`align-${_vm.configData.textAlign || 'left'}`, _vm.configData.customClass || '', {
|
|
43612
|
-
'has-link': _vm.configData.linkUrl,
|
|
43613
|
-
'cmhk-home_main': _vm.showCmhkMain,
|
|
43614
|
-
'hover-effect': _vm.configData.hoverEffect && _vm.configData.linkUrl
|
|
43615
|
-
}],
|
|
43616
|
-
style: _vm.containerStyle,
|
|
43617
|
-
attrs: {
|
|
43618
|
-
"aria-label": _vm.configData.ariaLabel,
|
|
43619
|
-
"tabindex": _vm.configData.tabIndex,
|
|
43620
|
-
"role": _vm.configData.role,
|
|
43621
|
-
"title": _vm.configData.seoTitle || _vm.configData.seoDescription
|
|
43622
|
-
},
|
|
43623
|
-
on: {
|
|
43624
|
-
"click": _vm.handleClick
|
|
43625
|
-
}
|
|
43626
|
-
}, [_c('div', {
|
|
43627
|
-
staticClass: "text-content",
|
|
43628
|
-
class: _vm.configData.textType,
|
|
43629
|
-
style: _vm.textStyle
|
|
43630
|
-
}, _vm._l(_vm.textLines, function (line, index) {
|
|
43631
|
-
return _c('p', {
|
|
43632
|
-
key: index,
|
|
43633
|
-
staticClass: "text-line",
|
|
43634
|
-
style: _vm.lineStyle
|
|
43635
|
-
}, [_vm._v(" " + _vm._s(line) + " ")]);
|
|
43636
|
-
}), 0), _vm.configData.linkUrl && _vm.configData.showLinkIcon ? _c('div', {
|
|
43637
|
-
staticClass: "link-indicator"
|
|
43638
|
-
}, [_c('i', {
|
|
43639
|
-
staticClass: "el-icon-link"
|
|
43640
|
-
})]) : _vm._e()])]);
|
|
43641
|
-
};
|
|
43642
|
-
var staticRenderFns = [];
|
|
43643
|
-
|
|
43644
|
-
// EXTERNAL MODULE: ./node_modules/core-js/modules/es.iterator.constructor.js
|
|
43645
|
-
var es_iterator_constructor = __webpack_require__(8111);
|
|
43646
|
-
// EXTERNAL MODULE: ./node_modules/core-js/modules/es.iterator.filter.js
|
|
43647
|
-
var es_iterator_filter = __webpack_require__(2489);
|
|
43648
|
-
// EXTERNAL MODULE: ./node_modules/core-js/modules/es.iterator.for-each.js
|
|
43649
|
-
var es_iterator_for_each = __webpack_require__(7588);
|
|
43650
|
-
// EXTERNAL MODULE: ./package/baseComp.vue + 5 modules
|
|
43651
|
-
var baseComp = __webpack_require__(4272);
|
|
43652
|
-
;// ./node_modules/thread-loader/dist/cjs.js!./node_modules/babel-loader/lib/index.js??clonedRuleSet-40.use[1]!./node_modules/babel-loader/lib/index.js??clonedRuleSet-41.use!./node_modules/@vue/vue-loader-v15/lib/index.js??vue-loader-options!./package/cms-text/View.vue?vue&type=script&lang=js
|
|
43653
|
-
|
|
43654
|
-
|
|
43655
|
-
|
|
43656
|
-
|
|
43657
|
-
|
|
43658
|
-
|
|
43659
|
-
|
|
43660
|
-
/* harmony default export */ var Viewvue_type_script_lang_js = ({
|
|
43661
|
-
name: "cms-text",
|
|
43662
|
-
components: {
|
|
43663
|
-
BaseComp: baseComp["default"]
|
|
43664
|
-
},
|
|
43665
|
-
props: {
|
|
43666
|
-
data: {
|
|
43667
|
-
type: Object,
|
|
43668
|
-
default: () => {
|
|
43669
|
-
return {};
|
|
43670
|
-
}
|
|
43671
|
-
},
|
|
43672
|
-
nowCompId: {
|
|
43673
|
-
type: [String, Number],
|
|
43674
|
-
default: ""
|
|
43675
|
-
},
|
|
43676
|
-
isOpcacity: {
|
|
43677
|
-
type: Boolean,
|
|
43678
|
-
default: true
|
|
43679
|
-
},
|
|
43680
|
-
lang: {
|
|
43681
|
-
type: String,
|
|
43682
|
-
default: "zh-HK"
|
|
43683
|
-
},
|
|
43684
|
-
showCmhkMain: {
|
|
43685
|
-
type: Boolean,
|
|
43686
|
-
default: true
|
|
43687
|
-
}
|
|
43688
|
-
},
|
|
43689
|
-
data() {
|
|
43690
|
-
return {
|
|
43691
|
-
configData: {},
|
|
43692
|
-
// 默认配置数据
|
|
43693
|
-
defaultConfig: {
|
|
43694
|
-
// 内容编辑
|
|
43695
|
-
textContent: "请输入文本内容",
|
|
43696
|
-
enableLineBreak: true,
|
|
43697
|
-
// 排版控制
|
|
43698
|
-
textAlign: "left",
|
|
43699
|
-
// fontSize: 16,
|
|
43700
|
-
// lineHeight: 1.5,
|
|
43701
|
-
letterSpacing: 0,
|
|
43702
|
-
// 样式美化
|
|
43703
|
-
fontColor: "#333333",
|
|
43704
|
-
// fontWeight: "normal",
|
|
43705
|
-
fontStyle: "normal",
|
|
43706
|
-
textDecoration: "none",
|
|
43707
|
-
// fontFamily: "inherit",
|
|
43708
|
-
|
|
43709
|
-
// 布局设置
|
|
43710
|
-
paddingTop: 0,
|
|
43711
|
-
paddingBottom: 0,
|
|
43712
|
-
paddingLeft: 0,
|
|
43713
|
-
paddingRight: 0,
|
|
43714
|
-
marginTop: 0,
|
|
43715
|
-
marginBottom: 0,
|
|
43716
|
-
marginLeft: 0,
|
|
43717
|
-
marginRight: 0,
|
|
43718
|
-
backgroundColor: "",
|
|
43719
|
-
// 视觉效果
|
|
43720
|
-
borderWidth: 0,
|
|
43721
|
-
borderStyle: "solid",
|
|
43722
|
-
borderColor: "#dcdfe6",
|
|
43723
|
-
borderRadius: 0,
|
|
43724
|
-
boxShadow: "",
|
|
43725
|
-
// 交互功能
|
|
43726
|
-
linkUrl: "",
|
|
43727
|
-
linkTarget: "_self",
|
|
43728
|
-
showLinkIcon: false,
|
|
43729
|
-
hoverEffect: false,
|
|
43730
|
-
// 高级配置
|
|
43731
|
-
customClass: "",
|
|
43732
|
-
customStyle: "",
|
|
43733
|
-
enableAnimation: false,
|
|
43734
|
-
animationType: "fadeIn",
|
|
43735
|
-
animationDuration: 300,
|
|
43736
|
-
// 可访问性配置
|
|
43737
|
-
ariaLabel: "",
|
|
43738
|
-
tabIndex: 0,
|
|
43739
|
-
role: "",
|
|
43740
|
-
// SEO配置
|
|
43741
|
-
seoTitle: "",
|
|
43742
|
-
seoDescription: "",
|
|
43743
|
-
// 响应式配置
|
|
43744
|
-
mobileTextAlign: "",
|
|
43745
|
-
mobileFontSize: 0,
|
|
43746
|
-
tabletFontSize: 0
|
|
43747
|
-
}
|
|
43748
|
-
};
|
|
43749
|
-
},
|
|
43750
|
-
mounted() {
|
|
43751
|
-
this.initConfigData();
|
|
43752
|
-
this.setCSSVariables();
|
|
43753
|
-
},
|
|
43754
|
-
watch: {
|
|
43755
|
-
configData: {
|
|
43756
|
-
handler() {
|
|
43757
|
-
this.updateStyles();
|
|
43758
|
-
},
|
|
43759
|
-
deep: true
|
|
43760
|
-
}
|
|
43761
|
-
},
|
|
43762
|
-
computed: {
|
|
43763
|
-
// 文本行数组(支持换行)
|
|
43764
|
-
textLines() {
|
|
43765
|
-
if (!this.configData.textContent) return [];
|
|
43766
|
-
if (!this.configData.enableLineBreak) {
|
|
43767
|
-
return [this.configData.textContent];
|
|
43768
|
-
}
|
|
43769
|
-
return this.configData.textContent.split("\n").filter(line => line.trim() !== "");
|
|
43770
|
-
},
|
|
43771
|
-
// 容器样式
|
|
43772
|
-
containerStyle() {
|
|
43773
|
-
const config = {
|
|
43774
|
-
...this.defaultConfig,
|
|
43775
|
-
...this.configData
|
|
43776
|
-
};
|
|
43777
|
-
return {
|
|
43778
|
-
padding: `${config.paddingTop}px ${config.paddingRight}px ${config.paddingBottom}px ${config.paddingLeft}px`,
|
|
43779
|
-
margin: `${config.marginTop}px ${config.marginRight}px ${config.marginBottom}px ${config.marginLeft}px`,
|
|
43780
|
-
backgroundColor: config.backgroundColor || "transparent",
|
|
43781
|
-
border: config.borderWidth ? `${config.borderWidth}px ${config.borderStyle} ${config.borderColor}` : "none",
|
|
43782
|
-
borderRadius: `${config.borderRadius}px`,
|
|
43783
|
-
boxShadow: config.boxShadow || "none",
|
|
43784
|
-
cursor: config.linkUrl ? "pointer" : "default",
|
|
43785
|
-
transition: config.hoverEffect ? "all 0.3s ease" : "none",
|
|
43786
|
-
animation: config.enableAnimation ? this.getAnimationStyle() : "none",
|
|
43787
|
-
...this.parseCustomStyle(config.customStyle)
|
|
43788
|
-
};
|
|
43789
|
-
},
|
|
43790
|
-
// 文本样式
|
|
43791
|
-
textStyle() {
|
|
43792
|
-
const config = {
|
|
43793
|
-
...this.defaultConfig,
|
|
43794
|
-
...this.configData
|
|
43795
|
-
};
|
|
43796
|
-
return {
|
|
43797
|
-
color: config.fontColor,
|
|
43798
|
-
// fontSize: `${config.fontSize}px`,
|
|
43799
|
-
// fontWeight: config.fontWeight,
|
|
43800
|
-
fontStyle: config.fontStyle,
|
|
43801
|
-
textDecoration: config.textDecoration,
|
|
43802
|
-
// fontFamily: config.fontFamily,
|
|
43803
|
-
// lineHeight: config.lineHeight,
|
|
43804
|
-
letterSpacing: `${config.letterSpacing}px`,
|
|
43805
|
-
textAlign: config.textAlign,
|
|
43806
|
-
wordBreak: "break-word",
|
|
43807
|
-
wordWrap: "break-word",
|
|
43808
|
-
cursor: config.linkUrl ? "pointer" : "default"
|
|
43809
|
-
};
|
|
43810
|
-
},
|
|
43811
|
-
// 行样式
|
|
43812
|
-
lineStyle() {
|
|
43813
|
-
return {
|
|
43814
|
-
margin: "0",
|
|
43815
|
-
padding: "0"
|
|
43816
|
-
};
|
|
43817
|
-
}
|
|
43818
|
-
},
|
|
43819
|
-
methods: {
|
|
43820
|
-
// 初始化配置数据
|
|
43821
|
-
initConfigData() {
|
|
43822
|
-
this.configData = {
|
|
43823
|
-
...this.defaultConfig,
|
|
43824
|
-
...this.configData
|
|
43825
|
-
};
|
|
43826
|
-
},
|
|
43827
|
-
// 获取配置数据
|
|
43828
|
-
getConfigData(configData) {
|
|
43829
|
-
this.configData = {
|
|
43830
|
-
...this.defaultConfig,
|
|
43831
|
-
...configData
|
|
43832
|
-
};
|
|
43833
|
-
this.updateStyles();
|
|
43834
|
-
},
|
|
43835
|
-
// 更新样式
|
|
43836
|
-
updateStyles() {
|
|
43837
|
-
this.$nextTick(() => {
|
|
43838
|
-
this.setCSSVariables();
|
|
43839
|
-
this.$forceUpdate();
|
|
43840
|
-
});
|
|
43841
|
-
},
|
|
43842
|
-
// 设置CSS变量
|
|
43843
|
-
setCSSVariables() {
|
|
43844
|
-
if (!this.$el) return;
|
|
43845
|
-
const config = {
|
|
43846
|
-
...this.defaultConfig,
|
|
43847
|
-
...this.configData
|
|
43848
|
-
};
|
|
43849
|
-
|
|
43850
|
-
// 设置响应式字体大小
|
|
43851
|
-
if (config.mobileFontSize > 0) {
|
|
43852
|
-
this.$el.style.setProperty("--mobile-font-size", `${config.mobileFontSize}px`);
|
|
43853
|
-
}
|
|
43854
|
-
if (config.tabletFontSize > 0) {
|
|
43855
|
-
this.$el.style.setProperty("--tablet-font-size", `${config.tabletFontSize}px`);
|
|
43856
|
-
}
|
|
43857
|
-
|
|
43858
|
-
// 设置移动端文本对齐
|
|
43859
|
-
if (config.mobileTextAlign) {
|
|
43860
|
-
this.$el.style.setProperty("--mobile-text-align", config.mobileTextAlign);
|
|
43861
|
-
}
|
|
43862
|
-
},
|
|
43863
|
-
// 处理点击事件
|
|
43864
|
-
handleClick() {
|
|
43865
|
-
if (this.configData.linkUrl) {
|
|
43866
|
-
const target = this.configData.linkTarget || "_self";
|
|
43867
|
-
if (target === "_blank") {
|
|
43868
|
-
window.open(this.configData.linkUrl, "_blank");
|
|
43869
|
-
} else {
|
|
43870
|
-
window.location.href = this.configData.linkUrl;
|
|
43871
|
-
}
|
|
43872
|
-
}
|
|
43873
|
-
},
|
|
43874
|
-
// 获取动画样式
|
|
43875
|
-
getAnimationStyle() {
|
|
43876
|
-
const animationType = this.configData.animationType || this.defaultConfig.animationType;
|
|
43877
|
-
const duration = this.configData.animationDuration || this.defaultConfig.animationDuration;
|
|
43878
|
-
if (!this.configData.enableAnimation || animationType === "none") return "";
|
|
43879
|
-
return `${animationType} ${duration}ms ease-in-out`;
|
|
43880
|
-
},
|
|
43881
|
-
// 解析自定义样式
|
|
43882
|
-
parseCustomStyle(customStyle) {
|
|
43883
|
-
if (!customStyle) return {};
|
|
43884
|
-
try {
|
|
43885
|
-
// 简单的CSS样式解析
|
|
43886
|
-
const styles = {};
|
|
43887
|
-
const declarations = customStyle.split(";");
|
|
43888
|
-
declarations.forEach(declaration => {
|
|
43889
|
-
const [property, value] = declaration.split(":");
|
|
43890
|
-
if (property && value) {
|
|
43891
|
-
const camelCaseProperty = property.trim().replace(/-([a-z])/g, g => g[1].toUpperCase());
|
|
43892
|
-
styles[camelCaseProperty] = value.trim();
|
|
43893
|
-
}
|
|
43894
|
-
});
|
|
43895
|
-
return styles;
|
|
43896
|
-
} catch (error) {
|
|
43897
|
-
console.warn("解析自定义样式失败:", error);
|
|
43898
|
-
return {};
|
|
43899
|
-
}
|
|
43900
|
-
},
|
|
43901
|
-
// 文本内容验证
|
|
43902
|
-
validateTextContent() {
|
|
43903
|
-
const content = this.configData.textContent;
|
|
43904
|
-
if (!content || content.trim() === "") {
|
|
43905
|
-
console.warn("文本内容为空");
|
|
43906
|
-
return false;
|
|
43907
|
-
}
|
|
43908
|
-
return true;
|
|
43909
|
-
},
|
|
43910
|
-
// 获取纯文本内容
|
|
43911
|
-
getPlainTextContent() {
|
|
43912
|
-
return this.configData.textContent || "";
|
|
43913
|
-
},
|
|
43914
|
-
// 获取文本长度
|
|
43915
|
-
getTextLength() {
|
|
43916
|
-
return this.getPlainTextContent().length;
|
|
43917
|
-
},
|
|
43918
|
-
// 复制文本内容到剪贴板
|
|
43919
|
-
copyTextToClipboard() {
|
|
43920
|
-
const text = this.getPlainTextContent();
|
|
43921
|
-
if (navigator.clipboard && window.isSecureContext) {
|
|
43922
|
-
navigator.clipboard.writeText(text).then(() => {
|
|
43923
|
-
var _this$$message;
|
|
43924
|
-
(_this$$message = this.$message) === null || _this$$message === void 0 ? void 0 : _this$$message.success("文本已复制到剪贴板");
|
|
43925
|
-
}).catch(err => {
|
|
43926
|
-
console.error("复制失败:", err);
|
|
43927
|
-
});
|
|
43928
|
-
} else {
|
|
43929
|
-
// 降级方案
|
|
43930
|
-
const textArea = document.createElement("textarea");
|
|
43931
|
-
textArea.value = text;
|
|
43932
|
-
document.body.appendChild(textArea);
|
|
43933
|
-
textArea.select();
|
|
43934
|
-
try {
|
|
43935
|
-
var _this$$message2;
|
|
43936
|
-
document.execCommand("copy");
|
|
43937
|
-
(_this$$message2 = this.$message) === null || _this$$message2 === void 0 ? void 0 : _this$$message2.success("文本已复制到剪贴板");
|
|
43938
|
-
} catch (err) {
|
|
43939
|
-
console.error("复制失败:", err);
|
|
43940
|
-
}
|
|
43941
|
-
document.body.removeChild(textArea);
|
|
43942
|
-
}
|
|
43943
|
-
},
|
|
43944
|
-
// 文本搜索高亮
|
|
43945
|
-
highlightText(searchTerm) {
|
|
43946
|
-
if (!searchTerm) return;
|
|
43947
|
-
const content = this.getPlainTextContent();
|
|
43948
|
-
const regex = new RegExp(`(${searchTerm})`, "gi");
|
|
43949
|
-
const highlightedContent = content.replace(regex, "<mark>$1</mark>");
|
|
43950
|
-
|
|
43951
|
-
// 这里可以根据需要实现高亮显示逻辑
|
|
43952
|
-
console.log("高亮内容:", highlightedContent);
|
|
43953
|
-
},
|
|
43954
|
-
// 文本统计信息
|
|
43955
|
-
getTextStats() {
|
|
43956
|
-
const text = this.getPlainTextContent();
|
|
43957
|
-
const words = text.split(/\s+/).filter(word => word.length > 0);
|
|
43958
|
-
const lines = text.split("\n").length;
|
|
43959
|
-
const characters = text.length;
|
|
43960
|
-
const charactersNoSpaces = text.replace(/\s/g, "").length;
|
|
43961
|
-
return {
|
|
43962
|
-
characters,
|
|
43963
|
-
charactersNoSpaces,
|
|
43964
|
-
words: words.length,
|
|
43965
|
-
lines,
|
|
43966
|
-
paragraphs: text.split(/\n\s*\n/).filter(p => p.trim().length > 0).length
|
|
43967
|
-
};
|
|
43968
|
-
}
|
|
43969
|
-
}
|
|
43970
|
-
});
|
|
43971
|
-
;// ./package/cms-text/View.vue?vue&type=script&lang=js
|
|
43972
|
-
/* harmony default export */ var cms_text_Viewvue_type_script_lang_js = (Viewvue_type_script_lang_js);
|
|
43973
|
-
;// ./node_modules/mini-css-extract-plugin/dist/loader.js??clonedRuleSet-22.use[0]!./node_modules/css-loader/dist/cjs.js??clonedRuleSet-22.use[1]!./node_modules/@vue/vue-loader-v15/lib/loaders/stylePostLoader.js!./node_modules/postcss-loader/dist/cjs.js??clonedRuleSet-22.use[2]!./node_modules/sass-loader/dist/cjs.js??clonedRuleSet-22.use[3]!./node_modules/sass-loader/dist/cjs.js??clonedRuleSet-42.use[0]!./node_modules/@vue/vue-loader-v15/lib/index.js??vue-loader-options!./package/cms-text/View.vue?vue&type=style&index=0&id=877468fe&prod&lang=scss&scoped=true
|
|
43974
|
-
// extracted by mini-css-extract-plugin
|
|
43975
|
-
|
|
43976
|
-
;// ./package/cms-text/View.vue?vue&type=style&index=0&id=877468fe&prod&lang=scss&scoped=true
|
|
43977
|
-
|
|
43978
|
-
// EXTERNAL MODULE: ./node_modules/@vue/vue-loader-v15/lib/runtime/componentNormalizer.js
|
|
43979
|
-
var componentNormalizer = __webpack_require__(1656);
|
|
43980
|
-
;// ./package/cms-text/View.vue
|
|
43981
|
-
|
|
43982
|
-
|
|
43983
|
-
|
|
43984
|
-
;
|
|
43985
|
-
|
|
43986
|
-
|
|
43987
|
-
/* normalize component */
|
|
43988
|
-
|
|
43989
|
-
var component = (0,componentNormalizer/* default */.A)(
|
|
43990
|
-
cms_text_Viewvue_type_script_lang_js,
|
|
43991
|
-
render,
|
|
43992
|
-
staticRenderFns,
|
|
43993
|
-
false,
|
|
43994
|
-
null,
|
|
43995
|
-
"877468fe",
|
|
43996
|
-
null
|
|
43997
|
-
|
|
43998
|
-
)
|
|
43999
|
-
|
|
44000
|
-
/* harmony default export */ var View = (component.exports);
|
|
44001
|
-
|
|
44002
43868
|
/***/ }),
|
|
44003
43869
|
|
|
44004
43870
|
/***/ 6763:
|
|
@@ -53758,6 +53624,431 @@ module.exports = function (fn) {
|
|
|
53758
53624
|
};
|
|
53759
53625
|
|
|
53760
53626
|
|
|
53627
|
+
/***/ }),
|
|
53628
|
+
|
|
53629
|
+
/***/ 7524:
|
|
53630
|
+
/***/ (function(__unused_webpack_module, __webpack_exports__, __webpack_require__) {
|
|
53631
|
+
|
|
53632
|
+
"use strict";
|
|
53633
|
+
// ESM COMPAT FLAG
|
|
53634
|
+
__webpack_require__.r(__webpack_exports__);
|
|
53635
|
+
|
|
53636
|
+
// EXPORTS
|
|
53637
|
+
__webpack_require__.d(__webpack_exports__, {
|
|
53638
|
+
"default": function() { return /* binding */ View; }
|
|
53639
|
+
});
|
|
53640
|
+
|
|
53641
|
+
;// ./node_modules/thread-loader/dist/cjs.js!./node_modules/babel-loader/lib/index.js??clonedRuleSet-40.use[1]!./node_modules/babel-loader/lib/index.js??clonedRuleSet-41.use!./node_modules/@vue/vue-loader-v15/lib/loaders/templateLoader.js??ruleSet[1].rules[4]!./node_modules/@vue/vue-loader-v15/lib/index.js??vue-loader-options!./package/cms-text/View.vue?vue&type=template&id=0914066e&scoped=true
|
|
53642
|
+
var render = function render() {
|
|
53643
|
+
var _vm = this,
|
|
53644
|
+
_c = _vm._self._c;
|
|
53645
|
+
return _c('BaseComp', _vm._b({
|
|
53646
|
+
attrs: {
|
|
53647
|
+
"data": _vm.data,
|
|
53648
|
+
"nowCompId": _vm.nowCompId,
|
|
53649
|
+
"isOpcacity": _vm.isOpcacity,
|
|
53650
|
+
"lang": _vm.lang
|
|
53651
|
+
},
|
|
53652
|
+
on: {
|
|
53653
|
+
"getConfigData": _vm.getConfigData
|
|
53654
|
+
}
|
|
53655
|
+
}, 'BaseComp', _vm.$attrs, false), [_c('section', {
|
|
53656
|
+
staticClass: "cms-text-container",
|
|
53657
|
+
class: [`align-${_vm.configData.textAlign || 'left'}`, _vm.configData.customClass || '', {
|
|
53658
|
+
'has-link': _vm.configData.linkUrl,
|
|
53659
|
+
'cmhk-home_main': _vm.showCmhkMain,
|
|
53660
|
+
'hover-effect': _vm.configData.hoverEffect && _vm.configData.linkUrl
|
|
53661
|
+
}],
|
|
53662
|
+
style: _vm.containerStyle,
|
|
53663
|
+
attrs: {
|
|
53664
|
+
"aria-label": _vm.configData.ariaLabel,
|
|
53665
|
+
"tabindex": _vm.configData.tabIndex,
|
|
53666
|
+
"role": _vm.configData.role,
|
|
53667
|
+
"title": _vm.configData.seoTitle || _vm.configData.seoDescription
|
|
53668
|
+
},
|
|
53669
|
+
on: {
|
|
53670
|
+
"click": _vm.handleClick
|
|
53671
|
+
}
|
|
53672
|
+
}, [_c('div', {
|
|
53673
|
+
staticClass: "text-content",
|
|
53674
|
+
class: _vm.configData.textType,
|
|
53675
|
+
style: _vm.textStyle
|
|
53676
|
+
}, _vm._l(_vm.textLines, function (line, index) {
|
|
53677
|
+
return _c('p', {
|
|
53678
|
+
key: index,
|
|
53679
|
+
staticClass: "text-line",
|
|
53680
|
+
style: _vm.lineStyle
|
|
53681
|
+
}, [_vm._v(" " + _vm._s(line) + " ")]);
|
|
53682
|
+
}), 0), _vm.configData.linkUrl && _vm.configData.showLinkIcon ? _c('div', {
|
|
53683
|
+
staticClass: "link-indicator"
|
|
53684
|
+
}, [_c('i', {
|
|
53685
|
+
staticClass: "el-icon-link"
|
|
53686
|
+
})]) : _vm._e()])]);
|
|
53687
|
+
};
|
|
53688
|
+
var staticRenderFns = [];
|
|
53689
|
+
|
|
53690
|
+
// EXTERNAL MODULE: ./node_modules/core-js/modules/es.iterator.constructor.js
|
|
53691
|
+
var es_iterator_constructor = __webpack_require__(8111);
|
|
53692
|
+
// EXTERNAL MODULE: ./node_modules/core-js/modules/es.iterator.filter.js
|
|
53693
|
+
var es_iterator_filter = __webpack_require__(2489);
|
|
53694
|
+
// EXTERNAL MODULE: ./node_modules/core-js/modules/es.iterator.for-each.js
|
|
53695
|
+
var es_iterator_for_each = __webpack_require__(7588);
|
|
53696
|
+
// EXTERNAL MODULE: ./package/baseComp.vue + 5 modules
|
|
53697
|
+
var baseComp = __webpack_require__(4272);
|
|
53698
|
+
;// ./node_modules/thread-loader/dist/cjs.js!./node_modules/babel-loader/lib/index.js??clonedRuleSet-40.use[1]!./node_modules/babel-loader/lib/index.js??clonedRuleSet-41.use!./node_modules/@vue/vue-loader-v15/lib/index.js??vue-loader-options!./package/cms-text/View.vue?vue&type=script&lang=js
|
|
53699
|
+
|
|
53700
|
+
|
|
53701
|
+
|
|
53702
|
+
|
|
53703
|
+
|
|
53704
|
+
|
|
53705
|
+
|
|
53706
|
+
/* harmony default export */ var Viewvue_type_script_lang_js = ({
|
|
53707
|
+
name: "cms-text",
|
|
53708
|
+
components: {
|
|
53709
|
+
BaseComp: baseComp["default"]
|
|
53710
|
+
},
|
|
53711
|
+
props: {
|
|
53712
|
+
data: {
|
|
53713
|
+
type: Object,
|
|
53714
|
+
default: () => {
|
|
53715
|
+
return {};
|
|
53716
|
+
}
|
|
53717
|
+
},
|
|
53718
|
+
nowCompId: {
|
|
53719
|
+
type: [String, Number],
|
|
53720
|
+
default: ""
|
|
53721
|
+
},
|
|
53722
|
+
isOpcacity: {
|
|
53723
|
+
type: Boolean,
|
|
53724
|
+
default: true
|
|
53725
|
+
},
|
|
53726
|
+
lang: {
|
|
53727
|
+
type: String,
|
|
53728
|
+
default: "zh-HK"
|
|
53729
|
+
},
|
|
53730
|
+
showCmhkMain: {
|
|
53731
|
+
type: Boolean,
|
|
53732
|
+
default: true
|
|
53733
|
+
}
|
|
53734
|
+
},
|
|
53735
|
+
data() {
|
|
53736
|
+
return {
|
|
53737
|
+
configData: {},
|
|
53738
|
+
// 默认配置数据
|
|
53739
|
+
defaultConfig: {
|
|
53740
|
+
// 内容编辑
|
|
53741
|
+
textContent: "请输入文本内容",
|
|
53742
|
+
enableLineBreak: true,
|
|
53743
|
+
// 排版控制
|
|
53744
|
+
textAlign: "left",
|
|
53745
|
+
// fontSize: 16,
|
|
53746
|
+
// lineHeight: 1.5,
|
|
53747
|
+
letterSpacing: 0,
|
|
53748
|
+
// 样式美化
|
|
53749
|
+
fontColor: "#333333",
|
|
53750
|
+
// fontWeight: "normal",
|
|
53751
|
+
fontStyle: "normal",
|
|
53752
|
+
textDecoration: "none",
|
|
53753
|
+
// fontFamily: "inherit",
|
|
53754
|
+
|
|
53755
|
+
// 布局设置
|
|
53756
|
+
paddingTop: 0,
|
|
53757
|
+
paddingBottom: 0,
|
|
53758
|
+
paddingLeft: 0,
|
|
53759
|
+
paddingRight: 0,
|
|
53760
|
+
marginTop: 0,
|
|
53761
|
+
marginBottom: 0,
|
|
53762
|
+
marginLeft: 0,
|
|
53763
|
+
marginRight: 0,
|
|
53764
|
+
backgroundColor: "",
|
|
53765
|
+
// 视觉效果
|
|
53766
|
+
borderWidth: 0,
|
|
53767
|
+
borderStyle: "solid",
|
|
53768
|
+
borderColor: "#dcdfe6",
|
|
53769
|
+
borderRadius: 0,
|
|
53770
|
+
boxShadow: "",
|
|
53771
|
+
// 交互功能
|
|
53772
|
+
linkUrl: "",
|
|
53773
|
+
linkTarget: "_self",
|
|
53774
|
+
showLinkIcon: false,
|
|
53775
|
+
hoverEffect: false,
|
|
53776
|
+
// 高级配置
|
|
53777
|
+
customClass: "",
|
|
53778
|
+
customStyle: "",
|
|
53779
|
+
enableAnimation: false,
|
|
53780
|
+
animationType: "fadeIn",
|
|
53781
|
+
animationDuration: 300,
|
|
53782
|
+
// 可访问性配置
|
|
53783
|
+
ariaLabel: "",
|
|
53784
|
+
tabIndex: 0,
|
|
53785
|
+
role: "",
|
|
53786
|
+
// SEO配置
|
|
53787
|
+
seoTitle: "",
|
|
53788
|
+
seoDescription: "",
|
|
53789
|
+
// 响应式配置
|
|
53790
|
+
mobileTextAlign: "",
|
|
53791
|
+
mobileFontSize: 0,
|
|
53792
|
+
tabletFontSize: 0
|
|
53793
|
+
}
|
|
53794
|
+
};
|
|
53795
|
+
},
|
|
53796
|
+
mounted() {
|
|
53797
|
+
this.initConfigData();
|
|
53798
|
+
this.setCSSVariables();
|
|
53799
|
+
},
|
|
53800
|
+
watch: {
|
|
53801
|
+
configData: {
|
|
53802
|
+
handler() {
|
|
53803
|
+
this.updateStyles();
|
|
53804
|
+
},
|
|
53805
|
+
deep: true
|
|
53806
|
+
}
|
|
53807
|
+
},
|
|
53808
|
+
computed: {
|
|
53809
|
+
// 文本行数组(支持换行)
|
|
53810
|
+
textLines() {
|
|
53811
|
+
if (!this.configData.textContent) return [];
|
|
53812
|
+
if (!this.configData.enableLineBreak) {
|
|
53813
|
+
return [this.configData.textContent];
|
|
53814
|
+
}
|
|
53815
|
+
return this.configData.textContent.split("\n").filter(line => line.trim() !== "");
|
|
53816
|
+
},
|
|
53817
|
+
// 容器样式
|
|
53818
|
+
containerStyle() {
|
|
53819
|
+
const config = {
|
|
53820
|
+
...this.defaultConfig,
|
|
53821
|
+
...this.configData
|
|
53822
|
+
};
|
|
53823
|
+
let marginSettting = `${config.marginTop}px ${config.marginRight}px ${config.marginBottom}px ${config.marginLeft}px`;
|
|
53824
|
+
if (this.showCmhkMain && !(parseInt(config.marginTop) || parseInt(config.marginRight) || parseInt(config.marginBottom) || parseInt(config.marginLeft))) {
|
|
53825
|
+
marginSettting = "0 auto";
|
|
53826
|
+
}
|
|
53827
|
+
return {
|
|
53828
|
+
padding: `${config.paddingTop}px ${config.paddingRight}px ${config.paddingBottom}px ${config.paddingLeft}px`,
|
|
53829
|
+
margin: marginSettting,
|
|
53830
|
+
backgroundColor: config.backgroundColor || "transparent",
|
|
53831
|
+
border: config.borderWidth ? `${config.borderWidth}px ${config.borderStyle} ${config.borderColor}` : "none",
|
|
53832
|
+
borderRadius: `${config.borderRadius}px`,
|
|
53833
|
+
boxShadow: config.boxShadow || "none",
|
|
53834
|
+
cursor: config.linkUrl ? "pointer" : "default",
|
|
53835
|
+
transition: config.hoverEffect ? "all 0.3s ease" : "none",
|
|
53836
|
+
animation: config.enableAnimation ? this.getAnimationStyle() : "none",
|
|
53837
|
+
...this.parseCustomStyle(config.customStyle)
|
|
53838
|
+
};
|
|
53839
|
+
},
|
|
53840
|
+
// 文本样式
|
|
53841
|
+
textStyle() {
|
|
53842
|
+
const config = {
|
|
53843
|
+
...this.defaultConfig,
|
|
53844
|
+
...this.configData
|
|
53845
|
+
};
|
|
53846
|
+
return {
|
|
53847
|
+
color: config.fontColor,
|
|
53848
|
+
// fontSize: `${config.fontSize}px`,
|
|
53849
|
+
// fontWeight: config.fontWeight,
|
|
53850
|
+
fontStyle: config.fontStyle,
|
|
53851
|
+
textDecoration: config.textDecoration,
|
|
53852
|
+
// fontFamily: config.fontFamily,
|
|
53853
|
+
// lineHeight: config.lineHeight,
|
|
53854
|
+
letterSpacing: `${config.letterSpacing}px`,
|
|
53855
|
+
textAlign: config.textAlign,
|
|
53856
|
+
wordBreak: "break-word",
|
|
53857
|
+
wordWrap: "break-word",
|
|
53858
|
+
cursor: config.linkUrl ? "pointer" : "default"
|
|
53859
|
+
};
|
|
53860
|
+
},
|
|
53861
|
+
// 行样式
|
|
53862
|
+
lineStyle() {
|
|
53863
|
+
return {
|
|
53864
|
+
margin: "0",
|
|
53865
|
+
padding: "0"
|
|
53866
|
+
};
|
|
53867
|
+
}
|
|
53868
|
+
},
|
|
53869
|
+
methods: {
|
|
53870
|
+
// 初始化配置数据
|
|
53871
|
+
initConfigData() {
|
|
53872
|
+
this.configData = {
|
|
53873
|
+
...this.defaultConfig,
|
|
53874
|
+
...this.configData
|
|
53875
|
+
};
|
|
53876
|
+
},
|
|
53877
|
+
// 获取配置数据
|
|
53878
|
+
getConfigData(configData) {
|
|
53879
|
+
this.configData = {
|
|
53880
|
+
...this.defaultConfig,
|
|
53881
|
+
...configData
|
|
53882
|
+
};
|
|
53883
|
+
this.updateStyles();
|
|
53884
|
+
},
|
|
53885
|
+
// 更新样式
|
|
53886
|
+
updateStyles() {
|
|
53887
|
+
this.$nextTick(() => {
|
|
53888
|
+
this.setCSSVariables();
|
|
53889
|
+
this.$forceUpdate();
|
|
53890
|
+
});
|
|
53891
|
+
},
|
|
53892
|
+
// 设置CSS变量
|
|
53893
|
+
setCSSVariables() {
|
|
53894
|
+
if (!this.$el) return;
|
|
53895
|
+
const config = {
|
|
53896
|
+
...this.defaultConfig,
|
|
53897
|
+
...this.configData
|
|
53898
|
+
};
|
|
53899
|
+
|
|
53900
|
+
// 设置响应式字体大小
|
|
53901
|
+
if (config.mobileFontSize > 0) {
|
|
53902
|
+
this.$el.style.setProperty("--mobile-font-size", `${config.mobileFontSize}px`);
|
|
53903
|
+
}
|
|
53904
|
+
if (config.tabletFontSize > 0) {
|
|
53905
|
+
this.$el.style.setProperty("--tablet-font-size", `${config.tabletFontSize}px`);
|
|
53906
|
+
}
|
|
53907
|
+
|
|
53908
|
+
// 设置移动端文本对齐
|
|
53909
|
+
if (config.mobileTextAlign) {
|
|
53910
|
+
this.$el.style.setProperty("--mobile-text-align", config.mobileTextAlign);
|
|
53911
|
+
}
|
|
53912
|
+
},
|
|
53913
|
+
// 处理点击事件
|
|
53914
|
+
handleClick() {
|
|
53915
|
+
if (this.configData.linkUrl) {
|
|
53916
|
+
const target = this.configData.linkTarget || "_self";
|
|
53917
|
+
if (target === "_blank") {
|
|
53918
|
+
window.open(this.configData.linkUrl, "_blank");
|
|
53919
|
+
} else {
|
|
53920
|
+
window.location.href = this.configData.linkUrl;
|
|
53921
|
+
}
|
|
53922
|
+
}
|
|
53923
|
+
},
|
|
53924
|
+
// 获取动画样式
|
|
53925
|
+
getAnimationStyle() {
|
|
53926
|
+
const animationType = this.configData.animationType || this.defaultConfig.animationType;
|
|
53927
|
+
const duration = this.configData.animationDuration || this.defaultConfig.animationDuration;
|
|
53928
|
+
if (!this.configData.enableAnimation || animationType === "none") return "";
|
|
53929
|
+
return `${animationType} ${duration}ms ease-in-out`;
|
|
53930
|
+
},
|
|
53931
|
+
// 解析自定义样式
|
|
53932
|
+
parseCustomStyle(customStyle) {
|
|
53933
|
+
if (!customStyle) return {};
|
|
53934
|
+
try {
|
|
53935
|
+
// 简单的CSS样式解析
|
|
53936
|
+
const styles = {};
|
|
53937
|
+
const declarations = customStyle.split(";");
|
|
53938
|
+
declarations.forEach(declaration => {
|
|
53939
|
+
const [property, value] = declaration.split(":");
|
|
53940
|
+
if (property && value) {
|
|
53941
|
+
const camelCaseProperty = property.trim().replace(/-([a-z])/g, g => g[1].toUpperCase());
|
|
53942
|
+
styles[camelCaseProperty] = value.trim();
|
|
53943
|
+
}
|
|
53944
|
+
});
|
|
53945
|
+
return styles;
|
|
53946
|
+
} catch (error) {
|
|
53947
|
+
console.warn("解析自定义样式失败:", error);
|
|
53948
|
+
return {};
|
|
53949
|
+
}
|
|
53950
|
+
},
|
|
53951
|
+
// 文本内容验证
|
|
53952
|
+
validateTextContent() {
|
|
53953
|
+
const content = this.configData.textContent;
|
|
53954
|
+
if (!content || content.trim() === "") {
|
|
53955
|
+
console.warn("文本内容为空");
|
|
53956
|
+
return false;
|
|
53957
|
+
}
|
|
53958
|
+
return true;
|
|
53959
|
+
},
|
|
53960
|
+
// 获取纯文本内容
|
|
53961
|
+
getPlainTextContent() {
|
|
53962
|
+
return this.configData.textContent || "";
|
|
53963
|
+
},
|
|
53964
|
+
// 获取文本长度
|
|
53965
|
+
getTextLength() {
|
|
53966
|
+
return this.getPlainTextContent().length;
|
|
53967
|
+
},
|
|
53968
|
+
// 复制文本内容到剪贴板
|
|
53969
|
+
copyTextToClipboard() {
|
|
53970
|
+
const text = this.getPlainTextContent();
|
|
53971
|
+
if (navigator.clipboard && window.isSecureContext) {
|
|
53972
|
+
navigator.clipboard.writeText(text).then(() => {
|
|
53973
|
+
var _this$$message;
|
|
53974
|
+
(_this$$message = this.$message) === null || _this$$message === void 0 ? void 0 : _this$$message.success("文本已复制到剪贴板");
|
|
53975
|
+
}).catch(err => {
|
|
53976
|
+
console.error("复制失败:", err);
|
|
53977
|
+
});
|
|
53978
|
+
} else {
|
|
53979
|
+
// 降级方案
|
|
53980
|
+
const textArea = document.createElement("textarea");
|
|
53981
|
+
textArea.value = text;
|
|
53982
|
+
document.body.appendChild(textArea);
|
|
53983
|
+
textArea.select();
|
|
53984
|
+
try {
|
|
53985
|
+
var _this$$message2;
|
|
53986
|
+
document.execCommand("copy");
|
|
53987
|
+
(_this$$message2 = this.$message) === null || _this$$message2 === void 0 ? void 0 : _this$$message2.success("文本已复制到剪贴板");
|
|
53988
|
+
} catch (err) {
|
|
53989
|
+
console.error("复制失败:", err);
|
|
53990
|
+
}
|
|
53991
|
+
document.body.removeChild(textArea);
|
|
53992
|
+
}
|
|
53993
|
+
},
|
|
53994
|
+
// 文本搜索高亮
|
|
53995
|
+
highlightText(searchTerm) {
|
|
53996
|
+
if (!searchTerm) return;
|
|
53997
|
+
const content = this.getPlainTextContent();
|
|
53998
|
+
const regex = new RegExp(`(${searchTerm})`, "gi");
|
|
53999
|
+
const highlightedContent = content.replace(regex, "<mark>$1</mark>");
|
|
54000
|
+
|
|
54001
|
+
// 这里可以根据需要实现高亮显示逻辑
|
|
54002
|
+
console.log("高亮内容:", highlightedContent);
|
|
54003
|
+
},
|
|
54004
|
+
// 文本统计信息
|
|
54005
|
+
getTextStats() {
|
|
54006
|
+
const text = this.getPlainTextContent();
|
|
54007
|
+
const words = text.split(/\s+/).filter(word => word.length > 0);
|
|
54008
|
+
const lines = text.split("\n").length;
|
|
54009
|
+
const characters = text.length;
|
|
54010
|
+
const charactersNoSpaces = text.replace(/\s/g, "").length;
|
|
54011
|
+
return {
|
|
54012
|
+
characters,
|
|
54013
|
+
charactersNoSpaces,
|
|
54014
|
+
words: words.length,
|
|
54015
|
+
lines,
|
|
54016
|
+
paragraphs: text.split(/\n\s*\n/).filter(p => p.trim().length > 0).length
|
|
54017
|
+
};
|
|
54018
|
+
}
|
|
54019
|
+
}
|
|
54020
|
+
});
|
|
54021
|
+
;// ./package/cms-text/View.vue?vue&type=script&lang=js
|
|
54022
|
+
/* harmony default export */ var cms_text_Viewvue_type_script_lang_js = (Viewvue_type_script_lang_js);
|
|
54023
|
+
;// ./node_modules/mini-css-extract-plugin/dist/loader.js??clonedRuleSet-22.use[0]!./node_modules/css-loader/dist/cjs.js??clonedRuleSet-22.use[1]!./node_modules/@vue/vue-loader-v15/lib/loaders/stylePostLoader.js!./node_modules/postcss-loader/dist/cjs.js??clonedRuleSet-22.use[2]!./node_modules/sass-loader/dist/cjs.js??clonedRuleSet-22.use[3]!./node_modules/sass-loader/dist/cjs.js??clonedRuleSet-42.use[0]!./node_modules/@vue/vue-loader-v15/lib/index.js??vue-loader-options!./package/cms-text/View.vue?vue&type=style&index=0&id=0914066e&prod&lang=scss&scoped=true
|
|
54024
|
+
// extracted by mini-css-extract-plugin
|
|
54025
|
+
|
|
54026
|
+
;// ./package/cms-text/View.vue?vue&type=style&index=0&id=0914066e&prod&lang=scss&scoped=true
|
|
54027
|
+
|
|
54028
|
+
// EXTERNAL MODULE: ./node_modules/@vue/vue-loader-v15/lib/runtime/componentNormalizer.js
|
|
54029
|
+
var componentNormalizer = __webpack_require__(1656);
|
|
54030
|
+
;// ./package/cms-text/View.vue
|
|
54031
|
+
|
|
54032
|
+
|
|
54033
|
+
|
|
54034
|
+
;
|
|
54035
|
+
|
|
54036
|
+
|
|
54037
|
+
/* normalize component */
|
|
54038
|
+
|
|
54039
|
+
var component = (0,componentNormalizer/* default */.A)(
|
|
54040
|
+
cms_text_Viewvue_type_script_lang_js,
|
|
54041
|
+
render,
|
|
54042
|
+
staticRenderFns,
|
|
54043
|
+
false,
|
|
54044
|
+
null,
|
|
54045
|
+
"0914066e",
|
|
54046
|
+
null
|
|
54047
|
+
|
|
54048
|
+
)
|
|
54049
|
+
|
|
54050
|
+
/* harmony default export */ var View = (component.exports);
|
|
54051
|
+
|
|
53761
54052
|
/***/ }),
|
|
53762
54053
|
|
|
53763
54054
|
/***/ 7551:
|
|
@@ -53842,7 +54133,7 @@ $({ target: 'Iterator', proto: true, real: true }, {
|
|
|
53842
54133
|
__webpack_require__.r(__webpack_exports__);
|
|
53843
54134
|
/* harmony import */ var _baseConfig__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(649);
|
|
53844
54135
|
|
|
53845
|
-
const View = () => Promise.resolve(/* import() */).then(__webpack_require__.bind(__webpack_require__,
|
|
54136
|
+
const View = () => Promise.resolve(/* import() */).then(__webpack_require__.bind(__webpack_require__, 450));
|
|
53846
54137
|
const langData = {
|
|
53847
54138
|
input1: "请输入富文本内容"
|
|
53848
54139
|
};
|
|
@@ -56926,286 +57217,6 @@ const standard_page_list = [{
|
|
|
56926
57217
|
|
|
56927
57218
|
/***/ }),
|
|
56928
57219
|
|
|
56929
|
-
/***/ 8169:
|
|
56930
|
-
/***/ (function(__unused_webpack_module, __webpack_exports__, __webpack_require__) {
|
|
56931
|
-
|
|
56932
|
-
"use strict";
|
|
56933
|
-
// ESM COMPAT FLAG
|
|
56934
|
-
__webpack_require__.r(__webpack_exports__);
|
|
56935
|
-
|
|
56936
|
-
// EXPORTS
|
|
56937
|
-
__webpack_require__.d(__webpack_exports__, {
|
|
56938
|
-
"default": function() { return /* binding */ View; }
|
|
56939
|
-
});
|
|
56940
|
-
|
|
56941
|
-
;// ./node_modules/thread-loader/dist/cjs.js!./node_modules/babel-loader/lib/index.js??clonedRuleSet-40.use[1]!./node_modules/babel-loader/lib/index.js??clonedRuleSet-41.use!./node_modules/@vue/vue-loader-v15/lib/loaders/templateLoader.js??ruleSet[1].rules[4]!./node_modules/@vue/vue-loader-v15/lib/index.js??vue-loader-options!./package/cms-button/View.vue?vue&type=template&id=d7712dd2&scoped=true
|
|
56942
|
-
var render = function render() {
|
|
56943
|
-
var _vm = this,
|
|
56944
|
-
_c = _vm._self._c;
|
|
56945
|
-
return _c('BaseComp', _vm._b({
|
|
56946
|
-
attrs: {
|
|
56947
|
-
"data": _vm.data,
|
|
56948
|
-
"nowCompId": _vm.nowCompId,
|
|
56949
|
-
"isOpcacity": _vm.isOpcacity,
|
|
56950
|
-
"lang": _vm.lang
|
|
56951
|
-
},
|
|
56952
|
-
on: {
|
|
56953
|
-
"getConfigData": _vm.getConfigData
|
|
56954
|
-
}
|
|
56955
|
-
}, 'BaseComp', _vm.$attrs, false), [_c('section', {
|
|
56956
|
-
staticClass: "cms-button-container",
|
|
56957
|
-
class: [`align-${_vm.configData.textAlign || 'center'}`, _vm.configData.customClass || ''],
|
|
56958
|
-
style: _vm.containerStyle
|
|
56959
|
-
}, [_c('button', {
|
|
56960
|
-
staticClass: "cms-button",
|
|
56961
|
-
class: ['cms-button-element', {
|
|
56962
|
-
'has-link': _vm.configData.linkUrl,
|
|
56963
|
-
'hover-effect': _vm.configData.hoverEffect
|
|
56964
|
-
}],
|
|
56965
|
-
style: _vm.buttonStyle,
|
|
56966
|
-
attrs: {
|
|
56967
|
-
"disabled": _vm.configData.disabled
|
|
56968
|
-
},
|
|
56969
|
-
on: {
|
|
56970
|
-
"click": _vm.handleClick
|
|
56971
|
-
}
|
|
56972
|
-
}, [_vm._v(" " + _vm._s(_vm.configData.buttonText) + " "), _c('i', {
|
|
56973
|
-
staticClass: "el-icon-arrow-right el-icon--right"
|
|
56974
|
-
})])])]);
|
|
56975
|
-
};
|
|
56976
|
-
var staticRenderFns = [];
|
|
56977
|
-
|
|
56978
|
-
// EXTERNAL MODULE: ./node_modules/core-js/modules/es.iterator.constructor.js
|
|
56979
|
-
var es_iterator_constructor = __webpack_require__(8111);
|
|
56980
|
-
// EXTERNAL MODULE: ./node_modules/core-js/modules/es.iterator.for-each.js
|
|
56981
|
-
var es_iterator_for_each = __webpack_require__(7588);
|
|
56982
|
-
// EXTERNAL MODULE: ./package/baseComp.vue + 5 modules
|
|
56983
|
-
var baseComp = __webpack_require__(4272);
|
|
56984
|
-
;// ./node_modules/thread-loader/dist/cjs.js!./node_modules/babel-loader/lib/index.js??clonedRuleSet-40.use[1]!./node_modules/babel-loader/lib/index.js??clonedRuleSet-41.use!./node_modules/@vue/vue-loader-v15/lib/index.js??vue-loader-options!./package/cms-button/View.vue?vue&type=script&lang=js
|
|
56985
|
-
|
|
56986
|
-
|
|
56987
|
-
|
|
56988
|
-
|
|
56989
|
-
|
|
56990
|
-
/* harmony default export */ var Viewvue_type_script_lang_js = ({
|
|
56991
|
-
name: "cms-button",
|
|
56992
|
-
components: {
|
|
56993
|
-
BaseComp: baseComp["default"]
|
|
56994
|
-
},
|
|
56995
|
-
props: {
|
|
56996
|
-
data: {
|
|
56997
|
-
type: Object,
|
|
56998
|
-
default: () => {
|
|
56999
|
-
return {};
|
|
57000
|
-
}
|
|
57001
|
-
},
|
|
57002
|
-
nowCompId: {
|
|
57003
|
-
type: [String, Number],
|
|
57004
|
-
default: ""
|
|
57005
|
-
},
|
|
57006
|
-
isOpcacity: {
|
|
57007
|
-
type: Boolean,
|
|
57008
|
-
default: true
|
|
57009
|
-
},
|
|
57010
|
-
lang: {
|
|
57011
|
-
type: String,
|
|
57012
|
-
default: "zh-HK"
|
|
57013
|
-
}
|
|
57014
|
-
},
|
|
57015
|
-
data() {
|
|
57016
|
-
return {
|
|
57017
|
-
configData: {},
|
|
57018
|
-
// 默认配置数据
|
|
57019
|
-
defaultConfig: {
|
|
57020
|
-
// 文字设置
|
|
57021
|
-
buttonText: "按钮文字",
|
|
57022
|
-
textAlign: "center",
|
|
57023
|
-
fontSize: 16,
|
|
57024
|
-
fontColor: "#ffffff",
|
|
57025
|
-
fontWeight: "normal",
|
|
57026
|
-
// 样式控制
|
|
57027
|
-
backgroundColor: "#409eff",
|
|
57028
|
-
borderRadius: 30,
|
|
57029
|
-
borderWidth: 1,
|
|
57030
|
-
borderStyle: "solid",
|
|
57031
|
-
borderColor: "#409eff",
|
|
57032
|
-
// 空间布局
|
|
57033
|
-
paddingTop: 12,
|
|
57034
|
-
paddingBottom: 12,
|
|
57035
|
-
paddingLeft: 20,
|
|
57036
|
-
paddingRight: 20,
|
|
57037
|
-
marginTop: 0,
|
|
57038
|
-
marginBottom: 0,
|
|
57039
|
-
marginLeft: 0,
|
|
57040
|
-
marginRight: 0,
|
|
57041
|
-
// 交互功能
|
|
57042
|
-
linkUrl: "",
|
|
57043
|
-
linkTarget: "_self",
|
|
57044
|
-
disabled: false,
|
|
57045
|
-
// 高级配置
|
|
57046
|
-
customClass: "",
|
|
57047
|
-
customStyle: "",
|
|
57048
|
-
hoverEffect: false,
|
|
57049
|
-
// 尺寸设置
|
|
57050
|
-
buttonWidth: "300",
|
|
57051
|
-
buttonHeight: "48",
|
|
57052
|
-
minWidth: 80,
|
|
57053
|
-
minHeight: 36
|
|
57054
|
-
}
|
|
57055
|
-
};
|
|
57056
|
-
},
|
|
57057
|
-
mounted() {
|
|
57058
|
-
this.initConfigData();
|
|
57059
|
-
},
|
|
57060
|
-
watch: {
|
|
57061
|
-
configData: {
|
|
57062
|
-
handler() {
|
|
57063
|
-
this.updateStyles();
|
|
57064
|
-
},
|
|
57065
|
-
deep: true
|
|
57066
|
-
}
|
|
57067
|
-
},
|
|
57068
|
-
computed: {
|
|
57069
|
-
// 容器样式
|
|
57070
|
-
containerStyle() {
|
|
57071
|
-
const config = {
|
|
57072
|
-
...this.defaultConfig,
|
|
57073
|
-
...this.configData
|
|
57074
|
-
};
|
|
57075
|
-
return {
|
|
57076
|
-
backgroundColor: config.wrapperBackgroundColor,
|
|
57077
|
-
textAlign: config.textAlign,
|
|
57078
|
-
margin: `${config.marginTop}px ${config.marginRight}px ${config.marginBottom}px ${config.marginLeft}px`,
|
|
57079
|
-
...this.parseCustomStyle(config.customStyle)
|
|
57080
|
-
};
|
|
57081
|
-
},
|
|
57082
|
-
// 按钮样式
|
|
57083
|
-
buttonStyle() {
|
|
57084
|
-
const config = {
|
|
57085
|
-
...this.defaultConfig,
|
|
57086
|
-
...this.configData
|
|
57087
|
-
};
|
|
57088
|
-
return {
|
|
57089
|
-
// 文字样式
|
|
57090
|
-
fontSize: `${config.fontSize}px`,
|
|
57091
|
-
color: config.fontColor,
|
|
57092
|
-
fontWeight: config.fontWeight,
|
|
57093
|
-
// 背景和边框
|
|
57094
|
-
backgroundColor: config.backgroundColor ? config.backgroundColor : "transparent",
|
|
57095
|
-
borderRadius: `${config.borderRadius}px`,
|
|
57096
|
-
border: config.borderWidth ? `${config.borderWidth}px ${config.borderStyle} ${config.borderColor}` : "none",
|
|
57097
|
-
// 内边距
|
|
57098
|
-
padding: `${config.paddingTop}px ${config.paddingRight}px ${config.paddingBottom}px ${config.paddingLeft}px`,
|
|
57099
|
-
// 尺寸
|
|
57100
|
-
width: config.buttonWidth === "auto" ? "auto" : `${config.buttonWidth}px`,
|
|
57101
|
-
height: config.buttonHeight === "auto" ? "auto" : `${config.buttonHeight}px`,
|
|
57102
|
-
minWidth: `${config.minWidth}px`,
|
|
57103
|
-
minHeight: `${config.minHeight}px`,
|
|
57104
|
-
// 交互效果
|
|
57105
|
-
cursor: config.linkUrl ? "pointer" : "default",
|
|
57106
|
-
opacity: config.disabled ? 0.6 : 1,
|
|
57107
|
-
transition: config.hoverEffect ? "all 0.3s ease" : "none",
|
|
57108
|
-
// 基础样式
|
|
57109
|
-
outline: "none",
|
|
57110
|
-
textDecoration: "none",
|
|
57111
|
-
display: "inline-block",
|
|
57112
|
-
textAlign: "center",
|
|
57113
|
-
verticalAlign: "middle",
|
|
57114
|
-
userSelect: "none",
|
|
57115
|
-
whiteSpace: "nowrap"
|
|
57116
|
-
};
|
|
57117
|
-
}
|
|
57118
|
-
},
|
|
57119
|
-
methods: {
|
|
57120
|
-
// 初始化配置数据
|
|
57121
|
-
initConfigData() {
|
|
57122
|
-
this.configData = {
|
|
57123
|
-
...this.defaultConfig,
|
|
57124
|
-
...this.configData
|
|
57125
|
-
};
|
|
57126
|
-
},
|
|
57127
|
-
// 获取配置数据
|
|
57128
|
-
getConfigData(configData) {
|
|
57129
|
-
this.configData = {
|
|
57130
|
-
...this.defaultConfig,
|
|
57131
|
-
...configData
|
|
57132
|
-
};
|
|
57133
|
-
this.updateStyles();
|
|
57134
|
-
},
|
|
57135
|
-
// 更新样式
|
|
57136
|
-
updateStyles() {
|
|
57137
|
-
this.$nextTick(() => {
|
|
57138
|
-
this.$forceUpdate();
|
|
57139
|
-
});
|
|
57140
|
-
},
|
|
57141
|
-
// 处理点击事件
|
|
57142
|
-
handleClick() {
|
|
57143
|
-
if (this.configData.disabled) {
|
|
57144
|
-
return;
|
|
57145
|
-
}
|
|
57146
|
-
if (this.configData.linkUrl) {
|
|
57147
|
-
const target = this.configData.linkTarget || "_self";
|
|
57148
|
-
if (target === "_blank") {
|
|
57149
|
-
window.open(this.configData.linkUrl, "_blank");
|
|
57150
|
-
} else {
|
|
57151
|
-
window.location.href = this.configData.linkUrl;
|
|
57152
|
-
}
|
|
57153
|
-
}
|
|
57154
|
-
},
|
|
57155
|
-
// 解析自定义样式
|
|
57156
|
-
parseCustomStyle(customStyle) {
|
|
57157
|
-
if (!customStyle) return {};
|
|
57158
|
-
try {
|
|
57159
|
-
const styles = {};
|
|
57160
|
-
const declarations = customStyle.split(";");
|
|
57161
|
-
declarations.forEach(declaration => {
|
|
57162
|
-
const [property, value] = declaration.split(":");
|
|
57163
|
-
if (property && value) {
|
|
57164
|
-
const camelCaseProperty = property.trim().replace(/-([a-z])/g, g => g[1].toUpperCase());
|
|
57165
|
-
styles[camelCaseProperty] = value.trim();
|
|
57166
|
-
}
|
|
57167
|
-
});
|
|
57168
|
-
return styles;
|
|
57169
|
-
} catch (error) {
|
|
57170
|
-
console.warn("解析自定义样式失败:", error);
|
|
57171
|
-
return {};
|
|
57172
|
-
}
|
|
57173
|
-
}
|
|
57174
|
-
}
|
|
57175
|
-
});
|
|
57176
|
-
;// ./package/cms-button/View.vue?vue&type=script&lang=js
|
|
57177
|
-
/* harmony default export */ var cms_button_Viewvue_type_script_lang_js = (Viewvue_type_script_lang_js);
|
|
57178
|
-
;// ./node_modules/mini-css-extract-plugin/dist/loader.js??clonedRuleSet-22.use[0]!./node_modules/css-loader/dist/cjs.js??clonedRuleSet-22.use[1]!./node_modules/@vue/vue-loader-v15/lib/loaders/stylePostLoader.js!./node_modules/postcss-loader/dist/cjs.js??clonedRuleSet-22.use[2]!./node_modules/sass-loader/dist/cjs.js??clonedRuleSet-22.use[3]!./node_modules/sass-loader/dist/cjs.js??clonedRuleSet-42.use[0]!./node_modules/@vue/vue-loader-v15/lib/index.js??vue-loader-options!./package/cms-button/View.vue?vue&type=style&index=0&id=d7712dd2&prod&lang=scss&scoped=true
|
|
57179
|
-
// extracted by mini-css-extract-plugin
|
|
57180
|
-
|
|
57181
|
-
;// ./package/cms-button/View.vue?vue&type=style&index=0&id=d7712dd2&prod&lang=scss&scoped=true
|
|
57182
|
-
|
|
57183
|
-
// EXTERNAL MODULE: ./node_modules/@vue/vue-loader-v15/lib/runtime/componentNormalizer.js
|
|
57184
|
-
var componentNormalizer = __webpack_require__(1656);
|
|
57185
|
-
;// ./package/cms-button/View.vue
|
|
57186
|
-
|
|
57187
|
-
|
|
57188
|
-
|
|
57189
|
-
;
|
|
57190
|
-
|
|
57191
|
-
|
|
57192
|
-
/* normalize component */
|
|
57193
|
-
|
|
57194
|
-
var component = (0,componentNormalizer/* default */.A)(
|
|
57195
|
-
cms_button_Viewvue_type_script_lang_js,
|
|
57196
|
-
render,
|
|
57197
|
-
staticRenderFns,
|
|
57198
|
-
false,
|
|
57199
|
-
null,
|
|
57200
|
-
"d7712dd2",
|
|
57201
|
-
null
|
|
57202
|
-
|
|
57203
|
-
)
|
|
57204
|
-
|
|
57205
|
-
/* harmony default export */ var View = (component.exports);
|
|
57206
|
-
|
|
57207
|
-
/***/ }),
|
|
57208
|
-
|
|
57209
57220
|
/***/ 8227:
|
|
57210
57221
|
/***/ (function(module, __unused_webpack_exports, __webpack_require__) {
|
|
57211
57222
|
|
|
@@ -58026,7 +58037,7 @@ var lib_default = /*#__PURE__*/__webpack_require__.n(lib);
|
|
|
58026
58037
|
// images
|
|
58027
58038
|
placeholderImg: __webpack_require__(5335),
|
|
58028
58039
|
arrowRightImg: __webpack_require__(4860),
|
|
58029
|
-
arrowDownImg: __webpack_require__(
|
|
58040
|
+
arrowDownImg: __webpack_require__(1861),
|
|
58030
58041
|
arrowHoverImg: __webpack_require__(4116),
|
|
58031
58042
|
arrowActiveImg: __webpack_require__(9670),
|
|
58032
58043
|
shopList: [],
|