jac-client 0.2.0__py3-none-any.whl → 0.2.1__py3-none-any.whl

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (84) hide show
  1. jac_client/docs/README.md +31 -1
  2. jac_client/docs/asset-serving/intro.md +209 -0
  3. jac_client/docs/assets/pipe_line-v2.svg +32 -0
  4. jac_client/docs/file-system/intro.md +90 -0
  5. jac_client/docs/styling/intro.md +250 -0
  6. jac_client/docs/styling/js-styling.md +373 -0
  7. jac_client/docs/styling/material-ui.md +346 -0
  8. jac_client/docs/styling/pure-css.md +305 -0
  9. jac_client/docs/styling/sass.md +409 -0
  10. jac_client/docs/styling/styled-components.md +401 -0
  11. jac_client/docs/styling/tailwind.md +303 -0
  12. jac_client/examples/asset-serving/css-with-image/.babelrc +9 -0
  13. jac_client/examples/asset-serving/css-with-image/README.md +91 -0
  14. jac_client/examples/asset-serving/css-with-image/app.jac +67 -0
  15. jac_client/examples/asset-serving/css-with-image/assets/burger.png +0 -0
  16. jac_client/examples/asset-serving/css-with-image/package.json +28 -0
  17. jac_client/examples/asset-serving/css-with-image/styles.css +27 -0
  18. jac_client/examples/asset-serving/css-with-image/vite.config.js +29 -0
  19. jac_client/examples/asset-serving/image-asset/.babelrc +9 -0
  20. jac_client/examples/asset-serving/image-asset/README.md +119 -0
  21. jac_client/examples/asset-serving/image-asset/app.jac +43 -0
  22. jac_client/examples/asset-serving/image-asset/assets/burger.png +0 -0
  23. jac_client/examples/asset-serving/image-asset/package.json +28 -0
  24. jac_client/examples/asset-serving/image-asset/styles.css +27 -0
  25. jac_client/examples/asset-serving/image-asset/vite.config.js +29 -0
  26. jac_client/examples/asset-serving/import-alias/.babelrc +9 -0
  27. jac_client/examples/asset-serving/import-alias/README.md +83 -0
  28. jac_client/examples/asset-serving/import-alias/app.jac +57 -0
  29. jac_client/examples/asset-serving/import-alias/assets/burger.png +0 -0
  30. jac_client/examples/asset-serving/import-alias/package.json +28 -0
  31. jac_client/examples/asset-serving/import-alias/vite.config.js +29 -0
  32. jac_client/examples/css-styling/js-styling/.babelrc +9 -0
  33. jac_client/examples/css-styling/js-styling/README.md +183 -0
  34. jac_client/examples/css-styling/js-styling/app.jac +63 -0
  35. jac_client/examples/css-styling/js-styling/package.json +28 -0
  36. jac_client/examples/css-styling/js-styling/styles.js +100 -0
  37. jac_client/examples/css-styling/js-styling/vite.config.js +28 -0
  38. jac_client/examples/css-styling/material-ui/.babelrc +9 -0
  39. jac_client/examples/css-styling/material-ui/README.md +16 -0
  40. jac_client/examples/css-styling/material-ui/app.jac +82 -0
  41. jac_client/examples/css-styling/material-ui/package.json +32 -0
  42. jac_client/examples/css-styling/material-ui/vite.config.js +28 -0
  43. jac_client/examples/css-styling/pure-css/.babelrc +9 -0
  44. jac_client/examples/css-styling/pure-css/README.md +16 -0
  45. jac_client/examples/css-styling/pure-css/app.jac +63 -0
  46. jac_client/examples/css-styling/pure-css/package.json +28 -0
  47. jac_client/examples/css-styling/pure-css/styles.css +112 -0
  48. jac_client/examples/css-styling/pure-css/vite.config.js +28 -0
  49. jac_client/examples/css-styling/sass-example/.babelrc +9 -0
  50. jac_client/examples/css-styling/sass-example/README.md +16 -0
  51. jac_client/examples/css-styling/sass-example/app.jac +63 -0
  52. jac_client/examples/css-styling/sass-example/package.json +29 -0
  53. jac_client/examples/css-styling/sass-example/styles.scss +158 -0
  54. jac_client/examples/css-styling/sass-example/vite.config.js +28 -0
  55. jac_client/examples/css-styling/styled-components/.babelrc +9 -0
  56. jac_client/examples/css-styling/styled-components/README.md +16 -0
  57. jac_client/examples/css-styling/styled-components/app.jac +66 -0
  58. jac_client/examples/css-styling/styled-components/package.json +29 -0
  59. jac_client/examples/css-styling/styled-components/styled.js +91 -0
  60. jac_client/examples/css-styling/styled-components/vite.config.js +28 -0
  61. jac_client/examples/css-styling/tailwind-example/.babelrc +9 -0
  62. jac_client/examples/css-styling/tailwind-example/README.md +16 -0
  63. jac_client/examples/css-styling/tailwind-example/app.jac +64 -0
  64. jac_client/examples/css-styling/tailwind-example/global.css +1 -0
  65. jac_client/examples/css-styling/tailwind-example/package.json +30 -0
  66. jac_client/examples/css-styling/tailwind-example/vite.config.js +30 -0
  67. jac_client/examples/with-router/app.jac +1 -1
  68. jac_client/plugin/cli.py +5 -0
  69. jac_client/plugin/client.py +64 -3
  70. jac_client/plugin/vite_client_bundle.py +96 -1
  71. jac_client/tests/__init__.py +0 -1
  72. jac_client/tests/fixtures/cl_file/app.cl.jac +38 -0
  73. jac_client/tests/fixtures/cl_file/app.jac +15 -0
  74. jac_client/tests/fixtures/js_import/app.jac +1 -1
  75. jac_client/tests/fixtures/relative_import/button.jac +2 -2
  76. jac_client/tests/fixtures/test_fragments_spread/app.jac +2 -2
  77. jac_client/tests/test_asset_examples.py +339 -0
  78. jac_client/tests/test_cl.py +165 -87
  79. jac_client/tests/test_create_jac_app.py +40 -44
  80. {jac_client-0.2.0.dist-info → jac_client-0.2.1.dist-info}/METADATA +2 -2
  81. jac_client-0.2.1.dist-info/RECORD +140 -0
  82. jac_client-0.2.0.dist-info/RECORD +0 -72
  83. {jac_client-0.2.0.dist-info → jac_client-0.2.1.dist-info}/WHEEL +0 -0
  84. {jac_client-0.2.0.dist-info → jac_client-0.2.1.dist-info}/entry_points.txt +0 -0
@@ -0,0 +1,91 @@
1
+ # Relative Imports Example
2
+
3
+ This example demonstrates how to import static assets using relative path imports.
4
+
5
+ ## Features
6
+
7
+ - Imports image using relative path (`./assets/burger.png`)
8
+ - Component-scoped asset organization
9
+ - Vite processes and optimizes the asset
10
+ - Familiar import syntax
11
+
12
+ ## Project Structure
13
+
14
+ ```
15
+ relative-imports/
16
+ ├── app.jac # Main application file
17
+ ├── assets/ # Static assets directory
18
+ │ └── burger.png # Burger image
19
+ ├── src/ # Source files (generated)
20
+ ├── build/ # Build output (generated)
21
+ └── dist/ # Distribution output (generated)
22
+ ```
23
+
24
+ ## Running the Example
25
+
26
+ 1. Make sure node modules are installed:
27
+ ```bash
28
+ npm install
29
+ ```
30
+
31
+ 2. Run the Jac server:
32
+ ```bash
33
+ jac serve app.jac
34
+ ```
35
+
36
+ 3. Open your browser and navigate to:
37
+ ```
38
+ http://localhost:8000/page/app
39
+ ```
40
+
41
+ ## How It Works
42
+
43
+ ### Import Syntax
44
+
45
+ ```jac
46
+ cl import from "./assets/burger.png" { default as burgerImage }
47
+ <img src={burgerImage} />
48
+ ```
49
+
50
+ ### Path Resolution
51
+
52
+ - Relative paths are resolved from the current file location
53
+ - `./assets/burger.png` resolves relative to `app.jac`
54
+ - Vite processes the import during build
55
+ - Assets are optimized and bundled
56
+
57
+ ### Use Cases
58
+
59
+ **Component-Scoped Assets:**
60
+ ```jac
61
+ # In a component file
62
+ cl import from "./images/icon.svg" { default as icon }
63
+ ```
64
+
65
+ **Parent Directory Assets:**
66
+ ```jac
67
+ # Access assets from parent directory
68
+ cl import from "../shared/assets/logo.png" { default as logo }
69
+ ```
70
+
71
+ **Nested Assets:**
72
+ ```jac
73
+ # Assets in subdirectories
74
+ cl import from "./assets/images/hero.jpg" { default as hero }
75
+ ```
76
+
77
+ ### Benefits
78
+
79
+ - **Familiar Syntax**: Standard relative import pattern
80
+ - **Component Organization**: Assets organized by component/feature
81
+ - **Flexibility**: Easy to reorganize without changing alias config
82
+ - **Modular**: Works well with component-based architecture
83
+
84
+ ## Best Practices
85
+
86
+ 1. Use relative imports for component-specific assets
87
+ 2. Organize assets near the components that use them
88
+ 3. Keep relative paths simple and clear
89
+ 4. Use consistent naming conventions
90
+
91
+ Happy coding with Jac! 🍔
@@ -0,0 +1,67 @@
1
+ # Pages
2
+ cl import from react {useState, useEffect}
3
+ cl import ".styles.css";
4
+
5
+ cl {
6
+ def app() -> any {
7
+ let [count, setCount] = useState(0);
8
+ useEffect(lambda -> None {
9
+ console.log("Count: ", count);
10
+ }, [count]);
11
+ return <div style={{padding: "20px", textAlign: "center", fontFamily: "Arial, sans-serif"}}>
12
+ <h1>🍔 Burger Counter App</h1>
13
+ <img
14
+ src="/static/assets/burger.png"
15
+ alt="Delicious Burger"
16
+ style={{
17
+ width: "200px",
18
+ height: "auto",
19
+ margin: "20px 0",
20
+ borderRadius: "10px",
21
+ boxShadow: "0 4px 8px rgba(0,0,0,0.2)"
22
+ }}
23
+ />
24
+ <p style={{fontSize: "18px", margin: "20px 0"}}>
25
+ You've clicked the burger <strong>{count}</strong> times!
26
+ </p>
27
+ <button
28
+ onClick={lambda e: any -> None {setCount(count + 1);}}
29
+ style={{
30
+ padding: "10px 20px",
31
+ fontSize: "16px",
32
+ backgroundColor: "#ff6b35",
33
+ color: "white",
34
+ border: "none",
35
+ borderRadius: "5px",
36
+ cursor: "pointer",
37
+ boxShadow: "0 2px 4px rgba(0,0,0,0.2)"
38
+ }}
39
+ >
40
+ Click the Burger! 🍔
41
+ </button>
42
+
43
+ <h2 style={{marginTop: "40px", marginBottom: "20px"}}>CSS Asset Examples</h2>
44
+
45
+ <div className="container">
46
+ <h3 style={{color: "white", textShadow: "2px 2px 4px rgba(0,0,0,0.5)"}}>
47
+ Background Image Example
48
+ </h3>
49
+ <p style={{color: "white", textShadow: "2px 2px 4px rgba(0,0,0,0.5)"}}>
50
+ This container uses the burger image as a background via CSS
51
+ </p>
52
+ </div>
53
+
54
+ <div className="card">
55
+ <h3>Image in Card</h3>
56
+ <img
57
+ src="/static/assets/burger.png"
58
+ alt="Burger in Card"
59
+ className="burgerImage"
60
+ />
61
+ <p style={{marginTop: "15px", color: "#666"}}>
62
+ This image is displayed within a styled card using CSS classes
63
+ </p>
64
+ </div>
65
+ </div>;
66
+ }
67
+ }
@@ -0,0 +1,28 @@
1
+ {
2
+ "name": "relative-imports",
3
+ "version": "1.0.0",
4
+ "main": "index.js",
5
+ "scripts": {
6
+ "build": "npm run compile && vite build",
7
+ "dev": "vite dev",
8
+ "preview": "vite preview",
9
+ "compile": "babel src --out-dir build --extensions \".jsx,.js\" --out-file-extension .js"
10
+ },
11
+ "keywords": [],
12
+ "author": "",
13
+ "license": "ISC",
14
+ "description": "Jac application: relative-imports",
15
+ "type": "module",
16
+ "devDependencies": {
17
+ "vite": "^6.4.1",
18
+ "@babel/cli": "^7.28.3",
19
+ "@babel/core": "^7.28.5",
20
+ "@babel/preset-env": "^7.28.5",
21
+ "@babel/preset-react": "^7.28.5"
22
+ },
23
+ "dependencies": {
24
+ "react": "^19.2.0",
25
+ "react-dom": "^19.2.0",
26
+ "react-router-dom": "^6.30.1"
27
+ }
28
+ }
@@ -0,0 +1,27 @@
1
+ .container {
2
+ background-image: url('/static/assets/burger.png');
3
+ background-size: cover;
4
+ background-position: center;
5
+ min-height: 300px;
6
+ border-radius: 10px;
7
+ padding: 20px;
8
+ margin: 20px 0;
9
+ }
10
+
11
+ .card {
12
+ background: white;
13
+ border-radius: 10px;
14
+ padding: 20px;
15
+ box-shadow: 0 4px 8px rgba(0,0,0,0.2);
16
+ max-width: 400px;
17
+ margin: 20px auto;
18
+ }
19
+
20
+ .burgerImage {
21
+ width: 200px;
22
+ height: auto;
23
+ border-radius: 10px;
24
+ display: block;
25
+ margin: 0 auto;
26
+ }
27
+
@@ -0,0 +1,29 @@
1
+
2
+ import { defineConfig } from "vite";
3
+ import path from "path";
4
+ import { fileURLToPath } from "url";
5
+
6
+ const __dirname = path.dirname(fileURLToPath(import.meta.url));
7
+
8
+ export default defineConfig({
9
+ root: ".", // base folder
10
+ build: {
11
+ rollupOptions: {
12
+ input: "build/main.js", // your compiled entry file
13
+ output: {
14
+ entryFileNames: "client.[hash].js", // name of the final js file
15
+ assetFileNames: "[name].[ext]",
16
+ },
17
+ },
18
+ outDir: "dist", // final bundled output
19
+ emptyOutDir: true,
20
+ },
21
+ publicDir: false,
22
+ resolve: {
23
+ alias: {
24
+ "@jac-client/utils": path.resolve(__dirname, "src/client_runtime.js"),
25
+ "@jac-client/assets": path.resolve(__dirname, "src/assets"),
26
+ },
27
+ },
28
+ });
29
+
@@ -0,0 +1,9 @@
1
+
2
+ {
3
+ "presets": [[
4
+ "@babel/preset-env",
5
+ {
6
+ "modules": false
7
+ }
8
+ ], "@babel/preset-react"]
9
+ }
@@ -0,0 +1,119 @@
1
+ # Static Path Example
2
+
3
+ This example demonstrates how to serve static assets using direct `/static/` path references.
4
+
5
+ ## Features
6
+
7
+ - Direct path references using `/static/assets/` URLs
8
+ - Simple and straightforward approach
9
+ - No build configuration required
10
+ - Works immediately without imports
11
+
12
+ ## Project Structure
13
+
14
+ ```
15
+ image-asset/
16
+ ├── app.jac # Main application file
17
+ ├── assets/ # Static assets directory
18
+ │ └── burger.png # Burger image
19
+ ├── src/ # Source files (generated)
20
+ ├── build/ # Build output (generated)
21
+ └── dist/ # Distribution output (generated)
22
+ ```
23
+
24
+ ## Running the Example
25
+
26
+ 1. Make sure node modules are installed:
27
+ ```bash
28
+ npm install
29
+ ```
30
+
31
+ 2. Run the Jac server:
32
+ ```bash
33
+ jac serve app.jac
34
+ ```
35
+
36
+ 3. Open your browser and navigate to:
37
+ ```
38
+ http://localhost:8000/page/app
39
+ ```
40
+
41
+ ## How It Works
42
+
43
+ ### Static Path Syntax
44
+
45
+ ```jac
46
+ <img src="/static/assets/burger.png" alt="Burger" />
47
+ ```
48
+
49
+ ### Server Configuration
50
+
51
+ The server automatically serves files from:
52
+ - `dist/` directory (Vite-bundled assets)
53
+ - `assets/` directory (user-provided static assets)
54
+
55
+ Both directories are checked when serving `/static/*` requests.
56
+
57
+ ### Path Resolution
58
+
59
+ 1. Request: `/static/assets/burger.png`
60
+ 2. Server checks `dist/assets/burger.png` first
61
+ 3. If not found, checks `assets/burger.png`
62
+ 4. Serves file with appropriate MIME type
63
+ 5. Sets cache headers for optimal performance
64
+
65
+ ### Benefits
66
+
67
+ - **Simplicity**: No imports or build configuration needed
68
+ - **Immediate**: Works right away without build step
69
+ - **Flexible**: Easy to reference assets from anywhere
70
+ - **Quick Prototyping**: Perfect for rapid development
71
+
72
+ ### Use Cases
73
+
74
+ **Direct Image References:**
75
+ ```jac
76
+ <img src="/static/assets/logo.png" alt="Logo" />
77
+ ```
78
+
79
+ **CSS Background Images:**
80
+ ```jac
81
+ <div style={{backgroundImage: "url('/static/assets/hero.jpg')"}} />
82
+ ```
83
+
84
+ **Dynamic Asset Paths:**
85
+ ```jac
86
+ let imagePath = `/static/assets/${imageName}.png`;
87
+ <img src={imagePath} />
88
+ ```
89
+
90
+ ## Best Practices
91
+
92
+ 1. Use this method for quick prototypes
93
+ 2. Organize assets in the `assets/` folder
94
+ 3. Use descriptive file names
95
+ 4. Keep assets reasonably sized
96
+ 5. Consider using imports for production apps
97
+
98
+ ## Limitations
99
+
100
+ - No automatic optimization
101
+ - No hash-based cache busting
102
+ - Manual cache control required
103
+ - No type safety for asset paths
104
+
105
+ ## When to Use
106
+
107
+ **Choose Static Path if:**
108
+ - Building a quick prototype
109
+ - Assets don't need optimization
110
+ - Want immediate results
111
+ - Working with simple, small assets
112
+
113
+ **Consider Import Methods if:**
114
+ - Building for production
115
+ - Need automatic optimization
116
+ - Want cache busting
117
+ - Prefer type-safe references
118
+
119
+ Happy coding with Jac! 🍔
@@ -0,0 +1,43 @@
1
+ # Pages
2
+ cl import from react {useState, useEffect}
3
+
4
+ cl {
5
+ def app() -> any {
6
+ let [count, setCount] = useState(0);
7
+ useEffect(lambda -> None {
8
+ console.log("Count: ", count);
9
+ }, [count]);
10
+ return <div style={{padding: "20px", textAlign: "center", fontFamily: "Arial, sans-serif"}}>
11
+ <h1>🍔 Burger Counter App</h1>
12
+ <img
13
+ src="/static/assets/burger.png"
14
+ alt="Delicious Burger"
15
+ style={{
16
+ width: "200px",
17
+ height: "auto",
18
+ margin: "20px 0",
19
+ borderRadius: "10px",
20
+ boxShadow: "0 4px 8px rgba(0,0,0,0.2)"
21
+ }}
22
+ />
23
+ <p style={{fontSize: "18px", margin: "20px 0"}}>
24
+ You've clicked the burger <strong>{count}</strong> times!
25
+ </p>
26
+ <button
27
+ onClick={lambda e: any -> None {setCount(count + 1);}}
28
+ style={{
29
+ padding: "10px 20px",
30
+ fontSize: "16px",
31
+ backgroundColor: "#ff6b35",
32
+ color: "white",
33
+ border: "none",
34
+ borderRadius: "5px",
35
+ cursor: "pointer",
36
+ boxShadow: "0 2px 4px rgba(0,0,0,0.2)"
37
+ }}
38
+ >
39
+ Click the Burger! 🍔
40
+ </button>
41
+ </div>;
42
+ }
43
+ }
@@ -0,0 +1,28 @@
1
+ {
2
+ "name": "image-asset",
3
+ "version": "1.0.0",
4
+ "main": "index.js",
5
+ "scripts": {
6
+ "build": "npm run compile && vite build",
7
+ "dev": "vite dev",
8
+ "preview": "vite preview",
9
+ "compile": "babel src --out-dir build --extensions \".jsx,.js\" --out-file-extension .js"
10
+ },
11
+ "keywords": [],
12
+ "author": "",
13
+ "license": "ISC",
14
+ "description": "Jac application: image-asset",
15
+ "type": "module",
16
+ "devDependencies": {
17
+ "vite": "^6.4.1",
18
+ "@babel/cli": "^7.28.3",
19
+ "@babel/core": "^7.28.5",
20
+ "@babel/preset-env": "^7.28.5",
21
+ "@babel/preset-react": "^7.28.5"
22
+ },
23
+ "dependencies": {
24
+ "react": "^19.2.0",
25
+ "react-dom": "^19.2.0",
26
+ "react-router-dom": "^6.30.1"
27
+ }
28
+ }
@@ -0,0 +1,27 @@
1
+ .container {
2
+ background-image: url('/static/assets/burger.png');
3
+ background-size: cover;
4
+ background-position: center;
5
+ min-height: 300px;
6
+ border-radius: 10px;
7
+ padding: 20px;
8
+ margin: 20px 0;
9
+ }
10
+
11
+ .card {
12
+ background: white;
13
+ border-radius: 10px;
14
+ padding: 20px;
15
+ box-shadow: 0 4px 8px rgba(0,0,0,0.2);
16
+ max-width: 400px;
17
+ margin: 20px auto;
18
+ }
19
+
20
+ .burgerImage {
21
+ width: 200px;
22
+ height: auto;
23
+ border-radius: 10px;
24
+ display: block;
25
+ margin: 0 auto;
26
+ }
27
+
@@ -0,0 +1,29 @@
1
+
2
+ import { defineConfig } from "vite";
3
+ import path from "path";
4
+ import { fileURLToPath } from "url";
5
+
6
+ const __dirname = path.dirname(fileURLToPath(import.meta.url));
7
+
8
+ export default defineConfig({
9
+ root: ".", // base folder
10
+ build: {
11
+ rollupOptions: {
12
+ input: "build/main.js", // your compiled entry file
13
+ output: {
14
+ entryFileNames: "client.[hash].js", // name of the final js file
15
+ assetFileNames: "[name].[ext]",
16
+ },
17
+ },
18
+ outDir: "dist", // final bundled output
19
+ emptyOutDir: true,
20
+ },
21
+ publicDir: false,
22
+ resolve: {
23
+ alias: {
24
+ "@jac-client/utils": path.resolve(__dirname, "src/client_runtime.js"),
25
+ "@jac-client/assets": path.resolve(__dirname, "src/assets"),
26
+ },
27
+ },
28
+ });
29
+
@@ -0,0 +1,9 @@
1
+
2
+ {
3
+ "presets": [[
4
+ "@babel/preset-env",
5
+ {
6
+ "modules": false
7
+ }
8
+ ], "@babel/preset-react"]
9
+ }
@@ -0,0 +1,83 @@
1
+ # Import Alias Example
2
+
3
+ This example demonstrates how to import static assets using the `@jac-client/assets` alias pattern.
4
+
5
+ ## Features
6
+
7
+ - Imports image using `@jac-client/assets` alias
8
+ - Vite processes and optimizes the asset
9
+ - Automatic hash generation for cache busting
10
+ - Type-safe asset references
11
+
12
+ ## Project Structure
13
+
14
+ ```
15
+ import-alias/
16
+ ├── app.jac # Main application file
17
+ ├── assets/ # Static assets directory
18
+ │ └── burger.png # Burger image
19
+ ├── src/ # Source files (generated)
20
+ ├── build/ # Build output (generated)
21
+ └── dist/ # Distribution output (generated)
22
+ ```
23
+
24
+ ## Running the Example
25
+
26
+ 1. Make sure node modules are installed:
27
+ ```bash
28
+ npm install
29
+ ```
30
+
31
+ 2. Run the Jac server:
32
+ ```bash
33
+ jac serve app.jac
34
+ ```
35
+
36
+ 3. Open your browser and navigate to:
37
+ ```
38
+ http://localhost:8000/page/app
39
+ ```
40
+
41
+ ## How It Works
42
+
43
+ ### Import Syntax
44
+
45
+ ```jac
46
+ cl import from "@jac-client/assets/burger.png" { default as burgerImage }
47
+ <img src={burgerImage} />
48
+ ```
49
+
50
+ ### Configuration
51
+
52
+ The alias is configured in `vite.config.js`:
53
+
54
+ ```javascript
55
+ resolve: {
56
+ alias: {
57
+ "@jac-client/assets": path.resolve(__dirname, "src/assets"),
58
+ },
59
+ }
60
+ ```
61
+
62
+ ### Build Process
63
+
64
+ 1. Assets from root `assets/` folder are copied to `src/assets/` during build
65
+ 2. Vite processes the import and generates optimized asset URLs
66
+ 3. Assets are bundled with hash-based filenames for cache invalidation
67
+ 4. The imported variable contains the processed asset URL
68
+
69
+ ### Benefits
70
+
71
+ - **Type Safety**: Import errors caught at build time
72
+ - **Optimization**: Vite automatically optimizes assets
73
+ - **Cache Busting**: Hash-based filenames prevent stale cache
74
+ - **Code Splitting**: Assets can be code-split automatically
75
+
76
+ ## Best Practices
77
+
78
+ 1. Use this method for production applications
79
+ 2. Organize assets in the `assets/` folder
80
+ 3. Let Vite handle optimization and caching
81
+ 4. Use descriptive variable names for imported assets
82
+
83
+ Happy coding with Jac! 🍔
@@ -0,0 +1,57 @@
1
+ # Pages
2
+ cl import from react {useState, useEffect}
3
+ # Import image using the @jac-client/assets alias
4
+ cl import from "@jac-client/assets/burger.png" { default as burgerImage }
5
+
6
+ cl {
7
+ def app() -> any {
8
+ let [count, setCount] = useState(0);
9
+ useEffect(lambda -> None {
10
+ console.log("Count: ", count);
11
+ }, [count]);
12
+ return <div style={{padding: "20px", textAlign: "center", fontFamily: "Arial, sans-serif"}}>
13
+ <h1>🍔 Import Alias Example</h1>
14
+ <p style={{color: "#666", marginBottom: "20px"}}>
15
+ Using <code>@jac-client/assets</code> alias to import assets
16
+ </p>
17
+ <img
18
+ src={burgerImage}
19
+ alt="Delicious Burger"
20
+ style={{
21
+ width: "200px",
22
+ height: "auto",
23
+ margin: "20px 0",
24
+ borderRadius: "10px",
25
+ boxShadow: "0 4px 8px rgba(0,0,0,0.2)"
26
+ }}
27
+ />
28
+ <p style={{fontSize: "18px", margin: "20px 0"}}>
29
+ You've clicked the burger <strong>{count}</strong> times!
30
+ </p>
31
+ <button
32
+ onClick={lambda e: any -> None {setCount(count + 1);}}
33
+ style={{
34
+ padding: "10px 20px",
35
+ fontSize: "16px",
36
+ backgroundColor: "#ff6b35",
37
+ color: "white",
38
+ border: "none",
39
+ borderRadius: "5px",
40
+ cursor: "pointer",
41
+ boxShadow: "0 2px 4px rgba(0,0,0,0.2)"
42
+ }}
43
+ >
44
+ Click the Burger! 🍔
45
+ </button>
46
+ <div style={{marginTop: "30px", padding: "15px", backgroundColor: "#f5f5f5", borderRadius: "5px", fontSize: "12px", textAlign: "left", maxWidth: "600px", margin: "30px auto"}}>
47
+ <strong>How it works:</strong>
48
+ <ul style={{marginTop: "10px", paddingLeft: "20px"}}>
49
+ <li>Import using: <code>cl import from '@jac-client/assets/burger.png'</code></li>
50
+ <li>Vite processes the import and generates optimized URLs</li>
51
+ <li>Assets are automatically copied from <code>assets/</code> to <code>src/assets/</code> during build</li>
52
+ <li>Automatic hash generation for cache busting</li>
53
+ </ul>
54
+ </div>
55
+ </div>;
56
+ }
57
+ }