-
-
Notifications
You must be signed in to change notification settings - Fork 72
Conversation
* refactor virtualization, virtualization settings, and derived props * refactor renaming paging / pagination props * refactor virtual, viewport and pagination into adapters * isolate derived props * build update * fix regression * improve typing * fix test regression * simplify pagination adapter / refactor * lint * clean up unused props * - change factory - clean up props / build update * fix lint * bump version * add dash level props for virtual_dataframe * refactor fp / derived props * derived props * refactor viewport and virtual controlled props * fix fp regression * fix fp regression * refactor controlled table / table fp * controlled table purecomponent * fix test (rebrake it!) * fix selection regression for be paging/sorting/filtering * improve re-renders & controlled props * fix test regressions * update inner-selection fixture * remove useless spy * - fix pr comment - fix for IE/Edge * clean up
* refactor virtualization, virtualization settings, and derived props * refactor renaming paging / pagination props * refactor virtual, viewport and pagination into adapters * isolate derived props * build update * fix regression * improve typing * fix test regression * simplify pagination adapter / refactor * lint * clean up unused props * - change factory - clean up props / build update * fix lint * bump version * add dash level props for virtual_dataframe * cleaup offsets * triad validation * - define external facing classes and attributes * fix regression, update build * fix test regression (invalid props) * update test name * refactor fp / derived props * derived props * refactor viewport and virtual controlled props * fix fp regression * fix fp regression * refactor controlled table / table fp * controlled table purecomponent * fix test (rebrake it!) * fix selection regression for be paging/sorting/filtering * improve re-renders & controlled props * fix test regressions * update inner-selection fixture * remove useless spy * - control columns into visible columns - cleanup "hidden" conditional processing * update changelog * clean up header factory * apply style on first controlled table render * typo/merge miss * derived visible columns * - visual tests for hidden columns * rename functions * - fix dropdown styling regression * lint
* props fixes * update changelog * bump version * filter typing * Update derivedViewport_test.ts Add basic viewport test with |df| > page_size
see discussion in #108
* props fixes * update changelog * bump version * filter typing * - delete unused usage files - restructure tests folder * - separate cypress and visual tests into 2 ci jobs * - build before tests! * add browsers to the node image for visual-test
# Conflicts: # dash_table/bundle.js # dash_table/demo.js # src/dash-table/components/ControlledTable/index.tsx # src/dash-table/components/HeaderFactory.tsx # src/dash-table/components/Table/Table.less # src/dash-table/components/Table/props.ts
💯 add percent examples
107 save on tab -> develop
* WIP - memoize cell event handlers as derived values - isolate cell event handlers * wip - attempt to isolate cell logic from input logic for individual datum * wip - celan up cell wrapper - isolate input logic a bit more * further down the rabbit hole.. - separating operation cells from content * fix dropdown navigation regression * fix selected row regression * renaming / restructuring * rename/restructure * - clean up zipping - separate wrappers from styles * rework style/ast cache * clean up * clean up * build update * improve rendering perf * optimize wrappers generation * build config * - fix typing regression - fix rendering perf regression * - fix navigation regression * simplify slightly the derived props / ui * fix copy/paste regressions * clean up wrapper props * clean up * fix regression on conditional dropdowns * wip, fp the headers * fp content, wrappers, labels, indices from header factory * fix regressions * fp the table itself * fix typing and behavior for table fp * fix sorting icon regression * fix regression * regression * fix column name regression with only 1 header row * fix header actions regression * fix style application on mount * fix regression edit cell in n-th page * fix editing on non-first page (continued) * fix test
* WIP - memoize cell event handlers as derived values - isolate cell event handlers * wip - attempt to isolate cell logic from input logic for individual datum * wip - celan up cell wrapper - isolate input logic a bit more * further down the rabbit hole.. - separating operation cells from content * fix dropdown navigation regression * fix selected row regression * renaming / restructuring * rename/restructure * - clean up zipping - separate wrappers from styles * rework style/ast cache * clean up * clean up * build update * improve rendering perf * optimize wrappers generation * build config * - fix typing regression - fix rendering perf regression * - fix navigation regression * simplify slightly the derived props / ui * fix copy/paste regressions * clean up wrapper props * clean up * fix regression on conditional dropdowns * wip, fp the headers * fp content, wrappers, labels, indices from header factory * fix regressions * fp the table itself * fix typing and behavior for table fp * fix sorting icon regression * fix regression * regression * fix column name regression with only 1 header row * fix header actions regression * add width percentage support + content_style * fix style application on mount * fix visual regression with empty df * only apply row style when necessary * fix tab test (no offset) * clean up header styling * use dash-* classes * support default column width (override input behavior) * fix regression edit cell in n-th page * fix editing on non-first page (continued) * fix test * fit to content behavior * fix regressions * fix lint * add column width visual tests * fix dropdown minimum size when using default width * sizing examples * black * fix navigation test regression * fix regressions in visual tests * default column width - fix dropdown width eval * default width columns - fix width when first content row is search filter * percy - add delay before screenshot (attempt to fix FF visual tests) * debugging selenium * fix black * debug selenium * debug selenium * fix black * debug selenium * debug selenium * debug selenium * undo all selenium modifications * default column width - filter inputs behave like cell inputs (do not affect width) * - fixed rows+columns height evaluated correctly * remove dead code * remove .only from tests * add data-dash-column to filter cells
# Conflicts: # CHANGELOG.md # dash_table/bundle.js # dash_table/demo.js # dash_table/package.json # package.json # src/dash-table/components/ControlledTable/index.tsx # src/dash-table/components/HeaderFactory.tsx # src/dash-table/components/Table/Table.less # src/dash-table/components/Table/props.ts
* 🌈 styling examples examples that represent of the level of customization that we need in dash-table. The examples are implemented with HTML tables to demonstrate the intended behaviour. I’d like to see each of these examples implemented with the `dash_table` syntax. We’ll use these examples as our `dash-table` documentation * ❌ removing black and pylint this keeps tripping us up and I don’t think it’s worth the pain right now.
* 🏭 backend computed data usage examples * 📊 tying it together w a graph * ❓ not sure what `displayed_pages` does?
* ⬇️ dropdown usage examples * add conditional dropdown example
- fixes for editable/readonly
…ly-tests # Conflicts: # CHANGELOG.md # dash_table/bundle.js # dash_table/demo.js # dash_table/package.json # package.json # src/dash-table/components/CellInput/index.tsx # src/dash-table/derived/cell/inputs.tsx # src/dash-table/derived/cell/wrappers.tsx # tests/cypress/tests/standalone/edit_cell_test.ts # tests/visual/percy-storybook/Width.defaults.percy.tsx # tests/visual/percy-storybook/Width.min.percy.tsx # tests/visual/percy-storybook/Width.percy.tsx
@@ -1,6 +1,6 @@ | |||
{ | |||
"name": "dash-table", | |||
"version": "3.1.0rc4", | |||
"version": "3.1.0rc5", |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
bump version
type: 'numeric', | ||
editable: false, | ||
width: 150, | ||
data: gendata(i => i + 1), |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
adding two additional readonly fields to the demo app to test out readonly cases
@@ -88,7 +108,7 @@ export default class CellInput extends PureComponent<ICellProps, ICellState> { | |||
onDoubleClick: onDoubleClick | |||
}; | |||
|
|||
const readonly = !active && this.state.value === this.props.value; | |||
const readonly = (!active && this.state.value === this.props.value) || !editable; |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
cell content is readonly if not focused or if not editable (table+column configuration)
@@ -43,7 +44,7 @@ const getter = ( | |||
clearable={column.clearable} | |||
datum={datum} | |||
dropdown={dropdown} | |||
editable={editable} | |||
editable={colIsEditable(editable, column)} |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
calculate readonly/readwrite based on table and column props
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Slightly nitpicky (sorry) but I think the derivedState.js
name is a little confusing. I see you've got files like derived/cell/isActive
, couldn't it go in something like that? Like derived/columns/isEditable
.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Hadn't renamed it because I hadn't moved it from js to typescript.. but sure, I'll do it now.
@@ -3,6 +3,10 @@ export default class DashTable { | |||
return cy.get(`#table tbody tr td.column-${column}`).eq(row); | |||
} | |||
|
|||
static getCellById(row: number, column: number | string) { | |||
return cy.get(`#table tbody tr td[data-dash-column="${column}"]`).eq(row); | |||
} |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
new selector for tests that uses the column id attribute instead of the index -- when applied to everything, will make tests more robust to changes in the demo app
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Looks good, copy paste tests are still failing on my end though. New tests look fine and pass so 💃
@@ -43,7 +44,7 @@ const getter = ( | |||
clearable={column.clearable} | |||
datum={datum} | |||
dropdown={dropdown} | |||
editable={editable} | |||
editable={colIsEditable(editable, column)} |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Slightly nitpicky (sorry) but I think the derivedState.js
name is a little confusing. I see you've got files like derived/cell/isActive
, couldn't it go in something like that? Like derived/columns/isEditable
.
export default ( | ||
editable: boolean, | ||
column: IVisibleColumn | ||
): boolean => editable && (column.editable === undefined || column.editable); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@valentijnnieman As per suggestion, renaming and TS-ing
#132