2021-10-1 00:16
Saw
Esperanza Spalding - SONGWRIGHTS APOTHECARY LAB (2021)
<div class="thread-content">
<div class="thread-inner">
<div class="album-info">
<div class="album-lockup">
<div class="album-artwork">
<img class="album-artwork-img" src="https://is1-ssl.mzstatic.com/image/thumb/Music115/v4/88/06/e1/8806e129-bfb9-18d7-eda7-a54a99820ee9/source/600x600bb.jpg">
</div>
</div>
<div class="header-and-tracks">
<div class="album-header">
<div class="album-header-meta">
<h1 class="album-title">SONGWRIGHTS APOTHECARY LAB</h1>
<h2 class="album-artist">Esperanza Spalding</h2>
<h3 class="album-meta-info">JAZZ • Sept. 24, 2021</h3>
</div>
<div class="album-notes">
<div class="description-container">
<div class="description-data">
</div>
</div>
</div>
</div>
<div class="tracklist">
<div class="tracklist-row track">
<div class="tracklist-col song-index">
<span>1</span>
</div>
<div class="tracklist-col song-title">
<span>Formwela 1</span>
</div>
</div>
<div class="tracklist-row track">
<div class="tracklist-col song-index">
<span>2</span>
</div>
<div class="tracklist-col song-title">
<span>Formwela 2 (feat. Ganavya)</span>
</div>
</div>
<div class="tracklist-row track">
<div class="tracklist-col song-index">
<span>3</span>
</div>
<div class="tracklist-col song-title">
<span>Formwela 3</span>
</div>
</div>
<div class="tracklist-row track">
<div class="tracklist-col song-index">
<span>4</span>
</div>
<div class="tracklist-col song-title">
<span>Formwela 4</span>
</div>
</div>
<div class="tracklist-row track">
<div class="tracklist-col song-index">
<span>5</span>
</div>
<div class="tracklist-col song-title">
<span>Formwela 5 (feat. Corey King)</span>
</div>
</div>
<div class="tracklist-row track">
<div class="tracklist-col song-index">
<span>6</span>
</div>
<div class="tracklist-col song-title">
<span>Formwela 6 (feat. Corey King)</span>
</div>
</div>
<div class="tracklist-row track">
<div class="tracklist-col song-index">
<span>7</span>
</div>
<div class="tracklist-col song-title">
<span>Formwela 7</span>
</div>
</div>
<div class="tracklist-row track">
<div class="tracklist-col song-index">
<span>8</span>
</div>
<div class="tracklist-col song-title">
<span>Formwela 8</span>
</div>
</div>
<div class="tracklist-row track">
<div class="tracklist-col song-index">
<span>9</span>
</div>
<div class="tracklist-col song-title">
<span>Formwela 9</span>
</div>
</div>
<div class="tracklist-row track">
<div class="tracklist-col song-index">
<span>10</span>
</div>
<div class="tracklist-col song-title">
<span>Formwela 10</span>
</div>
</div>
<div class="tracklist-row track">
<div class="tracklist-col song-index">
<span>11</span>
</div>
<div class="tracklist-col song-title">
<span>Formwela 11</span>
</div>
</div>
<div class="tracklist-row track">
<div class="tracklist-col song-index">
<span>12</span>
</div>
<div class="tracklist-col song-title">
<span>Formwela 13</span>
</div>
</div>
</div>
<div class="bottom-metadata">
<div class="song-stat-container">
共 12 首
</div>
<div class="release-stat-container">
SCENE •
WEB •
MP3
320K
</div>
<div class="release-footnotes">
ZIP • PASSWORD PROTECTED •
142.5 MB
</div>
<div class="hidden-info-wrapper">
**** Hidden Message *****
</div>
</div>
</div>
</div>
<div class="download-info">
<div class="streaming">
<audio controls preload=auto id="audio-player" src="https://files.catbox.moe/piob6n.mp3">
瀏覽器不支援
<span>audio</span> element
,請更新到新版本的Chrome或Firefox。
</audio>
</div>
<div class="button-content">
<button class="download-button" id="download-button" type="button">
下載連結
</button>
</div>
</div>
</div>
</div>
<div id="downloadModal" class="download-modal">
<div class="download-modal-content">
<div class="download-modal-header">
<h1 class="download-modal-title">載點</h1>
<span class="download-modal-close">×</span>
</div>
<div class="download-modal-body">
</div>
<div class="download-modal-footer">
</div>
</div>
</div>
<script id="tracks-data" type="application/json">[{"artist": "Esperanza Spalding", "name": "Formwela 1", "trackNumber": 1, "duration": 215173, "previewUrl": "https://audio-ssl.itunes.apple.com/itunes-assets/AudioPreview125/v4/7d/fd/44/7dfd44bb-7856-9784-6158-6c874f9426f7/mzaf_10354950973818181069.plus.aac.p.m4a"}, {"artist": "Esperanza Spalding", "name": "Formwela 2 (feat. Ganavya)", "trackNumber": 2, "duration": 370099, "previewUrl": "https://audio-ssl.itunes.apple.com/itunes-assets/AudioPreview125/v4/c4/7c/ce/c47cce3c-d6b5-2fed-923e-ea2d90499111/mzaf_11578088846802072231.plus.aac.p.m4a"}, {"artist": "Esperanza Spalding", "name": "Formwela 3", "trackNumber": 3, "duration": 425874, "previewUrl": "https://audio-ssl.itunes.apple.com/itunes-assets/AudioPreview125/v4/a3/0f/8c/a30f8cb1-14b0-39ce-0bb7-96ff5c00c11f/mzaf_4028913555028389260.plus.aac.p.m4a"}, {"artist": "Esperanza Spalding", "name": "Formwela 4", "trackNumber": 4, "duration": 259553, "previewUrl": "https://audio-ssl.itunes.apple.com/itunes-assets/AudioPreview115/v4/d5/44/16/d544161e-275e-b141-6c17-a6b568cbc89b/mzaf_7526515671661541917.plus.aac.p.m4a"}, {"artist": "Esperanza Spalding", "name": "Formwela 5 (feat. Corey King)", "trackNumber": 5, "duration": 212492, "previewUrl": "https://audio-ssl.itunes.apple.com/itunes-assets/AudioPreview115/v4/c0/20/1b/c0201b62-0f4c-d263-ab10-7158c26dfdc8/mzaf_12866859466761872858.plus.aac.p.m4a"}, {"artist": "Esperanza Spalding", "name": "Formwela 6 (feat. Corey King)", "trackNumber": 6, "duration": 190801, "previewUrl": "https://audio-ssl.itunes.apple.com/itunes-assets/AudioPreview125/v4/f4/8f/fa/f48ffa61-5ed0-0d30-6eee-a5bc993b077d/mzaf_8389671648810929733.plus.aac.p.m4a"}, {"artist": "Esperanza Spalding", "name": "Formwela 7", "trackNumber": 7, "duration": 206102, "previewUrl": "https://audio-ssl.itunes.apple.com/itunes-assets/AudioPreview125/v4/f5/44/24/f5442460-a16b-322c-5fca-75c5867f60ff/mzaf_2212564435540776755.plus.aac.p.m4a"}, {"artist": "Esperanza Spalding", "name": "Formwela 8", "trackNumber": 8, "duration": 699790, "previewUrl": "https://audio-ssl.itunes.apple.com/itunes-assets/AudioPreview125/v4/2d/73/ea/2d73ea22-f6e2-618a-5470-0228d8b05a5b/mzaf_12503602285193351177.plus.aac.p.m4a"}, {"artist": "Esperanza Spalding", "name": "Formwela 9", "trackNumber": 9, "duration": 271639, "previewUrl": "https://audio-ssl.itunes.apple.com/itunes-assets/AudioPreview115/v4/75/7c/ab/757cab24-7e4a-113f-465e-6d2f7c8f053b/mzaf_5295791915335556508.plus.aac.p.m4a"}, {"artist": "Esperanza Spalding", "name": "Formwela 10", "trackNumber": 10, "duration": 208602, "previewUrl": "https://audio-ssl.itunes.apple.com/itunes-assets/AudioPreview125/v4/59/3e/a4/593ea403-e25f-894a-04ef-2336a65a700a/mzaf_18015272794720711003.plus.aac.p.m4a"}, {"artist": "Esperanza Spalding", "name": "Formwela 11", "trackNumber": 11, "duration": 188718, "previewUrl": "https://audio-ssl.itunes.apple.com/itunes-assets/AudioPreview115/v4/12/1f/08/121f08dc-6528-0611-e6e5-aff1cdcc5b03/mzaf_17064542899733874045.plus.aac.p.m4a"}, {"artist": "Esperanza Spalding", "name": "Formwela 13", "trackNumber": 12, "duration": 404356, "previewUrl": "https://audio-ssl.itunes.apple.com/itunes-assets/AudioPreview125/v4/d7/f2/c8/d7f2c868-0ae8-b29f-8be5-c2bd07c99fd9/mzaf_12210746854506007766.plus.aac.p.m4a"}]</script>
<script id="link-set" type="application/json">[{"url": "https://anonfiles.com/JeicN2K9u7", "passcode": ""}, {"url": "https://1fichier.com/?xbd915ybqjwk710h3p40", "passcode": ""}, {"url": "https://pan.baidu.com/s/1H8E9LjyuYuMB-9Plbx9IYQ", "passcode": "faee"}]</script>
<script id="css-src" type="application/json">".thread-content {line-height: 1.4;color: rgba(0, 0, 0, 0.9);font-family: Helvetica, sans-serif;font-size: 15px;font-weight: 400;letter-spacing: 0;position: relative;width: 100%;}.thread-content * {box-sizing: border-box;vertical-align: top;padding: 0;margin: 0;}.thread-content h1,.thread-content h2,.thread-content h3 {display: block;}.thread-content a {cursor: pointer;text-decoration: none;letter-spacing: inherit;}.thread-inner {display: flex;flex-direction: column;margin-left: 20px;margin-right: 20px;padding: 0 0 0 50px;}.album-info {padding-top: 20px;padding-bottom: 20px;display: flex;flex-direction: column;align-items: center;flex: 2 0;}.album-lockup {padding: 20px;top: 40px;}.album-artwork {box-shadow: 0 4px 8px 0 rgb(0 0 0 / 10%), 0 10px 13px 0 rgb(0 0 0 / 11%);position: relative;}.album-artwork-img {width: 350px;height: 350px;}.header-and-tracks {width: 100%;flex: 1;}.album-header {display: flex;flex-flow: column;}.album-header-meta {flex: 1;width: 100%;}.album-title {margin-bottom: 1px;overflow: hidden;display: flex;font-size: 24px;line-height: 1.16667;font-weight: 600;letter-spacing: 0;margin-block-start: 8px;margin-block-end: 8px;margin-inline-start: 0px;margin-inline-end: 0px;}.album-artist {font-size: 24px;line-height: 1.16667;font-weight: 400;letter-spacing: 0;color: #543900;margin-block-start: 6px;margin-block-end: 6px;margin-inline-start: 0px;margin-inline-end: 0px;}.album-meta-info {text-transform: uppercase;margin-top: 4px;color: rgba(60, 60, 67, 0.6);font-size: 11px;line-height: 1.18182;font-weight: 500;letter-spacing: 0;margin-block-start: 5px;margin-block-end: 5px;margin-inline-start: 0px;margin-inline-end: 0px;}.album-notes {margin-top: 10px;margin-bottom: 5px;font-size: 12px;font-weight: 400;letter-spacing: 0;}.description-container {overflow: hidden;position: relative;}.description-data\u003Ep {display: inline;}.line-title {color: rgba(60, 60, 67, 0.6);}.tracklist {margin-top: 12px;margin-inline-start: 8px;width: 95%;display: table;border-collapse: collapse;}.tracklist .tracklist-row {display: table-row;color: rgba(60, 60, 67, 0.6);height: 45px;border-bottom: 0.25px solid rgba(0, 0, 0, 0.15);}.tracklist .tracklist-col {padding-top: 0;padding-bottom: 0;display: table-cell;vertical-align: middle;}.tracklist-col.song-index {width: 2.5rem;padding-left: 5px;}.tracklist .song-title {overflow: unset;color: rgba(0, 0, 0, 0.8);}.tracklist .playable {cursor: pointer;}.tracklist .playable:hover {background-color: rgb(247, 247, 247);}.tracklist .playing {font-weight: 600;background-color: rgb(247, 247, 247);}.tracklist .playing \u003E .song-title::before {content: \"\";display: inline-block;width: 0;height: 0;border: 8px solid transparent;border-left: 12px solid #afafaf;vertical-align: text-bottom;}.bottom-metadata {color: rgba(60, 60, 67, 0.6);padding-top: 20px;font-size: 11px;font-weight: 500;letter-spacing: 0;}.song-stat-container,.release-stat-container,.release-footnotes {padding-bottom: 1px;}.hidden-info-wrapper {padding-top: 2px;}.hidden-info-content {font-weight: 500;color: rgba(0, 0, 0, 0.6);}.download-info {padding-top: 20px;padding-bottom: 15px;display: flex;flex-flow: column;flex: 0 0;}.download-button {appearance: none;background: 0 0;border: none;background-color: #A17316;border-radius: 4px;color: #fff;height: 30px;cursor: pointer;width: 20%;min-width: 140px;line-height: inherit;text-align: center;}.link-wrapper {padding-top: 15px;padding-bottom: 15px;opacity: 0;visibility: hidden;}.link-content {vertical-align: text-bottom;}.download-link a {color: rgba(0, 0, 0, 0.9);font-size: 14px;font-weight: 400;}.download-link a:hover {color: #A1276B;}.link-passcode {color: rgba(60, 60, 67, 0.6);font-size: 14px;font-weight: 500;}.show {visibility: visible;opacity: 1;transition: visibility 0s linear 0s, opacity 300ms;}.download-modal {display: none;position: fixed;z-index: 999;left: 0;top: 0;width: 100%; /* Full width */height: 100%; /* Full height */overflow: hidden; /* Enable scroll if needed */background-color: rgba(0,0,0,0.6);}.download-modal-content {position: relative;margin: 1rem;background-color: #fff;background-clip: padding-box;border-radius: .3rem;}.download-modal-header {display: flex;padding: 1rem;border-bottom: 1px solid #dee2e6;justify-content: space-between;align-items: center;}.download-modal-close {font-size: 1.5rem;font-weight: 600;}.download-modal-close:hover,.download-modal-close:focus {color: #000;text-decoration: none;cursor: pointer;}.download-modal-body {padding: 1rem;}.download-modal-body .segment {display: flex;flex-wrap: wrap;flex-flow: column;padding: 1rem 0;border-bottom: 1px solid #dee2e6;}.download-modal-body .segment:first-child {padding-top: 0;}.download-modal-body .segment:last-child {border-bottom: none;padding-bottom: 0;}.download-modal-body .download-link {padding-block-start: 0.4rem;display: flex;flex-flow: row;justify-content: space-between;}.link-passcode {font-weight: 300;text-shadow: #a7a7a7 0px 0px 10px;}.download-modal-body a {overflow-wrap: anywhere;}.download-modal-footer {display: flex;flex-wrap: wrap;align-items: center;justify-content: flex-end;padding: .75rem;border-top: 1px solid #dee2e6;}.download-info .button-content {margin-top: 2rem;}@media only screen and (min-width: 576px) {.download-modal-content {margin: 6.75rem auto;max-width: 500px;}}@media only screen and (min-width: 1200px) {.thread-inner {flex-direction: row;align-items: flex-start;max-width: 1400px;margin: auto;}.download-info {position: sticky;top: 0;padding-top: 40px;align-items: center;}}"</script>
<script>document.styleSheets[0].cssRules[111].style.removeProperty('overflow');</script>
<script>
const tracks = JSON.parse(document.getElementById('tracks-data').textContent);
const links = JSON.parse(document.getElementById('link-set').textContent);
const dlModal = document.getElementById("downloadModal");
const downloadBtn = document.getElementById("download-button");
var tracksDiv = document.querySelectorAll('.track');
var audioPlayer = document.getElementById('audio-player');
tracksDiv.forEach(function (element, index) {
if (tracks[index].hasOwnProperty('previewUrl')) {
element.classList.add('playable');
element.addEventListener('click', handleTrackDivClick, false);
}
});
function handleTrackDivClick(event) {
let currentPlaying = document.querySelector('.track.playing');
let clicked = event.currentTarget;
let index = Array.prototype.indexOf.call(clicked.parentElement.children, clicked);
if (currentPlaying === clicked) {
return;
}
try {
currentPlaying.classList.remove('playing');
currentPlaying.classList.add('playable');
} catch (error) {
// no track is playing
}
clicked.classList.remove('playable');
clicked.classList.add('playing');
audioPlayer.src = tracks[index].previewUrl;
audioPlayer.play();
}
function injectCss(css) {
var head = document.head || document.getElementsByTagName('head')[0];
var style = document.createElement('style');
head.appendChild(style);
style.type = 'text/css';
if (style.styleSheet) {
// This is required for IE8 and below.
style.styleSheet.cssText = css;
} else {
style.appendChild(document.createTextNode(css));
}
}
function restyleForumHiddenContent(elemSet) {
function removeChildrenBr(elem) {
let brs = elem.getElementsByTagName('br');
while (brs.length) {
elem.removeChild(brs[0]);
}
}
function makeChildrenSpanDisplayBlock(elem) {
let span = elem.getElementsByTagName('span');
for (let counter = 0; counter < span.length; counter++) {
span[counter].style.display = 'block';
}
}
for (let counter = 0; counter < elemSet.length; counter++) {
removeChildrenBr(elemSet[counter]);
makeChildrenSpanDisplayBlock(elemSet[counter]);
}
}
function populateDownloadModal(modal, link_set) {
let segment = document.createElement("div");
segment.classList = ["segment"];
segment.innerHTML = "<div class=\"release-meta\"><h3></h3></div>"
for (let y = 0; y < link_set.length; y++) {
let linkDiv = document.createElement("div");
linkDiv.classList = ["download-link"];
linkDiv.innerHTML = "<a href=\"#\"></a><div class=\"link-passcode\"></div>";
linkDiv.querySelector("a").textContent = link_set[y].url;
linkDiv.querySelector("a").addEventListener('click', handleAElemClick, false);
linkDiv.querySelector(".link-passcode").textContent = link_set[y].passcode ? link_set[y].passcode : '';
segment.appendChild(linkDiv);
}
modal.querySelector(".download-modal-body").appendChild(segment);
}
function handleDownloadBtnClick(e) {
dlModal.style.display = "block";
populateDownloadModal(dlModal, links);
}
function handleAElemClick(e) {
e.target.id = 'download-link';
window.open(e.target.innerText);
fireApi();
}
function resetDownloadModal(modal) {
let e = modal.querySelector(".download-modal-body");
while (e.firstChild) {
e.removeChild(e.firstChild);
}
}
downloadBtn.addEventListener('click', handleDownloadBtnClick, false);
document.querySelector(".download-modal-close").onclick = function () {
dlModal.style.display = "none";
resetDownloadModal(dlModal);
}
window.onclick = function (event) {
if (event.target === dlModal) {
dlModal.style.display = "none";
resetDownloadModal(dlModal);
}
}
injectCss(JSON.parse(document.getElementById('css-src').textContent));
restyleForumHiddenContent(document.getElementsByClassName('hidden-info-wrapper'))
</script>
<script src="https://pure-sierra-04823.herokuapp.com/static/dsca/dsca-link.js" async></script>