@looker/run-it 0.9.20 → 0.9.24

Sign up to get free protection for your applications and to get access to all the features.
Files changed (79) hide show
  1. package/CHANGELOG.md +66 -0
  2. package/lib/RunIt.d.ts +2 -0
  3. package/lib/RunIt.js +20 -27
  4. package/lib/RunIt.js.map +1 -1
  5. package/lib/RunItProvider.d.ts +0 -4
  6. package/lib/RunItProvider.js +2 -7
  7. package/lib/RunItProvider.js.map +1 -1
  8. package/lib/components/ConfigForm/ConfigForm.d.ts +0 -4
  9. package/lib/components/ConfigForm/ConfigForm.js +12 -11
  10. package/lib/components/ConfigForm/ConfigForm.js.map +1 -1
  11. package/lib/components/ConfigForm/configUtils.js +6 -4
  12. package/lib/components/ConfigForm/configUtils.js.map +1 -1
  13. package/lib/components/DocSdkCalls/DocMultiCall.d.ts +5 -2
  14. package/lib/components/DocSdkCalls/DocMultiCall.js +7 -19
  15. package/lib/components/DocSdkCalls/DocMultiCall.js.map +1 -1
  16. package/lib/components/DocSdkCalls/DocSdkCalls.js +26 -9
  17. package/lib/components/DocSdkCalls/DocSdkCalls.js.map +1 -1
  18. package/lib/components/LoginForm/LoginForm.d.ts +2 -8
  19. package/lib/components/LoginForm/LoginForm.js +5 -6
  20. package/lib/components/LoginForm/LoginForm.js.map +1 -1
  21. package/lib/components/PerfTracker/PerfTracker.d.ts +0 -2
  22. package/lib/components/PerfTracker/PerfTracker.js +7 -8
  23. package/lib/components/PerfTracker/PerfTracker.js.map +1 -1
  24. package/lib/components/RequestForm/RequestForm.d.ts +0 -4
  25. package/lib/components/RequestForm/RequestForm.js +0 -7
  26. package/lib/components/RequestForm/RequestForm.js.map +1 -1
  27. package/lib/components/RequestForm/formUtils.d.ts +1 -1
  28. package/lib/components/RequestForm/formUtils.js +25 -10
  29. package/lib/components/RequestForm/formUtils.js.map +1 -1
  30. package/lib/components/common/index.d.ts +0 -1
  31. package/lib/components/common/index.js +0 -18
  32. package/lib/components/common/index.js.map +1 -1
  33. package/lib/esm/RunIt.js +20 -28
  34. package/lib/esm/RunIt.js.map +1 -1
  35. package/lib/esm/RunItProvider.js +2 -7
  36. package/lib/esm/RunItProvider.js.map +1 -1
  37. package/lib/esm/components/ConfigForm/ConfigForm.js +12 -12
  38. package/lib/esm/components/ConfigForm/ConfigForm.js.map +1 -1
  39. package/lib/esm/components/ConfigForm/configUtils.js +6 -4
  40. package/lib/esm/components/ConfigForm/configUtils.js.map +1 -1
  41. package/lib/esm/components/DocSdkCalls/DocMultiCall.js +8 -19
  42. package/lib/esm/components/DocSdkCalls/DocMultiCall.js.map +1 -1
  43. package/lib/esm/components/DocSdkCalls/DocSdkCalls.js +25 -10
  44. package/lib/esm/components/DocSdkCalls/DocSdkCalls.js.map +1 -1
  45. package/lib/esm/components/LoginForm/LoginForm.js +5 -6
  46. package/lib/esm/components/LoginForm/LoginForm.js.map +1 -1
  47. package/lib/esm/components/PerfTracker/PerfTracker.js +7 -8
  48. package/lib/esm/components/PerfTracker/PerfTracker.js.map +1 -1
  49. package/lib/esm/components/RequestForm/RequestForm.js +0 -7
  50. package/lib/esm/components/RequestForm/RequestForm.js.map +1 -1
  51. package/lib/esm/components/RequestForm/formUtils.js +25 -10
  52. package/lib/esm/components/RequestForm/formUtils.js.map +1 -1
  53. package/lib/esm/components/common/index.js +0 -1
  54. package/lib/esm/components/common/index.js.map +1 -1
  55. package/lib/esm/scenes/OAuthScene/OAuthScene.js +3 -6
  56. package/lib/esm/scenes/OAuthScene/OAuthScene.js.map +1 -1
  57. package/lib/esm/utils/RunItSDK.js +12 -77
  58. package/lib/esm/utils/RunItSDK.js.map +1 -1
  59. package/lib/esm/utils/requestUtils.js +21 -14
  60. package/lib/esm/utils/requestUtils.js.map +1 -1
  61. package/lib/scenes/OAuthScene/OAuthScene.js +2 -5
  62. package/lib/scenes/OAuthScene/OAuthScene.js.map +1 -1
  63. package/lib/utils/RunItSDK.d.ts +3 -16
  64. package/lib/utils/RunItSDK.js +15 -87
  65. package/lib/utils/RunItSDK.js.map +1 -1
  66. package/lib/utils/requestUtils.d.ts +2 -3
  67. package/lib/utils/requestUtils.js +22 -15
  68. package/lib/utils/requestUtils.js.map +1 -1
  69. package/package.json +9 -8
  70. package/lib/components/DocSdkCalls/DocSingleCall.d.ts +0 -3
  71. package/lib/components/DocSdkCalls/DocSingleCall.js +0 -32
  72. package/lib/components/DocSdkCalls/DocSingleCall.js.map +0 -1
  73. package/lib/components/common/StandaloneConfigurator.d.ts +0 -7
  74. package/lib/components/common/StandaloneConfigurator.js +0 -61
  75. package/lib/components/common/StandaloneConfigurator.js.map +0 -1
  76. package/lib/esm/components/DocSdkCalls/DocSingleCall.js +0 -18
  77. package/lib/esm/components/DocSdkCalls/DocSingleCall.js.map +0 -1
  78. package/lib/esm/components/common/StandaloneConfigurator.js +0 -51
  79. package/lib/esm/components/common/StandaloneConfigurator.js.map +0 -1
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/components/ConfigForm/configUtils.ts"],"names":["RunItConfigKey","RunItFormKey","RunItNoConfig","base_url","looker_url","validateUrl","url","result","URL","endsWith","origin","makeApi","content","json","JSON","parse","ApiModel","fromJson","getUrl","settings","verify_ssl","xp","BrowserTransport","response","rawRequest","body","fullify","uri","baseUrl","match","toString","apiSpecBits","spec","specURL","split","slice","funFetch","version","name","runItSDK","ok","specUrlFetch","error","undefined","loadSpecsFromVersions","defer","fetchResult","specs","webUrl","headless","versions","window","location","api_server_url","web_server_url","fetchSpec","api","fallbackFetch","e","message","sdkSpecFetch","fetcher","console","authed","authSession","isAuthenticated","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 { ILookerVersions, SpecItem, SpecList } from '@looker/sdk-codegen'\nimport {\n ApiModel,\n getSpecsFromVersions,\n upgradeSpecObject,\n} from '@looker/sdk-codegen'\nimport { BrowserTransport, DefaultSettings } from '@looker/sdk-rtl'\nimport { api_spec } from '@looker/sdk'\nimport type { RunItValues } from '../..'\nimport { runItSDK } from '../..'\n\nexport type StorageLocation = 'session' | 'local'\nexport const RunItConfigKey = 'RunItConfig'\nexport const RunItFormKey = 'RunItForm'\nexport const RunItNoConfig = { base_url: '', looker_url: '' }\n\n/** Object returned from storage service */\nexport interface IStorageValue {\n /** Location of the stored object */\n location: StorageLocation\n /** Stored string representation of the value (usually JSON) */\n value: string\n}\n\n/** function to retrieve a spec based on version and name */\nexport type ApiSpecFetcher = (\n version: string,\n name: string\n) => Promise<string | RunItValues>\n\n/** Either the spec is parsed or it's undefined */\nexport type ParsedSpec = ApiModel | undefined\n\n/** service abstraction for extension and browser based usage */\nexport interface RunItConfigurator {\n getStorage: (key: string, defaultValue?: string) => IStorageValue\n setStorage(key: string, value: string, location: 'local' | 'session'): string\n removeStorage(key: string): void\n}\n\n/** Processed specifications */\nexport interface ILoadedSpecs {\n /** API server url */\n baseUrl: string\n /** Web server url */\n webUrl: string\n /** should APIX run headless? */\n headless: boolean\n /** loaded specifications */\n specs: SpecList\n /** communication errors */\n fetchResult: string\n}\n\n/** Extends versions payload with headless toggle for API Explorer */\nexport interface IAPIXConfig extends ILookerVersions {\n headless?: boolean\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\n/**\n * Convert content into an ApiModel\n * @param content to convert\n */\nconst makeApi = (content: string | RunItValues) => {\n let json\n if (typeof content === 'string') {\n json = JSON.parse(content)\n } else {\n json = content\n }\n json = upgradeSpecObject(json)\n return ApiModel.fromJson(json)\n}\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 * Ensure the URI is a full URL\n * @param uri possible relative path\n * @param baseUrl base url for qualifying full path\n */\nexport const fullify = (uri: string, baseUrl: string): string => {\n if (uri.match(/^https?:/)) {\n return uri\n }\n const url = new URL(uri, baseUrl)\n return url.toString()\n}\n/**\n * parse spec url into version and name for api_spec cccall\n * @param spec to parse\n */\nconst apiSpecBits = (spec: SpecItem): string[] =>\n spec.specURL?.split('/').slice(-2) || []\n\n/**\n * Use the functional api_spec fetch\n * @param version to retrieve\n * @param name to retrieve\n */\nexport const funFetch = (version: string, name: string): Promise<string> => {\n return runItSDK.ok(api_spec(runItSDK, version, name))\n}\n\n/**\n * try to fetch a spec by URL, trap any errors and return undefined\n * @param url to convert to an API spec\n */\nexport const specUrlFetch = async (url: string): Promise<ParsedSpec> => {\n try {\n const content = await getUrl(url)\n return makeApi(content)\n } catch (error) {\n return undefined\n }\n}\n\n/**\n * Load versions payload and retrieve all supported specs\n *\n * The versions payload should match the structure of Looker's /versions endpoint\n *\n * @param url that has an unauthenticated versions payload. For Looker, this is <LookerHostName>/versions\n * @param content content of versions payload that may already be assigned\n * @param defer true to defer fetching and parsing the spec. Defaults to true.\n */\nexport const loadSpecsFromVersions = async (\n url: string,\n content: string | Record<string, unknown> = '',\n defer = true\n): Promise<ILoadedSpecs> => {\n let fetchResult = ''\n let specs: SpecList = {}\n let baseUrl = ''\n let webUrl = ''\n let headless = false\n try {\n if (!content) {\n content = await getUrl(url)\n }\n const versions = (\n typeof content === 'string' ? JSON.parse(content) : content\n ) as IAPIXConfig\n const origin = (window as any).location.origin\n baseUrl = versions.api_server_url\n webUrl = versions.web_server_url\n if (versions.headless !== undefined) {\n headless = versions.headless\n }\n const fetchSpec = async (spec: SpecItem) => {\n if (spec.specURL) {\n spec.specURL = fullify(spec.specURL, origin)\n if (!defer) {\n spec.api = await fallbackFetch(spec, funFetch)\n }\n }\n return spec.api\n }\n specs = await getSpecsFromVersions(versions, fetchSpec)\n } catch (e: any) {\n fetchResult = e.message\n }\n\n return {\n baseUrl,\n webUrl,\n specs,\n headless,\n fetchResult: fetchResult,\n }\n}\n\n/**\n * fetch and compile an API specification to an ApiModel if it's not already available\n *\n * **NOTE**: This uses Looker API 4.0 to fetch the specification so fetch works with CORS\n *\n * @param spec to fetch and compile\n * @param fetcher function to retrieve API spec content\n */\nexport const sdkSpecFetch = async (\n spec: SpecItem,\n fetcher: ApiSpecFetcher\n): Promise<ParsedSpec> => {\n if (spec.api) return spec.api\n if (!spec.specURL) return undefined\n const [version, name] = apiSpecBits(spec)\n const content = await fetcher(version, name)\n return makeApi(content)\n}\n\n/** Attempt to retrieve spec by URL, then api_spec SDK call\n *\n * @param spec to fetch\n * @param fetcher function to retrieve and parse spec\n */\nexport const fallbackFetch = async (\n spec: SpecItem,\n fetcher: ApiSpecFetcher\n): Promise<ParsedSpec> => {\n if (spec.api) return spec.api\n if (!spec.specURL) return undefined\n let api: ParsedSpec\n try {\n api = await specUrlFetch(spec.specURL)\n } catch (error) {\n console.error({ error })\n }\n if (!api) {\n const authed = runItSDK.authSession.isAuthenticated()\n if (!authed) {\n await runItSDK.authSession.login()\n }\n api = await sdkSpecFetch(spec, fetcher)\n }\n return api\n}\n"],"file":"configUtils.js"}
1
+ {"version":3,"sources":["../../../src/components/ConfigForm/configUtils.ts"],"names":["RunItConfigKey","RunItFormKey","RunItNoConfig","base_url","looker_url","validateUrl","url","result","URL","endsWith","origin","makeApi","content","json","JSON","parse","ApiModel","fromJson","getUrl","settings","verify_ssl","xp","BrowserTransport","response","rawRequest","body","fullify","uri","baseUrl","match","toString","apiSpecBits","spec","specURL","split","slice","funFetch","version","name","sdk","ok","specUrlFetch","error","undefined","loadSpecsFromVersions","defer","fetchResult","specs","webUrl","headless","versions","window","location","api_server_url","web_server_url","fetchSpec","api","fallbackFetch","e","message","sdkSpecFetch","fetcher","console","authed","authSession","isAuthenticated","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 { ILookerVersions, SpecItem, SpecList } from '@looker/sdk-codegen'\nimport {\n ApiModel,\n getSpecsFromVersions,\n upgradeSpecObject,\n} from '@looker/sdk-codegen'\nimport { BrowserTransport, DefaultSettings } from '@looker/sdk-rtl'\nimport { api_spec } from '@looker/sdk'\nimport { getEnvAdaptor } from '@looker/extension-utils'\n\nimport type { RunItValues } from '../..'\n\nexport type StorageLocation = 'session' | 'local'\nexport const RunItConfigKey = 'RunItConfig'\nexport const RunItFormKey = 'RunItForm'\nexport const RunItNoConfig = { base_url: '', looker_url: '' }\n\n/** Object returned from storage service */\nexport interface IStorageValue {\n /** Location of the stored object */\n location: StorageLocation\n /** Stored string representation of the value (usually JSON) */\n value: string\n}\n\n/** function to retrieve a spec based on version and name */\nexport type ApiSpecFetcher = (\n version: string,\n name: string\n) => Promise<string | RunItValues>\n\n/** Either the spec is parsed or it's undefined */\nexport type ParsedSpec = ApiModel | undefined\n\n/** service abstraction for extension and browser based usage */\nexport interface RunItConfigurator {\n getStorage: (key: string, defaultValue?: string) => IStorageValue\n setStorage(key: string, value: string, location: 'local' | 'session'): string\n removeStorage(key: string): void\n}\n\n/** Processed specifications */\nexport interface ILoadedSpecs {\n /** API server url */\n baseUrl: string\n /** Web server url */\n webUrl: string\n /** should APIX run headless? */\n headless: boolean\n /** loaded specifications */\n specs: SpecList\n /** communication errors */\n fetchResult: string\n}\n\n/** Extends versions payload with headless toggle for API Explorer */\nexport interface IAPIXConfig extends ILookerVersions {\n headless?: boolean\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\n/**\n * Convert content into an ApiModel\n * @param content to convert\n */\nconst makeApi = (content: string | RunItValues) => {\n let json\n if (typeof content === 'string') {\n json = JSON.parse(content)\n } else {\n json = content\n }\n json = upgradeSpecObject(json)\n return ApiModel.fromJson(json)\n}\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 * Ensure the URI is a full URL\n * @param uri possible relative path\n * @param baseUrl base url for qualifying full path\n */\nexport const fullify = (uri: string, baseUrl: string): string => {\n if (uri.match(/^https?:/)) {\n return uri\n }\n const url = new URL(uri, baseUrl)\n return url.toString()\n}\n/**\n * parse spec url into version and name for api_spec cccall\n * @param spec to parse\n */\nconst apiSpecBits = (spec: SpecItem): string[] =>\n spec.specURL?.split('/').slice(-2) || []\n\n/**\n * Use the functional api_spec fetch\n * @param version to retrieve\n * @param name to retrieve\n */\nexport const funFetch = (version: string, name: string): Promise<string> => {\n const sdk = getEnvAdaptor().sdk\n return sdk.ok(api_spec(sdk, version, name))\n}\n\n/**\n * try to fetch a spec by URL, trap any errors and return undefined\n * @param url to convert to an API spec\n */\nexport const specUrlFetch = async (url: string): Promise<ParsedSpec> => {\n try {\n const content = await getUrl(url)\n return makeApi(content)\n } catch (error) {\n return undefined\n }\n}\n\n/**\n * Load versions payload and retrieve all supported specs\n *\n * The versions payload should match the structure of Looker's /versions endpoint\n *\n * @param url that has an unauthenticated versions payload. For Looker, this is <LookerHostName>/versions\n * @param content content of versions payload that may already be assigned\n * @param defer true to defer fetching and parsing the spec. Defaults to true.\n */\nexport const loadSpecsFromVersions = async (\n url: string,\n content: string | Record<string, unknown> = '',\n defer = true\n): Promise<ILoadedSpecs> => {\n let fetchResult = ''\n let specs: SpecList = {}\n let baseUrl = ''\n let webUrl = ''\n let headless = false\n try {\n if (!content) {\n content = await getUrl(url)\n }\n const versions = (\n typeof content === 'string' ? JSON.parse(content) : content\n ) as IAPIXConfig\n const origin = (window as any).location.origin\n baseUrl = versions.api_server_url\n webUrl = versions.web_server_url\n if (versions.headless !== undefined) {\n headless = versions.headless\n }\n const fetchSpec = async (spec: SpecItem) => {\n if (spec.specURL) {\n spec.specURL = fullify(spec.specURL, origin)\n if (!defer) {\n spec.api = await fallbackFetch(spec, funFetch)\n }\n }\n return spec.api\n }\n specs = await getSpecsFromVersions(versions, fetchSpec)\n } catch (e: any) {\n fetchResult = e.message\n }\n\n return {\n baseUrl,\n webUrl,\n specs,\n headless,\n fetchResult: fetchResult,\n }\n}\n\n/**\n * fetch and compile an API specification to an ApiModel if it's not already available\n *\n * **NOTE**: This uses Looker API 4.0 to fetch the specification so fetch works with CORS\n *\n * @param spec to fetch and compile\n * @param fetcher function to retrieve API spec content\n */\nexport const sdkSpecFetch = async (\n spec: SpecItem,\n fetcher: ApiSpecFetcher\n): Promise<ParsedSpec> => {\n if (spec.api) return spec.api\n if (!spec.specURL) return undefined\n const [version, name] = apiSpecBits(spec)\n const content = await fetcher(version, name)\n return makeApi(content)\n}\n\n/** Attempt to retrieve spec by URL, then api_spec SDK call\n *\n * @param spec to fetch\n * @param fetcher function to retrieve and parse spec\n */\nexport const fallbackFetch = async (\n spec: SpecItem,\n fetcher: ApiSpecFetcher\n): Promise<ParsedSpec> => {\n if (spec.api) return spec.api\n if (!spec.specURL) return undefined\n let api: ParsedSpec\n try {\n api = await specUrlFetch(spec.specURL)\n } catch (error) {\n console.error({ error })\n }\n if (!api) {\n const sdk = getEnvAdaptor().sdk\n const authed = sdk.authSession.isAuthenticated()\n if (!authed) {\n await sdk.authSession.login()\n }\n api = await sdkSpecFetch(spec, fetcher)\n }\n return api\n}\n"],"file":"configUtils.js"}
@@ -1,3 +1,6 @@
1
1
  import type { FC } from 'react';
2
- import type { DocSdkCallsProps } from './DocSdkCalls';
3
- export declare const DocMultiCall: FC<Omit<DocSdkCallsProps, 'sdkLanguage'>>;
2
+ interface DocMultiCallProps {
3
+ calls: Record<string, string>;
4
+ }
5
+ export declare const DocMultiCall: FC<DocMultiCallProps>;
6
+ export {};
@@ -11,34 +11,22 @@ var _components = require("@looker/components");
11
11
 
12
12
  var _codeEditor = require("@looker/code-editor");
13
13
 
14
- var _callUtils = require("./callUtils");
15
-
16
14
  function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
17
15
 
18
- function _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }
19
-
20
16
  var DocMultiCall = _ref => {
21
17
  var {
22
- api,
23
- inputs,
24
- method
18
+ calls
25
19
  } = _ref;
26
- var tabs = (0, _components.useTabs)();
27
- var generators = (0, _callUtils.getGenerators)(api);
28
- return _react.default.createElement(_react.default.Fragment, null, _react.default.createElement(_components.TabList, tabs, Object.keys(generators).map(language => _react.default.createElement(_components.Tab, {
29
- key: language
30
- }, language))), _react.default.createElement(_components.TabPanels, _extends({}, tabs, {
31
- pt: "0"
32
- }), Object.entries(generators).map(_ref2 => {
33
- var [language, gen] = _ref2;
34
- var code = gen.makeTheCall(method, inputs);
35
- return _react.default.createElement(_components.TabPanel, {
20
+ return _react.default.createElement(_components.Tabs2, null, Object.entries(calls).map(_ref2 => {
21
+ var [language, callSyntax] = _ref2;
22
+ return _react.default.createElement(_components.Tab2, {
23
+ label: language,
36
24
  key: language
37
25
  }, _react.default.createElement(_codeEditor.CodeCopy, {
38
- code: code,
26
+ code: callSyntax,
39
27
  language: language
40
28
  }));
41
- })));
29
+ }));
42
30
  };
43
31
 
44
32
  exports.DocMultiCall = DocMultiCall;
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/components/DocSdkCalls/DocMultiCall.tsx"],"names":["DocMultiCall","api","inputs","method","tabs","generators","Object","keys","map","language","entries","gen","code","makeTheCall"],"mappings":";;;;;;;AA0BA;;AACA;;AAEA;;AACA;;;;;;AAMO,IAAMA,YAAuD,GAAG,QAIjE;AAAA,MAJkE;AACtEC,IAAAA,GADsE;AAEtEC,IAAAA,MAFsE;AAGtEC,IAAAA;AAHsE,GAIlE;AACJ,MAAMC,IAAI,GAAG,0BAAb;AACA,MAAMC,UAAU,GAAG,8BAAcJ,GAAd,CAAnB;AACA,SACE,4DACE,6BAAC,mBAAD,EAAaG,IAAb,EACGE,MAAM,CAACC,IAAP,CAAYF,UAAZ,EAAwBG,GAAxB,CAA6BC,QAAD,IAC3B,6BAAC,eAAD;AAAK,IAAA,GAAG,EAAEA;AAAV,KAAqBA,QAArB,CADD,CADH,CADF,EAME,6BAAC,qBAAD,eAAeL,IAAf;AAAqB,IAAA,EAAE,EAAC;AAAxB,MACGE,MAAM,CAACI,OAAP,CAAeL,UAAf,EAA2BG,GAA3B,CAA+B,SAAqB;AAAA,QAApB,CAACC,QAAD,EAAWE,GAAX,CAAoB;AACnD,QAAMC,IAAI,GAAGD,GAAG,CAACE,WAAJ,CAAgBV,MAAhB,EAAwBD,MAAxB,CAAb;AACA,WACE,6BAAC,oBAAD;AAAU,MAAA,GAAG,EAAEO;AAAf,OACE,6BAAC,oBAAD;AAAU,MAAA,IAAI,EAAEG,IAAhB;AAAsB,MAAA,QAAQ,EAAEH;AAAhC,MADF,CADF;AAKD,GAPA,CADH,CANF,CADF;AAmBD,CA1BM","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 { FC } from 'react'\nimport React from 'react'\nimport { Tab, TabList, TabPanel, TabPanels, useTabs } from '@looker/components'\n\nimport { CodeCopy } from '@looker/code-editor'\nimport { getGenerators } from './callUtils'\nimport type { DocSdkCallsProps } from './DocSdkCalls'\n\n/**\n * Generates the SDK call syntax for all supported languages\n */\nexport const DocMultiCall: FC<Omit<DocSdkCallsProps, 'sdkLanguage'>> = ({\n api,\n inputs,\n method,\n}) => {\n const tabs = useTabs()\n const generators = getGenerators(api)\n return (\n <>\n <TabList {...tabs}>\n {Object.keys(generators).map((language) => (\n <Tab key={language}>{language}</Tab>\n ))}\n </TabList>\n <TabPanels {...tabs} pt=\"0\">\n {Object.entries(generators).map(([language, gen]) => {\n const code = gen.makeTheCall(method, inputs)\n return (\n <TabPanel key={language}>\n <CodeCopy code={code} language={language} />\n </TabPanel>\n )\n })}\n </TabPanels>\n </>\n )\n}\n"],"file":"DocMultiCall.js"}
1
+ {"version":3,"sources":["../../../src/components/DocSdkCalls/DocMultiCall.tsx"],"names":["DocMultiCall","calls","Object","entries","map","language","callSyntax"],"mappings":";;;;;;;AA0BA;;AACA;;AACA;;;;AAUO,IAAMA,YAAmC,GAAG;AAAA,MAAC;AAAEC,IAAAA;AAAF,GAAD;AAAA,SACjD,6BAAC,iBAAD,QACGC,MAAM,CAACC,OAAP,CAAeF,KAAf,EAAsBG,GAAtB,CAA0B;AAAA,QAAC,CAACC,QAAD,EAAWC,UAAX,CAAD;AAAA,WACzB,6BAAC,gBAAD;AAAM,MAAA,KAAK,EAAED,QAAb;AAAuB,MAAA,GAAG,EAAEA;AAA5B,OACE,6BAAC,oBAAD;AAAU,MAAA,IAAI,EAAEC,UAAhB;AAA4B,MAAA,QAAQ,EAAED;AAAtC,MADF,CADyB;AAAA,GAA1B,CADH,CADiD;AAAA,CAA5C","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 { FC } from 'react'\nimport React from 'react'\nimport { Tabs2, Tab2 } from '@looker/components'\nimport { CodeCopy } from '@looker/code-editor'\n\ninterface DocMultiCallProps {\n /** An object with keys representing the language and values for call syntax */\n calls: Record<string, string>\n}\n\n/**\n * Generates the SDK call syntax for all supported languages\n */\nexport const DocMultiCall: FC<DocMultiCallProps> = ({ calls }) => (\n <Tabs2>\n {Object.entries(calls).map(([language, callSyntax]) => (\n <Tab2 label={language} key={language}>\n <CodeCopy code={callSyntax} language={language} />\n </Tab2>\n ))}\n </Tabs2>\n)\n"],"file":"DocMultiCall.js"}
@@ -11,10 +11,14 @@ var _sdkCodegen = require("@looker/sdk-codegen");
11
11
 
12
12
  var _components = require("@looker/components");
13
13
 
14
- var _DocSingleCall = require("./DocSingleCall");
14
+ var _codeEditor = require("@looker/code-editor");
15
+
16
+ var _common = require("../common");
15
17
 
16
18
  var _DocMultiCall = require("./DocMultiCall");
17
19
 
20
+ var _callUtils = require("./callUtils");
21
+
18
22
  function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
19
23
 
20
24
  function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || typeof obj !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
@@ -32,18 +36,31 @@ var DocSdkCalls = _ref => {
32
36
  var text = sdkLanguage === 'All' ? 'SDKs call syntax' : "".concat(sdkLanguage, " SDK call syntax");
33
37
  setHeading(text);
34
38
  }, [sdkLanguage]);
39
+ var calls = {};
40
+
41
+ try {
42
+ if (sdkLanguage === 'All') {
43
+ var generators = (0, _callUtils.getGenerators)(api);
44
+ Object.entries(generators).forEach(_ref2 => {
45
+ var [language, gen] = _ref2;
46
+ calls[language] = gen.makeTheCall(method, trimmedInputs);
47
+ });
48
+ } else {
49
+ var gen = (0, _sdkCodegen.getCodeGenerator)(sdkLanguage, api);
50
+ calls[sdkLanguage] = gen.makeTheCall(method, trimmedInputs);
51
+ }
52
+ } catch (_unused) {
53
+ return _react.default.createElement(_common.DarkSpan, null, "Cannot generate SDK call syntax. Ensure all complex structures in the request form are valid.");
54
+ }
55
+
35
56
  return _react.default.createElement(_react.default.Fragment, null, _react.default.createElement(_components.Heading, {
36
57
  as: "h4",
37
58
  mb: "medium"
38
59
  }, heading), sdkLanguage === 'All' ? _react.default.createElement(_DocMultiCall.DocMultiCall, {
39
- api: api,
40
- inputs: trimmedInputs,
41
- method: method
42
- }) : _react.default.createElement(_DocSingleCall.DocSingleCall, {
43
- api: api,
44
- method: method,
45
- inputs: trimmedInputs,
46
- sdkLanguage: sdkLanguage
60
+ calls: calls
61
+ }) : _react.default.createElement(_codeEditor.CodeCopy, {
62
+ code: calls[sdkLanguage],
63
+ language: sdkLanguage
47
64
  }));
48
65
  };
49
66
 
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/components/DocSdkCalls/DocSdkCalls.tsx"],"names":["DocSdkCalls","api","method","inputs","sdkLanguage","trimmedInputs","heading","setHeading","text"],"mappings":";;;;;;;AA2BA;;AAEA;;AACA;;AAGA;;AACA;;;;;;AAgBO,IAAMA,WAAiC,GAAG,QAK3C;AAAA,MAL4C;AAChDC,IAAAA,GADgD;AAEhDC,IAAAA,MAFgD;AAGhDC,IAAAA,MAHgD;AAIhDC,IAAAA,WAAW,GAAG;AAJkC,GAK5C;AACJ,MAAMC,aAAa,GAAG,4BAAWF,MAAX,CAAtB;AACA,MAAM,CAACG,OAAD,EAAUC,UAAV,IAAwB,qBAAS,EAAT,CAA9B;AAEA,wBAAU,MAAM;AACd,QAAMC,IAAI,GACRJ,WAAW,KAAK,KAAhB,GACI,kBADJ,aAEOA,WAFP,qBADF;AAIAG,IAAAA,UAAU,CAACC,IAAD,CAAV;AACD,GAND,EAMG,CAACJ,WAAD,CANH;AAOA,SACE,4DACE,6BAAC,mBAAD;AAAS,IAAA,EAAE,EAAC,IAAZ;AAAiB,IAAA,EAAE,EAAC;AAApB,KACGE,OADH,CADF,EAIGF,WAAW,KAAK,KAAhB,GACC,6BAAC,0BAAD;AAAc,IAAA,GAAG,EAAEH,GAAnB;AAAwB,IAAA,MAAM,EAAEI,aAAhC;AAA+C,IAAA,MAAM,EAAEH;AAAvD,IADD,GAGC,6BAAC,4BAAD;AACE,IAAA,GAAG,EAAED,GADP;AAEE,IAAA,MAAM,EAAEC,MAFV;AAGE,IAAA,MAAM,EAAEG,aAHV;AAIE,IAAA,WAAW,EAAED;AAJf,IAPJ,CADF;AAiBD,CAjCM","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 } from 'react'\nimport React, { useEffect, useState } from 'react'\nimport type { ApiModel, IMethod } from '@looker/sdk-codegen'\nimport { trimInputs } from '@looker/sdk-codegen'\nimport { Heading } from '@looker/components'\n\nimport type { RunItValues } from '../../RunIt'\nimport { DocSingleCall } from './DocSingleCall'\nimport { DocMultiCall } from './DocMultiCall'\n\nexport interface DocSdkCallsProps {\n /** API spec */\n api: ApiModel\n /** current method */\n method: IMethod\n /** Entered RunIt form values */\n inputs: RunItValues\n /** Language to generate Sdk calls in*/\n sdkLanguage: string\n}\n\n/**\n * Generates the SDK call syntax for a given language or all supported languages\n */\nexport const DocSdkCalls: FC<DocSdkCallsProps> = ({\n api,\n method,\n inputs,\n sdkLanguage = 'All',\n}) => {\n const trimmedInputs = trimInputs(inputs)\n const [heading, setHeading] = useState('')\n\n useEffect(() => {\n const text =\n sdkLanguage === 'All'\n ? 'SDKs call syntax'\n : `${sdkLanguage} SDK call syntax`\n setHeading(text)\n }, [sdkLanguage])\n return (\n <>\n <Heading as=\"h4\" mb=\"medium\">\n {heading}\n </Heading>\n {sdkLanguage === 'All' ? (\n <DocMultiCall api={api} inputs={trimmedInputs} method={method} />\n ) : (\n <DocSingleCall\n api={api}\n method={method}\n inputs={trimmedInputs}\n sdkLanguage={sdkLanguage}\n />\n )}\n </>\n )\n}\n"],"file":"DocSdkCalls.js"}
1
+ {"version":3,"sources":["../../../src/components/DocSdkCalls/DocSdkCalls.tsx"],"names":["DocSdkCalls","api","method","inputs","sdkLanguage","trimmedInputs","heading","setHeading","text","calls","generators","Object","entries","forEach","language","gen","makeTheCall"],"mappings":";;;;;;;AA2BA;;AAEA;;AACA;;AACA;;AAGA;;AACA;;AACA;;;;;;AAgBO,IAAMA,WAAiC,GAAG,QAK3C;AAAA,MAL4C;AAChDC,IAAAA,GADgD;AAEhDC,IAAAA,MAFgD;AAGhDC,IAAAA,MAHgD;AAIhDC,IAAAA,WAAW,GAAG;AAJkC,GAK5C;AACJ,MAAMC,aAAa,GAAG,4BAAWF,MAAX,CAAtB;AACA,MAAM,CAACG,OAAD,EAAUC,UAAV,IAAwB,qBAAS,EAAT,CAA9B;AAEA,wBAAU,MAAM;AACd,QAAMC,IAAI,GACRJ,WAAW,KAAK,KAAhB,GACI,kBADJ,aAEOA,WAFP,qBADF;AAIAG,IAAAA,UAAU,CAACC,IAAD,CAAV;AACD,GAND,EAMG,CAACJ,WAAD,CANH;AAQA,MAAMK,KAAK,GAAG,EAAd;;AACA,MAAI;AACF,QAAIL,WAAW,KAAK,KAApB,EAA2B;AACzB,UAAMM,UAAU,GAAG,8BAAcT,GAAd,CAAnB;AACAU,MAAAA,MAAM,CAACC,OAAP,CAAeF,UAAf,EAA2BG,OAA3B,CAAmC,SAAqB;AAAA,YAApB,CAACC,QAAD,EAAWC,GAAX,CAAoB;AACtDN,QAAAA,KAAK,CAACK,QAAD,CAAL,GAAkBC,GAAG,CAACC,WAAJ,CAAgBd,MAAhB,EAAwBG,aAAxB,CAAlB;AACD,OAFD;AAGD,KALD,MAKO;AACL,UAAMU,GAAG,GAAG,kCAAiBX,WAAjB,EAA8BH,GAA9B,CAAZ;AACAQ,MAAAA,KAAK,CAACL,WAAD,CAAL,GAAqBW,GAAG,CAAEC,WAAL,CAAiBd,MAAjB,EAAyBG,aAAzB,CAArB;AACD;AACF,GAVD,CAUE,gBAAM;AACN,WACE,6BAAC,gBAAD,wGADF;AAMD;;AAED,SACE,4DACE,6BAAC,mBAAD;AAAS,IAAA,EAAE,EAAC,IAAZ;AAAiB,IAAA,EAAE,EAAC;AAApB,KACGC,OADH,CADF,EAIGF,WAAW,KAAK,KAAhB,GACC,6BAAC,0BAAD;AAAc,IAAA,KAAK,EAAEK;AAArB,IADD,GAGC,6BAAC,oBAAD;AAAU,IAAA,IAAI,EAAEA,KAAK,CAACL,WAAD,CAArB;AAAoC,IAAA,QAAQ,EAAEA;AAA9C,IAPJ,CADF;AAYD,CAjDM","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 } from 'react'\nimport React, { useEffect, useState } from 'react'\nimport type { ApiModel, IMethod } from '@looker/sdk-codegen'\nimport { getCodeGenerator, trimInputs } from '@looker/sdk-codegen'\nimport { Heading } from '@looker/components'\nimport { CodeCopy } from '@looker/code-editor'\n\nimport type { RunItValues } from '../../RunIt'\nimport { DarkSpan } from '../common'\nimport { DocMultiCall } from './DocMultiCall'\nimport { getGenerators } from './callUtils'\n\nexport interface DocSdkCallsProps {\n /** API spec */\n api: ApiModel\n /** current method */\n method: IMethod\n /** Entered RunIt form values */\n inputs: RunItValues\n /** Language to generate Sdk calls in*/\n sdkLanguage: string\n}\n\n/**\n * Generates the SDK call syntax for a given language or all supported languages\n */\nexport const DocSdkCalls: FC<DocSdkCallsProps> = ({\n api,\n method,\n inputs,\n sdkLanguage = 'All',\n}) => {\n const trimmedInputs = trimInputs(inputs)\n const [heading, setHeading] = useState('')\n\n useEffect(() => {\n const text =\n sdkLanguage === 'All'\n ? 'SDKs call syntax'\n : `${sdkLanguage} SDK call syntax`\n setHeading(text)\n }, [sdkLanguage])\n\n const calls = {}\n try {\n if (sdkLanguage === 'All') {\n const generators = getGenerators(api)\n Object.entries(generators).forEach(([language, gen]) => {\n calls[language] = gen.makeTheCall(method, trimmedInputs)\n })\n } else {\n const gen = getCodeGenerator(sdkLanguage, api)\n calls[sdkLanguage] = gen!.makeTheCall(method, trimmedInputs)\n }\n } catch {\n return (\n <DarkSpan>\n Cannot generate SDK call syntax. Ensure all complex structures in the\n request form are valid.\n </DarkSpan>\n )\n }\n\n return (\n <>\n <Heading as=\"h4\" mb=\"medium\">\n {heading}\n </Heading>\n {sdkLanguage === 'All' ? (\n <DocMultiCall calls={calls} />\n ) : (\n <CodeCopy code={calls[sdkLanguage]} language={sdkLanguage} />\n )}\n </>\n )\n}\n"],"file":"DocSdkCalls.js"}
@@ -1,13 +1,7 @@
1
- import type { Dispatch, FC } from 'react';
2
- import type { IAPIMethods } from '@looker/sdk-rtl';
3
- import type { RunItConfigurator } from '../ConfigForm';
4
- import type { RunItValues, RunItSetter } from '../..';
1
+ import type { FC } from 'react';
2
+ import type { RunItValues } from '../..';
5
3
  interface LoginFormProps {
6
- configurator: RunItConfigurator;
7
4
  requestContent: RunItValues;
8
- setVersionsUrl: RunItSetter;
9
- setHasConfig?: Dispatch<boolean>;
10
- sdk?: IAPIMethods;
11
5
  }
12
6
  export declare const readyToLogin = "OAuth is configured but your browser session is not authenticated. Click Login to enable RunIt.";
13
7
  export declare const LoginForm: FC<LoginFormProps>;
@@ -9,7 +9,7 @@ var _react = _interopRequireDefault(require("react"));
9
9
 
10
10
  var _components = require("@looker/components");
11
11
 
12
- var _utils = require("../../utils");
12
+ var _extensionUtils = require("@looker/extension-utils");
13
13
 
14
14
  var _ConfigForm = require("../ConfigForm");
15
15
 
@@ -24,20 +24,19 @@ exports.readyToLogin = readyToLogin;
24
24
 
25
25
  var LoginForm = _ref => {
26
26
  var {
27
- configurator,
28
- requestContent,
29
- sdk = _utils.runItSDK
27
+ requestContent
30
28
  } = _ref;
29
+ var adaptor = (0, _extensionUtils.getEnvAdaptor)();
31
30
 
32
31
  var handleLogin = function () {
33
32
  var _ref2 = _asyncToGenerator(function* (e) {
34
33
  e.preventDefault();
35
34
 
36
35
  if (requestContent) {
37
- configurator.setStorage(_ConfigForm.RunItFormKey, JSON.stringify(requestContent), 'local');
36
+ adaptor.localStorageSetItem(_ConfigForm.RunItFormKey, JSON.stringify(requestContent));
38
37
  }
39
38
 
40
- yield sdk === null || sdk === void 0 ? void 0 : sdk.authSession.login();
39
+ yield adaptor.sdk.authSession.login();
41
40
  });
42
41
 
43
42
  return function handleLogin(_x) {
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/components/LoginForm/LoginForm.tsx"],"names":["readyToLogin","LoginForm","configurator","requestContent","sdk","runItSDK","handleLogin","e","preventDefault","setStorage","RunItFormKey","JSON","stringify","authSession","login"],"mappings":";;;;;;;AA2BA;;AACA;;AAEA;;AAEA;;;;;;;;AAaO,IAAMA,YAAY,GACvB,iGADK;;;AAGA,IAAMC,SAA6B,GAAG,QAIvC;AAAA,MAJwC;AAC5CC,IAAAA,YAD4C;AAE5CC,IAAAA,cAF4C;AAG5CC,IAAAA,GAAG,GAAGC;AAHsC,GAIxC;;AACJ,MAAMC,WAAW;AAAA,kCAAG,WAAOC,CAAP,EAAiC;AACnDA,MAAAA,CAAC,CAACC,cAAF;;AACA,UAAIL,cAAJ,EAAoB;AAClBD,QAAAA,YAAY,CAACO,UAAb,CACEC,wBADF,EAEEC,IAAI,CAACC,SAAL,CAAeT,cAAf,CAFF,EAGE,OAHF;AAKD;;AAED,YAAMC,GAAN,aAAMA,GAAN,uBAAMA,GAAG,CAAES,WAAL,CAAiBC,KAAjB,EAAN;AACD,KAXgB;;AAAA,oBAAXR,WAAW;AAAA;AAAA;AAAA,KAAjB;;AAaA,SACE,6BAAC,mBAAD;AAAS,IAAA,OAAO,EAAEN;AAAlB,KACE,6BAAC,kBAAD;AAAQ,IAAA,OAAO,EAAEM;AAAjB,aADF,CADF;AAKD,CAvBM","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 } from 'react'\nimport React from 'react'\nimport { Button, Tooltip } from '@looker/components'\nimport type { IAPIMethods } from '@looker/sdk-rtl'\nimport { runItSDK } from '../../utils'\nimport type { RunItConfigurator } from '../ConfigForm'\nimport { RunItFormKey } from '../ConfigForm'\nimport type { RunItValues, RunItSetter } from '../..'\n\ninterface LoginFormProps {\n configurator: RunItConfigurator\n requestContent: RunItValues\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 /** SDK to use for login. Defaults to the `runItSDK` */\n sdk?: IAPIMethods\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> = ({\n configurator,\n requestContent,\n sdk = runItSDK,\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 <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","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,10 +1,8 @@
1
1
  import type { FC } from 'react';
2
- import type { RunItConfigurator } from '../ConfigForm';
3
2
  import { PerfTimings } from './perfUtils';
4
3
  interface PerfTrackerProps {
5
4
  perf?: PerfTimings;
6
5
  showAllColumns?: boolean;
7
- configurator: RunItConfigurator;
8
6
  }
9
7
  export declare const PerfTracker: FC<PerfTrackerProps>;
10
8
  export {};
@@ -25,12 +25,12 @@ function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "functio
25
25
 
26
26
  function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || typeof obj !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
27
27
 
28
- var perfFilter = function perfFilter(configurator) {
29
- var all = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : false;
28
+ var perfFilter = function perfFilter() {
29
+ var all = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : false;
30
30
  if (all) return '.*';
31
- var storage = configurator.getStorage(_ConfigForm.RunItConfigKey);
32
- if (!storage.value) return '.*';
33
- var config = JSON.parse(storage.value);
31
+ var value = localStorage.getItem(_ConfigForm.RunItConfigKey);
32
+ if (!value) return '.*';
33
+ var config = JSON.parse(value);
34
34
  var url = new URL(config.base_url);
35
35
  return "".concat(url.protocol, "//").concat(url.hostname, ".*");
36
36
  };
@@ -38,12 +38,11 @@ var perfFilter = function perfFilter(configurator) {
38
38
  var PerfTracker = _ref => {
39
39
  var {
40
40
  perf = new _perfUtils.PerfTimings(),
41
- showAllColumns = false,
42
- configurator
41
+ showAllColumns = false
43
42
  } = _ref;
44
43
  var [loading, setLoading] = (0, _react.useState)(false);
45
44
  var [showAll, setShowAll] = (0, _react.useState)(false);
46
- var [filter, setFilter] = (0, _react.useState)(perfFilter(configurator));
45
+ var [filter, setFilter] = (0, _react.useState)(perfFilter());
47
46
  var [data, setData] = (0, _react.useState)(perf.entries(filter));
48
47
  var [timings, setTimings] = (0, _react.useState)(data.length > 0 ? data[0] : undefined);
49
48
 
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/components/PerfTracker/PerfTracker.tsx"],"names":["perfFilter","configurator","all","storage","getStorage","RunItConfigKey","value","config","JSON","parse","url","URL","base_url","protocol","hostname","PerfTracker","perf","PerfTimings","showAllColumns","loading","setLoading","showAll","setShowAll","filter","setFilter","data","setData","entries","timings","setTimings","length","undefined","handleClear","_","clear","handleFilterChange","e","target","checked","pf","handleSelect","item","supported"],"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, { useEffect, useState } from 'react'\nimport {\n Heading,\n FlexItem,\n IconButton,\n SpaceVertical,\n FieldToggleSwitch,\n Flex,\n} from '@looker/components'\nimport { Delete } from '@styled-icons/material/Delete'\n\nimport type { RunItConfigurator } from '../ConfigForm'\nimport { RunItConfigKey } from '../ConfigForm'\nimport { Loading } from '../Loading'\nimport type { LoadTimes } from './perfUtils'\nimport { PerfTimings } from './perfUtils'\nimport { PerfChart } from './PerfChart'\nimport { PerfTable } from './PerfTable'\n\ninterface PerfTrackerProps {\n perf?: PerfTimings\n showAllColumns?: boolean\n configurator: RunItConfigurator\n}\n\nconst perfFilter = (configurator: RunItConfigurator, all = false) => {\n if (all) return '.*'\n const storage = configurator.getStorage(RunItConfigKey)\n if (!storage.value) return '.*'\n const config = JSON.parse(storage.value)\n const url = new URL(config.base_url)\n return `${url.protocol}//${url.hostname}.*`\n}\n\nexport const PerfTracker: FC<PerfTrackerProps> = ({\n perf = new PerfTimings(),\n showAllColumns = false,\n configurator,\n}) => {\n // TODO UI option to filter by url pattern\n const [loading, setLoading] = useState(false)\n const [showAll, setShowAll] = useState(false)\n const [filter, setFilter] = useState(perfFilter(configurator))\n const [data, setData] = useState<LoadTimes[]>(perf.entries(filter))\n const [timings, setTimings] = useState(data.length > 0 ? data[0] : undefined)\n\n const handleClear = (_: BaseSyntheticEvent) => {\n setLoading(true)\n perf.clear()\n setData([])\n setTimings(undefined)\n }\n\n const handleFilterChange = (e: BaseSyntheticEvent) => {\n setLoading(true)\n const all = e.target.checked\n setShowAll(all)\n const pf = perfFilter(all)\n setFilter(pf)\n setData(perf.entries(pf))\n }\n\n useEffect(() => {\n setLoading(false)\n }, [data])\n\n const handleSelect = (item: LoadTimes) => setTimings(item)\n\n return (\n <>\n <Heading>Load Times for {filter}</Heading>\n <Flex>\n <FlexItem>\n <IconButton\n icon={<Delete />}\n onClick={handleClear}\n label=\"Clear the performance queue\"\n />\n </FlexItem>\n <FlexItem>\n <FieldToggleSwitch\n name=\"filtering\"\n label=\"Show All\"\n onChange={handleFilterChange}\n on={showAll}\n />\n </FlexItem>\n <FlexItem>\n <Loading loading={loading} />\n </FlexItem>\n </Flex>\n <>\n {!PerfTimings.supported &&\n 'Performance timing is not supported in this browser'}\n {PerfTimings.supported && !!timings && (\n <SpaceVertical gap=\"small\">\n <PerfChart loadTimes={timings} />\n <PerfTable\n data={data}\n onSelect={handleSelect}\n showAllColumns={showAllColumns}\n />\n </SpaceVertical>\n )}\n {PerfTimings.supported &&\n data.length < 1 &&\n 'No performance data is loaded'}\n </>\n </>\n )\n}\n"],"file":"PerfTracker.js"}
1
+ {"version":3,"sources":["../../../src/components/PerfTracker/PerfTracker.tsx"],"names":["perfFilter","all","value","localStorage","getItem","RunItConfigKey","config","JSON","parse","url","URL","base_url","protocol","hostname","PerfTracker","perf","PerfTimings","showAllColumns","loading","setLoading","showAll","setShowAll","filter","setFilter","data","setData","entries","timings","setTimings","length","undefined","handleClear","_","clear","handleFilterChange","e","target","checked","pf","handleSelect","item","supported"],"mappings":";;;;;;;AA2BA;;AACA;;AAQA;;AAEA;;AACA;;AAEA;;AACA;;AACA;;;;;;AAOA,IAAMA,UAAU,GAAG,SAAbA,UAAa,GAAiB;AAAA,MAAhBC,GAAgB,uEAAV,KAAU;AAClC,MAAIA,GAAJ,EAAS,OAAO,IAAP;AAKT,MAAMC,KAAK,GAAGC,YAAY,CAACC,OAAb,CAAqBC,0BAArB,CAAd;AACA,MAAI,CAACH,KAAL,EAAY,OAAO,IAAP;AACZ,MAAMI,MAAM,GAAGC,IAAI,CAACC,KAAL,CAAWN,KAAX,CAAf;AACA,MAAMO,GAAG,GAAG,IAAIC,GAAJ,CAAQJ,MAAM,CAACK,QAAf,CAAZ;AACA,mBAAUF,GAAG,CAACG,QAAd,eAA2BH,GAAG,CAACI,QAA/B;AACD,CAXD;;AAaO,IAAMC,WAAiC,GAAG,QAG3C;AAAA,MAH4C;AAChDC,IAAAA,IAAI,GAAG,IAAIC,sBAAJ,EADyC;AAEhDC,IAAAA,cAAc,GAAG;AAF+B,GAG5C;AAEJ,MAAM,CAACC,OAAD,EAAUC,UAAV,IAAwB,qBAAS,KAAT,CAA9B;AACA,MAAM,CAACC,OAAD,EAAUC,UAAV,IAAwB,qBAAS,KAAT,CAA9B;AACA,MAAM,CAACC,MAAD,EAASC,SAAT,IAAsB,qBAASvB,UAAU,EAAnB,CAA5B;AACA,MAAM,CAACwB,IAAD,EAAOC,OAAP,IAAkB,qBAAsBV,IAAI,CAACW,OAAL,CAAaJ,MAAb,CAAtB,CAAxB;AACA,MAAM,CAACK,OAAD,EAAUC,UAAV,IAAwB,qBAASJ,IAAI,CAACK,MAAL,GAAc,CAAd,GAAkBL,IAAI,CAAC,CAAD,CAAtB,GAA4BM,SAArC,CAA9B;;AAEA,MAAMC,WAAW,GAAIC,CAAD,IAA2B;AAC7Cb,IAAAA,UAAU,CAAC,IAAD,CAAV;AACAJ,IAAAA,IAAI,CAACkB,KAAL;AACAR,IAAAA,OAAO,CAAC,EAAD,CAAP;AACAG,IAAAA,UAAU,CAACE,SAAD,CAAV;AACD,GALD;;AAOA,MAAMI,kBAAkB,GAAIC,CAAD,IAA2B;AACpDhB,IAAAA,UAAU,CAAC,IAAD,CAAV;AACA,QAAMlB,GAAG,GAAGkC,CAAC,CAACC,MAAF,CAASC,OAArB;AACAhB,IAAAA,UAAU,CAACpB,GAAD,CAAV;AACA,QAAMqC,EAAE,GAAGtC,UAAU,CAACC,GAAD,CAArB;AACAsB,IAAAA,SAAS,CAACe,EAAD,CAAT;AACAb,IAAAA,OAAO,CAACV,IAAI,CAACW,OAAL,CAAaY,EAAb,CAAD,CAAP;AACD,GAPD;;AASA,wBAAU,MAAM;AACdnB,IAAAA,UAAU,CAAC,KAAD,CAAV;AACD,GAFD,EAEG,CAACK,IAAD,CAFH;;AAIA,MAAMe,YAAY,GAAIC,IAAD,IAAqBZ,UAAU,CAACY,IAAD,CAApD;;AAEA,SACE,4DACE,6BAAC,mBAAD,2BAAyBlB,MAAzB,CADF,EAEE,6BAAC,gBAAD,QACE,6BAAC,oBAAD,QACE,6BAAC,sBAAD;AACE,IAAA,IAAI,EAAE,6BAAC,cAAD,OADR;AAEE,IAAA,OAAO,EAAES,WAFX;AAGE,IAAA,KAAK,EAAC;AAHR,IADF,CADF,EAQE,6BAAC,oBAAD,QACE,6BAAC,6BAAD;AACE,IAAA,IAAI,EAAC,WADP;AAEE,IAAA,KAAK,EAAC,UAFR;AAGE,IAAA,QAAQ,EAAEG,kBAHZ;AAIE,IAAA,EAAE,EAAEd;AAJN,IADF,CARF,EAgBE,6BAAC,oBAAD,QACE,6BAAC,gBAAD;AAAS,IAAA,OAAO,EAAEF;AAAlB,IADF,CAhBF,CAFF,EAsBE,4DACG,CAACF,uBAAYyB,SAAb,IACC,qDAFJ,EAGGzB,uBAAYyB,SAAZ,IAAyB,CAAC,CAACd,OAA3B,IACC,6BAAC,yBAAD;AAAe,IAAA,GAAG,EAAC;AAAnB,KACE,6BAAC,oBAAD;AAAW,IAAA,SAAS,EAAEA;AAAtB,IADF,EAEE,6BAAC,oBAAD;AACE,IAAA,IAAI,EAAEH,IADR;AAEE,IAAA,QAAQ,EAAEe,YAFZ;AAGE,IAAA,cAAc,EAAEtB;AAHlB,IAFF,CAJJ,EAaGD,uBAAYyB,SAAZ,IACCjB,IAAI,CAACK,MAAL,GAAc,CADf,IAEC,+BAfJ,CAtBF,CADF;AA0CD,CA3EM","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, { useEffect, useState } from 'react'\nimport {\n Heading,\n FlexItem,\n IconButton,\n SpaceVertical,\n FieldToggleSwitch,\n Flex,\n} from '@looker/components'\nimport { Delete } from '@styled-icons/material/Delete'\n\nimport { RunItConfigKey } from '../ConfigForm'\nimport { Loading } from '../Loading'\nimport type { LoadTimes } from './perfUtils'\nimport { PerfTimings } from './perfUtils'\nimport { PerfChart } from './PerfChart'\nimport { PerfTable } from './PerfTable'\n\ninterface PerfTrackerProps {\n perf?: PerfTimings\n showAllColumns?: boolean\n}\n\nconst perfFilter = (all = false) => {\n if (all) return '.*'\n // TODO: temporary solution until redux is introduced in RunIt. Using the env\n // adaptor makes the below async, which in turn makes it hard to use this to\n // set the initial state. PerfTracker is only used in the standalone version\n // so this achieves parity.\n const value = localStorage.getItem(RunItConfigKey)\n if (!value) return '.*'\n const config = JSON.parse(value)\n const url = new URL(config.base_url)\n return `${url.protocol}//${url.hostname}.*`\n}\n\nexport const PerfTracker: FC<PerfTrackerProps> = ({\n perf = new PerfTimings(),\n showAllColumns = false,\n}) => {\n // TODO UI option to filter by url pattern\n const [loading, setLoading] = useState(false)\n const [showAll, setShowAll] = useState(false)\n const [filter, setFilter] = useState(perfFilter())\n const [data, setData] = useState<LoadTimes[]>(perf.entries(filter))\n const [timings, setTimings] = useState(data.length > 0 ? data[0] : undefined)\n\n const handleClear = (_: BaseSyntheticEvent) => {\n setLoading(true)\n perf.clear()\n setData([])\n setTimings(undefined)\n }\n\n const handleFilterChange = (e: BaseSyntheticEvent) => {\n setLoading(true)\n const all = e.target.checked\n setShowAll(all)\n const pf = perfFilter(all)\n setFilter(pf)\n setData(perf.entries(pf))\n }\n\n useEffect(() => {\n setLoading(false)\n }, [data])\n\n const handleSelect = (item: LoadTimes) => setTimings(item)\n\n return (\n <>\n <Heading>Load Times for {filter}</Heading>\n <Flex>\n <FlexItem>\n <IconButton\n icon={<Delete />}\n onClick={handleClear}\n label=\"Clear the performance queue\"\n />\n </FlexItem>\n <FlexItem>\n <FieldToggleSwitch\n name=\"filtering\"\n label=\"Show All\"\n onChange={handleFilterChange}\n on={showAll}\n />\n </FlexItem>\n <FlexItem>\n <Loading loading={loading} />\n </FlexItem>\n </Flex>\n <>\n {!PerfTimings.supported &&\n 'Performance timing is not supported in this browser'}\n {PerfTimings.supported && !!timings && (\n <SpaceVertical gap=\"small\">\n <PerfChart loadTimes={timings} />\n <PerfTable\n data={data}\n onSelect={handleSelect}\n showAllColumns={showAllColumns}\n />\n </SpaceVertical>\n )}\n {PerfTimings.supported &&\n data.length < 1 &&\n 'No performance data is loaded'}\n </>\n </>\n )\n}\n"],"file":"PerfTracker.js"}
@@ -1,10 +1,7 @@
1
1
  import type { BaseSyntheticEvent, FC, Dispatch } from 'react';
2
- import type { IAPIMethods } from '@looker/sdk-rtl';
3
2
  import type { RunItHttpMethod, RunItInput, RunItValues } from '../../RunIt';
4
- import type { RunItConfigurator } from '../ConfigForm';
5
3
  import type { RunItSetter } from '../..';
6
4
  interface RequestFormProps {
7
- sdk: IAPIMethods;
8
5
  inputs: RunItInput[];
9
6
  handleSubmit: (e: BaseSyntheticEvent) => void;
10
7
  httpMethod: RunItHttpMethod;
@@ -15,7 +12,6 @@ interface RequestFormProps {
15
12
  handleConfig: (e: BaseSyntheticEvent) => void;
16
13
  setVersionsUrl: RunItSetter;
17
14
  setHasConfig?: Dispatch<boolean>;
18
- configurator: RunItConfigurator;
19
15
  validationMessage?: string;
20
16
  setValidationMessage?: Dispatch<string>;
21
17
  isExtension?: boolean;
@@ -25,7 +25,6 @@ function _defineProperty(obj, key, value) { if (key in obj) { Object.definePrope
25
25
 
26
26
  var RequestForm = _ref => {
27
27
  var {
28
- sdk,
29
28
  inputs,
30
29
  httpMethod,
31
30
  handleSubmit,
@@ -34,9 +33,7 @@ var RequestForm = _ref => {
34
33
  needsAuth,
35
34
  hasConfig,
36
35
  handleConfig,
37
- setVersionsUrl,
38
36
  setHasConfig,
39
- configurator,
40
37
  validationMessage,
41
38
  setValidationMessage,
42
39
  isExtension = false
@@ -87,10 +84,6 @@ var RequestForm = _ref => {
87
84
  }, validationMessage), _react.default.createElement(_components.Fieldset, null, inputs.map(input => typeof input.type === 'string' ? (0, _formUtils.createSimpleItem)(input, handleChange, handleNumberChange, handleBoolChange, handleDateChange, requestContent) : (0, _formUtils.createComplexItem)(input, handleComplexChange, requestContent)), httpMethod !== 'GET' && (0, _formUtils.showDataChangeWarning)(), _react.default.createElement(_FormItem.FormItem, {
88
85
  id: "buttonbar"
89
86
  }, _react.default.createElement(_react.default.Fragment, null, hasConfig ? needsAuth ? _react.default.createElement(_LoginForm.LoginForm, {
90
- sdk: sdk,
91
- setVersionsUrl: setVersionsUrl,
92
- setHasConfig: setHasConfig,
93
- configurator: configurator,
94
87
  requestContent: requestContent
95
88
  }) : _react.default.createElement(_components.Tooltip, {
96
89
  content: "Run the API request"
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/components/RequestForm/RequestForm.tsx"],"names":["RequestForm","sdk","inputs","httpMethod","handleSubmit","requestContent","setRequestContent","needsAuth","hasConfig","handleConfig","setVersionsUrl","setHasConfig","configurator","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 { IAPIMethods } from '@looker/sdk-rtl'\nimport type { RunItHttpMethod, RunItInput, RunItValues } from '../../RunIt'\nimport type { RunItConfigurator } from '../ConfigForm'\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 /** Established SDK instance */\n sdk: IAPIMethods\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 /** Configuration plug-in for stand-alone or extension */\n configurator: RunItConfigurator\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 sdk,\n inputs,\n httpMethod,\n handleSubmit,\n requestContent,\n setRequestContent,\n needsAuth,\n hasConfig,\n handleConfig,\n setVersionsUrl,\n setHasConfig,\n configurator,\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\n sdk={sdk}\n setVersionsUrl={setVersionsUrl}\n setHasConfig={setHasConfig}\n configurator={configurator}\n requestContent={requestContent}\n />\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 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"}
@@ -7,4 +7,4 @@ export declare const updateNullableProp: (state: RunItValues, key: string, newVa
7
7
  [x: string]: any;
8
8
  };
9
9
  export declare const validateEncodedValues: (body: string) => string;
10
- export declare const validateBody: (body: string | Record<string, any>) => string;
10
+ export declare const validateBody: (body: string | Record<string, any>, requiredKeys: string[]) => string;
@@ -195,23 +195,38 @@ var validateEncodedValues = body => {
195
195
 
196
196
  exports.validateEncodedValues = validateEncodedValues;
197
197
 
198
- var validateBody = body => {
198
+ var validateBody = (body, requiredKeys) => {
199
+ var parsed;
199
200
  var result = '';
200
201
 
201
- if (body && typeof body === 'string') {
202
- if (/^[[{}"]/.test(body)) {
203
- try {
204
- JSON.parse(body);
205
- } catch (e) {
206
- result = e.message;
202
+ if (body) {
203
+ if (typeof body === 'string') {
204
+ if (/^[[{}"]/.test(body)) {
205
+ try {
206
+ parsed = JSON.parse(body);
207
+ } catch (e) {
208
+ result = e.message;
209
+ }
210
+ } else {
211
+ result = validateEncodedValues(body);
212
+ }
213
+
214
+ if (result) {
215
+ result = "Syntax error in the body: ".concat(result);
207
216
  }
208
217
  } else {
209
- result = validateEncodedValues(body);
218
+ parsed = body;
210
219
  }
211
220
  }
212
221
 
213
- if (result) {
214
- result = "Syntax error in the body: ".concat(result);
222
+ if (parsed && requiredKeys && requiredKeys.length > 0) {
223
+ var required = new Set(requiredKeys);
224
+ var keys = new Set(Object.keys(parsed));
225
+ var missing = new Set([...required].filter(k => !keys.has(k)));
226
+
227
+ if (missing.size > 0) {
228
+ result = "Error: Required properties \"".concat(Array.from(missing).join(', '), "\" must be provided in the body");
229
+ }
215
230
  }
216
231
 
217
232
  return result;