dict.ts 2.0 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374
  1. import { defineStore } from 'pinia'
  2. import { store } from '../index'
  3. import { DictDataVO } from '@/api/system/dict/types'
  4. import { CACHE_KEY, useCache } from '@/hooks/web/useCache'
  5. const { wsCache } = useCache('sessionStorage')
  6. import { listSimpleDictDataApi } from '@/api/system/dict/dict.data'
  7. export interface DictValueType {
  8. value: any
  9. label: string
  10. clorType?: string
  11. cssClass?: string
  12. }
  13. export interface DictTypeType {
  14. dictType: string
  15. dictValue: DictValueType[]
  16. }
  17. export interface DictState {
  18. dictMap: Map<string, any>
  19. isSetDict: boolean
  20. }
  21. export const useDictStore = defineStore('dict', {
  22. state: (): DictState => ({
  23. dictMap: new Map<string, any>(),
  24. isSetDict: false
  25. }),
  26. getters: {
  27. getDictMap(): Recordable {
  28. const dictMap = wsCache.get(CACHE_KEY.DICT_CACHE)
  29. if (dictMap) {
  30. this.dictMap = dictMap
  31. }
  32. return this.dictMap
  33. },
  34. getIsSetDict(): boolean {
  35. return this.isSetDict
  36. }
  37. },
  38. actions: {
  39. async setDictMap() {
  40. const dictMap = wsCache.get(CACHE_KEY.DICT_CACHE)
  41. if (dictMap) {
  42. this.dictMap = dictMap
  43. this.isSetDict = true
  44. } else {
  45. const res = await listSimpleDictDataApi()
  46. // 设置数据
  47. const dictDataMap = new Map<string, any>()
  48. res.forEach((dictData: DictDataVO) => {
  49. // 获得 dictType 层级
  50. const enumValueObj = dictDataMap[dictData.dictType]
  51. if (!enumValueObj) {
  52. dictDataMap[dictData.dictType] = []
  53. }
  54. // 处理 dictValue 层级
  55. dictDataMap[dictData.dictType].push({
  56. value: dictData.value,
  57. label: dictData.label,
  58. colorType: dictData.colorType,
  59. cssClass: dictData.cssClass
  60. })
  61. })
  62. this.dictMap = dictDataMap
  63. this.isSetDict = true
  64. wsCache.set(CACHE_KEY.DICT_CACHE, dictDataMap, { exp: 60 }) // 60 秒 过期
  65. }
  66. }
  67. }
  68. })
  69. export const useDictStoreWithOut = () => {
  70. return useDictStore(store)
  71. }