mirror of
https://github.com/jellyfin/jellyfin-web
synced 2025-03-30 19:56:21 +00:00
Add non-standard multi-value audio tag support
This commit is contained in:
parent
d770e40130
commit
524ede412b
3 changed files with 41 additions and 0 deletions
|
@ -12,6 +12,7 @@ import dom from '../../scripts/dom';
|
||||||
import '../../elements/emby-checkbox/emby-checkbox';
|
import '../../elements/emby-checkbox/emby-checkbox';
|
||||||
import '../../elements/emby-select/emby-select';
|
import '../../elements/emby-select/emby-select';
|
||||||
import '../../elements/emby-input/emby-input';
|
import '../../elements/emby-input/emby-input';
|
||||||
|
import '../../elements/emby-textarea/emby-textarea';
|
||||||
import './style.scss';
|
import './style.scss';
|
||||||
import template from './libraryoptionseditor.template.html';
|
import template from './libraryoptionseditor.template.html';
|
||||||
|
|
||||||
|
@ -439,8 +440,10 @@ export function setContentType(parent, contentType) {
|
||||||
|
|
||||||
if (contentType === 'music') {
|
if (contentType === 'music') {
|
||||||
parent.querySelector('.lyricSettingsSection').classList.remove('hide');
|
parent.querySelector('.lyricSettingsSection').classList.remove('hide');
|
||||||
|
parent.querySelector('.audioTagSettingsSection').classList.remove('hide');
|
||||||
} else {
|
} else {
|
||||||
parent.querySelector('.lyricSettingsSection').classList.add('hide');
|
parent.querySelector('.lyricSettingsSection').classList.add('hide');
|
||||||
|
parent.querySelector('.audioTagSettingsSection').classList.add('hide');
|
||||||
}
|
}
|
||||||
|
|
||||||
parent.querySelector('.chkAutomaticallyAddToCollectionContainer').classList.toggle('hide', contentType !== 'movies' && contentType !== 'mixed');
|
parent.querySelector('.chkAutomaticallyAddToCollectionContainer').classList.toggle('hide', contentType !== 'movies' && contentType !== 'mixed');
|
||||||
|
@ -550,6 +553,8 @@ export function getLibraryOptions(parent) {
|
||||||
SaveLyricsWithMedia: parent.querySelector('#chkSaveLyricsLocally').checked,
|
SaveLyricsWithMedia: parent.querySelector('#chkSaveLyricsLocally').checked,
|
||||||
RequirePerfectSubtitleMatch: parent.querySelector('#chkRequirePerfectMatch').checked,
|
RequirePerfectSubtitleMatch: parent.querySelector('#chkRequirePerfectMatch').checked,
|
||||||
AutomaticallyAddToCollection: parent.querySelector('#chkAutomaticallyAddToCollection').checked,
|
AutomaticallyAddToCollection: parent.querySelector('#chkAutomaticallyAddToCollection').checked,
|
||||||
|
PreferNonstandardArtistsTag: parent.querySelector('#chkPreferNonstandardArtistsTag').checked,
|
||||||
|
UseCustomTagDelimiters: parent.querySelector('#chkUseCustomTagDelimiters').checked,
|
||||||
MetadataSavers: Array.prototype.map.call(Array.prototype.filter.call(parent.querySelectorAll('.chkMetadataSaver'), elem => {
|
MetadataSavers: Array.prototype.map.call(Array.prototype.filter.call(parent.querySelectorAll('.chkMetadataSaver'), elem => {
|
||||||
return elem.checked;
|
return elem.checked;
|
||||||
}), elem => {
|
}), elem => {
|
||||||
|
@ -566,6 +571,8 @@ export function getLibraryOptions(parent) {
|
||||||
}), elem => {
|
}), elem => {
|
||||||
return elem.getAttribute('data-lang');
|
return elem.getAttribute('data-lang');
|
||||||
});
|
});
|
||||||
|
options.CustomTagDelimiters = parent.querySelector('#customTagDelimitersInput').value.split('');
|
||||||
|
options.DelimiterWhitelist = parent.querySelector('#tagDelimiterWhitelist').value.split('\n');
|
||||||
setSubtitleFetchersIntoOptions(parent, options);
|
setSubtitleFetchersIntoOptions(parent, options);
|
||||||
setMetadataFetchersIntoOptions(parent, options);
|
setMetadataFetchersIntoOptions(parent, options);
|
||||||
setImageFetchersIntoOptions(parent, options);
|
setImageFetchersIntoOptions(parent, options);
|
||||||
|
@ -612,12 +619,16 @@ export function setLibraryOptions(parent, options) {
|
||||||
parent.querySelector('#chkSkipIfAudioTrackPresent').checked = options.SkipSubtitlesIfAudioTrackMatches;
|
parent.querySelector('#chkSkipIfAudioTrackPresent').checked = options.SkipSubtitlesIfAudioTrackMatches;
|
||||||
parent.querySelector('#chkRequirePerfectMatch').checked = options.RequirePerfectSubtitleMatch;
|
parent.querySelector('#chkRequirePerfectMatch').checked = options.RequirePerfectSubtitleMatch;
|
||||||
parent.querySelector('#chkAutomaticallyAddToCollection').checked = options.AutomaticallyAddToCollection;
|
parent.querySelector('#chkAutomaticallyAddToCollection').checked = options.AutomaticallyAddToCollection;
|
||||||
|
parent.querySelector('#chkPreferNonstandardArtistsTag').checked = options.PreferNonstandardArtistsTag;
|
||||||
|
parent.querySelector('#chkUseCustomTagDelimiters').checked = options.UseCustomTagDelimiters;
|
||||||
Array.prototype.forEach.call(parent.querySelectorAll('.chkMetadataSaver'), elem => {
|
Array.prototype.forEach.call(parent.querySelectorAll('.chkMetadataSaver'), elem => {
|
||||||
elem.checked = options.MetadataSavers ? options.MetadataSavers.includes(elem.getAttribute('data-pluginname')) : elem.getAttribute('data-defaultenabled') === 'true';
|
elem.checked = options.MetadataSavers ? options.MetadataSavers.includes(elem.getAttribute('data-pluginname')) : elem.getAttribute('data-defaultenabled') === 'true';
|
||||||
});
|
});
|
||||||
Array.prototype.forEach.call(parent.querySelectorAll('.chkSubtitleLanguage'), elem => {
|
Array.prototype.forEach.call(parent.querySelectorAll('.chkSubtitleLanguage'), elem => {
|
||||||
elem.checked = !!options.SubtitleDownloadLanguages && options.SubtitleDownloadLanguages.includes(elem.getAttribute('data-lang'));
|
elem.checked = !!options.SubtitleDownloadLanguages && options.SubtitleDownloadLanguages.includes(elem.getAttribute('data-lang'));
|
||||||
});
|
});
|
||||||
|
parent.querySelector('#customTagDelimitersInput').value = options.CustomTagDelimiters.join('');
|
||||||
|
parent.querySelector('#tagDelimiterWhitelist').value = options.DelimiterWhitelist.join('\n').filter(item => item.trim());
|
||||||
renderMetadataReaders(parent, getOrderedPlugins(parent.availableOptions.MetadataReaders, options.LocalMetadataReaderOrder || []));
|
renderMetadataReaders(parent, getOrderedPlugins(parent.availableOptions.MetadataReaders, options.LocalMetadataReaderOrder || []));
|
||||||
renderMetadataFetchers(parent, parent.availableOptions, options);
|
renderMetadataFetchers(parent, parent.availableOptions, options);
|
||||||
renderImageFetchers(parent, parent.availableOptions, options);
|
renderImageFetchers(parent, parent.availableOptions, options);
|
||||||
|
|
|
@ -205,3 +205,29 @@
|
||||||
<div class="fieldDescription checkboxFieldDescription">${SaveLyricsIntoMediaFoldersHelp}</div>
|
<div class="fieldDescription checkboxFieldDescription">${SaveLyricsIntoMediaFoldersHelp}</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
<div class="audioTagSettingsSection hide">
|
||||||
|
<h2>Audio Tag settings</h2>
|
||||||
|
<div class="checkboxContainer checkboxContainer-withDescription advanced">
|
||||||
|
<label>
|
||||||
|
<input type="checkbox" is="emby-checkbox" id="chkPreferNonstandardArtistsTag" />
|
||||||
|
<span>Prefer ARTISTS tag if available</span>
|
||||||
|
</label>
|
||||||
|
<div class="fieldDescription checkboxFieldDescription">${PreferNonstandardArtistsTagHelp}</div>
|
||||||
|
</div>
|
||||||
|
<div class="checkboxContainer checkboxContainer-withDescription advanced">
|
||||||
|
<label>
|
||||||
|
<input type="checkbox" is="emby-checkbox" id="chkUseCustomTagDelimiters" />
|
||||||
|
<span>Use custom tag splitter</span>
|
||||||
|
</label>
|
||||||
|
<div class="fieldDescription checkboxFieldDescription">${UseCustomTagDelimitersHelp}</div>
|
||||||
|
</div>
|
||||||
|
<div class="inputContainer">
|
||||||
|
<input type="text" is="emby-input" id="customTagDelimitersInput" label="Custom Tag Delimiter" value="/|;\"/>
|
||||||
|
<div class="fieldDescription">${LabelcustomTagDelimitersHelp}</div>
|
||||||
|
</div>
|
||||||
|
<div class="inputContainer">
|
||||||
|
<textarea is="emby-textarea" id="tagDelimiterWhitelist" label="Delimiter Whitelist" class="textarea-mono" style="resize: none;min-height:2.5em"></textarea>
|
||||||
|
<div class="fieldDescription">${LabelDelimiterWhitelistHelp}</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
|
@ -615,6 +615,7 @@
|
||||||
"LabelCustomCssHelp": "Apply your custom CSS code for theming/branding on the web interface.",
|
"LabelCustomCssHelp": "Apply your custom CSS code for theming/branding on the web interface.",
|
||||||
"LabelCustomDeviceDisplayNameHelp": "Supply a custom display name or leave empty to use the name reported by the device.",
|
"LabelCustomDeviceDisplayNameHelp": "Supply a custom display name or leave empty to use the name reported by the device.",
|
||||||
"LabelCustomRating": "Custom rating",
|
"LabelCustomRating": "Custom rating",
|
||||||
|
"LabelcustomTagDelimitersHelp": "Characters to be treated as delimiters to separate tags.",
|
||||||
"LabelDashboardTheme": "Server Dashboard theme",
|
"LabelDashboardTheme": "Server Dashboard theme",
|
||||||
"LabelDate": "Date",
|
"LabelDate": "Date",
|
||||||
"LabelDateAdded": "Date added",
|
"LabelDateAdded": "Date added",
|
||||||
|
@ -625,6 +626,7 @@
|
||||||
"LabelDeathDate": "Death date",
|
"LabelDeathDate": "Death date",
|
||||||
"LabelDefaultScreen": "Default screen",
|
"LabelDefaultScreen": "Default screen",
|
||||||
"LabelDeinterlaceMethod": "Deinterlacing method",
|
"LabelDeinterlaceMethod": "Deinterlacing method",
|
||||||
|
"LabelDelimiterWhitelistHelp": "Items to be excluded from tag splitting. One item per line.",
|
||||||
"LabelDeveloper": "Developer",
|
"LabelDeveloper": "Developer",
|
||||||
"LabelDisableCustomCss": "Disable custom CSS code for theming/branding provided from the server.",
|
"LabelDisableCustomCss": "Disable custom CSS code for theming/branding provided from the server.",
|
||||||
"LabelDiscNumber": "Disc number",
|
"LabelDiscNumber": "Disc number",
|
||||||
|
@ -1301,6 +1303,7 @@
|
||||||
"PreferEmbeddedExtrasTitlesOverFileNamesHelp": "Extras often have the same embedded name as the parent, check this to use embedded titles for them anyway.",
|
"PreferEmbeddedExtrasTitlesOverFileNamesHelp": "Extras often have the same embedded name as the parent, check this to use embedded titles for them anyway.",
|
||||||
"PreferEmbeddedTitlesOverFileNames": "Prefer embedded titles over filenames",
|
"PreferEmbeddedTitlesOverFileNames": "Prefer embedded titles over filenames",
|
||||||
"PreferEmbeddedTitlesOverFileNamesHelp": "Determine the display title to use when no internet metadata or local metadata is available.",
|
"PreferEmbeddedTitlesOverFileNamesHelp": "Determine the display title to use when no internet metadata or local metadata is available.",
|
||||||
|
"PreferNonstandardArtistsTagHelp": "Use the non-standard ARTISTS tag instead of ARTIST tag when available.",
|
||||||
"AllowEmbeddedSubtitles": "Disable different types of embedded subtitles",
|
"AllowEmbeddedSubtitles": "Disable different types of embedded subtitles",
|
||||||
"AllowEmbeddedSubtitlesHelp": "Disable subtitles that are packaged within media containers. Requires a full library refresh.",
|
"AllowEmbeddedSubtitlesHelp": "Disable subtitles that are packaged within media containers. Requires a full library refresh.",
|
||||||
"AllowEmbeddedSubtitlesAllowAllOption": "Allow All",
|
"AllowEmbeddedSubtitlesAllowAllOption": "Allow All",
|
||||||
|
@ -1529,6 +1532,7 @@
|
||||||
"UnsupportedPlayback": "Jellyfin cannot decrypt content protected by DRM but all content will be tried regardless, including protected titles. Some files may appear completely black due to encryption or other unsupported features, such as interactive titles.",
|
"UnsupportedPlayback": "Jellyfin cannot decrypt content protected by DRM but all content will be tried regardless, including protected titles. Some files may appear completely black due to encryption or other unsupported features, such as interactive titles.",
|
||||||
"Up": "Up",
|
"Up": "Up",
|
||||||
"Upload": "Upload",
|
"Upload": "Upload",
|
||||||
|
"UseCustomTagDelimitersHelp": "Split artist/genre tags with custom characters.",
|
||||||
"UseDoubleRateDeinterlacing": "Double the frame rate when deinterlacing",
|
"UseDoubleRateDeinterlacing": "Double the frame rate when deinterlacing",
|
||||||
"UseDoubleRateDeinterlacingHelp": "This setting uses the field rate when deinterlacing, often referred to as bob deinterlacing, which doubles the frame rate of the video to provide full motion like what you would see when viewing interlaced video on a TV.",
|
"UseDoubleRateDeinterlacingHelp": "This setting uses the field rate when deinterlacing, often referred to as bob deinterlacing, which doubles the frame rate of the video to provide full motion like what you would see when viewing interlaced video on a TV.",
|
||||||
"UseEpisodeImagesInNextUp": "Use episode images in 'Next Up' and 'Continue Watching' sections",
|
"UseEpisodeImagesInNextUp": "Use episode images in 'Next Up' and 'Continue Watching' sections",
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue