react-dropdown-select
Advanced tools
Comparing version 1.2.1 to 1.2.2
@@ -269,3 +269,3 @@ "use strict"; | ||
value: function componentDidUpdate(prevProps, prevState) { | ||
if (prevState.values !== this.state.values || prevProps.multi !== this.props.multi) { | ||
if (prevState.values !== this.state.values) { | ||
this.props.onChange(this.state.values); | ||
@@ -275,2 +275,12 @@ this.updateSelectBounds(); | ||
if (prevProps.values !== this.props.values) { | ||
this.setState({ | ||
values: this.props.values | ||
}); | ||
} | ||
if (prevProps.multi !== this.props.multi) { | ||
this.updateSelectBounds(); | ||
} | ||
if (prevState.dropdown && prevState.dropdown !== this.state.dropdown, this.props.debounceDelay) { | ||
@@ -373,2 +383,3 @@ this.props.onDropdownClose(); | ||
values: [], | ||
options: [], | ||
multi: false, | ||
@@ -404,4 +415,4 @@ disabled: false, | ||
return disabled ? 'cursor: not-allowed;pointer-events: none;opacity: 0.3;' : 'pointer-events: all;'; | ||
}, ":focus-within{border-color:deepskyblue;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/index.js"],"names":[],"mappings":"AAgTsC","file":"../src/index.js","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport styled from '@emotion/styled';\nimport ClickOutHandler from 'react-onclickout';\n\nimport Content from './components/Content';\nimport Dropdown from './components/Dropdown';\nimport Loading from './components/Loading';\nimport Clear from './components/Clear';\nimport Separator from './components/Separator';\nimport DropdownHandle from './components/DropdownHandle';\n\nconst debounce = (fn, delay = 0) => {\n  let timerId;\n\n  return (...args) => {\n    if (timerId) {\n      clearTimeout(timerId);\n    }\n    timerId = setTimeout(() => {\n      fn(...args);\n      timerId = null;\n    }, delay);\n  };\n};\n\nexport class Select extends React.Component {\n  static propTypes = {\n    onChange: PropTypes.func.isRequired,\n    onDropdownClose: PropTypes.func,\n    onDropdownOpen: PropTypes.func,\n    onClearAll: PropTypes.func,\n    onSelectAll: PropTypes.func,\n    values: PropTypes.array,\n    options: PropTypes.array.isRequired,\n    keepOpen: PropTypes.bool,\n    dropdownGap: PropTypes.number,\n    multi: PropTypes.bool,\n    placeholder: PropTypes.string,\n    addPlaceholder: PropTypes.string,\n    disabled: PropTypes.bool,\n    className: PropTypes.string,\n    loading: PropTypes.bool,\n    clearable: PropTypes.bool,\n    separator: PropTypes.bool,\n    dropdownHandle: PropTypes.bool,\n    searchBy: PropTypes.string,\n    closeOnScroll: PropTypes.bool,\n    style: PropTypes.object,\n    contentRenderer: PropTypes.func,\n    dropdownRenderer: PropTypes.func,\n    itemRenderer: PropTypes.func,\n    noDataRenderer: PropTypes.func,\n    optionRenderer: PropTypes.func,\n    inputRenderer: PropTypes.func,\n    loadingRenderer: PropTypes.func,\n    clearRenderer: PropTypes.func,\n    separatorRenderer: PropTypes.func,\n    dropdownHandleRenderer: PropTypes.func\n  };\n\n  constructor(props) {\n    super(props);\n\n    this.state = {\n      dropdown: false,\n      values: [],\n      search: '',\n      selectBounds: {}\n    };\n\n    this.methods = {\n      removeItem: this.removeItem,\n      dropDown: this.dropDown,\n      addItem: this.addItem,\n      setSearch: this.setSearch,\n      getInputSize: this.getInputSize,\n      toggleSelectAll: this.toggleSelectAll,\n      clearAll: this.clearAll,\n      selectAll: this.selectAll,\n      searchResults: this.searchResults,\n      getSelectRef: this.getSelectRef,\n      isSelected: this.isSelected,\n      getSelectBounds: this.getSelectBounds\n    };\n\n    this.select = React.createRef();\n  }\n\n  componentDidMount() {\n    window.addEventListener('resize', debounce(this.updateSelectBounds));\n    window.addEventListener('scroll', debounce(this.onScroll));\n\n    this.props.onChange(this.state.values);\n\n    this.dropDown('close');\n\n    if (this.select) {\n      this.updateSelectBounds();\n    }\n  }\n\n  componentDidUpdate(prevProps, prevState) {\n    if (prevState.values !== this.state.values || prevProps.multi !== this.props.multi) {\n      this.props.onChange(this.state.values);\n      this.updateSelectBounds();\n    }\n\n    if (prevState.dropdown && prevState.dropdown !== this.state.dropdown, this.props.debounceDelay) {\n      this.props.onDropdownClose();\n    }\n\n    if (!prevState.dropdown && prevState.dropdown !== this.state.dropdown, this.props.debounceDelay) {\n      this.props.onDropdownOpen();\n    }\n  }\n\n  componentWillUnmount() {\n    window.removeEventListener('resize', debounce(this.updateSelectBounds, this.props.debounceDelay));\n    window.removeEventListener('scroll', debounce(this.onScroll, this.props.debounceDelay));\n  }\n\n  onScroll = () => {\n    if(this.props.closeOnScroll) {\n      this.dropDown('close');\n    }\n\n    this.updateSelectBounds();\n  };\n\n  updateSelectBounds = () =>\n    this.select.current && this.setState({\n      selectBounds: this.select.current.getBoundingClientRect()\n    });\n\n  getSelectBounds = () => this.state.selectBounds;\n\n  dropDown = (action = 'toggle') => {\n    if (this.props.keepOpen) {\n      return this.setState({ dropdown: true });\n    }\n\n    if (action === 'close') {\n      return this.setState({ dropdown: false, search: '' });\n    }\n\n    if (action === 'open') {\n      return this.setState({ dropdown: true });\n    }\n\n    if (action === 'toggle') {\n      return this.setState({ dropdown: !this.state.dropdown });\n    }\n\n    return false;\n  };\n\n  getSelectRef = () => this.select.current;\n\n  addItem = (item) => {\n    if (this.props.multi) {\n      if (this.state.values.indexOf(item) !== -1) {\n        return this.removeItem(null, item, false);\n      }\n\n      this.setState({\n        values: [...this.state.values, item]\n      });\n    } else {\n      this.setState({\n        values: [item],\n        dropdown: false,\n        search: ''\n      });\n    }\n\n    return true;\n  };\n\n  removeItem = (event, item, close = false) => {\n    if (event && close) {\n      event.preventDefault();\n      event.stopPropagation();\n      this.dropDown('close');\n    }\n\n    this.setState({\n      values: this.state.values.filter((values) => values.value !== item.value)\n    });\n  };\n\n  setSearch = (event) =>\n    this.setState({\n      search: event.target.value\n    });\n\n  getInputSize = () => {\n    if (this.state.search) {\n      return this.state.search.length;\n    }\n\n    if (this.state.values.length > 0) {\n      return this.props.addPlaceholder.length;\n    }\n\n    return this.props.placeholder.length;\n  };\n\n  toggleSelectAll = () => {\n    return this.setState({\n      values: this.state.values.length === 0 ? this.selectAll() : this.clearAll()\n    });\n  };\n\n  clearAll = () => {\n    this.props.onClearAll();\n    this.setState({\n      values: []\n    });\n  };\n\n  selectAll = () => {\n    this.props.onSelectAll();\n    return this.setState({\n      values: this.props.options\n    });\n  };\n\n  isSelected = (option) => this.state.values.indexOf(option) !== -1;\n\n  searchResults = () => {\n    const regexp = new RegExp(this.state.search, 'i');\n\n    return this.props.options.filter((item) =>\n      regexp.test(item[this.props.searchBy] || item.label)\n    );\n  };\n\n  render() {\n    return (\n      <ClickOutHandler onClickOut={() => this.dropDown('close')}>\n        <ReactDropdownSelect\n          style={this.props.style}\n          ref={this.select}\n          disabled={this.props.disabled}\n          className={this.props.className}>\n          <Content parentProps={this.props} parentState={this.state} parentMethods={this.methods} />\n\n          {this.props.loading && <Loading parentProps={this.props} />}\n\n          {this.props.clearable && (\n            <Clear parentProps={this.props} parentState={this.state} parentMethods={this.methods} />\n          )}\n\n          {this.props.separator && (\n            <Separator\n              parentProps={this.props}\n              parentState={this.state}\n              parentMethods={this.methods}\n            />\n          )}\n\n          {this.props.dropdownHandle && (\n            <DropdownHandle\n              parentProps={this.props}\n              parentState={this.state}\n              parentMethods={this.methods}\n            />\n          )}\n\n          {this.state.dropdown && (\n            <Dropdown\n              parentProps={this.props}\n              parentState={this.state}\n              parentMethods={this.methods}\n            />\n          )}\n        </ReactDropdownSelect>\n      </ClickOutHandler>\n    );\n  }\n}\n\nSelect.defaultProps = {\n  addPlaceholder: '+',\n  placeholder: 'Select...',\n  values: [],\n  multi: false,\n  disabled: false,\n  searchBy: 'label',\n  clearable: true,\n  dropdownHandle: true,\n  separator: true,\n  keepOpen: undefined,\n  noDataLabel: 'No data',\n  dropdownGap: 5,\n  closeOnScroll: false,\n  debounceDelay: 0,\n  onDropdownOpen: () => undefined,\n  onDropdownClose: () => undefined,\n  onClearAll: () => undefined,\n  onSelectAll: () => undefined\n};\n\nconst ReactDropdownSelect = styled.div`\n  display: flex;\n  border: 1px solid #ccc;\n  width: 100%;\n  border-radius: 2px;\n  padding: 2px 5px;\n  flex-direction: row;\n  align-items: center;\n  min-height: 36px;\n  ${({ disabled }) =>\n    disabled ? 'cursor: not-allowed;pointer-events: none;opacity: 0.3;' : 'pointer-events: all;'}\n\n  :focus-within {\n    border-color: deepskyblue;\n  }\n`;\n\nexport default Select;\n"]} */")); | ||
}, ":focus-within{border-color:deepskyblue;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/index.js"],"names":[],"mappings":"AAyTsC","file":"../src/index.js","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport styled from '@emotion/styled';\nimport ClickOutHandler from 'react-onclickout';\n\nimport Content from './components/Content';\nimport Dropdown from './components/Dropdown';\nimport Loading from './components/Loading';\nimport Clear from './components/Clear';\nimport Separator from './components/Separator';\nimport DropdownHandle from './components/DropdownHandle';\n\nconst debounce = (fn, delay = 0) => {\n  let timerId;\n\n  return (...args) => {\n    if (timerId) {\n      clearTimeout(timerId);\n    }\n    timerId = setTimeout(() => {\n      fn(...args);\n      timerId = null;\n    }, delay);\n  };\n};\n\nexport class Select extends React.Component {\n  static propTypes = {\n    onChange: PropTypes.func.isRequired,\n    onDropdownClose: PropTypes.func,\n    onDropdownOpen: PropTypes.func,\n    onClearAll: PropTypes.func,\n    onSelectAll: PropTypes.func,\n    values: PropTypes.array,\n    options: PropTypes.array.isRequired,\n    keepOpen: PropTypes.bool,\n    dropdownGap: PropTypes.number,\n    multi: PropTypes.bool,\n    placeholder: PropTypes.string,\n    addPlaceholder: PropTypes.string,\n    disabled: PropTypes.bool,\n    className: PropTypes.string,\n    loading: PropTypes.bool,\n    clearable: PropTypes.bool,\n    separator: PropTypes.bool,\n    dropdownHandle: PropTypes.bool,\n    searchBy: PropTypes.string,\n    closeOnScroll: PropTypes.bool,\n    style: PropTypes.object,\n    contentRenderer: PropTypes.func,\n    dropdownRenderer: PropTypes.func,\n    itemRenderer: PropTypes.func,\n    noDataRenderer: PropTypes.func,\n    optionRenderer: PropTypes.func,\n    inputRenderer: PropTypes.func,\n    loadingRenderer: PropTypes.func,\n    clearRenderer: PropTypes.func,\n    separatorRenderer: PropTypes.func,\n    dropdownHandleRenderer: PropTypes.func\n  };\n\n  constructor(props) {\n    super(props);\n\n    this.state = {\n      dropdown: false,\n      values: [],\n      search: '',\n      selectBounds: {}\n    };\n\n    this.methods = {\n      removeItem: this.removeItem,\n      dropDown: this.dropDown,\n      addItem: this.addItem,\n      setSearch: this.setSearch,\n      getInputSize: this.getInputSize,\n      toggleSelectAll: this.toggleSelectAll,\n      clearAll: this.clearAll,\n      selectAll: this.selectAll,\n      searchResults: this.searchResults,\n      getSelectRef: this.getSelectRef,\n      isSelected: this.isSelected,\n      getSelectBounds: this.getSelectBounds\n    };\n\n    this.select = React.createRef();\n  }\n\n  componentDidMount() {\n    window.addEventListener('resize', debounce(this.updateSelectBounds));\n    window.addEventListener('scroll', debounce(this.onScroll));\n\n    this.props.onChange(this.state.values);\n\n    this.dropDown('close');\n\n    if (this.select) {\n      this.updateSelectBounds();\n    }\n  }\n\n  componentDidUpdate(prevProps, prevState) {\n    if (prevState.values !== this.state.values) {\n      this.props.onChange(this.state.values);\n      this.updateSelectBounds();\n    }\n\n    if (prevProps.values !== this.props.values) {\n      this.setState({ values: this.props.values});\n    }\n\n    if (prevProps.multi !== this.props.multi) {\n      this.updateSelectBounds();\n    }\n\n    if (prevState.dropdown && prevState.dropdown !== this.state.dropdown, this.props.debounceDelay) {\n      this.props.onDropdownClose();\n    }\n\n    if (!prevState.dropdown && prevState.dropdown !== this.state.dropdown, this.props.debounceDelay) {\n      this.props.onDropdownOpen();\n    }\n  }\n\n  componentWillUnmount() {\n    window.removeEventListener('resize', debounce(this.updateSelectBounds, this.props.debounceDelay));\n    window.removeEventListener('scroll', debounce(this.onScroll, this.props.debounceDelay));\n  }\n\n  onScroll = () => {\n    if(this.props.closeOnScroll) {\n      this.dropDown('close');\n    }\n\n    this.updateSelectBounds();\n  };\n\n  updateSelectBounds = () =>\n    this.select.current && this.setState({\n      selectBounds: this.select.current.getBoundingClientRect()\n    });\n\n  getSelectBounds = () => this.state.selectBounds;\n\n  dropDown = (action = 'toggle') => {\n    if (this.props.keepOpen) {\n      return this.setState({ dropdown: true });\n    }\n\n    if (action === 'close') {\n      return this.setState({ dropdown: false, search: '' });\n    }\n\n    if (action === 'open') {\n      return this.setState({ dropdown: true });\n    }\n\n    if (action === 'toggle') {\n      return this.setState({ dropdown: !this.state.dropdown });\n    }\n\n    return false;\n  };\n\n  getSelectRef = () => this.select.current;\n\n  addItem = (item) => {\n    if (this.props.multi) {\n      if (this.state.values.indexOf(item) !== -1) {\n        return this.removeItem(null, item, false);\n      }\n\n      this.setState({\n        values: [...this.state.values, item]\n      });\n    } else {\n      this.setState({\n        values: [item],\n        dropdown: false,\n        search: ''\n      });\n    }\n\n    return true;\n  };\n\n  removeItem = (event, item, close = false) => {\n    if (event && close) {\n      event.preventDefault();\n      event.stopPropagation();\n      this.dropDown('close');\n    }\n\n    this.setState({\n      values: this.state.values.filter((values) => values.value !== item.value)\n    });\n  };\n\n  setSearch = (event) =>\n    this.setState({\n      search: event.target.value\n    });\n\n  getInputSize = () => {\n    if (this.state.search) {\n      return this.state.search.length;\n    }\n\n    if (this.state.values.length > 0) {\n      return this.props.addPlaceholder.length;\n    }\n\n    return this.props.placeholder.length;\n  };\n\n  toggleSelectAll = () => {\n    return this.setState({\n      values: this.state.values.length === 0 ? this.selectAll() : this.clearAll()\n    });\n  };\n\n  clearAll = () => {\n    this.props.onClearAll();\n    this.setState({\n      values: []\n    });\n  };\n\n  selectAll = () => {\n    this.props.onSelectAll();\n    return this.setState({\n      values: this.props.options\n    });\n  };\n\n  isSelected = (option) => this.state.values.indexOf(option) !== -1;\n\n  searchResults = () => {\n    const regexp = new RegExp(this.state.search, 'i');\n\n    return this.props.options.filter((item) =>\n      regexp.test(item[this.props.searchBy] || item.label)\n    );\n  };\n\n  render() {\n    return (\n      <ClickOutHandler onClickOut={() => this.dropDown('close')}>\n        <ReactDropdownSelect\n          style={this.props.style}\n          ref={this.select}\n          disabled={this.props.disabled}\n          className={this.props.className}>\n          <Content parentProps={this.props} parentState={this.state} parentMethods={this.methods} />\n\n          {this.props.loading && <Loading parentProps={this.props} />}\n\n          {this.props.clearable && (\n            <Clear parentProps={this.props} parentState={this.state} parentMethods={this.methods} />\n          )}\n\n          {this.props.separator && (\n            <Separator\n              parentProps={this.props}\n              parentState={this.state}\n              parentMethods={this.methods}\n            />\n          )}\n\n          {this.props.dropdownHandle && (\n            <DropdownHandle\n              parentProps={this.props}\n              parentState={this.state}\n              parentMethods={this.methods}\n            />\n          )}\n\n          {this.state.dropdown && (\n            <Dropdown\n              parentProps={this.props}\n              parentState={this.state}\n              parentMethods={this.methods}\n            />\n          )}\n        </ReactDropdownSelect>\n      </ClickOutHandler>\n    );\n  }\n}\n\nSelect.defaultProps = {\n  addPlaceholder: '+',\n  placeholder: 'Select...',\n  values: [],\n  options: [],\n  multi: false,\n  disabled: false,\n  searchBy: 'label',\n  clearable: true,\n  dropdownHandle: true,\n  separator: true,\n  keepOpen: undefined,\n  noDataLabel: 'No data',\n  dropdownGap: 5,\n  closeOnScroll: false,\n  debounceDelay: 0,\n  onDropdownOpen: () => undefined,\n  onDropdownClose: () => undefined,\n  onClearAll: () => undefined,\n  onSelectAll: () => undefined\n};\n\nconst ReactDropdownSelect = styled.div`\n  display: flex;\n  border: 1px solid #ccc;\n  width: 100%;\n  border-radius: 2px;\n  padding: 2px 5px;\n  flex-direction: row;\n  align-items: center;\n  min-height: 36px;\n  ${({ disabled }) =>\n    disabled ? 'cursor: not-allowed;pointer-events: none;opacity: 0.3;' : 'pointer-events: all;'}\n\n  :focus-within {\n    border-color: deepskyblue;\n  }\n`;\n\nexport default Select;\n"]} */")); | ||
var _default = Select; | ||
exports.default = _default; |
{ | ||
"name": "react-dropdown-select", | ||
"version": "1.2.1", | ||
"version": "1.2.2", | ||
"description": "Customizable dropdown select for react", | ||
@@ -5,0 +5,0 @@ "main": "dist/index.js", |
Long strings
Supply chain riskContains long string literals, which may be a sign of obfuscated or packed code.
Found 1 instance in 1 package
Long strings
Supply chain riskContains long string literals, which may be a sign of obfuscated or packed code.
Found 1 instance in 1 package
65179
829