base_href as a data attr

This commit is contained in:
Shish 2024-01-28 21:24:21 +00:00
parent bc7adaffe8
commit e5828b0810
4 changed files with 33 additions and 24 deletions

View file

@ -383,8 +383,6 @@ class BasePage
$data_href = get_base_href(); $data_href = get_base_href();
$theme_name = $config->get_string(SetupConfig::THEME, 'default'); $theme_name = $config->get_string(SetupConfig::THEME, 'default');
$this->add_html_header("<script type='text/javascript'>base_href = '$data_href';</script>", 40);
# static handler will map these to themes/foo/static/bar.ico or ext/static_files/static/bar.ico # static handler will map these to themes/foo/static/bar.ico or ext/static_files/static/bar.ico
$this->add_html_header("<link rel='icon' type='image/x-icon' href='$data_href/favicon.ico'>", 41); $this->add_html_header("<link rel='icon' type='image/x-icon' href='$data_href/favicon.ico'>", 41);
$this->add_html_header("<link rel='apple-touch-icon' href='$data_href/apple-touch-icon.png'>", 42); $this->add_html_header("<link rel='apple-touch-icon' href='$data_href/apple-touch-icon.png'>", 42);
@ -558,6 +556,7 @@ class BasePage
$body_attrs = [ $body_attrs = [
"data-userclass" => $user->class->name, "data-userclass" => $user->class->name,
"data-base-href" => get_base_href(),
]; ];
print emptyHTML( print emptyHTML(

View file

@ -42,7 +42,7 @@ function updateCompletions(element) {
} }
else { else {
element.completer_timeout = setTimeout(() => { element.completer_timeout = setTimeout(() => {
fetch(base_href + '/api/internal/autocomplete?s=' + word).then( fetch(document.body.getAttribute("data-base-href") + '/api/internal/autocomplete?s=' + word).then(
(response) => response.json() (response) => response.json()
).then((json) => { ).then((json) => {
if(element.selected_completion !== -1) { if(element.selected_completion !== -1) {

30
ext/handle_mp3/script.js Normal file
View file

@ -0,0 +1,30 @@
document.addEventListener("DOMContentLoaded", () => {
let main_image = document.getElementById("main_image");
if (main_image) {
main_image.setAttribute("volume", 0.25);
}
let base_href = document.body.getAttribute("data-base-href");
let audio_src = document.getElementById("audio_src");
if (audio_src) {
let ilink = audio_src.getAttribute("src");
window.jsmediatags.read(location.origin + base_href + ilink, {
onSuccess: function (tag) {
var artist = tag.tags.artist,
title = tag.tags.title;
document.getElementById("audio-title").innerText = title;
document.getElementById("audio-artist").innerText = artist;
document
.getElementById("audio-download")
.setAttribute(
"download",
(artist + " - " + title).substring(0, 250) + ".mp3",
);
},
onError: function (error) {
console.log(error);
},
});
}
});

View file

@ -13,31 +13,11 @@ class MP3FileHandlerTheme extends Themelet
$ilink = $image->get_image_link(); $ilink = $image->get_image_link();
$html = " $html = "
<audio controls class='shm-main-image audio_image' id='main_image' alt='main image'> <audio controls class='shm-main-image audio_image' id='main_image' alt='main image'>
<source src=\"$ilink\" type=\"audio/mpeg\"> <source id='audio_src' src=\"$ilink\" type=\"audio/mpeg\">
Your browser does not support the audio element. Your browser does not support the audio element.
</audio> </audio>
<p>Title: <span id='audio-title'>???</span> | Artist: <span id='audio-artist'>???</span></p> <p>Title: <span id='audio-title'>???</span> | Artist: <span id='audio-artist'>???</span></p>
<script>
$('#main_image').prop('volume', 0.25);
var jsmediatags = window.jsmediatags;
jsmediatags.read(location.origin+base_href+'$ilink', {
onSuccess: function(tag) {
var artist = tag.tags.artist,
title = tag.tags.title;
$('#audio-title').text(title);
$('#audio-artist').text(artist);
$('#audio-download').prop('download', (artist+' - '+title).substr(0, 250)+'.mp3');
},
onError: function(error) {
console.log(error);
}
});
</script>
<p><a href='$ilink' id='audio-download'>Download</a>"; <p><a href='$ilink' id='audio-download'>Download</a>";
$page->add_html_header("<script src='{$data_href}/ext/handle_mp3/lib/jsmediatags.min.js' type='text/javascript'></script>"); $page->add_html_header("<script src='{$data_href}/ext/handle_mp3/lib/jsmediatags.min.js' type='text/javascript'></script>");