1
0
Fork 0
mirror of https://github.com/jellyfin/jellyfin-web synced 2025-03-30 19:56:21 +00:00
jellyfin-web/src/components/metadataEditor/metadataEditor.js

1105 lines
39 KiB
JavaScript
Raw Normal View History

2019-01-23 11:33:34 +00:00
define(['itemHelper', 'dom', 'layoutManager', 'dialogHelper', 'datetime', 'loading', 'focusManager', 'connectionManager', 'globalize', 'require', 'shell', 'emby-checkbox', 'emby-input', 'emby-select', 'listViewStyle', 'emby-textarea', 'emby-button', 'paper-icon-button-light', 'css!./../formdialog', 'clearButtonStyle', 'flexStyles'], function (itemHelper, dom, layoutManager, dialogHelper, datetime, loading, focusManager, connectionManager, globalize, require, shell) {
'use strict';
var currentContext;
var metadataEditorInfo;
var currentItem;
2018-10-23 01:05:09 +03:00
function isDialog() {
return currentContext.classList.contains('dialog');
2018-10-23 01:05:09 +03:00
}
function closeDialog(isSubmitted) {
if (isDialog()) {
dialogHelper.close(currentContext);
}
2018-10-23 01:05:09 +03:00
}
function submitUpdatedItem(form, item) {
2018-10-23 01:05:09 +03:00
function afterContentTypeUpdated() {
require(['toast'], function (toast) {
toast(globalize.translate('MessageItemSaved'));
});
loading.hide();
closeDialog(true);
2018-10-23 01:05:09 +03:00
}
2018-10-23 01:05:09 +03:00
var apiClient = getApiClient();
apiClient.updateItem(item).then(function () {
var newContentType = form.querySelector('#selectContentType').value || '';
if ((metadataEditorInfo.ContentType || '') !== newContentType) {
apiClient.ajax({
url: apiClient.getUrl('Items/' + item.Id + '/ContentType', {
ContentType: newContentType
}),
type: 'POST'
}).then(function () {
afterContentTypeUpdated();
});
} else {
afterContentTypeUpdated();
}
});
2018-10-23 01:05:09 +03:00
}
function getSelectedAirDays(form) {
var checkedItems = form.querySelectorAll('.chkAirDay:checked') || [];
return Array.prototype.map.call(checkedItems, function (c) {
return c.getAttribute('data-day');
});
2018-10-23 01:05:09 +03:00
}
function getAlbumArtists(form) {
return form.querySelector('#txtAlbumArtist').value.trim().split(';').filter(function (s) {
return s.length > 0;
}).map(function (a) {
2018-10-23 01:05:09 +03:00
return {
Name: a
};
});
2018-10-23 01:05:09 +03:00
}
function getArtists(form) {
return form.querySelector('#txtArtist').value.trim().split(';').filter(function (s) {
return s.length > 0;
}).map(function (a) {
2018-10-23 01:05:09 +03:00
return {
Name: a
};
});
2018-10-23 01:05:09 +03:00
}
function getDateValue(form, element, property) {
2018-10-23 01:05:09 +03:00
var val = form.querySelector(element).value;
if (!val) {
return null;
}
2018-10-23 01:05:09 +03:00
if (currentItem[property]) {
var date = datetime.parseISO8601Date(currentItem[property], true);
var parts = date.toISOString().split('T');
// If the date is the same, preserve the time
if (parts[0].indexOf(val) === 0) {
var iso = parts[1];
val += 'T' + iso;
2018-10-23 01:05:09 +03:00
}
}
return val;
2018-10-23 01:05:09 +03:00
}
function onSubmit(e) {
2018-10-23 01:05:09 +03:00
loading.show();
var form = this;
var item = {
Id: currentItem.Id,
Name: form.querySelector('#txtName').value,
OriginalTitle: form.querySelector('#txtOriginalName').value,
ForcedSortName: form.querySelector('#txtSortName').value,
CommunityRating: form.querySelector('#txtCommunityRating').value,
CriticRating: form.querySelector('#txtCriticRating').value,
IndexNumber: form.querySelector('#txtIndexNumber').value || null,
AirsBeforeSeasonNumber: form.querySelector('#txtAirsBeforeSeason').value,
AirsAfterSeasonNumber: form.querySelector('#txtAirsAfterSeason').value,
AirsBeforeEpisodeNumber: form.querySelector('#txtAirsBeforeEpisode').value,
ParentIndexNumber: form.querySelector('#txtParentIndexNumber').value || null,
DisplayOrder: form.querySelector('#selectDisplayOrder').value,
Album: form.querySelector('#txtAlbum').value,
AlbumArtists: getAlbumArtists(form),
ArtistItems: getArtists(form),
Overview: form.querySelector('#txtOverview').value,
Status: form.querySelector('#selectStatus').value,
AirDays: getSelectedAirDays(form),
AirTime: form.querySelector('#txtAirTime').value,
2020-05-04 12:44:12 +02:00
Genres: getListValues(form.querySelector('#listGenres')),
Tags: getListValues(form.querySelector('#listTags')),
Studios: getListValues(form.querySelector('#listStudios')).map(function (element) {
return { Name: element };
}),
PremiereDate: getDateValue(form, '#txtPremiereDate', 'PremiereDate'),
DateCreated: getDateValue(form, '#txtDateAdded', 'DateCreated'),
EndDate: getDateValue(form, '#txtEndDate', 'EndDate'),
ProductionYear: form.querySelector('#txtProductionYear').value,
AspectRatio: form.querySelector('#txtOriginalAspectRatio').value,
Video3DFormat: form.querySelector('#select3dFormat').value,
OfficialRating: form.querySelector('#selectOfficialRating').value,
CustomRating: form.querySelector('#selectCustomRating').value,
People: currentItem.People,
2020-05-04 12:44:12 +02:00
LockData: form.querySelector('#chkLockData').checked,
LockedFields: Array.prototype.filter.call(form.querySelectorAll('.selectLockedField'), function (c) {
return !c.checked;
}).map(function (c) {
return c.getAttribute('data-value');
})
};
2018-10-23 01:05:09 +03:00
item.ProviderIds = Object.assign({}, currentItem.ProviderIds);
var idElements = form.querySelectorAll('.txtExternalId');
Array.prototype.map.call(idElements, function (idElem) {
var providerKey = idElem.getAttribute('data-providerkey');
item.ProviderIds[providerKey] = idElem.value;
});
item.PreferredMetadataLanguage = form.querySelector('#selectLanguage').value;
item.PreferredMetadataCountryCode = form.querySelector('#selectCountry').value;
2020-05-04 12:44:12 +02:00
if (currentItem.Type === 'Person') {
var placeOfBirth = form.querySelector('#txtPlaceOfBirth').value;
item.ProductionLocations = placeOfBirth ? [placeOfBirth] : [];
2018-10-23 01:05:09 +03:00
}
2020-05-04 12:44:12 +02:00
if (currentItem.Type === 'Series') {
// 600000000
var seriesRuntime = form.querySelector('#txtSeriesRuntime').value;
item.RunTimeTicks = seriesRuntime ? (seriesRuntime * 600000000) : null;
2018-10-23 01:05:09 +03:00
}
var tagline = form.querySelector('#txtTagline').value;
item.Taglines = tagline ? [tagline] : [];
submitUpdatedItem(form, item);
e.preventDefault();
e.stopPropagation();
// Disable default form submission
return false;
2018-10-23 01:05:09 +03:00
}
function getListValues(list) {
return Array.prototype.map.call(list.querySelectorAll('.textValue'), function (el) {
return el.textContent;
});
2018-10-23 01:05:09 +03:00
}
function addElementToList(source, sortCallback) {
require(['prompt'], function (prompt) {
2018-10-23 01:05:09 +03:00
prompt({
label: 'Value:'
}).then(function (text) {
var list = dom.parentWithClass(source, 'editableListviewContainer').querySelector('.paperList');
var items = getListValues(list);
items.push(text);
populateListView(list, items, sortCallback);
});
});
2018-10-23 01:05:09 +03:00
}
function removeElementFromList(source) {
var el = dom.parentWithClass(source, 'listItem');
el.parentNode.removeChild(el);
2018-10-23 01:05:09 +03:00
}
function editPerson(context, person, index) {
require(['personEditor'], function (personEditor) {
personEditor.show(person).then(function (updatedPerson) {
var isNew = index === -1;
if (isNew) {
currentItem.People.push(updatedPerson);
}
populatePeople(context, currentItem.People);
});
});
2018-10-23 01:05:09 +03:00
}
function onEditorClick(e) {
var btnRemoveFromEditorList = dom.parentWithClass(e.target, 'btnRemoveFromEditorList');
if (btnRemoveFromEditorList) {
removeElementFromList(btnRemoveFromEditorList);
return;
}
var btnAddTextItem = dom.parentWithClass(e.target, 'btnAddTextItem');
if (btnAddTextItem) {
addElementToList(btnAddTextItem);
}
2018-10-23 01:05:09 +03:00
}
function getApiClient() {
return connectionManager.getApiClient(currentItem.ServerId);
2018-10-23 01:05:09 +03:00
}
2020-05-11 21:43:41 +02:00
function bindAll(elems, eventName, fn) {
for (var i = 0, length = elems.length; i < length; i++) {
elems[i].addEventListener(eventName, fn);
}
}
2018-10-23 01:05:09 +03:00
function init(context, apiClient) {
context.querySelector('.externalIds').addEventListener('click', function (e) {
var btnOpenExternalId = dom.parentWithClass(e.target, 'btnOpenExternalId');
2018-10-23 01:05:09 +03:00
if (btnOpenExternalId) {
var field = context.querySelector('#' + btnOpenExternalId.getAttribute('data-fieldid'));
var formatString = field.getAttribute('data-formatstring');
if (field.value) {
shell.openUrl(formatString.replace('{0}', field.value));
}
2018-10-23 01:05:09 +03:00
}
});
if (!layoutManager.desktop) {
context.querySelector('.btnBack').classList.remove('hide');
context.querySelector('.btnClose').classList.add('hide');
}
2020-05-11 21:43:41 +02:00
bindAll(context.querySelectorAll('.btnCancel'), 'click', function (event) {
event.preventDefault();
closeDialog(false);
});
context.querySelector('.btnHeaderSave').addEventListener('click', function (e) {
context.querySelector('.btnSave').click();
});
context.querySelector('#chkLockData').addEventListener('click', function (e) {
if (!e.target.checked) {
showElement('.providerSettingsContainer');
} else {
hideElement('.providerSettingsContainer');
}
});
context.removeEventListener('click', onEditorClick);
context.addEventListener('click', onEditorClick);
var form = context.querySelector('form');
form.removeEventListener('submit', onSubmit);
form.addEventListener('submit', onSubmit);
2020-05-04 12:44:12 +02:00
context.querySelector('#btnAddPerson').addEventListener('click', function (event, data) {
editPerson(context, {}, -1);
});
context.querySelector('#peopleList').addEventListener('click', function (e) {
var index;
var btnDeletePerson = dom.parentWithClass(e.target, 'btnDeletePerson');
if (btnDeletePerson) {
index = parseInt(btnDeletePerson.getAttribute('data-index'));
currentItem.People.splice(index, 1);
populatePeople(context, currentItem.People);
}
var btnEditPerson = dom.parentWithClass(e.target, 'btnEditPerson');
if (btnEditPerson) {
index = parseInt(btnEditPerson.getAttribute('data-index'));
editPerson(context, currentItem.People[index], index);
}
});
2018-10-23 01:05:09 +03:00
}
function getItem(itemId, serverId) {
2018-10-23 01:05:09 +03:00
var apiClient = connectionManager.getApiClient(serverId);
if (itemId) {
return apiClient.getItem(apiClient.getCurrentUserId(), itemId);
}
return apiClient.getRootFolder(apiClient.getCurrentUserId());
2018-10-23 01:05:09 +03:00
}
function getEditorConfig(itemId, serverId) {
2018-10-23 01:05:09 +03:00
var apiClient = connectionManager.getApiClient(serverId);
if (itemId) {
return apiClient.getJSON(apiClient.getUrl('Items/' + itemId + '/MetadataEditor'));
}
return Promise.resolve({});
2018-10-23 01:05:09 +03:00
}
function populateCountries(select, allCountries) {
2020-05-04 12:44:12 +02:00
var html = '';
2018-10-23 01:05:09 +03:00
html += "<option value=''></option>";
2018-10-23 01:05:09 +03:00
for (var i = 0, length = allCountries.length; i < length; i++) {
2018-10-23 01:05:09 +03:00
var culture = allCountries[i];
2020-05-04 12:44:12 +02:00
html += "<option value='" + culture.TwoLetterISORegionName + "'>" + culture.DisplayName + '</option>';
2018-10-23 01:05:09 +03:00
}
select.innerHTML = html;
2018-10-23 01:05:09 +03:00
}
function populateLanguages(select, languages) {
2020-05-04 12:44:12 +02:00
var html = '';
2018-10-23 01:05:09 +03:00
html += "<option value=''></option>";
2018-10-23 01:05:09 +03:00
for (var i = 0, length = languages.length; i < length; i++) {
2018-10-23 01:05:09 +03:00
var culture = languages[i];
2020-05-04 12:44:12 +02:00
html += "<option value='" + culture.TwoLetterISOLanguageName + "'>" + culture.DisplayName + '</option>';
2018-10-23 01:05:09 +03:00
}
select.innerHTML = html;
2018-10-23 01:05:09 +03:00
}
function renderContentTypeOptions(context, metadataInfo) {
if (!metadataInfo.ContentTypeOptions.length) {
hideElement('#fldContentType', context);
} else {
showElement('#fldContentType', context);
}
var html = metadataInfo.ContentTypeOptions.map(function (i) {
return '<option value="' + i.Value + '">' + i.Name + '</option>';
}).join('');
var selectEl = context.querySelector('#selectContentType');
selectEl.innerHTML = html;
selectEl.value = metadataInfo.ContentType || '';
2018-10-23 01:05:09 +03:00
}
function loadExternalIds(context, item, externalIds) {
var html = '';
var providerIds = item.ProviderIds || {};
for (var i = 0, length = externalIds.length; i < length; i++) {
var idInfo = externalIds[i];
2020-05-04 12:44:12 +02:00
var id = 'txt1' + idInfo.Key;
var formatString = idInfo.UrlFormatString || '';
2020-03-22 13:08:10 -07:00
var fullName = idInfo.Name;
if (idInfo.Type) {
2020-05-04 12:44:12 +02:00
fullName = idInfo.Name + ' ' + globalize.translate(idInfo.Type);
2020-03-22 13:08:10 -07:00
}
2020-04-03 23:41:19 +02:00
var labelText = globalize.translate('LabelDynamicExternalId', fullName);
html += '<div class="inputContainer">';
html += '<div class="flex align-items-center">';
var value = providerIds[idInfo.Key] || '';
html += '<div class="flex-grow">';
html += '<input is="emby-input" class="txtExternalId" value="' + value + '" data-providerkey="' + idInfo.Key + '" data-formatstring="' + formatString + '" id="' + id + '" label="' + labelText + '"/>';
html += '</div>';
if (formatString) {
2020-04-26 02:37:28 +03:00
html += '<button type="button" is="paper-icon-button-light" class="btnOpenExternalId align-self-flex-end" data-fieldid="' + id + '"><span class="material-icons open_in_browser"></span></button>';
}
html += '</div>';
html += '</div>';
}
var elem = context.querySelector('.externalIds', context);
elem.innerHTML = html;
if (externalIds.length) {
context.querySelector('.externalIdsSection').classList.remove('hide');
} else {
context.querySelector('.externalIdsSection').classList.add('hide');
2018-10-23 01:05:09 +03:00
}
}
// Function to hide the element by selector or raw element
// Selector can be an element or a selector string
// Context is optional and restricts the querySelector to the context
2018-10-23 01:05:09 +03:00
function hideElement(selector, context, multiple) {
context = context || document;
if (typeof selector === 'string') {
2018-10-23 01:05:09 +03:00
var elements = multiple ? context.querySelectorAll(selector) : [context.querySelector(selector)];
Array.prototype.forEach.call(elements, function (el) {
if (el) {
el.classList.add('hide');
}
});
} else {
selector.classList.add('hide');
}
2018-10-23 01:05:09 +03:00
}
// Function to show the element by selector or raw element
// Selector can be an element or a selector string
// Context is optional and restricts the querySelector to the context
2018-10-23 01:05:09 +03:00
function showElement(selector, context, multiple) {
context = context || document;
if (typeof selector === 'string') {
2018-10-23 01:05:09 +03:00
var elements = multiple ? context.querySelectorAll(selector) : [context.querySelector(selector)];
Array.prototype.forEach.call(elements, function (el) {
if (el) {
el.classList.remove('hide');
}
});
} else {
selector.classList.remove('hide');
}
2018-10-23 01:05:09 +03:00
}
function setFieldVisibilities(context, item) {
if (item.Path && item.EnableMediaSourceDisplay !== false) {
showElement('#fldPath', context);
} else {
hideElement('#fldPath', context);
}
2020-05-04 12:44:12 +02:00
if (item.Type === 'Series' || item.Type === 'Movie' || item.Type === 'Trailer') {
showElement('#fldOriginalName', context);
} else {
hideElement('#fldOriginalName', context);
}
2020-05-04 12:44:12 +02:00
if (item.Type === 'Series') {
showElement('#fldSeriesRuntime', context);
} else {
hideElement('#fldSeriesRuntime', context);
}
2020-05-04 12:44:12 +02:00
if (item.Type === 'Series' || item.Type === 'Person') {
showElement('#fldEndDate', context);
} else {
hideElement('#fldEndDate', context);
}
2020-05-04 12:44:12 +02:00
if (item.Type === 'MusicAlbum') {
showElement('#albumAssociationMessage', context);
} else {
hideElement('#albumAssociationMessage', context);
}
2020-05-04 12:44:12 +02:00
if (item.Type === 'Movie' || item.Type === 'Trailer') {
showElement('#fldCriticRating', context);
} else {
hideElement('#fldCriticRating', context);
}
2020-05-04 12:44:12 +02:00
if (item.Type === 'Series') {
showElement('#fldStatus', context);
showElement('#fldAirDays', context);
showElement('#fldAirTime', context);
} else {
hideElement('#fldStatus', context);
hideElement('#fldAirDays', context);
hideElement('#fldAirTime', context);
}
2020-05-04 12:44:12 +02:00
if (item.MediaType === 'Video' && item.Type !== 'TvChannel') {
showElement('#fld3dFormat', context);
} else {
hideElement('#fld3dFormat', context);
}
2020-05-04 12:44:12 +02:00
if (item.Type === 'Audio') {
showElement('#fldAlbumArtist', context);
} else {
hideElement('#fldAlbumArtist', context);
}
2020-05-04 12:44:12 +02:00
if (item.Type === 'Audio' || item.Type === 'MusicVideo') {
showElement('#fldArtist', context);
showElement('#fldAlbum', context);
} else {
hideElement('#fldArtist', context);
hideElement('#fldAlbum', context);
}
2020-05-04 12:44:12 +02:00
if (item.Type === 'Episode' && item.ParentIndexNumber === 0) {
showElement('#collapsibleSpecialEpisodeInfo', context);
} else {
hideElement('#collapsibleSpecialEpisodeInfo', context);
}
2020-05-04 12:44:12 +02:00
if (item.Type === 'Person' ||
item.Type === 'Genre' ||
item.Type === 'Studio' ||
item.Type === 'MusicGenre' ||
item.Type === 'TvChannel' ||
item.Type === 'Book') {
hideElement('#peopleCollapsible', context);
} else {
showElement('#peopleCollapsible', context);
}
2020-05-04 12:44:12 +02:00
if (item.Type === 'Person' || item.Type === 'Genre' || item.Type === 'Studio' || item.Type === 'MusicGenre' || item.Type === 'TvChannel') {
hideElement('#fldCommunityRating', context);
hideElement('#genresCollapsible', context);
hideElement('#studiosCollapsible', context);
2020-05-04 12:44:12 +02:00
if (item.Type === 'TvChannel') {
showElement('#fldOfficialRating', context);
} else {
hideElement('#fldOfficialRating', context);
}
hideElement('#fldCustomRating', context);
} else {
showElement('#fldCommunityRating', context);
showElement('#genresCollapsible', context);
showElement('#studiosCollapsible', context);
showElement('#fldOfficialRating', context);
showElement('#fldCustomRating', context);
}
showElement('#tagsCollapsible', context);
2020-05-04 12:44:12 +02:00
if (item.Type === 'TvChannel') {
hideElement('#metadataSettingsCollapsible', context);
hideElement('#fldPremiereDate', context);
hideElement('#fldDateAdded', context);
hideElement('#fldYear', context);
} else {
showElement('#metadataSettingsCollapsible', context);
showElement('#fldPremiereDate', context);
showElement('#fldDateAdded', context);
showElement('#fldYear', context);
}
2020-05-04 12:44:12 +02:00
if (item.Type === 'TvChannel') {
hideElement('.overviewContainer', context);
} else {
showElement('.overviewContainer', context);
}
2020-05-04 12:44:12 +02:00
if (item.Type === 'Person') {
//todo
context.querySelector('#txtProductionYear').label(globalize.translate('LabelBirthYear'));
2020-05-04 12:44:12 +02:00
context.querySelector('#txtPremiereDate').label(globalize.translate('LabelBirthDate'));
context.querySelector('#txtEndDate').label(globalize.translate('LabelDeathDate'));
showElement('#fldPlaceOfBirth');
} else {
context.querySelector('#txtProductionYear').label(globalize.translate('LabelYear'));
2020-05-04 12:44:12 +02:00
context.querySelector('#txtPremiereDate').label(globalize.translate('LabelReleaseDate'));
context.querySelector('#txtEndDate').label(globalize.translate('LabelEndDate'));
hideElement('#fldPlaceOfBirth');
}
2020-05-04 12:44:12 +02:00
if (item.MediaType === 'Video' && item.Type !== 'TvChannel') {
showElement('#fldOriginalAspectRatio');
} else {
hideElement('#fldOriginalAspectRatio');
}
2020-05-04 12:44:12 +02:00
if (item.Type === 'Audio' || item.Type === 'Episode' || item.Type === 'Season') {
showElement('#fldIndexNumber');
2020-05-04 12:44:12 +02:00
if (item.Type === 'Episode') {
context.querySelector('#txtIndexNumber').label(globalize.translate('LabelEpisodeNumber'));
2020-05-04 12:44:12 +02:00
} else if (item.Type === 'Season') {
context.querySelector('#txtIndexNumber').label(globalize.translate('LabelSeasonNumber'));
2020-05-04 12:44:12 +02:00
} else if (item.Type === 'Audio') {
context.querySelector('#txtIndexNumber').label(globalize.translate('LabelTrackNumber'));
} else {
context.querySelector('#txtIndexNumber').label(globalize.translate('LabelNumber'));
}
} else {
hideElement('#fldIndexNumber');
}
2020-05-04 12:44:12 +02:00
if (item.Type === 'Audio' || item.Type === 'Episode') {
showElement('#fldParentIndexNumber');
2020-05-04 12:44:12 +02:00
if (item.Type === 'Episode') {
context.querySelector('#txtParentIndexNumber').label(globalize.translate('LabelSeasonNumber'));
2020-05-04 12:44:12 +02:00
} else if (item.Type === 'Audio') {
context.querySelector('#txtParentIndexNumber').label(globalize.translate('LabelDiscNumber'));
} else {
context.querySelector('#txtParentIndexNumber').label(globalize.translate('LabelParentNumber'));
}
} else {
hideElement('#fldParentIndexNumber', context);
}
2020-05-04 12:44:12 +02:00
if (item.Type === 'BoxSet') {
showElement('#fldDisplayOrder', context);
hideElement('.seriesDisplayOrderDescription', context);
context.querySelector('#selectDisplayOrder').innerHTML = '<option value="SortName">' + globalize.translate('SortName') + '</option><option value="PremiereDate">' + globalize.translate('ReleaseDate') + '</option>';
2020-05-04 12:44:12 +02:00
} else if (item.Type === 'Series') {
showElement('#fldDisplayOrder', context);
showElement('.seriesDisplayOrderDescription', context);
context.querySelector('#selectDisplayOrder').innerHTML = '<option value="">' + globalize.translate('Aired') + '</option><option value="absolute">' + globalize.translate('Absolute') + '</option><option value="dvd">Dvd</option>';
} else {
context.querySelector('#selectDisplayOrder').innerHTML = '';
hideElement('#fldDisplayOrder', context);
}
2018-10-23 01:05:09 +03:00
}
function fillItemInfo(context, item, parentalRatingOptions) {
var select = context.querySelector('#selectOfficialRating');
populateRatings(parentalRatingOptions, select, item.OfficialRating);
2020-05-04 12:44:12 +02:00
select.value = item.OfficialRating || '';
select = context.querySelector('#selectCustomRating');
populateRatings(parentalRatingOptions, select, item.CustomRating);
2020-05-04 12:44:12 +02:00
select.value = item.CustomRating || '';
var selectStatus = context.querySelector('#selectStatus');
populateStatus(selectStatus);
2020-05-04 12:44:12 +02:00
selectStatus.value = item.Status || '';
2020-05-04 12:44:12 +02:00
context.querySelector('#select3dFormat', context).value = item.Video3DFormat || '';
Array.prototype.forEach.call(context.querySelectorAll('.chkAirDay', context), function (el) {
el.checked = (item.AirDays || []).indexOf(el.getAttribute('data-day')) !== -1;
});
populateListView(context.querySelector('#listGenres'), item.Genres);
populatePeople(context, item.People || []);
populateListView(context.querySelector('#listStudios'), (item.Studios || []).map(function (element) {
return element.Name || '';
}));
populateListView(context.querySelector('#listTags'), item.Tags);
var lockData = (item.LockData || false);
2020-05-04 12:44:12 +02:00
var chkLockData = context.querySelector('#chkLockData');
chkLockData.checked = lockData;
if (chkLockData.checked) {
hideElement('.providerSettingsContainer', context);
} else {
showElement('.providerSettingsContainer', context);
}
fillMetadataSettings(context, item, item.LockedFields);
context.querySelector('#txtPath').value = item.Path || '';
2020-05-04 12:44:12 +02:00
context.querySelector('#txtName').value = item.Name || '';
context.querySelector('#txtOriginalName').value = item.OriginalTitle || '';
context.querySelector('#txtOverview').value = item.Overview || '';
context.querySelector('#txtTagline').value = (item.Taglines && item.Taglines.length ? item.Taglines[0] : '');
2020-05-04 12:44:12 +02:00
context.querySelector('#txtSortName').value = item.ForcedSortName || '';
context.querySelector('#txtCommunityRating').value = item.CommunityRating || '';
2020-05-04 12:44:12 +02:00
context.querySelector('#txtCriticRating').value = item.CriticRating || '';
context.querySelector('#txtIndexNumber').value = item.IndexNumber == null ? '' : item.IndexNumber;
context.querySelector('#txtParentIndexNumber').value = item.ParentIndexNumber == null ? '' : item.ParentIndexNumber;
2020-05-04 12:44:12 +02:00
context.querySelector('#txtAirsBeforeSeason').value = ('AirsBeforeSeasonNumber' in item) ? item.AirsBeforeSeasonNumber : '';
context.querySelector('#txtAirsAfterSeason').value = ('AirsAfterSeasonNumber' in item) ? item.AirsAfterSeasonNumber : '';
context.querySelector('#txtAirsBeforeEpisode').value = ('AirsBeforeEpisodeNumber' in item) ? item.AirsBeforeEpisodeNumber : '';
2020-05-04 12:44:12 +02:00
context.querySelector('#txtAlbum').value = item.Album || '';
context.querySelector('#txtAlbumArtist').value = (item.AlbumArtists || []).map(function (a) {
return a.Name;
}).join(';');
2020-04-14 07:00:47 +02:00
context.querySelector('#selectDisplayOrder').value = item.DisplayOrder || '';
context.querySelector('#txtArtist').value = (item.ArtistItems || []).map(function (a) {
return a.Name;
}).join(';');
2018-10-23 01:05:09 +03:00
var date;
if (item.DateCreated) {
try {
date = datetime.parseISO8601Date(item.DateCreated, true);
context.querySelector('#txtDateAdded').value = date.toISOString().slice(0, 10);
} catch (e) {
context.querySelector('#txtDateAdded').value = '';
}
} else {
context.querySelector('#txtDateAdded').value = '';
}
if (item.PremiereDate) {
try {
date = datetime.parseISO8601Date(item.PremiereDate, true);
context.querySelector('#txtPremiereDate').value = date.toISOString().slice(0, 10);
} catch (e) {
context.querySelector('#txtPremiereDate').value = '';
}
} else {
context.querySelector('#txtPremiereDate').value = '';
}
if (item.EndDate) {
try {
date = datetime.parseISO8601Date(item.EndDate, true);
context.querySelector('#txtEndDate').value = date.toISOString().slice(0, 10);
} catch (e) {
context.querySelector('#txtEndDate').value = '';
}
} else {
context.querySelector('#txtEndDate').value = '';
}
2020-05-04 12:44:12 +02:00
context.querySelector('#txtProductionYear').value = item.ProductionYear || '';
context.querySelector('#txtAirTime').value = item.AirTime || '';
var placeofBirth = item.ProductionLocations && item.ProductionLocations.length ? item.ProductionLocations[0] : '';
context.querySelector('#txtPlaceOfBirth').value = placeofBirth;
2020-05-04 12:44:12 +02:00
context.querySelector('#txtOriginalAspectRatio').value = item.AspectRatio || '';
2020-05-04 12:44:12 +02:00
context.querySelector('#selectLanguage').value = item.PreferredMetadataLanguage || '';
context.querySelector('#selectCountry').value = item.PreferredMetadataCountryCode || '';
if (item.RunTimeTicks) {
var minutes = item.RunTimeTicks / 600000000;
context.querySelector('#txtSeriesRuntime').value = Math.round(minutes);
} else {
2020-05-04 12:44:12 +02:00
context.querySelector('#txtSeriesRuntime', context).value = '';
}
2018-10-23 01:05:09 +03:00
}
function populateRatings(allParentalRatings, select, currentValue) {
2020-05-04 12:44:12 +02:00
var html = '';
2018-10-23 01:05:09 +03:00
html += "<option value=''></option>";
var ratings = [];
var i;
var length;
var rating;
var currentValueFound = false;
for (i = 0, length = allParentalRatings.length; i < length; i++) {
rating = allParentalRatings[i];
ratings.push({ Name: rating.Name, Value: rating.Name });
if (rating.Name === currentValue) {
currentValueFound = true;
}
}
if (currentValue && !currentValueFound) {
ratings.push({ Name: currentValue, Value: currentValue });
}
for (i = 0, length = ratings.length; i < length; i++) {
rating = ratings[i];
2020-05-04 12:44:12 +02:00
html += "<option value='" + rating.Value + "'>" + rating.Name + '</option>';
}
select.innerHTML = html;
2018-10-23 01:05:09 +03:00
}
function populateStatus(select) {
2020-05-04 12:44:12 +02:00
var html = '';
html += "<option value=''></option>";
2020-05-04 12:44:12 +02:00
html += "<option value='Continuing'>" + globalize.translate('Continuing') + '</option>';
html += "<option value='Ended'>" + globalize.translate('Ended') + '</option>';
select.innerHTML = html;
2018-10-23 01:05:09 +03:00
}
function populateListView(list, items, sortCallback) {
items = items || [];
if (typeof (sortCallback) === 'undefined') {
items.sort(function (a, b) {
return a.toLowerCase().localeCompare(b.toLowerCase());
});
} else {
items = sortCallback(items);
}
var html = '';
for (var i = 0; i < items.length; i++) {
html += '<div class="listItem">';
2020-04-26 02:37:28 +03:00
html += '<span class="material-icons listItemIcon live_tv" style="background-color:#333;"></span>';
html += '<div class="listItemBody">';
html += '<div class="textValue">';
html += items[i];
html += '</div>';
html += '</div>';
2020-04-26 02:37:28 +03:00
html += '<button type="button" is="paper-icon-button-light" data-index="' + i + '" class="btnRemoveFromEditorList autoSize"><span class="material-icons delete"></span></button>';
html += '</div>';
}
list.innerHTML = html;
2018-10-23 01:05:09 +03:00
}
function populatePeople(context, people) {
var lastType = '';
var html = '';
var elem = context.querySelector('#peopleList');
for (var i = 0, length = people.length; i < length; i++) {
2018-10-23 01:05:09 +03:00
var person = people[i];
html += '<div class="listItem">';
2020-04-26 02:37:28 +03:00
html += '<span class="material-icons listItemIcon person" style="background-color:#333;"></span>';
html += '<div class="listItemBody">';
html += '<button style="text-align:left;" type="button" class="btnEditPerson clearButton" data-index="' + i + '">';
html += '<div class="textValue">';
html += (person.Name || '');
html += '</div>';
if (person.Role && person.Role !== lastType) {
html += '<div class="secondary">' + (person.Role) + '</div>';
}
html += '</button>';
html += '</div>';
2020-04-26 02:37:28 +03:00
html += '<button type="button" is="paper-icon-button-light" data-index="' + i + '" class="btnDeletePerson autoSize"><span class="material-icons delete"></span></button>';
html += '</div>';
2018-10-23 01:05:09 +03:00
}
elem.innerHTML = html;
2018-10-23 01:05:09 +03:00
}
function getLockedFieldsHtml(fields, currentFields) {
var html = '';
for (var i = 0; i < fields.length; i++) {
var field = fields[i];
var name = field.name;
var value = field.value || field.name;
var checkedHtml = currentFields.indexOf(value) === -1 ? ' checked' : '';
html += '<label>';
html += '<input type="checkbox" is="emby-checkbox" class="selectLockedField" data-value="' + value + '"' + checkedHtml + '/>';
html += '<span>' + name + '</span>';
html += '</label>';
2018-10-23 01:05:09 +03:00
}
return html;
2018-10-23 01:05:09 +03:00
}
function fillMetadataSettings(context, item, lockedFields) {
var container = context.querySelector('.providerSettingsContainer');
2018-10-23 01:05:09 +03:00
lockedFields = lockedFields || [];
var lockedFieldsList = [
2020-05-04 12:44:12 +02:00
{ name: globalize.translate('Name'), value: 'Name' },
{ name: globalize.translate('Overview'), value: 'Overview' },
{ name: globalize.translate('Genres'), value: 'Genres' },
{ name: globalize.translate('ParentalRating'), value: 'OfficialRating' },
{ name: globalize.translate('People'), value: 'Cast' }
];
2020-05-04 12:44:12 +02:00
if (item.Type === 'Person') {
lockedFieldsList.push({ name: globalize.translate('BirthLocation'), value: 'ProductionLocations' });
} else {
2020-05-04 12:44:12 +02:00
lockedFieldsList.push({ name: globalize.translate('ProductionLocations'), value: 'ProductionLocations' });
}
2020-05-04 12:44:12 +02:00
if (item.Type === 'Series') {
lockedFieldsList.push({ name: globalize.translate('Runtime'), value: 'Runtime' });
}
2020-05-04 12:44:12 +02:00
lockedFieldsList.push({ name: globalize.translate('Studios'), value: 'Studios' });
lockedFieldsList.push({ name: globalize.translate('Tags'), value: 'Tags' });
var html = '';
2020-05-04 12:44:12 +02:00
html += '<h2>' + globalize.translate('HeaderEnabledFields') + '</h2>';
html += '<p>' + globalize.translate('HeaderEnabledFieldsHelp') + '</p>';
html += getLockedFieldsHtml(lockedFieldsList, lockedFields);
container.innerHTML = html;
2018-10-23 01:05:09 +03:00
}
function reload(context, itemId, serverId) {
loading.show();
Promise.all([getItem(itemId, serverId), getEditorConfig(itemId, serverId)]).then(function (responses) {
2018-10-23 01:05:09 +03:00
var item = responses[0];
metadataEditorInfo = responses[1];
currentItem = item;
var languages = metadataEditorInfo.Cultures;
var countries = metadataEditorInfo.Countries;
renderContentTypeOptions(context, metadataEditorInfo);
loadExternalIds(context, item, metadataEditorInfo.ExternalIdInfos);
populateLanguages(context.querySelector('#selectLanguage'), languages);
populateCountries(context.querySelector('#selectCountry'), countries);
setFieldVisibilities(context, item);
fillItemInfo(context, item, metadataEditorInfo.ParentalRatingOptions);
2020-05-04 12:44:12 +02:00
if (item.MediaType === 'Video' && item.Type !== 'Episode' && item.Type !== 'TvChannel') {
showElement('#fldTagline', context);
} else {
hideElement('#fldTagline', context);
}
loading.hide();
});
2018-10-23 01:05:09 +03:00
}
function centerFocus(elem, horiz, on) {
require(['scrollHelper'], function (scrollHelper) {
var fn = on ? 'on' : 'off';
scrollHelper.centerFocus[fn](elem, horiz);
});
2018-10-23 01:05:09 +03:00
}
function show(itemId, serverId, resolve, reject) {
loading.show();
require(['text!./metadataEditor.template.html'], function (template) {
2018-10-23 01:05:09 +03:00
var dialogOptions = {
removeOnClose: true,
scrollY: false
2018-10-23 01:05:09 +03:00
};
if (layoutManager.tv) {
dialogOptions.size = 'fullscreen';
} else {
2020-05-11 21:43:41 +02:00
dialogOptions.size = 'small';
}
2018-10-23 01:05:09 +03:00
var dlg = dialogHelper.createDialog(dialogOptions);
dlg.classList.add('formDialog');
var html = '';
2019-02-08 07:50:23 +01:00
html += globalize.translateDocument(template, 'core');
dlg.innerHTML = html;
if (layoutManager.tv) {
centerFocus(dlg.querySelector('.formDialogContent'), false, true);
}
dialogHelper.open(dlg);
dlg.addEventListener('close', function () {
if (layoutManager.tv) {
centerFocus(dlg.querySelector('.formDialogContent'), false, false);
}
resolve();
});
currentContext = dlg;
init(dlg, connectionManager.getApiClient(serverId));
reload(dlg, itemId, serverId);
});
}
2018-10-23 01:05:09 +03:00
return {
show: function (itemId, serverId) {
return new Promise(function (resolve, reject) {
return show(itemId, serverId, resolve, reject);
});
2018-10-23 01:05:09 +03:00
},
embed: function (elem, itemId, serverId) {
return new Promise(function (resolve, reject) {
loading.show();
require(['text!./metadataEditor.template.html'], function (template) {
2019-02-08 07:50:23 +01:00
elem.innerHTML = globalize.translateDocument(template, 'core');
elem.querySelector('.formDialogFooter').classList.remove('formDialogFooter');
elem.querySelector('.btnHeaderSave').classList.remove('hide');
elem.querySelector('.btnCancel').classList.add('hide');
currentContext = elem;
init(elem, connectionManager.getApiClient(serverId));
reload(elem, itemId, serverId);
focusManager.autoFocus(elem);
});
});
2018-10-23 01:05:09 +03:00
}
};
2019-01-27 22:10:07 +01:00
});