@looker/run-it 0.9.21 → 0.9.25
Sign up to get free protection for your applications and to get access to all the features.
- package/CHANGELOG.md +74 -1
- package/lib/RunIt.d.ts +2 -0
- package/lib/RunIt.js +20 -27
- package/lib/RunIt.js.map +1 -1
- package/lib/RunItProvider.d.ts +0 -4
- package/lib/RunItProvider.js +2 -7
- package/lib/RunItProvider.js.map +1 -1
- package/lib/components/ConfigForm/ConfigForm.d.ts +0 -4
- package/lib/components/ConfigForm/ConfigForm.js +12 -11
- package/lib/components/ConfigForm/ConfigForm.js.map +1 -1
- package/lib/components/ConfigForm/configUtils.js +6 -4
- package/lib/components/ConfigForm/configUtils.js.map +1 -1
- package/lib/components/DocSdkCalls/DocMultiCall.d.ts +5 -2
- package/lib/components/DocSdkCalls/DocMultiCall.js +7 -19
- package/lib/components/DocSdkCalls/DocMultiCall.js.map +1 -1
- package/lib/components/DocSdkCalls/DocSdkCalls.js +26 -9
- package/lib/components/DocSdkCalls/DocSdkCalls.js.map +1 -1
- package/lib/components/LoginForm/LoginForm.d.ts +2 -8
- package/lib/components/LoginForm/LoginForm.js +5 -6
- package/lib/components/LoginForm/LoginForm.js.map +1 -1
- package/lib/components/PerfTracker/PerfTracker.d.ts +0 -2
- package/lib/components/PerfTracker/PerfTracker.js +7 -8
- package/lib/components/PerfTracker/PerfTracker.js.map +1 -1
- package/lib/components/RequestForm/RequestForm.d.ts +0 -4
- package/lib/components/RequestForm/RequestForm.js +0 -7
- package/lib/components/RequestForm/RequestForm.js.map +1 -1
- package/lib/components/RequestForm/formUtils.d.ts +1 -1
- package/lib/components/RequestForm/formUtils.js +25 -10
- package/lib/components/RequestForm/formUtils.js.map +1 -1
- package/lib/components/common/index.d.ts +0 -1
- package/lib/components/common/index.js +0 -18
- package/lib/components/common/index.js.map +1 -1
- package/lib/esm/RunIt.js +20 -28
- package/lib/esm/RunIt.js.map +1 -1
- package/lib/esm/RunItProvider.js +2 -7
- package/lib/esm/RunItProvider.js.map +1 -1
- package/lib/esm/components/ConfigForm/ConfigForm.js +12 -12
- package/lib/esm/components/ConfigForm/ConfigForm.js.map +1 -1
- package/lib/esm/components/ConfigForm/configUtils.js +6 -4
- package/lib/esm/components/ConfigForm/configUtils.js.map +1 -1
- package/lib/esm/components/DocSdkCalls/DocMultiCall.js +8 -19
- package/lib/esm/components/DocSdkCalls/DocMultiCall.js.map +1 -1
- package/lib/esm/components/DocSdkCalls/DocSdkCalls.js +25 -10
- package/lib/esm/components/DocSdkCalls/DocSdkCalls.js.map +1 -1
- package/lib/esm/components/LoginForm/LoginForm.js +5 -6
- package/lib/esm/components/LoginForm/LoginForm.js.map +1 -1
- package/lib/esm/components/PerfTracker/PerfTracker.js +7 -8
- package/lib/esm/components/PerfTracker/PerfTracker.js.map +1 -1
- package/lib/esm/components/RequestForm/RequestForm.js +0 -7
- package/lib/esm/components/RequestForm/RequestForm.js.map +1 -1
- package/lib/esm/components/RequestForm/formUtils.js +25 -10
- package/lib/esm/components/RequestForm/formUtils.js.map +1 -1
- package/lib/esm/components/common/index.js +0 -1
- package/lib/esm/components/common/index.js.map +1 -1
- package/lib/esm/scenes/OAuthScene/OAuthScene.js +3 -6
- package/lib/esm/scenes/OAuthScene/OAuthScene.js.map +1 -1
- package/lib/esm/utils/RunItSDK.js +12 -77
- package/lib/esm/utils/RunItSDK.js.map +1 -1
- package/lib/esm/utils/requestUtils.js +21 -14
- package/lib/esm/utils/requestUtils.js.map +1 -1
- package/lib/scenes/OAuthScene/OAuthScene.js +2 -5
- package/lib/scenes/OAuthScene/OAuthScene.js.map +1 -1
- package/lib/test-data/responses.js +9 -0
- package/lib/test-data/responses.js.map +1 -1
- package/lib/utils/RunItSDK.d.ts +3 -16
- package/lib/utils/RunItSDK.js +15 -87
- package/lib/utils/RunItSDK.js.map +1 -1
- package/lib/utils/requestUtils.d.ts +2 -3
- package/lib/utils/requestUtils.js +22 -15
- package/lib/utils/requestUtils.js.map +1 -1
- package/package.json +9 -8
- package/lib/components/DocSdkCalls/DocSingleCall.d.ts +0 -3
- package/lib/components/DocSdkCalls/DocSingleCall.js +0 -32
- package/lib/components/DocSdkCalls/DocSingleCall.js.map +0 -1
- package/lib/components/common/StandaloneConfigurator.d.ts +0 -7
- package/lib/components/common/StandaloneConfigurator.js +0 -61
- package/lib/components/common/StandaloneConfigurator.js.map +0 -1
- package/lib/esm/components/DocSdkCalls/DocSingleCall.js +0 -18
- package/lib/esm/components/DocSdkCalls/DocSingleCall.js.map +0 -1
- package/lib/esm/components/common/StandaloneConfigurator.js +0 -51
- package/lib/esm/components/common/StandaloneConfigurator.js.map +0 -1
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"sources":["../../../src/components/RequestForm/formUtils.tsx"],"names":["createDateItem","name","handleChange","requestContent","undefined","bind","createBoolItem","description","inputTextType","type","createItem","required","placeholder","createSimpleItem","input","handleNumberChange","handleBoolChange","handleDateChange","createComplexItem","handleComplexChange","content","code","JSON","stringify","showDataChangeWarning","updateNullableProp","state","key","newValue","updatedState","validateEncodedValues","body","result","args","split","forEach","arg","formArg","test","trim","validateBody","parse","e","message"],"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 } from 'react'\nimport React, { Fragment } from 'react'\nimport {\n ToggleSwitch,\n Label,\n FieldCheckbox,\n ButtonOutline,\n Box,\n Popover,\n InputText,\n Tooltip,\n Icon,\n Space,\n} from '@looker/components'\n// eslint-disable-next-line no-restricted-imports\nimport { Info } from '@styled-icons/material'\nimport { DateFormat, InputDate } from '@looker/components-date'\nimport { CodeEditor } from '@looker/code-editor'\n\nimport type { RunItInput, RunItValues } from '../../RunIt'\nimport { FormItem } from './FormItem'\n\n/**\n * Creates a datetime form item\n * @param name Form item's name\n * @param handleChange A callback function for updating the parent\n * component's requestContent state with date item changes\n * @param requestContent A state object containing the values of all form items\n * @returns A datetime form item\n */\nconst createDateItem = (\n name: string,\n handleChange: (name: string, date?: Date) => void,\n requestContent: RunItValues\n) => (\n <FormItem key={`${name}_fid`} id={name} label={name}>\n <Popover\n key={`${name}_pop`}\n placement=\"bottom-start\"\n content={\n <Box key={`${name}_popbox`} p=\"u3\">\n <InputDate\n key={`datepick_${name}`}\n defaultValue={\n name in requestContent ? requestContent[name] : undefined\n }\n onChange={handleChange.bind(null, name)}\n />\n </Box>\n }\n >\n <ButtonOutline type=\"button\" key={`${name}_pop_button`}>\n {name in requestContent ? (\n <DateFormat key={`${name}_dateformat`}>\n {name in requestContent ? requestContent[name] : undefined}\n </DateFormat>\n ) : (\n 'Choose'\n )}\n </ButtonOutline>\n </Popover>\n </FormItem>\n)\n\n/**\n * Creates a boolean form item\n * @param name Form item's name\n * @param description Form item's description\n * @param handleChange A callback function that updates parent's component state when boolean item is clicked\n * @param requestContent A state object containing the values of all form items\n * @returns A boolean form item (a FieldToggleSwitch)\n */\nconst createBoolItem = (\n name: string,\n description: string,\n handleChange: (e: BaseSyntheticEvent) => void,\n requestContent: RunItValues\n) => (\n <FormItem key={`${name}_fib`} id={name} label={name}>\n <>\n <ToggleSwitch\n key={name}\n id={name}\n name={name}\n onChange={handleChange}\n on={name in requestContent ? requestContent[name] : false}\n />\n {description && <Label>{description}</Label>}\n </>\n </FormItem>\n)\n\nconst inputTextType = (type: string) => {\n switch (type) {\n case 'number':\n return 'number'\n case 'email':\n return 'email'\n case 'password':\n return 'password'\n default:\n return 'text'\n }\n}\n\n/**\n * Create a field text input item based on definitions\n * @param name Form item's name\n * @param description Form item's description\n * @param required Form item's required flag\n * @param type Form item's type\n * @param placeholder Form item's placeholder\n * @param handleChange A callback function that updates parent's component state when form item value changes\n * @param requestContent A state object containing the values of all form items\n * @returns A form item\n */\nconst createItem = (\n name: string,\n description: string,\n required: boolean,\n type: string,\n placeholder: string,\n handleChange: (e: BaseSyntheticEvent) => void,\n requestContent: RunItValues\n) => (\n <FormItem key={`${name}_fi`} id={name} label={name}>\n <InputText\n key={name}\n id={name}\n name={name}\n required={required}\n placeholder={`${placeholder} ${description || name}`}\n type={inputTextType(type)}\n value={name in requestContent ? requestContent[name] : ''}\n onChange={handleChange}\n />\n </FormItem>\n)\n\n/**\n * Creates a simple form item\n * @param input An object describing the form item\n * @param handleChange A callback function for updating the parent component's requestContent state with\n * text/email/password item changes\n * @param handleNumberChange A callback function for updating the parent component's requestContent state with number\n * item changes\n * @param handleBoolChange A callback function for updating the parent\n * component's requestContent state with bool item changes\n * @param handleDateChange A callback function for updating the parent\n * component's requestContent state with date item changes\n * @param requestContent A state object containing the values of all form items\n * @returns A simple form item\n */\nexport const createSimpleItem = (\n input: RunItInput,\n handleChange: (e: BaseSyntheticEvent) => void,\n handleNumberChange: (e: BaseSyntheticEvent) => void,\n handleBoolChange: (e: BaseSyntheticEvent) => void,\n handleDateChange: (name: string, date?: Date) => void,\n requestContent: RunItValues\n) => {\n switch (input.type) {\n case 'boolean':\n return createBoolItem(\n input.name,\n input.description,\n handleBoolChange,\n requestContent\n )\n case 'int64':\n case 'integer':\n case 'float':\n case 'double':\n return createItem(\n input.name,\n input.description,\n input.required,\n 'number',\n '(number)',\n handleNumberChange,\n requestContent\n )\n case 'string':\n case 'hostname':\n case 'uuid':\n case 'uri':\n case 'ipv4':\n case 'ipv6':\n return createItem(\n input.name,\n input.description,\n input.required,\n 'string',\n '(string)',\n handleChange,\n requestContent\n )\n case 'email':\n case 'password':\n return createItem(\n input.name,\n input.description,\n input.required,\n input.type,\n '(string)',\n handleChange,\n requestContent\n )\n case 'datetime':\n return createDateItem(input.name, handleDateChange, requestContent)\n default:\n return <Fragment key={input.name}></Fragment>\n }\n}\n\n/**\n * Creates a complex item\n * @param input An object describing the form item\n * @param handleComplexChange A callback function for updating the parent\n * component's requestContent state\n * @param requestContent A state object containing the values of all form items\n * @returns A complex form item\n */\nexport const createComplexItem = (\n input: RunItInput,\n handleComplexChange: (value: string, name: string) => void,\n requestContent: RunItValues\n) => {\n const content = requestContent[input.name]\n const code =\n typeof content === 'string' ? content : JSON.stringify(content, null, 2)\n\n return (\n <FormItem\n key={`${input.name}_fic`}\n id={input.name}\n label={\n <Space>\n {input.name}\n <Tooltip content=\"Empty values are automatically removed from the request.\">\n <Icon\n data-testid=\"body-param-tooltip\"\n icon={<Info />}\n size=\"xsmall\"\n ml=\"xsmall\"\n />\n </Tooltip>\n </Space>\n }\n >\n <CodeEditor\n key={`code_${input.name}`}\n language=\"json\"\n code={code}\n lineNumbers={false}\n onChange={handleComplexChange.bind(null, input.name)}\n transparent={true}\n />\n </FormItem>\n )\n}\n\n/**\n * Creates a required checkbox form item\n */\nexport const showDataChangeWarning = () => (\n <FormItem key=\"warningfi\" id=\"change_warning\">\n <FieldCheckbox\n name=\"warning\"\n key=\"warning\"\n required\n label=\"I understand that this API endpoint will change data.\"\n />\n </FormItem>\n)\n\n/**\n * Updates a given state with a key/value pair, taking into consideration\n * indeterminate values.\n * @param state A collection to update\n * @param key Property to update\n * @param newValue? New value corresponding to given key\n */\nexport const updateNullableProp = (\n state: RunItValues,\n key: string,\n newValue?: any\n) => {\n const updatedState = { ...state }\n if (key in state && !newValue) {\n delete updatedState[key]\n } else {\n updatedState[key] = newValue\n }\n return updatedState\n}\n\n/**\n * If the body isn't empty, it must be valid form encoded syntax\n *\n * This may not be perfect validation but it should be good enough to tolerate variances\n *\n * @param body to validate\n */\nexport const validateEncodedValues = (body: string) => {\n let result = ''\n if (!body) return result\n const args = body.split('&')\n args.forEach((arg) => {\n const formArg = /[\\w-_.]+(\\[])?=.*/i\n if (!formArg.test(arg)) {\n result += ` ${arg}`\n }\n })\n return result.trim()\n}\n\n/**\n * Returns an error message if the body is not JSON or valid form url encoding\n *\n * @param body string to validate\n */\nexport const validateBody = (body: string | Record<string, any>) => {\n let result = ''\n if (body && typeof body === 'string') {\n if (/^[[{}\"]/.test(body)) {\n // most likely JSON\n try {\n JSON.parse(body)\n } catch (e: any) {\n result = e.message\n }\n } else {\n result = validateEncodedValues(body)\n }\n }\n if (result) {\n result = `Syntax error in the body: ${result}`\n }\n return result\n}\n"],"file":"formUtils.js"}
|
1
|
+
{"version":3,"sources":["../../../src/components/RequestForm/formUtils.tsx"],"names":["createDateItem","name","handleChange","requestContent","undefined","bind","createBoolItem","description","inputTextType","type","createItem","required","placeholder","createSimpleItem","input","handleNumberChange","handleBoolChange","handleDateChange","createComplexItem","handleComplexChange","content","code","JSON","stringify","showDataChangeWarning","updateNullableProp","state","key","newValue","updatedState","validateEncodedValues","body","result","args","split","forEach","arg","formArg","test","trim","validateBody","requiredKeys","parsed","parse","e","message","length","Set","keys","Object","missing","filter","k","has","size","Array","from","join"],"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 } from 'react'\nimport React, { Fragment } from 'react'\nimport {\n ToggleSwitch,\n Label,\n FieldCheckbox,\n ButtonOutline,\n Box,\n Popover,\n InputText,\n Tooltip,\n Icon,\n Space,\n} from '@looker/components'\n// eslint-disable-next-line no-restricted-imports\nimport { Info } from '@styled-icons/material'\nimport { DateFormat, InputDate } from '@looker/components-date'\nimport { CodeEditor } from '@looker/code-editor'\nimport type { RunItInput, RunItValues } from '../../RunIt'\nimport { FormItem } from './FormItem'\n\n/**\n * Creates a datetime form item\n * @param name Form item's name\n * @param handleChange A callback function for updating the parent\n * component's requestContent state with date item changes\n * @param requestContent A state object containing the values of all form items\n * @returns A datetime form item\n */\nconst createDateItem = (\n name: string,\n handleChange: (name: string, date?: Date) => void,\n requestContent: RunItValues\n) => (\n <FormItem key={`${name}_fid`} id={name} label={name}>\n <Popover\n key={`${name}_pop`}\n placement=\"bottom-start\"\n content={\n <Box key={`${name}_popbox`} p=\"u3\">\n <InputDate\n key={`datepick_${name}`}\n defaultValue={\n name in requestContent ? requestContent[name] : undefined\n }\n onChange={handleChange.bind(null, name)}\n />\n </Box>\n }\n >\n <ButtonOutline type=\"button\" key={`${name}_pop_button`}>\n {name in requestContent ? (\n <DateFormat key={`${name}_dateformat`}>\n {name in requestContent ? requestContent[name] : undefined}\n </DateFormat>\n ) : (\n 'Choose'\n )}\n </ButtonOutline>\n </Popover>\n </FormItem>\n)\n\n/**\n * Creates a boolean form item\n * @param name Form item's name\n * @param description Form item's description\n * @param handleChange A callback function that updates parent's component state when boolean item is clicked\n * @param requestContent A state object containing the values of all form items\n * @returns A boolean form item (a FieldToggleSwitch)\n */\nconst createBoolItem = (\n name: string,\n description: string,\n handleChange: (e: BaseSyntheticEvent) => void,\n requestContent: RunItValues\n) => (\n <FormItem key={`${name}_fib`} id={name} label={name}>\n <>\n <ToggleSwitch\n key={name}\n id={name}\n name={name}\n onChange={handleChange}\n on={name in requestContent ? requestContent[name] : false}\n />\n {description && <Label>{description}</Label>}\n </>\n </FormItem>\n)\n\nconst inputTextType = (type: string) => {\n switch (type) {\n case 'number':\n return 'number'\n case 'email':\n return 'email'\n case 'password':\n return 'password'\n default:\n return 'text'\n }\n}\n\n/**\n * Create a field text input item based on definitions\n * @param name Form item's name\n * @param description Form item's description\n * @param required Form item's required flag\n * @param type Form item's type\n * @param placeholder Form item's placeholder\n * @param handleChange A callback function that updates parent's component state when form item value changes\n * @param requestContent A state object containing the values of all form items\n * @returns A form item\n */\nconst createItem = (\n name: string,\n description: string,\n required: boolean,\n type: string,\n placeholder: string,\n handleChange: (e: BaseSyntheticEvent) => void,\n requestContent: RunItValues\n) => (\n <FormItem key={`${name}_fi`} id={name} label={name}>\n <InputText\n key={name}\n id={name}\n name={name}\n required={required}\n placeholder={`${placeholder} ${description || name}`}\n type={inputTextType(type)}\n value={name in requestContent ? requestContent[name] : ''}\n onChange={handleChange}\n />\n </FormItem>\n)\n\n/**\n * Creates a simple form item\n * @param input An object describing the form item\n * @param handleChange A callback function for updating the parent component's requestContent state with\n * text/email/password item changes\n * @param handleNumberChange A callback function for updating the parent component's requestContent state with number\n * item changes\n * @param handleBoolChange A callback function for updating the parent\n * component's requestContent state with bool item changes\n * @param handleDateChange A callback function for updating the parent\n * component's requestContent state with date item changes\n * @param requestContent A state object containing the values of all form items\n * @returns A simple form item\n */\nexport const createSimpleItem = (\n input: RunItInput,\n handleChange: (e: BaseSyntheticEvent) => void,\n handleNumberChange: (e: BaseSyntheticEvent) => void,\n handleBoolChange: (e: BaseSyntheticEvent) => void,\n handleDateChange: (name: string, date?: Date) => void,\n requestContent: RunItValues\n) => {\n switch (input.type) {\n case 'boolean':\n return createBoolItem(\n input.name,\n input.description,\n handleBoolChange,\n requestContent\n )\n case 'int64':\n case 'integer':\n case 'float':\n case 'double':\n return createItem(\n input.name,\n input.description,\n input.required,\n 'number',\n '(number)',\n handleNumberChange,\n requestContent\n )\n case 'string':\n case 'hostname':\n case 'uuid':\n case 'uri':\n case 'ipv4':\n case 'ipv6':\n return createItem(\n input.name,\n input.description,\n input.required,\n 'string',\n '(string)',\n handleChange,\n requestContent\n )\n case 'email':\n case 'password':\n return createItem(\n input.name,\n input.description,\n input.required,\n input.type,\n '(string)',\n handleChange,\n requestContent\n )\n case 'datetime':\n return createDateItem(input.name, handleDateChange, requestContent)\n default:\n return <Fragment key={input.name}></Fragment>\n }\n}\n\n/**\n * Creates a complex item\n * @param input An object describing the form item\n * @param handleComplexChange A callback function for updating the parent\n * component's requestContent state\n * @param requestContent A state object containing the values of all form items\n * @returns A complex form item\n */\nexport const createComplexItem = (\n input: RunItInput,\n handleComplexChange: (value: string, name: string) => void,\n requestContent: RunItValues\n) => {\n const content = requestContent[input.name]\n const code =\n typeof content === 'string' ? content : JSON.stringify(content, null, 2)\n\n return (\n <FormItem\n key={`${input.name}_fic`}\n id={input.name}\n label={\n <Space>\n {input.name}\n <Tooltip content=\"Empty values are automatically removed from the request.\">\n <Icon\n data-testid=\"body-param-tooltip\"\n icon={<Info />}\n size=\"xsmall\"\n ml=\"xsmall\"\n />\n </Tooltip>\n </Space>\n }\n >\n <CodeEditor\n key={`code_${input.name}`}\n language=\"json\"\n code={code}\n lineNumbers={false}\n onChange={handleComplexChange.bind(null, input.name)}\n transparent={true}\n />\n </FormItem>\n )\n}\n\n/**\n * Creates a required checkbox form item\n */\nexport const showDataChangeWarning = () => (\n <FormItem key=\"warningfi\" id=\"change_warning\">\n <FieldCheckbox\n name=\"warning\"\n key=\"warning\"\n required\n label=\"I understand that this API endpoint will change data.\"\n />\n </FormItem>\n)\n\n/**\n * Updates a given state with a key/value pair, taking into consideration\n * indeterminate values.\n * @param state A collection to update\n * @param key Property to update\n * @param newValue? New value corresponding to given key\n */\nexport const updateNullableProp = (\n state: RunItValues,\n key: string,\n newValue?: any\n) => {\n const updatedState = { ...state }\n if (key in state && !newValue) {\n delete updatedState[key]\n } else {\n updatedState[key] = newValue\n }\n return updatedState\n}\n\n/**\n * If the body isn't empty, it must be valid form encoded syntax\n *\n * This may not be perfect validation but it should be good enough to tolerate variances\n *\n * @param body to validate\n */\nexport const validateEncodedValues = (body: string) => {\n let result = ''\n if (!body) return result\n const args = body.split('&')\n args.forEach((arg) => {\n const formArg = /[\\w-_.]+(\\[])?=.*/i\n if (!formArg.test(arg)) {\n result += ` ${arg}`\n }\n })\n return result.trim()\n}\n\n/**\n * Returns an error message if the body is not JSON or valid form url encoding\n *\n * @param body string to validate\n * @param requiredKeys keys that are required in the body parameter\n */\nexport const validateBody = (\n body: string | Record<string, any>,\n requiredKeys: string[]\n) => {\n let parsed\n\n let result = ''\n if (body) {\n if (typeof body === 'string') {\n if (/^[[{}\"]/.test(body)) {\n // most likely JSON\n try {\n parsed = JSON.parse(body)\n } catch (e: any) {\n result = e.message\n }\n } else {\n result = validateEncodedValues(body)\n }\n if (result) {\n result = `Syntax error in the body: ${result}`\n }\n } else {\n parsed = body\n }\n }\n\n if (parsed && requiredKeys && requiredKeys.length > 0) {\n const required = new Set<string>(requiredKeys)\n const keys = new Set<string>(Object.keys(parsed))\n const missing = new Set<string>([...required].filter((k) => !keys.has(k)))\n if (missing.size > 0) {\n result = `Error: Required properties \"${Array.from(missing).join(\n ', '\n )}\" must be provided in the body`\n }\n }\n return result\n}\n"],"file":"formUtils.js"}
|
@@ -3,10 +3,6 @@
|
|
3
3
|
Object.defineProperty(exports, "__esModule", {
|
4
4
|
value: true
|
5
5
|
});
|
6
|
-
var _exportNames = {
|
7
|
-
DarkSpan: true,
|
8
|
-
RunItHeading: true
|
9
|
-
};
|
10
6
|
Object.defineProperty(exports, "DarkSpan", {
|
11
7
|
enumerable: true,
|
12
8
|
get: function get() {
|
@@ -21,18 +17,4 @@ Object.defineProperty(exports, "RunItHeading", {
|
|
21
17
|
});
|
22
18
|
|
23
19
|
var _common = require("./common");
|
24
|
-
|
25
|
-
var _StandaloneConfigurator = require("./StandaloneConfigurator");
|
26
|
-
|
27
|
-
Object.keys(_StandaloneConfigurator).forEach(function (key) {
|
28
|
-
if (key === "default" || key === "__esModule") return;
|
29
|
-
if (Object.prototype.hasOwnProperty.call(_exportNames, key)) return;
|
30
|
-
if (key in exports && exports[key] === _StandaloneConfigurator[key]) return;
|
31
|
-
Object.defineProperty(exports, key, {
|
32
|
-
enumerable: true,
|
33
|
-
get: function get() {
|
34
|
-
return _StandaloneConfigurator[key];
|
35
|
-
}
|
36
|
-
});
|
37
|
-
});
|
38
20
|
//# sourceMappingURL=index.js.map
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"sources":["../../../src/components/common/index.ts"],"names":[],"mappings":"
|
1
|
+
{"version":3,"sources":["../../../src/components/common/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;AAyBA","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 */\nexport { DarkSpan, RunItHeading } from './common'\n"],"file":"index.js"}
|
package/lib/esm/RunIt.js
CHANGED
@@ -6,11 +6,13 @@ function _asyncToGenerator(fn) { return function () { var self = this, args = ar
|
|
6
6
|
|
7
7
|
import React, { useContext, useState, useEffect } from 'react';
|
8
8
|
import { Box, Tab, TabList, TabPanels, TabPanel, useTabs } from '@looker/components';
|
9
|
+
import { registerEnvAdaptor } from '@looker/extension-utils';
|
9
10
|
import { RequestForm, ResponseExplorer, Loading, DocSdkCalls, ConfigForm, validateBody, PerfTimings, PerfTracker } from './components';
|
10
|
-
import { initRequestContent, createRequestParams, runRequest, pathify,
|
11
|
+
import { initRequestContent, createRequestParams, runRequest, pathify, prepareInputs, createInputs } from './utils';
|
11
12
|
import { runItNoSet, RunItContext } from '.';
|
12
13
|
export var RunIt = _ref => {
|
13
14
|
var {
|
15
|
+
adaptor,
|
14
16
|
api,
|
15
17
|
method,
|
16
18
|
setVersionsUrl = runItNoSet,
|
@@ -18,35 +20,26 @@ export var RunIt = _ref => {
|
|
18
20
|
} = _ref;
|
19
21
|
var httpMethod = method.httpMethod;
|
20
22
|
var endpoint = method.endpoint;
|
23
|
+
var sdk = adaptor.sdk;
|
24
|
+
var [initialized, setInitialized] = useState(false);
|
21
25
|
var {
|
22
|
-
sdk,
|
23
|
-
configurator,
|
24
26
|
basePath
|
25
27
|
} = useContext(RunItContext);
|
26
28
|
var [inputs] = useState(() => createInputs(api, method));
|
27
|
-
var [requestContent, setRequestContent] = useState(
|
29
|
+
var [requestContent, setRequestContent] = useState(initRequestContent(inputs));
|
28
30
|
var [activePathParams, setActivePathParams] = useState({});
|
29
31
|
var [loading, setLoading] = useState(false);
|
30
32
|
var [responseContent, setResponseContent] = useState(undefined);
|
31
|
-
var
|
32
|
-
var [hasConfig, setHasConfig] = useState(
|
33
|
-
var [needsAuth
|
33
|
+
var isExtension = adaptor.isExtension();
|
34
|
+
var [hasConfig, setHasConfig] = useState(isExtension || sdk.authSession.settings.authIsConfigured());
|
35
|
+
var [needsAuth] = useState(() => !isExtension && !sdk.authSession.isAuthenticated());
|
34
36
|
var [validationMessage, setValidationMessage] = useState('');
|
35
37
|
var tabs = useTabs();
|
36
38
|
var perf = new PerfTimings();
|
37
39
|
useEffect(() => {
|
38
|
-
|
39
|
-
|
40
|
-
|
41
|
-
setIsExtension(!configIsNeeded);
|
42
|
-
setHasConfig(!configIsNeeded || settings.authIsConfigured());
|
43
|
-
setNeedsAuth(configIsNeeded && !sdk.authSession.isAuthenticated());
|
44
|
-
} else {
|
45
|
-
setIsExtension(true);
|
46
|
-
setHasConfig(true);
|
47
|
-
setNeedsAuth(false);
|
48
|
-
}
|
49
|
-
}, [sdk]);
|
40
|
+
registerEnvAdaptor(adaptor);
|
41
|
+
setInitialized(true);
|
42
|
+
}, []);
|
50
43
|
|
51
44
|
var handleConfig = _e => {
|
52
45
|
tabs.onSelectTab(4);
|
@@ -58,7 +51,9 @@ export var RunIt = _ref => {
|
|
58
51
|
var [pathParams, queryParams, body] = createRequestParams(inputs, requestContent);
|
59
52
|
|
60
53
|
if (body) {
|
61
|
-
var
|
54
|
+
var [bodyParam] = method.bodyParams;
|
55
|
+
var requiredKeys = Object.keys(bodyParam.type.requiredProperties);
|
56
|
+
var message = validateBody(body, requiredKeys);
|
62
57
|
setValidationMessage(message);
|
63
58
|
|
64
59
|
if (message) {
|
@@ -96,12 +91,13 @@ export var RunIt = _ref => {
|
|
96
91
|
};
|
97
92
|
}();
|
98
93
|
|
99
|
-
if (!sdk) return React.createElement(React.Fragment, null);
|
100
94
|
return React.createElement(Box, {
|
101
95
|
bg: "background",
|
102
96
|
py: "large",
|
103
97
|
height: "100%"
|
104
|
-
}, React.createElement(
|
98
|
+
}, !initialized ? React.createElement(Loading, {
|
99
|
+
loading: true
|
100
|
+
}) : React.createElement(React.Fragment, null, React.createElement(TabList, _extends({
|
105
101
|
distribute: true
|
106
102
|
}, tabs), React.createElement(Tab, {
|
107
103
|
key: "request"
|
@@ -121,7 +117,6 @@ export var RunIt = _ref => {
|
|
121
117
|
}), React.createElement(TabPanel, {
|
122
118
|
key: "request"
|
123
119
|
}, React.createElement(RequestForm, {
|
124
|
-
sdk: sdk,
|
125
120
|
httpMethod: httpMethod,
|
126
121
|
inputs: inputs,
|
127
122
|
requestContent: requestContent,
|
@@ -131,7 +126,6 @@ export var RunIt = _ref => {
|
|
131
126
|
hasConfig: hasConfig,
|
132
127
|
handleConfig: handleConfig,
|
133
128
|
setHasConfig: setHasConfig,
|
134
|
-
configurator: configurator,
|
135
129
|
isExtension: isExtension,
|
136
130
|
validationMessage: validationMessage,
|
137
131
|
setValidationMessage: setValidationMessage,
|
@@ -155,15 +149,13 @@ export var RunIt = _ref => {
|
|
155
149
|
})), isExtension ? React.createElement(React.Fragment, null) : React.createElement(TabPanel, {
|
156
150
|
key: "performance"
|
157
151
|
}, React.createElement(PerfTracker, {
|
158
|
-
perf: perf
|
159
|
-
configurator: configurator
|
152
|
+
perf: perf
|
160
153
|
})), isExtension ? React.createElement(React.Fragment, null) : React.createElement(TabPanel, {
|
161
154
|
key: "config"
|
162
155
|
}, React.createElement(ConfigForm, {
|
163
156
|
setHasConfig: setHasConfig,
|
164
|
-
configurator: configurator,
|
165
157
|
setVersionsUrl: setVersionsUrl,
|
166
158
|
requestContent: requestContent
|
167
|
-
}))));
|
159
|
+
})))));
|
168
160
|
};
|
169
161
|
//# sourceMappingURL=RunIt.js.map
|
package/lib/esm/RunIt.js.map
CHANGED
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"sources":["../../src/RunIt.tsx"],"names":["React","useContext","useState","useEffect","Box","Tab","TabList","TabPanels","TabPanel","useTabs","RequestForm","ResponseExplorer","Loading","DocSdkCalls","ConfigForm","validateBody","PerfTimings","PerfTracker","initRequestContent","createRequestParams","runRequest","pathify","sdkNeedsConfig","prepareInputs","sdkNeedsAuth","createInputs","runItNoSet","RunItContext","RunIt","api","method","setVersionsUrl","sdkLanguage","httpMethod","endpoint","sdk","configurator","basePath","inputs","requestContent","setRequestContent","activePathParams","setActivePathParams","loading","setLoading","responseContent","setResponseContent","undefined","isExtension","setIsExtension","hasConfig","setHasConfig","needsAuth","setNeedsAuth","validationMessage","setValidationMessage","tabs","perf","settings","authSession","configIsNeeded","authIsConfigured","isAuthenticated","handleConfig","_e","onSelectTab","handleSubmit","e","preventDefault","pathParams","queryParams","body","message","response","err","ok","statusMessage","statusCode","contentType","JSON","stringify","headers"],"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 } 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 { ResponseContent } from './components'\nimport {\n RequestForm,\n ResponseExplorer,\n Loading,\n DocSdkCalls,\n ConfigForm,\n validateBody,\n PerfTimings,\n PerfTracker,\n} from './components'\nimport type { RunItSettings } from './utils'\nimport {\n initRequestContent,\n createRequestParams,\n runRequest,\n pathify,\n sdkNeedsConfig,\n prepareInputs,\n sdkNeedsAuth,\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 /** 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 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, configurator, basePath } = useContext(RunItContext)\n const [inputs] = useState(() => createInputs(api, method))\n const [requestContent, setRequestContent] = useState(() =>\n initRequestContent(configurator, inputs)\n )\n const [activePathParams, setActivePathParams] = useState({})\n const [loading, setLoading] = useState(false)\n const [responseContent, setResponseContent] =\n useState<ResponseContent>(undefined)\n const [isExtension, setIsExtension] = useState<boolean>(false)\n const [hasConfig, setHasConfig] = useState<boolean>(true)\n const [needsAuth, setNeedsAuth] = useState<boolean>(() => sdkNeedsAuth(sdk))\n const [validationMessage, setValidationMessage] = useState<string>('')\n const tabs = useTabs()\n\n const perf = new PerfTimings()\n\n useEffect(() => {\n if (sdk) {\n const settings = sdk.authSession.settings as RunItSettings\n const configIsNeeded = sdkNeedsConfig(sdk)\n setIsExtension(!configIsNeeded)\n setHasConfig(!configIsNeeded || settings.authIsConfigured())\n setNeedsAuth(configIsNeeded && !sdk.authSession.isAuthenticated())\n } else {\n setIsExtension(true)\n setHasConfig(true)\n setNeedsAuth(false)\n }\n }, [sdk])\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 message = validateBody(body)\n setValidationMessage(message)\n if (message) {\n // syntax 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 // No SDK, no RunIt for you!\n if (!sdk) return <></>\n\n return (\n <Box bg=\"background\" py=\"large\" height=\"100%\">\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 sdk={sdk}\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 configurator={configurator}\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} configurator={configurator} />\n </TabPanel>\n )}\n {isExtension ? (\n <></>\n ) : (\n <TabPanel key=\"config\">\n <ConfigForm\n setHasConfig={setHasConfig}\n configurator={configurator}\n setVersionsUrl={setVersionsUrl}\n requestContent={requestContent}\n />\n </TabPanel>\n )}\n </TabPanels>\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","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":"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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 } 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"}
|
package/lib/esm/RunItProvider.js
CHANGED
@@ -1,20 +1,15 @@
|
|
1
1
|
import React, { createContext } from 'react';
|
2
2
|
var defaultRunItContextValue = {
|
3
|
-
basePath: ''
|
4
|
-
configurator: {}
|
3
|
+
basePath: ''
|
5
4
|
};
|
6
5
|
export var RunItContext = createContext(defaultRunItContextValue);
|
7
6
|
export var RunItProvider = _ref => {
|
8
7
|
var {
|
9
8
|
children,
|
10
|
-
|
11
|
-
basePath,
|
12
|
-
configurator
|
9
|
+
basePath
|
13
10
|
} = _ref;
|
14
11
|
return React.createElement(RunItContext.Provider, {
|
15
12
|
value: {
|
16
|
-
sdk,
|
17
|
-
configurator,
|
18
13
|
basePath
|
19
14
|
}
|
20
15
|
}, children);
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"sources":["../../src/RunItProvider.tsx"],"names":["React","createContext","defaultRunItContextValue","basePath","
|
1
|
+
{"version":3,"sources":["../../src/RunItProvider.tsx"],"names":["React","createContext","defaultRunItContextValue","basePath","RunItContext","RunItProvider","children"],"mappings":"AA2BA,OAAOA,KAAP,IAAgBC,aAAhB,QAAqC,OAArC;AAUA,IAAMC,wBAA2C,GAAG;AAClDC,EAAAA,QAAQ,EAAE;AADwC,CAApD;AAIA,OAAO,IAAMC,YAAY,GAAGH,aAAa,CACvCC,wBADuC,CAAlC;AASP,OAAO,IAAMG,aAAqC,GAAG,QAG/C;AAAA,MAHgD;AACpDC,IAAAA,QADoD;AAEpDH,IAAAA;AAFoD,GAGhD;AACJ,SACE,oBAAC,YAAD,CAAc,QAAd;AAAuB,IAAA,KAAK,EAAE;AAAEA,MAAAA;AAAF;AAA9B,KACGG,QADH,CADF;AAKD,CATM","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 { FC, ReactElement } from 'react'\nimport React, { createContext } from 'react'\n\nexport interface RunItContextProps {\n basePath: string\n}\n\nexport interface RunItProviderProps extends RunItContextProps {\n children: ReactElement<any> | ReactElement[]\n}\n\nconst defaultRunItContextValue: RunItContextProps = {\n basePath: '',\n}\n\nexport const RunItContext = createContext<RunItContextProps>(\n defaultRunItContextValue\n)\n\n/**\n * TODO: Eliminate this provider. Configurator currently duplicates adaptor\n * functionality. basePath can be passed as a prop and should be stored using\n * redux when RunIt has it.\n */\nexport const RunItProvider: FC<RunItProviderProps> = ({\n children,\n basePath,\n}) => {\n return (\n <RunItContext.Provider value={{ basePath }}>\n {children}\n </RunItContext.Provider>\n )\n}\n"],"file":"RunItProvider.js"}
|
@@ -11,7 +11,8 @@ function _defineProperty(obj, key, value) { if (key in obj) { Object.definePrope
|
|
11
11
|
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
|
-
import {
|
14
|
+
import { getEnvAdaptor } from '@looker/extension-utils';
|
15
|
+
import { CollapserCard, RunItFormKey, RunItHeading, DarkSpan, readyToLogin, RunItNoConfig } from '../..';
|
15
16
|
import { RunItConfigKey, validateUrl, loadSpecsFromVersions } from './configUtils';
|
16
17
|
var POSITIVE = 'positive';
|
17
18
|
var defaultFieldValues = {
|
@@ -24,11 +25,9 @@ var defaultFieldValues = {
|
|
24
25
|
};
|
25
26
|
export var ConfigForm = _ref => {
|
26
27
|
var {
|
27
|
-
configurator,
|
28
28
|
setVersionsUrl,
|
29
29
|
title,
|
30
30
|
requestContent,
|
31
|
-
sdk = runItSDK,
|
32
31
|
setHasConfig
|
33
32
|
} = _ref;
|
34
33
|
var BASE_URL = 'baseUrl';
|
@@ -37,11 +36,12 @@ export var ConfigForm = _ref => {
|
|
37
36
|
var FETCH_RESULT = 'fetchResult';
|
38
37
|
var CRITICAL = 'critical';
|
39
38
|
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;
|
40
40
|
title = title || 'RunIt Configuration';
|
41
41
|
|
42
42
|
var getConfig = () => {
|
43
|
-
var data =
|
44
|
-
var result = data
|
43
|
+
var data = localStorage.getItem(RunItConfigKey);
|
44
|
+
var result = data ? JSON.parse(data) : {
|
45
45
|
base_url: '',
|
46
46
|
looker_url: ''
|
47
47
|
};
|
@@ -73,14 +73,14 @@ export var ConfigForm = _ref => {
|
|
73
73
|
var {
|
74
74
|
base_url,
|
75
75
|
looker_url
|
76
|
-
} =
|
76
|
+
} = data;
|
77
77
|
setSaved(data);
|
78
78
|
updateFields({
|
79
79
|
[BASE_URL]: base_url,
|
80
80
|
[WEB_URL]: looker_url,
|
81
81
|
[FETCH_INTENT]: base_url !== '' && looker_url !== '' ? POSITIVE : CRITICAL
|
82
82
|
});
|
83
|
-
}, [
|
83
|
+
}, []);
|
84
84
|
var [validationMessages, setValidationMessages] = useState({});
|
85
85
|
|
86
86
|
var updateMessage = (intent, message) => {
|
@@ -123,7 +123,7 @@ export var ConfigForm = _ref => {
|
|
123
123
|
base_url: baseUrl,
|
124
124
|
looker_url: webUrl
|
125
125
|
};
|
126
|
-
|
126
|
+
localStorage.setItem(RunItConfigKey, JSON.stringify(data));
|
127
127
|
if (setHasConfig) setHasConfig(true);
|
128
128
|
setSaved(data);
|
129
129
|
setVersionsUrl(versionsUrl);
|
@@ -162,7 +162,7 @@ export var ConfigForm = _ref => {
|
|
162
162
|
|
163
163
|
var handleClear = function () {
|
164
164
|
var _ref5 = _asyncToGenerator(function* (_e) {
|
165
|
-
|
165
|
+
localStorage.removeItem(RunItConfigKey);
|
166
166
|
updateFields({
|
167
167
|
[BASE_URL]: '',
|
168
168
|
[WEB_URL]: '',
|
@@ -206,7 +206,7 @@ export var ConfigForm = _ref => {
|
|
206
206
|
setValidationMessages(newValidationMessages);
|
207
207
|
};
|
208
208
|
|
209
|
-
var isAuthenticated = () => sdk
|
209
|
+
var isAuthenticated = () => sdk.authSession.isAuthenticated();
|
210
210
|
|
211
211
|
var verifyButtonDisabled = fields.baseUrl.trim().length === 0 || Object.keys(validationMessages).length > 0;
|
212
212
|
var saveButtonDisabled = verifyButtonDisabled || fields.webUrl.trim().length === 0 || isConfigured();
|
@@ -218,10 +218,10 @@ export var ConfigForm = _ref => {
|
|
218
218
|
e.preventDefault();
|
219
219
|
|
220
220
|
if (requestContent) {
|
221
|
-
|
221
|
+
localStorage.setItem(RunItFormKey, JSON.stringify(requestContent));
|
222
222
|
}
|
223
223
|
|
224
|
-
yield sdk
|
224
|
+
yield sdk.authSession.login();
|
225
225
|
});
|
226
226
|
|
227
227
|
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","CollapserCard","RunItFormKey","RunItHeading","DarkSpan","runItSDK","readyToLogin","RunItNoConfig","RunItConfigKey","validateUrl","loadSpecsFromVersions","POSITIVE","defaultFieldValues","baseUrl","webUrl","headless","specs","fetchResult","fetchIntent","ConfigForm","configurator","setVersionsUrl","title","requestContent","sdk","setHasConfig","BASE_URL","WEB_URL","FETCH_INTENT","FETCH_RESULT","CRITICAL","appConfig","window","location","origin","getConfig","data","getStorage","result","value","JSON","parse","base_url","looker_url","config","fields","setFields","saved","setSaved","updateFields","nameOrValues","previousFields","validationMessages","setValidationMessages","updateMessage","intent","message","isConfigured","fetchError","updateForm","_e","save","versionsUrl","setStorage","stringify","err","handleSave","e","handleVerify","handleClear","removeStorage","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 type { IAPIMethods } from '@looker/sdk-rtl'\nimport type { RunItSetter, RunItValues } from '../..'\nimport {\n CollapserCard,\n RunItFormKey,\n RunItHeading,\n DarkSpan,\n runItSDK,\n readyToLogin,\n RunItNoConfig,\n} from '../..'\nimport type { RunItConfigurator, 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 configurator: RunItConfigurator\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 /** SDK to use for login. Defaults to the `runItSDK` */\n sdk?: IAPIMethods\n}\n\nexport const ConfigForm: FC<ConfigFormProps> = ({\n configurator,\n setVersionsUrl,\n title,\n requestContent,\n sdk = runItSDK,\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\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 // get configuration from storage, or default it\n const data = configurator.getStorage(RunItConfigKey)\n const result = data.value\n ? JSON.parse(data.value)\n : { 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 } = getConfig()\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 }, [configurator])\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 configurator.setStorage(\n RunItConfigKey,\n JSON.stringify(data),\n // Always store in local storage\n 'local'\n )\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 // e.preventDefault()\n configurator.removeStorage(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 configurator.setStorage(\n RunItFormKey,\n JSON.stringify(requestContent),\n 'local'\n )\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","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":"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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'\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"}
|
@@ -11,7 +11,7 @@ function _asyncToGenerator(fn) { return function () { var self = this, args = ar
|
|
11
11
|
import { ApiModel, getSpecsFromVersions, upgradeSpecObject } from '@looker/sdk-codegen';
|
12
12
|
import { BrowserTransport, DefaultSettings } from '@looker/sdk-rtl';
|
13
13
|
import { api_spec } from '@looker/sdk';
|
14
|
-
import {
|
14
|
+
import { getEnvAdaptor } from '@looker/extension-utils';
|
15
15
|
export var RunItConfigKey = 'RunItConfig';
|
16
16
|
export var RunItFormKey = 'RunItForm';
|
17
17
|
export var RunItNoConfig = {
|
@@ -73,7 +73,8 @@ var apiSpecBits = spec => {
|
|
73
73
|
};
|
74
74
|
|
75
75
|
export var funFetch = (version, name) => {
|
76
|
-
|
76
|
+
var sdk = getEnvAdaptor().sdk;
|
77
|
+
return sdk.ok(api_spec(sdk, version, name));
|
77
78
|
};
|
78
79
|
export var specUrlFetch = function () {
|
79
80
|
var _ref2 = _asyncToGenerator(function* (url) {
|
@@ -177,10 +178,11 @@ export var fallbackFetch = function () {
|
|
177
178
|
}
|
178
179
|
|
179
180
|
if (!api) {
|
180
|
-
var
|
181
|
+
var sdk = getEnvAdaptor().sdk;
|
182
|
+
var authed = sdk.authSession.isAuthenticated();
|
181
183
|
|
182
184
|
if (!authed) {
|
183
|
-
yield
|
185
|
+
yield sdk.authSession.login();
|
184
186
|
}
|
185
187
|
|
186
188
|
api = yield sdkSpecFetch(spec, fetcher);
|