@saltcorn/data 0.6.2-beta.0 → 0.6.2-beta.4

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 +180 -0
  286. package/dist/models/config.d.ts.map +1 -0
  287. package/dist/models/config.js +758 -0
  288. package/dist/models/config.js.map +1 -0
  289. package/dist/models/crash.d.ts +74 -0
  290. package/dist/models/crash.d.ts.map +1 -0
  291. package/dist/models/crash.js +118 -0
  292. package/dist/models/crash.js.map +1 -0
  293. package/dist/models/discovery.d.ts +28 -0
  294. package/dist/models/discovery.d.ts.map +1 -0
  295. package/dist/models/discovery.js +163 -0
  296. package/dist/models/discovery.js.map +1 -0
  297. package/dist/models/email.d.ts +16 -0
  298. package/dist/models/email.d.ts.map +1 -0
  299. package/dist/models/email.js +90 -0
  300. package/dist/models/email.js.map +1 -0
  301. package/dist/models/eventlog.d.ts +77 -0
  302. package/dist/models/eventlog.d.ts.map +1 -0
  303. package/dist/models/eventlog.js +132 -0
  304. package/dist/models/eventlog.js.map +1 -0
  305. package/dist/models/expression.d.ts +54 -0
  306. package/dist/models/expression.d.ts.map +1 -0
  307. package/dist/models/expression.js +274 -0
  308. package/dist/models/expression.js.map +1 -0
  309. package/dist/models/field.d.ts +217 -0
  310. package/dist/models/field.d.ts.map +1 -0
  311. package/dist/models/field.js +619 -0
  312. package/dist/models/field.js.map +1 -0
  313. package/dist/models/fieldrepeat.d.ts +49 -0
  314. package/dist/models/fieldrepeat.d.ts.map +1 -0
  315. package/dist/models/fieldrepeat.js +88 -0
  316. package/dist/models/fieldrepeat.js.map +1 -0
  317. package/dist/models/file.d.ts +122 -0
  318. package/dist/models/file.d.ts.map +1 -0
  319. package/dist/models/file.js +224 -0
  320. package/dist/models/file.js.map +1 -0
  321. package/dist/models/form.d.ts +82 -0
  322. package/dist/models/form.d.ts.map +1 -0
  323. package/dist/models/form.js +163 -0
  324. package/dist/models/form.js.map +1 -0
  325. package/dist/models/index.d.ts +1 -0
  326. package/dist/models/index.d.ts.map +1 -0
  327. package/{models → dist/models}/index.js +42 -42
  328. package/dist/models/index.js.map +1 -0
  329. package/dist/models/layout.d.ts +34 -0
  330. package/dist/models/layout.d.ts.map +1 -0
  331. package/dist/models/layout.js +153 -0
  332. package/dist/models/layout.js.map +1 -0
  333. package/dist/models/library.d.ts +50 -0
  334. package/dist/models/library.d.ts.map +1 -0
  335. package/dist/models/library.js +129 -0
  336. package/dist/models/library.js.map +1 -0
  337. package/dist/models/pack.d.ts +89 -0
  338. package/dist/models/pack.d.ts.map +1 -0
  339. package/dist/models/pack.js +390 -0
  340. package/dist/models/pack.js.map +1 -0
  341. package/dist/models/page.d.ts +101 -0
  342. package/dist/models/page.d.ts.map +1 -0
  343. package/dist/models/page.js +223 -0
  344. package/dist/models/page.js.map +1 -0
  345. package/dist/models/plugin.d.ts +100 -0
  346. package/dist/models/plugin.d.ts.map +1 -0
  347. package/dist/models/plugin.js +204 -0
  348. package/dist/models/plugin.js.map +1 -0
  349. package/dist/models/random.d.ts +24 -0
  350. package/dist/models/random.d.ts.map +1 -0
  351. package/dist/models/random.js +186 -0
  352. package/dist/models/random.js.map +1 -0
  353. package/dist/models/role.d.ts +42 -0
  354. package/dist/models/role.d.ts.map +1 -0
  355. package/dist/models/role.js +64 -0
  356. package/dist/models/role.js.map +1 -0
  357. package/dist/models/scheduler.d.ts +18 -0
  358. package/dist/models/scheduler.d.ts.map +1 -0
  359. package/dist/models/scheduler.js +159 -0
  360. package/dist/models/scheduler.js.map +1 -0
  361. package/dist/models/table.d.ts +326 -0
  362. package/dist/models/table.d.ts.map +1 -0
  363. package/dist/models/table.js +1006 -0
  364. package/dist/models/table.js.map +1 -0
  365. package/dist/models/table_constraints.d.ts +69 -0
  366. package/dist/models/table_constraints.d.ts.map +1 -0
  367. package/dist/models/table_constraints.js +118 -0
  368. package/dist/models/table_constraints.js.map +1 -0
  369. package/dist/models/tenant.d.ts +55 -0
  370. package/dist/models/tenant.d.ts.map +1 -0
  371. package/{models → dist/models}/tenant.js +40 -63
  372. package/dist/models/tenant.js.map +1 -0
  373. package/dist/models/trigger.d.ts +133 -0
  374. package/dist/models/trigger.d.ts.map +1 -0
  375. package/dist/models/trigger.js +292 -0
  376. package/dist/models/trigger.js.map +1 -0
  377. package/dist/models/user.d.ts +235 -0
  378. package/dist/models/user.d.ts.map +1 -0
  379. package/dist/models/user.js +434 -0
  380. package/dist/models/user.js.map +1 -0
  381. package/dist/models/view.d.ts +204 -0
  382. package/dist/models/view.d.ts.map +1 -0
  383. package/dist/models/view.js +497 -0
  384. package/dist/models/view.js.map +1 -0
  385. package/dist/models/workflow.d.ts +48 -0
  386. package/dist/models/workflow.d.ts.map +1 -0
  387. package/dist/models/workflow.js +190 -0
  388. package/dist/models/workflow.js.map +1 -0
  389. package/dist/plugin-helper.d.ts +145 -0
  390. package/dist/plugin-helper.d.ts.map +1 -0
  391. package/dist/plugin-helper.js +1158 -0
  392. package/dist/plugin-helper.js.map +1 -0
  393. package/dist/plugin-testing.d.ts +3 -0
  394. package/dist/plugin-testing.d.ts.map +1 -0
  395. package/dist/plugin-testing.js +120 -0
  396. package/dist/plugin-testing.js.map +1 -0
  397. package/dist/tests/actions.test.d.ts +2 -0
  398. package/dist/tests/actions.test.d.ts.map +1 -0
  399. package/dist/tests/actions.test.js +205 -0
  400. package/dist/tests/actions.test.js.map +1 -0
  401. package/dist/tests/auxtest.test.d.ts +2 -0
  402. package/dist/tests/auxtest.test.d.ts.map +1 -0
  403. package/dist/tests/auxtest.test.js +48 -0
  404. package/dist/tests/auxtest.test.js.map +1 -0
  405. package/dist/tests/backup.test.d.ts +2 -0
  406. package/dist/tests/backup.test.d.ts.map +1 -0
  407. package/dist/tests/backup.test.js +88 -0
  408. package/dist/tests/backup.test.js.map +1 -0
  409. package/dist/tests/calc.test.d.ts +2 -0
  410. package/dist/tests/calc.test.d.ts.map +1 -0
  411. package/dist/tests/calc.test.js +231 -0
  412. package/dist/tests/calc.test.js.map +1 -0
  413. package/dist/tests/config.test.d.ts +2 -0
  414. package/dist/tests/config.test.d.ts.map +1 -0
  415. package/dist/tests/config.test.js +83 -0
  416. package/dist/tests/config.test.js.map +1 -0
  417. package/dist/tests/discover.test.d.ts +2 -0
  418. package/dist/tests/discover.test.d.ts.map +1 -0
  419. package/dist/tests/discover.test.js +106 -0
  420. package/dist/tests/discover.test.js.map +1 -0
  421. package/dist/tests/exact_views.test.d.ts +2 -0
  422. package/dist/tests/exact_views.test.d.ts.map +1 -0
  423. package/dist/tests/exact_views.test.js +511 -0
  424. package/dist/tests/exact_views.test.js.map +1 -0
  425. package/dist/tests/field.test.d.ts +2 -0
  426. package/dist/tests/field.test.d.ts.map +1 -0
  427. package/dist/tests/field.test.js +237 -0
  428. package/dist/tests/field.test.js.map +1 -0
  429. package/dist/tests/form.test.d.ts +2 -0
  430. package/dist/tests/form.test.d.ts.map +1 -0
  431. package/dist/tests/form.test.js +191 -0
  432. package/dist/tests/form.test.js.map +1 -0
  433. package/dist/tests/mocks.d.ts +111 -0
  434. package/dist/tests/mocks.d.ts.map +1 -0
  435. package/dist/tests/mocks.js +165 -0
  436. package/dist/tests/mocks.js.map +1 -0
  437. package/dist/tests/models.test.d.ts +2 -0
  438. package/dist/tests/models.test.d.ts.map +1 -0
  439. package/dist/tests/models.test.js +210 -0
  440. package/dist/tests/models.test.js.map +1 -0
  441. package/dist/tests/pack.test.d.ts +2 -0
  442. package/dist/tests/pack.test.d.ts.map +1 -0
  443. package/dist/tests/pack.test.js +331 -0
  444. package/dist/tests/pack.test.js.map +1 -0
  445. package/dist/tests/plugin.test.d.ts +2 -0
  446. package/dist/tests/plugin.test.d.ts.map +1 -0
  447. package/dist/tests/plugin.test.js +53 -0
  448. package/dist/tests/plugin.test.js.map +1 -0
  449. package/dist/tests/random.test.d.ts +2 -0
  450. package/dist/tests/random.test.d.ts.map +1 -0
  451. package/dist/tests/random.test.js +138 -0
  452. package/dist/tests/random.test.js.map +1 -0
  453. package/dist/tests/table.test.d.ts +2 -0
  454. package/dist/tests/table.test.d.ts.map +1 -0
  455. package/dist/tests/table.test.js +1048 -0
  456. package/dist/tests/table.test.js.map +1 -0
  457. package/dist/tests/tenant.test.d.ts +2 -0
  458. package/dist/tests/tenant.test.d.ts.map +1 -0
  459. package/dist/tests/tenant.test.js +45 -0
  460. package/dist/tests/tenant.test.js.map +1 -0
  461. package/dist/tests/user.test.d.ts +2 -0
  462. package/dist/tests/user.test.d.ts.map +1 -0
  463. package/dist/tests/user.test.js +190 -0
  464. package/dist/tests/user.test.js.map +1 -0
  465. package/dist/tests/view.test.d.ts +2 -0
  466. package/dist/tests/view.test.d.ts.map +1 -0
  467. package/dist/tests/view.test.js +238 -0
  468. package/dist/tests/view.test.js.map +1 -0
  469. package/dist/tests/workflow.test.d.ts +2 -0
  470. package/dist/tests/workflow.test.d.ts.map +1 -0
  471. package/dist/tests/workflow.test.js +115 -0
  472. package/dist/tests/workflow.test.js.map +1 -0
  473. package/dist/tsconfig.ref.tsbuildinfo +1 -0
  474. package/dist/utils.d.ts +26 -0
  475. package/dist/utils.d.ts.map +1 -0
  476. package/dist/utils.js +124 -0
  477. package/dist/utils.js.map +1 -0
  478. package/package.json +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 -669
  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 -713
  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,652 +0,0 @@
1
- /**
2
- * @category saltcorn-data
3
- * @module base-plugin/viewtemplates/room
4
- * @subcategory base-plugin
5
- */
6
- const Field = require("../../models/field");
7
- const Table = require("../../models/table");
8
- const Form = require("../../models/form");
9
- const View = require("../../models/view");
10
- const Workflow = require("../../models/workflow");
11
- const {
12
- text,
13
- div,
14
- h4,
15
- hr,
16
- button,
17
- form,
18
- input,
19
- i,
20
- script,
21
- domReady,
22
- } = require("@saltcorn/markup/tags");
23
- const { pagination } = require("@saltcorn/markup/helpers");
24
- const { renderForm, tabs, link } = require("@saltcorn/markup");
25
- const { mkTable } = require("@saltcorn/markup");
26
- const {
27
- link_view,
28
- stateToQueryString,
29
- stateFieldsToWhere,
30
- stateFieldsToQuery,
31
- readState,
32
- } = require("../../plugin-helper");
33
- const { InvalidConfiguration } = require("../../utils");
34
- const { getState } = require("../../db/state");
35
- const db = require("../../db");
36
- const { getForm, fill_presets } = require("./viewable_fields");
37
-
38
- /**
39
- *
40
- * @param {object} req
41
- * @returns {Workflow}
42
- */
43
- const configuration_workflow = (req) =>
44
- new Workflow({
45
- steps: [
46
- {
47
- name: req.__("Views"),
48
- form: async (context) => {
49
- /*
50
- we need:
51
- - message string
52
- - message show view?
53
- - message sender field
54
- - participant field: key to user in table with fkey to this
55
- */
56
-
57
- const roomtable = await Table.findOne(context.table_id);
58
- const { child_relations } = await roomtable.get_child_relations();
59
- //const msg_table_options = child_relations.map(cr=>cr.table.name)
60
- const participant_field_options = [];
61
- const msg_relation_options = [];
62
- const msgsender_field_options = {};
63
- const msgview_options = {};
64
- const msgform_options = {};
65
- const participant_max_read_options = [];
66
- const msg_own_options = [];
67
-
68
- for (const { table, key_field } of child_relations) {
69
- const fields = await table.getFields();
70
- for (const f of fields) {
71
- if (f.reftable_name === "users") {
72
- participant_field_options.push(
73
- `${table.name}.${key_field.name}.${f.name}`
74
- );
75
-
76
- msg_relation_options.push(`${table.name}.${key_field.name}`);
77
-
78
- msgsender_field_options[`${table.name}.${key_field.name}`] = [
79
- ...(msgsender_field_options[
80
- `${table.name}.${key_field.name}`
81
- ] || []),
82
- f.name,
83
- ];
84
-
85
- const views = await View.find_possible_links_to_table(table);
86
- msgview_options[`${table.name}.${key_field.name}`] = views.map(
87
- (v) => v.name
88
- );
89
- msgform_options[`${table.name}.${key_field.name}`] = views.map(
90
- (v) => v.name
91
- );
92
- } else if (f.reftable_name) {
93
- participant_max_read_options.push(
94
- `${table.name}.${key_field.name}.${f.name}`
95
- );
96
- }
97
- }
98
- }
99
- return new Form({
100
- fields: [
101
- {
102
- name: "msg_relation",
103
- label: req.__("Message relation"),
104
- type: "String",
105
- sublabel: req.__(
106
- "The relationship to the table of individual messages"
107
- ),
108
- required: true,
109
- attributes: {
110
- options: msg_relation_options,
111
- },
112
- },
113
- {
114
- name: "msgsender_field",
115
- label: req.__("Message sender field"),
116
- type: "String",
117
- sublabel: req.__(
118
- "The field for the sender user id on the table for messages"
119
- ),
120
- required: true,
121
- attributes: {
122
- calcOptions: ["msg_relation", msgsender_field_options],
123
- },
124
- },
125
- {
126
- name: "msgview",
127
- label: req.__("Message show view"),
128
- type: "String",
129
- sublabel: req.__("The view to show an individual message"),
130
- required: true,
131
- attributes: {
132
- calcOptions: ["msg_relation", msgview_options],
133
- },
134
- },
135
- {
136
- name: "msgform",
137
- label: req.__("New message form view"),
138
- type: "String",
139
- sublabel: req.__("The view to enter a new message"),
140
- required: true,
141
- attributes: {
142
- calcOptions: ["msg_relation", msgform_options],
143
- },
144
- },
145
- {
146
- name: "participant_field",
147
- label: req.__("Participant field"),
148
- type: "String",
149
- sublabel: req.__("The field for the participant user id"),
150
- required: true,
151
- attributes: {
152
- options: participant_field_options,
153
- },
154
- },
155
- {
156
- name: "participant_maxread_field",
157
- label: req.__("Participant max read id field"),
158
- type: "String",
159
- sublabel: req.__(
160
- "The field for the participant's last read message, of type Key to message table"
161
- ),
162
- attributes: {
163
- options: participant_max_read_options,
164
- },
165
- },
166
- ],
167
- });
168
- },
169
- },
170
- ],
171
- });
172
-
173
- /**
174
- * @returns {object[]}
175
- */
176
- const get_state_fields = () => [
177
- {
178
- name: "id",
179
- type: "Integer",
180
- required: true,
181
- primary_key: true,
182
- },
183
- ];
184
- const limit = 10;
185
-
186
- /**
187
- * @param {string} table_id
188
- * @param {string} viewname
189
- * @param {object} optsOne
190
- * @param {string} optsOne.participant_field,
191
- * @param {string} optsOne.msg_relation
192
- * @param {*} optsOne.msgsender_field
193
- * @param {string} optsOne.msgview
194
- * @param {string} optsOne.msgform
195
- * @param {string} optsOne.participant_maxread_field
196
- * @param {object} state
197
- * @param {object} optsTwo
198
- * @param {object} optsTwo.req
199
- * @param {object} optsTwo.res
200
- * @returns {Promise<div>}
201
- * @throws {InvalidConfiguration}
202
- */
203
- const run = async (
204
- table_id,
205
- viewname,
206
- {
207
- participant_field,
208
- msg_relation,
209
- msgsender_field,
210
- msgview,
211
- msgform,
212
- participant_maxread_field,
213
- },
214
- state,
215
- { req, res }
216
- ) => {
217
- const table = await Table.findOne({ id: table_id });
218
- const fields = await table.getFields();
219
- readState(state, fields);
220
- if (!state.id) return "Need room id";
221
- const appState = getState();
222
- const locale = req.getLocale();
223
- const __ = (s) => appState.i18n.__({ phrase: s, locale }) || s;
224
- if (
225
- !participant_field ||
226
- !msgview ||
227
- !msgform ||
228
- !msgsender_field ||
229
- !msg_relation
230
- )
231
- throw new InvalidConfiguration(
232
- `View ${viewname} incorrectly configured: must supply Message views, Message sender and Participant fields`
233
- );
234
-
235
- const [msgtable_name, msgkey_to_room] = msg_relation.split(".");
236
- const [
237
- part_table_name,
238
- part_key_to_room,
239
- part_user_field,
240
- ] = participant_field.split(".");
241
-
242
- // check we participate
243
- const parttable = Table.findOne({ name: part_table_name });
244
- const partRow = await parttable.getRow({
245
- [part_user_field]: req.user ? req.user.id : 0,
246
- [part_key_to_room]: +state.id,
247
- });
248
- if (!partRow) return "You are not a participant in this room";
249
-
250
- const v = await View.findOne({ name: msgview });
251
- const vresps = await v.runMany(
252
- { [msgkey_to_room]: state.id },
253
- { req, res, orderBy: "id", orderDesc: true, limit }
254
- );
255
- vresps.reverse();
256
- const n_retrieved = vresps.length;
257
-
258
- const msglist = vresps.map((r) => r.html).join("");
259
- const formview = await View.findOne({ name: msgform });
260
- if (!formview)
261
- throw new InvalidConfiguration("Message form view does not exist");
262
- const { columns, layout } = formview.configuration;
263
- const msgtable = Table.findOne({ name: msgtable_name });
264
- const min_read_id = Math.min.apply(
265
- Math,
266
- vresps.map((r) => r.row.id)
267
- );
268
- if (participant_maxread_field) {
269
- const [
270
- part_table_name1,
271
- part_key_to_room1,
272
- part_maxread_field,
273
- ] = participant_maxread_field.split(".");
274
- const max_read_id = Math.max.apply(
275
- Math,
276
- vresps.map((r) => r.row.id)
277
- );
278
- if (vresps.length > 0)
279
- await parttable.updateRow(
280
- { [part_maxread_field]: max_read_id },
281
- partRow.id
282
- );
283
- }
284
- const form = await getForm(msgtable, viewname, columns, layout, null, req);
285
-
286
- form.class = `room-${state.id}`;
287
- form.hidden("room_id");
288
- form.values = { room_id: state.id };
289
- await form.fill_fkey_options();
290
-
291
- return div(
292
- n_retrieved === limit &&
293
- button(
294
- {
295
- class: "btn btn-outline-secondary mb-1 fetch_older",
296
- onclick: `room_older('${viewname}',${state.id},this)`,
297
- "data-lt-msg-id": min_read_id,
298
- },
299
- req.__("Show older messages")
300
- ),
301
- div({ class: `msglist-${state.id}`, "data-user-id": req.user.id }, msglist),
302
- renderForm(form, req.csrfToken()),
303
- script({
304
- src: `/static_assets/${db.connectObj.version_tag}/socket.io.min.js`,
305
- }) + script(domReady(`init_room("${viewname}", ${state.id})`))
306
- );
307
- };
308
-
309
- /**
310
- * @param {*} table_id
311
- * @param {*} viewname
312
- * @param {object} optsOne
313
- * @param {string} optsOne.participant_field
314
- * @param {string} optsOne.participant_maxread_field
315
- * @param {body} body
316
- * @param {object} optsTwo
317
- * @param {object} optsTwo.req
318
- * @param {object} optsTwo.res
319
- * @returns {Promise<void>}
320
- */
321
- const ack_read = async (
322
- table_id,
323
- viewname,
324
- { participant_field, participant_maxread_field },
325
- body,
326
- { req, res }
327
- ) => {
328
- if (!participant_maxread_field)
329
- return {
330
- json: {
331
- success: "ok",
332
- },
333
- };
334
-
335
- const [
336
- part_table_name,
337
- part_key_to_room,
338
- part_user_field,
339
- ] = participant_field.split(".");
340
- const [
341
- part_table_name1,
342
- part_key_to_room1,
343
- part_maxread_field,
344
- ] = participant_maxread_field.split(".");
345
-
346
- const parttable = Table.findOne({ name: part_table_name });
347
- // check we participate
348
-
349
- const partRow = await parttable.getRow({
350
- [part_user_field]: req.user ? req.user.id : 0,
351
- [part_key_to_room]: +body.room_id,
352
- });
353
-
354
- if (!partRow)
355
- return {
356
- json: {
357
- error: "Not participating",
358
- },
359
- };
360
-
361
- await parttable.updateRow({ [part_maxread_field]: body.id }, partRow.id);
362
- return {
363
- json: {
364
- success: "ok",
365
- },
366
- };
367
- };
368
-
369
- /**
370
- * @param {*} table_id
371
- * @param {*} viewname
372
- * @param {object} optsOne.
373
- * @param {string} optsOne.participant_field
374
- * @param {string} optsOne.msg_relation
375
- * @param {*} optsOne.msgsender_field
376
- * @param {string} optsOne.msgview
377
- * @param {*} optsOne.msgform
378
- * @param {*} optsOne.participant_maxread_field
379
- * @param {object} body
380
- * @param {object} optsTwo
381
- * @param {object} optsTwo.req
382
- * @param {object} optsTwo.res
383
- * @returns {Promise<object>}
384
- */
385
- const fetch_older_msg = async (
386
- table_id,
387
- viewname,
388
- {
389
- participant_field,
390
- msg_relation,
391
- msgsender_field,
392
- msgview,
393
- msgform,
394
- participant_maxread_field,
395
- },
396
- body,
397
- { req, res }
398
- ) => {
399
- const [msgtable_name, msgkey_to_room] = msg_relation.split(".");
400
- const [
401
- part_table_name,
402
- part_key_to_room,
403
- part_user_field,
404
- ] = participant_field.split(".");
405
- const parttable = Table.findOne({ name: part_table_name });
406
- // check we participate
407
-
408
- const partRow = await parttable.getRow({
409
- [part_user_field]: req.user ? req.user.id : 0,
410
- [part_key_to_room]: +body.room_id,
411
- });
412
-
413
- if (!partRow)
414
- return {
415
- json: {
416
- error: "Not participating",
417
- },
418
- };
419
-
420
- const v = await View.findOne({ name: msgview });
421
- const vresps = await v.runMany(
422
- { [msgkey_to_room]: +body.room_id },
423
- {
424
- req,
425
- res,
426
- orderBy: "id",
427
- orderDesc: true,
428
- limit,
429
- where: { id: { lt: +body.lt_msg_id } },
430
- }
431
- );
432
- vresps.reverse();
433
- const n_retrieved = vresps.length;
434
- const min_read_id = Math.min.apply(
435
- Math,
436
- vresps.map((r) => r.row.id)
437
- );
438
- const msglist = vresps.map((r) => r.html).join("");
439
- return {
440
- json: {
441
- success: "ok",
442
- prepend: msglist,
443
- remove_fetch_older: n_retrieved < limit,
444
- new_fetch_older_lt: min_read_id,
445
- },
446
- };
447
- };
448
-
449
- /**
450
- * @param {*} table_id
451
- * @param {string} viewname
452
- * @param {object} optsOne
453
- * @param {string} optsOne.participant_field
454
- * @param {string} optsOne.msg_relation
455
- * @param {*} optsOne.msgsender_field
456
- * @param {string} optsOne.msgview
457
- * @param {string} optsOne.msgform
458
- * @param {string} optsOne.participant_maxread_field
459
- * @param {*} body
460
- * @param {object} optsTwo
461
- * @param {object} optsTwo.req
462
- * @param {object} optsTwo.res
463
- * @returns {Promise<object>}
464
- */
465
- const submit_msg_ajax = async (
466
- table_id,
467
- viewname,
468
- {
469
- participant_field,
470
- msg_relation,
471
- msgsender_field,
472
- msgview,
473
- msgform,
474
- participant_maxread_field,
475
- },
476
- body,
477
- { req, res }
478
- ) => {
479
- const [msgtable_name, msgkey_to_room] = msg_relation.split(".");
480
- const [
481
- part_table_name,
482
- part_key_to_room,
483
- part_user_field,
484
- ] = participant_field.split(".");
485
- const parttable = Table.findOne({ name: part_table_name });
486
- // check we participate
487
-
488
- const partRow = await parttable.getRow({
489
- [part_user_field]: req.user ? req.user.id : 0,
490
- [part_key_to_room]: +body.room_id,
491
- });
492
-
493
- if (!partRow)
494
- return {
495
- json: {
496
- error: "Not participating",
497
- },
498
- };
499
-
500
- const formview = await View.findOne({ name: msgform });
501
- if (!formview)
502
- throw new InvalidConfiguration("Message form view does not exist");
503
- const { columns, layout, fixed } = formview.configuration;
504
- const msgtable = Table.findOne({ name: msgtable_name });
505
-
506
- const form = await getForm(msgtable, viewname, columns, layout, null, req);
507
- form.validate(req.body);
508
- if (!form.hasErrors) {
509
- const use_fixed = await fill_presets(msgtable, req, fixed);
510
- const row = {
511
- ...form.values,
512
- ...use_fixed,
513
- [msgkey_to_room]: body.room_id,
514
- [msgsender_field]: req.user.id,
515
- };
516
- const msgid = await msgtable.tryInsertRow(row, req.user.id);
517
- if (participant_maxread_field) {
518
- const [
519
- part_table_name1,
520
- part_key_to_room1,
521
- part_maxread_field,
522
- ] = participant_maxread_field.split(".");
523
- await parttable.updateRow(
524
- { [part_maxread_field]: msgid.success },
525
- partRow.id
526
- );
527
- }
528
- const v = await View.findOne({ name: msgview });
529
- const myhtml = await v.run({ id: msgid.success }, { req, res });
530
- const newreq = { ...req, user: { ...req.user, id: 0 } };
531
- const theirhtml = await v.run({ id: msgid.success }, { req: newreq, res });
532
-
533
- getState().emitRoom(viewname, +body.room_id, {
534
- append: theirhtml,
535
- not_for_user_id: req.user.id,
536
- pls_ack_msg_id: msgid.success,
537
- });
538
- return {
539
- json: {
540
- success: "ok",
541
- append: myhtml,
542
- },
543
- };
544
- } else {
545
- return {
546
- json: {
547
- error: form.errors,
548
- },
549
- };
550
- }
551
- };
552
-
553
- /**
554
- * @param {*} table_id
555
- * @param {string} viewname
556
- * @param {object} opts
557
- * @param {*} opts.participant_field
558
- * @param {string} opts.msg_relation,
559
- * @param {string} opts.msgsender_field,
560
- * @param {string} opts.msgview,
561
- * @param {*} opts.msgform,
562
- * @param {*} opts.participant_maxread_field,
563
- * @returns {object[]}
564
- */
565
- const virtual_triggers = (
566
- table_id,
567
- viewname,
568
- {
569
- participant_field,
570
- msg_relation,
571
- msgsender_field,
572
- msgview,
573
- msgform,
574
- participant_maxread_field,
575
- }
576
- ) => {
577
- if (!msg_relation) return [];
578
- const [msgtable_name, msgkey_to_room] = msg_relation.split(".");
579
- const msgtable = Table.findOne({ name: msgtable_name });
580
- if (!msgsender_field) return [];
581
-
582
- return [
583
- {
584
- when_trigger: "Insert",
585
- table_id: msgtable.id,
586
- run: async (row) => {
587
- if (row[msgsender_field]) return; // TODO how else to avoid double emit
588
- const v = await View.findOne({ name: msgview });
589
-
590
- const html = await v.run(
591
- { id: row.id },
592
- {
593
- req: { getLocale: () => "en", user: { id: 0 }, __: (s) => s },
594
- res: {},
595
- }
596
- );
597
-
598
- getState().emitRoom(viewname, row[msgkey_to_room], {
599
- append: html,
600
- pls_ack_msg_id: row.id,
601
- });
602
- },
603
- },
604
- ];
605
- };
606
- module.exports = {
607
- /** @type {string} */
608
- name: "Room",
609
- /** @type {string} */
610
- description: "Real-time space for chat",
611
- configuration_workflow,
612
- run,
613
- get_state_fields,
614
- /** @type {boolean} */
615
- display_state_form: false,
616
- routes: { submit_msg_ajax, ack_read, fetch_older_msg },
617
- /** @type {boolean} */
618
- noAutoTest: true,
619
- /**
620
- * @param {object} opts
621
- * @param {object} opts.participant_field
622
- * @param {string} room_id
623
- * @param {object} user
624
- * @returns {Promise<object>}
625
- */
626
- authorize_join: async ({ participant_field }, room_id, user) => {
627
- if (!user) return false;
628
- const [
629
- part_table_name,
630
- part_key_to_room,
631
- part_user_field,
632
- ] = participant_field.split(".");
633
-
634
- // TODO check we participate
635
- const parttable = Table.findOne({ name: part_table_name });
636
- const partRow = await parttable.getRow({
637
- [part_user_field]: user.id,
638
- [part_key_to_room]: room_id,
639
- });
640
- return !!partRow;
641
- },
642
- virtual_triggers,
643
- /** @returns {object[]} */
644
- getStringsForI18n() {
645
- return [];
646
- },
647
- };
648
- /*todo:
649
-
650
- find_or_create_dm_room -dms only
651
-
652
- */