Skip to content

Commit

Permalink
Merge pull request #313 from BSd3v/fix-scrollTo
Browse files Browse the repository at this point in the history
Fix scroll to
  • Loading branch information
gvwilson authored Jul 29, 2024
2 parents 9032bf6 + 3401126 commit 1c272b6
Show file tree
Hide file tree
Showing 4 changed files with 77 additions and 9 deletions.
4 changes: 4 additions & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,10 @@ Links "DE#nnn" prior to version 2.0 point to the Dash Enterprise closed-source D
### Fixed
- [#314](https://github.com/plotly/dash-ag-grid/pull/314)
- locking selenium for tests that were failing due to missing import
- [#313](https://github.com/plotly/dash-ag-grid/pull/313)
- [#312](https://github.com/plotly/dash-ag-grid/issues/312) fixing issue where `scrollTo` was defaulting to not reset the value
- to maintain scroll position during a grid rerender, be sure to use `getRowId`
- fixing side issue where `cellDoubleClicked` was forcing the grid to rerender


## [31.2.0] - 2024-02-25
Expand Down
4 changes: 2 additions & 2 deletions src/lib/fragments/AgGrid.react.js
Original file line number Diff line number Diff line change
Expand Up @@ -700,7 +700,7 @@ export default class DashAgGrid extends Component {
}

if (scrollTo) {
this.scrollTo(scrollTo);
this.scrollTo(false);
propsToSet.scrollTo = null;
}

Expand Down Expand Up @@ -1203,7 +1203,7 @@ export default class DashAgGrid extends Component {
}
}

scrollTo(reset = false) {
scrollTo(reset = true) {
const {gridApi} = this.state;
const {scrollTo, setProps, getRowId} = this.props;
if (!gridApi) {
Expand Down
2 changes: 2 additions & 0 deletions src/lib/utils/propCategories.js
Original file line number Diff line number Diff line change
Expand Up @@ -328,6 +328,7 @@ export const PROPS_NOT_FOR_AG_GRID = [
'virtualRowData',
'cellValueChanged',
'cellClicked',
'cellDoubleClicked',
'getRowRequest',
'getRowResponse',
'getDetailRequest',
Expand Down Expand Up @@ -364,6 +365,7 @@ export const OMIT_PROP_RENDER = [
'cellClicked',
'paginationInfo',
'cellRendererData',
'cellDoubleClicked',
];

/**
Expand Down
76 changes: 69 additions & 7 deletions tests/test_scroll_to.py
Original file line number Diff line number Diff line change
@@ -1,10 +1,11 @@
from dash import Dash, html, Input, Output
from dash import Dash, html, Input, Output, Patch, State
from dash_ag_grid import AgGrid
import plotly.express as px
import json
from dash.testing.wait import until
import pandas as pd
import pytest
import time

from . import utils

Expand All @@ -20,9 +21,9 @@ def df():
def scroll_to_inputs():
return [
{"rowIndex": 100, "rowPosition": "bottom", "cell": (100, 0)},
{"column": "bronze", "columnPosition": "end", "cell": (100, 8)},
{"rowId": "Elizabeth Beisel12/8/2012", "rowPosition": "top", "cell": (200, 8)},
{"rowIndex": 300, "rowId": 500, "cell": (300, 8)},
{"rowIndex": 100, "column": "bronze", "columnPosition": "end", "cell": (100, 8)},
{"rowId": "Elizabeth Beisel12/8/2012", "column": "bronze", "columnPosition": "end", "rowPosition": "top", "cell": (200, 8)},
{"rowIndex": 300, "column": "bronze", "columnPosition": "end", "cell": (300, 8)},
{
"rowIndex": 400,
"rowId": "Ryan Bayley29/08/2004",
Expand Down Expand Up @@ -86,6 +87,7 @@ def test_st001_scroll_to(dash_duo, df, scroll_to_inputs):
getRowId="params.data.athlete+params.data.date",
),
html.Button(id="btn"),
html.Button(id="btn_columnState"),
html.Div(id="scrollTo-output"),
html.Div(id="scrollTo-input"),
]
Expand All @@ -97,7 +99,19 @@ def test_st001_scroll_to(dash_duo, df, scroll_to_inputs):
Input("grid", "scrollTo"),
)
def display_scrollTo(scroll_to):
return json.dumps(scroll_to)
if scroll_to:
return json.dumps(scroll_to)

@app.callback(
Output('grid', 'columnState'),
Input('btn_columnState', 'n_clicks'),
State('grid', 'columnState'),
prevent_initial_call=True
)
def reset_columnState(n, s):
state = Patch()
state[0]['width'] = s[0]['width'] - n+1
return state

# On click sets up a new value for scrollTo from the fixture scroll_to_inputs
@app.callback(
Expand All @@ -111,6 +125,8 @@ def update_scrollTo(n_clicks):
dash_duo.start_server(app)
grid = utils.Grid(dash_duo, "grid")

action = utils.ActionChains(dash_duo.driver)

# Check that the grid has been loaded successfully
until(lambda: "Michael Phelps" == grid.get_cell(0, 0).text, timeout=3)

Expand All @@ -119,7 +135,8 @@ def update_scrollTo(n_clicks):

y, x = info["cell"]
dash_duo.find_element("#btn").click()
dash_duo.wait_for_text_to_equal("#scrollTo-output", json.dumps(info), timeout=5)
# removing as this no longer works due to resetting the value, [#313](https://github.com/plotly/dash-ag-grid/pull/313)
# dash_duo.wait_for_text_to_equal("#scrollTo-output", json.dumps(info), timeout=5)
until(lambda: grid.get_cell(y, x).is_displayed(), timeout=3)

# row testing
Expand Down Expand Up @@ -161,6 +178,22 @@ def update_scrollTo(n_clicks):
if x - 1 >= 0:
assert not grid.cell_in_viewport(y, x - 1)

# resets the grid
dash_duo.driver.execute_script("""
dash_ag_grid.getApi('grid').ensureIndexVisible(0);
dash_ag_grid.getApi('grid').ensureColumnVisible('athlete');
""")
until(lambda: grid.get_cell(0, 0).is_displayed(), timeout=3)
# make sure grid doesnt change upon double-click
action.double_click(grid.get_cell(0, 0)).perform()
time.sleep(1)
until(lambda: grid.get_cell(0, 0).is_displayed(), timeout=3)
# make sure scroll doesnt fire upon triggered reload by columnState
dash_duo.find_element("#btn_columnState").click()
time.sleep(1)
until(lambda: grid.get_cell(0, 0).is_displayed(), timeout=3)



def test_st002_initial_scroll_to(dash_duo, df):
app = Dash()
Expand All @@ -180,11 +213,23 @@ def test_st002_initial_scroll_to(dash_duo, df):
"rowPosition": "top",
"column": "bronze",
"columnPosition": "end",
},
}
),
html.Button(id="btn_columnState"),
]
)

@app.callback(
Output('grid', 'columnState'),
Input('btn_columnState', 'n_clicks'),
State('grid', 'columnState'),
prevent_initial_call=True
)
def reset_columnState(n, s):
state = Patch()
state[0]['width'] = s[0]['width'] - n + 1
return state

dash_duo.start_server(app)

grid = utils.Grid(dash_duo, "grid")
Expand All @@ -205,3 +250,20 @@ def test_st002_initial_scroll_to(dash_duo, df):
# column testing
assert not grid.cell_in_viewport(y, x + 1)
assert grid.cell_in_viewport(y, x - 1)

action = utils.ActionChains(dash_duo.driver)

# resets the grid
dash_duo.driver.execute_script("""
dash_ag_grid.getApi('grid').ensureIndexVisible(0);
dash_ag_grid.getApi('grid').ensureColumnVisible('athlete');
""")
until(lambda: grid.get_cell(0, 0).is_displayed(), timeout=3)
# make sure grid doesnt change upon double-click
action.double_click(grid.get_cell(0, 0)).perform()
time.sleep(1)
until(lambda: grid.get_cell(0, 0).is_displayed(), timeout=3)
# make sure scroll doesnt fire upon triggered reload by columnState
dash_duo.find_element("#btn_columnState").click()
time.sleep(1)
until(lambda: grid.get_cell(0, 0).is_displayed(), timeout=3)

0 comments on commit 1c272b6

Please sign in to comment.