Skip to content

Commit

Permalink
Cleanup OAI / Login
Browse files Browse the repository at this point in the history
  • Loading branch information
truell20 committed Mar 30, 2023
1 parent 81a28a4 commit 77cf2d8
Show file tree
Hide file tree
Showing 4 changed files with 68 additions and 48 deletions.
2 changes: 1 addition & 1 deletion src/components/errors.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -51,6 +51,7 @@ const loginStyles = {
marginLeft: 'auto',
marginRight: 'auto',
maxWidth: '450px',
overflow: 'none',
},
}

Expand Down Expand Up @@ -177,7 +178,6 @@ export function ErrorPopup() {
Upgrade
</div>
</div>
<div className="signup__signup_button">Upgrade</div>
</div>
<div className="signup__module signup__last_module">
<div className="signup__subtitle">
Expand Down
112 changes: 65 additions & 47 deletions src/components/settingsPane.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -162,6 +162,7 @@ export function SettingsPopup() {
/>
</div>

<CursorLogin />
<OpenAIPanel />
<CopilotPanel />
{/* REMOVED CODEBASE-WIDE FEATURES!
Expand All @@ -172,7 +173,6 @@ export function SettingsPopup() {
languageName={name}
/>
))}
<CursorLogin />
</div>
</div>
<div className="cover-bar"></div>
Expand Down Expand Up @@ -209,7 +209,6 @@ export function OpenAILoginPanel({ onSubmit }: { onSubmit: () => void }) {

const handleNewAPIKey = useCallback(async () => {
const { models, isValidKey } = await ssel.getModels(localAPIKey)
console.log({ models, isValidKey })
if (!isValidKey) {
// Error, and we let them know
showKeyError(true)
Expand All @@ -219,11 +218,12 @@ export function OpenAILoginPanel({ onSubmit }: { onSubmit: () => void }) {
dispatch(
changeSettings({
openAIKey: localAPIKey,
})
)
useOpenAIKey: true,
openAIModel: models.at(0) ?? null
}))
onSubmit()
}
}, [localAPIKey])
}, [dispatch, localAPIKey])

return (
<div className="settings__item">
Expand Down Expand Up @@ -267,17 +267,17 @@ export function OpenAILoginPanel({ onSubmit }: { onSubmit: () => void }) {
? 'bg-green-500'
: 'bg-red-500'
}
mt-2 relative inline-flex h-[38px] w-[74px] shrink-0 cursor-pointer rounded-full border-2 border-transparent transition-colors duration-200 ease-in-out focus:outline-none focus-visible:ring-2 focus-visible:ring-white focus-visible:ring-opacity-75`}
mt-2 relative inline-flex h-[25px] w-[52px] shrink-0 cursor-pointer rounded-full border-2 border-transparent transition-colors duration-200 ease-in-out focus:outline-none focus-visible:ring-2 focus-visible:ring-white focus-visible:ring-opacity-75`}
>
<span className="sr-only">Use setting</span>
<span
aria-hidden="true"
className={`${
settings.useOpenAIKey
? 'translate-x-9'
? 'translate-x-7'
: 'translate-x-0'
}
pointer-events-none inline-block h-[34px] w-[34px] transform rounded-full bg-white shadow-lg ring-0 transition duration-200 ease-in-out`}
pointer-events-none inline-block h-[20px] w-[20px] transform rounded-full bg-white shadow-lg ring-0 transition duration-200 ease-in-out`}
/>
</Switch>
{settings.useOpenAIKey ? (
Expand Down Expand Up @@ -331,28 +331,32 @@ export function OpenAIPanel() {
}, [localAPIKey])

const handleNewAPIKey = useCallback(async () => {
console.log('here 2')
const { models, isValidKey } = await ssel.getModels(localAPIKey)
console.log({ models, isValidKey })
if (!isValidKey) {
// Error, and we let them know
console.log('here 3')
showKeyError(true)
setAvailableModels([])
} else {
setAvailableModels(models)
console.log('here')
dispatch(
changeSettings({
openAIKey: localAPIKey,
})
)
useOpenAIKey: true,
openAIModel: models.at(0) ?? null
}))
}
}, [localAPIKey])
}, [dispatch, localAPIKey])


return (
<div className="settings__item">
<div className="settings__item_title">OpenAI API Key</div>
<div className="settings__item_description">
We'll use your key for any requests to OpenAI. This will help
you avoid "maximum capacity" limits.
You can enter an OpenAI API key to use Cursor at-cost
</div>
<div className="flex">
<input
Expand Down Expand Up @@ -394,17 +398,17 @@ export function OpenAIPanel() {
? 'bg-green-500'
: 'bg-red-500'
}
mt-2 relative inline-flex h-[38px] w-[74px] shrink-0 cursor-pointer rounded-full border-2 border-transparent transition-colors duration-200 ease-in-out focus:outline-none focus-visible:ring-2 focus-visible:ring-white focus-visible:ring-opacity-75`}
mt-2 relative inline-flex h-[24px] w-[52px] shrink-0 cursor-pointer rounded-full border-2 border-transparent transition-colors duration-200 ease-in-out focus:outline-none focus-visible:ring-2 focus-visible:ring-white focus-visible:ring-opacity-75`}
>
<span className="sr-only">Use setting</span>
<span
aria-hidden="true"
className={`${
settings.useOpenAIKey
? 'translate-x-9'
? 'translate-x-7'
: 'translate-x-0'
}
pointer-events-none inline-block h-[34px] w-[34px] transform rounded-full bg-white shadow-lg ring-0 transition duration-200 ease-in-out`}
pointer-events-none inline-block h-[20px] w-[20px] transform rounded-full bg-white shadow-lg ring-0 transition duration-200 ease-in-out`}
/>
</Switch>
{settings.useOpenAIKey ? (
Expand Down Expand Up @@ -467,47 +471,61 @@ export function CursorLogin({
} else {
if (proVersion) {
currentPanel = (
<div className="copilot__signin">
<button onClick={signOut}>Log out</button>
{showSettings && (
<>
<br />
<button onClick={openAccountSettings}>
Manage settings
</button>
</>
)}
<div className="settings__item">
<div className="settings__item_title">Cursor Account</div>
<div className="settings__item_description">
Login to use the AI without an API key
</div>
<div className="copilot__signin">
<button onClick={signOut}>Log out</button>
{showSettings && (
<>
<br />
<button onClick={openAccountSettings}>
Manage settings
</button>
</>
)}
</div>
</div>
)
} else {
currentPanel = (
<div className="copilot__signin">
<br />
<button onClick={signOut}>Log out</button>
{showSettings && (
<>
<>
<div className="settings__item">
<div className="settings__item_title">Cursor Account</div>
<div className="settings__item_description">
Login to use the AI without an API key
</div>
<div className="copilot__signin">
<button onClick={signOut}>Log out</button>
{showSettings && (
<>
<br />
<button onClick={openAccountSettings}>
Manage settings
</button>
</>
)}
<br />
<button onClick={openAccountSettings}>
Manage settings
</button>
</>
)}
<br />
Upgrade for unlimited generations
<button onClick={upgrade}>Upgrade to Pro</button>
</div>
</div>
</div>
<div className="settings__item">
<div className="settings__item_title">Cursor Pro</div>
<div className="settings__item_description">
Upgrade for unlimited generations
</div>
<div className="copilot__signin">
<button onClick={upgrade}>Upgrade to Pro</button>
</div>
</div>
</>
)
}
}

return (
<div className="settings__item">
<div className="settings__item_title">Cursor Account</div>
<div className="settings__item_description">
Login to use the AI without an API key
</div>
{currentPanel}
</div>
currentPanel
)
}

Expand Down
1 change: 1 addition & 0 deletions src/index.css
Original file line number Diff line number Diff line change
Expand Up @@ -2550,6 +2550,7 @@ free servers .disabled_command .shortcut__block {

.signup__last_module {
margin-bottom: 0px;
text-align: center;
}

.error-message {
Expand Down
1 change: 1 addition & 0 deletions src/main/main.ts
Original file line number Diff line number Diff line change
Expand Up @@ -40,6 +40,7 @@ import todesktop from '@todesktop/runtime'
todesktop.init()

const store = new Store()
store.clear()

let main_window: Electron.BrowserWindow

Expand Down

0 comments on commit 77cf2d8

Please sign in to comment.