451 lines
28 KiB
PHP
451 lines
28 KiB
PHP
<?php
|
|
$pagination_baseurl = $this->getUrl($Mod,"Index");
|
|
$pagination_baseurl_params = ["filter" => $filter];
|
|
$pagination_entity_name = "Produkte";
|
|
?>
|
|
<?php include(realpath(dirname(__FILE__)."/../../$mfLayoutPackage")."/header.php"); ?>
|
|
|
|
<!-- start page title -->
|
|
<div class="row">
|
|
<div class="col-12">
|
|
<div class="page-title-box">
|
|
<div class="page-title-right">
|
|
<ol class="breadcrumb m-0">
|
|
<li class="breadcrumb-item"><a href="<?=self::getUrl("Dashboard")?>"><?=MFAPPNAME_SLUG?></a></li>
|
|
<li class="breadcrumb-item active">Fertiggestellte Bestellungen</li>
|
|
</ol>
|
|
</div>
|
|
<h4 class="page-title">Contractfreigabe</h4>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
<!-- end page title -->
|
|
|
|
<div class="row">
|
|
<div class="col-lg-12">
|
|
|
|
<div class="card">
|
|
<div class="card-body mb-3">
|
|
<h4 class="header-title mb-3">Filter</h4>
|
|
|
|
<form method="get" action="<?=self::getUrl("Contractqueue")?>">
|
|
<div class="row">
|
|
|
|
<div class="col-1">
|
|
<label class="form-label" for="filter_owner">Kundennummer</label>
|
|
<input type="text" class="form-control" name="filter[customer_number]" id="filter_street" value="<?=(array_key_exists("customer_number", $filter)) ? $filter['customer_number'] : ""?>" />
|
|
</div>
|
|
|
|
<div class="col-1">
|
|
<label class="form-label" for="filter_owner">Inhaber Name</label>
|
|
<input type="text" class="form-control" name="filter[owner]" id="filter_street" value="<?=(array_key_exists("owner", $filter)) ? $filter['owner'] : ""?>" />
|
|
</div>
|
|
|
|
<div class="col-1">
|
|
<label class="form-label" for="filter_billingaddress">Rech.Empfänger</label>
|
|
<input type="text" class="form-control" name="filter[billingaddress]" id="filter_billingaddress" value="<?=(array_key_exists("billing_address", $filter)) ? $filter['billingaddress'] : ""?>" />
|
|
</div>
|
|
|
|
<div class="col-1">
|
|
<label class="form-label" for="filter_product_group">Produktgruppe</label>
|
|
<input type="text" class="form-control" name="filter[product_group]" id="filter_product_group" value="<?=(array_key_exists("product_group", $filter)) ? $filter['product_group'] : ""?>" />
|
|
</div>
|
|
|
|
<div class="col-1">
|
|
<label class="form-label" for="filter_product_name">Produkt</label>
|
|
<input type="text" class="form-control" name="filter[product_name]" id="filter_product_name" value="<?=(array_key_exists("product_name", $filter)) ? $filter['product_name'] : ""?>" />
|
|
</div>
|
|
|
|
</div>
|
|
<div class="row mt-2">
|
|
<div class="col">
|
|
<button type="submit" class="btn btn-primary">Filter anwenden</button>
|
|
<a class="btn btn-secondary" href="<?=self::getUrl("Contractqueue")?>?resetFilter=1">Filter zurücksetzen</a>
|
|
</div>
|
|
<!--<div class="col">
|
|
<button class="btn btn-info" type="button" onclick="refreshMap()"><i class="far fa-map"></i> Auf Karte anzeigen</button>
|
|
</div>-->
|
|
</div>
|
|
</form>
|
|
|
|
</div>
|
|
</div>
|
|
|
|
<div class="card">
|
|
<div class="card-body mb-3">
|
|
<div class="row">
|
|
<div class="col-12">
|
|
<div class="float-left">
|
|
<h4 class="header-title">Fertiggestellte Bestellungen</h4>
|
|
</div>
|
|
<div class="float-right">
|
|
<a class="btn btn-primary mb-2" href="<?=self::getUrl("Contractqueue", "importFinishedOrders")?>"><i class="fas fa-fw fa-file-import"></i> Fertiggestellte Bestellungen importieren</a>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
|
|
<?php include(realpath(dirname(__FILE__)."/../")."/tpl/pagination.php"); ?>
|
|
<?php include(realpath(dirname(__FILE__)."/../")."/tpl/pagination-summary.php"); ?>
|
|
|
|
<?php $i = 0; foreach($orders as $order_id => $contracts): ?>
|
|
<?php $order = $contracts[0]->orderproduct->order; ?>
|
|
|
|
<div class="row">
|
|
<div class="col-12">
|
|
<div class="card border-top-success">
|
|
<div class="card-header">
|
|
<span class="float-right order-date-pill active mr-2 mt-1">Fertigstellung: <span class="text-monospace font-weight-bold"><?=date("d.m.Y", $order->finish_date)?></span></span>
|
|
<span class="float-right order-date-pill active mr-2 mt-1">Zuletzt bearbeitet: <span class="text-monospace font-weight-bold"><?=date("d.m.Y H:i", $order->edit)?> (<?=$order->editor?>)</span></span>
|
|
<span class="float-right order-date-pill active mr-2 mt-1">Erstellt: <span class="text-monospace font-weight-bold"><?=date("d.m.Y H:i", $order->create)?> (<?=$order->creator?>)</span></span>
|
|
|
|
<h4><a href="<?=self::getUrl("Order", "", ["id" => $order_id])?>" target="_blank">Bestellung <?=$order_id?></a></h4>
|
|
</div>
|
|
<div class="card-body bg-light">
|
|
|
|
<div class="row">
|
|
|
|
<div class="col-6">
|
|
<div class="card">
|
|
<div class="card-body">
|
|
<div>
|
|
<span class="float-right"><i class="fas fa-fw fa-pencil pointer text-primary" onclick="toggleEdit('owner', <?=$order_id?>, false)"></i></span>
|
|
<h5 class="m-0">Inhaber</h5>
|
|
|
|
</div>
|
|
<hr class="mt-1" />
|
|
<span class="text-monospace"><?=$order->owner->customer_number?></span><br />
|
|
<strong><?=$order->owner->getCompanyOrName()?></strong><br />
|
|
<?=$order->owner->street?><br />
|
|
<?=$order->owner->zip?> <?=$order->owner->city?><br />
|
|
</div>
|
|
</div>
|
|
|
|
<div class="card">
|
|
<div class="card-body">
|
|
<div>
|
|
<span class="float-right"><i class="fas fa-fw fa-pencil pointer text-primary" onclick="toggleEdit('billingaddress', <?=$order_id?>, false)"></i></span>
|
|
<h5 class="m-0">Rechnungsempfänger</h5>
|
|
<hr class="mt-1" />
|
|
</div>
|
|
<?php if($order->billingaddress_id): ?>
|
|
<?=($order->billingaddress->customer_number) ? $order->billingaddress->customer_number."<br />" : ""?>
|
|
<?=$order->billingaddress->getCompanyOrName()?><br />
|
|
<?=$order->billingaddress->street?><br />
|
|
<?=$order->billingaddress->zip?> <?=$order->billingaddress->city?><br />
|
|
<?php endif; ?>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
|
|
<div class="col-6">
|
|
<div class="card mb-1">
|
|
<div class="card-body">
|
|
<h5 class="m-0">Bestelljournal</h5>
|
|
|
|
<table class="table table-sm table-striped mt-1 mb-0">
|
|
<tr>
|
|
<th>Erstellt</th>
|
|
<th>Text</th>
|
|
</tr>
|
|
<?php foreach($order->journals as $journal): ?>
|
|
<tr>
|
|
<td class="text-monospace"><?=date("d.m.Y H:i", $journal->create)?> (<?=$journal->creator?>)</td>
|
|
<td><?=nl2br($journal->text)?></td>
|
|
</tr>
|
|
<?php endforeach; ?>
|
|
</table>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
|
|
|
|
|
|
</div>
|
|
<?php if(trim($order->note)): ?>
|
|
<div class="row">
|
|
<div class="col">
|
|
<div class="card">
|
|
<div class="card-body">
|
|
<h5 class="m-0">Interne Notiz</h5>
|
|
<hr class="mt-1">
|
|
<?=nl2br(htmlentities($order->note))?>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
<?php endif; ?>
|
|
<div class="row">
|
|
|
|
<div class="col-12">
|
|
<div class="card">
|
|
<div class="card-body">
|
|
|
|
<h5>Produkte</h5>
|
|
<table class="table table-striped table-hover" id="order-products-<?=$order_id?>">
|
|
<tr>
|
|
<th style="width:56px;"><input type="checkbox" class="form-control pointer checkbox-toggle" onclick="toggleOrderApproval(this, <?=$order_id?>, 'order')" /></th>
|
|
<th>Produkt</th>
|
|
<th>Matchcode</th>
|
|
<th>Preis</th>
|
|
<th>Preis Setup</th>
|
|
<th>Rechnungsperiode</th>
|
|
<th>Verz. Verrechnungsstart</th>
|
|
<th>Erstellt</th>
|
|
<th>Zuletzt bearbeitet</th>
|
|
</tr>
|
|
|
|
<?php foreach($contracts as $contract): ?>
|
|
<tr id="contract-<?=$contract->id?>">
|
|
<td><input type="checkbox" class="form-control pointer" id="approve-order-<?=$order_id?>-contract-<?=$contract->id?>" onclick="toggleApproval(<?=$order_id?>, 'order')" <?=($contract->approved) ? "checked='checked'" : ""?> /></td>
|
|
<td class="text-wrap product">
|
|
<div class="text">
|
|
<i class="fas fa-fw fa-pencil pointer text-primary" onclick="toggleEdit('contract', <?=$contract->id?>, 'product')"></i> <?=$contract->product_name?>
|
|
<?php if($contract->termination_id && $contract->termination): ?>
|
|
<br /><small class="text-pink"><?=$contract->termination->code?> - <?= str_replace("\n", " - ", $contract->termination->getAddress())?></small>
|
|
<?php endif ?>
|
|
</div>
|
|
<div class="edit hidden">
|
|
<div class="input-group mb-3">
|
|
<select class="edit-control form-control" data-val="<?=$contract->product_id?>" data-ov="<?=$contract->product_id?>"></select>
|
|
<div class="input-group-append">
|
|
<button class="btn btn-primary"><i class="fas fa-check"></i></button>
|
|
<button class="btn btn-secondary" onclick="toggleEdit('contract', <?=$contract->id?>, 'product')"><i class="fas fa-times"></i></button>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</td>
|
|
<td class="matchcode">
|
|
<div class="text">
|
|
<i class="fas fa-fw fa-pencil pointer text-primary" onclick="toggleEdit('contract', <?=$contract->id?>, 'matchcode')"></i> <?= htmlentities($contract->matchcode)?>
|
|
</div>
|
|
<div class="edit hidden">
|
|
<div class="input-group mb-3">
|
|
<input type="text" class="form-control edit-control" value="<?=$contract->matchcode?>" data-val="<?=htmlentities($contract->matchcode)?>" data-ov="<?=htmlentities($contract->matchcode)?>" />
|
|
<div class="input-group-append">
|
|
<button class="btn btn-primary"><i class="fas fa-check"></i></button>
|
|
<button class="btn btn-secondary" onclick="toggleEdit('contract', <?=$contract->id?>, 'matchcode')"><i class="fas fa-times"></i></button>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</td>
|
|
<td class="price">
|
|
<div class="text"><i class="fas fa-fw fa-pencil pointer text-primary" onclick="toggleEdit('contract', <?=$contract->id?>, 'price')"></i> € <?=$contract->price?></div>
|
|
<div class="edit hidden">
|
|
<div class="input-group mb-3">
|
|
<input type="text" class="form-control edit-control" value="<?=$contract->price?>" data-val="<?=$contract->price?>" data-ov="<?=$contract->price?>" />
|
|
<div class="input-group-append">
|
|
<button class="btn btn-primary"><i class="fas fa-check"></i></button>
|
|
<button class="btn btn-secondary" onclick="toggleEdit('contract', <?=$contract->id?>, 'price')"><i class="fas fa-times"></i></button>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</td>
|
|
<td class="price_setup">
|
|
<div class="text"><i class="fas fa-fw fa-pencil pointer text-primary" onclick="toggleEdit('contract', <?=$contract->id?>, 'price_setup')"></i> € <?=$contract->price_setup?></div>
|
|
<div class="edit hidden">
|
|
<div class="input-group mb-3">
|
|
<input type="text" class="form-control edit-control" value="<?=$contract->price_setup?>" data-val="<?=$contract->price_setup?>" data-ov="<?=$contract->price_setup?>" />
|
|
<div class="input-group-append">
|
|
<button class="btn btn-primary"><i class="fas fa-check"></i></button>
|
|
<button class="btn btn-secondary" onclick="toggleEdit('contract', <?=$contract->id?>, 'price_setup')"><i class="fas fa-times"></i></button>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</td>
|
|
<td class="billing_period">
|
|
<div class="text">
|
|
<i class="fas fa-fw fa-pencil pointer text-primary" onclick="toggleEdit('contract', <?=$contract->id?>, 'billing_period')"></i>
|
|
<?php if($contract->billing_period == 1): ?>
|
|
monatlich
|
|
<?php elseif($contract->billing_period == 24): ?>
|
|
biennal
|
|
<?php elseif($contract->billing_period == 36): ?>
|
|
triennal
|
|
<?php else: ?>
|
|
<?=(12 / $contract->billing_period)?>x Jährlich
|
|
<?php endif; ?>
|
|
</div>
|
|
<div class="edit hidden">
|
|
<div class="input-group mb-3">
|
|
<select class="edit-control form-control" data-val="<?=$contract->product_id?>" data-ov="<?=$contract->product_id?>">
|
|
<option value="1" <?=($contract->billing_period == 1) ? "selected='selected'" : ""?>>Monatlich</option>
|
|
<option value="12" <?=($contract->billing_period == 12) ? "selected='selected'" : ""?>>Jährlich</option>
|
|
<option value="24" <?=($contract->billing_period == 24) ? "selected='selected'" : ""?>>2-Jährlich</option>
|
|
<option value="36" <?=($contract->billing_period == 36) ? "selected='selected'" : ""?>>3-Jährlich</option>
|
|
</select>
|
|
<div class="input-group-append">
|
|
<button class="btn btn-primary"><i class="fas fa-check"></i></button>
|
|
<button class="btn btn-secondary" onclick="toggleEdit('contract', <?=$contract->id?>, 'billing_period')"><i class="fas fa-times"></i></button>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</td>
|
|
<td class="billing_delay">
|
|
<div class="text"><i class="fas fa-fw fa-pencil pointer text-primary" onclick="toggleEdit('contract', <?=$contract->id?>, 'billing_delay')"></i> <?=($contract->billing_delay) ? $contract->billing_delay." Monate" : ""?></div>
|
|
<div class="edit hidden">
|
|
<div class="input-group mb-3">
|
|
<input type="text" class="form-control edit-control" value="<?=$contract->billing_delay?>" data-val="<?=$contract->billing_delay?>" data-ov="<?=$contract->billing_delay?>" />
|
|
<div class="input-group-append">
|
|
<button class="btn btn-primary"><i class="fas fa-check"></i></button>
|
|
<button class="btn btn-secondary" onclick="toggleEdit('contract', <?=$contract->id?>, 'billing_delay')"><i class="fas fa-times"></i></button>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</td>
|
|
<td class="text-monospace"><?=date('d.m.Y H:i', $contract->orderproduct->create)?><br /><?=$contract->orderproduct->creator->name?></td>
|
|
<td class="text-monospace"><?=date('d.m.Y H:i', $contract->orderproduct->edit)?><br /><?=$contract->orderproduct->editor->name?></td>
|
|
</tr>
|
|
<?php endforeach; ?>
|
|
</table>
|
|
|
|
<h5>Gutschriften / Provisionen</h5>
|
|
<table class="table table-striped table-hover" id="credit-products-<?=$order_id?>">
|
|
<tr>
|
|
<th style="width:56px;"><input type="checkbox" class="form-control pointer checkbox-toggle" onclick="toggleOrderApproval(this, <?=$order_id?>, 'credit')" /></th>
|
|
<th>Bezieher</th>
|
|
<th>Produkt</th>
|
|
<th>Matchcode</th>
|
|
<th>Provision</th>
|
|
<th>Rechnungsperiode</th>
|
|
<th>Verz. Verrechnungsstart</th>
|
|
</tr>
|
|
|
|
<?php foreach($contracts as $contract): ?>
|
|
<?php $credit = $contract->getCredit(); if(!$credit) continue; ?>
|
|
<tr id="credit-<?=$contract->id?>">
|
|
<td><input type="checkbox" class="form-control pointer" id="approve-credit-<?=$order_id?>-contract-<?=$contract->id?>" onclick="toggleApproval(<?=$order_id?>, 'credit')" <?=($contract->approved) ? "checked='checked'" : ""?> /></td>
|
|
<td><?=($credit["partner"]) ? $credit["partner"]->getCompanyOrName() : ""?></td>
|
|
<td class="text-wrap">
|
|
<?=$contract->product_name?>
|
|
<?php if($contract->termination_id && $contract->termination): ?>
|
|
<br /><small class="text-pink"><?=$contract->termination->code?> - <?= str_replace("\n", " - ", $contract->termination->getAddress())?></small>
|
|
<?php endif ?>
|
|
</td>
|
|
<td class="matchcode">
|
|
<div class="text">
|
|
<i class="fas fa-fw fa-pencil pointer text-primary" onclick="toggleEdit('credit', <?=$contract->id?>, 'matchcode')"></i> <?=$contract->matchcode?>
|
|
</div>
|
|
<div class="edit hidden">
|
|
<div class="input-group mb-3">
|
|
<input type="text" class="form-control edit-control" value="<?=$contract->matchcode?>" data-val="<?=$contract->matchcode?>" data-ov="<?=$contract->matchcode?>" />
|
|
<div class="input-group-append">
|
|
<button class="btn btn-primary"><i class="fas fa-check"></i></button>
|
|
<button class="btn btn-secondary" onclick="toggleEdit('credit', <?=$contract->id?>, 'matchcode')"><i class="fas fa-times"></i></button>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</td>
|
|
<td><?=($credit["rate_source"] == "rate") ? "€ ".$credit["rate"] : "€ ".$contract->price_nne?> <?=($credit["rate_source"] == "rate") ? "(Prozentrate)" : "(NNE)"?></td>
|
|
<td>
|
|
<?php if($contract->billing_period == 1): ?>
|
|
monatlich
|
|
<?php elseif($contract->billing_period == 24): ?>
|
|
biennal
|
|
<?php elseif($contract->billing_period == 36): ?>
|
|
triennal
|
|
<?php else: ?>
|
|
<?=(12 / $contract->billing_period)?>x Jährlich
|
|
<?php endif; ?>
|
|
</td>
|
|
<td class=""><?=($contract->billing_delay) ? $contract->billing_delay." Monate" : ""?></td>
|
|
</tr>
|
|
<?php endforeach; ?>
|
|
</table>
|
|
|
|
|
|
</div>
|
|
</div>
|
|
</div>
|
|
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
<?php $i++; endforeach; ?>
|
|
|
|
<?php include(realpath(dirname(__FILE__)."/../")."/tpl/pagination-summary.php"); ?>
|
|
<?php include(realpath(dirname(__FILE__)."/../")."/tpl/pagination.php"); ?>
|
|
|
|
</div>
|
|
</div>
|
|
|
|
</div>
|
|
</div>
|
|
|
|
|
|
<script type="text/javascript">
|
|
<?php
|
|
$prods = [];
|
|
foreach(ProductModel::getActive() as $product):
|
|
$prods[] = ["id" => $product->id, "name" => $product->name];
|
|
endforeach;
|
|
?>
|
|
|
|
var products = <?=json_encode($prods)?>;
|
|
|
|
function toggleOrderApproval(cbox, order_id, type) {
|
|
if(!parseInt(order_id) || !order_id) return;
|
|
|
|
//var checked_count = $("#order-products-" + order_id + " input[id^='approve-contract-']:checked").length;
|
|
|
|
if($(cbox).is(":checked")) {
|
|
$("#" + type + "-products-" + order_id + " input[id^='approve-" + type + "-" + order_id + "-contract-']").prop('checked', true);
|
|
} else {
|
|
$("#" + type + "-products-" + order_id + " input[id^='approve-" + type + "-" + order_id + "-contract-']").prop('checked', false);
|
|
}
|
|
}
|
|
|
|
function toggleApproval(order_id, type) {
|
|
if(!parseInt(order_id) || !order_id) return;
|
|
|
|
console.log("#" + type + "-products-" + order_id + " input[id^='approve-" + order_id + "-contract-']");
|
|
|
|
var box_count = $("#" + type + "-products-" + order_id + " input[id^='approve-" + type + "-" + order_id + "-contract-']").length;
|
|
var checked_count = $("#" + type + "-products-" + order_id + " input[id^='approve-" + type + "-" + order_id + "-contract-']:checked").length;
|
|
|
|
console.log("box_count: " + box_count + " checked_count: " + checked_count);
|
|
|
|
if(checked_count == box_count) {
|
|
$("#" + type + "-products-" + order_id + " .checkbox-toggle").prop("checked", true);
|
|
}
|
|
if(checked_count < box_count) {
|
|
$("#" + type + "-products-" + order_id + " .checkbox-toggle").prop("checked", false);
|
|
}
|
|
}
|
|
|
|
function toggleEdit(type, id, control_name) {
|
|
var textBlock = $("#" + type + "-" + id + " ." + control_name + " .text");
|
|
var editBlock = $("#" + type + "-" + id + " ." + control_name + " .edit");
|
|
|
|
var control = $("#" + type + "-" + id + " ." + control_name + " .edit .edit-control");
|
|
|
|
var current_val = control.data("val");
|
|
var original_val = control.data("ov");
|
|
|
|
textBlock.toggle();
|
|
editBlock.toggle();
|
|
|
|
if(type == "owner" || type == "billingaddress") {
|
|
return;
|
|
}
|
|
|
|
if(control_name == "product") {
|
|
if(!control.children().length) {
|
|
products.forEach((product) => {
|
|
var opt = document.createElement("option");
|
|
opt.text = product.name;
|
|
opt.value = product.id;
|
|
control.append(opt);
|
|
});
|
|
console.log(current_val);
|
|
control.val(current_val);
|
|
}
|
|
|
|
return;
|
|
}
|
|
|
|
}
|
|
|
|
</script>
|
|
<?php include(realpath(dirname(__FILE__)."/../../$mfLayoutPackage")."/footer.php"); ?>
|