#region Apache License Version 2.0
/*----------------------------------------------------------------
Copyright 2019 Jeffrey Su & Suzhou Senparc Network Technology Co.,Ltd.
Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file
except in compliance with the License. You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software distributed under the
License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND,
either express or implied. See the License for the specific language governing permissions
and limitations under the License.
Detail: https://github.com/JeffreySu/WeiXinMPSDK/blob/master/license.md
----------------------------------------------------------------*/
#endregion Apache License Version 2.0
/*----------------------------------------------------------------
Copyright (C) 2019 Senparc
文件名:CardCreateData.cs
文件功能描述:所有类型的卡券数据
创建标识:Senparc - 20150211
修改标识:Senparc - 20150303
修改描述:整理接口
修改标识:Senparc - 20150323
修改描述:添加会议门票类型
修改标识:hello2008zj - 20160502
修改描述:v13.7.8 添加 Card_MemberCardData.background_pic_url
修改标识:Senparc - 20170528
修改描述:v14.4.10 修改Card_CashData属性类型(int)
修改标识:Senparc - 20170711
修改描述:v14.5.2 Card_MemberCardData添加wx_activate_after_submit和wx_activate_after_submit_url
修改标识:Senparc - 20171117
修改描述:v14.8.6 修改Card_MemberCardData.wx_activate_after_submit_url为string类型
----------------------------------------------------------------*/
using Senparc.CO2NET.Helpers.Serializers;
using Senparc.Weixin.Entities;
using Senparc.Weixin.Helpers;
namespace Senparc.Weixin.MP.AdvancedAPIs.Card
{
/* 所有类型的卡券数据 */
///
/// 通用券数据
///
public class Card_GeneralCouponData : BaseCardInfo
{
///
/// 描述文本
/// 必填
///
public string default_detail { get; set; }
public Card_GeneralCouponData()
: base(CardType.GENERAL_COUPON)
{
}
}
///
/// 团购券数据
///
public class Card_GrouponData : BaseCardInfo
{
///
/// 团购券专用,团购详情
/// 必填
///
public string deal_detail { get; set; }
public Card_GrouponData()
: base(CardType.GROUPON)
{
}
}
///
/// 礼品券数据
///
public class Card_GiftData : BaseCardInfo
{
///
/// 礼品券专用,表示礼品名字
/// 必填
///
public string gift { get; set; }
public Card_GiftData()
: base(CardType.GIFT)
{
}
}
///
/// 代金券数据
///
public class Card_CashData : BaseCardInfo
{
///
/// 代金券专用,表示起用金额(单位为分)
/// 非必填
///
public int least_cost { get; set; }
///
/// 代金券专用,表示减免金额(单位为分)
/// 必填
///
public int reduce_cost { get; set; }
public Card_CashData()
: base(CardType.CASH)
{
}
}
///
/// 折扣券数据
///
public class Card_DisCountData : BaseCardInfo
{
///
///折扣券专用,表示打折额度(百分比)。填30 就是七折。
/// 必填
///
public float discount { get; set; }
public Card_DisCountData()
: base(CardType.DISCOUNT)
{
}
}
///
/// 会员卡数据
///
public class Card_MemberCardData : BaseCardInfo
{
///
/// 是否支持积分,填写true 或false,如填写true,积分相关字段均为必填。
/// 必填
///
public bool supply_bonus { get; set; }
///
/// 是否支持储值,填写true 或false。
/// 必填
///
public bool supply_balance { get; set; }
///
/// 设置为true时用户领取会员卡后系统自动将其激活,无需调用激活接口。
/// 非必填
///
[JsonSetting.IgnoreValueAttribute(false)]
public bool auto_activate { get; set; }
///
/// 设置为true时会员卡支持一键激活,不允许同时传入activate_url字段,否则设置wx_activate失效。
/// 非必填
///
[JsonSetting.IgnoreValueAttribute(false)]
public bool wx_activate { get; set; }
///
/// 积分清零规则
/// 非必填
///
public string bonus_cleared { get; set; }
///
/// 积分规则
/// 非必填
///
public string bonus_rules { get; set; }
///
/// 储值说明
/// 非必填
///
public string balance_rules { get; set; }
///
/// 特权说明
/// 必填
///
public string prerogative { get; set; }
///
/// 绑定旧卡的url,与“activate_url”字段二选一必填。
///
public string bind_old_card_url { get; set; }
///
/// 激活会员卡的url,与“bind_old_card_url”字段二选一必填。
///
public string activate_url { get; set; }
///
/// 设置跳转外链查看积分详情。仅适用于积分无法通过激活接口同步的情况下使用该字段。
/// 非必填
///
public string bonus_url { get; set; }
///
/// 积分信息类目对应的小程序 user_name,格式为原始id+@app 小程序原始id可以在小程序的设置页面底部查看到
///
public string bonus_app_brand_user_name { get; set; }
///
/// 积分入口小程序的页面路径
///
public string bonus_app_brand_pass { get; set; }
///
/// 设置跳转外链查看余额详情。仅适用于余额无法通过激活接口同步的情况下使用该字段。
/// 非必填
///
public string balance_url { get; set; }
///
/// 余额信息类目对应的小程序 user_name,格式为原始id+@app 小程序原始id可以在小程序的设置页面底部查看到
///
public string balance_app_brand_user_name { get; set; }
///
/// 余额入口小程序的页面路径
///
public string balance_app_brand_pass { get; set; }
///
/// 自定义会员信息类目,会员卡激活后显示。
/// 非必填
///
public CustomField custom_field1 { get; set; }
///
/// 自定义会员信息类目,会员卡激活后显示。
/// 非必填
///
public CustomField custom_field2 { get; set; }
///
/// 自定义会员信息类目,会员卡激活后显示。
/// 非必填
///
public CustomField custom_field3 { get; set; }
///
/// 自定义会员信息类目,会员卡激活后显示
/// 非必填
///
public CustomCell custom_cell1 { get; set; }
///
/// 会员卡背景图片,非必填
///
public string background_pic_url { get; set; }
//以下增加
///
/// 积分规则结构体
///
public BonusRule bonus_rule { get; set; }
///
/// 折扣
///
[JsonSetting.IgnoreValueAttribute(0)]
public int discount { get; set; }
//[JsonSetting.IgnoreValue()]
///
/// 是否支持跳转型一键激活,填true或lse
///
public bool? wx_activate_after_submit { get; set; }
///
/// 跳转型一键激活跳转的地址链接,请填写http://或者https://开头的链接(官方文档为bool类型:https://mp.weixin.qq.com/wiki?t=resource/res_main&id=mp1451025283)
/// 如果是使用小程序页面激活则不填此字段,填写activate_app_brand_user_name和activate_app_brand_pass字段
///
public string wx_activate_after_submit_url { get; set; }
///
/// 激活会员卡跳转的小程序user_name,格式为小程序原始id+@app 小程序原始id可以在小程序的设置页面底部查看到
///
public string activate_app_brand_user_name { get; set; }
///
/// 激活会员卡跳转的小程序页面路径
///
public string activate_app_brand_pass { get; set; }
public Card_MemberCardData()
: base(CardType.MEMBER_CARD)
{
}
}
public class CustomField /*: IJsonEnumString*/
{
///
/// 会员信息类目名称。FIELD_NAME_TYPE_LEVEL等级;FIELD_NAME_TYPE_COUPON优惠券;FIELD_NAME_TYPE_STAMP印花;FIELD_NAME_TYPE_DISCOUNT折扣;FIELD_NAME_TYPE_ACHIEVEMEN成就;FIELD_NAME_TYPE_MILEAGE里程。
///
[JsonSetting.EnumString]
public MemberCard_CustomField_NameType name_type { get; set; }
///
/// 点击类目跳转外链url
///
public string url { get; set; }
///
/// 自定义入口小程序user_name,格式为原始id+@app 小程序原始id可以在小程序的设置页面底部查看到
///
public string app_brand_user_name { get; set; }
///
/// 自定义入口小程序的页面路径 如:API/cardPage
///
public string app_brand_pass { get; set; }
}
public class CustomCell
{
///
/// 入口名称
/// 必填
///
public string name { get; set; }
///
/// 入口右侧提示语,6个汉字内
/// 必填
///
public string tips { get; set; }
///
/// 入口跳转链接
/// 必填
///
public string url { get; set; }
///
/// 自定义入口小程序user_name,格式为原始id+@app 小程序原始id可以在小程序的设置页面底部查看到
///
public string app_brand_user_name { get; set; }
///
/// 自定义入口小程序的页面路径 如:API/cardPage
///
public string app_brand_pass { get; set; }
}
///
/// 积分规则,新增加
///
public class BonusRule
{
[JsonSetting.IgnoreValueAttribute(0)]
public int cost_money_unit { get; set; }
[JsonSetting.IgnoreValueAttribute(0)]
public int increase_bonus { get; set; }
[JsonSetting.IgnoreValueAttribute(0)]
public int max_increase_bonus { get; set; }
[JsonSetting.IgnoreValueAttribute(0)]
public int init_increase_bonus { get; set; }
[JsonSetting.IgnoreValueAttribute(0)]
public int cost_bonus_unit { get; set; }
[JsonSetting.IgnoreValueAttribute(0)]
public int reduce_money { get; set; }
[JsonSetting.IgnoreValueAttribute(0)]
public int least_money_to_use_bonus { get; set; }
[JsonSetting.IgnoreValueAttribute(0)]
public int max_reduce_bonus { get; set; }
}
///
/// 门票数据
///
public class Card_ScenicTicketData : BaseCardInfo
{
///
/// 票类型,例如平日全票,套票等
/// 非必填
///
public string ticket_class { get; set; }
///
/// 导览图url
/// 非必填
///
public string guide_url { get; set; }
public Card_ScenicTicketData()
: base(CardType.SCENIC_TICKET)
{
}
}
///
/// 电影票数据
///
public class Card_MovieTicketData : BaseCardInfo
{
///
/// 电影票详请
/// 非必填
///
public string detail { get; set; }
public Card_MovieTicketData()
: base(CardType.MOVIE_TICKET)
{
}
}
///
/// 飞机票数据
///
public class Card_BoardingPassData : BaseCardInfo
{
///
/// 起点,上限为18 个汉字
/// 必填
///
public string from { get; set; }
///
/// 终点,上限为18 个汉字
/// 必填
///
public string to { get; set; }
///
/// 航班
/// 必填
///
public string flight { get; set; }
///
/// 起飞时间,上限为17 个汉字
/// 非必填
///
public string departure_time { get; set; }
///
/// 降落时间,上限为17 个汉字
/// 非必填
///
public string landing_time { get; set; }
///
/// 在线值机的链接
/// 非必填
///
public string check_in_url { get; set; }
///
/// 登机口。如发生登机口变更,建议商家实时调用该接口变更
///
public string gate { get; set; }
///
/// 登机时间,只显示“时分”不显示日期,按时间戳格式填写。如发生登机时间变更,建议商家实时调用该接口变更
///
public string boarding_time { get; set; }
///
/// 机型,上限为8 个汉字
/// 非必填
///
public string air_model { get; set; }
public Card_BoardingPassData()
: base(CardType.BOARDING_PASS)
{
}
}
///
/// 红包数据
///
public class Card_LuckyMoneyData : BaseCardInfo
{
public Card_LuckyMoneyData()
: base(CardType.LUCKY_MONEY)
{
}
}
///
/// 会议门票数据
///
public class Card_MeetingTicketData : BaseCardInfo
{
///
/// 会议详情
///
public string meeting_detail { get; set; }
///
/// 会场导览图
///
public string map_url { get; set; }
public Card_MeetingTicketData()
: base(CardType.MEETING_TICKET)
{
}
}
}