dict.ts 2.8 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697
  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. async resetDict() {
  68. wsCache.delete(CACHE_KEY.DICT_CACHE)
  69. const res = await listSimpleDictDataApi()
  70. // 设置数据
  71. const dictDataMap = new Map<string, any>()
  72. res.forEach((dictData: DictDataVO) => {
  73. // 获得 dictType 层级
  74. const enumValueObj = dictDataMap[dictData.dictType]
  75. if (!enumValueObj) {
  76. dictDataMap[dictData.dictType] = []
  77. }
  78. // 处理 dictValue 层级
  79. dictDataMap[dictData.dictType].push({
  80. value: dictData.value,
  81. label: dictData.label,
  82. colorType: dictData.colorType,
  83. cssClass: dictData.cssClass
  84. })
  85. })
  86. this.dictMap = dictDataMap
  87. this.isSetDict = true
  88. wsCache.set(CACHE_KEY.DICT_CACHE, dictDataMap, { exp: 60 }) // 60 秒 过期
  89. }
  90. }
  91. })
  92. export const useDictStoreWithOut = () => {
  93. return useDictStore(store)
  94. }