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