365 lines
11 KiB
HTML
365 lines
11 KiB
HTML
<!DOCTYPE html>
|
|
<html>
|
|
|
|
<head>
|
|
<title>Caleb Fontenot's Web Server</title>
|
|
<link rel="icon" type="image/x-icon" href="Caleb_face.jpg">
|
|
<link rel="icon" href="Caleb_face.jpg" type="image/jpeg" />
|
|
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />
|
|
<meta content="Caleb Fontenot's Web Server" property="og:title" />
|
|
<meta content="Home Page of Caleb Fontenot's Web Server" property="og:description" />
|
|
<meta content="https://calebfontenot.com" property="og:url" />
|
|
<meta content="Caleb_face.jpg" property="og:image" />
|
|
<meta content="#FF0000" data-react-helmet="true" name="theme-color" />
|
|
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
|
<link href="root.css" rel="stylesheet">
|
|
<!-- Google tag (gtag.js) -->
|
|
<script async src="https://www.googletagmanager.com/gtag/js?id=G-L9QF12JY74"></script>
|
|
<script>
|
|
window.dataLayer = window.dataLayer || [];
|
|
function gtag() { dataLayer.push(arguments); }
|
|
gtag('js', new Date());
|
|
|
|
gtag('config', 'G-L9QF12JY74');
|
|
</script>
|
|
|
|
</head>
|
|
|
|
|
|
<body class="center">
|
|
<div id="wrapper">
|
|
<nav>
|
|
<h1>Hi! Welcome to my Web Server!</h1>
|
|
<div class="navborder">
|
|
<a class="button" href="index.html">Home</a>
|
|
<a class="button" href="https://gitea.calebfontenot.com">Gitea</a>
|
|
<a class="button" href="https://search.calebfontenot.com">SearXNG Instance</a>
|
|
<a class="button" href="dynmap.html">Minecraft Server Dynamic Maps</a>
|
|
<a class="button" href="mario">Mario</a>
|
|
<a class="button" href="sonic1">Sonic 1</a>
|
|
<a class="button" href="sonic2">Sonic 2</a>
|
|
<a class="button" href="soniccd">Sonic CD</a>
|
|
|
|
</div>
|
|
</nav>
|
|
|
|
<h2 class="aboutme">About me<img class="aboutme" src="Caleb.jpg" alt="Caleb" height="5%" width="5%"></h2>
|
|
<p>Hi! My name is <mark>Caleb Fontenot.</mark> I am a software developer in my third semester at South Lousiana Community College. <br> I love writing code! 😁</p>
|
|
<p>Pick a design!</p>
|
|
<div id="selectDesign">
|
|
<input id=inputText>
|
|
<select id="designSelections" name="designSelections">
|
|
<option value="design1">Design 1</option>
|
|
<option value="design2">Design 2 (Triangle)</option>
|
|
<option value="design3">Design 3 (Triangle, varient 2)</option>
|
|
<option value="design4">Design 4 (Circle)</option>
|
|
<option value="design5">Design 5 (Circle, varient 2)</option>
|
|
</select>
|
|
<input class="button" type="button" onclick="drawDesign();" value="Draw design">
|
|
</div>
|
|
<script>
|
|
function drawDesign() {
|
|
let event = document.getElementById('designSelections');
|
|
let value = event.options[event.selectedIndex].value;
|
|
//alert(value);
|
|
let inputText = document.getElementById("inputText").value;
|
|
let designText;
|
|
switch (value) {
|
|
case "design1":
|
|
designText = design1(inputText);
|
|
break;
|
|
case "design2":
|
|
designText = design2(inputText);
|
|
break;
|
|
case "design3":
|
|
designText = design3(inputText);
|
|
break;
|
|
case "design4":
|
|
designText = design4(inputText);
|
|
break;
|
|
case "design5":
|
|
designText = design5(inputText);
|
|
break;
|
|
}
|
|
document.getElementById("jsOutput").innerHTML = designText;
|
|
}
|
|
|
|
function design1(input) {
|
|
console.log("Running design1...");
|
|
let outputString;
|
|
let startEnd = "";
|
|
for (let i = 0; i < input.length + 2; i++) {
|
|
startEnd += "*";
|
|
}
|
|
outputString = startEnd + "<br>";
|
|
outputString += "*" + "<br>";
|
|
outputString += "* " + input + "<br>";
|
|
outputString += "*" + "<br>";
|
|
outputString += startEnd;
|
|
return outputString;
|
|
}
|
|
function design2(input) {
|
|
console.log("Running design2...");
|
|
let outputString;
|
|
let height = (input.length * 2) + 6;
|
|
let mid = Math.trunc(height / 2) + 1;
|
|
if (height % 2 == 0) {
|
|
height++;
|
|
}
|
|
outputString = "";
|
|
for (let i = 0; i < height; i++) {
|
|
if (mid == i) { //Determine if we're in the middle of the triangle
|
|
outputString += "**" + input + "**";
|
|
} else {
|
|
for (let j = 0; j < i; j++) {
|
|
outputString += "*";
|
|
}
|
|
}
|
|
outputString += "<br>";
|
|
}
|
|
return outputString;
|
|
}
|
|
function design3(input) {
|
|
console.log("Running design3...");
|
|
let outputString;
|
|
let height = (input.length * 2) + 6;
|
|
let mid = Math.trunc(height / 2) + 1;
|
|
if (height % 2 == 0) {
|
|
height++;
|
|
}
|
|
outputString = "";
|
|
if (mid % 2 == 1) { // Skip a line if odd
|
|
var subOffset = 1;
|
|
var addOffset = 0;
|
|
} else {
|
|
var subOffset = 0;
|
|
var addOffset = 1;
|
|
}
|
|
for (let i = 0; i < mid - addOffset; i++) {
|
|
for (let j = 0; j < i; j++) {
|
|
if (i % 2 == 1) {
|
|
if (i != (mid - 1)) {
|
|
if (i == 0 || (j == 0 || j == (i - 1))) { // Check if we're at the beginning or end of the line
|
|
outputString += "*";
|
|
} else {
|
|
outputString += " ";
|
|
}
|
|
}
|
|
}
|
|
}
|
|
outputString += "<br>";
|
|
}
|
|
outputString += "* " + input + " *<br>";
|
|
for (let i = mid - subOffset; i > 0; i--) {
|
|
for (let j = 0; j < i; j++) {
|
|
if (i % 2 == 1) {
|
|
if (j != (mid - 1) || (j != mid)) {
|
|
if ((i == 0 || (j == 0 || j == (i - 1)))) { // Check if we're at the beginning or end of the line
|
|
outputString += "*";
|
|
} else {
|
|
outputString += " ";
|
|
}
|
|
}
|
|
}
|
|
}
|
|
outputString += "<br>";
|
|
}
|
|
return outputString;
|
|
}
|
|
|
|
function design4(input) {
|
|
let outputString = "";
|
|
let outputLine = "";
|
|
let radius = (input.length + 1);
|
|
let mid = radius;
|
|
if (mid % 2 == 1) {
|
|
var spaceOffset = " ";
|
|
} else {
|
|
var spaceOffset = "";
|
|
}
|
|
console.log(radius, mid);
|
|
// dist represents distance to the center
|
|
let dist = parseFloat(0);
|
|
let space = ""
|
|
for (let i = 0; i < (input.length / 2); ++i) {
|
|
space += " ";
|
|
}
|
|
// for horizontal movement
|
|
var i;
|
|
var j;
|
|
let lineHasInput = false;
|
|
for (i = 0; i <= 2 * radius; i++) {
|
|
lineHasInput = false;
|
|
if (Math.trunc(i) != mid) {
|
|
// for vertical movement
|
|
for (j = 0; j <= 2 * radius; j++) {
|
|
dist = Math.sqrt(
|
|
((i - radius) * (i - radius) * 4) + // (* 4) accounts for the offset between lines
|
|
(j - radius) * (j - radius)
|
|
);
|
|
//console.log(i, j, radius, dist);
|
|
// dist should be in the range (radius - 0.5)
|
|
// and (radius + 0.5) to print stars(*)
|
|
|
|
|
|
if (dist > radius - 1 && dist < radius + 1) { //&& dist > radius - 1
|
|
lineHasInput = true;
|
|
outputLine += "·"; //zero-width space
|
|
} else {
|
|
outputLine += " ";
|
|
}
|
|
}
|
|
} else {
|
|
lineHasInput = true;
|
|
outputLine += "·" + space + input + space + spaceOffset + "·"; //zero-width space
|
|
}
|
|
|
|
//console.log(i, j, outputLine);
|
|
if (lineHasInput) {
|
|
console.log("outputLine", outputLine);
|
|
outputString += outputLine + "<br>";
|
|
}
|
|
outputLine = "";
|
|
}
|
|
return outputString;
|
|
}
|
|
|
|
var charIterateState;
|
|
const surrogatePairs = /[\uD800-\uDBFF][\uDC00-\uDFFF]/g;
|
|
function charIterate(input) {
|
|
let stringLength = (input.length - 1);
|
|
let temp = input.split('');
|
|
for (let i = 0; i < stringLength; ++i) {
|
|
let compareString = temp.join("");
|
|
let stringEval = undefined, stringEvalIndex = undefined;
|
|
while ((stringEval = surrogatePairs.exec(compareString)) !== null) {
|
|
stringEvalIndex = stringEval.index;
|
|
console.log("emoji is at index", stringEvalIndex);
|
|
}
|
|
if (stringEvalIndex == i) {
|
|
stringLength--;
|
|
temp.splice(i, 1);
|
|
console.log("Decreasing stringLength variable to", stringLength);
|
|
}
|
|
}
|
|
if (charIterateState == undefined) {
|
|
//console.log("undefined! setting to zero");
|
|
charIterateState = 0;
|
|
} else {
|
|
if (charIterateState < stringLength) {
|
|
charIterateState++;
|
|
} else {
|
|
charIterateState = 0;
|
|
}
|
|
}
|
|
//console.log(charIterateState, fixedCharAt(input, charIterateState));
|
|
return charIterateState;
|
|
}
|
|
|
|
function design5(input) {
|
|
charIterateState = undefined;
|
|
let outputString = "";
|
|
let outputLine = "";
|
|
let radius = (input.length);
|
|
let mid = radius;
|
|
if (mid % 2 == 1) {
|
|
var spaceOffset = " ";
|
|
} else {
|
|
var spaceOffset = "";
|
|
}
|
|
console.log(radius, mid);
|
|
// dist represents distance to the center
|
|
let dist = parseFloat(0);
|
|
let space = ""
|
|
for (let i = 0; i < (input.length / 2); ++i) {
|
|
space += " ";
|
|
}
|
|
// for horizontal movement
|
|
var i;
|
|
var j;
|
|
let lineHasInput = false;
|
|
for (i = 0; i <= 2 * radius; i++) {
|
|
lineHasInput = false;
|
|
if (Math.trunc(i) != mid) {
|
|
// for vertical movement
|
|
for (j = 0; j <= 2 * radius; j++) {
|
|
dist = Math.sqrt(
|
|
((i - radius) * (i - radius) * 4) + // (* 4) accounts for the offset between lines
|
|
(j - radius) * (j - radius)
|
|
);
|
|
//console.log(i, j, radius, dist);
|
|
// dist should be in the range (radius - 0.5)
|
|
// and (radius + 0.5) to print stars(*)
|
|
|
|
|
|
if (dist > radius - 1 && dist < radius + 1) { //&& dist > radius - 1
|
|
lineHasInput = true;
|
|
outputLine += "" + fixedCharAt(input, charIterate(input)); //zero-width space
|
|
} else {
|
|
outputLine += " ";
|
|
}
|
|
}
|
|
} else {
|
|
lineHasInput = true;
|
|
outputLine += fixedCharAt(input, charIterate(input)) + space + input + space + spaceOffset + fixedCharAt(input, charIterate(input));
|
|
}
|
|
|
|
//console.log(i, j, outputLine);
|
|
if (lineHasInput) {
|
|
outputString += outputLine + "<br>";
|
|
}
|
|
outputLine = "";
|
|
}
|
|
return outputString;
|
|
}
|
|
|
|
// Code from https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/String/charAt
|
|
|
|
function fixedCharAt(str, idx) {
|
|
str = String(str);
|
|
|
|
//const surrogatePairs = /[\uD800-\uDBFF][\uDC00-\uDFFF]/g;
|
|
while (surrogatePairs.exec(str) !== null) {
|
|
const lastIdx = surrogatePairs.lastIndex;
|
|
if (lastIdx - 2 < idx) {
|
|
idx++;
|
|
} else {
|
|
break;
|
|
}
|
|
}
|
|
|
|
if (idx >= str.length || idx < 0) {
|
|
return "";
|
|
}
|
|
|
|
let ret = str.charAt(idx);
|
|
if (
|
|
/[\uD800-\uDBFF]/.test(ret) &&
|
|
/[\uDC00-\uDFFF]/.test(str.charAt(idx + 1))
|
|
) {
|
|
// Go one further, since one of the "characters" is part of a surrogate pair
|
|
ret += str.charAt(idx + 1);
|
|
}
|
|
return ret;
|
|
}
|
|
</script>
|
|
<p id="jsOutput"></p>
|
|
<img id=riitag src="https://tag.rc24.xyz/294976590658666497/tag.max.png" alt="My RiiTag" width=1024>
|
|
<p>
|
|
<a href="https://jigsaw.w3.org/css-validator/check/referer">
|
|
<img style="border:0;width:88px;height:31px" src="https://jigsaw.w3.org/css-validator/images/vcss"
|
|
alt="Valid CSS!" />
|
|
</a>
|
|
</p>
|
|
|
|
|
|
<footer>
|
|
<a href=https://gitea.calebfontenot.com/CCF_100/frontpage class=button>Caleb Fontenot, 2023</a>
|
|
</footer>
|
|
</div>
|
|
</body>
|
|
|
|
|
|
|
|
</html>
|