@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/plugin-helper.js DELETED
@@ -1,1291 +0,0 @@
1
- /**
2
- * Plugin-helper
3
- * @category saltcorn-data
4
- * @module plugin-helper
5
- */
6
- const View = require("./models/view");
7
- const Field = require("./models/field");
8
- const Table = require("./models/table");
9
- const Trigger = require("./models/trigger");
10
-
11
- const { getState } = require("./db/state");
12
- const db = require("./db");
13
- const { contract, is } = require("contractis");
14
- const {
15
- fieldlike,
16
- is_table_query,
17
- is_column,
18
- is_tablely,
19
- } = require("./contracts");
20
- const { link } = require("@saltcorn/markup");
21
- const { button, a, label, text, i } = require("@saltcorn/markup/tags");
22
- const { applyAsync, InvalidConfiguration } = require("./utils");
23
- const { jsexprToSQL } = require("./models/expression");
24
- /**
25
- *
26
- * @param {string} url
27
- * @param {string} label
28
- * @param {boolean} [popup]
29
- * @param {string} [link_style = ""]
30
- * @param {string} [link_size = ""]
31
- * @param {string} [link_icon = ""]
32
- * @param {string} [textStyle = ""]
33
- * @param {string} [link_bgcol]
34
- * @param {string} [link_bordercol]
35
- * @param {string} [link_textcol]
36
- * @returns {button|a}
37
- */
38
- const link_view = (
39
- url,
40
- label,
41
- popup,
42
- link_style = "",
43
- link_size = "",
44
- link_icon = "",
45
- textStyle = "",
46
- link_bgcol,
47
- link_bordercol,
48
- link_textcol
49
- ) => {
50
- let style =
51
- link_style === "btn btn-custom-color"
52
- ? `background-color: ${link_bgcol || "#000000"};border-color: ${
53
- link_bordercol || "#000000"
54
- }; color: ${link_textcol || "#000000"}`
55
- : null;
56
- if (popup) {
57
- return button(
58
- {
59
- class: [
60
- textStyle,
61
- link_style,
62
- link_size,
63
- !link_style && "btn btn-link",
64
- ],
65
- onClick: `ajax_modal('${url}')`,
66
- style,
67
- },
68
- link_icon ? i({ class: link_icon }) + " " : "",
69
- label
70
- );
71
- } else
72
- return a(
73
- {
74
- href: url,
75
- class: [textStyle, link_style, link_size],
76
- style,
77
- },
78
- link_icon ? i({ class: link_icon }) + " " : "",
79
- text(label)
80
- );
81
- };
82
-
83
- /**
84
- * @function
85
- * @param {object} [state]
86
- * @returns {string}
87
- */
88
- const stateToQueryString = contract(
89
- is.fun(is.maybe(is.obj()), is.str),
90
- (state) => {
91
- if (!state || Object.keys(state).length === 0) return "";
92
-
93
- return (
94
- "?" +
95
- Object.entries(state)
96
- .map(([k, v]) =>
97
- k === "id"
98
- ? null
99
- : `${encodeURIComponent(k)}=${encodeURIComponent(v)}`
100
- )
101
- .filter((s) => !!s)
102
- .join("&")
103
- );
104
- }
105
- );
106
-
107
- /**
108
- * @function
109
- * @param {Field[]} fields
110
- * @param {boolean}
111
- * @returns {object}
112
- */
113
- const calcfldViewOptions = contract(
114
- is.fun(
115
- [is.array(is.class("Field")), is.bool],
116
- is.obj({ field_view_options: is.objVals(is.array(is.str)) })
117
- ),
118
- (fields, isEdit) => {
119
- var fvs = {};
120
- const handlesTextStyle = {};
121
- fields.forEach((f) => {
122
- handlesTextStyle[f.name] = [];
123
- if (f.type === "File") {
124
- if (!isEdit) fvs[f.name] = Object.keys(getState().fileviews);
125
- else fvs[f.name] = ["upload"];
126
- } else if (f.type === "Key") {
127
- if (isEdit) fvs[f.name] = Object.keys(getState().keyFieldviews);
128
- else {
129
- if (f.reftable && f.reftable.fields) {
130
- const { field_view_options } = calcfldViewOptions(
131
- f.reftable.fields,
132
- isEdit
133
- );
134
- for (const jf of f.reftable.fields) {
135
- fvs[`${f.name}.${jf.name}`] = field_view_options[jf.name];
136
- }
137
- }
138
- fvs[f.name] = ["show"];
139
- }
140
- Object.entries(getState().keyFieldviews).forEach(([k, v]) => {
141
- if (v && v.handlesTextStyle) handlesTextStyle[f.name].push(k);
142
- });
143
- } else if (f.type && f.type.fieldviews) {
144
- const tfvs = Object.entries(f.type.fieldviews).filter(([k, fv]) =>
145
- f.calculated ? !fv.isEdit : !fv.isEdit || isEdit
146
- );
147
- let tfvs_ordered = [];
148
- if (isEdit) {
149
- tfvs_ordered = [
150
- ...tfvs.filter(([k, fv]) => fv.isEdit),
151
- ...tfvs.filter(([k, fv]) => !fv.isEdit),
152
- ];
153
- } else tfvs_ordered = tfvs;
154
- fvs[f.name] = tfvs_ordered.map(([k, fv]) => {
155
- if (fv && fv.handlesTextStyle) handlesTextStyle[f.name].push(k);
156
- return k;
157
- });
158
- }
159
- });
160
- return { field_view_options: fvs, handlesTextStyle };
161
- }
162
- );
163
-
164
- /**
165
- * @function
166
- * @param {Field[]} fields
167
- * @param {boolean}
168
- * @returns {Promise<object>}
169
- */
170
- const calcfldViewConfig = contract(
171
- is.fun([is.array(is.class("Field")), is.bool], is.promise(is.obj())),
172
- async (fields, isEdit) => {
173
- const fieldViewConfigForms = {};
174
- for (const f of fields) {
175
- fieldViewConfigForms[f.name] = {};
176
- const fieldviews =
177
- f.type === "Key"
178
- ? getState().keyFieldviews
179
- : (f.type && f.type.fieldviews) || {};
180
- for (const [nm, fv] of Object.entries(fieldviews)) {
181
- if (fv.configFields)
182
- fieldViewConfigForms[f.name][nm] = await applyAsync(
183
- fv.configFields,
184
- f
185
- );
186
- }
187
- }
188
- return fieldViewConfigForms;
189
- }
190
- );
191
-
192
- /**
193
- * @function
194
- * @param {Table|object} table
195
- * @param {string} viewname
196
- * @param {boolean}
197
- * @returns {Promise<object[]>}
198
- */
199
- const get_link_view_opts = contract(
200
- is.fun(
201
- [is_tablely, is.str],
202
- is.promise(is.array(is.obj({ label: is.str, name: is.str })))
203
- ),
204
- async (table, viewname) => {
205
- const own_link_views = await View.find_possible_links_to_table(table);
206
- const link_view_opts = own_link_views
207
- .filter((v) => v.name !== viewname)
208
- .map((v) => ({
209
- label: `${v.name} [${v.viewtemplate} ${table.name}]`,
210
- name: `Own:${v.name}`,
211
- }));
212
- const link_view_names = new Set();
213
- const child_views = await get_child_views(table, viewname);
214
- for (const { relation, related_table, views } of child_views) {
215
- for (const view of views) {
216
- const name = `${view.name}.${related_table.name}.${relation.name}`;
217
- link_view_names.add(name);
218
- link_view_opts.push({
219
- name: `ChildList:${view.name}.${related_table.name}.${relation.name}`,
220
- label: `${view.name} [${view.viewtemplate} ${related_table.name}.${relation.label}]`,
221
- });
222
- }
223
- }
224
-
225
- const parent_views = await get_parent_views(table, viewname);
226
- for (const { relation, related_table, views } of parent_views) {
227
- for (const view of views) {
228
- link_view_opts.push({
229
- name: `ParentShow:${view.name}.${related_table.name}.${relation.name}`,
230
- label: `${view.name} [${view.viewtemplate} ${relation.name}.${related_table.name}]`,
231
- });
232
- }
233
- }
234
- const onetoone_views = await get_onetoone_views(table, viewname);
235
- for (const { relation, related_table, views } of onetoone_views) {
236
- for (const view of views) {
237
- const name = `${view.name}.${related_table.name}.${relation.name}`;
238
- if (!link_view_names.has(name))
239
- link_view_opts.push({
240
- name: `OneToOneShow:${view.name}.${related_table.name}.${relation.name}`,
241
- label: `${view.name} [${view.viewtemplate} ${related_table.name}.${relation.label}]`,
242
- });
243
- }
244
- }
245
- const independent_views = await View.find_all_views_where(
246
- ({ state_fields }) => !state_fields.some((sf) => sf.required)
247
- );
248
- independent_views.forEach((view) => {
249
- link_view_opts.push({
250
- label: `${view.name} [${view.viewtemplate}]`,
251
- name: `Independent:${view.name}`,
252
- });
253
- });
254
- return link_view_opts;
255
- }
256
- );
257
-
258
- /**
259
- * Get Action configuration fields
260
- * @param {object} action
261
- * @param {object} table
262
- * @returns {Promise<object[]>}
263
- */
264
- const getActionConfigFields = async (action, table) =>
265
- typeof action.configFields === "function"
266
- ? await action.configFields({ table })
267
- : action.configFields || [];
268
-
269
- /**
270
- * @function
271
- * @param {Table|object} table
272
- * @param {string} viewname
273
- * @param {object} req
274
- * @returns {Promise<object[]>}
275
- */
276
- const field_picker_fields = contract(
277
- is.fun(
278
- is.obj({ table: is_tablely, viewname: is.str }),
279
- is.promise(is.array(fieldlike))
280
- ),
281
- async ({ table, viewname, req }) => {
282
- const __ = (...s) => (req ? req.__(...s) : s.join(""));
283
- const fields = await table.getFields();
284
- for (const field of fields) {
285
- if (field.type === "Key") {
286
- field.reftable = await Table.findOne({ name: field.reftable_name });
287
- if (field.reftable) await field.reftable.getFields();
288
- }
289
- }
290
- const boolfields = fields.filter((f) => f.type && f.type.name === "Bool");
291
-
292
- const stateActions = getState().actions;
293
- const stateActionKeys = Object.entries(stateActions)
294
- .filter(([k, v]) => !v.requireRow && !v.disableInList)
295
- .map(([k, v]) => k);
296
- const actions = [
297
- "Delete",
298
- ...boolfields.map((f) => `Toggle ${f.name}`),
299
- ...stateActionKeys,
300
- ];
301
- const triggers = await Trigger.find({
302
- when_trigger: { or: ["API call", "Never"] },
303
- });
304
- triggers.forEach((tr) => {
305
- actions.push(tr.name);
306
- });
307
- const actionConfigFields = [];
308
- for (const [name, action] of Object.entries(stateActions)) {
309
- if (!stateActionKeys.includes(name)) continue;
310
- const cfgFields = await getActionConfigFields(action, table);
311
-
312
- for (const field of cfgFields) {
313
- const cfgFld = {
314
- ...field,
315
- showIf: {
316
- action_name: name,
317
- type: "Action",
318
- ...(field.showIf || {}),
319
- },
320
- };
321
- if (cfgFld.input_type === "code") cfgFld.input_type = "textarea";
322
- actionConfigFields.push(cfgFld);
323
- }
324
- }
325
- const fldOptions = fields.map((f) => f.name);
326
- const { field_view_options } = calcfldViewOptions(fields, false);
327
- const fieldViewConfigForms = await calcfldViewConfig(fields, false);
328
- const fvConfigFields = [];
329
- for (const [field_name, fvOptFields] of Object.entries(
330
- fieldViewConfigForms
331
- )) {
332
- for (const [fieldview, formFields] of Object.entries(fvOptFields)) {
333
- for (const formField of formFields) {
334
- fvConfigFields.push({
335
- ...formField,
336
- showIf: {
337
- type: "Field",
338
- field_name,
339
- fieldview,
340
- },
341
- });
342
- }
343
- }
344
- }
345
- const link_view_opts = await get_link_view_opts(table, viewname);
346
-
347
- const { parent_field_list } = await table.get_parent_relations(true);
348
- const {
349
- child_field_list,
350
- child_relations,
351
- } = await table.get_child_relations();
352
- const aggStatOptions = {};
353
- const agg_field_opts = child_relations.map(({ table, key_field }) => {
354
- aggStatOptions[`${table.name}.${key_field.name}`] = [
355
- "Count",
356
- "Avg",
357
- "Sum",
358
- "Max",
359
- "Min",
360
- ];
361
- table.fields.forEach((f) => {
362
- if (f.type && f.type.name === "Date") {
363
- aggStatOptions[`${table.name}.${key_field.name}`].push(
364
- `Latest ${f.name}`
365
- );
366
- }
367
- });
368
- return {
369
- name: `agg_field`,
370
- label: __("On Field"),
371
- type: "String",
372
- required: true,
373
- attributes: {
374
- options: table.fields
375
- .filter((f) => !f.calculated || f.stored)
376
- .map((f) => f.name),
377
- },
378
- showIf: {
379
- agg_relation: `${table.name}.${key_field.name}`,
380
- type: "Aggregation",
381
- },
382
- };
383
- });
384
- return [
385
- {
386
- name: "type",
387
- label: __("Type"),
388
- type: "String",
389
- required: true,
390
- attributes: {
391
- //TODO omit when no options
392
- options: [
393
- {
394
- name: "Field",
395
- label: __(`Field in %s table`, table.name),
396
- },
397
- { name: "Action", label: __("Action on row") },
398
-
399
- ...(link_view_opts.length > 0
400
- ? [{ name: "ViewLink", label: __("Link to other view") }]
401
- : []),
402
- { name: "Link", label: __("Link to anywhere") },
403
- ...(parent_field_list.length > 0
404
- ? [{ name: "JoinField", label: __("Join Field") }]
405
- : []),
406
- ...(child_field_list.length > 0
407
- ? [{ name: "Aggregation", label: __("Aggregation") }]
408
- : []),
409
- ],
410
- },
411
- },
412
- {
413
- name: "field_name",
414
- label: __("Field"),
415
- type: "String",
416
- required: true,
417
- attributes: {
418
- options: fldOptions,
419
- },
420
- showIf: { type: "Field" },
421
- },
422
- {
423
- name: "fieldview",
424
- label: __("Field view"),
425
- type: "String",
426
- required: false,
427
- attributes: {
428
- calcOptions: ["field_name", field_view_options],
429
- },
430
- showIf: { type: "Field" },
431
- },
432
- ...fvConfigFields,
433
- {
434
- name: "action_name",
435
- label: __("Action"),
436
- type: "String",
437
- required: true,
438
- attributes: {
439
- options: actions,
440
- },
441
- showIf: { type: "Action" },
442
- },
443
- {
444
- name: "action_label",
445
- label: __("Action Label"),
446
- type: "String",
447
- showIf: { type: "Action" },
448
- },
449
- {
450
- name: "action_label_formula",
451
- label: __("Action label is a formula?"),
452
- type: "Bool",
453
- required: false,
454
- showIf: { type: "Action" },
455
- },
456
- {
457
- name: "action_style",
458
- label: __("Action Style"),
459
- type: "String",
460
- required: true,
461
- attributes: {
462
- options: [
463
- { name: "btn-primary", label: "Primary button" },
464
- { name: "btn-secondary", label: "Secondary button" },
465
- { name: "btn-success", label: "Success button" },
466
- { name: "btn-danger", label: "Danger button" },
467
- { name: "btn-outline-primary", label: "Primary outline button" },
468
- {
469
- name: "btn-outline-secondary",
470
- label: "Secondary outline button",
471
- },
472
- { name: "btn-link", label: "Link" },
473
- ],
474
- },
475
-
476
- showIf: { type: "Action" },
477
- },
478
- {
479
- name: "action_size",
480
- label: __("Button size"),
481
- type: "String",
482
- required: true,
483
- attributes: {
484
- options: [
485
- { name: "", label: "Standard" },
486
- { name: "btn-lg", label: "Large" },
487
- { name: "btn-sm", label: "Small" },
488
- { name: "btn-block", label: "Block" },
489
- { name: "btn-block btn-lg", label: "Large block" },
490
- ],
491
- },
492
- showIf: { type: "Action" },
493
- },
494
- {
495
- name: "confirm",
496
- label: __("User confirmation?"),
497
- type: "Bool",
498
- showIf: { type: "Action" },
499
- },
500
- ...actionConfigFields,
501
- {
502
- name: "view",
503
- label: __("View"),
504
- type: "String",
505
- required: true,
506
- attributes: {
507
- options: link_view_opts,
508
- },
509
- showIf: { type: "ViewLink" },
510
- },
511
- {
512
- name: "view_label",
513
- label: __("View label"),
514
- sublabel: __("Leave blank for default label."),
515
- type: "String",
516
- required: false,
517
- showIf: { type: "ViewLink" },
518
- },
519
- {
520
- name: "view_label_formula",
521
- label: __("View label is a formula?"),
522
- type: "Bool",
523
- required: false,
524
- showIf: { type: "ViewLink" },
525
- },
526
- {
527
- name: "in_modal",
528
- label: __("Open in popup modal?"),
529
- type: "Bool",
530
- required: false,
531
- showIf: { type: "ViewLink" },
532
- },
533
- {
534
- name: "link_style",
535
- label: __("Link Style"),
536
- type: "String",
537
- required: true,
538
- attributes: {
539
- options: [
540
- { name: "", label: "Link" },
541
- { name: "btn btn-primary", label: "Primary button" },
542
- { name: "btn btn-secondary", label: "Secondary button" },
543
- { name: "btn btn-success", label: "Success button" },
544
- { name: "btn btn-danger", label: "Danger button" },
545
- {
546
- name: "btn btn-outline-primary",
547
- label: "Primary outline button",
548
- },
549
- {
550
- name: "btn btn-outline-secondary",
551
- label: "Secondary outline button",
552
- },
553
- ],
554
- },
555
-
556
- showIf: { type: "ViewLink" },
557
- },
558
- {
559
- name: "link_size",
560
- label: __("Link size"),
561
- type: "String",
562
- required: true,
563
- attributes: {
564
- options: [
565
- { name: "", label: "Standard" },
566
- { name: "btn-lg", label: "Large" },
567
- { name: "btn-sm", label: "Small" },
568
- { name: "btn-block", label: "Block" },
569
- { name: "btn-block btn-lg", label: "Large block" },
570
- ],
571
- },
572
- showIf: { type: "ViewLink" },
573
- },
574
- {
575
- name: "link_text",
576
- label: __("Link text"),
577
- type: "String",
578
- required: true,
579
- showIf: { type: "Link" },
580
- },
581
- {
582
- name: "link_text_formula",
583
- label: __("Link text is a formula?"),
584
- type: "Bool",
585
- required: false,
586
- showIf: { type: "Link" },
587
- },
588
- {
589
- name: "link_url",
590
- label: __("Link URL"),
591
- type: "String",
592
- required: true,
593
- showIf: { type: "Link" },
594
- },
595
- {
596
- name: "link_url_formula",
597
- label: __("Link URL is a formula?"),
598
- type: "Bool",
599
- required: false,
600
- showIf: { type: "Link" },
601
- },
602
- {
603
- name: "link_target_blank",
604
- label: __("Open in new tab"),
605
- type: "Bool",
606
- required: false,
607
- showIf: { type: "Link" },
608
- },
609
- {
610
- name: "join_field",
611
- label: __("Join Field"),
612
- type: "String",
613
- required: true,
614
- attributes: {
615
- options: parent_field_list,
616
- },
617
- showIf: { type: "JoinField" },
618
- },
619
- {
620
- name: "agg_relation",
621
- label: __("Relation"),
622
- type: "String",
623
- required: true,
624
- attributes: {
625
- options: child_field_list,
626
- },
627
- showIf: { type: "Aggregation" },
628
- },
629
- ...agg_field_opts,
630
- {
631
- name: "stat",
632
- label: __("Statistic"),
633
- type: "String",
634
- required: true,
635
- attributes: {
636
- calcOptions: ["agg_relation", aggStatOptions],
637
- },
638
-
639
- showIf: { type: "Aggregation" },
640
- },
641
- {
642
- name: "aggwhere",
643
- label: __("Where"),
644
- sublabel: __("Formula"),
645
- type: "String",
646
- required: false,
647
- showIf: { type: "Aggregation" },
648
- },
649
- {
650
- name: "state_field",
651
- label: __("In search form"),
652
- type: "Bool",
653
- showIf: { type: "Field" },
654
- },
655
- {
656
- name: "header_label",
657
- label: __("Header label"),
658
- type: "String",
659
- },
660
- {
661
- name: "col_width",
662
- label: __("Column width"),
663
- type: "Integer",
664
- },
665
- {
666
- name: "col_width_units",
667
- label: __("Column width units"),
668
- type: "String",
669
- required: true,
670
- fieldview: "radio_group",
671
- attributes: {
672
- inline: true,
673
- options: ["px", "%", "vw", "em", "rem"],
674
- },
675
- },
676
- ];
677
- }
678
- );
679
-
680
- /**
681
- * get_child_views Contract
682
- * @function
683
- * @param {Table|object} table
684
- * @param {string} viewname
685
- * @returns {Promise<object[]>}
686
- */
687
- const get_child_views = contract(
688
- is.fun(
689
- [is_tablely, is.str],
690
- is.promise(
691
- is.array(
692
- is.obj({
693
- relation: is.class("Field"),
694
- related_table: is.class("Table"),
695
- views: is.array(is.class("View")),
696
- })
697
- )
698
- )
699
- ),
700
- async (table, viewname) => {
701
- const rels = await Field.find({ reftable_name: table.name });
702
- var child_views = [];
703
- for (const relation of rels) {
704
- const related_table = await Table.findOne({ id: relation.table_id });
705
- const views = await View.find_table_views_where(
706
- related_table.id,
707
- ({ state_fields, viewrow }) =>
708
- viewrow.name !== viewname && state_fields.every((sf) => !sf.required)
709
- );
710
- child_views.push({ relation, related_table, views });
711
- }
712
- return child_views;
713
- }
714
- );
715
-
716
- /**
717
- * get_parent_views Contract
718
- * @function
719
- * @param {Table|object} table
720
- * @param {string} viewname
721
- * @returns {Promise<object[]>}
722
- */
723
- const get_parent_views = contract(
724
- is.fun(
725
- [is_tablely, is.str],
726
- is.promise(
727
- is.array(
728
- is.obj({
729
- relation: is.class("Field"),
730
- related_table: is.class("Table"),
731
- views: is.array(is.class("View")),
732
- })
733
- )
734
- )
735
- ),
736
- async (table, viewname) => {
737
- var parent_views = [];
738
- const parentrels = (await table.getFields()).filter(
739
- (f) => f.is_fkey && f.type !== "File"
740
- );
741
- for (const relation of parentrels) {
742
- const related_table = await Table.findOne({
743
- name: relation.reftable_name,
744
- });
745
- const views = await View.find_table_views_where(
746
- related_table,
747
- ({ state_fields, viewrow }) =>
748
- viewrow.name !== viewname &&
749
- state_fields.some((sf) => sf.name === "id")
750
- );
751
-
752
- parent_views.push({ relation, related_table, views });
753
- }
754
- return parent_views;
755
- }
756
- );
757
-
758
- /**
759
- * get_onetoone_views Contract
760
- * @function
761
- * @param {Table|is_tablely} table
762
- * @param {string} viewname
763
- * @returns {Promise<object[]>}
764
- */
765
- const get_onetoone_views = contract(
766
- is.fun(
767
- [is_tablely, is.str],
768
- is.promise(
769
- is.array(
770
- is.obj({
771
- relation: is.class("Field"),
772
- related_table: is.class("Table"),
773
- views: is.array(is.class("View")),
774
- })
775
- )
776
- )
777
- ),
778
- async (table, viewname) => {
779
- const rels = await Field.find({
780
- reftable_name: table.name,
781
- is_unique: true,
782
- });
783
- var child_views = [];
784
- for (const relation of rels) {
785
- const related_table = await Table.findOne({ id: relation.table_id });
786
- const views = await View.find_table_views_where(
787
- related_table.id,
788
- ({ state_fields, viewrow }) =>
789
- viewrow.name !== viewname &&
790
- state_fields.some((sf) => sf.name === "id")
791
- );
792
- child_views.push({ relation, related_table, views });
793
- }
794
- return child_views;
795
- }
796
- );
797
-
798
- /**
799
- * picked_fields_to_query Contract
800
- * @function
801
- * @param {object[]} columns
802
- * @param {Field[]} fields
803
- * @throws {InvalidConfiguration}
804
- * @returns {object}
805
- */
806
- const picked_fields_to_query = contract(
807
- is.fun([is.array(is_column), is.array(is.class("Field"))], is_table_query),
808
- (columns, fields) => {
809
- var joinFields = {};
810
- var aggregations = {};
811
- (columns || []).forEach((column) => {
812
- if (column.type === "JoinField") {
813
- if (column.join_field && column.join_field.split) {
814
- const kpath = column.join_field.split(".");
815
- if (kpath.length === 2) {
816
- const [refNm, targetNm] = kpath;
817
- joinFields[`${refNm}_${targetNm}`] = {
818
- ref: refNm,
819
- target: targetNm,
820
- };
821
- } else {
822
- const [refNm, through, targetNm] = kpath;
823
- joinFields[`${refNm}_${through}_${targetNm}`] = {
824
- ref: refNm,
825
- target: targetNm,
826
- through,
827
- };
828
- }
829
- } else {
830
- throw new InvalidConfiguration(
831
- `Join field is specified as column but no join field is chosen`
832
- );
833
- }
834
- } else if (column.type === "ViewLink") {
835
- if (column.view && column.view.split) {
836
- const [vtype, vrest] = column.view.split(":");
837
- if (vtype === "ParentShow") {
838
- const [pviewnm, ptbl, pfld] = vrest.split(".");
839
- const field = fields.find((f) => f.name === pfld);
840
- if (field && field.attributes.summary_field)
841
- joinFields[`summary_field_${ptbl.toLowerCase()}`] = {
842
- ref: pfld,
843
- target: field.attributes.summary_field,
844
- };
845
- }
846
- }
847
- } else if (column.type === "Aggregation") {
848
- //console.log(column)
849
- if (column.agg_relation && column.agg_relation.split) {
850
- const [table, fld] = column.agg_relation.split(".");
851
- const field = column.agg_field;
852
- const targetNm = (
853
- column.stat.replace(" ", "") +
854
- "_" +
855
- table +
856
- "_" +
857
- fld +
858
- db.sqlsanitize(column.aggwhere || "")
859
- ).toLowerCase();
860
- aggregations[targetNm] = {
861
- table,
862
- ref: fld,
863
- where: jsexprToSQL(column.aggwhere),
864
- field,
865
- aggregate: column.stat,
866
- };
867
- }
868
- }
869
- });
870
-
871
- return { joinFields, aggregations };
872
- }
873
- );
874
-
875
- /**
876
- * @function
877
- * @param {object}
878
- * @param {object}
879
- * @param {string} - missing in contract
880
- * @returns {object}
881
- */
882
- const stateFieldsToQuery = contract(
883
- is.fun(is.obj(), is.obj()),
884
- ({ state, fields, prefix = "" }) => {
885
- let q = {};
886
- const stateKeys = Object.keys(state);
887
- if (state._sortby) {
888
- const field = fields.find((f) => f.name === state._sortby);
889
- //this is ok because it has to match fieldname
890
- if (field) q.orderBy = state._sortby;
891
- if (state._sortdesc) q.orderDesc = true;
892
- }
893
- if (state._pagesize) q.limit = parseInt(state._pagesize);
894
- if (state._pagesize && state._page)
895
- q.offset = (parseInt(state._page) - 1) * parseInt(state._pagesize);
896
- const latNear = stateKeys.find((k) => k.startsWith("_near_lat_"));
897
- const longNear = stateKeys.find((k) => k.startsWith("_near_long_"));
898
- if (latNear && longNear) {
899
- const latField =
900
- prefix + db.sqlsanitize(latNear.replace("_near_lat_", ""));
901
- const longField =
902
- prefix + db.sqlsanitize(longNear.replace("_near_long_", ""));
903
- const lat = parseFloat(state[latNear]);
904
- const long = parseFloat(state[longNear]);
905
- q.orderBy = { distance: { lat, long, latField, longField } };
906
- }
907
- return q;
908
- }
909
- );
910
-
911
- /**
912
- *
913
- * @param {object} container
914
- * @param {string} key
915
- * @param {object} x
916
- * @returns {void}
917
- */
918
- const addOrCreateList = (container, key, x) => {
919
- if (container[key]) container[key].push(x);
920
- else container[key] = [x];
921
- };
922
-
923
- /**
924
- * @function
925
- * @param {object} opts
926
- * @param {Field[]} opts.fields
927
- * @param {object} opts.state missing in contract
928
- * @param {boolean} [opts.approximate = true]
929
- * @returns {object}
930
- */
931
- const stateFieldsToWhere = contract(
932
- is.fun(
933
- is.obj({
934
- fields: is.array(is.class("Field")),
935
- approximate: is.maybe(is.bool),
936
- }),
937
- is.obj()
938
- ),
939
- ({ fields, state, approximate = true }) => {
940
- var qstate = {};
941
- Object.entries(state).forEach(([k, v]) => {
942
- if (k === "_fts") {
943
- qstate[k] = { searchTerm: v.replace(/\0/g, ""), fields };
944
- return;
945
- }
946
- const field = fields.find((fld) => fld.name == k);
947
- if (k.startsWith("_fromdate_")) {
948
- const datefield = db.sqlsanitize(k.replace("_fromdate_", ""));
949
- const dfield = fields.find((fld) => fld.name == datefield);
950
- if (dfield)
951
- addOrCreateList(qstate, datefield, { gt: new Date(v), equal: true });
952
- } else if (k.startsWith("_todate_")) {
953
- const datefield = db.sqlsanitize(k.replace("_todate_", ""));
954
- const dfield = fields.find((fld) => fld.name == datefield);
955
- if (dfield)
956
- addOrCreateList(qstate, datefield, { lt: new Date(v), equal: true });
957
- } else if (
958
- field &&
959
- field.type.name === "String" &&
960
- !(field.attributes && field.attributes.options) &&
961
- approximate
962
- ) {
963
- qstate[k] = { ilike: v };
964
- } else if (field && field.type.name === "Bool" && state[k] === "?") {
965
- // omit
966
- } else if (field && field.type && field.type.read)
967
- qstate[k] = field.type.read(v);
968
- else if (field) qstate[k] = v;
969
- else if (k.includes(".")) {
970
- const kpath = k.split(".");
971
- if (kpath.length === 3) {
972
- const [jtNm, jFieldNm, lblField] = kpath;
973
- qstate.id = [
974
- ...(qstate.id ? [qstate.id] : []),
975
- {
976
- // where id in (select jFieldNm from jtnm where lblField=v)
977
- inSelect: {
978
- table: `${db.getTenantSchemaPrefix()}"${db.sqlsanitize(jtNm)}"`,
979
- field: db.sqlsanitize(jFieldNm),
980
- where: { [db.sqlsanitize(lblField)]: v },
981
- },
982
- },
983
- ];
984
- }
985
- }
986
- });
987
- return qstate;
988
- }
989
- );
990
-
991
- /**
992
- * initial_config_all_fields Contract
993
- * @function
994
- * @param {boolean}
995
- * @returns {function}
996
- */
997
- const initial_config_all_fields = contract(
998
- is.fun(
999
- is.bool,
1000
- is.fun(
1001
- is.obj({ table_id: is.posint }),
1002
- is.promise(is.obj({ columns: is.array(is.obj()), layout: is.obj() }))
1003
- )
1004
- ),
1005
- (isEdit) => async ({ table_id, exttable_name }) => {
1006
- const table = await Table.findOne(
1007
- table_id ? { id: table_id } : { name: exttable_name }
1008
- );
1009
-
1010
- const fields = (await table.getFields()).filter(
1011
- (f) => !f.primary_key && (!isEdit || !f.calculated)
1012
- );
1013
- var cfg = { columns: [] };
1014
- var aboves = [null];
1015
- fields.forEach((f) => {
1016
- if (!f.type) return;
1017
- const flabel = {
1018
- above: [
1019
- null,
1020
- {
1021
- type: "blank",
1022
- block: false,
1023
- contents: f.label,
1024
- textStyle: "",
1025
- ...(isEdit ? { labelFor: f.name } : {}),
1026
- },
1027
- ],
1028
- };
1029
- if (
1030
- f.is_fkey &&
1031
- f.type !== "File" &&
1032
- f.reftable_name !== "users" &&
1033
- !isEdit
1034
- ) {
1035
- cfg.columns.push({
1036
- type: "JoinField",
1037
- join_field: `${f.name}.${f.attributes.summary_field}`,
1038
- });
1039
- aboves.push({
1040
- widths: [2, 10],
1041
- besides: [
1042
- flabel,
1043
- {
1044
- above: [
1045
- null,
1046
- {
1047
- type: "join_field",
1048
- block: false,
1049
- textStyle: "",
1050
- join_field: `${f.name}.${f.attributes.summary_field}`,
1051
- },
1052
- ],
1053
- },
1054
- ],
1055
- });
1056
- } else if (f.reftable_name !== "users") {
1057
- const fvNm = f.type.fieldviews
1058
- ? Object.entries(f.type.fieldviews).find(
1059
- ([nm, fv]) => fv.isEdit === isEdit
1060
- )[0]
1061
- : f.type === "File" && !isEdit
1062
- ? Object.keys(getState().fileviews)[0]
1063
- : f.type === "File" && isEdit
1064
- ? "upload"
1065
- : f.type === "Key"
1066
- ? "select"
1067
- : undefined;
1068
- cfg.columns.push({
1069
- field_name: f.name,
1070
- type: "Field",
1071
- fieldview: fvNm,
1072
- state_field: true,
1073
- });
1074
- aboves.push({
1075
- widths: [2, 10],
1076
- besides: [
1077
- flabel,
1078
- {
1079
- above: [
1080
- null,
1081
- {
1082
- type: "field",
1083
- block: false,
1084
- fieldview: fvNm,
1085
- textStyle: "",
1086
- field_name: f.name,
1087
- },
1088
- ],
1089
- },
1090
- ],
1091
- });
1092
- }
1093
- aboves.push({ type: "line_break" });
1094
- });
1095
- if (isEdit)
1096
- aboves.push({
1097
- type: "action",
1098
- block: false,
1099
- minRole: 10,
1100
- action_name: "Save",
1101
- });
1102
- cfg.layout = { above: aboves };
1103
- return cfg;
1104
- }
1105
- );
1106
-
1107
- /**
1108
- *
1109
- * @param {string} x
1110
- * @returns {number|undefined}
1111
- */
1112
- const strictParseInt = (x) => {
1113
- const y = +x;
1114
- return !isNaN(y) && y ? y : undefined;
1115
- };
1116
-
1117
- /**
1118
- *
1119
- * @param {object} state
1120
- * @param {object[]} fields
1121
- * @returns {object}
1122
- */
1123
- const readState = (state, fields, req) => {
1124
- fields.forEach((f) => {
1125
- const current = state[f.name];
1126
- if (typeof current !== "undefined") {
1127
- if (f.type.read) state[f.name] = f.type.read(current);
1128
- else if (typeof current === "string" && current.startsWith("Preset:")) {
1129
- const preset = f.presets[current.replace("Preset:", "")];
1130
- state[f.name] = preset(req);
1131
- } else if (f.type === "Key" || f.type === "File")
1132
- state[f.name] =
1133
- current === "null" || current === "" || current === null
1134
- ? null
1135
- : getState().types[f.reftype].read(current);
1136
- }
1137
- });
1138
- return state;
1139
- };
1140
-
1141
- /**
1142
- *
1143
- * @param {object} state
1144
- * @param {object[]} fields
1145
- * @returns {boolean|*}
1146
- */
1147
- const readStateStrict = (state, fields) => {
1148
- let hasErrors = false;
1149
- fields.forEach((f) => {
1150
- const current = state[f.name];
1151
- //console.log(f.name, current, typeof current);
1152
-
1153
- if (typeof current !== "undefined") {
1154
- if (f.type.read) {
1155
- const readval = f.type.read(current);
1156
- if (typeof readval === "undefined") {
1157
- if (current === "" && !f.required) delete state[f.name];
1158
- else hasErrors = true;
1159
- }
1160
- if (f.type && f.type.validate) {
1161
- const vres = f.type.validate(f.attributes || {})(readval);
1162
- if (vres.error) hasErrors = true;
1163
- }
1164
- state[f.name] = readval;
1165
- } else if (f.type === "Key" || f.type === "File")
1166
- state[f.name] =
1167
- current === "null" || current === "" || current === null
1168
- ? null
1169
- : +current;
1170
- } else if (f.required && !f.primary_key) hasErrors = true;
1171
- });
1172
- return hasErrors ? false : state;
1173
- };
1174
- /**
1175
- *
1176
- * @param {function} get_json_list
1177
- * @param {object[]} fields0
1178
- * @returns {object}
1179
- */
1180
- const json_list_to_external_table = (get_json_list, fields0) => {
1181
- const fields = fields0.map((f) =>
1182
- f.constructor.name === Object.name ? new Field(f) : f
1183
- );
1184
- const getRows = async (where = {}, selopts = {}) => {
1185
- let data_in = await get_json_list({ where, ...selopts });
1186
- const restricts = Object.entries(where);
1187
- const data_filtered =
1188
- restricts.length === 0
1189
- ? data_in
1190
- : data_in.filter((x) => restricts.every(([k, v]) => x[k] === v));
1191
- if (selopts.orderBy) {
1192
- const cmp = selopts.orderDesc
1193
- ? new Function(
1194
- "a,b",
1195
- `return b.${selopts.orderBy}-a.${selopts.orderBy}`
1196
- )
1197
- : new Function(
1198
- "a,b",
1199
- `return a.${selopts.orderBy}-b.${selopts.orderBy}`
1200
- );
1201
- data_filtered.sort(cmp);
1202
- }
1203
- if (selopts.limit)
1204
- return data_filtered.slice(
1205
- selopts.offset || 0,
1206
- (selopts.offset || 0) + selopts.limit
1207
- );
1208
- else return data_filtered;
1209
- };
1210
- const tbl = {
1211
- getFields() {
1212
- return fields;
1213
- },
1214
- fields,
1215
- getRows,
1216
- get min_role_read() {
1217
- const roles = getState().getConfig("exttables_min_role_read", {});
1218
- return roles[tbl.name] || 10;
1219
- },
1220
- getJoinedRows(opts = {}) {
1221
- const { where, ...rest } = opts;
1222
- return getRows(where || {}, rest || {});
1223
- },
1224
- async countRows(where) {
1225
- let data_in = await get_json_list({ where });
1226
- return data_in.length;
1227
- },
1228
- get_child_relations() {
1229
- return { child_relations: [], child_field_list: [] };
1230
- },
1231
- get_parent_relations() {
1232
- return { parent_relations: [], parent_field_list: [] };
1233
- },
1234
- external: true,
1235
- owner_fieldname() {
1236
- return null;
1237
- },
1238
- async distinctValues(fldNm) {
1239
- let data_in = await get_json_list({});
1240
- const s = new Set(data_in.map((x) => x[fldNm]));
1241
- return [...s];
1242
- },
1243
- };
1244
- return tbl;
1245
- };
1246
-
1247
- /**
1248
- *
1249
- * @param {object} col
1250
- * @param {object} req
1251
- * @param {...*} rest
1252
- * @returns {Promise<*>}
1253
- */
1254
- const run_action_column = async ({ col, req, ...rest }) => {
1255
- let state_action = getState().actions[col.action_name];
1256
- let configuration;
1257
- if (state_action) configuration = col.configuration;
1258
- else {
1259
- const trigger = await Trigger.findOne({ name: col.action_name });
1260
- state_action = getState().actions[trigger.action];
1261
- configuration = trigger.configuration;
1262
- }
1263
- return await state_action.run({
1264
- configuration,
1265
- user: req.user,
1266
- req,
1267
- ...rest,
1268
- });
1269
- };
1270
-
1271
- module.exports = {
1272
- field_picker_fields,
1273
- picked_fields_to_query,
1274
- get_child_views,
1275
- get_parent_views,
1276
- stateFieldsToWhere,
1277
- stateFieldsToQuery,
1278
- initial_config_all_fields,
1279
- calcfldViewOptions,
1280
- get_link_view_opts,
1281
- is_column,
1282
- readState,
1283
- readStateStrict,
1284
- stateToQueryString,
1285
- link_view,
1286
- getActionConfigFields,
1287
- calcfldViewConfig,
1288
- strictParseInt,
1289
- run_action_column,
1290
- json_list_to_external_table,
1291
- };