rsnext/packages/next/build/babel/plugins/next-data.ts
Joe Haddad f9f80dffe5
Upgrade dependencies (#7412)
* ⬆️ Upgrade workspace dependencies

* Run new prettier against examples

* Upgrade some next-server packages

* Upgrade Next.js dependencies

* Upgrade webpack deps

* Upgrade async sema

* Fix compilation

* Revert broken plugin
2019-05-23 00:52:36 -07:00

61 lines
1.6 KiB
TypeScript

import { PluginObj } from '@babel/core'
import { NodePath } from '@babel/traverse'
import * as BabelTypes from '@babel/types'
export default function({
types: t,
}: {
types: typeof BabelTypes
}): PluginObj<any> {
return {
visitor: {
ImportDeclaration(path: NodePath<BabelTypes.ImportDeclaration>, state) {
const source = path.node.source.value
if (source !== 'next/data') return
const createHookSpecifier = path.get('specifiers').find(specifier => {
return (
specifier.isImportSpecifier() &&
specifier.node.imported.name === 'createHook'
)
})
if (!createHookSpecifier) return
const bindingName = createHookSpecifier.node.local.name
const binding = path.scope.getBinding(bindingName)
if (!binding) {
return
}
binding.referencePaths.forEach(refPath => {
let callExpression = refPath.parentPath
if (!callExpression.isCallExpression()) return
let args: any = callExpression.get('arguments')
if (!args[0]) {
throw callExpression.buildCodeFrameError(
'first argument to createHook should be a function'
)
}
if (!args[1]) {
callExpression.node.arguments.push(t.objectExpression([]))
}
args = callExpression.get('arguments')
args[1].node.properties.push(
t.objectProperty(
t.identifier('key'),
t.stringLiteral(state.opts.key)
)
)
})
},
},
}
}