addEdit.vue 7.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269
  1. <template>
  2. <el-dialog
  3. v-loading="loading"
  4. :title="'查看毛利率'"
  5. :center="true"
  6. align="left"
  7. top="12vh"
  8. width="600px"
  9. :close-on-click-modal="false"
  10. :visible.sync="showModelThis"
  11. element-loading-text="拼命加载中"
  12. element-loading-spinner="el-icon-loading"
  13. element-loading-background="rgba(0, 0, 0, 0.8)"
  14. @close="showModelThis = false"
  15. >
  16. <el-card style="margin: -20px 0 0 0">
  17. <el-row :gutter="0">
  18. <el-col :span="24">
  19. <el-form
  20. ref="ruleForm"
  21. :model="ruleForm"
  22. status-icon
  23. :size="'small'"
  24. :rules="rulesThis"
  25. label-width="110px"
  26. class="demo-ruleForm"
  27. >
  28. <el-form-item label="分类名称" prop="cat_name">
  29. <el-input
  30. v-model="ruleForm.cat_name"
  31. disabled
  32. placeholder="分类名称"
  33. maxlength="20"
  34. />
  35. </el-form-item>
  36. <el-form-item label="财务核算码" prop="fund_code">
  37. <el-input
  38. v-model="ruleForm.fund_code"
  39. disabled
  40. placeholder="财务核算码"
  41. maxlength="50"
  42. />
  43. </el-form-item>
  44. <el-form-item label="预算→成本" prop="order_rate">
  45. <digital-input
  46. :values="ruleForm.order_rate"
  47. :placeholder="'预算→成本'"
  48. :min="0"
  49. :max="100000000000"
  50. :position="'right'"
  51. :precision="2"
  52. :size="'mini'"
  53. :controls="false"
  54. disabled
  55. :append="'%'"
  56. @reschange="order_rate_change"
  57. />
  58. </el-form-item>
  59. <el-form-item label="成本→售价" prop="sale_rate">
  60. <digital-input
  61. :values="ruleForm.sale_rate"
  62. :placeholder="'成本→售价'"
  63. :min="-100"
  64. :max="100000000000"
  65. :position="'right'"
  66. :precision="2"
  67. :size="'mini'"
  68. disabled
  69. :controls="false"
  70. :append="'%'"
  71. @reschange="sale_rate_change"
  72. />
  73. </el-form-item>
  74. <el-form-item label="最低毛利" prop="lower_rate">
  75. <digital-input
  76. :values="ruleForm.lower_rate"
  77. :placeholder="'最低毛利'"
  78. :min="-100"
  79. :max="100000000000"
  80. :position="'right'"
  81. :precision="2"
  82. :size="'mini'"
  83. :controls="false"
  84. disabled
  85. :append="'%'"
  86. @reschange="lower_rate_change"
  87. />
  88. </el-form-item>
  89. <el-form-item label="单品修改下限" prop="rate">
  90. <digital-input
  91. :values="ruleForm.rate"
  92. :placeholder="'单品修改下限'"
  93. :min="-100"
  94. :max="100000000000"
  95. :position="'right'"
  96. :precision="2"
  97. :size="'mini'"
  98. :controls="false"
  99. disabled
  100. :append="'%'"
  101. @reschange="rate_change"
  102. />
  103. </el-form-item>
  104. </el-form>
  105. </el-col>
  106. </el-row>
  107. </el-card>
  108. </el-dialog>
  109. </template>
  110. <script>
  111. import asyncRequest from "@/apis/service/goodStore/sort";
  112. import resToken from "@/mixins/resToken";
  113. export default {
  114. name: "sort",
  115. props: ["showModel", "id", "sitem"],
  116. mixins: [resToken],
  117. data() {
  118. const validate_order_rate = (rule, value, callback) => {
  119. if (value === "") {
  120. callback(new Error("预算→成本毛利率不能为空!"));
  121. } else {
  122. callback();
  123. }
  124. };
  125. const validate_sale_rate = (rule, value, callback) => {
  126. if (value === "") {
  127. callback(new Error("成本→售价毛利率不能为空!"));
  128. } else {
  129. callback();
  130. }
  131. };
  132. const validate_lower_rate = (rule, value, callback) => {
  133. if (value === "") {
  134. callback(new Error("最低毛利率不能为空!"));
  135. } else {
  136. callback();
  137. }
  138. };
  139. const validate_rate = (rule, value, callback) => {
  140. if (value === "") {
  141. callback(new Error("单品修改下限毛利率不能为空!"));
  142. } else {
  143. callback();
  144. }
  145. };
  146. return {
  147. loading: false,
  148. showModelThis: this.showModel,
  149. ruleForm: {
  150. id: "",
  151. cat_name: "",
  152. order_rate: "0",
  153. sale_rate: "0",
  154. lower_rate: "0",
  155. rate: "0",
  156. },
  157. rulesThis: this.rules,
  158. rules: {
  159. fund_code: "",
  160. order_rate: [
  161. { required: true, validator: validate_order_rate, trigger: "blur" },
  162. ],
  163. sale_rate: [
  164. { required: true, validator: validate_sale_rate, trigger: "blur" },
  165. ],
  166. lower_rate: [
  167. { required: true, validator: validate_lower_rate, trigger: "blur" },
  168. ],
  169. rate: [{ required: true, validator: validate_rate, trigger: "blur" }],
  170. },
  171. };
  172. },
  173. watch: {
  174. showModel: function (val) {
  175. this.showModelThis = val;
  176. if (val) {
  177. this.initForm();
  178. }
  179. },
  180. showModelThis(val) {
  181. if (!val) {
  182. this.$emit("cancel");
  183. }
  184. },
  185. },
  186. methods: {
  187. async initForm() {
  188. this.loading = true;
  189. this.rulesThis = this.rules;
  190. await this.resetForm();
  191. await this.initData();
  192. this.loading = false;
  193. },
  194. async resetForm() {
  195. // 重置
  196. await this.$nextTick(() => {
  197. if (this.$refs.ruleForm) {
  198. this.$refs.ruleForm.resetFields();
  199. this.$refs.ruleForm.clearValidate();
  200. const {
  201. pid,
  202. id,
  203. cat_name,
  204. order_rate,
  205. sale_rate,
  206. lower_rate,
  207. rate,
  208. fund_code,
  209. } = this.sitem;
  210. this.ruleForm = {
  211. pid: pid || "",
  212. id: id || "",
  213. cat_name: cat_name || "",
  214. fund_code: fund_code || "",
  215. order_rate: order_rate || "0",
  216. sale_rate: sale_rate || "0",
  217. lower_rate: lower_rate || "0",
  218. rate: rate || "0",
  219. };
  220. }
  221. });
  222. },
  223. order_rate_change(e) {
  224. this.ruleForm.order_rate = e + "";
  225. this.$refs.ruleForm.validateField("order_rate");
  226. },
  227. sale_rate_change(e) {
  228. this.ruleForm.sale_rate = e + "";
  229. this.$refs.ruleForm.validateField("sale_rate");
  230. },
  231. lower_rate_change(e) {
  232. this.ruleForm.lower_rate = e + "";
  233. this.$refs.ruleForm.validateField("lower_rate");
  234. },
  235. rate_change(e) {
  236. this.ruleForm.rate = e + "";
  237. this.$refs.ruleForm.validateField("rate");
  238. },
  239. async initData() {
  240. const res = await asyncRequest.detail({ id: this.sitem.id });
  241. if (res && res.code === 0 && res.data) {
  242. console.log(res.data);
  243. const { pid, id, cat_name, order_rate, sale_rate, lower_rate, rate } =
  244. res.data;
  245. this.ruleForm = {
  246. pid: pid || "",
  247. id: id || "",
  248. cat_name: cat_name || "",
  249. order_rate: order_rate || "0",
  250. sale_rate: sale_rate || "0",
  251. lower_rate: lower_rate || "0",
  252. rate: rate || "0",
  253. };
  254. } else if (res && res.code >= 100 && res.code <= 104) {
  255. await this.logout();
  256. } else {
  257. this.$message.warning(res.message);
  258. }
  259. },
  260. },
  261. };
  262. </script>
  263. <style lang="scss" scoped>
  264. .sort {
  265. }
  266. </style>