WIP Voiceplan Zones
This commit is contained in:
@@ -68,6 +68,7 @@
|
||||
<tr>
|
||||
<th>Name</th>
|
||||
<th>Beschreibung</th>
|
||||
<th>Anzahl Tarifzonen</th>
|
||||
<th>Anzahl Destinations</th>
|
||||
<th>Erstellt</th>
|
||||
<th></th>
|
||||
@@ -76,7 +77,8 @@
|
||||
<tr>
|
||||
<td><a href="<?=self::getUrl("Voiceplan", "view", ['id' => $plan->id])?>"><?=$plan->name?></a></td>
|
||||
<td><?=$plan->description?></td>
|
||||
<td><?=VoiceplandestinationModel::count(['voiceplan_id' => $plan->id])?></td>
|
||||
<td><?=count($plan->zones)?></td>
|
||||
<td><?=count($plan->destinations)?></td>
|
||||
<td><?=date("d.m.Y H:i", $plan->create)?> (<?=$plan->creator->name?>)</td>
|
||||
<td style="text-align: left; letter-spacing: 4px; font-size: 1.1em;">
|
||||
<a href="<?=self::getUrl("Voiceplan", "view", ["id" => $plan->id])?>"><i class="far fa-eyes" title="Anzeigen"></i></a>
|
||||
|
||||
@@ -16,7 +16,7 @@
|
||||
<li class="breadcrumb-item active"><?=$plan->name?></li>
|
||||
</ol>
|
||||
</div>
|
||||
<h4 class="page-title">Sprachtarife</h4>
|
||||
<h4 class="page-title">Tarifzonen</h4>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
@@ -30,10 +30,10 @@
|
||||
<div class="row">
|
||||
<div class="col-12">
|
||||
<div class="float-left">
|
||||
<h4 class="header-title">Destinations für Sprachtarifpaket <?=$plan->name?></h4>
|
||||
<h4 class="header-title">Tarifzonen für Sprachtarifpaket <?=$plan->name?></h4>
|
||||
</div>
|
||||
<div class="float-right">
|
||||
<a class="btn btn-primary mb-2" href="<?=self::getUrl("Voiceplandestination", "add", ["voiceplan_id" => $plan->id])?>"><i class="fas fa-plus"></i> Neue Destination anlegen</a>
|
||||
<a class="btn btn-primary mb-2" href="<?=self::getUrl("Voiceplanzone", "add", ["voiceplan_id" => $plan->id])?>"><i class="fas fa-plus"></i> Neue Tarifzone anlegen</a>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
@@ -43,8 +43,8 @@
|
||||
|
||||
<table class="table table-striped table-hover">
|
||||
<tr>
|
||||
<th>Destination</th>
|
||||
<th>Prefix</th>
|
||||
<th>Zone</th>
|
||||
<th>Anzahl Prefixes</th>
|
||||
<th>Taktung</th>
|
||||
<th>Einkaufspreis</th>
|
||||
<th>Verkaufspreis</th>
|
||||
@@ -52,19 +52,19 @@
|
||||
<th>Bearbeitet</th>
|
||||
<th></th>
|
||||
</tr>
|
||||
<?php foreach($destinations as $destination): ?>
|
||||
<?php foreach($zones as $zone): ?>
|
||||
<tr>
|
||||
<td><?=$destination->destination?></td>
|
||||
<td><?=$destination->prefix?></td>
|
||||
<td><?=($destination->increment_first && $destination->increment) ? "$destination->increment_first"."/".$destination->increment : ""?></td>
|
||||
<td><?=$destination->purchase_price?></td>
|
||||
<td><?=$destination->price?></td>
|
||||
<td><a href="<?=self::getUrl("Voiceplanzone", "view", ["id" => $zone->id])?>"><?=$zone->name?></a></td>
|
||||
<td><?=count($zone->destinations)?></td>
|
||||
<td><?=($zone->increment_first && $zone->increment) ? $zone->increment_first."/".$zone->increment : ""?></td>
|
||||
<td><?=$zone->purchase_price?></td>
|
||||
<td><?=$zone->price?></td>
|
||||
<td><?=date("d.m.Y H:i", $plan->create)?> (<?=$plan->creator->name?>)</td>
|
||||
<td><?=date("d.m.Y H:i", $plan->edit)?> (<?=$plan->editor->name?>)</td>
|
||||
<td style="text-align: left; letter-spacing: 4px; font-size: 1.1em;">
|
||||
<a href="<?=self::getUrl("Voiceplandestination", "view", ["id" => $destination->id])?>"><i class="far fa-eyes" title="Anzeigen"></i></a>
|
||||
<a href="<?=self::getUrl("Voiceplandestination", "edit", ["id" => $destination->id])?>"><i class="far fa-edit" title="Bearbeiten"></i></a>
|
||||
<a href="<?=self::getUrl("Voiceplandestination", "delete", ["id" => $destination->id])?>" onclick="if(!confirm('Destination wirklich löschen?')) return false;" class="text-danger" title="Löschen"><i class="fas fa-trash"></i></a>
|
||||
<a href="<?=self::getUrl("Voiceplanzone", "view", ["id" => $zone->id])?>"><i class="far fa-eyes" title="Prefixes anzeigen"></i></a>
|
||||
<a href="<?=self::getUrl("Voiceplanzone", "edit", ["id" => $zone->id])?>"><i class="far fa-edit" title="Zone bearbeiten"></i></a>
|
||||
<a href="<?=self::getUrl("Voiceplanzone", "delete", ["id" => $zone->id])?>" onclick="if(!confirm('Tarifzone wirklich löschen?')) return false;" class="text-danger" title="Löschen"><i class="fas fa-trash"></i></a>
|
||||
</td>
|
||||
</tr>
|
||||
<?php endforeach; ?>
|
||||
|
||||
@@ -7,7 +7,8 @@
|
||||
<ol class="breadcrumb m-0">
|
||||
<li class="breadcrumb-item"><a href="<?=self::getUrl("Dashboard")?>"><?=MFAPPNAME_SLUG?></a></li>
|
||||
<li class="breadcrumb-item"><a href="<?=self::getUrl("Voiceplan")?>">Sprachtarife</a></li>
|
||||
<li class="breadcrumb-item"><a href="<?=self::getUrl("Voiceplan", "view", ["id" => $voiceplan->id])?>"></a></li>
|
||||
<li class="breadcrumb-item"><a href="<?=self::getUrl("Voiceplan", "view", ["id" => $zone->voiceplan_id])?>">Sprachtarif <?=$zone->voiceplan->name?></a></li>
|
||||
<li class="breadcrumb-item active">Destinationen Tarifzone <?=$zone->name?></li>
|
||||
<li class="breadcrumb-item active"><?=($plan->id) ? "Destination ".$destination->destination." bearbeiten" : "Neu" ?></li>
|
||||
</ol>
|
||||
</div>
|
||||
@@ -31,19 +32,16 @@
|
||||
<input type="hidden" name="id" value="<?=$destination->id?>" />
|
||||
|
||||
<div class="form-group row">
|
||||
<label class="col-lg-2 col-form-label" for="voiceplan_id">Tarifpaket</label>
|
||||
<label class="col-lg-2 col-form-label" for="voiceplanzone_id">Tarifzone</label>
|
||||
<div class="col-lg-10">
|
||||
<select name="voiceplan_id" class="form-control">
|
||||
<option value=""></option>
|
||||
<?php if($destination && $destination->voiceplan_id): ?>
|
||||
<?php foreach($voiceplans as $vp): ?>
|
||||
<option value="<?=$vp->id?>" <?=($destination->voiceplan_id == $vp->id) ? "selected='selected'" : ""?>><?=$vp->name?></option>
|
||||
<?php endforeach; ?>
|
||||
<?php elseif($voiceplan): ?>
|
||||
<?php foreach($voiceplans as $vp): ?>
|
||||
<option value="<?=$vp->id?>" <?=($vp->id == $voiceplan->id) ? "selected='selected'" : ""?>><?=$vp->name?></option>
|
||||
<?php endforeach; ?>
|
||||
<select name="voiceplanzone_id" class="form-control">
|
||||
<?php foreach($zones as $zone): ?>
|
||||
<?php if($destination->id): ?>
|
||||
<option value="<?=$zone->id?>" <?=($zone->id == $destination->voiceplanzone_id) ? "selected='selected'" : ""?>><?=$zone->voiceplan->name?> - <?=$zone->name?></option>
|
||||
<?php else: ?>
|
||||
<option value="<?=$zone->id?>" <?=($zone->id == $zone_id) ? "selected='selected'" : ""?>><?=$zone->voiceplan->name?> - <?=$zone->name?></option>
|
||||
<?php endif; ?>
|
||||
<?php endforeach; ?>
|
||||
</select>
|
||||
</div>
|
||||
</div>
|
||||
@@ -62,27 +60,6 @@
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<div class="form-group row">
|
||||
<label class="col-lg-2 col-form-label" for="purchase_price">Einkaufspreis *</label>
|
||||
<div class="col-lg-10">
|
||||
<input type="text" class="form-control" name="purchase_price" id="purchase_price" value="<?=$destination->purchase_price?>" />
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<div class="form-group row">
|
||||
<label class="col-lg-2 col-form-label" for="price">Verkaufspreis *</label>
|
||||
<div class="col-lg-10">
|
||||
<input type="text" class="form-control" name="price" id="price" value="<?=$destination->price?>" />
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<div class="form-group row">
|
||||
<label class="col-lg-2 col-form-label" for="name">Taktung *</label>
|
||||
<div class="col-lg-10">
|
||||
<input type="text" class="form-control" name="increment" id="increment" value="<?=($destination->increment_first && $destination->increment) ? $destination->increment_first."/".$destination->increment : ""?>" placeholder="60/30" />
|
||||
</div>
|
||||
</div>
|
||||
|
||||
</div>
|
||||
</div>
|
||||
|
||||
|
||||
95
Layout/default/Voiceplanzone/Form.php
Normal file
95
Layout/default/Voiceplanzone/Form.php
Normal file
@@ -0,0 +1,95 @@
|
||||
<?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"><a href="<?=self::getUrl("Voiceplan")?>">Sprachtarife</a></li>
|
||||
<li class="breadcrumb-item active"><?=($plan->id) ? "Tarifzone ".$destination->destination." bearbeiten" : "Neue Tarifzone" ?></li>
|
||||
</ol>
|
||||
</div>
|
||||
<h4 class="page-title">Sprachtarife</h4>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
<!-- end page title -->
|
||||
|
||||
<div class="row">
|
||||
<div class="col-lg-12">
|
||||
|
||||
<div class="card">
|
||||
<div class="card-body">
|
||||
<h4 class="header-title mb-2"><?=($zone->id) ? "Zone bearbeiten" : "Neue Zone"?></h4>
|
||||
|
||||
<form class="form-horizontal" method="post" action="<?=self::getUrl("Voiceplanzone", "save")?>">
|
||||
<div class="card">
|
||||
<div class="card-body">
|
||||
|
||||
<input type="hidden" name="id" value="<?=$zone->id?>" />
|
||||
|
||||
<div class="form-group row">
|
||||
<label class="col-lg-2 col-form-label" for="name">Sprachtarif *</label>
|
||||
<div class="col-lg-10">
|
||||
<select name="voiceplan_id" class="form-control">
|
||||
<?php foreach(VoiceplanModel::getAll() as $vp): ?>
|
||||
<?php if($voiceplan_id): ?>
|
||||
<option value="<?=$vp->id?>" <?=($vp->id == $voiceplan_id) ? "selected='selected'" : ""?>><?=$vp->name?></option>
|
||||
<?php else: ?>
|
||||
<option value="<?=$vp->id?>" <?=($vp->id == $zone->voiceplan_id) ? "selected='selected'" : ""?>><?=$vp->name?></option>
|
||||
<?php endif; ?>
|
||||
<?php endforeach; ?>
|
||||
</select>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<div class="form-group row">
|
||||
<label class="col-lg-2 col-form-label" for="name">Tarifzone Name *</label>
|
||||
<div class="col-lg-10">
|
||||
<input type="text" class="form-control" name="name" id="name" value="<?=$zone->name?>" />
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<div class="form-group row">
|
||||
<label class="col-lg-2 col-form-label" for="purchase_price">Einkaufspreis *</label>
|
||||
<div class="col-lg-10">
|
||||
<input type="text" class="form-control" name="purchase_price" id="purchase_price" value="<?=$zone->purchase_price?>" />
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<div class="form-group row">
|
||||
<label class="col-lg-2 col-form-label" for="price">Verkaufspreis *</label>
|
||||
<div class="col-lg-10">
|
||||
<input type="text" class="form-control" name="price" id="price" value="<?=$zone->price?>" />
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<div class="form-group row">
|
||||
<label class="col-lg-2 col-form-label" for="name">Taktung *</label>
|
||||
<div class="col-lg-10">
|
||||
<input type="text" class="form-control" name="increment" id="increment" value="<?=($zone->increment_first && $zone->increment) ? $zone->increment_first."/".$zone->increment : ""?>" placeholder="60/30" />
|
||||
</div>
|
||||
</div>
|
||||
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<div class="form-group row">
|
||||
<label class="col-lg-2"></label>
|
||||
<div class="col-lg-10">
|
||||
<button type="submit" class="btn btn-primary">Speichern</button>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
|
||||
|
||||
</form>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
</div>
|
||||
</div>
|
||||
|
||||
|
||||
<?php include(realpath(dirname(__FILE__)."/../../$mfLayoutPackage")."/footer.php"); ?>
|
||||
99
Layout/default/Voiceplanzone/View.php
Normal file
99
Layout/default/Voiceplanzone/View.php
Normal file
@@ -0,0 +1,99 @@
|
||||
<?php
|
||||
$pagination_baseurl = $this->getUrl($Mod,"View");
|
||||
$pagination_baseurl_params = ["filter" => $filter, "id" => $zone->id];
|
||||
$pagination_entity_name = "Destinations";
|
||||
?>
|
||||
<?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"><a href="<?=self::getUrl("Voiceplan")?>">Sprachtarife</a></li>
|
||||
<li class="breadcrumb-item"><a href="<?=self::getUrl("Voiceplan", "view", ["id" => $zone->voiceplan_id])?>">Sprachtarif <?=$zone->voiceplan->name?></a></li>
|
||||
<li class="breadcrumb-item active">Destinationen Tarifzone <?=$zone->name?></li>
|
||||
</ol>
|
||||
</div>
|
||||
<h4 class="page-title">Tarifzonen</h4>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
<!-- end page title -->
|
||||
|
||||
<div class="row">
|
||||
<div class="col-lg-12">
|
||||
|
||||
<div class="card">
|
||||
<div class="card-body mb-3">
|
||||
<div class="row">
|
||||
<div class="col-12">
|
||||
<div class="float-left">
|
||||
<h4 class="header-title">Destinations für Sprachtarifzone <?=$zone->name?></h4>
|
||||
</div>
|
||||
<div class="float-right">
|
||||
<a class="btn btn-primary mb-2" href="<?=self::getUrl("Voiceplandestination", "add", ["voiceplanzone_id" => $zone->id])?>"><i class="fas fa-plus"></i> Neue Destination anlegen</a>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<?php include(realpath(dirname(__FILE__)."/../")."/tpl/pagination.php"); ?>
|
||||
<?php include(realpath(dirname(__FILE__)."/../")."/tpl/pagination-summary.php"); ?>
|
||||
|
||||
<table class="table table-striped table-hover">
|
||||
<tr>
|
||||
<th>Destination</th>
|
||||
<th>Prefix</th>
|
||||
<th>Erstellt</th>
|
||||
<th>Bearbeitet</th>
|
||||
<th></th>
|
||||
</tr>
|
||||
<?php foreach($destinations as $destination): ?>
|
||||
<tr>
|
||||
<td><?=$destination->destination?></td>
|
||||
<td><?=$destination->prefix?></td>
|
||||
<td><?=date("d.m.Y H:i", $zone->create)?> (<?=$zone->creator->name?>)</td>
|
||||
<td><?=date("d.m.Y H:i", $zone->edit)?> (<?=$zone->editor->name?>)</td>
|
||||
<td style="text-align: left; letter-spacing: 4px; font-size: 1.1em;">
|
||||
<a href="<?=self::getUrl("Voiceplanzone", "edit", ["id" => $zone->id])?>"><i class="far fa-edit" title="Zone bearbeiten"></i></a>
|
||||
<a href="<?=self::getUrl("Voiceplanzone", "delete", ["id" => $zone->id])?>" onclick="if(!confirm('Tarifzone wirklich löschen?')) return false;" class="text-danger" title="Löschen"><i class="fas fa-trash"></i></a>
|
||||
</td>
|
||||
</tr>
|
||||
<?php endforeach; ?>
|
||||
</table>
|
||||
|
||||
<?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">
|
||||
function toggleBlock(id) {
|
||||
$('#block-detail-' + id).toggle();
|
||||
if($('#block-detail-' + id).is(":hidden")) {
|
||||
$('#block-' + id).removeClass("table-info");
|
||||
$('#block-' + id).removeClass("text-info");
|
||||
} else {
|
||||
$('#block-' + id).addClass("text-info");
|
||||
$('#block-' + id).addClass("table-info");
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
var block;
|
||||
var hash = window.location.hash.substr(1);
|
||||
var match = hash.match(/block=(\d+)/);
|
||||
if(match && match[1]) {
|
||||
block = match[1]
|
||||
toggleBlock(block);
|
||||
}
|
||||
|
||||
</script>
|
||||
<?php include(realpath(dirname(__FILE__)."/../../$mfLayoutPackage")."/footer.php"); ?>
|
||||
@@ -100,7 +100,7 @@
|
||||
</a>
|
||||
<ul class="submenu">
|
||||
<?php if($me->isAdmin() || $me->can("Voipnumbering")): ?><li><a href="<?=self::getUrl("Voicenumberblock")?>"><i class="fad fa-fw fa-phone-office text-info"></i> Rufnummernblöcke</a></li><?php endif; ?>
|
||||
<?php if($me->isAdmin() || $me->can("Voiceplan")): ?><li><a href="<?=self::getUrl("Voiceplan")?>"><i class="fas fa-fw fa-phone-arrow-up-right text-info"></i> Rufnummernpläne</a></li><?php endif; ?>
|
||||
<?php if($me->isAdmin() || $me->can("Voiceplan")): ?><li><a href="<?=self::getUrl("Voiceplan")?>"><i class="fas fa-fw fa-phone-arrow-up-right text-info"></i> Sprachtarife</a></li><?php endif; ?>
|
||||
</ul>
|
||||
</li>
|
||||
<?php endif; ?>
|
||||
|
||||
@@ -73,7 +73,7 @@ class OpenAccessId extends mfBaseModel {
|
||||
$unit_extdata = $extdata;
|
||||
}
|
||||
|
||||
if(is_object($extdata) && isset($extdata->rimo) && isset($extdata->rimo->ftu->id)) {
|
||||
if(is_object($extdata) && isset($extdata->rimo) && isset($extdata->rimo->ftu->id) && $extdata->rimo->ftu->id) {
|
||||
//var_dump($extdata);exit;
|
||||
$fetch_ftu = false;
|
||||
}
|
||||
|
||||
@@ -4,6 +4,7 @@ class Voiceplan extends mfBaseModel {
|
||||
private $creator;
|
||||
private $editor;
|
||||
|
||||
private $zones;
|
||||
private $destinations;
|
||||
|
||||
public function importDestinationsFromCsv(File $file) {
|
||||
@@ -68,10 +69,18 @@ class Voiceplan extends mfBaseModel {
|
||||
if($this->$name == null) {
|
||||
|
||||
if($name == "destinations") {
|
||||
$this->destinations = VoiceplandestinationModel::search(["voiceplan_id" => $this->id]);
|
||||
$this->destinations = [];
|
||||
foreach($this->getProperty("zones") as $zone) {
|
||||
$this->destinations[] = $zone->destinations;
|
||||
}
|
||||
return $this->destinations;
|
||||
}
|
||||
|
||||
if($name == "zones") {
|
||||
$this->zones = VoiceplanzoneModel::search(["voiceplan_id" => $this->id]);
|
||||
return $this->zones;
|
||||
}
|
||||
|
||||
if($name == "creator") {
|
||||
$user = mfValuecache::singleton()->get("Worker-id-".$this->create_by);
|
||||
if($user) {
|
||||
|
||||
@@ -73,9 +73,9 @@ class VoiceplanController extends mfBaseController {
|
||||
$pagination['start'] = intval($this->request->s);
|
||||
}
|
||||
|
||||
$pagination['maxItems'] = VoiceplandestinationModel::count(['voiceplan_id' => $id]);
|
||||
$destinations = VoiceplandestinationModel::search(['voiceplan_id' => $id], $pagination);
|
||||
$this->layout()->set("destinations", $destinations);
|
||||
$pagination['maxItems'] = VoiceplanzoneModel::count(['voiceplan_id' => $id]);
|
||||
$zones = VoiceplanzoneModel::search(['voiceplan_id' => $id], $pagination);
|
||||
$this->layout()->set("zones", $zones);
|
||||
|
||||
$this->layout()->set("pagination", $pagination);
|
||||
|
||||
|
||||
@@ -3,4 +3,38 @@
|
||||
class Voiceplandestination extends mfBaseModel {
|
||||
protected $forcestr = ["name", "destination", "prefix"];
|
||||
|
||||
private $voiceplan;
|
||||
|
||||
public function getProperty($name) {
|
||||
if($this->$name == null) {
|
||||
|
||||
if(!$this->id) {
|
||||
return null;
|
||||
}
|
||||
|
||||
if($name == "voiceplan") {
|
||||
$zone = $this->getProperty("voiceplanzone");
|
||||
if($zone->voiceplan_id) {
|
||||
$voiceplan = new Voiceplan($zone->voiceplan_id);
|
||||
if($voiceplan->id) {
|
||||
$this->voiceplan = $voiceplan;
|
||||
}
|
||||
}
|
||||
return $this->voiceplan;
|
||||
}
|
||||
|
||||
$classname = ucfirst($name);
|
||||
$idfield = $name."_id";
|
||||
$this->$name = new $classname($this->$idfield);
|
||||
|
||||
if($this->$name->id) {
|
||||
return $this->$name;
|
||||
} else {
|
||||
return null;
|
||||
}
|
||||
}
|
||||
|
||||
return $this->$name;
|
||||
}
|
||||
|
||||
}
|
||||
@@ -17,13 +17,14 @@ class VoiceplandestinationController extends mfBaseController {
|
||||
protected function addAction() {
|
||||
$this->layout()->setTemplate("Voiceplandestination/Form");
|
||||
|
||||
$voiceplans = VoiceplanModel::getAll();
|
||||
$this->layout()->set("voiceplans", $voiceplans);
|
||||
$zones = VoiceplanzoneModel::getAll();
|
||||
$this->layout()->set("zones", $zones);
|
||||
|
||||
$voiceplan_id = $this->request->voiceplan_id;
|
||||
if($voiceplan_id) {
|
||||
$voiceplan = new Voiceplan($voiceplan_id);
|
||||
$this->layout()->set("voiceplan", $voiceplan);
|
||||
$zone_id = $this->request->voiceplanzone_id;
|
||||
if(strtolower($this->action) == "add" && $zone_id) {
|
||||
$zone = new Voiceplanzone($zone_id);
|
||||
$this->layout()->set("zone", $zones);
|
||||
$this->layout()->set("zone_id", $zone->id);
|
||||
}
|
||||
}
|
||||
|
||||
@@ -47,7 +48,7 @@ class VoiceplandestinationController extends mfBaseController {
|
||||
|
||||
protected function saveAction() {
|
||||
$r = $this->request;
|
||||
var_dump($r);
|
||||
//var_dump($r);exit;
|
||||
|
||||
$id = $r->id;
|
||||
if(is_numeric($id) && $id > 0) {
|
||||
@@ -63,25 +64,11 @@ class VoiceplandestinationController extends mfBaseController {
|
||||
}
|
||||
|
||||
$data = [];
|
||||
$data['voiceplan_id'] = $r->voiceplan_id;
|
||||
$data['voiceplanzone_id'] = $r->voiceplanzone_id;
|
||||
$data['destination'] = $r->destination;
|
||||
$data['prefix'] = intval($r->prefix);
|
||||
$data['purchase_price'] = (str_replace(",",".",$r->purchase_price)) ? str_replace(",",".",$r->purchase_price) : 0;
|
||||
$data['price'] = (str_replace(",",".",$r->price)) ? str_replace(",",".",$r->price) : 0;
|
||||
|
||||
if($r->increment) {
|
||||
$increments = explode("/",$r->increment);
|
||||
if(count($increments) != 2) {
|
||||
$this->layout()->setFlash("Ungültige Taktung", "error");
|
||||
$this->layout()->set("destination", VoiceplandestinationModel::create($data));
|
||||
return $this->addAction();
|
||||
}
|
||||
|
||||
$data["increment_first"] = $increments[0];
|
||||
$data["increment"] = $increments[1];
|
||||
}
|
||||
|
||||
if(!$data['destination'] || !$data['prefix'] || !$data['voiceplan_id']) {
|
||||
if(!$data['destination'] || !$data['prefix'] || !$data['voiceplanzone_id']) {
|
||||
$this->layout()->setFlash("Destination, Prefix und Tarifpaket sind erforderlich", "error");
|
||||
$this->layout()->set("destination", VoiceplandestinationModel::create($data));
|
||||
return $this->addAction();
|
||||
@@ -100,6 +87,6 @@ class VoiceplandestinationController extends mfBaseController {
|
||||
return $this->addAction();
|
||||
}
|
||||
|
||||
$this->redirect("Voiceplan", "view", ["id" => $destination->voiceplan_id]);
|
||||
$this->redirect("Voiceplanzone", "view", ["id" => $destination->voiceplanzone_id]);
|
||||
}
|
||||
}
|
||||
@@ -1,14 +1,9 @@
|
||||
<?php
|
||||
|
||||
class VoiceplandestinationModel {
|
||||
public $voiceplan_id;
|
||||
public $description;
|
||||
public $voiceplanzone_id;
|
||||
public $destination;
|
||||
public $prefix;
|
||||
public $purchase_price;
|
||||
public $price;
|
||||
public $increment_first;
|
||||
public $increment;
|
||||
|
||||
public $create_by;
|
||||
public $edit_by;
|
||||
@@ -124,10 +119,10 @@ class VoiceplandestinationModel {
|
||||
return $where;
|
||||
}
|
||||
|
||||
if(array_key_exists("voiceplan_id", $filter)) {
|
||||
$voiceplan_id = $filter['voiceplan_id'];
|
||||
if(is_numeric($voiceplan_id)) {
|
||||
$where .= " AND voiceplan_id = $voiceplan_id";
|
||||
if(array_key_exists("voiceplanzone_id", $filter)) {
|
||||
$voiceplanzone_id = $filter['voiceplanzone_id'];
|
||||
if(is_numeric($voiceplanzone_id)) {
|
||||
$where .= " AND voiceplanzone_id = $voiceplanzone_id";
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
33
application/Voiceplanzone/Voiceplanzone.php
Normal file
33
application/Voiceplanzone/Voiceplanzone.php
Normal file
@@ -0,0 +1,33 @@
|
||||
<?php
|
||||
|
||||
class Voiceplanzone extends mfBaseModel {
|
||||
private $destinations;
|
||||
private $voiceplan;
|
||||
|
||||
public function getProperty($name) {
|
||||
if($this->$name == null) {
|
||||
|
||||
if(!$this->id) {
|
||||
return null;
|
||||
}
|
||||
|
||||
if($name == "destinations") {
|
||||
$this->destinations = VoiceplandestinationModel::search(["voiceplanzone_id" => $this->id]);
|
||||
return $this->destinations;
|
||||
}
|
||||
|
||||
$classname = ucfirst($name);
|
||||
$idfield = $name."_id";
|
||||
$this->$name = new $classname($this->$idfield);
|
||||
|
||||
if($this->$name->id) {
|
||||
return $this->$name;
|
||||
} else {
|
||||
return null;
|
||||
}
|
||||
}
|
||||
|
||||
return $this->$name;
|
||||
}
|
||||
|
||||
}
|
||||
140
application/Voiceplanzone/VoiceplanzoneController.php
Normal file
140
application/Voiceplanzone/VoiceplanzoneController.php
Normal file
@@ -0,0 +1,140 @@
|
||||
<?php
|
||||
|
||||
class VoiceplanzoneController extends mfBaseController {
|
||||
|
||||
protected function init() {
|
||||
$this->needlogin=true;
|
||||
$me = new User();
|
||||
$me->loadMe();
|
||||
$this->me = $me;
|
||||
$this->layout()->set("me",$me);
|
||||
|
||||
if(!$me->isAdmin()) {
|
||||
$this->redirect("Dashboard");
|
||||
}
|
||||
}
|
||||
|
||||
protected function addAction() {
|
||||
$this->layout()->setTemplate("Voiceplanzone/Form");
|
||||
|
||||
if(strtolower($this->action) == "add" && $this->request->voiceplan_id) {
|
||||
$this->layout()->set("voiceplan_id", $this->request->voiceplan_id);
|
||||
$this->layout()->set("voiceplan", new Voiceplan($this->request->voiceplan_id));
|
||||
}
|
||||
}
|
||||
|
||||
protected function viewAction() {
|
||||
$this->layout()->setTemplate("Voiceplanzone/View");
|
||||
$id = $this->request->id;
|
||||
if(!is_numeric($id) || $id < 1) {
|
||||
$this->layout()->setFlash("Tarifzone nicht gefunden.", "error");
|
||||
$this->redirect("Voiceplan");
|
||||
}
|
||||
|
||||
$zone = new Voiceplanzone($id);
|
||||
if(!$zone->id) {
|
||||
$this->layout()->setFlash("Tarifzone nicht gefunden.", "error");
|
||||
$this->redirect("Voiceplan");
|
||||
}
|
||||
|
||||
$this->layout()->set("zone", $zone);
|
||||
|
||||
$pagination = [];
|
||||
$pagination['start'] = 0;
|
||||
$pagination['count'] = 20;
|
||||
$pagination['maxItems'] = 0;
|
||||
|
||||
if(is_numeric($this->request->s)) {
|
||||
$pagination['start'] = intval($this->request->s);
|
||||
}
|
||||
|
||||
$pagination['maxItems'] = VoiceplandestinationModel::count(['voiceplanzone_id' => $id]);
|
||||
$destinations = VoiceplandestinationModel::search(['voiceplanzone_id' => $id], $pagination);
|
||||
$this->layout()->set("destinations", $destinations);
|
||||
|
||||
$this->layout()->set("pagination", $pagination);
|
||||
|
||||
}
|
||||
|
||||
protected function editAction() {
|
||||
$id = $this->request->id;
|
||||
if(!is_numeric($id) || $id < 1) {
|
||||
$this->layout()->setFlash("Tarifzone nicht gefunden.", "error");
|
||||
$this->redirect("Voiceplan");
|
||||
}
|
||||
|
||||
$zone = new Voiceplanzone($id);
|
||||
if(!$zone->id) {
|
||||
$this->layout()->setFlash("Tarifzone nicht gefunden.", "error");
|
||||
$this->redirect("Voiceplan");
|
||||
}
|
||||
|
||||
$this->layout()->set("zone", $zone);
|
||||
return $this->addAction();
|
||||
}
|
||||
|
||||
protected function saveAction() {
|
||||
$r = $this->request;
|
||||
//var_dump($r);exit;
|
||||
|
||||
$id = $r->id;
|
||||
if(is_numeric($id) && $id > 0) {
|
||||
$mode = "edit";
|
||||
$zone = new Voiceplanzone($id);
|
||||
if(!$zone->id) {
|
||||
$this->layout()->setFlash("Tarifzone nicht gefunden", "error");
|
||||
$this->redirect("Voiceplan");
|
||||
}
|
||||
} else {
|
||||
$id = false;
|
||||
$mode = "add";
|
||||
}
|
||||
|
||||
$data["voiceplan_id"] = $r->voiceplan_id;
|
||||
$data["name"] = $r->name;
|
||||
$data['purchase_price'] = (str_replace(",",".",$r->purchase_price)) ? str_replace(",",".",$r->purchase_price) : 0;
|
||||
$data['price'] = (str_replace(",",".",$r->price)) ? str_replace(",",".",$r->price) : 0;
|
||||
|
||||
if($r->increment) {
|
||||
$increments = explode("/",$r->increment);
|
||||
if(count($increments) != 2) {
|
||||
$this->layout()->setFlash("Ungültige Taktung", "error");
|
||||
if($mode == "edit") {
|
||||
$this->redirect("Voiceplanzone", "edit", ["id" => $id]);
|
||||
} else {
|
||||
$this->layout()->set("zone", VoiceplanzoneModel::create($data));
|
||||
return $this->addAction();
|
||||
}
|
||||
}
|
||||
|
||||
$data["increment_first"] = $increments[0];
|
||||
$data["increment"] = $increments[1];
|
||||
}
|
||||
|
||||
if(!$data['name'] || !$data['voiceplan_id']) {
|
||||
$this->layout()->setFlash("Name und Tarifpaket sind erforderlich", "error");
|
||||
if($mode == "edit") {
|
||||
$this->redirect("Voiceplanzone", "edit", ["id" => $id]);
|
||||
} else {
|
||||
$this->layout()->set("destination", VoiceplanzoneModel::create($data));
|
||||
return $this->addAction();
|
||||
}
|
||||
}
|
||||
|
||||
if($mode == "edit") {
|
||||
$zone->update($data);
|
||||
} else {
|
||||
$zone = VoiceplanzoneModel::create($data);
|
||||
}
|
||||
|
||||
$id = $zone->save();
|
||||
if(!$id) {
|
||||
$this->layout()->setFlash("Fehler beim Speichern!", "error");
|
||||
$this->layout()->set("zone", $zone);
|
||||
return $this->addAction();
|
||||
}
|
||||
|
||||
$this->redirect("Voiceplan", "view", ["id" => $zone->voiceplan_id]);
|
||||
|
||||
}
|
||||
}
|
||||
134
application/Voiceplanzone/VoiceplanzoneModel.php
Normal file
134
application/Voiceplanzone/VoiceplanzoneModel.php
Normal file
@@ -0,0 +1,134 @@
|
||||
<?php
|
||||
|
||||
class VoiceplanzoneModel {
|
||||
public $voiceplan_id;
|
||||
public $name;
|
||||
public $purchase_price;
|
||||
public $price;
|
||||
public $increment_first;
|
||||
public $increment;
|
||||
|
||||
public $create_by;
|
||||
public $edit_by;
|
||||
public $create;
|
||||
public $edit;
|
||||
|
||||
|
||||
public static function create(Array $data) {
|
||||
$model = new Voiceplanzone();
|
||||
|
||||
foreach($data as $field => $value) {
|
||||
if(property_exists(get_called_class(), $field)) {
|
||||
$model ->$field = $value;
|
||||
}
|
||||
}
|
||||
|
||||
$me = mfValuecache::singleton()->get("me");
|
||||
if(!$me) {
|
||||
$me = new User();
|
||||
$me->loadMe();
|
||||
mfValuecache::singleton()->set("me", $me);
|
||||
}
|
||||
|
||||
if($model->create_by === null) {
|
||||
$model->create_by = $me->id;
|
||||
}
|
||||
if($model->edit_by === null) {
|
||||
$model->edit_by = $me->id;
|
||||
}
|
||||
|
||||
return $model;
|
||||
}
|
||||
|
||||
public static function getAll() {
|
||||
$items = [];
|
||||
|
||||
$db = FronkDB::singleton();
|
||||
|
||||
$res = $db->select("Voiceplanzone", "*", "1=1 ORDER BY voiceplan_id,name");
|
||||
if($db->num_rows($res)) {
|
||||
while($data = $db->fetch_object($res)) {
|
||||
$items[] = new Voiceplanzone($data);
|
||||
}
|
||||
}
|
||||
return $items;
|
||||
|
||||
}
|
||||
|
||||
public static function getFirst() {
|
||||
$db = FronkDB::singleton();
|
||||
|
||||
$where = self::getSqlFilter($filter);
|
||||
$res = $db->select("Voiceplanzone", "*", "$where ORDER BY voiceplan_id,name");
|
||||
if($db->num_rows($res)) {
|
||||
$data = $db->fetch_object($res);
|
||||
$item = new Voiceplanzone($data);
|
||||
if($item->id) {
|
||||
return $item;
|
||||
} else {
|
||||
return null;
|
||||
}
|
||||
}
|
||||
return null;
|
||||
}
|
||||
|
||||
public static function count($filter) {
|
||||
$db = FronkDB::singleton();
|
||||
|
||||
$where = self::getSqlFilter($filter);
|
||||
$sql = "SELECT COUNT(*) as cnt FROM Voiceplanzone
|
||||
WHERE $where
|
||||
";
|
||||
|
||||
$res = $db->query($sql);
|
||||
if($db->num_rows($res)) {
|
||||
$data = $db->fetch_object($res);
|
||||
return $data->cnt;
|
||||
}
|
||||
return 0;
|
||||
}
|
||||
|
||||
public static function search($filter) {
|
||||
$items = [];
|
||||
$db = FronkDB::singleton();
|
||||
|
||||
$where = self::getSqlFilter($filter);
|
||||
|
||||
$sql = "SELECT * FROM Voiceplanzone
|
||||
WHERE $where
|
||||
ORDER BY voiceplan_id,name";
|
||||
|
||||
$res = $db->query($sql);
|
||||
|
||||
if($db->num_rows($res)) {
|
||||
while($data = $db->fetch_object($res)) {
|
||||
$items[] = new Voiceplanzone($data);
|
||||
}
|
||||
}
|
||||
return $items;
|
||||
}
|
||||
|
||||
private static function getSqlFilter($filter) {
|
||||
$where = "1=1 ";
|
||||
|
||||
|
||||
if(array_key_exists("voiceplan_id", $filter)) {
|
||||
$voiceplan_id = $filter['voiceplan_id'];
|
||||
if(is_numeric($voiceplan_id)) {
|
||||
$where .= " AND voiceplan_id=$voiceplan_id";
|
||||
}
|
||||
}
|
||||
|
||||
//var_dump($filter);exit;
|
||||
if(array_key_exists("name", $filter)) {
|
||||
$name = FronkDB::singleton()->escape($filter['name']);
|
||||
if($name) {
|
||||
$where .= " AND name='$name'";
|
||||
}
|
||||
}
|
||||
|
||||
//var_dump($filter, $where);exit;
|
||||
return $where;
|
||||
}
|
||||
|
||||
}
|
||||
@@ -82,10 +82,10 @@ final class AddVoicenumberTables extends AbstractMigration
|
||||
public function down(): void
|
||||
{
|
||||
if($this->getEnvironment() == "thetool") {
|
||||
$this->table("Voiceplandestination")->drop();
|
||||
$this->table("Voiceplan")->drop();
|
||||
$this->table("Voicenumber")->drop();
|
||||
$this->table("Voicenumberblock")->drop();
|
||||
$this->table("Voiceplandestination")->drop()->save();
|
||||
$this->table("Voiceplan")->drop()->save();
|
||||
$this->table("Voicenumber")->drop()->save();
|
||||
$this->table("Voicenumberblock")->drop()->save();
|
||||
}
|
||||
|
||||
if($this->getEnvironment() == "addressdb") {
|
||||
|
||||
56
db/migrations/20231010161225_add_voiceplan_zone.php
Normal file
56
db/migrations/20231010161225_add_voiceplan_zone.php
Normal file
@@ -0,0 +1,56 @@
|
||||
<?php
|
||||
declare(strict_types=1);
|
||||
|
||||
use Phinx\Migration\AbstractMigration;
|
||||
|
||||
final class AddVoiceplanZone extends AbstractMigration
|
||||
{
|
||||
public function up(): void
|
||||
{
|
||||
if($this->getEnvironment() == "thetool") {
|
||||
$table = $this->table("Voiceplanzone");
|
||||
$table->addColumn("voiceplan_id", "integer", ["null" => false]);
|
||||
$table->addColumn("name", "string", ["null" => false, "limit" => 255]);
|
||||
$table->addColumn("purchase_price", "decimal", ["null" => false, "precision" => 14, "scale" => 4]);
|
||||
$table->addColumn("price", "decimal", ["null" => false, "precision" => 14, "scale" => 4]);
|
||||
$table->addColumn("increment_first", "integer", ["null" => false, "default" => 60]);
|
||||
$table->addColumn("increment", "integer", ["null" => false, "default" => 30]);
|
||||
$table->addColumn("create_by", "integer", ["null" => false]);
|
||||
$table->addColumn("edit_by", "integer", ["null" => false]);
|
||||
$table->addColumn("create", "integer", ["null" => false]);
|
||||
$table->addColumn("edit", "integer", ["null" => false]);
|
||||
$table->create();
|
||||
|
||||
$table = $this->table("Voiceplandestination");
|
||||
$table->removeColumn("purchase_price");
|
||||
$table->removeColumn("price");
|
||||
$table->removeColumn("increment_first");
|
||||
$table->removeColumn("increment");
|
||||
$table->renameColumn("voiceplan_id", "voiceplanzone_id");
|
||||
$table->update();
|
||||
}
|
||||
|
||||
if($this->getEnvironment() == "addressdb") {
|
||||
|
||||
}
|
||||
}
|
||||
|
||||
public function down(): void
|
||||
{
|
||||
if($this->getEnvironment() == "thetool") {
|
||||
$table = $this->table("Voiceplandestination");
|
||||
$table->renameColumn("voiceplanzone_id", "voiceplan_id");
|
||||
$table->addColumn("purchase_price", "decimal", ["null" => false, "precision" => 14, "scale" => 4]);
|
||||
$table->addColumn("price", "decimal", ["null" => false, "precision" => 14, "scale" => 4]);
|
||||
$table->addColumn("increment_first", "integer", ["null" => false, "default" => 1]);
|
||||
$table->addColumn("increment", "integer", ["null" => false, "default" => 1]);
|
||||
$table->update();
|
||||
|
||||
$this->table("Voiceplanzone")->drop()->save();
|
||||
}
|
||||
|
||||
if($this->getEnvironment() == "addressdb") {
|
||||
|
||||
}
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user