diff --git a/edit_data_form.py b/edit_data_form.py index 4914660..c8ce0ae 100755 --- a/edit_data_form.py +++ b/edit_data_form.py @@ -14,52 +14,64 @@ class FormApp(npyscreen.NPSAppManaged): def main(self): f = npyscreen.Form(name='Edit Member data') - + sd = self.member['stammdaten'] - self.sd2 = {} - self.sd2['fullname'] = f.add(npyscreen.TitleText, name="Name: ", value=sd['fullname']) - self.sd2['nickname'] = f.add(npyscreen.TitleText, name="Nickname: ", - value=sd['nickname']) - self.sd2['address_street'] = f.add( + base_data_widgets = {} + base_data_widgets['fullname'] = f.add( + npyscreen.TitleText, name="Name: ", value=sd['fullname']) + base_data_widgets['nickname'] = f.add(npyscreen.TitleText, name="Nickname: ", + value=sd['nickname']) + base_data_widgets['address_street'] = f.add( npyscreen.TitleText, name="Adresse - Straße: ", value=sd['address_street']) - self.sd2['address_locality'] = f.add( + base_data_widgets['address_locality'] = f.add( npyscreen.TitleText, name="Adresse - Stadt: ", value=sd['address_locality']) - self.sd2['address_code'] = f.add(npyscreen.TitleText, - name="Adresse - PLZ: ", value=sd['address_code']) - self.sd2['address_country'] = f.add( + base_data_widgets['address_code'] = f.add(npyscreen.TitleText, + name="Adresse - PLZ: ", value=sd['address_code']) + base_data_widgets['address_country'] = f.add( npyscreen.TitleText, name="Adresse - Land: ", value=sd['address_country']) - self.sd2['birth_date'] = f.add(npyscreen.TitleText, - name="Geburtstag: ", value=sd['birth_date']) - self.sd2['birth_location'] = f.add( + base_data_widgets['birth_date'] = f.add(npyscreen.TitleText, + name="Geburtstag: ", value=sd['birth_date']) + base_data_widgets['birth_location'] = f.add( npyscreen.TitleText, name="Geburtsort: ", value=sd['birth_location']) - self.sd2['email'] = f.add(npyscreen.TitleText, - name="email: ", value=sd['email']) - self.sd2['pgp-key'] = f.add(npyscreen.TitleText, name="URI PGP Key: ", value=sd['pgp-key']) - self.sd2['ssh-key'] = f.add(npyscreen.TitleText, name="URI SSH Key: ", value=sd['ssh-key']) + base_data_widgets['email'] = f.add(npyscreen.TitleText, + name="email: ", value=sd['email']) + base_data_widgets['pgp-key'] = f.add(npyscreen.TitleText, + name="URI PGP Key: ", value=sd['pgp-key']) + base_data_widgets['ssh-key'] = f.add(npyscreen.TitleText, + name="URI SSH Key: ", value=sd['ssh-key']) + self.base_data_widgets = base_data_widgets fin = self.member['finanzdaten'] - self.fin2 = {} - self.fin2['iban'] = f.add(npyscreen.TitleText, name="IBAN: ", value=fin['iban']) - self.fin2['bic'] = f.add(npyscreen.TitleText, name="BIC: ", value=fin['bic']) - self.fin2['holder'] = f.add(npyscreen.TitleText, name="Kontoinhaber: ", value=fin['holder']) - self.fin2['issuance'] = f.add(npyscreen.TitleText, name="Tag der Erteilung Lastschriftmandat: ", - value=fin['issuance']) - self.fin2['reference'] = f.add(npyscreen.TitleText, name="Mandatsreferenznummer: ", - value=fin['reference']) - self.fin2['scan-sepa-mandate'] = f.add(npyscreen.TitleText, name="URI Scan SEPA-Mandat: ", - value=fin['scan-sepa-mandate']) + finance_widgets = {} + finance_widgets['iban'] = f.add( + npyscreen.TitleText, name="IBAN: ", value=fin['iban']) + finance_widgets['bic'] = f.add( + npyscreen.TitleText, name="BIC: ", value=fin['bic']) + finance_widgets['holder'] = f.add( + npyscreen.TitleText, name="Kontoinhaber: ", value=fin['holder']) + finance_widgets['issuance'] = f.add(npyscreen.TitleText, name="Tag der Erteilung Lastschriftmandat: ", + value=fin['issuance']) + finance_widgets['reference'] = f.add(npyscreen.TitleText, name="Mandatsreferenznummer: ", + value=fin['reference']) + finance_widgets['scan-sepa-mandate'] = f.add(npyscreen.TitleText, name="URI Scan SEPA-Mandat: ", + value=fin['scan-sepa-mandate']) + self.finance_widgets = finance_widgets mem = self.member['mitgliederdaten'] - self.mem2 = {} - self.mem2['status'] = f.add(npyscreen.TitleText, name="Status: ", value=mem['status']) - self.mem2['von'] = f.add(npyscreen.TitleText, name="Von: ", value=mem['von']) - self.mem2['bis'] = f.add(npyscreen.TitleText, name="Bis: ", value=mem['bis']) - self.mem2['mitgliedsbeitrag'] = f.add(npyscreen.TitleText, name="Mitgliedsbeitrag: ", - value=mem['mitgliedsbeitrag']) - self.mem2['schliessberechtigung'] = f.add(npyscreen.TitleText, name="Schliessberechtigung: ", - value=mem['schliessberechtigung']) - self.mem2['scan-antrag'] = f.add(npyscreen.TitleText, name="URI Scan Antrag: ", - value=mem['scan-antrag']) + member_widgets = {} + member_widgets['status'] = f.add( + npyscreen.TitleText, name="Status: ", value=mem['status']) + member_widgets['von'] = f.add( + npyscreen.TitleText, name="Von: ", value=mem['von']) + member_widgets['bis'] = f.add( + npyscreen.TitleText, name="Bis: ", value=mem['bis']) + member_widgets['mitgliedsbeitrag'] = f.add(npyscreen.TitleText, name="Mitgliedsbeitrag: ", + value=mem['mitgliedsbeitrag']) + member_widgets['schliessberechtigung'] = f.add(npyscreen.TitleText, name="Schliessberechtigung: ", + value=mem['schliessberechtigung']) + member_widgets['scan-antrag'] = f.add(npyscreen.TitleText, name="URI Scan Antrag: ", + value=mem['scan-antrag']) + self.member_widgets = member_widgets f.edit() @@ -70,14 +82,33 @@ def main(*_args): else: member_struct = json.load(open('example.json', 'r')) app = FormApp(member_struct) - app.run() + try: + app.run() + except Exception as e: + print(e) + return 0 + new_data = {} - new_data['stammdaten'] = dict(zip(app.sd2.keys(), map(lambda f: f.value, app.sd2.values()))) - new_data['finanzdaten'] = dict(zip(app.fin2.keys(), map(lambda f: f.value, app.fin2.values()))) - new_data['mitgliederdaten'] = dict(zip(app.mem2.keys(), map(lambda f: f.value, app.mem2.values()))) + new_data['stammdaten'] = dict( + zip(app.base_data_widgets.keys(), map(lambda f: f.value, app.base_data_widgets.values()))) + new_data['finanzdaten'] = dict( + zip(app.finance_widgets.keys(), map(lambda f: f.value, app.finance_widgets.values()))) + new_data['mitgliederdaten'] = dict( + zip(app.member_widgets.keys(), map(lambda f: f.value, app.member_widgets.values()))) + + new_data['stammdaten'] = dict(zip(app.base_data_widgets.keys(), map(lambda f: f.value, app.base_data_widgets.values()))) + new_data['stammdaten']['address_label'] = \ + f"{new_data['stammdaten']['fullname']}\n\ +{new_data['stammdaten']['address_street']}\n\ +{new_data['stammdaten']['address_code']} {new_data['stammdaten']['address_locality']}" + + new_data['finanzdaten'] = dict(zip(app.finance_widgets.keys(), map(lambda f: f.value, app.finance_widgets.values()))) + new_data['mitgliederdaten'] = dict(zip(app.member_widgets.keys(), map(lambda f: f.value, app.member_widgets.values()))) + new_data['timestamp'] = datetime.datetime.now().replace(microsecond=0).isoformat() - outfile_name = '{}_{}.json'.format('_'.join(new_data['stammdaten']['fullname'].split()),datetime.datetime.now().replace(microsecond=0).isoformat()) + outfile_name = '{}_{}.json'.format('_'.join(new_data['stammdaten']['fullname'].split()), datetime.datetime.now().replace(microsecond=0).isoformat()) + with open(outfile_name, 'w') as outfile: json.dump(new_data, outfile, sort_keys=True, indent=4)