calculate.js 5.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154
  1. import _ from "lodash";
  2. //计算费用
  3. export function calculationFees(num, num2, num3) {
  4. const val = Number(num ? num : 0)
  5. const val2 = Number(num2 ? num2 : 0)
  6. const val3 = Number(num3 ? num3 : 0)
  7. const sum = _.multiply(_.add(val, val2),val3)
  8. return Number(sum).toFixed(2)
  9. }
  10. //配件总价
  11. export function partSum(num, num2, num3, num4, num5, num6, num7) {
  12. const val = Number(num ? num : 0)
  13. const val2 = Number(num2 ? num2 : 0)
  14. const val3 = Number(num3 ? num3 : 0)
  15. const val4 = Number(num4 ? num4 : 0)
  16. const val5 = Number(num5 ? num5 : 0)
  17. const val6 = Number(num6 ? num6 : 0)
  18. const val7 = Number(num7 ? num7 : 0)
  19. const sum = _.add(val, _.add(val2, _.add(val3, _.add(val4, _.add(val5, _.add(val6, val7))))))
  20. return Number(sum).toFixed(2)
  21. }
  22. //总价
  23. export function sum(num, num2) {
  24. //最新价格
  25. const val = Number(num ? num : 0)
  26. const val2 = Number(num2 ? num2 : 0)
  27. const sum = _.add(val, val2)
  28. return Number(sum).toFixed(2)
  29. }
  30. //金额相乘
  31. export function multiply(num, num2) {
  32. //最新价格
  33. const val = Number(num ? num : 0)
  34. const val2 = Number(num2 ? num2 : 0)
  35. const multiply = _.multiply(val, val2)
  36. return Number(multiply).toFixed(2)
  37. }
  38. //原始成本=最新价格/(1+税率/100)
  39. export function costCal(num, num2) {
  40. //最新价格
  41. const price = Number(num ? num : 0)
  42. //税率
  43. const rate = Number(num2 ? num2 : 0)
  44. const sum = _.divide(price, _.add(1, _.divide(rate, 100)))
  45. return Number(sum).toFixed(2)
  46. }
  47. //采购价格加配件价计算出产品价格
  48. export function productCal(num, num2, num3) {
  49. //采购价格
  50. const price = Number(num ? num : 0)
  51. //配件价
  52. const fitting = Number(num2 ? num2 : 0)
  53. //fob
  54. const fob = Number(num3 ? num3 : 0)
  55. const sum = _.multiply(_.add(price, fitting), _.add(1, _.divide(fob, 100)))
  56. return Number(sum).toFixed(2)
  57. }
  58. export function costsCal(num, num2, num3) {
  59. //数字1
  60. const price1 = Number(num ? num : 0)
  61. //数字2
  62. const price2 = Number(num2 ? num2 : 0)
  63. //数量
  64. const Num = Number(num3 ? num3 : 0)
  65. const sum = _.add(price1, _.multiply(price2, Num))
  66. return Number(sum).toFixed(2)
  67. }
  68. //产品价格/汇率 计算出销售价格
  69. export function sellingCal(num, num2) {
  70. //产品价格
  71. const product = Number(num ? num : 0)
  72. //汇率
  73. const exchangeRate = Number(Number(num2) ? num2 : 1)
  74. const sum = _.divide(product, exchangeRate)
  75. return Number(sum).toFixed(2)
  76. }
  77. //销售价格乘以数量加运费加保险乘以(折扣除以10) 计算出金额
  78. export function amountCal(num, num2, num3, num4, num5) {
  79. //销售价
  80. const sell = Number(num ? num : 0)
  81. //数量
  82. const quantity = Number(num2 ? num2 : 0)
  83. //运费
  84. const freight = Number(num3 ? num3 : 0)
  85. //保险
  86. const insurance = Number(num4 ? num4 : 0)
  87. //折扣
  88. const discount = Number(num5 || num5 === 0 ? num5 : 10)
  89. const sum = _.multiply(_.add(_.multiply(sell, quantity), _.add(freight, insurance)), _.divide(discount, 10))
  90. return Number(sum).toFixed(2)
  91. }
  92. //保险、运费转换汇率
  93. export function transformCal(num, num2, num3) {
  94. //采购价格
  95. const cost = Number(num ? num : 0)
  96. //旧汇率
  97. const oldExchangeRate = Number(Number(num2) ? num2 : 1)
  98. //汇率
  99. const exchangeRate = Number(Number(num3) ? num3 : 1)
  100. const sum = _.divide(_.multiply(cost, oldExchangeRate), exchangeRate)
  101. return Number(sum).toFixed(2)
  102. }
  103. // 采购报价=单价 / (1+税率/100) *(1+FOB系数/100)
  104. export function purchaseCal(num, num2, num3) {
  105. const price = Number(num ? num : 0)
  106. const taxRate = Number(num2 ? num2 : 0)
  107. const fob = Number(num3 ? num3 : 0)
  108. const sum = _.multiply(_.divide(price, _.add(1, _.divide(taxRate, 100))), _.add(1, _.divide(fob, 100)))
  109. return Number(sum).toFixed(2)
  110. }
  111. // 单品毛利率:( 销售价*汇率 -(采购价格+配件价格))/销售价*汇率
  112. export function grossProfitCal(num, num2, num3, num4) {
  113. const purchase = Number(num ? num : 0)
  114. const fitting = Number(num2 ? num2 : 0)
  115. const price = Number(num3 ? num3 : 0)
  116. const exchangeRate = Number(Number(num4) ? num4 : 1)
  117. const sum = _.multiply(_.divide(_.subtract(_.multiply(price, exchangeRate), _.add(purchase, fitting)), _.multiply(price, exchangeRate)), 100)
  118. return sum ? Number(sum).toFixed(2) : '0.00'
  119. }
  120. //单票毛利: (金额*汇率+费用应收合计)-(成本*数量+费用应付合计)
  121. export function STGPCal(num, num2, num3, num4) {
  122. const amountSum = Number(num ? num : 0)
  123. const reSum = Number(num2 ? num2 : 0)
  124. const costSum = Number(num3 ? num3 : 0)
  125. const paySum = Number(num4 ? num4 : 0)
  126. const sum = _.subtract(_.add(amountSum, reSum), _.add(costSum, paySum))
  127. return Number(sum).toFixed(2)
  128. }
  129. //校验值是否合法
  130. export function numCal(num) {
  131. if (isNaN(Number(num))) {
  132. return Number(0)
  133. } else {
  134. return Number(num ? num : 0)
  135. }
  136. }
  137. //工资拨付标准+职级工资
  138. export function addAllsalary(num, num2, num3) {
  139. const Sum1 = Number(num ? num : 0)
  140. const Sum2 = Number(num2 ? num2 : 0)
  141. const Sum3 = Number(num3 ? num3 : 0)
  142. const sum = _.add(_.add(Sum1, Sum2), Sum3)
  143. return Number(sum)
  144. }
  145. //
  146. export function addAllsalary2(num, num2, num3, num4) {
  147. const Sum1 = Number(num ? num : 0)
  148. const Sum2 = Number(num2 ? num2 : 0)
  149. const Sum3 = Number(num3 ? num3 : 0)
  150. const Sum4 = Number(num4 ? num4 : 0)
  151. const sum = _.add(_.add(Sum1, Sum2), _.add(Sum3, Sum4))
  152. return Number(sum)
  153. }