mirror of
https://github.com/murdos/musicbrainz-userscripts
synced 2024-11-10 13:14:16 +00:00
14a32dab62
None of these changes are manual changes made a human
1128 lines
43 KiB
JavaScript
1128 lines
43 KiB
JavaScript
// ==UserScript==
|
|
// @name Import Takealot releases to MusicBrainz
|
|
// @description Add a button to import Takealot releases to MusicBrainz
|
|
// @version 2018.2.18.1
|
|
// @namespace https://github.com/murdos/musicbrainz-userscripts
|
|
// @include http*://www.takealot.com/*
|
|
// @downloadURL https://raw.github.com/murdos/musicbrainz-userscripts/master/takealot_importer.user.js
|
|
// @updateURL https://raw.github.com/murdos/musicbrainz-userscripts/master/takealot_importer.user.js
|
|
// @require https://ajax.googleapis.com/ajax/libs/jquery/2.1.4/jquery.min.js
|
|
// @require lib/mbimport.js
|
|
// @require lib/logger.js
|
|
// @require lib/mblinks.js
|
|
// @require lib/mbimportstyle.js
|
|
// @icon https://raw.githubusercontent.com/murdos/musicbrainz-userscripts/master/assets/images/Musicbrainz_import_logo.png
|
|
// @grant none
|
|
// ==/UserScript==
|
|
|
|
// prevent JQuery conflicts, see http://wiki.greasespot.net/@grant
|
|
this.$ = this.jQuery = jQuery.noConflict(true);
|
|
|
|
if (!unsafeWindow) unsafeWindow = window;
|
|
|
|
var DEBUG = false;
|
|
//DEBUG = true;
|
|
if (DEBUG) {
|
|
LOGGER.setLevel('debug');
|
|
}
|
|
|
|
////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
|
|
|
|
/*
|
|
* Test cases:
|
|
* - http://www.takealot.com/theuns-jordaan-roeper-cd/PLID17284867 - working (Single artist release)
|
|
* - http://www.takealot.com/various-artists-still-the-one-3cd/PLID40723650 - a dirty example
|
|
* - http://www.takealot.com/now-71-various-artists-cd/PLID40688034 - working (Various Artists and Multi Disc)
|
|
* - http://www.takealot.com/various-clubtraxxx-15-cd/PLID41391268 - working - do check if tracklist not in product info then look if tracklist in description
|
|
* - http://www.takealot.com/afrikaans-is-groot-vol-8-cd/PLID40736577
|
|
* - http://www.takealot.com/erens-in-die-middel-van-nerens-elvis-blue-cd/PLID38531203
|
|
*/
|
|
|
|
////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
|
|
|
|
$(document).ready(function() {
|
|
LOGGER.info('Document Ready & Takealot Userscript executing');
|
|
let TakealotRelease = ParseTakealotPage();
|
|
insertMBSection(TakealotRelease);
|
|
});
|
|
|
|
////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
|
|
// Insert MusicBrainz section into Takealot page //
|
|
////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
|
|
|
|
function insertMbUI(mbUI) {
|
|
let e;
|
|
if ((e = $('div.section.box-summary')) && e.length) {
|
|
e.after(mbUI);
|
|
} else if ((e = $('#buybox')) && e.length) {
|
|
e.before(mbUI);
|
|
} else if ((e = $('div.section.more-choices')) && e.length) {
|
|
e.before(mbUI);
|
|
}
|
|
}
|
|
|
|
// Insert links to high res image in Takealot page
|
|
function insertIMGlinks() {
|
|
let imghref = $('#slideshow a.jqzoom').attr('href');
|
|
LOGGER.debug('insertIMGlink Firing', imghref);
|
|
$('#slideshow').append(`<p><img src="//musicbrainz.org/favicon.ico" /><a href="${imghref}">MB High Res Image</a></p>`);
|
|
}
|
|
|
|
// Artist in product information is without diacritics
|
|
// Remove Diacritics from Artist in header to comapre with product information
|
|
function removeDiacritics(str) {
|
|
let defaultDiacriticsRemovalMap = [
|
|
{
|
|
base: 'A',
|
|
letters: /[\u0041\u24B6\uFF21\u00C0\u00C1\u00C2\u1EA6\u1EA4\u1EAA\u1EA8\u00C3\u0100\u0102\u1EB0\u1EAE\u1EB4\u1EB2\u0226\u01E0\u00C4\u01DE\u1EA2\u00C5\u01FA\u01CD\u0200\u0202\u1EA0\u1EAC\u1EB6\u1E00\u0104\u023A\u2C6F]/g
|
|
},
|
|
{
|
|
base: 'AA',
|
|
letters: /[\uA732]/g
|
|
},
|
|
{
|
|
base: 'AE',
|
|
letters: /[\u00C6\u01FC\u01E2]/g
|
|
},
|
|
{
|
|
base: 'AO',
|
|
letters: /[\uA734]/g
|
|
},
|
|
{
|
|
base: 'AU',
|
|
letters: /[\uA736]/g
|
|
},
|
|
{
|
|
base: 'AV',
|
|
letters: /[\uA738\uA73A]/g
|
|
},
|
|
{
|
|
base: 'AY',
|
|
letters: /[\uA73C]/g
|
|
},
|
|
{
|
|
base: 'B',
|
|
letters: /[\u0042\u24B7\uFF22\u1E02\u1E04\u1E06\u0243\u0182\u0181]/g
|
|
},
|
|
{
|
|
base: 'C',
|
|
letters: /[\u0043\u24B8\uFF23\u0106\u0108\u010A\u010C\u00C7\u1E08\u0187\u023B\uA73E]/g
|
|
},
|
|
{
|
|
base: 'D',
|
|
letters: /[\u0044\u24B9\uFF24\u1E0A\u010E\u1E0C\u1E10\u1E12\u1E0E\u0110\u018B\u018A\u0189\uA779]/g
|
|
},
|
|
{
|
|
base: 'DZ',
|
|
letters: /[\u01F1\u01C4]/g
|
|
},
|
|
{
|
|
base: 'Dz',
|
|
letters: /[\u01F2\u01C5]/g
|
|
},
|
|
{
|
|
base: 'E',
|
|
letters: /[\u0045\u24BA\uFF25\u00C8\u00C9\u00CA\u1EC0\u1EBE\u1EC4\u1EC2\u1EBC\u0112\u1E14\u1E16\u0114\u0116\u00CB\u1EBA\u011A\u0204\u0206\u1EB8\u1EC6\u0228\u1E1C\u0118\u1E18\u1E1A\u0190\u018E]/g
|
|
},
|
|
{
|
|
base: 'F',
|
|
letters: /[\u0046\u24BB\uFF26\u1E1E\u0191\uA77B]/g
|
|
},
|
|
{
|
|
base: 'G',
|
|
letters: /[\u0047\u24BC\uFF27\u01F4\u011C\u1E20\u011E\u0120\u01E6\u0122\u01E4\u0193\uA7A0\uA77D\uA77E]/g
|
|
},
|
|
{
|
|
base: 'H',
|
|
letters: /[\u0048\u24BD\uFF28\u0124\u1E22\u1E26\u021E\u1E24\u1E28\u1E2A\u0126\u2C67\u2C75\uA78D]/g
|
|
},
|
|
{
|
|
base: 'I',
|
|
letters: /[\u0049\u24BE\uFF29\u00CC\u00CD\u00CE\u0128\u012A\u012C\u0130\u00CF\u1E2E\u1EC8\u01CF\u0208\u020A\u1ECA\u012E\u1E2C\u0197]/g
|
|
},
|
|
{
|
|
base: 'J',
|
|
letters: /[\u004A\u24BF\uFF2A\u0134\u0248]/g
|
|
},
|
|
{
|
|
base: 'K',
|
|
letters: /[\u004B\u24C0\uFF2B\u1E30\u01E8\u1E32\u0136\u1E34\u0198\u2C69\uA740\uA742\uA744\uA7A2]/g
|
|
},
|
|
{
|
|
base: 'L',
|
|
letters: /[\u004C\u24C1\uFF2C\u013F\u0139\u013D\u1E36\u1E38\u013B\u1E3C\u1E3A\u0141\u023D\u2C62\u2C60\uA748\uA746\uA780]/g
|
|
},
|
|
{
|
|
base: 'LJ',
|
|
letters: /[\u01C7]/g
|
|
},
|
|
{
|
|
base: 'Lj',
|
|
letters: /[\u01C8]/g
|
|
},
|
|
{
|
|
base: 'M',
|
|
letters: /[\u004D\u24C2\uFF2D\u1E3E\u1E40\u1E42\u2C6E\u019C]/g
|
|
},
|
|
{
|
|
base: 'N',
|
|
letters: /[\u004E\u24C3\uFF2E\u01F8\u0143\u00D1\u1E44\u0147\u1E46\u0145\u1E4A\u1E48\u0220\u019D\uA790\uA7A4]/g
|
|
},
|
|
{
|
|
base: 'NJ',
|
|
letters: /[\u01CA]/g
|
|
},
|
|
{
|
|
base: 'Nj',
|
|
letters: /[\u01CB]/g
|
|
},
|
|
{
|
|
base: 'O',
|
|
letters: /[\u004F\u24C4\uFF2F\u00D2\u00D3\u00D4\u1ED2\u1ED0\u1ED6\u1ED4\u00D5\u1E4C\u022C\u1E4E\u014C\u1E50\u1E52\u014E\u022E\u0230\u00D6\u022A\u1ECE\u0150\u01D1\u020C\u020E\u01A0\u1EDC\u1EDA\u1EE0\u1EDE\u1EE2\u1ECC\u1ED8\u01EA\u01EC\u00D8\u01FE\u0186\u019F\uA74A\uA74C]/g
|
|
},
|
|
{
|
|
base: 'OI',
|
|
letters: /[\u01A2]/g
|
|
},
|
|
{
|
|
base: 'OO',
|
|
letters: /[\uA74E]/g
|
|
},
|
|
{
|
|
base: 'OU',
|
|
letters: /[\u0222]/g
|
|
},
|
|
{
|
|
base: 'P',
|
|
letters: /[\u0050\u24C5\uFF30\u1E54\u1E56\u01A4\u2C63\uA750\uA752\uA754]/g
|
|
},
|
|
{
|
|
base: 'Q',
|
|
letters: /[\u0051\u24C6\uFF31\uA756\uA758\u024A]/g
|
|
},
|
|
{
|
|
base: 'R',
|
|
letters: /[\u0052\u24C7\uFF32\u0154\u1E58\u0158\u0210\u0212\u1E5A\u1E5C\u0156\u1E5E\u024C\u2C64\uA75A\uA7A6\uA782]/g
|
|
},
|
|
{
|
|
base: 'S',
|
|
letters: /[\u0053\u24C8\uFF33\u1E9E\u015A\u1E64\u015C\u1E60\u0160\u1E66\u1E62\u1E68\u0218\u015E\u2C7E\uA7A8\uA784]/g
|
|
},
|
|
{
|
|
base: 'T',
|
|
letters: /[\u0054\u24C9\uFF34\u1E6A\u0164\u1E6C\u021A\u0162\u1E70\u1E6E\u0166\u01AC\u01AE\u023E\uA786]/g
|
|
},
|
|
{
|
|
base: 'TZ',
|
|
letters: /[\uA728]/g
|
|
},
|
|
{
|
|
base: 'U',
|
|
letters: /[\u0055\u24CA\uFF35\u00D9\u00DA\u00DB\u0168\u1E78\u016A\u1E7A\u016C\u00DC\u01DB\u01D7\u01D5\u01D9\u1EE6\u016E\u0170\u01D3\u0214\u0216\u01AF\u1EEA\u1EE8\u1EEE\u1EEC\u1EF0\u1EE4\u1E72\u0172\u1E76\u1E74\u0244]/g
|
|
},
|
|
{
|
|
base: 'V',
|
|
letters: /[\u0056\u24CB\uFF36\u1E7C\u1E7E\u01B2\uA75E\u0245]/g
|
|
},
|
|
{
|
|
base: 'VY',
|
|
letters: /[\uA760]/g
|
|
},
|
|
{
|
|
base: 'W',
|
|
letters: /[\u0057\u24CC\uFF37\u1E80\u1E82\u0174\u1E86\u1E84\u1E88\u2C72]/g
|
|
},
|
|
{
|
|
base: 'X',
|
|
letters: /[\u0058\u24CD\uFF38\u1E8A\u1E8C]/g
|
|
},
|
|
{
|
|
base: 'Y',
|
|
letters: /[\u0059\u24CE\uFF39\u1EF2\u00DD\u0176\u1EF8\u0232\u1E8E\u0178\u1EF6\u1EF4\u01B3\u024E\u1EFE]/g
|
|
},
|
|
{
|
|
base: 'Z',
|
|
letters: /[\u005A\u24CF\uFF3A\u0179\u1E90\u017B\u017D\u1E92\u1E94\u01B5\u0224\u2C7F\u2C6B\uA762]/g
|
|
},
|
|
{
|
|
base: 'a',
|
|
letters: /[\u0061\u24D0\uFF41\u1E9A\u00E0\u00E1\u00E2\u1EA7\u1EA5\u1EAB\u1EA9\u00E3\u0101\u0103\u1EB1\u1EAF\u1EB5\u1EB3\u0227\u01E1\u00E4\u01DF\u1EA3\u00E5\u01FB\u01CE\u0201\u0203\u1EA1\u1EAD\u1EB7\u1E01\u0105\u2C65\u0250]/g
|
|
},
|
|
{
|
|
base: 'aa',
|
|
letters: /[\uA733]/g
|
|
},
|
|
{
|
|
base: 'ae',
|
|
letters: /[\u00E6\u01FD\u01E3]/g
|
|
},
|
|
{
|
|
base: 'ao',
|
|
letters: /[\uA735]/g
|
|
},
|
|
{
|
|
base: 'au',
|
|
letters: /[\uA737]/g
|
|
},
|
|
{
|
|
base: 'av',
|
|
letters: /[\uA739\uA73B]/g
|
|
},
|
|
{
|
|
base: 'ay',
|
|
letters: /[\uA73D]/g
|
|
},
|
|
{
|
|
base: 'b',
|
|
letters: /[\u0062\u24D1\uFF42\u1E03\u1E05\u1E07\u0180\u0183\u0253]/g
|
|
},
|
|
{
|
|
base: 'c',
|
|
letters: /[\u0063\u24D2\uFF43\u0107\u0109\u010B\u010D\u00E7\u1E09\u0188\u023C\uA73F\u2184]/g
|
|
},
|
|
{
|
|
base: 'd',
|
|
letters: /[\u0064\u24D3\uFF44\u1E0B\u010F\u1E0D\u1E11\u1E13\u1E0F\u0111\u018C\u0256\u0257\uA77A]/g
|
|
},
|
|
{
|
|
base: 'dz',
|
|
letters: /[\u01F3\u01C6]/g
|
|
},
|
|
{
|
|
base: 'e',
|
|
letters: /[\u0065\u24D4\uFF45\u00E8\u00E9\u00EA\u1EC1\u1EBF\u1EC5\u1EC3\u1EBD\u0113\u1E15\u1E17\u0115\u0117\u00EB\u1EBB\u011B\u0205\u0207\u1EB9\u1EC7\u0229\u1E1D\u0119\u1E19\u1E1B\u0247\u025B\u01DD]/g
|
|
},
|
|
{
|
|
base: 'f',
|
|
letters: /[\u0066\u24D5\uFF46\u1E1F\u0192\uA77C]/g
|
|
},
|
|
{
|
|
base: 'g',
|
|
letters: /[\u0067\u24D6\uFF47\u01F5\u011D\u1E21\u011F\u0121\u01E7\u0123\u01E5\u0260\uA7A1\u1D79\uA77F]/g
|
|
},
|
|
{
|
|
base: 'h',
|
|
letters: /[\u0068\u24D7\uFF48\u0125\u1E23\u1E27\u021F\u1E25\u1E29\u1E2B\u1E96\u0127\u2C68\u2C76\u0265]/g
|
|
},
|
|
{
|
|
base: 'hv',
|
|
letters: /[\u0195]/g
|
|
},
|
|
{
|
|
base: 'i',
|
|
letters: /[\u0069\u24D8\uFF49\u00EC\u00ED\u00EE\u0129\u012B\u012D\u00EF\u1E2F\u1EC9\u01D0\u0209\u020B\u1ECB\u012F\u1E2D\u0268\u0131]/g
|
|
},
|
|
{
|
|
base: 'j',
|
|
letters: /[\u006A\u24D9\uFF4A\u0135\u01F0\u0249]/g
|
|
},
|
|
{
|
|
base: 'k',
|
|
letters: /[\u006B\u24DA\uFF4B\u1E31\u01E9\u1E33\u0137\u1E35\u0199\u2C6A\uA741\uA743\uA745\uA7A3]/g
|
|
},
|
|
{
|
|
base: 'l',
|
|
letters: /[\u006C\u24DB\uFF4C\u0140\u013A\u013E\u1E37\u1E39\u013C\u1E3D\u1E3B\u017F\u0142\u019A\u026B\u2C61\uA749\uA781\uA747]/g
|
|
},
|
|
{
|
|
base: 'lj',
|
|
letters: /[\u01C9]/g
|
|
},
|
|
{
|
|
base: 'm',
|
|
letters: /[\u006D\u24DC\uFF4D\u1E3F\u1E41\u1E43\u0271\u026F]/g
|
|
},
|
|
{
|
|
base: 'n',
|
|
letters: /[\u006E\u24DD\uFF4E\u01F9\u0144\u00F1\u1E45\u0148\u1E47\u0146\u1E4B\u1E49\u019E\u0272\u0149\uA791\uA7A5]/g
|
|
},
|
|
{
|
|
base: 'nj',
|
|
letters: /[\u01CC]/g
|
|
},
|
|
{
|
|
base: 'o',
|
|
letters: /[\u006F\u24DE\uFF4F\u00F2\u00F3\u00F4\u1ED3\u1ED1\u1ED7\u1ED5\u00F5\u1E4D\u022D\u1E4F\u014D\u1E51\u1E53\u014F\u022F\u0231\u00F6\u022B\u1ECF\u0151\u01D2\u020D\u020F\u01A1\u1EDD\u1EDB\u1EE1\u1EDF\u1EE3\u1ECD\u1ED9\u01EB\u01ED\u00F8\u01FF\u0254\uA74B\uA74D\u0275]/g
|
|
},
|
|
{
|
|
base: 'oi',
|
|
letters: /[\u01A3]/g
|
|
},
|
|
{
|
|
base: 'ou',
|
|
letters: /[\u0223]/g
|
|
},
|
|
{
|
|
base: 'oo',
|
|
letters: /[\uA74F]/g
|
|
},
|
|
{
|
|
base: 'p',
|
|
letters: /[\u0070\u24DF\uFF50\u1E55\u1E57\u01A5\u1D7D\uA751\uA753\uA755]/g
|
|
},
|
|
{
|
|
base: 'q',
|
|
letters: /[\u0071\u24E0\uFF51\u024B\uA757\uA759]/g
|
|
},
|
|
{
|
|
base: 'r',
|
|
letters: /[\u0072\u24E1\uFF52\u0155\u1E59\u0159\u0211\u0213\u1E5B\u1E5D\u0157\u1E5F\u024D\u027D\uA75B\uA7A7\uA783]/g
|
|
},
|
|
{
|
|
base: 's',
|
|
letters: /[\u0073\u24E2\uFF53\u00DF\u015B\u1E65\u015D\u1E61\u0161\u1E67\u1E63\u1E69\u0219\u015F\u023F\uA7A9\uA785\u1E9B]/g
|
|
},
|
|
{
|
|
base: 't',
|
|
letters: /[\u0074\u24E3\uFF54\u1E6B\u1E97\u0165\u1E6D\u021B\u0163\u1E71\u1E6F\u0167\u01AD\u0288\u2C66\uA787]/g
|
|
},
|
|
{
|
|
base: 'tz',
|
|
letters: /[\uA729]/g
|
|
},
|
|
{
|
|
base: 'u',
|
|
letters: /[\u0075\u24E4\uFF55\u00F9\u00FA\u00FB\u0169\u1E79\u016B\u1E7B\u016D\u00FC\u01DC\u01D8\u01D6\u01DA\u1EE7\u016F\u0171\u01D4\u0215\u0217\u01B0\u1EEB\u1EE9\u1EEF\u1EED\u1EF1\u1EE5\u1E73\u0173\u1E77\u1E75\u0289]/g
|
|
},
|
|
{
|
|
base: 'v',
|
|
letters: /[\u0076\u24E5\uFF56\u1E7D\u1E7F\u028B\uA75F\u028C]/g
|
|
},
|
|
{
|
|
base: 'vy',
|
|
letters: /[\uA761]/g
|
|
},
|
|
{
|
|
base: 'w',
|
|
letters: /[\u0077\u24E6\uFF57\u1E81\u1E83\u0175\u1E87\u1E85\u1E98\u1E89\u2C73]/g
|
|
},
|
|
{
|
|
base: 'x',
|
|
letters: /[\u0078\u24E7\uFF58\u1E8B\u1E8D]/g
|
|
},
|
|
{
|
|
base: 'y',
|
|
letters: /[\u0079\u24E8\uFF59\u1EF3\u00FD\u0177\u1EF9\u0233\u1E8F\u00FF\u1EF7\u1E99\u1EF5\u01B4\u024F\u1EFF]/g
|
|
},
|
|
{
|
|
base: 'z',
|
|
letters: /[\u007A\u24E9\uFF5A\u017A\u1E91\u017C\u017E\u1E93\u1E95\u01B6\u0225\u0240\u2C6C\uA763]/g
|
|
}
|
|
];
|
|
|
|
for (let i = 0; i < defaultDiacriticsRemovalMap.length; i++) {
|
|
str = str.replace(defaultDiacriticsRemovalMap[i].letters, defaultDiacriticsRemovalMap[i].base);
|
|
}
|
|
|
|
return str;
|
|
}
|
|
|
|
// Insert links in Takealot page
|
|
function insertMBSection(release) {
|
|
//LOGGER.debug("insertMBsection Firing");
|
|
|
|
let mbUI = $('<div class="section musicbrainz"><h3>MusicBrainz</h3></div>').hide();
|
|
|
|
if (DEBUG)
|
|
mbUI.css({
|
|
border: '3px dotted red'
|
|
});
|
|
|
|
let mbContentBlock = $('<div class="section_content"></div>');
|
|
mbUI.append(mbContentBlock);
|
|
|
|
if (release.maybe_buggy) {
|
|
let warning_buggy = $('<p><small><b>Warning</b>: this release is buggy, please check twice the data you import.</small><p').css({
|
|
color: 'red',
|
|
'margin-top': '4px',
|
|
'margin-bottom': '4px'
|
|
});
|
|
mbContentBlock.prepend(warning_buggy);
|
|
}
|
|
|
|
// Form parameters
|
|
let edit_note = MBImport.makeEditNote(window.location.href, 'Takealot');
|
|
LOGGER.debug('Edit Note: ', edit_note);
|
|
let parameters = MBImport.buildFormParameters(release, edit_note);
|
|
// LOGGER.debug("*** Form parameters: ", parameters);
|
|
// Build form + search button
|
|
let innerHTML = `<div id="mb_buttons">${MBImport.buildFormHTML(parameters)}${MBImport.buildSearchButton(release)}</div>`;
|
|
mbContentBlock.append(innerHTML);
|
|
|
|
insertMbUI(mbUI);
|
|
insertIMGlinks();
|
|
insertMBLinks();
|
|
|
|
$('#mb_buttons').css({
|
|
display: 'inline-block',
|
|
width: '100%'
|
|
});
|
|
$('form.musicbrainz_import').css({
|
|
width: '49%',
|
|
display: 'inline-block'
|
|
});
|
|
$('form.musicbrainz_import_search').css({
|
|
float: 'right'
|
|
});
|
|
$('form.musicbrainz_import > button').css({
|
|
width: '100%',
|
|
'box-sizing': 'border-box'
|
|
});
|
|
|
|
mbUI.slideDown();
|
|
}
|
|
|
|
// Insert link to MB release (MB Release need a URL entry to match )
|
|
function insertMBLinks() {
|
|
let mblinks = new MBLinks('TAKEALOT_CACHE', 7 * 24 * 60); // force refresh of cached links once a week
|
|
|
|
// var artist_link = 'http://' + window.location.href.match( /^https?:\/\/(.*)\/album\/.+$/i)[1];
|
|
// mblinks.searchAndDisplayMbLink(artist_link, 'artist', function (link) { $('div#there').before(link); } );
|
|
|
|
let album_link = window.location.href;
|
|
mblinks.searchAndDisplayMbLink(album_link, 'release', function(link) {
|
|
$('h1.fn').append(link);
|
|
});
|
|
}
|
|
// Analyze Takealot data and return a release object
|
|
function ParseTakealotPage() {
|
|
LOGGER.debug('ParseTakealotPage function firing');
|
|
|
|
let releasebarcode = '';
|
|
let releasecountry = '';
|
|
let releasedaterel = '';
|
|
let releaselanguage = '';
|
|
let releasetitle = '';
|
|
let releaselabel = [];
|
|
let releaseformat = '';
|
|
let release_maybe_buggy = false;
|
|
|
|
// Select all DL data in the "Product Info" div id = second div class = details
|
|
let allinfolist = document.querySelectorAll('div#second > div.details > dl > *');
|
|
// Iterate all over the lines
|
|
for (let i = 0; i < allinfolist.length; i++) {
|
|
let artistitemlabel = allinfolist[i];
|
|
|
|
if (artistitemlabel.tagName == 'DT') {
|
|
let artistitem = artistitemlabel.textContent.toLowerCase();
|
|
switch (artistitem) {
|
|
case 'barcode': // use these cases to select the spesific text values
|
|
releasebarcode = artistitemlabel.nextSibling.textContent.trim();
|
|
LOGGER.debug(`The value is :${artistitem} > ${releasebarcode}`);
|
|
break;
|
|
case 'country': // use these cases to select the spesific text values
|
|
releasecountry = artistitemlabel.nextSibling.textContent.trim();
|
|
LOGGER.debug(`The value is :${artistitem} > ${releasecountry}`);
|
|
break;
|
|
case 'artists': // use these cases to select the spesific text values
|
|
releaseartist = artistitemlabel.nextSibling.textContent.trim();
|
|
LOGGER.debug(`The value is :${artistitem} > ${releaseartist}`);
|
|
break;
|
|
case 'label': // use these cases to select the spesific text values
|
|
releaselabel.push({
|
|
name: artistitemlabel.nextSibling.textContent.trim()
|
|
});
|
|
LOGGER.debug(`The value is :${artistitem} > ${releaselabel}`);
|
|
break;
|
|
case 'date released': // use these cases to select the spesific text values
|
|
releasedaterel = artistitemlabel.nextSibling.textContent.trim();
|
|
LOGGER.debug(`The value is :${artistitem} > ${releasedaterel}`);
|
|
break;
|
|
case 'format': // use these cases to select the spesific text values
|
|
releaseformat = artistitemlabel.nextSibling.textContent.trim();
|
|
LOGGER.debug(`The value is :${artistitem} > ${releaseformat}`);
|
|
break;
|
|
case 'language': // use these cases to select the spesific text values
|
|
releaselanguage = artistitemlabel.nextSibling.textContent.trim();
|
|
LOGGER.debug(`The value is :${artistitem} > ${releaselanguage}`);
|
|
break;
|
|
case 'title': // use these cases to select the spesific text values
|
|
releasetitle = artistitemlabel.nextSibling.textContent.trim();
|
|
LOGGER.debug(`The value is :${artistitem} > ${releasetitle}`);
|
|
break;
|
|
case 'tracks': // use these cases to select the spesific text values
|
|
LOGGER.debug(`The label chosen is :${artistitem}`);
|
|
|
|
// Iterate over all the tracks - changed * to li to try and only catch tracks
|
|
var alltracklist = document.querySelectorAll('div#second > div.details > dl > dd > ol:last-child > li');
|
|
LOGGER.debug(' *** Dump the tracks nodeList to see what is going on ***');
|
|
LOGGER.debug(alltracklist);
|
|
// Tracks
|
|
var tracklistarray = new Array(); // create the tracklist array to use later
|
|
|
|
// var releaseartist = alltracklist[0].textContent.trim();
|
|
// The format on Takealot changed and Artist is not the first element in li anymore but last
|
|
// remember this is a nodeList and not an array
|
|
var releaseartist = alltracklist[alltracklist.length - 1].textContent.trim();
|
|
LOGGER.debug(`The album artist:${releaseartist}`);
|
|
|
|
// Last track to find last disc number
|
|
var lasttrack = alltracklist[alltracklist.length - 2].textContent.trim();
|
|
LOGGER.debug(`The last track:${lasttrack}`);
|
|
|
|
lastdiscnumberregex = /\[ Disc (.*) Track./; // regex to match disc number from last track
|
|
var lastdiscnumbermatch = lasttrack.match(lastdiscnumberregex);
|
|
var lastdiscnumber = parseInt(lastdiscnumbermatch[1]);
|
|
LOGGER.debug('Last Disc Number: ', lastdiscnumber);
|
|
|
|
// Discs
|
|
var disclistarray = new Array(); // create the tracklist array to use later
|
|
|
|
for (var k = 1; k < lastdiscnumber + 1; k++) {
|
|
// start at 1 to keep array in sync with disc numbers
|
|
LOGGER.debug('Disc iterate: ', k);
|
|
|
|
// Tracks
|
|
var tracklistarray = new Array(); // create the track list array
|
|
|
|
for (let j = 0; j < alltracklist.length - 1; j++) {
|
|
// changed j to 0 and length-1 as Artist is at end
|
|
// do regex here and if current disc listed in track = k then push the track into the array for that disc
|
|
let trackdetails = alltracklist[j].textContent.trim();
|
|
disctracktitleregex = /\[ Disc (\d{2}) Track.(\b\d{2}) \] (.*)/;
|
|
let disctracktitle = trackdetails.match(disctracktitleregex);
|
|
|
|
let currentdiscnumber = parseInt(disctracktitle[1]);
|
|
|
|
if (currentdiscnumber == k) {
|
|
var track = new Object();
|
|
track.number = parseInt(disctracktitle[2]);
|
|
track.title = disctracktitle[3];
|
|
LOGGER.debug('The track object: ', `${currentdiscnumber} - ${track.number} - ${track.title}`);
|
|
tracklistarray.push(track);
|
|
}
|
|
}
|
|
disclistarray.push(tracklistarray);
|
|
}
|
|
|
|
LOGGER.debug('** Disclist Array *** ', disclistarray);
|
|
break;
|
|
}
|
|
}
|
|
}
|
|
|
|
// Logic added to derive the release title from the heading if missing from product info
|
|
if (releasetitle == '') {
|
|
let MediaHeading = document.querySelectorAll('h1.fn');
|
|
let TitleStr = MediaHeading[0].innerText;
|
|
var TitleRegex = /(.*)-(.*)+\s\(([^)]+)\)/;
|
|
|
|
if (TitleStr.match(TitleRegex)) {
|
|
var HeadArray = TitleStr.match(TitleRegex);
|
|
LOGGER.debug('HeadArray', HeadArray);
|
|
if (removeDiacritics(HeadArray[1].trim()) == releaseartist) {
|
|
LOGGER.debug('matched title equal the releaseartist therefore swapped');
|
|
releasetitle = HeadArray[2].trim();
|
|
} else {
|
|
LOGGER.debug('matched title equal the title therefore not swapped');
|
|
releasetitle = HeadArray[1].trim();
|
|
LOGGER.debug('Title:', releasetitle, ' Artist:', releaseartist);
|
|
// check if artist assigned else make the remaining value the artist and mark buggy true
|
|
if (releaseartist == null) {
|
|
releaseartist = HeadArray[2].trim();
|
|
release_maybe_buggy = true;
|
|
}
|
|
}
|
|
} else {
|
|
LOGGER.debug('The Heading REGEX not matched!!');
|
|
var TitleRegex = /(.*)+\s\(([^)]+)\)/;
|
|
var HeadArray = TitleStr.match(TitleRegex);
|
|
LOGGER.debug('HeadArray', HeadArray);
|
|
releasetitle = HeadArray[1].trim();
|
|
if (releaseformat == null) {
|
|
releaseformat = HeadArray[2].trim();
|
|
}
|
|
}
|
|
|
|
LOGGER.debug('Release Title from heading:', releasetitle);
|
|
}
|
|
|
|
var thediscnumber = 0;
|
|
let allprodinfo = '';
|
|
let descriptionarray = [];
|
|
|
|
if (lastdiscnumber > 0) {
|
|
LOGGER.debug('** Tracklist present in Product Info tab **');
|
|
} else {
|
|
LOGGER.debug(" ** No tracks in Product Info tab let's have a look in description tab");
|
|
// TODO logic to check VA and below or artist with "Tracklisting:" and no Disc 1...
|
|
if (document.querySelectorAll('div#prod-desc > br').length != 0) {
|
|
// Known format based on <br>
|
|
LOGGER.debug(' ** Formatting based on <br>');
|
|
allprodinfo = document.querySelectorAll('div#prod-desc > br'); // Select all data in the "Description" div id = prod-desc with <br>
|
|
for (var k = 0; k < allprodinfo.length - 1; k++) {
|
|
descriptionrow = allprodinfo[k].nextSibling.textContent.trim();
|
|
// LOGGER.debug("PROD-INFO > BR > ",descriptionrow);
|
|
// regex to find Disc 1 and add 1 to a group ^Disc+(.\d)
|
|
descriptionrowregex = /^Disc+(.\d)/;
|
|
var founddisc = descriptionrow.match(descriptionrowregex);
|
|
LOGGER.debug(' **** DISC FOUND ****', founddisc);
|
|
if (founddisc != null) {
|
|
var thediscnumber = parseInt(founddisc[1]);
|
|
// LOGGER.debug(" **** DISC FOUND NUMBER ****", thediscnumber);
|
|
}
|
|
LOGGER.debug('PROD-INFO > BR > ', `${thediscnumber}-${descriptionrow}`);
|
|
|
|
if (thediscnumber == 0) {
|
|
thediscnumber = 1;
|
|
LOGGER.debug(' **** DISC NUMBER ****', thediscnumber);
|
|
}
|
|
|
|
// regex to split the description row into track, title and artist (^\d).(.*)-(.*)
|
|
var descriptionrowregex = /(^\d+).(.*)-(.*)/;
|
|
//var descriptionrow_tracktitleartist = descriptionrow.match(descriptionrowregex);
|
|
|
|
if (descriptionrow.match(descriptionrowregex) != null) {
|
|
LOGGER.debug('Track. title - Artist');
|
|
var descriptionrow_tracktitleartist = descriptionrow.match(descriptionrowregex);
|
|
// do the same as in tracklist and push the disc numbers into an array
|
|
descriptiontrack = new Object();
|
|
|
|
if (descriptionrow_tracktitleartist != null) {
|
|
descriptiontrack.disc = thediscnumber;
|
|
descriptiontrack.track = descriptionrow_tracktitleartist[1];
|
|
descriptiontrack.title = descriptionrow_tracktitleartist[2].trim();
|
|
descriptiontrack.artist = descriptionrow_tracktitleartist[3];
|
|
|
|
//to get the last disc number via iterate
|
|
var description_lastdisc = parseInt(thediscnumber);
|
|
descriptionarray.push(descriptiontrack);
|
|
}
|
|
} else {
|
|
LOGGER.debug('Assume Track. title');
|
|
// regex to split the description row into track. title (^\d).(.*)
|
|
var descriptionrowregex = /(^\d+).(.*)/;
|
|
descriptionrow_tracktitleartist = descriptionrow.match(descriptionrowregex);
|
|
// do the same as in tracklist and push the disc numbers into an array
|
|
descriptiontrack = new Object();
|
|
|
|
if (descriptionrow_tracktitleartist != null) {
|
|
descriptiontrack.disc = thediscnumber;
|
|
descriptiontrack.track = descriptionrow_tracktitleartist[1];
|
|
descriptiontrack.title = descriptionrow_tracktitleartist[2];
|
|
descriptiontrack.artist = releaseartist;
|
|
|
|
//to get the last disc number via iterate
|
|
var description_lastdisc = parseInt(thediscnumber);
|
|
descriptionarray.push(descriptiontrack);
|
|
}
|
|
}
|
|
}
|
|
} else if (document.querySelectorAll('div#prod-desc > div').length != 0) {
|
|
// New format encountered based on <div> LOGGER.debug(" ** Formatting based on <div>");
|
|
LOGGER.debug(' ** Formatting based on <div>');
|
|
allprodinfo = document.querySelectorAll('div#prod-desc > div'); // Select all data in the "Description" div id = prod-desc with <div>
|
|
for (let div_iterate = 0; div_iterate < allprodinfo.length; div_iterate++) {
|
|
//LOGGER.debug(div_iterate," - ",allprodinfo[div_iterate].textContent.trim());
|
|
descriptionrow = allprodinfo[div_iterate].textContent.trim();
|
|
|
|
descriptionrowdiscregex = /^[Disc|CD]+(.\d)/; // need to find more div samples to test variants
|
|
var founddisc = descriptionrow.match(descriptionrowdiscregex);
|
|
|
|
if (founddisc != null) {
|
|
var thediscnumber = parseInt(founddisc[1]);
|
|
LOGGER.debug(' **** DISC FOUND NUMBER ****', thediscnumber);
|
|
}
|
|
|
|
LOGGER.debug('FOUNDDISC# ', founddisc);
|
|
// else if (founddisc == null) {
|
|
// var thediscnumber = 1;
|
|
// LOGGER.debug(" **** DISC NUMBER ****", thediscnumber);
|
|
// }
|
|
|
|
if (founddisc == null) {
|
|
var thediscnumber = 1;
|
|
LOGGER.debug(' **** DISC NUMBER ****', thediscnumber);
|
|
}
|
|
|
|
descriptionrowregex = /(^\d+).(.*)/;
|
|
let descriptionrow_tracknumtitle = descriptionrow.match(descriptionrowregex);
|
|
|
|
descriptiontrack = new Object();
|
|
|
|
if (descriptionrow_tracknumtitle != null) {
|
|
LOGGER.debug('** Track **', descriptionrow_tracknumtitle);
|
|
descriptiontrack.disc = thediscnumber;
|
|
descriptiontrack.track = descriptionrow_tracknumtitle[1];
|
|
descriptiontrack.title = descriptionrow_tracknumtitle[2].trim();
|
|
descriptiontrack.artist = releaseartist; // need to do logic to check regex with and without artist
|
|
|
|
//to get the last disc number via iterate
|
|
var description_lastdisc = parseInt(thediscnumber);
|
|
descriptionarray.push(descriptiontrack);
|
|
}
|
|
}
|
|
} else {
|
|
LOGGER.info(' ***** Unknown formatting ****** ');
|
|
release_maybe_buggy = true;
|
|
}
|
|
|
|
// Discs
|
|
var disclistarray = new Array(); // create the tracklist array to use later
|
|
|
|
for (let desc_discs = 0; desc_discs < description_lastdisc; desc_discs++) {
|
|
var tracklistarray = new Array();
|
|
for (let desc__track = 0; desc__track < descriptionarray.length; desc__track++) {
|
|
let desc_currentdiscnumber = descriptionarray[desc__track].disc;
|
|
if (desc_currentdiscnumber == desc_discs + 1) {
|
|
var track = new Object();
|
|
let track_artist_credit = new Array();
|
|
|
|
track.number = descriptionarray[desc__track].track;
|
|
track.title = descriptionarray[desc__track].title;
|
|
|
|
let track_artist_credit_object = new Object();
|
|
track_artist_credit_object.artist_name = descriptionarray[desc__track].artist;
|
|
track_artist_credit.push(track_artist_credit_object);
|
|
//track_artist_credit.artist_name = descriptionarray[desc__track].artist;
|
|
track.artist_credit = track_artist_credit;
|
|
tracklistarray.push(track);
|
|
}
|
|
}
|
|
disclistarray.push(tracklistarray);
|
|
}
|
|
lastdiscnumber = description_lastdisc;
|
|
}
|
|
|
|
// do final checks to determine if it may be buggy
|
|
if (releaseartist == null) {
|
|
release_maybe_buggy = true;
|
|
}
|
|
|
|
release = new Object();
|
|
|
|
release.maybe_buggy = release_maybe_buggy;
|
|
|
|
// Release artist credit
|
|
release.artist_credit = new Array();
|
|
|
|
let artist_name = releaseartist;
|
|
release.artist_credit.push({
|
|
artist_name: artist_name
|
|
});
|
|
|
|
// Release title
|
|
release.title = releasetitle;
|
|
// Release Barcode
|
|
release.barcode = releasebarcode;
|
|
|
|
// Default status is official
|
|
release.status = 'official';
|
|
|
|
// Other hard-coded info
|
|
release.script = 'Latn';
|
|
|
|
release.country = Countries[releasecountry];
|
|
release.language = Languages[releaselanguage];
|
|
|
|
release.discs = new Array();
|
|
for (let l = 0; l < lastdiscnumber; l++) {
|
|
// LOGGER.debug("Disc position:", l + 1);
|
|
// LOGGER.debug("Tracklist for the selected disc: ", disclistarray[l]);
|
|
let disc = {
|
|
position: l + 1,
|
|
format: DiscFormats[releaseformat],
|
|
tracks: disclistarray[l]
|
|
};
|
|
release.discs.push(disc);
|
|
}
|
|
|
|
release.labels = releaselabel;
|
|
|
|
// Release URL
|
|
release.urls = new Array();
|
|
release.urls.push({
|
|
url: window.location.href,
|
|
link_type: MBImport.URL_TYPES.purchase_for_mail_order
|
|
}); //type 74 is purchase for download
|
|
// TODO check if CD then add purchase medium
|
|
|
|
// Release date
|
|
let releasedate = releasedaterel;
|
|
if (typeof releasedate != 'undefined' && releasedate != '') {
|
|
let tmp = releasedate.split('-');
|
|
if (tmp[0] != 'undefined' && tmp[0] != '') {
|
|
release.year = parseInt(tmp[0], 10);
|
|
if (tmp[1] != 'undefined' && tmp[1] != '') {
|
|
release.month = parseInt(tmp[1], 10);
|
|
if (tmp[2] != 'undefined' && tmp[2] != '') {
|
|
release.day = parseInt(tmp[2], 10);
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
LOGGER.info('Release:', release);
|
|
|
|
return release;
|
|
}
|
|
|
|
////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
|
|
// Takealot -> MusicBrainz mapping //
|
|
////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
|
|
|
|
var DiscFormats = new Array();
|
|
DiscFormats['CD'] = 'CD';
|
|
DiscFormats['DVD'] = 'DVD';
|
|
DiscFormats['Audio CD'] = 'CD';
|
|
|
|
var Languages = new Array();
|
|
Languages['Afrikaans'] = 'afr';
|
|
|
|
var Countries = new Array();
|
|
Countries['Afghanistan'] = 'AF';
|
|
Countries['Albania'] = 'AL';
|
|
Countries['Algeria'] = 'DZ';
|
|
Countries['American Samoa'] = 'AS';
|
|
Countries['Andorra'] = 'AD';
|
|
Countries['Angola'] = 'AO';
|
|
Countries['Anguilla'] = 'AI';
|
|
Countries['Antarctica'] = 'AQ';
|
|
Countries['Antigua and Barbuda'] = 'AG';
|
|
Countries['Argentina'] = 'AR';
|
|
Countries['Armenia'] = 'AM';
|
|
Countries['Aruba'] = 'AW';
|
|
Countries['Australia'] = 'AU';
|
|
Countries['Austria'] = 'AT';
|
|
Countries['Azerbaijan'] = 'AZ';
|
|
Countries['Bahamas'] = 'BS';
|
|
Countries['Bahrain'] = 'BH';
|
|
Countries['Bangladesh'] = 'BD';
|
|
Countries['Barbados'] = 'BB';
|
|
Countries['Belarus'] = 'BY';
|
|
Countries['Belgium'] = 'BE';
|
|
Countries['Belize'] = 'BZ';
|
|
Countries['Benin'] = 'BJ';
|
|
Countries['Bermuda'] = 'BM';
|
|
Countries['Bhutan'] = 'BT';
|
|
Countries['Bolivia'] = 'BO';
|
|
Countries['Croatia'] = 'HR';
|
|
Countries['Botswana'] = 'BW';
|
|
Countries['Bouvet Island'] = 'BV';
|
|
Countries['Brazil'] = 'BR';
|
|
Countries['British Indian Ocean Territory'] = 'IO';
|
|
Countries['Brunei Darussalam'] = 'BN';
|
|
Countries['Bulgaria'] = 'BG';
|
|
Countries['Burkina Faso'] = 'BF';
|
|
Countries['Burundi'] = 'BI';
|
|
Countries['Cambodia'] = 'KH';
|
|
Countries['Cameroon'] = 'CM';
|
|
Countries['Canada'] = 'CA';
|
|
Countries['Cape Verde'] = 'CV';
|
|
Countries['Cayman Islands'] = 'KY';
|
|
Countries['Central African Republic'] = 'CF';
|
|
Countries['Chad'] = 'TD';
|
|
Countries['Chile'] = 'CL';
|
|
Countries['China'] = 'CN';
|
|
Countries['Christmas Island'] = 'CX';
|
|
Countries['Cocos (Keeling) Islands'] = 'CC';
|
|
Countries['Colombia'] = 'CO';
|
|
Countries['Comoros'] = 'KM';
|
|
Countries['Congo'] = 'CG';
|
|
Countries['Cook Islands'] = 'CK';
|
|
Countries['Costa Rica'] = 'CR';
|
|
Countries['Virgin Islands, British'] = 'VG';
|
|
Countries['Cuba'] = 'CU';
|
|
Countries['Cyprus'] = 'CY';
|
|
Countries['Czech Republic'] = 'CZ';
|
|
Countries['Denmark'] = 'DK';
|
|
Countries['Djibouti'] = 'DJ';
|
|
Countries['Dominica'] = 'DM';
|
|
Countries['Dominican Republic'] = 'DO';
|
|
Countries['Ecuador'] = 'EC';
|
|
Countries['Egypt'] = 'EG';
|
|
Countries['El Salvador'] = 'SV';
|
|
Countries['Equatorial Guinea'] = 'GQ';
|
|
Countries['Eritrea'] = 'ER';
|
|
Countries['Estonia'] = 'EE';
|
|
Countries['Ethiopia'] = 'ET';
|
|
Countries['Falkland Islands (Malvinas)'] = 'FK';
|
|
Countries['Faroe Islands'] = 'FO';
|
|
Countries['Fiji'] = 'FJ';
|
|
Countries['Finland'] = 'FI';
|
|
Countries['France'] = 'FR';
|
|
Countries['French Guiana'] = 'GF';
|
|
Countries['French Polynesia'] = 'PF';
|
|
Countries['French Southern Territories'] = 'TF';
|
|
Countries['Gabon'] = 'GA';
|
|
Countries['Gambia'] = 'GM';
|
|
Countries['Georgia'] = 'GE';
|
|
Countries['Germany'] = 'DE';
|
|
Countries['Ghana'] = 'GH';
|
|
Countries['Gibraltar'] = 'GI';
|
|
Countries['Greece'] = 'GR';
|
|
Countries['Greenland'] = 'GL';
|
|
Countries['Grenada'] = 'GD';
|
|
Countries['Guadeloupe'] = 'GP';
|
|
Countries['Guam'] = 'GU';
|
|
Countries['Guatemala'] = 'GT';
|
|
Countries['Guinea'] = 'GN';
|
|
Countries['Guinea-Bissau'] = 'GW';
|
|
Countries['Guyana'] = 'GY';
|
|
Countries['Haiti'] = 'HT';
|
|
Countries['Virgin Islands, U.S.'] = 'VI';
|
|
Countries['Honduras'] = 'HN';
|
|
Countries['Hong Kong'] = 'HK';
|
|
Countries['Hungary'] = 'HU';
|
|
Countries['Iceland'] = 'IS';
|
|
Countries['India'] = 'IN';
|
|
Countries['Indonesia'] = 'ID';
|
|
Countries['Wallis and Futuna'] = 'WF';
|
|
Countries['Iraq'] = 'IQ';
|
|
Countries['Ireland'] = 'IE';
|
|
Countries['Israel'] = 'IL';
|
|
Countries['Italy'] = 'IT';
|
|
Countries['Jamaica'] = 'JM';
|
|
Countries['Japan'] = 'JP';
|
|
Countries['Jordan'] = 'JO';
|
|
Countries['Kazakhstan'] = 'KZ';
|
|
Countries['Kenya'] = 'KE';
|
|
Countries['Kiribati'] = 'KI';
|
|
Countries['Kuwait'] = 'KW';
|
|
Countries['Kyrgyzstan'] = 'KG';
|
|
Countries["Lao People's Democratic Republic"] = 'LA';
|
|
Countries['Latvia'] = 'LV';
|
|
Countries['Lebanon'] = 'LB';
|
|
Countries['Lesotho'] = 'LS';
|
|
Countries['Liberia'] = 'LR';
|
|
Countries['Libyan Arab Jamahiriya'] = 'LY';
|
|
Countries['Liechtenstein'] = 'LI';
|
|
Countries['Lithuania'] = 'LT';
|
|
Countries['Luxembourg'] = 'LU';
|
|
Countries['Montserrat'] = 'MS';
|
|
Countries['Macedonia, The Former Yugoslav Republic of'] = 'MK';
|
|
Countries['Madagascar'] = 'MG';
|
|
Countries['Malawi'] = 'MW';
|
|
Countries['Malaysia'] = 'MY';
|
|
Countries['Maldives'] = 'MV';
|
|
Countries['Mali'] = 'ML';
|
|
Countries['Malta'] = 'MT';
|
|
Countries['Marshall Islands'] = 'MH';
|
|
Countries['Martinique'] = 'MQ';
|
|
Countries['Mauritania'] = 'MR';
|
|
Countries['Mauritius'] = 'MU';
|
|
Countries['Mayotte'] = 'YT';
|
|
Countries['Mexico'] = 'MX';
|
|
Countries['Micronesia, Federated States of'] = 'FM';
|
|
Countries['Morocco'] = 'MA';
|
|
Countries['Monaco'] = 'MC';
|
|
Countries['Mongolia'] = 'MN';
|
|
Countries['Mozambique'] = 'MZ';
|
|
Countries['Myanmar'] = 'MM';
|
|
Countries['Namibia'] = 'NA';
|
|
Countries['Nauru'] = 'NR';
|
|
Countries['Nepal'] = 'NP';
|
|
Countries['Netherlands'] = 'NL';
|
|
Countries['Netherlands Antilles'] = 'AN';
|
|
Countries['New Caledonia'] = 'NC';
|
|
Countries['New Zealand'] = 'NZ';
|
|
Countries['Nicaragua'] = 'NI';
|
|
Countries['Niger'] = 'NE';
|
|
Countries['Nigeria'] = 'NG';
|
|
Countries['Niue'] = 'NU';
|
|
Countries['Norfolk Island'] = 'NF';
|
|
Countries['Northern Mariana Islands'] = 'MP';
|
|
Countries['Norway'] = 'NO';
|
|
Countries['Oman'] = 'OM';
|
|
Countries['Pakistan'] = 'PK';
|
|
Countries['Palau'] = 'PW';
|
|
Countries['Panama'] = 'PA';
|
|
Countries['Papua New Guinea'] = 'PG';
|
|
Countries['Paraguay'] = 'PY';
|
|
Countries['Peru'] = 'PE';
|
|
Countries['Philippines'] = 'PH';
|
|
Countries['Pitcairn'] = 'PN';
|
|
Countries['Poland'] = 'PL';
|
|
Countries['Portugal'] = 'PT';
|
|
Countries['Puerto Rico'] = 'PR';
|
|
Countries['Qatar'] = 'QA';
|
|
Countries['Reunion'] = 'RE';
|
|
Countries['Romania'] = 'RO';
|
|
Countries['Russian Federation'] = 'RU';
|
|
Countries['Russia'] = 'RU';
|
|
Countries['Rwanda'] = 'RW';
|
|
Countries['Saint Kitts and Nevis'] = 'KN';
|
|
Countries['Saint Lucia'] = 'LC';
|
|
Countries['Saint Vincent and The Grenadines'] = 'VC';
|
|
Countries['Samoa'] = 'WS';
|
|
Countries['San Marino'] = 'SM';
|
|
Countries['Sao Tome and Principe'] = 'ST';
|
|
Countries['Saudi Arabia'] = 'SA';
|
|
Countries['Senegal'] = 'SN';
|
|
Countries['Seychelles'] = 'SC';
|
|
Countries['Sierra Leone'] = 'SL';
|
|
Countries['Singapore'] = 'SG';
|
|
Countries['Slovenia'] = 'SI';
|
|
Countries['Solomon Islands'] = 'SB';
|
|
Countries['Somalia'] = 'SO';
|
|
Countries['South Africa'] = 'ZA';
|
|
Countries['Spain'] = 'ES';
|
|
Countries['Sri Lanka'] = 'LK';
|
|
Countries['Sudan'] = 'SD';
|
|
Countries['Suriname'] = 'SR';
|
|
Countries['Swaziland'] = 'SZ';
|
|
Countries['Sweden'] = 'SE';
|
|
Countries['Switzerland'] = 'CH';
|
|
Countries['Syrian Arab Republic'] = 'SY';
|
|
Countries['Tajikistan'] = 'TJ';
|
|
Countries['Tanzania, United Republic of'] = 'TZ';
|
|
Countries['Thailand'] = 'TH';
|
|
Countries['Togo'] = 'TG';
|
|
Countries['Tokelau'] = 'TK';
|
|
Countries['Tonga'] = 'TO';
|
|
Countries['Trinidad and Tobago'] = 'TT';
|
|
Countries['Tunisia'] = 'TN';
|
|
Countries['Turkey'] = 'TR';
|
|
Countries['Turkmenistan'] = 'TM';
|
|
Countries['Turks and Caicos Islands'] = 'TC';
|
|
Countries['Tuvalu'] = 'TV';
|
|
Countries['Uganda'] = 'UG';
|
|
Countries['Ukraine'] = 'UA';
|
|
Countries['United Arab Emirates'] = 'AE';
|
|
Countries['UK'] = 'GB';
|
|
Countries['US'] = 'US';
|
|
Countries['United States Minor Outlying Islands'] = 'UM';
|
|
Countries['Uruguay'] = 'UY';
|
|
Countries['Uzbekistan'] = 'UZ';
|
|
Countries['Vanuatu'] = 'VU';
|
|
Countries['Vatican City State (Holy See)'] = 'VA';
|
|
Countries['Venezuela'] = 'VE';
|
|
Countries['Viet Nam'] = 'VN';
|
|
Countries['Western Sahara'] = 'EH';
|
|
Countries['Yemen'] = 'YE';
|
|
Countries['Zambia'] = 'ZM';
|
|
Countries['Zimbabwe'] = 'ZW';
|
|
Countries['Taiwan'] = 'TW';
|
|
Countries['[Worldwide]'] = 'XW';
|
|
Countries['Europe'] = 'XE';
|
|
Countries['Soviet Union (historical, 1922-1991)'] = 'SU';
|
|
Countries['East Germany (historical, 1949-1990)'] = 'XG';
|
|
Countries['Czechoslovakia (historical, 1918-1992)'] = 'XC';
|
|
Countries['Congo, The Democratic Republic of the'] = 'CD';
|
|
Countries['Slovakia'] = 'SK';
|
|
Countries['Bosnia and Herzegovina'] = 'BA';
|
|
Countries["Korea (North), Democratic People's Republic of"] = 'KP';
|
|
Countries['North Korea'] = 'KP';
|
|
Countries['Korea (South), Republic of'] = 'KR';
|
|
Countries['South Korea'] = 'KR';
|
|
Countries['Montenegro'] = 'ME';
|
|
Countries['South Georgia and the South Sandwich Islands'] = 'GS';
|
|
Countries['Palestinian Territory'] = 'PS';
|
|
Countries['Macao'] = 'MO';
|
|
Countries['Timor-Leste'] = 'TL';
|
|
Countries['<85>land Islands'] = 'AX';
|
|
Countries['Guernsey'] = 'GG';
|
|
Countries['Isle of Man'] = 'IM';
|
|
Countries['Jersey'] = 'JE';
|
|
Countries['Serbia'] = 'RS';
|
|
Countries['Saint Barthélemy'] = 'BL';
|
|
Countries['Saint Martin'] = 'MF';
|
|
Countries['Moldova'] = 'MD';
|
|
Countries['Yugoslavia (historical, 1918-2003)'] = 'YU';
|
|
Countries['Serbia and Montenegro (historical, 2003-2006)'] = 'CS';
|
|
Countries["Côte d'Ivoire"] = 'CI';
|
|
Countries['Heard Island and McDonald Islands'] = 'HM';
|
|
Countries['Iran, Islamic Republic of'] = 'IR';
|
|
Countries['Saint Pierre and Miquelon'] = 'PM';
|
|
Countries['Saint Helena'] = 'SH';
|
|
Countries['Svalbard and Jan Mayen'] = 'SJ';
|