chamilo/chamilo-lms

View on GitHub
public/main/inc/lib/array.lib.php

Summary

Maintainability
A
0 mins
Test Coverage
<?php

/* For licensing terms, see /license.txt */

/**
 * This is the array library for Chamilo.

 * Removes duplicate values from a dimensional array.
 *
 * @param array|mixed $array dimensional array
 *
 * @return array an array with unique values
 */
function array_unique_dimensional($array)
{
    if (!is_array($array)) {
        return $array;
    }

    foreach ($array as &$myvalue) {
        $myvalue = serialize($myvalue);
    }

    $array = array_unique($array);

    foreach ($array as &$myvalue) {
        $myvalue = UnserializeApi::unserialize('not_allowed_clases', $myvalue);
    }

    return $array;
}

/**
 * Sort multidimensional arrays.
 *
 * @param    array    unsorted multidimensional array
 * @param    string    key to be sorted
 *
 * @return array result array
 *
 * @author    found in http://php.net/manual/en/function.sort.php
 */
function msort($array, $id = 'id', $order = 'desc')
{
    if (empty($array)) {
        return $array;
    }
    $temp_array = [];
    while (count($array) > 0) {
        $lowest_id = 0;
        $index = 0;
        foreach ($array as $item) {
            if ('desc' === $order) {
                if (strip_tags($item[$id]) < strip_tags($array[$lowest_id][$id])) {
                    $lowest_id = $index;
                }
            } else {
                if (isset($item[$id]) && strip_tags($item[$id]) > strip_tags($array[$lowest_id][$id])) {
                    $lowest_id = $index;
                }
            }
            $index++;
        }
        $temp_array[] = $array[$lowest_id];
        $array = array_merge(
            array_slice($array, 0, $lowest_id),
            array_slice($array, $lowest_id + 1)
        );
    }

    return $temp_array;
}

/**
 * @param $array
 *
 * @return mixed
 */
function utf8_sort($array)
{
    $old_locale = setlocale(LC_ALL, 0);
    $code = api_get_language_isocode();
    $locale_list = [$code.'.utf8', 'en.utf8', 'en_US.utf8', 'en_GB.utf8'];
    $try_sort = false;

    foreach ($locale_list as $locale) {
        $my_local = setlocale(LC_COLLATE, $locale);
        if ($my_local) {
            $try_sort = true;
            break;
        }
    }

    if ($try_sort) {
        uasort($array, 'strcoll');
    }
    setlocale(LC_COLLATE, $old_locale);

    return $array;
}

/**
 * @param array  $array
 * @param string $separator
 *
 * @return string
 */
function array_to_string($array, $separator = ',')
{
    if (empty($array)) {
        return '';
    }

    return implode($separator.' ', $array);
}

/**
 * @return array
 */
function array_flatten(array $array)
{
    $flatten = [];
    array_walk_recursive(
        $array,
        function ($value) use (&$flatten) {
            $flatten[] = $value;
        }
    );

    return $flatten;
}

/**
 * Shuffles an array keeping the associations.
 *
 * @param $array
 *
 * @return bool
 */
function shuffle_assoc(&$array)
{
    $keys = array_keys($array);
    shuffle($keys);
    $new = [];
    foreach ($keys as $key) {
        $new[$key] = $array[$key];
    }
    $array = $new;

    return true;
}