1 | <?php |
||
12 | trait HasData |
||
13 | { |
||
14 | /** |
||
15 | * @var string|array |
||
16 | */ |
||
17 | protected $ajax = ''; |
||
18 | |||
19 | /** |
||
20 | * Setup ajax parameter. |
||
21 | * |
||
22 | * @param string|array $attributes |
||
23 | * @return $this |
||
24 | */ |
||
25 | public function ajax($attributes = '') |
||
31 | |||
32 | /** |
||
33 | * Setup "ajax" parameter with POST method. |
||
34 | * |
||
35 | * @param string|array $attributes |
||
36 | * @return $this |
||
37 | */ |
||
38 | public function postAjax($attributes = '') |
||
50 | |||
51 | /** |
||
52 | * Setup ajax parameter for datatables pipeline plugin. |
||
53 | * |
||
54 | * @param string $url |
||
55 | * @param string $pages |
||
56 | * @return $this |
||
57 | */ |
||
58 | public function pipeline($url, $pages) |
||
64 | |||
65 | /** |
||
66 | * Minify ajax url generated when using get request |
||
67 | * by deleting unnecessary url params. |
||
68 | * |
||
69 | * @param string $url |
||
70 | * @param string $script |
||
71 | * @param array $data |
||
72 | * @param array $ajaxParameters |
||
73 | * @return $this |
||
74 | */ |
||
75 | public function minifiedAjax($url = '', $script = null, $data = [], $ajaxParameters = []) |
||
76 | { |
||
77 | $this->ajax = []; |
||
78 | $appendData = $this->makeDataScript($data); |
||
|
|||
79 | |||
80 | $this->ajax['url'] = empty($url) ? url()->full() : $url; |
||
81 | $this->ajax['type'] = 'GET'; |
||
82 | if (isset($this->attributes['serverSide']) ? $this->attributes['serverSide'] : true) { |
||
83 | $this->ajax['data'] = 'function(data) { |
||
84 | for (var i = 0, len = data.columns.length; i < len; i++) { |
||
85 | if (!data.columns[i].search.value) delete data.columns[i].search; |
||
86 | if (data.columns[i].searchable === true) delete data.columns[i].searchable; |
||
87 | if (data.columns[i].orderable === true) delete data.columns[i].orderable; |
||
88 | if (data.columns[i].data === data.columns[i].name) delete data.columns[i].name; |
||
89 | } |
||
90 | delete data.search.regex;'; |
||
91 | } else { |
||
92 | $this->ajax['data'] = 'function(data){'; |
||
93 | } |
||
94 | |||
95 | if ($appendData) { |
||
96 | $this->ajax['data'] .= $appendData; |
||
97 | } |
||
98 | |||
99 | if ($script) { |
||
100 | $this->ajax['data'] .= $script; |
||
101 | } |
||
102 | |||
103 | $this->ajax['data'] .= '}'; |
||
104 | |||
105 | $this->ajax = array_merge($this->ajax, $ajaxParameters); |
||
106 | |||
107 | return $this; |
||
108 | } |
||
109 | |||
110 | /** |
||
111 | * Get ajax url. |
||
112 | * |
||
113 | * @return array|mixed|string |
||
114 | */ |
||
115 | public function getAjaxUrl() |
||
123 | |||
124 | /** |
||
125 | * Set ajax url with data added from form. |
||
126 | * |
||
127 | * @param string $url |
||
128 | * @param string $formSelector |
||
129 | * @return $this |
||
130 | */ |
||
131 | public function ajaxWithForm($url, $formSelector) |
||
142 | } |
||
143 |
This check looks for methods that are used by a trait but not required by it.
To illustrate, let’s look at the following code example
The trait
Idable
provides a methodequalsId
that in turn relies on the methodgetId()
. If this method does not exist on a class mixing in this trait, the method will fail.Adding the
getId()
as an abstract method to the trait will make sure it is available.