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

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (555) hide show
  1. package/dist/base-plugin/actions.d.ts +141 -0
  2. package/dist/base-plugin/actions.d.ts.map +1 -0
  3. package/dist/base-plugin/actions.js +551 -0
  4. package/dist/base-plugin/actions.js.map +1 -0
  5. package/dist/base-plugin/base.test.d.ts +2 -0
  6. package/dist/base-plugin/base.test.d.ts.map +1 -0
  7. package/dist/base-plugin/base.test.js +15 -0
  8. package/dist/base-plugin/base.test.js.map +1 -0
  9. package/dist/base-plugin/fieldviews.d.ts +25 -0
  10. package/dist/base-plugin/fieldviews.d.ts.map +1 -0
  11. package/dist/base-plugin/fieldviews.js +159 -0
  12. package/dist/base-plugin/fieldviews.js.map +1 -0
  13. package/dist/base-plugin/fileviews.d.ts +52 -0
  14. package/dist/base-plugin/fileviews.d.ts.map +1 -0
  15. package/dist/base-plugin/fileviews.js +59 -0
  16. package/dist/base-plugin/fileviews.js.map +1 -0
  17. package/dist/base-plugin/index.d.ts +524 -0
  18. package/dist/base-plugin/index.d.ts.map +1 -0
  19. package/{base-plugin → dist/base-plugin}/index.js +22 -24
  20. package/dist/base-plugin/index.js.map +1 -0
  21. package/dist/base-plugin/types.d.ts +383 -0
  22. package/dist/base-plugin/types.d.ts.map +1 -0
  23. package/dist/base-plugin/types.js +1080 -0
  24. package/dist/base-plugin/types.js.map +1 -0
  25. package/dist/base-plugin/viewtemplates/edit.d.ts +116 -0
  26. package/dist/base-plugin/viewtemplates/edit.d.ts.map +1 -0
  27. package/dist/base-plugin/viewtemplates/edit.js +561 -0
  28. package/dist/base-plugin/viewtemplates/edit.js.map +1 -0
  29. package/dist/base-plugin/viewtemplates/feed.d.ts +73 -0
  30. package/dist/base-plugin/viewtemplates/feed.d.ts.map +1 -0
  31. package/dist/base-plugin/viewtemplates/feed.js +348 -0
  32. package/dist/base-plugin/viewtemplates/feed.js.map +1 -0
  33. package/dist/base-plugin/viewtemplates/filter.d.ts +46 -0
  34. package/dist/base-plugin/viewtemplates/filter.d.ts.map +1 -0
  35. package/dist/base-plugin/viewtemplates/filter.js +267 -0
  36. package/dist/base-plugin/viewtemplates/filter.js.map +1 -0
  37. package/dist/base-plugin/viewtemplates/list.d.ts +99 -0
  38. package/dist/base-plugin/viewtemplates/list.d.ts.map +1 -0
  39. package/dist/base-plugin/viewtemplates/list.js +471 -0
  40. package/dist/base-plugin/viewtemplates/list.js.map +1 -0
  41. package/dist/base-plugin/viewtemplates/listshowlist.d.ts +41 -0
  42. package/dist/base-plugin/viewtemplates/listshowlist.d.ts.map +1 -0
  43. package/dist/base-plugin/viewtemplates/listshowlist.js +248 -0
  44. package/dist/base-plugin/viewtemplates/listshowlist.js.map +1 -0
  45. package/dist/base-plugin/viewtemplates/room.d.ts +140 -0
  46. package/dist/base-plugin/viewtemplates/room.d.ts.map +1 -0
  47. package/dist/base-plugin/viewtemplates/room.js +469 -0
  48. package/dist/base-plugin/viewtemplates/room.js.map +1 -0
  49. package/dist/base-plugin/viewtemplates/show.d.ts +101 -0
  50. package/dist/base-plugin/viewtemplates/show.d.ts.map +1 -0
  51. package/dist/base-plugin/viewtemplates/show.js +562 -0
  52. package/dist/base-plugin/viewtemplates/show.js.map +1 -0
  53. package/dist/base-plugin/viewtemplates/viewable_fields.d.ts +108 -0
  54. package/dist/base-plugin/viewtemplates/viewable_fields.d.ts.map +1 -0
  55. package/dist/base-plugin/viewtemplates/viewable_fields.js +563 -0
  56. package/dist/base-plugin/viewtemplates/viewable_fields.js.map +1 -0
  57. package/dist/contracts.d.ts +49 -0
  58. package/dist/contracts.d.ts.map +1 -0
  59. package/dist/contracts.js +212 -0
  60. package/dist/contracts.js.map +1 -0
  61. package/dist/coverage/lcov-report/block-navigation.d.ts +2 -0
  62. package/dist/coverage/lcov-report/block-navigation.d.ts.map +1 -0
  63. package/dist/coverage/lcov-report/block-navigation.js +66 -0
  64. package/dist/coverage/lcov-report/block-navigation.js.map +1 -0
  65. package/dist/coverage/lcov-report/prettify.d.ts +1 -0
  66. package/dist/coverage/lcov-report/prettify.d.ts.map +1 -0
  67. package/dist/coverage/lcov-report/prettify.js +478 -0
  68. package/dist/coverage/lcov-report/prettify.js.map +1 -0
  69. package/dist/coverage/lcov-report/sorter.d.ts +2 -0
  70. package/dist/coverage/lcov-report/sorter.d.ts.map +1 -0
  71. package/dist/coverage/lcov-report/sorter.js +141 -0
  72. package/dist/coverage/lcov-report/sorter.js.map +1 -0
  73. package/dist/db/connect.d.ts +40 -0
  74. package/dist/db/connect.d.ts.map +1 -0
  75. package/dist/db/connect.js +150 -0
  76. package/dist/db/connect.js.map +1 -0
  77. package/dist/db/db.test.d.ts +2 -0
  78. package/dist/db/db.test.d.ts.map +1 -0
  79. package/dist/db/db.test.js +28 -0
  80. package/dist/db/db.test.js.map +1 -0
  81. package/dist/db/fixtures.d.ts +8 -0
  82. package/dist/db/fixtures.d.ts.map +1 -0
  83. package/dist/db/fixtures.js +300 -0
  84. package/dist/db/fixtures.js.map +1 -0
  85. package/dist/db/index.d.ts +3 -0
  86. package/dist/db/index.d.ts.map +1 -0
  87. package/dist/db/index.js +41 -0
  88. package/dist/db/index.js.map +1 -0
  89. package/dist/db/reset_schema.d.ts +13 -0
  90. package/dist/db/reset_schema.d.ts.map +1 -0
  91. package/{db → dist/db}/reset_schema.js +45 -55
  92. package/dist/db/reset_schema.js.map +1 -0
  93. package/dist/db/state.d.ts +56 -0
  94. package/dist/db/state.d.ts.map +1 -0
  95. package/dist/db/state.js +610 -0
  96. package/dist/db/state.js.map +1 -0
  97. package/dist/index.d.ts +2 -0
  98. package/dist/index.d.ts.map +1 -0
  99. package/{index.js → dist/index.js} +2 -1
  100. package/dist/index.js.map +1 -0
  101. package/dist/migrate.d.ts +12 -0
  102. package/dist/migrate.d.ts.map +1 -0
  103. package/dist/migrate.js +94 -0
  104. package/dist/migrate.js.map +1 -0
  105. package/dist/migrations/202005141503.d.ts +2 -0
  106. package/dist/migrations/202005141503.d.ts.map +1 -0
  107. package/{migrations → dist/migrations}/202005141503.js +2 -1
  108. package/dist/migrations/202005141503.js.map +1 -0
  109. package/dist/migrations/202005241712.d.ts +2 -0
  110. package/dist/migrations/202005241712.d.ts.map +1 -0
  111. package/{migrations → dist/migrations}/202005241712.js +2 -1
  112. package/dist/migrations/202005241712.js.map +1 -0
  113. package/dist/migrations/202005251037.d.ts +2 -0
  114. package/dist/migrations/202005251037.d.ts.map +1 -0
  115. package/{migrations → dist/migrations}/202005251037.js +2 -1
  116. package/dist/migrations/202005251037.js.map +1 -0
  117. package/dist/migrations/202005282134.d.ts +2 -0
  118. package/dist/migrations/202005282134.d.ts.map +1 -0
  119. package/{migrations → dist/migrations}/202005282134.js +2 -1
  120. package/dist/migrations/202005282134.js.map +1 -0
  121. package/dist/migrations/202006022156.d.ts +2 -0
  122. package/dist/migrations/202006022156.d.ts.map +1 -0
  123. package/{migrations → dist/migrations}/202006022156.js +2 -1
  124. package/dist/migrations/202006022156.js.map +1 -0
  125. package/dist/migrations/202006051507.d.ts +2 -0
  126. package/dist/migrations/202006051507.d.ts.map +1 -0
  127. package/{migrations → dist/migrations}/202006051507.js +2 -1
  128. package/dist/migrations/202006051507.js.map +1 -0
  129. package/dist/migrations/202006240906.d.ts +2 -0
  130. package/dist/migrations/202006240906.d.ts.map +1 -0
  131. package/{migrations → dist/migrations}/202006240906.js +2 -1
  132. package/dist/migrations/202006240906.js.map +1 -0
  133. package/dist/migrations/202007091707.d.ts +2 -0
  134. package/dist/migrations/202007091707.d.ts.map +1 -0
  135. package/{migrations → dist/migrations}/202007091707.js +2 -1
  136. package/dist/migrations/202007091707.js.map +1 -0
  137. package/dist/migrations/202007202144.d.ts +2 -0
  138. package/dist/migrations/202007202144.d.ts.map +1 -0
  139. package/{migrations → dist/migrations}/202007202144.js +2 -1
  140. package/dist/migrations/202007202144.js.map +1 -0
  141. package/dist/migrations/202008031500.d.ts +2 -0
  142. package/dist/migrations/202008031500.d.ts.map +1 -0
  143. package/dist/migrations/202008031500.js +4 -0
  144. package/dist/migrations/202008031500.js.map +1 -0
  145. package/dist/migrations/202008051415.d.ts +2 -0
  146. package/dist/migrations/202008051415.d.ts.map +1 -0
  147. package/{migrations → dist/migrations}/202008051415.js +2 -1
  148. package/dist/migrations/202008051415.js.map +1 -0
  149. package/dist/migrations/202008121149.d.ts +3 -0
  150. package/dist/migrations/202008121149.d.ts.map +1 -0
  151. package/{migrations → dist/migrations}/202008121149.js +2 -2
  152. package/dist/migrations/202008121149.js.map +1 -0
  153. package/dist/migrations/202009112140.d.ts +3 -0
  154. package/dist/migrations/202009112140.d.ts.map +1 -0
  155. package/{migrations → dist/migrations}/202009112140.js +2 -2
  156. package/dist/migrations/202009112140.js.map +1 -0
  157. package/dist/migrations/202009181655.d.ts +2 -0
  158. package/dist/migrations/202009181655.d.ts.map +1 -0
  159. package/dist/migrations/202009181655.js +7 -0
  160. package/dist/migrations/202009181655.js.map +1 -0
  161. package/dist/migrations/202009221105.d.ts +2 -0
  162. package/dist/migrations/202009221105.d.ts.map +1 -0
  163. package/dist/migrations/202009221105.js +4 -0
  164. package/dist/migrations/202009221105.js.map +1 -0
  165. package/dist/migrations/202009231331.d.ts +2 -0
  166. package/dist/migrations/202009231331.d.ts.map +1 -0
  167. package/{migrations → dist/migrations}/202009231331.js +2 -1
  168. package/dist/migrations/202009231331.js.map +1 -0
  169. package/dist/migrations/202009301531.d.ts +2 -0
  170. package/dist/migrations/202009301531.d.ts.map +1 -0
  171. package/dist/migrations/202009301531.js +8 -0
  172. package/dist/migrations/202009301531.js.map +1 -0
  173. package/dist/migrations/202010231444.d.ts +2 -0
  174. package/dist/migrations/202010231444.d.ts.map +1 -0
  175. package/dist/migrations/202010231444.js +4 -0
  176. package/dist/migrations/202010231444.js.map +1 -0
  177. package/dist/migrations/202010251412.d.ts +2 -0
  178. package/dist/migrations/202010251412.d.ts.map +1 -0
  179. package/dist/migrations/202010251412.js +10 -0
  180. package/dist/migrations/202010251412.js.map +1 -0
  181. package/dist/migrations/202011021749.d.ts +2 -0
  182. package/dist/migrations/202011021749.d.ts.map +1 -0
  183. package/{migrations → dist/migrations}/202011021749.js +2 -1
  184. package/dist/migrations/202011021749.js.map +1 -0
  185. package/dist/migrations/202011051353.d.ts +2 -0
  186. package/dist/migrations/202011051353.d.ts.map +1 -0
  187. package/{migrations → dist/migrations}/202011051353.js +2 -1
  188. package/dist/migrations/202011051353.js.map +1 -0
  189. package/dist/migrations/202011111127.d.ts +2 -0
  190. package/dist/migrations/202011111127.d.ts.map +1 -0
  191. package/{migrations → dist/migrations}/202011111127.js +2 -1
  192. package/dist/migrations/202011111127.js.map +1 -0
  193. package/dist/migrations/202012011203.d.ts +2 -0
  194. package/dist/migrations/202012011203.d.ts.map +1 -0
  195. package/{migrations → dist/migrations}/202012011203.js +2 -1
  196. package/dist/migrations/202012011203.js.map +1 -0
  197. package/dist/migrations/202012100841.d.ts +2 -0
  198. package/dist/migrations/202012100841.d.ts.map +1 -0
  199. package/{migrations → dist/migrations}/202012100841.js +2 -1
  200. package/dist/migrations/202012100841.js.map +1 -0
  201. package/dist/migrations/202012281835.d.ts +2 -0
  202. package/dist/migrations/202012281835.d.ts.map +1 -0
  203. package/{migrations → dist/migrations}/202012281835.js +2 -1
  204. package/dist/migrations/202012281835.js.map +1 -0
  205. package/dist/migrations/202101061051.d.ts +2 -0
  206. package/dist/migrations/202101061051.d.ts.map +1 -0
  207. package/{migrations → dist/migrations}/202101061051.js +2 -1
  208. package/dist/migrations/202101061051.js.map +1 -0
  209. package/dist/migrations/202101141128.d.ts +2 -0
  210. package/dist/migrations/202101141128.d.ts.map +1 -0
  211. package/dist/migrations/202101141128.js +4 -0
  212. package/dist/migrations/202101141128.js.map +1 -0
  213. package/dist/migrations/202102091312.d.ts +3 -0
  214. package/dist/migrations/202102091312.d.ts.map +1 -0
  215. package/dist/migrations/202102091312.js +19 -0
  216. package/dist/migrations/202102091312.js.map +1 -0
  217. package/dist/migrations/202102101624.d.ts +2 -0
  218. package/dist/migrations/202102101624.d.ts.map +1 -0
  219. package/dist/migrations/202102101624.js +7 -0
  220. package/dist/migrations/202102101624.js.map +1 -0
  221. package/dist/migrations/202102172148.d.ts +2 -0
  222. package/dist/migrations/202102172148.d.ts.map +1 -0
  223. package/{migrations → dist/migrations}/202102172148.js +2 -2
  224. package/dist/migrations/202102172148.js.map +1 -0
  225. package/dist/migrations/202102261650.d.ts +2 -0
  226. package/dist/migrations/202102261650.d.ts.map +1 -0
  227. package/dist/migrations/202102261650.js +7 -0
  228. package/dist/migrations/202102261650.js.map +1 -0
  229. package/dist/migrations/202106102347.d.ts +2 -0
  230. package/dist/migrations/202106102347.d.ts.map +1 -0
  231. package/{migrations → dist/migrations}/202106102347.js +2 -3
  232. package/dist/migrations/202106102347.js.map +1 -0
  233. package/dist/migrations/202106112120.d.ts +2 -0
  234. package/dist/migrations/202106112120.d.ts.map +1 -0
  235. package/{migrations → dist/migrations}/202106112120.js +2 -3
  236. package/dist/migrations/202106112120.js.map +1 -0
  237. package/dist/migrations/202106120012.d.ts +2 -0
  238. package/dist/migrations/202106120012.d.ts.map +1 -0
  239. package/{migrations → dist/migrations}/202106120012.js +2 -3
  240. package/dist/migrations/202106120012.js.map +1 -0
  241. package/dist/migrations/202106120220.d.ts +2 -0
  242. package/dist/migrations/202106120220.d.ts.map +1 -0
  243. package/{migrations → dist/migrations}/202106120220.js +2 -4
  244. package/dist/migrations/202106120220.js.map +1 -0
  245. package/dist/migrations/202106121701.d.ts +2 -0
  246. package/dist/migrations/202106121701.d.ts.map +1 -0
  247. package/{migrations → dist/migrations}/202106121701.js +2 -3
  248. package/dist/migrations/202106121701.js.map +1 -0
  249. package/dist/migrations/202106121703.d.ts +3 -0
  250. package/dist/migrations/202106121703.d.ts.map +1 -0
  251. package/{migrations → dist/migrations}/202106121703.js +2 -3
  252. package/dist/migrations/202106121703.js.map +1 -0
  253. package/dist/migrations/202106251126.d.ts +2 -0
  254. package/dist/migrations/202106251126.d.ts.map +1 -0
  255. package/dist/migrations/202106251126.js +6 -0
  256. package/dist/migrations/202106251126.js.map +1 -0
  257. package/dist/migrations/202107281619.d.ts +2 -0
  258. package/dist/migrations/202107281619.d.ts.map +1 -0
  259. package/{migrations → dist/migrations}/202107281619.js +2 -1
  260. package/dist/migrations/202107281619.js.map +1 -0
  261. package/dist/migrations/202107302158.d.ts +3 -0
  262. package/dist/migrations/202107302158.d.ts.map +1 -0
  263. package/{migrations → dist/migrations}/202107302158.js +2 -3
  264. package/dist/migrations/202107302158.js.map +1 -0
  265. package/dist/migrations/202108022257.d.ts +2 -0
  266. package/dist/migrations/202108022257.d.ts.map +1 -0
  267. package/{migrations → dist/migrations}/202108022257.js +3 -4
  268. package/dist/migrations/202108022257.js.map +1 -0
  269. package/dist/migrations/202109201624.d.ts +2 -0
  270. package/dist/migrations/202109201624.d.ts.map +1 -0
  271. package/{migrations → dist/migrations}/202109201624.js +2 -1
  272. package/dist/migrations/202109201624.js.map +1 -0
  273. package/dist/migrations/202109301031.d.ts +3 -0
  274. package/dist/migrations/202109301031.d.ts.map +1 -0
  275. package/{migrations → dist/migrations}/202109301031.js +2 -2
  276. package/dist/migrations/202109301031.js.map +1 -0
  277. package/dist/migrations/202111290253.d.ts +3 -0
  278. package/dist/migrations/202111290253.d.ts.map +1 -0
  279. package/dist/migrations/202111290253.js +5 -0
  280. package/dist/migrations/202111290253.js.map +1 -0
  281. package/dist/models/backup.d.ts +22 -0
  282. package/dist/models/backup.d.ts.map +1 -0
  283. package/{models → dist/models}/backup.js +95 -192
  284. package/dist/models/backup.js.map +1 -0
  285. package/dist/models/config.d.ts +180 -0
  286. package/dist/models/config.d.ts.map +1 -0
  287. package/dist/models/config.js +758 -0
  288. package/dist/models/config.js.map +1 -0
  289. package/dist/models/crash.d.ts +74 -0
  290. package/dist/models/crash.d.ts.map +1 -0
  291. package/dist/models/crash.js +118 -0
  292. package/dist/models/crash.js.map +1 -0
  293. package/dist/models/discovery.d.ts +28 -0
  294. package/dist/models/discovery.d.ts.map +1 -0
  295. package/dist/models/discovery.js +163 -0
  296. package/dist/models/discovery.js.map +1 -0
  297. package/dist/models/email.d.ts +16 -0
  298. package/dist/models/email.d.ts.map +1 -0
  299. package/dist/models/email.js +90 -0
  300. package/dist/models/email.js.map +1 -0
  301. package/dist/models/eventlog.d.ts +77 -0
  302. package/dist/models/eventlog.d.ts.map +1 -0
  303. package/dist/models/eventlog.js +132 -0
  304. package/dist/models/eventlog.js.map +1 -0
  305. package/dist/models/expression.d.ts +54 -0
  306. package/dist/models/expression.d.ts.map +1 -0
  307. package/dist/models/expression.js +274 -0
  308. package/dist/models/expression.js.map +1 -0
  309. package/dist/models/field.d.ts +217 -0
  310. package/dist/models/field.d.ts.map +1 -0
  311. package/dist/models/field.js +619 -0
  312. package/dist/models/field.js.map +1 -0
  313. package/dist/models/fieldrepeat.d.ts +49 -0
  314. package/dist/models/fieldrepeat.d.ts.map +1 -0
  315. package/dist/models/fieldrepeat.js +88 -0
  316. package/dist/models/fieldrepeat.js.map +1 -0
  317. package/dist/models/file.d.ts +122 -0
  318. package/dist/models/file.d.ts.map +1 -0
  319. package/dist/models/file.js +224 -0
  320. package/dist/models/file.js.map +1 -0
  321. package/dist/models/form.d.ts +82 -0
  322. package/dist/models/form.d.ts.map +1 -0
  323. package/dist/models/form.js +163 -0
  324. package/dist/models/form.js.map +1 -0
  325. package/dist/models/index.d.ts +1 -0
  326. package/dist/models/index.d.ts.map +1 -0
  327. package/{models → dist/models}/index.js +42 -42
  328. package/dist/models/index.js.map +1 -0
  329. package/dist/models/layout.d.ts +34 -0
  330. package/dist/models/layout.d.ts.map +1 -0
  331. package/dist/models/layout.js +153 -0
  332. package/dist/models/layout.js.map +1 -0
  333. package/dist/models/library.d.ts +50 -0
  334. package/dist/models/library.d.ts.map +1 -0
  335. package/dist/models/library.js +129 -0
  336. package/dist/models/library.js.map +1 -0
  337. package/dist/models/pack.d.ts +89 -0
  338. package/dist/models/pack.d.ts.map +1 -0
  339. package/dist/models/pack.js +390 -0
  340. package/dist/models/pack.js.map +1 -0
  341. package/dist/models/page.d.ts +101 -0
  342. package/dist/models/page.d.ts.map +1 -0
  343. package/dist/models/page.js +223 -0
  344. package/dist/models/page.js.map +1 -0
  345. package/dist/models/plugin.d.ts +100 -0
  346. package/dist/models/plugin.d.ts.map +1 -0
  347. package/dist/models/plugin.js +204 -0
  348. package/dist/models/plugin.js.map +1 -0
  349. package/dist/models/random.d.ts +24 -0
  350. package/dist/models/random.d.ts.map +1 -0
  351. package/dist/models/random.js +186 -0
  352. package/dist/models/random.js.map +1 -0
  353. package/dist/models/role.d.ts +42 -0
  354. package/dist/models/role.d.ts.map +1 -0
  355. package/dist/models/role.js +64 -0
  356. package/dist/models/role.js.map +1 -0
  357. package/dist/models/scheduler.d.ts +18 -0
  358. package/dist/models/scheduler.d.ts.map +1 -0
  359. package/dist/models/scheduler.js +159 -0
  360. package/dist/models/scheduler.js.map +1 -0
  361. package/dist/models/table.d.ts +326 -0
  362. package/dist/models/table.d.ts.map +1 -0
  363. package/dist/models/table.js +1006 -0
  364. package/dist/models/table.js.map +1 -0
  365. package/dist/models/table_constraints.d.ts +69 -0
  366. package/dist/models/table_constraints.d.ts.map +1 -0
  367. package/dist/models/table_constraints.js +118 -0
  368. package/dist/models/table_constraints.js.map +1 -0
  369. package/dist/models/tenant.d.ts +55 -0
  370. package/dist/models/tenant.d.ts.map +1 -0
  371. package/{models → dist/models}/tenant.js +40 -63
  372. package/dist/models/tenant.js.map +1 -0
  373. package/dist/models/trigger.d.ts +133 -0
  374. package/dist/models/trigger.d.ts.map +1 -0
  375. package/dist/models/trigger.js +292 -0
  376. package/dist/models/trigger.js.map +1 -0
  377. package/dist/models/user.d.ts +235 -0
  378. package/dist/models/user.d.ts.map +1 -0
  379. package/dist/models/user.js +434 -0
  380. package/dist/models/user.js.map +1 -0
  381. package/dist/models/view.d.ts +204 -0
  382. package/dist/models/view.d.ts.map +1 -0
  383. package/dist/models/view.js +497 -0
  384. package/dist/models/view.js.map +1 -0
  385. package/dist/models/workflow.d.ts +48 -0
  386. package/dist/models/workflow.d.ts.map +1 -0
  387. package/dist/models/workflow.js +190 -0
  388. package/dist/models/workflow.js.map +1 -0
  389. package/dist/plugin-helper.d.ts +145 -0
  390. package/dist/plugin-helper.d.ts.map +1 -0
  391. package/dist/plugin-helper.js +1158 -0
  392. package/dist/plugin-helper.js.map +1 -0
  393. package/dist/plugin-testing.d.ts +3 -0
  394. package/dist/plugin-testing.d.ts.map +1 -0
  395. package/dist/plugin-testing.js +120 -0
  396. package/dist/plugin-testing.js.map +1 -0
  397. package/dist/tests/actions.test.d.ts +2 -0
  398. package/dist/tests/actions.test.d.ts.map +1 -0
  399. package/dist/tests/actions.test.js +205 -0
  400. package/dist/tests/actions.test.js.map +1 -0
  401. package/dist/tests/auxtest.test.d.ts +2 -0
  402. package/dist/tests/auxtest.test.d.ts.map +1 -0
  403. package/dist/tests/auxtest.test.js +48 -0
  404. package/dist/tests/auxtest.test.js.map +1 -0
  405. package/dist/tests/backup.test.d.ts +2 -0
  406. package/dist/tests/backup.test.d.ts.map +1 -0
  407. package/dist/tests/backup.test.js +88 -0
  408. package/dist/tests/backup.test.js.map +1 -0
  409. package/dist/tests/calc.test.d.ts +2 -0
  410. package/dist/tests/calc.test.d.ts.map +1 -0
  411. package/dist/tests/calc.test.js +231 -0
  412. package/dist/tests/calc.test.js.map +1 -0
  413. package/dist/tests/config.test.d.ts +2 -0
  414. package/dist/tests/config.test.d.ts.map +1 -0
  415. package/dist/tests/config.test.js +83 -0
  416. package/dist/tests/config.test.js.map +1 -0
  417. package/dist/tests/discover.test.d.ts +2 -0
  418. package/dist/tests/discover.test.d.ts.map +1 -0
  419. package/dist/tests/discover.test.js +106 -0
  420. package/dist/tests/discover.test.js.map +1 -0
  421. package/dist/tests/exact_views.test.d.ts +2 -0
  422. package/dist/tests/exact_views.test.d.ts.map +1 -0
  423. package/dist/tests/exact_views.test.js +511 -0
  424. package/dist/tests/exact_views.test.js.map +1 -0
  425. package/dist/tests/field.test.d.ts +2 -0
  426. package/dist/tests/field.test.d.ts.map +1 -0
  427. package/dist/tests/field.test.js +237 -0
  428. package/dist/tests/field.test.js.map +1 -0
  429. package/dist/tests/form.test.d.ts +2 -0
  430. package/dist/tests/form.test.d.ts.map +1 -0
  431. package/dist/tests/form.test.js +191 -0
  432. package/dist/tests/form.test.js.map +1 -0
  433. package/dist/tests/mocks.d.ts +111 -0
  434. package/dist/tests/mocks.d.ts.map +1 -0
  435. package/dist/tests/mocks.js +165 -0
  436. package/dist/tests/mocks.js.map +1 -0
  437. package/dist/tests/models.test.d.ts +2 -0
  438. package/dist/tests/models.test.d.ts.map +1 -0
  439. package/dist/tests/models.test.js +210 -0
  440. package/dist/tests/models.test.js.map +1 -0
  441. package/dist/tests/pack.test.d.ts +2 -0
  442. package/dist/tests/pack.test.d.ts.map +1 -0
  443. package/dist/tests/pack.test.js +331 -0
  444. package/dist/tests/pack.test.js.map +1 -0
  445. package/dist/tests/plugin.test.d.ts +2 -0
  446. package/dist/tests/plugin.test.d.ts.map +1 -0
  447. package/dist/tests/plugin.test.js +53 -0
  448. package/dist/tests/plugin.test.js.map +1 -0
  449. package/dist/tests/random.test.d.ts +2 -0
  450. package/dist/tests/random.test.d.ts.map +1 -0
  451. package/dist/tests/random.test.js +138 -0
  452. package/dist/tests/random.test.js.map +1 -0
  453. package/dist/tests/table.test.d.ts +2 -0
  454. package/dist/tests/table.test.d.ts.map +1 -0
  455. package/dist/tests/table.test.js +1048 -0
  456. package/dist/tests/table.test.js.map +1 -0
  457. package/dist/tests/tenant.test.d.ts +2 -0
  458. package/dist/tests/tenant.test.d.ts.map +1 -0
  459. package/dist/tests/tenant.test.js +45 -0
  460. package/dist/tests/tenant.test.js.map +1 -0
  461. package/dist/tests/user.test.d.ts +2 -0
  462. package/dist/tests/user.test.d.ts.map +1 -0
  463. package/dist/tests/user.test.js +190 -0
  464. package/dist/tests/user.test.js.map +1 -0
  465. package/dist/tests/view.test.d.ts +2 -0
  466. package/dist/tests/view.test.d.ts.map +1 -0
  467. package/dist/tests/view.test.js +238 -0
  468. package/dist/tests/view.test.js.map +1 -0
  469. package/dist/tests/workflow.test.d.ts +2 -0
  470. package/dist/tests/workflow.test.d.ts.map +1 -0
  471. package/dist/tests/workflow.test.js +115 -0
  472. package/dist/tests/workflow.test.js.map +1 -0
  473. package/dist/tsconfig.ref.tsbuildinfo +1 -0
  474. package/dist/utils.d.ts +26 -0
  475. package/dist/utils.d.ts.map +1 -0
  476. package/dist/utils.js +124 -0
  477. package/dist/utils.js.map +1 -0
  478. package/package.json +34 -8
  479. package/base-plugin/actions.js +0 -629
  480. package/base-plugin/base.test.js +0 -15
  481. package/base-plugin/fieldviews.js +0 -197
  482. package/base-plugin/fileviews.js +0 -65
  483. package/base-plugin/types.js +0 -1154
  484. package/base-plugin/viewtemplates/edit.js +0 -672
  485. package/base-plugin/viewtemplates/feed.js +0 -434
  486. package/base-plugin/viewtemplates/filter.js +0 -358
  487. package/base-plugin/viewtemplates/list.js +0 -575
  488. package/base-plugin/viewtemplates/listshowlist.js +0 -292
  489. package/base-plugin/viewtemplates/room.js +0 -652
  490. package/base-plugin/viewtemplates/show.js +0 -689
  491. package/base-plugin/viewtemplates/viewable_fields.js +0 -714
  492. package/contracts.js +0 -311
  493. package/db/connect.js +0 -151
  494. package/db/db.test.js +0 -33
  495. package/db/fixtures.js +0 -303
  496. package/db/index.js +0 -63
  497. package/db/state.js +0 -674
  498. package/migrate.js +0 -99
  499. package/migrations/202008031500.js +0 -4
  500. package/migrations/202009181655.js +0 -6
  501. package/migrations/202009221105.js +0 -4
  502. package/migrations/202009301531.js +0 -7
  503. package/migrations/202010231444.js +0 -4
  504. package/migrations/202010251412.js +0 -9
  505. package/migrations/202101141128.js +0 -4
  506. package/migrations/202102091312.js +0 -19
  507. package/migrations/202102101624.js +0 -5
  508. package/migrations/202102261650.js +0 -6
  509. package/migrations/202106251126.js +0 -5
  510. package/models/config.js +0 -680
  511. package/models/crash.js +0 -126
  512. package/models/discovery.js +0 -195
  513. package/models/email.js +0 -92
  514. package/models/eventlog.js +0 -146
  515. package/models/expression.js +0 -276
  516. package/models/field.js +0 -746
  517. package/models/fieldrepeat.js +0 -96
  518. package/models/file.js +0 -234
  519. package/models/form.js +0 -169
  520. package/models/layout.js +0 -146
  521. package/models/library.js +0 -135
  522. package/models/pack.js +0 -466
  523. package/models/page.js +0 -255
  524. package/models/plugin.js +0 -219
  525. package/models/random.js +0 -206
  526. package/models/role.js +0 -94
  527. package/models/scheduler.js +0 -163
  528. package/models/table.js +0 -1211
  529. package/models/table_constraints.js +0 -133
  530. package/models/trigger.js +0 -327
  531. package/models/user.js +0 -503
  532. package/models/view.js +0 -622
  533. package/models/workflow.js +0 -205
  534. package/plugin-helper.js +0 -1311
  535. package/plugin-testing.js +0 -124
  536. package/tests/actions.test.js +0 -232
  537. package/tests/auxtest.test.js +0 -52
  538. package/tests/backup.test.js +0 -92
  539. package/tests/calc.test.js +0 -243
  540. package/tests/config.test.js +0 -91
  541. package/tests/discover.test.js +0 -114
  542. package/tests/exact_views.test.js +0 -526
  543. package/tests/field.test.js +0 -253
  544. package/tests/form.test.js +0 -198
  545. package/tests/mocks.js +0 -173
  546. package/tests/models.test.js +0 -221
  547. package/tests/pack.test.js +0 -350
  548. package/tests/plugin.test.js +0 -59
  549. package/tests/random.test.js +0 -154
  550. package/tests/table.test.js +0 -1091
  551. package/tests/tenant.test.js +0 -56
  552. package/tests/user.test.js +0 -196
  553. package/tests/view.test.js +0 -251
  554. package/tests/workflow.test.js +0 -119
  555. package/utils.js +0 -137
@@ -1,714 +0,0 @@
1
- /**
2
- * @category saltcorn-data
3
- * @module base-plugin/viewtemplates/viewable_fields
4
- * @subcategory base-plugin
5
- */
6
- const { post_btn, link } = require("@saltcorn/markup");
7
- const { text, a, i } = require("@saltcorn/markup/tags");
8
- const { getState } = require("../../db/state");
9
- const { contract, is } = require("contractis");
10
- const { is_column, is_tablely } = require("../../contracts");
11
- const { link_view, strictParseInt } = require("../../plugin-helper");
12
- const { get_expression_function } = require("../../models/expression");
13
- const Field = require("../../models/field");
14
- const Form = require("../../models/form");
15
- const { traverseSync } = require("../../models/layout");
16
- const { structuredClone } = require("../../utils");
17
- const db = require("../../db");
18
-
19
- /**
20
- * @function
21
- * @param {string} viewname
22
- * @param {Table|object} table
23
- * @param {string} action_name
24
- * @param {object} r
25
- * @param {string} colId missing in contract
26
- * @param {colIdNm} colIdNm missing in contract
27
- * @returns {any}
28
- */
29
- const action_url = contract(
30
- is.fun([is.str, is_tablely, is.str, is.obj()], is.any),
31
- (viewname, table, action_name, r, colId, colIdNm) => {
32
- if (action_name === "Delete")
33
- return `/delete/${table.name}/${r.id}?redirect=/view/${viewname}`;
34
- else if (action_name.startsWith("Toggle")) {
35
- const field_name = action_name.replace("Toggle ", "");
36
- return `/edit/toggle/${table.name}/${r.id}/${field_name}?redirect=/view/${viewname}`;
37
- }
38
- return {
39
- javascript: `view_post('${viewname}', 'run_action', {${colIdNm}:'${colId}', id:${r.id}});`,
40
- };
41
- }
42
- );
43
-
44
- /**
45
- * @param {string} url
46
- * @param {object} req
47
- * @param {object} opts
48
- * @param {string} opts.action_name
49
- * @param {string} opts.action_label
50
- * @param {*} opts.confirm
51
- * @param {*} opts.rndid
52
- * @param {string} opts.action_style
53
- * @param {number} opts.action_size
54
- * @param {*} opts.action_icon
55
- * @param {string} opts.action_bgcol
56
- * @param {string} opts.action_bordercol
57
- * @param {string} opts.action_textcol
58
- * @param {*} __
59
- * @returns {object}
60
- */
61
- const action_link = (
62
- url,
63
- req,
64
- {
65
- action_name,
66
- action_label,
67
- confirm,
68
- rndid,
69
- action_style,
70
- action_size,
71
- action_icon,
72
- action_bgcol,
73
- action_bordercol,
74
- action_textcol,
75
- },
76
- __ = (s) => s
77
- ) => {
78
- const label = __(action_label) || action_name;
79
- let style =
80
- action_style === "btn-custom-color"
81
- ? `background-color: ${action_bgcol || "#000000"};border-color: ${
82
- action_bordercol || "#000000"
83
- }; color: ${action_textcol || "#000000"}`
84
- : null;
85
- if (url.javascript)
86
- return a(
87
- {
88
- href: "javascript:" + url.javascript,
89
- class:
90
- action_style === "btn-link"
91
- ? ""
92
- : `btn ${action_style || "btn-primary"} ${action_size || ""}`,
93
- style,
94
- },
95
- action_icon ? i({ class: action_icon }) + " " : false,
96
- label
97
- );
98
- else
99
- return post_btn(url, label, req.csrfToken(), {
100
- confirm,
101
- req,
102
- icon: action_icon,
103
- style,
104
- btnClass: `${action_style || "btn-primary"} ${action_size || ""}`,
105
- });
106
- };
107
-
108
- /**
109
- * @function
110
- * @param {Field[]} fields
111
- * @returns {function}
112
- */
113
- const get_view_link_query = contract(
114
- is.fun(is.array(is.class("Field")), is.fun(is.obj(), is.str)),
115
- (fields) => {
116
- const fUniqueString = fields.find(
117
- (f) => f.is_unique && f.type.name === "String"
118
- );
119
- if (fUniqueString)
120
- return (r) =>
121
- `?${fUniqueString.name}=${encodeURIComponent(r[fUniqueString.name])}`;
122
- const fUnique = fields.find((f) => f.is_unique);
123
- if (fUnique)
124
- return (r) => `?${fUnique.name}=${encodeURIComponent(r[fUnique.name])}`;
125
- else {
126
- const pk_name = fields.find((f) => f.primary_key).name;
127
- return (r) => `?${pk_name}=${r[pk_name]}`;
128
- }
129
- }
130
- );
131
-
132
- /**
133
- * @function
134
- * @param {object} opts
135
- * @param {string} opts.link_text
136
- * @param {boolean} opts.link_text_formula missing in contract
137
- * @param {string} [opts.link_url]
138
- * @param {boolean} opts.link_url_formula
139
- * @param {boolean} opts.link_target_blank
140
- * @param {Field[]} fields
141
- * @returns {object}
142
- */
143
- const make_link = contract(
144
- is.fun(
145
- [is.obj({ link_text: is.str }), is.array(is.class("Field"))],
146
- is.obj({ key: is.fun(is.obj(), is.str), label: is.str })
147
- ),
148
- (
149
- {
150
- link_text,
151
- link_text_formula,
152
- link_url,
153
- link_url_formula,
154
- link_target_blank,
155
- },
156
- fields,
157
- __ = (s) => s
158
- ) => {
159
- return {
160
- label: "",
161
- key: (r) => {
162
- const txt = link_text_formula
163
- ? get_expression_function(link_text, fields)(r)
164
- : link_text;
165
- const href = link_url_formula
166
- ? get_expression_function(link_url, fields)(r)
167
- : link_url;
168
- const attrs = { href };
169
- if (link_target_blank) attrs.target = "_blank";
170
- return a(attrs, txt);
171
- },
172
- };
173
- }
174
- );
175
-
176
- /**
177
- * @param {string} s
178
- * @returns {object}
179
- */
180
- const parse_view_select = (s) => {
181
- const colonSplit = s.split(":");
182
- if (colonSplit.length === 1) return { type: "Own", viewname: s };
183
- const [type, vrest] = colonSplit;
184
- switch (type) {
185
- case "Own":
186
- return { type, viewname: vrest };
187
- case "ChildList":
188
- case "OneToOneShow":
189
- const [viewnm, tbl, fld] = vrest.split(".");
190
- return { type, viewname: viewnm, table_name: tbl, field_name: fld };
191
- case "ParentShow":
192
- const [pviewnm, ptbl, pfld] = vrest.split(".");
193
- return { type, viewname: pviewnm, table_name: ptbl, field_name: pfld };
194
- case "Independent":
195
- return { type, viewname: vrest };
196
- }
197
- };
198
-
199
- //todo: use above to simplify code
200
- /**
201
- * @function
202
- * @param {object} opts
203
- * @param {string} opts.view,
204
- * @param {object} opts.view_label missing in contract
205
- * @param {object} opts.in_modal
206
- * @param {object} opts.view_label_formula
207
- * @param {string} [opts.link_style = ""]
208
- * @param {string} [opts.link_size = ""]
209
- * @param {string} [opts.link_icon = ""]
210
- * @param {string} [opts.textStyle = ""]
211
- * @param {string} [opts.link_bgcol]
212
- * @param {string} [opts.link_bordercol]
213
- * @param {string} [opts.link_textcol]
214
- * @param {Field[]} fields
215
- * @returns {object}
216
- */
217
- const view_linker = contract(
218
- is.fun(
219
- [is.obj({ view: is.str }), is.array(is.class("Field"))],
220
- is.obj({ key: is.fun(is.obj(), is.str), label: is.str })
221
- ),
222
- (
223
- {
224
- view,
225
- view_label,
226
- in_modal,
227
- view_label_formula,
228
- link_style = "",
229
- link_size = "",
230
- link_icon = "",
231
- textStyle = "",
232
- link_bgcol,
233
- link_bordercol,
234
- link_textcol,
235
- },
236
- fields,
237
- __ = (s) => s
238
- ) => {
239
- const get_label = (def, row) => {
240
- if (!view_label || view_label.length === 0) return def;
241
- if (!view_label_formula) return view_label;
242
- const f = get_expression_function(view_label, fields);
243
- return f(row);
244
- };
245
- const [vtype, vrest] = view.split(":");
246
- switch (vtype) {
247
- case "Own":
248
- const vnm = vrest;
249
- const get_query = get_view_link_query(fields);
250
- return {
251
- label: vnm,
252
- key: (r) =>
253
- link_view(
254
- `/view/${encodeURIComponent(vnm)}${get_query(r)}`,
255
- get_label(vnm, r),
256
- in_modal,
257
- link_style,
258
- link_size,
259
- link_icon,
260
- textStyle,
261
- link_bgcol,
262
- link_bordercol,
263
- link_textcol
264
- ),
265
- };
266
- case "Independent":
267
- const ivnm = vrest;
268
- return {
269
- label: ivnm,
270
- key: (r) =>
271
- link_view(
272
- `/view/${encodeURIComponent(ivnm)}`,
273
- get_label(ivnm, r),
274
- in_modal,
275
- link_style,
276
- link_size,
277
- link_icon,
278
- textStyle,
279
- link_bgcol,
280
- link_bordercol,
281
- link_textcol
282
- ),
283
- };
284
- case "ChildList":
285
- case "OneToOneShow":
286
- const [viewnm, tbl, fld] = vrest.split(".");
287
- return {
288
- label: viewnm,
289
- key: (r) =>
290
- link_view(
291
- `/view/${encodeURIComponent(viewnm)}?${fld}=${r.id}`,
292
- get_label(viewnm, r),
293
- in_modal,
294
- link_style,
295
- link_size,
296
- link_icon,
297
- textStyle,
298
- link_bgcol,
299
- link_bordercol,
300
- link_textcol
301
- ),
302
- };
303
- case "ParentShow":
304
- const [pviewnm, ptbl, pfld] = vrest.split(".");
305
- //console.log([pviewnm, ptbl, pfld])
306
- return {
307
- label: pviewnm,
308
- key: (r) => {
309
- const reffield = fields.find((f) => f.name === pfld);
310
- const summary_field = r[`summary_field_${ptbl.toLowerCase()}`];
311
- return r[pfld]
312
- ? link_view(
313
- `/view/${encodeURIComponent(pviewnm)}?${reffield.refname}=${
314
- r[pfld]
315
- }`,
316
- get_label(
317
- typeof summary_field === "undefined"
318
- ? pviewnm
319
- : summary_field,
320
- r
321
- ),
322
- in_modal,
323
- link_style,
324
- link_size,
325
- link_icon,
326
- textStyle,
327
- link_bgcol,
328
- link_bordercol,
329
- link_textcol
330
- )
331
- : "";
332
- },
333
- };
334
- default:
335
- throw new Error(view);
336
- }
337
- }
338
- );
339
-
340
- /**
341
- * @param {string} nm
342
- * @returns {boolean}
343
- */
344
- const action_requires_write = (nm) => {
345
- if (!nm) return false;
346
- if (nm === "Delete") return true;
347
- if (nm.startsWith("Toggle")) return true;
348
- };
349
-
350
- /**
351
- * @function
352
- * @param {string} viewname
353
- * @param {Table|object} table
354
- * @param {Fields[]} fields
355
- * @param {object[]} columns
356
- * @param {boolean} isShow
357
- * @param {object} req
358
- * @param {*} __
359
- * @returns {object[]}
360
- */
361
- const get_viewable_fields = contract(
362
- is.fun(
363
- [
364
- is.str,
365
- is_tablely,
366
- is.array(is.class("Field")),
367
- is.array(is_column),
368
- is.bool,
369
- is.obj({ csrfToken: is.fun([], is.str) }),
370
- ],
371
-
372
- is.array(
373
- is.obj({
374
- key: is.or(is.fun(is.obj(), is.str), is.str, is.undefined),
375
- label: is.str,
376
- })
377
- )
378
- ),
379
- (viewname, table, fields, columns, isShow, req, __) =>
380
- columns
381
- .map((column) => {
382
- const role = req.user ? req.user.role_id : 10;
383
- const user_id = req.user ? req.user.id : null;
384
- const setWidth = column.col_width
385
- ? { width: `${column.col_width}${column.col_width_units}` }
386
- : {};
387
- if (column.type === "Action")
388
- return {
389
- ...setWidth,
390
- label: column.header_label ? text(__(column.header_label)) : "",
391
- key: (r) => {
392
- if (action_requires_write(column.action_name)) {
393
- if (table.min_role_write < role && !table.is_owner(req.user, r))
394
- return "";
395
- }
396
- const url = action_url(
397
- viewname,
398
- table,
399
- column.action_name,
400
- r,
401
- column.action_name,
402
- "action_name"
403
- );
404
- const label = column.action_label_formula
405
- ? get_expression_function(column.action_label, fields)(r)
406
- : __(column.action_label) || column.action_name;
407
- if (url.javascript)
408
- return a(
409
- {
410
- href: "javascript:" + url.javascript,
411
- class:
412
- column.action_style === "btn-link"
413
- ? ""
414
- : `btn ${column.action_style || "btn-primary"} ${
415
- column.action_size || ""
416
- }`,
417
- },
418
- label
419
- );
420
- else
421
- return post_btn(url, label, req.csrfToken(), {
422
- small: true,
423
- ajax: true,
424
- reload_on_done: true,
425
- confirm: column.confirm,
426
- btnClass: column.action_style || "btn-primary",
427
- req,
428
- });
429
- },
430
- };
431
- else if (column.type === "ViewLink") {
432
- if (!column.view) return;
433
- const r = view_linker(column, fields, __);
434
- if (column.header_label) r.label = text(__(column.header_label));
435
- Object.assign(r, setWidth);
436
- return r;
437
- } else if (column.type === "Link") {
438
- const r = make_link(column, fields, __);
439
- if (column.header_label) r.label = text(__(column.header_label));
440
- Object.assign(r, setWidth);
441
- return r;
442
- } else if (column.type === "JoinField") {
443
- const keypath = column.join_field.split(".");
444
- let refNm, targetNm, through, key;
445
- if (keypath.length === 2) {
446
- [refNm, targetNm] = keypath;
447
- key = `${refNm}_${targetNm}`;
448
- } else {
449
- [refNm, through, targetNm] = keypath;
450
- key = `${refNm}_${through}_${targetNm}`;
451
- }
452
-
453
- return {
454
- ...setWidth,
455
- label: column.header_label
456
- ? text(__(column.header_label))
457
- : text(targetNm),
458
- key,
459
- // sortlink: `javascript:sortby('${text(targetNm)}')`
460
- };
461
- } else if (column.type === "Aggregation") {
462
- //console.log(column)
463
- const [table, fld] = column.agg_relation.split(".");
464
- const targetNm = (
465
- column.stat.replace(" ", "") +
466
- "_" +
467
- table +
468
- "_" +
469
- fld +
470
- db.sqlsanitize(column.aggwhere || "")
471
- ).toLowerCase();
472
-
473
- return {
474
- ...setWidth,
475
- label: column.header_label
476
- ? text(column.header_label)
477
- : text(column.stat + " " + table),
478
- key: text(targetNm),
479
- // sortlink: `javascript:sortby('${text(targetNm)}')`
480
- };
481
- } else if (column.type === "Field") {
482
- let f = fields.find((fld) => fld.name === column.field_name);
483
- let f_with_val = f;
484
- if (f && f.attributes && f.attributes.localized_by) {
485
- const locale = req.getLocale();
486
- const localized_fld_nm = f.attributes.localized_by[locale];
487
- f_with_val =
488
- fields.find((fld) => fld.name === localized_fld_nm) || f;
489
- }
490
- const isNum = f && f.type && f.type.name === "Integer";
491
- return (
492
- f && {
493
- ...setWidth,
494
- align: isNum ? "right" : undefined,
495
- label: headerLabelForName(column, f, req, __),
496
- key:
497
- column.fieldview && f.type === "File"
498
- ? (row) =>
499
- row[f.name] &&
500
- getState().fileviews[column.fieldview].run(
501
- row[f.name],
502
- row[`${f.name}__filename`]
503
- )
504
- : column.fieldview &&
505
- f.type.fieldviews &&
506
- f.type.fieldviews[column.fieldview]
507
- ? (row) =>
508
- f.type.fieldviews[column.fieldview].run(
509
- row[f_with_val.name],
510
- req,
511
- column.configuration
512
- )
513
- : isShow
514
- ? f.type.showAs
515
- ? (row) => f.type.showAs(row[f_with_val.name])
516
- : (row) => text(row[f_with_val.name])
517
- : f.listKey,
518
- sortlink:
519
- !f.calculated || f.stored
520
- ? sortlinkForName(f.name, req)
521
- : undefined,
522
- }
523
- );
524
- }
525
- })
526
- .filter((v) => !!v)
527
- );
528
-
529
- /**
530
- * @param {string} fname
531
- * @param {object} req
532
- * @returns {string}
533
- */
534
- const sortlinkForName = (fname, req) => {
535
- const { _sortby, _sortdesc } = req.query || {};
536
- const desc =
537
- typeof _sortdesc == "undefined"
538
- ? _sortby === fname
539
- : _sortdesc
540
- ? "false"
541
- : "true";
542
- return `javascript:sortby('${text(fname)}', ${desc})`;
543
- };
544
-
545
- /**
546
- * @param {object} column
547
- * @param {object} f
548
- * @param {object} req
549
- * @param {*} __
550
- * @returns {string}
551
- */
552
- const headerLabelForName = (column, f, req, __) => {
553
- const label = column.header_label
554
- ? text(__(column.header_label))
555
- : text(f.label);
556
- const { _sortby, _sortdesc } = req.query || {};
557
- let arrow =
558
- _sortby !== f.name
559
- ? ""
560
- : _sortdesc
561
- ? i({ class: "fas fa-caret-down" })
562
- : i({ class: "fas fa-caret-up" });
563
- return label + arrow;
564
- };
565
-
566
- /**
567
- * @function
568
- * @param {Field[]} fields
569
- * @param {object} state
570
- * @param {boolean} [fuzzyStrings]
571
- * @returns {object}
572
- */
573
- const splitUniques = contract(
574
- is.fun(
575
- [is.array(is.class("Field")), is.obj(), is.maybe(is.bool)],
576
- is.obj({ uniques: is.obj(), nonUniques: is.obj() })
577
- ),
578
- (fields, state, fuzzyStrings) => {
579
- var uniques = [];
580
- var nonUniques = [];
581
- Object.entries(state).forEach(([k, v]) => {
582
- const field = fields.find((f) => f.name === k);
583
- if (
584
- field &&
585
- field.is_unique &&
586
- fuzzyStrings &&
587
- field.type &&
588
- field.type.name === "String"
589
- )
590
- uniques[k] = { ilike: v };
591
- else if (field && field.is_unique)
592
- uniques[k] = field.type.read ? field.type.read(v) : v;
593
- else nonUniques[k] = v;
594
- });
595
- return { uniques, nonUniques };
596
- }
597
- );
598
-
599
- /**
600
- * @param {object} table
601
- * @param {string} viewname
602
- * @param {object[]} [columns]
603
- * @param {object} layout0
604
- * @param {boolean} id
605
- * @param {object} req
606
- * @returns {Promise<Form>}
607
- */
608
- const getForm = async (table, viewname, columns, layout0, id, req) => {
609
- const fields = await table.getFields();
610
-
611
- const tfields = (columns || [])
612
- .map((column) => {
613
- if (column.type === "Field") {
614
- const f = fields.find((fld) => fld.name === column.field_name);
615
- if (f) {
616
- f.fieldview = column.fieldview;
617
- if (f.type === "Key") {
618
- if (getState().keyFieldviews[column.fieldview])
619
- f.fieldviewObj = getState().keyFieldviews[column.fieldview];
620
- f.input_type =
621
- !f.fieldview ||
622
- !f.fieldviewObj ||
623
- (f.fieldview === "select" && !f.fieldviewObj)
624
- ? "select"
625
- : "fromtype";
626
- }
627
- if (f.calculated)
628
- f.sourceURL = `/field/show-calculated/${table.name}/${f.name}/${f.fieldview}`;
629
- f.attributes = { ...column.configuration, ...f.attributes };
630
- return f;
631
- } else if (table.name === "users" && column.field_name === "password") {
632
- return new Field({
633
- name: "password",
634
- fieldview: column.fieldview,
635
- type: "String",
636
- });
637
- } else if (
638
- table.name === "users" &&
639
- column.field_name === "passwordRepeat"
640
- ) {
641
- return new Field({
642
- name: "passwordRepeat",
643
- fieldview: column.fieldview,
644
- type: "String",
645
- });
646
- } else if (table.name === "users" && column.field_name === "remember") {
647
- return new Field({
648
- name: "remember",
649
- fieldview: column.fieldview,
650
- type: "Bool",
651
- });
652
- }
653
- }
654
- })
655
- .filter((tf) => !!tf);
656
- const path = req.baseUrl + req.path;
657
- let action = `/view/${viewname}`;
658
- if (path && path.startsWith("/auth/")) action = path;
659
- const layout = structuredClone(layout0);
660
- traverseSync(layout, {
661
- container(segment) {
662
- if (segment.showIfFormula) {
663
- segment.showIfFormulaInputs = segment.showIfFormula;
664
- }
665
- },
666
- });
667
- const form = new Form({
668
- action,
669
- fields: tfields,
670
- layout,
671
- });
672
- if (id) form.hidden("id");
673
- return form;
674
- };
675
-
676
- /**
677
- * @param {object} table
678
- * @param {object} req
679
- * @param {object} fixed
680
- * @returns {Promise<object>}
681
- */
682
- const fill_presets = async (table, req, fixed) => {
683
- const fields = await table.getFields();
684
- Object.keys(fixed || {}).forEach((k) => {
685
- if (k.startsWith("preset_")) {
686
- if (fixed[k]) {
687
- const fldnm = k.replace("preset_", "");
688
- const fld = fields.find((f) => f.name === fldnm);
689
- if (fld) {
690
- if (table.name === "users" && fld.primary_key)
691
- fixed[fldnm] = req.user ? req.user.id : null;
692
- else fixed[fldnm] = fld.presets[fixed[k]]({ user: req.user, req });
693
- }
694
- }
695
- delete fixed[k];
696
- } else {
697
- const fld = fields.find((f) => f.name === k);
698
- if (!fld) delete fixed[k];
699
- }
700
- });
701
- return fixed;
702
- };
703
-
704
- module.exports = {
705
- get_viewable_fields,
706
- action_url,
707
- action_link,
708
- view_linker,
709
- parse_view_select,
710
- splitUniques,
711
- getForm,
712
- fill_presets,
713
- get_view_link_query,
714
- };