views:

1093

answers:

3

I've looked at the documentation but I've been unable to find an answer. Is there a way to prevent a row from being highlighted when selected? That or even a way to stop the row being selected at all. I like the "hoverrows: true" option, but ideally I would like to stop a row from being selected on-click.

Thanks,

Update: I've been able to "hackily" implement something which seems to be an interim fix. I don't really like it at all and would idealy like a better solution, if there is one...

I have found that if I pass the option

onSelectRow: function(rowid, status) {
    $('#'+rowid).removeClass('ui-state-highlight');
}

when I instantiate the jqGrid, I can strip the highlight when it is added.

Is there another, more ideal, way to do this?

+1  A: 

I suppose you could address this in the CSS directly. Just override the values for ui-state-highlight for your specific table

#table_id tr.ui-state-highlight {
  border: inherit !important;
  background: inherit !important;
  color: inherit !important;
}

#table_id tr.ui-state-highlight a {
  color: inherit !important;
}

#table_id tr.ui-state-highlight .ui-icon {
  background-image: inherit !important;
}

I used the value inherit just as an example - you will likely need to copy some values from your theme.css to make this work.

Peter Bailey
Thank's, I'll give this a shot in the morning and get back to you.
Mike
For browser compatibility sakes I'm going to dodge this implementation. However it does seem quite nice to hide this problem in the css. Thanks anyway +1.
Mike
+1  A: 

try:

onSelectRow: function(rowid, status) {
    $("#grid_id").resetSelection(); //Resets (unselects) the selected row(s). Also works in multiselect mode.
}

you can read documentations here. Hope it helps you...

Reigel
Slightly more accurate than my solution. Thanks.
Mike
+4  A: 

Use the following code:

beforeSelectRow: function(rowid, e) {
    return false;
}
Vinodh Ramasubramanian
Perfect! This is exactly the way I was trying to do it, I just couldn't find the right event to hook off. Thanks.
Mike