utils.js 6.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270
  1. import { Toast } from '@douyinfe/semi-ui';
  2. import { toastConstants } from '../constants';
  3. import React from 'react';
  4. import { toast } from 'react-toastify';
  5. const HTMLToastContent = ({ htmlContent }) => {
  6. return <div dangerouslySetInnerHTML={{ __html: htmlContent }} />;
  7. };
  8. export default HTMLToastContent;
  9. export function isAdmin() {
  10. let user = localStorage.getItem('user');
  11. if (!user) return false;
  12. user = JSON.parse(user);
  13. return user.role >= 10;
  14. }
  15. export function isRoot() {
  16. let user = localStorage.getItem('user');
  17. if (!user) return false;
  18. user = JSON.parse(user);
  19. return user.role >= 100;
  20. }
  21. export function getSystemName() {
  22. let system_name = localStorage.getItem('system_name');
  23. if (!system_name) return 'New API';
  24. return system_name;
  25. }
  26. export function getLogo() {
  27. let logo = localStorage.getItem('logo');
  28. if (!logo) return '/logo.png';
  29. return logo;
  30. }
  31. export function getUserIdFromLocalStorage() {
  32. let user = localStorage.getItem('user');
  33. if (!user) return -1;
  34. user = JSON.parse(user);
  35. return user.id;
  36. }
  37. export function getFooterHTML() {
  38. return localStorage.getItem('footer_html');
  39. }
  40. export async function copy(text) {
  41. let okay = true;
  42. try {
  43. await navigator.clipboard.writeText(text);
  44. } catch (e) {
  45. okay = false;
  46. console.error(e);
  47. }
  48. return okay;
  49. }
  50. export function isMobile() {
  51. return window.innerWidth <= 600;
  52. }
  53. let showErrorOptions = { autoClose: toastConstants.ERROR_TIMEOUT };
  54. let showWarningOptions = { autoClose: toastConstants.WARNING_TIMEOUT };
  55. let showSuccessOptions = { autoClose: toastConstants.SUCCESS_TIMEOUT };
  56. let showInfoOptions = { autoClose: toastConstants.INFO_TIMEOUT };
  57. let showNoticeOptions = { autoClose: false };
  58. if (isMobile()) {
  59. showErrorOptions.position = 'top-center';
  60. // showErrorOptions.transition = 'flip';
  61. showSuccessOptions.position = 'top-center';
  62. // showSuccessOptions.transition = 'flip';
  63. showInfoOptions.position = 'top-center';
  64. // showInfoOptions.transition = 'flip';
  65. showNoticeOptions.position = 'top-center';
  66. // showNoticeOptions.transition = 'flip';
  67. }
  68. export function showError(error) {
  69. console.error(error);
  70. if (error.message) {
  71. if (error.name === 'AxiosError') {
  72. switch (error.response.status) {
  73. case 401:
  74. // toast.error('错误:未登录或登录已过期,请重新登录!', showErrorOptions);
  75. window.location.href = '/login?expired=true';
  76. break;
  77. case 429:
  78. Toast.error('错误:请求次数过多,请稍后再试!');
  79. break;
  80. case 500:
  81. Toast.error('错误:服务器内部错误,请联系管理员!');
  82. break;
  83. case 405:
  84. Toast.info('本站仅作演示之用,无服务端!');
  85. break;
  86. default:
  87. Toast.error('错误:' + error.message);
  88. }
  89. return;
  90. }
  91. Toast.error('错误:' + error.message);
  92. } else {
  93. Toast.error('错误:' + error);
  94. }
  95. }
  96. export function showWarning(message) {
  97. Toast.warning(message);
  98. }
  99. export function showSuccess(message) {
  100. Toast.success(message);
  101. }
  102. export function showInfo(message) {
  103. Toast.info(message);
  104. }
  105. export function showNotice(message, isHTML = false) {
  106. if (isHTML) {
  107. toast(<HTMLToastContent htmlContent={message} />, showNoticeOptions);
  108. } else {
  109. Toast.info(message);
  110. }
  111. }
  112. export function openPage(url) {
  113. window.open(url);
  114. }
  115. export function removeTrailingSlash(url) {
  116. if (url.endsWith('/')) {
  117. return url.slice(0, -1);
  118. } else {
  119. return url;
  120. }
  121. }
  122. export function getTodayStartTimestamp() {
  123. var now = new Date();
  124. now.setHours(0, 0, 0, 0);
  125. return Math.floor(now.getTime() / 1000);
  126. }
  127. export function timestamp2string(timestamp) {
  128. let date = new Date(timestamp * 1000);
  129. let year = date.getFullYear().toString();
  130. let month = (date.getMonth() + 1).toString();
  131. let day = date.getDate().toString();
  132. let hour = date.getHours().toString();
  133. let minute = date.getMinutes().toString();
  134. let second = date.getSeconds().toString();
  135. if (month.length === 1) {
  136. month = '0' + month;
  137. }
  138. if (day.length === 1) {
  139. day = '0' + day;
  140. }
  141. if (hour.length === 1) {
  142. hour = '0' + hour;
  143. }
  144. if (minute.length === 1) {
  145. minute = '0' + minute;
  146. }
  147. if (second.length === 1) {
  148. second = '0' + second;
  149. }
  150. return (
  151. year + '-' + month + '-' + day + ' ' + hour + ':' + minute + ':' + second
  152. );
  153. }
  154. export function timestamp2string1(timestamp, dataExportDefaultTime = 'hour') {
  155. let date = new Date(timestamp * 1000);
  156. // let year = date.getFullYear().toString();
  157. let month = (date.getMonth() + 1).toString();
  158. let day = date.getDate().toString();
  159. let hour = date.getHours().toString();
  160. if (month.length === 1) {
  161. month = '0' + month;
  162. }
  163. if (day.length === 1) {
  164. day = '0' + day;
  165. }
  166. if (hour.length === 1) {
  167. hour = '0' + hour;
  168. }
  169. let str = month + '-' + day;
  170. if (dataExportDefaultTime === 'hour') {
  171. str += ' ' + hour + ':00';
  172. } else if (dataExportDefaultTime === 'week') {
  173. let nextWeek = new Date(timestamp * 1000 + 6 * 24 * 60 * 60 * 1000);
  174. let nextMonth = (nextWeek.getMonth() + 1).toString();
  175. let nextDay = nextWeek.getDate().toString();
  176. if (nextMonth.length === 1) {
  177. nextMonth = '0' + nextMonth;
  178. }
  179. if (nextDay.length === 1) {
  180. nextDay = '0' + nextDay;
  181. }
  182. str += ' - ' + nextMonth + '-' + nextDay;
  183. }
  184. return str;
  185. }
  186. export function downloadTextAsFile(text, filename) {
  187. let blob = new Blob([text], { type: 'text/plain;charset=utf-8' });
  188. let url = URL.createObjectURL(blob);
  189. let a = document.createElement('a');
  190. a.href = url;
  191. a.download = filename;
  192. a.click();
  193. }
  194. export const verifyJSON = (str) => {
  195. try {
  196. JSON.parse(str);
  197. } catch (e) {
  198. return false;
  199. }
  200. return true;
  201. };
  202. export function verifyJSONPromise(value) {
  203. try {
  204. JSON.parse(value);
  205. return Promise.resolve();
  206. } catch (e) {
  207. return Promise.reject('不是合法的 JSON 字符串');
  208. }
  209. }
  210. export function shouldShowPrompt(id) {
  211. let prompt = localStorage.getItem(`prompt-${id}`);
  212. return !prompt;
  213. }
  214. export function setPromptShown(id) {
  215. localStorage.setItem(`prompt-${id}`, 'true');
  216. }
  217. /**
  218. * 比较两个对象的属性,找出有变化的属性,并返回包含变化属性信息的数组
  219. * @param {Object} oldObject - 旧对象
  220. * @param {Object} newObject - 新对象
  221. * @return {Array} 包含变化属性信息的数组,每个元素是一个对象,包含 key, oldValue 和 newValue
  222. */
  223. export function compareObjects(oldObject, newObject) {
  224. const changedProperties = [];
  225. // 比较两个对象的属性
  226. for (const key in oldObject) {
  227. if (oldObject.hasOwnProperty(key) && newObject.hasOwnProperty(key)) {
  228. if (oldObject[key] !== newObject[key]) {
  229. changedProperties.push({
  230. key: key,
  231. oldValue: oldObject[key],
  232. newValue: newObject[key],
  233. });
  234. }
  235. }
  236. }
  237. return changedProperties;
  238. }