Mercurial > libervia-web
diff libervia/pages/lists/create/page_meta.py @ 1387:a84383c659b4
lists: creation, invitation, item deletion:
this big patch includes:
- reorganisation of pages for consistency, discovery is now the main list page, and list
overview is now in `view` while item view is moved to `view_item`
- lists from lists of interest are now shown in discovery page
- list deletion from discory page
- list can now be created, using templates now available from backend
- invitation manager can now be used from list overview
- list item can now be deleted from `view_item`
author | Goffi <goffi@goffi.org> |
---|---|
date | Sat, 20 Feb 2021 14:07:22 +0100 |
parents | e3e303a30a74 |
children | 106bae41f5c8 |
line wrap: on
line diff
--- a/libervia/pages/lists/create/page_meta.py Sat Feb 20 13:58:42 2021 +0100 +++ b/libervia/pages/lists/create/page_meta.py Sat Feb 20 14:07:22 2021 +0100 @@ -1,58 +1,41 @@ #!/usr/bin/env python3 - from libervia.server.constants import Const as C -from sat.tools.common import template_xmlui -from sat.tools.common import data_objects from sat.tools.common import data_format from sat.core.log import getLogger log = getLogger(__name__) name = "list_create" -access = C.PAGES_ACCESS_PUBLIC -template = "list/overview.html" +access = C.PAGES_ACCESS_PROFILE +template = "list/create.html" def parse_url(self, request): - self.getPathArgs(request, ["service", "node"], service="jid") + self.getPathArgs(request, ["template_id"]) data = self.getRData(request) - service, node = data["service"], data["node"] - if node is None: - self.pageRedirect("lists_disco", request) - if node == "@": - node = data["node"] = "" - template_data = request.template_data - template_data["url_list_items"] = self.getURL(service.full(), node or "@") - template_data["url_list_new"] = self.getSubPageURL(request, "list_new") + if data["template_id"]: + self.HTTPRedirect( + request, + self.getPageByName("list_create_from_tpl").getURL(data["template_id"]) + ) async def prepare_render(self, request): - data = self.getRData(request) template_data = request.template_data - service, node = data["service"], data["node"] - profile = self.getProfile(request) or C.SERVICE_PROFILE - - self.checkCache(request, C.CACHE_PUBSUB, service=service, node=node, short="tickets") - - extra = self.getPubsubExtra(request) - extra["labels_as_list"] = C.BOOL_TRUE - self.handleSearch(request, extra) - - list_data_raw = await self.host.bridgeCall( - "listGet", - service.full() if service else "", - node, - C.NO_LIMIT, - [], + profile = self.getProfile(request) + tpl_raw = await self.host.bridgeCall( + "listTemplatesNamesGet", "", - extra, profile, ) - list_items, metadata = data_format.deserialise(list_data_raw, type_check=list) - template_data["list_items"] = [template_xmlui.create(self.host, x) for x in - list_items] - template_data["on_list_item_click"] = data_objects.OnClick( - url=self.getSubPageURL(request, "list_view") + "/{item.id}" - ) - self.setPagination(request, metadata) + lists_templates = data_format.deserialise(tpl_raw, type_check=list) + template_data["icons_names"] = {tpl['icon'] for tpl in lists_templates} + template_data["lists_templates"] = [ + { + "icon": tpl["icon"], + "name": tpl["name"], + "url": self.getURL(tpl["id"]), + } + for tpl in lists_templates + ]