matt HOFFNER commited on
Commit
36355a5
β€’
1 Parent(s): a942b58
package-lock.json CHANGED
@@ -15,8 +15,6 @@
15
  "@types/react": "18.2.6",
16
  "@types/react-dom": "18.2.4",
17
  "@xenova/transformers": "^2.1.1",
18
- "chromadb": "^1.5.2",
19
- "cohere-ai": "^5.1.0",
20
  "dexie": "^3.2.4",
21
  "eslint": "8.40.0",
22
  "eslint-config-next": "13.4.2",
@@ -1691,6 +1689,20 @@
1691
  "url": "https://github.com/chalk/ansi-styles?sponsor=1"
1692
  }
1693
  },
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1694
  "node_modules/aproba": {
1695
  "version": "2.0.0",
1696
  "resolved": "https://registry.npmjs.org/aproba/-/aproba-2.0.0.tgz",
@@ -2207,6 +2219,47 @@
2207
  "url": "https://github.com/chalk/chalk?sponsor=1"
2208
  }
2209
  },
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
2210
  "node_modules/chownr": {
2211
  "version": "1.1.4",
2212
  "resolved": "https://registry.npmjs.org/chownr/-/chownr-1.1.4.tgz",
@@ -2215,7 +2268,9 @@
2215
  "node_modules/chromadb": {
2216
  "version": "1.5.2",
2217
  "resolved": "https://registry.npmjs.org/chromadb/-/chromadb-1.5.2.tgz",
2218
- "integrity": "sha512-x/rOD7Oo1RiYA+vPK+Ma7CliCHlx26OjUt5J7Z9HZ5Ud1qDrPlvctBycK9Il3zqza96yeUoPQ7gCXHVKNoyvRQ=="
 
 
2219
  },
2220
  "node_modules/client-only": {
2221
  "version": "0.0.1",
@@ -2225,7 +2280,9 @@
2225
  "node_modules/cohere-ai": {
2226
  "version": "5.1.0",
2227
  "resolved": "https://registry.npmjs.org/cohere-ai/-/cohere-ai-5.1.0.tgz",
2228
- "integrity": "sha512-7q3z3w6GSoPxQqRL9G6QTaQ0e513auVE1JlNDnqnoFEXGtDbkVfaTOliR5qrMoK//74Csb0NW669evqngwPx3g=="
 
 
2229
  },
2230
  "node_modules/color": {
2231
  "version": "4.2.3",
@@ -3875,6 +3932,13 @@
3875
  "node": ">= 4"
3876
  }
3877
  },
 
 
 
 
 
 
 
3878
  "node_modules/import-fresh": {
3879
  "version": "3.3.0",
3880
  "resolved": "https://registry.npmjs.org/import-fresh/-/import-fresh-3.3.0.tgz",
@@ -3979,6 +4043,19 @@
3979
  "url": "https://github.com/sponsors/ljharb"
3980
  }
3981
  },
 
 
 
 
 
 
 
 
 
 
 
 
 
3982
  "node_modules/is-boolean-object": {
3983
  "version": "1.1.2",
3984
  "resolved": "https://registry.npmjs.org/is-boolean-object/-/is-boolean-object-1.1.2.tgz",
@@ -5075,6 +5152,16 @@
5075
  "node": ">=6"
5076
  }
5077
  },
 
 
 
 
 
 
 
 
 
 
5078
  "node_modules/normalize-range": {
5079
  "version": "0.1.2",
5080
  "resolved": "https://registry.npmjs.org/normalize-range/-/normalize-range-0.1.2.tgz",
@@ -5818,6 +5905,19 @@
5818
  "node": ">= 6"
5819
  }
5820
  },
 
 
 
 
 
 
 
 
 
 
 
 
 
5821
  "node_modules/regenerator-runtime": {
5822
  "version": "0.13.11",
5823
  "resolved": "https://registry.npmjs.org/regenerator-runtime/-/regenerator-runtime-0.13.11.tgz",
@@ -6129,6 +6229,24 @@
6129
  "url": "https://github.com/sponsors/ljharb"
6130
  }
6131
  },
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
6132
  "node_modules/scheduler": {
6133
  "version": "0.23.0",
6134
  "resolved": "https://registry.npmjs.org/scheduler/-/scheduler-0.23.0.tgz",
 
15
  "@types/react": "18.2.6",
16
  "@types/react-dom": "18.2.4",
17
  "@xenova/transformers": "^2.1.1",
 
 
18
  "dexie": "^3.2.4",
19
  "eslint": "8.40.0",
20
  "eslint-config-next": "13.4.2",
 
1689
  "url": "https://github.com/chalk/ansi-styles?sponsor=1"
1690
  }
1691
  },
1692
+ "node_modules/anymatch": {
1693
+ "version": "3.1.3",
1694
+ "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-3.1.3.tgz",
1695
+ "integrity": "sha512-KMReFUr0B4t+D+OBkjR3KYqvocp2XaSzO55UcB6mgQMd3KbcE+mWTyvVV7D/zsdEbNnV6acZUutkiHQXvTr1Rw==",
1696
+ "optional": true,
1697
+ "peer": true,
1698
+ "dependencies": {
1699
+ "normalize-path": "^3.0.0",
1700
+ "picomatch": "^2.0.4"
1701
+ },
1702
+ "engines": {
1703
+ "node": ">= 8"
1704
+ }
1705
+ },
1706
  "node_modules/aproba": {
1707
  "version": "2.0.0",
1708
  "resolved": "https://registry.npmjs.org/aproba/-/aproba-2.0.0.tgz",
 
2219
  "url": "https://github.com/chalk/chalk?sponsor=1"
2220
  }
2221
  },
2222
+ "node_modules/chokidar": {
2223
+ "version": "3.5.3",
2224
+ "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-3.5.3.tgz",
2225
+ "integrity": "sha512-Dr3sfKRP6oTcjf2JmUmFJfeVMvXBdegxB0iVQ5eb2V10uFJUCAS8OByZdVAyVb8xXNz3GjjTgj9kLWsZTqE6kw==",
2226
+ "funding": [
2227
+ {
2228
+ "type": "individual",
2229
+ "url": "https://paulmillr.com/funding/"
2230
+ }
2231
+ ],
2232
+ "optional": true,
2233
+ "peer": true,
2234
+ "dependencies": {
2235
+ "anymatch": "~3.1.2",
2236
+ "braces": "~3.0.2",
2237
+ "glob-parent": "~5.1.2",
2238
+ "is-binary-path": "~2.1.0",
2239
+ "is-glob": "~4.0.1",
2240
+ "normalize-path": "~3.0.0",
2241
+ "readdirp": "~3.6.0"
2242
+ },
2243
+ "engines": {
2244
+ "node": ">= 8.10.0"
2245
+ },
2246
+ "optionalDependencies": {
2247
+ "fsevents": "~2.3.2"
2248
+ }
2249
+ },
2250
+ "node_modules/chokidar/node_modules/glob-parent": {
2251
+ "version": "5.1.2",
2252
+ "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz",
2253
+ "integrity": "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==",
2254
+ "optional": true,
2255
+ "peer": true,
2256
+ "dependencies": {
2257
+ "is-glob": "^4.0.1"
2258
+ },
2259
+ "engines": {
2260
+ "node": ">= 6"
2261
+ }
2262
+ },
2263
  "node_modules/chownr": {
2264
  "version": "1.1.4",
2265
  "resolved": "https://registry.npmjs.org/chownr/-/chownr-1.1.4.tgz",
 
2268
  "node_modules/chromadb": {
2269
  "version": "1.5.2",
2270
  "resolved": "https://registry.npmjs.org/chromadb/-/chromadb-1.5.2.tgz",
2271
+ "integrity": "sha512-x/rOD7Oo1RiYA+vPK+Ma7CliCHlx26OjUt5J7Z9HZ5Ud1qDrPlvctBycK9Il3zqza96yeUoPQ7gCXHVKNoyvRQ==",
2272
+ "optional": true,
2273
+ "peer": true
2274
  },
2275
  "node_modules/client-only": {
2276
  "version": "0.0.1",
 
2280
  "node_modules/cohere-ai": {
2281
  "version": "5.1.0",
2282
  "resolved": "https://registry.npmjs.org/cohere-ai/-/cohere-ai-5.1.0.tgz",
2283
+ "integrity": "sha512-7q3z3w6GSoPxQqRL9G6QTaQ0e513auVE1JlNDnqnoFEXGtDbkVfaTOliR5qrMoK//74Csb0NW669evqngwPx3g==",
2284
+ "optional": true,
2285
+ "peer": true
2286
  },
2287
  "node_modules/color": {
2288
  "version": "4.2.3",
 
3932
  "node": ">= 4"
3933
  }
3934
  },
3935
+ "node_modules/immutable": {
3936
+ "version": "4.3.0",
3937
+ "resolved": "https://registry.npmjs.org/immutable/-/immutable-4.3.0.tgz",
3938
+ "integrity": "sha512-0AOCmOip+xgJwEVTQj1EfiDDOkPmuyllDuTuEX+DDXUgapLAsBIfkg3sxCYyCEA8mQqZrrxPUGjcOQ2JS3WLkg==",
3939
+ "optional": true,
3940
+ "peer": true
3941
+ },
3942
  "node_modules/import-fresh": {
3943
  "version": "3.3.0",
3944
  "resolved": "https://registry.npmjs.org/import-fresh/-/import-fresh-3.3.0.tgz",
 
4043
  "url": "https://github.com/sponsors/ljharb"
4044
  }
4045
  },
4046
+ "node_modules/is-binary-path": {
4047
+ "version": "2.1.0",
4048
+ "resolved": "https://registry.npmjs.org/is-binary-path/-/is-binary-path-2.1.0.tgz",
4049
+ "integrity": "sha512-ZMERYes6pDydyuGidse7OsHxtbI7WVeUEozgR/g7rd0xUimYNlvZRE/K2MgZTjWy725IfelLeVcEM97mmtRGXw==",
4050
+ "optional": true,
4051
+ "peer": true,
4052
+ "dependencies": {
4053
+ "binary-extensions": "^2.0.0"
4054
+ },
4055
+ "engines": {
4056
+ "node": ">=8"
4057
+ }
4058
+ },
4059
  "node_modules/is-boolean-object": {
4060
  "version": "1.1.2",
4061
  "resolved": "https://registry.npmjs.org/is-boolean-object/-/is-boolean-object-1.1.2.tgz",
 
5152
  "node": ">=6"
5153
  }
5154
  },
5155
+ "node_modules/normalize-path": {
5156
+ "version": "3.0.0",
5157
+ "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz",
5158
+ "integrity": "sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA==",
5159
+ "optional": true,
5160
+ "peer": true,
5161
+ "engines": {
5162
+ "node": ">=0.10.0"
5163
+ }
5164
+ },
5165
  "node_modules/normalize-range": {
5166
  "version": "0.1.2",
5167
  "resolved": "https://registry.npmjs.org/normalize-range/-/normalize-range-0.1.2.tgz",
 
5905
  "node": ">= 6"
5906
  }
5907
  },
5908
+ "node_modules/readdirp": {
5909
+ "version": "3.6.0",
5910
+ "resolved": "https://registry.npmjs.org/readdirp/-/readdirp-3.6.0.tgz",
5911
+ "integrity": "sha512-hOS089on8RduqdbhvQ5Z37A0ESjsqz6qnRcffsMU3495FuTdqSm+7bhJ29JvIOsBDEEnan5DPu9t3To9VRlMzA==",
5912
+ "optional": true,
5913
+ "peer": true,
5914
+ "dependencies": {
5915
+ "picomatch": "^2.2.1"
5916
+ },
5917
+ "engines": {
5918
+ "node": ">=8.10.0"
5919
+ }
5920
+ },
5921
  "node_modules/regenerator-runtime": {
5922
  "version": "0.13.11",
5923
  "resolved": "https://registry.npmjs.org/regenerator-runtime/-/regenerator-runtime-0.13.11.tgz",
 
6229
  "url": "https://github.com/sponsors/ljharb"
6230
  }
6231
  },
6232
+ "node_modules/sass": {
6233
+ "version": "1.63.3",
6234
+ "resolved": "https://registry.npmjs.org/sass/-/sass-1.63.3.tgz",
6235
+ "integrity": "sha512-ySdXN+DVpfwq49jG1+hmtDslYqpS7SkOR5GpF6o2bmb1RL/xS+wvPmegMvMywyfsmAV6p7TgwXYGrCZIFFbAHg==",
6236
+ "optional": true,
6237
+ "peer": true,
6238
+ "dependencies": {
6239
+ "chokidar": ">=3.0.0 <4.0.0",
6240
+ "immutable": "^4.0.0",
6241
+ "source-map-js": ">=0.6.2 <2.0.0"
6242
+ },
6243
+ "bin": {
6244
+ "sass": "sass.js"
6245
+ },
6246
+ "engines": {
6247
+ "node": ">=14.0.0"
6248
+ }
6249
+ },
6250
  "node_modules/scheduler": {
6251
  "version": "0.23.0",
6252
  "resolved": "https://registry.npmjs.org/scheduler/-/scheduler-0.23.0.tgz",
src/components/ChatWindow.jsx CHANGED
@@ -6,7 +6,8 @@ import {FileLoader} from './FileLoader';
6
  import Loader from "./Loader";
7
  import { RecursiveCharacterTextSplitter } from 'langchain/text_splitter';
8
  import { XenovaTransformersEmbeddings } from '../embed/hf';
9
- import { MemoryVectorStore } from "langchain/vectorstores/memory";
 
10
  import {
11
  Button,
12
  TextInput,
@@ -117,7 +118,7 @@ function ChatWindow({
117
  {isReady && (
118
  <div>
119
  <form onSubmit={handleSubmit}>
120
- <div className="flex">
121
  <TextInput
122
  value={userInput}
123
  placeholder="Say something..."
@@ -135,15 +136,15 @@ function ChatWindow({
135
  </div>
136
 
137
  <div className="flex justify-start m-2">
138
- <div>
139
  <div>
140
  <Button
141
  onClick={handleSubmit}
142
  className="submit"
143
- style={{ height: "65px", width: "65px", float: "right" }}
144
  >
145
  <Image
146
- src=""
147
  alt="Send Message"
148
  style={{
149
  filter:
@@ -170,7 +171,7 @@ function ChatWindow({
170
  marginTop: "2px",
171
  }}
172
  ></div>
173
- </div>
174
  </div>
175
  </div>
176
  )}
 
6
  import Loader from "./Loader";
7
  import { RecursiveCharacterTextSplitter } from 'langchain/text_splitter';
8
  import { XenovaTransformersEmbeddings } from '../embed/hf';
9
+ import { MemoryVectorStore } from "langchain/vectorstores/memory";
10
+
11
  import {
12
  Button,
13
  TextInput,
 
118
  {isReady && (
119
  <div>
120
  <form onSubmit={handleSubmit}>
121
+ <div className="flex" style={{ color: 'white', textarea: { color: 'white' } }}>
122
  <TextInput
123
  value={userInput}
124
  placeholder="Say something..."
 
136
  </div>
137
 
138
  <div className="flex justify-start m-2">
139
+
140
  <div>
141
  <Button
142
  onClick={handleSubmit}
143
  className="submit"
144
+ style={{ backgroundColor: "black", height: "65px", width: "65px", float: "right" }}
145
  >
146
  <Image
147
+ src=""
148
  alt="Send Message"
149
  style={{
150
  filter:
 
171
  marginTop: "2px",
172
  }}
173
  ></div>
174
+
175
  </div>
176
  </div>
177
  )}
src/components/Loader.jsx CHANGED
@@ -25,37 +25,24 @@ const Loader = () => {
25
  <div
26
  style={{
27
  display: "flex",
28
- alignItems: "center",
29
  flexDirection: "column",
30
  gap: "10px",
31
  fontSize: "24px",
32
- textAlign: "center",
33
- fontFamily: "\"Comic Sans MS\", cursive, sans-serif;"
34
  }}
35
  >
36
- <div className="lg:hidden">
37
- <h1 className="p-1">
38
- <b>πŸ’Ž web-llm-embed πŸ“„</b>
39
  </h1>
40
- <p className="p-1">
41
- Proof of concept using Transformers.js embeddings in a WebGPU powered LLM chat.
42
- </p>
43
- <p className="p-1">
44
- No data is sent to the server. Conversations are cached in local
45
- storage.
46
- </p>
47
- <p className="p-1">
48
- WebGPU is only supported in Desktop Google Chrome 113
49
- </p>
50
- <p className="p-1">
51
- Powered by Apache TVM and MLC Relax Runtime.
52
- </p>
53
- <p className="p-1">
54
- Model is Vicuna 7b trained by LMSys.
55
- </p>
56
  </div>
57
  <div>
58
- This will download the model (~4GB) and may take a few minutes. After the
59
  first time, it will be cached.
60
  </div>
61
 
 
25
  <div
26
  style={{
27
  display: "flex",
28
+ alignItems: "left",
29
  flexDirection: "column",
30
  gap: "10px",
31
  fontSize: "24px",
32
+ textAlign: "left",
33
+ fontFamily: "Arial"
34
  }}
35
  >
36
+ <div>
37
+ <h1 className="p-1">
38
+ <b>web-llm-embed</b>
39
  </h1>
40
+ <div>
41
+ πŸ’Ž Edge based document chat. No data is sent to the server. Model is Vicuna 7b trained by LMSys.
42
+ </div>
 
 
 
 
 
 
 
 
 
 
 
 
 
43
  </div>
44
  <div>
45
+ πŸ“„ This will download the model (~4GB) and may take a few minutes. After the
46
  first time, it will be cached.
47
  </div>
48
 
src/components/MessageList.jsx CHANGED
@@ -1,6 +1,5 @@
1
  import useLLM from "@react-llm/headless";
2
  import { useEffect, useRef } from "react";
3
- import { ScrollView } from "react95";
4
 
5
  function MessageList({
6
  screenName = "endlessbox5",
@@ -21,31 +20,33 @@ function MessageList({
21
  }, [conversation, messages.length]);
22
 
23
  return (
24
- <ScrollView style={{ height: "65vh" }} className="w-full">
25
  <div className="p-2 leading-6 w-full min-h-full">
26
  {conversation?.messages.map((m) => (
27
  <div key={m.id} style={{ display: "flex" }}>
28
  <div
29
  style={{
30
- padding: "2px",
31
- borderRadius: "5px",
 
 
32
  }}
33
  >
34
  <span
35
  style={{
36
  fontWeight: "bold",
37
- color: m.role === userRoleName ? "blue" : "red",
38
  }}
39
  >
40
- {m.role === userRoleName ? screenName : assistantScreenName}
41
  </span>
42
- : {m.text}
43
  </div>
44
  </div>
45
  ))}
46
  <div ref={scrollRef}></div>
47
  </div>
48
- </ScrollView>
49
  );
50
  }
51
 
 
1
  import useLLM from "@react-llm/headless";
2
  import { useEffect, useRef } from "react";
 
3
 
4
  function MessageList({
5
  screenName = "endlessbox5",
 
20
  }, [conversation, messages.length]);
21
 
22
  return (
23
+ <div style={{ height: "65vh" }} className="w-full">
24
  <div className="p-2 leading-6 w-full min-h-full">
25
  {conversation?.messages.map((m) => (
26
  <div key={m.id} style={{ display: "flex" }}>
27
  <div
28
  style={{
29
+ padding: "12px",
30
+ margin: "5px",
31
+ borderRadius: "15px",
32
+ backgroundColor: m.role === userRoleName ? "green": "#333333"
33
  }}
34
  >
35
  <span
36
  style={{
37
  fontWeight: "bold",
38
+ color: m.role === userRoleName ? "white" : "#999999",
39
  }}
40
  >
41
+ {m.role === userRoleName ? `` : `${assistantScreenName}: `}
42
  </span>
43
+ {m.text}
44
  </div>
45
  </div>
46
  ))}
47
  <div ref={scrollRef}></div>
48
  </div>
49
+ </div>
50
  );
51
  }
52
 
src/pages/_app.tsx CHANGED
@@ -1,5 +1,6 @@
1
  import Head from "next/head";
2
  import { AppProps } from "next/app";
 
3
 
4
  export interface MyAppProps extends AppProps {
5
  emotionCache?: any;
 
1
  import Head from "next/head";
2
  import { AppProps } from "next/app";
3
+ import '../styles.css'
4
 
5
  export interface MyAppProps extends AppProps {
6
  emotionCache?: any;
src/styles.css ADDED
@@ -0,0 +1,9 @@
 
 
 
 
 
 
 
 
 
 
1
+ body {
2
+ font-family: system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Oxygen, Ubuntu, Cantarell, 'Open Sans', 'Helvetica Neue', sans-serif;
3
+ background-color: black;
4
+ color: white;
5
+ }
6
+
7
+ textarea {
8
+ color: white;
9
+ }