Ticketing system for Laravel (from 5 to 8). Allows to create new tickets via form only. Includes file attachments, ticket tags, filtering, scheduling and e-mail notifications.

Installs: 1 470

Dependents: 0

Suggesters: 0

Security: 0

Stars: 44

Watchers: 7

Forks: 20

Open Issues: 15


v0.20.0 2020-09-10 15:16 UTC


This is a ticketing system for Laravel PHP framework (from version 5 to 8): It is based on Kordy/Ticketit. We have kept almost all ticketit features and added many additional functionalities, like file attachments, ticket tags, scheduling, filtering and an advanced search form. This package uses an own route, "/PanicHD" which can be customized, so It may be installed in your existent Laravel project.

Table of contents



Panic Help Desk is a ticketing system that may be integrated on any Laravel app. A "ticket" can be any specific issue, thread, bug or whatever you need. It includes some general fields that may be useful to classify it and has some interaction possibilities between the user that creates it and the ticket managers.

General view

This ticketing system is actually mean to be used in a corporate support environment, by these reasons:

  • Only registered users or ticket managers are able to add tickets. For any manager, a ticket can only be assigned to an owner which is registered.
  • We have included all required asset files in the package structure because we want it to be usable in our LAN even without working internet connection (think about IT corporate support)


This package comes with Catalan, English and Brazillian Portuguese language files. For any of them you don't need to do anything: PanicHD will get your Laravel configuration.

You may also you may create your own language files. There are some outdated language files that come from Ticketit and can be a good starting point. We encourage you to make your own language files and create a pull request in PanicHD to share with other speakers.

A ticket step by step example

  1. A user registers a new ticket for a specific issue
  2. The ticket gets automatically assigned to an agent (a ticket manager) that receives an e-mail notification.
  3. The agent contacts the user to give support. After the support tasks, leaves the ticket opened in "User pending" status because a confirmation that the issue is solved is needed
  4. The user confirms within the ticket that it is solved. He can do it by directly completing the ticket or making a new comment
  5. In any case, the agent will receive an e-mail notification with the user update
  6. If the ticket was left active, the agent completes it
  7. Both the agent and the user will see the ticket in the Complete list for future reference.


This is a synopsis of the main PanicHD features. For detailed descriptions, example screenshots and general reference, please read our Current features page in the wiki

  • Three user roles: Member, Agent and Admin

  • PanicHD ticket fields

    • Basic set that any member can fill up when registering a new ticket:

      • Subject
      • Description: It may contain text, html or even directly pasted screenshots
      • Category
      • Attached files
    • classification fields, like: Priority, status, tags

    • Time related fields:

      • Start date: When the ticket activity may start. By default it is the creation date
      • Limit date: When the ticket expires. It is used for schedule ticket filtering
    • Any of the ticket managers may view / edit all the ticket fields

    • A manager may add a ticket assigning it to any owner (any registered user)

    • A manager may add a user hidden ticket (or switch a visible ticket to hidden):

      • It may be also assigned to any owner
      • The owner (if it's not also an agent on the ticket category) won't be able to view the ticket
      • This kind of owner will not receive any e-mail notification
  • User / Managers communication

    • By comments added from both of them within a ticket card
    • By e-mail notifications: All of them will receive notifications relative to relevant changes in the ticket made by any of them
    • Manager may add user hidden messages called "internal notes". If the ticket is assigned to another agent, he will receive a related e-mail notification also
  • Ticket filters

    • All ticket lists include a filter panel that lets you use a specific criteria in some relevant fields (Calendar, category, agent)
    • These filters are kept in user session until you change or deletes them
    • Only members with permissions to manage at least one category will be able to use the filter panel
    • You may activate a field by URL, as we explain in the wiki
  • Ticket search

    • There is a dedicated search form where you may specify it by any of the ticket related fields
    • We have added some advanced search options, like search text in any field, text in comments, text in attachment fields, search by specific date criteria...
    • After executing the search, you will have a button with a permanent link to it, which has all specified parameters and values in URL
    • It is enabled for all members with permissions
  • For Admins

    • Any classification element may be edited
    • They can easily manage categories and assigned Agents
  • For developers

    • There is a configuration settings menu that directly comes from Ticketit. It is so useful and flexible to configure the package at your own desire even without altering the package files

    • We have added some useful Artisan commands to help you make your own local tests. Click the link or type in the Laravel console the following command:

      php artisan panichd



  • Laravel 5.1 or higher including:

    • Laravel auth with at least one user registered
    • Model App\User.php that uses users table. It is added with Laravel auth by default and PanicHD requires it to be there. It seems that some admin panels change it to App\Models\User.php or maybe other routes.
    • Valid email configuration (Needed for PanicHD notification emails)
  • Composer (the PHP dependency manager)

If Kordy/Ticketit is installed

If it's installed in the same Laravel project you want to install Panic Help Desk, Panic Help Desk will replace it, reusing it's database tables and keeping registered tickets. Before installing PanicHD, you will have to uninstall Kordy/Ticketit following these steps:

  1. Open composer.json file at laravel root folder. Remove the line that reffers to kordy/ticketit in the "require" section
  2. Open config/app.php. Remove the line that contains "TicketitServiceProvider"
  3. Via command line in laravel root, execute: composer update kordy/ticketit
  4. Delete all possible remaining refferences and files that you may have in your Laravel project (Published files? Refferences in Laravel files?)

Installation steps

  1. Open a command line in the Laravel folder and type: composer require panichd/panichd

  2. If you are using Laravel 5.4 or lower, you will have to add the service provider. In this case, Open config/app.php. In the "Providers" section, add:


Complete installation

At this point, if you think you typed enough commands, the web installer comes to rescue you ;) But if you're a tough and experienced Laravel coder, please forget this and jump to Complete installation with command line section.

Option 1: Web installer

To access the web installer you just have to:

  1. Log in the Laravel app via web browser
  2. access URL http://your-laravel-app-URL/panichd
  3. Read and follow the installation steps

Option 2: Command line (for advanced users)

Create the attachments folders:

  1. Access "storage" folder inside Laravel root and create the subfolder: panichd_attachments
  2. Access storage\app\public and create the subfolder: panichd_thumbnails

Execute these commands:

  1. Publish and install migrations

    1.1 Publish migrations: php artisan vendor:publish --tag=panichd-db

    1.2 Execute migrations: php artisan migrate

  2. Fill up "panichd_settings" table with the required defaults seeder:

    php artisan db:seed --class=PanicHD\\PanicHD\\Seeds\\SettingsTableSeeder

  3. If Kordy/Ticketit was installed, Patch settings table with:

php artisan db:seed --class=PanicHD\\PanicHD\\Seeds\\SettingsPatch

  1. Enable "panichd_thumbnails" folder access:

    php artisan storage:link

  2. Publish included assets:

    php artisan vendor:publish --tag=panichd-public

  3. If you didn't have Kordy/Ticketit, you will have to enable your user account (or any other) as an admin in Panic Help Desk. In the "users" table, just find your account and set "panichd_admin" value to 1.

  4. Test functionality with generated demo content If you want to test the package first, you can install some demo contents from command line in your Laravel app:

  5. Configure the package for real environment usage

    • If you want to add the included default priorities, statuses and category: php artisan db:seed --class=PanicHD\\PanicHD\\Seeds\\Basic
    • If you want to create only your custom parameters, you can skip to the next installation step
  6. Access http://your-laravel-app-URL/panichd in your browser

Configurations and Laravel integration


Please read our contributing reference.

Built with

If some day this package is as useful to someone as other ones like these have been to us, our debt will for sure still be enormous, but also we'd be very happy!


Thanks to Kordy and his collaborators for building up Kordy/Ticketit and sharing it on GitHub. Without it, Panic Help Desk simply won't exist.

A big Thank You also to all the guys at online communities like StackOverflow that do their best everyday to help others like me on their daily coding headaches.