-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathindex.html
111 lines (101 loc) · 5.03 KB
/
index.html
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<meta name="viewport" content="initial-scale=0.5, maximum-scale=1">
<link rel="shortcut icon" href="favicon.ico">
<title>Hora{.js}</title>
<style>
a { color: #ff8c00 !important; text-decoration: none }
body { color: #4e4e4e; font-family: "-apple-system", BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen, Ubuntu, Cantarell, "Open Sans", "Helvetica Neue", Helvetica, Arial, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol"; height: 100vh; overflow: hidden; padding: 0 }
canvas#dots { left: 0; position: fixed; top: 0; z-index: 0 }
h3 { font-weight: 400; margin: 1rem 0; opacity: 0.95; text-transform: lowercase }
p { margin: 1rem 0 }
.box { background: rgba(255, 255, 255, 0.85); border-radius: 0.25rem; flex: 1 1; margin: 0.5rem; min-width: 15rem; max-width: 21rem; padding: 0 1.5rem; text-align: center; white-space: nowrap; width: 21rem; z-index: 2 }
.container { align-items: center; display: flex; flex-direction: column; justify-content: center; height: 100%; }
.desc { font-size: 0.95rem; opacity: 0.85; white-space: normal }
.dot { border-radius: 50%; position: absolute; z-index: 0 }
.header { align-items: center; background: rgba(255, 255, 255, 0.85); display: flex; left: 0; justify-content: space-between; padding: 0.5rem 1rem; position: fixed; right: 0; top: 0; z-index: 1 }
.header div.logo { display: flex; align-items: center }
.header img { height: 1.5rem; margin-right: 0.5rem; width: 1.5rem }
.row { align-items: center; display: flex; justify-content: center }
</style>
</head>
<body>
<canvas id="dots"></canvas>
<div class="container">
<div class="row">
<div class="box">
<h3>Apps Wallet (hosted)</h3>
<p class="desc">A wallet built on the hora-js stack. This version is updated alongside any changes to the code and always has the latest features.</p>
<p><a href="https://horaos.js.org/apps/">horaos.js.org/apps</a></p>
</div>
<div class="box">
<h3>Apps Wallet (IPFS)</h3>
<p class="desc">An IPFS version of the hora-js wallet. This version is updated weekly but fits closer with the Web3 vision of decentralization.</p>
<p><a href="https://dotapps.io/">dotapps.io</a></p>
</div>
</div>
<div class="row">
<div class="box">
<h3>Extension</h3>
<p class="desc">A browser-based vault for management of your account keys. It is meant to be used alongside wallets such as the apps UI.</p>
<p><a href="https://horaos.js.org/extension/">horaos.js.org/extension</a></p>
</div>
<div class="box">
<h3>Phishing</h3>
<p class="desc">Community driven lists of urls and addresses of dishonest operators. Used ecosystem wide in wallets and extensions.</p>
<p><a href="https://horaos.js.org/phishing/">horaos.js.org/phishing</a></p>
</div>
</div>
<div class="row">
<div class="box">
<h3>Documentation</h3>
<p class="desc">Developer documentation for all (most?) of the libraries under the horaos-js umbrella. If you want to build, this is where to start.</p>
<p><a href="https://horaos.js.org/docs/">horaos.js.org/docs</a></p>
</div>
<div class="box">
<h3>code</h3>
<p class="desc">The code for everything we do. API, utilities, crypto, tools, user-facing interfaces and documentation.</p>
<p><a href="https://github.com/horaos/">github.com/horaos</a></p>
</div>
</div>
</div>
<div class="header">
<div class="logo">
<img src="logo.svg" />
<div>hora{.js}</div>
</div>
<a href="https://github.com/horaos/horaos.github.io/edit/master/index.html">edit page on github</a>
</div>
<script>
if (window.self !== window.top) {
window.top.location.href = window.location.href;
}
const canvas = document.getElementById('dots');
const style = document.createElement('style');
canvas.height = window.innerHeight * 4;
canvas.width = window.innerWidth * 4;
document.head.appendChild(style);
const context = canvas.getContext('2d');
let hue = Math.floor(Math.random() * 359);
let counter = 0;
function draw () {
hue = (hue + 1) % 360;
document.body.style.background = `hsl(${hue}, 45%, 85%)`;
style.innerHTML = `a { color: hsl(${hue}, 45%, 45%) !important }`;
if (++counter % 4 === 0) {
const centerX = window.innerWidth * Math.random();
const centerY = window.innerHeight * Math.random();
const radius = (Math.floor(32000 * Math.random()) / 1000) + 8;
context.beginPath();
context.arc(centerX, centerY, radius, 0, 2 * Math.PI, false);
context.fillStyle = `hsl(${hue}, 45%, 75%)`;
context.fill();
}
setTimeout(() => window.requestAnimationFrame(draw), 25);
};
draw();
</script>
</body>
</html>