@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,689 +0,0 @@
1
- /**
2
- * @category saltcorn-data
3
- * @module base-plugin/viewtemplates/show
4
- * @subcategory base-plugin
5
- */
6
- const Form = require("../../models/form");
7
- const User = require("../../models/user");
8
- const Field = require("../../models/field");
9
- const View = require("../../models/view");
10
- const File = require("../../models/file");
11
- const Table = require("../../models/table");
12
- const Page = require("../../models/page");
13
- const Workflow = require("../../models/workflow");
14
- const Trigger = require("../../models/trigger");
15
-
16
- const { post_btn, link } = require("@saltcorn/markup");
17
- const { getState } = require("../../db/state");
18
- const {
19
- eachView,
20
- traverse,
21
- getStringsForI18n,
22
- translateLayout,
23
- } = require("../../models/layout");
24
-
25
- const { div, text, span, a, text_attr, i } = require("@saltcorn/markup/tags");
26
- const renderLayout = require("@saltcorn/markup/layout");
27
-
28
- const {
29
- stateFieldsToWhere,
30
- stateFieldsToQuery,
31
- get_link_view_opts,
32
- picked_fields_to_query,
33
- initial_config_all_fields,
34
- calcfldViewOptions,
35
- calcfldViewConfig,
36
- getActionConfigFields,
37
- run_action_column,
38
- readState,
39
- } = require("../../plugin-helper");
40
- const {
41
- action_url,
42
- view_linker,
43
- parse_view_select,
44
- action_link,
45
- } = require("./viewable_fields");
46
- const db = require("../../db");
47
- const {
48
- asyncMap,
49
- structuredClone,
50
- InvalidConfiguration,
51
- } = require("../../utils");
52
- const { traverseSync } = require("../../models/layout");
53
- const { get_expression_function } = require("../../models/expression");
54
- const { get_base_url } = require("../../models/config");
55
- const Library = require("../../models/library");
56
-
57
- /**
58
- * @param {object} req
59
- * @returns {Workflow}
60
- */
61
- const configuration_workflow = (req) =>
62
- new Workflow({
63
- steps: [
64
- {
65
- name: req.__("Layout"),
66
- builder: async (context) => {
67
- const table = await Table.findOne(
68
- context.table_id || context.exttable_name
69
- );
70
- const fields = await table.getFields();
71
-
72
- const boolfields = fields.filter(
73
- (f) => f.type && f.type.name === "Bool"
74
- );
75
- const stateActions = Object.entries(getState().actions).filter(
76
- ([k, v]) => !v.disableInBuilder
77
- );
78
- const actions = [
79
- "Delete",
80
- ...boolfields.map((f) => `Toggle ${f.name}`),
81
- ...stateActions.map(([k, v]) => k),
82
- ];
83
- const triggers = await Trigger.find({
84
- when_trigger: { or: ["API call", "Never"] },
85
- });
86
- triggers.forEach((tr) => {
87
- actions.push(tr.name);
88
- });
89
- for (const field of fields) {
90
- if (field.type === "Key") {
91
- field.reftable = await Table.findOne({
92
- name: field.reftable_name,
93
- });
94
- if (field.reftable) await field.reftable.getFields();
95
- }
96
- }
97
- const actionConfigForms = {};
98
- for (const [name, action] of stateActions) {
99
- if (action.configFields) {
100
- actionConfigForms[name] = await getActionConfigFields(
101
- action,
102
- table
103
- );
104
- }
105
- }
106
- const fieldViewConfigForms = await calcfldViewConfig(fields, false);
107
- const { field_view_options, handlesTextStyle } = calcfldViewOptions(
108
- fields,
109
- "show"
110
- );
111
- if (table.name === "users") {
112
- fields.push(
113
- new Field({
114
- name: "verification_url",
115
- label: "Verification URL",
116
- type: "String",
117
- })
118
- );
119
- field_view_options.verification_url = ["as_text", "as_link"];
120
- }
121
- const link_view_opts = await get_link_view_opts(
122
- table,
123
- context.viewname
124
- );
125
- const roles = await User.get_roles();
126
- const { parent_field_list } = await table.get_parent_relations(true);
127
- const {
128
- child_field_list,
129
- child_relations,
130
- } = await table.get_child_relations();
131
- var agg_field_opts = {};
132
- child_relations.forEach(({ table, key_field }) => {
133
- agg_field_opts[
134
- `${table.name}.${key_field.name}`
135
- ] = table.fields
136
- .filter((f) => !f.calculated || f.stored)
137
- .map((f) => f.name);
138
- });
139
- const views = link_view_opts;
140
- const pages = await Page.find();
141
- const images = await File.find({ mime_super: "image" });
142
- const library = (await Library.find({})).filter((l) =>
143
- l.suitableFor("show")
144
- );
145
- const myviewrow = await View.findOne({ name: context.viewname });
146
- return {
147
- tableName: table.name,
148
- fields,
149
- images,
150
- actions,
151
- actionConfigForms,
152
- fieldViewConfigForms,
153
- field_view_options,
154
- link_view_opts,
155
- parent_field_list,
156
- child_field_list,
157
- agg_field_opts,
158
- min_role: (myviewrow || {}).min_role,
159
- roles,
160
- views,
161
- library,
162
- pages,
163
- handlesTextStyle,
164
- mode: "show",
165
- ownership: !!table.ownership_field_id || table.name === "users",
166
- };
167
- },
168
- },
169
- {
170
- name: req.__("Set page title"),
171
- form: () =>
172
- new Form({
173
- blurb: req.__(
174
- "Skip this section if you do not want to set the page title"
175
- ),
176
- fields: [
177
- {
178
- name: "page_title",
179
- label: req.__("Page title"),
180
- type: "String",
181
- },
182
- {
183
- name: "page_title_formula",
184
- label: req.__("Page title is a formula?"),
185
- type: "Bool",
186
- required: false,
187
- },
188
- ],
189
- }),
190
- },
191
- ],
192
- });
193
-
194
- /**
195
- * @returns {object[]}
196
- */
197
- const get_state_fields = () => [
198
- {
199
- name: "id",
200
- type: "Integer",
201
- required: true,
202
- primary_key: true,
203
- },
204
- ];
205
-
206
- /** @type {function} */
207
- const initial_config = initial_config_all_fields(false);
208
-
209
- /**
210
- * @param {string} table_id
211
- * @param {string} viewname
212
- * @param {object} opts
213
- * @param {object[]} opts.columns
214
- * @param {object} opts.layout
215
- * @param {string} [opts.page_title]
216
- * @param {boolean} opts.page_title_formula
217
- * @param {object} state
218
- * @param {object} extra
219
- * @returns {Promise<string>}
220
- */
221
- const run = async (
222
- table_id,
223
- viewname,
224
- { columns, layout, page_title, page_title_formula },
225
- state,
226
- extra
227
- ) => {
228
- //console.log(columns);
229
- //console.log(layout);
230
- if (!columns || !layout) return "View not yet built";
231
- const tbl = await Table.findOne(table_id);
232
- const fields = await tbl.getFields();
233
- if (tbl.name === "users") {
234
- fields.push(
235
- new Field({
236
- name: "verification_token",
237
- label: "Verification Token",
238
- type: "String",
239
- })
240
- );
241
- }
242
- const { joinFields, aggregations } = picked_fields_to_query(columns, fields);
243
- readState(state, fields);
244
- const qstate = await stateFieldsToWhere({ fields, state, approximate: true });
245
- if (Object.keys(qstate).length === 0) return extra.req.__("No row selected");
246
- const rows = await tbl.getJoinedRows({
247
- where: qstate,
248
- joinFields,
249
- aggregations,
250
- limit: 5,
251
- });
252
- if (rows.length > 1)
253
- rows.sort((a, b) => {
254
- let diff = 0;
255
- Object.keys(state).forEach((key) => {
256
- if (a[key] && b[key]) {
257
- if (typeof a[key] === "string" && typeof b[key] === "string") {
258
- diff += a[key].length - b[key].length;
259
- }
260
- }
261
- });
262
- return diff;
263
- });
264
-
265
- if (rows.length == 0) return extra.req.__("No row selected");
266
- if (tbl.name === "users") {
267
- const base = get_base_url(extra.req);
268
- fields.push(
269
- new Field({
270
- name: "verification_url",
271
- label: "Verification URL",
272
- type: "String",
273
- })
274
- );
275
- for (const row of rows) {
276
- row.verification_url = `${base}auth/verify?token=${
277
- row.verification_token
278
- }&email=${encodeURIComponent(row.email)}`;
279
- }
280
- }
281
- await set_join_fieldviews({ layout, fields });
282
-
283
- const rendered = (
284
- await renderRows(tbl, viewname, { columns, layout }, extra, [rows[0]])
285
- )[0];
286
- let page_title_preamble = "";
287
- if (page_title) {
288
- let the_title = page_title;
289
- if (page_title_formula) {
290
- const f = get_expression_function(page_title, fields);
291
- the_title = f(rows[0]);
292
- }
293
- page_title_preamble = `<!--SCPT:${text_attr(the_title)}-->`;
294
- }
295
- return page_title_preamble + rendered;
296
- };
297
-
298
- /**
299
- * @param {object} opts
300
- * @param {object} opts.layout
301
- * @param {object[]} opts.fields
302
- * @returns {Promise<void>}
303
- */
304
- const set_join_fieldviews = async ({ layout, fields }) => {
305
- await traverse(layout, {
306
- join_field: async (segment) => {
307
- const { join_field, fieldview } = segment;
308
- if (!fieldview) return;
309
- const keypath = join_field.split(".");
310
- if (keypath.length === 2) {
311
- const [refNm, targetNm] = keypath;
312
- const ref = fields.find((f) => f.name === refNm);
313
- if (!ref) return;
314
- const table = await Table.findOne({ name: ref.reftable_name });
315
- if (!table) return;
316
- const reffields = await table.getFields();
317
- const field = reffields.find((f) => f.name === targetNm);
318
- if (field && field.type === "File") segment.field_type = "File";
319
- else if (
320
- field &&
321
- field.type &&
322
- field.type.name &&
323
- field.type.fieldviews &&
324
- field.type.fieldviews[fieldview]
325
- )
326
- segment.field_type = field.type.name;
327
- } else {
328
- //const [refNm, through, targetNm] = keypath;
329
- }
330
- },
331
- });
332
- };
333
-
334
- /**
335
- * @param {object} table
336
- * @param {string} viewname
337
- * @param {object} opts
338
- * @param {object[]} opts.columns
339
- * @param {object} opts.layout
340
- * @param {object} extra
341
- * @param {object[]} rows
342
- * @returns {Promise<string>}
343
- */
344
- const renderRows = async (
345
- table,
346
- viewname,
347
- { columns, layout },
348
- extra,
349
- rows
350
- ) => {
351
- //console.log(columns);
352
- //console.log(layout);
353
- if (!columns || !layout) return req.__("View not yet built");
354
-
355
- const fields = await table.getFields();
356
-
357
- const role = extra.req.user ? extra.req.user.role_id : 10;
358
- var views = {};
359
- const getView = async (nm) => {
360
- if (views[nm]) return views[nm];
361
- const view_select = parse_view_select(nm);
362
- const view = await View.findOne({ name: view_select.viewname });
363
- if (!view) return false;
364
- if (view.table_id === table.id) view.table = table;
365
- else view.table = await Table.findOne({ id: view.table_id });
366
- view.view_select = view_select;
367
- views[nm] = view;
368
- return view;
369
- };
370
- await set_join_fieldviews({ layout, fields });
371
-
372
- const owner_field = await table.owner_fieldname();
373
- return await asyncMap(rows, async (row) => {
374
- await eachView(layout, async (segment) => {
375
- const view = await getView(segment.view);
376
- if (!view)
377
- throw new InvalidConfiguration(
378
- `View ${viewname} incorrectly configured: cannot find view ${segment.view}`
379
- );
380
- view.check_viewtemplate();
381
- if (view.viewtemplateObj.renderRows && view.view_select.type === "Own") {
382
- segment.contents = (
383
- await view.viewtemplateObj.renderRows(
384
- view.table,
385
- view.name,
386
- view.configuration,
387
- extra,
388
- [row]
389
- )
390
- )[0];
391
- } else {
392
- let state;
393
- const pk_name = table.pk_name;
394
- switch (view.view_select.type) {
395
- case "Own":
396
- state = { [pk_name]: row[pk_name] };
397
- break;
398
- case "Independent":
399
- state = {};
400
- break;
401
- case "ChildList":
402
- case "OneToOneShow":
403
- state = { [view.view_select.field_name]: row[pk_name] };
404
- break;
405
- case "ParentShow":
406
- //todo set by pk name of parent tablr
407
- state = { id: row[view.view_select.field_name] };
408
- break;
409
- }
410
- segment.contents = await view.run(state, extra);
411
- }
412
- });
413
- const user_id = extra.req.user ? extra.req.user.id : null;
414
-
415
- const is_owner =
416
- table.ownership_formula && user_id
417
- ? await table.is_owner(extra.req.user, row)
418
- : owner_field && user_id && row[owner_field] === user_id;
419
-
420
- return render(
421
- row,
422
- fields,
423
- layout,
424
- viewname,
425
- table,
426
- role,
427
- extra.req,
428
- is_owner
429
- );
430
- });
431
- };
432
-
433
- /**
434
- * @param {number} table_id
435
- * @param {string} viewname
436
- * @param {object} opts
437
- * @param {object[]} opts.columns
438
- * @param {object} opts.layout
439
- * @param {object} state
440
- * @param {object} extra
441
- * @returns {Promise<object[]>}
442
- */
443
- const runMany = async (
444
- table_id,
445
- viewname,
446
- { columns, layout },
447
- state,
448
- extra
449
- ) => {
450
- const tbl = await Table.findOne({ id: table_id });
451
- const fields = await tbl.getFields();
452
- const { joinFields, aggregations } = picked_fields_to_query(columns, fields);
453
- const qstate = await stateFieldsToWhere({ fields, state });
454
- const q = await stateFieldsToQuery({ state, fields });
455
- if (extra && extra.where) Object.assign(qstate, extra.where);
456
-
457
- const rows = await tbl.getJoinedRows({
458
- where: qstate,
459
- joinFields,
460
- aggregations,
461
- ...(extra && extra.limit && { limit: extra.limit }),
462
- ...(extra && extra.offset && { offset: extra.offset }),
463
- ...(extra && extra.orderBy && { orderBy: extra.orderBy }),
464
- ...(extra && extra.orderDesc && { orderDesc: extra.orderDesc }),
465
- ...q,
466
- });
467
-
468
- const rendered = await renderRows(
469
- tbl,
470
- viewname,
471
- { columns, layout },
472
- extra,
473
- rows
474
- );
475
-
476
- return rendered.map((html, ix) => ({ html, row: rows[ix] }));
477
- };
478
-
479
- /**
480
- * @param {object} row
481
- * @param {Field[]} fields
482
- * @param {Layout} layout0
483
- * @param {string} viewname
484
- * @param {Table} table
485
- * @param {Role} role
486
- * @param {object} req
487
- * @param {object} is_owner
488
- * @throws {Error}
489
- * @returns {Layout}
490
- */
491
- const render = (row, fields, layout0, viewname, table, role, req, is_owner) => {
492
- const evalMaybeExpr = (segment, key, fmlkey) => {
493
- if (segment.isFormula && segment.isFormula[fmlkey || key]) {
494
- try {
495
- const f = get_expression_function(segment[key], fields);
496
- segment[key] = f(row, req.user);
497
- } catch (error) {
498
- error.message = `Error in formula ${segment[key]} for property ${key} in segment of type ${segment.type}:\n${error.message}`;
499
- throw error;
500
- }
501
- }
502
- };
503
- const layout = structuredClone(layout0);
504
- traverseSync(layout, {
505
- link(segment) {
506
- evalMaybeExpr(segment, "url");
507
- evalMaybeExpr(segment, "text");
508
- },
509
- view_link(segment) {
510
- evalMaybeExpr(segment, "view_label", "label");
511
- },
512
- blank(segment) {
513
- evalMaybeExpr(segment, "contents", "text");
514
- },
515
- action(segment) {
516
- evalMaybeExpr(segment, "action_label");
517
- },
518
- card(segment) {
519
- evalMaybeExpr(segment, "url");
520
- evalMaybeExpr(segment, "title");
521
- },
522
- image(segment) {
523
- evalMaybeExpr(segment, "url");
524
- evalMaybeExpr(segment, "alt");
525
- if (segment.srctype === "Field") {
526
- const field = fields.find((f) => f.name === segment.field);
527
- if (!field) return;
528
- if (field.type.name === "String") segment.url = row[segment.field];
529
- if (field.reftable_name === "_sc_files")
530
- segment.url = `/files/serve/${row[segment.field]}`;
531
- }
532
- },
533
- container(segment) {
534
- evalMaybeExpr(segment, "bgColor");
535
- evalMaybeExpr(segment, "customClass");
536
- evalMaybeExpr(segment, "url");
537
-
538
- if (segment.showIfFormula) {
539
- const f = get_expression_function(segment.showIfFormula, fields);
540
- if (!f(row)) segment.hide = true;
541
- }
542
- },
543
- });
544
- const locale = req.getLocale();
545
- translateLayout(layout, locale);
546
- const blockDispatch = {
547
- field({ field_name, fieldview, configuration }) {
548
- let field = fields.find((fld) => fld.name === field_name);
549
- if (!field) return "";
550
-
551
- let val = row[field_name];
552
- if (
553
- field &&
554
- field.attributes &&
555
- field.attributes.localized_by &&
556
- field.attributes.localized_by[locale]
557
- ) {
558
- const localized_fld = field.attributes.localized_by[locale];
559
- val = row[localized_fld];
560
- }
561
-
562
- if (fieldview && field.type === "File") {
563
- return val
564
- ? getState().fileviews[fieldview].run(
565
- val,
566
- row[`${field_name}__filename`],
567
- configuration
568
- )
569
- : "";
570
- } else if (
571
- fieldview &&
572
- field.type &&
573
- field.type.fieldviews &&
574
- field.type.fieldviews[fieldview]
575
- )
576
- return field.type.fieldviews[fieldview].run(val, req, configuration);
577
- else return text(val);
578
- },
579
- join_field({ join_field, field_type, fieldview }) {
580
- const keypath = join_field.split(".");
581
- let value;
582
- if (keypath.length === 2) {
583
- const [refNm, targetNm] = keypath;
584
- value = row[`${refNm}_${targetNm}`];
585
- } else {
586
- const [refNm, through, targetNm] = keypath;
587
- value = row[`${refNm}_${through}_${targetNm}`];
588
- }
589
- if (field_type === "File") {
590
- return value ? getState().fileviews[fieldview].run(value, "") : "";
591
- }
592
- if (field_type && fieldview) {
593
- const type = getState().types[field_type];
594
- if (type && getState().types[field_type])
595
- return type.fieldviews[fieldview].run(value, req);
596
- else return text(value);
597
- } else return text(value);
598
- },
599
- aggregation({ agg_relation, stat }) {
600
- const [table, fld] = agg_relation.split(".");
601
- const targetNm = (stat + "_" + table + "_" + fld).toLowerCase();
602
- const val = row[targetNm];
603
- return text(val);
604
- },
605
- action(segment) {
606
- const url = action_url(
607
- viewname,
608
- table,
609
- segment.action_name,
610
- row,
611
- segment.rndid,
612
- "rndid"
613
- );
614
- return action_link(url, req, segment);
615
- },
616
- view_link(view) {
617
- const { key } = view_linker(view, fields);
618
- return key(row);
619
- },
620
- };
621
- return renderLayout({
622
- blockDispatch,
623
- layout,
624
- role,
625
- is_owner,
626
- });
627
- };
628
-
629
- /**
630
- * @param {number} table_id
631
- * @param {*} viewname
632
- * @param {object} opts
633
- * @param {object[]} opts.columns
634
- * @param {*} opts.layout
635
- * @param {*} body
636
- * @param {object} optsTwo
637
- * @param {object} optsTwo.req
638
- * @param {*} optsTwo.res
639
- * @returns {Promise<object>}
640
- */
641
- const run_action = async (
642
- table_id,
643
- viewname,
644
- { columns, layout },
645
- body,
646
- { req, res }
647
- ) => {
648
- const col = columns.find(
649
- (c) => c.type === "Action" && c.rndid === body.rndid && body.rndid
650
- );
651
- const table = await Table.findOne({ id: table_id });
652
- const row = await table.getRow({ id: body.id });
653
- try {
654
- const result = await run_action_column({
655
- col,
656
- req,
657
- table,
658
- row,
659
- referrer: req.get("Referrer"),
660
- });
661
- return { json: { success: "ok", ...(result || {}) } };
662
- } catch (e) {
663
- return { json: { error: e.message || e } };
664
- }
665
- };
666
-
667
- module.exports = {
668
- /** @type {string} */
669
- name: "Show",
670
- /** @type {string} */
671
- description: "Show a single row, with flexible layout",
672
- get_state_fields,
673
- configuration_workflow,
674
- run,
675
- runMany,
676
- renderRows,
677
- initial_config,
678
- /** @type {boolean} */
679
- display_state_form: false,
680
- routes: { run_action },
681
- /**
682
- * @param {object} opts
683
- * @param {object} opts.layout
684
- * @returns {string[]}
685
- */
686
- getStringsForI18n({ layout }) {
687
- return getStringsForI18n(layout);
688
- },
689
- };