NopCommerce 增加 Customer Field
预期效果:
Customer表新增一个Column
该新增字段可以在Admin段 新增 修改 列表查询及显示
示例步骤:
0.数据库表修改
alter table [Customer] add MemberType nvarchar(2) ;
1.Entity处理
Libraries\Nop.Core\Domain\Customers\Customer.cs
仿照 Username 新增
/// <summary>
/// Gets or sets the Member Type
/// </summary>
public string MemberType { get; set; }
2.EntityMap处理
Libraries\Nop.Data\Mapping\Customers\CustomerMap.cs
新增
this.Property(u => u.MemberType).HasMaxLength(2);
3.EntityModel处理
Presentation\Nop.Web\Administration\Models\Customers\CustomerModel.cs
仿照 GenderEnabled 及 Gender 新增
//可以不增加MemberTypeEnabled
//如需该设置的控制 可 NopCommerce 增加 Customer Settings
public bool MemberTypeEnabled { get; set; }
[NopResourceDisplayName("Admin.Customers.Customers.Fields.MemberType")]
[AllowHtml]
public string MemberType { get; set; }
4.增修页面
Presentation\Nop.Web\Administration\Views\Customer\_CreateOrUpdate.cshtml
仿照 @if (Model.CompanyEnabled) 新增
@if (Model.MemberTypeEnabled)
{
<div class="form-group">
<div class="col-md-3">
@Html.NopLabelFor(model => model.MemberType)
</div>
<div class="col-md-9">
@Html.NopEditorFor(model => model.MemberType)
@Html.ValidationMessageFor(model => model.MemberType)
</div>
</div>
}
5.新增操作
Presentation\Nop.Web\Administration\Controllers\CustomerController.cs
进入页面时 Model准备
修改 protected virtual void PrepareCustomerModel 的Action
新增 model.MemberTypeEnabled = _customerSettings.MemberTypeEnabled;
新增操作保存时 Post处理
修改 public ActionResult Create(CustomerModel model, bool continueEditing, FormCollection form)
的 var customer = new Customer
新增 MemberType = model.MemberType,
6.修改操作
Presentation\Nop.Web\Administration\Controllers\CustomerController.cs
进入页面时 Model准备
修改 protected virtual void PrepareCustomerModel 的Action
if (customer != null) 分支下
新增 model.MemberType = customer.MemberType;
修改操作保存时 Post处理
修改 public ActionResult Edit(CustomerModel model, bool continueEditing, FormCollection form)
仿照 username 新增
//MemberType
if (_customerSettings.MemberTypeEnabled )
{
customer.MemberType = model.MemberType;
}
7.列表页面 列表显示
Presentation\Nop.Web\Administration\Models\Customers\CustomerListModel.cs
仿照 ZipPostalCodeEnabled 新增
public bool MemberTypeEnabled { get; set; }
列表显示
Presentation\Nop.Web\Administration\Views\Customer\List.cshtml
$("#customers-grid").kendoGrid
仿照 @if (Model.CompanyEnabled) 新增
@if (Model.MemberTypeEnabled)
{
<text>{
field: "MemberType",
title: "@T("Admin.Customers.Customers.Fields.MemberType")",
width: 200
},</text>
}
其 $("#customers-grid").kendoGrid 的 url: "@Html.Raw(Url.Action("CustomerList", "Customer"))",
Presentation\Nop.Web\Administration\Controllers\CustomerController.cs
对应的 protected virtual CustomerModel PrepareCustomerModelForList(Customer customer)
return new CustomerModel 增加 MemberType = customer.MemberType,
8.列表页面 新增查询条件
1).Model处理
Presentation\Nop.Web\Administration\Models\Customers\CustomerListModel.cs
仿照 SearchZipPostalCode 新增
[NopResourceDisplayName("Admin.Customers.Customers.List.SearchMemberType")]
[AllowHtml]
public string SearchMemberType { get; set; }
2).Service处理
Libraries\Nop.Services\Customers\ICustomerService.cs
IPagedList<Customer> GetAllCustomers
增加查询参数 string memberType=null,
Libraries\Nop.Services\Customers\CustomerService.cs
public virtual IPagedList<Customer> GetAllCustomers
增加查询参数 string memberType=null,
及仿照 username 增加其Linq过滤
if (!String.IsNullOrWhiteSpace(memberType))
query = query.Where(c => c.MemberType.Contains(memberType));
3).Controller Action 处理
Presentation\Nop.Web\Administration\Controllers\CustomerController.cs
public ActionResult CustomerList(
var customers = _customerService.GetAllCustomers( 中 新增
memberType:model.SearchMemberType,
4).页面处理
Presentation\Nop.Web\Administration\Views\Customer\List.cshtml
仿照 @if (Model.ZipPostalCodeEnabled) 新增
@if (Model.MemberTypeEnabled )
{
<div class="form-group">
<div class="col-md-4">
@Html.NopLabelFor(model => model.SearchMemberType)
</div>
<div class="col-md-8">
@Html.NopEditorFor(model => model.SearchMemberType)
</div>
</div>
}
js查找及新增SearchMemberType
$("".concat("#@Html.FieldIdFor(model => model.SearchEmail),",
"#@Html.FieldIdFor(model => model.SearchUsername),",
"#@Html.FieldIdFor(model => model.SearchMemberType),",
js查找及新增SearchMemberType
function additionalData() {
var data = {
SearchCustomerRoleIds: $('#@Html.FieldIdFor(model => model.SearchCustomerRoleIds)').val(),
SearchEmail: $('#@Html.FieldIdFor(model => model.SearchEmail)').val(),
SearchMemberType: $('#@Html.FieldIdFor(model => model.SearchMemberType)').val(),
9.增加文本资源
运行站点
Admin -> Configuration -> Languages -> Edit
-> String resources -> Add new record
Admin.Customers.Customers.Fields.MemberType
Admin.Customers.Customers.List.SearchMemberType
10.解决方案 Clean 和 Rebuild
运行站点 查看效果
NopCommerce 增加 Customer Field的更多相关文章
- NopCommerce 增加 Customer Settings
预期: 仿照Customer 的 Phone number enabled 和 required 增加MemberType 相关步骤如下: 1.运行站点 Admin -> Settings -& ...
- NopCommerce 增加 Customer Attributes
预期: Customer 新增一个自定义属性 运行站点 1.Admin -> Settings -> Customer settings -> Customer form field ...
- 如何为Rails作贡献:例增加rich_text field generators
如何为Rails作贡献 例增加rich_text field generators 下载https://github.com/rails/rails 打开atom,在 rails/railties/l ...
- [转]教你一招 - 如何给nopcommerce增加新闻类别模块
本文转自:http://www.nopchina.net/post/nopchina-teach-newscategory.html nopcommerce的新闻模块一直都没有新闻类别,但是很多情况下 ...
- [转]教你一招 - 如何给nopcommerce增加一个类似admin的area
本文转自:http://www.cnblogs.com/wucf2004/p/nopcommerce-area.html asp.net mvc里面的area是什么,点击这里查看 如果在nopcomm ...
- NopCommerce 关于Customer的会员类别及会员价处理 的尝试途径
示例效果: 当Customer是某个会员级别或内部员工时, 购物结算时享受一定的折扣: 相关设定如下: Step1.新增会员类别 Admin - Customers - Customer rol ...
- 教你一招 - 如何给nopcommerce增加一个类似admin的area
asp.net mvc里面的area是什么,点击这里查看 如果在nopcommerce里面加入类似admin的area,步骤如下: 1.新建一个mvc空项目MvcApplication1,位置放在\N ...
- openerp 经典收藏 Openerp开发进销存系统完毕总结(转载)
原文地址:http://blog.csdn.net/heartrude/article/details/9142463 Openerp开发进销存系统完毕总结 分类: 代码历程 OpenERP 工程思想 ...
- mysql中的sql
变量 用户变量: 在用户变量前加@ 系统变量: 在系统变量前加@@ 运算符 算术运算符有: +(加), -(减), * (乘), / (除) 和% (求模) 五中运算 位运算符有: & (位于 ...
随机推荐
- C#使用Log4Net记录日志
当你在开发程序的时候, 调试(debugging)和日志(logging)都是非常重要的工作.在应用中使用日志主要有三个目的 l 监视代码中的变量的变化情况,把数据周期性地记录到文件中供其它应用进行 ...
- jQuery实现AJAX定时刷新局部页面实例
本篇文章通过两种方法实例讲解ajax定时刷新局部页面,当然方法有很多种,也可以不使用ajax来刷新页面,可以使用jquery中的append来给指定内容加东西,但是都不太实用,最实用的方法还是ajax ...
- 设置Textview最大长度,超出显示省略号
<TextView android:id="@+id/tvUserNameUgcListItem" android:layout_height="@dimen/dp ...
- [WCF编程]8.服务实例的生命周期
一.服务实例的生命周期概览 我们已经直到,通过显式调用Close方法或等待默认的超时时间到来,都可以释放服务实例.但是,在会话连接里,经常需要按一定顺序调用方法. 二.分步操作 会话契约的操作有时隐含 ...
- html中<radio>单选按钮控件标签用法解析及如何设置默认选中
<input type="radio" name="radio" value="1">单选1 <input type=&q ...
- php中防止SQL注入的方法
[一.在服务器端配置] 安全,PHP代码编写是一方面,PHP的配置更是非常关键. 我们php手手工安装的,php的默认配置文件在 /usr/local/apache2/conf/php.ini,我们最 ...
- js自建方法库(持续更新)
1.得到一个数,在一个有序数组中应该排在的位置序号: function orderInArr(num,arr) { if(num > arr[0]){ return 1 + arguments. ...
- Android 6.0 权限管理最佳实践
博客: Android 6.0 运行时权限管理最佳实践 github: https://github.com/yanzhenjie/AndPermission
- Android Support Library介绍
v4 Support Library 这个库是为Android 1.6(API版本为4)及以上的版本设计的,它包含大部分高版本中有而低版本中没有的API,包括application component ...
- React Native知识2-Text组件
Text用于显示文本的React组件,并且它也支持嵌套.样式,以及触摸处理.在下面的例子里,嵌套的标题和正文文字会继承来自styles.baseText的fontFamily字体样式,不过标题上还附加 ...