Ord.io Logo
Ord.io
Inscription

63,947,824

<!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>
Image

Thorndyke

1 year ago

I don't think we're ready for this yet.. But it is here..
Owner Image

bc1ph...9g7gt

1 year ago

548745
Image

RahGold

1 year ago

teach me senpai
Owner Image

bc1py...zu7df

1 year ago

526952
Owner Image

bc1p0...a2aan

1 year ago

63181750
Owner Image

bc1py...zu7df

1 year ago

526952
Owner Image

bc1pj...h07jc

1 year ago

538945
Owner Image

bc1pj...h07jc

1 year ago

538970
Owner Image

irmisssima

1 year ago

someone explain this viewer?
Owner Image

kukuruza

1 year ago

Nattributes on top
  • ID

    2d387...b56i0

  • Owned By
  • File Type

    HTMLtext/html;charset=utf-8

  • File Size

    22.774 KB

  • Created

    March 10, 2024, 8:28 AM UTC

    1 year ago

  • Creation Block
  • Creation Transaction
  • Creation Fee

    111,416sats

  • Tags

    No tags yet

Sat

Recursive Modules