Skip to content

Commit 3b9f5d1

Browse files
committed
Update logo
1 parent 5fb5c94 commit 3b9f5d1

File tree

3 files changed

+195
-5
lines changed

3 files changed

+195
-5
lines changed

.astro/content.d.ts

Lines changed: 184 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,184 @@
1+
declare module 'astro:content' {
2+
interface Render {
3+
'.mdx': Promise<{
4+
Content: import('astro').MarkdownInstance<{}>['Content'];
5+
headings: import('astro').MarkdownHeading[];
6+
remarkPluginFrontmatter: Record<string, any>;
7+
components: import('astro').MDXInstance<{}>['components'];
8+
}>;
9+
}
10+
}
11+
12+
declare module 'astro:content' {
13+
export interface RenderResult {
14+
Content: import('astro/runtime/server/index.js').AstroComponentFactory;
15+
headings: import('astro').MarkdownHeading[];
16+
remarkPluginFrontmatter: Record<string, any>;
17+
}
18+
interface Render {
19+
'.md': Promise<RenderResult>;
20+
}
21+
22+
export interface RenderedContent {
23+
html: string;
24+
metadata?: {
25+
imagePaths: Array<string>;
26+
[key: string]: unknown;
27+
};
28+
}
29+
}
30+
31+
declare module 'astro:content' {
32+
type Flatten<T> = T extends { [K: string]: infer U } ? U : never;
33+
34+
export type CollectionKey = keyof AnyEntryMap;
35+
export type CollectionEntry<C extends CollectionKey> = Flatten<AnyEntryMap[C]>;
36+
37+
export type ContentCollectionKey = keyof ContentEntryMap;
38+
export type DataCollectionKey = keyof DataEntryMap;
39+
40+
type AllValuesOf<T> = T extends any ? T[keyof T] : never;
41+
type ValidContentEntrySlug<C extends keyof ContentEntryMap> = AllValuesOf<
42+
ContentEntryMap[C]
43+
>['slug'];
44+
45+
/** @deprecated Use `getEntry` instead. */
46+
export function getEntryBySlug<
47+
C extends keyof ContentEntryMap,
48+
E extends ValidContentEntrySlug<C> | (string & {}),
49+
>(
50+
collection: C,
51+
// Note that this has to accept a regular string too, for SSR
52+
entrySlug: E,
53+
): E extends ValidContentEntrySlug<C>
54+
? Promise<CollectionEntry<C>>
55+
: Promise<CollectionEntry<C> | undefined>;
56+
57+
/** @deprecated Use `getEntry` instead. */
58+
export function getDataEntryById<C extends keyof DataEntryMap, E extends keyof DataEntryMap[C]>(
59+
collection: C,
60+
entryId: E,
61+
): Promise<CollectionEntry<C>>;
62+
63+
export function getCollection<C extends keyof AnyEntryMap, E extends CollectionEntry<C>>(
64+
collection: C,
65+
filter?: (entry: CollectionEntry<C>) => entry is E,
66+
): Promise<E[]>;
67+
export function getCollection<C extends keyof AnyEntryMap>(
68+
collection: C,
69+
filter?: (entry: CollectionEntry<C>) => unknown,
70+
): Promise<CollectionEntry<C>[]>;
71+
72+
export function getEntry<
73+
C extends keyof ContentEntryMap,
74+
E extends ValidContentEntrySlug<C> | (string & {}),
75+
>(entry: {
76+
collection: C;
77+
slug: E;
78+
}): E extends ValidContentEntrySlug<C>
79+
? Promise<CollectionEntry<C>>
80+
: Promise<CollectionEntry<C> | undefined>;
81+
export function getEntry<
82+
C extends keyof DataEntryMap,
83+
E extends keyof DataEntryMap[C] | (string & {}),
84+
>(entry: {
85+
collection: C;
86+
id: E;
87+
}): E extends keyof DataEntryMap[C]
88+
? Promise<DataEntryMap[C][E]>
89+
: Promise<CollectionEntry<C> | undefined>;
90+
export function getEntry<
91+
C extends keyof ContentEntryMap,
92+
E extends ValidContentEntrySlug<C> | (string & {}),
93+
>(
94+
collection: C,
95+
slug: E,
96+
): E extends ValidContentEntrySlug<C>
97+
? Promise<CollectionEntry<C>>
98+
: Promise<CollectionEntry<C> | undefined>;
99+
export function getEntry<
100+
C extends keyof DataEntryMap,
101+
E extends keyof DataEntryMap[C] | (string & {}),
102+
>(
103+
collection: C,
104+
id: E,
105+
): E extends keyof DataEntryMap[C]
106+
? string extends keyof DataEntryMap[C]
107+
? Promise<DataEntryMap[C][E]> | undefined
108+
: Promise<DataEntryMap[C][E]>
109+
: Promise<CollectionEntry<C> | undefined>;
110+
111+
/** Resolve an array of entry references from the same collection */
112+
export function getEntries<C extends keyof ContentEntryMap>(
113+
entries: {
114+
collection: C;
115+
slug: ValidContentEntrySlug<C>;
116+
}[],
117+
): Promise<CollectionEntry<C>[]>;
118+
export function getEntries<C extends keyof DataEntryMap>(
119+
entries: {
120+
collection: C;
121+
id: keyof DataEntryMap[C];
122+
}[],
123+
): Promise<CollectionEntry<C>[]>;
124+
125+
export function render<C extends keyof AnyEntryMap>(
126+
entry: AnyEntryMap[C][string],
127+
): Promise<RenderResult>;
128+
129+
export function reference<C extends keyof AnyEntryMap>(
130+
collection: C,
131+
): import('astro/zod').ZodEffects<
132+
import('astro/zod').ZodString,
133+
C extends keyof ContentEntryMap
134+
? {
135+
collection: C;
136+
slug: ValidContentEntrySlug<C>;
137+
}
138+
: {
139+
collection: C;
140+
id: keyof DataEntryMap[C];
141+
}
142+
>;
143+
// Allow generic `string` to avoid excessive type errors in the config
144+
// if `dev` is not running to update as you edit.
145+
// Invalid collection names will be caught at build time.
146+
export function reference<C extends string>(
147+
collection: C,
148+
): import('astro/zod').ZodEffects<import('astro/zod').ZodString, never>;
149+
150+
type ReturnTypeOrOriginal<T> = T extends (...args: any[]) => infer R ? R : T;
151+
type InferEntrySchema<C extends keyof AnyEntryMap> = import('astro/zod').infer<
152+
ReturnTypeOrOriginal<Required<ContentConfig['collections'][C]>['schema']>
153+
>;
154+
155+
type ContentEntryMap = {
156+
157+
};
158+
159+
type DataEntryMap = {
160+
"articles": Record<string, {
161+
id: string;
162+
body?: string;
163+
collection: "articles";
164+
data: InferEntrySchema<"articles">;
165+
rendered?: RenderedContent;
166+
filePath?: string;
167+
}>;
168+
"blog": Record<string, {
169+
id: string;
170+
render(): Render[".md"];
171+
slug: string;
172+
body: string;
173+
collection: "blog";
174+
data: InferEntrySchema<"blog">;
175+
rendered?: RenderedContent;
176+
filePath?: string;
177+
}>;
178+
179+
};
180+
181+
type AnyEntryMap = ContentEntryMap & DataEntryMap;
182+
183+
export type ContentConfig = typeof import("../src/content.config.js");
184+
}

.gitignore

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -34,4 +34,4 @@ npm-debug.log*
3434
yarn-debug.log*
3535
yarn-error.log*
3636
pnpm-debug.log*
37-
/.astro/**
37+
.astro/*

src/assets/styles/globals.css

Lines changed: 10 additions & 4 deletions
Original file line numberDiff line numberDiff line change
@@ -47,7 +47,8 @@
4747
container-name: thread;
4848
box-sizing: border-box;
4949
min-height: 100vh;
50-
font-family: "Roboto", "SF Pro Text", "SF Pro Icons", "AOS Icons", "Helvetica Neue", Helvetica, Arial, sans-serif, system-ui;
50+
font-family: "Roboto", "SF Pro Text", "SF Pro Icons", "AOS Icons", "Helvetica Neue", Helvetica, Arial, sans-serif,
51+
system-ui;
5152
padding-left: clamp(1rem, 5vw, 10rem);
5253
padding-right: clamp(1rem, 5vw, 10rem);
5354
transition: background-color 0.3s ease;
@@ -123,15 +124,15 @@
123124
outline: 1px solid greenyellow;
124125
}
125126

126-
/*.whiteBg {
127+
.whiteBg {
127128
background-color: #eee;
128129
color: #111;
129130
}
130131

131132
.darkBg {
132133
background-color: #222;
133134
color: #fff;
134-
}*/
135+
}
135136

136137
textarea {
137138
resize: none;
@@ -145,4 +146,9 @@
145146
.yellowBtnHover:hover {
146147
background-color: #b89405;
147148
}
148-
}
149+
.clipped-logo {
150+
position: relative;
151+
-webkit-clip-path: inset(30px 10px 30px 10px);
152+
clip-path: inset(30px 10px 30px 10px);
153+
}
154+
}

0 commit comments

Comments
 (0)