@kaspernj/api-maker 1.0.446 → 1.0.447
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.
- package/{.eslintrc.cjs → .eslintrc.js} +4 -0
- package/README.md +35 -0
- package/android/build.gradle +43 -0
- package/android/src/main/AndroidManifest.xml +2 -0
- package/android/src/main/java/expo/modules/api_maker/ApiMakerModule.kt +50 -0
- package/android/src/main/java/expo/modules/api_maker/ApiMakerView.kt +30 -0
- package/build/api.js +120 -0
- package/build/attribute-not-loaded-error.js +2 -0
- package/build/base-component.js +5 -0
- package/build/base-error.js +33 -0
- package/build/base-model/attribute.js +25 -0
- package/build/base-model/column.js +11 -0
- package/build/base-model/reflection.js +14 -0
- package/build/base-model/scope.js +11 -0
- package/build/base-model.js +828 -0
- package/build/bootstrap/attribute-row/index.js +105 -0
- package/build/bootstrap/attribute-rows.js +31 -0
- package/build/bootstrap/card.js +138 -0
- package/build/bootstrap/checkbox.js +97 -0
- package/build/bootstrap/checkboxes.js +183 -0
- package/build/bootstrap/index.js +2 -0
- package/build/bootstrap/input.js +128 -0
- package/build/bootstrap/invalid-feedback.js +27 -0
- package/build/bootstrap/paginate.js +150 -0
- package/build/bootstrap/radio-buttons.js +72 -0
- package/build/bootstrap/select.js +88 -0
- package/build/bootstrap/sort-link.js +130 -0
- package/build/cable-connection-pool.js +128 -0
- package/build/cable-subscription-pool.js +207 -0
- package/build/cable-subscription.js +21 -0
- package/build/cache-key-generator.js +81 -0
- package/build/can-can.js +134 -0
- package/build/channels-consumer.js +3 -0
- package/build/collection-loader.js +48 -0
- package/build/collection.js +279 -0
- package/build/command-submit-data.js +81 -0
- package/build/commands-pool.js +195 -0
- package/build/compose.js +9 -0
- package/build/config.js +53 -0
- package/build/custom-error.js +5 -0
- package/build/data-set-to-attributes.js +10 -0
- package/build/deserializer.js +56 -0
- package/build/destroy-error.js +5 -0
- package/build/devise.js +109 -0
- package/build/draggable-sort/controller.js +136 -0
- package/build/draggable-sort/index.js +114 -0
- package/build/draggable-sort/item.js +188 -0
- package/build/error-logger.js +101 -0
- package/build/error-messages.js +13 -0
- package/build/event-connection.js +32 -0
- package/build/event-model-class.js +24 -0
- package/build/events.js +5 -0
- package/build/form.js +83 -0
- package/build/index.js +3 -0
- package/build/inputs/attachment.js +121 -0
- package/build/inputs/auto-submit.js +36 -0
- package/build/inputs/checkbox.js +145 -0
- package/build/inputs/checkboxes.js +111 -0
- package/build/inputs/id-for-component.js +15 -0
- package/build/inputs/input-wrapper.js +18 -0
- package/build/inputs/input.js +230 -0
- package/build/inputs/money.js +179 -0
- package/build/inputs/name-for-component.js +13 -0
- package/build/inputs/select.js +92 -0
- package/build/instance-of-class-name.js +23 -0
- package/build/key-value-store.js +53 -0
- package/build/link.js +68 -0
- package/build/logger.js +30 -0
- package/build/modal.js +37 -0
- package/build/model-class-require.js +13 -0
- package/build/model-events.js +30 -0
- package/build/model-name.js +28 -0
- package/build/model-prop-type.js +101 -0
- package/build/model-recipes-loader.js +32 -0
- package/build/model-recipes-model-loader.js +357 -0
- package/build/models-response-reader.js +40 -0
- package/build/models.js +8 -0
- package/build/money-formatter.js +77 -0
- package/build/not-loaded-error.js +2 -0
- package/build/params.js +60 -0
- package/build/preloaded.js +38 -0
- package/build/resize-observer.js +11 -0
- package/build/result.js +13 -0
- package/build/router/route.js +262 -0
- package/build/router/switch.js +72 -0
- package/build/router.js +57 -0
- package/build/routes-native.js +202 -0
- package/build/routes.js +50 -0
- package/build/run-last.js +35 -0
- package/build/serializer.js +63 -0
- package/build/services.js +20 -0
- package/build/session-status-updater.js +126 -0
- package/build/source-maps-loader.js +171 -0
- package/build/super-admin/config-reader.js +84 -0
- package/build/super-admin/edit-page/edit-attribute-checkbox.js +85 -0
- package/build/super-admin/edit-page/edit-attribute-content.js +54 -0
- package/build/super-admin/edit-page/edit-attribute-input.js +79 -0
- package/build/super-admin/edit-page/edit-attribute.js +76 -0
- package/build/super-admin/edit-page.js +120 -0
- package/build/super-admin/has-edit-config.js +12 -0
- package/build/super-admin/index-page.js +24 -0
- package/build/super-admin/index.js +180 -0
- package/build/super-admin/layout/header/index.js +151 -0
- package/build/super-admin/layout/index.js +109 -0
- package/build/super-admin/layout/menu/index.js +93 -0
- package/build/super-admin/layout/menu/menu-content.js +40 -0
- package/build/super-admin/layout/menu/menu-item.js +83 -0
- package/build/super-admin/layout/no-access.js +25 -0
- package/build/super-admin/model-class-table.js +61 -0
- package/build/super-admin/models.js +8 -0
- package/build/super-admin/show-nav.js +49 -0
- package/build/super-admin/show-page/belongs-to-attribute-row.js +28 -0
- package/build/super-admin/show-page/index.js +141 -0
- package/build/super-admin/show-reflection-actions.js +47 -0
- package/build/super-admin/show-reflection-link.js +46 -0
- package/build/super-admin/show-reflection-page.js +47 -0
- package/build/table/column-content.js +112 -0
- package/build/table/column-identifier.js +18 -0
- package/build/table/column-visible.js +7 -0
- package/build/table/components/column.js +20 -0
- package/build/table/components/flat-list.js +20 -0
- package/build/table/components/header.js +25 -0
- package/build/table/components/row.js +25 -0
- package/build/table/filters/attribute-element.js +43 -0
- package/build/table/filters/filter-form.js +392 -0
- package/build/table/filters/filter.js +89 -0
- package/build/table/filters/index.js +182 -0
- package/build/table/filters/load-search-modal.js +174 -0
- package/build/table/filters/reflection-element.js +36 -0
- package/build/table/filters/save-search-modal.js +86 -0
- package/build/table/filters/scope-element.js +41 -0
- package/build/table/header-column-content.js +67 -0
- package/build/table/header-column.js +144 -0
- package/build/table/header-select.js +104 -0
- package/build/table/model-callback-args.js +10 -0
- package/build/table/model-column.js +87 -0
- package/build/table/model-row.js +179 -0
- package/build/table/select-calculator.js +63 -0
- package/build/table/settings/column-row.js +97 -0
- package/build/table/settings/download-action.js +78 -0
- package/build/table/settings/index.js +92 -0
- package/build/table/table-settings.js +219 -0
- package/build/table/table.js +972 -0
- package/build/table/use-sorting.js +34 -0
- package/build/table/widths.js +75 -0
- package/build/table/worker-plugins-check-all-checkbox.js +125 -0
- package/build/table/worker-plugins-checkbox.js +115 -0
- package/build/translated-attributes.js +10 -0
- package/build/translated-collections.js +11 -0
- package/build/updated-attribute.js +76 -0
- package/build/url-encode.js +15 -0
- package/build/use-breakpoint.js +44 -0
- package/build/use-can-can.js +55 -0
- package/build/use-collection.js +225 -0
- package/build/use-created-event.js +52 -0
- package/build/use-current-user.js +73 -0
- package/build/use-destroyed-event.js +60 -0
- package/build/use-event-emitter.js +13 -0
- package/build/use-event-listener.js +16 -0
- package/build/use-input.js +140 -0
- package/build/use-model-event.js +60 -0
- package/build/use-model.js +169 -0
- package/build/use-resize-observer.js +23 -0
- package/build/use-router.js +102 -0
- package/build/use-screen-layout.js +39 -0
- package/build/use-updated-event.js +60 -0
- package/build/use-validation-errors.js +30 -0
- package/build/utils/card.js +51 -0
- package/build/utils/checkbox.js +48 -0
- package/build/utils/default-style.js +18 -0
- package/build/utils/modal.js +61 -0
- package/build/utils/text.js +18 -0
- package/build/validation-error.js +28 -0
- package/build/validation-errors.js +98 -0
- package/build/with-collection.js +13 -0
- package/build/with-current-user.js +9 -0
- package/build/with-model.js +14 -0
- package/build/with-router.js +21 -0
- package/expo-module.config.json +17 -0
- package/ios/ApiMaker.podspec +29 -0
- package/ios/ApiMakerModule.swift +48 -0
- package/ios/ApiMakerView.swift +38 -0
- package/package.json +35 -15
- package/src/{api.mjs → api.js} +5 -5
- package/src/{base-error.mjs → base-error.js} +1 -1
- package/src/base-model/{attribute.mjs → attribute.js} +1 -1
- package/src/base-model/{reflection.mjs → reflection.js} +1 -1
- package/src/{base-model.mjs → base-model.js} +14 -14
- package/src/bootstrap/attribute-row/index.jsx +2 -2
- package/src/bootstrap/attribute-rows.jsx +1 -1
- package/src/bootstrap/card.jsx +1 -1
- package/src/bootstrap/checkbox.jsx +1 -1
- package/src/bootstrap/checkboxes.jsx +1 -1
- package/src/bootstrap/input.jsx +1 -1
- package/src/bootstrap/paginate.jsx +2 -2
- package/src/bootstrap/sort-link.jsx +3 -3
- package/src/{cable-connection-pool.mjs → cable-connection-pool.js} +3 -3
- package/src/{cable-subscription-pool.mjs → cable-subscription-pool.js} +4 -4
- package/src/{cable-subscription.mjs → cable-subscription.js} +1 -1
- package/src/{can-can.mjs → can-can.js} +1 -1
- package/src/collection-loader.jsx +2 -2
- package/src/{collection.mjs → collection.js} +3 -3
- package/src/{commands-pool.mjs → commands-pool.js} +11 -11
- package/src/{custom-error.mjs → custom-error.js} +1 -1
- package/src/{deserializer.mjs → deserializer.js} +2 -2
- package/src/{destroy-error.mjs → destroy-error.js} +1 -1
- package/src/{devise.mjs → devise.js} +5 -9
- package/src/draggable-sort/index.jsx +3 -3
- package/src/draggable-sort/item.jsx +2 -2
- package/src/{error-logger.mjs → error-logger.js} +1 -1
- package/src/event-connection.jsx +1 -1
- package/src/event-model-class.jsx +1 -1
- package/src/form.jsx +1 -1
- package/src/index.js +3 -0
- package/src/inputs/attachment.jsx +2 -2
- package/src/inputs/checkbox.jsx +7 -6
- package/src/inputs/checkboxes.jsx +1 -1
- package/src/inputs/input-wrapper.jsx +1 -1
- package/src/inputs/input.jsx +8 -7
- package/src/inputs/money.jsx +3 -3
- package/src/inputs/select.jsx +1 -1
- package/src/{key-value-store.mjs → key-value-store.js} +1 -1
- package/src/link.jsx +2 -2
- package/src/modal.jsx +1 -1
- package/src/{model-class-require.mjs → model-class-require.js} +4 -2
- package/src/{model-events.mjs → model-events.js} +1 -1
- package/src/{model-name.mjs → model-name.js} +1 -1
- package/src/{model-recipes-loader.mjs → model-recipes-loader.js} +1 -1
- package/src/{model-recipes-model-loader.mjs → model-recipes-model-loader.js} +2 -2
- package/src/{models-response-reader.mjs → models-response-reader.js} +2 -2
- package/src/models.js +7 -0
- package/src/{models.mjs.erb → models.js.erb} +1 -1
- package/src/{params.mjs → params.js} +2 -2
- package/src/{preloaded.mjs → preloaded.js} +1 -1
- package/src/resize-observer.jsx +1 -1
- package/src/router/route.jsx +1 -1
- package/src/router/switch.jsx +1 -1
- package/src/router.jsx +1 -1
- package/src/{routes-native.mjs → routes-native.js} +1 -1
- package/src/{services.mjs → services.js} +1 -1
- package/src/{session-status-updater.mjs → session-status-updater.js} +3 -3
- package/src/{source-maps-loader.mjs → source-maps-loader.js} +1 -1
- package/src/super-admin/edit-page/edit-attribute-checkbox.jsx +1 -1
- package/src/super-admin/edit-page/edit-attribute-content.jsx +1 -1
- package/src/super-admin/edit-page/edit-attribute-input.jsx +1 -1
- package/src/super-admin/edit-page/edit-attribute.jsx +1 -1
- package/src/super-admin/edit-page.jsx +2 -2
- package/src/super-admin/has-edit-config.js +1 -1
- package/src/super-admin/index-page.jsx +1 -1
- package/src/super-admin/index.jsx +7 -7
- package/src/super-admin/layout/header/index.jsx +2 -2
- package/src/super-admin/layout/index.jsx +3 -3
- package/src/super-admin/layout/menu/index.jsx +3 -3
- package/src/super-admin/layout/menu/menu-content.jsx +2 -2
- package/src/super-admin/layout/menu/{menu-item/index.jsx → menu-item.jsx} +5 -6
- package/src/super-admin/layout/no-access.jsx +2 -2
- package/src/super-admin/model-class-table.jsx +3 -3
- package/src/super-admin/models.js +1 -1
- package/src/super-admin/show-nav.jsx +2 -2
- package/src/super-admin/show-page/belongs-to-attribute-row.jsx +1 -1
- package/src/super-admin/show-page/index.jsx +2 -2
- package/src/super-admin/show-reflection-actions.jsx +1 -1
- package/src/super-admin/show-reflection-link.jsx +1 -1
- package/src/super-admin/show-reflection-page.jsx +1 -1
- package/src/table/column-content.jsx +1 -1
- package/src/table/filters/filter-form.jsx +1 -1
- package/src/table/filters/index.jsx +5 -3
- package/src/table/filters/load-search-modal.jsx +6 -4
- package/src/table/filters/save-search-modal.jsx +4 -4
- package/src/table/header-select.jsx +1 -1
- package/src/table/model-column.jsx +1 -1
- package/src/table/model-row.jsx +2 -2
- package/src/table/{select-calculator.mjs → select-calculator.js} +1 -1
- package/src/table/settings/column-row.jsx +2 -2
- package/src/table/settings/download-action.jsx +3 -3
- package/src/table/settings/index.jsx +3 -3
- package/src/table/table-settings.js +5 -4
- package/src/table/table.jsx +8 -8
- package/src/table/{use-sorting.mjs → use-sorting.js} +1 -1
- package/src/table/worker-plugins-check-all-checkbox.jsx +2 -2
- package/src/table/worker-plugins-checkbox.jsx +2 -2
- package/src/{translated-collections.mjs → translated-collections.js} +1 -1
- package/src/updated-attribute.jsx +1 -1
- package/src/{use-breakpoint.mjs → use-breakpoint.js} +2 -2
- package/src/use-can-can.js +55 -0
- package/src/{use-collection.mjs → use-collection.js} +4 -4
- package/src/{use-created-event.mjs → use-created-event.js} +2 -2
- package/src/{use-current-user.mjs → use-current-user.js} +6 -5
- package/src/{use-destroyed-event.mjs → use-destroyed-event.js} +2 -2
- package/src/{use-input.mjs → use-input.js} +5 -5
- package/src/use-model-event.js +2 -2
- package/src/{use-model.mjs → use-model.js} +4 -4
- package/src/{use-resize-observer.mjs → use-resize-observer.js} +1 -1
- package/src/use-router.jsx +2 -2
- package/src/{use-updated-event.mjs → use-updated-event.js} +2 -2
- package/src/{use-validation-errors.mjs → use-validation-errors.js} +3 -3
- package/src/utils/checkbox.jsx +2 -2
- package/src/{validation-error.mjs → validation-error.js} +1 -1
- package/src/{validation-errors.mjs → validation-errors.js} +1 -1
- package/src/with-current-user.jsx +1 -1
- package/src/with-model.jsx +1 -1
- package/__tests__/base-model.test.mjs +0 -71
- package/__tests__/cable-connection-pool.test.mjs +0 -227
- package/__tests__/cable-subscription-pool.test.mjs +0 -27
- package/__tests__/can-can.test.mjs +0 -34
- package/__tests__/collection.test.mjs +0 -51
- package/__tests__/custom-error.test.mjs +0 -13
- package/__tests__/model-name.test.mjs +0 -34
- package/__tests__/model-prop-type.test.mjs +0 -113
- package/__tests__/params.test.mjs +0 -40
- package/__tests__/routes-native.test.mjs +0 -104
- package/__tests__/routes.test.mjs +0 -47
- package/__tests__/serializer.test.mjs +0 -30
- package/__tests__/support/task.mjs +0 -27
- package/__tests__/support/user.mjs +0 -32
- package/index.js +0 -1
- package/jest.config.js +0 -9
- package/src/event-created.jsx +0 -12
- package/src/event-destroyed.jsx +0 -25
- package/src/event-emitter-listener.jsx +0 -10
- package/src/event-listener.jsx +0 -25
- package/src/event-updated.jsx +0 -27
- package/src/super-admin/layout/menu/menu-item/style.scss +0 -10
- package/src/use-can-can.mjs +0 -48
- package/src/with-can-can.jsx +0 -12
- package/webpack.config.js +0 -15
- /package/src/{attribute-not-loaded-error.mjs → attribute-not-loaded-error.js} +0 -0
- /package/src/base-model/{column.mjs → column.js} +0 -0
- /package/src/base-model/{scope.mjs → scope.js} +0 -0
- /package/src/{cache-key-generator.mjs → cache-key-generator.js} +0 -0
- /package/src/{channels-consumer.mjs → channels-consumer.js} +0 -0
- /package/src/{command-submit-data.mjs → command-submit-data.js} +0 -0
- /package/src/{config.mjs → config.js} +0 -0
- /package/src/{data-set-to-attributes.mjs → data-set-to-attributes.js} +0 -0
- /package/src/draggable-sort/{controller.mjs → controller.js} +0 -0
- /package/src/{error-messages.mjs → error-messages.js} +0 -0
- /package/src/{events.mjs → events.js} +0 -0
- /package/src/inputs/{auto-submit.mjs → auto-submit.js} +0 -0
- /package/src/inputs/{id-for-component.mjs → id-for-component.js} +0 -0
- /package/src/inputs/{name-for-component.mjs → name-for-component.js} +0 -0
- /package/src/{instance-of-class-name.mjs → instance-of-class-name.js} +0 -0
- /package/src/{logger.mjs → logger.js} +0 -0
- /package/src/{model-prop-type.mjs → model-prop-type.js} +0 -0
- /package/src/{money-formatter.mjs → money-formatter.js} +0 -0
- /package/src/{not-loaded-error.mjs → not-loaded-error.js} +0 -0
- /package/src/{result.mjs → result.js} +0 -0
- /package/src/{routes.mjs → routes.js} +0 -0
- /package/src/{run-last.mjs → run-last.js} +0 -0
- /package/src/{serializer.mjs → serializer.js} +0 -0
- /package/src/table/{column-identifier.mjs → column-identifier.js} +0 -0
- /package/src/table/{column-visible.mjs → column-visible.js} +0 -0
- /package/src/table/{model-callback-args.mjs → model-callback-args.js} +0 -0
- /package/src/{translated-collections-data.mjs.erb → translated-collections-data.js.erb} +0 -0
- /package/src/{url-encode.mjs → url-encode.js} +0 -0
- /package/src/{use-event-emitter.mjs → use-event-emitter.js} +0 -0
- /package/src/{use-event-listener.mjs → use-event-listener.js} +0 -0
- /package/src/{use-screen-layout.mjs → use-screen-layout.js} +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 FontAwesomeIcon from "react-native-vector-icons/FontAwesome";
|
|
16
|
+
import { Form } from "../form";
|
|
17
|
+
import Header from "./components/header";
|
|
18
|
+
import HeaderColumn from "./header-column";
|
|
19
|
+
import HeaderSelect from "./header-select";
|
|
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/src/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(FontAwesomeIcon, {
|
|
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(FontAwesomeIcon, {
|
|
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","FontAwesomeIcon","Form","Header","HeaderColumn","HeaderSelect","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 FontAwesomeIcon from \"react-native-vector-icons/FontAwesome\"\nimport {Form} from \"../form\"\nimport Header from \"./components/header\"\nimport HeaderColumn from \"./header-column\"\nimport HeaderSelect from \"./header-select\"\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/src/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          <FontAwesomeIcon 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            <FontAwesomeIcon 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":[]}
|