Skip to content

Commit

Permalink
Handle multiple imports of next/dynamic
Browse files Browse the repository at this point in the history
  • Loading branch information
padmaia committed Aug 4, 2021
1 parent 043f1a8 commit dd03755
Show file tree
Hide file tree
Showing 3 changed files with 29 additions and 6 deletions.
16 changes: 10 additions & 6 deletions packages/next/build/swc/src/next_dynamic.rs
Original file line number Diff line number Diff line change
@@ -1,23 +1,24 @@
use swc_atoms::{js_word, JsWord};
use swc_atoms::js_word;
use swc_common::{FileName, DUMMY_SP};
use swc_ecmascript::ast::{
ArrayLit, ArrowExpr, BinExpr, BinaryOp, BlockStmtOrExpr, CallExpr, Expr, ExprOrSpread,
ExprOrSuper, Ident, ImportDecl, ImportSpecifier, KeyValueProp, Lit, MemberExpr, ObjectLit, Prop,
PropName, PropOrSpread, Str, StrKind,
};
use swc_ecmascript::utils::Id;
use swc_ecmascript::visit::Fold;

pub fn next_dynamic(filename: FileName) -> impl Fold {
NextDynamicPatcher {
filename,
dynamic_binding: js_word!(""),
dynamic_bindings: vec![],
}
}

#[derive(Debug)]
struct NextDynamicPatcher {
filename: FileName,
dynamic_binding: JsWord,
dynamic_bindings: Vec<Id>,
}

impl Fold for NextDynamicPatcher {
Expand All @@ -30,7 +31,10 @@ impl Fold for NextDynamicPatcher {
if &src.value == "next/dynamic" {
for specifier in specifiers {
if let ImportSpecifier::Default(default_specifier) = specifier {
self.dynamic_binding = default_specifier.local.sym.clone();
self.dynamic_bindings.push((
default_specifier.local.sym.clone(),
default_specifier.local.span.ctxt,
));
}
}
}
Expand All @@ -40,8 +44,8 @@ impl Fold for NextDynamicPatcher {

fn fold_call_expr(&mut self, mut expr: CallExpr) -> CallExpr {
if let ExprOrSuper::Expr(i) = &expr.callee {
if let Expr::Ident(Ident { sym, .. }) = &**i {
if sym == &self.dynamic_binding {
if let Expr::Ident(Ident { sym, span, .. }) = &**i {
if self.dynamic_bindings.contains(&(sym.clone(), span.ctxt)) {
let mut import_specifier = None;
if let Expr::Arrow(ArrowExpr {
body: BlockStmtOrExpr::Expr(e),
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
import dynamic1 from 'next/dynamic'
import dynamic2 from 'next/dynamic'

const DynamicComponent1 = dynamic1(() => import('../components/hello1'))
const DynamicComponent2 = dynamic2(() => import('../components/hello2'))
Original file line number Diff line number Diff line change
@@ -0,0 +1,14 @@
import dynamic1 from 'next/dynamic'
import dynamic2 from 'next/dynamic'
const DynamicComponent1 = dynamic1(() => import('../components/hello1'), {
loadableGenerated: {
webpack: () => [require.resolveWeak('/some-project/src/some-file.js')],
modules: ['/some-project/src/some-file.js -> ' + '../components/hello1'],
},
})
const DynamicComponent2 = dynamic2(() => import('../components/hello2'), {
loadableGenerated: {
webpack: () => [require.resolveWeak('/some-project/src/some-file.js')],
modules: ['/some-project/src/some-file.js -> ' + '../components/hello2'],
},
})

0 comments on commit dd03755

Please sign in to comment.