1
0
Fork 0

Move makeTile to Tile.ts

This commit is contained in:
Kitteh 2021-05-09 14:21:40 +01:00
parent 66217ccadf
commit ba3df3af78
2 changed files with 69 additions and 63 deletions

44
src/elements/Tile.ts Normal file
View file

@ -0,0 +1,44 @@
import { makeElement } from "../htmlUtils";
type TileParams = {
condition: Boolean;
title: string;
description: string;
icon: string;
iconText: string;
onclick: () => void;
}
export function Tile(params: TileParams): HTMLElement {
if (!params.condition) return;
return makeElement({
tag: "a",
class: "uk-link-heading",
onclick: params.onclick,
children: makeElement({
tag: "div",
class: ["uk-padding-small", "uk-background-primary"],
children: [
makeElement({
tag: "p",
class: "uk-h4",
text: params.title,
children: makeElement({
tag: "span",
class: ["uk-icon", "uk-margin-small-left"],
attributes: {
"uk-icon": `icon: ${params.icon}`,
"role": "img",
"aria-label": params.iconText
}
})
}),
makeElement({
tag: "span",
class: "uk-text-muted",
text: params.description
})
]
})
});
}

View file

@ -4,6 +4,7 @@ import { makeElement } from "../../htmlUtils";
import { pageState } from "../../globalPageState"; import { pageState } from "../../globalPageState";
import i18next from 'i18next'; import i18next from 'i18next';
import { getTransitKey } from "../../api/transit/getTransitKey"; import { getTransitKey } from "../../api/transit/getTransitKey";
import { Tile } from "../../elements/Tile";
type TileParams = { type TileParams = {
condition: Boolean; condition: Boolean;
@ -23,40 +24,6 @@ export class TransitViewSecretPage extends Page {
changePage("TRANSIT_VIEW"); changePage("TRANSIT_VIEW");
} }
makeTile(params: TileParams): HTMLElement {
if (!params.condition) return;
return makeElement({
tag: "a",
class: "uk-link-heading",
onclick: params.onclick,
children: makeElement({
tag: "div",
class: ["uk-padding-small", "uk-background-primary"],
children: [
makeElement({
tag: "p",
class: "uk-h4",
text: params.title,
children: makeElement({
tag: "span",
class: ["uk-icon", "uk-margin-small-left"],
attributes: {
"uk-icon": `icon: ${params.icon}`,
"role": "img",
"aria-label": params.iconText
}
})
}),
makeElement({
tag: "span",
class: "uk-text-muted",
text: params.description
})
]
})
});
}
async render(): Promise<void> { async render(): Promise<void> {
setTitleElement(pageState); setTitleElement(pageState);
@ -64,17 +31,13 @@ export class TransitViewSecretPage extends Page {
setPageContent(makeElement({ setPageContent(makeElement({
tag: "div", tag: "div",
class: ["uk-grid", "uk-child-width-expand@s"], class: ["uk-list", "uk-width-1-1@s"],
attributes: { "uk-grid": "" },
children: makeElement({
tag: "div",
class: ["uk-list", "uk-width-2-3@s"],
attributes: { "uk-grid": "" }, attributes: { "uk-grid": "" },
children: [ children: [
makeElement({ makeElement({
tag: "div", tag: "div",
children: [ children: [
this.makeTile({ Tile({
condition: transitKey.supports_encryption, condition: transitKey.supports_encryption,
title: i18next.t("transit_view_encrypt_text"), title: i18next.t("transit_view_encrypt_text"),
description: i18next.t("transit_view_encrypt_description"), description: i18next.t("transit_view_encrypt_description"),
@ -82,7 +45,7 @@ export class TransitViewSecretPage extends Page {
iconText: i18next.t("transit_view_encrypt_icon_text"), iconText: i18next.t("transit_view_encrypt_icon_text"),
onclick: () => { changePage("TRANSIT_ENCRYPT"); } onclick: () => { changePage("TRANSIT_ENCRYPT"); }
}), }),
this.makeTile({ Tile({
condition: transitKey.supports_decryption, condition: transitKey.supports_decryption,
title: i18next.t("transit_view_decrypt_text"), title: i18next.t("transit_view_decrypt_text"),
description: i18next.t("transit_view_decrypt_description"), description: i18next.t("transit_view_decrypt_description"),
@ -93,7 +56,6 @@ export class TransitViewSecretPage extends Page {
] ]
}), }),
] ]
})
})); }));
} }