feat: Update contact and homelab links in nav/footer
This commit is contained in:
parent
8b66bdaab9
commit
5eb4f4c504
6
SETUP.md
6
SETUP.md
|
@ -3,9 +3,9 @@
|
||||||
## Quick Start
|
## Quick Start
|
||||||
```bash
|
```bash
|
||||||
# Clone and initialize the blog repository
|
# Clone and initialize the blog repository
|
||||||
git clone https://git.argobox.com/KeyArgo/laforceit-blog.git
|
git clone https://gitea.argobox.com/InovinLabs/argobox.git # Updated URL
|
||||||
cd laforceit-blog
|
cd argobox # Updated directory name
|
||||||
./scripts/init-blog-repo.sh
|
# ./scripts/init-blog-repo.sh # This script might need review/removal depending on its purpose
|
||||||
```
|
```
|
||||||
|
|
||||||
## What This Does
|
## What This Does
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
{
|
{
|
||||||
"name": "laforceit-blog",
|
"name": "argobox-astro",
|
||||||
"type": "module",
|
"type": "module",
|
||||||
"version": "0.0.1",
|
"version": "0.0.1",
|
||||||
"scripts": {
|
"scripts": {
|
||||||
|
|
|
@ -29,7 +29,7 @@ const categories = [
|
||||||
{
|
{
|
||||||
title: 'Projects',
|
title: 'Projects',
|
||||||
links: [
|
links: [
|
||||||
{ name: 'HomeLab Setup', url: 'https://argobox.com' },
|
{ name: 'HomeLab Setup', path: '/homelab' },
|
||||||
{ name: 'Tech Stack', url: 'https://argobox.com/#services' },
|
{ name: 'Tech Stack', url: 'https://argobox.com/#services' },
|
||||||
{ name: 'Github Repos', path: '/projects/github' },
|
{ name: 'Github Repos', path: '/projects/github' },
|
||||||
{ name: 'Live Services', path: '/projects/services' },
|
{ name: 'Live Services', path: '/projects/services' },
|
||||||
|
@ -175,6 +175,8 @@ const services = [
|
||||||
<span class="link-divider">|</span>
|
<span class="link-divider">|</span>
|
||||||
<a href="/terms" class="meta-link">Terms of Use</a>
|
<a href="/terms" class="meta-link">Terms of Use</a>
|
||||||
<span class="link-divider">|</span>
|
<span class="link-divider">|</span>
|
||||||
|
<a href="/contact" class="meta-link">Contact</a>
|
||||||
|
<span class="link-divider">|</span>
|
||||||
<a href="/sitemap.xml" class="meta-link">Sitemap</a>
|
<a href="/sitemap.xml" class="meta-link">Sitemap</a>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
|
@ -11,7 +11,7 @@ const navItems = [
|
||||||
{ name: 'Home Lab', url: '/homelab' }, // Updated URL
|
{ name: 'Home Lab', url: '/homelab' }, // Updated URL
|
||||||
{ name: 'Resources', url: '/resources' },
|
{ name: 'Resources', url: '/resources' },
|
||||||
{ name: 'About', url: 'https://ArgoBox.com' },
|
{ name: 'About', url: 'https://ArgoBox.com' },
|
||||||
{ name: 'Contact', url: 'https://ArgoBox.com/index.html#contact' }
|
{ name: 'Contact', url: '/contact' }
|
||||||
];
|
];
|
||||||
|
|
||||||
// Get current URL path for active nav item highlighting
|
// Get current URL path for active nav item highlighting
|
||||||
|
|
|
@ -413,6 +413,49 @@ const nodeTypeCounts = {
|
||||||
setTimeout(() => { loadingEl.classList.add('hidden'); }, 500);
|
setTimeout(() => { loadingEl.classList.add('hidden'); }, 500);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// --- Fullscreen Toggle Functionality ---
|
||||||
|
if (fullscreenToggle) {
|
||||||
|
fullscreenToggle.addEventListener('click', toggleFullscreen);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Toggle fullscreen function
|
||||||
|
function toggleFullscreen() {
|
||||||
|
isFullscreen = !isFullscreen;
|
||||||
|
|
||||||
|
if (isFullscreen) {
|
||||||
|
// Enable fullscreen mode
|
||||||
|
graphWrapper.classList.add('fullscreen');
|
||||||
|
fullscreenEnterIcon.classList.add('hidden');
|
||||||
|
fullscreenExitIcon.classList.remove('hidden');
|
||||||
|
|
||||||
|
// Hide the node details panel if it's visible
|
||||||
|
if (nodeDetailsEl) nodeDetailsEl.classList.remove('active');
|
||||||
|
|
||||||
|
// In fullscreen, we adjust the cytoscape layout to fit
|
||||||
|
setTimeout(() => {
|
||||||
|
cy.resize();
|
||||||
|
cy.fit(null, 30);
|
||||||
|
}, 300); // Wait for transition to complete
|
||||||
|
} else {
|
||||||
|
// Disable fullscreen mode
|
||||||
|
graphWrapper.classList.remove('fullscreen');
|
||||||
|
fullscreenEnterIcon.classList.remove('hidden');
|
||||||
|
fullscreenExitIcon.classList.add('hidden');
|
||||||
|
|
||||||
|
// Hide the full post content panel
|
||||||
|
if (fullPostContent) {
|
||||||
|
fullPostContent.classList.remove('active');
|
||||||
|
// Ensure display is set back to none if needed, though CSS handles visibility
|
||||||
|
// fullPostContent.style.display = 'none';
|
||||||
|
}
|
||||||
|
|
||||||
|
// Reset the cytoscape layout
|
||||||
|
setTimeout(() => {
|
||||||
|
cy.resize();
|
||||||
|
cy.fit(null, 30);
|
||||||
|
}, 300); // Wait for transition to complete
|
||||||
|
}
|
||||||
|
}
|
||||||
// --- Fullscreen Toggle Functionality ---
|
// --- Fullscreen Toggle Functionality ---
|
||||||
if (fullscreenToggle) {
|
if (fullscreenToggle) {
|
||||||
fullscreenToggle.addEventListener('click', toggleFullscreen);
|
fullscreenToggle.addEventListener('click', toggleFullscreen);
|
||||||
|
@ -764,6 +807,7 @@ const nodeTypeCounts = {
|
||||||
if (nodeDetailsEl) nodeDetailsEl.classList.remove('active');
|
if (nodeDetailsEl) nodeDetailsEl.classList.remove('active');
|
||||||
if (isFullscreen && fullPostContent) {
|
if (isFullscreen && fullPostContent) {
|
||||||
fullPostContent.classList.remove('active');
|
fullPostContent.classList.remove('active');
|
||||||
|
fullPostContent.style.display = 'none'; // Ensure display is none
|
||||||
}
|
}
|
||||||
cy.elements().removeClass('selected highlighted faded');
|
cy.elements().removeClass('selected highlighted faded');
|
||||||
}
|
}
|
||||||
|
@ -776,6 +820,17 @@ const nodeTypeCounts = {
|
||||||
cy.elements().removeClass('highlighted faded');
|
cy.elements().removeClass('highlighted faded');
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
// Close full post panel button
|
||||||
|
if (closeFullPostBtn) {
|
||||||
|
closeFullPostBtn.addEventListener('click', () => {
|
||||||
|
if (fullPostContent) {
|
||||||
|
fullPostContent.classList.remove('active');
|
||||||
|
fullPostContent.style.display = 'none'; // Ensure display is none
|
||||||
|
}
|
||||||
|
cy.$(':selected').unselect();
|
||||||
|
cy.elements().removeClass('highlighted faded');
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
// Close full post panel button
|
// Close full post panel button
|
||||||
if (closeFullPostBtn) {
|
if (closeFullPostBtn) {
|
||||||
|
@ -1979,4 +2034,350 @@ const nodeTypeCounts = {
|
||||||
@keyframes spin {
|
@keyframes spin {
|
||||||
to { transform: rotate(360deg); }
|
to { transform: rotate(360deg); }
|
||||||
}
|
}
|
||||||
|
/* Fullscreen mode styles */
|
||||||
|
.graph-container-wrapper.fullscreen {
|
||||||
|
position: fixed;
|
||||||
|
top: 0;
|
||||||
|
left: 0;
|
||||||
|
width: 100vw;
|
||||||
|
height: 100vh;
|
||||||
|
max-height: 100vh;
|
||||||
|
z-index: 9999;
|
||||||
|
margin: 0;
|
||||||
|
padding: 20px;
|
||||||
|
background: var(--bg-primary);
|
||||||
|
backdrop-filter: blur(10px);
|
||||||
|
display: flex;
|
||||||
|
border-radius: 0;
|
||||||
|
transition: all 0.5s cubic-bezier(0.19, 1, 0.22, 1);
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Adjust graph container in fullscreen mode */
|
||||||
|
.graph-container-wrapper.fullscreen .graph-container {
|
||||||
|
position: relative;
|
||||||
|
width: 60%;
|
||||||
|
height: 100%;
|
||||||
|
border-radius: 12px;
|
||||||
|
margin-right: 20px;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Fullscreen Toggle Button */
|
||||||
|
.fullscreen-toggle {
|
||||||
|
position: absolute;
|
||||||
|
top: 20px;
|
||||||
|
right: 20px;
|
||||||
|
width: 40px;
|
||||||
|
height: 40px;
|
||||||
|
border-radius: 8px;
|
||||||
|
background: rgba(30, 41, 59, 0.7);
|
||||||
|
border: 1px solid var(--border-primary);
|
||||||
|
color: var(--text-primary);
|
||||||
|
display: flex;
|
||||||
|
align-items: center;
|
||||||
|
justify-content: center;
|
||||||
|
cursor: pointer;
|
||||||
|
z-index: 4;
|
||||||
|
transition: all 0.2s ease;
|
||||||
|
box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
|
||||||
|
}
|
||||||
|
|
||||||
|
.fullscreen-toggle:hover {
|
||||||
|
background: rgba(30, 41, 59, 0.9);
|
||||||
|
transform: translateY(-2px);
|
||||||
|
box-shadow: 0 6px 16px rgba(0, 0, 0, 0.2);
|
||||||
|
}
|
||||||
|
|
||||||
|
.graph-container-wrapper.fullscreen .fullscreen-toggle {
|
||||||
|
top: 25px;
|
||||||
|
right: 25px;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Hide one of the fullscreen icons */
|
||||||
|
.hidden {
|
||||||
|
display: none;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Full Post Content Panel */
|
||||||
|
.full-post-content {
|
||||||
|
position: absolute;
|
||||||
|
top: 0;
|
||||||
|
right: 0;
|
||||||
|
width: 0;
|
||||||
|
height: 100%;
|
||||||
|
overflow: hidden;
|
||||||
|
transition: all 0.3s cubic-bezier(0.19, 1, 0.22, 1);
|
||||||
|
background: var(--bg-secondary);
|
||||||
|
border-radius: 12px;
|
||||||
|
opacity: 0;
|
||||||
|
z-index: 4;
|
||||||
|
border: 1px solid var(--card-border);
|
||||||
|
box-shadow: 0 10px 30px rgba(0, 0, 0, 0.2);
|
||||||
|
visibility: hidden;
|
||||||
|
display: none;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Full post panel in fullscreen mode */
|
||||||
|
.graph-container-wrapper.fullscreen .full-post-content {
|
||||||
|
position: relative;
|
||||||
|
width: 40%;
|
||||||
|
height: 100%;
|
||||||
|
background: rgba(30, 41, 59, 0.7);
|
||||||
|
backdrop-filter: blur(10px);
|
||||||
|
display: flex;
|
||||||
|
flex-direction: column;
|
||||||
|
opacity: 1;
|
||||||
|
visibility: visible;
|
||||||
|
}
|
||||||
|
|
||||||
|
.graph-container-wrapper.fullscreen .full-post-content.active {
|
||||||
|
display: flex;
|
||||||
|
}
|
||||||
|
|
||||||
|
.full-post-header {
|
||||||
|
display: flex;
|
||||||
|
justify-content: space-between;
|
||||||
|
align-items: flex-start;
|
||||||
|
padding: 1.5rem;
|
||||||
|
border-bottom: 1px solid var(--border-primary);
|
||||||
|
}
|
||||||
|
|
||||||
|
.full-post-title {
|
||||||
|
font-size: 1.5rem;
|
||||||
|
margin: 0;
|
||||||
|
color: var(--text-primary);
|
||||||
|
font-weight: 600;
|
||||||
|
line-height: 1.3;
|
||||||
|
}
|
||||||
|
|
||||||
|
.full-post-metadata {
|
||||||
|
padding: 1rem 1.5rem;
|
||||||
|
display: flex;
|
||||||
|
flex-wrap: wrap;
|
||||||
|
gap: 1rem;
|
||||||
|
align-items: center;
|
||||||
|
border-bottom: 1px solid rgba(255, 255, 255, 0.05);
|
||||||
|
}
|
||||||
|
|
||||||
|
.full-post-category {
|
||||||
|
display: inline-block;
|
||||||
|
padding: 0.25rem 0.75rem;
|
||||||
|
border-radius: 20px;
|
||||||
|
font-size: 0.85rem;
|
||||||
|
font-weight: 500;
|
||||||
|
font-family: var(--font-mono);
|
||||||
|
}
|
||||||
|
|
||||||
|
.full-post-tags {
|
||||||
|
display: flex;
|
||||||
|
gap: 0.5rem;
|
||||||
|
flex-wrap: wrap;
|
||||||
|
}
|
||||||
|
|
||||||
|
.post-tag {
|
||||||
|
background: rgba(16, 185, 129, 0.1);
|
||||||
|
color: #10B981;
|
||||||
|
padding: 0.25rem 0.5rem;
|
||||||
|
border-radius: 4px;
|
||||||
|
font-size: 0.75rem;
|
||||||
|
font-family: var(--font-mono);
|
||||||
|
}
|
||||||
|
|
||||||
|
.full-post-container {
|
||||||
|
flex: 1;
|
||||||
|
padding: 1.5rem;
|
||||||
|
overflow-y: auto;
|
||||||
|
color: var(--text-primary);
|
||||||
|
}
|
||||||
|
|
||||||
|
.full-post-container::-webkit-scrollbar {
|
||||||
|
width: 8px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.full-post-container::-webkit-scrollbar-track {
|
||||||
|
background: rgba(30, 41, 59, 0.5);
|
||||||
|
border-radius: 4px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.full-post-container::-webkit-scrollbar-thumb {
|
||||||
|
background: rgba(226, 232, 240, 0.1);
|
||||||
|
border-radius: 4px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.full-post-container::-webkit-scrollbar-thumb:hover {
|
||||||
|
background: rgba(226, 232, 240, 0.2);
|
||||||
|
}
|
||||||
|
|
||||||
|
.full-post-placeholder {
|
||||||
|
height: 100%;
|
||||||
|
display: flex;
|
||||||
|
flex-direction: column;
|
||||||
|
align-items: center;
|
||||||
|
justify-content: center;
|
||||||
|
color: var(--text-secondary);
|
||||||
|
text-align: center;
|
||||||
|
padding: 2rem;
|
||||||
|
}
|
||||||
|
|
||||||
|
.full-post-placeholder svg {
|
||||||
|
margin-bottom: 1rem;
|
||||||
|
opacity: 0.5;
|
||||||
|
}
|
||||||
|
|
||||||
|
.post-content {
|
||||||
|
line-height: 1.7;
|
||||||
|
font-size: 1rem;
|
||||||
|
}
|
||||||
|
|
||||||
|
.post-content h1, .post-content h2, .post-content h3,
|
||||||
|
.post-content h4, .post-content h5, .post-content h6 {
|
||||||
|
margin-top: 1.5rem;
|
||||||
|
margin-bottom: 1rem;
|
||||||
|
color: var(--text-primary);
|
||||||
|
font-weight: 600;
|
||||||
|
}
|
||||||
|
|
||||||
|
.post-content p {
|
||||||
|
margin-bottom: 1.25rem;
|
||||||
|
}
|
||||||
|
|
||||||
|
.post-content a {
|
||||||
|
color: var(--accent-primary);
|
||||||
|
text-decoration: none;
|
||||||
|
border-bottom: 1px dotted var(--accent-primary);
|
||||||
|
transition: all 0.2s ease;
|
||||||
|
}
|
||||||
|
|
||||||
|
.post-content a:hover {
|
||||||
|
color: var(--accent-secondary);
|
||||||
|
border-bottom-style: solid;
|
||||||
|
}
|
||||||
|
|
||||||
|
.post-content pre {
|
||||||
|
background: rgba(15, 23, 42, 0.6);
|
||||||
|
padding: 1rem;
|
||||||
|
border-radius: 6px;
|
||||||
|
overflow-x: auto;
|
||||||
|
margin: 1.5rem 0;
|
||||||
|
border: 1px solid var(--border-primary);
|
||||||
|
}
|
||||||
|
|
||||||
|
.post-content code {
|
||||||
|
font-family: var(--font-mono);
|
||||||
|
font-size: 0.9rem;
|
||||||
|
}
|
||||||
|
|
||||||
|
.post-content img {
|
||||||
|
max-width: 100%;
|
||||||
|
height: auto;
|
||||||
|
margin: 1.5rem 0;
|
||||||
|
border-radius: 6px;
|
||||||
|
box-shadow: 0 4px 20px rgba(0, 0, 0, 0.2);
|
||||||
|
}
|
||||||
|
|
||||||
|
.post-content blockquote {
|
||||||
|
border-left: 4px solid var(--accent-primary);
|
||||||
|
padding-left: 1rem;
|
||||||
|
margin-left: 0;
|
||||||
|
margin-right: 0;
|
||||||
|
font-style: italic;
|
||||||
|
color: var(--text-secondary);
|
||||||
|
}
|
||||||
|
|
||||||
|
.post-content ul, .post-content ol {
|
||||||
|
padding-left: 1.5rem;
|
||||||
|
margin-bottom: 1.25rem;
|
||||||
|
}
|
||||||
|
|
||||||
|
.post-content li {
|
||||||
|
margin-bottom: 0.5rem;
|
||||||
|
}
|
||||||
|
|
||||||
|
.full-post-link {
|
||||||
|
display: flex;
|
||||||
|
align-items: center;
|
||||||
|
justify-content: center;
|
||||||
|
gap: 0.5rem;
|
||||||
|
padding: 1rem;
|
||||||
|
background: linear-gradient(90deg, var(--accent-primary), var(--accent-secondary));
|
||||||
|
color: var(--bg-primary);
|
||||||
|
text-decoration: none;
|
||||||
|
font-weight: 500;
|
||||||
|
transition: all 0.3s ease;
|
||||||
|
}
|
||||||
|
|
||||||
|
.full-post-link:hover {
|
||||||
|
background: linear-gradient(90deg, var(--accent-secondary), var(--accent-primary));
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Media Queries */
|
||||||
|
@media screen and (max-width: 992px) {
|
||||||
|
/* Adjust fullscreen layout for smaller screens */
|
||||||
|
.graph-container-wrapper.fullscreen {
|
||||||
|
flex-direction: column;
|
||||||
|
padding: 15px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.graph-container-wrapper.fullscreen .graph-container {
|
||||||
|
width: 100%;
|
||||||
|
height: 50%;
|
||||||
|
margin-right: 0;
|
||||||
|
margin-bottom: 15px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.graph-container-wrapper.fullscreen .full-post-content {
|
||||||
|
width: 100%;
|
||||||
|
height: 50%;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@media screen and (max-width: 768px) {
|
||||||
|
.fullscreen-toggle {
|
||||||
|
top: 15px;
|
||||||
|
right: 15px;
|
||||||
|
width: 36px;
|
||||||
|
height: 36px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.graph-container-wrapper.fullscreen .graph-container {
|
||||||
|
height: 40%;
|
||||||
|
}
|
||||||
|
|
||||||
|
.graph-container-wrapper.fullscreen .full-post-content {
|
||||||
|
height: 60%;
|
||||||
|
}
|
||||||
|
|
||||||
|
.full-post-header {
|
||||||
|
padding: 1rem;
|
||||||
|
}
|
||||||
|
|
||||||
|
.full-post-title {
|
||||||
|
font-size: 1.25rem;
|
||||||
|
}
|
||||||
|
|
||||||
|
.full-post-metadata {
|
||||||
|
padding: 0.75rem 1rem;
|
||||||
|
}
|
||||||
|
|
||||||
|
.full-post-container {
|
||||||
|
padding: 1rem;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@media screen and (max-width: 480px) {
|
||||||
|
.graph-container-wrapper.fullscreen {
|
||||||
|
padding: 10px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.graph-container-wrapper.fullscreen .graph-container {
|
||||||
|
height: 35%;
|
||||||
|
}
|
||||||
|
|
||||||
|
.graph-container-wrapper.fullscreen .full-post-content {
|
||||||
|
height: 65%;
|
||||||
|
}
|
||||||
|
|
||||||
|
.full-post-title {
|
||||||
|
font-size: 1.1rem;
|
||||||
|
}
|
||||||
|
}
|
||||||
</style>
|
</style>
|
|
@ -99,17 +99,17 @@ sortedPosts
|
||||||
// Terminal commands for tech effect
|
// Terminal commands for tech effect
|
||||||
const commands = [
|
const commands = [
|
||||||
{
|
{
|
||||||
prompt: "[laforceit@argobox]$ ",
|
prompt: "[user@argobox]$ ",
|
||||||
command: "find ./posts -type f -name \"*.md\" | sort -n | wc -l",
|
command: "find ./posts -type f -name \"*.md\" | sort -n | wc -l",
|
||||||
output: [`${allPosts.length} posts found`]
|
output: [`${allPosts.length} posts found`]
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
prompt: "[laforceit@argobox]$ ",
|
prompt: "[user@argobox]$ ",
|
||||||
command: "ls -la ./tags",
|
command: "ls -la ./tags",
|
||||||
output: allTags.map(tag => `${tag}`)
|
output: allTags.map(tag => `${tag}`)
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
prompt: "[laforceit@argobox]$ ",
|
prompt: "[user@argobox]$ ",
|
||||||
command: "grep -r \"kubernetes\" --include=\"*.md\" ./posts | wc -l",
|
command: "grep -r \"kubernetes\" --include=\"*.md\" ./posts | wc -l",
|
||||||
output: [`${allPosts.filter(post =>
|
output: [`${allPosts.filter(post =>
|
||||||
post.data.tags?.includes('kubernetes') ||
|
post.data.tags?.includes('kubernetes') ||
|
||||||
|
|
Loading…
Reference in New Issue