From 36a3ea845b090c8353f6d1bc6909a9e8e60929c5 Mon Sep 17 00:00:00 2001 From: Fabien Arcellier Date: Tue, 16 Jul 2024 08:46:36 +0200 Subject: [PATCH] feat: implement editable dataframe to manage dataframe editor component * docs: improve documentation * docs: add dataframe section --- docs/framework/dataframe.mdx | 15 ++++++--------- docs/mint.json | 1 + src/writer/core.py | 10 +++++++--- 3 files changed, 14 insertions(+), 12 deletions(-) diff --git a/docs/framework/dataframe.mdx b/docs/framework/dataframe.mdx index 864cbdfb7..77414035d 100644 --- a/docs/framework/dataframe.mdx +++ b/docs/framework/dataframe.mdx @@ -11,7 +11,7 @@ it offers components as `dataframe` to manipulate dataframes. These components a | `polar.DataFrame` | x | | `list of records` | x (with `EditableDataframe`) | -### Use a dataframe +## Use a dataframe **a dataframe is simply added to the state**. A component like `dataframe` will be able to display it. @@ -24,9 +24,9 @@ wf.init_state({ }) ``` -### Prepare a dataframe for editing +## Prepare a dataframe for editing -**writer provides a helper to facilitate dataframe manipulatione**. This helper makes it easier to write event handlers such as adding a line, +**writer provides `EditableDataframe` as a helper to facilitate manipulation**. it makes it easier to write event handlers such as adding a line, deleting it or modifying a value, etc... ```python @@ -40,9 +40,7 @@ wf.init_state({ }) ``` -An `EditableDataframe` value can also be displayed in the `dataframe` component - -#### Handle events from a dataframe editor +### Handle events from a dataframe editor **The dataframe component emits events when an action is performed**. You must subscribe to events to integrate changes to the state of the application. @@ -78,9 +76,9 @@ def on_record_action(state, payload): state['record'] = state['df'].record(record_index) # dict representation of record ``` -#### Alternative to pandas.DataFrame +### Datastructures supported by `EditableDataframe` -`EditableDataframe` can also be used with a polar dataframe and list of records. +`EditableDataframe` can be used with a panda dataframe, a polar dataframe and list of records. ```python import pandas @@ -91,7 +89,6 @@ import writer as wf panda_df = pandas.DataFrame({'a': [1, 2, 3], 'b': [4, 5, 6]}) polars_df = polars.DataFrame({'a': [1, 2, 3], 'b': [4, 5, 6]}) list_of_records = [{'a': 1, 'b': 4}, {'a': 2, 'b': 5}, {'a': 3, 'b': 6}] -list_of_records = [[1, 4], [2, 5], [3, 6]] wf.init_state({ 'mypandas': wf.EditableDataframe(panda_df), diff --git a/docs/mint.json b/docs/mint.json index 15e0eab03..6d5dd9e9f 100644 --- a/docs/mint.json +++ b/docs/mint.json @@ -41,6 +41,7 @@ "framework/event-handlers", "framework/builder-basics", "framework/handling-inputs", + "framework/dataframe", "framework/backend-driven-ui", "framework/stylesheets", "framework/frontend-scripts", diff --git a/src/writer/core.py b/src/writer/core.py index 0d82bd83a..c565066f9 100644 --- a/src/writer/core.py +++ b/src/writer/core.py @@ -1705,9 +1705,13 @@ def record_add(df: 'pandas.DataFrame', payload: DataframeRecordAdded) -> 'pandas _assert_record_match_pandas_df(df, payload['record']) record, index = _split_record_as_pandas_record_and_index(payload['record'], df.index.names) - - new_df = pandas.DataFrame([record], index=[index]) - return pandas.concat([df, new_df]) + + if isinstance(df.index, pandas.RangeIndex): + new_df = pandas.DataFrame([record]) + return pandas.concat([df, new_df], ignore_index=True) + else: + new_df = pandas.DataFrame([record], index=[index]) + return pandas.concat([df, new_df]) @staticmethod def record_update(df: 'pandas.DataFrame', payload: DataframeRecordUpdated) -> 'pandas.DataFrame':