Skip to content
Snippets Groups Projects
Commit 6fbb5a24 authored by Dominik Hebeler's avatar Dominik Hebeler
Browse files

Merge branch '1103-keys-for-donors' into 'development'

Resolve "Keys for donors"

Closes #1103

See merge request !1819
parents f606f5df 0101688d
No related branches found
No related tags found
3 merge requests!1895Development,!1841Development,!1819Resolve "Keys for donors"
...@@ -137,8 +137,22 @@ class MailController extends Controller ...@@ -137,8 +137,22 @@ class MailController extends Controller
public function donation(Request $request) public function donation(Request $request)
{ {
$firstname = "";
$lastname = "";
$company = "";
$private = $request->input('person', '') === 'private' ? true : false;
if($request->input('person', '') === 'private') {
$firstname = $request->input('firstname');
$lastname = $request->input('lastname');
} elseif($request->input('person', '') === 'company') {
$company = $request->input('companyname');
}
$data = [ $data = [
'name' => $request->input('Name', ''), 'person' => $request->input('person', ''),
'firstname' => $request->input('firstname', ''),
'lastname' => $request->input('lastname', ''),
'company' => $company,
'iban' => $request->input('iban', ''), 'iban' => $request->input('iban', ''),
'bic' => $request->input('bic', ''), 'bic' => $request->input('bic', ''),
'email' => $request->input('email', ''), 'email' => $request->input('email', ''),
...@@ -146,7 +160,7 @@ class MailController extends Controller ...@@ -146,7 +160,7 @@ class MailController extends Controller
'frequency' => $request->input('frequency', ''), 'frequency' => $request->input('frequency', ''),
'nachricht' => $request->input('Nachricht', ''), 'nachricht' => $request->input('Nachricht', ''),
]; ];
$name = $request->input('Name', '');
$iban = $request->input('iban', ''); $iban = $request->input('iban', '');
$bic = $request->input('bic', ''); $bic = $request->input('bic', '');
$email = $request->input('email', ''); $email = $request->input('email', '');
...@@ -175,7 +189,6 @@ class MailController extends Controller ...@@ -175,7 +189,6 @@ class MailController extends Controller
# Check the IBAN # Check the IBAN
$iban = new IBAN($iban); $iban = new IBAN($iban);
$bic = $request->input('Bankleitzahl', '');
$country = new IBANCountry($iban->Country()); $country = new IBANCountry($iban->Country());
$isSEPA = filter_var($country->IsSEPA(), FILTER_VALIDATE_BOOLEAN); $isSEPA = filter_var($country->IsSEPA(), FILTER_VALIDATE_BOOLEAN);
...@@ -186,8 +199,10 @@ class MailController extends Controller ...@@ -186,8 +199,10 @@ class MailController extends Controller
if (!filter_var($email, FILTER_VALIDATE_EMAIL)) { if (!filter_var($email, FILTER_VALIDATE_EMAIL)) {
$email = "anonymous@suma-ev.de"; $email = "anonymous@suma-ev.de";
} }
if(($private && (empty($firstname) || empty($lastname))) || (!$private && empty($company))){
if (!$iban->Verify()) { $messageToUser = trans('spende.error.name');
$messageType = "error";
} elseif (!$iban->Verify()) {
$messageToUser = trans('spende.error.iban'); $messageToUser = trans('spende.error.iban');
$messageType = "error"; $messageType = "error";
} elseif (!$isSEPA && $bic === '') { } elseif (!$isSEPA && $bic === '') {
...@@ -204,59 +219,44 @@ class MailController extends Controller ...@@ -204,59 +219,44 @@ class MailController extends Controller
# The value has to have a maximum of 2 decimal digits # The value has to have a maximum of 2 decimal digits
$betrag = round($betrag, 2, PHP_ROUND_HALF_DOWN); $betrag = round($betrag, 2, PHP_ROUND_HALF_DOWN);
# Folgende Felder werden vom Spendenformular als Input übergeben: # Generating personalised key for donor
# Name $key = app('App\Models\Key')->generateKey($betrag);
# Telefon
# email
# Kontonummer ( IBAN )
# Bankleitzahl ( BIC )
# Nachricht
$message = "\r\nName: " . $name;
$message .= "\r\nIBAN: " . $iban->HumanFormat();
if ($bic !== "") {
$message .= "\r\nBIC: " . $bic;
}
$message .= "\r\nBetrag: " . $betrag;
$message .= "\r\nHäufigkeit: " . trans('spende.frequency.' . $frequency);
$message .= "\r\nNachricht: " . $nachricht;
try { try {
$postdata = [ $postdata = [
"alert" => true, "entity" => "Contribution",
"autorespond" => true, "action" => "mgcreate",
"source" => "API", "api_key" => env("CIVICRM_API_KEY", ''),
"name" => $name, "key" => env("CIVICRM_SITE_KEY", ''),
"json" => 1,
"iban" => $iban->MachineFormat(),
"bic" => $bic,
"amount" => $betrag,
"frequency" => $frequency,
"email" => $email, "email" => $email,
"subject" => "MetaGer - Spende", "mgkey" => $key,
"ip" => $request->ip(), "message" => $nachricht
"deptId" => 4,
"message" => "data:text/plain;charset=utf-8, $message",
]; ];
if (LaravelLocalization::getCurrentLocale() === "de") { if($request->input('person') === 'private') {
$postdata["deptId"] = 4; $postdata['first_name'] = $firstname;
} $postdata['last_name'] = $lastname;
} elseif($request->input('person') === 'company') {
if($email === "anonymous@suma-ev.de"){ $postdata['business_name'] = $company;
$postdata["autorespond"] = false;
} }
$postdata = json_encode($postdata); $postdata = http_build_query($postdata);
$resulthash = md5($message); $resulthash = md5(json_encode($postdata));
$mission = [ $mission = [
"resulthash" => $resulthash, "resulthash" => $resulthash,
"url" => env("TICKET_URL", "https://metager.de"), "url" => env("CIVICRM_URL", "https://metager.de"),
"useragent" => "Mozilla/5.0 (X11; Ubuntu; Linux x86_64; rv:81.0) Gecko/20100101 Firefox/81.0", "useragent" => "Mozilla/5.0 (X11; Ubuntu; Linux x86_64; rv:81.0) Gecko/20100101 Firefox/81.0",
"username" => null, "username" => null,
"password" => null, "password" => null,
"headers" => [ "headers" => [
"X-API-Key" => env("TICKET_APIKEY", ""), "Content-Type" => "application/x-www-form-urlencoded",
"Content-Type" => "application/json",
"Content-Length" => strlen($postdata)
], ],
"cacheDuration" => 0, "cacheDuration" => 0,
"name" => "Ticket", "name" => "Ticket",
...@@ -296,6 +296,7 @@ class MailController extends Controller ...@@ -296,6 +296,7 @@ class MailController extends Controller
->with('data', $data); ->with('data', $data);
} else { } else {
$data['iban'] = $iban->HumanFormat(); $data['iban'] = $iban->HumanFormat();
$data['key'] = $key;
$data = base64_encode(serialize($data)); $data = base64_encode(serialize($data));
return redirect(LaravelLocalization::getLocalizedURL(LaravelLocalization::getCurrentLocale(), route("danke", ['data' => $data]))); return redirect(LaravelLocalization::getLocalizedURL(LaravelLocalization::getCurrentLocale(), route("danke", ['data' => $data])));
} }
......
...@@ -56,7 +56,6 @@ class Key ...@@ -56,7 +56,6 @@ class Key
} }
} }
public function updateStatus() public function updateStatus()
{ {
$authKey = base64_encode(env("KEY_USER", "test") . ':' . env("KEY_PASSWORD", "test")); $authKey = base64_encode(env("KEY_USER", "test") . ':' . env("KEY_PASSWORD", "test"));
...@@ -119,4 +118,35 @@ class Key ...@@ -119,4 +118,35 @@ class Key
return false; return false;
} }
} }
public function generateKey($payment)
{
$authKey = base64_encode(env("KEY_USER", "test") . ':' . env("KEY_PASSWORD", "test"));
$postdata = http_build_query(array(
'payment' => $payment,
'apiAccess' => 'normal',
'notes' => 'Fuer ' . $payment . '€ aufgeladen am '. date("d.m.Y"),
'expiresAfterDays' => 365
));
$opts = array(
'http' => array(
'method' => 'POST',
'header' => [
'Content-type: application/x-www-form-urlencoded',
'Authorization: Basic ' . $authKey
],
'content' => $postdata,
'timeout' => 5
),
);
$context = stream_context_create($opts);
try {
$link = $this->keyserver . "v2/key/";
$result = json_decode(file_get_contents($link, false, $context));
return $result->{'mgKey'};
} catch (\ErrorException $e) {
return false;
}
}
} }
...@@ -30,12 +30,16 @@ return [ ...@@ -30,12 +30,16 @@ return [
'bankinfo.2.2' => 'BIC: GENODEM1GLS', 'bankinfo.2.2' => 'BIC: GENODEM1GLS',
'bankinfo.2.3' => 'Bank: GLS Gemeinschaftsbank, Bochum', 'bankinfo.2.3' => 'Bank: GLS Gemeinschaftsbank, Bochum',
'bankinfo.2.4' => '(Konto-Nr.: 4075 0332 01, BLZ: 43060967)', 'bankinfo.2.4' => '(Konto-Nr.: 4075 0332 01, BLZ: 43060967)',
'bankinfo.3' => 'Falls Sie eine Spendenbescheinigung wünschen, teilen Sie uns bitte Ihre vollständige Adresse mit. Bei Spenden bis 200,-€ genügt der Kontoauszug für die Absetzbarkeit beim Finanzamt.', 'bankinfo.3' => 'Falls Sie eine Spendenbescheinigung wünschen, teilen Sie uns bitte Ihre vollständige Adresse mit. Bei Spenden bis 300,-€ genügt der Kontoauszug für die Absetzbarkeit beim Finanzamt.',
'lastschrift.1' => 'Spenden mittels elektronischem Lastschriftverfahren:', 'lastschrift.1' => 'Spenden mittels elektronischem Lastschriftverfahren:',
'lastschrift.2' => 'Tragen Sie hier Ihre Kontodaten ein. Wir buchen dann entsprechend von Ihrem Konto ab. Notwendige Felder sind mit einem "*" gekennzeichnet.', 'lastschrift.2' => 'Tragen Sie hier Ihre Kontodaten ein. Wir buchen dann entsprechend von Ihrem Konto ab. Notwendige Felder sind mit einem "*" gekennzeichnet.',
'lastschrift.3' => 'Bitte geben Sie den Namen des Kontoinhabers ein:', 'lastschrift.3f' => 'Bitte geben Sie den Vornamen des Kontoinhabers ein:',
'lastschrift.3.placeholder' => 'Name', 'lastschrift.3f.placeholder' => 'Vorname',
'lastschrift.3l' => 'Bitte geben Sie den Nachnamen des Kontoinhabers ein:',
'lastschrift.3l.placeholder' => 'Nachname',
'lastschrift.3c' => 'Bitte geben Sie den Firmenkontonamen ein:',
'lastschrift.3c.placeholder' => 'Firma',
'lastschrift.4' => 'Ihre E-Mail Adresse:', 'lastschrift.4' => 'Ihre E-Mail Adresse:',
'lastschrift.5' => 'Ihre Telefonnummer, um Ihre Spende ggf. durch einen Rückruf zu verifizieren:', 'lastschrift.5' => 'Ihre Telefonnummer, um Ihre Spende ggf. durch einen Rückruf zu verifizieren:',
'lastschrift.6' => 'Ihre IBAN:', 'lastschrift.6' => 'Ihre IBAN:',
...@@ -43,6 +47,9 @@ return [ ...@@ -43,6 +47,9 @@ return [
'lastschrift.8.message' => 'Hier können Sie uns ggf. noch eine Mitteilung dazu senden:', 'lastschrift.8.message' => 'Hier können Sie uns ggf. noch eine Mitteilung dazu senden:',
'lastschrift.8.message.placeholder' => 'Weitere Angaben', 'lastschrift.8.message.placeholder' => 'Weitere Angaben',
'lastschrift.10' => 'Ihre Daten werden über eine verschlüsselte Verbindung zu uns übertragen und können von Dritten nicht mitgelesen werden. SUMA-EV verwendet Ihre Daten ausschließlich für die Spendenabrechnung; Ihre Daten werden nicht weitergegeben. Spenden an den SUMA-EV sind steuerlich absetzbar, da der Verein vom Finanzamt Hannover Nord als gemeinnützig anerkannt ist, eingetragen in das Vereinsregister beim Amtsgericht Hannover unter VR200033.', 'lastschrift.10' => 'Ihre Daten werden über eine verschlüsselte Verbindung zu uns übertragen und können von Dritten nicht mitgelesen werden. SUMA-EV verwendet Ihre Daten ausschließlich für die Spendenabrechnung; Ihre Daten werden nicht weitergegeben. Spenden an den SUMA-EV sind steuerlich absetzbar, da der Verein vom Finanzamt Hannover Nord als gemeinnützig anerkannt ist, eingetragen in das Vereinsregister beim Amtsgericht Hannover unter VR200033.',
'lastschrift.private' => '*Privatperson:',
'lastschrift.company' => '*Firma:',
'paypal.1' => 'Mit einem Klick auf Spenden werden Sie zu Paypal weitergeleitet.', 'paypal.1' => 'Mit einem Klick auf Spenden werden Sie zu Paypal weitergeleitet.',
...@@ -60,16 +67,19 @@ return [ ...@@ -60,16 +67,19 @@ return [
'drucken' => 'Drucken', 'drucken' => 'Drucken',
'danke.title' => 'Herzlichen Dank!! Wir haben Ihre Spendenbenachrichtigung für MetaGer an SUMA-EV erhalten.', 'danke.title' => 'Herzlichen Dank! Wir haben Ihre Spendenbenachrichtigung erhalten.',
'danke.nachricht' => 'Falls Sie Kontaktdaten angegeben haben, erhalten Sie demnächst auch eine persönliche Nachricht.', 'danke.nachricht' => 'Falls Sie Kontaktdaten angegeben haben, erhalten Sie demnächst auch eine persönliche Nachricht.',
'danke.kontrolle' => 'Folgende Nachricht hat uns erreicht:', 'danke.kontrolle' => 'Folgende Nachricht hat uns erreicht:',
'danke.schluessel' => 'Als kleines Dankeschön bieten wir unseren Spendern einen Schlüssel für werbefreie Suchen. <br> Dieser lässt sich eingeben indem man auf das Schlüsselsymbol neben der Suchleiste klickt. <br> Ihr Schlüssel lautet: ',
'telefonnummer' => 'Telefonnummer', 'telefonnummer' => 'Telefonnummer',
'iban' => 'IBAN/Kontonummer', 'iban' => 'IBAN',
'bic' => 'BIC/Bankleitzahl', 'bic' => 'BIC',
'betrag' => 'Betrag', 'betrag' => 'Betrag',
'danke.message' => 'Ihre Nachricht', 'danke.message' => 'Ihre Nachricht',
'error.name' => 'Es scheint, als hätten sie keinen Namen angegeben. Bitte versuchen Sie es erneut.',
'error.iban' => 'Die eingegebene IBAN scheint nicht Korrekt zu sein. Nachricht wurde nicht gesendet.', 'error.iban' => 'Die eingegebene IBAN scheint nicht Korrekt zu sein. Nachricht wurde nicht gesendet.',
'error.bic' => 'Die eingegebene IBAN gehört nicht zu einem Land aus dem SEPA Raum. Für einen Bankeinzug benötigen wir eine BIC von Ihnen.', 'error.bic' => 'Die eingegebene IBAN gehört nicht zu einem Land aus dem SEPA Raum. Für einen Bankeinzug benötigen wir eine BIC von Ihnen.',
'error.amount' => 'Der eingegebene Spendenbetrag ist ungültig. Bitte korrigieren Sie Ihre Eingabe und versuchen es erneut.', 'error.amount' => 'Der eingegebene Spendenbetrag ist ungültig. Bitte korrigieren Sie Ihre Eingabe und versuchen es erneut.',
......
...@@ -35,17 +35,20 @@ return [ ...@@ -35,17 +35,20 @@ return [
"lastschrift.1" => "Donate by Sepa direct debit", "lastschrift.1" => "Donate by Sepa direct debit",
"lastschrift.2" => "Enter your account data. We will debit your bank account accordingly. This method is only available for SEPA area. Required fields are marked with \"*\"", "lastschrift.2" => "Enter your account data. We will debit your bank account accordingly. This method is only available for SEPA area. Required fields are marked with \"*\"",
"lastschrift.3" => "Please enter your name:", "lastschrift.3f.placeholder" => "First Name",
"lastschrift.3.placeholder" => "Name", "lastschrift.3l.placeholder" => "Last Name",
"lastschrift.4" => "Your E-Mail adress:", "lastschrift.3c.placeholder" => "Business Name",
"lastschrift.4" => "Your E-Mail Adress:",
"lastschrift.5" => "Your phone number to verify your donation by callback:", "lastschrift.5" => "Your phone number to verify your donation by callback:",
"lastschrift.6" => "Your IBAN:", "lastschrift.6" => "Your IBAN:",
"lastschrift.7" => "Your BIC:", "lastschrift.7" => "Your BIC:",
"lastschrift.8.value" => "Here you can tell us, what amount you want to donate:", "lastschrift.8.value" => "Here you can tell us, what amount you want to donate:",
"lastschrift.8.message" => "Here you can informally add a message to your donation:", "lastschrift.8.message" => "Here you can informally add a message to your donation:",
"lastschrift.8.message.placeholder" => "message", "lastschrift.8.message.placeholder" => "Message",
"lastschrift.9" => "Donate", "lastschrift.9" => "Donate",
"lastschrift.10" => "Your information is transmitted encrypted and is not read by a third party. SUMA-EV only uses your information for accounting; Your information is not passed on. Donations to the SUMA-EV are tax-deductible, because the association is recognized as charitable by the Finanzamt Hannover Nord (revenue board), listed in the register of associations, Amtsgericht Hannover under VR200033. A certificate for single donations above 200,-EUR is sent automatically (post address is required!). For donations below 200,-EUR an account current is enough for tax-deduction.", "lastschrift.10" => "Your information is transmitted encrypted and is not read by a third party. SUMA-EV only uses your information for accounting; Your information is not passed on. Donations to the SUMA-EV are tax-deductible, because the association is recognized as charitable by the Finanzamt Hannover Nord (revenue board), listed in the register of associations, Amtsgericht Hannover under VR200033. A certificate for single donations above 300,-EUR is sent automatically (post address is required!). For donations below 300,-EUR an account current is enough for tax-deduction.",
"lastschrift.private" => "*As a Person:",
"lastschrift.company" => "*As a Business:",
'paypal.1' => 'You will be redirected where you can finalize your donation.', 'paypal.1' => 'You will be redirected where you can finalize your donation.',
......
...@@ -61,6 +61,12 @@ label { ...@@ -61,6 +61,12 @@ label {
// address browser inconsistencies. // address browser inconsistencies.
// Override content-box in Normalize (* isn't specific enough) // Override content-box in Normalize (* isn't specific enough)
input[type="text"] {
background-color: @input-background;
color: @input-text;
padding: 4px 8px;
}
input[type="search"] { input[type="search"] {
.box-sizing(border-box); .box-sizing(border-box);
} }
......
...@@ -68,6 +68,7 @@ ...@@ -68,6 +68,7 @@
} }
input:checked + .frequency-label { input:checked + .frequency-label {
border: 2px solid #f47216; border: 2px solid #f47216;
font-weight: bold;
} }
} }
#payment-methods { #payment-methods {
...@@ -162,5 +163,16 @@ ...@@ -162,5 +163,16 @@
grid-area: form; grid-area: form;
} }
} }
#input-picker{
label {
min-width: 8em;
}
.show-on-input-checked {
display: none;
}
input:checked + label + .show-on-input-checked {
display: inline-block;
}
}
} }
\ No newline at end of file
.data-element {
&> label {
min-width: 100px;
}
&> input, textarea {
padding: 4px 8px;
min-width: 250px;
}
}
\ No newline at end of file
...@@ -5,52 +5,64 @@ ...@@ -5,52 +5,64 @@
@section('navbarFocus.donate', 'class="dropdown active"') @section('navbarFocus.donate', 'class="dropdown active"')
@section('content') @section('content')
<h1>{{ trans('spende.danke.title') }}</h1> <div id="donation-data" class="card-heavy">
<div class="col"> <h2>{{ trans('spende.danke.title') }}</h2>
<div id="left" class="col-lg-6 col-md-12 col-sm-12 others"> <p style="width:100%;" class="text-muted">{{ trans('spende.danke.nachricht') }}</p>
<p style="width:100%;" class="text-muted">{{ trans('spende.danke.nachricht') }}</p> <h3>{{ trans('spende.danke.kontrolle') }}</h3>
<h2>{{ trans('spende.danke.kontrolle') }}</h2> <div>
<div> @if($data["person"] === "private")
<table class="table table-condensed"> <div class="data-element">
<tr> <label for="firstname" style="margin-right: 16px;">{{ trans('spende.lastschrift.3f.placeholder')}}</label>
<td>{{ trans('spende.lastschrift.3.placeholder')}}</td> <input type="text" name="firstname" id="firstname" value="{{ $data['firstname'] }}" readonly>
<td>{{ $data['name'] }}</td> </div>
</tr> <div class="data-element">
<tr> <label for="lastname" style="margin-right: 16px;">{{ trans('spende.lastschrift.3l.placeholder')}}</label>
<td>Email</td> <input type="text" name="lastname" id="lastname" value="{{ $data['lastname'] }}" readonly>
<td>{{ $data['email'] }}</td> </div>
</tr> @else
<tr> <div class="data-element">
<td>{{ trans('spende.iban') }}</td> <label for="company" style="margin-right: 16px;">{{ trans('spende.lastschrift.3c.placeholder')}}</label>
<td>{{ $data['iban'] }}</td> <input type="text" name="company" id="company" value="{{ $data['company'] }}" readonly>
</tr> </div>
<tr> @endif
<td>{{ trans('spende.bic') }}</td> @if(!empty($data['email']))
<td>{{ $data['bic'] }}</td> <div class="data-element">
</tr> <label for="email" style="margin-right: 16px;">Email</label>
<tr> <input type="text" name="email" id="email" value="{{ $data['email'] }}" readonly>
<td>{{ trans('spende.betrag') }}</td> </div>
<td>{{ $data['betrag'] }} </td> @endif
</tr> <div class="data-element">
<tr> <label for="iban" style="margin-right: 16px;">{{ trans('spende.iban') }}</label>
<td>{{ trans('spende.frequency') }}</td> <input type="text" name="iban" id="iban" value="{{ $data['iban'] }}" readonly>
<td>{{ trans('spende.frequency.' . $data['frequency']) }} </td> </div>
</tr> @if(!empty($data["bic"]))
<tr> <div class="data-element">
<td>{{ trans('spende.danke.message') }}</td> <label for="bic" style="margin-right: 16px;">{{ trans('spende.bic') }}</label>
<td>{{ $data['nachricht'] }}</td> <input type="text" name="bic" id="bic" value="{{ $data['bic'] }}" readonly>
</tr> </div>
</table> @endif
</div> <div class="data-element">
<button type="button" class="btn btn-primary noprint" onclick="window.print();">{{ trans('spende.drucken') }}</button> <label for="betrag" style="margin-right: 16px;">{{ trans('spende.betrag') }}</label>
</div> <input type="text" name="betrag" id="betrag" value="{{ $data['betrag'] }} €" readonly>
<div class="col-lg-6 col-md-12 col-sm-12 others noprint" id="right"> </div>
<h2>{{ trans('about.about.1') }}</h2> <div class="data-element">
<p>{!! trans('about.about.2') !!}</p> <label for="frequency" style="margin-right: 16px;">{{ trans('spende.frequency') }}</label>
<p>{!! trans('about.about.3') !!}</p> <input type="text" name="frequency" id="frequency" value="{{ trans('spende.frequency.' . $data['frequency']) }}" readonly>
<p>{!! trans('about.about.4') !!}</p> </div>
<p>{!! trans('about.about.5') !!}</p> <div class="data-element">
</div> <label for="nachricht" style="margin-right: 16px;">{{ trans('spende.danke.message') }}</label>
<div class="clearfix"></div> <textarea name="nachricht" id="nachricht" readonly>{{ $data['nachricht'] }}</textarea>
</div>
</div>
<button type="button" style="margin-top: 16px; margin-bottom: 16px;" class="btn btn-primary noprint js-only" onclick="window.print();">{{ trans('spende.drucken') }}</button>
@if($data['key'] !== false)
<div class="card-light">
<p style="text-align: center; width:100%;">{!! trans('spende.danke.schluessel') !!}</p>
<div class="copyLink">
<input id="key" class="loadSettings" type="text" style="text-align: center;" value="{{ $data['key'] }}">
<button class="btn btn-default js-only" onclick="var copyText = document.getElementById('key');copyText.select();copyText.setSelectionRange(0, 99999);document.execCommand('copy');">Kopieren</button>
</div>
</div>
@endif
</div> </div>
@endsection @endsection
...@@ -95,9 +95,17 @@ ...@@ -95,9 +95,17 @@
<h3>{!! trans('spende.headline.6') !!}</h3> <h3>{!! trans('spende.headline.6') !!}</h3>
<p>{!! trans('spende.lastschrift.2') !!}</p> <p>{!! trans('spende.lastschrift.2') !!}</p>
<input type="hidden" name="dt" value="{{ md5(date('Y') . date('m') . date('d')) }}"> <input type="hidden" name="dt" value="{{ md5(date('Y') . date('m') . date('d')) }}">
<div class="form-group donation-form-group"> <div id="input-picker" class="form-group donation-form-group">
<label for="Name">*{!! trans('spende.lastschrift.3') !!}</label> <input type="radio" required="required" id="private" name="person" value="private" @if(empty($data) || $data["person"] === "private")checked="checked"@endif><label for="private">{{trans('spende.lastschrift.private')}}</label>
<input type="text" required="required" class="form-control" id="Name" name="Name" placeholder="{!! trans('spende.lastschrift.3.placeholder') !!}" @if(isset($data['name'])) value="{{$data['name']}}" @endif /> <div id="input-private" class="show-on-input-checked form-inline">
<input type="text" class="form-control" id="firstname" name="firstname" placeholder="{!! trans('spende.lastschrift.3f.placeholder') !!}" @if(isset($data['firstname'])) value="{{$data['firstname']}}" @endif />
<input type="text" class="form-control" id="lastname" name="lastname" placeholder="{!! trans('spende.lastschrift.3l.placeholder') !!}" @if(isset($data['lastname'])) value="{{$data['lastname']}}" @endif />
</div>
<br>
<input type="radio" id="company" name="person" value="company" @if(!empty($data) && $data["person"] === "company")checked="checked"@endif><label for="company">{{trans('spende.lastschrift.company')}}</label>
<div id="input-company" class="show-on-input-checked form-inline">
<input type="text" class="form-control" id="companyname" name="companyname" placeholder="{!! trans('spende.lastschrift.3c.placeholder') !!}" @if(isset($data['company'])) value="{{$data['company']}}" @endif />
</div>
</div> </div>
<div class="form-group donation-form-group"> <div class="form-group donation-form-group">
<label for="email">{!! trans('spende.lastschrift.4') !!}</label> <label for="email">{!! trans('spende.lastschrift.4') !!}</label>
......
...@@ -91,6 +91,7 @@ Route::group( ...@@ -91,6 +91,7 @@ Route::group(
return view('spende.danke') return view('spende.danke')
->with('title', trans('titles.spende')) ->with('title', trans('titles.spende'))
->with('navbarFocus', 'foerdern') ->with('navbarFocus', 'foerdern')
->with('css', [mix('/css/spende/danke.css')])
->with('data', unserialize(base64_decode($data))); ->with('data', unserialize(base64_decode($data)));
}]); }]);
Route::get('partnershops', function () { Route::get('partnershops', function () {
......
...@@ -55,6 +55,9 @@ mix ...@@ -55,6 +55,9 @@ mix
.less("resources/less/metager/pages/count/style.less", "public/css/count/style.css", { .less("resources/less/metager/pages/count/style.less", "public/css/count/style.css", {
strictMath: true strictMath: true
}) })
.less("resources/less/metager/pages/spende/danke.less", "public/css/spende/danke.css", {
strictMath: true
})
// js // js
.babel( .babel(
[ [
......
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment