pandora/static/js/pandora/menu.js

630 lines
34 KiB
JavaScript
Raw Normal View History

2011-07-29 18:37:11 +00:00
// vim: et:ts=4:sw=4:sts=4:ft=javascript
2012-02-03 09:15:38 +00:00
'use strict';
2011-05-25 19:42:45 +00:00
pandora.ui.mainMenu = function() {
2011-09-27 14:14:40 +00:00
var isGuest = pandora.user.level == 'guest',
ui = pandora.user.ui,
findState = pandora.getFindState(ui.find),
2011-06-19 17:49:25 +00:00
that = Ox.MainMenu({
2011-05-25 19:42:45 +00:00
extras: [
2011-06-19 17:49:25 +00:00
pandora.$ui.loadingIcon = Ox.LoadingIcon({
2011-05-25 19:42:45 +00:00
size: 'medium'
})
],
id: 'mainMenu',
menus: Ox.merge(
[
{ id: pandora.site.site.id + 'Menu', title: pandora.site.site.name, items: Ox.merge(
[
{ id: 'home', title: 'Home' },
{}
],
pandora.site.sitePages,
[
{},
{ id: 'software', title: 'Software' }
]
) },
{ id: 'userMenu', title: 'User', items: [
2012-03-08 09:40:04 +00:00
{ id: 'username', title: 'User: ' + (isGuest ? 'not signed in' : Ox.encodeHTMLEntities(pandora.user.username)), disabled: true },
2011-09-04 21:15:53 +00:00
{},
{ id: 'preferences', title: 'Preferences...', disabled: isGuest, keyboard: 'control ,' },
2011-11-03 14:09:30 +00:00
{ id: 'archives', title: 'Archives...', disabled: /*isGuest*/ true },
{ id: 'upload', title: 'Upload...', disabled: !pandora.site.capabilities.canUploadVideo[pandora.user.level]},
{},
{ id: 'signup', title: 'Sign Up...', disabled: !isGuest },
isGuest ? { id: 'signin', title: 'Sign In...' }
: { id: 'signout', title: 'Sign Out...'}
] },
getListMenu(),
{ id: 'editMenu', title: 'Edit', items: [
{ id: 'undo', title: 'Undo', disabled: true, keyboard: 'control z' },
{ id: 'redo', title: 'Redo', disabled: true, keyboard: 'shift control z' },
{},
{ id: 'cut', title: 'Cut', disabled: true, keyboard: 'control x' },
{ id: 'copy', title: 'Copy', disabled: true, keyboard: 'control c' },
{ id: 'paste', title: 'Paste', disabled: true, keyboard: 'control v' },
{ id: 'delete', title: 'Delete', disabled: true, keyboard: 'delete' },
{},
{ id: 'selectall', title: 'Select All', disabled: true, keyboard: 'control a' },
{ id: 'selectnone', title: 'Select None', disabled: true, keyboard: 'shift control a' },
{ id: 'invertselection', title: 'Invert Selection', disabled: true, keyboard: 'alt control a' }
] },
{ id: 'viewMenu', title: 'View', items: [
{ id: 'items', title: 'View ' + pandora.site.itemName.plural, items: [
{ group: 'listview', min: 1, max: 1, items: pandora.site.listViews.map(function(view) {
return Ox.extend({
checked: ui.listView == view.id,
}, view);
}) },
]},
{ id: 'icons', title: 'Icons', items: Ox.merge([
{ group: 'viewicons', min: 1, max: 1, items: ['posters', 'frames'].map(function(icons) {
return {id: icons, title: Ox.toTitleCase(icons), checked: ui.icons == icons};
}) }
], pandora.site.media.importPosters ? [
{},
{ id: 'showsiteposters', title: 'Always Show ' + pandora.site.site.name + ' Poster', checked: ui.showSitePosters }
] : []
) },
2012-03-06 21:28:27 +00:00
{ id: 'timelines', title: 'Timelines', items: [
2012-03-17 06:31:34 +00:00
{ group: 'viewtimelines', min: 1, max: 1, items: pandora.site.timelines.map(function(mode) {
2012-03-20 15:14:05 +00:00
return {id: mode.id, title: mode.title, checked: ui.videoTimeline == mode.id, disabled: true};
2012-03-06 21:28:27 +00:00
}) }
]},
{ id: 'columns', title: 'Columns', items: [
2011-11-11 13:20:53 +00:00
{ id: 'loadcolumns', title: 'Load Layout...', disabled: true },
{ id: 'savecolumns', title: 'Save Layout...', disabled: true },
{},
2011-11-11 13:20:53 +00:00
{ id: 'resetcolumns', title: 'Reset Layout', disabled: true }
2012-03-06 21:28:27 +00:00
] },
{},
{ id: 'item', title: ['Open ' + pandora.site.itemName.singular, 'Open ' + pandora.site.itemName.plural], items: [
{ group: 'itemview', min: 1, max: 1, items: pandora.site.itemViews.map(function(view) {
return Ox.extend({
checked: ui.itemView == view.id,
}, view);
}) },
2012-03-06 21:28:27 +00:00
] },
{ id: 'clips', title: 'Open Clips', items: [
{ group: 'videoview', min: 1, max: 1, items: ['video', 'timeline'].map(function(view) {
return {id: view, title: view == 'video' ? 'Player' : 'Editor', checked: ui.videoView == view};
}) }
] },
{},
2011-11-06 08:28:10 +00:00
{ id: 'filters', title: 'Filters', items: [
{ group: 'filters', min: 5, max: 5, items: pandora.site.filters.map(function(filter) {
return Ox.extend({
checked: Ox.getIndexById(ui.filters, filter.id) > -1
2011-11-06 08:28:10 +00:00
}, filter);
}) },
{},
2011-11-06 08:28:10 +00:00
{ id: 'resetfilters', title: 'Reset Filters' }
] },
{},
{ id: 'showsidebar', title: (ui.showSidebar ? 'Hide' : 'Show') + ' Sidebar', keyboard: 'shift s' },
{ id: 'showinfo', title: (ui.showInfo ? 'Hide' : 'Show') + ' Info', disabled: !ui.showSidebar, keyboard: 'shift i' },
2011-11-06 08:28:10 +00:00
{ id: 'showfilters', title: (ui.showFilters ? 'Hide' : 'Show') + ' Filters', disabled: !!ui.item, keyboard: 'shift f' },
{ id: 'showbrowser', title: (ui.showBrowser ? 'Hide' : 'Show') + ' ' + pandora.site.itemName.singular + ' Browser', disabled: !ui.item, keyboard: 'shift b' },
{ id: 'showannotations', title: (ui.showAnnotations ? 'Hide' : 'Show') + ' Annotations', disabled: !ui.item || ['timeline', 'video'].indexOf(ui.itemView) == -1, keyboard: 'shift a' },
{ id: 'showtimeline', title: (ui.showTimeline ? 'Hide' : 'Show') + ' Timeline', disabled: !ui.item || ui.itemView != 'video', keyboard: 'shift t' },
{},
{ id: 'fullscreen', title: 'Enter Fullscreen', disabled: !ui.item || ui.itemView != 'video' },
{},
{ id: 'theme', title: 'Theme', items: [
{ group: 'settheme', min: 1, max: 1, items: [
2012-02-17 22:29:38 +00:00
{ id: 'classic', title: 'Light', checked: ui.theme == 'classic'},
{ id: 'modern', title: 'Dark', checked: ui.theme == 'modern' }
]}
] }
2011-05-25 19:42:45 +00:00
]},
getSortMenu(),
{ id: 'findMenu', title: 'Find', items: [
{ id: 'find', title: 'Find', items: [
{ group: 'find', min: 0, max: 1, items: pandora.site.findKeys.map(function(key, i) {
return Ox.extend({
checked: key.id == findState.key
}, key);
}) }
] },
{ id: 'advancedfind', title: 'Advanced Find...', keyboard: 'shift control f' },
{},
{ id: 'findsimilar', title: 'Find Similar Clips...', disabled: true}
2011-08-19 06:40:19 +00:00
] },
{ id: 'dataMenu', title: 'Data', items: [
{ id: 'titles', title: 'Manage Titles...', disabled: !pandora.site.capabilities.canManageTitlesAndNames[pandora.user.level] },
{ id: 'names', title: 'Manage Names...', disabled: !pandora.site.capabilities.canManageTitlesAndNames[pandora.user.level] },
2011-09-18 00:31:41 +00:00
{},
{ id: 'places', title: 'Manage Places...', disabled: !pandora.site.capabilities.canManagePlacesAndEvents[pandora.user.level] },
{ id: 'events', title: 'Manage Events...', disabled: !pandora.site.capabilities.canManagePlacesAndEvents[pandora.user.level] },
{},
{ id: 'users', title: 'Manage Users...', disabled: !pandora.site.capabilities.canManageUsers[pandora.user.level] },
{ id: 'statistics', title: 'Statistics...', disabled: !pandora.site.capabilities.canManageUsers[pandora.user.level] }
2011-09-17 23:24:53 +00:00
] },
{ id: 'helpMenu', title: 'Help', items: [
2011-11-03 14:09:30 +00:00
{ id: 'help', title: pandora.site.site.name + ' Help', keyboard: 'control ?' }
2011-09-09 12:09:05 +00:00
] }
],
pandora.site.capabilities.canSeeDebugMenu[pandora.user.level]
? [
{ id: 'debugMenu', title: 'Debug', items: [
2011-11-02 21:04:27 +00:00
{ id: 'logs', title: 'View Logs...'},
{ id: 'clearcache', title: 'Clear Cache'},
{ id: 'reloadapplication', title: 'Reload Application'},
2011-10-28 18:05:17 +00:00
{ id: 'resetui', title: 'Reset UI Settings'},
2011-12-30 20:47:40 +00:00
{ id: 'debug', title: (pandora.localStorage('debug')?'Disable':'Enable')+' Debug Mode'},
2011-11-03 01:52:15 +00:00
{ id: 'triggererror', title: 'Trigger JavaScript Error'},
] }
]
: []
)
2011-05-25 19:42:45 +00:00
})
2011-11-01 12:03:02 +00:00
.bindKeyboard()
2011-05-25 19:42:45 +00:00
.bindEvent({
2011-09-17 17:40:15 +00:00
change: function(data) {
2011-09-18 01:52:43 +00:00
var value = data.checked[0] ? data.checked[0].id : null;
if (data.id == 'allitems') {
if (data.checked) {
pandora.UI.set('find', {conditions: [], operator: '&'});
} else {
that.checkItem('allitems');
}
} else if (data.id == 'find') {
if (value) {
pandora.$ui.findSelect.value(value);
if (pandora.user.ui._findState.key == 'advanced') {
// fixme: autocomplete function doesn't get updated
pandora.$ui.findInput.options({placeholder: ''});
}
} else {
that.checkItem('findMenu_find_' + pandora.$ui.findSelect.value());
}
pandora.$ui.findInput.focusInput(true);
} else if (data.id == 'itemview') {
pandora.UI.set({itemView: value});
} else if (data.id == 'listview') {
var set = {listView: value};
if (
!pandora.isClipView(key, pandora.user.ui.item)
&& ['title', 'position'].indexOf(pandora.user.ui.listSort[0].key) > -1
) {
set.listSort = pandora.site.user.ui.listSort;
}
pandora.UI.set(set);
2011-11-06 08:28:10 +00:00
} else if (Ox.startsWith(data.id, 'orderfilter')) {
var filters = Ox.clone(pandora.user.ui.filters),
id = data.id.replace('orderfilter', ''),
index = Ox.getIndexById(filters, id),
key = filters[index].sort[0].key,
2011-09-17 23:24:53 +00:00
operator = value == 'ascending' ? '+' : '-';
pandora.$ui.filters[index].options({
2011-09-17 23:24:53 +00:00
sort: [{key: key, operator: operator}]
});
filters[index].sort[0].operator = operator;
2011-11-06 08:28:10 +00:00
pandora.UI.set({filters: filters});
} else if (data.id == 'listorder') {
var key = pandora.user.ui.listSort[0].key,
2011-08-18 07:54:46 +00:00
operator = value == 'ascending' ? '+' : '-';
pandora.UI.set({listSort: [{key: key, operator: operator}]});
} else if (data.id == 'listsort') {
pandora.UI.set({listSort: [{key: value, operator: ''}]});
2011-09-09 12:09:05 +00:00
} else if (data.id == 'settheme') {
Ox.Theme(value);
pandora.UI.set('theme', value);
} else if (data.id == 'showsiteposters') {
pandora.UI.set('showSitePosters', data.checked)
2011-11-06 08:28:10 +00:00
} else if (Ox.startsWith(data.id, 'sortfilter')) {
var filters = Ox.clone(ui.filters),
id = data.id.replace('sortfilter', ''),
index = Ox.getIndexById(filters, id),
2011-11-06 08:28:10 +00:00
type = Ox.getObjectById(pandora.site.filters, id).type,
2011-09-17 23:24:53 +00:00
key = value,
operator = key == 'name' && type == 'string' ? '+' : '-';
2011-11-06 08:28:10 +00:00
pandora.$ui.mainMenu.checkItem(
'sortMenu_orderfilters_orderfilter' + id + '_'
+ (operator == '+' ? 'ascending' : 'descending')
);
pandora.$ui.filters[index].options({
2011-09-17 23:24:53 +00:00
sort: [{key: key, operator: operator}]
});
filters[index].sort[0].key = key;
2011-11-06 08:28:10 +00:00
pandora.UI.set({filters: filters});
} else if (data.id == 'videoview') {
var set = {videoView: value};
if (
value == 'video' && ui.itemView == 'timeline'
|| value == 'timeline' && ui.itemView == 'video'
) {
set.itemView = value;
}
pandora.UI.set(set);
} else if (data.id == 'viewicons') {
pandora.UI.set({icons: value});
} else if (data.id.substr(0, 8) == 'viewlist') {
2011-11-03 17:11:10 +00:00
pandora.UI.set({
find: {
conditions: data.checked ? [
{key: 'list', value: data.id.substr(8), operator: '=='}
2011-11-03 17:11:10 +00:00
] : [],
operator: '&'
}
});
2012-03-06 21:28:27 +00:00
} else if (data.id == 'viewtimelines') {
pandora.UI.set({videoTimeline: value});
2011-05-25 19:42:45 +00:00
}
},
2011-09-17 17:40:15 +00:00
click: function(data) {
2012-01-20 18:10:25 +00:00
if (Ox.merge(
['home', 'software'],
pandora.site.sitePages.map(function(page) {
return page.id;
}),
['signup', 'signin', 'signout', 'preferences', 'tv', 'help']
2012-01-30 23:56:41 +00:00
).indexOf(data.id) > -1) {
2011-11-09 22:32:54 +00:00
pandora.UI.set({page: data.id});
2012-03-17 00:15:06 +00:00
} else if (data.id == 'upload') {
pandora.$ui.uploadDialog = pandora.ui.uploadDialog().open();
2011-09-29 17:25:04 +00:00
} else if ([
'newlist', 'newlistfromselection', 'newsmartlist', 'newsmartlistfromresults'
].indexOf(data.id) > -1) {
pandora.addList(data.id.indexOf('smart') > -1, data.id.indexOf('from') > -1);
} else if (data.id == 'duplicatelist') {
pandora.addList(pandora.user.ui._list);
} else if (data.id == 'editlist') {
pandora.ui.listDialog().open();
} else if (data.id == 'deletelist') {
pandora.ui.deleteListDialog().open();
} else if (data.id == 'showsidebar') {
pandora.UI.set({showSidebar: !ui.showSidebar});
} else if (data.id == 'showinfo') {
pandora.UI.set({showInfo: !ui.showInfo});
2011-11-06 08:28:10 +00:00
} else if (data.id == 'showfilters') {
pandora.UI.set({showFilters: !ui.showFilters});
} else if (data.id == 'showbrowser') {
pandora.UI.set({showBrowser: !ui.showBrowser});
} else if (data.id == 'showannotations') {
pandora.UI.set({showAnnotations: !ui.showAnnotations});
} else if (data.id == 'showtimeline') {
pandora.UI.set({showTimeline: !ui.showTimeline});
} else if (data.id == 'fullscreen') {
pandora.$ui.player.options({fullscreen: true});
} else if (data.id == 'advancedfind') {
if (!pandora.hasDialogOrScreen()) {
pandora.$ui.filterDialog = pandora.ui.filterDialog().open();
}
2011-10-11 11:29:05 +00:00
} else if (data.id == 'titles') {
2011-11-01 20:04:16 +00:00
(pandora.$ui.titlesDialog || (
pandora.$ui.titlesDialog = pandora.ui.titlesDialog()
)).open();
} else if (data.id == 'names') {
(pandora.$ui.namesDialog || (
pandora.$ui.namesDialog = pandora.ui.namesDialog()
)).open();
2011-05-25 19:42:45 +00:00
} else if (data.id == 'places') {
2011-11-01 20:04:16 +00:00
(pandora.$ui.placesDialog || (
pandora.$ui.placesDialog = pandora.ui.placesDialog()
)).open();
} else if (data.id == 'events') {
2011-11-01 20:04:16 +00:00
(pandora.$ui.eventsDialog || (
pandora.$ui.eventsDialog = pandora.ui.eventsDialog()
)).open();
} else if (data.id == 'users') {
2011-11-11 18:55:13 +00:00
pandora.$ui.usersDialog = pandora.ui.usersDialog().open();
2012-03-22 20:08:51 +00:00
} else if (data.id == 'statistics') {
pandora.$ui.statisticsDialog = pandora.ui.statisticsDialog().open();
2011-11-06 08:28:10 +00:00
} else if (data.id == 'resetfilters') {
2011-09-18 00:31:41 +00:00
pandora.UI.set({
2011-11-06 08:28:10 +00:00
filters: pandora.site.user.ui.filters
2011-09-18 00:31:41 +00:00
});
pandora.$ui.contentPanel.replaceElement(0, pandora.$ui.browser = pandora.ui.browser());
2011-11-02 21:04:27 +00:00
} else if (data.id == 'logs') {
2012-03-19 12:35:41 +00:00
pandora.$ui.logsDialog = pandora.ui.logsDialog().open();
} else if (data.id == 'clearcache') {
Ox.Request.clearCache();
} else if (data.id == 'reloadapplication') {
2012-03-23 11:17:50 +00:00
Ox.Request.clearCache();
pandora.$ui.appPanel.reload();
2011-05-25 19:42:45 +00:00
} else if (data.id == 'resetui') {
pandora.api.resetUI({}, function() {
2011-06-06 15:48:11 +00:00
pandora.$ui.appPanel.reload();
2011-05-25 19:42:45 +00:00
});
2011-10-28 18:05:17 +00:00
} else if (data.id == 'debug') {
2011-12-30 20:47:40 +00:00
if(pandora.localStorage('debug')) {
pandora.localStorage.delete('debug');
2011-10-28 18:05:17 +00:00
} else {
2011-12-30 20:47:40 +00:00
pandora.localStorage('debug', true);
2011-10-28 18:05:17 +00:00
}
2011-12-30 20:47:40 +00:00
that.setItemTitle('debug', (pandora.localStorage('debug') ? 'Disable' : 'Enable') + ' Debug Mode');
2011-11-03 01:52:15 +00:00
} else if (data.id == 'triggererror') {
var e = error;
2011-05-25 19:42:45 +00:00
}
},
2011-11-03 14:09:30 +00:00
key_control_comma: function() {
if (!pandora.hasDialogOrScreen()) {
pandora.UI.set({page: 'preferences'});
2011-11-03 14:09:30 +00:00
}
},
2011-11-01 12:03:02 +00:00
key_control_f: function() {
if (!pandora.hasDialogOrScreen()) {
if (pandora.user.ui._findState.key != 'advanced') {
pandora.$ui.findInput.focusInput(true);
} else {
pandora.$ui.filterDialog = pandora.ui.filterDialog().open();
}
}
},
key_control_shift_f: function() {
if (!pandora.hasDialogOrScreen()) {
pandora.$ui.filterDialog = pandora.ui.filterDialog().open();
2011-11-01 12:03:02 +00:00
}
},
key_control_shift_w: function() {
if (!pandora.hasDialogOrScreen() || (ui.item || ui._list)) {
pandora.UI.set({find: {conditions: [], operator: '&'}});
}
},
2011-11-03 14:09:30 +00:00
key_control_slash: function() {
if (!pandora.hasDialogOrScreen()) {
pandora.UI.set({page: 'help'});
2011-11-03 14:09:30 +00:00
}
},
2011-12-22 15:48:48 +00:00
key_control_space: function() {
if (!pandora.hasDialogOrScreen()) {
pandora.UI.set({page: 'tv'});
}
},
key_control_w: function() {
if (!pandora.hasDialogOrScreen()) {
if (ui.item) {
pandora.UI.set({item: ''});
} else if (ui._list) {
pandora.UI.set({find: {conditions: [], operator: '&'}});
}
}
},
2011-11-01 12:03:02 +00:00
key_shift_a: function() {
ui.item && ['video', 'timeline'].indexOf(ui.itemView) > -1
&& pandora.UI.set({showAnnotations: !ui.showAnnotations});
2011-11-01 12:03:02 +00:00
},
key_shift_b: function() {
ui.item && pandora.UI.set({showBrowser: !ui.showBrowser});
2011-11-01 12:03:02 +00:00
},
2011-11-06 08:28:10 +00:00
key_shift_f: function() {
!ui.item && pandora.UI.set({showFilters: !ui.showFilters});
2011-11-01 12:03:02 +00:00
},
key_shift_i: function() {
ui.showSidebar && pandora.UI.set({showInfo: !ui.showInfo});
2011-11-01 12:03:02 +00:00
},
key_shift_s: function() {
pandora.UI.set({showSidebar: !ui.showSidebar});
},
key_shift_t: function() {
ui.item && ui.itemView == 'video'
&& pandora.UI.set({showTimeline: !ui.showTimeline});
},
2011-09-29 17:25:04 +00:00
pandora_find: function() {
var list = ui._list,
listData = pandora.getListData(),
previousList = pandora.UI.getPrevious()._list,
action = list && listData.user == pandora.user.username
? 'enableItem' : 'disableItem';
if (list != previousList) {
that.uncheckItem(previousList == '' ? 'allitems' : 'viewlist' + previousList);
that.checkItem(list == '' ? 'allitems' : 'viewlist' + list);
}
2011-09-29 17:25:04 +00:00
that[action]('editlist');
that[action]('duplicatelist');
that[action]('deletelist');
that[ui.listSelection.length ? 'enableItem' : 'disableItem']('newlistfromselection');
},
2011-11-06 08:28:10 +00:00
pandora_filters: function(data) {
that.replaceMenu('sortMenu', getSortMenu());
},
pandora_item: function(data) {
if (!!data.value != !!data.previousValue) {
2011-11-06 08:28:10 +00:00
that[data.value ? 'disableItem' : 'enableItem']('showfilters');
that[data.value ? 'enableItem' : 'disableItem']('showbrowser');
2011-10-31 16:45:55 +00:00
that.replaceMenu('sortMenu', getSortMenu());
}
if (!data.value) {
that.disableItem('showannotations');
that.disableItem('showtimeline');
that.disableItem('fullscreen');
} else {
if (['video', 'timeline'].indexOf(ui.itemView) > -1) {
that.enableItem('showannotations');
}
if (ui.itemView == 'video') {
that.enableItem('showtimeline');
that.enableItem('fullscreen');
}
}
},
pandora_itemview: function(data) {
var action,
isVideoView = ['video', 'timeline'].indexOf(data.value) > -1,
wasVideoView = ['video', 'timeline'].indexOf(data.previousValue) > -1;
that.checkItem('viewMenu_item_' + data.value);
if (isVideoView) {
that.checkItem('viewMenu_clips_' + data.value);
}
if (isVideoView != wasVideoView) {
that[isVideoView ? 'enableItem' : 'disableItem']('showannotations');
}
if ((data.value == 'video') != (data.previousValue == 'video')) {
action = data.value == 'video' ? 'enableItem' : 'disableItem';
that[action]('showtimeline');
that[action]('fullscreen');
}
2011-09-29 17:25:04 +00:00
},
pandora_listselection: function(data) {
that[data.value.length ? 'enableItem' : 'disableItem']('newlistfromselection');
},
pandora_listsort: function(data) {
that.checkItem('sortMenu_sortitems_' + data.value[0].key);
that.checkItem('sortMenu_orderitems_' + (
data.value[0].operator == '+' ? 'ascending' : 'descending')
);
},
2011-09-29 17:25:04 +00:00
pandora_listview: function(data) {
that.checkItem('viewMenu_items_' + data.value);
if (pandora.isClipView() != pandora.isClipView(data.previousValue)) {
that.replaceMenu('sortMenu', getSortMenu());
}
},
pandora_showannotations: function(data) {
that.setItemTitle('showannotations', (data.value ? 'Hide' : 'Show') + ' Annotations');
},
pandora_showbrowser: function(data) {
that.setItemTitle('showbrowser', (data.value ? 'Hide' : 'Show') + ' ' + pandora.site.itemName.singular + ' Browser');
},
2011-11-06 08:28:10 +00:00
pandora_showfilters: function(data) {
that.setItemTitle('showfilters', (data.value ? 'Hide' : 'Show') + ' Filters');
},
pandora_showinfo: function(data) {
that.setItemTitle('showinfo', (data.value ? 'Hide' : 'Show') + ' Info');
},
pandora_showsidebar: function(data) {
that.setItemTitle('showsidebar', (data.value ? 'Hide' : 'Show') + ' Sidebar');
that[data.value ? 'enableItem' : 'disableItem']('showinfo');
},
pandora_showtimeline: function(data) {
that.setItemTitle('showtimeline', (data.value ? 'Hide' : 'Show') + ' Timeline');
2011-05-25 19:42:45 +00:00
}
});
2011-09-18 01:52:43 +00:00
2011-09-27 14:14:40 +00:00
function getListMenu(lists) {
return { id: 'listMenu', title: 'List', items: Ox.merge(
{ id: 'allitems', title: 'All ' + pandora.site.itemName.plural, checked: !ui.item && !ui._list, keyboard: 'shift control w' },
2011-09-27 14:14:40 +00:00
['personal', 'favorite', 'featured'].map(function(folder) {
return {
id: folder + 'lists',
title: Ox.toTitleCase(folder) + ' Lists',
items: Ox.isUndefined(lists)
? [{id: 'loading', title: 'Loading...', disabled: true}]
: lists[folder].length == 0
? [{id: 'nolists', title: 'No ' + Ox.toTitleCase(folder) + ' Lists', disabled: true}]
: lists[folder].map(function(list) {
2011-09-27 14:14:40 +00:00
return {
id: 'viewlist' + list.id,
title: Ox.encodeHTMLEntities((
folder == 'favorite' ? list.user + ': ' : ''
) + list.name),
2011-09-28 00:10:26 +00:00
checked: list.id == pandora.user.ui._list
2011-09-27 14:14:40 +00:00
};
})
2011-09-27 14:14:40 +00:00
};
}),
[
{},
{ id: 'newlist', title: 'New List', disabled: isGuest, keyboard: 'control n' },
{ id: 'newlistfromselection', title: 'New List from Selection', disabled: isGuest || ui.listSelection.length == 0, keyboard: 'shift control n' },
{ id: 'newsmartlist', title: 'New Smart List', disabled: isGuest, keyboard: 'alt control n' },
{ id: 'newsmartlistfromresults', title: 'New Smart List from Results', disabled: isGuest, keyboard: 'shift alt control n' },
2011-09-27 14:14:40 +00:00
{},
{ id: 'duplicatelist', title: 'Duplicate Selected List', disabled: isGuest || !pandora.user.ui._list, keyboard: 'control d' },
{ id: 'editlist', title: 'Edit Selected List...', disabled: isGuest || !pandora.user.ui._list, keyboard: 'control e' },
{ id: 'deletelist', title: 'Delete Selected List...', disabled: isGuest || !pandora.user.ui._list, keyboard: 'delete' },
2011-12-22 15:48:48 +00:00
{},
{ id: 'tv', title: 'TV', keyboard: 'control space' }
2011-09-27 14:14:40 +00:00
]
)};
};
function getSortMenu() {
var ui = pandora.user.ui,
isClipView = pandora.isClipView(ui.listView),
items = isClipView ? pandora.site.clipKeys.map(function(key) {
return Ox.extend(Ox.clone(key), {
checked: ui.listSort[0].key == key.id,
title: 'Clip ' + key.title
});
}) : [];
2011-09-27 14:14:40 +00:00
return { id: 'sortMenu', title: 'Sort', items: [
{ id: 'sortitems', title: 'Sort ' + (isClipView || ui.item ? 'Clips' : pandora.site.itemName.plural) + ' by', items: [
{ group: 'listsort', min: 1, max: 1, items: Ox.merge(
items,
Ox.map(pandora.site.sortKeys, function(key) {
return Ox.getIndexById(items, key.id) == -1 && (
!key.capability
|| pandora.site.capabilities[key.capability][pandora.user.level]
) ? Ox.extend({
2011-10-31 16:45:55 +00:00
checked: ui.listSort[0].key == key.id
}, key) : null;
})
2011-10-31 16:45:55 +00:00
) }
2011-09-27 14:14:40 +00:00
] },
{ id: 'orderitems', title: 'Order ' + (isClipView ? 'Clips' : pandora.site.itemName.plural), items: [
{ group: 'listorder', min: 1, max: 1, items: [
2011-09-27 14:14:40 +00:00
{ id: 'ascending', title: 'Ascending', checked: (ui.listSort[0].operator || pandora.getSortOperator(ui.listSort[0].key)) == '+' },
{ id: 'descending', title: 'Descending', checked: (ui.listSort[0].operator || pandora.getSortOperator(ui.listSort[0].key)) == '-' }
]}
] },
2011-11-11 16:11:01 +00:00
{ id: 'advancedsort', title: 'Advanced Sort...', keyboard: 'shift control s', disabled: true },
2011-09-27 14:14:40 +00:00
{},
2011-11-06 08:28:10 +00:00
{ id: 'sortfilters', title: 'Sort Filters', items: pandora.user.ui.filters.map(function(filter) {
2011-09-27 14:14:40 +00:00
return {
2011-11-06 08:28:10 +00:00
id: 'sortfilter' + filter.id,
title: 'Sort ' + Ox.getObjectById(pandora.site.filters, filter.id).title + ' Filter by',
2011-09-27 14:14:40 +00:00
items: [
2011-11-06 08:28:10 +00:00
{ group: 'sortfilter' + filter.id, min: 1, max: 1, items: [
{ id: 'name', title: 'Name', checked: filter.sort[0].key == 'name' },
{ id: 'items', title: 'Items', checked: filter.sort[0].key == 'items' }
2011-09-27 14:14:40 +00:00
] }
]
}
}) },
2011-11-06 08:28:10 +00:00
{ id: 'orderfilters', title: 'Order Filters', items: pandora.user.ui.filters.map(function(filter) {
2011-09-27 14:14:40 +00:00
return {
2011-11-06 08:28:10 +00:00
id: 'orderfilter' + filter.id,
title: 'Order ' + Ox.getObjectById(pandora.site.filters, filter.id).title + ' Filter',
2011-09-27 14:14:40 +00:00
items: [
2011-11-06 08:28:10 +00:00
{ group: 'orderfilter' + filter.id, min: 1, max: 1, items: [
{ id: 'ascending', title: 'Ascending', checked: filter.sort[0].operator == '+' },
{ id: 'descending', title: 'Descending', checked: filter.sort[0].operator == '-' }
2011-09-27 14:14:40 +00:00
] }
]
}
}) }
] };
}
// fixme: the sidebar makes (almost) the same requests.
2011-09-18 01:52:43 +00:00
// is it ok to make them twice, or should the sidebar trigger the menu replace?
var counter = 0,
lists = {},
queries = {
// fixme: duplicated
personal: {conditions: [
2011-09-28 17:32:03 +00:00
{key: 'user', value: pandora.user.username, operator: '=='},
{key: 'status', value: 'featured', operator: '!='}
2011-09-18 01:52:43 +00:00
], operator: '&'},
favorite: {conditions: [
{key: 'subscribed', value: true, operator: '='},
2011-09-28 17:32:03 +00:00
{key: 'status', value: 'featured', operator: '!='},
2011-09-18 01:52:43 +00:00
], operator: '&'},
featured: {conditions: [
{key: 'status', value: 'featured', operator: '='}
], operator: '&'}
};
Ox.forEach(queries, function(query, folder) {
pandora.api.findLists({
query: query,
keys: ['id', 'name', 'user'],
sort: [{key: 'position', operator: '+'}]
2011-09-18 01:52:43 +00:00
}, function(result) {
lists[folder] = result.data.items;
if (++counter == 3) {
2011-11-04 15:54:42 +00:00
Ox.Log('', '--------------------------------------------', lists)
2011-09-27 14:14:40 +00:00
pandora.$ui.mainMenu.replaceMenu('listMenu', getListMenu(lists));
2011-09-18 01:52:43 +00:00
}
});
});
2011-05-25 19:42:45 +00:00
return that;
2011-09-27 22:12:37 +00:00
2011-05-25 19:42:45 +00:00
};