Why Gemfury? Push, build, and install  RubyGems npm packages Python packages Maven artifacts PHP packages Go Modules Debian packages RPM packages NuGet packages

Repository URL to install this package:

Details    
@doodle/components / structure / Footer / FooterNav.js
Size: Mime:
"use strict";

Object.defineProperty(exports, "__esModule", {
  value: true
});
exports["default"] = void 0;

var _react = _interopRequireDefault(require("react"));

var _propTypes = _interopRequireDefault(require("prop-types"));

var _Link = _interopRequireDefault(require("../../controls/Link/Link"));

var _pickDataAttributes = _interopRequireDefault(require("../../utils/pickDataAttributes"));

function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }

function _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }

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; }

var FooterNav = function FooterNav(_ref) {
  var links = _ref.links,
      variant = _ref.variant;

  var makeLink = function makeLink(itemOrElement) {
    if ( /*#__PURE__*/_react["default"].isValidElement(itemOrElement)) {
      return itemOrElement; // itemOrElement: <Link>
    }

    var label = itemOrElement.label,
        to = itemOrElement.to,
        rest = _objectWithoutProperties(itemOrElement, ["label", "to"]); // itemOrElement: { props }


    return /*#__PURE__*/_react["default"].createElement(_Link["default"], _extends({
      to: to
    }, (0, _pickDataAttributes["default"])(rest)), label);
  };

  var makeList = function makeList(linkItemsOrElements) {
    return /*#__PURE__*/_react["default"].createElement("ul", null, linkItemsOrElements.map(function (itemOrElement, index) {
      return /*#__PURE__*/_react["default"].createElement("li", {
        key: itemOrElement.key || index
      }, makeLink(itemOrElement));
    }));
  };

  if (variant === 'primary') {
    var linksRow1 = links.slice(0, 4);
    var linksRow2 = links.slice(4);

    var primaryNavWrapped = /*#__PURE__*/_react["default"].createElement("nav", {
      className: "Footer-primaryNav Footer-primaryNav-wrapped"
    }, makeList(linksRow1), makeList(linksRow2));

    var primaryNavStraight = /*#__PURE__*/_react["default"].createElement("nav", {
      className: "Footer-primaryNav Footer-primaryNav-straight"
    }, makeList(links));

    return /*#__PURE__*/_react["default"].createElement(_react["default"].Fragment, null, primaryNavWrapped, primaryNavStraight);
  } else if (variant === 'secondary') {
    var secondaryNav = /*#__PURE__*/_react["default"].createElement("nav", {
      className: "Footer-secondaryNav"
    }, makeList(links));

    return /*#__PURE__*/_react["default"].createElement(_react["default"].Fragment, null, secondaryNav);
  }
};

FooterNav.propTypes = {
  links: _propTypes["default"].arrayOf(_propTypes["default"].oneOfType([_propTypes["default"].object, _propTypes["default"].element])),
  variant: _propTypes["default"].oneOf(['primary', 'secondary'])
};
FooterNav.defaultProps = {
  links: [],
  variant: 'primary'
};
var _default = FooterNav;
exports["default"] = _default;