mcesar / laravel-survey
Survey package for Laravel 5.5 and up
Installs: 1 696
Dependents: 0
Suggesters: 0
Security: 0
Stars: 16
Watchers: 1
Forks: 9
Open Issues: 2
pkg:composer/mcesar/laravel-survey
Requires
- php: >=7.0
- illuminate/database: ~5.4.0|~5.5.0|~5.6.0|~5.7.0|~5.8.0
Requires (Dev)
- phpunit/phpunit: ^5.7|6.2|^7.0
This package is auto-updated.
Last update: 2021-03-14 15:06:33 UTC
README
This package allows you to add a survey to your Laravel application
Once installed you can do stuff like this:
// Get all question that a user has Question::answered(false)->get()
Installation
Laravel
This package can be used in Laravel 5.4 or higher. If you are using an older version of Laravel You can install the package via composer:
composer require mcesar/laravel-survey
In Laravel 5.5 the service provider will automatically get registered. In older versions of the framework just add the service provider in config/app.php file:
'providers' => [ // ... MCesar\Survey\SurveyServiceProvider::class, ];
You can publish the migration with:
php artisan vendor:publish --provider="MCesar\Survey\SurveyServiceProvider" --tag="migrations"
After the migration has been published you can create the category-, question- and answer-tables by running the migrations:
php artisan migrate
You can publish the config file with:
php artisan vendor:publish --provider="MCesar\Survey\SurveyServiceProvider" --tag="config"
When published, the config/survey.php config file contains:
return [ 'models' => [ /* * We need to know which Eloquent model should be used to retrieve your categories. * Of course, it is often just the "Category" model but you may use whatever you like. * * The model you want to use as a Category model needs to implement the * `MCesar\Survey\Contracts\Category` contract. */ 'category' => MCesar\Survey\Models\Category::class, /* * We need to know which Eloquent model should be used to retrieve your questions. * Of course, it is often just the "Question" model but you may use whatever you like. * * The model you want to use as a Question model needs to implement the * `MCesar\Survey\Question\Category` contract. */ 'question' => MCesar\Survey\Models\Question::class, /* * We need to know which Eloquent model should be used to retrieve your answers. * Of course, it is often just the "Answer" model but you may use whatever you like. * * The model you want to use as a Answer model needs to implement the * `MCesar\Survey\Question\Answer` contract. */ 'answer' => MCesar\Survey\Models\Answer::class, /* * We need to know which Eloquent model should be used to assign the answers to. * Of course, it is often just the "User" model but you may use whatever you like. */ 'user' => App\User::class, ], ];
Lumen
Lumen support is not tested!
You can install the package via Composer:
composer require mcesar/laravel-survey
Copy the required files:
cp vendor/mcesar/laravel-survey/config/permission.php config/survey.php cp vendor/mcesar/laravel-survey/database/migrations/create_survey_tables.php.stub database/migrations/2018_01_01_000000_create_survey_tables.php
Now, run your migrations:
php artisan migrate
Then, register the configuration and the service provider:
$app->configure('survey'); $app->register(MCesar\Survey\SurveyServiceProvider::class);
Usage
The models supplied by this package can be used the same as any other model you make.
Extending
If you need to EXTEND the existing models note that:
- Your Categorymodel needs to extend theMCesar\Survey\Models\Categorymodel
- Your Questionmodel needs to extend theMCesar\Survey\Models\Questionmodel
- Your Answermodel needs to extend theMCesar\Survey\Models\Answermodel
If you need to REPLACE the existing models you need to keep the following things in mind:
- Your Categorymodel needs to implement theMCesar\Survey\Contracts\Categorycontract
- Your Questionmodel needs to implement theMCesar\Survey\Contracts\Questioncontract
- Your Answermodel needs to implement theMCesar\Survey\Contracts\Answercontract
In BOTH cases, whether extending or replacing, you will need to specify your new models in the configuration. To do this you must update the models.categorie, models.question and models.answer values in the configuration file after publishing the configuration with this command:
php artisan vendor:publish --provider="MCesar\Survey\SurveyServiceProvider" --tag="config"
Testing
composer test
Credits
License
The MIT License (MIT). Please see License File for more information.