DefaultCategory.js 3.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119
  1. Ext.QuickTips.init();
  2. Ext.define('erp.controller.co.cost.DefaultCategory', {
  3. extend: 'Ext.app.Controller',
  4. FormUtil: Ext.create('erp.util.FormUtil'),
  5. GridUtil: Ext.create('erp.util.GridUtil'),
  6. BaseUtil: Ext.create('erp.util.BaseUtil'),
  7. views:[
  8. 'core.grid.Panel4','core.toolbar.Toolbar3','co.cost.DefaultCategory',
  9. 'core.button.Save',
  10. 'core.trigger.DbfindTrigger','core.trigger.HrOrgTreeDbfindTrigger'
  11. ],
  12. init:function(){
  13. var me = this;
  14. me.gridLastSelected = null;
  15. this.control({
  16. 'erpGridPanel4': {
  17. itemclick: this.onGridItemClick
  18. },
  19. 'erpSaveButton': {
  20. click: function(btn){
  21. this.beforeUpdate();
  22. }
  23. }
  24. });
  25. },
  26. onGridItemClick: function(selModel, record){//grid行选择
  27. /*this.gridLastSelected = record;
  28. var grid = Ext.getCmp('grid');
  29. if(record.data[grid.necessaryField] == null || record.data[grid.necessaryField] == ''){
  30. this.gridLastSelected.findable = true;//空数据可以在输入完code,并移开光标后,自动调出该条数据
  31. } else {
  32. this.gridLastSelected.findable = false;
  33. }
  34. this.GridUtil.onGridItemClick(selModel, record);*/
  35. },
  36. getForm: function(btn){
  37. return btn.ownerCt.ownerCt;
  38. },
  39. beforeSaveARBill: function(){
  40. this.FormUtil.beforeSave(this);
  41. },
  42. beforeUpdate: function(){
  43. Array.prototype.contains = function(obj) {
  44. var i = this.length;
  45. while (i--) {
  46. if (this[i] === obj) {
  47. return true;
  48. }
  49. }
  50. return false;
  51. };
  52. var grid = Ext.getCmp('grid');
  53. var items = grid.store.data.items;
  54. var rowNo = [];
  55. Ext.each(items,function(item,index){
  56. Ext.each(grid.columns, function(c){
  57. if(item.data[c.dataIndex]!=item.raw[c.dataIndex])
  58. {
  59. if(!rowNo.contains(index+1)){
  60. rowNo.push(index+1);
  61. }
  62. }
  63. });
  64. });
  65. if(rowNo.length==0){
  66. Ext.Msg.alert("你未对数据做任何修改!");
  67. return;
  68. } else {
  69. var result = confirm("第"+rowNo.toString()+"行已经修改,确定更新?");
  70. if(result){
  71. var index = 0;
  72. var jsonGridData = new Array();
  73. var s = grid.getStore().data.items;
  74. for(var i=0;i<s.length;i++){//将grid里面各行的数据获取并拼成jsonGridData
  75. var data = s[i].data;
  76. Ext.each(grid.columns, function(c){
  77. if(c.xtype == 'datecolumn'){
  78. if(Ext.isDate(data[c.dataIndex])){
  79. data[c.dataIndex] = Ext.Date.toString(data[c.dataIndex]);//在这里把GMT日期转化成Y-m-d格式日期
  80. } else {
  81. data[c.dataIndex] = '1970-01-01';//如果用户没输入日期,或输入有误,就给个默认日期,
  82. //或干脆return;并且提示一下用户
  83. }
  84. } else if(c.xtype == 'numbercolumn'){//赋个默认值0吧,不然不好保存
  85. if(data[c.dataIndex] == null || data[c.dataIndex] == ''){
  86. data[c.dataIndex] = '0';
  87. }
  88. }
  89. });
  90. jsonGridData[index++] = Ext.JSON.encode(data);
  91. }
  92. this.update(jsonGridData.toString());
  93. }
  94. else return;
  95. }
  96. },
  97. update:function(param){
  98. Ext.Ajax.request({
  99. url: basePath+'fa/ars/updateDefaultCategory.action',
  100. params:{
  101. param:param
  102. },
  103. success: function(response){
  104. var text = response.responseText;
  105. result = Ext.decode(text);
  106. if(result.success){
  107. Ext.Msg.alert("提示","操作成功!");// 尚未国际化,以后订正。
  108. }
  109. }
  110. });
  111. }
  112. });