detail.js 17 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638
  1. import common from '../../utils/util';
  2. import main from '../../utils/main';
  3. const app = getApp();
  4. const arrFontSize = [46, 68, 108];
  5. var innerAudioContext1;
  6. var innerAudioContext2;
  7. var listTaskFinished = []; //完成的任务
  8. var timeStart; //计算时长
  9. var TaskList = [];
  10. Page({
  11. data: {
  12. NumberNew: 10,
  13. NumberReview: 0,
  14. NumberHistory: 30,
  15. IsShowNumberInfo: false,
  16. TaskInfo:{},
  17. Color: {//配色1
  18. Name: "黑白",
  19. BackColor: "#ffffff",
  20. BackColor1: "#D2D2D2",
  21. FrontColor: "#1E1E1E",
  22. FrontColor1: "rgba(0,0,0,0.3)",
  23. BackColor2: "#E3E3E3",
  24. BackColor20: 'rgba(227,227,227,0)',
  25. FrontColor2: "#1E1E1E",
  26. TagColor: "#9B9B9B",
  27. FieldLineColor: "#4B3840",
  28. IconColor: "black",
  29. FrontColorNavigationBar: "#000000",
  30. },
  31. },
  32. onLoad: function () {
  33. wx.hideShareMenu();
  34. var that = this;
  35. that.setData({
  36. Containnerheight: main.getWindowHeight(),
  37. IsShowAnswer: [0, 0],
  38. CanUndo: 1,
  39. });
  40. innerAudioContext1 = wx.createInnerAudioContext();
  41. innerAudioContext2 = wx.createInnerAudioContext();
  42. this.getList();
  43. this.getColor();
  44. },
  45. onShow: function () {
  46. var that = this;
  47. if (that.data.NumberNew == 0 &&
  48. that.data.NumberReview == 0 &&
  49. that.data.NumberHistory == 0) {
  50. listTaskFinished = [];
  51. that.setSoundFile(1);
  52. }
  53. else {
  54. that.setSoundFile(-1);
  55. var list = wx.getStorageSync("CardList");
  56. if (list && list.length > 0) {
  57. for (var i = 0; i < list.length; i++) {
  58. if (TaskList[0].MiaoguoCardID == list[i].MiaoguoCardID) {
  59. var card = {};
  60. TaskList[0].Content = list[i].Content;
  61. TaskList[0].ContentNew = main.changeStringToView(list[i].Content);
  62. that.setData({
  63. TaskInfo: TaskList[0],
  64. });
  65. wx.removeStorageSync("CardList");
  66. break;
  67. }
  68. }
  69. }
  70. }
  71. },
  72. onPullDownRefresh: function () {
  73. },
  74. setSoundFile: function (isFinish) {//isFinish=1 结束 =0正常 =-1开始
  75. var that = this;
  76. var url = "/pages/sounds/";
  77. if (isFinish == 1) {
  78. url += "end.mp3";
  79. if (wx.canIUse('setBackgroundColor')) {
  80. wx.setBackgroundColor({
  81. backgroundColor: "#a5656e",
  82. });
  83. }
  84. that.getTaskTime();
  85. }
  86. else {
  87. url += "short2.mp3";
  88. }
  89. if (isFinish >= 0) {
  90. innerAudioContext1.src = url;
  91. innerAudioContext1.play();
  92. }
  93. wx.pageScrollTo({
  94. scrollTop: 0,
  95. });
  96. },
  97. getColor: function () {
  98. var that = this;
  99. common.getStorageValue(that, "ColorIndex", 0, function () {
  100. var color = main.getDetailColor(that.data.ColorIndex);
  101. that.setData({
  102. Color: color,
  103. });
  104. if (wx.setBackgroundColor) {
  105. wx.setBackgroundColor({
  106. backgroundColor: color.BackColor,
  107. backgroundColorTop: color.BackColor, // 顶部窗口的背景色为白色
  108. backgroundColorBottom: color.BackColor2, // 底部窗口的背景色为白色
  109. })
  110. }
  111. if (wx.setNavigationBarColor) {
  112. wx.setNavigationBarColor({
  113. frontColor: color.FrontColorNavigationBar,
  114. backgroundColor: color.BackColor,
  115. })
  116. }
  117. });
  118. },
  119. getList: function () {
  120. var task = wx.getStorageSync("TaskToday");
  121. var that = this;
  122. var arrNew = task.ListNew;
  123. var arrHistory = task.ListHistory;
  124. var listTaskReview = task.ListReview;
  125. var nMax = [1, 1];
  126. if (arrNew.length == 0 || arrHistory.length == 0) {
  127. if (arrNew.length == 0) {
  128. nMax[0] = 0;
  129. }
  130. if (arrHistory.length == 0) {
  131. nMax[1] = 0;
  132. }
  133. } else if (arrNew.length >= arrHistory.length) {
  134. nMax[0] = Math.floor(arrNew.length / arrHistory.length);
  135. } else if (arrNew.length < arrHistory.length) {
  136. nMax[1] = Math.floor(arrHistory.length / arrNew.length);
  137. }
  138. arrNew = common.randomArray(arrNew);
  139. arrHistory = common.randomArray(arrHistory);
  140. var Len = arrNew.length + arrHistory.length;
  141. TaskList = [];
  142. var indexNew = 0,
  143. indexHistory = 0;
  144. for (var i = 0; i < Len; i++) {
  145. for (var j = 0; j < nMax[0]; j++) {
  146. if (indexNew < arrNew.length) {
  147. arrNew[indexNew].IsNew = true;
  148. TaskList.push(arrNew[indexNew++]);
  149. }
  150. }
  151. for (var j = 0; j < nMax[1]; j++) {
  152. if (indexHistory < arrHistory.length) {
  153. arrHistory[indexHistory].IsHistory = true;
  154. TaskList.push(arrHistory[indexHistory++]);
  155. }
  156. }
  157. }
  158. that.data.NumberReview = listTaskReview.length;
  159. for (var i = 0; i < listTaskReview.length; i++) {
  160. listTaskReview[i].IsReview = true;
  161. TaskList.push(listTaskReview[i]);
  162. }
  163. TaskList = updateNumberStr(TaskList);
  164. //处理列表
  165. TaskList = formatList(TaskList);
  166. that.setData({
  167. NumberNew: arrNew.length,
  168. NumberReview: that.data.NumberReview,
  169. NumberHistory: arrHistory.length,
  170. TaskInfo: TaskList[0],
  171. CanUndo: 0,
  172. });
  173. listTaskFinished = [];
  174. timeStart = new Date(); //起始时间
  175. function formatList(list) {
  176. for (var i = 0; i < list.length; i++) {
  177. list[i].ContentNew = main.changeStringToView(list[i].Content);
  178. }
  179. return list;
  180. }
  181. function replaceStr(data) {
  182. var result = "";
  183. if (data.indexOf("d") > 0) {
  184. var dayNum = Number(data.replace("d", ""));
  185. if (dayNum >= 365) {
  186. var year1 = Math.floor(dayNum / 365);
  187. var year = year1 + Math.round(10 * (dayNum - year1 * 365) / 365) / 10;
  188. result = year + "年";
  189. } else {
  190. if (dayNum > 31) {
  191. var month1 = Math.floor(dayNum / 30);
  192. var month = month1 + Math.round(10 * (dayNum - month1 * 30) / 30) / 10;
  193. result = month + "月";
  194. } else
  195. result = data.replace("d", "天");
  196. }
  197. } else if (data.indexOf("m") > 0)
  198. result = "<" + data.replace("m", "分钟");
  199. return result;
  200. }
  201. function updateNumberStr(list) {
  202. for (var i = 0; i < list.length; i++) {
  203. if (list[i].Number0)
  204. list[i].Number0Str = replaceStr(list[i].Number0);
  205. if (list[i].Number1)
  206. list[i].Number1Str = replaceStr(list[i].Number1);
  207. if (list[i].Number2)
  208. list[i].Number2Str = replaceStr(list[i].Number2);
  209. if (list[i].Number3)
  210. list[i].Number3Str = replaceStr(list[i].Number3);
  211. }
  212. return list;
  213. }
  214. },
  215. onShowAnswer: function (e) {
  216. var start = e.currentTarget.dataset.start;
  217. var that = this;
  218. if (!(that.data.NumberNew == 0 &&
  219. that.data.NumberReview == 0 &&
  220. that.data.NumberHistory == 0)) {
  221. if (start) {
  222. that.data.IsShowAnswer[0] = 0;
  223. that.data.IsShowAnswer[1] = 0;
  224. }
  225. else {
  226. if (!that.data.IsShowAnswer[0] && !that.data.IsShowAnswer[1]) {
  227. that.data.IsShowAnswer[0] = 1;
  228. if (TaskList[0].ContentNew.Field[3].length == 0) {
  229. that.data.IsShowAnswer[1] = 1;
  230. }
  231. }
  232. else if (that.data.IsShowAnswer[0] && !that.data.IsShowAnswer[1]) {
  233. that.data.IsShowAnswer[1] = 1;
  234. }
  235. }
  236. that.setData({
  237. IsShowAnswer: that.data.IsShowAnswer,
  238. });
  239. }
  240. },
  241. onAddQuestion: function () {
  242. wx.navigateTo({
  243. url: './add'
  244. });
  245. },
  246. gotoEdit: function () {
  247. var that = this;
  248. //console.log(res.tapIndex);
  249. var list = [];
  250. TaskList[0].MiaoguoCardID = TaskList[0].ID;
  251. list.push(TaskList[0]);
  252. wx.setStorageSync("CardList", list);
  253. wx.navigateTo({
  254. url: './add?type=edit&id=' + TaskList[0].MiaoguoCardID,
  255. });
  256. },
  257. onFontSize: function () {
  258. for (var i = 0; i < arrFontSize.length; i++) {
  259. if (arrFontSize[i] == TaskList[0].FontSize) {
  260. i++;
  261. if (i == arrFontSize.length)
  262. i = 0;
  263. TaskList[0].FontSize = arrFontSize[i];
  264. break;
  265. }
  266. }
  267. this.setData({
  268. TaskInfo: TaskList[0],
  269. });
  270. },
  271. gotoPrev: function () {
  272. if (listTaskFinished.length > 0) {
  273. var card = listTaskFinished.pop();
  274. //console.log(card);
  275. var that = this;
  276. var url = "UndoMiaoguoCard?";
  277. url += "ID=" + card.Card.ID;
  278. url += "&UserID=" + app.globalData.userInfo.UserID;
  279. url += "&IntervalTime=" + card.IntervalTime;
  280. url += "&IntervalDay=" + card.Card.IntervalDay;
  281. url += "&RepetitionCoefficient=" + card.Card.RepetitionCoefficient;
  282. if (card.Card.FirstTime)
  283. url += "&FirstTime=" + card.Card.FirstTime;
  284. if (card.Card.LastTime)
  285. url += "&LastTime=" + card.Card.LastTime;
  286. main.getData(url, function (data) {
  287. timeStart = new Date();
  288. card.Card.Number0 = card.Number0Old;
  289. card.Card.Number0Str = card.Number0StrOld;
  290. card.Card.Number1 = card.Number1Old;
  291. card.Card.Number1Str = card.Number1StrOld;
  292. card.Card.Number2 = card.Number2Old;
  293. card.Card.Number2Str = card.Number2StrOld;
  294. card.Card.Number3 = card.Number3Old;
  295. card.Card.Number3Str = card.Number3StrOld;
  296. if (card.IsReviewOld)
  297. card.Card.IsReview = card.IsReviewOld;
  298. //去除重复
  299. for (var i = 0; i < TaskList.length; i++) {
  300. if (TaskList[i].ID == card.Card.ID) {
  301. TaskList.splice(i, 1);
  302. }
  303. }
  304. TaskList.unshift(card.Card);
  305. var canUndo = 1;
  306. if (listTaskFinished.length == 0)
  307. canUndo = 0;
  308. that.setData({
  309. IsShowAnswer: [0, 0],
  310. TaskInfo: TaskList[0],
  311. NumberNew: card.NumberNew,
  312. NumberReview: card.NumberReview,
  313. NumberHistory: card.NumberHistory,
  314. CanUndo: canUndo,
  315. });
  316. });
  317. wx.showToast({
  318. title: '已返回',
  319. icon: 'none',
  320. });
  321. }
  322. },
  323. gotoNext: function (e) {
  324. var that = this;
  325. wx.showLoading({
  326. title: '请稍候',
  327. });
  328. var btnnumber = e.currentTarget.dataset.btnnumber;
  329. var time = e.currentTarget.dataset.time;
  330. //处理当前卡片进入历史数组
  331. var finishCard = {};
  332. finishCard.Card = TaskList[0];
  333. finishCard.NumberNew = this.data.NumberNew;
  334. finishCard.NumberReview = this.data.NumberReview;
  335. finishCard.NumberHistory = this.data.NumberHistory;
  336. finishCard.Number0Old = TaskList[0].Number0;
  337. finishCard.Number0StrOld = TaskList[0].Number0Str;
  338. finishCard.Number1Old = TaskList[0].Number1;
  339. finishCard.Number1StrOld = TaskList[0].Number1Str;
  340. finishCard.Number2Old = TaskList[0].Number2;
  341. finishCard.Number2StrOld = TaskList[0].Number2Str;
  342. finishCard.Number3Old = TaskList[0].Number3;
  343. finishCard.Number3StrOld = TaskList[0].Number3Str;
  344. //若不是搁置
  345. if (btnnumber != "1") {
  346. //若是分钟,则进入复习列表
  347. if (time.lastIndexOf("m") == time.length - 1) {
  348. var minute = Number(time.substr(0, time.indexOf("m")));
  349. TaskList[0].LimitTime = common.formatTime(common.addDate("n", minute, new Date()));
  350. //若是新增,则10m 1d 4d
  351. if (TaskList[0].IsNew) {
  352. TaskList[0].Number0 = "10m";
  353. TaskList[0].Number0Str = "<10分钟";
  354. delete TaskList[0].Number1;
  355. delete TaskList[0].Number1Str;
  356. TaskList[0].Number2 = "1d";
  357. TaskList[0].Number2Str = "1天";
  358. TaskList[0].Number3 = "4d";
  359. TaskList[0].Number3Str = "4天";
  360. TaskList[0].FirstTime = null;
  361. TaskList[0].LastTime = null;
  362. }
  363. //若是历史的,则10m 1d
  364. else if (TaskList[0].IsHistory) {
  365. TaskList[0].Number0 = "10m";
  366. TaskList[0].Number0Str = "<10分钟";
  367. delete TaskList[0].Number1;
  368. delete TaskList[0].Number1Str;
  369. TaskList[0].Number2 = "1d";
  370. TaskList[0].Number2Str = "1天";
  371. delete TaskList[0].Number3;
  372. delete TaskList[0].Number3Str;
  373. }
  374. finishCard.IsReviewOld = TaskList[0].IsReview;
  375. TaskList[0].IsReview = true;
  376. TaskList.push(TaskList[0]);
  377. }
  378. //若是天月年
  379. else {
  380. var dayNum = Number(time.substr(0, time.indexOf("d")));
  381. var date = common.addDate("d", dayNum, new Date());
  382. TaskList[0].LimitTime = common.formatTime(date);
  383. }
  384. }
  385. else {
  386. wx.showToast({
  387. title: '已搁置',
  388. icon: 'none',
  389. });
  390. }
  391. //修改学习任务个数
  392. var learningType = 0;
  393. if (TaskList[0].IsReview) {
  394. learningType = 2;
  395. }
  396. if (TaskList[0].IsNew) {
  397. learningType = 0;
  398. }
  399. else if (TaskList[0].IsHistory) {
  400. learningType = 1;
  401. }
  402. if (btnnumber == "1") {
  403. learningType = 3;
  404. }
  405. finishCard.IntervalTime = time;
  406. finishCard.BtnNumber = btnnumber;
  407. finishCard.LearningType = learningType;
  408. //保存上传
  409. var obj = {
  410. ID: TaskList[0].ID,
  411. IntervalTime: time,
  412. BtnNumber: btnnumber,
  413. LearningType: learningType,
  414. IsUndo: 0,
  415. }
  416. this.saveCard(obj, function () {
  417. wx.hideLoading();
  418. //添加完成列表,去掉任务列表数据
  419. listTaskFinished.push(finishCard);
  420. TaskList.shift();
  421. that.data.NumberNew = 0;
  422. that.data.NumberHistory = 0;
  423. that.data.NumberReview = 0;
  424. var arrTemp = [];
  425. for (var i = 0; i < TaskList.length; i++) {
  426. if (TaskList[i].IsReview) {
  427. if (TaskList[i].LimitTime < common.formatTime(new Date())) {
  428. var card = TaskList.splice(i, 1);
  429. TaskList.unshift(card[0]);
  430. }
  431. that.data.NumberReview++;
  432. }
  433. else if (TaskList[i].IsNew) {
  434. that.data.NumberNew++;
  435. }
  436. else if (TaskList[i].IsHistory) {
  437. that.data.NumberHistory++;
  438. }
  439. }
  440. //console.log(JSON.stringify(TaskList[0]));
  441. if (that.data.NumberNew == 0 &&
  442. that.data.NumberReview == 0 &&
  443. that.data.NumberHistory == 0) {
  444. that.setData({
  445. IsShowAnswer: [0, 0],
  446. NumberNew: 0,
  447. NumberReview: 0,
  448. NumberHistory: 0,
  449. CanUndo: 1,
  450. });
  451. that.setSoundFile(1);
  452. } else {
  453. //任务没有完成,下一张卡片
  454. that.setData({
  455. IsShowAnswer: [0, 0],
  456. TaskInfo: TaskList[0],
  457. NumberNew: that.data.NumberNew,
  458. NumberReview: that.data.NumberReview,
  459. NumberHistory: that.data.NumberHistory,
  460. CanUndo: 1,
  461. });
  462. if (btnnumber != "1")
  463. that.setSoundFile(0);
  464. }
  465. });
  466. },
  467. saveCard: function (obj, callback) {
  468. var url = "UpdateMiaoguoCardToday?";
  469. url += "ID=" + obj.ID;
  470. url += "&UserID=" + app.globalData.userInfo.UserID;
  471. url += "&IntervalTime=" + obj.IntervalTime;
  472. url += "&BtnNumber=" + obj.BtnNumber;
  473. url += "&LearningType=" + obj.LearningType;
  474. url += "&FontSize=" + TaskList[0].FontSize;
  475. var duration = common.diffDate("s", timeStart, new Date());
  476. url += "&Duration=" + duration;
  477. url += "&IsUndo=" + obj.IsUndo;
  478. if (obj.LastTime)
  479. url += "&LastTime=" + obj.LastTime;
  480. main.getData(url, function (data) {
  481. timeStart = new Date();
  482. callback();
  483. });
  484. },
  485. playSound: function (e) {
  486. var that = this;
  487. var str = e.currentTarget.dataset.content;
  488. var url = "";
  489. if (str.indexOf("英 [") >= 0 || str.indexOf("美 [") >= 0) {
  490. str = str.replace("英 [", "[");
  491. str = str.replace("美 [", "[");
  492. url = e.currentTarget.dataset.soundmark;
  493. }
  494. else if (e.currentTarget.dataset.soundmark && e.currentTarget.dataset.soundmark != "undefined") {
  495. url = e.currentTarget.dataset.soundmark;
  496. }
  497. else {
  498. url = app.globalData.audioUrlBaidu;
  499. url = url.replace("[token]", app.globalData.BaiduToken);
  500. url = url.replace("[word]", str);
  501. }
  502. innerAudioContext2.src = url;
  503. innerAudioContext2.play();
  504. var fieldid = e.currentTarget.dataset.fieldid;
  505. var content = TaskList[0].ContentNew.Field[fieldid];
  506. var selectIndex = 0;
  507. for (var i = 0; i < content.length; i++) {
  508. if (content[i].Type == 'sound') {
  509. if (content[i].Content == e.currentTarget.dataset.content) {
  510. content[i].SoundImageName = "gif";
  511. selectIndex = i;
  512. break;
  513. }
  514. }
  515. }
  516. that.setData({
  517. TaskInfo: TaskList[0],
  518. });
  519. setTimeout(function () {
  520. content[selectIndex].SoundImageName = "png";
  521. TaskList[0].ContentNew.Field[fieldid] = content;
  522. that.setData({
  523. TaskInfo: TaskList[0],
  524. });
  525. }, 2000);
  526. },
  527. getTaskTime: function () {
  528. var that = this;
  529. var url = "GetMiaoguoTaskTime?";
  530. url += "UserID=" + app.globalData.userInfo.UserID;
  531. main.getData(url, function (data) {
  532. if (data) {
  533. var duration = common.getMinuteSecond(data.Duration, true);
  534. var speed1 = Math.round(100 * data.Count / (data.Duration / 60)) / 100;
  535. var speed2 = common.getMinuteSecond(Math.round(data.Duration / data.Count), true);
  536. that.setData({
  537. TodayTime: duration,
  538. Speed1: speed1 + "张题卡",
  539. Speed2: speed2,
  540. });
  541. }
  542. });
  543. },
  544. showNumberContainner: function () {
  545. this.setData({
  546. IsShowNumberInfo: true,
  547. });
  548. },
  549. closeNumberContainner: function () {
  550. this.setData({
  551. IsShowNumberInfo: false,
  552. });
  553. },
  554. onShareAppMessage: function () {
  555. return {
  556. title: app.globalData.ShareTitle,
  557. path: app.globalData.SharePath + '?UserID=' + app.globalData.userInfo.UserID,
  558. imageUrl: app.globalData.ShareImage,
  559. }
  560. },
  561. });