Initial commit
This commit is contained in:
commit
0cd1d502c7
BIN
DSEG14ClassicMini-Regular.woff
Normal file
BIN
DSEG14ClassicMini-Regular.woff
Normal file
Binary file not shown.
118
LICENSE.txt
Normal file
118
LICENSE.txt
Normal file
|
@ -0,0 +1,118 @@
|
||||||
|
Code
|
||||||
|
====
|
||||||
|
|
||||||
|
Code for fireworks animation copyright (c) 2022 Vitalij Ryndin
|
||||||
|
Other code copyright (c) 2022 Samuel Sloniker
|
||||||
|
|
||||||
|
Permission is hereby granted, free of charge, to any person obtaining a copy of
|
||||||
|
this software and associated documentation files (the "Software"), to deal in
|
||||||
|
the Software without restriction, including without limitation the rights to
|
||||||
|
use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies
|
||||||
|
of the Software, and to permit persons to whom the Software is furnished to do
|
||||||
|
so, subject to the following conditions:
|
||||||
|
|
||||||
|
The above copyright notice and this permission notice shall be included in all
|
||||||
|
copies or substantial portions of the Software.
|
||||||
|
|
||||||
|
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||||
|
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||||||
|
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
||||||
|
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
||||||
|
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
||||||
|
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
||||||
|
SOFTWARE.
|
||||||
|
|
||||||
|
Font
|
||||||
|
====
|
||||||
|
|
||||||
|
The font is DSEG14 Classic Mini Regular.
|
||||||
|
|
||||||
|
Copyright (c) 2017, keshikan (http://www.keshikan.net), with Reserved Font Name
|
||||||
|
"DSEG".
|
||||||
|
|
||||||
|
This Font Software is licensed under the SIL Open Font License, Version 1.1.
|
||||||
|
This license is copied below, and is also available with a FAQ at:
|
||||||
|
http://scripts.sil.org/OFL
|
||||||
|
|
||||||
|
|
||||||
|
-----------------------------------------------------------
|
||||||
|
SIL OPEN FONT LICENSE Version 1.1 - 26 February 2007
|
||||||
|
-----------------------------------------------------------
|
||||||
|
|
||||||
|
PREAMBLE
|
||||||
|
The goals of the Open Font License (OFL) are to stimulate worldwide development
|
||||||
|
of collaborative font projects, to support the font creation efforts of
|
||||||
|
academic and linguistic communities, and to provide a free and open framework
|
||||||
|
in which fonts may be shared and improved in partnership with others.
|
||||||
|
|
||||||
|
The OFL allows the licensed fonts to be used, studied, modified and
|
||||||
|
redistributed freely as long as they are not sold by themselves. The fonts,
|
||||||
|
including any derivative works, can be bundled, embedded, redistributed and/or
|
||||||
|
sold with any software provided that any reserved names are not used by
|
||||||
|
derivative works. The fonts and derivatives, however, cannot be released under
|
||||||
|
any other type of license. The requirement for fonts to remain under this
|
||||||
|
license does not apply to any document created using the fonts or their
|
||||||
|
derivatives.
|
||||||
|
|
||||||
|
DEFINITIONS
|
||||||
|
"Font Software" refers to the set of files released by the Copyright Holder(s)
|
||||||
|
under this license and clearly marked as such. This may include source files,
|
||||||
|
build scripts and documentation.
|
||||||
|
|
||||||
|
"Reserved Font Name" refers to any names specified as such after the copyright
|
||||||
|
statement(s).
|
||||||
|
|
||||||
|
"Original Version" refers to the collection of Font Software components as
|
||||||
|
distributed by the Copyright Holder(s).
|
||||||
|
|
||||||
|
"Modified Version" refers to any derivative made by adding to, deleting, or
|
||||||
|
substituting -- in part or in whole -- any of the components of the Original
|
||||||
|
Version, by changing formats or by porting the Font Software to a new
|
||||||
|
environment.
|
||||||
|
|
||||||
|
"Author" refers to any designer, engineer, programmer, technical writer or
|
||||||
|
other person who contributed to the Font Software.
|
||||||
|
|
||||||
|
PERMISSION & CONDITIONS
|
||||||
|
Permission is hereby granted, free of charge, to any person obtaining a copy of
|
||||||
|
the Font Software, to use, study, copy, merge, embed, modify, redistribute, and
|
||||||
|
sell modified and unmodified copies of the Font Software, subject to the
|
||||||
|
following conditions:
|
||||||
|
|
||||||
|
1) Neither the Font Software nor any of its individual components, in Original
|
||||||
|
or Modified Versions, may be sold by itself.
|
||||||
|
|
||||||
|
2) Original or Modified Versions of the Font Software may be bundled,
|
||||||
|
redistributed and/or sold with any software, provided that each copy contains
|
||||||
|
the above copyright notice and this license. These can be included either as
|
||||||
|
stand-alone text files, human-readable headers or in the appropriate
|
||||||
|
machine-readable metadata fields within text or binary files as long as those
|
||||||
|
fields can be easily viewed by the user.
|
||||||
|
|
||||||
|
3) No Modified Version of the Font Software may use the Reserved Font Name(s)
|
||||||
|
unless explicit written permission is granted by the corresponding Copyright
|
||||||
|
Holder. This restriction only applies to the primary font name as presented to
|
||||||
|
the users.
|
||||||
|
|
||||||
|
4) The name(s) of the Copyright Holder(s) or the Author(s) of the Font Software
|
||||||
|
shall not be used to promote, endorse or advertise any Modified Version, except
|
||||||
|
to acknowledge the contribution(s) of the Copyright Holder(s) and the Author(s)
|
||||||
|
or with their explicit written permission.
|
||||||
|
|
||||||
|
5) The Font Software, modified or unmodified, in part or in whole, must be
|
||||||
|
distributed entirely under this license, and must not be distributed under any
|
||||||
|
other license. The requirement for fonts to remain under this license does not
|
||||||
|
apply to any document created using the Font Software.
|
||||||
|
|
||||||
|
TERMINATION
|
||||||
|
This license becomes null and void if any of the above conditions are not met.
|
||||||
|
|
||||||
|
DISCLAIMER
|
||||||
|
THE FONT SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||||
|
IMPLIED, INCLUDING BUT NOT LIMITED TO ANY WARRANTIES OF MERCHANTABILITY,
|
||||||
|
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT OF COPYRIGHT, PATENT,
|
||||||
|
TRADEMARK, OR OTHER RIGHT. IN NO EVENT SHALL THE COPYRIGHT HOLDER BE LIABLE FOR
|
||||||
|
ANY CLAIM, DAMAGES OR OTHER LIABILITY, INCLUDING ANY GENERAL, SPECIAL,
|
||||||
|
INDIRECT, INCIDENTAL, OR CONSEQUENTIAL DAMAGES, WHETHER IN AN ACTION OF
|
||||||
|
CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF THE USE OR INABILITY TO USE
|
||||||
|
THE FONT SOFTWARE OR FROM OTHER DEALINGS IN THE FONT SOFTWARE.
|
6
fireworks.js
Normal file
6
fireworks.js
Normal file
File diff suppressed because one or more lines are too long
20
index.html
Normal file
20
index.html
Normal file
|
@ -0,0 +1,20 @@
|
||||||
|
<!DOCTYPE html>
|
||||||
|
<html>
|
||||||
|
<head>
|
||||||
|
<title>New Year Coundown</title>
|
||||||
|
<link rel=stylesheet href=style.css>
|
||||||
|
<meta name="viewport" content="width=device-width, initial-scale=1">
|
||||||
|
<script src="fireworks.js"></script>
|
||||||
|
<script src="main.js"></script>
|
||||||
|
</head>
|
||||||
|
<body>
|
||||||
|
<div id=container>
|
||||||
|
<h1 id=header>NEW YEAR COUNTDOWN</h1>
|
||||||
|
<div id=countdownbox><p id=countdown><span id=countdowntext><noscript>Sorry, the New Year coundown c</noscript>lo<noscript>ck requires J</noscript>a<noscript>vaScript. Please switch to a supporte</noscript>d<noscript> browser, or enable JS in your exist</noscript>ing<noscript> one.</noscript></span></p></div>
|
||||||
|
<div id=creditbox>
|
||||||
|
<p class=credits>Font (<a href="https://www.keshikan.net/fonts-e.html">DSEG14 Classic Mini Regular</a>) by Keshikan; <a href="https://github.com/crashmax-dev/fireworks-js/">effect that happens at midnight</a> by Vitalij Ryndin; all other code by Samuel Sloniker. <a href="LICENSE.txt">Click here for license information.</a> <a href="https://git.kj7rrv.com/kj7rrv/new-year-countdown">This site is open-source.</a></p>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div id=firepops></div>
|
||||||
|
</body>
|
||||||
|
</html>
|
69
main.js
Normal file
69
main.js
Normal file
|
@ -0,0 +1,69 @@
|
||||||
|
"use strict"
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Copyright (c) 2022 Samuel Sloniker
|
||||||
|
*
|
||||||
|
* Permission is hereby granted, free of charge, to any person obtaining a copy
|
||||||
|
* of this software and associated documentation files (the "Software"), to
|
||||||
|
* deal in the Software without restriction, including without limitation the
|
||||||
|
* rights to use, copy, modify, merge, publish, distribute, sublicense, and/or
|
||||||
|
* sell copies of the Software, and to permit persons to whom the Software is
|
||||||
|
* furnished to do so, subject to the following conditions:
|
||||||
|
*
|
||||||
|
* The above copyright notice and this permission notice shall be included in
|
||||||
|
* all copies or substantial portions of the Software.
|
||||||
|
*
|
||||||
|
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||||
|
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||||||
|
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
||||||
|
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
||||||
|
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
|
||||||
|
* FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS
|
||||||
|
* IN THE SOFTWARE.
|
||||||
|
*/
|
||||||
|
|
||||||
|
function format(number) {
|
||||||
|
return (number < 10)?("0" + String(number)):String(number)
|
||||||
|
}
|
||||||
|
|
||||||
|
function adjust() {
|
||||||
|
let ce = document.querySelector("#countdown")
|
||||||
|
let cec = document.querySelector("#countdownbox")
|
||||||
|
let cet = document.querySelector("#countdowntext")
|
||||||
|
|
||||||
|
let time = (newYear - new Date()) / 1000
|
||||||
|
if (time <= 0) {
|
||||||
|
clearInterval(intervalID)
|
||||||
|
cet.innerHTML = "HAPPY NEW YEAR"
|
||||||
|
let fireworks = new Fireworks(document.querySelector("div#firepops"), { /* options */ })
|
||||||
|
fireworks.start()
|
||||||
|
} else {
|
||||||
|
let days = Math.floor(time / (60 * 60 * 24))
|
||||||
|
let hours = Math.floor(time / (60 * 60)) % 24
|
||||||
|
let minutes = Math.floor(time / 60) % 60
|
||||||
|
let seconds = Math.floor(time) % 60
|
||||||
|
cet.textContent = (days?(format(days) + ":"):"") +
|
||||||
|
((hours || days)?(format(hours) + ":"):"") +
|
||||||
|
((minutes || hours || days)?(format(minutes) + ":"):"") +
|
||||||
|
format(seconds)
|
||||||
|
}
|
||||||
|
|
||||||
|
let fontSize = 1
|
||||||
|
ce.style.fontSize = String(fontSize - 1) + "px"
|
||||||
|
ce.style.fontSize = "1px"
|
||||||
|
while (ce.clientHeight <= cec.clientHeight && cec.scrollWidth <= document.documentElement.clientWidth && fontSize <= 180) {
|
||||||
|
fontSize += 1
|
||||||
|
ce.style.fontSize = String(fontSize) + "px"
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
function main() {
|
||||||
|
window.newYear = new Date(new Date().getFullYear() + 1, 0, 1)
|
||||||
|
document.querySelector("h1#header").textContent = "NEW YEAR " + String(newYear.getFullYear()) + " COUNTDOWN"
|
||||||
|
window.intervalID = setInterval(adjust, 100)
|
||||||
|
window.addEventListener("resize", adjust)
|
||||||
|
adjust()
|
||||||
|
}
|
||||||
|
|
||||||
|
window.onload = main
|
68
style.css
Normal file
68
style.css
Normal file
|
@ -0,0 +1,68 @@
|
||||||
|
@font-face {
|
||||||
|
font-family: "DSEG";
|
||||||
|
src: url(DSEG14ClassicMini-Regular.woff);
|
||||||
|
}
|
||||||
|
|
||||||
|
body {
|
||||||
|
background-color: #000;
|
||||||
|
text-align: center;
|
||||||
|
margin: 0 !important;
|
||||||
|
padding: 0 !important;
|
||||||
|
font-family: DSEG;
|
||||||
|
color: #0F0
|
||||||
|
}
|
||||||
|
|
||||||
|
div#container {
|
||||||
|
display: flex;
|
||||||
|
flex-flow: column;
|
||||||
|
height: 100vh;
|
||||||
|
}
|
||||||
|
|
||||||
|
h1 {
|
||||||
|
font-size: 32pt;
|
||||||
|
flex: 0 1 auto;
|
||||||
|
margin-bottom: 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
div#countdownbox {
|
||||||
|
font-size: 20pt;
|
||||||
|
flex: 1 1 auto;
|
||||||
|
overflow: hidden;
|
||||||
|
align-items: center;
|
||||||
|
justify-content: center;
|
||||||
|
display: flex;
|
||||||
|
}
|
||||||
|
|
||||||
|
p#countdown {
|
||||||
|
margin-top: 0;
|
||||||
|
margin-bottom: 0;
|
||||||
|
margin-left: 10px;
|
||||||
|
margin-right: 10px;
|
||||||
|
}
|
||||||
|
|
||||||
|
div#creditbox {
|
||||||
|
font-size: 8pt;
|
||||||
|
padding-left: 4px;
|
||||||
|
padding-right: 4px;
|
||||||
|
flex: 0 1 auto;
|
||||||
|
z-index: 200;
|
||||||
|
}
|
||||||
|
|
||||||
|
div#creditbox p.credits {
|
||||||
|
margin-top: 2px;
|
||||||
|
margin-bottom: 2px;
|
||||||
|
font-family: sans-serif;
|
||||||
|
}
|
||||||
|
|
||||||
|
div#creditbox p.credits a {
|
||||||
|
color: #0F8;
|
||||||
|
}
|
||||||
|
|
||||||
|
div#firepops {
|
||||||
|
position: absolute;
|
||||||
|
top: 0px;
|
||||||
|
left: 0px;
|
||||||
|
height: 100vh;
|
||||||
|
width: 100vw;
|
||||||
|
z-index: 100;
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user