27use OOUI\ButtonGroupWidget;
56 $this->mSort = $this->
getRequest()->getText(
'sort' );
57 if ( !array_key_exists( $this->mSort, $this->
getFieldNames() )
64 } elseif ( $this->
getRequest()->getBool(
'desc' ) ) {
69 parent::__construct(
null, $linkRenderer );
89 return parent::getBody();
102 $body = parent::getBody();
120 $body = parent::getBody();
123 $pout->
setRawText( $navigation . $body . $navigation );
139 foreach ( $fields as $field => $name ) {
140 if ( strval( $name ) ==
'' ) {
141 $s .= Html::rawElement(
'th', [],
"\u{00A0}" ) .
"\n";
147 if ( $this->mSort == $field ) {
152 $class =
"$sortClass mw-datatable-is-sorted mw-datatable-is-descending";
157 $class =
"$sortClass mw-datatable-is-sorted mw-datatable-is-ascending";
159 $query[
'desc'] =
'1';
163 $link = $this->
makeLink( htmlspecialchars( $name ), $query, $linkType );
164 $s .= Html::rawElement(
'th', [
'class' => $class ], $link ) .
"\n";
170 $ret = Html::openElement(
'table', [
173 $ret .= Html::rawElement(
'thead', [], Html::rawElement(
'tr', [],
"\n" . $s .
"\n" ) );
174 $ret .= Html::openElement(
'tbody' ) .
"\n";
184 return "</tbody></table>\n";
192 $msgEmpty = $this->
msg(
'table_pager_empty' )->text();
193 return Html::rawElement(
'tr', [],
194 Html::element(
'td', [
'colspan' => $colspan ], $msgEmpty ) );
203 $this->mCurrentRow = $row;
204 $s = Html::openElement(
'tr', $this->
getRowAttrs( $row ) ) .
"\n";
207 foreach ( $fieldNames as $field => $name ) {
208 $value = $row->$field ??
null;
209 $formatted = strval( $this->
formatValue( $field, $value ) );
211 if ( $formatted ==
'' ) {
212 $formatted =
"\u{00A0}";
215 $s .= Html::rawElement(
'td', $this->
getCellAttrs( $field, $value ), $formatted ) .
"\n";
218 $s .= Html::closeElement(
'tr' ) .
"\n";
266 return [
'class' =>
'TablePager_col_' . $field ];
284 return 'mw-datatable';
292 return 'TablePager_nav';
300 return 'TablePager_sort';
316 $types = [
'first',
'prev',
'next',
'last' ];
324 foreach ( $types as $type ) {
325 $buttons[] =
new ButtonWidget( [
331 'classes' => [
'TablePager-button-' . $type ],
332 'flags' => [
'progressive' ],
334 'label' => $this->
msg(
'table_pager_' . $type )->text(),
335 'href' => $queries[ $type ] ?
336 $title->getLinkURL( $queries[ $type ] + $this->getDefaultQuery() ) :
338 'icon' => $type ===
'prev' ?
'previous' : $type,
339 'disabled' => $queries[ $type ] === false
342 return new ButtonGroupWidget( [
353 parent::getModuleStyles(), [
'oojs-ui.styles.icons-movement' ]
364 $select =
new XmlSelect(
'limit',
false, $this->mLimit );
366 foreach ( $attribs as $name => $value ) {
367 $select->setAttribute( $name, $value );
369 return $select->getHTML();
380 # Add the current limit from the query string
381 # to avoid that the limit is lost after clicking Go next time
382 if ( !in_array( $this->mLimit, $this->mLimitsShown ) ) {
384 sort( $this->mLimitsShown );
387 foreach ( $this->mLimitsShown as $key => $value ) {
388 # The pair is either $index => $limit, in which case the $value
389 # will be numeric, or $limit => $text, in which case the $value
391 if ( is_int( $value ) ) {
398 $ret[$text] = $limit;
413 $noResubmit = (array)$noResubmit;
414 $query = $this->
getRequest()->getQueryValues();
415 foreach ( $noResubmit as $name ) {
416 unset( $query[$name] );
419 foreach ( $query as $name => $value ) {
420 if ( is_array( $value ) ) {
424 $s .= Html::hidden( $name, $value ) .
"\n";
435 return Html::rawElement(
441 "\n" . $this->getLimitDropdown()
450 private function getLimitDropdown() {
451 # Make the select with some explanatory text
452 $msgSubmit = $this->
msg(
'table_pager_limit_submit' )->escaped();
454 return $this->
msg(
'table_pager_limit' )
456 "\n<input type=\"submit\" value=\"$msgSubmit\"/>\n" .
504class_alias( TablePager::class,
'TablePager' );
wfScript( $script='index')
Get the URL path to a MediaWiki entry point.
wfDeprecated( $function, $version=false, $component=false, $callerOffset=2)
Logs a warning that a deprecated feature was used.
setContext(IContextSource $context)
msg( $key,... $params)
Get a Message object with context set Parameters are the same as wfMessage()
Class for generating HTML <select> or <datalist> elements.
Interface for objects which can provide a MediaWiki context on request.