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

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 +608 -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 +177 -0
  286. package/dist/models/config.d.ts.map +1 -0
  287. package/dist/models/config.js +683 -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 +383 -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 +32 -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
package/models/view.js DELETED
@@ -1,622 +0,0 @@
1
- /**
2
- * View Data Access Layer
3
- * @category saltcorn-data
4
- * @module models/view
5
- * @subcategory models
6
- */
7
-
8
- const db = require("../db");
9
- const Form = require("../models/form");
10
- const { contract, is } = require("contractis");
11
- const { fieldlike, is_viewtemplate, is_tablely } = require("../contracts");
12
- const {
13
- removeEmptyStrings,
14
- numberToBool,
15
- stringToJSON,
16
- InvalidConfiguration,
17
- satisfies,
18
- structuredClone,
19
- } = require("../utils");
20
- const { remove_from_menu } = require("./config");
21
- const { div } = require("@saltcorn/markup/tags");
22
- const { renderForm } = require("@saltcorn/markup");
23
-
24
- /**
25
- * View Class
26
- * @category saltcorn-data
27
- */
28
- class View {
29
- /**
30
- * View constructor
31
- * @param {object} o
32
- */
33
- constructor(o) {
34
- this.name = o.name;
35
- this.id = o.id;
36
- this.viewtemplate = o.viewtemplate;
37
- this.exttable_name = o.exttable_name;
38
- this.description = o.description;
39
- if (o.table_id) this.table_id = o.table_id;
40
- if (o.table && !o.table_id) {
41
- this.table_id = o.table.id;
42
- }
43
- if (o.table_name) this.table_name = o.table_name;
44
- this.configuration = stringToJSON(o.configuration);
45
- this.min_role =
46
- !o.min_role && typeof o.is_public !== "undefined"
47
- ? o.is_public
48
- ? 10
49
- : 8
50
- : +o.min_role;
51
- const { getState } = require("../db/state");
52
- this.viewtemplateObj = getState().viewtemplates[this.viewtemplate];
53
- this.default_render_page = o.default_render_page;
54
- contract.class(this);
55
- }
56
-
57
- /**
58
- * @param {object} where
59
- * @returns {View}
60
- */
61
- static findOne(where) {
62
- const { getState } = require("../db/state");
63
- const v = getState().views.find(
64
- where.id
65
- ? (v) => v.id === +where.id
66
- : where.name
67
- ? (v) => v.name === where.name
68
- : satisfies(where)
69
- );
70
- return v
71
- ? new View({ ...v, configuration: structuredClone(v.configuration) })
72
- : v;
73
- }
74
-
75
- /**
76
- * @param where
77
- * @param selectopts
78
- * @returns {Promise<View[]>}
79
- */
80
- static async find(where, selectopts = { orderBy: "name", nocase: true }) {
81
- if (selectopts.cached) {
82
- const { getState } = require("../db/state");
83
- return getState().views.map((t) => new View(t));
84
- }
85
- const views = await db.select("_sc_views", where, selectopts);
86
-
87
- return views.map((v) => new View(v));
88
- }
89
-
90
- /**
91
- * @returns {Promise<object[]>}
92
- */
93
- async get_state_fields() {
94
- if (this.viewtemplateObj && this.viewtemplateObj.get_state_fields) {
95
- return await this.viewtemplateObj.get_state_fields(
96
- this.table_id,
97
- this.name,
98
- this.configuration
99
- );
100
- } else return [];
101
- }
102
-
103
- /**
104
- * Get menu label
105
- * @type {string|undefined}
106
- */
107
- get menu_label() {
108
- const { getState } = require("../db/state");
109
- const menu_items = getState().getConfig("menu_items", []);
110
- const item = menu_items.find((mi) => mi.viewname === this.name);
111
- return item ? item.label : undefined;
112
- }
113
-
114
- /**
115
- * @param table
116
- * @param pred
117
- * @returns {Promise<object[]>}
118
- */
119
- static async find_table_views_where(table, pred) {
120
- var link_view_opts = [];
121
- const link_views = await View.find(
122
- table.id
123
- ? {
124
- table_id: table.id,
125
- }
126
- : table.name
127
- ? { exttable_name: table.name }
128
- : typeof table === "string"
129
- ? { exttable_name: table }
130
- : { table_id: table },
131
- { orderBy: "name", nocase: true }
132
- );
133
-
134
- for (const viewrow of link_views) {
135
- // may fail if incomplete view
136
- const sfs = await viewrow.get_state_fields();
137
- if (
138
- pred({
139
- viewrow,
140
- viewtemplate: viewrow.viewtemplateObj,
141
- state_fields: sfs,
142
- })
143
- )
144
- link_view_opts.push(viewrow);
145
- }
146
- return link_view_opts;
147
- }
148
-
149
- /**
150
- * @type {object}
151
- */
152
- get select_option() {
153
- return {
154
- name: this.name,
155
- label: `${this.name} [${this.viewtemplate}${
156
- this.table
157
- ? ` ${this.table.name}`
158
- : this.table_name
159
- ? ` ${this.table_name}`
160
- : ""
161
- }]`,
162
- };
163
- }
164
-
165
- /**
166
- * @param {function} pred
167
- * @returns {Promise<object>}
168
- */
169
- static async find_all_views_where(pred) {
170
- var link_view_opts = [];
171
- const link_views = await View.find({}, { orderBy: "name", nocase: true });
172
-
173
- for (const viewrow of link_views) {
174
- // may fail if incomplete view
175
- const sfs = await viewrow.get_state_fields();
176
- if (
177
- pred({
178
- viewrow,
179
- viewtemplate: viewrow.viewtemplateObj,
180
- state_fields: sfs,
181
- })
182
- )
183
- link_view_opts.push(viewrow);
184
- }
185
- return link_view_opts;
186
- }
187
-
188
- /**
189
- * @param {Table|object} table
190
- * @returns {Promise<View[]>}
191
- */
192
- static async find_possible_links_to_table(table) {
193
- return View.find_table_views_where(table, ({ state_fields }) =>
194
- state_fields.some((sf) => sf.name === "id" || sf.primary_key)
195
- );
196
- }
197
-
198
- /**
199
- * Create view in database
200
- * @param v
201
- * @returns {Promise<View>}
202
- */
203
- // todo there hard code about roles and flag is_public
204
- static async create(v) {
205
- // is_public flag processing
206
- if (!v.min_role && typeof v.is_public !== "undefined") {
207
- v.min_role = v.is_public ? 10 : 8;
208
- delete v.is_public;
209
- }
210
- // insert view defintion into _sc_views
211
- const id = await db.insert("_sc_views", v);
212
- // refresh views list cache
213
- await require("../db/state").getState().refresh_views();
214
- return new View({ id, ...v });
215
- }
216
-
217
- /**
218
- * Clone View
219
- * @returns {Promise<View>}
220
- */
221
- async clone() {
222
- const basename = this.name + " copy";
223
- let newname;
224
- // todo there is hard code linmitation about 100 copies of veiew
225
- for (let i = 0; i < 100; i++) {
226
- newname = i ? `${basename} (${i})` : basename;
227
- const existing = await View.findOne({ name: newname });
228
- if (!existing) break;
229
- }
230
- const createObj = {
231
- ...this,
232
- name: newname,
233
- };
234
- delete createObj.viewtemplateObj;
235
- delete createObj.id;
236
- return await View.create(createObj);
237
- }
238
-
239
- /**
240
- * Delete current view from db
241
- * @returns {Promise<void>}
242
- */
243
- async delete() {
244
- if (this.viewtemplateObj && this.viewtemplateObj.on_delete)
245
- await this.viewtemplateObj.on_delete(
246
- this.table_id,
247
- this.name,
248
- this.configuration
249
- );
250
- // delete view from _sc_view
251
- await db.deleteWhere("_sc_views", { id: this.id });
252
- // remove view from menu
253
- await remove_from_menu({ name: this.name, type: "View" });
254
- // fresh view list cache
255
- await require("../db/state").getState().refresh_views();
256
- }
257
-
258
- /**
259
- * Delete list of views
260
- * @param where - condition
261
- * @returns {Promise<void>}
262
- */
263
- static async delete(where) {
264
- const vs = await View.find(where);
265
- for (const v of vs) await v.delete();
266
- }
267
-
268
- /**
269
- * Update View description
270
- * @param v - view name
271
- * @param id - id
272
- * @returns {Promise<void>}
273
- */
274
- static async update(v, id) {
275
- // update view description
276
- await db.update("_sc_views", v, id);
277
- // fresh view list cache
278
- await require("../db/state").getState().refresh_views();
279
- }
280
-
281
- /**
282
- * @param {*} arg
283
- * @returns {Promise<object>}
284
- */
285
- async authorise_post(arg) {
286
- if (!this.viewtemplateObj.authorise_post) return false;
287
- return await this.viewtemplateObj.authorise_post(arg);
288
- }
289
-
290
- /**
291
- * @param {*} arg
292
- * @returns {Promise<object>}
293
- */
294
- async authorise_get(arg) {
295
- if (!this.viewtemplateObj.authorise_get) return false;
296
- return await this.viewtemplateObj.authorise_get(arg);
297
- }
298
-
299
- /**
300
- * @returns {string}
301
- */
302
- getStringsForI18n() {
303
- if (!this.viewtemplateObj || !this.viewtemplateObj.getStringsForI18n)
304
- return [];
305
- return this.viewtemplateObj.getStringsForI18n(this.configuration);
306
- }
307
-
308
- /**
309
- * Run (Execute) View
310
- * @param query
311
- * @param extraArgs
312
- * @returns {Promise<*>}
313
- */
314
- async run(query, extraArgs) {
315
- this.check_viewtemplate();
316
- try {
317
- return await this.viewtemplateObj.run(
318
- this.exttable_name || this.table_id,
319
- this.name,
320
- this.configuration,
321
- removeEmptyStrings(query),
322
- extraArgs
323
- );
324
- } catch (error) {
325
- error.message = `In ${this.name} view (${this.viewtemplate} viewtemplate):\n${error.message}`;
326
- throw error;
327
- }
328
- }
329
-
330
- /**
331
- * @throws {InvalidConfiguration}
332
- */
333
- check_viewtemplate() {
334
- if (!this.viewtemplateObj)
335
- throw new InvalidConfiguration(
336
- `Cannot find viewtemplate ${this.viewtemplate} in view ${this.name}`
337
- );
338
- }
339
-
340
- /**
341
- * @param {*} query
342
- * @param {*} req
343
- * @param {*} res
344
- * @returns {Promise<object>}
345
- */
346
- async run_possibly_on_page(query, req, res) {
347
- const view = this;
348
- this.check_viewtemplate();
349
- if (view.default_render_page && (!req.xhr || req.headers.pjaxpageload)) {
350
- const Page = require("../models/page");
351
- const db_page = await Page.findOne({ name: view.default_render_page });
352
- if (db_page) {
353
- const contents = await db_page.run(query, { res, req });
354
- return contents;
355
- }
356
- }
357
- const state = view.combine_state_and_default_state(query);
358
- const resp = await view.run(state, { res, req });
359
- const state_form = await view.get_state_form(state, req);
360
- const contents = div(
361
- state_form ? renderForm(state_form, req.csrfToken()) : "",
362
- resp
363
- );
364
- return contents;
365
- }
366
-
367
- /**
368
- * @param {*} query
369
- * @param {*} extraArgs
370
- * @throws {InvalidConfiguration}
371
- * @returns {Promise<object>}
372
- */
373
- async runMany(query, extraArgs) {
374
- this.check_viewtemplate();
375
- try {
376
- if (this.viewtemplateObj.runMany)
377
- return await this.viewtemplateObj.runMany(
378
- this.table_id,
379
- this.name,
380
- this.configuration,
381
- query,
382
- extraArgs
383
- );
384
- if (this.viewtemplateObj.renderRows) {
385
- const Table = require("./table");
386
- const { stateFieldsToWhere } = require("../plugin-helper");
387
-
388
- const tbl = await Table.findOne({ id: this.table_id });
389
- const fields = await tbl.getFields();
390
- const qstate = await stateFieldsToWhere({ fields, state: query });
391
- const rows = await tbl.getRows(qstate);
392
- const rendered = await this.viewtemplateObj.renderRows(
393
- tbl,
394
- this.name,
395
- this.configuration,
396
- extraArgs,
397
- rows
398
- );
399
-
400
- return rendered.map((html, ix) => ({ html, row: rows[ix] }));
401
- }
402
- } catch (error) {
403
- error.message = `In ${this.name} view (${this.viewtemplate} viewtemplate):\n${error.message}`;
404
- throw error;
405
- }
406
- throw new InvalidConfiguration(
407
- `runMany on view ${this.name}: viewtemplate ${this.viewtemplate} does not have renderRows or runMany methods`
408
- );
409
- }
410
-
411
- /**
412
- * @param {*} query
413
- * @param {*} body
414
- * @param {*} extraArgs
415
- * @returns {Promise<object>}
416
- */
417
- async runPost(query, body, extraArgs) {
418
- this.check_viewtemplate();
419
- return await this.viewtemplateObj.runPost(
420
- this.table_id,
421
- this.name,
422
- this.configuration,
423
- removeEmptyStrings(query),
424
- removeEmptyStrings(body),
425
- extraArgs
426
- );
427
- }
428
-
429
- /**
430
- * @param {*} route
431
- * @param {*} body
432
- * @param {*} res
433
- * @param {*} extraArgs
434
- * @returns {Promise<void>}
435
- */
436
- async runRoute(route, body, res, extraArgs) {
437
- this.check_viewtemplate();
438
- const result = await this.viewtemplateObj.routes[route](
439
- this.table_id,
440
- this.name,
441
- this.configuration,
442
- body,
443
- extraArgs
444
- );
445
- if (result && result.json) res.json(result.json);
446
- else if (result && result.html) res.send(result.html);
447
- else res.json({ success: "ok" });
448
- }
449
-
450
- /**
451
- * @param {object} req_query
452
- * @returns {object}
453
- */
454
- combine_state_and_default_state(req_query) {
455
- var state = { ...req_query };
456
- this.check_viewtemplate();
457
- const defstate = this.viewtemplateObj.default_state_form
458
- ? this.viewtemplateObj.default_state_form(this.configuration)
459
- : {};
460
-
461
- Object.entries(defstate || {}).forEach(([k, v]) => {
462
- if (!state[k]) {
463
- state[k] = v;
464
- }
465
- });
466
- return state;
467
- }
468
-
469
- /**
470
- * @param {object} query
471
- * @param {object} req
472
- * @returns {Promise<Form|null>}
473
- */
474
- async get_state_form(query, req) {
475
- this.check_viewtemplate();
476
- const vt_display_state_form = this.viewtemplateObj.display_state_form;
477
- const display_state_form =
478
- typeof vt_display_state_form === "function"
479
- ? vt_display_state_form(this.configuration)
480
- : vt_display_state_form;
481
- if (display_state_form) {
482
- const fields = await this.get_state_fields();
483
-
484
- fields.forEach((f) => {
485
- f.required = false;
486
- if (f.label === "Anywhere" && f.name === "_fts")
487
- f.label = req.__(f.label);
488
- if (f.type && f.type.name === "Bool") f.fieldview = "tristate";
489
- if (f.type && f.type.read && typeof query[f.name] !== "undefined") {
490
- query[f.name] = f.type.read(query[f.name]);
491
- }
492
- });
493
- const form = new Form({
494
- methodGET: true,
495
- action: `/view/${encodeURIComponent(this.name)}`,
496
- fields,
497
- submitLabel: req.__("Apply"),
498
- isStateForm: true,
499
- __: req.__,
500
- values: removeEmptyStrings(query),
501
- });
502
- await form.fill_fkey_options(true);
503
- return form;
504
- } else return null;
505
- }
506
-
507
- /**
508
- * @param {object} req
509
- * @returns {Promise<object>}
510
- */
511
- async get_config_flow(req) {
512
- this.check_viewtemplate();
513
- const configFlow = this.viewtemplateObj.configuration_workflow(req);
514
- configFlow.action = `/viewedit/config/${encodeURIComponent(this.name)}`;
515
- const oldOnDone = configFlow.onDone || ((c) => c);
516
- configFlow.onDone = async (ctx) => {
517
- const { table_id, ...configuration } = await oldOnDone(ctx);
518
-
519
- await View.update({ configuration }, this.id);
520
- return {
521
- redirect: `/viewedit`,
522
- flash: ["success", `View ${this.name || ""} saved`],
523
- };
524
- };
525
- return configFlow;
526
- }
527
- }
528
-
529
- View.contract = {
530
- variables: {
531
- name: is.str,
532
- id: is.maybe(is.posint),
533
- table_id: is.maybe(is.posint),
534
- viewtemplate: is.str,
535
- min_role: is.posint,
536
- viewtemplateObj: is.maybe(is_viewtemplate),
537
- default_render_page: is.maybe(is.str),
538
- },
539
- methods: {
540
- get_state_fields: is.fun([], is.promise(is.array(fieldlike))),
541
- get_state_form: is.fun(
542
- [is.obj(), is.obj({ __: is.fun(is.str, is.str) })],
543
- is.promise(is.maybe(is.class("Form")))
544
- ),
545
- get_config_flow: is.fun(
546
- is.obj({ __: is.fun(is.str, is.str) }),
547
- is.promise(is.class("Workflow"))
548
- ),
549
- delete: is.fun([], is.promise(is.undefined)),
550
- menu_label: is.getter(is.maybe(is.str)),
551
- run: is.fun(
552
- [is.obj(), is.obj({ req: is.defined, res: is.defined })],
553
- is.promise(is.any)
554
- ),
555
- runPost: is.fun(
556
- [is.obj(), is.obj(), is.obj({ req: is.defined, res: is.defined })],
557
- is.promise(is.any)
558
- ),
559
- runRoute: is.fun(
560
- [
561
- is.str,
562
- is.obj(),
563
- is.obj(),
564
- is.obj({ req: is.defined, res: is.defined }),
565
- ],
566
- is.promise(is.any)
567
- ),
568
- runMany: is.fun(
569
- [is.obj(), is.obj({ req: is.defined, res: is.defined })],
570
- is.promise(is.array(is.obj({ html: is.defined, row: is.obj() })))
571
- ),
572
- combine_state_and_default_state: is.fun(is.obj(), is.obj()),
573
- },
574
- static_methods: {
575
- find: is.fun(
576
- [is.maybe(is.obj()), is.maybe(is.obj())],
577
- is.promise(is.array(is.class("View")))
578
- ),
579
- findOne: is.fun(is.obj(), is.maybe(is.class("View"))),
580
- create: is.fun(
581
- is.obj({
582
- name: is.str,
583
- table_id: is.maybe(is.posint),
584
- viewtemplate: is.str,
585
- }),
586
- is.promise(is.class("View"))
587
- ),
588
- update: is.fun([is.obj(), is.posint], is.promise(is.undefined)),
589
- delete: is.fun(is.obj(), is.promise(is.undefined)),
590
-
591
- find_possible_links_to_table: is.fun(
592
- is.or(is.posint, is_tablely, is.str),
593
- is.promise(is.array(is.class("View")))
594
- ),
595
- find_all_views_where: is.fun(
596
- is.fun(
597
- is.obj({
598
- viewrow: is.class("View"),
599
- viewtemplate: is.obj(),
600
- state_fields: is.array(fieldlike),
601
- }),
602
- is.bool
603
- ),
604
- is.promise(is.array(is.class("View")))
605
- ),
606
- find_table_views_where: is.fun(
607
- [
608
- is.or(is.posint, is_tablely, is.str),
609
- is.fun(
610
- is.obj({
611
- viewrow: is.class("View"),
612
- viewtemplate: is.obj(),
613
- state_fields: is.array(fieldlike),
614
- }),
615
- is.bool
616
- ),
617
- ],
618
- is.promise(is.array(is.class("View")))
619
- ),
620
- },
621
- };
622
- module.exports = View;