index.js 3.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115
  1. import dayjs from "dayjs";
  2. /**
  3. * 将一个整数转换为分数保留两位小数
  4. * @param {number | string | undefined} num 整数
  5. * @return {number} 分数
  6. */
  7. export const formatToFraction = (num) => {
  8. if (typeof num === 'undefined') return 0
  9. const parsedNumber = typeof num === 'string' ? parseFloat(num) : num
  10. return parseFloat((parsedNumber / 100).toFixed(2))
  11. }
  12. /**
  13. * 将一个数转换为 1.00 这样
  14. * 数据呈现的时候使用
  15. *
  16. * @param {number | string | undefined} num 整数
  17. * @return {string} 分数
  18. */
  19. export const floatToFixed2 = (num) => {
  20. let str = '0.00'
  21. if (typeof num === 'undefined') {
  22. return str
  23. }
  24. const f = formatToFraction(num)
  25. const decimalPart = f.toString().split('.')[1]
  26. const len = decimalPart ? decimalPart.length : 0
  27. switch (len) {
  28. case 0:
  29. str = f.toString() + '.00'
  30. break
  31. case 1:
  32. str = f.toString() + '.0'
  33. break
  34. case 2:
  35. str = f.toString()
  36. break
  37. }
  38. return str
  39. }
  40. /**
  41. * 将一个分数转换为整数
  42. *
  43. * @param {number | string | undefined} num 分数
  44. * @return {number} 整数
  45. */
  46. export const convertToInteger = (num) => {
  47. if (typeof num === 'undefined') return 0
  48. const parsedNumber = typeof num === 'string' ? parseFloat(num) : num
  49. // TODO 分转元后还有小数则四舍五入
  50. return Math.round(parsedNumber * 100)
  51. }
  52. /**
  53. * 时间日期转换
  54. * @param {dayjs.ConfigType} date 当前时间,new Date() 格式
  55. * @param {string} format 需要转换的时间格式字符串
  56. * @description format 字符串随意,如 `YYYY-mm、YYYY-mm-dd`
  57. * @description format 季度:"YYYY-mm-dd HH:MM:SS QQQQ"
  58. * @description format 星期:"YYYY-mm-dd HH:MM:SS WWW"
  59. * @description format 几周:"YYYY-mm-dd HH:MM:SS ZZZ"
  60. * @description format 季度 + 星期 + 几周:"YYYY-mm-dd HH:MM:SS WWW QQQQ ZZZ"
  61. * @returns {string} 返回拼接后的时间字符串
  62. */
  63. export function formatDate(date, format) {
  64. // 日期不存在,则返回空
  65. if (!date) {
  66. return ''
  67. }
  68. // 日期存在,则进行格式化
  69. if (format === undefined) {
  70. format = 'YYYY-MM-DD HH:mm:ss'
  71. }
  72. return dayjs(date).format(format)
  73. }
  74. /**
  75. * 构造树型结构数据
  76. *
  77. * @param {*} data 数据源
  78. * @param {*} id id字段 默认 'id'
  79. * @param {*} parentId 父节点字段 默认 'parentId'
  80. * @param {*} children 孩子节点字段 默认 'children'
  81. * @param {*} rootId 根Id 默认 0
  82. */
  83. export function handleTree(data, id = 'id', parentId = 'parentId', children = 'children', rootId = 0) {
  84. // 对源数据深度克隆
  85. const cloneData = JSON.parse(JSON.stringify(data))
  86. // 循环所有项
  87. const treeData = cloneData.filter(father => {
  88. let branchArr = cloneData.filter(child => {
  89. //返回每一项的子级数组
  90. return father[id] === child[parentId]
  91. });
  92. branchArr.length > 0 ? father.children = branchArr : '';
  93. //返回第一层
  94. return father[parentId] === rootId;
  95. });
  96. return treeData !== '' ? treeData : data;
  97. }
  98. /**
  99. * 重置分页对象
  100. *
  101. * TODO 非繁人:需要处理其它页面
  102. *
  103. * @param pagination 分页对象
  104. */
  105. export function resetPagination(pagination) {
  106. pagination.list = [];
  107. pagination.total = 0;
  108. pagination.pageNo = 1;
  109. }