KindController.js 3.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111
  1. /**
  2. * Created by zhouy on 2018/10/18.
  3. */
  4. Ext.define('saas.view.document.kind.KindController', {
  5. extend: 'Ext.app.ViewController',
  6. alias: 'controller.document-kind',
  7. loadDefualt:function(grid){
  8. var me=this,view = me.getView(),vm = me.getViewModel(),defaultKind;
  9. if(view.defaultType!=''){
  10. defaultKind = view.defaultType //其他单表界面
  11. vm.setData({'dataKind':{'value':defaultKind}});
  12. }else{
  13. defaultKind=vm.getData()['dataKind'].value //类别合并界面
  14. }
  15. var etc = view.etc[defaultKind];
  16. var store = vm.getStore(defaultKind);
  17. store.load();
  18. grid.reconfigure(store, me.insertActionColumn(etc.columns));
  19. },
  20. onKindToggle:function(container, button, pressed){
  21. var me = this,
  22. name = button.value,
  23. view = me.getView(),
  24. grid = me.lookup('document-kind-Grid'),
  25. vm = me.getViewModel(),
  26. etc = view.etc[name],
  27. store=vm.getStore(name);
  28. var columns=me.insertActionColumn(etc.columns);
  29. grid.reconfigure(store, columns);
  30. if(store) store.reload();
  31. vm.set('title', button.typeText);
  32. },
  33. onAdd:function(){
  34. var me=this,
  35. dataKind=me.getViewModel().getData()['dataKind'].value;
  36. me.createDialog(dataKind);
  37. },
  38. onRefresh:function(){
  39. var me = this;
  40. me.view.items.items[0].store.load();
  41. },
  42. insertActionColumn:function(columns){
  43. var me=this;
  44. if(columns.length>0 && columns[0].xtype!='actioncolumn'){
  45. return Ext.Array.insert(columns,0,[{
  46. xtype:'actioncolumn',
  47. text:'操作',
  48. items: [{
  49. tooltip: '编辑',
  50. iconCls: 'x-fa fa-pencil fa-fw',
  51. handler: me.onEdit,
  52. scope:this
  53. },{
  54. text:'删除',
  55. iconCls:'x-fa fa-trash-o fa-fw',
  56. tooltip: '删除',
  57. handler: me.onDelete,
  58. scope:this
  59. }]
  60. }]);
  61. }
  62. return columns;
  63. },
  64. onEdit:function(grid,row,col){
  65. var me=this,
  66. dataKind=me.getViewModel().getData()['dataKind'].value;
  67. rec = grid.getStore().getAt(row);
  68. this.createDialog(dataKind,rec);
  69. },
  70. onDelete:function(grid,row,col){
  71. var me=this,
  72. view=me.getView(),
  73. dataKind=me.getViewModel().getData()['dataKind'].value;
  74. rec = grid.getStore().getAt(row);
  75. var keyV=rec.get(view.etc[dataKind].keyField);
  76. //删除接口
  77. saas.util.BaseUtil.request({
  78. url: view.etc[dataKind].delUrl+'/'+keyV,
  79. method: 'POST'
  80. })
  81. .then(function(localJson) {
  82. if(localJson.success){
  83. saas.util.BaseUtil.showToast('删除成功');
  84. grid.store.load();
  85. }
  86. })
  87. .catch(function(res) {
  88. console.error(res);
  89. saas.util.BaseUtil.showToast('删除失败: ' + res.message);
  90. });
  91. },
  92. createDialog: function(dataKind,record) {
  93. var view = this.getView();var me=this;
  94. this.isEdit = !!record;
  95. this.dialog = view.add({
  96. autoScroll:true,
  97. xtype: 'document-kind-childwin',
  98. bind: {
  99. title: record ? '修改{title}' : '新增{title}'
  100. },
  101. dataKind:dataKind,
  102. belong:this.getView().etc[dataKind],
  103. _parent:this.getView(),
  104. record:record,
  105. session: true
  106. });
  107. this.dialog.show();
  108. }
  109. });