+
{title}
diff --git a/src/constants/index.ts b/src/constants/index.ts
index 627d9b0b56..d23109a50f 100644
--- a/src/constants/index.ts
+++ b/src/constants/index.ts
@@ -1,4 +1,8 @@
export const githubRepoURL = "https://github.com/tailcallhq/tailcall"
+export const tailCallBenchmarkUrl = "https://github.com/tailcallhq/graphql-benchmarks#benchmark-results"
+export const tailCallBlogUrl = "https://blog.tailcall.run/"
+export const codeSandboxUrl = "https://codesandbox.io/p/github/tailcallhq/tailcall-sandbox/main"
+export const zapierLink = "https://hooks.zapier.com/hooks/catch/2793322/3a1gxp2/"
export const partnerImages: PartnerImage[] = [
{
@@ -212,7 +216,7 @@ export const enterpriseFeatures: EnterpriseFeature[] = [
},
]
-export const additionalEnterpriseFeatures = [
+export const additionalEnterpriseFeatures: AdditionalEnterpriseFeatures[] = [
{
id: 1,
logo: require("@site/static/icons/basic/adaptive.svg").default,
@@ -453,3 +457,29 @@ export const investors: Investor[] = [
title: "SVP - Engineering Dream11",
},
]
+
+export const radioOptions: RadioOptions[] = [
+ {id: "1", name: "Evaluating", value: "evaluating"},
+ {
+ id: "2",
+ name: "Monolith",
+ value: "monolith",
+ },
+ {
+ id: "3",
+ name: "Multiple Graphql with Bff",
+ value: "bff",
+ },
+ {
+ id: "4",
+ name: "Federated",
+ value: "federated",
+ },
+]
+
+// Define an enum for theme options
+export enum Theme {
+ Light = "light",
+ Dark = "dark",
+ Gray = "gray",
+}
diff --git a/src/constants/routes.ts b/src/constants/routes.ts
new file mode 100644
index 0000000000..a7a24785ae
--- /dev/null
+++ b/src/constants/routes.ts
@@ -0,0 +1,8 @@
+export const pageLinks = {
+ home: "/",
+ docs: "/docs/getting_started/",
+ pricing: "/pricing",
+ about: "/about",
+ contact: "/contact",
+ enterprise: "/enterprise",
+}
diff --git a/src/css/custom.css b/src/css/custom.css
index 15ce060c49..159f134766 100644
--- a/src/css/custom.css
+++ b/src/css/custom.css
@@ -5,25 +5,43 @@
@tailwind utilities;
:root {
+ /* Font and Dimension Tokens */
--ifm-font-family-base: "Space Grotesk", sans-serif;
--header-height: 6.5rem;
--ifm-navbar-height: 6.5rem;
- --ifm-color-yellow: #fdea2e;
- --ifm-color-black: #000;
- --ifm-color-dark: #323335;
- --ifm-color-dark-800: #121315;
- --ifm-color-dark-900: #2c2c2c;
- --ifm-color-white: #ffffff;
- --ifm-color-gray-300: #f3f4f7;
- --ifm-color-gray-400: #e4e4e4;
- --ifm-color-gray-500: #e5e5e5;
- --ifm-color-gray-600: #e7e7e7;
- --ifm-color-gray-700: #cececf;
- --ifm-color-gray-800: #b6b6b7;
- --ifm-color-linkedin: #0a66c2;
- --ifm-color-discord: #5865f2;
- --ifm-color-white-opacity-15: rgba(255, 255, 255, 0.15);
- --ifm-color-black-opacity-05: rgba(0, 0, 0, 0.05);
+ --ifm-navbar-height-sm: 4.5rem;
+ --ifm-edit-this-page-height: 3rem;
+ --ifm-navbar-logo-height: 2.5rem;
+ --ifm-navbar-logo-height-sm: 1.75rem;
+ --ifm-search-input-height: 2.75rem;
+ --ifm-search-dropdown-height: 18.5rem;
+ --ifm-grid-bg-size-lg: 3.25rem;
+ --ifm-grid-bg-size-md: 2.5rem;
+ --ifm-grid-bg-size-sm: 1.25rem;
+ --ifm-list-item-link: 1.5rem;
+ --ifm-navbar-font-size: 1.25rem;
+ --ifm-content-link-font-size: 0.875rem;
+ --ifm-search-input-font-size: 0.9rem;
+ --ifm-search-desc-font-size: 14px;
+
+ /* Color Tokens */
+ --ifm-color-brand: #fdea2e;
+ --ifm-color-brand-linkedin: #0a66c2;
+ --ifm-color-brand-discord: #5865f2;
+ --ifm-color-brand-dark: #000;
+ --ifm-color-brand-dark-100: #121315;
+ --ifm-color-brand-dark-200: #323335;
+ --ifm-color-brand-dark-300: #2c2c2c;
+ --ifm-color-brand-dark-400: #545556;
+ --ifm-color-brand-dark-opacity-05: rgba(0, 0, 0, 0.05);
+ --ifm-color-brand-light: #ffffff;
+ --ifm-color-brand-light-100: #f3f4f7;
+ --ifm-color-brand-light-200: #e4e4e4;
+ --ifm-color-brand-light-300: #e5e5e5;
+ --ifm-color-brand-light-400: #e7e7e7;
+ --ifm-color-brand-light-500: #cececf;
+ --ifm-color-brand-light-600: #b6b6b7;
+ --ifm-color-brand-light-opacity-15: rgba(255, 255, 255, 0.15);
}
input[type="radio"] {
@@ -31,7 +49,6 @@ input[type="radio"] {
appearance: none;
background-color: "";
margin: 0;
-
font: inherit;
color: currentColor;
width: 16px;
@@ -40,7 +57,6 @@ input[type="radio"] {
border-radius: 50%;
transform: translateY(-0.075em);
cursor: pointer;
-
display: grid;
place-content: center;
}
@@ -52,7 +68,7 @@ input[type="radio"]::before {
border-radius: 50%;
transform: scale(0);
transition: 120ms transform ease-in-out;
- box-shadow: inset 16px 16px var(--ifm-color-yellow);
+ box-shadow: inset 16px 16px var(--ifm-color-brand);
}
input[type="radio"]:checked::before {
@@ -85,7 +101,7 @@ input[type="radio"]:checked::before {
}
.menu__list-item-collapsible a {
- font-size: 1.5rem;
+ font-size: var(--ifm-list-item-link);
font-weight: var(--ifm-font-weight-bold);
}
@@ -98,7 +114,7 @@ input[type="radio"]:checked::before {
}
.menu__link.menu__link--active {
- background-color: var(--ifm-color-yellow);
+ background-color: var(--ifm-color-brand);
color: var(--ifm-color-gray-900);
font-weight: var(--ifm-font-weight-bold);
}
@@ -114,8 +130,8 @@ input[type="radio"]:checked::before {
.theme-edit-this-page {
display: flex;
align-items: center;
- height: 3rem;
- color: var(--ifm-color-dark);
+ height: var(--ifm-edit-this-page-height);
+ color: var(--ifm-color-brand-dark-200);
font-weight: var(--ifm-font-weight-bold);
}
@@ -125,7 +141,7 @@ input[type="radio"]:checked::before {
}
.pagination-nav__link {
- background: var(--ifm-color-yellow);
+ background: var(--ifm-color-brand);
border: none;
border-radius: 16px;
}
@@ -136,7 +152,7 @@ input[type="radio"]:checked::before {
.pagination-nav__sublabel {
display: flex;
- color: var(--ifm-color-dark);
+ color: var(--ifm-color-brand-dark-200);
line-height: 1;
align-items: center;
}
@@ -155,7 +171,7 @@ input[type="radio"]:checked::before {
.pagination-nav__link--next .pagination-nav__sublabel:after {
content: "";
- color: var(--ifm-color-dark);
+ color: var(--ifm-color-brand-dark-200);
background: url("../../static/icons/basic/arrow-right.svg") no-repeat;
width: 0.7rem;
height: 0.7rem;
@@ -167,7 +183,7 @@ input[type="radio"]:checked::before {
.pagination-nav__link--prev .pagination-nav__sublabel:before {
content: "";
background: url("../../static/icons/basic/arrow-left.svg") no-repeat;
- color: var(--ifm-color-dark);
+ color: var(--ifm-color-brand-dark-200);
width: 0.7rem;
height: 0.7rem;
margin-right: 0.5rem;
@@ -214,7 +230,7 @@ input[type="radio"]:checked::before {
}
.navbar {
- box-shadow: var(--ifm-color-gray-600) 0 0 0 1px;
+ box-shadow: var(--ifm-color-brand-light-400) 0 0 0 1px;
height: var(--header-height);
}
@@ -224,7 +240,7 @@ input[type="radio"]:checked::before {
}
.navbar__logo {
- height: 2.5rem;
+ height: var(--ifm-navbar-logo-height);
}
.navbar__items--right {
@@ -233,7 +249,7 @@ input[type="radio"]:checked::before {
.navbar__item.navbar__link {
font-weight: var(--ifm-font-weight-bold);
- font-size: 1.25rem;
+ font-size: var(--ifm-navbar-font-size);
}
.navbar__item.navbar__link {
@@ -246,7 +262,7 @@ input[type="radio"]:checked::before {
}
.navbar__item.navbar__link.navbar__link--active {
- background-color: var(--ifm-color-yellow);
+ background-color: var(--ifm-color-brand);
color: var(--ifm-color-gray-900);
border-radius: 6px;
}
@@ -280,7 +296,7 @@ input[type="radio"]:checked::before {
}
.table-of-contents__link {
- font-size: 0.875rem;
+ font-size: var(--ifm-content-link-font-size);
}
.table-of-contents__link--active {
@@ -324,7 +340,7 @@ aside.theme-doc-sidebar-container {
.algolia-docsearch-suggestion--category-header {
background-color: var(--ifm-color-gray-300) !important;
- color: var(--ifm-color-dark-900) !important;
+ color: var(--ifm-color-brand-dark-300) !important;
text-transform: none !important;
}
@@ -343,9 +359,9 @@ aside.theme-doc-sidebar-container {
.navbar__search input {
width: 100%;
border-radius: 0;
- border-bottom: 1px solid var(--ifm-color-dark-800);
+ border-bottom: 1px solid var(--ifm-color-brand-dark-100);
background-color: transparent;
- height: 44px;
+ height: var(--ifm-search-input-height);
outline: 0;
}
@@ -377,48 +393,56 @@ nav.menu {
top: 44px;
border-radius: 0;
box-shadow: none;
- height: 296px;
+ height: var(--ifm-search-dropdown-height);
max-width: none;
- background: white;
+ background: var(--ifm-color-brand-light);
}
-.algolia-autocomplete .ds-dropdown-menu [class^=ds-dataset-] {
+.algolia-autocomplete .ds-dropdown-menu [class^="ds-dataset-"] {
border-radius: 0 !important;
}
.grid-bg-section {
- background-image: linear-gradient(var(--ifm-color-black-opacity-05) 1px, transparent 1px),
- linear-gradient(90deg, var(--ifm-color-black-opacity-05) 1px, transparent 1px);
- background-size: 52px 52px;
+ background-image: linear-gradient(var(--ifm-color-brand-dark-opacity-05) 1px, transparent 1px),
+ linear-gradient(90deg, var(--ifm-color-brand-dark-opacity-05) 1px, transparent 1px);
+ background-size: var(--ifm-grid-bg-size-lg) var(--ifm-grid-bg-size-lg);
clip-path: inset(0.5rem 0 1rem 0);
}
.button-grid-bg-section {
- background-image: linear-gradient(var(--ifm-color-white-opacity-15) 1px, transparent 2px),
- linear-gradient(90deg, var(--ifm-color-white-opacity-15) 1px, transparent 2px);
- background-size: 20px 20px;
+ background-image: linear-gradient(var(--ifm-color-brand-light-opacity-15) 1px, transparent 2px),
+ linear-gradient(90deg, var(--ifm-color-brand-light-opacity-15) 1px, transparent 2px);
+ background-size: var(--ifm-grid-bg-size-sm) var(--ifm-grid-bg-size-sm);
clip-path: inset(0.2rem);
position: absolute;
border-radius: 20px;
}
.button-grid-bg-section-dark {
- background-image: linear-gradient(var(--ifm-color-black-opacity-05) 1px, transparent 2px),
- linear-gradient(90deg, var(--ifm-color-black-opacity-05) 1px, transparent 2px);
- background-size: 20px 20px;
+ background-image: linear-gradient(var(--ifm-color-brand-dark-opacity-05) 1px, transparent 2px),
+ linear-gradient(90deg, var(--ifm-color-brand-dark-opacity-05) 1px, transparent 2px);
+ background-size: var(--ifm-grid-bg-size-sm) var(--ifm-grid-bg-size-sm);
position: absolute;
border-radius: 20px;
}
.button-grid-bg-github {
- background-image: linear-gradient(var(--ifm-color-black-opacity-05) 1px, transparent 2px),
- linear-gradient(90deg, var(--ifm-color-black-opacity-05) 1px, transparent 2px);
- background-size: 20px 20px;
+ background-image: linear-gradient(var(--ifm-color-brand-dark-opacity-05) 1px, transparent 2px),
+ linear-gradient(90deg, var(--ifm-color-brand-dark-opacity-05) 1px, transparent 2px);
+ background-size: var(--ifm-grid-bg-size-sm) var(--ifm-grid-bg-size-sm);
+ scale: 0.9;
+ opacity: 0;
+}
+
+.button-grid-bg-github:hover {
+ scale: 1;
+ opacity: 1;
+ transition: all 250ms ease-out;
}
@media (max-width: 996px) {
.grid-bg-section {
- background-size: 40px 40px;
+ background-size: var(--ifm-grid-bg-size-md) var(--ifm-grid-bg-size-md);
}
.navbar__items {
@@ -471,14 +495,48 @@ nav.menu {
}
.navbar {
- height: 4.5rem;
+ height: var(--ifm-navbar-height-sm);
+ transform: none;
}
.navbar__logo {
- height: 1.75rem;
+ height: var(--ifm-navbar-logo-height-sm);
}
.sidebar-search-container {
display: none;
}
+
+ .sidebar-search-container {
+ position: sticky;
+ top: 100px;
+ max-height: 100vh;
+ transition: all 250ms ease-in-out;
+ z-index: 99;
+ }
+
+ .navbar__search input {
+ border-radius: 8px;
+ border: 1px solid var(--ifm-color-brand-light-600);
+ }
+}
+
+@media (max-width: 600px) {
+ .algolia-autocomplete span[role="listbox"] {
+ display: block;
+ max-height: 90%;
+ max-width: 100%;
+ position: fixed;
+ top: 90px !important;
+ left: 0px !important;
+ width: 600px;
+ height: 100vh;
+ z-index: 100;
+ background: transparent;
+ overflow-y: auto;
+ }
+
+ .algolia-autocomplete .ds-dropdown-menu {
+ box-shadow: none;
+ }
}
diff --git a/src/pages/about.tsx b/src/pages/about.tsx
index d07e4de480..0dbdca5bd9 100644
--- a/src/pages/about.tsx
+++ b/src/pages/about.tsx
@@ -1,12 +1,15 @@
import React, {useEffect} from "react"
import ReactGA from "react-ga4"
import Layout from "@theme/Layout"
+import {useLocation} from "@docusaurus/router"
import AboutPage from "../components/about"
-export default function About(): JSX.Element {
+const About = (): JSX.Element => {
+ const location = useLocation()
+
useEffect(() => {
- ReactGA.send({hitType: "pageview", page: window.location.pathname, title: "About Page"})
+ ReactGA.send({hitType: "pageview", page: location.pathname, title: "About Page"})
}, [])
return (
@@ -15,3 +18,5 @@ export default function About(): JSX.Element {
)
}
+
+export default About
diff --git a/src/pages/contact.tsx b/src/pages/contact.tsx
index 278a97937b..0ca473b4a6 100644
--- a/src/pages/contact.tsx
+++ b/src/pages/contact.tsx
@@ -1,12 +1,15 @@
import React, {useEffect} from "react"
import ReactGA from "react-ga4"
import Layout from "@theme/Layout"
+import {useLocation} from "@docusaurus/router"
import ContactPage from "../components/contact"
-const Contact = () => {
+const Contact = (): JSX.Element => {
+ const location = useLocation()
+
useEffect(() => {
- ReactGA.send({hitType: "pageview", page: window.location.pathname, title: "Contact Page"})
+ ReactGA.send({hitType: "pageview", page: location.pathname, title: "Contact Page"})
}, [])
return (
diff --git a/src/pages/enterprise.tsx b/src/pages/enterprise.tsx
index 9c6ce7d0cc..032dca8012 100644
--- a/src/pages/enterprise.tsx
+++ b/src/pages/enterprise.tsx
@@ -1,12 +1,15 @@
import React, {useEffect} from "react"
import ReactGA from "react-ga4"
import Layout from "@theme/Layout"
+import {useLocation} from "@docusaurus/router"
import EnterprisePage from "../components/enterprise"
-const Enterprise = () => {
+const Enterprise = (): JSX.Element => {
+ const location = useLocation()
+
useEffect(() => {
- ReactGA.send({hitType: "pageview", page: window.location.pathname, title: "Enterprise Page"})
+ ReactGA.send({hitType: "pageview", page: location.pathname, title: "Enterprise Page"})
}, [])
return (
diff --git a/src/pages/index.tsx b/src/pages/index.tsx
index c9c35cc861..b9552cc079 100644
--- a/src/pages/index.tsx
+++ b/src/pages/index.tsx
@@ -1,16 +1,16 @@
import React, {useEffect} from "react"
import Layout from "@theme/Layout"
import ReactGA from "react-ga4"
+import {useLocation} from "@docusaurus/router"
import HomePage from "../components/home"
-ReactGA.initialize("G-JEP3QDWT0G")
-
-export default function Home(): JSX.Element {
+const Home = (): JSX.Element => {
const isDevelopment = process.env.NODE_ENV === "development"
+ const location = useLocation()
useEffect(() => {
- ReactGA.send({hitType: "pageview", page: window.location.pathname, title: "Home Page"})
+ ReactGA.send({hitType: "pageview", page: location.pathname, title: "Home Page"})
}, [])
return (
@@ -27,3 +27,5 @@ export default function Home(): JSX.Element {
)
}
+
+export default Home
diff --git a/src/theme/DocRoot/Layout/Sidebar/index.tsx b/src/theme/DocRoot/Layout/Sidebar/index.tsx
index 62e563b798..fcbb30794e 100644
--- a/src/theme/DocRoot/Layout/Sidebar/index.tsx
+++ b/src/theme/DocRoot/Layout/Sidebar/index.tsx
@@ -1,96 +1,98 @@
import React, {useEffect, useState} from "react"
+import {useHistory} from "react-router-dom"
import Sidebar from "@theme-original/DocRoot/Layout/Sidebar"
import Search from "docusaurus-lunr-search/src/theme/SearchBar"
-import {useHistory} from "react-router-dom"
import useIsBrowser from "@docusaurus/useIsBrowser"
+import Platform from "react-platform-js"
+
import PageSearchIcon from "@site/static/icons/basic/page-search.svg"
import EnterKeyIcon from "@site/static/icons/basic/enter-key.svg"
import UpDownKeyIcon from "@site/static/icons/basic/up-down-key.svg"
import EscapeKeyIcon from "@site/static/icons/basic/escape-key.svg"
-import styles from "./Sidebar.module.css"
+import styles from "./styles.module.css"
+import {getSearchInputRef, setBodyOverflow} from "@site/src/utils"
-export default function SidebarWrapper(props) {
- const [isSearchModalVisible, setIsSearchModalVisible] = useState(false)
+const CustomSearch = () => {
+ const [isSearchModalVisible, setIsSearchModalVisible] = useState
(false)
const history = useHistory()
const isBrowser = useIsBrowser()
- const placeholder = isBrowser && window.navigator.platform.startsWith("Mac") ? "Search ⌘+K" : "Search Ctrl+K"
+ const placeholder = isBrowser ? (Platform.OS.startsWith("Mac") ? "Search ⌘+K" : "Search Ctrl+K") : "Search"
- function handleSearchClick() {
+ // Function to handle opening the search modal
+ const handleSearchClick = () => {
setIsSearchModalVisible(true)
}
- function handleSearchModalClose() {
+ // Function to handle closing the search modal
+ const handleSearchModalClose = () => {
setIsSearchModalVisible(false)
}
- function setBodyScroll() {
- document.body.style.overflow = isSearchModalVisible ? "hidden" : "auto"
- }
-
- useEffect(() => {
- setBodyScroll()
- return () => {
- document.body.style.overflow = "initial"
+ // Function to control body scroll based on modal visibility
+ const setBodyScroll = () => {
+ if (isSearchModalVisible) {
+ setBodyOverflow("hidden")
+ } else {
+ setBodyOverflow("initial")
}
- }, [isSearchModalVisible])
+ }
- function handleKeyPress(event) {
+ // Function to handle key press events
+ const handleKeyPress = (event: KeyboardEvent) => {
if (event.key === "Escape") {
handleSearchModalClose()
}
if (
- (event.metaKey && event.key === "k" && navigator.platform.includes("Mac")) ||
- (event.ctrlKey && event.key === "k" && navigator.platform.includes("Win"))
+ (event.metaKey && event.key === "k" && Platform.UA.includes("Mac")) ||
+ (event.ctrlKey && event.key === "k" && Platform.UA.includes("Win"))
) {
handleSearchClick()
}
}
useEffect(() => {
- document.addEventListener("keydown", handleKeyPress)
+ let timer: NodeJS.Timeout
- return () => {
- document.removeEventListener("keydown", handleKeyPress)
- }
- }, [])
+ // handle body scroll based on modal visibility changes
+ setBodyScroll()
- useEffect(() => {
+ // handle keydown events for search functionality
+ document.addEventListener("keydown", handleKeyPress)
+
+ // close the search modal when route changes
const unlisten = history.listen((location, action) => {
if (action === "PUSH" || action === "POP") {
setIsSearchModalVisible(false)
}
})
- return () => {
- unlisten()
+ // focus on search input when modal becomes visible
+ if (isSearchModalVisible) {
+ timer = setTimeout(() => {
+ const searchInput = getSearchInputRef()
+ if (searchInput) {
+ searchInput.focus()
+ }
+ }, 50)
}
- }, [history])
-
- useEffect(() => {
- const handleKeyPress = (event) => {
- if (
- (event.metaKey && event.key === "k" && navigator.platform.includes("Mac")) ||
- (event.ctrlKey && event.key === "k" && navigator.platform.includes("Win"))
- ) {
- // Your action when CMD/CTRL + K is pressed
- console.log("CMD/CTRL + K pressed")
- // Perform your desired action here
- }
- }
-
- document.addEventListener("keydown", handleKeyPress)
return () => {
+ clearTimeout(timer)
+ setBodyOverflow("initial")
document.removeEventListener("keydown", handleKeyPress)
+ unlisten()
}
- }, [])
+ }, [isSearchModalVisible, history])
return (
-
+ <>
+ {/* Search input container */}
+
+ {/* Search modal */}
{isSearchModalVisible ? (
<>
@@ -99,8 +101,8 @@ export default function SidebarWrapper(props) {
-
Search Docs
-
Search anything within the docs
+
Search Docs
+
Search anything within the docs
@@ -120,7 +122,18 @@ export default function SidebarWrapper(props) {
>
) : null}
+ >
+ )
+}
+
+// Wrapper component combining Sidebar with CustomSearch
+const SidebarWrapper = (props: SidebarConfig) => {
+ return (
+
+
)
}
+
+export default SidebarWrapper
diff --git a/src/theme/DocRoot/Layout/Sidebar/Sidebar.module.css b/src/theme/DocRoot/Layout/Sidebar/styles.module.css
similarity index 75%
rename from src/theme/DocRoot/Layout/Sidebar/Sidebar.module.css
rename to src/theme/DocRoot/Layout/Sidebar/styles.module.css
index ff100a7716..4b08164d45 100644
--- a/src/theme/DocRoot/Layout/Sidebar/Sidebar.module.css
+++ b/src/theme/DocRoot/Layout/Sidebar/styles.module.css
@@ -9,9 +9,9 @@
color: var(--ifm-navbar-search-input-color);
cursor: text;
display: inline-block;
- font-size: 0.9rem;
+ font-size: var(--ifm-search-input-font-size);
padding: 0 0.5rem 0 2.2rem;
- background: transparent var(--ifm-navbar-search-input-icon) no-repeat .75rem center/1rem 1rem;
+ background: transparent var(--ifm-navbar-search-input-icon) no-repeat 0.75rem center/1rem 1rem;
}
.inputContainer {
@@ -37,10 +37,10 @@
left: 50%;
margin-right: -50%;
z-index: 9;
- background: white;
+ background: var(--ifm-color-brand-light);
width: 640px;
transform: translate(-50%, -50%);
- border: 1px solid var(--ifm-color-dark-800);
+ border: 1px solid var(--ifm-color-brand-dark-100);
border-radius: 8px;
}
@@ -53,7 +53,7 @@
}
.footer {
- padding: .75rem 1rem;
+ padding: 0.75rem 1rem;
border-top: 1px solid var(--ifm-color-gray-600);
}
@@ -62,11 +62,10 @@
align-items: center;
}
-
.navigationInfoItem span {
color: var(--ifm-color-gray-800);
display: block;
- margin-left: .25rem;
+ margin-left: 0.25rem;
font-size: 12px;
}
@@ -80,11 +79,22 @@
height: 340px;
}
+.searchDocsTitle {
+ margin-top: 8px;
+ font-weight: bold;
+}
+.searchDocsDesc {
+ font-size: var(--ifm-search-desc-font-size);
+ line-height: 20.73px;
+ letter-spacing: -4%;
+ font-weight: 400;
+ color: var(--ifm-color-brand-dark-400);
+}
@media (max-height: 600px) {
.modal {
top: calc(var(--header-height) + 1rem);
transform: translate(-50%, 0);
}
-}
\ No newline at end of file
+}
diff --git a/src/theme/Layout/Provider/index.tsx b/src/theme/Layout/Provider/index.tsx
index 82d712e5fa..a4caa8fb2b 100644
--- a/src/theme/Layout/Provider/index.tsx
+++ b/src/theme/Layout/Provider/index.tsx
@@ -1,4 +1,4 @@
-import React from "react"
+import React, {ReactNode} from "react"
import {composeProviders} from "@docusaurus/theme-common"
import {
ColorModeProvider,
@@ -10,6 +10,12 @@ import {
} from "@docusaurus/theme-common/internal"
import GithubStarsProvider from "@site/src/components/shared/GithubStarsProvider"
+// Define the type for LayoutProvider props
+type LayoutProviderProps = {
+ children: ReactNode // ReactNode represents any React child (JSX, strings, etc.)
+}
+
+// Compose the providers to create a single Provider component
const Provider = composeProviders([
ColorModeProvider,
AnnouncementBarProvider,
@@ -19,6 +25,10 @@ const Provider = composeProviders([
NavbarProvider,
GithubStarsProvider,
])
-export default function LayoutProvider({children}) {
+
+// LayoutProvider component wraps the composed providers around its children
+const LayoutProvider = ({children}: LayoutProviderProps) => {
return {children}
}
+
+export default LayoutProvider
diff --git a/src/theme/Navbar/Content/index.tsx b/src/theme/Navbar/Content/index.tsx
index bbf2b38808..6181de6c73 100644
--- a/src/theme/Navbar/Content/index.tsx
+++ b/src/theme/Navbar/Content/index.tsx
@@ -1,20 +1,28 @@
-import React, {useState, useEffect, useContext} from "react"
+import React, {type ReactNode, useEffect, useState} from "react"
import {useThemeConfig, ErrorCauseBoundary} from "@docusaurus/theme-common"
import {splitNavbarItems, useNavbarMobileSidebar} from "@docusaurus/theme-common/internal"
-import NavbarItem from "@theme/NavbarItem"
+import {useHistory} from "react-router-dom"
+import {useLocation} from "@docusaurus/router"
+import NavbarItem, {type Props as NavbarItemConfig} from "@theme/NavbarItem"
+
+import Search from "docusaurus-lunr-search/src/theme/SearchBar" // Assuming Search is a valid component
import NavbarColorModeToggle from "@theme/Navbar/ColorModeToggle"
import SearchBar from "@theme/SearchBar"
import NavbarMobileSidebarToggle from "@theme/Navbar/MobileSidebar/Toggle"
import NavbarLogo from "@theme/Navbar/Logo"
import NavbarSearch from "@theme/Navbar/Search"
-import styles from "./styles.module.css"
import GithubStarsButton from "@site/src/components/shared/GithubStarsButton"
+import SearchIcon from "@site/static/icons/basic/search.svg"
+import PageSearchIcon from "@site/static/icons/basic/page-search.svg"
+import styles from "./styles.module.css"
+import {getSearchInputRef, setBodyOverflow} from "@site/src/utils"
-function useNavbarItems() {
- // TODO temporary casting until ThemeConfig type is improved
- return useThemeConfig().navbar.items
+const useNavbarItems = () => {
+ // TODO temporary casting until ThemeConfig type is improved (added by docusaurus)
+ return useThemeConfig().navbar.items as NavbarItemConfig[]
}
-function NavbarItems({items}) {
+
+const NavbarItems = ({items}: {items: NavbarItemConfig[]}): JSX.Element => {
return (
<>
{items.map((item, i) => (
@@ -34,7 +42,8 @@ ${JSON.stringify(item, null, 2)}`,
>
)
}
-const NavbarContentLayout = ({left, right}) => {
+
+const NavbarContentLayout = ({left, right}: {left: ReactNode; right: ReactNode}) => {
return (
{left}
@@ -43,25 +52,146 @@ const NavbarContentLayout = ({left, right}) => {
)
}
-export default function NavbarContent() {
+// Custom search component
+const CustomSearch = () => {
+ const [showSearchIcon, setShowSearchIcon] = useState
(false)
+ const [isSearchModalVisible, setIsSearchModalVisible] = useState(false)
+ const history = useHistory()
+ const location = useLocation()
+
+ // Handlers to control search visibility
+ const handleSearchClick = () => {
+ setIsSearchModalVisible(true)
+ }
+
+ const handleSearchModalClose = () => {
+ setIsSearchModalVisible(false)
+ }
+
+ // Function to handle zoom behavior based on input focus
+ const handleZoomBehavior = () => {
+ /* TODO: Figure out a better way to do this */
+ const viewportMetaTag = document.querySelector('meta[name="viewport"]') as HTMLMetaElement
+ if (viewportMetaTag) {
+ // Enable user zooming when no input is in focus
+ viewportMetaTag.content = "width=device-width, initial-scale=1, maximum-scale=5, user-scalable=yes"
+ // Add an event listener to detect when an input is in focus
+ document.addEventListener("focusin", handleInputFocus)
+ // Remove the event listener when the component unmounts or the modal closes
+ return () => {
+ document.removeEventListener("focusin", handleInputFocus)
+ }
+ }
+ }
+
+ // Function to handle input focus
+ const handleInputFocus = (event: FocusEvent) => {
+ const isInput = (event.target as HTMLElement).tagName.toLowerCase() === "input"
+
+ // Disable user zooming when an input is in focus
+ const viewportMetaTag = document.querySelector('meta[name="viewport"]') as HTMLMetaElement
+ if (viewportMetaTag && isInput) {
+ viewportMetaTag.content = "width=device-width, initial-scale=1, maximum-scale=1, user-scalable=no"
+ }
+ }
+
+ useEffect(() => {
+ // Variable to store the timer for handling modal animation
+ let timer: NodeJS.Timeout
+
+ // Check if the current page is within the "/docs/" path to show or hide the search icon
+ location.pathname.includes("/docs/") ? setShowSearchIcon(true) : setShowSearchIcon(false)
+
+ // Set up a listener to handle changes in the browser history (navigation)
+ const unlisten = history.listen((location, action) => {
+ if (action === "PUSH" || action === "POP") {
+ // If navigating, hide the search modal and reset the zoom when the modal is closed
+ setIsSearchModalVisible(false)
+ }
+ })
+
+ // Handle modal visibility and behavior
+ if (isSearchModalVisible) {
+ // If the search modal is visible, prevent body scrolling and handle modal animations
+ setBodyOverflow("hidden")
+ timer = setTimeout(() => {
+ // After a delay, focus on the search input and apply zoom behavior
+ const searchInput = getSearchInputRef()
+ handleZoomBehavior()
+ if (searchInput) {
+ searchInput.focus()
+ }
+ }, 200)
+ } else {
+ // If the search modal is not visible, allow body scrolling
+ setBodyOverflow("initial")
+ }
+
+ // Clean up timer and history listener when the component unmounts or when dependencies change
+ return () => {
+ clearTimeout(timer)
+ unlisten()
+ }
+ }, [isSearchModalVisible, history])
+
+ return (
+ <>
+ {showSearchIcon && }
+ {isSearchModalVisible ? (
+ <>
+
+
+ {/* Search modal content */}
+
+
+
+
+
Search Docs
+
+ Search anything within the docs
+
+
+
+
+ >
+ ) : null}
+ >
+ )
+}
+
+const NavbarContent = (): JSX.Element => {
const mobileSidebar = useNavbarMobileSidebar()
+
const items = useNavbarItems()
const [leftItems, rightItems] = splitNavbarItems(items)
+
const searchBarItem = items.find((item) => item.type === "search")
return (
+
{!mobileSidebar.disabled && }
>
}
right={
- // TODO stop hardcoding items?
- // Ask the user to add the respective navbar items => more flexible
+ // TODO stop hardcoding items? (added by docusaurus)
+ // Render right navbar items
<>
@@ -76,3 +206,5 @@ export default function NavbarContent() {
/>
)
}
+
+export default NavbarContent
diff --git a/src/theme/Navbar/Content/styles.module.css b/src/theme/Navbar/Content/styles.module.css
index 4c9471e109..191c6f6110 100644
--- a/src/theme/Navbar/Content/styles.module.css
+++ b/src/theme/Navbar/Content/styles.module.css
@@ -1,8 +1,96 @@
/*
Hide color mode toggle in small viewports
*/
-@media (max-width: 996px) {
+@media (min-width: 996px) {
.colorModeToggle {
display: none;
}
}
+
+@media screen and (min-width: 996px) {
+ .searchInput {
+ width: 600px;
+ }
+
+ .overlay {
+ display: none;
+ }
+
+ .modal {
+ display: none;
+ }
+}
+
+.overlay {
+ background-color: var(--ifm-color-brand-light);
+ position: fixed;
+ top: 0;
+ left: 0;
+ width: 100%;
+ height: 100%;
+ z-index: 1;
+ backdrop-filter: blur(3px);
+ overflow: hidden;
+}
+
+.modal {
+ position: fixed;
+ top: 24px;
+ left: 0;
+ margin-right: -50%;
+ z-index: 9;
+ background: var(--ifm-color-brand-light);
+ width: 100%;
+}
+
+.initialCase {
+ display: flex;
+ flex-direction: column;
+ justify-content: center;
+ align-items: center;
+ padding-top: 100px;
+}
+
+.modalContent {
+ height: 100vh;
+ overflow-y: auto;
+}
+
+.search {
+ display: flex;
+ flex-direction: row;
+ align-items: center;
+ justify-content: space-around;
+}
+
+.searchInput {
+ width: 300px;
+}
+
+.searchDocsTitle {
+ margin-top: 8px;
+ font-weight: bold;
+}
+
+.searchDocsCommon {
+ font-size: var(--ifm-search-desc-font-size);
+ line-height: 20.73px;
+ letter-spacing: -4%;
+ color: var(--ifm-color-brand-dark-400);
+}
+
+.searchDocsDesc {
+ font-weight: 400;
+}
+
+.searchDocsClose {
+ font-weight: bold;
+ cursor: pointer;
+}
+
+@media (max-height: 600px) {
+ .modal {
+ top: calc(var(--header-height) + 1rem);
+ transform: translate(-50%, 0);
+ }
+}
diff --git a/src/theme/Navbar/MobileSidebar/PrimaryMenu/index.tsx b/src/theme/Navbar/MobileSidebar/PrimaryMenu/index.tsx
index 9135ea3717..1321a394d0 100644
--- a/src/theme/Navbar/MobileSidebar/PrimaryMenu/index.tsx
+++ b/src/theme/Navbar/MobileSidebar/PrimaryMenu/index.tsx
@@ -1,26 +1,33 @@
import React from "react"
import {useThemeConfig} from "@docusaurus/theme-common"
import {useNavbarMobileSidebar} from "@docusaurus/theme-common/internal"
-import NavbarItem from "@theme/NavbarItem"
import GithubStarsButton from "@site/src/components/shared/GithubStarsButton"
-function useNavbarItems() {
- // TODO temporary casting until ThemeConfig type is improved
- return useThemeConfig().navbar.items
+import NavbarItem, {type Props as NavbarItemConfig} from "@theme/NavbarItem"
+
+const useNavbarItems = () => {
+ // TODO temporary casting until ThemeConfig type is improved (added by docusaurus)
+ return useThemeConfig().navbar.items as NavbarItemConfig[]
}
+
// The primary menu displays the navbar items
-export default function NavbarMobilePrimaryMenu() {
+const NavbarMobilePrimaryMenu = (): JSX.Element => {
const mobileSidebar = useNavbarMobileSidebar()
- // TODO how can the order be defined for mobile?
+
+ // TODO how can the order be defined for mobile? (added by docusaurus)
// Should we allow providing a different list of items?
const items = useNavbarItems()
+
return (
{items.map((item, i) => (
- mobileSidebar.toggle()} key={i} />
+ mobileSidebar.toggle()} key={i} />
))}
+ {/* Render the GithubStarsButton component */}
)
}
+
+export default NavbarMobilePrimaryMenu
diff --git a/src/types/index.d.ts b/src/types/index.d.ts
index 452a533678..b398fea5a6 100644
--- a/src/types/index.d.ts
+++ b/src/types/index.d.ts
@@ -22,7 +22,7 @@ type MoreFeatures = {
type Social = {
id: number
name: string
- image?: React.FunctionComponent>
+ image?: FunctionComponent> | undefined
href: string
}
@@ -40,6 +40,12 @@ type EnterpriseFeature = {
description: string
}
+type AdditionalEnterpriseFeatures = {
+ id: number
+ logo: React.FunctionComponent>
+ title: string
+}
+
type PricingPlans = {
id: number
name: string
@@ -71,3 +77,44 @@ type Investor = {
name: string
title: string
}
+
+type RadioOptions = {
+ id: string
+ name: string
+ value: string
+}
+
+type SidebarLink = {
+ type: "link"
+ label: string
+ href: string
+ docId: string
+ unlisted: boolean
+}
+
+type SidebarCategory = {
+ type: "category"
+ label: string
+ collapsible: boolean
+ collapsed: boolean
+ items: SidebarLink[]
+}
+
+type SidebarItem = {
+ type: "category" | "link"
+ label: string
+ collapsible?: boolean
+ collapsed?: boolean
+ items?: SidebarLink[]
+ href?: string
+ docId?: string
+ unlisted?: boolean
+}
+
+type SidebarConfig = {
+ sidebar: SidebarItem[]
+ hiddenSidebarContainer: boolean
+}
+
+declare module "docusaurus-lunr-search/src/theme/SearchBar"
+declare module "react-platform-js"
diff --git a/src/utils/index.ts b/src/utils/index.ts
index d7fc003604..54b0fc01da 100644
--- a/src/utils/index.ts
+++ b/src/utils/index.ts
@@ -1,9 +1,21 @@
import ReactGA from "react-ga4"
+// Function to handle analytics events
export const analyticsHandler = (category: string, action: string, label: string): void => {
+ // Sending event to Google Analytics
ReactGA.event({
category: category,
action: action,
label: label,
})
}
+
+// Function to set overflow on body
+export const setBodyOverflow = (value: "initial" | "hidden") => {
+ document.body.style.overflow = value
+}
+
+// Function to get search element ref
+export const getSearchInputRef = () => {
+ return document.getElementById("search_input_react")
+}
diff --git a/static/animations/solution-graphic.json b/static/animations/solution-graphic.json
index 07857298b0..085eb89185 100644
--- a/static/animations/solution-graphic.json
+++ b/static/animations/solution-graphic.json
@@ -8,55 +8,41 @@
"nm": "tailcall-solution-visual 2",
"ddd": 0,
"assets": [
+ {
+ "id": "image_0",
+ "w": 1061,
+ "h": 222,
+ "u": "",
+ "p": "",
+ "e": 1
+ },
{
"id": "comp_0",
"layers": [
{
"ddd": 0,
- "ind": 1,
- "ty": 5,
- "nm": "Work with APIs not with Protocols",
+ "ind": 2,
+ "ty": 2,
+ "nm": "Work with APIs not\u2028with Protocols.png",
+ "cl": "png",
+ "refId": "image_0",
"sr": 1,
"ks": {
"o": {"a": 0, "k": 100, "ix": 11},
"r": {"a": 0, "k": 0, "ix": 10},
- "p": {"a": 0, "k": [704, 546.029, 0], "ix": 2, "l": 2},
- "a": {"a": 0, "k": [0, 0, 0], "ix": 1, "l": 2},
- "s": {"a": 0, "k": [100, 100, 100], "ix": 6, "l": 2}
+ "p": {"a": 0, "k": [703, 532.5, 0], "ix": 2, "l": 2},
+ "a": {"a": 0, "k": [530.5, 111, 0], "ix": 1, "l": 2},
+ "s": {"a": 0, "k": [50, 50, 100], "ix": 6, "l": 2}
},
"ao": 0,
- "t": {
- "d": {
- "k": [
- {
- "s": {
- "sz": [1178, 140],
- "ps": [-589, -70],
- "s": 64,
- "f": "SpaceGrotesk-Bold",
- "t": "Work with APIs not\rwith Protocols",
- "j": 2,
- "tr": -40,
- "lh": 70.4000015258789,
- "ls": 0,
- "fc": [1, 1, 1]
- },
- "t": 0
- }
- ]
- },
- "p": {},
- "m": {"g": 1, "a": {"a": 0, "k": [0, 0], "ix": 2}},
- "a": []
- },
"ip": 0,
- "op": 1205,
+ "op": 1250,
"st": 0,
"bm": 0
},
{
"ddd": 0,
- "ind": 2,
+ "ind": 3,
"ty": 3,
"nm": "NULL",
"sr": 1,
@@ -75,10 +61,10 @@
},
{
"ddd": 0,
- "ind": 3,
+ "ind": 4,
"ty": 4,
"nm": "tailcall-logo",
- "parent": 2,
+ "parent": 3,
"sr": 1,
"ks": {
"o": {"a": 0, "k": 100, "ix": 11},
@@ -474,10 +460,10 @@
},
{
"ddd": 0,
- "ind": 4,
+ "ind": 5,
"ty": 4,
"nm": "tailcall-text",
- "parent": 2,
+ "parent": 3,
"sr": 1,
"ks": {
"o": {"a": 0, "k": 100, "ix": 11},
@@ -1318,7 +1304,7 @@
},
{
"ddd": 0,
- "ind": 5,
+ "ind": 6,
"ty": 4,
"nm": "Shape Layer 24",
"sr": 1,
@@ -1433,7 +1419,7 @@
},
{
"ddd": 0,
- "ind": 6,
+ "ind": 7,
"ty": 4,
"nm": "Shape Layer 23",
"sr": 1,
@@ -1542,7 +1528,7 @@
},
{
"ddd": 0,
- "ind": 7,
+ "ind": 8,
"ty": 4,
"nm": "Shape Layer 22",
"sr": 1,
@@ -1660,7 +1646,7 @@
},
{
"ddd": 0,
- "ind": 8,
+ "ind": 9,
"ty": 4,
"nm": "Shape Layer 21",
"sr": 1,
@@ -1778,7 +1764,7 @@
},
{
"ddd": 0,
- "ind": 9,
+ "ind": 10,
"ty": 4,
"nm": "Shape Layer 20",
"sr": 1,
@@ -1902,7 +1888,7 @@
},
{
"ddd": 0,
- "ind": 10,
+ "ind": 11,
"ty": 4,
"nm": "Shape Layer 19",
"sr": 1,
@@ -2017,7 +2003,7 @@
},
{
"ddd": 0,
- "ind": 11,
+ "ind": 12,
"ty": 4,
"nm": "Shape Layer 18",
"sr": 1,
@@ -2126,7 +2112,7 @@
},
{
"ddd": 0,
- "ind": 12,
+ "ind": 13,
"ty": 4,
"nm": "Shape Layer 17",
"sr": 1,
@@ -2244,7 +2230,7 @@
},
{
"ddd": 0,
- "ind": 13,
+ "ind": 14,
"ty": 4,
"nm": "Shape Layer 16",
"sr": 1,
@@ -2362,7 +2348,7 @@
},
{
"ddd": 0,
- "ind": 14,
+ "ind": 15,
"ty": 4,
"nm": "Shape Layer 15",
"sr": 1,
@@ -2486,7 +2472,7 @@
},
{
"ddd": 0,
- "ind": 15,
+ "ind": 16,
"ty": 4,
"nm": "Vector 22",
"sr": 1,
@@ -2615,7 +2601,7 @@
},
{
"ddd": 0,
- "ind": 16,
+ "ind": 17,
"ty": 4,
"nm": "Vector 21",
"sr": 1,
@@ -2744,7 +2730,7 @@
},
{
"ddd": 0,
- "ind": 17,
+ "ind": 18,
"ty": 0,
"nm": "http",
"refId": "comp_1",
@@ -2766,7 +2752,7 @@
},
{
"ddd": 0,
- "ind": 18,
+ "ind": 19,
"ty": 0,
"nm": "grpc",
"refId": "comp_3",
@@ -2788,7 +2774,7 @@
},
{
"ddd": 0,
- "ind": 19,
+ "ind": 20,
"ty": 0,
"nm": "graphql",
"refId": "comp_4",
@@ -2810,10 +2796,10 @@
},
{
"ddd": 0,
- "ind": 20,
+ "ind": 21,
"ty": 4,
"nm": "grid",
- "parent": 21,
+ "parent": 22,
"sr": 1,
"ks": {
"o": {"a": 0, "k": 100, "ix": 11},
@@ -4112,7 +4098,7 @@
},
{
"ddd": 0,
- "ind": 21,
+ "ind": 22,
"ty": 4,
"nm": "solution-graphic",
"sr": 1,
@@ -8285,9 +8271,6 @@
]
}
],
- "fonts": {
- "list": [{"fName": "SpaceGrotesk-Bold", "fFamily": "Space Grotesk", "fStyle": "Bold", "ascent": 69.9996948242188}]
- },
"layers": [
{
"ddd": 0,
@@ -8312,1491 +8295,5 @@
"bm": 0
}
],
- "markers": [],
- "chars": [
- {
- "ch": "W",
- "size": 64,
- "style": "Bold",
- "w": 89.8,
- "data": {
- "shapes": [
- {
- "ty": "gr",
- "it": [
- {
- "ind": 0,
- "ty": "sh",
- "ix": 1,
- "ks": {
- "a": 0,
- "k": {
- "i": [
- [0, 0],
- [0, 0],
- [0, 0],
- [0, 0],
- [0, 0],
- [0, 0],
- [0, 0],
- [0, 0],
- [0, 0],
- [0, 0],
- [0, 0],
- [0, 0],
- [0, 0],
- [0, 0],
- [0, 0],
- [0, 0]
- ],
- "o": [
- [0, 0],
- [0, 0],
- [0, 0],
- [0, 0],
- [0, 0],
- [0, 0],
- [0, 0],
- [0, 0],
- [0, 0],
- [0, 0],
- [0, 0],
- [0, 0],
- [0, 0],
- [0, 0],
- [0, 0],
- [0, 0]
- ],
- "v": [
- [35, 0],
- [44, -62.2],
- [45.8, -62.2],
- [54.8, 0],
- [77.6, 0],
- [86.8, -70],
- [73.7, -70],
- [66.9, -9.2],
- [65.1, -9.2],
- [56.3, -70],
- [33.5, -70],
- [24.7, -9.2],
- [22.9, -9.2],
- [16.1, -70],
- [3, -70],
- [12.2, 0]
- ],
- "c": true
- },
- "ix": 2
- },
- "nm": "W",
- "mn": "ADBE Vector Shape - Group",
- "hd": false
- }
- ],
- "nm": "W",
- "np": 3,
- "cix": 2,
- "bm": 0,
- "ix": 1,
- "mn": "ADBE Vector Group",
- "hd": false
- }
- ]
- },
- "fFamily": "Space Grotesk"
- },
- {
- "ch": "o",
- "size": 64,
- "style": "Bold",
- "w": 61.2,
- "data": {
- "shapes": [
- {
- "ty": "gr",
- "it": [
- {
- "ind": 0,
- "ty": "sh",
- "ix": 1,
- "ks": {
- "a": 0,
- "k": {
- "i": [
- [-3.934, 2],
- [-2.267, 3.8],
- [0, 5.334],
- [0, 0],
- [2.266, 3.8],
- [3.933, 2],
- [4.933, 0],
- [3.933, -2],
- [2.266, -3.8],
- [0, -5.333],
- [0, 0],
- [-2.267, -3.8],
- [-3.934, -2],
- [-4.934, 0]
- ],
- "o": [
- [3.933, -2],
- [2.266, -3.8],
- [0, 0],
- [0, -5.333],
- [-2.267, -3.8],
- [-3.934, -2],
- [-4.934, 0],
- [-3.934, 2],
- [-2.267, 3.8],
- [0, 0],
- [0, 5.334],
- [2.266, 3.8],
- [3.933, 2],
- [4.933, 0]
- ],
- "v": [
- [43.9, -1.6],
- [53.2, -10.3],
- [56.6, -24],
- [56.6, -25.6],
- [53.2, -39.3],
- [43.9, -48],
- [30.6, -51],
- [17.3, -48],
- [8, -39.3],
- [4.6, -25.6],
- [4.6, -24],
- [8, -10.3],
- [17.3, -1.6],
- [30.6, 1.4]
- ],
- "c": true
- },
- "ix": 2
- },
- "nm": "o",
- "mn": "ADBE Vector Shape - Group",
- "hd": false
- },
- {
- "ind": 1,
- "ty": "sh",
- "ix": 2,
- "ks": {
- "a": 0,
- "k": {
- "i": [
- [2.533, 2.5],
- [0, 4.667],
- [0, 0],
- [-2.534, 2.5],
- [-3.867, 0],
- [-2.5, -2.5],
- [0, -4.666],
- [0, 0],
- [2.533, -2.5],
- [3.866, 0]
- ],
- "o": [
- [-2.534, -2.5],
- [0, 0],
- [0, -4.666],
- [2.533, -2.5],
- [3.933, 0],
- [2.5, 2.5],
- [0, 0],
- [0, 4.667],
- [-2.534, 2.5],
- [-3.867, 0]
- ],
- "v": [
- [21, -13.55],
- [17.2, -24.3],
- [17.2, -25.3],
- [21, -36.05],
- [30.6, -39.8],
- [40.25, -36.05],
- [44, -25.3],
- [44, -24.3],
- [40.2, -13.55],
- [30.6, -9.8]
- ],
- "c": true
- },
- "ix": 2
- },
- "nm": "o",
- "mn": "ADBE Vector Shape - Group",
- "hd": false
- }
- ],
- "nm": "o",
- "np": 5,
- "cix": 2,
- "bm": 0,
- "ix": 1,
- "mn": "ADBE Vector Group",
- "hd": false
- }
- ]
- },
- "fFamily": "Space Grotesk"
- },
- {
- "ch": "r",
- "size": 64,
- "style": "Bold",
- "w": 39.6,
- "data": {
- "shapes": [
- {
- "ty": "gr",
- "it": [
- {
- "ind": 0,
- "ty": "sh",
- "ix": 1,
- "ks": {
- "a": 0,
- "k": {
- "i": [
- [0, 0],
- [0, 0],
- [-2.067, 1.7],
- [-3.2, 0],
- [0, 0],
- [0, 0],
- [0, 0],
- [1.7, -0.933],
- [0.733, -2],
- [0, 0],
- [0, 0],
- [0, 0],
- [0, 0]
- ],
- "o": [
- [0, 0],
- [0, -3.533],
- [2.066, -1.7],
- [0, 0],
- [0, 0],
- [0, 0],
- [-2.267, 0],
- [-1.7, 0.934],
- [0, 0],
- [0, 0],
- [0, 0],
- [0, 0],
- [0, 0]
- ],
- "v": [
- [19.6, 0],
- [19.6, -28.2],
- [22.7, -36.05],
- [30.6, -38.6],
- [36.8, -38.6],
- [36.8, -49.8],
- [30.8, -49.8],
- [24.85, -48.4],
- [21.2, -44],
- [19.4, -44],
- [19.4, -49.6],
- [7, -49.6],
- [7, 0]
- ],
- "c": true
- },
- "ix": 2
- },
- "nm": "r",
- "mn": "ADBE Vector Shape - Group",
- "hd": false
- }
- ],
- "nm": "r",
- "np": 3,
- "cix": 2,
- "bm": 0,
- "ix": 1,
- "mn": "ADBE Vector Group",
- "hd": false
- }
- ]
- },
- "fFamily": "Space Grotesk"
- },
- {
- "ch": "k",
- "size": 64,
- "style": "Bold",
- "w": 56.4,
- "data": {
- "shapes": [
- {
- "ty": "gr",
- "it": [
- {
- "ind": 0,
- "ty": "sh",
- "ix": 1,
- "ks": {
- "a": 0,
- "k": {
- "i": [
- [0, 0],
- [0, 0],
- [0, 0],
- [0, 0],
- [0, 0],
- [0, 0],
- [0, 0],
- [0, 0],
- [0, 0],
- [0, 0],
- [0, 0],
- [0, 0],
- [0, 0]
- ],
- "o": [
- [0, 0],
- [0, 0],
- [0, 0],
- [0, 0],
- [0, 0],
- [0, 0],
- [0, 0],
- [0, 0],
- [0, 0],
- [0, 0],
- [0, 0],
- [0, 0],
- [0, 0]
- ],
- "v": [
- [19.6, 0],
- [19.6, -19.7],
- [21.4, -19.7],
- [38.8, 0],
- [55, 0],
- [31.3, -25.6],
- [54.2, -49.6],
- [37.8, -49.6],
- [21.4, -31.3],
- [19.6, -31.3],
- [19.6, -70],
- [7, -70],
- [7, 0]
- ],
- "c": true
- },
- "ix": 2
- },
- "nm": "k",
- "mn": "ADBE Vector Shape - Group",
- "hd": false
- }
- ],
- "nm": "k",
- "np": 3,
- "cix": 2,
- "bm": 0,
- "ix": 1,
- "mn": "ADBE Vector Group",
- "hd": false
- }
- ]
- },
- "fFamily": "Space Grotesk"
- },
- {"ch": " ", "size": 64, "style": "Bold", "w": 25.4, "data": {}, "fFamily": "Space Grotesk"},
- {
- "ch": "w",
- "size": 64,
- "style": "Bold",
- "w": 78.4,
- "data": {
- "shapes": [
- {
- "ty": "gr",
- "it": [
- {
- "ind": 0,
- "ty": "sh",
- "ix": 1,
- "ks": {
- "a": 0,
- "k": {
- "i": [
- [0, 0],
- [0, 0],
- [0, 0],
- [0, 0],
- [0, 0],
- [0, 0],
- [0, 0],
- [0, 0],
- [0, 0],
- [0, 0],
- [0, 0],
- [0, 0],
- [0, 0],
- [0, 0],
- [0, 0],
- [0, 0]
- ],
- "o": [
- [0, 0],
- [0, 0],
- [0, 0],
- [0, 0],
- [0, 0],
- [0, 0],
- [0, 0],
- [0, 0],
- [0, 0],
- [0, 0],
- [0, 0],
- [0, 0],
- [0, 0],
- [0, 0],
- [0, 0],
- [0, 0]
- ],
- "v": [
- [31.9, 0],
- [38.3, -41.1],
- [40.1, -41.1],
- [46.5, 0],
- [67.4, 0],
- [74.4, -49.6],
- [61.9, -49.6],
- [57.5, -8.5],
- [55.7, -8.5],
- [49.3, -49.6],
- [29.1, -49.6],
- [22.7, -8.5],
- [20.9, -8.5],
- [16.5, -49.6],
- [4, -49.6],
- [11, 0]
- ],
- "c": true
- },
- "ix": 2
- },
- "nm": "w",
- "mn": "ADBE Vector Shape - Group",
- "hd": false
- }
- ],
- "nm": "w",
- "np": 3,
- "cix": 2,
- "bm": 0,
- "ix": 1,
- "mn": "ADBE Vector Group",
- "hd": false
- }
- ]
- },
- "fFamily": "Space Grotesk"
- },
- {
- "ch": "i",
- "size": 64,
- "style": "Bold",
- "w": 26.6,
- "data": {
- "shapes": [
- {
- "ty": "gr",
- "it": [
- {
- "ind": 0,
- "ty": "sh",
- "ix": 1,
- "ks": {
- "a": 0,
- "k": {
- "i": [
- [0, 0],
- [0, 0],
- [0, 0],
- [0, 0]
- ],
- "o": [
- [0, 0],
- [0, 0],
- [0, 0],
- [0, 0]
- ],
- "v": [
- [19.6, 0],
- [19.6, -49.6],
- [7, -49.6],
- [7, 0]
- ],
- "c": true
- },
- "ix": 2
- },
- "nm": "i",
- "mn": "ADBE Vector Shape - Group",
- "hd": false
- },
- {
- "ind": 1,
- "ty": "sh",
- "ix": 2,
- "ks": {
- "a": 0,
- "k": {
- "i": [
- [-1.534, 1.467],
- [0, 2.4],
- [1.533, 1.467],
- [2.333, 0],
- [1.566, -1.466],
- [0, -2.4],
- [-1.567, -1.466],
- [-2.267, 0]
- ],
- "o": [
- [1.533, -1.466],
- [0, -2.4],
- [-1.534, -1.466],
- [-2.267, 0],
- [-1.567, 1.467],
- [0, 2.4],
- [1.566, 1.467],
- [2.333, 0]
- ],
- "v": [
- [19.1, -57.6],
- [21.4, -63.4],
- [19.1, -69.2],
- [13.3, -71.4],
- [7.55, -69.2],
- [5.2, -63.4],
- [7.55, -57.6],
- [13.3, -55.4]
- ],
- "c": true
- },
- "ix": 2
- },
- "nm": "i",
- "mn": "ADBE Vector Shape - Group",
- "hd": false
- }
- ],
- "nm": "i",
- "np": 5,
- "cix": 2,
- "bm": 0,
- "ix": 1,
- "mn": "ADBE Vector Group",
- "hd": false
- }
- ]
- },
- "fFamily": "Space Grotesk"
- },
- {
- "ch": "t",
- "size": 64,
- "style": "Bold",
- "w": 32.6,
- "data": {
- "shapes": [
- {
- "ty": "gr",
- "it": [
- {
- "ind": 0,
- "ty": "sh",
- "ix": 1,
- "ks": {
- "a": 0,
- "k": {
- "i": [
- [0, 0],
- [0, 0],
- [0, 0],
- [0, 2],
- [0, 0],
- [0, 0],
- [0, 0],
- [0, 0],
- [0, 0],
- [0, 0],
- [0, 0],
- [0, 0],
- [0, 0],
- [0, 0],
- [0, 0],
- [-2.034, -2.033],
- [-3.267, 0]
- ],
- "o": [
- [0, 0],
- [0, 0],
- [-1.867, 0],
- [0, 0],
- [0, 0],
- [0, 0],
- [0, 0],
- [0, 0],
- [0, 0],
- [0, 0],
- [0, 0],
- [0, 0],
- [0, 0],
- [0, 0],
- [0, 3.4],
- [2.033, 2.034],
- [0, 0]
- ],
- "v": [
- [40, 0],
- [40, -10.4],
- [30.4, -10.4],
- [27.6, -13.4],
- [27.6, -39.2],
- [41.2, -39.2],
- [41.2, -49.6],
- [27.6, -49.6],
- [27.6, -65],
- [15, -65],
- [15, -49.6],
- [2.6, -49.6],
- [2.6, -39.2],
- [15, -39.2],
- [15, -11.2],
- [18.05, -3.05],
- [26, 0]
- ],
- "c": true
- },
- "ix": 2
- },
- "nm": "t",
- "mn": "ADBE Vector Shape - Group",
- "hd": false
- }
- ],
- "nm": "t",
- "np": 3,
- "cix": 2,
- "bm": 0,
- "ix": 1,
- "mn": "ADBE Vector Group",
- "hd": false
- }
- ]
- },
- "fFamily": "Space Grotesk"
- },
- {
- "ch": "h",
- "size": 64,
- "style": "Bold",
- "w": 61.6,
- "data": {
- "shapes": [
- {
- "ty": "gr",
- "it": [
- {
- "ind": 0,
- "ty": "sh",
- "ix": 1,
- "ks": {
- "a": 0,
- "k": {
- "i": [
- [0, 0],
- [0, 0],
- [-2.134, 2.567],
- [-3.867, 0],
- [-1.834, -1.866],
- [0, -3.733],
- [0, 0],
- [0, 0],
- [0, 0],
- [1.6, 3.1],
- [2.9, 1.767],
- [3.866, 0],
- [1.9, -0.7],
- [1.133, -1.066],
- [0.533, -1.066],
- [0, 0],
- [0, 0],
- [0, 0],
- [0, 0]
- ],
- "o": [
- [0, 0],
- [0, -4.6],
- [2.133, -2.566],
- [3.4, 0],
- [1.833, 1.867],
- [0, 0],
- [0, 0],
- [0, 0],
- [0, -4.133],
- [-1.6, -3.1],
- [-2.9, -1.766],
- [-2.934, 0],
- [-1.9, 0.7],
- [-1.134, 1.067],
- [0, 0],
- [0, 0],
- [0, 0],
- [0, 0],
- [0, 0]
- ],
- "v": [
- [19.6, 0],
- [19.6, -25.2],
- [22.8, -35.95],
- [31.8, -39.8],
- [39.65, -37],
- [42.4, -28.6],
- [42.4, 0],
- [55, 0],
- [55, -29.6],
- [52.6, -40.45],
- [45.85, -47.75],
- [35.7, -50.4],
- [28.45, -49.35],
- [23.9, -46.7],
- [21.4, -43.5],
- [19.6, -43.5],
- [19.6, -70],
- [7, -70],
- [7, 0]
- ],
- "c": true
- },
- "ix": 2
- },
- "nm": "h",
- "mn": "ADBE Vector Shape - Group",
- "hd": false
- }
- ],
- "nm": "h",
- "np": 3,
- "cix": 2,
- "bm": 0,
- "ix": 1,
- "mn": "ADBE Vector Group",
- "hd": false
- }
- ]
- },
- "fFamily": "Space Grotesk"
- },
- {
- "ch": "A",
- "size": 64,
- "style": "Bold",
- "w": 63.4,
- "data": {
- "shapes": [
- {
- "ty": "gr",
- "it": [
- {
- "ind": 0,
- "ty": "sh",
- "ix": 1,
- "ks": {
- "a": 0,
- "k": {
- "i": [
- [0, 0],
- [0, 0],
- [0, 0],
- [0, 0],
- [0, 0],
- [0, 0],
- [0, 0],
- [0, 0]
- ],
- "o": [
- [0, 0],
- [0, 0],
- [0, 0],
- [0, 0],
- [0, 0],
- [0, 0],
- [0, 0],
- [0, 0]
- ],
- "v": [
- [15.4, 0],
- [19.2, -15.4],
- [44.2, -15.4],
- [48, 0],
- [61.6, 0],
- [43.2, -70],
- [20.2, -70],
- [1.8, 0]
- ],
- "c": true
- },
- "ix": 2
- },
- "nm": "A",
- "mn": "ADBE Vector Shape - Group",
- "hd": false
- },
- {
- "ind": 1,
- "ty": "sh",
- "ix": 2,
- "ks": {
- "a": 0,
- "k": {
- "i": [
- [0, 0],
- [0, 0],
- [0, 0],
- [0, 0]
- ],
- "o": [
- [0, 0],
- [0, 0],
- [0, 0],
- [0, 0]
- ],
- "v": [
- [30.8, -61.7],
- [32.6, -61.7],
- [41.1, -27.6],
- [22.3, -27.6]
- ],
- "c": true
- },
- "ix": 2
- },
- "nm": "A",
- "mn": "ADBE Vector Shape - Group",
- "hd": false
- }
- ],
- "nm": "A",
- "np": 5,
- "cix": 2,
- "bm": 0,
- "ix": 1,
- "mn": "ADBE Vector Group",
- "hd": false
- }
- ]
- },
- "fFamily": "Space Grotesk"
- },
- {
- "ch": "P",
- "size": 64,
- "style": "Bold",
- "w": 60.4,
- "data": {
- "shapes": [
- {
- "ty": "gr",
- "it": [
- {
- "ind": 0,
- "ty": "sh",
- "ix": 1,
- "ks": {
- "a": 0,
- "k": {
- "i": [
- [0, 0],
- [0, 0],
- [0, 0],
- [-3.367, 1.767],
- [-1.967, 3.234],
- [0, 4.334],
- [0, 0],
- [1.9, 3.2],
- [3.366, 1.767],
- [4.4, 0],
- [0, 0],
- [0, 0]
- ],
- "o": [
- [0, 0],
- [0, 0],
- [4.266, 0],
- [3.366, -1.766],
- [1.966, -3.233],
- [0, 0],
- [0, -4.4],
- [-1.9, -3.2],
- [-3.367, -1.766],
- [0, 0],
- [0, 0],
- [0, 0]
- ],
- "v": [
- [19.8, 0],
- [19.8, -25.6],
- [35.4, -25.6],
- [46.85, -28.25],
- [54.85, -35.75],
- [57.8, -47.1],
- [57.8, -48.5],
- [54.95, -59.9],
- [47.05, -67.35],
- [35.4, -70],
- [6.6, -70],
- [6.6, 0]
- ],
- "c": true
- },
- "ix": 2
- },
- "nm": "P",
- "mn": "ADBE Vector Shape - Group",
- "hd": false
- },
- {
- "ind": 1,
- "ty": "sh",
- "ix": 2,
- "ks": {
- "a": 0,
- "k": {
- "i": [
- [0, 0],
- [0, 0],
- [-1.934, -1.733],
- [0, -3],
- [0, 0],
- [1.933, -1.733],
- [3.133, 0],
- [0, 0]
- ],
- "o": [
- [0, 0],
- [3.133, 0],
- [1.933, 1.734],
- [0, 0],
- [0, 3],
- [-1.934, 1.734],
- [0, 0],
- [0, 0]
- ],
- "v": [
- [19.8, -58],
- [34.1, -58],
- [41.7, -55.4],
- [44.6, -48.3],
- [44.6, -47.3],
- [41.7, -40.2],
- [34.1, -37.6],
- [19.8, -37.6]
- ],
- "c": true
- },
- "ix": 2
- },
- "nm": "P",
- "mn": "ADBE Vector Shape - Group",
- "hd": false
- }
- ],
- "nm": "P",
- "np": 5,
- "cix": 2,
- "bm": 0,
- "ix": 1,
- "mn": "ADBE Vector Group",
- "hd": false
- }
- ]
- },
- "fFamily": "Space Grotesk"
- },
- {
- "ch": "I",
- "size": 64,
- "style": "Bold",
- "w": 26.4,
- "data": {
- "shapes": [
- {
- "ty": "gr",
- "it": [
- {
- "ind": 0,
- "ty": "sh",
- "ix": 1,
- "ks": {
- "a": 0,
- "k": {
- "i": [
- [0, 0],
- [0, 0],
- [0, 0],
- [0, 0]
- ],
- "o": [
- [0, 0],
- [0, 0],
- [0, 0],
- [0, 0]
- ],
- "v": [
- [19.8, 0],
- [19.8, -70],
- [6.6, -70],
- [6.6, 0]
- ],
- "c": true
- },
- "ix": 2
- },
- "nm": "I",
- "mn": "ADBE Vector Shape - Group",
- "hd": false
- }
- ],
- "nm": "I",
- "np": 3,
- "cix": 2,
- "bm": 0,
- "ix": 1,
- "mn": "ADBE Vector Group",
- "hd": false
- }
- ]
- },
- "fFamily": "Space Grotesk"
- },
- {
- "ch": "s",
- "size": 64,
- "style": "Bold",
- "w": 52.4,
- "data": {
- "shapes": [
- {
- "ty": "gr",
- "it": [
- {
- "ind": 0,
- "ty": "sh",
- "ix": 1,
- "ks": {
- "a": 0,
- "k": {
- "i": [
- [-3.767, 2.834],
- [0, 5.2],
- [1.766, 2.034],
- [3.033, 1.1],
- [3.733, 0.667],
- [0, 0],
- [1.333, 0.767],
- [0, 1.6],
- [-1.267, 0.834],
- [-2.4, 0],
- [-1.634, -1.066],
- [-0.534, -2.533],
- [0, 0],
- [3.666, 2.467],
- [5.533, 0],
- [3.6, -2.633],
- [0, -4.933],
- [-1.734, -2.066],
- [-2.867, -1.166],
- [-3.467, -0.666],
- [0, 0],
- [-1.334, -0.833],
- [0, -1.533],
- [1.4, -1.033],
- [2.933, 0],
- [1.633, 0.567],
- [1.1, 1.334],
- [0.466, 2.334],
- [0, 0],
- [-4.134, -2.8],
- [-6.467, 0]
- ],
- "o": [
- [3.766, -2.833],
- [0, -3.466],
- [-1.767, -2.033],
- [-3.034, -1.1],
- [0, 0],
- [-2.267, -0.4],
- [-1.334, -0.766],
- [0, -1.466],
- [1.266, -0.833],
- [2.4, 0],
- [1.633, 1.067],
- [0, 0],
- [-1.134, -4],
- [-3.667, -2.466],
- [-5.867, 0],
- [-3.6, 2.634],
- [0, 3.267],
- [1.733, 2.067],
- [2.866, 1.167],
- [0, 0],
- [2.933, 0.534],
- [1.333, 0.834],
- [0, 1.534],
- [-1.4, 1.034],
- [-1.934, 0],
- [-1.634, -0.566],
- [-1.1, -1.333],
- [0, 0],
- [0.866, 5.2],
- [4.133, 2.8],
- [6.333, 0]
- ],
- "v": [
- [42.75, -2.85],
- [48.4, -14.9],
- [45.75, -23.15],
- [38.55, -27.85],
- [28.4, -30.5],
- [25.6, -31],
- [20.2, -32.75],
- [18.2, -36.3],
- [20.1, -39.75],
- [25.6, -41],
- [31.65, -39.4],
- [34.9, -34],
- [46.6, -37.6],
- [39.4, -47.3],
- [25.6, -51],
- [11.4, -47.05],
- [6, -35.7],
- [8.6, -27.7],
- [15.5, -22.85],
- [25, -20.1],
- [27.8, -19.6],
- [34.2, -17.55],
- [36.2, -14],
- [34.1, -10.15],
- [27.6, -8.6],
- [22.25, -9.45],
- [18.15, -12.3],
- [15.8, -17.8],
- [4.2, -14.8],
- [11.7, -2.8],
- [27.6, 1.4]
- ],
- "c": true
- },
- "ix": 2
- },
- "nm": "s",
- "mn": "ADBE Vector Shape - Group",
- "hd": false
- }
- ],
- "nm": "s",
- "np": 3,
- "cix": 2,
- "bm": 0,
- "ix": 1,
- "mn": "ADBE Vector Group",
- "hd": false
- }
- ]
- },
- "fFamily": "Space Grotesk"
- },
- {
- "ch": "n",
- "size": 64,
- "style": "Bold",
- "w": 61.6,
- "data": {
- "shapes": [
- {
- "ty": "gr",
- "it": [
- {
- "ind": 0,
- "ty": "sh",
- "ix": 1,
- "ks": {
- "a": 0,
- "k": {
- "i": [
- [0, 0],
- [0, 0],
- [-2.134, 2.567],
- [-3.867, 0],
- [-1.834, -1.866],
- [0, -3.733],
- [0, 0],
- [0, 0],
- [0, 0],
- [1.6, 3.1],
- [2.9, 1.767],
- [3.866, 0],
- [2.2, -1.566],
- [0.8, -1.733],
- [0, 0],
- [0, 0],
- [0, 0],
- [0, 0]
- ],
- "o": [
- [0, 0],
- [0, -4.6],
- [2.133, -2.566],
- [3.4, 0],
- [1.833, 1.867],
- [0, 0],
- [0, 0],
- [0, 0],
- [0, -4.133],
- [-1.6, -3.1],
- [-2.9, -1.766],
- [-4.467, 0],
- [-2.2, 1.567],
- [0, 0],
- [0, 0],
- [0, 0],
- [0, 0],
- [0, 0]
- ],
- "v": [
- [19.6, 0],
- [19.6, -25.2],
- [22.8, -35.95],
- [31.8, -39.8],
- [39.65, -37],
- [42.4, -28.6],
- [42.4, 0],
- [55, 0],
- [55, -29.6],
- [52.6, -40.45],
- [45.85, -47.75],
- [35.7, -50.4],
- [25.7, -48.05],
- [21.2, -43.1],
- [19.4, -43.1],
- [19.4, -49.6],
- [7, -49.6],
- [7, 0]
- ],
- "c": true
- },
- "ix": 2
- },
- "nm": "n",
- "mn": "ADBE Vector Shape - Group",
- "hd": false
- }
- ],
- "nm": "n",
- "np": 3,
- "cix": 2,
- "bm": 0,
- "ix": 1,
- "mn": "ADBE Vector Group",
- "hd": false
- }
- ]
- },
- "fFamily": "Space Grotesk"
- },
- {"ch": "\r", "size": 64, "style": "Bold", "w": 0, "fFamily": "Space Grotesk"},
- {
- "ch": "c",
- "size": 64,
- "style": "Bold",
- "w": 58.6,
- "data": {
- "shapes": [
- {
- "ty": "gr",
- "it": [
- {
- "ind": 0,
- "ty": "sh",
- "ix": 1,
- "ks": {
- "a": 0,
- "k": {
- "i": [
- [-3.4, 1.666],
- [-2.1, 2.9],
- [-0.867, 3.534],
- [0, 0],
- [1.966, -1.966],
- [3.8, 0],
- [2.033, 1.1],
- [1.166, 2.167],
- [0, 3.134],
- [0, 0],
- [-1.167, 2.167],
- [-2.034, 1.1],
- [-2.534, 0],
- [-1.7, -0.933],
- [-0.934, -1.6],
- [-0.267, -2],
- [0, 0],
- [2.1, 2.9],
- [3.4, 1.667],
- [4.733, 0],
- [3.9, -2],
- [2.266, -3.8],
- [0, -5.4],
- [0, 0],
- [-2.267, -3.8],
- [-3.9, -2],
- [-4.8, 0]
- ],
- "o": [
- [3.4, -1.666],
- [2.1, -2.9],
- [0, 0],
- [-0.534, 3.2],
- [-1.967, 1.967],
- [-2.534, 0],
- [-2.034, -1.1],
- [-1.167, -2.166],
- [0, 0],
- [0, -3.133],
- [1.166, -2.166],
- [2.033, -1.1],
- [2.533, 0],
- [1.7, 0.934],
- [0.933, 1.6],
- [0, 0],
- [-0.667, -3.666],
- [-2.1, -2.9],
- [-3.4, -1.666],
- [-4.8, 0],
- [-3.9, 2],
- [-2.267, 3.8],
- [0, 0],
- [0, 5.4],
- [2.266, 3.8],
- [3.9, 2],
- [4.733, 0]
- ],
- "v": [
- [42.5, -1.1],
- [50.75, -7.95],
- [55.2, -17.6],
- [43, -20.5],
- [39.25, -12.75],
- [30.6, -9.8],
- [23.75, -11.45],
- [18.95, -16.35],
- [17.2, -24.3],
- [17.2, -25.3],
- [18.95, -33.25],
- [23.75, -38.15],
- [30.6, -39.8],
- [36.95, -38.4],
- [40.9, -34.6],
- [42.7, -29.2],
- [54.9, -31.8],
- [50.75, -41.65],
- [42.5, -48.5],
- [30.3, -51],
- [17.25, -48],
- [8, -39.3],
- [4.6, -25.5],
- [4.6, -24.1],
- [8, -10.3],
- [17.25, -1.6],
- [30.3, 1.4]
- ],
- "c": true
- },
- "ix": 2
- },
- "nm": "c",
- "mn": "ADBE Vector Shape - Group",
- "hd": false
- }
- ],
- "nm": "c",
- "np": 3,
- "cix": 2,
- "bm": 0,
- "ix": 1,
- "mn": "ADBE Vector Group",
- "hd": false
- }
- ]
- },
- "fFamily": "Space Grotesk"
- },
- {
- "ch": "l",
- "size": 64,
- "style": "Bold",
- "w": 26.6,
- "data": {
- "shapes": [
- {
- "ty": "gr",
- "it": [
- {
- "ind": 0,
- "ty": "sh",
- "ix": 1,
- "ks": {
- "a": 0,
- "k": {
- "i": [
- [0, 0],
- [0, 0],
- [0, 0],
- [0, 0]
- ],
- "o": [
- [0, 0],
- [0, 0],
- [0, 0],
- [0, 0]
- ],
- "v": [
- [19.6, 0],
- [19.6, -70],
- [7, -70],
- [7, 0]
- ],
- "c": true
- },
- "ix": 2
- },
- "nm": "l",
- "mn": "ADBE Vector Shape - Group",
- "hd": false
- }
- ],
- "nm": "l",
- "np": 3,
- "cix": 2,
- "bm": 0,
- "ix": 1,
- "mn": "ADBE Vector Group",
- "hd": false
- }
- ]
- },
- "fFamily": "Space Grotesk"
- }
- ]
+ "markers": []
}
diff --git a/static/icons/basic/search.svg b/static/icons/basic/search.svg
new file mode 100644
index 0000000000..141a2f42b8
--- /dev/null
+++ b/static/icons/basic/search.svg
@@ -0,0 +1,3 @@
+
+
+
diff --git a/static/icons/companies/github-light.svg b/static/icons/companies/github-light.svg
index bc81de7630..5076bc8230 100644
--- a/static/icons/companies/github-light.svg
+++ b/static/icons/companies/github-light.svg
@@ -1,15 +1,3 @@
-
-
-
-
-
-
-
-
-
-
-
-
diff --git a/tailwind.config.ts b/tailwind.config.ts
index bf1ee045ff..1124e3e939 100644
--- a/tailwind.config.ts
+++ b/tailwind.config.ts
@@ -5,6 +5,23 @@ module.exports = {
extend: {
colors: {
tailCall: {
+ border: {
+ light: {
+ 100: "#f3f4f7",
+ 200: "#e4e4e4",
+ 300: "#e5e5e5",
+ 400: "#e7e7e7",
+ 500: "#cececf",
+ 600: "#b6b6b7",
+ },
+ dark: {
+ 100: "#121315",
+ 200: "#323335",
+ 300: "#2c2c2c",
+ 400: "#545556",
+ 700: "#000000",
+ },
+ },
light: {
100: "#FFFFFF",
200: "#F3F3F3",
@@ -26,6 +43,28 @@ module.exports = {
yellow: "#FDEA2E",
},
},
+ spacing: {
+ SPACE_01: "4px",
+ SPACE_02: "8px",
+ SPACE_03: "12px",
+ SPACE_04: "16px",
+ SPACE_05: "20px",
+ SPACE_06: "24px",
+ SPACE_07: "28px",
+ SPACE_08: "32px",
+ SPACE_09: "36px",
+ SPACE_10: "40px",
+ SPACE_11: "44px",
+ SPACE_12: "48px",
+ SPACE_13: "52px",
+ SPACE_14: "56px",
+ SPACE_15: "60px",
+ SPACE_16: "64px",
+ SPACE_17: "68px",
+ SPACE_18: "72px",
+ SPACE_19: "76px",
+ SPACE_20: "80px",
+ },
},
fontFamily: {
"space-grotesk": ["Space Grotesk", "sans-serif"],
diff --git a/tsconfig.json b/tsconfig.json
index 7dc3bde14a..e3f3ae2ee3 100644
--- a/tsconfig.json
+++ b/tsconfig.json
@@ -3,6 +3,14 @@
"extends": "@docusaurus/tsconfig",
"compilerOptions": {
"jsx": "react",
- "baseUrl": "."
+ "baseUrl": ".",
+ "strict": true, // Enable all strict type checking options
+ "noImplicitAny": true, // Raise error on expressions and declarations with an implied 'any' type
+ "strictNullChecks": true, // When type checking, take into account 'null' and 'undefined'
+ "strictFunctionTypes": true, // Ensure function parameter and return type matching is more accurate
+ "strictBindCallApply": true, // Enable stricter checking of the 'bind', 'call', and 'apply' methods
+ "strictPropertyInitialization": true, // Ensure class properties are initialized in the constructor
+ "noImplicitThis": true, // Raise error on 'this' expressions with an implied 'any' type
+ "alwaysStrict": true // Parse in strict mode and emit "use strict" for each source file
}
}