@airtable/blocks 1.18.1 → 1.19.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (747) hide show
  1. package/CHANGELOG.md +15 -1
  2. package/dist/cjs/color_utils.js +21 -23
  3. package/dist/cjs/colors.js +4 -60
  4. package/dist/cjs/error_utils.js +15 -25
  5. package/dist/cjs/event_tracker.js +5 -11
  6. package/dist/cjs/global_config.js +107 -188
  7. package/dist/cjs/index.js +16 -40
  8. package/dist/cjs/injected/airtable_interface.js +1 -6
  9. package/dist/cjs/models/abstract_model.js +50 -81
  10. package/dist/cjs/models/abstract_model_with_async_data.js +102 -177
  11. package/dist/cjs/models/base.js +211 -374
  12. package/dist/cjs/models/create_aggregators.js +53 -47
  13. package/dist/cjs/models/cursor.js +125 -201
  14. package/dist/cjs/models/field.js +256 -303
  15. package/dist/cjs/models/grouped_record_query_result.js +210 -286
  16. package/dist/cjs/models/linked_records_query_result.js +276 -454
  17. package/dist/cjs/models/models.js +36 -50
  18. package/dist/cjs/models/mutation_constants.js +5 -9
  19. package/dist/cjs/models/mutations.js +125 -338
  20. package/dist/cjs/models/object_pool.js +37 -94
  21. package/dist/cjs/models/record.js +132 -226
  22. package/dist/cjs/models/record_coloring.js +14 -19
  23. package/dist/cjs/models/record_query_result.js +323 -282
  24. package/dist/cjs/models/record_store.js +355 -688
  25. package/dist/cjs/models/session.js +99 -158
  26. package/dist/cjs/models/table.js +361 -549
  27. package/dist/cjs/models/table_or_view_query_result.js +410 -765
  28. package/dist/cjs/models/view.js +161 -204
  29. package/dist/cjs/models/view_data_store.js +177 -282
  30. package/dist/cjs/models/view_metadata_query_result.js +96 -127
  31. package/dist/cjs/perform_record_action.js +69 -103
  32. package/dist/cjs/private_utils.js +133 -223
  33. package/dist/cjs/sdk.js +97 -142
  34. package/dist/cjs/settings_button.js +30 -57
  35. package/dist/cjs/stats/block_stats.js +3 -15
  36. package/dist/cjs/testing/abstract_mock_airtable_interface.js +53 -97
  37. package/dist/cjs/types/airtable_interface.js +36 -8
  38. package/dist/cjs/types/field.js +66 -12
  39. package/dist/cjs/types/mutations.js +99 -6
  40. package/dist/cjs/types/permission_levels.js +2 -4
  41. package/dist/cjs/types/undo_redo.js +2 -3
  42. package/dist/cjs/types/view.js +16 -11
  43. package/dist/cjs/ui/base_provider.js +14 -9
  44. package/dist/cjs/ui/baymax_utils.js +107 -1102
  45. package/dist/cjs/ui/block_wrapper.js +30 -68
  46. package/dist/cjs/ui/box.js +52 -56
  47. package/dist/cjs/ui/button.js +60 -77
  48. package/dist/cjs/ui/cell_renderer.js +78 -139
  49. package/dist/cjs/ui/choice_token.js +45 -47
  50. package/dist/cjs/ui/collaborator_token.js +33 -54
  51. package/dist/cjs/ui/color_palette.js +58 -106
  52. package/dist/cjs/ui/color_palette_synced.js +41 -52
  53. package/dist/cjs/ui/confirmation_dialog.js +53 -69
  54. package/dist/cjs/ui/control_sizes.js +21 -46
  55. package/dist/cjs/ui/create_detect_element_resize.js +16 -50
  56. package/dist/cjs/ui/css_helpers.js +3 -10
  57. package/dist/cjs/ui/dialog.js +44 -71
  58. package/dist/cjs/ui/dialog_close_button.js +52 -72
  59. package/dist/cjs/ui/expand_record.js +4 -11
  60. package/dist/cjs/ui/expand_record_list.js +6 -11
  61. package/dist/cjs/ui/expand_record_picker_async.js +18 -35
  62. package/dist/cjs/ui/field_icon.js +25 -28
  63. package/dist/cjs/ui/field_picker.js +47 -81
  64. package/dist/cjs/ui/field_picker_synced.js +33 -44
  65. package/dist/cjs/ui/form_field.js +45 -64
  66. package/dist/cjs/ui/geometry/geometry.js +6 -10
  67. package/dist/cjs/ui/geometry/point.js +5 -13
  68. package/dist/cjs/ui/geometry/rect.js +7 -29
  69. package/dist/cjs/ui/geometry/size.js +5 -13
  70. package/dist/cjs/ui/global_alert.js +35 -61
  71. package/dist/cjs/ui/global_config_synced_component_helpers.js +4 -13
  72. package/dist/cjs/ui/heading.js +63 -92
  73. package/dist/cjs/ui/icon.js +44 -66
  74. package/dist/cjs/ui/icon_config.js +13 -24
  75. package/dist/cjs/ui/initialize_block.js +23 -36
  76. package/dist/cjs/ui/input.js +74 -87
  77. package/dist/cjs/ui/input_synced.js +34 -43
  78. package/dist/cjs/ui/key_codes.js +4 -9
  79. package/dist/cjs/ui/label.js +45 -50
  80. package/dist/cjs/ui/link.js +74 -89
  81. package/dist/cjs/ui/loader.js +26 -42
  82. package/dist/cjs/ui/modal.js +63 -89
  83. package/dist/cjs/ui/model_picker_select.js +29 -47
  84. package/dist/cjs/ui/popover.js +98 -180
  85. package/dist/cjs/ui/progress_bar.js +45 -51
  86. package/dist/cjs/ui/record_card.js +143 -278
  87. package/dist/cjs/ui/record_card_list.js +117 -165
  88. package/dist/cjs/ui/remote_utils.js +5 -13
  89. package/dist/cjs/ui/sdk_context.js +7 -9
  90. package/dist/cjs/ui/select.js +84 -118
  91. package/dist/cjs/ui/select_and_select_buttons_helpers.js +29 -45
  92. package/dist/cjs/ui/select_buttons.js +54 -90
  93. package/dist/cjs/ui/select_buttons_synced.js +32 -41
  94. package/dist/cjs/ui/select_synced.js +32 -42
  95. package/dist/cjs/ui/switch.js +66 -84
  96. package/dist/cjs/ui/switch_synced.js +32 -38
  97. package/dist/cjs/ui/synced.js +16 -43
  98. package/dist/cjs/ui/system/all_styles_set.js +89 -22
  99. package/dist/cjs/ui/system/appearance/appearance_set.js +15 -26
  100. package/dist/cjs/ui/system/appearance/background_color.js +6 -12
  101. package/dist/cjs/ui/system/appearance/border.js +6 -12
  102. package/dist/cjs/ui/system/appearance/border_radius.js +6 -12
  103. package/dist/cjs/ui/system/appearance/box_shadow.js +6 -12
  104. package/dist/cjs/ui/system/appearance/opacity.js +5 -11
  105. package/dist/cjs/ui/system/dimensions/dimensions_set.js +15 -27
  106. package/dist/cjs/ui/system/dimensions/height.js +5 -11
  107. package/dist/cjs/ui/system/dimensions/max_height.js +5 -11
  108. package/dist/cjs/ui/system/dimensions/max_width.js +5 -11
  109. package/dist/cjs/ui/system/dimensions/min_height.js +5 -11
  110. package/dist/cjs/ui/system/dimensions/min_width.js +5 -11
  111. package/dist/cjs/ui/system/dimensions/width.js +5 -11
  112. package/dist/cjs/ui/system/display.js +8 -9
  113. package/dist/cjs/ui/system/flex_container/align_content.js +6 -12
  114. package/dist/cjs/ui/system/flex_container/align_items.js +6 -12
  115. package/dist/cjs/ui/system/flex_container/flex_container_set.js +15 -27
  116. package/dist/cjs/ui/system/flex_container/flex_direction.js +5 -11
  117. package/dist/cjs/ui/system/flex_container/flex_wrap.js +5 -11
  118. package/dist/cjs/ui/system/flex_container/justify_content.js +5 -11
  119. package/dist/cjs/ui/system/flex_container/justify_items.js +5 -11
  120. package/dist/cjs/ui/system/flex_item/align_self.js +6 -12
  121. package/dist/cjs/ui/system/flex_item/flex.js +5 -11
  122. package/dist/cjs/ui/system/flex_item/flex_basis.js +5 -11
  123. package/dist/cjs/ui/system/flex_item/flex_grow.js +5 -11
  124. package/dist/cjs/ui/system/flex_item/flex_item_set.js +15 -28
  125. package/dist/cjs/ui/system/flex_item/flex_shrink.js +5 -11
  126. package/dist/cjs/ui/system/flex_item/justify_self.js +5 -11
  127. package/dist/cjs/ui/system/flex_item/order.js +5 -11
  128. package/dist/cjs/ui/system/index.js +310 -362
  129. package/dist/cjs/ui/system/overflow.js +8 -9
  130. package/dist/cjs/ui/system/position/bottom.js +6 -13
  131. package/dist/cjs/ui/system/position/left.js +5 -12
  132. package/dist/cjs/ui/system/position/position.js +5 -11
  133. package/dist/cjs/ui/system/position/position_set.js +15 -27
  134. package/dist/cjs/ui/system/position/right.js +5 -12
  135. package/dist/cjs/ui/system/position/top.js +5 -12
  136. package/dist/cjs/ui/system/position/z_index.js +5 -11
  137. package/dist/cjs/ui/system/spacing/margin.js +5 -12
  138. package/dist/cjs/ui/system/spacing/padding.js +5 -12
  139. package/dist/cjs/ui/system/spacing/spacing_set.js +15 -23
  140. package/dist/cjs/ui/system/typography/font_family.js +5 -11
  141. package/dist/cjs/ui/system/typography/font_size.js +5 -11
  142. package/dist/cjs/ui/system/typography/font_style.js +5 -11
  143. package/dist/cjs/ui/system/typography/font_weight.js +5 -11
  144. package/dist/cjs/ui/system/typography/letter_spacing.js +5 -11
  145. package/dist/cjs/ui/system/typography/line_height.js +5 -11
  146. package/dist/cjs/ui/system/typography/text_align.js +5 -11
  147. package/dist/cjs/ui/system/typography/text_color.js +5 -11
  148. package/dist/cjs/ui/system/typography/text_decoration.js +5 -11
  149. package/dist/cjs/ui/system/typography/text_transform.js +5 -11
  150. package/dist/cjs/ui/system/typography/typography_set.js +15 -31
  151. package/dist/cjs/ui/system/utils/create_responsive_prop_type.js +2 -4
  152. package/dist/cjs/ui/system/utils/create_style_prop_types.js +5 -13
  153. package/dist/cjs/ui/system/utils/ensure_numbers_are_within_scale.js +4 -14
  154. package/dist/cjs/ui/system/utils/get_style_props_for_responsive_prop.js +30 -70
  155. package/dist/cjs/ui/table_picker.js +26 -43
  156. package/dist/cjs/ui/table_picker_synced.js +33 -42
  157. package/dist/cjs/ui/text.js +59 -71
  158. package/dist/cjs/ui/text_button.js +80 -97
  159. package/dist/cjs/ui/theme/default_theme/button_variants.js +1 -5
  160. package/dist/cjs/ui/theme/default_theme/control_sizes.js +29 -42
  161. package/dist/cjs/ui/theme/default_theme/heading_styles.js +4 -5
  162. package/dist/cjs/ui/theme/default_theme/index.js +15 -32
  163. package/dist/cjs/ui/theme/default_theme/input_variants.js +1 -5
  164. package/dist/cjs/ui/theme/default_theme/link_variants.js +1 -5
  165. package/dist/cjs/ui/theme/default_theme/select_buttons_variants.js +1 -5
  166. package/dist/cjs/ui/theme/default_theme/select_variants.js +10 -21
  167. package/dist/cjs/ui/theme/default_theme/switch_variants.js +8 -20
  168. package/dist/cjs/ui/theme/default_theme/text_button_variants.js +1 -5
  169. package/dist/cjs/ui/theme/default_theme/text_styles.js +1 -2
  170. package/dist/cjs/ui/theme/default_theme/tokens.js +33 -35
  171. package/dist/cjs/ui/theme/theme_context.js +3 -6
  172. package/dist/cjs/ui/theme/use_theme.js +1 -7
  173. package/dist/cjs/ui/tooltip.js +38 -79
  174. package/dist/cjs/ui/types/aria_props.js +3 -7
  175. package/dist/cjs/ui/types/data_attributes_prop.js +8 -6
  176. package/dist/cjs/ui/types/tooltip_anchor_props.js +4 -5
  177. package/dist/cjs/ui/ui.js +97 -130
  178. package/dist/cjs/ui/unstable_standalone_ui.js +18 -42
  179. package/dist/cjs/ui/use_array_identity.js +0 -4
  180. package/dist/cjs/ui/use_base.js +4 -13
  181. package/dist/cjs/ui/use_color_scheme.js +60 -0
  182. package/dist/cjs/ui/use_cursor.js +3 -12
  183. package/dist/cjs/ui/use_form_field.js +4 -6
  184. package/dist/cjs/ui/use_global_config.js +3 -10
  185. package/dist/cjs/ui/use_loadable.js +59 -132
  186. package/dist/cjs/ui/use_record_action_data.js +6 -12
  187. package/dist/cjs/ui/use_records.js +27 -28
  188. package/dist/cjs/ui/use_session.js +6 -15
  189. package/dist/cjs/ui/use_settings_button.js +4 -11
  190. package/dist/cjs/ui/use_styled_system.js +12 -21
  191. package/dist/cjs/ui/use_synced.js +0 -7
  192. package/dist/cjs/ui/use_text_color_for_background_color.js +1 -5
  193. package/dist/cjs/ui/use_view_metadata.js +5 -8
  194. package/dist/cjs/ui/use_viewport.js +1 -7
  195. package/dist/cjs/ui/use_watchable.js +36 -74
  196. package/dist/cjs/ui/view_picker.js +44 -78
  197. package/dist/cjs/ui/view_picker_synced.js +33 -44
  198. package/dist/cjs/ui/viewport_constraint.js +37 -64
  199. package/dist/cjs/ui/with_hooks.js +17 -22
  200. package/dist/cjs/ui/with_styled_system.js +33 -60
  201. package/dist/cjs/undo_redo.js +12 -32
  202. package/dist/cjs/unstable_private_utils.js +6 -8
  203. package/dist/cjs/unstable_testing_utils.js +44 -57
  204. package/dist/cjs/viewport.js +127 -189
  205. package/dist/cjs/warning.js +5 -6
  206. package/dist/cjs/watchable.js +66 -148
  207. package/dist/types/src/colors.d.ts +1 -1
  208. package/dist/types/src/colors.d.ts.map +1 -1
  209. package/dist/types/src/global_config.d.ts +1 -1
  210. package/dist/types/src/global_config.d.ts.map +1 -1
  211. package/dist/types/src/models/base.d.ts +1 -1
  212. package/dist/types/src/models/base.d.ts.map +1 -1
  213. package/dist/types/src/models/cursor.d.ts +1 -1
  214. package/dist/types/src/models/cursor.d.ts.map +1 -1
  215. package/dist/types/src/models/field.d.ts +1 -1
  216. package/dist/types/src/models/field.d.ts.map +1 -1
  217. package/dist/types/src/models/linked_records_query_result.d.ts.map +1 -1
  218. package/dist/types/src/models/models.d.ts.map +1 -1
  219. package/dist/types/src/models/record.d.ts +1 -1
  220. package/dist/types/src/models/record.d.ts.map +1 -1
  221. package/dist/types/src/models/record_coloring.d.ts +2 -2
  222. package/dist/types/src/models/record_coloring.d.ts.map +1 -1
  223. package/dist/types/src/models/record_query_result.d.ts +3 -3
  224. package/dist/types/src/models/record_query_result.d.ts.map +1 -1
  225. package/dist/types/src/models/session.d.ts +1 -1
  226. package/dist/types/src/models/session.d.ts.map +1 -1
  227. package/dist/types/src/models/table.d.ts +1 -1
  228. package/dist/types/src/models/table.d.ts.map +1 -1
  229. package/dist/types/src/models/view.d.ts +1 -1
  230. package/dist/types/src/models/view.d.ts.map +1 -1
  231. package/dist/types/src/models/view_metadata_query_result.d.ts +2 -2
  232. package/dist/types/src/models/view_metadata_query_result.d.ts.map +1 -1
  233. package/dist/types/src/perform_record_action.d.ts +1 -1
  234. package/dist/types/src/perform_record_action.d.ts.map +1 -1
  235. package/dist/types/src/private_utils.d.ts +8 -8
  236. package/dist/types/src/private_utils.d.ts.map +1 -1
  237. package/dist/types/src/sdk.d.ts +1 -1
  238. package/dist/types/src/sdk.d.ts.map +1 -1
  239. package/dist/types/src/settings_button.d.ts +1 -1
  240. package/dist/types/src/settings_button.d.ts.map +1 -1
  241. package/dist/types/src/types/aggregators.d.ts +1 -1
  242. package/dist/types/src/types/aggregators.d.ts.map +1 -1
  243. package/dist/types/src/types/airtable_interface.d.ts +6 -6
  244. package/dist/types/src/types/airtable_interface.d.ts.map +1 -1
  245. package/dist/types/src/types/attachment.d.ts +1 -1
  246. package/dist/types/src/types/attachment.d.ts.map +1 -1
  247. package/dist/types/src/types/base.d.ts +1 -1
  248. package/dist/types/src/types/base.d.ts.map +1 -1
  249. package/dist/types/src/types/block.d.ts +1 -1
  250. package/dist/types/src/types/block.d.ts.map +1 -1
  251. package/dist/types/src/types/collaborator.d.ts +1 -1
  252. package/dist/types/src/types/collaborator.d.ts.map +1 -1
  253. package/dist/types/src/types/field.d.ts +5 -5
  254. package/dist/types/src/types/field.d.ts.map +1 -1
  255. package/dist/types/src/types/global_config.d.ts +6 -6
  256. package/dist/types/src/types/global_config.d.ts.map +1 -1
  257. package/dist/types/src/types/mutations.d.ts +4 -4
  258. package/dist/types/src/types/mutations.d.ts.map +1 -1
  259. package/dist/types/src/types/permission_levels.d.ts +1 -1
  260. package/dist/types/src/types/permission_levels.d.ts.map +1 -1
  261. package/dist/types/src/types/record.d.ts +2 -2
  262. package/dist/types/src/types/record.d.ts.map +1 -1
  263. package/dist/types/src/types/record_action_data.d.ts +1 -1
  264. package/dist/types/src/types/record_action_data.d.ts.map +1 -1
  265. package/dist/types/src/types/table.d.ts +3 -3
  266. package/dist/types/src/types/table.d.ts.map +1 -1
  267. package/dist/types/src/types/undo_redo.d.ts +1 -1
  268. package/dist/types/src/types/undo_redo.d.ts.map +1 -1
  269. package/dist/types/src/types/view.d.ts +4 -4
  270. package/dist/types/src/types/view.d.ts.map +1 -1
  271. package/dist/types/src/ui/base_provider.d.ts +1 -1
  272. package/dist/types/src/ui/base_provider.d.ts.map +1 -1
  273. package/dist/types/src/ui/block_wrapper.d.ts +2 -2
  274. package/dist/types/src/ui/button.d.ts +2 -2
  275. package/dist/types/src/ui/button.d.ts.map +1 -1
  276. package/dist/types/src/ui/cell_renderer.d.ts +2 -2
  277. package/dist/types/src/ui/choice_token.d.ts +4 -4
  278. package/dist/types/src/ui/choice_token.d.ts.map +1 -1
  279. package/dist/types/src/ui/collaborator_token.d.ts +6 -6
  280. package/dist/types/src/ui/collaborator_token.d.ts.map +1 -1
  281. package/dist/types/src/ui/color_palette.d.ts +3 -3
  282. package/dist/types/src/ui/color_palette.d.ts.map +1 -1
  283. package/dist/types/src/ui/color_palette_synced.d.ts +2 -2
  284. package/dist/types/src/ui/confirmation_dialog.d.ts +1 -1
  285. package/dist/types/src/ui/control_sizes.d.ts +2 -2
  286. package/dist/types/src/ui/control_sizes.d.ts.map +1 -1
  287. package/dist/types/src/ui/dialog.d.ts +2 -2
  288. package/dist/types/src/ui/dialog.d.ts.map +1 -1
  289. package/dist/types/src/ui/dialog_close_button.d.ts +1 -1
  290. package/dist/types/src/ui/field_icon.d.ts +3 -3
  291. package/dist/types/src/ui/field_icon.d.ts.map +1 -1
  292. package/dist/types/src/ui/field_picker.d.ts +2 -2
  293. package/dist/types/src/ui/field_picker.d.ts.map +1 -1
  294. package/dist/types/src/ui/form_field.d.ts +1 -1
  295. package/dist/types/src/ui/form_field.d.ts.map +1 -1
  296. package/dist/types/src/ui/global_alert.d.ts +1 -1
  297. package/dist/types/src/ui/global_alert.d.ts.map +1 -1
  298. package/dist/types/src/ui/global_config_synced_component_helpers.d.ts +1 -1
  299. package/dist/types/src/ui/global_config_synced_component_helpers.d.ts.map +1 -1
  300. package/dist/types/src/ui/heading.d.ts +4 -4
  301. package/dist/types/src/ui/heading.d.ts.map +1 -1
  302. package/dist/types/src/ui/icon.d.ts +2 -2
  303. package/dist/types/src/ui/icon.d.ts.map +1 -1
  304. package/dist/types/src/ui/icon_config.d.ts +39 -39
  305. package/dist/types/src/ui/icon_config.d.ts.map +1 -1
  306. package/dist/types/src/ui/initialize_block.d.ts +3 -3
  307. package/dist/types/src/ui/initialize_block.d.ts.map +1 -1
  308. package/dist/types/src/ui/input.d.ts +16 -16
  309. package/dist/types/src/ui/input.d.ts.map +1 -1
  310. package/dist/types/src/ui/label.d.ts +1 -1
  311. package/dist/types/src/ui/label.d.ts.map +1 -1
  312. package/dist/types/src/ui/link.d.ts +2 -2
  313. package/dist/types/src/ui/link.d.ts.map +1 -1
  314. package/dist/types/src/ui/loader.d.ts +2 -2
  315. package/dist/types/src/ui/loader.d.ts.map +1 -1
  316. package/dist/types/src/ui/model_picker_select.d.ts +1 -1
  317. package/dist/types/src/ui/model_picker_select.d.ts.map +1 -1
  318. package/dist/types/src/ui/popover.d.ts +5 -5
  319. package/dist/types/src/ui/popover.d.ts.map +1 -1
  320. package/dist/types/src/ui/progress_bar.d.ts +2 -2
  321. package/dist/types/src/ui/progress_bar.d.ts.map +1 -1
  322. package/dist/types/src/ui/record_card.d.ts +3 -3
  323. package/dist/types/src/ui/record_card.d.ts.map +1 -1
  324. package/dist/types/src/ui/record_card_list.d.ts +3 -3
  325. package/dist/types/src/ui/record_card_list.d.ts.map +1 -1
  326. package/dist/types/src/ui/select.d.ts +4 -4
  327. package/dist/types/src/ui/select_and_select_buttons_helpers.d.ts +4 -4
  328. package/dist/types/src/ui/select_and_select_buttons_helpers.d.ts.map +1 -1
  329. package/dist/types/src/ui/select_buttons.d.ts +5 -5
  330. package/dist/types/src/ui/select_buttons.d.ts.map +1 -1
  331. package/dist/types/src/ui/switch.d.ts +2 -2
  332. package/dist/types/src/ui/switch.d.ts.map +1 -1
  333. package/dist/types/src/ui/synced.d.ts +3 -3
  334. package/dist/types/src/ui/system/all_styles_set.d.ts +0 -1
  335. package/dist/types/src/ui/system/all_styles_set.d.ts.map +1 -1
  336. package/dist/types/src/ui/system/appearance/appearance_set.d.ts +0 -1
  337. package/dist/types/src/ui/system/appearance/appearance_set.d.ts.map +1 -1
  338. package/dist/types/src/ui/system/appearance/background_color.d.ts +0 -1
  339. package/dist/types/src/ui/system/appearance/background_color.d.ts.map +1 -1
  340. package/dist/types/src/ui/system/appearance/border.d.ts +0 -1
  341. package/dist/types/src/ui/system/appearance/border.d.ts.map +1 -1
  342. package/dist/types/src/ui/system/appearance/border_radius.d.ts +0 -1
  343. package/dist/types/src/ui/system/appearance/border_radius.d.ts.map +1 -1
  344. package/dist/types/src/ui/system/appearance/box_shadow.d.ts +0 -1
  345. package/dist/types/src/ui/system/appearance/box_shadow.d.ts.map +1 -1
  346. package/dist/types/src/ui/system/appearance/opacity.d.ts +0 -1
  347. package/dist/types/src/ui/system/appearance/opacity.d.ts.map +1 -1
  348. package/dist/types/src/ui/system/dimensions/dimensions_set.d.ts +0 -1
  349. package/dist/types/src/ui/system/dimensions/dimensions_set.d.ts.map +1 -1
  350. package/dist/types/src/ui/system/dimensions/height.d.ts +0 -1
  351. package/dist/types/src/ui/system/dimensions/height.d.ts.map +1 -1
  352. package/dist/types/src/ui/system/dimensions/max_height.d.ts +0 -1
  353. package/dist/types/src/ui/system/dimensions/max_height.d.ts.map +1 -1
  354. package/dist/types/src/ui/system/dimensions/max_width.d.ts +0 -1
  355. package/dist/types/src/ui/system/dimensions/max_width.d.ts.map +1 -1
  356. package/dist/types/src/ui/system/dimensions/min_height.d.ts +0 -1
  357. package/dist/types/src/ui/system/dimensions/min_height.d.ts.map +1 -1
  358. package/dist/types/src/ui/system/dimensions/min_width.d.ts +0 -1
  359. package/dist/types/src/ui/system/dimensions/min_width.d.ts.map +1 -1
  360. package/dist/types/src/ui/system/dimensions/width.d.ts +0 -1
  361. package/dist/types/src/ui/system/dimensions/width.d.ts.map +1 -1
  362. package/dist/types/src/ui/system/display.d.ts +0 -1
  363. package/dist/types/src/ui/system/display.d.ts.map +1 -1
  364. package/dist/types/src/ui/system/flex_container/align_content.d.ts +0 -1
  365. package/dist/types/src/ui/system/flex_container/align_content.d.ts.map +1 -1
  366. package/dist/types/src/ui/system/flex_container/align_items.d.ts +0 -1
  367. package/dist/types/src/ui/system/flex_container/align_items.d.ts.map +1 -1
  368. package/dist/types/src/ui/system/flex_container/flex_container_set.d.ts +0 -1
  369. package/dist/types/src/ui/system/flex_container/flex_container_set.d.ts.map +1 -1
  370. package/dist/types/src/ui/system/flex_container/flex_direction.d.ts +0 -1
  371. package/dist/types/src/ui/system/flex_container/flex_direction.d.ts.map +1 -1
  372. package/dist/types/src/ui/system/flex_container/flex_wrap.d.ts +0 -1
  373. package/dist/types/src/ui/system/flex_container/flex_wrap.d.ts.map +1 -1
  374. package/dist/types/src/ui/system/flex_container/justify_content.d.ts +0 -1
  375. package/dist/types/src/ui/system/flex_container/justify_content.d.ts.map +1 -1
  376. package/dist/types/src/ui/system/flex_container/justify_items.d.ts +0 -1
  377. package/dist/types/src/ui/system/flex_container/justify_items.d.ts.map +1 -1
  378. package/dist/types/src/ui/system/flex_item/align_self.d.ts +0 -1
  379. package/dist/types/src/ui/system/flex_item/align_self.d.ts.map +1 -1
  380. package/dist/types/src/ui/system/flex_item/flex.d.ts +0 -1
  381. package/dist/types/src/ui/system/flex_item/flex.d.ts.map +1 -1
  382. package/dist/types/src/ui/system/flex_item/flex_basis.d.ts +0 -1
  383. package/dist/types/src/ui/system/flex_item/flex_basis.d.ts.map +1 -1
  384. package/dist/types/src/ui/system/flex_item/flex_grow.d.ts +0 -1
  385. package/dist/types/src/ui/system/flex_item/flex_grow.d.ts.map +1 -1
  386. package/dist/types/src/ui/system/flex_item/flex_item_set.d.ts +0 -1
  387. package/dist/types/src/ui/system/flex_item/flex_item_set.d.ts.map +1 -1
  388. package/dist/types/src/ui/system/flex_item/flex_shrink.d.ts +0 -1
  389. package/dist/types/src/ui/system/flex_item/flex_shrink.d.ts.map +1 -1
  390. package/dist/types/src/ui/system/flex_item/justify_self.d.ts +0 -1
  391. package/dist/types/src/ui/system/flex_item/justify_self.d.ts.map +1 -1
  392. package/dist/types/src/ui/system/flex_item/order.d.ts +0 -1
  393. package/dist/types/src/ui/system/flex_item/order.d.ts.map +1 -1
  394. package/dist/types/src/ui/system/overflow.d.ts +0 -1
  395. package/dist/types/src/ui/system/overflow.d.ts.map +1 -1
  396. package/dist/types/src/ui/system/position/bottom.d.ts +0 -1
  397. package/dist/types/src/ui/system/position/bottom.d.ts.map +1 -1
  398. package/dist/types/src/ui/system/position/left.d.ts +0 -1
  399. package/dist/types/src/ui/system/position/left.d.ts.map +1 -1
  400. package/dist/types/src/ui/system/position/position.d.ts +0 -1
  401. package/dist/types/src/ui/system/position/position.d.ts.map +1 -1
  402. package/dist/types/src/ui/system/position/position_set.d.ts +0 -1
  403. package/dist/types/src/ui/system/position/position_set.d.ts.map +1 -1
  404. package/dist/types/src/ui/system/position/right.d.ts +0 -1
  405. package/dist/types/src/ui/system/position/right.d.ts.map +1 -1
  406. package/dist/types/src/ui/system/position/top.d.ts +0 -1
  407. package/dist/types/src/ui/system/position/top.d.ts.map +1 -1
  408. package/dist/types/src/ui/system/position/z_index.d.ts +0 -1
  409. package/dist/types/src/ui/system/position/z_index.d.ts.map +1 -1
  410. package/dist/types/src/ui/system/spacing/margin.d.ts +0 -1
  411. package/dist/types/src/ui/system/spacing/margin.d.ts.map +1 -1
  412. package/dist/types/src/ui/system/spacing/padding.d.ts +0 -1
  413. package/dist/types/src/ui/system/spacing/padding.d.ts.map +1 -1
  414. package/dist/types/src/ui/system/spacing/spacing_set.d.ts +0 -1
  415. package/dist/types/src/ui/system/spacing/spacing_set.d.ts.map +1 -1
  416. package/dist/types/src/ui/system/typography/font_family.d.ts +0 -1
  417. package/dist/types/src/ui/system/typography/font_family.d.ts.map +1 -1
  418. package/dist/types/src/ui/system/typography/font_size.d.ts +0 -1
  419. package/dist/types/src/ui/system/typography/font_size.d.ts.map +1 -1
  420. package/dist/types/src/ui/system/typography/font_style.d.ts +0 -1
  421. package/dist/types/src/ui/system/typography/font_style.d.ts.map +1 -1
  422. package/dist/types/src/ui/system/typography/font_weight.d.ts +0 -1
  423. package/dist/types/src/ui/system/typography/font_weight.d.ts.map +1 -1
  424. package/dist/types/src/ui/system/typography/letter_spacing.d.ts +0 -1
  425. package/dist/types/src/ui/system/typography/letter_spacing.d.ts.map +1 -1
  426. package/dist/types/src/ui/system/typography/line_height.d.ts +0 -1
  427. package/dist/types/src/ui/system/typography/line_height.d.ts.map +1 -1
  428. package/dist/types/src/ui/system/typography/text_align.d.ts +0 -1
  429. package/dist/types/src/ui/system/typography/text_align.d.ts.map +1 -1
  430. package/dist/types/src/ui/system/typography/text_color.d.ts +0 -1
  431. package/dist/types/src/ui/system/typography/text_color.d.ts.map +1 -1
  432. package/dist/types/src/ui/system/typography/text_decoration.d.ts +0 -1
  433. package/dist/types/src/ui/system/typography/text_decoration.d.ts.map +1 -1
  434. package/dist/types/src/ui/system/typography/text_transform.d.ts +0 -1
  435. package/dist/types/src/ui/system/typography/text_transform.d.ts.map +1 -1
  436. package/dist/types/src/ui/system/typography/typography_set.d.ts +0 -1
  437. package/dist/types/src/ui/system/typography/typography_set.d.ts.map +1 -1
  438. package/dist/types/src/ui/system/utils/create_style_prop_types.d.ts +1 -1
  439. package/dist/types/src/ui/system/utils/create_style_prop_types.d.ts.map +1 -1
  440. package/dist/types/src/ui/system/utils/csstype.d.ts +578 -578
  441. package/dist/types/src/ui/system/utils/csstype.d.ts.map +1 -1
  442. package/dist/types/src/ui/system/utils/types.d.ts +4 -4
  443. package/dist/types/src/ui/system/utils/types.d.ts.map +1 -1
  444. package/dist/types/src/ui/table_picker.d.ts +1 -1
  445. package/dist/types/src/ui/table_picker.d.ts.map +1 -1
  446. package/dist/types/src/ui/text.d.ts +4 -4
  447. package/dist/types/src/ui/text.d.ts.map +1 -1
  448. package/dist/types/src/ui/text_button.d.ts +2 -2
  449. package/dist/types/src/ui/text_button.d.ts.map +1 -1
  450. package/dist/types/src/ui/theme/default_theme/heading_styles.d.ts +2 -2
  451. package/dist/types/src/ui/theme/default_theme/heading_styles.d.ts.map +1 -1
  452. package/dist/types/src/ui/theme/default_theme/index.d.ts +1 -1
  453. package/dist/types/src/ui/theme/theme_context.d.ts +1 -3
  454. package/dist/types/src/ui/theme/theme_context.d.ts.map +1 -1
  455. package/dist/types/src/ui/theme/use_theme.d.ts +1 -1
  456. package/dist/types/src/ui/tooltip.d.ts +3 -3
  457. package/dist/types/src/ui/types/data_attributes_prop.d.ts.map +1 -1
  458. package/dist/types/src/ui/types/tooltip_anchor_props.d.ts +0 -1
  459. package/dist/types/src/ui/types/tooltip_anchor_props.d.ts.map +1 -1
  460. package/dist/types/src/ui/ui.d.ts +1 -0
  461. package/dist/types/src/ui/ui.d.ts.map +1 -1
  462. package/dist/types/src/ui/use_base.d.ts.map +1 -1
  463. package/dist/types/src/ui/use_color_scheme.d.ts +28 -0
  464. package/dist/types/src/ui/use_color_scheme.d.ts.map +1 -0
  465. package/dist/types/src/ui/use_cursor.d.ts.map +1 -1
  466. package/dist/types/src/ui/use_form_field.d.ts +0 -2
  467. package/dist/types/src/ui/use_form_field.d.ts.map +1 -1
  468. package/dist/types/src/ui/use_records.d.ts +2 -2
  469. package/dist/types/src/ui/use_records.d.ts.map +1 -1
  470. package/dist/types/src/ui/use_session.d.ts.map +1 -1
  471. package/dist/types/src/ui/view_picker.d.ts +3 -3
  472. package/dist/types/src/ui/view_picker.d.ts.map +1 -1
  473. package/dist/types/src/ui/viewport_constraint.d.ts +3 -3
  474. package/dist/types/src/ui/viewport_constraint.d.ts.map +1 -1
  475. package/dist/types/src/viewport.d.ts +2 -2
  476. package/dist/types/src/viewport.d.ts.map +1 -1
  477. package/dist/types/src/warning.d.ts +1 -1
  478. package/dist/types/src/warning.d.ts.map +1 -1
  479. package/package.json +40 -34
  480. package/dist/types/stories/all_controls.stories.d.ts +0 -2
  481. package/dist/types/stories/all_controls.stories.d.ts.map +0 -1
  482. package/dist/types/stories/box.appearance.stories.d.ts +0 -2
  483. package/dist/types/stories/box.appearance.stories.d.ts.map +0 -1
  484. package/dist/types/stories/box.dimensions.stories.d.ts +0 -2
  485. package/dist/types/stories/box.dimensions.stories.d.ts.map +0 -1
  486. package/dist/types/stories/box.flex_container.stories.d.ts +0 -2
  487. package/dist/types/stories/box.flex_container.stories.d.ts.map +0 -1
  488. package/dist/types/stories/box.flex_item.stories.d.ts +0 -2
  489. package/dist/types/stories/box.flex_item.stories.d.ts.map +0 -1
  490. package/dist/types/stories/box.position.stories.d.ts +0 -2
  491. package/dist/types/stories/box.position.stories.d.ts.map +0 -1
  492. package/dist/types/stories/box.spacing.stories.d.ts +0 -2
  493. package/dist/types/stories/box.spacing.stories.d.ts.map +0 -1
  494. package/dist/types/stories/box.stories.d.ts +0 -2
  495. package/dist/types/stories/box.stories.d.ts.map +0 -1
  496. package/dist/types/stories/box.typography.stories.d.ts +0 -2
  497. package/dist/types/stories/box.typography.stories.d.ts.map +0 -1
  498. package/dist/types/stories/button.stories.d.ts +0 -2
  499. package/dist/types/stories/button.stories.d.ts.map +0 -1
  500. package/dist/types/stories/cell_renderer.stories.d.ts +0 -2
  501. package/dist/types/stories/cell_renderer.stories.d.ts.map +0 -1
  502. package/dist/types/stories/choice_token.stories.d.ts +0 -2
  503. package/dist/types/stories/choice_token.stories.d.ts.map +0 -1
  504. package/dist/types/stories/collaborator_token.stories.d.ts +0 -2
  505. package/dist/types/stories/collaborator_token.stories.d.ts.map +0 -1
  506. package/dist/types/stories/color_palette.stories.d.ts +0 -2
  507. package/dist/types/stories/color_palette.stories.d.ts.map +0 -1
  508. package/dist/types/stories/confirmation_dialog.stories.d.ts +0 -2
  509. package/dist/types/stories/confirmation_dialog.stories.d.ts.map +0 -1
  510. package/dist/types/stories/dialog.stories.d.ts +0 -2
  511. package/dist/types/stories/dialog.stories.d.ts.map +0 -1
  512. package/dist/types/stories/field_icon.stories.d.ts +0 -2
  513. package/dist/types/stories/field_icon.stories.d.ts.map +0 -1
  514. package/dist/types/stories/form_field.stories.d.ts +0 -2
  515. package/dist/types/stories/form_field.stories.d.ts.map +0 -1
  516. package/dist/types/stories/heading.size.stories.d.ts +0 -2
  517. package/dist/types/stories/heading.size.stories.d.ts.map +0 -1
  518. package/dist/types/stories/heading.stories.d.ts +0 -2
  519. package/dist/types/stories/heading.stories.d.ts.map +0 -1
  520. package/dist/types/stories/helpers/attachments.d.ts +0 -4
  521. package/dist/types/stories/helpers/attachments.d.ts.map +0 -1
  522. package/dist/types/stories/helpers/categorize_style_props.d.ts +0 -14
  523. package/dist/types/stories/helpers/categorize_style_props.d.ts.map +0 -1
  524. package/dist/types/stories/helpers/choice_options.d.ts +0 -7
  525. package/dist/types/stories/helpers/choice_options.d.ts.map +0 -1
  526. package/dist/types/stories/helpers/code_block.d.ts +0 -5
  527. package/dist/types/stories/helpers/code_block.d.ts.map +0 -1
  528. package/dist/types/stories/helpers/code_utils.d.ts +0 -32
  529. package/dist/types/stories/helpers/code_utils.d.ts.map +0 -1
  530. package/dist/types/stories/helpers/collaborator_options.d.ts +0 -7
  531. package/dist/types/stories/helpers/collaborator_options.d.ts.map +0 -1
  532. package/dist/types/stories/helpers/example.d.ts +0 -39
  533. package/dist/types/stories/helpers/example.d.ts.map +0 -1
  534. package/dist/types/stories/helpers/example_code_panel.d.ts +0 -10
  535. package/dist/types/stories/helpers/example_code_panel.d.ts.map +0 -1
  536. package/dist/types/stories/helpers/fake_cell_renderer.d.ts +0 -7
  537. package/dist/types/stories/helpers/fake_cell_renderer.d.ts.map +0 -1
  538. package/dist/types/stories/helpers/fake_foreign_record.d.ts +0 -5
  539. package/dist/types/stories/helpers/fake_foreign_record.d.ts.map +0 -1
  540. package/dist/types/stories/helpers/fake_record_card.d.ts +0 -13
  541. package/dist/types/stories/helpers/fake_record_card.d.ts.map +0 -1
  542. package/dist/types/stories/helpers/field_type.d.ts +0 -6
  543. package/dist/types/stories/helpers/field_type.d.ts.map +0 -1
  544. package/dist/types/stories/helpers/raf_throttle.d.ts +0 -5
  545. package/dist/types/stories/helpers/raf_throttle.d.ts.map +0 -1
  546. package/dist/types/stories/helpers/style_prop_list.d.ts +0 -9
  547. package/dist/types/stories/helpers/style_prop_list.d.ts.map +0 -1
  548. package/dist/types/stories/helpers/sync_source_options.d.ts +0 -7
  549. package/dist/types/stories/helpers/sync_source_options.d.ts.map +0 -1
  550. package/dist/types/stories/helpers/use_resizable_panel.d.ts +0 -27
  551. package/dist/types/stories/helpers/use_resizable_panel.d.ts.map +0 -1
  552. package/dist/types/stories/icon.stories.d.ts +0 -2
  553. package/dist/types/stories/icon.stories.d.ts.map +0 -1
  554. package/dist/types/stories/icon_example.d.ts +0 -3
  555. package/dist/types/stories/icon_example.d.ts.map +0 -1
  556. package/dist/types/stories/input.stories.d.ts +0 -2
  557. package/dist/types/stories/input.stories.d.ts.map +0 -1
  558. package/dist/types/stories/label.stories.d.ts +0 -2
  559. package/dist/types/stories/label.stories.d.ts.map +0 -1
  560. package/dist/types/stories/link.stories.d.ts +0 -2
  561. package/dist/types/stories/link.stories.d.ts.map +0 -1
  562. package/dist/types/stories/loader.stories.d.ts +0 -2
  563. package/dist/types/stories/loader.stories.d.ts.map +0 -1
  564. package/dist/types/stories/model_pickers.stories.d.ts +0 -2
  565. package/dist/types/stories/model_pickers.stories.d.ts.map +0 -1
  566. package/dist/types/stories/progress_bar.stories.d.ts +0 -2
  567. package/dist/types/stories/progress_bar.stories.d.ts.map +0 -1
  568. package/dist/types/stories/record_card.stories.d.ts +0 -2
  569. package/dist/types/stories/record_card.stories.d.ts.map +0 -1
  570. package/dist/types/stories/record_card_list.stories.d.ts +0 -2
  571. package/dist/types/stories/record_card_list.stories.d.ts.map +0 -1
  572. package/dist/types/stories/select.stories.d.ts +0 -2
  573. package/dist/types/stories/select.stories.d.ts.map +0 -1
  574. package/dist/types/stories/select_buttons.stories.d.ts +0 -2
  575. package/dist/types/stories/select_buttons.stories.d.ts.map +0 -1
  576. package/dist/types/stories/switch.stories.d.ts +0 -2
  577. package/dist/types/stories/switch.stories.d.ts.map +0 -1
  578. package/dist/types/stories/text.size.stories.d.ts +0 -2
  579. package/dist/types/stories/text.size.stories.d.ts.map +0 -1
  580. package/dist/types/stories/text.stories.d.ts +0 -2
  581. package/dist/types/stories/text.stories.d.ts.map +0 -1
  582. package/dist/types/stories/text_button.stories.d.ts +0 -2
  583. package/dist/types/stories/text_button.stories.d.ts.map +0 -1
  584. package/dist/types/stories/tooltip.stories.d.ts +0 -2
  585. package/dist/types/stories/tooltip.stories.d.ts.map +0 -1
  586. package/dist/types/test/airtable_interface_mocks/fixture_data.d.ts +0 -124
  587. package/dist/types/test/airtable_interface_mocks/fixture_data.d.ts.map +0 -1
  588. package/dist/types/test/airtable_interface_mocks/linked_records.d.ts +0 -4
  589. package/dist/types/test/airtable_interface_mocks/linked_records.d.ts.map +0 -1
  590. package/dist/types/test/airtable_interface_mocks/mock_airtable_interface.d.ts +0 -61
  591. package/dist/types/test/airtable_interface_mocks/mock_airtable_interface.d.ts.map +0 -1
  592. package/dist/types/test/airtable_interface_mocks/project_tracker.d.ts +0 -4
  593. package/dist/types/test/airtable_interface_mocks/project_tracker.d.ts.map +0 -1
  594. package/dist/types/test/error_utils.test.d.ts +0 -2
  595. package/dist/types/test/error_utils.test.d.ts.map +0 -1
  596. package/dist/types/test/get_style_props_for_responsive_prop.test.d.ts +0 -2
  597. package/dist/types/test/get_style_props_for_responsive_prop.test.d.ts.map +0 -1
  598. package/dist/types/test/index.test.d.ts +0 -2
  599. package/dist/types/test/index.test.d.ts.map +0 -1
  600. package/dist/types/test/models/base.test.d.ts +0 -2
  601. package/dist/types/test/models/base.test.d.ts.map +0 -1
  602. package/dist/types/test/models/cursor.test.d.ts +0 -2
  603. package/dist/types/test/models/cursor.test.d.ts.map +0 -1
  604. package/dist/types/test/models/field.test.d.ts +0 -2
  605. package/dist/types/test/models/field.test.d.ts.map +0 -1
  606. package/dist/types/test/models/linked_records_query_result.test.d.ts +0 -2
  607. package/dist/types/test/models/linked_records_query_result.test.d.ts.map +0 -1
  608. package/dist/types/test/models/mutations.test.d.ts +0 -2
  609. package/dist/types/test/models/mutations.test.d.ts.map +0 -1
  610. package/dist/types/test/models/object_pool.test.d.ts +0 -2
  611. package/dist/types/test/models/object_pool.test.d.ts.map +0 -1
  612. package/dist/types/test/models/record.test.d.ts +0 -2
  613. package/dist/types/test/models/record.test.d.ts.map +0 -1
  614. package/dist/types/test/models/session.test.d.ts +0 -2
  615. package/dist/types/test/models/session.test.d.ts.map +0 -1
  616. package/dist/types/test/models/table.test.d.ts +0 -2
  617. package/dist/types/test/models/table.test.d.ts.map +0 -1
  618. package/dist/types/test/models/table_mutations.test.d.ts +0 -2
  619. package/dist/types/test/models/table_mutations.test.d.ts.map +0 -1
  620. package/dist/types/test/models/table_or_view_query_result.test.d.ts +0 -2
  621. package/dist/types/test/models/table_or_view_query_result.test.d.ts.map +0 -1
  622. package/dist/types/test/models/view.test.d.ts +0 -2
  623. package/dist/types/test/models/view.test.d.ts.map +0 -1
  624. package/dist/types/test/models/view_metadata_query_result.test.d.ts +0 -2
  625. package/dist/types/test/models/view_metadata_query_result.test.d.ts.map +0 -1
  626. package/dist/types/test/private_utils.test.d.ts +0 -2
  627. package/dist/types/test/private_utils.test.d.ts.map +0 -1
  628. package/dist/types/test/sdk.test.d.ts +0 -2
  629. package/dist/types/test/sdk.test.d.ts.map +0 -1
  630. package/dist/types/test/setup_enzyme.d.ts +0 -2
  631. package/dist/types/test/setup_enzyme.d.ts.map +0 -1
  632. package/dist/types/test/test_helpers.d.ts +0 -11
  633. package/dist/types/test/test_helpers.d.ts.map +0 -1
  634. package/dist/types/test/ui/base_provider.test.d.ts +0 -2
  635. package/dist/types/test/ui/base_provider.test.d.ts.map +0 -1
  636. package/dist/types/test/ui/block_wrapper.test.d.ts +0 -2
  637. package/dist/types/test/ui/block_wrapper.test.d.ts.map +0 -1
  638. package/dist/types/test/ui/box.test.d.ts +0 -2
  639. package/dist/types/test/ui/box.test.d.ts.map +0 -1
  640. package/dist/types/test/ui/button.test.d.ts +0 -2
  641. package/dist/types/test/ui/button.test.d.ts.map +0 -1
  642. package/dist/types/test/ui/cell_renderer.test.d.ts +0 -2
  643. package/dist/types/test/ui/cell_renderer.test.d.ts.map +0 -1
  644. package/dist/types/test/ui/choice_token.test.d.ts +0 -2
  645. package/dist/types/test/ui/choice_token.test.d.ts.map +0 -1
  646. package/dist/types/test/ui/collaborator_token.test.d.ts +0 -2
  647. package/dist/types/test/ui/collaborator_token.test.d.ts.map +0 -1
  648. package/dist/types/test/ui/color_palette.test.d.ts +0 -2
  649. package/dist/types/test/ui/color_palette.test.d.ts.map +0 -1
  650. package/dist/types/test/ui/color_palette_synced.test.d.ts +0 -2
  651. package/dist/types/test/ui/color_palette_synced.test.d.ts.map +0 -1
  652. package/dist/types/test/ui/confirmation_dialog.test.d.ts +0 -2
  653. package/dist/types/test/ui/confirmation_dialog.test.d.ts.map +0 -1
  654. package/dist/types/test/ui/dialog.test.d.ts +0 -2
  655. package/dist/types/test/ui/dialog.test.d.ts.map +0 -1
  656. package/dist/types/test/ui/expand_record.test.d.ts +0 -2
  657. package/dist/types/test/ui/expand_record.test.d.ts.map +0 -1
  658. package/dist/types/test/ui/expand_record_list.test.d.ts +0 -2
  659. package/dist/types/test/ui/expand_record_list.test.d.ts.map +0 -1
  660. package/dist/types/test/ui/expand_record_picker_async.test.d.ts +0 -2
  661. package/dist/types/test/ui/expand_record_picker_async.test.d.ts.map +0 -1
  662. package/dist/types/test/ui/field_icon.test.d.ts +0 -2
  663. package/dist/types/test/ui/field_icon.test.d.ts.map +0 -1
  664. package/dist/types/test/ui/field_picker.test.d.ts +0 -2
  665. package/dist/types/test/ui/field_picker.test.d.ts.map +0 -1
  666. package/dist/types/test/ui/field_picker_synced.test.d.ts +0 -2
  667. package/dist/types/test/ui/field_picker_synced.test.d.ts.map +0 -1
  668. package/dist/types/test/ui/form_field.test.d.ts +0 -2
  669. package/dist/types/test/ui/form_field.test.d.ts.map +0 -1
  670. package/dist/types/test/ui/global_alert.test.d.ts +0 -2
  671. package/dist/types/test/ui/global_alert.test.d.ts.map +0 -1
  672. package/dist/types/test/ui/heading.test.d.ts +0 -2
  673. package/dist/types/test/ui/heading.test.d.ts.map +0 -1
  674. package/dist/types/test/ui/icon.test.d.ts +0 -2
  675. package/dist/types/test/ui/icon.test.d.ts.map +0 -1
  676. package/dist/types/test/ui/initialize_block.test.d.ts +0 -2
  677. package/dist/types/test/ui/initialize_block.test.d.ts.map +0 -1
  678. package/dist/types/test/ui/input.test.d.ts +0 -2
  679. package/dist/types/test/ui/input.test.d.ts.map +0 -1
  680. package/dist/types/test/ui/input_synced.test.d.ts +0 -2
  681. package/dist/types/test/ui/input_synced.test.d.ts.map +0 -1
  682. package/dist/types/test/ui/label.test.d.ts +0 -2
  683. package/dist/types/test/ui/label.test.d.ts.map +0 -1
  684. package/dist/types/test/ui/link.test.d.ts +0 -2
  685. package/dist/types/test/ui/link.test.d.ts.map +0 -1
  686. package/dist/types/test/ui/loader.test.d.ts +0 -2
  687. package/dist/types/test/ui/loader.test.d.ts.map +0 -1
  688. package/dist/types/test/ui/modal.test.d.ts +0 -2
  689. package/dist/types/test/ui/modal.test.d.ts.map +0 -1
  690. package/dist/types/test/ui/popover.test.d.ts +0 -2
  691. package/dist/types/test/ui/popover.test.d.ts.map +0 -1
  692. package/dist/types/test/ui/progress_bar.test.d.ts +0 -2
  693. package/dist/types/test/ui/progress_bar.test.d.ts.map +0 -1
  694. package/dist/types/test/ui/record_card.test.d.ts +0 -2
  695. package/dist/types/test/ui/record_card.test.d.ts.map +0 -1
  696. package/dist/types/test/ui/record_card_list.test.d.ts +0 -2
  697. package/dist/types/test/ui/record_card_list.test.d.ts.map +0 -1
  698. package/dist/types/test/ui/remote_utils.test.d.ts +0 -2
  699. package/dist/types/test/ui/remote_utils.test.d.ts.map +0 -1
  700. package/dist/types/test/ui/select.test.d.ts +0 -2
  701. package/dist/types/test/ui/select.test.d.ts.map +0 -1
  702. package/dist/types/test/ui/select_buttons.test.d.ts +0 -2
  703. package/dist/types/test/ui/select_buttons.test.d.ts.map +0 -1
  704. package/dist/types/test/ui/select_buttons_synced.test.d.ts +0 -2
  705. package/dist/types/test/ui/select_buttons_synced.test.d.ts.map +0 -1
  706. package/dist/types/test/ui/select_synced.test.d.ts +0 -2
  707. package/dist/types/test/ui/select_synced.test.d.ts.map +0 -1
  708. package/dist/types/test/ui/switch.test.d.ts +0 -2
  709. package/dist/types/test/ui/switch.test.d.ts.map +0 -1
  710. package/dist/types/test/ui/switch_synced.test.d.ts +0 -2
  711. package/dist/types/test/ui/switch_synced.test.d.ts.map +0 -1
  712. package/dist/types/test/ui/synced.test.d.ts +0 -2
  713. package/dist/types/test/ui/synced.test.d.ts.map +0 -1
  714. package/dist/types/test/ui/table_picker.test.d.ts +0 -2
  715. package/dist/types/test/ui/table_picker.test.d.ts.map +0 -1
  716. package/dist/types/test/ui/table_picker_synced.test.d.ts +0 -2
  717. package/dist/types/test/ui/table_picker_synced.test.d.ts.map +0 -1
  718. package/dist/types/test/ui/text.test.d.ts +0 -2
  719. package/dist/types/test/ui/text.test.d.ts.map +0 -1
  720. package/dist/types/test/ui/text_button.test.d.ts +0 -2
  721. package/dist/types/test/ui/text_button.test.d.ts.map +0 -1
  722. package/dist/types/test/ui/tooltip.test.d.ts +0 -2
  723. package/dist/types/test/ui/tooltip.test.d.ts.map +0 -1
  724. package/dist/types/test/ui/ui.test.d.ts +0 -2
  725. package/dist/types/test/ui/ui.test.d.ts.map +0 -1
  726. package/dist/types/test/ui/unstable_standalone_ui.test.d.ts +0 -1
  727. package/dist/types/test/ui/unstable_standalone_ui.test.d.ts.map +0 -1
  728. package/dist/types/test/ui/use_array_identity.test.d.ts +0 -2
  729. package/dist/types/test/ui/use_array_identity.test.d.ts.map +0 -1
  730. package/dist/types/test/ui/use_loadable.test.d.ts +0 -2
  731. package/dist/types/test/ui/use_loadable.test.d.ts.map +0 -1
  732. package/dist/types/test/ui/use_record_action_data.test.d.ts +0 -2
  733. package/dist/types/test/ui/use_record_action_data.test.d.ts.map +0 -1
  734. package/dist/types/test/ui/use_records.test.d.ts +0 -2
  735. package/dist/types/test/ui/use_records.test.d.ts.map +0 -1
  736. package/dist/types/test/ui/use_view_metadata.test.d.ts +0 -2
  737. package/dist/types/test/ui/use_view_metadata.test.d.ts.map +0 -1
  738. package/dist/types/test/ui/use_watchable.test.d.ts +0 -2
  739. package/dist/types/test/ui/use_watchable.test.d.ts.map +0 -1
  740. package/dist/types/test/ui/view_picker.test.d.ts +0 -2
  741. package/dist/types/test/ui/view_picker.test.d.ts.map +0 -1
  742. package/dist/types/test/ui/view_picker_synced.test.d.ts +0 -2
  743. package/dist/types/test/ui/view_picker_synced.test.d.ts.map +0 -1
  744. package/dist/types/test/ui/viewport_constraint.test.d.ts +0 -2
  745. package/dist/types/test/ui/viewport_constraint.test.d.ts.map +0 -1
  746. package/dist/types/test/unstable_private_utils.test.d.ts +0 -1
  747. package/dist/types/test/unstable_private_utils.test.d.ts.map +0 -1
@@ -1,74 +1,50 @@
1
1
  "use strict";
2
2
 
3
+ require("core-js/modules/es.symbol.js");
4
+ require("core-js/modules/es.symbol.description.js");
5
+ require("core-js/modules/es.array.from.js");
6
+ require("core-js/modules/es.regexp.exec.js");
7
+ require("core-js/modules/es.regexp.to-string.js");
3
8
  var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
-
5
- require("core-js/modules/es.symbol");
6
-
7
- require("core-js/modules/es.symbol.description");
8
-
9
- require("core-js/modules/es.array.concat");
10
-
11
- require("core-js/modules/es.array.filter");
12
-
13
- require("core-js/modules/es.array.iterator");
14
-
15
- require("core-js/modules/es.array.map");
16
-
17
- require("core-js/modules/es.array.slice");
18
-
19
- require("core-js/modules/es.object.to-string");
20
-
21
- require("core-js/modules/es.promise");
22
-
23
- require("core-js/modules/es.string.starts-with");
24
-
25
- require("core-js/modules/web.dom-collections.iterator");
26
-
27
9
  Object.defineProperty(exports, "__esModule", {
28
10
  value: true
29
11
  });
30
- exports.default = exports.getLinkedTableId = void 0;
31
-
12
+ exports.getLinkedTableId = exports.default = void 0;
32
13
  var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator"));
33
-
34
- require("regenerator-runtime/runtime");
35
-
14
+ require("core-js/modules/es.array.concat.js");
15
+ require("core-js/modules/es.array.filter.js");
16
+ require("core-js/modules/es.array.iterator.js");
17
+ require("core-js/modules/es.array.map.js");
18
+ require("core-js/modules/es.array.slice.js");
19
+ require("core-js/modules/es.object.to-string.js");
20
+ require("core-js/modules/es.promise.js");
21
+ require("core-js/modules/es.string.starts-with.js");
22
+ require("core-js/modules/web.dom-collections.iterator.js");
23
+ var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator"));
36
24
  var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
37
-
38
25
  var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));
39
-
40
26
  var _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime/helpers/possibleConstructorReturn"));
41
-
42
- var _assertThisInitialized2 = _interopRequireDefault(require("@babel/runtime/helpers/assertThisInitialized"));
43
-
44
- var _getPrototypeOf2 = _interopRequireDefault(require("@babel/runtime/helpers/getPrototypeOf"));
45
-
46
27
  var _get2 = _interopRequireDefault(require("@babel/runtime/helpers/get"));
47
-
28
+ var _getPrototypeOf2 = _interopRequireDefault(require("@babel/runtime/helpers/getPrototypeOf"));
48
29
  var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits"));
49
-
50
30
  var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
51
-
52
31
  var _field = require("../types/field");
53
-
54
32
  var _error_utils = require("../error_utils");
55
-
56
33
  var _record_query_result = _interopRequireDefault(require("./record_query_result"));
57
-
58
- /** @module @airtable/blocks/models: RecordQueryResult */
59
-
60
- /** */
34
+ function _createForOfIteratorHelper(r, e) { var t = "undefined" != typeof Symbol && r[Symbol.iterator] || r["@@iterator"]; if (!t) { if (Array.isArray(r) || (t = _unsupportedIterableToArray(r)) || e && r && "number" == typeof r.length) { t && (r = t); var _n = 0, F = function F() {}; return { s: F, n: function n() { return _n >= r.length ? { done: !0 } : { done: !1, value: r[_n++] }; }, e: function e(r) { throw r; }, f: F }; } throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } var o, a = !0, u = !1; return { s: function s() { t = t.call(r); }, n: function n() { var r = t.next(); return a = r.done, r; }, e: function e(r) { u = !0, o = r; }, f: function f() { try { a || null == t.return || t.return(); } finally { if (u) throw o; } } }; }
35
+ function _unsupportedIterableToArray(r, a) { if (r) { if ("string" == typeof r) return _arrayLikeToArray(r, a); var t = {}.toString.call(r).slice(8, -1); return "Object" === t && r.constructor && (t = r.constructor.name), "Map" === t || "Set" === t ? Array.from(r) : "Arguments" === t || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t) ? _arrayLikeToArray(r, a) : void 0; } }
36
+ function _arrayLikeToArray(r, a) { (null == a || a > r.length) && (a = r.length); for (var e = 0, n = Array(a); e < a; e++) n[e] = r[e]; return n; }
37
+ function _callSuper(t, o, e) { return o = (0, _getPrototypeOf2.default)(o), (0, _possibleConstructorReturn2.default)(t, _isNativeReflectConstruct() ? Reflect.construct(o, e || [], (0, _getPrototypeOf2.default)(t).constructor) : o.apply(t, e)); }
38
+ function _isNativeReflectConstruct() { try { var t = !Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); } catch (t) {} return (_isNativeReflectConstruct = function _isNativeReflectConstruct() { return !!t; })(); } /** @module @airtable/blocks/models: RecordQueryResult */ /** */
61
39
  var getLinkedTableId = field => {
62
40
  var options = field.options;
63
41
  var linkedTableId = options && options.linkedTableId;
64
42
  (0, _error_utils.invariant)(typeof linkedTableId === 'string', 'linkedTableId must exist');
65
43
  return linkedTableId;
66
44
  };
67
- /** internal */
68
-
69
45
 
46
+ /** internal */
70
47
  exports.getLinkedTableId = getLinkedTableId;
71
-
72
48
  /**
73
49
  * Represents a set of records from a LinkedRecord cell value. See {@link RecordQueryResult} for main
74
50
  * documentation.
@@ -78,75 +54,60 @@ exports.getLinkedTableId = getLinkedTableId;
78
54
  *
79
55
  * @docsPath models/query results/LinkedRecordsQueryResult
80
56
  */
81
- var LinkedRecordsQueryResult =
82
- /*#__PURE__*/
83
- function (_RecordQueryResult) {
84
- (0, _inherits2.default)(LinkedRecordsQueryResult, _RecordQueryResult);
85
-
86
- /** @internal */
87
- // the record containing the linked-record cell this is a query of.
88
-
89
- /** @internal */
90
- // the cell's field in the record
91
-
92
- /** @internal */
93
- // the table we're linking to
94
-
95
- /** @internal */
96
- // the records store for the origin table
97
-
98
- /** @internal */
99
- // the records store for the linked table
100
-
101
- /** @internal */
102
- // a RecordQueryResult containing all the rows in the linked table
103
-
104
- /** @internal */
105
- // is the query result currently valid. if the field config changes to link
106
- // to another table or not be a linked record field at all, isValid will
107
- // become false. once a LinkedRecordsQueryResult has become invalid, it will
108
- // not become valid again.
109
-
110
- /** @internal */
111
- // a lazily-generated set of the record ids in the result set.
112
-
113
- /** @internal */
114
- // a lazily-generated array of the record ids in the query result.
115
-
116
- /** @internal */
117
- // how many times has each 'cellValuesInField:$FieldId' been watched?
118
-
119
- /** @internal */
120
-
57
+ var LinkedRecordsQueryResult = /*#__PURE__*/function (_RecordQueryResult) {
121
58
  /** @internal */
122
59
  function LinkedRecordsQueryResult(record, field, normalizedOpts, sdk) {
123
60
  var _this;
124
-
125
61
  (0, _classCallCheck2.default)(this, LinkedRecordsQueryResult);
126
- _this = (0, _possibleConstructorReturn2.default)(this, (0, _getPrototypeOf2.default)(LinkedRecordsQueryResult).call(this, sdk, normalizedOpts));
127
- (0, _defineProperty2.default)((0, _assertThisInitialized2.default)(_this), "_record", void 0);
128
- (0, _defineProperty2.default)((0, _assertThisInitialized2.default)(_this), "_field", void 0);
129
- (0, _defineProperty2.default)((0, _assertThisInitialized2.default)(_this), "_linkedTable", void 0);
130
- (0, _defineProperty2.default)((0, _assertThisInitialized2.default)(_this), "_originRecordStore", void 0);
131
- (0, _defineProperty2.default)((0, _assertThisInitialized2.default)(_this), "_linkedRecordStore", void 0);
132
- (0, _defineProperty2.default)((0, _assertThisInitialized2.default)(_this), "_linkedQueryResult", void 0);
133
- (0, _defineProperty2.default)((0, _assertThisInitialized2.default)(_this), "_isValid", true);
134
- (0, _defineProperty2.default)((0, _assertThisInitialized2.default)(_this), "_computedRecordIdsSet", null);
135
- (0, _defineProperty2.default)((0, _assertThisInitialized2.default)(_this), "_computedFilteredSortedRecordIds", null);
136
- (0, _defineProperty2.default)((0, _assertThisInitialized2.default)(_this), "_cellValueChangeHandlerByFieldId", {});
62
+ _this = _callSuper(this, LinkedRecordsQueryResult, [sdk, normalizedOpts]);
63
+ // the record containing the linked-record cell this is a query of.
64
+ /** @internal */
65
+ (0, _defineProperty2.default)(_this, "_record", void 0);
66
+ // the cell's field in the record
67
+ /** @internal */
68
+ (0, _defineProperty2.default)(_this, "_field", void 0);
69
+ // the table we're linking to
70
+ /** @internal */
71
+ (0, _defineProperty2.default)(_this, "_linkedTable", void 0);
72
+ // the records store for the origin table
73
+ /** @internal */
74
+ (0, _defineProperty2.default)(_this, "_originRecordStore", void 0);
75
+ // the records store for the linked table
76
+ /** @internal */
77
+ (0, _defineProperty2.default)(_this, "_linkedRecordStore", void 0);
78
+ // a RecordQueryResult containing all the rows in the linked table
79
+ /** @internal */
80
+ (0, _defineProperty2.default)(_this, "_linkedQueryResult", void 0);
81
+ // is the query result currently valid. if the field config changes to link
82
+ // to another table or not be a linked record field at all, isValid will
83
+ // become false. once a LinkedRecordsQueryResult has become invalid, it will
84
+ // not become valid again.
85
+ /** @internal */
86
+ (0, _defineProperty2.default)(_this, "_isValid", true);
87
+ // a lazily-generated set of the record ids in the result set.
88
+ /** @internal */
89
+ (0, _defineProperty2.default)(_this, "_computedRecordIdsSet", null);
90
+ // a lazily-generated array of the record ids in the query result.
91
+ /** @internal */
92
+ (0, _defineProperty2.default)(_this, "_computedFilteredSortedRecordIds", null);
93
+ // how many times has each 'cellValuesInField:$FieldId' been watched?
94
+ /** @internal */
95
+ (0, _defineProperty2.default)(_this, "_cellValueChangeHandlerByFieldId", {});
137
96
  (0, _error_utils.invariant)(record.parentTable === field.parentTable, 'record and field must belong to the same table');
138
97
  _this._record = record;
139
98
  _this._field = field;
140
99
  _this._linkedTable = normalizedOpts.table;
141
100
  _this._originRecordStore = _this._sdk.base.__getRecordStore(_this._record.parentTable.id);
142
- _this._linkedRecordStore = normalizedOpts.recordStore; // we could rely on RecordQueryResult's reuse pool to make sure we get back
101
+ _this._linkedRecordStore = normalizedOpts.recordStore;
102
+
103
+ // we could rely on RecordQueryResult's reuse pool to make sure we get back
143
104
  // the same RecordQueryResult every time, but that would make it much harder
144
105
  // to make sure we unwatch everything from the old RecordQueryResult if e.g.
145
106
  // the field config changes to point at a different table
146
-
147
107
  _this._linkedQueryResult = _this._linkedTable.__tableOrViewQueryResultPool.getObjectForReuse(_this._sdk, _this._linkedTable, normalizedOpts);
148
108
  return _this;
149
109
  }
110
+
150
111
  /**
151
112
  * Is the query result currently valid? This value always starts as 'true',
152
113
  * but can become false if the record from which this result was created is
@@ -156,213 +117,196 @@ function (_RecordQueryResult) {
156
117
  * will never become true again. Many fields will throw on attempting to
157
118
  * access them, and watches will no longer fire.
158
119
  */
120
+ (0, _inherits2.default)(LinkedRecordsQueryResult, _RecordQueryResult);
121
+ return (0, _createClass2.default)(LinkedRecordsQueryResult, [{
122
+ key: "isValid",
123
+ get: function get() {
124
+ return this._isValid;
125
+ }
126
+
127
+ /**
128
+ * The table that records in this RecordQueryResult are part of
129
+ *
130
+ * @internal (since we may not be able to return parent model instances in the immutable models world)
131
+ */
132
+ }, {
133
+ key: "parentTable",
134
+ get: function get() {
135
+ (0, _error_utils.invariant)(this.isValid, 'LinkedRecordsQueryResult is no longer valid');
136
+ return this._linkedTable;
137
+ }
159
138
 
139
+ /**
140
+ * Ordered array of all the linked record ids. Watchable.
141
+ */
142
+ }, {
143
+ key: "recordIds",
144
+ get: function get() {
145
+ (0, _error_utils.invariant)(this.isValid, 'LinkedRecordsQueryResult is no longer valid');
146
+ (0, _error_utils.invariant)(this.isDataLoaded, 'LinkedRecordsQueryResult data is not loaded');
160
147
 
161
- (0, _createClass2.default)(LinkedRecordsQueryResult, [{
162
- key: "watch",
148
+ // record ids are lazily generated
149
+ this._generateComputedDataIfNeeded();
150
+ (0, _error_utils.invariant)(this._computedFilteredSortedRecordIds, 'no recordIds');
151
+ return this._computedFilteredSortedRecordIds;
152
+ }
153
+
154
+ /**
155
+ * Ordered array of all the linked records. Watchable.
156
+ */
157
+ }, {
158
+ key: "records",
159
+ get: function get() {
160
+ (0, _error_utils.invariant)(this.isValid, 'LinkedRecordsQueryResult is no longer valid');
161
+ return this.recordIds.map(recordId => {
162
+ var record = this._linkedRecordStore.getRecordByIdIfExists(recordId);
163
+ (0, _error_utils.invariant)(record, 'No record for id: %s', recordId);
164
+ return record;
165
+ });
166
+ }
167
+
168
+ /**
169
+ * The fields that were used to create this LinkedRecordsQueryResult.
170
+ */
171
+ }, {
172
+ key: "fields",
173
+ get: function get() {
174
+ (0, _error_utils.invariant)(this.isValid, 'LinkedRecordsQueryResult is no longer valid');
175
+ return this._linkedQueryResult.fields;
176
+ }
163
177
 
164
178
  /** @inheritdoc */
179
+ }, {
180
+ key: "watch",
165
181
  value: function watch(keys, callback, context) {
166
182
  (0, _error_utils.invariant)(this.isValid, 'cannot watch an invalid LinkedRecordsQueryResult');
167
183
  var validKeys = (0, _get2.default)((0, _getPrototypeOf2.default)(LinkedRecordsQueryResult.prototype), "watch", this).call(this, keys, callback, context);
168
- var _iteratorNormalCompletion = true;
169
- var _didIteratorError = false;
170
- var _iteratorError = undefined;
171
-
184
+ var _iterator = _createForOfIteratorHelper(validKeys),
185
+ _step;
172
186
  try {
173
- for (var _iterator = validKeys[Symbol.iterator](), _step; !(_iteratorNormalCompletion = (_step = _iterator.next()).done); _iteratorNormalCompletion = true) {
174
- var _key = _step.value;
175
-
176
- if (_key === _record_query_result.default.WatchableKeys.cellValues) {
187
+ for (_iterator.s(); !(_step = _iterator.n()).done;) {
188
+ var key = _step.value;
189
+ if (key === _record_query_result.default.WatchableKeys.cellValues) {
177
190
  this._watchLinkedQueryCellValuesIfNeededAfterWatch();
178
191
  }
179
-
180
- if (_key.startsWith(_record_query_result.default.WatchableCellValuesInFieldKeyPrefix)) {
181
- var fieldId = _key.substring(_record_query_result.default.WatchableCellValuesInFieldKeyPrefix.length);
182
-
192
+ if (key.startsWith(_record_query_result.default.WatchableCellValuesInFieldKeyPrefix)) {
193
+ var fieldId = key.substring(_record_query_result.default.WatchableCellValuesInFieldKeyPrefix.length);
183
194
  this._watchLinkedQueryCellValuesInFieldIfNeededAfterWatch(fieldId);
184
195
  }
185
196
  }
186
197
  } catch (err) {
187
- _didIteratorError = true;
188
- _iteratorError = err;
198
+ _iterator.e(err);
189
199
  } finally {
190
- try {
191
- if (!_iteratorNormalCompletion && _iterator.return != null) {
192
- _iterator.return();
193
- }
194
- } finally {
195
- if (_didIteratorError) {
196
- throw _iteratorError;
197
- }
198
- }
200
+ _iterator.f();
199
201
  }
200
-
201
202
  return validKeys;
202
203
  }
203
- /** @inheritdoc */
204
204
 
205
+ /** @inheritdoc */
205
206
  }, {
206
207
  key: "unwatch",
207
208
  value: function unwatch(keys, callback, context) {
208
209
  var arrayKeys = Array.isArray(keys) ? keys : [keys];
209
- var _iteratorNormalCompletion2 = true;
210
- var _didIteratorError2 = false;
211
- var _iteratorError2 = undefined;
212
-
210
+ var _iterator2 = _createForOfIteratorHelper(arrayKeys),
211
+ _step2;
213
212
  try {
214
- for (var _iterator2 = arrayKeys[Symbol.iterator](), _step2; !(_iteratorNormalCompletion2 = (_step2 = _iterator2.next()).done); _iteratorNormalCompletion2 = true) {
215
- var _key2 = _step2.value;
216
-
217
- if (_key2 === _record_query_result.default.WatchableKeys.cellValues) {
213
+ for (_iterator2.s(); !(_step2 = _iterator2.n()).done;) {
214
+ var key = _step2.value;
215
+ if (key === _record_query_result.default.WatchableKeys.cellValues) {
218
216
  this._unwatchLinkedQueryCellValuesIfPossibleBeforeUnwatch();
219
217
  }
220
-
221
- if (_key2.startsWith(_record_query_result.default.WatchableCellValuesInFieldKeyPrefix)) {
222
- var fieldId = _key2.substring(_record_query_result.default.WatchableCellValuesInFieldKeyPrefix.length);
223
-
218
+ if (key.startsWith(_record_query_result.default.WatchableCellValuesInFieldKeyPrefix)) {
219
+ var fieldId = key.substring(_record_query_result.default.WatchableCellValuesInFieldKeyPrefix.length);
224
220
  this._unwatchLinkedQueryCellValuesInFieldIfPossibleBeforeUnwatch(fieldId);
225
221
  }
226
222
  }
227
223
  } catch (err) {
228
- _didIteratorError2 = true;
229
- _iteratorError2 = err;
224
+ _iterator2.e(err);
230
225
  } finally {
231
- try {
232
- if (!_iteratorNormalCompletion2 && _iterator2.return != null) {
233
- _iterator2.return();
234
- }
235
- } finally {
236
- if (_didIteratorError2) {
237
- throw _iteratorError2;
238
- }
239
- }
226
+ _iterator2.f();
240
227
  }
241
-
242
228
  return (0, _get2.default)((0, _getPrototypeOf2.default)(LinkedRecordsQueryResult.prototype), "unwatch", this).call(this, arrayKeys, callback, context);
243
229
  }
244
- /** @inheritdoc */
245
230
 
231
+ /** @inheritdoc */
246
232
  }, {
247
233
  key: "loadDataAsync",
248
- value: function loadDataAsync() {
249
- return _regenerator.default.async(function loadDataAsync$(_context) {
250
- while (1) {
251
- switch (_context.prev = _context.next) {
234
+ value: (function () {
235
+ var _loadDataAsync2 = (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee() {
236
+ return _regenerator.default.wrap(function _callee$(_context) {
237
+ while (1) switch (_context.prev = _context.next) {
252
238
  case 0:
253
239
  _context.next = 2;
254
- return _regenerator.default.awrap((0, _get2.default)((0, _getPrototypeOf2.default)(LinkedRecordsQueryResult.prototype), "loadDataAsync", this).call(this));
255
-
240
+ return (0, _get2.default)((0, _getPrototypeOf2.default)(LinkedRecordsQueryResult.prototype), "loadDataAsync", this).call(this);
256
241
  case 2:
257
242
  if (this.isDataLoaded) {
258
243
  _context.next = 6;
259
244
  break;
260
245
  }
261
-
262
246
  _context.next = 5;
263
- return _regenerator.default.awrap(this.loadDataAsync());
264
-
247
+ return this.loadDataAsync();
265
248
  case 5:
266
249
  // there has to be an unloadData call for every loadDataAsync call.
267
250
  // call it here to offset calling loadDataAsync a second time
268
251
  this.unloadData();
269
-
270
252
  case 6:
271
253
  case "end":
272
254
  return _context.stop();
273
255
  }
274
- }
275
- }, null, this);
276
- }
277
- /** @internal */
278
-
256
+ }, _callee, this);
257
+ }));
258
+ function loadDataAsync() {
259
+ return _loadDataAsync2.apply(this, arguments);
260
+ }
261
+ return loadDataAsync;
262
+ }() /** @internal */)
279
263
  }, {
280
264
  key: "_loadDataAsync",
281
- value: function _loadDataAsync() {
282
- var initiallyLoaded, changedKeys, fieldIds, _iteratorNormalCompletion3, _didIteratorError3, _iteratorError3, _iterator3, _step3, fieldId;
283
-
284
- return _regenerator.default.async(function _loadDataAsync$(_context2) {
285
- while (1) {
286
- switch (_context2.prev = _context2.next) {
265
+ value: (function () {
266
+ var _loadDataAsync3 = (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee2() {
267
+ var initiallyLoaded, changedKeys, fieldIds, _iterator3, _step3, fieldId;
268
+ return _regenerator.default.wrap(function _callee2$(_context2) {
269
+ while (1) switch (_context2.prev = _context2.next) {
287
270
  case 0:
288
271
  this._record.__linkedRecordsQueryResultPool.registerObjectForReuseStrong(this);
289
-
290
272
  this._watchOrigin();
291
-
292
273
  this._watchLinkedQueryResult();
293
-
294
274
  initiallyLoaded = this._linkedQueryResult.isDataLoaded;
295
275
  _context2.next = 6;
296
- return _regenerator.default.awrap(Promise.all([this._sdk.base.__getRecordStore(this._record.parentTable.id).loadCellValuesInFieldIdsAsync([this._field.id]), this._linkedQueryResult.loadDataAsync(), this._loadRecordColorsAsync()]));
297
-
276
+ return Promise.all([this._sdk.base.__getRecordStore(this._record.parentTable.id).loadCellValuesInFieldIdsAsync([this._field.id]), this._linkedQueryResult.loadDataAsync(), this._loadRecordColorsAsync()]);
298
277
  case 6:
299
278
  this._invalidateComputedData();
300
-
301
279
  changedKeys = ['records', 'recordIds', 'recordColors']; // If the linked query result was not initially loaded, then the
302
280
  // `cellValues` event will be emitted via `_onLinkedCellValuesChange`.
303
281
  // Otherwise, it must be explicitly included here in order to promote
304
282
  // consistency.
305
-
306
283
  if (initiallyLoaded) {
307
284
  changedKeys.push('cellValues');
308
285
  }
309
-
310
286
  fieldIds = this._normalizedOpts.fieldIdsOrNullIfAllFields || this.parentTable.fields.map(field => field.id);
311
- _iteratorNormalCompletion3 = true;
312
- _didIteratorError3 = false;
313
- _iteratorError3 = undefined;
314
- _context2.prev = 13;
315
-
316
- for (_iterator3 = fieldIds[Symbol.iterator](); !(_iteratorNormalCompletion3 = (_step3 = _iterator3.next()).done); _iteratorNormalCompletion3 = true) {
317
- fieldId = _step3.value;
318
- changedKeys.push(_record_query_result.default.WatchableCellValuesInFieldKeyPrefix + fieldId);
319
- }
320
-
321
- _context2.next = 21;
322
- break;
323
-
324
- case 17:
325
- _context2.prev = 17;
326
- _context2.t0 = _context2["catch"](13);
327
- _didIteratorError3 = true;
328
- _iteratorError3 = _context2.t0;
329
-
330
- case 21:
331
- _context2.prev = 21;
332
- _context2.prev = 22;
333
-
334
- if (!_iteratorNormalCompletion3 && _iterator3.return != null) {
335
- _iterator3.return();
336
- }
337
-
338
- case 24:
339
- _context2.prev = 24;
340
-
341
- if (!_didIteratorError3) {
342
- _context2.next = 27;
343
- break;
287
+ _iterator3 = _createForOfIteratorHelper(fieldIds);
288
+ try {
289
+ for (_iterator3.s(); !(_step3 = _iterator3.n()).done;) {
290
+ fieldId = _step3.value;
291
+ changedKeys.push(_record_query_result.default.WatchableCellValuesInFieldKeyPrefix + fieldId);
292
+ }
293
+ } catch (err) {
294
+ _iterator3.e(err);
295
+ } finally {
296
+ _iterator3.f();
344
297
  }
345
-
346
- throw _iteratorError3;
347
-
348
- case 27:
349
- return _context2.finish(24);
350
-
351
- case 28:
352
- return _context2.finish(21);
353
-
354
- case 29:
355
298
  return _context2.abrupt("return", changedKeys);
356
-
357
- case 30:
299
+ case 13:
358
300
  case "end":
359
301
  return _context2.stop();
360
302
  }
361
- }
362
- }, null, this, [[13, 17, 21, 29], [22,, 24, 28]]);
363
- }
364
- /** @internal */
365
-
303
+ }, _callee2, this);
304
+ }));
305
+ function _loadDataAsync() {
306
+ return _loadDataAsync3.apply(this, arguments);
307
+ }
308
+ return _loadDataAsync;
309
+ }() /** @internal */)
366
310
  }, {
367
311
  key: "_unloadData",
368
312
  value: function _unloadData() {
@@ -371,37 +315,43 @@ function (_RecordQueryResult) {
371
315
  // istanbul ignore else
372
316
  if (this.isValid) {
373
317
  this._record.__linkedRecordsQueryResultPool.unregisterObjectForReuseStrong(this);
374
-
375
318
  this._unwatchOrigin();
376
-
377
319
  this._unwatchLinkedQueryResult();
378
-
379
320
  this._originRecordStore.unloadCellValuesInFieldIds([this._field.id]);
380
-
381
321
  this._linkedQueryResult.unloadData();
382
-
383
322
  this._unloadRecordColors();
384
-
385
323
  this._invalidateComputedData();
386
324
  }
387
325
  }
326
+
388
327
  /**
389
328
  * the key used to identify this query result in ObjectPool
390
329
  *
391
330
  * @hidden
392
331
  */
332
+ }, {
333
+ key: "__poolKey",
334
+ get: function get() {
335
+ return "".concat(this._serializedOpts, "::").concat(this._field.id, "::").concat(this._linkedTable.id, "::").concat(this.isValid);
336
+ }
393
337
 
338
+ /** @internal */
394
339
  }, {
395
- key: "_watchLinkedQueryCellValuesIfNeededAfterWatch",
340
+ key: "_cellValuesWatchCount",
341
+ get: function get() {
342
+ return (this._changeWatchersByKey[_record_query_result.default.WatchableKeys.cellValues] || []).length;
343
+ }
396
344
 
397
345
  /** @internal */
346
+ }, {
347
+ key: "_watchLinkedQueryCellValuesIfNeededAfterWatch",
398
348
  value: function _watchLinkedQueryCellValuesIfNeededAfterWatch() {
399
349
  if (this._cellValuesWatchCount === 1) {
400
350
  this._watchLinkedQueryCellValues();
401
351
  }
402
352
  }
403
- /** @internal */
404
353
 
354
+ /** @internal */
405
355
  }, {
406
356
  key: "_unwatchLinkedQueryCellValuesIfPossibleBeforeUnwatch",
407
357
  value: function _unwatchLinkedQueryCellValuesIfPossibleBeforeUnwatch() {
@@ -409,68 +359,81 @@ function (_RecordQueryResult) {
409
359
  this._unwatchLinkedQueryCellValues();
410
360
  }
411
361
  }
412
- /** @internal */
413
362
 
363
+ /** @internal */
414
364
  }, {
415
- key: "_watchLinkedQueryCellValuesInFieldIfNeededAfterWatch",
365
+ key: "_cellValueWatchCountByFieldId",
366
+ get: function get() {
367
+ var countByFieldId = {};
368
+ var watchKeys = Object.keys(this._changeWatchersByKey).filter(key => {
369
+ return key.startsWith(_record_query_result.default.WatchableCellValuesInFieldKeyPrefix);
370
+ });
371
+ var _iterator4 = _createForOfIteratorHelper(watchKeys),
372
+ _step4;
373
+ try {
374
+ for (_iterator4.s(); !(_step4 = _iterator4.n()).done;) {
375
+ var watchKey = _step4.value;
376
+ var fieldId = watchKey.slice(_record_query_result.default.WatchableCellValuesInFieldKeyPrefix.length);
377
+ countByFieldId[fieldId] = this._changeWatchersByKey[watchKey].length;
378
+ }
379
+ } catch (err) {
380
+ _iterator4.e(err);
381
+ } finally {
382
+ _iterator4.f();
383
+ }
384
+ return countByFieldId;
385
+ }
416
386
 
417
387
  /** @internal */
388
+ }, {
389
+ key: "_watchLinkedQueryCellValuesInFieldIfNeededAfterWatch",
418
390
  value: function _watchLinkedQueryCellValuesInFieldIfNeededAfterWatch(fieldId) {
419
391
  if (this._cellValueWatchCountByFieldId[fieldId] === 1 && this.isValid) {
420
392
  this._watchLinkedQueryCellValuesInField(fieldId);
421
393
  }
422
394
  }
423
- /** @internal */
424
395
 
396
+ /** @internal */
425
397
  }, {
426
398
  key: "_unwatchLinkedQueryCellValuesInFieldIfPossibleBeforeUnwatch",
427
399
  value: function _unwatchLinkedQueryCellValuesInFieldIfPossibleBeforeUnwatch(fieldId) {
428
400
  (0, _error_utils.invariant)(this._cellValueWatchCountByFieldId[fieldId], "cellValuesInField:%s over-free'd", fieldId);
429
-
430
401
  if (this._cellValueWatchCountByFieldId[fieldId] === 1 && this.isValid) {
431
402
  this._unwatchLinkedQueryCellValuesInField(fieldId);
432
403
  }
433
404
  }
434
- /** @internal */
435
405
 
406
+ /** @internal */
436
407
  }, {
437
408
  key: "_watchOrigin",
438
409
  value: function _watchOrigin() {
439
410
  // if the cell values in the record change, we need to invalidate our
440
411
  // cached data and notify watchers
441
- this._record.watch("cellValueInField:".concat(this._field.id), this._onOriginCellValueChange, this); // if the field config changes, we need to invalidate cached data,
412
+ this._record.watch("cellValueInField:".concat(this._field.id), this._onOriginCellValueChange, this);
413
+ // if the field config changes, we need to invalidate cached data,
442
414
  // and potentially start watching a different table
443
-
444
-
445
415
  this._field.watch('type', this._onOriginFieldConfigChange, this);
446
-
447
- this._field.watch('options', this._onOriginFieldConfigChange, this); // if the underlying record is deleted, we need to invalidate this
416
+ this._field.watch('options', this._onOriginFieldConfigChange, this);
417
+ // if the underlying record is deleted, we need to invalidate this
448
418
  // result
449
-
450
-
451
- this._originRecordStore.watch('recordIds', this._onOriginRecordsChange, this); // if the linked field in the origin table is deleted, we need to
419
+ this._originRecordStore.watch('recordIds', this._onOriginRecordsChange, this);
420
+ // if the linked field in the origin table is deleted, we need to
452
421
  // invalidate this result
453
-
454
-
455
422
  this._record.parentTable.watch('fields', this._onOriginFieldsChange, this);
456
423
  }
457
- /** @internal */
458
424
 
425
+ /** @internal */
459
426
  }, {
460
427
  key: "_unwatchOrigin",
461
428
  value: function _unwatchOrigin() {
462
429
  this._record.unwatch("cellValueInField:".concat(this._field.id), this._onOriginCellValueChange, this);
463
-
464
430
  this._field.unwatch('type', this._onOriginFieldConfigChange, this);
465
-
466
431
  this._field.unwatch('options', this._onOriginFieldConfigChange, this);
467
-
468
432
  this._originRecordStore.unwatch('recordIds', this._onOriginRecordsChange, this);
469
-
470
433
  this._record.parentTable.unwatch('fields', this._onOriginFieldsChange, this);
471
434
  }
472
- /** @internal */
473
435
 
436
+ /** @internal */
474
437
  }, {
475
438
  key: "_watchLinkedQueryResult",
476
439
  value: function _watchLinkedQueryResult() {
@@ -480,43 +443,43 @@ function (_RecordQueryResult) {
480
443
  // watching the origin record
481
444
  this._linkedQueryResult.watch('recordIds', this._onLinkedRecordIdsChange, this);
482
445
  }
483
- /** @internal */
484
446
 
447
+ /** @internal */
485
448
  }, {
486
449
  key: "_unwatchLinkedQueryResult",
487
450
  value: function _unwatchLinkedQueryResult() {
488
451
  this._linkedQueryResult.unwatch('recordIds', this._onLinkedRecordIdsChange, this);
489
452
  }
490
- /** @internal */
491
453
 
454
+ /** @internal */
492
455
  }, {
493
456
  key: "_watchLinkedQueryCellValues",
494
457
  value: function _watchLinkedQueryCellValues() {
495
458
  this._linkedQueryResult.watch('cellValues', this._onLinkedCellValuesChange, this);
496
459
  }
497
- /** @internal */
498
460
 
461
+ /** @internal */
499
462
  }, {
500
463
  key: "_unwatchLinkedQueryCellValues",
501
464
  value: function _unwatchLinkedQueryCellValues() {
502
465
  this._linkedQueryResult.unwatch('cellValues', this._onLinkedCellValuesChange, this);
503
466
  }
504
- /** @internal */
505
467
 
468
+ /** @internal */
506
469
  }, {
507
470
  key: "_watchLinkedQueryCellValuesInField",
508
471
  value: function _watchLinkedQueryCellValuesInField(fieldId) {
509
472
  this._linkedQueryResult.watch(_record_query_result.default.WatchableCellValuesInFieldKeyPrefix + fieldId, this._getOnLinkedCellValuesInFieldChange(fieldId), this);
510
473
  }
511
- /** @internal */
512
474
 
475
+ /** @internal */
513
476
  }, {
514
477
  key: "_unwatchLinkedQueryCellValuesInField",
515
478
  value: function _unwatchLinkedQueryCellValuesInField(fieldId) {
516
479
  this._linkedQueryResult.unwatch(_record_query_result.default.WatchableCellValuesInFieldKeyPrefix + fieldId, this._getOnLinkedCellValuesInFieldChange(fieldId), this);
517
480
  }
518
- /** @internal */
519
481
 
482
+ /** @internal */
520
483
  }, {
521
484
  key: "_onLinkedRecordIdsChange",
522
485
  value: function _onLinkedRecordIdsChange() {
@@ -528,17 +491,15 @@ function (_RecordQueryResult) {
528
491
  // records while keeping the behavior of isValid consistent
529
492
  return;
530
493
  }
531
-
532
494
  (0, _error_utils.invariant)(this.isValid, 'watch key change event whilst invalid');
495
+ this._invalidateComputedData();
533
496
 
534
- this._invalidateComputedData(); // we don't actually know at this stage whether anything changed or
497
+ // we don't actually know at this stage whether anything changed or
535
498
  // not. it may have done though, so notify watchers
536
-
537
-
538
499
  this._onChange('records');
539
-
540
500
  this._onChange('recordIds');
541
501
  }
502
+
542
503
  /**
543
504
  * This model doesn't use the `_data` computed property it inherits from
544
505
  * AbstractModel. It implements the following method only so that internal
@@ -547,43 +508,50 @@ function (_RecordQueryResult) {
547
508
  *
548
509
  * @internal
549
510
  */
550
-
551
511
  }, {
552
- key: "_onLinkedCellValuesChange",
512
+ key: "_dataOrNullIfDeleted",
513
+ get: function get() {
514
+ if (this._record.isDeleted || this._linkedRecordStore.isDeleted) {
515
+ return null;
516
+ }
517
+ return {};
518
+ }
553
519
 
554
520
  /** @internal */
521
+ }, {
522
+ key: "_onLinkedCellValuesChange",
555
523
  value: function _onLinkedCellValuesChange(queryResult, key, changes) {
556
524
  (0, _error_utils.invariant)(this.isValid, 'watch key change event whilst invalid');
557
-
558
525
  if (changes && changes.fieldIds && changes.recordIds) {
559
526
  var recordIdsSet = this._getOrGenerateRecordIdsSet();
560
-
561
- var _recordIds = changes.recordIds.filter(id => recordIdsSet[id] === true);
562
-
563
- if (_recordIds.length) {
527
+ var recordIds = changes.recordIds.filter(id => recordIdsSet[id] === true);
528
+ if (recordIds.length) {
564
529
  this._onChange('cellValues', {
565
530
  fieldIds: changes.fieldIds,
566
- recordIds: _recordIds
531
+ recordIds
567
532
  });
568
533
  }
569
534
  } else {
570
535
  this._onChange('cellValues');
571
536
  }
572
537
  }
573
- /** @internal */
574
538
 
539
+ /** @internal */
575
540
  }, {
576
541
  key: "_getOnLinkedCellValuesInFieldChange",
577
542
  value: function _getOnLinkedCellValuesInFieldChange(fieldId) {
578
543
  if (!this._cellValueChangeHandlerByFieldId[fieldId]) {
579
544
  this._cellValueChangeHandlerByFieldId[fieldId] = (queryResult, key, recordIds) => {
580
- (0, _error_utils.invariant)(this.isValid, 'watch key change event whilst invalid'); // The linked record may finish loading before its parent. In
545
+ (0, _error_utils.invariant)(this.isValid, 'watch key change event whilst invalid');
546
+
547
+ // The linked record may finish loading before its parent. In
581
548
  // that case, the appropriate events will be triggered by the
582
549
  // `_loadDataAsync` method.
583
-
584
550
  if (!this.isDataLoaded) {
585
551
  return;
586
- } // The `else` branch will only be reached when the underlying
552
+ }
553
+
554
+ // The `else` branch will only be reached when the underlying
587
555
  // `RecordOrViewQueryResult` is loaded, unloaded, and then
588
556
  // loaded again. Because that query result is not directly
589
557
  // exposed to consumers, the condition can only be met when the
@@ -592,13 +560,9 @@ function (_RecordQueryResult) {
592
560
  // situation in a logical way, but it is not tested because it
593
561
  // is fundamentally invalid.
594
562
  // istanbul ignore else
595
-
596
-
597
563
  if (Array.isArray(recordIds)) {
598
564
  var recordIdsSet = this._getOrGenerateRecordIdsSet();
599
-
600
565
  var filteredRecordIds = recordIds.filter(id => typeof id === 'string' && recordIdsSet[id] === true);
601
-
602
566
  if (filteredRecordIds.length) {
603
567
  this._onChange(_record_query_result.default.WatchableCellValuesInFieldKeyPrefix + fieldId, filteredRecordIds);
604
568
  }
@@ -607,11 +571,10 @@ function (_RecordQueryResult) {
607
571
  }
608
572
  };
609
573
  }
610
-
611
574
  return this._cellValueChangeHandlerByFieldId[fieldId];
612
575
  }
613
- /** @internal */
614
576
 
577
+ /** @internal */
615
578
  }, {
616
579
  key: "_onOriginCellValueChange",
617
580
  value: function _onOriginCellValueChange() {
@@ -623,20 +586,19 @@ function (_RecordQueryResult) {
623
586
  // records while keeping the behavior of isValid consistent
624
587
  return;
625
588
  }
589
+ (0, _error_utils.invariant)(this.isValid, 'watch key change event whilst invalid');
626
590
 
627
- (0, _error_utils.invariant)(this.isValid, 'watch key change event whilst invalid'); // when the origin cell value (listing all the linked records) changes,
591
+ // when the origin cell value (listing all the linked records) changes,
628
592
  // invalidate all the data we have stored - we need to completely
629
593
  // regenerate it
594
+ this._invalidateComputedData();
630
595
 
631
- this._invalidateComputedData(); // notify watchers that our set of linked records has changed
632
-
633
-
596
+ // notify watchers that our set of linked records has changed
634
597
  this._onChange('records');
635
-
636
598
  this._onChange('recordIds');
637
599
  }
638
- /** @internal */
639
600
 
601
+ /** @internal */
640
602
  }, {
641
603
  key: "_onOriginRecordsChange",
642
604
  value: function _onOriginRecordsChange() {
@@ -644,8 +606,8 @@ function (_RecordQueryResult) {
644
606
  this._isValid = false;
645
607
  }
646
608
  }
647
- /** @internal */
648
609
 
610
+ /** @internal */
649
611
  }, {
650
612
  key: "_onOriginFieldsChange",
651
613
  value: function _onOriginFieldsChange() {
@@ -653,63 +615,52 @@ function (_RecordQueryResult) {
653
615
  this._isValid = false;
654
616
  }
655
617
  }
656
- /** @internal */
657
618
 
619
+ /** @internal */
658
620
  }, {
659
621
  key: "_onOriginFieldConfigChange",
660
622
  value: function _onOriginFieldConfigChange() {
661
623
  (0, _error_utils.invariant)(this.isValid, 'watch key change event whilst invalid');
662
624
  var type = this._field.type;
663
-
664
625
  if (type !== _field.FieldType.MULTIPLE_RECORD_LINKS) {
665
626
  this._invalidateQueryResult();
666
-
667
627
  return;
668
628
  }
669
-
670
629
  var linkedTableId = getLinkedTableId(this._field);
671
-
672
630
  if (linkedTableId !== this._linkedTable.id) {
673
631
  this._invalidateQueryResult();
674
-
675
632
  return;
676
633
  }
677
634
  }
678
- /** @internal */
679
635
 
636
+ /** @internal */
680
637
  }, {
681
638
  key: "_invalidateQueryResult",
682
639
  value: function _invalidateQueryResult() {
683
640
  if (this.isDataLoaded) {
684
641
  this._unloadData();
685
642
  }
686
-
687
643
  if (this._cellValuesWatchCount > 0) {
688
644
  this._unwatchLinkedQueryCellValues();
689
645
  }
690
-
691
646
  for (var _i = 0, _Object$keys = Object.keys(this._cellValueWatchCountByFieldId); _i < _Object$keys.length; _i++) {
692
647
  var fieldId = _Object$keys[_i];
693
-
694
648
  this._unwatchLinkedQueryCellValuesInField(fieldId);
695
649
  }
696
-
697
650
  this._isValid = false;
698
-
699
651
  this._onChange('records');
700
-
701
652
  this._onChange('recordIds');
702
653
  }
703
- /** @internal */
704
654
 
655
+ /** @internal */
705
656
  }, {
706
657
  key: "_invalidateComputedData",
707
658
  value: function _invalidateComputedData() {
708
659
  this._computedRecordIdsSet = null;
709
660
  this._computedFilteredSortedRecordIds = null;
710
661
  }
711
- /** @internal */
712
662
 
663
+ /** @internal */
713
664
  }, {
714
665
  key: "_generateComputedDataIfNeeded",
715
666
  value: function _generateComputedDataIfNeeded() {
@@ -717,52 +668,38 @@ function (_RecordQueryResult) {
717
668
  this._generateComputedData();
718
669
  }
719
670
  }
720
- /** @internal */
721
671
 
672
+ /** @internal */
722
673
  }, {
723
674
  key: "_generateComputedData",
724
675
  value: function _generateComputedData() {
725
676
  var recordIdsSet = {};
726
-
727
677
  var rawCellValue = this._record.getCellValue(this._field);
728
-
729
678
  var cellValue = rawCellValue === null ? [] : rawCellValue;
730
679
  (0, _error_utils.invariant)(Array.isArray(cellValue), 'cellValue should be array');
731
- var _iteratorNormalCompletion4 = true;
732
- var _didIteratorError4 = false;
733
- var _iteratorError4 = undefined;
734
-
680
+ var _iterator5 = _createForOfIteratorHelper(cellValue),
681
+ _step5;
735
682
  try {
736
- for (var _iterator4 = cellValue[Symbol.iterator](), _step4; !(_iteratorNormalCompletion4 = (_step4 = _iterator4.next()).done); _iteratorNormalCompletion4 = true) {
737
- var linkedRecord = _step4.value;
683
+ for (_iterator5.s(); !(_step5 = _iterator5.n()).done;) {
684
+ var linkedRecord = _step5.value;
738
685
  (0, _error_utils.invariant)(linkedRecord && typeof linkedRecord === 'object', 'linked record should be object');
739
686
  var recordId = linkedRecord.id;
740
- (0, _error_utils.invariant)(typeof recordId === 'string', 'id should be present'); // We need to use the query result as the source of truth for
687
+ (0, _error_utils.invariant)(typeof recordId === 'string', 'id should be present');
688
+
689
+ // We need to use the query result as the source of truth for
741
690
  // recordIds, since when the client deletes a record from the linked
742
691
  // table, we update it optimistically but the origin cell value
743
692
  // doesn't update until receiving the push payload.
744
-
745
693
  if (this._linkedQueryResult.hasRecord(recordId)) {
746
694
  recordIdsSet[recordId] = true;
747
695
  }
748
696
  }
749
697
  } catch (err) {
750
- _didIteratorError4 = true;
751
- _iteratorError4 = err;
698
+ _iterator5.e(err);
752
699
  } finally {
753
- try {
754
- if (!_iteratorNormalCompletion4 && _iterator4.return != null) {
755
- _iterator4.return();
756
- }
757
- } finally {
758
- if (_didIteratorError4) {
759
- throw _iteratorError4;
760
- }
761
- }
700
+ _iterator5.f();
762
701
  }
763
-
764
702
  this._computedRecordIdsSet = recordIdsSet;
765
-
766
703
  if (this._normalizedOpts.sorts && this._normalizedOpts.sorts.length) {
767
704
  // when sorts are present, record order comes from the query result
768
705
  this._computedFilteredSortedRecordIds = this._linkedQueryResult.recordIds.filter(recordId => recordIdsSet[recordId] === true);
@@ -774,133 +711,18 @@ function (_RecordQueryResult) {
774
711
  this._computedFilteredSortedRecordIds = Object.keys(recordIdsSet);
775
712
  }
776
713
  }
777
- /** @internal */
778
714
 
715
+ /** @internal */
779
716
  }, {
780
717
  key: "_getOrGenerateRecordIdsSet",
781
718
  value: function _getOrGenerateRecordIdsSet() {
782
719
  this._generateComputedDataIfNeeded();
783
-
784
720
  var recordIdsSet = this._computedRecordIdsSet;
785
721
  (0, _error_utils.invariant)(recordIdsSet, 'recordIdsSet must exist');
786
722
  return recordIdsSet;
787
723
  }
788
- }, {
789
- key: "isValid",
790
- get: function get() {
791
- return this._isValid;
792
- }
793
- /**
794
- * The table that records in this RecordQueryResult are part of
795
- *
796
- * @internal (since we may not be able to return parent model instances in the immutable models world)
797
- */
798
-
799
- }, {
800
- key: "parentTable",
801
- get: function get() {
802
- (0, _error_utils.invariant)(this.isValid, 'LinkedRecordsQueryResult is no longer valid');
803
- return this._linkedTable;
804
- }
805
- /**
806
- * Ordered array of all the linked record ids. Watchable.
807
- */
808
-
809
- }, {
810
- key: "recordIds",
811
- get: function get() {
812
- (0, _error_utils.invariant)(this.isValid, 'LinkedRecordsQueryResult is no longer valid');
813
- (0, _error_utils.invariant)(this.isDataLoaded, 'LinkedRecordsQueryResult data is not loaded'); // record ids are lazily generated
814
-
815
- this._generateComputedDataIfNeeded();
816
-
817
- (0, _error_utils.invariant)(this._computedFilteredSortedRecordIds, 'no recordIds');
818
- return this._computedFilteredSortedRecordIds;
819
- }
820
- /**
821
- * Ordered array of all the linked records. Watchable.
822
- */
823
-
824
- }, {
825
- key: "records",
826
- get: function get() {
827
- (0, _error_utils.invariant)(this.isValid, 'LinkedRecordsQueryResult is no longer valid');
828
- return this.recordIds.map(recordId => {
829
- var record = this._linkedRecordStore.getRecordByIdIfExists(recordId);
830
-
831
- (0, _error_utils.invariant)(record, 'No record for id: %s', recordId);
832
- return record;
833
- });
834
- }
835
- /**
836
- * The fields that were used to create this LinkedRecordsQueryResult.
837
- */
838
-
839
- }, {
840
- key: "fields",
841
- get: function get() {
842
- (0, _error_utils.invariant)(this.isValid, 'LinkedRecordsQueryResult is no longer valid');
843
- return this._linkedQueryResult.fields;
844
- }
845
- }, {
846
- key: "__poolKey",
847
- get: function get() {
848
- return "".concat(this._serializedOpts, "::").concat(this._field.id, "::").concat(this._linkedTable.id, "::").concat(this.isValid);
849
- }
850
- /** @internal */
851
-
852
- }, {
853
- key: "_cellValuesWatchCount",
854
- get: function get() {
855
- return (this._changeWatchersByKey[_record_query_result.default.WatchableKeys.cellValues] || []).length;
856
- }
857
- }, {
858
- key: "_cellValueWatchCountByFieldId",
859
- get: function get() {
860
- var countByFieldId = {};
861
- var watchKeys = Object.keys(this._changeWatchersByKey).filter(key => {
862
- return key.startsWith(_record_query_result.default.WatchableCellValuesInFieldKeyPrefix);
863
- });
864
- var _iteratorNormalCompletion5 = true;
865
- var _didIteratorError5 = false;
866
- var _iteratorError5 = undefined;
867
-
868
- try {
869
- for (var _iterator5 = watchKeys[Symbol.iterator](), _step5; !(_iteratorNormalCompletion5 = (_step5 = _iterator5.next()).done); _iteratorNormalCompletion5 = true) {
870
- var watchKey = _step5.value;
871
- var fieldId = watchKey.slice(_record_query_result.default.WatchableCellValuesInFieldKeyPrefix.length);
872
- countByFieldId[fieldId] = this._changeWatchersByKey[watchKey].length;
873
- }
874
- } catch (err) {
875
- _didIteratorError5 = true;
876
- _iteratorError5 = err;
877
- } finally {
878
- try {
879
- if (!_iteratorNormalCompletion5 && _iterator5.return != null) {
880
- _iterator5.return();
881
- }
882
- } finally {
883
- if (_didIteratorError5) {
884
- throw _iteratorError5;
885
- }
886
- }
887
- }
888
-
889
- return countByFieldId;
890
- }
891
- }, {
892
- key: "_dataOrNullIfDeleted",
893
- get: function get() {
894
- if (this._record.isDeleted || this._linkedRecordStore.isDeleted) {
895
- return null;
896
- }
897
-
898
- return {};
899
- }
900
724
  }]);
901
- return LinkedRecordsQueryResult;
902
725
  }(_record_query_result.default);
903
-
726
+ /** @internal */
904
727
  (0, _defineProperty2.default)(LinkedRecordsQueryResult, "_className", 'LinkedRecordsQueryResult');
905
- var _default = LinkedRecordsQueryResult;
906
- exports.default = _default;
728
+ var _default = exports.default = LinkedRecordsQueryResult;