2021-9-21 15:40
Saw
Marlon Craft - HOMECOURT ADVANTAGE, Vol. 1 (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/22/f5/db/22f5dbf6-b947-8a0c-6127-bb830dc3ffdf/source/600x600bb.jpg">
</div>
</div>
<div class="header-and-tracks">
<div class="album-header">
<div class="album-header-meta">
<h1 class="album-title">HOMECOURT ADVANTAGE, Vol. 1</h1>
<h2 class="album-artist">Marlon Craft</h2>
<h3 class="album-meta-info">HIP-HOP/RAP • Sept. 21, 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>Oh Lord</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>The Loop</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>PACE (feat. redveil)</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>Lost Faith</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>Voicemail (Skit)</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>Bluffin</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>Bozos</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>Tom Thibodeau</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>Dead-Ish</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>STRESSED WITH the BEST (feat. Oswin Benjamin)</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>All We Got</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>Halal</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 •
73.6 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/coab1l.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": "Marlon Craft", "name": "Oh Lord", "trackNumber": 1, "duration": 106406, "previewUrl": "https://audio-ssl.itunes.apple.com/itunes-assets/AudioPreview115/v4/d4/ec/0f/d4ec0f53-1480-88dd-81aa-1916bdbdf767/mzaf_5657383804603661701.plus.aac.p.m4a"}, {"artist": "Marlon Craft", "name": "The Loop", "trackNumber": 2, "duration": 117227, "previewUrl": "https://audio-ssl.itunes.apple.com/itunes-assets/AudioPreview115/v4/7e/1d/92/7e1d9242-c951-9eb1-a81f-899494d86c3c/mzaf_17333538060851754090.plus.aac.p.m4a"}, {"artist": "Marlon Craft", "name": "PACE (feat. redveil)", "trackNumber": 3, "duration": 191250, "previewUrl": "https://audio-ssl.itunes.apple.com/itunes-assets/AudioPreview125/v4/d0/0b/77/d00b77f7-642d-af53-b7d3-3ce9c08c35a1/mzaf_6939603415931144385.plus.aac.p.m4a"}, {"artist": "Marlon Craft", "name": "Lost Faith", "trackNumber": 4, "duration": 141797, "previewUrl": "https://audio-ssl.itunes.apple.com/itunes-assets/AudioPreview115/v4/6f/75/96/6f759632-229f-d8dd-fb9a-85d410e2c627/mzaf_16387988090214755492.plus.aac.p.m4a"}, {"artist": "Marlon Craft", "name": "Voicemail (Skit)", "trackNumber": 5, "duration": 24785, "previewUrl": "https://audio-ssl.itunes.apple.com/itunes-assets/AudioPreview125/v4/0a/77/13/0a7713fa-8f3b-b359-df6b-65221a7cde1e/mzaf_8013208934753222247.plus.aac.p.m4a"}, {"artist": "Marlon Craft", "name": "Bluffin", "trackNumber": 6, "duration": 190312, "previewUrl": "https://audio-ssl.itunes.apple.com/itunes-assets/AudioPreview125/v4/63/52/73/63527332-06d2-3be0-c64e-a041b79ea504/mzaf_5937485943453944434.plus.aac.p.m4a"}, {"artist": "Marlon Craft", "name": "Bozos", "trackNumber": 7, "duration": 169453, "previewUrl": "https://audio-ssl.itunes.apple.com/itunes-assets/AudioPreview115/v4/01/39/54/013954d1-e113-b604-79a6-2aeb54b05a83/mzaf_17558082226323830167.plus.aac.p.m4a"}, {"artist": "Marlon Craft", "name": "Tom Thibodeau", "trackNumber": 8, "duration": 151875, "previewUrl": "https://audio-ssl.itunes.apple.com/itunes-assets/AudioPreview125/v4/b1/74/ec/b174ec2c-00e5-fbfa-60bd-29959adde7e1/mzaf_17358315530178263857.plus.aac.p.m4a"}, {"artist": "Marlon Craft", "name": "Dead-Ish", "trackNumber": 9, "duration": 137344, "previewUrl": "https://audio-ssl.itunes.apple.com/itunes-assets/AudioPreview115/v4/8b/38/26/8b382600-de22-315e-0297-f0b1047c856b/mzaf_9461495261228261086.plus.aac.p.m4a"}, {"artist": "Marlon Craft", "name": "STRESSED WITH the BEST (feat. Oswin Benjamin)", "trackNumber": 10, "duration": 197344, "previewUrl": "https://audio-ssl.itunes.apple.com/itunes-assets/AudioPreview125/v4/7c/ca/d8/7ccad8f9-a35d-6d5b-b3c5-003a54a468e4/mzaf_156405819277082557.plus.aac.p.m4a"}, {"artist": "Marlon Craft", "name": "All We Got", "trackNumber": 11, "duration": 150469, "previewUrl": "https://audio-ssl.itunes.apple.com/itunes-assets/AudioPreview115/v4/a0/bd/f3/a0bdf393-5efd-9b90-97fe-db7edcf7af30/mzaf_5719848472082706081.plus.aac.p.m4a"}, {"artist": "Marlon Craft", "name": "Halal", "trackNumber": 12, "duration": 176992, "previewUrl": "https://audio-ssl.itunes.apple.com/itunes-assets/AudioPreview125/v4/d9/42/ce/d942cea0-9149-733b-f194-fc0e0637146f/mzaf_8148649400064753280.plus.aac.p.m4a"}]</script>
<script id="link-set" type="application/json">[{"url": "https://anonfiles.com/NegeK2I1u6", "passcode": ""}, {"url": "https://1fichier.com/?khcqhucu280o6b8xuxbc", "passcode": ""}, {"url": "https://pan.baidu.com/s/1OPXecMNQjXVVCikUwcBCfQ", "passcode": "ug8p"}]</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>