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>
122 lines • 18.6 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", "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, useMemo } 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-channels-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,
labelStyle = _ref.labelStyle,
style = _ref.style,
otherProps = _objectWithoutProperties(_ref, _excluded);
var _useContext = useContext(FormContext),
labelAlignContext = _useContext.labelAlign,
itemStyle = _useContext.itemStyle,
labelStyleContext = _useContext.labelStyle,
labelSizeContext = _useContext.labelSize;
var classSet = classNames(className, "".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
} : {};
var labelSizeFinal = labelSize || labelSizeContext;
var labelFinal = useMemo(function () {
var getFormatStrLeng = function getFormatStrLeng(str) {
var len = str.length;
var realLength = 0;
var charCode = -1;
for (var i = 0; i < len; i += 1) {
charCode = str.charCodeAt(i);
if (charCode >= 0 && charCode <= 128) {
realLength += 0.5;
} else {
realLength += 1;
}
}
return Math.ceil(realLength);
};
if (typeof label === "string" && labelSizeFinal && getFormatStrLeng(label) - labelSizeFinal === 1) {
return "".concat(label.slice(0, 4), "\n").concat(label.slice(4));
}
return label;
}, [label]);
return React.createElement("div", _extends({
className: classSet,
style: _objectSpread(_objectSpread({}, itemStyle), style)
}, otherProps), !!label && React.createElement("div", {
className: "".concat(prefix, "-label"),
style: _objectSpread(_objectSpread(_objectSpread({
width: "".concat(labelSizeFinal, "em")
}, alignStyle), labelStyleContext), labelStyle)
}, labelFinal, !!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"]),
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,
labelStyle: {},
style: {}
};
export default Item;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["React","useContext","useMemo","PropTypes","classNames","Icon","Popover","FormContext","prefix","Item","_ref","children","className","label","labelAlign","labelHelper","labelHelperIcon","labelHelperProps","labelSize","labelStyle","style","otherProps","_objectWithoutProperties","_excluded","_useContext","labelAlignContext","itemStyle","labelStyleContext","labelSizeContext","classSet","concat","align","alignStyle","justifyContent","labelSizeFinal","labelFinal","getFormatStrLeng","str","len","length","realLength","charCode","i","charCodeAt","Math","ceil","slice","createElement","_extends","_objectSpread","width","popup","alignEdge","placement","icon","interactive","color","marginLeft","propTypes","node","string","oneOf","any","object","number","defaultProps","undefined"],"sources":["../../components/channels-form/Item.tsx"],"sourcesContent":["import React, { useContext, useMemo } 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-channels-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 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  labelStyle,\n  style,\n  ...otherProps\n}: IItemProps) => {\n  const {\n    labelAlign: labelAlignContext,\n    itemStyle,\n    labelStyle: labelStyleContext,\n    labelSize: labelSizeContext,\n  } = useContext(FormContext)\n\n  const classSet = classNames(className, `${prefix}-item`)\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  const labelSizeFinal = labelSize || labelSizeContext\n\n  /**\n   * 如果 label 为 text，则防止一个字换行的问题\n   */\n  const labelFinal = useMemo((): React.ReactNode => {\n    const getFormatStrLeng = (str: string) => {\n      const len = str.length\n      let realLength = 0\n      let charCode = -1\n      for (let i = 0; i < len; i += 1) {\n        charCode = str.charCodeAt(i)\n        if (charCode >= 0 && charCode <= 128) {\n          realLength += 0.5\n        } else {\n          realLength += 1\n        }\n      }\n      return Math.ceil(realLength)\n    }\n\n    if (\n      typeof label === \"string\" &&\n      labelSizeFinal &&\n      getFormatStrLeng(label) - labelSizeFinal === 1\n    ) {\n      return `${label.slice(0, 4)}\\n${label.slice(4)}`\n    }\n    return label\n  }, [label])\n\n  return (\n    <div\n      className={classSet}\n      style={{\n        ...itemStyle,\n        ...style,\n      }}\n      {...otherProps}\n    >\n      {!!label && (\n        <div\n          className={`${prefix}-label`}\n          style={{\n            width: `${labelSizeFinal}em`,\n            ...alignStyle,\n            ...labelStyleContext,\n            ...labelStyle,\n          }}\n        >\n          {labelFinal}\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 解释内容\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  labelStyle: {},\n  style: {},\n}\n\nexport default Item\n"],"mappings":"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","ignoreList":[]}