Split hljs into a new file; improved dev vite server system (#91)

This commit is contained in:
Thomas Miceli 2023-09-05 15:22:09 +02:00 committed by GitHub
parent ffafde2b3e
commit d4eed91130
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
6 changed files with 69 additions and 56 deletions

View file

@ -82,11 +82,14 @@ var fm = template.FuncMap{
return defaultAvatar() return defaultAvatar()
}, },
"asset": func(jsfile string) string { "asset": func(file string) string {
if dev { if dev {
return "http://localhost:16157/" + jsfile return "http://localhost:16157/" + file
} }
return config.C.ExternalUrl + "/" + manifestEntries[jsfile].File return config.C.ExternalUrl + "/" + manifestEntries[file].File
},
"dev": func() bool {
return dev
}, },
"defaultAvatar": defaultAvatar, "defaultAvatar": defaultAvatar,
"visibilityStr": func(visibility int, lowercase bool) string { "visibilityStr": func(visibility int, lowercase bool) string {

50
public/hljs.ts Normal file
View file

@ -0,0 +1,50 @@
import hljs from 'highlight.js';
import md from 'markdown-it';
document.querySelectorAll('.markdown').forEach((e: HTMLElement) => {
e.innerHTML = md({
html: true,
highlight: function (str, lang) {
if (lang && hljs.getLanguage(lang)) {
try {
return '<pre class="hljs"><code>' +
hljs.highlight(str, {language: lang, ignoreIllegals: true}).value +
'</code></pre>';
} catch (__) {
}
}
return '<pre class="hljs"><code>' + md().utils.escapeHtml(str) + '</code></pre>';
}
}).render(e.textContent);
});
document.querySelectorAll<HTMLElement>('.table-code').forEach((el) => {
const ext = el.dataset.filename?.split('.').pop() || '';
if (hljs.autoDetection(ext) && ext !== 'txt') {
el.querySelectorAll<HTMLElement>('td.line-code').forEach((ell) => {
ell.classList.add('language-' + ext);
hljs.highlightElement(ell);
});
}
el.addEventListener('click', event => {
if (event.target && (event.target as HTMLElement).matches('.line-num')) {
Array.from(document.querySelectorAll('.table-code .selected')).forEach((el) => el.classList.remove('selected'));
const nextSibling = (event.target as HTMLElement).nextSibling;
if (nextSibling instanceof HTMLElement) {
nextSibling.classList.add('selected');
}
const filename = el.dataset.filenameSlug;
const line = (event.target as HTMLElement).textContent;
const url = location.protocol + '//' + location.host + location.pathname;
const hash = '#file-' + filename + '-' + line;
window.history.pushState(null, null, url + hash);
location.hash = hash;
}
});
});

View file

@ -34,11 +34,11 @@ document.addEventListener('DOMContentLoaded', () => {
checkTheme(); checkTheme();
} }
document.getElementById('theme-btn')!.onclick = (e) => { document.getElementById('theme-btn')!.onclick = () => {
themeMenu.classList.toggle('hidden'); themeMenu.classList.toggle('hidden');
} }
document.getElementById('user-btn')?.addEventListener("click" , (e) => { document.getElementById('user-btn')?.addEventListener("click" , () => {
document.getElementById('user-menu').classList.toggle('hidden'); document.getElementById('user-menu').classList.toggle('hidden');
}) })
@ -65,53 +65,6 @@ document.addEventListener('DOMContentLoaded', () => {
}; };
} }
document.querySelectorAll('.markdown').forEach((e: HTMLElement) => {
e.innerHTML = md({
html: true,
highlight: function (str, lang) {
if (lang && hljs.getLanguage(lang)) {
try {
return '<pre class="hljs"><code>' +
hljs.highlight(str, {language: lang, ignoreIllegals: true}).value +
'</code></pre>';
} catch (__) {
}
}
return '<pre class="hljs"><code>' + md().utils.escapeHtml(str) + '</code></pre>';
}
}).render(e.textContent);
});
document.querySelectorAll<HTMLElement>('.table-code').forEach((el) => {
const ext = el.dataset.filename?.split('.').pop() || '';
if (hljs.autoDetection(ext) && ext !== 'txt') {
el.querySelectorAll<HTMLElement>('td.line-code').forEach((ell) => {
ell.classList.add('language-' + ext);
hljs.highlightElement(ell);
});
}
el.addEventListener('click', event => {
if (event.target && (event.target as HTMLElement).matches('.line-num')) {
Array.from(document.querySelectorAll('.table-code .selected')).forEach((el) => el.classList.remove('selected'));
const nextSibling = (event.target as HTMLElement).nextSibling;
if (nextSibling instanceof HTMLElement) {
nextSibling.classList.add('selected');
}
const filename = el.dataset.filenameSlug;
const line = (event.target as HTMLElement).textContent;
const url = location.protocol + '//' + location.host + location.pathname;
const hash = '#file-' + filename + '-' + line;
window.history.pushState(null, null, url + hash);
location.hash = hash;
}
});
});
const colorhash = () => { const colorhash = () => {
Array.from(document.querySelectorAll('.table-code .selected')).forEach((el) => el.classList.remove('selected')); Array.from(document.querySelectorAll('.table-code .selected')).forEach((el) => el.classList.remove('selected'));
@ -191,7 +144,6 @@ document.addEventListener('DOMContentLoaded', () => {
if (gistmenuvisibility) { if (gistmenuvisibility) {
let submitgistbutton = (document.getElementById('submit-gist') as HTMLInputElement); let submitgistbutton = (document.getElementById('submit-gist') as HTMLInputElement);
document.getElementById('gist-visibility-menu-button')!.onclick = () => { document.getElementById('gist-visibility-menu-button')!.onclick = () => {
console.log("z");
gistmenuvisibility!.classList.toggle('hidden'); gistmenuvisibility!.classList.toggle('hidden');
} }
Array.from(document.querySelectorAll('.gist-visibility-option')).forEach((el) => { Array.from(document.querySelectorAll('.gist-visibility-option')).forEach((el) => {

View file

@ -15,6 +15,7 @@
</p> </p>
</div> </div>
<script type="module" src="{{ asset "hljs.ts" }}"></script>
</div> </div>
</body> </body>

View file

@ -27,8 +27,15 @@
</script> </script>
<link rel="icon" type="image/svg+xml" href="{{ asset "favicon.svg" }}" /> <link rel="icon" type="image/svg+xml" href="{{ asset "favicon.svg" }}" />
<meta name="viewport" content="width=device-width, initial-scale=1.0" /> <meta name="viewport" content="width=device-width, initial-scale=1.0" />
{{ if dev }}
<script type="module" src="{{ asset "@vite/client" }}"></script>
<link rel="stylesheet" href="{{ asset "style.css" }}" />
<script type="module" src="{{ asset "main.ts" }}"></script>
{{ else }}
<link rel="stylesheet" href="{{ asset "main.css" }}" /> <link rel="stylesheet" href="{{ asset "main.css" }}" />
<script type="module" src="{{ asset "main.ts" }}"></script> <script type="module" src="{{ asset "main.ts" }}"></script>
{{ end }}
{{ if .htmlTitle }} {{ if .htmlTitle }}
<title>{{ .htmlTitle }} - Opengist</title> <title>{{ .htmlTitle }} - Opengist</title>

2
vite.config.js vendored
View file

@ -9,7 +9,7 @@ export default defineConfig({
assetsDir: 'assets', assetsDir: 'assets',
manifest: true, manifest: true,
rollupOptions: { rollupOptions: {
input: ['./public/main.ts', './public/editor.ts', './public/admin.ts'] input: ['./public/main.ts', './public/editor.ts', './public/admin.ts', './public/hljs.ts']
} }
} }
}) })