2017-03-04 15:23:12 +11:00

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 = {
'&': '&amp;',
'<': '&lt;',
'>': '&gt;',
'"': '&quot;',
"'": '&#x27;',
'/': '&#x2F;'
},
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()
))
}
}