// Copyright (c) 2020 Tulir Asokan
//
// This Source Code Form is subject to the terms of the Mozilla Public
// License, v. 2.0. If a copy of the MPL was not distributed with this
// file, You can obtain one at http://mozilla.org/MPL/2.0/.
import { html } from "../lib/htm/preact.js"

export const Spinner = ({ size = 40, noCenter = false, noMargin = false, green = false }) => {
	let margin = 0
	if (!isNaN(+size)) {
		size = +size
		margin = noMargin ? 0 : `${Math.round(size / 6)}px`
		size = `${size}px`
	}
	const noInnerMargin = !noCenter || !margin
	const comp = html`
        <div style="width: ${size}; height: ${size}; margin: ${noInnerMargin ? 0 : margin} 0;"
             class="sk-chase ${green && "green"}">
            <div class="sk-chase-dot" />
            <div class="sk-chase-dot" />
            <div class="sk-chase-dot" />
            <div class="sk-chase-dot" />
            <div class="sk-chase-dot" />
            <div class="sk-chase-dot" />
        </div>
    `
	if (!noCenter) {
		return html`<div style="margin: ${margin} 0;" class="sk-center-wrapper">${comp}</div>`
	}
	return comp
}