jac-client 0.2.12__py3-none-any.whl → 0.2.14__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 (51) hide show
  1. jac_client/examples/all-in-one/components/Header.jac +1 -1
  2. jac_client/examples/all-in-one/components/ProfitOverview.jac +1 -1
  3. jac_client/examples/all-in-one/components/Summary.jac +1 -1
  4. jac_client/examples/all-in-one/components/TransactionList.jac +2 -2
  5. jac_client/examples/all-in-one/components/navigation.jac +3 -9
  6. jac_client/examples/all-in-one/context/BudgetContext.jac +1 -1
  7. jac_client/examples/all-in-one/main.jac +5 -386
  8. jac_client/examples/all-in-one/pages/(auth)/index.jac +299 -0
  9. jac_client/examples/all-in-one/pages/{nestedDemo.jac → (auth)/nested.jac} +3 -13
  10. jac_client/examples/all-in-one/pages/{loginPage.jac → (public)/login.jac} +1 -1
  11. jac_client/examples/all-in-one/pages/{signupPage.jac → (public)/signup.jac} +1 -1
  12. jac_client/examples/all-in-one/pages/{notFound.jac → [...notFound].jac} +2 -1
  13. jac_client/examples/all-in-one/pages/budget.jac +11 -0
  14. jac_client/examples/all-in-one/pages/budget_planner_ui.cl.jac +1 -1
  15. jac_client/examples/all-in-one/pages/features.jac +8 -0
  16. jac_client/examples/all-in-one/pages/features_test_ui.cl.jac +7 -7
  17. jac_client/examples/all-in-one/pages/{LandingPage.jac → landing.jac} +4 -9
  18. jac_client/examples/all-in-one/pages/layout.jac +20 -0
  19. jac_client/examples/nested-folders/nested-advance/src/ButtonRoot.jac +1 -1
  20. jac_client/examples/nested-folders/nested-advance/src/level1/ButtonSecondL.jac +1 -1
  21. jac_client/examples/nested-folders/nested-advance/src/level1/level2/ButtonThirdL.jac +1 -1
  22. jac_client/plugin/cli.jac +3 -3
  23. jac_client/plugin/client_runtime.cl.jac +7 -4
  24. jac_client/plugin/impl/client_runtime.impl.jac +29 -7
  25. jac_client/plugin/plugin_config.jac +4 -11
  26. jac_client/plugin/src/compiler.jac +19 -1
  27. jac_client/plugin/src/config_loader.jac +1 -0
  28. jac_client/plugin/src/impl/compiler.impl.jac +232 -62
  29. jac_client/plugin/src/impl/config_loader.impl.jac +8 -0
  30. jac_client/plugin/src/impl/package_installer.impl.jac +3 -2
  31. jac_client/plugin/src/impl/route_scanner.impl.jac +201 -0
  32. jac_client/plugin/src/impl/vite_bundler.impl.jac +54 -15
  33. jac_client/plugin/src/route_scanner.jac +44 -0
  34. jac_client/plugin/src/targets/desktop/sidecar/main.py +42 -23
  35. jac_client/plugin/src/targets/desktop_target.jac +4 -2
  36. jac_client/plugin/src/targets/impl/desktop_target.impl.jac +324 -112
  37. jac_client/plugin/src/vite_bundler.jac +18 -3
  38. jac_client/plugin/utils/impl/bun_installer.impl.jac +16 -19
  39. jac_client/plugin/utils/impl/client_deps.impl.jac +12 -16
  40. jac_client/templates/fullstack.jacpack +3 -2
  41. jac_client/tests/test_cli.py +74 -0
  42. jac_client/tests/test_desktop_api_url.py +854 -0
  43. jac_client/tests/test_e2e.py +31 -40
  44. jac_client/tests/test_it.py +209 -11
  45. {jac_client-0.2.12.dist-info → jac_client-0.2.14.dist-info}/METADATA +2 -2
  46. {jac_client-0.2.12.dist-info → jac_client-0.2.14.dist-info}/RECORD +49 -44
  47. jac_client/examples/all-in-one/pages/BudgetPlanner.jac +0 -140
  48. jac_client/examples/all-in-one/pages/FeaturesTest.jac +0 -157
  49. {jac_client-0.2.12.dist-info → jac_client-0.2.14.dist-info}/WHEEL +0 -0
  50. {jac_client-0.2.12.dist-info → jac_client-0.2.14.dist-info}/entry_points.txt +0 -0
  51. {jac_client-0.2.12.dist-info → jac_client-0.2.14.dist-info}/top_level.txt +0 -0
@@ -1,140 +0,0 @@
1
- # Features Test Page - Backend Logic
2
- # This file is intentionally kept empty to demonstrate the separation of concerns
3
- # where UI logic resides in .cl.jac files and backend walker logic in app.jac
4
-
5
- # All walker implementations for this feature are in main.jac
6
- # This demonstrates that you can have separate .jac files for different purposes
7
- # Features Test - Backend Walkers
8
- # This file demonstrates walker functionality for testing various JAC features
9
- import from datetime {
10
- datetime,
11
- timedelta
12
- }
13
-
14
- # Node definition for storing test data
15
- node TestData {
16
- has message: str,
17
- count: int = 0,
18
- created_at: str = "";
19
- }
20
-
21
- # Walker: Create test data
22
- walker create_test_data {
23
- has message: str;
24
-
25
- can create with `root entry {
26
- new_data = here ++> TestData(
27
- message=self.message,
28
- count=1,
29
- created_at=datetime.now().strftime("%Y-%m-%d %H:%M:%S")
30
- );
31
- report new_data;
32
- }
33
- }
34
-
35
- # Walker: Read all test data
36
- walker read_test_data {
37
- can read with `root entry {
38
- visit [-->(`?TestData)];
39
- }
40
-
41
- can report_data with exit {
42
- report here;
43
- }
44
- }
45
-
46
- # Walker: Update test data
47
- walker update_test_data {
48
- has new_message: str;
49
-
50
- can update with TestData entry {
51
- here.message = self.new_message;
52
- here.count = here.count + 1;
53
- report here;
54
- }
55
- }
56
-
57
- # Walker: Delete test data
58
- walker delete_test_data {
59
- can delete with TestData entry {
60
- del here;
61
- report {"status": "deleted"};
62
- }
63
- }
64
-
65
- # Walker: String manipulation test
66
- walker test_string_methods {
67
- has input_text: str;
68
-
69
- can process with `root entry {
70
- result = {
71
- "original": self.input_text,
72
- "uppercase": self.input_text.upper(),
73
- "lowercase": self.input_text.lower(),
74
- "capitalized": self.input_text.capitalize(),
75
- "reversed": self.input_text[::-1],
76
- "length": len(self.input_text),
77
- "words": self.input_text.split(),
78
- "trimmed": self.input_text.strip(),
79
- "replaced": self.input_text.replace("test", "demo")
80
- };
81
- report result;
82
- }
83
- }
84
-
85
- # Walker: Array/List operations test
86
- walker test_list_operations {
87
- has numbers: list;
88
-
89
- can process with `root entry {
90
- result = {
91
- "original": self.numbers,
92
- "sorted": sorted(self.numbers),
93
- "reversed": list(reversed(self.numbers)),
94
- "sum": sum(self.numbers),
95
- "max": max(self.numbers) if len(self.numbers) > 0 else 0,
96
- "min": min(self.numbers) if len(self.numbers) > 0 else 0,
97
- "length": len(self.numbers),
98
- "doubled": [x * 2 for x in self.numbers]
99
- };
100
- report result;
101
- }
102
- }
103
-
104
- # Walker: Complex data processing
105
- walker process_complex_data {
106
- has items: list;
107
-
108
- can process with `root entry {
109
- processed = [];
110
- for item in self.items {
111
- processed.append(
112
- {
113
- "id": item.get("id", 0),
114
- "name": item.get("name", "").upper(),
115
- "value": item.get("value", 0) * 2,
116
- "processed_at": datetime.now().strftime("%H:%M:%S")
117
- }
118
- );
119
- }
120
-
121
- result = {
122
- "original_count": len(self.items),
123
- "processed_count": len(processed),
124
- "items": processed,
125
- "total_value": sum([p["value"] for p in processed])
126
- };
127
-
128
- report result;
129
- }
130
- }
131
-
132
- # Re-export client components from the standalone client module
133
- cl {
134
- import from .budget_planner_ui { BudgetPlanner as BudgetPlannerUI }
135
-
136
- def:pub BudgetPlanner -> any {
137
- return
138
- <BudgetPlannerUI />;
139
- }
140
- }
@@ -1,157 +0,0 @@
1
- # Features Test Page - Backend Logic
2
- # This file is intentionally kept empty to demonstrate the separation of concerns
3
- # where UI logic resides in .cl.jac files and backend walker logic in app.jac
4
-
5
- # All walker implementations for this feature are in main.jac
6
- # This demonstrates that you can have separate .jac files for different purposes
7
- # Features Test - Backend Walkers
8
- # This file demonstrates walker functionality for testing various JAC features
9
- import from datetime {
10
- datetime,
11
- timedelta
12
- }
13
-
14
- # Node definition for storing test data
15
- node TestData {
16
- has message: str,
17
- count: int = 0,
18
- created_at: str = "";
19
- }
20
-
21
- # Walker: Create test data
22
- walker create_test_data {
23
- has message: str;
24
-
25
- can create with `root entry {
26
- new_data = here ++> TestData(
27
- message=self.message,
28
- count=1,
29
- created_at=datetime.now().strftime("%Y-%m-%d %H:%M:%S")
30
- );
31
- report new_data;
32
- }
33
- }
34
-
35
- # Walker: Read all test data
36
- walker read_test_data {
37
- can read with `root entry {
38
- visit [-->(`?TestData)];
39
- }
40
-
41
- can report_data with exit {
42
- report here;
43
- }
44
- }
45
-
46
- # Walker: Update test data
47
- walker update_test_data {
48
- has new_message: str;
49
-
50
- can update with TestData entry {
51
- here.message = self.new_message;
52
- here.count = here.count + 1;
53
- report here;
54
- }
55
- }
56
-
57
- # Walker: Delete test data
58
- walker delete_test_data {
59
- can delete with TestData entry {
60
- del here;
61
- report {"status": "deleted"};
62
- }
63
- }
64
-
65
- # Walker: String manipulation test
66
- walker test_string_methods {
67
- has input_text: str;
68
-
69
- can process with `root entry {
70
- result = {
71
- "original": self.input_text,
72
- "uppercase": self.input_text.upper(),
73
- "lowercase": self.input_text.lower(),
74
- "capitalized": self.input_text.capitalize(),
75
- "reversed": self.input_text[::-1],
76
- "length": len(self.input_text),
77
- "words": self.input_text.split(),
78
- "trimmed": self.input_text.strip(),
79
- "replaced": self.input_text.replace("test", "demo")
80
- };
81
- report result;
82
- }
83
- }
84
-
85
- # Walker: Array/List operations test
86
- walker test_list_operations {
87
- has numbers: list;
88
-
89
- can process with `root entry {
90
- result = {
91
- "original": self.numbers,
92
- "sorted": sorted(self.numbers),
93
- "reversed": list(reversed(self.numbers)),
94
- "sum": sum(self.numbers),
95
- "max": max(self.numbers) if len(self.numbers) > 0 else 0,
96
- "min": min(self.numbers) if len(self.numbers) > 0 else 0,
97
- "length": len(self.numbers),
98
- "doubled": [x * 2 for x in self.numbers]
99
- };
100
- report result;
101
- }
102
- }
103
-
104
- # Walker: Complex data processing
105
- walker process_complex_data {
106
- has items: list;
107
-
108
- can process with `root entry {
109
- processed = [];
110
- for item in self.items {
111
- processed.append(
112
- {
113
- "id": item.get("id", 0),
114
- "name": item.get("name", "").upper(),
115
- "value": item.get("value", 0) * 2,
116
- "processed_at": datetime.now().strftime("%H:%M:%S")
117
- }
118
- );
119
- }
120
-
121
- result = {
122
- "original_count": len(self.items),
123
- "processed_count": len(processed),
124
- "items": processed,
125
- "total_value": sum([p["value"] for p in processed])
126
- };
127
-
128
- report result;
129
- }
130
- }
131
-
132
- # Re-export client components from the standalone client module
133
- cl {
134
- import from .features_test_ui {
135
- FeaturesTest as FeaturesTestUI,
136
- TestButton as TestButtonUI,
137
- TestCard as TestCardUI,
138
- ResultDisplay as ResultDisplayUI
139
- }
140
-
141
- def:pub FeaturesTest -> any {
142
- return
143
- <FeaturesTestUI />;
144
- }
145
- def:pub TestButton(text: str, onClick: any, variant: str) -> any {
146
- return
147
- <TestButtonUI text={text} onClick={onClick} variant={variant} />;
148
- }
149
- def:pub TestCard(title: str, children: any, color: str) -> any {
150
- return
151
- <TestCardUI title={title} children={children} color={color} />;
152
- }
153
- def:pub ResultDisplay(data: any, label: str) -> any {
154
- return
155
- <ResultDisplayUI data={data} label={label} />;
156
- }
157
- }