<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Nattribute DMT Viewer</title>
<style>
body {
font-family: sans-serif;
background-color: #fdf6e4;
/* Cream color */
color: #333;
text-align: center;
margin: 0;
padding: 40px 0;
position: relative;
/* Needed to position svgContainer absolutely */
}
h1 {
color: #2c3e50;
font-weight: 600;
margin-bottom: 20px;
}
#dmtForm {
padding: 20px 40px;
border-radius: 10px;
display: inline-block;
margin-bottom: 40px;
position: relative;
/* Ensures that the z-index is applied correctly */
z-index: 10;
/* Ensures form is above the overlaid image */
}
#dmtForm input[type="number"],
#dmtForm button {
width: 100%;
padding: 10px 15px;
margin-bottom: 20px;
border-radius: 5px;
border: 1px solid #bdc3c7;
font-size: 16px;
}
#dmtForm button {
background-color: #0b2531;
/* Dark color */
color: white;
border: none;
font-weight: 600;
cursor: pointer;
transition: background-color 0.3s ease;
position: relative;
/* For z-index */
z-index: 10;
/* Ensures button is above the overlaid image */
}
#dmtForm button:hover {
background-color: #34495e;
}
#svgContainer {
position: fixed;
top: 0;
left: 0;
width: 100vw;
height: 100vh;
display: flex;
justify-content: center;
align-items: center;
}
#svgContainer img {
width: 80%;
/* Change from 100% to 80% */
height: 80%;
/* Adjust height automatically to maintain the aspect ratio */
max-width: 100%;
/* Ensure the image does not exceed the screen width */
max-height: 100%;
/* Ensure the image does not exceed the screen height */
object-fit: contain;
/* This will ensure that the SVG fits nicely within the space, maintaining aspect ratio */
position: absolute;
top: 50%;
left: 50%;
transform: translate(-50%, -50%);
}
/* Additional styles */
.additional-text {
position: relative;
/* For z-index */
z-index: 10;
/* Ensures text is above the overlaid image */
color: #333;
font-size: 14px;
margin-top: 10px;
}
</style>
</head>
<body>
<img src="" alt="Logo" style="max-width: 100%; height: auto;">
<h1>Onchain Viewer</h1>
<form id="dmtForm">
<input type="number" id="numberInput" placeholder="Enter Nattribute Number" required>
<button type="button" id="generateButton">View DMT</button>
<p class="additional-text">Welcome to the DMT Nattribute Onchain NAT Viewer. Simple circles with deeper meaning. This Onchain Art Viewer will display your Nattribute, just enter your valid Nattribute number and we will draw your Nattribute using Digital Matter from data inscribed on Bitcoin. This is just a canvas, a starting point for something greater than any one of us. Long Live Art. Long Live Bitcoin.</p>
</form>
<div id="svgContainer"></div>
<script>
const inscriptiondata = {
"background": {
"background": "d52ccf01aa03a83d557489d2afb625a9179036b04fb9f83345b2ba0b5e063bb1i0"
},
"bottomleft": {
"9": "d52ccf01aa03a83d557489d2afb625a9179036b04fb9f83345b2ba0b5e063bb1i9",
"0": "d52ccf01aa03a83d557489d2afb625a9179036b04fb9f83345b2ba0b5e063bb1i1",
"7": "d52ccf01aa03a83d557489d2afb625a9179036b04fb9f83345b2ba0b5e063bb1i7",
"6": "d52ccf01aa03a83d557489d2afb625a9179036b04fb9f83345b2ba0b5e063bb1i6",
"5": "d52ccf01aa03a83d557489d2afb625a9179036b04fb9f83345b2ba0b5e063bb1i5",
"4": "d52ccf01aa03a83d557489d2afb625a9179036b04fb9f83345b2ba0b5e063bb1i4",
"3": "d52ccf01aa03a83d557489d2afb625a9179036b04fb9f83345b2ba0b5e063bb1i3",
"1": "d52ccf01aa03a83d557489d2afb625a9179036b04fb9f83345b2ba0b5e063bb1i2",
"8": "d52ccf01aa03a83d557489d2afb625a9179036b04fb9f83345b2ba0b5e063bb1i8",
"2": "5f3d181cbd6fc8926113ce3324902f2efe902c91cbc340eb880546376527e598i0"
},
"bottomleftsmall": {
"9": "d52ccf01aa03a83d557489d2afb625a9179036b04fb9f83345b2ba0b5e063bb1i17",
"0": "d52ccf01aa03a83d557489d2afb625a9179036b04fb9f83345b2ba0b5e063bb1i10",
"6": "d52ccf01aa03a83d557489d2afb625a9179036b04fb9f83345b2ba0b5e063bb1i15",
"5": "d52ccf01aa03a83d557489d2afb625a9179036b04fb9f83345b2ba0b5e063bb1i14",
"4": "d52ccf01aa03a83d557489d2afb625a9179036b04fb9f83345b2ba0b5e063bb1i13",
"3": "d52ccf01aa03a83d557489d2afb625a9179036b04fb9f83345b2ba0b5e063bb1i12",
"1": "d52ccf01aa03a83d557489d2afb625a9179036b04fb9f83345b2ba0b5e063bb1i11",
"8": "d52ccf01aa03a83d557489d2afb625a9179036b04fb9f83345b2ba0b5e063bb1i16",
"2": "5f3d181cbd6fc8926113ce3324902f2efe902c91cbc340eb880546376527e598i0"
},
"bottommiddle": {
"13": "d52ccf01aa03a83d557489d2afb625a9179036b04fb9f83345b2ba0b5e063bb1i20",
"15": "d52ccf01aa03a83d557489d2afb625a9179036b04fb9f83345b2ba0b5e063bb1i22",
"14": "d52ccf01aa03a83d557489d2afb625a9179036b04fb9f83345b2ba0b5e063bb1i21",
"12": "d52ccf01aa03a83d557489d2afb625a9179036b04fb9f83345b2ba0b5e063bb1i19",
"11": "d52ccf01aa03a83d557489d2afb625a9179036b04fb9f83345b2ba0b5e063bb1i18",
"16": "d52ccf01aa03a83d557489d2afb625a9179036b04fb9f83345b2ba0b5e063bb1i23"
},
"bottomright": {
"9": "d52ccf01aa03a83d557489d2afb625a9179036b04fb9f83345b2ba0b5e063bb1i32",
"0": "d52ccf01aa03a83d557489d2afb625a9179036b04fb9f83345b2ba0b5e063bb1i24",
"7": "d52ccf01aa03a83d557489d2afb625a9179036b04fb9f83345b2ba0b5e063bb1i30",
"6": "d52ccf01aa03a83d557489d2afb625a9179036b04fb9f83345b2ba0b5e063bb1i29",
"5": "d52ccf01aa03a83d557489d2afb625a9179036b04fb9f83345b2ba0b5e063bb1i28",
"4": "d52ccf01aa03a83d557489d2afb625a9179036b04fb9f83345b2ba0b5e063bb1i27",
"3": "d52ccf01aa03a83d557489d2afb625a9179036b04fb9f83345b2ba0b5e063bb1i26",
"1": "d52ccf01aa03a83d557489d2afb625a9179036b04fb9f83345b2ba0b5e063bb1i25",
"8": "d52ccf01aa03a83d557489d2afb625a9179036b04fb9f83345b2ba0b5e063bb1i31",
"2": "5f3d181cbd6fc8926113ce3324902f2efe902c91cbc340eb880546376527e598i0"
},
"bottomrightsmall": {
"9": "d52ccf01aa03a83d557489d2afb625a9179036b04fb9f83345b2ba0b5e063bb1i40",
"0": "d52ccf01aa03a83d557489d2afb625a9179036b04fb9f83345b2ba0b5e063bb1i33",
"6": "d52ccf01aa03a83d557489d2afb625a9179036b04fb9f83345b2ba0b5e063bb1i38",
"5": "d52ccf01aa03a83d557489d2afb625a9179036b04fb9f83345b2ba0b5e063bb1i37",
"4": "d52ccf01aa03a83d557489d2afb625a9179036b04fb9f83345b2ba0b5e063bb1i36",
"3": "d52ccf01aa03a83d557489d2afb625a9179036b04fb9f83345b2ba0b5e063bb1i35",
"1": "d52ccf01aa03a83d557489d2afb625a9179036b04fb9f83345b2ba0b5e063bb1i34",
"8": "d52ccf01aa03a83d557489d2afb625a9179036b04fb9f83345b2ba0b5e063bb1i39",
"2": "5f3d181cbd6fc8926113ce3324902f2efe902c91cbc340eb880546376527e598i0"
},
"face": {
"9": "d52ccf01aa03a83d557489d2afb625a9179036b04fb9f83345b2ba0b5e063bb1i50",
"0": "d52ccf01aa03a83d557489d2afb625a9179036b04fb9f83345b2ba0b5e063bb1i41",
"7": "d52ccf01aa03a83d557489d2afb625a9179036b04fb9f83345b2ba0b5e063bb1i48",
"6": "d52ccf01aa03a83d557489d2afb625a9179036b04fb9f83345b2ba0b5e063bb1i47",
"5": "d52ccf01aa03a83d557489d2afb625a9179036b04fb9f83345b2ba0b5e063bb1i46",
"4": "d52ccf01aa03a83d557489d2afb625a9179036b04fb9f83345b2ba0b5e063bb1i45",
"3": "d52ccf01aa03a83d557489d2afb625a9179036b04fb9f83345b2ba0b5e063bb1i44",
"1": "d52ccf01aa03a83d557489d2afb625a9179036b04fb9f83345b2ba0b5e063bb1i42",
"8": "d52ccf01aa03a83d557489d2afb625a9179036b04fb9f83345b2ba0b5e063bb1i49",
"2": "d52ccf01aa03a83d557489d2afb625a9179036b04fb9f83345b2ba0b5e063bb1i43"
},
"lefteye": {
"lefteye": "d52ccf01aa03a83d557489d2afb625a9179036b04fb9f83345b2ba0b5e063bb1i51"
},
"righteye": {
"righteye": "3bb7548aed13e802133ca01e6311ef76758a162b63b12a2857cbf2f48a0bcb9ei5"
},
"nose": {
"nose": "3bb7548aed13e802133ca01e6311ef76758a162b63b12a2857cbf2f48a0bcb9ei4"
},
"middleleft": {
"9": "d52ccf01aa03a83d557489d2afb625a9179036b04fb9f83345b2ba0b5e063bb1i59",
"0": "d52ccf01aa03a83d557489d2afb625a9179036b04fb9f83345b2ba0b5e063bb1i52",
"6": "d52ccf01aa03a83d557489d2afb625a9179036b04fb9f83345b2ba0b5e063bb1i57",
"5": "d52ccf01aa03a83d557489d2afb625a9179036b04fb9f83345b2ba0b5e063bb1i56",
"4": "d52ccf01aa03a83d557489d2afb625a9179036b04fb9f83345b2ba0b5e063bb1i55",
"3": "d52ccf01aa03a83d557489d2afb625a9179036b04fb9f83345b2ba0b5e063bb1i54",
"1": "d52ccf01aa03a83d557489d2afb625a9179036b04fb9f83345b2ba0b5e063bb1i53",
"8": "d52ccf01aa03a83d557489d2afb625a9179036b04fb9f83345b2ba0b5e063bb1i58"
},
"middleright": {
"9": "3bb7548aed13e802133ca01e6311ef76758a162b63b12a2857cbf2f48a0bcb9ei3",
"0": "d52ccf01aa03a83d557489d2afb625a9179036b04fb9f83345b2ba0b5e063bb1i60",
"6": "3bb7548aed13e802133ca01e6311ef76758a162b63b12a2857cbf2f48a0bcb9ei1",
"5": "3bb7548aed13e802133ca01e6311ef76758a162b63b12a2857cbf2f48a0bcb9ei0",
"4": "d52ccf01aa03a83d557489d2afb625a9179036b04fb9f83345b2ba0b5e063bb1i63",
"3": "d52ccf01aa03a83d557489d2afb625a9179036b04fb9f83345b2ba0b5e063bb1i62",
"1": "d52ccf01aa03a83d557489d2afb625a9179036b04fb9f83345b2ba0b5e063bb1i61",
"8": "3bb7548aed13e802133ca01e6311ef76758a162b63b12a2857cbf2f48a0bcb9ei2"
},
"SPECIAL": {
"aiblocks": "3bb7548aed13e802133ca01e6311ef76758a162b63b12a2857cbf2f48a0bcb9ei6",
"btclogo": "3bb7548aed13e802133ca01e6311ef76758a162b63b12a2857cbf2f48a0bcb9ei7"
},
"topleft": {
"9": "3bb7548aed13e802133ca01e6311ef76758a162b63b12a2857cbf2f48a0bcb9ei16",
"0": "3bb7548aed13e802133ca01e6311ef76758a162b63b12a2857cbf2f48a0bcb9ei8",
"7": "3bb7548aed13e802133ca01e6311ef76758a162b63b12a2857cbf2f48a0bcb9ei14",
"6": "3bb7548aed13e802133ca01e6311ef76758a162b63b12a2857cbf2f48a0bcb9ei13",
"5": "3bb7548aed13e802133ca01e6311ef76758a162b63b12a2857cbf2f48a0bcb9ei12",
"4": "3bb7548aed13e802133ca01e6311ef76758a162b63b12a2857cbf2f48a0bcb9ei11",
"3": "3bb7548aed13e802133ca01e6311ef76758a162b63b12a2857cbf2f48a0bcb9ei10",
"1": "3bb7548aed13e802133ca01e6311ef76758a162b63b12a2857cbf2f48a0bcb9ei9",
"8": "3bb7548aed13e802133ca01e6311ef76758a162b63b12a2857cbf2f48a0bcb9ei15"
},
"topmiddle": {
"9": "3bb7548aed13e802133ca01e6311ef76758a162b63b12a2857cbf2f48a0bcb9ei25",
"0": "3bb7548aed13e802133ca01e6311ef76758a162b63b12a2857cbf2f48a0bcb9ei17",
"7": "3bb7548aed13e802133ca01e6311ef76758a162b63b12a2857cbf2f48a0bcb9ei23",
"6": "3bb7548aed13e802133ca01e6311ef76758a162b63b12a2857cbf2f48a0bcb9ei22",
"5": "3bb7548aed13e802133ca01e6311ef76758a162b63b12a2857cbf2f48a0bcb9ei21",
"4": "3bb7548aed13e802133ca01e6311ef76758a162b63b12a2857cbf2f48a0bcb9ei20",
"3": "3bb7548aed13e802133ca01e6311ef76758a162b63b12a2857cbf2f48a0bcb9ei19",
"1": "3bb7548aed13e802133ca01e6311ef76758a162b63b12a2857cbf2f48a0bcb9ei18",
"8": "3bb7548aed13e802133ca01e6311ef76758a162b63b12a2857cbf2f48a0bcb9ei24"
},
"topright": {
"9": "3bb7548aed13e802133ca01e6311ef76758a162b63b12a2857cbf2f48a0bcb9ei34",
"0": "3bb7548aed13e802133ca01e6311ef76758a162b63b12a2857cbf2f48a0bcb9ei26",
"7": "3bb7548aed13e802133ca01e6311ef76758a162b63b12a2857cbf2f48a0bcb9ei32",
"6": "3bb7548aed13e802133ca01e6311ef76758a162b63b12a2857cbf2f48a0bcb9ei31",
"5": "3bb7548aed13e802133ca01e6311ef76758a162b63b12a2857cbf2f48a0bcb9ei30",
"4": "3bb7548aed13e802133ca01e6311ef76758a162b63b12a2857cbf2f48a0bcb9ei29",
"3": "3bb7548aed13e802133ca01e6311ef76758a162b63b12a2857cbf2f48a0bcb9ei28",
"1": "3bb7548aed13e802133ca01e6311ef76758a162b63b12a2857cbf2f48a0bcb9ei27",
"8": "3bb7548aed13e802133ca01e6311ef76758a162b63b12a2857cbf2f48a0bcb9ei33"
}
}
function isNumberInRange(number) {
let ranges = [
"110880-112895",
"249984-251999",
"455616-457631",
"538272-540287",
"548352-550367"
];
for (let range of ranges) {
let [start, end] = range.split('-').map(Number);
if (number >= start && number <= end) {
return true;
}
}
return false;
}
function hideUI() {
// Hide form, title, and additional text
document.getElementById('dmtForm').style.display = 'none';
document.querySelector('h1').style.display = 'none';
document.querySelectorAll('.additional-text').forEach(element => {
element.style.display = 'none';
});
// Make the SVG container fullscreen and adjust styling for proper image fitting
document.getElementById('svgContainer').style.position = 'fixed';
document.getElementById('svgContainer').style.width = '100vw';
document.getElementById('svgContainer').style.height = '100vh';
document.getElementById('svgContainer').style.top = '0';
document.getElementById('svgContainer').style.left = '0';
document.getElementById('svgContainer').style.margin = '0';
document.getElementById('svgContainer').style.padding = '0';
document.getElementById('svgContainer').style.zIndex = '9999';
}
document.getElementById('generateButton').addEventListener('click', function(event) {
event.preventDefault();
const inputNumber = document.getElementById('numberInput').value;
if (isNumberInRange(parseInt(inputNumber))) {
clearSvgContainer();
generateDMT(inputNumber);
hideUI()
document.getElementById('warning').innerHTML = ''
} else {
document.getElementById('warning').innerHTML = 'Please enter a valid 6-digit number.'
}
});
function generateDMT(sixDigitNumber) {
const baseUrl = '';
let allSvgPaths = [
'background/background',
'lefteye/lefteye',
'righteye/righteye',
'nose/nose'
];
addSpecialAndDivisibleLayers(sixDigitNumber, allSvgPaths);
addDigitSpecificLayers(sixDigitNumber, allSvgPaths);
renderSvgLayers(allSvgPaths, baseUrl);
}
function addSpecialAndDivisibleLayers(sixDigitNumber, allSvgPaths) {
if (sixDigitNumber.includes("4849") || sixDigitNumber.includes("3839") || sixDigitNumber.includes("0150")) {
allSvgPaths.push('SPECIAL/btclogo');
} else if (sixDigitNumber.includes("8500")) { // Check for "8500" for aiblocks
allSvgPaths.push('SPECIAL/aiblocks');
}
const ranges = [{
min: 540367,
max: 548352,
file: '11'
},
{
max: 457631,
min: 455616,
file: '13'
},
{
max: 251999,
min: 249984,
file: '14'
},
{
max: 112895,
min: 110880,
file: '15'
}
];
const numberValue = parseInt(sixDigitNumber, 10);
const divisors = [{
value: 42,
folders: ['middleleft', 'middleright', 'bottomleft', 'bottomright', 'bottomleftsmall', 'bottomrightsmall']
},
{
value: 21,
folders: ['bottomleft', 'bottomright', 'bottomleftsmall', 'bottomrightsmall']
},
{
value: 15,
folders: ['middleleft', 'middleright', 'bottomleft']
},
{
value: 14,
folders: ['bottomleftsmall', 'bottomrightsmall', 'middleleft', 'middleright']
},
{
value: 13,
folders: ['bottomleftsmall', 'bottomrightsmall']
},
{
value: 10,
folders: ['middleleft', 'middleright', 'bottomright']
},
{
value: 6,
folders: ['middleleft', 'middleright', 'bottomleft', 'bottomright']
},
{
value: 3,
folders: ['bottomleft', 'bottomright']
},
{
value: 2,
folders: ['middleleft', 'middleright']
}
];
for (const divisor of divisors) {
if (numberValue % divisor.value === 0) {
divisor.folders.forEach(folder => {
const lastDigit = (Math.floor(numberValue / divisor.value) % 10).toString();
if (!['middleleft', 'middleright'].includes(folder) || (['middleleft', 'middleright'].includes(folder) && lastDigit !== '2')) {
allSvgPaths.push(`${folder}/${lastDigit}`); // Corrected line
}
});
break;
}
}
let bottomMiddleFile = '';
for (const range of ranges) {
if (numberValue >= range.min && numberValue <= range.max) {
bottomMiddleFile = `bottommiddle/${range.file}`; // Corrected line
break;
}
}
if (bottomMiddleFile) {
allSvgPaths.push(bottomMiddleFile);
}
}
function addDigitSpecificLayers(sixDigitNumber, allSvgPaths) {
const digits = sixDigitNumber.toString().split('');
const folders = ['topmiddle', 'face', 'topright', 'topleft', 'bottomright', 'bottomleft'];
digits.forEach((digit, index) => {
const path = `${folders[index]}/${digit}`; // Corrected line
if (!path.endsWith('2')) {
allSvgPaths.push(path);
}
});
}
function renderSvgLayers(allSvgPaths) {
allSvgPaths.forEach(path => {
const [folder, file] = path.split('/');
const fileKey = file;
const imgElement = document.createElement('img');
if (inscriptiondata[folder] && inscriptiondata[folder][fileKey]) {
const inscriptionId = inscriptiondata[folder][fileKey];
imgElement.src = `/content/${inscriptionId}`; // Corrected line
} else {
console.error('No inscription data for:', path);
return;
}
document.getElementById('svgContainer').appendChild(imgElement);
});
}
function clearSvgContainer() {
document.getElementById('svgContainer').innerHTML = '';
}
</script>
</body>
</html>
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago