当前位置: 首页>>代码示例>>PHP>>正文


PHP DataTable::setTableSortedBy方法代码示例

本文整理汇总了PHP中Piwik\DataTable::setTableSortedBy方法的典型用法代码示例。如果您正苦于以下问题:PHP DataTable::setTableSortedBy方法的具体用法?PHP DataTable::setTableSortedBy怎么用?PHP DataTable::setTableSortedBy使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在Piwik\DataTable的用法示例。


在下文中一共展示了DataTable::setTableSortedBy方法的3个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的PHP代码示例。

示例1: getEvenUnevenTimes

 /**
  * API method that returns number of visits based on hour parity.
  * @param int    $idSite
  * @param string $period
  * @param string $date
  * @param bool|string $segment
  * @return DataTable
  */
 public function getEvenUnevenTimes($idSite, $period, $date, $segment = false)
 {
     $archive = Archive::build($idSite, $period, $date);
     $oddHoursCount = $archive->getNumeric(Archiver::ODD_HOURS_COUNT_RECORD_NAME);
     $evenHoursCount = $archive->getNumeric(Archiver::EVEN_HOURS_COUNT_RECORD_NAME);
     $table = new DataTable();
     $table->setTableSortedBy('times');
     $table->addRowFromArray(array(Row::COLUMNS => array('times' => Piwik::translate('HourParity_Oddhours'), 'nb_visits' => $oddHoursCount)));
     $table->addRowFromArray(array(Row::COLUMNS => array('times' => Piwik::translate('HourParity_Evenhours'), 'nb_visits' => $evenHoursCount)));
     return $table;
 }
开发者ID:MichalKrakiewicz,项目名称:HourParity,代码行数:19,代码来源:API.php

示例2: sort

 /**
  * Sorts the DataTable rows using the supplied callback function.
  *
  * @param DataTable $table The table to sort.
  */
 public function sort(DataTable $table)
 {
     // all that code is in here and not in separate methods for best performance. It does make a difference once
     // php has to copy many (eg 50k) rows otherwise.
     $table->setTableSortedBy($this->config->primaryColumnToSort);
     $rows = $table->getRowsWithoutSummaryRow();
     // we need to sort rows that have a value separately from rows that do not have a value since we always want
     // to append rows that do not have a value at the end.
     $rowsWithValues = array();
     $rowsWithoutValues = array();
     $valuesToSort = array();
     foreach ($rows as $key => $row) {
         $value = $this->getColumnValue($row);
         if (isset($value)) {
             $valuesToSort[] = $value;
             $rowsWithValues[] = $row;
         } else {
             $rowsWithoutValues[] = $row;
         }
     }
     unset($rows);
     if ($this->config->isSecondaryColumnSortEnabled && $this->config->secondaryColumnToSort) {
         $secondaryValues = array();
         foreach ($rowsWithValues as $key => $row) {
             $secondaryValues[$key] = $row->getColumn($this->config->secondaryColumnToSort);
         }
         array_multisort($valuesToSort, $this->config->primarySortOrder, $this->config->primarySortFlags, $secondaryValues, $this->config->secondarySortOrder, $this->config->secondarySortFlags, $rowsWithValues);
     } else {
         array_multisort($valuesToSort, $this->config->primarySortOrder, $this->config->primarySortFlags, $rowsWithValues);
     }
     if (!empty($rowsWithoutValues) && $this->config->secondaryColumnToSort) {
         $secondaryValues = array();
         foreach ($rowsWithoutValues as $key => $row) {
             $secondaryValues[$key] = $row->getColumn($this->config->secondaryColumnToSort);
         }
         array_multisort($secondaryValues, $this->config->secondarySortOrder, $this->config->secondarySortFlags, $rowsWithoutValues);
     }
     unset($secondaryValues);
     foreach ($rowsWithoutValues as $row) {
         $rowsWithValues[] = $row;
     }
     $table->setRows(array_values($rowsWithValues));
 }
开发者ID:piwik,项目名称:piwik,代码行数:48,代码来源:Sorter.php

示例3: sort

 /**
  * Sorts the DataTable rows using the supplied callback function.
  *
  * @param string $functionCallback A comparison callback compatible with {@link usort}.
  * @param string $columnSortedBy The column name `$functionCallback` sorts by. This is stored
  *                               so we can determine how the DataTable was sorted in the future.
  */
 private function sort(DataTable $table, $functionCallback)
 {
     $table->setTableSortedBy($this->columnToSort);
     $rows = $table->getRowsWithoutSummaryRow();
     // get column value and label only once for performance tweak
     $values = array();
     if ($functionCallback === 'numberSort') {
         foreach ($rows as $key => $row) {
             $values[$key] = array($this->getColumnValue($row), $row->getColumn('label'));
         }
     } else {
         foreach ($rows as $key => $row) {
             $values[$key] = $this->getColumnValue($row);
         }
     }
     uasort($values, array($this, $functionCallback));
     $sortedRows = array();
     foreach ($values as $key => $value) {
         $sortedRows[] = $rows[$key];
     }
     $table->setRows($sortedRows);
     unset($rows);
     unset($sortedRows);
     if ($table->isSortRecursiveEnabled()) {
         foreach ($table->getRowsWithoutSummaryRow() as $row) {
             $subTable = $row->getSubtable();
             if ($subTable) {
                 $subTable->enableRecursiveSort();
                 $this->sort($subTable, $functionCallback);
             }
         }
     }
 }
开发者ID:bossrabbit,项目名称:piwik,代码行数:40,代码来源:Sort.php


注:本文中的Piwik\DataTable::setTableSortedBy方法示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。