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: "Фото в админке" }