gcmsQuestionnaire.js 16 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469
  1. /**
  2. * [ONEMAP.M.gcmsQuestionnaire]
  3. * @return {[object]}
  4. */
  5. define(['handlebars','css!cssDir/mod-gcms','jquery/jquery.drag'],
  6. function(Handlebars){
  7. //参数
  8. var _options = {};
  9. //地图层
  10. var _map = ONEMAP.M.mapHolder.map;
  11. var _questionnaireListData = [];
  12. var _questionnaireDetailData;
  13. var _tpl = '<div id="gcmsQuestionnaireViewer" class="modal">'+
  14. '<div class="modal-header">'+
  15. '<button type="button" class="btn btn1 close">×</button>'+
  16. '<h3>问卷列表</h3>'+
  17. '</div>'+
  18. '<div class="modal-body" style="height:100%">'+
  19. '<ul id="gcmsQuestionnaireViewerList"></ul>'+
  20. '</div>'+
  21. '</div>';
  22. var _detailTpl = '<div id="gcmsQuestionnaireDetail" class="modal">'+
  23. '<div class="modal-header">'+
  24. '<button type="button" class="btn btn1 close">×</button>'+
  25. '<h3>问卷详情</h3>'+
  26. '</div>'+
  27. '<div class="modal-body" style="height:100%">'+
  28. '<div id="gcmsQuestionnaireDetailBox"></div>'+
  29. '</div>'+
  30. '</div>';
  31. /**
  32. * 模块初始化
  33. * @return {[type]} [description]
  34. */
  35. function init(options){
  36. remove();
  37. _options = {};
  38. _questionnaireListData = [];
  39. _questionnaireDetailData = null;
  40. for(var op in options){
  41. _options[op] = options[op];
  42. }
  43. getArticleData({callback:function(){
  44. //设置容器布局
  45. setQuestionnaireModal();
  46. }})
  47. //订阅推送
  48. subscribe();
  49. }
  50. function getArticleData(options){
  51. ONEMAP.V.loading.load();
  52. $.ajax({
  53. url: onemapUrlConfig.gcmsServiceUrl+'/show/'+_options['column_name']+'/'+_options['article_id'],
  54. type:"GET",
  55. dataType: 'jsonp'
  56. })
  57. .done(function(data) {
  58. ONEMAP.V.loading.loaded();
  59. if(data.code == 4){
  60. ONEMAP.C.noPermission('getDetailData');
  61. return false;
  62. }
  63. if(data.code == 3){
  64. ONEMAP.C.logout('getDetailData');
  65. }
  66. ONEMAP.D.gcmsCurArticleData = data['data'];
  67. options.callback();
  68. })
  69. .fail(function() {
  70. ONEMAP.V.loading.loaded();
  71. });
  72. }
  73. function getDetailData(options){
  74. _questionnaireDetailData = {
  75. "jibenxinxi": {
  76. "values": [
  77. [
  78. {
  79. "id": "xuexiaomingcheng",
  80. "label": "学校名称",
  81. "type": "Text",
  82. "value": "北京实验小学"
  83. },
  84. {
  85. "id": "xueduan",
  86. "label": "学校学段",
  87. "type": "Text",
  88. "value": "初级"
  89. },
  90. {
  91. "filename": "9_31.jpg",
  92. "size": 0,
  93. "id": "logo",
  94. "label": "学校校徽/LOGO",
  95. "type": "File",
  96. "value": "9_31.jpg"
  97. }
  98. ],
  99. [
  100. {
  101. "id": "xuexiaomingcheng",
  102. "label": "学校名称",
  103. "type": "Text",
  104. "value": "北京清华附小"
  105. },
  106. {
  107. "id": "xueduan",
  108. "label": "学校学段",
  109. "type": "Text",
  110. "value": "初级"
  111. },
  112. {
  113. "filename": "9_46.jpg",
  114. "size": 0,
  115. "id": "logo",
  116. "label": "学校校徽/LOGO",
  117. "type": "File",
  118. "value": "9_46.jpg"
  119. }
  120. ]
  121. ],
  122. "label": "学校基本信息",
  123. "type": "Entity"
  124. },
  125. "kecheng": {
  126. "values": [
  127. [
  128. {
  129. "code": "小学一年级",
  130. "qualifier": null,
  131. "id": "nianji",
  132. "label": "年级",
  133. "type": "Code",
  134. "value": "小学一年级"
  135. },
  136. {
  137. "code": "自然",
  138. "qualifier": "学期",
  139. "id": "kecheng",
  140. "label": "课程",
  141. "type": "Code",
  142. "value": "其他"
  143. },
  144. {
  145. "id": "beizhu",
  146. "label": "备注",
  147. "type": "Text",
  148. "value": "选修"
  149. }
  150. ],
  151. [
  152. {
  153. "code": "小学二年级",
  154. "qualifier": null,
  155. "id": "nianji",
  156. "label": "年级",
  157. "type": "Code",
  158. "value": "小学二年级"
  159. },
  160. {
  161. "code": "数学",
  162. "qualifier": null,
  163. "id": "kecheng",
  164. "label": "课程",
  165. "type": "Code",
  166. "value": "数学"
  167. },
  168. {
  169. "id": "beizhu",
  170. "label": "备注",
  171. "type": "Text",
  172. "value": "必学"
  173. }
  174. ]
  175. ],
  176. "label": "各年级开设的课程(教材版本)",
  177. "type": "Entity"
  178. },
  179. "beizhu": {
  180. "id": "beizhu",
  181. "label": "备注",
  182. "type": "Text",
  183. "value": "小学教育调查"
  184. }
  185. };
  186. options.callback();
  187. // ONEMAP.V.loading.load();
  188. // $.ajax({
  189. // url: onemapUrlConfig.gcmsServiceUrl+'/show/'+_options['column_name']+'/'+_options['article_id'],
  190. // type:"GET",
  191. // dataType: 'jsonp'
  192. // })
  193. // .done(function(data) {
  194. // ONEMAP.V.loading.loaded();
  195. // })
  196. // .fail(function() {
  197. // ONEMAP.V.loading.loaded();
  198. // });
  199. }
  200. /**
  201. * 设置容器
  202. */
  203. function setQuestionnaireModal(){
  204. _questionnaireListData = JSON.parse(ONEMAP.D.gcmsCurColumnModelData['field_list'][_options['field_name']]['custom_value']);
  205. $('body').append(_tpl);
  206. $('body').append(_detailTpl);
  207. layoutResize();
  208. $('#gcmsQuestionnaireViewerList').empty();
  209. $(_questionnaireListData).each(function(index, el) {
  210. $('#gcmsQuestionnaireViewerList').append('<li><button mid="'+el['id']+'" class="btn">'+el['name']+'</button></li>')
  211. });
  212. $('#gcmsQuestionnaireViewerList .btn').bind('click',function(){
  213. //根据id获取问卷内容列表,根据文章名称筛选出问卷ID,再根据ID获取问卷详情 orz!
  214. var mid = $(this).attr('mid');
  215. getDetailData({
  216. mid:mid,
  217. article_title:ONEMAP.D.gcmsCurArticleData['record']['gcms_title'],
  218. callback:function(){
  219. showQuestionnaireDetail();
  220. }
  221. });
  222. });
  223. bindEvent();
  224. $('#gcmsQuestionnaireViewer').show();
  225. }
  226. /**
  227. * 显示问卷详情
  228. * @return {[type]} [description]
  229. */
  230. function showQuestionnaireDetail(){
  231. $('#gcmsQuestionnaireDetailBox').empty();
  232. for(var name in _questionnaireDetailData){
  233. var item = _questionnaireDetailData[name];
  234. var func = 'get'+item['type']+'Detail';
  235. $('#gcmsQuestionnaireDetailBox').append(eval(func+'(item)'));
  236. }
  237. $('#gcmsQuestionnaireDetail').show();
  238. }
  239. function getTextDetail(data){
  240. var table = $('<table class="border box-header"><tbody></tbody></table>');
  241. var tr = $('<tr><th></th><td></td></tr>');
  242. tr.find('th:first').html(data['label']);
  243. tr.find('td:first').html(data['value']);
  244. tr.appendTo(table.find('tbody'));
  245. return table;
  246. }
  247. function getFileDetail(data){
  248. var table = $('<table class="border box-header"><tbody></tbody></table>');
  249. var tr = $('<tr><th></th><td></td></tr>');
  250. tr.find('th:first').html(data['label']);
  251. tr.find('td:first').html(data['value']);
  252. tr.appendTo(table.find('tbody'));
  253. return table;
  254. }
  255. function getCodeDetail(data){
  256. var table = $('<table class="border box-header"><tbody></tbody></table>');
  257. var tr = $('<tr><th></th><td></td></tr>');
  258. tr.find('th:first').html(data['label']);
  259. tr.find('td:first').html(data['value']);
  260. tr.appendTo(table.find('tbody'));
  261. return table;
  262. }
  263. function getBooleanDetail(data){
  264. var table = $('<table class="border box-header"><tbody></tbody></table>');
  265. var tr = $('<tr><th></th><td></td></tr>');
  266. tr.find('th:first').html(data['label']);
  267. tr.find('td:first').html(data['value']);
  268. tr.appendTo(table.find('tbody'));
  269. return table;
  270. }
  271. function getCoordinateDetail(data){
  272. var table = $('<table class="border box-header"><tbody></tbody></table>');
  273. var tr = $('<tr><th></th><td></td></tr>');
  274. tr.find('th:first').html(data['label']);
  275. tr.find('td:first').html(data['value']);
  276. tr.appendTo(table.find('tbody'));
  277. return table;
  278. }
  279. function getIntegerDetail(data){
  280. var table = $('<table class="border box-header"><tbody></tbody></table>');
  281. var tr = $('<tr><th></th><td></td></tr>');
  282. tr.find('th:first').html(data['label']+'('+data['unit']+')');
  283. tr.find('td:first').html(data['value']);
  284. tr.appendTo(table.find('tbody'));
  285. return table;
  286. }
  287. function getIntegerRangeDetail(data){
  288. var table = $('<table class="border box-header"><tbody></tbody></table>');
  289. var tr = $('<tr><th></th><td></td></tr>');
  290. tr.find('th:first').html(data['label']+'('+data['unit']+')');
  291. tr.find('td:first').html(data['value']);
  292. tr.appendTo(table.find('tbody'));
  293. return table;
  294. }
  295. function getRealDetail(data){
  296. var table = $('<table class="border box-header"><tbody></tbody></table>');
  297. var tr = $('<tr><th></th><td></td></tr>');
  298. tr.find('th:first').html(data['label']+'('+data['unit']+')');
  299. tr.find('td:first').html(data['value']);
  300. tr.appendTo(table.find('tbody'));
  301. return table;
  302. }
  303. function getRealRangeDetail(data){
  304. var table = $('<table class="border box-header"><tbody></tbody></table>');
  305. var tr = $('<tr><th></th><td></td></tr>');
  306. tr.find('th:first').html(data['label']+'('+data['unit']+')');
  307. tr.find('td:first').html(data['value']);
  308. tr.appendTo(table.find('tbody'));
  309. return table;
  310. }
  311. function getDateDetail(data){
  312. var table = $('<table class="border box-header"><tbody></tbody></table>');
  313. var tr = $('<tr><th></th><td></td></tr>');
  314. tr.find('th:first').html(data['label']);
  315. tr.find('td:first').html(data['value']);
  316. tr.appendTo(table.find('tbody'));
  317. return table;
  318. }
  319. function getTimeDetail(data){
  320. var table = $('<table class="border box-header"><tbody></tbody></table>');
  321. var tr = $('<tr><th></th><td></td></tr>');
  322. tr.find('th:first').html(data['label']);
  323. tr.find('td:first').html(data['value']);
  324. tr.appendTo(table.find('tbody'));
  325. return table;
  326. }
  327. function getTaxonDetail(data){
  328. var table = $('<table class="border box-header"><tbody></tbody></table>');
  329. var tr = $('<tr><th></th><td></td></tr>');
  330. tr.find('th:first').html(data['label']);
  331. tr.find('td:first').html(data['value']);
  332. tr.appendTo(table.find('tbody'));
  333. return table;
  334. }
  335. function getEntityDetail(data){
  336. var table = $('<table class="border box-header"><tbody></tbody></table>');
  337. var tr = $('<tr><th></th><td></td></tr>');
  338. tr.find('th:first').html(data['label']);
  339. $(data.values).each(function(index, el) {
  340. var table_in = $('<table class="border box-header"><tbody></tbody></table>');
  341. var tr_in = $('<tr><td></td></tr>');
  342. $(el).each(function(index_in, el_in) {
  343. var func = 'get'+el_in['type']+'Detail';
  344. tr_in.find('td:first').append(eval(func+'(el_in)'));
  345. });
  346. tr_in.appendTo(table_in.find('tbody'));
  347. tr.find('td:first').append(table_in);
  348. });
  349. tr.appendTo(table.find('tbody'));
  350. return table;
  351. }
  352. /**
  353. * 事件绑定
  354. * @return {[type]} [description]
  355. */
  356. function bindEvent(){
  357. $('#gcmsQuestionnaireViewer .modal-header .close').bind('click', function() {
  358. remove();
  359. });
  360. var $box = $('#gcmsQuestionnaireViewer').mousedown(function(e) {
  361. var offset = $(this).offset();
  362. this.posix = {'x': e.pageX - offset.left, 'y': ((e.pageY - offset.top)>0?(e.pageY - offset.top):0)};
  363. $.extend(document, {'move': true, 'move_target': this});
  364. });
  365. $('#gcmsQuestionnaireViewer .modal-body').on('mousedown',function(e){
  366. return false;
  367. });
  368. $('#gcmsQuestionnaireDetail .modal-header .close').bind('click', function() {
  369. $('#gcmsQuestionnaireDetail').hide();
  370. });
  371. var $box2 = $('#gcmsQuestionnaireDetail').mousedown(function(e) {
  372. var offset = $(this).offset();
  373. this.posix = {'x': e.pageX - offset.left, 'y': ((e.pageY - offset.top)>0?(e.pageY - offset.top):0)};
  374. $.extend(document, {'move': true, 'move_target': this});
  375. });
  376. $('#gcmsQuestionnaireDetail .modal-body').on('mousedown',function(e){
  377. return false;
  378. });
  379. }
  380. /**
  381. * 界面布局重置
  382. * @type {Function}
  383. */
  384. function layoutResize(){
  385. $('#gcmsQuestionnaireDetail .modal-body').css({height:ONEMAP.M.pcLayout.styles.mapHeight-300});
  386. }
  387. /**
  388. * 注册监听
  389. * @type {Function}
  390. */
  391. function subscribe(){
  392. ONEMAP.C.publisher.subscribe(layoutResize,'sideBarLayoutChange');
  393. ONEMAP.C.publisher.subscribe(remove,'gcmsArticleShowRemove');
  394. }
  395. /**
  396. * 取消监听
  397. * @type {Function}
  398. */
  399. function unSubscribe() {
  400. ONEMAP.C.publisher.unSubscribe(layoutResize,'sideBarLayoutChange');
  401. }
  402. /**
  403. * 模块移除
  404. * @return {[type]} [description]
  405. */
  406. function remove(){
  407. $('#gcmsQuestionnaireViewer').remove();
  408. $('#gcmsQuestionnaireDetail').remove();
  409. _questionnaireListData = [];
  410. _questionnaireDetailData = null;
  411. unSubscribe();
  412. }
  413. return ONEMAP.M.gcmsQuestionnaire = {
  414. init:init,
  415. remove:remove
  416. }
  417. });