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>
106 lines • 16.7 kB
JavaScript
function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); }
var _excluded = ["children", "className", "label", "labelAlign", "labelHelper", "labelHelperIcon", "labelHelperProps", "labelSize", "labelClassName", "labelStyle", "style"];
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 ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
function _defineProperty(e, r, t) { return (r = _toPropertyKey(r)) in e ? Object.defineProperty(e, r, { value: t, enumerable: !0, configurable: !0, writable: !0 }) : e[r] = t, e; }
function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; }
function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); }
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 } 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","_ref","children","className","label","labelAlign","labelHelper","labelHelperIcon","labelHelperProps","labelSize","labelClassName","labelStyle","style","otherProps","_objectWithoutProperties","_excluded","_useContext","itemClassNameContext","itemClassName","itemStyle","labelAlignContext","labelStyleContext","labelSizeContext","labelClassNameContext","classSet","concat","align","alignStyle","justifyContent","createElement","_extends","_objectSpread","width","popup","alignEdge","placement","icon","interactive","color","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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","ignoreList":[]}