@deephaven/iris-grid 0.46.1-beta.2 → 0.46.1-beta.4

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 (99) hide show
  1. package/dist/AdvancedFilterCreator.js +122 -102
  2. package/dist/AdvancedFilterCreator.js.map +1 -1
  3. package/dist/AdvancedFilterCreatorFilterItem.js +47 -38
  4. package/dist/AdvancedFilterCreatorFilterItem.js.map +1 -1
  5. package/dist/AdvancedFilterCreatorSelectValue.js +52 -40
  6. package/dist/AdvancedFilterCreatorSelectValue.js.map +1 -1
  7. package/dist/AdvancedFilterCreatorSelectValueList.js +35 -28
  8. package/dist/AdvancedFilterCreatorSelectValueList.js.map +1 -1
  9. package/dist/ColumnStatistics.js +74 -54
  10. package/dist/ColumnStatistics.js.map +1 -1
  11. package/dist/CrossColumnSearch.js +113 -90
  12. package/dist/CrossColumnSearch.js.map +1 -1
  13. package/dist/FilterInputField.js +42 -35
  14. package/dist/FilterInputField.js.map +1 -1
  15. package/dist/GotoRow.js +226 -193
  16. package/dist/GotoRow.js.map +1 -1
  17. package/dist/IrisGrid.js +371 -344
  18. package/dist/IrisGrid.js.map +1 -1
  19. package/dist/IrisGridBottomBar.js +11 -8
  20. package/dist/IrisGridBottomBar.js.map +1 -1
  21. package/dist/IrisGridCellOverflowModal.js +56 -50
  22. package/dist/IrisGridCellOverflowModal.js.map +1 -1
  23. package/dist/IrisGridCopyHandler.js +34 -24
  24. package/dist/IrisGridCopyHandler.js.map +1 -1
  25. package/dist/IrisGridPartitionSelector.js +59 -46
  26. package/dist/IrisGridPartitionSelector.js.map +1 -1
  27. package/dist/PartitionSelectorSearch.js +43 -36
  28. package/dist/PartitionSelectorSearch.js.map +1 -1
  29. package/dist/PendingDataBottomBar.js +34 -22
  30. package/dist/PendingDataBottomBar.js.map +1 -1
  31. package/dist/ToastBottomBar.js +5 -3
  32. package/dist/ToastBottomBar.js.map +1 -1
  33. package/dist/format-context-menus/CustomFormatAction.js +34 -25
  34. package/dist/format-context-menus/CustomFormatAction.js.map +1 -1
  35. package/dist/format-context-menus/FormatContextMenuUtils.js +2 -1
  36. package/dist/format-context-menus/FormatContextMenuUtils.js.map +1 -1
  37. package/dist/mousehandlers/IrisGridContextMenuHandler.js +50 -36
  38. package/dist/mousehandlers/IrisGridContextMenuHandler.js.map +1 -1
  39. package/dist/sidebar/AdvancedSettingsMenu.js +2 -1
  40. package/dist/sidebar/AdvancedSettingsMenu.js.map +1 -1
  41. package/dist/sidebar/ChartBuilder.js +134 -107
  42. package/dist/sidebar/ChartBuilder.js.map +1 -1
  43. package/dist/sidebar/CustomColumnBuilder.js +70 -48
  44. package/dist/sidebar/CustomColumnBuilder.js.map +1 -1
  45. package/dist/sidebar/CustomColumnInput.js +66 -53
  46. package/dist/sidebar/CustomColumnInput.js.map +1 -1
  47. package/dist/sidebar/InputEditor.js +15 -11
  48. package/dist/sidebar/InputEditor.js.map +1 -1
  49. package/dist/sidebar/RollupRows.js +130 -103
  50. package/dist/sidebar/RollupRows.js.map +1 -1
  51. package/dist/sidebar/SelectDistinctBuilder.js +49 -39
  52. package/dist/sidebar/SelectDistinctBuilder.js.map +1 -1
  53. package/dist/sidebar/TableCsvExporter.js +178 -128
  54. package/dist/sidebar/TableCsvExporter.js.map +1 -1
  55. package/dist/sidebar/aggregations/AggregationEdit.js +67 -57
  56. package/dist/sidebar/aggregations/AggregationEdit.js.map +1 -1
  57. package/dist/sidebar/aggregations/Aggregations.js +86 -63
  58. package/dist/sidebar/aggregations/Aggregations.js.map +1 -1
  59. package/dist/sidebar/conditional-formatting/ColumnFormatEditor.js +30 -22
  60. package/dist/sidebar/conditional-formatting/ColumnFormatEditor.js.map +1 -1
  61. package/dist/sidebar/conditional-formatting/ConditionEditor.js +52 -47
  62. package/dist/sidebar/conditional-formatting/ConditionEditor.js.map +1 -1
  63. package/dist/sidebar/conditional-formatting/ConditionalFormatEditor.js +52 -42
  64. package/dist/sidebar/conditional-formatting/ConditionalFormatEditor.js.map +1 -1
  65. package/dist/sidebar/conditional-formatting/ConditionalFormattingMenu.js +90 -67
  66. package/dist/sidebar/conditional-formatting/ConditionalFormattingMenu.js.map +1 -1
  67. package/dist/sidebar/conditional-formatting/RowFormatEditor.js +30 -22
  68. package/dist/sidebar/conditional-formatting/RowFormatEditor.js.map +1 -1
  69. package/dist/sidebar/conditional-formatting/StyleEditor.js +70 -58
  70. package/dist/sidebar/conditional-formatting/StyleEditor.js.map +1 -1
  71. package/dist/sidebar/icons/BarIcon.js +21 -12
  72. package/dist/sidebar/icons/BarIcon.js.map +1 -1
  73. package/dist/sidebar/icons/FormatColumnWhereIcon.js +38 -30
  74. package/dist/sidebar/icons/FormatColumnWhereIcon.js.map +1 -1
  75. package/dist/sidebar/icons/FormatRowWhereIcon.js +32 -24
  76. package/dist/sidebar/icons/FormatRowWhereIcon.js.map +1 -1
  77. package/dist/sidebar/icons/HistogramIcon.js +21 -12
  78. package/dist/sidebar/icons/HistogramIcon.js.map +1 -1
  79. package/dist/sidebar/icons/LineIcon.js +24 -15
  80. package/dist/sidebar/icons/LineIcon.js.map +1 -1
  81. package/dist/sidebar/icons/PieIcon.js +21 -12
  82. package/dist/sidebar/icons/PieIcon.js.map +1 -1
  83. package/dist/sidebar/icons/ScatterIcon.js +71 -62
  84. package/dist/sidebar/icons/ScatterIcon.js.map +1 -1
  85. package/dist/sidebar/visibility-ordering-builder/VisibilityOrderingBuilder.js +129 -121
  86. package/dist/sidebar/visibility-ordering-builder/VisibilityOrderingBuilder.js.map +1 -1
  87. package/dist/sidebar/visibility-ordering-builder/VisibilityOrderingGroup.js +121 -87
  88. package/dist/sidebar/visibility-ordering-builder/VisibilityOrderingGroup.js.map +1 -1
  89. package/dist/sidebar/visibility-ordering-builder/VisibilityOrderingItem.js +40 -26
  90. package/dist/sidebar/visibility-ordering-builder/VisibilityOrderingItem.js.map +1 -1
  91. package/dist/sidebar/visibility-ordering-builder/sortable-tree/SortableTree.js +17 -14
  92. package/dist/sidebar/visibility-ordering-builder/sortable-tree/SortableTree.js.map +1 -1
  93. package/dist/sidebar/visibility-ordering-builder/sortable-tree/SortableTreeInner.js +34 -28
  94. package/dist/sidebar/visibility-ordering-builder/sortable-tree/SortableTreeInner.js.map +1 -1
  95. package/dist/sidebar/visibility-ordering-builder/sortable-tree/SortableTreeItem.js +2 -2
  96. package/dist/sidebar/visibility-ordering-builder/sortable-tree/SortableTreeItem.js.map +1 -1
  97. package/dist/sidebar/visibility-ordering-builder/sortable-tree/TreeItem.js +8 -7
  98. package/dist/sidebar/visibility-ordering-builder/sortable-tree/TreeItem.js.map +1 -1
  99. package/package.json +15 -15
@@ -1 +1 @@
1
- {"version":3,"file":"SelectDistinctBuilder.js","names":["React","Component","deepEqual","FontAwesomeIcon","dhNewCircleLargeFilled","vsTrash","Button","Log","log","module","SelectDistinctBuilder","constructor","props","handleAddColumnClick","bind","handleDeleteColumn","handleDropdownChanged","model","selectDistinctColumns","state","inputs","length","columns","originalColumns","componentDidUpdate","prevProps","prevState","onChange","filteredInputs","filter","val","setState","prevInputs","index","input","inputIndex","event","debug","value","target","renderInputs","map","options","name","includes","render","disableAddButton","undefined"],"sources":["../../src/sidebar/SelectDistinctBuilder.tsx"],"sourcesContent":["import React, { Component, ReactElement } from 'react';\nimport deepEqual from 'deep-equal';\nimport { FontAwesomeIcon } from '@fortawesome/react-fontawesome';\nimport { dhNewCircleLargeFilled, vsTrash } from '@deephaven/icons';\nimport { Button } from '@deephaven/components';\nimport Log from '@deephaven/log';\nimport type { Column } from '@deephaven/jsapi-types';\nimport { ModelIndex } from '@deephaven/grid';\nimport IrisGridModel from '../IrisGridModel';\n\nimport './SelectDistinctBuilder.scss';\nimport { ColumnName } from '../CommonTypes';\n\nconst log = Log.module('SelectDistinctBuilder');\n\ninterface SelectDistinctBuilderProps {\n model: IrisGridModel;\n selectDistinctColumns: readonly ColumnName[];\n onChange: (newStr: readonly string[]) => void;\n}\ninterface SelectDistinctBuilderState {\n inputs: readonly string[];\n columns: readonly Column[];\n}\nclass SelectDistinctBuilder extends Component<\n SelectDistinctBuilderProps,\n SelectDistinctBuilderState\n> {\n static defaultProps = {\n selectDistinctColumns: [],\n onChange: (): void => undefined,\n };\n\n constructor(props: SelectDistinctBuilderProps) {\n super(props);\n\n this.handleAddColumnClick = this.handleAddColumnClick.bind(this);\n this.handleDeleteColumn = this.handleDeleteColumn.bind(this);\n this.handleDropdownChanged = this.handleDropdownChanged.bind(this);\n\n const { model, selectDistinctColumns } = this.props;\n\n this.state = {\n inputs:\n selectDistinctColumns.length > 0 ? [...selectDistinctColumns] : [''],\n columns: model.originalColumns,\n };\n }\n\n componentDidUpdate(\n prevProps: SelectDistinctBuilderProps,\n prevState: SelectDistinctBuilderState\n ): void {\n const { inputs } = this.state;\n const { onChange } = this.props;\n if (prevState.inputs !== inputs) {\n const filteredInputs = inputs.filter(val => val !== '');\n if (\n !deepEqual(\n prevState.inputs.filter(val => val !== ''),\n filteredInputs\n )\n ) {\n onChange(filteredInputs);\n }\n }\n }\n\n handleAddColumnClick(): void {\n this.setState(({ inputs: prevInputs }) => ({\n inputs: [...prevInputs, ''],\n }));\n }\n\n handleDeleteColumn(index: ModelIndex): void {\n this.setState(({ inputs }) => ({\n inputs:\n inputs.length === 1 && index === 0\n ? ['']\n : inputs.filter((input, inputIndex) => index !== inputIndex),\n }));\n }\n\n handleDropdownChanged(\n index: number,\n event: React.ChangeEvent<HTMLSelectElement>\n ): void {\n log.debug('handleDropdownChanged', index, event);\n const { value } = event.target;\n this.setState(({ inputs: prevInputs }) => {\n const inputs = [...prevInputs];\n inputs[index] = value;\n return { inputs };\n });\n }\n\n renderInputs(): ReactElement[] {\n const { columns, inputs } = this.state;\n\n return inputs.map((value, index) => {\n const options = columns\n .filter(({ name }) => name === value || !inputs.includes(name))\n .map(({ name }) => (\n <option value={name} key={name}>\n {name}\n </option>\n ));\n return (\n // eslint-disable-next-line react/no-array-index-key\n <div className=\"form-inline px-3 pb-3\" key={index}>\n <select\n className=\"form-control custom-select col\"\n value={value}\n onChange={event => this.handleDropdownChanged(index, event)}\n >\n <option value=\"\">Select a column</option>\n {options}\n </select>\n\n {(inputs.length > 1 || value !== '') && (\n <Button\n kind=\"ghost\"\n className=\"ml-1 px-2\"\n onClick={() => {\n this.handleDeleteColumn(index);\n }}\n icon={<FontAwesomeIcon icon={vsTrash} transform=\"grow-3\" />}\n tooltip=\"Delete column\"\n />\n )}\n </div>\n );\n });\n }\n\n render(): React.ReactElement {\n const { columns, inputs } = this.state;\n const disableAddButton = inputs.length >= columns.length;\n return (\n <div\n role=\"presentation\"\n className=\"select-distinct-builder-container h-100\"\n >\n <div className=\"select-distinct-title\">Display Unique Values From</div>\n\n {this.renderInputs()}\n\n <hr />\n\n <div className=\"pt-1 px-3\">\n <Button\n kind=\"ghost\"\n className=\"btn-add-column\"\n onClick={this.handleAddColumnClick}\n disabled={disableAddButton}\n icon={dhNewCircleLargeFilled}\n >\n Add Additional Column\n </Button>\n </div>\n\n <div className=\"select-distinct-builder-footer\">\n <div className=\"select-distinct-builder-hint\">\n Display only unique values from the selected table columns. Note\n that this will reset any filters and display only the selected\n columns.\n </div>\n </div>\n </div>\n );\n }\n}\n\nexport default SelectDistinctBuilder;\n"],"mappings":"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"}
1
+ {"version":3,"file":"SelectDistinctBuilder.js","names":["React","Component","deepEqual","FontAwesomeIcon","dhNewCircleLargeFilled","vsTrash","Button","Log","log","module","SelectDistinctBuilder","constructor","props","handleAddColumnClick","bind","handleDeleteColumn","handleDropdownChanged","model","selectDistinctColumns","state","inputs","length","columns","originalColumns","componentDidUpdate","prevProps","prevState","onChange","filteredInputs","filter","val","setState","prevInputs","index","input","inputIndex","event","debug","value","target","renderInputs","map","options","name","includes","render","disableAddButton","undefined"],"sources":["../../src/sidebar/SelectDistinctBuilder.tsx"],"sourcesContent":["import React, { Component, ReactElement } from 'react';\nimport deepEqual from 'deep-equal';\nimport { FontAwesomeIcon } from '@fortawesome/react-fontawesome';\nimport { dhNewCircleLargeFilled, vsTrash } from '@deephaven/icons';\nimport { Button } from '@deephaven/components';\nimport Log from '@deephaven/log';\nimport type { Column } from '@deephaven/jsapi-types';\nimport { ModelIndex } from '@deephaven/grid';\nimport IrisGridModel from '../IrisGridModel';\n\nimport './SelectDistinctBuilder.scss';\nimport { ColumnName } from '../CommonTypes';\n\nconst log = Log.module('SelectDistinctBuilder');\n\ninterface SelectDistinctBuilderProps {\n model: IrisGridModel;\n selectDistinctColumns: readonly ColumnName[];\n onChange: (newStr: readonly string[]) => void;\n}\ninterface SelectDistinctBuilderState {\n inputs: readonly string[];\n columns: readonly Column[];\n}\nclass SelectDistinctBuilder extends Component<\n SelectDistinctBuilderProps,\n SelectDistinctBuilderState\n> {\n static defaultProps = {\n selectDistinctColumns: [],\n onChange: (): void => undefined,\n };\n\n constructor(props: SelectDistinctBuilderProps) {\n super(props);\n\n this.handleAddColumnClick = this.handleAddColumnClick.bind(this);\n this.handleDeleteColumn = this.handleDeleteColumn.bind(this);\n this.handleDropdownChanged = this.handleDropdownChanged.bind(this);\n\n const { model, selectDistinctColumns } = this.props;\n\n this.state = {\n inputs:\n selectDistinctColumns.length > 0 ? [...selectDistinctColumns] : [''],\n columns: model.originalColumns,\n };\n }\n\n componentDidUpdate(\n prevProps: SelectDistinctBuilderProps,\n prevState: SelectDistinctBuilderState\n ): void {\n const { inputs } = this.state;\n const { onChange } = this.props;\n if (prevState.inputs !== inputs) {\n const filteredInputs = inputs.filter(val => val !== '');\n if (\n !deepEqual(\n prevState.inputs.filter(val => val !== ''),\n filteredInputs\n )\n ) {\n onChange(filteredInputs);\n }\n }\n }\n\n handleAddColumnClick(): void {\n this.setState(({ inputs: prevInputs }) => ({\n inputs: [...prevInputs, ''],\n }));\n }\n\n handleDeleteColumn(index: ModelIndex): void {\n this.setState(({ inputs }) => ({\n inputs:\n inputs.length === 1 && index === 0\n ? ['']\n : inputs.filter((input, inputIndex) => index !== inputIndex),\n }));\n }\n\n handleDropdownChanged(\n index: number,\n event: React.ChangeEvent<HTMLSelectElement>\n ): void {\n log.debug('handleDropdownChanged', index, event);\n const { value } = event.target;\n this.setState(({ inputs: prevInputs }) => {\n const inputs = [...prevInputs];\n inputs[index] = value;\n return { inputs };\n });\n }\n\n renderInputs(): ReactElement[] {\n const { columns, inputs } = this.state;\n\n return inputs.map((value, index) => {\n const options = columns\n .filter(({ name }) => name === value || !inputs.includes(name))\n .map(({ name }) => (\n <option value={name} key={name}>\n {name}\n </option>\n ));\n return (\n // eslint-disable-next-line react/no-array-index-key\n <div className=\"form-inline px-3 pb-3\" key={index}>\n <select\n className=\"form-control custom-select col\"\n value={value}\n onChange={event => this.handleDropdownChanged(index, event)}\n >\n <option value=\"\">Select a column</option>\n {options}\n </select>\n\n {(inputs.length > 1 || value !== '') && (\n <Button\n kind=\"ghost\"\n className=\"ml-1 px-2\"\n onClick={() => {\n this.handleDeleteColumn(index);\n }}\n icon={<FontAwesomeIcon icon={vsTrash} transform=\"grow-3\" />}\n tooltip=\"Delete column\"\n />\n )}\n </div>\n );\n });\n }\n\n render(): React.ReactElement {\n const { columns, inputs } = this.state;\n const disableAddButton = inputs.length >= columns.length;\n return (\n <div\n role=\"presentation\"\n className=\"select-distinct-builder-container h-100\"\n >\n <div className=\"select-distinct-title\">Display Unique Values From</div>\n\n {this.renderInputs()}\n\n <hr />\n\n <div className=\"pt-1 px-3\">\n <Button\n kind=\"ghost\"\n className=\"btn-add-column\"\n onClick={this.handleAddColumnClick}\n disabled={disableAddButton}\n icon={dhNewCircleLargeFilled}\n >\n Add Additional Column\n </Button>\n </div>\n\n <div className=\"select-distinct-builder-footer\">\n <div className=\"select-distinct-builder-hint\">\n Display only unique values from the selected table columns. Note\n that this will reset any filters and display only the selected\n columns.\n </div>\n </div>\n </div>\n );\n }\n}\n\nexport default SelectDistinctBuilder;\n"],"mappings":"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"}
@@ -16,6 +16,9 @@ import shortid from 'shortid';
16
16
  import "./TableCsvExporter.css";
17
17
  import Log from '@deephaven/log';
18
18
  import IrisGridUtils from "../IrisGridUtils.js";
19
+ import { jsx as _jsx } from "react/jsx-runtime";
20
+ import { jsxs as _jsxs } from "react/jsx-runtime";
21
+ import { Fragment as _Fragment } from "react/jsx-runtime";
19
22
  var log = Log.module('TableCsvExporter');
20
23
  class TableCsvExporter extends Component {
21
24
  static getDateString(dh) {
@@ -146,9 +149,11 @@ class TableCsvExporter extends Component {
146
149
  } catch (error) {
147
150
  log.error('CSV download failed', error);
148
151
  _this.setState({
149
- errorMessage: /*#__PURE__*/React.createElement("p", null, /*#__PURE__*/React.createElement(FontAwesomeIcon, {
150
- icon: vsWarning
151
- }), " ", "".concat(error))
152
+ errorMessage: /*#__PURE__*/_jsxs("p", {
153
+ children: [/*#__PURE__*/_jsx(FontAwesomeIcon, {
154
+ icon: vsWarning
155
+ }), " ", "".concat(error)]
156
+ })
152
157
  });
153
158
  onCancel();
154
159
  }
@@ -210,17 +215,21 @@ class TableCsvExporter extends Component {
210
215
  } = this.state;
211
216
  if (downloadRowOption === TableCsvExporter.DOWNLOAD_ROW_OPTIONS.SELECTED_ROWS && selectedRanges.length === 0) {
212
217
  this.setState({
213
- errorMessage: /*#__PURE__*/React.createElement("p", null, /*#__PURE__*/React.createElement(FontAwesomeIcon, {
214
- icon: vsWarning
215
- }), " No rows selected. Please select some rows in the table.")
218
+ errorMessage: /*#__PURE__*/_jsxs("p", {
219
+ children: [/*#__PURE__*/_jsx(FontAwesomeIcon, {
220
+ icon: vsWarning
221
+ }), " No rows selected. Please select some rows in the table."]
222
+ })
216
223
  });
217
224
  return false;
218
225
  }
219
226
  if (downloadRowOption === TableCsvExporter.DOWNLOAD_ROW_OPTIONS.CUSTOMIZED_ROWS && customizedDownloadRows <= 0) {
220
227
  this.setState({
221
- errorMessage: /*#__PURE__*/React.createElement("p", null, /*#__PURE__*/React.createElement(FontAwesomeIcon, {
222
- icon: vsWarning
223
- }), " Number of rows to output must be greater than 0")
228
+ errorMessage: /*#__PURE__*/_jsxs("p", {
229
+ children: [/*#__PURE__*/_jsx(FontAwesomeIcon, {
230
+ icon: vsWarning
231
+ }), " Number of rows to output must be greater than 0"]
232
+ })
224
233
  });
225
234
  return false;
226
235
  }
@@ -249,125 +258,166 @@ class TableCsvExporter extends Component {
249
258
  var {
250
259
  rowCount
251
260
  } = model;
252
- return /*#__PURE__*/React.createElement("div", {
253
- className: "table-csv-exporter"
254
- }, /*#__PURE__*/React.createElement("div", {
255
- className: "section-title"
256
- }, "Download Rows"), /*#__PURE__*/React.createElement("div", {
257
- className: "form-group"
258
- }, /*#__PURE__*/React.createElement(RadioGroup, {
259
- onChange: this.handleDownloadRowOptionChanged,
260
- value: downloadRowOption,
261
- disabled: isDownloading
262
- }, /*#__PURE__*/React.createElement(RadioItem, {
263
- value: TableCsvExporter.DOWNLOAD_ROW_OPTIONS.ALL_ROWS,
264
- "data-testid": "radio-csv-exporter-download-all"
265
- }, "All Rows", /*#__PURE__*/React.createElement("span", {
266
- className: "text-muted ml-2"
267
- }, "(".concat(rowCount.toString().replace(/(\d)(?=(\d{3})+(?!\d))/g, '$1,'), " rows)"))), /*#__PURE__*/React.createElement(RadioItem, {
268
- value: TableCsvExporter.DOWNLOAD_ROW_OPTIONS.SELECTED_ROWS,
269
- "data-testid": "radio-csv-exporter-only-selected"
270
- }, "Only Selected Rows", /*#__PURE__*/React.createElement("span", {
271
- className: "text-muted ml-2"
272
- }, selectedRanges.length > 0 ? "(".concat(GridRange.rowCount(selectedRanges).toString().replace(/(\d)(?=(\d{3})+(?!\d))/g, '$1,'), " rows)") : null)), /*#__PURE__*/React.createElement(RadioItem, {
273
- value: TableCsvExporter.DOWNLOAD_ROW_OPTIONS.CUSTOMIZED_ROWS,
274
- "data-testid": "radio-csv-exporter-customized-rows"
275
- }, /*#__PURE__*/React.createElement("div", {
276
- className: "radio-input-row",
277
- role: "presentation",
278
- onClick: () => {
279
- this.setState({
280
- downloadRowOption: TableCsvExporter.DOWNLOAD_ROW_OPTIONS.CUSTOMIZED_ROWS
281
- });
282
- }
283
- }, /*#__PURE__*/React.createElement("select", {
284
- value: customizedDownloadRowOption,
285
- "data-testid": "select-csv-exporter-customized-rows",
286
- className: "custom-select",
287
- disabled: isDownloading,
288
- onChange: this.handleCustomizedDownloadRowOptionChanged
289
- }, /*#__PURE__*/React.createElement("option", {
290
- value: "FIRST"
291
- }, "First"), /*#__PURE__*/React.createElement("option", {
292
- value: "LAST"
293
- }, "Last")), /*#__PURE__*/React.createElement("input", {
294
- type: "number",
295
- className: "form-control",
296
- id: "customizedRows-".concat(id),
297
- "data-testid": "input-csv-exporter-customized-rows",
298
- name: "customizedRows-".concat(id),
299
- placeholder: "100",
300
- value: customizedDownloadRows,
301
- disabled: isDownloading,
302
- onChange: this.handleCustomizedDownloadRowsChanged
303
- }), /*#__PURE__*/React.createElement("div", null, "Rows"))))), /*#__PURE__*/React.createElement("div", {
304
- className: "form-group"
305
- }, /*#__PURE__*/React.createElement("label", {
306
- htmlFor: "customizedRows-".concat(id)
307
- }, "File Name"), /*#__PURE__*/React.createElement("input", {
308
- type: "text",
309
- className: "form-control",
310
- id: "filename-".concat(id),
311
- "data-testid": "input-csv-exporter-file-name",
312
- name: "filename-".concat(id),
313
- value: fileName,
314
- onChange: event => {
315
- this.setState({
316
- fileName: event.target.value
317
- });
318
- },
319
- disabled: isDownloading
320
- })), /*#__PURE__*/React.createElement("div", {
321
- className: "checkbox-options"
322
- }, /*#__PURE__*/React.createElement(Checkbox, {
323
- checked: includeColumnHeaders,
324
- onChange: this.handleIncludeColumnHeadersChanged
325
- }, "Include column headers"), /*#__PURE__*/React.createElement(Checkbox, {
326
- checked: includeHiddenColumns,
327
- onChange: this.handleIncludeHiddenColumnsChanged
328
- }, "Include hidden columns"), /*#__PURE__*/React.createElement(Checkbox, {
329
- checked: useUnformattedValues,
330
- onChange: this.handleUseUnformattedValuesChanged
331
- }, "Use unformatted values")), /*#__PURE__*/React.createElement("div", {
332
- className: "section-footer flex-column"
333
- }, errorMessage != null && /*#__PURE__*/React.createElement("div", {
334
- className: "error-message"
335
- }, errorMessage), tableDownloadStatus && /*#__PURE__*/React.createElement("div", {
336
- className: "download-status"
337
- }, (tableDownloadStatus === TableCsvExporter.DOWNLOAD_STATUS.DOWNLOADING || tableDownloadStatus === TableCsvExporter.DOWNLOAD_STATUS.INITIATING) && /*#__PURE__*/React.createElement(React.Fragment, null, tableDownloadStatus === TableCsvExporter.DOWNLOAD_STATUS.INITIATING && /*#__PURE__*/React.createElement("div", {
338
- className: "text-muted"
339
- }, "Starting Download..."), tableDownloadStatus === TableCsvExporter.DOWNLOAD_STATUS.DOWNLOADING && /*#__PURE__*/React.createElement("div", {
340
- className: "text-muted d-flex justify-content-between"
341
- }, /*#__PURE__*/React.createElement("span", null, tableDownloadEstimatedTime || tableDownloadEstimatedTime === 0 ? "Estimated time: ".concat(TimeUtils.formatElapsedTime(tableDownloadEstimatedTime)) : null), /*#__PURE__*/React.createElement("span", null, "".concat(tableDownloadProgress, "%")))), tableDownloadStatus === TableCsvExporter.DOWNLOAD_STATUS.FINISHED && /*#__PURE__*/React.createElement("div", {
342
- className: "text-muted text-right"
343
- }, "Download Completed"), tableDownloadStatus === TableCsvExporter.DOWNLOAD_STATUS.CANCELED && /*#__PURE__*/React.createElement("div", {
344
- className: "text-muted"
345
- }, "Download Canceled"), (tableDownloadStatus === TableCsvExporter.DOWNLOAD_STATUS.DOWNLOADING || tableDownloadStatus === TableCsvExporter.DOWNLOAD_STATUS.INITIATING) && /*#__PURE__*/React.createElement("div", {
346
- className: "progress"
347
- }, /*#__PURE__*/React.createElement("div", {
348
- className: "progress-bar progress-bar-striped progress-bar-animated",
349
- style: {
350
- width: "".concat(tableDownloadProgress, "%")
351
- }
352
- })), tableDownloadStatus === TableCsvExporter.DOWNLOAD_STATUS.FINISHED && /*#__PURE__*/React.createElement("div", {
353
- className: "progress"
354
- }, /*#__PURE__*/React.createElement("div", {
355
- className: "progress-bar bg-success",
356
- style: {
357
- width: "".concat(tableDownloadProgress, "%")
358
- }
359
- }))), /*#__PURE__*/React.createElement(Button, {
360
- kind: "primary",
361
- "data-testid": "btn-csv-exporter-download",
362
- className: ClassNames('btn-downloading', {
363
- 'btn-spinner btn-cancelable': isDownloading
364
- }),
365
- onClick: this.handleDownloadClick
366
- }, isDownloading && /*#__PURE__*/React.createElement("span", null, /*#__PURE__*/React.createElement(LoadingSpinner, null), /*#__PURE__*/React.createElement("span", {
367
- className: "btn-normal-content"
368
- }, "Downloading"), /*#__PURE__*/React.createElement("span", {
369
- className: "btn-hover-content"
370
- }, "Cancel")), !isDownloading && 'Download')));
261
+ return /*#__PURE__*/_jsxs("div", {
262
+ className: "table-csv-exporter",
263
+ children: [/*#__PURE__*/_jsx("div", {
264
+ className: "section-title",
265
+ children: "Download Rows"
266
+ }), /*#__PURE__*/_jsx("div", {
267
+ className: "form-group",
268
+ children: /*#__PURE__*/_jsxs(RadioGroup, {
269
+ onChange: this.handleDownloadRowOptionChanged,
270
+ value: downloadRowOption,
271
+ disabled: isDownloading,
272
+ children: [/*#__PURE__*/_jsxs(RadioItem, {
273
+ value: TableCsvExporter.DOWNLOAD_ROW_OPTIONS.ALL_ROWS,
274
+ "data-testid": "radio-csv-exporter-download-all",
275
+ children: ["All Rows", /*#__PURE__*/_jsx("span", {
276
+ className: "text-muted ml-2",
277
+ children: "(".concat(rowCount.toString().replace(/(\d)(?=(\d{3})+(?!\d))/g, '$1,'), " rows)")
278
+ })]
279
+ }), /*#__PURE__*/_jsxs(RadioItem, {
280
+ value: TableCsvExporter.DOWNLOAD_ROW_OPTIONS.SELECTED_ROWS,
281
+ "data-testid": "radio-csv-exporter-only-selected",
282
+ children: ["Only Selected Rows", /*#__PURE__*/_jsx("span", {
283
+ className: "text-muted ml-2",
284
+ children: selectedRanges.length > 0 ? "(".concat(GridRange.rowCount(selectedRanges).toString().replace(/(\d)(?=(\d{3})+(?!\d))/g, '$1,'), " rows)") : null
285
+ })]
286
+ }), /*#__PURE__*/_jsx(RadioItem, {
287
+ value: TableCsvExporter.DOWNLOAD_ROW_OPTIONS.CUSTOMIZED_ROWS,
288
+ "data-testid": "radio-csv-exporter-customized-rows",
289
+ children: /*#__PURE__*/_jsxs("div", {
290
+ className: "radio-input-row",
291
+ role: "presentation",
292
+ onClick: () => {
293
+ this.setState({
294
+ downloadRowOption: TableCsvExporter.DOWNLOAD_ROW_OPTIONS.CUSTOMIZED_ROWS
295
+ });
296
+ },
297
+ children: [/*#__PURE__*/_jsxs("select", {
298
+ value: customizedDownloadRowOption,
299
+ "data-testid": "select-csv-exporter-customized-rows",
300
+ className: "custom-select",
301
+ disabled: isDownloading,
302
+ onChange: this.handleCustomizedDownloadRowOptionChanged,
303
+ children: [/*#__PURE__*/_jsx("option", {
304
+ value: "FIRST",
305
+ children: "First"
306
+ }), /*#__PURE__*/_jsx("option", {
307
+ value: "LAST",
308
+ children: "Last"
309
+ })]
310
+ }), /*#__PURE__*/_jsx("input", {
311
+ type: "number",
312
+ className: "form-control",
313
+ id: "customizedRows-".concat(id),
314
+ "data-testid": "input-csv-exporter-customized-rows",
315
+ name: "customizedRows-".concat(id),
316
+ placeholder: "100",
317
+ value: customizedDownloadRows,
318
+ disabled: isDownloading,
319
+ onChange: this.handleCustomizedDownloadRowsChanged
320
+ }), /*#__PURE__*/_jsx("div", {
321
+ children: "Rows"
322
+ })]
323
+ })
324
+ })]
325
+ })
326
+ }), /*#__PURE__*/_jsxs("div", {
327
+ className: "form-group",
328
+ children: [/*#__PURE__*/_jsx("label", {
329
+ htmlFor: "customizedRows-".concat(id),
330
+ children: "File Name"
331
+ }), /*#__PURE__*/_jsx("input", {
332
+ type: "text",
333
+ className: "form-control",
334
+ id: "filename-".concat(id),
335
+ "data-testid": "input-csv-exporter-file-name",
336
+ name: "filename-".concat(id),
337
+ value: fileName,
338
+ onChange: event => {
339
+ this.setState({
340
+ fileName: event.target.value
341
+ });
342
+ },
343
+ disabled: isDownloading
344
+ })]
345
+ }), /*#__PURE__*/_jsxs("div", {
346
+ className: "checkbox-options",
347
+ children: [/*#__PURE__*/_jsx(Checkbox, {
348
+ checked: includeColumnHeaders,
349
+ onChange: this.handleIncludeColumnHeadersChanged,
350
+ children: "Include column headers"
351
+ }), /*#__PURE__*/_jsx(Checkbox, {
352
+ checked: includeHiddenColumns,
353
+ onChange: this.handleIncludeHiddenColumnsChanged,
354
+ children: "Include hidden columns"
355
+ }), /*#__PURE__*/_jsx(Checkbox, {
356
+ checked: useUnformattedValues,
357
+ onChange: this.handleUseUnformattedValuesChanged,
358
+ children: "Use unformatted values"
359
+ })]
360
+ }), /*#__PURE__*/_jsxs("div", {
361
+ className: "section-footer flex-column",
362
+ children: [errorMessage != null && /*#__PURE__*/_jsx("div", {
363
+ className: "error-message",
364
+ children: errorMessage
365
+ }), tableDownloadStatus && /*#__PURE__*/_jsxs("div", {
366
+ className: "download-status",
367
+ children: [(tableDownloadStatus === TableCsvExporter.DOWNLOAD_STATUS.DOWNLOADING || tableDownloadStatus === TableCsvExporter.DOWNLOAD_STATUS.INITIATING) && /*#__PURE__*/_jsxs(_Fragment, {
368
+ children: [tableDownloadStatus === TableCsvExporter.DOWNLOAD_STATUS.INITIATING && /*#__PURE__*/_jsx("div", {
369
+ className: "text-muted",
370
+ children: "Starting Download..."
371
+ }), tableDownloadStatus === TableCsvExporter.DOWNLOAD_STATUS.DOWNLOADING && /*#__PURE__*/_jsxs("div", {
372
+ className: "text-muted d-flex justify-content-between",
373
+ children: [/*#__PURE__*/_jsx("span", {
374
+ children: tableDownloadEstimatedTime || tableDownloadEstimatedTime === 0 ? "Estimated time: ".concat(TimeUtils.formatElapsedTime(tableDownloadEstimatedTime)) : null
375
+ }), /*#__PURE__*/_jsx("span", {
376
+ children: "".concat(tableDownloadProgress, "%")
377
+ })]
378
+ })]
379
+ }), tableDownloadStatus === TableCsvExporter.DOWNLOAD_STATUS.FINISHED && /*#__PURE__*/_jsx("div", {
380
+ className: "text-muted text-right",
381
+ children: "Download Completed"
382
+ }), tableDownloadStatus === TableCsvExporter.DOWNLOAD_STATUS.CANCELED && /*#__PURE__*/_jsx("div", {
383
+ className: "text-muted",
384
+ children: "Download Canceled"
385
+ }), (tableDownloadStatus === TableCsvExporter.DOWNLOAD_STATUS.DOWNLOADING || tableDownloadStatus === TableCsvExporter.DOWNLOAD_STATUS.INITIATING) && /*#__PURE__*/_jsx("div", {
386
+ className: "progress",
387
+ children: /*#__PURE__*/_jsx("div", {
388
+ className: "progress-bar progress-bar-striped progress-bar-animated",
389
+ style: {
390
+ width: "".concat(tableDownloadProgress, "%")
391
+ }
392
+ })
393
+ }), tableDownloadStatus === TableCsvExporter.DOWNLOAD_STATUS.FINISHED && /*#__PURE__*/_jsx("div", {
394
+ className: "progress",
395
+ children: /*#__PURE__*/_jsx("div", {
396
+ className: "progress-bar bg-success",
397
+ style: {
398
+ width: "".concat(tableDownloadProgress, "%")
399
+ }
400
+ })
401
+ })]
402
+ }), /*#__PURE__*/_jsxs(Button, {
403
+ kind: "primary",
404
+ "data-testid": "btn-csv-exporter-download",
405
+ className: ClassNames('btn-downloading', {
406
+ 'btn-spinner btn-cancelable': isDownloading
407
+ }),
408
+ onClick: this.handleDownloadClick,
409
+ children: [isDownloading && /*#__PURE__*/_jsxs("span", {
410
+ children: [/*#__PURE__*/_jsx(LoadingSpinner, {}), /*#__PURE__*/_jsx("span", {
411
+ className: "btn-normal-content",
412
+ children: "Downloading"
413
+ }), /*#__PURE__*/_jsx("span", {
414
+ className: "btn-hover-content",
415
+ children: "Cancel"
416
+ })]
417
+ }), !isDownloading && 'Download']
418
+ })]
419
+ })]
420
+ });
371
421
  }
372
422
  }
373
423
  _defineProperty(TableCsvExporter, "FILENAME_DATE_FORMAT", 'yyyy-MM-dd-HHmmss');
@@ -1 +1 @@
1
- {"version":3,"file":"TableCsvExporter.js","names":["React","Component","ClassNames","FontAwesomeIcon","Button","Checkbox","LoadingSpinner","RadioGroup","RadioItem","GridRange","GridUtils","vsWarning","TimeUtils","shortid","Log","IrisGridUtils","log","module","TableCsvExporter","getDateString","dh","i18n","DateTimeFormat","format","FILENAME_DATE_FORMAT","Date","constructor","props","handleDownloadClick","bind","handleDownloadRowOptionChanged","handleCustomizedDownloadRowOptionChanged","handleCustomizedDownloadRowsChanged","handleIncludeColumnHeadersChanged","handleIncludeHiddenColumnsChanged","handleUseUnformattedValuesChanged","model","name","state","fileName","downloadRowOption","DOWNLOAD_ROW_OPTIONS","ALL_ROWS","customizedDownloadRowOption","CUSTOMIZED_ROWS_OPTIONS","FIRST","customizedDownloadRows","DEFAULT_DOWNLOAD_ROWS","includeColumnHeaders","includeHiddenColumns","useUnformattedValues","errorMessage","id","generate","getSnapshotRanges","selectedRanges","rowCount","columnCount","snapshotRanges","push","SELECTED_ROWS","map","range","startColumn","endColumn","sort","rangeA","rangeB","startRow","CUSTOMIZED_ROWS","Math","min","LAST","max","getModelRanges","ranges","userColumnWidths","movedColumns","hiddenColumns","getHiddenColumns","modelRanges","length","subtractRanges","makeColumn","subtractRangesFromRanges","resetDownloadState","setState","isDownloading","onDownloadStart","onDownload","onCancel","validateOptionInput","frozenTable","export","tableSubscription","setViewport","getViewportData","error","event","target","value","parseInt","render","tableDownloadProgress","tableDownloadEstimatedTime","tableDownloadStatus","toString","replace","DOWNLOAD_STATUS","DOWNLOADING","INITIATING","formatElapsedTime","FINISHED","CANCELED","width","undefined"],"sources":["../../src/sidebar/TableCsvExporter.tsx"],"sourcesContent":["import React, { Component, ReactElement } from 'react';\nimport ClassNames from 'classnames';\nimport { FontAwesomeIcon } from '@fortawesome/react-fontawesome';\nimport {\n Button,\n Checkbox,\n LoadingSpinner,\n RadioGroup,\n RadioItem,\n} from '@deephaven/components';\nimport {\n GridRange,\n GridUtils,\n ModelSizeMap,\n MoveOperation,\n} from '@deephaven/grid';\nimport { vsWarning } from '@deephaven/icons';\nimport type {\n dh as DhType,\n Table,\n TableViewportSubscription,\n} from '@deephaven/jsapi-types';\nimport { TimeUtils } from '@deephaven/utils';\nimport shortid from 'shortid';\nimport './TableCsvExporter.scss';\nimport Log from '@deephaven/log';\nimport IrisGridModel from '../IrisGridModel';\nimport IrisGridUtils from '../IrisGridUtils';\n\nconst log = Log.module('TableCsvExporter');\ninterface TableCsvExporterProps {\n model: IrisGridModel;\n name: string;\n userColumnWidths: ModelSizeMap;\n movedColumns: readonly MoveOperation[];\n isDownloading: boolean;\n tableDownloadStatus: string;\n tableDownloadProgress: number;\n tableDownloadEstimatedTime: number;\n onDownloadStart: () => void;\n onDownload: (\n fileName: string,\n frozenTable: Table,\n tableSubscription: TableViewportSubscription,\n snapshotRanges: readonly GridRange[],\n modelRanges: readonly GridRange[],\n includeColumnHeaders: boolean,\n useUnformattedValues: boolean\n ) => void;\n onCancel: () => void;\n selectedRanges: readonly GridRange[];\n}\n\ninterface TableCsvExporterState {\n fileName: string;\n\n downloadRowOption: string;\n customizedDownloadRowOption: string;\n customizedDownloadRows: number;\n\n includeColumnHeaders: boolean;\n includeHiddenColumns: boolean;\n useUnformattedValues: boolean;\n\n errorMessage: React.ReactNode;\n id: string;\n}\nclass TableCsvExporter extends Component<\n TableCsvExporterProps,\n TableCsvExporterState\n> {\n static FILENAME_DATE_FORMAT = 'yyyy-MM-dd-HHmmss';\n\n static DOWNLOAD_STATUS = {\n INITIATING: 'INITIATING',\n DOWNLOADING: 'DOWNLOADING',\n FINISHED: 'FINISHED',\n CANCELED: 'CANCELED',\n };\n\n static DOWNLOAD_ROW_OPTIONS = {\n ALL_ROWS: 'ALL_ROWS',\n SELECTED_ROWS: 'SELECTED_ROWS',\n CUSTOMIZED_ROWS: 'CUSTOMIZED_ROWS',\n };\n\n static CUSTOMIZED_ROWS_OPTIONS = {\n FIRST: 'FIRST',\n LAST: 'LAST',\n };\n\n static DEFAULT_DOWNLOAD_ROWS = 100;\n\n static defaultProps = {\n onDownloadStart: (): void => undefined,\n isDownloading: false,\n tableDownloadStatus: '',\n tableDownloadProgress: 0,\n tableDownloadEstimatedTime: null,\n selectedRanges: [],\n };\n\n static getDateString(dh: DhType): string {\n return dh.i18n.DateTimeFormat.format(\n TableCsvExporter.FILENAME_DATE_FORMAT,\n new Date()\n );\n }\n\n constructor(props: TableCsvExporterProps) {\n super(props);\n\n this.handleDownloadClick = this.handleDownloadClick.bind(this);\n this.handleDownloadRowOptionChanged =\n this.handleDownloadRowOptionChanged.bind(this);\n this.handleCustomizedDownloadRowOptionChanged =\n this.handleCustomizedDownloadRowOptionChanged.bind(this);\n this.handleCustomizedDownloadRowsChanged =\n this.handleCustomizedDownloadRowsChanged.bind(this);\n this.handleIncludeColumnHeadersChanged =\n this.handleIncludeColumnHeadersChanged.bind(this);\n this.handleIncludeHiddenColumnsChanged =\n this.handleIncludeHiddenColumnsChanged.bind(this);\n this.handleUseUnformattedValuesChanged =\n this.handleUseUnformattedValuesChanged.bind(this);\n\n const { model, name } = props;\n this.state = {\n fileName: `${name}-${TableCsvExporter.getDateString(model.dh)}.csv`,\n\n downloadRowOption: TableCsvExporter.DOWNLOAD_ROW_OPTIONS.ALL_ROWS,\n customizedDownloadRowOption:\n TableCsvExporter.CUSTOMIZED_ROWS_OPTIONS.FIRST,\n customizedDownloadRows: TableCsvExporter.DEFAULT_DOWNLOAD_ROWS,\n\n includeColumnHeaders: true,\n includeHiddenColumns: false,\n useUnformattedValues: false,\n\n errorMessage: null,\n id: shortid.generate(),\n };\n }\n\n getSnapshotRanges(): GridRange[] {\n const { model, selectedRanges } = this.props;\n const {\n downloadRowOption,\n customizedDownloadRowOption,\n customizedDownloadRows,\n } = this.state;\n const { rowCount, columnCount } = model;\n let snapshotRanges = [] as GridRange[];\n switch (downloadRowOption) {\n case TableCsvExporter.DOWNLOAD_ROW_OPTIONS.ALL_ROWS:\n snapshotRanges.push(new GridRange(0, 0, columnCount - 1, rowCount - 1));\n break;\n case TableCsvExporter.DOWNLOAD_ROW_OPTIONS.SELECTED_ROWS:\n snapshotRanges = selectedRanges\n .map(range => ({\n ...range,\n startColumn: 0,\n endColumn: columnCount - 1,\n }))\n .sort((rangeA, rangeB) => {\n if (rangeA.startRow != null && rangeB.startRow != null) {\n return rangeA.startRow - rangeB.startRow;\n }\n return 0;\n }) as GridRange[];\n break;\n case TableCsvExporter.DOWNLOAD_ROW_OPTIONS.CUSTOMIZED_ROWS:\n switch (customizedDownloadRowOption) {\n case TableCsvExporter.CUSTOMIZED_ROWS_OPTIONS.FIRST:\n snapshotRanges.push(\n new GridRange(\n 0,\n 0,\n columnCount - 1,\n Math.min(customizedDownloadRows - 1, rowCount - 1)\n )\n );\n break;\n case TableCsvExporter.CUSTOMIZED_ROWS_OPTIONS.LAST:\n snapshotRanges.push(\n new GridRange(\n 0,\n Math.max(0, rowCount - customizedDownloadRows),\n columnCount - 1,\n rowCount - 1\n )\n );\n break;\n default:\n break;\n }\n break;\n default:\n break;\n }\n return snapshotRanges;\n }\n\n getModelRanges(ranges: readonly GridRange[]): GridRange[] {\n const { userColumnWidths, movedColumns } = this.props;\n const { includeHiddenColumns } = this.state;\n const hiddenColumns = IrisGridUtils.getHiddenColumns(userColumnWidths);\n let modelRanges = GridUtils.getModelRanges(ranges, movedColumns);\n if (!includeHiddenColumns && hiddenColumns.length > 0) {\n const subtractRanges = hiddenColumns.map(GridRange.makeColumn);\n modelRanges = GridRange.subtractRangesFromRanges(\n modelRanges,\n subtractRanges\n );\n }\n return modelRanges;\n }\n\n resetDownloadState(): void {\n this.setState({ errorMessage: null });\n }\n\n async handleDownloadClick(): Promise<void> {\n const { model, isDownloading, onDownloadStart, onDownload, onCancel } =\n this.props;\n const { fileName, includeColumnHeaders, useUnformattedValues } = this.state;\n\n if (isDownloading) {\n onCancel();\n return;\n }\n\n this.resetDownloadState();\n\n const snapshotRanges = this.getSnapshotRanges();\n const modelRanges = this.getModelRanges(snapshotRanges);\n if (this.validateOptionInput()) {\n onDownloadStart();\n try {\n const frozenTable = await model.export();\n const tableSubscription = frozenTable.setViewport(0, 0);\n await tableSubscription.getViewportData();\n onDownload(\n fileName,\n frozenTable,\n tableSubscription,\n snapshotRanges,\n modelRanges,\n includeColumnHeaders,\n useUnformattedValues\n );\n } catch (error) {\n log.error('CSV download failed', error);\n\n this.setState({\n errorMessage: (\n <p>\n <FontAwesomeIcon icon={vsWarning} /> {`${error}`}\n </p>\n ),\n });\n onCancel();\n }\n }\n }\n\n handleDownloadRowOptionChanged(\n event: React.ChangeEvent<HTMLInputElement>\n ): void {\n this.setState({ downloadRowOption: event.target.value });\n }\n\n handleCustomizedDownloadRowOptionChanged(\n event: React.ChangeEvent<HTMLSelectElement>\n ): void {\n this.setState({ customizedDownloadRowOption: event.target.value });\n }\n\n handleCustomizedDownloadRowsChanged(\n event: React.ChangeEvent<HTMLInputElement>\n ): void {\n this.setState({ customizedDownloadRows: parseInt(event.target.value, 10) });\n }\n\n handleIncludeColumnHeadersChanged(): void {\n this.setState(({ includeColumnHeaders }) => ({\n includeColumnHeaders: !includeColumnHeaders,\n }));\n }\n\n handleIncludeHiddenColumnsChanged(): void {\n this.setState(({ includeHiddenColumns }) => ({\n includeHiddenColumns: !includeHiddenColumns,\n }));\n }\n\n handleUseUnformattedValuesChanged(): void {\n this.setState(({ useUnformattedValues }) => ({\n useUnformattedValues: !useUnformattedValues,\n }));\n }\n\n validateOptionInput(): boolean {\n const { selectedRanges } = this.props;\n const { downloadRowOption, customizedDownloadRows } = this.state;\n\n if (\n downloadRowOption ===\n TableCsvExporter.DOWNLOAD_ROW_OPTIONS.SELECTED_ROWS &&\n selectedRanges.length === 0\n ) {\n this.setState({\n errorMessage: (\n <p>\n <FontAwesomeIcon icon={vsWarning} /> No rows selected. Please select\n some rows in the table.\n </p>\n ),\n });\n return false;\n }\n\n if (\n downloadRowOption ===\n TableCsvExporter.DOWNLOAD_ROW_OPTIONS.CUSTOMIZED_ROWS &&\n customizedDownloadRows <= 0\n ) {\n this.setState({\n errorMessage: (\n <p>\n <FontAwesomeIcon icon={vsWarning} /> Number of rows to output must\n be greater than 0\n </p>\n ),\n });\n return false;\n }\n return true;\n }\n\n render(): ReactElement {\n const {\n model,\n isDownloading,\n tableDownloadProgress,\n tableDownloadEstimatedTime,\n selectedRanges,\n tableDownloadStatus,\n } = this.props;\n const {\n fileName,\n downloadRowOption,\n customizedDownloadRowOption,\n customizedDownloadRows,\n includeColumnHeaders,\n includeHiddenColumns,\n useUnformattedValues,\n errorMessage,\n id,\n } = this.state;\n const { rowCount } = model;\n return (\n <div className=\"table-csv-exporter\">\n <div className=\"section-title\">Download Rows</div>\n <div className=\"form-group\">\n <RadioGroup\n onChange={this.handleDownloadRowOptionChanged}\n value={downloadRowOption}\n disabled={isDownloading}\n >\n <RadioItem\n value={TableCsvExporter.DOWNLOAD_ROW_OPTIONS.ALL_ROWS}\n data-testid=\"radio-csv-exporter-download-all\"\n >\n All Rows\n <span className=\"text-muted ml-2\">\n {`(${rowCount\n .toString()\n .replace(/(\\d)(?=(\\d{3})+(?!\\d))/g, '$1,')} rows)`}\n </span>\n </RadioItem>\n <RadioItem\n value={TableCsvExporter.DOWNLOAD_ROW_OPTIONS.SELECTED_ROWS}\n data-testid=\"radio-csv-exporter-only-selected\"\n >\n Only Selected Rows\n <span className=\"text-muted ml-2\">\n {selectedRanges.length > 0\n ? `(${GridRange.rowCount(selectedRanges)\n .toString()\n .replace(/(\\d)(?=(\\d{3})+(?!\\d))/g, '$1,')} rows)`\n : null}\n </span>\n </RadioItem>\n <RadioItem\n value={TableCsvExporter.DOWNLOAD_ROW_OPTIONS.CUSTOMIZED_ROWS}\n data-testid=\"radio-csv-exporter-customized-rows\"\n >\n <div\n className=\"radio-input-row\"\n role=\"presentation\"\n onClick={() => {\n this.setState({\n downloadRowOption:\n TableCsvExporter.DOWNLOAD_ROW_OPTIONS.CUSTOMIZED_ROWS,\n });\n }}\n >\n <select\n value={customizedDownloadRowOption}\n data-testid=\"select-csv-exporter-customized-rows\"\n className=\"custom-select\"\n disabled={isDownloading}\n onChange={this.handleCustomizedDownloadRowOptionChanged}\n >\n <option value=\"FIRST\">First</option>\n <option value=\"LAST\">Last</option>\n </select>\n <input\n type=\"number\"\n className=\"form-control\"\n id={`customizedRows-${id}`}\n data-testid=\"input-csv-exporter-customized-rows\"\n name={`customizedRows-${id}`}\n placeholder=\"100\"\n value={customizedDownloadRows}\n disabled={isDownloading}\n onChange={this.handleCustomizedDownloadRowsChanged}\n />\n <div>Rows</div>\n </div>\n </RadioItem>\n </RadioGroup>\n </div>\n <div className=\"form-group\">\n <label htmlFor={`customizedRows-${id}`}>File Name</label>\n <input\n type=\"text\"\n className=\"form-control\"\n id={`filename-${id}`}\n data-testid=\"input-csv-exporter-file-name\"\n name={`filename-${id}`}\n value={fileName}\n onChange={event => {\n this.setState({ fileName: event.target.value });\n }}\n disabled={isDownloading}\n />\n </div>\n <div className=\"checkbox-options\">\n <Checkbox\n checked={includeColumnHeaders}\n onChange={this.handleIncludeColumnHeadersChanged}\n >\n Include column headers\n </Checkbox>\n <Checkbox\n checked={includeHiddenColumns}\n onChange={this.handleIncludeHiddenColumnsChanged}\n >\n Include hidden columns\n </Checkbox>\n <Checkbox\n checked={useUnformattedValues}\n onChange={this.handleUseUnformattedValuesChanged}\n >\n Use unformatted values\n </Checkbox>\n </div>\n <div className=\"section-footer flex-column\">\n {errorMessage != null && (\n <div className=\"error-message\">{errorMessage}</div>\n )}\n {tableDownloadStatus && (\n <div className=\"download-status\">\n {(tableDownloadStatus ===\n TableCsvExporter.DOWNLOAD_STATUS.DOWNLOADING ||\n tableDownloadStatus ===\n TableCsvExporter.DOWNLOAD_STATUS.INITIATING) && (\n <>\n {tableDownloadStatus ===\n TableCsvExporter.DOWNLOAD_STATUS.INITIATING && (\n <div className=\"text-muted\">Starting Download...</div>\n )}\n {tableDownloadStatus ===\n TableCsvExporter.DOWNLOAD_STATUS.DOWNLOADING && (\n <div className=\"text-muted d-flex justify-content-between\">\n <span>\n {tableDownloadEstimatedTime ||\n tableDownloadEstimatedTime === 0\n ? `Estimated time: ${TimeUtils.formatElapsedTime(\n tableDownloadEstimatedTime\n )}`\n : null}\n </span>\n <span>{`${tableDownloadProgress}%`}</span>\n </div>\n )}\n </>\n )}\n {tableDownloadStatus ===\n TableCsvExporter.DOWNLOAD_STATUS.FINISHED && (\n <div className=\"text-muted text-right\">Download Completed</div>\n )}\n {tableDownloadStatus ===\n TableCsvExporter.DOWNLOAD_STATUS.CANCELED && (\n <div className=\"text-muted\">Download Canceled</div>\n )}\n\n {(tableDownloadStatus ===\n TableCsvExporter.DOWNLOAD_STATUS.DOWNLOADING ||\n tableDownloadStatus ===\n TableCsvExporter.DOWNLOAD_STATUS.INITIATING) && (\n <div className=\"progress\">\n <div\n className=\"progress-bar progress-bar-striped progress-bar-animated\"\n style={{ width: `${tableDownloadProgress}%` }}\n />\n </div>\n )}\n {tableDownloadStatus ===\n TableCsvExporter.DOWNLOAD_STATUS.FINISHED && (\n <div className=\"progress\">\n <div\n className=\"progress-bar bg-success\"\n style={{ width: `${tableDownloadProgress}%` }}\n />\n </div>\n )}\n </div>\n )}\n <Button\n kind=\"primary\"\n data-testid=\"btn-csv-exporter-download\"\n className={ClassNames('btn-downloading', {\n 'btn-spinner btn-cancelable': isDownloading,\n })}\n onClick={this.handleDownloadClick}\n >\n {isDownloading && (\n <span>\n <LoadingSpinner />\n <span className=\"btn-normal-content\">Downloading</span>\n <span className=\"btn-hover-content\">Cancel</span>\n </span>\n )}\n {!isDownloading && 'Download'}\n </Button>\n </div>\n </div>\n );\n }\n}\n\nexport default TableCsvExporter;\n"],"mappings":"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"}
1
+ {"version":3,"file":"TableCsvExporter.js","names":["React","Component","ClassNames","FontAwesomeIcon","Button","Checkbox","LoadingSpinner","RadioGroup","RadioItem","GridRange","GridUtils","vsWarning","TimeUtils","shortid","Log","IrisGridUtils","log","module","TableCsvExporter","getDateString","dh","i18n","DateTimeFormat","format","FILENAME_DATE_FORMAT","Date","constructor","props","handleDownloadClick","bind","handleDownloadRowOptionChanged","handleCustomizedDownloadRowOptionChanged","handleCustomizedDownloadRowsChanged","handleIncludeColumnHeadersChanged","handleIncludeHiddenColumnsChanged","handleUseUnformattedValuesChanged","model","name","state","fileName","downloadRowOption","DOWNLOAD_ROW_OPTIONS","ALL_ROWS","customizedDownloadRowOption","CUSTOMIZED_ROWS_OPTIONS","FIRST","customizedDownloadRows","DEFAULT_DOWNLOAD_ROWS","includeColumnHeaders","includeHiddenColumns","useUnformattedValues","errorMessage","id","generate","getSnapshotRanges","selectedRanges","rowCount","columnCount","snapshotRanges","push","SELECTED_ROWS","map","range","startColumn","endColumn","sort","rangeA","rangeB","startRow","CUSTOMIZED_ROWS","Math","min","LAST","max","getModelRanges","ranges","userColumnWidths","movedColumns","hiddenColumns","getHiddenColumns","modelRanges","length","subtractRanges","makeColumn","subtractRangesFromRanges","resetDownloadState","setState","isDownloading","onDownloadStart","onDownload","onCancel","validateOptionInput","frozenTable","export","tableSubscription","setViewport","getViewportData","error","event","target","value","parseInt","render","tableDownloadProgress","tableDownloadEstimatedTime","tableDownloadStatus","toString","replace","DOWNLOAD_STATUS","DOWNLOADING","INITIATING","formatElapsedTime","FINISHED","CANCELED","width","undefined"],"sources":["../../src/sidebar/TableCsvExporter.tsx"],"sourcesContent":["import React, { Component, ReactElement } from 'react';\nimport ClassNames from 'classnames';\nimport { FontAwesomeIcon } from '@fortawesome/react-fontawesome';\nimport {\n Button,\n Checkbox,\n LoadingSpinner,\n RadioGroup,\n RadioItem,\n} from '@deephaven/components';\nimport {\n GridRange,\n GridUtils,\n ModelSizeMap,\n MoveOperation,\n} from '@deephaven/grid';\nimport { vsWarning } from '@deephaven/icons';\nimport type {\n dh as DhType,\n Table,\n TableViewportSubscription,\n} from '@deephaven/jsapi-types';\nimport { TimeUtils } from '@deephaven/utils';\nimport shortid from 'shortid';\nimport './TableCsvExporter.scss';\nimport Log from '@deephaven/log';\nimport IrisGridModel from '../IrisGridModel';\nimport IrisGridUtils from '../IrisGridUtils';\n\nconst log = Log.module('TableCsvExporter');\ninterface TableCsvExporterProps {\n model: IrisGridModel;\n name: string;\n userColumnWidths: ModelSizeMap;\n movedColumns: readonly MoveOperation[];\n isDownloading: boolean;\n tableDownloadStatus: string;\n tableDownloadProgress: number;\n tableDownloadEstimatedTime: number;\n onDownloadStart: () => void;\n onDownload: (\n fileName: string,\n frozenTable: Table,\n tableSubscription: TableViewportSubscription,\n snapshotRanges: readonly GridRange[],\n modelRanges: readonly GridRange[],\n includeColumnHeaders: boolean,\n useUnformattedValues: boolean\n ) => void;\n onCancel: () => void;\n selectedRanges: readonly GridRange[];\n}\n\ninterface TableCsvExporterState {\n fileName: string;\n\n downloadRowOption: string;\n customizedDownloadRowOption: string;\n customizedDownloadRows: number;\n\n includeColumnHeaders: boolean;\n includeHiddenColumns: boolean;\n useUnformattedValues: boolean;\n\n errorMessage: React.ReactNode;\n id: string;\n}\nclass TableCsvExporter extends Component<\n TableCsvExporterProps,\n TableCsvExporterState\n> {\n static FILENAME_DATE_FORMAT = 'yyyy-MM-dd-HHmmss';\n\n static DOWNLOAD_STATUS = {\n INITIATING: 'INITIATING',\n DOWNLOADING: 'DOWNLOADING',\n FINISHED: 'FINISHED',\n CANCELED: 'CANCELED',\n };\n\n static DOWNLOAD_ROW_OPTIONS = {\n ALL_ROWS: 'ALL_ROWS',\n SELECTED_ROWS: 'SELECTED_ROWS',\n CUSTOMIZED_ROWS: 'CUSTOMIZED_ROWS',\n };\n\n static CUSTOMIZED_ROWS_OPTIONS = {\n FIRST: 'FIRST',\n LAST: 'LAST',\n };\n\n static DEFAULT_DOWNLOAD_ROWS = 100;\n\n static defaultProps = {\n onDownloadStart: (): void => undefined,\n isDownloading: false,\n tableDownloadStatus: '',\n tableDownloadProgress: 0,\n tableDownloadEstimatedTime: null,\n selectedRanges: [],\n };\n\n static getDateString(dh: DhType): string {\n return dh.i18n.DateTimeFormat.format(\n TableCsvExporter.FILENAME_DATE_FORMAT,\n new Date()\n );\n }\n\n constructor(props: TableCsvExporterProps) {\n super(props);\n\n this.handleDownloadClick = this.handleDownloadClick.bind(this);\n this.handleDownloadRowOptionChanged =\n this.handleDownloadRowOptionChanged.bind(this);\n this.handleCustomizedDownloadRowOptionChanged =\n this.handleCustomizedDownloadRowOptionChanged.bind(this);\n this.handleCustomizedDownloadRowsChanged =\n this.handleCustomizedDownloadRowsChanged.bind(this);\n this.handleIncludeColumnHeadersChanged =\n this.handleIncludeColumnHeadersChanged.bind(this);\n this.handleIncludeHiddenColumnsChanged =\n this.handleIncludeHiddenColumnsChanged.bind(this);\n this.handleUseUnformattedValuesChanged =\n this.handleUseUnformattedValuesChanged.bind(this);\n\n const { model, name } = props;\n this.state = {\n fileName: `${name}-${TableCsvExporter.getDateString(model.dh)}.csv`,\n\n downloadRowOption: TableCsvExporter.DOWNLOAD_ROW_OPTIONS.ALL_ROWS,\n customizedDownloadRowOption:\n TableCsvExporter.CUSTOMIZED_ROWS_OPTIONS.FIRST,\n customizedDownloadRows: TableCsvExporter.DEFAULT_DOWNLOAD_ROWS,\n\n includeColumnHeaders: true,\n includeHiddenColumns: false,\n useUnformattedValues: false,\n\n errorMessage: null,\n id: shortid.generate(),\n };\n }\n\n getSnapshotRanges(): GridRange[] {\n const { model, selectedRanges } = this.props;\n const {\n downloadRowOption,\n customizedDownloadRowOption,\n customizedDownloadRows,\n } = this.state;\n const { rowCount, columnCount } = model;\n let snapshotRanges = [] as GridRange[];\n switch (downloadRowOption) {\n case TableCsvExporter.DOWNLOAD_ROW_OPTIONS.ALL_ROWS:\n snapshotRanges.push(new GridRange(0, 0, columnCount - 1, rowCount - 1));\n break;\n case TableCsvExporter.DOWNLOAD_ROW_OPTIONS.SELECTED_ROWS:\n snapshotRanges = selectedRanges\n .map(range => ({\n ...range,\n startColumn: 0,\n endColumn: columnCount - 1,\n }))\n .sort((rangeA, rangeB) => {\n if (rangeA.startRow != null && rangeB.startRow != null) {\n return rangeA.startRow - rangeB.startRow;\n }\n return 0;\n }) as GridRange[];\n break;\n case TableCsvExporter.DOWNLOAD_ROW_OPTIONS.CUSTOMIZED_ROWS:\n switch (customizedDownloadRowOption) {\n case TableCsvExporter.CUSTOMIZED_ROWS_OPTIONS.FIRST:\n snapshotRanges.push(\n new GridRange(\n 0,\n 0,\n columnCount - 1,\n Math.min(customizedDownloadRows - 1, rowCount - 1)\n )\n );\n break;\n case TableCsvExporter.CUSTOMIZED_ROWS_OPTIONS.LAST:\n snapshotRanges.push(\n new GridRange(\n 0,\n Math.max(0, rowCount - customizedDownloadRows),\n columnCount - 1,\n rowCount - 1\n )\n );\n break;\n default:\n break;\n }\n break;\n default:\n break;\n }\n return snapshotRanges;\n }\n\n getModelRanges(ranges: readonly GridRange[]): GridRange[] {\n const { userColumnWidths, movedColumns } = this.props;\n const { includeHiddenColumns } = this.state;\n const hiddenColumns = IrisGridUtils.getHiddenColumns(userColumnWidths);\n let modelRanges = GridUtils.getModelRanges(ranges, movedColumns);\n if (!includeHiddenColumns && hiddenColumns.length > 0) {\n const subtractRanges = hiddenColumns.map(GridRange.makeColumn);\n modelRanges = GridRange.subtractRangesFromRanges(\n modelRanges,\n subtractRanges\n );\n }\n return modelRanges;\n }\n\n resetDownloadState(): void {\n this.setState({ errorMessage: null });\n }\n\n async handleDownloadClick(): Promise<void> {\n const { model, isDownloading, onDownloadStart, onDownload, onCancel } =\n this.props;\n const { fileName, includeColumnHeaders, useUnformattedValues } = this.state;\n\n if (isDownloading) {\n onCancel();\n return;\n }\n\n this.resetDownloadState();\n\n const snapshotRanges = this.getSnapshotRanges();\n const modelRanges = this.getModelRanges(snapshotRanges);\n if (this.validateOptionInput()) {\n onDownloadStart();\n try {\n const frozenTable = await model.export();\n const tableSubscription = frozenTable.setViewport(0, 0);\n await tableSubscription.getViewportData();\n onDownload(\n fileName,\n frozenTable,\n tableSubscription,\n snapshotRanges,\n modelRanges,\n includeColumnHeaders,\n useUnformattedValues\n );\n } catch (error) {\n log.error('CSV download failed', error);\n\n this.setState({\n errorMessage: (\n <p>\n <FontAwesomeIcon icon={vsWarning} /> {`${error}`}\n </p>\n ),\n });\n onCancel();\n }\n }\n }\n\n handleDownloadRowOptionChanged(\n event: React.ChangeEvent<HTMLInputElement>\n ): void {\n this.setState({ downloadRowOption: event.target.value });\n }\n\n handleCustomizedDownloadRowOptionChanged(\n event: React.ChangeEvent<HTMLSelectElement>\n ): void {\n this.setState({ customizedDownloadRowOption: event.target.value });\n }\n\n handleCustomizedDownloadRowsChanged(\n event: React.ChangeEvent<HTMLInputElement>\n ): void {\n this.setState({ customizedDownloadRows: parseInt(event.target.value, 10) });\n }\n\n handleIncludeColumnHeadersChanged(): void {\n this.setState(({ includeColumnHeaders }) => ({\n includeColumnHeaders: !includeColumnHeaders,\n }));\n }\n\n handleIncludeHiddenColumnsChanged(): void {\n this.setState(({ includeHiddenColumns }) => ({\n includeHiddenColumns: !includeHiddenColumns,\n }));\n }\n\n handleUseUnformattedValuesChanged(): void {\n this.setState(({ useUnformattedValues }) => ({\n useUnformattedValues: !useUnformattedValues,\n }));\n }\n\n validateOptionInput(): boolean {\n const { selectedRanges } = this.props;\n const { downloadRowOption, customizedDownloadRows } = this.state;\n\n if (\n downloadRowOption ===\n TableCsvExporter.DOWNLOAD_ROW_OPTIONS.SELECTED_ROWS &&\n selectedRanges.length === 0\n ) {\n this.setState({\n errorMessage: (\n <p>\n <FontAwesomeIcon icon={vsWarning} /> No rows selected. Please select\n some rows in the table.\n </p>\n ),\n });\n return false;\n }\n\n if (\n downloadRowOption ===\n TableCsvExporter.DOWNLOAD_ROW_OPTIONS.CUSTOMIZED_ROWS &&\n customizedDownloadRows <= 0\n ) {\n this.setState({\n errorMessage: (\n <p>\n <FontAwesomeIcon icon={vsWarning} /> Number of rows to output must\n be greater than 0\n </p>\n ),\n });\n return false;\n }\n return true;\n }\n\n render(): ReactElement {\n const {\n model,\n isDownloading,\n tableDownloadProgress,\n tableDownloadEstimatedTime,\n selectedRanges,\n tableDownloadStatus,\n } = this.props;\n const {\n fileName,\n downloadRowOption,\n customizedDownloadRowOption,\n customizedDownloadRows,\n includeColumnHeaders,\n includeHiddenColumns,\n useUnformattedValues,\n errorMessage,\n id,\n } = this.state;\n const { rowCount } = model;\n return (\n <div className=\"table-csv-exporter\">\n <div className=\"section-title\">Download Rows</div>\n <div className=\"form-group\">\n <RadioGroup\n onChange={this.handleDownloadRowOptionChanged}\n value={downloadRowOption}\n disabled={isDownloading}\n >\n <RadioItem\n value={TableCsvExporter.DOWNLOAD_ROW_OPTIONS.ALL_ROWS}\n data-testid=\"radio-csv-exporter-download-all\"\n >\n All Rows\n <span className=\"text-muted ml-2\">\n {`(${rowCount\n .toString()\n .replace(/(\\d)(?=(\\d{3})+(?!\\d))/g, '$1,')} rows)`}\n </span>\n </RadioItem>\n <RadioItem\n value={TableCsvExporter.DOWNLOAD_ROW_OPTIONS.SELECTED_ROWS}\n data-testid=\"radio-csv-exporter-only-selected\"\n >\n Only Selected Rows\n <span className=\"text-muted ml-2\">\n {selectedRanges.length > 0\n ? `(${GridRange.rowCount(selectedRanges)\n .toString()\n .replace(/(\\d)(?=(\\d{3})+(?!\\d))/g, '$1,')} rows)`\n : null}\n </span>\n </RadioItem>\n <RadioItem\n value={TableCsvExporter.DOWNLOAD_ROW_OPTIONS.CUSTOMIZED_ROWS}\n data-testid=\"radio-csv-exporter-customized-rows\"\n >\n <div\n className=\"radio-input-row\"\n role=\"presentation\"\n onClick={() => {\n this.setState({\n downloadRowOption:\n TableCsvExporter.DOWNLOAD_ROW_OPTIONS.CUSTOMIZED_ROWS,\n });\n }}\n >\n <select\n value={customizedDownloadRowOption}\n data-testid=\"select-csv-exporter-customized-rows\"\n className=\"custom-select\"\n disabled={isDownloading}\n onChange={this.handleCustomizedDownloadRowOptionChanged}\n >\n <option value=\"FIRST\">First</option>\n <option value=\"LAST\">Last</option>\n </select>\n <input\n type=\"number\"\n className=\"form-control\"\n id={`customizedRows-${id}`}\n data-testid=\"input-csv-exporter-customized-rows\"\n name={`customizedRows-${id}`}\n placeholder=\"100\"\n value={customizedDownloadRows}\n disabled={isDownloading}\n onChange={this.handleCustomizedDownloadRowsChanged}\n />\n <div>Rows</div>\n </div>\n </RadioItem>\n </RadioGroup>\n </div>\n <div className=\"form-group\">\n <label htmlFor={`customizedRows-${id}`}>File Name</label>\n <input\n type=\"text\"\n className=\"form-control\"\n id={`filename-${id}`}\n data-testid=\"input-csv-exporter-file-name\"\n name={`filename-${id}`}\n value={fileName}\n onChange={event => {\n this.setState({ fileName: event.target.value });\n }}\n disabled={isDownloading}\n />\n </div>\n <div className=\"checkbox-options\">\n <Checkbox\n checked={includeColumnHeaders}\n onChange={this.handleIncludeColumnHeadersChanged}\n >\n Include column headers\n </Checkbox>\n <Checkbox\n checked={includeHiddenColumns}\n onChange={this.handleIncludeHiddenColumnsChanged}\n >\n Include hidden columns\n </Checkbox>\n <Checkbox\n checked={useUnformattedValues}\n onChange={this.handleUseUnformattedValuesChanged}\n >\n Use unformatted values\n </Checkbox>\n </div>\n <div className=\"section-footer flex-column\">\n {errorMessage != null && (\n <div className=\"error-message\">{errorMessage}</div>\n )}\n {tableDownloadStatus && (\n <div className=\"download-status\">\n {(tableDownloadStatus ===\n TableCsvExporter.DOWNLOAD_STATUS.DOWNLOADING ||\n tableDownloadStatus ===\n TableCsvExporter.DOWNLOAD_STATUS.INITIATING) && (\n <>\n {tableDownloadStatus ===\n TableCsvExporter.DOWNLOAD_STATUS.INITIATING && (\n <div className=\"text-muted\">Starting Download...</div>\n )}\n {tableDownloadStatus ===\n TableCsvExporter.DOWNLOAD_STATUS.DOWNLOADING && (\n <div className=\"text-muted d-flex justify-content-between\">\n <span>\n {tableDownloadEstimatedTime ||\n tableDownloadEstimatedTime === 0\n ? `Estimated time: ${TimeUtils.formatElapsedTime(\n tableDownloadEstimatedTime\n )}`\n : null}\n </span>\n <span>{`${tableDownloadProgress}%`}</span>\n </div>\n )}\n </>\n )}\n {tableDownloadStatus ===\n TableCsvExporter.DOWNLOAD_STATUS.FINISHED && (\n <div className=\"text-muted text-right\">Download Completed</div>\n )}\n {tableDownloadStatus ===\n TableCsvExporter.DOWNLOAD_STATUS.CANCELED && (\n <div className=\"text-muted\">Download Canceled</div>\n )}\n\n {(tableDownloadStatus ===\n TableCsvExporter.DOWNLOAD_STATUS.DOWNLOADING ||\n tableDownloadStatus ===\n TableCsvExporter.DOWNLOAD_STATUS.INITIATING) && (\n <div className=\"progress\">\n <div\n className=\"progress-bar progress-bar-striped progress-bar-animated\"\n style={{ width: `${tableDownloadProgress}%` }}\n />\n </div>\n )}\n {tableDownloadStatus ===\n TableCsvExporter.DOWNLOAD_STATUS.FINISHED && (\n <div className=\"progress\">\n <div\n className=\"progress-bar bg-success\"\n style={{ width: `${tableDownloadProgress}%` }}\n />\n </div>\n )}\n </div>\n )}\n <Button\n kind=\"primary\"\n data-testid=\"btn-csv-exporter-download\"\n className={ClassNames('btn-downloading', {\n 'btn-spinner btn-cancelable': isDownloading,\n })}\n onClick={this.handleDownloadClick}\n >\n {isDownloading && (\n <span>\n <LoadingSpinner />\n <span className=\"btn-normal-content\">Downloading</span>\n <span className=\"btn-hover-content\">Cancel</span>\n </span>\n )}\n {!isDownloading && 'Download'}\n </Button>\n </div>\n </div>\n );\n }\n}\n\nexport default TableCsvExporter;\n"],"mappings":"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"}