"use strict"; class LanguagesSublistManager extends SublistManager { static get _ROW_TEMPLATE () { return [ new SublistCellTemplate({ name: "Name", css: "bold ve-col-8 pl-0", colStyle: "", }), new SublistCellTemplate({ name: "Type", css: "ve-col-2 ve-text-center", colStyle: "text-center", }), new SublistCellTemplate({ name: "Script", css: "ve-col-2 ve-text-center pr-0", colStyle: "text-center", }), ]; } pGetSublistItem (it, hash) { const cellsText = [ it.name, (it.type || "\u2014").uppercaseFirst(), (it.script || "\u2014").toTitleCase(), ]; const $ele = $(`
${this.constructor._getRowCellsHtml({values: cellsText})}
`) .contextmenu(evt => this._handleSublistItemContextMenu(evt, listItem)) .click(evt => this._listSub.doSelect(listItem, evt)); const listItem = new ListItem( hash, $ele, it.name, { hash, type: it.type || "", script: it.script || "", }, { entity: it, mdRow: [...cellsText], }, ); return listItem; } } class LanguagesPage extends ListPage { constructor () { const pageFilter = new PageFilterLanguages(); super({ dataSource: DataUtil.language.loadJSON.bind(DataUtil.language), pFnGetFluff: Renderer.language.pGetFluff.bind(Renderer.language), pageFilter, dataProps: ["language"], isMarkdownPopout: true, }); } getListItem (it, anI, isExcluded) { this._pageFilter.mutateAndAddToFilters(it, isExcluded); const eleLi = document.createElement("div"); eleLi.className = `lst__row ve-flex-col ${isExcluded ? "lst__row--blocklisted" : ""}`; const source = Parser.sourceJsonToAbv(it.source); const hash = UrlUtil.autoEncodeHash(it); eleLi.innerHTML = ` ${it.name} ${(it.type || "\u2014").uppercaseFirst()} ${(it.script || "\u2014").toTitleCase()} ${source} `; const listItem = new ListItem( anI, eleLi, it.name, { hash, source, dialects: it.dialects || [], type: it.type || "", script: it.script || "", }, { isExcluded, }, ); eleLi.addEventListener("click", (evt) => this._list.doSelect(listItem, evt)); eleLi.addEventListener("contextmenu", (evt) => this._openContextMenu(evt, this._list, listItem)); return listItem; } _renderStats_doBuildStatsTab ({ent}) { this._$pgContent.empty().append(RenderLanguages.$getRenderedLanguage(ent)); } _renderStats_getTabMetasAdditional ({ent}) { return [ new Renderer.utils.TabButton({ label: "Fonts", fnPopulate: () => { this._$pgContent.empty().append(Renderer.utils.getBorderTr()); this._$pgContent.append(Renderer.utils.getNameTr(ent)); const $td = $(``); $$`${$td}`.appendTo(this._$pgContent); this._$pgContent.append(Renderer.utils.getBorderTr()); const allFonts = [...ent.fonts || [], ...ent._fonts || []]; if (!allFonts || !allFonts.length) { $td.append("No fonts available."); return; } const $styleFont = $(`