As of currently, the light mode on this site doesn't live up to what I want it to be. I want it to be something that is the opposite of the dark mode, and it really isn't that. Expect it to change. But, in case you do still want to view it, here are the current css variable colors:
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/blog/Changing_the_Light-mode.txt b/blog/Changing_the_Light-mode.txt
new file mode 100644
index 0000000..01cfbc2
--- /dev/null
+++ b/blog/Changing_the_Light-mode.txt
@@ -0,0 +1,5 @@
+---
+title: Changing the light-mode
+date: 2021 Sep 11
+---
+As of currently, the light mode on this site doesn't live up to what I want it to be. I want it to be something that is the opposite of the dark mode, and it really isn't that. Expect it to change. But, in case you do still want to view it, here are the current css variable colors:
Inorder to create a drop-down selection list in HTML, we must first understand why they are important. Drop-down lists can be used in lots of ways, from creating a way for people to chose from a strict set of options, to making an on-off switch(even though you should use buttons for that) Before we start, here is an example:
It has it's own tags, know as <select> and <option>. Using these is alittle like making a list, if you've ever made one. Here's an example bit of HTML.
<select>
<option>op 1</option>
<option>op 2</option>
</select>
Next we want to add values to <options>, and an id(#) to <select>. You most-likely already know how to do ids, and maybe also values(if you have used input in any way), so I'll leave it up to you. However, you may not know some things that could be useful here, such as preselections, or making things update upon being changed, well, you can do preselections with selected in the <option> that you want to be preselected. Changes done the page upon the change of the selection in the drop-down(or anything else that can be changed by the user) is onchange="submitFunction()" being placed in the <select>. Let's check back on the code that we made at the code example:
Inorder to access the selected option with JavaScript, use document.getElementById("selection").value That's basically it, feel free to CTRL + CCTRL + V it. /s
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/blog/Creating_HTML_DD_List.txt b/blog/Creating_HTML_DD_List.txt
new file mode 100644
index 0000000..7893c77
--- /dev/null
+++ b/blog/Creating_HTML_DD_List.txt
@@ -0,0 +1,5 @@
+---
+title: Creating a HTML drop-down list
+date: 2021 Oct 01
+---
+Inorder to create a drop-down selection list in HTML, we must first understand why they are important. Drop-down lists can be used in lots of ways, from creating a way for people to chose from a strict set of options, to making an on-off switch(even though you should use buttons for that) Before we start, here is an example:
It has it's own tags, know as <select> and <option>. Using these is alittle like making a list, if you've ever made one. Here's an example bit of HTML.
<select>
<option>op 1</option>
<option>op 2</option>
</select>
Next we want to add values to <options>, and an id(#) to <select>. You most-likely already know how to do ids, and maybe also values(if you have used input in any way), so I'll leave it up to you. However, you may not know some things that could be useful here, such as preselections, or making things update upon being changed, well, you can do preselections with selected in the <option> that you want to be preselected. Changes done the page upon the change of the selection in the drop-down(or anything else that can be changed by the user) is onchange="submitFunction()" being placed in the <select>. Let's check back on the code that we made at the code example:
Inorder to access the selected option with JavaScript, use document.getElementById("selection").value That's basically it, feel free to CTRL + CCTRL + V it. /s
\ No newline at end of file
diff --git a/blog/How-To-make-mockups.html b/blog/How-To-make-mockups.html
new file mode 100644
index 0000000..f64ff89
--- /dev/null
+++ b/blog/How-To-make-mockups.html
@@ -0,0 +1,89 @@
+
+
+
+
+
+
+
+
+ How to make mockups - S0G
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
This post isn't very good, and I'm not proud of it.
The first step to making a mockup is to open up the inpect menu, you may be able to do this using ctrl+shifT+i(or f12)
this will be different from browser to browser.
once you see inspect element open, simply go to the page you're making a mockup for(ex. MyStuff; or if you're making a new page, go to the page that looks the closest.), and press ctrl+shifT+c, and click on the area that you want to change(ex. the + New Project button.
now that you've selected the element, let's learn how to edit it! You should see the element that you clicked on(using the ctrl+shifT+c command) highlighted in blue. Inside of the element(if you selected text, or even an image), you should see a darker area, that isn't red, double click on it, it should now be hilighted, now type in whatever you want(if it's an image, make sure to put in an image link, ex. https://imagehoster.com/png/png.png; if you clicked on a link(in the "" in "a href=''", unselect it and select the part ""here"").
anyways... if you don't have the monna lisa yet, just give up /s
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/blog/How-To-make-mockups.txt b/blog/How-To-make-mockups.txt
new file mode 100644
index 0000000..0949fe4
--- /dev/null
+++ b/blog/How-To-make-mockups.txt
@@ -0,0 +1,5 @@
+---
+title: How to make mockups
+date: 2021 Apr 22
+---
+
This post isn't very good, and I'm not proud of it.
The first step to making a mockup is to open up the inpect menu, you may be able to do this using ctrl+shifT+i(or f12)
this will be different from browser to browser.
once you see inspect element open, simply go to the page you're making a mockup for(ex. MyStuff; or if you're making a new page, go to the page that looks the closest.), and press ctrl+shifT+c, and click on the area that you want to change(ex. the + New Project button.
now that you've selected the element, let's learn how to edit it! You should see the element that you clicked on(using the ctrl+shifT+c command) highlighted in blue. Inside of the element(if you selected text, or even an image), you should see a darker area, that isn't red, double click on it, it should now be hilighted, now type in whatever you want(if it's an image, make sure to put in an image link, ex. https://imagehoster.com/png/png.png; if you clicked on a link(in the "" in "a href=''", unselect it and select the part ""here"").
anyways... if you don't have the monna lisa yet, just give up /s
\ No newline at end of file
diff --git a/blog/How-to-Store-Passwords.html b/blog/How-to-Store-Passwords.html
new file mode 100644
index 0000000..ae93d00
--- /dev/null
+++ b/blog/How-to-Store-Passwords.html
@@ -0,0 +1,122 @@
+
+
+
+
+
+
+
+
+ How to Store a Passwords - S0G
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
Disclaimer: The world of cyber-security is an incredibly complex and constantly evolving topic, and I am not a cyber-security researcher; I create projects for fun.
+
+
Storing a password in a server can be intimidating. Password management is incredibly tricky, as anything you mess up could compromise your users' password(s). Thankfully, random websites you've never visited before have a pure HTML blog post from 2023 about that exact topic, and how to do it properly.
+
+
Basically, it's just this sequence of steps:
+
+
+
Generate a long random sequence of characters, this is called a salt(generate for each user, do not use a master salt)
+
Prepend(or append, it doesn't matter, just keep it consistent) this to the user's password
+
Use a hashing algorithm, such as PBKDF2, to generate a unique sequence of characters that will uniquely identify that password.
+
Store the salt and hash in the same place, do not store the password on it's own.
+
+
+
And to check if a password is right, repeat the steps, except rather than generating a random sequence of characters, get the sequence of characters that you've stored along with the hash.
+
+
Why Do This?
+
+
You might be thinking: That's a bit arbitrary innit? And if you aren't then you can stop reading now.
+
+
This method of storing passwords is the only way to ensure that you are securely storing them. So let's go through some other ways, and why they aren't so good.
+
+
Plaintext Passwords
+
+
Storing your passwords in plaintext allows anyone who can get into your server to easily take any password they want, as no matter how good your users' password is, their account will be hacked if an unauthorized or malicious individual is able to get in.
+
+
Encrypted Passwords
+
+
This is basically just plaintext with additional steps. As long as your master-key is stored somewhere, it will get stolen as soon as somebody manages to get into your system.
+
+
Bare Hashing
+
+
A hash isn't able to be undone, meaning theoretically you should be able to just hash your password. This, while a fair assumption, has unfortunately been incorrect for quite some time. There are databases online that store every word in the english language(or just some words) in addition to common passwords and their hashes, and users will often use words for their passwords, even though it's insecure.
+
+
This is where salts come in. Due to the nature of hashes, even a single change in a string will entirely change it's hash, as such, if you add a random sequence of characters to a string, then you can entirely change it's hash.
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/blog/How-to-Store-Passwords.txt b/blog/How-to-Store-Passwords.txt
new file mode 100644
index 0000000..c2043ef
--- /dev/null
+++ b/blog/How-to-Store-Passwords.txt
@@ -0,0 +1,35 @@
+---
+title: How to Store a Passwords
+date: 2023 Nov 2
+---
+**Disclaimer**: The world of cyber-security is an incredibly complex and constantly evolving topic, and I am not a cyber-security researcher; I create projects for fun.
+
+Storing a password in a server can be intimidating. Password management is incredibly tricky, as anything you mess up could compromise your users' password(s). Thankfully, random websites you've never visited before have a pure HTML blog post from 2023 about that exact topic, and how to do it properly.
+
+Basically, it's just this sequence of steps:
+
+* Generate a long random sequence of characters, this is called a *[salt](https://en.wikipedia.org/wiki/Salt_(cryptography))*(generate for each user, do not use a master salt)
+* Prepend(or append, it doesn't matter, just keep it consistent) this to the user's password
+* Use a [hashing algorithm](https://en.wikipedia.org/wiki/Hash_function), such as [PBKDF2](https://en.wikipedia.org/wiki/PBKDF2), to generate a unique sequence of characters that will uniquely identify that password.
+* Store the salt and hash in the same place, *do not* store the password on it's own.
+
+And to check if a password is right, repeat the steps, except rather than generating a random sequence of characters, get the sequence of characters that you've stored along with the hash.
+
+## Why Do *This*?
+You might be thinking: *That's a bit arbitrary innit?* And if you aren't then you can stop reading now.
+
+This method of storing passwords is the only way to ensure that you are securely storing them. So let's go through some other ways, and why they aren't so good.
+
+### Plaintext Passwords
+
+Storing your passwords in plaintext allows anyone who can get into your server to easily take any password they want, as no matter how good your users' password is, their account will be hacked if an unauthorized or malicious individual is able to get in.
+
+### Encrypted Passwords
+
+This is basically just plaintext with additional steps. As long as your master-key is stored somewhere, it will get stolen as soon as somebody manages to get into your system.
+
+### Bare Hashing
+
+A hash isn't able to be undone, meaning theoretically you should be able to *just* hash your password. This, while a fair assumption, has unfortunately been incorrect for quite some time. There are databases online that store every word in the english language(or just some words) in addition to common passwords and their hashes, and users will often use words for their passwords, even though it's insecure.
+
+This is where salts come in. Due to the nature of hashes, even a single change in a string will entirely change it's hash, as such, if you add a random sequence of characters to a string, then you can entirely change it's hash.
\ No newline at end of file
diff --git a/blog/How-to-copy-and-paste-on-mobile.html b/blog/How-to-copy-and-paste-on-mobile.html
new file mode 100644
index 0000000..e497ab4
--- /dev/null
+++ b/blog/How-to-copy-and-paste-on-mobile.html
@@ -0,0 +1,89 @@
+
+
+
+
+
+
+
+
+ How to Copy and Paste on mobile - S0G
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
This post isn't very good, and I'm not proud of it.
Recently, I've been seeing a lot of people coming up with one excuse for not linking the dupelicate topic in the suggestions forum. They say something like,
I'm on mobile!!!!! 😖😭😫
this is not a correct argument, so I've decided to make this post to prove it.
Safari/iOS
the way that you copy and paste on Safari is by double taping on the text, then dragging until you've selected all the text(the next bit works for links, not this)
Coping links
tap and hold on the link until you see:
Paste
going to any textbox, in the top-lefT-hand conner, you should see a little clipboard icon(as long as you aren't selecting any text), press it. tap "copy(circled in red)"
🏷Note: I don't own an android tablet or phone, so take this with a grain of salt
Chrome/Android
press and hold until a few selection boxes come up(might work for links)
pasting
tap and hold int the text box, you should see "paste," now click that(boxed in :Image Source
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/blog/How-to-copy-and-paste-on-mobile.txt b/blog/How-to-copy-and-paste-on-mobile.txt
new file mode 100644
index 0000000..86e082a
--- /dev/null
+++ b/blog/How-to-copy-and-paste-on-mobile.txt
@@ -0,0 +1,5 @@
+---
+title: How to Copy and Paste on mobile
+date: 2021 May 05
+---
+
This post isn't very good, and I'm not proud of it.
Recently, I've been seeing a lot of people coming up with one excuse for not linking the dupelicate topic in the suggestions forum. They say something like,
I'm on mobile!!!!! 😖😭😫
this is not a correct argument, so I've decided to make this post to prove it.
Safari/iOS
the way that you copy and paste on Safari is by double taping on the text, then dragging until you've selected all the text(the next bit works for links, not this)
Coping links
tap and hold on the link until you see:
Paste
going to any textbox, in the top-lefT-hand conner, you should see a little clipboard icon(as long as you aren't selecting any text), press it. tap "copy(circled in red)"
🏷Note: I don't own an android tablet or phone, so take this with a grain of salt
Chrome/Android
press and hold until a few selection boxes come up(might work for links)
pasting
tap and hold int the text box, you should see "paste," now click that(boxed in :Image Source
\ No newline at end of file
diff --git a/blog/How_To_Make_Tea.html b/blog/How_To_Make_Tea.html
new file mode 100644
index 0000000..5fecbfe
--- /dev/null
+++ b/blog/How_To_Make_Tea.html
@@ -0,0 +1,89 @@
+
+
+
+
+
+
+
+
+ How to Make the perfect Tea. - S0G
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
Tea is the perfect fit for most meals, breakfast, 2nd breakfast, morning tea, lunch, afTernoon tea, dinner, or supper. But how do I make it? Here's how I make my tea.
Step 1
The first step is to get the brand of tea you like. I personally like stuff such as Mighty Leaf, it tastes strong, and your able to use it 3 times without it getting weaker, and even then, you can still use it more, it really doesn't lose it's weakness.
Step 2
Get a mug, or tea cup. I personally like mugs, as they are normally bigger, meaning you don't have to refill as much as a tea cup.
Step 3
Get your tea, if you're using loose leaf, I'd use a smaller cup to make it, then use a strainer to the leaves out, as it adds texture that I don't like personally, otherwise just put the tea bag in, it is at this point that I like to stir it.
Final Step
Enjoy. You can add sugar and milk cream, if you're into those kinda things... even lemon if you really want.
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/blog/How_To_Make_Tea.txt b/blog/How_To_Make_Tea.txt
new file mode 100644
index 0000000..15a59e2
--- /dev/null
+++ b/blog/How_To_Make_Tea.txt
@@ -0,0 +1,5 @@
+---
+title: How to Make the perfect Tea.
+date: 2021 Sep 28
+---
+
this is opinion based, there's no perfect tea
Tea is the perfect fit for most meals, breakfast, 2nd breakfast, morning tea, lunch, afTernoon tea, dinner, or supper. But how do I make it? Here's how I make my tea.
Step 1
The first step is to get the brand of tea you like. I personally like stuff such as Mighty Leaf, it tastes strong, and your able to use it 3 times without it getting weaker, and even then, you can still use it more, it really doesn't lose it's weakness.
Step 2
Get a mug, or tea cup. I personally like mugs, as they are normally bigger, meaning you don't have to refill as much as a tea cup.
Step 3
Get your tea, if you're using loose leaf, I'd use a smaller cup to make it, then use a strainer to the leaves out, as it adds texture that I don't like personally, otherwise just put the tea bag in, it is at this point that I like to stir it.
Final Step
Enjoy. You can add sugar and milk cream, if you're into those kinda things... even lemon if you really want.
\ No newline at end of file
diff --git a/blog/Is_Kris_the_Knight.html b/blog/Is_Kris_the_Knight.html
new file mode 100644
index 0000000..a89c892
--- /dev/null
+++ b/blog/Is_Kris_the_Knight.html
@@ -0,0 +1,89 @@
+
+
+
+
+
+
+
+
+ Is Kris the Knight? - S0G
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
Is Kris the Knight? At face value, this seemes insain. Right? Well, let's look at the evidence First and formost, the Knight opens Dark Fountains. Now, what does Kris do at the end of Chapter 2? They create a Dark Fountain. Second, what does Kris look like in Dark Worlds? That's right, a Knight. This is what Kris looks like in a Dark World, they're wearing plated armor. They even have a sword(not shown in image). We know that Kris made a Dark Fountain at the end of Chapter 2, so is it really that far off to assume that they also made the one in the librarby's computer lab? Or the on in the closet for that matter. Well, we know that they had thier knife at the end of chapter 1, and only Toby Fox knows what they did before chapter 1. In the end of chapter 2, they rips they soul out before creating the new fountain, and shuffeling around outside; and slashing Torial's tires. Infact, they rips out their heart in the end of chapter 1, too. Afterward, they presumably went to librarby and made a fountain in the computer lab. This is a really common thereoy, but it really needs more evidence to be collected, and more speculating to be done. taken from Fandom.
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/blog/Is_Kris_the_Knight.txt b/blog/Is_Kris_the_Knight.txt
new file mode 100644
index 0000000..00280ce
--- /dev/null
+++ b/blog/Is_Kris_the_Knight.txt
@@ -0,0 +1,5 @@
+---
+title: Is Kris the Knight?
+date: 2021 Oct 23
+---
+Is Kris the Knight? At face value, this seemes insain. Right? Well, let's look at the evidence First and formost, the Knight opens Dark Fountains. Now, what does Kris do at the end of Chapter 2? They create a Dark Fountain. Second, what does Kris look like in Dark Worlds? That's right, a Knight. This is what Kris looks like in a Dark World, they're wearing plated armor. They even have a sword(not shown in image). We know that Kris made a Dark Fountain at the end of Chapter 2, so is it really that far off to assume that they also made the one in the librarby's computer lab? Or the on in the closet for that matter. Well, we know that they had thier knife at the end of chapter 1, and only Toby Fox knows what they did before chapter 1. In the end of chapter 2, they rips they soul out before creating the new fountain, and shuffeling around outside; and slashing Torial's tires. Infact, they rips out their heart in the end of chapter 1, too. Afterward, they presumably went to librarby and made a fountain in the computer lab. This is a really common thereoy, but it really needs more evidence to be collected, and more speculating to be done. taken from Fandom.
\ No newline at end of file
diff --git a/blog/The_song_that_we_didnt_get_in_undertale.html b/blog/The_song_that_we_didnt_get_in_undertale.html
new file mode 100644
index 0000000..671058d
--- /dev/null
+++ b/blog/The_song_that_we_didnt_get_in_undertale.html
@@ -0,0 +1,89 @@
+
+
+
+
+
+
+
+
+ The Song we didn't get in Undertale - S0G
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
Undertale is an amazing game. I really enjoyed my time playing it. I listen to the sound track a lot(I'm doing it as I write this). I even read a fanmade AU called Inverted Fate. The only thing that I haven't done(and don't intend on doing) is a Genocide Run. But, there's one thing that's kinda been bugging me since it first found out about it. It's the fact that their's a version of Undertale(the song) that wasn't added, and instead was replaced with the version we have now.
The Current Version
The version we got of Undertale was a pretty good one. It's a little sad, while also filled with hope(just like the monsters in the neutral route. It is kinda the song of their hope, since it only plays during the end of the neutral route). Below is the version we got in the game.
The One that could have been
This one is also greate, and I personally think I like it a lot better than the one we have. I feel like it's more happy in tone. Even if it might not fit with what the game would have been trying to fit it's context into, it's still a good song on it's own.
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/blog/The_song_that_we_didnt_get_in_undertale.txt b/blog/The_song_that_we_didnt_get_in_undertale.txt
new file mode 100644
index 0000000..c297711
--- /dev/null
+++ b/blog/The_song_that_we_didnt_get_in_undertale.txt
@@ -0,0 +1,5 @@
+---
+title: The Song we didn't get in Undertale
+date: 2021 Dec 20
+---
+
Undertale is an amazing game. I really enjoyed my time playing it. I listen to the sound track a lot(I'm doing it as I write this). I even read a fanmade AU called Inverted Fate. The only thing that I haven't done(and don't intend on doing) is a Genocide Run. But, there's one thing that's kinda been bugging me since it first found out about it. It's the fact that their's a version of Undertale(the song) that wasn't added, and instead was replaced with the version we have now.
The Current Version
The version we got of Undertale was a pretty good one. It's a little sad, while also filled with hope(just like the monsters in the neutral route. It is kinda the song of their hope, since it only plays during the end of the neutral route). Below is the version we got in the game.
The One that could have been
This one is also greate, and I personally think I like it a lot better than the one we have. I feel like it's more happy in tone. Even if it might not fit with what the game would have been trying to fit it's context into, it's still a good song on it's own.
\ No newline at end of file
diff --git a/blog/Why-inspect-element-is-a-useful-tool.html b/blog/Why-inspect-element-is-a-useful-tool.html
new file mode 100644
index 0000000..fcd00dc
--- /dev/null
+++ b/blog/Why-inspect-element-is-a-useful-tool.html
@@ -0,0 +1,89 @@
+
+
+
+
+
+
+
+
+ Why inspect-element is useful - S0G
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
This post isn't very good, and I'm not proud of it.
So, as of currently, my Ocular Status is Mobile needs a better browser! #MobileSmartBrowser! (Er/Him). Part of the reason for this is so that inspect can be on mobile.
but what makes inspect so important?
Well I'm glad I asked!
So on GitHub, you only have 2000 actions you can do(on the free plan). So that means you need to use them carefully, make sure that you won't do something that wastes an action.
It helps you fix any mistake, before you make anymore.
Of course, you can always download the file, and edit it offline. But inspect element is easier, live, and requires less space in your hard-drive.
Thanks for coming to my Ted-talk.😜🤪
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/blog/Why-inspect-element-is-a-useful-tool.txt b/blog/Why-inspect-element-is-a-useful-tool.txt
new file mode 100644
index 0000000..c1fafb1
--- /dev/null
+++ b/blog/Why-inspect-element-is-a-useful-tool.txt
@@ -0,0 +1,5 @@
+---
+title: Why inspect-element is useful
+date: 2021 May 17
+---
+
This post isn't very good, and I'm not proud of it.
So, as of currently, my Ocular Status is Mobile needs a better browser! #MobileSmartBrowser! (Er/Him). Part of the reason for this is so that inspect can be on mobile.
but what makes inspect so important?
Well I'm glad I asked!
So on GitHub, you only have 2000 actions you can do(on the free plan). So that means you need to use them carefully, make sure that you won't do something that wastes an action.
It helps you fix any mistake, before you make anymore.
Of course, you can always download the file, and edit it offline. But inspect element is easier, live, and requires less space in your hard-drive.
Thanks for coming to my Ted-talk.😜🤪
\ No newline at end of file
diff --git a/blog/Youtube_needs_a_Rest_API.html b/blog/Youtube_needs_a_Rest_API.html
new file mode 100644
index 0000000..c755efd
--- /dev/null
+++ b/blog/Youtube_needs_a_Rest_API.html
@@ -0,0 +1,89 @@
+
+
+
+
+
+
+
+
+ YouTube needs to have an open REST API - S0G
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
Youtube needs an open Rest API. Here are some reasons:
It makes my life easier, as I don't need to write a billion lines of code, and not go throught the paid service known as google cloud console, to get an api key.
It means that you only need to use fetch() on it.
We don't need the most in depth api.
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/blog/Youtube_needs_a_Rest_API.txt b/blog/Youtube_needs_a_Rest_API.txt
new file mode 100644
index 0000000..2276465
--- /dev/null
+++ b/blog/Youtube_needs_a_Rest_API.txt
@@ -0,0 +1,5 @@
+---
+title: YouTube needs to have an open REST API
+date: 2021 Sep 29
+---
+Youtube needs an open Rest API. Here are some reasons:
It makes my life easier, as I don't need to write a billion lines of code, and not go throught the paid service known as google cloud console, to get an api key.
It means that you only need to use fetch() on it.
We don't need the most in depth api.
\ No newline at end of file
diff --git a/blog/checkbox-custom-styles.html b/blog/checkbox-custom-styles.html
new file mode 100644
index 0000000..e628d47
--- /dev/null
+++ b/blog/checkbox-custom-styles.html
@@ -0,0 +1,89 @@
+
+
+
+
+
+
+
+
+ Customize an HTML Checkbox - S0G
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/blog/checkbox-custom-styles.txt b/blog/checkbox-custom-styles.txt
new file mode 100644
index 0000000..c29e268
--- /dev/null
+++ b/blog/checkbox-custom-styles.txt
@@ -0,0 +1,5 @@
+---
+title: Customize an HTML Checkbox
+date: 2022 Feb 19
+---
+
Checkboxes are hard to style. But when you're making a website, they may look ugly.
As you can see here, this bland checkbox does not fit into my clearly great website(/s). But really, it does not fit in at all.
The first step toward styling it how we want it is to give it an appearence of none, and a width and height that are what you want.
input[type="checkbox"] {
appearance: none; width: 15px; height: 15px;
}
Now we can do whatever we want to it. Also, remeber to add a checked pseudo
This is a simple tutorial on how to make a simple theme switcher.
Step 1: Creating the themes
The first step is to create the themes in your stylesheet, you can have as many as you want. Just make sure to remeber all their names within your CSS.
Step 2: Making an array
This is why you need to remeber all their names within the CSS. You need to add them all to an array in your JS. Below is an example of an array containing some themes.
const themes = ["light", "dark", "gamer"]
Step 3: Switching themes
This is the part you've been waiting for! The actual content switcher. It's surprisingly simple.
First, get the index of the current theme using let currentTheme = themes.indexOf(document.documentElement.className). Then, use an if statement to see if it's more than or equal to the length of the array containing your themes.
In the end, what you just made should look something like the iFrame below.
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/blog/creating_a_theme_switch.txt b/blog/creating_a_theme_switch.txt
new file mode 100644
index 0000000..71b35c4
--- /dev/null
+++ b/blog/creating_a_theme_switch.txt
@@ -0,0 +1,5 @@
+---
+title: Creating a simple theme switcher
+date: 2021 Dec 08
+---
+This is a simple tutorial on how to make a simple theme switcher.
Step 1: Creating the themes
The first step is to create the themes in your stylesheet, you can have as many as you want. Just make sure to remeber all their names within your CSS.
Step 2: Making an array
This is why you need to remeber all their names within the CSS. You need to add them all to an array in your JS. Below is an example of an array containing some themes.
const themes = ["light", "dark", "gamer"]
Step 3: Switching themes
This is the part you've been waiting for! The actual content switcher. It's surprisingly simple.
First, get the index of the current theme using let currentTheme = themes.indexOf(document.documentElement.className). Then, use an if statement to see if it's more than or equal to the length of the array containing your themes.
In the end, what you just made should look something like the iFrame below.
\ No newline at end of file
diff --git a/blog/creatingaswitch.html b/blog/creatingaswitch.html
new file mode 100644
index 0000000..fcf593b
--- /dev/null
+++ b/blog/creatingaswitch.html
@@ -0,0 +1,89 @@
+
+
+
+
+
+
+
+
+ Creating a Switch in HTML and CSS - S0G
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
A switch is something that is basically just a nicer checkbox. Here, I'll be showing you how to make one.
The first step is to create checkbox with any classname; I'll be using switch.
<style>
input[type=checkbox].switch {}
</style> <input type="checkbox" class="switch">
Next step is to add an appearance of none to the CSS--make sure to add -moz- and -webkit-. After that, you're going to want to set it so that the checkbox a rectangle--make sure it's in px. We also want to set the position to relative
Next we want to create a ::before pseudo. In there we want to make it have a position of relative, a width and height that are abit less than the height of the main switch, a display of inline-block, a top and left of 0, a content of anything, color of transparent, and a background color that's different from the one in the main switch.
Finally add a pseudo called :checked which checks if a checkbox, or a radio, was checked; you'll want to change the before pseudo if the the checkbox is checked. You need to set the left to a bit less than the width of the checkbox; you can adjust it until it looks right to you.
Now, let's look at what it looks like
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/blog/creatingaswitch.txt b/blog/creatingaswitch.txt
new file mode 100644
index 0000000..a0fefe0
--- /dev/null
+++ b/blog/creatingaswitch.txt
@@ -0,0 +1,5 @@
+---
+title: Creating a Switch in HTML and CSS
+date: 2022 Feb 11
+---
+
A switch is something that is basically just a nicer checkbox. Here, I'll be showing you how to make one.
The first step is to create checkbox with any classname; I'll be using switch.
<style>
input[type=checkbox].switch {}
</style> <input type="checkbox" class="switch">
Next step is to add an appearance of none to the CSS--make sure to add -moz- and -webkit-. After that, you're going to want to set it so that the checkbox a rectangle--make sure it's in px. We also want to set the position to relative
Next we want to create a ::before pseudo. In there we want to make it have a position of relative, a width and height that are abit less than the height of the main switch, a display of inline-block, a top and left of 0, a content of anything, color of transparent, and a background color that's different from the one in the main switch.
Finally add a pseudo called :checked which checks if a checkbox, or a radio, was checked; you'll want to change the before pseudo if the the checkbox is checked. You need to set the left to a bit less than the width of the checkbox; you can adjust it until it looks right to you.
Now, let's look at what it looks like
\ No newline at end of file
diff --git a/blog/feed.atom b/blog/feed.atom
new file mode 100644
index 0000000..92bc9d2
--- /dev/null
+++ b/blog/feed.atom
@@ -0,0 +1,501 @@
+
+
+ https://steve0greatness.github.io/blog/
+
+
+ Steve0Greatness' Blog
+ A blog by a human being
+
+ Steve0Greatness
+ https://steve0greatness.github.io
+
+ Custom w/Jinja
+ 2024-01-01T00:00:00Z
+
+
+ My blog is now in one place
+
+
+
+
Alright, I've now moved all my full blog posts over to this one website. There might be other I miss in other places, but I'll add them here soon. I will not be moving over my micro-blogs, however. Those are too small, and I'd rather keep those separated anyway.
+
+
I'm not a fan of how I wrote before December of 2022, everything there is filled with spelling mistakes and grammar issues, I also think most of it was rude towards the reader, which is not a good impression.
+
+
+ singular-blog.html
+ 2024-01-01T00:00:00Z
+ 2024-01-01T00:00:00Z
+
+
+
+ How to Store a Passwords
+
+
+
+
Disclaimer: The world of cyber-security is an incredibly complex and constantly evolving topic, and I am not a cyber-security researcher; I create projects for fun.
+
+
Storing a password in a server can be intimidating. Password management is incredibly tricky, as anything you mess up could compromise your users' password(s). Thankfully, random websites you've never visited before have a pure HTML blog post from 2023 about that exact topic, and how to do it properly.
+
+
Basically, it's just this sequence of steps:
+
+
+
Generate a long random sequence of characters, this is called a salt(generate for each user, do not use a master salt)
+
Prepend(or append, it doesn't matter, just keep it consistent) this to the user's password
+
Use a hashing algorithm, such as PBKDF2, to generate a unique sequence of characters that will uniquely identify that password.
+
Store the salt and hash in the same place, do not store the password on it's own.
+
+
+
And to check if a password is right, repeat the steps, except rather than generating a random sequence of characters, get the sequence of characters that you've stored along with the hash.
+
+
Why Do This?
+
+
You might be thinking: That's a bit arbitrary innit? And if you aren't then you can stop reading now.
+
+
This method of storing passwords is the only way to ensure that you are securely storing them. So let's go through some other ways, and why they aren't so good.
+
+
Plaintext Passwords
+
+
Storing your passwords in plaintext allows anyone who can get into your server to easily take any password they want, as no matter how good your users' password is, their account will be hacked if an unauthorized or malicious individual is able to get in.
+
+
Encrypted Passwords
+
+
This is basically just plaintext with additional steps. As long as your master-key is stored somewhere, it will get stolen as soon as somebody manages to get into your system.
+
+
Bare Hashing
+
+
A hash isn't able to be undone, meaning theoretically you should be able to just hash your password. This, while a fair assumption, has unfortunately been incorrect for quite some time. There are databases online that store every word in the english language(or just some words) in addition to common passwords and their hashes, and users will often use words for their passwords, even though it's insecure.
+
+
This is where salts come in. Due to the nature of hashes, even a single change in a string will entirely change it's hash, as such, if you add a random sequence of characters to a string, then you can entirely change it's hash.
Here is my idea for automating the collection of healing materials(such as Beryl Nuts) in Satisfactory
+
+
Plant Pods
+
+
Plant pods would be researchable in the Nutrients section of the MAM. It would cost:
+* 5 modular frames
+* 10 steel pipes
+* 20 biofuel
+
+
to research.
+
+
You'd be able to build it in a new _Farming_ section in the production category of the build menu. It would cost the user:
+* 4 steel pipes
+* 2 quickwire
+* 5 biofuel
+
+
to build. It would require 1 MW of power to function. Plants that are left without power while in there will not continue growing or providing harvest, however they will not die(that'd be annoying if they did).
+
+
The user would be able to interact with the planting pod to bring up a menu that tells them what stage of growing it's at(baby, growing, fully grown), how ripe for harvest the plant is(out of 3 states: none, starting, ripe). The UI will have a button to harvest at the bottom, and a box that will allow the plant to be exchanged for another--which would give you a few leaves, proportional to how long it's been growing(0 if baby, 4 if growing, 10 if fully grown), and the amount of fruit they would have gotten from the harvest + 1 extra(for the fruit they put in).
+
+
Robot Farmers
+
+
Researchable under the _Crystal Oscillator_. The research cost is:
+* 10 Crystal Oscillators
+* 5 AI limiter
+* 3 quickwire
+
+
These little farmers need power to survive, which is why the _ROBOT charger_ is unlocked with them.
+This building can be built in the power section. They cost:
+* 15 quickwire
+* 2 modular frames
+* 5 crystal oscillators
+
+
to build.
+
+
Once built, this building acts like the truck station, but instead of coal, it loads power, and it can only unload items from the bot's inventory.
+
+
The Robo-Farmer is then buildable under the _Farming_ section in the production category of the build menu. It costs :
+* 1 Factory Cart
+* 2 Crystal Oscillators
+* 1 AI limiter
+* 3 quickwire
+* 5 steal pipes
+
+
to build.
+
+
These little robots have themselves a little UI that allows you to select items they should farm. Once given a task, these robots will always return to the nearest _ROBOT charger_ when their inventory is full, or they are running low on power(robots will always attempt to keep themselves powered). If the robot cannot find a plant within range that is harvestable, then the they will wait until there is one.
+
+
Getting the most out of these resources
+
+
Robot Farmers are best at traversing on foundations(they spend less power). As such, it is recommended, that the player create a flat platform that has plant pods with some space between for the bots to traverse between them. In the center, the player should build a _ROBOT charger_, as it will allow the robots the run around equally in each direction. Players should also utilize the _Conveyor Lift_ to bring materials to a layer above for sorting, or other purposes.
The basic layout of the disguise command is very simple.
+
+
disguise [class] [team]
+
+
+
class Parameter
+
+
1 : Scout
+
+
2 : Sniper
+
+
3 : Soldier
+
+
4 : Demoman
+
+
5 : Medic
+
+
6 : Heavy
+
+
7 : Pyro
+
+
8 : Spy
+
+
9 : Engineer
+
+
The reason the classes are in this order is that they were added in that order. As mentioned in Quake World Team Fortress § Versions on the Team Fortress wiki, it mentions the classes were added in the order of scout, sniper, soldier, demoman, and medic; then heavy; pyro; and finally spy and engineer.
+
+
team Parameter
+
+
These depend upon what team you're on.
+
+
-1 : Enemy Team
+
+
-2 : Friendly Team
+
+
Specific Teams
+
+
These aren't extremely useful, but they exist. They are independent of the team you're on.
+
+
1 : Blu Team
+
+
2 : Red Team
+
+
Example
+
+
Normally, when you disguise as a spy of your team, you undisguise. This also applies to the disguise command, allowing for an "undisguise" command.
+
+
disguise "8" "-2"
+
+
+
You're also able to put this into a bind, allowing for an undisguise bind.
Fortress Forever is finally playable fully on Linux using Proton-GE version 7-41(note: if you change the setting you will have to reboot the game).
+
+
If you need a quick rundown on how to download and install Proton-GE, I've made a video about that already. It is technically about a different game, however, the problem is still similar enough to apply pretty much the same steps.
+
+
It plays pretty well, the only problem is when a local server changes maps, and the font for some of the menus(and the chat) being very... bad looking. It's not the game's fault for the second one, however, it is still something that's annoying if you don't want to do too much tinkering.
+
+
I'm glad to be able to play this great game on my daily OS without having to open Bottles every time I want to play Fortress Forever.
+
+
Whenever I'm playing Fortress Forever, I'm usually on MaxTF's Midwest server... I have the lowest ping there, not good though.
When I've been trying(and failing) to use Tab on my computer(it's a Macbook) for what feels like forever now. Turns out, it was as simple as hitting Ctrl + F7.
+
+
To be honest, I thought that it was just an issue with FireFox, and then I read Browser keyboard navigation in macOS and realized that it was an issue with MacOS! This should really be an option enabled by default, but Apple is stupid.
+
+
+ macos-page-tab-nav.html
+ 2022-02-26T00:00:00Z
+ 2024-01-17T00:00:00Z
+
+
+
+ The FizzBuzz Program
+
+
+
+
A FizzBuzz Program is a program used in many job interviews to see if a programmer is good at problem solving. There are many ways to make one.
+
+
First let me tell you why I write these programs. These programs, at least in my opinion, are good when you're learning a new programming language. It gives you a problem to solve, and all you need to do to solve it. Incase you're wondering, the problem is to make a program that counts from 1 to 100 and replaces all multiples of 3 with Fizz, all multiples of 5 with Buzz, and multiples of both with FizzBuzz. Generally in interviews, they also ask you to add on more multiples, such as multiples of 7 are replaced with Fuzz, and multiples of 11 are replaced with Bizz.
+
+
Now that I've told you what a FizzBuzz Program is, let me show you how I make them in Python.
+
+
for i in range(1, 100):
+ toPrint = ""
+ print(toPrint)
+
+
+
The first thing I do is I create a for loop, and within it I put a print statement and a variable named toPrint.
+
+
def check(checktomulti, multi, toreturn):
+ if checktomulti % multi == 0:
+ return toreturn
+ return ""
+
+def checkEmpty(string, number):
+ if string == "":
+ return number
+ return string
+
+for i in range(1, 100):
+ toPrint = checkEmpty(check(i, 3, "Fizz") + check(i, 5, "Buzz"), i)
+ print(toPrint)
+
+
+
The next thing I do is I define a function that checks if one number is a multiple of another, and if it is, then it returns the string, otherwise, it returns an empty string.
+
+
Then I make a function that checks if a string is an empty one, if it is, then it returns a number.
+
+
Once I have these 2 functions, I go back into the for loop and make the toPrint variable have the variable for checking if a string is empty(and if it is replace it with a number) check if 2 of the other function that check if one number is a multiple of another(and if it is, return a string). Finally, it prints the output.
+
+
I've tried this method many times. Below are some examples of this method in action!
A switch is something that is basically just a nicer checkbox. Here, I'll be showing you how to make one.
The first step is to create checkbox with any classname; I'll be using switch.
<style>
input[type=checkbox].switch {}
</style> <input type="checkbox" class="switch">
Next step is to add an appearance of none to the CSS--make sure to add -moz- and -webkit-. After that, you're going to want to set it so that the checkbox a rectangle--make sure it's in px. We also want to set the position to relative
Next we want to create a ::before pseudo. In there we want to make it have a position of relative, a width and height that are abit less than the height of the main switch, a display of inline-block, a top and left of 0, a content of anything, color of transparent, and a background color that's different from the one in the main switch.
Finally add a pseudo called :checked which checks if a checkbox, or a radio, was checked; you'll want to change the before pseudo if the the checkbox is checked. You need to set the left to a bit less than the width of the checkbox; you can adjust it until it looks right to you.
Now, let's look at what it looks like
+
+
+ creatingaswitch.html
+ 2022-02-11T00:00:00Z
+ 2022-02-11T00:00:00Z
+
+
+
+ Why local variables are called "let"
+
+
+
+
In JavaScript there are 3 different kinds of variables, global variables(using var), constants(const, and local variables(let). All of the act allittle differently from eachother. Allow me to explain what they do.
Global variables, made using var, are as they sound, global variables. Once defined, they can be used, edited, or redefind anywhere.
Constants, defined with const, are constant, they cannot change, at all.
Local variables, defined with let, are variables that can only be used in the place that it is defined, like a function, and it's children.
Now that we has that established, let's talk about how local variables got their name.
Turns out "let" is a mathematical term. The "let" expression may also be defined in mathematics, where it associates a Boolean condition with a restricted scope.[source]. It was first used in programming in early languages like Basic.
In case you're wondering, the main source is this answer on Stack Overflow.
+
+
+ whyLocalVarCallLet.html
+ 2022-01-10T00:00:00Z
+ 2022-01-10T00:00:00Z
+
+
+
+ The Song we didn't get in Undertale
+
+
+
+
Undertale is an amazing game. I really enjoyed my time playing it. I listen to the sound track a lot(I'm doing it as I write this). I even read a fanmade AU called Inverted Fate. The only thing that I haven't done(and don't intend on doing) is a Genocide Run. But, there's one thing that's kinda been bugging me since it first found out about it. It's the fact that their's a version of Undertale(the song) that wasn't added, and instead was replaced with the version we have now.
The Current Version
The version we got of Undertale was a pretty good one. It's a little sad, while also filled with hope(just like the monsters in the neutral route. It is kinda the song of their hope, since it only plays during the end of the neutral route). Below is the version we got in the game.
The One that could have been
This one is also greate, and I personally think I like it a lot better than the one we have. I feel like it's more happy in tone. Even if it might not fit with what the game would have been trying to fit it's context into, it's still a good song on it's own.
This is a simple tutorial on how to make a simple theme switcher.
Step 1: Creating the themes
The first step is to create the themes in your stylesheet, you can have as many as you want. Just make sure to remeber all their names within your CSS.
Step 2: Making an array
This is why you need to remeber all their names within the CSS. You need to add them all to an array in your JS. Below is an example of an array containing some themes.
const themes = ["light", "dark", "gamer"]
Step 3: Switching themes
This is the part you've been waiting for! The actual content switcher. It's surprisingly simple.
First, get the index of the current theme using let currentTheme = themes.indexOf(document.documentElement.className). Then, use an if statement to see if it's more than or equal to the length of the array containing your themes.
In the end, what you just made should look something like the iFrame below.
+
+
+ creating_a_theme_switch.html
+ 2021-12-08T00:00:00Z
+ 2021-12-08T00:00:00Z
+
+
+
+ Is Kris the Knight?
+
+
+
+
Is Kris the Knight? At face value, this seemes insain. Right? Well, let's look at the evidence First and formost, the Knight opens Dark Fountains. Now, what does Kris do at the end of Chapter 2? They create a Dark Fountain. Second, what does Kris look like in Dark Worlds? That's right, a Knight. This is what Kris looks like in a Dark World, they're wearing plated armor. They even have a sword(not shown in image). We know that Kris made a Dark Fountain at the end of Chapter 2, so is it really that far off to assume that they also made the one in the librarby's computer lab? Or the on in the closet for that matter. Well, we know that they had thier knife at the end of chapter 1, and only Toby Fox knows what they did before chapter 1. In the end of chapter 2, they rips they soul out before creating the new fountain, and shuffeling around outside; and slashing Torial's tires. Infact, they rips out their heart in the end of chapter 1, too. Afterward, they presumably went to librarby and made a fountain in the computer lab. This is a really common thereoy, but it really needs more evidence to be collected, and more speculating to be done. taken from Fandom.
In our lifes on the internet, we see alot of characters that we don't normally see. Like @, #, &, [], {}, \, ;, and |. But what are thier names, what are their origins, and why do they look like they do? I'm going to try and find out! Let's start with what they are used for most of the time on the web.
@ is used to mean at. It can also be used to define a username(@user), or even emails(person@emailprovider.topleveldomain)
The hashtag, #, is used for tagging posts to topics(#NumberOneProgrammer). It is also sometimes used to define a number(#1). It's also used in CSS to define IDs, and in urls to scroll down to a certain part of the page(#theMan).
& is a symbol used to mean "and"(the dog & the cat). It is also used in urls to be an addition to the search(?q=look%20mom%20no%hands%21&images)
Square brackets([]), are used to define a list in the most widely used programming language on the web, JavaScript(["the dog", "the cat", "the bird", "the plane"]). They can also be used in the middle of quotes to give context("Have a nice day!" [The mayor] shouted)
Curly brackets({}) are used to define a JavaScript object( {person: "Jim", car: "JavaScript car :)"} )
backslash(\) is used in markdown, and JavaScript strings, to define a character that should remain itself, such as \# showing up as a # instead of a heading.
Semi-collins(;) are used to define the end of a command in lots of programming languages, like JavaScript(alert("hello world");), PHP(echo "hello world";)
|, or Vertical bar, has no real use on the web.
~, or tilde, also, doesn't find much use
Grave accents(`) are used to define a multi-lined JavaScript string(`this has 2 lines`)
Those are what they are, but what about their original meanings?
The At-Sign(@) is used to mean at(they're @ their house), it could also be used for a price(@10 pence)
#(pound-sign, hashtag, number-sign, octothorpe, sharp-sign), it's used to mean lb(10 #), define numbers(#10), define a tag in social media(#NumberOneCoder), to define the musical notes that are sharp, or used on telephones to do... something.
Ampersands(&) are used as &, that's it(doges & golden retrievers).
[Square Brackets] are used as a way to add context to the middle of a sentence, like "he ate the sausage", but we don't know who "he" is, and what kind of sausage he is eating, so it should be "[the young boy] ate the [cheese filled] sausage"
{Curly Brackets} don't get much use. They would be used for {defining words, lines, sentences as being in a group}.
|s are used to define absolute value, like |-2| = 2. It can also be used as a replacement for periods, and forward slashed
The backslash doesn't get much real use in writing. In math, it is used to represent the set difference(which I won't really explain), such as a\n
The Semicolon is used to seperate ideas in a sentence filled with commas, add seperation between an explaination; and a seperator(,) in a list, and merge 2 sentences together without a compound(and, but, or). Such as "I am so happy for them, and I am proud" & "I am so happy; I am proud." act the same. If you'd like a better explaination, I'd suggest you to check out How to use a semicolon by Ted-Ed, it's a great whatch, and it's presented in an interesting and fun style.
Grave accents(`) are used in some words from other languages, but not much in English. However it can be used in songs and poems to indicate that silent letters aren't silent.
Tildes(~) can be used in a sentence to mean about, for example, ~10.
+
+
+ symbols.html
+ 2021-10-10T00:00:00Z
+ 2021-10-10T00:00:00Z
+
+
+
+ Creating a HTML drop-down list
+
+
+
+
Inorder to create a drop-down selection list in HTML, we must first understand why they are important. Drop-down lists can be used in lots of ways, from creating a way for people to chose from a strict set of options, to making an on-off switch(even though you should use buttons for that) Before we start, here is an example:
It has it's own tags, know as <select> and <option>. Using these is alittle like making a list, if you've ever made one. Here's an example bit of HTML.
<select>
<option>op 1</option>
<option>op 2</option>
</select>
Next we want to add values to <options>, and an id(#) to <select>. You most-likely already know how to do ids, and maybe also values(if you have used input in any way), so I'll leave it up to you. However, you may not know some things that could be useful here, such as preselections, or making things update upon being changed, well, you can do preselections with selected in the <option> that you want to be preselected. Changes done the page upon the change of the selection in the drop-down(or anything else that can be changed by the user) is onchange="submitFunction()" being placed in the <select>. Let's check back on the code that we made at the code example:
Inorder to access the selected option with JavaScript, use document.getElementById("selection").value That's basically it, feel free to CTRL + CCTRL + V it. /s
+
+
+ Creating_HTML_DD_List.html
+ 2021-10-01T00:00:00Z
+ 2021-10-01T00:00:00Z
+
+
+
+ YouTube needs to have an open REST API
+
+
+
+
Youtube needs an open Rest API. Here are some reasons:
It makes my life easier, as I don't need to write a billion lines of code, and not go throught the paid service known as google cloud console, to get an api key.
It means that you only need to use fetch() on it.
We don't need the most in depth api.
+
+
+ Youtube_needs_a_Rest_API.html
+ 2021-09-29T00:00:00Z
+ 2021-09-29T00:00:00Z
+
+
+
+ How to Make the perfect Tea.
+
+
+
+
Tea is the perfect fit for most meals, breakfast, 2nd breakfast, morning tea, lunch, afTernoon tea, dinner, or supper. But how do I make it? Here's how I make my tea.
Step 1
The first step is to get the brand of tea you like. I personally like stuff such as Mighty Leaf, it tastes strong, and your able to use it 3 times without it getting weaker, and even then, you can still use it more, it really doesn't lose it's weakness.
Step 2
Get a mug, or tea cup. I personally like mugs, as they are normally bigger, meaning you don't have to refill as much as a tea cup.
Step 3
Get your tea, if you're using loose leaf, I'd use a smaller cup to make it, then use a strainer to the leaves out, as it adds texture that I don't like personally, otherwise just put the tea bag in, it is at this point that I like to stir it.
Final Step
Enjoy. You can add sugar and milk cream, if you're into those kinda things... even lemon if you really want.
+
+
+ How_To_Make_Tea.html
+ 2021-09-28T00:00:00Z
+ 2021-09-28T00:00:00Z
+
+
+
+ Changing the light-mode
+
+
+
+
As of currently, the light mode on this site doesn't live up to what I want it to be. I want it to be something that is the opposite of the dark mode, and it really isn't that. Expect it to change. But, in case you do still want to view it, here are the current css variable colors:
This post isn't very good, and I'm not proud of it.
So, as of currently, my Ocular Status is Mobile needs a better browser! #MobileSmartBrowser! (Er/Him). Part of the reason for this is so that inspect can be on mobile.
but what makes inspect so important?
Well I'm glad I asked!
So on GitHub, you only have 2000 actions you can do(on the free plan). So that means you need to use them carefully, make sure that you won't do something that wastes an action.
It helps you fix any mistake, before you make anymore.
Of course, you can always download the file, and edit it offline. But inspect element is easier, live, and requires less space in your hard-drive.
Thanks for coming to my Ted-talk.😜🤪
+
+
+ Why-inspect-element-is-a-useful-tool.html
+ 2021-05-17T00:00:00Z
+ 2021-05-17T00:00:00Z
+
+
+
+ How to Copy and Paste on mobile
+
+
+
+
This post isn't very good, and I'm not proud of it.
Recently, I've been seeing a lot of people coming up with one excuse for not linking the dupelicate topic in the suggestions forum. They say something like,
I'm on mobile!!!!! 😖😭😫
this is not a correct argument, so I've decided to make this post to prove it.
Safari/iOS
the way that you copy and paste on Safari is by double taping on the text, then dragging until you've selected all the text(the next bit works for links, not this)
Coping links
tap and hold on the link until you see:
Paste
going to any textbox, in the top-lefT-hand conner, you should see a little clipboard icon(as long as you aren't selecting any text), press it. tap "copy(circled in red)"
🏷Note: I don't own an android tablet or phone, so take this with a grain of salt
Chrome/Android
press and hold until a few selection boxes come up(might work for links)
pasting
tap and hold int the text box, you should see "paste," now click that(boxed in :Image Source
+
+
+ How-to-copy-and-paste-on-mobile.html
+ 2021-05-05T00:00:00Z
+ 2021-05-05T00:00:00Z
+
+
+
+ How to make mockups
+
+
+
+
This post isn't very good, and I'm not proud of it.
The first step to making a mockup is to open up the inpect menu, you may be able to do this using ctrl+shifT+i(or f12)
this will be different from browser to browser.
once you see inspect element open, simply go to the page you're making a mockup for(ex. MyStuff; or if you're making a new page, go to the page that looks the closest.), and press ctrl+shifT+c, and click on the area that you want to change(ex. the + New Project button.
now that you've selected the element, let's learn how to edit it! You should see the element that you clicked on(using the ctrl+shifT+c command) highlighted in blue. Inside of the element(if you selected text, or even an image), you should see a darker area, that isn't red, double click on it, it should now be hilighted, now type in whatever you want(if it's an image, make sure to put in an image link, ex. https://imagehoster.com/png/png.png; if you clicked on a link(in the "" in "a href=''", unselect it and select the part ""here"").
anyways... if you don't have the monna lisa yet, just give up /s
+
+
+ How-To-make-mockups.html
+ 2021-04-22T00:00:00Z
+ 2021-04-22T00:00:00Z
+
+
+
\ No newline at end of file
diff --git a/blog/feed.json b/blog/feed.json
new file mode 100644
index 0000000..c6e1103
--- /dev/null
+++ b/blog/feed.json
@@ -0,0 +1 @@
+{"version": "https://jsonfeed.org/version/1", "title": "Steve0Greatness' Blog", "home_page_url": "https://steve0greatness.github.io", "feed_url": "https://steve0greatness.github.io/blog/feed.rss", "language": "en-US", "favicon": "https://steve0greatness.github.io/favicon.ico", "description": "A blog by a human being.", "authors": [{"name": "Steve0Greatness", "url": "https://steve0greatness.github.io"}], "items": [{"id": "https://steve0greatness.github.io/blog/singular-blog.html", "title": "JSON Feed version 1.1", "icon": "https://steve0greatness.github.io/favicon.ico", "content_html": "
Alright, I've now moved all my full blog posts over to this one website. There might be other I miss in other places, but I'll add them here soon. I will not be moving over my micro-blogs, however. Those are too small, and I'd rather keep those separated anyway.
\n\n
I'm not a fan of how I wrote before December of 2022, everything there is filled with spelling mistakes and grammar issues, I also think most of it was rude towards the reader, which is not a good impression.
Disclaimer: The world of cyber-security is an incredibly complex and constantly evolving topic, and I am not a cyber-security researcher; I create projects for fun.
\n\n
Storing a password in a server can be intimidating. Password management is incredibly tricky, as anything you mess up could compromise your users' password(s). Thankfully, random websites you've never visited before have a pure HTML blog post from 2023 about that exact topic, and how to do it properly.
\n\n
Basically, it's just this sequence of steps:
\n\n
\n
Generate a long random sequence of characters, this is called a salt(generate for each user, do not use a master salt)
\n
Prepend(or append, it doesn't matter, just keep it consistent) this to the user's password
\n
Use a hashing algorithm, such as PBKDF2, to generate a unique sequence of characters that will uniquely identify that password.
\n
Store the salt and hash in the same place, do not store the password on it's own.
\n
\n\n
And to check if a password is right, repeat the steps, except rather than generating a random sequence of characters, get the sequence of characters that you've stored along with the hash.
\n\n
Why Do This?
\n\n
You might be thinking: That's a bit arbitrary innit? And if you aren't then you can stop reading now.
\n\n
This method of storing passwords is the only way to ensure that you are securely storing them. So let's go through some other ways, and why they aren't so good.
\n\n
Plaintext Passwords
\n\n
Storing your passwords in plaintext allows anyone who can get into your server to easily take any password they want, as no matter how good your users' password is, their account will be hacked if an unauthorized or malicious individual is able to get in.
\n\n
Encrypted Passwords
\n\n
This is basically just plaintext with additional steps. As long as your master-key is stored somewhere, it will get stolen as soon as somebody manages to get into your system.
\n\n
Bare Hashing
\n\n
A hash isn't able to be undone, meaning theoretically you should be able to just hash your password. This, while a fair assumption, has unfortunately been incorrect for quite some time. There are databases online that store every word in the english language(or just some words) in addition to common passwords and their hashes, and users will often use words for their passwords, even though it's insecure.
\n\n
This is where salts come in. Due to the nature of hashes, even a single change in a string will entirely change it's hash, as such, if you add a random sequence of characters to a string, then you can entirely change it's hash.
Here is my idea for automating the collection of healing materials(such as Beryl Nuts) in Satisfactory
\n\n
Plant Pods
\n\n
Plant pods would be researchable in the Nutrients section of the MAM. It would cost:\n* 5 modular frames \n* 10 steel pipes\n* 20 biofuel
\n\n
to research.
\n\n
You'd be able to build it in a new _Farming_ section in the production category of the build menu. It would cost the user:\n* 4 steel pipes\n* 2 quickwire\n* 5 biofuel
\n\n
to build. It would require 1 MW of power to function. Plants that are left without power while in there will not continue growing or providing harvest, however they will not die(that'd be annoying if they did).
\n\n
The user would be able to interact with the planting pod to bring up a menu that tells them what stage of growing it's at(baby, growing, fully grown), how ripe for harvest the plant is(out of 3 states: none, starting, ripe). The UI will have a button to harvest at the bottom, and a box that will allow the plant to be exchanged for another--which would give you a few leaves, proportional to how long it's been growing(0 if baby, 4 if growing, 10 if fully grown), and the amount of fruit they would have gotten from the harvest + 1 extra(for the fruit they put in).
\n\n
Robot Farmers
\n\n
Researchable under the _Crystal Oscillator_. The research cost is:\n* 10 Crystal Oscillators\n* 5 AI limiter\n* 3 quickwire
\n\n
These little farmers need power to survive, which is why the _ROBOT charger_ is unlocked with them.\nThis building can be built in the power section. They cost:\n* 15 quickwire\n* 2 modular frames\n* 5 crystal oscillators
\n\n
to build.
\n\n
Once built, this building acts like the truck station, but instead of coal, it loads power, and it can only unload items from the bot's inventory.
\n\n
The Robo-Farmer is then buildable under the _Farming_ section in the production category of the build menu. It costs :\n* 1 Factory Cart\n* 2 Crystal Oscillators\n* 1 AI limiter\n* 3 quickwire\n* 5 steal pipes
\n\n
to build.
\n\n
These little robots have themselves a little UI that allows you to select items they should farm. Once given a task, these robots will always return to the nearest _ROBOT charger_ when their inventory is full, or they are running low on power(robots will always attempt to keep themselves powered). If the robot cannot find a plant within range that is harvestable, then the they will wait until there is one.
\n\n
Getting the most out of these resources
\n\n
Robot Farmers are best at traversing on foundations(they spend less power). As such, it is recommended, that the player create a flat platform that has plant pods with some space between for the bots to traverse between them. In the center, the player should build a _ROBOT charger_, as it will allow the robots the run around equally in each direction. Players should also utilize the _Conveyor Lift_ to bring materials to a layer above for sorting, or other purposes.
The basic layout of the disguise command is very simple.
\n\n
disguise [class] [team]\n
\n\n
class Parameter
\n\n
1 : Scout
\n\n
2 : Sniper
\n\n
3 : Soldier
\n\n
4 : Demoman
\n\n
5 : Medic
\n\n
6 : Heavy
\n\n
7 : Pyro
\n\n
8 : Spy
\n\n
9 : Engineer
\n\n
The reason the classes are in this order is that they were added in that order. As mentioned in Quake World Team Fortress \u00a7 Versions on the Team Fortress wiki, it mentions the classes were added in the order of scout, sniper, soldier, demoman, and medic; then heavy; pyro; and finally spy and engineer.
\n\n
team Parameter
\n\n
These depend upon what team you're on.
\n\n
-1 : Enemy Team
\n\n
-2 : Friendly Team
\n\n
Specific Teams
\n\n
These aren't extremely useful, but they exist. They are independent of the team you're on.
\n\n
1 : Blu Team
\n\n
2 : Red Team
\n\n
Example
\n\n
Normally, when you disguise as a spy of your team, you undisguise. This also applies to the disguise command, allowing for an \"undisguise\" command.
\n\n
disguise \"8\" \"-2\"\n
\n\n
You're also able to put this into a bind, allowing for an undisguise bind.
Fortress Forever is finally playable fully on Linux using Proton-GE version 7-41(note: if you change the setting you will have to reboot the game).
\n\n
If you need a quick rundown on how to download and install Proton-GE, I've made a video about that already. It is technically about a different game, however, the problem is still similar enough to apply pretty much the same steps.
\n\n
It plays pretty well, the only problem is when a local server changes maps, and the font for some of the menus(and the chat) being very... bad looking. It's not the game's fault for the second one, however, it is still something that's annoying if you don't want to do too much tinkering.
\n\n
I'm glad to be able to play this great game on my daily OS without having to open Bottles every time I want to play Fortress Forever.
\n\n
Whenever I'm playing Fortress Forever, I'm usually on MaxTF's Midwest server... I have the lowest ping there, not good though.
When I've been trying(and failing) to use Tab on my computer(it's a Macbook) for what feels like forever now. Turns out, it was as simple as hitting Ctrl + F7.
\n\n
To be honest, I thought that it was just an issue with FireFox, and then I read Browser keyboard navigation in macOS and realized that it was an issue with MacOS! This should really be an option enabled by default, but Apple is stupid.
A FizzBuzz Program is a program used in many job interviews to see if a programmer is good at problem solving. There are many ways to make one.
\n\n
First let me tell you why I write these programs. These programs, at least in my opinion, are good when you're learning a new programming language. It gives you a problem to solve, and all you need to do to solve it. Incase you're wondering, the problem is to make a program that counts from 1 to 100 and replaces all multiples of 3 with Fizz, all multiples of 5 with Buzz, and multiples of both with FizzBuzz. Generally in interviews, they also ask you to add on more multiples, such as multiples of 7 are replaced with Fuzz, and multiples of 11 are replaced with Bizz.
\n\n
Now that I've told you what a FizzBuzz Program is, let me show you how I make them in Python.
\n\n
for i in range(1, 100):\n toPrint = \"\"\n print(toPrint)\n
\n\n
The first thing I do is I create a for loop, and within it I put a print statement and a variable named toPrint.
\n\n
def check(checktomulti, multi, toreturn):\n if checktomulti % multi == 0:\n return toreturn\n return \"\"\n\ndef checkEmpty(string, number):\n if string == \"\":\n return number\n return string\n\nfor i in range(1, 100):\n toPrint = checkEmpty(check(i, 3, \"Fizz\") + check(i, 5, \"Buzz\"), i)\n print(toPrint)\n
\n\n
The next thing I do is I define a function that checks if one number is a multiple of another, and if it is, then it returns the string, otherwise, it returns an empty string.
\n\n
Then I make a function that checks if a string is an empty one, if it is, then it returns a number.
\n\n
Once I have these 2 functions, I go back into the for loop and make the toPrint variable have the variable for checking if a string is empty(and if it is replace it with a number) check if 2 of the other function that check if one number is a multiple of another(and if it is, return a string). Finally, it prints the output.
\n\n
I've tried this method many times. Below are some examples of this method in action!
Next step is to add an appearance of none to the CSS--make sure to add -moz- and -webkit-. After that, you're going to want to set it so that the checkbox a rectangle--make sure it's in px. We also want to set the position to relative
Next we want to create a ::before pseudo. In there we want to make it have a position of relative, a width and height that are abit less than the height of the main switch, a display of inline-block, a top and left of 0, a content of anything, color of transparent, and a background color that's different from the one in the main switch.
Finally add a pseudo called :checked which checks if a checkbox, or a radio, was checked; you'll want to change the before pseudo if the the checkbox is checked. You need to set the left to a bit less than the width of the checkbox; you can adjust it until it looks right to you.
Now, let's look at what it looks like \n", "date_published": "2022-02-11T00:00:00Z", "date_modified": "2022-02-11T00:00:00Z", "url": "https://steve0greatness.github.io/blog/creatingaswitch.html"}, {"id": "https://steve0greatness.github.io/blog/whyLocalVarCallLet.html", "title": "JSON Feed version 1.1", "icon": "https://steve0greatness.github.io/favicon.ico", "content_html": "
In JavaScript there are 3 different kinds of variables, global variables(using var), constants(const, and local variables(let). All of the act allittle differently from eachother. Allow me to explain what they do.
Global variables, made using var, are as they sound, global variables. Once defined, they can be used, edited, or redefind anywhere.
Constants, defined with const, are constant, they cannot change, at all.
Local variables, defined with let, are variables that can only be used in the place that it is defined, like a function, and it's children.
Now that we has that established, let's talk about how local variables got their name.
Turns out \"let\" is a mathematical term. The \"let\" expression may also be defined in mathematics, where it associates a Boolean condition with a restricted scope.[source]. It was first used in programming in early languages like Basic.
In case you're wondering, the main source is this answer on Stack Overflow.\n", "date_published": "2022-01-10T00:00:00Z", "date_modified": "2022-01-10T00:00:00Z", "url": "https://steve0greatness.github.io/blog/whyLocalVarCallLet.html"}, {"id": "https://steve0greatness.github.io/blog/The_song_that_we_didnt_get_in_undertale.html", "title": "JSON Feed version 1.1", "icon": "https://steve0greatness.github.io/favicon.ico", "content_html": "
Undertale is an amazing game. I really enjoyed my time playing it. I listen to the sound track a lot(I'm doing it as I write this). I even read a fanmade AU called Inverted Fate. The only thing that I haven't done(and don't intend on doing) is a Genocide Run. But, there's one thing that's kinda been bugging me since it first found out about it. It's the fact that their's a version of Undertale(the song) that wasn't added, and instead was replaced with the version we have now.
The Current Version
The version we got of Undertale was a pretty good one. It's a little sad, while also filled with hope(just like the monsters in the neutral route. It is kinda the song of their hope, since it only plays during the end of the neutral route). Below is the version we got in the game.
The One that could have been
This one is also greate, and I personally think I like it a lot better than the one we have. I feel like it's more happy in tone. Even if it might not fit with what the game would have been trying to fit it's context into, it's still a good song on it's own.
This is a simple tutorial on how to make a simple theme switcher.
Step 1: Creating the themes
The first step is to create the themes in your stylesheet, you can have as many as you want. Just make sure to remeber all their names within your CSS.
Step 2: Making an array
This is why you need to remeber all their names within the CSS. You need to add them all to an array in your JS. Below is an example of an array containing some themes.
const themes = [\"light\", \"dark\", \"gamer\"]
Step 3: Switching themes
This is the part you've been waiting for! The actual content switcher. It's surprisingly simple.
First, get the index of the current theme using let currentTheme = themes.indexOf(document.documentElement.className). Then, use an if statement to see if it's more than or equal to the length of the array containing your themes.
In the end, what you just made should look something like the iFrame below. \n", "date_published": "2021-12-08T00:00:00Z", "date_modified": "2021-12-08T00:00:00Z", "url": "https://steve0greatness.github.io/blog/creating_a_theme_switch.html"}, {"id": "https://steve0greatness.github.io/blog/Is_Kris_the_Knight.html", "title": "JSON Feed version 1.1", "icon": "https://steve0greatness.github.io/favicon.ico", "content_html": "
Is Kris the Knight? At face value, this seemes insain. Right? Well, let's look at the evidence First and formost, the Knight opens Dark Fountains. Now, what does Kris do at the end of Chapter 2? They create a Dark Fountain. Second, what does Kris look like in Dark Worlds? That's right, a Knight. This is what Kris looks like in a Dark World, they're wearing plated armor. They even have a sword(not shown in image). We know that Kris made a Dark Fountain at the end of Chapter 2, so is it really that far off to assume that they also made the one in the librarby's computer lab? Or the on in the closet for that matter. Well, we know that they had thier knife at the end of chapter 1, and only Toby Fox knows what they did before chapter 1. In the end of chapter 2, they rips they soul out before creating the new fountain, and shuffeling around outside; and slashing Torial's tires. Infact, they rips out their heart in the end of chapter 1, too. Afterward, they presumably went to librarby and made a fountain in the computer lab. This is a really common thereoy, but it really needs more evidence to be collected, and more speculating to be done. taken from Fandom.
In our lifes on the internet, we see alot of characters that we don't normally see. Like @, #, &, [], {}, \\, ;, and |. But what are thier names, what are their origins, and why do they look like they do? I'm going to try and find out! Let's start with what they are used for most of the time on the web.
@ is used to mean at. It can also be used to define a username(@user), or even emails(person@emailprovider.topleveldomain)
The hashtag, #, is used for tagging posts to topics(#NumberOneProgrammer). It is also sometimes used to define a number(#1). It's also used in CSS to define IDs, and in urls to scroll down to a certain part of the page(#theMan).
& is a symbol used to mean \"and\"(the dog & the cat). It is also used in urls to be an addition to the search(?q=look%20mom%20no%hands%21&images)
Square brackets([]), are used to define a list in the most widely used programming language on the web, JavaScript([\"the dog\", \"the cat\", \"the bird\", \"the plane\"]). They can also be used in the middle of quotes to give context(\"Have a nice day!\" [The mayor] shouted)
Curly brackets({}) are used to define a JavaScript object( {person: \"Jim\", car: \"JavaScript car :)\"} )
backslash(\\) is used in markdown, and JavaScript strings, to define a character that should remain itself, such as \\# showing up as a # instead of a heading.
Semi-collins(;) are used to define the end of a command in lots of programming languages, like JavaScript(alert(\"hello world\");), PHP(echo \"hello world\";)
|, or Vertical bar, has no real use on the web.
~, or tilde, also, doesn't find much use
Grave accents(`) are used to define a multi-lined JavaScript string(`this has 2 lines`)
Those are what they are, but what about their original meanings?
The At-Sign(@) is used to mean at(they're @ their house), it could also be used for a price(@10 pence)
#(pound-sign, hashtag, number-sign, octothorpe, sharp-sign), it's used to mean lb(10 #), define numbers(#10), define a tag in social media(#NumberOneCoder), to define the musical notes that are sharp, or used on telephones to do... something.
Ampersands(&) are used as &, that's it(doges & golden retrievers).
[Square Brackets] are used as a way to add context to the middle of a sentence, like \"he ate the sausage\", but we don't know who \"he\" is, and what kind of sausage he is eating, so it should be \"[the young boy] ate the [cheese filled] sausage\"
{Curly Brackets} don't get much use. They would be used for {defining words, lines, sentences as being in a group}.
|s are used to define absolute value, like |-2| = 2. It can also be used as a replacement for periods, and forward slashed
The backslash doesn't get much real use in writing. In math, it is used to represent the set difference(which I won't really explain), such as a\\n
The Semicolon is used to seperate ideas in a sentence filled with commas, add seperation between an explaination; and a seperator(,) in a list, and merge 2 sentences together without a compound(and, but, or). Such as \"I am so happy for them, and I am proud\" & \"I am so happy; I am proud.\" act the same. If you'd like a better explaination, I'd suggest you to check out How to use a semicolon by Ted-Ed, it's a great whatch, and it's presented in an interesting and fun style.
Grave accents(`) are used in some words from other languages, but not much in English. However it can be used in songs and poems to indicate that silent letters aren't silent.
Tildes(~) can be used in a sentence to mean about, for example, ~10.
Inorder to create a drop-down selection list in HTML, we must first understand why they are important. Drop-down lists can be used in lots of ways, from creating a way for people to chose from a strict set of options, to making an on-off switch(even though you should use buttons for that) Before we start, here is an example:
It has it's own tags, know as <select> and <option>. Using these is alittle like making a list, if you've ever made one. Here's an example bit of HTML.
<select>
<option>op 1</option>
<option>op 2</option>
</select>
Next we want to add values to <options>, and an id(#) to <select>. You most-likely already know how to do ids, and maybe also values(if you have used input in any way), so I'll leave it up to you. However, you may not know some things that could be useful here, such as preselections, or making things update upon being changed, well, you can do preselections with selected in the <option> that you want to be preselected. Changes done the page upon the change of the selection in the drop-down(or anything else that can be changed by the user) is onchange=\"submitFunction()\" being placed in the <select>. Let's check back on the code that we made at the code example:
Inorder to access the selected option with JavaScript, use document.getElementById(\"selection\").value That's basically it, feel free to CTRL + CCTRL + V it. /s\n", "date_published": "2021-10-01T00:00:00Z", "date_modified": "2021-10-01T00:00:00Z", "url": "https://steve0greatness.github.io/blog/Creating_HTML_DD_List.html"}, {"id": "https://steve0greatness.github.io/blog/Youtube_needs_a_Rest_API.html", "title": "JSON Feed version 1.1", "icon": "https://steve0greatness.github.io/favicon.ico", "content_html": "
Youtube needs an open Rest API. Here are some reasons:
It makes my life easier, as I don't need to write a billion lines of code, and not go throught the paid service known as google cloud console, to get an api key.
Tea is the perfect fit for most meals, breakfast, 2nd breakfast, morning tea, lunch, afTernoon tea, dinner, or supper. But how do I make it? Here's how I make my tea.
Step 1
The first step is to get the brand of tea you like. I personally like stuff such as Mighty Leaf, it tastes strong, and your able to use it 3 times without it getting weaker, and even then, you can still use it more, it really doesn't lose it's weakness.
Step 2
Get a mug, or tea cup. I personally like mugs, as they are normally bigger, meaning you don't have to refill as much as a tea cup.
Step 3
Get your tea, if you're using loose leaf, I'd use a smaller cup to make it, then use a strainer to the leaves out, as it adds texture that I don't like personally, otherwise just put the tea bag in, it is at this point that I like to stir it.
Final Step
Enjoy. You can add sugar and milk cream, if you're into those kinda things... even lemon if you really want. \n", "date_published": "2021-09-28T00:00:00Z", "date_modified": "2021-09-28T00:00:00Z", "url": "https://steve0greatness.github.io/blog/How_To_Make_Tea.html"}, {"id": "https://steve0greatness.github.io/blog/Changing_the_Light-mode.html", "title": "JSON Feed version 1.1", "icon": "https://steve0greatness.github.io/favicon.ico", "content_html": "
As of currently, the light mode on this site doesn't live up to what I want it to be. I want it to be something that is the opposite of the dark mode, and it really isn't that. Expect it to change. But, in case you do still want to view it, here are the current css variable colors:
This post isn't very good, and I'm not proud of it.
So, as of currently, my Ocular Status is Mobile needs a better browser! #MobileSmartBrowser! (Er/Him). Part of the reason for this is so that inspect can be on mobile.
but what makes inspect so important?
Well I'm glad I asked!
So on GitHub, you only have 2000 actions you can do(on the free plan). So that means you need to use them carefully, make sure that you won't do something that wastes an action.
It helps you fix any mistake, before you make anymore.
Of course, you can always download the file, and edit it offline. But inspect element is easier, live, and requires less space in your hard-drive.
Thanks for coming to my Ted-talk.\ud83d\ude1c\ud83e\udd2a\n", "date_published": "2021-05-17T00:00:00Z", "date_modified": "2021-05-17T00:00:00Z", "url": "https://steve0greatness.github.io/blog/Why-inspect-element-is-a-useful-tool.html"}, {"id": "https://steve0greatness.github.io/blog/How-to-copy-and-paste-on-mobile.html", "title": "JSON Feed version 1.1", "icon": "https://steve0greatness.github.io/favicon.ico", "content_html": "
This post isn't very good, and I'm not proud of it.
Recently, I've been seeing a lot of people coming up with one excuse for not linking the dupelicate topic in the suggestions forum. They say something like,
I'm on mobile!!!!! 😖😭😫
this is not a correct argument, so I've decided to make this post to prove it.
Safari/iOS
the way that you copy and paste on Safari is by double taping on the text, then dragging until you've selected all the text(the next bit works for links, not this)
Coping links
tap and hold on the link until you see:
Paste
going to any textbox, in the top-lefT-hand conner, you should see a little clipboard icon(as long as you aren't selecting any text), press it. tap \"copy(circled in red)\"
\ud83c\udff7Note: I don't own an android tablet or phone, so take this with a grain of salt
Chrome/Android
press and hold until a few selection boxes come up(might work for links)
pasting
tap and hold int the text box, you should see \"paste,\" now click that(boxed in :Image Source\n", "date_published": "2021-05-05T00:00:00Z", "date_modified": "2021-05-05T00:00:00Z", "url": "https://steve0greatness.github.io/blog/How-to-copy-and-paste-on-mobile.html"}, {"id": "https://steve0greatness.github.io/blog/How-To-make-mockups.html", "title": "JSON Feed version 1.1", "icon": "https://steve0greatness.github.io/favicon.ico", "content_html": "
This post isn't very good, and I'm not proud of it.
The first step to making a mockup is to open up the inpect menu, you may be able to do this using ctrl+shifT+i(or f12)
this will be different from browser to browser.
once you see inspect element open, simply go to the page you're making a mockup for(ex. MyStuff; or if you're making a new page, go to the page that looks the closest.), and press ctrl+shifT+c, and click on the area that you want to change(ex. the + New Project button.
now that you've selected the element, let's learn how to edit it! You should see the element that you clicked on(using the ctrl+shifT+c command) highlighted in blue. Inside of the element(if you selected text, or even an image), you should see a darker area, that isn't red, double click on it, it should now be hilighted, now type in whatever you want(if it's an image, make sure to put in an image link, ex. https://imagehoster.com/png/png.png; if you clicked on a link(in the \"\" in \"a href=''\", unselect it and select the part \"\"here\"\").
anyways... if you don't have the monna lisa yet, just give up /s\n", "date_published": "2021-04-22T00:00:00Z", "date_modified": "2021-04-22T00:00:00Z", "url": "https://steve0greatness.github.io/blog/How-To-make-mockups.html"}]}
\ No newline at end of file
diff --git a/blog/feed.rss b/blog/feed.rss
new file mode 100644
index 0000000..18d54c4
--- /dev/null
+++ b/blog/feed.rss
@@ -0,0 +1,529 @@
+
+
+
+
+
+ Steve0Greatness' Blog
+ https://steve0greatness.github.io/
+ A blog by a human being.
+ en-us
+ Custom w/Jinja
+
+ https://steve0greatness.github.io/
+ Steve0Greatness' Blog
+ https://steve0greatness.github.io/RSS-Img.png
+ A blog by a human being.
+ 144
+ 120
+
+
+
+ My blog is now in one place
+ https://steve0greatness.github.io/blog/singular-blog.html
+
+
+ <p>Depending on your Feed reader, you may want to <a href="https://steve0greatness.github.io/blog/singular-blog.html">read this article online</a>.</p>
+ <p>Alright, I've now moved all my full blog posts over to this one website. There might be other I miss in other places, but I'll add them here soon. I will not be moving over my micro-blogs, however. Those are too small, and I'd rather keep those separated anyway.</p>
+
+<p>I'm not a fan of how I wrote before December of 2022, everything there is filled with spelling mistakes and grammar issues, I also think most of it was rude towards the reader, which is not a good impression.</p>
+
+
+ singular-blog.html
+ Mon, 01 Jan 2024 00:00:00 GMT
+ 2024-01-01T00:00:00Z
+ 2024-01-01T00:00:00Z
+
+
+
+ How to Store a Passwords
+ https://steve0greatness.github.io/blog/How-to-Store-Passwords.html
+
+
+ <p>Depending on your Feed reader, you may want to <a href="https://steve0greatness.github.io/blog/How-to-Store-Passwords.html">read this article online</a>.</p>
+ <p><strong>Disclaimer</strong>: The world of cyber-security is an incredibly complex and constantly evolving topic, and I am not a cyber-security researcher; I create projects for fun.</p>
+
+<p>Storing a password in a server can be intimidating. Password management is incredibly tricky, as anything you mess up could compromise your users' password(s). Thankfully, random websites you've never visited before have a pure HTML blog post from 2023 about that exact topic, and how to do it properly.</p>
+
+<p>Basically, it's just this sequence of steps:</p>
+
+<ul>
+<li>Generate a long random sequence of characters, this is called a <em><a href="https://en.wikipedia.org/wiki/Salt_(cryptography)">salt</a></em>(generate for each user, do not use a master salt)</li>
+<li>Prepend(or append, it doesn't matter, just keep it consistent) this to the user's password</li>
+<li>Use a <a href="https://en.wikipedia.org/wiki/Hash_function">hashing algorithm</a>, such as <a href="https://en.wikipedia.org/wiki/PBKDF2">PBKDF2</a>, to generate a unique sequence of characters that will uniquely identify that password.</li>
+<li>Store the salt and hash in the same place, <em>do not</em> store the password on it's own.</li>
+</ul>
+
+<p>And to check if a password is right, repeat the steps, except rather than generating a random sequence of characters, get the sequence of characters that you've stored along with the hash.</p>
+
+<h2 id="why-do-this">Why Do <em>This</em>?</h2>
+
+<p>You might be thinking: <em>That's a bit arbitrary innit?</em> And if you aren't then you can stop reading now.</p>
+
+<p>This method of storing passwords is the only way to ensure that you are securely storing them. So let's go through some other ways, and why they aren't so good.</p>
+
+<h3 id="plaintext-passwords">Plaintext Passwords</h3>
+
+<p>Storing your passwords in plaintext allows anyone who can get into your server to easily take any password they want, as no matter how good your users' password is, their account will be hacked if an unauthorized or malicious individual is able to get in.</p>
+
+<h3 id="encrypted-passwords">Encrypted Passwords</h3>
+
+<p>This is basically just plaintext with additional steps. As long as your master-key is stored somewhere, it will get stolen as soon as somebody manages to get into your system.</p>
+
+<h3 id="bare-hashing">Bare Hashing</h3>
+
+<p>A hash isn't able to be undone, meaning theoretically you should be able to <em>just</em> hash your password. This, while a fair assumption, has unfortunately been incorrect for quite some time. There are databases online that store every word in the english language(or just some words) in addition to common passwords and their hashes, and users will often use words for their passwords, even though it's insecure.</p>
+
+<p>This is where salts come in. Due to the nature of hashes, even a single change in a string will entirely change it's hash, as such, if you add a random sequence of characters to a string, then you can entirely change it's hash.</p>
+
+
+ How-to-Store-Passwords.html
+ Thu, 02 Nov 2023 00:00:00 GMT
+ 2023-11-02T00:00:00Z
+ 2023-11-02T00:00:00Z
+
+
+
+ Satisfactory Concept: Farming
+ https://steve0greatness.github.io/blog/satisfactory-farming-idea.html
+
+
+ <p>Depending on your Feed reader, you may want to <a href="https://steve0greatness.github.io/blog/satisfactory-farming-idea.html">read this article online</a>.</p>
+ <p>Here is my idea for automating the collection of healing materials(such as Beryl Nuts) in Satisfactory</p>
+
+<h2 id="plant-pods">Plant Pods</h2>
+
+<p>Plant pods would be researchable in the Nutrients section of the MAM. It would cost:
+* 5 modular frames
+* 10 steel pipes
+* 20 biofuel</p>
+
+<p>to research.</p>
+
+<p>You'd be able to build it in a new _Farming_ section in the production category of the build menu. It would cost the user:
+* 4 steel pipes
+* 2 quickwire
+* 5 biofuel</p>
+
+<p>to build. It would require 1 MW of power to function. Plants that are left without power while in there will not continue growing or providing harvest, however they will not die(that'd be annoying if they did).</p>
+
+<p>The user would be able to interact with the planting pod to bring up a menu that tells them what stage of growing it's at(baby, growing, fully grown), how ripe for harvest the plant is(out of 3 states: none, starting, ripe). The UI will have a button to harvest at the bottom, and a box that will allow the plant to be exchanged for another--which would give you a few leaves, proportional to how long it's been growing(0 if baby, 4 if growing, 10 if fully grown), and the amount of fruit they would have gotten from the harvest + 1 extra(for the fruit they put in).</p>
+
+<h2 id="robot-farmers">Robot Farmers</h2>
+
+<p>Researchable under the _Crystal Oscillator_. The research cost is:
+* 10 Crystal Oscillators
+* 5 AI limiter
+* 3 quickwire</p>
+
+<p>These little farmers need power to survive, which is why the _ROBOT charger_ is unlocked with them.
+This building can be built in the power section. They cost:
+* 15 quickwire
+* 2 modular frames
+* 5 crystal oscillators</p>
+
+<p>to build.</p>
+
+<p>Once built, this building acts like the truck station, but instead of coal, it loads power, and it can only unload items from the bot's inventory.</p>
+
+<p>The Robo-Farmer is then buildable under the _Farming_ section in the production category of the build menu. It costs :
+* 1 Factory Cart
+* 2 Crystal Oscillators
+* 1 AI limiter
+* 3 quickwire
+* 5 steal pipes</p>
+
+<p>to build.</p>
+
+<p>These little robots have themselves a little UI that allows you to select items they should farm. Once given a task, these robots will always return to the nearest _ROBOT charger_ when their inventory is full, or they are running low on power(robots will always attempt to keep themselves powered). If the robot cannot find a plant within range that is harvestable, then the they will wait until there is one. </p>
+
+<h2 id="getting-the-most-out-of-these-resources">Getting the most out of these resources</h2>
+
+<p>Robot Farmers are best at traversing on foundations(they spend less power). As such, it is recommended, that the player create a flat platform that has plant pods with some space between for the bots to traverse between them. In the center, the player should build a _ROBOT charger_, as it will allow the robots the run around equally in each direction. Players should also utilize the _Conveyor Lift_ to bring materials to a layer above for sorting, or other purposes.</p>
+
+
+ satisfactory-farming-idea.html
+ Sun, 16 Apr 2023 00:00:00 GMT
+ 2023-04-16T00:00:00Z
+ 2023-04-16T00:00:00Z
+
+
+
+ TF2 disguise Command
+ https://steve0greatness.github.io/blog/tf2-disguise-cmd.html
+
+
+ <p>Depending on your Feed reader, you may want to <a href="https://steve0greatness.github.io/blog/tf2-disguise-cmd.html">read this article online</a>.</p>
+ <p>A Spy class-specific command</p>
+
+<h2 id="layout">Layout</h2>
+
+<p>The basic layout of the disguise command is very simple.</p>
+
+<pre><code>disguise [class] [team]
+</code></pre>
+
+<h2 id="class-parameter"><code>class</code> Parameter</h2>
+
+<p><code>1</code> : Scout</p>
+
+<p><code>2</code> : Sniper</p>
+
+<p><code>3</code> : Soldier</p>
+
+<p><code>4</code> : Demoman</p>
+
+<p><code>5</code> : Medic</p>
+
+<p><code>6</code> : Heavy</p>
+
+<p><code>7</code> : Pyro</p>
+
+<p><code>8</code> : Spy</p>
+
+<p><code>9</code> : Engineer</p>
+
+<p>The reason the classes are in this order is that they were added in that order. As mentioned in <a href="https://wiki.teamfortress.com/wiki/Team_Fortress#Versions"><em>Quake World Team Fortress</em> § Versions</a> on the Team Fortress wiki, it mentions the classes were added in the order of <em>scout</em>, <em>sniper</em>, <em>soldier</em>, <em>demoman</em>, and <em>medic</em>; then <em>heavy</em>; <em>pyro</em>; and finally <em>spy</em> and <em>engineer</em>.</p>
+
+<h2 id="team-parameter"><code>team</code> Parameter</h2>
+
+<p>These depend upon what team you're on.</p>
+
+<p><code>-1</code> : Enemy Team</p>
+
+<p><code>-2</code> : Friendly Team</p>
+
+<h3 id="specific-teams">Specific Teams</h3>
+
+<p>These aren't extremely useful, but they exist. They are independent of the team you're on. </p>
+
+<p><code>1</code> : Blu Team</p>
+
+<p><code>2</code> : Red Team</p>
+
+<h2 id="example">Example</h2>
+
+<p>Normally, when you disguise as a spy of your team, you undisguise. This also applies to the disguise command, allowing for an "undisguise" command.</p>
+
+<pre><code>disguise "8" "-2"
+</code></pre>
+
+<p>You're also able to put this into a bind, allowing for an undisguise bind.</p>
+
+
+ tf2-disguise-cmd.html
+ Sat, 17 Dec 2022 00:00:00 GMT
+ 2022-12-17T00:00:00Z
+ 2024-01-17T00:00:00Z
+
+
+
+ Fortress Forever on Linux!
+ https://steve0greatness.github.io/blog/fortress-forever-on-linux.html
+
+
+ <p>Depending on your Feed reader, you may want to <a href="https://steve0greatness.github.io/blog/fortress-forever-on-linux.html">read this article online</a>.</p>
+ <p>Fortress Forever is finally playable fully on Linux using Proton-GE version 7-41(note: if you change the setting you will have to reboot the game).</p>
+
+<p>If you need a quick rundown on how to download and install Proton-GE, <a href="https://youtu.be/B2LZ8nYd3Bw">I've made a video about that already</a>. It is technically about a different game, however, the problem is still similar enough to apply pretty much the same steps.</p>
+
+<p>It plays pretty well, the only problem is when a local server changes maps, and the font for some of the menus(and the chat) being very... bad looking. It's not the game's fault for the second one, however, it is still something that's annoying if you don't want to do too much tinkering.</p>
+
+<p>I'm glad to be able to play this great game on my daily OS without having to open Bottles every time I want to play Fortress Forever.</p>
+
+<p>Whenever I'm playing Fortress Forever, I'm usually on <a href="https://www.gametracker.com/server_info/server2.maxcommunity.net:27015/">MaxTF's Midwest server</a>... I have the lowest ping there, not good though.</p>
+
+
+ fortress-forever-on-linux.html
+ Fri, 16 Dec 2022 00:00:00 GMT
+ 2022-12-16T00:00:00Z
+ 2023-01-01T00:00:00Z
+
+
+
+ MacOS Keyboard Navigation
+ https://steve0greatness.github.io/blog/macos-page-tab-nav.html
+
+
+ <p>Depending on your Feed reader, you may want to <a href="https://steve0greatness.github.io/blog/macos-page-tab-nav.html">read this article online</a>.</p>
+ <p>Ok, so I feel like a complete idiot right now.</p>
+
+<p>When I've been trying(and failing) to use <code>Tab</code> on my computer(it's a Macbook) for what feels like forever now. Turns out, it was as simple as hitting <code>Ctrl</code> + <code>F7</code>.</p>
+
+<p>To be honest, I thought that it was just an issue with FireFox, and then I read <a href="https://www.a11yproject.com/posts/macos-browser-keyboard-navigation/">Browser keyboard navigation in macOS</a> and realized that it was an issue with MacOS! This should really be an option enabled by default, but Apple is stupid.</p>
+
+
+ macos-page-tab-nav.html
+ Sat, 26 Feb 2022 00:00:00 GMT
+ 2022-02-26T00:00:00Z
+ 2024-01-17T00:00:00Z
+
+
+
+ The FizzBuzz Program
+ https://steve0greatness.github.io/blog/fizzbuzz.html
+
+
+ <p>Depending on your Feed reader, you may want to <a href="https://steve0greatness.github.io/blog/fizzbuzz.html">read this article online</a>.</p>
+ <p>A FizzBuzz Program is a program used in many job interviews to see if a programmer is good at problem solving. There are many ways to make one.</p>
+
+<p>First let me tell you why I write these programs. These programs, at least in my opinion, are good when you're learning a new programming language. It gives you a problem to solve, and all you need to do to solve it. Incase you're wondering, the problem is to make a program that counts from 1 to 100 and replaces all multiples of 3 with Fizz, all multiples of 5 with Buzz, and multiples of both with FizzBuzz. Generally in interviews, they also ask you to add on more multiples, such as multiples of 7 are replaced with Fuzz, and multiples of 11 are replaced with Bizz.</p>
+
+<p>Now that I've told you what a FizzBuzz Program is, let me show you how I make them in Python.</p>
+
+<pre><code>for i in range(1, 100):
+ toPrint = ""
+ print(toPrint)
+</code></pre>
+
+<p>The first thing I do is I create a for loop, and within it I put a print statement and a variable named toPrint.</p>
+
+<pre><code>def check(checktomulti, multi, toreturn):
+ if checktomulti % multi == 0:
+ return toreturn
+ return ""
+
+def checkEmpty(string, number):
+ if string == "":
+ return number
+ return string
+
+for i in range(1, 100):
+ toPrint = checkEmpty(check(i, 3, "Fizz") + check(i, 5, "Buzz"), i)
+ print(toPrint)
+</code></pre>
+
+<p>The next thing I do is I define a function that checks if one number is a multiple of another, and if it is, then it returns the string, otherwise, it returns an empty string.</p>
+
+<p>Then I make a function that checks if a string is an empty one, if it is, then it returns a number.</p>
+
+<p>Once I have these 2 functions, I go back into the for loop and make the <code>toPrint</code> variable have the variable for checking if a string is empty(and if it is replace it with a number) check if 2 of the other function that check if one number is a multiple of another(and if it is, return a string). Finally, it prints the output.</p>
+
+<p>I've tried this method many times. Below are some examples of this method in action!</p>
+
+<ul>
+<li><a href="https://replit.com/@StevesGreatness/FizzBuzzKotlin">Kotlin</a></li>
+<li><a href="https://replit.com/@StevesGreatness/FizzBuzzlua">Lua</a></li>
+<li><a href="https://replit.com/@StevesGreatness/FizzBuzzpython">Python</a></li>
+<li><a href="https://replit.com/@StevesGreatness/FizzBuzzRuby">Ruby</a></li>
+</ul>
+
+
+ fizzbuzz.html
+ Sun, 20 Feb 2022 00:00:00 GMT
+ 2022-02-20T00:00:00Z
+ 2024-01-17T00:00:00Z
+
+
+
+ Customize an HTML Checkbox
+ https://steve0greatness.github.io/blog/checkbox-custom-styles.html
+
+
+ <p>Depending on your Feed reader, you may want to <a href="https://steve0greatness.github.io/blog/checkbox-custom-styles.html">read this article online</a>.</p>
+ <p><p>Checkboxes are hard to style. But when you're making a website, they may look ugly.</p><input type="checkbox" style="appearance:checkbox" /><p>As you can see here, this bland checkbox does not fit into my clearly great website(/s). But really, it does not fit in at all.</p><p>The first step toward styling it how we want it is to give it an appearence of none, and a width and height that are what you want.</p><div class="code-container"><div class="code">input[type="checkbox"] {<div style="margin-left:1em">appearance: none;<br />width: 15px;<br />height: 15px;</div>}</div><div class="preview"><input type="checkbox" style="appearance:none;width:15px;height:15px"/></div></div><p>Now we can do whatever we want to it. Also, remeber to add a checked pseudo</p><div class="code-container"><div class="code">input[type="checkbox"] {<div style="margin-left:1em">appearance: none;<br />width: 15px;<br />height: 15px;<br />background: #555;<br />border: 1px #252525 solid;<br />border-radius: 2px;</div>}<br /><br />input[type="checkbox"]:checked {<div style="margin-left:1em">background: #ce5aff;</div>}</div><div class="preview"><style>input[type="checkbox"].examplecheckbox3_:checked {background: #ce5aff;}input[type="checkbox"].examplecheckbox3_ {background: #555;}</style><input type="checkbox" class="examplecheckbox3_" style="appearance:none;width:15px;height:15px;border-radius:2px;border:1px #252525 solid"/></div></div></p>
+
+
+ checkbox-custom-styles.html
+ Sat, 19 Feb 2022 00:00:00 GMT
+ 2022-02-19T00:00:00Z
+ 2022-02-19T00:00:00Z
+
+
+
+ Creating a Switch in HTML and CSS
+ https://steve0greatness.github.io/blog/creatingaswitch.html
+
+
+ <p>Depending on your Feed reader, you may want to <a href="https://steve0greatness.github.io/blog/creatingaswitch.html">read this article online</a>.</p>
+ <p><p>A switch is something that is basically just a nicer checkbox. Here, I'll be showing you how to make one.</p>The first step is to create checkbox with any classname; I'll be using <span class="code">switch</span>.<div class="code"><style><div style="margin-left:1em;">input[type=checkbox].switch {}</div></style><br /><input type="checkbox" class="switch"></div><p>Next step is to add an appearance of none to the CSS--make sure to add <span class="code">-moz-</span> and <span class="code">-webkit-</span>. After that, you're going to want to set it so that the checkbox a rectangle--make sure it's in <span class="code">px</span>. We also want to set the position to relative</p><div class="code"><style><div style="margin-left:1em;">input[type=checkbox].switch {<div style="margin-left:1em;">-webkit-appearance: none;<br />-moz-appearance: none;<br />appearance: none;<br />position: relative;<br />width: 30px;<br />height: 16px;</div>}</div></style><br /><input type="checkbox" class="switch"></div><p>Next we want to create a <span class="code">::before</span> pseudo. In there we want to make it have a position of relative, a width and height that are abit less than the height of the main switch, a display of inline-block, a top and left of 0, a content of anything, color of transparent, and a background color that's different from the one in the main switch.</p><div class="code"><style><div style="margin-left:1em;">input[type=checkbox].switch {<div style="margin-left:1em;">-webkit-appearance: none;<br />-moz-appearance: none;<br />appearance: none;<br />position: relative;<br />width: 30px;<br />height: 16px;</div>}<br />input[type=checkbox].switch::before {<div style="margin-left:1em;">top: 0;<br />left: 0;<br />position: relative;<br />background: red;<br />content: ".";<br />color: transparent;<br />width: 14px;<br />height: 14px;</div>}</div></style><br /><input type="checkbox" class="switch"></div><p>Finally add a pseudo called <span class="code">:checked</span> which checks if a checkbox, or a radio, was checked; you'll want to change the before pseudo if the the checkbox is checked. You need to set the left to a bit less than the width of the checkbox; you can adjust it until it looks right to you.</p>Now, let's look at what it looks like<br /><iframe style="background:#fff;border:none" src="data:text/html;base64,PHN0eWxlPmlucHV0W3R5cGU9Y2hlY2tib3hdLnN3aXRjaCB7LXdlYmtpdC1hcHBlYXJhbmNlOiBub25lOy1tb3otYXBwZWFyYW5jZTogbm9uZTthcHBlYXJhbmNlOiBub25lO2JhY2tncm91bmQ6ICNlZmVmZWY7cG9zaXRpb246IHJlbGF0aXZlO2JvcmRlcjogMXB4IGJsYWNrIHNvbGlkO3dpZHRoOiAzMHB4O2hlaWdodDogMTZweDtib3JkZXItcmFkaXVzOiAwO31pbnB1dFt0eXBlPWNoZWNrYm94XS5zd2l0Y2g6OmJlZm9yZSB7dG9wOiAwO2xlZnQ6IDAuMjRweDtwb3NpdGlvbjogcmVsYXRpdmU7YmFja2dyb3VuZDogcmVkO2NvbnRlbnQ6ICIuIjtjb2xvcjogdHJhbnNwYXJlbnQ7d2lkdGg6IDIwcHg7aGVpZ2h0OiAxNHB4O31pbnB1dFt0eXBlPWNoZWNrYm94XS5zd2l0Y2g6Y2hlY2tlZDo6YmVmb3JlIHtsZWZ0OiAyNXB4O308L3N0eWxlPjxpbnB1dCB0eXBlPSJjaGVja2JveCIgY2xhc3M9InN3aXRjaCI+"></iframe></p>
+
+
+ creatingaswitch.html
+ Fri, 11 Feb 2022 00:00:00 GMT
+ 2022-02-11T00:00:00Z
+ 2022-02-11T00:00:00Z
+
+
+
+ Why local variables are called "let"
+ https://steve0greatness.github.io/blog/whyLocalVarCallLet.html
+
+
+ <p>Depending on your Feed reader, you may want to <a href="https://steve0greatness.github.io/blog/whyLocalVarCallLet.html">read this article online</a>.</p>
+ <p><p>In JavaScript there are 3 different kinds of variables, global variables(using <span class="code">var</span>), constants(<span class="code">const</span>, and local variables(<span class="code">let</span>). All of the act allittle differently from eachother. Allow me to explain what they do.</p><p>Global variables, made using <span class="code">var</span>, are as they sound, global variables. Once defined, they can be used, edited, or redefind anywhere.</p><p>Constants, defined with <span class="code">const</span>, are constant, they cannot change, at all.</p><p>Local variables, defined with <span class="code">let</span>, are variables that can only be used in the place that it is defined, like a function, and it's children.</p>Now that we has that established, <em>let</em>'s talk about how local variables got their name.<p>Turns out "let" is a mathematical term. <span class="quote">The <b>"let" expression</b> may also be defined in mathematics, where it associates a Boolean condition with a restricted scope.</span> <a href="https://en.m.wikipedia.org/wiki/Let_expression" class="source">[source]</a>. It was first used in programming in early languages like Basic.</p>In case you're wondering, the main source is <a href="https://stackoverflow.com/a/37917071">this answer on Stack Overflow</a>.</p>
+
+
+ whyLocalVarCallLet.html
+ Mon, 10 Jan 2022 00:00:00 GMT
+ 2022-01-10T00:00:00Z
+ 2022-01-10T00:00:00Z
+
+
+
+ The Song we didn't get in Undertale
+ https://steve0greatness.github.io/blog/The_song_that_we_didnt_get_in_undertale.html
+
+
+ <p>Depending on your Feed reader, you may want to <a href="https://steve0greatness.github.io/blog/The_song_that_we_didnt_get_in_undertale.html">read this article online</a>.</p>
+ <p><p>Undertale is an amazing game. I really enjoyed my time playing it. I listen to the sound track a lot(I'm doing it as I write this). I even read a fanmade <a href="https://undertale-au.fandom.com/wiki/Category:AUs">AU</a> called <a href="https://invertedfate.com/chapters">Inverted Fate</a>. The only thing that I haven't done(and don't intend on doing) is a <a href="https://undertale.fandom.com/wiki/Genocide_Route">Genocide Run</a>. But, there's one thing that's kinda been bugging me since it first found out about it. It's the fact that their's a version of <a href="https://undertale.fandom.com/wiki/Undertale_(Soundtrack)">Undertale(the song)</a> that wasn't added, and instead was replaced with the version we have now.</p><h1>The Current Version</h1><p>The version we got of Undertale was a pretty good one. It's a little sad, while also filled with hope(just like the monsters in the neutral route. It is kinda the song of their hope, since it only plays during the end of the neutral route). Below is the version we got in the game.</p><audio controls="true"><source src="https://static.wikia.nocookie.net/undertale/images/6/66/Undertale_%28Soundtrack%29_music_1.ogg" type="audio/ogg" /><source src="https://ia902907.us.archive.org/29/items/undertaleost_202004/Undertale%20-%20Lossless%20Soundtrack%20%28toby%20fox%29/toby%20fox%20-%20UNDERTALE%20Soundtrack%20-%2071%20Undertale.mp3" type="audio/mpeg" /><source src="https://ia802907.us.archive.org/29/items/undertaleost_202004/Undertale%20-%20Lossless%20Soundtrack%20%28toby%20fox%29/toby%20fox%20-%20UNDERTALE%20Soundtrack%20-%2071%20Undertale.flac" type="audio/flac" />It looks like your browser doesn't support the audio tag. <a href="https://static.wikia.nocookie.net/undertale/images/6/66/Undertale_%28Soundtrack%29_music_1.ogg">This is a link to the audio so that you can download it if you so choose.</a></audio><h1>The One that could have been</h1><p>This one is also greate, and I personally think I like it a lot better than the one we have. I feel like it's more happy in tone. Even if it might not fit with what the game would have been trying to fit it's context into, it's still a good song on it's own.</p><audio controls="true"><source src="https://static.wikia.nocookie.net/undertale/images/6/64/Undertale_%28Soundtrack%29_music_unused.ogg" type="audio/ogg" /><source src="https://a.tumblr.com/tumblr_odg4sv0r3Z1s58ev6o1.mp3" type="audio/mpeg" />Again, it looks like you're browser doesn't support audio, so you can <a href="https://static.wikia.nocookie.net/undertale/images/6/64/Undertale_%28Soundtrack%29_music_unused.ogg">download the song</a> to listen to it. </audio></p>
+
+
+ The_song_that_we_didnt_get_in_undertale.html
+ Mon, 20 Dec 2021 00:00:00 GMT
+ 2021-12-20T00:00:00Z
+ 2021-12-20T00:00:00Z
+
+
+
+ Creating a simple theme switcher
+ https://steve0greatness.github.io/blog/creating_a_theme_switch.html
+
+
+ <p>Depending on your Feed reader, you may want to <a href="https://steve0greatness.github.io/blog/creating_a_theme_switch.html">read this article online</a>.</p>
+ <p>This is a simple tutorial on how to make a simple theme switcher.<h1 id="step1">Step 1: Creating the themes</h1><p>The first step is to create the themes in your stylesheet, you can have as many as you want. Just make sure to remeber all their names within your CSS.</p><h1 id="step2">Step 2: Making an array</h1><p>This is why you need to remeber all their names within the CSS. You need to add them all to an array in your JS. Below is an example of an array containing some themes.</p><div class="code">const themes = ["light", "dark", "gamer"]</div><h1 id="step3">Step 3: Switching themes</h1><p>This is the part you've been waiting for! The actual content switcher. It's surprisingly simple.</p><p>First, get the index of the current theme using <span class="code">let currentTheme = themes.indexOf(document.documentElement.className)</span>. Then, use an if statement to see if it's more than or equal to the length of the array containing your themes.</p><div class="code">if (currentTheme + 1 >= themes.length) {<div style="margin-left:1em">document.documentElement.className = themes[0]</div>} else {<div style="margin-left:1em">document.documentElement.className = themes[currentTheme + 1]</div>}</div>Now just add a listener to the button(using <a href="https://developer.mozilla.org/en-US/docs/Web/API/EventTarget/addEventListener">event listener</a>, <a href="https://developer.mozilla.org/en-US/docs/Web/API/GlobalEventHandlers/onclick">getElement.onclick</a>, or <a href="https://www.w3schools.com/TAgs/att_onclick.asp">onclick</a>)<h1 id="finished">Final Product</h1>In the end, what you just made should look something like the iFrame below.<br /><iframe id="finalProduct" src="data:text/html;base64,PCFkb2N0eXBlIGh0bWw+PGh0bWwgY2xhc3M9ImxpZ2h0Ij48aGVhZD48c3R5bGU+aHRtbC5saWdodCB7YmFja2dyb3VuZDogI2ZmZjtjb2xvcjogIzAwMDstLWJ1dHRvbkJhY2tncm91bmQ6ICNmZWZlZmU7LS1idXR0b25Cb3JkZXI6ICNjY2M7LS1idXR0b25Db2xvcjogIzAwMTt9aHRtbC5kYXJrIHtiYWNrZ3JvdW5kOiAjMDAwO2NvbG9yOiAjZmZmOy0tYnV0dG9uQmFja2dyb3VuZDogIzEwMTAxMDstLWJ1dHRvbkJvcmRlcjogIzMzMzstLWJ1dHRvbkNvbG9yOiAjZmZmO31odG1sLmdhbWVyIHtiYWNrZ3JvdW5kOiAjZjAwO2NvbG9yOiAjMDBmOy0tYnV0dG9uQmFja2dyb3VuZDogIzA1MDstLWJ1dHRvbkJvcmRlcjogIzBhMDstLWJ1dHRvbkNvbG9yOiAjMGYwO31idXR0b24ge2JhY2tncm91bmQ6IHZhcigtLWJ1dHRvbkJhY2tncm91bmQpO2JvcmRlcjogdmFyKC0tYnV0dG9uQm9yZGVyKSBzb2xpZCAzcHg7Y29sb3I6IHZhcigtLWJ1dHRvbkNvbG9yKTt9PC9zdHlsZT48L2hlYWQ+PGJvZHk+PGJ1dHRvbiBpZD0idGhlbWVTd2l0Y2giPlN3aXRjaCBUaGVtZTwvYnV0dG9uPjxiciAvPlRoaXMgaXMgZXBpYyE8c2NyaXB0IHR5cGU9ImFwcGxpY2F0aW9uL2phdmFzY3JpcHQiPmNvbnN0IHRoZW1lcyA9IFsibGlnaHQiLCAiZGFyayIsICJnYW1lciJdO2RvY3VtZW50LmdldEVsZW1lbnRCeUlkKCJ0aGVtZVN3aXRjaCIpLm9uY2xpY2sgPSAoKSA9Jmd0OyB7bGV0IGN1clRoZW1lID0gdGhlbWVzLmluZGV4T2YoZG9jdW1lbnQuZG9jdW1lbnRFbGVtZW50LmNsYXNzTmFtZSk7aWYgKGN1clRoZW1lICsgMSAmZ3Q7PSB0aGVtZXMubGVuZ3RoKSB7ZG9jdW1lbnQuZG9jdW1lbnRFbGVtZW50LmNsYXNzTmFtZSA9IHRoZW1lc1swXX0gZWxzZSB7ZG9jdW1lbnQuZG9jdW1lbnRFbGVtZW50LmNsYXNzTmFtZSA9IHRoZW1lc1tjdXJUaGVtZSArIDFdfX08L3NjcmlwdD48L2JvZHk+PC9odG1sPg==" style="border:none"></iframe></p>
+
+
+ creating_a_theme_switch.html
+ Wed, 08 Dec 2021 00:00:00 GMT
+ 2021-12-08T00:00:00Z
+ 2021-12-08T00:00:00Z
+
+
+
+ Is Kris the Knight?
+ https://steve0greatness.github.io/blog/Is_Kris_the_Knight.html
+
+
+ <p>Depending on your Feed reader, you may want to <a href="https://steve0greatness.github.io/blog/Is_Kris_the_Knight.html">read this article online</a>.</p>
+ <p>Is Kris <span style='color: hotpink; font-style: italic;'>the Knight</span>? At face value, this seemes insain. Right? Well, let's look at the evidence<br />First and formost, <span style='color: hotpink; font-style: italic;'>the Knight</span> opens <span style='color: red; font-style: italic;'>Dark Fountains</span>. Now, what does Kris do at the end of Chapter 2? They create a <span style='color: red; font-style: italic;'>Dark Fountain</span>.<br />Second, what does Kris look like in <span style='color: red; font-style: italic;'>Dark Worlds</span>? That's right, a Knight.<br /><img src='https://static.wikia.nocookie.net/deltarune/images/9/96/Kris_overworld_darkworld.png' width='100' align='left' />This is what Kris looks like in a <span style='color: red; font-style: italic;'>Dark World</span>, they're wearing plated armor. They even have a sword(not shown in image).<br />We know that Kris made a <span style='color: red; font-style: italic;'>Dark Fountain</span> at the end of Chapter 2, so is it really that far off to assume that they also made the one in the librarby's computer lab? Or the on in the closet for that matter. Well, we know that they had thier knife at the <a href='https://youtu.be/wBS1MNkVPGw'>end of chapter 1</a>, and only Toby Fox knows what they did before chapter 1.<br />In the end of chapter 2, they rips they soul out before creating the new fountain, and shuffeling around outside; and slashing Torial's tires. Infact, they rips out their heart in the end of chapter 1, too. Afterward, they presumably went to librarby and made a fountain in the computer lab.<br />This is a really common thereoy, but it really needs more evidence to be collected, and more speculating to be done.<br clear='left' /><span style='color: grey; font-size: 13px;'>taken from <a href='https://deltarune.fandom.com/wiki/'>Fandom</a>.</span></p>
+
+
+ Is_Kris_the_Knight.html
+ Sat, 23 Oct 2021 00:00:00 GMT
+ 2021-10-23T00:00:00Z
+ 2021-10-23T00:00:00Z
+
+
+
+ Symbols
+ https://steve0greatness.github.io/blog/symbols.html
+
+
+ <p>Depending on your Feed reader, you may want to <a href="https://steve0greatness.github.io/blog/symbols.html">read this article online</a>.</p>
+ <p>In our lifes on the internet, we see alot of characters that we don't normally see. Like @, #, &, [], {}, \, ;, and |. But what are thier names, what are their origins, and why do they look like they do? I'm going to try and find out!<br />Let's start with what they are used for most of the time on the web.<ol><li>@ is used to mean at. It can also be used to define a username(<span style="font-weight:bold">@</span>user), or even emails(person<span style="font-weight:bold">@</span>emailprovider.topleveldomain)</li><li>The hashtag, #, is used for tagging posts to topics(<span style="font-weight:bold">#</span>NumberOneProgrammer). It is also sometimes used to define a number(<span style="font-weight:bold">#</span>1). It's also used in CSS to define IDs, and in urls to scroll down to a certain part of the page(<span style="font-weight:bold">#</span>theMan).</li><li>& is a symbol used to mean "and"(the dog <span style="font-weight:bold">&</span> the cat). It is also used in urls to be an addition to the search(?q=look%20mom%20no%hands%21<span style="font-weight:bold">&</span>images)</li><li>Square brackets([]), are used to define a list in the most widely used programming language on the web, JavaScript(<span style="font-weight:bold">[</span>"the dog", "the cat", "the bird", "the plane"<span style="font-weight:bold">]</span>). They can also be used in the middle of quotes to give context("Have a nice day!" <span style="font-weight:bold">[</span>The mayor<span style="font-weight:bold">]</span> shouted)</li><li>Curly brackets({}) are used to define a JavaScript object( {person: "Jim", car: "JavaScript car :)"} )</li><li>backslash(\) is used in markdown, and JavaScript strings, to define a character that should remain itself, such as <span style="font-weight:bold">\</span># showing up as a # instead of a heading.</li><li>Semi-collins(;) are used to define the end of a command in lots of programming languages, like JavaScript(alert("hello world")<span style="font-weight:bold">;</span>), PHP(echo "hello world"<span style="font-weight:bold">;</span>)</li><li>|, or Vertical bar, has no <em>real</em> use on the web.</li><li>~, or tilde, also, doesn't find much use</li><li>Grave accents(`) are used to define a multi-lined JavaScript string(<span style="font-weight:bold">`</span>this has<br />2 lines<span style="font-weight:bold">`</span>)</li></ol>Those are what they are, but what about their original meanings?<ol><li>The At-Sign(@) is used to mean at(they're <span style="font-weight:bold">@</span> their house), it could also be used for a price(<span style="font-weight:bold">@</span>10 pence)</li><li>#(pound-sign, hashtag, number-sign, octothorpe, sharp-sign), it's used to mean lb(10 <span style="font-weight:bold">#</span>), define numbers(<span style="font-weight:bold">#</span>10), define a tag in social media(<span style="font-weight:bold">#</span>NumberOneCoder), to define the musical notes that are sharp, or used on telephones to do... something.</li><li>Ampersands(&) are used as &, that's it(doges <span style="font-weight:bold">&</span> golden retrievers).</li><li>[Square Brackets] are used as a way to add context to the middle of a sentence, like "he ate the sausage", but we don't know who "he" is, and what kind of sausage he is eating, so it should be "<span style="font-weight:bold">[the young boy]</span> ate the <span style="font-weight:bold">[cheese filled]</span> sausage"</li><li>{Curly Brackets} don't get much use. They would be used for <span style="font-weight:bold">{</span>defining words, lines, sentences as being in a group<span style="font-weight:bold">}</span>.</li><li>|s are used to define absolute value, like <span style="font-weight:bold">|-2|</span> = 2. It can also be used as a replacement for periods, and forward slashed</li><li>The backslash doesn't get much real use in writing. In math, it is used to represent the set difference(which I won't really explain), such as a<span style="font-weight:bold">\</span>n</li><li>The Semicolon is used to seperate ideas in a sentence filled with commas, add seperation between an explaination<span style="font-weight:bold">;</span> and a seperator(,) in a list, and merge 2 sentences together without a compound(and, but, or). Such as "I am so happy for them, and I am proud" & "I am so happy; I am proud." act the same. If you'd like a better explaination, I'd suggest you to check out <a href="https://youtu.be/th-zyfvwDdI">How to use a semicolon</a> by Ted-Ed, it's a great whatch, and it's presented in an interesting and fun style.</li><li>Grave accents(`) are used in some words from other languages, but not much in English. However it can be used in songs and poems to indicate that silent letters aren't silent.</li><li>Tildes(~) can be used in a sentence to mean about, for example, <span style="font-weight:bold">~</span>10.</li></ol></p>
+
+
+ symbols.html
+ Sun, 10 Oct 2021 00:00:00 GMT
+ 2021-10-10T00:00:00Z
+ 2021-10-10T00:00:00Z
+
+
+
+ Creating a HTML drop-down list
+ https://steve0greatness.github.io/blog/Creating_HTML_DD_List.html
+
+
+ <p>Depending on your Feed reader, you may want to <a href="https://steve0greatness.github.io/blog/Creating_HTML_DD_List.html">read this article online</a>.</p>
+ <p>Inorder to create a drop-down selection list in HTML, we must first understand why they are important.<br />Drop-down lists can be used in lots of ways, from creating a way for people to chose from a strict set of options, to making an on-off switch(even though you should use buttons for that)<br />Before we start, here is an example:<table><td style="font-weight: bolder; text-align: right; font-size: 1em;">Select Image: </td><td><select id="selcet" onchange="document.getElementById('img').src = document.getElementById('selcet').value"><option value="https://upload.wikimedia.org/wikipedia/commons/a/a2/Paul_von_Hindenburg_%281914%29_von_Nicola_Perscheid.jpg" selected="true">Img 1</option><option value="https://upload.wikimedia.org/wikipedia/commons/thumb/d/d4/Wilfried_Gruhn.jpg/121px-Wilfried_Gruhn.jpg">Img 2</option><option value="https://upload.wikimedia.org/wikipedia/commons/thumb/f/f5/Blackcap_%28Sylvia_atricapilla%29_male.jpg/129px-Blackcap_%28Sylvia_atricapilla%29_male.jpg">Img 3</option><option value="https://upload.wikimedia.org/wikipedia/commons/thumb/0/01/Lt._Gen._Nguy%E1%BB%85n_V%C4%83n_Thi%E1%BB%87u_at_Cam_Ranh_Base%2C_October_26%2C_1966.jpg/116px-Lt._Gen._Nguy%E1%BB%85n_V%C4%83n_Thi%E1%BB%87u_at_Cam_Ranh_Base%2C_October_26%2C_1966.jpg">Img 3</option><option value="https://upload.wikimedia.org/wikipedia/commons/thumb/6/66/Steve_Stricker.jpg/157px-Steve_Stricker.jpg">Img 4</option><option value="https://upload.wikimedia.org/wikipedia/commons/thumb/c/cf/Aegotheles_chrisoptus_-_Catlereigh_Nature_Reserve.jpg/350px-Aegotheles_chrisoptus_-_Catlereigh_Nature_Reserve.jpg">Img 5</option><option value="https://upload.wikimedia.org/wikipedia/commons/thumb/7/73/Michael_Whelan_-_Lucca_2017.jpg/118px-Michael_Whelan_-_Lucca_2017.jpg">Img 6</option><option value="https://upload.wikimedia.org/wikipedia/commons/thumb/6/60/St_Pancras_Railway_Station_2012-06-23.jpg/152px-St_Pancras_Railway_Station_2012-06-23.jpg">Img 7</option><option value="https://upload.wikimedia.org/wikipedia/commons/thumb/8/8c/Mae_La_refugee_camp_TFA.jpg/162px-Mae_La_refugee_camp_TFA.jpg">Img 8</option><option value="https://upload.wikimedia.org/wikipedia/commons/thumb/e/ea/JimmyCarterPortrait_%28cropped%29.jpg/121px-JimmyCarterPortrait_%28cropped%29.jpg">Img 9</option></select></td></table><img id="img" src="https://upload.wikimedia.org/wikipedia/commons/a/a2/Paul_von_Hindenburg_%281914%29_von_Nicola_Perscheid.jpg" style="width: auto; height: 10em;" /><div style="font-size: 10px;">Images from <a style="color: inherit;" href="https://en.wikipedia.org">Wikipedia</a>, on <a style="color: inherit;" href="https://web.archive.org/web/20211001135954/https://en.wikipedia.org/wiki/Main_Page">Oct. 2nd & </a><a style="color: inherit;" href="https://web.archive.org/web/20211002095505/https://en.wikipedia.org/wiki/Main_Page">1st, 2021</a></div>For some weird reason, it's not in<div class="code"><input></div>It has it's own tags, know as <span class="code"><select></span> and <span class="code"><option></span>. Using these is alittle like making a list, if you've ever made one. Here's an example bit of HTML.<div class="code"><select><div style="text-indent: 1em;"><option>op 1</option></div><div style="text-indent: 1em;"><option>op 2</option></div></select></div>Next we want to add values to <span class="code"><options></span>, and an id(#) to <span class="code"><select></span>.<br />You most-likely already know how to do ids, and maybe also values(if you have used input in any way), so I'll leave it up to you.<br />However, you may not know some things that could be useful here, such as preselections, or making things update upon being changed, well, you can do preselections with <span class="code">selected</span> in the <span class="code"><option></span> that you want to be preselected. Changes done the page upon the change of the selection in the drop-down(or anything else that can be changed by the user) is <span class="code">onchange="submitFunction()"</span> being placed in the <span class="code"><select></span>.<br />Let's check back on the code that we made at the code example:<div class="code" id="finished"><select onchange="submitFunction()" id="selection"><div style="text-indent: 1em;"><option value="op1" selected>op 1</option></div><div style="text-indent: 1em;"><option value="op2">op 2</option></div></select></div>Inorder to access the selected option with JavaScript, use <span class="code">document.getElementById("selection").value</span><br />That's basically it, feel free to <span class="code">CTRL + C</span> <span class="code">CTRL + V</span> it. /s</p>
+
+
+ Creating_HTML_DD_List.html
+ Fri, 01 Oct 2021 00:00:00 GMT
+ 2021-10-01T00:00:00Z
+ 2021-10-01T00:00:00Z
+
+
+
+ YouTube needs to have an open REST API
+ https://steve0greatness.github.io/blog/Youtube_needs_a_Rest_API.html
+
+
+ <p>Depending on your Feed reader, you may want to <a href="https://steve0greatness.github.io/blog/Youtube_needs_a_Rest_API.html">read this article online</a>.</p>
+ <p>Youtube needs an open Rest API. Here are some reasons:<ol><li>It makes my life easier, as I don't need to write a billion lines of code, and not go throught the <span style="font-style: italic; font-weight: bold;">paid service</span> known as google cloud console, to get an api key.</li><li>It means that you only need to use <span class="code">fetch()</span> on it.</li><li>We don't need the most in depth api.</li></ol></p>
+
+
+ Youtube_needs_a_Rest_API.html
+ Wed, 29 Sep 2021 00:00:00 GMT
+ 2021-09-29T00:00:00Z
+ 2021-09-29T00:00:00Z
+
+
+
+ How to Make the perfect Tea.
+ https://steve0greatness.github.io/blog/How_To_Make_Tea.html
+
+
+ <p>Depending on your Feed reader, you may want to <a href="https://steve0greatness.github.io/blog/How_To_Make_Tea.html">read this article online</a>.</p>
+ <p><div class="notice">this is opinion based, there's no perfect tea</div>Tea is the perfect fit for most meals, breakfast, 2nd breakfast, morning tea, lunch, afTernoon tea, dinner, or supper.<br />But how do I make it? Here's how I make my tea.<h2 id="step1">Step 1</h2>The first step is to get the brand of tea you like. I personally like stuff such as Mighty Leaf, it tastes strong, and your able to use it 3 times without it getting weaker, and even then, you can still use it more, it really doesn't lose it's weakness.<h2 id="step2">Step 2</h2>Get a mug, or tea cup. I personally like mugs, as they are normally bigger, meaning you don't have to refill as much as a tea cup.<h2 id="step3">Step 3</h2>Get your tea, if you're using loose leaf, I'd use a smaller cup to make it, then use a strainer to the leaves out, as it adds texture that I don't like personally, otherwise just put the tea bag in, it is at this point that I like to stir it.<h2 id="step4">Final Step</h2>Enjoy.<br />You can add sugar and <span style="text-decoration: line-through;">milk</span> cream, if you're into those kinda things... even lemon if you really want.<br /><img src="https://upload.wikimedia.org/wikipedia/commons/thumb/3/32/English_teaware.jpg/1280px-English_teaware.jpg" title="src: Wikipedia" width="250" /></p>
+
+
+ How_To_Make_Tea.html
+ Tue, 28 Sep 2021 00:00:00 GMT
+ 2021-09-28T00:00:00Z
+ 2021-09-28T00:00:00Z
+
+
+
+ Changing the light-mode
+ https://steve0greatness.github.io/blog/Changing_the_Light-mode.html
+
+
+ <p>Depending on your Feed reader, you may want to <a href="https://steve0greatness.github.io/blog/Changing_the_Light-mode.html">read this article online</a>.</p>
+ <p>As of currently, the light mode on this site doesn't live up to what I want it to be.<br />I want it to be something that is the opposite of the dark mode, and it really isn't that. Expect it to change. But, in case you do still want to view it, here are the current css variable colors:<br /><div class="code">html.l {<div style="margin-left: 1em;">--navCo: #0F0089;<br />--headCo: #3700FF;<br />--linkCo: #F7E45D;<br />--maCo: #0044F7;<br />--maTxtCo: #C2FFBA;<br />--buCo: #F09;<br />--buTxtCo: #0FF;<br />--buBoCo: #fff;<br />--noteCo: #f25;<br />--noteTxtCo: #ccc;<br />--inCo: #0bf;<br />--inlinkCo: #05c;<br />--selCo: #f51;<br />--selTxtCo: #059;<br />--taCo: #cf4;<br />--taTxtCo: black;</div>}</div></p>
+
+
+ Changing_the_Light-mode.html
+ Sat, 11 Sep 2021 00:00:00 GMT
+ 2021-09-11T00:00:00Z
+ 2021-09-11T00:00:00Z
+
+
+
+ Why inspect-element is useful
+ https://steve0greatness.github.io/blog/Why-inspect-element-is-a-useful-tool.html
+
+
+ <p>Depending on your Feed reader, you may want to <a href="https://steve0greatness.github.io/blog/Why-inspect-element-is-a-useful-tool.html">read this article online</a>.</p>
+ <p><div class="notice">This post isn't very good, and I'm not proud of it.</div>So, as of currently, my <a href="https://ocular.jeffalo.net/user/Steve0Greatness">Ocular Status</a> is <span style="font-style: italic; color: #0dbfb7; background-color: #0f0f0f;">Mobile needs a better browser! #MobileSmartBrowser! (Er/Him)</span>. Part of the reason for this is so that inspect can be on mobile.<p>but what makes inspect so important?</p>Well I'm glad I asked!<div>So on GitHub, you only have 2000 actions you can do(on the free plan). So that means you need to use them carefully, make sure that you won't do something that wastes an action.</div>It helps you fix any mistake, before you make anymore. <div>Of course, you can always download the file, and edit it offline. But inspect element is easier, live, and requires less space in your hard-drive.</div>Thanks for coming to my Ted-talk.😜🤪</p>
+
+
+ Why-inspect-element-is-a-useful-tool.html
+ Mon, 17 May 2021 00:00:00 GMT
+ 2021-05-17T00:00:00Z
+ 2021-05-17T00:00:00Z
+
+
+
+ How to Copy and Paste on mobile
+ https://steve0greatness.github.io/blog/How-to-copy-and-paste-on-mobile.html
+
+
+ <p>Depending on your Feed reader, you may want to <a href="https://steve0greatness.github.io/blog/How-to-copy-and-paste-on-mobile.html">read this article online</a>.</p>
+ <p><div class="notice">This post isn't very good, and I'm not proud of it.</div>Recently, I've been seeing a lot of people coming up with one excuse for not linking the dupelicate topic in the suggestions forum. They say something like,<div style="background-color: #979797;color: black;padding: 3px;">I'm on mobile!!!!! 😖😭😫</div>this is not a correct argument, so I've decided to make this post to prove it.<h1>Safari/iOS</h1>the way that you copy and paste on Safari is by double taping on the text, then dragging until you've selected all the text<span style="color: #FF0000;">(the next bit works for links, not this)</span><h2>Coping links</h2>tap and hold on the link until you see:<img src="https://i.ibb.co/9cYsfcP/IMG-5938.jpg" alt="open, open in background, open in new window, download link file, add to reading list, *copy*, share" border="0" width="130" height="105" /><h2>Paste</h2>going to any textbox, in the top-lefT-hand conner, you should see a little clipboard icon(as long as you aren't selecting any text), press it. tap "copy(circled in <span style="color: #FF0000;">red</span>)"<div style="background-color: #ff0004; color: #00FFFF; text-align: center;">🏷Note: I don't own an android tablet or phone, so take this with a grain of salt</div><h1>Chrome/Android</h1>press and hold until a few selection boxes come up(might work for links)<h2>pasting</h2>tap and hold int the text box, you should see "paste," now click that(boxed in <span style="color: #FF0000;">:<img src="https://u.cubeupload.com/Steve_Greatness/Screenshot2021050571.png" width="300" height="60" /><span style="font-size: 10px;"><a href="https://www.businessinsider.com/how-to-copy-and-paste-on-android?op=1">Image Source</a></span></span></p>
+
+
+ How-to-copy-and-paste-on-mobile.html
+ Wed, 05 May 2021 00:00:00 GMT
+ 2021-05-05T00:00:00Z
+ 2021-05-05T00:00:00Z
+
+
+
+ How to make mockups
+ https://steve0greatness.github.io/blog/How-To-make-mockups.html
+
+
+ <p>Depending on your Feed reader, you may want to <a href="https://steve0greatness.github.io/blog/How-To-make-mockups.html">read this article online</a>.</p>
+ <p><div class="notice">This post isn't very good, and I'm not proud of it.</div>The first step to making a mockup is to open up the inpect menu, you may be able to do this using <t>ctrl+shifT+i</t>(or <t>f12</t>)<div class="Notice">this will be different from browser to browser.</div>once you see inspect element open, simply go to the page you're making a mockup for(ex. <a href="https://Scratch.mit.edu/mystuff">MyStuff</a>; or if you're making a new page, go to the page that looks the closest.), and press <t>ctrl+shifT+c</t>, and click on the area that you want to change(ex. the <t>+ New Project</t> button.<p>now that you've selected the element, let's learn how to edit it! You should see the element that you clicked on(using the <t>ctrl+shifT+c</t> command) highlighted in blue. Inside of the element(if you selected text, or even an image), you should see a darker area, that isn't red, <t>double click</t> on it, it should now be hilighted, now type in whatever you want(if it's an image, make sure to put in an image link, ex. https://imagehoster.com/png/png.png; if you clicked on a link(in the "" in "a href=''", unselect it and select the part "<a href='link'>"here"</a>").</p>anyways... if you don't have the monna lisa yet, just give up /s</p>
+
+
+ How-To-make-mockups.html
+ Thu, 22 Apr 2021 00:00:00 GMT
+ 2021-04-22T00:00:00Z
+ 2021-04-22T00:00:00Z
+
+
+
+
+
\ No newline at end of file
diff --git a/blog/fizzbuzz.html b/blog/fizzbuzz.html
new file mode 100644
index 0000000..8cc41f7
--- /dev/null
+++ b/blog/fizzbuzz.html
@@ -0,0 +1,130 @@
+
+
+
+
+
+
+
+
+ The FizzBuzz Program - S0G
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
A FizzBuzz Program is a program used in many job interviews to see if a programmer is good at problem solving. There are many ways to make one.
+
+
First let me tell you why I write these programs. These programs, at least in my opinion, are good when you're learning a new programming language. It gives you a problem to solve, and all you need to do to solve it. Incase you're wondering, the problem is to make a program that counts from 1 to 100 and replaces all multiples of 3 with Fizz, all multiples of 5 with Buzz, and multiples of both with FizzBuzz. Generally in interviews, they also ask you to add on more multiples, such as multiples of 7 are replaced with Fuzz, and multiples of 11 are replaced with Bizz.
+
+
Now that I've told you what a FizzBuzz Program is, let me show you how I make them in Python.
+
+
for i in range(1, 100):
+ toPrint = ""
+ print(toPrint)
+
+
+
The first thing I do is I create a for loop, and within it I put a print statement and a variable named toPrint.
+
+
def check(checktomulti, multi, toreturn):
+ if checktomulti % multi == 0:
+ return toreturn
+ return ""
+
+def checkEmpty(string, number):
+ if string == "":
+ return number
+ return string
+
+for i in range(1, 100):
+ toPrint = checkEmpty(check(i, 3, "Fizz") + check(i, 5, "Buzz"), i)
+ print(toPrint)
+
+
+
The next thing I do is I define a function that checks if one number is a multiple of another, and if it is, then it returns the string, otherwise, it returns an empty string.
+
+
Then I make a function that checks if a string is an empty one, if it is, then it returns a number.
+
+
Once I have these 2 functions, I go back into the for loop and make the toPrint variable have the variable for checking if a string is empty(and if it is replace it with a number) check if 2 of the other function that check if one number is a multiple of another(and if it is, return a string). Finally, it prints the output.
+
+
I've tried this method many times. Below are some examples of this method in action!
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/blog/fizzbuzz.txt b/blog/fizzbuzz.txt
new file mode 100644
index 0000000..3e88157
--- /dev/null
+++ b/blog/fizzbuzz.txt
@@ -0,0 +1,46 @@
+---
+title: The FizzBuzz Program
+date: 2022 Feb 20
+updated: 2024 Jan 17
+---
+A FizzBuzz Program is a program used in many job interviews to see if a programmer is good at problem solving. There are many ways to make one.
+
+First let me tell you why I write these programs. These programs, at least in my opinion, are good when you're learning a new programming language. It gives you a problem to solve, and all you need to do to solve it. Incase you're wondering, the problem is to make a program that counts from 1 to 100 and replaces all multiples of 3 with Fizz, all multiples of 5 with Buzz, and multiples of both with FizzBuzz. Generally in interviews, they also ask you to add on more multiples, such as multiples of 7 are replaced with Fuzz, and multiples of 11 are replaced with Bizz.
+
+Now that I've told you what a FizzBuzz Program is, let me show you how I make them in Python.
+
+```python
+for i in range(1, 100):
+ toPrint = ""
+ print(toPrint)
+```
+
+The first thing I do is I create a for loop, and within it I put a print statement and a variable named toPrint.
+
+```python
+def check(checktomulti, multi, toreturn):
+ if checktomulti % multi == 0:
+ return toreturn
+ return ""
+
+def checkEmpty(string, number):
+ if string == "":
+ return number
+ return string
+
+for i in range(1, 100):
+ toPrint = checkEmpty(check(i, 3, "Fizz") + check(i, 5, "Buzz"), i)
+ print(toPrint)
+```
+The next thing I do is I define a function that checks if one number is a multiple of another, and if it is, then it returns the string, otherwise, it returns an empty string.
+
+Then I make a function that checks if a string is an empty one, if it is, then it returns a number.
+
+Once I have these 2 functions, I go back into the for loop and make the `toPrint` variable have the variable for checking if a string is empty(and if it is replace it with a number) check if 2 of the other function that check if one number is a multiple of another(and if it is, return a string). Finally, it prints the output.
+
+I've tried this method many times. Below are some examples of this method in action!
+
+* [Kotlin](https://replit.com/@StevesGreatness/FizzBuzzKotlin)
+* [Lua](https://replit.com/@StevesGreatness/FizzBuzzlua)
+* [Python](https://replit.com/@StevesGreatness/FizzBuzzpython)
+* [Ruby](https://replit.com/@StevesGreatness/FizzBuzzRuby)
\ No newline at end of file
diff --git a/blog/fortress-forever-on-linux.html b/blog/fortress-forever-on-linux.html
new file mode 100644
index 0000000..09ac5cf
--- /dev/null
+++ b/blog/fortress-forever-on-linux.html
@@ -0,0 +1,97 @@
+
+
+
+
+
+
+
+
+ Fortress Forever on Linux! - S0G
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
Fortress Forever is finally playable fully on Linux using Proton-GE version 7-41(note: if you change the setting you will have to reboot the game).
+
+
If you need a quick rundown on how to download and install Proton-GE, I've made a video about that already. It is technically about a different game, however, the problem is still similar enough to apply pretty much the same steps.
+
+
It plays pretty well, the only problem is when a local server changes maps, and the font for some of the menus(and the chat) being very... bad looking. It's not the game's fault for the second one, however, it is still something that's annoying if you don't want to do too much tinkering.
+
+
I'm glad to be able to play this great game on my daily OS without having to open Bottles every time I want to play Fortress Forever.
+
+
Whenever I'm playing Fortress Forever, I'm usually on MaxTF's Midwest server... I have the lowest ping there, not good though.
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/blog/fortress-forever-on-linux.txt b/blog/fortress-forever-on-linux.txt
new file mode 100644
index 0000000..5b762c9
--- /dev/null
+++ b/blog/fortress-forever-on-linux.txt
@@ -0,0 +1,14 @@
+---
+title: Fortress Forever on Linux!
+date: 2022 Dec 16
+updated: 2023 Jan 1
+---
+Fortress Forever is finally playable fully on Linux using Proton-GE version 7-41(note: if you change the setting you will have to reboot the game).
+
+If you need a quick rundown on how to download and install Proton-GE, [I've made a video about that already](https://youtu.be/B2LZ8nYd3Bw). It is technically about a different game, however, the problem is still similar enough to apply pretty much the same steps.
+
+It plays pretty well, the only problem is when a local server changes maps, and the font for some of the menus(and the chat) being very... bad looking. It's not the game's fault for the second one, however, it is still something that's annoying if you don't want to do too much tinkering.
+
+I'm glad to be able to play this great game on my daily OS without having to open Bottles every time I want to play Fortress Forever.
+
+Whenever I'm playing Fortress Forever, I'm usually on [MaxTF's Midwest server](https://www.gametracker.com/server_info/server2.maxcommunity.net:27015/)... I have the lowest ping there, not good though.
\ No newline at end of file
diff --git a/blog/index.html b/blog/index.html
new file mode 100644
index 0000000..ad3dd19
--- /dev/null
+++ b/blog/index.html
@@ -0,0 +1,272 @@
+
+
+
+
+
+
+
+
+ Blog Index - S0G
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
When I've been trying(and failing) to use Tab on my computer(it's a Macbook) for what feels like forever now. Turns out, it was as simple as hitting Ctrl + F7.
+
+
To be honest, I thought that it was just an issue with FireFox, and then I read Browser keyboard navigation in macOS and realized that it was an issue with MacOS! This should really be an option enabled by default, but Apple is stupid.
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/blog/macos-page-tab-nav.txt b/blog/macos-page-tab-nav.txt
new file mode 100644
index 0000000..e24d10a
--- /dev/null
+++ b/blog/macos-page-tab-nav.txt
@@ -0,0 +1,10 @@
+---
+title: MacOS Keyboard Navigation
+date: 2022 Feb 26
+updated: 2024 Jan 17
+---
+Ok, so I feel like a complete idiot right now.
+
+When I've been trying(and failing) to use `Tab` on my computer(it's a Macbook) for what feels like forever now. Turns out, it was as simple as hitting `Ctrl` + `F7`.
+
+To be honest, I thought that it was just an issue with FireFox, and then I read [Browser keyboard navigation in macOS](https://www.a11yproject.com/posts/macos-browser-keyboard-navigation/) and realized that it was an issue with MacOS! This should really be an option enabled by default, but Apple is stupid.
\ No newline at end of file
diff --git a/blog/satisfactory-farming-idea.html b/blog/satisfactory-farming-idea.html
new file mode 100644
index 0000000..ae4dd39
--- /dev/null
+++ b/blog/satisfactory-farming-idea.html
@@ -0,0 +1,139 @@
+
+
+
+
+
+
+
+
+ Satisfactory Concept: Farming - S0G
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
Here is my idea for automating the collection of healing materials(such as Beryl Nuts) in Satisfactory
+
+
Plant Pods
+
+
Plant pods would be researchable in the Nutrients section of the MAM. It would cost:
+* 5 modular frames
+* 10 steel pipes
+* 20 biofuel
+
+
to research.
+
+
You'd be able to build it in a new _Farming_ section in the production category of the build menu. It would cost the user:
+* 4 steel pipes
+* 2 quickwire
+* 5 biofuel
+
+
to build. It would require 1 MW of power to function. Plants that are left without power while in there will not continue growing or providing harvest, however they will not die(that'd be annoying if they did).
+
+
The user would be able to interact with the planting pod to bring up a menu that tells them what stage of growing it's at(baby, growing, fully grown), how ripe for harvest the plant is(out of 3 states: none, starting, ripe). The UI will have a button to harvest at the bottom, and a box that will allow the plant to be exchanged for another--which would give you a few leaves, proportional to how long it's been growing(0 if baby, 4 if growing, 10 if fully grown), and the amount of fruit they would have gotten from the harvest + 1 extra(for the fruit they put in).
+
+
Robot Farmers
+
+
Researchable under the _Crystal Oscillator_. The research cost is:
+* 10 Crystal Oscillators
+* 5 AI limiter
+* 3 quickwire
+
+
These little farmers need power to survive, which is why the _ROBOT charger_ is unlocked with them.
+This building can be built in the power section. They cost:
+* 15 quickwire
+* 2 modular frames
+* 5 crystal oscillators
+
+
to build.
+
+
Once built, this building acts like the truck station, but instead of coal, it loads power, and it can only unload items from the bot's inventory.
+
+
The Robo-Farmer is then buildable under the _Farming_ section in the production category of the build menu. It costs :
+* 1 Factory Cart
+* 2 Crystal Oscillators
+* 1 AI limiter
+* 3 quickwire
+* 5 steal pipes
+
+
to build.
+
+
These little robots have themselves a little UI that allows you to select items they should farm. Once given a task, these robots will always return to the nearest _ROBOT charger_ when their inventory is full, or they are running low on power(robots will always attempt to keep themselves powered). If the robot cannot find a plant within range that is harvestable, then the they will wait until there is one.
+
+
Getting the most out of these resources
+
+
Robot Farmers are best at traversing on foundations(they spend less power). As such, it is recommended, that the player create a flat platform that has plant pods with some space between for the bots to traverse between them. In the center, the player should build a _ROBOT charger_, as it will allow the robots the run around equally in each direction. Players should also utilize the _Conveyor Lift_ to bring materials to a layer above for sorting, or other purposes.
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/blog/satisfactory-farming-idea.txt b/blog/satisfactory-farming-idea.txt
new file mode 100644
index 0000000..07bbb25
--- /dev/null
+++ b/blog/satisfactory-farming-idea.txt
@@ -0,0 +1,54 @@
+---
+title: Satisfactory Concept: Farming
+date: 2023 Apr 16
+---
+Here is my idea for automating the collection of healing materials(such as Beryl Nuts) in Satisfactory
+
+## Plant Pods
+
+Plant pods would be researchable in the Nutrients section of the MAM. It would cost:
+* 5 modular frames
+* 10 steel pipes
+* 20 biofuel
+
+to research.
+
+You'd be able to build it in a new _Farming_ section in the production category of the build menu. It would cost the user:
+* 4 steel pipes
+* 2 quickwire
+* 5 biofuel
+
+to build. It would require 1 MW of power to function. Plants that are left without power while in there will not continue growing or providing harvest, however they will not die(that'd be annoying if they did).
+
+The user would be able to interact with the planting pod to bring up a menu that tells them what stage of growing it's at(baby, growing, fully grown), how ripe for harvest the plant is(out of 3 states: none, starting, ripe). The UI will have a button to harvest at the bottom, and a box that will allow the plant to be exchanged for another--which would give you a few leaves, proportional to how long it's been growing(0 if baby, 4 if growing, 10 if fully grown), and the amount of fruit they would have gotten from the harvest + 1 extra(for the fruit they put in).
+
+## Robot Farmers
+
+Researchable under the _Crystal Oscillator_. The research cost is:
+* 10 Crystal Oscillators
+* 5 AI limiter
+* 3 quickwire
+
+These little farmers need power to survive, which is why the _ROBOT charger_ is unlocked with them.
+This building can be built in the power section. They cost:
+* 15 quickwire
+* 2 modular frames
+* 5 crystal oscillators
+
+to build.
+
+Once built, this building acts like the truck station, but instead of coal, it loads power, and it can only unload items from the bot's inventory.
+
+The Robo-Farmer is then buildable under the _Farming_ section in the production category of the build menu. It costs :
+* 1 Factory Cart
+* 2 Crystal Oscillators
+* 1 AI limiter
+* 3 quickwire
+* 5 steal pipes
+
+to build.
+
+These little robots have themselves a little UI that allows you to select items they should farm. Once given a task, these robots will always return to the nearest _ROBOT charger_ when their inventory is full, or they are running low on power(robots will always attempt to keep themselves powered). If the robot cannot find a plant within range that is harvestable, then the they will wait until there is one.
+
+## Getting the most out of these resources
+Robot Farmers are best at traversing on foundations(they spend less power). As such, it is recommended, that the player create a flat platform that has plant pods with some space between for the bots to traverse between them. In the center, the player should build a _ROBOT charger_, as it will allow the robots the run around equally in each direction. Players should also utilize the _Conveyor Lift_ to bring materials to a layer above for sorting, or other purposes.
diff --git a/blog/singular-blog.html b/blog/singular-blog.html
new file mode 100644
index 0000000..1202fa2
--- /dev/null
+++ b/blog/singular-blog.html
@@ -0,0 +1,91 @@
+
+
+
+
+
+
+
+
+ My blog is now in one place - S0G
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
Alright, I've now moved all my full blog posts over to this one website. There might be other I miss in other places, but I'll add them here soon. I will not be moving over my micro-blogs, however. Those are too small, and I'd rather keep those separated anyway.
+
+
I'm not a fan of how I wrote before December of 2022, everything there is filled with spelling mistakes and grammar issues, I also think most of it was rude towards the reader, which is not a good impression.
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/blog/singular-blog.txt b/blog/singular-blog.txt
new file mode 100644
index 0000000..2befef5
--- /dev/null
+++ b/blog/singular-blog.txt
@@ -0,0 +1,8 @@
+---
+title: My blog is now in one place
+date: 2024 Jan 1
+---
+
+Alright, I've now moved all my full blog posts over to this one website. There might be other I miss in other places, but I'll add them here soon. I will not be moving over my micro-blogs, however. Those are too small, and I'd rather keep those separated anyway.
+
+I'm not a fan of how I wrote before December of 2022, everything there is filled with spelling mistakes and grammar issues, I also think most of it was rude towards the reader, which is not a good impression.
\ No newline at end of file
diff --git a/blog/symbols.html b/blog/symbols.html
new file mode 100644
index 0000000..da07931
--- /dev/null
+++ b/blog/symbols.html
@@ -0,0 +1,89 @@
+
+
+
+
+
+
+
+
+ Symbols - S0G
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
In our lifes on the internet, we see alot of characters that we don't normally see. Like @, #, &, [], {}, \, ;, and |. But what are thier names, what are their origins, and why do they look like they do? I'm going to try and find out! Let's start with what they are used for most of the time on the web.
@ is used to mean at. It can also be used to define a username(@user), or even emails(person@emailprovider.topleveldomain)
The hashtag, #, is used for tagging posts to topics(#NumberOneProgrammer). It is also sometimes used to define a number(#1). It's also used in CSS to define IDs, and in urls to scroll down to a certain part of the page(#theMan).
& is a symbol used to mean "and"(the dog & the cat). It is also used in urls to be an addition to the search(?q=look%20mom%20no%hands%21&images)
Square brackets([]), are used to define a list in the most widely used programming language on the web, JavaScript(["the dog", "the cat", "the bird", "the plane"]). They can also be used in the middle of quotes to give context("Have a nice day!" [The mayor] shouted)
Curly brackets({}) are used to define a JavaScript object( {person: "Jim", car: "JavaScript car :)"} )
backslash(\) is used in markdown, and JavaScript strings, to define a character that should remain itself, such as \# showing up as a # instead of a heading.
Semi-collins(;) are used to define the end of a command in lots of programming languages, like JavaScript(alert("hello world");), PHP(echo "hello world";)
|, or Vertical bar, has no real use on the web.
~, or tilde, also, doesn't find much use
Grave accents(`) are used to define a multi-lined JavaScript string(`this has 2 lines`)
Those are what they are, but what about their original meanings?
The At-Sign(@) is used to mean at(they're @ their house), it could also be used for a price(@10 pence)
#(pound-sign, hashtag, number-sign, octothorpe, sharp-sign), it's used to mean lb(10 #), define numbers(#10), define a tag in social media(#NumberOneCoder), to define the musical notes that are sharp, or used on telephones to do... something.
Ampersands(&) are used as &, that's it(doges & golden retrievers).
[Square Brackets] are used as a way to add context to the middle of a sentence, like "he ate the sausage", but we don't know who "he" is, and what kind of sausage he is eating, so it should be "[the young boy] ate the [cheese filled] sausage"
{Curly Brackets} don't get much use. They would be used for {defining words, lines, sentences as being in a group}.
|s are used to define absolute value, like |-2| = 2. It can also be used as a replacement for periods, and forward slashed
The backslash doesn't get much real use in writing. In math, it is used to represent the set difference(which I won't really explain), such as a\n
The Semicolon is used to seperate ideas in a sentence filled with commas, add seperation between an explaination; and a seperator(,) in a list, and merge 2 sentences together without a compound(and, but, or). Such as "I am so happy for them, and I am proud" & "I am so happy; I am proud." act the same. If you'd like a better explaination, I'd suggest you to check out How to use a semicolon by Ted-Ed, it's a great whatch, and it's presented in an interesting and fun style.
Grave accents(`) are used in some words from other languages, but not much in English. However it can be used in songs and poems to indicate that silent letters aren't silent.
Tildes(~) can be used in a sentence to mean about, for example, ~10.
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/blog/symbols.txt b/blog/symbols.txt
new file mode 100644
index 0000000..353ee70
--- /dev/null
+++ b/blog/symbols.txt
@@ -0,0 +1,5 @@
+---
+title: Symbols
+date: 2021 Oct 10
+---
+In our lifes on the internet, we see alot of characters that we don't normally see. Like @, #, &, [], {}, \\, ;, and |. But what are thier names, what are their origins, and why do they look like they do? I'm going to try and find out! Let's start with what they are used for most of the time on the web.
@ is used to mean at. It can also be used to define a username(@user), or even emails(person@emailprovider.topleveldomain)
The hashtag, #, is used for tagging posts to topics(#NumberOneProgrammer). It is also sometimes used to define a number(#1). It's also used in CSS to define IDs, and in urls to scroll down to a certain part of the page(#theMan).
& is a symbol used to mean "and"(the dog & the cat). It is also used in urls to be an addition to the search(?q=look%20mom%20no%hands%21&images)
Square brackets([]), are used to define a list in the most widely used programming language on the web, JavaScript(["the dog", "the cat", "the bird", "the plane"]). They can also be used in the middle of quotes to give context("Have a nice day!" [The mayor] shouted)
Curly brackets({}) are used to define a JavaScript object( {person: "Jim", car: "JavaScript car :)"} )
backslash(\\) is used in markdown, and JavaScript strings, to define a character that should remain itself, such as \\# showing up as a # instead of a heading.
Semi-collins(;) are used to define the end of a command in lots of programming languages, like JavaScript(alert("hello world");), PHP(echo "hello world";)
|, or Vertical bar, has no real use on the web.
~, or tilde, also, doesn't find much use
Grave accents(\`) are used to define a multi-lined JavaScript string(\`this has 2 lines\`)
Those are what they are, but what about their original meanings?
The At-Sign(@) is used to mean at(they're @ their house), it could also be used for a price(@10 pence)
#(pound-sign, hashtag, number-sign, octothorpe, sharp-sign), it's used to mean lb(10 #), define numbers(#10), define a tag in social media(#NumberOneCoder), to define the musical notes that are sharp, or used on telephones to do... something.
Ampersands(&) are used as &, that's it(doges & golden retrievers).
[Square Brackets] are used as a way to add context to the middle of a sentence, like "he ate the sausage", but we don't know who "he" is, and what kind of sausage he is eating, so it should be "[the young boy] ate the [cheese filled] sausage"
{Curly Brackets} don't get much use. They would be used for {defining words, lines, sentences as being in a group}.
|s are used to define absolute value, like |-2| = 2. It can also be used as a replacement for periods, and forward slashed
The backslash doesn't get much real use in writing. In math, it is used to represent the set difference(which I won't really explain), such as a\\n
The Semicolon is used to seperate ideas in a sentence filled with commas, add seperation between an explaination; and a seperator(,) in a list, and merge 2 sentences together without a compound(and, but, or). Such as "I am so happy for them, and I am proud" & "I am so happy; I am proud." act the same. If you'd like a better explaination, I'd suggest you to check out How to use a semicolon by Ted-Ed, it's a great whatch, and it's presented in an interesting and fun style.
Grave accents(\`) are used in some words from other languages, but not much in English. However it can be used in songs and poems to indicate that silent letters aren't silent.
Tildes(~) can be used in a sentence to mean about, for example, ~10.
\ No newline at end of file
diff --git a/blog/tf2-disguise-cmd.html b/blog/tf2-disguise-cmd.html
new file mode 100644
index 0000000..bb27a20
--- /dev/null
+++ b/blog/tf2-disguise-cmd.html
@@ -0,0 +1,143 @@
+
+
+
+
+
+
+
+
+ TF2 disguise Command - S0G
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
The basic layout of the disguise command is very simple.
+
+
disguise [class] [team]
+
+
+
class Parameter
+
+
1 : Scout
+
+
2 : Sniper
+
+
3 : Soldier
+
+
4 : Demoman
+
+
5 : Medic
+
+
6 : Heavy
+
+
7 : Pyro
+
+
8 : Spy
+
+
9 : Engineer
+
+
The reason the classes are in this order is that they were added in that order. As mentioned in Quake World Team Fortress § Versions on the Team Fortress wiki, it mentions the classes were added in the order of scout, sniper, soldier, demoman, and medic; then heavy; pyro; and finally spy and engineer.
+
+
team Parameter
+
+
These depend upon what team you're on.
+
+
-1 : Enemy Team
+
+
-2 : Friendly Team
+
+
Specific Teams
+
+
These aren't extremely useful, but they exist. They are independent of the team you're on.
+
+
1 : Blu Team
+
+
2 : Red Team
+
+
Example
+
+
Normally, when you disguise as a spy of your team, you undisguise. This also applies to the disguise command, allowing for an "undisguise" command.
+
+
disguise "8" "-2"
+
+
+
You're also able to put this into a bind, allowing for an undisguise bind.
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/blog/tf2-disguise-cmd.txt b/blog/tf2-disguise-cmd.txt
new file mode 100644
index 0000000..97289fc
--- /dev/null
+++ b/blog/tf2-disguise-cmd.txt
@@ -0,0 +1,62 @@
+---
+title: TF2 disguise Command
+date: 2022 Dec 17
+updated: 2024 Jan 17
+---
+A Spy class-specific command
+
+## Layout
+
+The basic layout of the disguise command is very simple.
+
+```
+disguise [class] [team]
+```
+
+## `class` Parameter
+
+`1` : Scout
+
+`2` : Sniper
+
+`3` : Soldier
+
+`4` : Demoman
+
+`5` : Medic
+
+`6` : Heavy
+
+`7` : Pyro
+
+`8` : Spy
+
+`9` : Engineer
+
+The reason the classes are in this order is that they were added in that order. As mentioned in [*Quake World Team Fortress* § Versions](https://wiki.teamfortress.com/wiki/Team_Fortress#Versions) on the Team Fortress wiki, it mentions the classes were added in the order of *scout*, *sniper*, *soldier*, *demoman*, and *medic*; then *heavy*; *pyro*; and finally *spy* and *engineer*.
+
+## `team` Parameter
+
+These depend upon what team you're on.
+
+`-1` : Enemy Team
+
+`-2` : Friendly Team
+
+### Specific Teams
+
+These aren't extremely useful, but they exist. They are independent of the team you're on.
+
+`1` : Blu Team
+
+`2` : Red Team
+
+## Example
+
+Normally, when you disguise as a spy of your team, you undisguise. This also applies to the disguise command, allowing for an "undisguise" command.
+
+```
+disguise "8" "-2"
+```
+
+You're also able to put this into a bind, allowing for an undisguise bind.
\ No newline at end of file
diff --git a/blog/whyLocalVarCallLet.html b/blog/whyLocalVarCallLet.html
new file mode 100644
index 0000000..82154f4
--- /dev/null
+++ b/blog/whyLocalVarCallLet.html
@@ -0,0 +1,89 @@
+
+
+
+
+
+
+
+
+ Why local variables are called "let" - S0G
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
In JavaScript there are 3 different kinds of variables, global variables(using var), constants(const, and local variables(let). All of the act allittle differently from eachother. Allow me to explain what they do.
Global variables, made using var, are as they sound, global variables. Once defined, they can be used, edited, or redefind anywhere.
Constants, defined with const, are constant, they cannot change, at all.
Local variables, defined with let, are variables that can only be used in the place that it is defined, like a function, and it's children.
Now that we has that established, let's talk about how local variables got their name.
Turns out "let" is a mathematical term. The "let" expression may also be defined in mathematics, where it associates a Boolean condition with a restricted scope.[source]. It was first used in programming in early languages like Basic.
In case you're wondering, the main source is this answer on Stack Overflow.
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/blog/whyLocalVarCallLet.txt b/blog/whyLocalVarCallLet.txt
new file mode 100644
index 0000000..0d3ebbe
--- /dev/null
+++ b/blog/whyLocalVarCallLet.txt
@@ -0,0 +1,5 @@
+---
+title: Why local variables are called "let"
+date: 2022 Jan 10
+---
+
In JavaScript there are 3 different kinds of variables, global variables(using var), constants(const, and local variables(let). All of the act allittle differently from eachother. Allow me to explain what they do.
Global variables, made using var, are as they sound, global variables. Once defined, they can be used, edited, or redefind anywhere.
Constants, defined with const, are constant, they cannot change, at all.
Local variables, defined with let, are variables that can only be used in the place that it is defined, like a function, and it's children.
Now that we has that established, let's talk about how local variables got their name.
Turns out "let" is a mathematical term. The "let" expression may also be defined in mathematics, where it associates a Boolean condition with a restricted scope.[source]. It was first used in programming in early languages like Basic.
In case you're wondering, the main source is this answer on Stack Overflow.
\ No newline at end of file
diff --git a/favicon.ico b/favicon.ico
new file mode 100644
index 0000000..887794f
Binary files /dev/null and b/favicon.ico differ
diff --git a/index.html b/index.html
new file mode 100644
index 0000000..15e660d
--- /dev/null
+++ b/index.html
@@ -0,0 +1,52 @@
+
+
+
+
+
+
+
+
+ Homepage - S0G
+
+
+
+
+
+
+
+
+
+
+
+
Hey there! I'm Steve0Greatness. Welcome to my website!
+
As of the current moment in time, there isn't much here. This mostly exists because I am one of those people that thinks that everyone should really have a website.
+
+
+
+
+
\ No newline at end of file
diff --git a/link-icon.png b/link-icon.png
new file mode 100644
index 0000000..7b2d05d
Binary files /dev/null and b/link-icon.png differ
diff --git a/link-tree.html b/link-tree.html
new file mode 100644
index 0000000..d334ad0
--- /dev/null
+++ b/link-tree.html
@@ -0,0 +1,7 @@
+
+
+
+
+
+Redirecting
Redirecting
+
This page has been moved to list/link-tree.html if you aren't automatically redirected, please click the following link to proceed to the new location of this page: list/link-tree.html
\ No newline at end of file
diff --git a/list/index.html b/list/index.html
new file mode 100644
index 0000000..9541e81
--- /dev/null
+++ b/list/index.html
@@ -0,0 +1,61 @@
+
+
+
+
+
+
+
+
+ List Index - S0G
+
+
+
+
+
+
+
+
+
+