X-Git-Url: http://git.roojs.org/?p=roojs1;a=blobdiff_plain;f=Roo%2FTemplate.js;h=4f8e30281afe8a961bae09bb01001ee20415f749;hp=cd230b2fd3a4806bc05e13f6a2aa0e97ba021867;hb=0b69a11b1055a6d3a3fd0719bdd58b5a235de0e4;hpb=1464be9f6f85f6777f9b9ae1474438834853aa86
diff --git a/Roo/Template.js b/Roo/Template.js
index cd230b2fd3..4f8e30281a 100644
--- a/Roo/Template.js
+++ b/Roo/Template.js
@@ -25,7 +25,9 @@ var t = new Roo.Template({
});
t.append('some-element', {id: 'myid', cls: 'myclass', name: 'foo', value: 'bar'});
-* For more information see this blog post with examples: DomHelper - Create Elements using DOM, HTML fragments and Templates.
+* For more information see this blog post with examples:
+* DomHelper
+ - Create Elements using DOM, HTML fragments and Templates.
* @constructor
* @param {Object} cfg - Configuration object.
*/
@@ -44,11 +46,18 @@ Roo.Template = function(cfg){
// bc
this.html = cfg;
}
-
+ if (this.url) {
+ this.load();
+ }
};
Roo.Template.prototype = {
+ /**
+ * @cfg {String} url The Url to load the template from. beware if you are loading from a url, the data may not be ready if you use it instantly..
+ * it should be fixed so that template is observable...
+ */
+ url : false,
/**
* @cfg {String} html The HTML fragment or an array of fragments to join("") or multiple arguments to join("")
*/
@@ -59,8 +68,9 @@ Roo.Template.prototype = {
* @return {String} The HTML fragment
*/
applyTemplate : function(values){
+ //Roo.log(["applyTemplate", values]);
try {
-
+
if(this.compiled){
return this.compiled(values);
}
@@ -98,6 +108,36 @@ Roo.Template.prototype = {
},
+ loading : false,
+
+ load : function ()
+ {
+
+ if (this.loading) {
+ return;
+ }
+ var _t = this;
+
+ this.loading = true;
+ this.compiled = false;
+
+ var cx = new Roo.data.Connection();
+ cx.request({
+ url : this.url,
+ method : 'GET',
+ success : function (response) {
+ _t.loading = false;
+ _t.html = response.responseText;
+ _t.url = false;
+ _t.compile();
+ },
+ failure : function(response) {
+ Roo.log("Template failed to load from " + _t.url);
+ _t.loading = false;
+ }
+ });
+ },
+
/**
* Sets the HTML used as the template and optionally compiles it.
* @param {String} html