'use strict'; pandora.ui.helpDialog = function() { var text = {}, $panel, $list, $text, $image, that = Ox.Dialog({ buttons: [ Ox.Button({ id: 'switch', title: Ox._('API Documentation...') }).bindEvent({ click: function() { pandora.UI.set({page: 'api'}); } }), {}, Ox.Button({ id: 'close', title: Ox._('Close') }).bindEvent({ click: function() { that.close(); } }) ], closeButton: true, content: Ox.LoadingScreen().start(), height: 384, keys: {escape: 'close'}, maximizeButton: true, minHeight: 256, minWidth: 544 + 2 * Ox.UI.SCROLLBAR_SIZE, removeOnClose: true, title: Ox._('Help'), width: 672 + 2 * Ox.UI.SCROLLBAR_SIZE }) .bindEvent({ close: function() { pandora.user.ui.page == 'help' && pandora.UI.set({page: ''}); }, resize: resize, 'pandora_part.help': function(data) { if (pandora.user.ui.page == 'help') { that.select(data.value == '' ? 'help' : data.value); } } }), url = '/static/html/help.html'; // FIXME: should be updated at build time if (Ox.contains(['ar'], pandora.user.ui.locale)) { url = '/static/html/help.' + pandora.user.ui.locale + '.html'; } Ox.get(url, function(html) { var $html = $('<div>'), strings = Ox.clone(pandora.site, true); strings.addAnnotationShortcuts = strings.layers.slice(0, 9).map(function(layer, index) { return '<tr><td>' + (index + 1) + '</td><td>' + Ox._('Add {0}', [layer.item.toLowerCase()]) + '</td></tr>'; }).join('\n'); strings.itemName = Ox.map(strings.itemName, function(v) { return Ox._(v).toLowerCase(); }); strings.signup = pandora.user.level == 'guest' ? '<a href="/signup">' + Ox._('sign up') + '</a>' : Ox._('sign up'); $html.html(Ox.formatString(html, strings)); pandora.site.help.forEach(function(section) { var html = $html.find('#' + section.id).html(); text[section.id] = '<h1><b>' + Ox._(section.title) + '</b></h1>\n' + html; }); $list = Ox.TableList({ // fixme: silly _tree: true, columns: [ { id: 'title', visible: true, width: 128 - Ox.UI.SCROLLBAR_SIZE } ], items: pandora.site.help.map(function(value, index) { return Ox.extend({index: index}, value, {title: Ox._(value.title)}); }), max: 1, min: 1, scrollbarVisible: true, selected: [pandora.user.ui.part.help || 'help'], sort: [{key: 'index', operator: '+'}], unique: 'id' }) .bindEvent({ select: function(data) { var id = data.ids[0] == 'help' ? '' : data.ids[0]; pandora.UI.set({'part.help': id}); } }); $text = Ox.Element() .addClass('OxTextPage OxSelectable') .css({ padding: '16px', overflowY: 'scroll' }); $panel = Ox.SplitPanel({ elements: [ {element: $list, size: 128 + Ox.UI.SCROLLBAR_SIZE}, {element: $text} ], orientation: 'horizontal' }); that.select(pandora.user.ui.part.help).options({content: $panel}); pandora.createLinks($text); $list.gainFocus(); }); function getImageSize() { var width = that.options('width') - 160 - 2 * Ox.UI.SCROLLBAR_SIZE, height = Math.round(width * 5/8); return {width: width, height: height}; } function resize(data) { $list.size(); $image && $image.options(getImageSize()); } that.select = function(id) { var img, $img; $text.html(text[id || 'help']).scrollTop(0); img = $text.find('img'); if (img) { $img = $(img); $img.replaceWith( $image = Ox.ImageElement( Ox.extend(getImageSize(), {src: $img.attr('src')}) ) .css({borderRadius: '8px'}) ); } $text.find('td:first-child') .css({ height: '16px', paddingRight: '8px', textAlign: 'right', whiteSpace: 'nowrap' }); return that; } return that; };