type TodoItem = {
id: string;
txt: string;
}
type State = Record<string, TodoItem>;
enum ActionType {
ADD = 'add',
REMOVE = 'remove'
}
type ActionAdd = {
type: ActionType.ADD,
payload: Omit<TodoItem, 'id'>;
}
type ActionRemove = {
type: ActionType.REMOVE
payload: string;
}
type Actions = ActionAdd | ActionRemove
const reducer = (state: State, action: Actions) => {
switch(action) {
case ActionType.ADD:
return {
...state,
[generateId()]: action.payload
};
case ActionType.REMOVE:{
const next = {...state};
delete next[action.payload];
return next;
}
}
};
const TodoContext = React.createContext();
export const TodoListProvider = (
options: React.PropsWithChildren<{ initial: State }>
) => {
const [selected, setSelected] = useState<string|undefined>();
const state$ = useObservable(reducer, initial);
const add = useCallback((item: Emit<TodoItem, 'id'>) => {
state$.next({ type: ActionType.ADD, payload: item });
}, [state$]);
const remove = useCallback((id: string) => {
state$.next({ type: ActionType.REMOVE, payload: item });
}, [state$])
return (
<TodoContext.Provider value={ {state$, add, remove, selected, setSelected} }>
{ options.children }
</TodoContext.Provider>
);
}
const TodoDetail = () => {
const { state$, selected } = useContext(TodoContext);
const item = useObservableSelectorState(state$, selected)
return item ? (
<div>
<span>ID: {item.id}</span>
<span>TXT: {item.txt}</span>
</div>
) : null;
}
const AddTodo = () => {
const { add } = useContext(TodoContext);
const txtRef = useRef(null);
const onSubmit = useCallback(() => {
add({ txt: txtRef.current.value })
}, [add, txtRef]);
return (
<div>
<input ref={ txtRef } />
<button onClick={ onSubmit } />
</div>
);
};
const TodoList = () => {
const { state$, setSelected } = useContext(TodoContext);
const items = useObservableState(state$).next;
return (
<ul>
{ Object.entries(items).map(
([key,value]) => <li key={key} onClick={ () => setSelected(key) }>{value.txt}</li>
)}
</ul>
)
}
const App = () => {
return (
<TodoListProvider initial={ {} }>
<TodoDetail />
<TodoList />
<AddTodo />
</TodoListProvider>
)
}
@equinor/fusion-observable
8.4.6 • Public • Published Versions
Current Tags
Version | Downloads (Last 7 Days) | Tag |
---|---|---|
9.0.0-next-663bed8344cc2ca0111705b05045173328b3104d | 0 | next |
8.4.4-msal-v4-preview-4113a03adbbeaf888ca8bbe55cb89589b5f736ba | 1 | msal-v4-preview |
8.4.4-msal-v3-preview-2fe00c7097b86959194d2c5f2c7e725a5d20bdc0 | 0 | msal-v3-preview |
8.4.6 | 726 | latest |
8.4.7-beta-AH-test-778ecddcafac619d1bdc9be4a2c50f2f8c15cc68 | 3 | beta-AH-test |
8.4.5-msal-0b0dadf270ee512f019a325c2f1586f91f9150a4 | 1 | msal |
Version History
Package Sidebar
Install
npm i @equinor/fusion-observable
Repository
Weekly Downloads
1,183
Version
8.4.6
License
ISC
Unpacked Size
188 kB
Total Files
97