@json-editor/json-editor 1.4.0-beta.0 → 1.17.0

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 (435) hide show
  1. package/.claude/settings.local.json +8 -0
  2. package/.env +2 -0
  3. package/.env-dist +2 -0
  4. package/.eslintrc +10 -0
  5. package/.github/PULL_REQUEST_TEMPLATE.md +9 -0
  6. package/.github/workflows/build.yml +70 -0
  7. package/.travis.yml +62 -16
  8. package/CHANGELOG.md +483 -113
  9. package/CONTRIBUTING.md +43 -4
  10. package/Makefile +26 -0
  11. package/README.md +632 -121
  12. package/README_ADDON.md +577 -0
  13. package/UPGRADING.md +46 -0
  14. package/build/CssToJson.js +55 -0
  15. package/codecept.conf.js +35 -0
  16. package/config/.eslintrc +7 -0
  17. package/config/codeceptjs_helpers.js +146 -0
  18. package/config/helpers.js +10 -0
  19. package/config/karma.conf.js +89 -0
  20. package/config/readme.md +31 -0
  21. package/config/webpack.common.js +71 -0
  22. package/config/webpack.dev.js +15 -0
  23. package/config/webpack.nonmin.js +19 -0
  24. package/config/webpack.prod.js +24 -0
  25. package/dist/jsoneditor.js +2 -11550
  26. package/dist/jsoneditor.js.LICENSE.txt +15 -0
  27. package/dist/nonmin/jsoneditor.js +31392 -0
  28. package/dist/nonmin/jsoneditor.js.map +1 -0
  29. package/docs/basic.html +2 -2
  30. package/docs/basic_person.json +2 -1
  31. package/docs/choices.html +86 -0
  32. package/docs/cleave.html +11 -19
  33. package/docs/colorpicker.html +194 -0
  34. package/docs/css_integration.html +56 -54
  35. package/docs/custom-editor.html +92 -0
  36. package/docs/datetime.html +48 -21
  37. package/docs/describedby.html +42 -35
  38. package/docs/enumsource.html +67 -0
  39. package/docs/form-submission.html +162 -0
  40. package/docs/imask.html +192 -0
  41. package/docs/index.html +600 -582
  42. package/docs/materialize_css.html +1 -1
  43. package/docs/meta-schema.html +793 -0
  44. package/docs/meta_schema.json +446 -400
  45. package/docs/polyfills/assign.js +29 -0
  46. package/docs/radio.html +9 -17
  47. package/docs/recursive.html +15 -17
  48. package/docs/scripts/ajv-validator.js +8695 -0
  49. package/docs/select2.html +15 -9
  50. package/docs/selectize.html +11 -9
  51. package/docs/signature.html +12 -11
  52. package/docs/starrating.html +5 -17
  53. package/docs/upload.html +33 -23
  54. package/docs/uuid.html +70 -0
  55. package/docs/wysiwyg.html +14 -7
  56. package/jasmine.json +11 -0
  57. package/package.json +74 -25
  58. package/release-notes.md +90 -0
  59. package/src/core.js +411 -611
  60. package/src/defaults.js +381 -327
  61. package/src/editor.js +733 -544
  62. package/src/editors/ace.js +90 -0
  63. package/src/editors/array/choices.js +104 -0
  64. package/src/editors/array/select2.js +112 -0
  65. package/src/editors/array/selectize.js +107 -130
  66. package/src/editors/array.css +9 -0
  67. package/src/editors/array.css.js +3 -0
  68. package/src/editors/array.js +812 -695
  69. package/src/editors/autocomplete.js +59 -0
  70. package/src/editors/base64.js +148 -129
  71. package/src/editors/button.js +104 -0
  72. package/src/editors/checkbox.js +111 -76
  73. package/src/editors/choices.css +3 -0
  74. package/src/editors/choices.css.js +3 -0
  75. package/src/editors/choices.js +71 -0
  76. package/src/editors/colorpicker.js +105 -0
  77. package/src/editors/datetime.js +93 -79
  78. package/src/editors/describedby.js +141 -125
  79. package/src/editors/enum.js +131 -116
  80. package/src/editors/hidden.js +100 -86
  81. package/src/editors/index.js +81 -0
  82. package/src/editors/info.js +28 -0
  83. package/src/editors/integer.js +21 -8
  84. package/src/editors/ip.js +36 -0
  85. package/src/editors/jodit.js +66 -0
  86. package/src/editors/multiple.js +380 -241
  87. package/src/editors/multiselect.js +207 -207
  88. package/src/editors/null.js +15 -11
  89. package/src/editors/number.js +39 -30
  90. package/src/editors/object.css +41 -0
  91. package/src/editors/object.css.js +3 -0
  92. package/src/editors/object.js +1190 -1068
  93. package/src/editors/radio.js +117 -101
  94. package/src/editors/sceditor.js +74 -0
  95. package/src/editors/select.js +318 -342
  96. package/src/editors/select2.js +112 -0
  97. package/src/editors/selectize.js +89 -338
  98. package/src/editors/signature.js +100 -104
  99. package/src/editors/simplemde.js +103 -0
  100. package/src/{styles → editors}/starrating.css +11 -2
  101. package/src/editors/starrating.css.js +3 -0
  102. package/src/editors/starrating.js +126 -95
  103. package/src/editors/stepper.js +27 -0
  104. package/src/editors/string.js +352 -426
  105. package/src/editors/table.js +486 -410
  106. package/src/editors/upload.js +297 -131
  107. package/src/editors/uuid.js +49 -0
  108. package/src/iconlib.js +22 -27
  109. package/src/iconlibs/bootstrap.js +28 -0
  110. package/src/iconlibs/bootstrap2.js +28 -17
  111. package/src/iconlibs/bootstrap3.js +28 -17
  112. package/src/iconlibs/fontawesome3.js +28 -17
  113. package/src/iconlibs/fontawesome4.js +28 -18
  114. package/src/iconlibs/fontawesome5.js +28 -18
  115. package/src/iconlibs/foundation2.js +24 -17
  116. package/src/iconlibs/foundation3.js +28 -17
  117. package/src/iconlibs/index.js +27 -0
  118. package/src/iconlibs/jqueryui.js +28 -17
  119. package/src/iconlibs/materialicons.js +49 -44
  120. package/src/iconlibs/openiconic.js +28 -0
  121. package/src/iconlibs/spectre.js +28 -0
  122. package/src/resolvers.js +135 -0
  123. package/src/schemaloader.js +639 -0
  124. package/src/style.css +157 -0
  125. package/src/style.css.js +3 -0
  126. package/src/templates/default.js +46 -51
  127. package/src/templates/ejs.js +8 -10
  128. package/src/templates/handlebars.js +1 -3
  129. package/src/templates/hogan.js +7 -9
  130. package/src/templates/index.js +21 -0
  131. package/src/templates/lodash.js +6 -8
  132. package/src/templates/markup.js +6 -8
  133. package/src/templates/mustache.js +6 -8
  134. package/src/templates/swig.js +1 -3
  135. package/src/templates/underscore.js +6 -8
  136. package/src/theme.js +717 -433
  137. package/src/themes/barebones.css +35 -0
  138. package/src/themes/barebones.css.js +3 -0
  139. package/src/themes/barebones.js +31 -0
  140. package/src/themes/bootstrap2.js +302 -265
  141. package/src/themes/bootstrap3.css +53 -0
  142. package/src/themes/bootstrap3.css.js +3 -0
  143. package/src/themes/bootstrap3.js +355 -262
  144. package/src/themes/bootstrap4.css +89 -0
  145. package/src/themes/bootstrap4.css.js +3 -0
  146. package/src/themes/bootstrap4.js +743 -237
  147. package/src/themes/bootstrap5.css +97 -0
  148. package/src/themes/bootstrap5.css.js +3 -0
  149. package/src/themes/bootstrap5.js +687 -0
  150. package/src/themes/foundation.js +535 -472
  151. package/src/themes/html.css +60 -0
  152. package/src/themes/html.css.js +3 -0
  153. package/src/themes/html.js +69 -82
  154. package/src/themes/index.js +29 -0
  155. package/src/themes/jqueryui.js +181 -167
  156. package/src/themes/materialize.js +263 -292
  157. package/src/themes/spectre.css +208 -0
  158. package/src/themes/spectre.css.js +3 -0
  159. package/src/themes/spectre.js +443 -0
  160. package/src/themes/tailwind.css +303 -0
  161. package/src/themes/tailwind.css.js +3 -0
  162. package/src/themes/tailwind.js +469 -0
  163. package/src/utilities.js +127 -68
  164. package/src/validator.js +909 -565
  165. package/src/validators/ip-validator.js +51 -0
  166. package/tests/Dockerfile +3 -0
  167. package/tests/README.md +25 -5
  168. package/tests/codeceptjs/codecept.json +9 -2
  169. package/tests/codeceptjs/constrains/contains_test.js +37 -0
  170. package/tests/codeceptjs/constrains/dependentRequired_test.js +33 -0
  171. package/tests/codeceptjs/constrains/dependentSchemas_test.js +16 -0
  172. package/tests/codeceptjs/constrains/if-then-else_test.js +186 -0
  173. package/tests/codeceptjs/core_test.js +534 -63
  174. package/tests/codeceptjs/editors/advanced_test.js +12 -9
  175. package/tests/codeceptjs/editors/array_any_of_test.js +50 -0
  176. package/tests/codeceptjs/editors/array_test.js +923 -657
  177. package/tests/codeceptjs/editors/autocomplete_test.js +15 -0
  178. package/tests/codeceptjs/editors/button_test.js +50 -0
  179. package/tests/codeceptjs/editors/checkbox_test.js +21 -6
  180. package/tests/codeceptjs/editors/colorpicker_test.js +29 -0
  181. package/tests/codeceptjs/editors/datetime_test.js +33 -0
  182. package/tests/codeceptjs/editors/inheritance_test.js +10 -0
  183. package/tests/codeceptjs/editors/integer_test.js +82 -64
  184. package/tests/codeceptjs/editors/jodit_test.js +23 -0
  185. package/tests/codeceptjs/editors/multiple_test.js +27 -0
  186. package/tests/codeceptjs/editors/multiselect_test.js +6 -7
  187. package/tests/codeceptjs/editors/number_test.js +75 -60
  188. package/tests/codeceptjs/editors/object_test.js +322 -80
  189. package/tests/codeceptjs/editors/option-no_default_values_test.js +42 -0
  190. package/tests/codeceptjs/editors/programmatic-changes_test.js +20 -0
  191. package/tests/codeceptjs/editors/purify_test.js +26 -0
  192. package/tests/codeceptjs/editors/radio_test.js +9 -0
  193. package/tests/codeceptjs/editors/range_test.js +10 -0
  194. package/tests/codeceptjs/editors/rating_test.js +10 -10
  195. package/tests/codeceptjs/editors/select_test.js +47 -18
  196. package/tests/codeceptjs/editors/starrating_test.js +15 -0
  197. package/tests/codeceptjs/editors/stepper_test.js +37 -0
  198. package/tests/codeceptjs/editors/string_test.js +107 -91
  199. package/tests/codeceptjs/editors/table-confirm-delete_test.js +60 -54
  200. package/tests/codeceptjs/editors/tabs_test.js +15 -11
  201. package/tests/codeceptjs/editors/uuid_test.js +48 -0
  202. package/tests/codeceptjs/editors/validation_test.js +13 -9
  203. package/tests/codeceptjs/issues/issue-gh-1133_test.js +9 -0
  204. package/tests/codeceptjs/issues/issue-gh-1158-2_test.js +10 -0
  205. package/tests/codeceptjs/issues/issue-gh-1158_test.js +8 -0
  206. package/tests/codeceptjs/issues/issue-gh-1164_test.js +9 -0
  207. package/tests/codeceptjs/issues/issue-gh-1171_test.js +11 -0
  208. package/tests/codeceptjs/issues/issue-gh-1211_test.js +17 -0
  209. package/tests/codeceptjs/issues/issue-gh-1257_test.js +11 -0
  210. package/tests/codeceptjs/issues/issue-gh-1272_test.js +21 -0
  211. package/tests/codeceptjs/issues/issue-gh-1330_test.js +8 -0
  212. package/tests/codeceptjs/issues/issue-gh-1338_test.js +18 -0
  213. package/tests/codeceptjs/issues/issue-gh-1347_test.js +8 -0
  214. package/tests/codeceptjs/issues/issue-gh-1364_test.js +13 -0
  215. package/tests/codeceptjs/issues/issue-gh-1367_test.js +11 -0
  216. package/tests/codeceptjs/issues/issue-gh-1383_test.js +9 -0
  217. package/tests/codeceptjs/issues/issue-gh-1384_test.js +9 -0
  218. package/tests/codeceptjs/issues/issue-gh-1410_test.js +13 -0
  219. package/tests/codeceptjs/issues/issue-gh-1422_test.js +9 -0
  220. package/tests/codeceptjs/issues/issue-gh-1431_test.js +12 -0
  221. package/tests/codeceptjs/issues/issue-gh-1439_test.js +12 -0
  222. package/tests/codeceptjs/issues/issue-gh-1452_test.js +10 -0
  223. package/tests/codeceptjs/issues/issue-gh-1453_test.js +18 -0
  224. package/tests/codeceptjs/issues/issue-gh-1461_test.js +14 -0
  225. package/tests/codeceptjs/issues/issue-gh-1463_test.js +9 -0
  226. package/tests/codeceptjs/issues/issue-gh-1471_test.js +17 -0
  227. package/tests/codeceptjs/issues/issue-gh-1485_test.js +13 -0
  228. package/tests/codeceptjs/issues/issue-gh-1491_test.js +9 -0
  229. package/tests/codeceptjs/issues/issue-gh-1525_test.js +9 -0
  230. package/tests/codeceptjs/issues/issue-gh-1536_test.js +12 -0
  231. package/tests/codeceptjs/issues/issue-gh-1538_test.js +10 -0
  232. package/tests/codeceptjs/issues/issue-gh-1541_test.js +8 -0
  233. package/tests/codeceptjs/issues/issue-gh-1559_test.js +15 -0
  234. package/tests/codeceptjs/issues/issue-gh-1562_test.js +12 -0
  235. package/tests/codeceptjs/issues/issue-gh-1586_test.js +15 -0
  236. package/tests/codeceptjs/issues/issue-gh-1636_test.js +9 -0
  237. package/tests/codeceptjs/issues/issue-gh-795_test.js +13 -0
  238. package/tests/codeceptjs/issues/issue-gh-810_test.js +52 -0
  239. package/tests/codeceptjs/issues/issue-gh-812_test.js +25 -0
  240. package/tests/codeceptjs/meta-schema_test.js +85 -0
  241. package/tests/codeceptjs/schemaloader_test.js +14 -0
  242. package/tests/codeceptjs/steps.d.ts +13 -0
  243. package/tests/codeceptjs/steps_file.js +4 -4
  244. package/tests/codeceptjs/test-config.js +3 -0
  245. package/tests/codeceptjs/themes_test.js +564 -0
  246. package/tests/docker-compose-local.yml +5 -0
  247. package/tests/docker-compose.yml +11 -19
  248. package/tests/fixtures/basic_person.json +2 -1
  249. package/tests/fixtures/definitions.json +22 -0
  250. package/tests/fixtures/nested_object.json +26 -0
  251. package/tests/fixtures/properties.json +20 -0
  252. package/tests/fixtures/some_types.json +32 -0
  253. package/tests/fixtures/validation.json +1347 -0
  254. package/tests/pages/_demo.html +475 -0
  255. package/tests/pages/advanced.html +1 -1
  256. package/tests/pages/anyof-2.html +91 -0
  257. package/tests/pages/anyof.html +82 -0
  258. package/tests/pages/array-anyof.html +145 -0
  259. package/tests/pages/array-checkboxes-infotext.html +55 -0
  260. package/tests/pages/array-checkboxes.html +5 -2
  261. package/tests/pages/array-choices.html +48 -0
  262. package/tests/pages/array-events-table.html +70 -0
  263. package/tests/pages/array-events.html +75 -0
  264. package/tests/pages/array-header-template.html +60 -0
  265. package/tests/pages/array-integers.html +5 -2
  266. package/tests/pages/array-multiselects.html +5 -2
  267. package/tests/pages/array-nested-arrays.html +5 -2
  268. package/tests/pages/array-numbers.html +5 -2
  269. package/tests/pages/array-objects.html +5 -2
  270. package/tests/pages/array-ratings.html +5 -2
  271. package/tests/pages/array-selectize-create.html +63 -0
  272. package/tests/pages/array-selectize.html +10 -8
  273. package/tests/pages/array-selects.html +5 -2
  274. package/tests/pages/array-strings.html +5 -2
  275. package/tests/pages/array-table-responsive.html +66 -0
  276. package/tests/pages/array-unique-items-sort.html +81 -0
  277. package/tests/pages/array.html +5 -2
  278. package/tests/pages/assets/autocomplete.css +1 -0
  279. package/tests/pages/assets/autocomplete.min.js +1 -0
  280. package/tests/pages/assets/pages.css +130 -0
  281. package/tests/pages/autocomplete.html +72 -0
  282. package/tests/pages/button-callbacks.html +79 -0
  283. package/tests/pages/button-icons.html +39 -0
  284. package/tests/pages/button_state_mode_1.html +35 -0
  285. package/tests/pages/button_state_mode_2.html +36 -0
  286. package/tests/pages/checkbox-labels.html +116 -0
  287. package/tests/pages/colorpicker-no-3rd-party.html +45 -0
  288. package/tests/pages/colorpicker-use-vanilla-picker.html +52 -0
  289. package/tests/pages/container-attributes.html +51 -0
  290. package/tests/pages/contains.html +39 -0
  291. package/tests/pages/core.html +14 -7
  292. package/tests/pages/datetime.html +78 -0
  293. package/tests/pages/dependentRequired.html +72 -0
  294. package/tests/pages/dependentSchemas.html +53 -0
  295. package/tests/pages/disable-button-in-object-editors.html +57 -0
  296. package/tests/pages/editor-show-validation-errors.html +54 -0
  297. package/tests/pages/enforce-const.html +168 -0
  298. package/tests/pages/error-messages.html +48 -0
  299. package/tests/pages/form-name.html +111 -0
  300. package/tests/pages/grid-strict.html +10 -13
  301. package/tests/pages/grid.html +4 -7
  302. package/tests/pages/if-else.html +58 -0
  303. package/tests/pages/if-then-else-allOf.html +118 -0
  304. package/tests/pages/if-then-else-disable-fields.html +70 -0
  305. package/tests/pages/if-then-else.html +65 -0
  306. package/tests/pages/if-then.html +58 -0
  307. package/tests/pages/inheritance.html +80 -0
  308. package/tests/pages/integer.html +17 -10
  309. package/tests/pages/issues/_template.html +50 -0
  310. package/tests/pages/issues/issue-gh-1133.html +64 -0
  311. package/tests/pages/issues/issue-gh-1158-2.html +189 -0
  312. package/tests/pages/issues/issue-gh-1158.html +50 -0
  313. package/tests/pages/issues/issue-gh-1164.html +71 -0
  314. package/tests/pages/issues/issue-gh-1165.html +63 -0
  315. package/tests/pages/issues/issue-gh-1165.json +8 -0
  316. package/tests/pages/issues/issue-gh-1171.html +39 -0
  317. package/tests/pages/issues/issue-gh-1211.html +1022 -0
  318. package/tests/pages/issues/issue-gh-1233-failing.html +46 -0
  319. package/tests/pages/issues/issue-gh-1233-passing.html +49 -0
  320. package/tests/pages/issues/issue-gh-1257.html +77 -0
  321. package/tests/pages/issues/issue-gh-1272.html +167 -0
  322. package/tests/pages/issues/issue-gh-1330.html +52 -0
  323. package/tests/pages/issues/issue-gh-1338.html +74 -0
  324. package/tests/pages/issues/issue-gh-1347.html +142 -0
  325. package/tests/pages/issues/issue-gh-1364.html +64 -0
  326. package/tests/pages/issues/issue-gh-1367.html +49 -0
  327. package/tests/pages/issues/issue-gh-1383.html +31 -0
  328. package/tests/pages/issues/issue-gh-1383.json +14 -0
  329. package/tests/pages/issues/issue-gh-1384.html +31 -0
  330. package/tests/pages/issues/issue-gh-1384.json +36 -0
  331. package/tests/pages/issues/issue-gh-1410.html +57 -0
  332. package/tests/pages/issues/issue-gh-1422.html +68 -0
  333. package/tests/pages/issues/issue-gh-1431.html +49 -0
  334. package/tests/pages/issues/issue-gh-1439.html +69 -0
  335. package/tests/pages/issues/issue-gh-1452.html +98 -0
  336. package/tests/pages/issues/issue-gh-1453.html +45 -0
  337. package/tests/pages/issues/issue-gh-1461.html +55 -0
  338. package/tests/pages/issues/issue-gh-1463.html +41 -0
  339. package/tests/pages/issues/issue-gh-1466.html +63 -0
  340. package/tests/pages/issues/issue-gh-1471.html +49 -0
  341. package/tests/pages/issues/issue-gh-1485.html +59 -0
  342. package/tests/pages/issues/issue-gh-1491.html +59 -0
  343. package/tests/pages/issues/issue-gh-1525.html +62 -0
  344. package/tests/pages/issues/issue-gh-1536.html +55 -0
  345. package/tests/pages/issues/issue-gh-1538.html +56 -0
  346. package/tests/pages/issues/issue-gh-1541.html +51 -0
  347. package/tests/pages/issues/issue-gh-1541.json +9 -0
  348. package/tests/pages/issues/issue-gh-1559.html +68 -0
  349. package/tests/pages/issues/issue-gh-1562.html +170 -0
  350. package/tests/pages/issues/issue-gh-1586.html +48 -0
  351. package/tests/pages/issues/issue-gh-1636.html +52 -0
  352. package/tests/pages/issues/issue-gh-795.html +58 -0
  353. package/tests/pages/issues/issue-gh-810.html +149 -0
  354. package/tests/pages/issues/issue-gh-812.html +113 -0
  355. package/tests/pages/issues/issue-gh-823-meta-schema.html +35 -0
  356. package/tests/pages/issues/issue-gh-848.html +81 -0
  357. package/tests/pages/keep_only_existing_values.html +81 -0
  358. package/tests/pages/load-events.html +61 -0
  359. package/tests/pages/maxContains.html +40 -0
  360. package/tests/pages/meta-schema.html +793 -0
  361. package/tests/pages/meta_schema.json +740 -0
  362. package/tests/pages/minContains.html +40 -0
  363. package/tests/pages/number.html +53 -6
  364. package/tests/pages/object-case-sensitive-property-search-false.html +42 -0
  365. package/tests/pages/object-case-sensitive-property-search-true.html +42 -0
  366. package/tests/pages/object-no-additional-properties.html +68 -0
  367. package/tests/pages/object-no-duplicated-id.html +70 -0
  368. package/tests/pages/object-required-properties.html +56 -20
  369. package/tests/pages/object-show-opt-in.html +111 -0
  370. package/tests/pages/object-with-dependencies-array.html +58 -0
  371. package/tests/pages/object-with-dependencies.html +62 -0
  372. package/tests/pages/object.html +5 -3
  373. package/tests/pages/oneof-2.html +91 -0
  374. package/tests/pages/oneof.html +105 -0
  375. package/tests/pages/opt-in-widget.html +134 -0
  376. package/tests/pages/option-dependencies.html +107 -0
  377. package/tests/pages/option-no_default_values.html +60 -0
  378. package/tests/pages/per-editor-options.html +44 -0
  379. package/tests/pages/placeholder-options.html +57 -0
  380. package/tests/pages/programmatic-changes.html +121 -0
  381. package/tests/pages/prompt-paste-max-length-reached.html +51 -0
  382. package/tests/pages/purify.html +66 -0
  383. package/tests/pages/range.html +62 -0
  384. package/tests/pages/read-only.html +60 -8
  385. package/tests/pages/ready.html +44 -0
  386. package/tests/pages/references.html +168 -0
  387. package/tests/pages/remove-false-properties.html +85 -0
  388. package/tests/pages/select-values.html +91 -0
  389. package/tests/pages/select.html +4 -3
  390. package/tests/pages/show-validation-errors.html +73 -0
  391. package/tests/pages/starrating.html +86 -0
  392. package/tests/pages/stepper-manual.html +59 -0
  393. package/tests/pages/stepper.html +61 -0
  394. package/tests/pages/string-ace-editor.html +7 -3
  395. package/tests/pages/string-cleave.html +48 -0
  396. package/tests/pages/string-custom-attributes.html +9 -6
  397. package/tests/pages/string-formats.html +54 -0
  398. package/tests/pages/string-formats2.html +59 -0
  399. package/tests/pages/{array-move-events.html → string-jodit-editor.html} +21 -29
  400. package/tests/pages/string-sceditor.html +9 -7
  401. package/tests/pages/string-simplemde-editor.html +83 -0
  402. package/tests/pages/switcher-option.html +69 -0
  403. package/tests/pages/table.html +4 -2
  404. package/tests/pages/tabs.html +1 -1
  405. package/tests/pages/themes.html +517 -0
  406. package/tests/pages/title-hidden.html +75 -0
  407. package/tests/pages/translate-property.html +248 -0
  408. package/tests/pages/urn.html +98 -0
  409. package/tests/pages/use-name-attributes.html +207 -0
  410. package/tests/pages/uuid.html +113 -0
  411. package/tests/pages/validation-messages.json +705 -0
  412. package/tests/pages/validation.html +20 -730
  413. package/tests/unit/.eslintrc +8 -0
  414. package/tests/unit/core.spec.js +320 -0
  415. package/tests/unit/defaults.spec.js +40 -0
  416. package/tests/unit/editor.spec.js +172 -0
  417. package/tests/unit/editors/array.spec.js +87 -0
  418. package/tests/unit/editors/object.spec.js +81 -0
  419. package/tests/unit/editors/table.spec.js +93 -0
  420. package/tests/unit/readme.md +35 -0
  421. package/tests/unit/schemaloader.spec.js +576 -0
  422. package/tests/unit/validator.spec.js +104 -0
  423. package/tests/unit/validators/ip-validator.spec.js +62 -0
  424. package/Gruntfile.js +0 -228
  425. package/dist/css/jsoneditor.min.css +0 -1
  426. package/dist/jsoneditor.js.map +0 -1
  427. package/dist/jsoneditor.min.js +0 -19
  428. package/dist/jsoneditor.min.js.map +0 -1
  429. package/src/class.js +0 -68
  430. package/src/editors/rating.js +0 -152
  431. package/src/ie9.js +0 -51
  432. package/src/intro.js +0 -23
  433. package/src/jquery.js +0 -64
  434. package/src/outro.js +0 -2
  435. package/src/themes/jsoneditor.barebones-theme.js +0 -60
@@ -0,0 +1,469 @@
1
+ import { AbstractTheme } from '../theme.js'
2
+ import rules from './tailwind.css.js'
3
+
4
+ const options = {
5
+ disable_theme_rules: false, /* Disable creation of Inline Style Rules */
6
+ label_bold: false, /* Element labels bold */
7
+ object_panel_default: true, /* Indicates whether to use rules as default or alternate style */
8
+ object_indent: true, /* Indent nested object elements */
9
+ object_border: false, /* Add border around object elements */
10
+ table_border: false, /* Add border to array "table" row and cells */
11
+ table_hdiv: false, /* Add bottom-border to array "table" cells */
12
+ table_zebrastyle: false, /* Add "zebra style" to array "table" rows */
13
+ input_size: 'small', /* Size of input and select elements. "small", "normal", "large" */
14
+ enable_compact: false
15
+ }
16
+
17
+ export class tailwindTheme extends AbstractTheme {
18
+ constructor (jsoneditor) {
19
+ super(jsoneditor, options)
20
+ }
21
+
22
+ getOptInSwitch (formname) {
23
+ const label = this.getHiddenLabel(formname + ' opt-in')
24
+ label.setAttribute('for', formname + '-opt-in')
25
+
26
+ const container = document.createElement('label')
27
+ container.classList.add('switch')
28
+
29
+ const checkbox = document.createElement('input')
30
+ checkbox.setAttribute('type', 'checkbox')
31
+ checkbox.setAttribute('id', formname + '-opt-in')
32
+ checkbox.classList.add('json-editor-opt-in')
33
+
34
+ const slider = document.createElement('span')
35
+ slider.classList.add('switch-slider', 'round')
36
+
37
+ const switchLabelText = document.createElement('span')
38
+ switchLabelText.classList.add('sr-only')
39
+ switchLabelText.textContent = formname + '-opt-in'
40
+
41
+ container.appendChild(switchLabelText)
42
+ container.appendChild(checkbox)
43
+ container.appendChild(slider)
44
+
45
+ return { label, checkbox, container }
46
+ }
47
+
48
+ getGridContainer () {
49
+ const el = document.createElement('div')
50
+ el.classList.add('flex', 'flex-col', 'w-full')
51
+ if (!this.options.object_indent) el.classList.add('je-noindent')
52
+ return el
53
+ }
54
+
55
+ getGridRow () {
56
+ const el = document.createElement('div')
57
+ el.classList.add('flex', 'flex-wrap', 'w-full')
58
+ return el
59
+ }
60
+
61
+ getGridColumn () {
62
+ const el = document.createElement('div')
63
+ el.classList.add('flex', 'flex-col')
64
+ return el
65
+ }
66
+
67
+ setGridColumnSize (el, size, offset) {
68
+ if (size > 0 && size < 12) { el.classList.add(`w-${size}/12`, 'px-1') } else el.classList.add('w-full', 'px-1')
69
+
70
+ if (offset) el.style.marginLeft = `${(100 / 12) * offset}%`
71
+ }
72
+
73
+ getIndentedPanel () {
74
+ const el = document.createElement('div')
75
+ if (this.options.object_panel_default) { el.classList.add('w-full', 'p-1') } else { el.classList.add('relative', 'flex', 'flex-col', 'rounded', 'break-words', 'border', 'bg-white', 'border-0', 'border-blue-400', 'p-1', 'shadow-md') }
76
+ if (this.options.object_border) el.classList.add('je-border')
77
+ return el
78
+ }
79
+
80
+ /* Used for "type: array" with "format: tabs-top" */
81
+ getTopIndentedPanel () {
82
+ const el = document.createElement('div')
83
+ if (this.options.object_panel_default) { el.classList.add('w-full', 'm-2') } else { el.classList.add('relative', 'flex', 'flex-col', 'rounded', 'break-words', 'border', 'bg-white', 'border-0', 'border-blue-400', 'p-1', 'shadow-md') }
84
+ if (this.options.object_border) el.classList.add('je-border')
85
+ return el
86
+ }
87
+
88
+ getTitle () {
89
+ return this.translateProperty(this.schema.title)
90
+ }
91
+
92
+ getSelectInput (options, multiple) {
93
+ const el = super.getSelectInput(options)
94
+ if (multiple) el.classList.add('form-multiselect', 'block', 'py-0', 'h-auto', 'w-full', 'px-1', 'text-sm', 'text-black', 'leading-normal', 'bg-white', 'border', 'border-grey', 'rounded')
95
+ else el.classList.add('form-select', 'block', 'py-0', 'h-6', 'w-full', 'px-1', 'text-sm', 'text-black', 'leading-normal', 'bg-white', 'border', 'border-grey', 'rounded')
96
+ if (this.options.enable_compact) el.classList.add('compact')
97
+ return el
98
+ }
99
+
100
+ afterInputReady (input) {
101
+ if (input.controlgroup) return
102
+ input.controlgroup = this.closest(input, '.form-group')
103
+ if (this.closest(input, '.compact')) {
104
+ input.controlgroup.style.marginBottom = 0
105
+ }
106
+ }
107
+
108
+ getTextareaInput () {
109
+ const el = super.getTextareaInput()
110
+ el.classList.add('block', 'w-full', 'px-1', 'text-sm', 'leading-normal', 'bg-white', 'text-black', 'border', 'border-grey', 'rounded')
111
+ if (this.options.enable_compact) el.classList.add('compact')
112
+ el.style.height = 0
113
+ return el
114
+ }
115
+
116
+ /* Create input field for type="range" */
117
+ getRangeInput (min, max, step) {
118
+ const el = this.getFormInputField('range')
119
+ el.classList.add('slider')
120
+ if (this.options.enable_compact) el.classList.add('compact')
121
+ el.setAttribute('oninput', 'this.setAttribute("value", this.value)')
122
+ el.setAttribute('min', min)
123
+ el.setAttribute('max', max)
124
+ el.setAttribute('step', step)
125
+ return el
126
+ }
127
+
128
+ getRangeControl (input, output) {
129
+ const el = super.getRangeControl(input, output)
130
+ el.classList.add('text-center', 'text-black')
131
+ return el
132
+ }
133
+
134
+ /* Checkbox elements */
135
+ getCheckbox () {
136
+ const el = this.getFormInputField('checkbox')
137
+ el.classList.add('form-checkbox', 'text-red-600')
138
+ return el
139
+ }
140
+
141
+ getCheckboxLabel (text, req) {
142
+ const el = super.getCheckboxLabel(text, req)
143
+ el.classList.add('inline-flex', 'items-center')
144
+ return el
145
+ }
146
+
147
+ getFormCheckboxControl (label, input, compact) {
148
+ label.insertBefore(input, label.firstChild) /* Move input into label element */
149
+ if (compact) label.classList.add('inline-flex flex-row')
150
+ return label
151
+ }
152
+
153
+ getMultiCheckboxHolder (controls, label, description, infoText) {
154
+ const el = super.getMultiCheckboxHolder(controls, label, description, infoText)
155
+ el.classList.add('inline-flex', 'flex-col')
156
+ return el
157
+ }
158
+
159
+ /* Radio elements */
160
+ getFormRadio (attributes) {
161
+ const el = this.getFormInputField('radio')
162
+ el.classList.add('form-radio', 'text-red-600')
163
+ for (const key in attributes) {
164
+ el.setAttribute(key, attributes[key])
165
+ }
166
+ return el
167
+ }
168
+
169
+ getFormRadioLabel (text, req) {
170
+ const el = super.getFormRadioLabel(text, req)
171
+ el.classList.add('inline-flex', 'items-center', 'mr-2')
172
+ return el
173
+ }
174
+
175
+ getFormRadioControl (label, input, compact) {
176
+ label.insertBefore(input, label.firstChild) /* Move input into label element */
177
+ if (compact) label.classList.add('form-radio')
178
+ return label
179
+ }
180
+
181
+ getRadioHolder (schema, controls, label, description, infoText) {
182
+ const el = super.getRadioHolder(controls, label, description, infoText)
183
+ if (schema.options.layout === 'h') el.classList.add('inline-flex', 'flex-row')
184
+ else el.classList.add('inline-flex', 'flex-col')
185
+ return el
186
+ }
187
+
188
+ getFormInputLabel (text, req) {
189
+ const el = super.getFormInputLabel(text, req)
190
+ if (this.options.label_bold) el.classList.add('font-bold')
191
+ else el.classList.add('required')
192
+ return el
193
+ }
194
+
195
+ getFormInputField (type) {
196
+ const el = super.getFormInputField(type)
197
+ if (!['checkbox', 'radio'].includes(type)) el.classList.add('block', 'w-full', 'px-1', 'text-black', 'text-sm', 'leading-normal', 'bg-white', 'border', 'border-grey', 'rounded')
198
+ if (this.options.enable_compact) el.classList.add('compact')
199
+ return el
200
+ }
201
+
202
+ getFormInputDescription (text) {
203
+ const el = document.createElement('p')
204
+ el.classList.add('block', 'mt-1', 'text-xs')
205
+ if (window.DOMPurify) el.innerHTML = window.DOMPurify.sanitize(text)
206
+ else el.textContent = this.cleanText(text)
207
+ return el
208
+ }
209
+
210
+ getFormControl (label, input, description, infoText) {
211
+ const group = document.createElement('div')
212
+ group.classList.add('form-group', 'mb-1', 'w-full')
213
+ if (label) {
214
+ label.classList.add('text-xs')
215
+
216
+ if (input.type === 'checkbox') {
217
+ input.classList.add('form-checkbox', 'text-xs', 'text-red-600', 'mr-1')
218
+ label.classList.add('items-center', 'flex')
219
+ label = this.getFormCheckboxControl(label, input, false, infoText)
220
+ }
221
+
222
+ if (input.type === 'radio') {
223
+ input.classList.add('form-radio', 'text-red-600', 'mr-1')
224
+ label.classList.add('items-center', 'flex')
225
+ label = this.getFormRadioControl(label, input, false, infoText)
226
+ }
227
+ group.appendChild(label)
228
+
229
+ if (!['checkbox', 'radio'].includes(input.type) && infoText) group.appendChild(infoText)
230
+ }
231
+ if (!['checkbox', 'radio'].includes(input.type)) {
232
+ if (this.options.input_size === 'small') input.classList.add('text-xs')
233
+ else if (this.options.input_size === 'normal') input.classList.add('text-base')
234
+ else if (this.options.input_size === 'large') input.classList.add('text-xl')
235
+ group.appendChild(input)
236
+ }
237
+
238
+ if (description) group.appendChild(description)
239
+
240
+ return group
241
+ }
242
+
243
+ getHeaderButtonHolder () {
244
+ const el = this.getButtonHolder()
245
+ el.classList.add('text-sm')
246
+ return el
247
+ }
248
+
249
+ getButtonHolder () {
250
+ const el = document.createElement('div')
251
+ el.classList.add('flex', 'relative', 'inline-flex', 'align-middle')
252
+ return el
253
+ }
254
+
255
+ getButton (text, icon, title) {
256
+ const el = super.getButton(text, icon, title)
257
+ el.classList.add('inline-block', 'align-middle', 'text-center', 'text-sm', 'bg-blue-700', 'text-white', 'py-1', 'pr-1', 'm-2', 'shadow', 'select-none', 'whitespace-no-wrap', 'rounded')
258
+ return el
259
+ }
260
+
261
+ /* Button for displaying infotext tooltip */
262
+ getInfoButton (text) {
263
+ const tooltip = document.createElement('a')
264
+ tooltip.classList.add('tooltips', 'float-right')
265
+ tooltip.innerHTML = 'ⓘ'
266
+ const span = document.createElement('span')
267
+ span.innerHTML = text
268
+ tooltip.appendChild(span)
269
+
270
+ return tooltip
271
+ }
272
+
273
+ getTable () {
274
+ const el = super.getTable()
275
+ if (this.options.table_border) el.classList.add('je-table-border')
276
+ else el.classList.add('table', 'border', 'p-0')
277
+ return el
278
+ }
279
+
280
+ getTableRow () {
281
+ const el = super.getTableRow()
282
+ if (this.options.table_border) el.classList.add('je-table-border')
283
+ if (this.options.table_zebrastyle) el.classList.add('je-table-zebra')
284
+ return el
285
+ }
286
+
287
+ getTableHeaderCell (text) {
288
+ const el = super.getTableHeaderCell(text)
289
+ if (this.options.table_border) el.classList.add('je-table-border')
290
+ else if (this.options.table_hdiv) el.classList.add('je-table-hdiv')
291
+ else el.classList.add('text-xs', 'border', 'p-0', 'm-0')
292
+ return el
293
+ }
294
+
295
+ getTableCell () {
296
+ const el = super.getTableCell()
297
+ if (this.options.table_border) el.classList.add('je-table-border')
298
+ else if (this.options.table_hdiv) el.classList.add('je-table-hdiv')
299
+ else el.classList.add('border-0', 'p-0', 'm-0')
300
+ return el
301
+ }
302
+
303
+ addInputError (input, text) {
304
+ if (!input.controlgroup) return
305
+ input.controlgroup.classList.add('has-error')
306
+ input.controlgroup.classList.add('text-red-600')
307
+ if (!input.errmsg) {
308
+ input.errmsg = document.createElement('p')
309
+ input.errmsg.classList.add('block', 'mt-1', 'text-xs', 'text-red')
310
+ input.controlgroup.appendChild(input.errmsg)
311
+ } else {
312
+ input.errmsg.style.display = ''
313
+ }
314
+ input.errmsg.textContent = text
315
+ }
316
+
317
+ removeInputError (input) {
318
+ if (!input.errmsg) return
319
+ input.errmsg.style.display = 'none'
320
+ input.controlgroup.classList.remove('text-red-600')
321
+ input.controlgroup.classList.remove('has-error')
322
+ }
323
+
324
+ getTabHolder (propertyName) {
325
+ const el = document.createElement('div')
326
+ const pName = typeof propertyName === 'undefined' ? '' : propertyName
327
+ el.innerHTML = `<div class='w-2/12' id='${pName}'><ul class='list-reset pl-0 mb-0'></ul></div><div class='w-10/12' id='${pName}'></div>`
328
+ el.classList.add('flex')
329
+ return el
330
+ }
331
+
332
+ addTab (holder, tab) {
333
+ holder.children[0].children[0].appendChild(tab)
334
+ }
335
+
336
+ getTopTabHolder (propertyName) {
337
+ const pName = typeof propertyName === 'undefined' ? '' : propertyName
338
+ const el = document.createElement('div')
339
+ el.innerHTML = `<ul class='nav-tabs flex list-reset pl-0 mb-0 border-b border-grey-light' id='${pName}'></ul><div class='p-6 block' id='${pName}'></div>`
340
+ return el
341
+ }
342
+
343
+ getTab (text, tabId) {
344
+ const liel = document.createElement('li')
345
+ liel.classList.add('nav-item', 'flex-col', 'text-center', 'text-white', 'bg-blue-500', 'shadow-md', 'border', 'p-2', 'mb-2', 'mr-2', 'hover:bg-blue-400', 'rounded')
346
+ const ael = document.createElement('a')
347
+ ael.classList.add('nav-link', 'text-center')
348
+ ael.setAttribute('href', `#${tabId}`)
349
+ ael.setAttribute('data-toggle', 'tab')
350
+ ael.appendChild(text)
351
+ liel.appendChild(ael)
352
+ return liel
353
+ }
354
+
355
+ getTopTab (text, tabId) {
356
+ const el = document.createElement('li')
357
+ el.classList.add('nav-item', 'flex', 'border-l', 'border-t', 'border-r')
358
+ const a = document.createElement('a')
359
+ a.classList.add('nav-link', '-mb-px', 'flex-row', 'text-center', 'bg-white', 'p-2', 'hover:bg-blue-400', 'rounded-t')
360
+ a.setAttribute('href', `#${tabId}`)
361
+ a.setAttribute('data-toggle', 'tab')
362
+ a.appendChild(text)
363
+ el.appendChild(a)
364
+ return el
365
+ }
366
+
367
+ getTabContent () {
368
+ const el = document.createElement('div')
369
+ el.setAttribute('role', 'tabpanel')
370
+ return el
371
+ }
372
+
373
+ getTopTabContent () {
374
+ const el = document.createElement('div')
375
+ el.setAttribute('role', 'tabpanel')
376
+ return el
377
+ }
378
+
379
+ markTabActive (row) {
380
+ row.tab.firstChild.classList.add('block')
381
+ if (row.tab.firstChild.classList.contains('border-b') === true) {
382
+ row.tab.firstChild.classList.add('border-b-0')
383
+ row.tab.firstChild.classList.remove('border-b')
384
+ } else {
385
+ row.tab.firstChild.classList.add('border-b-0')
386
+ }
387
+ if (row.container.classList.contains('hidden') === true) {
388
+ row.container.classList.remove('hidden')
389
+ row.container.classList.add('block')
390
+ } else {
391
+ row.container.classList.add('block')
392
+ }
393
+ }
394
+
395
+ markTabInactive (row) {
396
+ if (row.tab.firstChild.classList.contains('border-b-0') === true) {
397
+ row.tab.firstChild.classList.add('border-b')
398
+ row.tab.firstChild.classList.remove('border-b-0')
399
+ } else {
400
+ row.tab.firstChild.classList.add('border-b')
401
+ }
402
+ if (row.container.classList.contains('block') === true) {
403
+ row.container.classList.remove('block')
404
+ row.container.classList.add('hidden')
405
+ }
406
+ }
407
+
408
+ getProgressBar () {
409
+ const min = 0
410
+ const max = 100
411
+ const start = 0
412
+
413
+ const container = document.createElement('div')
414
+ container.classList.add('progress')
415
+
416
+ const bar = document.createElement('div')
417
+ bar.classList.add('bg-blue', 'leading-none', 'py-1', 'text-xs', 'text-center', 'text-white')
418
+ bar.setAttribute('role', 'progressbar')
419
+ bar.setAttribute('aria-valuenow', start)
420
+ bar.setAttribute('aria-valuemin', min)
421
+ bar.setAttribute('aria-valuenax', max)
422
+ bar.innerHTML = `${start}%`
423
+ container.appendChild(bar)
424
+
425
+ return container
426
+ }
427
+
428
+ updateProgressBar (progressBar, progress) {
429
+ if (!progressBar) return
430
+
431
+ const bar = progressBar.firstChild
432
+ const percentage = `${progress}%`
433
+ bar.setAttribute('aria-valuenow', progress)
434
+ bar.style.width = percentage
435
+ bar.innerHTML = percentage
436
+ }
437
+
438
+ updateProgressBarUnknown (progressBar) {
439
+ if (!progressBar) return
440
+
441
+ const bar = progressBar.firstChild
442
+ progressBar.classList.add('progress', 'bg-blue', 'leading-none', 'py-1', 'text-xs', 'text-center', 'text-white', 'block')
443
+ bar.removeAttribute('aria-valuenow')
444
+ bar.classList.add('w-full')
445
+ bar.innerHTML = ''
446
+ }
447
+
448
+ getInputGroup (input, buttons) {
449
+ if (!input) return
450
+
451
+ const inputGroupContainer = document.createElement('div')
452
+ inputGroupContainer.classList.add('relative', 'items-stretch', 'w-full')
453
+ inputGroupContainer.appendChild(input)
454
+
455
+ const inputGroup = document.createElement('div')
456
+ inputGroup.classList.add('-mr-1')
457
+ inputGroupContainer.appendChild(inputGroup)
458
+
459
+ for (let i = 0; i < buttons.length; i++) {
460
+ inputGroup.appendChild(buttons[i])
461
+ }
462
+
463
+ return inputGroupContainer
464
+ }
465
+ }
466
+
467
+ /* Custom stylesheet rules. (Does not support comma separated selectors) */
468
+ /* Will create a stylesheet in document head with the id "theme-spectre" if not exists. */
469
+ tailwindTheme.rules = rules
package/src/utilities.js CHANGED
@@ -1,79 +1,138 @@
1
1
  /**
2
2
  * Taken from jQuery 2.1.3
3
3
  *
4
- * @param obj
5
- * @returns {boolean}
4
+ * #### NOTE
5
+ * Not plain objects is,
6
+ * - Any object or value whose internal [[Class]] property is not "[object Object]"
7
+ * - DOM nodes
8
+ * - window
9
+ *
10
+ * @param {Object} obj - Variable name
11
+ * @returns {Boolean}
6
12
  */
7
- var $isplainobject = function( obj ) {
8
- // Not plain objects:
9
- // - Any object or value whose internal [[Class]] property is not "[object Object]"
10
- // - DOM nodes
11
- // - window
12
- if (typeof obj !== "object" || obj.nodeType || (obj !== null && obj === obj.window)) {
13
- return false;
14
- }
13
+ export function isPlainObject (obj) {
14
+ if (obj === null) return false
15
15
 
16
- if (obj.constructor && !Object.prototype.hasOwnProperty.call(obj.constructor.prototype, "isPrototypeOf")) {
17
- return false;
18
- }
16
+ if (typeof obj !== 'object' || obj.nodeType || (obj === obj.window)) return false
19
17
 
20
- // If the function hasn't returned already, we're confident that
21
- // |obj| is a plain object, created by {} or constructed with new Object
22
- return true;
23
- };
24
-
25
- var $extend = function(destination) {
26
- var source, i,property;
27
- for(i=1; i<arguments.length; i++) {
28
- source = arguments[i];
29
- for (property in source) {
30
- if(!source.hasOwnProperty(property)) continue;
31
- if(source[property] && $isplainobject(source[property])) {
32
- if(!destination.hasOwnProperty(property)) destination[property] = {};
33
- $extend(destination[property], source[property]);
34
- }
35
- else {
36
- destination[property] = source[property];
37
- }
38
- }
39
- }
40
- return destination;
41
- };
42
-
43
- var $each = function(obj,callback) {
44
- if(!obj || typeof obj !== "object") return;
45
- var i;
46
- if(Array.isArray(obj) || (typeof obj.length === 'number' && obj.length > 0 && (obj.length - 1) in obj)) {
47
- for(i=0; i<obj.length; i++) {
48
- if(callback(i,obj[i])===false) return;
18
+ if (obj.constructor && !hasOwnProperty(obj.constructor.prototype, 'isPrototypeOf')) return false
19
+
20
+ /* Most likely |obj| is a plain object, created by {} or constructed with new Object */
21
+ return true
22
+ }
23
+
24
+ export function deepCopy (target) {
25
+ return isPlainObject(target) ? extend({}, target) : Array.isArray(target) ? target.map(deepCopy) : target
26
+ }
27
+
28
+ export function extend (destination, ...args) {
29
+ args.forEach(source => {
30
+ if (source) {
31
+ Object.keys(source).forEach(property => {
32
+ if (source[property] && isPlainObject(source[property])) {
33
+ if (!hasOwnProperty(destination, property)) destination[property] = {}
34
+ extend(destination[property], source[property])
35
+ } else if (Array.isArray(source[property])) {
36
+ destination[property] = deepCopy(source[property])
37
+ } else {
38
+ destination[property] = source[property]
39
+ }
40
+ })
49
41
  }
42
+ })
43
+
44
+ return destination
45
+ }
46
+
47
+ export function trigger (el, event) {
48
+ const e = document.createEvent('HTMLEvents')
49
+ e.initEvent(event, true, true)
50
+ el.dispatchEvent(e)
51
+ }
52
+
53
+ /**
54
+ * Helper function to locate a shadowRoot parent if at all
55
+ *
56
+ * @param {Element} node - Node
57
+ */
58
+ export function getShadowParent (node) {
59
+ return node && (node.toString() === '[object ShadowRoot]' ? node : getShadowParent(node.parentNode))
60
+ }
61
+
62
+ /**
63
+ * Helper function to check own property key
64
+ *
65
+ * @see https://eslint.org/docs/rules/no-prototype-builtins
66
+ */
67
+ export function hasOwnProperty (obj, key) {
68
+ return obj && Object.prototype.hasOwnProperty.call(obj, key)
69
+ }
70
+
71
+ // From https://github.com/angular/angular.js/blob/master/src/ng/directive/input.js
72
+ const NUMBER_REGEXP = /^\s*(-|\+)?(\d+|(\d*(\.\d*)))([eE][+-]?\d+)?\s*$/
73
+
74
+ export function isNumber (value) {
75
+ if (typeof value === 'undefined' || value === null) return false
76
+ const match = value.match(NUMBER_REGEXP)
77
+ const v = parseFloat(value)
78
+ return match !== null && !isNaN(v) && isFinite(v)
79
+ }
80
+
81
+ const INTEGER_REGEXP = /^\s*(-|\+)?(\d+)\s*$/
82
+
83
+ export function isInteger (value) {
84
+ if (typeof value === 'undefined' || value === null) return false
85
+ const match = value.match(INTEGER_REGEXP)
86
+ const v = parseInt(value)
87
+ return match !== null && !isNaN(v) && isFinite(v)
88
+ }
89
+
90
+ /* This function generates a uuid.
91
+ https://stackoverflow.com/questions/105034/create-guid-uuid-in-javascript
92
+ TODO: It will be probably better to move to: https://www.npmjs.com/package/uuid
93
+ */
94
+ export function generateUUID () {
95
+ let d = new Date().getTime()
96
+
97
+ if (typeof performance !== 'undefined' && typeof performance.now === 'function') {
98
+ d += performance.now() /* use high-precision timer if available */
50
99
  }
51
- else {
52
- if (Object.keys) {
53
- var keys = Object.keys(obj);
54
- for(i=0; i<keys.length; i++) {
55
- if(callback(keys[i],obj[keys[i]])===false) return;
56
- }
57
- }
58
- else {
59
- for(i in obj) {
60
- if(!obj.hasOwnProperty(i)) continue;
61
- if(callback(i,obj[i])===false) return;
100
+
101
+ return 'xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx'.replace(/[xy]/g, (c) => {
102
+ const r = (d + Math.random() * 16) % 16 | 0
103
+ d = Math.floor(d / 16)
104
+ return (c === 'x' ? r : (r & 0x3 | 0x8)).toString(16)
105
+ })
106
+ }
107
+
108
+ export function isObject (item) {
109
+ return (item && typeof item === 'object' && !Array.isArray(item))
110
+ }
111
+
112
+ export function mergeDeep (target, ...sources) {
113
+ if (!sources.length) return target
114
+ const source = sources.shift()
115
+
116
+ if (isObject(target) && isObject(source)) {
117
+ for (const key in source) {
118
+ if (isObject(source[key])) {
119
+ if (!target[key]) Object.assign(target, { [key]: {} })
120
+ mergeDeep(target[key], source[key])
121
+ } else {
122
+ Object.assign(target, { [key]: source[key] })
62
123
  }
63
124
  }
64
125
  }
65
- };
66
-
67
- var $trigger = function(el,event) {
68
- var e = document.createEvent('HTMLEvents');
69
- e.initEvent(event, true, true);
70
- el.dispatchEvent(e);
71
- };
72
- var $triggerc = function(el,event) {
73
- var e = new CustomEvent(event,{
74
- bubbles: true,
75
- cancelable: true
76
- });
77
-
78
- el.dispatchEvent(e);
79
- };
126
+
127
+ return mergeDeep(target, ...sources)
128
+ }
129
+
130
+ export function overwriteExistingProperties (obj1, obj2) {
131
+ Object.keys(obj2).forEach(function (key) {
132
+ if (key in obj1) {
133
+ obj1[key] = obj2[key]
134
+ }
135
+ })
136
+
137
+ return obj1
138
+ }