'use strict'; pandora.ui.metadataDialog = function(data) { var keys = [ 'title', 'alternativeTitles', 'director', 'country', 'year', 'language', 'runtime', 'color', 'sound', 'productionCompany', 'producer', 'writer', 'cinematographer', 'editor', 'composer', 'actor', 'lyricist', 'singer', 'genre', 'keyword', 'summary' ], mapKeys = { 'keyword': 'topic' }, updateKeys, dialogHeight = Math.round((window.innerHeight - 48) * 0.9), dialogWidth = Math.round(window.innerWidth * 0.9), formWidth = getFormWidth(), imdb, $confirmDialog, $selectAllButton, $selectNoneButton, $label = {}, $input = {}, that = data.imdbId ? updateDialog() : idDialog(); keys = keys.filter(function(key) { return key == 'alternativeTitles' || getItemKey(key); }); data.imdbId && getMetadata(); function idDialog() { return pandora.ui.iconDialog({ buttons: [ Ox.Button({ id: 'close', title: Ox._('Not Now') }) .bindEvent({ click: function() { that.close(); } }), Ox.Button({ distabled: true, id: 'update', title: Ox._('Update IMDb ID...') }) .bindEvent({ click: function() { that.close(); pandora.$ui.idDialog = pandora.ui.idDialog(data).open(); } }) ], content: Ox._( 'To update the metadata for this {0}, please enter its IMDb ID.', [pandora.site.itemName.singular.toLowerCase()] ), keyboard: {enter: 'update', escape: 'close'}, title: Ox._('Update Metadata') }); } function updateDialog() { return Ox.Dialog({ buttons: [ Ox.Button({ id: 'switch', title: Ox._('Update IMDb ID...') }) .bindEvent({ click: function() { that.close(); pandora.$ui.idDialog = pandora.ui.idDialog(data).open(); } }), {}, Ox.Button({ id: 'cancel', title: Ox._('Don\'t Update') }) .bindEvent({ click: function() { that.close(); } }), Ox.Button({ disabled: true, id: 'update', title: Ox._('Update Metadata...') }) .bindEvent({ click: function() { $confirmDialog = confirmDialog().open(); } }) ], closeButton: true, content: Ox.LoadingScreen().start(), height: dialogHeight, maximizeButton: true, minHeight: 256, minWidth: 512, removeOnClose: true, title: Ox._('Update Metadata'), width: dialogWidth }) .bindEvent({ resize: setSize }); } function confirmDialog() { return pandora.ui.iconDialog({ buttons: [ Ox.Button({ id: 'cancel', title: Ox._('Don\'t Update') }) .bindEvent({ click: function() { $confirmDialog.close(); } }), Ox.Button({ id: 'update', title: Ox._('Update') }) .bindEvent({ click: function() { $confirmDialog.close(); updateMetadata(); } }) ], content: Ox._('Are you sure you want to update the value' + (updateKeys.length == 1 ? '' : 's') + ' for {0}?', [updateKeys.map(function(key, index) { return ( index == 0 ? '' : index < updateKeys.length - 1 ? ', ' : ' ' + Ox._('and') + ' ' ) + getTitle(key) }).join('')] ), height: 192, keyboard: {enter: 'update', escape: 'cancel'}, title: Ox._('Update Metadata') }); } function formatValue(key, value) { return !value ? '' : key == 'alternativeTitles' ? value.map(function(v) { return v[0]; }).join('; ') : key == 'runtime' ? Math.round(value / 60) + ' min' : key == 'productionCompany' ? value.join('; ') : Ox.isArray( getItemKey(key).type ) ? value.join(', ') : value; } function getFormWidth() { return dialogWidth - 32 - Ox.UI.SCROLLBAR_SIZE; } function getItemKey(key) { return Ox.getObjectById(pandora.site.itemKeys, getKey(key)); } function getKey(key) { return mapKeys[key] || key; } function getMetadata() { pandora.api.getMetadata({ id: data.imdbId, keys: keys.concat(['originalTitle']) }, function(result) { var $bar = Ox.Bar({size: 24}), $data = Ox.Element() .css({padding: '13px', overflowY: 'auto'}), $content = Ox.SplitPanel({ elements: [ {element: $bar, size: 24}, {element: $data} ], orientation: 'vertical' }); $selectNoneButton = Ox.Button({ title: Ox._('Select No Updates'), }) .css({float: 'left', margin: '4px 2px 4px 4px'}) .bindEvent({ click: function() { selectAll(0) } }) .appendTo($bar), $selectAllButton = Ox.Button({ title: Ox._('Select All Updates'), }) .css({float: 'left', margin: '4px 2px 4px 2px'}) .bindEvent({ click: function() { selectAll(1); } }) .appendTo($bar); if (result.data) { imdb = Ox.clone(result.data, true); if (imdb.originalTitle) { imdb.alternativeTitles = [[imdb.title, []]].concat(imdb.alternativeTitles || []); imdb.title = imdb.originalTitle; } keys.forEach(function(key, index) { var isEqual = Ox.isEqual(data[getKey(key)], imdb[key]) || ( isEmpty(data[getKey(key)]) && isEmpty(imdb[key]) ), checked = isEqual ? [true, true] : isEmpty(data[getKey(key)]) && !isEmpty(imdb[key]) ? [false, true] : [true, false]; if (index > 0) { $('