@kaspernj/api-maker 1.0.2011 → 1.0.2013

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 (413) hide show
  1. package/{.eslintrc.cjs → .eslintrc.js} +10 -1
  2. package/README.md +35 -0
  3. package/android/build.gradle +43 -0
  4. package/android/src/main/AndroidManifest.xml +2 -0
  5. package/android/src/main/java/expo/modules/api_maker/ApiMakerModule.kt +50 -0
  6. package/android/src/main/java/expo/modules/api_maker/ApiMakerView.kt +30 -0
  7. package/build/api.js +120 -0
  8. package/build/attribute-not-loaded-error.js +2 -0
  9. package/build/base-component.js +5 -0
  10. package/build/base-error.js +33 -0
  11. package/build/base-model/attribute.js +25 -0
  12. package/build/base-model/column.js +11 -0
  13. package/build/base-model/reflection.js +14 -0
  14. package/build/base-model/scope.js +11 -0
  15. package/build/base-model.js +828 -0
  16. package/build/bootstrap/attribute-row.js +135 -0
  17. package/build/bootstrap/attribute-rows.js +31 -0
  18. package/build/bootstrap/card.js +138 -0
  19. package/build/bootstrap/checkbox.js +97 -0
  20. package/build/bootstrap/checkboxes.js +183 -0
  21. package/build/bootstrap/index.js +2 -0
  22. package/build/bootstrap/input.js +129 -0
  23. package/build/bootstrap/invalid-feedback.js +27 -0
  24. package/build/bootstrap/paginate.js +150 -0
  25. package/build/bootstrap/radio-buttons.js +72 -0
  26. package/build/bootstrap/select.js +88 -0
  27. package/build/bootstrap/sort-link.js +131 -0
  28. package/build/cable-connection-pool.js +128 -0
  29. package/build/cable-subscription-pool.js +207 -0
  30. package/build/cable-subscription.js +21 -0
  31. package/build/cache-key-generator.js +81 -0
  32. package/build/can-can.js +134 -0
  33. package/build/channels-consumer.js +9 -0
  34. package/build/collection-loader.js +48 -0
  35. package/build/collection.js +280 -0
  36. package/build/command-submit-data.js +81 -0
  37. package/build/commands-pool.js +195 -0
  38. package/build/compose.js +9 -0
  39. package/build/config.js +62 -0
  40. package/build/custom-error.js +5 -0
  41. package/build/data-set-to-attributes.js +10 -0
  42. package/build/deserializer.js +56 -0
  43. package/build/destroy-error.js +5 -0
  44. package/build/devise.js +112 -0
  45. package/build/draggable-sort/controller.js +136 -0
  46. package/build/draggable-sort/index.js +114 -0
  47. package/build/draggable-sort/item.js +188 -0
  48. package/build/error-logger.js +101 -0
  49. package/build/error-messages.js +13 -0
  50. package/build/event-connection.js +32 -0
  51. package/build/event-emitter-listener.js +15 -0
  52. package/build/event-model-class.js +24 -0
  53. package/build/events.js +5 -0
  54. package/build/flash-message.js +79 -0
  55. package/build/form.js +83 -0
  56. package/build/history-expo.js +20 -0
  57. package/build/history-react-native.js +20 -0
  58. package/build/history.js +3 -0
  59. package/build/index.js +3 -0
  60. package/build/inputs/attachment.js +133 -0
  61. package/build/inputs/auto-submit.js +36 -0
  62. package/build/inputs/checkbox.js +138 -0
  63. package/build/inputs/checkboxes.js +112 -0
  64. package/build/inputs/id-for-component.js +15 -0
  65. package/build/inputs/input-wrapper.js +19 -0
  66. package/build/inputs/input.js +243 -0
  67. package/build/inputs/money.js +179 -0
  68. package/build/inputs/name-for-component.js +13 -0
  69. package/build/inputs/select.js +93 -0
  70. package/build/instance-of-class-name.js +23 -0
  71. package/build/is-expo.js +22 -0
  72. package/build/key-value-store.js +53 -0
  73. package/build/link.js +73 -0
  74. package/build/logger.js +30 -0
  75. package/build/modal.js +38 -0
  76. package/build/model-class-require.js +13 -0
  77. package/build/model-events.js +30 -0
  78. package/build/model-name.js +28 -0
  79. package/build/model-prop-type.js +101 -0
  80. package/build/model-recipes-loader.js +32 -0
  81. package/build/model-recipes-model-loader.js +357 -0
  82. package/build/models-response-reader.js +40 -0
  83. package/build/models.js +8 -0
  84. package/build/money-formatter.js +78 -0
  85. package/build/not-loaded-error.js +2 -0
  86. package/build/params.js +61 -0
  87. package/build/preloaded.js +38 -0
  88. package/build/resize-observer.js +11 -0
  89. package/build/result.js +13 -0
  90. package/build/router/route.js +270 -0
  91. package/build/router/switch.js +72 -0
  92. package/build/router.js +59 -0
  93. package/build/routes-native.js +202 -0
  94. package/build/routes.js +50 -0
  95. package/build/run-last.js +35 -0
  96. package/build/serializer.js +63 -0
  97. package/build/services.js +20 -0
  98. package/build/session-status-updater.js +134 -0
  99. package/build/source-maps-loader.js +184 -0
  100. package/build/super-admin/config-reader.js +85 -0
  101. package/build/super-admin/edit-page/edit-attribute-checkbox.js +85 -0
  102. package/build/super-admin/edit-page/edit-attribute-content.js +55 -0
  103. package/build/super-admin/edit-page/edit-attribute-input.js +79 -0
  104. package/build/super-admin/edit-page/edit-attribute.js +77 -0
  105. package/build/super-admin/edit-page.js +123 -0
  106. package/build/super-admin/has-edit-config.js +12 -0
  107. package/build/super-admin/index-page.js +25 -0
  108. package/build/super-admin/index.js +181 -0
  109. package/build/super-admin/layout/header/index.js +161 -0
  110. package/build/super-admin/layout/index.js +164 -0
  111. package/build/super-admin/layout/menu/index.js +206 -0
  112. package/build/super-admin/layout/menu/menu-content.js +46 -0
  113. package/build/super-admin/layout/menu/menu-item.js +84 -0
  114. package/build/super-admin/layout/no-access.js +27 -0
  115. package/build/super-admin/model-class-table.js +61 -0
  116. package/build/super-admin/models.js +8 -0
  117. package/build/super-admin/show-nav.js +51 -0
  118. package/build/super-admin/show-page/belongs-to-attribute-row.js +29 -0
  119. package/build/super-admin/show-page/index.js +141 -0
  120. package/build/super-admin/show-reflection-actions.js +47 -0
  121. package/build/super-admin/show-reflection-link.js +48 -0
  122. package/build/super-admin/show-reflection-page.js +48 -0
  123. package/build/table/column-content.js +117 -0
  124. package/build/table/column-identifier.js +18 -0
  125. package/build/table/column-visible.js +7 -0
  126. package/build/table/components/column.js +21 -0
  127. package/build/table/components/flat-list.js +21 -0
  128. package/build/table/components/header.js +26 -0
  129. package/build/table/components/row.js +26 -0
  130. package/build/table/filters/attribute-element.js +44 -0
  131. package/build/table/filters/filter-form.js +402 -0
  132. package/build/table/filters/filter.js +90 -0
  133. package/build/table/filters/index.js +184 -0
  134. package/build/table/filters/load-search-modal.js +175 -0
  135. package/build/table/filters/reflection-element.js +37 -0
  136. package/build/table/filters/save-search-modal.js +88 -0
  137. package/build/table/filters/scope-element.js +42 -0
  138. package/build/table/header-column-content.js +68 -0
  139. package/build/table/header-column.js +144 -0
  140. package/build/table/header-select.js +105 -0
  141. package/build/table/model-callback-args.js +10 -0
  142. package/build/table/model-column.js +97 -0
  143. package/build/table/model-row.js +193 -0
  144. package/build/table/select-calculator.js +63 -0
  145. package/build/table/settings/column-row.js +97 -0
  146. package/build/table/settings/download-action.js +79 -0
  147. package/build/table/settings/index.js +92 -0
  148. package/build/table/table-settings.js +219 -0
  149. package/build/table/table.js +972 -0
  150. package/build/table/use-sorting.js +34 -0
  151. package/build/table/widths.js +75 -0
  152. package/build/table/worker-plugins-check-all-checkbox.js +125 -0
  153. package/build/table/worker-plugins-checkbox.js +115 -0
  154. package/build/translated-attributes.js +10 -0
  155. package/build/translated-collections.js +12 -0
  156. package/build/updated-attribute.js +76 -0
  157. package/build/url-encode.js +15 -0
  158. package/build/use-breakpoint.js +71 -0
  159. package/build/use-can-can.js +55 -0
  160. package/build/use-collection.js +225 -0
  161. package/build/use-created-event.js +52 -0
  162. package/build/use-current-user.js +76 -0
  163. package/build/use-destroyed-event.js +60 -0
  164. package/build/use-event-emitter.js +13 -0
  165. package/build/use-event-listener.js +16 -0
  166. package/build/use-input.js +137 -0
  167. package/build/use-model-event.js +60 -0
  168. package/build/use-model.js +169 -0
  169. package/build/use-resize-observer.js +23 -0
  170. package/build/use-router.js +104 -0
  171. package/build/use-screen-layout.js +39 -0
  172. package/build/use-styles.js +41 -0
  173. package/build/use-updated-event.js +60 -0
  174. package/build/use-validation-errors.js +30 -0
  175. package/build/utils/card.js +51 -0
  176. package/build/utils/checkbox.js +78 -0
  177. package/build/utils/checkboxes.js +163 -0
  178. package/build/utils/default-style.js +18 -0
  179. package/build/utils/icon.js +23 -0
  180. package/build/utils/invalid-feedback.js +19 -0
  181. package/build/utils/modal.js +62 -0
  182. package/build/utils/text.js +44 -0
  183. package/build/validation-error.js +28 -0
  184. package/build/validation-errors.js +98 -0
  185. package/build/with-api-maker.js +29 -0
  186. package/build/with-collection.js +14 -0
  187. package/build/with-current-user.js +10 -0
  188. package/build/with-model.js +15 -0
  189. package/build/with-router.js +22 -0
  190. package/expo-module.config.json +17 -0
  191. package/ios/ApiMaker.podspec +29 -0
  192. package/ios/ApiMakerModule.swift +48 -0
  193. package/ios/ApiMakerView.swift +38 -0
  194. package/package.json +49 -46
  195. package/src/{api.mjs → api.js} +38 -37
  196. package/src/base-component.jsx +5 -0
  197. package/src/{base-error.mjs → base-error.js} +4 -6
  198. package/src/base-model/attribute.js +33 -0
  199. package/src/base-model/column.js +13 -0
  200. package/src/base-model/reflection.js +15 -0
  201. package/src/base-model/scope.js +12 -0
  202. package/src/{base-model.mjs → base-model.js} +302 -144
  203. package/src/bootstrap/attribute-row.jsx +135 -0
  204. package/src/bootstrap/attribute-rows.jsx +27 -0
  205. package/src/bootstrap/card.jsx +149 -0
  206. package/src/bootstrap/checkbox.jsx +86 -0
  207. package/src/bootstrap/checkboxes.jsx +185 -0
  208. package/src/bootstrap/index.js +0 -0
  209. package/src/bootstrap/input.jsx +173 -0
  210. package/src/bootstrap/invalid-feedback.jsx +31 -0
  211. package/src/bootstrap/paginate.jsx +187 -0
  212. package/src/bootstrap/radio-buttons.jsx +87 -0
  213. package/src/bootstrap/select.jsx +110 -0
  214. package/src/bootstrap/sort-link.jsx +106 -0
  215. package/src/{cable-connection-pool.mjs → cable-connection-pool.js} +16 -36
  216. package/src/{cable-subscription-pool.mjs → cable-subscription-pool.js} +26 -21
  217. package/src/{cable-subscription.mjs → cable-subscription.js} +6 -4
  218. package/src/cache-key-generator.js +100 -0
  219. package/src/{can-can.mjs → can-can.js} +13 -12
  220. package/src/channels-consumer.js +10 -0
  221. package/src/collection-loader.jsx +58 -224
  222. package/src/{collection.mjs → collection.js} +98 -44
  223. package/src/{command-submit-data.mjs → command-submit-data.js} +2 -7
  224. package/src/{commands-pool.mjs → commands-pool.js} +57 -41
  225. package/src/compose.js +11 -0
  226. package/src/{config.mjs → config.js} +6 -2
  227. package/src/{custom-error.mjs → custom-error.js} +1 -1
  228. package/src/data-set-to-attributes.js +13 -0
  229. package/src/{deserializer.mjs → deserializer.js} +3 -3
  230. package/src/destroy-error.js +7 -0
  231. package/src/devise.js +129 -0
  232. package/src/draggable-sort/controller.js +137 -0
  233. package/src/draggable-sort/index.jsx +108 -0
  234. package/src/draggable-sort/item.jsx +174 -0
  235. package/src/{error-logger.mjs → error-logger.js} +12 -7
  236. package/src/{error-messages.mjs → error-messages.js} +1 -0
  237. package/src/event-connection.jsx +1 -1
  238. package/src/event-emitter-listener.jsx +8 -27
  239. package/src/event-model-class.jsx +2 -4
  240. package/src/events.js +7 -0
  241. package/src/flash-message.js +70 -0
  242. package/src/form.jsx +91 -0
  243. package/src/history-expo.js +23 -0
  244. package/src/history-react-native.js +25 -0
  245. package/src/history.js +3 -0
  246. package/src/index.js +3 -0
  247. package/src/inputs/attachment.jsx +108 -0
  248. package/src/inputs/auto-submit.js +37 -0
  249. package/src/inputs/checkbox.jsx +125 -0
  250. package/src/inputs/checkboxes.jsx +116 -0
  251. package/src/inputs/id-for-component.js +15 -0
  252. package/src/inputs/input-wrapper.jsx +16 -0
  253. package/src/inputs/input.jsx +260 -0
  254. package/src/inputs/money.jsx +187 -0
  255. package/src/inputs/name-for-component.js +15 -0
  256. package/src/inputs/select.jsx +104 -0
  257. package/src/is-expo.js +18 -0
  258. package/src/{key-value-store.mjs → key-value-store.js} +1 -1
  259. package/src/link.jsx +54 -9
  260. package/src/logger.js +38 -0
  261. package/src/modal.jsx +37 -0
  262. package/src/model-class-require.js +17 -0
  263. package/src/{model-events.mjs → model-events.js} +1 -1
  264. package/src/{model-name.mjs → model-name.js} +8 -8
  265. package/src/{model-recipes-loader.mjs → model-recipes-loader.js} +1 -1
  266. package/src/{model-recipes-model-loader.mjs → model-recipes-model-loader.js} +5 -5
  267. package/src/{models-response-reader.mjs → models-response-reader.js} +3 -4
  268. package/src/models.js +7 -0
  269. package/src/{models.mjs.erb → models.js.erb} +6 -3
  270. package/src/{money-formatter.mjs → money-formatter.js} +5 -4
  271. package/src/{params.mjs → params.js} +17 -7
  272. package/src/{preloaded.mjs → preloaded.js} +2 -2
  273. package/src/resize-observer.jsx +10 -0
  274. package/src/result.js +13 -0
  275. package/src/router/route.jsx +246 -0
  276. package/src/router/switch.jsx +76 -0
  277. package/src/router.jsx +23 -21
  278. package/src/{routes-native.mjs → routes-native.js} +12 -6
  279. package/src/{routes.mjs → routes.js} +1 -1
  280. package/src/run-last.js +39 -0
  281. package/src/{serializer.mjs → serializer.js} +2 -2
  282. package/src/{services.mjs → services.js} +1 -1
  283. package/src/session-status-updater.js +172 -0
  284. package/src/{source-maps-loader.mjs → source-maps-loader.js} +54 -28
  285. package/src/super-admin/config-reader.jsx +93 -0
  286. package/src/super-admin/edit-page/edit-attribute-checkbox.jsx +81 -0
  287. package/src/super-admin/edit-page/edit-attribute-content.jsx +57 -0
  288. package/src/super-admin/edit-page/edit-attribute-input.jsx +71 -0
  289. package/src/super-admin/edit-page/edit-attribute.jsx +81 -0
  290. package/src/super-admin/edit-page.jsx +117 -0
  291. package/src/super-admin/has-edit-config.js +15 -0
  292. package/src/super-admin/index-page.jsx +23 -0
  293. package/src/super-admin/index.jsx +197 -0
  294. package/src/super-admin/layout/header/index.jsx +144 -0
  295. package/src/super-admin/layout/header/style.scss +45 -0
  296. package/src/super-admin/layout/index.jsx +154 -0
  297. package/src/super-admin/layout/menu/index.jsx +171 -0
  298. package/src/super-admin/layout/menu/menu-content.jsx +43 -0
  299. package/src/super-admin/layout/menu/menu-item.jsx +70 -0
  300. package/src/super-admin/layout/menu/style.scss +11 -0
  301. package/src/super-admin/layout/no-access.jsx +26 -0
  302. package/src/super-admin/model-class-table.jsx +66 -0
  303. package/src/super-admin/models.js +11 -0
  304. package/src/super-admin/show-nav.jsx +44 -0
  305. package/src/super-admin/show-page/belongs-to-attribute-row.jsx +30 -0
  306. package/src/super-admin/show-page/index.jsx +141 -0
  307. package/src/super-admin/show-reflection-actions.jsx +49 -0
  308. package/src/super-admin/show-reflection-link.jsx +40 -0
  309. package/src/super-admin/show-reflection-page.jsx +47 -0
  310. package/src/super-admin/stylesheets/variables.scss +11 -0
  311. package/src/table/column-content.jsx +122 -0
  312. package/src/table/column-identifier.js +23 -0
  313. package/src/table/column-visible.js +7 -0
  314. package/src/table/components/column.jsx +19 -0
  315. package/src/table/components/flat-list.jsx +19 -0
  316. package/src/table/components/header.jsx +21 -0
  317. package/src/table/components/row.jsx +23 -0
  318. package/src/table/filters/attribute-element.jsx +47 -0
  319. package/src/table/filters/filter-form.jsx +407 -0
  320. package/src/table/filters/filter.jsx +70 -0
  321. package/src/table/filters/index.jsx +170 -0
  322. package/src/table/filters/load-search-modal.jsx +146 -0
  323. package/src/table/filters/reflection-element.jsx +38 -0
  324. package/src/table/filters/save-search-modal.jsx +74 -0
  325. package/src/table/filters/scope-element.jsx +44 -0
  326. package/src/table/header-column-content.jsx +55 -0
  327. package/src/table/header-column.jsx +129 -0
  328. package/src/table/header-select.jsx +73 -0
  329. package/src/table/model-callback-args.js +10 -0
  330. package/src/table/model-column.jsx +82 -0
  331. package/src/table/model-row.jsx +136 -0
  332. package/src/table/select-calculator.js +65 -0
  333. package/src/table/settings/column-row.jsx +93 -0
  334. package/src/table/settings/download-action.jsx +68 -0
  335. package/src/table/settings/index.jsx +65 -0
  336. package/src/table/table-settings.js +263 -0
  337. package/src/table/table.jsx +950 -0
  338. package/src/table/use-sorting.js +35 -0
  339. package/src/table/variables.scss +11 -0
  340. package/src/table/widths.jsx +87 -0
  341. package/src/table/worker-plugins-check-all-checkbox.jsx +112 -0
  342. package/src/table/worker-plugins-checkbox.jsx +104 -0
  343. package/src/translated-attributes.js +11 -0
  344. package/src/{translated-collections.mjs → translated-collections.js} +3 -2
  345. package/src/updated-attribute.jsx +1 -1
  346. package/src/url-encode.js +18 -0
  347. package/src/use-breakpoint.js +87 -0
  348. package/src/use-can-can.js +55 -0
  349. package/src/use-collection.js +280 -0
  350. package/src/use-created-event.js +55 -0
  351. package/src/use-current-user.js +88 -0
  352. package/src/use-destroyed-event.js +60 -0
  353. package/src/use-event-emitter.js +15 -0
  354. package/src/use-event-listener.js +19 -0
  355. package/src/use-input.js +157 -0
  356. package/src/use-model-event.js +60 -0
  357. package/src/use-model.js +189 -0
  358. package/src/use-resize-observer.js +24 -0
  359. package/src/use-router.jsx +128 -0
  360. package/src/use-screen-layout.js +49 -0
  361. package/src/use-styles.js +50 -0
  362. package/src/use-updated-event.js +60 -0
  363. package/src/use-validation-errors.js +33 -0
  364. package/src/utils/card.jsx +49 -0
  365. package/src/utils/checkbox.jsx +80 -0
  366. package/src/utils/checkboxes.jsx +158 -0
  367. package/src/utils/default-style.jsx +25 -0
  368. package/src/utils/icon.jsx +21 -0
  369. package/src/utils/invalid-feedback.jsx +20 -0
  370. package/src/utils/modal.jsx +60 -0
  371. package/src/utils/text.jsx +38 -0
  372. package/src/{validation-error.mjs → validation-error.js} +9 -5
  373. package/src/{validation-errors.mjs → validation-errors.js} +15 -27
  374. package/src/with-api-maker.jsx +31 -0
  375. package/src/with-collection.jsx +17 -0
  376. package/src/with-current-user.jsx +7 -25
  377. package/src/with-model.jsx +16 -0
  378. package/src/with-router.jsx +7 -129
  379. package/__tests__/base-model.test.js +0 -71
  380. package/__tests__/cable-connection-pool.test.js +0 -227
  381. package/__tests__/cable-subscription-pool.test.js +0 -26
  382. package/__tests__/can-can.test.js +0 -34
  383. package/__tests__/collection.test.js +0 -51
  384. package/__tests__/custom-error.test.js +0 -13
  385. package/__tests__/model-name.test.js +0 -34
  386. package/__tests__/model-prop-type.test.js +0 -113
  387. package/__tests__/params.test.js +0 -40
  388. package/__tests__/routes-native.test.js +0 -103
  389. package/__tests__/routes.test.js +0 -46
  390. package/__tests__/serializer.test.js +0 -30
  391. package/__tests__/support/task.js +0 -27
  392. package/__tests__/support/user.js +0 -32
  393. package/index.js +0 -1
  394. package/jest.config.js +0 -4
  395. package/src/can-can-loader.jsx +0 -54
  396. package/src/channels-consumer.mjs +0 -3
  397. package/src/destroy-error.mjs +0 -7
  398. package/src/devise.mjs +0 -122
  399. package/src/event-created.jsx +0 -65
  400. package/src/event-destroyed.jsx +0 -29
  401. package/src/event-listener.jsx +0 -38
  402. package/src/event-updated.jsx +0 -74
  403. package/src/logger.mjs +0 -25
  404. package/src/model-class-require.mjs +0 -10
  405. package/src/model-load-wrapper.jsx +0 -116
  406. package/src/result.mjs +0 -29
  407. package/src/session-status-updater.mjs +0 -116
  408. package/webpack.config.js +0 -15
  409. /package/src/{attribute-not-loaded-error.mjs → attribute-not-loaded-error.js} +0 -0
  410. /package/src/{instance-of-class-name.mjs → instance-of-class-name.js} +0 -0
  411. /package/src/{model-prop-type.mjs → model-prop-type.js} +0 -0
  412. /package/src/{not-loaded-error.mjs → not-loaded-error.js} +0 -0
  413. /package/src/{translated-collections-data.mjs.erb → translated-collections-data.js.erb} +0 -0
@@ -0,0 +1,972 @@
1
+ function _extends() { return _extends = Object.assign ? Object.assign.bind() : function (n) { for (var e = 1; e < arguments.length; e++) { var t = arguments[e]; for (var r in t) ({}).hasOwnProperty.call(t, r) && (n[r] = t[r]); } return n; }, _extends.apply(null, arguments); }
2
+ import { digg, digs } from "diggerize";
3
+ import React, { createContext, useContext, useMemo, useRef } from "react";
4
+ import { Animated, Pressable, View } from "react-native";
5
+ import BaseComponent from "../base-component";
6
+ import Card from "../bootstrap/card";
7
+ import classNames from "classnames";
8
+ import Collection from "../collection";
9
+ import columnVisible from "./column-visible";
10
+ import debounce from "debounce";
11
+ import DraggableSort from "../draggable-sort/index";
12
+ import EventEmitter from "events";
13
+ import Filters from "./filters";
14
+ import FlatList from "./components/flat-list";
15
+ import { Form } from "../form";
16
+ import Header from "./components/header";
17
+ import HeaderColumn from "./header-column";
18
+ import HeaderSelect from "./header-select";
19
+ import Icon from "../utils/icon";
20
+ import * as inflection from "inflection";
21
+ import memo from "set-state-compare/src/memo";
22
+ import modelClassRequire from "../model-class-require";
23
+ import ModelRow from "./model-row";
24
+ import Paginate from "../bootstrap/paginate";
25
+ import Params from "../params";
26
+ import PropTypes from "prop-types";
27
+ import Row from "./components/row";
28
+ import selectCalculator from "./select-calculator";
29
+ import Select from "../inputs/select";
30
+ import Settings from "./settings/index";
31
+ import { shapeComponent } from "set-state-compare/src/shape-component";
32
+ import TableSettings from "./table-settings";
33
+ import Text from "../utils/text";
34
+ import uniqunize from "uniqunize";
35
+ import useBreakpoint from "../use-breakpoint";
36
+ import useCollection from "../use-collection";
37
+ import useI18n from "i18n-on-steroids/src/use-i18n";
38
+ import useEventEmitter from "../use-event-emitter";
39
+ import useModelEvent from "../use-model-event";
40
+ import useQueryParams from "on-location-changed/build/use-query-params";
41
+ import Widths from "./widths";
42
+ const paginationOptions = [30, 60, 90, ["All", "all"]];
43
+ const WorkerPluginsCheckAllCheckbox = /*#__PURE__*/React.lazy(() => import("./worker-plugins-check-all-checkbox"));
44
+ const TableContext = /*#__PURE__*/createContext();
45
+ const ListHeaderComponent = memo(shapeComponent(class ListHeaderComponent extends BaseComponent {
46
+ setup() {
47
+ this.useStates({
48
+ lastUpdate: new Date()
49
+ });
50
+ }
51
+ render() {
52
+ const {
53
+ mdUp
54
+ } = useBreakpoint();
55
+ const tableContextValue = useContext(TableContext);
56
+ const table = tableContextValue.table;
57
+ const {
58
+ collection,
59
+ events,
60
+ queryWithoutPagination,
61
+ t
62
+ } = table.tt;
63
+ const {
64
+ query
65
+ } = digs(collection, "query");
66
+ useEventEmitter(events, "columnVisibilityUpdated", this.tt.onColumnVisibilityUpdated);
67
+ return /*#__PURE__*/React.createElement(Row, {
68
+ dataSet: {
69
+ class: "api-maker/table/header-row"
70
+ },
71
+ style: table.styleForRowHeader()
72
+ }, table.p.workplace && table.s.currentWorkplace && /*#__PURE__*/React.createElement(Header, {
73
+ style: table.styleForHeader({
74
+ style: {
75
+ width: mdUp ? 41 : undefined
76
+ }
77
+ })
78
+ }, /*#__PURE__*/React.createElement(WorkerPluginsCheckAllCheckbox, {
79
+ currentWorkplace: table.s.currentWorkplace,
80
+ query: queryWithoutPagination,
81
+ style: {
82
+ marginHorizontal: "auto"
83
+ }
84
+ }), !mdUp && /*#__PURE__*/React.createElement(Text, {
85
+ style: {
86
+ marginLeft: 3
87
+ }
88
+ }, t(".select_all_found", {
89
+ defaultValue: "Select all found"
90
+ }))), !mdUp && /*#__PURE__*/React.createElement(Header, {
91
+ style: table.styleForHeader({
92
+ style: {}
93
+ })
94
+ }, /*#__PURE__*/React.createElement(HeaderSelect, {
95
+ preparedColumns: table.s.preparedColumns,
96
+ query: query,
97
+ table: table
98
+ })), mdUp && /*#__PURE__*/React.createElement(React.Fragment, null, table.headersContentFromColumns(), /*#__PURE__*/React.createElement(Header, {
99
+ style: table.styleForHeader({
100
+ style: {},
101
+ type: "actions"
102
+ })
103
+ })));
104
+ }
105
+ onColumnVisibilityUpdated = () => this.setState({
106
+ lastUpdate: new Date()
107
+ });
108
+ }));
109
+ export default memo(shapeComponent(class ApiMakerTable extends BaseComponent {
110
+ static defaultProps = {
111
+ card: true,
112
+ currentUser: null,
113
+ destroyEnabled: true,
114
+ filterCard: true,
115
+ filterSubmitButton: true,
116
+ noRecordsAvailableContent: undefined,
117
+ noRecordsFoundContent: undefined,
118
+ preloads: [],
119
+ select: {},
120
+ styleUI: true,
121
+ workplace: false
122
+ };
123
+ static propTypes = {
124
+ abilities: PropTypes.object,
125
+ actionsContent: PropTypes.func,
126
+ appHistory: PropTypes.object,
127
+ card: PropTypes.bool.isRequired,
128
+ className: PropTypes.string,
129
+ collection: PropTypes.instanceOf(Collection),
130
+ columns: PropTypes.oneOfType([PropTypes.array, PropTypes.func]),
131
+ controls: PropTypes.func,
132
+ currentUser: PropTypes.object,
133
+ defaultDateFormatName: PropTypes.string,
134
+ defaultDateTimeFormatName: PropTypes.string,
135
+ defaultParams: PropTypes.object,
136
+ destroyEnabled: PropTypes.bool.isRequired,
137
+ destroyMessage: PropTypes.string,
138
+ editModelPath: PropTypes.func,
139
+ filterCard: PropTypes.bool.isRequired,
140
+ filterContent: PropTypes.func,
141
+ filterSubmitLabel: PropTypes.node,
142
+ groupBy: PropTypes.array,
143
+ header: PropTypes.oneOfType([PropTypes.func, PropTypes.string]),
144
+ identifier: PropTypes.string,
145
+ modelClass: PropTypes.func.isRequired,
146
+ noRecordsAvailableContent: PropTypes.func,
147
+ noRecordsFoundContent: PropTypes.func,
148
+ onModelsLoaded: PropTypes.func,
149
+ paginateContent: PropTypes.func,
150
+ paginationComponent: PropTypes.func,
151
+ preloads: PropTypes.array.isRequired,
152
+ queryMethod: PropTypes.func,
153
+ queryName: PropTypes.string,
154
+ select: PropTypes.object,
155
+ selectColumns: PropTypes.object,
156
+ styles: PropTypes.object,
157
+ styleUI: PropTypes.bool.isRequired,
158
+ viewModelPath: PropTypes.func,
159
+ workplace: PropTypes.bool.isRequired
160
+ };
161
+ draggableSortEvents = new EventEmitter();
162
+ events = new EventEmitter();
163
+ tableSettings = null;
164
+ setup() {
165
+ const {
166
+ t
167
+ } = useI18n({
168
+ namespace: "js.api_maker.table"
169
+ });
170
+ const {
171
+ name: breakpoint,
172
+ mdUp
173
+ } = useBreakpoint();
174
+ const queryParams = useQueryParams();
175
+ this.setInstance({
176
+ breakpoint,
177
+ filterFormRef: useRef(),
178
+ mdUp,
179
+ t
180
+ });
181
+ const collectionKey = digg(this.p.modelClass.modelClassData(), "collectionKey");
182
+ let queryName = this.props.queryName;
183
+ if (!queryName) queryName = collectionKey;
184
+ const querySName = `${queryName}_s`;
185
+ this.useStates({
186
+ columns: () => this.columnsAsArray(),
187
+ currentWorkplace: undefined,
188
+ currentWorkplaceCount: null,
189
+ filterForm: null,
190
+ columnsToShow: null,
191
+ draggedColumn: null,
192
+ identifier: () => this.props.identifier || `${collectionKey}-default`,
193
+ lastUpdate: () => new Date(),
194
+ preload: undefined,
195
+ preparedColumns: undefined,
196
+ queryName,
197
+ queryQName: () => `${queryName}_q`,
198
+ queryPageName: () => `${queryName}_page`,
199
+ querySName,
200
+ resizing: false,
201
+ showFilters: () => Boolean(queryParams[querySName]),
202
+ showSettings: false,
203
+ tableSetting: undefined,
204
+ tableSettingLoaded: false,
205
+ tableSettingFullCacheKey: undefined,
206
+ width: undefined,
207
+ widths: null
208
+ });
209
+ this.tableContextValue = useMemo(() => ({
210
+ cacheKey: this.s.tableSettingFullCacheKey,
211
+ lastUpdate: this.s.lastUpdate,
212
+ resizing: this.s.resizing,
213
+ table: this
214
+ }), [this.s.lastUpdate, this.s.resizing, this.s.tableSettingFullCacheKey]);
215
+ useMemo(() => {
216
+ if (this.props.workplace) {
217
+ this.loadCurrentWorkplace().then(() => {
218
+ this.loadCurrentWorkplaceCount();
219
+ });
220
+ }
221
+ }, [this.p.currentUser?.id()]);
222
+ useMemo(() => {
223
+ if (!this.tt.tableSettings && this.s.width) {
224
+ this.loadTableSetting();
225
+ }
226
+ }, [this.p.currentUser?.id(), this.s.width]);
227
+ useModelEvent(this.s.currentWorkplace, "workplace_links_created", this.tt.onLinksCreated);
228
+ useModelEvent(this.s.currentWorkplace, "workplace_links_destroyed", this.tt.onLinksDestroyed);
229
+ let collectionReady = true;
230
+ let select;
231
+ if (!this.s.preparedColumns) {
232
+ collectionReady = false;
233
+ }
234
+ if (collectionReady) {
235
+ select = selectCalculator({
236
+ table: this
237
+ });
238
+ }
239
+ this.collection = useCollection({
240
+ abilities: this.abilitiesToLoad(),
241
+ defaultParams: this.props.defaultParams,
242
+ collection: this.props.collection,
243
+ groupBy: this.props.groupBy,
244
+ ifCondition: collectionReady,
245
+ modelClass: this.props.modelClass,
246
+ onModelsLoaded: this.props.onModelsLoaded,
247
+ noRecordsAvailableContent: this.props.noRecordsAvailableContent,
248
+ noRecordsFoundContent: this.props.noRecordsFoundContent,
249
+ pagination: true,
250
+ preloads: this.state.preload,
251
+ queryMethod: this.props.queryMethod,
252
+ queryName,
253
+ select,
254
+ selectColumns: this.props.selectColumns
255
+ });
256
+ this.queryWithoutPagination = useMemo(() => this.collection?.query?.clone()?.except("page"), [this.collection.query]);
257
+ useEventEmitter(this.tt.draggableSortEvents, "onDragStart", this.tt.onDragStart);
258
+ useEventEmitter(this.tt.draggableSortEvents, "onDragEndAnimation", this.tt.onDragEndAnimation);
259
+ useEventEmitter(this.tt.events, "columnVisibilityUpdated", this.tt.onColumnVisibilityUpdated);
260
+ }
261
+ onColumnVisibilityUpdated = () => this.setState({
262
+ columnsToShow: this.getColumnsToShow(this.s.columns),
263
+ lastUpdate: new Date()
264
+ });
265
+ onDragStart = ({
266
+ item
267
+ }) => item.animatedZIndex.setValue(9999);
268
+ onDragEndAnimation = ({
269
+ item
270
+ }) => item.animatedZIndex.setValue(0);
271
+ async loadCurrentWorkplace() {
272
+ const Workplace = modelClassRequire("Workplace");
273
+ const result = await Workplace.current();
274
+ const currentWorkplace = digg(result, "current", 0);
275
+ this.setState({
276
+ currentWorkplace
277
+ });
278
+ }
279
+ async loadCurrentWorkplaceCount() {
280
+ const WorkplaceLink = modelClassRequire("WorkplaceLink");
281
+ const currentWorkplaceCount = await WorkplaceLink.ransack({
282
+ resource_type_eq: this.p.modelClass.modelClassData().name,
283
+ workplace_id_eq: this.s.currentWorkplace.id()
284
+ }).count();
285
+ this.setState({
286
+ currentWorkplaceCount
287
+ });
288
+ }
289
+ getColumnsToShow(columns) {
290
+ return columns.filter(({
291
+ column,
292
+ tableSettingColumn
293
+ }) => columnVisible(column, tableSettingColumn)).sort((a, b) => a.tableSettingColumn.position() - b.tableSettingColumn.position());
294
+ }
295
+ async loadTableSetting() {
296
+ this.tableSettings = new TableSettings({
297
+ table: this
298
+ });
299
+ const tableSetting = await this.tableSettings.loadExistingOrCreateTableSettings();
300
+ const {
301
+ columns,
302
+ preload
303
+ } = this.tableSettings.preparedColumns(tableSetting);
304
+ const {
305
+ width
306
+ } = this.s;
307
+ const widths = new Widths({
308
+ columns,
309
+ table: this,
310
+ width
311
+ });
312
+ const columnsToShow = this.getColumnsToShow(columns);
313
+ this.setState({
314
+ columns,
315
+ columnsToShow,
316
+ preparedColumns: columns,
317
+ preload: this.mergedPreloads(preload),
318
+ tableSetting,
319
+ tableSettingLoaded: true,
320
+ tableSettingFullCacheKey: tableSetting.fullCacheKey(),
321
+ widths
322
+ });
323
+ }
324
+ updateSettingsFullCacheKey = () => this.setState({
325
+ tableSettingFullCacheKey: this.state.tableSetting.fullCacheKey()
326
+ });
327
+ columnsAsArray = () => {
328
+ if (typeof this.props.columns == "function") {
329
+ return this.props.columns();
330
+ }
331
+ return this.props.columns;
332
+ };
333
+ mergedPreloads(preload) {
334
+ const {
335
+ preloads
336
+ } = this.props;
337
+ let mergedPreloads = [];
338
+ if (preloads) mergedPreloads = mergedPreloads.concat(preloads);
339
+ if (preload) mergedPreloads = mergedPreloads.concat(preload);
340
+ return uniqunize(mergedPreloads);
341
+ }
342
+ render() {
343
+ const {
344
+ modelClass,
345
+ noRecordsAvailableContent,
346
+ noRecordsFoundContent
347
+ } = this.p;
348
+ const {
349
+ collection,
350
+ currentUser
351
+ } = this.props;
352
+ const {
353
+ queryName,
354
+ querySName,
355
+ showFilters
356
+ } = this.s;
357
+ const {
358
+ models,
359
+ overallCount,
360
+ qParams,
361
+ query,
362
+ result,
363
+ showNoRecordsAvailableContent,
364
+ showNoRecordsFoundContent
365
+ } = digs(this.collection, "models", "overallCount", "qParams", "query", "result", "showNoRecordsAvailableContent", "showNoRecordsFoundContent");
366
+ if (collection && collection.args.modelClass.modelClassData().name != modelClass.modelClassData().name) {
367
+ throw new Error(`Model class from collection '${collection.args.modelClass.modelClassData().name}' ` + `didn't match model class on table: '${modelClass.modelClassData().name}'`);
368
+ }
369
+ return /*#__PURE__*/React.createElement(View, {
370
+ dataSet: {
371
+ class: this.className()
372
+ },
373
+ onLayout: this.tt.onContainerLayout,
374
+ style: this.props.styles?.container
375
+ }, showNoRecordsAvailableContent && /*#__PURE__*/React.createElement("div", {
376
+ className: "live-table--no-records-available-content"
377
+ }, noRecordsAvailableContent({
378
+ models,
379
+ qParams,
380
+ overallCount
381
+ })), showNoRecordsFoundContent && /*#__PURE__*/React.createElement("div", {
382
+ className: "live-table--no-records-found-content"
383
+ }, noRecordsFoundContent({
384
+ models,
385
+ qParams,
386
+ overallCount
387
+ })), showFilters && /*#__PURE__*/React.createElement(Filters, {
388
+ currentUser: currentUser,
389
+ modelClass: modelClass,
390
+ queryName: queryName,
391
+ querySName: querySName
392
+ }), qParams && query && result && models && !showNoRecordsAvailableContent && !showNoRecordsFoundContent && this.cardOrTable());
393
+ }
394
+ abilitiesToLoad() {
395
+ const abilitiesToLoad = {};
396
+ const {
397
+ abilities,
398
+ modelClass
399
+ } = this.props;
400
+ const ownAbilities = [];
401
+ if (this.props.destroyEnabled) ownAbilities.push("destroy");
402
+ if (this.props.editModelPath) ownAbilities.push("edit");
403
+ if (this.props.viewModelPath) ownAbilities.push("show");
404
+ if (ownAbilities.length > 0) {
405
+ const modelClassName = digg(modelClass.modelClassData(), "name");
406
+ abilitiesToLoad[modelClassName] = ownAbilities;
407
+ }
408
+ if (abilities) {
409
+ for (const modelName in abilities) {
410
+ if (!(modelName in abilitiesToLoad)) {
411
+ abilitiesToLoad[modelName] = [];
412
+ }
413
+ for (const ability of abilities[modelName]) {
414
+ abilitiesToLoad[modelName].push(ability);
415
+ }
416
+ }
417
+ }
418
+ return abilitiesToLoad;
419
+ }
420
+ cardOrTable() {
421
+ const {
422
+ abilities,
423
+ actionsContent,
424
+ appHistory,
425
+ card,
426
+ className,
427
+ collection,
428
+ columns,
429
+ controls,
430
+ currentUser,
431
+ defaultDateFormatName,
432
+ defaultDateTimeFormatName,
433
+ defaultParams,
434
+ destroyEnabled,
435
+ destroyMessage,
436
+ editModelPath,
437
+ filterCard,
438
+ filterContent,
439
+ filterSubmitButton,
440
+ filterSubmitLabel,
441
+ groupBy,
442
+ header,
443
+ identifier,
444
+ modelClass,
445
+ noRecordsAvailableContent,
446
+ noRecordsFoundContent,
447
+ onModelsLoaded,
448
+ paginateContent,
449
+ paginationComponent,
450
+ preloads,
451
+ queryMethod,
452
+ queryName,
453
+ select,
454
+ selectColumns,
455
+ styleUI,
456
+ viewModelPath,
457
+ workplace,
458
+ ...restProps
459
+ } = this.props;
460
+ const {
461
+ models,
462
+ qParams,
463
+ query,
464
+ result
465
+ } = digs(this.collection, "models", "qParams", "query", "result");
466
+ let headerContent, PaginationComponent;
467
+ if (typeof header == "function") {
468
+ headerContent = header({
469
+ models,
470
+ qParams,
471
+ query,
472
+ result
473
+ });
474
+ } else if (header) {
475
+ headerContent = header;
476
+ } else {
477
+ headerContent = modelClass.modelName().human({
478
+ count: 2
479
+ });
480
+ }
481
+ if (!paginateContent) {
482
+ if (paginationComponent) {
483
+ PaginationComponent = paginationComponent;
484
+ } else {
485
+ PaginationComponent = Paginate;
486
+ }
487
+ }
488
+ const flatListStyle = {
489
+ overflowX: "auto"
490
+ };
491
+ if (styleUI) {
492
+ flatListStyle.border = "1px solid #dbdbdb";
493
+ flatListStyle.borderRadius = 5;
494
+ }
495
+ const flatList = /*#__PURE__*/React.createElement(TableContext.Provider, {
496
+ value: this.tt.tableContextValue
497
+ }, /*#__PURE__*/React.createElement(FlatList, _extends({
498
+ data: models,
499
+ dataSet: {
500
+ class: classNames("api-maker--table", className),
501
+ cacheKey: this.s.tableSettingFullCacheKey,
502
+ lastUpdate: this.s.lastUpdate
503
+ },
504
+ extraData: this.s.lastUpdate,
505
+ keyExtractor: this.tt.keyExtrator,
506
+ ListHeaderComponent: ListHeaderComponent,
507
+ renderItem: this.tt.renderItem,
508
+ showsHorizontalScrollIndicator: true,
509
+ style: flatListStyle
510
+ }, restProps)));
511
+ return /*#__PURE__*/React.createElement(React.Fragment, null, filterContent && filterCard && /*#__PURE__*/React.createElement(Card, {
512
+ className: "live-table--filter-card mb-4"
513
+ }, this.filterForm()), filterContent && !filterCard && this.filterForm(), card && /*#__PURE__*/React.createElement(Card, _extends({
514
+ className: classNames("live-table--table-card", "mb-4", className),
515
+ controls: this.tableControls(),
516
+ header: headerContent,
517
+ footer: this.tableFooter()
518
+ }, restProps), flatList), !card && flatList, result && PaginationComponent && /*#__PURE__*/React.createElement(PaginationComponent, {
519
+ result: result
520
+ }), result && paginateContent && paginateContent({
521
+ result
522
+ }));
523
+ }
524
+ onContainerLayout = e => {
525
+ const {
526
+ width
527
+ } = e.nativeEvent.layout;
528
+ const {
529
+ widths
530
+ } = this.s;
531
+ this.setState({
532
+ width
533
+ });
534
+ if (widths) widths.tableWidth = width;
535
+ };
536
+ onLinksCreated = ({
537
+ args
538
+ }) => {
539
+ const modelClassName = this.p.modelClass.modelClassData().name;
540
+ if (args.created[modelClassName]) {
541
+ const amountCreated = args.created[modelClassName].length;
542
+ this.setState(prevState => ({
543
+ currentWorkplaceCount: prevState.currentWorkplaceCount + amountCreated
544
+ }));
545
+ }
546
+ };
547
+ onLinksDestroyed = ({
548
+ args
549
+ }) => {
550
+ const modelClassName = this.p.modelClass.modelClassData().name;
551
+ if (args.destroyed[modelClassName]) {
552
+ const amountDestroyed = args.destroyed[modelClassName].length;
553
+ this.setState(prevState => ({
554
+ currentWorkplaceCount: prevState.currentWorkplaceCount - amountDestroyed
555
+ }));
556
+ }
557
+ };
558
+ keyExtrator = model => `${this.s.tableSettingFullCacheKey}-${model.id()}`;
559
+ filterForm = () => {
560
+ const {
561
+ filterFormRef,
562
+ submitFilter,
563
+ submitFilterDebounce
564
+ } = this.tt;
565
+ const {
566
+ filterContent,
567
+ filterSubmitButton
568
+ } = this.p;
569
+ const {
570
+ queryQName
571
+ } = this.s;
572
+ const {
573
+ filterSubmitLabel
574
+ } = this.props;
575
+ const {
576
+ qParams
577
+ } = digs(this.collection, "qParams");
578
+ return /*#__PURE__*/React.createElement(Form, {
579
+ className: "live-table--filter-form",
580
+ formRef: filterFormRef,
581
+ onSubmit: this.tt.onFilterFormSubmit,
582
+ setForm: this.setStates.filterForm
583
+ }, "s" in qParams && /*#__PURE__*/React.createElement("input", {
584
+ name: "s",
585
+ type: "hidden",
586
+ value: qParams.s
587
+ }), filterContent({
588
+ onFilterChanged: submitFilter,
589
+ onFilterChangedWithDelay: submitFilterDebounce,
590
+ qParams,
591
+ queryQName
592
+ }), filterSubmitButton && /*#__PURE__*/React.createElement("input", {
593
+ className: "btn btn-primary live-table--submit-filter-button",
594
+ type: "submit",
595
+ style: {
596
+ marginTop: "8px"
597
+ },
598
+ value: filterSubmitLabel || this.t(".filter", {
599
+ defaultValue: "Filter"
600
+ })
601
+ }));
602
+ };
603
+ onFilterClicked = e => {
604
+ e.preventDefault();
605
+ this.setState({
606
+ showFilters: !this.state.showFilters
607
+ });
608
+ };
609
+ onPerPageChanged = e => {
610
+ const {
611
+ queryName
612
+ } = this.s;
613
+ const newPerPageValue = digg(e, "target", "value");
614
+ const perKey = `${queryName}_per`;
615
+ const paramsChange = {};
616
+ paramsChange[perKey] = newPerPageValue;
617
+ Params.changeParams(paramsChange);
618
+ };
619
+ renderItem = ({
620
+ index,
621
+ item: model
622
+ }) => {
623
+ if (!this.s.tableSettingLoaded) {
624
+ return /*#__PURE__*/React.createElement(View, null, /*#__PURE__*/React.createElement(Text, null, this.t(".loading_dot_dot_dot", {
625
+ defaultValue: "Loading..."
626
+ })));
627
+ }
628
+ return /*#__PURE__*/React.createElement(ModelRow, {
629
+ cacheKey: model.cacheKey(),
630
+ columns: this.s.columnsToShow,
631
+ columnWidths: this.columnWidths(),
632
+ events: this.tt.events,
633
+ index: index,
634
+ key: model.id(),
635
+ model: model,
636
+ table: this,
637
+ tableSettingFullCacheKey: this.s.tableSettingFullCacheKey
638
+ });
639
+ };
640
+ styleForColumn = ({
641
+ column,
642
+ columnIndex,
643
+ even,
644
+ style,
645
+ type
646
+ }) => {
647
+ const {
648
+ styleUI
649
+ } = this.p;
650
+ const defaultStyle = {
651
+ justifyContent: "center",
652
+ padding: 8,
653
+ overflow: "hidden"
654
+ };
655
+ if (styleUI) {
656
+ Object.assign(defaultStyle, {
657
+ backgroundColor: even ? "#f5f5f5" : "#fff"
658
+ });
659
+ }
660
+ if (type == "actions") {
661
+ defaultStyle.flexDirection = "row";
662
+ defaultStyle.alignItems = "center";
663
+ if (this.tt.mdUp) {
664
+ defaultStyle.marginLeft = "auto";
665
+ } else {
666
+ defaultStyle.marginRight = "auto";
667
+ }
668
+ } else if (this.tt.mdUp && styleUI) {
669
+ defaultStyle.borderRight = "1px solid #dbdbdb";
670
+ }
671
+ const actualStyle = Object.assign(defaultStyle, style);
672
+ return actualStyle;
673
+ };
674
+ styleForHeader = ({
675
+ column,
676
+ columnIndex,
677
+ style,
678
+ type
679
+ }) => {
680
+ const {
681
+ mdUp
682
+ } = this.tt;
683
+ const defaultStyle = {
684
+ flexDirection: "row",
685
+ alignItems: "center",
686
+ padding: 8
687
+ };
688
+ if (type != "actions" && mdUp && this.p.styleUI) {
689
+ defaultStyle.borderRight = "1px solid #dbdbdb";
690
+ }
691
+ const actualStyle = Object.assign(defaultStyle, style);
692
+ return actualStyle;
693
+ };
694
+ styleForHeaderText() {
695
+ const actualStyle = {
696
+ fontWeight: "bold"
697
+ };
698
+ return actualStyle;
699
+ }
700
+ styleForRow = ({
701
+ even
702
+ } = {}) => {
703
+ const actualStyle = {
704
+ flex: 1,
705
+ alignItems: "stretch"
706
+ };
707
+ if (even && this.p.styleUI) {
708
+ actualStyle.backgroundColor = "#f5f5f5";
709
+ }
710
+ return actualStyle;
711
+ };
712
+ styleForRowHeader = () => {
713
+ const actualStyle = {
714
+ flex: 1,
715
+ alignItems: "stretch"
716
+ };
717
+ return actualStyle;
718
+ };
719
+ tableControls() {
720
+ const {
721
+ controls
722
+ } = this.props;
723
+ const {
724
+ showSettings
725
+ } = this.s;
726
+ const {
727
+ models,
728
+ qParams,
729
+ query,
730
+ result
731
+ } = digs(this.collection, "models", "qParams", "query", "result");
732
+ return /*#__PURE__*/React.createElement(View, {
733
+ style: {
734
+ flexDirection: "row"
735
+ }
736
+ }, controls && controls({
737
+ models,
738
+ qParams,
739
+ query,
740
+ result
741
+ }), /*#__PURE__*/React.createElement(Pressable, {
742
+ dataSet: {
743
+ class: "filter-button"
744
+ },
745
+ onPress: this.tt.onFilterClicked
746
+ }, /*#__PURE__*/React.createElement(Icon, {
747
+ name: "search",
748
+ size: 20
749
+ })), /*#__PURE__*/React.createElement(View, {
750
+ style: {
751
+ position: "relative"
752
+ }
753
+ }, showSettings && /*#__PURE__*/React.createElement(Settings, {
754
+ onRequestClose: this.tt.onRequestCloseSettings,
755
+ table: this
756
+ }), /*#__PURE__*/React.createElement(Pressable, {
757
+ dataSet: {
758
+ class: "settings-button"
759
+ },
760
+ onPress: this.tt.onSettingsClicked
761
+ }, /*#__PURE__*/React.createElement(Icon, {
762
+ name: "gear",
763
+ size: 20
764
+ }))));
765
+ }
766
+ tableFooter() {
767
+ const {
768
+ result
769
+ } = digs(this.collection, "result");
770
+ const currentPage = result.currentPage();
771
+ const totalCount = result.totalCount();
772
+ const perPage = result.perPage();
773
+ const to = Math.min(currentPage * perPage, totalCount);
774
+ const defaultValue = "Showing %{from} to %{to} out of %{total_count} total.";
775
+ let from = (currentPage - 1) * perPage + 1;
776
+ if (to === 0) from = 0;
777
+ return /*#__PURE__*/React.createElement(View, {
778
+ style: {
779
+ flexDirection: "row",
780
+ justifyContent: "space-between",
781
+ marginTop: 10
782
+ }
783
+ }, /*#__PURE__*/React.createElement(View, {
784
+ dataSet: {
785
+ class: "showing-counts"
786
+ },
787
+ style: {
788
+ flexDirection: "row"
789
+ }
790
+ }, /*#__PURE__*/React.createElement(Text, null, this.t(".showing_from_to_out_of_total", {
791
+ defaultValue,
792
+ from,
793
+ to,
794
+ total_count: totalCount
795
+ })), this.p.workplace && this.s.currentWorkplaceCount !== null && /*#__PURE__*/React.createElement(Text, {
796
+ style: {
797
+ marginLeft: 3
798
+ }
799
+ }, this.t(".x_selected", {
800
+ defaultValue: "%{selected} selected.",
801
+ selected: this.s.currentWorkplaceCount
802
+ }))), /*#__PURE__*/React.createElement(View, null, /*#__PURE__*/React.createElement(Select, {
803
+ className: "per-page-select",
804
+ defaultValue: perPage,
805
+ onChange: this.tt.onPerPageChanged,
806
+ options: paginationOptions
807
+ })));
808
+ }
809
+ className() {
810
+ const classNames = ["api-maker--table"];
811
+ if (this.props.className) {
812
+ classNames.push(this.props.className);
813
+ }
814
+ return classNames.join(" ");
815
+ }
816
+ columnProps(column) {
817
+ const props = {};
818
+ if (column.textCenter) {
819
+ props.style ||= {};
820
+ props.style.textAlign = "center";
821
+ }
822
+ if (column.textRight) {
823
+ props.style ||= {};
824
+ props.style.textAlign = "right";
825
+ }
826
+ return props;
827
+ }
828
+ headerProps(column) {
829
+ const props = {};
830
+ if (column.textCenter) {
831
+ props.style ||= {};
832
+ props.style.justifyContent = "center";
833
+ }
834
+ if (column.textRight) {
835
+ props.style ||= {};
836
+ props.style.justifyContent = "end";
837
+ }
838
+ return props;
839
+ }
840
+ columnWidths() {
841
+ const columnWidths = {};
842
+ for (const column of this.s.preparedColumns) {
843
+ columnWidths[column.tableSettingColumn.identifier()] = column.width;
844
+ }
845
+ return columnWidths;
846
+ }
847
+ headersContentFromColumns = () => {
848
+ return /*#__PURE__*/React.createElement(DraggableSort, {
849
+ data: this.s.columnsToShow,
850
+ events: this.tt.draggableSortEvents,
851
+ horizontal: true,
852
+ keyExtractor: this.tt.dragListkeyExtractor,
853
+ onItemMoved: this.tt.onItemMoved,
854
+ onReordered: this.tt.onReordered,
855
+ renderItem: this.tt.dragListRenderItemContent
856
+ });
857
+ };
858
+ dragListCacheKeyExtractor = item => `${item.tableSettingColumn.identifier()}-${this.s.resizing}`;
859
+ dragListkeyExtractor = item => item.tableSettingColumn.identifier();
860
+ onItemMoved = ({
861
+ animationArgs,
862
+ itemIndex,
863
+ x,
864
+ y
865
+ }) => {
866
+ const animatedPosition = digg(this, "s", "columnsToShow", itemIndex, "animatedPosition");
867
+ if (animationArgs) {
868
+ Animated.timing(animatedPosition, animationArgs).start();
869
+ } else {
870
+ animatedPosition.setValue({
871
+ x,
872
+ y
873
+ });
874
+ }
875
+ };
876
+ onReordered = async ({
877
+ fromItem,
878
+ fromPosition,
879
+ toItem,
880
+ toPosition
881
+ }) => {
882
+ if (fromPosition == toPosition) return; // Only do requests and queries if changed
883
+
884
+ const TableSettingColumn = fromItem.tableSettingColumn.constructor;
885
+ const toColumn = await TableSettingColumn.find(toItem.tableSettingColumn.id()); // Need to load latest position because ActsAsList might have changed it
886
+
887
+ await fromItem.tableSettingColumn.update({
888
+ position: toColumn.position()
889
+ });
890
+ };
891
+ dragListRenderItemContent = ({
892
+ isActive,
893
+ item,
894
+ touchProps
895
+ }) => {
896
+ const {
897
+ animatedWidth,
898
+ animatedZIndex,
899
+ column,
900
+ tableSettingColumn
901
+ } = item;
902
+ return /*#__PURE__*/React.createElement(HeaderColumn, {
903
+ active: isActive,
904
+ animatedWidth: animatedWidth,
905
+ animatedZIndex: animatedZIndex,
906
+ column: column,
907
+ key: tableSettingColumn.identifier(),
908
+ resizing: this.s.resizing,
909
+ table: this,
910
+ tableSettingColumn: tableSettingColumn,
911
+ touchProps: touchProps,
912
+ widths: this.s.widths
913
+ });
914
+ };
915
+ headerClassNameForColumn(column) {
916
+ const classNames = [];
917
+ if (column.commonProps && column.commonProps.className) classNames.push(column.commonProps.className);
918
+ if (column.headerProps && column.headerProps.className) classNames.push(column.headerProps.className);
919
+ return classNames;
920
+ }
921
+ headerLabelForColumn(column) {
922
+ const {
923
+ modelClass
924
+ } = this.p;
925
+ if ("label" in column) {
926
+ if (typeof column.label == "function") {
927
+ return column.label();
928
+ } else {
929
+ return column.label;
930
+ }
931
+ }
932
+ let currentModelClass = modelClass;
933
+
934
+ // Calculate current model class through path
935
+ if (column.path) {
936
+ for (const pathPart of column.path) {
937
+ const relationships = digg(currentModelClass.modelClassData(), "relationships");
938
+ const relationship = relationships.find(relationshipInArray => relationshipInArray.name == inflection.underscore(pathPart));
939
+ currentModelClass = modelClassRequire(digg(relationship, "resource_name"));
940
+ }
941
+ }
942
+ if (column.attribute) return currentModelClass.humanAttributeName(column.attribute);
943
+ throw new Error("No 'label' or 'attribute' was given");
944
+ }
945
+ onFilterFormSubmit = () => this.submitFilter();
946
+ onRequestCloseSettings = () => this.setState({
947
+ showSettings: false
948
+ });
949
+ onSettingsClicked = e => {
950
+ e.preventDefault();
951
+ this.setState({
952
+ showSettings: !this.s.showSettings
953
+ });
954
+ };
955
+ submitFilter = () => {
956
+ const filterForm = digg(this.tt.filterFormRef, "current");
957
+ const {
958
+ appHistory
959
+ } = this.props;
960
+ const qParams = Params.serializeForm(filterForm);
961
+ const {
962
+ queryQName
963
+ } = this.s;
964
+ const changeParamsParams = {};
965
+ changeParamsParams[queryQName] = JSON.stringify(qParams);
966
+ Params.changeParams(changeParamsParams, {
967
+ appHistory
968
+ });
969
+ };
970
+ submitFilterDebounce = debounce(this.tt.submitFilter);
971
+ }));
972
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["digg","digs","React","createContext","useContext","useMemo","useRef","Animated","Pressable","View","BaseComponent","Card","classNames","Collection","columnVisible","debounce","DraggableSort","EventEmitter","Filters","FlatList","Form","Header","HeaderColumn","HeaderSelect","Icon","inflection","memo","modelClassRequire","ModelRow","Paginate","Params","PropTypes","Row","selectCalculator","Select","Settings","shapeComponent","TableSettings","Text","uniqunize","useBreakpoint","useCollection","useI18n","useEventEmitter","useModelEvent","useQueryParams","Widths","paginationOptions","WorkerPluginsCheckAllCheckbox","lazy","TableContext","ListHeaderComponent","setup","useStates","lastUpdate","Date","render","mdUp","tableContextValue","table","collection","events","queryWithoutPagination","t","tt","query","onColumnVisibilityUpdated","createElement","dataSet","class","style","styleForRowHeader","p","workplace","s","currentWorkplace","styleForHeader","width","undefined","marginHorizontal","marginLeft","defaultValue","preparedColumns","Fragment","headersContentFromColumns","type","setState","ApiMakerTable","defaultProps","card","currentUser","destroyEnabled","filterCard","filterSubmitButton","noRecordsAvailableContent","noRecordsFoundContent","preloads","select","styleUI","propTypes","abilities","object","actionsContent","func","appHistory","bool","isRequired","className","string","instanceOf","columns","oneOfType","array","controls","defaultDateFormatName","defaultDateTimeFormatName","defaultParams","destroyMessage","editModelPath","filterContent","filterSubmitLabel","node","groupBy","header","identifier","modelClass","onModelsLoaded","paginateContent","paginationComponent","queryMethod","queryName","selectColumns","styles","viewModelPath","draggableSortEvents","tableSettings","namespace","name","breakpoint","queryParams","setInstance","filterFormRef","collectionKey","modelClassData","props","querySName","columnsAsArray","currentWorkplaceCount","filterForm","columnsToShow","draggedColumn","preload","queryQName","queryPageName","resizing","showFilters","Boolean","showSettings","tableSetting","tableSettingLoaded","tableSettingFullCacheKey","widths","cacheKey","loadCurrentWorkplace","then","loadCurrentWorkplaceCount","id","loadTableSetting","onLinksCreated","onLinksDestroyed","collectionReady","abilitiesToLoad","ifCondition","pagination","state","clone","except","onDragStart","onDragEndAnimation","getColumnsToShow","item","animatedZIndex","setValue","Workplace","result","current","WorkplaceLink","ransack","resource_type_eq","workplace_id_eq","count","filter","column","tableSettingColumn","sort","a","b","position","loadExistingOrCreateTableSettings","mergedPreloads","fullCacheKey","updateSettingsFullCacheKey","concat","models","overallCount","qParams","showNoRecordsAvailableContent","showNoRecordsFoundContent","args","Error","onLayout","onContainerLayout","container","cardOrTable","ownAbilities","push","length","modelClassName","modelName","ability","restProps","headerContent","PaginationComponent","human","flatListStyle","overflowX","border","borderRadius","flatList","Provider","value","_extends","data","extraData","keyExtractor","keyExtrator","renderItem","showsHorizontalScrollIndicator","tableControls","footer","tableFooter","e","nativeEvent","layout","tableWidth","created","amountCreated","prevState","destroyed","amountDestroyed","model","submitFilter","submitFilterDebounce","formRef","onSubmit","onFilterFormSubmit","setForm","setStates","onFilterChanged","onFilterChangedWithDelay","marginTop","onFilterClicked","preventDefault","onPerPageChanged","newPerPageValue","perKey","paramsChange","changeParams","index","columnWidths","key","styleForColumn","columnIndex","even","defaultStyle","justifyContent","padding","overflow","Object","assign","backgroundColor","flexDirection","alignItems","marginRight","borderRight","actualStyle","styleForHeaderText","fontWeight","styleForRow","flex","onPress","size","onRequestClose","onRequestCloseSettings","onSettingsClicked","currentPage","totalCount","perPage","to","Math","min","from","total_count","selected","onChange","options","join","columnProps","textCenter","textAlign","textRight","headerProps","horizontal","dragListkeyExtractor","onItemMoved","onReordered","dragListRenderItemContent","dragListCacheKeyExtractor","animationArgs","itemIndex","x","y","animatedPosition","timing","start","fromItem","fromPosition","toItem","toPosition","TableSettingColumn","constructor","toColumn","find","update","isActive","touchProps","animatedWidth","active","headerClassNameForColumn","commonProps","headerLabelForColumn","label","currentModelClass","path","pathPart","relationships","relationship","relationshipInArray","underscore","attribute","humanAttributeName","serializeForm","changeParamsParams","JSON","stringify"],"sources":["../../src/table/table.jsx"],"sourcesContent":["import {digg, digs} from \"diggerize\"\nimport React, {createContext, useContext, useMemo, useRef} from \"react\"\nimport {Animated, Pressable, View} from \"react-native\"\nimport BaseComponent from \"../base-component\"\nimport Card from \"../bootstrap/card\"\nimport classNames from \"classnames\"\nimport Collection from \"../collection\"\nimport columnVisible from \"./column-visible\"\nimport debounce from \"debounce\"\nimport DraggableSort from \"../draggable-sort/index\"\nimport EventEmitter from \"events\"\nimport Filters from \"./filters\"\nimport FlatList from \"./components/flat-list\"\nimport {Form} from \"../form\"\nimport Header from \"./components/header\"\nimport HeaderColumn from \"./header-column\"\nimport HeaderSelect from \"./header-select\"\nimport Icon from \"../utils/icon\"\nimport * as inflection from \"inflection\"\nimport memo from \"set-state-compare/src/memo\"\nimport modelClassRequire from \"../model-class-require\"\nimport ModelRow from \"./model-row\"\nimport Paginate from \"../bootstrap/paginate\"\nimport Params from \"../params\"\nimport PropTypes from \"prop-types\"\nimport Row from \"./components/row\"\nimport selectCalculator from \"./select-calculator\"\nimport Select from \"../inputs/select\"\nimport Settings from \"./settings/index\"\nimport {shapeComponent} from \"set-state-compare/src/shape-component\"\nimport TableSettings from \"./table-settings\"\nimport Text from \"../utils/text\"\nimport uniqunize from \"uniqunize\"\nimport useBreakpoint from \"../use-breakpoint\"\nimport useCollection from \"../use-collection\"\nimport useI18n from \"i18n-on-steroids/src/use-i18n\"\nimport useEventEmitter from \"../use-event-emitter\"\nimport useModelEvent from \"../use-model-event\"\nimport useQueryParams from \"on-location-changed/build/use-query-params\"\nimport Widths from \"./widths\"\n\nconst paginationOptions = [30, 60, 90, [\"All\", \"all\"]]\nconst WorkerPluginsCheckAllCheckbox = React.lazy(() => import(\"./worker-plugins-check-all-checkbox\"))\nconst TableContext = createContext()\n\nconst ListHeaderComponent = memo(shapeComponent(class ListHeaderComponent extends BaseComponent {\n  setup() {\n    this.useStates({\n      lastUpdate: new Date()\n    })\n  }\n\n  render() {\n    const {mdUp} = useBreakpoint()\n    const tableContextValue = useContext(TableContext)\n    const table = tableContextValue.table\n    const {collection, events, queryWithoutPagination, t} = table.tt\n    const {query} = digs(collection, \"query\")\n\n    useEventEmitter(events, \"columnVisibilityUpdated\", this.tt.onColumnVisibilityUpdated)\n\n    return (\n      <Row dataSet={{class: \"api-maker/table/header-row\"}} style={table.styleForRowHeader()}>\n        {table.p.workplace && table.s.currentWorkplace &&\n          <Header style={table.styleForHeader({style: {width: mdUp ? 41 : undefined}})}>\n            <WorkerPluginsCheckAllCheckbox\n              currentWorkplace={table.s.currentWorkplace}\n              query={queryWithoutPagination}\n              style={{marginHorizontal: \"auto\"}}\n            />\n            {!mdUp &&\n              <Text style={{marginLeft: 3}}>\n                {t(\".select_all_found\", {defaultValue: \"Select all found\"})}\n              </Text>\n            }\n          </Header>\n        }\n        {!mdUp &&\n          <Header style={table.styleForHeader({style: {}})}>\n            <HeaderSelect preparedColumns={table.s.preparedColumns} query={query} table={table} />\n          </Header>\n        }\n        {mdUp &&\n          <>\n            {table.headersContentFromColumns()}\n            <Header style={table.styleForHeader({style: {}, type: \"actions\"})} />\n          </>\n        }\n      </Row>\n    )\n  }\n\n  onColumnVisibilityUpdated = () => this.setState({lastUpdate: new Date()})\n}))\n\nexport default memo(shapeComponent(class ApiMakerTable extends BaseComponent {\n  static defaultProps = {\n    card: true,\n    currentUser: null,\n    destroyEnabled: true,\n    filterCard: true,\n    filterSubmitButton: true,\n    noRecordsAvailableContent: undefined,\n    noRecordsFoundContent: undefined,\n    preloads: [],\n    select: {},\n    styleUI: true,\n    workplace: false\n  }\n\n  static propTypes = {\n    abilities: PropTypes.object,\n    actionsContent: PropTypes.func,\n    appHistory: PropTypes.object,\n    card: PropTypes.bool.isRequired,\n    className: PropTypes.string,\n    collection: PropTypes.instanceOf(Collection),\n    columns: PropTypes.oneOfType([PropTypes.array, PropTypes.func]),\n    controls: PropTypes.func,\n    currentUser: PropTypes.object,\n    defaultDateFormatName: PropTypes.string,\n    defaultDateTimeFormatName: PropTypes.string,\n    defaultParams: PropTypes.object,\n    destroyEnabled: PropTypes.bool.isRequired,\n    destroyMessage: PropTypes.string,\n    editModelPath: PropTypes.func,\n    filterCard: PropTypes.bool.isRequired,\n    filterContent: PropTypes.func,\n    filterSubmitLabel: PropTypes.node,\n    groupBy: PropTypes.array,\n    header: PropTypes.oneOfType([PropTypes.func, PropTypes.string]),\n    identifier: PropTypes.string,\n    modelClass: PropTypes.func.isRequired,\n    noRecordsAvailableContent: PropTypes.func,\n    noRecordsFoundContent: PropTypes.func,\n    onModelsLoaded: PropTypes.func,\n    paginateContent: PropTypes.func,\n    paginationComponent: PropTypes.func,\n    preloads: PropTypes.array.isRequired,\n    queryMethod: PropTypes.func,\n    queryName: PropTypes.string,\n    select: PropTypes.object,\n    selectColumns: PropTypes.object,\n    styles: PropTypes.object,\n    styleUI: PropTypes.bool.isRequired,\n    viewModelPath: PropTypes.func,\n    workplace: PropTypes.bool.isRequired\n  }\n\n  draggableSortEvents = new EventEmitter()\n  events = new EventEmitter()\n  tableSettings = null\n\n  setup() {\n    const {t} = useI18n({namespace: \"js.api_maker.table\"})\n    const {name: breakpoint, mdUp} = useBreakpoint()\n    const queryParams = useQueryParams()\n\n    this.setInstance({\n      breakpoint,\n      filterFormRef: useRef(),\n      mdUp,\n      t\n    })\n\n    const collectionKey = digg(this.p.modelClass.modelClassData(), \"collectionKey\")\n    let queryName = this.props.queryName\n\n    if (!queryName) queryName = collectionKey\n\n    const querySName = `${queryName}_s`\n\n    this.useStates({\n      columns: () => this.columnsAsArray(),\n      currentWorkplace: undefined,\n      currentWorkplaceCount: null,\n      filterForm: null,\n      columnsToShow: null,\n      draggedColumn: null,\n      identifier: () => this.props.identifier || `${collectionKey}-default`,\n      lastUpdate: () => new Date(),\n      preload: undefined,\n      preparedColumns: undefined,\n      queryName,\n      queryQName: () => `${queryName}_q`,\n      queryPageName: () => `${queryName}_page`,\n      querySName,\n      resizing: false,\n      showFilters: () => Boolean(queryParams[querySName]),\n      showSettings: false,\n      tableSetting: undefined,\n      tableSettingLoaded: false,\n      tableSettingFullCacheKey: undefined,\n      width: undefined,\n      widths: null\n    })\n\n    this.tableContextValue = useMemo(\n      () => ({\n        cacheKey: this.s.tableSettingFullCacheKey,\n        lastUpdate: this.s.lastUpdate,\n        resizing: this.s.resizing,\n        table: this\n      }),\n      [this.s.lastUpdate, this.s.resizing, this.s.tableSettingFullCacheKey]\n    )\n\n    useMemo(() => {\n      if (this.props.workplace) {\n        this.loadCurrentWorkplace().then(() => {\n          this.loadCurrentWorkplaceCount()\n        })\n      }\n    }, [this.p.currentUser?.id()])\n\n    useMemo(() => {\n      if (!this.tt.tableSettings && this.s.width) {\n        this.loadTableSetting()\n      }\n    }, [this.p.currentUser?.id(), this.s.width])\n\n    useModelEvent(this.s.currentWorkplace, \"workplace_links_created\", this.tt.onLinksCreated)\n    useModelEvent(this.s.currentWorkplace, \"workplace_links_destroyed\", this.tt.onLinksDestroyed)\n\n    let collectionReady = true\n    let select\n\n    if (!this.s.preparedColumns) {\n      collectionReady = false\n    }\n\n    if (collectionReady) {\n      select = selectCalculator({table: this})\n    }\n\n    this.collection = useCollection({\n      abilities: this.abilitiesToLoad(),\n      defaultParams: this.props.defaultParams,\n      collection: this.props.collection,\n      groupBy: this.props.groupBy,\n      ifCondition: collectionReady,\n      modelClass: this.props.modelClass,\n      onModelsLoaded: this.props.onModelsLoaded,\n      noRecordsAvailableContent: this.props.noRecordsAvailableContent,\n      noRecordsFoundContent: this.props.noRecordsFoundContent,\n      pagination: true,\n      preloads: this.state.preload,\n      queryMethod: this.props.queryMethod,\n      queryName,\n      select,\n      selectColumns: this.props.selectColumns\n    })\n    this.queryWithoutPagination = useMemo(\n      () => this.collection?.query?.clone()?.except(\"page\"),\n      [this.collection.query]\n    )\n\n    useEventEmitter(this.tt.draggableSortEvents, \"onDragStart\", this.tt.onDragStart)\n    useEventEmitter(this.tt.draggableSortEvents, \"onDragEndAnimation\", this.tt.onDragEndAnimation)\n    useEventEmitter(this.tt.events, \"columnVisibilityUpdated\", this.tt.onColumnVisibilityUpdated)\n  }\n\n  onColumnVisibilityUpdated = () => this.setState({columnsToShow: this.getColumnsToShow(this.s.columns), lastUpdate: new Date()})\n  onDragStart = ({item}) => item.animatedZIndex.setValue(9999)\n  onDragEndAnimation = ({item}) => item.animatedZIndex.setValue(0)\n\n  async loadCurrentWorkplace() {\n    const Workplace = modelClassRequire(\"Workplace\")\n    const result = await Workplace.current()\n    const currentWorkplace = digg(result, \"current\", 0)\n\n    this.setState({currentWorkplace})\n  }\n\n  async loadCurrentWorkplaceCount() {\n    const WorkplaceLink = modelClassRequire(\"WorkplaceLink\")\n    const currentWorkplaceCount = await WorkplaceLink\n      .ransack({\n        resource_type_eq: this.p.modelClass.modelClassData().name,\n        workplace_id_eq: this.s.currentWorkplace.id()\n      })\n      .count()\n\n    this.setState({currentWorkplaceCount})\n  }\n\n  getColumnsToShow(columns) {\n    return columns\n      .filter(({column, tableSettingColumn}) => columnVisible(column, tableSettingColumn))\n      .sort((a, b) => a.tableSettingColumn.position() - b.tableSettingColumn.position())\n  }\n\n  async loadTableSetting() {\n    this.tableSettings = new TableSettings({table: this})\n\n    const tableSetting = await this.tableSettings.loadExistingOrCreateTableSettings()\n    const {columns, preload} = this.tableSettings.preparedColumns(tableSetting)\n    const {width} = this.s\n    const widths = new Widths({columns, table: this, width})\n    const columnsToShow = this.getColumnsToShow(columns)\n\n    this.setState({\n      columns,\n      columnsToShow,\n      preparedColumns: columns,\n      preload: this.mergedPreloads(preload),\n      tableSetting,\n      tableSettingLoaded: true,\n      tableSettingFullCacheKey: tableSetting.fullCacheKey(),\n      widths\n    })\n  }\n\n  updateSettingsFullCacheKey = () => this.setState({tableSettingFullCacheKey: this.state.tableSetting.fullCacheKey()})\n\n  columnsAsArray = () => {\n    if (typeof this.props.columns == \"function\") {\n      return this.props.columns()\n    }\n\n    return this.props.columns\n  }\n\n  mergedPreloads(preload) {\n    const {preloads} = this.props\n    let mergedPreloads = []\n\n    if (preloads) mergedPreloads = mergedPreloads.concat(preloads)\n    if (preload) mergedPreloads = mergedPreloads.concat(preload)\n\n    return uniqunize(mergedPreloads)\n  }\n\n  render () {\n    const {modelClass, noRecordsAvailableContent, noRecordsFoundContent} = this.p\n    const {collection, currentUser} = this.props\n    const {queryName, querySName, showFilters} = this.s\n    const {\n      models,\n      overallCount,\n      qParams,\n      query,\n      result,\n      showNoRecordsAvailableContent,\n      showNoRecordsFoundContent\n    } = digs(\n      this.collection,\n      \"models\",\n      \"overallCount\",\n      \"qParams\",\n      \"query\",\n      \"result\",\n      \"showNoRecordsAvailableContent\",\n      \"showNoRecordsFoundContent\"\n    )\n\n    if (collection && collection.args.modelClass.modelClassData().name != modelClass.modelClassData().name) {\n      throw new Error(\n        `Model class from collection '${collection.args.modelClass.modelClassData().name}' ` +\n        `didn't match model class on table: '${modelClass.modelClassData().name}'`\n      )\n    }\n\n    return (\n      <View dataSet={{class: this.className()}} onLayout={this.tt.onContainerLayout} style={this.props.styles?.container}>\n        {showNoRecordsAvailableContent &&\n          <div className=\"live-table--no-records-available-content\">\n            {noRecordsAvailableContent({models, qParams, overallCount})}\n          </div>\n        }\n        {showNoRecordsFoundContent &&\n          <div className=\"live-table--no-records-found-content\">\n            {noRecordsFoundContent({models, qParams, overallCount})}\n          </div>\n        }\n        {showFilters &&\n          <Filters currentUser={currentUser} modelClass={modelClass} queryName={queryName} querySName={querySName} />\n        }\n        {qParams && query && result && models && !showNoRecordsAvailableContent && !showNoRecordsFoundContent &&\n          this.cardOrTable()\n        }\n      </View>\n    )\n  }\n\n  abilitiesToLoad () {\n    const abilitiesToLoad = {}\n    const {abilities, modelClass} = this.props\n    const ownAbilities = []\n\n    if (this.props.destroyEnabled) ownAbilities.push(\"destroy\")\n    if (this.props.editModelPath) ownAbilities.push(\"edit\")\n    if (this.props.viewModelPath) ownAbilities.push(\"show\")\n\n    if (ownAbilities.length > 0) {\n      const modelClassName = digg(modelClass.modelClassData(), \"name\")\n\n      abilitiesToLoad[modelClassName] = ownAbilities\n    }\n\n    if (abilities) {\n      for (const modelName in abilities) {\n        if (!(modelName in abilitiesToLoad)) {\n          abilitiesToLoad[modelName] = []\n        }\n\n        for (const ability of abilities[modelName]) {\n          abilitiesToLoad[modelName].push(ability)\n        }\n      }\n    }\n\n    return abilitiesToLoad\n  }\n\n  cardOrTable () {\n    const {\n      abilities,\n      actionsContent,\n      appHistory,\n      card,\n      className,\n      collection,\n      columns,\n      controls,\n      currentUser,\n      defaultDateFormatName,\n      defaultDateTimeFormatName,\n      defaultParams,\n      destroyEnabled,\n      destroyMessage,\n      editModelPath,\n      filterCard,\n      filterContent,\n      filterSubmitButton,\n      filterSubmitLabel,\n      groupBy,\n      header,\n      identifier,\n      modelClass,\n      noRecordsAvailableContent,\n      noRecordsFoundContent,\n      onModelsLoaded,\n      paginateContent,\n      paginationComponent,\n      preloads,\n      queryMethod,\n      queryName,\n      select,\n      selectColumns,\n      styleUI,\n      viewModelPath,\n      workplace,\n      ...restProps\n    } = this.props\n    const {models, qParams, query, result} = digs(this.collection, \"models\", \"qParams\", \"query\", \"result\")\n\n    let headerContent, PaginationComponent\n\n    if (typeof header == \"function\") {\n      headerContent = header({models, qParams, query, result})\n    } else if (header) {\n      headerContent = header\n    } else {\n      headerContent = modelClass.modelName().human({count: 2})\n    }\n\n    if (!paginateContent) {\n      if (paginationComponent) {\n        PaginationComponent = paginationComponent\n      } else {\n        PaginationComponent = Paginate\n      }\n    }\n\n    const flatListStyle = {\n      overflowX: \"auto\"\n    }\n\n    if (styleUI) {\n      flatListStyle.border = \"1px solid #dbdbdb\"\n      flatListStyle.borderRadius = 5\n    }\n\n    const flatList = (\n      <TableContext.Provider value={this.tt.tableContextValue}>\n        <FlatList\n          data={models}\n          dataSet={{\n            class: classNames(\"api-maker--table\", className),\n            cacheKey: this.s.tableSettingFullCacheKey,\n            lastUpdate: this.s.lastUpdate\n          }}\n          extraData={this.s.lastUpdate}\n          keyExtractor={this.tt.keyExtrator}\n          ListHeaderComponent={ListHeaderComponent}\n          renderItem={this.tt.renderItem}\n          showsHorizontalScrollIndicator\n          style={flatListStyle}\n          {...restProps}\n        />\n      </TableContext.Provider>\n    )\n\n    return (\n      <>\n        {filterContent && filterCard &&\n          <Card className=\"live-table--filter-card mb-4\">\n            {this.filterForm()}\n          </Card>\n        }\n        {filterContent && !filterCard &&\n          this.filterForm()\n        }\n        {card &&\n          <Card\n            className={classNames(\"live-table--table-card\", \"mb-4\", className)}\n            controls={this.tableControls()}\n            header={headerContent}\n            footer={this.tableFooter()}\n            {...restProps}\n          >\n            {flatList}\n          </Card>\n        }\n        {!card && flatList}\n        {result && PaginationComponent &&\n          <PaginationComponent result={result} />\n        }\n        {result && paginateContent &&\n          paginateContent({result})\n        }\n      </>\n    )\n  }\n\n  onContainerLayout = (e) => {\n    const {width} = e.nativeEvent.layout\n    const {widths} = this.s\n\n    this.setState({width})\n    if (widths) widths.tableWidth = width\n  }\n\n  onLinksCreated = ({args}) => {\n    const modelClassName = this.p.modelClass.modelClassData().name\n\n    if (args.created[modelClassName]) {\n      const amountCreated = args.created[modelClassName].length\n\n      this.setState((prevState) => ({\n        currentWorkplaceCount: prevState.currentWorkplaceCount + amountCreated\n      }))\n    }\n  }\n\n  onLinksDestroyed = ({args}) => {\n    const modelClassName = this.p.modelClass.modelClassData().name\n\n    if (args.destroyed[modelClassName]) {\n      const amountDestroyed = args.destroyed[modelClassName].length\n\n      this.setState((prevState) => ({\n        currentWorkplaceCount: prevState.currentWorkplaceCount - amountDestroyed\n      }))\n    }\n  }\n\n  keyExtrator = (model) => `${this.s.tableSettingFullCacheKey}-${model.id()}`\n\n  filterForm = () => {\n    const {filterFormRef, submitFilter, submitFilterDebounce} = this.tt\n    const {filterContent, filterSubmitButton} = this.p\n    const {queryQName} = this.s\n    const {filterSubmitLabel} = this.props\n    const {qParams} = digs(this.collection, \"qParams\")\n\n    return (\n      <Form className=\"live-table--filter-form\" formRef={filterFormRef} onSubmit={this.tt.onFilterFormSubmit} setForm={this.setStates.filterForm}>\n        {\"s\" in qParams &&\n          <input name=\"s\" type=\"hidden\" value={qParams.s} />\n        }\n        {filterContent({\n          onFilterChanged: submitFilter,\n          onFilterChangedWithDelay: submitFilterDebounce,\n          qParams,\n          queryQName\n        })}\n        {filterSubmitButton &&\n          <input\n            className=\"btn btn-primary live-table--submit-filter-button\"\n            type=\"submit\"\n            style={{marginTop: \"8px\"}}\n            value={filterSubmitLabel || this.t(\".filter\", {defaultValue: \"Filter\"})}\n          />\n        }\n      </Form>\n    )\n  }\n\n  onFilterClicked = (e) => {\n    e.preventDefault()\n    this.setState({showFilters: !this.state.showFilters})\n  }\n\n  onPerPageChanged = (e) => {\n    const {queryName} = this.s\n    const newPerPageValue = digg(e, \"target\", \"value\")\n    const perKey = `${queryName}_per`\n    const paramsChange = {}\n\n    paramsChange[perKey] = newPerPageValue\n\n    Params.changeParams(paramsChange)\n  }\n\n  renderItem = ({index, item: model}) => {\n    if (!this.s.tableSettingLoaded) {\n      return (\n        <View>\n          <Text>\n            {this.t(\".loading_dot_dot_dot\", {defaultValue: \"Loading...\"})}\n          </Text>\n        </View>\n      )\n    }\n\n    return (\n      <ModelRow\n        cacheKey={model.cacheKey()}\n        columns={this.s.columnsToShow}\n        columnWidths={this.columnWidths()}\n        events={this.tt.events}\n        index={index}\n        key={model.id()}\n        model={model}\n        table={this}\n        tableSettingFullCacheKey={this.s.tableSettingFullCacheKey}\n      />\n    )\n  }\n\n  styleForColumn = ({column, columnIndex, even, style, type}) => {\n    const {styleUI} = this.p\n    const defaultStyle = {\n      justifyContent: \"center\",\n      padding: 8,\n      overflow: \"hidden\"\n    }\n\n    if (styleUI) {\n      Object.assign(defaultStyle, {\n        backgroundColor: even ? \"#f5f5f5\" : \"#fff\"\n      })\n    }\n\n    if (type == \"actions\") {\n      defaultStyle.flexDirection = \"row\"\n      defaultStyle.alignItems = \"center\"\n\n      if (this.tt.mdUp) {\n        defaultStyle.marginLeft = \"auto\"\n      } else {\n        defaultStyle.marginRight = \"auto\"\n      }\n    } else if (this.tt.mdUp && styleUI) {\n      defaultStyle.borderRight = \"1px solid #dbdbdb\"\n    }\n\n    const actualStyle = Object.assign(\n      defaultStyle,\n      style\n    )\n\n    return actualStyle\n  }\n\n  styleForHeader = ({column, columnIndex, style, type}) => {\n    const {mdUp} = this.tt\n    const defaultStyle = {\n      flexDirection: \"row\",\n      alignItems: \"center\",\n      padding: 8\n    }\n\n    if (type != \"actions\" && mdUp && this.p.styleUI) {\n      defaultStyle.borderRight = \"1px solid #dbdbdb\"\n    }\n\n    const actualStyle = Object.assign(\n      defaultStyle,\n      style\n    )\n\n    return actualStyle\n  }\n\n  styleForHeaderText() {\n    const actualStyle = {fontWeight: \"bold\"}\n\n    return actualStyle\n  }\n\n  styleForRow = ({even} = {}) => {\n    const actualStyle = {\n      flex: 1,\n      alignItems: \"stretch\"\n    }\n\n    if (even && this.p.styleUI) {\n      actualStyle.backgroundColor = \"#f5f5f5\"\n    }\n\n    return actualStyle\n  }\n\n  styleForRowHeader = () => {\n    const actualStyle = {\n      flex: 1,\n      alignItems: \"stretch\"\n    }\n\n    return actualStyle\n  }\n\n  tableControls() {\n    const {controls} = this.props\n    const {showSettings} = this.s\n    const {models, qParams, query, result} = digs(this.collection, \"models\", \"qParams\", \"query\", \"result\")\n\n    return (\n      <View style={{flexDirection: \"row\"}}>\n        {controls && controls({models, qParams, query, result})}\n        <Pressable dataSet={{class: \"filter-button\"}} onPress={this.tt.onFilterClicked}>\n          <Icon name=\"search\" size={20} />\n        </Pressable>\n        <View style={{position: \"relative\"}}>\n          {showSettings &&\n            <Settings onRequestClose={this.tt.onRequestCloseSettings} table={this} />\n          }\n          <Pressable dataSet={{class: \"settings-button\"}} onPress={this.tt.onSettingsClicked}>\n            <Icon name=\"gear\" size={20} />\n          </Pressable>\n        </View>\n      </View>\n    )\n  }\n\n  tableFooter() {\n    const {result} = digs(this.collection, \"result\")\n    const currentPage = result.currentPage()\n    const totalCount = result.totalCount()\n    const perPage = result.perPage()\n    const to = Math.min(currentPage * perPage, totalCount)\n    const defaultValue = \"Showing %{from} to %{to} out of %{total_count} total.\"\n    let from = ((currentPage - 1) * perPage) + 1\n\n    if (to === 0) from = 0\n\n    return (\n      <View style={{flexDirection: \"row\", justifyContent: \"space-between\", marginTop: 10}}>\n        <View dataSet={{class: \"showing-counts\"}} style={{flexDirection: \"row\"}}>\n          <Text>\n            {this.t(\".showing_from_to_out_of_total\", {defaultValue, from, to, total_count: totalCount})}\n          </Text>\n          {this.p.workplace && this.s.currentWorkplaceCount !== null &&\n            <Text style={{marginLeft: 3}}>\n              {this.t(\".x_selected\", {defaultValue: \"%{selected} selected.\", selected: this.s.currentWorkplaceCount})}\n            </Text>\n          }\n        </View>\n        <View>\n          <Select\n            className=\"per-page-select\"\n            defaultValue={perPage}\n            onChange={this.tt.onPerPageChanged}\n            options={paginationOptions}\n          />\n        </View>\n      </View>\n    )\n  }\n\n  className() {\n    const classNames = [\"api-maker--table\"]\n\n    if (this.props.className) {\n      classNames.push(this.props.className)\n    }\n\n    return classNames.join(\" \")\n  }\n\n  columnProps(column) {\n    const props = {}\n\n    if (column.textCenter) {\n      props.style ||= {}\n      props.style.textAlign = \"center\"\n    }\n\n    if (column.textRight) {\n      props.style ||= {}\n      props.style.textAlign = \"right\"\n    }\n\n    return props\n  }\n\n  headerProps(column) {\n    const props = {}\n\n    if (column.textCenter) {\n      props.style ||= {}\n      props.style.justifyContent = \"center\"\n    }\n\n    if (column.textRight) {\n      props.style ||= {}\n      props.style.justifyContent = \"end\"\n    }\n\n    return props\n  }\n\n  columnWidths() {\n    const columnWidths = {}\n\n    for (const column of this.s.preparedColumns) {\n      columnWidths[column.tableSettingColumn.identifier()] = column.width\n    }\n\n    return columnWidths\n  }\n\n  headersContentFromColumns = () => {\n    return (\n      <DraggableSort\n        data={this.s.columnsToShow}\n        events={this.tt.draggableSortEvents}\n        horizontal\n        keyExtractor={this.tt.dragListkeyExtractor}\n        onItemMoved={this.tt.onItemMoved}\n        onReordered={this.tt.onReordered}\n        renderItem={this.tt.dragListRenderItemContent}\n      />\n    )\n  }\n\n  dragListCacheKeyExtractor = (item) => `${item.tableSettingColumn.identifier()}-${this.s.resizing}`\n  dragListkeyExtractor = (item) => item.tableSettingColumn.identifier()\n\n  onItemMoved = ({animationArgs, itemIndex, x, y}) => {\n    const animatedPosition = digg(this, \"s\", \"columnsToShow\", itemIndex, \"animatedPosition\")\n\n    if (animationArgs) {\n      Animated.timing(animatedPosition, animationArgs).start()\n    } else {\n      animatedPosition.setValue({x, y})\n    }\n  }\n\n  onReordered = async ({fromItem, fromPosition, toItem, toPosition}) => {\n    if (fromPosition == toPosition) return // Only do requests and queries if changed\n\n    const TableSettingColumn = fromItem.tableSettingColumn.constructor\n    const toColumn = await TableSettingColumn.find(toItem.tableSettingColumn.id()) // Need to load latest position because ActsAsList might have changed it\n\n    await fromItem.tableSettingColumn.update({position: toColumn.position()})\n  }\n\n  dragListRenderItemContent = ({isActive, item, touchProps}) => {\n    const {animatedWidth, animatedZIndex, column, tableSettingColumn} = item\n\n    return (\n      <HeaderColumn\n        active={isActive}\n        animatedWidth={animatedWidth}\n        animatedZIndex={animatedZIndex}\n        column={column}\n        key={tableSettingColumn.identifier()}\n        resizing={this.s.resizing}\n        table={this}\n        tableSettingColumn={tableSettingColumn}\n        touchProps={touchProps}\n        widths={this.s.widths}\n      />\n    )\n  }\n\n  headerClassNameForColumn(column) {\n    const classNames = []\n\n    if (column.commonProps && column.commonProps.className) classNames.push(column.commonProps.className)\n    if (column.headerProps && column.headerProps.className) classNames.push(column.headerProps.className)\n\n    return classNames\n  }\n\n  headerLabelForColumn(column) {\n    const {modelClass} = this.p\n\n    if (\"label\" in column) {\n      if (typeof column.label == \"function\") {\n        return column.label()\n      } else {\n        return column.label\n      }\n    }\n\n    let currentModelClass = modelClass\n\n    // Calculate current model class through path\n    if (column.path) {\n      for (const pathPart of column.path) {\n        const relationships = digg(currentModelClass.modelClassData(), \"relationships\")\n        const relationship = relationships.find((relationshipInArray) => relationshipInArray.name == inflection.underscore(pathPart))\n\n        currentModelClass = modelClassRequire(digg(relationship, \"resource_name\"))\n      }\n    }\n\n    if (column.attribute) return currentModelClass.humanAttributeName(column.attribute)\n\n    throw new Error(\"No 'label' or 'attribute' was given\")\n  }\n\n  onFilterFormSubmit = () => this.submitFilter()\n  onRequestCloseSettings = () => this.setState({showSettings: false})\n\n  onSettingsClicked = (e) => {\n    e.preventDefault()\n\n    this.setState({showSettings: !this.s.showSettings})\n  }\n\n  submitFilter = () => {\n    const filterForm = digg(this.tt.filterFormRef, \"current\")\n    const {appHistory} = this.props\n    const qParams = Params.serializeForm(filterForm)\n    const {queryQName} = this.s\n    const changeParamsParams = {}\n\n    changeParamsParams[queryQName] = JSON.stringify(qParams)\n\n    Params.changeParams(changeParamsParams, {appHistory})\n  }\n\n  submitFilterDebounce = debounce(this.tt.submitFilter)\n}))\n"],"mappings":"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","ignoreList":[]}