e6e774a76ac697dd85fe388aa2d368509c4525ed.svn-base 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456
  1. var sidValue = [];
  2. var orgLongNum="";
  3. var sumType = "1";
  4. var colNames;
  5. var colModel;
  6. shr.defineClass("shr.customer.gtiit.rpt.contractListReportNEWList", shr.framework.List, {
  7. gridId: '#reportGrid',
  8. reportUipk : "com.kingdee.eas.contractListReportNEW.list" ,
  9. rowNumPerPage : 30, // 设置默认分页30
  10. colModelData: null,
  11. isFirstTimeLoad: 0,
  12. initalizeDOM : function () {
  13. var that = this;
  14. that.setColModelData();
  15. shr.customer.gtiit.rpt.contractListReportNEWList.superClass.initalizeDOM.call(this);
  16. // 快速查询添加事件
  17. $('#searcher').shrSearchBar('option', {
  18. afterSearchClick: this.queryGridByEvent
  19. });
  20. $("#proposer").attr("maxlength","").attr("validate","");
  21. $("#queryTime").shrDateTimePicker("setValue", new Date());
  22. $("#queryTime").trigger("change")
  23. //快速过滤展开
  24. if($(".filter-containers").is(":hidden")){
  25. $("#filter-slideToggle").click();
  26. }
  27. }
  28. /**
  29. * 选择导航节点
  30. */
  31. ,queryGridByEvent: function(e) {
  32. var viewPage;
  33. var self=this;
  34. if (e.target) {
  35. viewPage = shr.getCurrentViewPage(e.target);
  36. } else {
  37. viewPage = shr.getCurrentViewPage(e);
  38. }
  39. // 将页码恢复为第1页
  40. $(viewPage.gridId).jqGrid('option', 'page', 1);
  41. viewPage.queryAction();
  42. },
  43. /**
  44. * 获得search查询条件
  45. */
  46. getSearchFilterItems: function() {
  47. var filter = $('#searcher').shrSearchBar('option', 'filterView');
  48. if (filter && filter.filterItems) {
  49. return filter.filterItems;
  50. }
  51. }
  52. ,queryAction : function () {
  53. var self = this;
  54. //search搜索
  55. var searchFilterItems = self.getSearchFilterItems();
  56. if( searchFilterItems == undefined)
  57. searchFilterItems = "" ;
  58. //快速过滤
  59. var fastFilterItems = self.getFastFilterItems();
  60. if(fastFilterItems == undefined){
  61. fastFilterItems = "";
  62. }
  63. if(fastFilterItems["add"] == ""){
  64. fastFilterItems["add"] = null;
  65. }
  66. //R20190625-2369保存方案后,其它条件设置的条件被清空
  67. //需把视图的filterItem其他条件name="add"改成name="advancedFilter"
  68. var advancedFilterItems = self.getAdvancedFilterItems();
  69. if(advancedFilterItems != undefined){
  70. fastFilterItems["add"] = advancedFilterItems;
  71. }
  72. $("#reportGrid").jqGrid('setGridParam', {
  73. datatype : 'json',
  74. postData : {
  75. 'NewRearch' : 'newRearch',
  76. 'fastFilterItems' : $.toJSON(fastFilterItems),
  77. 'searchFilterItems' : searchFilterItems,
  78. 'sumType' : sumType,
  79. 'page' : 1
  80. },
  81. page : 0
  82. });
  83. self.doRenderDataGrid();
  84. },
  85. setColModelData: function () {
  86. var self = this;
  87. self.remoteCall({
  88. method : "getGridColModel",
  89. success : function (data) {
  90. colNames = data.colNames;
  91. colModel = data.colModel;
  92. }
  93. })
  94. },
  95. /**
  96. * 表格数据请求URL
  97. */
  98. getGridDataRequestURL : function () {
  99. var serviceId = shr.getUrlRequestParam("serviceId");
  100. return this.dynamicPage_url + "?method=getGridData" + "&uipk=" + this.reportUipk + '&serviceId='+encodeURIComponent(serviceId);
  101. },
  102. doRenderDataGrid : function () {
  103. var self = this, table = $("#reportGrid");
  104. var searchFilterItems = self.getSearchFilterItems();
  105. var fastFilterItems = self.getFastFilterItems();
  106. if( searchFilterItems == undefined)
  107. searchFilterItems = "" ;
  108. if( fastFilterItems == undefined)
  109. fastFilterItems = "" ;
  110. if(fastFilterItems["add"] == ""){
  111. fastFilterItems["add"] = null;
  112. }
  113. //R20190625-2369保存方案后,其它条件设置的条件被清空
  114. //需把视图的filterItem其他条件name="add"改成name="advancedFilter"
  115. var advancedFilterItems = self.getAdvancedFilterItems();
  116. if(advancedFilterItems != undefined){
  117. fastFilterItems["add"] = advancedFilterItems;
  118. }
  119. postData = {
  120. 'searchFilterItems' : searchFilterItems,
  121. 'fastFilterItems' : $.toJSON(fastFilterItems),
  122. 'page1' : 1
  123. };
  124. var url = self.getGridDataRequestURL();
  125. var options = {
  126. url : url ,
  127. datatype : "json",
  128. multiselect : true,
  129. rownumbers : false,
  130. colNames : colNames,
  131. colModel : colModel,
  132. rowNum : self.rowNumPerPage,
  133. // pager : '#gridPager1',
  134. mtype: 'POST',
  135. postData: postData ,
  136. // height : 'auto',
  137. height : '600px',
  138. // height : self.rowNumPerPage > 21 ? '600px' : 'auto',
  139. rowList : [30,45,60],
  140. recordpos : 'left',
  141. recordtext : '({0}-{1})/{2}',
  142. gridview : true,
  143. // pginput : true,
  144. shrinkToFit :colModel.length>10?false:true,
  145. viewrecords : true,
  146. //cellEdit:true,
  147. // cellsubmit:"clientArray" ,
  148. // sortname : "sumsql.fproposerid",
  149. //caption: "Frozen Header",
  150. customPager : '#gridPager1',
  151. pagerpos:"center",
  152. pginputpos:"right",
  153. pginput:true,
  154. synchTotal:"true",
  155. onSelectRow: function(id){
  156. jQuery('#reportGrid').jqGrid('editRow', id, false, function(){});
  157. sidValue.push(id);
  158. lastsel2 = id;
  159. $("#reportGrid").attr("sid", sidValue.join(","));
  160. }
  161. };
  162. options.loadComplete = function (data) {
  163. if($("#gridPager1").html() == "" && "true" == "true"){
  164. $("#reportGrid").setCustomPager("#gridPager1");
  165. }
  166. shr.setIframeHeight();
  167. $('#gridPager1_left').click(function(){
  168. $('.ui-pg-selbox').show();
  169. $('.ui-pg-selbox').css({"left":"-60px"})
  170. $(this).children('.ui-paging-info').hide();
  171. });
  172. $("#microToolbar").parent().hide()
  173. $("#gridPager1").parent().css({"position":"relative"})
  174. $("#gridPager1").addClass("shrPage").css({
  175. "position":"absolute",
  176. "top":"-25px",
  177. "right":"0px",
  178. "background":"#FFF"
  179. })
  180. shr.customer.gtiit.rpt.contractListReportNEWList.superClass.gridLoadComplete.call(this,data);
  181. };
  182. table.html();
  183. table.jqGrid(options);
  184. jQuery("#reportGrid").jqGrid(options).jqGrid("reloadGrid");
  185. jQuery('#reportGrid').jqGrid('setFrozenColumns');
  186. self.firstTime = 1;
  187. },
  188. handleMicroToolbarInfo : function () {
  189. var self = this;
  190. var html = "";
  191. html += "<div class='shrPage page-Title' >";
  192. html += "<span id='gripage' class='ui-paging-info' style='cursor: default;display: inline-block;font-size: 13px;padding: 2px 5px 0 0;'></span>";
  193. html += "<span id='prevId' style='vertical-align: text-top;cursor: pointer;' class='ui-icon ui-icon-seek-prev'></span>";
  194. html += "<span id='nextId' style='vertical-align: text-top;cursor: pointer;' class='ui-icon ui-icon-seek-next'></span></div>";
  195. $('#microToolbar').html("");
  196. $('#microToolbar').append(html);
  197. $("#gripage").on("click", self.selectRowNumPerPage);
  198. $("#prevId").on("click", self.prePage);
  199. $("#nextId").on("click", self.nextPage);
  200. //页码 (1-4)/4
  201. self.updatePageEnable();
  202. $("#gripage").text($("#gridPager1_left >div[dir='ltr']").text());
  203. $("#gridPager1").hide();
  204. var ids=jQuery("#reportGrid").jqGrid('getDataIDs');
  205. var rowdata=jQuery("#reportGrid").jqGrid('getRowData',ids[0]);
  206. shr.setIframeHeight();
  207. $("#reportGrid_frozen").parent().height('583px');
  208. },
  209. updatePageEnable:function () {
  210. var temp = $("#gridPager1_left >div[dir='ltr']").text();
  211. if (temp.substring(1, temp.indexOf('-')) == '1') {
  212. $("#prevId").addClass("ui-state-disabled");
  213. } else {
  214. $("#prevId").removeClass("ui-state-disabled");
  215. }
  216. if (parseInt(temp.substring(temp.indexOf('-') + 1, temp.indexOf(')'))) >= parseInt(temp.substring(temp.indexOf('/') + 1).replace(new RegExp(",","gm"),""))) {
  217. $("#nextId").addClass("ui-state-disabled");
  218. } else {
  219. $("#nextId").removeClass("ui-state-disabled");
  220. }
  221. },
  222. getCurPage:function(){
  223. //(1-4)/4
  224. var self = this,
  225. rowNum = self.rowNumPerPage;
  226. var temp = $("#gridPager1_left >div[dir='ltr']").text();
  227. var curPageNum = (parseInt(temp.substring(1, temp.indexOf('-')))-1)/rowNum+1;
  228. return curPageNum;
  229. },
  230. prePage : function () {
  231. $("#prev_gridPager1").trigger("click");
  232. shr.setIframeHeight();
  233. $("#gripage").text($("#gridPager1_left >div[dir='ltr']").text());
  234. },
  235. nextPage : function () {
  236. $("#next_gridPager1").trigger("click");
  237. shr.setIframeHeight();
  238. $("#gripage").text($("#gridPager1_left >div[dir='ltr']").text());
  239. },
  240. selectRowNumPerPage:function(){
  241. }
  242. ,
  243. exportToExcelAction : function () {
  244. var _self = this ;
  245. var url = _self.exportCommonParam();
  246. var fastFilterItems = _self.getFastFilterItems();
  247. if( fastFilterItems == undefined)
  248. fastFilterItems = "" ;
  249. if(fastFilterItems["add"] == ""){
  250. fastFilterItems["add"] = null;
  251. }
  252. var serviceId = shr.getUrlRequestParam("serviceId");
  253. url += '&serviceId='+encodeURIComponent(serviceId) + "&isAll=true";
  254. //document.location.href = url;
  255. var callback=function(psw){
  256. var params = _self.getExportAllParams();
  257. params.exportPrivteProtected = $.allEncrypt(psw);
  258. openLoader(1,jsBizMultLan.atsManager_attendanceResultSumList_i18n_28);
  259. shr.ajax({
  260. type:"post",
  261. url:url,
  262. data: $.extend(_self.assemExportData(),{exportPrivteProtected: psw} ),
  263. success:function(res){
  264. closeLoader();
  265. if(null != res && null != res.url){ //这里有可能返回空,所以这里要做飞空判断的,但是不知道这里的业务逻辑,所以这里要问常青和飞羽
  266. shr.redirect(res.url,"");
  267. }
  268. //document.location.href = url;
  269. },
  270. error : function(res){
  271. shr.showError({message: jsBizMultLan.atsManager_attendanceResultSumList_i18n_6});
  272. closeLoader();
  273. }
  274. });
  275. }
  276. if(_self.isNeedExportFilePassword('#exportToExcel')) {
  277. fieldSensitiveService.setExportPsw(callback);
  278. }else{
  279. callback();
  280. }
  281. },
  282. assemExportData:function(exportData){
  283. var _self = this ;
  284. var fastFilterItems = _self.getFastFilterItems();
  285. var advancedFilterItems = _self.getAdvancedFilterItems();
  286. if( fastFilterItems == undefined)
  287. fastFilterItems = "" ;
  288. if(fastFilterItems["add"] == ""){
  289. fastFilterItems["add"] = null;
  290. }
  291. if(advancedFilterItems != undefined){
  292. fastFilterItems["add"] = advancedFilterItems;
  293. }
  294. var postData = {fastFilterItems : $.toJSON(fastFilterItems)};
  295. exportData && (postData = $.extend(postData, exportData));
  296. return postData;
  297. },
  298. exportCommonParam : function(){
  299. var self = this;
  300. var url = shr.getContextPath() + shr.dynamicURL + "?method=exportToExcel";
  301. var uipk = "com.kingdee.eas.hr.ats.app.AttendanceResultSumList";
  302. var filterItems = self.getQuickFilterItems();
  303. var sorder = $('#reportGrid').jqGrid('getGridParam', 'sortorder') || "";
  304. var sordName = $('#reportGrid').jqGrid('getGridParam', 'sortname') || "";
  305. //标题
  306. url += "&title="+jsBizMultLan.atsManager_attendanceResultSumList_i18n_8;
  307. url = url + '&uipk=' + uipk + "&sidx=" + sordName+"&page=0"+"&sumType="+sumType + "&sord=" + sorder + "&transverse=1";
  308. //如果存在高级搜索的条件,则拼上条件。
  309. if(filterItems){
  310. url += "&searchFilterItems=" + encodeURIComponent(filterItems);
  311. }
  312. return url;
  313. },
  314. exportCurrentAction : function(){
  315. var Exchange_json=[];
  316. var _self = this;
  317. var exportData = {
  318. exportSelect:"yes",
  319. serviceId:shr.getUrlRequestParam("serviceId")
  320. };
  321. var selectedIds = $("#reportGrid").jqGrid("getSelectedRows");
  322. if (selectedIds.length > 0) {
  323. for (var i = 0, length = selectedIds.length; i < length; i++) {
  324. // personIds.push($("#reportGrid").jqGrid("getCell", selectedIds[i], "id"));
  325. var item = selectedIds[i];
  326. var data = $("#reportGrid").jqGrid("getRowData", item);
  327. var personId=data["personId"] ;
  328. var adminOrgUnit=data["adminOrgUnitId"] ;
  329. Exchange_json.push({'personId':personId,'adminOrgUnit':adminOrgUnit});
  330. }
  331. }
  332. if(Exchange_json.length > 0){
  333. exportData.PersonJson = $.toJSON(Exchange_json);
  334. }else{
  335. shr.showWarning({
  336. message: jsBizMultLan.atsManager_attendanceResultSumList_i18n_13
  337. });
  338. return false;
  339. }
  340. var callback=function(psw){
  341. var params = _self.getExportCurrentParams();
  342. params.exportPrivteProtected = $.allEncrypt(psw);
  343. openLoader(1,jsBizMultLan.atsManager_attendanceResultSumList_i18n_28);
  344. shr.ajax({
  345. type:"post",
  346. url:_self.exportCommonParam(),
  347. data: $.extend( _self.assemExportData(exportData),params ),
  348. success:function(res){
  349. closeLoader();
  350. //document.location.href = url;
  351. shr.redirect(res.url,"");
  352. },
  353. error : function(res){
  354. shr.showError({message: jsBizMultLan.atsManager_attendanceResultSumList_i18n_6});
  355. closeLoader();
  356. }
  357. });
  358. }
  359. if(_self.isNeedExportFilePassword('#exportCurrent')) {
  360. fieldSensitiveService.setExportPsw(callback);
  361. }else{
  362. callback();
  363. }
  364. },
  365. //导出选中参数,供领域获取
  366. getExportCurrentParams: function() {
  367. var _self = this;
  368. var isenableexcelpwd = $('#exportCurrent').attr('data-isenableexcelpwd');
  369. var fieldName = this.getExportFieldName();
  370. if(isenableexcelpwd == 'false') {
  371. if(window.isShrSensitiveRuleOpen) isenableexcelpwd = _self.isSensitiveGrid();
  372. }
  373. var ids = $("#reportGrid").jqGrid("getSelectedRows");
  374. var params = {
  375. supportQueryUuid: false,
  376. selectedData: ids,
  377. fieldName_key: fieldName,
  378. encryptKeys: 'exportPrivteProtected',
  379. isEnableExcelPwd: typeof(isenableexcelpwd) === 'undefined' ? 'false' : JSON.parse(isenableexcelpwd)
  380. }
  381. return params;
  382. },
  383. exportAllExcelAction:function(){
  384. var _self = this;
  385. var self = this, table = $("#reportGrid");
  386. var searchFilterItems = self.getSearchFilterItems();
  387. var fastFilterItems = self.getFastFilterItems();
  388. if( searchFilterItems == undefined)
  389. searchFilterItems = "" ;
  390. if( fastFilterItems == undefined)
  391. fastFilterItems = "" ;
  392. if(fastFilterItems["add"] == ""){
  393. fastFilterItems["add"] = null;
  394. }
  395. //R20190625-2369保存方案后,其它条件设置的条件被清空
  396. //需把视图的filterItem其他条件name="add"改成name="advancedFilter"
  397. var advancedFilterItems = self.getAdvancedFilterItems();
  398. if(advancedFilterItems != undefined){
  399. fastFilterItems["add"] = advancedFilterItems;
  400. }
  401. var urlinner = shr.getContextPath() + shr.dynamicURL + "?fastFilterItems="+$.toJSON(fastFilterItems)+"&method=toExcel&handler=com.kingdee.shr.customer.gtiit.rpt.ContractListReportNEWListHandler"+"&uipk="+shr.getUrlRequestParam('uipk');
  402. //var urlinner = shr.getContextPath() + shr.dynamicURL + "?method=toExcel&handler=com.kingdee.shr.customer.gtiit.rpt.PersonRosterListHandler";
  403. //alert(urlinner);
  404. openLoader(1,"正在导出,请稍等...");
  405. var param2 = "";
  406. var test = shr.reloadUrlByPost(urlinner, param2, 'toExcel');
  407. closeLoader();
  408. /*
  409. _self.remoteCall({
  410. type: "post",
  411. async: false,
  412. method: "toExcel",
  413. param: {
  414. 'fastFilterItems' : $.toJSON(fastFilterItems)
  415. },
  416. });
  417. */
  418. }
  419. });