//= require_tree ./views //= require pagelet_rails/jquery.ajaxprogress (function (w) { var root = w['PageletRails'] || {}; w['PageletRails'] = root; root.addParamsToUrl = function( url, data ) { if ( ! $.isEmptyObject(data) ) { url += ( url.indexOf('?') >= 0 ? '&' : '?' ) + $.param(data); } return url; }; root.appendScriptTag = function (text) { var script = document.createElement( "script" ); script.type = "text/javascript"; script.text = text; $("body").append(script); }; root.loadDirectly = function(data) { $.ajax({ url: data.url, dataType: 'script', headers: { 'X-Pagelet': 'pagelet' } }).done(function(_) { }).fail(function(){ var html = JST['views/pagelet_load_failed']({ pagelet_url: data.url, reload_function: "PageletRails.loadPagelets('#" + data.id + "');" }); data.elem.html(html) }); }; root.loadThroughBatchProxy = function(urls) { if (urls.length === 0) { return; } var prev_index = 0; $.ajax({ url: '/pagelet_proxy', data: { urls: urls }, dataType: 'text', cache: false, headers: { 'X-Pagelet': 'pagelet' }, progress: function(_, progressEvent) { var text = progressEvent.target.responseText; var end_index = -1; do { end_index = text.indexOf("\n\n//\n\n", prev_index); if (end_index !== -1) { var new_text = text.substring(prev_index, end_index); eval(new_text); prev_index = end_index + 1; // console.log('found'); // console.log(new_text); } } while (end_index !== -1); } }); }; root.loadPagelets = function(selector) { selector = selector || '[data-pagelet-load]'; var groups = {}; $(selector).each(function(index, elem) { var $el = $(elem); var path = $el.data('widget-url'); var group = $el.data('pagelet-group'); var id = $el.attr('id'); var url = root.addParamsToUrl(path, { target_container: id, original_pagelet_options: $el.data('pagelet-options') }); groups[group] = groups[group] || []; groups[group].push({ id: id, elem: $el, url: url, group: group }); }); for (var group_name in groups) { if (groups.hasOwnProperty(group_name)) { var group = groups[group_name]; if (group.length === 1) { root.loadDirectly(group[0]); } else { var urls = group.map(function(e) { return e.url; }); root.loadThroughBatchProxy(urls); } } } }; root.pageletArrived = function(id, content, tags) { root.placeToContainer(id, content); root.processDataRemoteTags(); root.tagsChanged(id, tags); $(document).trigger('pagelet-loaded', [id, tags, content]); }; root.placeToContainer = function(id, content) { $('#' + id).replaceWith(content); }; root.tagsChanged = function(id, tags) { if (tags && tags.length > 0) { var selector = $(); tags.forEach(function(tag) { selector = selector.add('[data-pagelet-tags~="' + tag + '"]:not(#' + id + ')'); }); root.loadPagelets(selector); } }; root.processDataRemoteTags = function() { $('form[data-remote]').each(function(index, elem){ var $el = $(elem); var container = $el.closest('[data-pagelet-container]'); if (!container) { return; } var hidden_field = $el.find('input[name=target_container]')[0]; if (!hidden_field) { $("", { name: "target_container", type: "hidden", value: container.attr('id') }).appendTo($el); } hidden_field = $el.find('input[name=original_pagelet_options]')[0]; if (!hidden_field) { $("", { name: "original_pagelet_options", type: "hidden", value: container.data('pagelet-options') }).appendTo($el); } }); var selector = 'a[data-remote]:not([disabled]),button[data-remote]:not([disabled])'; $(selector).each(function(index, elem){ var $el = $(elem); var container = $el.closest('[data-pagelet-container]'); if (!container || container.length === 0) { return; } var params = $el.data('params'); if (!params) { var value = $.param({ target_container: container.attr('id'), original_pagelet_options: container.data('pagelet-options') }); $el.data('params', value); } }); }; function initialise() { document.addEventListener("turbolinks:load", function(){ root.loadPagelets(); root.processDataRemoteTags(); }); } initialise(); })(window);