photo upload bei runs geht jetzt (beim ergebnis eintragen)
All checks were successful
Build and push / Pulling repo on server (push) Successful in 3s
All checks were successful
Build and push / Pulling repo on server (push) Successful in 3s
This commit is contained in:
parent
e03d9ab449
commit
19622359f0
@ -54,6 +54,13 @@ main>.container {
|
|||||||
opacity: 1;
|
opacity: 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* Dropzone overrides */
|
||||||
|
.dropzone {
|
||||||
|
min-height: 150px;
|
||||||
|
border: 2px solid rgba(0,0,0,.3);
|
||||||
|
padding: 20px 20px;
|
||||||
|
}
|
||||||
|
|
||||||
/* XDEBUG */
|
/* XDEBUG */
|
||||||
.xdebug-error th
|
.xdebug-error th
|
||||||
{
|
{
|
||||||
|
1
web/css/dropzone.min.css
vendored
Normal file
1
web/css/dropzone.min.css
vendored
Normal file
File diff suppressed because one or more lines are too long
@ -243,6 +243,68 @@ function pictshareUploadImage($path,$hash=false)
|
|||||||
return $json;
|
return $json;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// takes $_FILES['file'] as input and validates, throws error if fails, else returns URL of the image
|
||||||
|
function pictShareFormValidateAndUpload($file,$key=false)
|
||||||
|
{
|
||||||
|
if($key===false)
|
||||||
|
{
|
||||||
|
$photo_name = $file['name'];
|
||||||
|
$photo_tmp_name = $file['tmp_name'];
|
||||||
|
$photo_size = $file['size'];
|
||||||
|
$photo_error = $file['error'];
|
||||||
|
$photo_type = $file['type'];
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
$photo_name = $file['name'][$key];
|
||||||
|
$photo_tmp_name = $file['tmp_name'][$key];
|
||||||
|
$photo_size = $file['size'][$key];
|
||||||
|
$photo_error = $file['error'][$key];
|
||||||
|
$photo_type = $file['type'][$key];
|
||||||
|
}
|
||||||
|
|
||||||
|
$allowed = ['jpg','jpeg','png','gif'];
|
||||||
|
$photo_ext = strtolower(end(explode('.', $photo_name)));
|
||||||
|
|
||||||
|
if(in_array($photo_ext, $allowed))
|
||||||
|
{
|
||||||
|
if($photo_error === 0)
|
||||||
|
{
|
||||||
|
if($photo_size < 10000000)
|
||||||
|
{
|
||||||
|
$answer = pictshareUploadImage($photo_tmp_name);
|
||||||
|
if($answer['status']=='ok' && in_array($answer['filetype'],['jpeg','png','gif']))
|
||||||
|
return $answer['url'];
|
||||||
|
else
|
||||||
|
throw new Exception('Fehler beim CDN Upload: '.json_encode($answer,true));
|
||||||
|
}
|
||||||
|
else
|
||||||
|
throw new Exception('Die Datei ist zu groß. Bitte eine kleinere Datei hochladen');
|
||||||
|
}
|
||||||
|
else
|
||||||
|
throw new Exception('Fehler beim Upload: '.getFileUploadError($photo_error));
|
||||||
|
}
|
||||||
|
else
|
||||||
|
throw new Exception('Dateityp nicht erlaubt. Bitte nur '.implode(', ',$allowed).' hochladen');
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
function getFileUploadError($error)
|
||||||
|
{
|
||||||
|
$phpFileUploadErrors = array(
|
||||||
|
0 => 'There is no error, the file uploaded with success',
|
||||||
|
1 => 'The uploaded file exceeds the upload_max_filesize directive in php.ini',
|
||||||
|
2 => 'The uploaded file exceeds the MAX_FILE_SIZE directive that was specified in the HTML form',
|
||||||
|
3 => 'The uploaded file was only partially uploaded',
|
||||||
|
4 => 'No file was uploaded',
|
||||||
|
6 => 'Missing a temporary folder',
|
||||||
|
7 => 'Failed to write file to disk.',
|
||||||
|
8 => 'A PHP extension stopped the file upload.',
|
||||||
|
);
|
||||||
|
|
||||||
|
return $phpFileUploadErrors[$error];
|
||||||
|
}
|
||||||
|
|
||||||
function partial($name,$variables=[])
|
function partial($name,$variables=[])
|
||||||
{
|
{
|
||||||
$templatefile = ROOT.DS.'templates'.DS.'partials'.DS.$name;
|
$templatefile = ROOT.DS.'templates'.DS.'partials'.DS.$name;
|
||||||
|
1
web/js/dropzone.min.js
vendored
Normal file
1
web/js/dropzone.min.js
vendored
Normal file
File diff suppressed because one or more lines are too long
@ -103,6 +103,25 @@ class Runs extends Page {
|
|||||||
$res->run = $rid;
|
$res->run = $rid;
|
||||||
$res->user = $_SESSION['user']->id;
|
$res->user = $_SESSION['user']->id;
|
||||||
|
|
||||||
|
if($_FILES['photos'])
|
||||||
|
{
|
||||||
|
foreach($_FILES['photos']['tmp_name'] as $key => $tmp_name)
|
||||||
|
{
|
||||||
|
try{
|
||||||
|
$url = pictShareFormValidateAndUpload($_FILES['photos'],$key);
|
||||||
|
$res->data['photos'][] = $url;
|
||||||
|
}
|
||||||
|
catch(Exception $e)
|
||||||
|
{
|
||||||
|
return partial('error.html', ['errorMessage' => 'Fehler beim Upload des Fotos: '.$e->getMessage()]);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
//filter out unique values so we don't have double entries
|
||||||
|
$res->data['photos'] = array_unique($res->data['photos']);
|
||||||
|
}
|
||||||
|
|
||||||
try{
|
try{
|
||||||
$resid = $res->save();
|
$resid = $res->save();
|
||||||
|
|
||||||
|
@ -22,7 +22,8 @@
|
|||||||
<h2>Ergebnis
|
<h2>Ergebnis
|
||||||
<?= $result_id?'Bearbeiten':'Eintragen'; ?>
|
<?= $result_id?'Bearbeiten':'Eintragen'; ?>
|
||||||
</h2>
|
</h2>
|
||||||
<form hx-post="/runs/validateresults" hx-encoding='multipart/form-data' hx-target="#response">
|
<form id="resulteditform" hx-post="/runs/validateresults" hx-encoding='multipart/form-data' hx-target="#response">
|
||||||
|
<div class="dropzone-previews"></div>
|
||||||
<input type="hidden" name="result_id" value="<?= $result_id; ?>">
|
<input type="hidden" name="result_id" value="<?= $result_id; ?>">
|
||||||
<input type="hidden" name="run_id" value="<?= $run_id; ?>">
|
<input type="hidden" name="run_id" value="<?= $run_id; ?>">
|
||||||
<div>
|
<div>
|
||||||
@ -88,7 +89,7 @@
|
|||||||
</div>
|
</div>
|
||||||
<div>
|
<div>
|
||||||
<label for="uploads">Uploads</label>
|
<label for="uploads">Uploads</label>
|
||||||
<input type="file" accept="image/png, image/jpeg, image/gif" id="uploads" name="uploads">
|
<input type="file" accept="image/png, image/jpeg, image/gif" id="uploads" name="photos[]" multiple>
|
||||||
</div>
|
</div>
|
||||||
<div>
|
<div>
|
||||||
<label for="video-url">Video Url</label>
|
<label for="video-url">Video Url</label>
|
||||||
@ -103,7 +104,13 @@
|
|||||||
<input class="form-check-input" type="checkbox" id="public" name="public" value="1" <?=$result['public']!='0' ?'checked':''; ?>>
|
<input class="form-check-input" type="checkbox" id="public" name="public" value="1" <?=$result['public']!='0' ?'checked':''; ?>>
|
||||||
</div>
|
</div>
|
||||||
<button type="submit" name="submit" value="true" class="btn btn-primary">Speichern</button>
|
<button type="submit" name="submit" value="true" class="btn btn-primary">Speichern</button>
|
||||||
|
<progress id='progress' value='0' max='100'></progress>
|
||||||
<div id="response"></div>
|
<div id="response"></div>
|
||||||
</form>
|
</form>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
<script>
|
||||||
|
htmx.on('#resulteditform', 'htmx:xhr:progress', function(evt) {
|
||||||
|
htmx.find('#progress').setAttribute('value', evt.detail.loaded/evt.detail.total * 100)
|
||||||
|
});
|
||||||
|
</script>
|
@ -1,33 +1,61 @@
|
|||||||
<div class="container">
|
<div class="container">
|
||||||
<nav aria-label="breadcrumb">
|
<nav aria-label="breadcrumb">
|
||||||
<ol class="breadcrumb">
|
<ol class="breadcrumb">
|
||||||
<li class="breadcrumb-item">
|
<li class="breadcrumb-item">
|
||||||
<i class="fas fa-calendar-star"></i>
|
<i class="fas fa-calendar-star"></i>
|
||||||
<a href="/tournaments/event/<?= $tournament_id; ?>" hx-push-url="/tournaments/event/<?= $tournament_id; ?>" hx-get="/tournaments/event/<?= $tournament_id; ?>" hx-target="#main"><?= escape($tournament['name']); ?></a>
|
<a href="/tournaments/event/<?= $tournament_id; ?>" hx-push-url="/tournaments/event/<?= $tournament_id; ?>" hx-get="/tournaments/event/<?= $tournament_id; ?>" hx-target="#main">
|
||||||
</li>
|
<?= escape($tournament['name']); ?>
|
||||||
<li class="breadcrumb-item active" aria-current="page">
|
</a>
|
||||||
<i class="far fa-running"></i> <?= escape($run['name']); ?>
|
</li>
|
||||||
</li>
|
<li class="breadcrumb-item active" aria-current="page">
|
||||||
|
<i class="far fa-running"></i>
|
||||||
|
<?= escape($run['name']); ?>
|
||||||
|
</li>
|
||||||
</ol>
|
</ol>
|
||||||
</nav>
|
</nav>
|
||||||
<div class="row">
|
<div class="row">
|
||||||
<div class="col-3">
|
<div class="col-3">
|
||||||
<div class="card">
|
<div class="card">
|
||||||
<?php if($run['photo']): ?><img src="<?= $run['photo'] ?>/300x170/fixedsize" class="card-img-top" alt="<?= escape($run['name']); ?>'s profile Picture"> <?php endif; ?>
|
<?php if($run['photo']): ?><img src="<?= $run['photo'] ?>/300x170/fixedsize" class="card-img-top" alt="<?= escape($run['name']); ?>'s profile Picture">
|
||||||
|
<?php endif; ?>
|
||||||
<div class="card-body">
|
<div class="card-body">
|
||||||
<h5 class="card-title"><?= escape($run['name']); ?></h5>
|
<h5 class="card-title">
|
||||||
|
<?= escape($run['name']); ?>
|
||||||
|
</h5>
|
||||||
<p class="card-text">
|
<p class="card-text">
|
||||||
<ul>
|
<ul>
|
||||||
|
|
||||||
<li>Gehört zu <a href="/tournaments/event/<?= $tournament_id; ?>" hx-push-url="/tournaments/event/<?= $tournament_id; ?>" hx-get="/tournaments/event/<?= $tournament_id; ?>" hx-target="#main"><?= escape($tournament['name']); ?></a></li>
|
<li>Gehört zu <a href="/tournaments/event/<?= $tournament_id; ?>" hx-push-url="/tournaments/event/<?= $tournament_id; ?>" hx-get="/tournaments/event/<?= $tournament_id; ?>" hx-target="#main">
|
||||||
<?php if($run['category']): ?> <li>Typ: <?= escape($run['category']); ?></li><?php endif; ?>
|
<?= escape($tournament['name']); ?>
|
||||||
<?php if($run['length']): ?> <li>Länge: <?= escape($run['length']); ?>m</li><?php endif; ?>
|
</a></li>
|
||||||
<?php if($run['time_standard']): ?> <li>Normzeit: <?= escape($run['time_standard']); ?>s</li><?php endif; ?>
|
<?php if($run['category']): ?>
|
||||||
<?php if($run['time_max']): ?> <li>Maxzeit: <?= escape($run['time_max']); ?>s</li><?php endif; ?>
|
<li>Typ:
|
||||||
<?php if($run['referee']): ?> <li>Richter: <?= escape($run['referee']); ?></li><?php endif; ?>
|
<?= escape($run['category']); ?>
|
||||||
</ul>
|
</li>
|
||||||
|
<?php endif; ?>
|
||||||
|
<?php if($run['length']): ?>
|
||||||
|
<li>Länge:
|
||||||
|
<?= escape($run['length']); ?>m
|
||||||
|
</li>
|
||||||
|
<?php endif; ?>
|
||||||
|
<?php if($run['time_standard']): ?>
|
||||||
|
<li>Normzeit:
|
||||||
|
<?= escape($run['time_standard']); ?>s
|
||||||
|
</li>
|
||||||
|
<?php endif; ?>
|
||||||
|
<?php if($run['time_max']): ?>
|
||||||
|
<li>Maxzeit:
|
||||||
|
<?= escape($run['time_max']); ?>s
|
||||||
|
</li>
|
||||||
|
<?php endif; ?>
|
||||||
|
<?php if($run['referee']): ?>
|
||||||
|
<li>Richter:
|
||||||
|
<?= escape($run['referee']); ?>
|
||||||
|
</li>
|
||||||
|
<?php endif; ?>
|
||||||
|
</ul>
|
||||||
|
|
||||||
|
|
||||||
<div class="d-flex justify-content-end">
|
<div class="d-flex justify-content-end">
|
||||||
<?php if($admin===true): ?>
|
<?php if($admin===true): ?>
|
||||||
<button type="button" class="btn btn-secondary" hx-get="/runs/edit/<?= $run_id; ?>" hx-target="#main">
|
<button type="button" class="btn btn-secondary" hx-get="/runs/edit/<?= $run_id; ?>" hx-target="#main">
|
||||||
@ -36,15 +64,36 @@
|
|||||||
<?php endif; ?>
|
<?php endif; ?>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
</div>
|
</div>
|
||||||
<div class="col" id="sitemain">
|
<div class="col" id="sitemain">
|
||||||
|
<div class="card p-2 mb-2">
|
||||||
|
<div class="row">
|
||||||
|
<h3>Fotos</h3>
|
||||||
|
<?php foreach($results as $result) : ?>
|
||||||
|
<?php if($result['photos']): ?>
|
||||||
|
<?php foreach($result['photos'] as $photo) : ?>
|
||||||
|
|
||||||
|
<div class="col-md-4 mt-3 col-lg-3">
|
||||||
|
<a href="<?= $photo; ?>">
|
||||||
|
<img src="<?= $photo; ?>/100x100/forcesize" alt="<?= escape( (new Dog())->getField('name',$result['dog']) ) ?>'s Lauf" class="figure-img rounded">
|
||||||
|
</a>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<?php endforeach; ?>
|
||||||
|
|
||||||
|
<?php endif; ?>
|
||||||
|
<?php endforeach; ?>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
<div class="card p-2">
|
<div class="card p-2">
|
||||||
<h4>Ergebnisse</h4>
|
<h4>Ergebnisse</h4>
|
||||||
<p class="card-text">
|
<p class="card-text">
|
||||||
<button hx-get="/runs/addresults/<?= $run_id; ?>" hx-push-url="/runs/addresults/<?= $run_id; ?>" hx-target="#main" class="btn btn-primary"><i class="fas fa-plus-circle"></i> Ergebnis Eintragen</button>
|
<button hx-get="/runs/addresults/<?= $run_id; ?>" hx-push-url="/runs/addresults/<?= $run_id; ?>" hx-target="#main" class="btn btn-primary"><i class="fas fa-plus-circle"></i> Ergebnis Eintragen</button>
|
||||||
|
|
||||||
</p>
|
</p>
|
||||||
|
|
||||||
<table class="table">
|
<table class="table">
|
||||||
<thead>
|
<thead>
|
||||||
@ -64,23 +113,42 @@
|
|||||||
<tbody>
|
<tbody>
|
||||||
<?php foreach($results as $result) : ?>
|
<?php foreach($results as $result) : ?>
|
||||||
<tr>
|
<tr>
|
||||||
<td><?= escape($result['ranking']); ?></td>
|
<td>
|
||||||
<td><?= $result['disqualified']?'Ja':'Nein'; ?></td>
|
<?= escape($result['ranking']); ?>
|
||||||
<td><?= escape($result['refusals']); ?></td>
|
</td>
|
||||||
<td><?= escape($result['errors']); ?></td>
|
<td>
|
||||||
<td><?= escape($result['timefaults']); ?></td>
|
<?= $result['disqualified']?'Ja':'Nein'; ?>
|
||||||
<td><?= escape($result['runtime']); ?></td>
|
</td>
|
||||||
<td><?= escape($result['penalties']); ?></td>
|
<td>
|
||||||
<td><?= escape($result['speed']); ?></td>
|
<?= escape($result['refusals']); ?>
|
||||||
<td><?= escape($result['rating']); ?></td>
|
</td>
|
||||||
<td><a href="/dogs/overview/<?= $result['dog'] ?>"><?= escape( (new Dog())->getField('name',$result['dog']) ); ?></a></td>
|
<td>
|
||||||
|
<?= escape($result['errors']); ?>
|
||||||
|
</td>
|
||||||
|
<td>
|
||||||
|
<?= escape($result['timefaults']); ?>
|
||||||
|
</td>
|
||||||
|
<td>
|
||||||
|
<?= escape($result['runtime']); ?>
|
||||||
|
</td>
|
||||||
|
<td>
|
||||||
|
<?= escape($result['penalties']); ?>
|
||||||
|
</td>
|
||||||
|
<td>
|
||||||
|
<?= escape($result['speed']); ?>
|
||||||
|
</td>
|
||||||
|
<td>
|
||||||
|
<?= escape($result['rating']); ?>
|
||||||
|
</td>
|
||||||
|
<td><a href="/dogs/overview/<?= $result['dog'] ?>">
|
||||||
|
<?= escape( (new Dog())->getField('name',$result['dog']) ); ?>
|
||||||
|
</a></td>
|
||||||
</tr>
|
</tr>
|
||||||
<?php endforeach; ?>
|
<?php endforeach; ?>
|
||||||
</tbody>
|
</tbody>
|
||||||
</table>
|
</table>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
|
</div>
|
||||||
|
</div>
|
@ -8,7 +8,9 @@
|
|||||||
<link href="/css/animate.min.css" rel="stylesheet">
|
<link href="/css/animate.min.css" rel="stylesheet">
|
||||||
<link href="/css/fontawesome.min.css" rel="stylesheet">
|
<link href="/css/fontawesome.min.css" rel="stylesheet">
|
||||||
<link href="/css/bootstrap.min.css" rel="stylesheet">
|
<link href="/css/bootstrap.min.css" rel="stylesheet">
|
||||||
|
|
||||||
<link href="/css/dogstats.css" rel="stylesheet">
|
<link href="/css/dogstats.css" rel="stylesheet">
|
||||||
|
|
||||||
|
|
||||||
<script src="/js/echarts.min.js"></script>
|
<script src="/js/echarts.min.js"></script>
|
||||||
</head>
|
</head>
|
||||||
@ -37,6 +39,7 @@
|
|||||||
|
|
||||||
<script src="/js/htmx.min.js"></script>
|
<script src="/js/htmx.min.js"></script>
|
||||||
<script src="/js/bootstrap.bundle.min.js"></script>
|
<script src="/js/bootstrap.bundle.min.js"></script>
|
||||||
|
<script src="/js/dropzone.min.js"></script>
|
||||||
<?php if((!$_SESSION['user'] || !$_SESSION['user']->theme)): ?><script src="/js/color-modes.js"></script><?php endif; ?>
|
<?php if((!$_SESSION['user'] || !$_SESSION['user']->theme)): ?><script src="/js/color-modes.js"></script><?php endif; ?>
|
||||||
</body>
|
</body>
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user