needlogin=true; $me = new User(); $me->loadMe(); $this->me = $me; $this->layout()->set("me",$me); if(!$me->is(["Admin", "salespartner"])) { $this->redirect("Dashboard"); } } protected function indexAction() { $rfilter = $this->request->filter; iF(!is_array($rfilter)) { $rfilter = []; } if(!array_key_exists("addresstype", $rfilter)) { $rfilter["addresstype"] = []; } if($this->request->resetFilter) { unset($_SESSION[MFAPPNAME.'-Address-filter']); } $filter = []; if(is_array($this->request->filter)) { $filter = $this->request->filter; $_SESSION[MFAPPNAME.'-Address-filter'] = $filter; } else { if(array_key_exists(MFAPPNAME.'-Address-filter', $_SESSION) && count($_SESSION[MFAPPNAME.'-Address-filter'])) { $filter = $_SESSION[MFAPPNAME.'-Address-filter']; } } $this->layout->set("filter", $filter); $filter = $this->getPreparedFilter($filter); // pagination defaults $pagination = []; $pagination['start'] = 0; $pagination['count'] = 25; $pagination['maxItems'] = 0; if(is_numeric($this->request->s)) { $pagination['start'] = intval($this->request->s); } //var_dump($filter);exit; $pagination['maxItems'] = AddressModel::count($filter); $addresses = AddressModel::search($filter, $pagination); $this->layout()->set("addresses", $addresses); $this->layout()->set("request", $this->request); $this->layout()->set("pagination", $pagination); $last_export = false; $bmd_export_ts = new mfConfig("bmd.export.ts"); if($bmd_export_ts->value()) { $last_export = $bmd_export_ts->value(); } $this->layout()->set("last_bmd_export", $last_export); return true; } private function getPreparedFilter($filter) { $new_filter = []; if(is_array($filter) && count($filter)) { $new_filter['add-where'] = ""; if(array_key_exists("kunde", $filter) && $filter["kunde"]) { $kunde = $this->db()->escape($filter['kunde']); $new_filter['add-where'] .= " AND (company like '%$kunde%' OR firstname like '%$kunde%' OR lastname like '%$kunde%' OR concat(firstname, ' ', lastname) like '%$kunde%' OR concat(lastname, ' ', firstname) like '%$kunde%')"; } if(!array_key_exists("parents_only", $filter)) { $new_filter["parents_only"] = 1; } if(array_key_exists("fibu_account_number", $filter) && $filter['fibu_account_number']) { $new_filter['fibu_or_supplier_account_number'] = $filter['fibu_account_number']."%"; unset($filter['fibu_account_number']); } if(!array_key_exists("customer_number", $filter) || !$filter["customer_number"]) { if(array_key_exists("type", $filter)) { if($filter["type"] == "xinon") { $new_filter["customer_or_fibu_numbers"] = true; } elseif($filter["type"] == "others") { $new_filter["customer_or_fibu_numbers"] = false; } } else { $new_filter["customer_or_fibu_numbers"] = true; // default } unset($filter["type"]); unset($filter["customer_number"]); } foreach($filter as $name => $value) { $new_filter[$name] = $value; } } return $new_filter; } protected function addAction() { $this->layout()->setTemplate("Address/Form"); $this->layout->set("filter", $this->request->filter); //$parents = AddressModel::search(['parent_id' => null]); //$this->layout()->set("parents", $parents); } protected function viewAction() { $this->layout()->setTemplate("Address/View"); $this->layout->set("filter", $this->request->filter); $this->layout->set("f", $this->request->f); $this->layout->set("s", $this->request->s); $address = new Address($this->request->id); $this->layout()->set("address", $address); if(!$address->id) { $this->layout()->setFlash("Addresse nicht gefunden", "error"); $this->redirect("Address"); } } protected function editAction() { $address = new Address($this->request->id); $this->layout->set("filter", $this->request->filter); $this->layout->set("f", $this->request->f); $this->layout->set("s", $this->request->s); $this->layout()->set("address", $address); if(!$address->id) { $this->layout()->setFlash("Addresse nicht gefunden", "error"); return $this->addAction(); } return $this->addAction(); } protected function deleteLink() { $id = $this->request->id; if(!is_numeric($id) || !$id) { $this->layout()->setFlash("Addresse nicht gefunden", "error"); $this->redirect("Address"); } $link = new AddressLink($id); if(!$link->id) { $this->layout()->setFlash("Addresse nicht gefunden", "error"); $this->redirect("Address"); } $address_id = $link->origin_address_id; $link->delete(); $this->layout()->setFlash("Verknüpfung erfolgreich entfernt", "success"); $this->redirect("Address", "edit", ['id' => $address_id]); } protected function exportBmdAction() { if(!$this->me->can("Fibu")) { $this->layout()->setFlash("Sicha ned!", "error"); $this->redirect("Address"); } $return = Address::runBmdExport($this->request->type); if($return === 10) { $this->layout()->setFlash("Export Pfad (".TT_ADDRESS_BMD_EXPORT_PATH.") nicht gefunden!", "error"); $this->redirect("Address"); } if($return === 11) { $this->layout()->setFlash("Keine geänderten Adressdatensätze gefunden. Export abgebrochen.", "warn"); $this->redirect("Address"); } if($return === 19) { $this->layout()->setFlash("Datei ".TT_ADDRESS_BMD_EXPORT_PATH."/".TT_ADDRESS_BMD_EXPORT_FILENAME." konnte nicht gespeichert werden!", "error"); $this->redirect("Address"); } if($return === true) { $this->layout()->setFlash("Adressen erfolgreich exportiert", "success"); $this->redirect("Address"); } } protected function saveAction() { $r = $this->request; $id = $r->id; //var_dump($r->get());exit; if(is_numeric($id) && $id > 0) { $mode = "edit"; $address = new Address($id); if(!$address->id) { $this->layout()->setFlash("Addresse nicht gefunden", "error"); $this->redirect("Address"); } } else { $mode = "add"; } //var_dump($r->addresstypes);exit; $data = []; $data['parent_id'] = (!$r->parent_id) ? null : $r->parent_id; $data['company'] = trim($r->company); $data['firstname'] = trim($r->firstname); $data['lastname'] = trim($r->lastname); $data['street'] = trim($r->street); $data['zip'] = trim($r->zip); $data['city'] = trim($r->city); $data['country_id'] = $r->country_id; $data['phone'] = trim($r->phone); $data['fax'] = trim($r->fax); $data['mobile'] = trim($r->mobile); $data['email'] = trim($r->email); $data['note'] = trim($r->note); $data['uid'] = trim($r->uid); if($this->me->can("Fibu")) { $data["sepa_date"] = ($r->sepa_date) ? Layout::dateToInt($r->sepa_date) : null; $data['fibu_account_number'] = ($r->fibu_account_number) ? trim($r->fibu_account_number) : null; $data['fibu_supplier_number'] = ($r->fibu_supplier_number) ? trim($r->fibu_supplier_number) : null; if($r->fibu_primary_account) { $data['fibu_primary_account'] = 1; } else { $data['fibu_primary_account'] = 0; } if($r->fibu_supplier_paymentblock) { $data['fibu_supplier_paymentblock'] = 1; } else { $data['fibu_supplier_paymentblock'] = 0; } $data['fibu_supplier_due'] = ($r->fibu_supplier_due) ? trim($r->fibu_supplier_due) : null; $data['fibu_supplier_skonto'] = ($r->fibu_supplier_skonto) ? trim($r->fibu_supplier_skonto) : null; $data['fibu_supplier_skonto_rate'] = ($r->fibu_supplier_skonto_rate) ? trim($r->fibu_supplier_skonto_rate) : null; } // billing data // validate sepa if(!$r->billing_type) { $this->layout()->setFlash("Ungültige Verrechnungsart."); $this->layout()->set("order", $r); return $this->add(); } if($r->billing_type == "sepa") { foreach(['owner', 'iban', 'bic'] as $required) { if(!$r->{"bank_account_$required"}) { $this->layout()->setFlash("Bitte Bankdaten für SEPA ausfüllen.", "warn"); $this->layout()->set("address", $r); return $this->add(); } } } if($r->billing_type == "sepa") { $data['billing_type'] = "sepa"; if(!$r->sepa_date) { if($mode == "add" || ($mode == "edit" && !$address->sepa_date)) { $data['sepa_date'] = date('U'); } } else { $data['sepa_date'] = Layout::dateToInt($r->sepa_date); } } else { $data['billing_type'] = "invoice"; } if($r->billing_delivery == "paper") { $data['billing_delivery'] = "paper"; } else { $data['billing_delivery'] = "email"; } $data['bank_account_bank'] = trim($r->bank_account_bank); $data['bank_account_owner'] = trim($r->bank_account_owner); $data['bank_account_iban'] = trim($r->bank_account_iban); $data['bank_account_bic'] = trim($r->bank_account_bic); $data['allow_contact'] = ($r->allow_contact) ? 1 : 0; $data['allow_spin'] = ($r->allow_spin) ? 1 : 0; $data['edit_by'] = 1; if($mode == "add") { $data['create_by'] = 1; $address = AddressModel::create($data); } else { $address->update($data); } //var_dump($address);exit; $new_id = $address->save(); if(!$new_id) { $this->layout()->setFlash("Fehler beim Speichern", "error"); $this->layout()->set("address", $address); return $this->add(); } // check for multiple primary fibu accounts, and remove from any other than this one if($address->fibu_primary_account && $address->fibu_account_number) { foreach(AddressModel::search(["fibu_primary_account" => true, "fibu_account_number" => $address->fibu_account_number]) as $fibu_primary) { if($fibu_primary->id == $address->id) continue; $fibu_primary->fibu_primary_account = 0; $fibu_primary->save(); } } // save address types $new_types = $r->addresstypes; if(is_array($new_types)) { foreach($address->types as $existing_type) { //var_dump($existing_type); //var_dump($new_types); //echo $existing_type->type; if(!in_array($existing_type->type, $new_types)) { $existing_type->delete(); } else { // remove existing type from new_types array (dont need to create again) $new_types = array_diff($new_types, [$existing_type->type]); //unset($new_types[$existing_type]); } } //exit; foreach($new_types as $type) { $type_object = AddresstypeModel::create(['address_id' => $address->id, 'type' => $type]); $type_object->save(); $address->types[$type] = $type_object; } } // generate new supplier account number if is supplier and supplier num empty //var_dump($mode, $address->fibu_supplier_number, $address->types);exit; if(!$address->fibu_supplier_number && array_key_exists("supplier", $address->types)) { $supplier_num = Address::getNextSupplierNumber(); if(!$supplier_num) { $this->layout()->setFlash("Lieferantennummer konnte nicht generiert werden."); } else { $this->log->debug("new supplier number: ". $supplier_num); $address->fibu_supplier_number = $supplier_num; $address->save(); } } $attribs = $r->attributes; //var_dump($attribs);exit; if(is_array($attribs) && count($attribs)) { foreach($attribs as $attrib => $value) { $aa = AddressattributeModel::getFirst(["address_id" => $new_id, "name" => $attrib]); if(!$aa) { $aa = AddressattributeModel::create(["address_id" => $new_id, "name" => $attrib]); } $aa->value = $value; $aa->save(); } } //$address->deleteLinks(); $existing_links = []; foreach(AddressLinkModel::search(['origin_address_id', $new_id]) as $elink) { $existing_links[$elink->address_id] = $elink; } //var_dump($r->links);exit; if(is_array($r->links) && count($r->links)) { //var_dump($r->links);exit; foreach($r->links as $linknum => $link) { if(!$link['type'] || !$link['address_id']) { continue; } if(array_key_exists($link['address_id'], $existing_links)) { continue; } $l = AddressLinkModel::create([ 'origin_address_id' => $new_id, 'type' => $link['type'], 'address_id' => $link['address_id'] ]); $l->save(); } } $sq = ""; $query = []; if($r->s) { $query['s'] = $r->s; } if($r->return != "index") { $query['id'] = $new_id; } $qs = http_build_query($query); $this->layout()->setFlash("Adresse erfolgreich gespeichert.", "success"); if($r->return == "index") { $this->redirect("Address", "Index", $qs); } if($r->f == "view") { $this->redirect("Address", "View", $qs); } $this->redirect("Address", "Edit", $qs); } protected function apiAction() { if(!$this->me->is(["Admin","salespartner"])) { $this->redirect("Dashboard"); } $do = $this->request->do; $data = []; switch($do) { case "getAddress": $return = $this->getAddressApi(); break; case "findAddress": $return = $this->findAddressApi(); break; case "validateIbanBic": $return = $this->validateIbanBicApi(); break; default: $return = false; } if(!is_array($return) || !count($return)) { $data = ["status" => "error"]; $this->returnJson($data); } $data['status'] = "OK"; $data['result'] = $return; $this->returnJson($data); } private function getAddressApi() { $id = trim($this->request->id); if(!is_numeric($id) || !$id) { return false; } $address = new Address($id); if(!$address->id) { return false; } $a = $address->toArray(); return ['address' => $a]; } private function findAddressApi() { $search = trim($this->request->q); $autocomplete = $this->request->autocomplete; $po = 1; $role = false; // if searching for billingaddress, set role and parents_only to 0 if($this->request->role == "billingaddress") { $role = "billing"; $po = 0; } if($this->request->role == "techcontact") { $role = "techcontact"; $po = 0; } $this->log->debug(print_r($this->request->get(),true)); $addresses = []; if(is_numeric($search)) { $cnumbers = AddressModel::search(["parents_only" => $po, "addresstype" => [$role], "customer_number" => $search]); if($cnumbers) { $addresses = array_merge($addresses, $cnumbers); } } $addresses = array_merge($addresses, AddressModel::search(["parents_only" => $po, "addresstype" => [$role], "mergedName" => $search])); $addresses = array_merge($addresses, AddressModel::search(["parents_only" => $po, "addresstype" => [$role], "company" => $search])); $addresses = array_merge($addresses, AddressModel::search(["parents_only" => $po, "addresstype" => [$role], "firstname" => $search])); $addresses = array_merge($addresses, AddressModel::search(["parents_only" => $po, "addresstype" => [$role], "lastname" => $search])); if(!is_array($addresses) || !count($addresses)) { return false; } $all_addresses = []; // remove duplicates foreach($addresses as $address) { if(!array_key_exists($address->id, $all_addresses)) { $all_addresses[$address->id] = $address; } } $results = []; if(!$autocomplete) { foreach($all_addresses as $id => $address) { $results[$id] = str_replace("'", "\\'", str_replace(["\n", "\r"], " ",$address->getCompanyOrName()))." (".$address->zip." ".$address->city.", ".$address->street.")".(($address->customer_number) ? " [".$address->customer_number."]" : ""); if(count($results) > 15) { $results["more"] = "..."; break; } } return ["addresses" => $results]; } // return bootstrap-autocomplete format foreach($all_addresses as $id => $address) { $result = ['value' => $id, 'text' => str_replace("'", "\\'", str_replace(["\n", "\r"], " ",$address->getCompanyOrName()))." (".$address->zip." ".$address->city.", ".$address->street.")".(($address->customer_number) ? " [".$address->customer_number."]" : "")]; $results[] = $result; if(count($results) > 15) { $results[] = ['value' => 0, 'text' => "  -->   Mehr Suchergebnisse vorhanden. Bitte Suchbegriff genauer definieren   <--"]; break; } } $this->returnJson($results); } private function validateIbanBicApi() { $iban = trim($this->request->iban); $bic = trim($this->request->bic); if(!$iban) { return false; } $result = IbanValidator::validate($iban, $bic); if(is_array($result) && $result) { return $result; } return false; } }