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.
@@ -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__, 6757));
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": 8169,
10644
- "./cms-button/View.vue": 8169,
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": 1861,
10657
- "./cms-column-card/View.vue": 1861,
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": 864,
10752
- "./cms-richText/View.vue": 864,
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": 6757,
10787
- "./cms-text/View.vue": 6757,
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(__unused_webpack_module, __webpack_exports__, __webpack_require__) {
11275
+ /***/ (function(module) {
11270
11276
 
11271
11277
  "use strict";
11272
- // ESM COMPAT FLAG
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__, 8169));
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: "#409eff",
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 = "#888888";
12844
- data.fontColor = "#fff";
12858
+ data.backgroundColor = "#fff";
12859
+ data.fontColor = "#191919";
12845
12860
  data.borderWidth = 1;
12846
12861
  data.borderStyle = "solid";
12847
- data.borderColor = "#fff";
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": 8169,
41769
+ "./cms-button/View.vue": 4018,
41483
41770
  "./cms-cells/View.vue": 5700,
41484
- "./cms-column-card/View.vue": 1861,
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": 864,
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": 6757,
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__, 1861));
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__, 864));
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__(4242),
58040
+ arrowDownImg: __webpack_require__(1861),
58030
58041
  arrowHoverImg: __webpack_require__(4116),
58031
58042
  arrowActiveImg: __webpack_require__(9670),
58032
58043
  shopList: [],