@airtable/blocks 1.9.0 → 1.10.0-experimental-48096ae-20211116
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/CHANGELOG.md +10 -1
- package/dist/cjs/color_utils.js +2 -1
- package/dist/cjs/colors.js +2 -1
- package/dist/cjs/error_utils.js +19 -1
- package/dist/cjs/event_tracker.js +2 -1
- package/dist/cjs/global_config.js +2 -1
- package/dist/cjs/index.js +2 -1
- package/dist/cjs/injected/airtable_interface.js +2 -1
- package/dist/cjs/models/abstract_model.js +2 -1
- package/dist/cjs/models/abstract_model_with_async_data.js +2 -1
- package/dist/cjs/models/base.js +4 -2
- package/dist/cjs/models/create_aggregators.js +2 -1
- package/dist/cjs/models/cursor.js +4 -1
- package/dist/cjs/models/field.js +5 -14
- package/dist/cjs/models/grouped_record_query_result.js +7 -15
- package/dist/cjs/models/linked_records_query_result.js +77 -28
- package/dist/cjs/models/models.js +2 -1
- package/dist/cjs/models/mutation_constants.js +2 -1
- package/dist/cjs/models/mutations.js +20 -163
- package/dist/cjs/models/object_pool.js +2 -1
- package/dist/cjs/models/query_manager.js +328 -0
- package/dist/cjs/models/record.js +310 -56
- package/dist/cjs/models/record_coloring.js +2 -1
- package/dist/cjs/models/record_query_result.js +6 -2
- package/dist/cjs/models/record_store.js +556 -766
- package/dist/cjs/models/session.js +2 -1
- package/dist/cjs/models/table.js +10 -8
- package/dist/cjs/models/table_or_view_query_result.js +482 -415
- package/dist/cjs/models/view.js +2 -1
- package/dist/cjs/models/view_data_store.js +245 -296
- package/dist/cjs/models/view_metadata_query_result.js +2 -1
- package/dist/cjs/perform_record_action.js +2 -1
- package/dist/cjs/private_utils.js +42 -1
- package/dist/cjs/sdk.js +13 -2
- package/dist/cjs/settings_button.js +2 -1
- package/dist/cjs/stats/block_stats.js +2 -1
- package/dist/cjs/testing/abstract_mock_airtable_interface.js +57 -11
- package/dist/cjs/types/aggregators.js +2 -1
- package/dist/cjs/types/airtable_interface.js +2 -1
- package/dist/cjs/types/attachment.js +2 -1
- package/dist/cjs/types/backend_fetch_types.js +2 -1
- package/dist/cjs/types/base.js +2 -1
- package/dist/cjs/types/block.js +2 -1
- package/dist/cjs/types/block_query_spec.js +86 -0
- package/dist/cjs/types/collaborator.js +2 -1
- package/dist/cjs/types/cursor.js +2 -1
- package/dist/cjs/types/field.js +2 -1
- package/dist/cjs/types/global_config.js +2 -1
- package/dist/cjs/types/mutations.js +2 -1
- package/dist/cjs/types/permission_levels.js +2 -1
- package/dist/cjs/types/record.js +2 -1
- package/dist/cjs/types/record_action_data.js +2 -1
- package/dist/cjs/types/stat.js +2 -1
- package/dist/cjs/types/table.js +2 -1
- package/dist/cjs/types/undo_redo.js +2 -1
- package/dist/cjs/types/view.js +2 -1
- package/dist/cjs/types/viewport.js +2 -1
- package/dist/cjs/ui/base_provider.js +2 -1
- package/dist/cjs/ui/baymax_utils.js +2 -1
- package/dist/cjs/ui/block_wrapper.js +2 -1
- package/dist/cjs/ui/box.js +2 -1
- package/dist/cjs/ui/button.js +2 -1
- package/dist/cjs/ui/cell_renderer.js +2 -1
- package/dist/cjs/ui/choice_token.js +2 -1
- package/dist/cjs/ui/collaborator_token.js +2 -1
- package/dist/cjs/ui/color_palette.js +2 -1
- package/dist/cjs/ui/color_palette_synced.js +2 -1
- package/dist/cjs/ui/confirmation_dialog.js +2 -1
- package/dist/cjs/ui/control_sizes.js +2 -1
- package/dist/cjs/ui/create_detect_element_resize.js +2 -1
- package/dist/cjs/ui/css_helpers.js +2 -1
- package/dist/cjs/ui/dialog.js +2 -1
- package/dist/cjs/ui/dialog_close_button.js +2 -1
- package/dist/cjs/ui/expand_record.js +2 -1
- package/dist/cjs/ui/expand_record_list.js +2 -1
- package/dist/cjs/ui/expand_record_picker_async.js +2 -1
- package/dist/cjs/ui/field_icon.js +2 -1
- package/dist/cjs/ui/field_picker.js +2 -1
- package/dist/cjs/ui/field_picker_synced.js +2 -1
- package/dist/cjs/ui/form_field.js +2 -1
- package/dist/cjs/ui/geometry/geometry.js +2 -1
- package/dist/cjs/ui/geometry/point.js +2 -1
- package/dist/cjs/ui/geometry/rect.js +2 -1
- package/dist/cjs/ui/geometry/size.js +2 -1
- package/dist/cjs/ui/global_alert.js +2 -1
- package/dist/cjs/ui/global_config_synced_component_helpers.js +2 -1
- package/dist/cjs/ui/heading.js +2 -1
- package/dist/cjs/ui/icon.js +2 -1
- package/dist/cjs/ui/icon_config.js +6 -3
- package/dist/cjs/ui/initialize_block.js +2 -1
- package/dist/cjs/ui/input.js +2 -1
- package/dist/cjs/ui/input_synced.js +2 -1
- package/dist/cjs/ui/key_codes.js +2 -1
- package/dist/cjs/ui/label.js +2 -1
- package/dist/cjs/ui/link.js +2 -1
- package/dist/cjs/ui/loader.js +2 -1
- package/dist/cjs/ui/modal.js +2 -1
- package/dist/cjs/ui/model_picker_select.js +2 -1
- package/dist/cjs/ui/popover.js +2 -1
- package/dist/cjs/ui/progress_bar.js +2 -1
- package/dist/cjs/ui/record_card.js +2 -1
- package/dist/cjs/ui/record_card_list.js +2 -1
- package/dist/cjs/ui/remote_utils.js +2 -1
- package/dist/cjs/ui/sdk_context.js +2 -1
- package/dist/cjs/ui/select.js +2 -1
- package/dist/cjs/ui/select_and_select_buttons_helpers.js +2 -1
- package/dist/cjs/ui/select_buttons.js +2 -1
- package/dist/cjs/ui/select_buttons_synced.js +2 -1
- package/dist/cjs/ui/select_synced.js +2 -1
- package/dist/cjs/ui/switch.js +2 -1
- package/dist/cjs/ui/switch_synced.js +2 -1
- package/dist/cjs/ui/synced.js +2 -1
- package/dist/cjs/ui/system/all_styles_set.js +2 -1
- package/dist/cjs/ui/system/appearance/appearance_set.js +2 -1
- package/dist/cjs/ui/system/appearance/background_color.js +2 -1
- package/dist/cjs/ui/system/appearance/border.js +2 -1
- package/dist/cjs/ui/system/appearance/border_radius.js +2 -1
- package/dist/cjs/ui/system/appearance/box_shadow.js +2 -1
- package/dist/cjs/ui/system/appearance/opacity.js +2 -1
- package/dist/cjs/ui/system/dimensions/dimensions_set.js +2 -1
- package/dist/cjs/ui/system/dimensions/height.js +2 -1
- package/dist/cjs/ui/system/dimensions/max_height.js +2 -1
- package/dist/cjs/ui/system/dimensions/max_width.js +2 -1
- package/dist/cjs/ui/system/dimensions/min_height.js +2 -1
- package/dist/cjs/ui/system/dimensions/min_width.js +2 -1
- package/dist/cjs/ui/system/dimensions/width.js +2 -1
- package/dist/cjs/ui/system/display.js +2 -1
- package/dist/cjs/ui/system/flex_container/align_content.js +2 -1
- package/dist/cjs/ui/system/flex_container/align_items.js +2 -1
- package/dist/cjs/ui/system/flex_container/flex_container_set.js +2 -1
- package/dist/cjs/ui/system/flex_container/flex_direction.js +2 -1
- package/dist/cjs/ui/system/flex_container/flex_wrap.js +2 -1
- package/dist/cjs/ui/system/flex_container/justify_content.js +2 -1
- package/dist/cjs/ui/system/flex_container/justify_items.js +2 -1
- package/dist/cjs/ui/system/flex_item/align_self.js +2 -1
- package/dist/cjs/ui/system/flex_item/flex.js +2 -1
- package/dist/cjs/ui/system/flex_item/flex_basis.js +2 -1
- package/dist/cjs/ui/system/flex_item/flex_grow.js +2 -1
- package/dist/cjs/ui/system/flex_item/flex_item_set.js +2 -1
- package/dist/cjs/ui/system/flex_item/flex_shrink.js +2 -1
- package/dist/cjs/ui/system/flex_item/justify_self.js +2 -1
- package/dist/cjs/ui/system/flex_item/order.js +2 -1
- package/dist/cjs/ui/system/index.js +2 -1
- package/dist/cjs/ui/system/overflow.js +2 -1
- package/dist/cjs/ui/system/position/bottom.js +2 -1
- package/dist/cjs/ui/system/position/left.js +2 -1
- package/dist/cjs/ui/system/position/position.js +2 -1
- package/dist/cjs/ui/system/position/position_set.js +2 -1
- package/dist/cjs/ui/system/position/right.js +2 -1
- package/dist/cjs/ui/system/position/top.js +2 -1
- package/dist/cjs/ui/system/position/z_index.js +2 -1
- package/dist/cjs/ui/system/spacing/margin.js +2 -1
- package/dist/cjs/ui/system/spacing/padding.js +2 -1
- package/dist/cjs/ui/system/spacing/spacing_set.js +2 -1
- package/dist/cjs/ui/system/typography/font_family.js +2 -1
- package/dist/cjs/ui/system/typography/font_size.js +2 -1
- package/dist/cjs/ui/system/typography/font_style.js +2 -1
- package/dist/cjs/ui/system/typography/font_weight.js +2 -1
- package/dist/cjs/ui/system/typography/letter_spacing.js +2 -1
- package/dist/cjs/ui/system/typography/line_height.js +2 -1
- package/dist/cjs/ui/system/typography/text_align.js +2 -1
- package/dist/cjs/ui/system/typography/text_color.js +2 -1
- package/dist/cjs/ui/system/typography/text_decoration.js +2 -1
- package/dist/cjs/ui/system/typography/text_transform.js +2 -1
- package/dist/cjs/ui/system/typography/typography_set.js +2 -1
- package/dist/cjs/ui/system/utils/create_responsive_prop_type.js +2 -1
- package/dist/cjs/ui/system/utils/create_style_prop_types.js +2 -1
- package/dist/cjs/ui/system/utils/csstype.js +2 -1
- package/dist/cjs/ui/system/utils/ensure_numbers_are_within_scale.js +2 -1
- package/dist/cjs/ui/system/utils/get_style_props_for_responsive_prop.js +2 -1
- package/dist/cjs/ui/system/utils/types.js +2 -1
- package/dist/cjs/ui/table_picker.js +2 -1
- package/dist/cjs/ui/table_picker_synced.js +2 -1
- package/dist/cjs/ui/text.js +2 -1
- package/dist/cjs/ui/text_button.js +2 -1
- package/dist/cjs/ui/theme/default_theme/button_variants.js +2 -1
- package/dist/cjs/ui/theme/default_theme/control_sizes.js +2 -1
- package/dist/cjs/ui/theme/default_theme/heading_styles.js +2 -1
- package/dist/cjs/ui/theme/default_theme/index.js +2 -1
- package/dist/cjs/ui/theme/default_theme/input_variants.js +2 -1
- package/dist/cjs/ui/theme/default_theme/link_variants.js +2 -1
- package/dist/cjs/ui/theme/default_theme/select_buttons_variants.js +2 -1
- package/dist/cjs/ui/theme/default_theme/select_variants.js +2 -1
- package/dist/cjs/ui/theme/default_theme/switch_variants.js +2 -1
- package/dist/cjs/ui/theme/default_theme/text_button_variants.js +2 -1
- package/dist/cjs/ui/theme/default_theme/text_styles.js +2 -1
- package/dist/cjs/ui/theme/default_theme/tokens.js +2 -1
- package/dist/cjs/ui/theme/theme_context.js +2 -1
- package/dist/cjs/ui/theme/use_theme.js +2 -1
- package/dist/cjs/ui/tooltip.js +2 -1
- package/dist/cjs/ui/types/aria_props.js +2 -1
- package/dist/cjs/ui/types/data_attributes_prop.js +2 -1
- package/dist/cjs/ui/types/tooltip_anchor_props.js +2 -1
- package/dist/cjs/ui/ui.js +2 -1
- package/dist/cjs/ui/unstable_standalone_ui.js +2 -1
- package/dist/cjs/ui/use_array_identity.js +2 -1
- package/dist/cjs/ui/use_base.js +2 -1
- package/dist/cjs/ui/use_cursor.js +2 -1
- package/dist/cjs/ui/use_form_field.js +2 -1
- package/dist/cjs/ui/use_global_config.js +3 -2
- package/dist/cjs/ui/use_loadable.js +2 -1
- package/dist/cjs/ui/use_record_action_data.js +2 -1
- package/dist/cjs/ui/use_records.js +7 -2
- package/dist/cjs/ui/use_session.js +2 -1
- package/dist/cjs/ui/use_settings_button.js +2 -1
- package/dist/cjs/ui/use_styled_system.js +2 -1
- package/dist/cjs/ui/use_synced.js +2 -1
- package/dist/cjs/ui/use_text_color_for_background_color.js +2 -1
- package/dist/cjs/ui/use_view_metadata.js +2 -1
- package/dist/cjs/ui/use_viewport.js +2 -1
- package/dist/cjs/ui/use_watchable.js +2 -1
- package/dist/cjs/ui/view_picker.js +2 -1
- package/dist/cjs/ui/view_picker_synced.js +2 -1
- package/dist/cjs/ui/viewport_constraint.js +2 -1
- package/dist/cjs/ui/with_hooks.js +2 -1
- package/dist/cjs/ui/with_styled_system.js +2 -1
- package/dist/cjs/undo_redo.js +2 -1
- package/dist/cjs/unstable_private_utils.js +2 -1
- package/dist/cjs/unstable_testing_utils.js +2 -1
- package/dist/cjs/viewport.js +2 -1
- package/dist/cjs/warning.js +2 -1
- package/dist/cjs/watchable.js +17 -2
- package/dist/types/src/models/base.d.ts +2 -1
- package/dist/types/src/models/base.d.ts.map +1 -1
- package/dist/types/src/models/cursor.d.ts +2 -0
- package/dist/types/src/models/cursor.d.ts.map +1 -1
- package/dist/types/src/models/field.d.ts +3 -13
- package/dist/types/src/models/field.d.ts.map +1 -1
- package/dist/types/src/models/grouped_record_query_result.d.ts +3 -3
- package/dist/types/src/models/grouped_record_query_result.d.ts.map +1 -1
- package/dist/types/src/models/linked_records_query_result.d.ts.map +1 -1
- package/dist/types/src/models/mutations.d.ts.map +1 -1
- package/dist/types/src/models/query_manager.d.ts +2 -0
- package/dist/types/src/models/query_manager.d.ts.map +1 -0
- package/dist/types/src/models/record.d.ts +12 -3
- package/dist/types/src/models/record.d.ts.map +1 -1
- package/dist/types/src/models/record_query_result.d.ts +3 -2
- package/dist/types/src/models/record_query_result.d.ts.map +1 -1
- package/dist/types/src/models/record_store.d.ts.map +1 -1
- package/dist/types/src/models/table.d.ts +2 -1
- package/dist/types/src/models/table.d.ts.map +1 -1
- package/dist/types/src/models/table_or_view_query_result.d.ts +3 -5
- package/dist/types/src/models/table_or_view_query_result.d.ts.map +1 -1
- package/dist/types/src/models/view_data_store.d.ts +0 -1
- package/dist/types/src/models/view_data_store.d.ts.map +1 -1
- package/dist/types/src/models/view_metadata_query_result.d.ts +1 -1
- package/dist/types/src/models/view_metadata_query_result.d.ts.map +1 -1
- package/dist/types/src/private_utils.d.ts +24 -1
- package/dist/types/src/private_utils.d.ts.map +1 -1
- package/dist/types/src/sdk.d.ts.map +1 -1
- package/dist/types/src/testing/abstract_mock_airtable_interface.d.ts +11 -11
- package/dist/types/src/testing/abstract_mock_airtable_interface.d.ts.map +1 -1
- package/dist/types/src/types/airtable_interface.d.ts +48 -20
- package/dist/types/src/types/airtable_interface.d.ts.map +1 -1
- package/dist/types/src/types/block_query_spec.d.ts +139 -0
- package/dist/types/src/types/block_query_spec.d.ts.map +1 -0
- package/dist/types/src/types/field.d.ts +7 -1
- package/dist/types/src/types/field.d.ts.map +1 -1
- package/dist/types/src/types/table.d.ts +0 -2
- package/dist/types/src/types/table.d.ts.map +1 -1
- package/dist/types/src/types/view.d.ts +3 -8
- package/dist/types/src/types/view.d.ts.map +1 -1
- package/dist/types/src/ui/cell_renderer.d.ts +1 -1
- package/dist/types/src/ui/color_palette.d.ts +1 -1
- package/dist/types/src/ui/control_sizes.d.ts +1 -1
- package/dist/types/src/ui/field_icon.d.ts +1 -1
- package/dist/types/src/ui/heading.d.ts +1 -1
- package/dist/types/src/ui/icon.d.ts +1 -1
- package/dist/types/src/ui/icon_config.d.ts +33 -31
- package/dist/types/src/ui/icon_config.d.ts.map +1 -1
- package/dist/types/src/ui/input.d.ts +10 -10
- package/dist/types/src/ui/link.d.ts +1 -1
- package/dist/types/src/ui/link.d.ts.map +1 -1
- package/dist/types/src/ui/record_card.d.ts +1 -1
- package/dist/types/src/ui/system/utils/create_style_prop_types.d.ts +1 -1
- package/dist/types/src/ui/system/utils/create_style_prop_types.d.ts.map +1 -1
- package/dist/types/src/ui/text.d.ts +1 -1
- package/dist/types/src/ui/theme/default_theme/index.d.ts +1 -1
- package/dist/types/src/ui/theme/theme_context.d.ts +1 -1
- package/dist/types/src/ui/theme/use_theme.d.ts +1 -1
- package/dist/types/src/ui/use_global_config.d.ts +1 -1
- package/dist/types/src/watchable.d.ts.map +1 -1
- package/dist/types/test/airtable_interface_mocks/fixture_data.d.ts +7 -5
- package/dist/types/test/airtable_interface_mocks/fixture_data.d.ts.map +1 -1
- package/dist/types/test/airtable_interface_mocks/mock_airtable_interface.d.ts +18 -11
- package/dist/types/test/airtable_interface_mocks/mock_airtable_interface.d.ts.map +1 -1
- package/dist/types/test/airtable_interface_mocks/mock_base_data_stores.d.ts +51 -0
- package/dist/types/test/airtable_interface_mocks/mock_base_data_stores.d.ts.map +1 -0
- package/dist/types/test/test_helpers.d.ts +2 -0
- package/dist/types/test/test_helpers.d.ts.map +1 -1
- package/package.json +2 -1
|
@@ -12,6 +12,8 @@ require("core-js/modules/es.array.concat");
|
|
|
12
12
|
|
|
13
13
|
require("core-js/modules/es.array.filter");
|
|
14
14
|
|
|
15
|
+
require("core-js/modules/es.array.includes");
|
|
16
|
+
|
|
15
17
|
require("core-js/modules/es.array.iterator");
|
|
16
18
|
|
|
17
19
|
require("core-js/modules/es.array.map");
|
|
@@ -24,6 +26,8 @@ require("core-js/modules/es.promise");
|
|
|
24
26
|
|
|
25
27
|
require("core-js/modules/es.set");
|
|
26
28
|
|
|
29
|
+
require("core-js/modules/es.string.includes");
|
|
30
|
+
|
|
27
31
|
require("core-js/modules/es.string.starts-with");
|
|
28
32
|
|
|
29
33
|
require("core-js/modules/web.dom-collections.for-each");
|
|
@@ -59,9 +63,13 @@ var _private_utils = require("../private_utils");
|
|
|
59
63
|
|
|
60
64
|
var _error_utils = require("../error_utils");
|
|
61
65
|
|
|
66
|
+
var _block_query_spec = require("../types/block_query_spec");
|
|
67
|
+
|
|
62
68
|
var _table = _interopRequireWildcard(require("./table"));
|
|
63
69
|
|
|
64
|
-
var
|
|
70
|
+
var _view = _interopRequireDefault(require("./view"));
|
|
71
|
+
|
|
72
|
+
var _record_query_result = _interopRequireWildcard(require("./record_query_result"));
|
|
65
73
|
|
|
66
74
|
var _record_coloring = require("./record_coloring");
|
|
67
75
|
|
|
@@ -97,6 +105,17 @@ function (_RecordQueryResult) {
|
|
|
97
105
|
|
|
98
106
|
/** @internal */
|
|
99
107
|
|
|
108
|
+
/**
|
|
109
|
+
* Tracks a unique ID for each model query that has been loaded.
|
|
110
|
+
* Note that hyperbase may return a new model query ID even if the
|
|
111
|
+
* query itself is identical to a previous one. Having these unique
|
|
112
|
+
* IDs allows the SDK to maintain an accurate reference count of
|
|
113
|
+
* all model loads. _loadedSourceModelQueryIds must only be updated
|
|
114
|
+
* before unloading occurs.
|
|
115
|
+
*
|
|
116
|
+
* @internal
|
|
117
|
+
*/
|
|
118
|
+
|
|
100
119
|
/** @internal */
|
|
101
120
|
|
|
102
121
|
/** @internal */
|
|
@@ -124,17 +143,6 @@ function (_RecordQueryResult) {
|
|
|
124
143
|
/** @internal */
|
|
125
144
|
// lazily generated set of record ids
|
|
126
145
|
|
|
127
|
-
/** @internal */
|
|
128
|
-
// NOTE: when a cellValue key (cellValues or cellValuesInField:) is watched, we want
|
|
129
|
-
// to make sure we watch the associated key on the table. However, we need to make
|
|
130
|
-
// sure that we only watch the table once for each key. Otherwise, the callbacks
|
|
131
|
-
// for each key will get called more than once for each change event. This is because
|
|
132
|
-
// Watchable stores references to callbacks for each key, and on each _onChange event
|
|
133
|
-
// calls each callback for that key. If we watch the table more than once, then we'll
|
|
134
|
-
// call _onChange more than once, and each callback will be called more than once, which
|
|
135
|
-
// is undesirable. Instead, we'll store watch counts for each key to make sure we only
|
|
136
|
-
// watch the table once.
|
|
137
|
-
|
|
138
146
|
/** @internal */
|
|
139
147
|
|
|
140
148
|
/** @internal */
|
|
@@ -146,7 +154,8 @@ function (_RecordQueryResult) {
|
|
|
146
154
|
(0, _classCallCheck2.default)(this, TableOrViewQueryResult);
|
|
147
155
|
_this = (0, _possibleConstructorReturn2.default)(this, (0, _getPrototypeOf2.default)(TableOrViewQueryResult).call(this, sdk, normalizedOpts));
|
|
148
156
|
(0, _defineProperty2.default)((0, _assertThisInitialized2.default)(_this), "_sourceModel", void 0);
|
|
149
|
-
(0, _defineProperty2.default)((0, _assertThisInitialized2.default)(_this), "
|
|
157
|
+
(0, _defineProperty2.default)((0, _assertThisInitialized2.default)(_this), "_mostRecentSourceModelLoadedPromise", void 0);
|
|
158
|
+
(0, _defineProperty2.default)((0, _assertThisInitialized2.default)(_this), "_loadedSourceModelQueryIds", void 0);
|
|
150
159
|
(0, _defineProperty2.default)((0, _assertThisInitialized2.default)(_this), "_table", void 0);
|
|
151
160
|
(0, _defineProperty2.default)((0, _assertThisInitialized2.default)(_this), "_fieldIdsSetToLoadOrNullIfAllFields", void 0);
|
|
152
161
|
(0, _defineProperty2.default)((0, _assertThisInitialized2.default)(_this), "_visList", void 0);
|
|
@@ -156,10 +165,145 @@ function (_RecordQueryResult) {
|
|
|
156
165
|
(0, _defineProperty2.default)((0, _assertThisInitialized2.default)(_this), "_orderedGroups", void 0);
|
|
157
166
|
(0, _defineProperty2.default)((0, _assertThisInitialized2.default)(_this), "_loadedGroupLevels", void 0);
|
|
158
167
|
(0, _defineProperty2.default)((0, _assertThisInitialized2.default)(_this), "_recordIdsSet", null);
|
|
159
|
-
(0, _defineProperty2.default)((0, _assertThisInitialized2.default)(_this), "_cellValueKeyWatchCounts", void 0);
|
|
160
168
|
(0, _defineProperty2.default)((0, _assertThisInitialized2.default)(_this), "__groupedRecordQueryResultPool", void 0);
|
|
169
|
+
(0, _defineProperty2.default)((0, _assertThisInitialized2.default)(_this), "_watchConfigByWatchableKey", {
|
|
170
|
+
// Handles if this is a prefix
|
|
171
|
+
[_record_query_result.default.WatchableCellValuesInFieldKeyPrefix]: (key, functionToCallWithKey) => {
|
|
172
|
+
var fieldId = key.substring(_record_query_result.default.WatchableCellValuesInFieldKeyPrefix.length);
|
|
173
|
+
|
|
174
|
+
if (_this._fieldIdsSetToLoadOrNullIfAllFields && !(0, _private_utils.has)(_this._fieldIdsSetToLoadOrNullIfAllFields, fieldId)) {
|
|
175
|
+
throw (0, _error_utils.spawnError)("Can't watch or unwatch field because it wasn't included in RecordQueryResult fields: %s", fieldId);
|
|
176
|
+
}
|
|
177
|
+
|
|
178
|
+
functionToCallWithKey(_record_query_result.default.WatchableCellValuesInFieldKeyPrefix + fieldId);
|
|
179
|
+
},
|
|
180
|
+
[_record_query_result.default.WatchableKeys.cellValues]: (key, functionToCallWithKey) => {
|
|
181
|
+
if (_this._fieldIdsSetToLoadOrNullIfAllFields) {
|
|
182
|
+
for (var _i = 0, _Object$keys = Object.keys(_this._fieldIdsSetToLoadOrNullIfAllFields); _i < _Object$keys.length; _i++) {
|
|
183
|
+
var fieldId = _Object$keys[_i];
|
|
184
|
+
functionToCallWithKey(_record_query_result.default.WatchableCellValuesInFieldKeyPrefix + fieldId);
|
|
185
|
+
}
|
|
186
|
+
} else {
|
|
187
|
+
functionToCallWithKey(_record_query_result.default.WatchableKeys.cellValues);
|
|
188
|
+
}
|
|
189
|
+
}
|
|
190
|
+
});
|
|
191
|
+
(0, _defineProperty2.default)((0, _assertThisInitialized2.default)(_this), "_unloadDataAsync", () => {
|
|
192
|
+
var viewDataStore, _iteratorNormalCompletion, _didIteratorError, _iteratorError, _iterator, _step, sort, field;
|
|
193
|
+
|
|
194
|
+
return _regenerator.default.async(function _callee$(_context) {
|
|
195
|
+
while (1) {
|
|
196
|
+
switch (_context.prev = _context.next) {
|
|
197
|
+
case 0:
|
|
198
|
+
if (!_this._mostRecentSourceModelLoadedPromise) {
|
|
199
|
+
_context.next = 3;
|
|
200
|
+
break;
|
|
201
|
+
}
|
|
202
|
+
|
|
203
|
+
_context.next = 3;
|
|
204
|
+
return _regenerator.default.awrap(_this._mostRecentSourceModelLoadedPromise);
|
|
205
|
+
|
|
206
|
+
case 3:
|
|
207
|
+
// Unload all queries that were subscribed to the entire query
|
|
208
|
+
if (_this._sourceModel instanceof _table.default) {
|
|
209
|
+
_this._recordStore.unloadCellValuesForQueryIdsThatAreSubscribedToAllCells(_this._loadedSourceModelQueryIds);
|
|
210
|
+
} else {
|
|
211
|
+
// Even if the view is deleted, we can still unsubscribe from the cells
|
|
212
|
+
_this._recordStore.unloadViewDataStoreAndCellValuesWithQueryIds(_this._loadedSourceModelQueryIds);
|
|
213
|
+
}
|
|
214
|
+
|
|
215
|
+
_this._mostRecentSourceModelLoadedPromise = null;
|
|
216
|
+
|
|
217
|
+
if (_this._sourceModel instanceof _table.default) {
|
|
218
|
+
_this._recordStore.unwatch(_record_store.WatchableRecordStoreKeys.records, _this._onRecordsChanged, (0, _assertThisInitialized2.default)(_this));
|
|
219
|
+
} else {
|
|
220
|
+
if (!_this._sourceModel.isDeleted) {
|
|
221
|
+
viewDataStore = _this._recordStore.getViewDataStore(_this._sourceModel.id);
|
|
222
|
+
viewDataStore.unwatch(_view_data_store.WatchableViewDataStoreKeys.visibleRecords, _this._onRecordsChanged, (0, _assertThisInitialized2.default)(_this));
|
|
223
|
+
viewDataStore.unwatch(_view_data_store.WatchableViewDataStoreKeys.groups, _this._onGroupsChanged, (0, _assertThisInitialized2.default)(_this));
|
|
224
|
+
viewDataStore.unwatch(_view_data_store.WatchableViewDataStoreKeys.groupLevels, _this._onGroupLevelsChanged, (0, _assertThisInitialized2.default)(_this));
|
|
225
|
+
}
|
|
226
|
+
}
|
|
227
|
+
|
|
228
|
+
_this._recordStore.unwatch(_this._cellValuesForSortWatchKeys, _this._onCellValuesForSortChanged, (0, _assertThisInitialized2.default)(_this));
|
|
229
|
+
|
|
230
|
+
_this._recordStore.unwatch(_this._cellValuesForGroupWatchKeys, _this._onCellValuesForGroupChanged, (0, _assertThisInitialized2.default)(_this));
|
|
231
|
+
|
|
232
|
+
_this._table.unwatch(_table.WatchableTableKeys.fields, _this._onTableFieldsChanged, (0, _assertThisInitialized2.default)(_this)); // If the table is deleted, can't call getFieldById on it below.
|
|
233
|
+
|
|
234
|
+
|
|
235
|
+
if (!(!_this._table.isDeleted && _this._sorts)) {
|
|
236
|
+
_context.next = 29;
|
|
237
|
+
break;
|
|
238
|
+
}
|
|
239
|
+
|
|
240
|
+
_iteratorNormalCompletion = true;
|
|
241
|
+
_didIteratorError = false;
|
|
242
|
+
_iteratorError = undefined;
|
|
243
|
+
_context.prev = 13;
|
|
244
|
+
|
|
245
|
+
for (_iterator = _this._sorts[Symbol.iterator](); !(_iteratorNormalCompletion = (_step = _iterator.next()).done); _iteratorNormalCompletion = true) {
|
|
246
|
+
sort = _step.value;
|
|
247
|
+
field = _this._table.getFieldByIdIfExists(sort.fieldId);
|
|
248
|
+
|
|
249
|
+
if (field) {
|
|
250
|
+
field.unwatch('type', _this._onFieldConfigChanged, (0, _assertThisInitialized2.default)(_this));
|
|
251
|
+
field.unwatch('options', _this._onFieldConfigChanged, (0, _assertThisInitialized2.default)(_this));
|
|
252
|
+
}
|
|
253
|
+
}
|
|
254
|
+
|
|
255
|
+
_context.next = 21;
|
|
256
|
+
break;
|
|
257
|
+
|
|
258
|
+
case 17:
|
|
259
|
+
_context.prev = 17;
|
|
260
|
+
_context.t0 = _context["catch"](13);
|
|
261
|
+
_didIteratorError = true;
|
|
262
|
+
_iteratorError = _context.t0;
|
|
263
|
+
|
|
264
|
+
case 21:
|
|
265
|
+
_context.prev = 21;
|
|
266
|
+
_context.prev = 22;
|
|
267
|
+
|
|
268
|
+
if (!_iteratorNormalCompletion && _iterator.return != null) {
|
|
269
|
+
_iterator.return();
|
|
270
|
+
}
|
|
271
|
+
|
|
272
|
+
case 24:
|
|
273
|
+
_context.prev = 24;
|
|
274
|
+
|
|
275
|
+
if (!_didIteratorError) {
|
|
276
|
+
_context.next = 27;
|
|
277
|
+
break;
|
|
278
|
+
}
|
|
279
|
+
|
|
280
|
+
throw _iteratorError;
|
|
281
|
+
|
|
282
|
+
case 27:
|
|
283
|
+
return _context.finish(24);
|
|
284
|
+
|
|
285
|
+
case 28:
|
|
286
|
+
return _context.finish(21);
|
|
287
|
+
|
|
288
|
+
case 29:
|
|
289
|
+
_this._unloadOrderedGroupsIfNeeded();
|
|
290
|
+
|
|
291
|
+
_this._visList = null;
|
|
292
|
+
_this._orderedRecordIds = null;
|
|
293
|
+
_this._recordIdsSet = null;
|
|
294
|
+
|
|
295
|
+
_this._table.__tableOrViewQueryResultPool.unregisterObjectForReuseStrong((0, _assertThisInitialized2.default)(_this));
|
|
296
|
+
|
|
297
|
+
case 34:
|
|
298
|
+
case "end":
|
|
299
|
+
return _context.stop();
|
|
300
|
+
}
|
|
301
|
+
}
|
|
302
|
+
}, null, null, [[13, 17, 21, 29], [22,, 24, 28]]);
|
|
303
|
+
});
|
|
161
304
|
_this._sourceModel = sourceModel;
|
|
162
|
-
_this.
|
|
305
|
+
_this._mostRecentSourceModelLoadedPromise = null;
|
|
306
|
+
_this._loadedSourceModelQueryIds = [];
|
|
163
307
|
_this._table = normalizedOpts.table;
|
|
164
308
|
var sorts = _this._normalizedOpts.sorts;
|
|
165
309
|
_this._sorts = sorts !== null && sorts !== void 0 ? sorts : null; // TODO (SeanKeenan): Placeholder until we support groups from normalizedOpts
|
|
@@ -169,58 +313,57 @@ function (_RecordQueryResult) {
|
|
|
169
313
|
_this._orderedRecordIds = null;
|
|
170
314
|
_this._orderedGroups = null;
|
|
171
315
|
_this._loadedGroupLevels = null;
|
|
172
|
-
_this._cellValueKeyWatchCounts = {};
|
|
173
316
|
var fieldIdsSetToLoadOrNullIfAllFields = null;
|
|
174
317
|
|
|
175
318
|
if (_this._normalizedOpts.fieldIdsOrNullIfAllFields) {
|
|
176
319
|
fieldIdsSetToLoadOrNullIfAllFields = {};
|
|
177
|
-
var
|
|
178
|
-
var
|
|
179
|
-
var
|
|
320
|
+
var _iteratorNormalCompletion2 = true;
|
|
321
|
+
var _didIteratorError2 = false;
|
|
322
|
+
var _iteratorError2 = undefined;
|
|
180
323
|
|
|
181
324
|
try {
|
|
182
|
-
for (var
|
|
183
|
-
var fieldId =
|
|
325
|
+
for (var _iterator2 = _this._normalizedOpts.fieldIdsOrNullIfAllFields[Symbol.iterator](), _step2; !(_iteratorNormalCompletion2 = (_step2 = _iterator2.next()).done); _iteratorNormalCompletion2 = true) {
|
|
326
|
+
var fieldId = _step2.value;
|
|
184
327
|
fieldIdsSetToLoadOrNullIfAllFields[fieldId] = true;
|
|
185
328
|
} // Need to load data for fields we're sorting by, even if
|
|
186
329
|
// they're not explicitly requested in the `fields` opt.
|
|
187
330
|
|
|
188
331
|
} catch (err) {
|
|
189
|
-
|
|
190
|
-
|
|
332
|
+
_didIteratorError2 = true;
|
|
333
|
+
_iteratorError2 = err;
|
|
191
334
|
} finally {
|
|
192
335
|
try {
|
|
193
|
-
if (!
|
|
194
|
-
|
|
336
|
+
if (!_iteratorNormalCompletion2 && _iterator2.return != null) {
|
|
337
|
+
_iterator2.return();
|
|
195
338
|
}
|
|
196
339
|
} finally {
|
|
197
|
-
if (
|
|
198
|
-
throw
|
|
340
|
+
if (_didIteratorError2) {
|
|
341
|
+
throw _iteratorError2;
|
|
199
342
|
}
|
|
200
343
|
}
|
|
201
344
|
}
|
|
202
345
|
|
|
203
346
|
if (_this._sorts !== null) {
|
|
204
|
-
var
|
|
205
|
-
var
|
|
206
|
-
var
|
|
347
|
+
var _iteratorNormalCompletion3 = true;
|
|
348
|
+
var _didIteratorError3 = false;
|
|
349
|
+
var _iteratorError3 = undefined;
|
|
207
350
|
|
|
208
351
|
try {
|
|
209
|
-
for (var
|
|
210
|
-
var sort =
|
|
352
|
+
for (var _iterator3 = _this._sorts[Symbol.iterator](), _step3; !(_iteratorNormalCompletion3 = (_step3 = _iterator3.next()).done); _iteratorNormalCompletion3 = true) {
|
|
353
|
+
var sort = _step3.value;
|
|
211
354
|
fieldIdsSetToLoadOrNullIfAllFields[sort.fieldId] = true;
|
|
212
355
|
}
|
|
213
356
|
} catch (err) {
|
|
214
|
-
|
|
215
|
-
|
|
357
|
+
_didIteratorError3 = true;
|
|
358
|
+
_iteratorError3 = err;
|
|
216
359
|
} finally {
|
|
217
360
|
try {
|
|
218
|
-
if (!
|
|
219
|
-
|
|
361
|
+
if (!_iteratorNormalCompletion3 && _iterator3.return != null) {
|
|
362
|
+
_iterator3.return();
|
|
220
363
|
}
|
|
221
364
|
} finally {
|
|
222
|
-
if (
|
|
223
|
-
throw
|
|
365
|
+
if (_didIteratorError3) {
|
|
366
|
+
throw _iteratorError3;
|
|
224
367
|
}
|
|
225
368
|
}
|
|
226
369
|
}
|
|
@@ -260,26 +403,26 @@ function (_RecordQueryResult) {
|
|
|
260
403
|
value: function _getOrGenerateRecordIdsSet() {
|
|
261
404
|
if (!this._recordIdsSet) {
|
|
262
405
|
var recordIdsSet = {};
|
|
263
|
-
var
|
|
264
|
-
var
|
|
265
|
-
var
|
|
406
|
+
var _iteratorNormalCompletion4 = true;
|
|
407
|
+
var _didIteratorError4 = false;
|
|
408
|
+
var _iteratorError4 = undefined;
|
|
266
409
|
|
|
267
410
|
try {
|
|
268
|
-
for (var
|
|
269
|
-
var recordId =
|
|
411
|
+
for (var _iterator4 = this.recordIds[Symbol.iterator](), _step4; !(_iteratorNormalCompletion4 = (_step4 = _iterator4.next()).done); _iteratorNormalCompletion4 = true) {
|
|
412
|
+
var recordId = _step4.value;
|
|
270
413
|
recordIdsSet[recordId] = true;
|
|
271
414
|
}
|
|
272
415
|
} catch (err) {
|
|
273
|
-
|
|
274
|
-
|
|
416
|
+
_didIteratorError4 = true;
|
|
417
|
+
_iteratorError4 = err;
|
|
275
418
|
} finally {
|
|
276
419
|
try {
|
|
277
|
-
if (!
|
|
278
|
-
|
|
420
|
+
if (!_iteratorNormalCompletion4 && _iterator4.return != null) {
|
|
421
|
+
_iterator4.return();
|
|
279
422
|
}
|
|
280
423
|
} finally {
|
|
281
|
-
if (
|
|
282
|
-
throw
|
|
424
|
+
if (_didIteratorError4) {
|
|
425
|
+
throw _iteratorError4;
|
|
283
426
|
}
|
|
284
427
|
}
|
|
285
428
|
}
|
|
@@ -296,85 +439,59 @@ function (_RecordQueryResult) {
|
|
|
296
439
|
*/
|
|
297
440
|
|
|
298
441
|
}, {
|
|
299
|
-
key: "
|
|
300
|
-
|
|
301
|
-
/** @internal */
|
|
302
|
-
value: function _incrementCellValueKeyWatchCountAndWatchIfNecessary(key, watchCallback) {
|
|
303
|
-
if (!this._cellValueKeyWatchCounts[key]) {
|
|
304
|
-
this._cellValueKeyWatchCounts[key] = 0;
|
|
305
|
-
|
|
306
|
-
this._recordStore.watch(key, watchCallback, this);
|
|
307
|
-
}
|
|
308
|
-
|
|
309
|
-
this._cellValueKeyWatchCounts[key]++;
|
|
310
|
-
}
|
|
311
|
-
/** @internal */
|
|
312
|
-
|
|
313
|
-
}, {
|
|
314
|
-
key: "_decrementCellValueKeyWatchCountAndUnwatchIfPossible",
|
|
315
|
-
value: function _decrementCellValueKeyWatchCountAndUnwatchIfPossible(key, watchCallback) {
|
|
316
|
-
if (!this._cellValueKeyWatchCounts[key]) {
|
|
317
|
-
// Key isn't watched, so just skip it. This matches behavior of Watchable,
|
|
318
|
-
// where calling unwatch on a key that isn't watched just no-ops.
|
|
319
|
-
return;
|
|
320
|
-
}
|
|
321
|
-
|
|
322
|
-
this._cellValueKeyWatchCounts[key]--;
|
|
323
|
-
|
|
324
|
-
if (this._cellValueKeyWatchCounts[key] === 0) {
|
|
325
|
-
// We're down to zero watches for this key, so we can actually unwatch it now.
|
|
326
|
-
this._recordStore.unwatch(key, watchCallback, this);
|
|
442
|
+
key: "watch",
|
|
327
443
|
|
|
328
|
-
delete this._cellValueKeyWatchCounts[key];
|
|
329
|
-
}
|
|
330
|
-
}
|
|
331
444
|
/** @inheritdoc */
|
|
332
|
-
|
|
333
|
-
}, {
|
|
334
|
-
key: "watch",
|
|
335
445
|
value: function watch(keys, callback, context) {
|
|
336
446
|
var validKeys = (0, _get2.default)((0, _getPrototypeOf2.default)(TableOrViewQueryResult.prototype), "watch", this).call(this, keys, callback, context);
|
|
337
|
-
var _iteratorNormalCompletion4 = true;
|
|
338
|
-
var _didIteratorError4 = false;
|
|
339
|
-
var _iteratorError4 = undefined;
|
|
340
|
-
|
|
341
|
-
try {
|
|
342
|
-
for (var _iterator4 = validKeys[Symbol.iterator](), _step4; !(_iteratorNormalCompletion4 = (_step4 = _iterator4.next()).done); _iteratorNormalCompletion4 = true) {
|
|
343
|
-
var _key2 = _step4.value;
|
|
344
|
-
|
|
345
|
-
if (_key2.startsWith(_record_query_result.default.WatchableCellValuesInFieldKeyPrefix)) {
|
|
346
|
-
var fieldId = _key2.substring(_record_query_result.default.WatchableCellValuesInFieldKeyPrefix.length);
|
|
347
447
|
|
|
348
|
-
|
|
349
|
-
|
|
350
|
-
|
|
448
|
+
var callWatchOnRecordStoreWithKeys = keysToWatch => {
|
|
449
|
+
this._recordStore.watchWithRecordQueryResult({
|
|
450
|
+
recordQueryResult: this,
|
|
451
|
+
keys: keysToWatch,
|
|
452
|
+
callbackForRegistration: callback,
|
|
453
|
+
context
|
|
454
|
+
});
|
|
455
|
+
};
|
|
351
456
|
|
|
352
|
-
|
|
353
|
-
|
|
457
|
+
var _iteratorNormalCompletion5 = true;
|
|
458
|
+
var _didIteratorError5 = false;
|
|
459
|
+
var _iteratorError5 = undefined;
|
|
354
460
|
|
|
355
|
-
|
|
356
|
-
|
|
357
|
-
|
|
358
|
-
|
|
461
|
+
try {
|
|
462
|
+
for (var _iterator5 = validKeys[Symbol.iterator](), _step5; !(_iteratorNormalCompletion5 = (_step5 = _iterator5.next()).done); _iteratorNormalCompletion5 = true) {
|
|
463
|
+
var _key2 = _step5.value;
|
|
464
|
+
|
|
465
|
+
// There are two watch systems:
|
|
466
|
+
// 1) the query-based watch
|
|
467
|
+
// 2) the non-query-based watch (through super)
|
|
468
|
+
// Depending on the key, we may use one or both of the systems.
|
|
469
|
+
// The non-query based watch system is used when when:
|
|
470
|
+
// - watching: records, recordIds
|
|
471
|
+
// - _loadDataAsync calls all watch keys on initial load
|
|
472
|
+
// - Support for _watchRecordColorsIfNeeded
|
|
473
|
+
// For all changes to the remaining keys - the query-based system is used.
|
|
474
|
+
if (_key2.startsWith(_record_query_result.default.WatchableCellValuesInFieldKeyPrefix)) {
|
|
475
|
+
this._watchConfigByWatchableKey[_record_query_result.default.WatchableCellValuesInFieldKeyPrefix](_key2, callWatchOnRecordStoreWithKeys);
|
|
476
|
+
} else {
|
|
477
|
+
var _functionToCallWithKey = this._watchConfigByWatchableKey[_key2];
|
|
359
478
|
|
|
360
|
-
|
|
361
|
-
|
|
362
|
-
} else {
|
|
363
|
-
this._incrementCellValueKeyWatchCountAndWatchIfNecessary(_key2, this._onCellValuesChanged);
|
|
479
|
+
if (_functionToCallWithKey) {
|
|
480
|
+
_functionToCallWithKey(_key2, callWatchOnRecordStoreWithKeys);
|
|
364
481
|
}
|
|
365
482
|
}
|
|
366
483
|
}
|
|
367
484
|
} catch (err) {
|
|
368
|
-
|
|
369
|
-
|
|
485
|
+
_didIteratorError5 = true;
|
|
486
|
+
_iteratorError5 = err;
|
|
370
487
|
} finally {
|
|
371
488
|
try {
|
|
372
|
-
if (!
|
|
373
|
-
|
|
489
|
+
if (!_iteratorNormalCompletion5 && _iterator5.return != null) {
|
|
490
|
+
_iterator5.return();
|
|
374
491
|
}
|
|
375
492
|
} finally {
|
|
376
|
-
if (
|
|
377
|
-
throw
|
|
493
|
+
if (_didIteratorError5) {
|
|
494
|
+
throw _iteratorError5;
|
|
378
495
|
}
|
|
379
496
|
}
|
|
380
497
|
}
|
|
@@ -387,41 +504,41 @@ function (_RecordQueryResult) {
|
|
|
387
504
|
key: "unwatch",
|
|
388
505
|
value: function unwatch(keys, callback, context) {
|
|
389
506
|
var validKeys = (0, _get2.default)((0, _getPrototypeOf2.default)(TableOrViewQueryResult.prototype), "unwatch", this).call(this, keys, callback, context);
|
|
390
|
-
|
|
391
|
-
var
|
|
392
|
-
|
|
507
|
+
|
|
508
|
+
var callUnwatchOnRecordStoreWithKeys = keysToUnwatch => {
|
|
509
|
+
this._recordStore.unwatch(keysToUnwatch, callback, context);
|
|
510
|
+
};
|
|
511
|
+
|
|
512
|
+
var _iteratorNormalCompletion6 = true;
|
|
513
|
+
var _didIteratorError6 = false;
|
|
514
|
+
var _iteratorError6 = undefined;
|
|
393
515
|
|
|
394
516
|
try {
|
|
395
|
-
for (var
|
|
396
|
-
var _key3 =
|
|
517
|
+
for (var _iterator6 = validKeys[Symbol.iterator](), _step6; !(_iteratorNormalCompletion6 = (_step6 = _iterator6.next()).done); _iteratorNormalCompletion6 = true) {
|
|
518
|
+
var _key3 = _step6.value;
|
|
397
519
|
|
|
520
|
+
// This is the inverse of the watch logic
|
|
398
521
|
if (_key3.startsWith(_record_query_result.default.WatchableCellValuesInFieldKeyPrefix)) {
|
|
399
|
-
this.
|
|
400
|
-
}
|
|
522
|
+
this._watchConfigByWatchableKey[_record_query_result.default.WatchableCellValuesInFieldKeyPrefix](_key3, callUnwatchOnRecordStoreWithKeys);
|
|
523
|
+
} else {
|
|
524
|
+
var _functionToCallWithKey2 = this._watchConfigByWatchableKey[_key3];
|
|
401
525
|
|
|
402
|
-
|
|
403
|
-
|
|
404
|
-
for (var _i2 = 0, _Object$keys2 = Object.keys(this._fieldIdsSetToLoadOrNullIfAllFields); _i2 < _Object$keys2.length; _i2++) {
|
|
405
|
-
var fieldId = _Object$keys2[_i2];
|
|
406
|
-
|
|
407
|
-
this._decrementCellValueKeyWatchCountAndUnwatchIfPossible(_record_query_result.default.WatchableCellValuesInFieldKeyPrefix + fieldId, this._onCellValuesChanged);
|
|
408
|
-
}
|
|
409
|
-
} else {
|
|
410
|
-
this._decrementCellValueKeyWatchCountAndUnwatchIfPossible(_key3, this._onCellValuesChanged);
|
|
526
|
+
if (_functionToCallWithKey2) {
|
|
527
|
+
_functionToCallWithKey2(_key3, callUnwatchOnRecordStoreWithKeys);
|
|
411
528
|
}
|
|
412
529
|
}
|
|
413
530
|
}
|
|
414
531
|
} catch (err) {
|
|
415
|
-
|
|
416
|
-
|
|
532
|
+
_didIteratorError6 = true;
|
|
533
|
+
_iteratorError6 = err;
|
|
417
534
|
} finally {
|
|
418
535
|
try {
|
|
419
|
-
if (!
|
|
420
|
-
|
|
536
|
+
if (!_iteratorNormalCompletion6 && _iterator6.return != null) {
|
|
537
|
+
_iterator6.return();
|
|
421
538
|
}
|
|
422
539
|
} finally {
|
|
423
|
-
if (
|
|
424
|
-
throw
|
|
540
|
+
if (_didIteratorError6) {
|
|
541
|
+
throw _iteratorError6;
|
|
425
542
|
}
|
|
426
543
|
}
|
|
427
544
|
}
|
|
@@ -433,45 +550,54 @@ function (_RecordQueryResult) {
|
|
|
433
550
|
}, {
|
|
434
551
|
key: "loadDataAsync",
|
|
435
552
|
value: function loadDataAsync() {
|
|
436
|
-
var sourceModelLoadPromise,
|
|
437
|
-
return _regenerator.default.async(function loadDataAsync$(
|
|
553
|
+
var sourceModelLoadPromise, fieldIdsToLoadOrNullIfAllFields, allFieldsToQuery, metadataFieldId, sourceModelLoadedPromise;
|
|
554
|
+
return _regenerator.default.async(function loadDataAsync$(_context2) {
|
|
438
555
|
while (1) {
|
|
439
|
-
switch (
|
|
556
|
+
switch (_context2.prev = _context2.next) {
|
|
440
557
|
case 0:
|
|
441
558
|
if (!this._sourceModel.isDeleted) {
|
|
442
|
-
|
|
559
|
+
_context2.next = 2;
|
|
443
560
|
break;
|
|
444
561
|
}
|
|
445
562
|
|
|
446
563
|
throw this._spawnErrorForDeletion();
|
|
447
564
|
|
|
448
565
|
case 2:
|
|
449
|
-
|
|
450
|
-
cellValuesInFieldsLoadPromise = this._recordStore.loadCellValuesInFieldIdsAsync(Object.keys(this._fieldIdsSetToLoadOrNullIfAllFields));
|
|
451
|
-
} else {
|
|
452
|
-
// Load all fields.
|
|
453
|
-
cellValuesInFieldsLoadPromise = this._recordStore.loadDataAsync();
|
|
454
|
-
}
|
|
566
|
+
fieldIdsToLoadOrNullIfAllFields = this._fieldIdsSetToLoadOrNullIfAllFields ? Object.keys(this._fieldIdsSetToLoadOrNullIfAllFields) : null;
|
|
455
567
|
|
|
456
568
|
if (this._sourceModel instanceof _table.default) {
|
|
457
|
-
if (
|
|
458
|
-
|
|
569
|
+
if (fieldIdsToLoadOrNullIfAllFields) {
|
|
570
|
+
// TODO: (#proj-blocks-sdk-record-limits) Do we need to load the recordData metadata field
|
|
571
|
+
// in order to load any record data? If we do - this should be encapsulated entirely
|
|
572
|
+
// inside of the RecordStore in publicAirtableInterface.
|
|
573
|
+
// (should the queryModel be able to specify metadata requirements?)
|
|
574
|
+
allFieldsToQuery = fieldIdsToLoadOrNullIfAllFields;
|
|
575
|
+
metadataFieldId = this._recordStore._getFieldIdForCausingRecordMetadataToLoad();
|
|
576
|
+
|
|
577
|
+
if (!allFieldsToQuery.includes(metadataFieldId)) {
|
|
578
|
+
allFieldsToQuery = [...allFieldsToQuery, metadataFieldId];
|
|
579
|
+
}
|
|
580
|
+
|
|
581
|
+
sourceModelLoadPromise = this._recordStore.loadAllCellValuesInFieldIdsAsync(allFieldsToQuery);
|
|
459
582
|
} else {
|
|
460
|
-
//
|
|
461
|
-
|
|
462
|
-
sourceModelLoadPromise = null;
|
|
583
|
+
// Load all fields.
|
|
584
|
+
sourceModelLoadPromise = this._recordStore.loadAllCellValuesAsync();
|
|
463
585
|
}
|
|
464
586
|
} else {
|
|
465
|
-
sourceModelLoadPromise = this._recordStore.
|
|
466
|
-
}
|
|
587
|
+
sourceModelLoadPromise = this._recordStore.loadViewDataStoreAndCellValuesForFieldIdsAsync(this._sourceModel.id, fieldIdsToLoadOrNullIfAllFields);
|
|
588
|
+
} // See comment on _loadedSourceModelQueryIds declaration for details
|
|
467
589
|
|
|
468
|
-
|
|
469
|
-
|
|
590
|
+
|
|
591
|
+
sourceModelLoadedPromise = sourceModelLoadPromise.then(sourceModelQueryId => {
|
|
592
|
+
this._loadedSourceModelQueryIds.push(sourceModelQueryId);
|
|
593
|
+
});
|
|
594
|
+
this._mostRecentSourceModelLoadedPromise = Promise.all([sourceModelLoadedPromise, this._loadRecordColorsAsync()]);
|
|
595
|
+
_context2.next = 8;
|
|
470
596
|
return _regenerator.default.awrap((0, _get2.default)((0, _getPrototypeOf2.default)(TableOrViewQueryResult.prototype), "loadDataAsync", this).call(this));
|
|
471
597
|
|
|
472
|
-
case
|
|
598
|
+
case 8:
|
|
473
599
|
case "end":
|
|
474
|
-
return
|
|
600
|
+
return _context2.stop();
|
|
475
601
|
}
|
|
476
602
|
}
|
|
477
603
|
}, null, this);
|
|
@@ -487,26 +613,26 @@ function (_RecordQueryResult) {
|
|
|
487
613
|
|
|
488
614
|
var fieldIds = this._normalizedOpts.fieldIdsOrNullIfAllFields || this._table.fields.map(field => field.id);
|
|
489
615
|
|
|
490
|
-
var
|
|
491
|
-
var
|
|
492
|
-
var
|
|
616
|
+
var _iteratorNormalCompletion7 = true;
|
|
617
|
+
var _didIteratorError7 = false;
|
|
618
|
+
var _iteratorError7 = undefined;
|
|
493
619
|
|
|
494
620
|
try {
|
|
495
|
-
for (var
|
|
496
|
-
var fieldId =
|
|
621
|
+
for (var _iterator7 = fieldIds[Symbol.iterator](), _step7; !(_iteratorNormalCompletion7 = (_step7 = _iterator7.next()).done); _iteratorNormalCompletion7 = true) {
|
|
622
|
+
var fieldId = _step7.value;
|
|
497
623
|
changedKeys.push(_record_query_result.default.WatchableCellValuesInFieldKeyPrefix + fieldId);
|
|
498
624
|
}
|
|
499
625
|
} catch (err) {
|
|
500
|
-
|
|
501
|
-
|
|
626
|
+
_didIteratorError7 = true;
|
|
627
|
+
_iteratorError7 = err;
|
|
502
628
|
} finally {
|
|
503
629
|
try {
|
|
504
|
-
if (!
|
|
505
|
-
|
|
630
|
+
if (!_iteratorNormalCompletion7 && _iterator7.return != null) {
|
|
631
|
+
_iterator7.return();
|
|
506
632
|
}
|
|
507
633
|
} finally {
|
|
508
|
-
if (
|
|
509
|
-
throw
|
|
634
|
+
if (_didIteratorError7) {
|
|
635
|
+
throw _iteratorError7;
|
|
510
636
|
}
|
|
511
637
|
}
|
|
512
638
|
}
|
|
@@ -518,55 +644,72 @@ function (_RecordQueryResult) {
|
|
|
518
644
|
}, {
|
|
519
645
|
key: "_loadDataAsync",
|
|
520
646
|
value: function _loadDataAsync() {
|
|
521
|
-
var viewDataStore,
|
|
647
|
+
var viewDataStore, _iteratorNormalCompletion8, _didIteratorError8, _iteratorError8, _iterator8, _step8, sort, field;
|
|
522
648
|
|
|
523
|
-
return _regenerator.default.async(function _loadDataAsync$(
|
|
649
|
+
return _regenerator.default.async(function _loadDataAsync$(_context3) {
|
|
524
650
|
while (1) {
|
|
525
|
-
switch (
|
|
651
|
+
switch (_context3.prev = _context3.next) {
|
|
526
652
|
case 0:
|
|
527
653
|
this._table.__tableOrViewQueryResultPool.registerObjectForReuseStrong(this);
|
|
528
654
|
|
|
529
|
-
(0, _error_utils.invariant)(this.
|
|
530
|
-
|
|
531
|
-
return _regenerator.default.awrap(this.
|
|
655
|
+
(0, _error_utils.invariant)(this._mostRecentSourceModelLoadedPromise, 'No source model load promises');
|
|
656
|
+
_context3.next = 4;
|
|
657
|
+
return _regenerator.default.awrap(this._mostRecentSourceModelLoadedPromise);
|
|
532
658
|
|
|
533
659
|
case 4:
|
|
534
660
|
if (this._sorts) {
|
|
535
661
|
this._replaceVisList();
|
|
536
662
|
}
|
|
537
663
|
|
|
538
|
-
this._orderedRecordIds = this._generateOrderedRecordIds();
|
|
539
|
-
this._orderedGroups = this._generateAndLoadOrderedGroups(); // The server provided value and developer supplied value are the same, no conversion needed
|
|
664
|
+
this._orderedRecordIds = this._generateOrderedRecordIds(); // Ensure that groups are not loaded
|
|
540
665
|
|
|
541
|
-
this.
|
|
666
|
+
this._orderedGroups = null; // The server provided value and developer supplied value are the same, no conversion needed
|
|
667
|
+
|
|
668
|
+
this._loadedGroupLevels = null;
|
|
542
669
|
|
|
543
670
|
if (this._sourceModel instanceof _table.default) {
|
|
544
|
-
this._recordStore.
|
|
671
|
+
this._recordStore.watchWithRecordQueryResult({
|
|
672
|
+
recordQueryResult: this,
|
|
673
|
+
keys: _record_store.WatchableRecordStoreKeys.records,
|
|
674
|
+
callbackForRegistration: this._onRecordsChanged,
|
|
675
|
+
context: this
|
|
676
|
+
});
|
|
545
677
|
} else {
|
|
546
678
|
viewDataStore = this._recordStore.getViewDataStore(this._sourceModel.id);
|
|
547
679
|
viewDataStore.watch(_view_data_store.WatchableViewDataStoreKeys.visibleRecords, this._onRecordsChanged, this);
|
|
548
680
|
viewDataStore.watch(_view_data_store.WatchableViewDataStoreKeys.groups, this._onGroupsChanged, this);
|
|
549
681
|
viewDataStore.watch(_view_data_store.WatchableViewDataStoreKeys.groupLevels, this._onGroupLevelsChanged, this);
|
|
550
|
-
}
|
|
682
|
+
} // This only watches cell values if a sort is specified
|
|
551
683
|
|
|
552
|
-
this._recordStore.watch(this._cellValuesForSortWatchKeys, this._onCellValuesForSortChanged, this);
|
|
553
684
|
|
|
554
|
-
this._recordStore.
|
|
685
|
+
this._recordStore.watchWithRecordQueryResult({
|
|
686
|
+
recordQueryResult: this,
|
|
687
|
+
keys: this._cellValuesForSortWatchKeys,
|
|
688
|
+
callbackForRegistration: this._onCellValuesForSortChanged,
|
|
689
|
+
context: this
|
|
690
|
+
});
|
|
691
|
+
|
|
692
|
+
this._recordStore.watchWithRecordQueryResult({
|
|
693
|
+
recordQueryResult: this,
|
|
694
|
+
keys: this._cellValuesForGroupWatchKeys,
|
|
695
|
+
callbackForRegistration: this._onCellValuesForGroupChanged,
|
|
696
|
+
context: this
|
|
697
|
+
});
|
|
555
698
|
|
|
556
699
|
this._table.watch(_table.WatchableTableKeys.fields, this._onTableFieldsChanged, this);
|
|
557
700
|
|
|
558
701
|
if (!this._sorts) {
|
|
559
|
-
|
|
702
|
+
_context3.next = 32;
|
|
560
703
|
break;
|
|
561
704
|
}
|
|
562
705
|
|
|
563
|
-
|
|
564
|
-
|
|
565
|
-
|
|
566
|
-
|
|
706
|
+
_iteratorNormalCompletion8 = true;
|
|
707
|
+
_didIteratorError8 = false;
|
|
708
|
+
_iteratorError8 = undefined;
|
|
709
|
+
_context3.prev = 16;
|
|
567
710
|
|
|
568
|
-
for (
|
|
569
|
-
sort =
|
|
711
|
+
for (_iterator8 = this._sorts[Symbol.iterator](); !(_iteratorNormalCompletion8 = (_step8 = _iterator8.next()).done); _iteratorNormalCompletion8 = true) {
|
|
712
|
+
sort = _step8.value;
|
|
570
713
|
field = this._table.getFieldByIdIfExists(sort.fieldId);
|
|
571
714
|
|
|
572
715
|
if (field) {
|
|
@@ -575,45 +718,45 @@ function (_RecordQueryResult) {
|
|
|
575
718
|
}
|
|
576
719
|
}
|
|
577
720
|
|
|
578
|
-
|
|
721
|
+
_context3.next = 24;
|
|
579
722
|
break;
|
|
580
723
|
|
|
581
724
|
case 20:
|
|
582
|
-
|
|
583
|
-
|
|
584
|
-
|
|
585
|
-
|
|
725
|
+
_context3.prev = 20;
|
|
726
|
+
_context3.t0 = _context3["catch"](16);
|
|
727
|
+
_didIteratorError8 = true;
|
|
728
|
+
_iteratorError8 = _context3.t0;
|
|
586
729
|
|
|
587
730
|
case 24:
|
|
588
|
-
|
|
589
|
-
|
|
731
|
+
_context3.prev = 24;
|
|
732
|
+
_context3.prev = 25;
|
|
590
733
|
|
|
591
|
-
if (!
|
|
592
|
-
|
|
734
|
+
if (!_iteratorNormalCompletion8 && _iterator8.return != null) {
|
|
735
|
+
_iterator8.return();
|
|
593
736
|
}
|
|
594
737
|
|
|
595
738
|
case 27:
|
|
596
|
-
|
|
739
|
+
_context3.prev = 27;
|
|
597
740
|
|
|
598
|
-
if (!
|
|
599
|
-
|
|
741
|
+
if (!_didIteratorError8) {
|
|
742
|
+
_context3.next = 30;
|
|
600
743
|
break;
|
|
601
744
|
}
|
|
602
745
|
|
|
603
|
-
throw
|
|
746
|
+
throw _iteratorError8;
|
|
604
747
|
|
|
605
748
|
case 30:
|
|
606
|
-
return
|
|
749
|
+
return _context3.finish(27);
|
|
607
750
|
|
|
608
751
|
case 31:
|
|
609
|
-
return
|
|
752
|
+
return _context3.finish(24);
|
|
610
753
|
|
|
611
754
|
case 32:
|
|
612
|
-
return
|
|
755
|
+
return _context3.abrupt("return", this._getChangedKeysOnLoad());
|
|
613
756
|
|
|
614
757
|
case 33:
|
|
615
758
|
case "end":
|
|
616
|
-
return
|
|
759
|
+
return _context3.stop();
|
|
617
760
|
}
|
|
618
761
|
}
|
|
619
762
|
}, null, this, [[16, 20, 24, 32], [25,, 27, 31]]);
|
|
@@ -625,21 +768,9 @@ function (_RecordQueryResult) {
|
|
|
625
768
|
value: function unloadData() {
|
|
626
769
|
(0, _get2.default)((0, _getPrototypeOf2.default)(TableOrViewQueryResult.prototype), "unloadData", this).call(this);
|
|
627
770
|
|
|
628
|
-
if (this.
|
|
629
|
-
|
|
630
|
-
|
|
631
|
-
} else {
|
|
632
|
-
this._recordStore.unloadData();
|
|
633
|
-
}
|
|
634
|
-
} else {
|
|
635
|
-
// If the view is deleted, we can't get a data store for it.
|
|
636
|
-
if (!this._sourceModel.isDeleted) {
|
|
637
|
-
this._recordStore.getViewDataStore(this._sourceModel.id).unloadData();
|
|
638
|
-
}
|
|
639
|
-
}
|
|
640
|
-
|
|
641
|
-
if (this._fieldIdsSetToLoadOrNullIfAllFields) {
|
|
642
|
-
this._recordStore.unloadCellValuesInFieldIds(Object.keys(this._fieldIdsSetToLoadOrNullIfAllFields));
|
|
771
|
+
if (this._loadedSourceModelQueryIds.length === 0) {
|
|
772
|
+
// Source model must have loaded a queryId to unload
|
|
773
|
+
return;
|
|
643
774
|
}
|
|
644
775
|
|
|
645
776
|
this._unloadRecordColors();
|
|
@@ -649,119 +780,34 @@ function (_RecordQueryResult) {
|
|
|
649
780
|
}, {
|
|
650
781
|
key: "_unloadData",
|
|
651
782
|
value: function _unloadData() {
|
|
652
|
-
this.
|
|
653
|
-
|
|
654
|
-
if (this._sourceModel instanceof _table.default) {
|
|
655
|
-
this._recordStore.unwatch(_record_store.WatchableRecordStoreKeys.records, this._onRecordsChanged, this);
|
|
656
|
-
} else {
|
|
657
|
-
if (!this._sourceModel.isDeleted) {
|
|
658
|
-
var viewDataStore = this._recordStore.getViewDataStore(this._sourceModel.id);
|
|
659
|
-
|
|
660
|
-
viewDataStore.unwatch(_view_data_store.WatchableViewDataStoreKeys.visibleRecords, this._onRecordsChanged, this);
|
|
661
|
-
viewDataStore.unwatch(_view_data_store.WatchableViewDataStoreKeys.groups, this._onGroupsChanged, this);
|
|
662
|
-
viewDataStore.unwatch(_view_data_store.WatchableViewDataStoreKeys.groupLevels, this._onGroupLevelsChanged, this);
|
|
663
|
-
}
|
|
664
|
-
}
|
|
665
|
-
|
|
666
|
-
this._recordStore.unwatch(this._cellValuesForSortWatchKeys, this._onCellValuesForSortChanged, this);
|
|
667
|
-
|
|
668
|
-
this._recordStore.unwatch(this._cellValuesForGroupWatchKeys, this._onCellValuesForGroupChanged, this);
|
|
669
|
-
|
|
670
|
-
this._table.unwatch(_table.WatchableTableKeys.fields, this._onTableFieldsChanged, this); // If the table is deleted, can't call getFieldById on it below.
|
|
671
|
-
|
|
672
|
-
|
|
673
|
-
if (!this._table.isDeleted && this._sorts) {
|
|
674
|
-
var _iteratorNormalCompletion8 = true;
|
|
675
|
-
var _didIteratorError8 = false;
|
|
676
|
-
var _iteratorError8 = undefined;
|
|
677
|
-
|
|
678
|
-
try {
|
|
679
|
-
for (var _iterator8 = this._sorts[Symbol.iterator](), _step8; !(_iteratorNormalCompletion8 = (_step8 = _iterator8.next()).done); _iteratorNormalCompletion8 = true) {
|
|
680
|
-
var sort = _step8.value;
|
|
681
|
-
|
|
682
|
-
var field = this._table.getFieldByIdIfExists(sort.fieldId);
|
|
683
|
-
|
|
684
|
-
if (field) {
|
|
685
|
-
field.unwatch('type', this._onFieldConfigChanged, this);
|
|
686
|
-
field.unwatch('options', this._onFieldConfigChanged, this);
|
|
687
|
-
}
|
|
688
|
-
}
|
|
689
|
-
} catch (err) {
|
|
690
|
-
_didIteratorError8 = true;
|
|
691
|
-
_iteratorError8 = err;
|
|
692
|
-
} finally {
|
|
693
|
-
try {
|
|
694
|
-
if (!_iteratorNormalCompletion8 && _iterator8.return != null) {
|
|
695
|
-
_iterator8.return();
|
|
696
|
-
}
|
|
697
|
-
} finally {
|
|
698
|
-
if (_didIteratorError8) {
|
|
699
|
-
throw _iteratorError8;
|
|
700
|
-
}
|
|
701
|
-
}
|
|
702
|
-
}
|
|
703
|
-
}
|
|
704
|
-
|
|
705
|
-
this._unloadOrderedGroupsIfNeeded();
|
|
706
|
-
|
|
707
|
-
this._visList = null;
|
|
708
|
-
this._orderedRecordIds = null;
|
|
709
|
-
this._recordIdsSet = null;
|
|
710
|
-
|
|
711
|
-
this._table.__tableOrViewQueryResultPool.unregisterObjectForReuseStrong(this);
|
|
783
|
+
(0, _private_utils.fireAndForgetPromise)(this._unloadDataAsync);
|
|
712
784
|
}
|
|
713
|
-
/** @internal */
|
|
714
|
-
|
|
715
785
|
}, {
|
|
716
786
|
key: "_addRecordIdsToVisList",
|
|
787
|
+
|
|
788
|
+
/** @internal */
|
|
717
789
|
value: function _addRecordIdsToVisList(recordIds) {
|
|
718
790
|
var visList = this._visList;
|
|
719
791
|
(0, _error_utils.invariant)(visList, 'No vis list');
|
|
720
|
-
|
|
721
|
-
var _didIteratorError9 = false;
|
|
722
|
-
var _iteratorError9 = undefined;
|
|
723
|
-
|
|
724
|
-
try {
|
|
725
|
-
for (var _iterator9 = recordIds[Symbol.iterator](), _step9; !(_iteratorNormalCompletion9 = (_step9 = _iterator9.next()).done); _iteratorNormalCompletion9 = true) {
|
|
726
|
-
var recordId = _step9.value;
|
|
727
|
-
|
|
728
|
-
var record = this._recordStore.getRecordByIdIfExists(recordId);
|
|
729
|
-
|
|
730
|
-
(0, _error_utils.invariant)(record, 'Record missing in table');
|
|
731
|
-
visList.addRecordData(record._data);
|
|
732
|
-
}
|
|
733
|
-
} catch (err) {
|
|
734
|
-
_didIteratorError9 = true;
|
|
735
|
-
_iteratorError9 = err;
|
|
736
|
-
} finally {
|
|
737
|
-
try {
|
|
738
|
-
if (!_iteratorNormalCompletion9 && _iterator9.return != null) {
|
|
739
|
-
_iterator9.return();
|
|
740
|
-
}
|
|
741
|
-
} finally {
|
|
742
|
-
if (_didIteratorError9) {
|
|
743
|
-
throw _iteratorError9;
|
|
744
|
-
}
|
|
745
|
-
}
|
|
746
|
-
}
|
|
792
|
+
visList.addRecordIds(recordIds);
|
|
747
793
|
}
|
|
748
794
|
/** @internal */
|
|
749
795
|
|
|
750
796
|
}, {
|
|
751
797
|
key: "_onGroupLevelsChanged",
|
|
752
798
|
value: function _onGroupLevelsChanged(model, key, updates) {
|
|
753
|
-
this._loadedGroupLevels =
|
|
799
|
+
this._loadedGroupLevels = null;
|
|
754
800
|
|
|
755
|
-
this.
|
|
801
|
+
this._unloadGroupsAndTriggerWatches();
|
|
756
802
|
|
|
757
|
-
this._onChange(_record_query_result.
|
|
803
|
+
this._onChange(_record_query_result.WatchableRecordQueryResultKeys.groupLevels);
|
|
758
804
|
}
|
|
759
805
|
/** @internal */
|
|
760
806
|
|
|
761
807
|
}, {
|
|
762
808
|
key: "_onGroupsChanged",
|
|
763
809
|
value: function _onGroupsChanged(model, key, updates) {
|
|
764
|
-
this.
|
|
810
|
+
this._unloadGroupsAndTriggerWatches();
|
|
765
811
|
}
|
|
766
812
|
/** @internal */
|
|
767
813
|
|
|
@@ -784,7 +830,11 @@ function (_RecordQueryResult) {
|
|
|
784
830
|
addedRecordIds: _addedRecordIds,
|
|
785
831
|
removedRecordIds: _removedRecordIds
|
|
786
832
|
};
|
|
787
|
-
}
|
|
833
|
+
} // We never need to handle an initial empty update coming from record_store
|
|
834
|
+
// since it does not issue empty initial updates.
|
|
835
|
+
// Keep the if statement for type safety. Invariant would also work, but is riskier.
|
|
836
|
+
// istanbul ignore if
|
|
837
|
+
|
|
788
838
|
|
|
789
839
|
if (!updates) {
|
|
790
840
|
// If there are no updates, do nothing, since we'll handle the initial
|
|
@@ -811,50 +861,50 @@ function (_RecordQueryResult) {
|
|
|
811
861
|
}
|
|
812
862
|
|
|
813
863
|
if (this._recordIdsSet) {
|
|
814
|
-
var
|
|
815
|
-
var
|
|
816
|
-
var
|
|
864
|
+
var _iteratorNormalCompletion9 = true;
|
|
865
|
+
var _didIteratorError9 = false;
|
|
866
|
+
var _iteratorError9 = undefined;
|
|
817
867
|
|
|
818
868
|
try {
|
|
819
|
-
for (var
|
|
820
|
-
var recordId =
|
|
869
|
+
for (var _iterator9 = addedRecordIds[Symbol.iterator](), _step9; !(_iteratorNormalCompletion9 = (_step9 = _iterator9.next()).done); _iteratorNormalCompletion9 = true) {
|
|
870
|
+
var recordId = _step9.value;
|
|
821
871
|
this._recordIdsSet[recordId] = true;
|
|
822
872
|
}
|
|
823
873
|
} catch (err) {
|
|
824
|
-
|
|
825
|
-
|
|
874
|
+
_didIteratorError9 = true;
|
|
875
|
+
_iteratorError9 = err;
|
|
826
876
|
} finally {
|
|
827
877
|
try {
|
|
828
|
-
if (!
|
|
829
|
-
|
|
878
|
+
if (!_iteratorNormalCompletion9 && _iterator9.return != null) {
|
|
879
|
+
_iterator9.return();
|
|
830
880
|
}
|
|
831
881
|
} finally {
|
|
832
|
-
if (
|
|
833
|
-
throw
|
|
882
|
+
if (_didIteratorError9) {
|
|
883
|
+
throw _iteratorError9;
|
|
834
884
|
}
|
|
835
885
|
}
|
|
836
886
|
}
|
|
837
887
|
|
|
838
|
-
var
|
|
839
|
-
var
|
|
840
|
-
var
|
|
888
|
+
var _iteratorNormalCompletion10 = true;
|
|
889
|
+
var _didIteratorError10 = false;
|
|
890
|
+
var _iteratorError10 = undefined;
|
|
841
891
|
|
|
842
892
|
try {
|
|
843
|
-
for (var
|
|
844
|
-
var _recordId =
|
|
893
|
+
for (var _iterator10 = removedRecordIds[Symbol.iterator](), _step10; !(_iteratorNormalCompletion10 = (_step10 = _iterator10.next()).done); _iteratorNormalCompletion10 = true) {
|
|
894
|
+
var _recordId = _step10.value;
|
|
845
895
|
this._recordIdsSet[_recordId] = undefined;
|
|
846
896
|
}
|
|
847
897
|
} catch (err) {
|
|
848
|
-
|
|
849
|
-
|
|
898
|
+
_didIteratorError10 = true;
|
|
899
|
+
_iteratorError10 = err;
|
|
850
900
|
} finally {
|
|
851
901
|
try {
|
|
852
|
-
if (!
|
|
853
|
-
|
|
902
|
+
if (!_iteratorNormalCompletion10 && _iterator10.return != null) {
|
|
903
|
+
_iterator10.return();
|
|
854
904
|
}
|
|
855
905
|
} finally {
|
|
856
|
-
if (
|
|
857
|
-
throw
|
|
906
|
+
if (_didIteratorError10) {
|
|
907
|
+
throw _iteratorError10;
|
|
858
908
|
}
|
|
859
909
|
}
|
|
860
910
|
}
|
|
@@ -883,6 +933,10 @@ function (_RecordQueryResult) {
|
|
|
883
933
|
}, {
|
|
884
934
|
key: "_onCellValuesForSortChanged",
|
|
885
935
|
value: function _onCellValuesForSortChanged(recordStore, key, recordIds, fieldId) {
|
|
936
|
+
// We never need to handle an initial empty update coming from record_store
|
|
937
|
+
// since it does not issue empty initial updates.
|
|
938
|
+
// Keep the if statement for type safety. Invariant would also work, but is riskier.
|
|
939
|
+
// istanbul ignore if
|
|
886
940
|
if (!recordIds || !fieldId) {
|
|
887
941
|
// If there are no updates, do nothing, since we'll handle the initial
|
|
888
942
|
// callback when the record set is loaded (and we don't want to fire
|
|
@@ -948,13 +1002,13 @@ function (_RecordQueryResult) {
|
|
|
948
1002
|
// deleted and then undeleted.
|
|
949
1003
|
|
|
950
1004
|
var wereAnyFieldsCreatedOrDeleted = false;
|
|
951
|
-
var
|
|
952
|
-
var
|
|
953
|
-
var
|
|
1005
|
+
var _iteratorNormalCompletion11 = true;
|
|
1006
|
+
var _didIteratorError11 = false;
|
|
1007
|
+
var _iteratorError11 = undefined;
|
|
954
1008
|
|
|
955
1009
|
try {
|
|
956
|
-
for (var
|
|
957
|
-
var fieldId =
|
|
1010
|
+
for (var _iterator11 = addedFieldIds[Symbol.iterator](), _step11; !(_iteratorNormalCompletion11 = (_step11 = _iterator11.next()).done); _iteratorNormalCompletion11 = true) {
|
|
1011
|
+
var fieldId = _step11.value;
|
|
958
1012
|
|
|
959
1013
|
// If a field that we rely on was created (i.e. it was undeleted), we need to
|
|
960
1014
|
// make sure we're watching it's config.
|
|
@@ -971,16 +1025,16 @@ function (_RecordQueryResult) {
|
|
|
971
1025
|
// istanbul ignore else
|
|
972
1026
|
|
|
973
1027
|
} catch (err) {
|
|
974
|
-
|
|
975
|
-
|
|
1028
|
+
_didIteratorError11 = true;
|
|
1029
|
+
_iteratorError11 = err;
|
|
976
1030
|
} finally {
|
|
977
1031
|
try {
|
|
978
|
-
if (!
|
|
979
|
-
|
|
1032
|
+
if (!_iteratorNormalCompletion11 && _iterator11.return != null) {
|
|
1033
|
+
_iterator11.return();
|
|
980
1034
|
}
|
|
981
1035
|
} finally {
|
|
982
|
-
if (
|
|
983
|
-
throw
|
|
1036
|
+
if (_didIteratorError11) {
|
|
1037
|
+
throw _iteratorError11;
|
|
984
1038
|
}
|
|
985
1039
|
}
|
|
986
1040
|
}
|
|
@@ -1010,34 +1064,6 @@ function (_RecordQueryResult) {
|
|
|
1010
1064
|
}
|
|
1011
1065
|
/** @internal */
|
|
1012
1066
|
|
|
1013
|
-
}, {
|
|
1014
|
-
key: "_onCellValuesChanged",
|
|
1015
|
-
value: function _onCellValuesChanged(table, key, updates) {
|
|
1016
|
-
if (!updates) {
|
|
1017
|
-
// If there are no updates, do nothing, since we'll handle the initial
|
|
1018
|
-
// callback when the record set is loaded (and we don't want to fire
|
|
1019
|
-
// a cellValues change twice with no data).
|
|
1020
|
-
return;
|
|
1021
|
-
}
|
|
1022
|
-
|
|
1023
|
-
this._onChange(_record_query_result.default.WatchableKeys.cellValues, updates);
|
|
1024
|
-
}
|
|
1025
|
-
/** @internal */
|
|
1026
|
-
|
|
1027
|
-
}, {
|
|
1028
|
-
key: "_onCellValuesInFieldChanged",
|
|
1029
|
-
value: function _onCellValuesInFieldChanged(table, key, recordIds, fieldId) {
|
|
1030
|
-
if (!recordIds && !fieldId) {
|
|
1031
|
-
// If there are no updates, do nothing, since we'll handle the initial
|
|
1032
|
-
// callback when the record set is loaded (and we don't want to fire
|
|
1033
|
-
// a cellValuesInField change twice with no data).
|
|
1034
|
-
return;
|
|
1035
|
-
}
|
|
1036
|
-
|
|
1037
|
-
this._onChange(key, recordIds, fieldId);
|
|
1038
|
-
}
|
|
1039
|
-
/** @internal */
|
|
1040
|
-
|
|
1041
1067
|
}, {
|
|
1042
1068
|
key: "_generateOrderedRecordIds",
|
|
1043
1069
|
value: function _generateOrderedRecordIds() {
|
|
@@ -1055,7 +1081,6 @@ function (_RecordQueryResult) {
|
|
|
1055
1081
|
value: function _generateAndLoadOrderedGroups() {
|
|
1056
1082
|
// istanbul ignore next
|
|
1057
1083
|
if (this._groupLevels) {
|
|
1058
|
-
(0, _error_utils.invariant)(this._visList, 'Cannot generate record ids without a vis list');
|
|
1059
1084
|
throw (0, _error_utils.spawnError)('custom group configs not supported');
|
|
1060
1085
|
} else {
|
|
1061
1086
|
// Get the group from the view itself
|
|
@@ -1081,26 +1106,26 @@ function (_RecordQueryResult) {
|
|
|
1081
1106
|
key: "_unloadOrderedGroupsIfNeeded",
|
|
1082
1107
|
value: function _unloadOrderedGroupsIfNeeded() {
|
|
1083
1108
|
if (this._orderedGroups) {
|
|
1084
|
-
var
|
|
1085
|
-
var
|
|
1086
|
-
var
|
|
1109
|
+
var _iteratorNormalCompletion12 = true;
|
|
1110
|
+
var _didIteratorError12 = false;
|
|
1111
|
+
var _iteratorError12 = undefined;
|
|
1087
1112
|
|
|
1088
1113
|
try {
|
|
1089
|
-
for (var
|
|
1090
|
-
var group =
|
|
1114
|
+
for (var _iterator12 = this._orderedGroups[Symbol.iterator](), _step12; !(_iteratorNormalCompletion12 = (_step12 = _iterator12.next()).done); _iteratorNormalCompletion12 = true) {
|
|
1115
|
+
var group = _step12.value;
|
|
1091
1116
|
group.unloadData();
|
|
1092
1117
|
}
|
|
1093
1118
|
} catch (err) {
|
|
1094
|
-
|
|
1095
|
-
|
|
1119
|
+
_didIteratorError12 = true;
|
|
1120
|
+
_iteratorError12 = err;
|
|
1096
1121
|
} finally {
|
|
1097
1122
|
try {
|
|
1098
|
-
if (!
|
|
1099
|
-
|
|
1123
|
+
if (!_iteratorNormalCompletion12 && _iterator12.return != null) {
|
|
1124
|
+
_iterator12.return();
|
|
1100
1125
|
}
|
|
1101
1126
|
} finally {
|
|
1102
|
-
if (
|
|
1103
|
-
throw
|
|
1127
|
+
if (_didIteratorError12) {
|
|
1128
|
+
throw _iteratorError12;
|
|
1104
1129
|
}
|
|
1105
1130
|
}
|
|
1106
1131
|
}
|
|
@@ -1108,22 +1133,21 @@ function (_RecordQueryResult) {
|
|
|
1108
1133
|
}
|
|
1109
1134
|
/**
|
|
1110
1135
|
* If groupings change then some groups will need to be created, and some removed
|
|
1111
|
-
*
|
|
1112
|
-
*
|
|
1136
|
+
* Triggers the WatchableKeys.group, as by necessity this will have changed.
|
|
1137
|
+
* TODO: This _should_ handle the diffing necessary to unload, and reload only the changed groups.
|
|
1113
1138
|
*
|
|
1114
1139
|
* @internal
|
|
1115
1140
|
*/
|
|
1116
1141
|
// TODO: (SeanKeenan) Properly diff and only unload groups that need to be unloaded
|
|
1117
1142
|
// In the meantime it's not too expensive to just unload everything, and GroupedRecordQueryResults
|
|
1118
1143
|
// don't yet properly watch changes relevant to updating, so this isn't too bad.
|
|
1119
|
-
// (They do invalidate their recordId caches, which is some very cheap work that we could remove)
|
|
1120
1144
|
|
|
1121
1145
|
}, {
|
|
1122
|
-
key: "
|
|
1123
|
-
value: function
|
|
1146
|
+
key: "_unloadGroupsAndTriggerWatches",
|
|
1147
|
+
value: function _unloadGroupsAndTriggerWatches() {
|
|
1124
1148
|
this._unloadOrderedGroupsIfNeeded();
|
|
1125
1149
|
|
|
1126
|
-
this._orderedGroups =
|
|
1150
|
+
this._orderedGroups = null;
|
|
1127
1151
|
|
|
1128
1152
|
this._onChange(_record_query_result.default.WatchableKeys.groups);
|
|
1129
1153
|
}
|
|
@@ -1133,15 +1157,14 @@ function (_RecordQueryResult) {
|
|
|
1133
1157
|
key: "_replaceVisList",
|
|
1134
1158
|
value: function _replaceVisList() {
|
|
1135
1159
|
var airtableInterface = this._sdk.__airtableInterface;
|
|
1136
|
-
var appInterface = this._sdk.__appInterface;
|
|
1137
1160
|
|
|
1138
|
-
var
|
|
1161
|
+
var recordIds = this._sourceModelRecords.map(record => record.id);
|
|
1139
1162
|
|
|
1140
1163
|
var fieldDatas = this._table.fields.map(field => field._data);
|
|
1141
1164
|
|
|
1142
1165
|
var filteredSorts = this._getSortsWithDeletedFieldsFiltered();
|
|
1143
1166
|
|
|
1144
|
-
this._visList = airtableInterface.
|
|
1167
|
+
this._visList = airtableInterface.createVisListWithRecordIds(recordIds, fieldDatas, filteredSorts, this._table.id);
|
|
1145
1168
|
}
|
|
1146
1169
|
/** @internal */
|
|
1147
1170
|
|
|
@@ -1167,6 +1190,31 @@ function (_RecordQueryResult) {
|
|
|
1167
1190
|
var sourceModelName = this._sourceModel instanceof _table.default ? 'table' : 'view';
|
|
1168
1191
|
return (0, _error_utils.spawnError)("RecordQueryResult's underlying %s has been deleted", sourceModelName);
|
|
1169
1192
|
}
|
|
1193
|
+
/** @internal */
|
|
1194
|
+
|
|
1195
|
+
}, {
|
|
1196
|
+
key: "__constructQuerySpecForBlockFieldSelectionSpec",
|
|
1197
|
+
value: function __constructQuerySpecForBlockFieldSelectionSpec(fieldSelection) {
|
|
1198
|
+
if (this._sourceModel instanceof _view.default) {
|
|
1199
|
+
return {
|
|
1200
|
+
sourceType: _block_query_spec.BlockQuerySourceType.VIEW,
|
|
1201
|
+
sourceTableId: this._table.id,
|
|
1202
|
+
sourceViewId: this._sourceModel.id,
|
|
1203
|
+
recordSelection: {
|
|
1204
|
+
fieldSelection
|
|
1205
|
+
},
|
|
1206
|
+
viewMetadataSelection: {}
|
|
1207
|
+
};
|
|
1208
|
+
} else {
|
|
1209
|
+
return {
|
|
1210
|
+
sourceType: _block_query_spec.BlockQuerySourceType.TABLE,
|
|
1211
|
+
sourceTableId: this._table.id,
|
|
1212
|
+
recordSelection: {
|
|
1213
|
+
fieldSelection
|
|
1214
|
+
}
|
|
1215
|
+
};
|
|
1216
|
+
}
|
|
1217
|
+
}
|
|
1170
1218
|
}, {
|
|
1171
1219
|
key: "_dataOrNullIfDeleted",
|
|
1172
1220
|
get: function get() {
|
|
@@ -1175,9 +1223,7 @@ function (_RecordQueryResult) {
|
|
|
1175
1223
|
}
|
|
1176
1224
|
|
|
1177
1225
|
return {
|
|
1178
|
-
recordIds: this._orderedRecordIds
|
|
1179
|
-
groups: this._orderedGroups,
|
|
1180
|
-
groupLevels: this._loadedGroupLevels
|
|
1226
|
+
recordIds: this._orderedRecordIds
|
|
1181
1227
|
};
|
|
1182
1228
|
}
|
|
1183
1229
|
/** @internal */
|
|
@@ -1231,8 +1277,10 @@ function (_RecordQueryResult) {
|
|
|
1231
1277
|
var recordIds = this._data.recordIds; // Throws when the model has been deleted.
|
|
1232
1278
|
|
|
1233
1279
|
(0, _error_utils.invariant)(this.isDataLoaded, 'RecordQueryResult data is not loaded');
|
|
1234
|
-
(0, _error_utils.invariant)(recordIds, 'No recordIds');
|
|
1235
|
-
|
|
1280
|
+
(0, _error_utils.invariant)(recordIds, 'No recordIds'); // TODO: (#proj-blocks-sdk-record-limits) Change this to readonly upon the
|
|
1281
|
+
// next breaking change.
|
|
1282
|
+
|
|
1283
|
+
return [...recordIds];
|
|
1236
1284
|
}
|
|
1237
1285
|
/**
|
|
1238
1286
|
* The ordered GroupedRecordQueryResult's in this RecordQueryResult.
|
|
@@ -1245,12 +1293,19 @@ function (_RecordQueryResult) {
|
|
|
1245
1293
|
}, {
|
|
1246
1294
|
key: "groups",
|
|
1247
1295
|
get: function get() {
|
|
1296
|
+
var _this$_orderedGroups;
|
|
1297
|
+
|
|
1248
1298
|
// The following statements have been carefully sequenced to ensure
|
|
1249
1299
|
// that when this method fails, it reports the most salient error.
|
|
1250
|
-
|
|
1300
|
+
(0, _error_utils.invariant)(this._data, 'RecordQueryResult must not be deleted'); // Throws when the model has been deleted.
|
|
1251
1301
|
|
|
1252
1302
|
(0, _error_utils.invariant)(this.isDataLoaded, 'RecordQueryResult data is not loaded');
|
|
1253
|
-
|
|
1303
|
+
|
|
1304
|
+
if (!this._orderedGroups) {
|
|
1305
|
+
this._orderedGroups = this._generateAndLoadOrderedGroups();
|
|
1306
|
+
}
|
|
1307
|
+
|
|
1308
|
+
return (_this$_orderedGroups = this._orderedGroups) !== null && _this$_orderedGroups !== void 0 ? _this$_orderedGroups : null;
|
|
1254
1309
|
}
|
|
1255
1310
|
/**
|
|
1256
1311
|
* The GroupLevels in this RecordQueryResult.
|
|
@@ -1263,10 +1318,15 @@ function (_RecordQueryResult) {
|
|
|
1263
1318
|
}, {
|
|
1264
1319
|
key: "groupLevels",
|
|
1265
1320
|
get: function get() {
|
|
1266
|
-
|
|
1321
|
+
(0, _error_utils.invariant)(this._data, 'RecordQueryResult must not be deleted'); // Throws when the model has been deleted.
|
|
1267
1322
|
|
|
1268
1323
|
(0, _error_utils.invariant)(this.isDataLoaded, 'RecordQueryResult data is not loaded');
|
|
1269
|
-
|
|
1324
|
+
|
|
1325
|
+
if (!this._loadedGroupLevels) {
|
|
1326
|
+
this._loadedGroupLevels = this._sourceModelGroupLevels;
|
|
1327
|
+
}
|
|
1328
|
+
|
|
1329
|
+
return this._loadedGroupLevels ? this._loadedGroupLevels.map(singleLevel => _objectSpread({}, singleLevel, {
|
|
1270
1330
|
field: this.parentTable.getFieldById(singleLevel.fieldId)
|
|
1271
1331
|
})) : null;
|
|
1272
1332
|
}
|
|
@@ -1281,13 +1341,13 @@ function (_RecordQueryResult) {
|
|
|
1281
1341
|
// using RecordQueryResult) if the user had to manually watch for deletion
|
|
1282
1342
|
// on all the fields and recreate the RecordQueryResult.
|
|
1283
1343
|
|
|
1284
|
-
var
|
|
1285
|
-
var
|
|
1286
|
-
var
|
|
1344
|
+
var _iteratorNormalCompletion13 = true;
|
|
1345
|
+
var _didIteratorError13 = false;
|
|
1346
|
+
var _iteratorError13 = undefined;
|
|
1287
1347
|
|
|
1288
1348
|
try {
|
|
1289
|
-
for (var
|
|
1290
|
-
var fieldId =
|
|
1349
|
+
for (var _iterator13 = fieldIdsOrNullIfAllFields[Symbol.iterator](), _step13; !(_iteratorNormalCompletion13 = (_step13 = _iterator13.next()).done); _iteratorNormalCompletion13 = true) {
|
|
1350
|
+
var fieldId = _step13.value;
|
|
1291
1351
|
|
|
1292
1352
|
var field = this._table.getFieldByIdIfExists(fieldId);
|
|
1293
1353
|
|
|
@@ -1296,16 +1356,16 @@ function (_RecordQueryResult) {
|
|
|
1296
1356
|
}
|
|
1297
1357
|
}
|
|
1298
1358
|
} catch (err) {
|
|
1299
|
-
|
|
1300
|
-
|
|
1359
|
+
_didIteratorError13 = true;
|
|
1360
|
+
_iteratorError13 = err;
|
|
1301
1361
|
} finally {
|
|
1302
1362
|
try {
|
|
1303
|
-
if (!
|
|
1304
|
-
|
|
1363
|
+
if (!_iteratorNormalCompletion13 && _iterator13.return != null) {
|
|
1364
|
+
_iterator13.return();
|
|
1305
1365
|
}
|
|
1306
1366
|
} finally {
|
|
1307
|
-
if (
|
|
1308
|
-
throw
|
|
1367
|
+
if (_didIteratorError13) {
|
|
1368
|
+
throw _iteratorError13;
|
|
1309
1369
|
}
|
|
1310
1370
|
}
|
|
1311
1371
|
}
|
|
@@ -1359,10 +1419,17 @@ function (_RecordQueryResult) {
|
|
|
1359
1419
|
get: function get() {
|
|
1360
1420
|
return this._sourceModel instanceof _table.default ? this._recordStore.records : this._recordStore.getViewDataStore(this._sourceModel.id).visibleRecords;
|
|
1361
1421
|
}
|
|
1422
|
+
/**
|
|
1423
|
+
* This is just a helper structure to better colocate watch and unwatch logic
|
|
1424
|
+
*
|
|
1425
|
+
* @internal
|
|
1426
|
+
*/
|
|
1427
|
+
|
|
1362
1428
|
}]);
|
|
1363
1429
|
return TableOrViewQueryResult;
|
|
1364
1430
|
}(_record_query_result.default);
|
|
1365
1431
|
|
|
1366
1432
|
(0, _defineProperty2.default)(TableOrViewQueryResult, "_className", 'TableOrViewQueryResult');
|
|
1367
1433
|
var _default = TableOrViewQueryResult;
|
|
1368
|
-
exports.default = _default;
|
|
1434
|
+
exports.default = _default;
|
|
1435
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/models/table_or_view_query_result.ts"],"names":["TableOrViewQueryResult","sdk","sourceModel","normalizedOpts","RecordQueryResult","WatchableCellValuesInFieldKeyPrefix","key","functionToCallWithKey","fieldId","substring","length","_fieldIdsSetToLoadOrNullIfAllFields","WatchableKeys","cellValues","Object","keys","_mostRecentSourceModelLoadedPromise","_sourceModel","Table","_recordStore","unloadCellValuesForQueryIdsThatAreSubscribedToAllCells","_loadedSourceModelQueryIds","unloadViewDataStoreAndCellValuesWithQueryIds","unwatch","WatchableRecordStoreKeys","records","_onRecordsChanged","isDeleted","viewDataStore","getViewDataStore","id","WatchableViewDataStoreKeys","visibleRecords","groups","_onGroupsChanged","groupLevels","_onGroupLevelsChanged","_cellValuesForSortWatchKeys","_onCellValuesForSortChanged","_cellValuesForGroupWatchKeys","_onCellValuesForGroupChanged","_table","WatchableTableKeys","fields","_onTableFieldsChanged","_sorts","sort","field","getFieldByIdIfExists","_onFieldConfigChanged","_unloadOrderedGroupsIfNeeded","_visList","_orderedRecordIds","_recordIdsSet","__tableOrViewQueryResultPool","unregisterObjectForReuseStrong","table","sorts","_normalizedOpts","_groupLevels","_orderedGroups","_loadedGroupLevels","fieldIdsSetToLoadOrNullIfAllFields","fieldIdsOrNullIfAllFields","recordColorMode","type","RecordColorModeTypes","BY_SELECT_FIELD","selectField","__groupedRecordQueryResultPool","ObjectPool","GroupedRecordQueryResult","seal","recordIdsSet","recordIds","recordId","callback","context","validKeys","callWatchOnRecordStoreWithKeys","keysToWatch","watchWithRecordQueryResult","recordQueryResult","callbackForRegistration","startsWith","_watchConfigByWatchableKey","callUnwatchOnRecordStoreWithKeys","keysToUnwatch","_spawnErrorForDeletion","fieldIdsToLoadOrNullIfAllFields","allFieldsToQuery","metadataFieldId","_getFieldIdForCausingRecordMetadataToLoad","includes","sourceModelLoadPromise","loadAllCellValuesInFieldIdsAsync","loadAllCellValuesAsync","loadViewDataStoreAndCellValuesForFieldIdsAsync","sourceModelLoadedPromise","then","sourceModelQueryId","push","Promise","all","_loadRecordColorsAsync","changedKeys","fieldIds","map","registerObjectForReuseStrong","_replaceVisList","_generateOrderedRecordIds","watch","_getChangedKeysOnLoad","_unloadRecordColors","_unloadDataAsync","visList","addRecordIds","model","updates","_unloadGroupsAndTriggerWatches","_onChange","WatchableRecordQueryResultKeys","ViewDataStore","visibleRecordIds","viewId","addedRecordIds","removedRecordIds","removeRecordIds","_addRecordIdsToVisList","undefined","recordStore","visListRecordIdsSet","Set","getOrderedRecordIds","recordIdsToMove","filter","has","changeData","_field","_key","addedFieldIds","removedFieldIds","fieldIdsSet","wereAnyFieldsCreatedOrDeleted","some","_sourceModelRecordIds","_sourceModelGroupLevels","_sourceModelGroups","groupData","group","getObjectForReuse","_sdk","loadDataAsync","unloadData","airtableInterface","__airtableInterface","_sourceModelRecords","record","fieldDatas","_data","filteredSorts","_getSortsWithDeletedFieldsFiltered","createVisListWithRecordIds","sourceModelName","fieldSelection","View","sourceType","BlockQuerySourceType","VIEW","sourceTableId","sourceViewId","recordSelection","viewMetadataSelection","TABLE","_serializedOpts","isDataLoaded","_generateAndLoadOrderedGroups","singleLevel","parentTable","getFieldById"],"mappings":"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","sourcesContent":["/** @module @airtable/blocks/models: RecordQueryResult */ /** */\nimport Sdk from '../sdk';\nimport {FieldId} from '../types/field';\nimport {\n    has,\n    arrayDifference,\n    FlowAnyObject,\n    FlowAnyFunction,\n    ObjectMap,\n    fireAndForgetPromise,\n} from '../private_utils';\nimport {invariant, spawnError} from '../error_utils';\nimport {VisList, NormalizedGroupLevel} from '../types/airtable_interface';\nimport {RecordId} from '../types/record';\nimport {GroupLevelData, GroupData} from '../types/view';\nimport {\n    BlockQueryId,\n    BlockQuerySpec,\n    BlockQuerySourceType,\n    BlockFieldSelectionSpec,\n} from '../types/block_query_spec';\nimport Table, {WatchableTableKeys} from './table';\nimport View from './view';\nimport RecordQueryResult, {\n    WatchableRecordQueryResultKey,\n    NormalizedRecordQueryResultOpts,\n    NormalizedSortConfig,\n    WatchableRecordQueryResultKeys,\n} from './record_query_result';\nimport {ModeTypes as RecordColorModeTypes} from './record_coloring';\nimport Field from './field';\nimport Record from './record';\nimport ObjectPool from './object_pool';\nimport RecordStore, {WatchableRecordStoreKey, WatchableRecordStoreKeys} from './record_store';\nimport ViewDataStore, {WatchableViewDataStoreKeys} from './view_data_store';\nimport GroupedRecordQueryResult from './grouped_record_query_result';\nimport {GroupLevels} from './view_metadata_query_result';\n\n/** @hidden */\ninterface TableOrViewQueryResultData {\n    recordIds: ReadonlyArray<string> | null; // null if data isn't loaded (or if it hasn't been lazily initialized).\n}\n\n/**\n * Represents a set of records directly from a view or table. See {@link RecordQueryResult} for main\n * documentation.\n *\n * Do not instantiate. You can get instances of this class by calling\n * `table.selectRecords` or `view.selectRecords`.\n *\n * @docsPath models/query results/TableOrViewQueryResult\n */\nclass TableOrViewQueryResult extends RecordQueryResult<TableOrViewQueryResultData> {\n    /** @internal */\n    static _className = 'TableOrViewQueryResult';\n\n    /** @internal */\n    _sourceModel: Table | View;\n    /** @internal */\n    _mostRecentSourceModelLoadedPromise: Promise<[void, void]> | null;\n    /**\n     * Tracks a unique ID for each model query that has been loaded.\n     * Note that hyperbase may return a new model query ID even if the\n     * query itself is identical to a previous one. Having these unique\n     * IDs allows the SDK to maintain an accurate reference count of\n     * all model loads. _loadedSourceModelQueryIds must only be updated\n     * before unloading occurs.\n     *\n     * @internal\n     */\n    _loadedSourceModelQueryIds: Array<BlockQueryId>;\n    /** @internal */\n    _table: Table;\n\n    /** @internal */\n    _fieldIdsSetToLoadOrNullIfAllFields: {[key: string]: true} | null;\n\n    // If custom sorts or groups are specified, we'll use a VisList to handle sorting.\n    // If no sorts are specified, we'll use the underlying row order of the source model.\n    // Note: we're currently handling visibility tracking for view query results within this class,\n    // not in the VisList. In other words, only visible records are added to the visList.\n    /** @internal */\n    _visList: VisList | null;\n    /** @internal */\n    _sorts: Array<NormalizedSortConfig> | null;\n    // These is the groupLevels provided to us by the user when executing a query\n    /** @internal */\n    _groupLevels: Array<NormalizedGroupLevel> | null;\n\n    // This is the ordered list of record ids.\n    /** @internal */\n    _orderedRecordIds: ReadonlyArray<string> | null;\n\n    // This is the ordered list of groups.\n    /** @internal */\n    _orderedGroups: ReadonlyArray<GroupedRecordQueryResult> | null;\n\n    // An ordered list of group levels returned to us from hyperbase, this should not be\n    // read from directly, but instead via this.data.groupLevels (Writing to this on hyperbase updates).\n    // (which check's that this model has not been not deleted)\n    /** @internal */\n    _loadedGroupLevels: ReadonlyArray<NormalizedGroupLevel> | null;\n\n    // lazily generated set of record ids\n    /** @internal */\n    _recordIdsSet: {[key: string]: true | void} | null = null;\n\n    /** @internal */\n    __groupedRecordQueryResultPool: ObjectPool<\n        GroupedRecordQueryResult,\n        typeof GroupedRecordQueryResult\n    >;\n\n    /** @internal */\n    constructor(\n        sdk: Sdk,\n        sourceModel: Table | View,\n        normalizedOpts: NormalizedRecordQueryResultOpts,\n    ) {\n        super(sdk, normalizedOpts);\n\n        this._sourceModel = sourceModel;\n        this._mostRecentSourceModelLoadedPromise = null;\n        this._loadedSourceModelQueryIds = [];\n        this._table = normalizedOpts.table;\n\n        const {sorts} = this._normalizedOpts;\n        this._sorts = sorts ?? null;\n        // TODO (SeanKeenan): Placeholder until we support groups from normalizedOpts\n        this._groupLevels = null;\n\n        this._visList = null;\n        this._orderedRecordIds = null;\n        this._orderedGroups = null;\n        this._loadedGroupLevels = null;\n\n        let fieldIdsSetToLoadOrNullIfAllFields: ObjectMap<FieldId, true> | null = null;\n        if (this._normalizedOpts.fieldIdsOrNullIfAllFields) {\n            fieldIdsSetToLoadOrNullIfAllFields = {};\n            for (const fieldId of this._normalizedOpts.fieldIdsOrNullIfAllFields) {\n                fieldIdsSetToLoadOrNullIfAllFields[fieldId] = true;\n            }\n            // Need to load data for fields we're sorting by, even if\n            // they're not explicitly requested in the `fields` opt.\n            if (this._sorts !== null) {\n                for (const sort of this._sorts) {\n                    fieldIdsSetToLoadOrNullIfAllFields[sort.fieldId] = true;\n                }\n            }\n            // TODO (SeanKeenan): Comment back in when enabling groups\n            // Same for group configs\n            // if (this._groupLevels !== null) {\n            //     for (const group of this._groupLevels) {\n            //         fieldIdsSetToLoadOrNullIfAllFields[group.fieldId] = true;\n            //     }\n            // }\n\n            const recordColorMode = this._normalizedOpts.recordColorMode;\n            if (recordColorMode && recordColorMode.type === RecordColorModeTypes.BY_SELECT_FIELD) {\n                fieldIdsSetToLoadOrNullIfAllFields[recordColorMode.selectField.id] = true;\n            }\n        }\n        this._fieldIdsSetToLoadOrNullIfAllFields = fieldIdsSetToLoadOrNullIfAllFields;\n        this.__groupedRecordQueryResultPool = new ObjectPool(GroupedRecordQueryResult);\n\n        Object.seal(this);\n    }\n    /** @internal */\n    get _dataOrNullIfDeleted(): TableOrViewQueryResultData | null {\n        if (this._sourceModel.isDeleted || this._recordStore.isDeleted) {\n            return null;\n        }\n\n        return {\n            recordIds: this._orderedRecordIds,\n        };\n    }\n    /** @internal */\n    // istanbul ignore next\n    get __sourceModelId(): string {\n        return this._sourceModel.id;\n    }\n\n    /** @internal */\n    get __poolKey(): string {\n        return `${this._serializedOpts}::${this._sourceModel.id}`;\n    }\n\n    /**\n     * @internal (since we may not be able to return parent model instances in the immutable models world)\n     * The table that records in this RecordQueryResult are part of\n     */\n    get parentTable(): Table {\n        return this._table;\n    }\n    /**\n     * @internal (since we may not be able to return parent model instances in the immutable models world)\n     * The view that was used to obtain this RecordQueryResult by calling\n     * `view.selectRecords`. Null if the RecordQueryResult was obtained by calling\n     * `table.selectRecords`.\n     */\n    get parentView(): View | null {\n        return this._sourceModel instanceof Table ? null : this._sourceModel;\n    }\n    /**\n     * The record IDs in this RecordQueryResult.\n     * Throws if data is not loaded yet.\n     * Can be watched.\n     */\n    get recordIds(): Array<string> {\n        // The following statements have been carefully sequenced to ensure\n        // that when this method fails, it reports the most salient error.\n        const {recordIds} = this._data; // Throws when the model has been deleted.\n        invariant(this.isDataLoaded, 'RecordQueryResult data is not loaded');\n        invariant(recordIds, 'No recordIds');\n        // TODO: (#proj-blocks-sdk-record-limits) Change this to readonly upon the\n        // next breaking change.\n        return [...recordIds];\n    }\n    /**\n     * The ordered GroupedRecordQueryResult's in this RecordQueryResult.\n     * Throws if data is not loaded yet.\n     * Can be watched.\n     *\n     * @hidden\n     */\n    get groups(): ReadonlyArray<GroupedRecordQueryResult> | null {\n        // The following statements have been carefully sequenced to ensure\n        // that when this method fails, it reports the most salient error.\n        invariant(this._data, 'RecordQueryResult must not be deleted'); // Throws when the model has been deleted.\n        invariant(this.isDataLoaded, 'RecordQueryResult data is not loaded');\n        if (!this._orderedGroups) {\n            this._orderedGroups = this._generateAndLoadOrderedGroups();\n        }\n\n        return this._orderedGroups ?? null;\n    }\n    /**\n     * The GroupLevels in this RecordQueryResult.\n     * Throws if data is not loaded yet.\n     * Can be watched.\n     *\n     * @hidden\n     */\n    get groupLevels(): GroupLevels | null {\n        invariant(this._data, 'RecordQueryResult must not be deleted'); // Throws when the model has been deleted.\n        invariant(this.isDataLoaded, 'RecordQueryResult data is not loaded');\n        if (!this._loadedGroupLevels) {\n            this._loadedGroupLevels = this._sourceModelGroupLevels;\n        }\n        return this._loadedGroupLevels\n            ? this._loadedGroupLevels.map(singleLevel => ({\n                  ...singleLevel,\n                  field: this.parentTable.getFieldById(singleLevel.fieldId),\n              }))\n            : null;\n    }\n    /**\n     * The set of record IDs in this RecordQueryResult.\n     * Throws if data is not loaded yet.\n     *\n     * @internal\n     */\n    _getOrGenerateRecordIdsSet(): {[key: string]: true | void} {\n        if (!this._recordIdsSet) {\n            const recordIdsSet: ObjectMap<RecordId, true> = {};\n            for (const recordId of this.recordIds) {\n                recordIdsSet[recordId] = true;\n            }\n            this._recordIdsSet = recordIdsSet;\n        }\n\n        return this._recordIdsSet;\n    }\n    /**\n     * The fields that were used to create this RecordQueryResult.\n     * Null if fields were not specified, which means the RecordQueryResult\n     * will load all fields in the table.\n     */\n    get fields(): Array<Field> | null {\n        const {fieldIdsOrNullIfAllFields} = this._normalizedOpts;\n        if (fieldIdsOrNullIfAllFields) {\n            const fields = [];\n            // Filter out any deleted fields, since RecordQueryResult is \"live\".\n            // It would be too cumbersome (and defeat part of the purpose of\n            // using RecordQueryResult) if the user had to manually watch for deletion\n            // on all the fields and recreate the RecordQueryResult.\n            for (const fieldId of fieldIdsOrNullIfAllFields) {\n                const field = this._table.getFieldByIdIfExists(fieldId);\n                if (field !== null) {\n                    fields.push(field);\n                }\n            }\n            return fields;\n        } else {\n            return null;\n        }\n    }\n    /** @internal */\n    get _cellValuesForSortWatchKeys(): Array<string> {\n        return this._sorts ? this._sorts.map(sort => `cellValuesInField:${sort.fieldId}`) : [];\n    }\n    /** @internal */\n    get _cellValuesForGroupWatchKeys(): Array<string> {\n        // _groupLevels can not be specified by the user during the query yet\n        // istanbul ignore next\n        return this._groupLevels\n            ? this._groupLevels.map(group => `cellValuesInField:${group.fieldId}`)\n            : [];\n    }\n    /** @internal */\n    get _sourceModelRecordIds(): ReadonlyArray<RecordId> {\n        return this._sourceModel instanceof Table\n            ? this._recordStore.recordIds\n            : this._recordStore.getViewDataStore(this._sourceModel.id).visibleRecordIds;\n    }\n    /** @internal */\n    get _sourceModelGroups(): ReadonlyArray<GroupData> | null {\n        return this._sourceModel instanceof Table\n            ? null\n            : this._recordStore.getViewDataStore(this._sourceModel.id).groups;\n    }\n    /** @internal */\n    get _sourceModelGroupLevels(): ReadonlyArray<GroupLevelData> | null {\n        return this._sourceModel instanceof Table\n            ? null\n            : this._recordStore.getViewDataStore(this._sourceModel.id).groupLevels;\n    }\n    /** @internal */\n    get _sourceModelRecords(): Array<Record> {\n        return this._sourceModel instanceof Table\n            ? this._recordStore.records\n            : this._recordStore.getViewDataStore(this._sourceModel.id).visibleRecords;\n    }\n\n    /**\n     * This is just a helper structure to better colocate watch and unwatch logic\n     *\n     * @internal\n     */\n    _watchConfigByWatchableKey: ObjectMap<\n        WatchableRecordQueryResultKey,\n        (\n            key: WatchableRecordQueryResultKey,\n            functionToCallWithKey: (key: WatchableRecordStoreKey) => void,\n        ) => void\n    > = {\n        // Handles if this is a prefix\n        [RecordQueryResult.WatchableCellValuesInFieldKeyPrefix]: (key, functionToCallWithKey) => {\n            const fieldId = key.substring(\n                RecordQueryResult.WatchableCellValuesInFieldKeyPrefix.length,\n            );\n\n            if (\n                this._fieldIdsSetToLoadOrNullIfAllFields &&\n                !has(this._fieldIdsSetToLoadOrNullIfAllFields, fieldId)\n            ) {\n                throw spawnError(\n                    \"Can't watch or unwatch field because it wasn't included in RecordQueryResult fields: %s\",\n                    fieldId,\n                );\n            }\n            functionToCallWithKey(RecordQueryResult.WatchableCellValuesInFieldKeyPrefix + fieldId);\n        },\n        [RecordQueryResult.WatchableKeys.cellValues]: (key, functionToCallWithKey) => {\n            if (this._fieldIdsSetToLoadOrNullIfAllFields) {\n                for (const fieldId of Object.keys(this._fieldIdsSetToLoadOrNullIfAllFields)) {\n                    functionToCallWithKey(\n                        RecordQueryResult.WatchableCellValuesInFieldKeyPrefix + fieldId,\n                    );\n                }\n            } else {\n                functionToCallWithKey(RecordQueryResult.WatchableKeys.cellValues);\n            }\n        },\n    };\n\n    /** @inheritdoc */\n    watch(\n        keys: WatchableRecordQueryResultKey | ReadonlyArray<WatchableRecordQueryResultKey>,\n        callback: FlowAnyFunction,\n        context?: FlowAnyObject | null,\n    ): Array<WatchableRecordQueryResultKey> {\n        const validKeys = super.watch(keys, callback, context);\n\n        const callWatchOnRecordStoreWithKeys = (\n            keysToWatch: WatchableRecordStoreKey | ReadonlyArray<WatchableRecordStoreKey>,\n        ) => {\n            this._recordStore.watchWithRecordQueryResult({\n                recordQueryResult: this,\n                keys: keysToWatch,\n                callbackForRegistration: callback,\n                context,\n            });\n        };\n\n        for (const key of validKeys) {\n            // There are two watch systems:\n            // 1) the query-based watch\n            // 2) the non-query-based watch (through super)\n            // Depending on the key, we may use one or both of the systems.\n            // The non-query based watch system is used when when:\n            //  - watching: records, recordIds\n            //  - _loadDataAsync calls all watch keys on initial load\n            //  - Support for _watchRecordColorsIfNeeded\n            // For all changes to the remaining keys - the query-based system is used.\n            if (key.startsWith(RecordQueryResult.WatchableCellValuesInFieldKeyPrefix)) {\n                this._watchConfigByWatchableKey[\n                    RecordQueryResult.WatchableCellValuesInFieldKeyPrefix\n                ](key, callWatchOnRecordStoreWithKeys);\n            } else {\n                const functionToCallWithKey = this._watchConfigByWatchableKey[key];\n                if (functionToCallWithKey) {\n                    functionToCallWithKey(key, callWatchOnRecordStoreWithKeys);\n                }\n            }\n        }\n\n        return validKeys;\n    }\n    /** @inheritdoc */\n    unwatch(\n        keys: WatchableRecordQueryResultKey | ReadonlyArray<WatchableRecordQueryResultKey>,\n        callback: FlowAnyFunction,\n        context?: FlowAnyObject | null,\n    ): Array<WatchableRecordQueryResultKey> {\n        const validKeys = super.unwatch(keys, callback, context);\n\n        const callUnwatchOnRecordStoreWithKeys = (\n            keysToUnwatch: WatchableRecordStoreKey | ReadonlyArray<WatchableRecordStoreKey>,\n        ) => {\n            this._recordStore.unwatch(keysToUnwatch, callback, context);\n        };\n\n        for (const key of validKeys) {\n            // This is the inverse of the watch logic\n            if (key.startsWith(RecordQueryResult.WatchableCellValuesInFieldKeyPrefix)) {\n                this._watchConfigByWatchableKey[\n                    RecordQueryResult.WatchableCellValuesInFieldKeyPrefix\n                ](key, callUnwatchOnRecordStoreWithKeys);\n            } else {\n                const functionToCallWithKey = this._watchConfigByWatchableKey[key];\n                if (functionToCallWithKey) {\n                    functionToCallWithKey(key, callUnwatchOnRecordStoreWithKeys);\n                }\n            }\n        }\n\n        return validKeys;\n    }\n    /** @inheritdoc */\n    async loadDataAsync() {\n        // TODO: (#proj-blocks-sdk-record-limits) Move _recordStore.loadDataAsync to a non-reference\n        // counted solution.\n        let sourceModelLoadPromise: Promise<BlockQueryId>;\n\n        if (this._sourceModel.isDeleted) {\n            throw this._spawnErrorForDeletion();\n        }\n\n        const fieldIdsToLoadOrNullIfAllFields = this._fieldIdsSetToLoadOrNullIfAllFields\n            ? Object.keys(this._fieldIdsSetToLoadOrNullIfAllFields)\n            : null;\n\n        if (this._sourceModel instanceof Table) {\n            if (fieldIdsToLoadOrNullIfAllFields) {\n                // TODO: (#proj-blocks-sdk-record-limits) Do we need to load the recordData metadata field\n                // in order to load any record data? If we do - this should be encapsulated entirely\n                // inside of the RecordStore in publicAirtableInterface.\n                // (should the queryModel be able to specify metadata requirements?)\n                let allFieldsToQuery = fieldIdsToLoadOrNullIfAllFields;\n                const metadataFieldId = this._recordStore._getFieldIdForCausingRecordMetadataToLoad();\n                if (!allFieldsToQuery.includes(metadataFieldId)) {\n                    allFieldsToQuery = [...allFieldsToQuery, metadataFieldId];\n                }\n                sourceModelLoadPromise = this._recordStore.loadAllCellValuesInFieldIdsAsync(\n                    allFieldsToQuery,\n                );\n            } else {\n                // Load all fields.\n                sourceModelLoadPromise = this._recordStore.loadAllCellValuesAsync();\n            }\n        } else {\n            sourceModelLoadPromise = this._recordStore.loadViewDataStoreAndCellValuesForFieldIdsAsync(\n                this._sourceModel.id,\n                fieldIdsToLoadOrNullIfAllFields,\n            );\n        }\n\n        // See comment on _loadedSourceModelQueryIds declaration for details\n        const sourceModelLoadedPromise = sourceModelLoadPromise.then(sourceModelQueryId => {\n            this._loadedSourceModelQueryIds.push(sourceModelQueryId);\n        });\n\n        this._mostRecentSourceModelLoadedPromise = Promise.all([\n            sourceModelLoadedPromise,\n            this._loadRecordColorsAsync(),\n        ]);\n\n        await super.loadDataAsync();\n    }\n\n    /**\n     * @internal\n     */\n    _getChangedKeysOnLoad(): Array<WatchableRecordQueryResultKey> {\n        const changedKeys: Array<WatchableRecordQueryResultKey> = [\n            RecordQueryResult.WatchableKeys.records,\n            RecordQueryResult.WatchableKeys.recordIds,\n            RecordQueryResult.WatchableKeys.cellValues,\n            RecordQueryResult.WatchableKeys.groups,\n            RecordQueryResult.WatchableKeys.groupLevels,\n        ];\n\n        const fieldIds =\n            this._normalizedOpts.fieldIdsOrNullIfAllFields ||\n            this._table.fields.map(field => field.id);\n\n        for (const fieldId of fieldIds) {\n            changedKeys.push(RecordQueryResult.WatchableCellValuesInFieldKeyPrefix + fieldId);\n        }\n\n        return changedKeys;\n    }\n\n    /** @internal */\n    async _loadDataAsync(): Promise<Array<WatchableRecordQueryResultKey>> {\n        this._table.__tableOrViewQueryResultPool.registerObjectForReuseStrong(this);\n\n        invariant(this._mostRecentSourceModelLoadedPromise, 'No source model load promises');\n        await this._mostRecentSourceModelLoadedPromise;\n\n        if (this._sorts) {\n            this._replaceVisList();\n        }\n        this._orderedRecordIds = this._generateOrderedRecordIds();\n        // Ensure that groups are not loaded\n        this._orderedGroups = null;\n        // The server provided value and developer supplied value are the same, no conversion needed\n        this._loadedGroupLevels = null;\n\n        if (this._sourceModel instanceof Table) {\n            this._recordStore.watchWithRecordQueryResult({\n                recordQueryResult: this,\n                keys: WatchableRecordStoreKeys.records,\n                callbackForRegistration: this._onRecordsChanged,\n                context: this,\n            });\n        } else {\n            const viewDataStore = this._recordStore.getViewDataStore(this._sourceModel.id);\n            viewDataStore.watch(\n                WatchableViewDataStoreKeys.visibleRecords,\n                this._onRecordsChanged,\n                this,\n            );\n            viewDataStore.watch(WatchableViewDataStoreKeys.groups, this._onGroupsChanged, this);\n            viewDataStore.watch(\n                WatchableViewDataStoreKeys.groupLevels,\n                this._onGroupLevelsChanged,\n                this,\n            );\n        }\n\n        // This only watches cell values if a sort is specified\n        this._recordStore.watchWithRecordQueryResult({\n            recordQueryResult: this,\n            keys: this._cellValuesForSortWatchKeys,\n            callbackForRegistration: this._onCellValuesForSortChanged,\n            context: this,\n        });\n\n        this._recordStore.watchWithRecordQueryResult({\n            recordQueryResult: this,\n            keys: this._cellValuesForGroupWatchKeys,\n            callbackForRegistration: this._onCellValuesForGroupChanged,\n            context: this,\n        });\n\n        this._table.watch(WatchableTableKeys.fields, this._onTableFieldsChanged, this);\n\n        if (this._sorts) {\n            for (const sort of this._sorts) {\n                const field = this._table.getFieldByIdIfExists(sort.fieldId);\n                if (field) {\n                    field.watch('type', this._onFieldConfigChanged, this);\n                    field.watch('options', this._onFieldConfigChanged, this);\n                }\n            }\n        }\n\n        return this._getChangedKeysOnLoad();\n    }\n    /** @inheritdoc */\n    unloadData() {\n        super.unloadData();\n\n        if (this._loadedSourceModelQueryIds.length === 0) {\n            // Source model must have loaded a queryId to unload\n            return;\n        }\n\n        this._unloadRecordColors();\n    }\n    /** @internal */\n    _unloadData() {\n        fireAndForgetPromise(this._unloadDataAsync);\n    }\n\n    _unloadDataAsync = async () => {\n        // If there is a loading promise in the process of adding more\n        // source model queryIds - wait for these to be added.\n        // (If it's already loaded the promise will resolve immediately)\n        if (this._mostRecentSourceModelLoadedPromise) {\n            await this._mostRecentSourceModelLoadedPromise;\n        }\n\n        // Unload all queries that were subscribed to the entire query\n        if (this._sourceModel instanceof Table) {\n            this._recordStore.unloadCellValuesForQueryIdsThatAreSubscribedToAllCells(\n                this._loadedSourceModelQueryIds,\n            );\n        } else {\n            // Even if the view is deleted, we can still unsubscribe from the cells\n            this._recordStore.unloadViewDataStoreAndCellValuesWithQueryIds(\n                this._loadedSourceModelQueryIds,\n            );\n        }\n\n        this._mostRecentSourceModelLoadedPromise = null;\n\n        if (this._sourceModel instanceof Table) {\n            this._recordStore.unwatch(\n                WatchableRecordStoreKeys.records,\n                this._onRecordsChanged,\n                this,\n            );\n        } else {\n            if (!this._sourceModel.isDeleted) {\n                const viewDataStore = this._recordStore.getViewDataStore(this._sourceModel.id);\n                viewDataStore.unwatch(\n                    WatchableViewDataStoreKeys.visibleRecords,\n                    this._onRecordsChanged,\n                    this,\n                );\n                viewDataStore.unwatch(\n                    WatchableViewDataStoreKeys.groups,\n                    this._onGroupsChanged,\n                    this,\n                );\n                viewDataStore.unwatch(\n                    WatchableViewDataStoreKeys.groupLevels,\n                    this._onGroupLevelsChanged,\n                    this,\n                );\n            }\n        }\n\n        this._recordStore.unwatch(\n            this._cellValuesForSortWatchKeys,\n            this._onCellValuesForSortChanged,\n            this,\n        );\n\n        this._recordStore.unwatch(\n            this._cellValuesForGroupWatchKeys,\n            this._onCellValuesForGroupChanged,\n            this,\n        );\n\n        this._table.unwatch(WatchableTableKeys.fields, this._onTableFieldsChanged, this);\n\n        // If the table is deleted, can't call getFieldById on it below.\n        if (!this._table.isDeleted && this._sorts) {\n            for (const sort of this._sorts) {\n                const field = this._table.getFieldByIdIfExists(sort.fieldId);\n                if (field) {\n                    field.unwatch('type', this._onFieldConfigChanged, this);\n                    field.unwatch('options', this._onFieldConfigChanged, this);\n                }\n            }\n        }\n\n        this._unloadOrderedGroupsIfNeeded();\n\n        this._visList = null;\n        this._orderedRecordIds = null;\n        this._recordIdsSet = null;\n\n        this._table.__tableOrViewQueryResultPool.unregisterObjectForReuseStrong(this);\n    };\n    /** @internal */\n    _addRecordIdsToVisList(recordIds: Array<string>) {\n        const visList = this._visList;\n        invariant(visList, 'No vis list');\n        visList.addRecordIds(recordIds);\n    }\n    /** @internal */\n    _onGroupLevelsChanged(\n        model: RecordStore | ViewDataStore,\n        key: string,\n        updates?: {addedRecordIds: Array<string>; removedRecordIds: Array<string>} | null,\n    ) {\n        this._loadedGroupLevels = null;\n        this._unloadGroupsAndTriggerWatches();\n        this._onChange(WatchableRecordQueryResultKeys.groupLevels);\n    }\n    /** @internal */\n    _onGroupsChanged(\n        model: RecordStore | ViewDataStore,\n        key: string,\n        updates?: {addedRecordIds: Array<string>; removedRecordIds: Array<string>} | null,\n    ) {\n        this._unloadGroupsAndTriggerWatches();\n    }\n    /** @internal */\n    _onRecordsChanged(\n        model: RecordStore | ViewDataStore,\n        key: string,\n        updates?: {addedRecordIds: Array<string>; removedRecordIds: Array<string>} | null,\n    ) {\n        if (model instanceof ViewDataStore) {\n            // For a view model, we don't get updates sent with the onChange event,\n            // so we need to manually generate updates based on the old and new\n            // recordIds.\n            invariant(this._orderedRecordIds, '_orderedRecordIds unset');\n            const visibleRecordIds = this._recordStore.getViewDataStore(model.viewId)\n                .visibleRecordIds;\n            const addedRecordIds = arrayDifference(visibleRecordIds, this._orderedRecordIds);\n            const removedRecordIds = arrayDifference(this._orderedRecordIds, visibleRecordIds);\n            updates = {addedRecordIds, removedRecordIds};\n        }\n\n        // We never need to handle an initial empty update coming from record_store\n        // since it does not issue empty initial updates.\n        // Keep the if statement for type safety. Invariant would also work, but is riskier.\n        // istanbul ignore if\n        if (!updates) {\n            // If there are no updates, do nothing, since we'll handle the initial\n            // callback when the record set is loaded (and we don't want to fire\n            // a records change twice with no data).\n            return;\n        }\n\n        const {addedRecordIds, removedRecordIds} = updates;\n\n        if (this._sorts) {\n            const visList = this._visList;\n            invariant(visList, 'No vis list');\n\n            if (removedRecordIds.length > 0) {\n                visList.removeRecordIds(removedRecordIds);\n            }\n\n            if (addedRecordIds.length > 0) {\n                this._addRecordIdsToVisList(addedRecordIds);\n            }\n        }\n\n        if (this._recordIdsSet) {\n            for (const recordId of addedRecordIds) {\n                this._recordIdsSet[recordId] = true;\n            }\n            for (const recordId of removedRecordIds) {\n                this._recordIdsSet[recordId] = undefined;\n            }\n        }\n\n        // Now that we've applied our changes (if applicable), let's regenerate our recordIds.\n        this._orderedRecordIds = this._generateOrderedRecordIds();\n\n        this._onChange(RecordQueryResult.WatchableKeys.records, updates);\n        this._onChange(RecordQueryResult.WatchableKeys.recordIds, updates);\n    }\n    /** @internal */\n    // istanbul ignore next\n    _onCellValuesForGroupChanged(\n        recordStore: RecordStore,\n        key: string,\n        recordIds?: Array<string> | null,\n        fieldId?: string | null,\n    ) {\n        // TODO(SeanKeenan): This isn't yet required as we don't yet support\n        // specifying groups for a custom query, and this will only be called\n        // if we specify groups (same as _onCellValuesForSortChanged)\n        // This functionality and _onCellValuesForSortChanged should be\n        // identical, but testing, validation, and careful thought is required.\n    }\n    /** @internal */\n    _onCellValuesForSortChanged(\n        recordStore: RecordStore,\n        key: string,\n        recordIds?: Array<string> | null,\n        fieldId?: string | null,\n    ) {\n        // We never need to handle an initial empty update coming from record_store\n        // since it does not issue empty initial updates.\n        // Keep the if statement for type safety. Invariant would also work, but is riskier.\n        // istanbul ignore if\n        if (!recordIds || !fieldId) {\n            // If there are no updates, do nothing, since we'll handle the initial\n            // callback when the record set is loaded (and we don't want to fire\n            // a records change twice with no data).\n            return;\n        }\n\n        // NOTE: this will only ever be called if we have sorts, so it's safe to assert that we have\n        // a vis list here.\n        const visList = this._visList;\n        invariant(visList, 'No vis list');\n\n        invariant(recordIds.length > 0, 'field ID set without a corresponding record ID');\n\n        // Only move recordIds that are already in the visList.\n        // It's possible to have recordId that is not currently in the visList since\n        // this callback can run before onRecordsChanged. (eg. when a deleted record is\n        // restored, this is triggered for that record but the record is not yet in the visList:\n        // onRecordsChanged actually adds it)\n        // Note: cell value changes that result in the records being filtered out trigger\n        //       onRecordsChanged on the View model, so we don't have to worry about that here.\n        const visListRecordIdsSet = new Set(visList.getOrderedRecordIds());\n        const recordIdsToMove = recordIds.filter(recordId => visListRecordIdsSet.has(recordId));\n\n        visList.removeRecordIds(recordIdsToMove);\n        this._addRecordIdsToVisList(recordIdsToMove);\n        this._orderedRecordIds = this._generateOrderedRecordIds();\n\n        const changeData = {addedRecordIds: [], removedRecordIds: []};\n        this._onChange(RecordQueryResult.WatchableKeys.records, changeData);\n        this._onChange(RecordQueryResult.WatchableKeys.recordIds, changeData);\n    }\n    /** @internal */\n    _onFieldConfigChanged(_field: Field, _key: string) {\n        // Field config changed for a field we rely on, so we need to replace our vis list.\n        // NOTE: this will only ever be called if we have sorts, so it's safe to assume we\n        // are using a vis list here.\n        this._replaceVisList();\n        this._orderedRecordIds = this._generateOrderedRecordIds();\n    }\n    /** @internal */\n    _onTableFieldsChanged(\n        table: Table,\n        key: string,\n        updates: {addedFieldIds: Array<string>; removedFieldIds: Array<string>},\n    ) {\n        if (!this._sorts) {\n            // If we don't have any sorts, we don't have to do anything in response to field changes.\n            return;\n        }\n\n        const {addedFieldIds, removedFieldIds} = updates;\n        const fieldIdsSet = new Set(this._sorts.map(sort => sort.fieldId));\n\n        // Check if any fields that we rely on were created or deleted. If they were,\n        // replace our vis list.\n        // NOTE: we need to check for created, since a field that we rely on can be\n        // deleted and then undeleted.\n        let wereAnyFieldsCreatedOrDeleted = false;\n        for (const fieldId of addedFieldIds) {\n            // If a field that we rely on was created (i.e. it was undeleted), we need to\n            // make sure we're watching it's config.\n            if (fieldIdsSet.has(fieldId)) {\n                wereAnyFieldsCreatedOrDeleted = true;\n                const field = this._table.getFieldByIdIfExists(fieldId);\n                invariant(field, 'Created field does not exist');\n                field.watch('type', this._onFieldConfigChanged, this);\n                field.watch('options', this._onFieldConfigChanged, this);\n            }\n        }\n\n        // coverage analysis\n        // istanbul ignore else\n        if (!wereAnyFieldsCreatedOrDeleted) {\n            wereAnyFieldsCreatedOrDeleted = removedFieldIds.some(fieldId =>\n                fieldIdsSet.has(fieldId),\n            );\n        }\n\n        if (wereAnyFieldsCreatedOrDeleted) {\n            // One of the fields we're relying on was deleted,\n            this._replaceVisList();\n            this._orderedRecordIds = this._generateOrderedRecordIds();\n\n            // Make sure we fire onChange events since the order may have changed\n            // as a result.\n            const changeData = {addedRecordIds: [], removedRecordIds: []};\n            this._onChange(RecordQueryResult.WatchableKeys.records, changeData);\n            this._onChange(RecordQueryResult.WatchableKeys.recordIds, changeData);\n\n            // We do not unload/reload groupQueryResults if it's field is deleted as\n            // it is responsible for failing to load if the field doesn't exist\n        }\n    }\n    /** @internal */\n    _generateOrderedRecordIds(): ReadonlyArray<string> {\n        if (this._sorts) {\n            invariant(this._visList, 'Cannot generate record ids without a vis list');\n            return this._visList.getOrderedRecordIds();\n        } else {\n            return this._sourceModelRecordIds;\n        }\n    }\n    /** @internal */\n    _generateAndLoadOrderedGroups(): Array<GroupedRecordQueryResult> | null {\n        // istanbul ignore next\n        if (this._groupLevels) {\n            throw spawnError('custom group configs not supported');\n        } else {\n            // Get the group from the view itself\n            const groupLevels = this._sourceModelGroupLevels;\n            if (!this._sourceModelGroups || !groupLevels) {\n                return null;\n            }\n            return this._sourceModelGroups.map(groupData => {\n                const group = this.__groupedRecordQueryResultPool.getObjectForReuse(\n                    this,\n                    groupData,\n                    groupLevels,\n                    this._normalizedOpts,\n                    this._sdk,\n                );\n                // Don't await the loading, let others check isDataLoaded.\n                // (it doesn't take any time anyway). Loading also strong retains.\n                group.loadDataAsync();\n                return group;\n            });\n        }\n    }\n\n    /** @internal */\n    _unloadOrderedGroupsIfNeeded() {\n        if (this._orderedGroups) {\n            for (const group of this._orderedGroups) {\n                group.unloadData();\n            }\n        }\n    }\n    /**\n     * If groupings change then some groups will need to be created, and some removed\n     * Triggers the WatchableKeys.group, as by necessity this will have changed.\n     * TODO: This _should_ handle the diffing necessary to unload, and reload only the changed groups.\n     *\n     * @internal\n     */\n    // TODO: (SeanKeenan) Properly diff and only unload groups that need to be unloaded\n    // In the meantime it's not too expensive to just unload everything, and GroupedRecordQueryResults\n    // don't yet properly watch changes relevant to updating, so this isn't too bad.\n    _unloadGroupsAndTriggerWatches() {\n        this._unloadOrderedGroupsIfNeeded();\n        this._orderedGroups = null;\n        this._onChange(RecordQueryResult.WatchableKeys.groups);\n    }\n    /** @internal */\n    _replaceVisList() {\n        const airtableInterface = this._sdk.__airtableInterface;\n\n        const recordIds = this._sourceModelRecords.map(record => record.id);\n        const fieldDatas = this._table.fields.map(field => field._data);\n        const filteredSorts = this._getSortsWithDeletedFieldsFiltered();\n\n        this._visList = airtableInterface.createVisListWithRecordIds(\n            recordIds,\n            fieldDatas,\n            filteredSorts,\n            this._table.id,\n        );\n    }\n    /** @internal */\n    _getSortsWithDeletedFieldsFiltered(): Array<NormalizedSortConfig> {\n        invariant(this._sorts, 'No sorts');\n\n        // Filter out any sorts levels that rely on deleted fields.\n        // NOTE: we keep deleted fields around (rather than filtering them out\n        // in realtime) in case a field gets undeleted, in which case we want to\n        // keep using it.\n        return this._sorts.filter(sort => {\n            const field = this._table.getFieldByIdIfExists(sort.fieldId);\n            return !!field;\n        });\n    }\n    /** @internal */\n    _spawnErrorForDeletion(): Error {\n        const sourceModelName = this._sourceModel instanceof Table ? 'table' : 'view';\n        return spawnError(\"RecordQueryResult's underlying %s has been deleted\", sourceModelName);\n    }\n    /** @internal */\n    __constructQuerySpecForBlockFieldSelectionSpec(\n        fieldSelection: BlockFieldSelectionSpec,\n    ): BlockQuerySpec {\n        if (this._sourceModel instanceof View) {\n            return {\n                sourceType: BlockQuerySourceType.VIEW,\n                sourceTableId: this._table.id,\n                sourceViewId: this._sourceModel.id,\n                recordSelection: {\n                    fieldSelection,\n                },\n                viewMetadataSelection: {},\n            };\n        } else {\n            return {\n                sourceType: BlockQuerySourceType.TABLE,\n                sourceTableId: this._table.id,\n                recordSelection: {\n                    fieldSelection,\n                },\n            };\n        }\n    }\n}\n\nexport default TableOrViewQueryResult;\n"]}
|