Skip to content

Commit

Permalink
refact: rename EditableDataframe into EditableDataFrame
Browse files Browse the repository at this point in the history
  • Loading branch information
FabienArcellier committed Dec 17, 2024
1 parent 00b964f commit adbe3be
Show file tree
Hide file tree
Showing 6 changed files with 55 additions and 55 deletions.
2 changes: 1 addition & 1 deletion apps/hello/main.py
Original file line number Diff line number Diff line change
Expand Up @@ -75,7 +75,7 @@ def _get_editable_df():
'object': [{"updatedAt": None}, {"updatedAt": None}, {"updatedAt": None}],
'text': ['one', 'two', 'three'],
})
return wf.EditableDataframe(df)
return wf.EditableDataFrame(df)

def _get_highlighted_members():
sample_df = _get_main_df().sample(3).set_index("name", drop=False)
Expand Down
18 changes: 9 additions & 9 deletions docs/framework/dataframe.mdx
Original file line number Diff line number Diff line change
Expand Up @@ -9,7 +9,7 @@ it offers components as `dataframe` to manipulate dataframes. These components a
|--------------------|---------------------------------------|
| `pandas.DataFrame` | x |
| `polar.DataFrame` | x |
| `list of records` | x (with `EditableDataframe`) |
| `list of records` | x (with `EditableDataFrame`) |

## Use a dataframe

Expand All @@ -26,7 +26,7 @@ wf.init_state({

## Prepare a dataframe for editing

**writer provides `EditableDataframe` as a helper to facilitate manipulation**. it 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
Expand All @@ -36,7 +36,7 @@ import writer as wf
df = pandas.DataFrame({'a': [1, 2, 3], 'b': [4, 5, 6]})

wf.init_state({
'mydf': wf.EditableDataframe(df)
'mydf': wf.EditableDataFrame(df)
})
```

Expand All @@ -50,7 +50,7 @@ import writer as wf

df = pandas.DataFrame({'a': [1, 2, 3], 'b': [4, 5, 6]})
wf.init_state({
'mydf': wf.EditableDataframe(df)
'mydf': wf.EditableDataFrame(df)
})

# Subscribe this event handler to the `wf-dataframe-add` event
Expand All @@ -76,9 +76,9 @@ def on_record_action(state, payload):
state['record'] = state['df'].record(record_index) # dict representation of record
```

### Datastructures supported by `EditableDataframe`
### Datastructures supported by `EditableDataFrame`

`EditableDataframe` can be used with a panda dataframe, 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
Expand All @@ -91,8 +91,8 @@ 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}]

wf.init_state({
'mypandas': wf.EditableDataframe(panda_df),
'mypolars': wf.EditableDataframe(polars_df),
'mylistofrecords': wf.EditableDataframe(list_of_records)
'mypandas': wf.EditableDataFrame(panda_df),
'mypolars': wf.EditableDataFrame(polars_df),
'mylistofrecords': wf.EditableDataFrame(list_of_records)
})
```
2 changes: 1 addition & 1 deletion src/writer/__init__.py
Original file line number Diff line number Diff line change
Expand Up @@ -21,7 +21,7 @@
from writer.core import (
writerproperty as property,
)
from writer.core_df import EditableDataframe
from writer.core_df import EditableDataFrame

try:
from writer.ui import WriterUIManager
Expand Down
4 changes: 2 additions & 2 deletions src/writer/core.py
Original file line number Diff line number Diff line change
Expand Up @@ -281,7 +281,7 @@ class StateSerialiser:
"""
def serialise(self, v: Any) -> Union[Dict, List, str, bool, int, float, None]:
from writer.ai import Conversation
from writer.core_df import EditableDataframe
from writer.core_df import EditableDataFrame

if isinstance(v, State):
return self._serialise_dict_recursively(v.to_dict())
Expand All @@ -299,7 +299,7 @@ def serialise(self, v: Any) -> Union[Dict, List, str, bool, int, float, None]:
return self._serialise_list_recursively(v)
if isinstance(v, (str, bool)):
return v
if isinstance(v, EditableDataframe):
if isinstance(v, EditableDataFrame):
table = v.pyarrow_table()
return self._serialise_pyarrow_table(table)
if v is None:
Expand Down
38 changes: 19 additions & 19 deletions src/writer/core_df.py
Original file line number Diff line number Diff line change
Expand Up @@ -38,7 +38,7 @@ def record(df: Any, record_index: int) -> dict:
"""
This method read a record at the given line and get it back as dictionary
>>> edf = EditableDataframe(df)
>>> edf = EditableDataFrame(df)
>>> r = edf.record(1)
"""
raise NotImplementedError
Expand All @@ -48,7 +48,7 @@ def record_add(df: Any, payload: DataframeRecordAdded) -> Any:
"""
signature of the methods to be implemented to process wf-dataframe-add event
>>> edf = EditableDataframe(df)
>>> edf = EditableDataFrame(df)
>>> edf.record_add({"record": {"a": 1, "b": 2}})
"""
raise NotImplementedError
Expand All @@ -58,7 +58,7 @@ def record_update(df: Any, payload: DataframeRecordUpdated) -> Any:
"""
signature of the methods to be implemented to process wf-dataframe-update event
>>> edf = EditableDataframe(df)
>>> edf = EditableDataFrame(df)
>>> edf.record_update({"record_index": 12, "record": {"a": 1, "b": 2}})
"""
raise NotImplementedError
Expand All @@ -68,7 +68,7 @@ def record_remove(df: Any, payload: DataframeRecordRemoved) -> Any:
"""
signature of the methods to be implemented to process wf-dataframe-action event
>>> edf = EditableDataframe(df)
>>> edf = EditableDataFrame(df)
>>> edf.record_remove({"record_index": 12})
"""
raise NotImplementedError
Expand All @@ -86,7 +86,7 @@ class PandasRecordProcessor(DataframeRecordProcessor):
PandasRecordProcessor processes records from a pandas dataframe saved into an EditableDataframe
>>> df = pandas.DataFrame({"a": [1, 2], "b": [3, 4]})
>>> edf = EditableDataframe(df)
>>> edf = EditableDataFrame(df)
>>> edf.record_add({"a": 1, "b": 2})
"""

Expand All @@ -100,7 +100,7 @@ def match(df: Any) -> bool:
def record(df: 'pandas.DataFrame', record_index: int) -> dict:
"""
>>> edf = EditableDataframe(df)
>>> edf = EditableDataFrame(df)
>>> r = edf.record(1)
"""
import pandas
Expand All @@ -120,7 +120,7 @@ def record(df: 'pandas.DataFrame', record_index: int) -> dict:
@staticmethod
def record_add(df: 'pandas.DataFrame', payload: DataframeRecordAdded) -> 'pandas.DataFrame':
"""
>>> edf = EditableDataframe(df)
>>> edf = EditableDataFrame(df)
>>> edf.record_add({"record": {"a": 1, "b": 2}})
"""
import pandas
Expand All @@ -139,7 +139,7 @@ def record_add(df: 'pandas.DataFrame', payload: DataframeRecordAdded) -> 'pandas
@staticmethod
def record_update(df: 'pandas.DataFrame', payload: DataframeRecordUpdated) -> 'pandas.DataFrame':
"""
>>> edf = EditableDataframe(df)
>>> edf = EditableDataFrame(df)
>>> edf.record_update({"record_index": 12, "record": {"a": 1, "b": 2}})
"""
import pandas
Expand All @@ -164,7 +164,7 @@ def record_update(df: 'pandas.DataFrame', payload: DataframeRecordUpdated) -> 'p
@staticmethod
def record_remove(df: 'pandas.DataFrame', payload: DataframeRecordRemoved) -> 'pandas.DataFrame':
"""
>>> edf = EditableDataframe(df)
>>> edf = EditableDataFrame(df)
>>> edf.record_remove({"record_index": 12})
"""
record_index: int = payload['record_index']
Expand All @@ -187,7 +187,7 @@ class PolarRecordProcessor(DataframeRecordProcessor):
PolarRecordProcessor processes records from a polar dataframe saved into an EditableDataframe
>>> df = polars.DataFrame({"a": [1, 2], "b": [3, 4]})
>>> edf = EditableDataframe(df)
>>> edf = EditableDataFrame(df)
>>> edf.record_add({"record": {"a": 1, "b": 2}})
"""

Expand All @@ -201,7 +201,7 @@ def match(df: Any) -> bool:
def record(df: 'polars.DataFrame', record_index: int) -> dict:
"""
>>> edf = EditableDataframe(df)
>>> edf = EditableDataFrame(df)
>>> r = edf.record(1)
"""
record = {}
Expand Down Expand Up @@ -257,7 +257,7 @@ class RecordListRecordProcessor(DataframeRecordProcessor):
RecordListRecordProcessor processes records from a list of record saved into an EditableDataframe
>>> df = [{"a": 1, "b": 2}, {"a": 3, "b": 4}]
>>> edf = EditableDataframe(df)
>>> edf = EditableDataFrame(df)
>>> edf.record_add({"record": {"a": 1, "b": 2}})
"""

Expand All @@ -270,7 +270,7 @@ def match(df: Any) -> bool:
def record(df: List[Dict[str, Any]], record_index: int) -> dict:
"""
>>> edf = EditableDataframe(df)
>>> edf = EditableDataFrame(df)
>>> r = edf.record(1)
"""
r = df[record_index]
Expand Down Expand Up @@ -314,13 +314,13 @@ def pyarrow_table(df: List[Dict[str, Any]]) -> pyarrow.Table:

return table

class EditableDataframe(MutableValue):
class EditableDataFrame(MutableValue):
"""
Editable Dataframe makes it easier to process events from components
that modify a dataframe like the dataframe editor.
>>> initial_state = wf.init_state({
>>> "df": wf.EditableDataframe(df)
>>> "df": wf.EditableDataFrame(df)
>>> })
Editable Dataframe is compatible with a pandas, thrillers or record list dataframe
Expand Down Expand Up @@ -353,7 +353,7 @@ def record_add(self, payload: DataframeRecordAdded) -> None:
Adds a record to the dataframe
>>> df = pandas.DataFrame({"a": [1, 2], "b": [3, 4]})
>>> edf = EditableDataframe(df)
>>> edf = EditableDataFrame(df)
>>> edf.record_add({"record": {"a": 1, "b": 2}})
"""
assert self.processor is not None
Expand All @@ -369,7 +369,7 @@ def record_update(self, payload: DataframeRecordUpdated) -> None:
It must a value for each index / column.
>>> df = pandas.DataFrame({"a": [1, 2], "b": [3, 4]})
>>> edf = EditableDataframe(df)
>>> edf = EditableDataFrame(df)
>>> edf.record_update({"record_index": 0, "record": {"a": 2, "b": 2}})
"""
assert self.processor is not None
Expand All @@ -382,7 +382,7 @@ def record_remove(self, payload: DataframeRecordRemoved) -> None:
Removes a record from the dataframe
>>> df = pandas.DataFrame({"a": [1, 2], "b": [3, 4]})
>>> edf = EditableDataframe(df)
>>> edf = EditableDataFrame(df)
>>> edf.record_remove({"record_index": 0})
"""
assert self.processor is not None
Expand All @@ -397,7 +397,7 @@ def pyarrow_table(self) -> pyarrow.Table:
This mechanism is used for serializing data for transmission to the frontend.
>>> df = pandas.DataFrame({"a": [1, 2], "b": [3, 4]})
>>> edf = EditableDataframe(df)
>>> edf = EditableDataFrame(df)
>>> pa_table = edf.pyarrow_table()
"""
assert self.processor is not None
Expand Down
Loading

0 comments on commit adbe3be

Please sign in to comment.