/* * Copyright (c) 2023-2023 Huawei Device Co., Ltd. * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ var __decorate = this && this.__decorate || function(e, t, o, i) { var s, r = arguments.length, n = r < 3 ? t : null === i ? i = Object.getOwnPropertyDescriptor(t, o) : i; if ("object" == typeof Reflect && "function" == typeof Reflect.decorate) n = Reflect.decorate(e, t, o, i); else 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); return r > 3 && n && Object.defineProperty(t, o, n), n }; const KeyCode = requireNapi('multimodalInput.keyCode').KeyCode; const PUBLIC_MORE = ""; export class TabTitleBar extends ViewPU { constructor(e, t, o, i = -1) { super(e, o, i); this.tabItems = void 0; this.menuItems = void 0; this.swiperContent = void 0; this.__tabWidth = new ObservedPropertySimplePU(0, this, "tabWidth"); this.__currentIndex = new ObservedPropertySimplePU(0, this, "currentIndex"); this.menuSectionWidth = 0; this.scroller = new Scroller; this.swiperController = new SwiperController; this.settings = new RenderingContextSettings(!0); this.leftContext2D = new CanvasRenderingContext2D(this.settings); this.rightContext2D = new CanvasRenderingContext2D(this.settings); this.setInitiallyProvidedValue(t) } setInitiallyProvidedValue(e) { void 0 !== e.tabItems && (this.tabItems = e.tabItems); void 0 !== e.menuItems && (this.menuItems = e.menuItems); void 0 !== e.swiperContent && (this.swiperContent = e.swiperContent); void 0 !== e.tabWidth && (this.tabWidth = e.tabWidth); void 0 !== e.currentIndex && (this.currentIndex = e.currentIndex); void 0 !== e.menuSectionWidth && (this.menuSectionWidth = e.menuSectionWidth); void 0 !== e.scroller && (this.scroller = e.scroller); void 0 !== e.swiperController && (this.swiperController = e.swiperController); void 0 !== e.settings && (this.settings = e.settings); void 0 !== e.leftContext2D && (this.leftContext2D = e.leftContext2D); void 0 !== e.rightContext2D && (this.rightContext2D = e.rightContext2D) } updateStateVars(e) {} purgeVariableDependenciesOnElmtId(e) { this.__tabWidth.purgeDependencyOnElmtId(e); this.__currentIndex.purgeDependencyOnElmtId(e) } aboutToBeDeleted() { this.__tabWidth.aboutToBeDeleted(); this.__currentIndex.aboutToBeDeleted(); SubscriberManager.Get().delete(this.id__()); this.aboutToBeDeletedInternal() } get tabWidth() { return this.__tabWidth.get() } set tabWidth(e) { this.__tabWidth.set(e) } get currentIndex() { return this.__currentIndex.get() } set currentIndex(e) { this.__currentIndex.set(e) } GradientMask(e, t, o, i, s, r = null) { this.observeComponentCreation(((e, t) => { ViewStackProcessor.StartGetAccessRecordingFor(e); Column.create(); Column.width(TabTitleBar.gradientMaskWidth); Column.height(TabTitleBar.totalHeight); t || Column.pop(); ViewStackProcessor.StopGetAccessRecording() })); this.observeComponentCreation(((r, n) => { ViewStackProcessor.StartGetAccessRecordingFor(r); Canvas.create(e); Canvas.width(TabTitleBar.gradientMaskWidth); Canvas.height(TabTitleBar.totalHeight); Canvas.onReady((() => { var r = e.createLinearGradient(t, o, i, s); r.addColorStop(0, "#ffffffff"); r.addColorStop(1, "#00ffffff"); e.fillStyle = r; e.fillRect(0, 0, TabTitleBar.gradientMaskWidth, TabTitleBar.totalHeight) })); n || Canvas.pop(); ViewStackProcessor.StopGetAccessRecording() })); Canvas.pop(); Column.pop() } initialRender() { this.observeComponentCreation(((e, t) => { ViewStackProcessor.StartGetAccessRecordingFor(e); Column.create(); t || Column.pop(); ViewStackProcessor.StopGetAccessRecording() })); this.observeComponentCreation(((e, t) => { ViewStackProcessor.StartGetAccessRecordingFor(e); Flex.create({ justifyContent: FlexAlign.SpaceBetween, alignItems: ItemAlign.Stretch }); Flex.backgroundColor({ id: -1, type: 10001, params: ["sys.color.ohos_id_color_background"], bundleName: "", moduleName: "" }); Flex.margin({ right: { id: -1, type: 10002, params: ["sys.float.ohos_id_max_padding_end"], bundleName: "", moduleName: "" } }); Flex.onAreaChange(((e, t) => { this.tabWidth = Number(t.width) - this.menuSectionWidth })); t || Flex.pop(); ViewStackProcessor.StopGetAccessRecording() })); this.observeComponentCreation(((e, t) => { ViewStackProcessor.StartGetAccessRecordingFor(e); Stack.create({ alignContent: Alignment.End }); t || Stack.pop(); ViewStackProcessor.StopGetAccessRecording() })); this.observeComponentCreation(((e, t) => { ViewStackProcessor.StartGetAccessRecordingFor(e); Stack.create({ alignContent: Alignment.Start }); t || Stack.pop(); ViewStackProcessor.StopGetAccessRecording() })); this.observeComponentCreation(((e, t) => { ViewStackProcessor.StartGetAccessRecordingFor(e); Column.create(); t || Column.pop(); ViewStackProcessor.StopGetAccessRecording() })); this.observeComponentCreation(((e, t) => { ViewStackProcessor.StartGetAccessRecordingFor(e); List.create({ initialIndex: 0, scroller: this.scroller, space: 0 }); List.width("100%"); List.height(TabTitleBar.totalHeight); List.constraintSize({ maxWidth: this.tabWidth }); List.edgeEffect(EdgeEffect.Spring); List.listDirection(Axis.Horizontal); List.scrollBar(BarState.Off); t || List.pop(); ViewStackProcessor.StopGetAccessRecording() })); this.observeComponentCreation(((e, t) => { ViewStackProcessor.StartGetAccessRecordingFor(e); ForEach.create(); this.forEachUpdateFunction(e, this.tabItems, ((e, t) => { const o = e; { const e = !0; const i = (t, o) => { ViewStackProcessor.StartGetAccessRecordingFor(t); ListItem.create(r, e); o || ListItem.pop(); ViewStackProcessor.StopGetAccessRecording() }; const s = () => { this.observeComponentCreation(i); this.observeComponentCreation(((e, i) => { ViewStackProcessor.StartGetAccessRecordingFor(e); i ? ViewPU.create(new TabContentItem(this, { item: o, index: t, maxIndex: this.tabItems.length - 1, currentIndex: this.currentIndex, onCustomClick: () => this.currentIndex = t }, void 0, e)) : this.updateStateVarsOfChildByElmtId(e, { currentIndex: this.currentIndex }); ViewStackProcessor.StopGetAccessRecording() })); ListItem.pop() }; const r = (e, s) => { i(e, s); this.updateFuncByElmtId.set(e, i); this.observeComponentCreation(((e, i) => { ViewStackProcessor.StartGetAccessRecordingFor(e); i ? ViewPU.create(new TabContentItem(this, { item: o, index: t, maxIndex: this.tabItems.length - 1, currentIndex: this.currentIndex, onCustomClick: () => this.currentIndex = t }, void 0, e)) : this.updateStateVarsOfChildByElmtId(e, { currentIndex: this.currentIndex }); ViewStackProcessor.StopGetAccessRecording() })); ListItem.pop() }; e ? (() => { this.observeComponentCreation(i); ListItem.pop() })() : s() } }), void 0, !0, !1); t || ForEach.pop(); ViewStackProcessor.StopGetAccessRecording() })); ForEach.pop(); List.pop(); Column.pop(); this.GradientMask.bind(this)(this.leftContext2D, 0, TabTitleBar.totalHeight / 2, TabTitleBar.gradientMaskWidth, TabTitleBar.totalHeight / 2); Stack.pop(); this.GradientMask.bind(this)(this.rightContext2D, TabTitleBar.gradientMaskWidth, TabTitleBar.totalHeight / 2, 0, TabTitleBar.totalHeight / 2); Stack.pop(); this.observeComponentCreation(((e, t) => { ViewStackProcessor.StartGetAccessRecordingFor(e); If.create(); void 0 !== this.menuItems && this.menuItems.length > 0 ? this.ifElseBranchUpdateFunction(0, (() => { this.observeComponentCreation(((e, t) => { ViewStackProcessor.StartGetAccessRecordingFor(e); __Common__.create(); __Common__.height(TabTitleBar.totalHeight); __Common__.onAreaChange(((e, t) => { this.menuSectionWidth = Number(t.width) })); t || __Common__.pop(); ViewStackProcessor.StopGetAccessRecording() })); this.observeComponentCreation(((e, t) => { ViewStackProcessor.StartGetAccessRecordingFor(e); t ? ViewPU.create(new CollapsibleMenuSection(this, { menuItems: this.menuItems }, void 0, e)) : this.updateStateVarsOfChildByElmtId(e, {}); ViewStackProcessor.StopGetAccessRecording() })); __Common__.pop() })) : If.branchId(1); t || If.pop(); ViewStackProcessor.StopGetAccessRecording() })); If.pop(); Flex.pop(); this.observeComponentCreation(((e, t) => { ViewStackProcessor.StartGetAccessRecordingFor(e); Column.create(); t || Column.pop(); ViewStackProcessor.StopGetAccessRecording() })); this.observeComponentCreation(((e, t) => { ViewStackProcessor.StartGetAccessRecordingFor(e); Swiper.create(this.swiperController); Swiper.index(this.currentIndex); Swiper.itemSpace(0); Swiper.indicator(!1); Swiper.width("100%"); Swiper.height("100%"); Swiper.curve(Curve.Friction); Swiper.onChange((e => { this.currentIndex = e; this.scroller.scrollToIndex(this.currentIndex); this.scroller.scrollBy(TabTitleBar.correctionOffset, 0) })); Swiper.onAppear((() => { this.scroller.scrollToIndex(this.currentIndex); this.scroller.scrollBy(TabTitleBar.correctionOffset, 0) })); t || Swiper.pop(); ViewStackProcessor.StopGetAccessRecording() })); this.swiperContent.bind(this)(); Swiper.pop(); Column.pop(); Column.pop() } rerender() { this.updateDirtyElements() } } TabTitleBar.totalHeight = 56; TabTitleBar.correctionOffset = -40; TabTitleBar.gradientMaskWidth = 24; __decorate([], TabTitleBar.prototype, "GradientMask", null); class CollapsibleMenuSection extends ViewPU { constructor(e, t, o, i = -1) { super(e, o, i); this.menuItems = void 0; this.__isPopupShown = new ObservedPropertySimplePU(!1, this, "isPopupShown"); this.__isMoreIconOnFocus = new ObservedPropertySimplePU(!1, this, "isMoreIconOnFocus"); this.__isMoreIconOnHover = new ObservedPropertySimplePU(!1, this, "isMoreIconOnHover"); this.__isMoreIconOnClick = new ObservedPropertySimplePU(!1, this, "isMoreIconOnClick"); this.setInitiallyProvidedValue(t) } setInitiallyProvidedValue(e) { void 0 !== e.menuItems && (this.menuItems = e.menuItems); void 0 !== e.isPopupShown && (this.isPopupShown = e.isPopupShown); void 0 !== e.isMoreIconOnFocus && (this.isMoreIconOnFocus = e.isMoreIconOnFocus); void 0 !== e.isMoreIconOnHover && (this.isMoreIconOnHover = e.isMoreIconOnHover); void 0 !== e.isMoreIconOnClick && (this.isMoreIconOnClick = e.isMoreIconOnClick) } updateStateVars(e) {} purgeVariableDependenciesOnElmtId(e) { this.__isPopupShown.purgeDependencyOnElmtId(e); this.__isMoreIconOnFocus.purgeDependencyOnElmtId(e); this.__isMoreIconOnHover.purgeDependencyOnElmtId(e); this.__isMoreIconOnClick.purgeDependencyOnElmtId(e) } aboutToBeDeleted() { this.__isPopupShown.aboutToBeDeleted(); this.__isMoreIconOnFocus.aboutToBeDeleted(); this.__isMoreIconOnHover.aboutToBeDeleted(); this.__isMoreIconOnClick.aboutToBeDeleted(); SubscriberManager.Get().delete(this.id__()); this.aboutToBeDeletedInternal() } get isPopupShown() { return this.__isPopupShown.get() } set isPopupShown(e) { this.__isPopupShown.set(e) } get isMoreIconOnFocus() { return this.__isMoreIconOnFocus.get() } set isMoreIconOnFocus(e) { this.__isMoreIconOnFocus.set(e) } get isMoreIconOnHover() { return this.__isMoreIconOnHover.get() } set isMoreIconOnHover(e) { this.__isMoreIconOnHover.set(e) } get isMoreIconOnClick() { return this.__isMoreIconOnClick.get() } set isMoreIconOnClick(e) { this.__isMoreIconOnClick.set(e) } getMoreIconFgColor() { return this.isMoreIconOnClick ? { id: -1, type: 10001, params: ["sys.color.ohos_id_color_titlebar_icon_pressed"], bundleName: "", moduleName: "" } : { id: -1, type: 10001, params: ["sys.color.ohos_id_color_titlebar_icon"], bundleName: "", moduleName: "" } } getMoreIconBgColor() { return this.isMoreIconOnClick ? { id: -1, type: 10001, params: ["sys.color.ohos_id_color_click_effect"], bundleName: "", moduleName: "" } : this.isMoreIconOnHover ? { id: -1, type: 10001, params: ["sys.color.ohos_id_color_hover"], bundleName: "", moduleName: "" } : Color.Transparent } initialRender() { this.observeComponentCreation(((e, t) => { ViewStackProcessor.StartGetAccessRecordingFor(e); Column.create(); Column.height("100%"); Column.justifyContent(FlexAlign.Center); t || Column.pop(); ViewStackProcessor.StopGetAccessRecording() })); this.observeComponentCreation(((e, t) => { ViewStackProcessor.StartGetAccessRecordingFor(e); Row.create(); t || Row.pop(); ViewStackProcessor.StopGetAccessRecording() })); this.observeComponentCreation(((e, t) => { ViewStackProcessor.StartGetAccessRecordingFor(e); If.create(); this.menuItems.length <= CollapsibleMenuSection.maxCountOfVisibleItems ? this.ifElseBranchUpdateFunction(0, (() => { this.observeComponentCreation(((e, t) => { ViewStackProcessor.StartGetAccessRecordingFor(e); ForEach.create(); this.forEachUpdateFunction(e, this.menuItems, (e => { const t = e; this.observeComponentCreation(((e, o) => { ViewStackProcessor.StartGetAccessRecordingFor(e); o ? ViewPU.create(new ImageMenuItem(this, { item: t }, void 0, e)) : this.updateStateVarsOfChildByElmtId(e, {}); ViewStackProcessor.StopGetAccessRecording() })) })); t || ForEach.pop(); ViewStackProcessor.StopGetAccessRecording() })); ForEach.pop() })) : this.ifElseBranchUpdateFunction(1, (() => { this.observeComponentCreation(((e, t) => { ViewStackProcessor.StartGetAccessRecordingFor(e); ForEach.create(); this.forEachUpdateFunction(e, this.menuItems.slice(0, CollapsibleMenuSection.maxCountOfVisibleItems - 1), (e => { const t = e; this.observeComponentCreation(((e, o) => { ViewStackProcessor.StartGetAccessRecordingFor(e); o ? ViewPU.create(new ImageMenuItem(this, { item: t }, void 0, e)) : this.updateStateVarsOfChildByElmtId(e, {}); ViewStackProcessor.StopGetAccessRecording() })) })); t || ForEach.pop(); ViewStackProcessor.StopGetAccessRecording() })); ForEach.pop(); this.observeComponentCreation(((e, t) => { ViewStackProcessor.StartGetAccessRecordingFor(e); Row.create(); Row.width(ImageMenuItem.imageHotZoneWidth); Row.height(ImageMenuItem.imageHotZoneWidth); Row.borderRadius(ImageMenuItem.buttonBorderRadius); Row.foregroundColor(this.getMoreIconFgColor()); Row.backgroundColor(this.getMoreIconBgColor()); Row.justifyContent(FlexAlign.Center); Row.border(this.isMoreIconOnFocus ? { width: ImageMenuItem.focusBorderWidth, color: { id: -1, type: 10001, params: ["sys.color.ohos_id_color_emphasize"], bundleName: "", moduleName: "" }, style: BorderStyle.Solid } : { width: 0 }); Row.onFocus((() => this.isMoreIconOnFocus = !0)); Row.onBlur((() => this.isMoreIconOnFocus = !1)); Row.onHover((e => this.isMoreIconOnHover = e)); Row.onKeyEvent((e => { if (e.keyCode === KeyCode.KEYCODE_ENTER || e.keyCode === KeyCode.KEYCODE_SPACE) { e.type === KeyType.Down && (this.isMoreIconOnClick = !0); e.type === KeyType.Up && (this.isMoreIconOnClick = !1) } })); Row.onTouch((e => { e.type === TouchType.Down && (this.isMoreIconOnClick = !0); e.type === TouchType.Up && (this.isMoreIconOnClick = !1) })); Row.onClick((() => this.isPopupShown = !0)); Row.bindPopup(this.isPopupShown, { builder: { builder: this.popupBuilder.bind(this) }, placement: Placement.Bottom, popupColor: Color.White, enableArrow: !1, onStateChange: e => this.isPopupShown = e.isVisible }); t || Row.pop(); ViewStackProcessor.StopGetAccessRecording() })); this.observeComponentCreation(((e, t) => { ViewStackProcessor.StartGetAccessRecordingFor(e); Image.create(PUBLIC_MORE); Image.width(ImageMenuItem.imageSize); Image.height(ImageMenuItem.imageSize); Image.focusable(!0); t || Image.pop(); ViewStackProcessor.StopGetAccessRecording() })); Row.pop() })); t || If.pop(); ViewStackProcessor.StopGetAccessRecording() })); If.pop(); Row.pop(); Column.pop() } popupBuilder(e = null) { this.observeComponentCreation(((e, t) => { ViewStackProcessor.StartGetAccessRecordingFor(e); Column.create(); Column.width(ImageMenuItem.imageHotZoneWidth + CollapsibleMenuSection.focusPadding * CollapsibleMenuSection.marginsNum); Column.margin({ top: CollapsibleMenuSection.focusPadding, bottom: CollapsibleMenuSection.focusPadding }); t || Column.pop(); ViewStackProcessor.StopGetAccessRecording() })); this.observeComponentCreation(((e, t) => { ViewStackProcessor.StartGetAccessRecordingFor(e); ForEach.create(); this.forEachUpdateFunction(e, this.menuItems.slice(CollapsibleMenuSection.maxCountOfVisibleItems - 1, this.menuItems.length), ((e, t) => { const o = e; this.observeComponentCreation(((e, t) => { ViewStackProcessor.StartGetAccessRecordingFor(e); t ? ViewPU.create(new ImageMenuItem(this, { item: o }, void 0, e)) : this.updateStateVarsOfChildByElmtId(e, {}); ViewStackProcessor.StopGetAccessRecording() })) }), void 0, !0, !1); t || ForEach.pop(); ViewStackProcessor.StopGetAccessRecording() })); ForEach.pop(); Column.pop() } rerender() { this.updateDirtyElements() } } CollapsibleMenuSection.maxCountOfVisibleItems = 1; CollapsibleMenuSection.focusPadding = 4; CollapsibleMenuSection.marginsNum = 2; __decorate([], CollapsibleMenuSection.prototype, "popupBuilder", null); class TabContentItem extends ViewPU { constructor(e, t, o, i = -1) { super(e, o, i); this.item = void 0; this.index = void 0; this.maxIndex = void 0; this.onCustomClick = void 0; this.__currentIndex = new SynchedPropertySimpleOneWayPU(t.currentIndex, this, "currentIndex"); this.__isOnFocus = new ObservedPropertySimplePU(!1, this, "isOnFocus"); this.__isOnHover = new ObservedPropertySimplePU(!1, this, "isOnHover"); this.__isOnClick = new ObservedPropertySimplePU(!1, this, "isOnClick"); this.setInitiallyProvidedValue(t) } setInitiallyProvidedValue(e) { void 0 !== e.item && (this.item = e.item); void 0 !== e.index && (this.index = e.index); void 0 !== e.maxIndex && (this.maxIndex = e.maxIndex); void 0 !== e.onCustomClick && (this.onCustomClick = e.onCustomClick); void 0 !== e.isOnFocus && (this.isOnFocus = e.isOnFocus); void 0 !== e.isOnHover && (this.isOnHover = e.isOnHover); void 0 !== e.isOnClick && (this.isOnClick = e.isOnClick) } updateStateVars(e) { this.__currentIndex.reset(e.currentIndex) } purgeVariableDependenciesOnElmtId(e) { this.__currentIndex.purgeDependencyOnElmtId(e); this.__isOnFocus.purgeDependencyOnElmtId(e); this.__isOnHover.purgeDependencyOnElmtId(e); this.__isOnClick.purgeDependencyOnElmtId(e) } aboutToBeDeleted() { this.__currentIndex.aboutToBeDeleted(); this.__isOnFocus.aboutToBeDeleted(); this.__isOnHover.aboutToBeDeleted(); this.__isOnClick.aboutToBeDeleted(); SubscriberManager.Get().delete(this.id__()); this.aboutToBeDeletedInternal() } get currentIndex() { return this.__currentIndex.get() } set currentIndex(e) { this.__currentIndex.set(e) } get isOnFocus() { return this.__isOnFocus.get() } set isOnFocus(e) { this.__isOnFocus.set(e) } get isOnHover() { return this.__isOnHover.get() } set isOnHover(e) { this.__isOnHover.set(e) } get isOnClick() { return this.__isOnClick.get() } set isOnClick(e) { this.__isOnClick.set(e) } getBgColor() { return this.isOnClick ? { id: -1, type: 10001, params: ["sys.color.ohos_id_color_click_effect"], bundleName: "", moduleName: "" } : this.isOnHover ? { id: -1, type: 10001, params: ["sys.color.ohos_id_color_hover"], bundleName: "", moduleName: "" } : Color.Transparent } initialRender() { this.observeComponentCreation(((e, t) => { ViewStackProcessor.StartGetAccessRecordingFor(e); Row.create(); Row.height(TabTitleBar.totalHeight); Row.alignItems(VerticalAlign.Center); Row.justifyContent(FlexAlign.Center); Row.margin({ left: 0 === this.index ? 16 : 0, right: this.index === this.maxIndex ? 12 : 0 }); Row.borderRadius(TabContentItem.buttonBorderRadius); Row.backgroundColor(this.getBgColor()); Row.border(this.isOnFocus ? { width: TabContentItem.focusBorderWidth, color: { id: -1, type: 10001, params: ["sys.color.ohos_id_color_emphasize"], bundleName: "", moduleName: "" }, style: BorderStyle.Solid } : { width: 0 }); t || Row.pop(); ViewStackProcessor.StopGetAccessRecording() })); this.observeComponentCreation(((e, t) => { ViewStackProcessor.StartGetAccessRecordingFor(e); Column.create(); Column.justifyContent(FlexAlign.Center); t || Column.pop(); ViewStackProcessor.StopGetAccessRecording() })); this.observeComponentCreation(((e, t) => { ViewStackProcessor.StartGetAccessRecordingFor(e); If.create(); void 0 === this.item.icon ? this.ifElseBranchUpdateFunction(0, (() => { this.observeComponentCreation(((e, t) => { ViewStackProcessor.StartGetAccessRecordingFor(e); Text.create(this.item.title); Text.fontSize(this.index === this.currentIndex ? { id: -1, type: 10002, params: ["sys.float.ohos_id_text_size_headline7"], bundleName: "", moduleName: "" } : { id: -1, type: 10002, params: ["sys.float.ohos_id_text_size_headline9"], bundleName: "", moduleName: "" }); Text.fontColor(this.index === this.currentIndex ? { id: -1, type: 10001, params: ["sys.color.ohos_id_color_titlebar_text"], bundleName: "", moduleName: "" } : { id: -1, type: 10001, params: ["sys.color.ohos_id_color_titlebar_text_off"], bundleName: "", moduleName: "" }); Text.fontWeight(FontWeight.Medium); Text.focusable(!0); Text.padding({ top: this.index === this.currentIndex ? 6 : 10, left: 8, bottom: 2, right: 8 }); Text.onFocus((() => this.isOnFocus = !0)); Text.onBlur((() => this.isOnFocus = !1)); Text.onHover((e => this.isOnHover = e)); Text.onKeyEvent((e => { if (e.keyCode === KeyCode.KEYCODE_ENTER || e.keyCode === KeyCode.KEYCODE_SPACE) { e.type === KeyType.Down && (this.isOnClick = !0); e.type === KeyType.Up && (this.isOnClick = !1) } })); Text.onTouch((e => { e.type === TouchType.Down && (this.isOnClick = !0); e.type === TouchType.Up && (this.isOnClick = !1) })); Text.onClick((() => this.onCustomClick && this.onCustomClick())); t || Text.pop(); ViewStackProcessor.StopGetAccessRecording() })); Text.pop() })) : this.ifElseBranchUpdateFunction(1, (() => { this.observeComponentCreation(((e, t) => { ViewStackProcessor.StartGetAccessRecordingFor(e); Row.create(); Row.width(TabContentItem.imageHotZoneWidth); Row.height(TabContentItem.imageHotZoneWidth); Row.justifyContent(FlexAlign.Center); Row.onFocus((() => this.isOnFocus = !0)); Row.onBlur((() => this.isOnFocus = !1)); Row.onHover((e => this.isOnHover = e)); Row.onKeyEvent((e => { if (e.keyCode === KeyCode.KEYCODE_ENTER || e.keyCode === KeyCode.KEYCODE_SPACE) { e.type === KeyType.Down && (this.isOnClick = !0); e.type === KeyType.Up && (this.isOnClick = !1) } })); Row.onTouch((e => { e.type === TouchType.Down && (this.isOnClick = !0); e.type === TouchType.Up && (this.isOnClick = !1) })); Row.onClick((() => this.onCustomClick && this.onCustomClick())); t || Row.pop(); ViewStackProcessor.StopGetAccessRecording() })); this.observeComponentCreation(((e, t) => { ViewStackProcessor.StartGetAccessRecordingFor(e); Image.create(this.item.icon); Image.alt(this.item.title); Image.height(TabContentItem.imageSize); Image.focusable(!0); Image.scale({ x: this.index === this.currentIndex ? TabContentItem.imageMagnificationFactor : 1, y: this.index === this.currentIndex ? TabContentItem.imageMagnificationFactor : 1 }); t || Image.pop(); ViewStackProcessor.StopGetAccessRecording() })); Row.pop() })); t || If.pop(); ViewStackProcessor.StopGetAccessRecording() })); If.pop(); Column.pop(); Row.pop() } rerender() { this.updateDirtyElements() } } TabContentItem.imageSize = 24; TabContentItem.imageHotZoneWidth = 48; TabContentItem.imageMagnificationFactor = 1.4; TabContentItem.buttonBorderRadius = 8; TabContentItem.focusBorderWidth = 2; class ImageMenuItem extends ViewPU { constructor(e, t, o, i = -1) { super(e, o, i); this.item = void 0; this.__isOnFocus = new ObservedPropertySimplePU(!1, this, "isOnFocus"); this.__isOnHover = new ObservedPropertySimplePU(!1, this, "isOnHover"); this.__isOnClick = new ObservedPropertySimplePU(!1, this, "isOnClick"); this.setInitiallyProvidedValue(t) } setInitiallyProvidedValue(e) { void 0 !== e.item && (this.item = e.item); void 0 !== e.isOnFocus && (this.isOnFocus = e.isOnFocus); void 0 !== e.isOnHover && (this.isOnHover = e.isOnHover); void 0 !== e.isOnClick && (this.isOnClick = e.isOnClick) } updateStateVars(e) {} purgeVariableDependenciesOnElmtId(e) { this.__isOnFocus.purgeDependencyOnElmtId(e); this.__isOnHover.purgeDependencyOnElmtId(e); this.__isOnClick.purgeDependencyOnElmtId(e) } aboutToBeDeleted() { this.__isOnFocus.aboutToBeDeleted(); this.__isOnHover.aboutToBeDeleted(); this.__isOnClick.aboutToBeDeleted(); SubscriberManager.Get().delete(this.id__()); this.aboutToBeDeletedInternal() } get isOnFocus() { return this.__isOnFocus.get() } set isOnFocus(e) { this.__isOnFocus.set(e) } get isOnHover() { return this.__isOnHover.get() } set isOnHover(e) { this.__isOnHover.set(e) } get isOnClick() { return this.__isOnClick.get() } set isOnClick(e) { this.__isOnClick.set(e) } getFgColor() { return this.isOnClick ? { id: -1, type: 10001, params: ["sys.color.ohos_id_color_titlebar_icon_pressed"], bundleName: "", moduleName: "" } : { id: -1, type: 10001, params: ["sys.color.ohos_id_color_titlebar_icon"], bundleName: "", moduleName: "" } } getBgColor() { return this.isOnClick ? { id: -1, type: 10001, params: ["sys.color.ohos_id_color_click_effect"], bundleName: "", moduleName: "" } : this.isOnHover ? { id: -1, type: 10001, params: ["sys.color.ohos_id_color_hover"], bundleName: "", moduleName: "" } : Color.Transparent } initialRender() { this.observeComponentCreation(((e, t) => { ViewStackProcessor.StartGetAccessRecordingFor(e); Row.create(); Row.width(ImageMenuItem.imageHotZoneWidth); Row.height(ImageMenuItem.imageHotZoneWidth); Row.borderRadius(ImageMenuItem.buttonBorderRadius); Row.foregroundColor(this.getFgColor()); Row.backgroundColor(this.getBgColor()); Row.justifyContent(FlexAlign.Center); Row.opacity(this.item.isEnabled ? 1 : ImageMenuItem.disabledImageOpacity); Row.border(this.isOnFocus ? { width: ImageMenuItem.focusBorderWidth, color: { id: -1, type: 10001, params: ["sys.color.ohos_id_color_emphasize"], bundleName: "", moduleName: "" }, style: BorderStyle.Solid } : { width: 0 }); Row.onFocus((() => { this.item.isEnabled && (this.isOnFocus = !0) })); Row.onBlur((() => this.isOnFocus = !1)); Row.onHover((e => { this.item.isEnabled && (this.isOnHover = e) })); Row.onKeyEvent((e => { if (this.item.isEnabled && (e.keyCode === KeyCode.KEYCODE_ENTER || e.keyCode === KeyCode.KEYCODE_SPACE)) { e.type === KeyType.Down && (this.isOnClick = !0); e.type === KeyType.Up && (this.isOnClick = !1) } })); Row.onTouch((e => { if (this.item.isEnabled) { e.type === TouchType.Down && (this.isOnClick = !0); e.type === TouchType.Up && (this.isOnClick = !1) } })); Row.onClick((() => this.item.isEnabled && this.item.action && this.item.action())); t || Row.pop(); ViewStackProcessor.StopGetAccessRecording() })); this.observeComponentCreation(((e, t) => { ViewStackProcessor.StartGetAccessRecordingFor(e); Image.create(this.item.value); Image.width(ImageMenuItem.imageSize); Image.height(ImageMenuItem.imageSize); Image.focusable(this.item.isEnabled); t || Image.pop(); ViewStackProcessor.StopGetAccessRecording() })); Row.pop() } rerender() { this.updateDirtyElements() } } ImageMenuItem.imageSize = 24; ImageMenuItem.imageHotZoneWidth = 48; ImageMenuItem.buttonBorderRadius = 8; ImageMenuItem.focusBorderWidth = 2; ImageMenuItem.disabledImageOpacity = .4; export default { TabTitleBar: TabTitleBar };