summaryrefslogtreecommitdiffstats
path: root/sticker.pinapelz.moe/src/spinner.js
blob: e89dd02bdd80afea846d028241105a19d5ca37e4 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
// maunium-stickerpicker - A fast and simple Matrix sticker picker widget.
// Copyright (C) 2020 Tulir Asokan
//
// This program is free software: you can redistribute it and/or modify
// it under the terms of the GNU Affero General Public License as published by
// the Free Software Foundation, either version 3 of the License, or
// (at your option) any later version.
//
// This program is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
// GNU Affero General Public License for more details.
//
// You should have received a copy of the GNU Affero General Public License
// along with this program.  If not, see <https://www.gnu.org/licenses/>.
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
}
send patches to the email below
yukais@pinapelz.com
include the subject [PATCH repo_name]
pinapelz.com
homepage