Controller.js 2.9 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283
  1. Ext.define('saas.view.core.tab.Controller', {
  2. extend: 'Ext.app.ViewController',
  3. alias: 'controller.core-tab-controller',
  4. init: function() {
  5. try {
  6. var me = this,
  7. tab = me.getView(),
  8. viewType = tab.viewType,
  9. _config = tab.index,
  10. viewConfig = tab.viewConfig;
  11. var view = {
  12. _config : viewConfig,
  13. xtype: viewType
  14. };
  15. Ext.apply(view, viewConfig);
  16. tab.add(view);
  17. }catch(e) {
  18. console.error(e);
  19. }
  20. },
  21. onTabActivate: function() {
  22. var component = this.getView();
  23. var tabView = component.down('container');
  24. if(tabView && typeof tabView.refresh == 'function') {
  25. tabView.refresh();
  26. }
  27. if(!component.resetCloseClick) {
  28. component.tab.onCloseClick = function() {
  29. var me = this,
  30. tabView = component.down('panel');
  31. if (me.fireEvent('beforeclose', me) !== false) {
  32. if (me.tabBar) {
  33. if(tabView.fireEvent('beforeclose', tabView) !== false && tabView.promiseCloseTab && typeof tabView.promiseCloseTab == 'function') {
  34. tabView.promiseCloseTab()
  35. .then(function(close) {
  36. console.log();
  37. if(close) {
  38. if (me.tabBar.closeTab(me) === false) {
  39. return;
  40. }
  41. }
  42. });
  43. }else {
  44. if (me.tabBar.closeTab(me) === false) {
  45. return;
  46. }
  47. }
  48. } else {
  49. if(tabView.fireEvent('beforeclose', tabView) !== false && tabView.promiseCloseTab && typeof tabView.promiseCloseTab == 'function') {
  50. tabView.promiseCloseTab()
  51. .then(function(close) {
  52. console.log();
  53. if(close) {
  54. if (me.tabBar.closeTab(me) === false) {
  55. return;
  56. }
  57. }
  58. });
  59. }else {
  60. me.fireClose();
  61. }
  62. }
  63. }
  64. }
  65. component.resetCloseClick = true;
  66. }
  67. tabView && tabView.fireEvent('onTabActivate', tabView);
  68. },
  69. onTabDeactivate: function(component) {
  70. var tabView = component.down('container');
  71. tabView && tabView.fireEvent('onTabDeactivate', tabView);
  72. }
  73. });