From b3bbd908f712660defefa5ba9051bf2c39b4f850 Mon Sep 17 00:00:00 2001 From: Kayla Glick <12898988+kayla-glick@users.noreply.github.com> Date: Sun, 14 Apr 2024 13:55:25 -0400 Subject: [PATCH] Fix wowhead tooltips in icon enum picker (#4243) * port two SoD updates * fix icon enum tooltips --- ui/core/components/icon_enum_picker.tsx | 88 +++++++++++-------------- 1 file changed, 40 insertions(+), 48 deletions(-) diff --git a/ui/core/components/icon_enum_picker.tsx b/ui/core/components/icon_enum_picker.tsx index 63fd94ba7d..c4f24368c5 100644 --- a/ui/core/components/icon_enum_picker.tsx +++ b/ui/core/components/icon_enum_picker.tsx @@ -4,7 +4,6 @@ import { element, fragment } from 'tsx-vanilla'; import { ActionId } from '../proto_utils/action_id.js'; import { TypedEvent } from '../typed_event.js'; - import { Input, InputConfig } from './input.js'; export enum IconEnumPickerDirection { @@ -13,32 +12,32 @@ export enum IconEnumPickerDirection { } export interface IconEnumValueConfig { - value: T, + value: T; // One of these should be set. If actionId is set, shows the icon for that id. If // color is set, shows that color. - actionId?: ActionId, - color?: string, + actionId?: ActionId; + color?: string; // Text to be displayed on the icon. - text?: string, + text?: string; // Hover tooltip. - tooltip?: string, + tooltip?: string; - showWhen?: (obj: ModObject) => boolean, + showWhen?: (obj: ModObject) => boolean; } export interface IconEnumPickerConfig extends InputConfig { - numColumns?: number, + numColumns?: number; values: Array>; // Value that will be considered inactive. - zeroValue: T, + zeroValue: T; // Function for comparing two values. // Tooltip that will be shown whne hovering over the icon-picker-button - tooltip?: string, + tooltip?: string; // The direction the menu will open in relative to the root element - direction?: IconEnumPickerDirection, - equals: (a: T, b: T) => boolean, - backupIconUrl?: (value: T) => ActionId, - showWhen?: (obj: ModObject) => boolean, + direction?: IconEnumPickerDirection; + equals: (a: T, b: T) => boolean; + backupIconUrl?: (value: T) => ActionId; + showWhen?: (obj: ModObject) => boolean; } // Icon-based UI for picking enum values. @@ -60,15 +59,14 @@ export class IconEnumPicker extends Input { if (config.showWhen) { config.changedEvent(this.modObject).on(_eventID => { const show = config.showWhen && config.showWhen(this.modObject); - if (!show) - this.rootElem.classList.add('hide'); + if (!show) this.rootElem.classList.add('hide'); }); } if (config.tooltip) { Tooltip.getOrCreateInstance(this.rootElem, { html: true, - title: config.tooltip + title: config.tooltip, }); } this.rootElem.appendChild( @@ -77,46 +75,44 @@ export class IconEnumPicker extends Input { href="javascript:void(0)" className="icon-picker-button" attributes={{ - 'aria-expanded':"false", - role: 'button' + 'aria-expanded': 'false', + role: 'button', }} dataset={{ bsToggle: 'dropdown', bsPlacement: 'bottom', - whtticon:"false", - disableWowheadTouchTooltip:'true' - }} - > - + whtticon: 'false', + disableWowheadTouchTooltip: 'true', + }}> +
    - - ) + , + ); this.buttonElem = this.rootElem.querySelector('.icon-picker-button') as HTMLAnchorElement; this.buttonText = this.buttonElem.querySelector('.icon-picker-label') as HTMLElement; const dropdownMenu = this.rootElem.querySelector('.dropdown-menu') as HTMLElement; - if (this.config.numColumns) - dropdownMenu.style.gridTemplateColumns = `repeat(${this.config.numColumns}, 1fr)`; + if (this.config.numColumns) dropdownMenu.style.gridTemplateColumns = `repeat(${this.config.numColumns}, 1fr)`; - if (this.config.direction == IconEnumPickerDirection.Horizontal) - dropdownMenu.style.gridAutoFlow = 'column'; + if (this.config.direction == IconEnumPickerDirection.Horizontal) dropdownMenu.style.gridAutoFlow = 'column'; config.values.forEach((valueConfig, _i) => { const optionContainer = document.createElement('li'); - optionContainer.classList.add('icon-dropdown-option', 'dropdown-option') + optionContainer.classList.add('icon-dropdown-option', 'dropdown-option'); dropdownMenu.appendChild(optionContainer); const option = document.createElement('a'); option.classList.add('icon-picker-button'); - option.dataset.disableWowheadTouchTooltip='true'; + option.dataset.whtticon = 'false'; + option.dataset.disableWowheadTouchTooltip = 'true'; optionContainer.appendChild(option); this.setImage(option, valueConfig); if (valueConfig.text != undefined) { const optionText = document.createElement('div'); - optionText.classList.add("icon-picker-label"); + optionText.classList.add('icon-picker-label'); optionText.textContent = valueConfig.text; option.append(optionText); } @@ -124,20 +120,18 @@ export class IconEnumPicker extends Input { if (valueConfig.tooltip) { Tooltip.getOrCreateInstance(option, { html: true, - title: valueConfig.tooltip + title: valueConfig.tooltip, }); } const show = !valueConfig.showWhen || valueConfig.showWhen(this.modObject); - if (!show) optionContainer.classList.add('hide') + if (!show) optionContainer.classList.add('hide'); if (valueConfig.showWhen) { config.changedEvent(this.modObject).on(_eventID => { const show = valueConfig.showWhen && valueConfig.showWhen(this.modObject); - if (show) - optionContainer.classList.remove('hide'); - else - optionContainer.classList.add('hide'); + if (show) optionContainer.classList.remove('hide'); + else optionContainer.classList.add('hide'); }); } @@ -179,17 +173,17 @@ export class IconEnumPicker extends Input { setInputValue(newValue: T) { this.currentValue = newValue; - this.setActive(this.enabled && !this.config.equals(this.currentValue, this.config.zeroValue)) + this.setActive(this.enabled && !this.config.equals(this.currentValue, this.config.zeroValue)); - this.buttonText.textContent = '' - this.buttonText.style.display = 'none' + this.buttonText.textContent = ''; + this.buttonText.style.display = 'none'; const valueConfig = this.config.values.find(valueConfig => this.config.equals(valueConfig.value, this.currentValue))!; if (valueConfig) { this.setImage(this.buttonElem, valueConfig); if (valueConfig.text != undefined) { - this.buttonText.style.display = 'block' - this.buttonText.textContent = valueConfig.text + this.buttonText.style.display = 'block'; + this.buttonText.textContent = valueConfig.text; } } else if (this.config.backupIconUrl) { const backupId = this.config.backupIconUrl(this.currentValue); @@ -199,9 +193,7 @@ export class IconEnumPicker extends Input { } setActive(active: boolean) { - if (active) - this.buttonElem.classList.add('active'); - else - this.buttonElem.classList.remove('active'); + if (active) this.buttonElem.classList.add('active'); + else this.buttonElem.classList.remove('active'); } }