1
Fork 0
mirror of https://github.com/Steffo99/bluelib.git synced 2025-01-14 22:29:46 +00:00
bluelib/src/components/Bluelib.tsx

95 lines
3.5 KiB
TypeScript
Raw Normal View History

2021-08-16 17:10:23 +00:00
import * as React from "react"
import * as ReactDOM from "react-dom"
import * as Types from "../types"
import * as Colors from "../utils/Colors"
import mergeClassNames from "classnames"
2021-08-16 17:10:23 +00:00
import {BaseElement} from "../abstract/BaseElement"
import PaperTheme from "../bluelib/src/targets/paper.module.css"
import RoyalBlueTheme from "../bluelib/src/targets/royalblue.module.css"
import HackerTheme from "../bluelib/src/targets/hacker.module.css"
import SophonTheme from "../bluelib/src/targets/sophon.module.css"
const BuiltinThemes = {
"paper": PaperTheme,
"royalblue": RoyalBlueTheme,
"hacker": HackerTheme,
"sophon": SophonTheme,
}
export interface BluelibProps {
2021-08-16 17:10:23 +00:00
theme: "paper" | "royalblue" | "hacker" | "sophon",
backgroundColor?: Colors.CustomColor,
foregroundColor?: Colors.CustomColor,
accentColor?: Colors.CustomColor,
linkColor?: Colors.CustomColor,
brokenColor?: Colors.CustomColor,
visitedColor?: Colors.CustomColor,
downloadColor?: Colors.CustomColor,
redColor?: Colors.CustomColor,
orangeColor?: Colors.CustomColor,
yellowColor?: Colors.CustomColor,
limeColor?: Colors.CustomColor,
cyanColor?: Colors.CustomColor,
blueColor?: Colors.CustomColor,
magentaColor?: Colors.CustomColor,
grayColor?: Colors.CustomColor,
polarity?: number,
[props: string]: any,
2021-08-16 17:10:23 +00:00
}
export function Bluelib({
theme,
backgroundColor,
foregroundColor,
accentColor,
linkColor,
brokenColor,
visitedColor,
downloadColor,
redColor,
orangeColor,
yellowColor,
limeColor,
cyanColor,
blueColor,
magentaColor,
grayColor,
polarity,
...props
}: BluelibProps): JSX.Element {
props.className = mergeClassNames(props.className, BuiltinThemes[theme]["bluelib"])
console.debug(props.style)
2021-08-16 17:10:23 +00:00
if(backgroundColor) props.style = {...props.style, ...Colors.colorToBluelibStyle("background", backgroundColor)}
if(foregroundColor) props.style = {...props.style, ...Colors.colorToBluelibStyle("foreground", foregroundColor)}
if(accentColor) props.style = {...props.style, ...Colors.colorToBluelibStyle("accent", accentColor)}
if(linkColor) props.style = {...props.style, ...Colors.colorToBluelibStyle("link", linkColor)}
if(brokenColor) props.style = {...props.style, ...Colors.colorToBluelibStyle("broken", brokenColor)}
if(visitedColor) props.style = {...props.style, ...Colors.colorToBluelibStyle("visited", visitedColor)}
if(downloadColor) props.style = {...props.style, ...Colors.colorToBluelibStyle("download", downloadColor)}
if(redColor) props.style = {...props.style, ...Colors.colorToBluelibStyle("red", redColor)}
if(orangeColor) props.style = {...props.style, ...Colors.colorToBluelibStyle("orange", orangeColor)}
if(yellowColor) props.style = {...props.style, ...Colors.colorToBluelibStyle("yellow", yellowColor)}
if(limeColor) props.style = {...props.style, ...Colors.colorToBluelibStyle("lime", limeColor)}
if(cyanColor) props.style = {...props.style, ...Colors.colorToBluelibStyle("cyan", cyanColor)}
if(blueColor) props.style = {...props.style, ...Colors.colorToBluelibStyle("blue", blueColor)}
if(magentaColor) props.style = {...props.style, ...Colors.colorToBluelibStyle("magenta", magentaColor)}
if(grayColor) props.style = {...props.style, ...Colors.colorToBluelibStyle("gray", grayColor)}
if(polarity) props.style["--bluelib-polarity"] = polarity
return (
<BaseElement
kind={"div"}
bluelibClassNames={"bluelib"}
{...props}
/>
)
}