@deephaven/iris-grid 0.85.3-beta.3 → 0.86.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 (35) hide show
  1. package/dist/IrisGrid.d.ts +9 -4
  2. package/dist/IrisGrid.d.ts.map +1 -1
  3. package/dist/IrisGrid.js +94 -60
  4. package/dist/IrisGrid.js.map +1 -1
  5. package/dist/IrisGridPartitionSelector.css +1 -2
  6. package/dist/IrisGridPartitionSelector.css.map +1 -1
  7. package/dist/IrisGridPartitionSelector.d.ts +5 -6
  8. package/dist/IrisGridPartitionSelector.d.ts.map +1 -1
  9. package/dist/IrisGridPartitionSelector.js +68 -84
  10. package/dist/IrisGridPartitionSelector.js.map +1 -1
  11. package/dist/IrisGridPartitionedTableModel.d.ts +5 -0
  12. package/dist/IrisGridPartitionedTableModel.d.ts.map +1 -1
  13. package/dist/IrisGridPartitionedTableModel.js +24 -4
  14. package/dist/IrisGridPartitionedTableModel.js.map +1 -1
  15. package/dist/IrisGridProxyModel.js +1 -1
  16. package/dist/IrisGridProxyModel.js.map +1 -1
  17. package/dist/IrisGridTableModel.d.ts +2 -0
  18. package/dist/IrisGridTableModel.d.ts.map +1 -1
  19. package/dist/IrisGridTableModel.js +36 -27
  20. package/dist/IrisGridTableModel.js.map +1 -1
  21. package/dist/PartitionedGridModel.d.ts +5 -1
  22. package/dist/PartitionedGridModel.d.ts.map +1 -1
  23. package/dist/PartitionedGridModel.js.map +1 -1
  24. package/dist/mousehandlers/IrisGridContextMenuHandler.d.ts.map +1 -1
  25. package/dist/mousehandlers/IrisGridContextMenuHandler.js +11 -0
  26. package/dist/mousehandlers/IrisGridContextMenuHandler.js.map +1 -1
  27. package/dist/mousehandlers/IrisGridPartitionedTableMouseHandler.d.ts +12 -0
  28. package/dist/mousehandlers/IrisGridPartitionedTableMouseHandler.d.ts.map +1 -0
  29. package/dist/mousehandlers/IrisGridPartitionedTableMouseHandler.js +38 -0
  30. package/dist/mousehandlers/IrisGridPartitionedTableMouseHandler.js.map +1 -0
  31. package/dist/mousehandlers/index.d.ts +1 -0
  32. package/dist/mousehandlers/index.d.ts.map +1 -1
  33. package/dist/mousehandlers/index.js +1 -0
  34. package/dist/mousehandlers/index.js.map +1 -1
  35. package/package.json +15 -15
@@ -18,8 +18,7 @@
18
18
  }
19
19
  .iris-grid-partition-selector .partition-button-group {
20
20
  display: flex;
21
- border: 1px var(--dh-color-hr);
22
- border-style: none solid;
21
+ border-right: 1px solid var(--dh-color-hr);
23
22
  padding: 0 0.5rem;
24
23
  gap: 0.5rem;
25
24
  }
@@ -1 +1 @@
1
- {"version":3,"sourceRoot":"","sources":["../../../node_modules/@deephaven/components/scss/custom.scss","../../../node_modules/@deephaven/components/scss/bootstrap_overrides.scss","../src/IrisGridPartitionSelector.scss","../../../node_modules/@deephaven/components/scss/new_variables.scss"],"names":[],"mappings":"AAAA;AC6LA;AC5LA;EACE;EACA;EACA;EACA;EACA,SCDS;EDET,KCFS;;ADIT;EACE;EACA;EACA,KCPO;;ADSP;EACE;;AAGJ;EACE;EACA;EACA;EACA;EACA,KClBO","file":"IrisGridPartitionSelector.css","sourcesContent":["/* stylelint-disable scss/at-import-no-partial-leading-underscore */\n// Consumers should be able to resolve bootstrap/ to node_modules/bootstrap\n\n//Make bootstrap functions available for use in overrides\n@import 'bootstrap/scss/_functions.scss';\n@import './bootstrap_overrides.scss';\n\n//_variable imports come after bootstrap default overrides,\n// makes all other variables and mixins from bootstrap available\n/// with just importing customer.scss\n@import 'bootstrap/scss/_variables.scss';\n@import 'bootstrap/scss/_mixins.scss';\n\n//New variables come after imports\n@import './new_variables.scss';\n@import './util.scss';\n","// Styling overrides for bootstrap\n@use 'sass:map';\n\n// Override / set color variables\n$red: var(--dh-color-visual-red);\n$orange: var(--dh-color-visual-orange);\n$yellow: var(--dh-color-visual-yellow);\n$green: var(--dh-color-visual-green);\n$blue: var(--dh-color-visual-blue);\n$purple: var(--dh-color-visual-purple);\n\n// Fallback colors are used if theme isn't loaded\n// this is required for error messages if the API doesn't load\n\n//Define our Gray scale\n$gray-100: var(--dh-color-gray-900, #fcfcfa);\n$gray-200: var(--dh-color-gray-800);\n$gray-300: var(--dh-color-gray-700);\n$gray-400: var(--dh-color-gray-600);\n$gray-500: var(--dh-color-gray-500);\n// intentional duplicate, scale doesn't line up otherwise\n// as we have gray-850 and spectrum doesn't and it is needed\n$gray-600: var(--dh-color-gray-500);\n$gray-700: var(--dh-color-gray-400);\n$gray-800: var(--dh-color-gray-300);\n$gray-850: var(--dh-color-gray-200);\n$gray-900: var(--dh-color-gray-75);\n$black: var(--dh-color-black, #1a171a);\n$white: var(--dh-color-white, #f0f0ee);\n\n//Define some UI colors\n$interfacegray: var(--dh-color-content-bg, #2d2a2e);\n$interfaceblue: var(--dh-color-accent-bg);\n$interfacewhite: $white;\n$interfaceblack: $black;\n$content-bg: var(--dh-color-content-bg, #2d2a2e);\n$background: var(--dh-color-bg, #1a171a);\n$foreground: var(--dh-color-fg, #f0f0ee);\n\n// Extend default Bootstrap $grays map\n$grays-custom: (\n '850': $gray-850,\n);\n$grays: () !default;\n$grays: map-merge($grays, $grays-custom);\n\n// Extend default Bootstrap $colors map\n$colors-custom: (\n 'black': $black,\n);\n$colors: () !default;\n$colors: map-merge($colors, $colors-custom);\n\n// Override default Bootstrap $theme-colors map by mapping each key to itself.\n// These will then be re-mapped inside of `button-outline-variant` and\n// `button-outline-variant` mixins in `bootstrap_override_mixins_buttons.scss`\n$theme-colors-self-map: ();\n@each $key\n in (\n 'primary',\n 'secondary',\n 'success',\n 'info',\n 'warning',\n 'danger',\n 'light',\n 'dark'\n )\n{\n $theme-colors-self-map: map.set($theme-colors-self-map, $key, $key);\n}\n$theme-colors: () !default;\n$theme-colors: map-merge($theme-colors, $theme-colors-self-map);\n\n// Used by bootstrap_override_mixins_buttons.scss to map Bootstrap colors to\n// DH semantic colors\n$bootstrap-dh-semantic-map: (\n 'primary': 'accent',\n 'secondary': 'neutral',\n 'success': 'positive',\n 'info': 'info',\n 'warning': 'notice',\n 'danger': 'negative',\n // We shouldn't be using these, but mapping so they work with our custom\n // `color-yiq` mixin. If we find a way to remove $light + $dark that are\n // defined in Bootstrap _variables.scss, we should remove these\n 'light': 'neutral',\n 'dark': 'neutral',\n);\n\n//Set default colors\n$body-bg: $black;\n$body-color: $interfacewhite;\n\n// Set brand colors\n$primary: var(--dh-color-accent-bg);\n$primary-hover: var(--dh-color-accent-hover-bg);\n$primary-dark: var(--dh-color-accent-down-bg);\n$secondary: var(--dh-color-neutral-bg);\n$secondary-hover: var(--dh-color-neutral-hover-bg);\n$success: $green;\n$info: $yellow;\n$warning: $orange;\n$danger: var(--dh-color-negative-bg);\n$danger-hover: var(--dh-color-negative-hover-bg);\n// We really don't want to use $light or $dark variables, but Bootstrap defines\n// them in _variables.scss. Explicitly setting them to ensure we are in control\n// of their values. If we can find a way to remove them, we should\n$light: var(--dh-color-gray-light);\n$dark: var(--dh-color-gray-dark);\n// Bootstrap doesn't define $mid, and we want to move away from this particular\n// semantic. Should be deleted by #1635\n$mid: var(--dh-color-gray-mid);\n\n$semantic-colors: (\n 'primary-hover': $primary-hover,\n 'primary-dark': $primary-dark,\n 'mid': $mid,\n 'content-bg': $interfacegray,\n 'background': $interfaceblack,\n 'foreground': $interfacewhite,\n 'secondary-hover': $secondary-hover,\n 'danger-hover': $danger-hover,\n);\n\n$component-active-bg: $primary;\n$theme-color-interval: 9%;\n$yiq-contrasted-threshold: 180;\n\n// Override fonts\n$font-family-sans-serif:\n 'Fira Sans',\n -apple-system,\n blinkmacsystemfont,\n 'Segoe UI',\n 'Roboto',\n 'Helvetica Neue',\n arial,\n sans-serif; //fira sans then native system ui fallbacks\n$font-family-monospace: 'Fira Mono', menlo, monaco, consolas, 'Liberation Mono',\n 'Courier New', monospace;\n$font-family-base: $font-family-sans-serif;\n\n$headings-font-weight: 400;\n\n//Text overides\n$text-muted: $gray-400;\n\n//Style Selection highlight color\n$text-select-color: var(--dh-color-text-highlight);\n\n//Grid variables, same value as default just making easily accessible\n$grid-gutter-width: 30px;\n\n//Visual Overrides\n$border-radius: 4px;\n$box-shadow: 0 0.1rem 1rem var(--dh-color-dropshadow);\n\n//Override Btn\n$btn-border-radius: 4rem;\n$btn-padding-x: 1.5rem;\n$btn-transition:\n color 0.12s ease-in-out,\n background-color 0.12s ease-in-out,\n border-color 0.12s ease-in-out,\n box-shadow 0.12s ease-in-out; //default 0.15 is too long\n$btn-border-width: 2px;\n$btn-font-weight: var(--spectrum-global-font-weight-bold);\n$btn-line-height: 1.3;\n\n//Override Inputs\n$input-bg: var(--dh-color-input-bg);\n$input-disabled-bg: var(--dh-color-input-disabled-bg);\n$input-color: var(--dh-color-input-fg);\n$input-border-color: var(--dh-color-input-border);\n$input-placeholder-color: var(--dh-color-input-placeholder);\n$input-focus-border-color: var(--dh-color-input-focus-border);\n\n$input-btn-focus-width: 0.2rem;\n$input-btn-focus-color: color-mix(\n in srgb,\n var(--dh-color-accent) 35%,\n transparent\n);\n$input-btn-focus-box-shadow: 0 0 0 $input-btn-focus-width $input-btn-focus-color;\n$input-btn-line-height: 1.3;\n// Bootstrap uses a calc expression to determine the input height (calc(line-height + 2*padding-y + border)).\n// The padding-y value has to be in rem to match units as it is a SASS calc.\n// Using 0.42145rem with 1.3 line height gets us to spectrum's 32px.\n/* stylelint-disable-next-line number-max-precision */\n$input-btn-padding-y: 0.42145rem;\n\n//checkbox\n$custom-control-indicator-bg: var(--dh-color-input-bg);\n$custom-control-indicator-border-color: var(--dh-color-input-border);\n$custom-checkbox-indicator-border-radius: 2px;\n$custom-control-indicator-border-width: 2px;\n$custom-control-indicator-active-bg: var(--dh-color-input-bg);\n$custom-control-indicator-active-border-color: var(--dh-color-input-fg);\n$custom-control-indicator-checked-bg: var(--dh-color-input-fg);\n$custom-control-indicator-checked-color: black; // used as mask fill color\n$custom-checkbox-indicator-indeterminate-bg: var(--dh-color-input-fg);\n$custom-control-indicator-bg-size: 75% 75%;\n$custom-control-indicator-disabled-bg: var(--dh-color-input-disabled-bg);\n$custom-control-indicator-checked-disabled-bg: var(\n --dh-color-input-disabled-bg\n);\n$custom-control-label-disabled-color: var(--dh-color-input-disabled-fg);\n\n// The $custom-select-indicator variable is used by Bootstrap to provide the\n// icon for the select dropdown. Inline svgs can't use CSS variables, so we hard\n// code the color to #929192 (the default value of --dh-color-gray-600). PR #1651\n// overrides this icon altogether for known dropdowns, so technically we may not\n// need this, but it's here in case there are any remaining instances.\n$custom-select-indicator-color: #929192;\n$custom-select-bg: var(--dh-color-selector-bg);\n$custom-select-bg-size: 16px 16px;\n//dhSort icon encoded\n$custom-select-indicator: str-replace(\n url(\"data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3E%3Cpath fill='#{$custom-select-indicator-color}' d='M4 7l-.4-.8 4-3.7h.8l4 3.7-.4.8H4zm0 2l-.4.8 4 3.7h.8l4-3.7L12 9H4z'/%3E%3C/svg%3E\"),\n '#',\n '%23'\n);\n$custom-select-focus-box-shadow: $input-btn-focus-box-shadow;\n$custom-select-disabled-color: $gray-500;\n$custom-select-disabled-bg: $gray-800;\n\n//modal\n$modal-content-bg: $content-bg;\n$modal-content-border-width: 0;\n$modal-md: 550px;\n$close-color: var(--dh-color-text);\n$close-text-shadow: none;\n\n// Toast notification\n$toast-bg: var(--dh-color-accent-100);\n$toast-color: var(--dh-color-text);\n$toast-error-bg: var(--dh-color-negative-bg);\n$toast-error-color: var(--dh-color-text);\n\n//tooltips\n$tooltip-bg: var(--dh-color-tooltip-bg);\n$tooltip-color: var(--dh-color-tooltip-fg);\n$tooltip-box-shadow: 0 0.1rem 1.5rem 0.1rem var(--dh-color-tooltip-box-shadow);\n\n//drowdowns\n$dropdown-bg: $gray-600;\n$dropdown-link-color: $foreground;\n$dropdown-link-hover-color: $foreground;\n$dropdown-link-hover-bg: var(--dh-color-item-list-hover-bg);\n$dropdown-divider-bg: $gray-700;\n\n//context menus\n$contextmenu-bg: var(--dh-color-popover-bg);\n$contextmenu-color: var(--dh-color-text);\n$contextmenu-disabled-color: var(--dh-color-input-disabled-fg);\n$contextmenu-keyboard-selected-bg: var(--dh-color-keyboard-selected-bg);\n$contextmenu-selected-bg: var(--dh-color-item-list-hover-bg);\n$contextmenu-selected-color: var(--dh-color-item-list-selected-fg);\n\n//hr\n$hr-border-color: var(--dh-color-hr);\n\n//links\n$link-color: $gray-400;\n$link-hover-color: $foreground;\n\n//progress-bar\n$progress-bg: $gray-600;\n$progress-border-radius: 1rem;\n\n// Set global options\n$enable-shadows: false;\n$enable-gradients: false;\n$enable-print-styles: false; //I don't think anyone should expect to \"print\" this app.\n\n// Transition times\n$transition: 0.15s;\n$transition-mid: 0.2s;\n$transition-long: 0.3s;\n$transition-slow: 0.6s;\n\n//form-validation icon, uses vsWarning icon encoded here as svg\n$form-feedback-icon-invalid-color: $danger;\n$form-feedback-icon-invalid: str-replace(\n url(\"data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 16 16'%3E%3Cg fill='none'%3E%3Cg fill='#{$form-feedback-icon-invalid-color}'%3E%3Cpath d='M7.56 1h.88l6.54 12.26-.44.74H1.44L1 13.26 7.56 1zM8 2.28 2.28 13H13.7L8 2.28zM8.625 12v-1h-1.25v1h1.25zm-1.25-2V6h1.25v4h-1.25z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E \"),\n '#',\n '%23'\n);\n\n// This section of variables is not consumed directly by DH, but they need to be\n// defined for sass to compile _variables\n$table-dark-bg: $gray-800;\n$table-dark-accent-bg: var(--dh-color-highlight-hover);\n$table-dark-hover-bg: var(--dh-color-highlight-active);\n$table-dark-border-color: $gray-700;\n$popover-bg: var(--dh-color-tooltip-bg);\n$popover-border-color: var(--dh-color-overlay-modal-bg);\n$popover-header-bg: #000;\n$popover-arrow-outer-color: var(--dh-color-dropshadow);\n$custom-range-thumb-active-bg: var(--dh-color-accent-1100);\n","@import '@deephaven/components/scss/custom.scss';\n.iris-grid-partition-selector {\n display: flex;\n flex-wrap: wrap;\n background: var(--dh-color-surface-bg);\n align-items: center;\n padding: $spacer-2;\n gap: $spacer-2;\n\n .column-selector {\n display: flex;\n align-items: center;\n gap: $spacer-2;\n\n .custom-select {\n min-width: 4rem;\n }\n }\n .partition-button-group {\n display: flex;\n border: 1px var(--dh-color-hr);\n border-style: none solid;\n padding: 0 $spacer-2;\n gap: $spacer-2;\n }\n}\n","@use 'sass:math';\n\n//Set of spacer variables from the spacer map\n$spacer-0: map-get($spacers, 0); //0\n$spacer-1: map-get($spacers, 1);\n$spacer-2: map-get($spacers, 2);\n$spacer-3: map-get($spacers, 3);\n$spacer-4: map-get($spacers, 4);\n$spacer-5: map-get($spacers, 5);\n\n//Marching Ants for golden layout dropzone and drag and drop\n//top bottom, left right.\n//create 4 background images that are 50% color 1, 50% color 2 using graidents, two veritical, two horizontal\n//size them to ant-size and thickness\n//position those images along the egdes and make top/bottom repeat-x and left/right repeat-y\n//then offest each of those background positions by ant-size in animation to make them march.\n$ant-size: 8px;\n$ant-thickness: 1px;\n\n@mixin ants-base($color-1: black, $color-2: white) {\n background-image: linear-gradient(to right, $color-2 50%, $color-1 50%),\n linear-gradient(to right, $color-2 50%, $color-1 50%),\n linear-gradient(to bottom, $color-2 50%, $color-1 50%),\n linear-gradient(to bottom, $color-2 50%, $color-1 50%);\n background-size:\n $ant-size $ant-thickness,\n $ant-size $ant-thickness,\n $ant-thickness $ant-size,\n $ant-thickness $ant-size;\n background-position:\n 0 top,\n 0 bottom,\n left 0,\n right 0;\n background-repeat: repeat-x, repeat-x, repeat-y, repeat-y;\n animation: march 0.5s;\n animation-timing-function: linear;\n animation-iteration-count: infinite;\n}\n\n@mixin drag-stack($pseudo-element) {\n &::#{$pseudo-element} {\n content: ' ';\n background: $primary;\n box-shadow: $box-shadow;\n border-radius: $border-radius;\n position: absolute;\n height: 100%;\n width: 100%;\n @content;\n }\n}\n\n$focus-bg-transparency: 12%;\n$hover-bg-transparency: 14%;\n$active-bg-transparency: 28%;\n$exception-transparency: 28%;\n"]}
1
+ {"version":3,"sourceRoot":"","sources":["../../../node_modules/@deephaven/components/scss/custom.scss","../../../node_modules/@deephaven/components/scss/bootstrap_overrides.scss","../src/IrisGridPartitionSelector.scss","../../../node_modules/@deephaven/components/scss/new_variables.scss"],"names":[],"mappings":"AAAA;AC6LA;AC5LA;EACE;EACA;EACA;EACA;EACA,SCDS;EDET,KCFS;;ADIT;EACE;EACA;EACA,KCPO;;ADSP;EACE;;AAGJ;EACE;EACA;EACA;EACA,KCjBO","file":"IrisGridPartitionSelector.css","sourcesContent":["/* stylelint-disable scss/at-import-no-partial-leading-underscore */\n// Consumers should be able to resolve bootstrap/ to node_modules/bootstrap\n\n//Make bootstrap functions available for use in overrides\n@import 'bootstrap/scss/_functions.scss';\n@import './bootstrap_overrides.scss';\n\n//_variable imports come after bootstrap default overrides,\n// makes all other variables and mixins from bootstrap available\n/// with just importing customer.scss\n@import 'bootstrap/scss/_variables.scss';\n@import 'bootstrap/scss/_mixins.scss';\n\n//New variables come after imports\n@import './new_variables.scss';\n@import './util.scss';\n","// Styling overrides for bootstrap\n@use 'sass:map';\n\n// Override / set color variables\n$red: var(--dh-color-visual-red);\n$orange: var(--dh-color-visual-orange);\n$yellow: var(--dh-color-visual-yellow);\n$green: var(--dh-color-visual-green);\n$blue: var(--dh-color-visual-blue);\n$purple: var(--dh-color-visual-purple);\n\n// Fallback colors are used if theme isn't loaded\n// this is required for error messages if the API doesn't load\n\n//Define our Gray scale\n$gray-100: var(--dh-color-gray-900, #fcfcfa);\n$gray-200: var(--dh-color-gray-800);\n$gray-300: var(--dh-color-gray-700);\n$gray-400: var(--dh-color-gray-600);\n$gray-500: var(--dh-color-gray-500);\n// intentional duplicate, scale doesn't line up otherwise\n// as we have gray-850 and spectrum doesn't and it is needed\n$gray-600: var(--dh-color-gray-500);\n$gray-700: var(--dh-color-gray-400);\n$gray-800: var(--dh-color-gray-300);\n$gray-850: var(--dh-color-gray-200);\n$gray-900: var(--dh-color-gray-75);\n$black: var(--dh-color-black, #1a171a);\n$white: var(--dh-color-white, #f0f0ee);\n\n//Define some UI colors\n$interfacegray: var(--dh-color-content-bg, #2d2a2e);\n$interfaceblue: var(--dh-color-accent-bg);\n$interfacewhite: $white;\n$interfaceblack: $black;\n$content-bg: var(--dh-color-content-bg, #2d2a2e);\n$background: var(--dh-color-bg, #1a171a);\n$foreground: var(--dh-color-fg, #f0f0ee);\n\n// Extend default Bootstrap $grays map\n$grays-custom: (\n '850': $gray-850,\n);\n$grays: () !default;\n$grays: map-merge($grays, $grays-custom);\n\n// Extend default Bootstrap $colors map\n$colors-custom: (\n 'black': $black,\n);\n$colors: () !default;\n$colors: map-merge($colors, $colors-custom);\n\n// Override default Bootstrap $theme-colors map by mapping each key to itself.\n// These will then be re-mapped inside of `button-outline-variant` and\n// `button-outline-variant` mixins in `bootstrap_override_mixins_buttons.scss`\n$theme-colors-self-map: ();\n@each $key\n in (\n 'primary',\n 'secondary',\n 'success',\n 'info',\n 'warning',\n 'danger',\n 'light',\n 'dark'\n )\n{\n $theme-colors-self-map: map.set($theme-colors-self-map, $key, $key);\n}\n$theme-colors: () !default;\n$theme-colors: map-merge($theme-colors, $theme-colors-self-map);\n\n// Used by bootstrap_override_mixins_buttons.scss to map Bootstrap colors to\n// DH semantic colors\n$bootstrap-dh-semantic-map: (\n 'primary': 'accent',\n 'secondary': 'neutral',\n 'success': 'positive',\n 'info': 'info',\n 'warning': 'notice',\n 'danger': 'negative',\n // We shouldn't be using these, but mapping so they work with our custom\n // `color-yiq` mixin. If we find a way to remove $light + $dark that are\n // defined in Bootstrap _variables.scss, we should remove these\n 'light': 'neutral',\n 'dark': 'neutral',\n);\n\n//Set default colors\n$body-bg: $black;\n$body-color: $interfacewhite;\n\n// Set brand colors\n$primary: var(--dh-color-accent-bg);\n$primary-hover: var(--dh-color-accent-hover-bg);\n$primary-dark: var(--dh-color-accent-down-bg);\n$secondary: var(--dh-color-neutral-bg);\n$secondary-hover: var(--dh-color-neutral-hover-bg);\n$success: $green;\n$info: $yellow;\n$warning: $orange;\n$danger: var(--dh-color-negative-bg);\n$danger-hover: var(--dh-color-negative-hover-bg);\n// We really don't want to use $light or $dark variables, but Bootstrap defines\n// them in _variables.scss. Explicitly setting them to ensure we are in control\n// of their values. If we can find a way to remove them, we should\n$light: var(--dh-color-gray-light);\n$dark: var(--dh-color-gray-dark);\n// Bootstrap doesn't define $mid, and we want to move away from this particular\n// semantic. Should be deleted by #1635\n$mid: var(--dh-color-gray-mid);\n\n$semantic-colors: (\n 'primary-hover': $primary-hover,\n 'primary-dark': $primary-dark,\n 'mid': $mid,\n 'content-bg': $interfacegray,\n 'background': $interfaceblack,\n 'foreground': $interfacewhite,\n 'secondary-hover': $secondary-hover,\n 'danger-hover': $danger-hover,\n);\n\n$component-active-bg: $primary;\n$theme-color-interval: 9%;\n$yiq-contrasted-threshold: 180;\n\n// Override fonts\n$font-family-sans-serif:\n 'Fira Sans',\n -apple-system,\n blinkmacsystemfont,\n 'Segoe UI',\n 'Roboto',\n 'Helvetica Neue',\n arial,\n sans-serif; //fira sans then native system ui fallbacks\n$font-family-monospace: 'Fira Mono', menlo, monaco, consolas, 'Liberation Mono',\n 'Courier New', monospace;\n$font-family-base: $font-family-sans-serif;\n\n$headings-font-weight: 400;\n\n//Text overides\n$text-muted: $gray-400;\n\n//Style Selection highlight color\n$text-select-color: var(--dh-color-text-highlight);\n\n//Grid variables, same value as default just making easily accessible\n$grid-gutter-width: 30px;\n\n//Visual Overrides\n$border-radius: 4px;\n$box-shadow: 0 0.1rem 1rem var(--dh-color-dropshadow);\n\n//Override Btn\n$btn-border-radius: 4rem;\n$btn-padding-x: 1.5rem;\n$btn-transition:\n color 0.12s ease-in-out,\n background-color 0.12s ease-in-out,\n border-color 0.12s ease-in-out,\n box-shadow 0.12s ease-in-out; //default 0.15 is too long\n$btn-border-width: 2px;\n$btn-font-weight: var(--spectrum-global-font-weight-bold);\n$btn-line-height: 1.3;\n\n//Override Inputs\n$input-bg: var(--dh-color-input-bg);\n$input-disabled-bg: var(--dh-color-input-disabled-bg);\n$input-color: var(--dh-color-input-fg);\n$input-border-color: var(--dh-color-input-border);\n$input-placeholder-color: var(--dh-color-input-placeholder);\n$input-focus-border-color: var(--dh-color-input-focus-border);\n\n$input-btn-focus-width: 0.2rem;\n$input-btn-focus-color: color-mix(\n in srgb,\n var(--dh-color-accent) 35%,\n transparent\n);\n$input-btn-focus-box-shadow: 0 0 0 $input-btn-focus-width $input-btn-focus-color;\n$input-btn-line-height: 1.3;\n// Bootstrap uses a calc expression to determine the input height (calc(line-height + 2*padding-y + border)).\n// The padding-y value has to be in rem to match units as it is a SASS calc.\n// Using 0.42145rem with 1.3 line height gets us to spectrum's 32px.\n/* stylelint-disable-next-line number-max-precision */\n$input-btn-padding-y: 0.42145rem;\n\n//checkbox\n$custom-control-indicator-bg: var(--dh-color-input-bg);\n$custom-control-indicator-border-color: var(--dh-color-input-border);\n$custom-checkbox-indicator-border-radius: 2px;\n$custom-control-indicator-border-width: 2px;\n$custom-control-indicator-active-bg: var(--dh-color-input-bg);\n$custom-control-indicator-active-border-color: var(--dh-color-input-fg);\n$custom-control-indicator-checked-bg: var(--dh-color-input-fg);\n$custom-control-indicator-checked-color: black; // used as mask fill color\n$custom-checkbox-indicator-indeterminate-bg: var(--dh-color-input-fg);\n$custom-control-indicator-bg-size: 75% 75%;\n$custom-control-indicator-disabled-bg: var(--dh-color-input-disabled-bg);\n$custom-control-indicator-checked-disabled-bg: var(\n --dh-color-input-disabled-bg\n);\n$custom-control-label-disabled-color: var(--dh-color-input-disabled-fg);\n\n// The $custom-select-indicator variable is used by Bootstrap to provide the\n// icon for the select dropdown. Inline svgs can't use CSS variables, so we hard\n// code the color to #929192 (the default value of --dh-color-gray-600). PR #1651\n// overrides this icon altogether for known dropdowns, so technically we may not\n// need this, but it's here in case there are any remaining instances.\n$custom-select-indicator-color: #929192;\n$custom-select-bg: var(--dh-color-selector-bg);\n$custom-select-bg-size: 16px 16px;\n//dhSort icon encoded\n$custom-select-indicator: str-replace(\n url(\"data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3E%3Cpath fill='#{$custom-select-indicator-color}' d='M4 7l-.4-.8 4-3.7h.8l4 3.7-.4.8H4zm0 2l-.4.8 4 3.7h.8l4-3.7L12 9H4z'/%3E%3C/svg%3E\"),\n '#',\n '%23'\n);\n$custom-select-focus-box-shadow: $input-btn-focus-box-shadow;\n$custom-select-disabled-color: $gray-500;\n$custom-select-disabled-bg: $gray-800;\n\n//modal\n$modal-content-bg: $content-bg;\n$modal-content-border-width: 0;\n$modal-md: 550px;\n$close-color: var(--dh-color-text);\n$close-text-shadow: none;\n\n// Toast notification\n$toast-bg: var(--dh-color-accent-100);\n$toast-color: var(--dh-color-text);\n$toast-error-bg: var(--dh-color-negative-bg);\n$toast-error-color: var(--dh-color-text);\n\n//tooltips\n$tooltip-bg: var(--dh-color-tooltip-bg);\n$tooltip-color: var(--dh-color-tooltip-fg);\n$tooltip-box-shadow: 0 0.1rem 1.5rem 0.1rem var(--dh-color-tooltip-box-shadow);\n\n//drowdowns\n$dropdown-bg: $gray-600;\n$dropdown-link-color: $foreground;\n$dropdown-link-hover-color: $foreground;\n$dropdown-link-hover-bg: var(--dh-color-item-list-hover-bg);\n$dropdown-divider-bg: $gray-700;\n\n//context menus\n$contextmenu-bg: var(--dh-color-popover-bg);\n$contextmenu-color: var(--dh-color-text);\n$contextmenu-disabled-color: var(--dh-color-input-disabled-fg);\n$contextmenu-keyboard-selected-bg: var(--dh-color-keyboard-selected-bg);\n$contextmenu-selected-bg: var(--dh-color-item-list-hover-bg);\n$contextmenu-selected-color: var(--dh-color-item-list-selected-fg);\n\n//hr\n$hr-border-color: var(--dh-color-hr);\n\n//links\n$link-color: $gray-400;\n$link-hover-color: $foreground;\n\n//progress-bar\n$progress-bg: $gray-600;\n$progress-border-radius: 1rem;\n\n// Set global options\n$enable-shadows: false;\n$enable-gradients: false;\n$enable-print-styles: false; //I don't think anyone should expect to \"print\" this app.\n\n// Transition times\n$transition: 0.15s;\n$transition-mid: 0.2s;\n$transition-long: 0.3s;\n$transition-slow: 0.6s;\n\n//form-validation icon, uses vsWarning icon encoded here as svg\n$form-feedback-icon-invalid-color: $danger;\n$form-feedback-icon-invalid: str-replace(\n url(\"data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 16 16'%3E%3Cg fill='none'%3E%3Cg fill='#{$form-feedback-icon-invalid-color}'%3E%3Cpath d='M7.56 1h.88l6.54 12.26-.44.74H1.44L1 13.26 7.56 1zM8 2.28 2.28 13H13.7L8 2.28zM8.625 12v-1h-1.25v1h1.25zm-1.25-2V6h1.25v4h-1.25z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E \"),\n '#',\n '%23'\n);\n\n// This section of variables is not consumed directly by DH, but they need to be\n// defined for sass to compile _variables\n$table-dark-bg: $gray-800;\n$table-dark-accent-bg: var(--dh-color-highlight-hover);\n$table-dark-hover-bg: var(--dh-color-highlight-active);\n$table-dark-border-color: $gray-700;\n$popover-bg: var(--dh-color-tooltip-bg);\n$popover-border-color: var(--dh-color-overlay-modal-bg);\n$popover-header-bg: #000;\n$popover-arrow-outer-color: var(--dh-color-dropshadow);\n$custom-range-thumb-active-bg: var(--dh-color-accent-1100);\n","@import '@deephaven/components/scss/custom.scss';\n.iris-grid-partition-selector {\n display: flex;\n flex-wrap: wrap;\n background: var(--dh-color-surface-bg);\n align-items: center;\n padding: $spacer-2;\n gap: $spacer-2;\n\n .column-selector {\n display: flex;\n align-items: center;\n gap: $spacer-2;\n\n .custom-select {\n min-width: 4rem;\n }\n }\n .partition-button-group {\n display: flex;\n border-right: 1px solid var(--dh-color-hr);\n padding: 0 $spacer-2;\n gap: $spacer-2;\n }\n}\n","@use 'sass:math';\n\n//Set of spacer variables from the spacer map\n$spacer-0: map-get($spacers, 0); //0\n$spacer-1: map-get($spacers, 1);\n$spacer-2: map-get($spacers, 2);\n$spacer-3: map-get($spacers, 3);\n$spacer-4: map-get($spacers, 4);\n$spacer-5: map-get($spacers, 5);\n\n//Marching Ants for golden layout dropzone and drag and drop\n//top bottom, left right.\n//create 4 background images that are 50% color 1, 50% color 2 using graidents, two veritical, two horizontal\n//size them to ant-size and thickness\n//position those images along the egdes and make top/bottom repeat-x and left/right repeat-y\n//then offest each of those background positions by ant-size in animation to make them march.\n$ant-size: 8px;\n$ant-thickness: 1px;\n\n@mixin ants-base($color-1: black, $color-2: white) {\n background-image: linear-gradient(to right, $color-2 50%, $color-1 50%),\n linear-gradient(to right, $color-2 50%, $color-1 50%),\n linear-gradient(to bottom, $color-2 50%, $color-1 50%),\n linear-gradient(to bottom, $color-2 50%, $color-1 50%);\n background-size:\n $ant-size $ant-thickness,\n $ant-size $ant-thickness,\n $ant-thickness $ant-size,\n $ant-thickness $ant-size;\n background-position:\n 0 top,\n 0 bottom,\n left 0,\n right 0;\n background-repeat: repeat-x, repeat-x, repeat-y, repeat-y;\n animation: march 0.5s;\n animation-timing-function: linear;\n animation-iteration-count: infinite;\n}\n\n@mixin drag-stack($pseudo-element) {\n &::#{$pseudo-element} {\n content: ' ';\n background: $primary;\n box-shadow: $box-shadow;\n border-radius: $border-radius;\n position: absolute;\n height: 100%;\n width: 100%;\n @content;\n }\n}\n\n$focus-bg-transparency: 12%;\n$hover-bg-transparency: 14%;\n$active-bg-transparency: 28%;\n$exception-transparency: 28%;\n"]}
@@ -7,15 +7,14 @@ import './IrisGridPartitionSelector.scss';
7
7
  import { PartitionConfig, PartitionedGridModel } from './PartitionedGridModel';
8
8
  interface IrisGridPartitionSelectorProps {
9
9
  model: PartitionedGridModel;
10
- partitionConfig: PartitionConfig;
10
+ partitionConfig?: PartitionConfig;
11
11
  onChange: (partitionConfig: PartitionConfig) => void;
12
12
  }
13
13
  interface IrisGridPartitionSelectorState {
14
14
  isLoading: boolean;
15
+ baseTable: dh.Table | null;
15
16
  keysTable: dh.Table | null;
16
17
  partitionTables: dh.Table[] | null;
17
- /** The filters to apply to each partition table */
18
- partitionFilters: dh.FilterCondition[][] | null;
19
18
  }
20
19
  declare class IrisGridPartitionSelector extends Component<IrisGridPartitionSelectorProps, IrisGridPartitionSelectorState> {
21
20
  constructor(props: IrisGridPartitionSelectorProps);
@@ -24,7 +23,7 @@ declare class IrisGridPartitionSelector extends Component<IrisGridPartitionSelec
24
23
  componentWillUnmount(): void;
25
24
  pending: Pending;
26
25
  tableUtils: TableUtils;
27
- handleKeyTableClick(): void;
26
+ handlePartitionTableClick(): void;
28
27
  handleMergeClick(): void;
29
28
  /**
30
29
  * Handles when a partition dropdown selection is changed. Will send an update with the new partition config
@@ -40,9 +39,9 @@ declare class IrisGridPartitionSelector extends Component<IrisGridPartitionSelec
40
39
  */
41
40
  getDisplayValue(index: number, value: unknown): string;
42
41
  /**
43
- * Update the filters on the partition dropdown tables
42
+ * Update the options on the partition dropdown tables
44
43
  */
45
- updatePartitionFilters(): void;
44
+ updatePartitionOptions(): Promise<void>;
46
45
  getPartitionFilters(partitionTables: dh.Table[]): dh.FilterCondition[][];
47
46
  getCachedChangeCallback: ((index: number) => (value: unknown) => Promise<void>) & memoizee.Memoized<(index: number) => (value: unknown) => Promise<void>>;
48
47
  getCachedFormatValueCallback: ((index: number) => (value: unknown) => string) & memoizee.Memoized<(index: number) => (value: unknown) => string>;
@@ -1 +1 @@
1
- {"version":3,"file":"IrisGridPartitionSelector.d.ts","sourceRoot":"","sources":["../src/IrisGridPartitionSelector.tsx"],"names":[],"mappings":"AAAA,OAAc,EAAE,SAAS,EAAE,MAAM,OAAO,CAAC;AACzC,OAAO,QAAQ,MAAM,UAAU,CAAC;AAMhC,OAAO,KAAK,EAAE,EAAE,EAAE,MAAM,wBAAwB,CAAC;AACjD,OAAO,EAAE,UAAU,EAAE,MAAM,wBAAwB,CAAC;AACpD,OAAO,EAAiB,OAAO,EAAgB,MAAM,kBAAkB,CAAC;AACxE,OAAO,kCAAkC,CAAC;AAC1C,OAAO,EAAE,eAAe,EAAE,oBAAoB,EAAE,MAAM,wBAAwB,CAAC;AAI/E,UAAU,8BAA8B;IACtC,KAAK,EAAE,oBAAoB,CAAC;IAC5B,eAAe,EAAE,eAAe,CAAC;IACjC,QAAQ,EAAE,CAAC,eAAe,EAAE,eAAe,KAAK,IAAI,CAAC;CACtD;AACD,UAAU,8BAA8B;IACtC,SAAS,EAAE,OAAO,CAAC;IAEnB,SAAS,EAAE,EAAE,CAAC,KAAK,GAAG,IAAI,CAAC;IAE3B,eAAe,EAAE,EAAE,CAAC,KAAK,EAAE,GAAG,IAAI,CAAC;IAEnC,mDAAmD;IACnD,gBAAgB,EAAE,EAAE,CAAC,eAAe,EAAE,EAAE,GAAG,IAAI,CAAC;CACjD;AACD,cAAM,yBAA0B,SAAQ,SAAS,CAC/C,8BAA8B,EAC9B,8BAA8B,CAC/B;gBACa,KAAK,EAAE,8BAA8B;IAqB3C,iBAAiB,IAAI,OAAO,CAAC,IAAI,CAAC;IAuCxC,kBAAkB,CAAC,SAAS,EAAE,8BAA8B,GAAG,IAAI;IAUnE,oBAAoB,IAAI,IAAI;IAQ5B,OAAO,EAAE,OAAO,CAAC;IAEjB,UAAU,EAAE,UAAU,CAAC;IAEvB,mBAAmB,IAAI,IAAI;IAW3B,gBAAgB,IAAI,IAAI;IAWxB;;;;OAIG;IACG,qBAAqB,CACzB,KAAK,EAAE,MAAM,EACb,aAAa,EAAE,OAAO,GACrB,OAAO,CAAC,IAAI,CAAC;IAsDhB,UAAU,CAAC,eAAe,EAAE,eAAe,GAAG,IAAI;IAOlD;;;;OAIG;IACH,eAAe,CAAC,KAAK,EAAE,MAAM,EAAE,KAAK,EAAE,OAAO,GAAG,MAAM;IAiBtD;;OAEG;IACH,sBAAsB,IAAI,IAAI;IAiB9B,mBAAmB,CAAC,eAAe,EAAE,EAAE,CAAC,KAAK,EAAE,GAAG,EAAE,CAAC,eAAe,EAAE,EAAE;IAkCxE,uBAAuB,WACb,MAAM,aAAa,OAAO,gDAA1B,MAAM,aAAa,OAAO,oBAElC;IAEF,4BAA4B,WAClB,MAAM,aAAa,OAAO,yCAA1B,MAAM,aAAa,OAAO,aAClC;IAEF,MAAM,IAAI,GAAG,CAAC,OAAO;CAgEtB;AAED,eAAe,yBAAyB,CAAC"}
1
+ {"version":3,"file":"IrisGridPartitionSelector.d.ts","sourceRoot":"","sources":["../src/IrisGridPartitionSelector.tsx"],"names":[],"mappings":"AAAA,OAAc,EAAE,SAAS,EAAE,MAAM,OAAO,CAAC;AACzC,OAAO,QAAQ,MAAM,UAAU,CAAC;AAMhC,OAAO,KAAK,EAAE,EAAE,EAAE,MAAM,wBAAwB,CAAC;AACjD,OAAO,EAAE,UAAU,EAAE,MAAM,wBAAwB,CAAC;AACpD,OAAO,EAAiB,OAAO,EAAgB,MAAM,kBAAkB,CAAC;AACxE,OAAO,kCAAkC,CAAC;AAC1C,OAAO,EAAE,eAAe,EAAE,oBAAoB,EAAE,MAAM,wBAAwB,CAAC;AAI/E,UAAU,8BAA8B;IACtC,KAAK,EAAE,oBAAoB,CAAC;IAC5B,eAAe,CAAC,EAAE,eAAe,CAAC;IAClC,QAAQ,EAAE,CAAC,eAAe,EAAE,eAAe,KAAK,IAAI,CAAC;CACtD;AACD,UAAU,8BAA8B;IACtC,SAAS,EAAE,OAAO,CAAC;IAEnB,SAAS,EAAE,EAAE,CAAC,KAAK,GAAG,IAAI,CAAC;IAE3B,SAAS,EAAE,EAAE,CAAC,KAAK,GAAG,IAAI,CAAC;IAE3B,eAAe,EAAE,EAAE,CAAC,KAAK,EAAE,GAAG,IAAI,CAAC;CACpC;AACD,cAAM,yBAA0B,SAAQ,SAAS,CAC/C,8BAA8B,EAC9B,8BAA8B,CAC/B;gBACa,KAAK,EAAE,8BAA8B;IAqB3C,iBAAiB,IAAI,OAAO,CAAC,IAAI,CAAC;IA2BxC,kBAAkB,CAAC,SAAS,EAAE,8BAA8B,GAAG,IAAI;IAUnE,oBAAoB,IAAI,IAAI;IAS5B,OAAO,EAAE,OAAO,CAAC;IAEjB,UAAU,EAAE,UAAU,CAAC;IAEvB,yBAAyB,IAAI,IAAI;IAajC,gBAAgB,IAAI,IAAI;IAYxB;;;;OAIG;IACG,qBAAqB,CACzB,KAAK,EAAE,MAAM,EACb,aAAa,EAAE,OAAO,GACrB,OAAO,CAAC,IAAI,CAAC;IAoDhB,UAAU,CAAC,eAAe,EAAE,eAAe,GAAG,IAAI;IAOlD;;;;OAIG;IACH,eAAe,CAAC,KAAK,EAAE,MAAM,EAAE,KAAK,EAAE,OAAO,GAAG,MAAM;IAiBtD;;OAEG;IACG,sBAAsB,IAAI,OAAO,CAAC,IAAI,CAAC;IAyB7C,mBAAmB,CAAC,eAAe,EAAE,EAAE,CAAC,KAAK,EAAE,GAAG,EAAE,CAAC,eAAe,EAAE,EAAE;IAmCxE,uBAAuB,WACb,MAAM,aAAa,OAAO,gDAA1B,MAAM,aAAa,OAAO,oBAElC;IAEF,4BAA4B,WAClB,MAAM,aAAa,OAAO,yCAA1B,MAAM,aAAa,OAAO,aAClC;IAEF,MAAM,IAAI,GAAG,CAAC,OAAO;CA8DtB;AAED,eAAe,yBAAyB,CAAC"}
@@ -25,7 +25,7 @@ class IrisGridPartitionSelector extends Component {
25
25
  _defineProperty(this, "tableUtils", void 0);
26
26
  _defineProperty(this, "getCachedChangeCallback", memoizee(index => value => this.handlePartitionSelect(index, value)));
27
27
  _defineProperty(this, "getCachedFormatValueCallback", memoizee(index => value => this.getDisplayValue(index, value)));
28
- this.handleKeyTableClick = this.handleKeyTableClick.bind(this);
28
+ this.handlePartitionTableClick = this.handlePartitionTableClick.bind(this);
29
29
  this.handleMergeClick = this.handleMergeClick.bind(this);
30
30
  this.handlePartitionSelect = this.handlePartitionSelect.bind(this);
31
31
  var {
@@ -36,8 +36,8 @@ class IrisGridPartitionSelector extends Component {
36
36
  this.state = {
37
37
  // We start be loading the partition tables, so we should be in a loading state
38
38
  isLoading: true,
39
+ baseTable: null,
39
40
  keysTable: null,
40
- partitionFilters: null,
41
41
  partitionTables: null
42
42
  };
43
43
  }
@@ -48,26 +48,14 @@ class IrisGridPartitionSelector extends Component {
48
48
  model
49
49
  } = _this.props;
50
50
  try {
51
- var keysTable = yield _this.pending.add(model.partitionKeysTable().then(keyTable => {
52
- var sorts = model.partitionColumns.map(column => column.sort().desc());
53
- keyTable.applySort(sorts);
54
- return keyTable;
55
- }), t => t.close());
56
- var partitionTables = yield Promise.all(model.partitionColumns.map( /*#__PURE__*/function () {
57
- var _ref = _asyncToGenerator(function* (_, i) {
58
- return _this.pending.add(keysTable.selectDistinct(model.partitionColumns.slice(0, i + 1)), t => t.close());
59
- });
60
- return function (_x, _x2) {
61
- return _ref.apply(this, arguments);
62
- };
63
- }()));
64
- var partitionFilters = _this.getPartitionFilters(partitionTables);
51
+ var keysTable = yield _this.pending.add(model.partitionKeysTable().then(keyTable => keyTable), t => t.close());
52
+ var baseTable = yield _this.pending.add(model.partitionBaseTable(), t => t.close());
65
53
  _this.setState({
66
- isLoading: false,
67
54
  keysTable,
68
- partitionFilters,
69
- partitionTables
55
+ baseTable,
56
+ isLoading: false
70
57
  });
58
+ _this.updatePartitionOptions();
71
59
  } catch (e) {
72
60
  if (!PromiseUtils.isCanceled(e)) {
73
61
  // Just re-throw the error if it's not a cancel
@@ -84,23 +72,26 @@ class IrisGridPartitionSelector extends Component {
84
72
  partitionConfig
85
73
  } = this.props;
86
74
  if (prevConfig !== partitionConfig) {
87
- this.updatePartitionFilters();
75
+ this.updatePartitionOptions();
88
76
  }
89
77
  }
90
78
  componentWillUnmount() {
91
79
  this.pending.cancel();
92
80
  var {
93
81
  keysTable,
82
+ baseTable,
94
83
  partitionTables
95
84
  } = this.state;
85
+ baseTable === null || baseTable === void 0 ? void 0 : baseTable.close();
96
86
  keysTable === null || keysTable === void 0 ? void 0 : keysTable.close();
97
87
  partitionTables === null || partitionTables === void 0 ? void 0 : partitionTables.forEach(table => table.close());
98
88
  }
99
- handleKeyTableClick() {
100
- log.debug2('handleKeyTableClick');
89
+ handlePartitionTableClick() {
90
+ log.debug2('handlePartitionTableClick');
101
91
  var {
102
92
  partitionConfig
103
93
  } = this.props;
94
+ assertNotNull(partitionConfig);
104
95
  var newPartitionConfig = _objectSpread({}, partitionConfig);
105
96
  // Toggle between Keys and Partition mode
106
97
  newPartitionConfig.mode = partitionConfig.mode === 'keys' ? 'partition' : 'keys';
@@ -111,6 +102,7 @@ class IrisGridPartitionSelector extends Component {
111
102
  var {
112
103
  partitionConfig
113
104
  } = this.props;
105
+ assertNotNull(partitionConfig);
114
106
  var newPartitionConfig = _objectSpread({}, partitionConfig);
115
107
  // Toggle between Merged and Partition mode
116
108
  newPartitionConfig.mode = partitionConfig.mode === 'merged' ? 'partition' : 'merged';
@@ -126,31 +118,25 @@ class IrisGridPartitionSelector extends Component {
126
118
  var _this2 = this;
127
119
  return _asyncToGenerator(function* () {
128
120
  var {
129
- model,
130
121
  partitionConfig: prevConfig
131
122
  } = _this2.props;
123
+ assertNotNull(prevConfig);
132
124
  log.debug('handlePartitionSelect', index, selectedValue, prevConfig);
133
125
  var newPartitions = [...prevConfig.partitions];
134
126
  newPartitions[index] = selectedValue;
135
-
136
- // If it's the last partition changed, we know it's already a valid value, just emit it
137
- if (index === model.partitionColumns.length - 1) {
138
- _this2.sendUpdate({
139
- partitions: newPartitions,
140
- mode: 'partition'
141
- });
142
- return;
143
- }
127
+ var {
128
+ baseTable
129
+ } = _this2.state;
144
130
  var {
145
131
  keysTable
146
132
  } = _this2.state;
147
- // Otherwise, we need to get the value from a filtered key table
133
+ assertNotNull(baseTable);
148
134
  assertNotNull(keysTable);
149
135
  try {
150
136
  _this2.setState({
151
137
  isLoading: true
152
138
  });
153
- var t = yield _this2.pending.add(keysTable.copy(), tCopy => tCopy.close());
139
+ var t = yield _this2.pending.add(baseTable.copy(), tCopy => tCopy.close());
154
140
 
155
141
  // Apply our partition filters, and just get the first value
156
142
  var partitionFilters = newPartitions.slice(0, index + 1).map((partition, i) => {
@@ -164,10 +150,7 @@ class IrisGridPartitionSelector extends Component {
164
150
  // Core JSAPI returns undefined for null table values,
165
151
  // coalesce with null to differentiate null from no selection in the dropdown
166
152
  // https://github.com/deephaven/deephaven-core/issues/5400
167
- partitions: t.columns.map(column => {
168
- var _data$rows$0$get;
169
- return (_data$rows$0$get = data.rows[0].get(column)) !== null && _data$rows$0$get !== void 0 ? _data$rows$0$get : null;
170
- }),
153
+ partitions: keysTable.columns.map(column => data.rows[0].get(column)),
171
154
  mode: 'partition'
172
155
  };
173
156
  t.close();
@@ -214,35 +197,48 @@ class IrisGridPartitionSelector extends Component {
214
197
  }
215
198
 
216
199
  /**
217
- * Update the filters on the partition dropdown tables
200
+ * Update the options on the partition dropdown tables
218
201
  */
219
- updatePartitionFilters() {
220
- var {
221
- partitionTables
222
- } = this.state;
223
- assertNotNull(partitionTables);
224
- var {
225
- partitionConfig
226
- } = this.props;
227
- var {
228
- mode
229
- } = partitionConfig;
230
- log.debug('updatePartitionFilters', partitionConfig);
231
- if (mode !== 'partition') {
232
- // We only need to update the filters if the mode is `partitions`
233
- // In the other modes, we disable the dropdowns anyway
234
- return;
235
- }
236
- var partitionFilters = this.getPartitionFilters(partitionTables);
237
- this.setState({
238
- partitionFilters
239
- });
202
+ updatePartitionOptions() {
203
+ var _this3 = this;
204
+ return _asyncToGenerator(function* () {
205
+ var {
206
+ model
207
+ } = _this3.props;
208
+ var {
209
+ partitionConfig: prevConfig
210
+ } = _this3.props;
211
+ if (prevConfig == null) {
212
+ return;
213
+ }
214
+ var {
215
+ keysTable
216
+ } = _this3.state;
217
+ assertNotNull(keysTable);
218
+ var partitionFilters = [...prevConfig.partitions].map((partition, i) => {
219
+ var partitionColumn = keysTable.columns[i];
220
+ return _this3.tableUtils.makeNullableEqFilter(partitionColumn, partition);
221
+ });
222
+ var partitionTables = yield Promise.all(model.partitionColumns.map( /*#__PURE__*/function () {
223
+ var _ref = _asyncToGenerator(function* (_, i) {
224
+ keysTable.applyFilter(partitionFilters.slice(0, i));
225
+ return keysTable.selectDistinct(model.partitionColumns.slice(0, i + 1));
226
+ });
227
+ return function (_x, _x2) {
228
+ return _ref.apply(this, arguments);
229
+ };
230
+ }()));
231
+ _this3.setState({
232
+ partitionTables
233
+ });
234
+ })();
240
235
  }
241
236
  getPartitionFilters(partitionTables) {
242
237
  var {
243
238
  model,
244
239
  partitionConfig
245
240
  } = this.props;
241
+ assertNotNull(partitionConfig);
246
242
  var {
247
243
  partitions
248
244
  } = partitionConfig;
@@ -274,17 +270,8 @@ class IrisGridPartitionSelector extends Component {
274
270
  } = this.props;
275
271
  var {
276
272
  isLoading,
277
- partitionFilters,
278
273
  partitionTables
279
274
  } = this.state;
280
- var {
281
- partitions
282
- } = partitionConfig;
283
- if (partitionFilters !== null && partitionTables !== null) {
284
- partitionFilters.forEach((filter, index) => {
285
- partitionTables[index].applyFilter(filter);
286
- });
287
- }
288
275
  var partitionSelectors = model.partitionColumns.map((column, index) => /*#__PURE__*/_jsxs("div", {
289
276
  className: "column-selector",
290
277
  children: [(partitionTables === null || partitionTables === void 0 ? void 0 : partitionTables[index]) && /*#__PURE__*/_jsx(Picker, {
@@ -294,30 +281,27 @@ class IrisGridPartitionSelector extends Component {
294
281
  direction: "bottom",
295
282
  shouldFlip: false,
296
283
  keyColumn: partitionTables[index].columns[index].name,
297
- placeholder: 'Loading...',
284
+ selectedKey: (partitionConfig === null || partitionConfig === void 0 ? void 0 : partitionConfig.mode) === 'partition' ? partitionConfig.partitions[index] : null,
285
+ placeholder: "Select a key",
298
286
  labelColumn: partitionTables[index].columns[index].name,
299
287
  onChange: this.getCachedChangeCallback(index),
300
- defaultSelectedKey: partitions[index],
301
- isDisabled: index > 0 && partitionConfig.mode !== 'partition' || isLoading
288
+ isDisabled: isLoading || partitionConfig == null
302
289
  }), model.partitionColumns.length - 1 === index || /*#__PURE__*/_jsx(FontAwesomeIcon, {
303
290
  icon: vsChevronRight
304
291
  })]
305
292
  }, "selector-".concat(column.name)));
306
293
  return /*#__PURE__*/_jsxs("div", {
307
294
  className: "iris-grid-partition-selector",
308
- children: [/*#__PURE__*/_jsx("div", {
309
- className: "table-name",
310
- children: "Partitioned Table"
311
- }), /*#__PURE__*/_jsxs("div", {
295
+ children: [/*#__PURE__*/_jsxs("div", {
312
296
  className: "partition-button-group",
313
297
  children: [/*#__PURE__*/_jsx(Button, {
314
- onClick: this.handleKeyTableClick,
298
+ onClick: this.handlePartitionTableClick,
315
299
  kind: "inline",
316
- tooltip: "View keys as table",
300
+ tooltip: model.isPartitionAwareSourceTable ? 'View keys as table' : 'View underlying partition table',
317
301
  icon: vsKey,
318
- active: partitionConfig.mode === 'keys',
319
- disabled: isLoading,
320
- children: "Keys"
302
+ active: (partitionConfig === null || partitionConfig === void 0 ? void 0 : partitionConfig.mode) === 'keys',
303
+ disabled: isLoading || partitionConfig == null,
304
+ children: "Partitions"
321
305
  }), /*#__PURE__*/_jsx(Button, {
322
306
  onClick: this.handleMergeClick,
323
307
  kind: "inline",
@@ -326,9 +310,9 @@ class IrisGridPartitionSelector extends Component {
326
310
  icon: vsMerge,
327
311
  rotation: 90
328
312
  }),
329
- active: partitionConfig.mode === 'merged',
330
- disabled: isLoading,
331
- children: "Merge"
313
+ active: (partitionConfig === null || partitionConfig === void 0 ? void 0 : partitionConfig.mode) === 'merged',
314
+ disabled: isLoading || partitionConfig == null,
315
+ children: model.isPartitionAwareSourceTable ? 'Coalesce' : 'Merge'
332
316
  })]
333
317
  }), partitionSelectors]
334
318
  });
@@ -1 +1 @@
1
- {"version":3,"file":"IrisGridPartitionSelector.js","names":["React","Component","memoizee","FontAwesomeIcon","Button","vsChevronRight","vsMerge","vsKey","Log","Picker","TableUtils","assertNotNull","Pending","PromiseUtils","jsx","_jsx","jsxs","_jsxs","log","module","IrisGridPartitionSelector","constructor","props","_defineProperty","index","value","handlePartitionSelect","getDisplayValue","handleKeyTableClick","bind","handleMergeClick","model","tableUtils","dh","pending","state","isLoading","keysTable","partitionFilters","partitionTables","componentDidMount","_this","_asyncToGenerator","add","partitionKeysTable","then","keyTable","sorts","partitionColumns","map","column","sort","desc","applySort","t","close","Promise","all","_ref","_","i","selectDistinct","slice","_x","_x2","apply","arguments","getPartitionFilters","setState","e","isCanceled","componentDidUpdate","prevProps","partitionConfig","prevConfig","updatePartitionFilters","componentWillUnmount","cancel","forEach","table","debug2","newPartitionConfig","_objectSpread","mode","sendUpdate","selectedValue","_this2","debug","newPartitions","partitions","length","copy","tCopy","partition","partitionColumn","columns","makeNullableEqFilter","applyFilter","setViewport","data","getViewportData","newConfig","_data$rows$0$get","rows","get","error","onChange","undefined","isCharType","type","toString","String","fromCharCode","parseInt","displayString","name","Error","concat","push","previousFilter","previousPartition","previousColumn","partitionFilter","render","filter","partitionSelectors","className","children","label","labelPosition","direction","shouldFlip","keyColumn","placeholder","labelColumn","getCachedChangeCallback","defaultSelectedKey","isDisabled","icon","onClick","kind","tooltip","active","disabled","rotation"],"sources":["../src/IrisGridPartitionSelector.tsx"],"sourcesContent":["import React, { Component } from 'react';\nimport memoizee from 'memoizee';\nimport { FontAwesomeIcon } from '@fortawesome/react-fontawesome';\nimport { Button, ItemKey } from '@deephaven/components';\nimport { vsChevronRight, vsMerge, vsKey } from '@deephaven/icons';\nimport Log from '@deephaven/log';\nimport { Picker } from '@deephaven/jsapi-components';\nimport type { dh } from '@deephaven/jsapi-types';\nimport { TableUtils } from '@deephaven/jsapi-utils';\nimport { assertNotNull, Pending, PromiseUtils } from '@deephaven/utils';\nimport './IrisGridPartitionSelector.scss';\nimport { PartitionConfig, PartitionedGridModel } from './PartitionedGridModel';\n\nconst log = Log.module('IrisGridPartitionSelector');\n\ninterface IrisGridPartitionSelectorProps {\n model: PartitionedGridModel;\n partitionConfig: PartitionConfig;\n onChange: (partitionConfig: PartitionConfig) => void;\n}\ninterface IrisGridPartitionSelectorState {\n isLoading: boolean;\n\n keysTable: dh.Table | null;\n\n partitionTables: dh.Table[] | null;\n\n /** The filters to apply to each partition table */\n partitionFilters: dh.FilterCondition[][] | null;\n}\nclass IrisGridPartitionSelector extends Component<\n IrisGridPartitionSelectorProps,\n IrisGridPartitionSelectorState\n> {\n constructor(props: IrisGridPartitionSelectorProps) {\n super(props);\n\n this.handleKeyTableClick = this.handleKeyTableClick.bind(this);\n this.handleMergeClick = this.handleMergeClick.bind(this);\n this.handlePartitionSelect = this.handlePartitionSelect.bind(this);\n\n const { model } = props;\n this.tableUtils = new TableUtils(model.dh);\n this.pending = new Pending();\n\n this.state = {\n // We start be loading the partition tables, so we should be in a loading state\n isLoading: true,\n\n keysTable: null,\n partitionFilters: null,\n partitionTables: null,\n };\n }\n\n async componentDidMount(): Promise<void> {\n const { model } = this.props;\n\n try {\n const keysTable = await this.pending.add(\n model.partitionKeysTable().then(keyTable => {\n const sorts = model.partitionColumns.map(column =>\n column.sort().desc()\n );\n keyTable.applySort(sorts);\n return keyTable;\n }),\n t => t.close()\n );\n\n const partitionTables = await Promise.all(\n model.partitionColumns.map(async (_, i) =>\n this.pending.add(\n keysTable.selectDistinct(model.partitionColumns.slice(0, i + 1)),\n t => t.close()\n )\n )\n );\n\n const partitionFilters = this.getPartitionFilters(partitionTables);\n this.setState({\n isLoading: false,\n keysTable,\n partitionFilters,\n partitionTables,\n });\n } catch (e) {\n if (!PromiseUtils.isCanceled(e)) {\n // Just re-throw the error if it's not a cancel\n throw e;\n }\n }\n }\n\n componentDidUpdate(prevProps: IrisGridPartitionSelectorProps): void {\n const { partitionConfig: prevConfig } = prevProps;\n\n const { partitionConfig } = this.props;\n\n if (prevConfig !== partitionConfig) {\n this.updatePartitionFilters();\n }\n }\n\n componentWillUnmount(): void {\n this.pending.cancel();\n\n const { keysTable, partitionTables } = this.state;\n keysTable?.close();\n partitionTables?.forEach(table => table.close());\n }\n\n pending: Pending;\n\n tableUtils: TableUtils;\n\n handleKeyTableClick(): void {\n log.debug2('handleKeyTableClick');\n\n const { partitionConfig } = this.props;\n const newPartitionConfig = { ...partitionConfig };\n // Toggle between Keys and Partition mode\n newPartitionConfig.mode =\n partitionConfig.mode === 'keys' ? 'partition' : 'keys';\n this.sendUpdate(newPartitionConfig);\n }\n\n handleMergeClick(): void {\n log.debug2('handleMergeClick');\n\n const { partitionConfig } = this.props;\n const newPartitionConfig = { ...partitionConfig };\n // Toggle between Merged and Partition mode\n newPartitionConfig.mode =\n partitionConfig.mode === 'merged' ? 'partition' : 'merged';\n this.sendUpdate(newPartitionConfig);\n }\n\n /**\n * Handles when a partition dropdown selection is changed. Will send an update with the new partition config\n * @param index Index of the partition column that was changed\n * @param selectedValue Selected value of the partition column\n */\n async handlePartitionSelect(\n index: number,\n selectedValue: unknown\n ): Promise<void> {\n const { model, partitionConfig: prevConfig } = this.props;\n\n log.debug('handlePartitionSelect', index, selectedValue, prevConfig);\n\n const newPartitions = [...prevConfig.partitions];\n newPartitions[index] = selectedValue;\n\n // If it's the last partition changed, we know it's already a valid value, just emit it\n if (index === model.partitionColumns.length - 1) {\n this.sendUpdate({ partitions: newPartitions, mode: 'partition' });\n return;\n }\n\n const { keysTable } = this.state;\n // Otherwise, we need to get the value from a filtered key table\n assertNotNull(keysTable);\n try {\n this.setState({ isLoading: true });\n const t = await this.pending.add(keysTable.copy(), tCopy =>\n tCopy.close()\n );\n\n // Apply our partition filters, and just get the first value\n const partitionFilters = newPartitions\n .slice(0, index + 1)\n .map((partition, i) => {\n const partitionColumn = t.columns[i];\n return this.tableUtils.makeNullableEqFilter(\n partitionColumn,\n partition\n );\n });\n t.applyFilter(partitionFilters);\n t.setViewport(0, 0, t.columns);\n const data = await this.pending.add(t.getViewportData());\n const newConfig: PartitionConfig = {\n // Core JSAPI returns undefined for null table values,\n // coalesce with null to differentiate null from no selection in the dropdown\n // https://github.com/deephaven/deephaven-core/issues/5400\n partitions: t.columns.map(column => data.rows[0].get(column) ?? null),\n mode: 'partition',\n };\n t.close();\n this.sendUpdate(newConfig);\n } catch (e) {\n if (!PromiseUtils.isCanceled(e)) {\n log.error('Unable to get partition tables', e);\n }\n } finally {\n this.setState({ isLoading: false });\n }\n }\n\n sendUpdate(partitionConfig: PartitionConfig): void {\n log.debug2('sendUpdate', partitionConfig);\n\n const { onChange } = this.props;\n onChange(partitionConfig);\n }\n\n /**\n * Calls model.displayString with a special character case\n * @param index The index of the partition column to get the display value for\n * @param value The partition value to get the display value for\n */\n getDisplayValue(index: number, value: unknown): string {\n const { model } = this.props;\n\n if (value === null) {\n return '(null)';\n }\n\n if (value === undefined || value === '') {\n return '';\n }\n const column = model.partitionColumns[index];\n if (TableUtils.isCharType(column.type) && value.toString().length > 0) {\n return String.fromCharCode(parseInt(value.toString(), 10));\n }\n return model.displayString(value, column.type, column.name);\n }\n\n /**\n * Update the filters on the partition dropdown tables\n */\n updatePartitionFilters(): void {\n const { partitionTables } = this.state;\n assertNotNull(partitionTables);\n\n const { partitionConfig } = this.props;\n const { mode } = partitionConfig;\n log.debug('updatePartitionFilters', partitionConfig);\n if (mode !== 'partition') {\n // We only need to update the filters if the mode is `partitions`\n // In the other modes, we disable the dropdowns anyway\n return;\n }\n\n const partitionFilters = this.getPartitionFilters(partitionTables);\n this.setState({ partitionFilters });\n }\n\n getPartitionFilters(partitionTables: dh.Table[]): dh.FilterCondition[][] {\n const { model, partitionConfig } = this.props;\n const { partitions } = partitionConfig;\n log.debug('getPartitionFilters', partitionConfig);\n\n if (partitions.length !== partitionTables.length) {\n throw new Error(\n `Invalid partition config set. Expected ${partitionTables.length} partitions, but got ${partitions.length}`\n );\n }\n\n // The filters are applied in order, so we need to build up the filters for each partition\n const partitionFilters: dh.FilterCondition[][] = [];\n for (let i = 0; i < partitions.length; i += 1) {\n if (i === 0) {\n // There's no reason to ever filter the first table\n partitionFilters.push([]);\n } else {\n const previousFilter = partitionFilters[i - 1];\n const previousPartition = partitions[i - 1];\n const previousColumn = model.partitionColumns[i - 1];\n const partitionFilter = [\n ...previousFilter,\n this.tableUtils.makeNullableEqFilter(\n previousColumn,\n previousPartition\n ),\n ];\n partitionFilters.push(partitionFilter);\n }\n }\n return partitionFilters;\n }\n\n getCachedChangeCallback = memoizee(\n (index: number) => (value: unknown) =>\n this.handlePartitionSelect(index, value)\n );\n\n getCachedFormatValueCallback = memoizee(\n (index: number) => (value: unknown) => this.getDisplayValue(index, value)\n );\n\n render(): JSX.Element {\n const { model, partitionConfig } = this.props;\n const { isLoading, partitionFilters, partitionTables } = this.state;\n\n const { partitions } = partitionConfig;\n\n if (partitionFilters !== null && partitionTables !== null) {\n partitionFilters.forEach((filter, index) => {\n partitionTables[index].applyFilter(filter as dh.FilterCondition[]);\n });\n }\n const partitionSelectors = model.partitionColumns.map((column, index) => (\n <div key={`selector-${column.name}`} className=\"column-selector\">\n {partitionTables?.[index] && (\n <Picker\n label={column.name}\n labelPosition=\"side\"\n table={partitionTables[index]}\n direction=\"bottom\"\n shouldFlip={false}\n keyColumn={partitionTables[index].columns[index].name}\n placeholder={'Loading...' as string}\n labelColumn={partitionTables[index].columns[index].name}\n onChange={this.getCachedChangeCallback(index)}\n defaultSelectedKey={partitions[index] as ItemKey}\n isDisabled={\n (index > 0 && partitionConfig.mode !== 'partition') || isLoading\n }\n />\n )}\n {model.partitionColumns.length - 1 === index || (\n <FontAwesomeIcon icon={vsChevronRight} />\n )}\n </div>\n ));\n return (\n <div className=\"iris-grid-partition-selector\">\n <div className=\"table-name\">Partitioned Table</div>\n <div className=\"partition-button-group\">\n <Button\n onClick={this.handleKeyTableClick}\n kind=\"inline\"\n tooltip=\"View keys as table\"\n icon={vsKey}\n active={partitionConfig.mode === 'keys'}\n disabled={isLoading}\n >\n Keys\n </Button>\n <Button\n onClick={this.handleMergeClick}\n kind=\"inline\"\n tooltip=\"View all partitions as one merged table\"\n icon={<FontAwesomeIcon icon={vsMerge} rotation={90} />}\n active={partitionConfig.mode === 'merged'}\n disabled={isLoading}\n >\n Merge\n </Button>\n </div>\n {partitionSelectors}\n </div>\n );\n }\n}\n\nexport default IrisGridPartitionSelector;\n"],"mappings":"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"}
1
+ {"version":3,"file":"IrisGridPartitionSelector.js","names":["React","Component","memoizee","FontAwesomeIcon","Button","vsChevronRight","vsMerge","vsKey","Log","Picker","TableUtils","assertNotNull","Pending","PromiseUtils","jsx","_jsx","jsxs","_jsxs","log","module","IrisGridPartitionSelector","constructor","props","_defineProperty","index","value","handlePartitionSelect","getDisplayValue","handlePartitionTableClick","bind","handleMergeClick","model","tableUtils","dh","pending","state","isLoading","baseTable","keysTable","partitionTables","componentDidMount","_this","_asyncToGenerator","add","partitionKeysTable","then","keyTable","t","close","partitionBaseTable","setState","updatePartitionOptions","e","isCanceled","componentDidUpdate","prevProps","partitionConfig","prevConfig","componentWillUnmount","cancel","forEach","table","debug2","newPartitionConfig","_objectSpread","mode","sendUpdate","selectedValue","_this2","debug","newPartitions","partitions","copy","tCopy","partitionFilters","slice","map","partition","i","partitionColumn","columns","makeNullableEqFilter","applyFilter","setViewport","data","getViewportData","newConfig","column","rows","get","error","onChange","undefined","partitionColumns","isCharType","type","toString","length","String","fromCharCode","parseInt","displayString","name","_this3","Promise","all","_ref","_","selectDistinct","_x","_x2","apply","arguments","getPartitionFilters","Error","concat","push","previousFilter","previousPartition","previousColumn","partitionFilter","render","partitionSelectors","className","children","label","labelPosition","direction","shouldFlip","keyColumn","selectedKey","placeholder","labelColumn","getCachedChangeCallback","isDisabled","icon","onClick","kind","tooltip","isPartitionAwareSourceTable","active","disabled","rotation"],"sources":["../src/IrisGridPartitionSelector.tsx"],"sourcesContent":["import React, { Component } from 'react';\nimport memoizee from 'memoizee';\nimport { FontAwesomeIcon } from '@fortawesome/react-fontawesome';\nimport { Button, ItemKey } from '@deephaven/components';\nimport { vsChevronRight, vsMerge, vsKey } from '@deephaven/icons';\nimport Log from '@deephaven/log';\nimport { Picker } from '@deephaven/jsapi-components';\nimport type { dh } from '@deephaven/jsapi-types';\nimport { TableUtils } from '@deephaven/jsapi-utils';\nimport { assertNotNull, Pending, PromiseUtils } from '@deephaven/utils';\nimport './IrisGridPartitionSelector.scss';\nimport { PartitionConfig, PartitionedGridModel } from './PartitionedGridModel';\n\nconst log = Log.module('IrisGridPartitionSelector');\n\ninterface IrisGridPartitionSelectorProps {\n model: PartitionedGridModel;\n partitionConfig?: PartitionConfig;\n onChange: (partitionConfig: PartitionConfig) => void;\n}\ninterface IrisGridPartitionSelectorState {\n isLoading: boolean;\n\n baseTable: dh.Table | null;\n\n keysTable: dh.Table | null;\n\n partitionTables: dh.Table[] | null;\n}\nclass IrisGridPartitionSelector extends Component<\n IrisGridPartitionSelectorProps,\n IrisGridPartitionSelectorState\n> {\n constructor(props: IrisGridPartitionSelectorProps) {\n super(props);\n\n this.handlePartitionTableClick = this.handlePartitionTableClick.bind(this);\n this.handleMergeClick = this.handleMergeClick.bind(this);\n this.handlePartitionSelect = this.handlePartitionSelect.bind(this);\n\n const { model } = props;\n this.tableUtils = new TableUtils(model.dh);\n this.pending = new Pending();\n\n this.state = {\n // We start be loading the partition tables, so we should be in a loading state\n isLoading: true,\n\n baseTable: null,\n keysTable: null,\n partitionTables: null,\n };\n }\n\n async componentDidMount(): Promise<void> {\n const { model } = this.props;\n\n try {\n const keysTable = await this.pending.add(\n model.partitionKeysTable().then(keyTable => keyTable),\n t => t.close()\n );\n\n const baseTable = await this.pending.add(model.partitionBaseTable(), t =>\n t.close()\n );\n\n this.setState({\n keysTable,\n baseTable,\n isLoading: false,\n });\n this.updatePartitionOptions();\n } catch (e) {\n if (!PromiseUtils.isCanceled(e)) {\n // Just re-throw the error if it's not a cancel\n throw e;\n }\n }\n }\n\n componentDidUpdate(prevProps: IrisGridPartitionSelectorProps): void {\n const { partitionConfig: prevConfig } = prevProps;\n\n const { partitionConfig } = this.props;\n\n if (prevConfig !== partitionConfig) {\n this.updatePartitionOptions();\n }\n }\n\n componentWillUnmount(): void {\n this.pending.cancel();\n\n const { keysTable, baseTable, partitionTables } = this.state;\n baseTable?.close();\n keysTable?.close();\n partitionTables?.forEach(table => table.close());\n }\n\n pending: Pending;\n\n tableUtils: TableUtils;\n\n handlePartitionTableClick(): void {\n log.debug2('handlePartitionTableClick');\n\n const { partitionConfig } = this.props;\n assertNotNull(partitionConfig);\n\n const newPartitionConfig = { ...partitionConfig };\n // Toggle between Keys and Partition mode\n newPartitionConfig.mode =\n partitionConfig.mode === 'keys' ? 'partition' : 'keys';\n this.sendUpdate(newPartitionConfig);\n }\n\n handleMergeClick(): void {\n log.debug2('handleMergeClick');\n\n const { partitionConfig } = this.props;\n assertNotNull(partitionConfig);\n const newPartitionConfig = { ...partitionConfig };\n // Toggle between Merged and Partition mode\n newPartitionConfig.mode =\n partitionConfig.mode === 'merged' ? 'partition' : 'merged';\n this.sendUpdate(newPartitionConfig);\n }\n\n /**\n * Handles when a partition dropdown selection is changed. Will send an update with the new partition config\n * @param index Index of the partition column that was changed\n * @param selectedValue Selected value of the partition column\n */\n async handlePartitionSelect(\n index: number,\n selectedValue: unknown\n ): Promise<void> {\n const { partitionConfig: prevConfig } = this.props;\n assertNotNull(prevConfig);\n\n log.debug('handlePartitionSelect', index, selectedValue, prevConfig);\n\n const newPartitions = [...prevConfig.partitions];\n newPartitions[index] = selectedValue;\n\n const { baseTable } = this.state;\n const { keysTable } = this.state;\n\n assertNotNull(baseTable);\n assertNotNull(keysTable);\n try {\n this.setState({ isLoading: true });\n\n const t = await this.pending.add(baseTable.copy(), tCopy =>\n tCopy.close()\n );\n\n // Apply our partition filters, and just get the first value\n const partitionFilters = newPartitions\n .slice(0, index + 1)\n .map((partition, i) => {\n const partitionColumn = t.columns[i];\n return this.tableUtils.makeNullableEqFilter(\n partitionColumn,\n partition\n );\n });\n t.applyFilter(partitionFilters);\n t.setViewport(0, 0, t.columns);\n const data = await this.pending.add(t.getViewportData());\n const newConfig: PartitionConfig = {\n // Core JSAPI returns undefined for null table values,\n // coalesce with null to differentiate null from no selection in the dropdown\n // https://github.com/deephaven/deephaven-core/issues/5400\n partitions: keysTable.columns.map(column => data.rows[0].get(column)),\n mode: 'partition',\n };\n t.close();\n this.sendUpdate(newConfig);\n } catch (e) {\n if (!PromiseUtils.isCanceled(e)) {\n log.error('Unable to get partition tables', e);\n }\n } finally {\n this.setState({ isLoading: false });\n }\n }\n\n sendUpdate(partitionConfig: PartitionConfig): void {\n log.debug2('sendUpdate', partitionConfig);\n\n const { onChange } = this.props;\n onChange(partitionConfig);\n }\n\n /**\n * Calls model.displayString with a special character case\n * @param index The index of the partition column to get the display value for\n * @param value The partition value to get the display value for\n */\n getDisplayValue(index: number, value: unknown): string {\n const { model } = this.props;\n\n if (value === null) {\n return '(null)';\n }\n\n if (value === undefined || value === '') {\n return '';\n }\n const column = model.partitionColumns[index];\n if (TableUtils.isCharType(column.type) && value.toString().length > 0) {\n return String.fromCharCode(parseInt(value.toString(), 10));\n }\n return model.displayString(value, column.type, column.name);\n }\n\n /**\n * Update the options on the partition dropdown tables\n */\n async updatePartitionOptions(): Promise<void> {\n const { model } = this.props;\n const { partitionConfig: prevConfig } = this.props;\n if (prevConfig == null) {\n return;\n }\n\n const { keysTable } = this.state;\n assertNotNull(keysTable);\n\n const partitionFilters = [...prevConfig.partitions].map((partition, i) => {\n const partitionColumn = keysTable.columns[i];\n return this.tableUtils.makeNullableEqFilter(partitionColumn, partition);\n });\n\n const partitionTables = await Promise.all(\n model.partitionColumns.map(async (_, i) => {\n keysTable.applyFilter(partitionFilters.slice(0, i));\n return keysTable.selectDistinct(model.partitionColumns.slice(0, i + 1));\n })\n );\n\n this.setState({ partitionTables });\n }\n\n getPartitionFilters(partitionTables: dh.Table[]): dh.FilterCondition[][] {\n const { model, partitionConfig } = this.props;\n assertNotNull(partitionConfig);\n const { partitions } = partitionConfig;\n log.debug('getPartitionFilters', partitionConfig);\n\n if (partitions.length !== partitionTables.length) {\n throw new Error(\n `Invalid partition config set. Expected ${partitionTables.length} partitions, but got ${partitions.length}`\n );\n }\n\n // The filters are applied in order, so we need to build up the filters for each partition\n const partitionFilters: dh.FilterCondition[][] = [];\n for (let i = 0; i < partitions.length; i += 1) {\n if (i === 0) {\n // There's no reason to ever filter the first table\n partitionFilters.push([]);\n } else {\n const previousFilter = partitionFilters[i - 1];\n const previousPartition = partitions[i - 1];\n const previousColumn = model.partitionColumns[i - 1];\n const partitionFilter = [\n ...previousFilter,\n this.tableUtils.makeNullableEqFilter(\n previousColumn,\n previousPartition\n ),\n ];\n partitionFilters.push(partitionFilter);\n }\n }\n return partitionFilters;\n }\n\n getCachedChangeCallback = memoizee(\n (index: number) => (value: unknown) =>\n this.handlePartitionSelect(index, value)\n );\n\n getCachedFormatValueCallback = memoizee(\n (index: number) => (value: unknown) => this.getDisplayValue(index, value)\n );\n\n render(): JSX.Element {\n const { model, partitionConfig } = this.props;\n const { isLoading, partitionTables } = this.state;\n\n const partitionSelectors = model.partitionColumns.map((column, index) => (\n <div key={`selector-${column.name}`} className=\"column-selector\">\n {partitionTables?.[index] && (\n <Picker\n label={column.name}\n labelPosition=\"side\"\n table={partitionTables[index]}\n direction=\"bottom\"\n shouldFlip={false}\n keyColumn={partitionTables[index].columns[index].name}\n selectedKey={\n partitionConfig?.mode === 'partition'\n ? (partitionConfig.partitions[index] as ItemKey)\n : null\n }\n placeholder=\"Select a key\"\n labelColumn={partitionTables[index].columns[index].name}\n onChange={this.getCachedChangeCallback(index)}\n isDisabled={isLoading || partitionConfig == null}\n />\n )}\n {model.partitionColumns.length - 1 === index || (\n <FontAwesomeIcon icon={vsChevronRight} />\n )}\n </div>\n ));\n return (\n <div className=\"iris-grid-partition-selector\">\n <div className=\"partition-button-group\">\n <Button\n onClick={this.handlePartitionTableClick}\n kind=\"inline\"\n tooltip={\n model.isPartitionAwareSourceTable\n ? 'View keys as table'\n : 'View underlying partition table'\n }\n icon={vsKey}\n active={partitionConfig?.mode === 'keys'}\n disabled={isLoading || partitionConfig == null}\n >\n Partitions\n </Button>\n <Button\n onClick={this.handleMergeClick}\n kind=\"inline\"\n tooltip=\"View all partitions as one merged table\"\n icon={<FontAwesomeIcon icon={vsMerge} rotation={90} />}\n active={partitionConfig?.mode === 'merged'}\n disabled={isLoading || partitionConfig == null}\n >\n {model.isPartitionAwareSourceTable ? 'Coalesce' : 'Merge'}\n </Button>\n </div>\n {partitionSelectors}\n </div>\n );\n }\n}\n\nexport default IrisGridPartitionSelector;\n"],"mappings":"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"}
@@ -12,12 +12,17 @@ declare class IrisGridPartitionedTableModel extends EmptyIrisGridModel implement
12
12
  */
13
13
  constructor(dh: typeof DhType, partitionedTable: DhType.PartitionedTable, formatter?: Formatter);
14
14
  get isPartitionRequired(): boolean;
15
+ get isPartitionAwareSourceTable(): boolean;
15
16
  get isReversible(): boolean;
16
17
  displayString(value: unknown, columnType: string, columnName?: ColumnName): string;
17
18
  close(): void;
18
19
  get columns(): readonly DhType.Column[];
19
20
  get partitionColumns(): readonly DhType.Column[];
21
+ get columnCount(): number;
22
+ getColumnIndexByName(columnName: string): number;
23
+ textForColumnHeader(column: number, depth?: number | undefined): string | undefined;
20
24
  partitionKeysTable(): Promise<DhType.Table>;
25
+ partitionBaseTable(): Promise<DhType.Table>;
21
26
  partitionMergedTable(): Promise<DhType.Table>;
22
27
  partitionTable(partitions: unknown[]): Promise<DhType.Table>;
23
28
  }
@@ -1 +1 @@
1
- {"version":3,"file":"IrisGridPartitionedTableModel.d.ts","sourceRoot":"","sources":["../src/IrisGridPartitionedTableModel.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,EAAE,IAAI,MAAM,EAAE,MAAM,wBAAwB,CAAC;AAC3D,OAAO,EAAE,SAAS,EAAE,MAAM,wBAAwB,CAAC;AACnD,OAAO,EAAE,UAAU,EAAE,MAAM,eAAe,CAAC;AAC3C,OAAO,kBAAkB,MAAM,sBAAsB,CAAC;AAItD,OAAO,EAAE,4BAA4B,EAAE,MAAM,wBAAwB,CAAC;AAEtE,cAAM,6BACJ,SAAQ,kBACR,YAAW,4BAA4B;IAEvC,QAAQ,CAAC,gBAAgB,EAAE,MAAM,CAAC,gBAAgB,CAAC;IAEnD;;;;OAIG;gBAED,EAAE,EAAE,OAAO,MAAM,EACjB,gBAAgB,EAAE,MAAM,CAAC,gBAAgB,EACzC,SAAS,YAAoB;IAM/B,IAAI,mBAAmB,IAAI,OAAO,CAEjC;IAED,IAAI,YAAY,IAAI,OAAO,CAE1B;IAED,aAAa,CACX,KAAK,EAAE,OAAO,EACd,UAAU,EAAE,MAAM,EAClB,UAAU,CAAC,EAAE,UAAU,GACtB,MAAM;IAIT,KAAK,IAAI,IAAI;IAIb,IAAI,OAAO,IAAI,SAAS,MAAM,CAAC,MAAM,EAAE,CAEtC;IAED,IAAI,gBAAgB,IAAI,SAAS,MAAM,CAAC,MAAM,EAAE,CAE/C;IAEK,kBAAkB,IAAI,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC;IAI3C,oBAAoB,IAAI,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC;IAI7C,cAAc,CAAC,UAAU,EAAE,OAAO,EAAE,GAAG,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC;CAgBnE;AAED,eAAe,6BAA6B,CAAC"}
1
+ {"version":3,"file":"IrisGridPartitionedTableModel.d.ts","sourceRoot":"","sources":["../src/IrisGridPartitionedTableModel.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,EAAE,IAAI,MAAM,EAAE,MAAM,wBAAwB,CAAC;AAC3D,OAAO,EAAE,SAAS,EAAE,MAAM,wBAAwB,CAAC;AACnD,OAAO,EAAE,UAAU,EAAE,MAAM,eAAe,CAAC;AAC3C,OAAO,kBAAkB,MAAM,sBAAsB,CAAC;AAItD,OAAO,EAAE,4BAA4B,EAAE,MAAM,wBAAwB,CAAC;AAEtE,cAAM,6BACJ,SAAQ,kBACR,YAAW,4BAA4B;IAEvC,QAAQ,CAAC,gBAAgB,EAAE,MAAM,CAAC,gBAAgB,CAAC;IAEnD;;;;OAIG;gBAED,EAAE,EAAE,OAAO,MAAM,EACjB,gBAAgB,EAAE,MAAM,CAAC,gBAAgB,EACzC,SAAS,YAAoB;IAM/B,IAAI,mBAAmB,IAAI,OAAO,CAEjC;IAED,IAAI,2BAA2B,IAAI,OAAO,CAEzC;IAED,IAAI,YAAY,IAAI,OAAO,CAE1B;IAED,aAAa,CACX,KAAK,EAAE,OAAO,EACd,UAAU,EAAE,MAAM,EAClB,UAAU,CAAC,EAAE,UAAU,GACtB,MAAM;IAIT,KAAK,IAAI,IAAI;IAIb,IAAI,OAAO,IAAI,SAAS,MAAM,CAAC,MAAM,EAAE,CAEtC;IAED,IAAI,gBAAgB,IAAI,SAAS,MAAM,CAAC,MAAM,EAAE,CAE/C;IAED,IAAI,WAAW,IAAI,MAAM,CAExB;IAED,oBAAoB,CAAC,UAAU,EAAE,MAAM,GAAG,MAAM;IAIhD,mBAAmB,CACjB,MAAM,EAAE,MAAM,EACd,KAAK,CAAC,EAAE,MAAM,GAAG,SAAS,GACzB,MAAM,GAAG,SAAS;IAIf,kBAAkB,IAAI,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC;IAI3C,kBAAkB,IAAI,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC;IAK3C,oBAAoB,IAAI,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC;IAI7C,cAAc,CAAC,UAAU,EAAE,OAAO,EAAE,GAAG,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC;CAgBnE;AAED,eAAe,6BAA6B,CAAC"}
@@ -23,6 +23,9 @@ class IrisGridPartitionedTableModel extends EmptyIrisGridModel {
23
23
  get isPartitionRequired() {
24
24
  return true;
25
25
  }
26
+ get isPartitionAwareSourceTable() {
27
+ return false;
28
+ }
26
29
  get isReversible() {
27
30
  return false;
28
31
  }
@@ -38,23 +41,40 @@ class IrisGridPartitionedTableModel extends EmptyIrisGridModel {
38
41
  get partitionColumns() {
39
42
  return this.partitionedTable.keyColumns;
40
43
  }
44
+ get columnCount() {
45
+ return this.columns.length;
46
+ }
47
+ getColumnIndexByName(columnName) {
48
+ return this.columns.findIndex(column => column.name === columnName);
49
+ }
50
+ textForColumnHeader(column, depth) {
51
+ var _this$columns$column$;
52
+ return (_this$columns$column$ = this.columns[column].name) !== null && _this$columns$column$ !== void 0 ? _this$columns$column$ : '';
53
+ }
41
54
  partitionKeysTable() {
42
55
  var _this = this;
43
56
  return _asyncToGenerator(function* () {
44
57
  return _this.partitionedTable.getKeyTable();
45
58
  })();
46
59
  }
47
- partitionMergedTable() {
60
+ partitionBaseTable() {
48
61
  var _this2 = this;
49
62
  return _asyncToGenerator(function* () {
50
- return _this2.partitionedTable.getMergedTable();
63
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
64
+ return _this2.partitionedTable.getBaseTable();
51
65
  })();
52
66
  }
53
- partitionTable(partitions) {
67
+ partitionMergedTable() {
54
68
  var _this3 = this;
69
+ return _asyncToGenerator(function* () {
70
+ return _this3.partitionedTable.getMergedTable();
71
+ })();
72
+ }
73
+ partitionTable(partitions) {
74
+ var _this4 = this;
55
75
  return _asyncToGenerator(function* () {
56
76
  try {
57
- var table = yield _this3.partitionedTable.getTable(partitions);
77
+ var table = yield _this4.partitionedTable.getTable(partitions);
58
78
  if (table == null) {
59
79
  // TODO: Will be unnecessary with https://github.com/deephaven/deephaven-core/pull/5050
60
80
  throw new MissingPartitionError('Partition not found');