From fbebd0e1896b45fc385d60cf90d636349dcf0402 Mon Sep 17 00:00:00 2001
From: Martin Mares <mj@ucw.cz>
Date: Tue, 23 Nov 2021 12:30:07 +0100
Subject: [PATCH] =?UTF-8?q?Export=20=C5=A1kol=20a=20jejich=20garant=C5=AF?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit

---
 bin/export-schools | 78 ++++++++++++++++++++++++++++++++++++++++++++++
 setup.py           |  1 +
 2 files changed, 79 insertions(+)
 create mode 100755 bin/export-schools

diff --git a/bin/export-schools b/bin/export-schools
new file mode 100755
index 00000000..cc0dc339
--- /dev/null
+++ b/bin/export-schools
@@ -0,0 +1,78 @@
+#!/usr/bin/env python3
+# Přehled všech škol v regionu a jejich garantů
+
+import argparse
+from dataclasses import dataclass
+import locale
+from sqlalchemy import and_
+from sqlalchemy.orm import joinedload
+import sys
+
+import mo.csv
+import mo.db as db
+from mo.util import die, init_standalone
+
+parser = argparse.ArgumentParser(description='Exportuje školy a jejich garanty')
+parser.add_argument('--region', type=str, help='omezí export na danou oblast')
+
+args = parser.parse_args()
+init_standalone()
+sess = db.get_session()
+
+if args.region:
+    reg = db.get_place_by_code(args.region)
+    if reg is None:
+        die(f"Oblast {args.region} neexistuje")
+else:
+    reg = db.get_root_place()
+
+schools = (sess.query(db.School, db.UserRole)
+               .join(db.RegionDescendant, and_(db.RegionDescendant.region == reg.place_id, db.RegionDescendant.descendant == db.School.place_id))
+               .outerjoin(db.UserRole, and_(db.UserRole.role == db.RoleType.garant_skola, db.UserRole.place_id == db.School.place_id))
+               .options(joinedload(db.School.place, db.Place.parent_place), joinedload(db.UserRole.user))
+               .all())
+
+@dataclass
+class Row:
+    obec: str
+    skola: str
+    kod_skoly: str
+    red_izo: str
+    typ: str
+    garant: str
+    garant_email: str
+
+
+def key(item):
+    s, ur = item
+    town = locale.strxfrm(s.place.parent_place.name)
+    school = locale.strxfrm(s.place.name)
+    garant = ur.user.sort_key() if ur else ("", "")
+    return town, school, garant
+
+
+output = []
+for s, ur in sorted(schools, key=key):
+    place = s.place
+    town = s.place.parent_place
+    user = ur.user if ur else None
+
+    typy = []
+    if s.is_zs:
+        typy.append('ZŠ')
+    if s.is_ss:
+        typy.append('SŠ')
+
+    r = Row(
+        obec=town.name,
+        skola=place.name,
+        kod_skoly=place.get_code(),
+        red_izo=s.red_izo,
+        typ='+'.join(typy),
+        garant=user.full_name() if user else "",
+        garant_email=user.email if user else "",
+    )
+
+    output.append(r)
+
+mo.csv.write(sys.stdout, mo.csv.FileFormat.en_csv, Row, output)
diff --git a/setup.py b/setup.py
index ee19d021..3f37cbbf 100644
--- a/setup.py
+++ b/setup.py
@@ -14,6 +14,7 @@ setuptools.setup(
         'bin/create-tasks',
         'bin/create-user',
         'bin/export-orgs',
+        'bin/export-schools',
         'bin/fix-submits',
         'bin/import-points',
         'bin/merge-users',
-- 
GitLab