import { Component, CSSProperties, ReactNode, useState, useEffect } from "react";

import SearchIcon from '@material-ui/icons/Search';
import CheckBoxOutlineBlankIcon from '@material-ui/icons/CheckBoxOutlineBlank';
import CheckBoxIcon from '@material-ui/icons/CheckBox';
import EditOutlinedIcon from '@material-ui/icons/EditOutlined';

export function Vierkant(props: {
	href?: string;
	width?: string;
	height?: string;
	style?: CSSProperties;
	children?: ReactNode;
	className?: string;
	id?: string;
	fullwidth?: boolean;
	onclick?: () => void;
}) {
	return <a style={{
		padding: 24,
		backgroundColor: "var(--background)",
		borderRadius: 8,
		color: "var(--text)",
		margin: 6, // geen margin collapse = 12px marge
		display: "inline-block",
		position: "relative",
		boxSizing: "border-box",
		width:
			props.width ? props.width :
			props.fullwidth ? "calc(100% - 12px)" :
			undefined,
		height: props.height ? props.height : undefined,
		...props.style
	}}
	href={props.href}
	className={props.className}
	id={props.id}
	onClick={props.onclick}
	>{props.children}</a>
}

export function Button(props: {
	text?: string;
	children?: ReactNode;
	style?: CSSProperties;
	href?: string;
	onclick?: (() => void);
	id?: string;
}) {
	return <a onClick={props.onclick} href={props.href} id={props.id} style={{
		padding: props.text ? 8 : 16,
		textAlign: props.text ? "center" : "left",
		borderRadius: 8,
		backgroundColor: "var(--disk-a)",
		cursor: "pointer",
		position: "relative",
		textDecoration: "none",
		display: "block",
		userSelect: "none",
		...props.style
	}}>
	{ 
		props.text ?
			<span style={{
				fontWeight: 600,
				userSelect: "none"
			}}>{props.text}</span>
			: undefined
	}
	{ props.children }
	</a>;
}

export function IconLabelButton(props: {
	text: string;
	icon: ReactNode;
	onclick?: () => void;
	style?: CSSProperties;
	href?: string;
}) {
	return <Button onclick={props.onclick} href={props.href} style={{
		display: "inline-block",
		verticalAlign: "top",
		padding: 8,
		float: "right",
		marginLeft: 12,
		...props.style
	}}>
		{props.icon}
		<span style={{
			display: "inline-block",
			verticalAlign: "top",
			fontWeight: 500,
			marginLeft: 8,
			marginTop: 3, marginBottom: 3, marginRight: 3
		}}>{props.text}</span>
	</Button>
}

export function Input(props: {
	label?: string;
	style?: CSSProperties;
	type?: string;
	id?: string;
	min?: number;
	max?: number;
	value?: string|number;
	dark?: boolean;
	autocomplete?: string;
	autofocus?: boolean;
}) {
	return <input
	id={props.id}
	type={props.type || "text"}
	min={props.min} max={props.max}
	placeholder={props.label}
	spellCheck={false}
	defaultValue={props.value ? String(props.value) : ""}
	className={props.dark ? "dark" : "light"}
	autoComplete={props.autocomplete}
	autoFocus={props.autofocus}
	style={{
		padding: 12,
		border: 0,
		width: "calc(100% - 24px)",
		fontSize: 14,
		backgroundColor: "var(--page-background)",
		color: "var(--text-alt)",
		borderRadius: 8,
		fontFamily: "Inter",
		...props.style
	}}/>
}

export function SearchBar(props: { label?: string }) {
	return <div style={{
		marginTop: 24,
		borderRadius: 8,
		overflow: "hidden",
		width: "100%"
	}}>
		<Input label={props.label} style={{
			width: "calc(100% - 24px - 41px)",
			borderTopRightRadius: 0,
			borderBottomRightRadius: 0
		}}/>
		<div style={{
			width: 41,
			height: 41,
			backgroundColor: "var(--disk-a)",
			display: "inline-block",
			verticalAlign: "top",
			position: "relative"
		}}>
			<SearchIcon style={{
				position: "absolute",
				top: "50%", left: "50%",
				transform: "translate(-50%, -50%)"
			}}/>
		</div>
	</div>
}

export function CheckBox(props: {
	state?: boolean;
	style?: CSSProperties;
	id?: string;
	onclick?: (state: boolean) => void;
}) {
	var [gotDefaultState, setGotDefaultState] = useState(false);
	var [on, setOn] = useState(props.state);

	useEffect(() => {
		if (gotDefaultState) return;
		setOn(props.state);
		if (typeof props.state !== "undefined") setGotDefaultState(true);
	});

	var toggle = () => {
		setOn(!on);
		props.onclick && props.onclick(!on);
	}

	return <div onClick={toggle} id={props.id} className={on ? "on" : "off"} style={{
		...props.style,
		display: "inline-block",
		cursor: "pointer"
	}}>
	{
		on ?
		<CheckBoxIcon/> :
		<CheckBoxOutlineBlankIcon/>
	}
	</div>
}

export class ColorPicker extends Component<{
	style?: CSSProperties;
}> {
	state: {
		color: string;
		dark: boolean;
	} = {
		color: "#012345",
		dark: true
	}

	render() {
		return <Button style={{
			display: "inline-block",
			verticalAlign: "top",
			padding: 6,
			float: "right",
			marginLeft: 12,
			color: this.state.dark ? "var(--text)" : "var(--text-alt)",
			borderColor: this.state.dark ? "var(--text)" : "var(--text-alt)",
			borderWidth: 2,
			borderStyle: "solid",
			backgroundColor: this.state.color,
			...this.props.style
		}}>
			<div>
				<EditOutlinedIcon/>
				<div style={{
					width: 150,
					height: 24,
					display: "inline-block",
					textAlign: "center",
					verticalAlign: "top",
					position: "relative"
				}}>
					<span style={{
						position: "absolute",
						top: "50%", left: "50%",
						transform: "translate(-50%, -50%)",
						fontWeight: 600,
						fontFeatureSettings: '"tnum", "ss01"'
					}}>{this.state.color}</span>
				</div>
			</div>
		</Button>
	}
}

export function Tuitje(props: {
	style?: CSSProperties;
	rotation?: number;
}) {
	return <svg width="36" height="12" viewBox="0 0 36 12" fill="none" xmlns="http://www.w3.org/2000/svg" style={{
		...props.style
	}}>
		<path d="M18 12C24 12 27 0 36 0L0 0C9 0 12 12 18 12Z"
			  fill={ props.style?.background as string || "var(--background)" }/>
	</svg>
}

export function Bubble(props: {
	children?: ReactNode;
	style?: CSSProperties;
	tuitjeStyle?: CSSProperties;
}) {
	return <Vierkant style={{
		position: "absolute",
		textAlign: "center",
		margin: 0,
		overflow: "visible",
		left: "50%",
		top: -24,
		transform: "translateY(-100%) translateX(-50%)",
		boxShadow: "0 8px 32px rgba(0, 0, 0, 0.3)",
		...props.style
	}}>
		{props.children}
		<Tuitje style={{
			position: "absolute",
			bottom: -12,
			transform: "translate(-50%, 0%) rotate(0deg)",
			...props.tuitjeStyle
		}}/>
	</Vierkant>
}