Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/marcnewton/laravel-whoops-vue-component


https://github.com/marcnewton/laravel-whoops-vue-component

ajax ajax-request custom-callback custom-handler debugger dump dumper laravel vue vuejs2 whoops whoops-error-handler

Last synced: 23 days ago
JSON representation

Awesome Lists containing this project

README

        

## About Vue Whoops Debug Component

Vue 2 ajax debug component for Laravel 5.5+ Vue based projects, pretty print Whoops style handler for ajax error responses in Laravel, auto handles error exceptions and Die Dump responses from ajax requests in a reactive display.

Features live debug mode for quick iteration through errors and dumps.

Works with [Laravel Debug Bar](https://github.com/barryvdh/laravel-debugbar), Debug Bar will continue to display over the top of this whoops handler view.

On demand or automatic retries of your last ajax request with the previous posted data.

Optional on success callback to resume any normal application function when request is free of errors or dump responses.

[![Video Demo](https://img.youtube.com/vi/n0U5a4S3crQ/0.jpg)](https://youtu.be/n0U5a4S3crQ "Video Demo")

## Installation

npm install laravel-vue-whoops

### Adding Whoops VUE Component

Add Whoops Vue component to your applications js file after Vue is declared.

```javascript
require('laravel-vue-whoops');
```

Example app.js:

```javascript
window.Vue = require('vue');

require('laravel-vue-whoops');

new Vue({
el: '#app',
components: {
'myComponent': require('./components/myComponent.vue'),
},
data: function() {
return {}
}
});

```

## How to use

The **Whoops.handle** method takes two parameters.

#### Error
The error handle object parameter.

#### Callback
An optional custom error callback handler fallback.
If the error response is not an exception or dump then your callback should be your custom client facing UX handler, typically this would be your custom handler for laravel validation UX responses or if APP DEBUG is disabled the custom callback would would called.

```javascript
axios.patch(url,data).then(response => {

// your public success handler here

}).catch(error => {

Whoops.handle(error, function() {

// your public fail handler here
alert('Hello Guest, Sorry but the server encountered an Internal Server Error during the processing of your request!');

});

});
```

## Issue Tracking

https://github.com/marcnewton/laravel-whoops-vue-component/issues

## FAQ

###### How do I open the debugger overlay?

The overlay will automatically present it's self if an Exception or Dump response is detected else your custom callback will execute if one is specified.

*Troubleshooting*
If you believe the condition has been met for the debugger to display you should check the following:

+ z-index on div#whoops-app is not competing against the z-index of your application or 3rd party tools (except Laravel Debug Bar).
+ Check the console for any errors such as webpack compilation errors, Seek support if needed (see Support lower down)

###### What is the use case of the custom callback?

When Laravel's environment is set to production where debugging should be disabled, The VUE Whoops handler should no longer detect any exception errors, therefore should only call your custom callback function.
This callback function should be a response handler that you would want your end users to see, like a custom error popup box.

## Support

Twitter: [@MarcANewton](https://twitter.com/MarcANewton) [#laravueoops](https://twitter.com/hashtag/laravueoops)

Stack Overflow: [@marc-newton](https://stackoverflow.com/users/1356141/marc-newton)