mirror of
https://github.com/captbaritone/webamp.git
synced 2026-01-23 10:15:31 +00:00
Try to fix EQ title buttons
This commit is contained in:
parent
4c73604684
commit
41fce44d98
8 changed files with 67 additions and 16 deletions
|
|
@ -2,7 +2,11 @@
|
|||
|
||||
### Features
|
||||
|
||||
- Support `.ani` cursors in skins [#1035](https://github.com/captbaritone/webamp/pull/1035) [blog post](https://jordaneldredge.com/blog/rendering-animated-ani-cursors-in-the-browser/).
|
||||
- Support `.ani` cursors in skins [#1035](https://github.com/captbaritone/webamp/pull/1035), [blog post](https://jordaneldredge.com/blog/rendering-animated-ani-cursors-in-the-browser/).
|
||||
|
||||
### Bug Fixes
|
||||
|
||||
- Fix a number of edge cases where the close and minimize buttons in the equalizer window could render the wrong sprite [#1046](https://github.com/captbaritone/webamp/pull/1046)
|
||||
|
||||
## 1.4.2
|
||||
|
||||
|
|
|
|||
|
|
@ -139,8 +139,10 @@
|
|||
#webamp #equalizer-balance.right::-moz-range-thumb {background-image: url()}
|
||||
#webamp #equalizer-shade:active {background-image: url()}
|
||||
#webamp #equalizer-window.shade #equalizer-shade:active {background-image: url()}
|
||||
#webamp #equalizer-window.selected #equalizer-close {background-image: url()}
|
||||
#webamp #equalizer-window #equalizer-close:active {background-image: url()}
|
||||
#webamp #equalizer-window.selected #eq-buttons.clicked #equalizer-close {background-image: url()}
|
||||
#webamp #equalizer-window.selected #eq-buttons.clicked #equalizer-close:active {background-image: url()}
|
||||
#webamp #equalizer-window.shade.selected #eq-buttons.clicked #equalizer-close {background-image: url()}
|
||||
#webamp #equalizer-window.shade.selected #eq-buttons.clicked #equalizer-close:active {background-image: url()}
|
||||
#webamp #position {background-image: url()}
|
||||
#webamp #position::-webkit-slider-thumb {background-image: url()}
|
||||
#webamp #position::-moz-range-thumb {background-image: url()}
|
||||
|
|
|
|||
|
|
@ -0,0 +1,24 @@
|
|||
import ClickedDiv from "../ClickedDiv";
|
||||
import { useTypedSelector, useActionCreator } from "../../hooks";
|
||||
import * as Selectors from "../../selectors";
|
||||
import * as Actions from "../../actionCreators";
|
||||
import { WINDOWS } from "../../constants";
|
||||
|
||||
export default function EqTitleButtons() {
|
||||
const focusedWindow = useTypedSelector(Selectors.getFocusedWindow);
|
||||
|
||||
const selected = focusedWindow === WINDOWS.EQUALIZER;
|
||||
const closeWindow = useActionCreator(Actions.closeWindow);
|
||||
const toggleEqualizerShadeMode = useActionCreator(
|
||||
Actions.toggleEqualizerShadeMode
|
||||
);
|
||||
return (
|
||||
<ClickedDiv id="eq-buttons" key={selected ? "selected" : "unselected"}>
|
||||
<div id="equalizer-shade" onClick={toggleEqualizerShadeMode} />
|
||||
<div
|
||||
id="equalizer-close"
|
||||
onClick={() => closeWindow(WINDOWS.EQUALIZER)}
|
||||
/>
|
||||
</ClickedDiv>
|
||||
);
|
||||
}
|
||||
|
|
@ -1,6 +1,7 @@
|
|||
import Volume from "../Volume";
|
||||
import Balance from "../Balance";
|
||||
import { segment } from "../../utils";
|
||||
import EqTitleButtons from "./EqTitleButtons";
|
||||
|
||||
import * as Actions from "../../actionCreators";
|
||||
import * as Selectors from "../../selectors";
|
||||
|
|
@ -9,7 +10,6 @@ import { useTypedSelector, useActionCreator } from "../../hooks";
|
|||
const EqualizerShade = () => {
|
||||
const volume = useTypedSelector(Selectors.getVolume);
|
||||
const balance = useTypedSelector(Selectors.getBalance);
|
||||
const closeWindow = useActionCreator(Actions.closeWindow);
|
||||
const toggleEqualizerShadeMode = useActionCreator(
|
||||
Actions.toggleEqualizerShadeMode
|
||||
);
|
||||
|
|
@ -23,8 +23,7 @@ const EqualizerShade = () => {
|
|||
onDoubleClick={toggleEqualizerShadeMode}
|
||||
style={{ width: "100%", height: "100%" }}
|
||||
>
|
||||
<div id="equalizer-shade" onClick={toggleEqualizerShadeMode} />
|
||||
<div id="equalizer-close" onClick={() => closeWindow("equalizer")} />
|
||||
<EqTitleButtons />
|
||||
<Volume id="equalizer-volume" className={eqVolumeClassName} />
|
||||
<Balance id="equalizer-balance" className={eqBalanceClassName} />
|
||||
</div>
|
||||
|
|
|
|||
|
|
@ -15,6 +15,7 @@ import "../../../css/equalizer-window.css";
|
|||
import { Band as BandType } from "../../types";
|
||||
import FocusTarget from "../FocusTarget";
|
||||
import { useTypedSelector, useActionCreator } from "../../hooks";
|
||||
import EqTitleButtons from "./EqTitleButtons";
|
||||
|
||||
const bandClassName = (band: BandType) => `band-${band}`;
|
||||
|
||||
|
|
@ -31,7 +32,6 @@ const EqualizerWindow = () => {
|
|||
const setEqToMid = useActionCreator(Actions.setEqToMid);
|
||||
const setEqToMax = useActionCreator(Actions.setEqToMax);
|
||||
const setHertzValue = useActionCreator(Actions.setEqBand);
|
||||
const closeWindow = useActionCreator(Actions.closeWindow);
|
||||
const toggleEqualizerShadeMode = useActionCreator(
|
||||
Actions.toggleEqualizerShadeMode
|
||||
);
|
||||
|
|
@ -54,11 +54,7 @@ const EqualizerWindow = () => {
|
|||
className="equalizer-top title-bar draggable"
|
||||
onDoubleClick={toggleEqualizerShadeMode}
|
||||
>
|
||||
<div id="equalizer-shade" onClick={toggleEqualizerShadeMode} />
|
||||
<div
|
||||
id="equalizer-close"
|
||||
onClick={() => closeWindow(WINDOWS.EQUALIZER)}
|
||||
/>
|
||||
<EqTitleButtons />
|
||||
</div>
|
||||
<EqOn />
|
||||
<EqAuto />
|
||||
|
|
|
|||
|
|
@ -31,6 +31,7 @@ const FALLBACKS: { [key: string]: string } = {
|
|||
MAIN_BALANCE_BACKGROUND: "MAIN_VOLUME_BACKGROUND",
|
||||
MAIN_BALANCE_THUMB: "MAIN_VOLUME_THUMB",
|
||||
MAIN_BALANCE_THUMB_ACTIVE: "MAIN_VOLUME_THUMB_SELECTED",
|
||||
EQ_MAXIMIZE_BUTTON_ACTIVE: "EQ_MAXIMIZE_BUTTON_ACTIVE_FALLBACK",
|
||||
};
|
||||
|
||||
// Cursors might appear in context menus which are not nested inside the window layout div.
|
||||
|
|
|
|||
|
|
@ -201,8 +201,18 @@ export const imageSelectors: Selectors = {
|
|||
EQ_MINIMIZE_BUTTON_ACTIVE: [
|
||||
"#equalizer-window.shade #equalizer-shade:active",
|
||||
],
|
||||
EQ_CLOSE_BUTTON: ["#equalizer-window.selected #equalizer-close"],
|
||||
EQ_CLOSE_BUTTON_ACTIVE: ["#equalizer-window #equalizer-close:active"],
|
||||
EQ_CLOSE_BUTTON: [
|
||||
"#equalizer-window.selected #eq-buttons.clicked #equalizer-close",
|
||||
],
|
||||
EQ_CLOSE_BUTTON_ACTIVE: [
|
||||
"#equalizer-window.selected #eq-buttons.clicked #equalizer-close:active",
|
||||
],
|
||||
EQ_SHADE_CLOSE_BUTTON: [
|
||||
"#equalizer-window.shade.selected #eq-buttons.clicked #equalizer-close",
|
||||
],
|
||||
EQ_SHADE_CLOSE_BUTTON_ACTIVE: [
|
||||
"#equalizer-window.shade.selected #eq-buttons.clicked #equalizer-close:active",
|
||||
],
|
||||
MAIN_POSITION_SLIDER_BACKGROUND: ["#position"],
|
||||
MAIN_POSITION_SLIDER_THUMB: [
|
||||
"#position::-webkit-slider-thumb",
|
||||
|
|
|
|||
|
|
@ -418,8 +418,8 @@ const sprites: SpriteMap = {
|
|||
},
|
||||
{ name: "EQ_MAXIMIZE_BUTTON_ACTIVE", x: 1, y: 38, width: 9, height: 9 },
|
||||
{ name: "EQ_MINIMIZE_BUTTON_ACTIVE", x: 1, y: 47, width: 9, height: 9 },
|
||||
{ name: "EQ_CLOSE_BUTTON", x: 11, y: 38, width: 9, height: 9 },
|
||||
{ name: "EQ_CLOSE_BUTTON_ACTIVE", x: 11, y: 47, width: 9, height: 9 },
|
||||
{ name: "EQ_SHADE_CLOSE_BUTTON", x: 11, y: 38, width: 9, height: 9 },
|
||||
{ name: "EQ_SHADE_CLOSE_BUTTON_ACTIVE", x: 11, y: 47, width: 9, height: 9 },
|
||||
],
|
||||
EQMAIN: [
|
||||
{ name: "EQ_WINDOW_BACKGROUND", x: 0, y: 0, width: 275, height: 116 },
|
||||
|
|
@ -428,6 +428,21 @@ const sprites: SpriteMap = {
|
|||
{ name: "EQ_SLIDER_BACKGROUND", x: 13, y: 164, width: 209, height: 129 },
|
||||
{ name: "EQ_SLIDER_THUMB", x: 0, y: 164, width: 11, height: 11 },
|
||||
{ name: "EQ_SLIDER_THUMB_SELECTED", x: 0, y: 176, width: 11, height: 11 },
|
||||
{ name: "EQ_CLOSE_BUTTON", x: 0, y: 116, width: 9, height: 9 },
|
||||
{ name: "EQ_CLOSE_BUTTON_ACTIVE", x: 0, y: 125, width: 9, height: 9 },
|
||||
// This is technically not a sprite, it's just part of the background.
|
||||
// However, we extract it to use it as a fallback for
|
||||
// `EQ_MAXIMIZE_BUTTON_ACTIVE`. Without this, skins that don't implement
|
||||
// `eq_ex.bmp` would show the default skin's `EQ_MAXIMIZE_BUTTON_ACTIVE`
|
||||
// instead of showing no sprite aka, just showing through to this portion of
|
||||
// the title bar image.
|
||||
{
|
||||
name: "EQ_MAXIMIZE_BUTTON_ACTIVE_FALLBACK",
|
||||
x: 254,
|
||||
y: 152,
|
||||
width: 9,
|
||||
height: 9,
|
||||
},
|
||||
{ name: "EQ_ON_BUTTON", x: 10, y: 119, width: 26, height: 12 },
|
||||
{ name: "EQ_ON_BUTTON_DEPRESSED", x: 128, y: 119, width: 26, height: 12 },
|
||||
{ name: "EQ_ON_BUTTON_SELECTED", x: 69, y: 119, width: 26, height: 12 },
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue