সিড ও ইনডেক্স পেইজ

প্রস্তুতি

যেহেতু এই প্রোজেক্টটি একটি blog এর মতো হবে তাই হোম বা ইনডেক্স পেইজ এ আমাদের পোস্ট গুলোর লিস্ট থাকাই স্বাভাবিক।

posts টেবিল এর জন্য Post মডেল তৈরিঃ

মডেল অধ্যায়ে আমার এই বিষয় নিয়ে বেশ আলোচনা করেছিলাম, চাইলে একবার ঘুরে আসতে পারেন।
আসুন নিচের কমান্ডটি দেইঃ
1
php artisan make:model Post
Copied!
project.one/app/Post.php ফাইলটি আমরা পাবো, সাধারণ নিয়ম অনুসারে Post ক্লাসটি, গত অধ্যায়ে migrate করা posts টেবিলটাকেই গ্রহণ করবে। আসুন টেবিলটি দেখে নেইঃ
এবার Post.php ফাইলটি খুলি
1
<?php
2
3
namespace App;
4
5
use Illuminate\Database\Eloquent\Model;
6
7
class Post extends Model
8
{
9
//
10
}
Copied!
এবং নিচের মতো পরিবর্তন করি
1
class Post extends Model
2
{
3
protected $guarded = ['status'];
4
protected $fillable = ['title', 'content'];
5
}
Copied!
অংশটি বোঝার জন্য এইখানে দেখুন

posts টেবিল এ কিছু রেকর্ড ইন্সার্ট করি ডেভেলপমেন্ট এর সুবিধার জন্য

আমরা আগেই Tinker ব্যবহার করে কিভাবে টেবিলে ডাটা ইন্সার্ট করা যায় তা দেখেছিলাম। আজ দেখবো Seeding ।

সিডিং(Seeding)

লারাভেল ডাটাবেজে টেস্ট ডাটা ইন্সার্ট করার জন্য সাধারণ একটি method যোগ করেছে, যার নাম সিডিং(Seeding)। সব সিড ক্লাস database/seeds ডাইরেক্টরিতে থাকে। সিড ক্লাস এর নাম আপনি যেকোনো কিছুই দিতে পারেন, কিন্তু কিছু রীতি মেনে নাম দেয়াই ভালো, যেমন আমাদের posts টেবিলের সিডার ক্লাস এর নাম হতে পারে PostsTableSeeder
আসুন তাহলে আমাদের সিডার বানিয়ে ফেলি নিচের কমান্ড দিয়েঃ
1
php artisan make:seeder PostsTableSeeder
Copied!
আমরা নিশ্চয় project.one/database/seeds/PostsTableSeeder.php ফাইলটি পাবো।
1
<?php
2
3
use Illuminate\Database\Seeder;
4
5
class PostsTableSeeder extends Seeder
6
{
7
/**
8
* Run the database seeds.
9
*
10
* @return void
11
*/
12
public function run()
13
{
14
//
15
}
16
}
Copied!
আমাদের ফাইলটাকে পরিবর্তন করার আগে আসুন project.one/database/seeds/DatabaseSeeder.php ফাইল এ একটু পরিবর্তন আনি নিচের মতো।
1
<?php
2
3
use Illuminate\Database\Seeder;
4
5
class DatabaseSeeder extends Seeder
6
{
7
/**
8
* Run the database seeds.
9
*
10
* @return void
11
*/
12
public function run()
13
{
14
$this->call(PostsTableSeeder::class);
15
}
16
}
Copied!
এবার project.one/database/seeds/PostsTableSeeder.php ফাইলটাকে পরিবর্তন করি
1
public function run()
2
{
3
DB::table('posts')->insert([
4
'title' => 'Seeding Title',
5
'content' => 'Seeding content'
6
]);
7
}
Copied!
এবার নিচের কমান্ডটি দিন ও ডাটাবেজে টেবিলটির পরিবর্তন লক্ষ্য করুন।
1
php artisan db:seed
Copied!
সতর্কতাঃ আপনি যদি নিচের মতো এরর দেখেন
1
2
[ReflectionException]
3
Class PostsTableSeeder does not exist
Copied!
তাহলে নিচের কমান্ডটি দিন।
1
2
composer dump-autoload
Copied!
আবার db::seed কমান্ডটি দিন ও ডাটাবেজে টেবিলটির পরিবর্তন লক্ষ্য করুন।
কিন্তু Tinker বা উপরের মতো করে টেস্ট ডাটা ডাটাবেজে ঢুকানো বড়ই কষ্টকর তাই লারাভেল টেস্ট ডাটার কারখানা বানিয়ে দিয়েছে, আসুন তার সাথে পরিচিত হই।

মডেল ফ্যাক্টরি(model factory) এর ব্যবহারঃ

project.one/database/factories/ModelFactory.php ফাইলটিতে নিচের মতো করে একটি ফ্যাক্টরি ডিফাইন করি।
1
$factory->define(App\Post::class, function (Faker\Generator $faker) {
2
return [
3
'title' => $faker->sentence(mt_rand(3, 10)),
4
'content' => join("\n\n", $faker->paragraphs(mt_rand(3, 6))),
5
'created_at' => $faker->dateTimeBetween('-1 month', '+3 days'),
6
];
7
});
Copied!
project.one/database/seeds/DatabaseSeeder.php ফাইলটি আগের মতোই থাকুক।
1
<?php
2
3
use Illuminate\Database\Seeder;
4
5
class DatabaseSeeder extends Seeder
6
{
7
/**
8
* Run the database seeds.
9
*
10
* @return void
11
*/
12
public function run()
13
{
14
$this->call(PostsTableSeeder::class);
15
}
16
}
Copied!
এবার project.one/database/seeds/PostsTableSeeder.php ফাইলটাকে পরিবর্তন করি
1
<?php
2
3
use Illuminate\Database\Seeder;
4
5
class PostsTableSeeder extends Seeder
6
{
7
/**
8
* Run the database seeds.
9
*
10
* @return void
11
*/
12
public function run()
13
{
14
App\Post::truncate(); // delete all previous rows
15
16
factory(App\Post::class, 10)->create(); // Create 10 rows
17
}
18
19
}
Copied!
এবার নিচের কমান্ডটি দিন ও ডাটাবেজে টেবিলটির পরিবর্তন লক্ষ্য করুন।
1
php artisan db:seed
Copied!
আপনি এভাবে মডেল ফ্যাক্টরি ও ফেকার এর সাহায্যে সহজেই ইউজার, পাসওয়ার্ড, ঠিকানা, মানুষের নাম এবং আরও অনেক কিছুই তৈরি করতে পারেন।

ইনডেক্স পেইজ তৈরি

আমরা ব্লেড টেমপ্লেটিং অধ্যায়ে দেখেছি কিভাবে ভিউ ও টেমপ্লেটিং করতে হয়। তাই সময় নষ্ট না করে নিচের মতো করে project.one/resources/views এর মধ্যে master.blade.php ফাইলটি তৈরি করি।
1
<!doctype html>
2
<html lang="en">
3
<head>
4
<meta charset="UTF-8">
5
<title>@yield('title')</title>
6
<link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.6/css/bootstrap.min.css">
7
{!! Html::style('css/style.css') !!}
8
</head>
9
<body>
10
@include('partials.navbar')
11
<div class="container">
12
13
<div class="row">
14
@yield('content')
15
</div>
16
</div>
17
18
<script src="{!! asset('js/jquery-1.12.2.min.js') !!}"></script>
19
<script src="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.6/js/bootstrap.min.js"></script>
20
</body>
21
</html>
Copied!
৬ নম্বর লাইনে CDN থেকে টুইটার বুটস্ত্রাপ লিঙ্ক করা হয়েছে। আসুন নিজেদের স্টাইল এর জন্য project.one/public/css পাথে style.css নামে একটি ফাইল তৈরি করি, যেটা ৭ নম্বর লাইনে লিঙ্ক করা হয়েছে। কিছু CSS যোগ করি এই ফাইলেঃ
1
.post-info span {
2
background-color: #888;
3
color: #fff;
4
padding: 4px;
5
}
Copied!
এবার project.one/public ফোল্ডারে js নামে আরেকটি ফোল্ডার করে jquery-1.12.2.min.js ডাউনলোড করে রাখি, যেটা ১৬ নং লাইনে লিঙ্ক করা হয়েছে। তার পরের লাইন টি আশা করি বুজতে পারছেন।
১০ নং লাইনে দেখুন navbar.blade.php নামে একটি ফাইল ইনক্লুড করা হয়েছে আসুন project.one/resources/views এর মধ্যে partials নামে একটি ফোল্ডার বানিয়ে ফাইলটি নিচের মতো বানিয়ে ফেলি।
1
<nav class="navbar navbar-default">
2
<div class="container-fluid">
3
<!-- Brand and toggle get grouped for better mobile display -->
4
<div class="navbar-header">
5
<button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#bs-example-navbar-collapse-1">
6
<span class="sr-only">Toggle navigation</span>
7
<span class="icon-bar"></span>
8
<span class="icon-bar"></span>
9
<span class="icon-bar"></span>
10
</button>
11
<a class="navbar-brand" href="/">laravel.howtocode.com.bd @yield('action')</a>
12
</div>
13
14
<!-- Navbar Right -->
15
<div class="collapse navbar-collapse" id="bs-example-navbar-collapse-1">
16
<ul class="nav navbar-nav navbar-right">
17
<li class="active"><a href="/">Home</a></li>
18
<li><a href="/about">About</a></li>
19
<li class="dropdown">
20
<a href="#" class="dropdown-toggle" data-toggle="dropdown" role="button" aria-expanded="false">Admin Area<span class="caret"></span></a>
21
<ul class="dropdown-menu" role="menu">
22
<li><a href="/admin/posts/new">New Post</a></li>
23
<li><a href="/admin/posts">Edit</a> </li>
24
</ul>
25
</li>
26
</ul>
27
</div>
28
</div>
29
</nav>
Copied!
এটা টুইটার বুটস্ত্রাপের সাধারন navbar, যেখানে লিঙ্ক গুলা তৈরি করেছি, পরে পেইজ গুলাও বানাবো।
এবার আসুন routes.php ফাইলে আমাদের হোমে রুট বানাই। নিচের মতো করে(এটা লারাভেল 5.2.31 ভার্সন)
1
<?php
2
3
/*
4
|--------------------------------------------------------------------------
5
| Application Routes
6
|--------------------------------------------------------------------------
7
|
8
| Here is where you can register all of the routes for an application.
9
| It's a breeze. Simply tell Laravel the URIs it should respond to
10
| and give it the controller to call when that URI is requested.
11
|
12
*/
13
14
Route::get('/', '[email protected]');
Copied!
এবার নিচের কমান্ড দিয়ে PostsController টি বানিয়ে ফেলি।
1
php artisan make:controller PostsController
Copied!
ও নিচের মতো পরিবর্তন করি।
1
<?php
2
3
namespace App\Http\Controllers;
4
5
use Illuminate\Http\Request;
6
7
use App\Http\Requests;
8
use App\Post;
9
10
class PostsController extends Controller
11
{
12
public function index(){
13
$posts = Post::all();
14
return view('posts.index', compact('posts'));
15
}
16
}
Copied!
এবার ভিউ তৈরি project.one/resources/views এর ভিতর posts নামে ফোল্ডার করে index.blade.php নামে নিচের মতো একটি ফাইল বানাই।
1
@extends('master')
2
@section('title', 'Posts')
3
@section('content')
4
<div class="col-md-12">
5
@if (count($posts))
6
@foreach($posts as $post)
7
<article>
8
<a href="#"><h1>{!! $post->title !!}</h1></a>
9
<div>
10
<p class="post-info"><span>Created at: {{$post->created_at->format('d-M-Y')}}</span></p>
11
</div>
12
<div class="post-excerpt">
13
{!! str_limit($post->content, 150) !!}
14
</div>
15
</article>
16
<hr>
17
@endforeach
18
@else
19
<h1>Hi, you've landed in our First Prject!</h1>
20
<h2>Sorry, We don't have any post right now.</h2>
21
@endif
22
</div>
23
@endsection
Copied!
এবার আমরা ব্রাউজারে আমাদের প্রোজেক্ট টি চেক করি, আশা করি নিচের মত দেখতে হবে, না হোলে কমেন্টে জানান দয়া করে।
index-page

কি ভাবে সোর্স কোড পাওয়া যাবে?

গিটহাব এর project.one রিপজিটোরিটি ফোর্ক করুন এবং আপনার সিস্টেমে ক্লোন করুন।
এই অধ্যায়ের সোর্স কোড পেতে
1
git checkout f384e15
Copied!
সর্বশেষ কমিট পর্যন্ত পেতে আবার নিচের কমান্ডটি দিন
1
git checkout master
Copied!