<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>OCM Ordinals</title>
<style>
#t {
display: none;
}
#ui {
margin: 8px;
}
body {
margin: 0;
}
</style>
</head>
<body>
<div id="t">
<button onclick="previousTokenID();">Prev</button>
<input type="text" id="tokenID" value="1" placeholder="0003" oninput="writeSVG(Number(document.getElementById('tokenID').value))" />
<button onclick="nextTokenID();">Next</button>
</div>
<div id="m"></div>
<script type="text/javascript">
! function() {
"use strict";
function t(t, e, r) {
this.blocks = [], this.s = [], this.padding = e, this.outputBits = r, this.reset = !0, this.finalized = !1, this.block = 0, this.start = 0, this.blockCount = 1600 - (t << 1) >> 5, this.byteCount = this.blockCount << 2, this.outputBlocks = r >> 5, this.extraBytes = (31 & r) >> 3;
for (var n = 0; n < 50; ++n) this.s[n] = 0
}
function e(e, r, n) {
t.call(this, e, r, n)
}
var r = "input is invalid type",
n = "object" == typeof window,
i = n ? window : {};
i.JS_SHA3_NO_WINDOW && (n = !1);
var o = !n && "object" == typeof self;
!i.JS_SHA3_NO_NODE_JS && "object" == typeof process && process.versions && process.versions.node ? i = global : o && (i = self);
var a = !i.JS_SHA3_NO_COMMON_JS && "object" == typeof module && module.exports,
s = "function" == typeof define && define.amd,
u = !i.JS_SHA3_NO_ARRAY_BUFFER && "undefined" != typeof ArrayBuffer,
f = "0123456789abcdef".split(""),
c = [4, 1024, 262144, 67108864],
h = [0, 8, 16, 24],
p = [1, 0, 32898, 0, 32906, 2147483648, 2147516416, 2147483648, 32907, 0, 2147483649, 0, 2147516545, 2147483648, 32777, 2147483648, 138, 0, 136, 0, 2147516425, 0, 2147483658, 0, 2147516555, 0, 139, 2147483648, 32905, 2147483648, 32771, 2147483648, 32770, 2147483648, 128, 2147483648, 32778, 0, 2147483658, 2147483648, 2147516545, 2147483648, 32896, 2147483648, 2147483649, 0, 2147516424, 2147483648],
d = [224, 256, 384, 512],
l = [128, 256],
y = ["hex", "buffer", "arrayBuffer", "array", "digest"],
b = {
128: 168,
256: 136
};
!i.JS_SHA3_NO_NODE_JS && Array.isArray || (Array.isArray = function(t) {
return "[object Array]" === Object.prototype.toString.call(t)
}), !u || !i.JS_SHA3_NO_ARRAY_BUFFER_IS_VIEW && ArrayBuffer.isView || (ArrayBuffer.isView = function(t) {
return "object" == typeof t && t.buffer && t.buffer.constructor === ArrayBuffer
});
for (var A = function(e, r, n) {
return function(i) {
return new t(e, r, e).update(i)[n]()
}
}, w = function(e, r, n) {
return function(i, o) {
return new t(e, r, o).update(i)[n]()
}
}, v = function(t, e, r) {
return function(e, n, i, o) {
return S["cshake" + t].update(e, n, i, o)[r]()
}
}, B = function(t, e, r) {
return function(e, n, i, o) {
return S["kmac" + t].update(e, n, i, o)[r]()
}
}, g = function(t, e, r, n) {
for (var i = 0; i < y.length; ++i) {
var o = y[i];
t[o] = e(r, n, o)
}
return t
}, _ = function(e, r) {
var n = A(e, r, "hex");
return n.create = function() {
return new t(e, r, e)
}, n.update = function(t) {
return n.create().update(t)
}, g(n, A, e, r)
}, k = [{
name: "keccak",
padding: [1, 256, 65536, 16777216],
bits: d,
createMethod: _
}, {
name: "sha3",
padding: [6, 1536, 393216, 100663296],
bits: d,
createMethod: _
}, {
name: "shake",
padding: [31, 7936, 2031616, 520093696],
bits: l,
createMethod: function(e, r) {
var n = w(e, r, "hex");
return n.create = function(n) {
return new t(e, r, n)
}, n.update = function(t, e) {
return n.create(e).update(t)
}, g(n, w, e, r)
}
}, {
name: "cshake",
padding: c,
bits: l,
createMethod: function(e, r) {
var n = b[e],
i = v(e, 0, "hex");
return i.create = function(i, o, a) {
return o || a ? new t(e, r, i).bytepad([o, a], n) : S["shake" + e].create(i)
}, i.update = function(t, e, r, n) {
return i.create(e, r, n).update(t)
}, g(i, v, e, r)
}
}, {
name: "kmac",
padding: c,
bits: l,
createMethod: function(t, r) {
var n = b[t],
i = B(t, 0, "hex");
return i.create = function(i, o, a) {
return new e(t, r, o).bytepad(["KMAC", a], n).bytepad([i], n)
}, i.update = function(t, e, r, n) {
return i.create(t, r, n).update(e)
}, g(i, B, t, r)
}
}], S = {}, C = [], x = 0; x < k.length; ++x)
for (var m = k[x], E = m.bits, O = 0; O < E.length; ++O) {
var z = m.name + "_" + E[O];
if (C.push(z), S[z] = m.createMethod(E[O], m.padding), "sha3" !== m.name) {
var N = m.name + E[O];
C.push(N), S[N] = S[z]
}
}
t.prototype.update = function(t) {
if (this.finalized) throw new Error("finalize already called");
var e, n = typeof t;
if ("string" !== n) {
if ("object" !== n) throw new Error(r);
if (null === t) throw new Error(r);
if (u && t.constructor === ArrayBuffer) t = new Uint8Array(t);
else if (!(Array.isArray(t) || u && ArrayBuffer.isView(t))) throw new Error(r);
e = !0
}
for (var i, o, a = this.blocks, s = this.byteCount, f = t.length, c = this.blockCount, p = 0, d = this.s; p < f;) {
if (this.reset)
for (this.reset = !1, a[0] = this.block, i = 1; i < c + 1; ++i) a[i] = 0;
if (e)
for (i = this.start; p < f && i < s; ++p) a[i >> 2] |= t[p] << h[3 & i++];
else
for (i = this.start; p < f && i < s; ++p)(o = t.charCodeAt(p)) < 128 ? a[i >> 2] |= o << h[3 & i++] : o < 2048 ? (a[i >> 2] |= (192 | o >> 6) << h[3 & i++], a[i >> 2] |= (128 | 63 & o) << h[3 & i++]) : o < 55296 || o >= 57344 ? (a[i >> 2] |= (224 | o >> 12) << h[3 & i++], a[i >> 2] |= (128 | o >> 6 & 63) << h[3 & i++], a[i >> 2] |= (128 | 63 & o) << h[3 & i++]) : (o = 65536 + ((1023 & o) << 10 | 1023 & t.charCodeAt(++p)), a[i >> 2] |= (240 | o >> 18) << h[3 & i++], a[i >> 2] |= (128 | o >> 12 & 63) << h[3 & i++], a[i >> 2] |= (128 | o >> 6 & 63) << h[3 & i++], a[i >> 2] |= (128 | 63 & o) << h[3 & i++]);
if (this.lastByteIndex = i, i >= s) {
for (this.start = i - s, this.block = a[c], i = 0; i < c; ++i) d[i] ^= a[i];
j(d), this.reset = !0
} else this.start = i
}
return this
}, t.prototype.encode = function(t, e) {
var r = 255 & t,
n = 1,
i = [r];
for (r = 255 & (t >>= 8); r > 0;) i.unshift(r), r = 255 & (t >>= 8), ++n;
return e ? i.push(n) : i.unshift(n), this.update(i), i.length
}, t.prototype.encodeString = function(t) {
var e, n = typeof t;
if ("string" !== n) {
if ("object" !== n) throw new Error(r);
if (null === t) throw new Error(r);
if (u && t.constructor === ArrayBuffer) t = new Uint8Array(t);
else if (!(Array.isArray(t) || u && ArrayBuffer.isView(t))) throw new Error(r);
e = !0
}
var i = 0,
o = t.length;
if (e) i = o;
else
for (var a = 0; a < t.length; ++a) {
var s = t.charCodeAt(a);
s < 128 ? i += 1 : s < 2048 ? i += 2 : s < 55296 || s >= 57344 ? i += 3 : (s = 65536 + ((1023 & s) << 10 | 1023 & t.charCodeAt(++a)), i += 4)
}
return i += this.encode(8 * i), this.update(t), i
}, t.prototype.bytepad = function(t, e) {
for (var r = this.encode(e), n = 0; n < t.length; ++n) r += this.encodeString(t[n]);
var i = e - r % e,
o = [];
return o.length = i, this.update(o), this
}, t.prototype.finalize = function() {
if (!this.finalized) {
this.finalized = !0;
var t = this.blocks,
e = this.lastByteIndex,
r = this.blockCount,
n = this.s;
if (t[e >> 2] |= this.padding[3 & e], this.lastByteIndex === this.byteCount)
for (t[0] = t[r], e = 1; e < r + 1; ++e) t[e] = 0;
for (t[r - 1] |= 2147483648, e = 0; e < r; ++e) n[e] ^= t[e];
j(n)
}
}, t.prototype.toString = t.prototype.hex = function() {
this.finalize();
for (var t, e = this.blockCount, r = this.s, n = this.outputBlocks, i = this.extraBytes, o = 0, a = 0, s = ""; a < n;) {
for (o = 0; o < e && a < n; ++o, ++a) t = r[o], s += f[t >> 4 & 15] + f[15 & t] + f[t >> 12 & 15] + f[t >> 8 & 15] + f[t >> 20 & 15] + f[t >> 16 & 15] + f[t >> 28 & 15] + f[t >> 24 & 15];
a % e == 0 && (j(r), o = 0)
}
return i && (t = r[o], s += f[t >> 4 & 15] + f[15 & t], i > 1 && (s += f[t >> 12 & 15] + f[t >> 8 & 15]), i > 2 && (s += f[t >> 20 & 15] + f[t >> 16 & 15])), s
}, t.prototype.arrayBuffer = function() {
this.finalize();
var t, e = this.blockCount,
r = this.s,
n = this.outputBlocks,
i = this.extraBytes,
o = 0,
a = 0,
s = this.outputBits >> 3;
t = i ? new ArrayBuffer(n + 1 << 2) : new ArrayBuffer(s);
for (var u = new Uint32Array(t); a < n;) {
for (o = 0; o < e && a < n; ++o, ++a) u[a] = r[o];
a % e == 0 && j(r)
}
return i && (u[o] = r[o], t = t.slice(0, s)), t
}, t.prototype.buffer = t.prototype.arrayBuffer, t.prototype.digest = t.prototype.array = function() {
this.finalize();
for (var t, e, r = this.blockCount, n = this.s, i = this.outputBlocks, o = this.extraBytes, a = 0, s = 0, u = []; s < i;) {
for (a = 0; a < r && s < i; ++a, ++s) t = s << 2, e = n[a], u[t] = 255 & e, u[t + 1] = e >> 8 & 255, u[t + 2] = e >> 16 & 255, u[t + 3] = e >> 24 & 255;
s % r == 0 && j(n)
}
return o && (t = s << 2, e = n[a], u[t] = 255 & e, o > 1 && (u[t + 1] = e >> 8 & 255), o > 2 && (u[t + 2] = e >> 16 & 255)), u
}, (e.prototype = new t).finalize = function() {
return this.encode(this.outputBits, !0), t.prototype.finalize.call(this)
};
var j = function(t) {
var e, r, n, i, o, a, s, u, f, c, h, d, l, y, b, A, w, v, B, g, _, k, S, C, x, m, E, O, z, N, j, J, M, H, I, R, U, V, F, D, W, Y, K, q, G, L, P, Q, T, X, Z, $, tt, et, rt, nt, it, ot, at, st, ut, ft, ct;
for (n = 0; n < 48; n += 2) i = t[0] ^ t[10] ^ t[20] ^ t[30] ^ t[40], o = t[1] ^ t[11] ^ t[21] ^ t[31] ^ t[41], a = t[2] ^ t[12] ^ t[22] ^ t[32] ^ t[42], s = t[3] ^ t[13] ^ t[23] ^ t[33] ^ t[43], u = t[4] ^ t[14] ^ t[24] ^ t[34] ^ t[44], f = t[5] ^ t[15] ^ t[25] ^ t[35] ^ t[45], c = t[6] ^ t[16] ^ t[26] ^ t[36] ^ t[46], h = t[7] ^ t[17] ^ t[27] ^ t[37] ^ t[47], e = (d = t[8] ^ t[18] ^ t[28] ^ t[38] ^ t[48]) ^ (a << 1 | s >>> 31), r = (l = t[9] ^ t[19] ^ t[29] ^ t[39] ^ t[49]) ^ (s << 1 | a >>> 31), t[0] ^= e, t[1] ^= r, t[10] ^= e, t[11] ^= r, t[20] ^= e, t[21] ^= r, t[30] ^= e, t[31] ^= r, t[40] ^= e, t[41] ^= r, e = i ^ (u << 1 | f >>> 31), r = o ^ (f << 1 | u >>> 31), t[2] ^= e, t[3] ^= r, t[12] ^= e, t[13] ^= r, t[22] ^= e, t[23] ^= r, t[32] ^= e, t[33] ^= r, t[42] ^= e, t[43] ^= r, e = a ^ (c << 1 | h >>> 31), r = s ^ (h << 1 | c >>> 31), t[4] ^= e, t[5] ^= r, t[14] ^= e, t[15] ^= r, t[24] ^= e, t[25] ^= r, t[34] ^= e, t[35] ^= r, t[44] ^= e, t[45] ^= r, e = u ^ (d << 1 | l >>> 31), r = f ^ (l << 1 | d >>> 31), t[6] ^= e, t[7] ^= r, t[16] ^= e, t[17] ^= r, t[26] ^= e, t[27] ^= r, t[36] ^= e, t[37] ^= r, t[46] ^= e, t[47] ^= r, e = c ^ (i << 1 | o >>> 31), r = h ^ (o << 1 | i >>> 31), t[8] ^= e, t[9] ^= r, t[18] ^= e, t[19] ^= r, t[28] ^= e, t[29] ^= r, t[38] ^= e, t[39] ^= r, t[48] ^= e, t[49] ^= r, y = t[0], b = t[1], L = t[11] << 4 | t[10] >>> 28, P = t[10] << 4 | t[11] >>> 28, O = t[20] << 3 | t[21] >>> 29, z = t[21] << 3 | t[20] >>> 29, st = t[31] << 9 | t[30] >>> 23, ut = t[30] << 9 | t[31] >>> 23, Y = t[40] << 18 | t[41] >>> 14, K = t[41] << 18 | t[40] >>> 14, H = t[2] << 1 | t[3] >>> 31, I = t[3] << 1 | t[2] >>> 31, A = t[13] << 12 | t[12] >>> 20, w = t[12] << 12 | t[13] >>> 20, Q = t[22] << 10 | t[23] >>> 22, T = t[23] << 10 | t[22] >>> 22, N = t[33] << 13 | t[32] >>> 19, j = t[32] << 13 | t[33] >>> 19, ft = t[42] << 2 | t[43] >>> 30, ct = t[43] << 2 | t[42] >>> 30, et = t[5] << 30 | t[4] >>> 2, rt = t[4] << 30 | t[5] >>> 2, R = t[14] << 6 | t[15] >>> 26, U = t[15] << 6 | t[14] >>> 26, v = t[25] << 11 | t[24] >>> 21, B = t[24] << 11 | t[25] >>> 21, X = t[34] << 15 | t[35] >>> 17, Z = t[35] << 15 | t[34] >>> 17, J = t[45] << 29 | t[44] >>> 3, M = t[44] << 29 | t[45] >>> 3, C = t[6] << 28 | t[7] >>> 4, x = t[7] << 28 | t[6] >>> 4, nt = t[17] << 23 | t[16] >>> 9, it = t[16] << 23 | t[17] >>> 9, V = t[26] << 25 | t[27] >>> 7, F = t[27] << 25 | t[26] >>> 7, g = t[36] << 21 | t[37] >>> 11, _ = t[37] << 21 | t[36] >>> 11, $ = t[47] << 24 | t[46] >>> 8, tt = t[46] << 24 | t[47] >>> 8, q = t[8] << 27 | t[9] >>> 5, G = t[9] << 27 | t[8] >>> 5, m = t[18] << 20 | t[19] >>> 12, E = t[19] << 20 | t[18] >>> 12, ot = t[29] << 7 | t[28] >>> 25, at = t[28] << 7 | t[29] >>> 25, D = t[38] << 8 | t[39] >>> 24, W = t[39] << 8 | t[38] >>> 24, k = t[48] << 14 | t[49] >>> 18, S = t[49] << 14 | t[48] >>> 18, t[0] = y ^ ~A & v, t[1] = b ^ ~w & B, t[10] = C ^ ~m & O, t[11] = x ^ ~E & z, t[20] = H ^ ~R & V, t[21] = I ^ ~U & F, t[30] = q ^ ~L & Q, t[31] = G ^ ~P & T, t[40] = et ^ ~nt & ot, t[41] = rt ^ ~it & at, t[2] = A ^ ~v & g, t[3] = w ^ ~B & _, t[12] = m ^ ~O & N, t[13] = E ^ ~z & j, t[22] = R ^ ~V & D, t[23] = U ^ ~F & W, t[32] = L ^ ~Q & X, t[33] = P ^ ~T & Z, t[42] = nt ^ ~ot & st, t[43] = it ^ ~at & ut, t[4] = v ^ ~g & k, t[5] = B ^ ~_ & S, t[14] = O ^ ~N & J, t[15] = z ^ ~j & M, t[24] = V ^ ~D & Y, t[25] = F ^ ~W & K, t[34] = Q ^ ~X & $, t[35] = T ^ ~Z & tt, t[44] = ot ^ ~st & ft, t[45] = at ^ ~ut & ct, t[6] = g ^ ~k & y, t[7] = _ ^ ~S & b, t[16] = N ^ ~J & C, t[17] = j ^ ~M & x, t[26] = D ^ ~Y & H, t[27] = W ^ ~K & I, t[36] = X ^ ~$ & q, t[37] = Z ^ ~tt & G, t[46] = st ^ ~ft & et, t[47] = ut ^ ~ct & rt, t[8] = k ^ ~y & A, t[9] = S ^ ~b & w, t[18] = J ^ ~C & m, t[19] = M ^ ~x & E, t[28] = Y ^ ~H & R, t[29] = K ^ ~I & U, t[38] = $ ^ ~q & L, t[39] = tt ^ ~G & P, t[48] = ft ^ ~et & nt, t[49] = ct ^ ~rt & it, t[0] ^= p[n], t[1] ^= p[n + 1]
};
if (a) module.exports = S;
else {
for (x = 0; x < C.length; ++x) i[C[x]] = S[C[x]];
s && define(function() {
return S
})
}
}();
</script>
<script type="text/javascript">
const clothesColor = [null, "f00", "f00", "222", "f00", "f00", "f00", "f00", "f00", "f00", "00f", "00f", "00f", "00f", "00f", "00f", "00f", "222", "00f", "f0f", "222", "f0f", "f0f", "f0f", "f0f", "f0f", "f0f", "f0f", "f80", "f80", "f80", "f80", "f80", "f00", "f80", "f80", "f80", "90f", "90f", "00f", "90f", "90f", "90f", "222"],
clothesColorPocket = [null, "d00", "00f", "f00", "f0f", "f80", "90f", "f48", "0f0", "ff0", "f00", "00d", "f0f", "f80", "90f", "f48", "0f0", "ddd", "ff0", "f00", "653", "00f", "d0d", "f80", "90f", "f48", "0f0", "ff0", "f00", "f0f", "00f", "d60", "f48", "ddd", "90f", "0f0", "ff0", "f00", "00f", "fd1", "f0f", "f80", "70d", "fd1"],
hatColorUpper = [null, "f00", "f00", "f00", "f00", "f00", "f00", "f00", "00f", "00f", "00f", "00f", "00f", "00f", "00f", "f00", "f0f", "f0f", "f0f", "f0f", "f0f", "f0f", "f0f", "f80", "f80", "f80", "f80", "f80", "f80", "f00", "f80", "90f", "f48", "22d", "90f", "90f", "ff0"],
hatColorLower = [null, "0f0", "00f", "f80", "ff0", "90f", "f0f", "f48", "f00", "0f0", "00f", "f80", "ff0", "90f", "f0f", "222", "f00", "0f0", "00f", "f80", "ff0", "90f", "f0f", "f00", "0f0", "00f", "f80", "ff0", "90f", "f00", "f0f", "f00", "222", "222", "0f0", "00f", "f48"],
furColorInner = ["653", "532", "444", "a71", "ffc", "ca9", "f89", "777", "049", "901", "fc5", "ffe", "574", "bcc", "d04", "222", "889", "7f9", "fd1"],
furColorOuter = ["532", "653", "653", "653", "653", "653", "653", "653", "653", "653", "110", "653", "711", "344", "799", "555", "8a8", "32f", "653"],
mouthColor = ["653", "ffc", "f89", "777", "049", "901", "bcc", "d04", "fd1", "ffc", "653", "f89", "777", "049", "bcc", "901", "901", "bcc", "653", "d04", "ffc", "f89", "777", "049", "fd1", "f89", "777", "bcc", "d04", "049", "ffc", "901", "fd1"],
fur_w = [249, 246, 223, 141, 116, 114, 93, 90, 89, 86, 74, 72, 55, 48, 39, 32, 28, 14, 8],
eyes_w = [245, 121, 107, 101, 79, 78, 70, 68, 62, 58, 56, 51, 50, 48, 44, 38, 35, 33, 31, 22, 15, 10, 7],
mouth_w = [252, 172, 80, 79, 56, 49, 37, 33, 31, 30, 28, 27, 26, 23, 22, 18, 15, 14, 13, 12, 11, 10, 10, 10, 9, 8, 7, 7, 6, 5, 5, 4, 3],
earring_w = [251, 32, 29, 17, 16, 8, 5],
clothes_w = [251, 55, 45, 43, 38, 37, 34, 33, 32, 31, 31, 31, 31, 31, 30, 30, 29, 29, 28, 27, 27, 27, 26, 25, 24, 22, 21, 20, 19, 19, 19, 19, 19, 19, 18, 17, 16, 15, 14, 13, 11, 9, 8, 6],
hat_w = [251, 64, 47, 42, 39, 38, 36, 35, 34, 34, 33, 29, 28, 26, 26, 25, 25, 25, 22, 21, 20, 20, 18, 17, 17, 15, 14, 14, 13, 13, 12, 12, 12, 10, 9, 8, 7],
background = ["656", "dda", "e92", "1eb", "663", "9de", "367", "ccc"],
fur1 = ["653", "532", "444", "a71", "ffc", "ca9", "f89", "777", "049", "901", "fc5", "ffe", "574", "bcc", "d04", "222", "889", "7f9", "fd1"],
fur2 = ["532", "653", "653", "653", "653", "653", "653", "653", "653", "653", "110", "653", "711", "344", "799", "555", "8a8", "32f", "653"],
eyes = ["abe", "0a0", "653", "888", "be7", "abe", "0a0", "653", "888", "be7", "cef", "abe", "0a0", "653", "888", "be7", "cef", "abe", "0a0", "653", "888", "be7", "cef"],
mouth = ["653", "ffc", "f89", "777", "049", "901", "bcc", "d04", "fd1", "ffc", "653", "f89", "777", "049", "bcc", "901", "901", "bcc", "653", "d04", "ffc", "f89", "777", "049", "fd1", "f89", "777", "bcc", "d04", "049", "ffc", "901", "fd1"],
earring = ["999", "fe7", "999", "999", "fe7", "bdd"],
clothes1 = ["f00", "f00", "222", "f00", "f00", "f00", "f00", "f00", "f00", "00f", "00f", "00f", "00f", "00f", "00f", "00f", "222", "00f", "f0f", "222", "f0f", "f0f", "f0f", "f0f", "f0f", "f0f", "f0f", "f80", "f80", "f80", "f80", "f80", "f00", "f80", "f80", "f80", "90f", "90f", "00f", "90f", "90f", "90f", "222"],
clothes2 = ["d00", "00f", "f00", "f0f", "f80", "90f", "f48", "0f0", "ff0", "f00", "00d", "f0f", "f80", "90f", "f48", "0f0", "ddd", "ff0", "f00", "653", "00f", "d0d", "f80", "90f", "f48", "0f0", "ff0", "f00", "f0f", "00f", "d60", "f48", "ddd", "90f", "0f0", "ff0", "f00", "00f", "fd1", "f0f", "f80", "70d", "fd1"],
hat1 = ["f00", "f00", "f00", "f00", "f00", "f00", "f00", "00f", "00f", "00f", "00f", "00f", "00f", "00f", "f00", "f0f", "f0f", "f0f", "f0f", "f0f", "f0f", "f0f", "f80", "f80", "f80", "f80", "f80", "f80", "f00", "f80", "90f", "f48", "22d", "90f", "90f", "ff0", ""],
hat2 = ["0f0", "00f", "f80", "ff0", "90f", "f0f", "f48", "f00", "0f0", "00f", "f80", "ff0", "90f", "f0f", "000", "f00", "0f0", "00f", "f80", "ff0", "90f", "f0f", "f00", "0f0", "00f", "f80", "ff0", "90f", "f00", "f0f", "f00", "000", "000", "0f0", "00f", "f48", ""],
cross = '<rect x="95" y="275" width="10" height="40" style="fill:#872"/><rect x="85" y="285" width="30" height="10" style="fill:#872"/>',
clo1 = '<rect width="300" height="120" x="99" y="400" style="fill:#',
clo2 = '"/><rect width="50" height="55" x="280" y="430" style="fill:#',
hh1 = '<rect width="200" height="99" x="150" y="40" style="fill:#',
hh2 = '"/><rect width="200" height="33" x="150" y="106" style="fill:#',
sl1 = '<rect x="150" y="190" width="200" height="30" style="fill:#',
sl2 = '"/><rect x="160" y="170" width="180" height="50" style="fill:#',
mou = '<line x1="287" y1="331" x2="320" y2="366" style="stroke:#000;stroke-width:5"/>',
ey1 = '<rect x="160" y="190" width="75" height="15" style="fill:#',
ey2 = '"/><rect x="275" y="190" width="65" height="15" style="fill:#',
ey3 = '<rect x="160" y="235" width="180" height="50" style="fill:#',
zz = '"/>',
ea1 = '<circle cx="100" cy="290" r="14" style="fill:#',
ea2 = "fe7",
ea3 = "999",
ea4 = '"/><circle cx="100" cy="290" r="4" style="fill:#000"/>',
ea5 = '<circle cx="100" cy="290" r="12" style="fill:#',
ea6 = "bdd",
mo1 = '<line x1="',
mo2 = '" y1="307" x2="',
mo3 = '" y2="312" style="stroke:#000;stroke-width:2"/>',
mo4 = '" y1="317" x2="',
mo5 = '" y2="322" style="stroke:#000;stroke-width:2"/>',
ra1 = "A",
ra2 = "C",
ra3 = "D",
ra4 = "E",
ra5 = "F",
ra6 = "G";
function usew(f, e) {
let t = 0,
r = f[0];
for (; r <= e;) t++, r += f[t];
return t
}
function random(f) {
return BigInt("0x" + keccak_256(f).toString("hex"))
}
function randomOne(f) {
const e = (f = 12839 - f).toString(),
t = {
background: Number(random(ra1 + e) % 8n),
fur: usew(fur_w, Number(random(clo1 + e) % 1817n)),
eyes: usew(eyes_w, Number(random(ra2 + e) % 1429n)),
mouth: usew(mouth_w, Number(random(ra3 + e) % 1112n)),
earring: usew(earring_w, Number(random(ra4 + e) % 358n)),
clothes: usew(clothes_w, Number(random(ra5 + e) % 1329n)),
hat: usew(hat_w, Number(random(ra6 + e) % 1111n))
};
return 7403 == f && t.hat++, t
}
function genEye(f, e, t) {
let r = "";
return t > 4 && (r = sl1 + f + sl2 + f + zz), t > 10 && (r = r + ey1 + e + ey2 + e + zz), t > 16 && (r = r + ey3 + f + zz), r
}
function genMouth(f) {
let e, t = "";
if (f > 24 || f > 8 && f < 16) {
for (e = 0; e < 7; e++) t = t + mo1 + (175 + 25 * e).toString() + mo2 + (175 + 25 * e).toString() + mo3;
for (e = 0; e < 6; e++) t = t + mo1 + (187 + 25 * e).toString() + mo4 + (187 + 25 * e).toString() + mo5
}
return f > 15 && (t += mou), t
}
function genEarring(f) {
return 0 == f ? "" : f < 3 ? f > 1 ? ea1 + ea2 + ea4 : ea1 + ea3 + ea4 : f > 3 ? f > 5 ? ea5 + ea6 + zz : f > 4 ? ea5 + ea2 + zz : ea5 + ea3 + zz : cross
}
function genSVG(f) {
const e = fur1[f.fur],
t = fur2[f.fur];
let r = "",
l = "";
f.clothes > 0 && (l = clo1 + clothes1[f.clothes - 1] + clo2 + clothes2[f.clothes - 1] + zz), f.hat > 0 && (r = hh1 + hat1[f.hat - 1] + hh2 + hat2[f.hat - 1] + zz);
let c = z[0] + background[f.background] + z[1] + t + z[2];
return c = c + e + z[3] + e + z[4] + t + z[5] + e + z[6], c = c + t + z[7] + e + z[8] + t + z[9] + e + z[10], c = c + eyes[f.eyes] + z[11] + eyes[f.eyes] + z[12] + genEye(e, t, f.eyes) + z[13] + mouth[f.mouth] + z[14], c + genMouth(f.mouth) + genEarring(f.earring) + r + l + z[15]
}
function ocmGenesisMetadata(f) {
return {
id: f,
...randomOne(f)
}
}
const queryString = window.location.search,
urlParams = new URLSearchParams(queryString),
tokenIdFromUrlParams = urlParams.get("tokenID"),
modeSetting = Number(urlParams.get("mode") ?? "0");
let animateStyleClassTags = "",
animateStyleFooter = "";
1 == modeSetting && (animateStyleClassTags = 'class="jiggle"', animateStyleFooter = "<style> .jiggle { animation-name: jiggleKF; animation-duration: 2s; animation-iteration-count: infinite; animation-direction: alternate-reverse; animation-timing-function: ease-in-out; } @keyframes jiggleKF { 0% { transform: translateX(-4px); } 100% { transform: translateX(9px); } } </style>");
const z = ['<svg xmlns="http://www.w3.org/2000/svg" preserveAspectRatio="xMinYMin meet" viewBox="0 0 500 500"><rect x="0" y="0" width="500" height="500" style="fill:#', '"/><rect width="300" height="120" x="99" y="400" style="fill:#', '"/><circle cx="190" cy="470" r="5" style="fill:#', '"/><circle cx="310" cy="470" r="5" style="fill:#', '"/><circle cx="100" cy="250" r="50" style="fill:#', '"/><circle cx="100" cy="250" r="20" style="fill:#', '"/><circle cx="400" cy="250" r="50" style="fill:#', '"/><circle cx="400" cy="250" r="20" style="fill:#', '"/><circle cx="250" cy="250" r="150" style="fill:#', '"/><circle cx="250" cy="250" r="120" style="fill:#', `"/><circle cx="200" cy="215" r="35" style="fill:#fff"/><circle cx="305" cy="222" r="31" style="fill:#fff"/><circle ${animateStyleClassTags} cx="200" cy="220" r="20" style="fill:#`, `"/><circle ${animateStyleClassTags} cx="300" cy="220" r="20" style="fill:#`, `"/><circle ${animateStyleClassTags} cx="200" cy="220" r="7" style="fill:#000"/><circle ${animateStyleClassTags} cx="300" cy="220" r="7" style="fill:#000"/>`, '<ellipse cx="250" cy="315" rx="84" ry="34" style="fill:#', '"/><rect x="195" y="330" width="110" height="3" style="fill:#000"/><circle cx="268" cy="295" r="5" style="fill:#000"/><circle cx="232" cy="295" r="5" style="fill:#000"/>', `${animateStyleFooter} </svg>`];
function writeSVG(f) {
if (Number.isNaN(f)) return;
const e = ocmGenesisMetadata(f);
document.querySelector("#m").innerHTML = genSVG(e)
}
function previousTokenID() {
let f = Number(document.getElementById("tokenID").value);
Number.isNaN(f) && (f = 1), f--, f < 1 && (f = 1e4), document.getElementById("tokenID").value = f, writeSVG(f)
}
function nextTokenID() {
let f = Number(document.getElementById("tokenID").value);
Number.isNaN(f) && (f = 1), f++, f > 1e4 && (f = 1), document.getElementById("tokenID").value = f, writeSVG(f)
}
tokenIdFromUrlParams ? writeSVG(Number(tokenIdFromUrlParams)) : (document.querySelector("#t").id = "ui", document.addEventListener("keydown", (function(f) {
37 === f.which ? previousTokenID() : 39 === f.which && nextTokenID()
})), writeSVG(1));
</script>
</body>
</html>