2024-04-20 10:10:34 +00:00
<!DOCTYPE html>
< html lang = "en" dir = "ltr" id = "page-top" >
< head >
< meta charset = "UTF-8" >
< meta http-equiv = "X-UA-Compatible" content = "IE=edge" >
< meta name = "viewport" content = "width=device-width, initial-scale=1.0" >
< meta property = "og:title" content = "Resources | Star Wars: Knights of the Old Republic Shrine" >
< meta charset = "utf-8" >
< meta http-equiv = "X-UA-Compatible" content = "IE=edge" >
< meta name = "viewport" content = "width=device-width, initial-scale=1" >
< meta name = "description" content = "List of Star Wars: Knights of the Old Republic resources I have created or compiled myself.." >
< meta name = "generator" content = "Eleventy v2.0.1" >
< meta property = "og:type" content = "website" >
< meta property = "og:url" content = "https://leilukin.neocities.org/shrines/starwarskotor/resources/" >
< meta property = "og:site_name" content = "Leilukin's Hub" >
< meta property = "og:locale" content = "en_MY" >
< meta property = "og:description" content = "List of Star Wars: Knights of the Old Republic resources I have created or compiled myself.." >
< meta name = "twitter:card" content = "summary" >
< meta name = "twitter:url" content = "https://leilukin.neocities.org/shrines/starwarskotor/resources/" >
< meta name = "twitter:description" content = "List of Star Wars: Knights of the Old Republic resources I have created or compiled myself.." >
< link rel = "canonical" href = "https://leilukin.neocities.org/shrines/starwarskotor/resources/" >
< link rel = "stylesheet" href = "/assets/css/main.css" >
< link rel = "stylesheet" href = "/assets/css/starwarskotor.css" >
< link rel = "stylesheet" href = "/assets/fonts/noto-sans/noto-sans.css" >
< link href = "/assets/fonts/fontawesome/css/fontawesome.css" rel = "stylesheet" / >
< link href = "/assets/fonts/fontawesome/css/brands.css" rel = "stylesheet" / >
< link href = "/assets/fonts/fontawesome/css/solid.css" rel = "stylesheet" / >
2024-04-21 23:15:48 +00:00
< link rel = "apple-touch-icon" sizes = "180x180" href = "/assets/shrines/starwarskotor/images/kotor-icon.png" >
< link rel = "icon" type = "image/png" sizes = "32x32" href = "/assets/shrines/starwarskotor/images/kotor-icon.png" >
< link rel = "icon" type = "image/png" sizes = "16x16" href = "/assets/shrines/starwarskotor/images/kotor-icon.png" >
2024-04-20 10:10:34 +00:00
< link rel = "manifest" href = "/assets/favicon/site.webmanifest" >
< title >
Resources | Star Wars: Knights of the Old Republic Shrine | Leilukin's Hub
< / title >
< / head >
< body >
< header class = "hero" >
< div class = "hero__top-bar hidden" > < / div >
< div class = "hero__img" >
< picture >
2024-04-21 23:15:48 +00:00
< source srcset = "/assets/shrines/starwarskotor/images/swkotor-header-320.png" media = "(orientation: landscape)" / >
< img src = "/assets/shrines/starwarskotor/images/swkotor-header.jpg" alt = "anner of Star Wars: Knights of the Old Republic Shrine" / >
2024-04-20 10:10:34 +00:00
< / picture >
< / div >
< / header >
< style >
.hero {
width: 100%;
background-color: var(--clr-hero-bg);
display: flex;
flex-direction: column;
justify-content: center;
text-align: center;
}
.hero__top-bar {
background-color: var(--clr-navbar-bg);
width: 100%;
2024-04-23 07:57:54 +00:00
padding: 0.5em 0.7em;
2024-04-20 10:10:34 +00:00
}
.hero__img {
display: grid;
place-content: center;
}
.hero img {
2024-04-20 11:43:13 +00:00
object-fit: contain;
2024-04-20 10:10:34 +00:00
overflow: hidden;
2024-04-20 11:43:13 +00:00
max-height: 16rem;
2024-04-26 16:12:13 +00:00
2024-04-20 10:10:34 +00:00
}
< / style >
< script defer >
const hero = document.querySelector(".hero");
const heroTopBarEl = document.querySelector(".hero__top-bar");
const headerImgEl = document.querySelector(".hero__img");
2024-04-29 03:16:44 +00:00
const todayEvent = getTodayEvent();
2024-04-20 10:10:34 +00:00
if (todayEvent != "No event") {
heroTopBarEl.classList.remove('hidden');
heroTopBarEl.innerHTML = getBlurbHtml(todayEvent);
}
function getTodayEvent() {
const date = new Date();
const month = date.getMonth() + 1;
const day = date.getDate();
2024-04-23 08:42:37 +00:00
if (month == 7 & & day == 15)
2024-04-20 10:10:34 +00:00
return "KotOR 1 Anniversary";
else if (month == 12 & & day == 6)
return "KotOR 2 Anniversary";
else
return "No event";
}
function getBlurbHtml(day) {
2024-04-23 08:42:37 +00:00
const currentYear = new Date().getFullYear();
const kotor1ReleaseDate = new Date("2003-07-15").getFullYear();
const kotor2ReleaseDate = new Date("2004-12-06").getFullYear();
const kotor1Anniversary = currentYear - kotor1ReleaseDate;
const kotor2Anniversary = currentYear - kotor2ReleaseDate;
2024-04-20 10:10:34 +00:00
switch (day) {
case "KotOR 1 Anniversary":
return `
2024-04-23 08:42:37 +00:00
Today is the ${kotor1Anniversary}-year anniversary of the release of < cite > Star Wars: Knihgts of the Old Republic< / cite >
2024-04-20 10:10:34 +00:00
`;
break;
case "KotOR 2 Anniversary":
return `
2024-04-23 08:42:37 +00:00
Today is the ${kotor2Anniversary}-year anniversary of the release of < cite > Star Wars: Knights of the Old Republic II — The Sith Lords< / cite >
2024-04-20 10:10:34 +00:00
`;
break;
default:
return ``;
}
}
< / script >
< nav class = "navbar" >
< ul class = "nav__menu" >
< li >
< a href = "/shrines/starwarskotor/" > Shrine Home< / a >
< / li >
< li >
< a href = "/shrines/starwarskotor/articles/" > Articles< / a >
< / li >
< li >
< a href = "/shrines/starwarskotor/guides/" > Guides< / a >
< / li >
< li >
< a aria-current = "page" href = "/shrines/starwarskotor/resources/" > Resources< / a >
< / li >
< li >
< a href = "/shrines/starwarskotor/universes/" > Universes< / a >
< / li >
< li > < a href = "/shrines/" > Shrine Index< / a > < / li >
< li > < a href = "/" > Main Site< / a > < / li >
< / ul >
< / nav >
< style >
.navbar {
background: var(--clr-navbar-bg);
padding: 0 0.6rem;
width: 100%;
z-index: 999;
position: sticky;
top: 0;
}
.navbar a {
color: var(--clr-navbar-link);
text-decoration: none;
cursor: pointer;
}
.navbar a:hover {
color: var(--clr-link-hover);
}
.navbar a:focus {
outline-offset: 0.3em;
outline: 0.15em solid var(--clr-navbar-link);
}
.nav__menu {
list-style: none;
padding: 0;
display: flex;
justify-content: space-evenly;
flex-wrap: wrap;
gap: 0.5rem;
}
< / style >
< main >
< header class = "main__header" >
< h1 > Star Wars: Knights of the Old Republic Resources< / h1 >
< p > List of Star Wars: Knights of the Old Republic resources I have created or compiled myself..< / p >
< / header >
< div class = "content__wrapper" >
< aside class = "left-sidebar" >
< details class = "toc__wrapper sidebar--sticky" >
< summary class = "toc__heading" >
On This Page
< / summary >
< nav class = "toc" >
< ol >
< li > < a href = "#my-mods" > My Mods< / a >
< / li >
< li > < a href = "#my-modders-resource" > My Modder's Resource< / a >
< / li >
< li > < a href = "#my-save-files" > My Save Files< / a >
< / li >
< li > < a href = "#my-mod-lists" > My Mod Lists< / a >
< / li >
< li > < a href = "#references" > References< / a >
< / li >
< li > < a href = "#my-mod-builds" > My Mod Builds< / a >
< / li >
< / ol >
< / nav >
< / details >
< / aside >
< style >
.toc__wrapper {
max-height: 89vh;
overflow: auto;
background-color: var(--clr-content-bg);
padding: 1rem 1.3rem;
}
.toc__heading {
font-size: 1.3rem;
font-weight: 700;
color: var(--clr-sub-heading);
cursor: pointer;
}
.toc ol,
.toc ol ol {
display: grid;
gap: 0.3em;
}
.toc ol {
border-top: 0.1em solid var(--clr-title-border);
padding-left: 1.3em;
padding-top: 1em;
}
.toc ol ol {
border-top: none;
list-style-type: disc;
padding-left: 1em;
padding-top: 0.3em;
}
.toc ol a {
font-size: 1.1rem;
padding-left: 0.3em;
}
.toc ol ol a {
padding: 0;
font-size: 1rem;
}
< / style >
< div class = "content " >
< div class = "heading-wrapper h2" >
< h2 id = "my-mods" > My Mods< / h2 >
< a class = "heading-anchor" href = "#my-mods" aria-labelledby = "my-mods" > < span hidden > #< / span > < / a > < / div >
< p > Here are the modifications for the KotOR series I have created.< / p >
< ul class = "content-list" >
< li > < a href = "/projects/kotor1mods/" target = "_blank" > < cite > Star Wars: Knights of the Old Republic< / cite > < / a > < / li >
< li > < a href = "/projects/kotor2mods/" target = "_blank" > < cite > Star Wars: Knights of the Old Republic II: The Sith Lords< / cite > < / a > < / li >
< / ul >
< div class = "heading-wrapper h2" >
< h2 id = "my-modders-resource" > My Modder's Resource< / h2 >
< a class = "heading-anchor" href = "#my-modders-resource" aria-labelledby = "my-modders-resource" > < span hidden > #< / span > < / a > < / div >
< ul class = "content-list" >
< li > < a href = "https://deadlystream.com/files/file/2249-missing-k1-party-member-ports-for-tsl-modders-resource/" target = "_blank" > Missing K1 Party Member Ports for TSL< / a > < / li >
< / ul >
< div class = "heading-wrapper h2" >
< h2 id = "my-save-files" > My Save Files< / h2 >
< a class = "heading-anchor" href = "#my-save-files" aria-labelledby = "my-save-files" > < span hidden > #< / span > < / a > < / div >
< ul class = "content-list" >
< li > < a href = "https://deadlystream.com/files/file/2180-light-side-female-saves-with-kotor-1-community-patch-and-all-romances/" target = "_blank" > Light Side Female Saves with KOTOR 1 Community Patch and All Romances< / a > < / li >
< li > < a href = "https://deadlystream.com/files/file/2213-kotor-2-light-side-female-saves-with-tslrcm-and-partyswap/" target = "_blank" > KotOR 2 Light Side Female Saves with The Sith Lords Restored Content Mod and PartySwap< / a > < / li >
< / ul >
< div class = "heading-wrapper h2" >
< h2 id = "my-mod-lists" > My Mod Lists< / h2 >
< a class = "heading-anchor" href = "#my-mod-lists" aria-labelledby = "my-mod-lists" > < span hidden > #< / span > < / a > < / div >
< ul class = "content-list" >
< li > < a href = "./kotor-same-gender-romance-mods" > List of Same-Gender Romance Mods for the < cite > KotOR< / cite > Series< / a > < / li >
< li > < a href = "./kotor2-female-exile-recruit-handmaiden-mods" > List of < cite > KotOR 2< / cite > Mods that Allow Female Exiles to Recruit the Handmaiden as a Party Member< / a > < / li >
< / ul >
< div class = "heading-wrapper h2" >
< h2 id = "references" > References< / h2 >
< a class = "heading-anchor" href = "#references" aria-labelledby = "references" > < span hidden > #< / span > < / a > < / div >
< ul class = "content-list" >
< li > < a href = "./tslrcm-m478ep-modules-music" > The Sith Lords Restored Content Mod + M4-78 Enhancement Project Modules, Warp Codes & Music Overview< / a > < / li >
< / ul >
< div class = "heading-wrapper h2" >
< h2 id = "my-mod-builds" > My Mod Builds< / h2 >
< a class = "heading-anchor" href = "#my-mod-builds" aria-labelledby = "my-mod-builds" > < span hidden > #< / span > < / a > < / div >
< p > Lists of modifications for the KotOR games I use for my own playthroughs.< / p >
< ul class = "content-list" >
< li > < a href = "https://docs.google.com/document/d/1BTMJ1c-NOjU9q7qNftZac6jkOPluyucILglovcHtiaI/edit" target = "_blank" > Star Wars: Knights of the Old Republic< / a > < / li >
< li > < a href = "https://docs.google.com/document/d/15HbD-k-D8WHrp10IjIryAguhq7k2W94pkuGys7Z7xNM/edit" target = "_blank" > Star Wars: Knights of the Old Republic II: The Sith Lords< / a > < / li >
< / ul >
< / div >
< aside class = "right-sidebar" >
< div class = "shrine__info sidebar--sticky" >
< h2 > About< / h2 >
< p > Welcome to Leilukin's shrine for < cite > Star Wars: Knights of the Old Republic< / cite > , a series of role-playing video games set in the < cite > Star Wars< / cite > universe, taking place almost 4,000 years before the events of the Skywalker film saga.< / p >
< h3 > Links< / h3 >
< ul >
< li > < a href = "https://kotor.neocities.org/" target = "_blank" > KOTOR Community Portal< / a > < / li >
< / ul >
< / div >
< / aside >
< style >
.right-sidebar {
background-color: var(--clr-content-bg);
font-size: clamp(0.9rem, 0.9rem + 3vw, 1rem);
}
.shrine__info {
padding: 1rem;
}
.shrine__info h2 {
font-size: clamp(1.5rem, 1rem + 3vw, 1.7rem);
margin-bottom: 0.2em;
}
.shrine__info h3 {
font-size: clamp(1.3rem, 1rem + 3vw, 1.5rem);
margin-top: 1em;
}
.shrine__info ul {
margin-top: 0.5em;
}
< / style >
< / div >
< style >
.breadcrumbs {
list-style: none;
padding: 0;
margin: 0 0 0.7em 0;
display: flex;
gap: 0.5em;
flex-wrap: wrap;
justify-content: center;
}
2024-04-24 17:31:54 +00:00
.breadcrumbs li::after {
content: '➔';
padding-left: 0.3em;
}
2024-04-20 10:10:34 +00:00
< / style >
< / main >
< footer class = "footer" >
< p > Made with ♥ and the Force by Leilukin | Shrine Launched: 17 February 2023< / p >
2024-04-26 09:31:18 +00:00
< p > Back to: < a href = "/shrines/" > Shrine Index< / a > | < a href = "/" > Leilukin' s Hub< / a > < / p >
2024-04-20 10:10:34 +00:00
< / footer >
< style >
.footer {
margin-top: auto;
background: var(--clr-main-footer-bg);
padding: 0.8rem;
text-align: center;
display: grid;
}
.footer p {
padding: 0;
}
.footer__links {
justify-self: center;
list-style: none;
margin: 0;
padding: 0;
display: flex;
gap: 0.7em;
}
2024-04-20 10:59:51 +00:00
.footer__links li:not(:last-child)::after {
content: '|';
padding-left: 0.6em;
}
2024-04-20 10:10:34 +00:00
@media only screen and (min-width: 600px) {
.footer {
width: 100%;
}
}
< / style >
2024-04-21 19:05:20 +00:00
< button class = "top-btn hidden" aria-label = "Scroll to top" >
< i class = "fa-solid fa-chevron-up" > < / i >
2024-04-20 10:10:34 +00:00
< / button >
< style >
.top-btn {
position: fixed;
2024-04-21 19:05:20 +00:00
margin: 0;
padding: 0;
2024-04-21 19:08:40 +00:00
bottom: 0.5rem;
right: 0.5rem;
2024-04-20 10:10:34 +00:00
z-index: 999;
border: none;
2024-04-21 19:05:20 +00:00
background-color: var(--clr-top-btn-bg);
color: var(--clr-top-btn-txt);
2024-04-20 10:10:34 +00:00
border-radius: 50em;
2024-04-21 19:08:40 +00:00
width: 2rem;
2024-04-21 19:05:20 +00:00
aspect-ratio: 1 / 1;
2024-04-20 10:10:34 +00:00
}
.top-btn:focus {
2024-04-21 19:05:20 +00:00
outline: 0.25em solid var(--clr-top-btn-bg);
2024-04-20 10:10:34 +00:00
outline-offset: 0.15em;
}
< / style >
< script defer >
const topButton = document.querySelector(".top-btn");
window.onscroll = () => {
if (document.body.scrollTop > 20 || document.documentElement.scrollTop > 20) {
topButton.classList.remove("hidden");
} else {
topButton.classList.add("hidden");
}
}
topButton.addEventListener('click', () => {
window.scrollTo({
top: 0,
left: 0,
behavior: "smooth",
});
});
< / script >
< / body >
< / html >