Mercurial > libervia-web
comparison 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 |
comparison
equal
deleted
inserted
replaced
1386:83be300d17e3 | 1387:a84383c659b4 |
---|---|
1 #!/usr/bin/env python3 | 1 #!/usr/bin/env python3 |
2 | 2 |
3 | |
4 from libervia.server.constants import Const as C | 3 from libervia.server.constants import Const as C |
5 from sat.tools.common import template_xmlui | |
6 from sat.tools.common import data_objects | |
7 from sat.tools.common import data_format | 4 from sat.tools.common import data_format |
8 from sat.core.log import getLogger | 5 from sat.core.log import getLogger |
9 | 6 |
10 log = getLogger(__name__) | 7 log = getLogger(__name__) |
11 | 8 |
12 name = "list_create" | 9 name = "list_create" |
13 access = C.PAGES_ACCESS_PUBLIC | 10 access = C.PAGES_ACCESS_PROFILE |
14 template = "list/overview.html" | 11 template = "list/create.html" |
15 | 12 |
16 | 13 |
17 def parse_url(self, request): | 14 def parse_url(self, request): |
18 self.getPathArgs(request, ["service", "node"], service="jid") | 15 self.getPathArgs(request, ["template_id"]) |
19 data = self.getRData(request) | 16 data = self.getRData(request) |
20 service, node = data["service"], data["node"] | 17 if data["template_id"]: |
21 if node is None: | 18 self.HTTPRedirect( |
22 self.pageRedirect("lists_disco", request) | 19 request, |
23 if node == "@": | 20 self.getPageByName("list_create_from_tpl").getURL(data["template_id"]) |
24 node = data["node"] = "" | 21 ) |
25 template_data = request.template_data | |
26 template_data["url_list_items"] = self.getURL(service.full(), node or "@") | |
27 template_data["url_list_new"] = self.getSubPageURL(request, "list_new") | |
28 | 22 |
29 | 23 |
30 async def prepare_render(self, request): | 24 async def prepare_render(self, request): |
31 data = self.getRData(request) | |
32 template_data = request.template_data | 25 template_data = request.template_data |
33 service, node = data["service"], data["node"] | 26 profile = self.getProfile(request) |
34 profile = self.getProfile(request) or C.SERVICE_PROFILE | 27 tpl_raw = await self.host.bridgeCall( |
35 | 28 "listTemplatesNamesGet", |
36 self.checkCache(request, C.CACHE_PUBSUB, service=service, node=node, short="tickets") | |
37 | |
38 extra = self.getPubsubExtra(request) | |
39 extra["labels_as_list"] = C.BOOL_TRUE | |
40 self.handleSearch(request, extra) | |
41 | |
42 list_data_raw = await self.host.bridgeCall( | |
43 "listGet", | |
44 service.full() if service else "", | |
45 node, | |
46 C.NO_LIMIT, | |
47 [], | |
48 "", | 29 "", |
49 extra, | |
50 profile, | 30 profile, |
51 ) | 31 ) |
52 list_items, metadata = data_format.deserialise(list_data_raw, type_check=list) | 32 lists_templates = data_format.deserialise(tpl_raw, type_check=list) |
53 template_data["list_items"] = [template_xmlui.create(self.host, x) for x in | 33 template_data["icons_names"] = {tpl['icon'] for tpl in lists_templates} |
54 list_items] | 34 template_data["lists_templates"] = [ |
55 template_data["on_list_item_click"] = data_objects.OnClick( | 35 { |
56 url=self.getSubPageURL(request, "list_view") + "/{item.id}" | 36 "icon": tpl["icon"], |
57 ) | 37 "name": tpl["name"], |
58 self.setPagination(request, metadata) | 38 "url": self.getURL(tpl["id"]), |
39 } | |
40 for tpl in lists_templates | |
41 ] |