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/itemMediaInfo/itemMediaInfo.js

165 lines
8 KiB
JavaScript
Raw Normal View History

2020-05-04 12:44:12 +02:00
define(['dialogHelper', 'require', 'layoutManager', 'globalize', 'userSettings', 'connectionManager', 'loading', 'focusManager', 'dom', 'apphost', 'emby-select', 'listViewStyle', 'paper-icon-button-light', 'css!./../formdialog', 'material-icons', 'emby-button', 'flexStyles'], function (dialogHelper, require, layoutManager, globalize, userSettings, connectionManager, loading, focusManager, dom, appHost) {
'use strict';
function setMediaInfo(user, page, item) {
var html = item.MediaSources.map(function (version) {
return getMediaSourceHtml(user, item, version);
}).join('<div style="border-top:1px solid #444;margin: 1em 0;"></div>');
if (item.MediaSources.length > 1) {
2020-05-04 12:44:12 +02:00
html = '<br/>' + html;
}
2020-05-04 12:44:12 +02:00
var mediaInfoContent = page.querySelector('#mediaInfoContent');
mediaInfoContent.innerHTML = html;
}
function getMediaSourceHtml(user, item, version) {
2020-05-04 12:44:12 +02:00
var html = '';
if (version.Name) {
2020-05-04 12:44:12 +02:00
html += '<div><h2 class="mediaInfoStreamType">' + version.Name + '</h2></div>';
}
if (version.Container) {
2020-05-04 12:44:12 +02:00
html += createAttribute(globalize.translate('MediaInfoContainer'), version.Container) + '<br/>';
}
if (version.Formats && version.Formats.length) {
2020-05-04 12:44:12 +02:00
html += createAttribute(globalize.translate('MediaInfoFormat'), version.Formats.join(',')) + '<br/>';
}
if (version.Path && user && user.Policy.IsAdministrator) {
2020-05-04 12:44:12 +02:00
html += createAttribute(globalize.translate('MediaInfoPath'), version.Path) + '<br/>';
}
2019-09-04 21:53:31 +03:00
if (version.Size) {
2020-05-04 12:44:12 +02:00
var size = (version.Size / (1024 * 1024)).toFixed(0) + ' MB';
html += createAttribute(globalize.translate('MediaInfoSize'), size) + '<br/>';
}
for (var i = 0, length = version.MediaStreams.length; i < length; i++) {
var stream = version.MediaStreams[i];
2020-05-04 12:44:12 +02:00
if (stream.Type === 'Data') {
continue;
}
html += '<div class="mediaInfoStream">';
2020-05-04 12:44:12 +02:00
var displayType = globalize.translate('MediaInfoStreamType' + stream.Type);
html += '<h2 class="mediaInfoStreamType">' + displayType + '</h2>';
var attributes = [];
if (stream.DisplayTitle) {
2020-05-04 12:44:12 +02:00
attributes.push(createAttribute('Title', stream.DisplayTitle));
}
2020-05-04 12:44:12 +02:00
if (stream.Language && stream.Type !== 'Video') {
attributes.push(createAttribute(globalize.translate('MediaInfoLanguage'), stream.Language));
}
if (stream.Codec) {
2020-05-04 12:44:12 +02:00
attributes.push(createAttribute(globalize.translate('MediaInfoCodec'), stream.Codec.toUpperCase()));
}
if (stream.CodecTag) {
2020-05-04 12:44:12 +02:00
attributes.push(createAttribute(globalize.translate('MediaInfoCodecTag'), stream.CodecTag));
}
if (stream.IsAVC != null) {
2020-05-04 12:44:12 +02:00
attributes.push(createAttribute('AVC', (stream.IsAVC ? 'Yes' : 'No')));
}
if (stream.Profile) {
2020-05-04 12:44:12 +02:00
attributes.push(createAttribute(globalize.translate('MediaInfoProfile'), stream.Profile));
}
if (stream.Level) {
2020-05-04 12:44:12 +02:00
attributes.push(createAttribute(globalize.translate('MediaInfoLevel'), stream.Level));
}
if (stream.Width || stream.Height) {
2020-05-04 12:44:12 +02:00
attributes.push(createAttribute(globalize.translate('MediaInfoResolution'), stream.Width + 'x' + stream.Height));
}
2020-05-04 12:44:12 +02:00
if (stream.AspectRatio && stream.Codec !== 'mjpeg') {
attributes.push(createAttribute(globalize.translate('MediaInfoAspectRatio'), stream.AspectRatio));
}
2020-05-04 12:44:12 +02:00
if (stream.Type === 'Video') {
if (stream.IsAnamorphic != null) {
2020-05-04 12:44:12 +02:00
attributes.push(createAttribute(globalize.translate('MediaInfoAnamorphic'), (stream.IsAnamorphic ? 'Yes' : 'No')));
}
2020-05-04 12:44:12 +02:00
attributes.push(createAttribute(globalize.translate('MediaInfoInterlaced'), (stream.IsInterlaced ? 'Yes' : 'No')));
}
if (stream.AverageFrameRate || stream.RealFrameRate) {
2020-05-04 12:44:12 +02:00
attributes.push(createAttribute(globalize.translate('MediaInfoFramerate'), (stream.AverageFrameRate || stream.RealFrameRate)));
}
if (stream.ChannelLayout) {
2020-05-04 12:44:12 +02:00
attributes.push(createAttribute(globalize.translate('MediaInfoLayout'), stream.ChannelLayout));
}
if (stream.Channels) {
2020-05-04 12:44:12 +02:00
attributes.push(createAttribute(globalize.translate('MediaInfoChannels'), stream.Channels + ' ch'));
}
2020-05-04 12:44:12 +02:00
if (stream.BitRate && stream.Codec !== 'mjpeg') {
attributes.push(createAttribute(globalize.translate('MediaInfoBitrate'), (parseInt(stream.BitRate / 1000)) + ' kbps'));
}
if (stream.SampleRate) {
2020-05-04 12:44:12 +02:00
attributes.push(createAttribute(globalize.translate('MediaInfoSampleRate'), stream.SampleRate + ' Hz'));
}
if (stream.BitDepth) {
2020-05-04 12:44:12 +02:00
attributes.push(createAttribute(globalize.translate('MediaInfoBitDepth'), stream.BitDepth + ' bit'));
}
if (stream.PixelFormat) {
2020-05-04 12:44:12 +02:00
attributes.push(createAttribute(globalize.translate('MediaInfoPixelFormat'), stream.PixelFormat));
}
if (stream.RefFrames) {
2020-05-04 12:44:12 +02:00
attributes.push(createAttribute(globalize.translate('MediaInfoRefFrames'), stream.RefFrames));
}
if (stream.NalLengthSize) {
2020-05-04 12:44:12 +02:00
attributes.push(createAttribute('NAL', stream.NalLengthSize));
}
2020-05-04 12:44:12 +02:00
if (stream.Type !== 'Video') {
attributes.push(createAttribute(globalize.translate('MediaInfoDefault'), (stream.IsDefault ? 'Yes' : 'No')));
}
2020-05-04 12:44:12 +02:00
if (stream.Type === 'Subtitle') {
attributes.push(createAttribute(globalize.translate('MediaInfoForced'), (stream.IsForced ? 'Yes' : 'No')));
attributes.push(createAttribute(globalize.translate('MediaInfoExternal'), (stream.IsExternal ? 'Yes' : 'No')));
}
2020-05-04 12:44:12 +02:00
if (stream.Type === 'Video' && version.Timestamp) {
attributes.push(createAttribute(globalize.translate('MediaInfoTimestamp'), version.Timestamp));
}
2020-05-04 12:44:12 +02:00
html += attributes.join('<br/>');
html += '</div>';
}
return html;
}
function createAttribute(label, value) {
2020-05-04 12:44:12 +02:00
return '<span class="mediaInfoLabel">' + label + '</span><span class="mediaInfoAttribute">' + value + '</span>';
}
function showMediaInfoMore(itemId, serverId, template) {
var apiClient = connectionManager.getApiClient(serverId);
return apiClient.getItem(apiClient.getCurrentUserId(), itemId).then(function (item) {
var dialogOptions = {
2020-05-04 12:44:12 +02:00
size: 'small',
removeOnClose: true,
scrollY: false
};
if (layoutManager.tv) {
2020-05-04 12:44:12 +02:00
dialogOptions.size = 'fullscreen';
}
var dlg = dialogHelper.createDialog(dialogOptions);
2020-05-04 12:44:12 +02:00
dlg.classList.add('formDialog');
var html = '';
html += globalize.translateDocument(template, 'core');
dlg.innerHTML = html;
if (layoutManager.tv) {
2020-05-04 12:44:12 +02:00
dlg.querySelector('.formDialogContent');
}
dialogHelper.open(dlg);
2020-05-04 12:44:12 +02:00
dlg.querySelector('.btnCancel').addEventListener('click', function (e) {
dialogHelper.close(dlg);
});
apiClient.getCurrentUser().then(function (user) {
setMediaInfo(user, dlg, item);
});
loading.hide();
});
}
function showMediaInfo(itemId, serverId) {
loading.show();
return new Promise(function (resolve, reject) {
2020-05-04 12:44:12 +02:00
require(['text!./itemMediaInfo.template.html'], function (template) {
showMediaInfoMore(itemId, serverId, template).then(resolve, reject);
});
});
}
return {
show: showMediaInfo
};
});