@looker/run-it 0.9.52 → 0.9.54

Sign up to get free protection for your applications and to get access to all the features.
Files changed (126) hide show
  1. package/CHANGELOG.md +14 -0
  2. package/lib/RunIt.js.map +1 -1
  3. package/lib/RunItProvider.js.map +1 -1
  4. package/lib/components/Collapser/CollapserCard.js.map +1 -1
  5. package/lib/components/ConfigForm/ConfigForm.js.map +1 -1
  6. package/lib/components/ConfigForm/utils.js.map +1 -1
  7. package/lib/components/CopyLinkWrapper/CopyLinkWrapper.js.map +1 -1
  8. package/lib/components/DataGrid/DataGrid.js.map +1 -1
  9. package/lib/components/DataGrid/gridUtils.js.map +1 -1
  10. package/lib/components/DocSdkCalls/DocMultiCall.js.map +1 -1
  11. package/lib/components/DocSdkCalls/DocSdkCalls.js.map +1 -1
  12. package/lib/components/Loading/Loading.js.map +1 -1
  13. package/lib/components/LoginForm/LoginForm.js.map +1 -1
  14. package/lib/components/MethodBadge/MethodBadge.js.map +1 -1
  15. package/lib/components/PerfTracker/PerfChart.js.map +1 -1
  16. package/lib/components/PerfTracker/PerfTable.js.map +1 -1
  17. package/lib/components/PerfTracker/PerfTracker.js.map +1 -1
  18. package/lib/components/PerfTracker/perfTableUtils.js.map +1 -1
  19. package/lib/components/PerfTracker/perfUtils.js.map +1 -1
  20. package/lib/components/RequestForm/FormItem.js.map +1 -1
  21. package/lib/components/RequestForm/RequestForm.js.map +1 -1
  22. package/lib/components/RequestForm/formUtils.js.map +1 -1
  23. package/lib/components/ResponseExplorer/ResponseExplorer.js.map +1 -1
  24. package/lib/components/ShowResponse/ShowResponse.js.map +1 -1
  25. package/lib/components/ShowResponse/responseUtils.js.map +1 -1
  26. package/lib/components/common/common.js.map +1 -1
  27. package/lib/esm/RunIt.js +48 -57
  28. package/lib/esm/RunIt.js.map +1 -1
  29. package/lib/esm/RunItProvider.js +4 -14
  30. package/lib/esm/RunItProvider.js.map +1 -1
  31. package/lib/esm/components/Collapser/CollapserCard.js +14 -22
  32. package/lib/esm/components/Collapser/CollapserCard.js.map +1 -1
  33. package/lib/esm/components/Collapser/index.js +1 -12
  34. package/lib/esm/components/Collapser/index.js.map +1 -1
  35. package/lib/esm/components/ConfigForm/ConfigForm.js +49 -58
  36. package/lib/esm/components/ConfigForm/ConfigForm.js.map +1 -1
  37. package/lib/esm/components/ConfigForm/index.js +2 -27
  38. package/lib/esm/components/ConfigForm/index.js.map +1 -1
  39. package/lib/esm/components/ConfigForm/utils.js +9 -21
  40. package/lib/esm/components/ConfigForm/utils.js.map +1 -1
  41. package/lib/esm/components/CopyLinkWrapper/CopyLinkWrapper.js +13 -22
  42. package/lib/esm/components/CopyLinkWrapper/CopyLinkWrapper.js.map +1 -1
  43. package/lib/esm/components/CopyLinkWrapper/index.js +1 -12
  44. package/lib/esm/components/CopyLinkWrapper/index.js.map +1 -1
  45. package/lib/esm/components/DataGrid/DataGrid.js +16 -25
  46. package/lib/esm/components/DataGrid/DataGrid.js.map +1 -1
  47. package/lib/esm/components/DataGrid/gridUtils.js +13 -26
  48. package/lib/esm/components/DataGrid/gridUtils.js.map +1 -1
  49. package/lib/esm/components/DataGrid/index.js +2 -25
  50. package/lib/esm/components/DataGrid/index.js.map +1 -1
  51. package/lib/esm/components/DocSdkCalls/DocMultiCall.js +7 -15
  52. package/lib/esm/components/DocSdkCalls/DocMultiCall.js.map +1 -1
  53. package/lib/esm/components/DocSdkCalls/DocSdkCalls.js +17 -26
  54. package/lib/esm/components/DocSdkCalls/DocSdkCalls.js.map +1 -1
  55. package/lib/esm/components/DocSdkCalls/callUtils.js +3 -10
  56. package/lib/esm/components/DocSdkCalls/callUtils.js.map +1 -1
  57. package/lib/esm/components/DocSdkCalls/index.js +2 -19
  58. package/lib/esm/components/DocSdkCalls/index.js.map +1 -1
  59. package/lib/esm/components/Loading/Loading.js +6 -14
  60. package/lib/esm/components/Loading/Loading.js.map +1 -1
  61. package/lib/esm/components/Loading/index.js +1 -12
  62. package/lib/esm/components/Loading/index.js.map +1 -1
  63. package/lib/esm/components/LoginForm/LoginForm.js +11 -21
  64. package/lib/esm/components/LoginForm/LoginForm.js.map +1 -1
  65. package/lib/esm/components/LoginForm/index.js +1 -18
  66. package/lib/esm/components/LoginForm/index.js.map +1 -1
  67. package/lib/esm/components/MethodBadge/MethodBadge.js +8 -19
  68. package/lib/esm/components/MethodBadge/MethodBadge.js.map +1 -1
  69. package/lib/esm/components/MethodBadge/index.js +1 -12
  70. package/lib/esm/components/MethodBadge/index.js.map +1 -1
  71. package/lib/esm/components/PerfTracker/PerfChart.js +11 -19
  72. package/lib/esm/components/PerfTracker/PerfChart.js.map +1 -1
  73. package/lib/esm/components/PerfTracker/PerfTable.js +13 -22
  74. package/lib/esm/components/PerfTracker/PerfTable.js.map +1 -1
  75. package/lib/esm/components/PerfTracker/PerfTracker.js +25 -34
  76. package/lib/esm/components/PerfTracker/PerfTracker.js.map +1 -1
  77. package/lib/esm/components/PerfTracker/index.js +2 -19
  78. package/lib/esm/components/PerfTracker/index.js.map +1 -1
  79. package/lib/esm/components/PerfTracker/perfTableUtils.js +17 -27
  80. package/lib/esm/components/PerfTracker/perfTableUtils.js.map +1 -1
  81. package/lib/esm/components/PerfTracker/perfUtils.js +3 -12
  82. package/lib/esm/components/PerfTracker/perfUtils.js.map +1 -1
  83. package/lib/esm/components/RequestForm/FormItem.js +6 -14
  84. package/lib/esm/components/RequestForm/FormItem.js.map +1 -1
  85. package/lib/esm/components/RequestForm/RequestForm.js +24 -32
  86. package/lib/esm/components/RequestForm/RequestForm.js.map +1 -1
  87. package/lib/esm/components/RequestForm/formUtils.js +26 -41
  88. package/lib/esm/components/RequestForm/formUtils.js.map +1 -1
  89. package/lib/esm/components/RequestForm/index.js +2 -19
  90. package/lib/esm/components/RequestForm/index.js.map +1 -1
  91. package/lib/esm/components/ResponseExplorer/ResponseExplorer.js +30 -41
  92. package/lib/esm/components/ResponseExplorer/ResponseExplorer.js.map +1 -1
  93. package/lib/esm/components/ResponseExplorer/index.js +1 -16
  94. package/lib/esm/components/ResponseExplorer/index.js.map +1 -1
  95. package/lib/esm/components/ShowResponse/ShowResponse.js +6 -14
  96. package/lib/esm/components/ShowResponse/ShowResponse.js.map +1 -1
  97. package/lib/esm/components/ShowResponse/index.js +1 -12
  98. package/lib/esm/components/ShowResponse/index.js.map +1 -1
  99. package/lib/esm/components/ShowResponse/responseUtils.js +28 -41
  100. package/lib/esm/components/ShowResponse/responseUtils.js.map +1 -1
  101. package/lib/esm/components/common/common.js +4 -13
  102. package/lib/esm/components/common/common.js.map +1 -1
  103. package/lib/esm/components/common/index.js +1 -18
  104. package/lib/esm/components/common/index.js.map +1 -1
  105. package/lib/esm/components/index.js +13 -148
  106. package/lib/esm/components/index.js.map +1 -1
  107. package/lib/esm/index.js +4 -49
  108. package/lib/esm/index.js.map +1 -1
  109. package/lib/esm/test-data/index.js +2 -67
  110. package/lib/esm/test-data/index.js.map +1 -1
  111. package/lib/esm/test-data/responses.js +9 -24
  112. package/lib/esm/test-data/responses.js.map +1 -1
  113. package/lib/esm/test-data/specs.js +3 -10
  114. package/lib/esm/test-data/specs.js.map +1 -1
  115. package/lib/esm/utils/RunItSDK.js +12 -20
  116. package/lib/esm/utils/RunItSDK.js.map +1 -1
  117. package/lib/esm/utils/index.js +2 -27
  118. package/lib/esm/utils/index.js.map +1 -1
  119. package/lib/esm/utils/requestUtils.js +26 -41
  120. package/lib/esm/utils/requestUtils.js.map +1 -1
  121. package/lib/test-data/responses.js.map +1 -1
  122. package/lib/test-data/specs.js +1 -1
  123. package/lib/test-data/specs.js.map +1 -1
  124. package/lib/utils/RunItSDK.js.map +1 -1
  125. package/lib/utils/requestUtils.js.map +1 -1
  126. package/package.json +4 -4
@@ -1,22 +1,15 @@
1
- "use strict";
2
-
3
- Object.defineProperty(exports, "__esModule", {
4
- value: true
5
- });
6
- exports.RequestForm = void 0;
7
- var _react = _interopRequireDefault(require("react"));
8
- var _components = require("@looker/components");
9
- var _LoginForm = require("../LoginForm");
10
- var _formUtils = require("./formUtils");
11
- var _FormItem = require("./FormItem");
12
- var _common = require("./../common");
13
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
14
1
  function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
15
2
  function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
16
3
  function _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
17
4
  function _toPropertyKey(arg) { var key = _toPrimitive(arg, "string"); return typeof key === "symbol" ? key : String(key); }
18
5
  function _toPrimitive(input, hint) { if (typeof input !== "object" || input === null) return input; var prim = input[Symbol.toPrimitive]; if (prim !== undefined) { var res = prim.call(input, hint || "default"); if (typeof res !== "object") return res; throw new TypeError("@@toPrimitive must return a primitive value."); } return (hint === "string" ? String : Number)(input); }
19
- var RequestForm = _ref => {
6
+ import React from 'react';
7
+ import { Button, Form, ButtonTransparent, Tooltip, Fieldset, MessageBar, ToggleSwitch, Label } from '@looker/components';
8
+ import { LoginForm } from '../LoginForm';
9
+ import { createSimpleItem, createComplexItem, showDataChangeWarning, updateNullableProp, BODY_HINT } from './formUtils';
10
+ import { FormItem } from './FormItem';
11
+ import { DarkSpan } from './../common';
12
+ export var RequestForm = _ref => {
20
13
  var {
21
14
  inputs,
22
15
  httpMethod,
@@ -41,15 +34,15 @@ var RequestForm = _ref => {
41
34
  };
42
35
  var handleNumberChange = e => {
43
36
  var value = e.target.value ? parseFloat(e.target.value) : undefined;
44
- var newState = (0, _formUtils.updateNullableProp)(requestContent, e.target.name, value);
37
+ var newState = updateNullableProp(requestContent, e.target.name, value);
45
38
  setRequestContent(newState);
46
39
  };
47
40
  var handleDateChange = (name, date) => {
48
- var newState = (0, _formUtils.updateNullableProp)(requestContent, name, date);
41
+ var newState = updateNullableProp(requestContent, name, date);
49
42
  setRequestContent(newState);
50
43
  };
51
44
  var handleChange = e => {
52
- var newState = (0, _formUtils.updateNullableProp)(requestContent, e.target.name, e.target.value);
45
+ var newState = updateNullableProp(requestContent, e.target.name, e.target.value);
53
46
  setRequestContent(newState);
54
47
  };
55
48
  var handleComplexChange = (name, value) => {
@@ -63,45 +56,44 @@ var RequestForm = _ref => {
63
56
  setRequestContent({});
64
57
  safeSetMessage('');
65
58
  };
66
- return _react.default.createElement(_components.Form, {
59
+ return React.createElement(Form, {
67
60
  onSubmit: handleSubmit
68
- }, validationMessage && _react.default.createElement(_components.MessageBar, {
61
+ }, validationMessage && React.createElement(MessageBar, {
69
62
  intent: 'critical',
70
63
  onPrimaryClick: () => safeSetMessage(''),
71
64
  visible: validationMessage !== ''
72
- }, 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)(), hasBody && !!toggleKeepBody && _react.default.createElement(_react.default.Fragment, null, _react.default.createElement(_FormItem.FormItem, {
65
+ }, validationMessage), React.createElement(Fieldset, null, inputs.map(input => typeof input.type === 'string' ? createSimpleItem(input, handleChange, handleNumberChange, handleBoolChange, handleDateChange, requestContent) : createComplexItem(input, handleComplexChange, requestContent)), httpMethod !== 'GET' && showDataChangeWarning(), hasBody && !!toggleKeepBody && React.createElement(React.Fragment, null, React.createElement(FormItem, {
73
66
  key: "keepbody_fib",
74
67
  id: "keepBody",
75
68
  label: "Send body as-is"
76
- }, _react.default.createElement(_react.default.Fragment, null, _react.default.createElement(_components.ToggleSwitch, {
69
+ }, React.createElement(React.Fragment, null, React.createElement(ToggleSwitch, {
77
70
  key: "keepBody",
78
71
  id: "keepBody",
79
72
  name: "keepBody",
80
73
  onChange: toggleKeepBody,
81
74
  on: keepBody
82
- }), _react.default.createElement(_components.Label, null, "Send the body parameter as entered"))), _react.default.createElement(_FormItem.FormItem, {
75
+ }), React.createElement(Label, null, "Send the body parameter as entered"))), React.createElement(FormItem, {
83
76
  key: "body_hint",
84
77
  id: "bodyHint"
85
- }, _react.default.createElement(_common.DarkSpan, {
78
+ }, React.createElement(DarkSpan, {
86
79
  fontSize: "small"
87
- }, _formUtils.BODY_HINT))), _react.default.createElement(_FormItem.FormItem, {
80
+ }, BODY_HINT))), React.createElement(FormItem, {
88
81
  id: "buttonbar"
89
- }, _react.default.createElement(_react.default.Fragment, null, hasConfig ? needsAuth ? _react.default.createElement(_LoginForm.LoginForm, {
82
+ }, React.createElement(React.Fragment, null, hasConfig ? needsAuth ? React.createElement(LoginForm, {
90
83
  requestContent: requestContent
91
- }) : _react.default.createElement(_components.Tooltip, {
84
+ }) : React.createElement(Tooltip, {
92
85
  content: "Run the API request"
93
- }, _react.default.createElement(_components.Button, {
86
+ }, React.createElement(Button, {
94
87
  type: "submit"
95
- }, "Run")) : !isExtension && setHasConfig && _react.default.createElement(_components.Tooltip, {
88
+ }, "Run")) : !isExtension && setHasConfig && React.createElement(Tooltip, {
96
89
  content: "Configure your OAuth server to Run requests"
97
- }, _react.default.createElement(_components.Button, {
90
+ }, React.createElement(Button, {
98
91
  onClick: handleConfig
99
- }, "Configure")), _react.default.createElement(_components.Tooltip, {
92
+ }, "Configure")), React.createElement(Tooltip, {
100
93
  content: "Clear entered values"
101
- }, _react.default.createElement(_components.ButtonTransparent, {
94
+ }, React.createElement(ButtonTransparent, {
102
95
  type: "button",
103
96
  onClick: handleClear
104
97
  }, "Clear"))))));
105
98
  };
106
- exports.RequestForm = RequestForm;
107
99
  //# sourceMappingURL=RequestForm.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"RequestForm.js","names":["_react","_interopRequireDefault","require","_components","_LoginForm","_formUtils","_FormItem","_common","obj","__esModule","default","ownKeys","object","enumerableOnly","keys","Object","getOwnPropertySymbols","symbols","filter","sym","getOwnPropertyDescriptor","enumerable","push","apply","_objectSpread","target","i","arguments","length","source","forEach","key","_defineProperty","getOwnPropertyDescriptors","defineProperties","defineProperty","value","_toPropertyKey","configurable","writable","arg","_toPrimitive","String","input","hint","prim","Symbol","toPrimitive","undefined","res","call","TypeError","Number","RequestForm","_ref","inputs","httpMethod","handleSubmit","requestContent","setRequestContent","needsAuth","hasConfig","handleConfig","setHasConfig","validationMessage","setValidationMessage","keepBody","toggleKeepBody","isExtension","hasBody","some","location","handleBoolChange","e","name","checked","handleNumberChange","parseFloat","newState","updateNullableProp","handleDateChange","date","handleChange","handleComplexChange","safeSetMessage","handleClear","preventDefault","createElement","Form","onSubmit","MessageBar","intent","onPrimaryClick","visible","Fieldset","map","type","createSimpleItem","createComplexItem","showDataChangeWarning","Fragment","FormItem","id","label","ToggleSwitch","onChange","on","Label","DarkSpan","fontSize","BODY_HINT","LoginForm","Tooltip","content","Button","onClick","ButtonTransparent","exports"],"sources":["../../../../src/components/RequestForm/RequestForm.tsx"],"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, FormEventHandler } from 'react'\nimport React from 'react'\nimport {\n Button,\n Form,\n ButtonTransparent,\n Tooltip,\n Fieldset,\n MessageBar,\n ToggleSwitch,\n Label,\n} from '@looker/components'\nimport type { RunItHttpMethod, RunItInput, RunItValues } from '../../RunIt'\nimport { LoginForm } from '../LoginForm'\nimport {\n createSimpleItem,\n createComplexItem,\n showDataChangeWarning,\n updateNullableProp,\n BODY_HINT,\n} from './formUtils'\nimport { FormItem } from './FormItem'\nimport { DarkSpan } from './../common'\n\n/** Properties required by RequestForm */\ninterface RequestFormProps {\n /** Request inputs to the endpoint */\n inputs: RunItInput[]\n /** A callback for submitting the form */\n handleSubmit: (e: BaseSyntheticEvent) => void\n /** HTTP method used for this REST request */\n httpMethod: RunItHttpMethod\n /** A collection type react state to store path, query and body parameters as entered by the user */\n requestContent: RunItValues\n /** A set state callback fn for populating requestContent on interaction with the request form */\n setRequestContent: Dispatch<RunItValues>\n /** Is authentication required? */\n needsAuth: boolean\n /** Does RunIt have the configuration values it needs? */\n hasConfig: boolean\n /** Handle config button click */\n handleConfig: (e: BaseSyntheticEvent) => void\n /** A set state callback which, if present, allows for editing, setting or clearing OAuth configuration parameters */\n setHasConfig?: Dispatch<boolean>\n /** Validation message to display */\n validationMessage?: string\n /** Validation message setter */\n setValidationMessage?: Dispatch<string>\n /** Toggle for processing body inputs */\n keepBody?: boolean\n /** Toggle to keep all body inputs */\n toggleKeepBody?: (_event: FormEventHandler<HTMLInputElement>) => void\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 keepBody,\n toggleKeepBody,\n isExtension = false,\n}) => {\n const hasBody = inputs.some((i) => i.location === 'body')\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 {hasBody && !!toggleKeepBody && (\n <>\n <FormItem key=\"keepbody_fib\" id=\"keepBody\" label=\"Send body as-is\">\n <>\n <ToggleSwitch\n key=\"keepBody\"\n id=\"keepBody\"\n name=\"keepBody\"\n onChange={toggleKeepBody as unknown as FormEventHandler}\n on={keepBody}\n />\n <Label>Send the body parameter as entered</Label>\n </>\n </FormItem>\n <FormItem key=\"body_hint\" id=\"bodyHint\">\n <DarkSpan fontSize=\"small\">{BODY_HINT}</DarkSpan>\n </FormItem>\n </>\n )}\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"],"mappings":"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"}
1
+ {"version":3,"file":"RequestForm.js","names":["React","Button","Form","ButtonTransparent","Tooltip","Fieldset","MessageBar","ToggleSwitch","Label","LoginForm","createSimpleItem","createComplexItem","showDataChangeWarning","updateNullableProp","BODY_HINT","FormItem","DarkSpan","RequestForm","_ref","inputs","httpMethod","handleSubmit","requestContent","setRequestContent","needsAuth","hasConfig","handleConfig","setHasConfig","validationMessage","setValidationMessage","keepBody","toggleKeepBody","isExtension","hasBody","some","i","location","handleBoolChange","e","_objectSpread","target","name","checked","handleNumberChange","value","parseFloat","undefined","newState","handleDateChange","date","handleChange","handleComplexChange","safeSetMessage","handleClear","preventDefault","createElement","onSubmit","intent","onPrimaryClick","visible","map","input","type","Fragment","key","id","label","onChange","on","fontSize","content","onClick"],"sources":["../../../../src/components/RequestForm/RequestForm.tsx"],"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, FormEventHandler } from 'react'\nimport React from 'react'\nimport {\n Button,\n Form,\n ButtonTransparent,\n Tooltip,\n Fieldset,\n MessageBar,\n ToggleSwitch,\n Label,\n} from '@looker/components'\nimport type { RunItHttpMethod, RunItInput, RunItValues } from '../../RunIt'\nimport { LoginForm } from '../LoginForm'\nimport {\n createSimpleItem,\n createComplexItem,\n showDataChangeWarning,\n updateNullableProp,\n BODY_HINT,\n} from './formUtils'\nimport { FormItem } from './FormItem'\nimport { DarkSpan } from './../common'\n\n/** Properties required by RequestForm */\ninterface RequestFormProps {\n /** Request inputs to the endpoint */\n inputs: RunItInput[]\n /** A callback for submitting the form */\n handleSubmit: (e: BaseSyntheticEvent) => void\n /** HTTP method used for this REST request */\n httpMethod: RunItHttpMethod\n /** A collection type react state to store path, query and body parameters as entered by the user */\n requestContent: RunItValues\n /** A set state callback fn for populating requestContent on interaction with the request form */\n setRequestContent: Dispatch<RunItValues>\n /** Is authentication required? */\n needsAuth: boolean\n /** Does RunIt have the configuration values it needs? */\n hasConfig: boolean\n /** Handle config button click */\n handleConfig: (e: BaseSyntheticEvent) => void\n /** A set state callback which, if present, allows for editing, setting or clearing OAuth configuration parameters */\n setHasConfig?: Dispatch<boolean>\n /** Validation message to display */\n validationMessage?: string\n /** Validation message setter */\n setValidationMessage?: Dispatch<string>\n /** Toggle for processing body inputs */\n keepBody?: boolean\n /** Toggle to keep all body inputs */\n toggleKeepBody?: (_event: FormEventHandler<HTMLInputElement>) => void\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 keepBody,\n toggleKeepBody,\n isExtension = false,\n}) => {\n const hasBody = inputs.some((i) => i.location === 'body')\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 {hasBody && !!toggleKeepBody && (\n <>\n <FormItem key=\"keepbody_fib\" id=\"keepBody\" label=\"Send body as-is\">\n <>\n <ToggleSwitch\n key=\"keepBody\"\n id=\"keepBody\"\n name=\"keepBody\"\n onChange={toggleKeepBody as unknown as FormEventHandler}\n on={keepBody}\n />\n <Label>Send the body parameter as entered</Label>\n </>\n </FormItem>\n <FormItem key=\"body_hint\" id=\"bodyHint\">\n <DarkSpan fontSize=\"small\">{BODY_HINT}</DarkSpan>\n </FormItem>\n </>\n )}\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"],"mappings":"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"}
@@ -1,44 +1,35 @@
1
- "use strict";
2
-
3
- Object.defineProperty(exports, "__esModule", {
4
- value: true
5
- });
6
- exports.validateEncodedValues = exports.validateBody = exports.updateNullableProp = exports.showDataChangeWarning = exports.createSimpleItem = exports.createComplexItem = exports.BODY_HINT = void 0;
7
- var _react = _interopRequireWildcard(require("react"));
8
- var _components = require("@looker/components");
9
- var _material = require("@styled-icons/material");
10
- var _codeEditor = require("@looker/code-editor");
11
- var _FormItem = require("./FormItem");
12
- 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); }
13
- 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; }
14
1
  function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
15
2
  function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
16
3
  function _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
17
4
  function _toPropertyKey(arg) { var key = _toPrimitive(arg, "string"); return typeof key === "symbol" ? key : String(key); }
18
5
  function _toPrimitive(input, hint) { if (typeof input !== "object" || input === null) return input; var prim = input[Symbol.toPrimitive]; if (prim !== undefined) { var res = prim.call(input, hint || "default"); if (typeof res !== "object") return res; throw new TypeError("@@toPrimitive must return a primitive value."); } return (hint === "string" ? String : Number)(input); }
19
- var BODY_HINT = 'By default, empty values are automatically removed from the request inputs, except for properties with `false` boolean values, which must be completely removed from the JSON body if they should not be passed.';
20
- exports.BODY_HINT = BODY_HINT;
21
- var createDateItem = (name, handleChange, requestContent) => _react.default.createElement(_FormItem.FormItem, {
6
+ import React, { Fragment } from 'react';
7
+ import { ToggleSwitch, Label, FieldCheckbox, InputText, Tooltip, Icon, InputDate, Space } from '@looker/components';
8
+ import { Info } from '@styled-icons/material';
9
+ import { CodeEditor } from '@looker/code-editor';
10
+ import { FormItem } from './FormItem';
11
+ export var BODY_HINT = 'By default, empty values are automatically removed from the request inputs, except for properties with `false` boolean values, which must be completely removed from the JSON body if they should not be passed.';
12
+ var createDateItem = (name, handleChange, requestContent) => React.createElement(FormItem, {
22
13
  key: "".concat(name, "_fid"),
23
14
  id: name,
24
15
  label: name
25
- }, _react.default.createElement(_components.InputDate, {
16
+ }, React.createElement(InputDate, {
26
17
  key: "datepick_".concat(name),
27
18
  "data-testid": "datepick_".concat(name),
28
19
  defaultValue: name in requestContent ? requestContent[name] : undefined,
29
20
  onChange: handleChange.bind(null, name)
30
21
  }));
31
- var createBoolItem = (name, description, handleChange, requestContent) => _react.default.createElement(_FormItem.FormItem, {
22
+ var createBoolItem = (name, description, handleChange, requestContent) => React.createElement(FormItem, {
32
23
  key: "".concat(name, "_fib"),
33
24
  id: name,
34
25
  label: name
35
- }, _react.default.createElement(_react.default.Fragment, null, _react.default.createElement(_components.ToggleSwitch, {
26
+ }, React.createElement(React.Fragment, null, React.createElement(ToggleSwitch, {
36
27
  key: name,
37
28
  id: name,
38
29
  name: name,
39
30
  onChange: handleChange,
40
31
  on: name in requestContent ? requestContent[name] : false
41
- }), description && _react.default.createElement(_components.Label, null, description)));
32
+ }), description && React.createElement(Label, null, description)));
42
33
  var inputTextType = type => {
43
34
  switch (type) {
44
35
  case 'number':
@@ -51,11 +42,11 @@ var inputTextType = type => {
51
42
  return 'text';
52
43
  }
53
44
  };
54
- var createItem = (name, description, required, type, placeholder, handleChange, requestContent) => _react.default.createElement(_FormItem.FormItem, {
45
+ var createItem = (name, description, required, type, placeholder, handleChange, requestContent) => React.createElement(FormItem, {
55
46
  key: "".concat(name, "_fi"),
56
47
  id: name,
57
48
  label: name
58
- }, _react.default.createElement(_components.InputText, {
49
+ }, React.createElement(InputText, {
59
50
  key: name,
60
51
  id: name,
61
52
  name: name,
@@ -65,7 +56,7 @@ var createItem = (name, description, required, type, placeholder, handleChange,
65
56
  value: name in requestContent ? requestContent[name] : '',
66
57
  onChange: handleChange
67
58
  }));
68
- var createSimpleItem = (input, handleChange, handleNumberChange, handleBoolChange, handleDateChange, requestContent) => {
59
+ export var createSimpleItem = (input, handleChange, handleNumberChange, handleBoolChange, handleDateChange, requestContent) => {
69
60
  switch (input.type) {
70
61
  case 'boolean':
71
62
  return createBoolItem(input.name, input.description, handleBoolChange, requestContent);
@@ -87,27 +78,26 @@ var createSimpleItem = (input, handleChange, handleNumberChange, handleBoolChang
87
78
  case 'datetime':
88
79
  return createDateItem(input.name, handleDateChange, requestContent);
89
80
  default:
90
- return _react.default.createElement(_react.Fragment, {
81
+ return React.createElement(Fragment, {
91
82
  key: input.name
92
83
  });
93
84
  }
94
85
  };
95
- exports.createSimpleItem = createSimpleItem;
96
- var createComplexItem = (input, handleComplexChange, requestContent) => {
86
+ export var createComplexItem = (input, handleComplexChange, requestContent) => {
97
87
  var content = requestContent[input.name];
98
88
  var code = typeof content === 'string' ? content : JSON.stringify(content, null, 2);
99
- return _react.default.createElement(_FormItem.FormItem, {
89
+ return React.createElement(FormItem, {
100
90
  key: "".concat(input.name, "_fic"),
101
91
  id: input.name,
102
- label: _react.default.createElement(_components.Space, null, input.name, _react.default.createElement(_components.Tooltip, {
92
+ label: React.createElement(Space, null, input.name, React.createElement(Tooltip, {
103
93
  content: BODY_HINT
104
- }, _react.default.createElement(_components.Icon, {
94
+ }, React.createElement(Icon, {
105
95
  "data-testid": "body-param-tooltip",
106
- icon: _react.default.createElement(_material.Info, null),
96
+ icon: React.createElement(Info, null),
107
97
  size: "xsmall",
108
98
  ml: "xsmall"
109
99
  })))
110
- }, _react.default.createElement(_codeEditor.CodeEditor, {
100
+ }, React.createElement(CodeEditor, {
111
101
  key: "code_".concat(input.name),
112
102
  language: "json",
113
103
  code: code,
@@ -116,18 +106,16 @@ var createComplexItem = (input, handleComplexChange, requestContent) => {
116
106
  transparent: true
117
107
  }));
118
108
  };
119
- exports.createComplexItem = createComplexItem;
120
- var showDataChangeWarning = () => _react.default.createElement(_FormItem.FormItem, {
109
+ export var showDataChangeWarning = () => React.createElement(FormItem, {
121
110
  key: "warningfi",
122
111
  id: "change_warning"
123
- }, _react.default.createElement(_components.FieldCheckbox, {
112
+ }, React.createElement(FieldCheckbox, {
124
113
  name: "warning",
125
114
  key: "warning",
126
115
  required: true,
127
116
  label: "I understand that this API endpoint will change data."
128
117
  }));
129
- exports.showDataChangeWarning = showDataChangeWarning;
130
- var updateNullableProp = (state, key, newValue) => {
118
+ export var updateNullableProp = (state, key, newValue) => {
131
119
  var updatedState = _objectSpread({}, state);
132
120
  if (key in state && !newValue) {
133
121
  delete updatedState[key];
@@ -136,8 +124,7 @@ var updateNullableProp = (state, key, newValue) => {
136
124
  }
137
125
  return updatedState;
138
126
  };
139
- exports.updateNullableProp = updateNullableProp;
140
- var validateEncodedValues = body => {
127
+ export var validateEncodedValues = body => {
141
128
  var result = '';
142
129
  if (!body) return result;
143
130
  var args = body.split('&');
@@ -149,8 +136,7 @@ var validateEncodedValues = body => {
149
136
  });
150
137
  return result.trim();
151
138
  };
152
- exports.validateEncodedValues = validateEncodedValues;
153
- var validateBody = (body, requiredKeys) => {
139
+ export var validateBody = (body, requiredKeys) => {
154
140
  var parsed;
155
141
  var result = '';
156
142
  if (body) {
@@ -181,5 +167,4 @@ var validateBody = (body, requiredKeys) => {
181
167
  }
182
168
  return result;
183
169
  };
184
- exports.validateBody = validateBody;
185
170
  //# sourceMappingURL=formUtils.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"formUtils.js","names":["_react","_interopRequireWildcard","require","_components","_material","_codeEditor","_FormItem","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","ownKeys","object","enumerableOnly","keys","getOwnPropertySymbols","symbols","filter","sym","enumerable","push","apply","_objectSpread","target","i","arguments","length","source","forEach","_defineProperty","getOwnPropertyDescriptors","defineProperties","value","_toPropertyKey","configurable","writable","arg","_toPrimitive","String","input","hint","prim","Symbol","toPrimitive","undefined","res","TypeError","Number","BODY_HINT","exports","createDateItem","name","handleChange","requestContent","createElement","FormItem","concat","id","label","InputDate","defaultValue","onChange","bind","createBoolItem","description","Fragment","ToggleSwitch","on","Label","inputTextType","type","createItem","required","placeholder","InputText","createSimpleItem","handleNumberChange","handleBoolChange","handleDateChange","createComplexItem","handleComplexChange","content","code","JSON","stringify","Space","Tooltip","Icon","icon","Info","size","ml","CodeEditor","language","lineNumbers","transparent","showDataChangeWarning","FieldCheckbox","updateNullableProp","state","newValue","updatedState","validateEncodedValues","body","result","args","split","formArg","test","trim","validateBody","requiredKeys","parsed","parse","e","message","Set","missing","k","Array","from","join"],"sources":["../../../../src/components/RequestForm/formUtils.tsx"],"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 InputText,\n Tooltip,\n Icon,\n InputDate,\n Space,\n} from '@looker/components'\n// eslint-disable-next-line no-restricted-imports\nimport { Info } from '@styled-icons/material'\nimport { CodeEditor } from '@looker/code-editor'\nimport type { RunItInput, RunItValues } from '../../RunIt'\nimport { FormItem } from './FormItem'\n\nexport const BODY_HINT =\n 'By default, empty values are automatically removed from the request inputs, except for properties with `false` boolean values, which must be completely removed from the JSON body if they should not be passed.'\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 <InputDate\n key={`datepick_${name}`}\n data-testid={`datepick_${name}`}\n defaultValue={name in requestContent ? requestContent[name] : undefined}\n onChange={handleChange.bind(null, name)}\n />\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={BODY_HINT}>\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"],"mappings":"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"}
1
+ {"version":3,"file":"formUtils.js","names":["React","Fragment","ToggleSwitch","Label","FieldCheckbox","InputText","Tooltip","Icon","InputDate","Space","Info","CodeEditor","FormItem","BODY_HINT","createDateItem","name","handleChange","requestContent","createElement","key","concat","id","label","defaultValue","undefined","onChange","bind","createBoolItem","description","on","inputTextType","type","createItem","required","placeholder","value","createSimpleItem","input","handleNumberChange","handleBoolChange","handleDateChange","createComplexItem","handleComplexChange","content","code","JSON","stringify","icon","size","ml","language","lineNumbers","transparent","showDataChangeWarning","updateNullableProp","state","newValue","updatedState","_objectSpread","validateEncodedValues","body","result","args","split","forEach","arg","formArg","test","trim","validateBody","requiredKeys","parsed","parse","e","message","length","Set","keys","Object","missing","filter","k","has","Array","from","join"],"sources":["../../../../src/components/RequestForm/formUtils.tsx"],"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 InputText,\n Tooltip,\n Icon,\n InputDate,\n Space,\n} from '@looker/components'\n// eslint-disable-next-line no-restricted-imports\nimport { Info } from '@styled-icons/material'\nimport { CodeEditor } from '@looker/code-editor'\nimport type { RunItInput, RunItValues } from '../../RunIt'\nimport { FormItem } from './FormItem'\n\nexport const BODY_HINT =\n 'By default, empty values are automatically removed from the request inputs, except for properties with `false` boolean values, which must be completely removed from the JSON body if they should not be passed.'\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 <InputDate\n key={`datepick_${name}`}\n data-testid={`datepick_${name}`}\n defaultValue={name in requestContent ? requestContent[name] : undefined}\n onChange={handleChange.bind(null, name)}\n />\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={BODY_HINT}>\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"],"mappings":"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"}
@@ -1,20 +1,3 @@
1
- "use strict";
2
-
3
- Object.defineProperty(exports, "__esModule", {
4
- value: true
5
- });
6
- Object.defineProperty(exports, "RequestForm", {
7
- enumerable: true,
8
- get: function get() {
9
- return _RequestForm.RequestForm;
10
- }
11
- });
12
- Object.defineProperty(exports, "validateBody", {
13
- enumerable: true,
14
- get: function get() {
15
- return _formUtils.validateBody;
16
- }
17
- });
18
- var _RequestForm = require("./RequestForm");
19
- var _formUtils = require("./formUtils");
1
+ export { RequestForm } from './RequestForm';
2
+ export { validateBody } from './formUtils';
20
3
  //# sourceMappingURL=index.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","names":["_RequestForm","require","_formUtils"],"sources":["../../../../src/components/RequestForm/index.ts"],"sourcesContent":["/*\n\n MIT License\n\n Copyright (c) 2021 Looker Data Sciences, Inc.\n\n Permission is hereby granted, free of charge, to any person obtaining a copy\n of this software and associated documentation files (the \"Software\"), to deal\n in the Software without restriction, including without limitation the rights\n to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n copies of the Software, and to permit persons to whom the Software is\n furnished to do so, subject to the following conditions:\n\n The above copyright notice and this permission notice shall be included in all\n copies or substantial portions of the Software.\n\n THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE\n SOFTWARE.\n\n */\n\nexport { RequestForm } from './RequestForm'\nexport { validateBody } from './formUtils'\n"],"mappings":";;;;;;;;;;;;;;;;;AA0BA,IAAAA,YAAA,GAAAC,OAAA;AACA,IAAAC,UAAA,GAAAD,OAAA"}
1
+ {"version":3,"file":"index.js","names":["RequestForm","validateBody"],"sources":["../../../../src/components/RequestForm/index.ts"],"sourcesContent":["/*\n\n MIT License\n\n Copyright (c) 2021 Looker Data Sciences, Inc.\n\n Permission is hereby granted, free of charge, to any person obtaining a copy\n of this software and associated documentation files (the \"Software\"), to deal\n in the Software without restriction, including without limitation the rights\n to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n copies of the Software, and to permit persons to whom the Software is\n furnished to do so, subject to the following conditions:\n\n The above copyright notice and this permission notice shall be included in all\n copies or substantial portions of the Software.\n\n THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE\n SOFTWARE.\n\n */\n\nexport { RequestForm } from './RequestForm'\nexport { validateBody } from './formUtils'\n"],"mappings":"AA0BA,SAASA,WAAW,QAAQ,eAAe;AAC3C,SAASC,YAAY,QAAQ,aAAa"}
@@ -1,20 +1,11 @@
1
- "use strict";
2
-
3
- Object.defineProperty(exports, "__esModule", {
4
- value: true
5
- });
6
- exports.ResponseHeaders = exports.ResponseExplorer = void 0;
7
- var _react = _interopRequireWildcard(require("react"));
8
- var _components = require("@looker/components");
9
- var _styledComponents = _interopRequireDefault(require("styled-components"));
10
- var _Warning = require("@styled-icons/material/Warning");
11
- var _extensionUtils = require("@looker/extension-utils");
12
- var _ShowResponse = require("../ShowResponse");
13
- var _Collapser = require("../Collapser");
14
- var _common = require("../common");
15
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
16
- 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); }
17
- 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; }
1
+ import React, { useState } from 'react';
2
+ import { Table, TableBody, TableRow, TableDataCell, Span, TableHead, TableHeaderCell, IconButton } from '@looker/components';
3
+ import styled from 'styled-components';
4
+ import { Warning } from '@styled-icons/material/Warning';
5
+ import { APIErrorDialog, APIErrorDisplay } from '@looker/extension-utils';
6
+ import { ShowResponse } from '../ShowResponse';
7
+ import { CollapserCard } from '../Collapser';
8
+ import { DarkSpan, RunItHeading } from '../common';
18
9
  var getHeaders = response => {
19
10
  if (!(response !== null && response !== void 0 && response.headers)) return [];
20
11
  var result = [];
@@ -28,78 +19,76 @@ var getBodySize = response => {
28
19
  var size = !response || !response.body ? 0 : (response === null || response === void 0 ? void 0 : response.body) instanceof Blob ? response === null || response === void 0 ? void 0 : response.body.size : response === null || response === void 0 ? void 0 : response.body.toString().length;
29
20
  return "".concat(size, " bytes");
30
21
  };
31
- var NoWrap = (0, _styledComponents.default)(_components.Span).withConfig({
22
+ var NoWrap = styled(Span).withConfig({
32
23
  displayName: "ResponseExplorer__NoWrap",
33
24
  componentId: "sc-bpger-0"
34
25
  })(["display:inline-block;direction:rtl;white-space:nowrap;overflow:hidden;"]);
35
- var ResponseHeaders = _ref2 => {
26
+ export var ResponseHeaders = _ref2 => {
36
27
  var {
37
28
  response
38
29
  } = _ref2;
39
30
  var rows = getHeaders(response);
40
- if (rows.length === 0) return _react.default.createElement(_react.default.Fragment, null);
41
- return _react.default.createElement(_Collapser.CollapserCard, {
31
+ if (rows.length === 0) return React.createElement(React.Fragment, null);
32
+ return React.createElement(CollapserCard, {
42
33
  key: "headers",
43
34
  heading: "Headers (".concat(rows.length, ")"),
44
35
  id: "headers",
45
36
  defaultOpen: false,
46
37
  divider: false
47
- }, _react.default.createElement(_react.default.Fragment, null, _react.default.createElement(_components.Table, null, _react.default.createElement(_components.TableHead, null, _react.default.createElement(_components.TableRow, null, _react.default.createElement(_components.TableHeaderCell, {
38
+ }, React.createElement(React.Fragment, null, React.createElement(Table, null, React.createElement(TableHead, null, React.createElement(TableRow, null, React.createElement(TableHeaderCell, {
48
39
  p: "xsmall"
49
- }, "Name"), _react.default.createElement(_components.TableHeaderCell, {
40
+ }, "Name"), React.createElement(TableHeaderCell, {
50
41
  p: "xsmall"
51
- }, "Value"))), _react.default.createElement(_components.TableBody, null, rows.map(_ref3 => {
42
+ }, "Value"))), React.createElement(TableBody, null, rows.map(_ref3 => {
52
43
  var [key, value] = _ref3;
53
- return _react.default.createElement(_components.TableRow, {
44
+ return React.createElement(TableRow, {
54
45
  key: key
55
- }, _react.default.createElement(_components.TableDataCell, {
46
+ }, React.createElement(TableDataCell, {
56
47
  p: "xsmall"
57
- }, _react.default.createElement(NoWrap, null, _react.default.createElement("strong", null, key))), _react.default.createElement(_components.TableDataCell, {
48
+ }, React.createElement(NoWrap, null, React.createElement("strong", null, key))), React.createElement(TableDataCell, {
58
49
  p: "xsmall"
59
- }, _react.default.createElement(_components.Span, null, value)));
50
+ }, React.createElement(Span, null, value)));
60
51
  })))));
61
52
  };
62
- exports.ResponseHeaders = ResponseHeaders;
63
- var ResponseExplorer = _ref4 => {
53
+ export var ResponseExplorer = _ref4 => {
64
54
  var {
65
55
  response,
66
56
  verb,
67
57
  path
68
58
  } = _ref4;
69
- var [isOpen, setIsOpen] = (0, _react.useState)(false);
59
+ var [isOpen, setIsOpen] = useState(false);
70
60
  var error = response && response.statusCode >= 400 && response.contentType === 'application/json' ? JSON.parse(response.body) : undefined;
71
61
  var timed = response => {
72
62
  if (!(response.responseCompleted || response.requestStarted)) return '';
73
63
  var diff = (response.responseCompleted - response.requestStarted) / 1000;
74
64
  return "Seconds: ".concat(diff.toFixed(3));
75
65
  };
76
- return _react.default.createElement(_react.default.Fragment, null, !response && _react.default.createElement(_common.DarkSpan, null, "No response was received"), response && _react.default.createElement(_react.default.Fragment, null, _react.default.createElement(_common.RunItHeading, {
66
+ return React.createElement(React.Fragment, null, !response && React.createElement(DarkSpan, null, "No response was received"), response && React.createElement(React.Fragment, null, React.createElement(RunItHeading, {
77
67
  as: "h4"
78
- }, error && _react.default.createElement(_react.default.Fragment, null, _react.default.createElement(_extensionUtils.APIErrorDialog, {
68
+ }, error && React.createElement(React.Fragment, null, React.createElement(APIErrorDialog, {
79
69
  error: error,
80
70
  isOpen: isOpen,
81
71
  setOpen: setIsOpen
82
- }), _react.default.createElement(_components.IconButton, {
72
+ }), React.createElement(IconButton, {
83
73
  size: "small",
84
74
  onClick: () => setIsOpen(true),
85
- icon: _react.default.createElement(_Warning.Warning, null),
75
+ icon: React.createElement(Warning, null),
86
76
  "aria-label": "API error",
87
77
  label: "API Error"
88
- })), "".concat(verb || '', " ").concat(path || '', " (").concat(response.statusCode, ": ").concat(response.statusMessage, ") ").concat(timed(response))), _react.default.createElement(_Collapser.CollapserCard, {
78
+ })), "".concat(verb || '', " ").concat(path || '', " (").concat(response.statusCode, ": ").concat(response.statusMessage, ") ").concat(timed(response))), React.createElement(CollapserCard, {
89
79
  divider: false,
90
80
  heading: "Body (".concat(getBodySize(response), ")"),
91
81
  id: "body"
92
- }, _react.default.createElement(_ShowResponse.ShowResponse, {
82
+ }, React.createElement(ShowResponse, {
93
83
  response: response
94
- })), error && _react.default.createElement(_Collapser.CollapserCard, {
84
+ })), error && React.createElement(CollapserCard, {
95
85
  divider: false,
96
86
  heading: 'Error information'
97
- }, _react.default.createElement(_extensionUtils.APIErrorDisplay, {
87
+ }, React.createElement(APIErrorDisplay, {
98
88
  error: error,
99
89
  showDoc: true
100
- })), _react.default.createElement(ResponseHeaders, {
90
+ })), React.createElement(ResponseHeaders, {
101
91
  response: response
102
92
  })));
103
93
  };
104
- exports.ResponseExplorer = ResponseExplorer;
105
94
  //# sourceMappingURL=ResponseExplorer.js.map