Pman.Tab.AdminContactsGroupRight.bjs
[Pman.Admin] / Pman.Tab.AdminContactsGroupRight.js
index dd68e25..7fe993a 100644 (file)
@@ -57,7 +57,8 @@ Pman.Tab.AdminContactsGroupRight = new Roo.XComponent({
                     },
                     cellclick : function (_self, rowIndex, columnIndex, e)
                     {
-                    
+                            _this.dataUpdate = typeof(_this.dataUpdate) =='undefined' ?  {} : _this.dataUpdate;
+                            
                             var di = this.colModel.getDataIndex(columnIndex);
                             var i = di.split('_').shift();
                             var k = di.split('_').pop();
@@ -72,7 +73,10 @@ Pman.Tab.AdminContactsGroupRight = new Roo.XComponent({
                                 });
                             } 
                             rec.set(i+'_'+k, rec.data[i+'_'+k] ? 0 : 1);
+                            //rec.data.accessmask = rec.data.accessmask + rec
+                            //Roo.log(rec);
                             _this.dataUpdate[rec.data.id] = rec.data.accessmask;
+                    
                             //rec.commit();
                              
                             
@@ -90,7 +94,7 @@ Pman.Tab.AdminContactsGroupRight = new Roo.XComponent({
                             if (!o.params) {
                                 o.params = {}
                             }
-                            var s = Pman.Tab.Groups.grid.getSelectionModel().getSelections();
+                            var s = Pman.Tab.AdminContactsGroup.grid.getSelectionModel().getSelections();
                             if (!s.length) {
                                 o.params.group_id = -1;
                             } else {
@@ -135,11 +139,24 @@ Pman.Tab.AdminContactsGroupRight = new Roo.XComponent({
                         },
                         load : function (_self, records, options)
                         {
+                            _this.dataUpdate = {};
+                            var full = 'ADEPS'.split('');
+                            
                             Roo.each(records, function(e){
+                                _this.dataUpdate[e.id] = e.data.accessmask;
+                            
                                 var k = e.data.accessmask.split('');
-                                Roo.each(k, function(ee){
-                                    e.set('accessmask_'+ee, 1);
+                                var rm = e.data.FullMask.split('');
+                                
+                                Roo.each(full, function(ee){
+                                    if (rm.indexOf(ee) < 0) {
+                                        e.set('accessmask_'+ee, -1);          
+                                        return;
+                                    }
+                                    
+                                    e.set('accessmask_'+ee, (k.indexOf(ee) < 0) ? 0 : 1);
                                 });
+                                
                                 if(e.data.accessmask == e.data.FullMask){
                                     e.set('accessmask_AA', 1);
                                 }
@@ -214,10 +231,16 @@ Pman.Tab.AdminContactsGroupRight = new Roo.XComponent({
                                 click : function (_self, e)
                                 {
                                     
+                                    var params = { group_id : 1 };
+                                    for(var i in _this.dataUpdate) {
+                                        params['dataUpdate[' + i + ']'] = _this.dataUpdate[i];
+                                    }
+                                    //Roo.log(params);return;
+                                    
                                     new Pman.Request({
-                                        url : baseURL + '/Roo/GroupRights.php',
+                                        url : baseURL + '/Admin/GroupRights.php',
                                         method :'POST',
-                                        params : _this.dataUpdate,
+                                        params : params,
                                         success : function() {
                                             // do nothing
                                             
@@ -289,6 +312,9 @@ Pman.Tab.AdminContactsGroupRight = new Roo.XComponent({
                         header : 'Add',
                         width : 75,
                         renderer : function(v) {  
+                            if (v < 0) {
+                                return '';
+                            }
                             var state = v> 0 ?  '-checked' : '';
                         
                             return '<img class="x-grid-check-icon' + state + '" src="' + Roo.BLANK_IMAGE_URL + '"/>';
@@ -302,6 +328,9 @@ Pman.Tab.AdminContactsGroupRight = new Roo.XComponent({
                         header : 'Edit',
                         width : 75,
                         renderer : function(v) {  
+                           if (v < 0) {
+                                return '';
+                            }
                             var state = v> 0 ?  '-checked' : '';
                         
                             return '<img class="x-grid-check-icon' + state + '" src="' + Roo.BLANK_IMAGE_URL + '"/>';
@@ -315,6 +344,9 @@ Pman.Tab.AdminContactsGroupRight = new Roo.XComponent({
                         header : 'Delete',
                         width : 75,
                         renderer : function(v) {  
+                            if (v < 0) {
+                                return '';
+                            }
                             var state = v> 0 ?  '-checked' : '';
                         
                             return '<img class="x-grid-check-icon' + state + '" src="' + Roo.BLANK_IMAGE_URL + '"/>';
@@ -328,6 +360,10 @@ Pman.Tab.AdminContactsGroupRight = new Roo.XComponent({
                         header : 'List/View',
                         width : 75,
                         renderer : function(v) {  
+                            
+                            if (v < 0) {
+                                return '';
+                            }
                             var state = v> 0 ?  '-checked' : '';
                         
                             return '<img class="x-grid-check-icon' + state + '" src="' + Roo.BLANK_IMAGE_URL + '"/>';
@@ -342,6 +378,10 @@ Pman.Tab.AdminContactsGroupRight = new Roo.XComponent({
                         width : 75,
                         renderer : function(v,x,r) {  
                             
+                            
+                            if (v < 0) {
+                                return '';
+                            }
                             var state = v> 0 ?  '-checked' : '';
                         
                             return '<img class="x-grid-check-icon' + state + '" src="' + Roo.BLANK_IMAGE_URL + '"/>';