mirror of
https://github.com/murdos/musicbrainz-userscripts
synced 2024-12-13 03:42:27 +00:00
Merge remote-tracking branch 'upstream/master'
This commit is contained in:
commit
3fe4a35fab
4 changed files with 54 additions and 44 deletions
|
@ -5,7 +5,7 @@ var meta = function() {
|
|||
// @name Import DG/Decca releases to MusicBrainz
|
||||
// @namespace https://github.com/murdos/musicbrainz-userscripts
|
||||
// @author loujine
|
||||
// @version 2016.10.28.0
|
||||
// @version 2016.11.13.1
|
||||
// @downloadURL https://raw.githubusercontent.com/murdos/musicbrainz-userscripts/master/dgdecca_importer.user.js
|
||||
// @updateURL https://raw.githubusercontent.com/murdos/musicbrainz-userscripts/master/dgdecca_importer.user.js
|
||||
// @icon https://raw.githubusercontent.com/murdos/musicbrainz-userscripts/master/assets/images/Musicbrainz_import_logo.png
|
||||
|
@ -127,7 +127,7 @@ function extract_release_data() {
|
|||
var nodes = [];
|
||||
var tracklist_node = document.getElementById('tracklist');
|
||||
|
||||
$('.item,.hier0,.hier1,.hier2').each(function (idx, node) {
|
||||
$('.item,.hier0,.hier1,.hier2,.hier3').each(function (idx, node) {
|
||||
var idx;
|
||||
var d = {};
|
||||
if (node.classList.contains('hier0')) {
|
||||
|
@ -136,6 +136,8 @@ function extract_release_data() {
|
|||
d['level'] = 1;
|
||||
} else if (node.classList.contains('hier2')) {
|
||||
d['level'] = 2;
|
||||
} else if (node.classList.contains('hier3')) {
|
||||
d['level'] = 3;
|
||||
}
|
||||
if (node.parentElement.classList.contains('track-container')) {
|
||||
d['type'] = 'track';
|
||||
|
@ -153,7 +155,7 @@ function extract_release_data() {
|
|||
console.log(nodes, tracklist_node);
|
||||
|
||||
// complete track titles
|
||||
var header0, header1, idx;
|
||||
var header0, header1, header2, idx;
|
||||
nodes.forEach(function (node, idx) {
|
||||
var level = node['level'],
|
||||
type = node['type'],
|
||||
|
@ -163,6 +165,8 @@ function extract_release_data() {
|
|||
header0 = content;
|
||||
} else if (level === 1) {
|
||||
header1 = content;
|
||||
} else if (level === 2) {
|
||||
header2 = content;
|
||||
}
|
||||
} else if (type === 'track') {
|
||||
if (level === 0) {
|
||||
|
@ -171,6 +175,8 @@ function extract_release_data() {
|
|||
nodes[idx]['title'] = header0 + ': ' + content;
|
||||
} else if (level === 2) {
|
||||
nodes[idx]['title'] = header0 + ', ' + header1 + ': ' + content;
|
||||
} else if (level === 3) {
|
||||
nodes[idx]['title'] = header0 + ', ' + header1 + ', ' + header2 + ': ' + content;
|
||||
}
|
||||
}
|
||||
});
|
||||
|
@ -211,7 +217,7 @@ function extract_release_data() {
|
|||
'language': 'eng', // 'English',
|
||||
'script': 'Latn', // 'Latin',
|
||||
'packaging': '',
|
||||
'country': 'XW',
|
||||
'country': '',
|
||||
'year': date[2],
|
||||
'month': months[date[1]],
|
||||
'day': date[0],
|
||||
|
|
|
@ -2,7 +2,7 @@
|
|||
|
||||
// @name Import Discogs releases to MusicBrainz
|
||||
// @description Add a button to import Discogs releases to MusicBrainz and add links to matching MusicBrainz entities for various Discogs entities (artist,release,master,label)
|
||||
// @version 2016.11.09.0
|
||||
// @version 2016.12.17.0
|
||||
// @namespace http://userscripts.org/users/22504
|
||||
// @downloadURL https://raw.githubusercontent.com/murdos/musicbrainz-userscripts/master/discogs_importer.user.js
|
||||
// @updateURL https://raw.githubusercontent.com/murdos/musicbrainz-userscripts/master/discogs_importer.user.js
|
||||
|
@ -531,8 +531,10 @@ function parseDiscogsRelease(data) {
|
|||
if (discogsRelease.formats[i].descriptions) {
|
||||
$.each(discogsRelease.formats[i].descriptions, function(index, desc) {
|
||||
if (!(discogs_format in ['Box Set'])) {
|
||||
// Release format: special handling of vinyl 7", 10" and 12" and other more specific CD/DVD formats
|
||||
if (desc.match(/7"|10"|12"|^VCD|SVCD|CD\+G|HDCD|DVD-Audio|DVD-Video/) && (desc in MediaTypes)) mb_format = MediaTypes[desc];
|
||||
// Release format: special handling of Vinyl and Shellac 7", 10" and 12"
|
||||
if (desc.match(/7"|10"|12"/) && (discogs_format.concat(desc) in MediaTypes)) mb_format = MediaTypes[discogs_format.concat(desc)];
|
||||
// Release format: special handling of specific CD/DVD formats
|
||||
if (desc.match(/^VCD|SVCD|CD\+G|HDCD|DVD-Audio|DVD-Video/) && (desc in MediaTypes)) mb_format = MediaTypes[desc];
|
||||
}
|
||||
// Release format: special handling of Vinyl, LP == 12" (http://www.discogs.com/help/submission-guidelines-release-format.html#LP)
|
||||
if (discogs_format == "Vinyl" && desc == "LP") mb_format = '12" Vinyl';
|
||||
|
@ -784,16 +786,19 @@ var MediaTypes = {
|
|||
"MVD": "Other",
|
||||
"Reel-To-Reel": "Reel-to-reel",
|
||||
"SelectaVision": "Other",
|
||||
"Shellac": "Vinyl",
|
||||
"Shellac": "Shellac",
|
||||
'Shellac7"': '7" Shellac',
|
||||
'Shellac10"': '10" Shellac',
|
||||
'Shellac12"': '12" Shellac',
|
||||
"SVCD": "SVCD",
|
||||
"UMD": "UMD",
|
||||
"VCD": "VCD",
|
||||
"VHS": "VHS",
|
||||
"Video 2000": "Other",
|
||||
"Vinyl": "Vinyl",
|
||||
'7"': '7" Vinyl',
|
||||
'10"': '10" Vinyl',
|
||||
'12"': '12" Vinyl'
|
||||
'Vinyl7"': '7" Vinyl',
|
||||
'Vinyl10"': '10" Vinyl',
|
||||
'Vinyl12"': '12" Vinyl'
|
||||
};
|
||||
|
||||
var Countries = {
|
||||
|
|
|
@ -1,13 +1,13 @@
|
|||
// ==UserScript==
|
||||
// @name Musicbrainz DiscIds Detector
|
||||
// @namespace http://userscripts.org/users/22504
|
||||
// @version 2016.03.05.0
|
||||
// @version 2016.12.11.0
|
||||
// @description Generate MusicBrainz DiscIds from online EAC logs, and check existence in MusicBrainz database.
|
||||
// @downloadURL https://raw.githubusercontent.com/murdos/musicbrainz-userscripts/master/mb_discids_detector.user.js
|
||||
// @updateURL https://raw.githubusercontent.com/murdos/musicbrainz-userscripts/master/mb_discids_detector.user.js
|
||||
// @include http://avaxhome.ws/music/*
|
||||
// @include http*://what.cd/torrents.php?id=*
|
||||
// @include https://ssl.what.cd/torrents.php?id=*
|
||||
// @include https://apollo.rip/torrents.php?id=*
|
||||
// @include https://passtheheadphones.me/torrents.php?id=*
|
||||
// @include http*://lztr.us/torrents.php?id=*
|
||||
// @include http*://lztr.me/torrents.php?id=*
|
||||
// @include http*://mutracker.org/torrents.php?id=*
|
||||
|
@ -19,11 +19,14 @@
|
|||
// prevent JQuery conflicts, see http://wiki.greasespot.net/@grant
|
||||
this.$ = this.jQuery = jQuery.noConflict(true);
|
||||
|
||||
LOGGER.setLevel('info');
|
||||
|
||||
var CHECK_IMAGE = "%3D";
|
||||
|
||||
$(document).ready(function () {
|
||||
|
||||
if (window.location.host.match(/what\.cd|lztr\.(us|me)|mutracker\.org/)) {
|
||||
if (window.location.host.match(/apollo\.rip|passtheheadphones\.me|lztr\.(us|me)|mutracker\.org/)) {
|
||||
LOGGER.info("Gazelle site detected");
|
||||
gazellePageHandler();
|
||||
} else if (window.location.host.match(/avaxhome\.ws/)) {
|
||||
avaxHomePageHandler();
|
||||
|
@ -83,18 +86,7 @@ function gazellePageHandler() {
|
|||
artistName = m[1];
|
||||
releaseName = m[2];
|
||||
}
|
||||
/*
|
||||
if (texts.length == 0) { texts = $("#content div.thin h2 span") };
|
||||
texts = texts.contents().filter(function() { return this.nodeType == 3 || $.nodeName(this, "a") });
|
||||
|
||||
var artistName = "";
|
||||
texts.each(function(i) {
|
||||
if (i < texts.length-1) { artistName = artistName + ((this.nodeType == 3) ? this.textContent : $(this).text()); }
|
||||
});
|
||||
|
||||
var releaseName = texts[texts.length-1].textContent.replace(/\s\[.*\]$/, '');
|
||||
releaseName = releaseName.substring(artistName.length > 0 ? 3 : 0, releaseName.length).replace(/ \[.*\]/g, "").replace("Various Artists - ", "");
|
||||
*/
|
||||
LOGGER.debug("artist:", artistName, "- releaseName:", releaseName);
|
||||
|
||||
// Parse each torrent
|
||||
$('tr.group_torrent').filter(function () {
|
||||
|
@ -105,42 +97,49 @@ function gazellePageHandler() {
|
|||
$(torrentInfo).find('a')
|
||||
// Only investigate the ones with a log
|
||||
.filter(function (index) {
|
||||
return $(this).attr("href").match(/action=viewlog/) || $(this).text().contains("View Log");
|
||||
return $(this).text().match(/View Log/i);
|
||||
})
|
||||
.each(function () {
|
||||
|
||||
// What.CD way
|
||||
if ($(this).attr("href").match(/action=viewlog/)) {
|
||||
var blockquote = $(this).parents('blockquote');
|
||||
var torrentId = /torrentid=(\d+)/.exec($(this).attr('href'))[1];
|
||||
var url = '/' + $(this).attr('href');
|
||||
LOGGER.debug("Log link", this);
|
||||
if ($(this).attr("onclick").match(/show_logs/)) {
|
||||
if (window.location.host.match(/apollo/)) {
|
||||
LOGGER.debug("Apollo");
|
||||
var logAction = 'viewlog';
|
||||
} else if (window.location.host.match(/passtheheadphones/)){
|
||||
LOGGER.debug("PTH");
|
||||
var logAction = 'loglist';
|
||||
}
|
||||
}
|
||||
// LzTR way
|
||||
else if ($(this).text().contains("View Log")) {
|
||||
var blockquote = $(this).parents('div.linkbox');
|
||||
var torrentId = $(this).parents("tr.pad").attr("id").match(/torrent_(\d+)/)[1];
|
||||
var url = '/torrents.php?action=log_ajax&torrentid=' + torrentId;
|
||||
// LzTR
|
||||
else if ($(this).attr("onclick").match(/get_log/)) {
|
||||
LOGGER.debug("LzTR");
|
||||
var logAction = 'log_ajax';
|
||||
} else {
|
||||
return true;
|
||||
}
|
||||
var targetContainer = $(this).parents(".linkbox");
|
||||
var torrentId = /(show_logs|get_log)\('(\d+)/.exec($(this).attr('onclick'))[2];
|
||||
var logUrl = '/torrents.php?action=' + logAction + '&torrentid=' + torrentId;
|
||||
LOGGER.info("Log URL: ", logUrl);
|
||||
LOGGER.debug("targetContainer: ", targetContainer);
|
||||
|
||||
// Get log content
|
||||
$.get(url,
|
||||
$.get(logUrl,
|
||||
function (data) {
|
||||
LOGGER.debug("Log content", $(data).find('pre'));
|
||||
var discs = analyze_log_files($(data).find('pre'));
|
||||
LOGGER.debug("Number of disc found", discs.length);
|
||||
check_and_display_discs(artistName, releaseName, discs,
|
||||
function (mb_toc_numbers, discid, discNumber) {
|
||||
blockquote.append('<br /><strong>' + (discs.length > 1 ? 'Disc ' + discNumber + ': ' : '' ) + 'MB DiscId: </strong><span id="' + torrentId + '_disc' + discNumber + '" />');
|
||||
targetContainer.append('<br /><strong>' + (discs.length > 1 ? 'Disc ' + discNumber + ': ' : '' ) + 'MB DiscId: </strong><span id="' + torrentId + '_disc' + discNumber + '" />');
|
||||
},
|
||||
function (mb_toc_numbers, discid, discNumber, found) {
|
||||
|
||||
var url = computeAttachURL(mb_toc_numbers, artistName, releaseName);
|
||||
var html = '<a href="' + url + '">' + discid + '</a>';
|
||||
if (found) {
|
||||
html = html + '<img src="' + CHECK_IMAGE + '" />';
|
||||
}
|
||||
LOGGER.debug('#' + torrentId + '_disc' + discNumber);
|
||||
$('#' + torrentId + '_disc' + discNumber).html(html);
|
||||
}
|
||||
);
|
||||
|
|
|
@ -1,7 +1,7 @@
|
|||
// ==UserScript==
|
||||
// @name Display shortcut for relationships on MusicBrainz
|
||||
// @description Display icon shortcut for relationships of release-group, release, recording and work: e.g. Amazon, Discogs, Wikipedia, ... links. This allows to access some relationships without opening the entity page.
|
||||
// @version 2016.02.06.0
|
||||
// @version 2016.12.12.0
|
||||
// @author Aurelien Mino <aurelien.mino@gmail.com>
|
||||
// @licence GPL (http://www.gnu.org/copyleft/gpl.html)
|
||||
// @downloadURL https://raw.github.com/murdos/musicbrainz-userscripts/master/mb_relationship_shortcuts.user.js
|
||||
|
@ -18,7 +18,7 @@ var relationsIconsURLs = {
|
|||
'url': {
|
||||
"amazon asin": "http://amazon.fr/favicon.ico",
|
||||
"discogs": "https://www.discogs.com/images/favicon.ico",
|
||||
"wikidata": "https://bits.wikimedia.org/favicon/wikidata.ico",
|
||||
"wikidata": "https://upload.wikimedia.org/wikipedia/commons/e/e8/Wikidata-favicon.png",
|
||||
"imdb": "http://www.imdb.com/favicon.ico",
|
||||
"creative commons licensed download": "http://creativecommons.org/favicon.ico",
|
||||
"cover art link": "http://cdcovers.to/favicon.ico",
|
||||
|
|
Loading…
Reference in a new issue