mirror of
https://github.com/wintercms/winter.git
synced 2024-06-28 05:33:29 +02:00
239 lines
5.9 KiB
JavaScript
239 lines
5.9 KiB
JavaScript
/*
|
|
* October General Utilities
|
|
*/
|
|
|
|
/*
|
|
* Ensure the CSRF token is added to all AJAX requests.
|
|
*/
|
|
|
|
$.ajaxPrefilter(function(options) {
|
|
var token = $('meta[name="csrf-token"]').attr('content')
|
|
|
|
if (token) {
|
|
if (!options.headers) options.headers = {}
|
|
options.headers['X-CSRF-TOKEN'] = token
|
|
}
|
|
})
|
|
|
|
/*
|
|
* Path helpers
|
|
*/
|
|
|
|
if ($.oc === undefined)
|
|
$.oc = {}
|
|
|
|
$.oc.backendUrl = function(url) {
|
|
var backendBasePath = $('meta[name="backend-base-path"]').attr('content')
|
|
|
|
if (!backendBasePath)
|
|
return url
|
|
|
|
if (url.substr(0, 1) == '/')
|
|
url = url.substr(1)
|
|
|
|
return backendBasePath + '/' + url
|
|
}
|
|
|
|
/*
|
|
* Asset Manager
|
|
*
|
|
* Usage: assetManager.load({ css:[], js:[], img:[] }, onLoadedCallback)
|
|
*/
|
|
|
|
AssetManager = function() {
|
|
|
|
var o = {
|
|
|
|
load: function(collection, callback) {
|
|
var jsList = (collection.js) ? collection.js : [],
|
|
cssList = (collection.css) ? collection.css : [],
|
|
imgList = (collection.img) ? collection.img : []
|
|
|
|
jsList = $.grep(jsList, function(item){
|
|
return $('head script[src="'+item+'"]').length == 0
|
|
})
|
|
|
|
cssList = $.grep(cssList, function(item){
|
|
return $('head link[href="'+item+'"]').length == 0
|
|
})
|
|
|
|
var cssCounter = 0,
|
|
jsLoaded = false,
|
|
imgLoaded = false
|
|
|
|
if (jsList.length === 0 && cssList.length === 0 && imgList.length === 0) {
|
|
callback && callback()
|
|
return
|
|
}
|
|
|
|
o.loadJavaScript(jsList, function(){
|
|
jsLoaded = true
|
|
checkLoaded()
|
|
})
|
|
|
|
$.each(cssList, function(index, source){
|
|
o.loadStyleSheet(source, function(){
|
|
cssCounter++
|
|
checkLoaded()
|
|
})
|
|
})
|
|
|
|
o.loadImage(imgList, function(){
|
|
imgLoaded = true
|
|
checkLoaded()
|
|
})
|
|
|
|
function checkLoaded() {
|
|
if (!imgLoaded)
|
|
return false
|
|
|
|
if (!jsLoaded)
|
|
return false
|
|
|
|
if (cssCounter < cssList.length)
|
|
return false
|
|
|
|
callback && callback()
|
|
}
|
|
},
|
|
|
|
/*
|
|
* Loads StyleSheet files
|
|
*/
|
|
loadStyleSheet: function(source, callback) {
|
|
var cssElement = document.createElement('link')
|
|
|
|
cssElement.setAttribute('rel', 'stylesheet')
|
|
cssElement.setAttribute('type', 'text/css')
|
|
cssElement.setAttribute('href', source)
|
|
cssElement.addEventListener('load', callback, false)
|
|
|
|
if (typeof cssElement != 'undefined') {
|
|
document.getElementsByTagName('head')[0].appendChild(cssElement)
|
|
}
|
|
|
|
return cssElement
|
|
},
|
|
|
|
/*
|
|
* Loads JavaScript files in sequence
|
|
*/
|
|
loadJavaScript: function(sources, callback) {
|
|
if (sources.length <= 0)
|
|
return callback()
|
|
|
|
var source = sources.shift(),
|
|
jsElement = document.createElement('script');
|
|
|
|
jsElement.setAttribute('type', 'text/javascript')
|
|
jsElement.setAttribute('src', source)
|
|
jsElement.addEventListener('load', function() {
|
|
o.loadJavaScript(sources, callback)
|
|
}, false)
|
|
|
|
if (typeof jsElement != 'undefined') {
|
|
document.getElementsByTagName('head')[0].appendChild(jsElement)
|
|
}
|
|
},
|
|
|
|
/*
|
|
* Loads Image files
|
|
*/
|
|
loadImage: function(sources, callback) {
|
|
if (sources.length <= 0)
|
|
return callback()
|
|
|
|
var loaded = 0
|
|
$.each(sources, function(index, source){
|
|
var img = new Image()
|
|
img.onload = function() {
|
|
if (++loaded == sources.length && callback)
|
|
callback()
|
|
}
|
|
img.src = source
|
|
})
|
|
}
|
|
|
|
};
|
|
|
|
return o;
|
|
};
|
|
|
|
assetManager = new AssetManager();
|
|
|
|
/*
|
|
* String escape
|
|
*/
|
|
if ($.oc === undefined)
|
|
$.oc = {}
|
|
|
|
$.oc.escapeHtmlString = function(string) {
|
|
var htmlEscapes = {
|
|
'&': '&',
|
|
'<': '<',
|
|
'>': '>',
|
|
'"': '"',
|
|
"'": ''',
|
|
'/': '/'
|
|
},
|
|
htmlEscaper = /[&<>"'\/]/g
|
|
|
|
return ('' + string).replace(htmlEscaper, function(match) {
|
|
return htmlEscapes[match];
|
|
})
|
|
}
|
|
|
|
/*
|
|
* Inverse Click Event (not used)
|
|
*
|
|
* Calls the handler function if the user has clicked outside the object
|
|
* and not on any of the elements in the exception list.
|
|
*/
|
|
/*
|
|
$.fn.extend({
|
|
clickOutside: function(handler, exceptions) {
|
|
var $this = this;
|
|
|
|
$('body').on('click', function(event) {
|
|
if (exceptions && $.inArray(event.target, exceptions) > -1) {
|
|
return;
|
|
} else if ($.contains($this[0], event.target)) {
|
|
return;
|
|
} else {
|
|
handler(event, $this);
|
|
}
|
|
});
|
|
|
|
return this;
|
|
}
|
|
})
|
|
*/
|
|
|
|
/*
|
|
* Browser Fixes
|
|
* - If another fix using JS is necessary, move this logic to backend.fixes.js
|
|
*/
|
|
|
|
/*
|
|
* Internet Explorer v11
|
|
* - IE11 will not honor height 100% when overflow is used on the Y axis.
|
|
*/
|
|
if (!!window.MSInputMethodContext && !!document.documentMode) {
|
|
$(window).on('resize', function() {
|
|
fixMediaManager()
|
|
fixSidebar()
|
|
})
|
|
|
|
function fixMediaManager() {
|
|
var $el = $('div[data-control="media-manager"] .control-scrollpad')
|
|
$el.height($el.parent().height())
|
|
}
|
|
|
|
function fixSidebar() {
|
|
$('#layout-sidenav').height(Math.max(
|
|
$('#layout-body').innerHeight(),
|
|
$(window).height() - $('#layout-mainmenu').height()
|
|
))
|
|
}
|
|
}
|