| Conditions | 8 | 
| Paths | 3 | 
| Total Lines | 57 | 
| Code Lines | 41 | 
| Lines | 0 | 
| Ratio | 0 % | 
| Changes | 1 | ||
| Bugs | 0 | Features | 0 | 
Small methods make your code easier to understand, in particular if combined with a good name. Besides, if your method is small, finding a good name is usually much easier.
For example, if you find yourself adding comments to a method's body, this is usually a good sign to extract the commented part to a new method, and use the comment as a starting point when coming up with a good name for this new method.
Commonly applied refactorings include:
If many parameters/temporary variables are present:
| 1 | <?php | ||
| 12 | private function getHtmlTopPlayer($data, string $locale = 'en'): string | ||
| 13 |     { | ||
| 14 | $html = ''; | ||
| 15 | |||
| 16 |         if (count($data['list']) > 0) { | ||
| 17 | $html .= '<div class="article-top article-top__players">'; | ||
| 18 |             for ($i = 0; $i <= 2; $i++) { | ||
| 19 |                 if (array_key_exists($i, $data['list'])) { | ||
| 20 | $html .= sprintf( | ||
| 21 | '<a href="%s"><img src="https://backoffice.video-games-records.com/users/%d/avatar" alt="%s" class="article-top__player" /></a>', | ||
| 22 | '/' . $locale . '/' . $data['list'][$i]['player']->getUrl(), | ||
| 23 | $data['list'][$i]['player']->getId(), | ||
| 24 | $data['list'][$i]['player']->getPseudo() | ||
| 25 | ); | ||
| 26 | } | ||
| 27 |                 if ($i == 0) { | ||
| 28 | $html .= '<br />'; | ||
| 29 | } | ||
| 30 | } | ||
| 31 | |||
| 32 | $html .= '<table class="article-top__table">'; | ||
| 33 | $html .= '<thead>'; | ||
| 34 | $html .= '<tr>'; | ||
| 35 | $html .= '<th scope="col"><abbr title="Rank">#</abbr></th>'; | ||
| 36 | $html .= '<th scope="col">Player</th>'; | ||
| 37 | $html .= '<th scope="col">Posts submitted</th>'; | ||
| 38 | $html .= '<th scope="col">Position change</th>'; | ||
| 39 | $html .= '</tr>'; | ||
| 40 | $html .= '</tr>'; | ||
| 41 | $html .= '<tbody>'; | ||
| 42 | |||
| 43 |             foreach ($data['list'] as $row) { | ||
| 44 | $html .= sprintf( | ||
| 45 | $this->getHtmLine(), | ||
|  | |||
| 46 | $row['rank'], | ||
| 47 | '/' . $locale . '/' . $row['player']->getUrl(), | ||
| 48 | (($row['player'] != null) ? $row['player']->getPseudo() : '???'), | ||
| 49 | $row['nb'], | ||
| 50 | $this->diff($row, count($data['list'])) | ||
| 51 | ); | ||
| 52 | } | ||
| 53 | |||
| 54 |             if ($data['nbTotalPost'] > $data['nbPostFromList']) { | ||
| 55 | $html .= sprintf( | ||
| 56 | $this->getHtmlBottom1(), | ||
| 57 | count($data['list']) + 1, | ||
| 58 | $data['nb'], | ||
| 59 | $data['nbTotalPost'] - $data['nbPostFromList'] | ||
| 60 | ); | ||
| 61 | } | ||
| 62 | $html .= sprintf($this->getHtmlBottom2(), $data['nbTotalPost']); | ||
| 63 | $html .= '</tbody>'; | ||
| 64 | $html .= '</table>'; | ||
| 65 | $html .= '</div>'; | ||
| 66 | } | ||
| 67 | |||
| 68 | return $html; | ||
| 69 | } | ||
| 71 |