UNPKG

choerodon-ui

Version:

An enterprise-class UI design language and React-based implementation

184 lines (149 loc) 5.48 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); Object.defineProperty(exports, "__esModule", { value: true }); exports["default"] = void 0; var _objectSpread2 = _interopRequireDefault(require("@babel/runtime/helpers/objectSpread2")); var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck")); var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass")); var _get2 = _interopRequireDefault(require("@babel/runtime/helpers/get")); var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits")); var _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime/helpers/possibleConstructorReturn")); var _getPrototypeOf2 = _interopRequireDefault(require("@babel/runtime/helpers/getPrototypeOf")); var _tslib = require("tslib"); var _react = _interopRequireDefault(require("react")); var _propTypes = _interopRequireDefault(require("prop-types")); var _mobxReact = require("mobx-react"); var _mobx = require("mobx"); var _TextField2 = require("../text-field/TextField"); var _autobind = _interopRequireDefault(require("../_util/autobind")); var _icon = _interopRequireDefault(require("../icon")); function _createSuper(Derived) { function isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Date.prototype.toString.call(Reflect.construct(Date, [], function () {})); return true; } catch (e) { return false; } } return function () { var Super = (0, _getPrototypeOf2["default"])(Derived), result; if (isNativeReflectConstruct()) { var NewTarget = (0, _getPrototypeOf2["default"])(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return (0, _possibleConstructorReturn2["default"])(this, result); }; } // let selectionStart; // let selectionEnd; var Password = /*#__PURE__*/ function (_TextField) { (0, _inherits2["default"])(Password, _TextField); var _super = _createSuper(Password); function Password() { var _this; (0, _classCallCheck2["default"])(this, Password); _this = _super.apply(this, arguments); _this.type = 'password'; return _this; } (0, _createClass2["default"])(Password, [{ key: "getOmitPropsKeys", value: function getOmitPropsKeys() { return (0, _get2["default"])((0, _getPrototypeOf2["default"])(Password.prototype), "getOmitPropsKeys", this).call(this).concat(['reveal']); } }, { key: "getOtherPrevNode", value: function getOtherPrevNode() { return _react["default"].createElement("input", { tabIndex: -1, className: "".concat(this.prefixCls, "-fix-autofill") }); } }, { key: "getInnerSpanButton", value: function getInnerSpanButton() { var reveal = this.props.reveal; if (reveal && !this.disabled) { return this.wrapperInnerSpanButton(_react["default"].createElement(_icon["default"], { type: this.reveal ? 'visibility' : 'visibility_off', onClick: this.handleToggleReveal }), { style: { right: this.lengthInfoWidth } }); } } }, { key: "handleToggleReveal", value: function handleToggleReveal(e) { e.preventDefault(); if (!this.isFocused) { this.focus(); } var target = this.element; if (target) { if (target.type === 'password') { this.doReveal(target); } else { this.resetReveal(target); } } } }, { key: "doReveal", value: function doReveal(target) { this.selectionEnd = target.selectionEnd; this.selectionStart = target.selectionStart; target.type = 'text'; this.type = target.type; this.reveal = true; } }, { key: "resetReveal", value: function resetReveal(target) { var selectionStart = this.selectionStart, selectionEnd = this.selectionEnd; target.type = 'password'; this.type = target.type; if (typeof selectionStart !== 'undefined' && typeof selectionEnd !== 'undefined') { target.setSelectionRange(selectionStart, selectionEnd); this.selectionStart = undefined; this.selectionEnd = undefined; } this.reveal = false; } }]); return Password; }(_TextField2.TextField); Password.displayName = 'Password'; Password.propTypes = (0, _objectSpread2["default"])({ /** * 是否可揭示 * @default true */ reveal: _propTypes["default"].bool }, _TextField2.TextField.propTypes); Password.defaultProps = (0, _objectSpread2["default"])({}, _TextField2.TextField.defaultProps, { suffixCls: 'password', reveal: true }); (0, _tslib.__decorate)([_mobx.observable], Password.prototype, "reveal", void 0); (0, _tslib.__decorate)([_autobind["default"]], Password.prototype, "handleToggleReveal", null); (0, _tslib.__decorate)([_mobx.action], Password.prototype, "doReveal", null); (0, _tslib.__decorate)([_mobx.action], Password.prototype, "resetReveal", null); Password = (0, _tslib.__decorate)([_mobxReact.observer], Password); var _default = Password; exports["default"] = _default; //# sourceMappingURL=Password.js.map