@redux-devtools/rtk-query-monitor
Version:
rtk-query monitor for Redux DevTools
62 lines • 56.7 kB
JavaScript
function _EMOTION_STRINGIFIED_CSS_ERROR__() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
import React from 'react';
import { css } from '@emotion/react';
import { Select } from '@redux-devtools/ui';
import { StyleUtilsContext } from '../styles/themes';
import debounce from 'lodash.debounce';
import { sortQueryOptions } from '../utils/comparators';
import { filterQueryOptions } from '../utils/filters';
import { SortOrderButton } from './SortOrderButton';
import { RegexIcon } from './RegexIcon';
import { jsx as ___EmotionJSX } from "@emotion/react";
const srOnlyCss = process.env.NODE_ENV === "production" ? {
name: "ccj1rl",
styles: "position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0"
} : {
name: "rmutks-srOnlyCss",
styles: "position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0;label:srOnlyCss;/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/components/QueryForm.tsx"],"names":[],"mappings":"AAakB","file":"../../../src/components/QueryForm.tsx","sourcesContent":["import React, { ReactNode, FormEvent, MouseEvent, ChangeEvent } from 'react';\nimport type { DebouncedFunc } from 'lodash';\nimport { css } from '@emotion/react';\nimport { Select } from '@redux-devtools/ui';\nimport { QueryFormValues } from '../types';\nimport { StyleUtilsContext } from '../styles/themes';\nimport { SelectOption } from '../types';\nimport debounce from 'lodash.debounce';\nimport { sortQueryOptions, QueryComparators } from '../utils/comparators';\nimport { QueryFilters, filterQueryOptions } from '../utils/filters';\nimport { SortOrderButton } from './SortOrderButton';\nimport { RegexIcon } from './RegexIcon';\n\nconst srOnlyCss = css({\n  position: 'absolute',\n  width: 1,\n  height: 1,\n  padding: 0,\n  margin: '-1px',\n  overflow: 'hidden',\n  clip: 'rect(0,0,0,0)',\n  border: 0,\n});\n\nexport interface QueryFormProps {\n  values: QueryFormValues;\n  searchQueryRegex: RegExp | null;\n  onFormValuesChange: (values: Partial<QueryFormValues>) => void;\n}\n\ninterface QueryFormState {\n  searchValue: string;\n}\n\nconst selectId = 'rtk-query-comp-select';\nconst searchId = 'rtk-query-search-query';\nconst filterSelectId = 'rtk-query-search-query-select';\nconst searchPlaceholder = 'filter query by...';\n\nconst labels = {\n  regexToggle: {\n    info: 'Use regular expression search',\n    error: 'Invalid regular expression provided',\n  },\n};\n\nexport class QueryForm extends React.PureComponent<\n  QueryFormProps,\n  QueryFormState\n> {\n  constructor(props: QueryFormProps) {\n    super(props);\n\n    this.state = {\n      searchValue: props.values.searchValue,\n    };\n  }\n\n  inputSearchRef = React.createRef<HTMLInputElement>();\n\n  handleSubmit = (evt: FormEvent<HTMLFormElement>): void => {\n    evt.preventDefault();\n  };\n\n  handleButtonGroupClick = (isAsc: boolean): void => {\n    this.props.onFormValuesChange({ isAscendingQueryComparatorOrder: isAsc });\n  };\n\n  handleSelectComparatorChange = (\n    option: SelectOption<QueryComparators> | undefined | null,\n  ): void => {\n    if (typeof option?.value === 'string') {\n      this.props.onFormValuesChange({ queryComparator: option.value });\n    }\n  };\n\n  handleSelectFilterChange = (\n    option: SelectOption<QueryFilters> | undefined | null,\n  ): void => {\n    if (typeof option?.value === 'string') {\n      this.props.onFormValuesChange({ queryFilter: option.value });\n    }\n  };\n\n  handleRegexSearchClick = (): void => {\n    this.props.onFormValuesChange({\n      isRegexSearch: !this.props.values.isRegexSearch,\n    });\n  };\n\n  restoreCaretPosition = (start: number | null, end: number | null): void => {\n    window.requestAnimationFrame(() => {\n      if (this.inputSearchRef.current) {\n        this.inputSearchRef.current.selectionStart = start;\n        this.inputSearchRef.current.selectionEnd = end;\n      }\n    });\n  };\n\n  invalidateSearchValueFromProps: DebouncedFunc<() => void> = debounce(() => {\n    this.props.onFormValuesChange({\n      searchValue: this.state.searchValue,\n    });\n  }, 150);\n\n  handleSearchChange = (evt: ChangeEvent<HTMLInputElement>): void => {\n    const searchValue = evt.target.value.trim();\n    this.setState({ searchValue });\n    this.invalidateSearchValueFromProps();\n  };\n\n  handleClearSearchClick = (evt: MouseEvent<HTMLButtonElement>): void => {\n    evt.preventDefault();\n\n    if (this.state.searchValue) {\n      this.setState({ searchValue: '' });\n      this.invalidateSearchValueFromProps();\n    }\n  };\n\n  render(): ReactNode {\n    const {\n      searchQueryRegex,\n      values: {\n        isAscendingQueryComparatorOrder: isAsc,\n        queryComparator,\n        searchValue,\n        queryFilter,\n        isRegexSearch,\n      },\n    } = this.props;\n\n    const isRegexInvalid =\n      isRegexSearch && searchValue.length > 0 && searchQueryRegex == null;\n    const regexToggleType = isRegexInvalid ? 'error' : 'info';\n    const regexToggleLabel = labels.regexToggle[regexToggleType];\n\n    return (\n      <StyleUtilsContext.Consumer>\n        {({ base16Theme }) => {\n          return (\n            <form\n              id=\"rtk-query-monitor-query-selection-form\"\n              action=\"#\"\n              onSubmit={this.handleSubmit}\n              css={{\n                display: 'flex',\n                flexFlow: 'column nowrap',\n              }}\n            >\n              <div\n                css={(theme) => ({\n                  display: 'flex',\n                  padding: 4,\n                  flex: '0 0 auto',\n                  alignItems: 'center',\n                  borderBottomWidth: '1px',\n                  borderBottomStyle: 'solid',\n\n                  borderColor: theme.LIST_BORDER_COLOR,\n                })}\n              >\n                <label htmlFor={searchId} css={srOnlyCss}>\n                  filter query\n                </label>\n                <div\n                  css={(theme) => ({\n                    maxWidth: '65%',\n                    backgroundColor: theme.BACKGROUND_COLOR,\n                    display: 'flex',\n                    alignItems: 'center',\n                    flexFlow: 'row nowrap',\n                    flex: '1 1 auto',\n                    paddingRight: 6,\n                    '& input': {\n                      outline: 'none',\n                      border: 'none',\n                      width: '100%',\n                      flex: '1 1 auto',\n                      padding: '5px 10px',\n                      fontSize: '1em',\n                      position: 'relative',\n                      fontFamily:\n                        'monaco, Consolas, \"Lucida Console\", monospace',\n\n                      backgroundColor: theme.BACKGROUND_COLOR,\n                      color: theme.TEXT_COLOR,\n\n                      '&::-webkit-input-placeholder': {\n                        color: theme.TEXT_PLACEHOLDER_COLOR,\n                      },\n\n                      '&::-moz-placeholder': {\n                        color: theme.TEXT_PLACEHOLDER_COLOR,\n                      },\n                      '&::-webkit-search-cancel-button': {\n                        WebkitAppearance: 'none',\n                      },\n                    },\n                  })}\n                >\n                  <input\n                    ref={this.inputSearchRef}\n                    type=\"search\"\n                    value={this.state.searchValue}\n                    onChange={this.handleSearchChange}\n                    placeholder={searchPlaceholder}\n                  />\n                  <button\n                    type=\"reset\"\n                    aria-label=\"clear search\"\n                    data-invisible={\n                      +(this.state.searchValue.length === 0) || undefined\n                    }\n                    onClick={this.handleClearSearchClick}\n                    css={(theme) => ({\n                      WebkitAppearance: 'none',\n                      border: 'none',\n                      outline: 'none',\n                      boxShadow: 'none',\n                      display: 'block',\n                      flex: '0 0 auto',\n                      cursor: 'pointer',\n                      background: 'transparent',\n                      position: 'relative',\n                      fontSize: 'inherit',\n                      '&[data-invisible=\"1\"]': {\n                        visibility: 'hidden !important' as 'hidden',\n                      },\n                      '&::after': {\n                        content: '\"\\u00d7\"',\n                        display: 'block',\n                        padding: 4,\n                        fontSize: '1.2em',\n                        color: theme.TEXT_PLACEHOLDER_COLOR,\n                        background: 'transparent',\n                      },\n                      '&:hover::after': {\n                        color: theme.TEXT_COLOR,\n                      },\n                    })}\n                  />\n                  <button\n                    type=\"button\"\n                    aria-label={regexToggleLabel}\n                    title={regexToggleLabel}\n                    data-type={regexToggleType}\n                    aria-pressed={isRegexSearch}\n                    onClick={this.handleRegexSearchClick}\n                    css={(theme) => ({\n                      width: '24px',\n                      height: '24px',\n                      display: 'inline-block',\n                      flex: '0 0 auto',\n                      color: theme.TEXT_PLACEHOLDER_COLOR,\n                      cursor: 'pointer',\n                      padding: 0,\n                      fontSize: '0.7em',\n                      letterSpacing: '-0.7px',\n                      outline: 'none',\n                      boxShadow: 'none',\n                      fontWeight: '700',\n                      border: 'none',\n\n                      '&:hover': {\n                        color: theme.TEXT_COLOR,\n                      },\n\n                      backgroundColor: 'transparent',\n                      '&[aria-pressed=\"true\"]': {\n                        color: theme.BACKGROUND_COLOR,\n                        backgroundColor: theme.TEXT_COLOR,\n                      },\n\n                      '&[data-type=\"error\"]': {\n                        color: theme.TEXT_COLOR,\n                        backgroundColor: theme.TOGGLE_BUTTON_ERROR,\n                      },\n                    })}\n                  >\n                    <RegexIcon />\n                  </button>\n                </div>\n                <label htmlFor={selectId} css={srOnlyCss}>\n                  filter by\n                </label>\n                <Select<SelectOption<QueryFilters>>\n                  id={filterSelectId}\n                  isSearchable={false}\n                  options={filterQueryOptions}\n                  theme={base16Theme as any}\n                  value={filterQueryOptions.find(\n                    (opt) => opt?.value === queryFilter,\n                  )}\n                  onChange={this.handleSelectFilterChange}\n                />\n              </div>\n              <div\n                css={{\n                  display: 'flex',\n                  padding: '0.4em',\n                  '& label': {\n                    display: 'flex',\n                    flex: '0 0 auto',\n                    whiteSpace: 'nowrap',\n                    alignItems: 'center',\n                    paddingRight: '0.4em',\n                  },\n\n                  '& > :last-child': {\n                    flex: '0 0 auto',\n                    marginLeft: '0.4em',\n                  },\n                }}\n              >\n                <label htmlFor={selectId}>Sort by</label>\n                <Select<SelectOption<QueryComparators>>\n                  id={selectId}\n                  isSearchable={false}\n                  theme={base16Theme as any}\n                  value={sortQueryOptions.find(\n                    (opt) => opt?.value === queryComparator,\n                  )}\n                  options={sortQueryOptions}\n                  onChange={this.handleSelectComparatorChange}\n                />\n                <SortOrderButton\n                  id={'rtk-query-sort-order-button'}\n                  isAsc={isAsc}\n                  onChange={this.handleButtonGroupClick}\n                />\n              </div>\n            </form>\n          );\n        }}\n      </StyleUtilsContext.Consumer>\n    );\n  }\n}\n"]} */",
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
};
const selectId = 'rtk-query-comp-select';
const searchId = 'rtk-query-search-query';
const filterSelectId = 'rtk-query-search-query-select';
const searchPlaceholder = 'filter query by...';
const labels = {
regexToggle: {
info: 'Use regular expression search',
error: 'Invalid regular expression provided'
}
};
var _ref2 = process.env.NODE_ENV === "production" ? {
name: "6joyip",
styles: "display:flex;flex-flow:column nowrap"
} : {
name: "1su3ua4-QueryForm",
styles: "display:flex;flex-flow:column nowrap;label:QueryForm;/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/components/QueryForm.tsx"],"names":[],"mappings":"AAiJc","file":"../../../src/components/QueryForm.tsx","sourcesContent":["import React, { ReactNode, FormEvent, MouseEvent, ChangeEvent } from 'react';\nimport type { DebouncedFunc } from 'lodash';\nimport { css } from '@emotion/react';\nimport { Select } from '@redux-devtools/ui';\nimport { QueryFormValues } from '../types';\nimport { StyleUtilsContext } from '../styles/themes';\nimport { SelectOption } from '../types';\nimport debounce from 'lodash.debounce';\nimport { sortQueryOptions, QueryComparators } from '../utils/comparators';\nimport { QueryFilters, filterQueryOptions } from '../utils/filters';\nimport { SortOrderButton } from './SortOrderButton';\nimport { RegexIcon } from './RegexIcon';\n\nconst srOnlyCss = css({\n  position: 'absolute',\n  width: 1,\n  height: 1,\n  padding: 0,\n  margin: '-1px',\n  overflow: 'hidden',\n  clip: 'rect(0,0,0,0)',\n  border: 0,\n});\n\nexport interface QueryFormProps {\n  values: QueryFormValues;\n  searchQueryRegex: RegExp | null;\n  onFormValuesChange: (values: Partial<QueryFormValues>) => void;\n}\n\ninterface QueryFormState {\n  searchValue: string;\n}\n\nconst selectId = 'rtk-query-comp-select';\nconst searchId = 'rtk-query-search-query';\nconst filterSelectId = 'rtk-query-search-query-select';\nconst searchPlaceholder = 'filter query by...';\n\nconst labels = {\n  regexToggle: {\n    info: 'Use regular expression search',\n    error: 'Invalid regular expression provided',\n  },\n};\n\nexport class QueryForm extends React.PureComponent<\n  QueryFormProps,\n  QueryFormState\n> {\n  constructor(props: QueryFormProps) {\n    super(props);\n\n    this.state = {\n      searchValue: props.values.searchValue,\n    };\n  }\n\n  inputSearchRef = React.createRef<HTMLInputElement>();\n\n  handleSubmit = (evt: FormEvent<HTMLFormElement>): void => {\n    evt.preventDefault();\n  };\n\n  handleButtonGroupClick = (isAsc: boolean): void => {\n    this.props.onFormValuesChange({ isAscendingQueryComparatorOrder: isAsc });\n  };\n\n  handleSelectComparatorChange = (\n    option: SelectOption<QueryComparators> | undefined | null,\n  ): void => {\n    if (typeof option?.value === 'string') {\n      this.props.onFormValuesChange({ queryComparator: option.value });\n    }\n  };\n\n  handleSelectFilterChange = (\n    option: SelectOption<QueryFilters> | undefined | null,\n  ): void => {\n    if (typeof option?.value === 'string') {\n      this.props.onFormValuesChange({ queryFilter: option.value });\n    }\n  };\n\n  handleRegexSearchClick = (): void => {\n    this.props.onFormValuesChange({\n      isRegexSearch: !this.props.values.isRegexSearch,\n    });\n  };\n\n  restoreCaretPosition = (start: number | null, end: number | null): void => {\n    window.requestAnimationFrame(() => {\n      if (this.inputSearchRef.current) {\n        this.inputSearchRef.current.selectionStart = start;\n        this.inputSearchRef.current.selectionEnd = end;\n      }\n    });\n  };\n\n  invalidateSearchValueFromProps: DebouncedFunc<() => void> = debounce(() => {\n    this.props.onFormValuesChange({\n      searchValue: this.state.searchValue,\n    });\n  }, 150);\n\n  handleSearchChange = (evt: ChangeEvent<HTMLInputElement>): void => {\n    const searchValue = evt.target.value.trim();\n    this.setState({ searchValue });\n    this.invalidateSearchValueFromProps();\n  };\n\n  handleClearSearchClick = (evt: MouseEvent<HTMLButtonElement>): void => {\n    evt.preventDefault();\n\n    if (this.state.searchValue) {\n      this.setState({ searchValue: '' });\n      this.invalidateSearchValueFromProps();\n    }\n  };\n\n  render(): ReactNode {\n    const {\n      searchQueryRegex,\n      values: {\n        isAscendingQueryComparatorOrder: isAsc,\n        queryComparator,\n        searchValue,\n        queryFilter,\n        isRegexSearch,\n      },\n    } = this.props;\n\n    const isRegexInvalid =\n      isRegexSearch && searchValue.length > 0 && searchQueryRegex == null;\n    const regexToggleType = isRegexInvalid ? 'error' : 'info';\n    const regexToggleLabel = labels.regexToggle[regexToggleType];\n\n    return (\n      <StyleUtilsContext.Consumer>\n        {({ base16Theme }) => {\n          return (\n            <form\n              id=\"rtk-query-monitor-query-selection-form\"\n              action=\"#\"\n              onSubmit={this.handleSubmit}\n              css={{\n                display: 'flex',\n                flexFlow: 'column nowrap',\n              }}\n            >\n              <div\n                css={(theme) => ({\n                  display: 'flex',\n                  padding: 4,\n                  flex: '0 0 auto',\n                  alignItems: 'center',\n                  borderBottomWidth: '1px',\n                  borderBottomStyle: 'solid',\n\n                  borderColor: theme.LIST_BORDER_COLOR,\n                })}\n              >\n                <label htmlFor={searchId} css={srOnlyCss}>\n                  filter query\n                </label>\n                <div\n                  css={(theme) => ({\n                    maxWidth: '65%',\n                    backgroundColor: theme.BACKGROUND_COLOR,\n                    display: 'flex',\n                    alignItems: 'center',\n                    flexFlow: 'row nowrap',\n                    flex: '1 1 auto',\n                    paddingRight: 6,\n                    '& input': {\n                      outline: 'none',\n                      border: 'none',\n                      width: '100%',\n                      flex: '1 1 auto',\n                      padding: '5px 10px',\n                      fontSize: '1em',\n                      position: 'relative',\n                      fontFamily:\n                        'monaco, Consolas, \"Lucida Console\", monospace',\n\n                      backgroundColor: theme.BACKGROUND_COLOR,\n                      color: theme.TEXT_COLOR,\n\n                      '&::-webkit-input-placeholder': {\n                        color: theme.TEXT_PLACEHOLDER_COLOR,\n                      },\n\n                      '&::-moz-placeholder': {\n                        color: theme.TEXT_PLACEHOLDER_COLOR,\n                      },\n                      '&::-webkit-search-cancel-button': {\n                        WebkitAppearance: 'none',\n                      },\n                    },\n                  })}\n                >\n                  <input\n                    ref={this.inputSearchRef}\n                    type=\"search\"\n                    value={this.state.searchValue}\n                    onChange={this.handleSearchChange}\n                    placeholder={searchPlaceholder}\n                  />\n                  <button\n                    type=\"reset\"\n                    aria-label=\"clear search\"\n                    data-invisible={\n                      +(this.state.searchValue.length === 0) || undefined\n                    }\n                    onClick={this.handleClearSearchClick}\n                    css={(theme) => ({\n                      WebkitAppearance: 'none',\n                      border: 'none',\n                      outline: 'none',\n                      boxShadow: 'none',\n                      display: 'block',\n                      flex: '0 0 auto',\n                      cursor: 'pointer',\n                      background: 'transparent',\n                      position: 'relative',\n                      fontSize: 'inherit',\n                      '&[data-invisible=\"1\"]': {\n                        visibility: 'hidden !important' as 'hidden',\n                      },\n                      '&::after': {\n                        content: '\"\\u00d7\"',\n                        display: 'block',\n                        padding: 4,\n                        fontSize: '1.2em',\n                        color: theme.TEXT_PLACEHOLDER_COLOR,\n                        background: 'transparent',\n                      },\n                      '&:hover::after': {\n                        color: theme.TEXT_COLOR,\n                      },\n                    })}\n                  />\n                  <button\n                    type=\"button\"\n                    aria-label={regexToggleLabel}\n                    title={regexToggleLabel}\n                    data-type={regexToggleType}\n                    aria-pressed={isRegexSearch}\n                    onClick={this.handleRegexSearchClick}\n                    css={(theme) => ({\n                      width: '24px',\n                      height: '24px',\n                      display: 'inline-block',\n                      flex: '0 0 auto',\n                      color: theme.TEXT_PLACEHOLDER_COLOR,\n                      cursor: 'pointer',\n                      padding: 0,\n                      fontSize: '0.7em',\n                      letterSpacing: '-0.7px',\n                      outline: 'none',\n                      boxShadow: 'none',\n                      fontWeight: '700',\n                      border: 'none',\n\n                      '&:hover': {\n                        color: theme.TEXT_COLOR,\n                      },\n\n                      backgroundColor: 'transparent',\n                      '&[aria-pressed=\"true\"]': {\n                        color: theme.BACKGROUND_COLOR,\n                        backgroundColor: theme.TEXT_COLOR,\n                      },\n\n                      '&[data-type=\"error\"]': {\n                        color: theme.TEXT_COLOR,\n                        backgroundColor: theme.TOGGLE_BUTTON_ERROR,\n                      },\n                    })}\n                  >\n                    <RegexIcon />\n                  </button>\n                </div>\n                <label htmlFor={selectId} css={srOnlyCss}>\n                  filter by\n                </label>\n                <Select<SelectOption<QueryFilters>>\n                  id={filterSelectId}\n                  isSearchable={false}\n                  options={filterQueryOptions}\n                  theme={base16Theme as any}\n                  value={filterQueryOptions.find(\n                    (opt) => opt?.value === queryFilter,\n                  )}\n                  onChange={this.handleSelectFilterChange}\n                />\n              </div>\n              <div\n                css={{\n                  display: 'flex',\n                  padding: '0.4em',\n                  '& label': {\n                    display: 'flex',\n                    flex: '0 0 auto',\n                    whiteSpace: 'nowrap',\n                    alignItems: 'center',\n                    paddingRight: '0.4em',\n                  },\n\n                  '& > :last-child': {\n                    flex: '0 0 auto',\n                    marginLeft: '0.4em',\n                  },\n                }}\n              >\n                <label htmlFor={selectId}>Sort by</label>\n                <Select<SelectOption<QueryComparators>>\n                  id={selectId}\n                  isSearchable={false}\n                  theme={base16Theme as any}\n                  value={sortQueryOptions.find(\n                    (opt) => opt?.value === queryComparator,\n                  )}\n                  options={sortQueryOptions}\n                  onChange={this.handleSelectComparatorChange}\n                />\n                <SortOrderButton\n                  id={'rtk-query-sort-order-button'}\n                  isAsc={isAsc}\n                  onChange={this.handleButtonGroupClick}\n                />\n              </div>\n            </form>\n          );\n        }}\n      </StyleUtilsContext.Consumer>\n    );\n  }\n}\n"]} */",
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
};
var _ref3 = process.env.NODE_ENV === "production" ? {
name: "i2xw34",
styles: "display:flex;padding:0.4em;& label{display:flex;flex:0 0 auto;white-space:nowrap;align-items:center;padding-right:0.4em;}& > :last-child{flex:0 0 auto;margin-left:0.4em;}"
} : {
name: "gydptq-QueryForm",
styles: "display:flex;padding:0.4em;& label{display:flex;flex:0 0 auto;white-space:nowrap;align-items:center;padding-right:0.4em;}& > :last-child{flex:0 0 auto;margin-left:0.4em;};label:QueryForm;/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/components/QueryForm.tsx"],"names":[],"mappings":"AA0SgB","file":"../../../src/components/QueryForm.tsx","sourcesContent":["import React, { ReactNode, FormEvent, MouseEvent, ChangeEvent } from 'react';\nimport type { DebouncedFunc } from 'lodash';\nimport { css } from '@emotion/react';\nimport { Select } from '@redux-devtools/ui';\nimport { QueryFormValues } from '../types';\nimport { StyleUtilsContext } from '../styles/themes';\nimport { SelectOption } from '../types';\nimport debounce from 'lodash.debounce';\nimport { sortQueryOptions, QueryComparators } from '../utils/comparators';\nimport { QueryFilters, filterQueryOptions } from '../utils/filters';\nimport { SortOrderButton } from './SortOrderButton';\nimport { RegexIcon } from './RegexIcon';\n\nconst srOnlyCss = css({\n  position: 'absolute',\n  width: 1,\n  height: 1,\n  padding: 0,\n  margin: '-1px',\n  overflow: 'hidden',\n  clip: 'rect(0,0,0,0)',\n  border: 0,\n});\n\nexport interface QueryFormProps {\n  values: QueryFormValues;\n  searchQueryRegex: RegExp | null;\n  onFormValuesChange: (values: Partial<QueryFormValues>) => void;\n}\n\ninterface QueryFormState {\n  searchValue: string;\n}\n\nconst selectId = 'rtk-query-comp-select';\nconst searchId = 'rtk-query-search-query';\nconst filterSelectId = 'rtk-query-search-query-select';\nconst searchPlaceholder = 'filter query by...';\n\nconst labels = {\n  regexToggle: {\n    info: 'Use regular expression search',\n    error: 'Invalid regular expression provided',\n  },\n};\n\nexport class QueryForm extends React.PureComponent<\n  QueryFormProps,\n  QueryFormState\n> {\n  constructor(props: QueryFormProps) {\n    super(props);\n\n    this.state = {\n      searchValue: props.values.searchValue,\n    };\n  }\n\n  inputSearchRef = React.createRef<HTMLInputElement>();\n\n  handleSubmit = (evt: FormEvent<HTMLFormElement>): void => {\n    evt.preventDefault();\n  };\n\n  handleButtonGroupClick = (isAsc: boolean): void => {\n    this.props.onFormValuesChange({ isAscendingQueryComparatorOrder: isAsc });\n  };\n\n  handleSelectComparatorChange = (\n    option: SelectOption<QueryComparators> | undefined | null,\n  ): void => {\n    if (typeof option?.value === 'string') {\n      this.props.onFormValuesChange({ queryComparator: option.value });\n    }\n  };\n\n  handleSelectFilterChange = (\n    option: SelectOption<QueryFilters> | undefined | null,\n  ): void => {\n    if (typeof option?.value === 'string') {\n      this.props.onFormValuesChange({ queryFilter: option.value });\n    }\n  };\n\n  handleRegexSearchClick = (): void => {\n    this.props.onFormValuesChange({\n      isRegexSearch: !this.props.values.isRegexSearch,\n    });\n  };\n\n  restoreCaretPosition = (start: number | null, end: number | null): void => {\n    window.requestAnimationFrame(() => {\n      if (this.inputSearchRef.current) {\n        this.inputSearchRef.current.selectionStart = start;\n        this.inputSearchRef.current.selectionEnd = end;\n      }\n    });\n  };\n\n  invalidateSearchValueFromProps: DebouncedFunc<() => void> = debounce(() => {\n    this.props.onFormValuesChange({\n      searchValue: this.state.searchValue,\n    });\n  }, 150);\n\n  handleSearchChange = (evt: ChangeEvent<HTMLInputElement>): void => {\n    const searchValue = evt.target.value.trim();\n    this.setState({ searchValue });\n    this.invalidateSearchValueFromProps();\n  };\n\n  handleClearSearchClick = (evt: MouseEvent<HTMLButtonElement>): void => {\n    evt.preventDefault();\n\n    if (this.state.searchValue) {\n      this.setState({ searchValue: '' });\n      this.invalidateSearchValueFromProps();\n    }\n  };\n\n  render(): ReactNode {\n    const {\n      searchQueryRegex,\n      values: {\n        isAscendingQueryComparatorOrder: isAsc,\n        queryComparator,\n        searchValue,\n        queryFilter,\n        isRegexSearch,\n      },\n    } = this.props;\n\n    const isRegexInvalid =\n      isRegexSearch && searchValue.length > 0 && searchQueryRegex == null;\n    const regexToggleType = isRegexInvalid ? 'error' : 'info';\n    const regexToggleLabel = labels.regexToggle[regexToggleType];\n\n    return (\n      <StyleUtilsContext.Consumer>\n        {({ base16Theme }) => {\n          return (\n            <form\n              id=\"rtk-query-monitor-query-selection-form\"\n              action=\"#\"\n              onSubmit={this.handleSubmit}\n              css={{\n                display: 'flex',\n                flexFlow: 'column nowrap',\n              }}\n            >\n              <div\n                css={(theme) => ({\n                  display: 'flex',\n                  padding: 4,\n                  flex: '0 0 auto',\n                  alignItems: 'center',\n                  borderBottomWidth: '1px',\n                  borderBottomStyle: 'solid',\n\n                  borderColor: theme.LIST_BORDER_COLOR,\n                })}\n              >\n                <label htmlFor={searchId} css={srOnlyCss}>\n                  filter query\n                </label>\n                <div\n                  css={(theme) => ({\n                    maxWidth: '65%',\n                    backgroundColor: theme.BACKGROUND_COLOR,\n                    display: 'flex',\n                    alignItems: 'center',\n                    flexFlow: 'row nowrap',\n                    flex: '1 1 auto',\n                    paddingRight: 6,\n                    '& input': {\n                      outline: 'none',\n                      border: 'none',\n                      width: '100%',\n                      flex: '1 1 auto',\n                      padding: '5px 10px',\n                      fontSize: '1em',\n                      position: 'relative',\n                      fontFamily:\n                        'monaco, Consolas, \"Lucida Console\", monospace',\n\n                      backgroundColor: theme.BACKGROUND_COLOR,\n                      color: theme.TEXT_COLOR,\n\n                      '&::-webkit-input-placeholder': {\n                        color: theme.TEXT_PLACEHOLDER_COLOR,\n                      },\n\n                      '&::-moz-placeholder': {\n                        color: theme.TEXT_PLACEHOLDER_COLOR,\n                      },\n                      '&::-webkit-search-cancel-button': {\n                        WebkitAppearance: 'none',\n                      },\n                    },\n                  })}\n                >\n                  <input\n                    ref={this.inputSearchRef}\n                    type=\"search\"\n                    value={this.state.searchValue}\n                    onChange={this.handleSearchChange}\n                    placeholder={searchPlaceholder}\n                  />\n                  <button\n                    type=\"reset\"\n                    aria-label=\"clear search\"\n                    data-invisible={\n                      +(this.state.searchValue.length === 0) || undefined\n                    }\n                    onClick={this.handleClearSearchClick}\n                    css={(theme) => ({\n                      WebkitAppearance: 'none',\n                      border: 'none',\n                      outline: 'none',\n                      boxShadow: 'none',\n                      display: 'block',\n                      flex: '0 0 auto',\n                      cursor: 'pointer',\n                      background: 'transparent',\n                      position: 'relative',\n                      fontSize: 'inherit',\n                      '&[data-invisible=\"1\"]': {\n                        visibility: 'hidden !important' as 'hidden',\n                      },\n                      '&::after': {\n                        content: '\"\\u00d7\"',\n                        display: 'block',\n                        padding: 4,\n                        fontSize: '1.2em',\n                        color: theme.TEXT_PLACEHOLDER_COLOR,\n                        background: 'transparent',\n                      },\n                      '&:hover::after': {\n                        color: theme.TEXT_COLOR,\n                      },\n                    })}\n                  />\n                  <button\n                    type=\"button\"\n                    aria-label={regexToggleLabel}\n                    title={regexToggleLabel}\n                    data-type={regexToggleType}\n                    aria-pressed={isRegexSearch}\n                    onClick={this.handleRegexSearchClick}\n                    css={(theme) => ({\n                      width: '24px',\n                      height: '24px',\n                      display: 'inline-block',\n                      flex: '0 0 auto',\n                      color: theme.TEXT_PLACEHOLDER_COLOR,\n                      cursor: 'pointer',\n                      padding: 0,\n                      fontSize: '0.7em',\n                      letterSpacing: '-0.7px',\n                      outline: 'none',\n                      boxShadow: 'none',\n                      fontWeight: '700',\n                      border: 'none',\n\n                      '&:hover': {\n                        color: theme.TEXT_COLOR,\n                      },\n\n                      backgroundColor: 'transparent',\n                      '&[aria-pressed=\"true\"]': {\n                        color: theme.BACKGROUND_COLOR,\n                        backgroundColor: theme.TEXT_COLOR,\n                      },\n\n                      '&[data-type=\"error\"]': {\n                        color: theme.TEXT_COLOR,\n                        backgroundColor: theme.TOGGLE_BUTTON_ERROR,\n                      },\n                    })}\n                  >\n                    <RegexIcon />\n                  </button>\n                </div>\n                <label htmlFor={selectId} css={srOnlyCss}>\n                  filter by\n                </label>\n                <Select<SelectOption<QueryFilters>>\n                  id={filterSelectId}\n                  isSearchable={false}\n                  options={filterQueryOptions}\n                  theme={base16Theme as any}\n                  value={filterQueryOptions.find(\n                    (opt) => opt?.value === queryFilter,\n                  )}\n                  onChange={this.handleSelectFilterChange}\n                />\n              </div>\n              <div\n                css={{\n                  display: 'flex',\n                  padding: '0.4em',\n                  '& label': {\n                    display: 'flex',\n                    flex: '0 0 auto',\n                    whiteSpace: 'nowrap',\n                    alignItems: 'center',\n                    paddingRight: '0.4em',\n                  },\n\n                  '& > :last-child': {\n                    flex: '0 0 auto',\n                    marginLeft: '0.4em',\n                  },\n                }}\n              >\n                <label htmlFor={selectId}>Sort by</label>\n                <Select<SelectOption<QueryComparators>>\n                  id={selectId}\n                  isSearchable={false}\n                  theme={base16Theme as any}\n                  value={sortQueryOptions.find(\n                    (opt) => opt?.value === queryComparator,\n                  )}\n                  options={sortQueryOptions}\n                  onChange={this.handleSelectComparatorChange}\n                />\n                <SortOrderButton\n                  id={'rtk-query-sort-order-button'}\n                  isAsc={isAsc}\n                  onChange={this.handleButtonGroupClick}\n                />\n              </div>\n            </form>\n          );\n        }}\n      </StyleUtilsContext.Consumer>\n    );\n  }\n}\n"]} */",
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
};
export class QueryForm extends React.PureComponent {
constructor(props) {
super(props);
this.state = {
searchValue: props.values.searchValue
};
}
inputSearchRef = (() => /*#__PURE__*/React.createRef())();
handleSubmit = evt => {
evt.preventDefault();
};
handleButtonGroupClick = isAsc => {
this.props.onFormValuesChange({
isAscendingQueryComparatorOrder: isAsc
});
};
handleSelectComparatorChange = option