add.js 18 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674
  1. import common from '../../utils/util';
  2. import main from '../../utils/main';
  3. const app = getApp();
  4. var field = [[], [], [], []];
  5. var arrTag = [];
  6. var tempCursor = 0,
  7. btnName = "";
  8. var arrSoundMark = [];
  9. var isUnload = true;
  10. var isEdit = true;
  11. Page({
  12. data: {
  13. PracticeTimeStr:"智能安排",
  14. HiddenFieldEdit:true,
  15. FieldContent: "",
  16. SoundSign: "[读]",
  17. LineSign: "[线]",
  18. BtnArray: ["+", "-", "×", "÷", "=", "<", ">"],
  19. },
  20. onLoad: function (options) {
  21. wx.hideShareMenu();
  22. var that = this;
  23. var type2=0;
  24. if (options.type2)
  25. type2=options.type2;
  26. that.setData({
  27. Containnerheight: main.getWindowHeight(),
  28. UpdateType: options.type,
  29. ShowType:type2,
  30. MiaoguoCardID: options.id,
  31. });
  32. var list = app.globalData.CardList;
  33. for (var i = 0; i < list.length; i++) {
  34. if (that.data.MiaoguoCardID == list[i].MiaoguoCardID) {
  35. wx.setStorageSync("TempCardInfo", list[i]);
  36. break;
  37. }
  38. }
  39. app.globalData.TempFieldNumber=0;
  40. app.globalData.TempMiaoguoCardID=that.data.MiaoguoCardID;
  41. },
  42. onShow: function () {
  43. var that = this;
  44. if (that.data.UpdateType == "add") {
  45. that.initAddCard();
  46. }
  47. else {
  48. var card = {},content="";
  49. var list = app.globalData.CardList;
  50. for (var i = 0; i < list.length; i++) {
  51. if (that.data.MiaoguoCardID == list[i].MiaoguoCardID) {
  52. card = main.changeStringToView(list[i].Content);
  53. card.MiaoguoCardID = list[i].MiaoguoCardID;
  54. card.LimitTime = list[i].LimitTime;
  55. if (that.data.FieldNumber && that.data.FieldNumber>0)
  56. content = main.encryptUrl(list[i].Content[that.data.FieldNumber].Content);
  57. break;
  58. }
  59. }
  60. that.setData({
  61. MiaoguoCardID: card.MiaoguoCardID,
  62. Field: card.Field,
  63. Tags: card.Tags,
  64. FieldContent:content,
  65. });
  66. if (that.data.UpdateType != "add2") {
  67. wx.setNavigationBarTitle({
  68. title: '编辑题卡'
  69. });
  70. }
  71. }
  72. },
  73. onUnload: function () {
  74. field = [[], [], [], []];
  75. var card = wx.getStorageSync("TempCardInfo");
  76. if (card) {
  77. var list = app.globalData.CardList;
  78. for (var i = 0; i < list.length; i++) {
  79. if (this.data.MiaoguoCardID == list[i].MiaoguoCardID) {
  80. list[i] = card;
  81. break;
  82. }
  83. }
  84. app.globalData.CardList=list;
  85. wx.removeStorageSync("TempCardInfo");
  86. }
  87. },
  88. onClose: function () {
  89. wx.navigateBack({
  90. delta: 1,
  91. });
  92. },
  93. gotoAddItem: function (e) {
  94. var that=this;
  95. var fieldid = e.currentTarget.dataset.fieldid;
  96. var content;
  97. var list = app.globalData.CardList;
  98. for (var i = 0; i < list.length; i++) {
  99. if (that.data.MiaoguoCardID == list[i].MiaoguoCardID) {
  100. content = main.encryptUrl(list[i].Content[fieldid].Content);
  101. break;
  102. }
  103. }
  104. that.setData({
  105. HiddenFieldEdit: false,
  106. Focus: true,
  107. FieldNumber: fieldid,
  108. FieldContent:content,
  109. });
  110. wx.setNavigationBarTitle({
  111. title: '编辑 段落' + fieldid,
  112. });
  113. },
  114. onSearch: function (e) {
  115. app.globalData.TempFieldNumber = 0;
  116. wx.navigateTo({
  117. url: './searchWeb',
  118. })
  119. },
  120. onPreview: function (e) {
  121. var that = this;
  122. if (that.data.Field[1] == "") {
  123. wx.showToast({
  124. title: '第一段必填',
  125. image: "../images/universalpic_wrong_white_120x120.png",
  126. });
  127. }
  128. else {
  129. wx.navigateTo({
  130. url: './preview?type=preview&id=' + this.data.MiaoguoCardID,
  131. });
  132. }
  133. },
  134. switch1Change(e) {
  135. var str="智能安排";
  136. if (e.detail.value){
  137. str="今日必练";
  138. }
  139. this.setData({
  140. IsTodayStudy: e.detail.value,
  141. });
  142. },
  143. saveCard: function () {
  144. var that = this;
  145. if (that.data.Field[1] == "") {
  146. wx.showToast({
  147. title: '第一段必填',
  148. image: "../images/universalpic_wrong_white_120x120.png",
  149. });
  150. }
  151. else {
  152. that.uploadImageAll(that.data.Field, function (field) {
  153. that.data.Field=field;
  154. var userid = app.globalData.userInfo.UserID;
  155. var isTodayStudy = 0;
  156. if (that.data.IsTodayStudy && that.data.UpdateType == "add2")
  157. isTodayStudy = 1;
  158. var tags = [];
  159. for (var i = 0; i < that.data.Tags.length; i++) {
  160. if (that.data.Tags[i])
  161. tags.push(that.data.Tags[i]);
  162. }
  163. var param1 = {
  164. Tags: tags,
  165. Field1: "",
  166. Field2: "",
  167. Field3: "",
  168. IsTodayStudy: isTodayStudy,
  169. ID: that.data.MiaoguoCardID,
  170. };
  171. for (var i = 1; i <= 3; i++) {
  172. for (var key in that.data.Field[i]) {
  173. var item = that.data.Field[i][key];
  174. var str = "";
  175. if (item.Type == "image") {
  176. str = "[图]" + item.Content + "[/图]";
  177. }
  178. else if (item.Type == "line") {
  179. for (var j = 0; j < item.Content.length; j++) {
  180. if (item.Content[j].key == "normal")
  181. str += item.Content[j].value;
  182. if (item.Content[j].key == "line") {
  183. str += "[线]" + item.Content[j].value + "[/线]";
  184. }
  185. }
  186. }
  187. else if (item.Type == "sound") {
  188. if (item.SoundMark)
  189. str = "[读 src='" + item.SoundMark + "']" + item.Content + "[/读]";
  190. else
  191. str = "[读]" + item.Content + "[/读]";
  192. }
  193. else if (item.Type == "normal") {
  194. str = item.Content;
  195. }
  196. else if (item.Type == "return") {
  197. str = "\n";
  198. }
  199. param1["Field" + i] += str;
  200. }
  201. param1["Field" + i] = main.changeViewToString(param1["Field" + i]);
  202. }
  203. that.saveLocalCardList(param1);
  204. // var param2 = {
  205. // param: common.Encrypt(JSON.stringify(param1))
  206. // }
  207. main.postData('AddMiaoguoCard?Type=' + that.data.UpdateType + '&UserID=' + userid, param1, function (data) {
  208. if (that.data.UpdateType == "edit" || that.data.UpdateType == "edit2") {
  209. that.onClose();
  210. }
  211. else {
  212. wx.showToast({
  213. title: '已保存!',
  214. image: "../images/universalpic_saved_white_120x120.png",
  215. });
  216. if (that.data.UpdateType == "add2") {
  217. that.initAddCard();
  218. }
  219. var taskToday = app.globalData.TaskToday;
  220. taskToday.CardNumber++;
  221. app.globalData.TaskToday=taskToday;
  222. that.setData({
  223. IsTodayStudy:false,
  224. })
  225. }
  226. wx.removeStorageSync("TempCardInfo");
  227. });
  228. });
  229. }
  230. },
  231. uploadImageAll: function (arr, callback) {
  232. var that=this;
  233. var arrSource=[], arrResult=[];
  234. for(var i=0;i<arr.length;i++){
  235. for(var j=0;j<arr[i].length;j++){
  236. if (arr[i][j].Type == "image" && arr[i][j].Content){
  237. arrSource.push(arr[i][j].Content);
  238. if (arr[i][j].ContentServer.indexOf(app.globalData.uploadImageUrl)>=0
  239. || arr[i][j].ContentServer.indexOf("baidu.com")>=0 ){
  240. arrResult.push(arr[i][j].ContentServer);
  241. }
  242. else{
  243. that.uploadImage(arr[i][j].Content, function (data) {
  244. //console.log("Target:"+data);
  245. data = app.globalData.uploadImageUrl + data;
  246. arrResult.push(data);
  247. });
  248. }
  249. }
  250. }
  251. }
  252. var interval=setInterval(function(){
  253. //console.log(arrResult.length);
  254. if (arrResult.length >= arrSource.length){
  255. clearInterval(interval);
  256. var ari=0;
  257. for (var i = 0; i < arr.length; i++) {
  258. for (var j = 0; j < arr[i].length; j++) {
  259. if (arr[i][j].Type == "image" && arr[i][j].Content) {
  260. var tempUrl = arr[i][j].Content;
  261. var serverUrl = arrResult[ari++];
  262. main.saveTempImage(serverUrl, tempUrl);
  263. arr[i][j].Content = serverUrl;
  264. arr[i][j].ContentServer = serverUrl;
  265. }
  266. }
  267. }
  268. //console.log(JSON.stringify(arr));
  269. callback(arr);
  270. }
  271. },500);
  272. },
  273. uploadImage:function(file,callback){
  274. var url = common.Encrypt("MiaoguoUploadFile");
  275. wx.uploadFile({
  276. url: app.globalData.serverUrl + url,
  277. filePath: file,
  278. name: 'file',
  279. success(res) {
  280. wx.hideLoading();
  281. callback(res.data);
  282. },
  283. fail: function (err) {
  284. wx.hideLoading();
  285. wx.showModal({
  286. title: '上传图片失败',
  287. showCancel: false,
  288. content: JSON.stringify(err),
  289. });
  290. }
  291. });
  292. },
  293. saveLocalCardList:function(param1){
  294. var that=this;
  295. var list = app.globalData.CardList;
  296. for (var i = 0; i < list.length; i++) {
  297. if (that.data.MiaoguoCardID == list[i].MiaoguoCardID) {
  298. for (var j = 0; j < 4; j++) {
  299. if (j == 0){
  300. if (param1.tags && param1.tags.length > 0)
  301. list[i].Content[j].Content = param1.tags.join(",");
  302. }
  303. else
  304. list[i].Content[j].Content = param1["Field" + j];
  305. }
  306. app.globalData.CardList=list;
  307. break;
  308. }
  309. }
  310. },
  311. initAddCard: function () {
  312. var card = {};
  313. card.MiaoguoCardID = 0;
  314. card.Content = [];
  315. for (var i = 0; i < 4; i++) {
  316. var obj = {};
  317. obj.ContentType = i;
  318. obj.Content = [];
  319. card.Content.push(obj);
  320. }
  321. app.globalData.CardList=[card];
  322. this.setData({
  323. MiaoguoCardID: 0,
  324. Field: [[], [], [], []],
  325. Tags: [],
  326. UpdateType: "add2",
  327. });
  328. },
  329. onBindError: function (e) {
  330. for (var i = 1; i < this.data.Field.length; i++) {
  331. for (var j = 0; j < this.data.Field[i].length; j++) {
  332. if (this.data.Field[i][j].Type == "image") {
  333. this.data.Field[i][j].Url = this.data.Field[i][j].Content;
  334. }
  335. }
  336. }
  337. this.setData({
  338. Field: this.data.Field,
  339. });
  340. },
  341. deleteItem: function (e) {
  342. var that = this;
  343. var index = e.currentTarget.dataset.id;
  344. wx.showModal({
  345. title: '提醒',
  346. content: '记号“'+that.data.Tags[index]+'”要删除吗?',
  347. success(res) {
  348. if (res.confirm) {
  349. that.data.Tags.splice(index, 1);
  350. that.setData({
  351. Tags: that.data.Tags,
  352. });
  353. var list = app.globalData.CardList;
  354. for (var i = 0; i < list.length; i++) {
  355. if (that.data.MiaoguoCardID == list[i].MiaoguoCardID) {
  356. list[i].Content[0].Content = that.data.Tags;
  357. break;
  358. }
  359. }
  360. app.globalData.CardList = list;
  361. }
  362. }
  363. });
  364. },
  365. onGotoList:function(){
  366. var that = this;
  367. if (that.data.Field[1] != "" && that.data.Field[2] != "" && that.data.Field[2] != "") {
  368. wx.showModal({
  369. title: '尚未保存',
  370. content: '即将前往“全部题卡”,但当前题卡尚未保存,按继续将放弃保存。',
  371. confirmText:'继续',
  372. success(res) {
  373. if (res.confirm) {
  374. goto();
  375. }
  376. }
  377. });
  378. }
  379. else{
  380. goto();
  381. }
  382. function goto(){
  383. wx.showLoading({
  384. title: '请稍候',
  385. });
  386. var url = 'GetMiaoguoCardList?UserID=' + app.globalData.userInfo.UserID;
  387. main.getData(url, function (data) {
  388. wx.hideLoading();
  389. if (data) {
  390. app.globalData.CardList = data.List;
  391. wx.redirectTo({
  392. url: './searchCardList?type=0&Count=' + data.Count,
  393. })
  394. }
  395. });
  396. }
  397. },
  398. //段落编辑**************************
  399. //字段输入
  400. bindinputField: function (e) {
  401. //console.log("bindinputField:" + e.detail.value + " isEdit:" + isEdit);
  402. var that = this;
  403. if (app.globalData.IsAndroid && !isEdit) {
  404. return;
  405. }
  406. this.setData({
  407. FieldContent: e.detail.value,
  408. });
  409. //this.updateField();
  410. },
  411. //加符号
  412. addSymbol: function (e) {
  413. //console.log("addSymbol");
  414. isEdit = true;
  415. var that = this;
  416. btnName = e.currentTarget.dataset.id;
  417. if (btnName == "[读]") {
  418. this.setData({
  419. SoundSign: "[/读]",
  420. });
  421. } else if (btnName == "[/读]") {
  422. this.setData({
  423. SoundSign: "[读]",
  424. });
  425. } else if (btnName == "[线]") {
  426. this.setData({
  427. LineSign: "[/线]",
  428. });
  429. } else if (btnName == "[/线]") {
  430. this.setData({
  431. LineSign: "[线]",
  432. });
  433. }
  434. if (!this.data.Focus) {
  435. this.data.FieldContent = this.data.FieldContent + btnName;
  436. this.setData({
  437. FieldContent: this.data.FieldContent,
  438. });
  439. }
  440. //console.log("addSymbol:" + this.data.FieldContent);
  441. setTimeout(function () {
  442. that.setData({
  443. Focus: true,
  444. });
  445. }, 300);
  446. },
  447. //焦点聚焦
  448. onBindFocus: function () {
  449. this.setData({
  450. Focus: true,
  451. });
  452. },
  453. //失焦
  454. onBindblur: function (e) {
  455. var that = this;
  456. //console.log("onBindblur:" + isEdit + " Filed:" + this.data.FieldContent);
  457. if (app.globalData.IsAndroid && !isEdit) {
  458. setTimeout(function () {
  459. isEdit = true;
  460. console.log("onBindblur2:" + isEdit);
  461. }, 500);
  462. return;
  463. }
  464. isEdit = false;
  465. if (app.globalData.IsAndroid && !isEdit) {
  466. setTimeout(function () {
  467. isEdit = true;
  468. console.log("onBindblur2:" + isEdit);
  469. }, 500);
  470. }
  471. //console.log("onBindblur:"+isEdit);
  472. this.updateField();
  473. tempCursor = e.detail.cursor;
  474. //console.log("tempCursor:" + tempCursor);
  475. if (tempCursor == undefined)
  476. tempCursor = this.data["FieldContent"].length;
  477. var str1 = "",
  478. str2 = "";
  479. if (this.data.FieldContent.length > 0) {
  480. str1 = this.data.FieldContent.substr(0, tempCursor);
  481. str2 = this.data.FieldContent.substring(tempCursor, this.data.FieldContent.length);
  482. }
  483. //console.log("str1:" + str1);
  484. //console.log("str2:" + str2);
  485. var cur = 1;
  486. if (btnName == "[读]" || btnName == "[线]") {
  487. cur = 3;
  488. } else if (btnName == "[/读]" || btnName == "[/线]") {
  489. cur = 4;
  490. } else if (btnName == "(   )") {
  491. cur = 5;
  492. } else if (btnName == "_____") {
  493. cur = 5;
  494. }
  495. this.data.FieldContent = str1 + btnName + str2;
  496. this.setData({
  497. FieldContent: this.data.FieldContent,
  498. Focus: false,
  499. Cursor: tempCursor + cur,
  500. });
  501. btnName = "";
  502. },
  503. onSearchField: function (e) {
  504. app.globalData.TempFieldNumber = this.data.FieldNumber;
  505. wx.navigateTo({
  506. url: './searchWeb',
  507. });
  508. this.updateField();
  509. setTimeout(function () {
  510. isEdit = true;
  511. //console.log("onSearchEnd");
  512. }, 1000);
  513. },
  514. clear: function () {
  515. var that = this;
  516. //console.log("clear");
  517. this.setData({
  518. FieldContent: "",
  519. Focus: true,
  520. Cursor: 0,
  521. });
  522. btnName = "";
  523. isEdit = false;
  524. this.updateField();
  525. },
  526. closeAddItem: function (e) {
  527. var that=this;
  528. var isSave = e.currentTarget.dataset.idsave;
  529. if (isSave == "true") {
  530. isUnload = false;
  531. wx.removeStorageSync("TempCardInfoAddItem");
  532. this.updateField();
  533. }
  534. this.setData({
  535. HiddenFieldEdit:true,
  536. });
  537. var title = "编辑题卡";
  538. if (that.data.UpdateType == "add2") {
  539. title = "添加题卡";
  540. }
  541. wx.setNavigationBarTitle({
  542. title: title,
  543. });
  544. },
  545. updateField: function (history) {
  546. var str = this.data.FieldContent;
  547. // str = main.decryptUrl(str);
  548. // str = str.replace(/\[读\]/g, "\n[读]");
  549. // str = str.replace(/\[图\]/g, "\n[图]");
  550. // str = str.replace(/\[\/读\]/g, "[\/读]\n");
  551. // str = str.replace(/\[\/图\]/g, "[\/图]\n");
  552. // str = str.replace(/\n\n\n/g, "\n\n");
  553. var list = app.globalData.CardList;
  554. var card={};
  555. for (var i = 0; i < list.length; i++) {
  556. if (this.data.MiaoguoCardID == list[i].MiaoguoCardID) {
  557. if (history != undefined)
  558. list[i].Content[this.data.FieldNumber].Content = history;
  559. else
  560. list[i].Content[this.data.FieldNumber].Content = str;
  561. card = main.changeStringToView(list[i].Content);
  562. break;
  563. }
  564. }
  565. app.globalData.CardList = list;
  566. this.setData({
  567. Field: card.Field,
  568. Tags: card.Tags,
  569. });
  570. },
  571. uploadImageField: function () {
  572. //console.log("uploadImageStart");
  573. var that = this;
  574. wx.chooseImage({
  575. count: 1,
  576. sizeType: ['compressed'],
  577. sourceType: ['album', 'camera'],
  578. success(res) {
  579. // tempFilePath可以作为img标签的src属性显示图片
  580. const tempFilePaths = res.tempFilePaths;
  581. //console.log(tempFilePaths[0]);
  582. //that.data.FieldContent = that.data.FieldContent + "[图 url='" + tempFilePaths[0] + "']" + tempFilePaths[0] + "[/图]";
  583. if (tempCursor == undefined)
  584. tempCursor = that.data.FieldContent.length;
  585. var str1 = "",
  586. str2 = "";
  587. if (that.data.FieldContent.length > 0) {
  588. str1 = that.data.FieldContent.substr(0, tempCursor);
  589. str2 = that.data.FieldContent.substring(tempCursor, that.data.FieldContent.length);
  590. }
  591. var str0 = "[图]" + tempFilePaths[0] + "[/图]";
  592. that.data.FieldContent = str1 + str0 + str2;
  593. //console.log("uploadImageEnd:" + that.data.FieldContent);
  594. that.setData({
  595. FieldContent: that.data.FieldContent,
  596. Focus: false,
  597. });
  598. that.updateField();
  599. },
  600. fail: function () {
  601. }
  602. });
  603. },
  604. onShareAppMessage: function () {
  605. return {
  606. title: app.globalData.ShareTitle,
  607. path: app.globalData.SharePath + '?UserID=' + app.globalData.userInfo.UserID,
  608. imageUrl: app.globalData.ShareImage,
  609. }
  610. },
  611. })