diff --git a/main.js b/main.js
index af6248b..d3fe999 100644
--- a/main.js
+++ b/main.js
@@ -173,20 +173,37 @@
}
toDiv(altName = null, altDesc = null) {
- let div = document.createElement('div')
let desc = altDesc ?? this.desc
- desc = desc ? "
" +
- "

" +
- "
" : ""
- div.innerHTML = "" + "" + (this.content ?? "") + "
" +
- desc
- return div
+ let descTooltip = desc ? Tag.div({
+ classes: 'desc-icon-container',
+ title: desc,
+ children: [
+ Tag.img({
+ classes: 'desc-icon',
+ src: ''
+ })
+ ]
+ }) : ""
+
+ return Tag.div({
+ children: [
+ Tag.make("label", {
+ _for: '',
+ textContent: altName ?? this.name ?? ""
+ }),
+ Tag.div({
+ innerHTML: this.content ?? "",
+ }),
+ descTooltip
+ ]
+ })
}
}
function createFrom(rows, classList, data) {
- let container = document.createElement('div')
- container.classList.add(...classList.split(" "))
+ let container = Tag.div({
+ classes: classList
+ })
for (const options of data) {
let div
if (options.index != null) {
@@ -504,11 +521,13 @@
let input = document.querySelector(`input[name="${inputName}\[\]"]`)
fileListContainer ??= input.parentElement.parentElement.querySelector(".file-list-container")
- let fileContainer = document.createElement("div")
- fileContainer.classList.add("file-container")
+ let fileContainer = Tag.div({
+ classes: "file-container"
+ })
- const displayedFile = document.createElement(type ?? "a")
- displayedFile.classList.add("preview-small")
+ const displayedFile = Tag.make(type ?? "a", {
+ classes: "preview-small"
+ })
if (type == "img") {
displayedFile.src = preview
@@ -528,8 +547,9 @@
displayedFile.textContent = "Файл"
}
- let fileButtonsContainer = document.createElement("div")
- fileButtonsContainer.classList.add("file-buttons-container")
+ let fileButtonsContainer = Tag.div({
+ classes: "file-buttons-container"
+ })
fileButtonsContainer.append(makeDownloadLink(/[^/]*$/.exec(new URL(file).pathname)[0], file))
@@ -582,7 +602,7 @@
break
}
}
- let el = document.createElement(res)
+ let el = Tag.make(res)
if (res == "audio") {
el.setAttribute("controls", "")
}
@@ -639,8 +659,9 @@
fileListContainer = this.parentElement.parentElement.querySelector(".file-list-container")
}
- let fileContainer = document.createElement("div")
- fileContainer.classList.add("file-container", "file-container-new")
+ let fileContainer = Tag.div({
+ classes: "file-container file-container-new"
+ })
const displayedFile = getHtmlElementByFileType(file)
displayedFile.classList.add("preview")
@@ -651,8 +672,9 @@
dialog.showModal()
})
- let fileButtonsContainer = document.createElement("div")
- fileButtonsContainer.classList.add("file-buttons-container")
+ let fileButtonsContainer = Tag.div({
+ classes: "file-buttons-container"
+ })
let downloadLink = makeDownloadLink(file.name)
fileButtonsContainer.append(downloadLink)
@@ -1131,17 +1153,17 @@
}
function createMenuFromLinks(links, blanks = []) {
- let menu = document.createElement("menu")
+ let menu = Tag.make("menu")
for (const [label, href] of Object.entries(links)) {
- let menuItem = document.createElement("li")
+ let menuItem = Tag.make("li")
let link = Tag.a({
href: href,
innerText: label
})
if (blanks.includes(label)) {
- link.setAttribute("target", "_blank")
+ link.target = "_blank"
}
menuItem.append(link)
@@ -1155,8 +1177,9 @@
let competition = getCompetition()
if (!competition) return
- let menuContainer = document.createElement("nav")
- menuContainer.classList.add("sticky-menu")
+ let menuContainer = Tag.make("nav", {
+ classes: "sticky-menu"
+ })
let mainLinksFormatted = {}
for (const [label, href] of Object.entries(links)) {
@@ -1242,7 +1265,7 @@
}
function addClearBoth() {
- let clearEl = document.createElement("div")
+ let clearEl = Tag.div()
clearEl.style.clear = "both"
document.body.append(clearEl)
}
@@ -1339,8 +1362,9 @@
{ index: 8, name: "Название" }
])
- let copyLink = document.createElement("div")
- copyLink.innerHTML = new Property(rows[2]).desc
+ let copyLink = Tag.div({
+ innerHTML: new Property(rows[2]).desc
+ })
headerContainer.append(copyLink)
return headerContainer
@@ -1358,8 +1382,9 @@
let bottomButtonsContainer = topButtonsContainer.cloneNode(true)
document.querySelectorAll("#props tr:is(:first-child, :last-child) th").forEach((el, index) => {
- let rowContentWrapper = document.createElement("div")
- rowContentWrapper.classList.add("buttons-row__content-wrapper")
+ let rowContentWrapper = Tag.div({
+ classes: "buttons-row__content-wrapper"
+ })
while ([...el.children].length > 0) {
let child = el.firstChild
rowContentWrapper.append(child)
@@ -1430,18 +1455,17 @@
/* LEGEND DESC */
- let legendDescContainer = document.createElement("div")
- legendDescContainer.classList.add("legend-container__desc")
-
- let legendDescHeader = document.createElement("div")
- legendDescHeader.classList.add("legend-container__desc-header")
-
-
const LEGEND_RU_LABEL = "Русский"
const LEGEND_EN_LABEL = "Английский"
- let legendLang = document.createElement("div")
- legendLang.classList.add("legend-desc__lang")
- legendLang.textContent = LEGEND_RU_LABEL
+
+ let legendDescHeader = Tag.div({
+ classes: "legend-container__desc-header"
+ })
+
+ let legendLang = Tag.div({
+ classes: "legend-desc__lang",
+ textContent: LEGEND_RU_LABEL
+ })
legendDescHeader.append(legendLang)
let legendEnSwitchContainer = createFrom(rows, "legend-switch-container", [
@@ -1525,12 +1549,18 @@
]
})
- legendDescContainer.append(legendDescHeader)
- legendDescContainer.append(legendRuDescContainer)
- legendDescContainer.append(legendRuHiddenDescContainer)
- legendDescContainer.append(legendEnDescContainer)
- legendDescContainer.append(legendEnHiddenDescContainer)
- legendDescContainer.append(hider)
+ let legendDescContainer = Tag.div({
+ classes: "legend-container__desc",
+ children: [
+ legendDescHeader,
+ legendRuDescContainer,
+ legendRuHiddenDescContainer,
+ legendEnDescContainer,
+ legendEnHiddenDescContainer,
+ hider
+ ]
+ })
+
legendContainer.append(legendDescContainer)
return legendContainer
@@ -1542,8 +1572,9 @@
}
function makeLegendFiles(rows) {
- let legendFilesContainer = document.createElement("div")
- legendFilesContainer.classList.add("legend-container__files")
+ let legendFilesContainer = Tag.div({
+ classes: "legend-container__files"
+ })
let imagesForLegendContainer = createFrom(rows, "files-container", [
{ index: 23, name: "Фото в легенде" }
@@ -1573,8 +1604,9 @@
}
function makeAdminFiles(rows) {
- let adminFilesContainer = document.createElement('div')
- adminFilesContainer.classList.add('admin-files-container')
+ let adminFilesContainer = Tag.div({
+ classes: 'admin-files-container'
+ })
let imagesForAdminContainer = createFrom(rows, "files-container admin-photo-container", [
{ index: 31, name: "Фото в админке" }