// vim: et:ts=4:sw=4:sts=4:ft=javascript 'use strict'; pandora.ui.changelogDialog = function() { var height = Math.round((window.innerHeight - 48) * 0.9), width = Math.round(window.innerWidth * 0.9), $reloadButton = Ox.Button({ disabled: true, title: 'redo', tooltip: Ox._('Reload'), type: 'image' }) .css({float: 'left', margin: '4px'}) .bindEvent({ click: function() { $reloadButton.options({disabled: true}); Ox.Request.clearCache('findChangeLogs'); $list.reloadList(true); } }), $findSelect = Ox.Select({ items: [ {id: 'all', title: Ox._('Find: All')}, {id: 'user', title: Ox._('Find: User')}, {id: 'action', title: Ox._('Find: Action')}, {id: 'changeid', title: Ox._('Find: ID')} ], overlap: 'right', type: 'image', value: 'all' }) .bindEvent({ change: function(data) { var key = data.value, value = $findInput.value(); value && updateList(key, value); $findInput.options({ placeholder: data.title }); } }), $findInput = Ox.Input({ changeOnKeypress: true, clear: true, placeholder: Ox._('Find: All'), width: 192 }) .bindEvent({ change: function(data) { var key = $findSelect.value(), value = data.value; updateList(key, value); } }), $findElement = Ox.FormElementGroup({ elements: [ $findSelect, $findInput ] }) .css({float: 'right', margin: '4px'}), $list = Ox.TableList({ columns: [ { id: 'id', title: Ox._('ID'), visible: false }, { format: function(value) { return Ox.formatDate(value, '%Y-%m-%d %H:%M:%S'); }, id: 'created', operator: '-', title: Ox._('Date'), visible: true, width: 160 }, { format: function(value) { return Ox.encodeHTMLEntities(value); }, id: 'user', operator: '+', title: Ox._('User'), visible: true, width: 160 }, { id: 'action', operator: '+', title: Ox._('Action'), visible: true, width: 160 }, { format: function(value, data) { return value; // FIXME: TODO }, id: 'changeid', operator: '+', title: Ox._('ID'), visible: true, width: 160 }, { format: function(value) { return Ox.encodeHTMLEntities(JSON.stringify(value)); }, id: 'data', operator: '+', title: Ox._('Data'), visible: true, width: 640 }, ], columnsMovable: true, columnsResizable: true, columnsVisible: true, items: pandora.api.findChangeLogs, scrollbarVisible: true, sort: [{key: 'created', operator: '-'}], unique: 'id' }) .bindEvent({ init: function(data) { $status.html(Ox.toTitleCase( Ox.formatCount(data.items, 'entry', 'entries') )); }, load: function() { $reloadButton.options({disabled: false}); }, open: function(data) { var value = $list.value(Ox.last(data.ids)), FIXME = Ox.print(value), $dialog = Ox.Dialog({ buttons: [ Ox.Button({ id: 'close', title: Ox._('Close') }) .bindEvent({ click: function() { $dialog.close(); } }) ], closeButton: true, content: $('<code>').append( $('<pre>') .addClass('OxSelectable') .css({margin: '16px'}) .text(JSON.stringify(value.data, null, ' ')) ), height: height - 48, keys: {enter: 'close', escape: 'close'}, maximizeButton: true, removeOnClose: true, title: [value.user, value.action, value.changeid].join(' — '), width: width - 48 }) .open(); } }), that = Ox.Dialog({ buttons: [ Ox.Button({ id: 'done', title: Ox._('Done'), width: 48 }).bindEvent({ click: function() { that.close(); } }) ], closeButton: true, content: Ox.SplitPanel({ elements: [ { element: Ox.Bar({size: 24}) .append($reloadButton) .append($findElement), size: 24 }, { element: $list } ], orientation: 'vertical' }), height: height, maximizeButton: true, minHeight: 256, minWidth: 512, padding: 0, removeOnClose: true, title: Ox._('Changelog'), width: width }), $status = $('<div>') .css({ position: 'absolute', top: '4px', left: '128px', right: '128px', bottom: '4px', paddingTop: '2px', fontSize: '9px', textAlign: 'center' }) .appendTo(that.find('.OxButtonsbar')); that.superClose = that.close; that.close = function() { Ox.Request.clearCache('findChangeLogs'); that.superClose(); }; function updateList(key, value) { var query = { conditions: key == 'all' ? [ {key: 'user', value: value, operator: '='}, {key: 'action', value: value, operator: '='}, {key: 'changeid', value: value, operator: '='} ] : [ {key: key, value: value, operator: '='} ], operator: key == 'all' ? '|' : '&' }; $list.options({ items: function(data, callback) { return pandora.api.findChangeLogs(Ox.extend(data, { query: query }), callback); } }); } return that; };