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