UNPKG

@findify/react-components

Version:
80 lines (71 loc) 3.96 kB
function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; } function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; } function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; } function _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; } function _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; } /** * @module components/Icon */ import { createElement } from 'react'; import cx from 'classnames'; var styles = { "root": "findify-components--icon" }; import Filters from "./icons/Filters"; import Fire from "./icons/Fire"; import Minus from "./icons/Minus"; import Plus from "./icons/Plus"; import Search from "./icons/Search"; import Sorting from "./icons/Sorting"; import CheckmarkDark from "./icons/Checkmark/Dark"; import Star from "./icons/Star"; import XDark from "./icons/X/Dark"; import XMobile from "./icons/X/Mobile"; import RadioEmpty from "./icons/Radio/Empty"; import RadioFilled from "./icons/Radio/Filled"; import ArrowBack from "./icons/Arrow/Back"; import ArrowDown from "./icons/Arrow/Down"; import ArrowUp from "./icons/Arrow/Up"; import ArrowLeft from "./icons/Arrow/Left"; import ArrowRight from "./icons/Arrow/Right"; import ArrowLeftBig from "./icons/Arrow/Left-Big"; import ArrowRightBig from "./icons/Arrow/Right-Big"; import CheckboxFilled from "./icons/Checkbox/Filled"; import CheckboxEmpty from "./icons/Checkbox/Empty"; import ExternalLink from "./icons/ExternalLink"; /** Possible icon types */ export var icons = { Filters: Filters, Fire: Fire, Minus: Minus, Plus: Plus, Search: Search, Sorting: Sorting, CheckmarkDark: CheckmarkDark, Star: Star, XDark: XDark, XMobile: XMobile, RadioEmpty: RadioEmpty, RadioFilled: RadioFilled, ArrowBack: ArrowBack, ArrowDown: ArrowDown, ArrowUp: ArrowUp, ArrowLeft: ArrowLeft, ArrowRight: ArrowRight, ArrowLeftBig: ArrowLeftBig, ArrowRightBig: ArrowRightBig, CheckboxFilled: CheckboxFilled, CheckboxEmpty: CheckboxEmpty, ExternalLink: ExternalLink }; /** Props that Icon accepts */ var Icon = function Icon(_ref) { var name = _ref.name, component = _ref.component, className = _ref.className, rest = _objectWithoutProperties(_ref, ["name", "component", "className"]); return /*#__PURE__*/createElement(component || icons[name], _objectSpread({ className: cx(styles.root, className) }, rest)); }; export default Icon;