All files / src/dialogs/query-history-dialog query-history-dialog.tsx

66.67% Statements 14/21
33.33% Branches 2/6
40% Functions 2/5
62.5% Lines 10/16

Press n or j to go to the next uncovered block, b, p or k for the previous block.

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89                                    2x 2x   2x     2x               2x     1x 1x                 1x 1x                                                       1x                            
/*
 * Licensed to the Apache Software Foundation (ASF) under one
 * or more contributor license agreements.  See the NOTICE file
 * distributed with this work for additional information
 * regarding copyright ownership.  The ASF licenses this file
 * to you under the Apache License, Version 2.0 (the
 * "License"); you may not use this file except in compliance
 * with the License.  You may obtain a copy of the License at
 *
 *     http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */
 
import { Button, Classes, Dialog, Intent, Tab, Tabs, TextArea } from '@blueprintjs/core';
import React, { useState } from 'react';
 
import { CenterMessage } from '../../components';
import { QueryRecord } from '../../utils/query-history';
 
import './query-history-dialog.scss';
 
export interface QueryHistoryDialogProps {
  queryRecords: readonly QueryRecord[];
  setQueryString: (queryString: string, queryContext: Record<string, any>) => void;
  onClose: () => void;
}
 
export const QueryHistoryDialog = React.memo(function QueryHistoryDialog(
  props: QueryHistoryDialogProps,
) {
  const [activeTab, setActiveTab] = useState(0);
  const { queryRecords, setQueryString, onClose } = props;
 
  function handleSelect() {
    const queryRecord = queryRecords[activeTab];
    setQueryString(queryRecord.queryString, queryRecord.queryContext || {});
    onClose();
  }
 
  function renderContent(): JSX.Element {
    Eif (!queryRecords.length) {
      return <CenterMessage>The query history is empty.</CenterMessage>;
    }
 
    const versions = queryRecords.map((record, index) => (
      <Tab
        id={index}
        key={index}
        title={record.version}
        panel={<TextArea readOnly value={record.queryString} className={'text-area'} />}
        panelClassName={'panel'}
      />
    ));
 
    return (
      <Tabs
        animate
        renderActiveTabPanelOnly
        vertical
        className={'tab-area'}
        selectedTabId={activeTab}
        onChange={(t: number) => setActiveTab(t)}
      >
        {versions}
        <Tabs.Expander />
      </Tabs>
    );
  }
 
  return (
    <Dialog className="query-history-dialog" isOpen onClose={onClose} title="Query history">
      <div className={Classes.DIALOG_BODY}>{renderContent()}</div>
      <div className={Classes.DIALOG_FOOTER}>
        <div className={Classes.DIALOG_FOOTER_ACTIONS}>
          <Button text="Close" onClick={onClose} />
          {Boolean(queryRecords.length) && (
            <Button text="Open" intent={Intent.PRIMARY} onClick={handleSelect} />
          )}
        </div>
      </div>
    </Dialog>
  );
});