define(['itemShortcuts', 'connectionManager', 'layoutManager', 'browser', 'dom', 'loading', 'serverNotifications', 'events', 'registerElement'], function (itemShortcuts, connectionManager, layoutManager, browser, dom, loading, serverNotifications, events) { var ItemsContainerProtoType = Object.create(HTMLDivElement.prototype); function onClick(e) { var itemsContainer = this; var target = e.target; var multiSelect = itemsContainer.multiSelect; if (multiSelect) { if (multiSelect.onContainerClick.call(itemsContainer, e) === false) { return; } } itemShortcuts.onClick.call(itemsContainer, e); } function disableEvent(e) { e.preventDefault(); e.stopPropagation(); return false; } function onContextMenu(e) { var itemsContainer = this; var target = e.target; var card = dom.parentWithAttribute(target, 'data-id'); if (card) { //var itemSelectionPanel = card.querySelector('.itemSelectionPanel'); //if (!itemSelectionPanel) { // showContextMenu(card, {}); //} itemShortcuts.showContextMenu(card, { positionTo: target, itemsContainer: itemsContainer }); e.preventDefault(); e.stopPropagation(); return false; } } function getShortcutOptions() { return { click: false }; } ItemsContainerProtoType.enableHoverMenu = function (enabled) { var current = this.hoverMenu; if (!enabled) { if (current) { current.destroy(); this.hoverMenu = null; } return; } if (current) { return; } var self = this; require(['itemHoverMenu'], function (ItemHoverMenu) { self.hoverMenu = new ItemHoverMenu(self); }); }; ItemsContainerProtoType.enableMultiSelect = function (enabled) { var current = this.multiSelect; if (!enabled) { if (current) { current.destroy(); this.multiSelect = null; } return; } if (current) { return; } var self = this; require(['multiSelect'], function (MultiSelect) { self.multiSelect = new MultiSelect({ container: self, bindOnClick: false }); }); }; function onDrop(evt, itemsContainer) { loading.show(); var el = evt.item; var newIndex = evt.newIndex; var itemId = el.getAttribute('data-playlistitemid'); var playlistId = el.getAttribute('data-playlistid'); var serverId = el.getAttribute('data-serverid'); var apiClient = connectionManager.getApiClient(serverId); apiClient.ajax({ url: apiClient.getUrl('Playlists/' + playlistId + '/Items/' + itemId + '/Move/' + newIndex), type: 'POST' }).then(function () { el.setAttribute('data-index', newIndex); loading.hide(); }, function () { loading.hide(); itemsContainer.dispatchEvent(new CustomEvent('needsrefresh', { detail: {}, cancelable: false, bubbles: true })); }); } ItemsContainerProtoType.enableDragReordering = function (enabled) { var current = this.sortable; if (!enabled) { if (current) { current.destroy(); this.sortable = null; } return; } if (current) { return; } var self = this; require(['sortable'], function (Sortable) { self.sortable = new Sortable(self, { draggable: ".listItem", handle: '.listViewDragHandle', // dragging ended onEnd: function (/**Event*/evt) { onDrop(evt, self); } }); }); }; function onUserDataChanged(e, apiClient, userData) { var itemsContainer = this; require(['cardBuilder'], function (cardBuilder) { cardBuilder.onUserDataChanged(userData, itemsContainer); }); } function onTimerCreated(e, apiClient, data) { var itemsContainer = this; var programId = data.ProgramId; // This could be null, not supported by all tv providers var newTimerId = data.Id; require(['cardBuilder'], function (cardBuilder) { cardBuilder.onTimerCreated(programId, newTimerId, itemsContainer); }); } function onSeriesTimerCreated(e, apiClient, data) { var itemsContainer = this; } function onTimerCancelled(e, apiClient, data) { var itemsContainer = this; var id = data.Id; require(['cardBuilder'], function (cardBuilder) { cardBuilder.onTimerCancelled(id, itemsContainer); }); } function onSeriesTimerCancelled(e, apiClient, data) { var itemsContainer = this; var id = data.Id; require(['cardBuilder'], function (cardBuilder) { cardBuilder.onSeriesTimerCancelled(id, itemsContainer); }); } function addNotificationEvent(instance, name, handler) { var localHandler = handler.bind(instance); events.on(serverNotifications, name, localHandler); instance[name] = localHandler; } function removeNotificationEvent(instance, name) { var handler = instance[name]; if (handler) { events.off(serverNotifications, 'UserDataChanged', handler); instance[name] = null; } } ItemsContainerProtoType.attachedCallback = function () { this.addEventListener('click', onClick); if (browser.touch) { this.addEventListener('contextmenu', disableEvent); } else { this.addEventListener('contextmenu', onContextMenu); } if (layoutManager.desktop) { this.enableHoverMenu(true); } if (layoutManager.desktop || layoutManager.mobile) { this.enableMultiSelect(true); } itemShortcuts.on(this, getShortcutOptions()); addNotificationEvent(this, 'UserDataChanged', onUserDataChanged); addNotificationEvent(this, 'TimerCreated', onTimerCreated); addNotificationEvent(this, 'SeriesTimerCreated', onSeriesTimerCreated); addNotificationEvent(this, 'TimerCancelled', onTimerCancelled); addNotificationEvent(this, 'SeriesTimerCancelled', onSeriesTimerCancelled); }; ItemsContainerProtoType.detachedCallback = function () { this.enableHoverMenu(false); this.enableMultiSelect(false); this.enableDragReordering(false); this.removeEventListener('click', onClick); this.removeEventListener('contextmenu', onContextMenu); this.removeEventListener('contextmenu', disableEvent); itemShortcuts.off(this, getShortcutOptions()); removeNotificationEvent(this, 'UserDataChanged'); removeNotificationEvent(this, 'TimerCreated'); removeNotificationEvent(this, 'SeriesTimerCreated'); removeNotificationEvent(this, 'TimerCancelled'); removeNotificationEvent(this, 'SeriesTimerCancelled'); }; document.registerElement('emby-itemscontainer', { prototype: ItemsContainerProtoType, extends: 'div' }); });