1
0
Fork 0
mirror of https://github.com/Yetangitu/ampache synced 2025-10-03 17:59:21 +02:00
ampache/lib/javascript/tools.js
Afterster b5f92aa25c Edit library items in a more generic way
Use real large image on Google gather arts
2014-07-08 00:51:52 +02:00

312 lines
10 KiB
JavaScript

// vim:set softtabstop=4 shiftwidth=4 expandtab:
//
// Copyright 2001 - 2013 Ampache.org
// All rights reserved.
//
// This program is free software; you can redistribute it and/or
// modify it under the terms of the GNU General Public License v2
// as published by the Free Software Foundation.
//
//
// This program is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
// GNU General Public License for more details.
//
// You should have received a copy of the GNU General Public License
// along with this program; if not, write to the Free Software
// Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
//
/***********/
/* Filters */
/***********/
function showFilters(element) {
var link = $('.browse-options-link');
link.hide();
var content = $('.browse-options-content');
content.show();
}
/************************************************************/
/* Dialog selection to add song to an existing/new playlist */
/************************************************************/
var closeplaylist;
function showPlaylistDialog(e, item_type, item_ids) {
$("#playlistdialog").dialog("close");
var parent = this;
parent.itemType = item_type;
parent.contentUrl = jsAjaxServer + '/edit.server.php?action=show_edit_playlist&object_type=' + item_type + '&id=' + item_ids;
parent.editDialogId = '<div id="playlistdialog"></div>';
$(parent.editDialogId).dialog({
modal: false,
dialogClass: 'playlistdialogstyle',
resizable: false,
draggable: false,
width: 300,
height: 100,
autoOpen: false,
open: function () {
closeplaylist = 1;
$(document).bind('click', overlayclickclose);
$(this).load(parent.contentUrl, function() {
$('#playlistdialog').focus();
});
},
focus: function() {
closeplaylist = 0;
},
close: function (e) {
$(document).unbind('click');
$(this).empty();
$(this).dialog("destroy");
}
});
$("#playlistdialog").dialog("option", "position", [e.clientX + 10, e.clientY]);
$("#playlistdialog").dialog("open");
closeplaylist = 0;
}
function overlayclickclose() {
if (closeplaylist) {
$("#playlistdialog").dialog("close");
}
closeplaylist = 1;
}
function handlePlaylistAction(url, id) {
ajaxPut(url, id);
$("#playlistdialog").dialog("close");
}
/************************************************************/
/* Dialog selection to start a broadcast */
/************************************************************/
var closebroadcasts;
function showBroadcastsDialog(e) {
$("#broadcastsdialog").dialog("close");
var parent = this;
parent.contentUrl = jsAjaxServer + '/ajax.server.php?page=player&action=show_broadcasts';
parent.editDialogId = '<div id="broadcastsdialog"></div>';
$(parent.editDialogId).dialog({
modal: false,
dialogClass: 'broadcastsdialogstyle',
resizable: false,
draggable: false,
width: 150,
height: 70,
autoOpen: false,
open: function () {
closebroadcasts = 1;
$(document).bind('click', broverlayclickclose);
$(this).load(parent.contentUrl, function() {
$('#broadcastsdialog').focus();
});
},
focus: function() {
closebroadcasts = 0;
},
close: function (e) {
$(document).unbind('click');
$(this).empty();
$(this).dialog("destroy");
}
});
$("#broadcastsdialog").dialog("option", "position", [e.clientX - 180, e.clientY]);
$("#broadcastsdialog").dialog("open");
closebroadcasts = 0;
}
function broverlayclickclose() {
if (closebroadcasts) {
$("#broadcastsdialog").dialog("close");
}
closebroadcasts = 1;
}
function handleBroadcastAction(url, id) {
ajaxPut(url, id);
$("#broadcastsdialog").dialog("close");
}
/***************************************************/
/* Edit modal dialog for artists, albums and songs */
/***************************************************/
var tag_choices = undefined;
function showEditDialog(edit_type, edit_id, edit_form_id, edit_title, refresh_row_prefix) {
var parent = this;
parent.editFormId = 'form#' + edit_form_id;
parent.contentUrl = jsAjaxServer + '/edit.server.php?action=show_edit_object&id=' + edit_id + '&type=' + edit_type;
parent.saveUrl = jsAjaxServer + '/edit.server.php?action=edit_object&id=' + edit_id + '&type=' + edit_type;
parent.editDialogId = '<div id="editdialog"></div>';
parent.refreshRowPrefix = refresh_row_prefix;
parent.editType = edit_type;
parent.editId = edit_id;
// Convert choices string ("tag0,tag1,tag2,...") to choices array
parent.editTagChoices = new Array();
if (tag_choices == undefined && tag_choices != '') {
// Load tag map
$.ajax(jsAjaxServer + '/ajax.server.php?page=tag&action=get_tag_map', { success: function(data) {
tag_choices = $(data).find('content').text();
if (tag_choices != '') {
showEditDialog(edit_type, edit_id, edit_form_id, edit_title, refresh_row_prefix);
}
}, type: 'post', dataType: 'xml' });
return;
}
var splitted = tag_choices.split(',');
var i;
for (i = 0; i < splitted.length; ++i) {
parent.editTagChoices.push($.trim(splitted[i]));
}
parent.dialog_buttons = {};
this.dialog_buttons[jsSaveTitle] = function() {
$.ajax({
url : parent.saveUrl,
type : 'POST',
data : $(parent.editFormId).serializeArray(),
success : function(resp){
$("#editdialog").dialog("close");
if (parent.refreshRowPrefix != '') {
var new_id = $.trim(resp.lastChild.textContent);
// resp should contain the new identifier, otherwise we take the same as the edited item
if (new_id == '') {
new_id = parent.editId;
}
var url = jsAjaxServer + '/edit.server.php?action=refresh_updated&type=' + parent.editType + '&id=' + new_id;
// Reload only table
$('#' + parent.refreshRowPrefix + parent.editId).load(url, function() {
// Update the current row identifier with new id
$('#' + parent.refreshRowPrefix + parent.editId).attr("id", parent.refreshRowPrefix + new_id);
});
} else {
location.reload(true);
}
},
error : function(resp){
$("#editdialog").dialog("close");
}
});
}
this.dialog_buttons[jsCancelTitle] = function() {
$("#editdialog").dialog("close");
}
$(parent.editDialogId).dialog({
title: edit_title,
modal: true,
dialogClass: 'editdialogstyle',
resizable: false,
width: 666,
autoOpen: false,
show: { effect: "fade", duration: 400 },
open: function () {
$(this).load(parent.contentUrl, function() {
$(this).dialog('option', 'position', 'center');
if ($('#edit_tags').length > 0) {
$("#edit_tags").tagit({
allowSpaces: true,
singleField: true,
singleFieldDelimiter: ',',
availableTags: parent.editTagChoices
});
}
if ($('#select_tags').length > 0) {
$.each(parent.editTagChoices, function(i, tagtext) {
$("#select_tags").append(new Option(tagtext, tagtext));
});
}
});
},
close: function (e) {
$(this).empty();
$(this).dialog("destroy");
},
buttons: dialog_buttons
});
$("#editdialog").dialog("open");
}
$(window).resize(function() {
$("#editdialog").dialog("option", "position", ['center', 'center']);
});
function check_inline_song_edit(type, song) {
var source = '#' + type + '_select_' + song;
if ($(source + ' option:selected').val() == -1) {
$(source).replaceWith('<input type="text" name="' + type + '_name" value="New ' + type + '" onclick="this.select();" />');
}
}
/*********************/
/* Sortable table */
/*********************/
$(document).ready(function () {
var eles = $("tbody[id^='sortableplaylist_']");
if (eles != null) {
var len = eles.length;
for (var i = 0; i < len; i++) {
$('#' + eles[i].id).sortable({
axis: 'y',
delay: 200
});
}
}
});
function submitNewItemsOrder(itemId, tableid, rowPrefix, updateUrl, refreshAction) {
var parent = this;
parent.itemId = itemId;
parent.refreshAction = refreshAction;
var table = document.getElementById(tableid);
var rowLength = table.rows.length;
var finalOrder = '';
for (var i = 0; i < rowLength; ++i) {
var row = table.rows[i];
if (row.id != '') {
var songid = row.id.replace(rowPrefix, '');
finalOrder += songid + ";"
}
}
if (finalOrder != '') {
$.ajax({
url : updateUrl,
type : 'GET',
data : 'order=' + finalOrder,
success : function(resp){
var url = jsAjaxServer + '/refresh_reordered.server.php?action=' + parent.refreshAction + '&id=' + parent.itemId;
// Reload only table
$('#reordered_list_' + parent.itemId).load(url, function() {
$('#sortableplaylist_' + parent.itemId).sortable({
axis: 'y',
delay: 200
});
});
}
});
}
}