detail.js 18 KB

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