diff --git a/src/app/pages/tabs-container/collection-types/grpc/send-header/protocol-switch.tsx b/src/app/pages/tabs-container/collection-types/grpc/send-header/protocol-switch.tsx new file mode 100644 index 0000000..3eecd31 --- /dev/null +++ b/src/app/pages/tabs-container/collection-types/grpc/send-header/protocol-switch.tsx @@ -0,0 +1,61 @@ +import { faGlobe, faWarning } from '@fortawesome/free-solid-svg-icons'; +import { FontAwesomeIcon } from '@fortawesome/react-fontawesome'; +import { Container, Spacer, Switch, SwitchEvent, Text, Tooltip, useTheme } from '@nextui-org/react'; +import React from 'react'; + +import { GrpcMethodType } from '@core/types'; +import { GrpcProtocol, GrpcTab } from '@storage'; + +export interface ProtocolSwitchProps { + tab: GrpcTab; + + onChange: (event: SwitchEvent) => void; +} + +export const ProtocolSwitch: React.FC = ({ tab, onChange }) => { + const { theme } = useTheme(); + + const isGrpcWebAvailable = + tab.info.methodType === GrpcMethodType.UNARY || + tab.info.methodType === GrpcMethodType.SERVER_STREAMING; + + let content = ( + + {tab.data.protocol === GrpcProtocol.GRPC_WEB ? 'Using gRPC-Web' : 'Using gRPC'} + + ); + + if (!isGrpcWebAvailable) { + content = ( + + Using gRPC + + + + + + gRPC-Web doesn't support + {tab.info.methodType === GrpcMethodType.CLIENT_STREAMING + ? ' client streaming' + : ' bidirectional streaming'} + + + + ); + } + + return ( + + } + checked={tab.data.protocol === GrpcProtocol.GRPC_WEB} + onChange={onChange} + /> + + ); +}; diff --git a/src/app/pages/tabs-container/collection-types/grpc/send-header/send-header.basic.tsx b/src/app/pages/tabs-container/collection-types/grpc/send-header/send-header.basic.tsx index d877b33..ebc4a25 100644 --- a/src/app/pages/tabs-container/collection-types/grpc/send-header/send-header.basic.tsx +++ b/src/app/pages/tabs-container/collection-types/grpc/send-header/send-header.basic.tsx @@ -1,6 +1,6 @@ -import { faFloppyDisk, faGlobe, faLock, faUnlock } from '@fortawesome/free-solid-svg-icons'; +import { faFloppyDisk, faLock, faUnlock } from '@fortawesome/free-solid-svg-icons'; import { FontAwesomeIcon } from '@fortawesome/react-fontawesome'; -import { Button, Container, Input, Spacer, Switch, SwitchEvent, Tooltip } from '@nextui-org/react'; +import { Button, Container, Input, Spacer, SwitchEvent, Tooltip } from '@nextui-org/react'; import React, { PropsWithChildren } from 'react'; import { MultiValue, SingleValue } from 'react-select'; @@ -17,6 +17,7 @@ import { import { CreateEnvironmentModal } from '../environments'; import { TlsSettingsModal } from '../tls'; +import { ProtocolSwitch } from './protocol-switch'; export interface SendHeaderProps { tab: GrpcTab; @@ -191,31 +192,7 @@ export const SendHeader: React.FC - - } - checked={tab.data.protocol === GrpcProtocol.GRPC_WEB} - onChange={handleGrpcProtocolChange} - /> - + {children}