/* * 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. */ const KeyCode = requireNapi('multimodalInput.keyCode').KeyCode; export var EditableLeftIconType; ! function(e) { e[e.Back = 0] = "Back"; e[e.Cancel = 1] = "Cancel" }(EditableLeftIconType || (EditableLeftIconType = {})); const PUBLIC_CANCEL = ""; const PUBLIC_OK = ""; const PUBLIC_BACK = ""; export class EditableTitleBar extends ViewPU { constructor(e, t, A, i = -1) { super(e, A, i); this.leftIconStyle = void 0; this.title = void 0; this.menuItems = void 0; this.onSave = void 0; this.onCancel = void 0; this.__titleMaxWidth = new ObservedPropertySimplePU(0, this, "titleMaxWidth"); this.setInitiallyProvidedValue(t) } setInitiallyProvidedValue(e) { void 0 !== e.leftIconStyle && (this.leftIconStyle = e.leftIconStyle); void 0 !== e.title && (this.title = e.title); void 0 !== e.menuItems && (this.menuItems = e.menuItems); void 0 !== e.onSave && (this.onSave = e.onSave); void 0 !== e.onCancel && (this.onCancel = e.onCancel); void 0 !== e.titleMaxWidth && (this.titleMaxWidth = e.titleMaxWidth) } updateStateVars(e) {} purgeVariableDependenciesOnElmtId(e) { this.__titleMaxWidth.purgeDependencyOnElmtId(e) } aboutToBeDeleted() { this.__titleMaxWidth.aboutToBeDeleted(); SubscriberManager.Get().delete(this.id__()); this.aboutToBeDeletedInternal() } get titleMaxWidth() { return this.__titleMaxWidth.get() } set titleMaxWidth(e) { this.__titleMaxWidth.set(e) } initialRender() { this.observeComponentCreation(((e, t) => { ViewStackProcessor.StartGetAccessRecordingFor(e); Flex.create({ justifyContent: FlexAlign.SpaceBetween, alignItems: ItemAlign.Stretch }); Flex.width("100%"); Flex.height(EditableTitleBar.totalHeight); Flex.backgroundColor({ id: -1, type: 10001, params: ["sys.color.ohos_id_color_background"], bundleName: "", moduleName: "" }); Flex.onAreaChange(((e, t) => { let A = Number(t.width); A = A - EditableTitleBar.leftPadding - EditableTitleBar.rightPadding - EditableTitleBar.titlePadding; A = A - ImageMenuItem.imageHotZoneWidth - ImageMenuItem.imageHotZoneWidth; void 0 !== this.menuItems ? this.menuItems.length > EditableTitleBar.maxCountOfExtraItems ? this.titleMaxWidth = A - ImageMenuItem.imageHotZoneWidth * EditableTitleBar.maxCountOfExtraItems : this.titleMaxWidth = A - ImageMenuItem.imageHotZoneWidth * this.menuItems.length : this.titleMaxWidth = A })); t || Flex.pop(); ViewStackProcessor.StopGetAccessRecording() })); this.observeComponentCreation(((e, t) => { ViewStackProcessor.StartGetAccessRecordingFor(e); Row.create(); Row.margin({ left: { id: -1, type: 10002, params: ["sys.float.ohos_id_default_padding_start"], bundleName: "", moduleName: "" } }); t || Row.pop(); ViewStackProcessor.StopGetAccessRecording() })); this.observeComponentCreation(((e, t) => { ViewStackProcessor.StartGetAccessRecordingFor(e); If.create(); this.leftIconStyle == EditableLeftIconType.Back ? this.ifElseBranchUpdateFunction(0, (() => { this.observeComponentCreation(((e, t) => { ViewStackProcessor.StartGetAccessRecordingFor(e); Navigator.create(); t || Navigator.pop(); ViewStackProcessor.StopGetAccessRecording() })); this.observeComponentCreation(((e, t) => { ViewStackProcessor.StartGetAccessRecordingFor(e); t ? ViewPU.create(new ImageMenuItem(this, { item: { value: PUBLIC_BACK, isEnabled: !0 } }, void 0, e)) : this.updateStateVarsOfChildByElmtId(e, {}); ViewStackProcessor.StopGetAccessRecording() })); Navigator.pop() })) : this.ifElseBranchUpdateFunction(1, (() => { this.observeComponentCreation(((e, t) => { ViewStackProcessor.StartGetAccessRecordingFor(e); t ? ViewPU.create(new ImageMenuItem(this, { item: { value: PUBLIC_CANCEL, isEnabled: !0, action: () => this.onCancel && this.onCancel() } }, void 0, e)) : this.updateStateVarsOfChildByElmtId(e, {}); ViewStackProcessor.StopGetAccessRecording() })) })); t || If.pop(); ViewStackProcessor.StopGetAccessRecording() })); If.pop(); this.observeComponentCreation(((e, t) => { ViewStackProcessor.StartGetAccessRecordingFor(e); Column.create(); Column.justifyContent(FlexAlign.Start); Column.alignItems(HorizontalAlign.Start); Column.constraintSize({ maxWidth: this.titleMaxWidth }); t || Column.pop(); ViewStackProcessor.StopGetAccessRecording() })); this.observeComponentCreation(((e, t) => { ViewStackProcessor.StartGetAccessRecordingFor(e); Text.create(this.title); Text.fontWeight(FontWeight.Medium); Text.fontSize({ id: -1, type: 10002, params: ["sys.float.ohos_id_text_size_headline8"], bundleName: "", moduleName: "" }); Text.fontColor({ id: -1, type: 10001, params: ["sys.color.ohos_id_color_titlebar_text"], bundleName: "", moduleName: "" }); Text.maxLines(1); Text.textOverflow({ overflow: TextOverflow.Ellipsis }); Text.constraintSize({ maxWidth: this.titleMaxWidth }); t || Text.pop(); ViewStackProcessor.StopGetAccessRecording() })); Text.pop(); Column.pop(); Row.pop(); this.observeComponentCreation(((e, t) => { ViewStackProcessor.StartGetAccessRecordingFor(e); t ? ViewPU.create(new EditableTitleBarMenuSection(this, { menuItems: this.menuItems, onSave: this.onSave }, void 0, e)) : this.updateStateVarsOfChildByElmtId(e, {}); ViewStackProcessor.StopGetAccessRecording() })); Flex.pop() } rerender() { this.updateDirtyElements() } } EditableTitleBar.maxCountOfExtraItems = 2; EditableTitleBar.totalHeight = 56; EditableTitleBar.leftPadding = 12; EditableTitleBar.rightPadding = 12; EditableTitleBar.titlePadding = 16; class EditableTitleBarMenuSection extends ViewPU { constructor(e, t, A, i = -1) { super(e, A, i); this.menuItems = void 0; this.onSave = void 0; this.setInitiallyProvidedValue(t) } setInitiallyProvidedValue(e) { void 0 !== e.menuItems && (this.menuItems = e.menuItems); void 0 !== e.onSave && (this.onSave = e.onSave) } updateStateVars(e) {} purgeVariableDependenciesOnElmtId(e) {} aboutToBeDeleted() { SubscriberManager.Get().delete(this.id__()); this.aboutToBeDeletedInternal() } initialRender() { this.observeComponentCreation(((e, t) => { ViewStackProcessor.StartGetAccessRecordingFor(e); Column.create(); Column.margin({ left: { id: -1, type: 10002, params: ["sys.float.ohos_id_elements_margin_vertical_l"], bundleName: "", moduleName: "" }, right: { id: -1, type: 10002, params: ["sys.float.ohos_id_default_padding_end"], bundleName: "", moduleName: "" } }); 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(); void 0 !== this.menuItems && this.menuItems.length > 0 ? this.ifElseBranchUpdateFunction(0, (() => { this.observeComponentCreation(((e, t) => { ViewStackProcessor.StartGetAccessRecordingFor(e); ForEach.create(); this.forEachUpdateFunction(e, this.menuItems.slice(0, EditableTitleBar.maxCountOfExtraItems), (e => { const t = e; this.observeComponentCreation(((e, A) => { ViewStackProcessor.StartGetAccessRecordingFor(e); A ? ViewPU.create(new ImageMenuItem(this, { item: t }, void 0, e)) : this.updateStateVarsOfChildByElmtId(e, {}); ViewStackProcessor.StopGetAccessRecording() })) })); t || ForEach.pop(); ViewStackProcessor.StopGetAccessRecording() })); ForEach.pop() })) : If.branchId(1); t || If.pop(); ViewStackProcessor.StopGetAccessRecording() })); If.pop(); this.observeComponentCreation(((e, t) => { ViewStackProcessor.StartGetAccessRecordingFor(e); t ? ViewPU.create(new ImageMenuItem(this, { item: { value: PUBLIC_OK, isEnabled: !0, action: () => this.onSave && this.onSave() } }, void 0, e)) : this.updateStateVarsOfChildByElmtId(e, {}); ViewStackProcessor.StopGetAccessRecording() })); Row.pop(); Column.pop() } rerender() { this.updateDirtyElements() } } class ImageMenuItem extends ViewPU { constructor(e, t, A, i = -1) { super(e, A, 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 { EditableLeftIconType: EditableLeftIconType, EditableTitleBar: EditableTitleBar };