mcesar/laravel-survey

This package is abandoned and no longer maintained. No replacement package was suggested.

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

1.1.2 2019-06-13 08:43 UTC

This package is auto-updated.

Last update: 2021-03-14 15:06:33 UTC


README

Latest Version on Packagist Build Status Total Downloads

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 Category model needs to extend the MCesar\Survey\Models\Category model
  • Your Question model needs to extend the MCesar\Survey\Models\Question model
  • Your Answer model needs to extend the MCesar\Survey\Models\Answer model

If you need to REPLACE the existing models you need to keep the following things in mind:

  • Your Category model needs to implement the MCesar\Survey\Contracts\Category contract
  • Your Question model needs to implement the MCesar\Survey\Contracts\Question contract
  • Your Answer model needs to implement the MCesar\Survey\Contracts\Answer contract

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.