first commit

This commit is contained in:
2026-03-05 13:07:40 +01:00
commit 64ba0721ee
25709 changed files with 4691006 additions and 0 deletions

View File

@@ -0,0 +1,259 @@
(function($) {
function initialize_field($el) {
//$el.doStuff();
}
function acf_photo_gallery_remove_media(id, field) {
$('.acf-photo-gallery-group-' + field + ' .acf-photo-gallery-mediabox-' + id).fadeOut('fast').remove();
if ($('.acf-photo-gallery-group-' + field + ' .acf-photo-gallery-metabox-list li').length < 1) {
$('.acf-photo-gallery-group-' + field + ' .acf-photo-gallery-metabox-list').append('<li class="acf-photo-gallery-media-box-placeholder"><span class="dashicons dashicons-format-image"></span></li>');
}
}
$(document).ready(function() {
$(".acf-photo-gallery-metabox-list").sortable({
containment: "parent",
placeholder: "acf-photo-gallery-sortable-placeholder",
tolerance: 'pointer'
}).disableSelection();
});
function acf_photo_gallery_edit(id, url, title, caption) {
var html;
html = '<div id="acf-photo-gallery-metabox-edit-' + id + '" class="acf-edit-photo-gallery">';
html += '<h3>Edit Image</h3>';
html += '<label>URL</label><input type="text" value="' + url + '"/>';
html += '<label><input type="checkbox" value="1"/>Open in new tab</label>';
html += '<label>Title</label><input type="text" value="' + title + '"/>';
html += '<label>Caption</label><textarea>' + caption + '</textarea>';
html += '<button class="button button-primary button-large" type="button">Save Changes</button>';
html += '<button class="button button-large button-close" type="button" data-close="' + id + '">Close</button>';
html += '</div>';
return html;
}
/**
* @param {{ index: number, splice: number }} options
*/
function acf_photo_gallery_html(attachment, field, options) {
var edit_box_html, presentation_html, id, url, title, caption;
id = attachment.id;
url = attachment.url;
title = attachment.title;
caption = attachment.caption;
var JsonField = jQuery.parseJSON(field);
if (typeof attachment.sizes.thumbnail != 'undefined') { url = attachment.sizes.thumbnail.url; }
edit_box_html = acf_photo_gallery_edit(id, url, title, caption);
$('.acf-photo-gallery-group-' + JsonField.key + ' .acf-photo-gallery-metabox-edit').append(edit_box_html);
var $list = $('.acf-photo-gallery-group-' + JsonField.key + ' .acf-photo-gallery-metabox-list');
presentation_html = '<li class="acf-photo-gallery-mediabox acf-photo-gallery-mediabox-' + id + '" data-id="' + id + '"><a class="dashicons dashicons-dismiss" href="#" data-id="' + id + '" data-field="' + JsonField.key + '" title="Remove this photo from the gallery"></a><input type="hidden" name="' + JsonField._name + '[]" value="' + id + '"/><img src="' + url + '"/></li>';
if (options.index) {
var $cursor = $list.children().eq(options.index);
$cursor.before(presentation_html);
if (options.splice) { $cursor.remove(); }
} else {
$list.prepend(presentation_html);
}
}
function acf_photo_gallery_add_media($el) {
var acf_photo_gallery_ids = new Array();
if ($('.acf-photo-gallery-metabox-add-images').length > 0) {
if (typeof wp !== 'undefined' && wp.media && wp.media.editor) {
$(document).on('click', '.acf-photo-gallery-metabox-add-images', function(e) {
e.preventDefault();
var button = $(this);
var id = button.prev();
var field = button.attr('data-field');
var JsonField = jQuery.parseJSON(field);
//On click of the add images button, check if the image limit has been reached
var pre_selected_list = $('.acf-photo-gallery-group-' + JsonField.key + ' .acf-photo-gallery-metabox-list li.acf-photo-gallery-mediabox');
var images_limit = $('.acf-photo-gallery-group-' + JsonField.key + ' input[name=\'acf-photo-gallery-images_limit\']').val();
if (images_limit != "" && pre_selected_list.length == images_limit) {
swal('Limit has been reached', 'Your website administrator has set a limit of ' + images_limit + ' images that can be added to this gallery.', 'error')
return false;
}
$(document).on('click', '.media-modal-content .attachments-browser .attachments li', function() {
var selection_list = $('.media-modal-content .attachments-browser .attachments li[aria-checked=true]').length;
var check_image_limit = pre_selected_list.length + selection_list;
console.log(images_limit);
if (images_limit != "" && check_image_limit > images_limit) {
$(this).click();
swal('Limit has been reached', 'Your website administrator has set a limit of ' + images_limit + ' images that can be added to this gallery.', 'error')
return false;
}
});
wp.media.editor.send.attachment = function(props, attachment) {
acf_photo_gallery_html(attachment, field, { index: 0, splice: 0 });
};
wp.media.editor.open(button, function() {});
if ($('.acf-photo-gallery-group-' + JsonField.key + ' .acf-photo-gallery-metabox-list li.acf-photo-gallery-media-box-placeholder').length > 0) {
$('.acf-photo-gallery-group-' + JsonField.key + ' .acf-photo-gallery-metabox-list li.acf-photo-gallery-media-box-placeholder').remove();
}
return false;
});
}
};
}
$(document).on('click', '.acf-photo-gallery-metabox-list .dashicons-dismiss', function() {
var id = $(this).attr('data-id');
var field = $(this).attr('data-field');
if (confirm('You are about to remove this photo from the gallery. Are you sure?')) {
acf_photo_gallery_remove_media(id, field);
}
return false;
});
$(document).on('click', '#acf-photo-gallery-metabox-edit .acf-edit-photo-gallery button.button-close', function() {
var id;
id = $(this).attr('data-close');
$('#acf-photo-gallery-metabox-edit #acf-photo-gallery-metabox-edit-' + id).fadeOut('fast');
$('.acf-gallery-backdrop').remove();
$('body').css('overflow', 'auto');
return false;
});
$(document).on('click', '#acf-photo-gallery-metabox-edit .acf-edit-photo-gallery button.button-primary', function() {
var button, field, data, post, attachment, action, nonce, fieldname, form = {};
button = $(this);
url = $(this).attr('data-ajaxurl');
action = 'acf_photo_gallery_edit_save';
attachment = $(this).attr('data-id');
fieldname = button.attr('data-fieldname');
$('div.acf-photo-gallery-group-' + fieldname + ' #acf-photo-gallery-metabox-edit-' + attachment + ' .acf-photo-gallery-edit-field').each(function(i, obj) {
if (obj.name == 'acf-pg-hidden-action') {
form['action'] = obj.value;
} else if (obj.type == 'checkbox') {
if ($(this).prop("checked")) {
form[obj.name] = obj.value;
} else {
form[obj.name] = null;
}
} else {
form[obj.name] = obj.value;
}
});
button.attr('disabled', true).html('Saving...');
$.post(url, form, function(data) {
button.attr('disabled', false).html('Save Changes');
$('#acf-photo-gallery-metabox-edit #acf-photo-gallery-metabox-edit-' + attachment).fadeOut('fast');
$('.acf-gallery-backdrop').remove();
$('body').css('overflow', 'auto');
});
return false;
});
$(document).on('click', '.acf-photo-gallery-metabox-list .dashicons-edit', function() {
var $btn = $(this);
var id = $btn.attr('data-id');
var field = $btn.attr('data-field');
var modal = $('.acf-photo-gallery-group-' + field + ' input[name="acf-photo-gallery-edit-modal"]').val();
var $list = $('.acf-photo-gallery-group-' + field + ' ul.acf-photo-gallery-metabox-list');
var index = $('.acf-photo-gallery-group-' + field + ' ul.acf-photo-gallery-metabox-list li').index();
$('body').prepend('<div class=\'acf-gallery-backdrop\'></div>');
$('body').css('overflow', 'hidden');
if (modal === 'Native') {
wp.media.editor.send.attachment = function(_, attachment) {
acf_photo_gallery_html(attachment, field, {
index: index,
splice: 1
});
};
var editor = wp.media.editor.open($btn, function() {}).state();
editor.set('menu', false);
var selection = editor.get('selection');
selection.multiple = false;
selection.reset([wp.media.attachment(id)]);
/**
* @param {{ id: number }} deleted
*/
var handleDestroy = function(deleted) {
$list.children().each(function() {
var $elem = $(this);
if ($elem.data('id') === deleted.id) {
remove($elem.find('.dashicons-dismiss'));
}
});
};
var library = editor.get('library');
library.on('destroy', handleDestroy);
editor.on('close', function() {
library.off('destroy', handleDestroy);
});
$('.acf-photo-gallery-group-' + field + ' .acf-photo-gallery-metabox-list li.acf-photo-gallery-media-box-placeholder').remove();
} else {
$('.acf-photo-gallery-group-' + field + ' #acf-photo-gallery-metabox-edit-' + id).fadeToggle('fast');
}
return false;
});
if (typeof acf.add_action !== 'undefined') {
/*
* ready append (ACF5)
*
* These are 2 events which are fired during the page load
* ready = on page load similar to $(document).ready()
* append = on new DOM elements appended via repeater field
*
* @type event
* @date 20/07/13
*
* @param $el (jQuery selection) the jQuery element which contains the ACF fields
* @return n/a
*/
acf.add_action('ready append', function($el) {
// search $el for fields of type 'photo_gallery'
acf.get_fields({ type: 'photo_gallery' }, $el).each(function() {
initialize_field($(this));
acf_photo_gallery_add_media($(this));
});
});
} else {
/*
* acf/setup_fields (ACF4)
*
* This event is triggered when ACF adds any new elements to the DOM.
*
* @type function
* @since 1.0.0
* @date 01/01/12
*
* @param event e: an event object. This can be ignored
* @param Element postbox: An element which contains the new HTML
*
* @return n/a
*/
$(document).on('acf/setup_fields', function(e, postbox) {
$(postbox).find('.field[data-field_type="photo_gallery"]').each(function() {
initialize_field($(this));
acf_photo_gallery_add_media($(this));
//acf_photo_gallery_edit_popover( $(this) );
//acf_photo_gallery_limit_images( $(this) );
});
});
}
})(jQuery);

File diff suppressed because one or more lines are too long