123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121 |
- "use strict";
- var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
- Object.defineProperty(exports, "__esModule", {
- value: true
- });
- exports.default = void 0;
- var _vue = require("vue");
- var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties"));
- var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
- var _objectSpread2 = _interopRequireDefault(require("@babel/runtime/helpers/objectSpread2"));
- var _classNames2 = _interopRequireDefault(require("../_util/classNames"));
- var _propsUtil = require("../_util/props-util");
- var _vnode = require("../_util/vnode");
- var _Input = _interopRequireDefault(require("./Input"));
- var _EyeOutlined = _interopRequireDefault(require("@ant-design/icons-vue/lib/icons/EyeOutlined"));
- var _EyeInvisibleOutlined = _interopRequireDefault(require("@ant-design/icons-vue/lib/icons/EyeInvisibleOutlined"));
- var _inputProps = _interopRequireDefault(require("./inputProps"));
- var _useConfigInject2 = _interopRequireDefault(require("../_util/hooks/useConfigInject"));
- var _omit = _interopRequireDefault(require("../_util/omit"));
- var _excluded = ["size", "visibilityToggle"];
- var ActionMap = {
- click: 'onClick',
- hover: 'onMouseover'
- };
- var defaultIconRender = function defaultIconRender(visible) {
- return visible ? (0, _vue.createVNode)(_EyeOutlined.default, null, null) : (0, _vue.createVNode)(_EyeInvisibleOutlined.default, null, null);
- };
- var _default = (0, _vue.defineComponent)({
- compatConfig: {
- MODE: 3
- },
- name: 'AInputPassword',
- inheritAttrs: false,
- props: (0, _objectSpread2.default)((0, _objectSpread2.default)({}, (0, _inputProps.default)()), {}, {
- prefixCls: String,
- inputPrefixCls: String,
- action: {
- type: String,
- default: 'click'
- },
- visibilityToggle: {
- type: Boolean,
- default: true
- },
- iconRender: Function
- }),
- setup: function setup(props, _ref) {
- var slots = _ref.slots,
- attrs = _ref.attrs,
- expose = _ref.expose;
- var visible = (0, _vue.ref)(false);
- var onVisibleChange = function onVisibleChange() {
- var disabled = props.disabled;
- if (disabled) {
- return;
- }
- visible.value = !visible.value;
- };
- var inputRef = (0, _vue.ref)();
- var focus = function focus() {
- var _inputRef$value;
- (_inputRef$value = inputRef.value) === null || _inputRef$value === void 0 ? void 0 : _inputRef$value.focus();
- };
- var blur = function blur() {
- var _inputRef$value2;
- (_inputRef$value2 = inputRef.value) === null || _inputRef$value2 === void 0 ? void 0 : _inputRef$value2.blur();
- };
- expose({
- focus: focus,
- blur: blur
- });
- var getIcon = function getIcon(prefixCls) {
- var _iconProps;
- var action = props.action,
- _props$iconRender = props.iconRender,
- iconRender = _props$iconRender === void 0 ? slots.iconRender || defaultIconRender : _props$iconRender;
- var iconTrigger = ActionMap[action] || '';
- var icon = iconRender(visible.value);
- var iconProps = (_iconProps = {}, (0, _defineProperty2.default)(_iconProps, iconTrigger, onVisibleChange), (0, _defineProperty2.default)(_iconProps, "class", "".concat(prefixCls, "-icon")), (0, _defineProperty2.default)(_iconProps, "key", 'passwordIcon'), (0, _defineProperty2.default)(_iconProps, "onMousedown", function onMousedown(e) {
- // Prevent focused state lost
- // https://github.com/ant-design/ant-design/issues/15173
- e.preventDefault();
- }), (0, _defineProperty2.default)(_iconProps, "onMouseup", function onMouseup(e) {
- // Prevent caret position change
- // https://github.com/ant-design/ant-design/issues/23524
- e.preventDefault();
- }), _iconProps);
- return (0, _vnode.cloneElement)((0, _propsUtil.isValidElement)(icon) ? icon : (0, _vue.createVNode)("span", null, [icon]), iconProps);
- };
- var _useConfigInject = (0, _useConfigInject2.default)('input-password', props),
- prefixCls = _useConfigInject.prefixCls,
- getPrefixCls = _useConfigInject.getPrefixCls;
- var inputPrefixCls = (0, _vue.computed)(function () {
- return getPrefixCls('input', props.inputPrefixCls);
- });
- var renderPassword = function renderPassword() {
- var size = props.size,
- visibilityToggle = props.visibilityToggle,
- restProps = (0, _objectWithoutProperties2.default)(props, _excluded);
- var suffixIcon = visibilityToggle && getIcon(prefixCls.value);
- var inputClassName = (0, _classNames2.default)(prefixCls.value, attrs.class, (0, _defineProperty2.default)({}, "".concat(prefixCls.value, "-").concat(size), !!size));
- var omittedProps = (0, _objectSpread2.default)((0, _objectSpread2.default)((0, _objectSpread2.default)({}, (0, _omit.default)(restProps, ['suffix', 'iconRender', 'action'])), attrs), {}, {
- type: visible.value ? 'text' : 'password',
- class: inputClassName,
- prefixCls: inputPrefixCls.value,
- suffix: suffixIcon
- });
- if (size) {
- omittedProps.size = size;
- }
- return (0, _vue.createVNode)(_Input.default, (0, _objectSpread2.default)({
- "ref": inputRef
- }, omittedProps), slots);
- };
- return function () {
- return renderPassword();
- };
- }
- });
- exports.default = _default;
|