refactor: btn color theme

This commit is contained in:
Xmader 2021-05-19 02:10:28 -04:00
parent 5d1639dddf
commit 4e92c06791
No known key found for this signature in database
GPG key ID: A20B97FB9EB730E4
3 changed files with 14 additions and 6 deletions

View file

@ -52,15 +52,19 @@ button {
/* fix `View in LibreScore` button text overflow */
button:last-of-type {
width: unset !important;
color: #2e68c0;
background: #e1effe;
}
button:hover {
background: #1a4f9f;
}
button:last-of-type:hover {
/* light theme btn */
button.light {
color: #2e68c0;
background: #e1effe;
}
button.light:hover {
background: #c3ddfd;
}

View file

@ -25,16 +25,17 @@ const getBtnContainer = (): HTMLDivElement => {
return btnParent
}
const buildDownloadBtn = (icon: ICON) => {
const buildDownloadBtn = (icon: ICON, lightTheme = false) => {
const btn = document.createElement('button')
btn.type = 'button'
if (lightTheme) btn.className = 'light'
// build icon svg element
const svg = document.createElementNS('http://www.w3.org/2000/svg', 'svg')
svg.setAttribute('viewBox', '0 0 24 24')
const svgPath = document.createElementNS('http://www.w3.org/2000/svg', 'path')
svgPath.setAttribute('d', icon)
svgPath.setAttribute('fill', icon === ICON.DOWNLOAD ? '#fff' : '#2e68c0')
svgPath.setAttribute('fill', lightTheme ? '#2e68c0' : '#fff')
svg.append(svgPath)
const textNode = document.createElement('span')
@ -63,6 +64,7 @@ interface BtnOptions {
readonly disabled?: boolean;
readonly tooltip?: string;
readonly icon?: ICON;
readonly lightTheme?: boolean;
}
export enum BtnListMode {
@ -76,7 +78,7 @@ export class BtnList {
constructor (private getBtnParent: () => HTMLDivElement = getBtnContainer) { }
add (options: BtnOptions): BtnElement {
const btnTpl = buildDownloadBtn(options.icon ?? ICON.DOWNLOAD)
const btnTpl = buildDownloadBtn(options.icon ?? ICON.DOWNLOAD, options.lightTheme)
const setText = (btn: BtnElement) => {
const textNode = btn.querySelector('span')
return (str: string): void => {

View file

@ -137,8 +137,10 @@ const main = (): void => {
action: BtnAction.openUrl(() => getLibreScoreLink(scoreinfo)),
tooltip: 'BETA',
icon: ICON.LIBRESCORE,
lightTheme: true,
})
// eslint-disable-next-line @typescript-eslint/no-floating-promises
btnList.commit(BtnListMode.InPage)
}