def get_termine_daten(): label = ('KiMu', 'KiVa', 'Kind', 'Paar', 'Familie', 'Soz.', 'Lehrer', 'Erz.', 'Hilfebespr.', 'Sonst.', 'Summe') namen = ('kkm', 'kkv', 'kki', 'kpa', 'kfa', 'ksoz', 'kleh', 'kerz', 'kkonf', 'kson', 'kat') items = [h.TextItem(label=lab, name=name, value=fs[name], class_='textboxmid', onBlur="set_term_sum_fachstat('%s')" % name, ) for lab, name in zip(label, namen)] kat = items[-1] kat.bold_label=True kat.bold_value=True if config.BERATUNGSKONTAKTE and not config.BERATUNGSKONTAKTE_BS: # wenn die Terminsumme aus den Beratungskontakten gleich der # Terminsumme in der Datenbank ist, nehmen wir an, dass die Daten # übernommen wurden und markieren das Kästchen. # Wenn nicht, sieht der Benutzer, dass die Daten nicht übernommen sind # und kann das Kästchen markieren, um sie erneut zu übernehmen. from ebkus.html.beratungskontakt import get_fs_kontakte pseudo_fs = {} fall_id = fs['fall_id'] if fall_id: fall = Fall(fall_id) get_fs_kontakte(fall, pseudo_fs) if pseudo_fs['kat'] == fs['kat'] == 0: # Übernahme ist nicht default bei neuer FS checked = False else: checked = pseudo_fs['kat'] == fs['kat'] else: checked = False checkitem = h.CheckItem(label="Aus Beratungskontakten übernehmen", name="uebernehmen", value='1', checked=checked, tip="Markieren, um Terminsummen aus Beratungskontakten zu übernehmen", ) else: checkitem = h.DummyItem() return [items[0:5]+[checkitem], items[5:10]+[kat]]
def processForm(self, REQUEST, RESPONSE): fallid = self.form.get('fallid') if not fallid: raise EE('Erstellen einer Fachstatistik nur für einen Fall moeglich.') fall = Fall(fallid) akte = fall['akte'] geschlecht = akte['gs'] if not geschlecht: raise EE("Bitte zuerst das Geschlecht in die Klientenkarte eintragen!") # Ich kanns mir nicht anders vorstellen: if akte['aktueller_fall']: assert fall['id'] == akte['aktueller_fall']['id'] == akte['letzter_fall']['id'] # das geht nicht immer weil Gleichheit nicht richtig definiert ist #assert fall == akte['letzter_fall'] == akte['aktueller_fall'] leistungen = fall['leistungen'] jahresl = ebapi.FachstatistikList(where = "fall_fn = '%s'" % fall['fn']) if jahresl: raise EE('Fachstatistik für den Fall schon vorhanden') fs = Fachstatistik() # Alter relativ zum Fallbeginn alter = calc_age(akte['gb'], fall.getDate('bg')) def altersgruppe(): ag = cc('fsag','999') try: ag = bcode('fsag', alter)['id'] except: pass # kein bereich gefunden return ag def altersgruppeeltern(verwcode): ag = cc('fsagel','999') try: for b in akte['bezugspersonen']: if b['verw__code'] == verwcode: if b['gb']: alter = calc_age(b['gb'], fall.getDate('bg')) ag = bcode('fsagel', alter)['id'] except: pass # kein valides Geburtsdatum gefunden return ag if config.STRASSENKATALOG: strasse = get_strasse(akte) else: strasse = {} fs.init( id=Fachstatistik().getNewId(), mit_id=fall['zustaendig__mit_id'], fall_id=fall['id'], fall_fn=fall['fn'], jahr=str(today().year), stz=akte['stzbg'], plraum=akte['plraum'], ort=akte['ort'], plz=akte['plz'], ortsteil=strasse.get('ortsteil', ''), bezirk=strasse.get('bezirk', ''), samtgemeinde=strasse.get('samtgemeinde', ''), gs=akte['gs'], ag=altersgruppe(), agkm=altersgruppeeltern('1'), # code klerv für Mutter agkv=altersgruppeeltern('2'), # code klerv für Vater fs=akte['fs'], anmprobleme=None, kindprobleme=None, elternprobleme=None, ) fs['eleistungen'] = ' '.join([str(leist['le']) for leist in leistungen]) single_kat_felder = ('zm', 'qualij', 'hkm', 'hkv', 'bkm', 'bkv', 'qualikm', 'qualikv', 'ba1', 'ba2', 'pbe', 'pbk', ) for f in single_kat_felder: fs[f] = ' ' # leere, selektierte Option, es muss aktiv ausgewählt werden # falls unter 14 Beschäftigung vorbelegen try: if alter < 14: fs['qualij'] = cc('fsqualij', '7') except: pass anm = fall['anmeldung'] if anm: fs['zm'] = anm[0]['zm'] joker_felder = ('joka1', 'joka2', 'joka3', 'joka4', 'jokf5', 'jokf6', 'jokf7', 'jokf8',) for f in joker_felder: if fs_customize.multifeld(f): fs[f] = None else: fs[f] = ' ' # leere, selektierte Option, es muss aktiv ausgewählt werden termin_felder = ('kkm', 'kkv', 'kki', 'kpa', 'kfa', 'ksoz', 'kleh', 'kerz', 'kkonf', 'kson', 'kat',) if config.BERATUNGSKONTAKTE and not config.BERATUNGSKONTAKTE_BS: from ebkus.html.beratungskontakt import get_fs_kontakte get_fs_kontakte(fall, fs) else: for f in termin_felder: fs[f] = 0 #print '***********FSNEU', fs return self._process(title='Neue Fachstatistik erstellen', file='fseinf', fs=fs, )