clubdesk import: assign youth leaders and omit groupless entries

pull/73/head
Christian Merten 1 year ago
parent 379c4547a6
commit 3fc1b65d67
Signed by: christian.merten
GPG Key ID: D953D69721B948B3

@ -1417,7 +1417,7 @@ class MemberTraining(CommonModel):
} }
def import_from_csv(path): def import_from_csv(path, omit_groupless=True):
with open(path, encoding='ISO-8859-1') as csvfile: with open(path, encoding='ISO-8859-1') as csvfile:
reader = csv.DictReader(csvfile, delimiter=';') reader = csv.DictReader(csvfile, delimiter=';')
rows = list(reader) rows = list(reader)
@ -1432,9 +1432,15 @@ def import_from_csv(path):
def transform_row(row): def transform_row(row):
kwargs = dict([ transform_field(k, v) for k, v in row.items() if k in CLUBDESK_TO_KOMPASS ]) kwargs = dict([ transform_field(k, v) for k, v in row.items() if k in CLUBDESK_TO_KOMPASS ])
kwargs_filtered = { k : v for k, v in kwargs.items() if k not in ['group', 'last_training', 'has_fundamental_training', 'special_training', 'phone_number_private', 'phone_number_parents'] } kwargs_filtered = { k : v for k, v in kwargs.items() if k not in ['group', 'last_training', 'has_fundamental_training', 'special_training', 'phone_number_private', 'phone_number_parents'] }
if not kwargs['group'] and omit_groupless:
# if member does not have a group, skip them
return
mem = Member(**kwargs_filtered) mem = Member(**kwargs_filtered)
mem.save() mem.save()
mem.group.set(kwargs['group']) mem.group.set([group for group, is_jl in kwargs['group']])
for group, is_jl in kwargs['group']:
if is_jl:
group.leiters.add(mem)
if kwargs['has_fundamental_training']: if kwargs['has_fundamental_training']:
try: try:
@ -1487,22 +1493,25 @@ def parse_group(value):
roles = set() roles = set()
def extract_group_name_and_role(raw): def extract_group_name_and_role(raw):
obj = re.search('^(.*?)(?: \((.*)\))?$', raw) obj = re.search('^(.*?)(?: \((.*)\))?$', raw)
is_jl = False
if obj.group(2) is not None: if obj.group(2) is not None:
roles.add(obj.group(2).strip()) roles.add(obj.group(2).strip())
return obj.group(1).strip() if obj.group(2) == 'Jugendleiter*in':
is_jl = True
return (obj.group(1).strip(), is_jl)
group_names = [extract_group_name_and_role(raw) for raw in groups_raw if raw != ''] group_names = [extract_group_name_and_role(raw) for raw in groups_raw if raw != '']
if "Jugendleiter*in" in roles: if "Jugendleiter*in" in roles:
group_names.append("Jugendleiter") group_names.append(('Jugendleiter', False))
groups = [] groups = []
for group_name in group_names: for group_name, is_jl in group_names:
try: try:
group = Group.objects.get(name=group_name) group = Group.objects.get(name=group_name)
except Group.DoesNotExist: except Group.DoesNotExist:
group = Group(name=group_name) group = Group(name=group_name)
group.save() group.save()
groups.append(group) groups.append((group, is_jl))
return groups return groups

Loading…
Cancel
Save