-
Notifications
You must be signed in to change notification settings - Fork 8
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
* fix: hydrate glob imports * chore: add changeset
- Loading branch information
Showing
16 changed files
with
216 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,5 @@ | ||
--- | ||
"@marko/vite": patch | ||
--- | ||
|
||
Enable hydration of components glob imported |
5 changes: 5 additions & 0 deletions
5
src/__tests__/fixtures/isomorphic-glob-import/__snapshots__/build.expected.loading.0.html
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,5 @@ | ||
<div | ||
id="clickable" | ||
> | ||
Mounted: false Clicks: 0 | ||
</div> |
5 changes: 5 additions & 0 deletions
5
src/__tests__/fixtures/isomorphic-glob-import/__snapshots__/build.expected.loading.1.html
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,5 @@ | ||
<div | ||
id="clickable" | ||
> | ||
Mounted: true Clicks: 0 | ||
</div> |
5 changes: 5 additions & 0 deletions
5
src/__tests__/fixtures/isomorphic-glob-import/__snapshots__/build.expected.step-0.0.html
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,5 @@ | ||
<div | ||
id="clickable" | ||
> | ||
Mounted: true Clicks: 1 | ||
</div> |
5 changes: 5 additions & 0 deletions
5
src/__tests__/fixtures/isomorphic-glob-import/__snapshots__/dev.expected.loading.0.html
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,5 @@ | ||
<div | ||
id="clickable" | ||
> | ||
Mounted: false Clicks: 0 | ||
</div> |
5 changes: 5 additions & 0 deletions
5
src/__tests__/fixtures/isomorphic-glob-import/__snapshots__/dev.expected.loading.1.html
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,5 @@ | ||
<div | ||
id="clickable" | ||
> | ||
Mounted: true Clicks: 0 | ||
</div> |
5 changes: 5 additions & 0 deletions
5
src/__tests__/fixtures/isomorphic-glob-import/__snapshots__/dev.expected.step-0.0.html
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,5 @@ | ||
<div | ||
id="clickable" | ||
> | ||
Mounted: true Clicks: 1 | ||
</div> |
38 changes: 38 additions & 0 deletions
38
src/__tests__/fixtures/isomorphic-glob-import/dev-server.mjs
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,38 @@ | ||
// In dev we'll start a Vite dev server in middleware mode, | ||
// and forward requests to our http request handler. | ||
|
||
import { createServer } from "vite"; | ||
import path from "path"; | ||
import url from "url"; | ||
import { createRequire } from "module"; | ||
|
||
// change to import once marko-vite is updated to ESM | ||
const markoPlugin = createRequire(import.meta.url)("../../..").default; | ||
|
||
const __dirname = path.dirname(url.fileURLToPath(import.meta.url)); | ||
|
||
const devServer = await createServer({ | ||
root: __dirname, | ||
appType: "custom", | ||
logLevel: "silent", | ||
plugins: [markoPlugin()], | ||
optimizeDeps: { force: true }, | ||
server: { | ||
middlewareMode: true, | ||
watch: { | ||
ignored: ["**/node_modules/**", "**/dist/**", "**/__snapshots__/**"], | ||
}, | ||
}, | ||
}); | ||
|
||
export default devServer.middlewares.use(async (req, res, next) => { | ||
try { | ||
const { handler } = await devServer.ssrLoadModule( | ||
path.join(__dirname, "./src/index.js") | ||
); | ||
await handler(req, res, next); | ||
} catch (err) { | ||
devServer.ssrFixStacktrace(err); | ||
return next(err); | ||
} | ||
}); |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,15 @@ | ||
// In production, simply start up the http server. | ||
import path from 'path' | ||
import url from 'url'; | ||
import { createServer } from "http"; | ||
import serve from "serve-handler"; | ||
import { handler } from "./dist/index.mjs"; | ||
|
||
const __dirname = path.dirname(url.fileURLToPath(import.meta.url)); | ||
const serveOpts = { public: path.resolve(__dirname, "dist") }; | ||
|
||
export default createServer(async (req, res) => { | ||
await handler(req, res); | ||
if (res.headersSent) return; | ||
await serve(req, res, serveOpts); | ||
}); |
9 changes: 9 additions & 0 deletions
9
src/__tests__/fixtures/isomorphic-glob-import/src/components/layout-component.marko
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,9 @@ | ||
<!DOCTYPE html> | ||
<html lang="en"> | ||
<head> | ||
<title>Hello World</title> | ||
</head> | ||
<body> | ||
<${input.renderBody}/> | ||
</body> | ||
</html> |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,9 @@ | ||
import template from "./template.marko"; | ||
|
||
export function handler(req, res) { | ||
if (req.url === "/") { | ||
res.statusCode = 200; | ||
res.setHeader("Content-Type", "text/html; charset=utf-8"); | ||
template.render({}, res); | ||
} | ||
} |
20 changes: 20 additions & 0 deletions
20
src/__tests__/fixtures/isomorphic-glob-import/src/modules/class-component.marko
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,20 @@ | ||
class { | ||
onCreate() { | ||
this.state = { | ||
clickCount: 0, | ||
mounted: false | ||
}; | ||
} | ||
onMount() { | ||
this.state.mounted = true; | ||
} | ||
handleClick() { | ||
this.state.clickCount++; | ||
} | ||
} | ||
|
||
<div#clickable onClick("handleClick")> | ||
Mounted: ${state.mounted} | ||
Clicks: ${state.clickCount} | ||
</div> |
13 changes: 13 additions & 0 deletions
13
src/__tests__/fixtures/isomorphic-glob-import/src/template.marko
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,13 @@ | ||
static const modules = import.meta.glob('./modules/*.marko', { eager: true }) | ||
|
||
style { | ||
div { color: green } | ||
} | ||
|
||
<layout-component> | ||
<div#app> | ||
<for|_id, mod| in=modules> | ||
<${mod}/> | ||
</for> | ||
</div> | ||
</layout-component> |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,4 @@ | ||
export const ssr = true; | ||
export async function steps() { | ||
await page.click("#clickable"); | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,71 @@ | ||
import { types as t } from "@marko/compiler"; | ||
import glob from "fast-glob"; | ||
import path from "path"; | ||
|
||
type GlobArgs = [string | string[], { eager?: boolean; exhaustive?: boolean }]; | ||
|
||
const programGlobImports = new WeakMap<t.NodePath<t.Program>, GlobArgs[]>(); | ||
|
||
export default { | ||
MetaProperty(tag: t.NodePath<t.MetaProperty>) { | ||
const memberExpression = tag.parentPath; | ||
if ( | ||
memberExpression.node.type === "MemberExpression" && | ||
memberExpression.node.property.type === "Identifier" && | ||
memberExpression.node.property.name === "glob" | ||
) { | ||
const callExpression = memberExpression.parentPath; | ||
if (callExpression?.node.type === "CallExpression") { | ||
const args = ( | ||
callExpression.get("arguments" as any) as t.NodePath<t.Expression>[] | ||
).map((arg) => arg.evaluate().value) as GlobArgs; | ||
if (args[1]?.eager) { | ||
const program = tag.hub.file.path; | ||
const existing = programGlobImports.get(program); | ||
if (!existing) { | ||
programGlobImports.set(program, [args]); | ||
} else { | ||
existing.push(args); | ||
} | ||
} | ||
} | ||
} | ||
}, | ||
Program: { | ||
exit(tag: t.NodePath<t.Program>) { | ||
const globImports = programGlobImports.get(tag); | ||
if (!globImports) { | ||
return; | ||
} | ||
|
||
const { cwd, filename } = tag.hub.file.opts as { | ||
cwd: string; | ||
filename: string; | ||
}; | ||
const dir = path.dirname(filename); | ||
const seen = new Set(); | ||
|
||
for (const [patterns, options] of globImports) { | ||
const resolvedPatterns = Array.isArray(patterns) | ||
? patterns.map((p) => path.resolve(dir, p)) | ||
: path.resolve(dir, patterns); | ||
|
||
const results = glob.globSync(resolvedPatterns, { | ||
cwd, | ||
absolute: true, | ||
dot: !!options.exhaustive, | ||
ignore: options.exhaustive | ||
? [] | ||
: [path.join(cwd, "**/node_modules/**")], | ||
}); | ||
|
||
for (const file of results) { | ||
if (file.endsWith(".marko") && file !== filename && !seen.has(file)) { | ||
seen.add(file); | ||
tag.node.body.push(t.importDeclaration([], t.stringLiteral(file))); | ||
} | ||
} | ||
} | ||
}, | ||
}, | ||
}; |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters