aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--LICENSE.txt21
-rw-r--r--src/routes/+page.svelte23
-rw-r--r--src/routes/RubySquareYear.svelte7
-rw-r--r--src/routes/Square.svelte1
4 files changed, 44 insertions, 8 deletions
diff --git a/LICENSE.txt b/LICENSE.txt
new file mode 100644
index 0000000..ec7d6e6
--- /dev/null
+++ b/LICENSE.txt
@@ -0,0 +1,21 @@
+MIT License
+
+Copyright (c) 2024-present Arjun Satarkar
+
+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. \ No newline at end of file
diff --git a/src/routes/+page.svelte b/src/routes/+page.svelte
index 093347f..3bdd11d 100644
--- a/src/routes/+page.svelte
+++ b/src/routes/+page.svelte
@@ -1,5 +1,7 @@
<script lang="ts">
import { DateTime } from "luxon";
+ import RubySquareYear from "./RubySquareYear.svelte";
+ import Square from "./Square.svelte";
const getCurrentYear = () => DateTime.now().year;
const getRelative = (year: number) =>
@@ -10,9 +12,8 @@
let isPerfectSquare = $derived(Number.isInteger(sqrt));
let lastSqrt = $derived(isPerfectSquare ? sqrt - 1 : Math.floor(sqrt));
let nextSqrt = $derived(isPerfectSquare ? sqrt + 1 : Math.ceil(sqrt));
- let last = $derived(lastSqrt ** 2);
let next = $derived(nextSqrt ** 2);
- let nextRelative: string = $state("");
+ let nextRelative = $state("");
const update = () => {
year = getCurrentYear();
@@ -22,22 +23,25 @@
setInterval(update, 500);
</script>
-<div id="container">
+<div id="mainDisplay">
<h1>Is the year a perfect square?</h1>
{#if isPerfectSquare}
<div id="answer">Yes.</div>
- <strong>{sqrt}</strong><sup>2</sup> = {year}.
+ <strong>{sqrt}</strong><Square /> = {year}.
{:else}
<div id="answer">No.</div>
{/if}
The last was
- <ruby>{last}<rp> (</rp><rt>{lastSqrt}<sup>2</sup></rt><rp>)</rp></ruby>, and
- the next is
- <ruby>{next}<rp> (</rp><rt>{nextSqrt}<sup>2</sup></rt><rp>)</rp></ruby>, {nextRelative}!
+ <RubySquareYear sqrt={lastSqrt} /> and the next is
+ <RubySquareYear sqrt={nextSqrt} />, {nextRelative}!
+</div>
+
+<div id="sourceLinkContainer">
+ <a href="https://github.com/arjunsatarkar/is-the-year-a-perfect-square">source code</a>
</div>
<style>
- #container {
+ #mainDisplay {
text-align: center;
font-size: 2rem;
}
@@ -52,4 +56,7 @@
font-weight: bold;
font-family: sans-serif;
}
+ #sourceLinkContainer {
+ text-align: right;
+ }
</style>
diff --git a/src/routes/RubySquareYear.svelte b/src/routes/RubySquareYear.svelte
new file mode 100644
index 0000000..53500bf
--- /dev/null
+++ b/src/routes/RubySquareYear.svelte
@@ -0,0 +1,7 @@
+<script lang="ts">
+ import Square from "./Square.svelte";
+
+ let { sqrt }: { sqrt: number } = $props();
+</script>
+
+<ruby>{sqrt ** 2}<rp> (</rp><rt>{sqrt}<Square /></rt><rp>)</rp></ruby>
diff --git a/src/routes/Square.svelte b/src/routes/Square.svelte
new file mode 100644
index 0000000..bcd1286
--- /dev/null
+++ b/src/routes/Square.svelte
@@ -0,0 +1 @@
+<sup>2</sup>