SaleFeatureChange.js 9.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245
  1. Ext.QuickTips.init();
  2. Ext.define('erp.controller.scm.sale.SaleFeatureChange', {
  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.form.Panel','scm.sale.SaleFeatureChange','core.grid.Panel2','core.toolbar.Toolbar',
  9. 'core.button.Save','core.button.Add','core.button.Submit','core.button.Print','core.button.Upload','core.button.ResAudit',
  10. 'core.button.Audit','core.button.Close','core.button.Delete','core.button.Update','core.button.DeleteDetail',
  11. 'core.button.ResSubmit','core.form.FileField',
  12. 'core.trigger.DbfindTrigger','core.trigger.TextAreaTrigger','core.form.YnField'
  13. ],
  14. init:function(){
  15. var me = this;
  16. this.control({
  17. 'erpGridPanel2': {
  18. itemclick: this.onGridItemClick
  19. },
  20. 'erpSaveButton': {
  21. click: function(btn){
  22. var form = me.getForm(btn);
  23. var grid = Ext.getCmp('grid'), items = grid.store.data.items, bool = true;
  24. if(Ext.getCmp(form.codeField).value == null || Ext.getCmp(form.codeField).value == ''){
  25. me.BaseUtil.getRandomNumber();//自动添加编号
  26. }
  27. Ext.each(items,function(item) {
  28. if (item.dirty && item.data[grid.necessaryField] != null && item.data[grid.necessaryField] != "") {
  29. if (item.data['scd_newqty'] > item.data['scd_oldqty']) {
  30. bool = false;
  31. showError('明细表第' + item.data['scd_detno'] + '行的新数量大于原数量');
  32. return;
  33. }
  34. if(!Ext.isEmpty(item.data['scd_newdelivery'])){
  35. if (Ext.Date.format(item.data['scd_newdelivery'],'Y-m-d') < Ext.Date.format(new Date(),'Y-m-d')) {
  36. bool = false;
  37. showError('明细表第' + item.data['scd_detno'] + '行的新交货日期小于当前日期');
  38. return;
  39. }
  40. }
  41. if(!Ext.isEmpty(item.data['scd_newenddate'])){
  42. if (Ext.Date.format(item.data['scd_newenddate'],'Y-m-d') < Ext.Date.format(new Date(),'Y-m-d')) {
  43. bool = false;
  44. showError('明细表第' + item.data['scd_detno'] + '行的新截止日期小于当前日期');
  45. return;
  46. }
  47. if(!Ext.isEmpty(item.data['scd_newdelivery'])){
  48. if (Ext.Date.format(item.data['scd_newenddate'],'Y-m-d') < Ext.Date.format(item.data['scd_newdelivery'],'Y-m-d')) {
  49. bool = false;
  50. showError('明细表第' + item.data['scd_detno'] + '行的新截止日期小于新截止日期');
  51. return;
  52. }
  53. }
  54. }
  55. }
  56. });
  57. if(bool){
  58. this.FormUtil.beforeSave(this);
  59. }
  60. }
  61. },
  62. 'erpDeleteButton' : {
  63. click: function(btn){
  64. me.FormUtil.onDelete(Ext.getCmp('sfc_id').value);
  65. }
  66. },
  67. 'erpUpdateButton': {
  68. click: function(btn){
  69. var grid = Ext.getCmp('grid'), items = grid.store.data.items, bool = true;
  70. Ext.each(items,function(item) {
  71. if (item.dirty && item.data[grid.necessaryField] != null && item.data[grid.necessaryField] != "") {
  72. if (item.data['scd_newqty'] > item.data['scd_oldqty']) {
  73. bool = false;
  74. showError('明细表第' + item.data['scd_detno'] + '行的新数量大于原数量');
  75. return;
  76. }
  77. if(!Ext.isEmpty(item.data['scd_newdelivery'])){
  78. if (Ext.Date.format(item.data['scd_newdelivery'],'Y-m-d') < Ext.Date.format(new Date(),'Y-m-d')) {
  79. bool = false;
  80. showError('明细表第' + item.data['scd_detno'] + '行的新交货日期小于当前日期');
  81. return;
  82. }
  83. }
  84. if(!Ext.isEmpty(item.data['scd_newenddate'])){
  85. if (Ext.Date.format(item.data['scd_newenddate'],'Y-m-d') < Ext.Date.format(new Date(),'Y-m-d')) {
  86. bool = false;
  87. showError('明细表第' + item.data['scd_detno'] + '行的新截止日期小于当前日期');
  88. return;
  89. }
  90. if(!Ext.isEmpty(item.data['scd_newdelivery'])){
  91. if (Ext.Date.format(item.data['scd_newenddate'],'Y-m-d') < Ext.Date.format(item.data['scd_newdelivery'],'Y-m-d')) {
  92. bool = false;
  93. showError('明细表第' + item.data['scd_detno'] + '行的新截止日期小于新截止日期');
  94. return;
  95. }
  96. }
  97. }
  98. }
  99. });
  100. if(bool){
  101. this.FormUtil.onUpdate(this);
  102. }
  103. }
  104. },
  105. 'erpAddButton': {
  106. click: function(){
  107. me.FormUtil.onAdd('addSaleFeatureChange', '新增销售特征值变更单', 'jsps/scm/sale/saleFeatureChange.jsp?whoami=' + caller);
  108. }
  109. },
  110. 'erpCloseButton': {
  111. click: function(btn){
  112. me.FormUtil.beforeClose(me);
  113. }
  114. },
  115. 'erpSubmitButton': {
  116. afterrender: function(btn){
  117. var status = Ext.getCmp('sfc_statuscode');
  118. if(status && status.value != 'ENTERING'){
  119. btn.hide();
  120. }
  121. },
  122. click: function(btn){
  123. var grid = Ext.getCmp('grid'), items = grid.store.data.items, bool = true;
  124. Ext.each(items,function(item) {
  125. if (item.dirty && item.data[grid.necessaryField] != null && item.data[grid.necessaryField] != "") {
  126. if (item.data['scd_newqty'] > item.data['scd_oldqty']) {
  127. bool = false;
  128. showError('明细表第' + item.data['scd_detno'] + '行的新数量大于原数量');
  129. return;
  130. }
  131. if(!Ext.isEmpty(item.data['scd_newdelivery'])){
  132. if (Ext.Date.format(item.data['scd_newdelivery'],'Y-m-d') < Ext.Date.format(new Date(),'Y-m-d')) {
  133. bool = false;
  134. showError('明细表第' + item.data['scd_detno'] + '行的新交货日期小于当前日期');
  135. return;
  136. }
  137. }
  138. if(!Ext.isEmpty(item.data['scd_newenddate'])){
  139. if (Ext.Date.format(item.data['scd_newenddate'],'Y-m-d') < Ext.Date.format(new Date(),'Y-m-d')) {
  140. bool = false;
  141. showError('明细表第' + item.data['scd_detno'] + '行的新截止日期小于当前日期');
  142. return;
  143. }
  144. if(!Ext.isEmpty(item.data['scd_newdelivery'])){
  145. if (Ext.Date.format(item.data['scd_newenddate'],'Y-m-d') < Ext.Date.format(item.data['scd_newdelivery'],'Y-m-d')) {
  146. bool = false;
  147. showError('明细表第' + item.data['scd_detno'] + '行的新截止日期小于新截止日期');
  148. return;
  149. }
  150. }
  151. }
  152. }
  153. });
  154. if(bool){
  155. me.FormUtil.onSubmit(Ext.getCmp('sfc_id').value);
  156. }
  157. }
  158. },
  159. 'erpResSubmitButton': {
  160. afterrender: function(btn){
  161. var status = Ext.getCmp('sfc_statuscode');
  162. if(status && status.value != 'COMMITED'){
  163. btn.hide();
  164. }
  165. },
  166. click: function(btn){
  167. me.FormUtil.onResSubmit(Ext.getCmp('sfc_id').value);
  168. }
  169. },
  170. 'erpAuditButton': {
  171. afterrender: function(btn){
  172. var status = Ext.getCmp('sfc_statuscode');
  173. if(status && status.value != 'COMMITED'){
  174. btn.hide();
  175. }
  176. },
  177. click: function(btn){
  178. me.FormUtil.onAudit(Ext.getCmp('sfc_id').value);
  179. }
  180. },
  181. 'erpResAuditButton': {
  182. afterrender: function(btn){
  183. var status = Ext.getCmp('sfc_statuscode');
  184. if(status && status.value != 'AUDITED'){
  185. btn.hide();
  186. }
  187. },
  188. click: function(btn){
  189. me.FormUtil.onResAudit(Ext.getCmp('sfc_id').value);
  190. }
  191. },
  192. 'erpPrintButton': {
  193. click:function(btn){
  194. var reportName="SaleFeatureChange";
  195. var condition='{SaleFeatureChange.sfc_id}='+Ext.getCmp('sfc_id').value+'';
  196. var id=Ext.getCmp('sfc_id').value;
  197. me.FormUtil.onwindowsPrint(id,reportName,condition);
  198. }
  199. },
  200. 'dbfindtrigger[name=sfcd_orderdetno]': {
  201. focus: function(t){
  202. t.setHideTrigger(false);
  203. t.setReadOnly(false);
  204. var record = Ext.getCmp('grid').selModel.lastSelected;
  205. var code = record.data['sfcd_ordercode'];
  206. var grid = Ext.getCmp('grid');
  207. if(code == null || code == ''){
  208. showError("请先选择订单号!");
  209. t.setHideTrigger(true);
  210. t.setReadOnly(true);
  211. } else {
  212. t.dbBaseCondition = "sa_code='" + code + "'";
  213. }
  214. var cond ="(sa_code='"+code+"' ";
  215. var arr = new Array();
  216. Ext.each(grid.store.data.items, function(item){
  217. if(item.data['sfcd_ordercode'] != null && item.data['sfcd_ordercode'] != ''
  218. && item.data['sfcd_orderdetno'] != null && item.data['sfcd_orderdetno'] !=''){
  219. if(item.data['sfcd_ordercode'] ==code){
  220. arr.push("sd_detno<>"+item.data['sfcd_orderdetno']);
  221. }
  222. }
  223. });
  224. if(arr.length > 0){
  225. cond += ' AND ' + arr.join(' and ');
  226. }
  227. t.dbBaseCondition = cond + ") ";
  228. }
  229. /*aftertrigger:function(){
  230. var grid = Ext.getCmp('grid');
  231. var datas = new Array();
  232. Ext.each(grid.store.data.items, function(item){
  233. datas.push();
  234. });
  235. }*/
  236. }
  237. });
  238. },
  239. onGridItemClick: function(selModel, record){//grid行选择
  240. this.GridUtil.onGridItemClick(selModel, record);
  241. },
  242. getForm: function(btn){
  243. return btn.ownerCt.ownerCt;
  244. }
  245. });