UNPKG

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>

119 lines (103 loc) 15.8 kB
var _excluded = ["children", "className", "label", "labelAlign", "labelHelper", "labelHelperIcon", "labelHelperProps", "labelSize", "labelClassName", "labelStyle", "style"]; function _extends() { _extends = Object.assign ? Object.assign.bind() : 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 ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); 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 = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : 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; } import React, { useContext } from "react"; import PropTypes from "prop-types"; import classNames from "classnames"; import Icon from "../icon"; import Popover from "../popover"; import { FormContext } from "./Context"; import "./style"; var prefix = "adui-form"; var Item = function Item(_ref) { var children = _ref.children, className = _ref.className, label = _ref.label, labelAlign = _ref.labelAlign, labelHelper = _ref.labelHelper, labelHelperIcon = _ref.labelHelperIcon, labelHelperProps = _ref.labelHelperProps, labelSize = _ref.labelSize, labelClassName = _ref.labelClassName, labelStyle = _ref.labelStyle, style = _ref.style, otherProps = _objectWithoutProperties(_ref, _excluded); var _useContext = useContext(FormContext), itemClassNameContext = _useContext.itemClassName, itemStyle = _useContext.itemStyle, labelAlignContext = _useContext.labelAlign, labelStyleContext = _useContext.labelStyle, labelSizeContext = _useContext.labelSize, labelClassNameContext = _useContext.labelClassName; var classSet = classNames(className || itemClassNameContext, "".concat(prefix, "-item")); var align = labelAlign || labelAlignContext; switch (align) { case "left": align = "flex-start"; break; case "right": align = "flex-end"; break; case "center": align = "center"; break; default: } var alignStyle = align ? { justifyContent: align } : {}; return React.createElement("div", _extends({ className: classSet, style: _objectSpread(_objectSpread({}, itemStyle), style) }, otherProps), !!label && React.createElement("div", { className: classNames("".concat(prefix, "-label"), labelClassName || labelClassNameContext), style: _objectSpread(_objectSpread(_objectSpread({ width: "".concat(labelSize || labelSizeContext, "em") }, alignStyle), labelStyleContext), labelStyle) }, label, !!labelHelper && React.createElement(Popover, _extends({ popup: labelHelper, alignEdge: false, placement: "bottom" }, labelHelperProps), React.createElement(Icon, { icon: labelHelperIcon || "help-circle", interactive: true, color: "var(--gray-600)", style: { marginLeft: "4px" } }))), React.createElement("div", { className: "".concat(prefix, "-control") }, children)); }; Item.propTypes = { children: PropTypes.node, className: PropTypes.string, label: PropTypes.node, labelAlign: PropTypes.oneOf([null, "left", "center", "right"]), labelClassName: PropTypes.string, labelHelper: PropTypes.node, labelHelperIcon: PropTypes.any, labelHelperProps: PropTypes.object, labelSize: PropTypes.number, labelStyle: PropTypes.object, style: PropTypes.object }; Item.defaultProps = { children: null, className: undefined, label: null, labelAlign: null, labelHelper: null, labelHelperIcon: "help-circle", labelHelperProps: {}, labelSize: null, labelClassName: undefined, labelStyle: {}, style: {} }; export default Item; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["React","useContext","PropTypes","classNames","Icon","Popover","FormContext","prefix","Item","children","className","label","labelAlign","labelHelper","labelHelperIcon","labelHelperProps","labelSize","labelClassName","labelStyle","style","otherProps","itemClassNameContext","itemClassName","itemStyle","labelAlignContext","labelStyleContext","labelSizeContext","labelClassNameContext","classSet","align","alignStyle","justifyContent","width","marginLeft","propTypes","node","string","oneOf","any","object","number","defaultProps","undefined"],"sources":["../../components/form/Item.tsx"],"sourcesContent":["import React, { useContext } from \"react\"\nimport PropTypes from \"prop-types\"\nimport classNames from \"classnames\"\nimport Icon, { IconNames } from \"../icon\"\nimport Popover, { IPopoverProps } from \"../popover\"\nimport { FormContext } from \"./Context\"\nimport \"./style\"\n\nconst prefix = \"adui-form\"\n\nexport interface IItemProps {\n  [key: string]: any\n  /**\n   * 子节点\n   */\n  children?: React.ReactNode\n  /**\n   * 附加类名\n   */\n  className?: string\n  /**\n   * label\n   */\n  label?: React.ReactNode\n  /**\n   * label 字符对齐方式\n   */\n  labelAlign?: \"left\" | \"center\" | \"right\" | null\n  /**\n   * label 解释内容\n   */\n  labelHelper?: React.ReactNode\n  /**\n   * label 解释内容的 Icon\n   */\n  labelHelperIcon?: IconNames\n  /**\n   * label 解释内容所使用的 Popover 的 Props\n   */\n  labelHelperProps?: IPopoverProps\n  /**\n   * label 字符数，Form 会以 em 单位设置 label 宽度\n   */\n  labelSize?: number | null\n  /**\n   * label className\n   */\n  labelClassName?: string\n  /**\n   * label style\n   */\n  labelStyle?: React.CSSProperties\n  /**\n   * 附加 style\n   */\n  style?: React.CSSProperties\n}\n\n/**\n * 表单 item\n */\nconst Item: React.FC<IItemProps> = ({\n  children,\n  className,\n  label,\n  labelAlign,\n  labelHelper,\n  labelHelperIcon,\n  labelHelperProps,\n  labelSize,\n  labelClassName,\n  labelStyle,\n  style,\n  ...otherProps\n}: IItemProps) => {\n  const {\n    itemClassName: itemClassNameContext,\n    itemStyle,\n    labelAlign: labelAlignContext,\n    labelStyle: labelStyleContext,\n    labelSize: labelSizeContext,\n    labelClassName: labelClassNameContext,\n  } = useContext(FormContext)\n\n  const classSet = classNames(\n    className || itemClassNameContext,\n    `${prefix}-item`\n  )\n\n  let align: string | undefined | null = labelAlign || labelAlignContext\n  switch (align) {\n    case \"left\":\n      align = \"flex-start\"\n      break\n    case \"right\":\n      align = \"flex-end\"\n      break\n    case \"center\":\n      align = \"center\"\n      break\n    default:\n  }\n\n  const alignStyle = align ? { justifyContent: align } : {}\n\n  return (\n    <div\n      className={classSet}\n      style={{\n        ...itemStyle,\n        ...style,\n      }}\n      {...otherProps}\n    >\n      {!!label && (\n        <div\n          className={classNames(\n            `${prefix}-label`,\n            labelClassName || labelClassNameContext\n          )}\n          style={{\n            width: `${labelSize || labelSizeContext}em`,\n            ...alignStyle,\n            ...labelStyleContext,\n            ...labelStyle,\n          }}\n        >\n          {label}\n          {!!labelHelper && (\n            <Popover\n              popup={labelHelper}\n              alignEdge={false}\n              placement=\"bottom\"\n              {...labelHelperProps}\n            >\n              <Icon\n                icon={labelHelperIcon || \"help-circle\"}\n                interactive\n                color=\"var(--gray-600)\"\n                style={{ marginLeft: \"4px\" }}\n              />\n            </Popover>\n          )}\n        </div>\n      )}\n      <div className={`${prefix}-control`}>{children}</div>\n    </div>\n  )\n}\n\nItem.propTypes = {\n  /**\n   * 子节点\n   */\n  children: PropTypes.node,\n  /**\n   * 附加类名\n   */\n  className: PropTypes.string,\n  /**\n   * label\n   */\n  label: PropTypes.node,\n  /**\n   * label 字符对齐方式\n   */\n  labelAlign: PropTypes.oneOf([null, \"left\", \"center\", \"right\"]),\n  /**\n   * label className\n   */\n  labelClassName: PropTypes.string,\n  /**\n   * label 解释内容\n   */\n  labelHelper: PropTypes.node,\n  /**\n   * label 解释内容的 Icon\n   */\n  labelHelperIcon: PropTypes.any,\n  /**\n   * label 解释内容所使用的 Popover 的 Props\n   */\n  labelHelperProps: PropTypes.object,\n  /**\n   * label 字符数，Form 会以 em 单位设置 label 宽度\n   */\n  labelSize: PropTypes.number,\n  /**\n   * label style\n   */\n  labelStyle: PropTypes.object,\n  /**\n   * 附加 style\n   */\n  style: PropTypes.object,\n}\n\nItem.defaultProps = {\n  children: null,\n  className: undefined,\n  label: null,\n  labelAlign: null,\n  labelHelper: null,\n  labelHelperIcon: \"help-circle\",\n  labelHelperProps: {},\n  labelSize: null,\n  labelClassName: undefined,\n  labelStyle: {},\n  style: {},\n}\n\nexport default Item\n"],"mappings":"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"}