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, r = arguments.length,
18    n = r < 3 ? t : null === i ? i = Object.getOwnPropertyDescriptor(t, o) : i;
19  if ("object" == typeof Reflect && "function" == typeof Reflect.decorate) n = Reflect.decorate(e, t, o, i);
20  else
21    for (var c = e.length - 1; c >= 0; c--)(s = e[c]) && (n = (r < 3 ? s(n) : r > 3 ? s(t, o, n) : s(t, o)) || n);
22  return r > 3 && n && Object.defineProperty(t, o, n), n
23};
24const KeyCode = requireNapi('multimodalInput.keyCode').KeyCode;
25const PUBLIC_MORE = "";
26const PUBLIC_BACK = "";
27export class SelectTitleBar extends ViewPU {
28  constructor(e, t, o, i = -1) {
29    super(e, o, i);
30    this.__selected = new ObservedPropertySimplePU(0, this, "selected");
31    this.options = void 0;
32    this.menuItems = void 0;
33    this.subtitle = void 0;
34    this.badgeValue = void 0;
35    this.hidesBackButton = void 0;
36    this.onSelected = void 0;
37    this.__selectMaxWidth = new ObservedPropertySimplePU(0, this, "selectMaxWidth");
38    this.setInitiallyProvidedValue(t)
39  }
40  setInitiallyProvidedValue(e) {
41    void 0 !== e.selected && (this.selected = e.selected);
42    void 0 !== e.options && (this.options = e.options);
43    void 0 !== e.menuItems && (this.menuItems = e.menuItems);
44    void 0 !== e.subtitle && (this.subtitle = e.subtitle);
45    void 0 !== e.badgeValue && (this.badgeValue = e.badgeValue);
46    void 0 !== e.hidesBackButton && (this.hidesBackButton = e.hidesBackButton);
47    void 0 !== e.onSelected && (this.onSelected = e.onSelected);
48    void 0 !== e.selectMaxWidth && (this.selectMaxWidth = e.selectMaxWidth)
49  }
50  updateStateVars(e) {}
51  purgeVariableDependenciesOnElmtId(e) {
52    this.__selected.purgeDependencyOnElmtId(e);
53    this.__selectMaxWidth.purgeDependencyOnElmtId(e)
54  }
55  aboutToBeDeleted() {
56    this.__selected.aboutToBeDeleted();
57    this.__selectMaxWidth.aboutToBeDeleted();
58    SubscriberManager.Get().delete(this.id__());
59    this.aboutToBeDeletedInternal()
60  }
61  get selected() {
62    return this.__selected.get()
63  }
64  set selected(e) {
65    this.__selected.set(e)
66  }
67  get selectMaxWidth() {
68    return this.__selectMaxWidth.get()
69  }
70  set selectMaxWidth(e) {
71    this.__selectMaxWidth.set(e)
72  }
73  initialRender() {
74    this.observeComponentCreation(((e, t) => {
75      ViewStackProcessor.StartGetAccessRecordingFor(e);
76      Flex.create({
77        justifyContent: FlexAlign.SpaceBetween,
78        alignItems: ItemAlign.Stretch
79      });
80      Flex.width("100%");
81      Flex.height(SelectTitleBar.totalHeight);
82      Flex.backgroundColor({
83        id: -1,
84        type: 10001,
85        params: ["sys.color.ohos_id_color_background"],
86        bundleName: "",
87        moduleName: ""
88      });
89      Flex.onAreaChange(((e, t) => {
90        let o = Number(t.width);
91        if (!this.hidesBackButton) {
92          o -= ImageMenuItem.imageHotZoneWidth;
93          o += SelectTitleBar.leftPadding;
94          o -= SelectTitleBar.leftPaddingWithBack
95        }
96        if (void 0 !== this.menuItems) {
97          let e = this.menuItems.length;
98          e >= CollapsibleMenuSection.maxCountOfVisibleItems ? o -= ImageMenuItem.imageHotZoneWidth * CollapsibleMenuSection.maxCountOfVisibleItems : e > 0 && (o -= ImageMenuItem.imageHotZoneWidth * e)
99        }
100        void 0 !== this.badgeValue ? this.selectMaxWidth = o - SelectTitleBar.badgeSize - SelectTitleBar.leftPadding - SelectTitleBar.rightPadding - SelectTitleBar.badgePadding : this.selectMaxWidth = o - SelectTitleBar.leftPadding - SelectTitleBar.rightPadding
101      }));
102      t || Flex.pop();
103      ViewStackProcessor.StopGetAccessRecording()
104    }));
105    this.observeComponentCreation(((e, t) => {
106      ViewStackProcessor.StartGetAccessRecordingFor(e);
107      Row.create();
108      Row.margin({
109        left: this.hidesBackButton ? {
110          id: -1,
111          type: 10002,
112          params: ["sys.float.ohos_id_max_padding_start"],
113          bundleName: "",
114          moduleName: ""
115        } : {
116          id: -1,
117          type: 10002,
118          params: ["sys.float.ohos_id_default_padding_start"],
119          bundleName: "",
120          moduleName: ""
121        }
122      });
123      t || Row.pop();
124      ViewStackProcessor.StopGetAccessRecording()
125    }));
126    this.observeComponentCreation(((e, t) => {
127      ViewStackProcessor.StartGetAccessRecordingFor(e);
128      If.create();
129      this.hidesBackButton ? If.branchId(1) : this.ifElseBranchUpdateFunction(0, (() => {
130        this.observeComponentCreation(((e, t) => {
131          ViewStackProcessor.StartGetAccessRecordingFor(e);
132          Navigator.create();
133          t || Navigator.pop();
134          ViewStackProcessor.StopGetAccessRecording()
135        }));
136        this.observeComponentCreation(((e, t) => {
137          ViewStackProcessor.StartGetAccessRecordingFor(e);
138          t ? ViewPU.create(new ImageMenuItem(this, {
139            item: {
140              value: PUBLIC_BACK,
141              isEnabled: !0
142            }
143          }, void 0, e)) : this.updateStateVarsOfChildByElmtId(e, {});
144          ViewStackProcessor.StopGetAccessRecording()
145        }));
146        Navigator.pop()
147      }));
148      t || If.pop();
149      ViewStackProcessor.StopGetAccessRecording()
150    }));
151    If.pop();
152    this.observeComponentCreation(((e, t) => {
153      ViewStackProcessor.StartGetAccessRecordingFor(e);
154      Column.create();
155      Column.justifyContent(FlexAlign.Start);
156      Column.alignItems(HorizontalAlign.Start);
157      Column.constraintSize({
158        maxWidth: this.selectMaxWidth
159      });
160      t || Column.pop();
161      ViewStackProcessor.StopGetAccessRecording()
162    }));
163    this.observeComponentCreation(((e, t) => {
164      ViewStackProcessor.StartGetAccessRecordingFor(e);
165      If.create();
166      void 0 !== this.badgeValue ? this.ifElseBranchUpdateFunction(0, (() => {
167        this.observeComponentCreation(((e, t) => {
168          ViewStackProcessor.StartGetAccessRecordingFor(e);
169          Badge.create({
170            count: this.badgeValue,
171            position: BadgePosition.Right,
172            style: {
173              badgeSize: SelectTitleBar.badgeSize,
174              badgeColor: {
175                id: -1,
176                type: 10001,
177                params: ["sys.color.ohos_id_color_emphasize"],
178                bundleName: "",
179                moduleName: ""
180              },
181              borderColor: {
182                id: -1,
183                type: 10001,
184                params: ["sys.color.ohos_id_color_emphasize"],
185                bundleName: "",
186                moduleName: ""
187              },
188              borderWidth: 0
189            }
190          });
191          t || Badge.pop();
192          ViewStackProcessor.StopGetAccessRecording()
193        }));
194        this.observeComponentCreation(((e, t) => {
195          ViewStackProcessor.StartGetAccessRecordingFor(e);
196          Row.create();
197          Row.justifyContent(FlexAlign.Start);
198          Row.margin({
199            right: {
200              id: -1,
201              type: 10002,
202              params: ["sys.float.ohos_id_elements_margin_horizontal_l"],
203              bundleName: "",
204              moduleName: ""
205            }
206          });
207          t || Row.pop();
208          ViewStackProcessor.StopGetAccessRecording()
209        }));
210        this.observeComponentCreation(((e, t) => {
211          ViewStackProcessor.StartGetAccessRecordingFor(e);
212          Select.create(this.options);
213          Select.selected(this.selected);
214          Select.value(this.selected < this.options.length ? this.options[this.selected].value.toString() : "");
215          Select.font({
216            size: this.hidesBackButton && void 0 === this.subtitle ? {
217              id: -1,
218              type: 10002,
219              params: ["sys.float.ohos_id_text_size_headline7"],
220              bundleName: "",
221              moduleName: ""
222            } : {
223              id: -1,
224              type: 10002,
225              params: ["sys.float.ohos_id_text_size_headline8"],
226              bundleName: "",
227              moduleName: ""
228            }
229          });
230          Select.fontColor({
231            id: -1,
232            type: 10001,
233            params: ["sys.color.ohos_id_color_titlebar_text"],
234            bundleName: "",
235            moduleName: ""
236          });
237          Select.backgroundColor(Color.Transparent);
238          Select.onSelect(this.onSelected);
239          Select.constraintSize({
240            maxWidth: this.selectMaxWidth
241          });
242          Select.offset({
243            x: -4
244          });
245          t || Select.pop();
246          ViewStackProcessor.StopGetAccessRecording()
247        }));
248        Select.pop();
249        Row.pop();
250        Badge.pop()
251      })) : this.ifElseBranchUpdateFunction(1, (() => {
252        this.observeComponentCreation(((e, t) => {
253          ViewStackProcessor.StartGetAccessRecordingFor(e);
254          Row.create();
255          Row.justifyContent(FlexAlign.Start);
256          t || Row.pop();
257          ViewStackProcessor.StopGetAccessRecording()
258        }));
259        this.observeComponentCreation(((e, t) => {
260          ViewStackProcessor.StartGetAccessRecordingFor(e);
261          Select.create(this.options);
262          Select.selected(this.selected);
263          Select.value(this.selected < this.options.length ? this.options[this.selected].value.toString() : "");
264          Select.font({
265            size: this.hidesBackButton && void 0 === this.subtitle ? {
266              id: -1,
267              type: 10002,
268              params: ["sys.float.ohos_id_text_size_headline7"],
269              bundleName: "",
270              moduleName: ""
271            } : {
272              id: -1,
273              type: 10002,
274              params: ["sys.float.ohos_id_text_size_headline8"],
275              bundleName: "",
276              moduleName: ""
277            }
278          });
279          Select.fontColor({
280            id: -1,
281            type: 10001,
282            params: ["sys.color.ohos_id_color_titlebar_text"],
283            bundleName: "",
284            moduleName: ""
285          });
286          Select.backgroundColor(Color.Transparent);
287          Select.onSelect(this.onSelected);
288          Select.constraintSize({
289            maxWidth: this.selectMaxWidth
290          });
291          Select.offset({
292            x: -4
293          });
294          t || Select.pop();
295          ViewStackProcessor.StopGetAccessRecording()
296        }));
297        Select.pop();
298        Row.pop()
299      }));
300      t || If.pop();
301      ViewStackProcessor.StopGetAccessRecording()
302    }));
303    If.pop();
304    this.observeComponentCreation(((e, t) => {
305      ViewStackProcessor.StartGetAccessRecordingFor(e);
306      If.create();
307      void 0 !== this.subtitle ? this.ifElseBranchUpdateFunction(0, (() => {
308        this.observeComponentCreation(((e, t) => {
309          ViewStackProcessor.StartGetAccessRecordingFor(e);
310          Row.create();
311          Row.justifyContent(FlexAlign.Start);
312          Row.margin({
313            left: SelectTitleBar.subtitleLeftPadding
314          });
315          t || Row.pop();
316          ViewStackProcessor.StopGetAccessRecording()
317        }));
318        this.observeComponentCreation(((e, t) => {
319          ViewStackProcessor.StartGetAccessRecordingFor(e);
320          Text.create(this.subtitle);
321          Text.fontSize({
322            id: -1,
323            type: 10002,
324            params: ["sys.float.ohos_id_text_size_over_line"],
325            bundleName: "",
326            moduleName: ""
327          });
328          Text.fontColor({
329            id: -1,
330            type: 10001,
331            params: ["sys.color.ohos_id_color_titlebar_subtitle_text"],
332            bundleName: "",
333            moduleName: ""
334          });
335          Text.maxLines(1);
336          Text.textOverflow({
337            overflow: TextOverflow.Ellipsis
338          });
339          Text.constraintSize({
340            maxWidth: this.selectMaxWidth
341          });
342          Text.offset({
343            y: -4
344          });
345          t || Text.pop();
346          ViewStackProcessor.StopGetAccessRecording()
347        }));
348        Text.pop();
349        Row.pop()
350      })) : If.branchId(1);
351      t || If.pop();
352      ViewStackProcessor.StopGetAccessRecording()
353    }));
354    If.pop();
355    Column.pop();
356    Row.pop();
357    this.observeComponentCreation(((e, t) => {
358      ViewStackProcessor.StartGetAccessRecordingFor(e);
359      If.create();
360      void 0 !== this.menuItems && this.menuItems.length > 0 ? this.ifElseBranchUpdateFunction(0, (() => {
361        this.observeComponentCreation(((e, t) => {
362          ViewStackProcessor.StartGetAccessRecordingFor(e);
363          t ? ViewPU.create(new CollapsibleMenuSection(this, {
364            menuItems: this.menuItems
365          }, void 0, e)) : this.updateStateVarsOfChildByElmtId(e, {});
366          ViewStackProcessor.StopGetAccessRecording()
367        }))
368      })) : If.branchId(1);
369      t || If.pop();
370      ViewStackProcessor.StopGetAccessRecording()
371    }));
372    If.pop();
373    Flex.pop()
374  }
375  rerender() {
376    this.updateDirtyElements()
377  }
378}
379SelectTitleBar.badgeSize = 16;
380SelectTitleBar.totalHeight = 56;
381SelectTitleBar.leftPadding = 24;
382SelectTitleBar.leftPaddingWithBack = 12;
383SelectTitleBar.rightPadding = 24;
384SelectTitleBar.badgePadding = 16;
385SelectTitleBar.subtitleLeftPadding = 4;
386class CollapsibleMenuSection extends ViewPU {
387  constructor(e, t, o, i = -1) {
388    super(e, o, i);
389    this.menuItems = void 0;
390    this.__isPopupShown = new ObservedPropertySimplePU(!1, this, "isPopupShown");
391    this.__isMoreIconOnFocus = new ObservedPropertySimplePU(!1, this, "isMoreIconOnFocus");
392    this.__isMoreIconOnHover = new ObservedPropertySimplePU(!1, this, "isMoreIconOnHover");
393    this.__isMoreIconOnClick = new ObservedPropertySimplePU(!1, this, "isMoreIconOnClick");
394    this.setInitiallyProvidedValue(t)
395  }
396  setInitiallyProvidedValue(e) {
397    void 0 !== e.menuItems && (this.menuItems = e.menuItems);
398    void 0 !== e.isPopupShown && (this.isPopupShown = e.isPopupShown);
399    void 0 !== e.isMoreIconOnFocus && (this.isMoreIconOnFocus = e.isMoreIconOnFocus);
400    void 0 !== e.isMoreIconOnHover && (this.isMoreIconOnHover = e.isMoreIconOnHover);
401    void 0 !== e.isMoreIconOnClick && (this.isMoreIconOnClick = e.isMoreIconOnClick)
402  }
403  updateStateVars(e) {}
404  purgeVariableDependenciesOnElmtId(e) {
405    this.__isPopupShown.purgeDependencyOnElmtId(e);
406    this.__isMoreIconOnFocus.purgeDependencyOnElmtId(e);
407    this.__isMoreIconOnHover.purgeDependencyOnElmtId(e);
408    this.__isMoreIconOnClick.purgeDependencyOnElmtId(e)
409  }
410  aboutToBeDeleted() {
411    this.__isPopupShown.aboutToBeDeleted();
412    this.__isMoreIconOnFocus.aboutToBeDeleted();
413    this.__isMoreIconOnHover.aboutToBeDeleted();
414    this.__isMoreIconOnClick.aboutToBeDeleted();
415    SubscriberManager.Get().delete(this.id__());
416    this.aboutToBeDeletedInternal()
417  }
418  get isPopupShown() {
419    return this.__isPopupShown.get()
420  }
421  set isPopupShown(e) {
422    this.__isPopupShown.set(e)
423  }
424  get isMoreIconOnFocus() {
425    return this.__isMoreIconOnFocus.get()
426  }
427  set isMoreIconOnFocus(e) {
428    this.__isMoreIconOnFocus.set(e)
429  }
430  get isMoreIconOnHover() {
431    return this.__isMoreIconOnHover.get()
432  }
433  set isMoreIconOnHover(e) {
434    this.__isMoreIconOnHover.set(e)
435  }
436  get isMoreIconOnClick() {
437    return this.__isMoreIconOnClick.get()
438  }
439  set isMoreIconOnClick(e) {
440    this.__isMoreIconOnClick.set(e)
441  }
442  getMoreIconFgColor() {
443    return this.isMoreIconOnClick ? {
444      id: -1,
445      type: 10001,
446      params: ["sys.color.ohos_id_color_titlebar_icon_pressed"],
447      bundleName: "",
448      moduleName: ""
449    } : {
450      id: -1,
451      type: 10001,
452      params: ["sys.color.ohos_id_color_titlebar_icon"],
453      bundleName: "",
454      moduleName: ""
455    }
456  }
457  getMoreIconBgColor() {
458    return this.isMoreIconOnClick ? {
459      id: -1,
460      type: 10001,
461      params: ["sys.color.ohos_id_color_click_effect"],
462      bundleName: "",
463      moduleName: ""
464    } : this.isMoreIconOnHover ? {
465      id: -1,
466      type: 10001,
467      params: ["sys.color.ohos_id_color_hover"],
468      bundleName: "",
469      moduleName: ""
470    } : Color.Transparent
471  }
472  initialRender() {
473    this.observeComponentCreation(((e, t) => {
474      ViewStackProcessor.StartGetAccessRecordingFor(e);
475      Column.create();
476      Column.height("100%");
477      Column.margin({
478        right: {
479          id: -1,
480          type: 10002,
481          params: ["sys.float.ohos_id_default_padding_end"],
482          bundleName: "",
483          moduleName: ""
484        }
485      });
486      Column.justifyContent(FlexAlign.Center);
487      t || Column.pop();
488      ViewStackProcessor.StopGetAccessRecording()
489    }));
490    this.observeComponentCreation(((e, t) => {
491      ViewStackProcessor.StartGetAccessRecordingFor(e);
492      Row.create();
493      t || Row.pop();
494      ViewStackProcessor.StopGetAccessRecording()
495    }));
496    this.observeComponentCreation(((e, t) => {
497      ViewStackProcessor.StartGetAccessRecordingFor(e);
498      If.create();
499      this.menuItems.length <= CollapsibleMenuSection.maxCountOfVisibleItems ? this.ifElseBranchUpdateFunction(0, (() => {
500        this.observeComponentCreation(((e, t) => {
501          ViewStackProcessor.StartGetAccessRecordingFor(e);
502          ForEach.create();
503          this.forEachUpdateFunction(e, this.menuItems, (e => {
504            const t = e;
505            this.observeComponentCreation(((e, o) => {
506              ViewStackProcessor.StartGetAccessRecordingFor(e);
507              o ? ViewPU.create(new ImageMenuItem(this, {
508                item: t
509              }, void 0, e)) : this.updateStateVarsOfChildByElmtId(e, {});
510              ViewStackProcessor.StopGetAccessRecording()
511            }))
512          }));
513          t || ForEach.pop();
514          ViewStackProcessor.StopGetAccessRecording()
515        }));
516        ForEach.pop()
517      })) : this.ifElseBranchUpdateFunction(1, (() => {
518        this.observeComponentCreation(((e, t) => {
519          ViewStackProcessor.StartGetAccessRecordingFor(e);
520          ForEach.create();
521          this.forEachUpdateFunction(e, this.menuItems.slice(0, CollapsibleMenuSection.maxCountOfVisibleItems - 1), (e => {
522            const t = e;
523            this.observeComponentCreation(((e, o) => {
524              ViewStackProcessor.StartGetAccessRecordingFor(e);
525              o ? ViewPU.create(new ImageMenuItem(this, {
526                item: t
527              }, void 0, e)) : this.updateStateVarsOfChildByElmtId(e, {});
528              ViewStackProcessor.StopGetAccessRecording()
529            }))
530          }));
531          t || ForEach.pop();
532          ViewStackProcessor.StopGetAccessRecording()
533        }));
534        ForEach.pop();
535        this.observeComponentCreation(((e, t) => {
536          ViewStackProcessor.StartGetAccessRecordingFor(e);
537          Row.create();
538          Row.width(ImageMenuItem.imageHotZoneWidth);
539          Row.height(ImageMenuItem.imageHotZoneWidth);
540          Row.borderRadius(ImageMenuItem.buttonBorderRadius);
541          Row.foregroundColor(this.getMoreIconFgColor());
542          Row.backgroundColor(this.getMoreIconBgColor());
543          Row.justifyContent(FlexAlign.Center);
544          Row.border(this.isMoreIconOnFocus ? {
545            width: ImageMenuItem.focusBorderWidth,
546            color: {
547              id: -1,
548              type: 10001,
549              params: ["sys.color.ohos_id_color_emphasize"],
550              bundleName: "",
551              moduleName: ""
552            },
553            style: BorderStyle.Solid
554          } : {
555            width: 0
556          });
557          Row.onFocus((() => this.isMoreIconOnFocus = !0));
558          Row.onBlur((() => this.isMoreIconOnFocus = !1));
559          Row.onHover((e => this.isMoreIconOnHover = e));
560          Row.onKeyEvent((e => {
561            if (e.keyCode === KeyCode.KEYCODE_ENTER || e.keyCode === KeyCode.KEYCODE_SPACE) {
562              e.type === KeyType.Down && (this.isMoreIconOnClick = !0);
563              e.type === KeyType.Up && (this.isMoreIconOnClick = !1)
564            }
565          }));
566          Row.onTouch((e => {
567            e.type === TouchType.Down && (this.isMoreIconOnClick = !0);
568            e.type === TouchType.Up && (this.isMoreIconOnClick = !1)
569          }));
570          Row.onClick((() => this.isPopupShown = !0));
571          Row.bindPopup(this.isPopupShown, {
572            builder: {
573              builder: this.popupBuilder.bind(this)
574            },
575            placement: Placement.Bottom,
576            popupColor: Color.White,
577            enableArrow: !1,
578            onStateChange: e => this.isPopupShown = e.isVisible
579          });
580          t || Row.pop();
581          ViewStackProcessor.StopGetAccessRecording()
582        }));
583        this.observeComponentCreation(((e, t) => {
584          ViewStackProcessor.StartGetAccessRecordingFor(e);
585          Image.create(PUBLIC_MORE);
586          Image.width(ImageMenuItem.imageSize);
587          Image.height(ImageMenuItem.imageSize);
588          Image.focusable(!0);
589          t || Image.pop();
590          ViewStackProcessor.StopGetAccessRecording()
591        }));
592        Row.pop()
593      }));
594      t || If.pop();
595      ViewStackProcessor.StopGetAccessRecording()
596    }));
597    If.pop();
598    Row.pop();
599    Column.pop()
600  }
601  popupBuilder(e = null) {
602    this.observeComponentCreation(((e, t) => {
603      ViewStackProcessor.StartGetAccessRecordingFor(e);
604      Column.create();
605      Column.width(ImageMenuItem.imageHotZoneWidth + CollapsibleMenuSection.focusPadding * CollapsibleMenuSection.marginsNum);
606      Column.margin({
607        top: CollapsibleMenuSection.focusPadding,
608        bottom: CollapsibleMenuSection.focusPadding
609      });
610      t || Column.pop();
611      ViewStackProcessor.StopGetAccessRecording()
612    }));
613    this.observeComponentCreation(((e, t) => {
614      ViewStackProcessor.StartGetAccessRecordingFor(e);
615      ForEach.create();
616      this.forEachUpdateFunction(e, this.menuItems.slice(CollapsibleMenuSection.maxCountOfVisibleItems - 1, this.menuItems.length), ((e, t) => {
617        const o = e;
618        this.observeComponentCreation(((e, t) => {
619          ViewStackProcessor.StartGetAccessRecordingFor(e);
620          t ? ViewPU.create(new ImageMenuItem(this, {
621            item: o
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 = 3;
637CollapsibleMenuSection.focusPadding = 4;
638CollapsibleMenuSection.marginsNum = 2;
639__decorate([], CollapsibleMenuSection.prototype, "popupBuilder", null);
640class ImageMenuItem extends ViewPU {
641  constructor(e, t, o, i = -1) {
642    super(e, o, i);
643    this.item = void 0;
644    this.__isOnFocus = new ObservedPropertySimplePU(!1, this, "isOnFocus");
645    this.__isOnHover = new ObservedPropertySimplePU(!1, this, "isOnHover");
646    this.__isOnClick = new ObservedPropertySimplePU(!1, this, "isOnClick");
647    this.setInitiallyProvidedValue(t)
648  }
649  setInitiallyProvidedValue(e) {
650    void 0 !== e.item && (this.item = e.item);
651    void 0 !== e.isOnFocus && (this.isOnFocus = e.isOnFocus);
652    void 0 !== e.isOnHover && (this.isOnHover = e.isOnHover);
653    void 0 !== e.isOnClick && (this.isOnClick = e.isOnClick)
654  }
655  updateStateVars(e) {}
656  purgeVariableDependenciesOnElmtId(e) {
657    this.__isOnFocus.purgeDependencyOnElmtId(e);
658    this.__isOnHover.purgeDependencyOnElmtId(e);
659    this.__isOnClick.purgeDependencyOnElmtId(e)
660  }
661  aboutToBeDeleted() {
662    this.__isOnFocus.aboutToBeDeleted();
663    this.__isOnHover.aboutToBeDeleted();
664    this.__isOnClick.aboutToBeDeleted();
665    SubscriberManager.Get().delete(this.id__());
666    this.aboutToBeDeletedInternal()
667  }
668  get isOnFocus() {
669    return this.__isOnFocus.get()
670  }
671  set isOnFocus(e) {
672    this.__isOnFocus.set(e)
673  }
674  get isOnHover() {
675    return this.__isOnHover.get()
676  }
677  set isOnHover(e) {
678    this.__isOnHover.set(e)
679  }
680  get isOnClick() {
681    return this.__isOnClick.get()
682  }
683  set isOnClick(e) {
684    this.__isOnClick.set(e)
685  }
686  getFgColor() {
687    return this.isOnClick ? {
688      id: -1,
689      type: 10001,
690      params: ["sys.color.ohos_id_color_titlebar_icon_pressed"],
691      bundleName: "",
692      moduleName: ""
693    } : {
694      id: -1,
695      type: 10001,
696      params: ["sys.color.ohos_id_color_titlebar_icon"],
697      bundleName: "",
698      moduleName: ""
699    }
700  }
701  getBgColor() {
702    return this.isOnClick ? {
703      id: -1,
704      type: 10001,
705      params: ["sys.color.ohos_id_color_click_effect"],
706      bundleName: "",
707      moduleName: ""
708    } : this.isOnHover ? {
709      id: -1,
710      type: 10001,
711      params: ["sys.color.ohos_id_color_hover"],
712      bundleName: "",
713      moduleName: ""
714    } : Color.Transparent
715  }
716  initialRender() {
717    this.observeComponentCreation(((e, t) => {
718      ViewStackProcessor.StartGetAccessRecordingFor(e);
719      Row.create();
720      Row.width(ImageMenuItem.imageHotZoneWidth);
721      Row.height(ImageMenuItem.imageHotZoneWidth);
722      Row.borderRadius(ImageMenuItem.buttonBorderRadius);
723      Row.foregroundColor(this.getFgColor());
724      Row.backgroundColor(this.getBgColor());
725      Row.justifyContent(FlexAlign.Center);
726      Row.opacity(this.item.isEnabled ? 1 : ImageMenuItem.disabledImageOpacity);
727      Row.border(this.isOnFocus ? {
728        width: ImageMenuItem.focusBorderWidth,
729        color: {
730          id: -1,
731          type: 10001,
732          params: ["sys.color.ohos_id_color_emphasize"],
733          bundleName: "",
734          moduleName: ""
735        },
736        style: BorderStyle.Solid
737      } : {
738        width: 0
739      });
740      Row.onFocus((() => {
741        this.item.isEnabled && (this.isOnFocus = !0)
742      }));
743      Row.onBlur((() => this.isOnFocus = !1));
744      Row.onHover((e => {
745        this.item.isEnabled && (this.isOnHover = e)
746      }));
747      Row.onKeyEvent((e => {
748        if (this.item.isEnabled && (e.keyCode === KeyCode.KEYCODE_ENTER || e.keyCode === KeyCode.KEYCODE_SPACE)) {
749          e.type === KeyType.Down && (this.isOnClick = !0);
750          e.type === KeyType.Up && (this.isOnClick = !1)
751        }
752      }));
753      Row.onTouch((e => {
754        if (this.item.isEnabled) {
755          e.type === TouchType.Down && (this.isOnClick = !0);
756          e.type === TouchType.Up && (this.isOnClick = !1)
757        }
758      }));
759      Row.onClick((() => this.item.isEnabled && this.item.action && this.item.action()));
760      t || Row.pop();
761      ViewStackProcessor.StopGetAccessRecording()
762    }));
763    this.observeComponentCreation(((e, t) => {
764      ViewStackProcessor.StartGetAccessRecordingFor(e);
765      Image.create(this.item.value);
766      Image.width(ImageMenuItem.imageSize);
767      Image.height(ImageMenuItem.imageSize);
768      Image.focusable(this.item.isEnabled);
769      t || Image.pop();
770      ViewStackProcessor.StopGetAccessRecording()
771    }));
772    Row.pop()
773  }
774  rerender() {
775    this.updateDirtyElements()
776  }
777}
778ImageMenuItem.imageSize = 24;
779ImageMenuItem.imageHotZoneWidth = 48;
780ImageMenuItem.buttonBorderRadius = 8;
781ImageMenuItem.focusBorderWidth = 2;
782ImageMenuItem.disabledImageOpacity = .4;
783export default {
784  SelectTitleBar: SelectTitleBar
785};