
Shift automatically applies the Laravel coding style - which uses the PSR-12 coding style as a base with some minor additions. You may customize the code style applied by configuring [Pint](https://laravel.com/docs/pint), [PHP CS Fixer](https://github.com/FriendsOfPHP/PHP-CS-Fixer), or [PHP CodeSniffer](https://github.com/squizlabs/PHP_CodeSniffer) for your project root. For more information on customizing the code style applied by Shift, [watch this short video](https://laravelshift.com/videos/shift-code-style).
105 lines
2.8 KiB
PHP
105 lines
2.8 KiB
PHP
<?php
|
|
|
|
namespace App\Model\helpdesk\Ticket;
|
|
|
|
use App\BaseModel;
|
|
|
|
class Tickets extends BaseModel
|
|
{
|
|
protected $table = 'tickets';
|
|
|
|
protected $fillable = ['id', 'ticket_number', 'num_sequence', 'user_id', 'priority_id', 'sla', 'help_topic_id', 'max_open_ticket', 'captcha', 'status', 'lock_by', 'lock_at', 'source', 'isoverdue', 'reopened', 'isanswered', 'is_deleted', 'closed', 'is_transfer', 'transfer_at', 'reopened_at', 'duedate', 'closed_at', 'last_message_at', 'last_response_at', 'created_at', 'updated_at', 'assigned_to'];
|
|
|
|
// public function attach(){
|
|
// return $this->hasMany('App\Model\helpdesk\Ticket\Ticket_attachments',);
|
|
//
|
|
// }
|
|
public function thread()
|
|
{
|
|
return $this->hasMany(\App\Model\helpdesk\Ticket\Ticket_Thread::class, 'ticket_id');
|
|
}
|
|
|
|
public function collaborator()
|
|
{
|
|
return $this->hasMany(\App\Model\helpdesk\Ticket\Ticket_Collaborator::class, 'ticket_id');
|
|
}
|
|
|
|
public function helptopic()
|
|
{
|
|
$related = \App\Model\helpdesk\Manage\Help_topic::class;
|
|
$foreignKey = 'help_topic_id';
|
|
|
|
return $this->belongsTo($related, $foreignKey);
|
|
}
|
|
|
|
public function formdata()
|
|
{
|
|
return $this->hasMany(\App\Model\helpdesk\Ticket\Ticket_Form_Data::class, 'ticket_id');
|
|
}
|
|
|
|
public function extraFields()
|
|
{
|
|
$id = $this->attributes['id'];
|
|
$ticket_form_datas = \App\Model\helpdesk\Ticket\Ticket_Form_Data::where('ticket_id', '=', $id)->get();
|
|
|
|
return $ticket_form_datas;
|
|
}
|
|
|
|
public function source()
|
|
{
|
|
$source_id = $this->attributes['source'];
|
|
$sources = new Ticket_source();
|
|
$source = $sources->find($source_id);
|
|
|
|
return $source;
|
|
}
|
|
|
|
public function sourceCss()
|
|
{
|
|
$css = 'fa fa-comment';
|
|
$source = $this->source();
|
|
if ($source) {
|
|
$css = $source->css_class;
|
|
}
|
|
|
|
return $css;
|
|
}
|
|
|
|
public function delete()
|
|
{
|
|
$this->thread()->delete();
|
|
$this->collaborator()->delete();
|
|
$this->formdata()->delete();
|
|
parent::delete();
|
|
}
|
|
|
|
public function setAssignedToAttribute($value)
|
|
{
|
|
if (! $value) {
|
|
$this->attributes['assigned_to'] = null;
|
|
} else {
|
|
$this->attributes['assigned_to'] = $value;
|
|
}
|
|
}
|
|
|
|
public function getAssignedTo()
|
|
{
|
|
$agentid = $this->attributes['assigned_to'];
|
|
if ($agentid) {
|
|
$users = new \App\User();
|
|
$user = $users->where('id', $agentid)->first();
|
|
if ($user) {
|
|
return $user;
|
|
}
|
|
}
|
|
}
|
|
|
|
public function user()
|
|
{
|
|
$related = \App\User::class;
|
|
$foreignKey = 'user_id';
|
|
|
|
return $this->belongsTo($related, $foreignKey);
|
|
}
|
|
}
|