adui
Version:
<div> <img src="https://wxa.wxs.qq.com/mpweb/delivery/legacy/wxadtouch/upload/t1/od834zef_52939fc6.png" style="margin:40px 0 0 -8px; background-color: #fcfcfc; box-shadow: none;" /> </div>
117 lines • 19.3 kB
JavaScript
var _excluded = ["children", "className", "defaultOpenIndexes", "defaultSelectedIndex", "onChange", "onOpenChange", "openIndexes", "selectedIndex", "size"];
function _extends() { return _extends = Object.assign ? Object.assign.bind() : function (n) { for (var e = 1; e < arguments.length; e++) { var t = arguments[e]; for (var r in t) ({}).hasOwnProperty.call(t, r) && (n[r] = t[r]); } return n; }, _extends.apply(null, arguments); }
function _toConsumableArray(r) { return _arrayWithoutHoles(r) || _iterableToArray(r) || _unsupportedIterableToArray(r) || _nonIterableSpread(); }
function _nonIterableSpread() { throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
function _iterableToArray(r) { if ("undefined" != typeof Symbol && null != r[Symbol.iterator] || null != r["@@iterator"]) return Array.from(r); }
function _arrayWithoutHoles(r) { if (Array.isArray(r)) return _arrayLikeToArray(r); }
function _slicedToArray(r, e) { return _arrayWithHoles(r) || _iterableToArrayLimit(r, e) || _unsupportedIterableToArray(r, e) || _nonIterableRest(); }
function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
function _unsupportedIterableToArray(r, a) { if (r) { if ("string" == typeof r) return _arrayLikeToArray(r, a); var t = {}.toString.call(r).slice(8, -1); return "Object" === t && r.constructor && (t = r.constructor.name), "Map" === t || "Set" === t ? Array.from(r) : "Arguments" === t || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t) ? _arrayLikeToArray(r, a) : void 0; } }
function _arrayLikeToArray(r, a) { (null == a || a > r.length) && (a = r.length); for (var e = 0, n = Array(a); e < a; e++) n[e] = r[e]; return n; }
function _iterableToArrayLimit(r, l) { var t = null == r ? null : "undefined" != typeof Symbol && r[Symbol.iterator] || r["@@iterator"]; if (null != t) { var e, n, i, u, a = [], f = !0, o = !1; try { if (i = (t = t.call(r)).next, 0 === l) { if (Object(t) !== t) return; f = !1; } else for (; !(f = (e = i.call(t)).done) && (a.push(e.value), a.length !== l); f = !0); } catch (r) { o = !0, n = r; } finally { try { if (!f && null != t.return && (u = t.return(), Object(u) !== u)) return; } finally { if (o) throw n; } } return a; } }
function _arrayWithHoles(r) { if (Array.isArray(r)) return r; }
function _objectWithoutProperties(e, t) { if (null == e) return {}; var o, r, i = _objectWithoutPropertiesLoose(e, t); if (Object.getOwnPropertySymbols) { var s = Object.getOwnPropertySymbols(e); for (r = 0; r < s.length; r++) o = s[r], t.includes(o) || {}.propertyIsEnumerable.call(e, o) && (i[o] = e[o]); } return i; }
function _objectWithoutPropertiesLoose(r, e) { if (null == r) return {}; var t = {}; for (var n in r) if ({}.hasOwnProperty.call(r, n)) { if (e.includes(n)) continue; t[n] = r[n]; } return t; }
import React, { useContext, useState } from "react";
import PropTypes from "prop-types";
import classNames from "classnames";
import { ConfigContext, getComputedSize } from "../config-provider";
import Divider from "./Divider";
import Group from "./Group";
import Item from "./Item";
import SubNav from "./SubNav";
import { NavContext } from "./Context";
import "./style";
var noop = function noop() {};
var prefix = "adui-nav";
var Nav = function Nav(_ref) {
var children = _ref.children,
className = _ref.className,
defaultOpenIndexes = _ref.defaultOpenIndexes,
defaultSelectedIndex = _ref.defaultSelectedIndex,
onChange = _ref.onChange,
onOpenChange = _ref.onOpenChange,
openIndexesProp = _ref.openIndexes,
selectedIndexProp = _ref.selectedIndex,
sizeProp = _ref.size,
otherProps = _objectWithoutProperties(_ref, _excluded);
var _useState = useState(selectedIndexProp !== null ? selectedIndexProp : defaultSelectedIndex),
_useState2 = _slicedToArray(_useState, 2),
selectedIndex = _useState2[0],
setSelectedIndex = _useState2[1];
var _useState3 = useState(openIndexesProp !== null ? openIndexesProp : defaultOpenIndexes),
_useState4 = _slicedToArray(_useState3, 2),
openIndexes = _useState4[0],
setOpenIndexes = _useState4[1];
if (selectedIndexProp !== null && selectedIndex !== selectedIndexProp) {
setSelectedIndex(selectedIndexProp);
}
if (openIndexesProp !== null && openIndexes !== openIndexesProp) {
setOpenIndexes(openIndexesProp);
}
var _useContext = useContext(ConfigContext),
sizeContext = _useContext.size;
var size = getComputedSize(sizeProp, sizeContext);
var classSet = classNames(className, "".concat(prefix, "-wrapper"), "".concat(prefix, "-").concat(size));
var handleChange = function handleChange(index) {
if (selectedIndexProp === null) {
setSelectedIndex(index);
}
if (onChange) {
onChange(index);
}
};
var handleOpenChange = function handleOpenChange(index) {
var openIndexesDuplicate = openIndexes ? _toConsumableArray(openIndexes) : [];
var i = openIndexesDuplicate.indexOf(index);
if (i !== -1) {
openIndexesDuplicate.splice(i, 1);
} else {
openIndexesDuplicate.push(index);
}
if (openIndexesProp === null) {
setOpenIndexes(openIndexesDuplicate);
}
if (onOpenChange) {
onOpenChange(openIndexesDuplicate);
}
};
return React.createElement(NavContext.Provider, {
value: {
onChange: handleChange,
onOpenChange: handleOpenChange,
openIndexes: openIndexes,
selectedIndex: selectedIndex
}
}, React.createElement("nav", _extends({
className: classSet
}, otherProps), children));
};
Nav.Divider = Divider;
Nav.Group = Group;
Nav.Item = Item;
Nav.SubNav = SubNav;
Nav.propTypes = {
children: PropTypes.node,
className: PropTypes.string,
defaultOpenIndexes: PropTypes.array,
defaultSelectedIndex: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),
onChange: PropTypes.func,
onOpenChange: PropTypes.func,
openIndexes: PropTypes.array,
selectedIndex: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),
size: PropTypes.oneOf(["mini", "small", "medium", "large"])
};
Nav.defaultProps = {
children: null,
className: undefined,
defaultOpenIndexes: [],
defaultSelectedIndex: null,
onChange: noop,
onOpenChange: noop,
openIndexes: null,
selectedIndex: null,
size: "small"
};
export default Nav;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["React","useContext","useState","PropTypes","classNames","ConfigContext","getComputedSize","Divider","Group","Item","SubNav","NavContext","noop","prefix","Nav","_ref","children","className","defaultOpenIndexes","defaultSelectedIndex","onChange","onOpenChange","openIndexesProp","openIndexes","selectedIndexProp","selectedIndex","sizeProp","size","otherProps","_objectWithoutProperties","_excluded","_useState","_useState2","_slicedToArray","setSelectedIndex","_useState3","_useState4","setOpenIndexes","_useContext","sizeContext","classSet","concat","handleChange","index","handleOpenChange","openIndexesDuplicate","_toConsumableArray","i","indexOf","splice","push","createElement","Provider","value","_extends","propTypes","node","string","array","oneOfType","number","func","oneOf","defaultProps","undefined"],"sources":["../../components/nav/Nav.tsx"],"sourcesContent":["import React, { useContext, useState } from \"react\"\nimport PropTypes from \"prop-types\"\nimport classNames from \"classnames\"\nimport { ConfigContext, getComputedSize } from \"../config-provider\"\nimport Divider from \"./Divider\"\nimport Group from \"./Group\"\nimport Item from \"./Item\"\nimport SubNav from \"./SubNav\"\nimport { NavContext } from \"./Context\"\nimport \"./style\"\n\nconst noop = () => {}\nconst prefix = \"adui-nav\"\n\nexport interface INavProps {\n  [key: string]: any\n  /**\n   * 子节点\n   */\n  children?: React.ReactNode\n  /**\n   * 附加类名\n   */\n  className?: string\n  /**\n   * 默认展开的 SubNav indexes，请确保数组项合法，Nav 不会做过多验证\n   */\n  defaultOpenIndexes?: Array<React.ReactText> | null\n  /**\n   * 默认选中的 Nav.Item index\n   */\n  defaultSelectedIndex?: React.ReactText | null\n  /**\n   * 点击 Nav.Item 时的 handler，参数：index\n   */\n  onChange?: (index: React.ReactText) => void\n  /**\n   * Sub 收起 / 展开 时的 handler，参数：index\n   */\n  onOpenChange?: (indexes: Array<React.ReactText>) => void\n  /**\n   * 外部控制：展开的 SubNav indexes，请确保数组项合法，Nav 不会做过多验证\n   */\n  openIndexes?: Array<React.ReactText> | null\n  /**\n   * 外部控制：选中的 Nav.Item index\n   */\n  selectedIndex?: React.ReactText | null\n  /**\n   * 设置尺寸大小\n   */\n  size?: \"mini\" | \"small\" | \"medium\" | \"large\"\n}\n\n/**\n * 导航栏引导用户确认位置、方向，完成内容之间移动。依据内容选择适当配合的导航形式，为页面和功能提供引导性结构菜单。\n */\nconst Nav: React.FC<INavProps> & {\n  Divider: typeof Divider\n  Group: typeof Group\n  Item: typeof Item\n  SubNav: typeof SubNav\n} = ({\n  children,\n  className,\n  defaultOpenIndexes,\n  defaultSelectedIndex,\n  onChange,\n  onOpenChange,\n  openIndexes: openIndexesProp,\n  selectedIndex: selectedIndexProp,\n  size: sizeProp,\n  ...otherProps\n}: INavProps) => {\n  const [selectedIndex, setSelectedIndex] = useState(\n    selectedIndexProp !== null ? selectedIndexProp : defaultSelectedIndex\n  )\n  const [openIndexes, setOpenIndexes] = useState(\n    openIndexesProp !== null ? openIndexesProp : defaultOpenIndexes\n  )\n\n  // 相当于生命周期 getDerivedStateFromProps\n  if (selectedIndexProp !== null && selectedIndex !== selectedIndexProp) {\n    setSelectedIndex(selectedIndexProp)\n  }\n  if (openIndexesProp !== null && openIndexes !== openIndexesProp) {\n    setOpenIndexes(openIndexesProp)\n  }\n\n  const { size: sizeContext } = useContext(ConfigContext)\n  const size = getComputedSize(sizeProp, sizeContext)\n\n  const classSet = classNames(\n    className,\n    `${prefix}-wrapper`,\n    `${prefix}-${size}`\n  )\n\n  const handleChange = (index: React.ReactText) => {\n    if (selectedIndexProp === null) {\n      setSelectedIndex(index)\n    }\n    if (onChange) {\n      onChange(index)\n    }\n  }\n\n  const handleOpenChange = (index: React.ReactText) => {\n    const openIndexesDuplicate = openIndexes ? [...openIndexes] : []\n    const i = openIndexesDuplicate.indexOf(index)\n    if (i !== -1) {\n      openIndexesDuplicate.splice(i, 1)\n    } else {\n      openIndexesDuplicate.push(index)\n    }\n\n    if (openIndexesProp === null) {\n      setOpenIndexes(openIndexesDuplicate)\n    }\n    if (onOpenChange) {\n      onOpenChange(openIndexesDuplicate)\n    }\n  }\n\n  return (\n    <NavContext.Provider\n      value={{\n        onChange: handleChange,\n        onOpenChange: handleOpenChange,\n        openIndexes,\n        selectedIndex,\n      }}\n    >\n      <nav className={classSet} {...otherProps}>\n        {children}\n      </nav>\n    </NavContext.Provider>\n  )\n}\n\nNav.Divider = Divider\nNav.Group = Group\nNav.Item = Item\nNav.SubNav = SubNav\n\nNav.propTypes = {\n  /**\n   * 子节点\n   */\n  children: PropTypes.node,\n  /**\n   * 附加类名\n   */\n  className: PropTypes.string,\n  /**\n   * 默认展开的 SubNav indexes，请确保数组项合法，Nav 不会做过多验证\n   */\n  defaultOpenIndexes: PropTypes.array,\n  /**\n   * 默认选中的 Nav.Item index\n   */\n  defaultSelectedIndex: PropTypes.oneOfType([\n    PropTypes.string,\n    PropTypes.number,\n  ]),\n  /**\n   * 点击 Nav.Item 时的 handler，参数：index\n   */\n  onChange: PropTypes.func,\n  /**\n   * Sub 收起 / 展开 时的 handler，参数：index\n   */\n  onOpenChange: PropTypes.func,\n  /**\n   * 外部控制：展开的 SubNav indexes，请确保数组项合法，Nav 不会做过多验证\n   */\n  openIndexes: PropTypes.array,\n  /**\n   * 外部控制：选中的 Nav.Item index\n   */\n  selectedIndex: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),\n  /**\n   * 设置尺寸大小\n   */\n  size: PropTypes.oneOf([\"mini\", \"small\", \"medium\", \"large\"]),\n}\n\nNav.defaultProps = {\n  children: null,\n  className: undefined,\n  defaultOpenIndexes: [],\n  defaultSelectedIndex: null,\n  onChange: noop,\n  onOpenChange: noop,\n  openIndexes: null,\n  selectedIndex: null,\n  size: \"small\",\n}\n\nexport default Nav\n"],"mappings":";;;;;;;;;;;;;;AAAA,OAAOA,KAAK,IAAIC,UAAU,EAAEC,QAAQ,QAAQ,OAAO;AACnD,OAAOC,SAAS,MAAM,YAAY;AAClC,OAAOC,UAAU,MAAM,YAAY;AACnC,SAASC,aAAa,EAAEC,eAAe,QAAQ,oBAAoB;AACnE,OAAOC,OAAO,MAAM,WAAW;AAC/B,OAAOC,KAAK,MAAM,SAAS;AAC3B,OAAOC,IAAI,MAAM,QAAQ;AACzB,OAAOC,MAAM,MAAM,UAAU;AAC7B,SAASC,UAAU,QAAQ,WAAW;AACtC,OAAO,SAAS;AAEhB,IAAMC,IAAI,GAAG,SAAPA,IAAIA,CAAA,EAAS,CAAC,CAAC;AACrB,IAAMC,MAAM,GAAG,UAAU;AA6CzB,IAAMC,GAKL,GAAG,SALEA,GAKLA,CAAAC,IAAA,EAWgB;EAAA,IAVfC,QAAQ,GAAAD,IAAA,CAARC,QAAQ;IACRC,SAAS,GAAAF,IAAA,CAATE,SAAS;IACTC,kBAAkB,GAAAH,IAAA,CAAlBG,kBAAkB;IAClBC,oBAAoB,GAAAJ,IAAA,CAApBI,oBAAoB;IACpBC,QAAQ,GAAAL,IAAA,CAARK,QAAQ;IACRC,YAAY,GAAAN,IAAA,CAAZM,YAAY;IACCC,eAAe,GAAAP,IAAA,CAA5BQ,WAAW;IACIC,iBAAiB,GAAAT,IAAA,CAAhCU,aAAa;IACPC,QAAQ,GAAAX,IAAA,CAAdY,IAAI;IACDC,UAAU,GAAAC,wBAAA,CAAAd,IAAA,EAAAe,SAAA;EAEb,IAAAC,SAAA,GAA0C7B,QAAQ,CAChDsB,iBAAiB,KAAK,IAAI,GAAGA,iBAAiB,GAAGL,oBACnD,CAAC;IAAAa,UAAA,GAAAC,cAAA,CAAAF,SAAA;IAFMN,aAAa,GAAAO,UAAA;IAAEE,gBAAgB,GAAAF,UAAA;EAGtC,IAAAG,UAAA,GAAsCjC,QAAQ,CAC5CoB,eAAe,KAAK,IAAI,GAAGA,eAAe,GAAGJ,kBAC/C,CAAC;IAAAkB,UAAA,GAAAH,cAAA,CAAAE,UAAA;IAFMZ,WAAW,GAAAa,UAAA;IAAEC,cAAc,GAAAD,UAAA;EAKlC,IAAIZ,iBAAiB,KAAK,IAAI,IAAIC,aAAa,KAAKD,iBAAiB,EAAE;IACrEU,gBAAgB,CAACV,iBAAiB,CAAC;EACrC;EACA,IAAIF,eAAe,KAAK,IAAI,IAAIC,WAAW,KAAKD,eAAe,EAAE;IAC/De,cAAc,CAACf,eAAe,CAAC;EACjC;EAEA,IAAAgB,WAAA,GAA8BrC,UAAU,CAACI,aAAa,CAAC;IAAzCkC,WAAW,GAAAD,WAAA,CAAjBX,IAAI;EACZ,IAAMA,IAAI,GAAGrB,eAAe,CAACoB,QAAQ,EAAEa,WAAW,CAAC;EAEnD,IAAMC,QAAQ,GAAGpC,UAAU,CACzBa,SAAS,KAAAwB,MAAA,CACN5B,MAAM,kBAAA4B,MAAA,CACN5B,MAAM,OAAA4B,MAAA,CAAId,IAAI,CACnB,CAAC;EAED,IAAMe,YAAY,GAAG,SAAfA,YAAYA,CAAIC,KAAsB,EAAK;IAC/C,IAAInB,iBAAiB,KAAK,IAAI,EAAE;MAC9BU,gBAAgB,CAACS,KAAK,CAAC;IACzB;IACA,IAAIvB,QAAQ,EAAE;MACZA,QAAQ,CAACuB,KAAK,CAAC;IACjB;EACF,CAAC;EAED,IAAMC,gBAAgB,GAAG,SAAnBA,gBAAgBA,CAAID,KAAsB,EAAK;IACnD,IAAME,oBAAoB,GAAGtB,WAAW,GAAAuB,kBAAA,CAAOvB,WAAW,IAAI,EAAE;IAChE,IAAMwB,CAAC,GAAGF,oBAAoB,CAACG,OAAO,CAACL,KAAK,CAAC;IAC7C,IAAII,CAAC,KAAK,CAAC,CAAC,EAAE;MACZF,oBAAoB,CAACI,MAAM,CAACF,CAAC,EAAE,CAAC,CAAC;IACnC,CAAC,MAAM;MACLF,oBAAoB,CAACK,IAAI,CAACP,KAAK,CAAC;IAClC;IAEA,IAAIrB,eAAe,KAAK,IAAI,EAAE;MAC5Be,cAAc,CAACQ,oBAAoB,CAAC;IACtC;IACA,IAAIxB,YAAY,EAAE;MAChBA,YAAY,CAACwB,oBAAoB,CAAC;IACpC;EACF,CAAC;EAED,OACE7C,KAAA,CAAAmD,aAAA,CAACxC,UAAU,CAACyC,QAAQ;IAClBC,KAAK,EAAE;MACLjC,QAAQ,EAAEsB,YAAY;MACtBrB,YAAY,EAAEuB,gBAAgB;MAC9BrB,WAAW,EAAXA,WAAW;MACXE,aAAa,EAAbA;IACF;EAAE,GAEFzB,KAAA,CAAAmD,aAAA,QAAAG,QAAA;IAAKrC,SAAS,EAAEuB;EAAS,GAAKZ,UAAU,GACrCZ,QACE,CACc,CAAC;AAE1B,CAAC;AAEDF,GAAG,CAACP,OAAO,GAAGA,OAAO;AACrBO,GAAG,CAACN,KAAK,GAAGA,KAAK;AACjBM,GAAG,CAACL,IAAI,GAAGA,IAAI;AACfK,GAAG,CAACJ,MAAM,GAAGA,MAAM;AAEnBI,GAAG,CAACyC,SAAS,GAAG;EAIdvC,QAAQ,EAAEb,SAAS,CAACqD,IAAI;EAIxBvC,SAAS,EAAEd,SAAS,CAACsD,MAAM;EAI3BvC,kBAAkB,EAAEf,SAAS,CAACuD,KAAK;EAInCvC,oBAAoB,EAAEhB,SAAS,CAACwD,SAAS,CAAC,CACxCxD,SAAS,CAACsD,MAAM,EAChBtD,SAAS,CAACyD,MAAM,CACjB,CAAC;EAIFxC,QAAQ,EAAEjB,SAAS,CAAC0D,IAAI;EAIxBxC,YAAY,EAAElB,SAAS,CAAC0D,IAAI;EAI5BtC,WAAW,EAAEpB,SAAS,CAACuD,KAAK;EAI5BjC,aAAa,EAAEtB,SAAS,CAACwD,SAAS,CAAC,CAACxD,SAAS,CAACsD,MAAM,EAAEtD,SAAS,CAACyD,MAAM,CAAC,CAAC;EAIxEjC,IAAI,EAAExB,SAAS,CAAC2D,KAAK,CAAC,CAAC,MAAM,EAAE,OAAO,EAAE,QAAQ,EAAE,OAAO,CAAC;AAC5D,CAAC;AAEDhD,GAAG,CAACiD,YAAY,GAAG;EACjB/C,QAAQ,EAAE,IAAI;EACdC,SAAS,EAAE+C,SAAS;EACpB9C,kBAAkB,EAAE,EAAE;EACtBC,oBAAoB,EAAE,IAAI;EAC1BC,QAAQ,EAAER,IAAI;EACdS,YAAY,EAAET,IAAI;EAClBW,WAAW,EAAE,IAAI;EACjBE,aAAa,EAAE,IAAI;EACnBE,IAAI,EAAE;AACR,CAAC;AAED,eAAeb,GAAG","ignoreList":[]}