GithubHelp home page GithubHelp logo

moman13 / cray Goto Github PK

View Code? Open in Web Editor NEW

This project forked from junaidqadirb/cray

0.0 0.0 0.0 213 KB

A Laravel package to help you generate nearly complete CRUD pages like crazy!

License: MIT License

PHP 97.96% Shell 2.04%

cray's Introduction

Cray For Laravel

Latest Stable Version Latest Unstable Version Daily Downloads Total Downloads Quality Score License PHP Version Require

What is Cray?

Cray is a disposable Laravel package to help you generate nearly complete CRUD pages like crazy. Literally. It's also a bit opinionated.

If you build straight-forward CRUD pages more often manually writing all the same logic becomes a chore. Cray will not only save you a save but also give you a better way to organize your code.

So what do you mean by disposable?

You use Cray and forget about it. It isn't coupled with your installation of Laravel and it is preferred to be installed as a dev dependency. Cray generates the files and it forgets about them and they are all yours to modify do whatever you want.

What does it actually do?

Suppose you are building a blog, and you want to create a Post model then you have to do a ton of other tedious and to be honest, boring things like creating migrations, model factories, the controller, form validation and adding all the logic and what not.

So what Cray does is when you tell it the model name, it will do all those boring things I listed earlier. When it's done you have the following:

  • Post.php
  • PostController.php with all the necessary logic to list, edit, create and delete posts.
  • PostStoreRequest.php and PostUpdateRequest.php
  • Timestamped create_posts_table.php migration file
  • PostFactory.php
  • posts views directory with index.blade.php, create.blade.php, edit.blade.php, show.blade.php, modals/delete.balde.phpas well as a blank _form.blade.php for you to add the fields.

Then all you have to do is:

  • Add the columns to the migration file
  • Add the necessary fields (as defined in the last step) to the _form.blade.php
  • Add validation rules for the fields you added to the form.

Installation

composer require jq/cray --dev

Or specify specific version, for example to try a beta

composer require "jq/cray:3.2.0-beta3" --dev

Then publish the stubs

php artisan vendor:publish --tag=cray

It will generate stubs to resources/vendor/cray/stubs directory.

Usage

php artisan cray Post

Once done, it will show you the details of the files generated.

Factory created successfully in /database/factories/PostFactory.php
Created Migration: 2020_03_14_151409_create_posts_table
Model created successfully in /app/Post.php
Controller created successfully in /app/Http/Controllers/PostController.php
View created successfully in /resources/views/posts/index.blade.php
View created successfully in /resources/views/posts/create.blade.php
View created successfully in /resources/views/posts/_form.blade.php
View created successfully in /resources/views/posts/edit.blade.php
View created successfully in /resources/views/posts/show.blade.php
View created successfully in /resources/views/posts/modals/delete.blade.php
Request created successfully in /app/Http/Requests/PostStoreRequest.php
Request created successfully in /app/Http/Requests/PostUpdateRequest.php

Now add the necessary fields and run

php artisan migrate

And that saved you an hour worth of repetitive and boring work which you can spend on more important development challenges.

Optional Packages

Changelog

Contributing

Please see CONTRIBUTING for details.

Security

If you discover any security related issues, please email [email protected] instead of using the issue tracker.

Credits

License

The MIT License (MIT). Please see License File for more information.

Laravel Package Boilerplate

This package was generated using the Laravel Package Boilerplate.

cray's People

Contributors

junaidqadirb avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.