Mercurial > libervia-web
view libervia/pages/lists/_browser/__init__.py @ 1466:cff720e26089
pages (blog/view): activate pagination when a single item is shown:
`previous_page_url` and `next_page_url` are set when `item_id` is used. For now, they are
both activated even if there is no item before or after, as it would request to make extra
request to check it. This may be improved in 0.9 by using internal cache.
fix 399
author | Goffi <goffi@goffi.org> |
---|---|
date | Thu, 30 Sep 2021 17:04:22 +0200 |
parents | 72f9639594b2 |
children | 106bae41f5c8 |
line wrap: on
line source
from browser import DOMNode, document, aio from javascript import JSON from aio_bridge import Bridge, BridgeException import dialog bridge = Bridge() async def on_delete(evt): evt.stopPropagation() evt.preventDefault() target = evt.currentTarget item_elt = DOMNode(target.closest('.item')) item_elt.classList.add("selected_for_deletion") item = JSON.parse(item_elt.dataset.item) confirmed = await dialog.Confirm( f"List {item['name']!r} will be deleted, are you sure?", ok_label="delete", ).ashow() if not confirmed: item_elt.classList.remove("selected_for_deletion") return try: await bridge.interestRetract("", item['id']) except BridgeException as e: dialog.notification.show( f"Can't remove list {item['name']!r} from personal interests: {e}", "error" ) else: print(f"{item['name']!r} removed successfuly from list of interests") item_elt.classList.add("state_deleted") item_elt.bind("transitionend", lambda evt: item_elt.remove()) if item.get("creator", False): try: await bridge.psNodeDelete( item['service'], item['node'], ) except BridgeException as e: dialog.notification.show( f"Error while deleting {item['name']!r}: {e}", "error" ) else: dialog.notification.show(f"{item['name']!r} has been deleted") for elt in document.select('.action_delete'): elt.bind("click", lambda evt: aio.run(on_delete(evt)))