@saltcorn/data 0.6.2-beta.1 → 0.6.2-beta.5

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 (555) hide show
  1. package/dist/base-plugin/actions.d.ts +141 -0
  2. package/dist/base-plugin/actions.d.ts.map +1 -0
  3. package/dist/base-plugin/actions.js +551 -0
  4. package/dist/base-plugin/actions.js.map +1 -0
  5. package/dist/base-plugin/base.test.d.ts +2 -0
  6. package/dist/base-plugin/base.test.d.ts.map +1 -0
  7. package/dist/base-plugin/base.test.js +15 -0
  8. package/dist/base-plugin/base.test.js.map +1 -0
  9. package/dist/base-plugin/fieldviews.d.ts +25 -0
  10. package/dist/base-plugin/fieldviews.d.ts.map +1 -0
  11. package/dist/base-plugin/fieldviews.js +159 -0
  12. package/dist/base-plugin/fieldviews.js.map +1 -0
  13. package/dist/base-plugin/fileviews.d.ts +52 -0
  14. package/dist/base-plugin/fileviews.d.ts.map +1 -0
  15. package/dist/base-plugin/fileviews.js +59 -0
  16. package/dist/base-plugin/fileviews.js.map +1 -0
  17. package/dist/base-plugin/index.d.ts +524 -0
  18. package/dist/base-plugin/index.d.ts.map +1 -0
  19. package/{base-plugin → dist/base-plugin}/index.js +22 -24
  20. package/dist/base-plugin/index.js.map +1 -0
  21. package/dist/base-plugin/types.d.ts +383 -0
  22. package/dist/base-plugin/types.d.ts.map +1 -0
  23. package/dist/base-plugin/types.js +1080 -0
  24. package/dist/base-plugin/types.js.map +1 -0
  25. package/dist/base-plugin/viewtemplates/edit.d.ts +116 -0
  26. package/dist/base-plugin/viewtemplates/edit.d.ts.map +1 -0
  27. package/dist/base-plugin/viewtemplates/edit.js +561 -0
  28. package/dist/base-plugin/viewtemplates/edit.js.map +1 -0
  29. package/dist/base-plugin/viewtemplates/feed.d.ts +73 -0
  30. package/dist/base-plugin/viewtemplates/feed.d.ts.map +1 -0
  31. package/dist/base-plugin/viewtemplates/feed.js +348 -0
  32. package/dist/base-plugin/viewtemplates/feed.js.map +1 -0
  33. package/dist/base-plugin/viewtemplates/filter.d.ts +46 -0
  34. package/dist/base-plugin/viewtemplates/filter.d.ts.map +1 -0
  35. package/dist/base-plugin/viewtemplates/filter.js +267 -0
  36. package/dist/base-plugin/viewtemplates/filter.js.map +1 -0
  37. package/dist/base-plugin/viewtemplates/list.d.ts +99 -0
  38. package/dist/base-plugin/viewtemplates/list.d.ts.map +1 -0
  39. package/dist/base-plugin/viewtemplates/list.js +471 -0
  40. package/dist/base-plugin/viewtemplates/list.js.map +1 -0
  41. package/dist/base-plugin/viewtemplates/listshowlist.d.ts +41 -0
  42. package/dist/base-plugin/viewtemplates/listshowlist.d.ts.map +1 -0
  43. package/dist/base-plugin/viewtemplates/listshowlist.js +248 -0
  44. package/dist/base-plugin/viewtemplates/listshowlist.js.map +1 -0
  45. package/dist/base-plugin/viewtemplates/room.d.ts +140 -0
  46. package/dist/base-plugin/viewtemplates/room.d.ts.map +1 -0
  47. package/dist/base-plugin/viewtemplates/room.js +469 -0
  48. package/dist/base-plugin/viewtemplates/room.js.map +1 -0
  49. package/dist/base-plugin/viewtemplates/show.d.ts +101 -0
  50. package/dist/base-plugin/viewtemplates/show.d.ts.map +1 -0
  51. package/dist/base-plugin/viewtemplates/show.js +562 -0
  52. package/dist/base-plugin/viewtemplates/show.js.map +1 -0
  53. package/dist/base-plugin/viewtemplates/viewable_fields.d.ts +108 -0
  54. package/dist/base-plugin/viewtemplates/viewable_fields.d.ts.map +1 -0
  55. package/dist/base-plugin/viewtemplates/viewable_fields.js +563 -0
  56. package/dist/base-plugin/viewtemplates/viewable_fields.js.map +1 -0
  57. package/dist/contracts.d.ts +49 -0
  58. package/dist/contracts.d.ts.map +1 -0
  59. package/dist/contracts.js +212 -0
  60. package/dist/contracts.js.map +1 -0
  61. package/dist/coverage/lcov-report/block-navigation.d.ts +2 -0
  62. package/dist/coverage/lcov-report/block-navigation.d.ts.map +1 -0
  63. package/dist/coverage/lcov-report/block-navigation.js +66 -0
  64. package/dist/coverage/lcov-report/block-navigation.js.map +1 -0
  65. package/dist/coverage/lcov-report/prettify.d.ts +1 -0
  66. package/dist/coverage/lcov-report/prettify.d.ts.map +1 -0
  67. package/dist/coverage/lcov-report/prettify.js +478 -0
  68. package/dist/coverage/lcov-report/prettify.js.map +1 -0
  69. package/dist/coverage/lcov-report/sorter.d.ts +2 -0
  70. package/dist/coverage/lcov-report/sorter.d.ts.map +1 -0
  71. package/dist/coverage/lcov-report/sorter.js +141 -0
  72. package/dist/coverage/lcov-report/sorter.js.map +1 -0
  73. package/dist/db/connect.d.ts +40 -0
  74. package/dist/db/connect.d.ts.map +1 -0
  75. package/dist/db/connect.js +150 -0
  76. package/dist/db/connect.js.map +1 -0
  77. package/dist/db/db.test.d.ts +2 -0
  78. package/dist/db/db.test.d.ts.map +1 -0
  79. package/dist/db/db.test.js +28 -0
  80. package/dist/db/db.test.js.map +1 -0
  81. package/dist/db/fixtures.d.ts +8 -0
  82. package/dist/db/fixtures.d.ts.map +1 -0
  83. package/dist/db/fixtures.js +300 -0
  84. package/dist/db/fixtures.js.map +1 -0
  85. package/dist/db/index.d.ts +3 -0
  86. package/dist/db/index.d.ts.map +1 -0
  87. package/dist/db/index.js +41 -0
  88. package/dist/db/index.js.map +1 -0
  89. package/dist/db/reset_schema.d.ts +13 -0
  90. package/dist/db/reset_schema.d.ts.map +1 -0
  91. package/{db → dist/db}/reset_schema.js +45 -55
  92. package/dist/db/reset_schema.js.map +1 -0
  93. package/dist/db/state.d.ts +56 -0
  94. package/dist/db/state.d.ts.map +1 -0
  95. package/dist/db/state.js +610 -0
  96. package/dist/db/state.js.map +1 -0
  97. package/dist/index.d.ts +2 -0
  98. package/dist/index.d.ts.map +1 -0
  99. package/{index.js → dist/index.js} +2 -1
  100. package/dist/index.js.map +1 -0
  101. package/dist/migrate.d.ts +12 -0
  102. package/dist/migrate.d.ts.map +1 -0
  103. package/dist/migrate.js +94 -0
  104. package/dist/migrate.js.map +1 -0
  105. package/dist/migrations/202005141503.d.ts +2 -0
  106. package/dist/migrations/202005141503.d.ts.map +1 -0
  107. package/{migrations → dist/migrations}/202005141503.js +2 -1
  108. package/dist/migrations/202005141503.js.map +1 -0
  109. package/dist/migrations/202005241712.d.ts +2 -0
  110. package/dist/migrations/202005241712.d.ts.map +1 -0
  111. package/{migrations → dist/migrations}/202005241712.js +2 -1
  112. package/dist/migrations/202005241712.js.map +1 -0
  113. package/dist/migrations/202005251037.d.ts +2 -0
  114. package/dist/migrations/202005251037.d.ts.map +1 -0
  115. package/{migrations → dist/migrations}/202005251037.js +2 -1
  116. package/dist/migrations/202005251037.js.map +1 -0
  117. package/dist/migrations/202005282134.d.ts +2 -0
  118. package/dist/migrations/202005282134.d.ts.map +1 -0
  119. package/{migrations → dist/migrations}/202005282134.js +2 -1
  120. package/dist/migrations/202005282134.js.map +1 -0
  121. package/dist/migrations/202006022156.d.ts +2 -0
  122. package/dist/migrations/202006022156.d.ts.map +1 -0
  123. package/{migrations → dist/migrations}/202006022156.js +2 -1
  124. package/dist/migrations/202006022156.js.map +1 -0
  125. package/dist/migrations/202006051507.d.ts +2 -0
  126. package/dist/migrations/202006051507.d.ts.map +1 -0
  127. package/{migrations → dist/migrations}/202006051507.js +2 -1
  128. package/dist/migrations/202006051507.js.map +1 -0
  129. package/dist/migrations/202006240906.d.ts +2 -0
  130. package/dist/migrations/202006240906.d.ts.map +1 -0
  131. package/{migrations → dist/migrations}/202006240906.js +2 -1
  132. package/dist/migrations/202006240906.js.map +1 -0
  133. package/dist/migrations/202007091707.d.ts +2 -0
  134. package/dist/migrations/202007091707.d.ts.map +1 -0
  135. package/{migrations → dist/migrations}/202007091707.js +2 -1
  136. package/dist/migrations/202007091707.js.map +1 -0
  137. package/dist/migrations/202007202144.d.ts +2 -0
  138. package/dist/migrations/202007202144.d.ts.map +1 -0
  139. package/{migrations → dist/migrations}/202007202144.js +2 -1
  140. package/dist/migrations/202007202144.js.map +1 -0
  141. package/dist/migrations/202008031500.d.ts +2 -0
  142. package/dist/migrations/202008031500.d.ts.map +1 -0
  143. package/dist/migrations/202008031500.js +4 -0
  144. package/dist/migrations/202008031500.js.map +1 -0
  145. package/dist/migrations/202008051415.d.ts +2 -0
  146. package/dist/migrations/202008051415.d.ts.map +1 -0
  147. package/{migrations → dist/migrations}/202008051415.js +2 -1
  148. package/dist/migrations/202008051415.js.map +1 -0
  149. package/dist/migrations/202008121149.d.ts +3 -0
  150. package/dist/migrations/202008121149.d.ts.map +1 -0
  151. package/{migrations → dist/migrations}/202008121149.js +2 -2
  152. package/dist/migrations/202008121149.js.map +1 -0
  153. package/dist/migrations/202009112140.d.ts +3 -0
  154. package/dist/migrations/202009112140.d.ts.map +1 -0
  155. package/{migrations → dist/migrations}/202009112140.js +2 -2
  156. package/dist/migrations/202009112140.js.map +1 -0
  157. package/dist/migrations/202009181655.d.ts +2 -0
  158. package/dist/migrations/202009181655.d.ts.map +1 -0
  159. package/dist/migrations/202009181655.js +7 -0
  160. package/dist/migrations/202009181655.js.map +1 -0
  161. package/dist/migrations/202009221105.d.ts +2 -0
  162. package/dist/migrations/202009221105.d.ts.map +1 -0
  163. package/dist/migrations/202009221105.js +4 -0
  164. package/dist/migrations/202009221105.js.map +1 -0
  165. package/dist/migrations/202009231331.d.ts +2 -0
  166. package/dist/migrations/202009231331.d.ts.map +1 -0
  167. package/{migrations → dist/migrations}/202009231331.js +2 -1
  168. package/dist/migrations/202009231331.js.map +1 -0
  169. package/dist/migrations/202009301531.d.ts +2 -0
  170. package/dist/migrations/202009301531.d.ts.map +1 -0
  171. package/dist/migrations/202009301531.js +8 -0
  172. package/dist/migrations/202009301531.js.map +1 -0
  173. package/dist/migrations/202010231444.d.ts +2 -0
  174. package/dist/migrations/202010231444.d.ts.map +1 -0
  175. package/dist/migrations/202010231444.js +4 -0
  176. package/dist/migrations/202010231444.js.map +1 -0
  177. package/dist/migrations/202010251412.d.ts +2 -0
  178. package/dist/migrations/202010251412.d.ts.map +1 -0
  179. package/dist/migrations/202010251412.js +10 -0
  180. package/dist/migrations/202010251412.js.map +1 -0
  181. package/dist/migrations/202011021749.d.ts +2 -0
  182. package/dist/migrations/202011021749.d.ts.map +1 -0
  183. package/{migrations → dist/migrations}/202011021749.js +2 -1
  184. package/dist/migrations/202011021749.js.map +1 -0
  185. package/dist/migrations/202011051353.d.ts +2 -0
  186. package/dist/migrations/202011051353.d.ts.map +1 -0
  187. package/{migrations → dist/migrations}/202011051353.js +2 -1
  188. package/dist/migrations/202011051353.js.map +1 -0
  189. package/dist/migrations/202011111127.d.ts +2 -0
  190. package/dist/migrations/202011111127.d.ts.map +1 -0
  191. package/{migrations → dist/migrations}/202011111127.js +2 -1
  192. package/dist/migrations/202011111127.js.map +1 -0
  193. package/dist/migrations/202012011203.d.ts +2 -0
  194. package/dist/migrations/202012011203.d.ts.map +1 -0
  195. package/{migrations → dist/migrations}/202012011203.js +2 -1
  196. package/dist/migrations/202012011203.js.map +1 -0
  197. package/dist/migrations/202012100841.d.ts +2 -0
  198. package/dist/migrations/202012100841.d.ts.map +1 -0
  199. package/{migrations → dist/migrations}/202012100841.js +2 -1
  200. package/dist/migrations/202012100841.js.map +1 -0
  201. package/dist/migrations/202012281835.d.ts +2 -0
  202. package/dist/migrations/202012281835.d.ts.map +1 -0
  203. package/{migrations → dist/migrations}/202012281835.js +2 -1
  204. package/dist/migrations/202012281835.js.map +1 -0
  205. package/dist/migrations/202101061051.d.ts +2 -0
  206. package/dist/migrations/202101061051.d.ts.map +1 -0
  207. package/{migrations → dist/migrations}/202101061051.js +2 -1
  208. package/dist/migrations/202101061051.js.map +1 -0
  209. package/dist/migrations/202101141128.d.ts +2 -0
  210. package/dist/migrations/202101141128.d.ts.map +1 -0
  211. package/dist/migrations/202101141128.js +4 -0
  212. package/dist/migrations/202101141128.js.map +1 -0
  213. package/dist/migrations/202102091312.d.ts +3 -0
  214. package/dist/migrations/202102091312.d.ts.map +1 -0
  215. package/dist/migrations/202102091312.js +19 -0
  216. package/dist/migrations/202102091312.js.map +1 -0
  217. package/dist/migrations/202102101624.d.ts +2 -0
  218. package/dist/migrations/202102101624.d.ts.map +1 -0
  219. package/dist/migrations/202102101624.js +7 -0
  220. package/dist/migrations/202102101624.js.map +1 -0
  221. package/dist/migrations/202102172148.d.ts +2 -0
  222. package/dist/migrations/202102172148.d.ts.map +1 -0
  223. package/{migrations → dist/migrations}/202102172148.js +2 -2
  224. package/dist/migrations/202102172148.js.map +1 -0
  225. package/dist/migrations/202102261650.d.ts +2 -0
  226. package/dist/migrations/202102261650.d.ts.map +1 -0
  227. package/dist/migrations/202102261650.js +7 -0
  228. package/dist/migrations/202102261650.js.map +1 -0
  229. package/dist/migrations/202106102347.d.ts +2 -0
  230. package/dist/migrations/202106102347.d.ts.map +1 -0
  231. package/{migrations → dist/migrations}/202106102347.js +2 -3
  232. package/dist/migrations/202106102347.js.map +1 -0
  233. package/dist/migrations/202106112120.d.ts +2 -0
  234. package/dist/migrations/202106112120.d.ts.map +1 -0
  235. package/{migrations → dist/migrations}/202106112120.js +2 -3
  236. package/dist/migrations/202106112120.js.map +1 -0
  237. package/dist/migrations/202106120012.d.ts +2 -0
  238. package/dist/migrations/202106120012.d.ts.map +1 -0
  239. package/{migrations → dist/migrations}/202106120012.js +2 -3
  240. package/dist/migrations/202106120012.js.map +1 -0
  241. package/dist/migrations/202106120220.d.ts +2 -0
  242. package/dist/migrations/202106120220.d.ts.map +1 -0
  243. package/{migrations → dist/migrations}/202106120220.js +2 -4
  244. package/dist/migrations/202106120220.js.map +1 -0
  245. package/dist/migrations/202106121701.d.ts +2 -0
  246. package/dist/migrations/202106121701.d.ts.map +1 -0
  247. package/{migrations → dist/migrations}/202106121701.js +2 -3
  248. package/dist/migrations/202106121701.js.map +1 -0
  249. package/dist/migrations/202106121703.d.ts +3 -0
  250. package/dist/migrations/202106121703.d.ts.map +1 -0
  251. package/{migrations → dist/migrations}/202106121703.js +2 -3
  252. package/dist/migrations/202106121703.js.map +1 -0
  253. package/dist/migrations/202106251126.d.ts +2 -0
  254. package/dist/migrations/202106251126.d.ts.map +1 -0
  255. package/dist/migrations/202106251126.js +6 -0
  256. package/dist/migrations/202106251126.js.map +1 -0
  257. package/dist/migrations/202107281619.d.ts +2 -0
  258. package/dist/migrations/202107281619.d.ts.map +1 -0
  259. package/{migrations → dist/migrations}/202107281619.js +2 -1
  260. package/dist/migrations/202107281619.js.map +1 -0
  261. package/dist/migrations/202107302158.d.ts +3 -0
  262. package/dist/migrations/202107302158.d.ts.map +1 -0
  263. package/{migrations → dist/migrations}/202107302158.js +2 -3
  264. package/dist/migrations/202107302158.js.map +1 -0
  265. package/dist/migrations/202108022257.d.ts +2 -0
  266. package/dist/migrations/202108022257.d.ts.map +1 -0
  267. package/{migrations → dist/migrations}/202108022257.js +3 -4
  268. package/dist/migrations/202108022257.js.map +1 -0
  269. package/dist/migrations/202109201624.d.ts +2 -0
  270. package/dist/migrations/202109201624.d.ts.map +1 -0
  271. package/{migrations → dist/migrations}/202109201624.js +2 -1
  272. package/dist/migrations/202109201624.js.map +1 -0
  273. package/dist/migrations/202109301031.d.ts +3 -0
  274. package/dist/migrations/202109301031.d.ts.map +1 -0
  275. package/{migrations → dist/migrations}/202109301031.js +2 -2
  276. package/dist/migrations/202109301031.js.map +1 -0
  277. package/dist/migrations/202111290253.d.ts +3 -0
  278. package/dist/migrations/202111290253.d.ts.map +1 -0
  279. package/dist/migrations/202111290253.js +5 -0
  280. package/dist/migrations/202111290253.js.map +1 -0
  281. package/dist/models/backup.d.ts +22 -0
  282. package/dist/models/backup.d.ts.map +1 -0
  283. package/{models → dist/models}/backup.js +95 -192
  284. package/dist/models/backup.js.map +1 -0
  285. package/dist/models/config.d.ts +180 -0
  286. package/dist/models/config.d.ts.map +1 -0
  287. package/dist/models/config.js +758 -0
  288. package/dist/models/config.js.map +1 -0
  289. package/dist/models/crash.d.ts +74 -0
  290. package/dist/models/crash.d.ts.map +1 -0
  291. package/dist/models/crash.js +118 -0
  292. package/dist/models/crash.js.map +1 -0
  293. package/dist/models/discovery.d.ts +28 -0
  294. package/dist/models/discovery.d.ts.map +1 -0
  295. package/dist/models/discovery.js +163 -0
  296. package/dist/models/discovery.js.map +1 -0
  297. package/dist/models/email.d.ts +16 -0
  298. package/dist/models/email.d.ts.map +1 -0
  299. package/dist/models/email.js +90 -0
  300. package/dist/models/email.js.map +1 -0
  301. package/dist/models/eventlog.d.ts +77 -0
  302. package/dist/models/eventlog.d.ts.map +1 -0
  303. package/dist/models/eventlog.js +132 -0
  304. package/dist/models/eventlog.js.map +1 -0
  305. package/dist/models/expression.d.ts +54 -0
  306. package/dist/models/expression.d.ts.map +1 -0
  307. package/dist/models/expression.js +274 -0
  308. package/dist/models/expression.js.map +1 -0
  309. package/dist/models/field.d.ts +217 -0
  310. package/dist/models/field.d.ts.map +1 -0
  311. package/dist/models/field.js +619 -0
  312. package/dist/models/field.js.map +1 -0
  313. package/dist/models/fieldrepeat.d.ts +49 -0
  314. package/dist/models/fieldrepeat.d.ts.map +1 -0
  315. package/dist/models/fieldrepeat.js +88 -0
  316. package/dist/models/fieldrepeat.js.map +1 -0
  317. package/dist/models/file.d.ts +122 -0
  318. package/dist/models/file.d.ts.map +1 -0
  319. package/dist/models/file.js +224 -0
  320. package/dist/models/file.js.map +1 -0
  321. package/dist/models/form.d.ts +82 -0
  322. package/dist/models/form.d.ts.map +1 -0
  323. package/dist/models/form.js +163 -0
  324. package/dist/models/form.js.map +1 -0
  325. package/dist/models/index.d.ts +1 -0
  326. package/dist/models/index.d.ts.map +1 -0
  327. package/{models → dist/models}/index.js +42 -42
  328. package/dist/models/index.js.map +1 -0
  329. package/dist/models/layout.d.ts +34 -0
  330. package/dist/models/layout.d.ts.map +1 -0
  331. package/dist/models/layout.js +153 -0
  332. package/dist/models/layout.js.map +1 -0
  333. package/dist/models/library.d.ts +50 -0
  334. package/dist/models/library.d.ts.map +1 -0
  335. package/dist/models/library.js +129 -0
  336. package/dist/models/library.js.map +1 -0
  337. package/dist/models/pack.d.ts +89 -0
  338. package/dist/models/pack.d.ts.map +1 -0
  339. package/dist/models/pack.js +390 -0
  340. package/dist/models/pack.js.map +1 -0
  341. package/dist/models/page.d.ts +101 -0
  342. package/dist/models/page.d.ts.map +1 -0
  343. package/dist/models/page.js +223 -0
  344. package/dist/models/page.js.map +1 -0
  345. package/dist/models/plugin.d.ts +100 -0
  346. package/dist/models/plugin.d.ts.map +1 -0
  347. package/dist/models/plugin.js +204 -0
  348. package/dist/models/plugin.js.map +1 -0
  349. package/dist/models/random.d.ts +24 -0
  350. package/dist/models/random.d.ts.map +1 -0
  351. package/dist/models/random.js +186 -0
  352. package/dist/models/random.js.map +1 -0
  353. package/dist/models/role.d.ts +42 -0
  354. package/dist/models/role.d.ts.map +1 -0
  355. package/dist/models/role.js +64 -0
  356. package/dist/models/role.js.map +1 -0
  357. package/dist/models/scheduler.d.ts +18 -0
  358. package/dist/models/scheduler.d.ts.map +1 -0
  359. package/dist/models/scheduler.js +159 -0
  360. package/dist/models/scheduler.js.map +1 -0
  361. package/dist/models/table.d.ts +326 -0
  362. package/dist/models/table.d.ts.map +1 -0
  363. package/dist/models/table.js +1006 -0
  364. package/dist/models/table.js.map +1 -0
  365. package/dist/models/table_constraints.d.ts +69 -0
  366. package/dist/models/table_constraints.d.ts.map +1 -0
  367. package/dist/models/table_constraints.js +118 -0
  368. package/dist/models/table_constraints.js.map +1 -0
  369. package/dist/models/tenant.d.ts +55 -0
  370. package/dist/models/tenant.d.ts.map +1 -0
  371. package/{models → dist/models}/tenant.js +40 -63
  372. package/dist/models/tenant.js.map +1 -0
  373. package/dist/models/trigger.d.ts +133 -0
  374. package/dist/models/trigger.d.ts.map +1 -0
  375. package/dist/models/trigger.js +292 -0
  376. package/dist/models/trigger.js.map +1 -0
  377. package/dist/models/user.d.ts +235 -0
  378. package/dist/models/user.d.ts.map +1 -0
  379. package/dist/models/user.js +434 -0
  380. package/dist/models/user.js.map +1 -0
  381. package/dist/models/view.d.ts +204 -0
  382. package/dist/models/view.d.ts.map +1 -0
  383. package/dist/models/view.js +497 -0
  384. package/dist/models/view.js.map +1 -0
  385. package/dist/models/workflow.d.ts +48 -0
  386. package/dist/models/workflow.d.ts.map +1 -0
  387. package/dist/models/workflow.js +190 -0
  388. package/dist/models/workflow.js.map +1 -0
  389. package/dist/plugin-helper.d.ts +145 -0
  390. package/dist/plugin-helper.d.ts.map +1 -0
  391. package/dist/plugin-helper.js +1158 -0
  392. package/dist/plugin-helper.js.map +1 -0
  393. package/dist/plugin-testing.d.ts +3 -0
  394. package/dist/plugin-testing.d.ts.map +1 -0
  395. package/dist/plugin-testing.js +120 -0
  396. package/dist/plugin-testing.js.map +1 -0
  397. package/dist/tests/actions.test.d.ts +2 -0
  398. package/dist/tests/actions.test.d.ts.map +1 -0
  399. package/dist/tests/actions.test.js +205 -0
  400. package/dist/tests/actions.test.js.map +1 -0
  401. package/dist/tests/auxtest.test.d.ts +2 -0
  402. package/dist/tests/auxtest.test.d.ts.map +1 -0
  403. package/dist/tests/auxtest.test.js +48 -0
  404. package/dist/tests/auxtest.test.js.map +1 -0
  405. package/dist/tests/backup.test.d.ts +2 -0
  406. package/dist/tests/backup.test.d.ts.map +1 -0
  407. package/dist/tests/backup.test.js +88 -0
  408. package/dist/tests/backup.test.js.map +1 -0
  409. package/dist/tests/calc.test.d.ts +2 -0
  410. package/dist/tests/calc.test.d.ts.map +1 -0
  411. package/dist/tests/calc.test.js +231 -0
  412. package/dist/tests/calc.test.js.map +1 -0
  413. package/dist/tests/config.test.d.ts +2 -0
  414. package/dist/tests/config.test.d.ts.map +1 -0
  415. package/dist/tests/config.test.js +83 -0
  416. package/dist/tests/config.test.js.map +1 -0
  417. package/dist/tests/discover.test.d.ts +2 -0
  418. package/dist/tests/discover.test.d.ts.map +1 -0
  419. package/dist/tests/discover.test.js +106 -0
  420. package/dist/tests/discover.test.js.map +1 -0
  421. package/dist/tests/exact_views.test.d.ts +2 -0
  422. package/dist/tests/exact_views.test.d.ts.map +1 -0
  423. package/dist/tests/exact_views.test.js +511 -0
  424. package/dist/tests/exact_views.test.js.map +1 -0
  425. package/dist/tests/field.test.d.ts +2 -0
  426. package/dist/tests/field.test.d.ts.map +1 -0
  427. package/dist/tests/field.test.js +237 -0
  428. package/dist/tests/field.test.js.map +1 -0
  429. package/dist/tests/form.test.d.ts +2 -0
  430. package/dist/tests/form.test.d.ts.map +1 -0
  431. package/dist/tests/form.test.js +191 -0
  432. package/dist/tests/form.test.js.map +1 -0
  433. package/dist/tests/mocks.d.ts +111 -0
  434. package/dist/tests/mocks.d.ts.map +1 -0
  435. package/dist/tests/mocks.js +165 -0
  436. package/dist/tests/mocks.js.map +1 -0
  437. package/dist/tests/models.test.d.ts +2 -0
  438. package/dist/tests/models.test.d.ts.map +1 -0
  439. package/dist/tests/models.test.js +210 -0
  440. package/dist/tests/models.test.js.map +1 -0
  441. package/dist/tests/pack.test.d.ts +2 -0
  442. package/dist/tests/pack.test.d.ts.map +1 -0
  443. package/dist/tests/pack.test.js +331 -0
  444. package/dist/tests/pack.test.js.map +1 -0
  445. package/dist/tests/plugin.test.d.ts +2 -0
  446. package/dist/tests/plugin.test.d.ts.map +1 -0
  447. package/dist/tests/plugin.test.js +53 -0
  448. package/dist/tests/plugin.test.js.map +1 -0
  449. package/dist/tests/random.test.d.ts +2 -0
  450. package/dist/tests/random.test.d.ts.map +1 -0
  451. package/dist/tests/random.test.js +138 -0
  452. package/dist/tests/random.test.js.map +1 -0
  453. package/dist/tests/table.test.d.ts +2 -0
  454. package/dist/tests/table.test.d.ts.map +1 -0
  455. package/dist/tests/table.test.js +1048 -0
  456. package/dist/tests/table.test.js.map +1 -0
  457. package/dist/tests/tenant.test.d.ts +2 -0
  458. package/dist/tests/tenant.test.d.ts.map +1 -0
  459. package/dist/tests/tenant.test.js +45 -0
  460. package/dist/tests/tenant.test.js.map +1 -0
  461. package/dist/tests/user.test.d.ts +2 -0
  462. package/dist/tests/user.test.d.ts.map +1 -0
  463. package/dist/tests/user.test.js +190 -0
  464. package/dist/tests/user.test.js.map +1 -0
  465. package/dist/tests/view.test.d.ts +2 -0
  466. package/dist/tests/view.test.d.ts.map +1 -0
  467. package/dist/tests/view.test.js +238 -0
  468. package/dist/tests/view.test.js.map +1 -0
  469. package/dist/tests/workflow.test.d.ts +2 -0
  470. package/dist/tests/workflow.test.d.ts.map +1 -0
  471. package/dist/tests/workflow.test.js +115 -0
  472. package/dist/tests/workflow.test.js.map +1 -0
  473. package/dist/tsconfig.ref.tsbuildinfo +1 -0
  474. package/dist/utils.d.ts +26 -0
  475. package/dist/utils.d.ts.map +1 -0
  476. package/dist/utils.js +124 -0
  477. package/dist/utils.js.map +1 -0
  478. package/package.json +34 -8
  479. package/base-plugin/actions.js +0 -629
  480. package/base-plugin/base.test.js +0 -15
  481. package/base-plugin/fieldviews.js +0 -197
  482. package/base-plugin/fileviews.js +0 -65
  483. package/base-plugin/types.js +0 -1154
  484. package/base-plugin/viewtemplates/edit.js +0 -672
  485. package/base-plugin/viewtemplates/feed.js +0 -434
  486. package/base-plugin/viewtemplates/filter.js +0 -358
  487. package/base-plugin/viewtemplates/list.js +0 -575
  488. package/base-plugin/viewtemplates/listshowlist.js +0 -292
  489. package/base-plugin/viewtemplates/room.js +0 -652
  490. package/base-plugin/viewtemplates/show.js +0 -689
  491. package/base-plugin/viewtemplates/viewable_fields.js +0 -714
  492. package/contracts.js +0 -311
  493. package/db/connect.js +0 -151
  494. package/db/db.test.js +0 -33
  495. package/db/fixtures.js +0 -303
  496. package/db/index.js +0 -63
  497. package/db/state.js +0 -674
  498. package/migrate.js +0 -99
  499. package/migrations/202008031500.js +0 -4
  500. package/migrations/202009181655.js +0 -6
  501. package/migrations/202009221105.js +0 -4
  502. package/migrations/202009301531.js +0 -7
  503. package/migrations/202010231444.js +0 -4
  504. package/migrations/202010251412.js +0 -9
  505. package/migrations/202101141128.js +0 -4
  506. package/migrations/202102091312.js +0 -19
  507. package/migrations/202102101624.js +0 -5
  508. package/migrations/202102261650.js +0 -6
  509. package/migrations/202106251126.js +0 -5
  510. package/models/config.js +0 -680
  511. package/models/crash.js +0 -126
  512. package/models/discovery.js +0 -195
  513. package/models/email.js +0 -92
  514. package/models/eventlog.js +0 -146
  515. package/models/expression.js +0 -276
  516. package/models/field.js +0 -746
  517. package/models/fieldrepeat.js +0 -96
  518. package/models/file.js +0 -234
  519. package/models/form.js +0 -169
  520. package/models/layout.js +0 -146
  521. package/models/library.js +0 -135
  522. package/models/pack.js +0 -466
  523. package/models/page.js +0 -255
  524. package/models/plugin.js +0 -219
  525. package/models/random.js +0 -206
  526. package/models/role.js +0 -94
  527. package/models/scheduler.js +0 -163
  528. package/models/table.js +0 -1211
  529. package/models/table_constraints.js +0 -133
  530. package/models/trigger.js +0 -327
  531. package/models/user.js +0 -503
  532. package/models/view.js +0 -622
  533. package/models/workflow.js +0 -205
  534. package/plugin-helper.js +0 -1311
  535. package/plugin-testing.js +0 -124
  536. package/tests/actions.test.js +0 -232
  537. package/tests/auxtest.test.js +0 -52
  538. package/tests/backup.test.js +0 -92
  539. package/tests/calc.test.js +0 -243
  540. package/tests/config.test.js +0 -91
  541. package/tests/discover.test.js +0 -114
  542. package/tests/exact_views.test.js +0 -526
  543. package/tests/field.test.js +0 -253
  544. package/tests/form.test.js +0 -198
  545. package/tests/mocks.js +0 -173
  546. package/tests/models.test.js +0 -221
  547. package/tests/pack.test.js +0 -350
  548. package/tests/plugin.test.js +0 -59
  549. package/tests/random.test.js +0 -154
  550. package/tests/table.test.js +0 -1091
  551. package/tests/tenant.test.js +0 -56
  552. package/tests/user.test.js +0 -196
  553. package/tests/view.test.js +0 -251
  554. package/tests/workflow.test.js +0 -119
  555. package/utils.js +0 -137
@@ -1,96 +0,0 @@
1
- /**
2
- * FieldRepeat Database Access Layer
3
- * @category saltcorn-data
4
- * @module models/fieldrepeat
5
- * @subcategory models
6
- */
7
- const { contract, is } = require("contractis");
8
- const Field = require("./field");
9
-
10
- /**
11
- * FieldRepeat Class
12
- * @category saltcorn-data
13
- */
14
- class FieldRepeat {
15
- /**
16
- * FieldRepeat constructor
17
- * @param {object} o
18
- */
19
- constructor(o) {
20
- this.label = o.label || o.name;
21
- this.name = o.name;
22
- this.fields = o.fields.map((f) =>
23
- f.constructor.name === Object.name ? new Field(f) : f
24
- );
25
- this.isRepeat = true;
26
- contract.class(this);
27
- }
28
-
29
- /**
30
- * @returns {Promise<void>}
31
- */
32
- async generate() {
33
- const nrepeats = Math.round(Math.random() * 5);
34
- var r = {};
35
- for (let index = 0; index < nrepeats; index++) {
36
- for (const f of this.fields) {
37
- if (f.required || is.bool.generate()) {
38
- r[`${f.name}_${index}`] = await f.generate();
39
- }
40
- }
41
- }
42
- }
43
-
44
- /**
45
- * @param {*} whole_rec
46
- * @returns {object}
47
- */
48
- validate(whole_rec) {
49
- return this.validate_from_ix(whole_rec, 0);
50
- }
51
-
52
- /**
53
- * @param {*} whole_rec
54
- * @param {*} ix
55
- * @returns {object}
56
- */
57
- validate_from_ix(whole_rec, ix) {
58
- var has_any = false;
59
- var res = {};
60
-
61
- this.fields.forEach((f) => {
62
- const fval = whole_rec[`${f.name}_${ix}`];
63
- if (typeof fval !== "undefined") {
64
- has_any = true;
65
- res[f.name] = fval;
66
- }
67
- });
68
- if (has_any) {
69
- const rest = this.validate_from_ix(whole_rec, ix + 1);
70
- return { success: [res, ...rest.success] };
71
- } else return { success: [] };
72
- }
73
-
74
- /**
75
- * @type {string}
76
- */
77
- get form_name() {
78
- return this.name;
79
- }
80
- }
81
-
82
- FieldRepeat.contract = {
83
- variables: {
84
- name: is.str,
85
- label: is.str,
86
- fields: is.array(is.class("Field")),
87
- isRepeat: is.eq(true),
88
- },
89
- methods: {
90
- validate: is.fun(
91
- is.obj(),
92
- is.or(is.obj({ errors: is.obj() }), is.obj({ success: is.obj() }))
93
- ),
94
- },
95
- };
96
- module.exports = FieldRepeat;
package/models/file.js DELETED
@@ -1,234 +0,0 @@
1
- /**
2
- * File Database Access Layer
3
- * @category saltcorn-data
4
- * @module models/file
5
- * @subcategory models
6
- */
7
-
8
- const db = require("../db");
9
- const { contract, is } = require("contractis");
10
- const { v4: uuidv4 } = require("uuid");
11
- const path = require("path");
12
- const { asyncMap } = require("../utils");
13
- const fs = require("fs").promises;
14
-
15
- /**
16
- * File Descriptor class
17
- *
18
- * Architecture tips:
19
- * 1. Physically Saltcorn stores files on local filesystem of the server, where Saltcorn runs.
20
- * 2. The path to file store is defined in db.connectObj.file_store.
21
- * 3. List of files stored in _sc_files table in Saltcorn database.
22
- * 4. Each tenant has own file list and file storage.
23
- * 5. This class provides file descriptor and basic functions to manipulate with files.
24
- * @category saltcorn-data
25
- */
26
- class File {
27
- /**
28
- * Constructor
29
- * @param o {object}
30
- */
31
- constructor(o) {
32
- this.filename = o.filename;
33
- this.location = o.location;
34
- this.uploaded_at = ["string", "number"].includes(typeof o.uploaded_at)
35
- ? new Date(o.uploaded_at)
36
- : o.uploaded_at;
37
- this.size_kb = o.size_kb;
38
- this.id = o.id;
39
- this.user_id = o.user_id;
40
- this.mime_super = o.mime_super;
41
- this.mime_sub = o.mime_sub;
42
- this.min_role_read = o.min_role_read;
43
- // TBD add checksum this.checksum = o.checksum;
44
- contract.class(this);
45
- }
46
-
47
- /**
48
- * Select list of file descriptors
49
- * @param where
50
- * @param selectopts
51
- * @returns {Promise<*>}
52
- */
53
- static async find(where, selectopts = {}) {
54
- if (selectopts.cached) {
55
- const { getState } = require("../db/state");
56
- const files = Object.values(getState().files).sort((a, b) =>
57
- a.filename > b.filename ? 1 : -1
58
- );
59
- return files.map((t) => new File(t));
60
- }
61
- const db_flds = await db.select("_sc_files", where, selectopts);
62
- return db_flds.map((dbf) => new File(dbf));
63
- }
64
-
65
- /**
66
- * Select one file descriptor
67
- *
68
- * @param where
69
- * @returns {Promise<File|null>}
70
- */
71
- static async findOne(where) {
72
- if (where.id) {
73
- const { getState } = require("../db/state");
74
- const cf = getState().files[+where.id];
75
- if (cf) return new File(cf);
76
- }
77
- const f = await db.selectMaybeOne("_sc_files", where);
78
- return f ? new File(f) : null;
79
- }
80
-
81
- /**
82
- * Update File descriptor
83
- *
84
- * @param id - primary key
85
- * @param row - row data
86
- * @returns {Promise<void>} no returns
87
- */
88
- static async update(id, row) {
89
- await db.update("_sc_files", row, id);
90
- await require("../db/state").getState().refresh_files();
91
- }
92
-
93
- /**
94
- * Get absolute path to new file in db.connectObj.file_store.
95
- *
96
- * @param suggest - path to file inside file store. If undefined that autogenerated uudv4 is used.
97
- * @returns {string} - path to file
98
- */
99
- static get_new_path(suggest) {
100
- const file_store = db.connectObj.file_store;
101
-
102
- const newFnm = suggest || uuidv4();
103
- return path.join(file_store, newFnm);
104
- }
105
-
106
- /**
107
- * Ensure that file_store path is physically exists in file system.
108
- * In reality just recursively creates full absolute path to db.connectObj.file_store.
109
- *
110
- * @returns {Promise<void>}
111
- */
112
- // TBD fs errors handling
113
- static async ensure_file_store() {
114
- const file_store = db.connectObj.file_store;
115
- await fs.mkdir(file_store, { recursive: true });
116
- }
117
-
118
- /**
119
- * Create new file
120
- * @param file
121
- * @param user_id
122
- * @param min_role_read
123
- * @returns {Promise<File>}
124
- */
125
- static async from_req_files(file, user_id, min_role_read = 1) {
126
- if (Array.isArray(file)) {
127
- return await asyncMap(file, (f) =>
128
- File.from_req_files(f, user_id, min_role_read)
129
- );
130
- } else {
131
- // get path to file
132
- const newPath = File.get_new_path();
133
- // set mime type
134
- const [mime_super, mime_sub] = file.mimetype.split("/");
135
- // move file in file system to newPath
136
- await file.mv(newPath);
137
- // create file
138
- return await File.create({
139
- filename: file.name,
140
- location: newPath,
141
- uploaded_at: new Date(),
142
- size_kb: Math.round(file.size / 1024),
143
- user_id,
144
- mime_super,
145
- mime_sub,
146
- min_role_read,
147
- });
148
- }
149
- }
150
-
151
- /**
152
- * Delete file
153
- * @returns {Promise<{error}>}
154
- */
155
- async delete() {
156
- try {
157
- // delete file from database
158
- await db.deleteWhere("_sc_files", { id: this.id });
159
- // delete name and possible file from file system
160
- await fs.unlink(this.location);
161
- // reload file list cache
162
- await require("../db/state").getState().refresh_files();
163
- } catch (e) {
164
- return { error: e.message };
165
- }
166
- }
167
-
168
- /**
169
- * MIME type of the file
170
- * @type {string}
171
- */
172
- get mimetype() {
173
- return `${this.mime_super}/${this.mime_sub}`;
174
- }
175
-
176
- /**
177
- * Create file
178
- * @param f
179
- * @returns {Promise<File>}
180
- */
181
- static async create(f) {
182
- const file = new File(f);
183
- const { id, ...rest } = file;
184
- // insert file descriptor row to database
185
- file.id = await db.insert("_sc_files", rest);
186
- // refresh file list cache
187
- await require("../db/state").getState().refresh_files();
188
-
189
- return file;
190
- }
191
- }
192
-
193
- File.contract = {
194
- variables: {
195
- filename: is.str,
196
- location: is.str,
197
- mime_super: is.str,
198
- mime_sub: is.str,
199
- uploaded_at: is.class("Date"),
200
- size_kb: is.posint,
201
- id: is.maybe(is.posint),
202
- user_id: is.maybe(is.posint),
203
- min_role_read: is.posint,
204
- // tdb add checksum
205
- },
206
- methods: {
207
- delete: is.fun(
208
- [],
209
- is.promise(is.or(is.obj({ error: is.str }), is.undefined))
210
- ),
211
- mimetype: is.getter(is.str),
212
- },
213
- static_methods: {
214
- find: is.fun(
215
- [is.maybe(is.obj()), is.maybe(is.obj())],
216
- is.promise(is.array(is.class("File")))
217
- ),
218
- findOne: is.fun(is.obj(), is.promise(is.maybe(is.class("File")))),
219
- create: is.fun(is.obj(), is.promise(is.class("File"))),
220
- from_req_files: is.fun(
221
- [
222
- is.or(is.obj(), is.array(is.obj())),
223
- is.maybe(is.posint),
224
- is.maybe(is.posint),
225
- ],
226
- is.promise(is.or(is.class("File"), is.array(is.class("File"))))
227
- ),
228
- update: is.fun([is.posint, is.obj()], is.promise(is.undefined)),
229
- ensure_file_store: is.fun([], is.promise(is.undefined)),
230
- get_new_path: is.fun(is.maybe(is.str), is.str),
231
- },
232
- };
233
-
234
- module.exports = File;
package/models/form.js DELETED
@@ -1,169 +0,0 @@
1
- /**
2
- * Role Database Access Layer
3
- * @category saltcorn-data
4
- * @module models/form
5
- * @subcategory models
6
- */
7
- const { contract, is } = require("contractis");
8
- const db = require("../db");
9
- const Field = require("./field");
10
-
11
- /**
12
- * Form Class
13
- * @category saltcorn-data
14
- */
15
- class Form {
16
- /**
17
- * Constructor
18
- * @param o
19
- */
20
- constructor(o) {
21
- this.fields = o.fields.map((f) =>
22
- f.constructor.name === Object.name ? new Field(f) : f
23
- );
24
- this.errors = o.errors || {};
25
- this.values = o.values || {};
26
- this.action = o.action;
27
- this.layout = o.layout;
28
- this.id = o.id;
29
- this.labelCols = o.labelCols;
30
- this.collapsedSummary = o.collapsedSummary;
31
- this.isStateForm = !!o.isStateForm;
32
- this.formStyle = o.formStyle || "horiz";
33
- this.class = o.class;
34
- this.methodGET = !!o.methodGET;
35
- this.blurb = o.blurb;
36
- this.submitLabel = o.submitLabel;
37
- this.submitButtonClass = o.submitButtonClass;
38
- this.noSubmitButton = o.noSubmitButton;
39
- this.additionalButtons = o.additionalButtons;
40
- this.onChange = o.onChange;
41
- this.validator = o.validator;
42
- this.hasErrors = false;
43
- this.xhrSubmit = !!o.xhrSubmit;
44
- this.req = o.req;
45
- this.__ = o.__ || (o.req && o.req.__);
46
- if (o.validate) this.validate(o.validate);
47
- contract.class(this);
48
- }
49
-
50
- /**
51
- * @param {object} ks
52
- */
53
- hidden(...ks) {
54
- ks.forEach((k) => {
55
- !this.fields.map((f) => f.name).includes(k) &&
56
- this.fields.push(
57
- new Field({
58
- name: k,
59
- input_type: "hidden",
60
- })
61
- );
62
- });
63
- }
64
-
65
- /**
66
- * @param {boolean} [force_allow_none = false]
67
- */
68
- async fill_fkey_options(force_allow_none = false) {
69
- //console.log(this.values);
70
- for (const f of this.fields) {
71
- await f.fill_fkey_options(force_allow_none, undefined, this.values);
72
- }
73
- }
74
-
75
- /**
76
- * @returns {Promise<object>}
77
- */
78
- async generate() {
79
- var r = {};
80
-
81
- for (const f of this.fields) {
82
- if (f.input_type === "hidden") r[f.name] = this.values[f.name];
83
- else if (f.required || is.bool.generate()) {
84
- r[f.name] = await f.generate();
85
- }
86
- }
87
- return r;
88
- }
89
-
90
- /**
91
- * @type {string}
92
- */
93
- get errorSummary() {
94
- let strs = [];
95
- Object.entries(this.errors).forEach(([k, v]) => {
96
- strs.push(`${k}: ${v}`);
97
- });
98
- return strs.join("; ");
99
- }
100
-
101
- /**
102
- * @param {*} v
103
- * @returns {object}
104
- */
105
- validate(v) {
106
- this.hasErrors = false;
107
- this.errors = {};
108
- this.fields.forEach((f) => {
109
- if (f.disabled || f.calculated) return;
110
- if (f.fieldview && f.type && f.type.fieldviews) {
111
- const fv = f.type.fieldviews[f.fieldview];
112
- if (fv && !fv.isEdit) return;
113
- }
114
- const valres = f.validate(v);
115
- if (valres.error) {
116
- this.errors[f.name] = valres.error;
117
- this.values[f.name] = v[f.name];
118
- this.hasErrors = true;
119
- } else {
120
- if (f.parent_field) {
121
- if (!this.values[f.parent_field]) this.values[f.parent_field] = {};
122
- this.values[f.parent_field][f.name] = valres.success;
123
- } else this.values[f.name] = valres.success;
124
- }
125
- });
126
-
127
- if (Object.keys(this.errors).length > 0) {
128
- return { errors: this.errors };
129
- } else {
130
- if (this.validator) {
131
- const fvalres = this.validator(this.values);
132
- if (typeof fvalres === "string") {
133
- this.hasErrors = true;
134
- this.errors._form = fvalres;
135
- return { errors: this.errors };
136
- }
137
- }
138
- return { success: this.values };
139
- }
140
- }
141
- }
142
-
143
- Form.contract = {
144
- variables: {
145
- fields: is.array(is.or(is.class("Field"), is.class("FieldRepeat"))),
146
- values: is.obj(),
147
- errors: is.obj(),
148
- action: is.maybe(is.str),
149
- labelCols: is.maybe(is.posint),
150
- hasErrors: is.bool,
151
- submitLabel: is.maybe(is.str),
152
- blurb: is.maybe(is.or(is.str, is.array(is.str))),
153
- class: is.maybe(is.str),
154
- isStateForm: is.bool,
155
- formStyle: is.str,
156
- methodGET: is.bool,
157
- },
158
- methods: {
159
- validate: is.fun(
160
- is.obj(),
161
- is.or(is.obj({ errors: is.obj() }), is.obj({ success: is.obj() }))
162
- ),
163
- generate: is.fun([], is.promise(is.obj())),
164
- fill_fkey_options: is.fun(is.maybe(is.bool), is.promise()),
165
- hidden: is.fun(is.any, is.eq(undefined)),
166
- },
167
- };
168
-
169
- module.exports = Form;
package/models/layout.js DELETED
@@ -1,146 +0,0 @@
1
- /**
2
- * @category saltcorn-data
3
- * @module models/layout
4
- * @subcategory models
5
- */
6
- const { getState } = require("../db/state");
7
-
8
- /**
9
- * @param {object} layout
10
- * @param {object[]} visitors
11
- * @returns {void}
12
- */
13
- const traverseSync = (layout, visitors) => {
14
- const go = (segment) => {
15
- if (!segment) return;
16
- if (visitors[segment.type]) {
17
- visitors[segment.type](segment);
18
- }
19
- if (Array.isArray(segment)) {
20
- for (const seg of segment) go(seg);
21
- return;
22
- }
23
- if (segment.contents) {
24
- if (typeof contents !== "string") go(segment.contents);
25
- return;
26
- }
27
- if (segment.above) {
28
- for (const seg of segment.above) go(seg);
29
- return;
30
- }
31
- if (segment.besides) {
32
- for (const seg of segment.besides) go(seg);
33
- return;
34
- }
35
- };
36
- go(layout);
37
- };
38
-
39
- /**
40
- * @param {object} layout
41
- * @param {object[]} visitors
42
- * @returns {Promise<void>}
43
- */
44
- const traverse = async (layout, visitors) => {
45
- const go = async (segment) => {
46
- if (!segment) return;
47
- if (visitors[segment.type]) {
48
- await visitors[segment.type](segment);
49
- return;
50
- }
51
- if (Array.isArray(segment)) {
52
- for (const seg of segment) await go(seg);
53
- return;
54
- }
55
- if (segment.contents) {
56
- if (typeof contents !== "string") await go(segment.contents);
57
- return;
58
- }
59
- if (segment.above) {
60
- for (const seg of segment.above) await go(seg);
61
- return;
62
- }
63
- if (segment.besides) {
64
- for (const seg of segment.besides) await go(seg);
65
- return;
66
- }
67
- };
68
- await go(layout);
69
- };
70
-
71
- /**
72
- * @param {object} layout
73
- * @param {*} f
74
- * @returns {void}
75
- */
76
- const eachView = (layout, f) => traverse(layout, { view: f });
77
-
78
- /**
79
- * @param {object} layout
80
- * @returns {Promise<object[]>}
81
- */
82
- const getViews = async (layout) => {
83
- const views = [];
84
- await eachView(layout, (segment) => {
85
- views.push(segment);
86
- });
87
- return views;
88
- };
89
-
90
- /**
91
- * @param {object} layout
92
- * @returns {string[]}
93
- */
94
- const getStringsForI18n = (layout) => {
95
- const strings = [];
96
- traverseSync(layout, {
97
- blank(s) {
98
- if (typeof s === "string") strings.push(s);
99
- else if (s.contents) strings.push(s.contents);
100
- },
101
- link({ text }) {
102
- strings.push(text);
103
- },
104
- card({ title }) {
105
- strings.push(title);
106
- },
107
- tabs({ titles }) {
108
- strings.push(...titles);
109
- },
110
- });
111
- return strings;
112
- };
113
-
114
- /**
115
- * @param {object} layout
116
- * @param {object} locale
117
- */
118
- const translateLayout = (layout, locale) => {
119
- const appState = getState()
120
- const __ = (s) => appState.i18n.__({ phrase: s, locale }) || s;
121
-
122
- traverseSync(layout, {
123
- blank(s) {
124
- s.contents = __(s.contents);
125
- },
126
- link(s) {
127
- s.text = __(s.text);
128
- },
129
- card(s) {
130
- s.title = __(s.title);
131
- },
132
- tabs(s) {
133
- s.titles = s.titles.map((t) => __(t));
134
- },
135
- });
136
- };
137
- //getViews: is.fun([], is.promise(is.array(is.obj()))),
138
- //eachView: is.fun(is.fun(is.obj(), is.any), is.promise(is.undefined)),
139
- module.exports = {
140
- eachView,
141
- getViews,
142
- traverse,
143
- traverseSync,
144
- getStringsForI18n,
145
- translateLayout,
146
- };