Commit 75741309 authored by Sven Franck's avatar Sven Franck

fixed loading gadgets via renderjs and requirejs in Chrome/Opera

parent 7beb14fb
define([], function () { define([
'overrides'
, 'jquery'
, 'jqm'
, 'polyfill'
, 'text'
, 'json'
, 'renderjs'
, 'i18next'
, 'css!../css/jquery-mobile/jquery-mobile.latest'
, 'css!../css/css'
, 'css!../css/normalize/normalize'
], function () {
"use strict"; "use strict";
var priv = {}; var priv = {};
...@@ -9,7 +21,7 @@ define([], function () { ...@@ -9,7 +21,7 @@ define([], function () {
======================================================================== */ ======================================================================== */
// document // document
priv.doc = $.mobile.document; priv.doc = $.mobile.document || $(document);
/* ======================================================================== /* ========================================================================
FLAGS FLAGS
...@@ -72,7 +84,7 @@ define([], function () { ...@@ -72,7 +84,7 @@ define([], function () {
// ============================ RenderJs related ======================== // ============================ RenderJs related ========================
// //
// get elements inside a popup // get elements inside a gadget
// @method getElements // @method getElements
// @param {object} gadget to search for recursive gadgets // @param {object} gadget to search for recursive gadgets
// //
...@@ -213,30 +225,29 @@ define([], function () { ...@@ -213,30 +225,29 @@ define([], function () {
// @param {object} gadget to be rendered // @param {object} gadget to be rendered
// //
that.renderGadgets = function (gadget) { that.renderGadgets = function (gadget) {
var spec = {}; var gadget_id = gadget.dom.attr('id'),
gadget_parent = gadget.dom.parents("div[data-gadget]"),
spec.gadget_id = gadget.dom.attr('id'); gadget_props = gadget["state"],
spec.gadget_props = gadget["state"]; gadget_cleaned_id = gadget_id.split("__").slice(-1)[0],
spec.gadget_cleaned_id = spec.gadget_id.split("__").slice(-1)[0]; propsToSet,
spec.propsToSet; fwd = [],
spec.fwd = []; i;
spec.i;
// JSON property API // JSON property API
// "state": [ // "state": [
// {"gadget-id" {"element": ["method", "key/value", "value"] } }, // {"gadget-id" {"element": ["method", "key/value", "value"] } },
// ... // ...
// ] // ]
if (spec.gadget_props !== undefined) { if (gadget_props !== undefined) {
for (spec.i = 0; spec.i < spec.gadget_props.length; spec.i += 1) { for (i = 0; i < gadget_props.length; i += 1) {
spec.propsToSet = spec.gadget_props[spec.i][spec.gadget_cleaned_id]; propsToSet = gadget_props[i][gadget_cleaned_id];
if (spec.propsToSet !== undefined) { if (propsToSet !== undefined) {
// properties for this gadget // properties for this gadget
priv.setAttributesOnGadgetElements(gadget, spec.propsToSet); priv.setAttributesOnGadgetElements(gadget, propsToSet);
} else { } else {
// fwd to new data-gadget-property object // fwd to new data-gadget-property object
spec.fwd.push(spec.gadget_props[spec.i]); fwd.push(gadget_props[i]);
} }
} }
// should we clean up? // should we clean up?
...@@ -246,32 +257,36 @@ define([], function () { ...@@ -246,32 +257,36 @@ define([], function () {
priv.getElements( priv.getElements(
gadget, "a[data-rel='popup'], a[data-rel='panel']" gadget, "a[data-rel='popup'], a[data-rel='panel']"
).each(function () { ).each(function () {
spec.href = this.getAttribute('href').replace("#", ''); var href = this.getAttribute('href').replace("#", ''),
spec.prefixedHref = priv.prefixElement(spec.href, spec.gadget_id); prefixedHref = priv.prefixElement(href, gadget_id);
this.setAttribute("href", "#" + spec.prefixedHref); this.setAttribute("href", "#" + prefixedHref);
// not nice... prevents panel getting prefix__prefix__gadget_id // not nice... prevents panel getting prefix__prefix__gadget_id
// TODO: find better way // TODO: find better way
if (this.getAttribute("data-rel") !== "panel") { if (this.getAttribute("data-rel") !== "panel") {
document document
.getElementById(spec.href) .getElementById(href)
.setAttribute("id", spec.prefixedHref); .setAttribute("id", prefixedHref);
} }
}); });
priv.getElements(gadget, "div[data-gadget]").each(function () { // beware: need to get children only to prevent selecting gadgets
spec.id = this.getAttribute('id'); // multiple levels deep
spec.prefixId = priv.prefixElement(spec.id, spec.gadget_id); priv.getElements(gadget, "> div[data-gadget]").each(function () {
if (spec.fwd.length > 0) { if (fwd.length > 0) {
this.setAttribute( this.setAttribute(
'data-gadget-property', JSON.stringify({ 'data-gadget-property', JSON.stringify({
"state": spec.fwd "state": fwd
}) })
); );
} }
this.setAttribute('id', spec.prefixId);
}); });
// update this gadgets id with the parent gadget id
if (gadget_parent.length > 0) {
gadget.dom.attr('id', gadget_parent.attr('id') + "__" + gadget_id);
}
}; };
// ======================================================================== // ========================================================================
......
...@@ -65,8 +65,7 @@ ...@@ -65,8 +65,7 @@
, pagefooter: '../modules/pagefooter/pagefooter' , pagefooter: '../modules/pagefooter/pagefooter'
} }
, shim: { , shim: {
'overrides': { deps: ['jquery'] } 'jqm': { deps: ['jquery'], exports: 'mobile' }
, 'jqm': { deps: ['jquery'], exports: 'mobile' }
, 'jio': { deps: ['md5'] } , 'jio': { deps: ['md5'] }
, 'complex_queries': { exports: 'complex_queries' } , 'complex_queries': { exports: 'complex_queries' }
, 'localstorage': { deps: ['jio', 'complex_queries'] } , 'localstorage': { deps: ['jio', 'complex_queries'] }
...@@ -82,52 +81,51 @@ ...@@ -82,52 +81,51 @@
} }
}); });
define(
[ require(['app', 'config'], function(App, Config) {
'require'
, 'overrides' var setup = new $.Deferred();
, 'jquery' var spec = {};
, 'jqm' var i;
, 'jio' var def;
, 'polyfill'
, 'text' spec.app = App;
, 'json' spec.config = Config;
, 'renderjs' spec.setup = setup;
, 'i18next'
, 'localstorage' // fallback for fast browsers...
, 'complex_queries' spec.fallbackLoader = {
, 'md5' deferreds: [],
, 'css!../css/jquery-mobile/jquery-mobile.latest' args: [],
, 'css!../css/css' };
, 'css!../css/normalize/normalize'
], // expose App once everything is loaded
function (require) { spec.setup.done(function(App, Config) {
require(['app', 'config'], function(App, Config) {
window.App = App;
var setup = new $.Deferred();
var spec = {}; // expose configuration - settings
window.App.settings = Config.settings;
spec.app = App; // expose configuration - storages
spec.config = Config; window.App.storage = Config.storage;
spec.setup = setup;
for (i = 0; i < window.fallbackLoader.deferreds.length; i += 1) {
// expose App once everything is loaded window.fallbackLoader.deferreds[i]
spec.setup.done(function(App, Config) { .resolve(window.fallbackLoader.args[i]);
window.App = App; }
// expose configuration - settings // cleanup
window.App.settings = Config.settings; delete window.fallbackLoader;
// expose configuration - storages
window.App.storage = Config.storage;
});
spec.configuration_setter = function (spec) {
spec.config.set(spec);
};
// initialize
App.initialize(spec);
}); });
}
); spec.configuration_setter = function (spec) {
spec.config.set(spec);
};
// expose fallback
window.fallbackLoader = spec.fallbackLoader;
// initialize
App.initialize(spec);
});
}()); }());
\ No newline at end of file
(function ($, document) { define(['jquery'], function ($) {
"use strict"; "use strict";
// we will trigger manually
$(document).on("mobileinit", function () { $(document).on("mobileinit", function () {
$.mobile.autoInitializePage = false; $.mobile.autoInitializePage = false;
}); });
}(jQuery, document));
\ No newline at end of file return undefined;
});
\ No newline at end of file
define([ define([
"storage" 'storage'
, "async" , 'async'
], ],
function (storage) { function (storage) {
"use strict"; "use strict";
......
...@@ -3,12 +3,33 @@ define([ ...@@ -3,12 +3,33 @@ define([
, 'css!header' , 'css!header'
], ],
function (source) { function (source) {
var response = {}; var response = {}, def;
response.data = source; response.data = source;
response.callback = function (self) { response.callback = function (self) {
// prefix instance-ids, pass JSON // TODO: this should be inside renderJs, although its application-specific
window.App.renderGadgets(self); // but the problem with using async-render-require will be everything
// being loaded at the same time, so the user should have the opportunity
// to run his callback no matter where. Still not sure where to wait
// (app-init or render-init), but it would be nice if a renderjs application
// would allow for a first page load deferred on all gadgets until some
// flag is set. In rjs2, we will not have to set globals, but we will
// have the problem of trying to access methods published by other gadgets
// BEFORE they have been published, so it's pretty much the same thing.
if (window.App === undefined) {
def = new $.Deferred;
def.done(function(zzz) {
// prefix instance-ids, pass JSON
window.App.renderGadgets(zzz);
});
window.fallbackLoader.deferreds.push(def);
window.fallbackLoader.args.push(self);
} else {
// prefix instance-ids, pass JSON
window.App.renderGadgets(self);
}
}; };
// return response object // return response object
......
...@@ -26,100 +26,5 @@ ...@@ -26,100 +26,5 @@
}'> }'>
</div> </div>
<!-- content --> </body>
<div data-role="content" class="ui-content">
<!-- teaser -->
<div id="teaser" data-gadget="modules/teaser/teaser.html" data-gadget-module="teaser"></div>
<!-- quicksearch -->
<div id="quicksearch"
class="searchbar_wrap"
data-gadget="modules/searchbar/searchbar.html"
data-gadget-module="searchbar"
data-gadget-property='{
"state": [
{
"quicksearch": {
"_elements": [
["ui-filter", "attr", "data-i18n", "[placeholder]quicksearch.browse"],
["ui-filter", "attr", "data-i18n-target", "input"]
],
"_config": {
"datasource": {"module": "storage"}
},
"_links": {
"self": {"href": ""},
"datasource": {"href": "modules/storage/storage.html#queryStorage?method=default"},
"show": {"href": "search.html#queryStorage?method=default"}
}
}
}
]
}'>
</div>
<!-- gallery widget -->
<div id="gallery" data-gadget="modules/gallery/gallery.html" data-gadget-module="gallery"></div>
<!-- top sellers -->
<div id="topsellers"
data-gadget="modules/items/items.html"
data-gadget-module="items"
data-gadget-property='{
"state": [
{
"topsellers": {
"_elements": [
["items_title", "attr", "data-i18n", "topsellers.info"],
["items_show", "attr", "data-i18n", "topsellers.show"],
["items_show", "attr", "href", "search.html?show=topsellers"]
],
"_config": {
"datasource": {"module": "storage", "pointer": "topsellers"}
},
"_links": {
"self": {"href": ""},
"datasource": {"href": "modules/storage/storage.html#queryStorage?method=topsellers"},
"show": {"href": "search.html#queryStorage?method=topsellers"}
}
}
}
]
}'>
</div>
<!-- top brands
<div id="topbrands"
data-gadget="modules/items/items.html"
data-gadget-module="items"
data-gadget-property='{
"state": [
{
"topbrands": {
"_elements": [
["items_title", "attr", "data-i18n", "topbrands.info"],
["items_show", "attr", "data-i18n", "topbrands.show"],
["items_show", "attr", "href", "search.html?show=topbrands"]
],
"_config": {
"datasource": {"module": "storage", "pointer": "topbrands"}
},
"_links": {
"self": {"href": ""},
"datasource": {"href": "modules/storage/storage.html#queryStorage?method=topbrands"},
"show": {"href": "search.html#queryStorage?method=topsellers"}
}
}
}
]
}'
></div>-->
<!-- seo story -->
<div id="seo" data-gadget="modules/seo/seo.html" data-gadget-module="seo"></div>
</div>
<!-- footer -->
<div id="footer" data-role="footer" data-position="fixed" data-gadget="modules/footer/footer.html" data-gadget-module="footer"></div>
</body>
</html> </html>
\ No newline at end of file
...@@ -3,12 +3,24 @@ define([ ...@@ -3,12 +3,24 @@ define([
, 'css!index' , 'css!index'
], ],
function (source) { function (source) {
var response = {}; var response = {}, def;
response.data = source; response.data = source;
response.callback = function (self) { response.callback = function (self) {
// prefix instance-ids, pass JSON if (window.App === undefined) {
window.App.renderGadgets(self); def = new $.Deferred;
def.done(function(gadget) {
// prefix instance-ids, pass JSON
window.App.renderGadgets(gadget);
});
window.fallbackLoader.deferreds.push(def);
window.fallbackLoader.args.push(self);
} else {
// prefix instance-ids, pass JSON
window.App.renderGadgets(self);
}
}; };
// return response object // return response object
......
...@@ -10,6 +10,7 @@ define([ ...@@ -10,6 +10,7 @@ define([
var that = {}; var that = {};
var priv = {}; var priv = {};
var def;
// ==================================================================== // ====================================================================
// ATTRIBUTES // ATTRIBUTES
...@@ -132,19 +133,36 @@ define([ ...@@ -132,19 +133,36 @@ define([
}); });
}); });
priv.deferred_setup_translations = function (gadget) {
// ==================================================================== // ====================================================================
// PUBLISH METHODS // PUBLISH METHODS
// ==================================================================== // ====================================================================
// TODO: remove once callable via link // TODO: remove once callable via link
window.App.translate = priv.translate; window.App.translate = priv.translate;
// prefix instance-ids, pass JSON, trigger("create") // prefix instance-ids, pass JSON, trigger("create")
window.App.renderGadgets(priv.gadget); window.App.renderGadgets(gadget);
// ==================================================================== // ====================================================================
// INITIALIZE // INITIALIZE
// ==================================================================== // ====================================================================
priv.initialize(window.App.settings.language_current); priv.initialize(window.App.settings.language_current);
};
if (window.App === undefined) {
def = new $.Deferred;
def.done(function(gadget) {
// prefix instance-ids, pass JSON
priv.deferred_setup_translations(gadget)
});
window.fallbackLoader.deferreds.push(def);
window.fallbackLoader.args.push(priv.gadget);
} else {
// prefix instance-ids, pass JSON
priv.deferred_setup_translations(priv.gadget);
}
} }
// return response object // return response object
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment