ZhiYeJianKang_PeiXun/Song.Site/Manage/Questions/Wrong.aspx.cs
2025-02-20 15:41:53 +08:00

223 lines
8.2 KiB
C#

using System;
using System.Data;
using System.Configuration;
using System.Collections;
using System.Web;
using System.Web.Security;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Web.UI.WebControls.WebParts;
using System.Web.UI.HtmlControls;
using System.Data.OleDb;
using System.IO;
using WeiSha.Common;
using Song.ServiceInterfaces;
using Song.Entities;
using WeiSha.WebControl;
using System.Text.RegularExpressions;
using NPOI.HSSF.UserModel;
using NPOI.SS.UserModel;
using System.Collections.Generic;
namespace Song.Site.Manage.Questions
{
public partial class Wrong : Extend.CustomPage
{
//题型分类汉字名称
protected string[] typeStr = App.Get["QuesType"].Split(',');
Song.Entities.Organization org = null;
protected void Page_Load(object sender, EventArgs e)
{
this.Form.DefaultButton = this.btnSear.UniqueID;
org = Business.Do<IOrganization>().OrganCurrent();
if (!IsPostBack)
{
InitBind();
BindData(null, null);
}
}
#region
/// <summary>
/// 界面的初始绑定
/// </summary>
private void InitBind()
{
//专业
Song.Entities.Subject[] subjects = Business.Do<ISubject>().SubjectCount(org.Org_ID, null, true, -1, -1);
ddlSubject.DataSource = subjects;
this.ddlSubject.DataTextField = "Sbj_Name";
this.ddlSubject.DataValueField = "Sbj_ID";
this.ddlSubject.Root = 0;
this.ddlSubject.DataBind();
ddlSubject.Items.Insert(0, new ListItem("-专业-", "0"));
//
this.SearchBind(this.searchBox);
ddlSubject_SelectedIndexChanged(null, null);
}
/// <summary>
/// 专业选择变更事件
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
protected void ddlSubject_SelectedIndexChanged(object sender, EventArgs e)
{
ddlCourse.Items.Clear();
int sbjid;
int.TryParse(ddlSubject.SelectedValue, out sbjid);
if (sbjid > 0)
{
//上级
List<Song.Entities.Course> cous = Business.Do<ICourse>().CourseCount(org.Org_ID, sbjid, null, true, -1);
ddlCourse.DataSource = cous;
this.ddlCourse.DataTextField = "Cou_Name";
this.ddlCourse.DataValueField = "Cou_ID";
this.ddlCourse.Root = 0;
this.ddlCourse.DataBind();
}
ddlCourse.Items.Insert(0, new ListItem("-课程-", "0"));
this.SearchBind(this.searchBox);
ddlCourse_SelectedIndexChanged(null, null);
}
/// <summary>
/// 课程选择项变更事件
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
protected void ddlCourse_SelectedIndexChanged(object sender, EventArgs e)
{
ddlOutline.Items.Clear();
//课程id
int cou;
int.TryParse(ddlCourse.SelectedValue, out cou);
if (cou > 0)
{
Song.Entities.Outline[] outline = Business.Do<IOutline>().OutlineAll(cou, null);
ddlOutline.DataSource = outline;
this.ddlOutline.DataTextField = "Ol_Name";
this.ddlOutline.DataValueField = "Ol_ID";
ddlOutline.DataBind();
}
this.ddlOutline.Items.Insert(0, new ListItem("-章节-", "0"));
this.SearchBind(this.searchBox);
BindData(null, null);
}
#endregion
/// <summary>
/// 绑定列表
/// </summary>
protected void BindData(object sender, EventArgs e)
{
Song.Entities.Organization org = Business.Do<IOrganization>().OrganCurrent();
//总记录数
int count = 0;
//学科,课程,章节
int sbjid = 0, couid = 0, olid = 0;
int.TryParse(ddlSubject.SelectedValue, out sbjid);
int.TryParse(ddlCourse.SelectedValue, out couid);
int.TryParse(ddlOutline.SelectedValue, out olid);
//难易度
int diff = Convert.ToInt32(ddlDiff.SelectedItem.Value);
Song.Entities.Questions[] eas = null;
eas = Business.Do<IQuestions>().QuesPager(org.Org_ID, -1, sbjid, couid, olid, null, null,true, diff, this.tbSear.Text, Pager1.Size, Pager1.Index, out count);
GridView1.DataSource = eas;
//去除题干中的html标签
string regexstr = @"(<[^>]*>)|\r|\n|\s";
foreach (Song.Entities.Questions q in eas)
{
q.Qus_Title = Regex.Replace(q.Qus_Title, regexstr, string.Empty, RegexOptions.IgnoreCase);
}
GridView1.DataKeyNames = new string[] { "Qus_ID" };
GridView1.DataBind();
Pager1.RecordAmount = count;
}
protected void btnsear_Click(object sender, EventArgs e)
{
Pager1.Qurey = this.SearchQuery(this.searchBox);
Pager1.Index = 1;
////BindData(null, null);
//string tm = this.Search(this.searchBox);
//this.Response.Write(tm);
}
/// <summary>
/// 删除
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
protected void DeleteEvent(object sender, EventArgs e)
{
string keys = GridView1.GetKeyValues;
Business.Do<IQuestions>().QuesDelete(keys);
BindData(null, null);
}
/// <summary>
/// 单个删除
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
protected void btnDel_Click(object sender, ImageClickEventArgs e)
{
WeiSha.WebControl.RowDelete img = (WeiSha.WebControl.RowDelete)sender;
int index = ((GridViewRow)(img.Parent.Parent)).RowIndex;
int id = int.Parse(this.GridView1.DataKeys[index].Value.ToString());
Business.Do<IQuestions>().QuesDelete(id);
BindData(null, null);
}
/// <summary>
/// 修改是否显示的状态
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
protected void sbUse_Click(object sender, EventArgs e)
{
StateButton ub = (StateButton)sender;
int index = ((GridViewRow)(ub.Parent.Parent)).RowIndex;
int id = int.Parse(this.GridView1.DataKeys[index].Value.ToString());
//
Song.Entities.Questions entity = Business.Do<IQuestions>().QuesSingle(id);
entity.Qus_IsUse = !entity.Qus_IsUse;
Business.Do<IQuestions>().QuesSave(entity);
BindData(null, null);
}
protected void lbUse_Click(object sender, EventArgs e)
{
string keys = GridView1.GetKeyValues;
foreach (string id in keys.Split(','))
{
if (string.IsNullOrEmpty(id)) continue;
int tmid = Convert.ToInt16(id);
Song.Entities.Questions entity = Business.Do<IQuestions>().QuesSingle(tmid);
entity.Qus_IsUse = true;
Business.Do<IQuestions>().QuesSave(entity);
}
BindData(null, null);
}
protected void lbNoUse_Click(object sender, EventArgs e)
{
try
{
string keys = GridView1.GetKeyValues;
foreach (string id in keys.Split(','))
{
if (string.IsNullOrEmpty(id)) continue;
int tmid = Convert.ToInt16(id);
Song.Entities.Questions entity = Business.Do<IQuestions>().QuesSingle(tmid);
entity.Qus_IsUse = false;
Business.Do<IQuestions>().QuesSave(entity);
}
BindData(null, null);
}
catch (Exception ex)
{
Message.ExceptionShow(ex);
}
}
}
}