@redocly/openapi-docs 3.0.0-alpha.57 → 3.0.0-alpha.57.patch.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/console.redocly-openapi-docs.min.js +158 -217
- package/dist/oauth2-redirect.js +1 -1
- package/dist/redocly-openapi-docs.min.js +5868 -4998
- package/lib/components/Callbacks/CallbackSummary.js +1 -1
- package/lib/components/Download/DownloadButtonWithLabel.js +6 -14
- package/lib/components/DropdownOrLabel/DropdownOrLabel.js +3 -3
- package/lib/components/Endpoint/Summary.js +1 -1
- package/lib/components/Endpoint/styled.js +4 -4
- package/lib/components/Fields/FieldDetails.js +1 -1
- package/lib/components/NextSectionButton/NextSectionButton.js +1 -1
- package/lib/components/Panel/CodeHeader.js +5 -2
- package/lib/components/Panel/CodePanel.js +1 -5
- package/lib/components/Parameters/ParametersGroup.js +1 -1
- package/lib/components/RedoclyOpenAPIDocs/styled.js +2 -2
- package/lib/components/Search/styled.js +3 -1
- package/lib/components/SecurityRequirement/RequirementElement.js +1 -1
- package/lib/components/SecurityRequirement/SecurityRequirement.js +1 -1
- package/lib/components/SideMenu/MenuItem.js +1 -1
- package/lib/components/SideMenu/MenuOperationItemContent.js +1 -1
- package/lib/components/SourceCodeWithFile/SourceCodeWithFile.js +1 -1
- package/lib/components/StickySidebar/StickyResponsiveSidebar.js +2 -2
- package/lib/components/Tabs/CollapsingTabs/CollapsingTabList.js +10 -2
- package/lib/components/Tabs/Tab.js +8 -12
- package/lib/components/common/CheckboxList.js +3 -3
- package/lib/components/common/Dropdown/Dropdown.js +3 -3
- package/lib/components/common/Dropdown/styled.js +11 -23
- package/lib/components/common/Dropdown/types.d.ts +0 -1
- package/lib/components/common/Fields/fields-layout.js +3 -3
- package/lib/components/common/Fields/fields.d.ts +1 -0
- package/lib/components/common/Fields/fields.js +11 -7
- package/lib/components/common/form.js +4 -4
- package/lib/components/common/headers.js +1 -1
- package/lib/components/common/panels.js +1 -1
- package/lib/components/icons/LinkIcon.js +1 -1
- package/lib/components/pluggable/styled.components.js +1 -0
- package/lib/components/rightPanel/ActionPanel.js +1 -1
- package/lib/components/rightPanel/CodemirrorInput/styled.js +14 -10
- package/lib/components/rightPanel/ConsoleTabs/styled.js +6 -16
- package/lib/components/rightPanel/OAuth2Flow/OAuth2Flow.js +1 -1
- package/lib/components/rightPanel/ParameterArray.js +1 -1
- package/lib/components/rightPanel/ResponsePanel.js +1 -1
- package/lib/components/rightPanel/TryItPanel.js +3 -3
- package/lib/components/rightPanel/styled.d.ts +0 -1
- package/lib/components/rightPanel/styled.js +6 -26
- package/lib/components/shared/HttpVerb.d.ts +2 -6
- package/lib/components/shared/HttpVerb.js +2 -3
- package/lib/components/shared/MimeLabel.js +4 -5
- package/lib/components/shared/NoSampleLabel.js +1 -1
- package/lib-esm/components/Callbacks/CallbackSummary.js +1 -1
- package/lib-esm/components/Download/DownloadButtonWithLabel.js +6 -14
- package/lib-esm/components/DropdownOrLabel/DropdownOrLabel.js +1 -1
- package/lib-esm/components/Endpoint/Summary.js +1 -1
- package/lib-esm/components/Endpoint/styled.js +4 -4
- package/lib-esm/components/Fields/FieldDetails.js +1 -1
- package/lib-esm/components/NextSectionButton/NextSectionButton.js +1 -1
- package/lib-esm/components/Panel/CodeHeader.js +5 -2
- package/lib-esm/components/Panel/CodePanel.js +1 -5
- package/lib-esm/components/Parameters/ParametersGroup.js +1 -1
- package/lib-esm/components/RedoclyOpenAPIDocs/styled.js +2 -2
- package/lib-esm/components/Search/styled.js +3 -1
- package/lib-esm/components/SecurityRequirement/RequirementElement.js +1 -1
- package/lib-esm/components/SecurityRequirement/SecurityRequirement.js +1 -1
- package/lib-esm/components/SideMenu/MenuItem.js +1 -1
- package/lib-esm/components/SideMenu/MenuOperationItemContent.js +2 -2
- package/lib-esm/components/SourceCodeWithFile/SourceCodeWithFile.js +1 -1
- package/lib-esm/components/StickySidebar/StickyResponsiveSidebar.js +3 -3
- package/lib-esm/components/Tabs/CollapsingTabs/CollapsingTabList.js +9 -1
- package/lib-esm/components/Tabs/Tab.js +7 -11
- package/lib-esm/components/common/CheckboxList.js +3 -3
- package/lib-esm/components/common/Dropdown/Dropdown.js +2 -2
- package/lib-esm/components/common/Dropdown/styled.js +10 -22
- package/lib-esm/components/common/Dropdown/types.d.ts +0 -1
- package/lib-esm/components/common/Fields/fields-layout.js +2 -2
- package/lib-esm/components/common/Fields/fields.d.ts +1 -0
- package/lib-esm/components/common/Fields/fields.js +8 -4
- package/lib-esm/components/common/form.js +4 -4
- package/lib-esm/components/common/headers.js +1 -1
- package/lib-esm/components/common/panels.js +1 -1
- package/lib-esm/components/icons/LinkIcon.js +1 -1
- package/lib-esm/components/pluggable/styled.components.js +1 -0
- package/lib-esm/components/rightPanel/ActionPanel.js +1 -1
- package/lib-esm/components/rightPanel/CodemirrorInput/styled.js +14 -10
- package/lib-esm/components/rightPanel/ConsoleTabs/styled.js +5 -15
- package/lib-esm/components/rightPanel/OAuth2Flow/OAuth2Flow.js +1 -1
- package/lib-esm/components/rightPanel/ParameterArray.js +1 -1
- package/lib-esm/components/rightPanel/ResponsePanel.js +2 -2
- package/lib-esm/components/rightPanel/TryItPanel.js +3 -3
- package/lib-esm/components/rightPanel/styled.d.ts +0 -1
- package/lib-esm/components/rightPanel/styled.js +2 -22
- package/lib-esm/components/shared/HttpVerb.d.ts +2 -6
- package/lib-esm/components/shared/HttpVerb.js +2 -3
- package/lib-esm/components/shared/MimeLabel.js +3 -4
- package/lib-esm/components/shared/NoSampleLabel.js +1 -1
- package/package.json +4 -4
|
@@ -10,7 +10,7 @@ import{LayoutVariant}from"@redocly/theme";import styled,{createGlobalStyle,css}f
|
|
|
10
10
|
font-size: var(--font-size-base);
|
|
11
11
|
line-height: var(--line-height-base);
|
|
12
12
|
font-weight: var(--font-weight-regular);
|
|
13
|
-
color: var(--text-
|
|
13
|
+
color: var(--text-base);
|
|
14
14
|
-webkit-font-text-smoothing: var(--text-smoothing);
|
|
15
15
|
|
|
16
16
|
* {
|
|
@@ -70,7 +70,7 @@ import{LayoutVariant}from"@redocly/theme";import styled,{createGlobalStyle,css}f
|
|
|
70
70
|
(
|
|
71
71
|
100% - min(100% - var(--sidebar-width) - var(--layout-controls-width), var(${a})) -
|
|
72
72
|
var(--sidebar-width) + var(--layout-controls-width)
|
|
73
|
-
) / 2
|
|
73
|
+
) / 2 - 4px /* -4px fix overlap for panels */
|
|
74
74
|
);
|
|
75
75
|
`;export const BackgroundStubFix=styled.div`
|
|
76
76
|
position: absolute;
|
|
@@ -2,7 +2,7 @@ import React from"react";import styled from"styled-components";export const Cros
|
|
|
2
2
|
cursor: pointer;
|
|
3
3
|
position: absolute;
|
|
4
4
|
right: 15px;
|
|
5
|
-
color: var(--text-
|
|
5
|
+
color: var(--text-secondary);
|
|
6
6
|
`;export const ButtonClear=styled.i.attrs((()=>({className:"button-clear"})))`
|
|
7
7
|
cursor: pointer;
|
|
8
8
|
position: absolute;
|
|
@@ -97,8 +97,10 @@ import React from"react";import styled from"styled-components";export const Cros
|
|
|
97
97
|
background-color: var(--search-modal-clear-button-background-color);
|
|
98
98
|
padding: 4px 16px;
|
|
99
99
|
border-radius: var(--border-radius);
|
|
100
|
+
border: var(--search-modal-clear-button-border);
|
|
100
101
|
&:hover {
|
|
101
102
|
background-color: var(--search-modal-clear-button-hover-background-color);
|
|
103
|
+
border: var(--search-modal-clear-button-hover-border);
|
|
102
104
|
}
|
|
103
105
|
}
|
|
104
106
|
`;export const TextContainer=styled.div`
|
|
@@ -12,7 +12,7 @@ import React from"react";import styled from"styled-components";import{linksCss}f
|
|
|
12
12
|
`,SecurityRequirementOrWrap=styled.span`
|
|
13
13
|
${linksCss};
|
|
14
14
|
`,ScopeName=styled.code`
|
|
15
|
-
border: 1px solid var(--border-
|
|
15
|
+
border: 1px solid var(--border-primary);
|
|
16
16
|
margin: 0 3px;
|
|
17
17
|
padding: 0.2em;
|
|
18
18
|
line-height: 1;
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import React,{Fragment,memo,useState}from"react";import styled from"styled-components";import{useRecoilValue}from"recoil";import{MarkdownWrapper}from"@redocly/theme";import{Markdown}from"../Markdown";import{OAuthFlow}from"../SecuritySchemes";import{PanelDescription}from"./PanelDescription";import{RequirementElement}from"./RequirementElement";import{RequiredScopesRow}from"./RequiredScopesRow";import{LockIcon}from"../icons";import{Row}from"./styled";import{AUTH_TYPES}from"./constants";import{l}from"../../services";import{titleize}from"../../utils";import{ContentPanel}from"../Panel";import{globalStoreSelector}from"../../recoil/store";import{useSecurityRequirements}from"./useSecurityRequirements";function getRequiredScopes(e,t){const r=[];let o=t.length;for(;o--;){const n=t[o];let c=n.schemes.length;for(;c--;){const t=n.schemes[c];t.id===e&&r.push(...t.scopes)}}return Array.from(new Set(r))}function SecurityRequirementsComponent({securities:e}){const[t,r]=useState(!1),{options:{showSecuritySchemeType:o,hideSecuritySection:n},parser:c}=useRecoilValue(globalStoreSelector),a=useSecurityRequirements({parser:c,securities:e});return!e.length||n?null:React.createElement(ContentPanel,{className:"panel-security-schemas",header:l("authorizations"),onToggle:e=>r(e),description:!t&&React.createElement(PanelDescription,{securities:e,showSecuritySchemeType:o}),expanded:t},t&&a&&a.length>1?React.createElement(SecurityRequirementBlock,null,e.map(((t,r)=>{let n,c,a="";return e.length>1&&t.schemes.length>1&&(c=0===r?"(":"",a=")"),r!==e.length-1&&(a+=" or",n=React.createElement("br",null)),React.createElement(Fragment,{key:t.schemes.map((({id:e})=>e)).join("")},c,React.createElement(RequirementElement,{security:t,showSecuritySchemeType:o}),a,n)}))):null,t?a.map((t=>{const r=getRequiredScopes(t.id,e);return React.createElement(SecurityDetails,{key:t.id},React.createElement("h5",null,React.createElement(LockIcon,{size:"11px",style:{verticalAlign:"baseline"},color:"--panel-body-text-color"})," ",AUTH_TYPES[t.type]||t.type,": ",t.id),React.createElement(Markdown,{source:t.description||""}),React.createElement(MarkdownWrapper,{key:t.id},t.apiKey?React.createElement(React.Fragment,null,React.createElement(Row,null,React.createElement("b",null,titleize(t.apiKey.in||"")," parameter name: "),React.createElement("code",null,t.apiKey.name)),React.createElement(RequiredScopesRow,{scopes:r})):t.http?React.createElement(React.Fragment,null,React.createElement(Row,null,React.createElement("b",null,"HTTP Authorization Scheme: "),React.createElement("code",null,t.http.scheme)),React.createElement(Row,null,"bearer"===t.http.scheme&&t.http.bearerFormat&&React.createElement(React.Fragment,null,React.createElement("b",null,"Bearer format: "),React.createElement("code",null,t.http.bearerFormat))),React.createElement(RequiredScopesRow,{scopes:r})):t.openId?React.createElement(React.Fragment,null,React.createElement(Row,null,React.createElement("b",null,"Connect URL: "),React.createElement("code",null,React.createElement("a",{target:"_blank",rel:"noopener noreferrer",href:t.openId.connectUrl},t.openId.connectUrl))),React.createElement(RequiredScopesRow,{scopes:r})):t.flows?Object.keys(t.flows).map((e=>React.createElement(OAuthFlow,{key:e,type:e,flow:t.flows[e]},React.createElement(RequiredScopesRow,{scopes:r})))):null))})):null)}export const SecurityRequirements=memo(SecurityRequirementsComponent);const SecurityDetails=styled.div`
|
|
2
|
-
border-bottom: 1px solid var(--border-
|
|
2
|
+
border-bottom: 1px solid var(--border-primary);
|
|
3
3
|
margin-bottom: 1.5em;
|
|
4
4
|
padding-bottom: 0.7em;
|
|
5
5
|
&:last-child {
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import React,{memo,useCallback}from"react";import{
|
|
1
|
+
import React,{memo,useCallback}from"react";import{Tag}from"@redocly/theme";import{Pagination}from"../../services";import{MenuItemLi,MenuItemTitle}from"./styled";import{MenuItems}from"./MenuItems";import{MenuItemLink}from"./MenuItemLink";import{MenuOperationItemContent}from"./MenuOperationItemContent";import{ShelfIcon}from"../icons";import{encodeBackSlashes}from"../../utils";import{useMenuItemExpanded}from"./hooks";function MenuItemComponent({item:e,children:t,onClick:n,pagination:m}){var o;const[i,a]=useMenuItemExpanded(e),r=getLink(e,m),c=useCallback((()=>{r&&e.hasActiveSubItem||a(!i)}),[r,e.hasActiveSubItem,a,i]),l=(null===(o=e.items)||void 0===o?void 0:o.length)>0;return React.createElement(MenuItemLi,{depth:e.depth,"data-item-id":e.id,onClick:n},"operation"===e.type?React.createElement(MenuOperationItemContent,{item:e,to:r,active:e.active},t):React.createElement(MenuItemLink,{to:r,depth:e.depth,type:e.type,hasChildren:l,active:e.active,onClick:c},e.depth>0&&l&&React.createElement(ShelfIcon,{direction:i?"down":"right"})||null,e.isSchema?React.createElement(Tag,{color:"schema"},"schema"):null,React.createElement(MenuItemTitle,{title:e.name},e.name,t)),l&&React.createElement(MenuItems,{expanded:i,items:e.items}))}export const MenuItem=memo(MenuItemComponent);export function getLink(e,t){return"tag"!==e.type||e.description||t!==Pagination.Item?encodeBackSlashes(e.href):""}
|
|
2
2
|
//# sourceMappingURL=MenuItem.js.map
|
|
@@ -1,8 +1,8 @@
|
|
|
1
|
-
import React,{memo}from"react";import{
|
|
1
|
+
import React,{memo}from"react";import{HttpTag}from"@redocly/theme";import styled from"styled-components";import{useRecoilValue}from"recoil";import{MenuItemPath,MenuItemTitle}from"./styled";import{MenuItemLink}from"./MenuItemLink";import{SideNavStyle,l}from"../../services";import{shortenHTTPVerb}from"../../utils";import{globalOptionsSelector}from"../../recoil/store";const MenuItemOperationLink=styled(MenuItemLink)`
|
|
2
2
|
flex-wrap: wrap;
|
|
3
3
|
`,MenuItemDescription=styled.small`
|
|
4
4
|
display: block;
|
|
5
5
|
font-size: 0.87em;
|
|
6
6
|
line-height: 1.2;
|
|
7
|
-
`;function MenuOperationItemContentComponent({item:e,to:t,children:o,active:n}){let r,i;const{sideNavStyle:m,showWebhookVerb:a}=useRecoilValue(globalOptionsSelector);return m!==SideNavStyle.PathFirst&&!e.search||"operation"!==e.type?(r=m===SideNavStyle.IdOnly?e.operationId||e.path:e.name,i=null):(r=React.createElement(MenuItemPath,{title:e.path}," ",e.path," "),i=React.createElement(MenuItemDescription,null," ",e.name," ")),React.createElement(MenuItemOperationLink,{depth:e.depth,deprecated:e.deprecated,to:t,active:n},e.isWebhook?React.createElement(
|
|
7
|
+
`;function MenuOperationItemContentComponent({item:e,to:t,children:o,active:n}){let r,i;const{sideNavStyle:m,showWebhookVerb:a}=useRecoilValue(globalOptionsSelector);return m!==SideNavStyle.PathFirst&&!e.search||"operation"!==e.type?(r=m===SideNavStyle.IdOnly?e.operationId||e.path:e.name,i=null):(r=React.createElement(MenuItemPath,{title:e.path}," ",e.path," "),i=React.createElement(MenuItemDescription,null," ",e.name," ")),React.createElement(MenuItemOperationLink,{depth:e.depth,deprecated:e.deprecated,to:t,active:n},e.isWebhook?React.createElement(HttpTag,{color:"hook"},a?e.httpVerb:l("webhook")):React.createElement(HttpTag,{color:e.httpVerb},shortenHTTPVerb(e.httpVerb)),React.createElement(MenuItemTitle,{width:"calc(100% - 42px)"},r,o),i)}export const MenuOperationItemContent=memo(MenuOperationItemContentComponent);
|
|
8
8
|
//# sourceMappingURL=MenuOperationItemContent.js.map
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import React from"react";import{CodeBlockContainer,CodeBlockControls}from"@redocly/theme";import styled from"styled-components";import{DownloadLink}from"../Download";import{FileIcon}from"../icons";export function SourceCodeWithFile({fileInfo:e}){return React.createElement(Wrapper,null,React.createElement(CodeBlockControls,null,React.createElement(DownloadLink,{fileInfo:e})),React.createElement(CodeBlockContainer,null,React.createElement(FileIcon,{color:"--text-
|
|
1
|
+
import React from"react";import{CodeBlockContainer,CodeBlockControls}from"@redocly/theme";import styled from"styled-components";import{DownloadLink}from"../Download";import{FileIcon}from"../icons";export function SourceCodeWithFile({fileInfo:e}){return React.createElement(Wrapper,null,React.createElement(CodeBlockControls,null,React.createElement(DownloadLink,{fileInfo:e})),React.createElement(CodeBlockContainer,null,React.createElement(FileIcon,{color:"--text-secondary"}),null==e?void 0:e.fileName))}const Wrapper=styled.div``;
|
|
2
2
|
//# sourceMappingURL=SourceCodeWithFile.js.map
|
|
@@ -24,8 +24,8 @@ import React,{memo,useEffect,useRef,useState}from"react";import styled,{css}from
|
|
|
24
24
|
}
|
|
25
25
|
`}
|
|
26
26
|
`,FloatingButton=styled(MobileSidebarButton)`
|
|
27
|
-
--fab-background-color: var(--
|
|
28
|
-
--fab-active-background: var(--
|
|
27
|
+
--fab-background-color: var(--bg-overlay);
|
|
28
|
+
--fab-active-background: var(--bg-raised);
|
|
29
29
|
|
|
30
30
|
${({theme:e})=>css`
|
|
31
31
|
${e.mediaQueries[e.showAtBreakpoint.sidebar]} {
|
|
@@ -35,5 +35,5 @@ import React,{memo,useEffect,useRef,useState}from"react";import styled,{css}from
|
|
|
35
35
|
display: none;
|
|
36
36
|
}
|
|
37
37
|
`}
|
|
38
|
-
`;function StickyResponsiveSidebarComponent({scrollYOffset:e,hideFab:t,className:i,children:o,collapsedSidebar:r}){const[a,l]=useState("0px"),s=useRef(null),
|
|
38
|
+
`;function StickyResponsiveSidebarComponent({scrollYOffset:e,hideFab:t,className:i,children:o,collapsedSidebar:r}){const[a,l]=useState("0px"),s=useRef(null),n=useLocation(),[c,d]=useRecoilState(isSidebarOpenedSelector);useEffect((()=>{n.hash&&d(!1)}),[n.pathname,n.hash,d]),useMount((()=>{stickyfill&&stickyfill.add(s.current);const t=e();l(`${t}px`)})),useUnmount((()=>{stickyfill&&stickyfill.remove(s.current)}));return React.createElement(React.Fragment,null,React.createElement(StyledStickySidebar,{open:c,className:i,offsetTop:a,style:{top:a},ref:s,collapsedSidebar:r},r||c?o:null,React.createElement(Actions,null)),!t&&React.createElement(FloatingButton,{opened:c,onClick:()=>{d(!c)}},React.createElement(MobileSidebarIcon,null)))}export const StickyResponsiveSidebar=memo(StickyResponsiveSidebarComponent);
|
|
39
39
|
//# sourceMappingURL=StickyResponsiveSidebar.js.map
|
|
@@ -1,4 +1,12 @@
|
|
|
1
1
|
import styled from"styled-components";import{TabList}from"../TabList";export const CollapsingTabList=styled(TabList)`
|
|
2
|
-
|
|
2
|
+
background-color: var(--bg-overlay);
|
|
3
|
+
border-radius: var(--border-radius-lg);
|
|
4
|
+
padding: 2px;
|
|
5
|
+
margin: 0 0 15px;
|
|
6
|
+
|
|
7
|
+
li[class^='Tab'] {
|
|
8
|
+
margin: 0;
|
|
9
|
+
list-style: none;
|
|
10
|
+
}
|
|
3
11
|
`;
|
|
4
12
|
//# sourceMappingURL=CollapsingTabList.js.map
|
|
@@ -1,32 +1,28 @@
|
|
|
1
1
|
import{Tab as ReactTab}from"react-tabs";import styled from"styled-components";export const Tab=styled(ReactTab)`
|
|
2
2
|
flex: 1;
|
|
3
|
+
display: flex;
|
|
4
|
+
align-items: center;
|
|
5
|
+
justify-content: center;
|
|
3
6
|
cursor: pointer;
|
|
4
|
-
padding:
|
|
7
|
+
padding: 0px 8px;
|
|
5
8
|
font-size: var(--panel-samples-tabs-font-size);
|
|
6
9
|
line-height: 26px;
|
|
7
10
|
font-weight: var(--panel-samples-tabs-font-weight);
|
|
8
11
|
text-align: center;
|
|
9
12
|
color: var(--panel-samples-tabs-text-color);
|
|
10
13
|
background-color: var(--panel-samples-tabs-background-color);
|
|
11
|
-
border-
|
|
12
|
-
margin-bottom: -4px;
|
|
14
|
+
border-radius: var(--border-radius-lg);
|
|
13
15
|
|
|
14
16
|
&:hover {
|
|
15
17
|
border-color: var(--panel-samples-tabs-hover-border-color);
|
|
16
18
|
background-color: var(--panel-samples-tabs-hover-background-color);
|
|
19
|
+
color: var(--panel-samples-tabs-hover-text-color);
|
|
17
20
|
}
|
|
18
21
|
|
|
19
22
|
&.react-tabs__tab--selected {
|
|
20
23
|
background-color: var(--panel-samples-tabs-active-background-color);
|
|
21
24
|
border-color: var(--panel-samples-tabs-active-border-color);
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
&:first-child {
|
|
25
|
-
border-top-left-radius: var(--border-radius);
|
|
26
|
-
}
|
|
27
|
-
|
|
28
|
-
&:last-child {
|
|
29
|
-
border-top-right-radius: var(--border-radius);
|
|
25
|
+
color: var(--panel-samples-tabs-active-text-color);
|
|
30
26
|
}
|
|
31
27
|
`;
|
|
32
28
|
//# sourceMappingURL=Tab.js.map
|
|
@@ -1,7 +1,7 @@
|
|
|
1
|
-
import{asField}from"informed";import{CodeBlockControls,CodeBlockControlButton}from"@redocly/theme";import React,{useState}from"react";import styled from"styled-components";import{FormError}from"./form";import{Checkbox}from"./Checkbox";const DEFAULT_MAX_ITEMS=11;export const CheckboxListComponent=({items:e,fieldApi:t,validateOnChange:o,maxDisplayedItems:l,showControls:r,trimItemsLength:c})=>{const[a,
|
|
1
|
+
import{asField}from"informed";import{CodeBlockControls,CodeBlockControlButton}from"@redocly/theme";import React,{useState}from"react";import styled from"styled-components";import{FormError}from"./form";import{Checkbox}from"./Checkbox";const DEFAULT_MAX_ITEMS=11;export const CheckboxListComponent=({items:e,fieldApi:t,validateOnChange:o,maxDisplayedItems:l,showControls:r,trimItemsLength:c})=>{const[a,s]=useState(!0),n=e=>t.getValue().includes(e),i=t.getError(),d=l||11,m=c&&a?e.slice(0,d):e;return React.createElement("div",null,r?React.createElement(CodeBlockControls,{controls:{select:{onClick:()=>{t.setValue(e)},label:"Select all",tooltipText:"Select all checkboxes"},deselect:{onClick:()=>{t.setValue([])},label:"Deselect all",tooltipText:"Deselect all checkboxes"}}}):null,React.createElement(ListWrapper,null,m.map((e=>React.createElement(Checkbox,{fullWidth:!0,id:e,value:e,checked:n(e),label:e,key:e,onChange:e=>{(e=>{const o=e.target.value,l=e.target.checked;t.setTouched(!0);const r=t.getValue()||[];let c;if(l)c=[...r,o];else{const e=r.indexOf(o);c=[...r.slice(0,e),...r.slice(e+1)]}t.setValue(c)})(e),o&&t.validate()}}))),e.length>d&&c?React.createElement(ToggleButton,{onClick:()=>{s((e=>!e))}},a?"Show all":"Collapse"):null),i?React.createElement(FormError,null,i):"")};export const CheckboxList=asField(CheckboxListComponent);const ListWrapper=styled.div`
|
|
2
2
|
padding: 10px;
|
|
3
|
-
|
|
4
|
-
border-radius: 0 0 var(--border-radius) var(--border-radius);
|
|
3
|
+
border: 1px solid var(--border-primary);
|
|
4
|
+
border-radius: 0 0 var(--border-radius-lg) var(--border-radius-lg);
|
|
5
5
|
`,ToggleButton=styled(CodeBlockControlButton)`
|
|
6
6
|
float: right;
|
|
7
7
|
`;
|
|
@@ -10,7 +10,7 @@ import React,{memo,useMemo}from"react";import styled from"styled-components";imp
|
|
|
10
10
|
margin: auto;
|
|
11
11
|
text-align: center;
|
|
12
12
|
polyline {
|
|
13
|
-
color:
|
|
13
|
+
color: inherit;
|
|
14
14
|
}
|
|
15
|
-
`,DropdownComponent=({options:e,onChange:t,handleClear:o,clearable:n,placeholder:
|
|
15
|
+
`,DropdownComponent=({options:e,onChange:t,handleClear:o,clearable:n,placeholder:r,value:a="",className:l})=>{var s;const c=useMemo((()=>e.map((({idx:e,value:t,title:o},n)=>{const r=normalizeText(t);return React.createElement("option",{key:e||r+n,value:r,className:"dropdown-option"},o||r)}))),[e]),i=normalizeText(a),m=(null===(s=e.find((e=>e.value===a)))||void 0===s?void 0:s.title)||i;return React.createElement("div",{className:l+" dropdown-wrapper"},React.createElement(ArrowIcon,null),n&&(null==i?void 0:i.length)>0&&React.createElement(ClearButton,{handleClear:o}),React.createElement("select",{onChange:o=>{const{selectedIndex:n}=o.target;t(e[r||!a?n-1:n])},value:i,className:"dropdown-select"},r&&React.createElement("option",{disabled:!0,hidden:!0,value:r},r),!i&&!r&&React.createElement("option",{disabled:!0}),c),React.createElement("label",null,m))};export const Dropdown=memo(DropdownComponent);
|
|
16
16
|
//# sourceMappingURL=Dropdown.js.map
|
|
@@ -6,14 +6,12 @@ import styled,{css}from"styled-components";import{Dropdown as DropdownComponent}
|
|
|
6
6
|
&,
|
|
7
7
|
&:hover,
|
|
8
8
|
&:focus-within {
|
|
9
|
-
border: none;
|
|
10
9
|
box-shadow: none;
|
|
11
10
|
}
|
|
12
11
|
`;export const Dropdown=styled(DropdownComponent)`
|
|
13
12
|
box-sizing: border-box;
|
|
14
13
|
outline: none;
|
|
15
14
|
display: inline-block;
|
|
16
|
-
border-radius: var(--border-radius);
|
|
17
15
|
vertical-align: bottom;
|
|
18
16
|
position: relative;
|
|
19
17
|
width: ${({fullWidth:o})=>o?"100%":"auto"};
|
|
@@ -27,8 +25,7 @@ import styled,{css}from"styled-components";import{Dropdown as DropdownComponent}
|
|
|
27
25
|
outline: none;
|
|
28
26
|
display: inline-block;
|
|
29
27
|
color: var(--docs-dropdown-text-color);
|
|
30
|
-
border-radius: var(--border-radius);
|
|
31
|
-
border: var(--docs-dropdown-border);
|
|
28
|
+
border-radius: var(--border-radius-md);
|
|
32
29
|
padding: var(--docs-dropdown-padding);
|
|
33
30
|
vertical-align: bottom;
|
|
34
31
|
width: ${({fullWidth:o})=>o?"100%":"auto"};
|
|
@@ -43,7 +40,6 @@ import styled,{css}from"styled-components";import{Dropdown as DropdownComponent}
|
|
|
43
40
|
&,
|
|
44
41
|
&:hover,
|
|
45
42
|
&:focus-within {
|
|
46
|
-
border: 1px solid var(--border-color);
|
|
47
43
|
box-shadow: none;
|
|
48
44
|
}
|
|
49
45
|
|
|
@@ -61,9 +57,9 @@ import styled,{css}from"styled-components";import{Dropdown as DropdownComponent}
|
|
|
61
57
|
appearance: none;
|
|
62
58
|
cursor: pointer;
|
|
63
59
|
|
|
64
|
-
color: var(--text-
|
|
60
|
+
color: var(--text-secondary);
|
|
65
61
|
line-height: inherit;
|
|
66
|
-
font-size:
|
|
62
|
+
font-size: var(--font-size-base);
|
|
67
63
|
font-family: inherit;
|
|
68
64
|
padding: var(--docs-dropdown-padding);
|
|
69
65
|
${({variant:o})=>"dark"===o?darkDropdownStyle:""};
|
|
@@ -75,16 +71,14 @@ import styled,{css}from"styled-components";import{Dropdown as DropdownComponent}
|
|
|
75
71
|
}
|
|
76
72
|
label {
|
|
77
73
|
padding: 0 26px 0 4px;
|
|
78
|
-
border: none;
|
|
79
74
|
background: transparent;
|
|
80
|
-
font-size:
|
|
81
|
-
font-weight:
|
|
75
|
+
font-size: var(--font-size-base);
|
|
76
|
+
font-weight: var(--font-weight-regular);
|
|
82
77
|
appearance: none;
|
|
83
78
|
height: auto;
|
|
84
79
|
|
|
85
80
|
&:hover,
|
|
86
81
|
&:focus-within {
|
|
87
|
-
border: none;
|
|
88
82
|
box-shadow: none;
|
|
89
83
|
}
|
|
90
84
|
}
|
|
@@ -96,22 +90,16 @@ import styled,{css}from"styled-components";import{Dropdown as DropdownComponent}
|
|
|
96
90
|
label {
|
|
97
91
|
${darkDropdownStyle};
|
|
98
92
|
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
margin: 0 0 -4px;
|
|
93
|
+
border-radius: var(--border-radius-lg);
|
|
94
|
+
margin-left: 5px;
|
|
102
95
|
transition: none;
|
|
103
96
|
min-width: auto;
|
|
104
|
-
background: ${({active:o})=>o?"var(--panel-samples-tabs-active-background-color)":"
|
|
97
|
+
background-color: ${({active:o})=>o?"var(--panel-samples-tabs-active-background-color)":"var(--bg-base)"};
|
|
105
98
|
& {
|
|
106
|
-
border-bottom: 4px solid
|
|
107
|
-
${({active:o})=>o?"var(--panel-samples-tabs-active-border-color)":"transparent"};
|
|
108
|
-
|
|
109
99
|
&[open],
|
|
110
100
|
&:focus-within,
|
|
111
101
|
&:hover {
|
|
112
|
-
background: var(--
|
|
113
|
-
border-bottom: 4px solid
|
|
114
|
-
${({active:o})=>o?"var( --panel-samples-tabs-active-border-color)":"transparent"};
|
|
102
|
+
background-color: var(--bg-raised);
|
|
115
103
|
}
|
|
116
104
|
}
|
|
117
105
|
}
|
|
@@ -120,7 +108,7 @@ import styled,{css}from"styled-components";import{Dropdown as DropdownComponent}
|
|
|
120
108
|
label {
|
|
121
109
|
width: 100%;
|
|
122
110
|
font-weight: 600;
|
|
123
|
-
color: var(--text-
|
|
111
|
+
color: var(--text-secondary);
|
|
124
112
|
}
|
|
125
113
|
`;export const SchemaDiscriminatorDropdown=styled(Dropdown)`
|
|
126
114
|
.dropdown-select {
|
|
@@ -2,7 +2,7 @@ import styled,{css}from"styled-components";import{typography}from"../../../utils
|
|
|
2
2
|
text-align: right;
|
|
3
3
|
font-size: 0.9em;
|
|
4
4
|
font-weight: normal;
|
|
5
|
-
color: var(--text-
|
|
5
|
+
color: var(--text-secondary);
|
|
6
6
|
`;const repeatingGradient=css`
|
|
7
7
|
repeating-linear-gradient(0deg,
|
|
8
8
|
var(--schemas-lines-color),
|
|
@@ -122,7 +122,7 @@ import styled,{css}from"styled-components";import{typography}from"../../../utils
|
|
|
122
122
|
min-width: 200px;
|
|
123
123
|
|
|
124
124
|
${({theme:e})=>e.mediaQueries.small} {
|
|
125
|
-
border-bottom: 1px solid var(--border-
|
|
125
|
+
border-bottom: 1px solid var(--border-primary);
|
|
126
126
|
border-left: none;
|
|
127
127
|
padding: 10px 0;
|
|
128
128
|
}
|
|
@@ -12,6 +12,7 @@ export declare const AdditionalPropertiesLabel: import("styled-components").Styl
|
|
|
12
12
|
export declare const AccessLabel: import("styled-components").StyledComponent<"div", any, {}, never>;
|
|
13
13
|
export declare const FieldValueLabel: import("styled-components").StyledComponent<"span", any, {}, never>;
|
|
14
14
|
export declare const RecursiveLabel: import("styled-components").StyledComponent<"span", any, {}, never>;
|
|
15
|
+
export declare const DeprecatedLabel: import("styled-components").StyledComponent<"span", any, {}, never>;
|
|
15
16
|
export declare const EnumValue: import("styled-components").StyledComponent<"span", any, {}, never>;
|
|
16
17
|
export declare const DefaultValue: import("styled-components").StyledComponent<"span", any, {}, never>;
|
|
17
18
|
export declare const ExampleValue: import("styled-components").StyledComponent<"span", any, {}, never>;
|
|
@@ -5,7 +5,7 @@ import styled,{css}from"styled-components";import{typography}from"../../../utils
|
|
|
5
5
|
outline: 0;
|
|
6
6
|
cursor: pointer;
|
|
7
7
|
padding: 0 10px 0 0;
|
|
8
|
-
color: var(--text-
|
|
8
|
+
color: var(--text-primary);
|
|
9
9
|
&:focus {
|
|
10
10
|
font-weight: var(--font-weight-bold);
|
|
11
11
|
}
|
|
@@ -40,7 +40,7 @@ import styled,{css}from"styled-components";import{typography}from"../../../utils
|
|
|
40
40
|
color: var(--schema-type-title-text-color);
|
|
41
41
|
word-break: break-word;
|
|
42
42
|
`;export const TypeFormat=TypeName;export const PropertyLabel=styled(FieldLabel.withComponent("div"))`
|
|
43
|
-
color: var(--text-
|
|
43
|
+
color: var(--text-secondary);
|
|
44
44
|
font-size: var(--schema-labels-font-size);
|
|
45
45
|
font-weight: normal;
|
|
46
46
|
line-height: 1;
|
|
@@ -62,6 +62,10 @@ import styled,{css}from"styled-components";import{typography}from"../../../utils
|
|
|
62
62
|
background-color: var(--schema-recursive-background-color);
|
|
63
63
|
border-color: var(--schema-recursive-border-color);
|
|
64
64
|
color: var(--schema-recursive-text-color);
|
|
65
|
+
`;export const DeprecatedLabel=styled(FieldValueLabel)`
|
|
66
|
+
color: var(--badge-deprecated-text-color);
|
|
67
|
+
background-color: var(--badge-deprecated-background-color);
|
|
68
|
+
border-color: var(--badge-deprecated-border-color);
|
|
65
69
|
`;export const EnumValue=styled(FieldValueLabel)`
|
|
66
70
|
background-color: var(--schema-enum-background-color);
|
|
67
71
|
border-color: var(--schema-enum-border-color);
|
|
@@ -97,11 +101,11 @@ import styled,{css}from"styled-components";import{typography}from"../../../utils
|
|
|
97
101
|
`;export const PatternLabel=styled(ConstraintItem)``;export const ToggleButton=styled.button`
|
|
98
102
|
background-color: transparent;
|
|
99
103
|
border: 0;
|
|
100
|
-
color: var(--text-
|
|
104
|
+
color: var(--text-secondary);
|
|
101
105
|
margin-left: var(--spacing-unit);
|
|
102
106
|
border-radius: var(--border-radius);
|
|
103
107
|
cursor: pointer;
|
|
104
|
-
outline-color: var(--text-
|
|
108
|
+
outline-color: var(--text-secondary);
|
|
105
109
|
font-size: 12px;
|
|
106
110
|
`;
|
|
107
111
|
//# sourceMappingURL=fields.js.map
|
|
@@ -30,18 +30,18 @@ import styled,{css}from"styled-components";export const Table=styled.div`
|
|
|
30
30
|
display: inline-block;
|
|
31
31
|
content: '*';
|
|
32
32
|
margin-left: 4px;
|
|
33
|
-
color: var(--color-error
|
|
33
|
+
color: var(--color-error);
|
|
34
34
|
}
|
|
35
35
|
`}
|
|
36
36
|
`;export const FormError=styled.div`
|
|
37
|
-
color: var(--color-error
|
|
37
|
+
color: var(--color-error);
|
|
38
38
|
font-size: 0.9em;
|
|
39
39
|
& pre {
|
|
40
40
|
word-break: break-word;
|
|
41
41
|
white-space: pre-wrap;
|
|
42
42
|
}
|
|
43
43
|
`;export const FormWarning=styled.div`
|
|
44
|
-
color: var(--color-warning
|
|
44
|
+
color: var(--color-warning);
|
|
45
45
|
font-size: 0.9em;
|
|
46
46
|
`;function placeholder(o,e){let t="";for(let r=0;r<o;r++)t+=e;return'"'+t+'"'}export const TokenField=styled.div`
|
|
47
47
|
position: relative;
|
|
@@ -55,7 +55,7 @@ import styled,{css}from"styled-components";export const Table=styled.div`
|
|
|
55
55
|
padding: 0 5px;
|
|
56
56
|
cursor: pointer;
|
|
57
57
|
`;export const TokenClear=styled(TokenShowHide)`
|
|
58
|
-
color: var(--color-error
|
|
58
|
+
color: var(--color-error);
|
|
59
59
|
`;export const FormHeader=styled.div`
|
|
60
60
|
font-weight: bold;
|
|
61
61
|
font-size: 1.2em;
|
|
@@ -3,7 +3,7 @@ import styled from"styled-components";import{typography}from"../../utils";export
|
|
|
3
3
|
|
|
4
4
|
${typography("right-panel-header")};
|
|
5
5
|
`;export const FieldsGroupHeader=styled.h5`
|
|
6
|
-
color: var(--text-
|
|
6
|
+
color: var(--text-secondary);
|
|
7
7
|
font-weight: bold;
|
|
8
8
|
text-transform: uppercase;
|
|
9
9
|
font-size: 14px;
|
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
import styled from"styled-components";import{SamplesMiddlePanel}from"../common/panels";export const SamplesWrap=styled.div`
|
|
2
2
|
padding: calc(var(--spacing-unit) * 4);
|
|
3
3
|
border-radius: var(--panel-border-radius);
|
|
4
|
+
border: var(--panel-samples-border);
|
|
4
5
|
background-color: var(--panel-samples-background-color);
|
|
5
6
|
`;export const ExamplesWrap=styled(SamplesWrap)`
|
|
6
7
|
width: 100%;
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import React,{memo}from"react";import styled from"styled-components";import{serializeParameterValue}from"../../utils";import{CodeHeader}from"../Panel";import{Path,PathWrapper,TryItButton}from"../Endpoint";import{HttpVerb}from"../shared";import{expandVariables}from"./utils";function formatPath(e,t,r){const n=t.path||{},a=t.query||{},o=Object.keys(a);let i=expandVariables(e,n);return o.length&&(i+="?"+o.map((e=>{if(!a[e])return"";const t=(e=>r.find((t=>t.name===e&&"query"===t.in)))(e);return t?serializeParameterValue(t,a[e]):`${e}=${encodeURIComponent(a[e])}`})).filter(Boolean).join("&")),i}export const ActionPanelComponent=({loading:e,operation:t,hasResponse:r,execute:n,params:a={}})=>React.createElement(CodeHeader,null,React.createElement(PathWrapper,null,React.createElement(HttpVerb,{
|
|
1
|
+
import React,{memo}from"react";import styled from"styled-components";import{serializeParameterValue}from"../../utils";import{CodeHeader}from"../Panel";import{Path,PathWrapper,TryItButton}from"../Endpoint";import{HttpVerb}from"../shared";import{expandVariables}from"./utils";function formatPath(e,t,r){const n=t.path||{},a=t.query||{},o=Object.keys(a);let i=expandVariables(e,n);return o.length&&(i+="?"+o.map((e=>{if(!a[e])return"";const t=(e=>r.find((t=>t.name===e&&"query"===t.in)))(e);return t?serializeParameterValue(t,a[e]):`${e}=${encodeURIComponent(a[e])}`})).filter(Boolean).join("&")),i}export const ActionPanelComponent=({loading:e,operation:t,hasResponse:r,execute:n,params:a={}})=>React.createElement(CodeHeader,null,React.createElement(PathWrapper,null,React.createElement(HttpVerb,{color:t.httpVerb},t.httpVerb),React.createElement(Path,{wrap:"true"},formatPath(t.path,a,t.parameters))),React.createElement(SendButton,{"data-cy":"send-button",color:"primary",blinking:e,onClick:()=>!e&&n()},e?"Sending...":r?"Resend":"Send"));const SendButton=styled(TryItButton)`
|
|
2
2
|
width: var(--panel-try-it-action-button-width);
|
|
3
3
|
`;export const ActionPanel=memo(ActionPanelComponent);
|
|
4
4
|
//# sourceMappingURL=ActionPanel.js.map
|
|
@@ -1,10 +1,13 @@
|
|
|
1
1
|
import{createGlobalStyle}from"styled-components";export const CodeMirrorStyles=createGlobalStyle`
|
|
2
2
|
.cm-s-material.CodeMirror {
|
|
3
|
-
background-color: var(--
|
|
4
|
-
color: var(--text-color
|
|
5
|
-
font-family: var(--code-font-family);
|
|
6
|
-
|
|
7
|
-
|
|
3
|
+
background-color: var(--bg-overlay) !important;
|
|
4
|
+
color: var(--code-block-text-color) !important;
|
|
5
|
+
font-family: var(--code-block-font-family);
|
|
6
|
+
font-weight: var(--code-block-font-weight);
|
|
7
|
+
font-size: var(--code-block-font-size);
|
|
8
|
+
line-height: var(--code-block-line-height);
|
|
9
|
+
padding: var(--code-block-padding);
|
|
10
|
+
white-space: var(--code-wrap, pre);
|
|
8
11
|
}
|
|
9
12
|
|
|
10
13
|
.CodeMirror-lint-mark-error {
|
|
@@ -12,10 +15,6 @@ import{createGlobalStyle}from"styled-components";export const CodeMirrorStyles=c
|
|
|
12
15
|
background-image: url('data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAgAAAAGCAYAAAD+Bd/7AAAAVUlEQVR42mNgQAL/GRjigPg/EP8FYntkCX4gtoVKgvE/BoabcEVAhj6S5DUgfgFl/wFJ2gPxL6iuT1DF+kD2R5AYA5KRj6CS/FAMYvszIBltz4AFAAD9fz0YtLg13wAAAABJRU5ErkJggg==') !important;
|
|
13
16
|
}
|
|
14
17
|
|
|
15
|
-
.cm-s-material.CodeMirror-focused div.CodeMirror-selected {
|
|
16
|
-
background: rgba(255, 255, 255, 0.3) !important;
|
|
17
|
-
}
|
|
18
|
-
|
|
19
18
|
.cm-s-material .CodeMirror-code .cm-string.cm-property {
|
|
20
19
|
color: var(--code-block-tokens-property-string-color);
|
|
21
20
|
}
|
|
@@ -25,12 +24,17 @@ import{createGlobalStyle}from"styled-components";export const CodeMirrorStyles=c
|
|
|
25
24
|
}
|
|
26
25
|
|
|
27
26
|
.cm-s-material .CodeMirror-code .cm-atom {
|
|
28
|
-
color: var(--text-
|
|
27
|
+
color: var(--text-secondary);
|
|
29
28
|
}
|
|
30
29
|
|
|
31
30
|
div .cm-s-material .CodeMirror-matchingbracket {
|
|
32
31
|
outline: 1px solid grey;
|
|
33
32
|
text-decoration: none;
|
|
33
|
+
color: var(--color-gold-8) !important;
|
|
34
|
+
}
|
|
35
|
+
|
|
36
|
+
div .cm-s-material .CodeMirror-nonmatchingbracket {
|
|
37
|
+
color: var(--color-red-8) !important;
|
|
34
38
|
}
|
|
35
39
|
|
|
36
40
|
.react-codemirror2 {
|
|
@@ -13,34 +13,24 @@ import styled,{css}from"styled-components";export const TabsWrap=styled.div`
|
|
|
13
13
|
color: var(--panel-try-it-tabs-text-color);
|
|
14
14
|
min-width: 80px;
|
|
15
15
|
min-height: 30px;
|
|
16
|
-
border-radius: var(--border-radius);
|
|
16
|
+
border-radius: var(--border-radius-lg);
|
|
17
17
|
font-size: var(--panel-try-it-tabs-font-size);
|
|
18
18
|
font-family: var(--panel-try-it-tabs-font-family);
|
|
19
19
|
font-weight: var(--panel-try-it-tabs-font-weight);
|
|
20
20
|
padding: 0 10px;
|
|
21
|
-
border-bottom: 4px solid var(--panel-try-it-tabs-border-color);
|
|
22
|
-
|
|
23
|
-
&:first-child {
|
|
24
|
-
border-radius: var(--border-radius) 0 0 var(--border-radius);
|
|
25
|
-
}
|
|
26
|
-
|
|
27
|
-
&:last-child {
|
|
28
|
-
border-radius: 0 var(--border-radius) var(--border-radius) 0;
|
|
29
|
-
}
|
|
30
21
|
|
|
31
22
|
&:hover:not(:disabled) {
|
|
32
|
-
border-color: var(--panel-try-it-tabs-hover-border-color);
|
|
33
23
|
background-color: var(--panel-try-it-tabs-hover-background-color);
|
|
24
|
+
color: var(--panel-try-it-tabs-hover-text-color);
|
|
34
25
|
}
|
|
35
26
|
|
|
36
|
-
${({active:
|
|
37
|
-
border-color: var(--panel-try-it-tabs-active-border-color);
|
|
27
|
+
${({active:t})=>t&&css`
|
|
38
28
|
background-color: var(--panel-try-it-tabs-active-background-color);
|
|
29
|
+
color: var(--panel-try-it-tabs-active-text-color);
|
|
39
30
|
`||""}
|
|
40
31
|
|
|
41
|
-
${({disabled:
|
|
32
|
+
${({disabled:t})=>t&&css`
|
|
42
33
|
cursor: default;
|
|
43
|
-
border-color: var(--panel-try-it-tabs-disables-border-color)
|
|
44
34
|
background-color: var(--panel-try-it-tabs-disabled-background-color);
|
|
45
35
|
color: var(--panel-try-it-tabs-disabled-text-color);
|
|
46
36
|
`||""}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
var __awaiter=this&&this.__awaiter||function(e,t,o,l){return new(o||(o=Promise))((function(n,r){function a(e){try{c(l.next(e))}catch(e){r(e)}}function i(e){try{c(l.throw(e))}catch(e){r(e)}}function c(e){var t;e.done?n(e.value):(t=e.value,t instanceof o?t:new o((function(e){e(t)}))).then(a,i)}c((l=l.apply(e,t||[])).next())}))};import React,{useEffect,useState}from"react";import{Button}from"@redocly/theme";import{useRecoilValue}from"recoil";import{ButtonsWrapper,PkceOptionsWrapper,PkceDetails}from"./styled";import{LinearProgress}from"../../common/LinearProgress";import{FormControl,FormLabel,FormError,FormWrapper}from"../../common/form";import{FormDropdown,FormTextField,TextField}from"../../common/TextField";import{Checkbox}from"../../common/Checkbox";import{OAuth2,deriveCodeChallenge}from"../../../services/OAuth2";import{fromSessionStorage,getSecurityDetailsOptions}from"../../../utils";import{isEmptyObject,randString}from"../../../services/utils";import{getOAuth2TokenEndpointAuthHeader,normalizeUrlProtocol,validateTokenEndpointMethod}from"../utils";import Scope from"../Scope";import{Error}from"./Error";import{globalOptionsSelector}from"../../../recoil/store";function requiredValidator(e){if(!e)return"Field is required"}export const OAuth2Flow=({usePkce:e,form:t,id:o,formApi:l,flow:n,tokenUrl:r,authCorsProxyUrl:a,tokenEndpointAuthMethod:i,server:c,scopes:u,authorizationUrl:d,defaultValues:s,clientId:m})=>{var p,h,f,v;const{oAuth2RedirectURI:g,routingBasePath:E}=useRecoilValue(globalOptionsSelector),[k,C]=useState(null),[R,F]=useState(!1),[S,y]=useState(!1),[O,b]=useState(void 0),[_,A]=useState(void 0),[x,W]=useState(void 0),P=(null===(h=null===(p=t.values)||void 0===p?void 0:p.auth)||void 0===h?void 0:h[o])||{},T=(null===(v=null===(f=t.errors)||void 0===f?void 0:f.auth)||void 0===v?void 0:v[o])||{},V=void 0!==O&&_!==x?{label:"sync",onClick:()=>{O&&A(x)}}:void 0;useEffect((()=>{if(e){const e=randString(43);deriveCodeChallenge(e).then((t=>{b(e),A(t),W(t)}))}}),[e]);const w=()=>{l.setValue(`auth.${o}.token`,"")};if(!d)return React.createElement(FormError,null,"No flow info");let z=fromSessionStorage(`auth.${o}.token`)||JSON.stringify(null==s?void 0:s.token);z=z?JSON.parse(z):"";const B=getSecurityDetailsOptions(o,"client_id"),U={field:`auth.${o}.client_id`,fullWidth:!0,initialValue:fromSessionStorage(`auth.${o}.client_id`)||m||(null==s?void 0:s.client_id),initValue:fromSessionStorage(`auth.${o}.client_id`)||m||(null==s?void 0:s.client_id),placeholder:"Your OAuth2 app Client ID",validate:requiredValidator,validateOnBlur:!0,validateOnChange:!0};return React.createElement("div",null,React.createElement(FormWrapper,null,React.createElement(FormControl,null,React.createElement(FormLabel,null," Client ID: "),B?React.createElement(FormDropdown,Object.assign({},U,{options:B})):React.createElement(FormTextField,Object.assign({},U,{"data-cy":"client-id-input",panel:"try-it"}))),"authorizationCode"===n&&React.createElement(React.Fragment,null,(!(null==e?void 0:e.hideClientSecretInput)||!e)&&React.createElement(FormControl,null,React.createElement(FormLabel,null,"Client Secret:"),React.createElement(FormTextField,{type:"password",fullWidth:!0,field:`auth.${o}.client_secret`,initialValue:fromSessionStorage(`auth.${o}.client_secret`)||(null==s?void 0:s.client_secret),validateOnBlur:!0,validateOnChange:!0,panel:"try-it","data-cy":"client-secret-input"})),e&&!e.disableManualConfiguration&&React.createElement(PkceOptionsWrapper,null,React.createElement(Checkbox,{id:"pkce-opitons-toggle",label:"Configure PKCE manually",checked:S,onChange:()=>{y((e=>!e))},"data-cy":"pkce-options-toggle"}),S&&React.createElement(PkceDetails,null,React.createElement(FormControl,null,React.createElement(FormLabel,null,"Code Verifier"),React.createElement(TextField,{fullWidth:!0,value:O,onChange:({target:{value:e}})=>__awaiter(void 0,void 0,void 0,(function*(){const t=yield deriveCodeChallenge(e);b(e),W(t)})),panel:"try-it","data-cy":"code-verifier-input"})),React.createElement(FormControl,null,React.createElement(FormLabel,null,"Code Challenge"),React.createElement(TextField,{fullWidth:!0,value:_,onChange:({target:{value:e}})=>{A(e)},inputActionButton:V,panel:"try-it","data-cy":"code-challenge-input"}))))),React.createElement(FormTextField,{fullWidth:!0,field:`auth.${o}.token`,type:"hidden",initialValue:z,panel:"try-it"}),React.createElement(Scope,{id:o,scopes:u}),P.token&&P.token.access_token?React.createElement(FormControl,null,React.createElement(FormLabel,null," Access Token: "),React.createElement(TextField,{disabled:!0,type:"password",fullWidth:!0,value:P.token.access_token,panel:"try-it"})):null),React.createElement(ButtonsWrapper,null,P.token&&P.token.access_token?React.createElement(Button,{fullWidth:!0,onClick:()=>{w(),C(null)}},"Log out"):R?React.createElement(React.Fragment,null,React.createElement(Button,{fullWidth:!0,onClick:()=>{F(!1),C(null),OAuth2.clearRedirectData(n)}},"Cancel"),React.createElement(LinearProgress,null)):React.createElement(Button,{fullWidth:!0,
|
|
1
|
+
var __awaiter=this&&this.__awaiter||function(e,t,o,l){return new(o||(o=Promise))((function(n,r){function a(e){try{c(l.next(e))}catch(e){r(e)}}function i(e){try{c(l.throw(e))}catch(e){r(e)}}function c(e){var t;e.done?n(e.value):(t=e.value,t instanceof o?t:new o((function(e){e(t)}))).then(a,i)}c((l=l.apply(e,t||[])).next())}))};import React,{useEffect,useState}from"react";import{Button}from"@redocly/theme";import{useRecoilValue}from"recoil";import{ButtonsWrapper,PkceOptionsWrapper,PkceDetails}from"./styled";import{LinearProgress}from"../../common/LinearProgress";import{FormControl,FormLabel,FormError,FormWrapper}from"../../common/form";import{FormDropdown,FormTextField,TextField}from"../../common/TextField";import{Checkbox}from"../../common/Checkbox";import{OAuth2,deriveCodeChallenge}from"../../../services/OAuth2";import{fromSessionStorage,getSecurityDetailsOptions}from"../../../utils";import{isEmptyObject,randString}from"../../../services/utils";import{getOAuth2TokenEndpointAuthHeader,normalizeUrlProtocol,validateTokenEndpointMethod}from"../utils";import Scope from"../Scope";import{Error}from"./Error";import{globalOptionsSelector}from"../../../recoil/store";function requiredValidator(e){if(!e)return"Field is required"}export const OAuth2Flow=({usePkce:e,form:t,id:o,formApi:l,flow:n,tokenUrl:r,authCorsProxyUrl:a,tokenEndpointAuthMethod:i,server:c,scopes:u,authorizationUrl:d,defaultValues:s,clientId:m})=>{var p,h,f,v;const{oAuth2RedirectURI:g,routingBasePath:E}=useRecoilValue(globalOptionsSelector),[k,C]=useState(null),[R,F]=useState(!1),[S,y]=useState(!1),[O,b]=useState(void 0),[_,A]=useState(void 0),[x,W]=useState(void 0),P=(null===(h=null===(p=t.values)||void 0===p?void 0:p.auth)||void 0===h?void 0:h[o])||{},T=(null===(v=null===(f=t.errors)||void 0===f?void 0:f.auth)||void 0===v?void 0:v[o])||{},V=void 0!==O&&_!==x?{label:"sync",onClick:()=>{O&&A(x)}}:void 0;useEffect((()=>{if(e){const e=randString(43);deriveCodeChallenge(e).then((t=>{b(e),A(t),W(t)}))}}),[e]);const w=()=>{l.setValue(`auth.${o}.token`,"")};if(!d)return React.createElement(FormError,null,"No flow info");let z=fromSessionStorage(`auth.${o}.token`)||JSON.stringify(null==s?void 0:s.token);z=z?JSON.parse(z):"";const B=getSecurityDetailsOptions(o,"client_id"),U={field:`auth.${o}.client_id`,fullWidth:!0,initialValue:fromSessionStorage(`auth.${o}.client_id`)||m||(null==s?void 0:s.client_id),initValue:fromSessionStorage(`auth.${o}.client_id`)||m||(null==s?void 0:s.client_id),placeholder:"Your OAuth2 app Client ID",validate:requiredValidator,validateOnBlur:!0,validateOnChange:!0};return React.createElement("div",null,React.createElement(FormWrapper,null,React.createElement(FormControl,null,React.createElement(FormLabel,null," Client ID: "),B?React.createElement(FormDropdown,Object.assign({},U,{options:B})):React.createElement(FormTextField,Object.assign({},U,{"data-cy":"client-id-input",panel:"try-it"}))),"authorizationCode"===n&&React.createElement(React.Fragment,null,(!(null==e?void 0:e.hideClientSecretInput)||!e)&&React.createElement(FormControl,null,React.createElement(FormLabel,null,"Client Secret:"),React.createElement(FormTextField,{type:"password",fullWidth:!0,field:`auth.${o}.client_secret`,initialValue:fromSessionStorage(`auth.${o}.client_secret`)||(null==s?void 0:s.client_secret),validateOnBlur:!0,validateOnChange:!0,panel:"try-it","data-cy":"client-secret-input"})),e&&!e.disableManualConfiguration&&React.createElement(PkceOptionsWrapper,null,React.createElement(Checkbox,{id:"pkce-opitons-toggle",label:"Configure PKCE manually",checked:S,onChange:()=>{y((e=>!e))},"data-cy":"pkce-options-toggle"}),S&&React.createElement(PkceDetails,null,React.createElement(FormControl,null,React.createElement(FormLabel,null,"Code Verifier"),React.createElement(TextField,{fullWidth:!0,value:O,onChange:({target:{value:e}})=>__awaiter(void 0,void 0,void 0,(function*(){const t=yield deriveCodeChallenge(e);b(e),W(t)})),panel:"try-it","data-cy":"code-verifier-input"})),React.createElement(FormControl,null,React.createElement(FormLabel,null,"Code Challenge"),React.createElement(TextField,{fullWidth:!0,value:_,onChange:({target:{value:e}})=>{A(e)},inputActionButton:V,panel:"try-it","data-cy":"code-challenge-input"}))))),React.createElement(FormTextField,{fullWidth:!0,field:`auth.${o}.token`,type:"hidden",initialValue:z,panel:"try-it"}),React.createElement(Scope,{id:o,scopes:u}),P.token&&P.token.access_token?React.createElement(FormControl,null,React.createElement(FormLabel,null," Access Token: "),React.createElement(TextField,{disabled:!0,type:"password",fullWidth:!0,value:P.token.access_token,panel:"try-it"})):null),React.createElement(ButtonsWrapper,null,P.token&&P.token.access_token?React.createElement(Button,{fullWidth:!0,onClick:()=>{w(),C(null)}},"Log out"):R?React.createElement(React.Fragment,null,React.createElement(Button,{fullWidth:!0,onClick:()=>{F(!1),C(null),OAuth2.clearRedirectData(n)}},"Cancel"),React.createElement(LinearProgress,null)):React.createElement(Button,{fullWidth:!0,disabled:!isEmptyObject(T),onClick:()=>{(t=>{if(!t)return;if(l.validate(),!isEmptyObject(T))return;F(!0),C(null);const u=a?a+normalizeUrlProtocol(t):t,d=a&&r?a+normalizeUrlProtocol(r):r,s=l.getValue(`auth.${o}.scopes`),m={authorizationUrl:u.startsWith("http")?u:c+u,clientId:P.client_id,scopes:s,redirectUri:g,routingBasePath:E,successCallback:e=>{l.setValue(`auth.${o}.token`,e),F(!1),C(null)},errorCallback:e=>{F(!1),C((null==e?void 0:e.message)||"Failed to retrieve the access token")}};"implicit"===n&&OAuth2.authorizeImplicit(m),validateTokenEndpointMethod(i)?"authorizationCode"===n&&OAuth2.authorizeAuthorizationCode(Object.assign(Object.assign(Object.assign({},m),{tokenUrl:(null==d?void 0:d.startsWith("http"))?d:c+d,clientSecret:P.client_secret,extraHeaders:getOAuth2TokenEndpointAuthHeader({authMethod:i,clientId:P.client_id,clientSecret:P.client_secret})}),e&&{codeVerifier:O,codeChallenge:_})):console.log(`Unsupported token endpoint auth method: ${i}`)})(d)}},"Authorize")),R||k||!P.token||!P.token.access_token&&React.createElement(Error,{loading:R,error:k,token:P.token}))};
|
|
2
2
|
//# sourceMappingURL=OAuth2Flow.js.map
|
|
@@ -5,7 +5,7 @@ import React from"react";import styled from"styled-components";import{ResponseBo
|
|
|
5
5
|
margin-right: 20px;
|
|
6
6
|
padding: 2px 0;
|
|
7
7
|
text-align: center;
|
|
8
|
-
color: var(--text-
|
|
8
|
+
color: var(--text-primary);
|
|
9
9
|
`,ResponseBadge=styled(ResponseBadgeBase)`
|
|
10
10
|
color: ${({code:e})=>e>=200&&e<300?"var(--response-success-text-color)":e>=300&&e<400?"var(--response-redirect-text-color)":e>400?"var(--response-error-text-color)":"var(--response-info-text-color)"};
|
|
11
11
|
`,ErrorHeader=styled.header`
|
|
@@ -14,5 +14,5 @@ import React from"react";import styled from"styled-components";import{ResponseBo
|
|
|
14
14
|
`,ErrorDetails=styled.code`
|
|
15
15
|
border-left: 3px solid #ff4040;
|
|
16
16
|
padding-left: 5px;
|
|
17
|
-
`;export const ResponsePanel=({error:e,response:t,time:n})=>{const r=t||e&&e.response,
|
|
17
|
+
`;export const ResponsePanel=({error:e,response:t,time:n})=>{const r=t||e&&e.response,a=r&&r.data&&r.data.length||0;let s;return s=a>1e6?(a/1e6).toFixed(2)+" MB":a>1e3?(a/1e3).toFixed(2)+" KB":a+" B",e&&!e.response||!r?React.createElement(React.Fragment,null,React.createElement(ErrorHeader,null," Could not get any response "),React.createElement(ErrorDetails,null,e&&e.message||"Unknown error"),React.createElement("br",null),React.createElement(ErrorHeader,null," Why this might have happened:"),React.createElement("div",null," - CORS is misconfigured on the server"),React.createElement("div",null," - The server couldn't send a response"),React.createElement("div",null," - No internet access"),React.createElement("div",null," - Documentation issue - contact API owner"),React.createElement("div",null," - Misconfigured security definition")):r?React.createElement(React.Fragment,null,React.createElement(ResponseBadges,null,React.createElement(ResponseBadge,{code:r.status},React.createElement("span",null," Status: "),r.status," ",r.statusText),React.createElement(ResponseBadgeBase,null,React.createElement("span",null," Time: "),n,"ms"),React.createElement(ResponseBadgeBase,null,React.createElement("span",null," Size: "),s)),React.createElement("div",null,React.createElement(ResponseHeadersList,{headers:r.headers}),React.createElement(ResponseBody,{response:r}))):React.createElement(React.Fragment,null,"Something went wrong")};
|
|
18
18
|
//# sourceMappingURL=ResponsePanel.js.map
|