diff options
Diffstat (limited to 'src')
| -rw-r--r-- | src/SortByFieldExtension.php | 125 | 
1 files changed, 63 insertions, 62 deletions
| diff --git a/src/SortByFieldExtension.php b/src/SortByFieldExtension.php index 144a383..5241b9e 100644 --- a/src/SortByFieldExtension.php +++ b/src/SortByFieldExtension.php @@ -1,6 +1,7 @@  <?php  namespace Snilius\Twig; +  use Exception;  /** @@ -12,75 +13,75 @@ use Exception;   *   * I have extended it to also sort array structures   */ -  class SortByFieldExtension extends \Twig_Extension { -  public function getName() { -    return 'sortbyfield'; -  } +    public function getName() { +        return 'sortbyfield'; +    } -  public function getFilters() { -    return array( -      new \Twig_SimpleFilter('sortbyfield', array($this, 'sortByFieldFilter')) -    ); -  } -  /** -   * The "sortByField" filter sorts an array of entries (objects or arrays) by the specified field's value -   * -   * Usage: {% for entry in master.entries|sortbyfield('ordering', 'desc') %} -   */ -  public function sortByFieldFilter($content, $sort_by = null, $direction = 'asc') { -    if (!is_array($content)) { -      throw new \InvalidArgumentException('Variable passed to the sortByField filter is not an array'); -    } elseif ($sort_by === null) { -      throw new Exception('No sort by parameter passed to the sortByField filter'); -    } elseif (!self::isSortable(current($content), $sort_by)) { -      throw new Exception('Entries passed to the sortByField filter do not have the field "' . $sort_by . '"'); -    } else { -      // Unfortunately have to suppress warnings here due to __get function -      // causing usort to think that the array has been modified: -      // usort(): Array was modified by the user comparison function -      @usort($content, function ($a, $b) use($sort_by, $direction) { -        $flip = ($direction === 'desc') ? -1 : 1; +    public function getFilters() { +        return array( +            new \Twig_SimpleFilter('sortbyfield', array($this, 'sortByFieldFilter')) +        ); +    } -        if (is_array($a)) -          $a_sort_value = $a[$sort_by]; -        else if (method_exists($a, 'get' . ucfirst($sort_by))) -          $a_sort_value = $a->{'get' . ucfirst($sort_by)}(); -        else -          $a_sort_value = $a->$sort_by; +    /** +     * The "sortByField" filter sorts an array of entries (objects or arrays) by the specified field's value +     * +     * Usage: {% for entry in master.entries|sortbyfield('ordering', 'desc') %} +     */ +    public function sortByFieldFilter($content, $sort_by = null, $direction = 'asc') { +        if (!is_array($content)) { +            throw new \InvalidArgumentException('Variable passed to the sortByField filter is not an array'); +        } elseif ($sort_by === null) { +            throw new Exception('No sort by parameter passed to the sortByField filter'); +        } elseif (!self::isSortable(current($content), $sort_by)) { +            throw new Exception('Entries passed to the sortByField filter do not have the field "' . $sort_by . '"'); +        } else { +            // Unfortunately have to suppress warnings here due to __get function +            // causing usort to think that the array has been modified: +            // usort(): Array was modified by the user comparison function +            @usort($content, function ($a, $b) use ($sort_by, $direction) { +                $flip = ($direction === 'desc') ? -1 : 1; -        if (is_array($b)) -          $b_sort_value = $b[$sort_by]; -        else if (method_exists($b, 'get' . ucfirst($sort_by))) -          $b_sort_value = $b->{'get' . ucfirst($sort_by)}(); -        else -          $b_sort_value = $b->$sort_by; +                if (is_array($a)) +                    $a_sort_value = $a[$sort_by]; +                else if (method_exists($a, 'get' . ucfirst($sort_by))) +                    $a_sort_value = $a->{'get' . ucfirst($sort_by)}(); +                else +                    $a_sort_value = $a->$sort_by; -        if($a_sort_value == $b_sort_value) { -          return 0; -        } else if($a_sort_value > $b_sort_value) { -          return (1 * $flip); -        } else { -          return (-1 * $flip); +                if (is_array($b)) +                    $b_sort_value = $b[$sort_by]; +                else if (method_exists($b, 'get' . ucfirst($sort_by))) +                    $b_sort_value = $b->{'get' . ucfirst($sort_by)}(); +                else +                    $b_sort_value = $b->$sort_by; + +                if ($a_sort_value == $b_sort_value) { +                    return 0; +                } else if ($a_sort_value > $b_sort_value) { +                    return (1 * $flip); +                } else { +                    return (-1 * $flip); +                } +            });          } -      }); +        return $content;      } -    return $content; -  } -  /** -   * Validate the passed $item to check if it can be sorted -   * @param $item mixed Collection item to be sorted -   * @param $field string -   * @return bool If collection item can be sorted -   */ -  private static function isSortable($item, $field) { -    if (is_array($item)) -      return array_key_exists($field, $item); -    elseif (is_object($item)) -      return isset($item->$field) || property_exists($item, $field); -    else -      return false; -  } +    /** +     * Validate the passed $item to check if it can be sorted +     * @param $item mixed Collection item to be sorted +     * @param $field string +     * @return bool If collection item can be sorted +     */ +    private static function isSortable($item, $field) { +        if (is_array($item)) +            return array_key_exists($field, $item); +        elseif (is_object($item)) +            return isset($item->$field) || property_exists($item, $field); +        else +            return false; +    }  } | 
