x4js 1.4.51 → 1.4.53

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 (305) hide show
  1. package/lib/{action.js → cjs/action.js} +0 -0
  2. package/lib/{application.js → cjs/application.js} +13 -19
  3. package/lib/{autocomplete.js → cjs/autocomplete.js} +0 -4
  4. package/lib/cjs/base_component.js +124 -0
  5. package/lib/{button.js → cjs/button.js} +4 -4
  6. package/lib/{calendar.js → cjs/calendar.js} +22 -22
  7. package/lib/{canvas.js → cjs/canvas.js} +7 -8
  8. package/lib/{cardview.js → cjs/cardview.js} +3 -5
  9. package/lib/{checkbox.js → cjs/checkbox.js} +6 -5
  10. package/lib/cjs/color.js +591 -0
  11. package/lib/{colorpicker.js → cjs/colorpicker.js} +1 -14
  12. package/lib/{combobox.js → cjs/combobox.js} +2 -6
  13. package/lib/{component.js → cjs/component.js} +20 -41
  14. package/lib/{datastore.js → cjs/datastore.js} +18 -32
  15. package/lib/{dialog.js → cjs/dialog.js} +4 -21
  16. package/lib/{dom_events.js → cjs/dom_events.js} +0 -0
  17. package/lib/{drag_manager.js → cjs/drag_manager.js} +0 -5
  18. package/lib/{drawtext.js → cjs/drawtext.js} +5 -4
  19. package/lib/{fileupload.js → cjs/fileupload.js} +0 -3
  20. package/lib/{form.js → cjs/form.js} +2 -6
  21. package/lib/{formatters.js → cjs/formatters.js} +0 -0
  22. package/lib/{gridview.js → cjs/gridview.js} +20 -33
  23. package/lib/{i18n.js → cjs/i18n.js} +0 -0
  24. package/lib/{icon.js → cjs/icon.js} +17 -11
  25. package/lib/{image.js → cjs/image.js} +4 -5
  26. package/lib/{index.js → cjs/index.js} +0 -0
  27. package/lib/cjs/input.js +174 -0
  28. package/lib/{label.js → cjs/label.js} +2 -1
  29. package/lib/{layout.js → cjs/layout.js} +9 -8
  30. package/lib/{link.js → cjs/link.js} +3 -2
  31. package/lib/cjs/listview.js +544 -0
  32. package/{src/md5.ts → lib/cjs/md5.js} +403 -438
  33. package/lib/{menu.js → cjs/menu.js} +4 -11
  34. package/lib/{messagebox.js → cjs/messagebox.js} +4 -4
  35. package/lib/{panel.js → cjs/panel.js} +3 -4
  36. package/lib/{popup.js → cjs/popup.js} +4 -5
  37. package/lib/{property_editor.js → cjs/property_editor.js} +2 -5
  38. package/lib/{radiobtn.js → cjs/radiobtn.js} +6 -6
  39. package/lib/{rating.js → cjs/rating.js} +7 -6
  40. package/lib/cjs/request.js +246 -0
  41. package/lib/{router.js → cjs/router.js} +0 -1
  42. package/lib/cjs/settings.js +69 -0
  43. package/lib/{sidebarview.js → cjs/sidebarview.js} +2 -3
  44. package/lib/{spreadsheet.js → cjs/spreadsheet.js} +10 -27
  45. package/lib/{styles.js → cjs/styles.js} +5 -6
  46. package/lib/{svgcomponent.js → cjs/svgcomponent.js} +3 -11
  47. package/lib/{tabbar.js → cjs/tabbar.js} +5 -5
  48. package/lib/{tabview.js → cjs/tabview.js} +0 -2
  49. package/lib/{textarea.js → cjs/textarea.js} +4 -3
  50. package/lib/{textedit.js → cjs/textedit.js} +7 -8
  51. package/lib/{toaster.js → cjs/toaster.js} +0 -2
  52. package/lib/{tools.js → cjs/tools.js} +7 -16
  53. package/lib/{tooltips.js → cjs/tooltips.js} +0 -1
  54. package/lib/{treeview.js → cjs/treeview.js} +23 -19
  55. package/lib/{action.d.ts → cjs/types/action.d.ts} +0 -0
  56. package/lib/{application.d.ts → cjs/types/application.d.ts} +0 -0
  57. package/lib/{autocomplete.d.ts → cjs/types/autocomplete.d.ts} +0 -0
  58. package/lib/{base_component.d.ts → cjs/types/base_component.d.ts} +0 -0
  59. package/lib/{button.d.ts → cjs/types/button.d.ts} +0 -0
  60. package/lib/{calendar.d.ts → cjs/types/calendar.d.ts} +0 -0
  61. package/lib/{canvas.d.ts → cjs/types/canvas.d.ts} +0 -0
  62. package/lib/{cardview.d.ts → cjs/types/cardview.d.ts} +0 -0
  63. package/lib/{checkbox.d.ts → cjs/types/checkbox.d.ts} +0 -0
  64. package/lib/{color.d.ts → cjs/types/color.d.ts} +0 -0
  65. package/lib/{colorpicker.d.ts → cjs/types/colorpicker.d.ts} +0 -0
  66. package/lib/{combobox.d.ts → cjs/types/combobox.d.ts} +0 -0
  67. package/lib/{component.d.ts → cjs/types/component.d.ts} +1 -7
  68. package/lib/{datastore.d.ts → cjs/types/datastore.d.ts} +0 -0
  69. package/lib/{dialog.d.ts → cjs/types/dialog.d.ts} +0 -0
  70. package/lib/{dom_events.d.ts → cjs/types/dom_events.d.ts} +0 -0
  71. package/lib/{drag_manager.d.ts → cjs/types/drag_manager.d.ts} +0 -0
  72. package/lib/{drawtext.d.ts → cjs/types/drawtext.d.ts} +0 -0
  73. package/lib/{fileupload.d.ts → cjs/types/fileupload.d.ts} +0 -0
  74. package/lib/{form.d.ts → cjs/types/form.d.ts} +0 -0
  75. package/lib/{formatters.d.ts → cjs/types/formatters.d.ts} +0 -0
  76. package/lib/{gridview.d.ts → cjs/types/gridview.d.ts} +0 -0
  77. package/lib/{i18n.d.ts → cjs/types/i18n.d.ts} +0 -0
  78. package/lib/{icon.d.ts → cjs/types/icon.d.ts} +0 -0
  79. package/lib/{image.d.ts → cjs/types/image.d.ts} +0 -0
  80. package/lib/{index.d.ts → cjs/types/index.d.ts} +0 -0
  81. package/lib/{input.d.ts → cjs/types/input.d.ts} +0 -0
  82. package/lib/{label.d.ts → cjs/types/label.d.ts} +0 -0
  83. package/lib/{layout.d.ts → cjs/types/layout.d.ts} +0 -0
  84. package/lib/{link.d.ts → cjs/types/link.d.ts} +0 -0
  85. package/lib/{listview.d.ts → cjs/types/listview.d.ts} +0 -0
  86. package/lib/{md5.d.ts → cjs/types/md5.d.ts} +0 -0
  87. package/lib/{menu.d.ts → cjs/types/menu.d.ts} +0 -0
  88. package/lib/{messagebox.d.ts → cjs/types/messagebox.d.ts} +0 -0
  89. package/lib/{panel.d.ts → cjs/types/panel.d.ts} +0 -0
  90. package/lib/{popup.d.ts → cjs/types/popup.d.ts} +0 -0
  91. package/lib/{property_editor.d.ts → cjs/types/property_editor.d.ts} +0 -0
  92. package/lib/{radiobtn.d.ts → cjs/types/radiobtn.d.ts} +0 -0
  93. package/lib/{rating.d.ts → cjs/types/rating.d.ts} +0 -0
  94. package/lib/{request.d.ts → cjs/types/request.d.ts} +0 -0
  95. package/lib/{router.d.ts → cjs/types/router.d.ts} +0 -0
  96. package/lib/{settings.d.ts → cjs/types/settings.d.ts} +0 -0
  97. package/lib/{sidebarview.d.ts → cjs/types/sidebarview.d.ts} +0 -0
  98. package/lib/{spreadsheet.d.ts → cjs/types/spreadsheet.d.ts} +0 -0
  99. package/lib/{styles.d.ts → cjs/types/styles.d.ts} +0 -0
  100. package/lib/{svgcomponent.d.ts → cjs/types/svgcomponent.d.ts} +0 -0
  101. package/lib/{tabbar.d.ts → cjs/types/tabbar.d.ts} +0 -0
  102. package/lib/{tabview.d.ts → cjs/types/tabview.d.ts} +0 -0
  103. package/lib/{textarea.d.ts → cjs/types/textarea.d.ts} +0 -0
  104. package/lib/{textedit.d.ts → cjs/types/textedit.d.ts} +0 -0
  105. package/lib/{toaster.d.ts → cjs/types/toaster.d.ts} +0 -0
  106. package/lib/{tools.d.ts → cjs/types/tools.d.ts} +0 -0
  107. package/lib/{tooltips.d.ts → cjs/types/tooltips.d.ts} +0 -0
  108. package/lib/{treeview.d.ts → cjs/types/treeview.d.ts} +0 -0
  109. package/lib/{version.d.ts → cjs/types/version.d.ts} +0 -0
  110. package/lib/{x4dom.d.ts → cjs/types/x4dom.d.ts} +0 -0
  111. package/lib/{x4events.d.ts → cjs/types/x4events.d.ts} +0 -0
  112. package/lib/cjs/types/x4react.d.ts +41 -0
  113. package/lib/{version.js → cjs/version.js} +0 -0
  114. package/lib/{x4dom.js → cjs/x4dom.js} +0 -0
  115. package/lib/{x4events.js → cjs/x4events.js} +6 -11
  116. package/lib/cjs/x4react.js +72 -0
  117. package/lib/esm/action.js +53 -0
  118. package/lib/esm/application.js +184 -0
  119. package/lib/esm/autocomplete.js +155 -0
  120. package/lib/{base_component.js → esm/base_component.js} +3 -7
  121. package/lib/esm/button.js +257 -0
  122. package/lib/esm/calendar.js +244 -0
  123. package/lib/esm/canvas.js +358 -0
  124. package/lib/esm/cardview.js +159 -0
  125. package/lib/esm/checkbox.js +133 -0
  126. package/lib/{color.js → esm/color.js} +3 -7
  127. package/lib/esm/colorpicker.js +1475 -0
  128. package/lib/esm/combobox.js +259 -0
  129. package/lib/esm/component.js +1711 -0
  130. package/lib/esm/datastore.js +990 -0
  131. package/lib/esm/dialog.js +490 -0
  132. package/lib/{base64.d.ts → esm/dom_events.js} +2 -8
  133. package/lib/esm/drag_manager.js +147 -0
  134. package/lib/esm/drawtext.js +271 -0
  135. package/lib/esm/fileupload.js +163 -0
  136. package/lib/esm/form.js +297 -0
  137. package/lib/esm/formatters.js +81 -0
  138. package/lib/esm/gridview.js +889 -0
  139. package/lib/esm/i18n.js +257 -0
  140. package/lib/esm/icon.js +256 -0
  141. package/lib/esm/image.js +154 -0
  142. package/lib/esm/index.mjs +86 -0
  143. package/lib/{input.js → esm/input.js} +2 -6
  144. package/lib/esm/label.js +90 -0
  145. package/lib/esm/layout.js +310 -0
  146. package/lib/esm/link.js +59 -0
  147. package/lib/{listview.js → esm/listview.js} +30 -36
  148. package/lib/{md5.js → esm/md5.js} +1 -5
  149. package/lib/esm/menu.js +300 -0
  150. package/lib/esm/messagebox.js +145 -0
  151. package/lib/esm/panel.js +65 -0
  152. package/lib/esm/popup.js +379 -0
  153. package/lib/esm/property_editor.js +251 -0
  154. package/lib/esm/radiobtn.js +136 -0
  155. package/lib/esm/rating.js +97 -0
  156. package/lib/{request.js → esm/request.js} +9 -16
  157. package/lib/esm/router.js +136 -0
  158. package/lib/{settings.js → esm/settings.js} +1 -5
  159. package/lib/esm/sidebarview.js +79 -0
  160. package/lib/esm/spreadsheet.js +1091 -0
  161. package/lib/esm/styles.js +270 -0
  162. package/lib/esm/svgcomponent.js +422 -0
  163. package/lib/esm/tabbar.js +107 -0
  164. package/lib/esm/tabview.js +83 -0
  165. package/lib/esm/textarea.js +123 -0
  166. package/lib/esm/textedit.js +412 -0
  167. package/lib/esm/toaster.js +62 -0
  168. package/lib/esm/tools.js +1155 -0
  169. package/lib/esm/tooltips.js +153 -0
  170. package/lib/esm/treeview.js +495 -0
  171. package/lib/esm/types/action.d.ts +57 -0
  172. package/lib/esm/types/application.d.ts +104 -0
  173. package/lib/esm/types/autocomplete.d.ts +58 -0
  174. package/lib/esm/types/base_component.d.ts +88 -0
  175. package/lib/esm/types/button.d.ts +151 -0
  176. package/lib/esm/types/calendar.d.ts +81 -0
  177. package/lib/esm/types/canvas.d.ts +92 -0
  178. package/lib/esm/types/cardview.d.ts +87 -0
  179. package/lib/esm/types/checkbox.d.ts +77 -0
  180. package/lib/esm/types/color.d.ts +148 -0
  181. package/lib/esm/types/colorpicker.d.ts +107 -0
  182. package/lib/esm/types/combobox.d.ts +101 -0
  183. package/lib/esm/types/component.d.ts +601 -0
  184. package/lib/esm/types/datastore.d.ts +396 -0
  185. package/lib/esm/types/dialog.d.ts +175 -0
  186. package/lib/esm/types/dom_events.d.ts +302 -0
  187. package/lib/esm/types/drag_manager.d.ts +54 -0
  188. package/lib/esm/types/drawtext.d.ts +48 -0
  189. package/lib/esm/types/fileupload.d.ts +64 -0
  190. package/lib/esm/types/form.d.ts +126 -0
  191. package/lib/esm/types/formatters.d.ts +35 -0
  192. package/lib/esm/types/gridview.d.ts +175 -0
  193. package/lib/esm/types/i18n.d.ts +73 -0
  194. package/lib/esm/types/icon.d.ts +64 -0
  195. package/lib/esm/types/image.d.ts +55 -0
  196. package/lib/esm/types/index.d.ts +83 -0
  197. package/lib/esm/types/input.d.ts +91 -0
  198. package/lib/esm/types/label.d.ts +58 -0
  199. package/lib/esm/types/layout.d.ts +87 -0
  200. package/lib/esm/types/link.d.ts +50 -0
  201. package/lib/esm/types/listview.d.ts +178 -0
  202. package/lib/esm/types/md5.d.ts +61 -0
  203. package/lib/esm/types/menu.d.ts +130 -0
  204. package/lib/esm/types/messagebox.d.ts +68 -0
  205. package/lib/esm/types/panel.d.ts +47 -0
  206. package/lib/esm/types/popup.d.ts +75 -0
  207. package/lib/esm/types/property_editor.d.ts +71 -0
  208. package/lib/esm/types/radiobtn.d.ts +72 -0
  209. package/lib/esm/types/rating.d.ts +53 -0
  210. package/lib/esm/types/request.d.ts +52 -0
  211. package/lib/esm/types/router.d.ts +42 -0
  212. package/lib/esm/types/settings.d.ts +37 -0
  213. package/lib/esm/types/sidebarview.d.ts +49 -0
  214. package/lib/esm/types/spreadsheet.d.ts +218 -0
  215. package/lib/esm/types/styles.d.ts +85 -0
  216. package/lib/esm/types/svgcomponent.d.ts +191 -0
  217. package/lib/esm/types/tabbar.d.ts +58 -0
  218. package/lib/esm/types/tabview.d.ts +49 -0
  219. package/lib/{texthiliter.d.ts → esm/types/textarea.d.ts} +26 -23
  220. package/lib/esm/types/textedit.d.ts +123 -0
  221. package/lib/esm/types/toaster.d.ts +42 -0
  222. package/lib/esm/types/tools.d.ts +394 -0
  223. package/lib/esm/types/tooltips.d.ts +46 -0
  224. package/lib/esm/types/treeview.d.ts +132 -0
  225. package/lib/esm/types/version.d.ts +29 -0
  226. package/lib/esm/types/x4dom.d.ts +49 -0
  227. package/lib/{x4_events.d.ts → esm/types/x4events.d.ts} +6 -3
  228. package/lib/esm/types/x4react.d.ts +41 -0
  229. package/lib/esm/version.js +29 -0
  230. package/lib/esm/x4dom.js +29 -0
  231. package/lib/{x4_events.js → esm/x4events.js} +11 -24
  232. package/lib/esm/x4react.js +71 -0
  233. package/lib/{x4.css → styles/x4.css} +11 -0
  234. package/{src → lib/styles}/x4.less +14 -0
  235. package/package.json +35 -14
  236. package/build.sh +0 -5
  237. package/lib/base64.js +0 -143
  238. package/lib/hosts/host.d.ts +0 -44
  239. package/lib/hosts/host.js +0 -73
  240. package/lib/smartedit.d.ts +0 -107
  241. package/lib/smartedit.js +0 -390
  242. package/lib/texthiliter.js +0 -227
  243. package/lib/x4react.d.ts +0 -6
  244. package/lib/x4react.js +0 -35
  245. package/src/MIT-license.md +0 -14
  246. package/src/action.ts +0 -88
  247. package/src/alpha.jpg +0 -0
  248. package/src/application.ts +0 -251
  249. package/src/autocomplete.ts +0 -197
  250. package/src/base64.ts +0 -166
  251. package/src/base_component.ts +0 -152
  252. package/src/button.ts +0 -355
  253. package/src/calendar.ts +0 -322
  254. package/src/canvas.ts +0 -505
  255. package/src/cardview.ts +0 -227
  256. package/src/checkbox.ts +0 -187
  257. package/src/color.ts +0 -752
  258. package/src/colorpicker.ts +0 -1639
  259. package/src/combobox.ts +0 -362
  260. package/src/component.ts +0 -2344
  261. package/src/datastore.ts +0 -1322
  262. package/src/dialog.ts +0 -656
  263. package/src/dom_events.ts +0 -315
  264. package/src/drag_manager.ts +0 -199
  265. package/src/drawtext.ts +0 -355
  266. package/src/fileupload.ts +0 -213
  267. package/src/form.ts +0 -366
  268. package/src/formatters.ts +0 -105
  269. package/src/gridview.ts +0 -1185
  270. package/src/i18n.ts +0 -346
  271. package/src/icon.ts +0 -329
  272. package/src/image.ts +0 -204
  273. package/src/index.ts +0 -88
  274. package/src/input.ts +0 -249
  275. package/src/label.ts +0 -128
  276. package/src/layout.ts +0 -430
  277. package/src/link.ts +0 -86
  278. package/src/listview.ts +0 -762
  279. package/src/menu.ts +0 -425
  280. package/src/messagebox.ts +0 -203
  281. package/src/panel.ts +0 -86
  282. package/src/popup.ts +0 -494
  283. package/src/property_editor.ts +0 -337
  284. package/src/radiobtn.ts +0 -196
  285. package/src/rating.ts +0 -135
  286. package/src/request.ts +0 -300
  287. package/src/router.ts +0 -185
  288. package/src/settings.ts +0 -77
  289. package/src/sidebarview.ts +0 -103
  290. package/src/spreadsheet.ts +0 -1442
  291. package/src/styles.ts +0 -343
  292. package/src/svgcomponent.ts +0 -537
  293. package/src/tabbar.ts +0 -151
  294. package/src/tabview.ts +0 -110
  295. package/src/textarea.ts +0 -187
  296. package/src/textedit.ts +0 -544
  297. package/src/toaster.ts +0 -80
  298. package/src/tools.ts +0 -1468
  299. package/src/tooltips.ts +0 -191
  300. package/src/treeview.ts +0 -675
  301. package/src/version.ts +0 -30
  302. package/src/x4dom.ts +0 -57
  303. package/src/x4events.ts +0 -585
  304. package/src/x4react.ts +0 -42
  305. package/tsconfig.json +0 -21
@@ -48,12 +48,6 @@ class MenuTitle extends label_1.Label {
48
48
  }
49
49
  exports.MenuTitle = MenuTitle;
50
50
  class Menu extends popup_1.Popup {
51
- static watchCount = 0;
52
- static rootMenu = null;
53
- m_subMenu;
54
- m_opener;
55
- m_virtual;
56
- m_lock;
57
51
  constructor(props, opener) {
58
52
  super(props);
59
53
  this.addClass('@shadow');
@@ -175,10 +169,9 @@ class Menu extends popup_1.Popup {
175
169
  }
176
170
  }
177
171
  exports.Menu = Menu;
172
+ Menu.watchCount = 0;
173
+ Menu.rootMenu = null;
178
174
  class MenuItem extends component_1.Component {
179
- m_menu;
180
- m_isOpen;
181
- m_action;
182
175
  constructor(a, b) {
183
176
  if (a instanceof action_1.Action) {
184
177
  super({
@@ -203,7 +196,8 @@ class MenuItem extends component_1.Component {
203
196
  }
204
197
  /** @ignore */
205
198
  render(props) {
206
- let icon = props.icon ?? 0;
199
+ var _a;
200
+ let icon = (_a = props.icon) !== null && _a !== void 0 ? _a : 0;
207
201
  let text = props.text;
208
202
  if (props.checked !== undefined) {
209
203
  icon = props.checked ? 'var( --x4-icon-check )' : 0;
@@ -293,7 +287,6 @@ exports.MenuItem = MenuItem;
293
287
  *
294
288
  */
295
289
  class MenuBar extends layout_1.HLayout {
296
- m_items;
297
290
  constructor(props, opener) {
298
291
  super(props);
299
292
  console.assert(false, 'not imp');
@@ -36,10 +36,10 @@ const icon_1 = require("./icon");
36
36
  const label_1 = require("./label");
37
37
  const textedit_1 = require("./textedit");
38
38
  class MessageBox extends dialog_1.Dialog {
39
- m_label;
40
39
  constructor(props) {
40
+ var _a;
41
41
  // remove overloaded elements from DialogBoxProps
42
- let icon = props.icon ?? 'var( --x4-icon-exclamation )'; // todo: resolve that
42
+ let icon = (_a = props.icon) !== null && _a !== void 0 ? _a : 'var( --x4-icon-exclamation )'; // todo: resolve that
43
43
  props.icon = undefined;
44
44
  let buttons = props.buttons === undefined ? ['ok'] : props.buttons;
45
45
  props.buttons = undefined;
@@ -94,13 +94,13 @@ class MessageBox extends dialog_1.Dialog {
94
94
  }
95
95
  exports.MessageBox = MessageBox;
96
96
  class PromptDialogBox extends dialog_1.Dialog {
97
- m_edit;
98
97
  constructor(props) {
98
+ var _a;
99
99
  // remove overloaded elements from DialogBoxProps
100
100
  //let icon = props.icon; // ?? 'cls(far fa-comment-check)'; // todo: resolve that
101
101
  //props.icon = undefined;
102
102
  props.buttons = undefined;
103
- props.width = props.width ?? 500;
103
+ props.width = (_a = props.width) !== null && _a !== void 0 ? _a : 500;
104
104
  super(props);
105
105
  this.form.updateContent(new layout_1.HLayout({
106
106
  cls: 'panel',
@@ -34,18 +34,17 @@ const layout_1 = require("./layout");
34
34
  const label_1 = require("./label");
35
35
  const icon_1 = require("./icon");
36
36
  class Panel extends layout_1.VLayout {
37
- m_ui_title;
38
- m_ui_body;
39
37
  constructor(props) {
40
38
  super(props);
41
- const sens = props?.sens == 'horizontal' ? '@hlayout' : '@vlayout';
39
+ const sens = (props === null || props === void 0 ? void 0 : props.sens) == 'horizontal' ? '@hlayout' : '@vlayout';
42
40
  //todo: cannot be called twice do to content overload
43
41
  this.m_ui_title = new label_1.Label({ cls: 'title', text: this.m_props.title });
44
42
  this.m_ui_body = new component_1.Component({ cls: 'body ' + sens, content: this.m_props.content, style: props.bodyStyle });
45
43
  }
46
44
  /** @ignore */
47
45
  render() {
48
- const gadgets = this.m_props.gadgets ?? [];
46
+ var _a;
47
+ const gadgets = (_a = this.m_props.gadgets) !== null && _a !== void 0 ? _a : [];
49
48
  const icon = this.m_props.icon ? new icon_1.Icon({ icon: this.m_props.icon }) : null;
50
49
  super.setContent([
51
50
  new layout_1.HLayout({
@@ -42,11 +42,9 @@ exports.EvMove = EvMove;
42
42
  * base class for all popup elements
43
43
  */
44
44
  class Popup extends component_1.Container {
45
- m_ui_mask;
46
- m_hasMask = true;
47
- static modal_stack = [];
48
45
  constructor(props) {
49
46
  super(props);
47
+ this.m_hasMask = true;
50
48
  this.addClass('@hidden');
51
49
  }
52
50
  enableMask(enable = true) {
@@ -164,7 +162,7 @@ class Popup extends component_1.Container {
164
162
  }
165
163
  if ((x + rm.width) > rc.right - 4) {
166
164
  x = rc.right - 4 - rm.width;
167
- if (offset?.x < 0) {
165
+ if ((offset === null || offset === void 0 ? void 0 : offset.x) < 0) {
168
166
  x += offset.x;
169
167
  }
170
168
  }
@@ -173,7 +171,7 @@ class Popup extends component_1.Container {
173
171
  }
174
172
  if ((y + rm.height) > rc.bottom - 4) {
175
173
  y = rc.bottom - 4 - rm.height;
176
- if (offset?.y < 0) {
174
+ if ((offset === null || offset === void 0 ? void 0 : offset.y) < 0) {
177
175
  y += offset.y;
178
176
  }
179
177
  }
@@ -312,6 +310,7 @@ class Popup extends component_1.Container {
312
310
  }
313
311
  }
314
312
  exports.Popup = Popup;
313
+ Popup.modal_stack = [];
315
314
  /**
316
315
  * handle tab key
317
316
  */
@@ -37,17 +37,14 @@ const checkbox_1 = require("./checkbox");
37
37
  const spreadsheet_1 = require("./spreadsheet");
38
38
  const i18n_1 = require("./i18n");
39
39
  class PropertyEditor extends component_1.Component {
40
- m_fields;
41
- m_record;
42
- m_sheet;
43
- m_label_w;
44
40
  constructor(props) {
45
41
  super(props);
46
42
  this.mapPropEvents(props, 'change');
47
43
  }
48
44
  render(props) {
45
+ var _a;
49
46
  this.m_record = props.record;
50
- this.m_fields = props.fields ?? [];
47
+ this.m_fields = (_a = props.fields) !== null && _a !== void 0 ? _a : [];
51
48
  this.m_label_w = props.labelWidth;
52
49
  this.m_sheet = new spreadsheet_1.Spreadsheet({
53
50
  cls: '@fit',
@@ -38,18 +38,18 @@ const label_1 = require("./label");
38
38
  * Standard RadioBtn
39
39
  */
40
40
  class RadioBtn extends component_1.Component {
41
- m_ui_input; // todo: remove that / use ref
42
41
  constructor(props) {
43
42
  super(props);
44
43
  this.mapPropEvents(props, 'change');
45
44
  }
46
45
  /** @ignore */
47
46
  render(props) {
48
- let text = props.text ?? '';
49
- let name = props.name ?? props.group;
50
- let labelWidth = props.labelWidth ?? -1;
51
- let checked = props.checked ?? false;
52
- let align = props.align ?? 'left';
47
+ var _a, _b, _c, _d, _e;
48
+ let text = (_a = props.text) !== null && _a !== void 0 ? _a : '';
49
+ let name = (_b = props.name) !== null && _b !== void 0 ? _b : props.group;
50
+ let labelWidth = (_c = props.labelWidth) !== null && _c !== void 0 ? _c : -1;
51
+ let checked = (_d = props.checked) !== null && _d !== void 0 ? _d : false;
52
+ let align = (_e = props.align) !== null && _e !== void 0 ? _e : 'left';
53
53
  let value = props.value;
54
54
  let icon = props.icon;
55
55
  this.setTag('label');
@@ -34,15 +34,15 @@ const layout_1 = require("./layout");
34
34
  const input_1 = require("./input");
35
35
  const x4events_1 = require("./x4events");
36
36
  class Rating extends layout_1.HLayout {
37
- m_els;
38
- m_input;
39
37
  constructor(props) {
38
+ var _a;
40
39
  super(props);
41
- props.steps = props.steps ?? 5;
40
+ props.steps = (_a = props.steps) !== null && _a !== void 0 ? _a : 5;
42
41
  }
43
42
  render(props) {
44
- let shape = props.shape ?? 'star';
45
- let value = props.value ?? 0;
43
+ var _a, _b;
44
+ let shape = (_a = props.shape) !== null && _a !== void 0 ? _a : 'star';
45
+ let value = (_b = props.value) !== null && _b !== void 0 ? _b : 0;
46
46
  this.m_input = new input_1.Input({
47
47
  cls: '@hidden',
48
48
  name: props.name,
@@ -67,7 +67,8 @@ class Rating extends layout_1.HLayout {
67
67
  this.setContent(this.m_els);
68
68
  }
69
69
  getValue() {
70
- return this.m_props.value ?? 0;
70
+ var _a;
71
+ return (_a = this.m_props.value) !== null && _a !== void 0 ? _a : 0;
71
72
  }
72
73
  set value(v) {
73
74
  this.m_props.value = v;
@@ -0,0 +1,246 @@
1
+ "use strict";
2
+ /**
3
+ * ___ ___ __
4
+ * \ \_/ / / _
5
+ * \ / /_| |_
6
+ * / _ \____ _|
7
+ * /__/ \__\ |_|
8
+ *
9
+ * @file request.ts
10
+ * @author Etienne Cochard
11
+ *
12
+ * Copyright (c) 2019-2022 R-libre ingenierie
13
+ *
14
+ * Permission is hereby granted, free of charge, to any person obtaining a copy
15
+ * of this software and associated documentation files (the "Software"), to deal
16
+ * in the Software without restriction, including without limitation the rights
17
+ * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies
18
+ * of the Software, and to permit persons to whom the Software is furnished to do so,
19
+ * subject to the following conditions:
20
+ * The above copyright notice and this permission notice shall be included in all copies
21
+ * or substantial portions of the Software.
22
+ *
23
+ * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED,
24
+ * INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A
25
+ * PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT
26
+ * HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
27
+ * OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
28
+ * SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
29
+ **/
30
+ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
31
+ function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
32
+ return new (P || (P = Promise))(function (resolve, reject) {
33
+ function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
34
+ function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
35
+ function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
36
+ step((generator = generator.apply(thisArg, _arguments || [])).next());
37
+ });
38
+ };
39
+ Object.defineProperty(exports, "__esModule", { value: true });
40
+ exports.ajax = exports.ajaxAsText = exports.ajaxAsJSON = exports.ajaxRequest = void 0;
41
+ /**
42
+ * TODO: use fetch api
43
+ *
44
+
45
+ async function xx( resp, cb ) {
46
+ cb( await resp.json() );
47
+ }
48
+
49
+ async function getToto( cb ) {
50
+ fetch('home/toto', { method: 'GET' }).then( (resp) => { xx(resp,cb); } );
51
+ }
52
+
53
+ function dump( resp ) {
54
+ console.log( resp );
55
+ }
56
+
57
+ getToto( dump );
58
+
59
+ */
60
+ const tools_1 = require("./tools");
61
+ const DEFAULT_TIMEOUT = 10000;
62
+ function ajaxRequest(cfg) {
63
+ let params, url = cfg.url, method = cfg.method || 'GET', formdata = false;
64
+ if (cfg.params instanceof FormData) {
65
+ params = cfg.params;
66
+ formdata = true;
67
+ }
68
+ else if (method == 'POST') {
69
+ params = buildQuery(cfg.params, false);
70
+ }
71
+ else {
72
+ url += buildQuery(cfg.params, true);
73
+ }
74
+ url = encodeURI(url);
75
+ let xhr = new XMLHttpRequest();
76
+ xhr.open(method, url);
77
+ xhr.upload.addEventListener('progress', progress, false);
78
+ xhr.addEventListener('timeout', failure);
79
+ xhr.addEventListener('error', failure);
80
+ xhr.addEventListener('load', success);
81
+ if (!formdata) {
82
+ xhr.setRequestHeader("Content-type", "application/x-www-form-urlencoded; charset=UTF-8");
83
+ }
84
+ if (method != 'POST') {
85
+ xhr.responseType = cfg.responseType || 'json';
86
+ xhr.timeout = cfg.timeout || DEFAULT_TIMEOUT;
87
+ }
88
+ if (cfg.headers) {
89
+ for (let h in cfg.headers) {
90
+ xhr.setRequestHeader(h, cfg.headers[h]);
91
+ }
92
+ }
93
+ function progress(ev) {
94
+ console.log(ev);
95
+ if (cfg.progress) {
96
+ try {
97
+ if (ev.lengthComputable) {
98
+ let disp = humanSize(ev.loaded) + ' / ' + humanSize(ev.total);
99
+ cfg.progress(ev.loaded, ev.total, disp);
100
+ }
101
+ }
102
+ catch (e) {
103
+ console.error('unhandled exception:', e);
104
+ }
105
+ }
106
+ }
107
+ function humanSize(bytes) {
108
+ let unit, value;
109
+ if (bytes >= 1e9) {
110
+ unit = 'Gb';
111
+ value = bytes / 1e9;
112
+ }
113
+ else if (bytes >= 1e6) {
114
+ unit = 'Mb';
115
+ value = bytes / 1e6;
116
+ }
117
+ else if (bytes >= 1e3) {
118
+ unit = 'Kb';
119
+ value = bytes / 1e3;
120
+ }
121
+ else {
122
+ unit = 'bytes';
123
+ value = bytes;
124
+ }
125
+ return value.toFixed(2) + unit;
126
+ }
127
+ function failure() {
128
+ if (cfg.failure) {
129
+ cfg.failure(xhr.status, xhr.statusText, cfg.userData);
130
+ }
131
+ }
132
+ function success() {
133
+ if (xhr.status >= 200 && xhr.status < 300) {
134
+ if (cfg.success) {
135
+ try {
136
+ cfg.success(xhr.response, cfg.userData);
137
+ }
138
+ catch (e) {
139
+ console.error('unhandled exception:', e);
140
+ }
141
+ }
142
+ }
143
+ else {
144
+ failure();
145
+ }
146
+ }
147
+ if (formdata || method == 'POST') {
148
+ xhr.send(params);
149
+ }
150
+ else {
151
+ xhr.send();
152
+ }
153
+ return function () {
154
+ xhr.abort();
155
+ };
156
+ }
157
+ exports.ajaxRequest = ajaxRequest;
158
+ function buildQuery(params, getMethod) {
159
+ if (!params) {
160
+ return '';
161
+ }
162
+ let query = [];
163
+ for (let key in params) {
164
+ let param = params[key];
165
+ // array
166
+ if ((0, tools_1.isArray)(param)) {
167
+ for (let i = 0, n = param.length; i < n; i++) {
168
+ query.push(encodeURIComponent(key) + '[]=' + encodeURIComponent('' + param[i]));
169
+ }
170
+ }
171
+ // simple string ...
172
+ else {
173
+ if (param === undefined) {
174
+ param = '';
175
+ }
176
+ query.push(encodeURIComponent(key) + '=' + encodeURIComponent('' + param));
177
+ }
178
+ }
179
+ let result = query.join('&');
180
+ if (getMethod) {
181
+ return '?' + result;
182
+ }
183
+ else {
184
+ return result;
185
+ }
186
+ }
187
+ function ajaxAsJSON(url, init) {
188
+ return __awaiter(this, void 0, void 0, function* () {
189
+ let response = yield ajax(url, init, 'application/json');
190
+ return response.json();
191
+ });
192
+ }
193
+ exports.ajaxAsJSON = ajaxAsJSON;
194
+ function ajaxAsText(url, init) {
195
+ return __awaiter(this, void 0, void 0, function* () {
196
+ let response = yield ajax(url, init, 'text/plain');
197
+ return response.text();
198
+ });
199
+ }
200
+ exports.ajaxAsText = ajaxAsText;
201
+ /**
202
+ * use encodeURIComponent for elements in url
203
+ */
204
+ function ajax(url, init, type) {
205
+ return __awaiter(this, void 0, void 0, function* () {
206
+ let options = {
207
+ method: 'GET',
208
+ headers: {
209
+ 'X-Requested-With': 'XMLHttpRequest'
210
+ }
211
+ };
212
+ if (type) {
213
+ options.headers['Content-Type'] = type;
214
+ }
215
+ if (init) {
216
+ options = Object.assign(Object.assign({}, options), init);
217
+ if (init.body && !(0, tools_1.isString)(init.body)) {
218
+ let cvt = false;
219
+ if ((0, tools_1.isLiteralObject)(init.body)) {
220
+ cvt = true;
221
+ }
222
+ else if (!(init.body instanceof Blob) && !(init.body instanceof ArrayBuffer) && !(init.body instanceof FormData) &&
223
+ !(init.body instanceof URLSearchParams) && !(init.body instanceof ReadableStream)) {
224
+ cvt = true;
225
+ }
226
+ if (cvt) {
227
+ options.body = JSON.stringify(init.body);
228
+ }
229
+ else {
230
+ options.body = init.body;
231
+ }
232
+ }
233
+ }
234
+ let response = yield fetch(url, options);
235
+ if (init && init.noGenX) {
236
+ return response;
237
+ }
238
+ else {
239
+ if (!response.ok) {
240
+ throw new tools_1.NetworkError(response);
241
+ }
242
+ return response;
243
+ }
244
+ });
245
+ }
246
+ exports.ajax = ajax;
@@ -69,7 +69,6 @@ function parseRoute(str, loose = false) {
69
69
  };
70
70
  }
71
71
  class Router extends x4events_1.EventSource {
72
- routes;
73
72
  constructor() {
74
73
  super();
75
74
  this.routes = [];
@@ -0,0 +1,69 @@
1
+ "use strict";
2
+ /**
3
+ * ___ ___ __
4
+ * \ \_/ / / _
5
+ * \ / /_| |_
6
+ * / _ \____ _|
7
+ * /__/ \__\ |_|
8
+ *
9
+ * @file local_storage.ts
10
+ * @author Etienne Cochard
11
+ *
12
+ * Copyright (c) 2019-2022 R-libre ingenierie
13
+ *
14
+ * Permission is hereby granted, free of charge, to any person obtaining a copy
15
+ * of this software and associated documentation files (the "Software"), to deal
16
+ * in the Software without restriction, including without limitation the rights
17
+ * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies
18
+ * of the Software, and to permit persons to whom the Software is furnished to do so,
19
+ * subject to the following conditions:
20
+ * The above copyright notice and this permission notice shall be included in all copies
21
+ * or substantial portions of the Software.
22
+ *
23
+ * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED,
24
+ * INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A
25
+ * PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT
26
+ * HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
27
+ * OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
28
+ * SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
29
+ **/
30
+ Object.defineProperty(exports, "__esModule", { value: true });
31
+ exports.Settings = void 0;
32
+ class Settings {
33
+ constructor(name) {
34
+ this.m_data = null;
35
+ this.m_name = name !== null && name !== void 0 ? name : 'settings';
36
+ }
37
+ set(name, value) {
38
+ this._load();
39
+ this.m_data[name] = value;
40
+ this._save();
41
+ }
42
+ get(name, defValue) {
43
+ var _a;
44
+ this._load();
45
+ return (_a = this.m_data[name]) !== null && _a !== void 0 ? _a : defValue;
46
+ }
47
+ _save() {
48
+ let data = JSON.stringify(this.m_data);
49
+ localStorage.setItem(this.m_name, data);
50
+ }
51
+ _load() {
52
+ if (this.m_data) {
53
+ return;
54
+ }
55
+ this.m_data = {};
56
+ let data = localStorage.getItem(this.m_name);
57
+ if (data !== null) {
58
+ data = JSON.parse(data);
59
+ if (data) {
60
+ this.m_data = data;
61
+ }
62
+ else {
63
+ console.info('There was an error attempting to read your settings.');
64
+ }
65
+ }
66
+ // console.info('There was an error attempting to read your settings.');
67
+ }
68
+ }
69
+ exports.Settings = Settings;
@@ -37,14 +37,13 @@ const cardview_1 = require("./cardview");
37
37
  *
38
38
  */
39
39
  class SideBarView extends cardview_1.CardView {
40
- m_sidebar;
41
- m_content;
42
40
  constructor(props) {
41
+ var _a;
43
42
  super(props);
44
43
  this.addClass('@hlayout');
45
44
  this.m_sidebar = new layout_1.VLayout({
46
45
  cls: '@side-bar',
47
- width: props.bar_width ?? undefined,
46
+ width: (_a = props.bar_width) !== null && _a !== void 0 ? _a : undefined,
48
47
  });
49
48
  this.m_content = new layout_1.HLayout({ flex: 1, cls: '@tab-container' });
50
49
  }
@@ -38,34 +38,14 @@ const tools_2 = require("./tools");
38
38
  const x4events_1 = require("./x4events");
39
39
  const combobox_1 = require("./combobox");
40
40
  class CellData {
41
- text;
42
- cls;
43
- static empty_cell = {
44
- text: ''
45
- };
46
41
  }
42
+ CellData.empty_cell = {
43
+ text: ''
44
+ };
47
45
  /**
48
46
  *
49
47
  */
50
48
  class Spreadsheet extends layout_1.VLayout {
51
- m_columns;
52
- m_row_limit;
53
- m_cells_data;
54
- m_rows_data;
55
- m_view;
56
- m_container;
57
- m_header;
58
- m_itemHeight;
59
- m_topIndex;
60
- m_visible_cells;
61
- m_row_count; // visible row count
62
- m_selection;
63
- m_editor;
64
- m_autoedit;
65
- m_lockupdate;
66
- m_auto_row_count;
67
- m_recycler;
68
- m_used_cells;
69
49
  constructor(props) {
70
50
  super(props);
71
51
  this.m_columns = props.columns;
@@ -350,7 +330,8 @@ class Spreadsheet extends layout_1.VLayout {
350
330
  let calcz = new Int32Array(this.m_columns.length);
351
331
  let calcm = new Int32Array(this.m_columns.length);
352
332
  this.m_columns.forEach((col, colIdx) => {
353
- let minw = Math.max(10, col.min_width ?? 0);
333
+ var _a;
334
+ let minw = Math.max(10, (_a = col.min_width) !== null && _a !== void 0 ? _a : 0);
354
335
  if (col.width > 0) {
355
336
  let cw = Math.max(col.width, minw);
356
337
  fullw += cw;
@@ -614,7 +595,8 @@ class Spreadsheet extends layout_1.VLayout {
614
595
  *
615
596
  */
616
597
  _updateScroll(forceUpdate) {
617
- if (!this?.m_view?.dom) {
598
+ var _a;
599
+ if (!((_a = this === null || this === void 0 ? void 0 : this.m_view) === null || _a === void 0 ? void 0 : _a.dom)) {
618
600
  return;
619
601
  }
620
602
  let newTop = Math.floor(this.m_view.dom.scrollTop / (this.m_itemHeight || 1));
@@ -631,9 +613,10 @@ class Spreadsheet extends layout_1.VLayout {
631
613
  * @param t
632
614
  */
633
615
  _moveSel(sensy, sensx) {
616
+ var _a, _b;
634
617
  let sel = this.m_selection;
635
- let newRow = sel.row ?? 0;
636
- let newCol = sel.col ?? 0;
618
+ let newRow = (_a = sel.row) !== null && _a !== void 0 ? _a : 0;
619
+ let newCol = (_b = sel.col) !== null && _b !== void 0 ? _b : 0;
637
620
  if (sensy == 1) {
638
621
  newRow++;
639
622
  }
@@ -35,9 +35,8 @@ const tools_1 = require("./tools");
35
35
  * -- [ @STYLESHEET ] -----------------------------------------------------------------
36
36
  */
37
37
  class Stylesheet {
38
- m_sheet;
39
- m_rules = new Map();
40
38
  constructor() {
39
+ this.m_rules = new Map();
41
40
  function getStyleSheet(name) {
42
41
  for (let i = 0; i < x4dom_1.x4document.styleSheets.length; i++) {
43
42
  let sheet = x4dom_1.x4document.styleSheets[i];
@@ -106,17 +105,18 @@ class Stylesheet {
106
105
  }
107
106
  return Stylesheet.doc_style.getPropertyValue(name); // #999999
108
107
  }
109
- static guid = 1;
110
- static doc_style;
111
108
  }
112
109
  exports.Stylesheet = Stylesheet;
110
+ Stylesheet.guid = 1;
113
111
  /**
114
112
  * -- [ @CSSPARSER ] -----------------------------------------------------------------
115
113
  *
116
114
  * adaptation of jss-for-node-js
117
115
  */
118
116
  class CSSParser {
119
- result = {};
117
+ constructor() {
118
+ this.result = {};
119
+ }
120
120
  parse(css) {
121
121
  this.result = {};
122
122
  this.parse_json('', css);
@@ -248,7 +248,6 @@ class CSSParser {
248
248
  }
249
249
  exports.CSSParser = CSSParser;
250
250
  class ComputedStyle {
251
- m_style;
252
251
  constructor(style) {
253
252
  this.m_style = style;
254
253
  }