@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
@@ -1,672 +0,0 @@
1
- /**
2
- * @category saltcorn-data
3
- * @module base-plugin/viewtemplates/edit
4
- * @subcategory base-plugin
5
- */
6
- const Field = require("../../models/field");
7
- const File = require("../../models/file");
8
- const Table = require("../../models/table");
9
- const User = require("../../models/user");
10
- const Form = require("../../models/form");
11
- const View = require("../../models/view");
12
- const Workflow = require("../../models/workflow");
13
- const { getState } = require("../../db/state");
14
- const { text, text_attr } = require("@saltcorn/markup/tags");
15
- const { renderForm } = require("@saltcorn/markup");
16
- const FieldRepeat = require("../../models/fieldrepeat");
17
- const { get_expression_function } = require("../../models/expression");
18
- const { InvalidConfiguration } = require("../../utils");
19
- const Library = require("../../models/library");
20
-
21
- const {
22
- initial_config_all_fields,
23
- calcfldViewOptions,
24
- calcfldViewConfig,
25
- get_parent_views,
26
- get_link_view_opts,
27
- picked_fields_to_query,
28
- stateFieldsToWhere,
29
- stateFieldsToQuery,
30
- strictParseInt,
31
- } = require("../../plugin-helper");
32
- const {
33
- splitUniques,
34
- getForm,
35
- fill_presets,
36
- parse_view_select,
37
- get_view_link_query,
38
- } = require("./viewable_fields");
39
- const {
40
- traverse,
41
- getStringsForI18n,
42
- translateLayout,
43
- } = require("../../models/layout");
44
- const { asyncMap } = require("../../utils");
45
-
46
- /**
47
- * @param {object} req
48
- * @returns {Workflow}
49
- */
50
- const configuration_workflow = (req) =>
51
- new Workflow({
52
- steps: [
53
- {
54
- name: req.__("Layout"),
55
- builder: async (context) => {
56
- const table = await Table.findOne({ id: context.table_id });
57
- const fields = (await table.getFields()).filter(
58
- (f) => !f.primary_key
59
- );
60
-
61
- const { field_view_options, handlesTextStyle } = calcfldViewOptions(
62
- fields,
63
- "edit"
64
- );
65
- const fieldViewConfigForms = await calcfldViewConfig(fields, true);
66
-
67
- const roles = await User.get_roles();
68
- const images = await File.find({ mime_super: "image" });
69
-
70
- const actions = ["Save", "Delete"];
71
- const actionConfigForms = {
72
- Delete: [
73
- {
74
- name: "after_delete_url",
75
- label: req.__("URL after delete"),
76
- type: "String",
77
- },
78
- ],
79
- };
80
- const views = await get_link_view_opts(table, context.viewname);
81
- if (table.name === "users") {
82
- actions.push("Login");
83
- actions.push("Sign up");
84
- Object.entries(getState().auth_methods).forEach(([k, v]) => {
85
- actions.push(`Login with ${k}`);
86
- });
87
- fields.push({
88
- name: "password",
89
- label: req.__("Password"),
90
- type: "String",
91
- });
92
- fields.push({
93
- name: "passwordRepeat",
94
- label: req.__("Password Repeat"),
95
- type: "String",
96
- });
97
- fields.push({
98
- name: "remember",
99
- label: req.__("Remember me"),
100
- type: "Bool",
101
- });
102
-
103
- field_view_options.password = ["password"];
104
- field_view_options.passwordRepeat = ["password"];
105
- field_view_options.remember = ["edit"];
106
- }
107
- const library = (await Library.find({})).filter((l) =>
108
- l.suitableFor("edit")
109
- );
110
- const myviewrow = await View.findOne({ name: context.viewname });
111
-
112
- return {
113
- tableName: table.name,
114
- fields,
115
- field_view_options,
116
- handlesTextStyle,
117
- roles,
118
- actions,
119
- fieldViewConfigForms,
120
- actionConfigForms,
121
- images,
122
- min_role: (myviewrow || {}).min_role,
123
- library,
124
- views,
125
- mode: "edit",
126
- };
127
- },
128
- },
129
- {
130
- name: req.__("Fixed fields"),
131
- contextField: "fixed",
132
- onlyWhen: async (context) => {
133
- const table = await Table.findOne({ id: context.table_id });
134
- const fields = await table.getFields();
135
- const in_form_fields = context.columns.map((f) => f.field_name);
136
- return fields.some(
137
- (f) =>
138
- !in_form_fields.includes(f.name) &&
139
- !f.calculated &&
140
- !f.primary_key
141
- );
142
- },
143
- form: async (context) => {
144
- const table = await Table.findOne({ id: context.table_id });
145
- const fields = await table.getFields();
146
- const in_form_fields = context.columns.map((f) => f.field_name);
147
- const omitted_fields = fields.filter(
148
- (f) =>
149
- !in_form_fields.includes(f.name) &&
150
- !f.calculated &&
151
- !f.primary_key
152
- );
153
- var formFields = [];
154
- omitted_fields.forEach((f) => {
155
- f.required = false;
156
-
157
- formFields.push(f);
158
- if (f.presets) {
159
- formFields.push(
160
- new Field({
161
- name: "preset_" + f.name,
162
- label: req.__("Preset %s", f.label),
163
- type: "String",
164
- attributes: { options: Object.keys(f.presets) },
165
- })
166
- );
167
- }
168
- });
169
- const form = new Form({
170
- blurb: req.__(
171
- "These fields were missing, you can give values here. The values you enter here can be overwritten by information coming from other views, for instance if the form is triggered from a list."
172
- ),
173
- fields: formFields,
174
- });
175
- await form.fill_fkey_options();
176
- return form;
177
- },
178
- },
179
- {
180
- name: req.__("Edit options"),
181
- onlyWhen: async (context) => {
182
- const done_views = await View.find_all_views_where(
183
- ({ state_fields, viewrow }) =>
184
- viewrow.name !== context.viewname &&
185
- (viewrow.table_id === context.table_id ||
186
- state_fields.every((sf) => !sf.required))
187
- );
188
- return done_views.length > 0;
189
- },
190
- form: async (context) => {
191
- const own_views = await View.find_all_views_where(
192
- ({ state_fields, viewrow }) =>
193
- viewrow.name !== context.viewname &&
194
- (viewrow.table_id === context.table_id ||
195
- state_fields.every((sf) => !sf.required))
196
- );
197
- const table = await Table.findOne({ id: context.table_id });
198
- const parent_views = await get_parent_views(table, context.viewname);
199
-
200
- const done_view_opts = own_views.map((v) => v.select_option);
201
- parent_views.forEach(({ relation, related_table, views }) =>
202
- views.forEach((v) => {
203
- done_view_opts.push(`${v.name}.${relation.name}`);
204
- })
205
- );
206
- return new Form({
207
- blurb: req.__(
208
- "The view you choose here can be ignored depending on the context of the form, for instance if it appears in a pop-up the redirect will not take place."
209
- ),
210
- fields: [
211
- {
212
- name: "view_when_done",
213
- label: req.__("Default view when done"),
214
- sublabel: req.__(
215
- "This is the view to which the user will be sent when the form is submitted, unless a formula below is true."
216
- ),
217
- type: "String",
218
- required: true,
219
- attributes: {
220
- options: done_view_opts,
221
- },
222
- },
223
- {
224
- label: req.__(
225
- "Alternative destinations if formula evaluates to true"
226
- ),
227
- sublabel: req.__(
228
- "You can send the user to an different view depending on the day the user has submitted. Ignore this option if you always want to send the user to the same destination"
229
- ),
230
- input_type: "section_header",
231
- },
232
- new FieldRepeat({
233
- name: "formula_destinations",
234
- fields: [
235
- { type: "String", name: "expression", label: "Formula" },
236
- {
237
- name: "view",
238
- label: req.__("View"),
239
- type: "String",
240
- required: true,
241
- attributes: {
242
- options: done_view_opts,
243
- },
244
- },
245
- ],
246
- }),
247
- ],
248
- });
249
- },
250
- },
251
- ],
252
- });
253
-
254
- /**
255
- * @param {*} table_id
256
- * @param {*} viewname
257
- * @param {object} opts
258
- * @param {*} opts.columns
259
- * @returns {Promise<object[]>}
260
- */
261
- const get_state_fields = async (table_id, viewname, { columns }) => [
262
- {
263
- name: "id",
264
- type: "Integer",
265
- primary_key: true,
266
- },
267
- ];
268
-
269
- /**
270
- * @param {Form} form
271
- * @param {string} locale
272
- */
273
- const setDateLocales = (form, locale) => {
274
- form.fields.forEach((f) => {
275
- if (f.type && f.type.name === "Date") {
276
- f.attributes.locale = locale;
277
- }
278
- });
279
- };
280
-
281
- /** @type {function} */
282
- const initial_config = initial_config_all_fields(true);
283
-
284
- /**
285
- * @param {number} table_id
286
- * @param {string} viewname
287
- * @param {object} optsOne
288
- * @param {*} optsOne.columns
289
- * @param {*} optsOne.layout
290
- * @param {string} state
291
- * @param {object} optsTwo
292
- * @param {object} optsTwo.req
293
- * @param {object} optsTwo.res
294
- * @returns {Promise<Form>}
295
- */
296
- const run = async (
297
- table_id,
298
- viewname,
299
- { columns, layout },
300
- state,
301
- { res, req }
302
- ) => {
303
- const table = await Table.findOne({ id: table_id });
304
- const fields = await table.getFields();
305
- const { uniques, nonUniques } = splitUniques(fields, state);
306
- let row = null;
307
- if (Object.keys(uniques).length > 0) {
308
- row = await table.getRow(uniques);
309
- }
310
- return await render({
311
- table,
312
- fields,
313
- viewname,
314
- columns,
315
- layout,
316
- row,
317
- req,
318
- res,
319
- state,
320
- });
321
- };
322
-
323
- /**
324
- * @param {number} table_id
325
- * @param {string} viewname
326
- * @param {object} opts
327
- * @param {*} opts.columns
328
- * @param {*} opts.layout
329
- * @param {State} state
330
- * @param {object} extra
331
- * @returns {Promise<Form[]>}
332
- */
333
- const runMany = async (
334
- table_id,
335
- viewname,
336
- { columns, layout },
337
- state,
338
- extra
339
- ) => {
340
- const table = await Table.findOne({ id: table_id });
341
- const fields = await table.getFields();
342
- const { joinFields, aggregations } = picked_fields_to_query(columns, fields);
343
- const qstate = await stateFieldsToWhere({ fields, state });
344
- const q = await stateFieldsToQuery({ state, fields });
345
-
346
- const rows = await table.getJoinedRows({
347
- where: qstate,
348
- joinFields,
349
- aggregations,
350
- ...(extra && extra.limit && { limit: extra.limit }),
351
- ...(extra && extra.offset && { offset: extra.offset }),
352
- ...(extra && extra.orderBy && { orderBy: extra.orderBy }),
353
- ...(extra && extra.orderDesc && { orderDesc: extra.orderDesc }),
354
- ...q,
355
- });
356
- return await asyncMap(rows, async (row) => {
357
- const html = await render({
358
- table,
359
- fields,
360
- viewname,
361
- columns,
362
- layout,
363
- row,
364
- req: extra.req,
365
- res: extra.res,
366
- state,
367
- });
368
- return { html, row };
369
- });
370
- };
371
-
372
- /**
373
- * @param {object} opts
374
- * @param {Form} opts.form
375
- * @param {Table} opts.table
376
- * @param {object} opts.req
377
- * @param {object} opts.row
378
- * @param {object} opts.res
379
- * @throws {InvalidConfiguration}
380
- * @returns {Promise<void>}
381
- */
382
- const transformForm = async ({ form, table, req, row, res }) => {
383
- await traverse(form.layout, {
384
- action(segment) {
385
- if (segment.action_name === "Delete") {
386
- if (form.values && form.values.id) {
387
- segment.action_url = `/delete/${table.name}/${form.values.id}`;
388
- } else {
389
- segment.type = "blank";
390
- segment.contents = "";
391
- }
392
- }
393
- },
394
- async view(segment) {
395
- if (!row) {
396
- segment.type = "blank";
397
- segment.contents = "";
398
- return;
399
- }
400
- const view_select = parse_view_select(segment.view);
401
- const view = await View.findOne({ name: view_select.viewname });
402
- if (!view)
403
- throw new InvalidConfiguration(
404
- `Edit view incorrectly configured: cannot find embedded view ${view_select.viewname}`
405
- );
406
- let state;
407
- switch (view_select.type) {
408
- case "Own":
409
- state = { id: row.id };
410
- break;
411
- case "Independent":
412
- state = {};
413
- break;
414
- case "ChildList":
415
- case "OneToOneShow":
416
- state = { [view_select.field_name]: row.id };
417
- break;
418
- case "ParentShow":
419
- state = { id: row[view_select.field_name] };
420
- break;
421
- }
422
- segment.contents = await view.run(state, { req, res });
423
- },
424
- });
425
- translateLayout(form.layout, req.getLocale());
426
- if (req.xhr) form.xhrSubmit = true;
427
- setDateLocales(form, req.getLocale());
428
- };
429
-
430
- /**
431
- * @param {object} opts
432
- * @param {Table} opts.table
433
- * @param {Fields[]} opts.fields
434
- * @param {string} opts.viewname
435
- * @param {object[]} opts.columns
436
- * @param {Layout} opts.layout
437
- * @param {object} opts.row
438
- * @param {object} opts.req
439
- * @param {object} opts.state
440
- * @param {object} opts.res
441
- * @returns {Promise<Form>}
442
- */
443
- const render = async ({
444
- table,
445
- fields,
446
- viewname,
447
- columns,
448
- layout,
449
- row,
450
- req,
451
- state,
452
- res,
453
- }) => {
454
- const form = await getForm(table, viewname, columns, layout, state.id, req);
455
-
456
- if (row) {
457
- form.values = row;
458
- const file_fields = form.fields.filter((f) => f.type === "File");
459
- for (const field of file_fields) {
460
- if (row[field.name]) {
461
- const file = await File.findOne({ id: row[field.name] });
462
- form.values[field.name] = file.filename;
463
- }
464
- }
465
- form.hidden(table.pk_name);
466
- }
467
-
468
- const { nonUniques } = splitUniques(fields, state);
469
- Object.entries(nonUniques).forEach(([k, v]) => {
470
- const field = form.fields.find((f) => f.name === k);
471
- if (field && ((field.type && field.type.read) || field.is_fkey)) {
472
- form.values[k] = field.type.read ? field.type.read(v) : v;
473
- } else {
474
- const tbl_field = fields.find((f) => f.name === k);
475
- if (tbl_field && !field) {
476
- form.fields.push(new Field({ name: k, input_type: "hidden" }));
477
- form.values[k] = tbl_field.type.read ? tbl_field.type.read(v) : v;
478
- }
479
- }
480
- });
481
- await form.fill_fkey_options();
482
-
483
- await transformForm({ form, table, req, row, res });
484
-
485
- return renderForm(form, req.csrfToken());
486
- };
487
-
488
- /**
489
- * @param {number} table_id
490
- * @param {string} viewname
491
- * @param {object} optsOne
492
- * @param {object[]} optsOne.columns
493
- * @param {Layout} optsOne.layout
494
- * @param {object} optsOne.fixed
495
- * @param {boolean} optsOne.view_when_done
496
- * @param {object[]} optsOne.formula_destinations
497
- * @param {object} state
498
- * @param {*} body
499
- * @param {object} optsTwo
500
- * @param {object} optsTwo.res
501
- * @param {object} optsTwo.req
502
- * @param {string} optsTwo.redirect
503
- * @returns {Promise<void>}
504
- */
505
- const runPost = async (
506
- table_id,
507
- viewname,
508
- { columns, layout, fixed, view_when_done, formula_destinations },
509
- state,
510
- body,
511
- { res, req, redirect }
512
- ) => {
513
- const table = await Table.findOne({ id: table_id });
514
- const fields = await table.getFields();
515
- const form = await getForm(table, viewname, columns, layout, body.id, req);
516
- Object.entries(body).forEach(([k, v]) => {
517
- const form_field = form.fields.find((f) => f.name === k);
518
- const tbl_field = fields.find((f) => f.name === k);
519
- if (tbl_field && !form_field) {
520
- form.fields.push(new Field({ name: k, input_type: "hidden" }));
521
- }
522
- });
523
- setDateLocales(form, req.getLocale());
524
- form.validate(body);
525
- if (form.hasErrors) {
526
- if (req.xhr) res.status(422);
527
- await form.fill_fkey_options();
528
- await transformForm({ form, table, req });
529
- res.sendWrap(viewname, renderForm(form, req.csrfToken()));
530
- } else {
531
- let row;
532
- const pk = fields.find((f) => f.primary_key);
533
- let id = pk.type.read(body[pk.name]);
534
- if (typeof id === "undefined") {
535
- const use_fixed = await fill_presets(table, req, fixed);
536
- row = { ...use_fixed, ...form.values };
537
- } else {
538
- row = form.values;
539
- }
540
- const file_fields = form.fields.filter((f) => f.type === "File");
541
- for (const field of file_fields) {
542
- if (req.files && req.files[field.name]) {
543
- const file = await File.from_req_files(
544
- req.files[field.name],
545
- req.user ? req.user.id : null,
546
- (field.attributes && +field.attributes.min_role_read) || 1
547
- );
548
- row[field.name] = file.id;
549
- } else {
550
- delete row[field.name];
551
- }
552
- }
553
- if (typeof id === "undefined") {
554
- const ins_res = await table.tryInsertRow(
555
- row,
556
- req.user ? +req.user.id : undefined
557
- );
558
- if (ins_res.success) {
559
- id = ins_res.success;
560
- row[pk.name] = id;
561
- } else {
562
- req.flash("error", text_attr(ins_res.error));
563
- res.sendWrap(viewname, renderForm(form, req.csrfToken()));
564
- return;
565
- }
566
- } else {
567
- const upd_res = await table.tryUpdateRow(
568
- row,
569
- id,
570
- req.user ? +req.user.id : undefined
571
- );
572
- if (upd_res.error) {
573
- req.flash("error", text_attr(upd_res.error));
574
- res.sendWrap(viewname, renderForm(form, req.csrfToken()));
575
- return;
576
- }
577
- }
578
- if (redirect) {
579
- res.redirect(redirect);
580
- return;
581
- }
582
- if (!view_when_done) {
583
- res.redirect(`/`);
584
- return;
585
- }
586
-
587
- let use_view_when_done = view_when_done;
588
- for (const { view, expression } of formula_destinations || []) {
589
- if (expression) {
590
- const f = get_expression_function(expression, fields);
591
- if (f(row)) {
592
- use_view_when_done = view;
593
- continue;
594
- }
595
- }
596
- }
597
- const [viewname_when_done, relation] = use_view_when_done.split(".");
598
- const nxview = await View.findOne({ name: viewname_when_done });
599
- //console.log()
600
- if (!nxview) {
601
- req.flash(
602
- "warning",
603
- `View "${use_view_when_done}" not found - change "View when done" in "${viewname}" view`
604
- );
605
- res.redirect(`/`);
606
- } else {
607
- const state_fields = await nxview.get_state_fields();
608
- if (
609
- (nxview.table_id === table_id || relation) &&
610
- state_fields.some((sf) => sf.name === pk.name)
611
- ) {
612
- const get_query = get_view_link_query(fields);
613
- const query = relation
614
- ? `?${pk.name}=${text(row[relation])}`
615
- : get_query(row);
616
- res.redirect(`/view/${text(viewname_when_done)}${query}`);
617
- } else res.redirect(`/view/${text(viewname_when_done)}`);
618
- }
619
- }
620
- };
621
-
622
- /**
623
- * @param {object} opts
624
- * @param {object} opts.body
625
- * @param {string} opts.table_id
626
- * @param {object} opts.req
627
- * @returns {Promise<boolean>}
628
- */
629
- const authorise_post = async ({ body, table_id, req }) => {
630
- const table = await Table.findOne({ id: table_id });
631
- const user_id = req.user ? req.user.id : null;
632
- if (table.ownership_field_id && user_id) {
633
- const field_name = await table.owner_fieldname();
634
- return field_name && `${body[field_name]}` === `${user_id}`;
635
- }
636
- if (table.ownership_formula && user_id) {
637
- return await table.is_owner(req.user, body);
638
- }
639
- if (table.name === "users" && `${body.id}` === `${user_id}`) return true;
640
- return false;
641
- };
642
- module.exports = {
643
- /** @type {string} */
644
- name: "Edit",
645
- /** @type {string} */
646
- description: "Form for creating a new row or editing existing rows",
647
- configuration_workflow,
648
- run,
649
- runMany,
650
- runPost,
651
- get_state_fields,
652
- initial_config,
653
- /** @type {boolean} */
654
- display_state_form: false,
655
- authorise_post,
656
- /**
657
- * @param {object} opts
658
- * @param {object} opts.query
659
- * @param {...*} opts.rest
660
- * @returns {Promise<boolean>}
661
- */
662
- authorise_get: async ({ query, ...rest }) =>
663
- authorise_post({ body: query, ...rest }),
664
- /**
665
- * @param {object} opts
666
- * @param {Layout} opts.layout
667
- * @returns {string[]}
668
- */
669
- getStringsForI18n({ layout }) {
670
- return getStringsForI18n(layout);
671
- },
672
- };