detail.js 17 KB

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