diff --git a/src/components/header/popovers/links.tsx b/src/components/header/popovers/links.tsx
index 483224b5..0f73fd30 100644
--- a/src/components/header/popovers/links.tsx
+++ b/src/components/header/popovers/links.tsx
@@ -4,7 +4,6 @@ import {
CalendarHeart,
Codesandbox,
FileStack,
- GraduationCap,
HeartHandshake,
} from "lucide-react";
@@ -286,12 +285,6 @@ export const networkItems = [
];
export const ecosystemNavItems = [
- {
- icon: GraduationCap,
- title: "Showcase",
-
- link: "/ecosystem/showcase/latest/",
- },
{
customIcon: (
),
- title: "Tools",
+ title: "Deployed on Akash",
- link: "/ecosystem/akash-tools/latest/",
+ link: "/ecosystem/deployed-on-akash/showcase/",
},
-
{
customIcon: (
),
- title: "Deployed on Akash",
+ title: "Tools",
- link: "/ecosystem/deployed-on-akash/latest/",
+ link: "/ecosystem/akash-tools",
},
+
{
icon: FileStack,
title: "Case Studies",
diff --git a/src/content/Ecosystem_Page/morpheus/index.md b/src/content/Ecosystem_Page/morpheus/index.md
index e01f7ecb..170d33ce 100644
--- a/src/content/Ecosystem_Page/morpheus/index.md
+++ b/src/content/Ecosystem_Page/morpheus/index.md
@@ -2,7 +2,7 @@
projectTitle: Morpheus
projectImage: "./project-banner.png"
pubDate: "2024-05-08"
-showcase: false
+showcase: true
tags:
- AI & ML
diff --git a/src/pages/ecosystem/akash-tools/[tag]/index.astro b/src/pages/ecosystem/akash-tools/[tag]/index.astro
new file mode 100644
index 00000000..5c069918
--- /dev/null
+++ b/src/pages/ecosystem/akash-tools/[tag]/index.astro
@@ -0,0 +1,47 @@
+---
+import { getCollection } from "astro:content";
+
+import EcosystemPage from "@/components/ecosystem-pages/ecosystem-page.astro";
+
+export async function getStaticPaths() {
+ const projects = (await getCollection("Ecosystem_Page"))
+ .filter((project) => project.data.category === "tool")
+ .sort((a, b) => {
+ const dateA = new Date(a.data.pubDate);
+ const dateB = new Date(b.data.pubDate);
+
+ return dateB.getTime() - dateA.getTime();
+ });
+
+ const tags: string[] = [];
+
+ projects.forEach((project) => {
+ project.data.tags.forEach((tag: string) => {
+ const lowerCasedTag = tag.toLowerCase();
+ if (!tags.includes(lowerCasedTag)) {
+ tags.push(lowerCasedTag);
+ }
+ });
+ });
+
+ return tags.flatMap((tag) => {
+ const lowercasedTag = tag.toLowerCase();
+
+ const filteredPosts = projects.filter((post) =>
+ post.data.tags.some((tag: string) => tag.toLowerCase() === lowercasedTag),
+ );
+
+ return {
+ params: { tag },
+
+ props: { currentTag: tag, tags: tags, page: filteredPosts },
+ };
+ });
+}
+
+const { page, currentTag, tags } = Astro.props;
+
+const formattedTag = currentTag.charAt(0).toUpperCase() + currentTag.slice(1);
+---
+
+
diff --git a/src/pages/ecosystem/akash-tools/[tag]/latest/[page].astro b/src/pages/ecosystem/akash-tools/[tag]/latest/[page].astro
deleted file mode 100644
index fa82a0d0..00000000
--- a/src/pages/ecosystem/akash-tools/[tag]/latest/[page].astro
+++ /dev/null
@@ -1,137 +0,0 @@
----
-import Layout from "@/layouts/layout.astro";
-import type { PaginateFunction } from "astro";
-import { getCollection, type CollectionEntry } from "astro:content";
-
-import ProjectCard from "@/components/ecosystem-pages/project-card.astro";
-import Pagination from "@/components/pagination.astro";
-
-import SortDropDown from "@/components/ecosystem-pages/sort-dropdown";
-import TagsSortDropDown from "@/components/ecosystem-pages/tags-sort-dropdown";
-
-import Categories from "@/components/ecosystem-pages/categories.astro";
-import TopHeader from "@/components/ecosystem-pages/top-header.astro";
-import TopMargin from "@/components/ui/top-margin.astro";
-// Define the data structure for a project
-type Project = CollectionEntry<"Ecosystem_Page">;
-
-// Define a function to generate static paths
-export async function getStaticPaths({
- paginate,
-}: {
- paginate: PaginateFunction;
-}) {
- // Retrieve the collection of "AkashTools_Page" and sort it by publication date
- const projects = (await getCollection("Ecosystem_Page"))
- .filter((project) => project.data.category === "tool")
- .sort((a, b) => {
- const dateA = new Date(a.data.pubDate);
- const dateB = new Date(b.data.pubDate);
-
- // Sort in descending order (latest date first)
- return dateB.getTime() - dateA.getTime();
- });
-
- // Initialize an array to store unique tags
- const tags: string[] = [];
-
- // Loop through each project
- projects.forEach((project) => {
- // Loop through the tags in each blog post
- project.data.tags.forEach((tag: string) => {
- // Capitalize the first letter of the tag
- const lowerCasedTag = tag.toLowerCase();
- // Check if the tag is not already in the allTags array
- if (!tags.includes(lowerCasedTag)) {
- // Add the tag to the allTags array
- tags.push(lowerCasedTag);
- }
- });
- });
-
- // Generate paths for each tag
- return tags.flatMap((tag) => {
- const lowercasedTag = tag.toLowerCase();
-
- // filter posts related to specified tag
- const filteredPosts = projects.filter((post) =>
- post.data.tags.some((tag: string) => tag.toLowerCase() === lowercasedTag),
- );
-
- return paginate(filteredPosts, {
- params: { tag },
- pageSize: 12,
- props: { currentTag: tag, tags: tags },
- });
- });
-}
-
-// Destructure data from Astro.props
-const { page, currentTag, tags } = Astro.props;
-
-// Access the current URL from Astro.url
-const astroUrl = Astro.url;
-const pathName = astroUrl.pathname.split("/");
-
-// Convert the first letter to uppercase
-const formattedTag = currentTag.charAt(0).toUpperCase() + currentTag.slice(1);
----
-
-
-
-
-
-
-
-
-
-
-
-
- {currentTag}
-
-
-
- {
- astroUrl.pathname.split("/")[3] === "latest" ||
- astroUrl.pathname.split("/")[3] === "oldest" ? (
-
- ) : (
-
- )
- }
-
-
-
-
- {
- page.data.map((project: Project, i: number) => {
- return (
-
- );
- })
- }
-
-
-
-
-
-
diff --git a/src/pages/ecosystem/akash-tools/[tag]/oldest/[page].astro b/src/pages/ecosystem/akash-tools/[tag]/oldest/[page].astro
deleted file mode 100644
index 78f2a740..00000000
--- a/src/pages/ecosystem/akash-tools/[tag]/oldest/[page].astro
+++ /dev/null
@@ -1,163 +0,0 @@
----
-import { getCollection, type CollectionEntry } from "astro:content";
-import type { PaginateFunction } from "astro";
-import Layout from "@/layouts/layout.astro";
-import Tag from "@/components/ui/tag.astro";
-import Pagination from "@/components/pagination.astro";
-import ProjectCard from "@/components/ecosystem-pages/project-card.astro";
-import EcosystemNavbar from "@/components/ecosystem-pages/ecosystem-navbar.astro";
-import { SortActions } from "@/components/ecosystem-pages/sort-actions";
-import SortDropDown from "@/components/ecosystem-pages/sort-dropdown";
-import TagsSortDropDown from "@/components/ecosystem-pages/tags-sort-dropdown";
-import SearchDialog from "@/components/ecosystem-pages/search-dialog";
-
-import TopMargin from "@/components/ui/top-margin.astro";
-import TopHeader from "@/components/ecosystem-pages/top-header.astro";
-import Categories from "@/components/ecosystem-pages/categories.astro";
-type Project = CollectionEntry<"Ecosystem_Page">;
-
-// Define a function to generate static paths
-export async function getStaticPaths({
- paginate,
-}: {
- paginate: PaginateFunction;
-}) {
- // Retrieve the collection of "AkashTools_Page" and sort it by publication date
- const projects = (await getCollection("Ecosystem_Page"))
- .filter((project) => project.data.category === "tool")
- .sort((a, b) => {
- const dateA = new Date(a.data.pubDate);
- const dateB = new Date(b.data.pubDate);
-
- // Sort in descending order (latest date first)
- return dateA.getTime() - dateB.getTime();
- });
-
- // Initialize an array to store unique tags
- const tags: string[] = [];
-
- // Loop through each project
- projects.forEach((project) => {
- // Loop through the tags in each blog post
- project.data.tags.forEach((tag: string) => {
- // Capitalize the first letter of the tag
- const lowerCasedTag = tag.toLowerCase();
- // Check if the tag is not already in the allTags array
- if (!tags.includes(lowerCasedTag)) {
- // Add the tag to the allTags array
- tags.push(lowerCasedTag);
- }
- });
- });
-
- // Generate paths for each tag
- return tags.flatMap((tag) => {
- const lowercasedTag = tag.toLowerCase();
-
- // filter posts related to specified tag
- const filteredPosts = projects.filter((post) =>
- post.data.tags.some((tag: string) => tag.toLowerCase() === lowercasedTag),
- );
-
- return paginate(filteredPosts, {
- params: { tag },
- pageSize: 12,
- props: { currentTag: tag, tags: tags },
- });
- });
-}
-
-// Destructure data from Astro.props
-const { page, currentTag, tags } = Astro.props;
-
-// Access the current URL from Astro.url
-const astroUrl = Astro.url;
-const pathName = astroUrl.pathname.split("/");
-
-const formattedTag = currentTag.charAt(0).toUpperCase() + currentTag.slice(1);
----
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- {currentTag}
-
-
-
- {
- astroUrl.pathname.split("/")[3] === "latest" ||
- astroUrl.pathname.split("/")[3] === "oldest" ? (
-
- ) : (
-
- )
- }
-
-
-
-
- {
- page.data.map((project: Project, i: number) => {
- return (
-
- );
- })
- }
-
-
-
-
-
-
diff --git a/src/pages/ecosystem/akash-tools/index.astro b/src/pages/ecosystem/akash-tools/index.astro
new file mode 100644
index 00000000..bbc7bcb2
--- /dev/null
+++ b/src/pages/ecosystem/akash-tools/index.astro
@@ -0,0 +1,28 @@
+---
+import { getCollection } from "astro:content";
+
+import EcosystemPage from "@/components/ecosystem-pages/ecosystem-page.astro";
+
+const projects = (await getCollection("Ecosystem_Page"))
+ .filter((project) => project.data.category === "tool")
+ .sort((a, b) => {
+ const dateA = new Date(a.data.pubDate);
+ const dateB = new Date(b.data.pubDate);
+
+ return dateB.getTime() - dateA.getTime();
+ });
+
+const tags: string[] = [];
+
+projects.forEach((project) => {
+ project.data.tags.forEach((tag: string) => {
+ const lowerCasedTag = tag.toLowerCase();
+
+ if (!tags.includes(lowerCasedTag)) {
+ tags.push(lowerCasedTag);
+ }
+ });
+});
+---
+
+
diff --git a/src/pages/ecosystem/akash-tools/latest/[...page].astro b/src/pages/ecosystem/akash-tools/latest/[...page].astro
deleted file mode 100644
index 8b9d186c..00000000
--- a/src/pages/ecosystem/akash-tools/latest/[...page].astro
+++ /dev/null
@@ -1,106 +0,0 @@
----
-import ProjectCard from "@/components/ecosystem-pages/project-card.astro";
-import SortDropDown from "@/components/ecosystem-pages/sort-dropdown";
-import TagsSortDropDown from "@/components/ecosystem-pages/tags-sort-dropdown";
-import Pagination from "@/components/pagination.astro";
-import Layout from "@/layouts/layout.astro";
-import type { PaginateFunction } from "astro";
-import { getCollection, type CollectionEntry } from "astro:content";
-
-import Categories from "@/components/ecosystem-pages/categories.astro";
-import TopHeader from "@/components/ecosystem-pages/top-header.astro";
-import TopMargin from "@/components/ui/top-margin.astro";
-type Project = CollectionEntry<"Ecosystem_Page">;
-
-export async function getStaticPaths({
- paginate,
-}: {
- paginate: PaginateFunction;
-}) {
- const projects = (await getCollection("Ecosystem_Page"))
- .filter((project) => project.data.category === "tool")
- .sort((a, b) => {
- const dateA = new Date(a.data.pubDate);
- const dateB = new Date(b.data.pubDate);
-
- return dateB.getTime() - dateA.getTime();
- });
-
- const tags: string[] = [];
-
- projects.forEach((project) => {
- project.data.tags.forEach((tag: string) => {
- const lowerCasedTag = tag.toLowerCase();
-
- if (!tags.includes(lowerCasedTag)) {
- tags.push(lowerCasedTag);
- }
- });
- });
-
- return paginate(projects, {
- props: { tags: tags },
- pageSize: 9,
- });
-}
-
-const { page, tags } = Astro.props;
-
-const astroUrl = Astro.url;
----
-
-
-
-
-
-
-
-
-
-
-
-
- Tools
-
-
-
- {
- astroUrl.pathname.split("/")[3] === "latest" ||
- astroUrl.pathname.split("/")[3] === "oldest" ? (
-
- ) : (
-
- )
- }
-
-
-
-
- {
- page.data.map((project: Project, i: number) => {
- return (
-
- );
- })
- }
-
-
-
-
-
-
diff --git a/src/pages/ecosystem/akash-tools/oldest/[...page].astro b/src/pages/ecosystem/akash-tools/oldest/[...page].astro
deleted file mode 100644
index c1e250f3..00000000
--- a/src/pages/ecosystem/akash-tools/oldest/[...page].astro
+++ /dev/null
@@ -1,152 +0,0 @@
----
-import Layout from "@/layouts/layout.astro";
-import ProjectCard from "@/components/ecosystem-pages/project-card.astro";
-import { SortActions } from "../../../../components/ecosystem-pages/sort-actions";
-import Pagination from "@/components/pagination.astro";
-import Tag from "@/components/ui/tag.astro";
-import { Image } from "astro:assets";
-import ChevronRight from "@/assets/chevron-right.svg";
-import { getCollection, type CollectionEntry } from "astro:content";
-import type { PaginateFunction } from "astro";
-import EcosystemNavbar from "@/components/ecosystem-pages/ecosystem-navbar.astro";
-import SortDropDown from "@/components/ecosystem-pages/sort-dropdown";
-import TagsSortDropDown from "@/components/ecosystem-pages/tags-sort-dropdown";
-import SearchDialog from "@/components/ecosystem-pages/search-dialog";
-
-import TopMargin from "@/components/ui/top-margin.astro";
-import TopHeader from "@/components/ecosystem-pages/top-header.astro";
-import Categories from "@/components/ecosystem-pages/categories.astro";
-type Project = CollectionEntry<"Ecosystem_Page">;
-
-// Define a function to generate static paths
-export async function getStaticPaths({
- paginate,
-}: {
- paginate: PaginateFunction;
-}) {
- // Retrieve the collection of "AkashTools_Page" and sort it by publication date
- const projects = (await getCollection("Ecosystem_Page"))
- .filter((project) => project.data.category === "tool")
- .sort((a, b) => {
- const dateA = new Date(a.data.pubDate);
- const dateB = new Date(b.data.pubDate);
-
- // Sort in ascending order of date
- return dateA.getTime() - dateB.getTime();
- });
-
- // Initialize an array to store unique tags
- const tags: string[] = [];
-
- // Loop through each project
- projects.forEach((project) => {
- // Loop through the tags in each project
- project.data.tags.forEach((tag: string) => {
- // Capitalize the first letter of the tag and convert it to lowercase
- const lowerCasedTag = tag.toLowerCase();
-
- // Check if the tag is not already in the 'tags' array
- if (!tags.includes(lowerCasedTag)) {
- // Add the tag to the 'tags' array
- tags.push(lowerCasedTag);
- }
- });
- });
-
- // Paginate the projects and pass the tags as props
- return paginate(projects, {
- props: { tags: tags },
- pageSize: 9,
- });
-}
-
-// Destructure data from Astro.props
-const { page, tags } = Astro.props;
-
-// Access the current URL from Astro.url
-const astroUrl = Astro.url;
-
-const pathName = astroUrl.pathname.split("/");
----
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- Tools
-
-
-
- {
- astroUrl.pathname.split("/")[3] === "latest" ||
- astroUrl.pathname.split("/")[3] === "oldest" ? (
-
- ) : (
-
- )
- }
-
-
-
-
- {
- page.data.map((project: Project, i: number) => {
- return (
-
- );
- })
- }
-
-
-
-
-
-
diff --git a/src/pages/ecosystem/deployed-on-akash/[tag]/index.astro b/src/pages/ecosystem/deployed-on-akash/[tag]/index.astro
new file mode 100644
index 00000000..2749140f
--- /dev/null
+++ b/src/pages/ecosystem/deployed-on-akash/[tag]/index.astro
@@ -0,0 +1,57 @@
+---
+import EcosystemPage from "@/components/ecosystem-pages/ecosystem-page.astro";
+import { getPriorityIndex } from "@/utils/sequences/deployedOnAkash";
+import { getCollection, type CollectionEntry } from "astro:content";
+type Project = CollectionEntry<"Ecosystem_Page">;
+
+export async function getStaticPaths() {
+ const projects = (await getCollection("Ecosystem_Page"))
+ .filter((project) => project.data.category === "deployed_on_akash")
+ .sort((a, b) => {
+ const dateA = new Date(a.data.pubDate);
+ const dateB = new Date(b.data.pubDate);
+ return (
+ dateB.getTime() - dateA.getTime() &&
+ getPriorityIndex(a.data.projectTitle) -
+ getPriorityIndex(b.data.projectTitle)
+ );
+ });
+
+ const tags: string[] = [];
+
+ projects.forEach((project) => {
+ project.data.tags.forEach((tag: string) => {
+ const lowerCasedTag = tag.toLowerCase();
+ if (!tags.includes(lowerCasedTag)) {
+ tags.push(lowerCasedTag);
+ }
+ });
+ });
+
+ return tags.flatMap((tag) => {
+ const lowercasedTag = tag.toLowerCase();
+ const filteredPosts = projects.filter((post) =>
+ post.data.tags.some((tag: string) => tag.toLowerCase() === lowercasedTag),
+ );
+
+ return {
+ params: { tag },
+
+ props: { currentTag: tag, tags: tags, page: filteredPosts },
+ };
+ });
+}
+
+const { page, currentTag, tags } = Astro.props;
+const astroUrl = Astro.url;
+const pathName = astroUrl.pathname.split("/");
+const formattedTag = currentTag.charAt(0).toUpperCase() + currentTag.slice(1);
+---
+
+
diff --git a/src/pages/ecosystem/deployed-on-akash/[tag]/latest/[page].astro b/src/pages/ecosystem/deployed-on-akash/[tag]/latest/[page].astro
deleted file mode 100644
index 3865aa4e..00000000
--- a/src/pages/ecosystem/deployed-on-akash/[tag]/latest/[page].astro
+++ /dev/null
@@ -1,124 +0,0 @@
----
-import Categories from "@/components/ecosystem-pages/categories.astro";
-import ProjectCard from "@/components/ecosystem-pages/project-card.astro";
-import SortDropDown from "@/components/ecosystem-pages/sort-dropdown";
-import TagsSortDropDown from "@/components/ecosystem-pages/tags-sort-dropdown";
-import TopHeader from "@/components/ecosystem-pages/top-header.astro";
-import Pagination from "@/components/pagination.astro";
-import TopMargin from "@/components/ui/top-margin.astro";
-import Layout from "@/layouts/layout.astro";
-import { getPriorityIndex } from "@/utils/sequences/deployedOnAkash";
-import type { PaginateFunction } from "astro";
-import { getCollection, type CollectionEntry } from "astro:content";
-type Project = CollectionEntry<"Ecosystem_Page">;
-
-export async function getStaticPaths({
- paginate,
-}: {
- paginate: PaginateFunction;
-}) {
- const projects = (await getCollection("Ecosystem_Page"))
- .filter((project) => project.data.category === "deployed_on_akash")
- .sort((a, b) => {
- const dateA = new Date(a.data.pubDate);
- const dateB = new Date(b.data.pubDate);
- return (
- dateB.getTime() - dateA.getTime() &&
- getPriorityIndex(a.data.projectTitle) -
- getPriorityIndex(b.data.projectTitle)
- );
- });
-
- const tags: string[] = [];
-
- projects.forEach((project) => {
- project.data.tags.forEach((tag: string) => {
- const lowerCasedTag = tag.toLowerCase();
- if (!tags.includes(lowerCasedTag)) {
- tags.push(lowerCasedTag);
- }
- });
- });
-
- return tags.flatMap((tag) => {
- const lowercasedTag = tag.toLowerCase();
- const filteredPosts = projects.filter((post) =>
- post.data.tags.some((tag: string) => tag.toLowerCase() === lowercasedTag),
- );
-
- return paginate(filteredPosts, {
- params: { tag },
- pageSize: 12,
- props: { currentTag: tag, tags: tags },
- });
- });
-}
-
-const { page, currentTag, tags } = Astro.props;
-const astroUrl = Astro.url;
-const pathName = astroUrl.pathname.split("/");
-const formattedTag = currentTag.charAt(0).toUpperCase() + currentTag.slice(1);
----
-
-
-
-
-
-
-
-
-
-
-
-
- {
- currentTag === "ai & ml"
- ? "AI & ML"
- : currentTag.charAt(0).toUpperCase() + currentTag.slice(1)
- }
-
-
-
- {
- astroUrl.pathname.split("/")[3] === "latest" ||
- astroUrl.pathname.split("/")[3] === "oldest" ? (
-
- ) : (
-
- )
- }
-
-
-
-
- {
- page.data.map((project: Project, i: number) => {
- return (
-
- );
- })
- }
-
-
-
-
-
-
diff --git a/src/pages/ecosystem/deployed-on-akash/[tag]/oldest/[page].astro b/src/pages/ecosystem/deployed-on-akash/[tag]/oldest/[page].astro
deleted file mode 100644
index abf1c9c1..00000000
--- a/src/pages/ecosystem/deployed-on-akash/[tag]/oldest/[page].astro
+++ /dev/null
@@ -1,124 +0,0 @@
----
-import ProjectCard from "@/components/ecosystem-pages/project-card.astro";
-import SortDropDown from "@/components/ecosystem-pages/sort-dropdown";
-import TagsSortDropDown from "@/components/ecosystem-pages/tags-sort-dropdown";
-import Pagination from "@/components/pagination.astro";
-import Layout from "@/layouts/layout.astro";
-import type { PaginateFunction } from "astro";
-import { getCollection, type CollectionEntry } from "astro:content";
-
-import Categories from "@/components/ecosystem-pages/categories.astro";
-import TopHeader from "@/components/ecosystem-pages/top-header.astro";
-import TopMargin from "@/components/ui/top-margin.astro";
-type Project = CollectionEntry<"Ecosystem_Page">;
-
-export async function getStaticPaths({
- paginate,
-}: {
- paginate: PaginateFunction;
-}) {
- const projects = (await getCollection("Ecosystem_Page"))
- .filter((project) => project.data.category === "deployed_on_akash")
- .sort((a, b) => {
- const dateA = new Date(a.data.pubDate);
- const dateB = new Date(b.data.pubDate);
-
- return dateA.getTime() - dateB.getTime();
- });
-
- const tags: string[] = [];
-
- projects.forEach((project) => {
- project.data.tags.forEach((tag: string) => {
- const lowerCasedTag = tag.toLowerCase();
-
- if (!tags.includes(lowerCasedTag)) {
- tags.push(lowerCasedTag);
- }
- });
- });
-
- return tags.flatMap((tag) => {
- const lowercasedTag = tag.toLowerCase();
-
- const filteredPosts = projects.filter((post) =>
- post.data.tags.some((tag: string) => tag.toLowerCase() === lowercasedTag),
- );
-
- return paginate(filteredPosts, {
- params: { tag },
- pageSize: 12,
- props: { currentTag: tag, tags: tags },
- });
- });
-}
-
-const { page, currentTag, tags } = Astro.props;
-
-const astroUrl = Astro.url;
-
-const formattedTag = currentTag.charAt(0).toUpperCase() + currentTag.slice(1);
----
-
-
-
-
-
-
-
-
-
-
-
-
- {
- currentTag === "ai & ml"
- ? "AI & ML"
- : currentTag.charAt(0).toUpperCase() + currentTag.slice(1)
- }
-
-
-
- {
- astroUrl.pathname.split("/")[3] === "latest" ||
- astroUrl.pathname.split("/")[3] === "oldest" ? (
-
- ) : (
-
- )
- }
-
-
-
-
- {
- page.data.map((project: Project, i: number) => {
- return (
-
- );
- })
- }
-
-
-
-
-
-
diff --git a/src/pages/ecosystem/deployed-on-akash/index.astro b/src/pages/ecosystem/deployed-on-akash/index.astro
new file mode 100644
index 00000000..8afaf38b
--- /dev/null
+++ b/src/pages/ecosystem/deployed-on-akash/index.astro
@@ -0,0 +1,33 @@
+---
+import { getCollection } from "astro:content";
+
+import EcosystemPage from "@/components/ecosystem-pages/ecosystem-page.astro";
+import { getPriorityIndex } from "@/utils/sequences/deployedOnAkash";
+
+const projects = (await getCollection("Ecosystem_Page"))
+ .filter((project) => project.data.category === "deployed_on_akash")
+ .sort((a, b) => {
+ const dateA = new Date(a.data.pubDate);
+ const dateB = new Date(b.data.pubDate);
+
+ return (
+ dateB.getTime() - dateA.getTime() &&
+ getPriorityIndex(a.data.projectTitle) -
+ getPriorityIndex(b.data.projectTitle)
+ );
+ });
+
+const tags: string[] = [];
+
+projects.forEach((project) => {
+ project.data.tags.forEach((tag: any) => {
+ const lowerCasedTag = tag.toLowerCase();
+
+ if (!tags.includes(lowerCasedTag)) {
+ tags.push(lowerCasedTag);
+ }
+ });
+});
+---
+
+
diff --git a/src/pages/ecosystem/deployed-on-akash/latest/[...page].astro b/src/pages/ecosystem/deployed-on-akash/latest/[...page].astro
deleted file mode 100644
index bc7a234a..00000000
--- a/src/pages/ecosystem/deployed-on-akash/latest/[...page].astro
+++ /dev/null
@@ -1,111 +0,0 @@
----
-import ProjectCard from "@/components/ecosystem-pages/project-card.astro";
-import SortDropDown from "@/components/ecosystem-pages/sort-dropdown";
-import TagsSortDropDown from "@/components/ecosystem-pages/tags-sort-dropdown";
-import Pagination from "@/components/pagination.astro";
-import Layout from "@/layouts/layout.astro";
-import type { PaginateFunction } from "astro";
-import { getCollection, type CollectionEntry } from "astro:content";
-
-import Categories from "@/components/ecosystem-pages/categories.astro";
-import TopHeader from "@/components/ecosystem-pages/top-header.astro";
-import TopMargin from "@/components/ui/top-margin.astro";
-import { getPriorityIndex } from "@/utils/sequences/deployedOnAkash";
-
-type Project = CollectionEntry<"Ecosystem_Page">;
-
-export async function getStaticPaths({
- paginate,
-}: {
- paginate: PaginateFunction;
-}) {
- const projects = (await getCollection("Ecosystem_Page"))
- .filter((project) => project.data.category === "deployed_on_akash")
- .sort((a, b) => {
- const dateA = new Date(a.data.pubDate);
- const dateB = new Date(b.data.pubDate);
-
- return (
- dateB.getTime() - dateA.getTime() &&
- getPriorityIndex(a.data.projectTitle) -
- getPriorityIndex(b.data.projectTitle)
- );
- });
-
- const tags: string[] = [];
-
- projects.forEach((project) => {
- project.data.tags.forEach((tag: any) => {
- const lowerCasedTag = tag.toLowerCase();
-
- if (!tags.includes(lowerCasedTag)) {
- tags.push(lowerCasedTag);
- }
- });
- });
-
- return paginate(projects, {
- props: { tags: tags },
- pageSize: 9,
- });
-}
-
-const { page, tags } = Astro.props;
-const astroUrl = Astro.url;
----
-
-
-
-
-
-
-
-
-
-
-
-
- Deployed On Akash
-
-
-
- {
- astroUrl.pathname.split("/")[3] === "latest" ||
- astroUrl.pathname.split("/")[3] === "oldest" ? (
-
- ) : (
-
- )
- }
-
-
-
-
- {
- page.data?.map((project: Project, i: number) => {
- return (
-
- );
- })
- }
-
-
-
-
-
-
diff --git a/src/pages/ecosystem/deployed-on-akash/oldest/[...page].astro b/src/pages/ecosystem/deployed-on-akash/oldest/[...page].astro
deleted file mode 100644
index b998f33d..00000000
--- a/src/pages/ecosystem/deployed-on-akash/oldest/[...page].astro
+++ /dev/null
@@ -1,106 +0,0 @@
----
-import ProjectCard from "@/components/ecosystem-pages/project-card.astro";
-import SortDropDown from "@/components/ecosystem-pages/sort-dropdown";
-import TagsSortDropDown from "@/components/ecosystem-pages/tags-sort-dropdown";
-import Pagination from "@/components/pagination.astro";
-import Layout from "@/layouts/layout.astro";
-import type { PaginateFunction } from "astro";
-import { getCollection, type CollectionEntry } from "astro:content";
-
-import Categories from "@/components/ecosystem-pages/categories.astro";
-import TopHeader from "@/components/ecosystem-pages/top-header.astro";
-import TopMargin from "@/components/ui/top-margin.astro";
-
-type Project = CollectionEntry<"Ecosystem_Page">;
-
-export async function getStaticPaths({
- paginate,
-}: {
- paginate: PaginateFunction;
-}) {
- const projects = (await getCollection("Ecosystem_Page"))
- .filter((project) => project.data.category === "deployed_on_akash")
- .sort((a, b) => {
- const dateA = new Date(a.data.pubDate);
- const dateB = new Date(b.data.pubDate);
-
- return dateA.getTime() - dateB.getTime();
- });
-
- const tags: string[] = [];
-
- projects.forEach((project) => {
- project.data.tags.forEach((tag: string) => {
- const lowerCasedTag = tag.toLowerCase();
-
- if (!tags.includes(lowerCasedTag)) {
- tags.push(lowerCasedTag);
- }
- });
- });
-
- return paginate(projects, {
- props: { tags: tags },
- pageSize: 9,
- });
-}
-
-const { page, tags } = Astro.props;
-const astroUrl = Astro.url;
----
-
-
-
-
-
-
-
-
-
-
-
-
- Deployed
-
-
-
- {
- astroUrl.pathname.split("/")[3] === "latest" ||
- astroUrl.pathname.split("/")[3] === "oldest" ? (
-
- ) : (
-
- )
- }
-
-
-
-
- {
- page.data.map((project: Project, i: number) => {
- return (
-
- );
- })
- }
-
-
-
-
-
-
diff --git a/src/pages/ecosystem/deployed-on-akash/showcase.astro b/src/pages/ecosystem/deployed-on-akash/showcase.astro
new file mode 100644
index 00000000..1b37add6
--- /dev/null
+++ b/src/pages/ecosystem/deployed-on-akash/showcase.astro
@@ -0,0 +1,39 @@
+---
+import { getCollection, type CollectionEntry } from "astro:content";
+
+import EcosystemPage from "@/components/ecosystem-pages/ecosystem-page.astro";
+import { getPriorityIndex } from "@/utils/sequences/deployedOnAkash";
+
+type Project = CollectionEntry<"Ecosystem_Page">;
+
+const data = await getCollection("Ecosystem_Page");
+
+const sortProjects = (projects: Project[]) =>
+ projects.sort((a, b) => {
+ const priorityDiff =
+ getPriorityIndex(a.data.projectTitle) -
+ getPriorityIndex(b.data.projectTitle);
+ if (priorityDiff !== 0) return priorityDiff;
+
+ return (
+ new Date(b.data.pubDate).getTime() - new Date(a.data.pubDate).getTime()
+ );
+ });
+
+const cards = sortProjects(
+ data.filter((project) => project.data.category === "deployed_on_akash"),
+);
+const projects = sortProjects(
+ data.filter((project) => project.data.showcase === true),
+);
+
+const tags: string[] = Array.from(
+ new Set(
+ cards.flatMap((project) =>
+ project.data.tags.map((tag) => tag.toLowerCase()),
+ ),
+ ),
+);
+---
+
+
diff --git a/src/pages/ecosystem/showcase/[tag]/latest/[page].astro b/src/pages/ecosystem/showcase/[tag]/latest/[page].astro
deleted file mode 100644
index 3f46a31d..00000000
--- a/src/pages/ecosystem/showcase/[tag]/latest/[page].astro
+++ /dev/null
@@ -1,124 +0,0 @@
----
-import ProjectCard from "@/components/ecosystem-pages/project-card.astro";
-import SortDropDown from "@/components/ecosystem-pages/sort-dropdown";
-import TagsSortDropDown from "@/components/ecosystem-pages/tags-sort-dropdown";
-import Pagination from "@/components/pagination.astro";
-import Layout from "@/layouts/layout.astro";
-import type { PaginateFunction } from "astro";
-import { getCollection, type CollectionEntry } from "astro:content";
-
-import Categories from "@/components/ecosystem-pages/categories.astro";
-import TopHeader from "@/components/ecosystem-pages/top-header.astro";
-import TopMargin from "@/components/ui/top-margin.astro";
-type Project = CollectionEntry<"Ecosystem_Page">;
-
-export async function getStaticPaths({
- paginate,
-}: {
- paginate: PaginateFunction;
-}) {
- const projects = (await getCollection("Ecosystem_Page"))
- .filter((project) => project.data.showcase === true)
- .sort((a, b) => {
- const dateA = new Date(a.data.pubDate);
- const dateB = new Date(b.data.pubDate);
-
- return dateB.getTime() - dateA.getTime();
- });
-
- const tags: string[] = [];
-
- projects.forEach((project) => {
- project.data.tags.forEach((tag: string) => {
- const lowerCasedTag = tag.toLowerCase();
-
- if (!tags.includes(lowerCasedTag)) {
- tags.push(lowerCasedTag);
- }
- });
- });
-
- return tags.flatMap((tag) => {
- const lowercasedTag = tag.toLowerCase();
-
- const filteredPosts = projects.filter((post) =>
- post.data.tags.some((tag: string) => tag.toLowerCase() === lowercasedTag),
- );
-
- return paginate(filteredPosts, {
- params: { tag },
- pageSize: 12,
- props: { currentTag: tag, tags: tags },
- });
- });
-}
-
-const { page, currentTag, tags } = Astro.props;
-
-const astroUrl = Astro.url;
-
-const formattedTag = currentTag.charAt(0).toUpperCase() + currentTag.slice(1);
----
-
-
-
-
-
-
-
-
-
-
-
-
- {
- currentTag === "ai & ml"
- ? "AI & ML"
- : currentTag.charAt(0).toUpperCase() + currentTag.slice(1)
- }
-
-
-
- {
- astroUrl.pathname.split("/")[3] === "latest" ||
- astroUrl.pathname.split("/")[3] === "oldest" ? (
-
- ) : (
-
- )
- }
-
-
-
-
- {
- page.data.map((project: Project, i: number) => {
- return (
-
- );
- })
- }
-
-
-
-
-
-
diff --git a/src/pages/ecosystem/showcase/[tag]/oldest/[page].astro b/src/pages/ecosystem/showcase/[tag]/oldest/[page].astro
deleted file mode 100644
index 9db75aa9..00000000
--- a/src/pages/ecosystem/showcase/[tag]/oldest/[page].astro
+++ /dev/null
@@ -1,121 +0,0 @@
----
-import ProjectCard from "@/components/ecosystem-pages/project-card.astro";
-import SortDropDown from "@/components/ecosystem-pages/sort-dropdown";
-import TagsSortDropDown from "@/components/ecosystem-pages/tags-sort-dropdown";
-import Pagination from "@/components/pagination.astro";
-import Layout from "@/layouts/layout.astro";
-import type { PaginateFunction } from "astro";
-import { getCollection, type CollectionEntry } from "astro:content";
-
-import Categories from "@/components/ecosystem-pages/categories.astro";
-import TopHeader from "@/components/ecosystem-pages/top-header.astro";
-import TopMargin from "@/components/ui/top-margin.astro";
-type Project = CollectionEntry<"Ecosystem_Page">;
-
-export async function getStaticPaths({
- paginate,
-}: {
- paginate: PaginateFunction;
-}) {
- const projects = (await getCollection("Ecosystem_Page"))
- .filter((project) => project.data.showcase === true)
- .sort((a, b) => {
- const dateA = new Date(a.data.pubDate);
- const dateB = new Date(b.data.pubDate);
-
- return dateA.getTime() - dateB.getTime();
- });
-
- const tags: string[] = [];
-
- projects.forEach((project) => {
- project.data.tags.forEach((tag: string) => {
- const lowerCasedTag = tag.toLowerCase();
-
- if (!tags.includes(lowerCasedTag)) {
- tags.push(lowerCasedTag);
- }
- });
- });
-
- return tags.flatMap((tag) => {
- const lowercasedTag = tag.toLowerCase();
-
- const filteredPosts = projects.filter((post) =>
- post.data.tags.some((tag: string) => tag.toLowerCase() === lowercasedTag),
- );
-
- return paginate(filteredPosts, {
- params: { tag },
- pageSize: 12,
- props: { currentTag: tag, tags: tags },
- });
- });
-}
-
-const { page, currentTag, tags } = Astro.props;
-
-const astroUrl = Astro.url;
-
-const formattedTag = currentTag.charAt(0).toUpperCase() + currentTag.slice(1);
----
-
-
-
-
-
-
-
-
-
-
-
-
- {
- currentTag === "ai & ml"
- ? "AI & ML"
- : currentTag.charAt(0).toUpperCase() + currentTag.slice(1)
- }
-
-
-
- {
- astroUrl.pathname.split("/")[3] === "latest" ||
- astroUrl.pathname.split("/")[3] === "oldest" ? (
-
- ) : (
-
- )
- }
-
-
-
-
- {
- page.data.map((project: Project, i: number) => {
- return (
-
- );
- })
- }
-
-
-
-
-
-
diff --git a/src/pages/ecosystem/showcase/latest/[...page].astro b/src/pages/ecosystem/showcase/latest/[...page].astro
deleted file mode 100644
index 3972c7df..00000000
--- a/src/pages/ecosystem/showcase/latest/[...page].astro
+++ /dev/null
@@ -1,151 +0,0 @@
----
-import ProjectCard from "@/components/ecosystem-pages/project-card.astro";
-import SortDropDown from "@/components/ecosystem-pages/sort-dropdown";
-import TagsSortDropDown from "@/components/ecosystem-pages/tags-sort-dropdown";
-import Pagination from "@/components/pagination.astro";
-import Layout from "@/layouts/layout.astro";
-import type { PaginateFunction } from "astro";
-import { getCollection, type CollectionEntry } from "astro:content";
-
-import Categories from "@/components/ecosystem-pages/categories.astro";
-import TopHeader from "@/components/ecosystem-pages/top-header.astro";
-import TopMargin from "@/components/ui/top-margin.astro";
-import { getPriorityIndex } from "@/utils/sequences/deployedOnAkash";
-type Project = CollectionEntry<"Ecosystem_Page">;
-
-// Define a function to generate static paths
-export async function getStaticPaths({
- paginate,
-}: {
- paginate: PaginateFunction;
-}) {
- // Retrieve the collection of "AkashTools_Page" and sort it by publication date
- const projects = (await getCollection("Ecosystem_Page"))
- .filter((project) => project.data.showcase === true)
- .sort((a, b) => {
- const dateA = new Date(a.data.pubDate);
- const dateB = new Date(b.data.pubDate);
-
- // Sort in decending order of date
- return (
- dateB.getTime() - dateA.getTime() &&
- getPriorityIndex(a?.data?.projectTitle) -
- getPriorityIndex(b?.data?.projectTitle)
- );
- });
-
- // Initialize an array to store unique tags
- const tags: string[] = [];
-
- // Loop through each project
- projects.forEach((project) => {
- // Loop through the tags in each project
- project.data.tags.forEach((tag: string) => {
- // Capitalize the first letter of the tag and convert it to lowercase
- const lowerCasedTag = tag.toLowerCase();
-
- // Check if the tag is not already in the 'tags' array
- if (!tags.includes(lowerCasedTag)) {
- // Add the tag to the 'tags' array
- tags.push(lowerCasedTag);
- }
- });
- });
-
- // Paginate the projects and pass the tags as props
- return paginate(projects, {
- props: { tags: tags },
- pageSize: 9,
- });
-}
-
-// Destructure data from Astro.props
-const { page, tags } = Astro.props;
-
-// Access the current URL from Astro.url
-const astroUrl = Astro.url;
-
-const pathName = astroUrl.pathname.split("/");
----
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- {pathName?.[2]?.charAt(0).toUpperCase() + pathName?.[2]?.slice(1)}
-
-
-
- {
- astroUrl.pathname.split("/")[3] === "latest" ||
- astroUrl.pathname.split("/")[3] === "oldest" ? (
-
- ) : (
-
- )
- }
-
-
-
-
- {
- page?.data?.map((project: Project, i: number) => {
- return (
-
- );
- })
- }
-
-
-
-
-
-
diff --git a/src/pages/ecosystem/showcase/oldest/[...page].astro b/src/pages/ecosystem/showcase/oldest/[...page].astro
deleted file mode 100644
index 2e2cd835..00000000
--- a/src/pages/ecosystem/showcase/oldest/[...page].astro
+++ /dev/null
@@ -1,108 +0,0 @@
----
-import ProjectCard from "@/components/ecosystem-pages/project-card.astro";
-import SortDropDown from "@/components/ecosystem-pages/sort-dropdown";
-import TagsSortDropDown from "@/components/ecosystem-pages/tags-sort-dropdown";
-import Pagination from "@/components/pagination.astro";
-import Layout from "@/layouts/layout.astro";
-import type { PaginateFunction } from "astro";
-import { getCollection, type CollectionEntry } from "astro:content";
-
-import Categories from "@/components/ecosystem-pages/categories.astro";
-import TopHeader from "@/components/ecosystem-pages/top-header.astro";
-import TopMargin from "@/components/ui/top-margin.astro";
-type Project = CollectionEntry<"Ecosystem_Page">;
-
-export async function getStaticPaths({
- paginate,
-}: {
- paginate: PaginateFunction;
-}) {
- const projects = (await getCollection("Ecosystem_Page"))
- .filter((project) => project.data.showcase === true)
- .sort((a, b) => {
- const dateA = new Date(a.data.pubDate);
- const dateB = new Date(b.data.pubDate);
-
- return dateA.getTime() - dateB.getTime();
- });
-
- const tags: string[] = [];
-
- projects.forEach((project) => {
- project.data.tags.forEach((tag: string) => {
- const lowerCasedTag = tag.toLowerCase();
-
- if (!tags.includes(lowerCasedTag)) {
- tags.push(lowerCasedTag);
- }
- });
- });
-
- return paginate(projects, {
- props: { tags: tags },
- pageSize: 9,
- });
-}
-
-const { page, tags } = Astro.props;
-
-const astroUrl = Astro.url;
-
-const pathName = astroUrl.pathname.split("/");
----
-
-
-
-
-
-
-
-
-
-
-
-
- {pathName?.[2]?.charAt(0).toUpperCase() + pathName?.[2]?.slice(1)}
-
-
-
- {
- astroUrl.pathname.split("/")[3] === "latest" ||
- astroUrl.pathname.split("/")[3] === "oldest" ? (
-
- ) : (
-
- )
- }
-
-
-
-
- {
- page.data.map((project: Project, i: number) => {
- return (
-
- );
- })
- }
-
-
-
-
-
-
diff --git a/src/utils/redirects.ts b/src/utils/redirects.ts
index 1a2287a6..0c871132 100644
--- a/src/utils/redirects.ts
+++ b/src/utils/redirects.ts
@@ -19,4 +19,6 @@ export const redirects = {
"/about/pricing/custom": "/pricing/usage-calculator/",
"/community/insiders/": "/community/akash-insiders/",
"/community/core-groups/cg-list/": "/development/current-groups/",
+ "/ecosystem/showcase/latest/": "/ecosystem/deployed-on-akash/showcase/",
+ "/ecosystem/akash-tools/latest/": "/ecosystem/akash-tools/",
};
diff --git a/src/utils/sequences/deployedOnAkash.ts b/src/utils/sequences/deployedOnAkash.ts
index 932c371d..3c1ddf29 100644
--- a/src/utils/sequences/deployedOnAkash.ts
+++ b/src/utils/sequences/deployedOnAkash.ts
@@ -4,6 +4,7 @@ export const deployedOnAkash = [
"Prime Intellect",
"University of Texas at Austin",
"Nous Research",
+ "Morpheus",
"Flock.io",
"Akash Chat API",
"Akash Chat",