We're Code & Cork, and together we've created WineWhisperer, an AI powered wine recommendation app that aims to make finding your next favourite wine easy.
- Tailwind CSS
- NextJS 13.4
- MaterialUI
- TypeScript
- JavaScript
- NextAuth.js
- MongoDB
- OpenAI API
- Hosted on Vercel
| .gitignore
| next.config.js
| package.json
| postcss.config.js
| README.md
| tailwind.config.js
| tsconfig.json
|
+---pages
| | 404.js
| | index.tsx # Landing page
| | _app.tsx # App layout
| | _document.tsx # Outer HTML layout, don't edit
| |
| +---api
| | | ai.ts
| | |
| | +---auth
| | | [...nextauth].js
| | |
| | \---wine
| | getsaveWine.ts
| | saveWine.ts
| | unsaveWine.ts
| | [_id].ts # Wine fetching API dependent on Wine ID
| |
| +---main
| | page.tsx # All of the sites pages are in /pages/main
| |
| \---wine
| [_id].tsx # Wine page depending on Wine ID
|
+---public
| images.png # Every image, audio and gif is in /public
|
\---styles
globals.css
- Create a MongoDB account
- Install Studio3T (optional but recommended)
- Create a wine database called 'Wine1' with a collection named 'wset'
- Download the Wine Tasting dataset from Kaggle and fill your wset collection with the contents
- Go to Google Developer Console and obtain the following:
- Client ID API Key
- Secret API Key
- Go to OpenAI's Developer Platform and obtain an API key
- Go to a GUID generator and obtain TWO API keys
- Save one under JWT_SECRET, and the other under SECRET
- Clone the repo with
git clone https://github.com/erictatchell/2800-202310-BBY29
- In the project root, create a .env file with the following structure:
GOOGLE_CLIENT_SECRET=
GOOGLE_CLIENT_ID=
NEXTAUTH_URL=https://2800-202310-bby-29.vercel.app/
SECRET=
JWT_SECRET=
OPENAI_API_KEY=
MONGODB_URI=
MONGODB_HOST=
MONGODB_USER=
MONGODB_PASSWORD=
MONGODB_DATABASE=Wine1
-
Insert your obtained API keys and MongoDB data in the fields and save.
-
Open your terminal and run
npm install
to fetch the latest dependencies.
- On the home page, enter any wine you want in the textbox! We have 3 sample options listed.
- Click Discover to see your recommended options. (and learn a fact about wine!)
- When the wines show up, you can click the arrow to learn more or save them!
This is every single wine in our dataset. You can sort by price and points by clicking the dropdown, or view all eco friendy wines!
- OpenAI API
- MaterialUI icons
- Wine Tasting dataset from MYSAR AHMAD BHAT
- Bordeaux image from WineXpert
- Background video was mashup of this, this and this
- We used GPT 4.0 to aid in the autocompletion of code blocks. We provided logic, it provided a solution. It was tremendously helpful as we were using brand new technologies that none of us have used prior.
- We had kind of struck gold with our Wine Tasting dataset so we didn't need to alter it with AI.
- Our app uses OpenAI's GPT3 text-davinci-003 model to read and analyze the users entered wine preference. On the backend, we provide the model this prompt: 'List 10 DISTINCT wines that best fits this prompt:' with the users prompt filled at the end. GPT3 returns a list of 10 wines in json format, which are then queried against our wine dataset. For every word, it first searches each document's title to find a match. If there's no match, it moves to the description where it does the same thing. Aside from a few random responses from the model, the success rate is almost 100%. The DB then returns 3 of the select 10. Moving forward, we would like to refine this logic and allow the user to customize the amount of options they have.
- We are not able to train GPT3 on our wine dataset. We solved this by adding the DB query in the middle. If we were to train the model, it would cut out the Mongo middleman and provide a faster, more accurate query.