This commit is contained in:
Kankys 2024-03-28 18:53:22 +01:00
parent 7746a98bb3
commit 18d6d01dc5
3 changed files with 457 additions and 75 deletions

View File

@ -13,26 +13,26 @@
src="https://kit.fontawesome.com/0a43c6cd1f.js"
crossorigin="anonymous"
></script>
<title>Project 2</title>
<title>ApolloNvim</title>
</head>
<body>
<header>
<!-- Terminal - logo (Terminal) -->
<div class="logo">
<img class="picture" src="img/terminal.png" alt="" />
<h1 class="title">Terminal</h1>
</div>
<!--<div class="logo">-->
<!--<img class="picture" src="#" alt="" />-->
<!--</div>-->
<h1 class="title">🚀ApolloNvim</h1>
<!-- Terminal - navigation -->
<nav class="navigation">
<ul>
<li><a class="link" href="">Domů</a></li>
<li><a class="link1" href="">O nás</a></li>
<li><a class="link2" href="">Kontakt</a></li>
<li><a href="">Úvod</a></li>
<li><a href="">O nás</a></li>
<li><a href="">Kontakt</a></li>
</ul>
</nav>
<!--<button id="toggleButton">Dracula/Light mode</button> -->
<div class="menu-icon">
<!-- Ikona hamburger -->
<i class="fa-solid fa-bars"></i>
@ -40,24 +40,366 @@
<!-- <i class="fa-solid fa-xmark"></i> -->
</div>
</header>
<hr />
<button id="toggleButton">Dark/Light mode</button>
<!--<hr />-->
<button id="toggleButton">Dracula/Light mode</button>
<!-- Sekce 1 -->
<section class="section1">
<section class="content" id="welcome">
<section class="welcome">
<h3>
Vítám tě na Terminalu, webu věnovanému Terminalům a aplikacim v
Terminalu.
</h3>
<h2>Úvod:</h2>
<p>
Tento projekt je věnován Terminálum hlavně na systémech Linux a MacOS.
Najdeš tu všechny možné terminály a multiplexory co si můžeš
naistalovat do svého OS, aplikace pro terminály, rady a tipy pro
terminály.
👉 Neovim setup pro Front-End vývoj postavený na
<a href="https://github.com/neoclide/coc.nvim" target="_blank">Coc</a
>.
</p>
<p>
👉 Výhody Neovim oproti klasickému IDE jsou nesporně v svobodě
konfigurace, je tisíce možností jak Váš Neovim může vypadat a
fungovat. Pro Vaši inspiraci a použití vznikl tento projekt 🚀
ApolloNvim.
</p>
<p>
👉 Tato distribuce nefunguje jen že kliknete na tlačítko a nainstaluje
se. Vede Vás k samostatné instalaci pomocí tohoto webu. Cílem je
pochopit jak Neovim funguje abyjste si mohli samy vše modifikovat, což
i click-on distribucí se nenaučíte.
</p>
<p>
👉 Toto nastavení jsem si udělal pro vývoj webu. Inspiroval jsem se
pluginy které jsem využíval v VSCode a Webstorm.
</p>
<p>👉 Velký důraz je kladen na rychlost a lehkost.</p>
<p>
👉 🚀 ApolloNvim Distro je stále vevývoji a postupně se na něm
pracuje.
</p>
<p>
👉 Pro nejlepší zážitek s 🚀 ApolloNvim Distro doporučuji používat
multiplexor
<a
href="https://git.archoslinux.cz/kankys/zellij-mySetup"
target="_blank"
>Zellij </a
>, ale není to samořejmě podmínkou.
</p>
</section>
<section id="advantages">
<h2>Přednosti:</h2>
<p>
👉 Hlavní přednosti tohoto nastavení jsou podpora: Tabnine, Prettier,
AutoSave, diplňování HTML, CSS, JS a zkratky k zakomentování a odk
omentování kódu. Taky je zde několik pluginu pro příjemnější práci v
Neovim.
</p>
<p>
👉 S
<a href="https://github.com/neovim/nvim-lspconfig" target="_blank"
>LSP</a
>
v této instalaci využívám
<a href="https://github.com/neoclide/coc.nvim" target="_blank">Coc</a>
pro jeho jednoduchost bez potřeby zásahů do konfigurace Coc. LSP se mi
velmi osvědčilo v modálním editoru
<a href="https://helix-editor.com/" target="_blank">Helix-editor</a>
má konfigurace
<a
href="https://git.archoslinux.cz/kankys/Helix-frontend-setup"
target="_blank"
>Helixu</a
>.
</p>
<p>
👉 Ty nejlepší témata pro Neovim ať je nemusíš hledat, defaultně je
nastavéné Dracula.
</p>
<p>
👉 Témá v Neovim si jednoduše změníš v command line příkazem
`colorscheme` a tlačítkem Tab se budeš přepínat mezi jednotlivými
tématy.
</p>
<p>Terminály nejsou jen pro programátory a správce sítí, pracovat nebo objevat kouzlo terminálů může každý a brzy zjistí že to není nic čeho se bát. Díky Terminálům můžeš monitorovat systém, automatizovat opakující se činnosti, editovat textové soubory, nastavovat svůj OS, programovat, hrát hry a sposty dalšího. To vš zvládneš v jednom Terminálu na jednou s nainatalovaným multiplexrem jako je <a href="https://zellij.dev/" target="_blank">Zellij</a> nebo <a href="https://github.com/tmux/tmux/wiki" target="_blank">Tmux</a>.</p>
</section>
<section class="photo">
<!--Jsem přidám galerii-->
</section>
<section id="install">
<h2>Instalace a nastavení:</h2>
<p>
👉 Pokud ještě nemáš nainstaluj si
<a href="https://neovim.io/" target="_blank">Neovim</a>.
</p>
<p>
👉 Bude potřeba nainstalovat plug.vim aby jsi mohl/a instalovat
rozšíření.
</p>
<p>
👉 Běž na tuto
<a href="https://github.com/junegunn/vim-plug" target="_blank"
>stránku</a
>
pod Installation si najdi svůj operační systém a zkopíruj odkaz pod
ním do svého terminálu.
</p>
<p>👉 Nejprve si zálohuj své aktuální nastavení Neovim!!!</p>
<p>👉 Linux & Mac:</p>
<div class="code-box">
<p>/home/kankys/.config/nvim/init.vim</p>
</div>
<p>Windows:</p>
<div class="code-box">
<p>
/home/kankys/.local/share/nvim/ (data) <br />
/home/kankys/.local/state/nvim/ (data)
</p>
</div>
<h2>Node.js:</h2>
<p>
👉 Doporučuji mít nainstalovaný
<a href="https://nodejs.org/en" href="_blank">Node.js</a>.
</p>
<p>
👉 Dále si v Node.js nainstaluj
<a href="https://www.npmjs.com/package/live-server" target="_blank"
>Live-server</a
>
příkazem:
</p>
<div class="code-box">
<p>npm i live-server</p>
</div>
<p>👉 Ve svém projektu budeš moc pouštět svůj index.html příkazem:</p>
<div class="code-box">
<p>npx live-server</p>
</div>
<h2>Neovim:</h2>
<p>
👉 Pro instalaci ApolloNvim Distra ti stačí stáhnout pouze soubor
init.vim s tohoto repositáře.
</p>
<p>
👉 Ulož ho do kořenováho adresáře <strong>~/.. /nvim</strong> dle
tvého OS. <strong>Nezapomeň na zálohu stávajících souborů</strong>
</p>
<p>👉 Neovim pustíš v terminálu příkazem <strong>nvim</strong>.</p>
<p>👉 Odklikej chybová hlášení.</p>
<p>
👉 V Neovimu zadej do command line <strong>PlugIns</strong> , tím
nainstaluješ všechny pluginy. Restartuj Neovim.
</p>
<p>
👉 Pokud ti některý plugin chybí můžeš lehce doinstalovat nebo
odinstalovat pomocí <strong>plug.vim</strong>. Více informací najdeš
na GitHubu
<a href="https://github.com/junegunn/vim-plug" target="_blank"
>plug.vim</a
>
nebo velmi rád poradím viz. o nás.
</p>
<p>
👉 Pokud některý plugin nechcete používat stačí v souboru
<strong>init.vim</strong> ho zakomentovat pomocí dvojitých uvozovek
<strong>"</strong>.
</p>
<p>
👉 Do command line ještě zadej Coc příkaz pro doinstalování zbylých
pluginů:
</p>
<div class="code-box">
<p>
CocInstall coc-todolist coc-tailwindcss coc-prettier coc-json
coc-html-css-support coc-html coc-emmet coc-xml coc-tsserver
coc-lsp-wl coc-lit-html coc-htmldjango coc-css
coc-markdown-preview-enhanced coc-markdownlint
</p>
</div>
<p>👉 A ještě jednou restartuj Neovim a vše máš připravené.</p>
<p>
👉 Také se zde podívej do souboru
<a
href="https://git.archoslinux.cz/kankys/ApolloNvim/src/branch/main/Hint.md"
target="_blank"
>Hint.md</a
>, pomůže ti na začátku.
</p>
<p>
👉 Tuto konfiguraci používám na Linuxu i MacOS. Je ozkoušena i na
Windows 11.
</p>
<h2>Plán 🚀ApolloNvim:</h2>
<p>👉 Do budoucna můžete očekávat tyto nové funkce a další novinky:</p>
<p>
👉 Web na vlastní doméně zatím ApolloNvim najdeš
<a href="https://lukaskanka.cz/apollo-nvim" target="_blank">zde</a>.
-> Vysoká priorita
</p>
<p>👉 Instalátor 🚀 ApolloNvim přes odkaz Git.</p>
<p>👉 Nová vlastní uvítací obrazovka.</p>
<p>👉 Nové pluginy.</p>
<p>👉 Telegram skupina k projektu.</p>
<p>
👉 Návody k pluginům, jak nastavit a jak s nimi pracovat. -> Vysoká
priorita
</p>
<p>👉 Návody k práci s Neovim -> Vysoká priorita</p>
<h2>Výběr pluginu v Lite Web 🚀 ApolloNvim Distro 2024:</h2>
<p>
👉
<a href="https://github.com/m4xshen/autoclose.nvim" target="_blank"
>Autoclosetag</a
>
nástroj pro uzavírání všech typů závorek a tagů.
</p>
<p>
👉
<a
href="https://github.com/valsorym/scrooloose-nerdtree"
target="_blank"
>NERDTree</a
>
vytvoří ti stromový postranní panel.
</p>
<p>
👉
<a href="https://github.com/neoclide/coc.nvim" target="_blank">Coc</a>
manager pro instalování doplňků do Neovim.
</p>
<p>
👉
<a href="https://github.com/codota/tabnine-nvim" target="_blank"
>Tabnine</a
>
alternativa k GitHub Copilot, který si případně lehce také můžeš
doinstalovat.
<a href="https://www.tabnine.com/" target="_blank">Tabnine</a>
narozdíl od Copilota nabízí free program a trial verzi na 90 dní.
</p>
<p>
👉
<a href="https://github.com/mhinz/vim-startify" target="_blank"></a>
alternativní uvítací obrazovka s pokaždé jiným IT mottem. Nemusí
fungovat s některými terminály či NERDTree nastaveným spuštěním po
startu.
</p>
<p>
👉
<a href="https://github.com/preservim/nerdcommenter" target="_blank"
>NERD Commenter</a
>
plugin pro zakomentování a odkomentování kódu. Zde ho máme nastaven na
<strong>Ctrl + k</strong>.
</p>
<p>
👉
<a href="https://wakatime.com/neovim" target="_blank">Wakatime</a>
služba která je schopna kolik času jste trávily při kódování na pc a i
na kterém projektu. Služba se jednoduše propojí přes API. WakaTime
najdeš <a href="https://wakatime.com/" target="_blank">zde</a>.
</p>
<p>
👉
<a href="https://github.com/junegunn/fzf.vim" target="_blank"
>fzf.vim</a
>
asynchronií vyhledávač souboru v projektu. Pro mnohé je toto
vyhledávaní rychlejší než klasické stromové, chce to trochu času. Ale
jak se dostane pod kůži vše ostatní Vám už přijde nedodělané.
</p>
<p>
👉
<a href="https://github.com/itchyny/lightline.vim)" target="_blank"
>Light Line</a
>
informační pruh do spodní lišty.
</p>
<p>
👉
<a href="https://github.com/Pocco81/auto-save.nvim" target="_blank"
>Auto-save</a
>
plugin pro automatické ukládání vašich souboru.
</p>
<h2>Coc extensions pro front-end:</h2>
<p>👉 coc-todolist</p>
<p>👉 coc-tailwindcss</p>
<p>👉 coc-project-manager</p>
<p>👉 coc-prettier</p>
<p>👉 coc-json</p>
<p>👉 coc-html-css-support</p>
<p>👉 coc-html</p>
<p>👉 coc-emmet</p>
<p>👉 coc-xml</p>
<p>👉 coc-tsserver</p>
<p>👉 coc-lsp-wl</p>
<p>👉 coc-lit-html</p>
<p>👉 coc-htmldjango</p>
<p>👉 coc-css</p>
<p>👉 coc-markdown-preview-enhanced</p>
<p>👉 coc-markdownlint</p>
<h2>Otázky a odpovědi:</h2>
<p>👉 Kolik stojí 🚀 ApolloNvim? -> Ne 🚀 ApolloNvim je zdarma.</p>
<h2>Kontakty:</h2>
<p>
<a href="https://t.me/+o6qcLGlFROJhNzhk" target="_blank"
>👉 🚀 ApolloNvim Telegram skupina</a
>
</p>
<p>
<a href="https://lukaskanka.cz/" target="_blank"
>👉 Osobní web autora 🚀 ApolloNvim</a
>
</p>
<p>
<a href="https://git.archoslinux.cz/kankys" target="_blank"
>👉 Gitea profil</a
>
</p>
<p>
<a href="https://github.com/LukasKanka/" target="_blank">GitHub</a>
</p>
<p>
<a
href="https://nostr.band/npub12xzu8ejrl9cwpd034cqj5jtuztn4mxp3em2frckm9tk28kmy48vqr0u0yu"
target="_blank"
>Nostr</a
>
</p>
<p>
<a href="https://mastodon.arch-linux.cz/@Kankys" target="_blank"></a
>Mastodon
</p>
<h2>Podpora:</h2>
<p>
👉 Pokud jakkoliv chceš podpořit nebo se podílet na obsahu a
funkčnosti 🚀 ApolloNvim, prosím budu rád když mi zde napíšeš.
</p>
<p>👉 Taky můžeš tento projekt podpořit pár Satoshi:</p>
<img
class="sat"
src="https://lukaskanka.cz/index/about/img/sat.jpeg"
alt="Satoshi"
/>
<h2>Další projekty a odkazy:</h2>
<p>
👉 <a href="https://arch-linux.cz/" target="_blank">ArchLinux CZ</a>
</p>
<p>
👉
<a href="https://searxng.cz/" target="_blank"
>Vyhledávač SearXNG CZ</a
>
</p>
<p>
👉
<a href="https://endeavouros.com/" target="_blank"
>EndeavourOS Linux</a
>
</p>
<p>
👉 <a href="https://i3wm.org/" target="_blank">i3 window manager</a>
</p>
</section>
<section></section>
<footer>
Copyright &copy;
<a href="https://git.archoslinux.cz/kankys" target="_blank"

View File

@ -18,49 +18,60 @@ menuIcon.addEventListener("click", () => {
// Dark Light Mode
const body = document.querySelector("body");
const logo = document.querySelector(".picture");
const link = document.querySelector(".link");
const link1 = document.querySelector(".link1");
const link2 = document.querySelector(".link2");
const head = document.querySelector("header");
const links = document.querySelectorAll("a");
const nav = document.querySelector(".navigation");
const h1 = document.querySelector("h1");
const h3 = document.querySelector("h3");
const nadpish2 = document.querySelectorAll("h2");
const p = document.querySelector("p");
const solid = document.querySelector(".fa-solid");
const solid1 = document.querySelector(".menu-icon");
const footer = document.querySelector("footer");
let isDraculaMode = false;
// Funkce pro nastavení stylů pro Dracula mód
function setDraculaStyles() {
body.style.backgroundColor = "#2a232b"; // Barva pozadí pro Dracula mód
body.style.color = "#f8f8f2"; // Barva textu pro Dracula mód
head.style.backgroundColor = "#2a232b";
links.forEach((a) => {
a.style.color = "#f76b00";
});
nav.style.backgroundColor = "#2a232b";
h1.style.color = "#e54472";
nadpish2.forEach((h2) => {
h2.style.color = "#18f700";
});
solid.style.backgroundColor = "#2a232b";
solid.style.color = "#f76b00";
solid1.style.backgroundColor = "#2a232b";
footer.style.backgroundColor = "#2a232b";
}
// Funkce pro nastavení stylů pro Light mód
function setLightStyles() {
body.style.backgroundColor = "#f8f8f2"; // Barva pozadí pro Light mód
body.style.color = "#282a36"; // Barva textu pro Light mód
head.style.backgroundColor = "#f8f8f2";
}
// Funkce pro přepnutí módu
function toggleMode() {
if (body.classList.contains("dark-mode")) {
// Pokud je momentálně dark mode, změň na light mode
body.classList.remove("dark-mode")
body.classList.add("light-mode");
body.style.backgroundColor = "white";
//logo.style.backgroundColor = "black";
link.style.color = "black";
link1.style.color = "black";
link2.style.color = "black";
nav.style.backgroundColor = "white";
h1.style.color = "black";
h3.style.color = "black";
p.style.color = "black";
if (isDraculaMode) {
// Pokud je momentálně v Dracula modu, přepnout na Light mód
setLightStyles();
isDraculaMode = false;
} else {
// Pokud je momentálně light mode, změň na dark mode
body.classList.remove("light-mode")
body.classList.add("dark-mode");
body.style.backgroundColor = "black";
logo.style.backgroundColor = "white";
link.style.color = "white";
link1.style.color = "white";
link2.style.color = "white";
nav.style.backgroundColor = "black";
h1.style.color = "white";
h3.style.color = "yellow";
p.style.color = "white";
// Pokud je momentálně v Light modu, přepnout na Dracula mód
setDraculaStyles();
isDraculaMode = true;
}
}
// Tlačítko pro přepnutí módu dark a light mode
// Při kliknutí na tlačítko spusť funkci pro přepnutí módu
document.getElementById("toggleButton").addEventListener("click", toggleMode);
// Nastavit výchozí styl na Dracula mód po načtení stránky
setDraculaStyles();
isDraculaMode = true;

View File

@ -9,37 +9,38 @@
box-sizing: border-box;
}
body {
max-width: 1200px;
max-width: 1000px;
margin: 0 auto;
/*background-color: green;*/
}
/* Terminal ( header) */
h1 {
padding-left: 8px;
}
header {
margin-top: 25px;
display: flex;
align-items: center;
height: 70px;
flex-direction: row;
/*position: fixed;*/
}
.title {
padding-top: 25px;
}
.logo {
.title {
flex-grow: 1;
display: flex;
}
.logo img {
/*width: 100px;*/
display: inline-block; /* zajistí, že rámeček bude mít rozměry odpovídající obsahu */
height: 100px;
margin-left: 20px;
}
/* Terminal - navigation */
/* navigation */
nav {
margin-right: 30px;
}
@ -60,7 +61,7 @@ nav li a {
.menu-icon {
display: none;
margin-right: 30px;
background-color: white;
/*background-color: white;*/
}
/*Dark/Light mode button*/
@ -68,7 +69,12 @@ background-color: white;
float: right;
margin-right: 30px;
margin-top: 10px;
background-color: red;
background-color: #18f700;
color: black;
border-bottom: 60px;
border-radius: 30px;
font-size: 15px;
padding: 5px;
}
@ -79,10 +85,11 @@ padding: 10px;
}
header {
/*width: 375px; */
position: relative;
}
header nav {
background-color: white;
/*background-color: white;*/
position: absolute;
top: 70px;
width: 100%;
@ -103,25 +110,47 @@ padding: 10px;
}
/* Sekce */
hr {
margin-top: 25px;
}
.section1 {
padding-top: 50px;
.content {
padding-top: 150px;
text-align: center;
}
#advantages{
padding-top: 50px;
}
#install {
padding-top: 50px;
}
/*Code box*/
.code-box {
background-color: grey;
padding: 10px;
border: 1px solid #ccc;
border-radius: 5px;
font-family: monospace;
max-width: auto;
}
/*Picture settings*/
.sat {
width: 175px;
height: 175px;}
/*footer pevná pozice*/
footer {
position: fixed;
bottom: 0;
margin-bottom: 10px;
margin-left: 25px;
background-color: white;
margin-top: 20px;
}
footer a {
text-decoration: none;
color: black;
}