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>
163 lines (129 loc) • 19.6 kB
JavaScript
;
function _typeof(obj) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && "function" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }, _typeof(obj); }
Object.defineProperty(exports, "__esModule", {
value: true
});
exports["default"] = void 0;
var _react = _interopRequireWildcard(require("react"));
var _propTypes = _interopRequireDefault(require("prop-types"));
var _classnames = _interopRequireDefault(require("classnames"));
var _icon = _interopRequireDefault(require("../icon"));
var _popover = _interopRequireDefault(require("../popover"));
var _Context = require("./Context");
require("./style");
var _excluded = ["children", "className", "label", "labelAlign", "labelHelper", "labelHelperIcon", "labelHelperProps", "labelSize", "labelStyle", "style"];
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== "object" && typeof obj !== "function") { return { "default": obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj["default"] = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
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; }
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 = (0, _react.useContext)(_Context.FormContext),
labelAlignContext = _useContext.labelAlign,
itemStyle = _useContext.itemStyle,
labelStyleContext = _useContext.labelStyle,
labelSizeContext = _useContext.labelSize;
var classSet = (0, _classnames["default"])(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 = (0, _react.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["default"].createElement("div", _extends({
className: classSet,
style: _objectSpread(_objectSpread({}, itemStyle), style)
}, otherProps), !!label && _react["default"].createElement("div", {
className: "".concat(prefix, "-label"),
style: _objectSpread(_objectSpread(_objectSpread({
width: "".concat(labelSizeFinal, "em")
}, alignStyle), labelStyleContext), labelStyle)
}, labelFinal, !!labelHelper && _react["default"].createElement(_popover["default"], _extends({
popup: labelHelper,
alignEdge: false,
placement: "bottom"
}, labelHelperProps), _react["default"].createElement(_icon["default"], {
icon: labelHelperIcon || "help-circle",
interactive: true,
color: "var(--gray-600)",
style: {
marginLeft: "4px"
}
}))), _react["default"].createElement("div", {
className: "".concat(prefix, "-control")
}, children));
};
Item.propTypes = {
children: _propTypes["default"].node,
className: _propTypes["default"].string,
label: _propTypes["default"].node,
labelAlign: _propTypes["default"].oneOf([null, "left", "center", "right"]),
labelHelper: _propTypes["default"].node,
labelHelperIcon: _propTypes["default"].any,
labelHelperProps: _propTypes["default"].object,
labelSize: _propTypes["default"].number,
labelStyle: _propTypes["default"].object,
style: _propTypes["default"].object
};
Item.defaultProps = {
children: null,
className: undefined,
label: null,
labelAlign: null,
labelHelper: null,
labelHelperIcon: "help-circle",
labelHelperProps: {},
labelSize: null,
labelStyle: {},
style: {}
};
var _default = Item;
exports["default"] = _default;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["prefix","Item","children","className","label","labelAlign","labelHelper","labelHelperIcon","labelHelperProps","labelSize","labelStyle","style","otherProps","useContext","FormContext","labelAlignContext","itemStyle","labelStyleContext","labelSizeContext","classSet","classNames","align","alignStyle","justifyContent","labelSizeFinal","labelFinal","useMemo","getFormatStrLeng","str","len","length","realLength","charCode","i","charCodeAt","Math","ceil","slice","width","marginLeft","propTypes","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":";;;;;;;;;AAAA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;;;;;;;;;;;;;;;;;;;;;AAEA,IAAMA,MAAM,GAAG,oBAAf;;AAiDA,IAAMC,IAA0B,GAAG,SAA7BA,IAA6B,OAYjB;EAAA,IAXhBC,QAWgB,QAXhBA,QAWgB;EAAA,IAVhBC,SAUgB,QAVhBA,SAUgB;EAAA,IAThBC,KASgB,QAThBA,KASgB;EAAA,IARhBC,UAQgB,QARhBA,UAQgB;EAAA,IAPhBC,WAOgB,QAPhBA,WAOgB;EAAA,IANhBC,eAMgB,QANhBA,eAMgB;EAAA,IALhBC,gBAKgB,QALhBA,gBAKgB;EAAA,IAJhBC,SAIgB,QAJhBA,SAIgB;EAAA,IAHhBC,UAGgB,QAHhBA,UAGgB;EAAA,IAFhBC,KAEgB,QAFhBA,KAEgB;EAAA,IADbC,UACa;;EAChB,kBAKI,IAAAC,iBAAA,EAAWC,oBAAX,CALJ;EAAA,IACcC,iBADd,eACEV,UADF;EAAA,IAEEW,SAFF,eAEEA,SAFF;EAAA,IAGcC,iBAHd,eAGEP,UAHF;EAAA,IAIaQ,gBAJb,eAIET,SAJF;;EAOA,IAAMU,QAAQ,GAAG,IAAAC,sBAAA,EAAWjB,SAAX,YAAyBH,MAAzB,WAAjB;EAEA,IAAIqB,KAAgC,GAAGhB,UAAU,IAAIU,iBAArD;;EACA,QAAQM,KAAR;IACE,KAAK,MAAL;MACEA,KAAK,GAAG,YAAR;MACA;;IACF,KAAK,OAAL;MACEA,KAAK,GAAG,UAAR;MACA;;IACF,KAAK,QAAL;MACEA,KAAK,GAAG,QAAR;MACA;;IACF;EAVF;;EAaA,IAAMC,UAAU,GAAGD,KAAK,GAAG;IAAEE,cAAc,EAAEF;EAAlB,CAAH,GAA+B,EAAvD;EACA,IAAMG,cAAc,GAAGf,SAAS,IAAIS,gBAApC;EAKA,IAAMO,UAAU,GAAG,IAAAC,cAAA,EAAQ,YAAuB;IAChD,IAAMC,gBAAgB,GAAG,SAAnBA,gBAAmB,CAACC,GAAD,EAAiB;MACxC,IAAMC,GAAG,GAAGD,GAAG,CAACE,MAAhB;MACA,IAAIC,UAAU,GAAG,CAAjB;MACA,IAAIC,QAAQ,GAAG,CAAC,CAAhB;;MACA,KAAK,IAAIC,CAAC,GAAG,CAAb,EAAgBA,CAAC,GAAGJ,GAApB,EAAyBI,CAAC,IAAI,CAA9B,EAAiC;QAC/BD,QAAQ,GAAGJ,GAAG,CAACM,UAAJ,CAAeD,CAAf,CAAX;;QACA,IAAID,QAAQ,IAAI,CAAZ,IAAiBA,QAAQ,IAAI,GAAjC,EAAsC;UACpCD,UAAU,IAAI,GAAd;QACD,CAFD,MAEO;UACLA,UAAU,IAAI,CAAd;QACD;MACF;;MACD,OAAOI,IAAI,CAACC,IAAL,CAAUL,UAAV,CAAP;IACD,CAbD;;IAeA,IACE,OAAO3B,KAAP,KAAiB,QAAjB,IACAoB,cADA,IAEAG,gBAAgB,CAACvB,KAAD,CAAhB,GAA0BoB,cAA1B,KAA6C,CAH/C,EAIE;MACA,iBAAUpB,KAAK,CAACiC,KAAN,CAAY,CAAZ,EAAe,CAAf,CAAV,eAAgCjC,KAAK,CAACiC,KAAN,CAAY,CAAZ,CAAhC;IACD;;IACD,OAAOjC,KAAP;EACD,CAxBkB,EAwBhB,CAACA,KAAD,CAxBgB,CAAnB;EA0BA,OACE;IACE,SAAS,EAAEe,QADb;IAEE,KAAK,kCACAH,SADA,GAEAL,KAFA;EAFP,GAMMC,UANN,GAQG,CAAC,CAACR,KAAF,IACC;IACE,SAAS,YAAKJ,MAAL,WADX;IAEE,KAAK;MACHsC,KAAK,YAAKd,cAAL;IADF,GAEAF,UAFA,GAGAL,iBAHA,GAIAP,UAJA;EAFP,GASGe,UATH,EAUG,CAAC,CAACnB,WAAF,IACC,gCAAC,mBAAD;IACE,KAAK,EAAEA,WADT;IAEE,SAAS,EAAE,KAFb;IAGE,SAAS,EAAC;EAHZ,GAIME,gBAJN,GAME,gCAAC,gBAAD;IACE,IAAI,EAAED,eAAe,IAAI,aAD3B;IAEE,WAAW,MAFb;IAGE,KAAK,EAAC,iBAHR;IAIE,KAAK,EAAE;MAAEgC,UAAU,EAAE;IAAd;EAJT,EANF,CAXJ,CATJ,EAoCE;IAAK,SAAS,YAAKvC,MAAL;EAAd,GAAsCE,QAAtC,CApCF,CADF;AAwCD,CA5GD;;AA8GAD,IAAI,CAACuC,SAAL,GAAiB;EAIftC,QAAQ,EAAEuC,qBAAA,CAAUC,IAJL;EAQfvC,SAAS,EAAEsC,qBAAA,CAAUE,MARN;EAYfvC,KAAK,EAAEqC,qBAAA,CAAUC,IAZF;EAgBfrC,UAAU,EAAEoC,qBAAA,CAAUG,KAAV,CAAgB,CAAC,IAAD,EAAO,MAAP,EAAe,QAAf,EAAyB,OAAzB,CAAhB,CAhBG;EAoBftC,WAAW,EAAEmC,qBAAA,CAAUC,IApBR;EAwBfnC,eAAe,EAAEkC,qBAAA,CAAUI,GAxBZ;EA4BfrC,gBAAgB,EAAEiC,qBAAA,CAAUK,MA5Bb;EAgCfrC,SAAS,EAAEgC,qBAAA,CAAUM,MAhCN;EAoCfrC,UAAU,EAAE+B,qBAAA,CAAUK,MApCP;EAwCfnC,KAAK,EAAE8B,qBAAA,CAAUK;AAxCF,CAAjB;AA2CA7C,IAAI,CAAC+C,YAAL,GAAoB;EAClB9C,QAAQ,EAAE,IADQ;EAElBC,SAAS,EAAE8C,SAFO;EAGlB7C,KAAK,EAAE,IAHW;EAIlBC,UAAU,EAAE,IAJM;EAKlBC,WAAW,EAAE,IALK;EAMlBC,eAAe,EAAE,aANC;EAOlBC,gBAAgB,EAAE,EAPA;EAQlBC,SAAS,EAAE,IARO;EASlBC,UAAU,EAAE,EATM;EAUlBC,KAAK,EAAE;AAVW,CAApB;eAaeV,I"}