mirror of
https://github.com/Pathduck/gallery3.git
synced 2026-06-08 04:29:23 -04:00
127 lines
3.9 KiB
JavaScript
127 lines
3.9 KiB
JavaScript
/**
|
|
* Initialize jQuery UI and Gallery Plugin elements
|
|
*/
|
|
|
|
var shortForms = new Array(
|
|
"#gQuickSearchForm",
|
|
"#gAddTagForm",
|
|
"#gSearchForm"
|
|
);
|
|
|
|
$(document).ready(function() {
|
|
|
|
// Initialize Superfish menus
|
|
$("ul.gMenu").addClass("sf-menu");
|
|
$('ul.sf-menu').superfish({
|
|
delay: 500,
|
|
animation: {
|
|
opacity:'show',
|
|
height:'show'
|
|
},
|
|
speed: 'fast'
|
|
});
|
|
$("#gSiteMenu").css("display", "block");
|
|
|
|
// Initialize status message effects
|
|
$("#gMessage li").gallery_show_message();
|
|
|
|
// Initialize dialogs
|
|
$("#gLoginLink").addClass("gDialogLink");
|
|
$(".gDialogLink").gallery_dialog();
|
|
|
|
// Initialize view menu
|
|
if ($("#gViewMenu").length) {
|
|
$("#gViewMenu ul").removeClass("gMenu").removeClass("sf-menu");
|
|
$("#gViewMenu a").addClass("ui-icon");
|
|
}
|
|
|
|
// Initialize short forms
|
|
handleShortFormEvent(shortForms);
|
|
$(".gShortForm input[type=text]").addClass("ui-corner-left");
|
|
$(".gShortForm input[type=submit]").addClass("ui-state-default ui-corner-right");
|
|
|
|
// Apply jQuery UI button css to submit inputs
|
|
$("input[type=submit]:not(.gShortForm input)").addClass("ui-state-default ui-corner-all");
|
|
|
|
// Apply styles and icon classes to gContextMenu
|
|
if ($(".gContextMenu").length) {
|
|
$(".gContextMenu li").addClass("ui-state-default");
|
|
$(".gContextMenu a").addClass("gButtonLink ui-icon-left");
|
|
$(".gContextMenu a").prepend("<span class=\"ui-icon\"></span>");
|
|
$(".gContextMenu a span").each(function() {
|
|
var iconClass = $(this).parent().attr("class").match(/ui-icon-.[^\s]+/).toString();
|
|
$(this).addClass(iconClass);
|
|
});
|
|
}
|
|
|
|
// Album view only
|
|
if ($("#gAlbumGrid").length) {
|
|
// Vertical align thumbnails/metadata in album grid
|
|
$(".gItem").gallery_valign();
|
|
|
|
// Initialize context menus
|
|
$(".gItem").hover(
|
|
function(){
|
|
// Insert invisible placeholder to hold the item's position in the grid
|
|
var placeHolder = $(this).clone();
|
|
$(placeHolder).attr("id", "gPlaceHolder");
|
|
$(placeHolder).css("visibility", "hidden");
|
|
$(this).after($(placeHolder));
|
|
// Style and position the item
|
|
$(this).addClass("gHoverItem");
|
|
var position = $(this).position();
|
|
$(this).css("position", "absolute");
|
|
$(this).css("top", position.top);
|
|
$(this).css("left", position.left);
|
|
$(this).css("z-index", "1000");
|
|
// Initialize the contextual menu
|
|
$(this).gallery_context_menu();
|
|
// Set height based on height of descendents
|
|
var title = $(this).find("h2");
|
|
var meta = $(this).find(".gMetadata");
|
|
var context_label = $(this).find(".gContextMenu li:first");
|
|
var item_ht = $(this).height();
|
|
var title_ht = $(title).gallery_height();
|
|
var meta_ht = $(meta).gallery_height();
|
|
var context_label_ht = $(context_label).gallery_height();
|
|
$(this).height(item_ht + title_ht + meta_ht + context_label_ht);
|
|
},
|
|
function() {
|
|
// Reset item height, position, and z-index
|
|
var sib_height = $(this).next().height();
|
|
$(this).css("height", sib_height);
|
|
$(this).css("position", "relative");
|
|
$(this).css("top", null);
|
|
$(this).css("left", null);
|
|
$(this).css("z-index", null);
|
|
// Remove the placeholder and hover class from the item
|
|
$("#gPlaceHolder").remove();
|
|
$(this).removeClass("gHoverItem");
|
|
}
|
|
);
|
|
}
|
|
|
|
// Photo/Item item view
|
|
if ($("#gItem").length) {
|
|
// Ensure the resized image fits within its container
|
|
$("#gItem").gallery_fit_photo();
|
|
|
|
// Initialize context menus
|
|
var resize = $("#gItem").gallery_get_photo();
|
|
$(resize).hover(function(){
|
|
$(this).gallery_context_menu();
|
|
});
|
|
|
|
// Add scroll effect for links to named anchors
|
|
$.localScroll({
|
|
queue: true,
|
|
duration: 1000,
|
|
hash: true
|
|
});
|
|
}
|
|
|
|
// Initialize button hover effect
|
|
$.fn.gallery_hover_init();
|
|
|
|
});
|