@saltcorn/data 0.6.1 → 0.6.2-beta.3

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 +37 -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 -192
  482. package/base-plugin/fileviews.js +0 -65
  483. package/base-plugin/types.js +0 -1025
  484. package/base-plugin/viewtemplates/edit.js +0 -665
  485. package/base-plugin/viewtemplates/feed.js +0 -434
  486. package/base-plugin/viewtemplates/filter.js +0 -311
  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 -650
  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 -60
  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 -264
  516. package/models/field.js +0 -740
  517. package/models/fieldrepeat.js +0 -96
  518. package/models/file.js +0 -234
  519. package/models/form.js +0 -168
  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 -1291
  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 -221
  540. package/tests/config.test.js +0 -91
  541. package/tests/discover.test.js +0 -114
  542. package/tests/exact_views.test.js +0 -526
  543. package/tests/field.test.js +0 -253
  544. package/tests/form.test.js +0 -198
  545. package/tests/mocks.js +0 -173
  546. package/tests/models.test.js +0 -221
  547. package/tests/pack.test.js +0 -350
  548. package/tests/plugin.test.js +0 -59
  549. package/tests/random.test.js +0 -154
  550. package/tests/table.test.js +0 -1091
  551. package/tests/tenant.test.js +0 -56
  552. package/tests/user.test.js +0 -196
  553. package/tests/view.test.js +0 -251
  554. package/tests/workflow.test.js +0 -119
  555. package/utils.js +0 -137
package/models/field.js DELETED
@@ -1,740 +0,0 @@
1
- /**
2
- * Field Data Access Layer
3
- * @category saltcorn-data
4
- * @module models/field
5
- * @subcategory models
6
- */
7
-
8
- const db = require("../db");
9
- const { contract, is } = require("contractis");
10
- const { recalculate_for_stored } = require("./expression");
11
- const { sqlsanitize } = require("@saltcorn/db-common/internal.js");
12
- const { InvalidAdminAction } = require("../utils");
13
- const { mkWhere } = require("../db");
14
-
15
- const readKey = (v, field) => {
16
- if (v === "") return null;
17
- if (typeof v === "string" && v.startsWith("Preset:")) return v;
18
- const { getState } = require("../db/state");
19
-
20
- const type = getState().types[field.reftype];
21
- const parsed = type.read(v);
22
- return parsed || (v ? { error: "Unable to read key" } : null);
23
- };
24
-
25
- /**
26
- * Field Class
27
- * @category saltcorn-data
28
- */
29
- class Field {
30
- /**
31
- * Constructor
32
- * @param o
33
- */
34
- constructor(o) {
35
- if (!o.type && !o.input_type)
36
- throw new Error(`Field ${o.name} initialised with no type`);
37
- this.label = o.label || o.name;
38
- this.name = o.name || Field.labelToName(o.label);
39
- this.fieldview = o.fieldview;
40
- this.validator = o.validator || (() => true);
41
- this.showIf = o.showIf;
42
- this.parent_field = o.parent_field;
43
- this.postText = o.postText;
44
- this.class = o.class || "";
45
- this.id = o.id;
46
- this.default = o.default;
47
- this.sublabel = o.sublabel;
48
- this.description = o.description;
49
- const { getState } = require("../db/state");
50
-
51
- this.type = typeof o.type === "string" ? getState().types[o.type] : o.type;
52
- if (!this.type) this.typename = o.type;
53
- this.options = o.options;
54
- this.required = o.required ? true : false;
55
- this.is_unique = o.is_unique ? true : false;
56
- this.hidden = o.hidden || false;
57
- this.disabled = !!o.disabled;
58
- this.calculated = !!o.calculated;
59
- this.primary_key = !!o.primary_key;
60
- this.stored = !!o.stored;
61
- this.expression = o.expression;
62
- this.sourceURL = o.sourceURL;
63
-
64
- this.is_fkey =
65
- o.type === "Key" ||
66
- o.type === "File" ||
67
- (typeof o.type === "string" && o.type.startsWith("Key to"));
68
-
69
- if (!this.is_fkey) {
70
- this.input_type = o.input_type || "fromtype";
71
- } else if (o.type === "File") {
72
- this.type = "File";
73
- this.input_type = "file";
74
- this.reftable_name = "_sc_files";
75
- this.reftype = "Integer";
76
- this.refname = "id";
77
- } else {
78
- this.reftable_name =
79
- o.reftable_name ||
80
- (o.reftable && o.reftable.name) ||
81
- o.type.replace("Key to ", "");
82
- this.reftable = o.reftable;
83
- this.type = "Key";
84
- this.input_type =
85
- !this.fieldview || this.fieldview === "select" ? "select" : "fromtype";
86
- this.reftype = o.reftype || "Integer";
87
- this.refname = o.refname || "id";
88
- }
89
-
90
- this.attributes =
91
- typeof o.attributes === "string"
92
- ? JSON.parse(o.attributes)
93
- : o.attributes || {};
94
- if (o.table_id) this.table_id = o.table_id;
95
-
96
- if (o.table) {
97
- this.table = o.table;
98
- if (o.table.id && !o.table_id) this.table_id = o.table.id;
99
- }
100
- contract.class(this);
101
- }
102
-
103
- /**
104
- * To Json
105
- * @type {object}
106
- */
107
- get toJson() {
108
- return {
109
- id: this.id,
110
- table_id: this.table_id,
111
- name: this.name,
112
- label: this.label,
113
- is_unique: this.is_unique,
114
- calculated: this.calculated,
115
- stored: this.stored,
116
- expression: this.expression,
117
- sublabel: this.sublabel,
118
- fieldview: this.fieldview,
119
- type: typeof this.type === "string" ? this.type : this.type.name,
120
- reftable_name: this.reftable_name,
121
- attributes: this.attributes,
122
- required: this.required,
123
- primary_key: this.primary_key,
124
- reftype: this.reftype,
125
- refname: this.refname,
126
- description: this.description, //
127
- };
128
- }
129
-
130
- /**
131
- * Label 2 Name
132
- * @param {string} label
133
- * @returns {string}
134
- */
135
- // todo from internalization point of view better to separate label, name. sqlname
136
- // because label can contain characters that cannot be used in PG for sql names
137
- static labelToName(label) {
138
- return sqlsanitize(label.toLowerCase().replace(" ", "_"));
139
- }
140
-
141
- /**
142
- * ???
143
- * @returns {string}
144
- */
145
- get form_name() {
146
- if (this.parent_field) return `${this.parent_field}_${this.name}`;
147
- else return this.name;
148
- }
149
-
150
- /**
151
- * Fill fkey options???
152
- * @param {boolean} [force_allow_none = false]
153
- * @param {object} where
154
- * @returns {Promise<void>}
155
- */
156
- async fill_fkey_options(force_allow_none = false, where) {
157
- if (
158
- this.is_fkey &&
159
- (this.type !== "File" ||
160
- typeof this.attributes.select_file_where !== "undefined")
161
- ) {
162
- const rows = await db.select(
163
- this.reftable_name,
164
- this.type === "File" ? this.attributes.select_file_where : where
165
- );
166
-
167
- const summary_field =
168
- this.attributes.summary_field ||
169
- (this.type === "File" ? "filename" : "id");
170
- const dbOpts = rows.map((r) => ({
171
- label: r[summary_field],
172
- value: r[this.refname],
173
- }));
174
- const allOpts =
175
- !this.required || force_allow_none
176
- ? [{ label: "", value: "" }, ...dbOpts]
177
- : dbOpts;
178
- this.options = [...new Set(allOpts)];
179
- }
180
- }
181
-
182
- /**
183
- * Distinct Values
184
- * @param {object} [req]
185
- * @returns {Promise<void>}
186
- */
187
- async distinct_values(req, where) {
188
- const __ = req && req.__ ? req.__ : (s) => s;
189
- if (
190
- this.type.name === "String" &&
191
- this.attributes &&
192
- this.attributes.options
193
- ) {
194
- return [
195
- { label: "", value: "" },
196
- ...this.attributes.options
197
- .split(",")
198
- .map((o) => ({ label: o.trim(), value: o.trim() })),
199
- ];
200
- }
201
- if (this.is_fkey) {
202
- await this.fill_fkey_options(false, where);
203
- return this.options || [];
204
- }
205
- if (this.type.name === "Bool") {
206
- return [
207
- { label: "", value: "" },
208
- { label: __("True"), value: "on", jsvalue: true },
209
- { label: __("False"), value: "off", jsvalue: false },
210
- ];
211
- }
212
- await this.fill_table();
213
- let whereS = "";
214
- let values = [];
215
- if (where) {
216
- const whereValues = mkWhere(where);
217
- whereS = whereValues.where;
218
- values = whereValues.values;
219
- }
220
- const { rows } = await db.query(
221
- `select distinct "${db.sqlsanitize(this.name)}" from ${
222
- this.table.sql_name
223
- } ${whereS} order by "${db.sqlsanitize(this.name)}"`,
224
- values
225
- );
226
- const dbOpts = rows.map((r) => ({
227
- label: `${r[this.name]}`,
228
- value: r[this.name],
229
- }));
230
- return [{ label: "", value: "" }, ...dbOpts];
231
- }
232
-
233
- /**
234
- * @type {string}
235
- */
236
- get sql_type() {
237
- if (this.is_fkey) {
238
- const schema = db.getTenantSchemaPrefix();
239
- const { getState } = require("../db/state");
240
-
241
- return `${
242
- getState().types[this.reftype].sql_name
243
- } references ${schema}"${sqlsanitize(this.reftable_name)}" ("${
244
- this.refname
245
- }")`;
246
- } else {
247
- return this.type.sql_name;
248
- }
249
- }
250
-
251
- /**
252
- * @type {string}
253
- */
254
- get pretty_type() {
255
- if (this.reftable_name === "_sc_files") return "File";
256
- if (this.is_fkey) return `Key to ${this.reftable_name}`;
257
- else return this.type ? this.type.name : "?";
258
- }
259
-
260
- /**
261
- * @type {string}
262
- */
263
- get sql_bare_type() {
264
- if (this.is_fkey) {
265
- const { getState } = require("../db/state");
266
-
267
- return getState().types[this.reftype].sql_name;
268
- } else {
269
- return this.type.sql_name;
270
- }
271
- }
272
-
273
- /**
274
- * @returns {Promise<any>}
275
- */
276
- async generate() {
277
- if (this.is_fkey) {
278
- const rows = await db.select(
279
- this.reftable_name,
280
- {},
281
- { limit: 1, orderBy: "RANDOM()" }
282
- );
283
- if (rows.length === 1) return rows[0].id;
284
- } else {
285
- if (this.type && this.type.contract)
286
- return this.type.contract(this.attributes).generate();
287
- }
288
- }
289
-
290
- /**
291
- * @param {object} whole_rec
292
- * @returns {object}
293
- */
294
- validate(whole_rec) {
295
- const type = this.is_fkey ? { name: "Key" } : this.type;
296
- const readval = this.is_fkey
297
- ? readKey(whole_rec[this.form_name], this)
298
- : !type || !type.read
299
- ? whole_rec[this.form_name]
300
- : type.readFromFormRecord
301
- ? type.readFromFormRecord(whole_rec, this.form_name)
302
- : type.read(whole_rec[this.form_name], this.attributes);
303
- if (typeof readval === "undefined" || readval === null)
304
- if (this.required && this.type !== "File")
305
- return { error: "Unable to read " + type.name };
306
- else return { success: null };
307
- const tyvalres =
308
- type && type.validate
309
- ? type.validate(this.attributes || {})(readval)
310
- : readval;
311
- if (tyvalres.error) return tyvalres;
312
- const fvalres = this.validator(readval);
313
- if (typeof fvalres === "string") return { error: fvalres };
314
- if (typeof fvalres === "undefined" || fvalres) return { success: readval };
315
- else return { error: "Not accepted" };
316
- }
317
-
318
- /**
319
- *
320
- * @param {object} where
321
- * @param {object} [selectopts]
322
- * @returns {Field[]}
323
- */
324
- static async find(where, selectopts = { orderBy: "name", nocase: true }) {
325
- const db_flds = await db.select("_sc_fields", where, selectopts);
326
- return db_flds.map((dbf) => new Field(dbf));
327
- }
328
-
329
- /**
330
- * @param {object} where
331
- * @returns {Promise<Field>}
332
- */
333
- static async findOne(where) {
334
- const db_fld = await db.selectOne("_sc_fields", where);
335
- return new Field(db_fld);
336
- }
337
-
338
- /**
339
- * @returns {Promise<void>}
340
- */
341
- async add_unique_constraint() {
342
- await this.fill_table();
343
- await db.add_unique_constraint(this.table.name, [this.name]);
344
- }
345
-
346
- /**
347
- * @returns {Promise<void>}
348
- */
349
- async remove_unique_constraint() {
350
- await this.fill_table();
351
- await db.drop_unique_constraint(this.table.name, [this.name]);
352
- }
353
-
354
- /**
355
- *
356
- * @param {boolean} not_null
357
- * @returns {Promise<void>}
358
- */
359
- async toggle_not_null(not_null) {
360
- const schema = db.getTenantSchemaPrefix();
361
- await this.fill_table();
362
- await db.query(
363
- `alter table ${schema}"${sqlsanitize(
364
- this.table.name
365
- )}" alter column "${sqlsanitize(this.name)}" ${
366
- not_null ? "set" : "drop"
367
- } not null;`
368
- );
369
- await require("../db/state").getState().refresh_tables();
370
- }
371
-
372
- /**
373
- * @param {object} new_field
374
- * @returns {Promise<void>}
375
- */
376
- async alter_sql_type(new_field) {
377
- let new_sql_type = new_field.sql_type;
378
- let def = "";
379
- let using = `USING ("${sqlsanitize(this.name)}"::${new_sql_type})`;
380
-
381
- const schema = db.getTenantSchemaPrefix();
382
- await this.fill_table();
383
- if (new_field.primary_key) {
384
- await db.query(
385
- `ALTER TABLE ${schema}"${sqlsanitize(
386
- this.table.name
387
- )}" drop column "${sqlsanitize(this.name)}";`
388
- );
389
-
390
- if (new_field.type.primaryKey.sql_type)
391
- new_sql_type = new_field.type.primaryKey.sql_type;
392
- if (new_field.type.primaryKey.default_sql) {
393
- def = `default ${new_field.type.primaryKey.default_sql}`;
394
- }
395
- await db.query(
396
- `ALTER TABLE ${schema}"${sqlsanitize(
397
- this.table.name
398
- )}" add column "${sqlsanitize(
399
- this.name
400
- )}" ${new_sql_type} primary key ${def};`
401
- );
402
- } else
403
- await db.query(
404
- `alter table ${schema}"${sqlsanitize(
405
- this.table.name
406
- )}" alter column "${sqlsanitize(
407
- this.name
408
- )}" TYPE ${new_sql_type} ${using} ${def};`
409
- );
410
- await require("../db/state").getState().refresh_tables();
411
- }
412
-
413
- /**
414
- * @returns {Promise<void>}
415
- */
416
- async fill_table() {
417
- if (!this.table) {
418
- const Table = require("./table");
419
- this.table = await Table.findOne({ id: this.table_id });
420
- }
421
- }
422
-
423
- /**
424
- * @param {object} v
425
- * @returns {Promise<void>}
426
- */
427
- async update(v) {
428
- if (
429
- typeof v.is_unique !== "undefined" &&
430
- !!v.is_unique !== !!this.is_unique
431
- ) {
432
- if (v.is_unique && !this.is_unique) await this.add_unique_constraint();
433
- if (!v.is_unique && this.is_unique) await this.remove_unique_constraint();
434
- await db.update("_sc_fields", { is_unique: v.is_unique }, this.id);
435
- }
436
-
437
- if (typeof v.required !== "undefined" && !!v.required !== !!this.required)
438
- await this.toggle_not_null(!!v.required);
439
-
440
- const f = new Field({ ...this, ...v });
441
- if (f.sql_type !== this.sql_type) {
442
- await this.alter_sql_type(f);
443
- }
444
- if (f.name !== this.name) {
445
- const schema = db.getTenantSchemaPrefix();
446
-
447
- await db.query(
448
- `alter table ${schema}"${sqlsanitize(
449
- this.table.name
450
- )}" rename column "${sqlsanitize(this.name)}" TO ${f.name};`
451
- );
452
- }
453
-
454
- await db.update("_sc_fields", v, this.id);
455
- Object.entries(v).forEach(([k, v]) => {
456
- this[k] = v;
457
- });
458
- await require("../db/state").getState().refresh_tables();
459
- }
460
-
461
- /**
462
- * @type {string}
463
- */
464
- get listKey() {
465
- return this.type.listAs
466
- ? (r) => this.type.listAs(r[this.name])
467
- : this.type.showAs
468
- ? (r) => this.type.showAs(r[this.name])
469
- : this.name;
470
- }
471
-
472
- /**
473
- * @type {object}
474
- */
475
- get presets() {
476
- if (this.type && this.type.presets) return this.type.presets;
477
-
478
- if (this.type === "Key" && this.reftable_name === "users")
479
- return { LoggedIn: ({ user }) => user && user.id };
480
-
481
- return null;
482
- }
483
-
484
- /**
485
- * @throws {InvalidAdminAction}
486
- * @returns {Promise<void>}
487
- */
488
- async delete() {
489
- const Table = require("./table");
490
- const table = await Table.findOne({ id: this.table_id });
491
- const TableConstraint = require("./table_constraints");
492
- await TableConstraint.delete_field_constraints(table, this);
493
- if (table.ownership_field_id === this.id) {
494
- throw new InvalidAdminAction(
495
- `Cannot delete field ${this.name} as it sets ownership for table ${table.name}`
496
- );
497
- }
498
-
499
- const schema = db.getTenantSchemaPrefix();
500
- const client = db.isSQLite ? db : await db.getClient();
501
- await client.query("BEGIN");
502
-
503
- await db.deleteWhere("_sc_fields", { id: this.id }, { client });
504
-
505
- if (!db.isSQLite && (!this.calculated || this.stored)) {
506
- await client.query(
507
- `alter table ${schema}"${sqlsanitize(
508
- table.name
509
- )}" drop column "${sqlsanitize(this.name)}"`
510
- );
511
- if (table.versioned) {
512
- await client.query(
513
- `alter table ${schema}"${sqlsanitize(
514
- table.name
515
- )}__history" drop column "${sqlsanitize(this.name)}"`
516
- );
517
- }
518
- }
519
- await client.query("COMMIT");
520
-
521
- if (!db.isSQLite) await client.release(true);
522
- await require("../db/state").getState().refresh_tables();
523
- }
524
-
525
- /**
526
- * @param {object} table
527
- * @returns {Promise<void>}
528
- */
529
- async enable_fkey_constraint(table) {
530
- if (this.is_fkey && !db.isSQLite) {
531
- const schema = db.getTenantSchemaPrefix();
532
-
533
- const q = `alter table ${schema}"${sqlsanitize(
534
- table.name
535
- )}" ADD CONSTRAINT "fkey_${sqlsanitize(table.name)}_${sqlsanitize(
536
- this.name
537
- )}" FOREIGN KEY ("${sqlsanitize(
538
- this.name
539
- )}") references ${schema}"${sqlsanitize(this.reftable_name)}" (id)`;
540
- await db.query(q);
541
- }
542
- }
543
-
544
- /**
545
- * @param {object} fld
546
- * @param {boolean} [bare = false]
547
- * @returns {Promise<Field>}
548
- */
549
- static async create(fld, bare = false) {
550
- const f = new Field(fld);
551
- const schema = db.getTenantSchemaPrefix();
552
-
553
- const Table = require("./table");
554
- const is_sqlite = db.isSQLite;
555
- //const tables = await Table.find();
556
- //console.log({ tables, fld });
557
- if (f.is_fkey) {
558
- //need to check ref types
559
- const reftable = await Table.findOne({ name: f.reftable_name });
560
- if (reftable) {
561
- const reffields = await reftable.getFields();
562
- const refpk = reffields.find((rf) => rf.primary_key);
563
- f.reftype = refpk.type.name;
564
- f.refname = refpk.name;
565
- }
566
- }
567
-
568
- const sql_type = bare ? f.sql_bare_type : f.sql_type;
569
- const table = await Table.findOne({ id: f.table_id });
570
- if (!f.calculated || f.stored) {
571
- if (typeof f.attributes.default === "undefined") {
572
- const q = `alter table ${schema}"${sqlsanitize(
573
- table.name
574
- )}" add column "${sqlsanitize(f.name)}" ${sql_type} ${
575
- f.required ? `not null ${is_sqlite ? 'default ""' : ""}` : ""
576
- }`;
577
- await db.query(q);
578
- } else if (is_sqlite) {
579
- //warning: not safe but sqlite so we don't care
580
- const q = `alter table ${schema}"${sqlsanitize(
581
- table.name
582
- )}" add column "${sqlsanitize(f.name)}" ${sql_type} ${
583
- f.required
584
- ? `not null default ${JSON.stringify(f.attributes.default)}`
585
- : ""
586
- }`;
587
- await db.query(q);
588
- } else {
589
- const q = `DROP FUNCTION IF EXISTS add_field_${sqlsanitize(f.name)};
590
- CREATE FUNCTION add_field_${sqlsanitize(f.name)}(thedef ${
591
- f.sql_bare_type
592
- }) RETURNS void AS $$
593
- BEGIN
594
- EXECUTE format('alter table ${schema}"${sqlsanitize(
595
- table.name
596
- )}" add column "${sqlsanitize(f.name)}" ${sql_type} ${
597
- f.required ? "not null" : ""
598
- } default %L', thedef);
599
- END;
600
- $$ LANGUAGE plpgsql;`;
601
- await db.query(q);
602
- await db.query(`SELECT add_field_${sqlsanitize(f.name)}($1)`, [
603
- f.attributes.default,
604
- ]);
605
- }
606
- }
607
- f.id = await db.insert("_sc_fields", {
608
- table_id: f.table_id,
609
- name: f.name,
610
- label: f.label,
611
- type: f.is_fkey ? f.type : f.type.name,
612
- reftable_name: f.is_fkey ? f.reftable_name : undefined,
613
- reftype: f.is_fkey ? f.reftype : undefined,
614
- refname: f.is_fkey ? f.refname : undefined,
615
- required: f.required,
616
- is_unique: f.is_unique,
617
- attributes: f.attributes,
618
- calculated: f.calculated,
619
- expression: f.expression,
620
- stored: f.stored,
621
- });
622
- await require("../db/state").getState().refresh_tables();
623
-
624
- if (table.versioned && !f.calculated) {
625
- await db.query(
626
- `alter table ${schema}"${sqlsanitize(
627
- table.name
628
- )}__history" add column "${sqlsanitize(f.name)}" ${f.sql_bare_type}`
629
- );
630
- }
631
-
632
- if (f.is_unique && !f.calculated) await f.add_unique_constraint();
633
-
634
- if (f.calculated && f.stored) {
635
- const nrows = await table.countRows({});
636
- if (nrows > 0) {
637
- const table1 = await Table.findOne({ id: f.table_id });
638
-
639
- recalculate_for_stored(table1); //not waiting as there could be a lot of data
640
- }
641
- }
642
- return f;
643
- }
644
-
645
- /**
646
- * @param {function|object[]} [typeattribs]
647
- * @param {number} [table_id]
648
- * @returns {*}
649
- */
650
- static getTypeAttributes(typeattribs, table_id) {
651
- const Table = require("./table");
652
-
653
- if (!typeattribs) return [];
654
- if (typeof typeattribs === "function") {
655
- if (!table_id) return typeattribs({});
656
- const table = Table.findOne({ id: table_id });
657
- return typeattribs({ table });
658
- } else return typeattribs;
659
- }
660
- }
661
-
662
- Field.contract = {
663
- variables: {
664
- name: is.str,
665
- label: is.str,
666
- class: is.str,
667
- postText: is.maybe(is.str),
668
- sublabel: is.maybe(is.str),
669
- fieldview: is.maybe(is.str),
670
- parent_field: is.maybe(is.str),
671
- reftable_name: is.maybe(is.str),
672
- validator: is.fun(is.any, is.bool),
673
- type: is.maybe(
674
- is.or(is.eq("Key"), is.eq("File"), is.obj({ name: is.str }))
675
- ),
676
- input_type: is.maybe(
677
- is.one_of([
678
- "hidden",
679
- "file",
680
- "select",
681
- "fromtype",
682
- "search",
683
- "text",
684
- "password",
685
- "section_header",
686
- "textarea",
687
- "custom_html",
688
- "code",
689
- ])
690
- ),
691
- is_fkey: is.bool,
692
- is_unique: is.bool,
693
- required: is.bool,
694
- disabled: is.bool,
695
- id: is.maybe(is.posint),
696
- attributes: is.obj(),
697
- table_id: is.maybe(is.posint),
698
- },
699
- instance_check: is.and(
700
- is.or(is.obj({ type: is.defined }), is.obj({ input_type: is.defined })),
701
- is.or(
702
- is.obj({ is_fkey: is.eq(false), reftable_name: is.eq(undefined) }),
703
- is.obj({ is_fkey: is.eq(true), reftable_name: is.str })
704
- )
705
- ),
706
- methods: {
707
- validate: is.fun(
708
- is.obj(),
709
- is.or(is.obj({ errors: is.str }), is.obj({ success: is.any }))
710
- ),
711
- toJson: is.getter(is.obj({ type: is.str })),
712
- sql_type: is.getter(is.str),
713
- sql_bare_type: is.getter(is.str),
714
- form_name: is.getter(is.str),
715
- listKey: is.getter(is.any), // todo why not str?
716
- presets: is.getter(is.maybe(is.objVals(is.fun(is.obj(), is.any)))),
717
- delete: is.fun([], is.promise(is.undefined)),
718
- generate: is.fun([], is.promise(is.any)),
719
- add_unique_constraint: is.fun([], is.promise(is.undefined)),
720
- remove_unique_constraint: is.fun([], is.promise(is.undefined)),
721
- toggle_not_null: is.fun(is.bool, is.promise(is.undefined)), // TODO requires postgres
722
- fill_table: is.fun([], is.promise(is.undefined)),
723
- update: is.fun(is.obj(), is.promise(is.undefined)), //TODO requires not-null id
724
- fill_fkey_options: is.fun(is.maybe(is.bool), is.promise()),
725
- distinct_values: is.fun(
726
- [],
727
- is.promise(is.array(is.obj({ label: is.any, value: is.any })))
728
- ),
729
- },
730
- static_methods: {
731
- find: is.fun(
732
- [is.maybe(is.obj()), is.maybe(is.obj())],
733
- is.promise(is.array(is.class("Field")))
734
- ),
735
- findOne: is.fun(is.obj(), is.promise(is.class("Field"))),
736
- create: is.fun(is.obj(), is.promise(is.class("Field"))),
737
- labelToName: is.fun(is.str, is.str),
738
- },
739
- };
740
- module.exports = Field;