// vim: et:ts=4:sw=4:sts=4:ft=javascript 'use strict'; pandora.ui.namesDialog = function() { // FIXME: add cache invalidation var height = Math.round((window.innerHeight - 48) * 0.9), width = 576 + Ox.UI.SCROLLBAR_SIZE, numberOfNames = 0, $findInput = Ox.Input({ changeOnKeypress: true, clear: true, placeholder: 'Find', width: 192 }) .css({float: 'right', margin: '4px'}) .bindEvent({ change: function(data) { var query = { conditions: [ {key: 'name', value: data.value, operator: '='}, {key: 'sortname', value: data.value, operator: '='} ], operator: '|' }; $list.options({ items: function(data, callback) { return pandora.api.findNames(Ox.extend(data, { query: query }), callback); } }); } }), $list = Ox.TextList({ columns: [ { id: 'id', title: 'ID', unique: true, visible: false, width: 0 }, { id: 'name', operator: '+', removable: false, title: 'Name', visible: true, width: 256 }, { editable: true, id: 'sortname', operator: '+', title: 'Sort Name', tooltip: 'Edit Sort Name', visible: true, width: 256 }, { id: 'numberofnames', align: 'right', operator: '-', title: 'Names', visible: true, width: 64 }, ], columnsVisible: true, items: pandora.api.findNames, max: 1, scrollbarVisible: true, sort: [{key: 'sortname', operator: '+'}] }) .bindEvent({ init: function(data) { numberOfNames = data.items; $status.html( Ox.formatNumber(numberOfNames) + ' name' + (numberOfNames == 1 ? '' : 's') ); }, open: function(data) { $list.$element .find('.OxItem.OxSelected > .OxCell.OxColumnSortname') .trigger('mousedown') .trigger('mouseup'); }, select: function(data) { $findButton.options({disabled: !data.ids.length}); }, submit: function(data) { Ox.Request.clearCache('findNames'); pandora.api.editName({ id: data.id, sortname: data.value }); } }), $findButton = Ox.Button({ disabled: true, title: 'Find', width: 48, }).bindEvent({ click: function() { that.close(); pandora.UI.set('find', { conditions: [{ key: 'name', value: $list.value($list.options('selected'), 'name'), operator: '=' }], operator: '&' }) } }), that = Ox.Dialog({ buttons: [ Ox.Button({ title: 'Manage Titles...' }).bindEvent({ click: function() { // ... } }), {}, $findButton, Ox.Button({ title: 'Done', width: 48 }).bindEvent({ click: function() { that.close(); } }) ], closeButton: true, content: Ox.SplitPanel({ elements: [ { element: Ox.Bar({size: 24}) .append($status) .append( $findInput ), size: 24 }, { element: $list } ], orientation: 'vertical' }), height: height, maximizeButton: true, minHeight: 256, minWidth: 512, padding: 0, title: 'Manage Names', width: width }), $status = $('