Upload files to "includes"
This commit is contained in:
185
includes/force-zuteilung.php
Normal file
185
includes/force-zuteilung.php
Normal file
@@ -0,0 +1,185 @@
|
||||
<?php
|
||||
function kc_force_zuteilung_page() {
|
||||
global $wpdb;
|
||||
$prefix = $wpdb->prefix;
|
||||
kc_admin_tabs('kc_force_zuteilung');
|
||||
|
||||
// Force-Zuteilung löschen
|
||||
if (isset($_GET['delete_force'])) {
|
||||
$fid = intval($_GET['delete_force']);
|
||||
$wpdb->delete("{$prefix}kc_force_zuteilung", ['id' => $fid]);
|
||||
echo '<div class="notice notice-success">Force-Zuteilung gelöscht!</div>';
|
||||
}
|
||||
|
||||
// Force speichern (neu/ändern)
|
||||
if (isset($_POST['kc_force_save'])) {
|
||||
$data = [
|
||||
'teilnehmer_id' => intval($_POST['teilnehmer_id']),
|
||||
'wahl_id' => intval($_POST['wahl_id']),
|
||||
'phase' => intval($_POST['phase']),
|
||||
'workshop_id' => intval($_POST['workshop_id']),
|
||||
'kommentar' => sanitize_text_field($_POST['kommentar'])
|
||||
];
|
||||
if (!empty($_POST['fid'])) {
|
||||
$wpdb->update("{$prefix}kc_force_zuteilung", $data, ['id'=>intval($_POST['fid'])]);
|
||||
echo '<div class="notice notice-success">Force-Zuteilung aktualisiert!</div>';
|
||||
} else {
|
||||
$wpdb->insert("{$prefix}kc_force_zuteilung", $data);
|
||||
echo '<div class="notice notice-success">Force-Zuteilung angelegt!</div>';
|
||||
}
|
||||
}
|
||||
|
||||
// Listen für Dropdowns
|
||||
$teilnehmer_liste = $wpdb->get_results("SELECT * FROM {$prefix}kc_teilnehmer ORDER BY nachname, vorname");
|
||||
$workshop_liste = $wpdb->get_results("SELECT * FROM {$prefix}kc_workshops ORDER BY name");
|
||||
$wahlen = $wpdb->get_results("SELECT id, name FROM {$prefix}kc_wahlen WHERE deleted=0 ORDER BY name");
|
||||
|
||||
// Bearbeiten
|
||||
if (isset($_GET['edit_force'])) {
|
||||
$fid = intval($_GET['edit_force']);
|
||||
$fz = $wpdb->get_row("SELECT * FROM {$prefix}kc_force_zuteilung WHERE id=$fid");
|
||||
echo '<div class="kc-admin-table-wrap">';
|
||||
echo '<h2>Force-Zuteilung bearbeiten</h2>
|
||||
<form method="post">
|
||||
<input type="hidden" name="fid" value="'.intval($fz->id).'">
|
||||
<div class="kc-form-row">
|
||||
<label>Teilnehmer <span class="kc-required">*</span></label>
|
||||
<select name="teilnehmer_id" id="kc-force-teilnehmer-dropdown" style="width:100%">
|
||||
<option value="">Teilnehmer auswählen…</option>';
|
||||
foreach($teilnehmer_liste as $t) {
|
||||
echo '<option value="'.esc_attr($t->id).'"'.($fz->teilnehmer_id==$t->id?' selected':'').'>'
|
||||
.esc_html($t->vorname.' '.$t->nachname.' (ID: '.$t->id.')')
|
||||
.'</option>';
|
||||
}
|
||||
echo ' </select>
|
||||
</div>
|
||||
<div class="kc-form-row">
|
||||
<label>Wahl <span class="kc-required">*</span></label>
|
||||
<select name="wahl_id" id="kc-force-wahl-dropdown" style="width:100%">
|
||||
<option value="">Wahl auswählen…</option>';
|
||||
foreach($wahlen as $w) {
|
||||
echo '<option value="'.intval($w->id).'"'.($fz->wahl_id==$w->id?' selected':'').'>'
|
||||
.esc_html($w->name.' (ID '.$w->id.')').'</option>';
|
||||
}
|
||||
echo ' </select>
|
||||
</div>
|
||||
<div class="kc-form-row">
|
||||
<label>Phase</label>
|
||||
<input type="number" name="phase" value="'.intval($fz->phase).'" style="width:100%">
|
||||
</div>
|
||||
<div class="kc-form-row">
|
||||
<label>Workshop <span class="kc-required">*</span></label>
|
||||
<select name="workshop_id" id="kc-force-workshop-dropdown" style="width:100%">
|
||||
<option value="">Workshop auswählen…</option>';
|
||||
foreach($workshop_liste as $ws) {
|
||||
echo '<option value="'.esc_attr($ws->id).'"'.($fz->workshop_id==$ws->id?' selected':'').'>'
|
||||
.esc_html($ws->name)
|
||||
.'</option>';
|
||||
}
|
||||
echo ' </select>
|
||||
</div>
|
||||
<div class="kc-form-row">
|
||||
<label>Kommentar</label>
|
||||
<input type="text" name="kommentar" value="'.esc_attr($fz->kommentar).'" style="width:100%">
|
||||
</div>
|
||||
<button name="kc_force_save" class="kc-btn">Speichern</button>
|
||||
<a href="?page=kc_force_zuteilung" class="kc-btn del" style="margin-left:24px;">Abbrechen</a>
|
||||
</form>
|
||||
<script>
|
||||
jQuery(function($){
|
||||
$("#kc-force-teilnehmer-dropdown").select2({placeholder:"Teilnehmer auswählen…",allowClear:true});
|
||||
$("#kc-force-wahl-dropdown").select2({placeholder:"Wahl auswählen…",allowClear:true});
|
||||
$("#kc-force-workshop-dropdown").select2({placeholder:"Workshop auswählen…",allowClear:true});
|
||||
});
|
||||
</script>';
|
||||
echo '</div>';
|
||||
return;
|
||||
}
|
||||
|
||||
// Neu anlegen
|
||||
if (isset($_GET['new'])) {
|
||||
echo '<div class="kc-admin-table-wrap">';
|
||||
echo '<h2>Neue Force-Zuteilung</h2>
|
||||
<form method="post">
|
||||
<div class="kc-form-row">
|
||||
<label>Teilnehmer <span class="kc-required">*</span></label>
|
||||
<select name="teilnehmer_id" id="kc-force-teilnehmer-dropdown" style="width:100%">
|
||||
<option value="">Teilnehmer auswählen…</option>';
|
||||
foreach($teilnehmer_liste as $t) {
|
||||
echo '<option value="'.esc_attr($t->id).'">'
|
||||
.esc_html($t->vorname.' '.$t->nachname.' (ID: '.$t->id.')')
|
||||
.'</option>';
|
||||
}
|
||||
echo ' </select>
|
||||
</div>
|
||||
<div class="kc-form-row">
|
||||
<label>Wahl <span class="kc-required">*</span></label>
|
||||
<select name="wahl_id" id="kc-force-wahl-dropdown" style="width:100%">
|
||||
<option value="">Wahl auswählen…</option>';
|
||||
foreach($wahlen as $w) {
|
||||
echo '<option value="'.intval($w->id).'">'
|
||||
.esc_html($w->name.' (ID '.$w->id.')').'</option>';
|
||||
}
|
||||
echo ' </select>
|
||||
</div>
|
||||
<div class="kc-form-row">
|
||||
<label>Phase</label>
|
||||
<input type="number" name="phase" value="1" style="width:100%">
|
||||
</div>
|
||||
<div class="kc-form-row">
|
||||
<label>Workshop <span class="kc-required">*</span></label>
|
||||
<select name="workshop_id" id="kc-force-workshop-dropdown" style="width:100%">
|
||||
<option value="">Workshop auswählen…</option>';
|
||||
foreach($workshop_liste as $ws) {
|
||||
echo '<option value="'.esc_attr($ws->id).'">'
|
||||
.esc_html($ws->name)
|
||||
.'</option>';
|
||||
}
|
||||
echo ' </select>
|
||||
</div>
|
||||
<div class="kc-form-row">
|
||||
<label>Kommentar</label>
|
||||
<input type="text" name="kommentar" style="width:100%">
|
||||
</div>
|
||||
<button name="kc_force_save" class="kc-btn">Speichern</button>
|
||||
<a href="?page=kc_force_zuteilung" class="kc-btn del" style="margin-left:24px;">Abbrechen</a>
|
||||
</form>
|
||||
<script>
|
||||
jQuery(function($){
|
||||
$("#kc-force-teilnehmer-dropdown").select2({placeholder:"Teilnehmer auswählen…",allowClear:true});
|
||||
$("#kc-force-wahl-dropdown").select2({placeholder:"Wahl auswählen…",allowClear:true});
|
||||
$("#kc-force-workshop-dropdown").select2({placeholder:"Workshop auswählen…",allowClear:true});
|
||||
});
|
||||
</script>';
|
||||
echo '</div>';
|
||||
return;
|
||||
}
|
||||
|
||||
// Übersicht
|
||||
echo '<div class="kc-admin-table-wrap">';
|
||||
echo '<h2 style="margin-top:0;">Alle Force-Zuteilungen</h2>';
|
||||
echo '<a class="kc-btn" style="float:right;margin-bottom:12px;" href="?page=kc_force_zuteilung&new=1">+ Neue Force-Zuteilung</a>';
|
||||
echo '<table class="kc-admin-table">';
|
||||
echo '<thead><tr><th>Teilnehmer</th><th>Wahl</th><th>Phase</th><th>Workshop</th><th>Kommentar</th><th>Aktion</th></tr></thead><tbody>';
|
||||
$fz = $wpdb->get_results("SELECT * FROM {$prefix}kc_force_zuteilung ORDER BY id DESC");
|
||||
foreach ($fz as $f) {
|
||||
// Teilnehmer-Namen holen
|
||||
$teilnehmer = $wpdb->get_row($wpdb->prepare("SELECT vorname, nachname FROM {$prefix}kc_teilnehmer WHERE id=%d", $f->teilnehmer_id));
|
||||
$teilnehmer_name = $teilnehmer ? ($teilnehmer->vorname . ' ' . $teilnehmer->nachname) : 'ID ' . $f->teilnehmer_id;
|
||||
$workshop_name = $wpdb->get_var($wpdb->prepare("SELECT name FROM {$prefix}kc_workshops WHERE id=%d", $f->workshop_id));
|
||||
$wahl_name = $wpdb->get_var($wpdb->prepare("SELECT name FROM {$prefix}kc_wahlen WHERE id=%d", $f->wahl_id));
|
||||
echo "<tr>
|
||||
<td>".esc_html($teilnehmer_name)."</td>
|
||||
<td>".esc_html($wahl_name)." (ID ".intval($f->wahl_id).")</td>
|
||||
<td>".intval($f->phase)."</td>
|
||||
<td>".esc_html($workshop_name)."</td>
|
||||
<td>".esc_html($f->kommentar)."</td>
|
||||
<td class='kc-actions'>
|
||||
<a class='kc-btn edit' href='?page=kc_force_zuteilung&edit_force={$f->id}'>Bearbeiten</a>
|
||||
<a class='kc-btn del' href='?page=kc_force_zuteilung&delete_force={$f->id}' onclick=\"return confirm('Wirklich loeschen?');\">Loeschen</a>
|
||||
</td>
|
||||
</tr>";
|
||||
}
|
||||
echo '</tbody></table></div>';
|
||||
}
|
||||
?>
|
||||
Reference in New Issue
Block a user