本文介绍如何实现进销存管理系统的财务对账模块,财务对账模块包括供应商对账和客户对账2个菜单页面。供应商和客户对账字段相同,因此可共用一个页面组件类。

1. 配置模块

运行项目,在【系统管理-模块管理】中配置如下模块菜单,配置教程参考之前的教程。

一级模块 二级模块 代码 图标 Url 描述
财务管理 Finance property-safety
客户对账单 CustomerAccount unordered-list /fms/CustomerAccount 查询和维护客户对账单信息。
供应商对账单 SupplierAccount unordered-list /fms/SupplierAccount 查询和维护供应商对账单信息。

2. 实体类

JxcLite项目Entities文件夹下面添加JxAccountHead.csJxAccountList.cs两个实体类文件,实体类代码可以直接复制模块管理中由模型设置生成的代码。文章中只简单描述一下实体类的定义,具体代码参见开源,代码定义如下:

namespace JxcLite.Entities;

/// <summary>
/// 对账单表头信息类。
/// </summary>
public class JxAccountHead : EntityBase { } /// <summary>
/// 对账单表体信息类。
/// </summary>
public class JxAccountList : EntityBase { }

3. 建表脚本

打开JxcLite.Web项目Resources文件夹下的Tables.sql资源文件,复制粘贴由【模块管理-模型设置】中生成的建表脚本。文章中只简单描述一下建表脚本,具体脚本参见开源,内容如下:

CREATE TABLE [JxAccountHead] (
[Id] varchar(50) NOT NULL PRIMARY KEY,
...
[Files] nvarchar(500) NULL
); CREATE TABLE [JxAccountList] (
[Id] varchar(50) NOT NULL PRIMARY KEY,
...
[BillId] varchar(50) NOT NULL
);

4. 服务接口

JxcLite项目Services文件夹下面添加财务管理模块服务接口,文件名定义为IFinanceService.cs,该接口定义前后端交互的Api访问方法,包括分页查询、批量删除实体、保存实体。具体方法定义如下:

namespace JxcLite.Services;

public interface IFinanceService : IService
{
//分页查询客户或供应商对账单,通过查询条件Type字段筛选
Task<PagingResult<JxAccountHead>> QueryAccountsAsync(PagingCriteria criteria);
//根据账单类型获取默认对账单信息
Task<JxAccountHead> GetDefaultAccountAsync(string type);
//批量删除对账单表头及表体信息
Task<Result> DeleteAccountsAsync(List<JxAccountHead> models);
//保存对账单表头信息
Task<Result> SaveAccountAsync(UploadInfo<JxAccountHead> info);
}

5. 服务实现

JxcLite.Web项目Services文件夹下面添加财务管理模块服务接口的实现类,文件名定义为FinanceService.cs,文章中只简单描述一下实现类的定义和继承,具体实现参见开源,定义如下:

namespace JxcLite.Web.Services;

class FinanceService(Context context) : ServiceBase(context), IFinanceService
{
public Task<PagingResult<JxAccountHead>> QueryAccountsAsync(PagingCriteria criteria) { }
public Task<JxAccountHead> GetDefaultAccountAsync(string type) { }
public Task<Result> DeleteAccountsAsync(List<JxAccountHead> models) { }
public Task<Result> SaveAccountAsync(UploadInfo<JxAccountHead> info) { }
}

双击打开JxcLite.Web项目中的AppWeb.cs文件,在AddJxcLiteCore方法中注册服务类,前端组件可以通过依赖注入工厂创建服务的实例。代码如下:

public static class AppWeb
{
public static void AddJxcLiteCore(this IServiceCollection services)
{
services.AddScoped<IFinanceService, FinanceService>();
}
}

6. 数据依赖

JxcLite.Web项目Repositories文件夹下面添加财务管理模块数据依赖类,文件名定义为FinanceRepository.cs,文章中只简单描述一下依赖类的定义,具体实现参见开源,定义如下:

namespace JxcLite.Web.Repositories;

class FinanceRepository
{
internal static Task<PagingResult<JxAccountHead>> QueryAccountsAsync(Database db, PagingCriteria criteria) { }
internal static Task<List<JxBillList>> GetBillListsAsync(Database db, string headId) { }
//根据前缀获取最大业务单号
internal static Task<string> GetMaxAccountNoAsync(Database db, string prefix) { }
internal static Task DeleteAccountListsAsync(Database db, string headId) { }
internal static Task DeleteAccountListAsync(Database db, string headId, string billId) { }
}

7. 列表页面

JxcLite.Client项目Pages\Finance文件夹下面添加AccountList.cs单据列表组件,该组件是客户和供应商对账单的列表组件共用类,具体实现参见开源,部分代码如下:

namespace JxcLite.Client.Pages.Finance;

public class AccountList : BaseTablePage<JxAccountHead>
{
private IFinanceService Service;
//取得对账类型(客户、供应商),由具体对账单页面重写该类型
protected virtual string Type { get; } protected override async Task OnPageInitAsync()
{
await base.OnPageInitAsync();
Service = await CreateServiceAsync<IFinanceService>();//创建服务
Table.FormType = typeof(AccountForm);//自定义表单类型
Table.OnQuery = QueryAccountsAsync; //查询方法
//下面是设置列表栏位显示的模板
Table.Column(c => c.Status).Template((b, r) => b.Tag(r.Status));
Table.Column(c => c.AccountDate).Type(FieldType.Date);
}
//新增
public async void New()
{
var row = await Service.GetDefaultBillAsync(Type);
Table.NewForm(Service.SaveBillAsync, row);
}
//编辑
public void Edit(JxAccountHead row) => Table.EditForm(Service.SaveAccountAsync, row);
//批量删除和删除
public void DeleteM() => Table.DeleteM(Service.DeleteAccountsAsync);
public void Delete(JxAccountHead row) => Table.Delete(Service.DeleteAccountsAsync, row);
//导出
public async void Export() => await ExportDataAsync(); private Task<PagingResult<JxAccountHead>> QueryAccountsAsync(PagingCriteria criteria)
{
//设置对账单类型查询条件
criteria.SetQuery(nameof(JxAccountHead.Type), QueryType.Equal, Type);
return Service.QueryAccountsAsync(criteria);
}
}

8. 表头组件

首先打开JxcLite.Client项目Shared文件夹下面TypeForms.cs文件,添加对账单表头类型表单组件,代码如下:

namespace JxcLite.Client.Shared;

public class AccountHeadTypeForm : AntForm<JxAccountHead> { }

再在JxcLite.Client项目Pages\Finance文件夹下面添加AccountHead.razor文件,具体实现参见开源,部分代码如下:

@inherits BaseForm<JxAccountHead>

<AccountHeadTypeForm Form="Model" ShowAction>
<AntRow>
<DataItem Span="8" Label="对账单号" Required>
<AntInput Disabled @bind-Value="@context.AccountNo" />
</DataItem>
<DataItem Span="8" Label="单证状态">
<KTag Text="@context.Status" />
</DataItem>
<DataItem Span="8" Label="对账日期" Required>
<AntDatePicker @bind-Value="@context.AccountDate" />
</DataItem>
</AntRow>
<AntRow>
<DataItem Span="8" Label="商业伙伴" Required>
<PartnerPicker Value="@context.Partner" AllowClear Type="@context.Type"
ValueChanged="e=>context.Partner=e[0].Name" />
</DataItem>
<DataItem Span="8" Label="业务日期" Required>
<AntRangePicker @bind-RangeValue="@context.BizDates" />
</DataItem>
<DataItem Span="8" Label="总金额">
<AntDecimal @bind-Value="@context.TotalAmount" /> 元
</DataItem>
</AntRow>
<AntRow>
<DataItem Span="8" Label="合同号">
<AntInput @bind-Value="@context.ContractNo" />
</DataItem>
<DataItem Span="8" Label="发票号">
<AntInput @bind-Value="@context.InvoiceNo" />
</DataItem>
</AntRow>
<AntRow>
<DataItem Span="24" Label="备注">
<AntTextArea @bind-Value="@context.Note" />
</DataItem>
</AntRow>
<AntRow>
<DataItem Span="24" Label="附件">
<KUpload @ref="upload" ReadOnly="Model.IsView" Value="@context.Files"
OpenFile IsButton="!Model.Data.IsNew" OnFilesChanged="OnFilesChanged" />
</DataItem>
</AntRow>
</AccountHeadTypeForm> @code {
private KUpload upload; private async void OnFilesChanged(List<FileDataInfo> files)
{
if (Model.Data.IsNew)
{
Model.Files[nameof(JxAccountHead.Files)] = files;
}
else
{
Model.Files[nameof(JxAccountHead.Files)] = files;
await Model.SaveAsync(d => upload.SetValue(d.Files), false);
}
}
}

9. 业务单表格组件

再在JxcLite.Client项目Shared文件夹下面添加BillHeadTable.cs文件,该组件为对账单明细列表,具体实现参见开源,部分代码如下:

namespace JxcLite.Client.Shared;

public class BillHeadTable : BaseTable<JxBillHead>
{
private IBillService Service; [Parameter] public JxAccountHead Account { get; set; } protected override async Task OnInitAsync()
{
await base.OnInitAsync();
Service = await CreateServiceAsync<IBillService>();
Table.ShowPager = true;
Table.OnQuery = QueryBillsAsync;
if (!ReadOnly)
{
Table.Toolbar.AddAction(nameof(New));
Table.Toolbar.AddAction(nameof(DeleteM));
Table.SelectType = TableSelectType.Checkbox;
}
Table.AddColumn(c => c.BillNo, true).Width(100);
Table.AddColumn(c => c.Status).Width(100).Template((b, r) => b.Tag(r.Status));
Table.AddColumn(c => c.BillDate).Width(100).Type(FieldType.Date);
Table.AddColumn(c => c.Partner).Width(150);
Table.AddColumn(c => c.ContractNo).Width(100);
Table.AddColumn(c => c.InvoiceNo).Width(100);
Table.AddColumn(c => c.TotalAmount).Width(100).Sum();
Table.AddColumn(c => c.Note).Width(200);
if (!ReadOnly)
{
Table.AddAction(nameof(Delete));
}
} public void New() { }
public void DeleteM() { }
public void Edit(JxBillHead row) { }
public void Delete(JxBillHead row) { } private Task<PagingResult<JxBillHead>> QueryBillsAsync(PagingCriteria criteria)
{
criteria.Parameters[nameof(BillQueryType)] = BillQueryType.Account;
criteria.SetQuery("BizId", QueryType.Equal, Account.Id);
return Service.QueryBillsAsync(criteria);
}
}

10. 表单组件

再在JxcLite.Client项目Pages\Finance文件夹下面添加AccountForm.cs文件,该组件为对账单弹窗表单组件,分表头信息和对账明细两个标签,代码如下:

namespace JxcLite.Client.Pages.Finance;

class AccountForm : BaseTabForm
{
[Parameter] public FormModel<JxAccountHead> Model { get; set; } protected override async Task OnInitFormAsync()
{
await base.OnInitFormAsync();
Tab.AddTab("表头信息", BuildHead);
Tab.AddTab("对账明细", BuildList);
Tab.Right = b => b.Tag(Model.Data.Status);
} private void BuildHead(RenderTreeBuilder builder)
{
builder.Component<AccountHead>().Set(c => c.Model, Model).Build();
} private void BuildList(RenderTreeBuilder builder)
{
builder.Component<BillHeadTable>()
.Set(c => c.ReadOnly, Model.IsView)
.Set(c => c.Account, Model.Data)
.Build();
}
}

Known框架实战演练——进销存财务管理的更多相关文章

  1. 文献综述十八:基于SSH框架的进销存管理系统设计与实现

    一.基本信息 标题:基于SSH框架的进销存管理系统设计与实现 时间:2017 出版源:内蒙古科技与经济 文件分类:对框架的研究 二.研究背景 进销存管理系统在各企业中广泛应用,使用SSH框架,很大程度 ...

  2. Net通用进销存管理系统 + 开发文档+ 使用说明

    通用进销存管理系统 + 开发文档+ 使用说明Net源码下载 包括下面的模块基础资料模块采购管理模块库存管理模块商务管理模块营业管理模块维修管理模块会员管理模块财务管理模块 Net通用进销存管理系统 + ...

  3. 【Mac进销存管理软件】Daily Sales Pro Mac

        [简介] Daily Sales Mac版是Mac平台上的一款进销存软件,库存管理系统.Daily Sales Mac版是一款易于使用的进出库存管理软件,让您及时了解库存状况.销售收入.采购成 ...

  4. 文献综述十五:基于b/s中小型超市进销存管理系统的研究与设计

    一.基本信息 标题:基于b/s中小型超市进销存管理系统的研究与设计 时间:2015 出版源:湘西财经大学 文件分类:对超市管理系统的研究 二.研究背景 在竞争日益激烈的行业中,尽可能降低运营成本,逐步 ...

  5. 文献综述十四:基于Oracle11g的超市进销存管理系统设计与实现

    一.基本信息 标题:基于Oracle11g的超市进销存管理系统设计与实现 时间:2016 出版源:技术创新 文件分类:对数据库的研究 二.研究背景 为超市设计开发的超市管理系统,采用的是 VC+ Or ...

  6. spring boot的一个小项目小型进销存系统

    项目所需的依赖: <dependency> <groupId>org.springframework.boot</groupId> <artifactId&g ...

  7. C# WINFORM进销存系统开发(内涵免费源码+部分实操视频讲解)

    互联网的时代,电商火爆,大家都开始进行线上销售货品,那你是如何管理你的商品库存和进销问题?软积木--小敏用的是C# WINFORM进销存系统来管理我的数据,给我带来了很多便利. 它是高频需求项目,很多 ...

  8. 管家婆软件工贸版(标准财务+进销存+生产管理)V18.0功能简介

    管家婆软件工贸版(标准财务+进销存+生产管理)V18.0功能简介 管家婆 工贸版(标准财务+进销存+生产管理) 1.整体介绍 管家婆工贸版系列软件是针对国内中小型生产加工企业,将ERP管理思想与几十万 ...

  9. 浩瀚技术团队... 安卓智能POS移动PDA开单器 开单器 进销存系统 进销存系统

    浩瀚技术团队... 智能POS移动PDA开单器 开单器 进销存系统 进销存系统 点餐 会员管理 会员管理 深度解读 手机APP移动办公到底是什么? 快速打单POS·不仅仅是快那么简单!  

  10. 寒冬之下,浩瀚智能开单收银打印扫描POS为何能在批发零售门店商场 车销行业 风靡!:进销存+打印扫描POS机

    是一款适用于商超.餐饮.服装鞋帽.家电专营等等具有零售行业特点的企业,供企业管理人员用于管理.监控本品牌的市场占有率.门店覆盖区域.网点分布合理性等经济地理信息的工具平台. 1,功能一:业务抄单文章来 ...

随机推荐

  1. Linux权限与组

    rwx r-xr r-x root root r:读 (read) 4 w:写(write) 2 x:执行(execute) ``1 - 没有权限 0 权限 的前三位 rwx 属主权限位(用户权限) ...

  2. 7.22考试总结(NOIP模拟23)[联·赛·题]

    不拼尽全力去试一下,又怎么会知道啊 前言 又是被细节问题搞掉的一天. T1 的话,与正解相差无几,少打了两个 else 一个 ls 打成了 rs,然后就爆零了(本来还有 45pts 的),然后加了一个 ...

  3. js 实现简易时钟效果

    大江东去,浪淘尽,千古风流人物.故垒西边,人道是,三国周郎赤壁.乱石穿空,惊涛拍岸,卷起千堆雪.江山如画,一时多少豪杰.遥想公瑾当年,小乔初嫁了,雄姿英发.羽扇纶巾,谈笑间,樯橹灰飞烟灭.故国神游,多 ...

  4. WEB攻防-代码特性

    WEB攻防-代码特性 目录 WEB攻防-代码特性 ASP 如何判断网站搭建是否是asp ASP常见的搭配组合 ASP语言的漏洞点(从哪一方面入手) ASP-数据库-MDB下载 ASP-数据库-ASP后 ...

  5. 喜讯!极限科技再次中标中国移动云 Elasticsearch 自研版技术开发服务项目!

    喜讯!极限科技 再次中标 中国移动云 Elasticsearch 自研版技术开发服务项目! 近日,极限科技再次成功中标中国移动苏州研发中心 <云能力中心 2023-2024 年移动云 Elast ...

  6. NLP与深度学习(三)Seq2Seq模型与Attention机制

    1.   Attention与Transformer模型 Attention机制与Transformer模型,以及基于Transformer模型的预训练模型BERT的出现,对NLP领域产生了变革性提升 ...

  7. 移植 uCos-III 3.03 到 STM32F429 上

    背景 通过STM32 的学习,我们可以往更深层次的地方走,尝试系统上的一些开发. STM32: F429(StdPeriph) uCos-III : v3.04 + 3.03 有关说明: 在移植 3. ...

  8. Java 把多个音频拼接成一个

    在Java中,将多个音频文件拼接成一个通常需要使用一些专门的音频处理库,因为Java标准库并不直接支持音频文件的合并.一个常用的库是JAVE2(Java Audio Video Encoder)或JL ...

  9. ONNX Runtime入门示例:在C#中使用ResNet50v2进行图像识别

    ONNX Runtime简介 ONNX Runtime 是一个跨平台的推理和训练机器学习加速器.ONNX 运行时推理可以实现更快的客户体验和更低的成本,支持来自深度学习框架(如 PyTorch 和 T ...

  10. PromQL全方位解读:监控与性能分析的关键技术

    本文全面探索PromQL,从基础语法到高级操作,详细介绍了数据聚合.时间序列分析及内置函数应用,旨在提升用户构建复杂监控策略和性能分析的能力. 关注[TechLeadCloud],分享互联网架构.云服 ...