Пример #1
0
 /**
  * Dashboard /login action
  *
  * @return void
  */
 public function login()
 {
     if (site()->user()) {
         go('dashboard');
     }
     // save the flashed redirect
     flash('login.redirect', flash('login.redirect'));
     if (r::is('post')) {
         if ($this->form->validates()) {
             $user = site()->user($this->form->data('username'));
             if ($user && $user->login($this->form->data('password'))) {
                 flash('messages.success', 'Logged in!');
                 if (get('_redirect')) {
                     go(get('_redirect'));
                 }
             } else {
                 $this->form->addErrors(['login' => 'Invalid username and password']);
             }
         }
         go('login');
     }
     $this->render('dashboard/login', ['pageTitle' => 'Login', 'form' => $this->form, 'page' => page()]);
 }
Пример #2
0
<?php

use Crazy\Form;
return function ($site, $pages, $page) {
    $studio = $page->parent();
    $form = new Form(['_token' => ['rules' => ['required', csrf(get('_token'))], 'message' => 'Invalid security token. Please try again.'], 'name' => ['rules' => ['required'], 'message' => 'Name is required'], 'email' => ['rules' => ['required', 'email'], 'message' => 'Valid email is required'], 'phone' => [], 'message' => []]);
    if (r::is('post')) {
        if ($form->validates()) {
            flash('messages.success', "Thanks! We'll be back in touch very soon!");
            event('studio.contacted', array_merge(['studio' => $studio], $form->data()));
        }
        go($page->url());
    }
    return ['studio' => $studio, 'form' => $form];
};
Пример #3
0
     $coupon = $order->applyCoupon(get('coupon_code'));
     if (!$coupon) {
         $promoForm->addError('coupon_code', 'Sorry, that coupon is not available.');
     }
 } else {
     if ($form->validates()) {
         // Accept the payment
         try {
             $stripeMode = env('STRIPE_API_MODE', 'test');
             if ($stripeMode == 'test') {
                 Stripe::setApiKey(env('STRIPE_TEST_SECRET_KEY'));
             }
             if ($stripeMode == 'live') {
                 Stripe::setApiKey(env('STRIPE_LIVE_SECRET_KEY'));
             }
             $charge = Charge::create(['card' => ['number' => $form->data('card_number'), 'exp_month' => $form->data('exp_month'), 'exp_year' => $form->data('exp_year'), 'name' => $form->data('billing_name')], 'amount' => $order->totalCents(), 'metadata' => ['email' => $form->data('email'), 'event_url' => $order->event()->tinyurl(), 'guests' => $order->guestlist()], 'description' => "{$order->quantity()} Ticket(s) for {$order->event()->title()->html()} @ {$order->event()->studio()->title()->html()} @ {$order->event()->tinyDateTime()}", 'currency' => 'usd']);
         } catch (Exception $e) {
             $form->addError('payment', $e->getMessage());
             $form->saveData();
             go($page->url());
         }
         // Save the order
         $orderPage = $order->store($form->data());
         // Empty the order and form sessions
         $order->deconstruct();
         // Fire event
         event('tickets.purchased', ['studio' => $studio, 'event' => $event, 'orderId' => $orderPage->title()->toString()]);
         // Redirect to a thank you page
         flash('messages.success', snippet('events/checkout/thanks', ['order' => $orderPage], true));
         go($order->event()->url());
     }