calculate.js 3.0 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182
  1. import _ from "lodash";
  2. //采购价格加配件价计算出产品价格
  3. export function productCal(num, num2, num3) {
  4. //采购价格
  5. const price = Number(num ? num : 0)
  6. //配件价
  7. const fitting = Number(num2 ? num2 : 0)
  8. //fob
  9. const fob = Number(num3 ? num3 : 0)
  10. const sum = _.multiply(_.add(price, fitting), _.add(1, _.divide(fob, 100)))
  11. return Number(sum).toFixed(2)
  12. }
  13. //产品价格/汇率 计算出销售价格
  14. export function sellingCal(num, num2) {
  15. //产品价格
  16. const product = Number(num ? num : 0)
  17. //汇率
  18. const exchangeRate = Number(Number(num2) ? num2 : 1)
  19. const sum = _.divide(product, exchangeRate)
  20. return Number(sum).toFixed(2)
  21. }
  22. //销售价格乘以数量加运费加保险乘以(折扣除以10) 计算出金额
  23. export function amountCal(num, num2, num3, num4, num5) {
  24. //销售价
  25. const sell = Number(num ? num : 0)
  26. //数量
  27. const quantity = Number(num2 ? num2 : 0)
  28. //运费
  29. const freight = Number(num3 ? num3 : 0)
  30. //保险
  31. const insurance = Number(num4 ? num4 : 0)
  32. //折扣
  33. const discount = Number(num5 || num5 === 0 ? num5 : 10)
  34. const sum = _.multiply(_.add(_.multiply(sell, quantity), _.add(freight, insurance)), _.divide(discount, 10))
  35. return Number(sum).toFixed(2)
  36. }
  37. //保险、运费转换汇率
  38. export function transformCal(num, num2, num3) {
  39. //采购价格
  40. const cost = Number(num ? num : 0)
  41. //旧汇率
  42. const oldExchangeRate = Number(Number(num2) ? num2 : 1)
  43. //汇率
  44. const exchangeRate = Number(Number(num3) ? num3 : 1)
  45. const sum = _.divide(_.multiply(cost, oldExchangeRate), exchangeRate)
  46. return Number(sum).toFixed(2)
  47. }
  48. // 采购报价=单价 / (1+税率/100) *(1+FOB系数/100)
  49. export function purchaseCal(num, num2, num3) {
  50. const price = Number(num ? num : 0)
  51. const taxRate = Number(num2 ? num2 : 0)
  52. const fob = Number(num3 ? num3 : 0)
  53. const sum = _.multiply(_.divide(price, _.add(1, _.divide(taxRate, 100))), _.add(1, _.divide(fob, 100)))
  54. return Number(sum).toFixed(2)
  55. }
  56. // 单品毛利率:( 销售价*汇率 -(采购价格+配件价格))/销售价*汇率
  57. export function grossProfitCal(num, num2, num3, num4) {
  58. const purchase = Number(num ? num : 0)
  59. const fitting = Number(num2 ? num2 : 0)
  60. const price = Number(num3 ? num3 : 0)
  61. const exchangeRate = Number(Number(num4) ? num4 : 1)
  62. const sum = _.multiply(_.divide(_.subtract(_.multiply(price, exchangeRate), _.add(purchase, fitting)), _.multiply(price, exchangeRate)), 100)
  63. return Number(sum).toFixed(2)
  64. }
  65. //单票毛利: (金额*汇率+费用应收合计)-(成本*数量+费用应付合计)
  66. export function STGPCal(num, num2, num3, num4){
  67. const amountSum= Number(num ? num : 0)
  68. const reSum = Number(num2 ? num2 : 0)
  69. const costSum = Number(num3 ? num3 : 0)
  70. const paySum = Number(num4 ? num4 : 0)
  71. const sum=_.subtract(_.add(amountSum,reSum),_.add(costSum,paySum))
  72. return Number(sum).toFixed(2)
  73. }
  74. //校验值是否合法
  75. export function numCal(num){
  76. if(isNaN(Number(num))){
  77. return Number(0)
  78. }else{
  79. return Number(num ? num : 0)
  80. }
  81. }