mapcomplete/UI/BigComponents/LicensePicker.ts

39 lines
1.6 KiB
TypeScript
Raw Normal View History

2022-09-08 21:40:48 +02:00
import { DropDown } from "../Input/DropDown"
import Translations from "../i18n/Translations"
import { UIEventSource } from "../../Logic/UIEventSource"
import { OsmConnection } from "../../Logic/Osm/OsmConnection"
import { Translation } from "../i18n/Translation"
2021-06-11 22:51:45 +02:00
export default class LicensePicker extends DropDown<string> {
private static readonly cc0 = "CC0"
private static readonly ccbysa = "CC-BY-SA 4.0"
private static readonly ccby = "CC-BY 4.0"
2022-01-26 21:40:38 +01:00
constructor(state: { osmConnection: OsmConnection }) {
2022-09-08 21:40:48 +02:00
super(
Translations.t.image.willBePublished.Clone(),
2021-06-11 22:51:45 +02:00
[
2022-09-08 21:40:48 +02:00
{ value: LicensePicker.cc0, shown: Translations.t.image.cco.Clone() },
{ value: LicensePicker.ccbysa, shown: Translations.t.image.ccbs.Clone() },
{ value: LicensePicker.ccby, shown: Translations.t.image.ccb.Clone() },
2021-06-11 22:51:45 +02:00
],
2022-09-08 21:40:48 +02:00
state?.osmConnection?.GetPreference("pictures-license") ??
new UIEventSource<string>("CC0"),
2022-04-19 23:43:28 +02:00
{
2022-09-08 21:40:48 +02:00
select_class: "w-min bg-indigo-100 p-1 rounded hover:bg-indigo-200",
2022-04-19 23:43:28 +02:00
}
2021-06-11 22:51:45 +02:00
)
2022-09-08 21:40:48 +02:00
this.SetClass("flex flex-col sm:flex-row").SetStyle("float:left")
2021-06-11 22:51:45 +02:00
}
2022-01-26 21:40:38 +01:00
public static LicenseExplanations(): Map<string, Translation> {
2022-09-08 21:40:48 +02:00
let dict = new Map<string, Translation>()
2022-01-26 21:40:38 +01:00
dict.set(LicensePicker.cc0, Translations.t.image.ccoExplanation)
dict.set(LicensePicker.ccby, Translations.t.image.ccbExplanation)
dict.set(LicensePicker.ccbysa, Translations.t.image.ccbsExplanation)
return dict
}
2022-09-08 21:40:48 +02:00
}