Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Merge staging into main #169

Merged
merged 65 commits into from
Oct 31, 2024
Merged
Show file tree
Hide file tree
Changes from 4 commits
Commits
Show all changes
65 commits
Select commit Hold shift + click to select a range
4a4365e
fix: code syntax highlighting to support all other languages
krushnarout Oct 25, 2024
900ae4a
Merge pull request #133 from krushnarout/fix-syntax-support
bracesproul Oct 25, 2024
d519b00
feat: address PR feedback - use initChatModel and implement configura…
ahmad2b Oct 25, 2024
78c2a26
feat: add @langchain/community for fireworks llm
ahmad2b Oct 25, 2024
a3b3902
Merge branch 'main' of https://github.com/langchain-ai/open-canvas in…
bracesproul Oct 25, 2024
9ff9ae1
cr
bracesproul Oct 25, 2024
0208017
merge staging
bracesproul Oct 25, 2024
8e0488b
cr
bracesproul Oct 25, 2024
ccd9a51
cr
bracesproul Oct 25, 2024
318b00f
cr
bracesproul Oct 25, 2024
6f4014c
Merge pull request #136 from ahmad2b/ahmad2b/customizable-model-selec…
bracesproul Oct 25, 2024
e122e44
Add Gemini 1.5 Flash to model options
mjunaidca Oct 26, 2024
900a3a4
fix: Update support for anthropic everywhere
bracesproul Oct 27, 2024
fbd294c
cr
bracesproul Oct 27, 2024
4279021
cr
bracesproul Oct 27, 2024
9791b32
move to genai
bracesproul Oct 28, 2024
a306ac2
Merge pull request #142 from mjunaidca/mjunaidca/add-gemini-1.5-flash
bracesproul Oct 28, 2024
f829417
Merge branch 'staging' into brace/use-anthropic
bracesproul Oct 28, 2024
8c4de3d
bump deps
bracesproul Oct 28, 2024
f06653b
cr
bracesproul Oct 28, 2024
61516bc
Merge pull request #145 from langchain-ai/brace/use-anthropic
bracesproul Oct 28, 2024
134e430
fix: Customize model for all requests
bracesproul Oct 28, 2024
8fb8408
cr
bracesproul Oct 28, 2024
51b3514
feat: Update font to match LangSmith
bracesproul Oct 28, 2024
614ceb4
Merge branch 'main' of https://github.com/langchain-ai/open-canvas in…
bracesproul Oct 28, 2024
2807fff
Merge branch 'staging' of https://github.com/langchain-ai/open-canvas…
bracesproul Oct 28, 2024
df26000
add tighter text
bracesproul Oct 28, 2024
679ec69
cr
bracesproul Oct 28, 2024
d9e935a
Merge pull request #156 from langchain-ai/brace/update-font
bracesproul Oct 28, 2024
c18478d
merge staging
bracesproul Oct 28, 2024
a5e1765
cr
bracesproul Oct 28, 2024
c11e50d
Merge pull request #146 from langchain-ai/brace/fix-custom-model
bracesproul Oct 28, 2024
717dba7
chore: Cleanups
bracesproul Oct 29, 2024
354c235
cleanup prop passing
bracesproul Oct 29, 2024
ceec3bc
feat: add chat feedback with thumbs up/down buttons
ahmad2b Oct 29, 2024
24bd4a8
feat: Add chat feedback only on last AI message
ahmad2b Oct 29, 2024
8904702
move components
bracesproul Oct 29, 2024
7779dd9
feat: add raw markdown view for text
listlessbird Oct 29, 2024
dad45e4
cr
bracesproul Oct 29, 2024
5d443da
Merge pull request #159 from langchain-ai/brace/cleanup-jsx
bracesproul Oct 29, 2024
e8d8e40
merge staging
bracesproul Oct 29, 2024
fed56dd
format/lint
bracesproul Oct 29, 2024
e8796d8
cr
bracesproul Oct 29, 2024
68c6f4b
Merge pull request #161 from ahmad2b/ahmad2b/add-chat-feedback
bracesproul Oct 29, 2024
4d354da
merge staging
bracesproul Oct 29, 2024
37732eb
format
bracesproul Oct 29, 2024
9f5dc01
make editable
bracesproul Oct 30, 2024
2b04198
Merge pull request #162 from listlessbird/raw-md-text
bracesproul Oct 30, 2024
099b192
fix: Set new chat true before api call returns
bracesproul Oct 30, 2024
e6303d2
Merge pull request #163 from langchain-ai/brace/reset-before-api-call
bracesproul Oct 30, 2024
8a36f43
feat: add the subgraph for generating chat titles in the background
ahmad2b Oct 30, 2024
9f941e9
feat: Add models section in readme
bracesproul Oct 30, 2024
c89f8df
Merge pull request #166 from langchain-ai/brace/models-readme-section
bracesproul Oct 30, 2024
ef620c8
cr
bracesproul Oct 30, 2024
781ec9b
cr
bracesproul Oct 30, 2024
b62c8eb
cr
bracesproul Oct 30, 2024
7a1ecb9
merge staging
bracesproul Oct 30, 2024
ebd224c
cr
bracesproul Oct 30, 2024
b325a05
Merge pull request #165 from ahmad2b/ahmad2b/background-job-chat-titles
bracesproul Oct 30, 2024
da70508
chore: Drop Llama 405b from models
bracesproul Oct 30, 2024
69967a2
Merge pull request #167 from langchain-ai/brace/remove-405b
bracesproul Oct 30, 2024
2bd7d9c
feat: Add customize model alert
bracesproul Oct 30, 2024
dfe7cbb
fade out
bracesproul Oct 30, 2024
525fabe
cr
bracesproul Oct 30, 2024
d0d6346
Merge pull request #168 from langchain-ai/brace/customize-model-alert
bracesproul Oct 30, 2024
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
5 changes: 5 additions & 0 deletions package.json
Original file line number Diff line number Diff line change
Expand Up @@ -24,15 +24,19 @@
"@codemirror/lang-html": "^6.4.9",
"@codemirror/lang-java": "^6.0.1",
"@codemirror/lang-javascript": "^6.2.2",
"@codemirror/lang-json": "^6.0.1",
"@codemirror/lang-php": "^6.0.1",
"@codemirror/lang-python": "^6.1.6",
"@codemirror/lang-rust": "^6.0.1",
"@codemirror/lang-sql": "^6.8.0",
"@codemirror/lang-xml": "^6.1.0",
"@langchain/anthropic": "^0.3.5",
"@langchain/community": "^0.3.9",
"@langchain/core": "^0.3.14",
"@langchain/langgraph": "^0.2.18",
"@langchain/langgraph-sdk": "^0.0.17",
"@langchain/openai": "^0.3.11",
"@nextjournal/lang-clojure": "^1.0.0",
"@radix-ui/react-avatar": "^1.1.0",
"@radix-ui/react-checkbox": "^1.1.2",
"@radix-ui/react-dialog": "^1.1.2",
Expand All @@ -46,6 +50,7 @@
"@radix-ui/react-slot": "^1.1.0",
"@radix-ui/react-toast": "^1.2.1",
"@radix-ui/react-tooltip": "^1.1.2",
"@replit/codemirror-lang-csharp": "^6.2.0",
"@supabase/ssr": "^0.5.1",
"@supabase/supabase-js": "^2.45.5",
"@types/react-syntax-highlighter": "^15.5.13",
Expand Down
61 changes: 41 additions & 20 deletions src/components/artifacts/CodeRenderer.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -6,10 +6,15 @@ import { cpp } from "@codemirror/lang-cpp";
import { java } from "@codemirror/lang-java";
import { php } from "@codemirror/lang-php";
import { python } from "@codemirror/lang-python";
import styles from "./CodeRenderer.module.css";
import { cleanContent } from "@/lib/normalize_string";
import { html } from "@codemirror/lang-html";
import { sql } from "@codemirror/lang-sql";
import { json } from "@codemirror/lang-json";
import { rust } from "@codemirror/lang-rust";
import { xml } from "@codemirror/lang-xml";
import { clojure } from "@nextjournal/lang-clojure";
import { csharp } from "@replit/codemirror-lang-csharp";
import styles from "./CodeRenderer.module.css";
import { cleanContent } from "@/lib/normalize_string";
import { cn } from "@/lib/utils";

export interface CodeRendererProps {
Expand All @@ -22,25 +27,41 @@ export interface CodeRendererProps {
setUpdateRenderedArtifactRequired: Dispatch<SetStateAction<boolean>>;
}

export function CodeRenderer(props: Readonly<CodeRendererProps>) {
let extensions: any[] = [];
if (props.artifactContent.language === "javascript") {
extensions = [javascript({ jsx: true, typescript: false })];
} else if (props.artifactContent.language === "typescript") {
extensions = [javascript({ jsx: true, typescript: true })];
} else if (props.artifactContent.language === "cpp") {
extensions = [cpp()];
} else if (props.artifactContent.language === "java") {
extensions = [java()];
} else if (props.artifactContent.language === "php") {
extensions = [php()];
} else if (props.artifactContent.language === "python") {
extensions = [python()];
} else if (props.artifactContent.language === "html") {
extensions = [html()];
} else if (props.artifactContent.language === "sql") {
extensions = [sql()];
const getLanguageExtension = (language: string) => {
switch (language) {
case "javascript":
return javascript({ jsx: true, typescript: false });
case "typescript":
return javascript({ jsx: true, typescript: true });
case "cpp":
return cpp();
case "java":
return java();
case "php":
return php();
case "python":
return python();
case "html":
return html();
case "sql":
return sql();
case "json":
return json();
case "rust":
return rust();
case "xml":
return xml();
case "clojure":
return clojure();
case "csharp":
return csharp();
default:
return [];
}
};

export function CodeRenderer(props: Readonly<CodeRendererProps>) {
const extensions = [getLanguageExtension(props.artifactContent.language)];

useEffect(() => {
if (props.updateRenderedArtifactRequired) {
Expand Down
25 changes: 25 additions & 0 deletions src/types.ts
Original file line number Diff line number Diff line change
Expand Up @@ -95,6 +95,11 @@ export type ProgrammingLanguageOptions =
| "python"
| "html"
| "sql"
| "json"
| "rust"
| "xml"
| "clojure"
| "csharp"
| "other";

export const PROGRAMMING_LANGUAGES: Array<{
Expand Down Expand Up @@ -133,6 +138,26 @@ export const PROGRAMMING_LANGUAGES: Array<{
language: "sql",
label: "SQL",
},
{
language: "json",
label: "JSON",
},
{
language: "rust",
label: "Rust",
},
{
language: "xml",
label: "XML",
},
{
language: "clojure",
label: "Clojure",
},
{
language: "csharp",
label: "C#",
},
{
language: "other",
label: "Other",
Expand Down
75 changes: 75 additions & 0 deletions yarn.lock
Original file line number Diff line number Diff line change
Expand Up @@ -263,6 +263,14 @@
"@lezer/common" "^1.0.0"
"@lezer/javascript" "^1.0.0"

"@codemirror/lang-json@^6.0.1":
version "6.0.1"
resolved "https://registry.yarnpkg.com/@codemirror/lang-json/-/lang-json-6.0.1.tgz#0a0be701a5619c4b0f8991f9b5e95fe33f462330"
integrity sha512-+T1flHdgpqDDlJZ2Lkil/rLiRy684WMLc74xUnjJH48GQdfJo/pudlTRreZmKwzP8/tGdKf83wlbAdOCzlJOGQ==
dependencies:
"@codemirror/language" "^6.0.0"
"@lezer/json" "^1.0.0"

"@codemirror/lang-php@^6.0.1":
version "6.0.1"
resolved "https://registry.yarnpkg.com/@codemirror/lang-php/-/lang-php-6.0.1.tgz#fa34cc75562178325861a5731f79bd621f57ffaa"
Expand All @@ -285,6 +293,14 @@
"@lezer/common" "^1.2.1"
"@lezer/python" "^1.1.4"

"@codemirror/lang-rust@^6.0.1":
version "6.0.1"
resolved "https://registry.yarnpkg.com/@codemirror/lang-rust/-/lang-rust-6.0.1.tgz#d6829fc7baa39a15bcd174a41a9e0a1bf7cf6ba8"
integrity sha512-344EMWFBzWArHWdZn/NcgkwMvZIWUR1GEBdwG8FEp++6o6vT6KL9V7vGs2ONsKxxFUPXKI0SPcWhyYyl2zPYxQ==
dependencies:
"@codemirror/language" "^6.0.0"
"@lezer/rust" "^1.0.0"

"@codemirror/lang-sql@^6.8.0":
version "6.8.0"
resolved "https://registry.yarnpkg.com/@codemirror/lang-sql/-/lang-sql-6.8.0.tgz#1ae68ad49f378605ff88a4cc428ba667ce056068"
Expand All @@ -297,6 +313,18 @@
"@lezer/highlight" "^1.0.0"
"@lezer/lr" "^1.0.0"

"@codemirror/lang-xml@^6.1.0":
version "6.1.0"
resolved "https://registry.yarnpkg.com/@codemirror/lang-xml/-/lang-xml-6.1.0.tgz#e3e786e1a89fdc9520efe75c1d6d3de1c40eb91c"
integrity sha512-3z0blhicHLfwi2UgkZYRPioSgVTo9PV5GP5ducFH6FaHy0IAJRg+ixj5gTR1gnT/glAIC8xv4w2VL1LoZfs+Jg==
dependencies:
"@codemirror/autocomplete" "^6.0.0"
"@codemirror/language" "^6.4.0"
"@codemirror/state" "^6.0.0"
"@codemirror/view" "^6.0.0"
"@lezer/common" "^1.0.0"
"@lezer/xml" "^1.0.0"

"@codemirror/language@^6.0.0", "@codemirror/language@^6.4.0", "@codemirror/language@^6.6.0", "@codemirror/language@^6.8.0":
version "6.10.3"
resolved "https://registry.yarnpkg.com/@codemirror/language/-/language-6.10.3.tgz#eb25fc5ade19032e7bf1dcaa957804e5f1660585"
Expand Down Expand Up @@ -778,6 +806,15 @@
"@lezer/highlight" "^1.1.3"
"@lezer/lr" "^1.3.0"

"@lezer/json@^1.0.0":
version "1.0.2"
resolved "https://registry.yarnpkg.com/@lezer/json/-/json-1.0.2.tgz#bdc849e174113e2d9a569a5e6fb1a27e2f703eaf"
integrity sha512-xHT2P4S5eeCYECyKNPhr4cbEL9tc8w83SPwRC373o9uEdrvGKTZoJVAGxpOsZckMlEh9W23Pc72ew918RWQOBQ==
dependencies:
"@lezer/common" "^1.2.0"
"@lezer/highlight" "^1.0.0"
"@lezer/lr" "^1.0.0"

"@lezer/lr@^1.0.0", "@lezer/lr@^1.1.0", "@lezer/lr@^1.3.0":
version "1.4.2"
resolved "https://registry.yarnpkg.com/@lezer/lr/-/lr-1.4.2.tgz#931ea3dea8e9de84e90781001dae30dea9ff1727"
Expand All @@ -803,6 +840,24 @@
"@lezer/highlight" "^1.0.0"
"@lezer/lr" "^1.0.0"

"@lezer/rust@^1.0.0":
version "1.0.2"
resolved "https://registry.yarnpkg.com/@lezer/rust/-/rust-1.0.2.tgz#cc9a75605d67182a0e799ac40b1965a61dcc6ef0"
integrity sha512-Lz5sIPBdF2FUXcWeCu1//ojFAZqzTQNRga0aYv6dYXqJqPfMdCAI0NzajWUd4Xijj1IKJLtjoXRPMvTKWBcqKg==
dependencies:
"@lezer/common" "^1.2.0"
"@lezer/highlight" "^1.0.0"
"@lezer/lr" "^1.0.0"

"@lezer/xml@^1.0.0":
version "1.0.5"
resolved "https://registry.yarnpkg.com/@lezer/xml/-/xml-1.0.5.tgz#4bb7fd3e527f41b78372477aa753f035b41c3846"
integrity sha512-VFouqOzmUWfIg+tfmpcdV33ewtK+NSwd4ngSe1aG7HFb4BN0ExyY1b8msp+ndFrnlG4V4iC8yXacjFtrwERnaw==
dependencies:
"@lezer/common" "^1.2.0"
"@lezer/highlight" "^1.0.0"
"@lezer/lr" "^1.0.0"

"@mantine/core@^7.10.1":
version "7.13.3"
resolved "https://registry.yarnpkg.com/@mantine/core/-/core-7.13.3.tgz#ad31f00de6d6eb52f0bc2ce1b95f79ac7ab25a67"
Expand Down Expand Up @@ -882,6 +937,21 @@
resolved "https://registry.yarnpkg.com/@next/swc-win32-x64-msvc/-/swc-win32-x64-msvc-14.2.7.tgz#75e1d90758cb10a547e1cdfb878871da28123682"
integrity sha512-pxsI23gKWRt/SPHFkDEsP+w+Nd7gK37Hpv0ngc5HpWy2e7cKx9zR/+Q2ptAUqICNTecAaGWvmhway7pj/JLEWA==

"@nextjournal/lang-clojure@^1.0.0":
version "1.0.0"
resolved "https://registry.yarnpkg.com/@nextjournal/lang-clojure/-/lang-clojure-1.0.0.tgz#0efbd594769e606eea532758519a239f0d38959d"
integrity sha512-gOCV71XrYD0DhwGoPMWZmZ0r92/lIHsqQu9QWdpZYYBwiChNwMO4sbVMP7eTuAqffFB2BTtCSC+1skSH9d3bNg==
dependencies:
"@codemirror/language" "^6.0.0"
"@nextjournal/lezer-clojure" "1.0.0"

"@nextjournal/lezer-clojure@1.0.0":
version "1.0.0"
resolved "https://registry.yarnpkg.com/@nextjournal/lezer-clojure/-/lezer-clojure-1.0.0.tgz#0e7ff75f8d0fabed36d26b9f6b5f00d8a9f385e6"
integrity sha512-VZyuGu4zw5mkTOwQBTaGVNWmsOZAPw5ZRxu1/Knk/Xfs7EDBIogwIs5UXTYkuECX5ZQB8eOB+wKA2pc7VyqaZQ==
dependencies:
"@lezer/lr" "^1.0.0"

"@nodelib/fs.scandir@2.1.5":
version "2.1.5"
resolved "https://registry.yarnpkg.com/@nodelib/fs.scandir/-/fs.scandir-2.1.5.tgz#7619c2eb21b25483f6d167548b4cfd5a7488c3d5"
Expand Down Expand Up @@ -1445,6 +1515,11 @@
resolved "https://registry.yarnpkg.com/@remirror/core-constants/-/core-constants-3.0.0.tgz#96fdb89d25c62e7b6a5d08caf0ce5114370e3b8f"
integrity sha512-42aWfPrimMfDKDi4YegyS7x+/0tlzaqwPQCULLanv3DMIlu96KTJR0fM5isWX2UViOqlGnX6YFgqWepcX+XMNg==

"@replit/codemirror-lang-csharp@^6.2.0":
version "6.2.0"
resolved "https://registry.yarnpkg.com/@replit/codemirror-lang-csharp/-/codemirror-lang-csharp-6.2.0.tgz#bd652f5788ad93579ee0dcab5b163ed2674b974f"
integrity sha512-6utbaWkoymhoAXj051mkRp+VIJlpwUgCX9Toevz3YatiZsz512fw3OVCedXQx+WcR0wb6zVHjChnuxqfCLtFVQ==

"@rtsao/scc@^1.1.0":
version "1.1.0"
resolved "https://registry.yarnpkg.com/@rtsao/scc/-/scc-1.1.0.tgz#927dd2fae9bc3361403ac2c7a00c32ddce9ad7e8"
Expand Down