Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Fix/side tabs does not appear #1001

Merged
merged 2 commits into from
May 23, 2019
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Original file line number Diff line number Diff line change
Expand Up @@ -904,12 +904,24 @@ const GraphqlContainer = styled.div`
width: 100%;
`

interface Props {
setRef?: (ref: any) => void
}
export class Container extends React.PureComponent {
private graphqlContainer

render() {
return (
<GraphqlContainer ref={this.setGraphqlContainer}>
{this.props.children}
</GraphqlContainer>
)
}

export const Container: React.SFC<Props> = ({ children, setRef }) => (
<GraphqlContainer ref={setRef}>{children}</GraphqlContainer>
)
getWidth = () => {
return this.graphqlContainer.offsetWidth
}

private setGraphqlContainer = ref => {
this.graphqlContainer = ref
}
}

export default Wrapper
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,6 @@ import { getLeft } from 'graphiql/dist/utility/elementPosition'
import {
addStack,
toggleDocs,
changeWidthDocs,
changeKeyMove,
setDocsVisible,
} from '../../../state/docs/actions'
Expand Down Expand Up @@ -40,12 +39,14 @@ export interface Props {
sessionId: string
children: Array<React.ReactElement<any>>
maxWidth: number
setWidth: (props?: any) => any
setActiveContentRef: (ref: any) => void
}

export interface SideTabContentProps {
schema: GraphQLSchema
sessionId: string
setWidth: (props: any) => any
setWidth: (props?: any) => any
}

export interface State {
Expand All @@ -58,7 +59,6 @@ class SideTabs extends React.Component<
State
> {
ref
public activeContentComponent: any // later React.Component<...>
private refContentContainer: any
private clientX: number = 0
private clientY: number = 0
Expand All @@ -67,27 +67,6 @@ class SideTabs extends React.Component<
;(window as any).d = this
}

setWidth = (props: any = this.props) => {
if (!this.activeContentComponent) {
return
}
if (!this.props.docs.docsOpen) {
return
}
requestAnimationFrame(() => {
const width = this.activeContentComponent.getWidth(props)
this.props.changeWidthDocs(
props.sessionId,
Math.min(width, this.props.maxWidth),
)
})
}
setActiveContentRef = ref => {
if (ref) {
this.activeContentComponent = ref.getWrappedInstance()
}
}

componentDidUpdate(prevProps) {
if (!prevProps.docs.activeTabIdx && this.props.docs.activeTabIdx) {
this.props.setDocsVisible(
Expand All @@ -99,7 +78,7 @@ class SideTabs extends React.Component<
if (prevProps.activeTabIdx && !this.props.docs.activeTabIdx) {
this.props.setDocsVisible(this.props.sessionId, false)
}
this.setWidth()
this.props.setWidth()
if (
this.props.docs.activeTabIdx !== prevProps.docs.activeTabIdx &&
this.refContentContainer
Expand All @@ -112,7 +91,7 @@ class SideTabs extends React.Component<
if (!this.props.docs.activeTabIdx) {
this.props.setDocsVisible(this.props.sessionId, false)
}
return this.setWidth()
return this.props.setWidth()
}

render() {
Expand Down Expand Up @@ -149,8 +128,8 @@ class SideTabs extends React.Component<
{activeTab &&
React.cloneElement(activeTab.props.children, {
...activeTab.props,
ref: this.setActiveContentRef,
setWidth: this.setWidth,
ref: this.props.setActiveContentRef,
setWidth: this.props.setWidth,
})}
</TabContentContainer>
</Tabs>
Expand All @@ -161,19 +140,14 @@ class SideTabs extends React.Component<
this.ref = ref
}

public showDocFromType = type => {
this.props.setDocsVisible(this.props.sessionId, true, 0)
this.activeContentComponent.showDocFromType(type)
}

private setContentContainerRef = ref => {
this.refContentContainer = ref
}

private handleTabClick = idx => () => {
if (this.props.docs.activeTabIdx === idx) {
this.props.setDocsVisible(this.props.sessionId, false)
return this.setWidth()
return this.props.setWidth()
}
if (this.props.docs.activeTabIdx !== idx) {
this.props.setDocsVisible(
Expand All @@ -182,10 +156,10 @@ class SideTabs extends React.Component<
this.props.docs.activeTabIdx,
)
this.props.setDocsVisible(this.props.sessionId, true, idx)
return this.setWidth()
return this.props.setWidth()
} else {
this.props.setDocsVisible(this.props.sessionId, true, idx)
return this.setWidth()
return this.props.setWidth()
}
}

Expand Down Expand Up @@ -275,7 +249,6 @@ const mapDispatchToProps = dispatch =>
{
addStack,
toggleDocs,
changeWidthDocs,
changeKeyMove,
setDocsVisible,
},
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -66,6 +66,8 @@ import {
fetchSchema,
} from '../../state/sessions/actions'
import { ResponseRecord } from '../../state/sessions/reducers'
import { getDocsOpen } from '../../state/docs/selectors'
import { changeWidthDocs } from '../../state/docs/actions'

/**
* The top-level React component for GraphQLEditor, intended to encompass the entire
Expand Down Expand Up @@ -94,7 +96,9 @@ export interface ReduxProps {
toggleVariables: () => void
setEditorFlex: (flex: number) => void
stopQuery: (sessionId: string) => void
changeWidthDocs: (sessionId: string, width: number) => void
navStack: any[]
docsOpen: boolean
// sesion props
queryRunning: boolean
responses: List<ResponseRecord>
Expand Down Expand Up @@ -140,6 +144,7 @@ class GraphQLEditor extends React.PureComponent<Props & ReduxProps> {
private queryVariablesRef
private httpHeadersRef
private containerComponent
private activeSideTabContent

componentDidMount() {
// Ensure a form of a schema exists (including `null`) and
Expand Down Expand Up @@ -167,7 +172,7 @@ class GraphQLEditor extends React.PureComponent<Props & ReduxProps> {

render() {
return (
<Container setRef={this.setContainerComponent}>
<Container ref={this.setContainerComponent}>
<EditorWrapper>
<TopBar
shareEnabled={this.props.shareEnabled}
Expand Down Expand Up @@ -265,23 +270,25 @@ class GraphQLEditor extends React.PureComponent<Props & ReduxProps> {
</ResultWrap>
</EditorBar>
</EditorWrapper>
{this.containerComponent && (
<SideTabs maxWidth={this.containerComponent.offsetWidth - 86}>
<SideTab label="Docs" activeColor="green" tabWidth="49px">
<GraphDocs
schema={this.props.schema}
ref={this.setDocExplorerRef}
/>
</SideTab>
<SideTab label="Schema" activeColor="blue" tabWidth="65px">
<SDLView
schema={this.props.schema}
ref={this.setSchemaExplorerRef}
sessionId={this.props.sessionId}
/>
</SideTab>
</SideTabs>
)}
<SideTabs
setActiveContentRef={this.setSideTabActiveContentRef}
setWidth={this.setDocsWidth}
>
<SideTab label="Docs" activeColor="green" tabWidth="49px">
<GraphDocs
schema={this.props.schema}
ref={this.setDocExplorerRef}
/>
</SideTab>
<SideTab label="Schema" activeColor="blue" tabWidth="65px">
<SDLView
schema={this.props.schema}
ref={this.setSchemaExplorerRef}
sessionId={this.props.sessionId}
/>
</SideTab>
</SideTabs>
}
</Container>
)
}
Expand Down Expand Up @@ -343,6 +350,12 @@ class GraphQLEditor extends React.PureComponent<Props & ReduxProps> {
}
}

setSideTabActiveContentRef = ref => {
if (ref) {
this.activeSideTabContent = ref.getWrappedInstance()
}
}

/**
* Inspect the query, automatically filling in selection sets for non-leaf
* fields which do not yet have them.
Expand Down Expand Up @@ -565,6 +578,20 @@ class GraphQLEditor extends React.PureComponent<Props & ReduxProps> {
}
}
}

private setDocsWidth = (props: any = this.props) => {
if (!this.activeSideTabContent) {
return
}
if (!this.props.docsOpen) {
return
}
requestAnimationFrame(() => {
const width = this.activeSideTabContent.getWidth()
const maxWidth = this.containerComponent.getWidth() - 86
this.props.changeWidthDocs(props.sessionId, Math.min(width, maxWidth))
})
}
}

const mapStateToProps = createStructuredSelector({
Expand All @@ -586,6 +613,7 @@ const mapStateToProps = createStructuredSelector({
operationName: getOperationName,
headersCount: getHeadersCount,
sessionId: getSelectedSessionIdFromRoot,
docsOpen: getDocsOpen,
})

export default // TODO fix redux types
Expand All @@ -605,6 +633,7 @@ connect<any, any, any>(
setEditorFlex,
toggleVariables,
fetchSchema,
changeWidthDocs,
},
null,
{
Expand Down
3 changes: 3 additions & 0 deletions packages/graphql-playground-react/src/state/docs/selectors.ts
Original file line number Diff line number Diff line change
Expand Up @@ -13,3 +13,6 @@ export const getSessionDocsState = createSelector(
export const getSessionDocs = createSelector([getSessionDocsState], state => {
return state.toJS()
})
export const getDocsOpen = createSelector([getSessionDocsState], state => {
return state.get('docsOpen')
})