【开源】基于Vue.js的公司货物订单管理系统
文末获取源码,项目编号:
S
082
。
\color{red}{文末获取源码,项目编号:S082。}
文末获取源码,项目编号:S082。
目录
- 一、摘要
- 1.1 项目介绍
- 1.2 项目录屏
- 二、功能模块
- 2.1 客户管理模块
- 2.2 商品维护模块
- 2.3 供应商管理模块
- 2.4 订单管理模块
- 三、系统展示
- 四、核心代码
- 4.1 查询供应商信息
- 4.2 新增商品信息
- 4.3 查询客户信息
- 4.4 新增订单信息
- 4.5 添加跟进子订单
- 五、免责说明
一、摘要
1.1 项目介绍
基于JAVA+Vue+SpringBoot+MySQL的公司货物订单管理系统包含了客户管理模块、商品维护模块、供应商管理模块和订单管理模块,还包含系统自带的用户管理、部门管理、角色管理、菜单管理、日志管理、数据字典管理、文件管理、图表展示等基础模块,公司货物订单管理系统基于角色的访问控制,给公司管理员和订单专员使用,可将权限精确到按钮级别,您可以自定义角色并分配权限,系统适合设计精确的权限约束需求。
1.2 项目录屏
源码下载
二、功能模块
2.1 客户管理模块
公司货物订单管理系统的客户管理模块是该系统中的一个重要组成部分,用于管理和维护与客户相关的信息和数据。在客户管理模块中,可以记录和管理客户的基本信息,如客户名称、联系人、联系方式、地址等。还可以为每个客户设置唯一的客户编号,方便对客户进行标识和检索。可以根据不同的需求或特点,将客户进行分类和标签化管理。例如,可以将客户按行业、地区、重要性等进行分类,方便后续的营销和服务工作。
通过客户管理模块,可以记录和跟进客户的沟通历史、交流内容、需求变更等信息,以便更好地维护和管理客户关系。还可以设置提醒和任务功能,帮助销售人员及时跟进客户需求,提高客户满意度。客户管理模块可以与订单管理模块进行关联,记录客户的订单信息,包括订单数量、金额、交付日期等。通过对订单数据的分析,可以了解客户的购买行为、偏好和趋势,为销售和市场策略提供参考依据。
客户管理模块可以生成各类客户报表和统计分析,如客户增长率、客户活跃度、客户满意度等,帮助企业了解客户群体的整体状况,制定针对性的市场营销策略。通过客户管理模块,企业可以更好地了解和管理客户,提高客户满意度,增加客户粘性,实现销售业绩的提升和持续增长。
2.2 商品维护模块
公司货物订单管理系统的商品维护模块是该系统中的一个重要组成部分,用于管理和维护公司的商品信息。通过商品维护模块,可以录入和维护公司的商品信息。包括商品名称、商品编号、商品分类、规格型号、单位、供应商信息等。通过统一的商品录入界面,可以方便地添加、修改和删除商品信息。商品维护模块支持对商品进行分类管理,将商品按照不同的分类进行组织和管理,如电子产品、服装、食品等。可以设置多级分类,方便用户进行商品检索和筛选。
商品维护模块可以记录和管理商品的价格信息。可以设置不同的价格策略,如售价、进价、促销价等。通过商品价格管理,可以方便地进行价格调整和跟踪。商品维护模块可以记录和管理商品的库存信息。可以实时监控商品的库存数量、库存预警和出入库记录。通过库存管理功能,可以提醒用户及时补充库存,避免库存不足或过剩。
商品维护模块支持上传商品的图片和描述信息。可以为每个商品添加多张图片,展示商品的外观和特点。同时,可以编写商品的详细描述,包括产品特性、用途等。通过商品维护模块,用户可以方便地对商品进行查询和检索,支持根据商品名称、商品编号、分类等进行快速搜索。同时,可以将查询结果导出为 Excel 格式,方便用户进行数据分析和报表生成。商品维护模块的使用可以帮助公司更好地管理和维护商品信息,提高商品管理的效率和准确性,从而提升订单处理的质量和效率。
2.3 供应商管理模块
公司货物订单管理系统的供应商管理模块是该系统中的一个重要组成部分,用于管理和维护与供应商相关的信息和数据。通过供应商管理模块,可以录入和维护公司的供应商信息。包括供应商名称、联系人、联系方式、地址、信用评级、合作时间等。可以方便地添加、修改和删除供应商信息。
供应商分类管理:供应商管理模块支持对供应商进行分类管理,将供应商按照不同的分类进行组织和管理,如原材料供应商、零部件供应商、成品供应商等。可以设置多级分类,方便用户进行供应商检索和筛选。通过供应商管理模块,可以对供应商进行评估和评级。评估指标可以包括供货质量、交货准时性、售后服务等方面。根据评估结果,可以给供应商进行等级评定,以便后续的供应商选择和合作决策。供应商管理模块可以记录和管理与供应商签订的合同信息。包括合同编号、合同有效期、付款方式、交货条款等。可以设置提醒和预警功能,帮助用户及时跟进合同履行情况。
供应商管理模块可以生成各类供应商报表和统计分析,如供应商数量、供应商合作时间、供应商评级分布等。这些报表和统计数据可以为供应链管理提供参考依据,帮助企业进行供应商绩效评估和供应商管理的优化。通过供应商管理模块,企业可以更好地管理和维护供应商信息,提高供应链管理的效率和准确性,确保货物的质量和交付的准时性。同时,供应商管理模块也可以为企业的采购决策提供数据支持,降低采购风险,实现采购成本的最优化。
2.4 订单管理模块
公司货物订单管理系统的订单管理模块是该系统中的一个核心模块,用于管理和处理公司的货物订单。通过订单管理模块,用户可以录入和创建新的订单信息。包括客户信息、商品信息、数量、价格、交货日期等。可以方便地添加、修改和删除订单信息。订单管理模块支持根据不同的条件进行订单查询和筛选,如订单编号、客户名称、订单状态等。同时,可以实时跟踪订单的处理进度,了解订单的当前状态和位置。
订单审批和审核:对于需要审批的订单,订单管理模块可以设置审批流程,设置审批人和审批步骤。审批人可以对订单进行审核和批准,确保订单的合法性和准确性。订单管理模块可以管理和更新订单的状态。包括新建、待处理、已处理、已发货、已完成等状态。通过订单状态管理,可以清楚地了解订单的处理情况,方便进行后续的跟踪和处理。
如果公司有多个仓库或分支机构,订单管理模块可以进行订单的分配和调度。根据订单的要求和仓库的库存情况,将订单分配给合适的仓库进行处理和发货。订单管理模块可以生成各类订单报表和统计分析,如每日订单量、订单金额、订单完成率等。这些报表和统计数据可以帮助企业进行订单管理和销售业绩分析,提供数据支持。
通过订单管理模块,企业可以更好地管理和处理订单信息,提高订单处理的效率和准确性,确保订单的及时交付和客户满意度。同时,订单管理模块也可以提供数据支持,帮助企业进行销售预测和供应链管理,实现业务的优化和增长。
三、系统展示
四、核心代码
4.1 查询供应商信息
@RequestMapping(value = "/getByPage", method = RequestMethod.GET)
@ApiOperation(value = "查询供应商信息")
public Result<IPage<Supplier>> getByPage(@ModelAttribute Supplier supplier ,@ModelAttribute PageVo page){
QueryWrapper<Supplier> qw = new QueryWrapper<>();
if(!ZwzNullUtils.isNull(supplier.getName())) {
qw.like("name",supplier.getName());
}
if(!ZwzNullUtils.isNull(supplier.getAddress())) {
qw.like("address",supplier.getAddress());
}
if(!ZwzNullUtils.isNull(supplier.getMobile())) {
qw.like("mobile",supplier.getMobile());
}
IPage<Supplier> data = iSupplierService.page(PageUtil.initMpPage(page),qw);
return new ResultUtil<IPage<Supplier>>().setData(data);
}
4.2 新增商品信息
@RequestMapping(value = "/insert", method = RequestMethod.POST)
@ApiOperation(value = "新增商品信息")
public Result<Commodity> insert(Commodity commodity){
if(ZwzNullUtils.isNull(commodity.getSupplierId())) {
return ResultUtil.error("供应商不能为空");
}
Supplier supplier = iSupplierService.getById(commodity.getSupplierId());
if(supplier == null) {
return ResultUtil.error("供应商已被删除");
}
commodity.setSupplierName(supplier.getName());
commodity.setCode(IdUtil.getSnowflake(1, 1).nextId() + "");
iCommodityService.saveOrUpdate(commodity);
return new ResultUtil<Commodity>().setData(commodity);
}
4.3 查询客户信息
@RequestMapping(value = "/getByPage", method = RequestMethod.GET)
@ApiOperation(value = "查询客户信息")
public Result<IPage<Customer>> getByPage(@ModelAttribute Customer customer ,@ModelAttribute PageVo page){
QueryWrapper<Customer> qw = new QueryWrapper<>();
if(!ZwzNullUtils.isNull(customer.getName())) {
qw.like("name",customer.getName());
}
if(!ZwzNullUtils.isNull(customer.getMobile())) {
qw.like("mobile",customer.getMobile());
}
if(!ZwzNullUtils.isNull(customer.getIdCard())) {
qw.like("id_card",customer.getIdCard());
}
IPage<Customer> data = iCustomerService.page(PageUtil.initMpPage(page),qw);
return new ResultUtil<IPage<Customer>>().setData(data);
}
4.4 新增订单信息
@RequestMapping(value = "/insert", method = RequestMethod.POST)
@ApiOperation(value = "新增订单信息")
public Result<Order> insert(Order order) {
if(ZwzNullUtils.isNull(order.getCustomerId())) {
return ResultUtil.error("订单客户不能为空");
}
Customer customer = iCustomerService.getById(order.getCustomerId());
if(customer == null) {
return ResultUtil.error("订单客户已被删除");
}
User currUser = securityUtil.getCurrUser();
order.setUserName(currUser.getNickname());
order.setCustomerName(customer.getName());
order.setDate(DateUtil.today());
order.setCode(IdUtil.getSnowflake(1, 1).nextId() + "");
iOrderService.saveOrUpdate(order);
return new ResultUtil<Order>().setData(order);
}
4.5 添加跟进子订单
@RequestMapping(value = "/inOrder", method = RequestMethod.POST)
@ApiOperation(value = "添加跟进子订单")
public Result<Object> inOrder(@RequestParam String orderId,@RequestParam String commodityId,@RequestParam float number){
Order order = iOrderService.getById(orderId);
if(order == null) {
return ResultUtil.error("订单不存在");
}
Commodity commodity = iCommodityService.getById(commodityId);
if(commodity == null) {
return ResultUtil.error("商品不存在");
}
OrderItem item = new OrderItem();
item.setCode(IdUtil.getSnowflake(1, 1).nextId() + "");
item.setCommodityId(commodity.getId());
item.setCommodityName(commodity.getName());
item.setUnit(commodity.getUnit());
item.setMoney(commodity.getMoney());
item.setDiscount(commodity.getDiscount());
item.setNumber(BigDecimal.valueOf(number));
item.setOrderId(orderId);
iOrderItemService.saveOrUpdate(item);
// 计算总订单金额
calOrderSumNumber(order);
return ResultUtil.success();
}
五、免责说明
- 本项目仅供个人学习使用,商用授权请联系博主,否则后果自负。
- 博主拥有本软件构建后的应用系统全部内容所有权及独立的知识产权,拥有最终解释权。
- 如有问题,欢迎在仓库 Issue 留言,看到后会第一时间回复,相关意见会酌情考虑,但没有一定被采纳的承诺或保证。
下载本系统代码或使用本系统的用户,必须同意以下内容,否则请勿下载!
- 出于自愿而使用/开发本软件,了解使用本软件的风险,且同意自己承担使用本软件的风险。
- 利用本软件构建的网站的任何信息内容以及导致的任何版权纠纷和法律争议及后果和博主无关,博主对此不承担任何责任。
- 在任何情况下,对于因使用或无法使用本软件而导致的任何难以合理预估的损失(包括但不仅限于商业利润损失、业务中断与业务信息丢失),博主概不承担任何责任。
- 必须了解使用本软件的风险,博主不承诺提供一对一的技术支持、使用担保,也不承担任何因本软件而产生的难以预料的问题的相关责任。