x4js 1.4.52 → 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 (303) 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} +16 -25
  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} +0 -0
  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/{x4react.d.ts → cjs/types/x4react.d.ts} +0 -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/{x4react.js → cjs/x4react.js} +1 -4
  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} +0 -0
  234. package/{src → lib/styles}/x4.less +0 -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/src/MIT-license.md +0 -14
  244. package/src/action.ts +0 -88
  245. package/src/alpha.jpg +0 -0
  246. package/src/application.ts +0 -251
  247. package/src/autocomplete.ts +0 -197
  248. package/src/base64.ts +0 -166
  249. package/src/base_component.ts +0 -152
  250. package/src/button.ts +0 -355
  251. package/src/calendar.ts +0 -322
  252. package/src/canvas.ts +0 -505
  253. package/src/cardview.ts +0 -227
  254. package/src/checkbox.ts +0 -187
  255. package/src/color.ts +0 -752
  256. package/src/colorpicker.ts +0 -1639
  257. package/src/combobox.ts +0 -362
  258. package/src/component.ts +0 -2329
  259. package/src/datastore.ts +0 -1322
  260. package/src/dialog.ts +0 -656
  261. package/src/dom_events.ts +0 -315
  262. package/src/drag_manager.ts +0 -199
  263. package/src/drawtext.ts +0 -355
  264. package/src/fileupload.ts +0 -213
  265. package/src/form.ts +0 -366
  266. package/src/formatters.ts +0 -105
  267. package/src/gridview.ts +0 -1185
  268. package/src/i18n.ts +0 -346
  269. package/src/icon.ts +0 -329
  270. package/src/image.ts +0 -204
  271. package/src/index.ts +0 -88
  272. package/src/input.ts +0 -249
  273. package/src/label.ts +0 -128
  274. package/src/layout.ts +0 -430
  275. package/src/link.ts +0 -86
  276. package/src/listview.ts +0 -762
  277. package/src/menu.ts +0 -425
  278. package/src/messagebox.ts +0 -203
  279. package/src/panel.ts +0 -86
  280. package/src/popup.ts +0 -494
  281. package/src/property_editor.ts +0 -337
  282. package/src/radiobtn.ts +0 -196
  283. package/src/rating.ts +0 -135
  284. package/src/request.ts +0 -300
  285. package/src/router.ts +0 -185
  286. package/src/settings.ts +0 -77
  287. package/src/sidebarview.ts +0 -103
  288. package/src/spreadsheet.ts +0 -1442
  289. package/src/styles.ts +0 -343
  290. package/src/svgcomponent.ts +0 -537
  291. package/src/tabbar.ts +0 -151
  292. package/src/tabview.ts +0 -110
  293. package/src/textarea.ts +0 -187
  294. package/src/textedit.ts +0 -544
  295. package/src/toaster.ts +0 -80
  296. package/src/tools.ts +0 -1468
  297. package/src/tooltips.ts +0 -191
  298. package/src/treeview.ts +0 -675
  299. package/src/version.ts +0 -30
  300. package/src/x4dom.ts +0 -57
  301. package/src/x4events.ts +0 -585
  302. package/src/x4react.ts +0 -90
  303. 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
  }