-
Notifications
You must be signed in to change notification settings - Fork 21
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
LLM-Powered Issue Suggestion #365
Comments
@heythisischris expressed early interest in this bounty. Pinging him here. We definitely have to factor in our money in the bank and the fact that this is a speculative feature (a feature no one has directly said they'll pay for) when deciding on the bounty. |
I'm definitely interested in tackling this one. Here's my proposed solution: OverviewWe'll leverage GPT-4o (possibly mini) to create GitHub tickets from individual Equalify issues. This will be exposed both on the frontend and via a developer-facing API endpoint. I'll start with the prompt Blake provided and refine as needed. The resulting link will be a pre-populated GitHub link with a draft of the given issue (you can click to test it out!):
We could even allow developers to link their GitHub account so we officially publish GitHub Issues on behalf of developers. I'd like to take this a step further and incorporate a new "Copilot" tab which allows the user to chat with a specialized Equalify Copilot chat tool which can help developers debug their accessibility fixes, look for insights/trends in their data, set alerts for certain accessibility fixes, etc. I'll create two new tables to store responses from both of these endpoints, I might create a new column inside of I'll also apply for $25,000 of Azure credit via the Microsoft for Startups program which will effectively give us $25,000 of OpenAI credit using their Azure OpenAI service (1 year expiry). Steps
Request body: {
"codeSnippet": "<textarea name=\"input_4\" id=\"input_7_4\" class=\"textarea large\" aria-describedby=\"gfield_description_7_4\" aria-required=\"true\" aria-invalid=\"false\" rows=\"10\" cols=\"50\"></textarea>",
"url": "https://equalify.app/",
"repository": "https://github.com/EqualifyEverything/equalify",
"author": "heythisischris",
"labels": ["accessibility"],
"template": "## Overview\nThis is the overview\n\n## Tasks\nThese are the tasks required to fix the issue\n\n##Timeline\nThis issue will be fixed in 1 week."
} Request response: {
"url": "https://github.com/equalifyeverything/equalify/issues/new?title=test&assignee=&body=This%20is%20a%20new%20issue&labels[]=accessibility"
} Responses will be stored inside of
Request body: [
{ "user": "What is the most common accessibility issue identified?" }
] Request response: [
{ "user": "What is the most common accessibility issue identified?" },
{ "system": "The most common issue I found was \"Element's background color could not be determined because it's partially obscured by another element\"" }
] Responses will be stored inside of BudgetThe requested bounty is This comes out to an effective rate of TimelineI intend to have this completed and ready for by |
Thanks @heythisischris! We'll probably discuss this on our July 29 contributor call. I want to make sure we focus on getting Version 1 up before we start adding features. |
@heythisischris I read this on my phone, which is probably why the code looks gnarly listening to it with voiceover. Lol. Where does accessibility fall into this? I would love to discuss with you before too long. |
@heythisischris what is the date of delivery for this? I'll create a milestone and add reminders for myself to check in on it. We can organize a mini release around this feature. |
I actually have an NVIDIA developer account, so let me talk with Kaju and see if we're interested in putting a bid in on this |
@bbertucc Normally I would say delivery date is pushed back a week, but I think I can stretch and get this done by Friday, August 9th, 2024 (if not sooner). The goal would be to create a simple and pragmatic solution using conventional LLM services and a basic web UI to accompany it. And @kevinandrews1, we could even pave some space in building an accessible AI chatbot interface. But I am curious about @BaronWolfenstein's potential proposal- I'm assuming it would involve training/using a custom model. |
I'm gonna go to Scale tomorrow and work on putting a proposal up. I'm happy to talk with you more about it @heythisischris, I did send Blake some details on what constitutes the NVIDIA program. |
@heythisischris that's an amazingly ambitious goal. Love it. I also want this to a feature we announce on it's own. So could we roll it out next week instead? This week we're already announcing the launch of the app. Next week, we can announce the LLM. Say, next Wednesday at 11:11 CST? I'll formally bless this feature and push the cash deposit as soon as these are done:
...which is basically to say #335 is done. Very curious to hear from @BaronWolfenstein on his proposal tool. There's always room to expand on LLM features. @BaronWolfenstein please share any documents here. I'm a man of Open Source and quickly forget anything DMed to me. |
@heythisischris I went ahead and assigned this to you, adding a milestone for next week delivery. |
@BaronWolfenstein if you don't mind, add your proposal to a new issue here: #391 |
This is approved for delivery september 2. |
@heythisischris I initiated the initial 50% payment on this one. |
@heythisischris said he'll have this by October 4 on our call today. |
@heythisischris Can we discuss this week? Would love to hear how a11y factors in on the front end and how I can support the feature's rollout. Feel free to grab a time https://calendly.com/kevinjandrews |
@kevinandrews1 I went ahead and booked some time for tomorrow to showcase and discuss the Equalify LLM implementation so far. Definitely want your feedback and to wrap this up as soon as possible! |
@kevinandrews1 Here are some quick instructions for testing out the current LLM feature:
|
@bbertucc If I go to the Equalify report under your account I get a 404. Out of scope for this but I noticed it and wanted to flag. @heythisischris, please see the video I created for context:
|
@kevinandrews1 will turn his comment into an issue or two. |
As per our conversation on 12/2, once @kevinandrews1 posts accessibility issues and @heythisischris addresses them, we'll push to production. When this issue is in production, we can mark this issue done and pay the second part of the amount. |
@bbertucc and @heythisischris, done. Please see the following issues: |
@bbertucc @kevinandrews1 All of these accessibility issues are taken care of! Here are the related commits for each:
Thanks again for the thorough testing and video @kevinandrews1, it was super helpful for debugging. I went ahead and redeployed to https://equalify.dev so you can test again and validate that the changes work! |
Update 12/16: The only thing left is to pretty the button and output. |
Added #510 - we'll need to do that before pushing to production. |
@heythisischris I just paid you payment 2 of 2. Still expecting a little bit of style cleanup, but wanted to get the payment to ya before holiday break. |
@bbertucc Got it, thank you! I'll make sure to have this cleaned up. |
Overview
This bountied issue is for the development of our LLM feature.
We've been discussing an LLM integration for a while. I've even created two ChatGPT GPTs to test out ideas. Now, I'm hoping we can deliver our LLM feature to production.
Feature Ideas
The most useful integration with LLMs is to create GitHub tickets from Equalify content. I've been testing creating issues from a single node source and creating issues from a single message with lots of nodes.
Issue from a Single Equalify Node Data
I imagine we could create a new "Actions" column and a button that says "Suggest Issue" in that column of each node list. Example:
Here's an example of an issue I created from a single node in Equalify: WordPress/wporg-mu-plugins#622
Here is the conversation I had to create that issue: https://chatgpt.com/share/174d5f0b-0feb-46da-a850-9dc5cb7eb97b
Here is the prompt behind the ChatGPT GPT I created:
Issue from a Single Equalify Message with Multiple Nodes
I imagine we could create a button on the top of a Message detail page that generates issue text. Here is a screenshot example:
Here's an example of an issue I created from a single node in Equalify: WordPress/wporg-mu-plugins#622
Here is the conversation I had to create that issue: https://chatgpt.com/share/405e54a9-a06d-4c2d-86a3-cf4344bbcb69
Here is the prompt behind the ChatGPT GPT I created:
Bounty Details
The text was updated successfully, but these errors were encountered: