Skip to content

Commit

Permalink
Add new ImportMapScriptElement
Browse files Browse the repository at this point in the history
ImportMapScriptElement renders a json importmap which allows to tell browsers how to resolve javascript dependencies.

Signed-off-by: Sylvain Rabot <sylvain@abstraction.fr>
  • Loading branch information
sylr committed Jan 16, 2025
1 parent 24be99e commit c1eae7e
Show file tree
Hide file tree
Showing 13 changed files with 2,427 additions and 49 deletions.
1 change: 1 addition & 0 deletions examples/typescript/.gitignore
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
assets/js/*.js.map
12 changes: 11 additions & 1 deletion examples/typescript/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,8 @@ This demonstrates how to bundle TypeScript code, and use it in a templ project.

The TypeScript code is bundled using `esbuild`, with templ used to serve HTML.

The `importmap` used by the browser to resolve dependencies is generated using [jspm-cli](https://jspm.org/docs/jspm-cli/stable/).

The code demonstrates application of `onclick` event handlers, and how to pass data from Go to TypeScript.

This demo passes data from server-side Go code to TypeScript code by placing the data in `<script type="application/json">` tags, or data attributes (called `alert-data` in this example).
Expand Down Expand Up @@ -33,7 +35,7 @@ npm install
If you have `esbuild` installed globally, you can bundle and minify the TypeScript code without using NPM. Remember to run `npm install` to install the dependencies first.

```bash
esbuild --bundle --minify --outfile=assets/js/index.js ts/src/index.ts
esbuild --minify --outdir=assets/js ts/src/*index*.ts
```

### ts-build-npm
Expand All @@ -46,6 +48,14 @@ Dir: ./ts
npm run build
```

### Add dependencies to the import-map

Dir: ./ts

```
npx jspm install --provider=jsdelivr --env=module lightweight-charts
```

### run

```bash
Expand Down
2 changes: 2 additions & 0 deletions examples/typescript/assets/js/alert.js

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

2 changes: 2 additions & 0 deletions examples/typescript/assets/js/graph.js

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

1 change: 0 additions & 1 deletion examples/typescript/assets/js/index.js

This file was deleted.

24 changes: 22 additions & 2 deletions examples/typescript/components/index.templ
Original file line number Diff line number Diff line change
@@ -1,20 +1,40 @@
package components

import (
"github.com/a-h/templ/examples/typescript/ts"
)

type Data struct {
Message string `json:"msg"`
}

var (
// The importmap is generated outside the template to avoid
// validating the JSON every time the template is executed.
importMapScriptElement = templ.ImportMapScript("", ts.ImportMapJSON)
)

templ Page(attributeData Data, scriptData Data) {
<!DOCTYPE html>
<html>
<head>
<title>Script usage</title>
<script src="/assets/js/index.js" defer></script>
<title>Typescript</title>
@importMapScriptElement
<script src="/assets/js/alert.js" defer></script>
</head>
<body>
<h2>Alert</h2>
<button id="attributeAlerter" alert-data={ templ.JSONString(attributeData) }>Show alert from data in alert-data attribute</button>
@templ.JSONScript("scriptData", scriptData)
<button id="scriptAlerter">Show alert from data in script</button>

<h2>Graph</h2>
<div id="graph" style="height: 200px"></div>
<script type="module">
import graph from "./assets/js/graph.js";
let container = document.getElementById("graph");
new graph.Graph(container);
</script>
</body>
</html>
}
26 changes: 22 additions & 4 deletions examples/typescript/components/index_templ.go

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

8 changes: 8 additions & 0 deletions examples/typescript/ts/embed.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,8 @@
package ts

import (
_ "embed"
)

//go:embed importmap.json
var ImportMapJSON string
15 changes: 15 additions & 0 deletions examples/typescript/ts/importmap.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,15 @@
{
"env": [
"browser",
"development",
"module"
],
"imports": {
"lightweight-charts": "https://cdn.jsdelivr.net/npm/lightweight-charts@4.1.6/dist/lightweight-charts.development.mjs"
},
"scopes": {
"https://cdn.jsdelivr.net/": {
"fancy-canvas": "https://cdn.jsdelivr.net/npm/fancy-canvas@2.1.0/index.mjs"
}
}
}
Loading

0 comments on commit c1eae7e

Please sign in to comment.