Merge remote-tracking branch 'origin/0.1' into dapper
# Conflicts: # web/App_Code/Model/Model.Designer.cs # web/App_Code/Model/Model.cs # web/App_Code/Model/Model.edmx # web/web.config
This commit is contained in:
@@ -1,4 +1,4 @@
|
|||||||
//------------------------------------------------------------------------------
|
//------------------------------------------------------------------------------
|
||||||
// <auto-generated>
|
// <auto-generated>
|
||||||
// 這個程式碼是由範本產生。
|
// 這個程式碼是由範本產生。
|
||||||
//
|
//
|
||||||
@@ -187,6 +187,7 @@ namespace Model
|
|||||||
public string pageSize { get; set; }
|
public string pageSize { get; set; }
|
||||||
public string printSize { get; set; }
|
public string printSize { get; set; }
|
||||||
public string defaultStyle { get; set; }
|
public string defaultStyle { get; set; }
|
||||||
|
public Nullable<int> sort_order { get; set; }
|
||||||
|
|
||||||
public virtual actItem_kind actItem_kind { get; set; }
|
public virtual actItem_kind actItem_kind { get; set; }
|
||||||
[System.Diagnostics.CodeAnalysis.SuppressMessage("Microsoft.Usage", "CA2227:CollectionPropertiesShouldBeReadOnly")]
|
[System.Diagnostics.CodeAnalysis.SuppressMessage("Microsoft.Usage", "CA2227:CollectionPropertiesShouldBeReadOnly")]
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
<?xml version="1.0" encoding="utf-8"?>
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
<edmx:Edmx Version="3.0" xmlns:edmx="http://schemas.microsoft.com/ado/2009/11/edmx">
|
<edmx:Edmx Version="3.0" xmlns:edmx="http://schemas.microsoft.com/ado/2009/11/edmx">
|
||||||
<!-- EF Runtime content -->
|
<!-- EF Runtime content -->
|
||||||
<edmx:Runtime>
|
<edmx:Runtime>
|
||||||
@@ -94,6 +94,7 @@
|
|||||||
<Property Name="pageSize" Type="varchar" MaxLength="50" />
|
<Property Name="pageSize" Type="varchar" MaxLength="50" />
|
||||||
<Property Name="printSize" Type="varchar" MaxLength="50" />
|
<Property Name="printSize" Type="varchar" MaxLength="50" />
|
||||||
<Property Name="defaultStyle" Type="varchar" MaxLength="50" />
|
<Property Name="defaultStyle" Type="varchar" MaxLength="50" />
|
||||||
|
<Property Name="sort_order" Type="int" />
|
||||||
</EntityType>
|
</EntityType>
|
||||||
<EntityType Name="actItem_files">
|
<EntityType Name="actItem_files">
|
||||||
<Key>
|
<Key>
|
||||||
@@ -607,8 +608,8 @@
|
|||||||
</Key>
|
</Key>
|
||||||
<Property Name="num" Type="int" StoreGeneratedPattern="Identity" Nullable="false" />
|
<Property Name="num" Type="int" StoreGeneratedPattern="Identity" Nullable="false" />
|
||||||
<Property Name="kind" Type="nvarchar" MaxLength="100" />
|
<Property Name="kind" Type="nvarchar" MaxLength="100" />
|
||||||
<Property Name="starttime" Type="time" Precision="0" />
|
<Property Name="starttime" Type="time" Precision="7" />
|
||||||
<Property Name="offtime" Type="time" Precision="0" />
|
<Property Name="offtime" Type="time" Precision="7" />
|
||||||
<Property Name="resttime" Type="int" />
|
<Property Name="resttime" Type="int" />
|
||||||
<Property Name="root" Type="int" />
|
<Property Name="root" Type="int" />
|
||||||
<Property Name="range" Type="int" />
|
<Property Name="range" Type="int" />
|
||||||
@@ -1083,7 +1084,9 @@
|
|||||||
</ReferentialConstraint>
|
</ReferentialConstraint>
|
||||||
</Association>
|
</Association>
|
||||||
<Association Name="FK_act_bom_actItem1">
|
<Association Name="FK_act_bom_actItem1">
|
||||||
<End Role="actItem" Type="Self.actItem" Multiplicity="0..1" />
|
<End Role="actItem" Type="Self.actItem" Multiplicity="0..1">
|
||||||
|
<OnDelete Action="Cascade" />
|
||||||
|
</End>
|
||||||
<End Role="act_bom" Type="Self.act_bom" Multiplicity="*" />
|
<End Role="act_bom" Type="Self.act_bom" Multiplicity="*" />
|
||||||
<ReferentialConstraint>
|
<ReferentialConstraint>
|
||||||
<Principal Role="actItem">
|
<Principal Role="actItem">
|
||||||
@@ -1203,7 +1206,9 @@
|
|||||||
</ReferentialConstraint>
|
</ReferentialConstraint>
|
||||||
</Association>
|
</Association>
|
||||||
<Association Name="FK_activity_relating_activity">
|
<Association Name="FK_activity_relating_activity">
|
||||||
<End Role="activity" Type="Self.activity" Multiplicity="1" />
|
<End Role="activity" Type="Self.activity" Multiplicity="1">
|
||||||
|
<OnDelete Action="Cascade" />
|
||||||
|
</End>
|
||||||
<End Role="activity_relating" Type="Self.activity_relating" Multiplicity="*" />
|
<End Role="activity_relating" Type="Self.activity_relating" Multiplicity="*" />
|
||||||
<ReferentialConstraint>
|
<ReferentialConstraint>
|
||||||
<Principal Role="activity">
|
<Principal Role="activity">
|
||||||
@@ -1629,7 +1634,9 @@
|
|||||||
</ReferentialConstraint>
|
</ReferentialConstraint>
|
||||||
</Association>
|
</Association>
|
||||||
<Association Name="FK_pro_order_activity">
|
<Association Name="FK_pro_order_activity">
|
||||||
<End Role="activity" Type="Self.activity" Multiplicity="0..1" />
|
<End Role="activity" Type="Self.activity" Multiplicity="0..1">
|
||||||
|
<OnDelete Action="Cascade" />
|
||||||
|
</End>
|
||||||
<End Role="pro_order" Type="Self.pro_order" Multiplicity="*" />
|
<End Role="pro_order" Type="Self.pro_order" Multiplicity="*" />
|
||||||
<ReferentialConstraint>
|
<ReferentialConstraint>
|
||||||
<Principal Role="activity">
|
<Principal Role="activity">
|
||||||
@@ -1679,7 +1686,9 @@
|
|||||||
</ReferentialConstraint>
|
</ReferentialConstraint>
|
||||||
</Association>
|
</Association>
|
||||||
<Association Name="FK_pro_order_detail_pro_order">
|
<Association Name="FK_pro_order_detail_pro_order">
|
||||||
<End Role="pro_order" Type="Self.pro_order" Multiplicity="1" />
|
<End Role="pro_order" Type="Self.pro_order" Multiplicity="1">
|
||||||
|
<OnDelete Action="Cascade" />
|
||||||
|
</End>
|
||||||
<End Role="pro_order_detail" Type="Self.pro_order_detail" Multiplicity="*" />
|
<End Role="pro_order_detail" Type="Self.pro_order_detail" Multiplicity="*" />
|
||||||
<ReferentialConstraint>
|
<ReferentialConstraint>
|
||||||
<Principal Role="pro_order">
|
<Principal Role="pro_order">
|
||||||
@@ -1691,7 +1700,9 @@
|
|||||||
</ReferentialConstraint>
|
</ReferentialConstraint>
|
||||||
</Association>
|
</Association>
|
||||||
<Association Name="FK_pro_order_followers">
|
<Association Name="FK_pro_order_followers">
|
||||||
<End Role="followers" Type="Self.followers" Multiplicity="0..1" />
|
<End Role="followers" Type="Self.followers" Multiplicity="0..1">
|
||||||
|
<OnDelete Action="Cascade" />
|
||||||
|
</End>
|
||||||
<End Role="pro_order" Type="Self.pro_order" Multiplicity="*" />
|
<End Role="pro_order" Type="Self.pro_order" Multiplicity="*" />
|
||||||
<ReferentialConstraint>
|
<ReferentialConstraint>
|
||||||
<Principal Role="followers">
|
<Principal Role="followers">
|
||||||
@@ -3053,8 +3064,8 @@
|
|||||||
</Key>
|
</Key>
|
||||||
<Property Name="num" Type="Int32" Nullable="false" annotation:StoreGeneratedPattern="Identity" />
|
<Property Name="num" Type="Int32" Nullable="false" annotation:StoreGeneratedPattern="Identity" />
|
||||||
<Property Name="kind" Type="String" MaxLength="100" FixedLength="false" Unicode="true" />
|
<Property Name="kind" Type="String" MaxLength="100" FixedLength="false" Unicode="true" />
|
||||||
<Property Name="starttime" Type="Time" Precision="0" />
|
<Property Name="starttime" Type="Time" Precision="7" />
|
||||||
<Property Name="offtime" Type="Time" Precision="0" />
|
<Property Name="offtime" Type="Time" Precision="7" />
|
||||||
<Property Name="resttime" Type="Int32" />
|
<Property Name="resttime" Type="Int32" />
|
||||||
<Property Name="root" Type="Int32" />
|
<Property Name="root" Type="Int32" />
|
||||||
<Property Name="range" Type="Int32" />
|
<Property Name="range" Type="Int32" />
|
||||||
|
|||||||
@@ -9,7 +9,7 @@
|
|||||||
<EntityTypeShape EntityType="Model.accounting_files" Width="1.5" PointX="15.75" PointY="27.75" IsExpanded="true" />
|
<EntityTypeShape EntityType="Model.accounting_files" Width="1.5" PointX="15.75" PointY="27.75" IsExpanded="true" />
|
||||||
<EntityTypeShape EntityType="Model.accounting_kind" Width="1.5" PointX="11.25" PointY="27.625" IsExpanded="true" />
|
<EntityTypeShape EntityType="Model.accounting_kind" Width="1.5" PointX="11.25" PointY="27.625" IsExpanded="true" />
|
||||||
<EntityTypeShape EntityType="Model.accounting_kind2" Width="1.5" PointX="13.5" PointY="11.25" IsExpanded="true" />
|
<EntityTypeShape EntityType="Model.accounting_kind2" Width="1.5" PointX="13.5" PointY="11.25" IsExpanded="true" />
|
||||||
<EntityTypeShape EntityType="Model.actItem" Width="1.5" PointX="9.25" PointY="7.875" IsExpanded="true" />
|
<EntityTypeShape EntityType="Model.actItem" Width="1.5" PointX="8.375" PointY="27.25" IsExpanded="true" />
|
||||||
<EntityTypeShape EntityType="Model.actItem_files" Width="1.5" PointX="16.5" PointY="5.875" IsExpanded="true" />
|
<EntityTypeShape EntityType="Model.actItem_files" Width="1.5" PointX="16.5" PointY="5.875" IsExpanded="true" />
|
||||||
<EntityTypeShape EntityType="Model.actItem_kind" Width="1.5" PointX="6.125" PointY="7.875" IsExpanded="true" />
|
<EntityTypeShape EntityType="Model.actItem_kind" Width="1.5" PointX="6.125" PointY="7.875" IsExpanded="true" />
|
||||||
<EntityTypeShape EntityType="Model.activity" Width="1.5" PointX="3" PointY="8.875" IsExpanded="true" />
|
<EntityTypeShape EntityType="Model.activity" Width="1.5" PointX="3" PointY="8.875" IsExpanded="true" />
|
||||||
|
|||||||
@@ -28,7 +28,7 @@ namespace MyWeb
|
|||||||
public AdmItem info { get; set; }
|
public AdmItem info { get; set; }
|
||||||
|
|
||||||
//定義欄位cookie==================start
|
//定義欄位cookie==================start
|
||||||
public class AdmItem
|
public class AdmItem
|
||||||
{
|
{
|
||||||
public int num { get; set; }
|
public int num { get; set; }
|
||||||
public string u_id { get; set; }
|
public string u_id { get; set; }
|
||||||
|
|||||||
@@ -103,17 +103,18 @@ public class FollowerController : ApiController
|
|||||||
{
|
{
|
||||||
foreach (var item in prod)
|
foreach (var item in prod)
|
||||||
{
|
{
|
||||||
foreach (var item2 in item.pro_order_detail1)
|
//foreach (var item2 in item.pro_order_detail1)
|
||||||
item2.from_id = null; //清空訂單明細的陽上報恩者from_id //f_num設定串聯刪除
|
// item2.from_id = null; //清空訂單明細的陽上報恩者from_id //f_num設定串聯刪除
|
||||||
|
|
||||||
foreach (var item2 in item.pro_order)
|
//foreach (var item2 in item.pro_order)
|
||||||
item2.introducer = null;
|
// item2.introducer = null;
|
||||||
|
|
||||||
item.leader = null;//清空leader
|
//item.leader = null;//清空leader
|
||||||
|
_db.followers.RemoveRange(prod);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
_db.followers.RemoveRange(prod);
|
//_db.followers.RemoveRange(prod);
|
||||||
_db.SaveChanges();
|
_db.SaveChanges();
|
||||||
|
|
||||||
Model.admin_log admin_log = new Model.admin_log();
|
Model.admin_log admin_log = new Model.admin_log();
|
||||||
@@ -150,8 +151,10 @@ public class FollowerController : ApiController
|
|||||||
qry = qry.Where(o => o.u_name.Contains(q.u_name.Trim()));
|
qry = qry.Where(o => o.u_name.Contains(q.u_name.Trim()));
|
||||||
if (q.birthday.HasValue)
|
if (q.birthday.HasValue)
|
||||||
qry = qry.Where(o => o.birthday >= q.birthday.Value);
|
qry = qry.Where(o => o.birthday >= q.birthday.Value);
|
||||||
if (q.birthday2.HasValue)
|
if (q.birthday2.HasValue) {
|
||||||
qry = qry.Where(o => o.birthday < Convert.ToDateTime(q.birthday2.Value).AddDays(1));
|
var tmpBirthday2 = Convert.ToDateTime(q.birthday2.Value).AddDays(1);
|
||||||
|
qry = qry.Where(o => o.birthday < tmpBirthday2);
|
||||||
|
}
|
||||||
if (!string.IsNullOrEmpty(q.address))
|
if (!string.IsNullOrEmpty(q.address))
|
||||||
qry = qry.Where(o => o.address !=null && o.address.Contains(q.address.Trim()));
|
qry = qry.Where(o => o.address !=null && o.address.Contains(q.address.Trim()));
|
||||||
//if (q.num.HasValue && q.num.Value>0)
|
//if (q.num.HasValue && q.num.Value>0)
|
||||||
@@ -655,8 +658,10 @@ public class FollowerController : ApiController
|
|||||||
list = orderrecord.Select(x => new
|
list = orderrecord.Select(x => new
|
||||||
{
|
{
|
||||||
orderno = x.order_no,
|
orderno = x.order_no,
|
||||||
startdate = x.reg_time,
|
//startdate = x.reg_time,
|
||||||
endtime = x.up_time,
|
//endtime = x.up_time,
|
||||||
|
startdate = x.activity.startDate_solar,
|
||||||
|
enddate = x.activity.endDate_solar,
|
||||||
pwcount = x.pro_order_detail.Where(a => a.actItem.act_bom.Where(b => b.item_num == a.actItem_num && b.package_num == null).Count() == 0).Count(),
|
pwcount = x.pro_order_detail.Where(a => a.actItem.act_bom.Where(b => b.item_num == a.actItem_num && b.package_num == null).Count() == 0).Count(),
|
||||||
amount = x.pro_order_detail.Select(o => (float?)o.price).Sum(),
|
amount = x.pro_order_detail.Select(o => (float?)o.price).Sum(),
|
||||||
activityname = x.activity.subject,
|
activityname = x.activity.subject,
|
||||||
|
|||||||
@@ -1,14 +1,18 @@
|
|||||||
using System;
|
using DocumentFormat.OpenXml.Drawing.Spreadsheet;
|
||||||
|
using Model;
|
||||||
|
using Newtonsoft.Json;
|
||||||
|
using Org.BouncyCastle.Crypto;
|
||||||
|
using PagedList;
|
||||||
|
using System;
|
||||||
|
using System.Collections;
|
||||||
using System.Collections.Generic;
|
using System.Collections.Generic;
|
||||||
|
using System.Data.Entity;
|
||||||
using System.Linq;
|
using System.Linq;
|
||||||
using System.Net;
|
using System.Net;
|
||||||
using System.Net.Http;
|
using System.Net.Http;
|
||||||
using System.Web.Http;
|
using System.Web.Http;
|
||||||
using PagedList;
|
using System.Web.Services;
|
||||||
using Newtonsoft.Json;
|
|
||||||
using System.Collections;
|
|
||||||
using static TreeView;
|
using static TreeView;
|
||||||
using System.Data.Entity;
|
|
||||||
|
|
||||||
// api/activity
|
// api/activity
|
||||||
//[ezAuthorize(Roles = "admin")]//群組:*
|
//[ezAuthorize(Roles = "admin")]//群組:*
|
||||||
@@ -126,6 +130,12 @@ public class activityController : ApiController
|
|||||||
if (prod != null)
|
if (prod != null)
|
||||||
{
|
{
|
||||||
////prod.IsDel = true; ////不確定是否新增欄位? 先註解
|
////prod.IsDel = true; ////不確定是否新增欄位? 先註解
|
||||||
|
|
||||||
|
// 先刪除子項目
|
||||||
|
var prod2 = _db.act_bom.Where(q => q.package_num == prod.num).ToList();
|
||||||
|
_db.act_bom.RemoveRange(prod2);
|
||||||
|
|
||||||
|
_db.actItems.Remove(prod);
|
||||||
_db.SaveChanges();
|
_db.SaveChanges();
|
||||||
Model.admin_log admin_log = new Model.admin_log();
|
Model.admin_log admin_log = new Model.admin_log();
|
||||||
MyWeb.admin admin = new MyWeb.admin();//api裡不可以用MyWeb
|
MyWeb.admin admin = new MyWeb.admin();//api裡不可以用MyWeb
|
||||||
@@ -190,12 +200,18 @@ public class activityController : ApiController
|
|||||||
if (prod.Count() > 0)
|
if (prod.Count() > 0)
|
||||||
{
|
{
|
||||||
//var prod2 = _db.actItem_files.AsEnumerable().Where(q => ids.Contains(Convert.ToInt32(q.actItem_num))).ToList();
|
//var prod2 = _db.actItem_files.AsEnumerable().Where(q => ids.Contains(Convert.ToInt32(q.actItem_num))).ToList();
|
||||||
var prod2 = _db.actItem_files.Where(q => ids.Contains(q.actItem_num)).ToList();
|
//var prod2 = _db.actItem_files.Where(q => ids.Contains(q.actItem_num)).ToList();
|
||||||
if (prod2.Count > 0)
|
//if (prod2.Count > 0)
|
||||||
{
|
//{
|
||||||
_db.actItem_files.RemoveRange(prod2);
|
// _db.actItem_files.RemoveRange(prod2);
|
||||||
//_db.SaveChanges();
|
// //_db.SaveChanges();
|
||||||
}
|
//}
|
||||||
|
|
||||||
|
// 先刪除子項目
|
||||||
|
var parentBoms = _db.act_bom.Where(q => q.item_num.HasValue && ids.Contains(q.item_num.Value)).ToList();
|
||||||
|
var parentIds = parentBoms.Select(x => x.num).ToList(); // 取得母件 id
|
||||||
|
var childBoms = _db.act_bom.Where(q => q.package_num.HasValue && parentIds.Contains(q.package_num.Value)).ToList();
|
||||||
|
_db.act_bom.RemoveRange(childBoms);
|
||||||
|
|
||||||
_db.actItems.RemoveRange(prod);
|
_db.actItems.RemoveRange(prod);
|
||||||
_db.SaveChanges();
|
_db.SaveChanges();
|
||||||
@@ -314,6 +330,36 @@ public class activityController : ApiController
|
|||||||
return Ok(ret);
|
return Ok(ret);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public class SortOrderRequest
|
||||||
|
{
|
||||||
|
public List<int> ids { get; set; }
|
||||||
|
}
|
||||||
|
|
||||||
|
[HttpPost]
|
||||||
|
[Route("api/activity/SaveItemList")]
|
||||||
|
public IHttpActionResult UpdateSortOrder([FromBody] SortOrderRequest request)
|
||||||
|
{
|
||||||
|
if (request == null || request.ids == null) return BadRequest();
|
||||||
|
|
||||||
|
using (Model.ezEntities _db = new Model.ezEntities())
|
||||||
|
{
|
||||||
|
int totalCount = request.ids.Count;
|
||||||
|
|
||||||
|
for (int i = 0; i < totalCount; i++)
|
||||||
|
{
|
||||||
|
int id = request.ids[i];
|
||||||
|
var item = _db.actItems.FirstOrDefault(x => x.num == id);
|
||||||
|
if (item != null)
|
||||||
|
{
|
||||||
|
// 改成總數減去索引,這樣第一筆 (i=0) 會拿到最大的數字
|
||||||
|
item.sort_order = totalCount - i;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
_db.SaveChanges();
|
||||||
|
}
|
||||||
|
return Ok();
|
||||||
|
}
|
||||||
|
|
||||||
[HttpPost]
|
[HttpPost]
|
||||||
[Route("api/activity/GetItemList")]
|
[Route("api/activity/GetItemList")]
|
||||||
public IHttpActionResult GetItemList([FromBody] Model.ViewModel.actItem q, int page, int pageSize = 10,
|
public IHttpActionResult GetItemList([FromBody] Model.ViewModel.actItem q, int page, int pageSize = 10,
|
||||||
@@ -418,8 +464,14 @@ public class activityController : ApiController
|
|||||||
else
|
else
|
||||||
qry = qry.OrderBy(o => o.status);
|
qry = qry.OrderBy(o => o.status);
|
||||||
}
|
}
|
||||||
else
|
else if (sortBy.Equals("num"))
|
||||||
|
{
|
||||||
qry = qry.OrderByDescending(o => o.num);
|
qry = qry.OrderByDescending(o => o.num);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
qry = qry.OrderByDescending(o => o.sort_order);
|
||||||
|
}
|
||||||
|
|
||||||
var tdesc = publicFun.enum_desc<Model.activity.category>();
|
var tdesc = publicFun.enum_desc<Model.activity.category>();
|
||||||
var count = qry.Count(); //pageSize = count;//一次取回??
|
var count = qry.Count(); //pageSize = count;//一次取回??
|
||||||
@@ -1303,7 +1355,7 @@ public class activityController : ApiController
|
|||||||
[Route("api/activity/OrderCheckIn")]
|
[Route("api/activity/OrderCheckIn")]
|
||||||
public IHttpActionResult OrderCheckIn([FromBody] Model.activity_check item)
|
public IHttpActionResult OrderCheckIn([FromBody] Model.activity_check item)
|
||||||
{
|
{
|
||||||
if (item.f_num.HasValue && item.activity_num.HasValue && item.qty.HasValue && item.status.HasValue)
|
if (item.f_num.HasValue && item.activity_num.HasValue && item.status.HasValue)
|
||||||
{
|
{
|
||||||
//同一天不能簽到兩次以上
|
//同一天不能簽到兩次以上
|
||||||
Model.activity_check check = _db.activity_check
|
Model.activity_check check = _db.activity_check
|
||||||
|
|||||||
@@ -1,17 +1,19 @@
|
|||||||
using System;
|
using DocumentFormat.OpenXml.Drawing.Charts;
|
||||||
|
using Model;
|
||||||
|
using MyWeb;
|
||||||
|
using Newtonsoft.Json;
|
||||||
|
using PagedList;
|
||||||
|
using System;
|
||||||
|
using System.Activities.Expressions;
|
||||||
|
using System.Collections;
|
||||||
using System.Collections.Generic;
|
using System.Collections.Generic;
|
||||||
|
using System.Diagnostics;
|
||||||
|
using System.IdentityModel.Metadata;
|
||||||
using System.Linq;
|
using System.Linq;
|
||||||
using System.Net;
|
using System.Net;
|
||||||
using System.Net.Http;
|
using System.Net.Http;
|
||||||
using System.Web.Http;
|
using System.Web.Http;
|
||||||
using PagedList;
|
|
||||||
using Newtonsoft.Json;
|
|
||||||
using System.Collections;
|
|
||||||
using static TreeView;
|
using static TreeView;
|
||||||
using Model;
|
|
||||||
using System.IdentityModel.Metadata;
|
|
||||||
using MyWeb;
|
|
||||||
using DocumentFormat.OpenXml.Drawing.Charts;
|
|
||||||
|
|
||||||
|
|
||||||
// api/order
|
// api/order
|
||||||
@@ -206,7 +208,7 @@ public class orderController : ApiController
|
|||||||
string sortBy = "", bool sortDesc = false)
|
string sortBy = "", bool sortDesc = false)
|
||||||
{
|
{
|
||||||
|
|
||||||
var qry = _db.pro_order.AsQueryable();
|
var qry = _db.pro_order.Include("activity").Include("activity.activity_check").AsQueryable();
|
||||||
//var aIDt = _db.actItems.AsEnumerable().Where(f => f.subject.Contains(q.actItemTxt.Trim())).Select(f => f.num);//品項
|
//var aIDt = _db.actItems.AsEnumerable().Where(f => f.subject.Contains(q.actItemTxt.Trim())).Select(f => f.num);//品項
|
||||||
|
|
||||||
|
|
||||||
@@ -221,7 +223,10 @@ public class orderController : ApiController
|
|||||||
if (q.up_time1.HasValue)
|
if (q.up_time1.HasValue)
|
||||||
qry = qry.Where(o => o.up_time >= q.up_time1.Value);
|
qry = qry.Where(o => o.up_time >= q.up_time1.Value);
|
||||||
if (q.up_time2.HasValue)
|
if (q.up_time2.HasValue)
|
||||||
qry = qry.Where(o => o.up_time < Convert.ToDateTime(q.up_time2.Value).AddDays(1));
|
{
|
||||||
|
var tmp_up_time2 = Convert.ToDateTime(q.up_time2.Value).AddDays(1);
|
||||||
|
qry = qry.Where(o => o.up_time < tmp_up_time2);
|
||||||
|
}
|
||||||
if (!string.IsNullOrEmpty(q.address))
|
if (!string.IsNullOrEmpty(q.address))
|
||||||
qry = qry.Where(o => o.address.Contains(q.address.Trim()));
|
qry = qry.Where(o => o.address.Contains(q.address.Trim()));
|
||||||
if (!string.IsNullOrEmpty(q.subject))
|
if (!string.IsNullOrEmpty(q.subject))
|
||||||
@@ -291,6 +296,13 @@ public class orderController : ApiController
|
|||||||
else
|
else
|
||||||
qry = qry.OrderBy(o => o.activity != null ? o.activity.subject : "");
|
qry = qry.OrderBy(o => o.activity != null ? o.activity.subject : "");
|
||||||
}
|
}
|
||||||
|
else if(sortBy.Equals("status"))
|
||||||
|
{
|
||||||
|
if (sortDesc)
|
||||||
|
qry = qry.OrderByDescending(o => o.activity.activity_check.FirstOrDefault(a => o.activity_num == a.activity_num && o.f_num == a.f_num).status ?? 0);
|
||||||
|
else
|
||||||
|
qry = qry.OrderBy(o => o.activity.activity_check.FirstOrDefault(a => o.activity_num == a.activity_num && o.f_num == a.f_num).status ?? 0);
|
||||||
|
}
|
||||||
else
|
else
|
||||||
qry = qry.OrderByDescending(o => o.reg_time);
|
qry = qry.OrderByDescending(o => o.reg_time);
|
||||||
|
|
||||||
@@ -307,6 +319,7 @@ public class orderController : ApiController
|
|||||||
keyin1 = x.keyin1,
|
keyin1 = x.keyin1,
|
||||||
up_time = x.up_time,
|
up_time = x.up_time,
|
||||||
keyin1_txt = Model.pro_order.keyin1_value_to_text(x.keyin1),
|
keyin1_txt = Model.pro_order.keyin1_value_to_text(x.keyin1),
|
||||||
|
status = x.activity.activity_check.FirstOrDefault(a => x.activity_num == a.activity_num && x.f_num == a.f_num)?.status ?? 0,
|
||||||
}),
|
}),
|
||||||
count = count
|
count = count
|
||||||
};
|
};
|
||||||
|
|||||||
@@ -16,6 +16,8 @@
|
|||||||
<asp:Repeater ID="Repeater2" runat="server" OnItemDataBound="Repeater2_ItemDataBound">
|
<asp:Repeater ID="Repeater2" runat="server" OnItemDataBound="Repeater2_ItemDataBound">
|
||||||
<ItemTemplate>
|
<ItemTemplate>
|
||||||
<a class="nav-link" href="<%#ResolveUrl(ValString(Eval("url"))) %>"
|
<a class="nav-link" href="<%#ResolveUrl(ValString(Eval("url"))) %>"
|
||||||
|
onclick="sessionStorage.removeItem('member_list_cache'); sessionStorage.removeItem('member_query_params');
|
||||||
|
sessionStorage.removeItem('order_list_cache'); sessionStorage.removeItem('order_query_params');"
|
||||||
target="<%#(ValString(Eval("target"))=="B"?"_blank":"_self") %>">
|
target="<%#(ValString(Eval("target"))=="B"?"_blank":"_self") %>">
|
||||||
<%#Eval("title") %></a>
|
<%#Eval("title") %></a>
|
||||||
</ItemTemplate>
|
</ItemTemplate>
|
||||||
|
|||||||
+202
-101
@@ -7,19 +7,20 @@
|
|||||||
<div class="mb-2 mb-sm-0">
|
<div class="mb-2 mb-sm-0">
|
||||||
<ul class="nav ps-0">
|
<ul class="nav ps-0">
|
||||||
<li class="nav-item pe-3">
|
<li class="nav-item pe-3">
|
||||||
<select class="form-select" v-model="search.kind" @change="btn_search">
|
<select class="form-select" v-model="search.kind" @change="btn_search" :disabled="isEditing">
|
||||||
<option value="">選擇分類</option>
|
<option value="">選擇分類</option>
|
||||||
<option v-for="item in itemKindList" :value="item.num">{{item.kind}}</option>
|
<option v-for="item in itemKindList" :value="item.num">{{item.kind}}</option>
|
||||||
</select>
|
</select>
|
||||||
</li>
|
</li>
|
||||||
<li class="nav-item pe-1">
|
<li class="nav-item pe-1">
|
||||||
<a href="item_reg.aspx" class="btn btn-primary">
|
<a href="item_reg.aspx" class="btn btn-primary" :class="{ 'disabled': isEditing }" >
|
||||||
<i class="mdi mdi-plus"></i>新增
|
<i class="mdi mdi-plus"></i>新增
|
||||||
</a>
|
</a>
|
||||||
</li>
|
</li>
|
||||||
<li class="nav-item pe-1">
|
|
||||||
<a @click="deleteAll" class="btn btn-outline-danger" title="刪除勾選的資料" ><i class="mdi mdi-trash-can"></i> 刪除勾選</a>
|
<li class="nav-item pe-1">
|
||||||
</li>
|
<a @click="deleteAll" class="btn btn-outline-danger" title="刪除勾選的資料" :class="{ 'disabled': isEditing }" ><i class="mdi mdi-trash-can"></i> 刪除勾選</a>
|
||||||
|
</li>
|
||||||
</ul>
|
</ul>
|
||||||
<%-- <div class="input-group mb-3" data-search-control="search1" @click="search_show(search_dialog.controls.search1)">
|
<%-- <div class="input-group mb-3" data-search-control="search1" @click="search_show(search_dialog.controls.search1)">
|
||||||
<input class="form-control search-text" type="text" readonly
|
<input class="form-control search-text" type="text" readonly
|
||||||
@@ -30,25 +31,30 @@
|
|||||||
</button>
|
</button>
|
||||||
</div>--%>
|
</div>--%>
|
||||||
</div>
|
</div>
|
||||||
|
<div>
|
||||||
|
|
||||||
<div class="">
|
|
||||||
|
|
||||||
<asp:LinkButton ID="excel" runat="server" CssClass="btn btn-outline-success" OnClick="excel_Click"><span class="fa-solid fa-file-excel"></span> 匯出Excel</asp:LinkButton>
|
<a v-if="!isEditing" @click="editClick" class="btn btn-outline-secondary" title="編輯排列順序"><i class="mdi mdi-swap-vertical"></i> 編輯排列順序</a>
|
||||||
|
<a v-else @click="editClick" class="btn btn-outline-secondary" title="完成編輯排列順序"><i class="mdi mdi-swap-vertical"></i> 完成編輯</a>
|
||||||
|
<div :style="isEditing ? 'pointer-events: none; opacity: 0.5;' : ''" style="display:inline-block;">
|
||||||
|
|
||||||
</div>
|
<asp:LinkButton ID="excel" runat="server" CssClass="btn btn-outline-success" OnClick="excel_Click" ><span class="fa-solid fa-file-excel"></span> 匯出Excel</asp:LinkButton>
|
||||||
|
|
||||||
|
</div> </div>
|
||||||
</asp:Content>
|
</asp:Content>
|
||||||
<asp:Content ID="Content5" ContentPlaceHolderID="footer_script" runat="Server">
|
<asp:Content ID="Content5" ContentPlaceHolderID="footer_script" runat="Server">
|
||||||
|
<script src="https://cdn.jsdelivr.net/npm/sortablejs@1.14.0/Sortable.min.js"></script>
|
||||||
<script>
|
<script>
|
||||||
Vue.filter('timeString', function (value, myFormat) {
|
Vue.filter('timeString', function (value, myFormat) {
|
||||||
return value == null || value == "" ? "" : moment(value).format(myFormat || 'YYYY-MM-DD, HH:mm:ss');
|
return value == null || value == "" ? "" : moment(value).format(myFormat || 'YYYY-MM-DD, HH:mm:ss');
|
||||||
});
|
});
|
||||||
|
|
||||||
let VueApp=new Vue({
|
let VueApp = new Vue({
|
||||||
el: '#app',
|
el: '#app',
|
||||||
vuetify: new Vuetify(vuetify_options),
|
vuetify: new Vuetify(vuetify_options),
|
||||||
data() {
|
data() {
|
||||||
return {
|
return {
|
||||||
|
isEditing: false,
|
||||||
options: { multiSort: false },
|
options: { multiSort: false },
|
||||||
data_table: {
|
data_table: {
|
||||||
loading: true,
|
loading: true,
|
||||||
@@ -68,15 +74,15 @@
|
|||||||
{ text: '', value: 'slot_btn', sortable: false, align: 'end' },
|
{ text: '', value: 'slot_btn', sortable: false, align: 'end' },
|
||||||
|
|
||||||
],
|
],
|
||||||
footer:{
|
footer: {
|
||||||
showFirstLastPage: true,
|
showFirstLastPage: true,
|
||||||
itemsPerPageOptions:[5,10,20,30],
|
itemsPerPageOptions: [5, 10, 20, 30],
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
search: {
|
search: {
|
||||||
kind: '',
|
kind: '',
|
||||||
subject: '',
|
subject: '',
|
||||||
selltime1:'',
|
selltime1: '',
|
||||||
selltime2: '',
|
selltime2: '',
|
||||||
uptime1: '',
|
uptime1: '',
|
||||||
uptime2: '',
|
uptime2: '',
|
||||||
@@ -98,7 +104,7 @@
|
|||||||
{ id: 'kind', title: '品項分類', value: '' },
|
{ id: 'kind', title: '品項分類', value: '' },
|
||||||
],
|
],
|
||||||
selected: {},
|
selected: {},
|
||||||
select(t,data) {
|
select(t, data) {
|
||||||
data.search.kind = t.num;
|
data.search.kind = t.num;
|
||||||
data.btn_search()
|
data.btn_search()
|
||||||
console.log("select search1", t);
|
console.log("select search1", t);
|
||||||
@@ -120,9 +126,9 @@
|
|||||||
}, snackbar: {
|
}, snackbar: {
|
||||||
show: false,
|
show: false,
|
||||||
text: "",
|
text: "",
|
||||||
}, itemKindList:{
|
}, itemKindList: {
|
||||||
num: 0,
|
num: 0,
|
||||||
kind:''
|
kind: ''
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
@@ -174,20 +180,39 @@
|
|||||||
|
|
||||||
},
|
},
|
||||||
getDefault(clearpage = false) {
|
getDefault(clearpage = false) {
|
||||||
const { sortBy, sortDesc, page, itemsPerPage } = this.options
|
if (this.isEditing) {
|
||||||
const params = {
|
const { sortBy, sortDesc, page, itemsPerPage } = this.options
|
||||||
sortBy: sortBy[0], sortDesc: sortDesc[0],
|
const params = {
|
||||||
page: clearpage ? '1' :page, pageSize: itemsPerPage
|
sortBy: "sort_order", sortDesc: sortDesc[0],
|
||||||
};
|
page: clearpage ? '1' : page, pageSize: 0
|
||||||
this.data_table.loading = true
|
};
|
||||||
axios
|
this.data_table.loading = true
|
||||||
.post(HTTP_HOST + 'api/activity/GetItemList', this.search, { params: params })
|
axios
|
||||||
.then(response => {
|
.post(HTTP_HOST + 'api/activity/GetItemList', this.search, { params: params })
|
||||||
this.data_table.list = response.data.list
|
.then(response => {
|
||||||
this.data_table.count = response.data.count;
|
this.data_table.list = response.data.list
|
||||||
this.data_table.loading = false
|
this.data_table.count = response.data.count;
|
||||||
})
|
this.data_table.loading = false
|
||||||
.catch(error => console.log(error))
|
})
|
||||||
|
.catch(error => console.log(error))
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
const { sortBy, sortDesc, page, itemsPerPage } = this.options
|
||||||
|
const params = {
|
||||||
|
sortBy: sortBy[0], sortDesc: sortDesc[0],
|
||||||
|
page: clearpage ? '1' : page, pageSize: itemsPerPage
|
||||||
|
};
|
||||||
|
this.data_table.loading = true
|
||||||
|
axios
|
||||||
|
.post(HTTP_HOST + 'api/activity/GetItemList', this.search, { params: params })
|
||||||
|
.then(response => {
|
||||||
|
this.data_table.list = response.data.list
|
||||||
|
this.data_table.count = response.data.count;
|
||||||
|
this.data_table.loading = false
|
||||||
|
})
|
||||||
|
.catch(error => console.log(error))
|
||||||
|
}
|
||||||
|
|
||||||
},
|
},
|
||||||
editItem(item) {
|
editItem(item) {
|
||||||
console.log("edit", item);
|
console.log("edit", item);
|
||||||
@@ -225,6 +250,29 @@
|
|||||||
.catch(error => console.log(error))
|
.catch(error => console.log(error))
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
editClick() {
|
||||||
|
if (this.isEditing) {
|
||||||
|
this.isEditing = false;
|
||||||
|
const sortedIds = this.data_table.list.map(item => item.num);
|
||||||
|
axios.post(HTTP_HOST + 'api/activity/SaveItemList', { ids: sortedIds })
|
||||||
|
.then(response => {
|
||||||
|
this.isEditing = false;
|
||||||
|
this.getDefault();
|
||||||
|
})
|
||||||
|
.catch(error => {
|
||||||
|
alert("儲存排序失敗:" + error);
|
||||||
|
})
|
||||||
|
.finally(() => {
|
||||||
|
this.data_table.loading = false;
|
||||||
|
|
||||||
|
});
|
||||||
|
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
this.isEditing = true;
|
||||||
|
this.getDefault()
|
||||||
|
}
|
||||||
|
},
|
||||||
btn_search() {
|
btn_search() {
|
||||||
this.getDefault(true)
|
this.getDefault(true)
|
||||||
},
|
},
|
||||||
@@ -232,86 +280,115 @@
|
|||||||
clearObjProps(this.search);
|
clearObjProps(this.search);
|
||||||
this.btn_search()
|
this.btn_search()
|
||||||
},
|
},
|
||||||
//===
|
//===
|
||||||
search_show(curr) {
|
search_show(curr) {
|
||||||
//console.log("btn_click:", curr, curr.api_url);
|
//console.log("btn_click:", curr, curr.api_url);
|
||||||
this.search_dialog.current = curr;
|
this.search_dialog.current = curr;
|
||||||
this.search_clear()
|
this.search_clear()
|
||||||
//this.search_get()//清除完自動會重抓, 故取消
|
//this.search_get()//清除完自動會重抓, 故取消
|
||||||
this.search_dialog.show = true;
|
this.search_dialog.show = true;
|
||||||
},
|
},
|
||||||
search_clear() {
|
search_clear() {
|
||||||
if (!this.search_dialog.current.keys) return;
|
if (!this.search_dialog.current.keys) return;
|
||||||
this.search_dialog.current.keys.forEach((t, i) => { t.value = '' })
|
this.search_dialog.current.keys.forEach((t, i) => { t.value = '' })
|
||||||
this.search_get()
|
this.search_get()
|
||||||
},
|
},
|
||||||
search_get() {
|
search_get() {
|
||||||
if (!this.search_dialog.current.keys) return;
|
if (!this.search_dialog.current.keys) return;
|
||||||
let api_url = this.search_dialog.current.api_url;
|
let api_url = this.search_dialog.current.api_url;
|
||||||
let keys = this.search_dialog.current.keys;
|
let keys = this.search_dialog.current.keys;
|
||||||
//const { page, itemsPerPage } = this.options
|
//const { page, itemsPerPage } = this.options
|
||||||
//const { sortBy, sortDesc, page, itemsPerPage } = this.options
|
//const { sortBy, sortDesc, page, itemsPerPage } = this.options
|
||||||
this.search_dialog.page = this.options.page ?? 1
|
this.search_dialog.page = this.options.page ?? 1
|
||||||
let params = { page: this.search_dialog.page, pageSize: 10 };//url params
|
let params = { page: this.search_dialog.page, pageSize: 10 };//url params
|
||||||
var search = {};//post body
|
var search = {};//post body
|
||||||
keys.forEach((t, i) => {
|
keys.forEach((t, i) => {
|
||||||
search[t.id] = t.value;
|
search[t.id] = t.value;
|
||||||
});
|
});
|
||||||
|
|
||||||
console.log("search_get", api_url, search, params, this.options);
|
console.log("search_get", api_url, search, params, this.options);
|
||||||
this.search_dialog.loading = true
|
this.search_dialog.loading = true
|
||||||
axios.post(api_url, search, { params: params })
|
axios.post(api_url, search, { params: params })
|
||||||
.then(response => {
|
.then(response => {
|
||||||
this.search_dialog.list = response.data.list
|
this.search_dialog.list = response.data.list
|
||||||
this.search_dialog.count = response.data.count
|
this.search_dialog.count = response.data.count
|
||||||
this.search_dialog.loading = false
|
this.search_dialog.loading = false
|
||||||
|
})
|
||||||
|
.catch(error => {
|
||||||
|
console.log(error)
|
||||||
|
this.search_dialog.list = []
|
||||||
|
this.search_dialog.count = 0
|
||||||
|
this.search_dialog.loading = false
|
||||||
|
this.snackbar.text = "錯誤:" + error
|
||||||
|
this.snackbar.show = true
|
||||||
|
})
|
||||||
|
},
|
||||||
|
search_headers() {
|
||||||
|
if (!this.search_dialog.current.columns) return;
|
||||||
|
r = [];
|
||||||
|
this.search_dialog.current.columns.forEach((t, i) => {
|
||||||
|
r.push({
|
||||||
|
text: t.title,
|
||||||
|
align: 'start',
|
||||||
|
sortable: false,
|
||||||
|
value: t.id,
|
||||||
|
})
|
||||||
})
|
})
|
||||||
.catch(error => {
|
return r
|
||||||
console.log(error)
|
},
|
||||||
this.search_dialog.list = []
|
search_select(row) {
|
||||||
this.search_dialog.count = 0
|
let curr = this.search_dialog.current;
|
||||||
this.search_dialog.loading = false
|
let target = $(`[data-search-control=${curr.id}]`);
|
||||||
this.snackbar.text = "錯誤:" + error
|
curr.selected = row;
|
||||||
this.snackbar.show = true
|
target.children("input.search-text").val(curr.selected[curr.text_prop])//text
|
||||||
})
|
target.children("input:hidden").val(curr.selected[curr.value_prop])//value
|
||||||
},
|
if (curr.select instanceof Function) {
|
||||||
search_headers() {
|
curr.select(row, this);
|
||||||
if (!this.search_dialog.current.columns) return;
|
}
|
||||||
r = [];
|
this.search_dialog.show = false;
|
||||||
this.search_dialog.current.columns.forEach((t, i) => {
|
},
|
||||||
r.push({
|
saveOrder(event) {
|
||||||
text: t.title,
|
const movedItem = this.data_table.list.splice(event.oldIndex, 1)[0];
|
||||||
align: 'start',
|
this.data_table.list.splice(event.newIndex, 0, movedItem);
|
||||||
sortable: false,
|
},
|
||||||
value: t.id,
|
|
||||||
})
|
|
||||||
})
|
|
||||||
return r
|
|
||||||
},
|
|
||||||
search_select(row) {
|
|
||||||
let curr = this.search_dialog.current;
|
|
||||||
let target = $(`[data-search-control=${curr.id}]`);
|
|
||||||
curr.selected = row;
|
|
||||||
target.children("input.search-text").val(curr.selected[curr.text_prop])//text
|
|
||||||
target.children("input:hidden").val(curr.selected[curr.value_prop])//value
|
|
||||||
if (curr.select instanceof Function) {
|
|
||||||
curr.select(row,this);
|
|
||||||
}
|
|
||||||
this.search_dialog.show = false;
|
|
||||||
},
|
|
||||||
|
|
||||||
},
|
},
|
||||||
computed: {
|
computed: {
|
||||||
pageCount() {
|
pageCount() {
|
||||||
return Math.ceil(this.data_table.count / this.data_table.pageSize)
|
return Math.ceil(this.data_table.count / this.data_table.pageSize)
|
||||||
},
|
},
|
||||||
|
computedHeaders() {
|
||||||
|
return this.data_table.header.map(h => {
|
||||||
|
if (h.value === 'slot_btn') {
|
||||||
|
return { ...h, sortable: false };
|
||||||
|
}
|
||||||
|
|
||||||
|
return {
|
||||||
|
...h,
|
||||||
|
sortable: this.isEditing ? false : (h.sortable !== false)
|
||||||
|
};
|
||||||
|
});
|
||||||
|
},
|
||||||
},
|
},
|
||||||
filters: {
|
filters: {
|
||||||
currency: function (value) {
|
currency: function (value) {
|
||||||
return value == null || value == "" ? "" :
|
return value == null || value == "" ? "" :
|
||||||
('$' + parseFloat(value).toFixed(2).replace(/(\d)(?=(\d{3})+\.)/g, "$1,").replace(".00", ""));
|
('$' + parseFloat(value).toFixed(2).replace(/(\d)(?=(\d{3})+\.)/g, "$1,").replace(".00", ""));
|
||||||
},
|
},
|
||||||
}
|
},
|
||||||
|
directives: {
|
||||||
|
sortableDataTable: {
|
||||||
|
bind(el, binding, vnode) {
|
||||||
|
const options = {
|
||||||
|
animation: 150,
|
||||||
|
onUpdate: function (event) {
|
||||||
|
vnode.child.$emit('sorted', event)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
Sortable.create(el.getElementsByTagName('tbody')[0], options)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
})
|
})
|
||||||
</script>
|
</script>
|
||||||
</asp:Content>
|
</asp:Content>
|
||||||
@@ -319,6 +396,9 @@
|
|||||||
<uc1:alert runat="server" ID="L_msg" Text="" />
|
<uc1:alert runat="server" ID="L_msg" Text="" />
|
||||||
<div id="content" class="container-fluid">
|
<div id="content" class="container-fluid">
|
||||||
<v-data-table
|
<v-data-table
|
||||||
|
v-sortable-data-table
|
||||||
|
@sorted="saveOrder"
|
||||||
|
:headers="computedHeaders"
|
||||||
v-model="data_table.selected"
|
v-model="data_table.selected"
|
||||||
:items="data_table.list"
|
:items="data_table.list"
|
||||||
:search-props="search"
|
:search-props="search"
|
||||||
@@ -332,8 +412,29 @@
|
|||||||
show-select
|
show-select
|
||||||
hide-default-footer
|
hide-default-footer
|
||||||
:page.sync="data_table.page"
|
:page.sync="data_table.page"
|
||||||
:items-per-page.sync="data_table.pageSize"
|
:items-per-page.sync= "isEditing ? -1 :data_table.pageSize"
|
||||||
class="elevation-1">
|
class="elevation-1">
|
||||||
|
<template v-slot:header.data-table-select="{ on, props }">
|
||||||
|
<v-simple-checkbox
|
||||||
|
v-if="!isEditing"
|
||||||
|
v-bind="props"
|
||||||
|
v-on="on"
|
||||||
|
></v-simple-checkbox>
|
||||||
|
|
||||||
|
<v-icon v-else small>mdi-swap-vertical</v-icon>
|
||||||
|
</template>
|
||||||
|
<template v-slot:item.data-table-select="{ item, isSelected, select }">
|
||||||
|
<v-simple-checkbox
|
||||||
|
v-if="!isEditing"
|
||||||
|
:value="isSelected"
|
||||||
|
@input="select($event)"
|
||||||
|
></v-simple-checkbox>
|
||||||
|
|
||||||
|
<div v-else class="handle" style="cursor: grab;">
|
||||||
|
<v-icon color="grey darken-1">mdi-drag-vertical</v-icon>
|
||||||
|
</div>
|
||||||
|
</template>
|
||||||
|
|
||||||
<template #item.price="{ item }" >
|
<template #item.price="{ item }" >
|
||||||
{{item.price | currency }}
|
{{item.price | currency }}
|
||||||
</template>
|
</template>
|
||||||
@@ -352,12 +453,12 @@
|
|||||||
</template>
|
</template>
|
||||||
|
|
||||||
|
|
||||||
<template #item.slot_btn="{ item }">
|
<template #item.slot_btn="{ item }" >
|
||||||
<a :href="'item_reg.aspx?num='+item.num" class="btn btn-outline-secondary btn-sm"><i class="mdi mdi-pencil-box-outline"></i>修改</a>
|
<a v-if="!isEditing" :href="'item_reg.aspx?num='+item.num" class="btn btn-outline-secondary btn-sm"><i class="mdi mdi-pencil-box-outline"></i>修改</a>
|
||||||
<a @click="deleteItem(item)" class="btn btn-outline-secondary btn-sm"><i class="mdi mdi-trash-can"></i>刪除</a>
|
<a v-if="!isEditing" @click="deleteItem(item)" class="btn btn-outline-secondary btn-sm"><i class="mdi mdi-trash-can"></i>刪除</a>
|
||||||
</template>
|
</template>
|
||||||
</v-data-table>
|
</v-data-table>
|
||||||
<v-container>
|
<v-container v-if="!isEditing">
|
||||||
<v-row class="align-baseline" wrap>
|
<v-row class="align-baseline" wrap>
|
||||||
<v-col cols="12" md="9">
|
<v-col cols="12" md="9">
|
||||||
<v-pagination
|
<v-pagination
|
||||||
|
|||||||
@@ -148,7 +148,7 @@ public partial class admin_activity_index2 : MyWeb.config
|
|||||||
}
|
}
|
||||||
|
|
||||||
var tdesc = publicFun.enum_desc<Model.activity.category>();
|
var tdesc = publicFun.enum_desc<Model.activity.category>();
|
||||||
qry = qry.OrderByDescending(o => o.num);
|
qry = qry.OrderByDescending(o => o.sort_order);
|
||||||
var list = qry.ToList();
|
var list = qry.ToList();
|
||||||
if (list.Count > 0)
|
if (list.Count > 0)
|
||||||
{
|
{
|
||||||
|
|||||||
@@ -133,6 +133,7 @@ public partial class admin_activity_item_reg : MyWeb.config
|
|||||||
L_msg.Text = "";
|
L_msg.Text = "";
|
||||||
|
|
||||||
Model.actItem actItem = new Model.actItem();//新增
|
Model.actItem actItem = new Model.actItem();//新增
|
||||||
|
int maxSort = _db.actItems.Max(x => (int?)x.sort_order) ?? 0;
|
||||||
actItem.subject = subject.Text;
|
actItem.subject = subject.Text;
|
||||||
actItem.print_init = print_init.Text;
|
actItem.print_init = print_init.Text;
|
||||||
actItem.partno = PARTNO.Text;
|
actItem.partno = PARTNO.Text;
|
||||||
@@ -158,6 +159,7 @@ public partial class admin_activity_item_reg : MyWeb.config
|
|||||||
actItem.is_reconcile = is_reconcile_item.Checked ? "Y" : "N";
|
actItem.is_reconcile = is_reconcile_item.Checked ? "Y" : "N";
|
||||||
actItem.demo = demo.Text;
|
actItem.demo = demo.Text;
|
||||||
actItem.customize_data = customize_data.Text;
|
actItem.customize_data = customize_data.Text;
|
||||||
|
actItem.sort_order = maxSort + 1;
|
||||||
|
|
||||||
_db.actItems.Add(actItem);
|
_db.actItems.Add(actItem);
|
||||||
_db.SaveChanges();
|
_db.SaveChanges();
|
||||||
|
|||||||
@@ -905,7 +905,7 @@
|
|||||||
<div class="">
|
<div class="">
|
||||||
<asp:Button ID="add" runat="server" Text="送出" OnClick="add_Click" CssClass="btn btn-primary" />
|
<asp:Button ID="add" runat="server" Text="送出" OnClick="add_Click" CssClass="btn btn-primary" />
|
||||||
<asp:Button ID="edit" runat="server" Text="修改" Visible="false" OnClick="edit_Click" CssClass="btn btn-primary" />
|
<asp:Button ID="edit" runat="server" Text="修改" Visible="false" OnClick="edit_Click" CssClass="btn btn-primary" />
|
||||||
<asp:Button ID="goback" runat="server" Text="回列表" Visible="false" CausesValidation="false" OnClick="goback_Click" CssClass="btn btn-outline-secondary" />
|
<asp:Button ID="goback" runat="server" Text="取消" Visible="true" CausesValidation="false" OnClick="goback_Click" CssClass="btn btn-outline-secondary" />
|
||||||
</div>
|
</div>
|
||||||
</asp:Content>
|
</asp:Content>
|
||||||
<asp:Content ID="Content2" ContentPlaceHolderID="ContentPlaceHolder1" runat="Server">
|
<asp:Content ID="Content2" ContentPlaceHolderID="ContentPlaceHolder1" runat="Server">
|
||||||
|
|||||||
+140
-14
@@ -13,10 +13,12 @@
|
|||||||
<a @click="print_dialog.show=true" class="btn btn-outline-primary btn-print" target="_blank">
|
<a @click="print_dialog.show=true" class="btn btn-outline-primary btn-print" target="_blank">
|
||||||
<i class="mdi mdi-printer"></i>列印管理報表
|
<i class="mdi mdi-printer"></i>列印管理報表
|
||||||
</a>
|
</a>
|
||||||
<a @click="goPrint" class="btn btn-outline-primary btn-print" target="_blank">
|
<a @click="goPrint" class="btn btn-outline-primary btn-print" :class="{ 'disabled': data_table.list.length === 0 }" target="_blank">
|
||||||
<i class="mdi mdi-printer"></i>列印查詢資料
|
<i class="mdi mdi-printer"></i>列印查詢資料
|
||||||
</a>
|
</a>
|
||||||
<asp:LinkButton ID="excel" runat="server" CssClass="btn btn-outline-success" OnClick="excel_Click"><span class="fa-solid fa-file-excel"></span> 匯出Excel</asp:LinkButton>
|
<div :style="data_table.list.length === 0 ? 'pointer-events: none; opacity: 0.5;' : ''" style="display:inline-block;">
|
||||||
|
<asp:LinkButton ID="excel" runat="server" CssClass="btn btn-outline-success" OnClick="export_Click"><span class="fa-solid fa-file-excel"></span> 匯出查詢資料(Excel)</asp:LinkButton>
|
||||||
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</asp:Content>
|
</asp:Content>
|
||||||
<asp:Content ID="Content5" ContentPlaceHolderID="footer_script" runat="Server">
|
<asp:Content ID="Content5" ContentPlaceHolderID="footer_script" runat="Server">
|
||||||
@@ -24,11 +26,13 @@
|
|||||||
Vue.filter('timeString', function (value, myFormat) {
|
Vue.filter('timeString', function (value, myFormat) {
|
||||||
return value == null || value == "" ? "" : moment(value).format(myFormat || 'YYYY-MM-DD, HH:mm:ss');
|
return value == null || value == "" ? "" : moment(value).format(myFormat || 'YYYY-MM-DD, HH:mm:ss');
|
||||||
});
|
});
|
||||||
let VueApp=new Vue({
|
let VueApp = new Vue({
|
||||||
el: '#app',
|
el: '#app',
|
||||||
vuetify: new Vuetify(vuetify_options),
|
vuetify: new Vuetify(vuetify_options),
|
||||||
data() {
|
data() {
|
||||||
return {
|
return {
|
||||||
|
isSearched: false,
|
||||||
|
print_error_msg: '',
|
||||||
options: { multiSort: false },
|
options: { multiSort: false },
|
||||||
search_options: { multiSort: false },
|
search_options: { multiSort: false },
|
||||||
data_table: {
|
data_table: {
|
||||||
@@ -41,7 +45,7 @@
|
|||||||
pageSize: 10,
|
pageSize: 10,
|
||||||
header: [
|
header: [
|
||||||
{ text: '信眾編號', value: 'f_number', align: 'start' },
|
{ text: '信眾編號', value: 'f_number', align: 'start' },
|
||||||
{ text: '信眾姓名', value: 'u_name'},
|
{ text: '信眾姓名', value: 'u_name' },
|
||||||
{ text: '身分別', value: 'identity_type_desc' },
|
{ text: '身分別', value: 'identity_type_desc' },
|
||||||
{ text: '性別', value: 'sex' },
|
{ text: '性別', value: 'sex' },
|
||||||
{ text: '生日', value: 'birthday' },
|
{ text: '生日', value: 'birthday' },
|
||||||
@@ -49,9 +53,9 @@
|
|||||||
{ text: '', value: 'slot', sortable: false },
|
{ text: '', value: 'slot', sortable: false },
|
||||||
{ text: '', value: 'slot_btn', sortable: false, align: 'end' },
|
{ text: '', value: 'slot_btn', sortable: false, align: 'end' },
|
||||||
],
|
],
|
||||||
footer:{
|
footer: {
|
||||||
showFirstLastPage: true,
|
showFirstLastPage: true,
|
||||||
pageSizeOptions:[5,10,20,30],
|
pageSizeOptions: [5, 10, 20, 30],
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
search: {
|
search: {
|
||||||
@@ -60,7 +64,7 @@
|
|||||||
sex: '',
|
sex: '',
|
||||||
//birthday: new Date().toISOString().split('T')[0],
|
//birthday: new Date().toISOString().split('T')[0],
|
||||||
//birthday2: new Date().toISOString().split('T')[0]
|
//birthday2: new Date().toISOString().split('T')[0]
|
||||||
birthday:'',
|
birthday: '',
|
||||||
birthday2: '',
|
birthday2: '',
|
||||||
address: '',
|
address: '',
|
||||||
country: '',
|
country: '',
|
||||||
@@ -69,7 +73,7 @@
|
|||||||
/*注意這邊的參數不能跟下方print_search重複*/
|
/*注意這邊的參數不能跟下方print_search重複*/
|
||||||
},
|
},
|
||||||
//列印管理報表
|
//列印管理報表
|
||||||
print_conditions:'yy',
|
print_conditions: 'yy',
|
||||||
print_search: {
|
print_search: {
|
||||||
year: '',
|
year: '',
|
||||||
month: '',
|
month: '',
|
||||||
@@ -132,7 +136,12 @@
|
|||||||
watch: {
|
watch: {
|
||||||
options: {
|
options: {
|
||||||
handler() {
|
handler() {
|
||||||
this.getList()
|
if (this.isSearched) {
|
||||||
|
this.getList()
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
this.data_table.loading = false;
|
||||||
|
}
|
||||||
},
|
},
|
||||||
deep: true,
|
deep: true,
|
||||||
},
|
},
|
||||||
@@ -141,23 +150,101 @@
|
|||||||
this.search_get()
|
this.search_get()
|
||||||
},
|
},
|
||||||
deep: true,
|
deep: true,
|
||||||
},
|
}
|
||||||
}, mounted() {
|
}, mounted() {
|
||||||
|
const printResult = document.getElementById('<%= hid_err_msg.ClientID %>').value;
|
||||||
|
document.getElementById('<%= hid_err_msg.ClientID %>').value = '';
|
||||||
|
window._printResult = printResult
|
||||||
|
|
||||||
this.search_dialog.current = this.search_dialog.controls.search1 ///default
|
this.search_dialog.current = this.search_dialog.controls.search1 ///default
|
||||||
this.initPrintSearch();
|
this.initPrintSearch();
|
||||||
|
|
||||||
const navEntries = performance.getEntriesByType("navigation");
|
const navEntries = performance.getEntriesByType("navigation");
|
||||||
const isReload = navEntries.length > 0 && navEntries[0].type === "reload";
|
const isReload = navEntries.length > 0 && navEntries[0].type === "reload";
|
||||||
|
|
||||||
|
const url = new URL(window.location.href);
|
||||||
|
let params = url.searchParams;
|
||||||
|
if (params.get('dirty') === '1') { // 資料有更新時執行 getlist
|
||||||
|
this.search = JSON.parse(sessionStorage.getItem("member_query_params"));
|
||||||
|
this.getList();
|
||||||
|
|
||||||
|
params.delete('dirty');
|
||||||
|
window.history.replaceState({}, '', url.pathname + url.search);
|
||||||
|
}
|
||||||
|
|
||||||
if (isReload) {
|
if (isReload) {
|
||||||
sessionStorage.removeItem("followerpage");
|
sessionStorage.removeItem("followerpage");
|
||||||
|
sessionStorage.removeItem("member_list_cache");
|
||||||
|
sessionStorage.removeItem("member_query_params");
|
||||||
|
}
|
||||||
|
else if ("<%=lastAddedID%>" !== "") {
|
||||||
|
const newQuery = { f_number: '<%=lastAddedID%>' };
|
||||||
|
sessionStorage.setItem('member_query_params', JSON.stringify(newQuery));
|
||||||
|
this.search = newQuery;
|
||||||
|
this.isSearched = true;
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
const savedPage = parseInt(sessionStorage.getItem('followerpage'));
|
const savedPage = parseInt(sessionStorage.getItem('followerpage'));
|
||||||
|
const savedData = sessionStorage.getItem("member_list_cache");
|
||||||
|
const savedQuery = JSON.parse(sessionStorage.getItem("member_query_params"));
|
||||||
|
if (savedQuery) {
|
||||||
|
this.search = savedQuery;
|
||||||
|
this.isSearched = true;
|
||||||
|
}
|
||||||
if (savedPage) {
|
if (savedPage) {
|
||||||
this.options.page = savedPage;
|
this.options.page = savedPage;
|
||||||
}
|
}
|
||||||
|
if (savedData && savedData !== "undefined") {
|
||||||
|
this.data_table = JSON.parse(savedData);
|
||||||
|
this.isSearched = true;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (printResult === 'nodata' || printResult === 'success') {
|
||||||
|
this.$nextTick(() => {
|
||||||
|
this.print_search.year = parseInt(document.getElementById('<%= hid_print_year.ClientID %>').value) || this.print_search.year;
|
||||||
|
this.print_search.month = parseInt(document.getElementById('<%= hid_print_month.ClientID %>').value) || this.print_search.month;
|
||||||
|
this.print_search.season = parseInt(document.getElementById('<%= hid_print_season.ClientID %>').value) || this.print_search.season;
|
||||||
|
this.print_conditions = document.getElementById('<%= hid_print_mode.ClientID %>').value || 'yy';
|
||||||
|
this.print_dialog.show = true;
|
||||||
|
if (printResult === 'nodata') {
|
||||||
|
this.print_error_msg = "查無資料,請重新選擇區間";
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
this.$nextTick(() => {
|
||||||
|
setTimeout(() => {
|
||||||
|
// 清空 URL
|
||||||
|
const cleanUrl = window.location.protocol + "//" + window.location.host + window.location.pathname;
|
||||||
|
window.history.replaceState({}, '', cleanUrl);
|
||||||
|
}, 100);
|
||||||
|
});
|
||||||
},
|
},
|
||||||
methods: {
|
methods: {
|
||||||
|
triggerManagementExport(mode) {
|
||||||
|
this.print_dialog.show = false;
|
||||||
|
this.print_error_msg = "";
|
||||||
|
if (this.print_search.year == '') {
|
||||||
|
msgbox('請輸入年份');
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
document.getElementById('<%= hid_print_mode.ClientID %>').value = this.print_conditions;
|
||||||
|
document.getElementById('<%= hid_print_year.ClientID %>').value = this.print_search.year;
|
||||||
|
if (this.print_conditions == 'mm') {
|
||||||
|
document.getElementById('<%= hid_print_month.ClientID %>').value = this.print_search.month;
|
||||||
|
}
|
||||||
|
else if (this.print_conditions == 'ss') {
|
||||||
|
document.getElementById('<%= hid_print_season.ClientID %>').value = this.print_search.season;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (mode === 'print') {
|
||||||
|
document.getElementById('<%= print_management.ClientID %>').click();
|
||||||
|
}
|
||||||
|
else if (mode === "excel") {
|
||||||
|
document.getElementById('<%= excel_management.ClientID %>').click();
|
||||||
|
}
|
||||||
|
},
|
||||||
search_show(curr) {
|
search_show(curr) {
|
||||||
//console.log("btn_click:", curr, curr.api_url);
|
//console.log("btn_click:", curr, curr.api_url);
|
||||||
this.search_dialog.current = curr;
|
this.search_dialog.current = curr;
|
||||||
@@ -228,6 +315,7 @@
|
|||||||
//console.log(row, row["u_name"], row["f_number"], curr.id, target);
|
//console.log(row, row["u_name"], row["f_number"], curr.id, target);
|
||||||
},
|
},
|
||||||
getList(clearpage = false) {
|
getList(clearpage = false) {
|
||||||
|
console.log("do getlist")
|
||||||
const { sortBy, sortDesc, page, itemsPerPage } = this.options
|
const { sortBy, sortDesc, page, itemsPerPage } = this.options
|
||||||
const params = {
|
const params = {
|
||||||
sortBy: sortBy[0], sortDesc: sortDesc[0],
|
sortBy: sortBy[0], sortDesc: sortDesc[0],
|
||||||
@@ -241,6 +329,9 @@
|
|||||||
this.data_table.list = response.data.list
|
this.data_table.list = response.data.list
|
||||||
this.data_table.count = response.data.count;
|
this.data_table.count = response.data.count;
|
||||||
this.data_table.loading = false
|
this.data_table.loading = false
|
||||||
|
|
||||||
|
const dataToStore = JSON.stringify(this.data_table);
|
||||||
|
sessionStorage.setItem("member_list_cache", dataToStore);
|
||||||
})
|
})
|
||||||
.catch(
|
.catch(
|
||||||
error => console.log(error)
|
error => console.log(error)
|
||||||
@@ -262,7 +353,7 @@
|
|||||||
const index = this.data_table.list.indexOf(item)
|
const index = this.data_table.list.indexOf(item)
|
||||||
if (index != -1) {
|
if (index != -1) {
|
||||||
axios
|
axios
|
||||||
.delete(HTTP_HOST + 'api/follower/' + item.num)
|
.delete(HTTP_HOST + 'api/follower/Delete/' + item.num)
|
||||||
.then(response => {
|
.then(response => {
|
||||||
this.getList();
|
this.getList();
|
||||||
})
|
})
|
||||||
@@ -282,18 +373,23 @@
|
|||||||
//}
|
//}
|
||||||
//this.data_table.selected = [];
|
//this.data_table.selected = [];
|
||||||
//this.data_table.count = this.data_table.list.length
|
//this.data_table.count = this.data_table.list.length
|
||||||
location.reload();
|
//location.reload();
|
||||||
|
this.getList();
|
||||||
})
|
})
|
||||||
.catch(error => console.log(error))
|
.catch(error => console.log(error))
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
btn_search() {
|
btn_search() {
|
||||||
|
this.isSearched = true;
|
||||||
|
sessionStorage.setItem("member_query_params", JSON.stringify(this.search));
|
||||||
this.getList(true)
|
this.getList(true)
|
||||||
bootstrap.Offcanvas.getInstance(document.getElementById("offcanvasRight")).hide()
|
bootstrap.Offcanvas.getInstance(document.getElementById("offcanvasRight")).hide()
|
||||||
},
|
},
|
||||||
btn_all() {
|
btn_all() {
|
||||||
|
this.isSearched = false;
|
||||||
clearObjProps(this.search);
|
clearObjProps(this.search);
|
||||||
this.btn_search()
|
sessionStorage.setItem("member_query_params", JSON.stringify(this.search));
|
||||||
|
//this.btn_search()
|
||||||
},
|
},
|
||||||
goPrint() {
|
goPrint() {
|
||||||
//debugger;
|
//debugger;
|
||||||
@@ -309,6 +405,7 @@
|
|||||||
//列印管理報表
|
//列印管理報表
|
||||||
print_close() {
|
print_close() {
|
||||||
this.print_dialog.show = false;
|
this.print_dialog.show = false;
|
||||||
|
this.print_error_msg = "";
|
||||||
}
|
}
|
||||||
,
|
,
|
||||||
initPrintSearch() {
|
initPrintSearch() {
|
||||||
@@ -391,10 +488,31 @@
|
|||||||
$('#country2').val('');
|
$('#country2').val('');
|
||||||
VueApp.search.country2 = '';
|
VueApp.search.country2 = '';
|
||||||
});
|
});
|
||||||
|
|
||||||
|
$(document).ready(function () {
|
||||||
|
// 判斷是否彈出 search dialog
|
||||||
|
let hasSearchResult = sessionStorage.getItem("member_list_cache") !== null;
|
||||||
|
|
||||||
|
if (!hasSearchResult && window._printResult === '') {
|
||||||
|
let $btn = $("a[data-bs-target='#offcanvasRight'][href='#search_panel']");
|
||||||
|
$btn.click();
|
||||||
|
let el = document.getElementById('offcanvasRight');
|
||||||
|
let offcanvas = bootstrap.Offcanvas.getOrCreateInstance(el);
|
||||||
|
offcanvas.show();
|
||||||
|
}
|
||||||
|
});
|
||||||
</script>
|
</script>
|
||||||
</asp:Content>
|
</asp:Content>
|
||||||
<asp:Content ID="Content2" ContentPlaceHolderID="ContentPlaceHolder1" runat="Server">
|
<asp:Content ID="Content2" ContentPlaceHolderID="ContentPlaceHolder1" runat="Server">
|
||||||
<uc1:alert runat="server" ID="L_msg" Text="" />
|
<uc1:alert runat="server" ID="L_msg" Text="" />
|
||||||
|
<asp:HiddenField ID="hid_err_msg" runat="server" />
|
||||||
|
<asp:HiddenField ID="hid_print_year" runat="server" />
|
||||||
|
<asp:HiddenField ID="hid_print_month" runat="server" />
|
||||||
|
<asp:HiddenField ID="hid_print_season" runat="server" />
|
||||||
|
<asp:HiddenField ID="hid_print_mode" runat="server" />
|
||||||
|
<asp:HiddenField ID="hid_qry" runat="server" />
|
||||||
|
<asp:LinkButton ID="excel_management" runat="server" OnClick="export_Click" style="display:none;" />
|
||||||
|
<asp:LinkButton ID="print_management" runat="server" OnClick="export_Click" style="display:none;" />
|
||||||
<div id="content" class="container-fluid">
|
<div id="content" class="container-fluid">
|
||||||
<v-data-table
|
<v-data-table
|
||||||
v-model="data_table.selected"
|
v-model="data_table.selected"
|
||||||
@@ -508,9 +626,17 @@
|
|||||||
</v-col>
|
</v-col>
|
||||||
|
|
||||||
</v-row>
|
</v-row>
|
||||||
|
<v-row>
|
||||||
|
<v-col>
|
||||||
|
<div v-if="print_error_msg" class="red--text mt-2 text-center" style="font-weight: bold;">
|
||||||
|
{{ print_error_msg }}
|
||||||
|
</div>
|
||||||
|
</v-col>
|
||||||
|
</v-row>
|
||||||
<v-row densee class="pt-3" >
|
<v-row densee class="pt-3" >
|
||||||
<v-col :cols="12" class="pt-3 text-center" >
|
<v-col :cols="12" class="pt-3 text-center" >
|
||||||
<v-btn class="ma-2" color="primary" dark @click="goPrint2" > 列印 </v-btn>
|
<v-btn class="ma-2" color="primary" dark @click="triggerManagementExport('print')" > 列印 </v-btn>
|
||||||
|
<v-btn class="ma-2" color="primary" dark @click="triggerManagementExport('excel')"> 匯出 Excel </v-btn>
|
||||||
<v-btn class="ma-2" color="green" dark @click="print_close" > 取消 </v-btn>
|
<v-btn class="ma-2" color="green" dark @click="print_close" > 取消 </v-btn>
|
||||||
</v-col>
|
</v-col>
|
||||||
</v-row>
|
</v-row>
|
||||||
|
|||||||
+287
-176
@@ -1,17 +1,20 @@
|
|||||||
using System;
|
using DocumentFormat.OpenXml;
|
||||||
|
using DocumentFormat.OpenXml.Packaging;
|
||||||
|
using DocumentFormat.OpenXml.Spreadsheet;
|
||||||
|
using System;
|
||||||
using System.Collections;
|
using System.Collections;
|
||||||
using System.Collections.Generic;
|
using System.Collections.Generic;
|
||||||
|
using System.Configuration;
|
||||||
using System.Data;
|
using System.Data;
|
||||||
using System.Data.OleDb;
|
using System.Data.OleDb;
|
||||||
|
using System.Diagnostics;
|
||||||
|
using System.IO;
|
||||||
|
using System.Linq;
|
||||||
using System.Web;
|
using System.Web;
|
||||||
using System.Web.UI;
|
using System.Web.UI;
|
||||||
using System.Web.UI.WebControls;
|
using System.Web.UI.WebControls;
|
||||||
using System.Configuration;
|
using System.Windows.Controls;
|
||||||
using System.IO;
|
using System.Windows.Interop;
|
||||||
using DocumentFormat.OpenXml.Packaging;
|
|
||||||
using DocumentFormat.OpenXml;
|
|
||||||
using DocumentFormat.OpenXml.Spreadsheet;
|
|
||||||
using System.Linq;
|
|
||||||
using static TreeView;
|
using static TreeView;
|
||||||
|
|
||||||
|
|
||||||
@@ -19,11 +22,17 @@ public partial class admin_follower_index : MyWeb.config
|
|||||||
{
|
{
|
||||||
public int page = 1;
|
public int page = 1;
|
||||||
private Model.ezEntities _db = new Model.ezEntities();
|
private Model.ezEntities _db = new Model.ezEntities();
|
||||||
|
protected string lastAddedID;
|
||||||
protected void Page_Load(object sender, EventArgs e)
|
protected void Page_Load(object sender, EventArgs e)
|
||||||
{
|
{
|
||||||
|
|
||||||
if (!IsPostBack)
|
if (!IsPostBack)
|
||||||
{
|
{
|
||||||
|
if (Session["LastAddedID"] != null)
|
||||||
|
{
|
||||||
|
lastAddedID = Session["LastAddedID"].ToString();
|
||||||
|
Session.Remove("LastAddedID");
|
||||||
|
}
|
||||||
BuildKind();
|
BuildKind();
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
@@ -42,10 +51,10 @@ public partial class admin_follower_index : MyWeb.config
|
|||||||
//國籍
|
//國籍
|
||||||
s_country.Items.Clear();
|
s_country.Items.Clear();
|
||||||
s_country.Items.Add(new ListItem("請選擇", ""));
|
s_country.Items.Add(new ListItem("請選擇", ""));
|
||||||
var qry =_db.countries.OrderBy(x => x.range).ThenBy(x => x.name_en).ToList();
|
var qry = _db.countries.OrderBy(x => x.range).ThenBy(x => x.name_en).ToList();
|
||||||
if (qry.Count > 0)
|
if (qry.Count > 0)
|
||||||
{
|
{
|
||||||
foreach(var x in qry)
|
foreach (var x in qry)
|
||||||
s_country.Items.Add(new ListItem(x.name_zh, x.ID));
|
s_country.Items.Add(new ListItem(x.name_zh, x.ID));
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -68,208 +77,310 @@ public partial class admin_follower_index : MyWeb.config
|
|||||||
#endregion
|
#endregion
|
||||||
|
|
||||||
|
|
||||||
#region 匯出Excel
|
#region 匯出
|
||||||
|
|
||||||
protected void excel_Click(object sender, EventArgs e)
|
protected void export_Click(object sender, EventArgs e)
|
||||||
{
|
{
|
||||||
var memoryStream = new MemoryStream();
|
var memoryStream = new MemoryStream();
|
||||||
using (var doc = SpreadsheetDocument.Create(memoryStream, SpreadsheetDocumentType.Workbook))
|
|
||||||
|
LinkButton btn = sender as LinkButton;
|
||||||
|
if (btn == null) return;
|
||||||
|
bool isPrintMode = (btn.ID == "print_management");
|
||||||
|
bool isExcelMode = (btn.ID == "excel_management" || btn.ID == "excel");
|
||||||
|
bool isManagementMode = (btn.ID == "excel_management" || btn.ID == "print_management");
|
||||||
|
|
||||||
|
//查詢要匯出的資料
|
||||||
|
string _query = ""; // 紀錄匯出條件
|
||||||
|
var list = searchData(ref _query, isManagementMode);
|
||||||
|
|
||||||
|
if (isExcelMode)
|
||||||
{
|
{
|
||||||
var wb = doc.AddWorkbookPart();
|
|
||||||
wb.Workbook = new Workbook();
|
|
||||||
var sheets = wb.Workbook.AppendChild(new Sheets());
|
|
||||||
|
|
||||||
//建立第一個頁籤
|
|
||||||
var ws = wb.AddNewPart<WorksheetPart>();
|
|
||||||
ws.Worksheet = new Worksheet();
|
|
||||||
sheets.Append(new Sheet()
|
|
||||||
{
|
|
||||||
Id = wb.GetIdOfPart(ws),
|
|
||||||
SheetId = 1,
|
|
||||||
Name = "信眾資料"
|
|
||||||
});
|
|
||||||
|
|
||||||
//設定欄寬
|
|
||||||
var cu = new Columns();
|
|
||||||
cu.Append(
|
|
||||||
new Column { Min = 1, Max = 2, Width = 15, CustomWidth = true },
|
|
||||||
new Column { Min = 3, Max = 3, Width = 10, CustomWidth = true },
|
|
||||||
new Column { Min = 4, Max = 11, Width = 15, CustomWidth = true },
|
|
||||||
new Column { Min = 12, Max = 12, Width = 25, CustomWidth = true },
|
|
||||||
new Column { Min = 13, Max = 13, Width = 8, CustomWidth = true },
|
|
||||||
new Column { Min = 14, Max = 14, Width = 35, CustomWidth = true },
|
|
||||||
new Column { Min = 15, Max = 16, Width = 15, CustomWidth = true }
|
|
||||||
);
|
|
||||||
ws.Worksheet.Append(cu);
|
|
||||||
|
|
||||||
//建立資料頁
|
|
||||||
var sd = new SheetData();
|
|
||||||
ws.Worksheet.AppendChild(sd);
|
|
||||||
|
|
||||||
//第一列資料
|
|
||||||
var tr = new Row();
|
|
||||||
tr.Append(
|
|
||||||
new Cell() { CellValue = new CellValue("信眾編號"), DataType = CellValues.String },
|
|
||||||
new Cell() { CellValue = new CellValue("信眾姓名"), DataType = CellValues.String },
|
|
||||||
new Cell() { CellValue = new CellValue("性別"), DataType = CellValues.String },
|
|
||||||
new Cell() { CellValue = new CellValue("身分別"), DataType = CellValues.String },
|
|
||||||
new Cell() { CellValue = new CellValue("生日(國曆)"), DataType = CellValues.String },
|
|
||||||
new Cell() { CellValue = new CellValue("聯絡電話"), DataType = CellValues.String },
|
|
||||||
new Cell() { CellValue = new CellValue("手機號碼"), DataType = CellValues.String },
|
|
||||||
new Cell() { CellValue = new CellValue("皈依道場"), DataType = CellValues.String },
|
|
||||||
new Cell() { CellValue = new CellValue("皈依法名"), DataType = CellValues.String },
|
|
||||||
new Cell() { CellValue = new CellValue("皈依日期"), DataType = CellValues.String },
|
|
||||||
new Cell() { CellValue = new CellValue("加入日期"), DataType = CellValues.String },
|
|
||||||
new Cell() { CellValue = new CellValue("緊急連絡人"), DataType = CellValues.String },
|
|
||||||
new Cell() { CellValue = new CellValue("緊急連絡人電話"), DataType = CellValues.String },
|
|
||||||
new Cell() { CellValue = new CellValue("血型"), DataType = CellValues.String },
|
|
||||||
new Cell() { CellValue = new CellValue("國籍"), DataType = CellValues.String },
|
|
||||||
new Cell() { CellValue = new CellValue("收件地址"), DataType = CellValues.String },
|
|
||||||
new Cell() { CellValue = new CellValue("介紹人"), DataType = CellValues.String },
|
|
||||||
new Cell() { CellValue = new CellValue("LINE帳號"), DataType = CellValues.String },
|
|
||||||
new Cell() { CellValue = new CellValue("其它社群帳號"), DataType = CellValues.String },
|
|
||||||
new Cell() { CellValue = new CellValue("建檔日期"), DataType = CellValues.String }
|
|
||||||
,new Cell() { CellValue = new CellValue("身分證號"), DataType = CellValues.String }
|
|
||||||
//,new Cell() { CellValue = new CellValue("SHA"), DataType = CellValues.String }
|
|
||||||
);
|
|
||||||
sd.AppendChild(tr);
|
|
||||||
|
|
||||||
//查詢要匯出的資料
|
|
||||||
|
|
||||||
//紀錄匯出條件
|
|
||||||
string _query = "";
|
|
||||||
|
|
||||||
var list = searchData(ref _query);
|
|
||||||
if (list.Count > 0)
|
if (list.Count > 0)
|
||||||
{
|
{
|
||||||
MyWeb.encrypt encrypt = new MyWeb.encrypt();
|
using (var doc = SpreadsheetDocument.Create(memoryStream, SpreadsheetDocumentType.Workbook))
|
||||||
Model.country country = new Model.country();
|
|
||||||
var tdesc = publicFun.enum_desc<Model.follower.type>();
|
|
||||||
foreach (var item in list)
|
|
||||||
{
|
{
|
||||||
//新增資料列
|
var wb = doc.AddWorkbookPart();
|
||||||
tr = new Row();
|
wb.Workbook = new Workbook();
|
||||||
string s1, s2, sha;
|
var sheets = wb.Workbook.AppendChild(new Sheets());
|
||||||
s1= encrypt.DecryptAutoKey(item.phone);
|
|
||||||
s2= encrypt.DecryptAutoKey(item.id_code);
|
//建立第一個頁籤
|
||||||
sha = encrypt.followerHash(s1, s2);
|
var ws = wb.AddNewPart<WorksheetPart>();
|
||||||
|
ws.Worksheet = new Worksheet();
|
||||||
|
sheets.Append(new Sheet()
|
||||||
|
{
|
||||||
|
Id = wb.GetIdOfPart(ws),
|
||||||
|
SheetId = 1,
|
||||||
|
Name = "信眾資料"
|
||||||
|
});
|
||||||
|
|
||||||
|
//設定欄寬
|
||||||
|
var cu = new Columns();
|
||||||
|
cu.Append(
|
||||||
|
new Column { Min = 1, Max = 2, Width = 15, CustomWidth = true },
|
||||||
|
new Column { Min = 3, Max = 3, Width = 10, CustomWidth = true },
|
||||||
|
new Column { Min = 4, Max = 11, Width = 15, CustomWidth = true },
|
||||||
|
new Column { Min = 12, Max = 12, Width = 25, CustomWidth = true },
|
||||||
|
new Column { Min = 13, Max = 13, Width = 8, CustomWidth = true },
|
||||||
|
new Column { Min = 14, Max = 14, Width = 35, CustomWidth = true },
|
||||||
|
new Column { Min = 15, Max = 16, Width = 15, CustomWidth = true }
|
||||||
|
);
|
||||||
|
ws.Worksheet.Append(cu);
|
||||||
|
|
||||||
|
//建立資料頁
|
||||||
|
var sd = new SheetData();
|
||||||
|
ws.Worksheet.AppendChild(sd);
|
||||||
|
|
||||||
|
//第一列資料
|
||||||
|
var tr = new Row();
|
||||||
tr.Append(
|
tr.Append(
|
||||||
new Cell() { CellValue = new CellValue(item.f_number), DataType = CellValues.String },
|
new Cell() { CellValue = new CellValue("信眾編號"), DataType = CellValues.String },
|
||||||
new Cell() { CellValue = new CellValue(item.u_name), DataType = CellValues.String },
|
new Cell() { CellValue = new CellValue("信眾姓名"), DataType = CellValues.String },
|
||||||
new Cell() { CellValue = new CellValue(item.sex), DataType = CellValues.String },
|
new Cell() { CellValue = new CellValue("性別"), DataType = CellValues.String },
|
||||||
new Cell() { CellValue = new CellValue(!isStrNull(item.identity_type)? tdesc[item.identity_type ?? 1] :""), DataType = CellValues.String },
|
new Cell() { CellValue = new CellValue("身分別"), DataType = CellValues.String },
|
||||||
new Cell() { CellValue = new CellValue(item.birthday.HasValue ? ValDate(item.birthday.Value).ToString("yyyy/MM/dd") : ""), DataType = CellValues.String },
|
new Cell() { CellValue = new CellValue("生日(國曆)"), DataType = CellValues.String },
|
||||||
new Cell() { CellValue = new CellValue(encrypt.DecryptAutoKey(item.phone)), DataType = CellValues.String },
|
new Cell() { CellValue = new CellValue("聯絡電話"), DataType = CellValues.String },
|
||||||
new Cell() { CellValue = new CellValue(encrypt.DecryptAutoKey(item.cellphone)), DataType = CellValues.String },
|
new Cell() { CellValue = new CellValue("手機號碼"), DataType = CellValues.String },
|
||||||
new Cell() { CellValue = new CellValue(item.refuge_area), DataType = CellValues.String },
|
new Cell() { CellValue = new CellValue("皈依道場"), DataType = CellValues.String },
|
||||||
new Cell() { CellValue = new CellValue(item.refuge_name), DataType = CellValues.String },
|
new Cell() { CellValue = new CellValue("皈依法名"), DataType = CellValues.String },
|
||||||
new Cell() { CellValue = new CellValue(item.refugedate.HasValue ? ValDate(item.refugedate.Value).ToString("yyyy/MM/dd") : ""), DataType = CellValues.String },
|
new Cell() { CellValue = new CellValue("皈依日期"), DataType = CellValues.String },
|
||||||
new Cell() { CellValue = new CellValue(item.join_date.HasValue ? ValDate(item.join_date.Value).ToString("yyyy/MM/dd") : ""), DataType = CellValues.String },
|
new Cell() { CellValue = new CellValue("加入日期"), DataType = CellValues.String },
|
||||||
new Cell() { CellValue = new CellValue(item.contactor), DataType = CellValues.String },
|
new Cell() { CellValue = new CellValue("緊急連絡人"), DataType = CellValues.String },
|
||||||
new Cell() { CellValue = new CellValue(encrypt.DecryptAutoKey(item.contactor_phone)), DataType = CellValues.String },
|
new Cell() { CellValue = new CellValue("緊急連絡人電話"), DataType = CellValues.String },
|
||||||
new Cell() { CellValue = new CellValue(item.blood), DataType = CellValues.String },
|
new Cell() { CellValue = new CellValue("血型"), DataType = CellValues.String },
|
||||||
new Cell() { CellValue = new CellValue(!isStrNull(item.country) ? item.country1.name_zh : ""), DataType = CellValues.String },
|
new Cell() { CellValue = new CellValue("國籍"), DataType = CellValues.String },
|
||||||
new Cell() { CellValue = new CellValue(item.address), DataType = CellValues.String },
|
new Cell() { CellValue = new CellValue("收件地址"), DataType = CellValues.String },
|
||||||
new Cell() { CellValue = new CellValue(item.introducer), DataType = CellValues.String },
|
new Cell() { CellValue = new CellValue("介紹人"), DataType = CellValues.String },
|
||||||
new Cell() { CellValue = new CellValue(item.socialid1), DataType = CellValues.String },
|
new Cell() { CellValue = new CellValue("LINE帳號"), DataType = CellValues.String },
|
||||||
new Cell() { CellValue = new CellValue(item.socialid2), DataType = CellValues.String },
|
new Cell() { CellValue = new CellValue("其它社群帳號"), DataType = CellValues.String },
|
||||||
new Cell() { CellValue = new CellValue(item.reg_time.HasValue ? ValDate(item.reg_time.Value).ToString("yyyy/MM/dd HH:mm:ss") : ""), DataType = CellValues.String }
|
new Cell() { CellValue = new CellValue("建檔日期"), DataType = CellValues.String }
|
||||||
,new Cell() { CellValue = new CellValue(encrypt.DecryptAutoKey(item.id_code)), DataType = CellValues.String }
|
, new Cell() { CellValue = new CellValue("身分證號"), DataType = CellValues.String }
|
||||||
//, new Cell() { CellValue = new CellValue(sha), DataType = CellValues.String }
|
//,new Cell() { CellValue = new CellValue("SHA"), DataType = CellValues.String }
|
||||||
);
|
);
|
||||||
sd.AppendChild(tr);
|
sd.AppendChild(tr);
|
||||||
|
|
||||||
|
|
||||||
|
MyWeb.encrypt encrypt = new MyWeb.encrypt();
|
||||||
|
Model.country country = new Model.country();
|
||||||
|
var tdesc = publicFun.enum_desc<Model.follower.type>();
|
||||||
|
foreach (var item in list)
|
||||||
|
{
|
||||||
|
//新增資料列
|
||||||
|
tr = new Row();
|
||||||
|
string s1, s2, sha;
|
||||||
|
s1 = encrypt.DecryptAutoKey(item.phone);
|
||||||
|
s2 = encrypt.DecryptAutoKey(item.id_code);
|
||||||
|
sha = encrypt.followerHash(s1, s2);
|
||||||
|
tr.Append(
|
||||||
|
new Cell() { CellValue = new CellValue(item.f_number), DataType = CellValues.String },
|
||||||
|
new Cell() { CellValue = new CellValue(item.u_name), DataType = CellValues.String },
|
||||||
|
new Cell() { CellValue = new CellValue(item.sex), DataType = CellValues.String },
|
||||||
|
new Cell() { CellValue = new CellValue(!isStrNull(item.identity_type) ? tdesc[item.identity_type ?? 1] : ""), DataType = CellValues.String },
|
||||||
|
new Cell() { CellValue = new CellValue(item.birthday.HasValue ? ValDate(item.birthday.Value).ToString("yyyy/MM/dd") : ""), DataType = CellValues.String },
|
||||||
|
new Cell() { CellValue = new CellValue(encrypt.DecryptAutoKey(item.phone)), DataType = CellValues.String },
|
||||||
|
new Cell() { CellValue = new CellValue(encrypt.DecryptAutoKey(item.cellphone)), DataType = CellValues.String },
|
||||||
|
new Cell() { CellValue = new CellValue(item.refuge_area), DataType = CellValues.String },
|
||||||
|
new Cell() { CellValue = new CellValue(item.refuge_name), DataType = CellValues.String },
|
||||||
|
new Cell() { CellValue = new CellValue(item.refugedate.HasValue ? ValDate(item.refugedate.Value).ToString("yyyy/MM/dd") : ""), DataType = CellValues.String },
|
||||||
|
new Cell() { CellValue = new CellValue(item.join_date.HasValue ? ValDate(item.join_date.Value).ToString("yyyy/MM/dd") : ""), DataType = CellValues.String },
|
||||||
|
new Cell() { CellValue = new CellValue(item.contactor), DataType = CellValues.String },
|
||||||
|
new Cell() { CellValue = new CellValue(encrypt.DecryptAutoKey(item.contactor_phone)), DataType = CellValues.String },
|
||||||
|
new Cell() { CellValue = new CellValue(item.blood), DataType = CellValues.String },
|
||||||
|
new Cell() { CellValue = new CellValue(!isStrNull(item.country) ? item.country1.name_zh : ""), DataType = CellValues.String },
|
||||||
|
new Cell() { CellValue = new CellValue(item.address), DataType = CellValues.String },
|
||||||
|
new Cell() { CellValue = new CellValue(item.introducer), DataType = CellValues.String },
|
||||||
|
new Cell() { CellValue = new CellValue(item.socialid1), DataType = CellValues.String },
|
||||||
|
new Cell() { CellValue = new CellValue(item.socialid2), DataType = CellValues.String },
|
||||||
|
new Cell() { CellValue = new CellValue(item.reg_time.HasValue ? ValDate(item.reg_time.Value).ToString("yyyy/MM/dd HH:mm:ss") : ""), DataType = CellValues.String }
|
||||||
|
, new Cell() { CellValue = new CellValue(encrypt.DecryptAutoKey(item.id_code)), DataType = CellValues.String }
|
||||||
|
//, new Cell() { CellValue = new CellValue(sha), DataType = CellValues.String }
|
||||||
|
);
|
||||||
|
sd.AppendChild(tr);
|
||||||
|
}
|
||||||
|
|
||||||
|
//空一列
|
||||||
|
tr = new Row();
|
||||||
|
sd.AppendChild(tr);
|
||||||
|
|
||||||
|
//匯出資訊
|
||||||
|
string _data = "匯出時間 : " + DateTime.Now.ToString("yyyy/MM/dd HH:mm:ss");
|
||||||
|
_data += " " + admin.info.u_id;
|
||||||
|
tr = new Row();
|
||||||
|
tr.Append(
|
||||||
|
new Cell() { CellValue = new CellValue(_data), DataType = CellValues.String }
|
||||||
|
);
|
||||||
|
sd.AppendChild(tr);
|
||||||
|
|
||||||
|
_data = "匯出條件 : " + (!isStrNull(_query) ? _query : "-");
|
||||||
|
tr = new Row();
|
||||||
|
tr.Append(
|
||||||
|
new Cell() { CellValue = new CellValue(_data), DataType = CellValues.String }
|
||||||
|
);
|
||||||
|
sd.AppendChild(tr);
|
||||||
|
|
||||||
|
|
||||||
|
Model.admin_log admin_log = new Model.admin_log();
|
||||||
|
admin_log.writeLog(admin.info.u_id, (int)Model.admin_log.Systems.Follower, (int)Model.admin_log.Status.Excel, admin_log.LogViewBtn(list.Select(x => x.f_number + x.u_name).ToList()));
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
HttpContext.Current.Response.Clear();
|
||||||
|
HttpContext.Current.Response.AddHeader("content-disposition", "attachment; filename=信眾_data.xlsx");
|
||||||
|
HttpContext.Current.Response.ContentType = "application/vnd.openxmlformats-officedocument.spreadsheetml.sheet";
|
||||||
|
HttpContext.Current.Response.BinaryWrite(memoryStream.ToArray());
|
||||||
|
HttpContext.Current.Response.End();
|
||||||
|
|
||||||
//空一列
|
hid_err_msg.Value = "success";
|
||||||
tr = new Row();
|
|
||||||
sd.AppendChild(tr);
|
|
||||||
|
|
||||||
//匯出資訊
|
|
||||||
string _data = "匯出時間 : " + DateTime.Now.ToString("yyyy/MM/dd HH:mm:ss");
|
|
||||||
_data += " " + admin.info.u_id;
|
|
||||||
tr = new Row();
|
|
||||||
tr.Append(
|
|
||||||
new Cell() { CellValue = new CellValue(_data), DataType = CellValues.String }
|
|
||||||
);
|
|
||||||
sd.AppendChild(tr);
|
|
||||||
|
|
||||||
_data = "匯出條件 : " + (!isStrNull(_query) ? _query : "-");
|
|
||||||
tr = new Row();
|
|
||||||
tr.Append(
|
|
||||||
new Cell() { CellValue = new CellValue(_data), DataType = CellValues.String }
|
|
||||||
);
|
|
||||||
sd.AppendChild(tr);
|
|
||||||
|
|
||||||
|
|
||||||
Model.admin_log admin_log = new Model.admin_log();
|
|
||||||
admin_log.writeLog(admin.info.u_id, (int)Model.admin_log.Systems.Follower, (int)Model.admin_log.Status.Excel, admin_log.LogViewBtn(list.Select(x => x.f_number + x.u_name).ToList()));
|
|
||||||
|
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
ScriptMsg2("查無資料");
|
//ScriptMsg2("查無資料");
|
||||||
|
hid_err_msg.Value = "nodata";
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
else if (isPrintMode)
|
||||||
|
{
|
||||||
|
string urlParams = "";
|
||||||
|
int selYear = !string.IsNullOrEmpty(hid_print_year.Value) ? int.Parse(hid_print_year.Value) : 0;
|
||||||
|
int selMonth = !string.IsNullOrEmpty(hid_print_month.Value) ? int.Parse(hid_print_month.Value) : 0;
|
||||||
|
int selSeason = !string.IsNullOrEmpty(hid_print_season.Value) ? int.Parse(hid_print_season.Value) : 0;
|
||||||
|
string selMode = !string.IsNullOrEmpty(hid_print_mode.Value) ? hid_print_mode.Value : "";
|
||||||
|
|
||||||
HttpContext.Current.Response.Clear();
|
var qry = _db.followers.AsQueryable();
|
||||||
HttpContext.Current.Response.AddHeader("content-disposition", "attachment; filename=信眾_data.xlsx");
|
if (selYear > 0)
|
||||||
HttpContext.Current.Response.ContentType = "application/vnd.openxmlformats-officedocument.spreadsheetml.sheet";
|
{
|
||||||
HttpContext.Current.Response.BinaryWrite(memoryStream.ToArray());
|
urlParams += "&year=" + selYear;
|
||||||
HttpContext.Current.Response.End();
|
}
|
||||||
|
if (selMode == "mm" && selMonth > 0)
|
||||||
|
{
|
||||||
|
urlParams += "&month=" + selMonth;
|
||||||
|
}
|
||||||
|
else if (selMode == "ss" && selSeason > 0)
|
||||||
|
{
|
||||||
|
urlParams += "&season=" + selSeason;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (list.Count > 0)
|
||||||
|
{
|
||||||
|
hid_err_msg.Value = "success";
|
||||||
|
hid_print_year.Value = selYear.ToString();
|
||||||
|
hid_print_month.Value = selMonth.ToString();
|
||||||
|
hid_print_season.Value = selSeason.ToString();
|
||||||
|
hid_print_mode.Value = selMode;
|
||||||
|
|
||||||
|
string script = $@"window.open('print.aspx?{urlParams}&mode={selMode}', '列印信眾資料', 'noopener,noreferrer');";
|
||||||
|
ScriptManager.RegisterStartupScript(this, GetType(), "ExecutePrint", script, true);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
hid_err_msg.Value = "nodata";
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
protected List<Model.follower> searchData(ref string _query)
|
protected List<Model.follower> searchData(ref string _query, bool isManagementMode = false)
|
||||||
{
|
{
|
||||||
|
|
||||||
//查詢要匯出的資料
|
//查詢要匯出的資料
|
||||||
var qry = _db.followers.AsQueryable();
|
var qry = _db.followers.AsQueryable();
|
||||||
|
|
||||||
//紀錄匯出條件
|
// 管理報表
|
||||||
if (!isStrNull(s_f_number.Value))
|
if (isManagementMode)
|
||||||
{
|
{
|
||||||
qry = qry.Where(o => o.f_number.Contains(s_f_number.Value.Trim()));
|
int selYear = !string.IsNullOrEmpty(hid_print_year.Value) ? int.Parse(hid_print_year.Value) : 0;
|
||||||
|
int selMonth = !string.IsNullOrEmpty(hid_print_month.Value) ? int.Parse(hid_print_month.Value) : 0;
|
||||||
|
int selSeason = !string.IsNullOrEmpty(hid_print_season.Value) ? int.Parse(hid_print_season.Value) : 0;
|
||||||
|
string selMode = !string.IsNullOrEmpty(hid_print_mode.Value) ? hid_print_mode.Value : "";
|
||||||
|
|
||||||
|
if (selYear > 0)
|
||||||
|
{
|
||||||
|
qry = qry.Where(o => o.join_date.HasValue && o.join_date.Value.Year == selYear);
|
||||||
|
_query += "年份:" + selYear + "\n";
|
||||||
|
}
|
||||||
|
if (selMode == "mm" && selMonth > 0)
|
||||||
|
{
|
||||||
|
qry = qry.Where(o => o.join_date.HasValue && o.join_date.Value.Month == selMonth);
|
||||||
|
_query += "月份:" + selMonth + "\n";
|
||||||
|
}
|
||||||
|
else if (selMode == "ss" && selSeason > 0)
|
||||||
|
{
|
||||||
|
if (selSeason == 1)
|
||||||
|
{
|
||||||
|
qry = qry.Where(o => o.join_date.HasValue)
|
||||||
|
.Where(o => o.join_date.Value.Month == 1 || o.join_date.Value.Month == 2 || o.join_date.Value.Month == 3);
|
||||||
|
}
|
||||||
|
else if (selSeason == 2)
|
||||||
|
{
|
||||||
|
qry = qry.Where(o => o.join_date.HasValue)
|
||||||
|
.Where(o => o.join_date.Value.Month == 4 || o.join_date.Value.Month == 5 || o.join_date.Value.Month == 6);
|
||||||
|
}
|
||||||
|
else if (selSeason == 3)
|
||||||
|
{
|
||||||
|
qry = qry.Where(o => o.join_date.HasValue)
|
||||||
|
.Where(o => o.join_date.Value.Month == 7 || o.join_date.Value.Month == 8 || o.join_date.Value.Month == 9);
|
||||||
|
}
|
||||||
|
else if (selSeason == 4)
|
||||||
|
{
|
||||||
|
qry = qry.Where(o => o.join_date.HasValue)
|
||||||
|
.Where(o => o.join_date.Value.Month == 10 || o.join_date.Value.Month == 11 || o.join_date.Value.Month == 12);
|
||||||
|
}
|
||||||
|
|
||||||
|
_query += "季度:" + selSeason + "\n";
|
||||||
|
}
|
||||||
|
|
||||||
|
qry = qry.OrderByDescending(o => o.num);
|
||||||
|
return qry.ToList();
|
||||||
|
}
|
||||||
|
else
|
||||||
|
// 匯出查詢資料
|
||||||
|
{
|
||||||
|
//紀錄匯出條件
|
||||||
|
if (!isStrNull(s_f_number.Value))
|
||||||
|
{
|
||||||
|
qry = qry.Where(o => o.f_number.Contains(s_f_number.Value.Trim()));
|
||||||
|
|
||||||
_query += "信眾編號:" + s_f_number.Value.Trim() + "\n";
|
_query += "信眾編號:" + s_f_number.Value.Trim() + "\n";
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!isStrNull(s_u_name.Value))
|
if (!isStrNull(s_u_name.Value))
|
||||||
{
|
{
|
||||||
qry = qry.Where(o => o.u_name.Contains(s_u_name.Value.Trim()));
|
qry = qry.Where(o => o.u_name.Contains(s_u_name.Value.Trim()));
|
||||||
|
|
||||||
_query += "信眾姓名:" + s_u_name.Value.Trim() + "\n";
|
_query += "信眾姓名:" + s_u_name.Value.Trim() + "\n";
|
||||||
|
|
||||||
}
|
|
||||||
if (!isStrNull(s_address.Value))
|
|
||||||
{
|
|
||||||
qry = qry.Where(o => o.address.Contains(s_address.Value.Trim()));
|
|
||||||
_query += "地址:" + s_u_name.Value.Trim() + "\n";
|
|
||||||
}
|
|
||||||
|
|
||||||
// 電話/證號搜尋 (使用 search_keywords HEX 編碼)
|
|
||||||
if (!isStrNull(s_phone_idcode.Value) && GlobalVariables.UseSearchKeywords)
|
|
||||||
{
|
|
||||||
MyWeb.encrypt encrypt = new MyWeb.encrypt();
|
|
||||||
string hexSearch = encrypt.ConvertToHex(s_phone_idcode.Value.Trim());
|
|
||||||
if (!string.IsNullOrEmpty(hexSearch))
|
|
||||||
{
|
|
||||||
qry = qry.Where(o => o.search_keywords != null && o.search_keywords.Contains(hexSearch));
|
|
||||||
_query += "電話/證號:" + s_phone_idcode.Value.Trim() + "\n";
|
|
||||||
}
|
}
|
||||||
}
|
if (!isStrNull(s_address.Value))
|
||||||
|
{
|
||||||
|
qry = qry.Where(o => o.address.Contains(s_address.Value.Trim()));
|
||||||
|
_query += "地址:" + s_address.Value.Trim() + "\n";
|
||||||
|
}
|
||||||
|
|
||||||
if (!isStrNull(s_birthday.Value) && isDate(s_birthday.Value))
|
// 電話/證號搜尋 (使用 search_keywords HEX 編碼)
|
||||||
{
|
if (!isStrNull(s_phone_idcode.Value) && GlobalVariables.UseSearchKeywords)
|
||||||
qry = qry.Where(o => o.birthday >= ValDate(s_birthday.Value));
|
{
|
||||||
_query += "生日(起):" + s_birthday.Value.Trim() + "\n";
|
MyWeb.encrypt encrypt = new MyWeb.encrypt();
|
||||||
|
string hexSearch = encrypt.ConvertToHex(s_phone_idcode.Value.Trim());
|
||||||
|
if (!string.IsNullOrEmpty(hexSearch))
|
||||||
|
{
|
||||||
|
qry = qry.Where(o => o.search_keywords != null && o.search_keywords.Contains(hexSearch));
|
||||||
|
_query += "電話/證號:" + s_phone_idcode.Value.Trim() + "\n";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!isStrNull(s_birthday.Value) && isDate(s_birthday.Value))
|
||||||
|
{
|
||||||
|
var tmp_s_birthday = ValDate(s_birthday.Value);
|
||||||
|
qry = qry.Where(o => o.birthday >= tmp_s_birthday);
|
||||||
|
_query += "生日(起):" + s_birthday.Value.Trim() + "\n";
|
||||||
|
}
|
||||||
|
if (!isStrNull(s_birthday2.Value) && isDate(s_birthday2.Value))
|
||||||
|
{
|
||||||
|
var tmp_s_birthday2 = Convert.ToDateTime(s_birthday2.Value).AddDays(1);
|
||||||
|
qry = qry.Where(o => o.birthday < tmp_s_birthday2);
|
||||||
|
_query += "生日(訖):" + s_birthday2.Value.Trim() + "\n";
|
||||||
|
}
|
||||||
|
qry = qry.OrderByDescending(o => o.num);
|
||||||
|
return qry.ToList();
|
||||||
}
|
}
|
||||||
if (!isStrNull(s_birthday2.Value) && isDate(s_birthday2.Value))
|
|
||||||
{
|
|
||||||
qry = qry.Where(o => o.birthday < Convert.ToDateTime(s_birthday2.Value).AddDays(1));
|
|
||||||
_query += "生日(訖):" + s_birthday2.Value.Trim() + "\n";
|
|
||||||
}
|
|
||||||
qry = qry.OrderByDescending(o => o.num);
|
|
||||||
return qry.ToList();
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -8,6 +8,7 @@
|
|||||||
<span>信眾姓名:</span><asp:Literal runat="server" ID="username"></asp:Literal>
|
<span>信眾姓名:</span><asp:Literal runat="server" ID="username"></asp:Literal>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
<a href="index.aspx" class="btn btn-outline-secondary">返回</a>
|
||||||
</asp:Content>
|
</asp:Content>
|
||||||
<asp:Content ID="Content3" ContentPlaceHolderID="ContentPlaceHolder1" Runat="Server">
|
<asp:Content ID="Content3" ContentPlaceHolderID="ContentPlaceHolder1" Runat="Server">
|
||||||
<div class="container-fluid">
|
<div class="container-fluid">
|
||||||
|
|||||||
@@ -4,10 +4,11 @@
|
|||||||
</asp:Content>
|
</asp:Content>
|
||||||
<asp:Content ID="Content2" ContentPlaceHolderID="page_nav" Runat="Server">
|
<asp:Content ID="Content2" ContentPlaceHolderID="page_nav" Runat="Server">
|
||||||
<div class="scroll-nav nav nav-tabs mb-2 mb-sm-0 d-none d-sm-flex">
|
<div class="scroll-nav nav nav-tabs mb-2 mb-sm-0 d-none d-sm-flex">
|
||||||
<div class="ms-3">
|
<div class="ms-3">
|
||||||
<span>信眾姓名:</span><asp:Literal runat="server" ID="username"></asp:Literal>
|
<span>信眾姓名:</span><asp:Literal runat="server" ID="username"></asp:Literal>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
<a href="order_record.aspx?userid=<%=Request["userid"] %>" class="btn btn-outline-secondary">返回</a>
|
||||||
</asp:Content>
|
</asp:Content>
|
||||||
<asp:Content ID="Content3" ContentPlaceHolderID="ContentPlaceHolder1" Runat="Server">
|
<asp:Content ID="Content3" ContentPlaceHolderID="ContentPlaceHolder1" Runat="Server">
|
||||||
<div class="container-fluid">
|
<div class="container-fluid">
|
||||||
|
|||||||
@@ -3,6 +3,7 @@ using DocumentFormat.OpenXml.Vml.Office;
|
|||||||
using OfficeOpenXml.FormulaParsing.Excel.Functions.Information;
|
using OfficeOpenXml.FormulaParsing.Excel.Functions.Information;
|
||||||
using System;
|
using System;
|
||||||
using System.Collections.Generic;
|
using System.Collections.Generic;
|
||||||
|
using System.Diagnostics;
|
||||||
using System.Linq;
|
using System.Linq;
|
||||||
using System.Web;
|
using System.Web;
|
||||||
using System.Web.UI;
|
using System.Web.UI;
|
||||||
@@ -60,7 +61,8 @@ public partial class admin_follower_print_ : System.Web.UI.Page
|
|||||||
if (!string.IsNullOrEmpty(Request["birthday2"]))
|
if (!string.IsNullOrEmpty(Request["birthday2"]))
|
||||||
{
|
{
|
||||||
DateTime birthday2Param = Convert.ToDateTime(Request["birthday2"].Trim());
|
DateTime birthday2Param = Convert.ToDateTime(Request["birthday2"].Trim());
|
||||||
qry = qry.Where(o => o.birthday < birthday2Param.AddDays(1));
|
var tmpBirthday2Param = birthday2Param.AddDays(1);
|
||||||
|
qry = qry.Where(o => o.birthday < tmpBirthday2Param);
|
||||||
_query += "生日(訖):" + birthday2Param.ToString("yyyy/MM/dd") + "\n";
|
_query += "生日(訖):" + birthday2Param.ToString("yyyy/MM/dd") + "\n";
|
||||||
}
|
}
|
||||||
// ❌ 錯誤寫法: _db.countries.Where(x => x.ID == Request["country"].ToString())
|
// ❌ 錯誤寫法: _db.countries.Where(x => x.ID == Request["country"].ToString())
|
||||||
@@ -86,6 +88,18 @@ public partial class admin_follower_print_ : System.Web.UI.Page
|
|||||||
_query += "國家:" + (_db.countries.Where(x => x.ID == country2Id).Select(x => x.name_zh).FirstOrDefault() ?? "") + "\n";
|
_query += "國家:" + (_db.countries.Where(x => x.ID == country2Id).Select(x => x.name_zh).FirstOrDefault() ?? "") + "\n";
|
||||||
}
|
}
|
||||||
|
|
||||||
|
string phone_ipcode = Request["phone_idcode"]?.ToString();
|
||||||
|
if (!string.IsNullOrEmpty(phone_ipcode) && GlobalVariables.UseSearchKeywords)
|
||||||
|
{
|
||||||
|
MyWeb.encrypt encrypt = new MyWeb.encrypt();
|
||||||
|
string hexSearch = encrypt.ConvertToHex(phone_ipcode.Trim());
|
||||||
|
if (!string.IsNullOrEmpty(hexSearch))
|
||||||
|
{
|
||||||
|
qry = qry.Where(o => o.search_keywords != null && o.search_keywords.Contains(hexSearch));
|
||||||
|
_query += "電話/證號:" + phone_ipcode.Trim() + "\n";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
//管理報表
|
//管理報表
|
||||||
if (!string.IsNullOrEmpty(Request["year"]))
|
if (!string.IsNullOrEmpty(Request["year"]))
|
||||||
{
|
{
|
||||||
|
|||||||
+36
-16
@@ -230,7 +230,7 @@
|
|||||||
{ id: 'f_number', title: '編號' },
|
{ id: 'f_number', title: '編號' },
|
||||||
{ id: 'u_name', title: '姓名' },
|
{ id: 'u_name', title: '姓名' },
|
||||||
{ id: 'address', title: '地址' },
|
{ id: 'address', title: '地址' },
|
||||||
{ id: 'onlyfamily', title: '只查親屬'},
|
{ id: 'onlyfamily', title: '只查親屬' },
|
||||||
],
|
],
|
||||||
api_url: HTTP_HOST + 'api/follower/GetList',
|
api_url: HTTP_HOST + 'api/follower/GetList',
|
||||||
columns: [
|
columns: [
|
||||||
@@ -314,10 +314,10 @@
|
|||||||
birthday: '',
|
birthday: '',
|
||||||
phoneDes: '',
|
phoneDes: '',
|
||||||
demo: '',
|
demo: '',
|
||||||
appellation_id_selected :
|
appellation_id_selected:
|
||||||
{
|
{
|
||||||
text : '',
|
text: '',
|
||||||
val : 0,
|
val: 0,
|
||||||
},
|
},
|
||||||
|
|
||||||
},
|
},
|
||||||
@@ -372,7 +372,7 @@
|
|||||||
],
|
],
|
||||||
tabletsDetail: { multiSort: false },
|
tabletsDetail: { multiSort: false },
|
||||||
tabletTable: {
|
tabletTable: {
|
||||||
Loading:true,
|
Loading: true,
|
||||||
disableButton: true,
|
disableButton: true,
|
||||||
searchDetail: '',
|
searchDetail: '',
|
||||||
headersDetail: [
|
headersDetail: [
|
||||||
@@ -394,11 +394,11 @@
|
|||||||
num: 0,
|
num: 0,
|
||||||
f_num: 0,
|
f_num: 0,
|
||||||
type: this.selectedTabletType,
|
type: this.selectedTabletType,
|
||||||
title:'',
|
title: '',
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
//新:家人
|
//新:家人
|
||||||
family:{
|
family: {
|
||||||
dialog: false,
|
dialog: false,
|
||||||
isEditing: false,
|
isEditing: false,
|
||||||
is_tw: true,
|
is_tw: true,
|
||||||
@@ -420,8 +420,8 @@
|
|||||||
chinese_year: "",
|
chinese_year: "",
|
||||||
zodiac: "",
|
zodiac: "",
|
||||||
birth_time: "",
|
birth_time: "",
|
||||||
city:"",
|
city: "",
|
||||||
area:"",
|
area: "",
|
||||||
address: "",
|
address: "",
|
||||||
phone: "",
|
phone: "",
|
||||||
mobile: "",
|
mobile: "",
|
||||||
@@ -440,8 +440,8 @@
|
|||||||
chinese_year: "",
|
chinese_year: "",
|
||||||
zodiac: "",
|
zodiac: "",
|
||||||
birth_time: "",
|
birth_time: "",
|
||||||
city:"",
|
city: "",
|
||||||
area:"",
|
area: "",
|
||||||
address: "",
|
address: "",
|
||||||
phone: "",
|
phone: "",
|
||||||
mobile: "",
|
mobile: "",
|
||||||
@@ -585,7 +585,7 @@
|
|||||||
this.search_dialog.list = response.data.list
|
this.search_dialog.list = response.data.list
|
||||||
this.search_dialog.count = response.data.count
|
this.search_dialog.count = response.data.count
|
||||||
this.search_dialog.loading = false
|
this.search_dialog.loading = false
|
||||||
|
console.log(this.search_dialog.list)
|
||||||
})
|
})
|
||||||
.catch(error => {
|
.catch(error => {
|
||||||
console.log(error)
|
console.log(error)
|
||||||
@@ -1318,13 +1318,32 @@
|
|||||||
$('.tab-pane,.edit_Click').removeClass('pe-none'); // 移除 pe-none 類,允許編輯
|
$('.tab-pane,.edit_Click').removeClass('pe-none'); // 移除 pe-none 類,允許編輯
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
let isComposing = false;
|
||||||
|
const cellphoneInput = document.querySelector('[id$="cellphone"]');
|
||||||
|
if (cellphoneInput) {
|
||||||
|
cellphoneInput.addEventListener('compositionstart', () => {
|
||||||
|
isComposing = true;
|
||||||
|
});
|
||||||
|
cellphoneInput.addEventListener('compositionend', (e) => {
|
||||||
|
isComposing = false;
|
||||||
|
formatCellphone(e.target);
|
||||||
|
});
|
||||||
|
cellphoneInput.addEventListener('input', (e) => {
|
||||||
|
if (!isComposing) {
|
||||||
|
formatCellphone(e.target);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
</script>
|
</script>
|
||||||
</asp:Content>
|
</asp:Content>
|
||||||
<asp:Content ID="Content3" ContentPlaceHolderID="page_nav" runat="Server">
|
<asp:Content ID="Content3" ContentPlaceHolderID="page_nav" runat="Server">
|
||||||
<div class="scroll-nav nav nav-tabs mb-2 mb-sm-0 d-none d-sm-flex">
|
<div class="scroll-nav nav nav-tabs mb-2 mb-sm-0 d-none d-sm-flex">
|
||||||
<template v-if="follower_id !='' "> {{titleword()}} </template>
|
<template v-if="follower_id !='' "> {{titleword()}} </template>
|
||||||
</div>
|
</div>
|
||||||
<div class="d-flex align-items-center">
|
<div class="">
|
||||||
<div class="form-check me-3 d-none" id="editCheckboxContainer">
|
<div class="form-check me-3 d-none" id="editCheckboxContainer">
|
||||||
<input class="form-check-input" type="checkbox" id="editCheckbox">
|
<input class="form-check-input" type="checkbox" id="editCheckbox">
|
||||||
<label class="form-check-label" for="editCheckbox">
|
<label class="form-check-label" for="editCheckbox">
|
||||||
@@ -1332,8 +1351,8 @@
|
|||||||
</label>
|
</label>
|
||||||
</div>
|
</div>
|
||||||
<asp:Button ID="add" runat="server" Text="送出" OnClick="add_Click" CssClass="btn btn-primary edit_Click noedit" />
|
<asp:Button ID="add" runat="server" Text="送出" OnClick="add_Click" CssClass="btn btn-primary edit_Click noedit" />
|
||||||
<asp:Button ID="edit" runat="server" Text="修改" Visible="false" OnClick="edit_Click" CssClass="btn btn-primary edit_Click noedit" />
|
<asp:Button ID="edit" runat="server" Text="儲存" Visible="false" OnClick="edit_Click" CssClass="btn btn-primary edit_Click noedit" />
|
||||||
<asp:Button ID="goback" runat="server" Text="回列表" Visible="false" CausesValidation="false" OnClick="goback_Click" CssClass="btn btn-outline-secondary" />
|
<asp:Button ID="goback" runat="server" Text="取消" Visible="true" CausesValidation="false" OnClick="goback_Click" CssClass="btn btn-outline-secondary" />
|
||||||
</div>
|
</div>
|
||||||
</asp:Content>
|
</asp:Content>
|
||||||
<asp:Content ID="Content2" ContentPlaceHolderID="ContentPlaceHolder1" runat="Server">
|
<asp:Content ID="Content2" ContentPlaceHolderID="ContentPlaceHolder1" runat="Server">
|
||||||
@@ -1412,7 +1431,7 @@
|
|||||||
</div>
|
</div>
|
||||||
<label class="col-sm-2 col-lg-1 col-form-label">手機號碼<asp:Literal ID="cellphoneReqStar" runat="server" Text=" *"></asp:Literal></label>
|
<label class="col-sm-2 col-lg-1 col-form-label">手機號碼<asp:Literal ID="cellphoneReqStar" runat="server" Text=" *"></asp:Literal></label>
|
||||||
<div class="col-sm-10 col-lg-3">
|
<div class="col-sm-10 col-lg-3">
|
||||||
<asp:TextBox ID="cellphone" MaxLength="12" runat="server" CssClass="form-control" data-encrypt="Y" placeholder="聯絡電話與手機號碼請至少填寫一項" oninput="formatCellphone(this)"></asp:TextBox>
|
<asp:TextBox ID="cellphone" MaxLength="12" runat="server" CssClass="form-control" data-encrypt="Y" placeholder="聯絡電話與手機號碼請至少填寫一項"></asp:TextBox>
|
||||||
<asp:RegularExpressionValidator ControlToValidate="cellphone" Display="Dynamic" ErrorMessage="格式有誤" ID="RegularExpressionValidator2" runat="server" SetFocusOnError="true" ValidationExpression="^09\d{2}-?\d{3}-?\d{3}$" />
|
<asp:RegularExpressionValidator ControlToValidate="cellphone" Display="Dynamic" ErrorMessage="格式有誤" ID="RegularExpressionValidator2" runat="server" SetFocusOnError="true" ValidationExpression="^09\d{2}-?\d{3}-?\d{3}$" />
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
@@ -2155,4 +2174,5 @@
|
|||||||
</template>
|
</template>
|
||||||
</v-snackbar>
|
</v-snackbar>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
</asp:Content>
|
</asp:Content>
|
||||||
@@ -1,21 +1,26 @@
|
|||||||
using System;
|
using Model;
|
||||||
|
using Newtonsoft.Json;
|
||||||
|
using System;
|
||||||
using System.Collections;
|
using System.Collections;
|
||||||
using System.Collections.Generic;
|
using System.Collections.Generic;
|
||||||
|
using System.Configuration;
|
||||||
using System.Data;
|
using System.Data;
|
||||||
|
using System.Data.Entity;
|
||||||
using System.Data.OleDb;
|
using System.Data.OleDb;
|
||||||
|
using System.Diagnostics;
|
||||||
|
using System.Globalization;
|
||||||
|
using System.IO;
|
||||||
|
using System.Linq;
|
||||||
using System.Web;
|
using System.Web;
|
||||||
using System.Web.UI;
|
using System.Web.UI;
|
||||||
using System.Web.UI.WebControls;
|
using System.Web.UI.WebControls;
|
||||||
using System.Configuration;
|
|
||||||
using System.IO;
|
|
||||||
using System.Linq;
|
|
||||||
using System.Globalization;
|
|
||||||
using Model;
|
|
||||||
|
|
||||||
public partial class admin_follower_reg : MyWeb.config
|
public partial class admin_follower_reg : MyWeb.config
|
||||||
{
|
{
|
||||||
private Model.ezEntities _db = new Model.ezEntities();
|
private Model.ezEntities _db = new Model.ezEntities();
|
||||||
public ArrayList _tmp = new ArrayList();
|
public ArrayList _tmp = new ArrayList();
|
||||||
|
public bool isDataChanged = false;
|
||||||
|
public bool isAutoNumbering = ConfigurationManager.AppSettings["IsAutoNumbering"].ToString() == "true" ? true : false;
|
||||||
protected void Page_Load(object sender, EventArgs e)
|
protected void Page_Load(object sender, EventArgs e)
|
||||||
{
|
{
|
||||||
CallAjax();
|
CallAjax();
|
||||||
@@ -29,6 +34,11 @@ public partial class admin_follower_reg : MyWeb.config
|
|||||||
|
|
||||||
if (isStrNull(Request["num"]))
|
if (isStrNull(Request["num"]))
|
||||||
{
|
{
|
||||||
|
if (!isAutoNumbering)
|
||||||
|
{
|
||||||
|
f_number.ReadOnly = false;
|
||||||
|
}
|
||||||
|
|
||||||
if (!isStrNull(Request["leader"]))
|
if (!isStrNull(Request["leader"]))
|
||||||
{
|
{
|
||||||
int _num = Val(Request["leader"]);
|
int _num = Val(Request["leader"]);
|
||||||
@@ -50,9 +60,14 @@ public partial class admin_follower_reg : MyWeb.config
|
|||||||
//預設國籍
|
//預設國籍
|
||||||
country.Value = "158";
|
country.Value = "158";
|
||||||
country_txt.Value = "中華民國(台灣)";
|
country_txt.Value = "中華民國(台灣)";
|
||||||
|
|
||||||
|
// 預設加入日期
|
||||||
|
join_date.Text = DateTime.Now.ToString("yyyy-MM-dd");
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
f_number.ReadOnly = true;
|
||||||
|
|
||||||
int _num = Val(Request["num"]);
|
int _num = Val(Request["num"]);
|
||||||
var prod = qry.Where(q => q.num == _num).FirstOrDefault();
|
var prod = qry.Where(q => q.num == _num).FirstOrDefault();
|
||||||
if (prod != null)
|
if (prod != null)
|
||||||
@@ -206,8 +221,11 @@ public partial class admin_follower_reg : MyWeb.config
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
// 使用新的 generate_f_number 方法,已內建重號檢查和重試機制
|
if (isAutoNumbering)
|
||||||
followers.f_number = follower.generate_f_number(sex.SelectedValue);
|
{
|
||||||
|
// 使用新的 generate_f_number 方法,已內建重號檢查和重試機制
|
||||||
|
followers.f_number = follower.generate_f_number(sex.SelectedValue);
|
||||||
|
}
|
||||||
followers.identity_type = Val(identity_type.SelectedValue);
|
followers.identity_type = Val(identity_type.SelectedValue);
|
||||||
if(!isStrNull(leader.Value)) followers.leader = Val(leader.Value);
|
if(!isStrNull(leader.Value)) followers.leader = Val(leader.Value);
|
||||||
if (!isStrNull(country.Value)) followers.country = country.Value;
|
if (!isStrNull(country.Value)) followers.country = country.Value;
|
||||||
@@ -240,6 +258,8 @@ public partial class admin_follower_reg : MyWeb.config
|
|||||||
Model.admin_log admin_log = new Model.admin_log();
|
Model.admin_log admin_log = new Model.admin_log();
|
||||||
admin_log.writeLog(admin.info.u_id, (int)Model.admin_log.Systems.Follower, (int)Model.admin_log.Status.Insert, f_number.Text + u_name.Text);
|
admin_log.writeLog(admin.info.u_id, (int)Model.admin_log.Systems.Follower, (int)Model.admin_log.Status.Insert, f_number.Text + u_name.Text);
|
||||||
|
|
||||||
|
Session["LastAddedID"] = followers.f_number;
|
||||||
|
|
||||||
Response.Redirect("index.aspx");
|
Response.Redirect("index.aspx");
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
@@ -310,7 +330,7 @@ public partial class admin_follower_reg : MyWeb.config
|
|||||||
followers.sex = sex.SelectedValue;
|
followers.sex = sex.SelectedValue;
|
||||||
followers.blood = blood.SelectedValue;
|
followers.blood = blood.SelectedValue;
|
||||||
followers.tab = tab.Value.Trim(',');
|
followers.tab = tab.Value.Trim(',');
|
||||||
followers.admin_log = admin.info.u_id + " " + DateTime.Now.ToString("yyyy/MM/dd HH:mm:ss");
|
//followers.admin_log = admin.info.u_id + " " + DateTime.Now.ToString("yyyy/MM/dd HH:mm:ss");
|
||||||
followers.follower_hash = encrypt.followerHash(followers.phone, followers.id_code);
|
followers.follower_hash = encrypt.followerHash(followers.phone, followers.id_code);
|
||||||
|
|
||||||
// 如果啟用 search_keywords 功能,生成並更新 search_keywords
|
// 如果啟用 search_keywords 功能,生成並更新 search_keywords
|
||||||
@@ -319,13 +339,51 @@ public partial class admin_follower_reg : MyWeb.config
|
|||||||
followers.search_keywords = encrypt.GenerateSearchKeywords(followers);
|
followers.search_keywords = encrypt.GenerateSearchKeywords(followers);
|
||||||
}
|
}
|
||||||
|
|
||||||
_db.SaveChanges();
|
// 檢查是否有修改資料
|
||||||
|
var entry = _db.Entry(followers);
|
||||||
|
this.isDataChanged = entry.CurrentValues.PropertyNames.Any(name =>
|
||||||
|
{
|
||||||
|
if (name == "admin_log" || name == "follower_hash")
|
||||||
|
return false;
|
||||||
|
|
||||||
Model.admin_log admin_log = new Model.admin_log();
|
var originalVal = entry.OriginalValues[name]?.ToString();
|
||||||
admin_log.writeLog(admin.info.u_id, (int)Model.admin_log.Systems.Follower, (int)Model.admin_log.Status.Update, f_number.Text + u_name.Text);
|
var currentVal = entry.CurrentValues[name]?.ToString();
|
||||||
|
|
||||||
Response.Redirect("index.aspx?page=" + Convert.ToString(Request["page"]));
|
// 針對加密欄位進行特殊處理
|
||||||
|
bool isEncryptedField = (name == "phone" || name == "id_code");
|
||||||
|
|
||||||
|
if (isEncryptedField)
|
||||||
|
{
|
||||||
|
string originalPlain = !string.IsNullOrEmpty(originalVal) ? encrypt.DecryptAutoKey(originalVal) : "";
|
||||||
|
string currentPlain = !string.IsNullOrEmpty(currentVal) ? encrypt.DecryptAutoKey(currentVal) : "";
|
||||||
|
return originalPlain.Trim() != currentPlain.Trim();
|
||||||
|
}
|
||||||
|
|
||||||
|
return !object.Equals(originalVal, currentVal);
|
||||||
|
});
|
||||||
|
|
||||||
|
if (this.isDataChanged)
|
||||||
|
{
|
||||||
|
followers.admin_log = admin.info.u_id + " " + DateTime.Now.ToString("yyyy/MM/dd HH:mm:ss");
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
entry.State = EntityState.Unchanged;
|
||||||
|
}
|
||||||
|
|
||||||
|
int isDataSaved = _db.SaveChanges();
|
||||||
|
if (isDataSaved > 0)
|
||||||
|
{
|
||||||
|
//L_msg.Type = alert_type.success;
|
||||||
|
//L_msg.Text = "修改成功";
|
||||||
|
Model.admin_log admin_log = new Model.admin_log();
|
||||||
|
admin_log.writeLog(admin.info.u_id, (int)Model.admin_log.Systems.Follower, (int)Model.admin_log.Status.Update, f_number.Text + u_name.Text);
|
||||||
|
Response.Redirect("index.aspx?dirty=1&page=" + Convert.ToString(Request["page"]));
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
Response.Redirect("index.aspx?page=" + Convert.ToString(Request["page"]));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
catch (Exception ex)
|
catch (Exception ex)
|
||||||
{
|
{
|
||||||
@@ -339,7 +397,7 @@ public partial class admin_follower_reg : MyWeb.config
|
|||||||
L_msg.Type = alert_type.danger;
|
L_msg.Type = alert_type.danger;
|
||||||
L_msg.Text = "查無資料";
|
L_msg.Text = "查無資料";
|
||||||
}
|
}
|
||||||
/*
|
/*
|
||||||
if (chk_pro_num(f_number.Text, Val(Request["num"])))
|
if (chk_pro_num(f_number.Text, Val(Request["num"])))
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -105,5 +105,36 @@
|
|||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<!-- /.content_box -->
|
<!-- /.content_box -->
|
||||||
|
<script>
|
||||||
|
document.addEventListener('DOMContentLoaded', function () {
|
||||||
|
var accountInput = document.getElementById('<%= u_id.ClientID %>');
|
||||||
|
var passwordInput = document.getElementById('<%= u_password.ClientID %>');
|
||||||
|
var chkInput = document.getElementById('<%= chknum.ClientID %>');
|
||||||
|
var btn = document.getElementById('<%= Button1.ClientID %>');
|
||||||
|
|
||||||
|
accountInput.addEventListener('keypress', function (e){
|
||||||
|
if (e.keyCode === 13) {
|
||||||
|
$("#<%= u_password.ClientID %>").focus();
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
})
|
||||||
|
|
||||||
|
passwordInput.addEventListener('keypress', function (e) {
|
||||||
|
if (e.keyCode === 13) {
|
||||||
|
$("#<%= chknum.ClientID %>").focus();
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
})
|
||||||
|
|
||||||
|
var triggerLogin = function (e) {
|
||||||
|
if (e.keyCode === 13) {
|
||||||
|
btn.click();
|
||||||
|
e.preventDefault();
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
if (chkInput) chkInput.addEventListener('keypress', triggerLogin);
|
||||||
|
});
|
||||||
|
</script>
|
||||||
</asp:Content>
|
</asp:Content>
|
||||||
|
|
||||||
|
|||||||
+228
-56
@@ -14,17 +14,18 @@
|
|||||||
<a @click="print_dialog.show=true" class="btn btn-outline-primary btn-print" target="_blank">
|
<a @click="print_dialog.show=true" class="btn btn-outline-primary btn-print" target="_blank">
|
||||||
<i class="mdi mdi-printer"></i>列印管理報表
|
<i class="mdi mdi-printer"></i>列印管理報表
|
||||||
</a>
|
</a>
|
||||||
|
<div :style="data_table.list.length === 0 ? 'pointer-events: none; opacity: 0.5;' : ''" style="display:inline-block;">
|
||||||
<div class="dropdown d-inline-block">
|
<div class="dropdown d-inline-block">
|
||||||
<a class="btn btn-outline-primary btn-print dropdown-toggle" data-bs-toggle="dropdown" href="#" role="button" aria-expanded="false"><i class="mdi mdi-printer"></i>列印報名資料</a>
|
<a class="btn btn-outline-primary btn-print dropdown-toggle" data-bs-toggle="dropdown" href="#" role="button" aria-expanded="false"><i class="mdi mdi-printer"></i>列印查詢資料</a>
|
||||||
<ul class="dropdown-menu ps-0 w-100" aria-labelledby="dropdownPrintLink">
|
<ul class="dropdown-menu ps-0 w-100" aria-labelledby="dropdownPrintLink">
|
||||||
<li><a @click="search.hasPrice='Y';goPrint()" class="dropdown-item"><i class="mdi mdi-printer me-1"></i>有金額</a></li>
|
<li><a @click="search.hasPrice='Y';goPrint()" class="dropdown-item"><i class="mdi mdi-printer me-1"></i>有金額</a></li>
|
||||||
<li><a @click="search.hasPrice='N';goPrint()" class="dropdown-item"><i class="mdi mdi-printer me-1"></i>無金額</a></li>
|
<li><a @click="search.hasPrice='N';goPrint()" class="dropdown-item"><i class="mdi mdi-printer me-1"></i>無金額</a></li>
|
||||||
</ul>
|
</ul>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div :style="data_table.list.length === 0 ? 'pointer-events: none; opacity: 0.5;' : ''" style="display:inline-block;">
|
||||||
|
<asp:LinkButton ID="excel" runat="server" CssClass="btn btn-outline-success" OnClick="excel_Click"><span class="fa-solid fa-file-excel"></span> 匯出查詢資料(Excel)</asp:LinkButton>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<asp:LinkButton ID="excel" runat="server" CssClass="btn btn-outline-success" OnClick="excel_Click"><span class="fa-solid fa-file-excel"></span> 匯出Excel</asp:LinkButton>
|
|
||||||
|
|
||||||
</div>
|
</div>
|
||||||
</asp:Content>
|
</asp:Content>
|
||||||
<asp:Content ID="Content5" ContentPlaceHolderID="footer_script" runat="Server">
|
<asp:Content ID="Content5" ContentPlaceHolderID="footer_script" runat="Server">
|
||||||
@@ -39,6 +40,8 @@
|
|||||||
vuetify: new Vuetify(vuetify_options),
|
vuetify: new Vuetify(vuetify_options),
|
||||||
data() {
|
data() {
|
||||||
return {
|
return {
|
||||||
|
print_error_msg: "",
|
||||||
|
isSearched: false,
|
||||||
this_act : '<%= Request["act_id"]%>',
|
this_act : '<%= Request["act_id"]%>',
|
||||||
options: { multiSort: false },
|
options: { multiSort: false },
|
||||||
search_options: { multiSort: false },
|
search_options: { multiSort: false },
|
||||||
@@ -56,6 +59,7 @@
|
|||||||
{ text: '報名日期', value: 'up_time' },
|
{ text: '報名日期', value: 'up_time' },
|
||||||
{ text: '報名活動', value: 'subject', align: 'start' },
|
{ text: '報名活動', value: 'subject', align: 'start' },
|
||||||
{ text: '單據狀態', value: 'keyin1_txt' },
|
{ text: '單據狀態', value: 'keyin1_txt' },
|
||||||
|
{ text: '報到狀態', value: 'status' },
|
||||||
{ text: '', value: 'slot_btn', sortable: false, align: 'end' }
|
{ text: '', value: 'slot_btn', sortable: false, align: 'end' }
|
||||||
],
|
],
|
||||||
footer:{
|
footer:{
|
||||||
@@ -203,6 +207,10 @@
|
|||||||
}
|
}
|
||||||
},
|
},
|
||||||
mounted() {
|
mounted() {
|
||||||
|
const printResult = document.getElementById('<%= hid_err_msg.ClientID %>').value;
|
||||||
|
document.getElementById('<%= hid_err_msg.ClientID %>').value = '';
|
||||||
|
window._printResult = printResult
|
||||||
|
|
||||||
this.detalKeyinArray();
|
this.detalKeyinArray();
|
||||||
this.search_dialog.current = this.search_dialog.controls.search1 ///default
|
this.search_dialog.current = this.search_dialog.controls.search1 ///default
|
||||||
if (this.this_act != '')
|
if (this.this_act != '')
|
||||||
@@ -211,20 +219,63 @@
|
|||||||
this.initActivity();
|
this.initActivity();
|
||||||
const navEntries = performance.getEntriesByType("navigation");
|
const navEntries = performance.getEntriesByType("navigation");
|
||||||
const isReload = navEntries.length > 0 && navEntries[0].type === "reload";
|
const isReload = navEntries.length > 0 && navEntries[0].type === "reload";
|
||||||
|
|
||||||
if (isReload) {
|
if (isReload) {
|
||||||
sessionStorage.removeItem("orderpage");
|
sessionStorage.removeItem("orderpage");
|
||||||
|
sessionStorage.removeItem("order_list_cache");
|
||||||
|
sessionStorage.removeItem("order_query_params");
|
||||||
|
}
|
||||||
|
else if ("<%=lastAddedNo%>" !== "") {
|
||||||
|
const newQuery = { order_no: '<%=lastAddedNo%>' };
|
||||||
|
sessionStorage.setItem('order_query_params', JSON.stringify(newQuery));
|
||||||
|
this.search = newQuery;
|
||||||
|
this.isSearched = true;
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
const savedPage = parseInt(sessionStorage.getItem('orderpage'));
|
const savedPage = parseInt(sessionStorage.getItem('orderpage'));
|
||||||
|
const savedData = sessionStorage.getItem("order_list_cache");
|
||||||
|
const savedQuery = JSON.parse(sessionStorage.getItem("order_query_params"));
|
||||||
|
if (savedQuery) {
|
||||||
|
this.search = savedQuery;
|
||||||
|
this.isSearched = true;
|
||||||
|
}
|
||||||
if (savedPage) {
|
if (savedPage) {
|
||||||
this.options.page = savedPage;
|
this.options.page = savedPage;
|
||||||
}
|
}
|
||||||
|
if (savedData && savedData !== "undefined") {
|
||||||
|
this.data_table = JSON.parse(savedData);
|
||||||
|
this.isSearched = true;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (printResult === 'nodata' || printResult === 'success') {
|
||||||
|
|
||||||
|
|
||||||
|
this.$nextTick(() => {
|
||||||
|
this.print_dialog.show = true;
|
||||||
|
if (printResult === 'nodata') {
|
||||||
|
this.print_error_msg = "查無資料,請重新選擇區間";
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
this.$nextTick(() => {
|
||||||
|
setTimeout(() => {
|
||||||
|
// 清空 URL
|
||||||
|
const cleanUrl = window.location.protocol + "//" + window.location.host + window.location.pathname;
|
||||||
|
window.history.replaceState({}, '', cleanUrl);
|
||||||
|
}, 100);
|
||||||
|
});
|
||||||
},
|
},
|
||||||
watch: {
|
watch: {
|
||||||
options: {
|
options: {
|
||||||
handler() {
|
handler() {
|
||||||
this.getDefault()
|
if (this.isSearched) {
|
||||||
|
this.getDefault()
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
this.data_table.loading = false;
|
||||||
|
}
|
||||||
},
|
},
|
||||||
deep: true,
|
deep: true,
|
||||||
},
|
},
|
||||||
@@ -236,6 +287,57 @@
|
|||||||
},
|
},
|
||||||
},
|
},
|
||||||
methods: {
|
methods: {
|
||||||
|
triggerManagementExport(mode) {
|
||||||
|
this.print_error_msg = "";
|
||||||
|
if (this.print_search.year == '') {
|
||||||
|
msgbox('請輸入年份');
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
if (!this.print_search.chk_noact && !this.print_search.chk_hasact) {
|
||||||
|
msgbox('活動/非活動至少勾選一項');
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
// 將 Vue 狀態同步至 ASP.NET HiddenField,供後端 PostBack 讀取參數
|
||||||
|
document.getElementById('<%= hid_print_mode.ClientID %>').value = this.print_conditions;
|
||||||
|
document.getElementById('<%= hid_print_year.ClientID %>').value = this.print_search.year;
|
||||||
|
if (this.print_conditions == 'mm')
|
||||||
|
document.getElementById('<%= hid_print_month.ClientID %>').value = this.print_search.month;
|
||||||
|
else if (this.print_conditions == 'ss')
|
||||||
|
document.getElementById('<%= hid_print_season.ClientID %>').value = this.print_search.season;
|
||||||
|
document.getElementById('<%= hid_select_act.ClientID %>').value = this.print_search.select_act;
|
||||||
|
document.getElementById('<%= hid_select_actitem.ClientID %>').value = this.print_search.select_actitem;
|
||||||
|
document.getElementById('<%= hid_chk_hasact.ClientID %>').value = this.print_search.chk_hasact;
|
||||||
|
document.getElementById('<%= hid_chk_noact.ClientID %>').value = this.print_search.chk_noact;
|
||||||
|
|
||||||
|
let qry = "";
|
||||||
|
Object.keys(this.print_search).forEach(key => {
|
||||||
|
if (this.print_search[key] != undefined && this.print_search[key] != null && this.print_search[key] != '') {
|
||||||
|
if (key == 'month' ) {
|
||||||
|
if (this.print_conditions == 'mm') {
|
||||||
|
qry += "&month=" + this.print_search.month;
|
||||||
|
}
|
||||||
|
} else if ( key == 'season')
|
||||||
|
{
|
||||||
|
if (this.print_conditions == 'ss') {
|
||||||
|
qry += "&season=" + this.print_search.season;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
qry += (qry != '' ? '&' : '?') + (key + '=' + this.print_search[key]);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
});
|
||||||
|
document.getElementById('<%= hid_qry.ClientID %>').value = qry;
|
||||||
|
|
||||||
|
if (mode === 'print') {
|
||||||
|
document.getElementById('<%= print_management.ClientID %>').click();
|
||||||
|
}
|
||||||
|
else if (mode === "excel") {
|
||||||
|
document.getElementById('<%= excel_management.ClientID %>').click();
|
||||||
|
}
|
||||||
|
},
|
||||||
search_show(curr) {
|
search_show(curr) {
|
||||||
//console.log("btn_click:", curr, curr.api_url);
|
//console.log("btn_click:", curr, curr.api_url);
|
||||||
this.search_dialog.current = curr;
|
this.search_dialog.current = curr;
|
||||||
@@ -321,19 +423,24 @@
|
|||||||
this.data_table.list = response.data.list
|
this.data_table.list = response.data.list
|
||||||
this.data_table.count = response.data.count;
|
this.data_table.count = response.data.count;
|
||||||
this.data_table.loading = false
|
this.data_table.loading = false
|
||||||
|
|
||||||
|
const dataToStore = JSON.stringify(this.data_table);
|
||||||
|
sessionStorage.setItem("order_list_cache", dataToStore);
|
||||||
})
|
})
|
||||||
.catch(error => console.log(error))
|
.catch(error => console.log(error))
|
||||||
},
|
},
|
||||||
detalKeyinArray() {
|
detalKeyinArray() {
|
||||||
var getArray = <%=Newtonsoft.Json.JsonConvert.SerializeObject(_keyin1Item, Newtonsoft.Json.Formatting.Indented) %>;
|
var getArray = <%=Newtonsoft.Json.JsonConvert.SerializeObject(_keyin1Item, Newtonsoft.Json.Formatting.Indented) %>;
|
||||||
var keys = Object.keys(getArray);
|
if (getArray !== null) {
|
||||||
for (let i = 0; i < keys.length; i++) {
|
var keys = Object.keys(getArray);
|
||||||
//console.log(`${keys[i]}:${getArray[keys[i]]}`); //value : text
|
for (let i = 0; i < keys.length; i++) {
|
||||||
var _tmp = {
|
//console.log(`${keys[i]}:${getArray[keys[i]]}`); //value : text
|
||||||
text: getArray[keys[i]],
|
var _tmp = {
|
||||||
val: parseInt(keys[i]),
|
text: getArray[keys[i]],
|
||||||
|
val: parseInt(keys[i]),
|
||||||
|
}
|
||||||
|
this.keyin1_items.push(_tmp);
|
||||||
}
|
}
|
||||||
this.keyin1_items.push(_tmp);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
},
|
},
|
||||||
@@ -368,22 +475,28 @@
|
|||||||
//}
|
//}
|
||||||
//this.data_table.selected = [];
|
//this.data_table.selected = [];
|
||||||
//this.data_table.count = this.data_table.list.length
|
//this.data_table.count = this.data_table.list.length
|
||||||
location.reload();
|
//location.reload();
|
||||||
|
this.getDefault();
|
||||||
})
|
})
|
||||||
.catch(error => console.log(error))
|
.catch(error => console.log(error))
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
btn_search() {
|
btn_search() {
|
||||||
|
this.isSearched = true;
|
||||||
|
sessionStorage.setItem("order_query_params", JSON.stringify(this.search));
|
||||||
this.this_act = '';
|
this.this_act = '';
|
||||||
this.search.activity_num = '';
|
this.search.activity_num = '';
|
||||||
|
|
||||||
this.getDefault(true)
|
this.getDefault(true)
|
||||||
|
bootstrap.Offcanvas.getInstance(document.getElementById("offcanvasRight")).hide()
|
||||||
},
|
},
|
||||||
btn_all() {
|
btn_all() {
|
||||||
|
this.isSearched = false;
|
||||||
this.this_act = '';
|
this.this_act = '';
|
||||||
this.search.activity_num = '';
|
this.search.activity_num = '';
|
||||||
clearObjProps(this.search);
|
clearObjProps(this.search);
|
||||||
this.btn_search()
|
sessionStorage.setItem("order_query_params", JSON.stringify(this.search));
|
||||||
|
//this.btn_search()
|
||||||
},
|
},
|
||||||
checkInMsg(item) {
|
checkInMsg(item) {
|
||||||
this.check_data.f_num = item.f_num;
|
this.check_data.f_num = item.f_num;
|
||||||
@@ -392,39 +505,59 @@
|
|||||||
this.check_data.activity_name = item.subject;
|
this.check_data.activity_name = item.subject;
|
||||||
this.check_dialog.show = true;
|
this.check_dialog.show = true;
|
||||||
},
|
},
|
||||||
checkIn() {
|
checkIn(item) {
|
||||||
if (this.check_data.qty > 0 && this.check_data.status.val > 0) {
|
var checkdata =
|
||||||
var chechdata =
|
{
|
||||||
{
|
f_num: item.f_num,
|
||||||
f_num: this.check_data.f_num,
|
activity_num: item.activity_num,
|
||||||
activity_num: this.check_data.activity_num,
|
status: 1,
|
||||||
status: this.check_data.status.val,
|
qty: 1,
|
||||||
qty: this.check_data.qty,
|
|
||||||
}
|
|
||||||
axios
|
|
||||||
.post(HTTP_HOST + 'api/activity/OrderCheckIn', chechdata)
|
|
||||||
.then(response => {
|
|
||||||
//清空
|
|
||||||
this.check_data.f_num = 0;
|
|
||||||
this.check_data.u_name = '';
|
|
||||||
this.check_data.activity_num = 0;
|
|
||||||
this.check_data.activity_name = '';
|
|
||||||
this.check_data.qty = 1;
|
|
||||||
this.check_data.status.text = '';
|
|
||||||
this.check_data.status.val = 1;
|
|
||||||
|
|
||||||
this.check_dialog.show = false;
|
|
||||||
msgtop('簽到成功')
|
|
||||||
})
|
|
||||||
.catch(
|
|
||||||
error => {
|
|
||||||
console.log(error)
|
|
||||||
msgtop('簽到失敗', 'error')
|
|
||||||
}
|
|
||||||
)
|
|
||||||
} else {
|
|
||||||
msgbox('報到資訊請填寫完整');
|
|
||||||
}
|
}
|
||||||
|
console.log(checkdata)
|
||||||
|
axios
|
||||||
|
.post(HTTP_HOST + 'api/activity/OrderCheckIn', checkdata)
|
||||||
|
.then(response => {
|
||||||
|
msgtop('簽到成功');
|
||||||
|
this.getDefault();
|
||||||
|
})
|
||||||
|
.catch(
|
||||||
|
error => {
|
||||||
|
console.log(error)
|
||||||
|
msgtop('簽到失敗', 'error')
|
||||||
|
}
|
||||||
|
)
|
||||||
|
//if (this.check_data.qty > 0 && this.check_data.status.val > 0) {
|
||||||
|
// var chechdata =
|
||||||
|
// {
|
||||||
|
// f_num: this.check_data.f_num,
|
||||||
|
// activity_num: this.check_data.activity_num,
|
||||||
|
// status: this.check_data.status.val,
|
||||||
|
// qty: this.check_data.qty,
|
||||||
|
// }
|
||||||
|
// axios
|
||||||
|
// .post(HTTP_HOST + 'api/activity/OrderCheckIn', chechdata)
|
||||||
|
// .then(response => {
|
||||||
|
// //清空
|
||||||
|
// this.check_data.f_num = 0;
|
||||||
|
// this.check_data.u_name = '';
|
||||||
|
// this.check_data.activity_num = 0;
|
||||||
|
// this.check_data.activity_name = '';
|
||||||
|
// this.check_data.qty = 1;
|
||||||
|
// this.check_data.status.text = '';
|
||||||
|
// this.check_data.status.val = 1;
|
||||||
|
|
||||||
|
// this.check_dialog.show = false;
|
||||||
|
// msgtop('簽到成功')
|
||||||
|
// })
|
||||||
|
// .catch(
|
||||||
|
// error => {
|
||||||
|
// console.log(error)
|
||||||
|
// msgtop('簽到失敗', 'error')
|
||||||
|
// }
|
||||||
|
// )
|
||||||
|
//} else {
|
||||||
|
// msgbox('報到資訊請填寫完整');
|
||||||
|
//}
|
||||||
}, goPrint() {
|
}, goPrint() {
|
||||||
let _qry = "";
|
let _qry = "";
|
||||||
Object.keys(this.search).forEach(key => {
|
Object.keys(this.search).forEach(key => {
|
||||||
@@ -442,6 +575,7 @@
|
|||||||
//列印管理報表
|
//列印管理報表
|
||||||
print_close() {
|
print_close() {
|
||||||
this.print_dialog.show = false;
|
this.print_dialog.show = false;
|
||||||
|
this.print_error_msg = "";
|
||||||
}
|
}
|
||||||
,
|
,
|
||||||
initPrintSearch() {
|
initPrintSearch() {
|
||||||
@@ -504,9 +638,9 @@
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
console.log(_qry);
|
||||||
this.print_dialog.show = false;
|
this.print_dialog.show = false;
|
||||||
window.open("print.aspx" + _qry, '_blank');
|
//window.open("print.aspx" + _qry, '_blank');
|
||||||
} else {
|
} else {
|
||||||
msgbox('活動/非活動至少勾選一項');
|
msgbox('活動/非活動至少勾選一項');
|
||||||
}
|
}
|
||||||
@@ -556,10 +690,35 @@
|
|||||||
$('#country2').val('');
|
$('#country2').val('');
|
||||||
VueApp.search.country2 = '';
|
VueApp.search.country2 = '';
|
||||||
});
|
});
|
||||||
|
|
||||||
|
$(document).ready(function () {
|
||||||
|
// 判斷是否彈出 search dialog
|
||||||
|
let hasSearchResult = sessionStorage.getItem("order_list_cache") !== null;
|
||||||
|
|
||||||
|
if (!hasSearchResult && window._printResult === '') {
|
||||||
|
let $btn = $("a[data-bs-target='#offcanvasRight'][href='#search_panel']");
|
||||||
|
$btn.click();
|
||||||
|
let el = document.getElementById('offcanvasRight');
|
||||||
|
let offcanvas = bootstrap.Offcanvas.getOrCreateInstance(el);
|
||||||
|
offcanvas.show();
|
||||||
|
}
|
||||||
|
});
|
||||||
</script>
|
</script>
|
||||||
</asp:Content>
|
</asp:Content>
|
||||||
<asp:Content ID="Content2" ContentPlaceHolderID="ContentPlaceHolder1" runat="Server">
|
<asp:Content ID="Content2" ContentPlaceHolderID="ContentPlaceHolder1" runat="Server">
|
||||||
<uc1:alert runat="server" ID="L_msg" Text="" />
|
<uc1:alert runat="server" ID="L_msg" Text="" />
|
||||||
|
<asp:HiddenField ID="hid_err_msg" runat="server" />
|
||||||
|
<asp:HiddenField ID="hid_print_year" runat="server" />
|
||||||
|
<asp:HiddenField ID="hid_print_month" runat="server" />
|
||||||
|
<asp:HiddenField ID="hid_print_season" runat="server" />
|
||||||
|
<asp:HiddenField ID="hid_print_mode" runat="server" />
|
||||||
|
<asp:HiddenField ID="hid_chk_hasact" runat="server" />
|
||||||
|
<asp:HiddenField ID="hid_chk_noact" runat="server" />
|
||||||
|
<asp:HiddenField ID="hid_select_act" runat="server" />
|
||||||
|
<asp:HiddenField ID="hid_select_actitem" runat="server" />
|
||||||
|
<asp:HiddenField ID="hid_qry" runat="server" />
|
||||||
|
<asp:LinkButton ID="print_management" runat="server" OnClick="export_Click" style="display:none;" />
|
||||||
|
<asp:LinkButton ID="excel_management" runat="server" OnClick="export_Click" style="display:none;" />
|
||||||
<div id="content" class="container-fluid">
|
<div id="content" class="container-fluid">
|
||||||
<v-data-table
|
<v-data-table
|
||||||
v-model="data_table.selected"
|
v-model="data_table.selected"
|
||||||
@@ -581,9 +740,12 @@
|
|||||||
{{ item.up_time|timeString('YYYY/MM/DD') }}
|
{{ item.up_time|timeString('YYYY/MM/DD') }}
|
||||||
</template>
|
</template>
|
||||||
<template #item.u_name="{ item }" >
|
<template #item.u_name="{ item }" >
|
||||||
<a v-if="item.f_num != null && item.activity_num != null" @click="checkInMsg(item)" class="btn btn-outline-secondary btn-sm"><i class="mdi mdi-account-check"></i>報到</a>
|
|
||||||
{{ item.u_name }}
|
{{ item.u_name }}
|
||||||
</template>
|
</template>
|
||||||
|
<template #item.status="{ item }" >
|
||||||
|
<a v-if="item.f_num != null && item.activity_num != null && item.status == 0" @click="checkIn(item)" class="btn btn-outline-secondary btn-sm"><i class="mdi mdi-account"></i>報到</a>
|
||||||
|
<a v-if="item.f_num != null && item.activity_num != null && item.status == 1" class="btn btn-outline-secondary btn-sm opacity-50" style="pointer-events: none" ><i class="mdi mdi-account-check"></i>已報到</a>
|
||||||
|
</template>
|
||||||
<template #item.slot_btn="{ item }">
|
<template #item.slot_btn="{ item }">
|
||||||
<a :href="'reg.aspx?order_no='+item.order_no" class="btn btn-outline-secondary btn-sm"><i class="mdi mdi-pencil-box-outline"></i>修改</a>
|
<a :href="'reg.aspx?order_no='+item.order_no" class="btn btn-outline-secondary btn-sm"><i class="mdi mdi-pencil-box-outline"></i>修改</a>
|
||||||
<a @click="deleteItem(item)" class="btn btn-outline-secondary btn-sm"><i class="mdi mdi-trash-can"></i>刪除</a>
|
<a @click="deleteItem(item)" class="btn btn-outline-secondary btn-sm"><i class="mdi mdi-trash-can"></i>刪除</a>
|
||||||
@@ -693,6 +855,7 @@
|
|||||||
item-value="val"
|
item-value="val"
|
||||||
v-model="print_search.month"
|
v-model="print_search.month"
|
||||||
:items="select_items.month"
|
:items="select_items.month"
|
||||||
|
eager
|
||||||
></v-select>
|
></v-select>
|
||||||
</v-col>
|
</v-col>
|
||||||
<v-col :cols="2" class="pt-5" v-if="print_conditions=='ss' ">
|
<v-col :cols="2" class="pt-5" v-if="print_conditions=='ss' ">
|
||||||
@@ -704,6 +867,7 @@
|
|||||||
item-value="val"
|
item-value="val"
|
||||||
v-model="print_search.season"
|
v-model="print_search.season"
|
||||||
:items="select_items.season"
|
:items="select_items.season"
|
||||||
|
eager
|
||||||
></v-select>
|
></v-select>
|
||||||
</v-col>
|
</v-col>
|
||||||
|
|
||||||
@@ -764,9 +928,17 @@
|
|||||||
</v-row>
|
</v-row>
|
||||||
</v-col>--%>
|
</v-col>--%>
|
||||||
</v-row>
|
</v-row>
|
||||||
|
<v-row>
|
||||||
|
<v-col>
|
||||||
|
<div v-if="print_error_msg" class="red--text mt-2 text-center" style="font-weight: bold;">
|
||||||
|
{{ print_error_msg }}
|
||||||
|
</div>
|
||||||
|
</v-col>
|
||||||
|
</v-row>
|
||||||
<v-row densee class="pt-3" >
|
<v-row densee class="pt-3" >
|
||||||
<v-col :cols="12" class="pt-3 text-center" >
|
<v-col :cols="12" class="pt-3 text-center" >
|
||||||
<v-btn class="ma-2" color="primary" dark @click="goPrint2" > 列印 </v-btn>
|
<v-btn class="ma-2" color="primary" dark @click="triggerManagementExport('print')" > 列印 </v-btn>
|
||||||
|
<v-btn class="ma-2" color="primary" dark @click="triggerManagementExport('excel')"> 匯出 Excel </v-btn>
|
||||||
<v-btn class="ma-2" color="green" dark @click="print_close" > 取消 </v-btn>
|
<v-btn class="ma-2" color="green" dark @click="print_close" > 取消 </v-btn>
|
||||||
</v-col>
|
</v-col>
|
||||||
</v-row>
|
</v-row>
|
||||||
|
|||||||
+563
-24
@@ -1,22 +1,28 @@
|
|||||||
using System;
|
using DocumentFormat.OpenXml;
|
||||||
|
using DocumentFormat.OpenXml.Packaging;
|
||||||
|
using DocumentFormat.OpenXml.Spreadsheet;
|
||||||
|
using Newtonsoft.Json.Linq;
|
||||||
|
using System;
|
||||||
using System.Collections;
|
using System.Collections;
|
||||||
using System.Collections.Generic;
|
using System.Collections.Generic;
|
||||||
|
using System.Configuration;
|
||||||
using System.Data;
|
using System.Data;
|
||||||
using System.Data.OleDb;
|
using System.Data.OleDb;
|
||||||
|
using System.Diagnostics;
|
||||||
|
using System.IO;
|
||||||
|
using System.Linq;
|
||||||
|
using System.Security.Cryptography;
|
||||||
using System.Web;
|
using System.Web;
|
||||||
using System.Web.UI;
|
using System.Web.UI;
|
||||||
using System.Web.UI.WebControls;
|
using System.Web.UI.WebControls;
|
||||||
using System.Configuration;
|
using static Model.admin_log;
|
||||||
using System.IO;
|
using static regionController;
|
||||||
using DocumentFormat.OpenXml.Packaging;
|
|
||||||
using DocumentFormat.OpenXml;
|
|
||||||
using DocumentFormat.OpenXml.Spreadsheet;
|
|
||||||
using System.Linq;
|
|
||||||
|
|
||||||
public partial class admin_order_index : MyWeb.config
|
public partial class admin_order_index : MyWeb.config
|
||||||
{
|
{
|
||||||
private Model.ezEntities _db = new Model.ezEntities();
|
private Model.ezEntities _db = new Model.ezEntities();
|
||||||
public Dictionary<int, string> _keyin1Item = null;
|
public Dictionary<int, string> _keyin1Item = null;
|
||||||
|
protected string lastAddedNo;
|
||||||
|
|
||||||
protected void Page_Load(object sender, EventArgs e)
|
protected void Page_Load(object sender, EventArgs e)
|
||||||
{
|
{
|
||||||
@@ -33,6 +39,13 @@ public partial class admin_order_index : MyWeb.config
|
|||||||
}
|
}
|
||||||
|
|
||||||
_keyin1Item = publicFun.enum_desc<Model.activity_check.keyin1>(); //狀態
|
_keyin1Item = publicFun.enum_desc<Model.activity_check.keyin1>(); //狀態
|
||||||
|
|
||||||
|
if (Session["LastAddedNo"] != null)
|
||||||
|
{
|
||||||
|
lastAddedNo = Session["LastAddedNo"].ToString();
|
||||||
|
Session.Remove("LastAddedNo");
|
||||||
|
}
|
||||||
|
|
||||||
BuildKind();
|
BuildKind();
|
||||||
|
|
||||||
}
|
}
|
||||||
@@ -58,6 +71,452 @@ public partial class admin_order_index : MyWeb.config
|
|||||||
#endregion
|
#endregion
|
||||||
#region 匯出Excel
|
#region 匯出Excel
|
||||||
|
|
||||||
|
protected void export_Click(object sender, EventArgs e)
|
||||||
|
{
|
||||||
|
LinkButton btn = sender as LinkButton;
|
||||||
|
if (btn == null) return;
|
||||||
|
bool isPrintMode = (btn.ID == "print_management");
|
||||||
|
bool isExcelMode = (btn.ID == "excel_management" || btn.ID == "excel");
|
||||||
|
|
||||||
|
//查詢要匯出的資料
|
||||||
|
string _query = ""; // 紀錄匯出條件
|
||||||
|
//var list = searchData(ref _query, isManagementMode);
|
||||||
|
|
||||||
|
if (isExcelMode)
|
||||||
|
{
|
||||||
|
int selYear = !string.IsNullOrEmpty(hid_print_year.Value) ? int.Parse(hid_print_year.Value) : 0;
|
||||||
|
int selMonth = !string.IsNullOrEmpty(hid_print_month.Value) ? int.Parse(hid_print_month.Value) : 0;
|
||||||
|
int selSeason = !string.IsNullOrEmpty(hid_print_season.Value) ? int.Parse(hid_print_season.Value) : 0;
|
||||||
|
string selMode = !string.IsNullOrEmpty(hid_print_mode.Value) ? hid_print_mode.Value : "";
|
||||||
|
bool chkHasAct = !string.IsNullOrEmpty(hid_chk_hasact.Value) && Convert.ToBoolean(hid_chk_hasact.Value);
|
||||||
|
bool chkNoAct = !string.IsNullOrEmpty(hid_chk_noact.Value) && Convert.ToBoolean(hid_chk_noact.Value);
|
||||||
|
int selAct = !string.IsNullOrEmpty(hid_select_act.Value) ? int.Parse(hid_select_act.Value) : 0;
|
||||||
|
int selActItem = !string.IsNullOrEmpty(hid_select_actitem.Value) ? int.Parse(hid_select_actitem.Value) : 0;
|
||||||
|
|
||||||
|
var qry = _db.pro_order.AsQueryable();
|
||||||
|
|
||||||
|
if (selYear > 0)
|
||||||
|
{
|
||||||
|
qry = qry.Where(o => o.up_time.HasValue && o.up_time.Value.Year == selYear);
|
||||||
|
_query += "年份:" + selYear + "\n";
|
||||||
|
}
|
||||||
|
|
||||||
|
if (selMode == "mm" && selMonth > 0)
|
||||||
|
{
|
||||||
|
qry = qry.Where(o => o.up_time.HasValue && o.up_time.Value.Month == selMonth);
|
||||||
|
_query += "月份:" + selMonth + "\n";
|
||||||
|
}
|
||||||
|
|
||||||
|
if (selMode == "ss" && selSeason > 0)
|
||||||
|
{
|
||||||
|
if (selSeason == 1)
|
||||||
|
{
|
||||||
|
qry = qry.Where(o => o.up_time.HasValue)
|
||||||
|
.Where(o => o.up_time.Value.Month == 1 || o.up_time.Value.Month == 2 || o.up_time.Value.Month == 3);
|
||||||
|
}
|
||||||
|
else if (selSeason == 2)
|
||||||
|
{
|
||||||
|
qry = qry.Where(o => o.up_time.HasValue)
|
||||||
|
.Where(o => o.up_time.Value.Month == 4 || o.up_time.Value.Month == 5 || o.up_time.Value.Month == 6);
|
||||||
|
}
|
||||||
|
else if (selSeason == 3)
|
||||||
|
{
|
||||||
|
qry = qry.Where(o => o.up_time.HasValue)
|
||||||
|
.Where(o => o.up_time.Value.Month == 7 || o.up_time.Value.Month == 8 || o.up_time.Value.Month == 9);
|
||||||
|
}
|
||||||
|
else if (selSeason == 4)
|
||||||
|
{
|
||||||
|
qry = qry.Where(o => o.up_time.HasValue)
|
||||||
|
.Where(o => o.up_time.Value.Month == 10 || o.up_time.Value.Month == 11 || o.up_time.Value.Month == 12);
|
||||||
|
}
|
||||||
|
|
||||||
|
_query += "季度:" + selSeason + "\n";
|
||||||
|
}
|
||||||
|
|
||||||
|
if (chkHasAct)
|
||||||
|
{
|
||||||
|
if(selAct > 0)
|
||||||
|
{
|
||||||
|
var actSubject = _db.activities.Where(a => a.num == selAct).Select(a => a.subject).FirstOrDefault();
|
||||||
|
_query += $"活動報名: {actSubject}\n";
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
_query += $"活動報名\n";
|
||||||
|
}
|
||||||
|
|
||||||
|
if (chkNoAct)
|
||||||
|
{
|
||||||
|
_query += "非活動報名\n";
|
||||||
|
if (selAct > 0)
|
||||||
|
qry = qry.Where(o => o.activity_num.HasValue && o.activity_num.Value == selAct);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
qry = qry.Where(o => o.activity_num.HasValue);
|
||||||
|
if (selAct > 0)
|
||||||
|
qry = qry.Where(o => o.activity_num.Value == selAct);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
if (chkNoAct)
|
||||||
|
{
|
||||||
|
qry = qry.Where(o => o.activity_num == null);
|
||||||
|
_query += "非活動報名\n";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
if (selActItem > 0)
|
||||||
|
qry = qry.Where(o => o.pro_order_detail.Where(f2 => f2.actItem_num.HasValue && f2.actItem_num.Value == selActItem).Count() > 0);
|
||||||
|
|
||||||
|
if (selYear > 0)
|
||||||
|
qry = qry.OrderByDescending(o => o.activity != null ? o.activity.startDate_solar : null).ThenByDescending(o => o.up_time).ThenByDescending(o => o.order_no);
|
||||||
|
else
|
||||||
|
qry = qry.OrderByDescending(o => o.order_no);
|
||||||
|
|
||||||
|
MyWeb.encrypt encrypt = new MyWeb.encrypt();
|
||||||
|
var tdesc = publicFun.enum_desc<Model.pro_order.detailKeyin1>();
|
||||||
|
var bedDt = _db.bed_order_detail.AsQueryable();//掛單明細
|
||||||
|
|
||||||
|
//紀錄匯出條件
|
||||||
|
//var list = qry.ToList();
|
||||||
|
var list = qry.GroupJoin(
|
||||||
|
_db.pro_order_detail, o => o.order_no, p => p.order_no, (o, c) =>
|
||||||
|
new
|
||||||
|
{
|
||||||
|
//訂單資料
|
||||||
|
order_no = o.order_no,
|
||||||
|
up_time = o.up_time,
|
||||||
|
keyin1 = o.keyin1,
|
||||||
|
f_num = o.follower != null ? o.follower.u_name : "", //姓名/名稱
|
||||||
|
phone = o.phone,
|
||||||
|
activity_num = o.activity_num.HasValue ? o.activity.subject : "",
|
||||||
|
address = o.address,
|
||||||
|
demo = o.demo,
|
||||||
|
c
|
||||||
|
}).SelectMany(o => o.c.DefaultIfEmpty(), (o, d) => //SelectMany 展開
|
||||||
|
new
|
||||||
|
{
|
||||||
|
//訂單資料
|
||||||
|
order_no = o.order_no,
|
||||||
|
up_time = o.up_time,
|
||||||
|
keyin1 = o.keyin1,
|
||||||
|
f_num = o.f_num, //姓名/名稱
|
||||||
|
phone = o.phone,
|
||||||
|
activity_num = o.activity_num,
|
||||||
|
address = o.address,
|
||||||
|
demo = o.demo,
|
||||||
|
|
||||||
|
//訂單明細
|
||||||
|
//使用DefaultIfEmpty 因匿名型別無法輸出NULL(無法轉換成強型別),需特別注意Null的處理
|
||||||
|
d_actItem_num = d == null ? "" : (d.actItem_num.HasValue ? d.actItem.subject : ""), //項目名稱
|
||||||
|
d_category = d == null ? "" : (d.actItem_num.HasValue ? d.actItem.category.ToString() : ""),
|
||||||
|
d_f_num = d == null ? "" : (d.f_num.HasValue ? d.follower.u_name : ""), //姓名
|
||||||
|
d_address = d == null ? "" : d.address,
|
||||||
|
d_from_id = d == null ? "" : (d.from_id.HasValue ? d.follower1.u_name : ""), //陽上/報恩者
|
||||||
|
d_f_num_tablet = d == null ? "" : d.f_num_tablet,
|
||||||
|
d_start_date = d == null ? (DateTime?)null : d.start_date, //開始日期
|
||||||
|
d_due_date = d == null ? (DateTime?)null : d.due_date, //期滿日期
|
||||||
|
d_extend_date = d == null ? (DateTime?)null : d.extend_date, //應續約日
|
||||||
|
d_price = d == null ? (float?)null : d.price, //預設金額
|
||||||
|
d_qty = d == null ? "" : (d.qty.HasValue ? d.qty.Value.ToString() : "0"), //數量
|
||||||
|
d_writeBedQty = d == null ? 0 : bedDt.Where(b => (b.bed_order.o_detail_id.Value == d.num) && b.checkIn_date.HasValue && b.bed_kind_detail_id.HasValue).Count(), //已劃數量
|
||||||
|
d_notBedQty = d == null ? 0 : bedDt.Where(b => b.bed_order.o_detail_id.Value == d.num && (!b.checkIn_date.HasValue || !b.bed_kind_detail_id.HasValue)).Count(), //未劃數量
|
||||||
|
d_pay = d == null ? "" : (d.pay.HasValue ? d.pay.Value.ToString() : "0"), //已收金額
|
||||||
|
d_pay_date = d == null ? (DateTime?)null : d.start_date, //付款期限
|
||||||
|
d_keyin1 = d == null ? (int?)null : d.keyin1,
|
||||||
|
d_demo = d == null ? "" : d.demo, //狀態備註
|
||||||
|
}).ToList();
|
||||||
|
|
||||||
|
var memoryStream = new MemoryStream();
|
||||||
|
|
||||||
|
if (list.Count > 0)
|
||||||
|
{
|
||||||
|
using (var doc = SpreadsheetDocument.Create(memoryStream, SpreadsheetDocumentType.Workbook))
|
||||||
|
{
|
||||||
|
var wb = doc.AddWorkbookPart();
|
||||||
|
wb.Workbook = new Workbook();
|
||||||
|
var sheets = wb.Workbook.AppendChild(new Sheets());
|
||||||
|
|
||||||
|
//建立第一個頁籤
|
||||||
|
var ws = wb.AddNewPart<WorksheetPart>();
|
||||||
|
ws.Worksheet = new Worksheet();
|
||||||
|
sheets.Append(new Sheet()
|
||||||
|
{
|
||||||
|
Id = wb.GetIdOfPart(ws),
|
||||||
|
SheetId = 1,
|
||||||
|
Name = "報名"
|
||||||
|
});
|
||||||
|
|
||||||
|
//設定欄寬
|
||||||
|
var cu = new Columns();
|
||||||
|
cu.Append(
|
||||||
|
new Column { Min = 1, Max = 1, Width = 15, CustomWidth = true },
|
||||||
|
new Column { Min = 2, Max = 4, Width = 10, CustomWidth = true },
|
||||||
|
new Column { Min = 5, Max = 5, Width = 15, CustomWidth = true },
|
||||||
|
new Column { Min = 6, Max = 8, Width = 25, CustomWidth = true },
|
||||||
|
new Column { Min = 9, Max = 9, Width = 15, CustomWidth = true },
|
||||||
|
new Column { Min = 10, Max = 10, Width = 10, CustomWidth = true },
|
||||||
|
new Column { Min = 11, Max = 11, Width = 25, CustomWidth = true },
|
||||||
|
new Column { Min = 12, Max = 16, Width = 10, CustomWidth = true },
|
||||||
|
new Column { Min = 17, Max = 20, Width = 10, CustomWidth = true }
|
||||||
|
);
|
||||||
|
ws.Worksheet.Append(cu);
|
||||||
|
|
||||||
|
//建立資料頁
|
||||||
|
var sd = new SheetData();
|
||||||
|
ws.Worksheet.AppendChild(sd);
|
||||||
|
|
||||||
|
//第一列資料
|
||||||
|
var tr = new Row();
|
||||||
|
tr.Append(
|
||||||
|
new Cell() { CellValue = new CellValue("單號"), DataType = CellValues.String },
|
||||||
|
new Cell() { CellValue = new CellValue("報名日期"), DataType = CellValues.String },
|
||||||
|
new Cell() { CellValue = new CellValue("單據狀態"), DataType = CellValues.String },
|
||||||
|
new Cell() { CellValue = new CellValue("姓名/名稱"), DataType = CellValues.String },
|
||||||
|
new Cell() { CellValue = new CellValue("聯絡電話"), DataType = CellValues.String },
|
||||||
|
new Cell() { CellValue = new CellValue("報名活動"), DataType = CellValues.String },
|
||||||
|
new Cell() { CellValue = new CellValue("收件地址"), DataType = CellValues.String },
|
||||||
|
new Cell() { CellValue = new CellValue("備註"), DataType = CellValues.String },
|
||||||
|
new Cell() { CellValue = new CellValue("項目名稱"), DataType = CellValues.String },
|
||||||
|
new Cell() { CellValue = new CellValue("姓名"), DataType = CellValues.String },
|
||||||
|
new Cell() { CellValue = new CellValue("代表地址"), DataType = CellValues.String },
|
||||||
|
new Cell() { CellValue = new CellValue("標題"), DataType = CellValues.String },
|
||||||
|
new Cell() { CellValue = new CellValue("陽上/報恩者"), DataType = CellValues.String },
|
||||||
|
new Cell() { CellValue = new CellValue("開始日期"), DataType = CellValues.String },
|
||||||
|
new Cell() { CellValue = new CellValue("期滿日期"), DataType = CellValues.String },
|
||||||
|
new Cell() { CellValue = new CellValue("應續約日"), DataType = CellValues.String },
|
||||||
|
new Cell() { CellValue = new CellValue("劃位狀態"), DataType = CellValues.String },
|
||||||
|
new Cell() { CellValue = new CellValue("預設金額"), DataType = CellValues.String },
|
||||||
|
new Cell() { CellValue = new CellValue("數量"), DataType = CellValues.String },
|
||||||
|
new Cell() { CellValue = new CellValue("小計"), DataType = CellValues.String },
|
||||||
|
new Cell() { CellValue = new CellValue("已收金額"), DataType = CellValues.String },
|
||||||
|
new Cell() { CellValue = new CellValue("未收金額"), DataType = CellValues.String },
|
||||||
|
new Cell() { CellValue = new CellValue("付款期限"), DataType = CellValues.String },
|
||||||
|
new Cell() { CellValue = new CellValue("報名狀態"), DataType = CellValues.String },
|
||||||
|
new Cell() { CellValue = new CellValue("狀態備註"), DataType = CellValues.String }
|
||||||
|
);
|
||||||
|
sd.AppendChild(tr);
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
foreach (var item in list)
|
||||||
|
{
|
||||||
|
string midNamesResult = "";
|
||||||
|
string leftNamesResult = "";
|
||||||
|
string jsonString = item.d_f_num_tablet?.ToString() ?? "";
|
||||||
|
try
|
||||||
|
{
|
||||||
|
var jo = JObject.Parse(jsonString);
|
||||||
|
|
||||||
|
// 標題
|
||||||
|
var midList = jo["mid_items"]?
|
||||||
|
.Select(i => (string)i["fam_name"])
|
||||||
|
.Where(name => !string.IsNullOrEmpty(name))
|
||||||
|
.ToList();
|
||||||
|
if (midList != null && midList.Any())
|
||||||
|
{
|
||||||
|
midNamesResult = string.Join(", ", midList);
|
||||||
|
}
|
||||||
|
|
||||||
|
// 陽上
|
||||||
|
var leftList = jo["left_items"]?
|
||||||
|
.Select(i => (string)i["fam_name"])
|
||||||
|
.Where(name => !string.IsNullOrEmpty(name))
|
||||||
|
.ToList();
|
||||||
|
if (leftList != null && leftList.Any())
|
||||||
|
{
|
||||||
|
leftNamesResult = string.Join(", ", leftList);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
catch (Exception ex)
|
||||||
|
{
|
||||||
|
System.Diagnostics.Debug.WriteLine($"JSON 解析失敗 (訂單:{item.order_no}): {ex.Message}");
|
||||||
|
}
|
||||||
|
|
||||||
|
//新增資料列
|
||||||
|
tr = new Row();
|
||||||
|
tr.Append(
|
||||||
|
new Cell() { CellValue = new CellValue(item.order_no), DataType = CellValues.String },
|
||||||
|
new Cell() { CellValue = new CellValue(item.up_time?.ToString("yyyy/MM/dd") ?? ""), DataType = CellValues.String },
|
||||||
|
new Cell() { CellValue = new CellValue(Model.pro_order.keyin1_value_to_text(item.keyin1)), DataType = CellValues.String },
|
||||||
|
new Cell() { CellValue = new CellValue(item.f_num), DataType = CellValues.String },
|
||||||
|
new Cell() { CellValue = new CellValue(encrypt.DecryptAutoKey(item.phone)), DataType = CellValues.String },
|
||||||
|
new Cell() { CellValue = new CellValue(item.activity_num), DataType = CellValues.String },
|
||||||
|
new Cell() { CellValue = new CellValue(item.address), DataType = CellValues.String },
|
||||||
|
new Cell() { CellValue = new CellValue(item.demo), DataType = CellValues.String },
|
||||||
|
|
||||||
|
new Cell() { CellValue = new CellValue(item.d_actItem_num), DataType = CellValues.String },
|
||||||
|
new Cell() { CellValue = new CellValue(item.d_f_num), DataType = CellValues.String },
|
||||||
|
new Cell() { CellValue = new CellValue(item.d_address), DataType = CellValues.String },
|
||||||
|
new Cell() { CellValue = new CellValue(midNamesResult), DataType = CellValues.String },
|
||||||
|
new Cell() { CellValue = new CellValue(leftNamesResult), DataType = CellValues.String },
|
||||||
|
//new Cell() { CellValue = new CellValue(item.d_from_id), DataType = CellValues.String },
|
||||||
|
new Cell() { CellValue = new CellValue(item.d_start_date?.ToString("yyyy/MM/dd") ?? ""), DataType = CellValues.String },
|
||||||
|
new Cell() { CellValue = new CellValue(item.d_due_date?.ToString("yyyy/MM/dd") ?? ""), DataType = CellValues.String },
|
||||||
|
new Cell() { CellValue = new CellValue(item.d_extend_date?.ToString("yyyy/MM/dd") ?? ""), DataType = CellValues.String },
|
||||||
|
new Cell() { CellValue = new CellValue((Val(item.d_category) == (int)Model.activity.category.Order) ? (item.d_notBedQty + "/" + item.d_writeBedQty) : ""), DataType = CellValues.String },
|
||||||
|
new Cell() { CellValue = new CellValue("$" + ValMoney(item.d_price)), DataType = CellValues.String },
|
||||||
|
new Cell() { CellValue = new CellValue(item.d_qty), DataType = CellValues.String },
|
||||||
|
new Cell() { CellValue = new CellValue("$" + ValMoney(ValFloat(item.d_price) * Val(item.d_qty))), DataType = CellValues.String },
|
||||||
|
new Cell() { CellValue = new CellValue("$" + ValMoney(item.d_pay)), DataType = CellValues.String },
|
||||||
|
new Cell() { CellValue = new CellValue("$" + ValMoney(ValFloat(item.d_price) * Val(item.d_qty) - ValFloat(item.d_pay))), DataType = CellValues.String },
|
||||||
|
new Cell() { CellValue = new CellValue(item.d_pay_date?.ToString("yyyy/MM/dd") ?? ""), DataType = CellValues.String },
|
||||||
|
new Cell() { CellValue = new CellValue(item.d_keyin1.HasValue ? tdesc[item.d_keyin1.Value] : ""), DataType = CellValues.String },
|
||||||
|
new Cell() { CellValue = new CellValue(item.d_demo), DataType = CellValues.String }
|
||||||
|
);
|
||||||
|
sd.AppendChild(tr);
|
||||||
|
}
|
||||||
|
|
||||||
|
//空一列
|
||||||
|
tr = new Row();
|
||||||
|
sd.AppendChild(tr);
|
||||||
|
|
||||||
|
//匯出資訊
|
||||||
|
string _data = "匯出時間 : " + DateTime.Now.ToString("yyyy/MM/dd HH:mm:ss");
|
||||||
|
_data += " " + admin.info.u_id;
|
||||||
|
tr = new Row();
|
||||||
|
tr.Append(
|
||||||
|
new Cell() { CellValue = new CellValue(_data), DataType = CellValues.String }
|
||||||
|
);
|
||||||
|
sd.AppendChild(tr);
|
||||||
|
|
||||||
|
_data = "匯出條件 : " + (!isStrNull(_query) ? _query : "-");
|
||||||
|
tr = new Row();
|
||||||
|
tr.Append(
|
||||||
|
new Cell() { CellValue = new CellValue(_data), DataType = CellValues.String }
|
||||||
|
);
|
||||||
|
sd.AppendChild(tr);
|
||||||
|
|
||||||
|
Model.admin_log admin_log = new Model.admin_log();
|
||||||
|
admin_log.writeLog(admin.info.u_id, (int)Model.admin_log.Systems.Order, (int)Model.admin_log.Status.Excel, admin_log.LogViewBtn(list.Select(x => x.order_no).ToList()));
|
||||||
|
}
|
||||||
|
|
||||||
|
HttpContext.Current.Response.Clear();
|
||||||
|
HttpContext.Current.Response.AddHeader("content-disposition", "attachment; filename=報名.xlsx");
|
||||||
|
HttpContext.Current.Response.ContentType = "application/vnd.openxmlformats-officedocument.spreadsheetml.sheet";
|
||||||
|
HttpContext.Current.Response.BinaryWrite(memoryStream.ToArray());
|
||||||
|
HttpContext.Current.Response.End();
|
||||||
|
|
||||||
|
hid_err_msg.Value = "success";
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
hid_err_msg.Value = "nodata";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else if (isPrintMode)
|
||||||
|
{
|
||||||
|
int selYear = !string.IsNullOrEmpty(hid_print_year.Value) ? int.Parse(hid_print_year.Value) : 0;
|
||||||
|
int selMonth = !string.IsNullOrEmpty(hid_print_month.Value) ? int.Parse(hid_print_month.Value) : 0;
|
||||||
|
int selSeason = !string.IsNullOrEmpty(hid_print_season.Value) ? int.Parse(hid_print_season.Value) : 0;
|
||||||
|
string selMode = !string.IsNullOrEmpty(hid_print_mode.Value) ? hid_print_mode.Value : "";
|
||||||
|
bool chkHasAct = !string.IsNullOrEmpty(hid_chk_hasact.Value) && Convert.ToBoolean(hid_chk_hasact.Value);
|
||||||
|
bool chkNoAct = !string.IsNullOrEmpty(hid_chk_noact.Value) && Convert.ToBoolean(hid_chk_noact.Value);
|
||||||
|
int selAct = !string.IsNullOrEmpty(hid_select_act.Value) ? int.Parse(hid_select_act.Value) : -1;
|
||||||
|
int selActItem = !string.IsNullOrEmpty(hid_select_actitem.Value) ? int.Parse(hid_select_actitem.Value) : -1;
|
||||||
|
string urlParams = !string.IsNullOrEmpty(hid_qry.Value) ? hid_qry.Value : "";
|
||||||
|
|
||||||
|
var qry = _db.pro_order.AsQueryable();
|
||||||
|
|
||||||
|
if (selYear > 0)
|
||||||
|
qry = qry.Where(o => o.up_time.HasValue && o.up_time.Value.Year == selYear);
|
||||||
|
if (selMode == "mm" && selMonth > 0)
|
||||||
|
qry = qry.Where(o => o.up_time.HasValue && o.up_time.Value.Month == selMonth);
|
||||||
|
else if (selMode == "ss" && selSeason > 0)
|
||||||
|
{
|
||||||
|
if (selSeason == 1)
|
||||||
|
qry = qry.Where(o => o.up_time.HasValue)
|
||||||
|
.Where(o => o.up_time.Value.Month == 1 || o.up_time.Value.Month == 2 || o.up_time.Value.Month == 3);
|
||||||
|
else if (selSeason == 2)
|
||||||
|
qry = qry.Where(o => o.up_time.HasValue)
|
||||||
|
.Where(o => o.up_time.Value.Month == 4 || o.up_time.Value.Month == 5 || o.up_time.Value.Month == 6);
|
||||||
|
else if (selSeason == 3)
|
||||||
|
qry = qry.Where(o => o.up_time.HasValue)
|
||||||
|
.Where(o => o.up_time.Value.Month == 7 || o.up_time.Value.Month == 8 || o.up_time.Value.Month == 9);
|
||||||
|
else if (selSeason == 4)
|
||||||
|
qry = qry.Where(o => o.up_time.HasValue)
|
||||||
|
.Where(o => o.up_time.Value.Month == 10 || o.up_time.Value.Month == 11 || o.up_time.Value.Month == 12);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (chkHasAct)
|
||||||
|
{
|
||||||
|
if (chkNoAct)
|
||||||
|
{
|
||||||
|
if (selAct >= 0)
|
||||||
|
qry = qry.Where(o => o.activity_num.HasValue && o.activity_num.Value == selAct);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
qry = qry.Where(o => o.activity_num.HasValue);
|
||||||
|
if (selAct >= 0)
|
||||||
|
qry = qry.Where(o => o.activity_num.Value == selAct);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
if (chkNoAct)
|
||||||
|
qry = qry.Where(o => o.activity_num == null);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (selActItem >= 0)
|
||||||
|
{
|
||||||
|
qry = qry.Where(o => o.pro_order_detail.Where(f2 => f2.actItem_num.HasValue && f2.actItem_num.Value == selActItem).Count() > 0);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
var count = qry.Count();
|
||||||
|
if (count > 0)
|
||||||
|
{
|
||||||
|
hid_err_msg.Value = "success";
|
||||||
|
|
||||||
|
string script = $@"var otherWin = window.open('print.aspx{urlParams}', '列印報名資料', 'noopener,noreferrer');";
|
||||||
|
ScriptManager.RegisterStartupScript(this, GetType(), "ExecutePrint", script, true);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
hid_err_msg.Value = "nodata";
|
||||||
|
}
|
||||||
|
//var qry = _db.followers.AsQueryable();
|
||||||
|
//if (selYear > 0)
|
||||||
|
//{
|
||||||
|
// urlParams += "&year=" + selYear;
|
||||||
|
//}
|
||||||
|
//if (selMode == "mm" && selMonth > 0)
|
||||||
|
//{
|
||||||
|
// urlParams += "&month=" + selMonth;
|
||||||
|
//}
|
||||||
|
//else if (selMode == "ss" && selSeason > 0)
|
||||||
|
//{
|
||||||
|
// urlParams += "&season=" + selSeason;
|
||||||
|
//}
|
||||||
|
|
||||||
|
//if (list.Count > 0)
|
||||||
|
//{
|
||||||
|
// hid_err_msg.Value = "success";
|
||||||
|
// hid_print_year.Value = selYear.ToString();
|
||||||
|
// hid_print_month.Value = selMonth.ToString();
|
||||||
|
// hid_print_season.Value = selSeason.ToString();
|
||||||
|
// hid_print_mode.Value = selMode;
|
||||||
|
|
||||||
|
// string script = $@"window.open('print.aspx?{urlParams}&mode={selMode}', '列印信眾資料');";
|
||||||
|
// ScriptManager.RegisterStartupScript(this, GetType(), "ExecutePrint", script, true);
|
||||||
|
//}
|
||||||
|
//else
|
||||||
|
//{
|
||||||
|
// hid_err_msg.Value = "nodata";
|
||||||
|
// string script = $@"
|
||||||
|
// var win = window.open('', '列印信眾資料');
|
||||||
|
// if (win) win.close()";
|
||||||
|
|
||||||
|
// ScriptManager.RegisterStartupScript(this, GetType(), "CancelPrint", script, true);
|
||||||
|
//}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
protected void excel_Click(object sender, EventArgs e)
|
protected void excel_Click(object sender, EventArgs e)
|
||||||
{
|
{
|
||||||
|
|
||||||
@@ -111,6 +570,7 @@ public partial class admin_order_index : MyWeb.config
|
|||||||
new Cell() { CellValue = new CellValue("項目名稱"), DataType = CellValues.String },
|
new Cell() { CellValue = new CellValue("項目名稱"), DataType = CellValues.String },
|
||||||
new Cell() { CellValue = new CellValue("姓名"), DataType = CellValues.String },
|
new Cell() { CellValue = new CellValue("姓名"), DataType = CellValues.String },
|
||||||
new Cell() { CellValue = new CellValue("代表地址"), DataType = CellValues.String },
|
new Cell() { CellValue = new CellValue("代表地址"), DataType = CellValues.String },
|
||||||
|
new Cell() { CellValue = new CellValue("標題"), DataType = CellValues.String },
|
||||||
new Cell() { CellValue = new CellValue("陽上/報恩者"), DataType = CellValues.String },
|
new Cell() { CellValue = new CellValue("陽上/報恩者"), DataType = CellValues.String },
|
||||||
new Cell() { CellValue = new CellValue("開始日期"), DataType = CellValues.String },
|
new Cell() { CellValue = new CellValue("開始日期"), DataType = CellValues.String },
|
||||||
new Cell() { CellValue = new CellValue("期滿日期"), DataType = CellValues.String },
|
new Cell() { CellValue = new CellValue("期滿日期"), DataType = CellValues.String },
|
||||||
@@ -132,31 +592,56 @@ public partial class admin_order_index : MyWeb.config
|
|||||||
// 改為整數陣列,避免後續查詢中使用 .ToString()
|
// 改為整數陣列,避免後續查詢中使用 .ToString()
|
||||||
var aIDt = _db.actItems.Where(f => f.subject.Contains(s_actItemTxt.Value.Trim())).Select(f => f.num).ToArray();//品項
|
var aIDt = _db.actItems.Where(f => f.subject.Contains(s_actItemTxt.Value.Trim())).Select(f => f.num).ToArray();//品項
|
||||||
var qry = _db.pro_order.AsQueryable();
|
var qry = _db.pro_order.AsQueryable();
|
||||||
|
string _query = ""; // 紀錄匯出條件
|
||||||
|
|
||||||
if (!isStrNull(s_order_no.Value))
|
if (!isStrNull(s_order_no.Value))
|
||||||
|
{
|
||||||
|
_query += "單號:" + s_order_no.Value + "\n";
|
||||||
qry = qry.Where(o => o.order_no.Contains(s_order_no.Value.Trim()));
|
qry = qry.Where(o => o.order_no.Contains(s_order_no.Value.Trim()));
|
||||||
|
}
|
||||||
if (!isStrNull(s_u_name.Value))
|
if (!isStrNull(s_u_name.Value))
|
||||||
|
{
|
||||||
|
_query += "姓名/名稱:" + s_u_name.Value + "\n";
|
||||||
qry = qry.Where(o => o.f_num.HasValue && o.follower.u_name.Contains(s_u_name.Value.Trim()));
|
qry = qry.Where(o => o.f_num.HasValue && o.follower.u_name.Contains(s_u_name.Value.Trim()));
|
||||||
|
}
|
||||||
if (!isStrNull(s_introducerTxt.Value))
|
if (!isStrNull(s_introducerTxt.Value))
|
||||||
|
{
|
||||||
|
_query += "介紹人:" + s_introducerTxt.Value + "\n";
|
||||||
qry = qry.Where(o => o.f_num.HasValue && o.follower1.u_name.Contains(s_introducerTxt.Value.Trim()));
|
qry = qry.Where(o => o.f_num.HasValue && o.follower1.u_name.Contains(s_introducerTxt.Value.Trim()));
|
||||||
|
}
|
||||||
if (!isStrNull(s_subject.Value))
|
if (!isStrNull(s_subject.Value))
|
||||||
|
{
|
||||||
|
_query += "報名活動:" + s_subject.Value + "\n";
|
||||||
qry = qry.Where(o => o.activity_num.HasValue && o.activity.subject.Contains(s_subject.Value.Trim()));
|
qry = qry.Where(o => o.activity_num.HasValue && o.activity.subject.Contains(s_subject.Value.Trim()));
|
||||||
|
}
|
||||||
if (!isStrNull(s_actItemTxt.Value))
|
if (!isStrNull(s_actItemTxt.Value))
|
||||||
{
|
{
|
||||||
// ❌ 錯誤寫法: qry = qry.Where(o => o.pro_order_detail.Where(f2 => f2.order_no == o.order_no && aIDt.ToArray().Contains(f2.actItem_num.ToString())).Count() > 0);
|
// ❌ 錯誤寫法: qry = qry.Where(o => o.pro_order_detail.Where(f2 => f2.order_no == o.order_no && aIDt.ToArray().Contains(f2.actItem_num.ToString())).Count() > 0);
|
||||||
// ✅ 實際比較:僅在 actItem_num 有值時才與整數陣列比對
|
// ✅ 實際比較:僅在 actItem_num 有值時才與整數陣列比對
|
||||||
|
_query += "品項:" + s_actItemTxt.Value + "\n";
|
||||||
qry = qry.Where(o => o.pro_order_detail.Any(f2 =>
|
qry = qry.Where(o => o.pro_order_detail.Any(f2 =>
|
||||||
f2.order_no == o.order_no &&
|
f2.order_no == o.order_no &&
|
||||||
f2.actItem_num.HasValue &&
|
f2.actItem_num.HasValue &&
|
||||||
aIDt.Contains(f2.actItem_num.Value)));
|
aIDt.Contains(f2.actItem_num.Value)));
|
||||||
}
|
}
|
||||||
if (!isStrNull(s_keyin1.SelectedValue))
|
if (!isStrNull(s_keyin1.SelectedValue))
|
||||||
|
{
|
||||||
|
_query += $"單據狀態:{Model.pro_order.keyin1_value_to_text(s_keyin1.SelectedValue)}\n";
|
||||||
qry = qry.Where(o => o.keyin1 == s_keyin1.SelectedValue);
|
qry = qry.Where(o => o.keyin1 == s_keyin1.SelectedValue);
|
||||||
|
}
|
||||||
|
|
||||||
if (!isStrNull(s_up_time1.Value) && isDate(s_up_time1.Value))
|
if (!isStrNull(s_up_time1.Value) && isDate(s_up_time1.Value))
|
||||||
qry = qry.Where(o => o.up_time >= ValDate(s_up_time1.Value));
|
{
|
||||||
|
_query += "報名日期(起):" + s_up_time1.Value.Trim() + "\n";
|
||||||
|
var tmp_s_up_time1 = ValDate(s_up_time1.Value);
|
||||||
|
qry = qry.Where(o => o.up_time >= tmp_s_up_time1);
|
||||||
|
}
|
||||||
if (!isStrNull(s_up_time2.Value) && isDate(s_up_time2.Value))
|
if (!isStrNull(s_up_time2.Value) && isDate(s_up_time2.Value))
|
||||||
qry = qry.Where(o => o.up_time < Convert.ToDateTime(s_up_time2.Value).AddDays(1));
|
{
|
||||||
|
_query += "報名日期(訖):" + s_up_time2.Value.Trim() + "\n";
|
||||||
|
var tmp_s_up_time2 = Convert.ToDateTime(s_up_time2.Value).AddDays(1);
|
||||||
|
qry = qry.Where(o => o.up_time < tmp_s_up_time2);
|
||||||
|
}
|
||||||
|
|
||||||
qry = qry.OrderByDescending(o => o.reg_time);
|
qry = qry.OrderByDescending(o => o.reg_time);
|
||||||
|
|
||||||
@@ -202,16 +687,17 @@ public partial class admin_order_index : MyWeb.config
|
|||||||
d_f_num = d == null ? "" : (d.f_num.HasValue ? d.follower.u_name : ""), //姓名
|
d_f_num = d == null ? "" : (d.f_num.HasValue ? d.follower.u_name : ""), //姓名
|
||||||
d_address = d == null ? "" : d.address,
|
d_address = d == null ? "" : d.address,
|
||||||
d_from_id = d == null ? "" : (d.from_id.HasValue ? d.follower1.u_name : ""), //陽上/報恩者
|
d_from_id = d == null ? "" : (d.from_id.HasValue ? d.follower1.u_name : ""), //陽上/報恩者
|
||||||
d_start_date = d == null ? "" : (d.start_date.HasValue ? d.start_date.Value.ToString("yyyy/MM/dd") : ""), //開始日期
|
d_f_num_tablet = d == null ? "" : d.f_num_tablet,
|
||||||
d_due_date = d == null ? "" : (d.due_date.HasValue ? d.due_date.Value.ToString("yyyy/MM/dd") : ""), //期滿日期
|
d_start_date = d == null ? (DateTime?)null : d.start_date, //開始日期
|
||||||
d_extend_date = d == null ? "" : (d.extend_date.HasValue ? d.extend_date.Value.ToString("yyyy/MM/dd") : ""), //應續約日
|
d_due_date = d == null ? (DateTime?)null : d.due_date, //期滿日期
|
||||||
d_price = d == null ? "" : (d.price.HasValue ? d.price.Value.ToString() : "0"), //預設金額
|
d_extend_date = d == null ? (DateTime?)null : d.extend_date, //應續約日
|
||||||
|
d_price = d == null ? (float?)null : d.price, //預設金額
|
||||||
d_qty = d == null ? "" : (d.qty.HasValue ? d.qty.Value.ToString() : "0"), //數量
|
d_qty = d == null ? "" : (d.qty.HasValue ? d.qty.Value.ToString() : "0"), //數量
|
||||||
d_writeBedQty = d == null ? 0 : bedDt.Where(b =>( b.bed_order.o_detail_id.Value == d.num) && b.checkIn_date.HasValue && b.bed_kind_detail_id.HasValue).Count(), //已劃數量
|
d_writeBedQty = d == null ? 0 : bedDt.Where(b => (b.bed_order.o_detail_id.Value == d.num) && b.checkIn_date.HasValue && b.bed_kind_detail_id.HasValue).Count(), //已劃數量
|
||||||
d_notBedQty = d == null ? 0 : bedDt.Where(b => b.bed_order.o_detail_id.Value == d.num && (!b.checkIn_date.HasValue || !b.bed_kind_detail_id.HasValue)).Count(), //未劃數量
|
d_notBedQty = d == null ? 0 : bedDt.Where(b => b.bed_order.o_detail_id.Value == d.num && (!b.checkIn_date.HasValue || !b.bed_kind_detail_id.HasValue)).Count(), //未劃數量
|
||||||
d_pay = d == null ? "" : (d.pay.HasValue ? d.pay.Value.ToString() : "0"), //已收金額
|
d_pay = d == null ? "" : (d.pay.HasValue ? d.pay.Value.ToString() : "0"), //已收金額
|
||||||
d_pay_date = d == null ? "" : (d.pay_date.HasValue ? d.pay_date.Value.ToString("yyyy/MM/dd") : ""), //付款期限
|
d_pay_date = d == null ? (DateTime?)null : d.start_date, //付款期限
|
||||||
d_keyin1 = d == null ? "" : (d.keyin1.HasValue&& d.keyin1.Value>0 ? tdesc[d.keyin1 ?? 1] : ""), //報名狀態
|
d_keyin1 = d == null ? (int?)null : d.keyin1,
|
||||||
d_demo = d == null ? "" : d.demo, //狀態備註
|
d_demo = d == null ? "" : d.demo, //狀態備註
|
||||||
}).ToList();
|
}).ToList();
|
||||||
|
|
||||||
@@ -259,11 +745,43 @@ public partial class admin_order_index : MyWeb.config
|
|||||||
{
|
{
|
||||||
foreach (var item in list)
|
foreach (var item in list)
|
||||||
{
|
{
|
||||||
|
string midNamesResult = "";
|
||||||
|
string leftNamesResult = "";
|
||||||
|
string jsonString = item.d_f_num_tablet?.ToString() ?? "";
|
||||||
|
try
|
||||||
|
{
|
||||||
|
var jo = JObject.Parse(jsonString);
|
||||||
|
|
||||||
|
// 標題
|
||||||
|
var midList = jo["mid_items"]?
|
||||||
|
.Select(i => (string)i["fam_name"])
|
||||||
|
.Where(name => !string.IsNullOrEmpty(name))
|
||||||
|
.ToList();
|
||||||
|
if (midList != null && midList.Any())
|
||||||
|
{
|
||||||
|
midNamesResult = string.Join(", ", midList);
|
||||||
|
}
|
||||||
|
|
||||||
|
// 陽上
|
||||||
|
var leftList = jo["left_items"]?
|
||||||
|
.Select(i => (string)i["fam_name"])
|
||||||
|
.Where(name => !string.IsNullOrEmpty(name))
|
||||||
|
.ToList();
|
||||||
|
if (leftList != null && leftList.Any())
|
||||||
|
{
|
||||||
|
leftNamesResult = string.Join(", ", leftList);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
catch (Exception ex)
|
||||||
|
{
|
||||||
|
System.Diagnostics.Debug.WriteLine($"JSON 解析失敗 (訂單:{item.order_no}): {ex.Message}");
|
||||||
|
}
|
||||||
|
|
||||||
//新增資料列
|
//新增資料列
|
||||||
tr = new Row();
|
tr = new Row();
|
||||||
tr.Append(
|
tr.Append(
|
||||||
new Cell() { CellValue = new CellValue(item.order_no), DataType = CellValues.String },
|
new Cell() { CellValue = new CellValue(item.order_no), DataType = CellValues.String },
|
||||||
new Cell() { CellValue = new CellValue(item.up_time.Value.ToString("yyyy/MM/dd")), DataType = CellValues.String },
|
new Cell() { CellValue = new CellValue(item.up_time?.ToString("yyyy/MM/dd") ?? ""), DataType = CellValues.String },
|
||||||
new Cell() { CellValue = new CellValue(Model.pro_order.keyin1_value_to_text(item.keyin1)), DataType = CellValues.String },
|
new Cell() { CellValue = new CellValue(Model.pro_order.keyin1_value_to_text(item.keyin1)), DataType = CellValues.String },
|
||||||
new Cell() { CellValue = new CellValue(item.f_num), DataType = CellValues.String },
|
new Cell() { CellValue = new CellValue(item.f_num), DataType = CellValues.String },
|
||||||
new Cell() { CellValue = new CellValue(encrypt.DecryptAutoKey(item.phone)), DataType = CellValues.String },
|
new Cell() { CellValue = new CellValue(encrypt.DecryptAutoKey(item.phone)), DataType = CellValues.String },
|
||||||
@@ -274,23 +792,44 @@ public partial class admin_order_index : MyWeb.config
|
|||||||
new Cell() { CellValue = new CellValue(item.d_actItem_num), DataType = CellValues.String },
|
new Cell() { CellValue = new CellValue(item.d_actItem_num), DataType = CellValues.String },
|
||||||
new Cell() { CellValue = new CellValue(item.d_f_num), DataType = CellValues.String },
|
new Cell() { CellValue = new CellValue(item.d_f_num), DataType = CellValues.String },
|
||||||
new Cell() { CellValue = new CellValue(item.d_address), DataType = CellValues.String },
|
new Cell() { CellValue = new CellValue(item.d_address), DataType = CellValues.String },
|
||||||
new Cell() { CellValue = new CellValue(item.d_from_id), DataType = CellValues.String },
|
new Cell() { CellValue = new CellValue(midNamesResult), DataType = CellValues.String },
|
||||||
new Cell() { CellValue = new CellValue(item.d_start_date), DataType = CellValues.String },
|
new Cell() { CellValue = new CellValue(leftNamesResult), DataType = CellValues.String },
|
||||||
new Cell() { CellValue = new CellValue(item.d_due_date), DataType = CellValues.String },
|
//new Cell() { CellValue = new CellValue(item.d_from_id), DataType = CellValues.String },
|
||||||
new Cell() { CellValue = new CellValue(item.d_extend_date), DataType = CellValues.String },
|
new Cell() { CellValue = new CellValue(item.d_start_date?.ToString("yyyy/MM/dd") ?? ""), DataType = CellValues.String },
|
||||||
new Cell() { CellValue = new CellValue((Val(item.d_category) ==(int)Model.activity.category.Order) ?( item.d_notBedQty +"/" + item.d_writeBedQty):""), DataType = CellValues.String },
|
new Cell() { CellValue = new CellValue(item.d_due_date?.ToString("yyyy/MM/dd") ?? ""), DataType = CellValues.String },
|
||||||
|
new Cell() { CellValue = new CellValue(item.d_extend_date?.ToString("yyyy/MM/dd") ?? ""), DataType = CellValues.String },
|
||||||
|
new Cell() { CellValue = new CellValue((Val(item.d_category) == (int)Model.activity.category.Order) ? (item.d_notBedQty + "/" + item.d_writeBedQty) : ""), DataType = CellValues.String },
|
||||||
new Cell() { CellValue = new CellValue("$" + ValMoney(item.d_price)), DataType = CellValues.String },
|
new Cell() { CellValue = new CellValue("$" + ValMoney(item.d_price)), DataType = CellValues.String },
|
||||||
new Cell() { CellValue = new CellValue(item.d_qty), DataType = CellValues.String },
|
new Cell() { CellValue = new CellValue(item.d_qty), DataType = CellValues.String },
|
||||||
new Cell() { CellValue = new CellValue("$" + ValMoney(ValFloat(item.d_price) * Val(item.d_qty))), DataType = CellValues.String },
|
new Cell() { CellValue = new CellValue("$" + ValMoney(ValFloat(item.d_price) * Val(item.d_qty))), DataType = CellValues.String },
|
||||||
new Cell() { CellValue = new CellValue("$" + ValMoney(item.d_pay)), DataType = CellValues.String },
|
new Cell() { CellValue = new CellValue("$" + ValMoney(item.d_pay)), DataType = CellValues.String },
|
||||||
new Cell() { CellValue = new CellValue("$" + ValMoney(ValFloat(item.d_price) * Val(item.d_qty) - ValFloat(item.d_pay))), DataType = CellValues.String },
|
new Cell() { CellValue = new CellValue("$" + ValMoney(ValFloat(item.d_price) * Val(item.d_qty) - ValFloat(item.d_pay))), DataType = CellValues.String },
|
||||||
new Cell() { CellValue = new CellValue(item.d_pay_date), DataType = CellValues.String },
|
new Cell() { CellValue = new CellValue(item.d_pay_date?.ToString("yyyy/MM/dd") ?? ""), DataType = CellValues.String },
|
||||||
new Cell() { CellValue = new CellValue(item.d_keyin1), DataType = CellValues.String },
|
new Cell() { CellValue = new CellValue(item.d_keyin1.HasValue ? tdesc[item.d_keyin1.Value] : ""), DataType = CellValues.String },
|
||||||
new Cell() { CellValue = new CellValue(item.d_demo), DataType = CellValues.String }
|
new Cell() { CellValue = new CellValue(item.d_demo), DataType = CellValues.String }
|
||||||
);
|
);
|
||||||
sd.AppendChild(tr);
|
sd.AppendChild(tr);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//空一列
|
||||||
|
tr = new Row();
|
||||||
|
sd.AppendChild(tr);
|
||||||
|
|
||||||
|
//匯出資訊
|
||||||
|
string _data = "匯出時間 : " + DateTime.Now.ToString("yyyy/MM/dd HH:mm:ss");
|
||||||
|
_data += " " + admin.info.u_id;
|
||||||
|
tr = new Row();
|
||||||
|
tr.Append(
|
||||||
|
new Cell() { CellValue = new CellValue(_data), DataType = CellValues.String }
|
||||||
|
);
|
||||||
|
sd.AppendChild(tr);
|
||||||
|
|
||||||
|
_data = "匯出條件 : " + (!isStrNull(_query) ? _query : "-");
|
||||||
|
tr = new Row();
|
||||||
|
tr.Append(
|
||||||
|
new Cell() { CellValue = new CellValue(_data), DataType = CellValues.String }
|
||||||
|
);
|
||||||
|
sd.AppendChild(tr);
|
||||||
|
|
||||||
Model.admin_log admin_log = new Model.admin_log();
|
Model.admin_log admin_log = new Model.admin_log();
|
||||||
admin_log.writeLog(admin.info.u_id, (int)Model.admin_log.Systems.Order, (int)Model.admin_log.Status.Excel, admin_log.LogViewBtn(list.Select(x => x.order_no).ToList()));
|
admin_log.writeLog(admin.info.u_id, (int)Model.admin_log.Systems.Order, (int)Model.admin_log.Status.Excel, admin_log.LogViewBtn(list.Select(x => x.order_no).ToList()));
|
||||||
|
|||||||
@@ -41,7 +41,7 @@
|
|||||||
{ text: '活動名稱', value: 'subject', },
|
{ text: '活動名稱', value: 'subject', },
|
||||||
{ text: '報到日期', value: 'reg_time_date', },
|
{ text: '報到日期', value: 'reg_time_date', },
|
||||||
{ text: '報到時間', value: 'reg_time_time' },
|
{ text: '報到時間', value: 'reg_time_time' },
|
||||||
{ text: '姓名(人數)', value: 'qty' },
|
{ text: '姓名', value: 'qty' },
|
||||||
{ text: '狀態', value: 'statusTxt' },
|
{ text: '狀態', value: 'statusTxt' },
|
||||||
{ text: '', value: 'slot_btn', sortable: false, align: 'end' }
|
{ text: '', value: 'slot_btn', sortable: false, align: 'end' }
|
||||||
|
|
||||||
@@ -199,7 +199,7 @@
|
|||||||
{{item.reg_time |timeString('HH:mm:ss') }}
|
{{item.reg_time |timeString('HH:mm:ss') }}
|
||||||
</template>
|
</template>
|
||||||
<template #item.qty="{ item }" >
|
<template #item.qty="{ item }" >
|
||||||
{{item.u_name }}({{item.qty }})
|
{{item.u_name }}
|
||||||
</template>
|
</template>
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
@@ -144,13 +144,10 @@
|
|||||||
<tbody>
|
<tbody>
|
||||||
<tr>
|
<tr>
|
||||||
<th>項目名稱</th>
|
<th>項目名稱</th>
|
||||||
<th class="nowarp">姓名</th>
|
<th class="nowarp">陽上</th>
|
||||||
<th>代表地址</th>
|
<th class="nowarp">標題</th>
|
||||||
<th class="nowarp">陽上/報恩</th>
|
|
||||||
<th class="fit">開始日</th>
|
<th class="fit">開始日</th>
|
||||||
<th class="fit">期滿日</th>
|
<th class="fit">期滿日</th>
|
||||||
<th class="fit">延續日</th>
|
|
||||||
<th class="fit">劃位</th>
|
|
||||||
<asp:PlaceHolder ID="PlaceHolder2" runat="server">
|
<asp:PlaceHolder ID="PlaceHolder2" runat="server">
|
||||||
<th class="fit">功德金</th>
|
<th class="fit">功德金</th>
|
||||||
<th class="fit">數量</th>
|
<th class="fit">數量</th>
|
||||||
@@ -167,18 +164,14 @@
|
|||||||
<td>
|
<td>
|
||||||
<asp:Literal ID="actitem_numTxt" runat="server"></asp:Literal></td>
|
<asp:Literal ID="actitem_numTxt" runat="server"></asp:Literal></td>
|
||||||
<td class="nowarp">
|
<td class="nowarp">
|
||||||
<asp:Literal ID="f_numTxt" runat="server"></asp:Literal></td>
|
<asp:Literal ID="left_nameTxt" runat="server"></asp:Literal></td>
|
||||||
<td><%# Eval("address") %></td>
|
|
||||||
<td class="nowarp">
|
<td class="nowarp">
|
||||||
<asp:Literal ID="from_idTxt" runat="server"></asp:Literal></td>
|
<asp:Literal ID="mid_nameTxt" runat="server"></asp:Literal></td>
|
||||||
|
|
||||||
|
|
||||||
<td class="fit"><%# Eval("start_date") != null? Convert.ToDateTime( Eval("start_date")).ToString("yyyy/MM/dd") : "" %></td>
|
<td class="fit"><%# Eval("start_date") != null? Convert.ToDateTime( Eval("start_date")).ToString("yyyy/MM/dd") : "" %></td>
|
||||||
<td class="fit">
|
<td class="fit">
|
||||||
<asp:Literal ID="due_date" runat="server"></asp:Literal></td>
|
<asp:Literal ID="due_date" runat="server"></asp:Literal></td>
|
||||||
<td class="fit">
|
|
||||||
<asp:Literal ID="extend_date" runat="server"></asp:Literal></td>
|
|
||||||
|
|
||||||
<td class="fit">
|
|
||||||
<asp:Literal ID="BedQty" runat="server"></asp:Literal></td>
|
|
||||||
<asp:PlaceHolder ID="PlaceHolder2" runat="server">
|
<asp:PlaceHolder ID="PlaceHolder2" runat="server">
|
||||||
<td class="fit text-end">
|
<td class="fit text-end">
|
||||||
<asp:Literal ID="item_price" runat="server" Text='<%# Eval("price") %>'></asp:Literal></td>
|
<asp:Literal ID="item_price" runat="server" Text='<%# Eval("price") %>'></asp:Literal></td>
|
||||||
|
|||||||
@@ -1,9 +1,15 @@
|
|||||||
using DocumentFormat.OpenXml.Drawing.Charts;
|
using DocumentFormat.OpenXml.Drawing.Charts;
|
||||||
using DocumentFormat.OpenXml.Vml.Office;
|
using DocumentFormat.OpenXml.Vml.Office;
|
||||||
|
using Microsoft.Ajax.Utilities;
|
||||||
|
using Newtonsoft.Json;
|
||||||
|
using Newtonsoft.Json.Linq;
|
||||||
|
using OfficeOpenXml.FormulaParsing.Excel.Functions.Text;
|
||||||
using System;
|
using System;
|
||||||
using System.Collections.Generic;
|
using System.Collections.Generic;
|
||||||
|
using System.Diagnostics;
|
||||||
using System.Linq;
|
using System.Linq;
|
||||||
using System.Web;
|
using System.Web;
|
||||||
|
using System.Web.Helpers;
|
||||||
using System.Web.UI;
|
using System.Web.UI;
|
||||||
using System.Web.UI.WebControls;
|
using System.Web.UI.WebControls;
|
||||||
|
|
||||||
@@ -182,7 +188,19 @@ public partial class admin_follower_print_ : System.Web.UI.Page
|
|||||||
|
|
||||||
if (!string.IsNullOrEmpty(_chkHasAct) && Convert.ToBoolean(_chkHasAct))
|
if (!string.IsNullOrEmpty(_chkHasAct) && Convert.ToBoolean(_chkHasAct))
|
||||||
{
|
{
|
||||||
_query += "活動報名\n";
|
if (!string.IsNullOrEmpty(_selectAct))
|
||||||
|
{
|
||||||
|
int selectAct = Convert.ToInt32(_selectAct);
|
||||||
|
if (selectAct > 0)
|
||||||
|
{
|
||||||
|
var actSubject = _db.activities.Where(a => a.num == selectAct).Select(a => a.subject).FirstOrDefault();
|
||||||
|
_query += $"活動報名: {actSubject}\n";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
_query += $"活動報名\n";
|
||||||
|
}
|
||||||
|
|
||||||
if (!string.IsNullOrEmpty(_chkNoAct) && Convert.ToBoolean(_chkNoAct))
|
if (!string.IsNullOrEmpty(_chkNoAct) && Convert.ToBoolean(_chkNoAct))
|
||||||
{
|
{
|
||||||
@@ -404,16 +422,56 @@ public partial class admin_follower_print_ : System.Web.UI.Page
|
|||||||
actitem_numTxt.Text = row.actItem_num.HasValue && row.actItem != null ? row.actItem.subject : "";
|
actitem_numTxt.Text = row.actItem_num.HasValue && row.actItem != null ? row.actItem.subject : "";
|
||||||
}
|
}
|
||||||
|
|
||||||
Literal fNumTxtLit = (Literal)e.Item.FindControl("f_numTxt");
|
//Literal fNumTxtLit = (Literal)e.Item.FindControl("f_numTxt");
|
||||||
if (fNumTxtLit != null)
|
//if (fNumTxtLit != null)
|
||||||
{
|
//{
|
||||||
fNumTxtLit.Text = row.f_num.HasValue && row.follower != null ? row.follower.u_name : "";
|
// fNumTxtLit.Text = row.f_num.HasValue && row.follower != null ? row.follower.u_name : "";
|
||||||
}
|
//}
|
||||||
|
|
||||||
Literal fromIdTxtLit = (Literal)e.Item.FindControl("from_idTxt");
|
string jsonString = row.f_num_tablet?.ToString() ?? "";
|
||||||
if (fromIdTxtLit != null)
|
if (!string.IsNullOrWhiteSpace(jsonString))
|
||||||
{
|
{
|
||||||
fromIdTxtLit.Text = row.from_id.HasValue && row.follower1 != null ? row.follower1.u_name : "";
|
var jo = JObject.Parse(jsonString);
|
||||||
|
List<string> allMidNames = new List<string>();
|
||||||
|
List<string> allLeftNames = new List<string>();
|
||||||
|
|
||||||
|
// 標題
|
||||||
|
var midNames = jo["mid_items"]?
|
||||||
|
.Select(item => (string)item["fam_name"])
|
||||||
|
.ToList();
|
||||||
|
|
||||||
|
if (midNames != null && midNames.Any())
|
||||||
|
{
|
||||||
|
allMidNames.AddRange(midNames);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (allMidNames.Any())
|
||||||
|
{
|
||||||
|
Literal midNameTextLit = (Literal)e.Item.FindControl("mid_nameTxt");
|
||||||
|
if (midNameTextLit != null)
|
||||||
|
{
|
||||||
|
midNameTextLit.Text = string.Join(", ", allMidNames);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// 陽上
|
||||||
|
var leftNames = jo["left_items"]?
|
||||||
|
.Select(item => (string)item["fam_name"])
|
||||||
|
.ToList();
|
||||||
|
|
||||||
|
if (leftNames != null && leftNames.Any())
|
||||||
|
{
|
||||||
|
allLeftNames.AddRange(leftNames);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (allLeftNames.Any())
|
||||||
|
{
|
||||||
|
Literal leftNameTextLit = (Literal)e.Item.FindControl("left_nameTxt");
|
||||||
|
if (leftNameTextLit != null)
|
||||||
|
{
|
||||||
|
leftNameTextLit.Text = string.Join(", ", allLeftNames);
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
Literal dueDateLit = (Literal)e.Item.FindControl("due_date");
|
Literal dueDateLit = (Literal)e.Item.FindControl("due_date");
|
||||||
@@ -422,21 +480,21 @@ public partial class admin_follower_print_ : System.Web.UI.Page
|
|||||||
dueDateLit.Text = row.due_date.HasValue ? row.due_date.Value.ToString("yyyy-MM-dd") : "";
|
dueDateLit.Text = row.due_date.HasValue ? row.due_date.Value.ToString("yyyy-MM-dd") : "";
|
||||||
}
|
}
|
||||||
|
|
||||||
Literal extendDateLit = (Literal)e.Item.FindControl("extend_date");
|
//Literal extendDateLit = (Literal)e.Item.FindControl("extend_date");
|
||||||
if (extendDateLit != null)
|
//if (extendDateLit != null)
|
||||||
{
|
//{
|
||||||
extendDateLit.Text = row.extend_date.HasValue ? row.extend_date.Value.ToString("yyyy-MM-dd") : "";
|
// extendDateLit.Text = row.extend_date.HasValue ? row.extend_date.Value.ToString("yyyy-MM-dd") : "";
|
||||||
}
|
//}
|
||||||
|
|
||||||
//劃位狀態
|
////劃位狀態
|
||||||
int writeBedQty = _bedDt.Where(b => b.bed_order != null && b.bed_order.o_detail_id == row.num && b.checkIn_date.HasValue && b.bed_kind_detail_id.HasValue).Count();
|
//int writeBedQty = _bedDt.Where(b => b.bed_order != null && b.bed_order.o_detail_id == row.num && b.checkIn_date.HasValue && b.bed_kind_detail_id.HasValue).Count();
|
||||||
int notBedQty = _bedDt.Where(b => b.bed_order != null && b.bed_order.o_detail_id == row.num && (!b.checkIn_date.HasValue || !b.bed_kind_detail_id.HasValue)).Count();
|
//int notBedQty = _bedDt.Where(b => b.bed_order != null && b.bed_order.o_detail_id == row.num && (!b.checkIn_date.HasValue || !b.bed_kind_detail_id.HasValue)).Count();
|
||||||
|
|
||||||
Literal bedQtyLit = (Literal)e.Item.FindControl("BedQty");
|
//Literal bedQtyLit = (Literal)e.Item.FindControl("BedQty");
|
||||||
if (bedQtyLit != null)
|
//if (bedQtyLit != null)
|
||||||
{
|
//{
|
||||||
bedQtyLit.Text = (row.actItem != null && row.actItem.category.HasValue && Convert.ToInt32(row.actItem.category.Value) == (int)Model.activity.category.Order) ? (notBedQty + "/" + writeBedQty) : "";
|
// bedQtyLit.Text = (row.actItem != null && row.actItem.category.HasValue && Convert.ToInt32(row.actItem.category.Value) == (int)Model.activity.category.Order) ? (notBedQty + "/" + writeBedQty) : "";
|
||||||
}
|
//}
|
||||||
|
|
||||||
Literal keyin1Lit = (Literal)e.Item.FindControl("keyin1");
|
Literal keyin1Lit = (Literal)e.Item.FindControl("keyin1");
|
||||||
if (keyin1Lit != null)
|
if (keyin1Lit != null)
|
||||||
|
|||||||
@@ -755,6 +755,7 @@
|
|||||||
curr.select(this.editedItem, row);
|
curr.select(this.editedItem, row);
|
||||||
}
|
}
|
||||||
this.search_dialog.show = false;
|
this.search_dialog.show = false;
|
||||||
|
this.search_dialog.page = 1;
|
||||||
//console.log(row, row["u_name"], row["f_number"], curr.id, target);
|
//console.log(row, row["u_name"], row["f_number"], curr.id, target);
|
||||||
},
|
},
|
||||||
//報名詳細資料
|
//報名詳細資料
|
||||||
@@ -859,7 +860,7 @@
|
|||||||
isValidDate = Date.parse(item.pay_date);
|
isValidDate = Date.parse(item.pay_date);
|
||||||
if (!isNaN(isValidDate))
|
if (!isNaN(isValidDate))
|
||||||
item.pay_date = new Date(item.pay_date).format("yyyy-MM-dd")
|
item.pay_date = new Date(item.pay_date).format("yyyy-MM-dd")
|
||||||
|
console.log(item);
|
||||||
this.editedItem = $.extend(true, {}, item);
|
this.editedItem = $.extend(true, {}, item);
|
||||||
this.data_dialog.show = true;
|
this.data_dialog.show = true;
|
||||||
this.data_dialog.isAddNew = false;
|
this.data_dialog.isAddNew = false;
|
||||||
@@ -1100,9 +1101,11 @@
|
|||||||
/* (this.editedItem.category=="1"? this.editedItem.from_id_selected.val != 0 : true) &&*/
|
/* (this.editedItem.category=="1"? this.editedItem.from_id_selected.val != 0 : true) &&*/
|
||||||
this.requireData(this.editedItem.qty, (this.editedItem.num == 0 ? false : true)) ) /* qty為0視為不需要此項目,不儲存此筆資料*/
|
this.requireData(this.editedItem.qty, (this.editedItem.num == 0 ? false : true)) ) /* qty為0視為不需要此項目,不儲存此筆資料*/
|
||||||
{
|
{
|
||||||
|
console.log(this.editedItem);
|
||||||
//check price
|
//check price
|
||||||
if (this.editedItem.pay <= this.editedItem.price * this.editedItem.qty) {
|
if (this.editedItem.pay <= this.editedItem.price * this.editedItem.qty) {
|
||||||
|
console.log(this.editedItem.f_num_selected.val);
|
||||||
|
console.log(this.editedItem.from_id_selected.val);
|
||||||
//check qty
|
//check qty
|
||||||
//數量不可小於掛單明細的數量
|
//數量不可小於掛單明細的數量
|
||||||
if (this.editedItem.qty >= this.editedItem.writeBedQty + this.editedItem.notBedQty) {
|
if (this.editedItem.qty >= this.editedItem.writeBedQty + this.editedItem.notBedQty) {
|
||||||
@@ -1857,7 +1860,7 @@
|
|||||||
<div class="">
|
<div class="">
|
||||||
<asp:Button ID="add" runat="server" Text="送出" OnClick="add_Click" CssClass="btn btn-primary" />
|
<asp:Button ID="add" runat="server" Text="送出" OnClick="add_Click" CssClass="btn btn-primary" />
|
||||||
<asp:Button ID="edit" runat="server" Text="修改" Visible="false" OnClick="edit_Click" CssClass="btn btn-primary" />
|
<asp:Button ID="edit" runat="server" Text="修改" Visible="false" OnClick="edit_Click" CssClass="btn btn-primary" />
|
||||||
<asp:Button ID="goback" runat="server" Text="回列表" Visible="false" CausesValidation="false" OnClick="goback_Click" CssClass="btn btn-outline-secondary" />
|
<asp:Button ID="goback" runat="server" Text="取消" CausesValidation="false" OnClick="goback_Click" CssClass="btn btn-outline-secondary" />
|
||||||
</div>
|
</div>
|
||||||
</asp:Content>
|
</asp:Content>
|
||||||
<asp:Content ID="Content2" ContentPlaceHolderID="ContentPlaceHolder1" runat="Server">
|
<asp:Content ID="Content2" ContentPlaceHolderID="ContentPlaceHolder1" runat="Server">
|
||||||
@@ -2486,7 +2489,7 @@
|
|||||||
<v-card>
|
<v-card>
|
||||||
<v-card-title class="justify-space-between grey lighten-2">
|
<v-card-title class="justify-space-between grey lighten-2">
|
||||||
查詢:{{search_dialog.current.title}}
|
查詢:{{search_dialog.current.title}}
|
||||||
<v-btn icon @click="search_dialog.show=false"><v-icon>mdi-close</v-icon></v-btn>
|
<v-btn icon @click="search_dialog.show=false; search_dialog.page = 1;"><v-icon>mdi-close</v-icon></v-btn>
|
||||||
</v-card-title>
|
</v-card-title>
|
||||||
<v-card-text >
|
<v-card-text >
|
||||||
<v-row>
|
<v-row>
|
||||||
|
|||||||
+26
-12
@@ -1,15 +1,16 @@
|
|||||||
using System;
|
using DocumentFormat.OpenXml.Spreadsheet;
|
||||||
|
using System;
|
||||||
using System.Collections;
|
using System.Collections;
|
||||||
using System.Collections.Generic;
|
using System.Collections.Generic;
|
||||||
|
using System.Configuration;
|
||||||
using System.Data;
|
using System.Data;
|
||||||
|
using System.Data.Entity.Infrastructure;
|
||||||
using System.Data.OleDb;
|
using System.Data.OleDb;
|
||||||
|
using System.IO;
|
||||||
|
using System.Linq;
|
||||||
using System.Web;
|
using System.Web;
|
||||||
using System.Web.UI;
|
using System.Web.UI;
|
||||||
using System.Web.UI.WebControls;
|
using System.Web.UI.WebControls;
|
||||||
using System.Configuration;
|
|
||||||
using System.IO;
|
|
||||||
using System.Linq;
|
|
||||||
using System.Data.Entity.Infrastructure;
|
|
||||||
|
|
||||||
public partial class admin_order_reg : MyWeb.config
|
public partial class admin_order_reg : MyWeb.config
|
||||||
{
|
{
|
||||||
@@ -187,16 +188,29 @@ public partial class admin_order_reg : MyWeb.config
|
|||||||
{
|
{
|
||||||
if (!isStrNull(pro_order.order_no))
|
if (!isStrNull(pro_order.order_no))
|
||||||
{
|
{
|
||||||
_db.pro_order.Add(pro_order);
|
bool isRegistered = _db.pro_order.Any(x => x.f_num == pro_order.f_num && x.activity_num == pro_order.activity_num);
|
||||||
_db.SaveChanges();
|
|
||||||
|
|
||||||
Model.admin_log admin_log = new Model.admin_log();
|
if (isRegistered) // 重複報名
|
||||||
admin_log.writeLog(admin.info.u_id, (int)Model.admin_log.Systems.Order, (int)Model.admin_log.Status.Insert, pro_order.order_no);
|
{
|
||||||
|
L_msg.Type = alert_type.warning;
|
||||||
|
L_msg.Text = "此信眾已報名過本活動";
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
_db.pro_order.Add(pro_order);
|
||||||
|
_db.SaveChanges();
|
||||||
|
|
||||||
|
Model.admin_log admin_log = new Model.admin_log();
|
||||||
|
admin_log.writeLog(admin.info.u_id, (int)Model.admin_log.Systems.Order, (int)Model.admin_log.Status.Insert, pro_order.order_no);
|
||||||
|
|
||||||
|
|
||||||
string url = "index.aspx";
|
string url = "index.aspx";
|
||||||
url = "reg.aspx?order_no=" + pro_order.order_no;
|
url = "reg.aspx?order_no=" + pro_order.order_no;
|
||||||
Response.Redirect(url);
|
|
||||||
|
Session["LastAddedNo"] = pro_order.order_no;
|
||||||
|
|
||||||
|
Response.Redirect(url);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
|||||||
+3
-1
@@ -1,4 +1,4 @@
|
|||||||
<?xml version="1.0" encoding="utf-8"?>
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
<configuration>
|
<configuration>
|
||||||
<configSections>
|
<configSections>
|
||||||
<!-- For more information on Entity Framework configuration, visit http://go.microsoft.com/fwlink/?LinkID=237468 -->
|
<!-- For more information on Entity Framework configuration, visit http://go.microsoft.com/fwlink/?LinkID=237468 -->
|
||||||
@@ -43,6 +43,8 @@
|
|||||||
<!--網站的簡稱,用來區別session和cookie-->
|
<!--網站的簡稱,用來區別session和cookie-->
|
||||||
<add key="SC" value="erp17168" />
|
<add key="SC" value="erp17168" />
|
||||||
<add key="LogPath" value="C:\\log\\" />
|
<add key="LogPath" value="C:\\log\\" />
|
||||||
|
<!--是否啟用信眾自動編號 (true=啟用, false=停用)-->
|
||||||
|
<add key="IsAutoNumbering" value="true" />
|
||||||
</appSettings>
|
</appSettings>
|
||||||
<connectionStrings>
|
<connectionStrings>
|
||||||
<!--SQL用-->
|
<!--SQL用-->
|
||||||
|
|||||||
@@ -0,0 +1,8 @@
|
|||||||
|
FK_act_bom_actItem1 刪除規則設為 cascade
|
||||||
|
FK_pro_order_followers 刪除規則設為 cascade
|
||||||
|
FK_pro_order_activity 刪除規則設為 cascade
|
||||||
|
FK_pro_order_detail_pro_order 刪除規則設為 cascade
|
||||||
|
FK_pro_order_detail_followers 刪除規則設為 沒有動作
|
||||||
|
FK_activity_relating_activity 刪除規則設為 cascade
|
||||||
|
|
||||||
|
actitem 加上 sort_order(int) 欄位
|
||||||
Reference in New Issue
Block a user