2020-07-29 16:46:45 +02:00
|
|
|
import Translations from "../i18n/Translations";
|
|
|
|
import Combine from "./Combine";
|
2021-06-10 01:36:20 +02:00
|
|
|
import BaseUIElement from "../BaseUIElement";
|
|
|
|
import Link from "./Link";
|
|
|
|
import Img from "./Img";
|
2022-06-05 02:24:14 +02:00
|
|
|
import {Store, UIEventSource} from "../../Logic/UIEventSource";
|
2021-06-12 02:58:32 +02:00
|
|
|
import {UIElement} from "../UIElement";
|
2022-02-16 01:28:23 +01:00
|
|
|
import {VariableUiElement} from "./VariableUIElement";
|
|
|
|
import Lazy from "./Lazy";
|
|
|
|
import Loading from "./Loading";
|
2020-07-29 16:46:45 +02:00
|
|
|
|
|
|
|
|
2021-06-12 02:58:32 +02:00
|
|
|
export class SubtleButton extends UIElement {
|
2021-12-21 19:09:24 +01:00
|
|
|
private readonly imageUrl: string | BaseUIElement;
|
|
|
|
private readonly message: string | BaseUIElement;
|
2022-06-05 02:24:14 +02:00
|
|
|
private readonly options: { url?: string | Store<string>; newTab?: boolean ; imgSize?: string};
|
2020-07-29 16:46:45 +02:00
|
|
|
|
2021-05-30 00:17:31 +02:00
|
|
|
|
2022-04-24 01:32:19 +02:00
|
|
|
constructor(imageUrl: string | BaseUIElement, message: string | BaseUIElement, options: {
|
2022-06-05 02:24:14 +02:00
|
|
|
url?: string | Store<string>,
|
2022-04-24 01:32:19 +02:00
|
|
|
newTab?: boolean,
|
|
|
|
imgSize?: "h-11 w-11" | string
|
|
|
|
} = undefined) {
|
2021-06-12 02:58:32 +02:00
|
|
|
super();
|
2021-12-21 19:09:24 +01:00
|
|
|
this.imageUrl = imageUrl;
|
|
|
|
this.message = message;
|
2022-04-24 01:32:19 +02:00
|
|
|
this.options = options;
|
2021-05-30 00:17:31 +02:00
|
|
|
}
|
|
|
|
|
2021-12-21 19:09:24 +01:00
|
|
|
protected InnerRender(): string | BaseUIElement {
|
2022-02-07 01:57:49 +01:00
|
|
|
const classes = "block flex p-3 my-2 bg-subtle rounded-lg hover:shadow-xl hover:bg-unsubtle transition-colors transition-shadow link-no-underline";
|
2021-12-21 19:09:24 +01:00
|
|
|
const message = Translations.W(this.message);
|
2021-01-18 19:36:19 +01:00
|
|
|
let img;
|
2021-12-21 19:09:24 +01:00
|
|
|
if ((this.imageUrl ?? "") === "") {
|
2021-06-10 01:36:20 +02:00
|
|
|
img = undefined;
|
2021-12-21 19:09:24 +01:00
|
|
|
} else if (typeof (this.imageUrl) === "string") {
|
|
|
|
img = new Img(this.imageUrl)
|
2020-09-15 02:29:31 +02:00
|
|
|
} else {
|
2021-12-21 19:09:24 +01:00
|
|
|
img = this.imageUrl;
|
2020-09-15 02:29:31 +02:00
|
|
|
}
|
2022-04-24 01:32:19 +02:00
|
|
|
const image = new Combine([img?.SetClass("block flex items-center justify-center "+(this.options?.imgSize ?? "h-11 w-11")+" flex-shrink0 mr-4")])
|
2021-01-25 03:12:09 +01:00
|
|
|
.SetClass("flex-shrink-0");
|
2021-06-12 02:58:32 +02:00
|
|
|
|
2022-02-07 01:57:49 +01:00
|
|
|
message?.SetClass("block overflow-ellipsis no-images")
|
|
|
|
|
|
|
|
const button = new Combine([
|
|
|
|
image,
|
|
|
|
message
|
|
|
|
]).SetClass("flex group w-full")
|
|
|
|
|
2022-04-24 01:32:19 +02:00
|
|
|
if (this.options?.url == undefined) {
|
2021-12-21 19:09:24 +01:00
|
|
|
this.SetClass(classes)
|
2022-02-07 01:57:49 +01:00
|
|
|
return button
|
2020-07-29 19:02:36 +02:00
|
|
|
}
|
2021-05-30 00:17:31 +02:00
|
|
|
|
2021-06-12 02:58:32 +02:00
|
|
|
|
|
|
|
return new Link(
|
2022-02-07 01:57:49 +01:00
|
|
|
button,
|
2022-04-24 01:32:19 +02:00
|
|
|
this.options.url,
|
|
|
|
this.options.newTab ?? false
|
2021-12-21 19:09:24 +01:00
|
|
|
).SetClass(classes)
|
2021-06-12 02:58:32 +02:00
|
|
|
|
2020-07-29 16:46:45 +02:00
|
|
|
}
|
|
|
|
|
2022-02-16 01:28:23 +01:00
|
|
|
public OnClickWithLoading(
|
|
|
|
loadingText: BaseUIElement | string,
|
|
|
|
action: () => Promise<void> ) : BaseUIElement{
|
|
|
|
const state = new UIEventSource<"idle" | "running">("idle")
|
|
|
|
const button = this;
|
|
|
|
|
|
|
|
button.onClick(async() => {
|
|
|
|
state.setData("running")
|
|
|
|
try{
|
|
|
|
await action()
|
|
|
|
}catch(e){
|
|
|
|
console.error(e)
|
|
|
|
}finally {
|
|
|
|
state.setData("idle")
|
|
|
|
}
|
|
|
|
|
|
|
|
})
|
|
|
|
const loading = new Lazy(() => new Loading(loadingText) )
|
|
|
|
return new VariableUiElement(state.map(st => {
|
|
|
|
console.log("State is: ", st)
|
|
|
|
if(st === "idle"){
|
|
|
|
return button
|
|
|
|
}
|
|
|
|
return loading
|
|
|
|
}))
|
|
|
|
}
|
2020-07-29 16:46:45 +02:00
|
|
|
|
|
|
|
}
|