x4js 2.0.7 → 2.0.9
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/lib/cjs/x4.js +1 -1
- package/lib/esm/x4.mjs +1 -1
- package/lib/output.d.ts +1472 -0
- package/lib/src/components/boxes/boxes.ts +1 -1
- package/lib/src/components/btngroup/btngroup.ts +7 -11
- package/lib/src/components/button/button.ts +3 -3
- package/lib/src/components/calendar/calendar.ts +6 -6
- package/lib/src/components/checkbox/checkbox.ts +3 -3
- package/lib/src/components/colorinput/colorinput.ts +3 -3
- package/lib/src/components/colorpicker/colorpicker.ts +3 -3
- package/lib/src/components/combobox/combobox.ts +1 -1
- package/lib/src/components/dialog/dialog.ts +3 -2
- package/lib/src/components/header/header.ts +1 -1
- package/lib/src/components/icon/icon.ts +1 -1
- package/lib/src/components/image/image.ts +1 -1
- package/lib/src/components/input/input.ts +2 -2
- package/lib/src/components/label/label.ts +2 -2
- package/lib/src/components/listbox/listbox.ts +1 -1
- package/lib/src/components/menu/menu.ts +3 -3
- package/lib/src/components/messages/messages.ts +2 -2
- package/lib/src/components/notification/notification.ts +2 -2
- package/lib/src/components/panel/panel.ts +2 -2
- package/lib/src/components/popup/popup.ts +2 -2
- package/lib/src/components/progress/progress.ts +1 -1
- package/lib/src/components/rating/rating.ts +2 -2
- package/lib/src/components/sizers/sizer.ts +2 -2
- package/lib/src/components/slider/slider.ts +2 -2
- package/lib/src/components/switch/switch.ts +1 -1
- package/lib/src/components/tabs/tabs.ts +2 -2
- package/lib/src/components/textarea/textarea.ts +1 -1
- package/lib/src/components/textedit/textedit.ts +2 -2
- package/lib/src/components/tooltips/tooltips.ts +2 -2
- package/lib/src/components/treeview/treeview.ts +1 -1
- package/lib/src/components/viewport/viewport.ts +1 -1
- package/lib/src/core/component.ts +1 -1
- package/lib/src/core/core_styles.ts +0 -1
- package/lib/src/types/svg.d.ts +1 -0
- package/lib/src/types/x4react.d.ts +9 -0
- package/lib/types/x4.d.ts +6144 -178
- package/package.json +6 -1
- package/build/x4.css +0 -1
- package/build/x4.js +0 -1
- package/scripts/build.mjs +0 -362
- package/scripts/prepack.mjs +0 -51
- package/src/components/base.scss +0 -26
- package/src/components/boxes/boxes.module.scss +0 -37
- package/src/components/boxes/boxes.ts +0 -125
- package/src/components/btngroup/btngroup.module.scss +0 -29
- package/src/components/btngroup/btngroup.ts +0 -106
- package/src/components/button/button.module.scss +0 -154
- package/src/components/button/button.ts +0 -117
- package/src/components/calendar/calendar-check-sharp-light.svg +0 -1
- package/src/components/calendar/calendar.module.scss +0 -163
- package/src/components/calendar/calendar.ts +0 -326
- package/src/components/calendar/chevron-left-sharp-light.svg +0 -1
- package/src/components/calendar/chevron-right-sharp-light.svg +0 -1
- package/src/components/checkbox/check.svg +0 -4
- package/src/components/checkbox/checkbox.module.scss +0 -142
- package/src/components/checkbox/checkbox.ts +0 -125
- package/src/components/colorinput/colorinput.module.scss +0 -65
- package/src/components/colorinput/colorinput.ts +0 -88
- package/src/components/colorinput/crosshairs-simple-sharp-light.svg +0 -1
- package/src/components/colorpicker/colorpicker.module.scss +0 -133
- package/src/components/colorpicker/colorpicker.ts +0 -477
- package/src/components/combobox/combobox.module.scss +0 -121
- package/src/components/combobox/combobox.ts +0 -190
- package/src/components/combobox/updown.svg +0 -4
- package/src/components/dialog/dialog.module.scss +0 -71
- package/src/components/dialog/dialog.ts +0 -91
- package/src/components/dialog/xmark-sharp-light.svg +0 -1
- package/src/components/form/form.module.scss +0 -34
- package/src/components/form/form.ts +0 -36
- package/src/components/header/header.module.scss +0 -40
- package/src/components/header/header.ts +0 -124
- package/src/components/icon/icon.module.scss +0 -30
- package/src/components/icon/icon.ts +0 -134
- package/src/components/image/image.module.scss +0 -21
- package/src/components/image/image.ts +0 -67
- package/src/components/input/input.module.scss +0 -69
- package/src/components/input/input.ts +0 -274
- package/src/components/label/label.module.scss +0 -52
- package/src/components/label/label.ts +0 -55
- package/src/components/listbox/listbox.module.scss +0 -103
- package/src/components/listbox/listbox.ts +0 -427
- package/src/components/menu/caret-right-solid.svg +0 -1
- package/src/components/menu/menu.module.scss +0 -108
- package/src/components/menu/menu.ts +0 -168
- package/src/components/messages/circle-exclamation.svg +0 -1
- package/src/components/messages/messages.module.scss +0 -47
- package/src/components/messages/messages.ts +0 -64
- package/src/components/normalize.scss +0 -386
- package/src/components/notification/circle-check-solid.svg +0 -1
- package/src/components/notification/circle-exclamation-solid.svg +0 -1
- package/src/components/notification/circle-notch-light.svg +0 -1
- package/src/components/notification/notification.module.scss +0 -82
- package/src/components/notification/notification.ts +0 -108
- package/src/components/notification/xmark-sharp-light.svg +0 -1
- package/src/components/panel/panel.module.scss +0 -48
- package/src/components/panel/panel.ts +0 -57
- package/src/components/popup/popup.module.scss +0 -43
- package/src/components/popup/popup.ts +0 -395
- package/src/components/progress/progress.module.scss +0 -57
- package/src/components/progress/progress.ts +0 -43
- package/src/components/rating/rating.module.scss +0 -23
- package/src/components/rating/rating.ts +0 -125
- package/src/components/rating/star-sharp-light.svg +0 -1
- package/src/components/rating/star-sharp-solid.svg +0 -1
- package/src/components/shared.scss +0 -76
- package/src/components/sizers/sizer.module.scss +0 -90
- package/src/components/sizers/sizer.ts +0 -120
- package/src/components/slider/slider.module.scss +0 -71
- package/src/components/slider/slider.ts +0 -143
- package/src/components/switch/switch.module.scss +0 -127
- package/src/components/switch/switch.ts +0 -56
- package/src/components/tabs/tabs.module.scss +0 -46
- package/src/components/tabs/tabs.ts +0 -157
- package/src/components/textarea/textarea.module.scss +0 -59
- package/src/components/textarea/textarea.ts +0 -54
- package/src/components/textedit/textedit.module.scss +0 -114
- package/src/components/textedit/textedit.ts +0 -82
- package/src/components/themes.scss +0 -77
- package/src/components/tooltips/circle-info-sharp-light.svg +0 -1
- package/src/components/tooltips/tooltips.scss +0 -51
- package/src/components/tooltips/tooltips.ts +0 -103
- package/src/components/treeview/chevron-down-light.svg +0 -1
- package/src/components/treeview/treeview.module.scss +0 -116
- package/src/components/treeview/treeview.ts +0 -403
- package/src/components/viewport/viewport.module.scss +0 -25
- package/src/components/viewport/viewport.ts +0 -38
- package/src/core/component.ts +0 -979
- package/src/core/core_colors.ts +0 -250
- package/src/core/core_dom.ts +0 -471
- package/src/core/core_dragdrop.ts +0 -201
- package/src/core/core_element.ts +0 -98
- package/src/core/core_events.ts +0 -149
- package/src/core/core_i18n.ts +0 -377
- package/src/core/core_router.ts +0 -221
- package/src/core/core_styles.ts +0 -215
- package/src/core/core_svg.ts +0 -550
- package/src/core/core_tools.ts +0 -673
- package/src/demo/assets/house-light.svg +0 -1
- package/src/demo/assets/radio.svg +0 -4
- package/src/demo/index.html +0 -12
- package/src/demo/main.scss +0 -21
- package/src/demo/main.tsx +0 -323
- package/src/x4.scss +0 -19
- package/tsconfig.json +0 -14
- package/types/svg.d.ts +0 -4
- package/types/x4react.d.ts +0 -9
- /package/{types → lib/src/types}/scss.d.ts +0 -0
|
@@ -1,326 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* ___ ___ __
|
|
3
|
-
* \ \/ / / _
|
|
4
|
-
* \ / /_| |_
|
|
5
|
-
* / \____ _|
|
|
6
|
-
* /__/\__\ |_|
|
|
7
|
-
*
|
|
8
|
-
* @file calendar.ts
|
|
9
|
-
* @author Etienne Cochard
|
|
10
|
-
*
|
|
11
|
-
* @copyright (c) 2024 R-libre ingenierie
|
|
12
|
-
*
|
|
13
|
-
* Use of this source code is governed by an MIT-style license
|
|
14
|
-
* that can be found in the LICENSE file or at https://opensource.org/licenses/MIT.
|
|
15
|
-
**/
|
|
16
|
-
|
|
17
|
-
import { Component, ComponentEvents, ComponentProps, EvChange, Flex } from '@core/component'
|
|
18
|
-
import { date_clone, date_hash, formatIntlDate, Point, unsafeHtml } from "@core/core_tools"
|
|
19
|
-
import { _tr } from '@core/core_i18n';
|
|
20
|
-
import { EventCallback } from '@core/core_events.js';
|
|
21
|
-
|
|
22
|
-
import { Button } from '../button/button';
|
|
23
|
-
import { Popup } from '../popup/popup';
|
|
24
|
-
import { Label } from '../label/label';
|
|
25
|
-
import { HBox, VBox } from '../boxes/boxes'
|
|
26
|
-
import { Menu, MenuItem } from '../menu/menu';
|
|
27
|
-
|
|
28
|
-
import "./calendar.module.scss"
|
|
29
|
-
import icon_prev from "./chevron-left-sharp-light.svg";
|
|
30
|
-
import icon_today from "./calendar-check-sharp-light.svg";
|
|
31
|
-
import icon_next from "./chevron-right-sharp-light.svg";
|
|
32
|
-
|
|
33
|
-
interface CalendarEventMap extends ComponentEvents {
|
|
34
|
-
change?: EvChange;
|
|
35
|
-
}
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
interface CalendarProps extends ComponentProps {
|
|
39
|
-
date?: Date; // initial date to display
|
|
40
|
-
minDate?: Date; // minimal date before the user cannot go
|
|
41
|
-
maxDate?: Date; // maximal date after the user cannot go
|
|
42
|
-
|
|
43
|
-
change?: EventCallback<EvChange>; // shortcut to events: { change: ... }
|
|
44
|
-
}
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
/**
|
|
48
|
-
* default calendar control
|
|
49
|
-
*
|
|
50
|
-
* fires:
|
|
51
|
-
* EventChange ( value = Date )
|
|
52
|
-
*/
|
|
53
|
-
|
|
54
|
-
export class Calendar extends VBox<CalendarProps, CalendarEventMap>
|
|
55
|
-
{
|
|
56
|
-
private m_date: Date;
|
|
57
|
-
|
|
58
|
-
constructor(props: CalendarProps) {
|
|
59
|
-
super(props);
|
|
60
|
-
|
|
61
|
-
this.mapPropEvents( props, 'change' );
|
|
62
|
-
this.m_date = props.date ? date_clone( props.date ) : new Date();
|
|
63
|
-
|
|
64
|
-
this._update( );
|
|
65
|
-
}
|
|
66
|
-
|
|
67
|
-
/** @ignore */
|
|
68
|
-
|
|
69
|
-
private _update( ) {
|
|
70
|
-
|
|
71
|
-
let month_start = date_clone(this.m_date);
|
|
72
|
-
month_start.setDate(1);
|
|
73
|
-
|
|
74
|
-
let day = month_start.getDay();
|
|
75
|
-
if (day == 0) {
|
|
76
|
-
day = 7;
|
|
77
|
-
}
|
|
78
|
-
|
|
79
|
-
month_start.setDate(-day + 1 + 1);
|
|
80
|
-
let dte = date_clone(month_start);
|
|
81
|
-
|
|
82
|
-
let selection = date_hash( this.m_date );
|
|
83
|
-
let today = date_hash( new Date() );
|
|
84
|
-
|
|
85
|
-
let month_end = date_clone(this.m_date);
|
|
86
|
-
month_end.setDate(1);
|
|
87
|
-
month_end.setMonth(month_end.getMonth() + 1);
|
|
88
|
-
month_end.setDate(0);
|
|
89
|
-
|
|
90
|
-
let end_of_month = date_hash(month_end);
|
|
91
|
-
|
|
92
|
-
let rows: HBox[] = [];
|
|
93
|
-
|
|
94
|
-
// month selector
|
|
95
|
-
let header = new HBox({
|
|
96
|
-
cls: 'month-sel',
|
|
97
|
-
content: [
|
|
98
|
-
new Label({
|
|
99
|
-
cls: 'month',
|
|
100
|
-
text: formatIntlDate(this.m_date, 'O'),
|
|
101
|
-
dom_events: {
|
|
102
|
-
click: () => this._choose('month')
|
|
103
|
-
}
|
|
104
|
-
}),
|
|
105
|
-
new Label({
|
|
106
|
-
cls: 'year',
|
|
107
|
-
text: formatIntlDate(this.m_date, 'Y'),
|
|
108
|
-
dom_events: {
|
|
109
|
-
click: () => this._choose('year')
|
|
110
|
-
}
|
|
111
|
-
}),
|
|
112
|
-
new Flex( ),
|
|
113
|
-
new Button({ icon: icon_prev, click: () => this._next(false) } ),
|
|
114
|
-
new Button({ icon: icon_today, click: () => this.setDate(new Date()), tooltip: _tr.global.today } ),
|
|
115
|
-
new Button({ icon: icon_next, click: () => this._next(true) } )
|
|
116
|
-
]
|
|
117
|
-
});
|
|
118
|
-
|
|
119
|
-
rows.push(header);
|
|
120
|
-
|
|
121
|
-
// calendar part
|
|
122
|
-
let day_names = [];
|
|
123
|
-
|
|
124
|
-
// day names
|
|
125
|
-
// empty week num
|
|
126
|
-
day_names.push(new HBox({
|
|
127
|
-
cls: 'weeknum cell',
|
|
128
|
-
}));
|
|
129
|
-
|
|
130
|
-
for (let d = 0; d < 7; d++) {
|
|
131
|
-
day_names.push(new Label({
|
|
132
|
-
cls: 'cell',
|
|
133
|
-
text: _tr.global.day_short[(d + 1) % 7]
|
|
134
|
-
}));
|
|
135
|
-
}
|
|
136
|
-
|
|
137
|
-
rows.push(new HBox({
|
|
138
|
-
cls: 'week header',
|
|
139
|
-
content: day_names
|
|
140
|
-
}));
|
|
141
|
-
|
|
142
|
-
let cmonth = this.m_date.getMonth();
|
|
143
|
-
|
|
144
|
-
// weeks
|
|
145
|
-
let first = true;
|
|
146
|
-
while (date_hash(dte) <= end_of_month) {
|
|
147
|
-
|
|
148
|
-
let days = [
|
|
149
|
-
new HBox({ cls: 'weeknum cell', content: new Component({ tag: 'span', content: formatIntlDate(dte, 'w') }) })
|
|
150
|
-
];
|
|
151
|
-
|
|
152
|
-
// days
|
|
153
|
-
for (let d = 0; d < 7; d++) {
|
|
154
|
-
|
|
155
|
-
let cls = 'cell day';
|
|
156
|
-
if (date_hash(dte) == selection) {
|
|
157
|
-
cls += ' selection';
|
|
158
|
-
}
|
|
159
|
-
|
|
160
|
-
if (date_hash(dte) == today) {
|
|
161
|
-
cls += ' today';
|
|
162
|
-
}
|
|
163
|
-
|
|
164
|
-
if (dte.getMonth() != cmonth) {
|
|
165
|
-
cls += ' out';
|
|
166
|
-
}
|
|
167
|
-
|
|
168
|
-
const mkItem = ( dte: Date ) => {
|
|
169
|
-
return new HBox({
|
|
170
|
-
cls,
|
|
171
|
-
flex: 1,
|
|
172
|
-
content: new Component({
|
|
173
|
-
cls: "text",
|
|
174
|
-
content: unsafeHtml( `<span>${formatIntlDate(dte, 'd')}</span>` ),
|
|
175
|
-
}),
|
|
176
|
-
dom_events: {
|
|
177
|
-
click: () => this.select(dte)
|
|
178
|
-
}
|
|
179
|
-
})
|
|
180
|
-
}
|
|
181
|
-
|
|
182
|
-
days.push( mkItem( date_clone( dte ) ) );
|
|
183
|
-
|
|
184
|
-
dte.setDate(dte.getDate() + 1);
|
|
185
|
-
first = false;
|
|
186
|
-
}
|
|
187
|
-
|
|
188
|
-
rows.push(new HBox({
|
|
189
|
-
cls: 'week',
|
|
190
|
-
flex: 1,
|
|
191
|
-
content: days
|
|
192
|
-
}));
|
|
193
|
-
}
|
|
194
|
-
|
|
195
|
-
this.setContent(rows);
|
|
196
|
-
}
|
|
197
|
-
|
|
198
|
-
/**
|
|
199
|
-
* select the given date
|
|
200
|
-
* @param date
|
|
201
|
-
*/
|
|
202
|
-
|
|
203
|
-
private select(date: Date) {
|
|
204
|
-
this.m_date = date;
|
|
205
|
-
this.fire('change', {value:date} );
|
|
206
|
-
this._update();
|
|
207
|
-
}
|
|
208
|
-
|
|
209
|
-
/**
|
|
210
|
-
*
|
|
211
|
-
*/
|
|
212
|
-
|
|
213
|
-
private _next(n: boolean) {
|
|
214
|
-
this.m_date.setMonth(this.m_date.getMonth() + (n ? 1 : -1));
|
|
215
|
-
this._update();
|
|
216
|
-
}
|
|
217
|
-
|
|
218
|
-
/**
|
|
219
|
-
*
|
|
220
|
-
*/
|
|
221
|
-
|
|
222
|
-
private _choose(type: 'month' | 'year') {
|
|
223
|
-
|
|
224
|
-
let items: MenuItem[] = [];
|
|
225
|
-
|
|
226
|
-
if (type == 'month') {
|
|
227
|
-
for (let m = 0; m < 12; m++) {
|
|
228
|
-
items.push(({
|
|
229
|
-
text: _tr.global.month_long[m],
|
|
230
|
-
click: () => { this.m_date.setMonth(m); this._update(); }
|
|
231
|
-
}));
|
|
232
|
-
}
|
|
233
|
-
}
|
|
234
|
-
else if (type == 'year') {
|
|
235
|
-
|
|
236
|
-
let min = this.props.minDate?.getFullYear() ?? 1900;
|
|
237
|
-
let max = this.props.maxDate?.getFullYear() ?? 2037;
|
|
238
|
-
|
|
239
|
-
for (let m = max; m >= min; m--) {
|
|
240
|
-
items.push({
|
|
241
|
-
text: '' + m,
|
|
242
|
-
click: () => { this.m_date.setFullYear(m); this._update(); }
|
|
243
|
-
});
|
|
244
|
-
}
|
|
245
|
-
}
|
|
246
|
-
|
|
247
|
-
let menu = new Menu({
|
|
248
|
-
items
|
|
249
|
-
});
|
|
250
|
-
|
|
251
|
-
let rc = this.getBoundingRect();
|
|
252
|
-
menu.displayAt(rc.left, rc.top);
|
|
253
|
-
}
|
|
254
|
-
|
|
255
|
-
getDate() {
|
|
256
|
-
return this.m_date;
|
|
257
|
-
}
|
|
258
|
-
|
|
259
|
-
setDate(date: Date) {
|
|
260
|
-
this.m_date = date;
|
|
261
|
-
this._update();
|
|
262
|
-
}
|
|
263
|
-
}
|
|
264
|
-
|
|
265
|
-
|
|
266
|
-
|
|
267
|
-
|
|
268
|
-
/**
|
|
269
|
-
* default popup calendar
|
|
270
|
-
* /
|
|
271
|
-
|
|
272
|
-
export class PopupCalendar extends Popup {
|
|
273
|
-
|
|
274
|
-
m_cal: Calendar;
|
|
275
|
-
|
|
276
|
-
constructor(props: CalendarProps) {
|
|
277
|
-
super({ tabIndex: 1 });
|
|
278
|
-
|
|
279
|
-
this.enableMask(false);
|
|
280
|
-
|
|
281
|
-
this.m_cal = new Calendar(props);
|
|
282
|
-
this.m_cal.addClass('@fit');
|
|
283
|
-
|
|
284
|
-
this.setContent(this.m_cal);
|
|
285
|
-
}
|
|
286
|
-
|
|
287
|
-
// binded
|
|
288
|
-
private _handleClick = (e: MouseEvent) => {
|
|
289
|
-
if (!this.dom) {
|
|
290
|
-
return;
|
|
291
|
-
}
|
|
292
|
-
|
|
293
|
-
let newfocus = <HTMLElement>e.target;
|
|
294
|
-
|
|
295
|
-
// child of this: ok
|
|
296
|
-
if (this.dom.contains(newfocus)) {
|
|
297
|
-
return;
|
|
298
|
-
}
|
|
299
|
-
|
|
300
|
-
// menu: ok
|
|
301
|
-
let dest = Component.getElement(newfocus, MenuItem);
|
|
302
|
-
if (dest) {
|
|
303
|
-
return;
|
|
304
|
-
}
|
|
305
|
-
|
|
306
|
-
this.close();
|
|
307
|
-
}
|
|
308
|
-
|
|
309
|
-
/ ** @ignore * /
|
|
310
|
-
show(modal?: boolean, at?: Point ) {
|
|
311
|
-
x4document.addEventListener('mousedown', this._handleClick);
|
|
312
|
-
if( at ) {
|
|
313
|
-
super.displayAt( at.x, at.y, 'top left', undefined, modal );
|
|
314
|
-
}
|
|
315
|
-
else {
|
|
316
|
-
super.show(modal);
|
|
317
|
-
}
|
|
318
|
-
}
|
|
319
|
-
|
|
320
|
-
/ ** @ignore * /
|
|
321
|
-
close() {
|
|
322
|
-
x4document.removeEventListener('mousedown', this._handleClick);
|
|
323
|
-
super.close();
|
|
324
|
-
}
|
|
325
|
-
}
|
|
326
|
-
*/
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 320 512" fill="currentColor"><!--!Font Awesome Pro 6.6.0 by @fontawesome - https://fontawesome.com License - https://fontawesome.com/license (Commercial License) Copyright 2024 Fonticons, Inc.--><path d="M9.4 256l11.3-11.3 192-192L224 41.4 246.6 64 235.3 75.3 54.6 256 235.3 436.7 246.6 448 224 470.6l-11.3-11.3-192-192L9.4 256z"/></svg>
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 320 512" fill="currentColor"><!--!Font Awesome Pro 6.6.0 by @fontawesome - https://fontawesome.com License - https://fontawesome.com/license (Commercial License) Copyright 2024 Fonticons, Inc.--><path d="M310.6 256l-11.3 11.3-192 192L96 470.6 73.4 448l11.3-11.3L265.4 256 84.7 75.3 73.4 64 96 41.4l11.3 11.3 192 192L310.6 256z"/></svg>
|
|
@@ -1,4 +0,0 @@
|
|
|
1
|
-
<svg viewBox="0 0 10 7" fill="none" xmlns="http://www.w3.org/2000/svg" aria-hidden="true">
|
|
2
|
-
<path d="M4 4.586L1.707 2.293A1 1 0 1 0 .293 3.707l3 3a.997.997 0 0 0 1.414 0l5-5A1 1 0 1 0 8.293.293L4 4.586z" fill="currentColor" fill-rule="evenodd" clip-rule="evenodd">
|
|
3
|
-
</path>
|
|
4
|
-
</svg>
|
|
@@ -1,142 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* ___ ___ __
|
|
3
|
-
* \ \/ / / _
|
|
4
|
-
* \ / /_| |_
|
|
5
|
-
* / \____ _|
|
|
6
|
-
* /__/\__\ |_|
|
|
7
|
-
*
|
|
8
|
-
* @file checkbox.module.scss
|
|
9
|
-
* @author Etienne Cochard
|
|
10
|
-
*
|
|
11
|
-
* @copyright (c) 2024 R-libre ingenierie
|
|
12
|
-
*
|
|
13
|
-
* Use of this source code is governed by an MIT-style license
|
|
14
|
-
* that can be found in the LICENSE file or at https://opensource.org/licenses/MIT.
|
|
15
|
-
**/
|
|
16
|
-
|
|
17
|
-
@use "../shared.scss";
|
|
18
|
-
|
|
19
|
-
:root {
|
|
20
|
-
--checkbox-background-check: var( --accent-background );
|
|
21
|
-
--checkbox-background-check-hover: var( --accent-background-hover );
|
|
22
|
-
--checkbox-background-disabled: var( --disabled-color );
|
|
23
|
-
--checkbox-background-disabled-check: var( --disabled-background );
|
|
24
|
-
--checkbox-color-disabled: var( --disabled-background );
|
|
25
|
-
--checkbox-check-border: var( --border );
|
|
26
|
-
--checkbox-check-border-hover: var( --border-hover );
|
|
27
|
-
}
|
|
28
|
-
|
|
29
|
-
.x4checkbox {
|
|
30
|
-
@extend .hbox;
|
|
31
|
-
|
|
32
|
-
display: flex;
|
|
33
|
-
flex-direction: row;
|
|
34
|
-
align-items: center;
|
|
35
|
-
|
|
36
|
-
margin: 5px;
|
|
37
|
-
padding: 4px;
|
|
38
|
-
gap: 4px;
|
|
39
|
-
cursor: pointer;
|
|
40
|
-
|
|
41
|
-
.inner {
|
|
42
|
-
height: 1rem;
|
|
43
|
-
width: 1rem;
|
|
44
|
-
color: white;
|
|
45
|
-
position: relative;
|
|
46
|
-
order: 1;
|
|
47
|
-
|
|
48
|
-
input {
|
|
49
|
-
appearance: none;
|
|
50
|
-
outline: none;
|
|
51
|
-
|
|
52
|
-
cursor: pointer;
|
|
53
|
-
display: block;
|
|
54
|
-
margin: 0;
|
|
55
|
-
padding: 0;
|
|
56
|
-
left: 0;
|
|
57
|
-
top: 0;
|
|
58
|
-
width: 100%;
|
|
59
|
-
height: 100%;
|
|
60
|
-
transition: opacity .1s ease;
|
|
61
|
-
|
|
62
|
-
&:checked {
|
|
63
|
-
background-color: var( --checkbox-background-check );
|
|
64
|
-
}
|
|
65
|
-
|
|
66
|
-
&:checked:hover {
|
|
67
|
-
background-color: var( --checkbox-background-check-hover );
|
|
68
|
-
}
|
|
69
|
-
|
|
70
|
-
&:not(:checked) {
|
|
71
|
-
border: 1px solid var( --checkbox-check-border );
|
|
72
|
-
}
|
|
73
|
-
|
|
74
|
-
&:not(:checked):hover {
|
|
75
|
-
border: 1px solid var( --checkbox-check-border-hover );
|
|
76
|
-
}
|
|
77
|
-
}
|
|
78
|
-
|
|
79
|
-
svg {
|
|
80
|
-
margin: auto;
|
|
81
|
-
pointer-events: none;
|
|
82
|
-
position: absolute;
|
|
83
|
-
opacity: 0;
|
|
84
|
-
left: 0;
|
|
85
|
-
right: 0;
|
|
86
|
-
top: 0;
|
|
87
|
-
bottom: 0;
|
|
88
|
-
width: 100%;
|
|
89
|
-
height: 50%;
|
|
90
|
-
}
|
|
91
|
-
|
|
92
|
-
&:has(input:checked) {
|
|
93
|
-
input {
|
|
94
|
-
opacity: 1;
|
|
95
|
-
}
|
|
96
|
-
|
|
97
|
-
svg {
|
|
98
|
-
opacity: 1;
|
|
99
|
-
}
|
|
100
|
-
}
|
|
101
|
-
}
|
|
102
|
-
|
|
103
|
-
&:focus-within {
|
|
104
|
-
label #text {
|
|
105
|
-
text-decoration: underline;
|
|
106
|
-
}
|
|
107
|
-
}
|
|
108
|
-
|
|
109
|
-
&[disabled] {
|
|
110
|
-
&, * {
|
|
111
|
-
cursor: not-allowed;
|
|
112
|
-
}
|
|
113
|
-
|
|
114
|
-
label {
|
|
115
|
-
|
|
116
|
-
pointer-events: none;
|
|
117
|
-
color: var( --checkbox-color-disabled );
|
|
118
|
-
}
|
|
119
|
-
|
|
120
|
-
.inner {
|
|
121
|
-
pointer-events: none;
|
|
122
|
-
input {
|
|
123
|
-
background-color: var( --checkbox-background-disabled );
|
|
124
|
-
|
|
125
|
-
&:checked {
|
|
126
|
-
background-color: var( --checkbox-background-disabled-check );
|
|
127
|
-
}
|
|
128
|
-
}
|
|
129
|
-
}
|
|
130
|
-
}
|
|
131
|
-
|
|
132
|
-
label {
|
|
133
|
-
text-align: right;
|
|
134
|
-
cursor: inherit;
|
|
135
|
-
order: 2;
|
|
136
|
-
}
|
|
137
|
-
|
|
138
|
-
&.left #label {
|
|
139
|
-
order: 0;
|
|
140
|
-
text-align: left;
|
|
141
|
-
}
|
|
142
|
-
}
|
|
@@ -1,125 +0,0 @@
|
|
|
1
|
-
import { Component, ComponentEvents, ComponentProps, EvChange, makeUniqueComponentId } from '@core/component.js';
|
|
2
|
-
import { EventCallback } from '@core/core_events.js';
|
|
3
|
-
|
|
4
|
-
import { Input } from '../input/input';
|
|
5
|
-
import { Label } from '../label/label';
|
|
6
|
-
|
|
7
|
-
import { svgLoader } from '../icon/icon.js';
|
|
8
|
-
|
|
9
|
-
import "./checkbox.module.scss"
|
|
10
|
-
import icon from "./check.svg";
|
|
11
|
-
|
|
12
|
-
/**
|
|
13
|
-
* Checkbox events
|
|
14
|
-
*/
|
|
15
|
-
|
|
16
|
-
interface CheckBoxEvents extends ComponentEvents {
|
|
17
|
-
change?: EvChange;
|
|
18
|
-
}
|
|
19
|
-
|
|
20
|
-
/**
|
|
21
|
-
* Checkbox properties.
|
|
22
|
-
*/
|
|
23
|
-
|
|
24
|
-
interface CheckboxProps extends ComponentProps {
|
|
25
|
-
label: string; // The text label for the checkbox.
|
|
26
|
-
checked?: boolean; // Optional boolean indicating if the checkbox is checked by default.
|
|
27
|
-
value?: string; // Optional value associated with the checkbox.
|
|
28
|
-
change?: EventCallback<EvChange>;
|
|
29
|
-
}
|
|
30
|
-
|
|
31
|
-
/**
|
|
32
|
-
* Checkbox component that can be checked or unchecked.
|
|
33
|
-
*/
|
|
34
|
-
|
|
35
|
-
export class Checkbox extends Component<CheckboxProps,CheckBoxEvents> {
|
|
36
|
-
|
|
37
|
-
readonly _input: Input;
|
|
38
|
-
|
|
39
|
-
/**
|
|
40
|
-
* Creates an instance of the Checkbox component.
|
|
41
|
-
*
|
|
42
|
-
* @param {CheckboxProps} props - The properties for the checkbox component, including label, checked state, and value.
|
|
43
|
-
* @example
|
|
44
|
-
* const checkbox = new Checkbox({ label: 'Accept Terms', checked: true });
|
|
45
|
-
*/
|
|
46
|
-
|
|
47
|
-
constructor( props: CheckboxProps ) {
|
|
48
|
-
super( props );
|
|
49
|
-
|
|
50
|
-
const inputId = makeUniqueComponentId( );
|
|
51
|
-
|
|
52
|
-
this.mapPropEvents( props, 'change' );
|
|
53
|
-
|
|
54
|
-
this.setContent( [
|
|
55
|
-
new Component( {
|
|
56
|
-
cls: 'inner',
|
|
57
|
-
content: [
|
|
58
|
-
this._input = new Input( {
|
|
59
|
-
type:"checkbox",
|
|
60
|
-
id: inputId,
|
|
61
|
-
checked: props.checked,
|
|
62
|
-
dom_events: {
|
|
63
|
-
change: ( ) => this._on_change( ),
|
|
64
|
-
}
|
|
65
|
-
})
|
|
66
|
-
]
|
|
67
|
-
}),
|
|
68
|
-
new Label( {
|
|
69
|
-
tag: 'label',
|
|
70
|
-
text: props.label,
|
|
71
|
-
labelFor: inputId,
|
|
72
|
-
id: undefined
|
|
73
|
-
} ),
|
|
74
|
-
])
|
|
75
|
-
|
|
76
|
-
svgLoader.load( icon ).then( svg => {
|
|
77
|
-
this.query<Label>( '.inner' ).dom.insertAdjacentHTML( "beforeend", svg );
|
|
78
|
-
});
|
|
79
|
-
}
|
|
80
|
-
|
|
81
|
-
/**
|
|
82
|
-
* check state changed
|
|
83
|
-
*/
|
|
84
|
-
|
|
85
|
-
private _on_change() {
|
|
86
|
-
this.fire('change', { value:this.getCheck() } );
|
|
87
|
-
}
|
|
88
|
-
|
|
89
|
-
/**
|
|
90
|
-
* @return the checked value
|
|
91
|
-
*/
|
|
92
|
-
|
|
93
|
-
public getCheck() {
|
|
94
|
-
const d = this._input.dom as HTMLInputElement;
|
|
95
|
-
return d.checked;
|
|
96
|
-
}
|
|
97
|
-
|
|
98
|
-
/**
|
|
99
|
-
* change the checked value
|
|
100
|
-
* @param {boolean} ck new checked value
|
|
101
|
-
*/
|
|
102
|
-
|
|
103
|
-
public setCheck(ck: boolean) {
|
|
104
|
-
const d = this._input.dom as HTMLInputElement;
|
|
105
|
-
d.checked = ck;
|
|
106
|
-
}
|
|
107
|
-
|
|
108
|
-
/**
|
|
109
|
-
* change the checkbox label
|
|
110
|
-
* @param text
|
|
111
|
-
*/
|
|
112
|
-
|
|
113
|
-
public setLabel(text: string) {
|
|
114
|
-
this.query<Label>('label').setText( text );
|
|
115
|
-
}
|
|
116
|
-
|
|
117
|
-
/**
|
|
118
|
-
* toggle the checkbox
|
|
119
|
-
*/
|
|
120
|
-
|
|
121
|
-
public toggle() {
|
|
122
|
-
this.setCheck( !this.getCheck() );
|
|
123
|
-
}
|
|
124
|
-
|
|
125
|
-
}
|
|
@@ -1,65 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* ___ ___ __
|
|
3
|
-
* \ \/ / / _
|
|
4
|
-
* \ / /_| |_
|
|
5
|
-
* / \____ _|
|
|
6
|
-
* /__/\__\ |_|
|
|
7
|
-
*
|
|
8
|
-
* @file colorinput.module.scss
|
|
9
|
-
* @author Etienne Cochard
|
|
10
|
-
*
|
|
11
|
-
* @copyright (c) 2024 R-libre ingenierie
|
|
12
|
-
*
|
|
13
|
-
* Use of this source code is governed by an MIT-style license
|
|
14
|
-
* that can be found in the LICENSE file or at https://opensource.org/licenses/MIT.
|
|
15
|
-
**/
|
|
16
|
-
|
|
17
|
-
:root {
|
|
18
|
-
--colorinput-btn-background: inherit;
|
|
19
|
-
--colorinput-btn-color: var( --text-secondary );
|
|
20
|
-
--colorinput-btn-color-hover: var( --text-primary );
|
|
21
|
-
}
|
|
22
|
-
|
|
23
|
-
.x4colorinput {
|
|
24
|
-
margin: 5px;
|
|
25
|
-
border-bottom: 1px solid var( --border );
|
|
26
|
-
outline: none;
|
|
27
|
-
|
|
28
|
-
&:focus-within {
|
|
29
|
-
border-bottom-color: var( --border-focus );
|
|
30
|
-
}
|
|
31
|
-
|
|
32
|
-
.swatch {
|
|
33
|
-
margin: 4px;
|
|
34
|
-
width: 1rem;
|
|
35
|
-
height: 1rem;
|
|
36
|
-
}
|
|
37
|
-
|
|
38
|
-
input {
|
|
39
|
-
outline: none;
|
|
40
|
-
margin: 0;
|
|
41
|
-
height: 100%;
|
|
42
|
-
flex-grow: 1;
|
|
43
|
-
}
|
|
44
|
-
|
|
45
|
-
.x4button {
|
|
46
|
-
margin: 0;
|
|
47
|
-
padding: 0;
|
|
48
|
-
outline: none;
|
|
49
|
-
background-color: var( --combobox-btn-background );
|
|
50
|
-
color: var( --colorinput-btn-color );
|
|
51
|
-
|
|
52
|
-
#icon {
|
|
53
|
-
color: var( --colorinput-btn-color );
|
|
54
|
-
}
|
|
55
|
-
|
|
56
|
-
&:hover, &:hover #icon {
|
|
57
|
-
color: var( --colorinput-btn-color-hover );
|
|
58
|
-
}
|
|
59
|
-
|
|
60
|
-
&:focus {
|
|
61
|
-
//background-color: var( --color-30 );
|
|
62
|
-
//color: var( --color-10 );
|
|
63
|
-
}
|
|
64
|
-
}
|
|
65
|
-
}
|