mirror of
https://github.com/openvk/openvk
synced 2025-01-09 01:09:46 +03:00
Refactor audio upload page
This commit is contained in:
parent
1d719309c7
commit
5bc306ebf9
10 changed files with 286 additions and 194 deletions
|
@ -809,7 +809,7 @@ final class AudioPresenter extends OpenVKPresenter
|
||||||
$output_array['name'] = $audio->getTitle();
|
$output_array['name'] = $audio->getTitle();
|
||||||
$output_array['performer'] = $audio->getPerformer();
|
$output_array['performer'] = $audio->getPerformer();
|
||||||
|
|
||||||
if(!$audio->isWithdrawn() && $audio->isAvailable()) {
|
if(!$audio->isWithdrawn()) {
|
||||||
$output_array['keys'] = $audio->getKeys();
|
$output_array['keys'] = $audio->getKeys();
|
||||||
$output_array['url'] = $audio->getUrl();
|
$output_array['url'] = $audio->getUrl();
|
||||||
}
|
}
|
||||||
|
|
|
@ -38,217 +38,196 @@
|
||||||
<li>{tr("audio_requirements_2")}</li>
|
<li>{tr("audio_requirements_2")}</li>
|
||||||
</ul>
|
</ul>
|
||||||
<div id="audio_upload">
|
<div id="audio_upload">
|
||||||
<form enctype="multipart/form-data" method="POST">
|
<input id="audio_input" multiple type="file" name="blob" accept="audio/*" style="display:none" />
|
||||||
<input type="hidden" name="name" />
|
|
||||||
<input type="hidden" name="performer" />
|
|
||||||
<input type="hidden" name="lyrics" />
|
|
||||||
<input type="hidden" name="genre" />
|
|
||||||
<input type="hidden" name="explicit" />
|
|
||||||
<input type="hidden" name="unlisted" />
|
|
||||||
|
|
||||||
<input type="hidden" name="hash" value="{$csrfToken}" />
|
|
||||||
<input id="audio_input" type="file" name="blob" accept="audio/*" style="display:none" />
|
|
||||||
<input value="{_upload_button}" class="button" type="button" onclick="document.querySelector('#audio_input').click()">
|
<input value="{_upload_button}" class="button" type="button" onclick="document.querySelector('#audio_input').click()">
|
||||||
</form>
|
|
||||||
</div><br/>
|
</div><br/>
|
||||||
|
|
||||||
<span>{_you_can_also_add_audio_using} <b><a href="/search?section=audios">{_search_audio_inst}</a></b>.<span>
|
<span>{_you_can_also_add_audio_using} <b><a href="/search?section=audios">{_search_audio_inst}</a></b>.<span>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div id="lastStep" style="display:none;">
|
<div id="lastStep" style="display:none;">
|
||||||
<table cellspacing="7" cellpadding="0" border="0" align="center">
|
<div id="lastStepContainers"></div>
|
||||||
<tbody>
|
<div id="lastStepButtons" style="text-align: center;margin-top: 10px;">
|
||||||
<tr>
|
<input class="button" type="button" id="uploadMusic" value="{_upload_button}">
|
||||||
<td width="120" valign="top"><span class="nobold">{_performer}:</span></td>
|
<input class="button" type="button" id="backToUpload" onclick="document.querySelector('#audio_input').click()" value="{_select_another_file}">
|
||||||
<td><input name="performer" type="text" autocomplete="off" maxlength="80" /></td>
|
</div>
|
||||||
</tr>
|
|
||||||
<tr>
|
|
||||||
<td width="120" valign="top"><span class="nobold">{_audio_name}:</span></td>
|
|
||||||
<td><input type="text" name="name" autocomplete="off" maxlength="80" /></td>
|
|
||||||
</tr>
|
|
||||||
<tr>
|
|
||||||
<td width="120" valign="top"><span class="nobold">{_genre}:</span></td>
|
|
||||||
<td>
|
|
||||||
<select name="genre">
|
|
||||||
<option n:foreach='\openvk\Web\Models\Entities\Audio::genres as $genre' n:attr="selected: $genre == 'Other'" value="{$genre}">
|
|
||||||
{$genre}
|
|
||||||
</option>
|
|
||||||
</select>
|
|
||||||
</td>
|
|
||||||
</tr>
|
|
||||||
<tr>
|
|
||||||
<td width="120" valign="top"><span class="nobold">{_lyrics}:</span></td>
|
|
||||||
<td><textarea name="lyrics" style="resize: vertical;max-height: 300px;"></textarea></td>
|
|
||||||
</tr>
|
|
||||||
<tr>
|
|
||||||
<td width="120" valign="top"></td>
|
|
||||||
<td>
|
|
||||||
<label style='display:block'><input type="checkbox" name="explicit">{_audios_explicit}</label>
|
|
||||||
<label><input type="checkbox" name="unlisted">{_audios_unlisted}</label>
|
|
||||||
</td>
|
|
||||||
</tr>
|
|
||||||
<tr>
|
|
||||||
<td width="120" valign="top"></td>
|
|
||||||
<td>
|
|
||||||
<input class="button" type="button" id="uploadMuziko" value="{_upload_button}">
|
|
||||||
<input class="button" type="button" id="backToUpload" value="{_select_another_file}">
|
|
||||||
</td>
|
|
||||||
</tr>
|
|
||||||
</tbody>
|
|
||||||
</table>
|
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<script type="module">
|
<script type="module" n:syntax='off'>
|
||||||
import * as id3 from "/assets/packages/static/openvk/js/node_modules/id3js/lib/id3.js";
|
import * as id3 from "/assets/packages/static/openvk/js/node_modules/id3js/lib/id3.js";
|
||||||
|
|
||||||
u("#audio_input").on("change", async function(e) {
|
window.__audio_upload_page = new class {
|
||||||
let files = e.currentTarget.files
|
files_list = []
|
||||||
if(files.length <= 0)
|
|
||||||
return;
|
|
||||||
|
|
||||||
document.querySelector("#firstStep").style.display = "none"
|
hideFirstPage() {
|
||||||
document.querySelector("#lastStep").style.display = "block"
|
u('#firstStep').attr('style', 'display:none')
|
||||||
|
u('#lastStep').attr('style', 'display:block')
|
||||||
|
}
|
||||||
|
|
||||||
|
showFirstPage() {
|
||||||
|
u('#firstStep').attr('style', 'display:block')
|
||||||
|
u('#lastStep').attr('style', 'display:none')
|
||||||
|
}
|
||||||
|
|
||||||
|
async detectTags(blob) {
|
||||||
|
const return_params = {
|
||||||
|
performer: '',
|
||||||
|
name: '',
|
||||||
|
genre: '',
|
||||||
|
lyrics: '',
|
||||||
|
explicit: 0,
|
||||||
|
unlisted: 0,
|
||||||
|
}
|
||||||
|
|
||||||
function fallback() {
|
function fallback() {
|
||||||
console.info('Tags not found, setting default values.')
|
console.info('Tags not found, setting default values.')
|
||||||
|
return_params.name = remove_file_format(blob.name)
|
||||||
document.querySelector("#lastStep input[name=name]").value = files[0].name
|
return_params.genre = 'Other'
|
||||||
document.querySelector("#lastStep select[name=genre]").value = "Other"
|
return_params.performer = tr('track_unknown')
|
||||||
document.querySelector("#lastStep input[name=performer]").value = tr("track_unknown");
|
|
||||||
}
|
}
|
||||||
|
|
||||||
let tags = null
|
let tags = null
|
||||||
|
|
||||||
try {
|
try {
|
||||||
tags = await id3.fromFile(files[0]);
|
tags = await id3.fromFile(blob)
|
||||||
} catch(e) {
|
} catch(e) {
|
||||||
console.error(e)
|
console.error(e)
|
||||||
}
|
}
|
||||||
|
|
||||||
console.log(tags)
|
console.log(tags)
|
||||||
if(tags != null) {
|
if(tags != null) {
|
||||||
console.log("ID" + tags.kind + " detected, setting values...");
|
console.log("ID" + tags.kind + " detected, setting values...")
|
||||||
|
if(tags.title) {
|
||||||
|
return_params.name = tags.title
|
||||||
|
} else {
|
||||||
|
return_params.name = remove_file_format(blob.name)
|
||||||
|
}
|
||||||
|
|
||||||
if(tags.title != null)
|
if(tags.artist) {
|
||||||
document.querySelector("#lastStep input[name=name]").value = tags.title;
|
return_params.performer = tags.artist
|
||||||
else
|
} else {
|
||||||
document.querySelector("#lastStep input[name=name]").value = files[0].name
|
return_params.performer = tr('track_unknown')
|
||||||
|
// todo: split performer and title from filename
|
||||||
if(tags.artist != null)
|
}
|
||||||
document.querySelector("#lastStep input[name=performer]").value = tags.artist;
|
|
||||||
else
|
|
||||||
document.querySelector("#lastStep input[name=performer]").value = tr("track_unknown");
|
|
||||||
|
|
||||||
if(tags.genre != null) {
|
if(tags.genre != null) {
|
||||||
// if there are more than one genre
|
|
||||||
if(tags.genre.split(', ').length > 1) {
|
if(tags.genre.split(', ').length > 1) {
|
||||||
const genres = tags.genre.split(', ')
|
const genres = tags.genre.split(', ')
|
||||||
|
|
||||||
genres.forEach(genre => {
|
genres.forEach(genre => {
|
||||||
if(document.querySelector("#lastStep select[name=genre] > option[value='" + genre + "']") != null) {
|
if(window.openvk.audio_genres[genre]) {
|
||||||
document.querySelector("#lastStep select[name=genre]").value = genre;
|
return_params.genre = genre;
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
} else {
|
} else {
|
||||||
if(document.querySelector("#lastStep select[name=genre] > option[value='" + tags.genre + "']") != null) {
|
if(window.openvk.audio_genres.indexOf(tags.genre) != -1) {
|
||||||
document.querySelector("#lastStep select[name=genre]").value = tags.genre;
|
return_params.genre = tags.genre
|
||||||
} else {
|
} else {
|
||||||
console.warn("Unknown genre: " + tags.genre);
|
console.warn("Unknown genre: " + tags.genre)
|
||||||
document.querySelector("#lastStep select[name=genre]").value = "Other"
|
return_params.genre = 'Other'
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
document.querySelector("#lastStep select[name=genre]").value = "Other"
|
return_params.genre = 'Other'
|
||||||
}
|
}
|
||||||
|
|
||||||
if(tags.comments != null)
|
if(tags.comments != null)
|
||||||
document.querySelector("#lastStep textarea[name=lyrics]").value = tags.comments
|
return_params.lyrics = tags.comments
|
||||||
} else {
|
} else {
|
||||||
fallback()
|
fallback()
|
||||||
}
|
}
|
||||||
});
|
|
||||||
|
|
||||||
u("#backToUpload").on("click", (e) => {
|
return return_params
|
||||||
document.querySelector("#firstStep").style.display = "block"
|
}
|
||||||
document.querySelector("#lastStep").style.display = "none"
|
|
||||||
|
|
||||||
document.querySelector("#lastStep input[name=name]").value = ""
|
async appendFile(appender)
|
||||||
document.querySelector("#lastStep input[name=performer]").value = ""
|
{
|
||||||
document.querySelector("#lastStep select[name=genre]").value = ""
|
appender.info = await this.detectTags(appender.file)
|
||||||
document.querySelector("#lastStep textarea[name=lyrics]").value = ""
|
const audio_index = this.files_list.push(appender) - 1
|
||||||
document.querySelector("#audio_input").value = ""
|
this.appendAudioFrame(audio_index)
|
||||||
|
}
|
||||||
|
|
||||||
|
appendAudioFrame(audio_index) {
|
||||||
|
const audio_element = this.files_list[audio_index]
|
||||||
|
if(!audio_element) {
|
||||||
|
return
|
||||||
|
|
||||||
|
}
|
||||||
|
const template = u(`
|
||||||
|
<div class='upload_container_element' data-index="${audio_index}">
|
||||||
|
<div class='upload_container_name'>
|
||||||
|
<span>${ovk_proc_strtr(escapeHtml(audio_element.file.name), 63)}</span>
|
||||||
|
<div id="small_remove_button"></div>
|
||||||
|
</div>
|
||||||
|
<table cellspacing="7" cellpadding="0" border="0" align="center">
|
||||||
|
<tbody>
|
||||||
|
<tr>
|
||||||
|
<td width="120" valign="top"><span class="nobold">${tr('performer')}:</span></td>
|
||||||
|
<td><input value='${audio_element.info.performer}' name="performer" type="text" autocomplete="off" maxlength="80" /></td>
|
||||||
|
</tr>
|
||||||
|
<tr>
|
||||||
|
<td width="120" valign="top"><span class="nobold">${tr('audio_name')}:</span></td>
|
||||||
|
<td><input type="text" value='${audio_element.info.name}' name="name" autocomplete="off" maxlength="80" /></td>
|
||||||
|
</tr>
|
||||||
|
<tr>
|
||||||
|
<td width="120" valign="top"><span class="nobold">${tr('genre')}:</span></td>
|
||||||
|
<td>
|
||||||
|
<select name="genre"></select>
|
||||||
|
</td>
|
||||||
|
</tr>
|
||||||
|
<tr>
|
||||||
|
<td width="120" valign="top"><span class="nobold">${tr('lyrics')}:</span></td>
|
||||||
|
<td><textarea name="lyrics" style="resize: vertical;max-height: 300px;">${audio_element.info.lyrics}</textarea></td>
|
||||||
|
</tr>
|
||||||
|
<tr>
|
||||||
|
<td width="120" valign="top"></td>
|
||||||
|
<td>
|
||||||
|
<label style='display:block'><input type="checkbox" name="explicit">${tr('audios_explicit')}</label>
|
||||||
|
<label><input type="checkbox" name="unlisted">${tr('audios_unlisted')}</label>
|
||||||
|
</td>
|
||||||
|
</tr>
|
||||||
|
</tbody>
|
||||||
|
</table>
|
||||||
|
</div>
|
||||||
|
`)
|
||||||
|
window.openvk.audio_genres.forEach(genre => {
|
||||||
|
template.find('select').append(`
|
||||||
|
<option ${genre == audio_element.info.genre ? 'selected': ''} value='${genre}'>${genre}</option>
|
||||||
|
`)
|
||||||
})
|
})
|
||||||
|
u('#lastStep #lastStepContainers').append(template)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
u("#uploadMuziko").on("click", (e) => {
|
u(`#audio_upload input`).on('change', (e) => {
|
||||||
var name_ = document.querySelector("#audio_upload input[name=name]");
|
const files = e.target.files
|
||||||
var perf_ = document.querySelector("#audio_upload input[name=performer]");
|
if(files.length <= 0) {
|
||||||
var genre_ = document.querySelector("#audio_upload input[name=genre]");
|
return
|
||||||
var lyrics_ = document.querySelector("#audio_upload input[name=lyrics]");
|
}
|
||||||
var explicit_ = document.querySelector("#audio_upload input[name=explicit]");
|
|
||||||
var unlisted_ = document.querySelector("#audio_upload input[name=unlisted]");
|
|
||||||
|
|
||||||
name_.value = document.querySelector("#lastStep input[name=name]").value
|
Array.from(files).forEach(async file => {
|
||||||
perf_.value = document.querySelector("#lastStep input[name=performer]").value
|
let has_duplicates = false
|
||||||
genre_.value = document.querySelector("#lastStep select[name=genre]").value
|
const appender = {
|
||||||
lyrics_.value = document.querySelector("#lastStep textarea[name=lyrics]").value
|
'file': file
|
||||||
explicit_.value = document.querySelector("#lastStep input[name=explicit]").checked ? "on" : "off"
|
}
|
||||||
unlisted_.value = document.querySelector("#lastStep input[name=unlisted]").checked ? "on" : "off"
|
|
||||||
|
|
||||||
$("#audio_upload > form").trigger("submit");
|
|
||||||
})
|
|
||||||
|
|
||||||
$(document).on("dragover drop", (e) => {
|
|
||||||
e.preventDefault()
|
|
||||||
|
|
||||||
return false;
|
|
||||||
})
|
|
||||||
|
|
||||||
$(".container_gray").on("drop", (e) => {
|
|
||||||
e.originalEvent.dataTransfer.dropEffect = 'move';
|
|
||||||
e.preventDefault()
|
|
||||||
|
|
||||||
let file = e.originalEvent.dataTransfer.files[0]
|
|
||||||
|
|
||||||
if(!file.type.startsWith('audio/')) {
|
if(!file.type.startsWith('audio/')) {
|
||||||
MessageBox(tr("error"), tr("only_audios_accepted", escapeHtml(file.name)), [tr("ok")], [() => Function.noop])
|
makeError(tr('only_audios_accepted', escapeHtml(file.name)))
|
||||||
return;
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
document.getElementById("audio_input").files = e.originalEvent.dataTransfer.files
|
window.__audio_upload_page.files_list.forEach(el => {
|
||||||
u("#audio_input").trigger("change")
|
if(el && file.name == el.file.name) {
|
||||||
})
|
has_duplicates = true
|
||||||
|
|
||||||
$("#audio_upload").on("submit", "form", (e) => {
|
|
||||||
e.preventDefault()
|
|
||||||
|
|
||||||
let fd = new FormData(e.currentTarget)
|
|
||||||
fd.append("ajax", 1)
|
|
||||||
|
|
||||||
$.ajax({
|
|
||||||
type: "POST",
|
|
||||||
url: location.href,
|
|
||||||
contentType: false,
|
|
||||||
processData: false,
|
|
||||||
data: fd,
|
|
||||||
beforeSend: function() {
|
|
||||||
document.querySelector("#lastStep").classList.add("lagged")
|
|
||||||
document.querySelector("#upload_container").classList.add("uploading")
|
|
||||||
},
|
|
||||||
success: (response) => {
|
|
||||||
document.querySelector("#lastStep").classList.remove("lagged")
|
|
||||||
document.querySelector("#upload_container").classList.remove("uploading")
|
|
||||||
if(response.success) {
|
|
||||||
u("#backToUpload").trigger("click")
|
|
||||||
NewNotification(tr("success"), tr("audio_successfully_uploaded"), null, () => {
|
|
||||||
window.router.route(response.redirect_link)
|
|
||||||
})
|
|
||||||
} else {
|
|
||||||
fastError(response.flash.message)
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
|
|
||||||
|
if(!has_duplicates) {
|
||||||
|
window.__audio_upload_page.appendFile(appender)
|
||||||
|
}
|
||||||
|
})
|
||||||
|
window.__audio_upload_page.hideFirstPage()
|
||||||
})
|
})
|
||||||
</script>
|
</script>
|
||||||
{/block}
|
{/block}
|
||||||
|
|
|
@ -966,6 +966,14 @@
|
||||||
color: white;
|
color: white;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#ajax_audio_player #aj_time {
|
||||||
|
cursor: pointer;
|
||||||
|
}
|
||||||
|
|
||||||
|
#ajax_audio_player #aj_time:hover {
|
||||||
|
text-decoration: underline;
|
||||||
|
}
|
||||||
|
|
||||||
#ajax_audio_player .selectableTrack {
|
#ajax_audio_player .selectableTrack {
|
||||||
width: 100%;
|
width: 100%;
|
||||||
position: relative;
|
position: relative;
|
||||||
|
|
|
@ -2261,6 +2261,25 @@ table td[width="120"] {
|
||||||
margin: 0;
|
margin: 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#upload_container #lastStepContainers {
|
||||||
|
display: flex;
|
||||||
|
flex-direction: column;
|
||||||
|
gap: 10px;
|
||||||
|
}
|
||||||
|
|
||||||
|
#upload_container .upload_container_element {
|
||||||
|
border: 1px solid #d6d6d6;
|
||||||
|
background: #f6f6f6;
|
||||||
|
}
|
||||||
|
|
||||||
|
#upload_container .upload_container_element .upload_container_name {
|
||||||
|
padding: 5px 5px;
|
||||||
|
display: flex;
|
||||||
|
flex-direction: row;
|
||||||
|
align-items: center;
|
||||||
|
justify-content: space-between;
|
||||||
|
}
|
||||||
|
|
||||||
#audio_upload {
|
#audio_upload {
|
||||||
width: 350px;
|
width: 350px;
|
||||||
margin: 20px auto;
|
margin: 20px auto;
|
||||||
|
@ -3561,7 +3580,7 @@ hr {
|
||||||
cursor: pointer;
|
cursor: pointer;
|
||||||
}
|
}
|
||||||
|
|
||||||
#upload_container.uploading {
|
#upload_container .upload_container_element .upload_container_name.uploading {
|
||||||
background: white url('/assets/packages/static/openvk/img/progressbar.gif') !important;
|
background: white url('/assets/packages/static/openvk/img/progressbar.gif') !important;
|
||||||
background-position-x: 0% !important;
|
background-position-x: 0% !important;
|
||||||
background-position-y: 0% !important;
|
background-position-y: 0% !important;
|
||||||
|
|
|
@ -690,7 +690,7 @@ window.player = new class {
|
||||||
miniplayer_template.find('#aj_player_close_btn').on('click', (e) => {
|
miniplayer_template.find('#aj_player_close_btn').on('click', (e) => {
|
||||||
this.ajClose()
|
this.ajClose()
|
||||||
})
|
})
|
||||||
miniplayer_template.find('#aj_player_track_title').on('click', (e) => {
|
miniplayer_template.find('#aj_time').on('click', (e) => {
|
||||||
if(window.player && window.player.context && window.player.context.object) {
|
if(window.player && window.player.context && window.player.context.object) {
|
||||||
window.router.route(window.player.context.object.url)
|
window.router.route(window.player.context.object.url)
|
||||||
}
|
}
|
||||||
|
@ -698,7 +698,7 @@ window.player = new class {
|
||||||
$('#ajax_audio_player').draggable({
|
$('#ajax_audio_player').draggable({
|
||||||
cursor: 'grabbing',
|
cursor: 'grabbing',
|
||||||
containment: 'window',
|
containment: 'window',
|
||||||
cancel: '#aj_player_track, #aj_player_volume, #aj_player_buttons',
|
cancel: '#aj_player_track .selectableTrack, #aj_player_volume .selectableTrack, #aj_player_buttons',
|
||||||
stop: function(e) {
|
stop: function(e) {
|
||||||
if(window.player.ajaxPlayer.length > 0) {
|
if(window.player.ajaxPlayer.length > 0) {
|
||||||
const left = parseInt(window.player.ajaxPlayer.nodes[0].style.left)
|
const left = parseInt(window.player.ajaxPlayer.nodes[0].style.left)
|
||||||
|
@ -906,6 +906,10 @@ u(document).on("mousemove click mouseup", ".bigPlayer .trackPanel .selectableTra
|
||||||
if(window.player.isAtAudiosPage() && window.player.current_track_id == 0)
|
if(window.player.isAtAudiosPage() && window.player.current_track_id == 0)
|
||||||
return
|
return
|
||||||
|
|
||||||
|
if(u('.ui-draggable-dragging').length > 0) {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
function __defaultAction(i_time) {
|
function __defaultAction(i_time) {
|
||||||
window.player.listen_coef -= 0.5
|
window.player.listen_coef -= 0.5
|
||||||
window.player.audioPlayer.currentTime = i_time
|
window.player.audioPlayer.currentTime = i_time
|
||||||
|
@ -944,6 +948,10 @@ u(document).on("mousemove click mouseup", ".bigPlayer .volumePanelTrack .selecta
|
||||||
if(window.player.isAtAudiosPage() && window.player.current_track_id == 0)
|
if(window.player.isAtAudiosPage() && window.player.current_track_id == 0)
|
||||||
return
|
return
|
||||||
|
|
||||||
|
if(u('.ui-draggable-dragging').length > 0) {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
function __defaultAction(i_volume) {
|
function __defaultAction(i_volume) {
|
||||||
window.player.audioPlayer.volume = i_volume
|
window.player.audioPlayer.volume = i_volume
|
||||||
}
|
}
|
||||||
|
@ -1849,3 +1857,66 @@ $(document).on("click", "#bookmarkPlaylist, #unbookmarkPlaylist", (e) => {
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
|
|
||||||
|
u(document).on('click', '.upload_container_element #small_remove_button', (e) => {
|
||||||
|
if(u('.uploading').length > 0) {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
const element = u(e.target).closest('.upload_container_element')
|
||||||
|
const element_index = Number(element.attr('data-index'))
|
||||||
|
|
||||||
|
element.remove()
|
||||||
|
window.__audio_upload_page.files_list[element_index] = null
|
||||||
|
|
||||||
|
if(u('#lastStep .upload_container_element').length < 1) {
|
||||||
|
window.__audio_upload_page.showFirstPage()
|
||||||
|
}
|
||||||
|
})
|
||||||
|
|
||||||
|
u(document).on('click', `#upload_container #uploadMusic`, async (e) => {
|
||||||
|
const current_upload_page = location.href
|
||||||
|
let end_redir = ''
|
||||||
|
u('#lastStepButtons').addClass('lagged')
|
||||||
|
for(const elem of u('#lastStepContainers .upload_container_element').nodes) {
|
||||||
|
if(!elem) {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
const elem_u = u(elem)
|
||||||
|
const index = elem.dataset.index
|
||||||
|
const file = window.__audio_upload_page.files_list[index]
|
||||||
|
if(!file || !index) {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
elem_u.addClass('lagged').find('.upload_container_name').addClass('uploading')
|
||||||
|
// Upload process
|
||||||
|
const fd = serializeForm(elem)
|
||||||
|
fd.append('blob', file.file)
|
||||||
|
fd.append('ajax', 1)
|
||||||
|
fd.append('hash', window.router.csrf)
|
||||||
|
|
||||||
|
const result = await fetch(current_upload_page, {
|
||||||
|
method: 'POST',
|
||||||
|
body: fd,
|
||||||
|
})
|
||||||
|
const result_text = await result.json()
|
||||||
|
if(result_text.success && result_text.redirect_link) {
|
||||||
|
end_redir = result_text.redirect_link
|
||||||
|
}
|
||||||
|
await sleep(6000)
|
||||||
|
elem_u.remove()
|
||||||
|
}
|
||||||
|
|
||||||
|
if(current_upload_page == location.href) {
|
||||||
|
window.router.route(end_redir)
|
||||||
|
}
|
||||||
|
})
|
||||||
|
|
||||||
|
u(document).on("drop", "#upload_container", function (e) {
|
||||||
|
e.preventDefault()
|
||||||
|
e.dataTransfer.dropEffect = 'move';
|
||||||
|
|
||||||
|
document.getElementById("audio_input").files = e.dataTransfer.files
|
||||||
|
u("#audio_input").trigger("change")
|
||||||
|
})
|
||||||
|
|
|
@ -1125,6 +1125,11 @@ u(document).on('dragover', '#write .post-horizontal .upload-item, .post-vertical
|
||||||
return
|
return
|
||||||
})
|
})
|
||||||
|
|
||||||
|
u(document).on("dragover drop", async (e) => {
|
||||||
|
e.preventDefault()
|
||||||
|
return false;
|
||||||
|
})
|
||||||
|
|
||||||
u(document).on('dragleave dragend', '#write .post-horizontal .upload-item, .post-vertical .upload-item', (e) => {
|
u(document).on('dragleave dragend', '#write .post-horizontal .upload-item, .post-vertical .upload-item', (e) => {
|
||||||
//console.log(e)
|
//console.log(e)
|
||||||
u(e.target).closest('.upload-item').removeClass('dragged')
|
u(e.target).closest('.upload-item').removeClass('dragged')
|
||||||
|
|
|
@ -224,7 +224,7 @@ u(document).on('click', 'a', async (e) => {
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
if(target.download != null) {
|
if(target.nodes[0].hasAttribute('download')) {
|
||||||
console.log('AJAX | Skipped because its download')
|
console.log('AJAX | Skipped because its download')
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
|
@ -238,3 +238,13 @@ async function copyToClipboard(text) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function remove_file_format(text)
|
||||||
|
{
|
||||||
|
return text.replace(/\.[^.]*$/, '')
|
||||||
|
}
|
||||||
|
|
||||||
|
function sleep(time)
|
||||||
|
{
|
||||||
|
return new Promise((resolve) => setTimeout(resolve, time));
|
||||||
|
}
|
||||||
|
|
|
@ -882,7 +882,7 @@
|
||||||
"genre" = "Genre";
|
"genre" = "Genre";
|
||||||
"lyrics" = "Lyrics";
|
"lyrics" = "Lyrics";
|
||||||
|
|
||||||
"select_another_file" = "Select another file";
|
"select_another_file" = "Upload another file";
|
||||||
|
|
||||||
"limits" = "Limits";
|
"limits" = "Limits";
|
||||||
"select_audio" = "Select audio from your computer";
|
"select_audio" = "Select audio from your computer";
|
||||||
|
|
|
@ -837,7 +837,7 @@
|
||||||
"genre" = "Жанр";
|
"genre" = "Жанр";
|
||||||
"lyrics" = "Текст";
|
"lyrics" = "Текст";
|
||||||
|
|
||||||
"select_another_file" = "Выбрать другой файл";
|
"select_another_file" = "Загрузить ещё";
|
||||||
|
|
||||||
"limits" = "Ограничения";
|
"limits" = "Ограничения";
|
||||||
"select_audio" = "Выберите аудиозапись на Вашем компьютере";
|
"select_audio" = "Выберите аудиозапись на Вашем компьютере";
|
||||||
|
|
Loading…
Reference in a new issue