From 4b0d0eb15579d1b9dcfcc17fe698824b56de1835 Mon Sep 17 00:00:00 2001 From: dodoels Date: Mon, 18 Nov 2024 22:33:09 -0500 Subject: [PATCH 1/3] add unequip all gems button to gem summary --- .../components/individual_sim_ui/gem_summary.ts | 15 +++++++++++++++ ui/scss/shared/_gems.scss | 10 +++++++++- 2 files changed, 24 insertions(+), 1 deletion(-) diff --git a/ui/core/components/individual_sim_ui/gem_summary.ts b/ui/core/components/individual_sim_ui/gem_summary.ts index e0a971e246..2d47109bdf 100644 --- a/ui/core/components/individual_sim_ui/gem_summary.ts +++ b/ui/core/components/individual_sim_ui/gem_summary.ts @@ -4,6 +4,7 @@ import { Player } from '../../player'; import { UIGem as Gem } from '../../proto/ui.js'; import { ActionId } from '../../proto_utils/action_id'; import { SimUI } from '../../sim_ui'; +import { TypedEvent } from '../../typed_event'; import { ContentBlock } from '../content_block'; interface GemSummaryData { @@ -26,6 +27,20 @@ export class GemSummary extends Component { header: { title: 'Gem Summary' }, }); player.gearChangeEmitter.on(() => this.updateTable()); + + const headerElement = this.container.headerElement; + if (headerElement) { + const unequipButton = document.createElement('button'); + unequipButton.innerHTML = ` Unequip All Gems`; + unequipButton.classList.add('btn', 'btn-sm', 'btn-link', 'gem-reset-button'); + unequipButton.id = 'unequip-all-gems-btn'; + unequipButton.onclick = () => this.unequipAllGems(); + headerElement.appendChild(unequipButton); + } + } + + private unequipAllGems() { + this.player.setGear(TypedEvent.nextEventID(), this.player.getGear().withoutGems()); } private updateTable() { diff --git a/ui/scss/shared/_gems.scss b/ui/scss/shared/_gems.scss index 2e9c50d880..c59cac9d97 100644 --- a/ui/scss/shared/_gems.scss +++ b/ui/scss/shared/_gems.scss @@ -4,7 +4,7 @@ position: relative; width: var(--gem-width); height: var(--gem-width); - + &:not(:last-child) { margin-right: 1px; } @@ -30,3 +30,11 @@ height: 100%; inset: 0; } + +.gem-reset-button { + margin-left: auto; + display: flex; + align-items: center; + padding: 0; + color: #ef9eaa; +} From e1657b191c0a71d79c0cf4405cdec0ab0d57f098 Mon Sep 17 00:00:00 2001 From: dodoels Date: Mon, 23 Dec 2024 23:16:53 -0500 Subject: [PATCH 2/3] use color variable --- ui/scss/shared/_gems.scss | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/ui/scss/shared/_gems.scss b/ui/scss/shared/_gems.scss index c59cac9d97..95bf70fae0 100644 --- a/ui/scss/shared/_gems.scss +++ b/ui/scss/shared/_gems.scss @@ -36,5 +36,5 @@ display: flex; align-items: center; padding: 0; - color: #ef9eaa; + color: $link-danger-color; } From 3bffce35f64384e6e5e33ce2d6eea14379ea590d Mon Sep 17 00:00:00 2001 From: dodoels Date: Tue, 24 Dec 2024 09:54:39 -0500 Subject: [PATCH 3/3] convert gem summary to tsx component --- .../individual_sim_ui/{gem_summary.ts => gem_summary.tsx} | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) rename ui/core/components/individual_sim_ui/{gem_summary.ts => gem_summary.tsx} (97%) diff --git a/ui/core/components/individual_sim_ui/gem_summary.ts b/ui/core/components/individual_sim_ui/gem_summary.tsx similarity index 97% rename from ui/core/components/individual_sim_ui/gem_summary.ts rename to ui/core/components/individual_sim_ui/gem_summary.tsx index 2d47109bdf..0beddab44a 100644 --- a/ui/core/components/individual_sim_ui/gem_summary.ts +++ b/ui/core/components/individual_sim_ui/gem_summary.tsx @@ -1,10 +1,10 @@ -import { Component } from '../../components/component'; import { setItemQualityCssClass } from '../../css_utils'; import { Player } from '../../player'; import { UIGem as Gem } from '../../proto/ui.js'; import { ActionId } from '../../proto_utils/action_id'; import { SimUI } from '../../sim_ui'; import { TypedEvent } from '../../typed_event'; +import { Component } from '../component'; import { ContentBlock } from '../content_block'; interface GemSummaryData {