@gizwits/vantui
Version:
机智云组件库
103 lines • 4.56 kB
JavaScript
import _defineProperty from "@babel/runtime/helpers/defineProperty";
import _slicedToArray from "@babel/runtime/helpers/slicedToArray";
import _objectWithoutProperties from "@babel/runtime/helpers/objectWithoutProperties";
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) { _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; }
import { useEffect, useState } from 'react';
import { canIUse as TaroCanIUse, getUserProfile as TaroGetUserProfile, getUserInfo as TaroGetUserInfo } from '@tarojs/taro';
import { Button } from '../button';
import { jsx as _jsx } from "react/jsx-runtime";
import { Fragment as _Fragment } from "react/jsx-runtime";
export function MiniUserButton(props) {
var onGetUserInfo = props.onGetUserInfo,
onFail = props.onFail,
desc = props.desc,
children = props.children,
others = _objectWithoutProperties(props, _excluded);
var _useState = useState(true),
_useState2 = _slicedToArray(_useState, 2),
userProfile = _useState2[0],
setUserProfile = _useState2[1];
useEffect(function () {
var canIUse = false;
if (process.env.TARO_ENV !== 'h5') {
try {
canIUse = TaroCanIUse('getUserProfile');
} catch (_unused) {}
}
setUserProfile(canIUse);
}, []);
var getUserProfile = function getUserProfile() {
TaroGetUserProfile({
desc: desc || '用于快速登录',
// 声明获取用户个人信息后的用途,后续会展示在弹窗中,请谨慎填写
success: function success(res) {
onGetUserInfo(res);
},
fail: function fail(error) {
onFail(error);
}
});
};
var getTTUserInfo = function getTTUserInfo() {
TaroGetUserInfo({
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__*/_jsx(Button, _objectSpread(_objectSpread({}, others), {}, {
openType: "getAuthorize",
scope: "userInfo",
onError: getError,
onGetAuthorize: getUserInfo,
children: children
}));
}
return /*#__PURE__*/_jsx(_Fragment, {
children: userProfile ? /*#__PURE__*/_jsx(Button, _objectSpread(_objectSpread({}, others), {}, {
onClick: getUserProfile,
children: children
})) : process.env.TARO_ENV === 'tt' ? /*#__PURE__*/_jsx(Button, _objectSpread(_objectSpread({}, others), {}, {
onClick: getTTUserInfo,
children: children
})) : /*#__PURE__*/_jsx(Button, _objectSpread(_objectSpread({}, others), {}, {
openType: "getUserInfo",
onGetUserInfo: getUserInfo,
children: children
}))
});
}
export default MiniUserButton;