2021-01-29 03:23:53 +01:00
|
|
|
import Combine from "../Base/Combine";
|
|
|
|
import Translations from "../i18n/Translations";
|
2021-06-12 02:58:32 +02:00
|
|
|
import BaseUIElement from "../BaseUIElement";
|
2021-06-18 01:25:13 +02:00
|
|
|
import {VariableUiElement} from "../Base/VariableUIElement";
|
2022-08-30 20:29:49 +02:00
|
|
|
import {Store} from "../../Logic/UIEventSource";
|
2021-09-29 23:56:59 +02:00
|
|
|
import {LicenseInfo} from "../../Logic/ImageProviders/LicenseInfo";
|
2022-05-06 12:41:24 +02:00
|
|
|
import {FixedUiElement} from "../Base/FixedUiElement";
|
2022-08-30 20:29:49 +02:00
|
|
|
import Link from "../Base/Link";
|
2021-01-29 03:23:53 +01:00
|
|
|
|
2022-08-30 20:29:49 +02:00
|
|
|
/**
|
|
|
|
* Small box in the bottom left of an image, e.g. the image in a popup
|
|
|
|
*/
|
2021-06-18 01:25:13 +02:00
|
|
|
export default class Attribution extends VariableUiElement {
|
2021-01-29 03:23:53 +01:00
|
|
|
|
2022-06-05 02:24:14 +02:00
|
|
|
constructor(license: Store<LicenseInfo>, icon: BaseUIElement, date?: Date) {
|
2021-06-18 01:25:13 +02:00
|
|
|
if (license === undefined) {
|
|
|
|
throw "No license source given in the attribution element"
|
|
|
|
}
|
|
|
|
super(
|
2021-09-09 00:05:51 +02:00
|
|
|
license.map((license: LicenseInfo) => {
|
2021-11-07 16:34:51 +01:00
|
|
|
if (license === undefined) {
|
2021-09-26 17:36:39 +02:00
|
|
|
return undefined
|
2021-06-18 01:25:13 +02:00
|
|
|
}
|
2021-11-07 16:34:51 +01:00
|
|
|
|
2022-08-30 20:29:49 +02:00
|
|
|
let title = undefined;
|
|
|
|
if (license?.title) {
|
|
|
|
title = Translations.W(license?.title).SetClass("block")
|
|
|
|
if (license.informationLocation) {
|
|
|
|
title = new Link(title, license.informationLocation.href, true)
|
|
|
|
}
|
|
|
|
}
|
2021-06-18 01:25:13 +02:00
|
|
|
return new Combine([
|
|
|
|
icon?.SetClass("block left").SetStyle("height: 2em; width: 2em; padding-right: 0.5em;"),
|
|
|
|
|
|
|
|
new Combine([
|
2022-08-30 20:29:49 +02:00
|
|
|
title,
|
2021-10-07 22:06:47 +02:00
|
|
|
Translations.W(license?.artist ?? "").SetClass("block font-bold"),
|
2022-06-13 00:51:53 +02:00
|
|
|
Translations.W(license?.license ?? license?.licenseShortName),
|
2022-05-06 12:41:24 +02:00
|
|
|
date === undefined ? undefined : new FixedUiElement(date.toLocaleDateString())
|
2021-06-18 01:25:13 +02:00
|
|
|
]).SetClass("flex flex-col")
|
2021-10-07 22:06:47 +02:00
|
|
|
]).SetClass("flex flex-row bg-black text-white text-sm absolute bottom-0 left-0 p-0.5 pl-5 pr-3 rounded-lg no-images")
|
2021-06-18 01:25:13 +02:00
|
|
|
|
|
|
|
}));
|
2021-01-29 03:23:53 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
}
|