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