Author Topic: Edit/Delete button works after resize browser screen  (Read 5171 times)

Chaitanya21

  • Newbie
  • *
  • Posts: 17
    • View Profile
Edit/Delete button works after resize browser screen
« on: January 17, 2017, 07:47:38 pm »

   //var data = [{ "departmentId": 1, "departmentCode": "HR", "departmentName": "Human Resource" }];
   var data= ${departmentList};
   $(function () {
       //define common ajax object for addition, update and delete.
       
           
       var ajaxObj = {
           dataType: "JSON",
           beforeSend: function () {
               this.pqGrid("showLoading");
           },
           complete: function () {
               this.pqGrid("hideLoading");
           },
           error: function () {
               this.pqGrid("rollback");
           }
       };

       //to check whether any row is currently being edited.
       function isEditing($grid) {
           var rows = $grid.pqGrid("getRowsByClass", { cls: 'pq-row-edit' });
           if (rows.length > 0) {
               //focus on editor if any
               $grid.find(".pq-editor-focus").focus();
               return true;
           }
           return false;
       }
       //called by add button in toolbar.
       function addRow($grid) {
          $(".customMessage").text("");
           if (isEditing($grid)) {
               return false;
           }
           //append empty row in the first row.                           
           var rowData = { departmentId:"", departmentName: "", departmentName:"", status:true}; //empty row template
           $grid.pqGrid("addRow", { rowIndxPage: 0, rowData: rowData });

           var $tr = $grid.pqGrid("getRow", { rowIndxPage: 0 });
           if ($tr) {
               //simulate click on edit button.
               $tr.find("button.edit_btn").click();
           }
       }
       //called by delete button.
       function deleteRow(rowIndx, $grid) {
           $grid.pqGrid("addClass", { rowIndx: rowIndx, cls: 'pq-row-delete' });
           var rowData = $grid.pqGrid("getRowData", { rowIndx: rowIndx });
           var ans = window.confirm("Are you sure to delete row No " + (rowIndx + 1) + "?");

           if (ans) {
               $grid.pqGrid("deleteRow", { rowIndx: rowIndx, effect: true });

               var ProductID = $grid.pqGrid("getRecId", { rowIndx: rowIndx });

               $.ajax($.extend({}, ajaxObj, {
                   context: $grid,
                   url: "/pro/products/delete",
                   //url: "/pro/products.php?pq_delete=1",//for PHP
                   data: { ProductID: ProductID },
                   success: function () {
                       this.pqGrid("commit");
                       this.pqGrid("refreshDataAndView");
                   },
                   error: function () {
                       //debugger;
                       this.pqGrid("removeClass", { rowData: rowData, cls: 'pq-row-delete' });
                       this.pqGrid("rollback");
                   }
               }));
           }
           else {
               $grid.pqGrid("removeClass", { rowIndx: rowIndx, cls: 'pq-row-delete' });
           }
       }
       //called by edit button.
       function editRow(rowIndx, $grid) {

           $grid.pqGrid("addClass", { rowIndx: rowIndx, cls: 'pq-row-edit' });
           $grid.pqGrid("editFirstCellInRow", { rowIndx: rowIndx });

           //change edit button to update button and delete to cancel.
           var $tr = $grid.pqGrid("getRow", { rowIndx: rowIndx }),
               $btn = $tr.find("button.edit_btn");
           $btn.button("option", { label: "Update", "icons": { primary: "ui-icon-check"} })
               .unbind("click")
               .click(function (evt) {
                   evt.preventDefault();
                   return update(rowIndx, $grid);
               });
           $btn.next().button("option", { label: "Cancel", "icons": { primary: "ui-icon-cancel"} })
               .unbind("click")
               .click(function (evt) {
                   $grid.pqGrid("quitEditMode");
                   $grid.pqGrid("removeClass", { rowIndx: rowIndx, cls: 'pq-row-edit' });
                   $grid.pqGrid("refreshRow", { rowIndx: rowIndx });
                   $grid.pqGrid("rollback");
               });
       }
       //called by update button.
       function update(rowIndx, $grid) {
alert("update")
           if ($grid.pqGrid("saveEditCell") == false) {
               return false;
           }

           var isValid = $grid.pqGrid("isValid", { rowIndx: rowIndx }).valid;
           if (!isValid) {
               return false;
           }
           var isDirty = $grid.pqGrid("isDirty");
           if (isDirty) {
              var jsonToBeSend=new Object();
               var url,
                   rowData = $grid.pqGrid("getRowData", { rowIndx: rowIndx }),
                   recIndx = $grid.pqGrid("option", "dataModel.recIndx");

               $grid.pqGrid("removeClass", { rowIndx: rowIndx, cls: 'pq-row-edit' });

               jsonToBeSend["departmentName"] = rowData.departmentName;
               jsonToBeSend["departmentCode"] = rowData.departmentCode;
               jsonToBeSend["status"] = rowData.status;
               if (rowData[recIndx] == null) {
                   //url to add records.
                   
                   url = "/SpringMVCSecruityMavenApp/addDepartment";
                   //url = "/pro/products.php?pq_add=1";for PHP
               }
               else {
                  alert("Update")
                   //url to  update records.
                   url = "/pro/products/update";
                   //url = "/pro/products.php?pq_update=1";for PHP
               }
               $.ajax({
                  url: url,
                  type: 'POST',
                  dataType: 'json',
                  data: JSON.stringify(jsonToBeSend),
                  async: true,
                  beforeSend: function(xhr) {                 
                       xhr.setRequestHeader("Accept", "application/json");
                       xhr.setRequestHeader("Content-Type", "application/json");
                   },
                  success: function(data) {
                     $(".customMessage").text(data.message);
                      var recIndx = $grid.pqGrid("option", "dataModel.recIndx");
                     if (rowData[recIndx] == null) {
                        rowData.departmentId= data.departmentId;
                    }
                     $grid.pqGrid("removeClass", { rowIndx: rowIndx, cls: 'pq-row-edit' });
                     $grid.pqGrid("commit");

                  },
                  error:function(data) {
                     $(".customMessage").text(data.message);
                  }
                 
              });
               
               
           }
           else {
              
               $grid.pqGrid("quitEditMode");
               $grid.pqGrid("removeClass", { rowIndx: rowIndx, cls: 'pq-row-edit' });
               $grid.pqGrid("refreshRow", { rowIndx: rowIndx });
           }
       }
       //define the grid.
       var obj = {                       
           wrap: false,
           hwrap: false,
           resizable: true,
           columnBorders: false,
           sortable: false,
           numberCell: { show: false },
           track: true, //to turn on the track changes.
           flexHeight: true,
           toolbar: {
               items: [
                   { type: 'button', icon: 'ui-icon-plus', label: 'Add Department', listeners: [
                       { "click": function (evt, ui) {
                           var $grid = $(this).closest('.pq-grid');
                           addRow($grid);
                           //debugger;
                       }
                       }
                   ]
                   },
                   {
                       type: '</br><span style="color:red;font-weight:bold;font-size:20px" class="customMessage"></span>'
                   }
               ]
           },
           trackModel: { on: true },
           scrollModel: {
               autoFit: true
           },
           selectionModel: {
               //type: 'cell'
               type: 'none'
           },
           hoverMode: 'cell',
           editModel: {
               //onBlur: 'validate',
               saveKey: $.ui.keyCode.ENTER
           },
           title: "<b>Department Master</b>",

           colModel: [
                   { title: "Department Id", dataType: "integer", dataIndx: "departmentId", editable: false, width: 80 },
                   { title: "Department Code", width: 140, dataType: "string", align: "right", dataIndx: "departmentCode",
                       validations: [
                           { type: 'minLen', value: 1, msg: "Required." },
                           { type: 'maxLen', value: 20, msg: "length should be <= 20" }
                       ]
                   },
                   { title: "Department Name", width: 165, dataType: "string", dataIndx: "departmentName",
                       validations: [
                           { type: 'minLen', value: 1, msg: "Required" },
                           { type: 'maxLen', value: 40, msg: "length should be <= 40" }
                       ]
                   },
                   
                   { title: "Active/Inactive", width: 100, dataType: "bool", align: "center", dataIndx: "status",
                       editor: { type: "checkbox", style: "margin:3px 5px;" },
                       render: function (ui) {
                           if(ui.cellData == true) return "Active";
                           else return "Inactive";
                           
                       }
                   },
                   
                   { title: "", editable: false, minWidth: 165, sortable: false, render: function (ui) {
                       return "<button type='button' class='edit_btn'>Edit</button>\
                           <button type='button' class='delete_btn'>Delete</button>";
                   }
                   }
           ],
           dataModel: {
              dataType: "JSON",
              data: data,
               location: "local",
               sorting: "local",
               sortIndx: "departmentName",
               sortDir: "down"
           },
           pageModel: { type: "local" },
           cellBeforeSave: function (evt, ui) {
               var $grid = $(this);
               var isValid = $grid.pqGrid("isValid", ui);
               if (!isValid.valid) {
                   return false;
               }
           },
           //make rows editable selectively.
           editable: function (ui) {
               var $grid = $(this);
               var rowIndx = ui.rowIndx;
               if ($grid.pqGrid("hasClass", { rowIndx: rowIndx, cls: 'pq-row-edit' }) == true) {
                   return true;
               }
               else {
                   return false;
               }
           }
       };
       var $grid = $("#grid_editing").pqGrid(obj);
       
       //use refresh & refreshRow events to display jQueryUI buttons and bind events.
       $grid.on('pqgridrefresh pqgridrefreshrow', function () {
           //debugger;
           var $grid = $(this);

           //delete button
           $grid.find("button.delete_btn").button({ icons: { primary: 'ui-icon-close'} })
           .unbind("click")
           .bind("click", function (evt) {
               if (isEditing($grid)) {
                   return false;
               }
               var $tr = $(this).closest("tr"),
                   rowIndx = $grid.pqGrid("getRowIndx", { $tr: $tr }).rowIndx;
               deleteRow(rowIndx, $grid);
           });
           //edit button
           $grid.find("button.edit_btn").button({ icons: { primary: 'ui-icon-pencil'} })
           .unbind("click")
           .bind("click", function (evt) {
               if (isEditing($grid)) {
                   return false;
               }
               var $tr = $(this).closest("tr"),
                   rowIndx = $grid.pqGrid("getRowIndx", { $tr: $tr }).rowIndx;
               editRow(rowIndx, $grid);
               return false;
           });

           //rows which were in edit mode before refresh, put them in edit mode again.
           var rows = $grid.pqGrid("getRowsByClass", { cls: 'pq-row-edit' });
           if (rows.length > 0) {
               var rowIndx = rows[0].rowIndx;
               editRow(rowIndx, $grid);
           }
       });       
   });   
   

paramvir

  • Administrator
  • Hero Member
  • *****
  • Posts: 6310
    • View Profile
Re: Edit/Delete button works after resize browser screen
« Reply #1 on: January 17, 2017, 09:14:38 pm »
Please share a functional jsfiddle along with some description of the issue.

Chaitanya21

  • Newbie
  • *
  • Posts: 17
    • View Profile
Re: Edit/Delete button works after resize browser screen
« Reply #2 on: January 18, 2017, 07:09:56 pm »
http://jsfiddle.net/Dalvi1988/x796gy5h/2/

This grid is exactly same as "Row Editing".
My issue is my grid is not editable when loaded(Edit & delete button do not work. when i resize grid size then CSS apply to Edit and Delete button and grid get activate.

To solve this issue temporary i have added $("#grid_editing").pqGrid("refresh") at the end of javascript(line no 437 in jsfiddle).
Please solve this issue.


Also when i try to update any row, i m getting isDirty value "false" so that i could not make ajax call to update records.

By the i m very thankful for such worderful grid. i was looking this kind of grid since last 1 year.

paramvir

  • Administrator
  • Hero Member
  • *****
  • Posts: 6310
    • View Profile
Re: Edit/Delete button works after resize browser screen
« Reply #3 on: January 23, 2017, 07:00:26 am »
1. Event binding to refresh & refreshRow should be done before initialization of grid.

var $grid = $("#grid_editing");

$grid.on('pqgridrefresh pqgridrefreshrow', function() {
  ....
});

//And initialize at the end
$grid.pqGrid( obj );


2. Tracking ( see track option ) should be turned on and dataModel.recIndx ( primary key ) should be added.