juxscript 1.1.403 → 1.1.408
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.
- package/dist/components/button.d.ts +1 -0
- package/dist/components/button.d.ts.map +1 -1
- package/dist/components/button.js +37 -0
- package/dist/components/button.js.map +1 -1
- package/dist/components/c.d.ts +53 -0
- package/dist/components/c.d.ts.map +1 -0
- package/dist/components/c.js +127 -0
- package/dist/components/c.js.map +1 -0
- package/dist/components/charts/barChart.d.ts +119 -0
- package/dist/components/charts/barChart.d.ts.map +1 -0
- package/dist/components/charts/barChart.js +644 -0
- package/dist/components/charts/barChart.js.map +1 -0
- package/dist/components/charts/lineChart.d.ts +104 -0
- package/dist/components/charts/lineChart.d.ts.map +1 -0
- package/dist/components/charts/lineChart.js +466 -0
- package/dist/components/charts/lineChart.js.map +1 -0
- package/dist/components/charts/pieChart.d.ts +93 -0
- package/dist/components/charts/pieChart.d.ts.map +1 -0
- package/dist/components/charts/pieChart.js +397 -0
- package/dist/components/charts/pieChart.js.map +1 -0
- package/dist/components/checkbox.d.ts +2 -0
- package/dist/components/checkbox.d.ts.map +1 -1
- package/dist/components/checkbox.js +47 -0
- package/dist/components/checkbox.js.map +1 -1
- package/dist/components/flex.d.ts +91 -0
- package/dist/components/flex.d.ts.map +1 -0
- package/dist/components/flex.js +166 -0
- package/dist/components/flex.js.map +1 -0
- package/dist/components/g.d.ts +21 -0
- package/dist/components/g.d.ts.map +1 -0
- package/dist/components/g.js +52 -0
- package/dist/components/g.js.map +1 -0
- package/dist/components/input.d.ts +2 -0
- package/dist/components/input.d.ts.map +1 -1
- package/dist/components/input.js +21 -2
- package/dist/components/input.js.map +1 -1
- package/dist/components/jtable.d.ts +47 -0
- package/dist/components/jtable.d.ts.map +1 -0
- package/dist/components/jtable.js +307 -0
- package/dist/components/jtable.js.map +1 -0
- package/dist/components/link.d.ts +1 -0
- package/dist/components/link.d.ts.map +1 -1
- package/dist/components/link.js +17 -0
- package/dist/components/link.js.map +1 -1
- package/dist/components/list.d.ts +1 -0
- package/dist/components/list.d.ts.map +1 -1
- package/dist/components/list.js +18 -0
- package/dist/components/list.js.map +1 -1
- package/dist/components/menu.d.ts +108 -0
- package/dist/components/menu.d.ts.map +1 -0
- package/dist/components/menu.js +665 -0
- package/dist/components/menu.js.map +1 -0
- package/dist/components/nav.d.ts +1 -0
- package/dist/components/nav.d.ts.map +1 -1
- package/dist/components/nav.js +19 -0
- package/dist/components/nav.js.map +1 -1
- package/dist/components/radio.d.ts +1 -0
- package/dist/components/radio.d.ts.map +1 -1
- package/dist/components/radio.js +23 -0
- package/dist/components/radio.js.map +1 -1
- package/dist/components/routes.d.ts +17 -0
- package/dist/components/routes.d.ts.map +1 -1
- package/dist/components/routes.js +86 -0
- package/dist/components/routes.js.map +1 -1
- package/dist/components/select.d.ts +1 -0
- package/dist/components/select.d.ts.map +1 -1
- package/dist/components/select.js +17 -0
- package/dist/components/select.js.map +1 -1
- package/dist/components/table.d.ts +1 -0
- package/dist/components/table.d.ts.map +1 -1
- package/dist/components/table.js +20 -0
- package/dist/components/table.js.map +1 -1
- package/dist/components/tabs.d.ts +17 -1
- package/dist/components/tabs.d.ts.map +1 -1
- package/dist/components/tabs.js +50 -8
- package/dist/components/tabs.js.map +1 -1
- package/dist/components/tag.d.ts +1 -0
- package/dist/components/tag.d.ts.map +1 -1
- package/dist/components/tag.js +16 -0
- package/dist/components/tag.js.map +1 -1
- package/dist/components/widgets/calendar.d.ts +74 -0
- package/dist/components/widgets/calendar.d.ts.map +1 -0
- package/dist/components/widgets/calendar.js +308 -0
- package/dist/components/widgets/calendar.js.map +1 -0
- package/dist/components/widgets/canvas-ai.d.ts +12 -0
- package/dist/components/widgets/canvas-ai.d.ts.map +1 -0
- package/dist/components/widgets/canvas-ai.js +97 -0
- package/dist/components/widgets/canvas-ai.js.map +1 -0
- package/dist/components/widgets/canvas-compile.d.ts +36 -0
- package/dist/components/widgets/canvas-compile.d.ts.map +1 -0
- package/dist/components/widgets/canvas-compile.js +379 -0
- package/dist/components/widgets/canvas-compile.js.map +1 -0
- package/dist/components/widgets/canvas-persist.d.ts +11 -0
- package/dist/components/widgets/canvas-persist.d.ts.map +1 -0
- package/dist/components/widgets/canvas-persist.js +60 -0
- package/dist/components/widgets/canvas-persist.js.map +1 -0
- package/dist/components/widgets/canvas-registry.d.ts +42 -0
- package/dist/components/widgets/canvas-registry.d.ts.map +1 -0
- package/dist/components/widgets/canvas-registry.js +338 -0
- package/dist/components/widgets/canvas-registry.js.map +1 -0
- package/dist/components/widgets/canvas-styles.d.ts +2 -0
- package/dist/components/widgets/canvas-styles.d.ts.map +1 -0
- package/dist/components/widgets/canvas-styles.js +215 -0
- package/dist/components/widgets/canvas-styles.js.map +1 -0
- package/dist/components/widgets/canvas.d.ts +125 -0
- package/dist/components/widgets/canvas.d.ts.map +1 -0
- package/dist/components/widgets/canvas.js +1359 -0
- package/dist/components/widgets/canvas.js.map +1 -0
- package/dist/components/widgets/sidebar.d.ts +100 -0
- package/dist/components/widgets/sidebar.d.ts.map +1 -0
- package/dist/components/widgets/sidebar.js +434 -0
- package/dist/components/widgets/sidebar.js.map +1 -0
- package/dist/components/widgets/stepper.d.ts +87 -0
- package/dist/components/widgets/stepper.d.ts.map +1 -0
- package/dist/components/widgets/stepper.js +388 -0
- package/dist/components/widgets/stepper.js.map +1 -0
- package/dist/generated/jux-registry.d.ts +24 -0
- package/dist/generated/jux-registry.d.ts.map +1 -0
- package/dist/generated/jux-registry.js +90 -0
- package/dist/generated/jux-registry.js.map +1 -0
- package/dist/index.d.ts +41 -23
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +39 -23
- package/dist/index.js.map +1 -1
- package/dist/state/pageState.d.ts +6 -0
- package/dist/state/pageState.d.ts.map +1 -1
- package/dist/state/pageState.js +24 -16
- package/dist/state/pageState.js.map +1 -1
- package/dist/styles/layout-regions-observer.d.ts +7 -0
- package/dist/styles/layout-regions-observer.d.ts.map +1 -0
- package/dist/styles/layout-regions-observer.js +52 -0
- package/dist/styles/layout-regions-observer.js.map +1 -0
- package/dist/utils/colors.d.ts +0 -3
- package/dist/utils/colors.d.ts.map +1 -1
- package/dist/utils/colors.js +20 -6
- package/dist/utils/colors.js.map +1 -1
- package/dist/utils/resolveContent.d.ts +11 -0
- package/dist/utils/resolveContent.d.ts.map +1 -0
- package/dist/utils/resolveContent.js +37 -0
- package/dist/utils/resolveContent.js.map +1 -0
- package/dist/utils/theme.d.ts +58 -0
- package/dist/utils/theme.d.ts.map +1 -0
- package/dist/utils/theme.js +172 -0
- package/dist/utils/theme.js.map +1 -0
- package/dist/widgets/canvas.d.ts +3 -94
- package/dist/widgets/canvas.d.ts.map +1 -1
- package/dist/widgets/canvas.js +3 -1007
- package/dist/widgets/canvas.js.map +1 -1
- package/juxconfig.example.js +19 -0
- package/machinery/compiler4.js +103 -9
- package/machinery/errors-client.js +171 -67
- package/machinery/jux-errors.js +218 -0
- package/machinery/serve.js +67 -0
- package/package.json +1 -1
|
@@ -0,0 +1,308 @@
|
|
|
1
|
+
import { pageState } from '../../state/pageState.js';
|
|
2
|
+
import generateId from '../../utils/idgen.js';
|
|
3
|
+
const MONTH_NAMES = ['January', 'February', 'March', 'April', 'May', 'June', 'July', 'August', 'September', 'October', 'November', 'December'];
|
|
4
|
+
const DAY_NAMES_SUN = ['Su', 'Mo', 'Tu', 'We', 'Th', 'Fr', 'Sa'];
|
|
5
|
+
const DAY_NAMES_MON = ['Mo', 'Tu', 'We', 'Th', 'Fr', 'Sa', 'Su'];
|
|
6
|
+
let calendarStylesInjected = false;
|
|
7
|
+
class Calendar {
|
|
8
|
+
constructor(id, options = {}) {
|
|
9
|
+
this._el = null;
|
|
10
|
+
this._onChange = null;
|
|
11
|
+
this.id = id || generateId('cal');
|
|
12
|
+
this._opts = {
|
|
13
|
+
showHeader: options.showHeader ?? true,
|
|
14
|
+
showWeekNumbers: options.showWeekNumbers ?? false,
|
|
15
|
+
firstDayOfWeek: options.firstDayOfWeek ?? 0,
|
|
16
|
+
disabled: options.disabled ?? false,
|
|
17
|
+
...options,
|
|
18
|
+
};
|
|
19
|
+
const now = options.value ? new Date(options.value) : new Date();
|
|
20
|
+
this._viewYear = now.getFullYear();
|
|
21
|
+
this._viewMonth = now.getMonth();
|
|
22
|
+
this._selectedDate = options.value || null;
|
|
23
|
+
if (options.onChange)
|
|
24
|
+
this._onChange = options.onChange;
|
|
25
|
+
}
|
|
26
|
+
// ═══════════════════════════════════════════════════════════
|
|
27
|
+
// FLUENT API
|
|
28
|
+
// ═══════════════════════════════════════════════════════════
|
|
29
|
+
title(val) { this._opts.title = val; return this; }
|
|
30
|
+
subtitle(val) { this._opts.subtitle = val; return this; }
|
|
31
|
+
value(val) { this._selectedDate = val; const d = new Date(val); this._viewYear = d.getFullYear(); this._viewMonth = d.getMonth(); this._rebuild(); return this; }
|
|
32
|
+
min(val) { this._opts.min = val; this._rebuild(); return this; }
|
|
33
|
+
max(val) { this._opts.max = val; this._rebuild(); return this; }
|
|
34
|
+
disabled(val = true) { this._opts.disabled = val; this._rebuild(); return this; }
|
|
35
|
+
style(val) { this._opts.style = val; if (this._el)
|
|
36
|
+
this._el.setAttribute('style', val); return this; }
|
|
37
|
+
class(val) { this._opts.class = val; return this; }
|
|
38
|
+
onChange(fn) { this._onChange = fn; return this; }
|
|
39
|
+
// ═══════════════════════════════════════════════════════════
|
|
40
|
+
// PAGESTATE
|
|
41
|
+
// ═══════════════════════════════════════════════════════════
|
|
42
|
+
getValue() { return this._selectedDate; }
|
|
43
|
+
setValue(val) { return this.value(val); }
|
|
44
|
+
getElement() { return this._el; }
|
|
45
|
+
getTitle() { return this._opts.title || ''; }
|
|
46
|
+
getSubtitle() { return this._opts.subtitle || ''; }
|
|
47
|
+
getDisabled() { return this._opts.disabled; }
|
|
48
|
+
getMin() { return this._opts.min || ''; }
|
|
49
|
+
getMax() { return this._opts.max || ''; }
|
|
50
|
+
getClass() { return this._opts.class || ''; }
|
|
51
|
+
getStyle() { return this._opts.style || ''; }
|
|
52
|
+
setTitle(val) { return this.title(val); }
|
|
53
|
+
setSubtitle(val) { return this.subtitle(val); }
|
|
54
|
+
setDisabled(val) { return this.disabled(val); }
|
|
55
|
+
setMin(val) { return this.min(val); }
|
|
56
|
+
setMax(val) { return this.max(val); }
|
|
57
|
+
setClass(val) { return this.class(val); }
|
|
58
|
+
setStyle(val) { return this.style(val); }
|
|
59
|
+
setContent(val) { return this.value(val); }
|
|
60
|
+
get state() { return pageState[this.id]; }
|
|
61
|
+
// ═══════════════════════════════════════════════════════════
|
|
62
|
+
// NAVIGATION
|
|
63
|
+
// ═══════════════════════════════════════════════════════════
|
|
64
|
+
prevMonth() { this._viewMonth--; if (this._viewMonth < 0) {
|
|
65
|
+
this._viewMonth = 11;
|
|
66
|
+
this._viewYear--;
|
|
67
|
+
} this._rebuild(); return this; }
|
|
68
|
+
nextMonth() { this._viewMonth++; if (this._viewMonth > 11) {
|
|
69
|
+
this._viewMonth = 0;
|
|
70
|
+
this._viewYear++;
|
|
71
|
+
} this._rebuild(); return this; }
|
|
72
|
+
prevYear() { this._viewYear--; this._rebuild(); return this; }
|
|
73
|
+
nextYear() { this._viewYear++; this._rebuild(); return this; }
|
|
74
|
+
today() { const now = new Date(); return this.value(this._toISO(now)); }
|
|
75
|
+
// ═══════════════════════════════════════════════════════════
|
|
76
|
+
// RENDER
|
|
77
|
+
// ═══════════════════════════════════════════════════════════
|
|
78
|
+
render(target) {
|
|
79
|
+
this._injectStyles();
|
|
80
|
+
this._el = this._buildDOM();
|
|
81
|
+
let container = null;
|
|
82
|
+
if (target && typeof target === 'object' && 'element' in target)
|
|
83
|
+
container = target.element;
|
|
84
|
+
else if (target instanceof HTMLElement)
|
|
85
|
+
container = target;
|
|
86
|
+
else if (typeof target === 'string')
|
|
87
|
+
container = document.getElementById(target) || document.querySelector(target);
|
|
88
|
+
else
|
|
89
|
+
container = document.getElementById('app');
|
|
90
|
+
container?.appendChild(this._el);
|
|
91
|
+
return this;
|
|
92
|
+
}
|
|
93
|
+
into(target) { return this.render(target); }
|
|
94
|
+
destroy() {
|
|
95
|
+
pageState.__unregister(this.id);
|
|
96
|
+
this._el?.remove();
|
|
97
|
+
}
|
|
98
|
+
// ═══════════════════════════════════════════════════════════
|
|
99
|
+
// INTERNAL
|
|
100
|
+
// ═══════════════════════════════════════════════════════════
|
|
101
|
+
_rebuild() {
|
|
102
|
+
if (!this._el)
|
|
103
|
+
return;
|
|
104
|
+
const parent = this._el.parentElement;
|
|
105
|
+
if (!parent)
|
|
106
|
+
return;
|
|
107
|
+
const newEl = this._buildDOM();
|
|
108
|
+
parent.replaceChild(newEl, this._el);
|
|
109
|
+
this._el = newEl;
|
|
110
|
+
}
|
|
111
|
+
_toISO(d) {
|
|
112
|
+
return `${d.getFullYear()}-${String(d.getMonth() + 1).padStart(2, '0')}-${String(d.getDate()).padStart(2, '0')}`;
|
|
113
|
+
}
|
|
114
|
+
_isDisabledDate(iso) {
|
|
115
|
+
if (this._opts.disabled)
|
|
116
|
+
return true;
|
|
117
|
+
if (this._opts.min && iso < this._opts.min)
|
|
118
|
+
return true;
|
|
119
|
+
if (this._opts.max && iso > this._opts.max)
|
|
120
|
+
return true;
|
|
121
|
+
return false;
|
|
122
|
+
}
|
|
123
|
+
_getWeekNumber(d) {
|
|
124
|
+
const oneJan = new Date(d.getFullYear(), 0, 1);
|
|
125
|
+
const days = Math.floor((d.getTime() - oneJan.getTime()) / 86400000);
|
|
126
|
+
return Math.ceil((days + oneJan.getDay() + 1) / 7);
|
|
127
|
+
}
|
|
128
|
+
_buildDOM() {
|
|
129
|
+
const { title, subtitle, showHeader, showWeekNumbers, firstDayOfWeek, disabled } = this._opts;
|
|
130
|
+
const id = this.id;
|
|
131
|
+
const wrapper = document.createElement('div');
|
|
132
|
+
wrapper.id = id;
|
|
133
|
+
wrapper.className = `jux-calendar${this._opts.class ? ' ' + this._opts.class : ''}`;
|
|
134
|
+
if (this._opts.style)
|
|
135
|
+
wrapper.setAttribute('style', this._opts.style);
|
|
136
|
+
if (disabled)
|
|
137
|
+
wrapper.setAttribute('data-disabled', 'true');
|
|
138
|
+
// Title/subtitle
|
|
139
|
+
if (title) {
|
|
140
|
+
const t = document.createElement('div');
|
|
141
|
+
t.className = 'jux-calendar-title';
|
|
142
|
+
t.textContent = title;
|
|
143
|
+
wrapper.appendChild(t);
|
|
144
|
+
}
|
|
145
|
+
if (subtitle) {
|
|
146
|
+
const s = document.createElement('div');
|
|
147
|
+
s.className = 'jux-calendar-subtitle';
|
|
148
|
+
s.textContent = subtitle;
|
|
149
|
+
wrapper.appendChild(s);
|
|
150
|
+
}
|
|
151
|
+
// Month nav
|
|
152
|
+
if (showHeader) {
|
|
153
|
+
const nav = document.createElement('div');
|
|
154
|
+
nav.className = 'jux-calendar-nav';
|
|
155
|
+
const prevBtn = document.createElement('button');
|
|
156
|
+
prevBtn.className = 'jux-calendar-nav-btn';
|
|
157
|
+
prevBtn.textContent = '‹';
|
|
158
|
+
prevBtn.addEventListener('click', () => this.prevMonth());
|
|
159
|
+
const label = document.createElement('span');
|
|
160
|
+
label.className = 'jux-calendar-nav-label';
|
|
161
|
+
label.textContent = `${MONTH_NAMES[this._viewMonth]} ${this._viewYear}`;
|
|
162
|
+
const nextBtn = document.createElement('button');
|
|
163
|
+
nextBtn.className = 'jux-calendar-nav-btn';
|
|
164
|
+
nextBtn.textContent = '›';
|
|
165
|
+
nextBtn.addEventListener('click', () => this.nextMonth());
|
|
166
|
+
nav.appendChild(prevBtn);
|
|
167
|
+
nav.appendChild(label);
|
|
168
|
+
nav.appendChild(nextBtn);
|
|
169
|
+
wrapper.appendChild(nav);
|
|
170
|
+
}
|
|
171
|
+
// Grid
|
|
172
|
+
const grid = document.createElement('div');
|
|
173
|
+
grid.className = 'jux-calendar-grid';
|
|
174
|
+
const cols = showWeekNumbers ? 8 : 7;
|
|
175
|
+
grid.style.gridTemplateColumns = showWeekNumbers ? 'auto repeat(7, 1fr)' : 'repeat(7, 1fr)';
|
|
176
|
+
// Day headers
|
|
177
|
+
const dayNames = firstDayOfWeek === 1 ? DAY_NAMES_MON : DAY_NAMES_SUN;
|
|
178
|
+
if (showWeekNumbers) {
|
|
179
|
+
const wk = document.createElement('div');
|
|
180
|
+
wk.className = 'jux-calendar-wk-header';
|
|
181
|
+
wk.textContent = 'Wk';
|
|
182
|
+
grid.appendChild(wk);
|
|
183
|
+
}
|
|
184
|
+
for (const dn of dayNames) {
|
|
185
|
+
const dh = document.createElement('div');
|
|
186
|
+
dh.className = 'jux-calendar-day-header';
|
|
187
|
+
dh.textContent = dn;
|
|
188
|
+
grid.appendChild(dh);
|
|
189
|
+
}
|
|
190
|
+
// Calculate days
|
|
191
|
+
const firstOfMonth = new Date(this._viewYear, this._viewMonth, 1);
|
|
192
|
+
const lastOfMonth = new Date(this._viewYear, this._viewMonth + 1, 0);
|
|
193
|
+
let startDay = firstOfMonth.getDay() - firstDayOfWeek;
|
|
194
|
+
if (startDay < 0)
|
|
195
|
+
startDay += 7;
|
|
196
|
+
const totalDays = lastOfMonth.getDate();
|
|
197
|
+
const todayISO = this._toISO(new Date());
|
|
198
|
+
const prevMonthLast = new Date(this._viewYear, this._viewMonth, 0).getDate();
|
|
199
|
+
let dayNum = 1;
|
|
200
|
+
let nextMonthDay = 1;
|
|
201
|
+
const totalCells = Math.ceil((startDay + totalDays) / 7) * 7;
|
|
202
|
+
for (let i = 0; i < totalCells; i++) {
|
|
203
|
+
// Week number at start of row
|
|
204
|
+
if (showWeekNumbers && i % 7 === 0) {
|
|
205
|
+
let refDate;
|
|
206
|
+
if (i < startDay)
|
|
207
|
+
refDate = new Date(this._viewYear, this._viewMonth, 1);
|
|
208
|
+
else if (dayNum <= totalDays)
|
|
209
|
+
refDate = new Date(this._viewYear, this._viewMonth, dayNum);
|
|
210
|
+
else
|
|
211
|
+
refDate = new Date(this._viewYear, this._viewMonth + 1, nextMonthDay);
|
|
212
|
+
const wk = document.createElement('div');
|
|
213
|
+
wk.className = 'jux-calendar-wk';
|
|
214
|
+
wk.textContent = String(this._getWeekNumber(refDate));
|
|
215
|
+
grid.appendChild(wk);
|
|
216
|
+
}
|
|
217
|
+
const cell = document.createElement('button');
|
|
218
|
+
cell.className = 'jux-calendar-day';
|
|
219
|
+
if (i < startDay) {
|
|
220
|
+
// Previous month
|
|
221
|
+
const d = prevMonthLast - startDay + i + 1;
|
|
222
|
+
cell.textContent = String(d);
|
|
223
|
+
cell.classList.add('jux-calendar-day--outside');
|
|
224
|
+
cell.disabled = true;
|
|
225
|
+
}
|
|
226
|
+
else if (dayNum > totalDays) {
|
|
227
|
+
// Next month
|
|
228
|
+
cell.textContent = String(nextMonthDay);
|
|
229
|
+
cell.classList.add('jux-calendar-day--outside');
|
|
230
|
+
cell.disabled = true;
|
|
231
|
+
nextMonthDay++;
|
|
232
|
+
}
|
|
233
|
+
else {
|
|
234
|
+
const iso = this._toISO(new Date(this._viewYear, this._viewMonth, dayNum));
|
|
235
|
+
cell.textContent = String(dayNum);
|
|
236
|
+
if (iso === todayISO)
|
|
237
|
+
cell.classList.add('jux-calendar-day--today');
|
|
238
|
+
if (iso === this._selectedDate)
|
|
239
|
+
cell.classList.add('jux-calendar-day--selected');
|
|
240
|
+
if (this._isDisabledDate(iso)) {
|
|
241
|
+
cell.disabled = true;
|
|
242
|
+
cell.classList.add('jux-calendar-day--disabled');
|
|
243
|
+
}
|
|
244
|
+
else {
|
|
245
|
+
const capturedISO = iso;
|
|
246
|
+
cell.addEventListener('click', () => {
|
|
247
|
+
this._selectedDate = capturedISO;
|
|
248
|
+
if (this._onChange)
|
|
249
|
+
this._onChange(capturedISO);
|
|
250
|
+
this._el?.dispatchEvent(new Event('change', { bubbles: false }));
|
|
251
|
+
this._rebuild();
|
|
252
|
+
});
|
|
253
|
+
}
|
|
254
|
+
dayNum++;
|
|
255
|
+
}
|
|
256
|
+
grid.appendChild(cell);
|
|
257
|
+
}
|
|
258
|
+
wrapper.appendChild(grid);
|
|
259
|
+
// Today button
|
|
260
|
+
const todayBtn = document.createElement('button');
|
|
261
|
+
todayBtn.className = 'jux-calendar-today-btn';
|
|
262
|
+
todayBtn.textContent = 'Today';
|
|
263
|
+
todayBtn.addEventListener('click', () => this.today());
|
|
264
|
+
wrapper.appendChild(todayBtn);
|
|
265
|
+
return wrapper;
|
|
266
|
+
}
|
|
267
|
+
_injectStyles() {
|
|
268
|
+
if (calendarStylesInjected)
|
|
269
|
+
return;
|
|
270
|
+
calendarStylesInjected = true;
|
|
271
|
+
const s = document.createElement('style');
|
|
272
|
+
s.id = 'jux-calendar-styles';
|
|
273
|
+
s.textContent = `
|
|
274
|
+
.jux-calendar{background:hsl(var(--card,0 0% 100%));border:1px solid hsl(var(--border,220 13% 91%));border-radius:var(--radius,12px);padding:16px;font-family:var(--font-sans,'Google Sans','Inter',system-ui,sans-serif);width:fit-content;box-shadow:0 1px 3px rgba(0,0,0,.04)}
|
|
275
|
+
.jux-calendar-title{font-size:15px;font-weight:600;color:hsl(var(--card-foreground,220 13% 18%));margin-bottom:2px}
|
|
276
|
+
.jux-calendar-subtitle{font-size:12px;color:hsl(var(--muted-foreground,220 9% 46%));margin-bottom:12px}
|
|
277
|
+
.jux-calendar-nav{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
|
|
278
|
+
.jux-calendar-nav-btn{background:none;border:1px solid hsl(var(--border,220 13% 91%));border-radius:var(--radius,12px);width:28px;height:28px;cursor:pointer;font-size:16px;display:flex;align-items:center;justify-content:center;color:hsl(var(--foreground,220 13% 18%));transition:background .15s}
|
|
279
|
+
.jux-calendar-nav-btn:hover{background:hsl(var(--accent,217 91% 97%))}
|
|
280
|
+
.jux-calendar-nav-label{font-size:13px;font-weight:600;color:hsl(var(--foreground,220 13% 18%))}
|
|
281
|
+
.jux-calendar-grid{display:grid;gap:2px}
|
|
282
|
+
.jux-calendar-day-header{text-align:center;font-size:11px;font-weight:500;color:hsl(var(--muted-foreground,220 9% 46%));padding:4px 0}
|
|
283
|
+
.jux-calendar-wk-header{text-align:center;font-size:10px;font-weight:500;color:hsl(var(--muted-foreground,220 9% 46%));padding:4px 2px}
|
|
284
|
+
.jux-calendar-wk{text-align:center;font-size:10px;color:hsl(var(--muted-foreground,220 9% 46%));padding:4px 2px;display:flex;align-items:center;justify-content:center}
|
|
285
|
+
.jux-calendar-day{background:none;border:none;border-radius:var(--radius,12px);width:32px;height:32px;cursor:pointer;font-size:13px;display:flex;align-items:center;justify-content:center;color:hsl(var(--foreground,220 13% 18%));transition:background .15s,color .15s}
|
|
286
|
+
.jux-calendar-day:hover:not(:disabled){background:hsl(var(--accent,217 91% 97%))}
|
|
287
|
+
.jux-calendar-day--outside{color:hsl(var(--muted-foreground,220 9% 46%));opacity:.4;cursor:default}
|
|
288
|
+
.jux-calendar-day--today{font-weight:700;outline:1px solid hsl(var(--primary,217 89% 51%));outline-offset:-1px}
|
|
289
|
+
.jux-calendar-day--selected{background:hsl(var(--primary,217 89% 51%))!important;color:hsl(var(--primary-foreground,0 0% 100%))!important;font-weight:600}
|
|
290
|
+
.jux-calendar-day--disabled{opacity:.3;cursor:not-allowed}
|
|
291
|
+
.jux-calendar-today-btn{display:block;width:100%;margin-top:8px;padding:6px;background:none;border:1px solid hsl(var(--border,220 13% 91%));border-radius:var(--radius,12px);cursor:pointer;font-size:12px;font-weight:500;color:hsl(var(--foreground,220 13% 18%));transition:background .15s}
|
|
292
|
+
.jux-calendar-today-btn:hover{background:hsl(var(--accent,217 91% 97%))}
|
|
293
|
+
[data-disabled=true] .jux-calendar-day{opacity:.4;pointer-events:none}
|
|
294
|
+
`;
|
|
295
|
+
document.head.appendChild(s);
|
|
296
|
+
}
|
|
297
|
+
}
|
|
298
|
+
// ═══════════════════════════════════════════════════════════
|
|
299
|
+
// FACTORY
|
|
300
|
+
// ═══════════════════════════════════════════════════════════
|
|
301
|
+
export function calendar(id, options = {}) {
|
|
302
|
+
const c = new Calendar(id, options);
|
|
303
|
+
pageState.__register(c);
|
|
304
|
+
return c;
|
|
305
|
+
}
|
|
306
|
+
export { Calendar };
|
|
307
|
+
export default calendar;
|
|
308
|
+
//# sourceMappingURL=calendar.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"calendar.js","sourceRoot":"","sources":["../../../lib/components/widgets/calendar.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
export interface AiSuggestRequest {
|
|
2
|
+
prompt: string;
|
|
3
|
+
code: string;
|
|
4
|
+
cursorLine?: number;
|
|
5
|
+
}
|
|
6
|
+
export interface AiSuggestResponse {
|
|
7
|
+
suggestion: string;
|
|
8
|
+
error?: string;
|
|
9
|
+
}
|
|
10
|
+
export declare function getSystemPrompt(): string;
|
|
11
|
+
export declare function aiSuggest(req: AiSuggestRequest): Promise<AiSuggestResponse>;
|
|
12
|
+
//# sourceMappingURL=canvas-ai.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"canvas-ai.d.ts","sourceRoot":"","sources":["../../../lib/components/widgets/canvas-ai.ts"],"names":[],"mappings":"AAgFA,MAAM,WAAW,gBAAgB;IAC7B,MAAM,EAAE,MAAM,CAAC;IACf,IAAI,EAAE,MAAM,CAAC;IACb,UAAU,CAAC,EAAE,MAAM,CAAC;CACvB;AAED,MAAM,WAAW,iBAAiB;IAC9B,UAAU,EAAE,MAAM,CAAC;IACnB,KAAK,CAAC,EAAE,MAAM,CAAC;CAClB;AAID,wBAAgB,eAAe,IAAI,MAAM,CAGxC;AAED,wBAAsB,SAAS,CAAC,GAAG,EAAE,gBAAgB,GAAG,OAAO,CAAC,iBAAiB,CAAC,CAuBjF"}
|
|
@@ -0,0 +1,97 @@
|
|
|
1
|
+
import { COMPONENT_REGISTRY, UTILITY_REGISTRY, LAYOUT_REGISTRY, METHOD_SIGNATURES, LAYOUT_METHODS, } from './canvas-registry.js';
|
|
2
|
+
// ── Build system prompt from live registry data ─────────────────────────
|
|
3
|
+
function buildSystemPrompt() {
|
|
4
|
+
const components = Object.entries(COMPONENT_REGISTRY)
|
|
5
|
+
.map(([name, entry]) => ` jux.${name}${entry.detail} methods: ${entry.methods.join(', ')}`)
|
|
6
|
+
.join('\n');
|
|
7
|
+
const utilities = Object.entries(UTILITY_REGISTRY)
|
|
8
|
+
.map(([name, entry]) => ` jux.${name} — ${entry.detail} methods: ${entry.methods.join(', ')}`)
|
|
9
|
+
.join('\n');
|
|
10
|
+
const layouts = Object.entries(LAYOUT_REGISTRY)
|
|
11
|
+
.map(([name, entry]) => ` ${name}${entry.detail}`)
|
|
12
|
+
.join('\n');
|
|
13
|
+
const methods = Object.entries(METHOD_SIGNATURES)
|
|
14
|
+
.map(([name, sig]) => ` .${sig}`)
|
|
15
|
+
.join('\n');
|
|
16
|
+
const layoutMethods = Object.entries(LAYOUT_METHODS)
|
|
17
|
+
.map(([name, meths]) => ` ${name}: ${meths.join(', ')}`)
|
|
18
|
+
.join('\n');
|
|
19
|
+
return `You are an expert code assistant for the JUX framework — a headless, JavaScript-first UI framework.
|
|
20
|
+
|
|
21
|
+
RULES:
|
|
22
|
+
- All UI is created via jux.* function calls — NO HTML, JSX, or templates.
|
|
23
|
+
- Components render in the order they are called (procedural).
|
|
24
|
+
- Every component supports fluent chaining: jux.comp(id, opts).method().method().render()
|
|
25
|
+
- Reactive state lives in pageState['component-id'].property
|
|
26
|
+
- .render() or .into('target') appends to the DOM.
|
|
27
|
+
- File extension is .jux (plain JavaScript with auto-imported jux and pageState).
|
|
28
|
+
- Return ONLY valid JUX code. No HTML.
|
|
29
|
+
|
|
30
|
+
COMPONENTS:
|
|
31
|
+
${components}
|
|
32
|
+
|
|
33
|
+
UTILITIES:
|
|
34
|
+
${utilities}
|
|
35
|
+
|
|
36
|
+
LAYOUT HELPERS (called without jux. prefix inside .jux files):
|
|
37
|
+
${layouts}
|
|
38
|
+
|
|
39
|
+
LAYOUT METHODS:
|
|
40
|
+
${layoutMethods}
|
|
41
|
+
|
|
42
|
+
METHOD SIGNATURES:
|
|
43
|
+
${methods}
|
|
44
|
+
|
|
45
|
+
PAGESTATE PROPERTIES (pageState['id'].prop):
|
|
46
|
+
value, content, visible, disabled, click, change, focus, hover, class, style
|
|
47
|
+
|
|
48
|
+
EXAMPLE — Form with validation:
|
|
49
|
+
const nameInput = jux.input('name', { label: 'Name' })
|
|
50
|
+
.placeholder('Enter name')
|
|
51
|
+
.onChange((val) => { pageState['save-btn'].disabled = val.length === 0; })
|
|
52
|
+
.render();
|
|
53
|
+
const saveBtn = jux.button('save-btn', { content: 'Save', disabled: true })
|
|
54
|
+
.onClick(() => { console.log(pageState['name'].value); })
|
|
55
|
+
.render();
|
|
56
|
+
|
|
57
|
+
EXAMPLE — Flex layout:
|
|
58
|
+
jux.flexRow('16px').padding('24px').append(
|
|
59
|
+
jux.div('col-a', { content: 'Left' }),
|
|
60
|
+
jux.div('col-b', { content: 'Right' })
|
|
61
|
+
).render();
|
|
62
|
+
|
|
63
|
+
EXAMPLE — Data table:
|
|
64
|
+
jux.table('t', { columns: ['Name','Role'], rows: [['Alice','Admin']] }).render();
|
|
65
|
+
|
|
66
|
+
Respond with concise, valid JUX code. Include brief comments only when helpful.`;
|
|
67
|
+
}
|
|
68
|
+
let _systemPrompt = null;
|
|
69
|
+
export function getSystemPrompt() {
|
|
70
|
+
if (!_systemPrompt)
|
|
71
|
+
_systemPrompt = buildSystemPrompt();
|
|
72
|
+
return _systemPrompt;
|
|
73
|
+
}
|
|
74
|
+
export async function aiSuggest(req) {
|
|
75
|
+
try {
|
|
76
|
+
const res = await fetch('/api/ai/suggest', {
|
|
77
|
+
method: 'POST',
|
|
78
|
+
headers: { 'Content-Type': 'application/json' },
|
|
79
|
+
body: JSON.stringify({
|
|
80
|
+
prompt: req.prompt,
|
|
81
|
+
code: req.code,
|
|
82
|
+
cursorLine: req.cursorLine,
|
|
83
|
+
systemPrompt: getSystemPrompt(),
|
|
84
|
+
}),
|
|
85
|
+
});
|
|
86
|
+
if (!res.ok) {
|
|
87
|
+
const body = await res.json().catch(() => ({ error: res.statusText }));
|
|
88
|
+
return { suggestion: '', error: body.error || `HTTP ${res.status}` };
|
|
89
|
+
}
|
|
90
|
+
const body = await res.json();
|
|
91
|
+
return { suggestion: body.suggestion || '', error: body.error };
|
|
92
|
+
}
|
|
93
|
+
catch (err) {
|
|
94
|
+
return { suggestion: '', error: err.message || 'Network error' };
|
|
95
|
+
}
|
|
96
|
+
}
|
|
97
|
+
//# sourceMappingURL=canvas-ai.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"canvas-ai.js","sourceRoot":"","sources":["../../../lib/components/widgets/canvas-ai.ts"],"names":[],"mappings":"AAAA,OAAO,EACH,kBAAkB,EAAE,gBAAgB,EAAE,eAAe,EACrD,iBAAiB,EAAE,cAAc,GACpC,MAAM,sBAAsB,CAAC;AAE9B,2EAA2E;AAE3E,SAAS,iBAAiB;IACtB,MAAM,UAAU,GAAG,MAAM,CAAC,OAAO,CAAC,kBAAkB,CAAC;SAChD,GAAG,CAAC,CAAC,CAAC,IAAI,EAAE,KAAK,CAAC,EAAE,EAAE,CAAC,SAAS,IAAI,GAAG,KAAK,CAAC,MAAM,cAAc,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC;SAC5F,IAAI,CAAC,IAAI,CAAC,CAAC;IAEhB,MAAM,SAAS,GAAG,MAAM,CAAC,OAAO,CAAC,gBAAgB,CAAC;SAC7C,GAAG,CAAC,CAAC,CAAC,IAAI,EAAE,KAAK,CAAC,EAAE,EAAE,CAAC,SAAS,IAAI,MAAM,KAAK,CAAC,MAAM,cAAc,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC;SAC/F,IAAI,CAAC,IAAI,CAAC,CAAC;IAEhB,MAAM,OAAO,GAAG,MAAM,CAAC,OAAO,CAAC,eAAe,CAAC;SAC1C,GAAG,CAAC,CAAC,CAAC,IAAI,EAAE,KAAK,CAAC,EAAE,EAAE,CAAC,KAAK,IAAI,GAAG,KAAK,CAAC,MAAM,EAAE,CAAC;SAClD,IAAI,CAAC,IAAI,CAAC,CAAC;IAEhB,MAAM,OAAO,GAAG,MAAM,CAAC,OAAO,CAAC,iBAAiB,CAAC;SAC5C,GAAG,CAAC,CAAC,CAAC,IAAI,EAAE,GAAG,CAAC,EAAE,EAAE,CAAC,MAAM,GAAG,EAAE,CAAC;SACjC,IAAI,CAAC,IAAI,CAAC,CAAC;IAEhB,MAAM,aAAa,GAAG,MAAM,CAAC,OAAO,CAAC,cAAc,CAAC;SAC/C,GAAG,CAAC,CAAC,CAAC,IAAI,EAAE,KAAK,CAAC,EAAE,EAAE,CAAC,KAAK,IAAI,KAAK,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC;SACxD,IAAI,CAAC,IAAI,CAAC,CAAC;IAEhB,OAAO;;;;;;;;;;;;EAYT,UAAU;;;EAGV,SAAS;;;EAGT,OAAO;;;EAGP,aAAa;;;EAGb,OAAO;;;;;;;;;;;;;;;;;;;;;;;gFAuBuE,CAAC;AACjF,CAAC;AAeD,IAAI,aAAa,GAAkB,IAAI,CAAC;AAExC,MAAM,UAAU,eAAe;IAC3B,IAAI,CAAC,aAAa;QAAE,aAAa,GAAG,iBAAiB,EAAE,CAAC;IACxD,OAAO,aAAa,CAAC;AACzB,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,SAAS,CAAC,GAAqB;IACjD,IAAI,CAAC;QACD,MAAM,GAAG,GAAG,MAAM,KAAK,CAAC,iBAAiB,EAAE;YACvC,MAAM,EAAE,MAAM;YACd,OAAO,EAAE,EAAE,cAAc,EAAE,kBAAkB,EAAE;YAC/C,IAAI,EAAE,IAAI,CAAC,SAAS,CAAC;gBACjB,MAAM,EAAE,GAAG,CAAC,MAAM;gBAClB,IAAI,EAAE,GAAG,CAAC,IAAI;gBACd,UAAU,EAAE,GAAG,CAAC,UAAU;gBAC1B,YAAY,EAAE,eAAe,EAAE;aAClC,CAAC;SACL,CAAC,CAAC;QAEH,IAAI,CAAC,GAAG,CAAC,EAAE,EAAE,CAAC;YACV,MAAM,IAAI,GAAG,MAAM,GAAG,CAAC,IAAI,EAAE,CAAC,KAAK,CAAC,GAAG,EAAE,CAAC,CAAC,EAAE,KAAK,EAAE,GAAG,CAAC,UAAU,EAAE,CAAC,CAAC,CAAC;YACvE,OAAO,EAAE,UAAU,EAAE,EAAE,EAAE,KAAK,EAAE,IAAI,CAAC,KAAK,IAAI,QAAQ,GAAG,CAAC,MAAM,EAAE,EAAE,CAAC;QACzE,CAAC;QAED,MAAM,IAAI,GAAG,MAAM,GAAG,CAAC,IAAI,EAAE,CAAC;QAC9B,OAAO,EAAE,UAAU,EAAE,IAAI,CAAC,UAAU,IAAI,EAAE,EAAE,KAAK,EAAE,IAAI,CAAC,KAAK,EAAE,CAAC;IACpE,CAAC;IAAC,OAAO,GAAQ,EAAE,CAAC;QAChB,OAAO,EAAE,UAAU,EAAE,EAAE,EAAE,KAAK,EAAE,GAAG,CAAC,OAAO,IAAI,eAAe,EAAE,CAAC;IACrE,CAAC;AACL,CAAC"}
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
export interface CompileResult {
|
|
2
|
+
success: boolean;
|
|
3
|
+
componentCount: number;
|
|
4
|
+
error?: string;
|
|
5
|
+
errorLine?: number;
|
|
6
|
+
errorContext?: string[];
|
|
7
|
+
}
|
|
8
|
+
export interface CanvasRegionTargets {
|
|
9
|
+
sidebarTarget?: HTMLElement;
|
|
10
|
+
sidebarRightTarget?: HTMLElement;
|
|
11
|
+
headerTarget?: HTMLElement;
|
|
12
|
+
footerTarget?: HTMLElement;
|
|
13
|
+
toolbarTarget?: HTMLElement;
|
|
14
|
+
statusbarTarget?: HTMLElement;
|
|
15
|
+
toastTarget?: HTMLElement;
|
|
16
|
+
modalTarget?: HTMLElement;
|
|
17
|
+
drawerTarget?: HTMLElement;
|
|
18
|
+
}
|
|
19
|
+
export declare function splitIntoStatements(lines: string[]): Array<{
|
|
20
|
+
code: string;
|
|
21
|
+
startLine: number;
|
|
22
|
+
}>;
|
|
23
|
+
export declare function runtimeAutowrap(codeStr: string): string;
|
|
24
|
+
/**
|
|
25
|
+
* Convert duplicate const/let declarations in the same scope to plain assignments.
|
|
26
|
+
* Tracks brace depth so block scopes are handled correctly.
|
|
27
|
+
*/
|
|
28
|
+
export declare function deduplicateDeclarations(codeStr: string): string;
|
|
29
|
+
export declare function compileAndRender(codeStr: string, previewEl: HTMLElement, canvasNavigate?: (path: string) => void, contentTarget?: HTMLElement, canvasTabs?: Array<{
|
|
30
|
+
id: string;
|
|
31
|
+
label: string;
|
|
32
|
+
code: string;
|
|
33
|
+
isLayout: boolean;
|
|
34
|
+
route: string;
|
|
35
|
+
}>, regionTargets?: CanvasRegionTargets): CompileResult;
|
|
36
|
+
//# sourceMappingURL=canvas-compile.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"canvas-compile.d.ts","sourceRoot":"","sources":["../../../lib/components/widgets/canvas-compile.ts"],"names":[],"mappings":"AAGA,MAAM,WAAW,aAAa;IAC1B,OAAO,EAAE,OAAO,CAAC;IACjB,cAAc,EAAE,MAAM,CAAC;IACvB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,YAAY,CAAC,EAAE,MAAM,EAAE,CAAC;CAC3B;AAED,MAAM,WAAW,mBAAmB;IAChC,aAAa,CAAC,EAAE,WAAW,CAAC;IAC5B,kBAAkB,CAAC,EAAE,WAAW,CAAC;IACjC,YAAY,CAAC,EAAE,WAAW,CAAC;IAC3B,YAAY,CAAC,EAAE,WAAW,CAAC;IAC3B,aAAa,CAAC,EAAE,WAAW,CAAC;IAC5B,eAAe,CAAC,EAAE,WAAW,CAAC;IAC9B,WAAW,CAAC,EAAE,WAAW,CAAC;IAC1B,WAAW,CAAC,EAAE,WAAW,CAAC;IAC1B,YAAY,CAAC,EAAE,WAAW,CAAC;CAC9B;AAED,wBAAgB,mBAAmB,CAAC,KAAK,EAAE,MAAM,EAAE,GAAG,KAAK,CAAC;IAAE,IAAI,EAAE,MAAM,CAAC;IAAC,SAAS,EAAE,MAAM,CAAA;CAAE,CAAC,CAuB/F;AAED,wBAAgB,eAAe,CAAC,OAAO,EAAE,MAAM,GAAG,MAAM,CAyCvD;AAED;;;GAGG;AACH,wBAAgB,uBAAuB,CAAC,OAAO,EAAE,MAAM,GAAG,MAAM,CA4B/D;AAED,wBAAgB,gBAAgB,CAC5B,OAAO,EAAE,MAAM,EACf,SAAS,EAAE,WAAW,EACtB,cAAc,CAAC,EAAE,CAAC,IAAI,EAAE,MAAM,KAAK,IAAI,EACvC,aAAa,CAAC,EAAE,WAAW,EAC3B,UAAU,CAAC,EAAE,KAAK,CAAC;IAAE,EAAE,EAAE,MAAM,CAAC;IAAC,KAAK,EAAE,MAAM,CAAC;IAAC,IAAI,EAAE,MAAM,CAAC;IAAC,QAAQ,EAAE,OAAO,CAAC;IAAC,KAAK,EAAE,MAAM,CAAA;CAAE,CAAC,EACjG,aAAa,CAAC,EAAE,mBAAmB,GACpC,aAAa,CAmQf"}
|