Form.js 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411
  1. Ext.define('erp.view.common.batchPrint.Form',{
  2. extend: 'Ext.form.Panel',
  3. alias: 'widget.erpBatchPrintFormPanel',
  4. id: 'printform',
  5. region: 'north',
  6. frame : true,
  7. header: false,//不显示title
  8. layout : 'column',
  9. autoScroll : true,
  10. defaultType : 'textfield',
  11. labelSeparator : ':',
  12. buttonAlign : 'center',
  13. fieldDefaults : {
  14. margin : '2 2 2 2',
  15. fieldStyle : "background:#FFFAFA;color:#515151;",
  16. labelAlign : "right",
  17. blankText : $I18N.common.form.blankText
  18. },
  19. FormUtil: Ext.create('erp.util.FormUtil'),
  20. tbar: [{
  21. name: 'query',
  22. text: $I18N.common.button.erpQueryButton,
  23. iconCls: 'x-button-icon-query',
  24. cls: 'x-btn-gray',
  25. handler: function(){
  26. var grid = Ext.getCmp('batchPrintGridPanel');
  27. var form = Ext.getCmp('printform');
  28. var gridParam = {caller: caller, condition: form.getCondition(), start: 1, end: 1000};
  29. form.beforeQuery(caller, gridParam.condition);//执行查询前逻辑
  30. grid.GridUtil.loadNewStore(grid, gridParam);
  31. }
  32. }, '->', {
  33. name: 'batchPrint',
  34. text: $I18N.common.button.erpVastPrintButton,
  35. iconCls: 'x-button-icon-print',
  36. cls: 'x-btn-gray',
  37. handler:function(btn){
  38. var form = btn.ownerCt.ownerCt, grid = form.ownerCt.down('grid');
  39. var keyField = form.fo_keyField;
  40. var items = grid.getMultiSelected();
  41. var ids =new Array();
  42. var length = items.length;
  43. var idStr ='';
  44. Ext.each(items,function(item,index){
  45. if(length!=index+1){
  46. //idStr = idStr+'[[['+item.data[keyField]+']]],';
  47. idStr = idStr+item.data[keyField]+',';
  48. }else{
  49. idStr = idStr+item.data[keyField];
  50. }
  51. // var id =item.data[keyField];
  52. // ids.push(id);
  53. });
  54. var title = form.title;
  55. var reportName="";
  56. var condition="";
  57. var todate='';
  58. var dateFW='';
  59. var fromdate='';
  60. var enddate='';
  61. if (title=='销售变更单打印'){
  62. reportName="SaleChange_Batch";
  63. condition='{SaleChange.sc_id}in[ '+idStr+' ]';
  64. }else if(title=="出货通知单打印"){
  65. reportName="SendNotify_batch";
  66. condition='{SendNotify.sn_id}in[ '+idStr+' ]';
  67. }else if(title=="出货单打印"){
  68. reportName="sendlist_yessale_batch";
  69. condition='{ProdInout.pi_id}in[ '+idStr+' ]';
  70. }else if(title=="请购单打印"){
  71. reportName="application_batch";
  72. condition='{application.ap_id}in[ '+idStr+' ]';
  73. }
  74. else if(title=="采购变更单打印"){
  75. reportName="PURCChange_batch";
  76. condition='{PurchaseChange.pc_id}in[ '+idStr+' ]';
  77. }else if(title=="采购收料单打印"){
  78. reportName="VerifyApply_batch";
  79. condition='{VerifyApply.va_id}in[ '+idStr+' ]';
  80. }else if(title=="估价单打印"){
  81. reportName="sale_gj_batch";
  82. condition='{evaluation.ev_id}in[ '+idStr+' ]';
  83. }else if(title=="报价单打印"){
  84. reportName="QUOTLIST_batch";
  85. condition='{Quotation.qu_id}in[ '+idStr+' ]';
  86. }else if(title=="销售订单评审表打印"){
  87. reportName="SaleForecastAudit1_batch";
  88. condition='{SaleForecast.sf_id}in[ '+idStr+' ]';
  89. }else if(title=="借货出货单打印"){
  90. reportName="jhch";
  91. condition='{ProdInout.pi_id}in[ '+idStr+' ]';
  92. }else if(title=="销售退货单打印"){
  93. reportName="retulist_batch";
  94. condition='{ProdInout.pi_id}in[ '+idStr+' ]';
  95. }else if(title=="采购物料明细表"){
  96. reportName="ProductBuy";
  97. condition='{Purchase.pu_id}in[ '+idStr+' ]';
  98. }else if(title=="收料明细打印"){
  99. reportName="VerifyApplyDetail";
  100. condition='{verifyapply.va_id}in[ '+idStr+' ]';
  101. }else if(title=="采购退料单打印"){
  102. reportName="piolist_yt_batch";
  103. condition='{ProdInout.pi_id}in[ '+idStr+' ]';
  104. }else if(title=="采购退货清单打印"){
  105. reportName="piolistytList";
  106. condition='{ProdInout.pi_id}in[ '+idStr+' ]';
  107. }else if(title=="采购退货清单打印"){
  108. reportName="piolistytList";
  109. condition='{ProdInout.pi_id}in[ '+idStr+' ]';
  110. }else if(title=="采购单批量打印"){
  111. reportName="PURCLIST_Batch";
  112. condition='{purchase.pu_id}in[ '+idStr+' ]';
  113. }else if(title=="未审核采购单打印"){
  114. reportName="PURCLIST_Batch";
  115. condition='{purchase.pu_id}in[ '+idStr+' ]';
  116. }else if(title=="采购单打印(英文版)"){
  117. reportName="PURCLIST_ENGLISH";
  118. condition='{purchase.pu_id}in[ '+idStr+' ]';
  119. }else if(title=="采购预测单打印"){
  120. reportName="PurchaseYC_Batch";
  121. condition='{PurchaseForecast.pf_id}in[ '+idStr+' ]';
  122. }else if(title=="委外加工单资料打印"){
  123. reportName="MAKEWW_Batch";
  124. condition='{make.ma_id}in[ '+idStr+' ]';
  125. }else if(title=="委外领料单打印"){
  126. reportName="PIOLISTMWW_Batch";
  127. condition='{ProdInout.pi_id}in[ '+idStr+' ]';
  128. }else if(title=="委外退料单打印"){
  129. reportName="EXPLIST_yt_Batch";
  130. condition='{ProdInout.pi_id}in[ '+idStr+' ]';
  131. }else if(title=="委外补料单打印"){
  132. reportName="Expiolist_Batch";
  133. condition='{ProdInout.pi_id}in[ '+idStr+' ]';
  134. }else if(title=="委外报废单打印"){
  135. reportName="MakeScrapWW_Batch";
  136. condition='{ProdInout.pi_id}in[ '+idStr+' ]';
  137. }else if(title=="制造单资料打印"){
  138. reportName="MakeList";
  139. condition='{make.ma_id}in[ '+idStr+' ]';
  140. }else if(title=="生产领料单打印"){
  141. reportName="PIOLISTM_Batch";
  142. condition='{ProdInout.pi_id}in[ '+idStr+' ]';
  143. }else if(title=="采购退货单打印"){
  144. reportName="PIOLISTM_Back";
  145. condition='{ProdInout.pi_id}in[ '+idStr+' ]';
  146. }else if(title=="生产补料单打印"){
  147. reportName="PIOLIST_bl_Batch";
  148. condition='{ProdInout.pi_id}in[ '+idStr+' ]';
  149. }else if(title=="生产报废单打印"){
  150. reportName="MakeScrap_Batch";
  151. condition='{make.ma_id}in[ '+idStr+' ]';
  152. }else if(title=="完工入库单打印"){
  153. reportName="finish_Batch";
  154. condition='{ProdInout.pi_id}in[ '+idStr+' ]';
  155. }else if(title=="拆件完工入库单打印"){
  156. reportName="chaijian_Batch";
  157. condition='{ProdInout.pi_id}in[ '+idStr+' ]';
  158. }else if(title=="BOM多级展开"){
  159. reportName="bomlevel3";
  160. //var boid = Ext.getCmp('bo_id').getValue();
  161. var kind=Ext.getCmp('bo_remark').getValue();
  162. //console.log(kind);
  163. //console.log(boid);
  164. condition='{BomStruct.bs_sonbomid}in[ '+idStr+' ]';
  165. //+' and '+' (isnull({BomDetail.bd_usestatus}) or {BomDetail.bd_usestatus}<>'+"'DISABLE')";
  166. if(kind=="原材料"){
  167. condition+=' and '+'{BomStruct.bs_sonbomid}='+"0";
  168. }
  169. if(kind=="半成品"){
  170. condition+=' and '+'(isnull({product.pr_manutype}) or {product.pr_manutype}<>'+"'PURCHASE'"+') and '+'{BomStruct.bs_sonbomid}>'+"0";
  171. }
  172. console.log(condition);
  173. }else if(title=="物料综合查询"){
  174. reportName="ProductBalance";
  175. var prodcode = Ext.getCmp('pr_code').getValue();
  176. if(prodcode!=""){
  177. condition='{Product.pr_code}='+"'"+prodcode+"'";
  178. }
  179. }else if(title=="FQC检验报告打印"){
  180. reportName="verifyMake_Batch";
  181. condition='{QUA_VerifyApplyDetail.ve_id}in[ '+idStr+' ]';
  182. console.log(condition);
  183. }else if(title=="凭证批量打印"){
  184. reportName="vouclist_rmb";
  185. condition='{voucher.vo_id}in[ '+idStr+' ]';
  186. console.log(condition);
  187. }else if(title=="采购验收单批量打印"){
  188. reportName="acclist_batch";
  189. condition='{ProdInout.pi_id}in[ '+idStr+' ]';
  190. console.log(condition);
  191. }else if(title=="费用批量打印"){
  192. reportName="AccountRegZW_batch";
  193. condition='{FeePlease.fp_id}in[ '+idStr+' ]';
  194. console.log(condition);
  195. }else if(title=="费用批量打印(无备注)"){
  196. reportName="AccountRegZW_batch_no";
  197. condition='{FeePlease.fp_id}in[ '+idStr+' ]';
  198. console.log(condition);
  199. }
  200. //=======================================================
  201. var me = this;
  202. Ext.Ajax.request({
  203. url : basePath + 'common/enterprise/getprinturl.action?caller=' + caller,
  204. callback: function(opt, s, r) {
  205. var re = Ext.decode(r.responseText);
  206. thisreport=re.reportname;
  207. //===========================================
  208. var whichsystem = re.whichsystem;
  209. var urladdress = "";
  210. var rpname = re.reportName;
  211. //console.log(rpname);
  212. if(Ext.isEmpty(rpname) || rpname == "null"){
  213. urladdress = re.printurl;
  214. } else if(rpname.indexOf(thisreport) > 0){
  215. urladdress = re.ErpPrintLargeData;
  216. } else{
  217. urladdress = re.printurl;
  218. }
  219. //console.log(reportName);
  220. //console.log(re.ErpPrintLargeData);
  221. console.log(urladdress);
  222. console.log(whichsystem);
  223. //===============================================
  224. form.FormUtil.batchPrint(idStr,reportName,condition,title,todate,dateFW,fromdate,enddate,urladdress,whichsystem);
  225. //在这里传条件和报表名字
  226. }
  227. });
  228. //=======================================================
  229. //form.FormUtil.batchPrint(idStr,reportName,condition,title);
  230. }
  231. },'-',{
  232. name: 'export',
  233. text: $I18N.common.button.erpExportButton,
  234. iconCls: 'x-button-icon-submit',
  235. cls: 'x-btn-gray',
  236. handler: function(btn){
  237. var form = btn.ownerCt.ownerCt,
  238. grid = Ext.getCmp('batchPrintGridPanel');
  239. var cond = form.getCondition();
  240. if(Ext.isEmpty(cond)) {
  241. cond = '1=1';
  242. }
  243. grid.BaseUtil.createExcel(caller, 'detailgrid', cond);
  244. }
  245. },'-',{
  246. text: $I18N.common.button.erpCloseButton,
  247. iconCls: 'x-button-icon-close',
  248. cls: 'x-btn-gray',
  249. handler: function(){
  250. var main = parent.Ext.getCmp("content-panel");
  251. main.getActiveTab().close();
  252. }
  253. }],
  254. initComponent : function(){
  255. var urlcondition = getUrlParam('condition');//从url解析参数
  256. urlcondition = (urlcondition == null) ? "" : urlcondition.replace(/IS/g,"=");
  257. var param = {caller: caller, condition: urlcondition};
  258. this.FormUtil.getItemsAndButtons(this, 'common/singleFormItems.action', param);
  259. this.callParent(arguments);
  260. this.addKeyBoardEvents();
  261. },
  262. getCondition: function(){
  263. var grid = Ext.getCmp('batchPrintGridPanel');
  264. var form = Ext.getCmp('printform');
  265. var condition = grid.defaultCondition || '';
  266. Ext.each(form.items.items, function(f){
  267. if(f.logic != null && f.logic != ''){
  268. if(f.xtype == 'checkbox' && f.value == true){
  269. if(condition == ''){
  270. condition += f.logic;
  271. } else {
  272. condition += ' AND ' + f.logic;
  273. }
  274. } else if(f.xtype == 'datefield' && f.value != null){
  275. var v = Ext.Date.format(new Date(f.value), 'Y-m-d');
  276. if(condition == ''){
  277. condition += f.logic + "=to_date('" + v + "', 'yyyy-MM-dd')";
  278. } else {
  279. condition += ' AND ' + f.logic + "=to_date('" + v + "', 'yyyy-MM-dd')";
  280. }
  281. } else if(f.xtype == 'datetimefield' && f.value != null){
  282. var v = Ext.Date.format(new Date(f.value), 'Y-m-d H:i:s');
  283. if(condition == ''){
  284. condition += f.logic + "=to_date('" + v + "', 'yyyy-MM-dd HH24:mi:ss')";
  285. } else {
  286. condition += ' AND ' + f.logic + "=to_date('" + v + "', 'yyyy-MM-dd HH24:mi:ss')";
  287. }
  288. } else if((f.xtype == 'numberfield' || f.xtype == 'monthdatefield') && f.value != null && f.value != ''){
  289. if(condition == ''){
  290. condition += f.logic + '=' + f.value;
  291. } else {
  292. condition += ' AND ' + f.logic + '=' + f.value;
  293. }
  294. } else if(f.xtype == 'combo' && f.value == '$ALL'){
  295. if(f.store.data.length > 1) {
  296. if(condition == ''){
  297. condition += '(';
  298. } else {
  299. condition += ' AND (';
  300. }
  301. var _a = '';
  302. f.store.each(function(d, idx){
  303. if(d.data.value != '$ALL') {
  304. if(_a == ''){
  305. _a += f.logic + "='" + d.data.value + "'";
  306. } else {
  307. _a += ' OR ' + f.logic + "='" + d.data.value + "'";
  308. }
  309. }
  310. });
  311. condition += _a + ')';
  312. }
  313. } else {
  314. if(contains(f.logic, 'to:', true)){
  315. if(!grid.toField){
  316. grid.toField = new Array();
  317. }
  318. grid.toField.push(f.logic.split(':')[1]);
  319. } else {
  320. if(!Ext.isEmpty(f.value)){
  321. if(contains(f.value.toString(), 'BETWEEN', true) && contains(f.value.toString(), 'AND', true)){
  322. if(condition == ''){
  323. condition += f.logic + " " + f.value;
  324. } else {
  325. condition += ' AND (' + f.logic + " " + f.value + ")";
  326. }
  327. } else if(contains(f.value.toString(), '||', true)){
  328. var str = '';
  329. Ext.each(f.value.split('||'), function(v){
  330. if(v != null && v != ''){
  331. if(str == ''){
  332. str += f.logic + "='" + v + "'";
  333. } else {
  334. str += ' OR ' + f.logic + "='" + v + "'";
  335. }
  336. }
  337. });
  338. if(condition == ''){
  339. condition += "(" + str + ")";
  340. } else {
  341. condition += ' AND (' + str + ")";
  342. }
  343. } else if(f.value.toString().charAt(0) == '!'){
  344. if(condition == ''){
  345. condition += 'nvl(' + f.logic + ",' ')<>'" + f.value.substr(1) + "'";
  346. } else {
  347. condition += ' AND (nvl(' + f.logic + ",' ')<>'" + f.value.substr(1) + "')";
  348. }
  349. } else {
  350. if(!Ext.isNumber(f.value) && f.value.indexOf('%') >= 0) {
  351. if(condition == ''){
  352. condition += f.logic + " like '" + f.value + "'";
  353. } else {
  354. condition += ' AND (' + f.logic + " like '" + f.value + "')";
  355. }
  356. } else {
  357. if(condition == ''){
  358. condition += f.logic + "='" + f.value + "'";
  359. } else {
  360. condition += ' AND (' + f.logic + "='" + f.value + "')";
  361. }
  362. }
  363. }
  364. }
  365. }
  366. }
  367. }
  368. });
  369. return condition;
  370. },
  371. addKeyBoardEvents: function(){
  372. var me = this;
  373. if(Ext.isIE){
  374. document.body.attachEvent('onkeydown', function(){//ie的事件名称不同,也不支持addEventListener
  375. if(window.event.altKey && window.event.ctrlKey && window.event.keyCode == 83){
  376. me.FormUtil.onAdd('form' + caller, 'Form配置维护(' + caller + ')', "jsps/ma/multiform.jsp?formCondition=fo_idIS" + me.fo_id +
  377. "&gridCondition=fd_foidIS" + me.fo_id + "&whoami=" + caller);
  378. }
  379. });
  380. } else {
  381. document.body.addEventListener("keydown", function(e){
  382. if(Ext.isFF5){//firefox不支持window.event
  383. e = e || window.event;
  384. }
  385. if(e.altKey && e.ctrlKey && e.keyCode == 83){
  386. me.FormUtil.onAdd('form' + caller, 'Form配置维护(' + caller + ')', "jsps/ma/multiform.jsp?formCondition=fo_idIS" + me.fo_id +
  387. "&gridCondition=fd_foidIS" + me.fo_id + "&whoami=" + caller);
  388. }
  389. });
  390. }
  391. },
  392. beforeQuery: function(call, cond) {
  393. Ext.Ajax.request({
  394. url: basePath + 'common/form/beforeQuery.action',
  395. params: {
  396. caller: call,
  397. condition: cond
  398. },
  399. async: false,
  400. callback: function(opt, s, r) {
  401. var rs = Ext.decode(r.responseText);
  402. if(rs.exceptionInfo) {
  403. showError(rs.exceptionInfo);
  404. }
  405. }
  406. });
  407. }
  408. });