/**
* Folder tree for WP Media Folder
*/
let wpmfFoldersTreeModule;
(function ($) {
wpmfFoldersTreeModule = {
categories: [], // categories
folders_states: [], // Contains open or closed status of folders
cloudInterval: false,
/**
* Retrieve the Jquery tree view element
* of the current frame
* @return jQuery
*/
getTreeElement: function () {
if (wpmfFoldersModule.page_type === 'upload-grid' || wpmfFoldersModule.page_type === 'upload-list') {
return $('.upload-php .wpmf-main-tree');
} else {
return wpmfFoldersModule.getFrame().find('.wpmf-main-tree').first();
}
},
/**
* Initialize module related things
*/
initModule: function ($current_frame) {
// Check if this frame has already the tree view
let is_initialized;
if (wpmfFoldersModule.page_type === 'upload-list' || wpmfFoldersModule.page_type === 'upload-grid') {
is_initialized = $('.upload-php .wpmf-main-tree').length > 0;
} else {
// not show tree on 900px of screen
if ($(window).width() <= 900) {
return;
}
if ($current_frame.hasClass('hide-menu')) {
// add placeholder for search media input
$current_frame.find('#media-search-input').attr('placeholder', $current_frame.find('.media-search-input-label').text());
if ($(window).width() > 768) {
$current_frame.addClass("wpmf-treeview").removeClass("hide-menu");
}
}
is_initialized = $current_frame.find('.media-frame-menu .wpmf-main-tree').length > 0;
}
if (is_initialized) {
// Show folder tree in case it has been hidden previously
wpmfFoldersTreeModule.getTreeElement().show();
return;
}
// Import categories from wpmf main module
wpmfFoldersTreeModule.importCategories();
if (typeof wpmf.vars.hide_tree !== "undefined" && parseInt(wpmf.vars.hide_tree) === 1) {
if (wpmfFoldersModule.page_type === 'upload-list' || wpmfFoldersModule.page_type === 'upload-grid') {
if (!$('.wpmf-main-tree').length) {
if ($(window).width() < 600) {
$('
').insertBefore($('ul.attachments'));
} else {
$('').insertBefore($('#wpbody-content'));
}
}
} else {
let $menu = $current_frame.find('.media-frame-menu .media-menu');
if (!$menu.length) {
$menu = $current_frame.find('.media-frame-menu');
$current_frame.find('.media-frame-menu-heading').hide();
}
if (!$menu.find('.wpmf-main-tree').length) {
$('').appendTo($menu);
}
}
// Render the tree view
wpmfFoldersTreeModule.loadTreeView();
}
// Subscribe to the change folder event in main wpmf module
wpmfFoldersModule.on('changeFolder', function (folder_id) {
wpmfFoldersTreeModule.changeFolder(folder_id);
});
// Subscribe to the add folder event in main wpmf module
wpmfFoldersModule.on(['addFolder', 'deleteFolder', 'updateFolder', 'moveFolder', 'foldersSelection', 'loadmoreFolder'], function (folder) {
wpmfFoldersTreeModule.importCategories();
wpmfFoldersTreeModule.loadTreeView();
// Initialize folder tree resizing
wpmfFoldersTreeModule.initContainerResizing($current_frame);
});
// Subscribe to the move file event in main wpmf module
wpmfFoldersModule.on('moveFile', function (files_ids, folder_to_id, folder_from_id) {
// Import categories with updated count
wpmfFoldersTreeModule.importCategories();
// Reload tree view
wpmfFoldersTreeModule.loadTreeView();
wpmfFoldersTreeModule.initContainerResizing($current_frame);
});
wpmfFoldersModule.on('deleteFile', function (folder_id) {
// Update file count in main wpmf Module
wpmfFoldersModule.categories[folder_id].files_count -= 1;
// Import categories with updated count
wpmfFoldersTreeModule.importCategories();
// Reload tree view
wpmfFoldersTreeModule.loadTreeView();
wpmfFoldersTreeModule.initContainerResizing($current_frame);
});
wpmfFoldersModule.on('duplicateFile', function (folder_id) {
// Update file count in main wpmf Module
wpmfFoldersModule.categories[folder_id].files_count += 1;
// Import categories with updated count
wpmfFoldersTreeModule.importCategories();
// Reload tree view
wpmfFoldersTreeModule.loadTreeView();
wpmfFoldersTreeModule.initContainerResizing($current_frame);
});
wpmfFoldersModule.on('addRemoteVideo', function (folder_id) {
// Update file count in main wpmf Module
wpmfFoldersModule.categories[folder_id].files_count += 1;
console.log(wpmfFoldersModule.categories[folder_id].files_count);
// Import categories with updated count
wpmfFoldersTreeModule.importCategories();
// Reload tree view
wpmfFoldersTreeModule.loadTreeView();
wpmfFoldersTreeModule.initContainerResizing($current_frame);
});
// Initialize the fixed tree view position on scrolling
if (wpmf.vars.wpmf_pagenow === 'upload.php') {
wpmfFoldersTreeModule.initFixedScrolling($current_frame);
}
// Subscribe to ordering folder filter
wpmfFoldersFiltersModule.on('foldersOrderChanged', function () {
wpmfFoldersTreeModule.importCategories();
wpmfFoldersTreeModule.loadTreeView();
wpmfFoldersTreeModule.initContainerResizing($current_frame);
});
wpmfFoldersModule.on('foldersOrderChanged', function () {
wpmfFoldersTreeModule.importCategories();
wpmfFoldersTreeModule.loadTreeView();
wpmfFoldersTreeModule.initContainerResizing($current_frame);
});
wpmfFoldersModule.on('foldersCountChanged', function () {
wpmfFoldersTreeModule.loadTreeView();
wpmfFoldersTreeModule.initContainerResizing($current_frame);
});
// Subscribe to gallery editing to hide folder tree
wpmfFoldersModule.on('wpGalleryEdition', function () {
wpmfFoldersTreeModule.getTreeElement().hide();
});
},
/**
* Import categories from wpmf main module
*/
importCategories: function () {
let folders_ordered = [];
// Add each category
$(wpmfFoldersModule.categories_order).each(function () {
folders_ordered.push(wpmfFoldersModule.categories[this]);
});
let folder_order = wpmfFoldersModule.getCookie('media-order-folder' + wpmf.vars.host);
if (typeof folder_order !== "undefined") {
wpmfFoldersModule.folder_ordering = folder_order;
}
// Order the array depending on main ordering
switch (wpmfFoldersModule.folder_ordering) {
default:
case 'name-ASC':
folders_ordered = Object.values(folders_ordered).sort(function (a, b) {
if (a.id === 0) return -1; // Root folder is always first
if (b.id === 0) return 1; // Root folder is always first
return a.label.localeCompare(b.label);
});
break;
case 'name-DESC':
folders_ordered = Object.values(folders_ordered).sort(function (a, b) {
if (a.id === 0) return -1; // Root folder is always first
if (b.id === 0) return 1; // Root folder is always first
return b.label.localeCompare(a.label);
});
break;
case 'id-ASC':
folders_ordered = Object.values(folders_ordered).sort(function (a, b) {
if (a.id === 0) return -1; // Root folder is always first
if (b.id === 0) return 1; // Root folder is always first
return a.id - b.id;
});
break;
case 'id-DESC':
folders_ordered = Object.values(folders_ordered).sort(function (a, b) {
if (a.id === 0) return -1; // Root folder is always first
if (b.id === 0) return 1; // Root folder is always first
return b.id - a.id;
});
break;
case 'custom':
folders_ordered = Object.values(folders_ordered).sort(function (a, b) {
if (a.id === 0) return -1; // Root folder is always first
if (b.id === 0) return 1; // Root folder is always first
return a.order - b.order;
});
break;
}
// Reorder array based on children
let folders_ordered_deep = [];
let processed_ids = [];
const loadChildren = function (id) {
if (processed_ids.indexOf(id) < 0) {
processed_ids.push(id);
for (let ij = 0; ij < folders_ordered.length; ij++) {
if (folders_ordered[ij].parent_id === id) {
folders_ordered_deep.push(folders_ordered[ij]);
loadChildren(folders_ordered[ij].id);
}
}
}
};
loadChildren(0);
// Finally save it to the global var
wpmfFoldersTreeModule.categories = folders_ordered_deep;
},
/**
* Render tree view inside content
*/
loadTreeView: function () {
if (typeof wpmf.vars.hide_tree !== "undefined" && parseInt(wpmf.vars.hide_tree) === 0) {
return;
}
// update height for folder tree when toggle menu
if (wpmf.vars.wpmf_pagenow !== 'upload.php') {
let $current_frame = wpmfFoldersTreeModule.getTreeElement().closest('.media-frame');
const $menu = $current_frame.find('.media-frame-menu');
if (!$current_frame.find('.wpmf-toggle-media-menu').length) {
$current_frame.addClass('wpmf_hide_media_menu');
$current_frame.find('.media-frame-menu-heading').append(' arrow_drop_down arrow_drop_up ');
$current_frame.find('.wpmf-toggle-media-menu').off('click').bind('click', function () {
var h = 220;
if ($menu.find('.wpmf-all-tree').hasClass('wpmf-tree-loadmore')) {
h += 70;
}
if ($current_frame.hasClass('wpmf_hide_media_menu')) {
$current_frame.removeClass('wpmf_hide_media_menu').addClass('wpmf_show_media_menu');
var a = $menu.find(".media-menu-item").length;
$menu.find('.wpmf-all-tree').height($menu.height() - 34 * a - h);
} else {
$current_frame.removeClass('wpmf_show_media_menu').addClass('wpmf_hide_media_menu');
$menu.find('.wpmf-all-tree').height($menu.height() - h);
}
});
}
}
// render folder tree
wpmfFoldersTreeModule.getTreeElement().html(wpmfFoldersTreeModule.getRendering());
wpmfFoldersTreeModule.initContainerResizing(wpmfFoldersModule.getFrame());
$('.wpmf-loadmore-folder').unbind('click').bind('click', function () {
var count = $(this).data('count');
count += parseInt(wpmfFoldersModule.limit_folders);
if (parseInt(count) < wpmfFoldersModule.categories_order_full.length) {
wpmfFoldersModule.categories_order = wpmfFoldersModule.categories_order_full.slice(0, count);
wpmfFoldersModule.trigger('loadmoreFolder');
}
});
$('.wpmf-cancel-remove-folders-btn').unbind('click').bind('click', function (e) {
e.preventDefault();
$('.wpmf-folder-actions').toggleClass('wpmf-deactivate');
$('.wpmf-tree-actions').find('.wpmf-new-folder').removeClass('hide');
$('.wpmf-tree-checkbox').addClass('hide');
});
$('.wpmf-remove-folders-btn').unbind('click').bind('click', function (e) {
e.preventDefault();
if (!$(this).hasClass('disabled')) {
var ids = [];
$('.wpmf-tree-checkbox:checked').each(function (i, checkbox) {
let folder_id = $(checkbox).val();
ids.push(folder_id);
});
showDialog({
title: wpmf.l18n.delete_multiple_folder.replace('%d', ids.length),
negative: {
title: wpmf.l18n.cancel
},
positive: {
title: wpmf.l18n.delete,
onClick: function () {
wpmfFoldersModule.deleteMultipleFolders(ids);
}
}
});
}
});
$('.wpmf-tree-checkbox').unbind('click').bind('click', function () {
if ($(this).is(':checked')) {
$(this).closest('li').find('ul .wpmf-tree-checkbox').prop('checked', true);
} else {
$(this).closest('li').find('ul .wpmf-tree-checkbox').prop('checked', false);
}
if ($('.wpmf-tree-checkbox:checked').length) {
$('.wpmf-remove-folders-btn').removeClass('disabled');
} else {
$('.wpmf-remove-folders-btn').addClass('disabled');
}
});
// load count by subfolders
if (wpmfFoldersModule.show_files_count) {
if (wpmfFoldersTreeModule.categories.length < 1000) {
wpmfFoldersTreeModule.loadCountAll();
} else {
wpmfFoldersTreeModule.getTreeElement().addClass('wpmf-many-folders');
}
}
wpmfFoldersModule.openContextMenuFolder();
let append_element;
if (wpmfFoldersModule.page_type === 'upload-list') {
append_element = '#posts-filter';
} else {
append_element = '.media-frame';
}
let folder_order = wpmfFoldersModule.getCookie('media-order-folder' + wpmf.vars.host);
let sortable = false;
if (typeof folder_order !== "undefined" && folder_order === 'custom') {
sortable = true;
}
if (sortable) {
if ($().sortable) {
wpmfFoldersTreeModule.getTreeElement().find('ul').sortable({
placeholder: 'wpmf_tree_drop_sort',
delay: 100, // Prevent dragging when only trying to click
distance: 10,
cursorAt: {top: 10, left: 10},
revert: true,
revertDuration: 1000,
/*tolerance: "intersect",*/
helper: function (ui) {
var helper = '
`;
// get last status folder tree
let lastStatusTree = wpmfFoldersModule.getCookie('lastStatusTree_' + wpmf.vars.host);
if (lastStatusTree !== '') {
lastStatusTree = JSON.parse(lastStatusTree);
}
/**
* Recursively print list of folders
* @return {boolean}
*/
const generateList = function (tree_class = '') {
content += '
';
while (ij < wpmfFoldersTreeModule.categories.length) {
let className = '';
// get color folder
let bgcolor = '', odvColor = '';
if (typeof wpmf.vars.colors !== 'undefined' && typeof wpmf.vars.colors[wpmfFoldersTreeModule.categories[ij].id] !== 'undefined') {
bgcolor = 'color: ' + wpmf.vars.colors[wpmfFoldersTreeModule.categories[ij].id];
odvColor = wpmf.vars.colors[wpmfFoldersTreeModule.categories[ij].id];
} else {
bgcolor = 'color: #b2b2b2';
odvColor = '#b2b2b2';
}
let icondrive;
if (parseInt(wpmfFoldersTreeModule.categories[ij].id) === 0) {
icondrive = '';
} else {
icondrive = 'folder';
}
if (lastStatusTree.indexOf(wpmfFoldersTreeModule.categories[ij].id) !== -1 || parseInt(wpmfFoldersTreeModule.categories[ij].id) === 0) {
className += 'open ';
} else {
className += 'closed ';
}
let drive_root = false;
// get last access folder
let lastAccessFolder = wpmfFoldersModule.getCookie('lastAccessFolder_' + wpmf.vars.host);
// Select the last element which was selected in wpmf main module
if (typeof lastAccessFolder === "undefined" || (typeof lastAccessFolder !== "undefined" && lastAccessFolder === '') || (typeof lastAccessFolder !== "undefined" && parseInt(lastAccessFolder) === 0) || typeof wpmfFoldersModule.categories[lastAccessFolder] === "undefined") {
if (wpmfFoldersTreeModule.categories[ij].id === wpmfFoldersModule.last_selected_folder) {
className += 'selected ';
}
} else {
if (wpmfFoldersTreeModule.categories[ij].id === parseInt(lastAccessFolder)) {
className += 'selected ';
}
}
if (parseInt(wpmf.vars.wpmf_addon_active) === 1) {
if (wpmfFoldersTreeModule.categories[ij].drive_type === 'onedrive_business') {
if (parseInt(wpmfFoldersTreeModule.categories[ij].parent_id) === 0) {
drive_root = true;
className += 'onedrive_business_list wpmf_drive_tree';
className = className.replace('closed', '');
}
}
if (wpmfFoldersTreeModule.categories[ij].drive_type === 'onedrive') {
if (parseInt(wpmfFoldersTreeModule.categories[ij].parent_id) === 0) {
drive_root = true;
className += 'onedrive_list wpmf_drive_tree';
className = className.replace('closed', '');
}
}
if (wpmfFoldersTreeModule.categories[ij].drive_type === 'onedrive' || wpmfFoldersTreeModule.categories[ij].drive_type === 'onedrive_business') {
icondrive = ``;
}
if (wpmfFoldersTreeModule.categories[ij].drive_type === 'dropbox') {
if (parseInt(wpmfFoldersTreeModule.categories[ij].parent_id) === 0) {
drive_root = true;
className += 'dropbox_list wpmf_drive_tree';
className = className.replace('closed', '');
}
icondrive = '';
}
if (wpmfFoldersTreeModule.categories[ij].drive_type === 'google_drive') {
if (parseInt(wpmfFoldersTreeModule.categories[ij].parent_id) === 0) {
drive_root = true;
className += 'google_drive_list wpmf_drive_tree';
className = className.replace('closed', '');
}
icondrive = '';
}
if (wpmfFoldersTreeModule.categories[ij].drive_type === 'nextcloud') {
if (parseInt(wpmfFoldersTreeModule.categories[ij].parent_id) === 0) {
drive_root = true;
className += 'nextcloud_list wpmf_drive_tree';
className = className.replace('closed', '');
}
icondrive = '';
}
if (typeof wpmfFoldersTreeModule.categories[ij].drive_type === 'undefined' || wpmfFoldersTreeModule.categories[ij].drive_type === '') {
className += ' wpmf_local_tree ';
}
}
// Open li tag
content += '
';
let pad = (wpmfFoldersTreeModule.categories[ij].depth) * 15;
if (wpmfFoldersTreeModule.categories[ij].drive_type !== '') {
pad = pad - 20;
}
content += '
';
// This is the end of the array
if (wpmfFoldersTreeModule.categories[ij + 1] === undefined) {
// Let's close all opened tags
for (let ik = wpmfFoldersTreeModule.categories[ij].depth; ik >= 0; ik--) {
content += '
';
content += '
';
}
// We are at the end don't continue to process array
return false;
}
if (wpmfFoldersTreeModule.categories[ij + 1].depth > wpmfFoldersTreeModule.categories[ij].depth) { // The next element is a sub folder
// Recursively list it
ij++;
if (generateList() === false) {
// We have reached the end, let's recursively end
return false;
}
} else if (wpmfFoldersTreeModule.categories[ij + 1].depth < wpmfFoldersTreeModule.categories[ij].depth) { // The next element don't have the same parent
// Let's close opened tags
for (let ik = wpmfFoldersTreeModule.categories[ij].depth; ik > wpmfFoldersTreeModule.categories[ij + 1].depth; ik--) {
content += '';
content += '';
}
// We're not at the end of the array let's continue processing it
return true;
}
// Close the current element
content += '';
ij++;
}
};
// Start generation
generateList('wpmf_media_library');
let loadmore = '';
if (wpmfFoldersModule.categories_order_full.length > wpmfFoldersModule.limit_folders) {
loadmore = ' expand_more ' + wpmf.l18n.load_more + '';
}
// Add the new folder button
content = '
' + search_folder + content + loadmore + search_no_result;
return content;
},
/**
* Change the selected folder in tree view
* @param folder_id
*/
changeFolder: function (folder_id) {
// Remove previous selection
wpmfFoldersTreeModule.getTreeElement().find('li').removeClass('selected');
// Select the folder
wpmfFoldersTreeModule.getTreeElement().find('li[data-id="' + folder_id + '"]').addClass('selected').// Open parent folders
parents('.wpmf-main-tree li.closed').removeClass('closed');
},
/**
* Toggle the open / closed state of a folder
* @param folder_id
*/
toggle: function (folder_id) {
// get last status folder tree
let lastStatusTree = [];
// Check is folder has closed class
if (wpmfFoldersTreeModule.getTreeElement().find('li[data-id="' + folder_id + '"]').hasClass('closed')) {
// Open the folder
wpmfFoldersTreeModule.openFolder(folder_id);
} else {
// Close the folder
wpmfFoldersTreeModule.closeFolder(folder_id);
// close all sub folder
$('li[data-id="' + folder_id + '"]').find('li').addClass('closed');
}
wpmfFoldersTreeModule.getTreeElement().find('li:not(.closed)').each(function (i, v) {
let id = $(v).data('id');
lastStatusTree.push(id);
});
// set last status folder tree
wpmfFoldersModule.setCookie("lastStatusTree_" + wpmf.vars.host, JSON.stringify(lastStatusTree), 365);
},
/**
* Open a folder to show children
*/
openFolder: function (folder_id) {
wpmfFoldersTreeModule.getTreeElement().find('li[data-id="' + folder_id + '"]').removeClass('closed');
wpmfFoldersTreeModule.folders_states[folder_id] = 'open';
},
/**
* Close a folder and hide children
*/
closeFolder: function (folder_id) {
wpmfFoldersTreeModule.getTreeElement().find('li[data-id="' + folder_id + '"]').addClass('closed');
wpmfFoldersTreeModule.folders_states[folder_id] = 'close';
},
/**
* Initialize the fixed position when user is scrolling
* to keep the folder tree always visible
*/
initFixedScrolling: function () {
if (typeof wpmf.vars.hide_tree !== "undefined" && parseInt(wpmf.vars.hide_tree) === 0) {
return;
}
setTimeout(function () {
// Fix initial left margin in list view
if (wpmfFoldersModule.page_type === 'upload-list' || wpmfFoldersModule.page_type === 'upload-grid') {
let $tree = $('.wpmf-main-tree');
let tree_width = $tree.outerWidth() + 'px';
let $admin_bar_height = $('#wpadminbar').height();
if ($admin_bar_height > 32) {
$tree.css('top', $admin_bar_height + 'px');
}
$('#wpbody-content').css({'width': 'calc(100% - '+ tree_width +')','margin-left': tree_width, 'opacity': 1, 'padding-left': '20px', 'box-sizing': 'border-box'});
// trigger window resize to set attachments columns
if (wpmfFoldersModule.page_type === 'upload-grid') {
$(window).trigger('resize');
}
$('.rtl #wpbody-content').css({
'margin-right': (wpmfFoldersTreeModule.getTreeElement().outerWidth()) + 'px',
'margin-left': 0,
'opacity': 1,
'padding-right': '20px',
'box-sizing': 'border-box'
});
$tree.css({'opacity': 1});
// Remove the loader on list page
if (!$('.upload-php #posts-filter').hasClass('listview-loaded')) {
setTimeout(function () {
$('.upload-php #posts-filter').addClass('listview-loaded');
}, 200);
}
}
}, 200);
},
/**
* Initialize folder tree resizing
* @param $current_frame
*/
initContainerResizing: function ($current_frame) {
if (typeof wpmf.vars.hide_tree !== "undefined" && parseInt(wpmf.vars.hide_tree) === 0) {
return;
}
let is_resizing = false;
const $body = $('body');
$(window).on('resize', function () {
$('.wpmf-all-tree.scrollbar-inner').scrollbar();
});
if (wpmf.vars.wpmf_pagenow === 'upload.php' && wpmfFoldersModule.page_type) {
// Main upload.php page
let $main = $('#wpbody');
let $tree = $('.wpmf-main-tree');
let $right_min_width = 500;
let $tree_min_width = 250;
const $handle = $('').appendTo($tree);
$handle.on('mousedown', function (e) {
is_resizing = true;
$('body').css('user-select', 'none'); // prevent content selection while moving
});
let uploadPageTreeSize = wpmfFoldersModule.getCookie('upload-page-tree-size');
if (uploadPageTreeSize < $tree_min_width) uploadPageTreeSize = $tree_min_width;
if (typeof uploadPageTreeSize !== "undefined" && parseFloat(uploadPageTreeSize) > 0) {
$tree.css({'width': parseFloat(uploadPageTreeSize) + 'px'});
}
$(document).on('mousemove', function (e) {
// we don't want to do anything if we aren't resizing.
if (!is_resizing)
return;
// Calculate tree width
let tree_width = (e.clientX - $tree.offset().left);
if (tree_width < $tree_min_width) tree_width = $tree_min_width;
let right_width = $main.width() - tree_width;
if (right_width < $right_min_width) {
right_width = $right_min_width;
tree_width = $main.width() - $right_min_width;
}
$tree.css('width', tree_width + 'px');
// We have to set margin if we are in a fixed tree position or in list page
if ($('body').hasClass('rtl')) {
$('#wpbody-content').css({'width': right_width + 'px', 'margin-right': tree_width + 'px', 'padding-right': '20px', 'box-sizing': 'border-box'});
} else {
$('#wpbody-content').css({'width': right_width + 'px', 'margin-left': tree_width + 'px', 'padding-left': '20px', 'box-sizing': 'border-box'});
}
wpmfFoldersModule.setCookie('upload-page-tree-size', tree_width, 365);
}).on('mouseup', function (e) {
if (is_resizing) {
// stop resizing
is_resizing = false;
$body.css('user-select', '');
$(window).trigger('resize');
}
});
} else {
// Modal window with left menu
const $right_min_width = 800;
const $tree_min_width = 250;
const $main = $('.media-modal-content:visible');
const $menu = $current_frame.find('.media-frame-menu');
const $tree = $current_frame.find('.wpmf-main-tree');
const $handle = $('').appendTo($tree);
const $right_cols = $current_frame.find('.media-frame-content, .media-frame-router, .media-frame-title, .media-frame-toolbar');
if ($menu) {
var h = 180;
if ($menu.find('.wpmf-all-tree').hasClass('wpmf-tree-loadmore')) {
h += 70;
}
if ($current_frame.hasClass('wpmf_hide_media_menu')) {
$menu.find('.wpmf-all-tree').height($menu.height() - h);
} else {
var a = $menu.find(".media-menu-item").length;
$menu.find('.wpmf-all-tree').height($menu.height() - 34 * a - h);
}
}
$tree.css({'min-width': 0, 'border-right': 0});
$handle.on('mousedown', function (e) {
is_resizing = true;
$body.css('user-select', 'none'); // prevent content selection while moving
});
let tree_width = wpmfFoldersModule.getCookie('menu-tree-size');
if (tree_width < $tree_min_width) tree_width = $tree_min_width;
if (typeof tree_width !== "undefined" && parseFloat(tree_width) > 0) {
$menu.css('width', parseFloat(tree_width) + 'px');
if ($('body').hasClass('rtl')) {
$right_cols.css('right', (parseFloat(tree_width) + 14) + 'px');
} else {
$right_cols.css('left', (parseFloat(tree_width) + 14) + 'px');
}
}
$(document).on('mousemove', function (e) {
// we don't want to do anything if we aren't resizing.
if (!is_resizing)
return;
let menu_width = (e.clientX - $menu.offset().left);
if (menu_width < $tree_min_width) menu_width = $tree_min_width;
let right_width = $main.width() - menu_width;
if (right_width < $right_min_width) {
menu_width = $main.width() - $right_min_width;
}
$menu.css('width', menu_width + 'px');
if ($('body').hasClass('rtl')) {
$right_cols.css('right', (parseFloat(menu_width) + 14) + 'px');
} else {
$right_cols.css('left', (parseFloat(menu_width) + 14) + 'px');
}
wpmfFoldersModule.setCookie('menu-tree-size', menu_width, 365);
}).on('mouseup', function (e) {
if (is_resizing) {
// stop resizing
is_resizing = false;
$body.css('user-select', '');
$(window).trigger('resize');
}
});
}
}
};
// Let's initialize WPMF folder tree features
$(document).ready(function () {
if (typeof wpmfFoldersModule !== "undefined") {
if (wpmfFoldersModule.page_type === 'upload-list') {
// Don't need to wait on list page
wpmfFoldersTreeModule.initModule(wpmfFoldersModule.getFrame());
} else {
// Wait for the main wpmf module to be ready
wpmfFoldersModule.on('ready', function ($current_frame) {
setTimeout(function () {
wpmfFoldersTreeModule.initModule($current_frame);
},200);
});
}
}
});
})(jQuery);
// call single click or double click on folder tree
jQuery.fn.wpmfSingleDoubleClick = function (single_click_callback, double_click_callback, timeout) {
return this.each(function () {
var clicks = 0, self = this;
jQuery(this).on('click', function (event) {
clicks++;
if (clicks === 1) {
setTimeout(function () {
if (clicks === 1) {
single_click_callback.call(self, event);
} else {
double_click_callback.call(self, event);
}
clicks = 0;
}, timeout || 300);
}
});
});
};
jQuery.fn.wpmfHandleKeyboardChange = function (nDelay) {
// Utility function to test if a keyboard event should be ignored
function shouldIgnore(event) {
var mapIgnoredKeys = {
9: true, // Tab
16: true, 17: true, 18: true, // Shift, Alt, Ctrl
37: true, 38: true, 39: true, 40: true, // Arrows
91: true, 92: true, 93: true // Windows keys
};
return mapIgnoredKeys[event.which];
}
// Utility function to fire OUR change event if the value was actually changed
function fireChange($element) {
if ($element.val() != jQuery.data($element[0], "valueLast")) {
jQuery.data($element[0], "valueLast", $element.val())
$element.trigger("change");
}
}
// The currently running timeout,
// will be accessed with closures
var timeout = 0;
// Utility function to cancel a previously set timeout
function clearPreviousTimeout() {
if (timeout) {
clearTimeout(timeout);
}
}
return this.keydown(function (event) {
if (shouldIgnore(event)) return;
// User pressed a key, stop the timeout for now
clearPreviousTimeout();
return null;
}).keyup(function (event) {
if (shouldIgnore(event)) return;
// Start a timeout to fire our event after some time of inactivity
// Eventually cancel a previously running timeout
clearPreviousTimeout();
var $self = jQuery(this);
timeout = setTimeout(function () {
fireChange($self)
}, nDelay);
}).change(function () {
// Fire a change
// Use our function instead of just firing the event
// Because we want to check if value really changed since
// our previous event.
// This is for when the browser fires the change event
// though we already fired the event because of the timeout
fireChange(jQuery(this));
});
};