user.ts 3.1 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798
  1. import { defineStore } from 'pinia'
  2. import { useVisitedRowState } from './visitedRow'
  3. import { useNotificationMessage } from './notificationMessage'
  4. import dayjs from 'dayjs'
  5. interface UserInfo {
  6. uname: string
  7. first_name: string
  8. last_name: string
  9. user_type: string
  10. email: string
  11. expire_day: number
  12. date_format: string
  13. numbers_format: string
  14. PASSWORD_CHANGE_CYCLE: number // 密码修改周期(多少天需要改一次)
  15. last_pwd_change: string // 上次密码修改时间
  16. }
  17. interface UserState {
  18. userInfo: UserInfo
  19. isFirstLogin: boolean
  20. }
  21. /**
  22. * 根据用户地区判断日期格式
  23. * @returns {string} - 返回日期格式
  24. */
  25. const getDateFormat = () => {
  26. const userLanguage = navigator.language || 'en-US' // 获取浏览器的语言设置
  27. // 判断用户地区
  28. if (userLanguage === 'en-US') {
  29. return 'MM/DD/YYYY' // 美国使用 MM/DD/YYYY 格式
  30. } else if (
  31. userLanguage.startsWith('de') ||
  32. userLanguage.startsWith('fr') ||
  33. userLanguage.startsWith('it') ||
  34. userLanguage.startsWith('es') ||
  35. userLanguage.startsWith('pl') ||
  36. userLanguage.startsWith('nl') ||
  37. userLanguage.startsWith('pt') ||
  38. userLanguage.startsWith('se')
  39. ) {
  40. return 'DD/MM/YYYY' // 其他欧洲国家(例:德语、法语、西班牙语等)使用 DD/MM/YYYY 格式
  41. } else if (['zh-CN', 'ja-JP', 'ko-KR'].includes(userLanguage)) {
  42. return 'YYYY-MM-DD' // 东亚国家(如简体中文、日语、韩语)使用 YYYY-MM-DD 格式
  43. } else {
  44. return 'DD/MM/YYYY' // 其他地区默认 DD/MM/YYYY 格式
  45. }
  46. }
  47. export const useUserStore = defineStore('user', {
  48. state: (): UserState => ({
  49. userInfo: JSON.parse(localStorage.getItem('userInfo') || '{}'),
  50. isFirstLogin: localStorage.getItem('isFirstLogin')
  51. ? JSON.parse(localStorage.getItem('isFirstLogin'))
  52. : false
  53. }),
  54. getters: {
  55. userName(state) {
  56. if (state.userInfo.first_name && state.userInfo.last_name) {
  57. return `${state.userInfo.first_name} ${state.userInfo.last_name}`
  58. } else {
  59. return state.userInfo.uname || ''
  60. }
  61. },
  62. dateFormat(state) {
  63. return state.userInfo.date_format || getDateFormat()
  64. },
  65. expireDay(state) {
  66. const userInfo = state.userInfo
  67. return userInfo.PASSWORD_CHANGE_CYCLE - dayjs().diff(dayjs(userInfo.last_pwd_change), 'day')
  68. }
  69. },
  70. actions: {
  71. setUserInfo(userInfo: any, isFirstLogin?: boolean) {
  72. this.userInfo = userInfo
  73. localStorage.setItem('userInfo', JSON.stringify(userInfo))
  74. if (isFirstLogin !== undefined) {
  75. localStorage.setItem('isFirstLogin', JSON.stringify(isFirstLogin))
  76. this.isFirstLogin = isFirstLogin
  77. }
  78. },
  79. async logout(isNeedLogout: boolean = true) {
  80. if (isNeedLogout) {
  81. await $api.logout().then(() => {})
  82. }
  83. localStorage.removeItem('userInfo')
  84. this.userInfo = {}
  85. if (localStorage.getItem('isFirstLogin')) {
  86. localStorage.removeItem('isFirstLogin')
  87. }
  88. this.isFirstLogin = false
  89. useVisitedRowState().clearVisitedRow()
  90. useNotificationMessage().clearData()
  91. }
  92. }
  93. })