diff --git a/.changeset/shy-fishes-melt.md b/.changeset/shy-fishes-melt.md
new file mode 100644
index 000000000..64d756fdd
--- /dev/null
+++ b/.changeset/shy-fishes-melt.md
@@ -0,0 +1,5 @@
+---
+'@codeimage/app': patch
+---
+
+Add new fonts
diff --git a/apps/codeimage/changelog/1-8-3_12-23-2024.mdx b/apps/codeimage/changelog/1-8-3_12-23-2024.mdx
new file mode 100644
index 000000000..d796a1bf5
--- /dev/null
+++ b/apps/codeimage/changelog/1-8-3_12-23-2024.mdx
@@ -0,0 +1,14 @@
+import {mdxComponents} from '../src/mdx/components';
+import shareablePresets from './data/1-7-0/shareable_presets.png';
+
+# v1.8.4
+
+💬 New fonts
+
+This new version of CodeImage introduces new fonts into it's core:
+- Geist Mono
+- IBM Plex Mono
+-
+
+
+
diff --git a/apps/codeimage/index.html b/apps/codeimage/index.html
index 05fa45bb9..65231690a 100644
--- a/apps/codeimage/index.html
+++ b/apps/codeimage/index.html
@@ -1,90 +1,129 @@
-
-
-
-
-
-
-
-
-
-
+
+
+
+
+
+
+
+
+
+
-
+
-
+
-
- CodeImage - A tool to manage and beautify your code screenshots
-
-
+
+
+ CodeImage - A tool to manage and beautify your code screenshots
+
+
+
-
-
-
-
-
-
+
+
+
+
+
+
-
-
-
-
-
-
-
-
+
+
+
+
+
+
+
+
-
-
+ .launcher img {
+ opacity: 1;
+ }
+
+
-
-
-
-
-
![logo](/assets/codeimage-logo-blue-svg-v1.svg)
-
-
-
-
+
+
+
+
+
![logo](/assets/codeimage-logo-blue-svg-v1.svg)
+
+
+
+
diff --git a/apps/codeimage/public/assets/fonts/IBM_Plex_Mono/IBMPlexMono-Bold.ttf b/apps/codeimage/public/assets/fonts/IBM_Plex_Mono/IBMPlexMono-Bold.ttf
new file mode 100644
index 000000000..2e437e21b
Binary files /dev/null and b/apps/codeimage/public/assets/fonts/IBM_Plex_Mono/IBMPlexMono-Bold.ttf differ
diff --git a/apps/codeimage/public/assets/fonts/IBM_Plex_Mono/IBMPlexMono-BoldItalic.ttf b/apps/codeimage/public/assets/fonts/IBM_Plex_Mono/IBMPlexMono-BoldItalic.ttf
new file mode 100644
index 000000000..f2695fcee
Binary files /dev/null and b/apps/codeimage/public/assets/fonts/IBM_Plex_Mono/IBMPlexMono-BoldItalic.ttf differ
diff --git a/apps/codeimage/public/assets/fonts/IBM_Plex_Mono/IBMPlexMono-ExtraLight.ttf b/apps/codeimage/public/assets/fonts/IBM_Plex_Mono/IBMPlexMono-ExtraLight.ttf
new file mode 100644
index 000000000..573ef7644
Binary files /dev/null and b/apps/codeimage/public/assets/fonts/IBM_Plex_Mono/IBMPlexMono-ExtraLight.ttf differ
diff --git a/apps/codeimage/public/assets/fonts/IBM_Plex_Mono/IBMPlexMono-ExtraLightItalic.ttf b/apps/codeimage/public/assets/fonts/IBM_Plex_Mono/IBMPlexMono-ExtraLightItalic.ttf
new file mode 100644
index 000000000..ea13f86de
Binary files /dev/null and b/apps/codeimage/public/assets/fonts/IBM_Plex_Mono/IBMPlexMono-ExtraLightItalic.ttf differ
diff --git a/apps/codeimage/public/assets/fonts/IBM_Plex_Mono/IBMPlexMono-Italic.ttf b/apps/codeimage/public/assets/fonts/IBM_Plex_Mono/IBMPlexMono-Italic.ttf
new file mode 100644
index 000000000..3cb28a39c
Binary files /dev/null and b/apps/codeimage/public/assets/fonts/IBM_Plex_Mono/IBMPlexMono-Italic.ttf differ
diff --git a/apps/codeimage/public/assets/fonts/IBM_Plex_Mono/IBMPlexMono-Light.ttf b/apps/codeimage/public/assets/fonts/IBM_Plex_Mono/IBMPlexMono-Light.ttf
new file mode 100644
index 000000000..df167f094
Binary files /dev/null and b/apps/codeimage/public/assets/fonts/IBM_Plex_Mono/IBMPlexMono-Light.ttf differ
diff --git a/apps/codeimage/public/assets/fonts/IBM_Plex_Mono/IBMPlexMono-LightItalic.ttf b/apps/codeimage/public/assets/fonts/IBM_Plex_Mono/IBMPlexMono-LightItalic.ttf
new file mode 100644
index 000000000..c9072e96a
Binary files /dev/null and b/apps/codeimage/public/assets/fonts/IBM_Plex_Mono/IBMPlexMono-LightItalic.ttf differ
diff --git a/apps/codeimage/public/assets/fonts/IBM_Plex_Mono/IBMPlexMono-Medium.ttf b/apps/codeimage/public/assets/fonts/IBM_Plex_Mono/IBMPlexMono-Medium.ttf
new file mode 100644
index 000000000..39f178db7
Binary files /dev/null and b/apps/codeimage/public/assets/fonts/IBM_Plex_Mono/IBMPlexMono-Medium.ttf differ
diff --git a/apps/codeimage/public/assets/fonts/IBM_Plex_Mono/IBMPlexMono-MediumItalic.ttf b/apps/codeimage/public/assets/fonts/IBM_Plex_Mono/IBMPlexMono-MediumItalic.ttf
new file mode 100644
index 000000000..0d887f76d
Binary files /dev/null and b/apps/codeimage/public/assets/fonts/IBM_Plex_Mono/IBMPlexMono-MediumItalic.ttf differ
diff --git a/apps/codeimage/public/assets/fonts/IBM_Plex_Mono/IBMPlexMono-Regular.ttf b/apps/codeimage/public/assets/fonts/IBM_Plex_Mono/IBMPlexMono-Regular.ttf
new file mode 100644
index 000000000..81ca3dcc9
Binary files /dev/null and b/apps/codeimage/public/assets/fonts/IBM_Plex_Mono/IBMPlexMono-Regular.ttf differ
diff --git a/apps/codeimage/public/assets/fonts/IBM_Plex_Mono/IBMPlexMono-SemiBold.ttf b/apps/codeimage/public/assets/fonts/IBM_Plex_Mono/IBMPlexMono-SemiBold.ttf
new file mode 100644
index 000000000..73dd5a4f1
Binary files /dev/null and b/apps/codeimage/public/assets/fonts/IBM_Plex_Mono/IBMPlexMono-SemiBold.ttf differ
diff --git a/apps/codeimage/public/assets/fonts/IBM_Plex_Mono/IBMPlexMono-SemiBoldItalic.ttf b/apps/codeimage/public/assets/fonts/IBM_Plex_Mono/IBMPlexMono-SemiBoldItalic.ttf
new file mode 100644
index 000000000..a41b0d3dd
Binary files /dev/null and b/apps/codeimage/public/assets/fonts/IBM_Plex_Mono/IBMPlexMono-SemiBoldItalic.ttf differ
diff --git a/apps/codeimage/public/assets/fonts/IBM_Plex_Mono/IBMPlexMono-Thin.ttf b/apps/codeimage/public/assets/fonts/IBM_Plex_Mono/IBMPlexMono-Thin.ttf
new file mode 100644
index 000000000..e173f5a1e
Binary files /dev/null and b/apps/codeimage/public/assets/fonts/IBM_Plex_Mono/IBMPlexMono-Thin.ttf differ
diff --git a/apps/codeimage/public/assets/fonts/IBM_Plex_Mono/IBMPlexMono-ThinItalic.ttf b/apps/codeimage/public/assets/fonts/IBM_Plex_Mono/IBMPlexMono-ThinItalic.ttf
new file mode 100644
index 000000000..85292757e
Binary files /dev/null and b/apps/codeimage/public/assets/fonts/IBM_Plex_Mono/IBMPlexMono-ThinItalic.ttf differ
diff --git a/apps/codeimage/public/assets/fonts/IBM_Plex_Mono/OFL.txt b/apps/codeimage/public/assets/fonts/IBM_Plex_Mono/OFL.txt
new file mode 100644
index 000000000..e423b7478
--- /dev/null
+++ b/apps/codeimage/public/assets/fonts/IBM_Plex_Mono/OFL.txt
@@ -0,0 +1,93 @@
+Copyright © 2017 IBM Corp. with Reserved Font Name "Plex"
+
+This Font Software is licensed under the SIL Open Font License, Version 1.1.
+This license is copied below, and is also available with a FAQ at:
+https://openfontlicense.org
+
+
+-----------------------------------------------------------
+SIL OPEN FONT LICENSE Version 1.1 - 26 February 2007
+-----------------------------------------------------------
+
+PREAMBLE
+The goals of the Open Font License (OFL) are to stimulate worldwide
+development of collaborative font projects, to support the font creation
+efforts of academic and linguistic communities, and to provide a free and
+open framework in which fonts may be shared and improved in partnership
+with others.
+
+The OFL allows the licensed fonts to be used, studied, modified and
+redistributed freely as long as they are not sold by themselves. The
+fonts, including any derivative works, can be bundled, embedded,
+redistributed and/or sold with any software provided that any reserved
+names are not used by derivative works. The fonts and derivatives,
+however, cannot be released under any other type of license. The
+requirement for fonts to remain under this license does not apply
+to any document created using the fonts or their derivatives.
+
+DEFINITIONS
+"Font Software" refers to the set of files released by the Copyright
+Holder(s) under this license and clearly marked as such. This may
+include source files, build scripts and documentation.
+
+"Reserved Font Name" refers to any names specified as such after the
+copyright statement(s).
+
+"Original Version" refers to the collection of Font Software components as
+distributed by the Copyright Holder(s).
+
+"Modified Version" refers to any derivative made by adding to, deleting,
+or substituting -- in part or in whole -- any of the components of the
+Original Version, by changing formats or by porting the Font Software to a
+new environment.
+
+"Author" refers to any designer, engineer, programmer, technical
+writer or other person who contributed to the Font Software.
+
+PERMISSION & CONDITIONS
+Permission is hereby granted, free of charge, to any person obtaining
+a copy of the Font Software, to use, study, copy, merge, embed, modify,
+redistribute, and sell modified and unmodified copies of the Font
+Software, subject to the following conditions:
+
+1) Neither the Font Software nor any of its individual components,
+in Original or Modified Versions, may be sold by itself.
+
+2) Original or Modified Versions of the Font Software may be bundled,
+redistributed and/or sold with any software, provided that each copy
+contains the above copyright notice and this license. These can be
+included either as stand-alone text files, human-readable headers or
+in the appropriate machine-readable metadata fields within text or
+binary files as long as those fields can be easily viewed by the user.
+
+3) No Modified Version of the Font Software may use the Reserved Font
+Name(s) unless explicit written permission is granted by the corresponding
+Copyright Holder. This restriction only applies to the primary font name as
+presented to the users.
+
+4) The name(s) of the Copyright Holder(s) or the Author(s) of the Font
+Software shall not be used to promote, endorse or advertise any
+Modified Version, except to acknowledge the contribution(s) of the
+Copyright Holder(s) and the Author(s) or with their explicit written
+permission.
+
+5) The Font Software, modified or unmodified, in part or in whole,
+must be distributed entirely under this license, and must not be
+distributed under any other license. The requirement for fonts to
+remain under this license does not apply to any document created
+using the Font Software.
+
+TERMINATION
+This license becomes null and void if any of the above conditions are
+not met.
+
+DISCLAIMER
+THE FONT SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
+EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO ANY WARRANTIES OF
+MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT
+OF COPYRIGHT, PATENT, TRADEMARK, OR OTHER RIGHT. IN NO EVENT SHALL THE
+COPYRIGHT HOLDER BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,
+INCLUDING ANY GENERAL, SPECIAL, INDIRECT, INCIDENTAL, OR CONSEQUENTIAL
+DAMAGES, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
+FROM, OUT OF THE USE OR INABILITY TO USE THE FONT SOFTWARE OR FROM
+OTHER DEALINGS IN THE FONT SOFTWARE.
diff --git a/apps/codeimage/public/assets/fonts/agave/Agave-Regular.ttf b/apps/codeimage/public/assets/fonts/agave/Agave-Regular.ttf
new file mode 100644
index 000000000..c5135c6d8
Binary files /dev/null and b/apps/codeimage/public/assets/fonts/agave/Agave-Regular.ttf differ
diff --git a/apps/codeimage/public/assets/fonts/geist_mono/GeistMono[wght].ttf b/apps/codeimage/public/assets/fonts/geist_mono/GeistMono[wght].ttf
new file mode 100644
index 000000000..5ea4e68f3
Binary files /dev/null and b/apps/codeimage/public/assets/fonts/geist_mono/GeistMono[wght].ttf differ
diff --git a/apps/codeimage/public/assets/fonts/monaspace/MonaspaceArgonVarVF[wght,wdth,slnt].ttf b/apps/codeimage/public/assets/fonts/monaspace/MonaspaceArgonVarVF[wght,wdth,slnt].ttf
new file mode 100644
index 000000000..ee7afa1ca
Binary files /dev/null and b/apps/codeimage/public/assets/fonts/monaspace/MonaspaceArgonVarVF[wght,wdth,slnt].ttf differ
diff --git a/apps/codeimage/public/assets/fonts/monaspace/MonaspaceKryptonVarVF[wght,wdth,slnt].ttf b/apps/codeimage/public/assets/fonts/monaspace/MonaspaceKryptonVarVF[wght,wdth,slnt].ttf
new file mode 100644
index 000000000..ae3c05624
Binary files /dev/null and b/apps/codeimage/public/assets/fonts/monaspace/MonaspaceKryptonVarVF[wght,wdth,slnt].ttf differ
diff --git a/apps/codeimage/public/assets/fonts/monaspace/MonaspaceNeonVarVF[wght,wdth,slnt].ttf b/apps/codeimage/public/assets/fonts/monaspace/MonaspaceNeonVarVF[wght,wdth,slnt].ttf
new file mode 100644
index 000000000..dfacca37e
Binary files /dev/null and b/apps/codeimage/public/assets/fonts/monaspace/MonaspaceNeonVarVF[wght,wdth,slnt].ttf differ
diff --git a/apps/codeimage/public/assets/fonts/monaspace/MonaspaceRadonVarVF[wght,wdth,slnt].ttf b/apps/codeimage/public/assets/fonts/monaspace/MonaspaceRadonVarVF[wght,wdth,slnt].ttf
new file mode 100644
index 000000000..a7d9ce368
Binary files /dev/null and b/apps/codeimage/public/assets/fonts/monaspace/MonaspaceRadonVarVF[wght,wdth,slnt].ttf differ
diff --git a/apps/codeimage/public/assets/fonts/monaspace/MonaspaceXenonVarVF[wght,wdth,slnt].ttf b/apps/codeimage/public/assets/fonts/monaspace/MonaspaceXenonVarVF[wght,wdth,slnt].ttf
new file mode 100644
index 000000000..f4c7cd5ef
Binary files /dev/null and b/apps/codeimage/public/assets/fonts/monaspace/MonaspaceXenonVarVF[wght,wdth,slnt].ttf differ
diff --git a/apps/codeimage/src/core/configuration/font.ts b/apps/codeimage/src/core/configuration/font.ts
index 6d45a7cbe..1609ba086 100644
--- a/apps/codeimage/src/core/configuration/font.ts
+++ b/apps/codeimage/src/core/configuration/font.ts
@@ -45,6 +45,15 @@ export const [SUPPORTED_FONTS, SUPPORTED_FONTS_DICTIONARY] = createCustomFonts([
{name: 'Bold', weight: 700},
],
},
+ {
+ id: 'geist-mono',
+ name: 'Geist Mono',
+ type: 'web',
+ types: [
+ {name: 'Regular', weight: 400},
+ {name: 'Bold', weight: 700},
+ ],
+ },
{
id: 'fira-code',
name: 'Fira Code',
@@ -55,6 +64,16 @@ export const [SUPPORTED_FONTS, SUPPORTED_FONTS_DICTIONARY] = createCustomFonts([
{name: 'Bold', weight: 700},
],
},
+ {
+ id: 'ibm-plex-mono',
+ name: 'IBM Plex Mono',
+ type: 'web',
+ types: [
+ {name: 'Regular', weight: 400},
+ {name: 'SemiBold', weight: 500},
+ {name: 'Bold', weight: 700},
+ ],
+ },
{
id: 'source-code-pro',
name: 'Source Code pro',
diff --git a/apps/codeimage/src/state/editor/config.store.ts b/apps/codeimage/src/state/editor/config.store.ts
index eb1800484..8ba5daa70 100644
--- a/apps/codeimage/src/state/editor/config.store.ts
+++ b/apps/codeimage/src/state/editor/config.store.ts
@@ -40,6 +40,7 @@ export const EditorConfigStore = defineStore(() => getDefaultConfig())
_.idb.hydrateOnInit().then(() => {
runWithOwner(owner, () => {
_.set('ready', true);
+ _.set('fonts', [...SUPPORTED_FONTS]);
createEffect(
on(
_,
diff --git a/apps/codeimage/src/theme/global.css.ts b/apps/codeimage/src/theme/global.css.ts
index 3fdd8004f..33619023a 100644
--- a/apps/codeimage/src/theme/global.css.ts
+++ b/apps/codeimage/src/theme/global.css.ts
@@ -1,5 +1,5 @@
import {themeVars} from '@codeimage/ui';
-import {globalStyle} from '@vanilla-extract/css';
+import {globalFontFace, globalStyle} from '@vanilla-extract/css';
globalStyle('body', {
fontFamily: 'Inter, system-ui, -apple-system, sans-serif',
@@ -46,3 +46,25 @@ globalStyle('::-webkit-scrollbar-thumb', {
globalStyle('::-webkit-scrollbar-thumb:hover', {
backgroundColor: themeVars.dynamicColors.scrollBar.hoverBackgroundColor,
});
+
+globalFontFace('Geist Mono', {
+ fontDisplay: 'swap',
+ fontWeight: '400 700',
+ fontStyle: 'normal',
+ src: "url(/assets/fonts/geist_mono/GeistMono[wght].ttf) format('truetype')",
+});
+
+(
+ [
+ ['Regular', 400],
+ ['SemiBold', 500],
+ ['Bold', 600],
+ ] as const
+).forEach(([font, weight]) => {
+ globalFontFace('IBM Plex Mono', {
+ fontDisplay: 'swap',
+ fontWeight: weight,
+ fontStyle: 'normal',
+ src: `url(/assets/fonts/IBM_Plex_Mono/IBMPlexMono-${font}.ttf) format('truetype')`,
+ });
+});