@apulis/group-selector
Version:
change user group at navbar
174 lines (152 loc) • 6.98 kB
JavaScript
import "antd/es/button/style";
import _Button from "antd/es/button";
import "antd/es/checkbox/style";
import _Checkbox from "antd/es/checkbox";
import "antd/es/modal/style";
import _Modal from "antd/es/modal";
function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }
function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }
function _iterableToArrayLimit(arr, i) { var _i = arr && (typeof Symbol !== "undefined" && arr[Symbol.iterator] || arr["@@iterator"]); if (_i == null) return; var _arr = []; var _n = true; var _d = false; var _s, _e; try { for (_i = _i.call(arr); !(_n = (_s = _i.next()).done); _n = true) { _arr.push(_s.value); if (i && _arr.length === i) break; } } catch (err) { _d = true; _e = err; } finally { try { if (!_n && _i["return"] != null) _i["return"](); } finally { if (_d) throw _e; } } return _arr; }
function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }
import React, { useMemo, useState, useEffect } from 'react';
import { WarningFilled, ExclamationCircleOutlined } from '@ant-design/icons';
import { useIntl } from '@apulis/provider';
import '../index.less';
var LicenseTip = function LicenseTip(_ref) {
var expire = _ref.expire;
var intl = useIntl();
var _useState = useState(false),
_useState2 = _slicedToArray(_useState, 2),
checked = _useState2[0],
setChecked = _useState2[1];
var _useState3 = useState(false),
_useState4 = _slicedToArray(_useState3, 2),
visible = _useState4[0],
setVisible = _useState4[1];
var tip = useMemo(function () {
var t = {
title: '',
content: ''
};
var tipMap = {
restDate: {
title: intl.getMessage('groupSelector.licenseRestDateTitle', "License\u8FD8\u6709{expire}\u5929\u8FC7\u671F", {
expire: expire
}),
content: intl.getMessage('groupSelector.LicenseRestDateTip', 'License过期时,所有用户将无法登录。为了您能够正常使用AI Studio, 请联系供应商获取新的License文件并激活')
},
outDate: {
title: intl.getMessage('groupSelector.licenseOutDateTitle', 'License已失效'),
content: intl.getMessage('groupSelector.licenseOutDateTip', 'License已失效。请联系供应商获取新的License文件并激活')
},
none: {
title: intl.getMessage('groupSelector.LicenseNoneTitle', '缺失License'),
content: intl.getMessage('groupSelector.LicenseNoneTip', '请联系供应商获取License文件并激活')
}
};
if (expire <= 30 && expire > 0) {
t = tipMap.restDate;
} else if (expire <= 0) {
t = tipMap.outDate;
}
return t;
}, [expire, intl]);
useEffect(function () {
if (expire <= 30 && expire > 0) {
if (localStorage.licenseNoTips) {
var _licenseNoTips$find;
var licenseNoTips = JSON.parse(localStorage.licenseNoTips) || [];
var currentUserID = localStorage.userId;
var flag = (_licenseNoTips$find = licenseNoTips.find(function (i) {
return i.id === currentUserID;
})) === null || _licenseNoTips$find === void 0 ? void 0 : _licenseNoTips$find.flag; // 下次是否不再提示license过期
if (flag) {
setVisible(!flag);
} else {
setVisible(true);
}
} else {
setVisible(true);
}
}
}, [expire]);
var showModalTip = function showModalTip() {
_Modal.warning({
title: tip.title,
icon: /*#__PURE__*/React.createElement(WarningFilled, {
style: {
color: '#faad14'
}
}),
content: tip.content,
okText: intl.getMessage('groupSelector.LicenseOK', '确定')
});
};
return /*#__PURE__*/React.createElement(React.Fragment, null, /*#__PURE__*/React.createElement("div", {
onClick: showModalTip,
className: "license-info"
}, /*#__PURE__*/React.createElement(WarningFilled, {
style: {
color: '#faad14',
marginRight: '4px'
}
}), /*#__PURE__*/React.createElement("span", null, tip.title)), /*#__PURE__*/React.createElement(_Modal, {
visible: visible,
footer: null,
onCancel: function onCancel() {
return setVisible(false);
},
title: /*#__PURE__*/React.createElement("div", {
style: {
display: 'flex',
alignItems: 'center'
}
}, /*#__PURE__*/React.createElement(ExclamationCircleOutlined, {
style: {
marginRight: '4px',
color: '#526ecc'
}
}), /*#__PURE__*/React.createElement("span", null, intl.getMessage('groupSelector.licenseRestDateTitle', 'License还有{expire}天过期', {
expire: expire
})))
}, /*#__PURE__*/React.createElement("div", null, intl.getMessage('groupSelector.LicenseRestDateTip', 'License过期时,所有用户将无法登录。为了您能够正常使用AI Studio, 请联系供应商获取新的License文件并激活')), /*#__PURE__*/React.createElement("div", {
style: {
marginTop: '20px',
display: 'flex',
justifyContent: 'space-between'
}
}, /*#__PURE__*/React.createElement(_Checkbox, {
onChange: function onChange(e) {
return setChecked(e.target.checked);
}
}, intl.getMessage('groupSelector.LicenseNoTip', '下次不再提示')), /*#__PURE__*/React.createElement(_Button, {
type: "primary",
onClick: function onClick() {
var licenseNoTips = [];
if (localStorage.licenseNoTips) {
licenseNoTips = JSON.parse(localStorage.licenseNoTips);
}
var currentUserID = localStorage.userId;
var currentUserLicenseTip = licenseNoTips.find(function (i) {
return i.id === currentUserID;
});
if (currentUserLicenseTip) {
licenseNoTips.forEach(function (i) {
if (i.id === currentUserID) {
i.flag = checked;
}
});
} else {
licenseNoTips.push({
id: currentUserID,
flag: checked
});
}
localStorage.licenseNoTips = JSON.stringify(licenseNoTips);
setVisible(false);
}
}, intl.getMessage('groupSelector.LicenseOK', '确定')))));
};
export default LicenseTip;