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
@@ -0,0 +1,191 @@
1
+ /**
2
+ * ___ ___ __
3
+ * \ \_/ / / _
4
+ * \ / /_| |_
5
+ * / _ \____ _|
6
+ * /__/ \__\ |_|
7
+ *
8
+ * @file svgcomponent.ts
9
+ * @author Etienne Cochard
10
+ *
11
+ * Copyright (c) 2019-2022 R-libre ingenierie
12
+ *
13
+ * Permission is hereby granted, free of charge, to any person obtaining a copy
14
+ * of this software and associated documentation files (the "Software"), to deal
15
+ * in the Software without restriction, including without limitation the rights
16
+ * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies
17
+ * of the Software, and to permit persons to whom the Software is furnished to do so,
18
+ * subject to the following conditions:
19
+ * The above copyright notice and this permission notice shall be included in all copies
20
+ * or substantial portions of the Software.
21
+ *
22
+ * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED,
23
+ * INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A
24
+ * PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT
25
+ * HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
26
+ * OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
27
+ * SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
28
+ **/
29
+ import { Component, CProps } from './component';
30
+ /**
31
+ *
32
+ */
33
+ declare abstract class SVGItem {
34
+ private m_tag;
35
+ private m_attrs;
36
+ private m_style;
37
+ constructor(tag: string);
38
+ /**
39
+ * render the item
40
+ * @returns
41
+ */
42
+ render(): string;
43
+ /**
44
+ * change the stroke color
45
+ * @param color
46
+ */
47
+ stroke(color: string, width?: number): this;
48
+ /**
49
+ * change the stroke width
50
+ * @param width
51
+ */
52
+ strokeWidth(width: number): this;
53
+ /**
54
+ * change the fill color
55
+ * @param color
56
+ */
57
+ fill(color: string): this;
58
+ /**
59
+ * define a new attribute
60
+ * @param name attibute name
61
+ * @param value attribute value
62
+ * @returns this
63
+ */
64
+ attr(name: string, value: string): this;
65
+ style(name: string, value: string | number): this;
66
+ /**
67
+ * add a class
68
+ * @param name class name to add
69
+ */
70
+ class(name: string): this;
71
+ /**
72
+ *
73
+ */
74
+ renderAttrs(): string;
75
+ /**
76
+ *
77
+ */
78
+ renderStyle(): string;
79
+ /**
80
+ *
81
+ */
82
+ renderContent(): string;
83
+ /**
84
+ *
85
+ */
86
+ clip(id: string): this;
87
+ }
88
+ /**
89
+ *
90
+ */
91
+ declare class SVGPath extends SVGItem {
92
+ private m_path;
93
+ constructor();
94
+ renderAttrs(): string;
95
+ /**
96
+ * move the current pos
97
+ * @param x new pos x
98
+ * @param y new pos y
99
+ * @returns this
100
+ */
101
+ moveTo(x: number, y: number): this;
102
+ /**
103
+ * draw aline to the given point
104
+ * @param x end x
105
+ * @param y end y
106
+ * @returns this
107
+ */
108
+ lineTo(x: number, y: number): this;
109
+ /**
110
+ * close the currentPath
111
+ */
112
+ closePath(): this;
113
+ /**
114
+ * draw an arc
115
+ * @param x center x
116
+ * @param y center y
117
+ * @param r radius
118
+ * @param start angle start in degrees
119
+ * @param end angle end in degrees
120
+ * @returns this
121
+ */
122
+ arc(x: number, y: number, r: number, start: number, end: number): this;
123
+ }
124
+ /**
125
+ *
126
+ */
127
+ declare class SVGText extends SVGItem {
128
+ private m_text;
129
+ constructor(x: number, y: number, txt: string);
130
+ font(font: string): this;
131
+ fontSize(size: number | string): this;
132
+ fontWeight(weight: 'light' | 'normal' | 'bold'): this;
133
+ textAlign(align: 'left' | 'center' | 'right'): this;
134
+ verticalAlign(align: 'top' | 'center' | 'bottom'): this;
135
+ renderContent(): any;
136
+ }
137
+ /**
138
+ *
139
+ */
140
+ declare class SVGShape extends SVGItem {
141
+ constructor(tag: string);
142
+ }
143
+ /**
144
+ *
145
+ */
146
+ declare class SVGGradient extends SVGItem {
147
+ private static g_id;
148
+ private m_id;
149
+ private m_stops;
150
+ constructor(x1: number, y1: number, x2: number, y2: number);
151
+ get id(): string;
152
+ addStop(offset: number, color: string): this;
153
+ renderContent(): string;
154
+ }
155
+ /**
156
+ *
157
+ */
158
+ declare class SVGGroup extends SVGItem {
159
+ protected m_items: SVGItem[];
160
+ constructor(tag?: string);
161
+ path(): SVGPath;
162
+ text(x: any, y: any, txt: any): SVGText;
163
+ ellipse(x: any, y: any, r1: any, r2?: any): SVGShape;
164
+ rect(x: any, y: any, w: any, h: any): SVGShape;
165
+ gradient(x1: any, y1: any, x2: any, y2: any): SVGGradient;
166
+ /**
167
+ * clear
168
+ */
169
+ clear(): void;
170
+ renderContent(): string;
171
+ }
172
+ /**
173
+ *
174
+ */
175
+ export declare class SVGPathBuilder extends SVGGroup {
176
+ private static g_clip_id;
177
+ constructor();
178
+ addClip(x: number, y: number, w: number, h: number): string;
179
+ render(): string;
180
+ }
181
+ /**
182
+ *
183
+ */
184
+ export interface SVGProps extends CProps {
185
+ viewBox?: string;
186
+ path?: string;
187
+ }
188
+ export declare class SVGComponent<P extends SVGProps = SVGProps> extends Component<P> {
189
+ constructor(props: P);
190
+ }
191
+ export {};
@@ -0,0 +1,58 @@
1
+ /**
2
+ * ___ ___ __
3
+ * \ \_/ / / _
4
+ * \ / /_| |_
5
+ * / _ \____ _|
6
+ * /__/ \__\ |_|
7
+ *
8
+ * @file tabbar.ts
9
+ * @author Etienne Cochard
10
+ *
11
+ * Copyright (c) 2019-2022 R-libre ingenierie
12
+ *
13
+ * Permission is hereby granted, free of charge, to any person obtaining a copy
14
+ * of this software and associated documentation files (the "Software"), to deal
15
+ * in the Software without restriction, including without limitation the rights
16
+ * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies
17
+ * of the Software, and to permit persons to whom the Software is furnished to do so,
18
+ * subject to the following conditions:
19
+ * The above copyright notice and this permission notice shall be included in all copies
20
+ * or substantial portions of the Software.
21
+ *
22
+ * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED,
23
+ * INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A
24
+ * PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT
25
+ * HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
26
+ * OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
27
+ * SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
28
+ **/
29
+ import { Component, Container, ContainerEventMap, CProps, EventHandler } from './component';
30
+ import { EvChange } from './x4events';
31
+ import { IconID } from './icon.js';
32
+ interface TabBarEventMap extends ContainerEventMap {
33
+ change: EvChange;
34
+ }
35
+ interface TabBarProps extends CProps<TabBarEventMap> {
36
+ pages?: ITabPage[];
37
+ default?: string;
38
+ vertical?: boolean;
39
+ change: EventHandler<EvChange>;
40
+ }
41
+ export interface ITabPage {
42
+ id: string;
43
+ title?: string;
44
+ icon?: IconID;
45
+ page: Component;
46
+ }
47
+ export declare class TabBar extends Container<TabBarProps, TabBarEventMap> {
48
+ private m_pages;
49
+ private m_curPage;
50
+ constructor(props: TabBarProps);
51
+ componentCreated(): void;
52
+ addPage(page: ITabPage): void;
53
+ render(): void;
54
+ select(id: string | null, notify?: boolean): boolean;
55
+ private _select;
56
+ get selection(): Component<CProps<import("./component").CEventMap>, import("./component").CEventMap>;
57
+ }
58
+ export {};
@@ -0,0 +1,49 @@
1
+ /**
2
+ * ___ ___ __
3
+ * \ \_/ / / _
4
+ * \ / /_| |_
5
+ * / _ \____ _|
6
+ * /__/ \__\ |_|
7
+ *
8
+ * @file tabview.ts
9
+ * @author Etienne Cochard
10
+ *
11
+ * Copyright (c) 2019-2022 R-libre ingenierie
12
+ *
13
+ * Permission is hereby granted, free of charge, to any person obtaining a copy
14
+ * of this software and associated documentation files (the "Software"), to deal
15
+ * in the Software without restriction, including without limitation the rights
16
+ * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies
17
+ * of the Software, and to permit persons to whom the Software is furnished to do so,
18
+ * subject to the following conditions:
19
+ * The above copyright notice and this permission notice shall be included in all copies
20
+ * or substantial portions of the Software.
21
+ *
22
+ * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED,
23
+ * INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A
24
+ * PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT
25
+ * HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
26
+ * OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
27
+ * SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
28
+ **/
29
+ import { Component } from './component';
30
+ import { CardView, CardViewProps, ICardViewItem } from './cardview';
31
+ import { MenuItem } from './menu';
32
+ interface TabProps extends CardViewProps {
33
+ tab_selector?: boolean;
34
+ menu?: MenuItem;
35
+ }
36
+ /**
37
+ * Standard TabView class
38
+ */
39
+ export declare class TabView extends CardView<TabProps> {
40
+ protected m_tab_selector: boolean;
41
+ protected m_menu: MenuItem;
42
+ constructor(props: TabProps);
43
+ /** @ignore */
44
+ render(): void;
45
+ protected _updateSelector(): void;
46
+ protected _prepareSelector(card: ICardViewItem): Component;
47
+ protected _preparePage(page: Component): void;
48
+ }
49
+ export {};
@@ -5,7 +5,7 @@
5
5
  * / _ \____ _|
6
6
  * /__/ \__\ |_|
7
7
  *
8
- * @file texthiliter.ts
8
+ * @file textarea.ts
9
9
  * @author Etienne Cochard
10
10
  *
11
11
  * Copyright (c) 2019-2022 R-libre ingenierie
@@ -26,35 +26,38 @@
26
26
  * OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
27
27
  * SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
28
28
  **/
29
- /**
30
- * idea came from https://www.cdolivet.com/editarea
31
- */
32
29
  import { Component, CProps, CEventMap } from './component';
33
- import { EvChange } from './x4_events';
34
- interface TextHiliterEventMap extends CEventMap {
30
+ import { EvChange, EventCallback } from './x4events';
31
+ interface TextAreaEventMap extends CEventMap {
35
32
  change: EvChange;
36
33
  }
37
- interface TextHiliterProps extends CProps {
38
- text: string;
39
- kwList?: Set<string>;
40
- change?: EvChange;
34
+ export interface TextAreaProps extends CProps {
35
+ text?: string;
36
+ readOnly?: boolean;
37
+ tabIndex?: number;
38
+ placeHolder?: string;
39
+ name?: string;
40
+ rows?: number;
41
+ autoGrow?: boolean;
42
+ autoFocus?: boolean;
43
+ spellcheck?: boolean;
44
+ change?: EventCallback<EvChange>;
41
45
  }
42
- export declare class TextHiliter extends Component<TextHiliterProps, TextHiliterEventMap> {
43
- private m_text;
44
- private m_ed;
45
- private m_hi;
46
- private m_top;
47
- private m_kwList;
48
- constructor(props: TextHiliterProps);
46
+ export declare class TextArea extends Component<TextAreaProps, TextAreaEventMap> {
47
+ constructor(props: TextAreaProps);
49
48
  /** @ignore */
50
- render(): void;
49
+ render(props: TextAreaProps): void;
50
+ private _change;
51
51
  componentCreated(): void;
52
52
  get value(): string;
53
53
  set value(t: string);
54
- private _keydown;
55
- private _hiliteText;
56
- private _updateScroll;
57
- private _escape;
58
- private _tokenize;
54
+ private _calcHeight;
55
+ private _updateHeight;
56
+ /**
57
+ * insert text at cursor position
58
+ */
59
+ insertText(text: any): void;
60
+ getStoreValue(): any;
61
+ setStoreValue(value: any): void;
59
62
  }
60
63
  export {};
@@ -0,0 +1,123 @@
1
+ /**
2
+ * ___ ___ __
3
+ * \ \_/ / / _
4
+ * \ / /_| |_
5
+ * / _ \____ _|
6
+ * /__/ \__\ |_|
7
+ *
8
+ * @file textedit.ts
9
+ * @author Etienne Cochard
10
+ *
11
+ * Copyright (c) 2019-2022 R-libre ingenierie
12
+ *
13
+ * Permission is hereby granted, free of charge, to any person obtaining a copy
14
+ * of this software and associated documentation files (the "Software"), to deal
15
+ * in the Software without restriction, including without limitation the rights
16
+ * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies
17
+ * of the Software, and to permit persons to whom the Software is furnished to do so,
18
+ * subject to the following conditions:
19
+ * The above copyright notice and this permission notice shall be included in all copies
20
+ * or substantial portions of the Software.
21
+ *
22
+ * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED,
23
+ * INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A
24
+ * PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT
25
+ * HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
26
+ * OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
27
+ * SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
28
+ **/
29
+ import { Component, EvFocus, HtmlString } from './component';
30
+ import { Input, InputProps, InputEventMap } from './input';
31
+ import { IconID } from './icon';
32
+ import { EvClick, EvChange, EventCallback } from './x4events';
33
+ declare type ValidationFunction = (value: string) => string;
34
+ interface TextEditEventMap extends InputEventMap {
35
+ click: EvClick;
36
+ change: EvChange;
37
+ focus: EvFocus;
38
+ }
39
+ export interface TextEditProps extends InputProps<TextEditEventMap> {
40
+ label?: string | HtmlString;
41
+ labelWidth?: number;
42
+ labelAlign?: 'left' | 'right' | 'top';
43
+ required?: boolean;
44
+ spellcheck?: boolean;
45
+ icon?: IconID;
46
+ pattern?: string;
47
+ uppercase?: boolean;
48
+ format?: string | 'native';
49
+ autosel?: boolean;
50
+ gadgets?: Component[];
51
+ validator?: ValidationFunction;
52
+ change?: EventCallback<EvChange>;
53
+ click?: EventCallback<EvClick>;
54
+ focus?: EventCallback<EvFocus>;
55
+ }
56
+ /**
57
+ * TextEdit is a single line editor, it can have a label and an error descriptor.
58
+ */
59
+ export declare class TextEdit<T extends TextEditProps = TextEditProps, E extends TextEditEventMap = TextEditEventMap> extends Component<T, E> {
60
+ private m_cal_popup;
61
+ protected m_ui_input: Input;
62
+ private m_error_tip;
63
+ constructor(props: T);
64
+ componentCreated(): void;
65
+ componentDisposed(): void;
66
+ focus(): void;
67
+ /** @ignore */
68
+ render(props: TextEditProps): void;
69
+ enable(ena?: boolean): void;
70
+ disable(): void;
71
+ private _btnClick;
72
+ /**
73
+ * select the value format for input/output on textedit of type date
74
+ * cf. formatIntlDate / parseIntlDate
75
+ * @param fmt
76
+ */
77
+ setDateStoreFormat(fmt: string): void;
78
+ setStoreValue(value: any): void;
79
+ getStoreValue(): any;
80
+ private _date_get_hook;
81
+ private _date_set_hook;
82
+ showError(text: string): void;
83
+ clearError(): void;
84
+ get value(): string;
85
+ set value(value: string);
86
+ /**
87
+ * select all the text
88
+ */
89
+ selectAll(): void;
90
+ select(start: number, length?: number): void;
91
+ getSelection(): {
92
+ start: number;
93
+ length: number;
94
+ };
95
+ set readOnly(ro: boolean);
96
+ get label(): string | HtmlString;
97
+ set label(text: string | HtmlString);
98
+ /**
99
+ * content changed
100
+ * todo: should move into Input
101
+ */
102
+ private _change;
103
+ /**
104
+ * getting focus
105
+ */
106
+ private _focus;
107
+ /**
108
+ * loosing focus
109
+ * @param value
110
+ */
111
+ private _blur;
112
+ /**
113
+ * todo: should move into Input
114
+ * @returns
115
+ */
116
+ validate(): boolean;
117
+ protected _validate(value: string): boolean;
118
+ _date_validator(value: string): string;
119
+ private _showDatePicker;
120
+ get input(): Input;
121
+ get type(): import("./input").EditType;
122
+ }
123
+ export {};
@@ -0,0 +1,42 @@
1
+ /**
2
+ * ___ ___ __
3
+ * \ \_/ / / _
4
+ * \ / /_| |_
5
+ * / _ \____ _|
6
+ * /__/ \__\ |_|
7
+ *
8
+ * @file toaster.ts
9
+ * @author Etienne Cochard
10
+ *
11
+ * Copyright (c) 2019-2022 R-libre ingenierie
12
+ *
13
+ * Permission is hereby granted, free of charge, to any person obtaining a copy
14
+ * of this software and associated documentation files (the "Software"), to deal
15
+ * in the Software without restriction, including without limitation the rights
16
+ * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies
17
+ * of the Software, and to permit persons to whom the Software is furnished to do so,
18
+ * subject to the following conditions:
19
+ * The above copyright notice and this permission notice shall be included in all copies
20
+ * or substantial portions of the Software.
21
+ *
22
+ * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED,
23
+ * INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A
24
+ * PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT
25
+ * HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
26
+ * OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
27
+ * SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
28
+ **/
29
+ import { IconID } from './icon';
30
+ import { Popup, PopupProps } from './popup';
31
+ export interface ToasterProps extends PopupProps {
32
+ message: string;
33
+ icon?: IconID;
34
+ }
35
+ export declare class Toaster extends Popup<ToasterProps> {
36
+ private m_message;
37
+ private m_icon;
38
+ constructor(props: ToasterProps);
39
+ /** @ignore */
40
+ render(): void;
41
+ show(): void;
42
+ }