mirror of
https://github.com/owncloudarchive/contacts.git
synced 2025-01-19 08:52:22 +01:00
Contacts: Moved octemplate plugin to separate file.
This commit is contained in:
parent
f591954689
commit
9c64617b04
54
js/app.js
54
js/app.js
@ -1734,58 +1734,10 @@ OC.Contacts = OC.Contacts || {
|
|||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
(function( $ ) {
|
|
||||||
// Support older browsers. From http://www.yelotofu.com/2008/08/jquery-outerhtml/
|
|
||||||
jQuery.fn.outerHTML = function(s) {
|
|
||||||
return s
|
|
||||||
? this.before(s).remove()
|
|
||||||
: jQuery('<p>').append(this.eq(0).clone()).html();
|
|
||||||
};
|
|
||||||
/**
|
|
||||||
* Object Template
|
|
||||||
* Inspired by micro templating done by e.g. underscore.js
|
|
||||||
*/
|
|
||||||
var Template = {
|
|
||||||
init: function(options, elem) {
|
|
||||||
// Mix in the passed in options with the default options
|
|
||||||
this.options = $.extend({},this.options,options);
|
|
||||||
|
|
||||||
// Save the element reference, both as a jQuery
|
|
||||||
// reference and a normal reference
|
|
||||||
this.elem = elem;
|
|
||||||
this.$elem = $(elem);
|
|
||||||
|
|
||||||
var _html = this._build(this.options);
|
|
||||||
//console.log('html', this.$elem.html());
|
|
||||||
return $(_html);
|
|
||||||
},
|
|
||||||
// From stackoverflow.com/questions/1408289/best-way-to-do-variable-interpolation-in-javascript
|
|
||||||
_build: function(o){
|
|
||||||
var data = this.$elem.html();
|
|
||||||
//this.$elem.attr('type') === 'text/template'
|
|
||||||
//? this.$elem.html() : this.$elem.outerHTML();
|
|
||||||
return data.replace(/{([^{}]*)}/g,
|
|
||||||
function (a, b) {
|
|
||||||
var r = o[b];
|
|
||||||
return typeof r === 'string' || typeof r === 'number' ? r : a;
|
|
||||||
}
|
|
||||||
);
|
|
||||||
},
|
|
||||||
options: {
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
$.fn.octemplate = function(options) {
|
|
||||||
if ( this.length ) {
|
|
||||||
var _template = Object.create(Template);
|
|
||||||
return _template.init(options, this);
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
})( jQuery );
|
|
||||||
|
|
||||||
$(document).ready(function() {
|
$(document).ready(function() {
|
||||||
|
|
||||||
OC.Contacts.init();
|
OC.Router.registerLoadedCallback(function() {
|
||||||
|
OC.Contacts.init();
|
||||||
|
});
|
||||||
|
|
||||||
});
|
});
|
||||||
|
50
js/octemplate.js
Normal file
50
js/octemplate.js
Normal file
@ -0,0 +1,50 @@
|
|||||||
|
(function( $ ) {
|
||||||
|
// Support older browsers. From http://www.yelotofu.com/2008/08/jquery-outerhtml/
|
||||||
|
jQuery.fn.outerHTML = function(s) {
|
||||||
|
return s
|
||||||
|
? this.before(s).remove()
|
||||||
|
: jQuery('<p>').append(this.eq(0).clone()).html();
|
||||||
|
};
|
||||||
|
/**
|
||||||
|
* Object Template
|
||||||
|
* Inspired by micro templating done by e.g. underscore.js
|
||||||
|
*/
|
||||||
|
var Template = {
|
||||||
|
init: function(options, elem) {
|
||||||
|
// Mix in the passed in options with the default options
|
||||||
|
this.options = $.extend({},this.options,options);
|
||||||
|
|
||||||
|
// Save the element reference, both as a jQuery
|
||||||
|
// reference and a normal reference
|
||||||
|
this.elem = elem;
|
||||||
|
this.$elem = $(elem);
|
||||||
|
|
||||||
|
var _html = this._build(this.options);
|
||||||
|
//console.log('html', this.$elem.html());
|
||||||
|
return $(_html);
|
||||||
|
},
|
||||||
|
// From stackoverflow.com/questions/1408289/best-way-to-do-variable-interpolation-in-javascript
|
||||||
|
_build: function(o){
|
||||||
|
var data = this.$elem.html();
|
||||||
|
//this.$elem.attr('type') === 'text/template'
|
||||||
|
//? this.$elem.html() : this.$elem.outerHTML();
|
||||||
|
return data.replace(/{([^{}]*)}/g,
|
||||||
|
function (a, b) {
|
||||||
|
var r = o[b];
|
||||||
|
return typeof r === 'string' || typeof r === 'number' ? r : a;
|
||||||
|
}
|
||||||
|
);
|
||||||
|
},
|
||||||
|
options: {
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
$.fn.octemplate = function(options) {
|
||||||
|
if ( this.length ) {
|
||||||
|
var _template = Object.create(Template);
|
||||||
|
return _template.init(options, this);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
})( jQuery );
|
||||||
|
|
Loading…
x
Reference in New Issue
Block a user