detail.js 19 KB

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