x4js 1.4.2

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 (176) hide show
  1. package/lib/application.d.ts +95 -0
  2. package/lib/application.js +137 -0
  3. package/lib/base64.d.ts +31 -0
  4. package/lib/base64.js +135 -0
  5. package/lib/base_component.d.ts +64 -0
  6. package/lib/base_component.js +77 -0
  7. package/lib/button.d.ts +145 -0
  8. package/lib/button.js +235 -0
  9. package/lib/calendar.d.ts +77 -0
  10. package/lib/calendar.js +236 -0
  11. package/lib/canvas.d.ts +88 -0
  12. package/lib/canvas.js +354 -0
  13. package/lib/cardview.d.ts +83 -0
  14. package/lib/cardview.js +152 -0
  15. package/lib/checkbox.d.ts +72 -0
  16. package/lib/checkbox.js +126 -0
  17. package/lib/color.d.ts +144 -0
  18. package/lib/color.js +584 -0
  19. package/lib/colorpicker.d.ts +98 -0
  20. package/lib/colorpicker.js +1457 -0
  21. package/lib/combobox.d.ts +97 -0
  22. package/lib/combobox.js +246 -0
  23. package/lib/component.d.ts +572 -0
  24. package/lib/component.js +1712 -0
  25. package/lib/datastore.d.ts +392 -0
  26. package/lib/datastore.js +986 -0
  27. package/lib/dialog.d.ts +171 -0
  28. package/lib/dialog.js +468 -0
  29. package/lib/dom_events.d.ts +284 -0
  30. package/lib/dom_events.js +13 -0
  31. package/lib/drag_manager.d.ts +26 -0
  32. package/lib/drag_manager.js +118 -0
  33. package/lib/drawtext.d.ts +43 -0
  34. package/lib/drawtext.js +261 -0
  35. package/lib/fileupload.d.ts +60 -0
  36. package/lib/fileupload.js +158 -0
  37. package/lib/form.d.ts +122 -0
  38. package/lib/form.js +293 -0
  39. package/lib/formatters.d.ts +31 -0
  40. package/lib/formatters.js +75 -0
  41. package/lib/gridview.d.ts +171 -0
  42. package/lib/gridview.js +786 -0
  43. package/lib/hosts/host.d.ts +44 -0
  44. package/lib/hosts/host.js +69 -0
  45. package/lib/i18n.d.ts +67 -0
  46. package/lib/i18n.js +169 -0
  47. package/lib/icon.d.ts +56 -0
  48. package/lib/icon.js +173 -0
  49. package/lib/image.d.ts +51 -0
  50. package/lib/image.js +149 -0
  51. package/lib/index.js +1 -0
  52. package/lib/input.d.ts +86 -0
  53. package/lib/input.js +172 -0
  54. package/lib/label.d.ts +54 -0
  55. package/lib/label.js +86 -0
  56. package/lib/layout.d.ts +77 -0
  57. package/lib/layout.js +261 -0
  58. package/lib/link.d.ts +46 -0
  59. package/lib/link.js +55 -0
  60. package/lib/listview.d.ts +173 -0
  61. package/lib/listview.js +532 -0
  62. package/lib/md5.d.ts +56 -0
  63. package/lib/md5.js +397 -0
  64. package/lib/menu.d.ts +122 -0
  65. package/lib/menu.js +276 -0
  66. package/lib/messagebox.d.ts +64 -0
  67. package/lib/messagebox.js +141 -0
  68. package/lib/panel.d.ts +42 -0
  69. package/lib/panel.js +61 -0
  70. package/lib/popup.d.ts +71 -0
  71. package/lib/popup.js +373 -0
  72. package/lib/property_editor.d.ts +67 -0
  73. package/lib/property_editor.js +247 -0
  74. package/lib/radiobtn.d.ts +68 -0
  75. package/lib/radiobtn.js +131 -0
  76. package/lib/rating.d.ts +49 -0
  77. package/lib/rating.js +93 -0
  78. package/lib/request.d.ts +48 -0
  79. package/lib/request.js +220 -0
  80. package/lib/router.d.ts +13 -0
  81. package/lib/router.js +27 -0
  82. package/lib/settings.d.ts +33 -0
  83. package/lib/settings.js +63 -0
  84. package/lib/sidebarview.d.ts +44 -0
  85. package/lib/sidebarview.js +73 -0
  86. package/lib/smartedit.d.ts +103 -0
  87. package/lib/smartedit.js +381 -0
  88. package/lib/spreadsheet.d.ts +214 -0
  89. package/lib/spreadsheet.js +1073 -0
  90. package/lib/styles.d.ts +81 -0
  91. package/lib/styles.js +262 -0
  92. package/lib/svgcomponent.d.ts +165 -0
  93. package/lib/svgcomponent.js +350 -0
  94. package/lib/tabbar.d.ts +41 -0
  95. package/lib/tabbar.js +66 -0
  96. package/lib/tabview.d.ts +45 -0
  97. package/lib/tabview.js +79 -0
  98. package/lib/textarea.d.ts +59 -0
  99. package/lib/textarea.js +119 -0
  100. package/lib/textedit.d.ts +118 -0
  101. package/lib/textedit.js +406 -0
  102. package/lib/texthiliter.d.ts +56 -0
  103. package/lib/texthiliter.js +219 -0
  104. package/lib/toaster.d.ts +38 -0
  105. package/lib/toaster.js +58 -0
  106. package/lib/tools.d.ts +382 -0
  107. package/lib/tools.js +1096 -0
  108. package/lib/tooltips.d.ts +42 -0
  109. package/lib/tooltips.js +148 -0
  110. package/lib/treeview.d.ts +128 -0
  111. package/lib/treeview.js +490 -0
  112. package/lib/x4_events.d.ts +253 -0
  113. package/lib/x4_events.js +363 -0
  114. package/package.json +21 -0
  115. package/src/README.md +2 -0
  116. package/src/application.ts +191 -0
  117. package/src/base64.ts +162 -0
  118. package/src/base_component.ts +118 -0
  119. package/src/button.ts +327 -0
  120. package/src/calendar.ts +312 -0
  121. package/src/canvas.ts +501 -0
  122. package/src/cardview.ts +220 -0
  123. package/src/checkbox.ts +178 -0
  124. package/src/color.ts +748 -0
  125. package/src/colorpicker.ts +1618 -0
  126. package/src/combobox.ts +348 -0
  127. package/src/component.ts +2330 -0
  128. package/src/datastore.ts +1318 -0
  129. package/src/dialog.ts +631 -0
  130. package/src/dom_events.ts +297 -0
  131. package/src/drag_manager.ts +168 -0
  132. package/src/drawtext.ts +342 -0
  133. package/src/fileupload.ts +208 -0
  134. package/src/form.ts +362 -0
  135. package/src/formatters.ts +96 -0
  136. package/src/gridview.ts +1051 -0
  137. package/src/hosts/electron.ts +161 -0
  138. package/src/hosts/host.ts +100 -0
  139. package/src/hosts/nwjs.ts +141 -0
  140. package/src/hosts/nwjs_types.ts +339 -0
  141. package/src/i18n.ts +205 -0
  142. package/src/icon.ts +237 -0
  143. package/src/image.ts +198 -0
  144. package/src/input.ts +236 -0
  145. package/src/label.ts +124 -0
  146. package/src/layout.ts +366 -0
  147. package/src/link.ts +82 -0
  148. package/src/listview.ts +749 -0
  149. package/src/md5.ts +432 -0
  150. package/src/menu.ts +394 -0
  151. package/src/messagebox.ts +199 -0
  152. package/src/panel.ts +81 -0
  153. package/src/popup.ts +488 -0
  154. package/src/property_editor.ts +333 -0
  155. package/src/radiobtn.ts +190 -0
  156. package/src/rating.ts +131 -0
  157. package/src/request.ts +296 -0
  158. package/src/router.ts +43 -0
  159. package/src/settings.ts +75 -0
  160. package/src/sidebarview.ts +97 -0
  161. package/src/smartedit.ts +532 -0
  162. package/src/spreadsheet.ts +1423 -0
  163. package/src/styles.ts +332 -0
  164. package/src/svgcomponent.ts +440 -0
  165. package/src/tabbar.ts +105 -0
  166. package/src/tabview.ts +106 -0
  167. package/src/textarea.ts +183 -0
  168. package/src/textedit.ts +535 -0
  169. package/src/texthiliter.ts +284 -0
  170. package/src/toaster.ts +76 -0
  171. package/src/tools.ts +1391 -0
  172. package/src/tooltips.ts +185 -0
  173. package/src/treeview.ts +670 -0
  174. package/src/x4.less +1940 -0
  175. package/src/x4_events.ts +558 -0
  176. package/tsconfig.json +14 -0
@@ -0,0 +1,191 @@
1
+ /**
2
+ * ___ ___ __
3
+ * \ \/ / / _
4
+ * \ / /_| |_
5
+ * / \____ _|
6
+ * /__/\__\ |_|
7
+ *
8
+ * @file application.ts
9
+ * @author Etienne Cochard
10
+ * @license
11
+ * Copyright (c) 2019-2021 R-libre ingenierie
12
+ *
13
+ * This program is free software; you can redistribute it and/or modify
14
+ * it under the terms of the GNU General Public License as published by
15
+ * the Free Software Foundation; either version 3 of the License, or
16
+ * (at your option) any later version.
17
+ *
18
+ * This program is distributed in the hope that it will be useful,
19
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
20
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
21
+ * GNU General Public License for more details.
22
+ *
23
+ * You should have received a copy of the GNU General Public License along with this program. If not, see <https://www.gnu.org/licenses/>.
24
+ **/
25
+
26
+ import { EvMessage } from './x4_events'
27
+ import { BaseComponent, BaseComponentEventMap, BaseComponentProps } from './base_component'
28
+ import { Component } from './component'
29
+ import { Settings } from './settings'
30
+ import { deferCall } from './tools'
31
+ import { _tr } from './i18n'
32
+
33
+
34
+ interface ApplicationEventMap extends BaseComponentEventMap {
35
+ message: EvMessage;
36
+ global: EvMessage;
37
+ }
38
+
39
+ /**
40
+ *
41
+ */
42
+
43
+ export interface ApplicationProps extends BaseComponentProps<ApplicationEventMap> {
44
+ app_name: string; //
45
+ app_version: string; //
46
+ app_uid: string;
47
+ locale: string; // fr-FR
48
+ }
49
+
50
+ /**
51
+ * Represents an x4 application, which is typically a single page app.
52
+ * You should inherit Application to define yours.
53
+ * Application derives from BaseComponent so you can use that to implement a global messaging system.
54
+ * @example ```ts
55
+ *
56
+ * // in yout main caode
57
+ * let app = new Application( );
58
+ *
59
+ * app.events.close.on( ( ev ) => {
60
+ * ... do something
61
+ * });
62
+ *
63
+ * // somewhere else in the source
64
+ * function xxx( ) {
65
+ * let app = Application.instance( );
66
+ * app.events.close.emit( new Events.close() );
67
+ * }
68
+ */
69
+
70
+ export class Application<P extends ApplicationProps = ApplicationProps, E extends ApplicationEventMap = ApplicationEventMap> extends BaseComponent<P,E> {
71
+
72
+ private static self: Application = null;
73
+
74
+ /**
75
+ * the application singleton
76
+ */
77
+
78
+ static instance( ) : Application {
79
+ return Application.self;
80
+ }
81
+
82
+ private m_mainView: Component;
83
+
84
+ private m_app_name: string;
85
+ private m_app_version: string;
86
+ private m_app_uid: string;
87
+
88
+ private m_local_storage: Settings;
89
+ private m_user_data: any;
90
+
91
+ constructor( props : P ) {
92
+ console.assert( Application.self===null, 'application is a singleton' );
93
+ super( props );
94
+
95
+ this.m_app_name = props.app_name ?? 'application';
96
+ this.m_app_version = props.app_version ?? '1.0';
97
+ this.m_app_uid = props.app_uid ?? 'application';
98
+
99
+ let settings_name = `${this.m_app_name}.${this.m_app_version}.settings`;
100
+ this.m_local_storage = new Settings( settings_name );
101
+ this.m_user_data = {};
102
+
103
+ (Application.self as any) = this;
104
+
105
+ if( 'onload' in globalThis ) {
106
+ globalThis.addEventListener( 'load', ( ) => {
107
+ this.ApplicationCreated( );
108
+ })
109
+ }
110
+ else {
111
+ this.ApplicationCreated( );
112
+ }
113
+ }
114
+
115
+ ApplicationCreated( ) {
116
+
117
+ }
118
+
119
+ public get app_name( ) {
120
+ return this.m_app_name;
121
+ }
122
+
123
+ public get app_uid( ) {
124
+ return this.m_app_uid;
125
+ }
126
+
127
+ public get app_version( ) {
128
+ return this.m_app_version;
129
+ }
130
+
131
+ public get local_storage( ) {
132
+ return this.m_local_storage;
133
+ }
134
+
135
+ public get user_data( ) {
136
+ return this.m_user_data;
137
+ }
138
+
139
+ public get history( ) {
140
+ //if( !this.m_history ) {
141
+ // this.m_history = new NavigationHistory( );
142
+ //}
143
+ //
144
+ //return this.m_history;
145
+ debugger;
146
+ return null;
147
+ }
148
+
149
+ /**
150
+ * define the application root object (MainView)
151
+ * @example ```ts
152
+ *
153
+ * let myApp = new Application( ... );
154
+ * let mainView = new VLayout( ... );
155
+ * myApp.setMainView( mainView );
156
+ */
157
+
158
+ public set mainView( root: Component ) {
159
+
160
+ this.m_mainView = root;
161
+
162
+ deferCall( ( ) => {
163
+ document.body.appendChild(root._build());
164
+ } );
165
+ }
166
+
167
+ public get mainView( ) : Component {
168
+ return this.m_mainView;
169
+ }
170
+
171
+ public setTitle( title: string ) {
172
+ document.title = this.m_app_name + ' > ' + title;
173
+ }
174
+
175
+ public disableZoomWheel( ) {
176
+
177
+ window.addEventListener('wheel', function( ev: WheelEvent ) {
178
+ if( ev.ctrlKey ) {
179
+ ev.preventDefault( );
180
+ //ev.stopPropagation( );
181
+ }
182
+
183
+ }, { passive: false, capture: true } );
184
+ }
185
+
186
+ public enterModal( enter: boolean ) {
187
+ }
188
+ };
189
+
190
+
191
+
package/src/base64.ts ADDED
@@ -0,0 +1,162 @@
1
+ /**
2
+ * ___ ___ __
3
+ * \ \/ / / _
4
+ * \ / /_| |_
5
+ * / \____ _|
6
+ * /__/\__\ |_|
7
+ *
8
+ * @file base64.ts
9
+ * @author Etienne Cochard
10
+ * @license
11
+ * Copyright (c) 2019-2021 R-libre ingenierie
12
+ *
13
+ * This program is free software; you can redistribute it and/or modify
14
+ * it under the terms of the GNU General Public License as published by
15
+ * the Free Software Foundation; either version 3 of the License, or
16
+ * (at your option) any later version.
17
+ *
18
+ * This program is distributed in the hope that it will be useful,
19
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
20
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
21
+ * GNU General Public License for more details.
22
+ *
23
+ * You should have received a copy of the GNU General Public License along with this program. If not, see <https://www.gnu.org/licenses/>.
24
+ **/
25
+
26
+ const _alphabet: string = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=';
27
+ let _lookup: any = null;
28
+
29
+
30
+ export class Base64 {
31
+ lookup: any = null;
32
+
33
+ static encode(s: string | Uint8Array ) {
34
+ let buffer;
35
+
36
+ if( s instanceof Uint8Array ) {
37
+ buffer = []
38
+ s.forEach( (v) => {
39
+ buffer.push( v );
40
+ });
41
+ }
42
+ else {
43
+ buffer = Base64._toUtf8(s);
44
+ }
45
+
46
+ let position = -1;
47
+ let len = buffer.length;
48
+ let nan1, nan2;
49
+ let enc = [, , ,];
50
+
51
+ let result = '';
52
+ while (++position < len) {
53
+ nan1 = buffer[position + 1], nan2 = buffer[position + 2];
54
+ enc[0] = buffer[position] >> 2;
55
+ enc[1] = ((buffer[position] & 3) << 4) | (buffer[++position] >> 4);
56
+
57
+ if (isNaN(nan1)) {
58
+ enc[2] = enc[3] = 64;
59
+ }
60
+ else {
61
+ enc[2] = ((buffer[position] & 15) << 2) | (buffer[++position] >> 6);
62
+ enc[3] = (isNaN(nan2)) ? 64 : buffer[position] & 63;
63
+ }
64
+
65
+ result += _alphabet[enc[0]] + _alphabet[enc[1]] + _alphabet[enc[2]] + _alphabet[enc[3]];
66
+ }
67
+
68
+ return result;
69
+ }
70
+
71
+ static decode(s: string) {
72
+ let buffer = Base64._fromUtf8(s);
73
+
74
+ let position = 0;
75
+ let len = buffer.length;
76
+
77
+ let result = '';
78
+ while (position < len) {
79
+ if (buffer[position] < 128) {
80
+ result += String.fromCharCode(buffer[position++]);
81
+ }
82
+ else if (buffer[position] > 191 && buffer[position] < 224) {
83
+ result += String.fromCharCode(((buffer[position++] & 31) << 6) | (buffer[position++] & 63));
84
+ }
85
+ else {
86
+ result += String.fromCharCode(((buffer[position++] & 15) << 12) | ((buffer[position++] & 63) << 6) | (buffer[position++] & 63));
87
+ }
88
+ }
89
+
90
+ return result;
91
+ }
92
+
93
+ private static _toUtf8(s) {
94
+ let position = -1;
95
+ let len = s.length;
96
+
97
+ let chr;
98
+ let buffer = [];
99
+
100
+ if (/^[\x00-\x7f]*$/.test(s)) {
101
+ while (++position < len) {
102
+ buffer.push(s.charCodeAt(position));
103
+ }
104
+ }
105
+ else {
106
+ while (++position < len) {
107
+ chr = s.charCodeAt(position);
108
+ if (chr < 128) {
109
+ buffer.push(chr);
110
+ }
111
+ else if (chr < 2048) {
112
+ buffer.push((chr >> 6) | 192, (chr & 63) | 128);
113
+ }
114
+ else {
115
+ buffer.push((chr >> 12) | 224, ((chr >> 6) & 63) | 128, (chr & 63) | 128);
116
+ }
117
+ }
118
+ }
119
+
120
+ return buffer;
121
+ }
122
+
123
+ private static _fromUtf8(s) {
124
+ let position = -1;
125
+ let len;
126
+ let buffer = [];
127
+ let enc = [, , ,];
128
+
129
+ if (!_lookup) {
130
+ len = _alphabet.length;
131
+ _lookup = {};
132
+ while (++position < len) {
133
+ _lookup[_alphabet[position]] = position;
134
+ }
135
+
136
+ position = -1;
137
+ }
138
+
139
+ len = s.length;
140
+ while (position < len) {
141
+ enc[0] = _lookup[s.charAt(++position)];
142
+ enc[1] = _lookup[s.charAt(++position)];
143
+ buffer.push((enc[0] << 2) | (enc[1] >> 4));
144
+
145
+ enc[2] = _lookup[s.charAt(++position)];
146
+ if (enc[2] == 64) {
147
+ break;
148
+ }
149
+
150
+ buffer.push(((enc[1] & 15) << 4) | (enc[2] >> 2));
151
+ enc[3] = _lookup[s.charAt(++position)];
152
+
153
+ if (enc[3] == 64) {
154
+ break;
155
+ }
156
+
157
+ buffer.push(((enc[2] & 3) << 6) | enc[3]);
158
+ }
159
+
160
+ return buffer;
161
+ }
162
+ }
@@ -0,0 +1,118 @@
1
+ /**
2
+ * ___ ___ __
3
+ * \ \/ / / _
4
+ * \ / /_| |_
5
+ * / \____ _|
6
+ * /__/\__\ |_|
7
+ *
8
+ * @file base_component.ts
9
+ * @author Etienne Cochard
10
+ * @copyright (c) 2022 R-libre ingenierie, all rights reserved.
11
+ *
12
+ **/
13
+
14
+ import { EventMap, MapEvents, EventSource, EvTimer } from './x4_events';
15
+
16
+ /**
17
+ * Timer Callback
18
+ * @see EvTimer, startTimer, stopTimer
19
+ */
20
+
21
+ interface TimerCallback {
22
+ (name: string, time: number): void;
23
+ }
24
+
25
+ /**
26
+ * BaseComponent EventMap
27
+ */
28
+
29
+ export interface BaseComponentEventMap extends EventMap {
30
+ timer: EvTimer,
31
+ }
32
+
33
+ /**
34
+ * BaseCompoment Properties
35
+ */
36
+
37
+ export interface BaseComponentProps<T = BaseComponentEventMap> {
38
+ events?: MapEvents<T>; // basic component event map in base interface, should specialised in derived interfaces
39
+ }
40
+
41
+ /**
42
+ * BaseComponent class
43
+ */
44
+
45
+ export class BaseComponent< P extends BaseComponentProps<BaseComponentEventMap>, E extends BaseComponentEventMap >
46
+ extends EventSource< E > {
47
+
48
+ protected m_props: P;
49
+ #m_timers: Map<string, Function>;
50
+
51
+ constructor(props: P) {
52
+ super();
53
+
54
+ //this.m_props = { ...props };
55
+ this.m_props = props;
56
+
57
+ if (props.events) {
58
+ this.listen(props.events as EventMap);
59
+ }
60
+ }
61
+
62
+ /**
63
+ * start a new timer
64
+ * @param name timer name
65
+ * @param timeout time out in ms
66
+ * @param repeat if true this is an auto repeat timer
67
+ * @param callback if !null, the callback to call else a EvTimer is fired
68
+ */
69
+
70
+ startTimer(name: string, timeout: number, repeat = true, callback: TimerCallback = null) {
71
+ if (!this.#m_timers) {
72
+ this.#m_timers = new Map();
73
+ }
74
+ else {
75
+ this.stopTimer(name);
76
+ }
77
+
78
+ const id = (repeat ? setInterval : setTimeout)((tm: number) => {
79
+ if (callback) {
80
+ callback(name, tm);
81
+ }
82
+ else {
83
+ this.emit('timer', EvTimer( name, tm ));
84
+ }
85
+ }, timeout);
86
+
87
+ this.#m_timers.set(name, () => { (repeat ? clearInterval : clearTimeout)(id) });
88
+ }
89
+
90
+ /**
91
+ * stop the given timer
92
+ * @param name
93
+ */
94
+
95
+ stopTimer(name: string) {
96
+ const clear = this.#m_timers.get(name);
97
+ if (clear) { clear(); }
98
+ }
99
+
100
+ /**
101
+ * stop all timers
102
+ */
103
+
104
+ disposeTimers( ) {
105
+ this.#m_timers?.forEach( v => v() );
106
+ this.#m_timers = undefined;
107
+ }
108
+
109
+ /**
110
+ *
111
+ * @param callback
112
+ * @param timeout
113
+ */
114
+
115
+ singleShot( callback: TimerCallback, timeout = 0 ) {
116
+ setTimeout( callback, timeout );
117
+ }
118
+ }