@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,208 @@
1
+ /* CSS variables */
2
+ * {
3
+ --primary-color: #5755d9;
4
+ --gray-color: #bcc3ce;
5
+ --light-color: #fff;
6
+ }
7
+ /* Remove slider focus shadow */
8
+ .slider:focus {
9
+ box-shadow: none;
10
+ }
11
+ /* Add margin between header and top buttons */
12
+ h4 > label + .btn-group {
13
+ margin-left: 1rem;
14
+ }
15
+ /* Remove right margin on right-aligned button */
16
+ .text-right > button {
17
+ margin-right: 0 !important;
18
+ }
19
+ /* Remove left margin on left-aligned button */
20
+ .text-left > button {
21
+ margin-left: 0 !important;
22
+ }
23
+ /* Fix fontsize in Properties modal and increase size of modal box */
24
+ .property-selector {
25
+ font-size: 0.7rem;
26
+ font-weight: normal;
27
+ max-height: 260px !important;
28
+ width: 395px !important;
29
+ }
30
+ /* Remove checkbox margins in Properties modal */
31
+ .property-selector .form-checkbox {
32
+ margin: 0;
33
+ }
34
+ /* Prevent textarea from being resized horizontally */
35
+ textarea {
36
+ width: 100%;
37
+ min-height: 2rem;
38
+ resize: vertical;
39
+ }
40
+ /* Remove gap between table element borders */
41
+ table {
42
+ border-collapse: collapse;
43
+ }
44
+ /* reduce table padding */
45
+ .table td {
46
+ padding: 0.4rem 0.4rem;
47
+ }
48
+ /* margin for checkbox label */
49
+ .mr-5 {
50
+ margin-right: 1rem !important;
51
+ }
52
+ /* Hover on input block (Should be removed in final version) */
53
+ div[data-schematype]:not([data-schematype="object"]) {
54
+ transition: 0.5s;
55
+ }
56
+ /* Hover on input block (Should be removed in final version) */
57
+ div[data-schematype]:not([data-schematype="object"]):hover {
58
+ background-color: #eee;
59
+ }
60
+ /* Option: table_border */
61
+ .je-table-border td {
62
+ border: 0.05rem solid #dadee4 !important;
63
+ }
64
+ /* Infobutton */
65
+ .btn-info {
66
+ font-size: 0.5rem;
67
+ font-weight: bold;
68
+ height: 0.8rem;
69
+ padding: 0.15rem 0;
70
+ line-height: 0.8;
71
+ margin: 0.3rem 0 0.3rem 0.1rem;
72
+ }
73
+ /* Select box for oneOf, anyOf and allOf */
74
+ .je-label + select {
75
+ min-width: 5rem;
76
+ }
77
+ /* Option: label_bold */
78
+ .je-label {
79
+ font-weight: 600;
80
+ }
81
+ /* Infobutton */
82
+ .btn-action.btn-info {
83
+ width: 0.8rem;
84
+ }
85
+ /* Option: object_border */
86
+ .je-border {
87
+ border: 0.05rem solid #dadee4;
88
+ }
89
+ .je-panel {
90
+ padding: 0.2rem;
91
+ margin: 0.2rem;
92
+ background-color: rgba(218, 222, 228, 0.1);
93
+ }
94
+ .je-panel-top {
95
+ padding: 0.2rem;
96
+ margin: 0.2rem;
97
+ background-color: rgba(218, 222, 228, 0.1);
98
+ }
99
+ /* Red * after label if field is required */
100
+ .required:after {
101
+ content: " *";
102
+ color: red;
103
+ font: inherit;
104
+ }
105
+ /* option: align_bottom */
106
+ .je-align-bottom {
107
+ margin-top: auto;
108
+ }
109
+ /* Description */
110
+ .je-desc {
111
+ font-size: smaller;
112
+ margin: 0.2rem 0;
113
+ }
114
+ /* Upload editor preview image */
115
+ .je-upload-preview img {
116
+ float: left;
117
+ margin: 0 0.5rem 0.5rem 0;
118
+ max-width: 100%;
119
+ max-height: 5rem;
120
+ border: 3px solid white;
121
+ box-shadow: 0px 0px 8px rgba(0, 0, 0, 0.3);
122
+ box-sizing: border-box;
123
+ }
124
+ .je-dropzone {
125
+ position: relative;
126
+ margin: 0.5rem 0;
127
+ border: 2px dashed black;
128
+ width: 100%;
129
+ height: 60px;
130
+ background: teal;
131
+ transition: all 0.5s;
132
+ }
133
+ .je-dropzone:before {
134
+ position: absolute;
135
+ content: attr(data-text);
136
+ color: rgba(0, 0, 0, 0.6);
137
+ left: 50%;
138
+ top: 50%;
139
+ transform: translate(-50%, -50%);
140
+ }
141
+ .je-dropzone.valid-dropzone {
142
+ background: green;
143
+ }
144
+ .je-dropzone.invalid-dropzone {
145
+ background: red;
146
+ }
147
+ /* Option: object_indent */
148
+ .columns .container.je-noindent {
149
+ padding-left: 0;
150
+ padding-right: 0;
151
+ }
152
+ /* Adjustments for Selectize styling */
153
+ .selectize-control.multi .item {
154
+ background: var(--primary-color) !important;
155
+ }
156
+ /* Adjustments for Select2 styling */
157
+ .select2-container--default
158
+ .select2-selection--single
159
+ .select2-selection__arrow {
160
+ display: none;
161
+ }
162
+ .select2-container--default .select2-selection--single {
163
+ border: none;
164
+ }
165
+ .select2-container .select2-selection--single .select2-selection__rendered {
166
+ padding: 0;
167
+ }
168
+ .select2-container .select2-search--inline .select2-search__field {
169
+ margin-top: 0;
170
+ }
171
+ .select2-container--default.select2-container--focus
172
+ .select2-selection--multiple {
173
+ border: 0.05rem solid var(--gray-color);
174
+ }
175
+ .select2-container--default
176
+ .select2-selection--multiple
177
+ .select2-selection__choice {
178
+ margin: 0.4rem 0.2rem 0.2rem 0;
179
+ padding: 2px 5px;
180
+ background-color: var(--primary-color);
181
+ color: var(--light-color);
182
+ }
183
+ .select2-container--default .select2-search--inline .select2-search__field {
184
+ line-height: normal;
185
+ }
186
+ /* Adjustment styling for Choices */
187
+ .choices {
188
+ margin-bottom: auto;
189
+ }
190
+ .choices__list--multiple .choices__item {
191
+ border: none;
192
+ background-color: var(--primary-color);
193
+ color: var(--light-color);
194
+ }
195
+ .choices[data-type*="select-multiple"] .choices__button {
196
+ border-left: 0.05rem solid #2826a6;
197
+ }
198
+ .choices__inner {
199
+ font-size: inherit;
200
+ min-height: 20px;
201
+ padding: 4px 7.5px 4px 3.75px;
202
+ }
203
+ .choices[data-type*="select-one"] .choices__inner {
204
+ padding-bottom: 4px;
205
+ }
206
+ .choices__list--dropdown .choices__item {
207
+ font-size: inherit;
208
+ }
@@ -0,0 +1,3 @@
1
+ /* eslint-disable */
2
+ export default {"*":"--primary-color:%235755d9;--gray-color:%23bcc3ce;--light-color:%23fff",".slider:focus":"box-shadow:none","h4 > label + .btn-group":"margin-left:1rem",".text-right > button":"margin-right:0%20!important",".text-left > button":"margin-left:0%20!important",".property-selector":"font-size:0.7rem;font-weight:normal;max-height:260px%20!important;width:395px%20!important",".property-selector .form-checkbox":"margin:0","textarea":"width:100%25;min-height:2rem;resize:vertical","table":"border-collapse:collapse",".table td":"padding:0.4rem%200.4rem",".mr-5":"margin-right:1rem%20!important","div[data-schematype]:not([data-schematype='object'])":"transition:0.5s","div[data-schematype]:not([data-schematype='object']):hover":"background-color:%23eee",".je-table-border td":"border:0.05rem%20solid%20%23dadee4%20!important",".btn-info":"font-size:0.5rem;font-weight:bold;height:0.8rem;padding:0.15rem%200;line-height:0.8;margin:0.3rem%200%200.3rem%200.1rem",".je-label + select":"min-width:5rem",".je-label":"font-weight:600",".btn-action.btn-info":"width:0.8rem",".je-border":"border:0.05rem%20solid%20%23dadee4",".je-panel":"padding:0.2rem;margin:0.2rem;background-color:rgba(218%2C%20222%2C%20228%2C%200.1)",".je-panel-top":"padding:0.2rem;margin:0.2rem;background-color:rgba(218%2C%20222%2C%20228%2C%200.1)",".required:after":"content:%22%20*%22;color:red;font:inherit",".je-align-bottom":"margin-top:auto",".je-desc":"font-size:smaller;margin:0.2rem%200",".je-upload-preview img":"float:left;margin:0%200.5rem%200.5rem%200;max-width:100%25;max-height:5rem;border:3px%20solid%20white;box-shadow:0px%200px%208px%20rgba(0%2C%200%2C%200%2C%200.3);box-sizing:border-box",".je-dropzone":"position:relative;margin:0.5rem%200;border:2px%20dashed%20black;width:100%25;height:60px;background:teal;transition:all%200.5s",".je-dropzone:before":"position:absolute;content:attr(data-text);color:rgba(0%2C%200%2C%200%2C%200.6);left:50%25;top:50%25;transform:translate(-50%25%2C%20-50%25)",".je-dropzone.valid-dropzone":"background:green",".je-dropzone.invalid-dropzone":"background:red",".columns .container.je-noindent":"padding-left:0;padding-right:0",".selectize-control.multi .item":"background:var(--primary-color)%20!important",".select2-container--default .select2-selection--single .select2-selection__arrow":"display:none",".select2-container--default .select2-selection--single":"border:none",".select2-container .select2-selection--single .select2-selection__rendered":"padding:0",".select2-container .select2-search--inline .select2-search__field":"margin-top:0",".select2-container--default.select2-container--focus .select2-selection--multiple":"border:0.05rem%20solid%20var(--gray-color)",".select2-container--default .select2-selection--multiple .select2-selection__choice":"margin:0.4rem%200.2rem%200.2rem%200;padding:2px%205px;background-color:var(--primary-color);color:var(--light-color)",".select2-container--default .select2-search--inline .select2-search__field":"line-height:normal",".choices":"margin-bottom:auto",".choices__list--multiple .choices__item":"border:none;background-color:var(--primary-color);color:var(--light-color)",".choices[data-type*='select-multiple'] .choices__button":"border-left:0.05rem%20solid%20%232826a6",".choices__inner":"font-size:inherit;min-height:20px;padding:4px%207.5px%204px%203.75px",".choices[data-type*='select-one'] .choices__inner":"padding-bottom:4px",".choices__list--dropdown .choices__item":"font-size:inherit"}
3
+ /* eslint-enable */
@@ -0,0 +1,443 @@
1
+ /* Spectre Theme using Spectre CSS framework. <https://picturepan2.github.io/spectre/index.html> */
2
+ import { AbstractTheme } from '../theme.js'
3
+ import rules from './spectre.css.js'
4
+
5
+ /* Config options that allows changing various aspects of the output */
6
+ const options = {
7
+ disable_theme_rules: false, /* Disable creation of Inline Style Rules */
8
+ label_bold: true, /* Element labels bold */
9
+ align_bottom: false, /* Align elements to bottom of flex container */
10
+ object_indent: false, /* Indent nested object elements */
11
+ object_border: false, /* Add border around object elements */
12
+ table_border: false, /* Add border to array "table" row and cells */
13
+ table_zebrastyle: false, /* Add "zebra style" to array "table" rows */
14
+ input_size: 'normal' /* Size of input and select elements. "small", "normal", "large" */
15
+ }
16
+
17
+ export class spectreTheme extends AbstractTheme {
18
+ constructor (jsoneditor) {
19
+ super(jsoneditor, options)
20
+ }
21
+
22
+ getOptInSwitch (formname) {
23
+ const container = document.createElement('span')
24
+ container.classList.add('form-group')
25
+
26
+ const label = document.createElement('label')
27
+ label.classList.add('form-switch', 'd-inline-block')
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 icon = document.createElement('i')
35
+ icon.classList.add('form-icon')
36
+
37
+ const switchLabelText = document.createElement('span')
38
+ switchLabelText.classList.add('sr-only')
39
+ switchLabelText.textContent = formname + '-opt-in'
40
+
41
+ label.appendChild(switchLabelText)
42
+ label.appendChild(checkbox)
43
+ label.appendChild(icon)
44
+
45
+ container.appendChild(label)
46
+
47
+ return { label, checkbox, container }
48
+ }
49
+
50
+ /* Functions for setting up the grid container, row and columns */
51
+ setGridColumnSize (el, size, offset) {
52
+ el.classList.add(`col-${size}`)
53
+ if (offset) el.classList.add('col-mx-auto')
54
+ }
55
+
56
+ getGridContainer () {
57
+ const el = document.createElement('div')
58
+ el.classList.add('container')
59
+ if (!this.options.object_indent) el.classList.add('je-noindent')
60
+ return el
61
+ }
62
+
63
+ getGridRow () {
64
+ const el = document.createElement('div')
65
+ el.classList.add('columns')
66
+ return el
67
+ }
68
+
69
+ getGridColumn () {
70
+ const el = document.createElement('div')
71
+ el.classList.add('column')
72
+ if (this.options.align_bottom) el.classList.add('je-align-bottom')
73
+ return el
74
+ }
75
+
76
+ /* Used for "type: object" or "type: array" (except if "format: tabs-top") */
77
+ getIndentedPanel () {
78
+ const el = document.createElement('div')
79
+ el.classList.add('je-panel')
80
+ if (this.options.object_border) el.classList.add('je-border')
81
+ return el
82
+ }
83
+
84
+ /* Used for "type: array" with "format: tabs-top" */
85
+ getTopIndentedPanel () {
86
+ const el = document.createElement('div')
87
+ el.classList.add('je-panel-top')
88
+ if (this.options.object_border) el.classList.add('je-border')
89
+ return el
90
+ }
91
+
92
+ /* Button functions */
93
+ getHeaderButtonHolder () {
94
+ const el = this.getButtonHolder()
95
+ return el
96
+ }
97
+
98
+ /* Button holder for the buttons */
99
+ getButtonHolder () {
100
+ const el = super.getButtonHolder()
101
+ el.classList.add('btn-group')
102
+ return el
103
+ }
104
+
105
+ getFormButtonHolder (buttonAlign) {
106
+ const el = super.getFormButtonHolder()
107
+ el.classList.remove('btn-group')
108
+ el.classList.add('d-block')
109
+ if (buttonAlign === 'center') el.classList.add('text-center')
110
+ else if (buttonAlign === 'right') el.classList.add('text-right')
111
+ else el.classList.add('text-left')
112
+ return el
113
+ }
114
+
115
+ getFormButton (text, icon, title) {
116
+ const el = super.getFormButton(text, icon, title)
117
+ el.classList.add('btn', 'btn-primary', 'mx-2', 'my-1')
118
+ if (this.options.input_size !== 'small') el.classList.remove('btn-sm')
119
+ if (this.options.input_size === 'large') el.classList.add('btn-lg')
120
+ return el
121
+ }
122
+
123
+ getButton (text, icon, title) {
124
+ const el = super.getButton(text, icon, title)
125
+ el.classList.add('btn', 'btn-sm', 'btn-primary', 'mr-2', 'my-1')
126
+ return el
127
+ }
128
+
129
+ getHeader (text, pathDepth) {
130
+ const el = document.createElement('span')
131
+ if (typeof text === 'string') {
132
+ el.textContent = text
133
+ } else {
134
+ el.appendChild(text)
135
+ }
136
+
137
+ el.style.display = 'inline-block'
138
+
139
+ return el
140
+ }
141
+
142
+ getFormInputDescription (text) {
143
+ const el = super.getFormInputDescription(text)
144
+ el.classList.add('je-desc', 'hide-sm')
145
+ return el
146
+ }
147
+
148
+ /* Label for all elements except checkbox and radio */
149
+ getFormInputLabel (text, req) {
150
+ const el = super.getFormInputLabel(text, req)
151
+ if (this.options.label_bold) el.classList.add('je-label')
152
+ return el
153
+ }
154
+
155
+ /* Checkbox elements */
156
+ /* ToDo: Rename function names for consistency */
157
+ getCheckbox () {
158
+ const el = this.getFormInputField('checkbox')
159
+ return el
160
+ }
161
+
162
+ getCheckboxLabel (text, req) {
163
+ const el = super.getCheckboxLabel(text, req); const icon = document.createElement('i')
164
+ icon.classList.add('form-icon')
165
+ el.classList.add('form-checkbox', 'pr-0')
166
+ el.insertBefore(icon, el.firstChild)
167
+ return el
168
+ }
169
+
170
+ getFormCheckboxControl (label, input, compact) {
171
+ label.insertBefore(input, label.firstChild) /* Move input into label element */
172
+ if (compact) label.classList.add('form-inline')
173
+ return label
174
+ }
175
+
176
+ getMultiCheckboxHolder (controls, label, description, infoText) {
177
+ return super.getMultiCheckboxHolder(controls, label, description, infoText)
178
+ }
179
+
180
+ /* Radio elements */
181
+ getFormRadio (attributes) {
182
+ const el = this.getFormInputField('radio')
183
+ for (const key in attributes) {
184
+ el.setAttribute(key, attributes[key])
185
+ }
186
+ return el
187
+ }
188
+
189
+ getFormRadioLabel (text, req) {
190
+ const el = super.getFormRadioLabel(text, req); const icon = document.createElement('i')
191
+ icon.classList.add('form-icon')
192
+ el.classList.add('form-radio')
193
+ el.insertBefore(icon, el.firstChild)
194
+ return el
195
+ }
196
+
197
+ getFormRadioControl (label, input, compact) {
198
+ label.insertBefore(input, label.firstChild) /* Move input into label element */
199
+ if (compact) label.classList.add('form-inline')
200
+ return label
201
+ }
202
+
203
+ /* Create input field */
204
+ getFormInputField (type) {
205
+ const el = super.getFormInputField(type)
206
+ if (!['checkbox', 'radio'].includes(type)) {
207
+ el.classList.add('form-input')
208
+ }
209
+ return el
210
+ }
211
+
212
+ /* Create input field for type="range" */
213
+ getRangeInput (min, max, step, description, formName) {
214
+ const el = super.getRangeInput(min, max, step, description, formName)
215
+ el.classList.add('slider')
216
+ el.classList.remove('form-input')
217
+ el.setAttribute('oninput', 'this.setAttribute("value", this.value)')
218
+ return el
219
+ }
220
+
221
+ getRangeControl (input, output) {
222
+ const el = super.getRangeControl(input, output)
223
+ el.classList.add('text-center')
224
+ return el
225
+ }
226
+
227
+ /* Create select box field */
228
+ getSelectInput (options, multiple) {
229
+ const el = super.getSelectInput(options)
230
+ el.classList.add('form-select')
231
+ return el
232
+ }
233
+
234
+ /* Create textarea field */
235
+ getTextareaInput () {
236
+ const el = document.createElement('textarea')
237
+ el.classList.add('form-input')
238
+ return el
239
+ }
240
+
241
+ getFormControl (label, input, description, infoText, formName) {
242
+ const group = document.createElement('div')
243
+ group.classList.add('form-group')
244
+
245
+ if (label && (input.type === 'checkbox' || input.type === 'radio')) {
246
+ group.classList.add(input.type)
247
+ if (infoText) label.appendChild(infoText)
248
+ label.insertBefore(input, label.firstChild)
249
+ group.appendChild(label)
250
+ } else {
251
+ if (label) {
252
+ label.classList.add('form-label')
253
+ group.appendChild(label)
254
+ if (infoText) label.appendChild(infoText)
255
+ }
256
+ group.appendChild(input)
257
+ }
258
+
259
+ if (this.options.input_size === 'small') input.classList.add('input-sm', 'select-sm')
260
+ else if (this.options.input_size === 'large') input.classList.add('input-lg', 'select-lg')
261
+ if (input.type !== 'checkbox') group.appendChild(input)
262
+
263
+ if (description) group.appendChild(description)
264
+
265
+ if (input.tagName.toLowerCase() !== 'div' && input && label && formName) {
266
+ label.setAttribute('for', formName)
267
+ input.setAttribute('id', formName)
268
+ }
269
+
270
+ if (input.tagName.toLowerCase() !== 'div' && input && description) {
271
+ description.setAttribute('id', formName + '-description')
272
+ input.setAttribute('aria-describedby', formName + '-description')
273
+ }
274
+
275
+ return group
276
+ }
277
+
278
+ /* Create input group (input field with buttons) */
279
+ getInputGroup (input, buttons) {
280
+ if (!input) return
281
+
282
+ const inputGroup = document.createElement('div')
283
+ inputGroup.classList.add('input-group')
284
+ inputGroup.appendChild(input)
285
+ for (let i = 0; i < buttons.length; i++) {
286
+ buttons[i].classList.add('input-group-btn')
287
+ buttons[i].classList.remove('btn-sm', 'mr-2', 'my-1')
288
+ inputGroup.appendChild(buttons[i])
289
+ }
290
+
291
+ return inputGroup
292
+ }
293
+
294
+ /* Create button for displaying infotext tooltip */
295
+ getInfoButton (text) {
296
+ const popover = document.createElement('div')
297
+ popover.classList.add('popover', 'popover-left', 'float-right')
298
+
299
+ const button = document.createElement('button')
300
+ button.classList.add('btn', 'btn-secondary', 'btn-info', 'btn-action', 's-circle')
301
+ button.setAttribute('tabindex', '-1') /* exclude element from tab order */
302
+ popover.appendChild(button)
303
+
304
+ const icon = document.createTextNode('I')
305
+ button.appendChild(icon)
306
+
307
+ const container = document.createElement('div')
308
+ container.classList.add('popover-container')
309
+ popover.appendChild(container)
310
+
311
+ const card = document.createElement('div')
312
+ card.classList.add('card')
313
+ container.appendChild(card)
314
+
315
+ const cardbody = document.createElement('div')
316
+ cardbody.classList.add('card-body')
317
+ cardbody.innerHTML = text
318
+ card.appendChild(cardbody)
319
+
320
+ return popover
321
+ }
322
+
323
+ /* Functions for rendering array with format: "table" */
324
+ getTable () {
325
+ const el = super.getTable()
326
+ el.classList.add('table', 'table-scroll')
327
+ if (this.options.table_border) el.classList.add('je-table-border')
328
+ if (this.options.table_zebrastyle) el.classList.add('table-striped')
329
+ return el
330
+ }
331
+
332
+ /* Function for rendering progressbar */
333
+ getProgressBar () {
334
+ const progressBar = super.getProgressBar()
335
+ progressBar.classList.add('progress')
336
+ return progressBar
337
+ }
338
+
339
+ /* Containers for array with format: "tab" */
340
+ getTabHolder (propertyName) {
341
+ const pName = typeof propertyName === 'undefined' ? '' : propertyName
342
+ const el = document.createElement('div')
343
+ el.classList.add('columns')
344
+ el.innerHTML = `<div class="column col-2"></div><div class="column col-10 content" id="${pName}"></div>`
345
+ return el
346
+ }
347
+
348
+ /* Containers for array with format: "tab-top" */
349
+ getTopTabHolder (propertyName) {
350
+ const pName = typeof propertyName === 'undefined' ? '' : propertyName
351
+ const el = document.createElement('div')
352
+ el.innerHTML = `<ul class="tab"></ul><div class="content" id="${pName}"></div>`
353
+ return el
354
+ }
355
+
356
+ /* Tab button for array with format: "tab" */
357
+ getTab (span, tabId) {
358
+ const el = document.createElement('a')
359
+ el.classList.add('btn', 'btn-secondary', 'btn-block')
360
+ el.setAttribute('href', `#${tabId}`)
361
+ el.appendChild(span)
362
+ return el
363
+ }
364
+
365
+ /* Tab button for array with format: "tab-top" */
366
+ getTopTab (span, tabId) {
367
+ const el = document.createElement('li')
368
+ el.id = tabId
369
+ el.classList.add('tab-item')
370
+
371
+ /* Spectre needs an a tag inside the tab item, not a span */
372
+ const a = document.createElement('a')
373
+ a.setAttribute('href', `#${tabId}`)
374
+ a.appendChild(span)
375
+
376
+ el.appendChild(a)
377
+ return el
378
+ }
379
+
380
+ markTabActive (row) {
381
+ row.tab.classList.add('active')
382
+ if (typeof row.rowPane !== 'undefined') row.rowPane.style.display = ''
383
+ else row.container.style.display = ''
384
+ }
385
+
386
+ markTabInactive (row) {
387
+ row.tab.classList.remove('active')
388
+ if (typeof row.rowPane !== 'undefined') row.rowPane.style.display = 'none'
389
+ else row.container.style.display = 'none'
390
+ }
391
+
392
+ afterInputReady (input) {
393
+ if (input.localName === 'select') {
394
+ /* Selectize adjustments */
395
+ if (input.classList.contains('selectized')) {
396
+ const selectized = input.nextSibling
397
+ if (selectized) {
398
+ /* Remove Spectre class 'form-select' as this conflicts with Selectize styling */
399
+ selectized.classList.remove('form-select')
400
+ Array.from(selectized.querySelectorAll('.form-select')).forEach(el => {
401
+ el.classList.remove('form-select')
402
+ })
403
+ }
404
+ /* Select2 ajustments */
405
+ } else if (input.classList.contains('select2-hidden-accessible')) {
406
+ const select2 = input.nextSibling
407
+ const single = select2 && select2.querySelector('.select2-selection--single')
408
+ /* Add Spectre 'form-select' to single-select2 elements */
409
+ if (single) select2.classList.add('form-select')
410
+ }
411
+ }
412
+
413
+ if (input.controlgroup) return
414
+ input.controlgroup = this.closest(input, '.form-group')
415
+ if (this.closest(input, '.compact')) {
416
+ input.controlgroup.style.marginBottom = 0
417
+ }
418
+ }
419
+
420
+ /* Controls output of errormessages displayed in form */
421
+ addInputError (input, text) {
422
+ if (!input.controlgroup) return
423
+ input.controlgroup.classList.add('has-error')
424
+ if (!input.errmsg) {
425
+ input.errmsg = document.createElement('p')
426
+ input.errmsg.classList.add('form-input-hint')
427
+ input.controlgroup.appendChild(input.errmsg)
428
+ }
429
+ input.errmsg.classList.remove('d-hide')
430
+ input.errmsg.textContent = text
431
+ input.errmsg.setAttribute('role', 'alert')
432
+ }
433
+
434
+ removeInputError (input) {
435
+ if (!input.errmsg) return
436
+ input.errmsg.classList.add('d-hide')
437
+ input.controlgroup.classList.remove('has-error')
438
+ }
439
+ }
440
+
441
+ /* Custom stylesheet rules. (Does not support comma separated selectors) */
442
+ /* Will create a stylesheet in document head with the id "theme-spectre" if not exists. */
443
+ spectreTheme.rules = rules