maddhatter / laravel-view-generator
Tiny package to create a make:view command for Laravel 5+
Installs: 8 089
Dependents: 3
Suggesters: 0
Security: 0
Stars: 14
Watchers: 2
Forks: 8
Open Issues: 0
Requires
- php: >=5.4.0
- illuminate/console: >5.0
- illuminate/filesystem: >5.0
- illuminate/support: >5.0
- illuminate/view: >5.0
README
This is a tiny package to add a php artisan make:view
command to quickly create blade views.
Installing
Require the package with composer using the following command:
composer require maddhatter/laravel-view-generator --dev
Or add the following to your composer.json's require section and composer update
"require-dev": { "maddhatter/laravel-view-generator": "dev-master" }
Or if you always want it included regardless of environment, just add it to the providers
array in config/app.php
Usage
Create a New View
php artisan make:view path.to.your.view
Use the same dotted notation to your view that you would pass to the view()
command. The directory will be created if it doesn't already exist.
Note: If there are multiple paths defined in your config/view.php
's paths
array, this package will use the first path.
Extend Another View
php artisan make:view path.to.your.view -e path.to.parent.view
You can optionally extend another view by adding the -e
parameter and providing the name of the view you want to extend. It will parse the parent view for @yield()
directives and create the corresponding @section
/ @endsection
tags. To exclude a section from automatic creation, begin the name with an underscore, e.g.: _meta
Example
Imagine you have the following layout defined:
resources/views/layouts/master.blade.php
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
@yield('_meta')
</head>
<body>
<div id="content">
@yield('content')
</div>
<script src="{{ elixir('js/app.js') }}"></script>
@yield('scripts')
</body>
</html>
And you run:
php artisan make:view pages.home -e layouts.master
The following will be created:
resources/views/pages/home.blade.php
@extends('layouts.master')
@section('content')
@endsection
@section('scripts')
@endsection