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

chore(babel-plugin-remove-graphql-queries): Convert index.js #23954

Merged
Changes from 1 commit
Commits
Show all changes
33 commits
Select commit Hold shift + click to select a range
72ddf2c
Declare Error class variables
zachdtaylor May 6, 2020
e506454
Apply linter
zachdtaylor May 6, 2020
d7a6a9e
Assert non-null NODE_ENV; remove unused state parameter
zachdtaylor May 7, 2020
b9ea1c5
Fix eslint warning about non-null assertion
zachdtaylor May 7, 2020
b4d10b6
Declare return types on some functions
zachdtaylor May 7, 2020
0876d3f
Prefix GraphQLTag interface with I
zachdtaylor May 7, 2020
136b73d
Declare function return types
zachdtaylor May 7, 2020
6a90f9c
Change getTagImport return type to any
zachdtaylor May 7, 2020
a496f36
Add babel types to dev dependencies
zachdtaylor May 8, 2020
c7af736
Add types in all functions before default export
zachdtaylor May 10, 2020
bd6329b
Add types in all functions before default export
zachdtaylor May 10, 2020
2c4a780
Type function parameters
zachdtaylor May 10, 2020
63113f6
Type jsx nodes
zachdtaylor May 10, 2020
4b11614
Type jsx nodes
zachdtaylor May 10, 2020
105808a
Create visitor interfaces
zachdtaylor May 10, 2020
6171bce
Merge remote-tracking branch 'upstream/master' into ts/babel-plugin-r…
zachdtaylor May 10, 2020
80162fa
Move 'as NodePath'
zachdtaylor May 14, 2020
29650e6
Merge remote-tracking branch 'upstream/master' into ts/babel-plugin-r…
zachdtaylor May 14, 2020
60f777e
Use type instead of interface
zachdtaylor May 14, 2020
90d8687
Use type
zachdtaylor May 14, 2020
26fa470
Create custom State type
zachdtaylor Jun 3, 2020
533a44a
Create custom State type
zachdtaylor Jun 3, 2020
8dd3f21
Merge remote-tracking branch 'upstream/master' into ts/babel-plugin-r…
zachdtaylor Aug 5, 2020
d780505
Allow undefined members in StringInterpolationNotAllowedError
zachdtaylor Aug 5, 2020
d490552
Wrap if statement in block
zachdtaylor Aug 5, 2020
bbd3c95
chore: format
Aug 5, 2020
06a46a7
Merge remote-tracking branch 'upstream/master' into ts/babel-plugin-r…
zachdtaylor Aug 11, 2020
c506b36
Merge remote-tracking branch 'upstream/master' into ts/babel-plugin-r…
Aug 11, 2020
c931045
Change the way graphql is imported
zachdtaylor Aug 14, 2020
c7dcd12
Fix typecheck errors
zachdtaylor Aug 14, 2020
cf37a3c
Merge remote-tracking branch 'upstream/master' into ts/babel-plugin-r…
Sep 8, 2020
87ad7fd
chore: format
Sep 8, 2020
fc0be92
Merge remote-tracking branch 'upstream/master' into ts/babel-plugin-r…
Sep 8, 2020
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
Prev Previous commit
Next Next commit
Declare return types on some functions
  • Loading branch information
zachdtaylor committed May 7, 2020
commit b4d10b61df313248dcd5de61cb96599375dd73d2
23 changes: 15 additions & 8 deletions packages/babel-plugin-remove-graphql-queries/src/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -49,10 +49,10 @@ class GraphQLSyntaxError extends Error {
}
}

const isGlobalIdentifier = tag =>
const isGlobalIdentifier = (tag): boolean =>
tag.isIdentifier({ name: `graphql` }) && tag.scope.hasGlobal(`graphql`)

export function followVariableDeclarations(binding) {
export function followVariableDeclarations(binding): any {
const node = binding.path?.node
if (
node?.type === `VariableDeclarator` &&
Expand Down Expand Up @@ -99,7 +99,7 @@ function getTagImport(tag) {
return null
}

function isGraphqlTag(tag) {
function isGraphqlTag(tag): boolean {
const isExpression = tag.isMemberExpression()
const identifier = isExpression ? tag.get(`object`) : tag

Expand All @@ -122,12 +122,12 @@ function isGraphqlTag(tag) {
return false
}

function removeImport(tag) {
function removeImport(tag): void {
const isExpression = tag.isMemberExpression()
const identifier = isExpression ? tag.get(`object`) : tag
const importPath = getTagImport(identifier)

const removeVariableDeclaration = statement => {
const removeVariableDeclaration = (statement): void => {
const declaration = statement.findParent(p => p.isVariableDeclaration())
if (declaration) {
declaration.remove()
Expand All @@ -152,11 +152,18 @@ function removeImport(tag) {
}
}

function getGraphQLTag(path) {
interface GraphQLTag {
ast: any,
text: string,
hash: number,
isGlobal: boolean
}

function getGraphQLTag(path): GraphQLTag {
const tag = path.get(`tag`)
const isGlobal = isGlobalIdentifier(tag)

if (!isGlobal && !isGraphqlTag(tag)) return {}
if (!isGlobal && !isGraphqlTag(tag)) return {} as GraphQLTag

const quasis = path.node.quasi.quasis

Expand All @@ -182,7 +189,7 @@ function getGraphQLTag(path) {
}
}

function isUseStaticQuery(path) {
function isUseStaticQuery(path): boolean {
return (
(path.node.callee.type === `MemberExpression` &&
path.node.callee.property.name === `useStaticQuery` &&
Expand Down