• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1/*
2 * Copyright (c) 2023-2023 Huawei Device Co., Ltd.
3 * Licensed under the Apache License, Version 2.0 (the "License");
4 * you may not use this file except in compliance with the License.
5 * You may obtain a copy of the License at
6 *
7 *     http://www.apache.org/licenses/LICENSE-2.0
8 *
9 * Unless required by applicable law or agreed to in writing, software
10 * distributed under the License is distributed on an "AS IS" BASIS,
11 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12 * See the License for the specific language governing permissions and
13 * limitations under the License.
14 */
15
16var __decorate = this && this.__decorate || function(e, t, o, i) {
17  var s, n = arguments.length,
18    r = n < 3 ? t : null === i ? i = Object.getOwnPropertyDescriptor(t, o) : i;
19  if ("object" == typeof Reflect && "function" == typeof Reflect.decorate) r = Reflect.decorate(e, t, o, i);
20  else
21    for (var a = e.length - 1; a >= 0; a--)(s = e[a]) && (r = (n < 3 ? s(r) : n > 3 ? s(t, o, r) : s(t, o)) || r);
22  return n > 3 && r && Object.defineProperty(t, o, r), r
23};
24const KeyCode = requireNapi("multimodalInput.keyCode").KeyCode;
25const MeasureText = requireNapi("measure");
26const PUBLIC_MORE = "";
27export class TabTitleBar extends ViewPU {
28  constructor(e, t, o, i = -1) {
29    super(e, o, i);
30    this.tabItems = void 0;
31    this.menuItems = void 0;
32    this.swiperContent = void 0;
33    this.__tabWidth = new ObservedPropertySimplePU(0, this, "tabWidth");
34    this.__currentIndex = new ObservedPropertySimplePU(0, this, "currentIndex");
35    this.menuSectionWidth = 0;
36    this.tabOffsets = Array();
37    this.imageWidths = Array();
38    this.scroller = new Scroller;
39    this.swiperController = new SwiperController;
40    this.settings = new RenderingContextSettings(!0);
41    this.leftContext2D = new CanvasRenderingContext2D(this.settings);
42    this.rightContext2D = new CanvasRenderingContext2D(this.settings);
43    this.setInitiallyProvidedValue(t)
44  }
45  setInitiallyProvidedValue(e) {
46    void 0 !== e.tabItems && (this.tabItems = e.tabItems);
47    void 0 !== e.menuItems && (this.menuItems = e.menuItems);
48    void 0 !== e.swiperContent && (this.swiperContent = e.swiperContent);
49    void 0 !== e.tabWidth && (this.tabWidth = e.tabWidth);
50    void 0 !== e.currentIndex && (this.currentIndex = e.currentIndex);
51    void 0 !== e.menuSectionWidth && (this.menuSectionWidth = e.menuSectionWidth);
52    void 0 !== e.tabOffsets && (this.tabOffsets = e.tabOffsets);
53    void 0 !== e.imageWidths && (this.imageWidths = e.imageWidths);
54    void 0 !== e.scroller && (this.scroller = e.scroller);
55    void 0 !== e.swiperController && (this.swiperController = e.swiperController);
56    void 0 !== e.settings && (this.settings = e.settings);
57    void 0 !== e.leftContext2D && (this.leftContext2D = e.leftContext2D);
58    void 0 !== e.rightContext2D && (this.rightContext2D = e.rightContext2D)
59  }
60  updateStateVars(e) {}
61  purgeVariableDependenciesOnElmtId(e) {
62    this.__tabWidth.purgeDependencyOnElmtId(e);
63    this.__currentIndex.purgeDependencyOnElmtId(e)
64  }
65  aboutToBeDeleted() {
66    this.__tabWidth.aboutToBeDeleted();
67    this.__currentIndex.aboutToBeDeleted();
68    SubscriberManager.Get().delete(this.id__());
69    this.aboutToBeDeletedInternal()
70  }
71  get tabWidth() {
72    return this.__tabWidth.get()
73  }
74  set tabWidth(e) {
75    this.__tabWidth.set(e)
76  }
77  get currentIndex() {
78    return this.__currentIndex.get()
79  }
80  set currentIndex(e) {
81    this.__currentIndex.set(e)
82  }
83  GradientMask(e, t, o, i, s, n = null) {
84    this.observeComponentCreation(((e, t) => {
85      ViewStackProcessor.StartGetAccessRecordingFor(e);
86      Column.create();
87      Column.width(TabTitleBar.gradientMaskWidth);
88      Column.height(TabTitleBar.totalHeight);
89      t || Column.pop();
90      ViewStackProcessor.StopGetAccessRecording()
91    }));
92    this.observeComponentCreation(((n, r) => {
93      ViewStackProcessor.StartGetAccessRecordingFor(n);
94      Canvas.create(e);
95      Canvas.width(TabTitleBar.gradientMaskWidth);
96      Canvas.height(TabTitleBar.totalHeight);
97      Canvas.onReady((() => {
98        var n = e.createLinearGradient(t, o, i, s);
99        n.addColorStop(0, "#ffffffff");
100        n.addColorStop(1, "#00ffffff");
101        e.fillStyle = n;
102        e.fillRect(0, 0, TabTitleBar.gradientMaskWidth, TabTitleBar.totalHeight)
103      }));
104      r || Canvas.pop();
105      ViewStackProcessor.StopGetAccessRecording()
106    }));
107    Canvas.pop();
108    Column.pop()
109  }
110  aboutToAppear() {
111    this.tabItems.forEach((e => {
112      this.imageWidths.push(0)
113    }));
114    this.loadOffsets()
115  }
116  loadOffsets() {
117    this.tabOffsets.length = 0;
118    let e = 0;
119    this.tabOffsets.push(e);
120    e += TabContentItem.marginFirst;
121    this.tabItems.forEach(((t, o) => {
122      if (void 0 !== t.icon) Math.abs(this.imageWidths[o]) > TabContentItem.imageHotZoneWidth ? e += this.imageWidths[o] : e += TabContentItem.imageHotZoneWidth;
123      else {
124        e += TabContentItem.paddingLeft;
125        e += px2vp(MeasureText.measureText({
126          textContent: t.title.toString(),
127          fontSize: 18,
128          fontWeight: FontWeight.Medium
129        }));
130        e += TabContentItem.paddingRight
131      }
132      this.tabOffsets.push(e)
133    }))
134  }
135  initialRender() {
136    this.observeComponentCreation(((e, t) => {
137      ViewStackProcessor.StartGetAccessRecordingFor(e);
138      Column.create();
139      t || Column.pop();
140      ViewStackProcessor.StopGetAccessRecording()
141    }));
142    this.observeComponentCreation(((e, t) => {
143      ViewStackProcessor.StartGetAccessRecordingFor(e);
144      Flex.create({
145        justifyContent: FlexAlign.SpaceBetween,
146        alignItems: ItemAlign.Stretch
147      });
148      Flex.backgroundColor({
149        id: -1,
150        type: 10001,
151        params: ["sys.color.ohos_id_color_background"],
152        bundleName: "",
153        moduleName: ""
154      });
155      Flex.margin({
156        right: {
157          id: -1,
158          type: 10002,
159          params: ["sys.float.ohos_id_max_padding_end"],
160          bundleName: "",
161          moduleName: ""
162        }
163      });
164      Flex.onAreaChange(((e, t) => {
165        this.tabWidth = Number(t.width) - this.menuSectionWidth
166      }));
167      t || Flex.pop();
168      ViewStackProcessor.StopGetAccessRecording()
169    }));
170    this.observeComponentCreation(((e, t) => {
171      ViewStackProcessor.StartGetAccessRecordingFor(e);
172      Stack.create({
173        alignContent: Alignment.End
174      });
175      t || Stack.pop();
176      ViewStackProcessor.StopGetAccessRecording()
177    }));
178    this.observeComponentCreation(((e, t) => {
179      ViewStackProcessor.StartGetAccessRecordingFor(e);
180      Stack.create({
181        alignContent: Alignment.Start
182      });
183      t || Stack.pop();
184      ViewStackProcessor.StopGetAccessRecording()
185    }));
186    this.observeComponentCreation(((e, t) => {
187      ViewStackProcessor.StartGetAccessRecordingFor(e);
188      Column.create();
189      t || Column.pop();
190      ViewStackProcessor.StopGetAccessRecording()
191    }));
192    this.observeComponentCreation(((e, t) => {
193      ViewStackProcessor.StartGetAccessRecordingFor(e);
194      List.create({
195        initialIndex: 0,
196        scroller: this.scroller,
197        space: 0
198      });
199      List.width("100%");
200      List.height(TabTitleBar.totalHeight);
201      List.constraintSize({
202        maxWidth: this.tabWidth
203      });
204      List.edgeEffect(EdgeEffect.Spring);
205      List.listDirection(Axis.Horizontal);
206      List.scrollBar(BarState.Off);
207      t || List.pop();
208      ViewStackProcessor.StopGetAccessRecording()
209    }));
210    this.observeComponentCreation(((e, t) => {
211      ViewStackProcessor.StartGetAccessRecordingFor(e);
212      ForEach.create();
213      this.forEachUpdateFunction(e, this.tabItems, ((e, t) => {
214        const o = e;
215        {
216          const e = !0;
217          const i = (t, o) => {
218            ViewStackProcessor.StartGetAccessRecordingFor(t);
219            ListItem.create(n, e);
220            o || ListItem.pop();
221            ViewStackProcessor.StopGetAccessRecording()
222          };
223          const s = () => {
224            this.observeComponentCreation(i);
225            this.observeComponentCreation(((e, i) => {
226              ViewStackProcessor.StartGetAccessRecordingFor(e);
227              i ? ViewPU.create(new TabContentItem(this, {
228                item: o,
229                index: t,
230                maxIndex: this.tabItems.length - 1,
231                currentIndex: this.currentIndex,
232                onCustomClick: e => this.currentIndex = e,
233                onImageComplete: e => {
234                  this.imageWidths[t] = e;
235                  this.loadOffsets()
236                }
237              }, void 0, e)) : this.updateStateVarsOfChildByElmtId(e, {
238                currentIndex: this.currentIndex
239              });
240              ViewStackProcessor.StopGetAccessRecording()
241            }));
242            ListItem.pop()
243          };
244          const n = (e, s) => {
245            i(e, s);
246            this.updateFuncByElmtId.set(e, i);
247            this.observeComponentCreation(((e, i) => {
248              ViewStackProcessor.StartGetAccessRecordingFor(e);
249              i ? ViewPU.create(new TabContentItem(this, {
250                item: o,
251                index: t,
252                maxIndex: this.tabItems.length - 1,
253                currentIndex: this.currentIndex,
254                onCustomClick: e => this.currentIndex = e,
255                onImageComplete: e => {
256                  this.imageWidths[t] = e;
257                  this.loadOffsets()
258                }
259              }, void 0, e)) : this.updateStateVarsOfChildByElmtId(e, {
260                currentIndex: this.currentIndex
261              });
262              ViewStackProcessor.StopGetAccessRecording()
263            }));
264            ListItem.pop()
265          };
266          e ? (() => {
267            this.observeComponentCreation(i);
268            ListItem.pop()
269          })() : s()
270        }
271      }), void 0, !0, !1);
272      t || ForEach.pop();
273      ViewStackProcessor.StopGetAccessRecording()
274    }));
275    ForEach.pop();
276    List.pop();
277    Column.pop();
278    this.GradientMask.bind(this)(this.leftContext2D, 0, TabTitleBar.totalHeight / 2, TabTitleBar.gradientMaskWidth, TabTitleBar.totalHeight / 2);
279    Stack.pop();
280    this.GradientMask.bind(this)(this.rightContext2D, TabTitleBar.gradientMaskWidth, TabTitleBar.totalHeight / 2, 0, TabTitleBar.totalHeight / 2);
281    Stack.pop();
282    this.observeComponentCreation(((e, t) => {
283      ViewStackProcessor.StartGetAccessRecordingFor(e);
284      If.create();
285      void 0 !== this.menuItems && this.menuItems.length > 0 ? this.ifElseBranchUpdateFunction(0, (() => {
286        this.observeComponentCreation(((e, t) => {
287          ViewStackProcessor.StartGetAccessRecordingFor(e);
288          __Common__.create();
289          __Common__.height(TabTitleBar.totalHeight);
290          __Common__.onAreaChange(((e, t) => {
291            this.menuSectionWidth = Number(t.width)
292          }));
293          t || __Common__.pop();
294          ViewStackProcessor.StopGetAccessRecording()
295        }));
296        this.observeComponentCreation(((e, t) => {
297          ViewStackProcessor.StartGetAccessRecordingFor(e);
298          t ? ViewPU.create(new CollapsibleMenuSection(this, {
299            menuItems: this.menuItems,
300            index: 1 + TabTitleBar.instanceCount++
301          }, void 0, e)) : this.updateStateVarsOfChildByElmtId(e, {});
302          ViewStackProcessor.StopGetAccessRecording()
303        }));
304        __Common__.pop()
305      })) : If.branchId(1);
306      t || If.pop();
307      ViewStackProcessor.StopGetAccessRecording()
308    }));
309    If.pop();
310    Flex.pop();
311    this.observeComponentCreation(((e, t) => {
312      ViewStackProcessor.StartGetAccessRecordingFor(e);
313      Column.create();
314      t || Column.pop();
315      ViewStackProcessor.StopGetAccessRecording()
316    }));
317    this.observeComponentCreation(((e, t) => {
318      ViewStackProcessor.StartGetAccessRecordingFor(e);
319      Swiper.create(this.swiperController);
320      Swiper.index(this.currentIndex);
321      Swiper.itemSpace(0);
322      Swiper.indicator(!1);
323      Swiper.width("100%");
324      Swiper.height("100%");
325      Swiper.curve(Curve.Friction);
326      Swiper.onChange((e => {
327        const t = this.tabOffsets[e] + TabTitleBar.correctionOffset;
328        this.currentIndex = e;
329        this.scroller.scrollTo({
330          xOffset: t > 0 ? t : 0,
331          yOffset: 0,
332          animation: {
333            duration: 300,
334            curve: Curve.EaseInOut
335          }
336        })
337      }));
338      Swiper.onAppear((() => {
339        this.scroller.scrollToIndex(this.currentIndex);
340        this.scroller.scrollBy(TabTitleBar.correctionOffset, 0)
341      }));
342      t || Swiper.pop();
343      ViewStackProcessor.StopGetAccessRecording()
344    }));
345    this.swiperContent.bind(this)();
346    Swiper.pop();
347    Column.pop();
348    Column.pop()
349  }
350  rerender() {
351    this.updateDirtyElements()
352  }
353}
354TabTitleBar.totalHeight = 56;
355TabTitleBar.correctionOffset = -40;
356TabTitleBar.gradientMaskWidth = 24;
357TabTitleBar.instanceCount = 0;
358__decorate([], TabTitleBar.prototype, "GradientMask", null);
359class CollapsibleMenuSection extends ViewPU {
360  constructor(e, t, o, i = -1) {
361    super(e, o, i);
362    this.menuItems = void 0;
363    this.index = void 0;
364    this.firstFocusableIndex = -1;
365    this.__isPopupShown = new ObservedPropertySimplePU(!1, this, "isPopupShown");
366    this.__isMoreIconOnFocus = new ObservedPropertySimplePU(!1, this, "isMoreIconOnFocus");
367    this.__isMoreIconOnHover = new ObservedPropertySimplePU(!1, this, "isMoreIconOnHover");
368    this.__isMoreIconOnClick = new ObservedPropertySimplePU(!1, this, "isMoreIconOnClick");
369    this.setInitiallyProvidedValue(t)
370  }
371  setInitiallyProvidedValue(e) {
372    void 0 !== e.menuItems && (this.menuItems = e.menuItems);
373    void 0 !== e.index && (this.index = e.index);
374    void 0 !== e.firstFocusableIndex && (this.firstFocusableIndex = e.firstFocusableIndex);
375    void 0 !== e.isPopupShown && (this.isPopupShown = e.isPopupShown);
376    void 0 !== e.isMoreIconOnFocus && (this.isMoreIconOnFocus = e.isMoreIconOnFocus);
377    void 0 !== e.isMoreIconOnHover && (this.isMoreIconOnHover = e.isMoreIconOnHover);
378    void 0 !== e.isMoreIconOnClick && (this.isMoreIconOnClick = e.isMoreIconOnClick)
379  }
380  updateStateVars(e) {}
381  purgeVariableDependenciesOnElmtId(e) {
382    this.__isPopupShown.purgeDependencyOnElmtId(e);
383    this.__isMoreIconOnFocus.purgeDependencyOnElmtId(e);
384    this.__isMoreIconOnHover.purgeDependencyOnElmtId(e);
385    this.__isMoreIconOnClick.purgeDependencyOnElmtId(e)
386  }
387  aboutToBeDeleted() {
388    this.__isPopupShown.aboutToBeDeleted();
389    this.__isMoreIconOnFocus.aboutToBeDeleted();
390    this.__isMoreIconOnHover.aboutToBeDeleted();
391    this.__isMoreIconOnClick.aboutToBeDeleted();
392    SubscriberManager.Get().delete(this.id__());
393    this.aboutToBeDeletedInternal()
394  }
395  get isPopupShown() {
396    return this.__isPopupShown.get()
397  }
398  set isPopupShown(e) {
399    this.__isPopupShown.set(e)
400  }
401  get isMoreIconOnFocus() {
402    return this.__isMoreIconOnFocus.get()
403  }
404  set isMoreIconOnFocus(e) {
405    this.__isMoreIconOnFocus.set(e)
406  }
407  get isMoreIconOnHover() {
408    return this.__isMoreIconOnHover.get()
409  }
410  set isMoreIconOnHover(e) {
411    this.__isMoreIconOnHover.set(e)
412  }
413  get isMoreIconOnClick() {
414    return this.__isMoreIconOnClick.get()
415  }
416  set isMoreIconOnClick(e) {
417    this.__isMoreIconOnClick.set(e)
418  }
419  getMoreIconFgColor() {
420    return this.isMoreIconOnClick ? {
421      id: -1,
422      type: 10001,
423      params: ["sys.color.ohos_id_color_titlebar_icon_pressed"],
424      bundleName: "",
425      moduleName: ""
426    } : {
427      id: -1,
428      type: 10001,
429      params: ["sys.color.ohos_id_color_titlebar_icon"],
430      bundleName: "",
431      moduleName: ""
432    }
433  }
434  getMoreIconBgColor() {
435    return this.isMoreIconOnClick ? {
436      id: -1,
437      type: 10001,
438      params: ["sys.color.ohos_id_color_click_effect"],
439      bundleName: "",
440      moduleName: ""
441    } : this.isMoreIconOnHover ? {
442      id: -1,
443      type: 10001,
444      params: ["sys.color.ohos_id_color_hover"],
445      bundleName: "",
446      moduleName: ""
447    } : Color.Transparent
448  }
449  aboutToAppear() {
450    this.menuItems.forEach(((e, t) => {
451      e.isEnabled && -1 == this.firstFocusableIndex && t > CollapsibleMenuSection.maxCountOfVisibleItems - 2 && (this.firstFocusableIndex = 1e3 * this.index + t + 1)
452    }))
453  }
454  initialRender() {
455    this.observeComponentCreation(((e, t) => {
456      ViewStackProcessor.StartGetAccessRecordingFor(e);
457      Column.create();
458      Column.height("100%");
459      Column.justifyContent(FlexAlign.Center);
460      t || Column.pop();
461      ViewStackProcessor.StopGetAccessRecording()
462    }));
463    this.observeComponentCreation(((e, t) => {
464      ViewStackProcessor.StartGetAccessRecordingFor(e);
465      Row.create();
466      t || Row.pop();
467      ViewStackProcessor.StopGetAccessRecording()
468    }));
469    this.observeComponentCreation(((e, t) => {
470      ViewStackProcessor.StartGetAccessRecordingFor(e);
471      If.create();
472      this.menuItems.length <= CollapsibleMenuSection.maxCountOfVisibleItems ? this.ifElseBranchUpdateFunction(0, (() => {
473        this.observeComponentCreation(((e, t) => {
474          ViewStackProcessor.StartGetAccessRecordingFor(e);
475          ForEach.create();
476          this.forEachUpdateFunction(e, this.menuItems, ((e, t) => {
477            const o = e;
478            this.observeComponentCreation(((e, i) => {
479              ViewStackProcessor.StartGetAccessRecordingFor(e);
480              i ? ViewPU.create(new ImageMenuItem(this, {
481                item: o,
482                index: 1e3 * this.index + t + 1
483              }, void 0, e)) : this.updateStateVarsOfChildByElmtId(e, {});
484              ViewStackProcessor.StopGetAccessRecording()
485            }))
486          }), void 0, !0, !1);
487          t || ForEach.pop();
488          ViewStackProcessor.StopGetAccessRecording()
489        }));
490        ForEach.pop()
491      })) : this.ifElseBranchUpdateFunction(1, (() => {
492        this.observeComponentCreation(((e, t) => {
493          ViewStackProcessor.StartGetAccessRecordingFor(e);
494          ForEach.create();
495          this.forEachUpdateFunction(e, this.menuItems.slice(0, CollapsibleMenuSection.maxCountOfVisibleItems - 1), ((e, t) => {
496            const o = e;
497            this.observeComponentCreation(((e, i) => {
498              ViewStackProcessor.StartGetAccessRecordingFor(e);
499              i ? ViewPU.create(new ImageMenuItem(this, {
500                item: o,
501                index: 1e3 * this.index + t + 1
502              }, void 0, e)) : this.updateStateVarsOfChildByElmtId(e, {});
503              ViewStackProcessor.StopGetAccessRecording()
504            }))
505          }), void 0, !0, !1);
506          t || ForEach.pop();
507          ViewStackProcessor.StopGetAccessRecording()
508        }));
509        ForEach.pop();
510        this.observeComponentCreation(((e, t) => {
511          ViewStackProcessor.StartGetAccessRecordingFor(e);
512          Row.create();
513          Row.width(ImageMenuItem.imageHotZoneWidth);
514          Row.height(ImageMenuItem.imageHotZoneWidth);
515          Row.borderRadius(ImageMenuItem.buttonBorderRadius);
516          Row.foregroundColor(this.getMoreIconFgColor());
517          Row.backgroundColor(this.getMoreIconBgColor());
518          Row.justifyContent(FlexAlign.Center);
519          ViewStackProcessor.visualState("focused");
520          Row.border({
521            radius: {
522              id: -1,
523              type: 10002,
524              params: ["sys.float.ohos_id_corner_radius_clicked"],
525              bundleName: "",
526              moduleName: ""
527            },
528            width: ImageMenuItem.focusBorderWidth,
529            color: {
530              id: -1,
531              type: 10001,
532              params: ["sys.color.ohos_id_color_focused_outline"],
533              bundleName: "",
534              moduleName: ""
535            },
536            style: BorderStyle.Solid
537          });
538          ViewStackProcessor.visualState("normal");
539          Row.border({
540            radius: {
541              id: -1,
542              type: 10002,
543              params: ["sys.float.ohos_id_corner_radius_clicked"],
544              bundleName: "",
545              moduleName: ""
546            },
547            width: 0
548          });
549          ViewStackProcessor.visualState();
550          Row.onFocus((() => this.isMoreIconOnFocus = !0));
551          Row.onBlur((() => this.isMoreIconOnFocus = !1));
552          Row.onHover((e => this.isMoreIconOnHover = e));
553          Row.onKeyEvent((e => {
554            if (e.keyCode === KeyCode.KEYCODE_ENTER || e.keyCode === KeyCode.KEYCODE_SPACE) {
555              e.type === KeyType.Down && (this.isMoreIconOnClick = !0);
556              e.type === KeyType.Up && (this.isMoreIconOnClick = !1)
557            }
558          }));
559          Row.onTouch((e => {
560            e.type === TouchType.Down && (this.isMoreIconOnClick = !0);
561            e.type === TouchType.Up && (this.isMoreIconOnClick = !1)
562          }));
563          Row.onClick((() => this.isPopupShown = !0));
564          Row.bindPopup(this.isPopupShown, {
565            builder: {
566              builder: this.popupBuilder.bind(this)
567            },
568            placement: Placement.Bottom,
569            popupColor: Color.White,
570            enableArrow: !1,
571            onStateChange: e => {
572              this.isPopupShown = e.isVisible;
573              e.isVisible || (this.isMoreIconOnClick = !1)
574            }
575          });
576          t || Row.pop();
577          ViewStackProcessor.StopGetAccessRecording()
578        }));
579        this.observeComponentCreation(((e, t) => {
580          ViewStackProcessor.StartGetAccessRecordingFor(e);
581          Image.create(PUBLIC_MORE);
582          Image.width(ImageMenuItem.imageSize);
583          Image.height(ImageMenuItem.imageSize);
584          Image.focusable(!0);
585          t || Image.pop();
586          ViewStackProcessor.StopGetAccessRecording()
587        }));
588        Row.pop()
589      }));
590      t || If.pop();
591      ViewStackProcessor.StopGetAccessRecording()
592    }));
593    If.pop();
594    Row.pop();
595    Column.pop()
596  }
597  popupBuilder(e = null) {
598    this.observeComponentCreation(((e, t) => {
599      ViewStackProcessor.StartGetAccessRecordingFor(e);
600      Column.create();
601      Column.width(ImageMenuItem.imageHotZoneWidth + CollapsibleMenuSection.focusPadding * CollapsibleMenuSection.marginsNum);
602      Column.margin({
603        top: CollapsibleMenuSection.focusPadding,
604        bottom: CollapsibleMenuSection.focusPadding
605      });
606      Column.onAppear((() => {
607        focusControl.requestFocus(ImageMenuItem.focusablePrefix + this.firstFocusableIndex)
608      }));
609      t || Column.pop();
610      ViewStackProcessor.StopGetAccessRecording()
611    }));
612    this.observeComponentCreation(((e, t) => {
613      ViewStackProcessor.StartGetAccessRecordingFor(e);
614      ForEach.create();
615      this.forEachUpdateFunction(e, this.menuItems.slice(CollapsibleMenuSection.maxCountOfVisibleItems - 1, this.menuItems.length), ((e, t) => {
616        const o = e;
617        this.observeComponentCreation(((e, i) => {
618          ViewStackProcessor.StartGetAccessRecordingFor(e);
619          i ? ViewPU.create(new ImageMenuItem(this, {
620            item: o,
621            index: 1e3 * this.index + CollapsibleMenuSection.maxCountOfVisibleItems + t
622          }, void 0, e)) : this.updateStateVarsOfChildByElmtId(e, {});
623          ViewStackProcessor.StopGetAccessRecording()
624        }))
625      }), void 0, !0, !1);
626      t || ForEach.pop();
627      ViewStackProcessor.StopGetAccessRecording()
628    }));
629    ForEach.pop();
630    Column.pop()
631  }
632  rerender() {
633    this.updateDirtyElements()
634  }
635}
636CollapsibleMenuSection.maxCountOfVisibleItems = 1;
637CollapsibleMenuSection.focusPadding = 4;
638CollapsibleMenuSection.marginsNum = 2;
639__decorate([], CollapsibleMenuSection.prototype, "popupBuilder", null);
640class TabContentItem extends ViewPU {
641  constructor(e, t, o, i = -1) {
642    super(e, o, i);
643    this.item = void 0;
644    this.index = void 0;
645    this.maxIndex = void 0;
646    this.onCustomClick = void 0;
647    this.onImageComplete = void 0;
648    this.__currentIndex = new SynchedPropertySimpleOneWayPU(t.currentIndex, this, "currentIndex");
649    this.__isOnFocus = new ObservedPropertySimplePU(!1, this, "isOnFocus");
650    this.__isOnHover = new ObservedPropertySimplePU(!1, this, "isOnHover");
651    this.__isOnClick = new ObservedPropertySimplePU(!1, this, "isOnClick");
652    this.__tabWidth = new ObservedPropertySimplePU(0, this, "tabWidth");
653    this.__imageWidth = new ObservedPropertySimplePU(24, this, "imageWidth");
654    this.__imageHeight = new ObservedPropertySimplePU(24, this, "imageHeight");
655    this.setInitiallyProvidedValue(t)
656  }
657  setInitiallyProvidedValue(e) {
658    void 0 !== e.item && (this.item = e.item);
659    void 0 !== e.index && (this.index = e.index);
660    void 0 !== e.maxIndex && (this.maxIndex = e.maxIndex);
661    void 0 !== e.onCustomClick && (this.onCustomClick = e.onCustomClick);
662    void 0 !== e.onImageComplete && (this.onImageComplete = e.onImageComplete);
663    void 0 !== e.isOnFocus && (this.isOnFocus = e.isOnFocus);
664    void 0 !== e.isOnHover && (this.isOnHover = e.isOnHover);
665    void 0 !== e.isOnClick && (this.isOnClick = e.isOnClick);
666    void 0 !== e.tabWidth && (this.tabWidth = e.tabWidth);
667    void 0 !== e.imageWidth && (this.imageWidth = e.imageWidth);
668    void 0 !== e.imageHeight && (this.imageHeight = e.imageHeight)
669  }
670  updateStateVars(e) {
671    this.__currentIndex.reset(e.currentIndex)
672  }
673  purgeVariableDependenciesOnElmtId(e) {
674    this.__currentIndex.purgeDependencyOnElmtId(e);
675    this.__isOnFocus.purgeDependencyOnElmtId(e);
676    this.__isOnHover.purgeDependencyOnElmtId(e);
677    this.__isOnClick.purgeDependencyOnElmtId(e);
678    this.__tabWidth.purgeDependencyOnElmtId(e);
679    this.__imageWidth.purgeDependencyOnElmtId(e);
680    this.__imageHeight.purgeDependencyOnElmtId(e)
681  }
682  aboutToBeDeleted() {
683    this.__currentIndex.aboutToBeDeleted();
684    this.__isOnFocus.aboutToBeDeleted();
685    this.__isOnHover.aboutToBeDeleted();
686    this.__isOnClick.aboutToBeDeleted();
687    this.__tabWidth.aboutToBeDeleted();
688    this.__imageWidth.aboutToBeDeleted();
689    this.__imageHeight.aboutToBeDeleted();
690    SubscriberManager.Get().delete(this.id__());
691    this.aboutToBeDeletedInternal()
692  }
693  get currentIndex() {
694    return this.__currentIndex.get()
695  }
696  set currentIndex(e) {
697    this.__currentIndex.set(e)
698  }
699  get isOnFocus() {
700    return this.__isOnFocus.get()
701  }
702  set isOnFocus(e) {
703    this.__isOnFocus.set(e)
704  }
705  get isOnHover() {
706    return this.__isOnHover.get()
707  }
708  set isOnHover(e) {
709    this.__isOnHover.set(e)
710  }
711  get isOnClick() {
712    return this.__isOnClick.get()
713  }
714  set isOnClick(e) {
715    this.__isOnClick.set(e)
716  }
717  get tabWidth() {
718    return this.__tabWidth.get()
719  }
720  set tabWidth(e) {
721    this.__tabWidth.set(e)
722  }
723  get imageWidth() {
724    return this.__imageWidth.get()
725  }
726  set imageWidth(e) {
727    this.__imageWidth.set(e)
728  }
729  get imageHeight() {
730    return this.__imageHeight.get()
731  }
732  set imageHeight(e) {
733    this.__imageHeight.set(e)
734  }
735  getBgColor() {
736    return this.isOnClick ? {
737      id: -1,
738      type: 10001,
739      params: ["sys.color.ohos_id_color_click_effect"],
740      bundleName: "",
741      moduleName: ""
742    } : this.isOnHover ? {
743      id: -1,
744      type: 10001,
745      params: ["sys.color.ohos_id_color_hover"],
746      bundleName: "",
747      moduleName: ""
748    } : Color.Transparent
749  }
750  getBorderAttr() {
751    return this.isOnFocus ? {
752      radius: {
753        id: -1,
754        type: 10002,
755        params: ["sys.float.ohos_id_corner_radius_clicked"],
756        bundleName: "",
757        moduleName: ""
758      },
759      width: TabContentItem.focusBorderWidth,
760      color: {
761        id: -1,
762        type: 10001,
763        params: ["sys.color.ohos_id_color_focused_outline"],
764        bundleName: "",
765        moduleName: ""
766      },
767      style: BorderStyle.Solid
768    } : {
769      width: 0
770    }
771  }
772  getImageScaleFactor() {
773    return this.index === this.currentIndex ? TabContentItem.imageMagnificationFactor : 1
774  }
775  getImageLayoutWidth() {
776    return TabContentItem.imageSize / Math.max(this.imageHeight, 1) * this.imageWidth
777  }
778  initialRender() {
779    this.observeComponentCreation(((e, t) => {
780      ViewStackProcessor.StartGetAccessRecordingFor(e);
781      Stack.create();
782      Stack.margin({
783        left: 0 === this.index ? TabContentItem.marginFirst : 0,
784        right: this.index === this.maxIndex ? 12 : 0
785      });
786      t || Stack.pop();
787      ViewStackProcessor.StopGetAccessRecording()
788    }));
789    this.observeComponentCreation(((e, t) => {
790      ViewStackProcessor.StartGetAccessRecordingFor(e);
791      Row.create();
792      Row.height(TabTitleBar.totalHeight);
793      Row.alignItems(VerticalAlign.Center);
794      Row.justifyContent(FlexAlign.Center);
795      Row.borderRadius(TabContentItem.buttonBorderRadius);
796      Row.backgroundColor(this.getBgColor());
797      Row.onAreaChange(((e, t) => {
798        this.tabWidth = Number(t.width)
799      }));
800      t || Row.pop();
801      ViewStackProcessor.StopGetAccessRecording()
802    }));
803    this.observeComponentCreation(((e, t) => {
804      ViewStackProcessor.StartGetAccessRecordingFor(e);
805      Column.create();
806      Column.justifyContent(FlexAlign.Center);
807      t || Column.pop();
808      ViewStackProcessor.StopGetAccessRecording()
809    }));
810    this.observeComponentCreation(((e, t) => {
811      ViewStackProcessor.StartGetAccessRecordingFor(e);
812      If.create();
813      void 0 === this.item.icon ? this.ifElseBranchUpdateFunction(0, (() => {
814        this.observeComponentCreation(((e, t) => {
815          ViewStackProcessor.StartGetAccessRecordingFor(e);
816          Text.create(this.item.title);
817          Context.animation({
818            duration: 300
819          });
820          Text.fontSize(this.index === this.currentIndex ? {
821            id: -1,
822            type: 10002,
823            params: ["sys.float.ohos_id_text_size_headline7"],
824            bundleName: "",
825            moduleName: ""
826          } : {
827            id: -1,
828            type: 10002,
829            params: ["sys.float.ohos_id_text_size_headline9"],
830            bundleName: "",
831            moduleName: ""
832          });
833          Text.fontColor(this.index === this.currentIndex ? {
834            id: -1,
835            type: 10001,
836            params: ["sys.color.ohos_id_color_titlebar_text"],
837            bundleName: "",
838            moduleName: ""
839          } : {
840            id: -1,
841            type: 10001,
842            params: ["sys.color.ohos_id_color_titlebar_text_off"],
843            bundleName: "",
844            moduleName: ""
845          });
846          Text.fontWeight(FontWeight.Medium);
847          Text.focusable(!0);
848          Context.animation(null);
849          Text.padding({
850            top: this.index === this.currentIndex ? 6 : 10,
851            left: TabContentItem.paddingLeft,
852            bottom: 2,
853            right: TabContentItem.paddingRight
854          });
855          Text.onFocus((() => this.isOnFocus = !0));
856          Text.onBlur((() => this.isOnFocus = !1));
857          Text.onHover((e => this.isOnHover = e));
858          Text.onKeyEvent((e => {
859            if (e.keyCode === KeyCode.KEYCODE_ENTER || e.keyCode === KeyCode.KEYCODE_SPACE) {
860              e.type === KeyType.Down && (this.isOnClick = !0);
861              e.type === KeyType.Up && (this.isOnClick = !1)
862            }
863          }));
864          Text.onTouch((e => {
865            e.type === TouchType.Down && (this.isOnClick = !0);
866            e.type === TouchType.Up && (this.isOnClick = !1)
867          }));
868          Text.onClick((() => this.onCustomClick && this.onCustomClick(this.index)));
869          t || Text.pop();
870          ViewStackProcessor.StopGetAccessRecording()
871        }));
872        Text.pop()
873      })) : this.ifElseBranchUpdateFunction(1, (() => {
874        this.observeComponentCreation(((e, t) => {
875          ViewStackProcessor.StartGetAccessRecordingFor(e);
876          Row.create();
877          Context.animation({
878            duration: 300
879          });
880          Row.width(this.getImageLayoutWidth() * this.getImageScaleFactor() + TabContentItem.paddingLeft + TabContentItem.paddingRight);
881          Row.constraintSize({
882            minWidth: TabContentItem.imageHotZoneWidth,
883            minHeight: TabContentItem.imageHotZoneWidth
884          });
885          Context.animation(null);
886          Row.justifyContent(FlexAlign.Center);
887          Row.onFocus((() => this.isOnFocus = !0));
888          Row.onBlur((() => this.isOnFocus = !1));
889          Row.onHover((e => this.isOnHover = e));
890          Row.onKeyEvent((e => {
891            if (e.keyCode === KeyCode.KEYCODE_ENTER || e.keyCode === KeyCode.KEYCODE_SPACE) {
892              e.type === KeyType.Down && (this.isOnClick = !0);
893              e.type === KeyType.Up && (this.isOnClick = !1)
894            }
895          }));
896          Row.onTouch((e => {
897            e.type === TouchType.Down && (this.isOnClick = !0);
898            e.type === TouchType.Up && (this.isOnClick = !1)
899          }));
900          Row.onClick((() => this.onCustomClick && this.onCustomClick(this.index)));
901          t || Row.pop();
902          ViewStackProcessor.StopGetAccessRecording()
903        }));
904        this.observeComponentCreation(((e, t) => {
905          ViewStackProcessor.StartGetAccessRecordingFor(e);
906          Image.create(this.item.icon);
907          Context.animation({
908            duration: 300
909          });
910          Image.alt(this.item.title);
911          Image.width(this.getImageLayoutWidth());
912          Image.height(TabContentItem.imageSize);
913          Image.objectFit(ImageFit.Fill);
914          Image.scale({
915            x: this.getImageScaleFactor(),
916            y: this.getImageScaleFactor()
917          });
918          Context.animation(null);
919          Image.hitTestBehavior(HitTestMode.None);
920          Image.focusable(!0);
921          Image.onComplete((e => {
922            if (this.onImageComplete) {
923              this.imageWidth = px2vp(e.width);
924              this.imageHeight = px2vp(e.height);
925              this.onImageComplete(px2vp(e.componentWidth) + TabContentItem.paddingLeft + TabContentItem.paddingRight)
926            }
927          }));
928          Image.onError((e => {
929            this.onImageComplete && this.onImageComplete(px2vp(e.componentWidth) + TabContentItem.paddingLeft + TabContentItem.paddingRight)
930          }));
931          t || Image.pop();
932          ViewStackProcessor.StopGetAccessRecording()
933        }));
934        Row.pop()
935      }));
936      t || If.pop();
937      ViewStackProcessor.StopGetAccessRecording()
938    }));
939    If.pop();
940    Column.pop();
941    Row.pop();
942    this.observeComponentCreation(((e, t) => {
943      ViewStackProcessor.StartGetAccessRecordingFor(e);
944      If.create();
945      this.isOnFocus && this.tabWidth > 0 ? this.ifElseBranchUpdateFunction(0, (() => {
946        this.observeComponentCreation(((e, t) => {
947          ViewStackProcessor.StartGetAccessRecordingFor(e);
948          Row.create();
949          Row.width(this.tabWidth);
950          Row.height(TabTitleBar.totalHeight);
951          Row.hitTestBehavior(HitTestMode.None);
952          Row.borderRadius(TabContentItem.buttonBorderRadius);
953          ViewStackProcessor.visualState("focused");
954          Row.border(this.getBorderAttr());
955          ViewStackProcessor.visualState("normal");
956          Row.border({
957            radius: {
958              id: -1,
959              type: 10002,
960              params: ["sys.float.ohos_id_corner_radius_clicked"],
961              bundleName: "",
962              moduleName: ""
963            },
964            width: 0
965          });
966          ViewStackProcessor.visualState();
967          t || Row.pop();
968          ViewStackProcessor.StopGetAccessRecording()
969        }));
970        Row.pop()
971      })) : If.branchId(1);
972      t || If.pop();
973      ViewStackProcessor.StopGetAccessRecording()
974    }));
975    If.pop();
976    Stack.pop()
977  }
978  rerender() {
979    this.updateDirtyElements()
980  }
981}
982TabContentItem.imageSize = 24;
983TabContentItem.imageHotZoneWidth = 48;
984TabContentItem.imageMagnificationFactor = 1.4;
985TabContentItem.buttonBorderRadius = 8;
986TabContentItem.focusBorderWidth = 2;
987TabContentItem.paddingLeft = 8;
988TabContentItem.paddingRight = 8;
989TabContentItem.marginFirst = 16;
990class ImageMenuItem extends ViewPU {
991  constructor(e, t, o, i = -1) {
992    super(e, o, i);
993    this.item = void 0;
994    this.index = void 0;
995    this.__isOnFocus = new ObservedPropertySimplePU(!1, this, "isOnFocus");
996    this.__isOnHover = new ObservedPropertySimplePU(!1, this, "isOnHover");
997    this.__isOnClick = new ObservedPropertySimplePU(!1, this, "isOnClick");
998    this.setInitiallyProvidedValue(t)
999  }
1000  setInitiallyProvidedValue(e) {
1001    void 0 !== e.item && (this.item = e.item);
1002    void 0 !== e.index && (this.index = e.index);
1003    void 0 !== e.isOnFocus && (this.isOnFocus = e.isOnFocus);
1004    void 0 !== e.isOnHover && (this.isOnHover = e.isOnHover);
1005    void 0 !== e.isOnClick && (this.isOnClick = e.isOnClick)
1006  }
1007  updateStateVars(e) {}
1008  purgeVariableDependenciesOnElmtId(e) {
1009    this.__isOnFocus.purgeDependencyOnElmtId(e);
1010    this.__isOnHover.purgeDependencyOnElmtId(e);
1011    this.__isOnClick.purgeDependencyOnElmtId(e)
1012  }
1013  aboutToBeDeleted() {
1014    this.__isOnFocus.aboutToBeDeleted();
1015    this.__isOnHover.aboutToBeDeleted();
1016    this.__isOnClick.aboutToBeDeleted();
1017    SubscriberManager.Get().delete(this.id__());
1018    this.aboutToBeDeletedInternal()
1019  }
1020  get isOnFocus() {
1021    return this.__isOnFocus.get()
1022  }
1023  set isOnFocus(e) {
1024    this.__isOnFocus.set(e)
1025  }
1026  get isOnHover() {
1027    return this.__isOnHover.get()
1028  }
1029  set isOnHover(e) {
1030    this.__isOnHover.set(e)
1031  }
1032  get isOnClick() {
1033    return this.__isOnClick.get()
1034  }
1035  set isOnClick(e) {
1036    this.__isOnClick.set(e)
1037  }
1038  getFgColor() {
1039    return this.isOnClick ? {
1040      id: -1,
1041      type: 10001,
1042      params: ["sys.color.ohos_id_color_titlebar_icon_pressed"],
1043      bundleName: "",
1044      moduleName: ""
1045    } : {
1046      id: -1,
1047      type: 10001,
1048      params: ["sys.color.ohos_id_color_titlebar_icon"],
1049      bundleName: "",
1050      moduleName: ""
1051    }
1052  }
1053  getBgColor() {
1054    return this.isOnClick ? {
1055      id: -1,
1056      type: 10001,
1057      params: ["sys.color.ohos_id_color_click_effect"],
1058      bundleName: "",
1059      moduleName: ""
1060    } : this.isOnHover ? {
1061      id: -1,
1062      type: 10001,
1063      params: ["sys.color.ohos_id_color_hover"],
1064      bundleName: "",
1065      moduleName: ""
1066    } : Color.Transparent
1067  }
1068  initialRender() {
1069    this.observeComponentCreation(((e, t) => {
1070      ViewStackProcessor.StartGetAccessRecordingFor(e);
1071      Row.create();
1072      Row.width(ImageMenuItem.imageHotZoneWidth);
1073      Row.height(ImageMenuItem.imageHotZoneWidth);
1074      Row.borderRadius(ImageMenuItem.buttonBorderRadius);
1075      Row.foregroundColor(this.getFgColor());
1076      Row.backgroundColor(this.getBgColor());
1077      Row.justifyContent(FlexAlign.Center);
1078      Row.opacity(this.item.isEnabled ? 1 : ImageMenuItem.disabledImageOpacity);
1079      ViewStackProcessor.visualState("focused");
1080      Row.border({
1081        radius: {
1082          id: -1,
1083          type: 10002,
1084          params: ["sys.float.ohos_id_corner_radius_clicked"],
1085          bundleName: "",
1086          moduleName: ""
1087        },
1088        width: ImageMenuItem.focusBorderWidth,
1089        color: {
1090          id: -1,
1091          type: 10001,
1092          params: ["sys.color.ohos_id_color_focused_outline"],
1093          bundleName: "",
1094          moduleName: ""
1095        },
1096        style: BorderStyle.Solid
1097      });
1098      ViewStackProcessor.visualState("normal");
1099      Row.border({
1100        radius: {
1101          id: -1,
1102          type: 10002,
1103          params: ["sys.float.ohos_id_corner_radius_clicked"],
1104          bundleName: "",
1105          moduleName: ""
1106        },
1107        width: 0
1108      });
1109      ViewStackProcessor.visualState();
1110      Row.onFocus((() => {
1111        this.item.isEnabled && (this.isOnFocus = !0)
1112      }));
1113      Row.onBlur((() => this.isOnFocus = !1));
1114      Row.onHover((e => {
1115        this.item.isEnabled && (this.isOnHover = e)
1116      }));
1117      Row.onKeyEvent((e => {
1118        if (this.item.isEnabled && (e.keyCode === KeyCode.KEYCODE_ENTER || e.keyCode === KeyCode.KEYCODE_SPACE)) {
1119          e.type === KeyType.Down && (this.isOnClick = !0);
1120          e.type === KeyType.Up && (this.isOnClick = !1)
1121        }
1122      }));
1123      Row.onTouch((e => {
1124        if (this.item.isEnabled) {
1125          e.type === TouchType.Down && (this.isOnClick = !0);
1126          e.type === TouchType.Up && (this.isOnClick = !1)
1127        }
1128      }));
1129      Row.onClick((() => this.item.isEnabled && this.item.action && this.item.action()));
1130      t || Row.pop();
1131      ViewStackProcessor.StopGetAccessRecording()
1132    }));
1133    this.observeComponentCreation(((e, t) => {
1134      ViewStackProcessor.StartGetAccessRecordingFor(e);
1135      Image.create(this.item.value);
1136      Image.width(ImageMenuItem.imageSize);
1137      Image.height(ImageMenuItem.imageSize);
1138      Image.focusable(this.item.isEnabled);
1139      Image.key(ImageMenuItem.focusablePrefix + this.index);
1140      t || Image.pop();
1141      ViewStackProcessor.StopGetAccessRecording()
1142    }));
1143    Row.pop()
1144  }
1145  rerender() {
1146    this.updateDirtyElements()
1147  }
1148}
1149ImageMenuItem.imageSize = 24;
1150ImageMenuItem.imageHotZoneWidth = 48;
1151ImageMenuItem.buttonBorderRadius = 8;
1152ImageMenuItem.focusBorderWidth = 2;
1153ImageMenuItem.disabledImageOpacity = .4;
1154ImageMenuItem.focusablePrefix = "Id-TabTitleBar-ImageMenuItem-";
1155export default {
1156  TabTitleBar: TabTitleBar
1157};