PHP Classes

File: assets/js/ckeditor/imagebrowser/browser/browser.js

Recommend this page to a friend!
  Classes of Gabriel Alejandro López López   Yii2 Website Module   assets/js/ckeditor/imagebrowser/browser/browser.js   Download  
File: assets/js/ckeditor/imagebrowser/browser/browser.js
Role: Auxiliary data
Content type: text/plain
Description: Auxiliary data
Class: Yii2 Website Module
Add a content page management system to a site
Author: By
Last change:
Date: 2 months ago
Size: 3,022 bytes
 

Contents

Class file image Download
var CkEditorImageBrowser = {}; CkEditorImageBrowser.folders = []; CkEditorImageBrowser.images = {}; //folder => list of images CkEditorImageBrowser.ckFunctionNum = null; CkEditorImageBrowser.init = function () { CkEditorImageBrowser.ckFunctionNum = CkEditorImageBrowser.getQueryStringParam('CKEditorFuncNum'); CkEditorImageBrowser.initEventHandlers(); CkEditorImageBrowser.loadData(decodeURIComponent(CkEditorImageBrowser.getQueryStringParam('listUrl')), function () { CkEditorImageBrowser.initFolderSwitcher(); }); }; CkEditorImageBrowser.loadData = function (url, onLoaded) { CkEditorImageBrowser.folders = []; CkEditorImageBrowser.images = {}; $.getJSON(url, function (list) { $.each(list, function (_idx, item) { if (typeof(item.folder) === 'undefined') { item.folder = 'Images'; } CkEditorImageBrowser.ensureFolderCreated(item.folder); CkEditorImageBrowser.addImage(item.folder, item.image, item.thumb); }); onLoaded(); }); }; CkEditorImageBrowser.ensureFolderCreated = function (folderName) { if (CkEditorImageBrowser.folders.indexOf(folderName) === -1) { CkEditorImageBrowser.folders.push(folderName); CkEditorImageBrowser.images[folderName] = []; } }; CkEditorImageBrowser.addImage = function (folderName, imageUrl, thumbUrl) { CkEditorImageBrowser.images[folderName].push({ "imageUrl": imageUrl, "thumbUrl": thumbUrl }); }; CkEditorImageBrowser.initFolderSwitcher = function () { var $switcher = $('#js-folder-switcher'); $switcher.find('option').remove(); $.each(CkEditorImageBrowser.folders, function (idx, folderName) { var $option = $('<option></option>').val(idx).text(folderName); $option.appendTo($switcher); }); if (CkEditorImageBrowser.folders.length === 1) { $switcher.hide(); } $switcher.trigger("change"); }; CkEditorImageBrowser.renderImagesForFolder = function (folderName) { var images = CkEditorImageBrowser.images[folderName], templateHtml = $('#js-template-image').html(), $imagesContainer = $('#js-images-container'); $imagesContainer.html(''); $.each(images, function (idx, imageData) { var html = templateHtml; html = html.replace('%imageUrl%', imageData.imageUrl); html = html.replace('%thumbUrl%', imageData.thumbUrl); var $item = $($.parseHTML(html)); $imagesContainer.append($item); }); }; CkEditorImageBrowser.initEventHandlers = function () { $('#js-folder-switcher').change(function () { var idx = parseInt($(this).val(), 10), folderName = CkEditorImageBrowser.folders[idx]; CkEditorImageBrowser.renderImagesForFolder(folderName); }); $(document).on('click', '.js-image-link', function () { var imageUrl = $(this).data('url'); window.opener.CKEDITOR.tools.callFunction(CkEditorImageBrowser.ckFunctionNum, imageUrl); window.close(); }); }; CkEditorImageBrowser.getQueryStringParam = function (name) { var regex = new RegExp('[\?|&]' + name + '=(.+?)[\&|$]'), result = window.location.search.match(regex); return (result && result.length > 1 ? result[1] : null); };