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