TKApiBLL.cs 19 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447
  1. using Business.TK;
  2. using Common;
  3. using M55128_rec.Models.ViewModels.GallerMangerModel;
  4. using M55128_rec.Util;
  5. using Models;
  6. using Models.Entity.LottomatBaseDB;
  7. using Models.Views;
  8. using Services;
  9. using System;
  10. using System.Collections.Generic;
  11. using System.Globalization;
  12. using System.Linq;
  13. using System.Web;
  14. namespace M55128_rec.Business.TK
  15. {
  16. public static class TKApiBLL
  17. {
  18. static TKApiBLL()
  19. {
  20. // log = new LogHelper();
  21. }
  22. public static List<QueryAllDataModel> QueryAll(int page, int rows, Dictionary<string, Object> queryjson, out int totalrows, out int totalpage, int periodsNumber)
  23. {
  24. totalrows = 0;
  25. List<QueryAllDataModel> rtdata = new List<QueryAllDataModel>();
  26. totalpage = 0;
  27. try
  28. {
  29. List<Tk_Gallery> list = Tk_GalleryBLL.GetPageList(page, rows, queryjson, out totalrows, "GalleryNumber").ToList();
  30. List<string> gallid = list.Select(s => s.ID).ToList();
  31. List<Tk_GalleryDetail> qDetailList = new List<Tk_GalleryDetail>();
  32. if (periodsNumber == 0)
  33. {
  34. periodsNumber = DateHelper.getTimeSpan();
  35. }
  36. if (gallid.Count > 0)
  37. {
  38. qDetailList = Tk_GalleryDetailBLL.QueryDetailByGalleryId(gallid, periodsNumber);
  39. }
  40. totalpage = totalrows % rows > 0 ? totalrows / rows + 1 : totalrows / rows;
  41. string[] aryname = new string[] { "A", "B", "C" };
  42. for (int i = 0; i < aryname.Length; i++)
  43. {
  44. List<ImageMenuInfoModel> tlist = new List<ImageMenuInfoModel>();
  45. IEnumerator<Tk_Gallery> tmp = list.Where(t => t.AreaCode == aryname[i]).GetEnumerator();
  46. while (tmp.MoveNext())
  47. {
  48. ImageMenuInfoModel tmpImg = new ImageMenuInfoModel()
  49. {
  50. GalleryNumStr = tmp.Current.AreaCode + GetGallerNum(tmp.Current.GalleryNumber),
  51. AreaCode = tmp.Current.AreaCode,
  52. CreateTime = tmp.Current.CreateTime.ToString(),
  53. GalleryName = tmp.Current.GalleryName,
  54. GalleryNumber = tmp.Current.GalleryNumber,
  55. HotNumber = int.Parse(tmp.Current.HotNumber),
  56. ID = tmp.Current.ID,
  57. Reamrk = tmp.Current.Reamrk,
  58. HasImage = 0
  59. };
  60. List<Tk_GalleryDetail> qtmp = qDetailList.Where(w => w.GalleryId == tmpImg.ID && w.PeriodsNumber == periodsNumber).ToList();
  61. if (qtmp.Count > 0)
  62. {
  63. tmpImg.ImageUrl = qtmp[0].ImageUrl;
  64. tmpImg.HasImage = 1;
  65. tmpImg.PK = qtmp[0].PK.ToString();
  66. }
  67. tlist.Add(tmpImg);
  68. }
  69. tlist = tlist.OrderBy(s => s.GalleryNumber).ToList();//升序排序
  70. rtdata.Add(new QueryAllDataModel() { AreaName = aryname[i], list = tlist, PeriodsNumber = periodsNumber });
  71. }
  72. }
  73. catch (Exception ee)
  74. {
  75. LogHelper.Error(typeof(TKApiBLL), ee.Message + "QueryAll");
  76. }
  77. return rtdata;
  78. }
  79. public static string GetGallerNum(int num)
  80. {
  81. if (num.ToString().Length < 2)
  82. {
  83. return "0" + num.ToString();
  84. }
  85. else
  86. {
  87. return num.ToString();
  88. }
  89. }
  90. public static List<HotMenuModel> QueryHotMenu(List<string> areacode)
  91. {
  92. List<HotMenuModel> rtdata = new List<HotMenuModel>();
  93. try
  94. {
  95. IEnumerator<DataItemModel> enumerator = DataItemBLL.GetDataItemList(areacode).GetEnumerator();
  96. while (enumerator.MoveNext())
  97. {
  98. HotMenuModel tmp = new HotMenuModel()
  99. {
  100. EnCode = enumerator.Current.EnCode,
  101. SimpleSpelling = enumerator.Current.SimpleSpelling,
  102. SortCode = enumerator.Current.SortCode.Value,
  103. ID = enumerator.Current.ItemDetailId,
  104. ItemName = enumerator.Current.ItemName,
  105. ItemValue = enumerator.Current.ItemValue,
  106. };
  107. rtdata.Add(tmp);
  108. }
  109. }
  110. catch (Exception ee)
  111. {
  112. LogHelper.Error(typeof(TKApiBLL), ee.Message + "QueryHotMenu");
  113. }
  114. //rtdata = rtdata.OrderBy(s => s.GalleryNumber).ToList();//升序排序
  115. return rtdata;
  116. }
  117. public static List<ImageMenuInfoModel> QueryHotArtList(int page, int rows, string menuname, out int totalrows, out int totalpage, int periodsNumber)
  118. {
  119. List<ImageMenuInfoModel> rtdata = new List<ImageMenuInfoModel>();
  120. totalrows = 0;
  121. totalpage = 0;
  122. try
  123. {
  124. Dictionary<string, object> dict = new Dictionary<string, object>();
  125. dict["SeoKey"] = menuname;
  126. List<Tk_Gallery> list = Tk_GalleryBLL.GetPageList(page, rows, dict, out totalrows, "GalleryNumber", false).ToList();
  127. totalpage = totalrows % rows > 0 ? totalrows / rows + 1 : totalrows / rows;
  128. List<string> gallid = list.Select(s => s.ID).ToList();
  129. List<Tk_GalleryDetail> qDetailList = new List<Tk_GalleryDetail>();
  130. if (periodsNumber == 0)
  131. {
  132. periodsNumber = Tk_GalleryBLL.NewPeriodsNumber();
  133. }
  134. if (gallid.Count > 0)
  135. {
  136. qDetailList = Tk_GalleryDetailBLL.QueryDetailByGalleryId(gallid, periodsNumber);
  137. }
  138. List<ImageMenuInfoModel> tplist = new List<ImageMenuInfoModel>();
  139. IEnumerator<Tk_Gallery> enumerator = list.GetEnumerator();
  140. while (enumerator.MoveNext())
  141. {
  142. ImageMenuInfoModel tmp = new ImageMenuInfoModel()
  143. {
  144. GalleryNumStr = enumerator.Current.AreaCode + GetGallerNum(enumerator.Current.GalleryNumber),
  145. GalleryName = enumerator.Current.GalleryName,
  146. AreaCode = enumerator.Current.AreaCode,
  147. CreateTime = enumerator.Current.CreateTime.ToString(),
  148. GalleryNumber = enumerator.Current.GalleryNumber,
  149. HotNumber = int.Parse(enumerator.Current.HotNumber),
  150. ID = enumerator.Current.ID.ToString(),
  151. Reamrk = enumerator.Current.Reamrk
  152. };
  153. List<Tk_GalleryDetail> qtmp = qDetailList.Where(w => w.GalleryId == tmp.ID && w.PeriodsNumber == periodsNumber).ToList();
  154. if (qtmp.Count > 0)
  155. {
  156. tmp.ImageUrl = qtmp[0].ImageUrl;
  157. tmp.HasImage = 1;
  158. tmp.PK = qtmp[0].PK.ToString();
  159. }
  160. tplist.Add(tmp);
  161. }
  162. // rtdata = rtdata.OrderBy(s => s.GalleryNumber).ToList();//升序排序
  163. List<ImageMenuInfoModel> alist = tplist.Where(w => w.AreaCode == "A").OrderBy(o => o.GalleryNumber).ToList();
  164. List<ImageMenuInfoModel> blist = tplist.Where(w => w.AreaCode == "B").OrderBy(o => o.GalleryNumber).ToList();
  165. List<ImageMenuInfoModel> clist = tplist.Where(w => w.AreaCode == "C").OrderBy(o => o.GalleryNumber).ToList();
  166. rtdata.AddRange(alist);
  167. rtdata.AddRange(blist);
  168. rtdata.AddRange(clist);
  169. }
  170. catch (Exception ee)
  171. {
  172. LogHelper.Error(typeof(TKApiBLL), ee.Message + "QueryHotArtList");
  173. }
  174. return rtdata;
  175. }
  176. public static List<ImageMenuInfoModel> QueryNew(int page, int rows, out int totalrows, out int totalpage, int periodsNumber)
  177. {
  178. List<ImageMenuInfoModel> rtdata = new List<ImageMenuInfoModel>();
  179. totalpage = 0;
  180. totalrows = 0;
  181. try
  182. {
  183. List<Tk_Gallery> list = Tk_GalleryBLL.GetPageList(page, rows, new Dictionary<string, object>(), out totalrows, "GalleryNumber", false).ToList();
  184. totalpage = totalrows % rows > 0 ? totalrows / rows + 1 : totalrows / rows;
  185. IEnumerator<Tk_Gallery> enumerator = list.GetEnumerator();
  186. List<string> gallid = list.Select(s => s.ID).ToList();
  187. List<Tk_GalleryDetail> qDetailList = new List<Tk_GalleryDetail>();
  188. if (periodsNumber == 0)
  189. {
  190. periodsNumber = Tk_GalleryBLL.NewPeriodsNumber();
  191. }
  192. if (gallid.Count > 0)
  193. {
  194. qDetailList = Tk_GalleryDetailBLL.QueryDetailByGalleryId(gallid, periodsNumber);
  195. }
  196. List<ImageMenuInfoModel> tplist = new List<ImageMenuInfoModel>();
  197. while (enumerator.MoveNext())
  198. {
  199. ImageMenuInfoModel tmp = new ImageMenuInfoModel()
  200. {
  201. GalleryNumStr = enumerator.Current.AreaCode + GetGallerNum(enumerator.Current.GalleryNumber),
  202. GalleryName = enumerator.Current.GalleryName,
  203. AreaCode = enumerator.Current.AreaCode,
  204. CreateTime = enumerator.Current.CreateTime.ToString(),
  205. GalleryNumber = enumerator.Current.GalleryNumber,
  206. HotNumber = int.Parse(enumerator.Current.HotNumber),
  207. //ID = enumerator.Current.PK.ToString(),
  208. ID = enumerator.Current.ID,
  209. Reamrk = enumerator.Current.Reamrk
  210. };
  211. List<Tk_GalleryDetail> qtmp = qDetailList.Where(w => w.GalleryId == tmp.ID && w.PeriodsNumber == periodsNumber).ToList();
  212. if (qtmp.Count > 0)
  213. {
  214. tmp.ImageUrl = qtmp[0].ImageUrl;
  215. tmp.HasImage = 1;
  216. //tmp.ID = qtmp[0].PK.ToString();
  217. tmp.PK = qtmp[0].PK.ToString();
  218. }
  219. tplist.Add(tmp);
  220. }
  221. List<ImageMenuInfoModel> alist = tplist.Where(w => w.AreaCode == "A").OrderBy(o => o.GalleryNumber).ToList();
  222. List<ImageMenuInfoModel> blist = tplist.Where(w => w.AreaCode == "B").OrderBy(o => o.GalleryNumber).ToList();
  223. List<ImageMenuInfoModel> clist = tplist.Where(w => w.AreaCode == "C").OrderBy(o => o.GalleryNumber).ToList();
  224. rtdata.AddRange(alist);
  225. rtdata.AddRange(blist);
  226. rtdata.AddRange(clist);
  227. }
  228. catch (Exception ee)
  229. {
  230. LogHelper.Error(typeof(TKApiBLL), ee.Message + "QueryNew");
  231. }
  232. return rtdata;
  233. // rtdata = rtdata.OrderBy(s => s.GalleryNumber).ToList();//升序排序
  234. }
  235. /// <summary>
  236. /// 查询图谜实体
  237. /// </summary>
  238. /// <param name="artInfoParams"></param>
  239. /// <returns></returns>
  240. public static ImageInfoModel QueryArtInfo(string ID = null, string PeriodsNumber = null, string pk = null)
  241. {
  242. ImageInfoModel rtdata = new ImageInfoModel();
  243. try
  244. {
  245. int num = 0;
  246. var data = Tk_GalleryDetailBLL.Qthreelist( int.Parse(pk),out num);
  247. var tmpsimple = data.Where(w => w.PeriodsNumber == num).ToList();
  248. if (tmpsimple.Count>0)
  249. {
  250. rtdata = new ImageInfoModel()
  251. {
  252. galleryId = tmpsimple[0].GalleryId,
  253. PK= tmpsimple[0].PK,
  254. SortCode = tmpsimple[0].SortCode,
  255. ID = tmpsimple[0].ID,
  256. ImageUrl = tmpsimple[0].ImageUrl,
  257. PeriodsNumber = tmpsimple[0].PeriodsNumber.ToString(),
  258. };
  259. var lastsimple = data.Where(w => w.PeriodsNumber == int.Parse(PeriodsNumber) - 1).ToList() ;
  260. if (lastsimple.Count>0)
  261. {
  262. ImageInfoModel tmp = new ImageInfoModel()
  263. {
  264. galleryId = lastsimple[0].GalleryId,
  265. PK = lastsimple[0].PK,
  266. SortCode = lastsimple[0].SortCode,
  267. ID = lastsimple[0].ID,
  268. ImageUrl = lastsimple[0].ImageUrl,
  269. PeriodsNumber = lastsimple[0].PeriodsNumber.ToString(),
  270. };
  271. rtdata.LastModel = tmp;
  272. }
  273. var nextsimple = data.Where(w => w.PeriodsNumber == int.Parse(PeriodsNumber) + 1).ToList() ;
  274. if (nextsimple.Count>0)
  275. {
  276. ImageInfoModel tmp = new ImageInfoModel()
  277. {
  278. galleryId = nextsimple[0].GalleryId,
  279. PK = nextsimple[0].PK,
  280. SortCode = nextsimple[0].SortCode,
  281. ID = nextsimple[0].ID,
  282. ImageUrl = nextsimple[0].ImageUrl,
  283. PeriodsNumber = nextsimple[0].PeriodsNumber.ToString(),
  284. };
  285. rtdata.NextModel = tmp;
  286. }
  287. }
  288. }
  289. catch (Exception ee)
  290. {
  291. LogHelper.Error(typeof(TKApiBLL), ee.Message + "QueryArtInfo");
  292. }
  293. return rtdata;
  294. }
  295. public static List<GalleryNumberList> GetTkPeriodsNumberList()
  296. {
  297. List<GalleryNumberList> newsPreviewItem = new List<GalleryNumberList>();
  298. try
  299. {
  300. string year = DateTime.Now.Year.ToString();
  301. string oldyear = DateTime.Now.AddYears(-1).Year.ToString();
  302. var data = Tk_GalleryBLL.GalleryNumberList();
  303. int num=DateHelper.getTimeSpan();
  304. var newyearlist = data.Where(w => int.Parse(w) <100).ToList();
  305. if (newyearlist.Count>0)
  306. {
  307. var oldyearlist= data.Where(w => int.Parse(w) > 100).ToList();
  308. foreach (var item in newyearlist)
  309. {
  310. GalleryNumberList preItem = new GalleryNumberList
  311. {
  312. PeriodsNumber = item,
  313. Title = year + item,
  314. };
  315. newsPreviewItem.Add(preItem);
  316. }
  317. foreach (var item in oldyearlist)
  318. {
  319. GalleryNumberList preItem = new GalleryNumberList
  320. {
  321. PeriodsNumber = item,
  322. Title = oldyear + item,
  323. };
  324. newsPreviewItem.Add(preItem);
  325. }
  326. }
  327. else
  328. {
  329. foreach (var item in data)
  330. {
  331. GalleryNumberList preItem = new GalleryNumberList
  332. {
  333. PeriodsNumber = item,
  334. Title = year + item,
  335. };
  336. newsPreviewItem.Add(preItem);
  337. }
  338. }
  339. newsPreviewItem.RemoveAll(w => int.Parse(w.Title) > int.Parse(DateTime.Now.Year +"0"+ num.ToString()));
  340. }
  341. catch (Exception ee)
  342. {
  343. LogHelper.Error(typeof(TKApiBLL), ee.Message + "GetTkPeriodsNumberList");
  344. }
  345. return newsPreviewItem;
  346. }
  347. public static TrendChartModel GetTrendChartSRC(string LotteryType)
  348. {
  349. TrendChartModel data = new TrendChartModel();
  350. try
  351. {
  352. DataItemModel itemdata = DataItemBLL.GetDataItemList(LotteryType);//param.LotteryType
  353. int count = 0;
  354. List<Base_TrendChart> list = TrendChartBLL.GetList(1, 10, new Dictionary<string, object>() { { "CategoryId", itemdata.ItemDetailId }, { "LikeTitle", "基本走势图" } }, out count, null, false);
  355. if (list.Count == 0)//继续采用走势图匹配
  356. {
  357. list = TrendChartBLL.GetList(1, 10, new Dictionary<string, object>() { { "CategoryId", itemdata.ItemDetailId }, { "EqTitle", "走势图" } }, out count, null, false);
  358. //trendChartBLL.GetPageList(s => s.CategoryId == itemdata.ItemDetailId && s.Title == "走势图").ToList();
  359. }
  360. if (list.Count == 0)//继续采用走势图带连线 匹配
  361. {
  362. list = TrendChartBLL.GetList(1, 10, new Dictionary<string, object>() { { "CategoryId", itemdata.ItemDetailId }, { "EqTitle", "走势图带连线" } }, out count, null, false);
  363. //trendChartBLL.GetPageList(s => s.CategoryId == itemdata.ItemDetailId && s.Title == "走势图带连线").ToList();
  364. }
  365. if (list.Count == 0)//还是就返回失败
  366. {
  367. return null;
  368. }
  369. else
  370. {
  371. data = new TrendChartModel()
  372. {
  373. Name = list[0].Title,
  374. Url = list[0].TrendChartUrl
  375. };
  376. }
  377. }
  378. catch (Exception ee)
  379. {
  380. LogHelper.Error(typeof(TKApiBLL), ee.Message + "GetTrendChartSRC");
  381. }
  382. return data;
  383. }
  384. public static string GetMaxInYear(string year)
  385. {
  386. string qs = "";
  387. try
  388. {
  389. qs = Tk_GalleryBLL.GetYearMaxPeridos(year);
  390. }
  391. catch (Exception ee)
  392. {
  393. LogHelper.Error(typeof(TKApiBLL), ee.Message + "GetMaxInYear");
  394. }
  395. return year + qs.PadLeft(3, '0');
  396. }
  397. public static Tk_Gallery GetBykey(object key)
  398. {
  399. return Tk_GalleryBLL.QueryItemByKey(key);
  400. }
  401. }
  402. }