@looker/run-it 0.9.26 → 0.9.29

Sign up to get free protection for your applications and to get access to all the features.
Files changed (55) hide show
  1. package/CHANGELOG.md +52 -0
  2. package/lib/RunIt.d.ts +0 -2
  3. package/lib/RunIt.js +1 -4
  4. package/lib/RunIt.js.map +1 -1
  5. package/lib/components/ConfigForm/ConfigForm.d.ts +1 -2
  6. package/lib/components/ConfigForm/ConfigForm.js +34 -44
  7. package/lib/components/ConfigForm/ConfigForm.js.map +1 -1
  8. package/lib/components/ConfigForm/index.d.ts +1 -1
  9. package/lib/components/ConfigForm/index.js +4 -4
  10. package/lib/components/ConfigForm/index.js.map +1 -1
  11. package/lib/components/ConfigForm/utils.d.ts +11 -0
  12. package/lib/components/ConfigForm/utils.js +81 -0
  13. package/lib/components/ConfigForm/utils.js.map +1 -0
  14. package/lib/components/LoginForm/LoginForm.d.ts +1 -0
  15. package/lib/components/LoginForm/LoginForm.js +5 -3
  16. package/lib/components/LoginForm/LoginForm.js.map +1 -1
  17. package/lib/components/RequestForm/RequestForm.d.ts +0 -2
  18. package/lib/components/RequestForm/RequestForm.js.map +1 -1
  19. package/lib/esm/RunIt.js +2 -5
  20. package/lib/esm/RunIt.js.map +1 -1
  21. package/lib/esm/components/ConfigForm/ConfigForm.js +29 -39
  22. package/lib/esm/components/ConfigForm/ConfigForm.js.map +1 -1
  23. package/lib/esm/components/ConfigForm/index.js +1 -1
  24. package/lib/esm/components/ConfigForm/index.js.map +1 -1
  25. package/lib/esm/components/ConfigForm/utils.js +61 -0
  26. package/lib/esm/components/ConfigForm/utils.js.map +1 -0
  27. package/lib/esm/components/LoginForm/LoginForm.js +3 -2
  28. package/lib/esm/components/LoginForm/LoginForm.js.map +1 -1
  29. package/lib/esm/components/RequestForm/RequestForm.js.map +1 -1
  30. package/lib/esm/index.js +0 -1
  31. package/lib/esm/index.js.map +1 -1
  32. package/lib/index.d.ts +0 -1
  33. package/lib/index.js +0 -13
  34. package/lib/index.js.map +1 -1
  35. package/package.json +7 -7
  36. package/lib/components/ConfigForm/configUtils.d.ts +0 -39
  37. package/lib/components/ConfigForm/configUtils.js +0 -234
  38. package/lib/components/ConfigForm/configUtils.js.map +0 -1
  39. package/lib/esm/components/ConfigForm/configUtils.js +0 -198
  40. package/lib/esm/components/ConfigForm/configUtils.js.map +0 -1
  41. package/lib/esm/scenes/OAuthScene/OAuthScene.js +0 -61
  42. package/lib/esm/scenes/OAuthScene/OAuthScene.js.map +0 -1
  43. package/lib/esm/scenes/OAuthScene/index.js +0 -2
  44. package/lib/esm/scenes/OAuthScene/index.js.map +0 -1
  45. package/lib/esm/scenes/index.js +0 -2
  46. package/lib/esm/scenes/index.js.map +0 -1
  47. package/lib/scenes/OAuthScene/OAuthScene.d.ts +0 -2
  48. package/lib/scenes/OAuthScene/OAuthScene.js +0 -78
  49. package/lib/scenes/OAuthScene/OAuthScene.js.map +0 -1
  50. package/lib/scenes/OAuthScene/index.d.ts +0 -1
  51. package/lib/scenes/OAuthScene/index.js +0 -14
  52. package/lib/scenes/OAuthScene/index.js.map +0 -1
  53. package/lib/scenes/index.d.ts +0 -1
  54. package/lib/scenes/index.js +0 -14
  55. package/lib/scenes/index.js.map +0 -1
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/components/LoginForm/LoginForm.tsx"],"names":["readyToLogin","LoginForm","requestContent","adaptor","handleLogin","e","preventDefault","localStorageSetItem","RunItFormKey","JSON","stringify","sdk","authSession","login"],"mappings":";;;;;;;AA2BA;;AACA;;AACA;;AAEA;;;;;;;;AAOO,IAAMA,YAAY,GACvB,iGADK;;;AAGA,IAAMC,SAA6B,GAAG,QAAwB;AAAA,MAAvB;AAAEC,IAAAA;AAAF,GAAuB;AACnE,MAAMC,OAAO,GAAG,oCAAhB;;AAEA,MAAMC,WAAW;AAAA,kCAAG,WAAOC,CAAP,EAAiC;AACnDA,MAAAA,CAAC,CAACC,cAAF;;AACA,UAAIJ,cAAJ,EAAoB;AAClBC,QAAAA,OAAO,CAACI,mBAAR,CAA4BC,wBAA5B,EAA0CC,IAAI,CAACC,SAAL,CAAeR,cAAf,CAA1C;AACD;;AAED,YAAMC,OAAO,CAACQ,GAAR,CAAYC,WAAZ,CAAwBC,KAAxB,EAAN;AACD,KAPgB;;AAAA,oBAAXT,WAAW;AAAA;AAAA;AAAA,KAAjB;;AASA,SACE,6BAAC,mBAAD;AAAS,IAAA,OAAO,EAAEJ;AAAlB,KACE,6BAAC,kBAAD;AAAQ,IAAA,OAAO,EAAEI;AAAjB,aADF,CADF;AAKD,CAjBM","sourcesContent":["/*\n\n MIT License\n\n Copyright (c) 2021 Looker Data Sciences, Inc.\n\n Permission is hereby granted, free of charge, to any person obtaining a copy\n of this software and associated documentation files (the \"Software\"), to deal\n in the Software without restriction, including without limitation the rights\n to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n copies of the Software, and to permit persons to whom the Software is\n furnished to do so, subject to the following conditions:\n\n The above copyright notice and this permission notice shall be included in all\n copies or substantial portions of the Software.\n\n THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE\n SOFTWARE.\n\n */\n\nimport type { BaseSyntheticEvent, FC } from 'react'\nimport React from 'react'\nimport { Button, Tooltip } from '@looker/components'\nimport { getEnvAdaptor } from '@looker/extension-utils'\n\nimport { RunItFormKey } from '../ConfigForm'\nimport type { RunItValues } from '../..'\n\ninterface LoginFormProps {\n requestContent: RunItValues\n}\n\nexport const readyToLogin =\n 'OAuth is configured but your browser session is not authenticated. Click Login to enable RunIt.'\n\nexport const LoginForm: FC<LoginFormProps> = ({ requestContent }) => {\n const adaptor = getEnvAdaptor()\n\n const handleLogin = async (e: BaseSyntheticEvent) => {\n e.preventDefault()\n if (requestContent) {\n adaptor.localStorageSetItem(RunItFormKey, JSON.stringify(requestContent))\n }\n // This will set storage variables and return to OAuthScene when successful\n await adaptor.sdk.authSession.login()\n }\n\n return (\n <Tooltip content={readyToLogin}>\n <Button onClick={handleLogin}>Login</Button>\n </Tooltip>\n )\n}\n"],"file":"LoginForm.js"}
1
+ {"version":3,"sources":["../../../src/components/LoginForm/LoginForm.tsx"],"names":["readyToLogin","notReadyToLogin","LoginForm","requestContent","adaptor","handleLogin","e","preventDefault","localStorageSetItem","RunItFormKey","JSON","stringify","login","sdk","authSession","settings","authIsConfigured"],"mappings":";;;;;;;AA2BA;;AACA;;AAEA;;AAEA;;;;;;;;AAOO,IAAMA,YAAY,GACvB,iGADK;;AAGA,IAAMC,eAAe,GAC1B,4DADK;;;AAGA,IAAMC,SAA6B,GAAG,QAAwB;AAAA,MAAvB;AAAEC,IAAAA;AAAF,GAAuB;AACnE,MAAMC,OAAO,GAAG,oCAAhB;;AACA,MAAMC,WAAW;AAAA,kCAAG,WAAOC,CAAP,EAAiC;AACnDA,MAAAA,CAAC,CAACC,cAAF;;AACA,UAAIJ,cAAJ,EAAoB;AAClBC,QAAAA,OAAO,CAACI,mBAAR,CAA4BC,wBAA5B,EAA0CC,IAAI,CAACC,SAAL,CAAeR,cAAf,CAA1C;AACD;;AAED,YAAMC,OAAO,CAACQ,KAAR,EAAN;AACD,KAPgB;;AAAA,oBAAXP,WAAW;AAAA;AAAA;AAAA,KAAjB;;AASA,SACE,6BAAC,mBAAD;AACE,IAAA,OAAO,EAEHD,OAAO,CAACS,GAAR,CAAYC,WAAZ,CAAwBC,QAD1B,CAEEC,gBAFF,KAGIhB,YAHJ,GAIIC;AANR,KASE,6BAAC,kBAAD;AAAQ,IAAA,OAAO,EAAEI;AAAjB,aATF,CADF;AAaD,CAxBM","sourcesContent":["/*\n\n MIT License\n\n Copyright (c) 2021 Looker Data Sciences, Inc.\n\n Permission is hereby granted, free of charge, to any person obtaining a copy\n of this software and associated documentation files (the \"Software\"), to deal\n in the Software without restriction, including without limitation the rights\n to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n copies of the Software, and to permit persons to whom the Software is\n furnished to do so, subject to the following conditions:\n\n The above copyright notice and this permission notice shall be included in all\n copies or substantial portions of the Software.\n\n THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE\n SOFTWARE.\n\n */\n\nimport type { BaseSyntheticEvent, FC } from 'react'\nimport React from 'react'\nimport { Button, Tooltip } from '@looker/components'\nimport type { OAuthConfigProvider } from '@looker/extension-utils'\nimport { getEnvAdaptor } from '@looker/extension-utils'\n\nimport { RunItFormKey } from '../ConfigForm'\nimport type { RunItValues } from '../..'\n\ninterface LoginFormProps {\n requestContent: RunItValues\n}\n\nexport const readyToLogin =\n 'OAuth is configured but your browser session is not authenticated. Click Login to enable RunIt.'\n\nexport const notReadyToLogin =\n 'OAuth is not configured. Configure it to be able to Login.'\n\nexport const LoginForm: FC<LoginFormProps> = ({ requestContent }) => {\n const adaptor = getEnvAdaptor()\n const handleLogin = async (e: BaseSyntheticEvent) => {\n e.preventDefault()\n if (requestContent) {\n adaptor.localStorageSetItem(RunItFormKey, JSON.stringify(requestContent))\n }\n // This will set storage variables and return to OAuthScene when successful\n await adaptor.login()\n }\n\n return (\n <Tooltip\n content={\n (\n adaptor.sdk.authSession.settings as OAuthConfigProvider\n ).authIsConfigured()\n ? readyToLogin\n : notReadyToLogin\n }\n >\n <Button onClick={handleLogin}>Login</Button>\n </Tooltip>\n )\n}\n"],"file":"LoginForm.js"}
@@ -1,6 +1,5 @@
1
1
  import type { BaseSyntheticEvent, FC, Dispatch } from 'react';
2
2
  import type { RunItHttpMethod, RunItInput, RunItValues } from '../../RunIt';
3
- import type { RunItSetter } from '../..';
4
3
  interface RequestFormProps {
5
4
  inputs: RunItInput[];
6
5
  handleSubmit: (e: BaseSyntheticEvent) => void;
@@ -10,7 +9,6 @@ interface RequestFormProps {
10
9
  needsAuth: boolean;
11
10
  hasConfig: boolean;
12
11
  handleConfig: (e: BaseSyntheticEvent) => void;
13
- setVersionsUrl: RunItSetter;
14
12
  setHasConfig?: Dispatch<boolean>;
15
13
  validationMessage?: string;
16
14
  setValidationMessage?: Dispatch<string>;
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/components/RequestForm/RequestForm.tsx"],"names":["RequestForm","inputs","httpMethod","handleSubmit","requestContent","setRequestContent","needsAuth","hasConfig","handleConfig","setHasConfig","validationMessage","setValidationMessage","isExtension","handleBoolChange","e","target","name","checked","handleNumberChange","value","parseFloat","undefined","newState","handleDateChange","date","handleChange","handleComplexChange","safeSetMessage","handleClear","preventDefault","map","input","type"],"mappings":"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","sourcesContent":["/*\n\n MIT License\n\n Copyright (c) 2021 Looker Data Sciences, Inc.\n\n Permission is hereby granted, free of charge, to any person obtaining a copy\n of this software and associated documentation files (the \"Software\"), to deal\n in the Software without restriction, including without limitation the rights\n to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n copies of the Software, and to permit persons to whom the Software is\n furnished to do so, subject to the following conditions:\n\n The above copyright notice and this permission notice shall be included in all\n copies or substantial portions of the Software.\n\n THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE\n SOFTWARE.\n\n */\n\nimport type { BaseSyntheticEvent, FC, Dispatch } from 'react'\nimport React from 'react'\nimport {\n Button,\n Form,\n ButtonTransparent,\n Tooltip,\n Fieldset,\n MessageBar,\n} from '@looker/components'\nimport type { RunItHttpMethod, RunItInput, RunItValues } from '../../RunIt'\nimport { LoginForm } from '../LoginForm'\nimport type { RunItSetter } from '../..'\nimport {\n createSimpleItem,\n createComplexItem,\n showDataChangeWarning,\n updateNullableProp,\n} from './formUtils'\nimport { FormItem } from './FormItem'\n\n/** Properties required by RequestForm */\ninterface RequestFormProps {\n /** Request inputs to the endpoint */\n inputs: RunItInput[]\n /** A callback for submitting the form */\n handleSubmit: (e: BaseSyntheticEvent) => void\n /** HTTP method used for this REST request */\n httpMethod: RunItHttpMethod\n /** A collection type react state to store path, query and body parameters as entered by the user */\n requestContent: RunItValues\n /** A set state callback fn for populating requestContent on interaction with the request form */\n setRequestContent: Dispatch<RunItValues>\n /** Is authentication required? */\n needsAuth: boolean\n /** Does RunIt have the configuration values it needs? */\n hasConfig: boolean\n /** Handle config button click */\n handleConfig: (e: BaseSyntheticEvent) => void\n /** Hook to refresh specifications */\n setVersionsUrl: RunItSetter\n /** A set state callback which if present allows for editing, setting or clearing OAuth configuration parameters */\n setHasConfig?: Dispatch<boolean>\n /** Validation message to display */\n validationMessage?: string\n /** Validation message setter */\n setValidationMessage?: Dispatch<string>\n /** Is RunIt being used in a Looker extension? */\n isExtension?: boolean\n}\n\n/**\n * Dynamically generates a REST request form and its form elements corresponding to parameters from an array of RunIt\n * inputs\n */\nexport const RequestForm: FC<RequestFormProps> = ({\n inputs,\n httpMethod,\n handleSubmit,\n requestContent,\n setRequestContent,\n needsAuth,\n hasConfig,\n handleConfig,\n setHasConfig,\n validationMessage,\n setValidationMessage,\n isExtension = false,\n}) => {\n const handleBoolChange = (e: BaseSyntheticEvent) => {\n setRequestContent({ ...requestContent, [e.target.name]: e.target.checked })\n }\n\n const handleNumberChange = (e: BaseSyntheticEvent) => {\n const value = e.target.value ? parseFloat(e.target.value) : undefined\n const newState = updateNullableProp(requestContent, e.target.name, value)\n setRequestContent(newState)\n }\n\n const handleDateChange = (name: string, date?: Date) => {\n const newState = updateNullableProp(requestContent, name, date)\n setRequestContent(newState)\n }\n\n const handleChange = (e: BaseSyntheticEvent) => {\n const newState = updateNullableProp(\n requestContent,\n e.target.name,\n e.target.value\n )\n setRequestContent(newState)\n }\n\n const handleComplexChange = (name: string, value: string) => {\n setRequestContent({ ...requestContent, [name]: value })\n }\n\n const safeSetMessage = (value: string) =>\n setValidationMessage && setValidationMessage(value)\n\n const handleClear = (e: BaseSyntheticEvent) => {\n e.preventDefault()\n setRequestContent({})\n safeSetMessage('')\n }\n\n return (\n <Form onSubmit={handleSubmit}>\n {validationMessage && (\n <MessageBar\n intent={'critical'}\n onPrimaryClick={() => safeSetMessage('')}\n visible={validationMessage !== ''}\n >\n {validationMessage}\n </MessageBar>\n )}\n <Fieldset>\n {inputs.map((input) =>\n typeof input.type === 'string'\n ? createSimpleItem(\n input,\n handleChange,\n handleNumberChange,\n handleBoolChange,\n handleDateChange,\n requestContent\n )\n : createComplexItem(input, handleComplexChange, requestContent)\n )}\n {httpMethod !== 'GET' && showDataChangeWarning()}\n <FormItem id=\"buttonbar\">\n <>\n {hasConfig ? (\n needsAuth ? (\n <LoginForm requestContent={requestContent} />\n ) : (\n <Tooltip content=\"Run the API request\">\n <Button type=\"submit\">Run</Button>\n </Tooltip>\n )\n ) : (\n !isExtension &&\n setHasConfig && (\n <Tooltip content=\"Configure your OAuth server to Run requests\">\n <Button onClick={handleConfig}>Configure</Button>\n </Tooltip>\n )\n )}\n <Tooltip content=\"Clear entered values\">\n <ButtonTransparent type=\"button\" onClick={handleClear}>\n Clear\n </ButtonTransparent>\n </Tooltip>\n </>\n </FormItem>\n </Fieldset>\n </Form>\n )\n}\n"],"file":"RequestForm.js"}
1
+ {"version":3,"sources":["../../../src/components/RequestForm/RequestForm.tsx"],"names":["RequestForm","inputs","httpMethod","handleSubmit","requestContent","setRequestContent","needsAuth","hasConfig","handleConfig","setHasConfig","validationMessage","setValidationMessage","isExtension","handleBoolChange","e","target","name","checked","handleNumberChange","value","parseFloat","undefined","newState","handleDateChange","date","handleChange","handleComplexChange","safeSetMessage","handleClear","preventDefault","map","input","type"],"mappings":"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","sourcesContent":["/*\n\n MIT License\n\n Copyright (c) 2021 Looker Data Sciences, Inc.\n\n Permission is hereby granted, free of charge, to any person obtaining a copy\n of this software and associated documentation files (the \"Software\"), to deal\n in the Software without restriction, including without limitation the rights\n to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n copies of the Software, and to permit persons to whom the Software is\n furnished to do so, subject to the following conditions:\n\n The above copyright notice and this permission notice shall be included in all\n copies or substantial portions of the Software.\n\n THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE\n SOFTWARE.\n\n */\n\nimport type { BaseSyntheticEvent, FC, Dispatch } from 'react'\nimport React from 'react'\nimport {\n Button,\n Form,\n ButtonTransparent,\n Tooltip,\n Fieldset,\n MessageBar,\n} from '@looker/components'\nimport type { RunItHttpMethod, RunItInput, RunItValues } from '../../RunIt'\nimport { LoginForm } from '../LoginForm'\nimport {\n createSimpleItem,\n createComplexItem,\n showDataChangeWarning,\n updateNullableProp,\n} from './formUtils'\nimport { FormItem } from './FormItem'\n\n/** Properties required by RequestForm */\ninterface RequestFormProps {\n /** Request inputs to the endpoint */\n inputs: RunItInput[]\n /** A callback for submitting the form */\n handleSubmit: (e: BaseSyntheticEvent) => void\n /** HTTP method used for this REST request */\n httpMethod: RunItHttpMethod\n /** A collection type react state to store path, query and body parameters as entered by the user */\n requestContent: RunItValues\n /** A set state callback fn for populating requestContent on interaction with the request form */\n setRequestContent: Dispatch<RunItValues>\n /** Is authentication required? */\n needsAuth: boolean\n /** Does RunIt have the configuration values it needs? */\n hasConfig: boolean\n /** Handle config button click */\n handleConfig: (e: BaseSyntheticEvent) => void\n /** A set state callback which if present allows for editing, setting or clearing OAuth configuration parameters */\n setHasConfig?: Dispatch<boolean>\n /** Validation message to display */\n validationMessage?: string\n /** Validation message setter */\n setValidationMessage?: Dispatch<string>\n /** Is RunIt being used in a Looker extension? */\n isExtension?: boolean\n}\n\n/**\n * Dynamically generates a REST request form and its form elements corresponding to parameters from an array of RunIt\n * inputs\n */\nexport const RequestForm: FC<RequestFormProps> = ({\n inputs,\n httpMethod,\n handleSubmit,\n requestContent,\n setRequestContent,\n needsAuth,\n hasConfig,\n handleConfig,\n setHasConfig,\n validationMessage,\n setValidationMessage,\n isExtension = false,\n}) => {\n const handleBoolChange = (e: BaseSyntheticEvent) => {\n setRequestContent({ ...requestContent, [e.target.name]: e.target.checked })\n }\n\n const handleNumberChange = (e: BaseSyntheticEvent) => {\n const value = e.target.value ? parseFloat(e.target.value) : undefined\n const newState = updateNullableProp(requestContent, e.target.name, value)\n setRequestContent(newState)\n }\n\n const handleDateChange = (name: string, date?: Date) => {\n const newState = updateNullableProp(requestContent, name, date)\n setRequestContent(newState)\n }\n\n const handleChange = (e: BaseSyntheticEvent) => {\n const newState = updateNullableProp(\n requestContent,\n e.target.name,\n e.target.value\n )\n setRequestContent(newState)\n }\n\n const handleComplexChange = (name: string, value: string) => {\n setRequestContent({ ...requestContent, [name]: value })\n }\n\n const safeSetMessage = (value: string) =>\n setValidationMessage && setValidationMessage(value)\n\n const handleClear = (e: BaseSyntheticEvent) => {\n e.preventDefault()\n setRequestContent({})\n safeSetMessage('')\n }\n\n return (\n <Form onSubmit={handleSubmit}>\n {validationMessage && (\n <MessageBar\n intent={'critical'}\n onPrimaryClick={() => safeSetMessage('')}\n visible={validationMessage !== ''}\n >\n {validationMessage}\n </MessageBar>\n )}\n <Fieldset>\n {inputs.map((input) =>\n typeof input.type === 'string'\n ? createSimpleItem(\n input,\n handleChange,\n handleNumberChange,\n handleBoolChange,\n handleDateChange,\n requestContent\n )\n : createComplexItem(input, handleComplexChange, requestContent)\n )}\n {httpMethod !== 'GET' && showDataChangeWarning()}\n <FormItem id=\"buttonbar\">\n <>\n {hasConfig ? (\n needsAuth ? (\n <LoginForm requestContent={requestContent} />\n ) : (\n <Tooltip content=\"Run the API request\">\n <Button type=\"submit\">Run</Button>\n </Tooltip>\n )\n ) : (\n !isExtension &&\n setHasConfig && (\n <Tooltip content=\"Configure your OAuth server to Run requests\">\n <Button onClick={handleConfig}>Configure</Button>\n </Tooltip>\n )\n )}\n <Tooltip content=\"Clear entered values\">\n <ButtonTransparent type=\"button\" onClick={handleClear}>\n Clear\n </ButtonTransparent>\n </Tooltip>\n </>\n </FormItem>\n </Fieldset>\n </Form>\n )\n}\n"],"file":"RequestForm.js"}
package/lib/esm/RunIt.js CHANGED
@@ -9,13 +9,12 @@ import { Box, Tab, TabList, TabPanels, TabPanel, useTabs } from '@looker/compone
9
9
  import { registerEnvAdaptor } from '@looker/extension-utils';
10
10
  import { RequestForm, ResponseExplorer, Loading, DocSdkCalls, ConfigForm, validateBody, PerfTimings, PerfTracker } from './components';
11
11
  import { initRequestContent, createRequestParams, runRequest, pathify, prepareInputs, createInputs } from './utils';
12
- import { runItNoSet, RunItContext } from '.';
12
+ import { RunItContext } from '.';
13
13
  export var RunIt = _ref => {
14
14
  var {
15
15
  adaptor,
16
16
  api,
17
17
  method,
18
- setVersionsUrl = runItNoSet,
19
18
  sdkLanguage = 'All'
20
19
  } = _ref;
21
20
  var httpMethod = method.httpMethod;
@@ -128,8 +127,7 @@ export var RunIt = _ref => {
128
127
  setHasConfig: setHasConfig,
129
128
  isExtension: isExtension,
130
129
  validationMessage: validationMessage,
131
- setValidationMessage: setValidationMessage,
132
- setVersionsUrl: setVersionsUrl
130
+ setValidationMessage: setValidationMessage
133
131
  })), React.createElement(TabPanel, {
134
132
  key: "response"
135
133
  }, React.createElement(Loading, {
@@ -154,7 +152,6 @@ export var RunIt = _ref => {
154
152
  key: "config"
155
153
  }, React.createElement(ConfigForm, {
156
154
  setHasConfig: setHasConfig,
157
- setVersionsUrl: setVersionsUrl,
158
155
  requestContent: requestContent
159
156
  })))));
160
157
  };
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/RunIt.tsx"],"names":["React","useContext","useState","useEffect","Box","Tab","TabList","TabPanels","TabPanel","useTabs","registerEnvAdaptor","RequestForm","ResponseExplorer","Loading","DocSdkCalls","ConfigForm","validateBody","PerfTimings","PerfTracker","initRequestContent","createRequestParams","runRequest","pathify","prepareInputs","createInputs","runItNoSet","RunItContext","RunIt","adaptor","api","method","setVersionsUrl","sdkLanguage","httpMethod","endpoint","sdk","initialized","setInitialized","basePath","inputs","requestContent","setRequestContent","activePathParams","setActivePathParams","loading","setLoading","responseContent","setResponseContent","undefined","isExtension","hasConfig","setHasConfig","authSession","settings","authIsConfigured","needsAuth","isAuthenticated","validationMessage","setValidationMessage","tabs","perf","handleConfig","_e","onSelectTab","handleSubmit","e","preventDefault","pathParams","queryParams","body","bodyParam","bodyParams","requiredKeys","Object","keys","type","requiredProperties","message","response","err","ok","statusMessage","statusCode","contentType","JSON","stringify","headers"],"mappings":";;;;;;AA2BA,OAAOA,KAAP,IAAgBC,UAAhB,EAA4BC,QAA5B,EAAsCC,SAAtC,QAAuD,OAAvD;AACA,SACEC,GADF,EAEEC,GAFF,EAGEC,OAHF,EAIEC,SAJF,EAKEC,QALF,EAMEC,OANF,QAOO,oBAPP;AAaA,SAASC,kBAAT,QAAmC,yBAAnC;AAGA,SACEC,WADF,EAEEC,gBAFF,EAGEC,OAHF,EAIEC,WAJF,EAKEC,UALF,EAMEC,YANF,EAOEC,WAPF,EAQEC,WARF,QASO,cATP;AAUA,SACEC,kBADF,EAEEC,mBAFF,EAGEC,UAHF,EAIEC,OAJF,EAKEC,aALF,EAMEC,YANF,QAOO,SAPP;AASA,SAASC,UAAT,EAAqBC,YAArB,QAAyC,GAAzC;AAuDA,OAAO,IAAMC,KAAqB,GAAG,QAM/B;AAAA,MANgC;AACpCC,IAAAA,OADoC;AAEpCC,IAAAA,GAFoC;AAGpCC,IAAAA,MAHoC;AAIpCC,IAAAA,cAAc,GAAGN,UAJmB;AAKpCO,IAAAA,WAAW,GAAG;AALsB,GAMhC;AACJ,MAAMC,UAAU,GAAGH,MAAM,CAACG,UAA1B;AACA,MAAMC,QAAQ,GAAGJ,MAAM,CAACI,QAAxB;AACA,MAAMC,GAAG,GAAGP,OAAO,CAACO,GAApB;AACA,MAAM,CAACC,WAAD,EAAcC,cAAd,IAAgCnC,QAAQ,CAAC,KAAD,CAA9C;AACA,MAAM;AAAEoC,IAAAA;AAAF,MAAerC,UAAU,CAACyB,YAAD,CAA/B;AACA,MAAM,CAACa,MAAD,IAAWrC,QAAQ,CAAC,MAAMsB,YAAY,CAACK,GAAD,EAAMC,MAAN,CAAnB,CAAzB;AAGA,MAAM,CAACU,cAAD,EAAiBC,iBAAjB,IAAsCvC,QAAQ,CAClDiB,kBAAkB,CAACoB,MAAD,CADgC,CAApD;AAGA,MAAM,CAACG,gBAAD,EAAmBC,mBAAnB,IAA0CzC,QAAQ,CAAC,EAAD,CAAxD;AACA,MAAM,CAAC0C,OAAD,EAAUC,UAAV,IAAwB3C,QAAQ,CAAC,KAAD,CAAtC;AACA,MAAM,CAAC4C,eAAD,EAAkBC,kBAAlB,IACJ7C,QAAQ,CAAkB8C,SAAlB,CADV;AAIA,MAAMC,WAAW,GAAGrB,OAAO,CAACqB,WAAR,EAApB;AACA,MAAM,CAACC,SAAD,EAAYC,YAAZ,IAA4BjD,QAAQ,CACxC+C,WAAW,IACRd,GAAG,CAACiB,WAAJ,CAAgBC,QAAjB,CAAkDC,gBAAlD,EAFsC,CAA1C;AAIA,MAAM,CAACC,SAAD,IAAcrD,QAAQ,CAC1B,MAAM,CAAC+C,WAAD,IAAgB,CAACd,GAAG,CAACiB,WAAJ,CAAgBI,eAAhB,EADG,CAA5B;AAIA,MAAM,CAACC,iBAAD,EAAoBC,oBAApB,IAA4CxD,QAAQ,CAAS,EAAT,CAA1D;AACA,MAAMyD,IAAI,GAAGlD,OAAO,EAApB;AAEA,MAAMmD,IAAI,GAAG,IAAI3C,WAAJ,EAAb;AAEAd,EAAAA,SAAS,CAAC,MAAM;AACdO,IAAAA,kBAAkB,CAACkB,OAAD,CAAlB;AACAS,IAAAA,cAAc,CAAC,IAAD,CAAd;AACD,GAHQ,EAGN,EAHM,CAAT;;AAKA,MAAMwB,YAAY,GAAIC,EAAD,IAA4B;AAC/CH,IAAAA,IAAI,CAACI,WAAL,CAAiB,CAAjB;AACD,GAFD;;AAIA,MAAMC,YAAY;AAAA,kCAAG,WAAOC,CAAP,EAAiC;AACpDA,MAAAA,CAAC,CAACC,cAAF;AAEA,UAAM,CAACC,UAAD,EAAaC,WAAb,EAA0BC,IAA1B,IAAkCjD,mBAAmB,CACzDmB,MADyD,EAEzDC,cAFyD,CAA3D;;AAIA,UAAI6B,IAAJ,EAAU;AACR,YAAM,CAACC,SAAD,IAAcxC,MAAM,CAACyC,UAA3B;AACA,YAAMC,YAAY,GAAGC,MAAM,CAACC,IAAP,CAAYJ,SAAS,CAACK,IAAV,CAAeC,kBAA3B,CAArB;AACA,YAAMC,OAAO,GAAG7D,YAAY,CAACqD,IAAD,EAAOG,YAAP,CAA5B;AACAd,QAAAA,oBAAoB,CAACmB,OAAD,CAApB;;AACA,YAAIA,OAAJ,EAAa;AAEX;AACD;AACF;;AACDlC,MAAAA,mBAAmB,CAACwB,UAAD,CAAnB;AACAR,MAAAA,IAAI,CAACI,WAAL,CAAiB,CAAjB;;AACA,UAAI5B,GAAJ,EAAS;AACPU,QAAAA,UAAU,CAAC,IAAD,CAAV;AACA,YAAIiC,QAAJ;;AACA,YAAI;AACFA,UAAAA,QAAQ,SAASzD,UAAU,CACzBc,GADyB,EAEzBG,QAFyB,EAGzBL,UAHyB,EAIzBC,QAJyB,EAKzBiC,UALyB,EAMzBC,WANyB,EAOzBC,IAPyB,CAA3B;AASD,SAVD,CAUE,OAAOU,GAAP,EAAiB;AAIjBD,UAAAA,QAAQ,GAAG;AACTE,YAAAA,EAAE,EAAE,KADK;AAETC,YAAAA,aAAa,EAAEF,GAAG,CAACF,OAAJ,GAAcE,GAAG,CAACF,OAAlB,GAA4B,gBAFlC;AAGTK,YAAAA,UAAU,EAAE,CAAC,CAHJ;AAITC,YAAAA,WAAW,EAAE,kBAJJ;AAKTd,YAAAA,IAAI,EAAEe,IAAI,CAACC,SAAL,CAAeN,GAAf,CALG;AAMTO,YAAAA,OAAO,EAAE;AANA,WAAX;AAQD;;AACDvC,QAAAA,kBAAkB,CAAC+B,QAAD,CAAlB;AACAjC,QAAAA,UAAU,CAAC,KAAD,CAAV;AACD;AACF,KAhDiB;;AAAA,oBAAZmB,YAAY;AAAA;AAAA;AAAA,KAAlB;;AAkDA,SACE,oBAAC,GAAD;AAAK,IAAA,EAAE,EAAC,YAAR;AAAqB,IAAA,EAAE,EAAC,OAAxB;AAAgC,IAAA,MAAM,EAAC;AAAvC,KACG,CAAC5B,WAAD,GACC,oBAAC,OAAD;AAAS,IAAA,OAAO,EAAE;AAAlB,IADD,GAGC,0CACE,oBAAC,OAAD;AAAS,IAAA,UAAU;AAAnB,KAAwBuB,IAAxB,GACE,oBAAC,GAAD;AAAK,IAAA,GAAG,EAAC;AAAT,eADF,EAEE,oBAAC,GAAD;AAAK,IAAA,GAAG,EAAC;AAAT,gBAFF,EAGE,oBAAC,GAAD;AAAK,IAAA,GAAG,EAAC;AAAT,gBAHF,EAIGV,WAAW,GAAG,yCAAH,GAAW,oBAAC,GAAD;AAAK,IAAA,GAAG,EAAC;AAAT,mBAJzB,EAKGA,WAAW,GAAG,yCAAH,GAAW,oBAAC,GAAD;AAAK,IAAA,GAAG,EAAC;AAAT,iBALzB,CADF,EAQE,oBAAC,SAAD;AAAW,IAAA,EAAE,EAAC;AAAd,KAA4BU,IAA5B;AAAkC,IAAA,QAAQ,EAAC,MAA3C;AAAkD,IAAA,MAAM,EAAC;AAAzD,MACE,oBAAC,QAAD;AAAU,IAAA,GAAG,EAAC;AAAd,KACE,oBAAC,WAAD;AACE,IAAA,UAAU,EAAE1B,UADd;AAEE,IAAA,MAAM,EAAEM,MAFV;AAGE,IAAA,cAAc,EAAEC,cAHlB;AAIE,IAAA,iBAAiB,EAAEC,iBAJrB;AAKE,IAAA,YAAY,EAAEuB,YALhB;AAME,IAAA,SAAS,EAAET,SANb;AAOE,IAAA,SAAS,EAAEL,SAPb;AAQE,IAAA,YAAY,EAAEW,YARhB;AASE,IAAA,YAAY,EAAEV,YAThB;AAUE,IAAA,WAAW,EAAEF,WAVf;AAWE,IAAA,iBAAiB,EAAEQ,iBAXrB;AAYE,IAAA,oBAAoB,EAAEC,oBAZxB;AAaE,IAAA,cAAc,EAAE3B;AAblB,IADF,CADF,EAkBE,oBAAC,QAAD;AAAU,IAAA,GAAG,EAAC;AAAd,KACE,oBAAC,OAAD;AACE,IAAA,OAAO,EAAEa,OADX;AAEE,IAAA,OAAO,YAAKX,UAAL,cAAmBX,OAAO,CAACY,QAAD,EAAWQ,gBAAX,CAA1B;AAFT,IADF,EAKE,oBAAC,gBAAD;AACE,IAAA,QAAQ,EAAEI,eADZ;AAEE,IAAA,IAAI,EAAEb,UAFR;AAGE,IAAA,IAAI,EAAEX,OAAO,CAACY,QAAD,EAAWQ,gBAAX;AAHf,IALF,CAlBF,EA6BE,oBAAC,QAAD;AAAU,IAAA,GAAG,EAAC;AAAd,KACE,oBAAC,WAAD;AACE,IAAA,WAAW,EAAEV,WADf;AAEE,IAAA,GAAG,EAAEH,GAFP;AAGE,IAAA,MAAM,EAAEC,MAHV;AAIE,IAAA,MAAM,EAAEP,aAAa,CAACgB,MAAD,EAASC,cAAT;AAJvB,IADF,CA7BF,EAqCGS,WAAW,GACV,yCADU,GAGV,oBAAC,QAAD;AAAU,IAAA,GAAG,EAAC;AAAd,KACE,oBAAC,WAAD;AAAa,IAAA,IAAI,EAAEW;AAAnB,IADF,CAxCJ,EA4CGX,WAAW,GACV,yCADU,GAGV,oBAAC,QAAD;AAAU,IAAA,GAAG,EAAC;AAAd,KACE,oBAAC,UAAD;AACE,IAAA,YAAY,EAAEE,YADhB;AAEE,IAAA,cAAc,EAAEpB,cAFlB;AAGE,IAAA,cAAc,EAAES;AAHlB,IADF,CA/CJ,CARF,CAJJ,CADF;AAyED,CA1KM","sourcesContent":["/*\n\n MIT License\n\n Copyright (c) 2021 Looker Data Sciences, Inc.\n\n Permission is hereby granted, free of charge, to any person obtaining a copy\n of this software and associated documentation files (the \"Software\"), to deal\n in the Software without restriction, including without limitation the rights\n to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n copies of the Software, and to permit persons to whom the Software is\n furnished to do so, subject to the following conditions:\n\n The above copyright notice and this permission notice shall be included in all\n copies or substantial portions of the Software.\n\n THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE\n SOFTWARE.\n\n */\n\nimport type { BaseSyntheticEvent, FC } from 'react'\nimport React, { useContext, useState, useEffect } from 'react'\nimport {\n Box,\n Tab,\n TabList,\n TabPanels,\n TabPanel,\n useTabs,\n} from '@looker/components'\nimport type { ApiModel, IMethod } from '@looker/sdk-codegen'\nimport type {\n IEnvironmentAdaptor,\n OAuthConfigProvider,\n} from '@looker/extension-utils'\nimport { registerEnvAdaptor } from '@looker/extension-utils'\n\nimport type { ResponseContent } from './components'\nimport {\n RequestForm,\n ResponseExplorer,\n Loading,\n DocSdkCalls,\n ConfigForm,\n validateBody,\n PerfTimings,\n PerfTracker,\n} from './components'\nimport {\n initRequestContent,\n createRequestParams,\n runRequest,\n pathify,\n prepareInputs,\n createInputs,\n} from './utils'\nimport type { RunItSetter } from '.'\nimport { runItNoSet, RunItContext } from '.'\n\nexport type RunItHttpMethod = 'GET' | 'PUT' | 'POST' | 'PATCH' | 'DELETE'\n\n/**\n * Generic collection\n */\nexport type RunItValues = Record<string, any>\n\ntype RunItInputType =\n | 'boolean'\n | 'int64'\n | 'integer'\n | 'float'\n | 'double'\n | 'string'\n | 'hostname'\n | 'uuid'\n | 'uri'\n | 'ipv4'\n | 'ipv6'\n | 'email'\n | 'password'\n | 'datetime'\n\ntype RunItInputLocation = 'body' | 'path' | 'query' | 'header' | 'cookie'\n\n/**\n * A RunIt input type describing a single REST request's parameter or a structure\n */\nexport interface RunItInput {\n name: string\n location: RunItInputLocation\n /** A RunItInputType or a structure */\n type: RunItInputType | any\n required: boolean\n description: string\n}\n\ninterface RunItProps {\n adaptor: IEnvironmentAdaptor\n /** spec model to use for sdk call generation */\n api: ApiModel\n /** Method to test */\n method: IMethod\n /** Set versions Url callback */\n setVersionsUrl: RunItSetter\n /** Sdk language to use for generating call syntax */\n sdkLanguage?: string\n}\n\n/**\n * Given an array of inputs, a method, and an api model it renders a REST request form\n * which on submit performs a REST request and renders the response with the appropriate MIME type handler\n */\nexport const RunIt: FC<RunItProps> = ({\n adaptor,\n api,\n method,\n setVersionsUrl = runItNoSet,\n sdkLanguage = 'All',\n}) => {\n const httpMethod = method.httpMethod as RunItHttpMethod\n const endpoint = method.endpoint\n const sdk = adaptor.sdk\n const [initialized, setInitialized] = useState(false)\n const { basePath } = useContext(RunItContext)\n const [inputs] = useState(() => createInputs(api, method))\n\n /** Request related state */\n const [requestContent, setRequestContent] = useState(\n initRequestContent(inputs)\n )\n const [activePathParams, setActivePathParams] = useState({})\n const [loading, setLoading] = useState(false)\n const [responseContent, setResponseContent] =\n useState<ResponseContent>(undefined)\n\n /** Auth config related state */\n const isExtension = adaptor.isExtension()\n const [hasConfig, setHasConfig] = useState<boolean>(\n isExtension ||\n (sdk.authSession.settings as OAuthConfigProvider).authIsConfigured()\n )\n const [needsAuth] = useState<boolean>(\n () => !isExtension && !sdk.authSession.isAuthenticated()\n )\n\n const [validationMessage, setValidationMessage] = useState<string>('')\n const tabs = useTabs()\n\n const perf = new PerfTimings()\n\n useEffect(() => {\n registerEnvAdaptor(adaptor)\n setInitialized(true)\n }, [])\n\n const handleConfig = (_e: BaseSyntheticEvent) => {\n tabs.onSelectTab(4)\n }\n\n const handleSubmit = async (e: BaseSyntheticEvent) => {\n e.preventDefault()\n\n const [pathParams, queryParams, body] = createRequestParams(\n inputs,\n requestContent\n )\n if (body) {\n const [bodyParam] = method.bodyParams\n const requiredKeys = Object.keys(bodyParam.type.requiredProperties)\n const message = validateBody(body, requiredKeys)\n setValidationMessage(message)\n if (message) {\n // body has an error, don't run\n return\n }\n }\n setActivePathParams(pathParams)\n tabs.onSelectTab(1)\n if (sdk) {\n setLoading(true)\n let response: ResponseContent\n try {\n response = await runRequest(\n sdk,\n basePath,\n httpMethod,\n endpoint,\n pathParams,\n queryParams,\n body\n )\n } catch (err: any) {\n // This should not happen but it could. runRequest uses\n // sdk.ok to login once. sdk.ok throws an error so fake\n // out the response so something can be rendered.\n response = {\n ok: false,\n statusMessage: err.message ? err.message : 'Unknown error!',\n statusCode: -1,\n contentType: 'application/json',\n body: JSON.stringify(err),\n headers: {},\n } as ResponseContent\n }\n setResponseContent(response)\n setLoading(false)\n }\n }\n\n return (\n <Box bg=\"background\" py=\"large\" height=\"100%\">\n {!initialized ? (\n <Loading loading={true} />\n ) : (\n <>\n <TabList distribute {...tabs}>\n <Tab key=\"request\">Request</Tab>\n <Tab key=\"response\">Response</Tab>\n <Tab key=\"makeTheCall\">SDK Call</Tab>\n {isExtension ? <></> : <Tab key=\"performance\">Performance</Tab>}\n {isExtension ? <></> : <Tab key=\"configuration\">Configure</Tab>}\n </TabList>\n <TabPanels px=\"xxlarge\" {...tabs} overflow=\"auto\" height=\"87vh\">\n <TabPanel key=\"request\">\n <RequestForm\n httpMethod={httpMethod}\n inputs={inputs}\n requestContent={requestContent}\n setRequestContent={setRequestContent}\n handleSubmit={handleSubmit}\n needsAuth={needsAuth}\n hasConfig={hasConfig}\n handleConfig={handleConfig}\n setHasConfig={setHasConfig}\n isExtension={isExtension}\n validationMessage={validationMessage}\n setValidationMessage={setValidationMessage}\n setVersionsUrl={setVersionsUrl}\n />\n </TabPanel>\n <TabPanel key=\"response\">\n <Loading\n loading={loading}\n message={`${httpMethod} ${pathify(endpoint, activePathParams)}`}\n />\n <ResponseExplorer\n response={responseContent}\n verb={httpMethod}\n path={pathify(endpoint, activePathParams)}\n />\n </TabPanel>\n <TabPanel key=\"makeTheCall\">\n <DocSdkCalls\n sdkLanguage={sdkLanguage}\n api={api}\n method={method}\n inputs={prepareInputs(inputs, requestContent)}\n />\n </TabPanel>\n {isExtension ? (\n <></>\n ) : (\n <TabPanel key=\"performance\">\n <PerfTracker perf={perf} />\n </TabPanel>\n )}\n {isExtension ? (\n <></>\n ) : (\n <TabPanel key=\"config\">\n <ConfigForm\n setHasConfig={setHasConfig}\n setVersionsUrl={setVersionsUrl}\n requestContent={requestContent}\n />\n </TabPanel>\n )}\n </TabPanels>\n </>\n )}\n </Box>\n )\n}\n"],"file":"RunIt.js"}
1
+ {"version":3,"sources":["../../src/RunIt.tsx"],"names":["React","useContext","useState","useEffect","Box","Tab","TabList","TabPanels","TabPanel","useTabs","registerEnvAdaptor","RequestForm","ResponseExplorer","Loading","DocSdkCalls","ConfigForm","validateBody","PerfTimings","PerfTracker","initRequestContent","createRequestParams","runRequest","pathify","prepareInputs","createInputs","RunItContext","RunIt","adaptor","api","method","sdkLanguage","httpMethod","endpoint","sdk","initialized","setInitialized","basePath","inputs","requestContent","setRequestContent","activePathParams","setActivePathParams","loading","setLoading","responseContent","setResponseContent","undefined","isExtension","hasConfig","setHasConfig","authSession","settings","authIsConfigured","needsAuth","isAuthenticated","validationMessage","setValidationMessage","tabs","perf","handleConfig","_e","onSelectTab","handleSubmit","e","preventDefault","pathParams","queryParams","body","bodyParam","bodyParams","requiredKeys","Object","keys","type","requiredProperties","message","response","err","ok","statusMessage","statusCode","contentType","JSON","stringify","headers"],"mappings":";;;;;;AA2BA,OAAOA,KAAP,IAAgBC,UAAhB,EAA4BC,QAA5B,EAAsCC,SAAtC,QAAuD,OAAvD;AACA,SACEC,GADF,EAEEC,GAFF,EAGEC,OAHF,EAIEC,SAJF,EAKEC,QALF,EAMEC,OANF,QAOO,oBAPP;AAaA,SAASC,kBAAT,QAAmC,yBAAnC;AAGA,SACEC,WADF,EAEEC,gBAFF,EAGEC,OAHF,EAIEC,WAJF,EAKEC,UALF,EAMEC,YANF,EAOEC,WAPF,EAQEC,WARF,QASO,cATP;AAUA,SACEC,kBADF,EAEEC,mBAFF,EAGEC,UAHF,EAIEC,OAJF,EAKEC,aALF,EAMEC,YANF,QAOO,SAPP;AAQA,SAASC,YAAT,QAA6B,GAA7B;AAqDA,OAAO,IAAMC,KAAqB,GAAG,QAK/B;AAAA,MALgC;AACpCC,IAAAA,OADoC;AAEpCC,IAAAA,GAFoC;AAGpCC,IAAAA,MAHoC;AAIpCC,IAAAA,WAAW,GAAG;AAJsB,GAKhC;AACJ,MAAMC,UAAU,GAAGF,MAAM,CAACE,UAA1B;AACA,MAAMC,QAAQ,GAAGH,MAAM,CAACG,QAAxB;AACA,MAAMC,GAAG,GAAGN,OAAO,CAACM,GAApB;AACA,MAAM,CAACC,WAAD,EAAcC,cAAd,IAAgCjC,QAAQ,CAAC,KAAD,CAA9C;AACA,MAAM;AAAEkC,IAAAA;AAAF,MAAenC,UAAU,CAACwB,YAAD,CAA/B;AACA,MAAM,CAACY,MAAD,IAAWnC,QAAQ,CAAC,MAAMsB,YAAY,CAACI,GAAD,EAAMC,MAAN,CAAnB,CAAzB;AAGA,MAAM,CAACS,cAAD,EAAiBC,iBAAjB,IAAsCrC,QAAQ,CAClDiB,kBAAkB,CAACkB,MAAD,CADgC,CAApD;AAGA,MAAM,CAACG,gBAAD,EAAmBC,mBAAnB,IAA0CvC,QAAQ,CAAC,EAAD,CAAxD;AACA,MAAM,CAACwC,OAAD,EAAUC,UAAV,IAAwBzC,QAAQ,CAAC,KAAD,CAAtC;AACA,MAAM,CAAC0C,eAAD,EAAkBC,kBAAlB,IACJ3C,QAAQ,CAAkB4C,SAAlB,CADV;AAIA,MAAMC,WAAW,GAAGpB,OAAO,CAACoB,WAAR,EAApB;AACA,MAAM,CAACC,SAAD,EAAYC,YAAZ,IAA4B/C,QAAQ,CACxC6C,WAAW,IACRd,GAAG,CAACiB,WAAJ,CAAgBC,QAAjB,CAAkDC,gBAAlD,EAFsC,CAA1C;AAIA,MAAM,CAACC,SAAD,IAAcnD,QAAQ,CAC1B,MAAM,CAAC6C,WAAD,IAAgB,CAACd,GAAG,CAACiB,WAAJ,CAAgBI,eAAhB,EADG,CAA5B;AAIA,MAAM,CAACC,iBAAD,EAAoBC,oBAApB,IAA4CtD,QAAQ,CAAS,EAAT,CAA1D;AACA,MAAMuD,IAAI,GAAGhD,OAAO,EAApB;AAEA,MAAMiD,IAAI,GAAG,IAAIzC,WAAJ,EAAb;AAEAd,EAAAA,SAAS,CAAC,MAAM;AACdO,IAAAA,kBAAkB,CAACiB,OAAD,CAAlB;AACAQ,IAAAA,cAAc,CAAC,IAAD,CAAd;AACD,GAHQ,EAGN,EAHM,CAAT;;AAKA,MAAMwB,YAAY,GAAIC,EAAD,IAA4B;AAC/CH,IAAAA,IAAI,CAACI,WAAL,CAAiB,CAAjB;AACD,GAFD;;AAIA,MAAMC,YAAY;AAAA,kCAAG,WAAOC,CAAP,EAAiC;AACpDA,MAAAA,CAAC,CAACC,cAAF;AAEA,UAAM,CAACC,UAAD,EAAaC,WAAb,EAA0BC,IAA1B,IAAkC/C,mBAAmB,CACzDiB,MADyD,EAEzDC,cAFyD,CAA3D;;AAIA,UAAI6B,IAAJ,EAAU;AACR,YAAM,CAACC,SAAD,IAAcvC,MAAM,CAACwC,UAA3B;AACA,YAAMC,YAAY,GAAGC,MAAM,CAACC,IAAP,CAAYJ,SAAS,CAACK,IAAV,CAAeC,kBAA3B,CAArB;AACA,YAAMC,OAAO,GAAG3D,YAAY,CAACmD,IAAD,EAAOG,YAAP,CAA5B;AACAd,QAAAA,oBAAoB,CAACmB,OAAD,CAApB;;AACA,YAAIA,OAAJ,EAAa;AAEX;AACD;AACF;;AACDlC,MAAAA,mBAAmB,CAACwB,UAAD,CAAnB;AACAR,MAAAA,IAAI,CAACI,WAAL,CAAiB,CAAjB;;AACA,UAAI5B,GAAJ,EAAS;AACPU,QAAAA,UAAU,CAAC,IAAD,CAAV;AACA,YAAIiC,QAAJ;;AACA,YAAI;AACFA,UAAAA,QAAQ,SAASvD,UAAU,CACzBY,GADyB,EAEzBG,QAFyB,EAGzBL,UAHyB,EAIzBC,QAJyB,EAKzBiC,UALyB,EAMzBC,WANyB,EAOzBC,IAPyB,CAA3B;AASD,SAVD,CAUE,OAAOU,GAAP,EAAiB;AAIjBD,UAAAA,QAAQ,GAAG;AACTE,YAAAA,EAAE,EAAE,KADK;AAETC,YAAAA,aAAa,EAAEF,GAAG,CAACF,OAAJ,GAAcE,GAAG,CAACF,OAAlB,GAA4B,gBAFlC;AAGTK,YAAAA,UAAU,EAAE,CAAC,CAHJ;AAITC,YAAAA,WAAW,EAAE,kBAJJ;AAKTd,YAAAA,IAAI,EAAEe,IAAI,CAACC,SAAL,CAAeN,GAAf,CALG;AAMTO,YAAAA,OAAO,EAAE;AANA,WAAX;AAQD;;AACDvC,QAAAA,kBAAkB,CAAC+B,QAAD,CAAlB;AACAjC,QAAAA,UAAU,CAAC,KAAD,CAAV;AACD;AACF,KAhDiB;;AAAA,oBAAZmB,YAAY;AAAA;AAAA;AAAA,KAAlB;;AAkDA,SACE,oBAAC,GAAD;AAAK,IAAA,EAAE,EAAC,YAAR;AAAqB,IAAA,EAAE,EAAC,OAAxB;AAAgC,IAAA,MAAM,EAAC;AAAvC,KACG,CAAC5B,WAAD,GACC,oBAAC,OAAD;AAAS,IAAA,OAAO,EAAE;AAAlB,IADD,GAGC,0CACE,oBAAC,OAAD;AAAS,IAAA,UAAU;AAAnB,KAAwBuB,IAAxB,GACE,oBAAC,GAAD;AAAK,IAAA,GAAG,EAAC;AAAT,eADF,EAEE,oBAAC,GAAD;AAAK,IAAA,GAAG,EAAC;AAAT,gBAFF,EAGE,oBAAC,GAAD;AAAK,IAAA,GAAG,EAAC;AAAT,gBAHF,EAIGV,WAAW,GAAG,yCAAH,GAAW,oBAAC,GAAD;AAAK,IAAA,GAAG,EAAC;AAAT,mBAJzB,EAKGA,WAAW,GAAG,yCAAH,GAAW,oBAAC,GAAD;AAAK,IAAA,GAAG,EAAC;AAAT,iBALzB,CADF,EAQE,oBAAC,SAAD;AAAW,IAAA,EAAE,EAAC;AAAd,KAA4BU,IAA5B;AAAkC,IAAA,QAAQ,EAAC,MAA3C;AAAkD,IAAA,MAAM,EAAC;AAAzD,MACE,oBAAC,QAAD;AAAU,IAAA,GAAG,EAAC;AAAd,KACE,oBAAC,WAAD;AACE,IAAA,UAAU,EAAE1B,UADd;AAEE,IAAA,MAAM,EAAEM,MAFV;AAGE,IAAA,cAAc,EAAEC,cAHlB;AAIE,IAAA,iBAAiB,EAAEC,iBAJrB;AAKE,IAAA,YAAY,EAAEuB,YALhB;AAME,IAAA,SAAS,EAAET,SANb;AAOE,IAAA,SAAS,EAAEL,SAPb;AAQE,IAAA,YAAY,EAAEW,YARhB;AASE,IAAA,YAAY,EAAEV,YAThB;AAUE,IAAA,WAAW,EAAEF,WAVf;AAWE,IAAA,iBAAiB,EAAEQ,iBAXrB;AAYE,IAAA,oBAAoB,EAAEC;AAZxB,IADF,CADF,EAiBE,oBAAC,QAAD;AAAU,IAAA,GAAG,EAAC;AAAd,KACE,oBAAC,OAAD;AACE,IAAA,OAAO,EAAEd,OADX;AAEE,IAAA,OAAO,YAAKX,UAAL,cAAmBT,OAAO,CAACU,QAAD,EAAWQ,gBAAX,CAA1B;AAFT,IADF,EAKE,oBAAC,gBAAD;AACE,IAAA,QAAQ,EAAEI,eADZ;AAEE,IAAA,IAAI,EAAEb,UAFR;AAGE,IAAA,IAAI,EAAET,OAAO,CAACU,QAAD,EAAWQ,gBAAX;AAHf,IALF,CAjBF,EA4BE,oBAAC,QAAD;AAAU,IAAA,GAAG,EAAC;AAAd,KACE,oBAAC,WAAD;AACE,IAAA,WAAW,EAAEV,WADf;AAEE,IAAA,GAAG,EAAEF,GAFP;AAGE,IAAA,MAAM,EAAEC,MAHV;AAIE,IAAA,MAAM,EAAEN,aAAa,CAACc,MAAD,EAASC,cAAT;AAJvB,IADF,CA5BF,EAoCGS,WAAW,GACV,yCADU,GAGV,oBAAC,QAAD;AAAU,IAAA,GAAG,EAAC;AAAd,KACE,oBAAC,WAAD;AAAa,IAAA,IAAI,EAAEW;AAAnB,IADF,CAvCJ,EA2CGX,WAAW,GACV,yCADU,GAGV,oBAAC,QAAD;AAAU,IAAA,GAAG,EAAC;AAAd,KACE,oBAAC,UAAD;AACE,IAAA,YAAY,EAAEE,YADhB;AAEE,IAAA,cAAc,EAAEX;AAFlB,IADF,CA9CJ,CARF,CAJJ,CADF;AAuED,CAvKM","sourcesContent":["/*\n\n MIT License\n\n Copyright (c) 2021 Looker Data Sciences, Inc.\n\n Permission is hereby granted, free of charge, to any person obtaining a copy\n of this software and associated documentation files (the \"Software\"), to deal\n in the Software without restriction, including without limitation the rights\n to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n copies of the Software, and to permit persons to whom the Software is\n furnished to do so, subject to the following conditions:\n\n The above copyright notice and this permission notice shall be included in all\n copies or substantial portions of the Software.\n\n THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE\n SOFTWARE.\n\n */\n\nimport type { BaseSyntheticEvent, FC } from 'react'\nimport React, { useContext, useState, useEffect } from 'react'\nimport {\n Box,\n Tab,\n TabList,\n TabPanels,\n TabPanel,\n useTabs,\n} from '@looker/components'\nimport type { ApiModel, IMethod } from '@looker/sdk-codegen'\nimport type {\n IEnvironmentAdaptor,\n OAuthConfigProvider,\n} from '@looker/extension-utils'\nimport { registerEnvAdaptor } from '@looker/extension-utils'\n\nimport type { ResponseContent } from './components'\nimport {\n RequestForm,\n ResponseExplorer,\n Loading,\n DocSdkCalls,\n ConfigForm,\n validateBody,\n PerfTimings,\n PerfTracker,\n} from './components'\nimport {\n initRequestContent,\n createRequestParams,\n runRequest,\n pathify,\n prepareInputs,\n createInputs,\n} from './utils'\nimport { RunItContext } from '.'\n\nexport type RunItHttpMethod = 'GET' | 'PUT' | 'POST' | 'PATCH' | 'DELETE'\n\n/**\n * Generic collection\n */\nexport type RunItValues = Record<string, any>\n\ntype RunItInputType =\n | 'boolean'\n | 'int64'\n | 'integer'\n | 'float'\n | 'double'\n | 'string'\n | 'hostname'\n | 'uuid'\n | 'uri'\n | 'ipv4'\n | 'ipv6'\n | 'email'\n | 'password'\n | 'datetime'\n\ntype RunItInputLocation = 'body' | 'path' | 'query' | 'header' | 'cookie'\n\n/**\n * A RunIt input type describing a single REST request's parameter or a structure\n */\nexport interface RunItInput {\n name: string\n location: RunItInputLocation\n /** A RunItInputType or a structure */\n type: RunItInputType | any\n required: boolean\n description: string\n}\n\ninterface RunItProps {\n adaptor: IEnvironmentAdaptor\n /** spec model to use for sdk call generation */\n api: ApiModel\n /** Method to test */\n method: IMethod\n /** Sdk language to use for generating call syntax */\n sdkLanguage?: string\n}\n\n/**\n * Given an array of inputs, a method, and an api model it renders a REST request form\n * which on submit performs a REST request and renders the response with the appropriate MIME type handler\n */\nexport const RunIt: FC<RunItProps> = ({\n adaptor,\n api,\n method,\n sdkLanguage = 'All',\n}) => {\n const httpMethod = method.httpMethod as RunItHttpMethod\n const endpoint = method.endpoint\n const sdk = adaptor.sdk\n const [initialized, setInitialized] = useState(false)\n const { basePath } = useContext(RunItContext)\n const [inputs] = useState(() => createInputs(api, method))\n\n /** Request related state */\n const [requestContent, setRequestContent] = useState(\n initRequestContent(inputs)\n )\n const [activePathParams, setActivePathParams] = useState({})\n const [loading, setLoading] = useState(false)\n const [responseContent, setResponseContent] =\n useState<ResponseContent>(undefined)\n\n /** Auth config related state */\n const isExtension = adaptor.isExtension()\n const [hasConfig, setHasConfig] = useState<boolean>(\n isExtension ||\n (sdk.authSession.settings as OAuthConfigProvider).authIsConfigured()\n )\n const [needsAuth] = useState<boolean>(\n () => !isExtension && !sdk.authSession.isAuthenticated()\n )\n\n const [validationMessage, setValidationMessage] = useState<string>('')\n const tabs = useTabs()\n\n const perf = new PerfTimings()\n\n useEffect(() => {\n registerEnvAdaptor(adaptor)\n setInitialized(true)\n }, [])\n\n const handleConfig = (_e: BaseSyntheticEvent) => {\n tabs.onSelectTab(4)\n }\n\n const handleSubmit = async (e: BaseSyntheticEvent) => {\n e.preventDefault()\n\n const [pathParams, queryParams, body] = createRequestParams(\n inputs,\n requestContent\n )\n if (body) {\n const [bodyParam] = method.bodyParams\n const requiredKeys = Object.keys(bodyParam.type.requiredProperties)\n const message = validateBody(body, requiredKeys)\n setValidationMessage(message)\n if (message) {\n // body has an error, don't run\n return\n }\n }\n setActivePathParams(pathParams)\n tabs.onSelectTab(1)\n if (sdk) {\n setLoading(true)\n let response: ResponseContent\n try {\n response = await runRequest(\n sdk,\n basePath,\n httpMethod,\n endpoint,\n pathParams,\n queryParams,\n body\n )\n } catch (err: any) {\n // This should not happen but it could. runRequest uses\n // sdk.ok to login once. sdk.ok throws an error so fake\n // out the response so something can be rendered.\n response = {\n ok: false,\n statusMessage: err.message ? err.message : 'Unknown error!',\n statusCode: -1,\n contentType: 'application/json',\n body: JSON.stringify(err),\n headers: {},\n } as ResponseContent\n }\n setResponseContent(response)\n setLoading(false)\n }\n }\n\n return (\n <Box bg=\"background\" py=\"large\" height=\"100%\">\n {!initialized ? (\n <Loading loading={true} />\n ) : (\n <>\n <TabList distribute {...tabs}>\n <Tab key=\"request\">Request</Tab>\n <Tab key=\"response\">Response</Tab>\n <Tab key=\"makeTheCall\">SDK Call</Tab>\n {isExtension ? <></> : <Tab key=\"performance\">Performance</Tab>}\n {isExtension ? <></> : <Tab key=\"configuration\">Configure</Tab>}\n </TabList>\n <TabPanels px=\"xxlarge\" {...tabs} overflow=\"auto\" height=\"87vh\">\n <TabPanel key=\"request\">\n <RequestForm\n httpMethod={httpMethod}\n inputs={inputs}\n requestContent={requestContent}\n setRequestContent={setRequestContent}\n handleSubmit={handleSubmit}\n needsAuth={needsAuth}\n hasConfig={hasConfig}\n handleConfig={handleConfig}\n setHasConfig={setHasConfig}\n isExtension={isExtension}\n validationMessage={validationMessage}\n setValidationMessage={setValidationMessage}\n />\n </TabPanel>\n <TabPanel key=\"response\">\n <Loading\n loading={loading}\n message={`${httpMethod} ${pathify(endpoint, activePathParams)}`}\n />\n <ResponseExplorer\n response={responseContent}\n verb={httpMethod}\n path={pathify(endpoint, activePathParams)}\n />\n </TabPanel>\n <TabPanel key=\"makeTheCall\">\n <DocSdkCalls\n sdkLanguage={sdkLanguage}\n api={api}\n method={method}\n inputs={prepareInputs(inputs, requestContent)}\n />\n </TabPanel>\n {isExtension ? (\n <></>\n ) : (\n <TabPanel key=\"performance\">\n <PerfTracker perf={perf} />\n </TabPanel>\n )}\n {isExtension ? (\n <></>\n ) : (\n <TabPanel key=\"config\">\n <ConfigForm\n setHasConfig={setHasConfig}\n requestContent={requestContent}\n />\n </TabPanel>\n )}\n </TabPanels>\n </>\n )}\n </Box>\n )\n}\n"],"file":"RunIt.js"}
@@ -12,20 +12,17 @@ import React, { useState, useEffect } from 'react';
12
12
  import { Button, ButtonTransparent, Divider, Fieldset, FieldText, Form, MessageBar, Paragraph, Link, Space, SpaceVertical, Tooltip } from '@looker/components';
13
13
  import { CodeCopy } from '@looker/code-editor';
14
14
  import { getEnvAdaptor } from '@looker/extension-utils';
15
- import { CollapserCard, RunItFormKey, RunItHeading, DarkSpan, readyToLogin, RunItNoConfig } from '../..';
16
- import { RunItConfigKey, validateUrl, loadSpecsFromVersions } from './configUtils';
15
+ import { CollapserCard, RunItHeading, DarkSpan, readyToLogin } from '../..';
16
+ import { getVersions, RunItConfigKey, RunItNoConfig, RunItFormKey, validateUrl } from './utils';
17
17
  var POSITIVE = 'positive';
18
18
  var defaultFieldValues = {
19
19
  baseUrl: '',
20
20
  webUrl: '',
21
- headless: false,
22
- specs: {},
23
21
  fetchResult: '',
24
22
  fetchIntent: POSITIVE
25
23
  };
26
24
  export var ConfigForm = _ref => {
27
25
  var {
28
- setVersionsUrl,
29
26
  title,
30
27
  requestContent,
31
28
  setHasConfig
@@ -36,15 +33,13 @@ export var ConfigForm = _ref => {
36
33
  var FETCH_RESULT = 'fetchResult';
37
34
  var CRITICAL = 'critical';
38
35
  var appConfig = "{\n \"client_guid\": \"looker.api-explorer\",\n \"redirect_uri\": \"".concat(window.location.origin, "/oauth\",\n \"display_name\": \"CORS API Explorer\",\n \"description\": \"Looker API Explorer using CORS\",\n \"enabled\": true\n}\n");
39
- var sdk = getEnvAdaptor().sdk;
36
+ var adaptor = getEnvAdaptor();
37
+ var sdk = adaptor.sdk;
40
38
  title = title || 'RunIt Configuration';
41
39
 
42
40
  var getConfig = () => {
43
41
  var data = localStorage.getItem(RunItConfigKey);
44
- var result = data ? JSON.parse(data) : {
45
- base_url: '',
46
- looker_url: ''
47
- };
42
+ var result = data ? JSON.parse(data) : RunItNoConfig;
48
43
  return result;
49
44
  };
50
45
 
@@ -101,37 +96,32 @@ export var ConfigForm = _ref => {
101
96
 
102
97
  var updateForm = function () {
103
98
  var _ref2 = _asyncToGenerator(function* (_e, save) {
99
+ updateMessage('inform', '');
100
+ var versionsUrl = "".concat(fields.baseUrl, "/versions");
101
+
104
102
  try {
105
- updateMessage('inform', '');
106
- var versionsUrl = "".concat(fields.baseUrl, "/versions");
107
103
  var {
108
- webUrl,
109
- baseUrl
110
- } = yield loadSpecsFromVersions(versionsUrl);
111
-
112
- if (!baseUrl || !webUrl) {
113
- fetchError('Invalid server configuration');
114
- } else {
115
- updateFields({
116
- [BASE_URL]: baseUrl,
117
- [WEB_URL]: webUrl
118
- });
119
- updateMessage(POSITIVE, 'Configuration is valid');
120
-
121
- if (save) {
122
- var data = {
123
- base_url: baseUrl,
124
- looker_url: webUrl
125
- };
126
- localStorage.setItem(RunItConfigKey, JSON.stringify(data));
127
- if (setHasConfig) setHasConfig(true);
128
- setSaved(data);
129
- setVersionsUrl(versionsUrl);
130
- updateMessage(POSITIVE, "Saved ".concat(webUrl, " as OAuth server"));
131
- }
104
+ web_server_url: webUrl,
105
+ api_server_url: baseUrl
106
+ } = yield getVersions(versionsUrl);
107
+ updateFields({
108
+ [BASE_URL]: baseUrl,
109
+ [WEB_URL]: webUrl
110
+ });
111
+ updateMessage(POSITIVE, 'Configuration is valid');
112
+
113
+ if (save) {
114
+ var data = {
115
+ base_url: baseUrl,
116
+ looker_url: webUrl
117
+ };
118
+ localStorage.setItem(RunItConfigKey, JSON.stringify(data));
119
+ if (setHasConfig) setHasConfig(true);
120
+ setSaved(data);
121
+ updateMessage(POSITIVE, "Saved ".concat(webUrl, " as OAuth server"));
132
122
  }
133
- } catch (err) {
134
- fetchError(err.message);
123
+ } catch (e) {
124
+ fetchError(e.message);
135
125
  }
136
126
  });
137
127
 
@@ -221,7 +211,7 @@ export var ConfigForm = _ref => {
221
211
  localStorage.setItem(RunItFormKey, JSON.stringify(requestContent));
222
212
  }
223
213
 
224
- yield sdk.authSession.login();
214
+ yield adaptor.login();
225
215
  });
226
216
 
227
217
  return function handleLogin(_x6) {
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../../src/components/ConfigForm/ConfigForm.tsx"],"names":["React","useState","useEffect","Button","ButtonTransparent","Divider","Fieldset","FieldText","Form","MessageBar","Paragraph","Link","Space","SpaceVertical","Tooltip","CodeCopy","getEnvAdaptor","CollapserCard","RunItFormKey","RunItHeading","DarkSpan","readyToLogin","RunItNoConfig","RunItConfigKey","validateUrl","loadSpecsFromVersions","POSITIVE","defaultFieldValues","baseUrl","webUrl","headless","specs","fetchResult","fetchIntent","ConfigForm","setVersionsUrl","title","requestContent","setHasConfig","BASE_URL","WEB_URL","FETCH_INTENT","FETCH_RESULT","CRITICAL","appConfig","window","location","origin","sdk","getConfig","data","localStorage","getItem","result","JSON","parse","base_url","looker_url","config","fields","setFields","saved","setSaved","updateFields","nameOrValues","value","previousFields","validationMessages","setValidationMessages","updateMessage","intent","message","isConfigured","fetchError","updateForm","_e","save","versionsUrl","setItem","stringify","err","handleSave","e","handleVerify","handleClear","removeItem","isAuthenticated","handleUrlChange","event","name","currentTarget","newValidationMessages","url","type","authSession","verifyButtonDisabled","trim","length","Object","keys","saveButtonDisabled","clearButtonDisabled","loginButtonDisabled","handleLogin","preventDefault","login"],"mappings":";;;;;;;;;;AA2BA,OAAOA,KAAP,IAAgBC,QAAhB,EAA0BC,SAA1B,QAA2C,OAA3C;AAEA,SACEC,MADF,EAEEC,iBAFF,EAGEC,OAHF,EAIEC,QAJF,EAKEC,SALF,EAMEC,IANF,EAOEC,UAPF,EAQEC,SARF,EASEC,IATF,EAUEC,KAVF,EAWEC,aAXF,EAYEC,OAZF,QAaO,oBAbP;AAcA,SAASC,QAAT,QAAyB,qBAAzB;AACA,SAASC,aAAT,QAA8B,yBAA9B;AAGA,SACEC,aADF,EAEEC,YAFF,EAGEC,YAHF,EAIEC,QAJF,EAKEC,YALF,EAMEC,aANF,QAOO,OAPP;AASA,SACEC,cADF,EAEEC,WAFF,EAGEC,qBAHF,QAIO,eAJP;AAMA,IAAMC,QAA0B,GAAG,UAAnC;AAMA,IAAMC,kBAAgC,GAAG;AACvCC,EAAAA,OAAO,EAAE,EAD8B;AAEvCC,EAAAA,MAAM,EAAE,EAF+B;AAIvCC,EAAAA,QAAQ,EAAE,KAJ6B;AAKvCC,EAAAA,KAAK,EAAE,EALgC;AAMvCC,EAAAA,WAAW,EAAE,EAN0B;AAOvCC,EAAAA,WAAW,EAAEP;AAP0B,CAAzC;AAoBA,OAAO,IAAMQ,UAA+B,GAAG,QAKzC;AAAA,MAL0C;AAC9CC,IAAAA,cAD8C;AAE9CC,IAAAA,KAF8C;AAG9CC,IAAAA,cAH8C;AAI9CC,IAAAA;AAJ8C,GAK1C;AACJ,MAAMC,QAAQ,GAAG,SAAjB;AACA,MAAMC,OAAO,GAAG,QAAhB;AACA,MAAMC,YAAY,GAAG,aAArB;AACA,MAAMC,YAAY,GAAG,aAArB;AACA,MAAMC,QAA0B,GAAG,UAAnC;AACA,MAAMC,SAAS,mFAEKC,MAAD,CAAgBC,QAAhB,CAAyBC,MAF7B,4IAAf;AAQA,MAAMC,GAAG,GAAGhC,aAAa,GAAGgC,GAA5B;AAGAZ,EAAAA,KAAK,GAAGA,KAAK,IAAI,qBAAjB;;AAEA,MAAMa,SAAS,GAAG,MAAM;AAGtB,QAAMC,IAAI,GAAGC,YAAY,CAACC,OAAb,CAAqB7B,cAArB,CAAb;AACA,QAAM8B,MAAM,GAAGH,IAAI,GAAGI,IAAI,CAACC,KAAL,CAAWL,IAAX,CAAH,GAAsB;AAAEM,MAAAA,QAAQ,EAAE,EAAZ;AAAgBC,MAAAA,UAAU,EAAE;AAA5B,KAAzC;AACA,WAAOJ,MAAP;AACD,GAND;;AAQA,MAAMK,MAAM,GAAGT,SAAS,EAAxB;AACA,MAAM,CAACU,MAAD,EAASC,SAAT,IAAsB3D,QAAQ,CAAe0B,kBAAf,CAApC;AACA,MAAM,CAACkC,KAAD,EAAQC,QAAR,IAAoB7D,QAAQ,CAAcyD,MAAd,CAAlC;;AAEA,MAAMK,YAAY,GAAG,SAAfA,YAAe,CACnBC,YADmB,EAGhB;AAAA,QADHC,KACG,uEADK,EACL;;AACH,QAAI,OAAOD,YAAP,KAAwB,QAA5B,EAAsC;AACpCJ,MAAAA,SAAS,CAAEM,cAAD,IAAoB;AAC5B,+CAAYA,cAAZ,GAA+B;AAAE,WAACF,YAAD,GAAgBC;AAAlB,SAA/B;AACD,OAFQ,CAAT;AAGD,KAJD,MAIO;AACLL,MAAAA,SAAS,CAAEM,cAAD,IAAoB;AAC5B,+CAAYA,cAAZ,GAA+BF,YAA/B;AACD,OAFQ,CAAT;AAGD;AACF,GAbD;;AAeA9D,EAAAA,SAAS,CAAC,MAAM;AACd,QAAMgD,IAAI,GAAGD,SAAS,EAAtB;AACA,QAAM;AAAEO,MAAAA,QAAF;AAAYC,MAAAA;AAAZ,QAA2BP,IAAjC;AACAY,IAAAA,QAAQ,CAACZ,IAAD,CAAR;AACAa,IAAAA,YAAY,CAAC;AACX,OAACxB,QAAD,GAAYiB,QADD;AAEX,OAAChB,OAAD,GAAWiB,UAFA;AAGX,OAAChB,YAAD,GACEe,QAAQ,KAAK,EAAb,IAAmBC,UAAU,KAAK,EAAlC,GAAuC/B,QAAvC,GAAkDiB;AAJzC,KAAD,CAAZ;AAMD,GAVQ,EAUN,EAVM,CAAT;AAYA,MAAM,CAACwB,kBAAD,EAAqBC,qBAArB,IACJnE,QAAQ,CAAqB,EAArB,CADV;;AAGA,MAAMoE,aAAa,GAAG,CAACC,MAAD,EAA2BC,OAA3B,KAA+C;AACnER,IAAAA,YAAY,CAAC;AAAE,OAACrB,YAAD,GAAgB6B,OAAlB;AAA2B,OAAC9B,YAAD,GAAgB6B;AAA3C,KAAD,CAAZ;AACD,GAFD;;AAIA,MAAME,YAAY,GAAG,MAAM;AACzB,WACEX,KAAK,KAAKvC,aAAV,IACAqC,MAAM,CAACpB,QAAD,CAAN,KAAqBsB,KAAK,CAACL,QAD3B,IAEAG,MAAM,CAACnB,OAAD,CAAN,KAAoBqB,KAAK,CAACJ,UAH5B;AAKD,GAND;;AAQA,MAAMgB,UAAU,GAAIF,OAAD,IAAqB;AACtCR,IAAAA,YAAY,CAACvB,OAAD,EAAU,EAAV,CAAZ;AACA6B,IAAAA,aAAa,CAAC1B,QAAD,EAAW4B,OAAX,CAAb;AACD,GAHD;;AAKA,MAAMG,UAAU;AAAA,kCAAG,WAAOC,EAAP,EAA+BC,IAA/B,EAAiD;AAElE,UAAI;AACFP,QAAAA,aAAa,CAAC,QAAD,EAAW,EAAX,CAAb;AACA,YAAMQ,WAAW,aAAMlB,MAAM,CAAC/B,OAAb,cAAjB;AACA,YAAM;AAAEC,UAAAA,MAAF;AAAUD,UAAAA;AAAV,kBAA4BH,qBAAqB,CAACoD,WAAD,CAAvD;;AACA,YAAI,CAACjD,OAAD,IAAY,CAACC,MAAjB,EAAyB;AACvB4C,UAAAA,UAAU,CAAC,8BAAD,CAAV;AACD,SAFD,MAEO;AACLV,UAAAA,YAAY,CAAC;AAAE,aAACxB,QAAD,GAAYX,OAAd;AAAuB,aAACY,OAAD,GAAWX;AAAlC,WAAD,CAAZ;AACAwC,UAAAA,aAAa,CAAC3C,QAAD,EAAW,wBAAX,CAAb;;AACA,cAAIkD,IAAJ,EAAU;AACR,gBAAM1B,IAAI,GAAG;AAAEM,cAAAA,QAAQ,EAAE5B,OAAZ;AAAqB6B,cAAAA,UAAU,EAAE5B;AAAjC,aAAb;AAEAsB,YAAAA,YAAY,CAAC2B,OAAb,CAAqBvD,cAArB,EAAqC+B,IAAI,CAACyB,SAAL,CAAe7B,IAAf,CAArC;AACA,gBAAIZ,YAAJ,EAAkBA,YAAY,CAAC,IAAD,CAAZ;AAClBwB,YAAAA,QAAQ,CAACZ,IAAD,CAAR;AACAf,YAAAA,cAAc,CAAC0C,WAAD,CAAd;AACAR,YAAAA,aAAa,CAAC3C,QAAD,kBAAoBG,MAApB,sBAAb;AACD;AACF;AACF,OAnBD,CAmBE,OAAOmD,GAAP,EAAiB;AACjBP,QAAAA,UAAU,CAACO,GAAG,CAACT,OAAL,CAAV;AACD;AACF,KAxBe;;AAAA,oBAAVG,UAAU;AAAA;AAAA;AAAA,KAAhB;;AA0BA,MAAMO,UAAU;AAAA,kCAAG,WAAOC,CAAP,EAAiC;AAClD,YAAMR,UAAU,CAACQ,CAAD,EAAI,IAAJ,CAAhB;AACD,KAFe;;AAAA,oBAAVD,UAAU;AAAA;AAAA;AAAA,KAAhB;;AAIA,MAAME,YAAY;AAAA,kCAAG,WAAOD,CAAP,EAAiC;AACpD,YAAMR,UAAU,CAACQ,CAAD,EAAI,KAAJ,CAAhB;AACD,KAFiB;;AAAA,oBAAZC,YAAY;AAAA;AAAA;AAAA,KAAlB;;AAIA,MAAMC,WAAW;AAAA,kCAAG,WAAOT,EAAP,EAAkC;AAEpDxB,MAAAA,YAAY,CAACkC,UAAb,CAAwB9D,cAAxB;AACAwC,MAAAA,YAAY,CAAC;AACX,SAACxB,QAAD,GAAY,EADD;AAEX,SAACC,OAAD,GAAW,EAFA;AAGX,SAACC,YAAD,GAAgBE,QAHL;AAIX,SAACD,YAAD,GAAgB;AAJL,OAAD,CAAZ;AAMAoB,MAAAA,QAAQ,CAACxC,aAAD,CAAR;AACA,UAAIgB,YAAJ,EAAkBA,YAAY,CAAC,KAAD,CAAZ;;AAClB,UAAIgD,eAAe,EAAnB,EAAuB;AACrBjB,QAAAA,aAAa,CAAC,MAAD,EAAS,2CAAT,CAAb;AACD;AACF,KAdgB;;AAAA,oBAAXe,WAAW;AAAA;AAAA;AAAA,KAAjB;;AAgBA,MAAMG,eAAe,GAAIC,KAAD,IAAwC;AAC9D,QAAMC,IAAI,GAAGD,KAAK,CAACE,aAAN,CAAoBD,IAAjC;;AAEA,QAAME,qBAAqB,qBAAQxB,kBAAR,CAA3B;;AAEA,QAAMyB,GAAG,GAAGpE,WAAW,CAACgE,KAAK,CAACE,aAAN,CAAoBzB,KAArB,CAAvB;;AACA,QAAI2B,GAAJ,EAAS;AACP,aAAOD,qBAAqB,CAACF,IAAD,CAA5B;AAEAD,MAAAA,KAAK,CAACE,aAAN,CAAoBzB,KAApB,GAA4B2B,GAA5B;AACD,KAJD,MAIO;AACLD,MAAAA,qBAAqB,CAACF,IAAD,CAArB,GAA8B;AAC5BlB,QAAAA,OAAO,aAAMiB,KAAK,CAACE,aAAN,CAAoBzB,KAA1B,yBADqB;AAE5B4B,QAAAA,IAAI,EAAE;AAFsB,OAA9B;AAID;;AACD9B,IAAAA,YAAY,CAAC;AACX,OAACyB,KAAK,CAACE,aAAN,CAAoBD,IAArB,GAA4BD,KAAK,CAACE,aAAN,CAAoBzB,KADrC;AAEX,OAACzB,OAAD,GAAW;AAFA,KAAD,CAAZ;AAKA4B,IAAAA,qBAAqB,CAACuB,qBAAD,CAArB;AACD,GAtBD;;AAwBA,MAAML,eAAe,GAAG,MAAMtC,GAAG,CAAC8C,WAAJ,CAAgBR,eAAhB,EAA9B;;AAEA,MAAMS,oBAAoB,GACxBpC,MAAM,CAAC/B,OAAP,CAAeoE,IAAf,GAAsBC,MAAtB,KAAiC,CAAjC,IACAC,MAAM,CAACC,IAAP,CAAYhC,kBAAZ,EAAgC8B,MAAhC,GAAyC,CAF3C;AAIA,MAAMG,kBAAkB,GACtBL,oBAAoB,IAAIpC,MAAM,CAAC9B,MAAP,CAAcmE,IAAd,GAAqBC,MAArB,KAAgC,CAAxD,IAA6DzB,YAAY,EAD3E;AAGA,MAAM6B,mBAAmB,GAAG1C,MAAM,CAAC/B,OAAP,CAAeoE,IAAf,GAAsBC,MAAtB,KAAiC,CAA7D;AAEA,MAAMK,mBAAmB,GACvBP,oBAAoB,IAAI,CAACvB,YAAY,EAArC,IAA2Cc,eAAe,EAD5D;;AAGA,MAAMiB,WAAW;AAAA,kCAAG,WAAOrB,CAAP,EAAiC;AACnDA,MAAAA,CAAC,CAACsB,cAAF;;AACA,UAAInE,cAAJ,EAAoB;AAElBc,QAAAA,YAAY,CAAC2B,OAAb,CAAqB5D,YAArB,EAAmCoC,IAAI,CAACyB,SAAL,CAAe1C,cAAf,CAAnC;AACD;;AAED,YAAMW,GAAG,CAAC8C,WAAJ,CAAgBW,KAAhB,EAAN;AACD,KARgB;;AAAA,oBAAXF,WAAW;AAAA;AAAA;AAAA,KAAjB;;AAUA,SACE,oBAAC,aAAD;AAAe,IAAA,GAAG,EAAC;AAAnB,KACE,oBAAC,YAAD,QAAenE,KAAf,CADF,EAEE,oBAAC,QAAD;AAAU,IAAA,QAAQ,EAAC;AAAnB,oHAFF,EAME,oBAAC,UAAD;AACE,IAAA,MAAM,EAAEuB,MAAM,CAAClB,YAAD,CADhB;AAEE,IAAA,cAAc,EAAE,MAAM4B,aAAa,CAACV,MAAM,CAAClB,YAAD,CAAP,EAAuB,EAAvB,CAFrC;AAGE,IAAA,OAAO,EAAEkB,MAAM,CAACjB,YAAD,CAAN,KAAyB;AAHpC,KAKGiB,MAAM,CAACjB,YAAD,CALT,CANF,EAaE,oBAAC,aAAD;AACE,IAAA,OAAO,EAAC,0BADV;AAEE,IAAA,EAAE,EAAC,eAFL;AAGE,IAAA,OAAO,EAAE,KAHX;AAIE,IAAA,WAAW,EAAE,CAAC4C,eAAe;AAJ/B,KAME,oBAAC,aAAD;AAAe,IAAA,GAAG,EAAC,IAAnB;AAAwB,IAAA,EAAE,EAAC,IAA3B;AAAgC,IAAA,EAAE,EAAC;AAAnC,KACE,oBAAC,IAAD;AAAM,IAAA,kBAAkB,EAAEnB;AAA1B,KACE,oBAAC,QAAD;AAAU,IAAA,MAAM,EAAC;AAAjB,KACE,oBAAC,SAAD;AACE,IAAA,QAAQ,MADV;AAEE,IAAA,KAAK,EAAC,gBAFR;AAGE,IAAA,WAAW,EAAC,6CAHd;AAIE,IAAA,IAAI,EAAE5B,QAJR;AAKE,IAAA,KAAK,EAAEoB,MAAM,CAACpB,QAAD,CALf;AAME,IAAA,QAAQ,EAAEgD;AANZ,IADF,EASE,oBAAC,SAAD;AACE,IAAA,KAAK,EAAC,kBADR;AAEE,IAAA,WAAW,EAAC,4BAFd;AAGE,IAAA,IAAI,EAAE/C,OAHR;AAIE,IAAA,KAAK,EAAEmB,MAAM,CAACnB,OAAD,CAJf;AAKE,IAAA,QAAQ,EAAE;AALZ,IATF,CADF,CADF,EAoBE,oBAAC,SAAD;AAAW,IAAA,QAAQ,EAAC;AAApB,4DACsD,GADtD,EAEE,oBAAC,IAAD;AACE,IAAA,IAAI,EAAC,mGADP;AAEE,IAAA,MAAM,EAAC;AAFT,2BAFF,MApBF,EA8BE,oBAAC,QAAD;AAAU,IAAA,GAAG,EAAC,WAAd;AAA0B,IAAA,QAAQ,EAAC,MAAnC;AAA0C,IAAA,IAAI,EAAEI;AAAhD,IA9BF,EA+BE,oBAAC,KAAD,QACE,oBAAC,OAAD;AAAS,IAAA,OAAO,EAAC;AAAjB,KACE,oBAAC,iBAAD;AACE,IAAA,OAAO,EAAEwC,WADX;AAEE,IAAA,QAAQ,EAAEiB;AAFZ,aADF,CADF,EASE,oBAAC,OAAD;AAAS,IAAA,OAAO,mBAAY1C,MAAM,CAACpB,QAAD,CAAlB;AAAhB,KACE,oBAAC,iBAAD;AACE,IAAA,QAAQ,EAAEwD,oBADZ;AAEE,IAAA,OAAO,EAAEZ,YAFX;AAGE,IAAA,EAAE,EAAC;AAHL,cADF,CATF,EAkBE,oBAAC,OAAD;AAAS,IAAA,OAAO,EAAC;AAAjB,KACE,oBAAC,MAAD;AACE,IAAA,QAAQ,EAAEiB,kBADZ;AAEE,IAAA,OAAO,EAAEnB,UAFX;AAGE,IAAA,EAAE,EAAC;AAHL,YADF,CAlBF,CA/BF,CANF,CAbF,EAgFE,oBAAC,OAAD;AAAS,IAAA,UAAU,EAAC;AAApB,IAhFF,EAiFE,oBAAC,aAAD;AACE,IAAA,OAAO,EAAC,sBADV;AAEE,IAAA,OAAO,EAAE,KAFX;AAGE,IAAA,EAAE,EAAC,eAHL;AAIE,IAAA,WAAW,EAAE,CAACK,eAAe;AAJ/B,KAME,oBAAC,aAAD;AAAe,IAAA,EAAE,EAAC,IAAlB;AAAuB,IAAA,EAAE,EAAC;AAA1B,KACGA,eAAe,KACd,oBAAC,QAAD,iEADc,GAIZd,YAAY,KACd,0CACE,oBAAC,QAAD,QAAWnD,YAAX,CADF,CADc,GAKd,oBAAC,QAAD,yEAVJ,EAcE,oBAAC,OAAD;AACE,IAAA,OAAO,qBAAcsC,MAAM,CAACnB,OAAD,CAApB;AADT,KAGE,oBAAC,MAAD;AAAQ,IAAA,OAAO,EAAE+D,WAAjB;AAA8B,IAAA,QAAQ,EAAED;AAAxC,aAHF,CAdF,CANF,CAjFF,CADF;AAiHD,CAtSM","sourcesContent":["/*\n\n MIT License\n\n Copyright (c) 2021 Looker Data Sciences, Inc.\n\n Permission is hereby granted, free of charge, to any person obtaining a copy\n of this software and associated documentation files (the \"Software\"), to deal\n in the Software without restriction, including without limitation the rights\n to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n copies of the Software, and to permit persons to whom the Software is\n furnished to do so, subject to the following conditions:\n\n The above copyright notice and this permission notice shall be included in all\n copies or substantial portions of the Software.\n\n THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE\n SOFTWARE.\n\n */\n\nimport type { BaseSyntheticEvent, Dispatch, FC, FormEvent } from 'react'\nimport React, { useState, useEffect } from 'react'\nimport type { ValidationMessages, MessageBarIntent } from '@looker/components'\nimport {\n Button,\n ButtonTransparent,\n Divider,\n Fieldset,\n FieldText,\n Form,\n MessageBar,\n Paragraph,\n Link,\n Space,\n SpaceVertical,\n Tooltip,\n} from '@looker/components'\nimport { CodeCopy } from '@looker/code-editor'\nimport { getEnvAdaptor } from '@looker/extension-utils'\n\nimport type { RunItSetter, RunItValues } from '../..'\nimport {\n CollapserCard,\n RunItFormKey,\n RunItHeading,\n DarkSpan,\n readyToLogin,\n RunItNoConfig,\n} from '../..'\nimport type { ILoadedSpecs } from './configUtils'\nimport {\n RunItConfigKey,\n validateUrl,\n loadSpecsFromVersions,\n} from './configUtils'\n\nconst POSITIVE: MessageBarIntent = 'positive'\n\ninterface IFieldValues extends ILoadedSpecs {\n fetchIntent: MessageBarIntent\n}\n\nconst defaultFieldValues: IFieldValues = {\n baseUrl: '',\n webUrl: '',\n /** not currently used but declared for property compatibility for ILoadedSpecs */\n headless: false,\n specs: {},\n fetchResult: '',\n fetchIntent: POSITIVE,\n}\n\ninterface ConfigFormProps {\n setVersionsUrl: RunItSetter\n /** A collection type react state to store path, query and body parameters as entered by the user */\n requestContent: RunItValues\n /** Title for the config form */\n title?: string\n /** A set state callback which if present allows for editing, setting or clearing OAuth configuration parameters */\n setHasConfig?: Dispatch<boolean>\n}\n\nexport const ConfigForm: FC<ConfigFormProps> = ({\n setVersionsUrl,\n title,\n requestContent,\n setHasConfig,\n}) => {\n const BASE_URL = 'baseUrl'\n const WEB_URL = 'webUrl'\n const FETCH_INTENT = 'fetchIntent'\n const FETCH_RESULT = 'fetchResult'\n const CRITICAL: MessageBarIntent = 'critical'\n const appConfig = `{\n \"client_guid\": \"looker.api-explorer\",\n \"redirect_uri\": \"${(window as any).location.origin}/oauth\",\n \"display_name\": \"CORS API Explorer\",\n \"description\": \"Looker API Explorer using CORS\",\n \"enabled\": true\n}\n`\n const sdk = getEnvAdaptor().sdk\n // See https://codesandbox.io/s/youthful-surf-0g27j?file=/src/index.tsx for a prototype from Luke\n // TODO see about useReducer to clean this up a bit more\n title = title || 'RunIt Configuration'\n\n const getConfig = () => {\n // TODO: This is temporary until config settings are available in redux.\n // get configuration from storage, or default it\n const data = localStorage.getItem(RunItConfigKey)\n const result = data ? JSON.parse(data) : { base_url: '', looker_url: '' } // TODO why is RunItNoConfig undefined here?\n return result\n }\n\n const config = getConfig()\n const [fields, setFields] = useState<IFieldValues>(defaultFieldValues)\n const [saved, setSaved] = useState<RunItValues>(config)\n\n const updateFields = (\n nameOrValues: string | Partial<IFieldValues>,\n value = ''\n ) => {\n if (typeof nameOrValues === 'string') {\n setFields((previousFields) => {\n return { ...previousFields, ...{ [nameOrValues]: value } }\n })\n } else {\n setFields((previousFields) => {\n return { ...previousFields, ...nameOrValues }\n })\n }\n }\n\n useEffect(() => {\n const data = getConfig()\n const { base_url, looker_url } = data\n setSaved(data)\n updateFields({\n [BASE_URL]: base_url,\n [WEB_URL]: looker_url,\n [FETCH_INTENT]:\n base_url !== '' && looker_url !== '' ? POSITIVE : CRITICAL,\n })\n }, [])\n\n const [validationMessages, setValidationMessages] =\n useState<ValidationMessages>({})\n\n const updateMessage = (intent: MessageBarIntent, message: string) => {\n updateFields({ [FETCH_RESULT]: message, [FETCH_INTENT]: intent })\n }\n\n const isConfigured = () => {\n return (\n saved !== RunItNoConfig &&\n fields[BASE_URL] === saved.base_url &&\n fields[WEB_URL] === saved.looker_url\n )\n }\n\n const fetchError = (message: string) => {\n updateFields(WEB_URL, '')\n updateMessage(CRITICAL, message)\n }\n\n const updateForm = async (_e: BaseSyntheticEvent, save: boolean) => {\n // e.preventDefault()\n try {\n updateMessage('inform', '')\n const versionsUrl = `${fields.baseUrl}/versions`\n const { webUrl, baseUrl } = await loadSpecsFromVersions(versionsUrl)\n if (!baseUrl || !webUrl) {\n fetchError('Invalid server configuration')\n } else {\n updateFields({ [BASE_URL]: baseUrl, [WEB_URL]: webUrl })\n updateMessage(POSITIVE, 'Configuration is valid')\n if (save) {\n const data = { base_url: baseUrl, looker_url: webUrl }\n // TODO: replace when redux is introduced to run it\n localStorage.setItem(RunItConfigKey, JSON.stringify(data))\n if (setHasConfig) setHasConfig(true)\n setSaved(data)\n setVersionsUrl(versionsUrl)\n updateMessage(POSITIVE, `Saved ${webUrl} as OAuth server`)\n }\n }\n } catch (err: any) {\n fetchError(err.message)\n }\n }\n\n const handleSave = async (e: BaseSyntheticEvent) => {\n await updateForm(e, true)\n }\n\n const handleVerify = async (e: BaseSyntheticEvent) => {\n await updateForm(e, false)\n }\n\n const handleClear = async (_e: BaseSyntheticEvent) => {\n // TODO: replace when redux is introduced to run it\n localStorage.removeItem(RunItConfigKey)\n updateFields({\n [BASE_URL]: '',\n [WEB_URL]: '',\n [FETCH_INTENT]: CRITICAL,\n [FETCH_RESULT]: '',\n })\n setSaved(RunItNoConfig)\n if (setHasConfig) setHasConfig(false)\n if (isAuthenticated()) {\n updateMessage('warn', 'Please reload the browser page to log out')\n }\n }\n\n const handleUrlChange = (event: FormEvent<HTMLInputElement>) => {\n const name = event.currentTarget.name\n\n const newValidationMessages = { ...validationMessages }\n\n const url = validateUrl(event.currentTarget.value)\n if (url) {\n delete newValidationMessages[name]\n // Update URL if it's been cleaned up\n event.currentTarget.value = url\n } else {\n newValidationMessages[name] = {\n message: `'${event.currentTarget.value}' is not a valid url`,\n type: 'error',\n }\n }\n updateFields({\n [event.currentTarget.name]: event.currentTarget.value,\n [WEB_URL]: '',\n })\n\n setValidationMessages(newValidationMessages)\n }\n\n const isAuthenticated = () => sdk.authSession.isAuthenticated()\n\n const verifyButtonDisabled =\n fields.baseUrl.trim().length === 0 ||\n Object.keys(validationMessages).length > 0\n\n const saveButtonDisabled =\n verifyButtonDisabled || fields.webUrl.trim().length === 0 || isConfigured()\n\n const clearButtonDisabled = fields.baseUrl.trim().length === 0\n\n const loginButtonDisabled =\n verifyButtonDisabled || !isConfigured() || isAuthenticated()\n\n const handleLogin = async (e: BaseSyntheticEvent) => {\n e.preventDefault()\n if (requestContent) {\n // TODO: Replace when redux is introduced to run it\n localStorage.setItem(RunItFormKey, JSON.stringify(requestContent))\n }\n // This will set storage variables and return to OAuthScene when successful\n await sdk.authSession.login()\n }\n\n return (\n <SpaceVertical gap=\"u2\">\n <RunItHeading>{title}</RunItHeading>\n <DarkSpan fontSize=\"small\">\n To configure RunIt mode, you need to supply your API server URL, then\n authenticate into your Looker Instance\n </DarkSpan>\n <MessageBar\n intent={fields[FETCH_INTENT]}\n onPrimaryClick={() => updateMessage(fields[FETCH_INTENT], '')}\n visible={fields[FETCH_RESULT] !== ''}\n >\n {fields[FETCH_RESULT]}\n </MessageBar>\n <CollapserCard\n heading=\"1. Supply API Server URL\"\n id=\"server_config\"\n divider={false}\n defaultOpen={!isAuthenticated()}\n >\n <SpaceVertical gap=\"u2\" pt=\"u3\" px=\"u6\">\n <Form validationMessages={validationMessages}>\n <Fieldset legend=\"Server locations\">\n <FieldText\n required\n label=\"API server URL\"\n placeholder=\"typically https://myserver.looker.com:19999\"\n name={BASE_URL}\n value={fields[BASE_URL]}\n onChange={handleUrlChange}\n />\n <FieldText\n label=\"OAuth server URL\"\n placeholder=\"Click 'Verify' to retrieve\"\n name={WEB_URL}\n value={fields[WEB_URL]}\n disabled={true}\n />\n </Fieldset>\n </Form>\n <Paragraph fontSize=\"small\">\n The following configuration can be used to create a{' '}\n <Link\n href=\"https://github.com/looker-open-source/sdk-codegen/blob/main/docs/cors.md#reference-implementation\"\n target=\"_blank\"\n >\n Looker OAuth client\n </Link>\n .\n </Paragraph>\n <CodeCopy key=\"appConfig\" language=\"json\" code={appConfig} />\n <Space>\n <Tooltip content=\"Clear the configuration values\">\n <ButtonTransparent\n onClick={handleClear}\n disabled={clearButtonDisabled}\n >\n Clear\n </ButtonTransparent>\n </Tooltip>\n <Tooltip content={`Verify ${fields[BASE_URL]}`}>\n <ButtonTransparent\n disabled={verifyButtonDisabled}\n onClick={handleVerify}\n mr=\"small\"\n >\n Verify\n </ButtonTransparent>\n </Tooltip>\n <Tooltip content=\"Save the configuration for this browser\">\n <Button\n disabled={saveButtonDisabled}\n onClick={handleSave}\n mr=\"small\"\n >\n Save\n </Button>\n </Tooltip>\n </Space>\n </SpaceVertical>\n </CollapserCard>\n <Divider appearance=\"light\" />\n <CollapserCard\n heading=\"2. Login to instance\"\n divider={false}\n id=\"login_section\"\n defaultOpen={!isAuthenticated()}\n >\n <SpaceVertical pt=\"u3\" px=\"u6\">\n {isAuthenticated() ? (\n <DarkSpan>\n You are already logged in. Reload the page to log out.\n </DarkSpan>\n ) : isConfigured() ? (\n <>\n <DarkSpan>{readyToLogin}</DarkSpan>\n </>\n ) : (\n <DarkSpan>\n You will be able to login after you Verify your API Server URL\n </DarkSpan>\n )}\n <Tooltip\n content={`Login to ${fields[WEB_URL]} using OAuth to enable RunIt`}\n >\n <Button onClick={handleLogin} disabled={loginButtonDisabled}>\n Login\n </Button>\n </Tooltip>\n </SpaceVertical>\n </CollapserCard>\n </SpaceVertical>\n )\n}\n"],"file":"ConfigForm.js"}
1
+ {"version":3,"sources":["../../../../src/components/ConfigForm/ConfigForm.tsx"],"names":["React","useState","useEffect","Button","ButtonTransparent","Divider","Fieldset","FieldText","Form","MessageBar","Paragraph","Link","Space","SpaceVertical","Tooltip","CodeCopy","getEnvAdaptor","CollapserCard","RunItHeading","DarkSpan","readyToLogin","getVersions","RunItConfigKey","RunItNoConfig","RunItFormKey","validateUrl","POSITIVE","defaultFieldValues","baseUrl","webUrl","fetchResult","fetchIntent","ConfigForm","title","requestContent","setHasConfig","BASE_URL","WEB_URL","FETCH_INTENT","FETCH_RESULT","CRITICAL","appConfig","window","location","origin","adaptor","sdk","getConfig","data","localStorage","getItem","result","JSON","parse","config","fields","setFields","saved","setSaved","updateFields","nameOrValues","value","previousFields","base_url","looker_url","validationMessages","setValidationMessages","updateMessage","intent","message","isConfigured","fetchError","updateForm","_e","save","versionsUrl","web_server_url","api_server_url","setItem","stringify","e","handleSave","handleVerify","handleClear","removeItem","isAuthenticated","handleUrlChange","event","name","currentTarget","newValidationMessages","url","type","authSession","verifyButtonDisabled","trim","length","Object","keys","saveButtonDisabled","clearButtonDisabled","loginButtonDisabled","handleLogin","preventDefault","login"],"mappings":"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","sourcesContent":["/*\n\n MIT License\n\n Copyright (c) 2021 Looker Data Sciences, Inc.\n\n Permission is hereby granted, free of charge, to any person obtaining a copy\n of this software and associated documentation files (the \"Software\"), to deal\n in the Software without restriction, including without limitation the rights\n to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n copies of the Software, and to permit persons to whom the Software is\n furnished to do so, subject to the following conditions:\n\n The above copyright notice and this permission notice shall be included in all\n copies or substantial portions of the Software.\n\n THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE\n SOFTWARE.\n\n */\n\nimport type { BaseSyntheticEvent, Dispatch, FC, FormEvent } from 'react'\nimport React, { useState, useEffect } from 'react'\nimport type { ValidationMessages, MessageBarIntent } from '@looker/components'\nimport {\n Button,\n ButtonTransparent,\n Divider,\n Fieldset,\n FieldText,\n Form,\n MessageBar,\n Paragraph,\n Link,\n Space,\n SpaceVertical,\n Tooltip,\n} from '@looker/components'\nimport { CodeCopy } from '@looker/code-editor'\nimport { getEnvAdaptor } from '@looker/extension-utils'\nimport type { ILookerVersions } from '@looker/sdk-codegen'\n\nimport type { RunItValues } from '../..'\nimport { CollapserCard, RunItHeading, DarkSpan, readyToLogin } from '../..'\nimport {\n getVersions,\n RunItConfigKey,\n RunItNoConfig,\n RunItFormKey,\n validateUrl,\n} from './utils'\n\nconst POSITIVE: MessageBarIntent = 'positive'\n\ninterface IFieldValues {\n baseUrl: string\n webUrl: string\n fetchIntent: MessageBarIntent\n fetchResult: string\n}\n\nconst defaultFieldValues: IFieldValues = {\n baseUrl: '',\n webUrl: '',\n fetchResult: '',\n fetchIntent: POSITIVE,\n}\n\ninterface ConfigFormProps {\n /** A collection type react state to store path, query and body parameters as entered by the user */\n requestContent: RunItValues\n /** Title for the config form */\n title?: string\n /** A set state callback which if present allows for editing, setting or clearing OAuth configuration parameters */\n setHasConfig?: Dispatch<boolean>\n}\n\nexport const ConfigForm: FC<ConfigFormProps> = ({\n title,\n requestContent,\n setHasConfig,\n}) => {\n const BASE_URL = 'baseUrl'\n const WEB_URL = 'webUrl'\n const FETCH_INTENT = 'fetchIntent'\n const FETCH_RESULT = 'fetchResult'\n const CRITICAL: MessageBarIntent = 'critical'\n const appConfig = `{\n \"client_guid\": \"looker.api-explorer\",\n \"redirect_uri\": \"${(window as any).location.origin}/oauth\",\n \"display_name\": \"CORS API Explorer\",\n \"description\": \"Looker API Explorer using CORS\",\n \"enabled\": true\n}\n`\n const adaptor = getEnvAdaptor()\n const sdk = adaptor.sdk\n // See https://codesandbox.io/s/youthful-surf-0g27j?file=/src/index.tsx for a prototype from Luke\n // TODO see about useReducer to clean this up a bit more\n title = title || 'RunIt Configuration'\n\n const getConfig = () => {\n // TODO: This is temporary until config settings are available in redux.\n // get configuration from storage, or default it\n const data = localStorage.getItem(RunItConfigKey)\n const result = data ? JSON.parse(data) : RunItNoConfig\n return result\n }\n\n const config = getConfig()\n const [fields, setFields] = useState<IFieldValues>(defaultFieldValues)\n const [saved, setSaved] = useState<RunItValues>(config)\n\n const updateFields = (\n nameOrValues: string | Partial<IFieldValues>,\n value = ''\n ) => {\n if (typeof nameOrValues === 'string') {\n setFields((previousFields) => {\n return { ...previousFields, ...{ [nameOrValues]: value } }\n })\n } else {\n setFields((previousFields) => {\n return { ...previousFields, ...nameOrValues }\n })\n }\n }\n\n useEffect(() => {\n const data = getConfig()\n const { base_url, looker_url } = data\n setSaved(data)\n updateFields({\n [BASE_URL]: base_url,\n [WEB_URL]: looker_url,\n [FETCH_INTENT]:\n base_url !== '' && looker_url !== '' ? POSITIVE : CRITICAL,\n })\n }, [])\n\n const [validationMessages, setValidationMessages] =\n useState<ValidationMessages>({})\n\n const updateMessage = (intent: MessageBarIntent, message: string) => {\n updateFields({ [FETCH_RESULT]: message, [FETCH_INTENT]: intent })\n }\n\n const isConfigured = () => {\n return (\n saved !== RunItNoConfig &&\n fields[BASE_URL] === saved.base_url &&\n fields[WEB_URL] === saved.looker_url\n )\n }\n\n const fetchError = (message: string) => {\n updateFields(WEB_URL, '')\n updateMessage(CRITICAL, message)\n }\n\n const updateForm = async (_e: BaseSyntheticEvent, save: boolean) => {\n updateMessage('inform', '')\n const versionsUrl = `${fields.baseUrl}/versions`\n try {\n const { web_server_url: webUrl, api_server_url: baseUrl } =\n (await getVersions(versionsUrl)) as ILookerVersions\n updateFields({\n [BASE_URL]: baseUrl,\n [WEB_URL]: webUrl,\n })\n updateMessage(POSITIVE, 'Configuration is valid')\n if (save) {\n const data = { base_url: baseUrl, looker_url: webUrl }\n // TODO: replace when redux is introduced to run it\n localStorage.setItem(RunItConfigKey, JSON.stringify(data))\n if (setHasConfig) setHasConfig(true)\n setSaved(data)\n updateMessage(POSITIVE, `Saved ${webUrl} as OAuth server`)\n }\n } catch (e: any) {\n fetchError(e.message)\n }\n }\n\n const handleSave = async (e: BaseSyntheticEvent) => {\n await updateForm(e, true)\n }\n\n const handleVerify = async (e: BaseSyntheticEvent) => {\n await updateForm(e, false)\n }\n\n const handleClear = async (_e: BaseSyntheticEvent) => {\n // TODO: replace when redux is introduced to run it\n localStorage.removeItem(RunItConfigKey)\n updateFields({\n [BASE_URL]: '',\n [WEB_URL]: '',\n [FETCH_INTENT]: CRITICAL,\n [FETCH_RESULT]: '',\n })\n setSaved(RunItNoConfig)\n if (setHasConfig) setHasConfig(false)\n if (isAuthenticated()) {\n updateMessage('warn', 'Please reload the browser page to log out')\n }\n }\n\n const handleUrlChange = (event: FormEvent<HTMLInputElement>) => {\n const name = event.currentTarget.name\n\n const newValidationMessages = { ...validationMessages }\n\n const url = validateUrl(event.currentTarget.value)\n if (url) {\n delete newValidationMessages[name]\n // Update URL if it's been cleaned up\n event.currentTarget.value = url\n } else {\n newValidationMessages[name] = {\n message: `'${event.currentTarget.value}' is not a valid url`,\n type: 'error',\n }\n }\n updateFields({\n [event.currentTarget.name]: event.currentTarget.value,\n [WEB_URL]: '',\n })\n\n setValidationMessages(newValidationMessages)\n }\n\n const isAuthenticated = () => sdk.authSession.isAuthenticated()\n\n const verifyButtonDisabled =\n fields.baseUrl.trim().length === 0 ||\n Object.keys(validationMessages).length > 0\n\n const saveButtonDisabled =\n verifyButtonDisabled || fields.webUrl.trim().length === 0 || isConfigured()\n\n const clearButtonDisabled = fields.baseUrl.trim().length === 0\n\n const loginButtonDisabled =\n verifyButtonDisabled || !isConfigured() || isAuthenticated()\n\n const handleLogin = async (e: BaseSyntheticEvent) => {\n e.preventDefault()\n if (requestContent) {\n // TODO: Replace when redux is introduced to run it\n localStorage.setItem(RunItFormKey, JSON.stringify(requestContent))\n }\n // This will set storage variables and return to OAuthScene when successful\n await adaptor.login()\n }\n\n return (\n <SpaceVertical gap=\"u2\">\n <RunItHeading>{title}</RunItHeading>\n <DarkSpan fontSize=\"small\">\n To configure RunIt mode, you need to supply your API server URL, then\n authenticate into your Looker Instance\n </DarkSpan>\n <MessageBar\n intent={fields[FETCH_INTENT]}\n onPrimaryClick={() => updateMessage(fields[FETCH_INTENT], '')}\n visible={fields[FETCH_RESULT] !== ''}\n >\n {fields[FETCH_RESULT]}\n </MessageBar>\n <CollapserCard\n heading=\"1. Supply API Server URL\"\n id=\"server_config\"\n divider={false}\n defaultOpen={!isAuthenticated()}\n >\n <SpaceVertical gap=\"u2\" pt=\"u3\" px=\"u6\">\n <Form validationMessages={validationMessages}>\n <Fieldset legend=\"Server locations\">\n <FieldText\n required\n label=\"API server URL\"\n placeholder=\"typically https://myserver.looker.com:19999\"\n name={BASE_URL}\n value={fields[BASE_URL]}\n onChange={handleUrlChange}\n />\n <FieldText\n label=\"OAuth server URL\"\n placeholder=\"Click 'Verify' to retrieve\"\n name={WEB_URL}\n value={fields[WEB_URL]}\n disabled={true}\n />\n </Fieldset>\n </Form>\n <Paragraph fontSize=\"small\">\n The following configuration can be used to create a{' '}\n <Link\n href=\"https://github.com/looker-open-source/sdk-codegen/blob/main/docs/cors.md#reference-implementation\"\n target=\"_blank\"\n >\n Looker OAuth client\n </Link>\n .\n </Paragraph>\n <CodeCopy key=\"appConfig\" language=\"json\" code={appConfig} />\n <Space>\n <Tooltip content=\"Clear the configuration values\">\n <ButtonTransparent\n onClick={handleClear}\n disabled={clearButtonDisabled}\n >\n Clear\n </ButtonTransparent>\n </Tooltip>\n <Tooltip content={`Verify ${fields[BASE_URL]}`}>\n <ButtonTransparent\n disabled={verifyButtonDisabled}\n onClick={handleVerify}\n mr=\"small\"\n >\n Verify\n </ButtonTransparent>\n </Tooltip>\n <Tooltip content=\"Save the configuration for this browser\">\n <Button\n disabled={saveButtonDisabled}\n onClick={handleSave}\n mr=\"small\"\n >\n Save\n </Button>\n </Tooltip>\n </Space>\n </SpaceVertical>\n </CollapserCard>\n <Divider appearance=\"light\" />\n <CollapserCard\n heading=\"2. Login to instance\"\n divider={false}\n id=\"login_section\"\n defaultOpen={!isAuthenticated()}\n >\n <SpaceVertical pt=\"u3\" px=\"u6\">\n {isAuthenticated() ? (\n <DarkSpan>\n You are already logged in. Reload the page to log out.\n </DarkSpan>\n ) : isConfigured() ? (\n <>\n <DarkSpan>{readyToLogin}</DarkSpan>\n </>\n ) : (\n <DarkSpan>\n You will be able to login after you Verify your API Server URL\n </DarkSpan>\n )}\n <Tooltip\n content={`Login to ${fields[WEB_URL]} using OAuth to enable RunIt`}\n >\n <Button onClick={handleLogin} disabled={loginButtonDisabled}>\n Login\n </Button>\n </Tooltip>\n </SpaceVertical>\n </CollapserCard>\n </SpaceVertical>\n )\n}\n"],"file":"ConfigForm.js"}
@@ -1,3 +1,3 @@
1
1
  export * from './ConfigForm';
2
- export * from './configUtils';
2
+ export * from './utils';
3
3
  //# sourceMappingURL=index.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../../src/components/ConfigForm/index.ts"],"names":[],"mappings":"AA0BA,cAAc,cAAd;AACA,cAAc,eAAd","sourcesContent":["/*\n\n MIT License\n\n Copyright (c) 2021 Looker Data Sciences, Inc.\n\n Permission is hereby granted, free of charge, to any person obtaining a copy\n of this software and associated documentation files (the \"Software\"), to deal\n in the Software without restriction, including without limitation the rights\n to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n copies of the Software, and to permit persons to whom the Software is\n furnished to do so, subject to the following conditions:\n\n The above copyright notice and this permission notice shall be included in all\n copies or substantial portions of the Software.\n\n THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE\n SOFTWARE.\n\n */\n\nexport * from './ConfigForm'\nexport * from './configUtils'\n"],"file":"index.js"}
1
+ {"version":3,"sources":["../../../../src/components/ConfigForm/index.ts"],"names":[],"mappings":"AA0BA,cAAc,cAAd;AACA,cAAc,SAAd","sourcesContent":["/*\n\n MIT License\n\n Copyright (c) 2021 Looker Data Sciences, Inc.\n\n Permission is hereby granted, free of charge, to any person obtaining a copy\n of this software and associated documentation files (the \"Software\"), to deal\n in the Software without restriction, including without limitation the rights\n to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n copies of the Software, and to permit persons to whom the Software is\n furnished to do so, subject to the following conditions:\n\n The above copyright notice and this permission notice shall be included in all\n copies or substantial portions of the Software.\n\n THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE\n SOFTWARE.\n\n */\n\nexport * from './ConfigForm'\nexport * from './utils'\n"],"file":"index.js"}
@@ -0,0 +1,61 @@
1
+ function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) { symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); } keys.push.apply(keys, symbols); } return keys; }
2
+
3
+ function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
4
+
5
+ function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
6
+
7
+ function asyncGeneratorStep(gen, resolve, reject, _next, _throw, key, arg) { try { var info = gen[key](arg); var value = info.value; } catch (error) { reject(error); return; } if (info.done) { resolve(value); } else { Promise.resolve(value).then(_next, _throw); } }
8
+
9
+ function _asyncToGenerator(fn) { return function () { var self = this, args = arguments; return new Promise(function (resolve, reject) { var gen = fn.apply(self, args); function _next(value) { asyncGeneratorStep(gen, resolve, reject, _next, _throw, "next", value); } function _throw(err) { asyncGeneratorStep(gen, resolve, reject, _next, _throw, "throw", err); } _next(undefined); }); }; }
10
+
11
+ import { BrowserTransport, DefaultSettings } from '@looker/sdk-rtl';
12
+ export var RunItConfigKey = 'RunItConfig';
13
+ export var RunItFormKey = 'RunItForm';
14
+ export var RunItNoConfig = {
15
+ base_url: '',
16
+ looker_url: ''
17
+ };
18
+ export var getUrl = function () {
19
+ var _ref = _asyncToGenerator(function* (url) {
20
+ var settings = _objectSpread(_objectSpread({}, DefaultSettings()), {
21
+ base_url: url,
22
+ verify_ssl: false
23
+ });
24
+
25
+ var xp = new BrowserTransport(settings);
26
+ var response = yield xp.rawRequest('GET', url);
27
+ return response.body;
28
+ });
29
+
30
+ return function getUrl(_x) {
31
+ return _ref.apply(this, arguments);
32
+ };
33
+ }();
34
+ export var getVersions = function () {
35
+ var _ref2 = _asyncToGenerator(function* (versionsUrl) {
36
+ var versions;
37
+
38
+ try {
39
+ var content = yield getUrl(versionsUrl);
40
+ versions = typeof content === 'string' ? JSON.parse(content) : content;
41
+ } catch (_unused) {
42
+ throw new Error('Invalid server configuration');
43
+ }
44
+
45
+ return versions;
46
+ });
47
+
48
+ return function getVersions(_x2) {
49
+ return _ref2.apply(this, arguments);
50
+ };
51
+ }();
52
+ export var validateUrl = url => {
53
+ try {
54
+ var result = new URL(url);
55
+ if (url.endsWith(':')) return url;
56
+ return result.origin;
57
+ } catch (_unused2) {
58
+ return '';
59
+ }
60
+ };
61
+ //# sourceMappingURL=utils.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../../src/components/ConfigForm/utils.ts"],"names":["BrowserTransport","DefaultSettings","RunItConfigKey","RunItFormKey","RunItNoConfig","base_url","looker_url","getUrl","url","settings","verify_ssl","xp","response","rawRequest","body","getVersions","versionsUrl","versions","content","JSON","parse","Error","validateUrl","result","URL","endsWith","origin"],"mappings":";;;;;;;;;;AA0BA,SAASA,gBAAT,EAA2BC,eAA3B,QAAkD,iBAAlD;AAIA,OAAO,IAAMC,cAAc,GAAG,aAAvB;AACP,OAAO,IAAMC,YAAY,GAAG,WAArB;AACP,OAAO,IAAMC,aAAa,GAAG;AAAEC,EAAAA,QAAQ,EAAE,EAAZ;AAAgBC,EAAAA,UAAU,EAAE;AAA5B,CAAtB;AAMP,OAAO,IAAMC,MAAM;AAAA,+BAAG,WAAOC,GAAP,EAAsD;AAC1E,QAAMC,QAAQ,mCACTR,eAAe,EADN,GAET;AAAEI,MAAAA,QAAQ,EAAEG,GAAZ;AAAiBE,MAAAA,UAAU,EAAE;AAA7B,KAFS,CAAd;;AAIA,QAAMC,EAAE,GAAG,IAAIX,gBAAJ,CAAqBS,QAArB,CAAX;AACA,QAAMG,QAAQ,SAASD,EAAE,CAACE,UAAH,CAAc,KAAd,EAAqBL,GAArB,CAAvB;AACA,WAAOI,QAAQ,CAACE,IAAhB;AACD,GARkB;;AAAA,kBAANP,MAAM;AAAA;AAAA;AAAA,GAAZ;AAcP,OAAO,IAAMQ,WAAW;AAAA,gCAAG,WACzBC,WADyB,EAEgB;AACzC,QAAIC,QAAJ;;AACA,QAAI;AACF,UAAMC,OAAO,SAASX,MAAM,CAACS,WAAD,CAA5B;AACAC,MAAAA,QAAQ,GAAG,OAAOC,OAAP,KAAmB,QAAnB,GAA8BC,IAAI,CAACC,KAAL,CAAWF,OAAX,CAA9B,GAAoDA,OAA/D;AACD,KAHD,CAGE,gBAAM;AACN,YAAM,IAAIG,KAAJ,CAAU,8BAAV,CAAN;AACD;;AACD,WAAOJ,QAAP;AACD,GAXuB;;AAAA,kBAAXF,WAAW;AAAA;AAAA;AAAA,GAAjB;AAkBP,OAAO,IAAMO,WAAW,GAAId,GAAD,IAAyB;AAClD,MAAI;AACF,QAAMe,MAAM,GAAG,IAAIC,GAAJ,CAAQhB,GAAR,CAAf;AACA,QAAIA,GAAG,CAACiB,QAAJ,CAAa,GAAb,CAAJ,EAAuB,OAAOjB,GAAP;AACvB,WAAOe,MAAM,CAACG,MAAd;AACD,GAJD,CAIE,iBAAM;AACN,WAAO,EAAP;AACD;AACF,CARM","sourcesContent":["/*\n\n MIT License\n\n Copyright (c) 2021 Looker Data Sciences, Inc.\n\n Permission is hereby granted, free of charge, to any person obtaining a copy\n of this software and associated documentation files (the \"Software\"), to deal\n in the Software without restriction, including without limitation the rights\n to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n copies of the Software, and to permit persons to whom the Software is\n furnished to do so, subject to the following conditions:\n\n The above copyright notice and this permission notice shall be included in all\n copies or substantial portions of the Software.\n\n THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE\n SOFTWARE.\n\n */\nimport type { ILookerVersions } from '@looker/sdk-codegen'\nimport { BrowserTransport, DefaultSettings } from '@looker/sdk-rtl'\n\nimport type { RunItValues } from '../..'\n\nexport const RunItConfigKey = 'RunItConfig'\nexport const RunItFormKey = 'RunItForm'\nexport const RunItNoConfig = { base_url: '', looker_url: '' }\n\n/**\n * Use the browser transport to GET a url\n * @param url to fetch\n */\nexport const getUrl = async (url: string): Promise<string | RunItValues> => {\n const settings = {\n ...DefaultSettings(),\n ...{ base_url: url, verify_ssl: false },\n }\n const xp = new BrowserTransport(settings)\n const response = await xp.rawRequest('GET', url)\n return response.body\n}\n\n/**\n * Gets the versions payload given a versions url\n * @param versionsUrl\n */\nexport const getVersions = async (\n versionsUrl: string\n): Promise<ILookerVersions | undefined> => {\n let versions\n try {\n const content = await getUrl(versionsUrl)\n versions = typeof content === 'string' ? JSON.parse(content) : content\n } catch {\n throw new Error('Invalid server configuration')\n }\n return versions\n}\n\n/**\n * Validates URL and standardizes it\n * @param url to validate\n * @returns the standardized url.origin if it's valid, or an empty string if it's not\n */\nexport const validateUrl = (url: string): string => {\n try {\n const result = new URL(url)\n if (url.endsWith(':')) return url\n return result.origin\n } catch {\n return ''\n }\n}\n"],"file":"utils.js"}
@@ -7,6 +7,7 @@ import { Button, Tooltip } from '@looker/components';
7
7
  import { getEnvAdaptor } from '@looker/extension-utils';
8
8
  import { RunItFormKey } from '../ConfigForm';
9
9
  export var readyToLogin = 'OAuth is configured but your browser session is not authenticated. Click Login to enable RunIt.';
10
+ export var notReadyToLogin = 'OAuth is not configured. Configure it to be able to Login.';
10
11
  export var LoginForm = _ref => {
11
12
  var {
12
13
  requestContent
@@ -21,7 +22,7 @@ export var LoginForm = _ref => {
21
22
  adaptor.localStorageSetItem(RunItFormKey, JSON.stringify(requestContent));
22
23
  }
23
24
 
24
- yield adaptor.sdk.authSession.login();
25
+ yield adaptor.login();
25
26
  });
26
27
 
27
28
  return function handleLogin(_x) {
@@ -30,7 +31,7 @@ export var LoginForm = _ref => {
30
31
  }();
31
32
 
32
33
  return React.createElement(Tooltip, {
33
- content: readyToLogin
34
+ content: adaptor.sdk.authSession.settings.authIsConfigured() ? readyToLogin : notReadyToLogin
34
35
  }, React.createElement(Button, {
35
36
  onClick: handleLogin
36
37
  }, "Login"));
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../../src/components/LoginForm/LoginForm.tsx"],"names":["React","Button","Tooltip","getEnvAdaptor","RunItFormKey","readyToLogin","LoginForm","requestContent","adaptor","handleLogin","e","preventDefault","localStorageSetItem","JSON","stringify","sdk","authSession","login"],"mappings":";;;;AA2BA,OAAOA,KAAP,MAAkB,OAAlB;AACA,SAASC,MAAT,EAAiBC,OAAjB,QAAgC,oBAAhC;AACA,SAASC,aAAT,QAA8B,yBAA9B;AAEA,SAASC,YAAT,QAA6B,eAA7B;AAOA,OAAO,IAAMC,YAAY,GACvB,iGADK;AAGP,OAAO,IAAMC,SAA6B,GAAG,QAAwB;AAAA,MAAvB;AAAEC,IAAAA;AAAF,GAAuB;AACnE,MAAMC,OAAO,GAAGL,aAAa,EAA7B;;AAEA,MAAMM,WAAW;AAAA,kCAAG,WAAOC,CAAP,EAAiC;AACnDA,MAAAA,CAAC,CAACC,cAAF;;AACA,UAAIJ,cAAJ,EAAoB;AAClBC,QAAAA,OAAO,CAACI,mBAAR,CAA4BR,YAA5B,EAA0CS,IAAI,CAACC,SAAL,CAAeP,cAAf,CAA1C;AACD;;AAED,YAAMC,OAAO,CAACO,GAAR,CAAYC,WAAZ,CAAwBC,KAAxB,EAAN;AACD,KAPgB;;AAAA,oBAAXR,WAAW;AAAA;AAAA;AAAA,KAAjB;;AASA,SACE,oBAAC,OAAD;AAAS,IAAA,OAAO,EAAEJ;AAAlB,KACE,oBAAC,MAAD;AAAQ,IAAA,OAAO,EAAEI;AAAjB,aADF,CADF;AAKD,CAjBM","sourcesContent":["/*\n\n MIT License\n\n Copyright (c) 2021 Looker Data Sciences, Inc.\n\n Permission is hereby granted, free of charge, to any person obtaining a copy\n of this software and associated documentation files (the \"Software\"), to deal\n in the Software without restriction, including without limitation the rights\n to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n copies of the Software, and to permit persons to whom the Software is\n furnished to do so, subject to the following conditions:\n\n The above copyright notice and this permission notice shall be included in all\n copies or substantial portions of the Software.\n\n THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE\n SOFTWARE.\n\n */\n\nimport type { BaseSyntheticEvent, FC } from 'react'\nimport React from 'react'\nimport { Button, Tooltip } from '@looker/components'\nimport { getEnvAdaptor } from '@looker/extension-utils'\n\nimport { RunItFormKey } from '../ConfigForm'\nimport type { RunItValues } from '../..'\n\ninterface LoginFormProps {\n requestContent: RunItValues\n}\n\nexport const readyToLogin =\n 'OAuth is configured but your browser session is not authenticated. Click Login to enable RunIt.'\n\nexport const LoginForm: FC<LoginFormProps> = ({ requestContent }) => {\n const adaptor = getEnvAdaptor()\n\n const handleLogin = async (e: BaseSyntheticEvent) => {\n e.preventDefault()\n if (requestContent) {\n adaptor.localStorageSetItem(RunItFormKey, JSON.stringify(requestContent))\n }\n // This will set storage variables and return to OAuthScene when successful\n await adaptor.sdk.authSession.login()\n }\n\n return (\n <Tooltip content={readyToLogin}>\n <Button onClick={handleLogin}>Login</Button>\n </Tooltip>\n )\n}\n"],"file":"LoginForm.js"}
1
+ {"version":3,"sources":["../../../../src/components/LoginForm/LoginForm.tsx"],"names":["React","Button","Tooltip","getEnvAdaptor","RunItFormKey","readyToLogin","notReadyToLogin","LoginForm","requestContent","adaptor","handleLogin","e","preventDefault","localStorageSetItem","JSON","stringify","login","sdk","authSession","settings","authIsConfigured"],"mappings":";;;;AA2BA,OAAOA,KAAP,MAAkB,OAAlB;AACA,SAASC,MAAT,EAAiBC,OAAjB,QAAgC,oBAAhC;AAEA,SAASC,aAAT,QAA8B,yBAA9B;AAEA,SAASC,YAAT,QAA6B,eAA7B;AAOA,OAAO,IAAMC,YAAY,GACvB,iGADK;AAGP,OAAO,IAAMC,eAAe,GAC1B,4DADK;AAGP,OAAO,IAAMC,SAA6B,GAAG,QAAwB;AAAA,MAAvB;AAAEC,IAAAA;AAAF,GAAuB;AACnE,MAAMC,OAAO,GAAGN,aAAa,EAA7B;;AACA,MAAMO,WAAW;AAAA,kCAAG,WAAOC,CAAP,EAAiC;AACnDA,MAAAA,CAAC,CAACC,cAAF;;AACA,UAAIJ,cAAJ,EAAoB;AAClBC,QAAAA,OAAO,CAACI,mBAAR,CAA4BT,YAA5B,EAA0CU,IAAI,CAACC,SAAL,CAAeP,cAAf,CAA1C;AACD;;AAED,YAAMC,OAAO,CAACO,KAAR,EAAN;AACD,KAPgB;;AAAA,oBAAXN,WAAW;AAAA;AAAA;AAAA,KAAjB;;AASA,SACE,oBAAC,OAAD;AACE,IAAA,OAAO,EAEHD,OAAO,CAACQ,GAAR,CAAYC,WAAZ,CAAwBC,QAD1B,CAEEC,gBAFF,KAGIf,YAHJ,GAIIC;AANR,KASE,oBAAC,MAAD;AAAQ,IAAA,OAAO,EAAEI;AAAjB,aATF,CADF;AAaD,CAxBM","sourcesContent":["/*\n\n MIT License\n\n Copyright (c) 2021 Looker Data Sciences, Inc.\n\n Permission is hereby granted, free of charge, to any person obtaining a copy\n of this software and associated documentation files (the \"Software\"), to deal\n in the Software without restriction, including without limitation the rights\n to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n copies of the Software, and to permit persons to whom the Software is\n furnished to do so, subject to the following conditions:\n\n The above copyright notice and this permission notice shall be included in all\n copies or substantial portions of the Software.\n\n THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE\n SOFTWARE.\n\n */\n\nimport type { BaseSyntheticEvent, FC } from 'react'\nimport React from 'react'\nimport { Button, Tooltip } from '@looker/components'\nimport type { OAuthConfigProvider } from '@looker/extension-utils'\nimport { getEnvAdaptor } from '@looker/extension-utils'\n\nimport { RunItFormKey } from '../ConfigForm'\nimport type { RunItValues } from '../..'\n\ninterface LoginFormProps {\n requestContent: RunItValues\n}\n\nexport const readyToLogin =\n 'OAuth is configured but your browser session is not authenticated. Click Login to enable RunIt.'\n\nexport const notReadyToLogin =\n 'OAuth is not configured. Configure it to be able to Login.'\n\nexport const LoginForm: FC<LoginFormProps> = ({ requestContent }) => {\n const adaptor = getEnvAdaptor()\n const handleLogin = async (e: BaseSyntheticEvent) => {\n e.preventDefault()\n if (requestContent) {\n adaptor.localStorageSetItem(RunItFormKey, JSON.stringify(requestContent))\n }\n // This will set storage variables and return to OAuthScene when successful\n await adaptor.login()\n }\n\n return (\n <Tooltip\n content={\n (\n adaptor.sdk.authSession.settings as OAuthConfigProvider\n ).authIsConfigured()\n ? readyToLogin\n : notReadyToLogin\n }\n >\n <Button onClick={handleLogin}>Login</Button>\n </Tooltip>\n )\n}\n"],"file":"LoginForm.js"}