util.js 55 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532153315341535153615371538153915401541154215431544154515461547154815491550155115521553155415551556155715581559156015611562156315641565156615671568156915701571157215731574157515761577157815791580158115821583158415851586158715881589159015911592159315941595
  1. // -------------------------------------------------------------页面初始化操作
  2. let myTaskListStateFalse = {}; // 我的任务暂存未读数据列表<id,T>
  3. let plusStatus = false;
  4. mui.plusReady(function() {
  5. if (plus) {
  6. plusStatus = true;
  7. console.log("plus初始化成功!")
  8. // 获取当前定位
  9. getLocalAddr();
  10. // plus start真机调试或打包需要注释
  11. // }
  12. // }, true);
  13. // plus end
  14. var mask = mui.createMask(function() {
  15. console.log("图片过大,压缩中!!!")
  16. });
  17. // 系统运行环境
  18. let SYSTEM_ENVIRONMENT = "Beta";
  19. let ENVIRONMENT = {
  20. // 本地测试环境(公司服务器DMS服务)
  21. DEV: {
  22. DMS_BASE_RUL: "http://121.43.55.7:2101",
  23. myTaskColumnId: 48, // 我的任务
  24. myTaskInfoColumnId: 1161, // 我的任务详情
  25. knowledgeRetrievalColumnId: 23, // 知识检索
  26. myMarksColumnId: 1218, // 我的标记栏目id
  27. myMarksModelId: 600 // 我的标记模型id
  28. },
  29. // 本地测试环境(政务内网DMS服务)
  30. Beta: {
  31. DMS_BASE_RUL: "https://117.131.26.69:10081",
  32. myTaskColumnId: 1794, // 我的任务
  33. myTaskInfoColumnId: 1537, // 我的任务详情
  34. knowledgeRetrievalColumnId: 1396, // 知识检索
  35. myMarksColumnId: 1538, // 我的标记栏目id
  36. myMarksModelId: 910 // 我的标记模型id
  37. }
  38. }
  39. let allCount = 0; // 数据总条数
  40. let pageSize = 10; // 每页显示数据条数
  41. let page = 0; // 初始页
  42. let searchStateValue = 0;
  43. let fileList = {};
  44. // 每页配置信息(注意每一个key指的是主页的每个按钮的class)
  45. const pageParam = {
  46. // 我的任务
  47. "myTask": {
  48. columnId: ENVIRONMENT[SYSTEM_ENVIRONMENT].myTaskColumnId,
  49. states: "0,1",
  50. userIdColumnName: "c_user_id",
  51. searchColumnName: "title",
  52. orderColumnName: "create_time",
  53. orderByType: 2,
  54. taskStatusTag: {
  55. 0: {
  56. class: "WarningTag",
  57. title: "未读"
  58. },
  59. 1: {
  60. class: "SuccessTag",
  61. title: "已读"
  62. }
  63. }
  64. },
  65. // 任务详情(任务和疑点关联表)
  66. "myTaskInfo": {
  67. columnId: ENVIRONMENT[SYSTEM_ENVIRONMENT].myTaskInfoColumnId,
  68. states: "0,1,2,3",
  69. userIdColumnName: "c_user_id",
  70. searchColumnName: "c_doubtful_points",
  71. orderColumnName: "c_create_time",
  72. orderByType: 2,
  73. params: {
  74. searchColumnName: "c_task_id",
  75. value: localStorage.getItem('taskId')
  76. },
  77. taskStatusTag: {
  78. 0: {
  79. class: "WarningTag",
  80. title: "未核查"
  81. },
  82. 1: {
  83. class: "SuccessTag",
  84. title: "已核查"
  85. }
  86. }
  87. },
  88. // 知识检索
  89. "knowledgeRetrieval": {
  90. columnId: ENVIRONMENT[SYSTEM_ENVIRONMENT].knowledgeRetrievalColumnId,
  91. states: "0,2,3",
  92. searchColumnName: "title",
  93. orderColumnName: "create_time",
  94. orderByType: 2,
  95. taskStatusTag: {
  96. 1: {
  97. class: "WarningTag",
  98. title: "待审核"
  99. },
  100. 2: {
  101. class: "BrandTag",
  102. title: "已审核"
  103. },
  104. 3: {
  105. class: "SuccessTag",
  106. title: "已发布"
  107. },
  108. 4: {
  109. class: "InfoTag",
  110. title: "已回退"
  111. },
  112. 5: {
  113. class: "DangerTag",
  114. title: "已撤回"
  115. }
  116. }
  117. },
  118. // 我的标记
  119. "myMarks": {
  120. columnId: ENVIRONMENT[SYSTEM_ENVIRONMENT].myMarksColumnId,
  121. states: "0,1",
  122. searchColumnName: "title",
  123. userIdColumnName: "c_editorid",
  124. orderColumnName: "create_time",
  125. orderByType: 2,
  126. taskStatusTag: {
  127. 0: {
  128. class: "InfoTag",
  129. title: "未上传"
  130. },
  131. 1: {
  132. class: "SuccessTag",
  133. title: "已上传"
  134. },
  135. }
  136. }
  137. }
  138. let page_e; // mui-pullRefresh
  139. // 后台服务地址
  140. const DMS_BASE_RUL = ENVIRONMENT[SYSTEM_ENVIRONMENT].DMS_BASE_RUL;
  141. // 接口URL
  142. const loginUrl = "/proxy_oauth/user/login";
  143. // token验证
  144. const getUserInfoUrl = "/proxy_oauth/api/user/getUserInfo";
  145. // 分页获取dms数据
  146. const getDataListUrl = "/proxy_dms/content/selectContentList";
  147. // 上传文件接口(提示跨域???)
  148. const proxyDmsFileUploadFile = "/proxy_dms/file/uploadFile";
  149. // 更新dms数据
  150. const updateContent = "/proxy_dms/content/updateContent";
  151. // 更新dms状态
  152. const updateAudit = "/proxy_dms/content/updateAudit";
  153. // 添加dms数据
  154. const addContent = "/proxy_dms/content/addContent";
  155. // ajax配置
  156. let requestSettins = {
  157. type: "POST",
  158. async: true,
  159. crossDomain: true,
  160. processData: false,
  161. contentType: false,
  162. timeout: 10000,
  163. headers: {
  164. "token": localStorage.getItem("token")
  165. }
  166. };
  167. // 记住密码变量
  168. let isActive = localStorage.key('isActive') ? localStorage.getItem('isActive') : false;
  169. // 标题自动填充
  170. if (document.getElementById('data-list-title') && localStorage.getItem('taskName')) {
  171. document.getElementById('data-list-title').innerHTML = localStorage.getItem('taskName');
  172. }
  173. if (document.getElementById('taskName')) {
  174. if (localStorage.getItem('taskName')) {
  175. document.getElementById('taskName').style.display = "blck";
  176. document.getElementById('taskName').innerHTML = localStorage.getItem('taskName');
  177. } else {
  178. document.getElementById('taskName').style.display = "none";
  179. }
  180. }
  181. // 地图页面标题记忆
  182. if (document.getElementById("mapTitle") && localStorage.getItem("mapTitle")) {
  183. document.getElementById('mapTitle').innerHTML = localStorage.getItem('mapTitle');
  184. }
  185. // 搜索框判断并初始化
  186. if (document.getElementById('searchInput')) {
  187. mui.init({
  188. swipeBack: true, //启用右滑关闭功能
  189. pullRefresh: {
  190. container: "#listMoveDom", //待刷新区域标识,querySelector能定位的css选择器均可,比如:id、.class等
  191. up: {
  192. height: 50, //可选.默认50.触发上拉加载拖动距离
  193. auto: true, //可选,默认false.自动上拉加载一次
  194. contentrefresh: "正在加载...", //可选,正在加载状态时,上拉加载控件上显示的标题内容
  195. contentnomore: '没有更多数据了', //可选,请求完毕若没有更多数据时显示的提醒内容;
  196. callback: getMoveMyTaskList //必选,刷新函数,根据具体业务来编写,比如通过ajax从服务器获取新数据;
  197. },
  198. // container: ".mui-content", //待刷新区域标识,querySelector能定位的css选择器均可,比如:id、.class等
  199. // down: {
  200. // style: 'circle', //必选,下拉刷新样式,目前支持原生5+ ‘circle’ 样式
  201. // color: '#2BD009', //可选,默认“#2BD009” 下拉刷新控件颜色
  202. // height: '50px', //可选,默认50px.下拉刷新控件的高度,
  203. // range: '100px', //可选 默认100px,控件可下拉拖拽的范围
  204. // offset: '0px', //可选 默认0px,下拉刷新控件的起始位置
  205. // // auto: true, //可选,默认false.首次加载自动上拉刷新一次
  206. // callback: getMoveMyTaskList //必选,刷新函数,根据具体业务来编写,比如通过ajax从服务器获取新数据;
  207. // }
  208. }
  209. });
  210. muiInit();
  211. // 存在搜索框的话开始监听
  212. document.getElementById('searchInput').addEventListener('keypress', function(event) {
  213. if (event.keyCode == 13) {
  214. document.activeElement.blur(); // 收起模拟键盘
  215. resetPageInfo();
  216. event.preventDefault(); // 阻止页面刷新
  217. }
  218. })
  219. } else {
  220. mui.init();
  221. muiInit();
  222. }
  223. // -------------------------------------------------------------自定义的mui事件监听事件
  224. function muiInit() {
  225. // 获取设备类型,后续很有可能会用到
  226. if (mui.os.ios) {
  227. console.log('苹果设备')
  228. console.log('version:' + mui.os.version)
  229. } else if (mui.os.android) {
  230. console.log('安卓设备')
  231. console.log('version:' + mui.os.version)
  232. }
  233. // 如果在首页存在autoLogin元素,自动登录判断
  234. if (document.getElementById('autoLogin')) {
  235. if (isActive) {
  236. document.getElementById('userName').value = localStorage.key('userName') ? localStorage
  237. .getItem(
  238. 'userName') : '';
  239. document.getElementById('passWord').value = localStorage.key('passWord') ? localStorage
  240. .getItem(
  241. 'passWord') : '';
  242. }
  243. document.getElementById('autoLogin').checked = isActive;
  244. if (localStorage.getItem('token') != null) {
  245. getUserInfo({
  246. dataType: "json"
  247. }, function success(res, textStatus, xhr) {
  248. if (res.code == 200) {
  249. mui.alert('欢迎回来!', '系统提示', function() {
  250. // 跳转到主页
  251. mui.openWindow({
  252. url: "pages/home.html",
  253. id: "home",
  254. createNew: true
  255. });
  256. });
  257. } else {
  258. mui.alert('token过期请重新登录!', '系统提示', function() {
  259. localStorage.removeItem("token");
  260. });
  261. }
  262. }, function error(xhr, type, errorThrown) {
  263. mui.alert('token过期请重新登录!', '系统提示', function() {
  264. localStorage.removeItem("token");
  265. });
  266. });
  267. }
  268. }
  269. // 监听用户点击状态触发事件
  270. mui('body').on('tap', '#loginButton', function() {
  271. login();
  272. }).on('tap', '.loginOut', function() {
  273. clearSearchValue();
  274. mui.toast('退出成功', '系统提示');
  275. localStorage.removeItem("token");
  276. mui.openWindow("../index.html", "login");
  277. }).on('tap', '#autoLoginText2', function() {
  278. mui.alert('忘记密码请联系系统管理员在oauth系统中重置密码!', '系统提示', null, 'div');
  279. }).on('tap', '.myTasks', function() {
  280. // 我的任务页面跳转
  281. clearSearchValue();
  282. mui.openWindow("myTask.html", "myTask")
  283. }).on('tap', '.customMarking', function() {
  284. // 自定义标记页面跳转
  285. clearSearchValue();
  286. if (localStorage.getItem("taskName")) {
  287. localStorage.removeItem('taskName');
  288. }
  289. localStorage.setItem("mapTitle", "自定义标记");
  290. mui.openWindow("map.html", "customMarking")
  291. }).on('tap', '.toMapPage', function() {
  292. console.log("tap > toMapPage")
  293. // 自定义标记页面跳转
  294. clearSearchValue();
  295. localStorage.setItem("markerId", this.dataset.markerId);
  296. let pageName = document.getElementById('pageName') ? document.getElementById('pageName')
  297. .value :
  298. 'myTask';
  299. if (pageName === "myTaskInfo") {
  300. localStorage.setItem("mapTitle", "我的任务");
  301. } else if (pageName === "myMarks") {
  302. localStorage.setItem("mapTitle", "我的标记");
  303. }
  304. mui.openWindow("map.html", "toMapPage")
  305. }).on('tap', '.toMyTask', function() {
  306. // 我的任务页面跳转
  307. clearSearchValue();
  308. mui.openWindow("myTask.html", "myTask")
  309. }).on('tap', '.knowledgeRetrieval', function() {
  310. // 知识检索页面跳转
  311. clearSearchValue();
  312. // 关键字过滤
  313. // if (this.dataset.searchStr.indexOf('土') != -1) {
  314. // localStorage.setItem('searchInput', '土地资源');
  315. // } else if (this.dataset.searchStr.indexOf('水') != -1) {
  316. // localStorage.setItem('searchInput', '水资源');
  317. // } else if (this.dataset.searchStr.indexOf('林') != -1) {
  318. // localStorage.setItem('searchInput', '林地资源');
  319. // } else if (this.dataset.searchStr.indexOf('生态') != -1) {
  320. // localStorage.setItem('searchInput', '生态资源');
  321. // } else {
  322. // localStorage.setItem('searchInput', this.dataset.searchStr.substring(0,2));
  323. // }
  324. localStorage.setItem('searchInput', '土');
  325. mui.openWindow("lawsAndRegulations.html", "lawsAndRegulations")
  326. }).on('tap', '.myMarks', function() {
  327. // 我的标记页面跳转
  328. clearSearchValue();
  329. mui.openWindow("myMark.html", "myMarks")
  330. }).on('tap', '#addMyMarker', function() {
  331. // console.log(document.getElementById('taskName'));
  332. if (localStorage.getItem("latlngLat")) {
  333. localStorage.setItem('showMyMarkerBottomBox', 'true');
  334. let mapBottomBoxInnerHtml = `<div class="mapWarning">新建标记</div>
  335. <div class="displayFlex2"><div>标题:</div><input id="markerTitle" value="" placeholder="请添加标题" /></div>
  336. <div class="displayFlex2"><div>位置:</div><input id="markerLocalAddr" value="" placeholder="请描述位置" /></div>
  337. <div class="arrowdown" data-state="0"><span class="mui-icon mui-icon-arrowdown"></span></div>
  338. <div id="mapImageList">
  339. <div id="uploadImage">
  340. <div><span class="mui-icon mui-icon-plus"></span></div>
  341. <div><span>上传照片</span></div>
  342. </div>
  343. </div>
  344. <div>
  345. <p>描述:</p>
  346. <textarea name="" id="mapTextArea" placeholder="请添加描述" cols="30" rows="3"></textarea>
  347. </div>
  348. <div class="paperplaneMyMarker"><span class="mui-icon mui-icon-paperplane"></span>提交</div>`;
  349. document.getElementById('mapBottomBox').innerHTML = mapBottomBoxInnerHtml;
  350. document.getElementById('mapBottomBox').style.bottom = "0";
  351. } else {
  352. mui.alert('请先选择地图中的一个点', '系统提示')
  353. }
  354. }).on('tap', '.paperplaneMyMarker', function() {
  355. if (document.getElementById("markerTitle")) {
  356. let markerTitle = document.getElementById("markerTitle").value;
  357. let markerLocalAddr = document.getElementById("markerLocalAddr").value;
  358. let mapTextArea = document.getElementById("mapTextArea").value;
  359. let content = {
  360. title: markerTitle,
  361. content: "app自定义标记",
  362. c_date_time: new Date().getTime(),
  363. c_editorid: localStorage.getItem("userId"),
  364. c_boolean: true,
  365. c_content: {
  366. "type": "Feature",
  367. "properties": {
  368. "title": markerTitle,
  369. "desc": mapTextArea,
  370. "state": 0,
  371. "localAddr": markerLocalAddr,
  372. "fileList": fileList
  373. },
  374. "geometry": {
  375. "coordinates": [
  376. [
  377. [localStorage.getItem("latlngLat") * 1, localStorage
  378. .getItem("latlngLng") *
  379. 1
  380. ]
  381. ]
  382. ],
  383. "type": "Point"
  384. }
  385. }
  386. }
  387. let paramData = new FormData();
  388. paramData.append("content", JSON.stringify(content));
  389. paramData.append("columnId", ENVIRONMENT[SYSTEM_ENVIRONMENT].myMarksColumnId);
  390. paramData.append("modelId", ENVIRONMENT[SYSTEM_ENVIRONMENT].myMarksModelId);
  391. addContentData({
  392. data: paramData
  393. }, function(res) {
  394. let resData = res;
  395. if (resData.code == 200) {
  396. mui.toast('提交成功');
  397. localStorage.setItem('showMyMarkerBottomBox', 'false');
  398. document.getElementById('mapBottomBox').style.bottom = "-100%";
  399. }
  400. }, function(e) {
  401. mui.alert(e, '系统提示')
  402. })
  403. } else {
  404. mui.alert('请先添加标题', '系统提示')
  405. }
  406. }).on('change', '#autoLogin', function() {
  407. isActive = this.checked ? "true" : "false";
  408. localStorage.setItem('isActive', isActive);
  409. }).on('tap', '.taskItem', function() {
  410. let taskId = this.dataset.taskId;
  411. let taskName = this.dataset.taskName;
  412. if (myTaskListStateFalse[taskId]) {
  413. let myTaskListStateFalseItem = myTaskListStateFalse[taskId];
  414. let columnId = Number(myTaskListStateFalseItem.column_id);
  415. // let modelId = Number(myTaskListStateFalseItem.model_id);
  416. let paramData2 = new FormData();
  417. paramData2.append("columnId", columnId);
  418. paramData2.append("id", myTaskListStateFalseItem.id);
  419. paramData2.append("state", 1);
  420. updateAuditState({
  421. data: paramData2
  422. }, function(res) {
  423. let resData = res;
  424. if (resData.code == 200) {
  425. // 我的任务详情页面跳转
  426. clearSearchValue();
  427. localStorage.setItem("taskId", taskId);
  428. localStorage.setItem("taskName", taskName);
  429. mui.openWindow({
  430. url: "myTaskInfo.html",
  431. id: "myTaskInfo",
  432. extras: {
  433. taskId: taskId,
  434. taskName: taskName
  435. }
  436. })
  437. }
  438. }, function(e) {
  439. console.log(e)
  440. })
  441. } else {
  442. // 我的任务详情页面跳转
  443. clearSearchValue();
  444. localStorage.setItem("taskId", taskId);
  445. localStorage.setItem("taskName", taskName);
  446. mui.openWindow({
  447. url: "myTaskInfo.html",
  448. id: "myTaskInfo",
  449. extras: {
  450. taskId: taskId,
  451. taskName: taskName
  452. }
  453. })
  454. }
  455. }).on('tap', '#reSearch', function() {
  456. // 数据列表刷新,搜索框重置
  457. mui.confirm("是否重置并刷新?", "系统提示", function(status) {
  458. if (status.index == 1) {
  459. clearSearchValue();
  460. resetPageInfo();
  461. }
  462. })
  463. }).on('tap', '#searchState', function() {
  464. var statePicker = new mui.PopPicker();
  465. let pageName = document.getElementById('pageName') ? document.getElementById('pageName')
  466. .value :
  467. 'myTask';
  468. let pickerData = [{
  469. value: 0,
  470. text: "所有"
  471. }];
  472. for (let item in pageParam[pageName].taskStatusTag) {
  473. pickerData.push({
  474. value: item,
  475. text: pageParam[pageName].taskStatusTag[item].title
  476. })
  477. }
  478. statePicker.setData(pickerData);
  479. statePicker.show(function(items) {
  480. searchStateValue = items[0].value;
  481. document.getElementById('searchStateText').innerText = items[0].text;
  482. resetPageInfo();
  483. });
  484. }).on('tap', '.toBackPage', function() {
  485. console.log("utils.toBackPage")
  486. mui.back();
  487. }).on('tap', '.changeMap', function() {
  488. try {
  489. changeMap();
  490. } catch (e) {
  491. //TODO handle the exception
  492. console.log("changeMap catch")
  493. }
  494. }).on('tap', '.getLocalAddr', function() {
  495. getLocalAddr();
  496. getLocalAddrGoTo();
  497. }).on('tap', '.detailedInformation', function() {
  498. console.log("疑点详细信息", this.dataset.markerData);
  499. try {
  500. if (this.dataset.markerData != 'undefined') {
  501. mui.alert(this.dataset.markerData.substring(1, this.dataset.markerData.length -
  502. 1)
  503. .replaceAll(',', '\n'), '疑点详细信息', '确定', null, 'div')
  504. } else {
  505. mui.alert('无', '疑点详细信息', '确定', null, 'div')
  506. }
  507. } catch (e) {
  508. //TODO handle the exception
  509. console.log("detailedInformation catch")
  510. }
  511. }).on('tap', '.fileBox', function() {
  512. console.log('fileUrl', DMS_BASE_RUL + "/proxy_dms" + this.dataset.fileUrl)
  513. openRemoteFile(DMS_BASE_RUL + "/proxy_dms" + this.dataset.fileUrl);
  514. }).on('tap', '.openMyPhoneMap', function() {
  515. console.log("导航到:", this.dataset.lat, this.dataset.lng);
  516. openMyPhoneMap(this.dataset.lat, this.dataset.lng);
  517. }).on('tap', '.arrowdown', function() {
  518. if (this.dataset.state == 0) {
  519. mui.confirm('关闭后将不会保留表单信息,是否关闭?', '系统提示', ['确定', '取消'], function(val) {
  520. if (val.index == 0) {
  521. localStorage.setItem('showMyMarkerBottomBox', 'false');
  522. document.getElementById('mapBottomBox').style.bottom = "-100%";
  523. }
  524. })
  525. } else {
  526. localStorage.setItem('showMyMarkerBottomBox', 'false');
  527. document.getElementById('mapBottomBox').style.bottom = "-100%";
  528. }
  529. }).on('tap', '.paperplane', function() {
  530. console.log("用户点击paperplane")
  531. let serverDataMap = JSON.parse(localStorage.getItem('serverDataMap'));
  532. let myMarkerData = serverDataMap[document.getElementById("myMarkerId").value];
  533. let fileList_ = localStorage.getItem("markerDataPropertiesFileList") != 'undefined' ?
  534. JSON.parse(
  535. localStorage.getItem("markerDataPropertiesFileList")) : {};
  536. Object.assign(fileList_, fileList);
  537. if (myMarkerData.c_content) {
  538. let c_content = JSON.parse(myMarkerData.c_content);
  539. c_content.properties.desc = document.getElementById("mapTextArea").value;
  540. c_content.properties.state = 1;
  541. c_content.properties.fileList = fileList_;
  542. myMarkerData.c_content = c_content;
  543. } else if (myMarkerData.c_doubtful_points) {
  544. let c_doubtful_points = JSON.parse(myMarkerData.c_doubtful_points);
  545. if (!c_doubtful_points.properties) {
  546. c_doubtful_points.properties = {
  547. desc: document.getElementById("mapTextArea").value,
  548. state: 1,
  549. fileList: fileList_
  550. }
  551. } else {
  552. c_doubtful_points.properties['desc'] = document.getElementById("mapTextArea")
  553. .value;
  554. c_doubtful_points.properties['state'] = 1;
  555. c_doubtful_points.properties['fileList'] = fileList_;
  556. }
  557. myMarkerData.c_doubtful_points = c_doubtful_points;
  558. } else {
  559. mui.alert('空间信息获取失败,请检查代码后重试!', '系统异常')
  560. return false;
  561. }
  562. let content = {
  563. "id": myMarkerData.id,
  564. "title": myMarkerData.title,
  565. "content": myMarkerData.content
  566. };
  567. for (let key in myMarkerData) {
  568. if (key.indexOf('c_') == 0) {
  569. if (typeof myMarkerData[key] == 'object') {
  570. content[key + ""] = JSON.stringify(myMarkerData[key]);
  571. } else {
  572. content[key + ""] = myMarkerData[key];
  573. }
  574. }
  575. }
  576. let columnId = Number(myMarkerData.column_id);
  577. let modelId = Number(myMarkerData.model_id);
  578. let paramData = new FormData();
  579. paramData.append("content", JSON.stringify(content));
  580. paramData.append("columnId", columnId);
  581. paramData.append("modelId", modelId);
  582. let paramData2 = new FormData();
  583. paramData2.append("columnId", columnId);
  584. paramData2.append("id", myMarkerData.id);
  585. paramData2.append("state", 1);
  586. updateContentData({
  587. data: paramData
  588. }, function(res) {
  589. let resData = res;
  590. if (resData.code == 200) {
  591. document.getElementById('mapBottomBox').style.bottom = "-100%";
  592. mui.toast('提交成功');
  593. updateAuditState({
  594. data: paramData2
  595. }, function(res) {
  596. let resData = res;
  597. if (resData.code == 200) {
  598. document.activeElement.blur(); // 收起模拟键盘
  599. event.preventDefault(); // 阻止页面刷新
  600. window.history.back();
  601. }
  602. }, function(e) {
  603. console.log(e)
  604. })
  605. }
  606. }, function(e) {
  607. console.log(e)
  608. })
  609. }).on('tap', '#uploadImage', function() {
  610. // 触发文件上传按钮
  611. document.getElementById("uploadFileInput").click();
  612. }).on('tap', '.removeImage', function() {
  613. let that = this;
  614. delete fileList[this.id];
  615. mui.confirm('是否删除该图片', '系统提示', ['确定', '取消'], function(val) {
  616. if (val.index == 0) {
  617. that.remove();
  618. if (!document.getElementById("uploadImage")) {
  619. let addInput = document.createElement('div');
  620. addInput.id = "uploadImage";
  621. addInput.innerHTML = `<div><span class="mui-icon mui-icon-plus"></span></div>
  622. <div><span>上传照片</span></div>`;
  623. document.getElementById('mapImageList').append(addInput);
  624. }
  625. }
  626. })
  627. }).on('change', '#uploadFileInput', function(e) {
  628. // 获取上传的文件列表
  629. let mapImageListDom = document.getElementById('mapImageList');
  630. const file = e.target.files[0]
  631. this.fullFile = file
  632. if (fileList[file.name]) {
  633. mui.alert('请不要上传重复的图片', '系统提示');
  634. return false;
  635. } else if (!/\.(jpg|jpeg|png|JPG|PNG)$/.test(e.target.value)) {
  636. mui.alert('请上传.png/.jpg/.jpeg格式的图片', '系统提示');
  637. return false;
  638. } else if (this.fullFile.size / 1024 / 1024 > 1) {
  639. // mui.alert('请上传不超过1MB的图片', '系统提示');
  640. mask.show(); //显示遮罩
  641. mui.toast('图片过大,压缩中!!!');
  642. imageConversion.compressAccurately(file, {
  643. size: 1024
  644. }).then(res => {
  645. blobToDataURI(res, function(base64) {
  646. // 文件上传
  647. let content = {
  648. title: "appUploadFile-" + new Date().getTime(),
  649. content: file.name,
  650. c_file_base64: base64
  651. }
  652. fileList[file.name] = content.title;
  653. let paramData = new FormData();
  654. paramData.append("columnId", "1793");
  655. paramData.append("modelId", "1128");
  656. paramData.append("content", JSON.stringify(content));
  657. addContentData({
  658. data: paramData
  659. }, function(res) {
  660. console.log(res);
  661. mui.toast('文件上传成功!');
  662. }, function(e) {
  663. console.log(e);
  664. mui.toast('文件上传失败!');
  665. });
  666. document.getElementById("uploadFileInput").value = "";
  667. let imgInnerHtml =
  668. `<img src="${base64}"/>`;
  669. let cDom = document.createElement('div');
  670. cDom.innerHTML = imgInnerHtml;
  671. cDom.className = "removeImage";
  672. cDom.id = file.name;
  673. if (mapImageListDom.getElementsByTagName('img').length ==
  674. 3) {
  675. document.getElementById('uploadImage').remove();
  676. document.getElementById('mapImageList').append(cDom);
  677. mask.close(); //关闭遮罩
  678. } else {
  679. document.getElementById('mapImageList').insertBefore(
  680. cDom, document
  681. .getElementById(
  682. 'uploadImage'));
  683. mask.close(); //关闭遮罩
  684. }
  685. });
  686. });
  687. } else {
  688. fileToBase64Async(file).then(item => {
  689. // fileList[file.name] = item;
  690. // 文件上传
  691. let content = {
  692. title: "appUploadFile-" + new Date().getTime(),
  693. content: file.name,
  694. c_file_base64: item
  695. }
  696. fileList[file.name] = content.title;
  697. let paramData = new FormData();
  698. paramData.append("columnId", "1793");
  699. paramData.append("modelId", "1128");
  700. paramData.append("content", JSON.stringify(content));
  701. addContentData({
  702. data: paramData
  703. }, function(res) {
  704. let resJson = res;
  705. if (resJson.code == 200) {
  706. mui.toast('文件上传成功!');
  707. } else {
  708. mui.toast('文件上传失败!');
  709. }
  710. }, function(e) {
  711. console.log('文件上传失败!', e);
  712. mui.toast('文件上传失败!');
  713. });
  714. document.getElementById("uploadFileInput").value = "";
  715. let imgInnerHtml =
  716. `<img src="${item}"/>`;
  717. let cDom = document.createElement('div');
  718. cDom.innerHTML = imgInnerHtml;
  719. cDom.className = "removeImage";
  720. cDom.id = file.name;
  721. if (mapImageListDom.getElementsByTagName('img').length == 3) {
  722. document.getElementById('uploadImage').remove();
  723. document.getElementById('mapImageList').append(cDom);
  724. } else {
  725. document.getElementById('mapImageList').insertBefore(cDom, document
  726. .getElementById(
  727. 'uploadImage'));
  728. }
  729. })
  730. }
  731. });
  732. }
  733. // -------------------------------------------------------------自定义请求
  734. // 动态获取图片(点击疑点或标记marker时)
  735. function getFileListUrl(fileList) {
  736. return new Promise((resolve, reject) => {
  737. if (fileList) {
  738. let fileUrlList = [];
  739. let index = 0;
  740. for (let fileName in fileList) {
  741. index++;
  742. }
  743. for (let fileName in fileList) {
  744. let paramData2 = new FormData();
  745. paramData2.append("columnId", 1793);
  746. paramData2.append("states", "0,1,2");
  747. paramData2.append("pageSize", 10);
  748. paramData2.append("page", 0);
  749. let searchParam = [];
  750. let paramItem = {
  751. field: "title",
  752. searchType: "1",
  753. content: {
  754. value: fileList[fileName]
  755. }
  756. };
  757. searchParam.push(paramItem);
  758. if (searchParam.length > 0) {
  759. paramData2.append("search", JSON.stringify(searchParam));
  760. }
  761. getDmsData({
  762. data: paramData2
  763. }, function funSuccess(res, textStatus, xhr) {
  764. let resJson2 = res;
  765. if (resJson2.code == 200) {
  766. let fileBase = resJson2.content
  767. .data[0].c_file_base64;
  768. fileUrlList.push(fileBase);
  769. if (fileUrlList.length == index) {
  770. resolve(fileUrlList);
  771. }
  772. }
  773. }, function funerror(res, textStatus, xhr) {});
  774. }
  775. } else {
  776. resolve();
  777. }
  778. });
  779. }
  780. function newPostRequest(url, setting, funSuccess, funError) {
  781. var xhr = new XMLHttpRequest();
  782. // 请求成功回调函数
  783. xhr.onload = e => {
  784. console.log('request success');
  785. };
  786. // 请求结束
  787. xhr.onloadend = e => {
  788. console.log('request loadend');
  789. };
  790. // 请求出错
  791. xhr.onerror = e => {
  792. console.log('request error');
  793. funError("request error");
  794. };
  795. // 请求超时
  796. xhr.ontimeout = e => {
  797. console.log('request timeout');
  798. funError("request timeout");
  799. };
  800. xhr.open('POST', DMS_BASE_RUL + url, true);
  801. if (localStorage.getItem("token")) {
  802. xhr.setRequestHeader("token", localStorage.getItem("token"))
  803. }
  804. xhr.onreadystatechange = function() {
  805. if (xhr.readyState == 4 && xhr.status == 200) {
  806. funSuccess(JSON.parse(xhr.responseText));
  807. }
  808. }
  809. xhr.send(setting.data);
  810. }
  811. // 用户登录
  812. function apiLogin(setting, funSuccess, funError) {
  813. newPostRequest(loginUrl, setting, funSuccess, funError);
  814. // functionAsync(loginUrl, setting, funSuccess, funError);
  815. // requestSettins.success = funSuccess;
  816. // requestSettins.error = funError;
  817. // let newSetting = Object.assign(requestSettins, setting);
  818. // mui.ajax(DMS_BASE_RUL + loginUrl, newSetting);
  819. }
  820. // token验证
  821. function getUserInfo(setting, funSuccess, funError) {
  822. newPostRequest(getUserInfoUrl, setting, funSuccess, funError);
  823. // requestSettins.success = funSuccess;
  824. // requestSettins.error = funError;
  825. // let newSetting = Object.assign(requestSettins, setting);
  826. // mui.ajax(DMS_BASE_RUL + getUserInfoUrl, newSetting);
  827. }
  828. // dms数据请求
  829. function getDmsData(setting, funSuccess, funError) {
  830. newPostRequest(getDataListUrl, setting, funSuccess, funError);
  831. // requestSettins.success = funSuccess;
  832. // requestSettins.error = funError;
  833. // let newSetting = Object.assign(requestSettins, setting);
  834. // mui.ajax(DMS_BASE_RUL + getDataListUrl, newSetting);
  835. }
  836. // dms数据更新
  837. function updateContentData(setting, funSuccess, funError) {
  838. newPostRequest(updateContent, setting, funSuccess, funError);
  839. // requestSettins.success = funSuccess;
  840. // requestSettins.error = funError;
  841. // let newSetting = Object.assign(requestSettins, setting);
  842. // mui.ajax(DMS_BASE_RUL + updateContent, newSetting);
  843. }
  844. // dms状态更新
  845. function updateAuditState(setting, funSuccess, funError) {
  846. newPostRequest(updateAudit, setting, funSuccess, funError);
  847. // requestSettins.success = funSuccess;
  848. // requestSettins.error = funError;
  849. // let newSetting = Object.assign(requestSettins, setting);
  850. // mui.ajax(DMS_BASE_RUL + updateAudit, newSetting);
  851. }
  852. // dms添加数据
  853. function addContentData(setting, funSuccess, funError) {
  854. newPostRequest(addContent, setting, funSuccess, funError);
  855. // requestSettins.success = funSuccess;
  856. // requestSettins.error = funError;
  857. // let newSetting = Object.assign(requestSettins, setting);
  858. // mui.ajax(DMS_BASE_RUL + addContent, newSetting);
  859. }
  860. // 文件上传
  861. function putFile(setting, funSuccess, funError) {
  862. newPostRequest(proxyDmsFileUploadFile, setting, funSuccess, funError);
  863. // requestSettins.success = funSuccess;
  864. // requestSettins.error = funError;
  865. // let newSetting = Object.assign(requestSettins, setting);
  866. // mui.ajax(DMS_BASE_RUL + proxyDmsFileUploadFile, newSetting);
  867. }
  868. // 在线文档预览
  869. function openRemoteFile(url) {
  870. if (plusStatus) {
  871. var wait = plus.nativeUI.showWaiting("正在打开文件...");
  872. var dtask = plus.downloader.createDownload(url, {
  873. method: "GET"
  874. }, function(d, status) {
  875. if (status == 200) {
  876. plus.runtime.openFile(d.filename, {}, function(e) {
  877. wait.close();
  878. mui.alert("无法打开此文件:" + e.emssage, "我的软件");
  879. });
  880. wait.close();
  881. } else {
  882. wait.close();
  883. mui.alert("文件打开失败: " + status, "我的软件");
  884. }
  885. });
  886. dtask.start();
  887. } else {
  888. mui.alert("plus未加载成功!", "系统提示")
  889. }
  890. }
  891. function getLocalAddr() {
  892. let user_latitude = "";
  893. let user_longitude = "";
  894. // 获取手机定位
  895. plus.geolocation.getCurrentPosition(function(res) {
  896. //成功回调
  897. user_latitude = wgs84togcj02(res.coords.longitude, res.coords.latitude)[1]; //纬度
  898. user_longitude = wgs84togcj02(res.coords.longitude, res.coords.latitude)[0]; //经度
  899. localStorage.setItem("user_longitude", user_longitude);
  900. localStorage.setItem("user_latitude", user_latitude);
  901. // mui.alert("经度:" + user_longitude + " 纬度:" + user_latitude);
  902. }, function(e) {
  903. console.log('Gelocation Error: code - ' + e.code + '; message - ' + e.message);
  904. switch (e.code) {
  905. case 10:
  906. mui.alert('请开启应用的定位权限', '温馨提示', '确定', function() {}, 'div');
  907. break;
  908. case 9:
  909. //mui.alert('请开启手机定位服务');
  910. mui.alert('请开启手机定位服务', '温馨提示', '确定', function() {}, 'div');
  911. break;
  912. case 2:
  913. if (e.message.indexOf("[geolocation:13]") > -1) {
  914. //如果网络开启,定位失败,提示检查定位权限
  915. mui.alert('请开启应用的定位权限', '温馨提示', '确定', function() {}, 'div');
  916. }
  917. if (e.message.indexOf("[geolocation:14]") > -1) {
  918. //如果应用的权限开了,提示网络异常
  919. mui.alert('请检查网络是否正常', '温馨提示', '确定', function() {}, 'div');
  920. }
  921. break;
  922. case e.PERMISSION_DENIED:
  923. mui.alert('请求定位被拒绝', '温馨提示', '确定', function() {}, 'div');
  924. break;
  925. case e.POSITION_UNAVAILABLE:
  926. mui.alert("位置信息不可用", '温馨提示', '确定', function() {}, 'div');
  927. break;
  928. case e.TIMEOUT:
  929. mui.alert("获取位置信息超时", '温馨提示', '确定', function() {}, 'div');
  930. break;
  931. case e.UNKNOWN_ERROR:
  932. mui.alert("未知错误", '温馨提示', '确定', function() {}, 'div');
  933. break;
  934. }
  935. }, {
  936. //超时未获取到经纬度信息 执行失败回调 (默认为5秒)
  937. timeout: 3000
  938. })
  939. }
  940. /**
  941. * file 转Base64 DataURL
  942. * @param {File} file
  943. * @returns
  944. */
  945. function fileToBase64Async(file) {
  946. return new Promise((resolve, reject) => {
  947. let reader = new FileReader();
  948. reader.readAsDataURL(file);
  949. reader.onload = (e) => {
  950. resolve(e.target.result);
  951. };
  952. });
  953. }
  954. /**
  955. * Bolb 转Base64 DataURL
  956. * @param {blob} file blob
  957. * @returns callback
  958. */
  959. function blobToDataURI(blob, callback) {
  960. var reader = new FileReader();
  961. reader.readAsDataURL(blob);
  962. reader.onload = function(e) {
  963. callback(e.target.result);
  964. }
  965. }
  966. // -------------------------------------------------------------自定义事件
  967. // 登录请求
  968. function login() {
  969. let docUserName = document.getElementById('userName').value;
  970. let docPassword = document.getElementById('passWord').value;
  971. // let docUserName = "user001";
  972. // let docPassword = "1234567890";
  973. if (!docUserName) {
  974. mui.alert('请输入用户名!', '表单校验', function() {
  975. return false;
  976. });
  977. return false;
  978. }
  979. if (!docPassword) {
  980. mui.alert('请输入密码!', '表单校验', function() {
  981. return false;
  982. });
  983. return false;
  984. }
  985. // 登录请求
  986. if (docUserName && docPassword) {
  987. // 创建formData对象
  988. let paramData = new FormData();
  989. paramData.append("userName", docUserName);
  990. paramData.append("password", docPassword);
  991. paramData.append("clientId", "1");
  992. console.log("登录参数", docUserName, docPassword);
  993. // 开始请求登录接口
  994. apiLogin({
  995. data: paramData,
  996. dataType: "json"
  997. }, function success(res, textStatus, xhr) {
  998. console.log(JSON.stringify(res), textStatus, xhr)
  999. if (res.code == 200) {
  1000. // 如果用户选中了记住密码,则保存账户信息
  1001. if (isActive) {
  1002. localStorage.setItem('userName', docUserName);
  1003. localStorage.setItem('passWord', docPassword);
  1004. }
  1005. // 缓存登录状态主要信息
  1006. localStorage.setItem("userId", res.content.id);
  1007. localStorage.setItem("userName", res.content.username);
  1008. localStorage.setItem("token", res.message);
  1009. // 跳转到主页
  1010. mui.openWindow({
  1011. url: "pages/home.html",
  1012. id: "home",
  1013. createNew: true
  1014. });
  1015. } else {
  1016. console.log(JSON.stringify(res), textStatus, JSON.stringify(xhr));
  1017. mui.alert(res.message ? res.message : '登录失败!', '系统提示', function() {
  1018. localStorage.setItem('isActive', false);
  1019. });
  1020. }
  1021. }, function error(xhr, type, errorThrown) {
  1022. mui.alert('登录失败!', '系统提示', function() {
  1023. localStorage.setItem('isActive', false);
  1024. });
  1025. });
  1026. }
  1027. }
  1028. // 请求我的任务列表(下一页)
  1029. function getMoveMyTaskList() {
  1030. page_e = this;
  1031. getMyTaskList(false);
  1032. }
  1033. // 清空搜索框值
  1034. function clearSearchValue() {
  1035. if (document.getElementById('searchInput')) {
  1036. document.getElementById('searchInput').value = null;
  1037. }
  1038. }
  1039. // 重置页面信息并查询
  1040. function resetPageInfo() {
  1041. allCount = 0;
  1042. pageSize = 10;
  1043. page = 0;
  1044. // 删除数据列表
  1045. if (document.getElementsByClassName('displayFlex').length > 0) {
  1046. let displayFlexDoms = document.getElementsByClassName('displayFlex');
  1047. let displayFlexDomsLength = displayFlexDoms.length;
  1048. for (let i = 0; i < displayFlexDomsLength; i++) {
  1049. if (displayFlexDoms[0]) {
  1050. displayFlexDoms[0].remove();
  1051. }
  1052. }
  1053. }
  1054. // 重新请求数据
  1055. getMyTaskList(true);
  1056. mui('#listMoveDom').pullRefresh().refresh(true);
  1057. };
  1058. // 请求我的任务列表,state:是否重新加载 ?清空缓存,重新加载 : 加载下一页数据并添加数据到缓存
  1059. function getMyTaskList(state) {
  1060. // 创建formData对象
  1061. let paramData = new FormData();
  1062. let pageName = document.getElementById('pageName') ? document.getElementById('pageName').value :
  1063. 'myTask';
  1064. paramData.append("columnId", pageParam[pageName].columnId);
  1065. if (pageParam[pageName].searchStateColumnName) {
  1066. paramData.append("states", pageParam[pageName].states);
  1067. } else {
  1068. paramData.append("states", searchStateValue !== 0 ? searchStateValue : pageParam[pageName]
  1069. .states);
  1070. }
  1071. paramData.append("pageSize", pageSize);
  1072. paramData.append("page", page);
  1073. let searchParam = [];
  1074. if (pageName == "myTaskInfo") {
  1075. let param = {
  1076. field: "title",
  1077. searchType: "1",
  1078. content: {
  1079. value: localStorage.getItem("taskName")
  1080. }
  1081. };
  1082. searchParam.push(param);
  1083. }
  1084. if (localStorage.getItem("searchInput")) {
  1085. let param = {
  1086. field: pageParam[pageName].searchColumnName,
  1087. searchType: "2",
  1088. content: {
  1089. value: localStorage.getItem("searchInput")
  1090. }
  1091. };
  1092. searchParam.push(param);
  1093. localStorage.removeItem('searchInput')
  1094. }
  1095. if (document.getElementById('searchInput') && document.getElementById('searchInput').value) {
  1096. let searchInputValue = document.getElementById('searchInput').value;
  1097. if (searchInputValue) {
  1098. let param = {
  1099. field: pageParam[pageName].searchColumnName,
  1100. searchType: "2",
  1101. content: {
  1102. value: searchInputValue
  1103. }
  1104. };
  1105. searchParam.push(param);
  1106. }
  1107. }
  1108. if (pageParam[pageName].params) {
  1109. let paramItem = {
  1110. field: pageParam[pageName].params.searchColumnName,
  1111. searchType: pageParam[pageName].params.searchType ? pageParam[pageName].params
  1112. .searchType : "2",
  1113. content: {
  1114. value: pageParam[pageName].params.value
  1115. }
  1116. };
  1117. searchParam.push(paramItem);
  1118. }
  1119. if (pageParam[pageName].userIdColumnName) {
  1120. let param = {
  1121. field: pageParam[pageName].userIdColumnName,
  1122. searchType: "1",
  1123. content: {
  1124. value: localStorage.getItem("userId")
  1125. }
  1126. };
  1127. searchParam.push(param);
  1128. }
  1129. if (pageParam[pageName].searchStateColumnName && searchStateValue !== 0) {
  1130. let paramItem = {
  1131. field: pageParam[pageName].searchStateColumnName,
  1132. searchType: "1",
  1133. content: {
  1134. value: searchStateValue
  1135. }
  1136. };
  1137. searchParam.push(paramItem);
  1138. }
  1139. if (searchParam.length > 0) {
  1140. paramData.append("search", JSON.stringify(searchParam));
  1141. }
  1142. if (pageParam[pageName].orderColumnName && pageParam[pageName].orderByType) {
  1143. let sortparam = [{
  1144. field: pageParam[pageName].orderColumnName,
  1145. orderByType: pageParam[pageName].orderByType
  1146. }];
  1147. paramData.append("orderBy", JSON.stringify(sortparam));
  1148. }
  1149. getDmsData({
  1150. data: paramData
  1151. }, function funSuccess(res, textStatus, xhr) {
  1152. let resJson = {};
  1153. try {
  1154. let serverDataMap = {};
  1155. let geometrys = [];
  1156. // 如果不是重新加载而是下一页
  1157. if (!state && page != 0) {
  1158. serverDataMap = JSON.parse(localStorage.getItem("serverDataMap"));
  1159. geometrys = JSON.parse(localStorage.getItem("geometrys"));
  1160. }
  1161. if (typeof res === "object") {
  1162. resJson = res;
  1163. } else {
  1164. resJson = res;
  1165. }
  1166. if (resJson.code == 200 && resJson.content != null && resJson.content.data &&
  1167. resJson.content.data
  1168. .length > 0) {
  1169. allCount = resJson.content.count;
  1170. let listDom = document.getElementById('myTaskListDom') ? document
  1171. .getElementById(
  1172. 'myTaskListDom') :
  1173. document.getElementById('lawsAndRegulationsListDom');
  1174. for (let i = 0; i < resJson.content.data.length; i++) {
  1175. let moveDom = document.createElement('div');
  1176. let createTime = new Date(resJson.content.data[i].create_time);
  1177. let updateTime = new Date(resJson.content.data[i].update_time);
  1178. if (pageName === 'myTask') {
  1179. if (resJson.content.data[i].state == 0) {
  1180. myTaskListStateFalse[resJson.content.data[i].c_task_id] = resJson
  1181. .content.data[i];
  1182. }
  1183. // 我的任务页面
  1184. moveDom.innerHTML = `<div data-task-name="${resJson.content.data[i].title}" data-task-id="${resJson.content.data[i].c_task_id}" class="displayFlex taskItem">
  1185. <h4 class="${pageParam[pageName].taskStatusTag[resJson.content.data[i].state].class}">${resJson.content.data[i].title}
  1186. <span class="list-tag">
  1187. ${pageParam[pageName].taskStatusTag[resJson.content.data[i].state].title}</span></h4>
  1188. <p class="content">${resJson.content.data[i].content}</p>
  1189. <div class="dataListHr">
  1190. <p>创建时间:<span>${timeToStr(createTime)}</span></p>
  1191. </div>
  1192. </div>`;
  1193. } else if (pageName === 'myTaskInfo') {
  1194. // 我的任务详情页面
  1195. let cDoubtfulPoints = JSON.parse(resJson.content.data[i]
  1196. .c_doubtful_points);
  1197. cDoubtfulPoints.dataTitle = cDoubtfulPoints.name ? cDoubtfulPoints
  1198. .name :
  1199. cDoubtfulPoints.id;
  1200. cDoubtfulPoints.id = resJson.content.data[i].id;
  1201. serverDataMap[cDoubtfulPoints.id] = resJson.content.data[i];
  1202. geometrys.push(cDoubtfulPoints);
  1203. localStorage.setItem("geometrys", JSON.stringify(geometrys));
  1204. moveDom.innerHTML = `<div data-marker-id="${resJson.content.data[i].id}" class="displayFlex toMapPage">
  1205. <h4 class="${pageParam[pageName].taskStatusTag[resJson.content.data[i].state].class}">
  1206. ${cDoubtfulPoints.dataTitle ? `${cDoubtfulPoints.dataTitle}` : ``}
  1207. <span class="list-tag">
  1208. ${pageParam[pageName].taskStatusTag[resJson.content.data[i].state].title}</span></h4>
  1209. <p class="content">
  1210. ${cDoubtfulPoints.properties && cDoubtfulPoints.properties["Name"] ? `${cDoubtfulPoints.properties["Name"]}` : ``}
  1211. </p>
  1212. <div class="dataListHr">
  1213. <p>创建时间:<span>${timeToStr(createTime)}</span></p>
  1214. </div>
  1215. </div>`;
  1216. } else if (pageName === 'myMarks') {
  1217. // 我的标记页面
  1218. let cDoubtfulPoints = JSON.parse(resJson.content.data[i].c_content);
  1219. // 暂存id,方便提交的时候得到原始数据
  1220. cDoubtfulPoints.id = resJson.content.data[i].id;
  1221. // 数据暂存到serverDataMap对象中
  1222. serverDataMap[cDoubtfulPoints.id] = resJson.content.data[i];
  1223. geometrys.push(cDoubtfulPoints);
  1224. localStorage.setItem("geometrys", JSON.stringify(geometrys));
  1225. moveDom.innerHTML = `<div data-marker-id="${resJson.content.data[i].id}" class="displayFlex toMapPage">
  1226. <h4 class="BrandTag">${resJson.content.data[i].title}</h4>
  1227. <p class="content">${cDoubtfulPoints.properties.desc +"-"+ cDoubtfulPoints.properties.title}</p>
  1228. <div class="dataListHr">
  1229. <p>创建时间:<span>${timeToStr(createTime)}</span></p>
  1230. </div>
  1231. </div>`;
  1232. } else {
  1233. // 知识检索页面
  1234. moveDom.innerHTML = `<div class="displayFlex fileBox" data-file-url="${resJson.content.data[i].c_pdf || resJson.content.data[i].c_c_pdf}">
  1235. <p class="fileTitle">${resJson.content.data[i].title}</p>
  1236. <div class="dataListHr">
  1237. <p class="nonePadding">发布日期:<span>${timeToStr(createTime)}</span></p>
  1238. </div>
  1239. </div>`;
  1240. }
  1241. // 恢复上拉刷新状态
  1242. listDom.insertBefore(moveDom, document.getElementById(
  1243. 'listMoveDom'));
  1244. }
  1245. localStorage.setItem("serverDataMap", JSON.stringify(serverDataMap));
  1246. // 分页配置
  1247. if (page_e) {
  1248. if (allCount > (page + 1) * pageSize) {
  1249. document.getElementById("upTitle").innerHTML = "上拉加载更多……";
  1250. page_e.endPullupToRefresh(false);
  1251. } else {
  1252. mui.toast('没有更多数据了');
  1253. document.getElementById("upTitle").innerHTML = "没有更多数据了";
  1254. page_e.endPullupToRefresh(true);
  1255. }
  1256. } else {
  1257. console.log('page_e is null!')
  1258. }
  1259. page++;
  1260. } else {
  1261. // 请求失败!
  1262. document.getElementById("upTitle").innerHTML = resJson.message;
  1263. page_e.endPullupToRefresh(true);
  1264. if (resJson.content === "无效token") {
  1265. localStorage.removeItem("token");
  1266. mui.openWindow("../index.html", "login");
  1267. }
  1268. }
  1269. } catch (e) {
  1270. // 处理异常
  1271. //TODO handle the exception
  1272. mui.alert('try处理异常!' + e, '系统提示', function() {
  1273. document.getElementById("upTitle").innerHTML = "处理异常!";
  1274. page_e.endPullupToRefresh(true);
  1275. });
  1276. }
  1277. }, function error(xhr, type, errorThrown) {
  1278. // request异常
  1279. mui.alert('请求失败!' + JSON.stringify(xhr), '系统提示', function() {
  1280. document.getElementById("upTitle").innerHTML = "请求失败!";
  1281. page_e.endPullupToRefresh(true);
  1282. });
  1283. });
  1284. };
  1285. function getFileBase64ByTitle(fileTitle) {
  1286. let paramData = new FormData();
  1287. paramData.append("columnId", 1793);
  1288. paramData.append("columnId", 1793);
  1289. paramData.append("states", "0,1,2,3");
  1290. paramData.append("pageSize", 10);
  1291. paramData.append("page", 0);
  1292. let searchParam = [];
  1293. let param = {
  1294. field: "title",
  1295. searchType: "2",
  1296. content: {
  1297. value: fileTitle
  1298. }
  1299. };
  1300. searchParam.push(param);
  1301. paramData.append("search", JSON.stringify(searchParam));
  1302. getDmsData({
  1303. data: paramData
  1304. }, function funSuccess(res, textStatus, xhr) {
  1305. console.log(res);
  1306. }, function funError(e) {
  1307. console.log(e);
  1308. })
  1309. }
  1310. // 时间戳转字符串
  1311. function timeToStr(date) {
  1312. return date.getFullYear() + "-" + timeToTwo(date.getMonth() + 1) +
  1313. "-" + timeToTwo(date.getDate()) + " " + timeToTwo(date.getHours()) + ":" + timeToTwo(date
  1314. .getMinutes()) + ":" +
  1315. timeToTwo(date.getSeconds());
  1316. }
  1317. // 时间单位(x|xx)转换
  1318. function timeToTwo(number) {
  1319. return number < 10 ? '0' + number : number
  1320. }
  1321. //定义一些常量
  1322. var x_PI = 3.14159265358979324 * 3000.0 / 180.0;
  1323. var PI = 3.1415926535897932384626;
  1324. var a = 6378245.0;
  1325. var ee = 0.00669342162296594323;
  1326. /**
  1327. * 百度坐标系 (BD-09) 与 火星坐标系 (GCJ-02)的转换
  1328. * 即 百度 转 谷歌、高德
  1329. * @param bd_lon
  1330. * @param bd_lat
  1331. * @returns {*[]}
  1332. */
  1333. function bd09togcj02(bd_lon, bd_lat) {
  1334. var bd_lon = +bd_lon;
  1335. var bd_lat = +bd_lat;
  1336. var x = bd_lon - 0.0065;
  1337. var y = bd_lat - 0.006;
  1338. var z = Math.sqrt(x * x + y * y) - 0.00002 * Math.sin(y * x_PI);
  1339. var theta = Math.atan2(y, x) - 0.000003 * Math.cos(x * x_PI);
  1340. var gg_lng = z * Math.cos(theta);
  1341. var gg_lat = z * Math.sin(theta);
  1342. return [gg_lng, gg_lat]
  1343. };
  1344. /**
  1345. * 火星坐标系 (GCJ-02) 与百度坐标系 (BD-09) 的转换
  1346. * 即谷歌、高德 转 百度
  1347. * @param lng
  1348. * @param lat
  1349. * @returns {*[]}
  1350. */
  1351. function gcj02tobd09(lng, lat) {
  1352. var lat = +lat;
  1353. var lng = +lng;
  1354. var z = Math.sqrt(lng * lng + lat * lat) + 0.00002 * Math.sin(lat * x_PI);
  1355. var theta = Math.atan2(lat, lng) + 0.000003 * Math.cos(lng * x_PI);
  1356. var bd_lng = z * Math.cos(theta) + 0.0065;
  1357. var bd_lat = z * Math.sin(theta) + 0.006;
  1358. return [bd_lng, bd_lat]
  1359. };
  1360. /**
  1361. * WGS84转GCj02
  1362. * @param lng
  1363. * @param lat
  1364. * @returns {*[]}
  1365. */
  1366. function wgs84togcj02(lng, lat) {
  1367. var lat = +lat;
  1368. var lng = +lng;
  1369. var dlat = transformlat(lng - 105.0, lat - 35.0);
  1370. var dlng = transformlng(lng - 105.0, lat - 35.0);
  1371. var radlat = lat / 180.0 * PI;
  1372. var magic = Math.sin(radlat);
  1373. magic = 1 - ee * magic * magic;
  1374. var sqrtmagic = Math.sqrt(magic);
  1375. dlat = (dlat * 180.0) / ((a * (1 - ee)) / (magic * sqrtmagic) * PI);
  1376. dlng = (dlng * 180.0) / (a / sqrtmagic * Math.cos(radlat) * PI);
  1377. var mglat = lat + dlat;
  1378. var mglng = lng + dlng;
  1379. return [mglng, mglat]
  1380. };
  1381. /**
  1382. * GCJ02 转换为 WGS84
  1383. * @param lng
  1384. * @param lat
  1385. * @returns {*[]}
  1386. */
  1387. function gcj02towgs84(lng, lat) {
  1388. var lat = +lat;
  1389. var lng = +lng;
  1390. var dlat = transformlat(lng - 105.0, lat - 35.0);
  1391. var dlng = transformlng(lng - 105.0, lat - 35.0);
  1392. var radlat = lat / 180.0 * PI;
  1393. var magic = Math.sin(radlat);
  1394. magic = 1 - ee * magic * magic;
  1395. var sqrtmagic = Math.sqrt(magic);
  1396. dlat = (dlat * 180.0) / ((a * (1 - ee)) / (magic * sqrtmagic) * PI);
  1397. dlng = (dlng * 180.0) / (a / sqrtmagic * Math.cos(radlat) * PI);
  1398. var mglat = lat + dlat;
  1399. var mglng = lng + dlng;
  1400. return [lng * 2 - mglng, lat * 2 - mglat]
  1401. };
  1402. /**
  1403. * 百度坐标系 (BD-09) 转换为 WGS84
  1404. * @param lng
  1405. * @param lat
  1406. * @returns {*[]}
  1407. */
  1408. function bd09towgs84(bd_lon, bd_lat) {
  1409. //百度经纬度坐标转国测局坐标
  1410. var bd09togcj02_arr = bd09togcj02(bd_lon, bd_lat);
  1411. //国测局坐标转wgs84坐标
  1412. var gcj02towgs84_arr = gcj02towgs84(bd09togcj02_arr[0], bd09togcj02_arr[1]);
  1413. return [gcj02towgs84_arr[0], gcj02towgs84_arr[1]]
  1414. };
  1415. /**
  1416. * WGS84 转换为 百度坐标系 (BD-09)
  1417. * @param lng
  1418. * @param lat
  1419. * @returns {*[]}
  1420. */
  1421. function wgs84tobd09(lng, lat) {
  1422. //wgs84转国测局坐标
  1423. var wgs84togcj02_arr = wgs84togcj02(lng, lat);
  1424. //国测局坐标转百度经纬度坐标
  1425. var gcj02tobd09_arr = gcj02tobd09(wgs84togcj02_arr[0], wgs84togcj02_arr[1]);
  1426. return [gcj02tobd09_arr[0], gcj02tobd09_arr[1]]
  1427. };
  1428. function transformlat(lng, lat) {
  1429. var lat = +lat;
  1430. var lng = +lng;
  1431. var ret = -100.0 + 2.0 * lng + 3.0 * lat + 0.2 * lat * lat + 0.1 * lng * lat + 0.2 * Math.sqrt(
  1432. Math.abs(lng));
  1433. ret += (20.0 * Math.sin(6.0 * lng * PI) + 20.0 * Math.sin(2.0 * lng * PI)) * 2.0 / 3.0;
  1434. ret += (20.0 * Math.sin(lat * PI) + 40.0 * Math.sin(lat / 3.0 * PI)) * 2.0 / 3.0;
  1435. ret += (160.0 * Math.sin(lat / 12.0 * PI) + 320 * Math.sin(lat * PI / 30.0)) * 2.0 / 3.0;
  1436. return ret
  1437. };
  1438. function transformlng(lng, lat) {
  1439. var lat = +lat;
  1440. var lng = +lng;
  1441. var ret = 300.0 + lng + 2.0 * lat + 0.1 * lng * lng + 0.1 * lng * lat + 0.1 * Math.sqrt(Math
  1442. .abs(lng));
  1443. ret += (20.0 * Math.sin(6.0 * lng * PI) + 20.0 * Math.sin(2.0 * lng * PI)) * 2.0 / 3.0;
  1444. ret += (20.0 * Math.sin(lng * PI) + 40.0 * Math.sin(lng / 3.0 * PI)) * 2.0 / 3.0;
  1445. ret += (150.0 * Math.sin(lng / 12.0 * PI) + 300.0 * Math.sin(lng / 30.0 * PI)) * 2.0 / 3.0;
  1446. return ret
  1447. };
  1448. // 唤起导航
  1449. function openMyPhoneMap(lat, lng) {
  1450. mui.alert('正在唤起本地导航应用,请稍后!', '系统提示')
  1451. if (lat && lng) {
  1452. // var lng = parseFloat(localStorage.getItem("user_longitude")); //目标经度
  1453. // var lat = parseFloat(localStorage.getItem("user_latitude")); //目标纬度
  1454. //把百度坐标系bd09转国测局坐标系wgs84
  1455. var sopt = [lng, lat];
  1456. //经测试腾讯地图必须使用火星坐标系gcj02,顾单独转换
  1457. var coordQQ = wgs84togcj02(lng, lat);
  1458. //如果还知道其他地图的包名,也可以放这个数组里
  1459. var mapsPackageNames = ['com.baidu.BaiduMap', 'com.autonavi.minimap', 'com.tencent.map'];
  1460. //iOS与Android的判断第三方程序不一样,Android是包名,iOS是action属性(Scheme)
  1461. var iosURLTypes = ['baidumap://', 'iosamap://', 'qqmap://'];
  1462. if (plus.os.name == "iOS") {
  1463. mapsPackageNames = iosURLTypes
  1464. };
  1465. operationAfterCheckInstall(mapsPackageNames, function(res) { //res(object)
  1466. // alert(JSON.stringify(res))
  1467. var m = 0,
  1468. gotoUrl = ""; //m:记录本机地图app个数,gotoUrl:记录实际直接跳转地址
  1469. var btnArray = []; //实际显示按钮数组
  1470. var btnTitle = ["使用百度地图导航", "使用高德地图导航", "使用腾讯地图导航"];
  1471. var urlArray = []; //实际显示跳转地址数组
  1472. //百度api文档:http://lbsyun.baidu.com/index.php?title=uri/api/android
  1473. //高德api文档:https://lbs.amap.com/api/amap-mobile/guide/ios/route
  1474. //腾讯api文档:https://lbs.qq.com/webApi/uriV1/uriGuide/uriMobileRoute
  1475. var andrUrl = [
  1476. "baidumap://map/direction?origin=&destination=" + sopt[1] + "," + sopt[0] +
  1477. "&coord_type=wgs84&mode=driving&src=andr.baidu.openAPIdemo",
  1478. "amapuri://route/plan/?slat=&slon=&dlat=" + sopt[1] + "&dlon=" + sopt[0] +
  1479. "&dev=1&t=0",
  1480. "qqmap://map/routeplan?type=drive&fromcoord=CurrentLocation&tocoord=" +
  1481. coordQQ[1] + "," +
  1482. coordQQ[
  1483. 0] + "&referer=OB4BZ-D4W3U-B7VVO-4PJWW-6TKDJ-WPB77"
  1484. ]
  1485. var iosUrl = [
  1486. "baidumap://map/direction?origin=&destination=" + sopt[1] + "," + sopt[0] +
  1487. "&coord_type=wgs84&mode=driving&src=ios.baidu.openAPIdemo",
  1488. "iosamap://path?sourceApplication=applicationNameslat=&slon=&dlat=" + sopt[
  1489. 1] + "&dlon=" +
  1490. sopt[
  1491. 0] +
  1492. "&dev=1&t=0",
  1493. "qqmap://map/routeplan?type=drive&fromcoord=CurrentLocation&tocoord=" +
  1494. coordQQ[1] + "," +
  1495. coordQQ[
  1496. 0] + "&referer=OB4BZ-D4W3U-B7VVO-4PJWW-6TKDJ-WPB77"
  1497. ]
  1498. //根据手机型号确定跳转数组var
  1499. if (plus.os.name == "iOS") {
  1500. urlArray = iosUrl;
  1501. } else {
  1502. urlArray = andrUrl;
  1503. }
  1504. var gotoUrlArr = [];
  1505. for (k in res) {
  1506. if (res[k]) {
  1507. m++;
  1508. gotoUrl = urlArray[k];
  1509. btnArray.push({
  1510. title: btnTitle[k]
  1511. })
  1512. gotoUrlArr.push(urlArray[k])
  1513. }
  1514. }
  1515. //当只有一个地图APP时,直接跳转;不止一个时弹出原生选择框
  1516. if (m > 1) {
  1517. plus.nativeUI.actionSheet({
  1518. title: "请选择地图",
  1519. cancel: "取消",
  1520. buttons: btnArray
  1521. }, function(e) {
  1522. if (e.index > 0) { //=0:取消,1:百度,2:高德,3:腾讯
  1523. plus.runtime.openURL(gotoUrlArr[e.index - 1]);
  1524. }
  1525. });
  1526. } else {
  1527. plus.runtime.openURL(gotoUrl);
  1528. }
  1529. // plus.maps.openSysMap(dst, name, src);//直接默认跳转第三方,无回调,已弃用
  1530. }, function() {
  1531. alert("您未安装百度地图、高德地图、腾讯地图,请前往应用市场下载");
  1532. })
  1533. }
  1534. }
  1535. //传入包名,检查手机上是否安装了这个应用
  1536. function isInstall(packageName) {
  1537. try {
  1538. if (plus.os.name == "iOS") {
  1539. var UIApplication = plus.ios.importClass("UIApplication");
  1540. var NSURL = plus.ios.importClass("NSURL");
  1541. var app = UIApplication.sharedApplication();
  1542. var bdScheme = NSURL.URLWithString(packageName);
  1543. var install = app.canOpenURL(bdScheme);
  1544. plus.ios.deleteObject(bdScheme);
  1545. plus.ios.deleteObject(app);
  1546. return install
  1547. } else {
  1548. var main = plus.android.runtimeMainActivity();
  1549. var packageManager = main.getPackageManager();
  1550. var PackageManager = plus.android.importClass(packageManager);
  1551. var packageinfo = packageManager.getPackageInfo(packageName, PackageManager.GET_ACTIVITIES)
  1552. if (packageinfo) {
  1553. return true;
  1554. } else {
  1555. return false;
  1556. }
  1557. }
  1558. } catch (e) {
  1559. return false;
  1560. }
  1561. }
  1562. //批量传入包名,检查一系列应用是否安装,如果有任意一个安装了,就执行success,否认执行fai
  1563. function operationAfterCheckInstall(mapsPackageNames, success, fail) {
  1564. var res = mapsPackageNames.map(function(item) {
  1565. return isInstall(item);
  1566. })
  1567. if (eval(res.join("||"))) {
  1568. success(res);
  1569. } else {
  1570. fail();
  1571. }
  1572. }
  1573. // plus注释区域,真机调试或打包需要放开
  1574. }
  1575. }, true);