Commit 12ce9057 authored by Yassine Doghri's avatar Yassine Doghri
Browse files

feat(podcast-form): update routes and redirect to podcast page

parent 32342243
Loading
Loading
Loading
Loading
+3 −0
Original line number Diff line number Diff line
@@ -125,3 +125,6 @@ nb-configuration.xml
/results/
/phpunit*.xml
/.phpunit.*.cache

# Media files
public/media/*
+8 −7
Original line number Diff line number Diff line
@@ -5,8 +5,7 @@ $routes = Services::routes();

// Load the system's routing file first, so that the app and ENVIRONMENT
// can override as needed.
if (file_exists(SYSTEMPATH . 'Config/Routes.php'))
{
if (file_exists(SYSTEMPATH . 'Config/Routes.php')) {
    require SYSTEMPATH . 'Config/Routes.php';
}

@@ -20,7 +19,8 @@ $routes->setDefaultController('Home');
$routes->setDefaultMethod('index');
$routes->setTranslateURIDashes(false);
$routes->set404Override();
$routes->setAutoRoute(true);
$routes->setAutoRoute(false);
$routes->addPlaceholder('podcastName', '^@[a-z0-9\_]{1,191}$');

/**
 * --------------------------------------------------------------------
@@ -31,6 +31,8 @@ $routes->setAutoRoute(true);
// We get a performance increase by specifying the default
// route since we don't have to scan directories.
$routes->get('/', 'Home::index');
$routes->add('/podcasts/create', 'Podcasts::create');
$routes->add('/(:podcastName)', 'Podcasts::podcastByHandle/$1');

/**
 * --------------------------------------------------------------------
@@ -45,7 +47,6 @@ $routes->get('/', 'Home::index');
 * You will have access to the $routes object within that file without
 * needing to reload it.
 */
if (file_exists(APPPATH . 'Config/' . ENVIRONMENT . '/Routes.php'))
{
if (file_exists(APPPATH . 'Config/' . ENVIRONMENT . '/Routes.php')) {
    require APPPATH . 'Config/' . ENVIRONMENT . '/Routes.php';
}
+22 −7
Original line number Diff line number Diff line
@@ -5,7 +5,7 @@ use App\Models\LanguageModel;
use App\Models\PodcastModel;
use RuntimeException;

class Podcast extends BaseController
class Podcasts extends BaseController
{
    public function index()
    {
@@ -15,10 +15,11 @@ class Podcast extends BaseController
    public function create()
    {
        $model = new PodcastModel();
        helper(['form', 'url']);

        if (!$this->validate([
            'title' => 'required',
            'name' => 'required|alpha_dash',
            'name' => 'required|regex_match[^[a-z0-9\_]{1,191}$]',
            'description' => 'required|max_length[4000]',
            'image' => 'uploaded[image]|is_image[image]|ext_in[image,jpg,png]|max_dims[image,3000,3000]',
            'owner_email' => 'required|valid_email|permit_empty',
@@ -38,20 +39,23 @@ class Podcast extends BaseController
                'browser_lang' => $browser_lang,
            ];

            echo view('podcast/create', $data);
            echo view('podcasts/create', $data);
        } else {
            $image = $this->request->getFile('image');
            if (!$image->isValid()) {
                throw new RuntimeException($image->getErrorString() . '(' . $image->getError() . ')');
            }
            $image_path = $image->store();
            $podcast_name = $this->request->getVar('name');
            $image_name = 'cover.' . $image->getExtension();
            $image_storage_folder = 'media/' . $podcast_name . '/';
            $image->move($image_storage_folder, $image_name);

            $model->save([
                'title' => $this->request->getVar('title'),
                'name' => $this->request->getVar('name'),
                'name' => $podcast_name,
                'description' => $this->request->getVar('description'),
                'episode_description_footer' => $this->request->getVar('episode_description_footer'),
                'image' => $image_path,
                'image' => $image_storage_folder . $image_name,
                'language' => $this->request->getVar('language'),
                'category' => $this->request->getVar('category'),
                'explicit' => $this->request->getVar('explicit') or false,
@@ -65,7 +69,18 @@ class Podcast extends BaseController
                'custom_html_head' => $this->request->getVar('custom_html_head'),
            ]);

            echo view('podcast/success');
            return redirect()->to(base_url('/@' . $podcast_name));
        }
    }

    public function podcastByHandle($handle)
    {
        $model = new PodcastModel();

        $podcast_name = substr($handle, 1);

        $data['podcast'] = $model->where('name', $podcast_name)->first();

        return view('podcasts/view.php', $data);
    }
}

src/app/Views/podcast/success.php

deleted100644 → 0
+0 −1
Original line number Diff line number Diff line
Success!
+1 −2
Original line number Diff line number Diff line
<?=helper('form')?>
<?=$this->extend('layouts/default')?>

<?=$this->section('content')?>
@@ -9,7 +8,7 @@
    <?=\Config\Services::validation()->listErrors()?>
</div>

<?=form_open_multipart('/podcast/create', ["method" => "post", "class" => "flex flex-col max-w-md"])?>
<?=form_open_multipart('podcasts/create', ["method" => "post", "class" => "flex flex-col max-w-md"])?>
    <?=csrf_field()?>

    <div class="flex flex-col mb-4">
Loading