@dolphinweex/weex-harmony 0.1.78 → 0.1.81

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@dolphinweex/weex-harmony",
3
- "version": "0.1.78",
3
+ "version": "0.1.81",
4
4
  "description": "weex harmony adapter",
5
5
  "main": "index.js",
6
6
  "files": [
@@ -1,5 +1,5 @@
1
1
  <template>
2
- <div>
2
+ <div @viewappear="allHarmonyViewAppear">
3
3
  <div class="progress-container" v-if="progressText">
4
4
  <img class="progress-loading" src="" alt="loading" />
5
5
  <text class="progress-text">{{progressText}}</text>
@@ -40,7 +40,7 @@ export default {
40
40
  embedId: `embedId_iframe_${
41
41
  Date.now().toString(36) + Math.random().toString(36).substring(2)
42
42
  }`,
43
- height: '0px',
43
+ height: window.location.href.includes('plugin-menu') ? '0px' : '100%',
44
44
  _resizeObserver: null,
45
45
  _heightCheckTimer: null,
46
46
  _weexRoot: null,
@@ -86,7 +86,6 @@ export default {
86
86
  if (args.progressText) {
87
87
  this.progressText = args.progressText;
88
88
  } else if (args.url) {
89
- this.progressText = ''
90
89
  this.url = args.url;
91
90
  this.backgroundColor = args.pageBackgroundColor;
92
91
  this.pluginType = args.pluginType
@@ -169,7 +168,14 @@ export default {
169
168
  window.addEventListener("message", this._onMessage, false);
170
169
  },
171
170
  methods: {
172
- onPageFinish() {
171
+ allHarmonyViewAppear() {
172
+ const iframe = this.$refs.iframe;
173
+ if (iframe && iframe.contentWindow && typeof iframe.contentWindow.harmonyViewAppear === 'function') {
174
+ iframe.contentWindow.harmonyViewAppear();
175
+ }
176
+ }
177
+ },
178
+ onPageFinish() {
173
179
  if (this.$refs["iframe"]) {
174
180
  this.$refs["iframe"].contentWindow.$midea_harmony_native =
175
181
  window.$midea_harmony_native;
@@ -22,11 +22,13 @@
22
22
  v-for="(item, index) in data.list"
23
23
  :key="item.id"
24
24
  class="grid-item"
25
- :class="{
26
- 'being-dragged': draggingIndex === index,
27
- hidden: isDragClone && draggingIndex === index,
28
- disabled: item.disabled === true
29
- }"
25
+ :class="{
26
+ 'being-dragged': draggingIndex === index,
27
+ hidden: isDragClone && draggingIndex === index,
28
+ disabled: item.disabled === true,
29
+ deleted: item.deleted
30
+ }"
31
+ v-show="!item.deleted"
30
32
  :data-index="index"
31
33
  @touchstart="(e) => onTouchStart(e, index)"
32
34
  @touchmove="onTouchMove"
@@ -37,9 +39,9 @@
37
39
  <div class="box" :class="{ shaking: isEditing }">
38
40
  <div class="thumb-wrap">
39
41
  <img class="thumb" :src="item.imageSrc" alt="" />
40
- <button class="delete-btn"
41
- :style="{ fontSize : data.deleteBtnSize && data.deleteBtnSize * 4 || 16 * 4 }"
42
- @click.stop="onDelete(index, item)">×</button>
42
+ <button class="delete-btn"
43
+ :style="{ fontSize : data.deleteBtnSize && data.deleteBtnSize * 4 || 16 * 4 }"
44
+ @click.stop="requestDelete(index, item)">×</button>
43
45
  </div>
44
46
  <div
45
47
  class="label-row"
@@ -68,8 +70,6 @@
68
70
  </div>
69
71
  </transition-group>
70
72
  </div>
71
-
72
- <!-- 编辑名称弹窗 -->
73
73
  <div v-if="showEditDialog" class="modal-mask">
74
74
  <div class="modal">
75
75
  <div class="modal-title">当前视角名称</div>
@@ -78,11 +78,22 @@
78
78
  v-model="editInputValue"
79
79
  :placeholder="data.inputPlaceholder || ''"
80
80
  />
81
- <div class="modal-actions">
82
- <text class="btn cancel" @click="onEditCancel">取消</text>
83
- <div class="btn-divider"></div>
84
- <text class="btn confirm" @click="onEditConfirm">确认</text>
85
- </div>
81
+ <div class="modal-actions">
82
+ <text class="btn cancel" @click="onEditCancel">取消</text>
83
+ <div class="btn-divider"></div>
84
+ <text class="btn confirm" @click="onEditConfirm">确认</text>
85
+ </div>
86
+ </div>
87
+ </div>
88
+ <div v-if="showDeleteConfirm" class="modal-mask">
89
+ <div class="modal">
90
+ <div class="modal-title">温馨提示</div>
91
+ <div class="modal-content">删除所选关注视角后,相关的智能场景将执行失败</div>
92
+ <div class="modal-actions">
93
+ <text class="btn cancel" @click="onDeleteCancel">取消</text>
94
+ <div class="btn-divider"></div>
95
+ <text class="btn confirm" @click="onDeleteConfirmAction">确定</text>
96
+ </div>
86
97
  </div>
87
98
  </div>
88
99
  </div>
@@ -134,6 +145,8 @@
134
145
  showEditDialog: false,
135
146
  editInputValue: '',
136
147
  editIndex: null,
148
+ showDeleteConfirm: false,
149
+ pendingDeleteIndex: null,
137
150
  scale: weex.config.env.scale
138
151
  };
139
152
  },
@@ -163,6 +176,25 @@
163
176
  if (this.isTouchDragging || this.longPressTimer || this.secondLongPressTimer) return;
164
177
  this.$emit('onClickEvent', { item, index });
165
178
  },
179
+
180
+ requestDelete(index, item) {
181
+ const targetItem = this.data.list[index];
182
+ if (!targetItem || targetItem.deleted) return;
183
+ this.pendingDeleteIndex = index;
184
+ this.showDeleteConfirm = true;
185
+ },
186
+
187
+ onDeleteCancel() {
188
+ this.showDeleteConfirm = false;
189
+ this.pendingDeleteIndex = null;
190
+ },
191
+
192
+ onDeleteConfirmAction() {
193
+ if (this.pendingDeleteIndex === null) return;
194
+ const item = this.data.list[this.pendingDeleteIndex];
195
+ this.onDelete(this.pendingDeleteIndex, item);
196
+ this.onDeleteCancel();
197
+ },
166
198
 
167
199
  onEditClick(item, index) {
168
200
  // 点击编辑按钮:弹出编辑名称对话框
@@ -175,10 +207,58 @@
175
207
  this.editInputValue = '';
176
208
  this.editIndex = null;
177
209
  },
210
+
211
+ /**
212
+ * @description 校验输入内容,仅允许中文/英文/数字,且去除前后空白。
213
+ * @param {string} value 当前输入值
214
+ * @returns {{ valid: boolean, message?: string, value?: string }}
215
+ */
216
+ validateLabelInput(value) {
217
+ const trimmedValue = (value || '').trim();
218
+ if (!trimmedValue) {
219
+ return { valid: false, message: '视角名称不能为空' };
220
+ }
221
+ if (/[^a-zA-Z0-9\u4e00-\u9fa5]/.test(trimmedValue)) {
222
+ return { valid: false, message: '视角名称只能输入中文、英文和数字' };
223
+ }
224
+ return { valid: true, value: trimmedValue };
225
+ },
226
+
227
+ showToast(message) {
228
+ console.log(`[TOAST 提示]: ${message}`);
229
+ if (typeof weex !== 'undefined' && weex.requireModule('bridgeModule')) {
230
+ weex.requireModule('bridgeModule').toast({
231
+ message: message,
232
+ bottom: 1,
233
+ duration: 1.5 // 1.5s
234
+ });
235
+ }
236
+ },
237
+
178
238
  onEditConfirm() {
239
+ const validation = this.validateLabelInput(this.editInputValue);
240
+ if (!validation.valid) {
241
+ this.showToast(validation.message);
242
+ return;
243
+ }
244
+ const newLabel = validation.value;
245
+
246
+ // 3. 检查长度
247
+ if (newLabel.length > 8) {
248
+ // 长度超限:提示并阻止后续更新和关闭逻辑
249
+ this.showToast('限8个字符以内名称,请重新输入');
250
+ return;
251
+ }
252
+ const duplicateExists = this.data.list && this.data.list.some((it, idx) => {
253
+ if (idx === this.editIndex) return false;
254
+ if (!it || it.deleted) return false;
255
+ return String(it.label || '') === newLabel;
256
+ });
257
+ if (duplicateExists) {
258
+ this.showToast('已存在此视角');
259
+ return;
260
+ }
179
261
  if (this.editIndex !== null && this.data.list && this.data.list[this.editIndex]) {
180
- const newLabel = (this.editInputValue || '').trim();
181
- // 更新 label
182
262
  this.$set(this.data.list[this.editIndex], 'label', newLabel);
183
263
  // 通知外部(可选)
184
264
  this.$emit('onLabelEdited', { index: this.editIndex, label: newLabel, item: this.data.list[this.editIndex] });
@@ -188,16 +268,27 @@
188
268
  this.editIndex = null;
189
269
  },
190
270
 
191
- onDelete(item, index) {
192
- this.$emit('onDeleteEvent', { item, index });
193
- // 默认本地也删除
194
- this.data.list.splice(index, 1);
195
- this.$nextTick(this.measureItemSize);
196
- },
271
+ /**
272
+ * @description 删除列表项
273
+ * FIX: 修复了参数顺序错误,确保传入的第一个参数是 index
274
+ * @param {number} index 列表项的索引
275
+ * @param {object} item 列表项数据
276
+ */
277
+ onDelete(index, item) {
278
+ const currentItem = this.data.list[index];
279
+ if (!currentItem) return;
280
+ this.$emit('onDeleteEvent', { item: currentItem, index });
281
+ this.$set(currentItem, 'deleted', true);
282
+ this.$nextTick(this.measureItemSize);
283
+ },
197
284
 
198
285
  onTouchStart(e, index) {
199
286
  if (!e.changedTouches || e.changedTouches.length === 0) return;
200
- this.measureItemSize();
287
+ const targetItem = this.data.list[index];
288
+ if (targetItem && targetItem.deleted) {
289
+ return;
290
+ }
291
+ this.measureItemSize();
201
292
  const touch = e.changedTouches[0];
202
293
  this.touchStartX = touch.pageX;
203
294
  this.touchStartY = touch.pageY;
@@ -354,7 +445,9 @@
354
445
  const gridItems = Array.from(this.$el.querySelectorAll('.grid-item'));
355
446
  let targetIndex = null;
356
447
  for (let i = 0; i < gridItems.length; i++) {
357
- if (i === this.draggingIndex) continue;
448
+ if (i === this.draggingIndex) continue;
449
+ const listItem = this.data.list[i];
450
+ if (listItem && listItem.deleted) continue;
358
451
  const rect = gridItems[i].getBoundingClientRect();
359
452
  const centerX = (rect.left + rect.right) / 2;
360
453
  const centerY = (rect.top + rect.bottom) / 2;
@@ -380,11 +473,15 @@
380
473
  },
381
474
  getListData(callback) {
382
475
  const list = Array.isArray(this.data && this.data.list) ? this.data.list : [];
383
- const arr = list.map((it) => ({
384
- id: String((it && (it.id != null ? it.id : '')) || ''),
385
- label: String((it && (it.label != null ? it.label : '')) || ''),
386
- imageSrc: (it && it.imageSrc) || ''
387
- }));
476
+ const arr = [];
477
+ list.forEach((it) => {
478
+ if (!it || it.deleted) return;
479
+ arr.push({
480
+ id: String((it && (it.id != null ? it.id : '')) || ''),
481
+ label: String((it && (it.label != null ? it.label : '')) || ''),
482
+ imageSrc: (it && it.imageSrc) || ''
483
+ });
484
+ });
388
485
  const payload = { listData: arr, list: arr };
389
486
  if (typeof callback === 'function') {
390
487
  try { callback(payload); } catch (e) { /* ignore */ }
@@ -471,8 +568,6 @@
471
568
  flex-direction: row;
472
569
  justify-content: center;
473
570
  gap: 8px;
474
- }
475
- .edit-icon {
476
571
  }
477
572
  .drag-clone {
478
573
  box-sizing: border-box;
@@ -507,6 +602,13 @@
507
602
  color: #222;
508
603
  margin: 24px 0 24px 0px;
509
604
  text-align: center;
605
+ font-weight: 500;
606
+ }
607
+ .modal-content {
608
+ font-size: 24px;
609
+ color: #333;
610
+ text-align: center;
611
+ padding-bottom: 16px;
510
612
  }
511
613
  .modal-input {
512
614
  width: 100%;
@@ -538,7 +640,4 @@
538
640
  height: 32px;
539
641
  background: #eee;
540
642
  }
541
- </style>
542
-
543
-
544
-
643
+ </style>
@@ -201,11 +201,11 @@ export default {
201
201
  },
202
202
 
203
203
  onStart(res) {
204
- this.$emit('onStart', res);
204
+ this.$emit('start', res);
205
205
  },
206
206
 
207
207
  onPause(res) {
208
- this.$emit('onPause', res);
208
+ this.$emit('Pause', res);
209
209
  },
210
210
 
211
211
  finish(res) {
@@ -213,11 +213,11 @@ export default {
213
213
  },
214
214
 
215
215
  onFail(res) {
216
- this.$emit('onFail', res);
216
+ this.$emit('fail', res);
217
217
  },
218
218
 
219
219
  onReadyToPlay(res) {
220
- this.$emit('onReadyToPlay', res);
220
+ this.$emit('readyToPlay', res);
221
221
  },
222
222
 
223
223
  deleteVideo(res) {
package/src/.DS_Store DELETED
Binary file
Binary file