add server_side event for cookie and local storage (#1206)
This commit is contained in:
parent
b37560cbeb
commit
8947c26c7e
@ -16,6 +16,7 @@
|
||||
"focus-visible": "^5.2.0",
|
||||
"framer-motion": "^10.12.4",
|
||||
"gridjs": "^6.0.6",
|
||||
"universal-cookie": "^4.0.4",
|
||||
"gridjs-react": "^6.0.1",
|
||||
"json5": "^2.2.3",
|
||||
"next": "^13.3.1",
|
||||
|
@ -3,6 +3,8 @@ import axios from "axios";
|
||||
import io from "socket.io-client";
|
||||
import JSON5 from "json5";
|
||||
import env from "env.json";
|
||||
import Cookies from "universal-cookie";
|
||||
|
||||
|
||||
// Endpoint URLs.
|
||||
const PINGURL = env.pingUrl
|
||||
@ -94,6 +96,18 @@ export const applyEvent = async (event, router, socket) => {
|
||||
return false;
|
||||
}
|
||||
|
||||
if (event.name == "_set_cookie") {
|
||||
const cookies = new Cookies();
|
||||
cookies.set(event.payload.key, event.payload.value);
|
||||
localStorage.setItem(event.payload.key, event.payload.value);
|
||||
return false;
|
||||
}
|
||||
|
||||
if (event.name == "_set_local_storage") {
|
||||
localStorage.setItem(event.payload.key, event.payload.value);
|
||||
return false;
|
||||
}
|
||||
|
||||
if (event.name == "_alert") {
|
||||
alert(event.payload.message);
|
||||
return false;
|
||||
|
@ -23,7 +23,9 @@ from .event import EventChain as EventChain
|
||||
from .event import FileUpload as upload_files
|
||||
from .event import console_log as console_log
|
||||
from .event import redirect as redirect
|
||||
from .event import set_cookie as set_cookie
|
||||
from .event import set_focus as set_focus
|
||||
from .event import set_local_storage as set_local_storage
|
||||
from .event import set_value as set_value
|
||||
from .event import window_alert as window_alert
|
||||
from .middleware import Middleware as Middleware
|
||||
|
@ -236,6 +236,42 @@ def set_value(ref: str, value: Any) -> EventSpec:
|
||||
)
|
||||
|
||||
|
||||
def set_cookie(key: str, value: str) -> EventSpec:
|
||||
"""Set a cookie on the frontend.
|
||||
|
||||
Args:
|
||||
key (str): The key identifying the cookie.
|
||||
value (str): The value contained in the cookie.
|
||||
|
||||
Returns:
|
||||
EventSpec: An event to set a cookie.
|
||||
"""
|
||||
return server_side(
|
||||
"_set_cookie",
|
||||
get_fn_signature(set_cookie),
|
||||
key=key,
|
||||
value=value,
|
||||
)
|
||||
|
||||
|
||||
def set_local_storage(key: str, value: str) -> EventSpec:
|
||||
"""Set a value in the local storage on the frontend.
|
||||
|
||||
Args:
|
||||
key (str): The key identifying the variable in the local storage.
|
||||
value (str): The value contained in the local storage.
|
||||
|
||||
Returns:
|
||||
EventSpec: An event to set a key-value in local storage.
|
||||
"""
|
||||
return server_side(
|
||||
"_set_local_storage",
|
||||
get_fn_signature(set_local_storage),
|
||||
key=key,
|
||||
value=value,
|
||||
)
|
||||
|
||||
|
||||
def get_event(state, event):
|
||||
"""Get the event from the given state.
|
||||
|
||||
|
@ -143,3 +143,33 @@ def test_set_value():
|
||||
assert (
|
||||
format.format_event(spec) == 'E("_set_value", {ref:ref_input1,value:message})'
|
||||
)
|
||||
|
||||
|
||||
def test_set_cookie():
|
||||
"""Test the event set_cookie."""
|
||||
spec = event.set_cookie("testkey", "testvalue")
|
||||
assert isinstance(spec, EventSpec)
|
||||
assert spec.handler.fn.__qualname__ == "_set_cookie"
|
||||
assert spec.args == (
|
||||
("key", "testkey"),
|
||||
("value", "testvalue"),
|
||||
)
|
||||
assert (
|
||||
format.format_event(spec)
|
||||
== 'E("_set_cookie", {key:"testkey",value:"testvalue"})'
|
||||
)
|
||||
|
||||
|
||||
def test_set_local_storage():
|
||||
"""Test the event set_local_storage."""
|
||||
spec = event.set_local_storage("testkey", "testvalue")
|
||||
assert isinstance(spec, EventSpec)
|
||||
assert spec.handler.fn.__qualname__ == "_set_local_storage"
|
||||
assert spec.args == (
|
||||
("key", "testkey"),
|
||||
("value", "testvalue"),
|
||||
)
|
||||
assert (
|
||||
format.format_event(spec)
|
||||
== 'E("_set_local_storage", {key:"testkey",value:"testvalue"})'
|
||||
)
|
||||
|
Loading…
Reference in New Issue
Block a user