PowerTreeGrid.js 10 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377
  1. /**
  2. * ERP项目gridpanel样式7:power(权限设置)tree
  3. */
  4. Ext.define('erp.view.core.grid.PowerTreeGrid',{
  5. extend: 'Ext.tree.Panel',
  6. alias: 'widget.erpPowerTreeGrid',
  7. region: 'south',
  8. layout : 'fit',
  9. id: 'treegrid',
  10. emptyText : $I18N.common.grid.emptyText,
  11. useArrows: true,
  12. rootVisible: false,
  13. singleExpand: true,
  14. saveNodes: [],
  15. updateNodes: [],
  16. deleteNodes: [],
  17. store: Ext.create('Ext.data.TreeStore', {
  18. fields: fields,
  19. root : {
  20. text: 'root',
  21. id: 'root',
  22. expanded: true
  23. }
  24. }),
  25. columns: columns,
  26. plugins: Ext.create('Ext.grid.plugin.CellEditing', {
  27. clicksToEdit: 1
  28. }),
  29. tbar: [{
  30. iconCls: 'tree-add',
  31. cls: 'x-btn-gray-1',
  32. text: $I18N.common.button.erpAddButton,
  33. handler: function(){
  34. var treegrid = Ext.getCmp('treegrid');
  35. var items = treegrid.selModel.selected.items;
  36. if(items.length > 0 && items[0].isLeaf() == true){
  37. if(items[0].data['po_id'] == null || items[0].data['po_id'] == ''){
  38. warnMsg('如果在该节点下添加子节点,需先保存该节点,是否保存?', function(btn){
  39. if(btn == 'yes'){
  40. if(items[0].data['po_powername'] == null || items[0].data['po_powername'] == ''){
  41. showError('请先描述该节点权限名称');
  42. return;
  43. } else {
  44. items[0].data['po_isleaf'] = 'F';
  45. treegrid.saveNodes.push(items[0]);
  46. treegrid.saveNode();
  47. }
  48. } else if(btn == 'no'){
  49. return;
  50. }
  51. });
  52. } else {
  53. items[0].data['leaf'] = false;
  54. items[0].data['cls'] = 'x-tree-cls-parent';
  55. items[0].data['po_isleaf'] = 'F';
  56. items[0].dirty = true;
  57. var o = {
  58. po_parentid: items[0].data['po_id'],
  59. po_isleaf: 'T',
  60. cls: "x-tree-cls-node",
  61. parentId: items[0].data['po_id'],
  62. leaf: true,
  63. allowDrag: true
  64. };
  65. items[0].appendChild(o);
  66. items[0].expand(true);
  67. }
  68. } else {
  69. var record = treegrid.getExpandItem();
  70. if(record){
  71. var o = {
  72. po_parentid: record.data['po_id'],
  73. po_isleaf: 'T',
  74. cls: "x-tree-cls-node",
  75. parentId: record.data['po_id'],
  76. leaf: true,
  77. allowDrag: true
  78. };
  79. record.appendChild(o);
  80. }
  81. }
  82. }
  83. },'-',{
  84. iconCls: 'tree-delete',
  85. cls: 'x-btn-gray-1',
  86. text: $I18N.common.button.erpDeleteButton,
  87. handler: function(){
  88. var treegrid = Ext.getCmp('treegrid');
  89. var items = treegrid.selModel.selected.items;
  90. if(items.length > 0){
  91. if(items[0].isLeaf() == true){
  92. if(items[0].data['po_id'] != null && items[0].data['po_id'] != ''){
  93. warnMsg('确定删除节点权限[' + items[0].data['po_powername'] + "]?", function(btn){
  94. if(btn == 'yes'){
  95. treegrid.deleteNode(items[0]);
  96. } else if(btn == 'no'){
  97. return;
  98. }
  99. });
  100. } else {
  101. items[0].remove(true);
  102. }
  103. } else {
  104. if(items[0].data['po_id'] != null || items[0].data['po_id'] != ''){
  105. warnMsg('确定删除节点[' + items[0].data['po_powername'] + ']及其子节点下所有权限?', function(btn){
  106. if(btn == 'yes'){
  107. treegrid.deleteNode(items[0]);
  108. } else if(btn == 'no'){
  109. return;
  110. }
  111. });
  112. } else {
  113. items[0].remove(true);
  114. }
  115. }
  116. } else {
  117. var record = treegrid.getExpandItem();
  118. if(record){
  119. if(record.childNodes.length == 0){
  120. if(record.data['po_id'] != null && record.data['po_id'] != ''){
  121. warnMsg('确定删除节点[' + record.data['po_powername'] + ']?', function(btn){
  122. if(btn == 'yes'){
  123. treegrid.deleteNode(record);
  124. } else if(btn == 'no'){
  125. return;
  126. }
  127. });
  128. } else {
  129. record.remove(true);
  130. }
  131. }
  132. }
  133. }
  134. }
  135. },'-',{
  136. iconCls: 'tree-save',
  137. cls: 'x-btn-gray-1',
  138. text: $I18N.common.button.erpSaveButton,
  139. handler: function(){
  140. var treegrid = Ext.getCmp('treegrid'),
  141. nodes = treegrid.store.tree.root.childNodes;
  142. treegrid.saveNodes = [];
  143. Ext.each(nodes, function(){
  144. treegrid.checkChild(this);
  145. });
  146. treegrid.saveNode();
  147. }
  148. },'-',{
  149. xtype: 'erpDistributeButton',
  150. disabled: true
  151. }],
  152. bodyStyle:'background-color:#f1f1f1;',
  153. initComponent : function(){
  154. Ext.override(Ext.data.AbstractStore,{
  155. indexOf: Ext.emptyFn
  156. });
  157. this.getTreeGridNode(0);
  158. this.callParent(arguments);
  159. },
  160. listeners: {//滚动条有时候没反应,添加此监听器
  161. scrollershow: function(scroller) {
  162. if (scroller && scroller.scrollEl) {
  163. scroller.clearManagedListeners();
  164. scroller.mon(scroller.scrollEl, 'scroll', scroller.onElScroll, scroller);
  165. }
  166. }
  167. },
  168. getTreeGridNode: function(id){
  169. var me = this;
  170. var activeTab = me.getActiveTab();
  171. activeTab.setLoading(true);
  172. Ext.Ajax.request({//拿到tree数据
  173. url : basePath + 'common/singleGridPanel.action',
  174. async: false,
  175. params: {
  176. caller: caller,
  177. condition: "po_parentid=" + id
  178. },
  179. callback : function(options,success,response){
  180. var res = new Ext.decode(response.responseText);
  181. activeTab.setLoading(false);
  182. if(res.data){
  183. var tree = Ext.decode(res.data.replace(/,}/g, '}').replace(/,]/g, ']'));
  184. Ext.each(tree, function(d){
  185. d.parentId = d.po_parentid;
  186. d.cls = 'x-tree-cls-node';
  187. d.leaf = d.po_isleaf == 'T';
  188. if(!d.leaf){
  189. d.cls = 'x-tree-cls-root';
  190. }
  191. });
  192. me.store.setRootNode({
  193. text: 'root',
  194. id: 'root',
  195. expanded: true,
  196. children: tree
  197. });
  198. Ext.each(me.store.tree.root.childNodes, function(){
  199. this.dirty = false;
  200. });
  201. } else if(res.exceptionInfo){
  202. showError(res.exceptionInfo);
  203. }
  204. }
  205. });
  206. },
  207. checkChild: function(record){
  208. var me = this;
  209. if(!record.data['leaf']){
  210. if(record.childNodes.length > 0){
  211. if(record.data['po_id'] == null || record.data['po_id'] == ''){
  212. warnMsg('如果在节点' + record.data['po_powername'] + '下添加子节点,需先保存该节点,是否保存?', function(btn){
  213. if(btn == 'yes'){
  214. if(items[0].data['po_powername'] == null || items[0].data['po_powername'] == ''){
  215. showError('请先描述该节点');
  216. return;
  217. } else {
  218. me.saveNodes.push(items[0]);
  219. me.saveNode();
  220. }
  221. } else if(btn == 'no'){
  222. return;
  223. }
  224. });
  225. }
  226. Ext.each(record.childNodes, function(){
  227. me.checkChild(this);
  228. });
  229. }
  230. } else {
  231. if(record.dirty){
  232. if(record.data['po_id'] == null || record.data['po_id'] == ''){
  233. me.saveNodes.push(record);
  234. } else {
  235. me.updateNodes.push(record);
  236. }
  237. }
  238. }
  239. },
  240. saveNode: function(){
  241. var me = this;
  242. me.getUpdateNodes();
  243. var save = new Array();
  244. var update = new Array();
  245. var index = 0;
  246. Ext.each(me.saveNodes, function(){
  247. if(this.data.po_powername != null && this.data.po_powername != ''){
  248. var o = {
  249. po_id: this.data.po_id,
  250. po_powername: this.data.po_powername,
  251. po_parentid: this.data.po_parentid,
  252. po_isleaf: this.data.po_isleaf,
  253. po_code: this.data.po_code
  254. };
  255. save[index++] = Ext.JSON.encode(o);
  256. }
  257. });
  258. index = 0;
  259. Ext.each(me.updateNodes, function(){
  260. if(this.data.po_powername != null && this.data.po_powername != ''){
  261. var o = {
  262. po_id: this.data.po_id,
  263. po_powername: this.data.po_powername,
  264. po_parentid: this.data.po_parentid,
  265. po_isleaf: this.data.po_isleaf,
  266. po_code: this.data.po_code
  267. };
  268. update[index++] = Ext.JSON.encode(o);
  269. }
  270. });
  271. if(save.length > 0 || update.length > 0){
  272. var activeTab = me.getActiveTab();
  273. activeTab.setLoading(true);
  274. Ext.Ajax.request({
  275. url : basePath + 'ma/savePower.action',
  276. params: {
  277. save: unescape(save.toString().replace(/\\/g,"%")),
  278. update: unescape(update.toString().replace(/\\/g,"%"))
  279. },
  280. callback : function(options,success,response){
  281. var res = new Ext.decode(response.responseText);
  282. activeTab.setLoading(false);
  283. if(res.success){
  284. me.saveNodes = [];
  285. me.updateNodes = [];
  286. me.getTreeGridNode(0);
  287. } else if(res.exceptionInfo){
  288. showError(res.exceptionInfo);
  289. }
  290. }
  291. });
  292. }
  293. },
  294. getExpandItem: function(root){
  295. var me = this;
  296. if(!root){
  297. root = this.store.tree.root;
  298. }
  299. var node = null;
  300. if(root.childNodes.length > 0){
  301. Ext.each(root.childNodes, function(){
  302. if(this.isExpanded()){
  303. node = this;
  304. if(this.childNodes.length > 0){
  305. var n = me.getExpandItem(this);
  306. node = n == null ? node : n;
  307. }
  308. }
  309. });
  310. }
  311. return node;
  312. },
  313. deleteNode: function(record){
  314. var me = this;
  315. if(record){
  316. var activeTab = me.getActiveTab();
  317. activeTab.setLoading(true);
  318. Ext.Ajax.request({
  319. url : basePath + 'ma/deletePower.action',
  320. params: {
  321. id: Number(record.data['po_id'])
  322. },
  323. callback : function(options,success,response){
  324. var res = new Ext.decode(response.responseText);
  325. activeTab.setLoading(false);
  326. if(res.success){
  327. record.remove(true);
  328. } else if(res.exceptionInfo){
  329. showError(res.exceptionInfo);
  330. }
  331. }
  332. });
  333. }
  334. },
  335. getUpdateNodes: function(root){
  336. var me = this;
  337. if(!root){
  338. root = this.store.tree.root;
  339. me.updateNodes = [];
  340. }
  341. if(root.childNodes.length > 0){
  342. Ext.each(root.childNodes, function(){
  343. if(this.dirty){
  344. if(this.data['po_id'] != null && this.data['po_id'] != ''){
  345. me.updateNodes.push(this);
  346. }
  347. }
  348. if(this.data['leaf'] == false && this.childNodes.length > 0){
  349. me.getUpdateNodes(this);
  350. }
  351. });
  352. } else {
  353. if(root.dirty){
  354. if(root.data['po_id'] != null && root.data['po_id'] != ''){
  355. me.updateNodes.push(root);
  356. }
  357. }
  358. }
  359. },
  360. getActiveTab: function(){
  361. var tab = null;
  362. if(Ext.getCmp("content-panel")){
  363. tab = Ext.getCmp("content-panel").getActiveTab();
  364. }
  365. if(!tab){
  366. var win = parent.Ext.ComponentQuery.query('window');
  367. if(win.length > 0){
  368. tab = win[win.length-1];
  369. }
  370. }
  371. if(!tab && parent.Ext.getCmp("content-panel"))
  372. tab = parent.Ext.getCmp("content-panel").getActiveTab();
  373. if(!tab && parent.parent.Ext.getCmp("content-panel"))
  374. tab = parent.parent.Ext.getCmp("content-panel").getActiveTab();
  375. return tab;
  376. }
  377. });