From d5efc7292a9df2d4711b26bc862aa012073ee603 Mon Sep 17 00:00:00 2001 From: Luis Ball Date: Fri, 14 Jun 2024 10:00:14 -0700 Subject: [PATCH] feat: allow customers to set a default source-id --- src/components/ConfigScreen/ConfigScreen.tsx | 45 +++++++++++++++++-- src/components/Dialog/Dialog.tsx | 14 ++++-- src/components/Gallery/ImageGallery.tsx | 7 ++- .../SourceSelect/SourceSelectDropdown.tsx | 36 ++++++++------- 4 files changed, 79 insertions(+), 23 deletions(-) diff --git a/src/components/ConfigScreen/ConfigScreen.tsx b/src/components/ConfigScreen/ConfigScreen.tsx index 8d4a8159..183f304c 100644 --- a/src/components/ConfigScreen/ConfigScreen.tsx +++ b/src/components/ConfigScreen/ConfigScreen.tsx @@ -23,6 +23,7 @@ import packageJson from './../../../package.json'; export interface AppInstallationParameters { imgixAPIKey?: string; + sourceID?: string; successfullyVerified?: boolean; } @@ -197,15 +198,32 @@ export default class Config extends Component { return { ...currentState, EditorInterface }; }; - handleChange = (e: ChangeEvent) => { + handleAPIKeyChange = ( + e: ChangeEvent, + ) => { + const prevState = { ...this.state }; this.setState({ parameters: { + ...prevState.parameters, imgixAPIKey: e.target.value, successfullyVerified: this.state.parameters.successfullyVerified, }, }); }; + handleSourceIDChange = ( + e: ChangeEvent, + ) => { + const prevState = { ...this.state }; + this.setState({ + parameters: { + ...prevState.parameters, + sourceID: e.target.value, + successfullyVerified: this.state.parameters.successfullyVerified, + }, + }); + }; + verifyAPIKey = async () => { this.setState({ isButtonLoading: true }); @@ -219,7 +237,12 @@ export default class Config extends Component { }; try { - await imgix.request('sources'); + if (this.state.parameters.sourceID?.length) { + await imgix.request(`sources/${this.state.parameters.sourceID}`); + } else { + await imgix.request('sources'); + } + Notification.setPosition('top', { offset: 650 }); Notification.success( 'Your API key was successfully confirmed! Click the Install/Save button (in the top right corner) to complete installation.', @@ -347,7 +370,7 @@ export default class Config extends Component { type: 'password', autoComplete: 'new-api-key', }} - onChange={this.handleChange} + onChange={this.handleAPIKeyChange} /> {this.state.parameters.successfullyVerified && ( @@ -366,6 +389,22 @@ export default class Config extends Component { https://dashboard.imgix.com/api-keys

+
+
+ +
+
+ !allSources.length ? ( + + ) : ( + + ) } > - {!allSources.length ? ( - - Loading - - ) : null} {allSources.map((source: SourceProps) => ( handleClick(source)}> {source.name}