diff libervia/pages/tickets/edit/page_meta.py @ 1124:28e3eb3bb217

files reorganisation and installation rework: - files have been reorganised to follow other SàT projects and usual Python organisation (no more "/src" directory) - VERSION file is now used, as for other SàT projects - replace the overcomplicated setup.py be a more sane one. Pyjamas part is not compiled anymore by setup.py, it must be done separatly - removed check for data_dir if it's empty - installation tested working in virtual env - libervia launching script is now in bin/libervia
author Goffi <goffi@goffi.org>
date Sat, 25 Aug 2018 17:59:48 +0200
parents src/pages/tickets/edit/page_meta.py@cdd389ef97bc
children 7bd47d32da87
line wrap: on
line diff
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/libervia/pages/tickets/edit/page_meta.py	Sat Aug 25 17:59:48 2018 +0200
@@ -0,0 +1,94 @@
+#!/usr/bin/env python2.7
+# -*- coding: utf-8 -*-
+
+from libervia.server.constants import Const as C
+from sat.core.i18n import _
+from twisted.internet import defer
+from sat.tools.common import template_xmlui
+from sat.core.log import getLogger
+
+log = getLogger("pages/ticket")
+"""ticket handling pages"""
+
+name = u"tickets_edit"
+access = C.PAGES_ACCESS_PROFILE
+template = u"ticket/edit.html"
+
+
+def parse_url(self, request):
+    try:
+        item_id = self.nextPath(request)
+    except IndexError:
+        log.warning(_(u"no ticket id specified"))
+        self.pageError(request, C.HTTP_BAD_REQUEST)
+
+    data = self.getRData(request)
+    data[u"ticket_id"] = item_id
+
+
+@defer.inlineCallbacks
+def prepare_render(self, request):
+    data = self.getRData(request)
+    template_data = request.template_data
+    service, node, ticket_id = (
+        data.get(u"service", u""),
+        data.get(u"node", u""),
+        data[u"ticket_id"],
+    )
+    profile = self.getProfile(request)
+
+    ignore = (
+        "publisher",
+        "author",
+        "author_jid",
+        "author_email",
+        "created",
+        "updated",
+        "comments_uri",
+    )
+    tickets = yield self.host.bridgeCall(
+        "ticketsGet",
+        service.full() if service else u"",
+        node,
+        C.NO_LIMIT,
+        [ticket_id],
+        "",
+        {},
+        profile,
+    )
+    ticket = [template_xmlui.create(self.host, x, ignore=ignore) for x in tickets[0]][0]
+
+    try:
+        # small trick to get a one line text input instead of the big textarea
+        ticket.widgets[u"labels"].type = u"string"
+        ticket.widgets[u"labels"].value = ticket.widgets[u"labels"].value.replace(
+            u"\n", ", "
+        )
+    except KeyError:
+        pass
+    template_data[u"new_ticket_xmlui"] = ticket
+
+
+@defer.inlineCallbacks
+def on_data_post(self, request):
+    data = self.getRData(request)
+    service = data["service"]
+    node = data["node"]
+    ticket_id = data["ticket_id"]
+    posted_data = self.getAllPostedData(request)
+    if not posted_data["title"] or not posted_data["body"]:
+        self.pageError(request, C.HTTP_BAD_REQUEST)
+    try:
+        posted_data["labels"] = [l.strip() for l in posted_data["labels"][0].split(",")]
+    except (KeyError, IndexError):
+        pass
+    profile = self.getProfile(request)
+    yield self.host.bridgeCall(
+        "ticketSet", service.full(), node, posted_data, u"", ticket_id, {}, profile
+    )
+    # we don't want to redirect to edit page on success, but to tickets list
+    data["post_redirect_page"] = (
+        self.getPageByName(u"tickets"),
+        service.full(),
+        node or u"@",
+    )