summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorThomas Tanghus <thomas@tanghus.net>2013-04-15 13:42:35 -0700
committerThomas Tanghus <thomas@tanghus.net>2013-04-15 13:42:35 -0700
commit3f7643ef46bab7cf3ab69a6907e060e5191fe950 (patch)
treeb0c7fb5509ca9ae9edf68311614288bb886b86a4
parentd484e140898256fe56bcfbd19204416b862120cb (diff)
parent155582ab70b0a469f1d0a7159a16334283f91bbc (diff)
downloadnextcloud-server-3f7643ef46bab7cf3ab69a6907e060e5191fe950.tar.gz
nextcloud-server-3f7643ef46bab7cf3ab69a6907e060e5191fe950.zip
Merge pull request #2769 from owncloud/octemplate
Add octemplate jQuery plugin
-rw-r--r--core/js/octemplate.js101
1 files changed, 101 insertions, 0 deletions
diff --git a/core/js/octemplate.js b/core/js/octemplate.js
new file mode 100644
index 00000000000..a5d56852a57
--- /dev/null
+++ b/core/js/octemplate.js
@@ -0,0 +1,101 @@
+/**
+ * jQuery plugin for micro templates
+ *
+ * Strings are automatically escaped, but that can be disabled by setting escapeFunction to null.
+ *
+ * Usage examples:
+ *
+ * var htmlStr = '<p>Bake, uncovered, until the {greasystuff} is melted and the {pasta} is heated through, about {min} minutes.</p>'
+ * $(htmlStr).octemplate({greasystuff: 'cheese', pasta: 'macaroni', min: 10});
+ *
+ * var htmlStr = '<p>Welcome back {user}</p>';
+ * $(htmlStr).octemplate({user: 'John Q. Public'}, {escapeFunction: null});
+ *
+ * Be aware that the target string must be wrapped in an HTML element for the plugin to work. The following won't work:
+ *
+ * var textStr = 'Welcome back {user}';
+ * $(textStr).octemplate({user: 'John Q. Public'});
+ *
+ * For anything larger than one-liners, you can use a simple $.get() ajax request to get the template,
+ * or you can embed them it the page using the text/template type:
+ *
+ * <script id="contactListItemTemplate" type="text/template">
+ * <tr class="contact" data-id="{id}">
+ * <td class="name">
+ * <input type="checkbox" name="id" value="{id}" /><span class="nametext">{name}</span>
+ * </td>
+ * <td class="email">
+ * <a href="mailto:{email}">{email}</a>
+ * </td>
+ * <td class="phone">{phone}</td>
+ * </tr>
+ * </script>
+ *
+ * var $tmpl = $('#contactListItemTemplate');
+ * var contacts = // fetched in some ajax call
+ *
+ * $.each(contacts, function(idx, contact) {
+ * $contactList.append(
+ * $tmpl.octemplate({
+ * id: contact.getId(),
+ * name: contact.getDisplayName(),
+ * email: contact.getPreferredEmail(),
+ * phone: contact.getPreferredPhone(),
+ * });
+ * );
+ * });
+ */
+(function( $ ) {
+ /**
+ * Object Template
+ * Inspired by micro templating done by e.g. underscore.js
+ */
+ var Template = {
+ init: function(vars, options, elem) {
+ // Mix in the passed in options with the default options
+ this.vars = vars;
+ this.options = $.extend({},this.options,options);
+
+ this.elem = elem;
+ var self = this;
+
+ if(typeof this.options.escapeFunction === 'function') {
+ $.each(this.vars, function(key, val) {
+ if(typeof val === 'string') {
+ self.vars[key] = self.options.escapeFunction(val);
+ }
+ });
+ }
+
+ var _html = this._build(this.vars);
+ return $(_html);
+ },
+ // From stackoverflow.com/questions/1408289/best-way-to-do-variable-interpolation-in-javascript
+ _build: function(o){
+ var data = this.elem.attr('type') === 'text/template' ? this.elem.html() : this.elem.get(0).outerHTML;
+ try {
+ return data.replace(/{([^{}]*)}/g,
+ function (a, b) {
+ var r = o[b];
+ return typeof r === 'string' || typeof r === 'number' ? r : a;
+ }
+ );
+ } catch(e) {
+ console.error(e, 'data:', data)
+ }
+ },
+ options: {
+ escapeFunction: function(str) {return $('<i></i>').text(str).html();}
+ }
+ };
+
+ $.fn.octemplate = function(vars, options) {
+ var vars = vars ? vars : {};
+ if(this.length) {
+ var _template = Object.create(Template);
+ return _template.init(vars, options, this);
+ }
+ };
+
+})( jQuery );
+