@antmjs/vantui
Version:
一套适用于Taro3及React的vantui组件库
111 lines (110 loc) • 4.94 kB
JavaScript
;
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.MiniUserButton = MiniUserButton;
exports.default = void 0;
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties"));
var _react = require("react");
var _taro = require("@tarojs/taro");
var _button = require("../button");
var _jsxRuntime = require("react/jsx-runtime");
var _excluded = ["onGetUserInfo", "onFail", "desc", "children"];
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) { (0, _defineProperty2.default)(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 MiniUserButton(props) {
var onGetUserInfo = props.onGetUserInfo,
onFail = props.onFail,
desc = props.desc,
children = props.children,
others = (0, _objectWithoutProperties2.default)(props, _excluded);
var _useState = (0, _react.useState)(true),
_useState2 = (0, _slicedToArray2.default)(_useState, 2),
userProfile = _useState2[0],
setUserProfile = _useState2[1];
(0, _react.useEffect)(function () {
var canIUse = false;
if (process.env.TARO_ENV !== 'h5') {
try {
canIUse = (0, _taro.canIUse)('getUserProfile');
} catch (_unused) {}
}
setUserProfile(canIUse);
}, []);
var getUserProfile = function getUserProfile() {
(0, _taro.getUserProfile)({
desc: desc || '用于快速登录',
// 声明获取用户个人信息后的用途,后续会展示在弹窗中,请谨慎填写
success: function success(res) {
onGetUserInfo(res);
},
fail: function fail(error) {
onFail(error);
}
});
};
var getTTUserInfo = function getTTUserInfo() {
(0, _taro.getUserInfo)({
success: function success(res) {
onGetUserInfo(res);
},
fail: function fail(error) {
onFail(error);
}
});
};
var getUserInfo = function getUserInfo(e) {
if (process.env.TARO_ENV === 'alipay') {
my.getOpenUserInfo({
fail: function fail(e) {
onFail({
errMsg: e.errorMessage || JSON.stringify(e)
});
},
success: function success(res) {
var userInfo = JSON.parse(res.response).response; // 以下方的报文格式解析两层 response
onGetUserInfo(userInfo);
}
});
} else {
if (e.detail) {
onGetUserInfo(e.detail);
} else {
onFail(e);
}
}
};
var getError = function getError(e) {
var _e$detail$errorMessag, _e$detail, _e$detail2;
onFail({
errMsg: /取消/.test((_e$detail$errorMessag = (_e$detail = e.detail) === null || _e$detail === void 0 ? void 0 : _e$detail.errorMessage) !== null && _e$detail$errorMessag !== void 0 ? _e$detail$errorMessag : '') ? 'getUserInfo:fail auth deny' : (_e$detail2 = e.detail) === null || _e$detail2 === void 0 ? void 0 : _e$detail2.errorMessage
});
};
if (process.env.TARO_ENV === 'alipay') {
return /*#__PURE__*/(0, _jsxRuntime.jsx)(_button.Button, _objectSpread(_objectSpread({}, others), {}, {
openType: "getAuthorize",
scope: "userInfo",
onError: getError,
onGetAuthorize: getUserInfo,
children: children
}));
}
return /*#__PURE__*/(0, _jsxRuntime.jsx)(_jsxRuntime.Fragment, {
children: userProfile ? /*#__PURE__*/(0, _jsxRuntime.jsx)(_button.Button, _objectSpread(_objectSpread({}, others), {}, {
onClick: getUserProfile,
children: children
})) : process.env.TARO_ENV === 'tt' ? /*#__PURE__*/(0, _jsxRuntime.jsx)(_button.Button, _objectSpread(_objectSpread({}, others), {}, {
onClick: getTTUserInfo,
children: children
})) : /*#__PURE__*/(0, _jsxRuntime.jsx)(_button.Button, _objectSpread(_objectSpread({}, others), {}, {
openType: "getUserInfo",
onGetUserInfo: getUserInfo,
children: children
}))
});
}
var _default = MiniUserButton;
exports.default = _default;