Files
thetool/application/Address/AddressController.php
2024-08-20 15:37:57 +02:00

628 lines
19 KiB
PHP

<?php
class AddressController extends mfBaseController {
private $filter;
protected function init() {
$this->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);
//var_dump($address->links_to);exit;
if(!$address->id) {
$this->layout()->setFlash("Addresse nicht gefunden", "error");
$this->redirect("Address");
}
}
protected function invoiceAction() {
$this->layout()->setTemplate("Address/invoice");
$address_id = $this->request->address_id;
if(!is_numeric($address_id) || $address_id < 1) {
$this->layout()->setFlash("Addresse nicht gefunden", "error");
$this->redirect("Address");
}
$address = new Address($address_id);
if(!$address->id) {
$this->layout()->setFlash("Addresse nicht gefunden", "error");
$this->redirect("Address");
}
$invoices = InvoiceModel::search(["owner_or_billingaddress_id" => $address->id], false, "invoice_date DESC");
$this->layout()->set("invoices", $invoices);
$this->layout()->set("address", $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(trim($r->birthdate)) {
try {
$data["birthdate"] = (DateTime::createFromFormat("d.m.Y", trim($r->birthdate)))->format("Y-m-d");
} catch(Exception $e) {
$this->layout()->setFlash("Ungültiges Geburtsdaum", "warning");
}
}
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();
$a['name'] = $address->getCompanyOrName();
return ['address' => $a];
}
private function findAddressApi() {
$search = trim($this->request->q);
$autocomplete = $this->request->autocomplete;
if($autocomplete && $this->request->searchedID) {
$address = new Address($this->request->searchedID);
if($address->id) {
$result = [
'value' => $address->id,
'text' => str_replace("'", "\\'", str_replace(["\n", "\r"], " ",$address->getCompanyOrName()))." (".$address->zip." ".$address->city.", ".$address->street.")".(($address->customer_number) ? " [".$address->customer_number."]" : "")
];
$results[] = $result;
$this->returnJson($results);
}
}
$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' => "&nbsp;&nbsp;--> &nbsp;&nbsp;Mehr Suchergebnisse vorhanden. Bitte Suchbegriff genauer definieren &nbsp;&nbsp;<--"];
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;
}
}