Skip to:
Content

bbPress.org


Ignore:
Timestamp:
01/23/2018 11:26:56 PM (8 years ago)
Author:
johnjamesjacoby
Message:

Admin: enforce row-action order for forums, topics, and replies.

This change introduces a known (and filterable) sort-order to row-action keys, allowing for a more logical flow to better match Posts, Pages, and other WordPress core objects.

With slight variations, the flow is: Edit, Stick(to front), Un/approve, Open/Close, Delete/Trash, Spam, View.

Previous to this change, these row_actions() filters were only appending or overwriting keys, which introduced an unnecessary administration variation with no real benefit.

File:
1 edited

Legend:

Unmodified
Added
Removed
  • trunk/src/includes/admin/forums.php

    r6771 r6772  
    475475
    476476    /**
     477     * Returns an array of keys used to sort row actions
     478     *
     479     * @since 2.6.0 bbPress (r6771)
     480     *
     481     * @return array
     482     */
     483    private function get_row_action_sort_order() {
     484
     485        // Filter & return
     486        return (array) apply_filters( 'bbp_admin_forum_row_action_sort_order', array(
     487            'edit',
     488            'closed',
     489            'trash',
     490            'untrash',
     491            'delete',
     492            'view'
     493        ) );
     494    }
     495
     496    /**
    477497     * Returns an array of notice toggles
    478498     *
     
    596616     * @since 2.0.0 bbPress (r2577)
    597617     *
    598      * @param array $actions Actions
    599      * @param array $forum Forum object
     618     * @param array  $actions Actions
     619     * @param object $forum Topic object
     620     *
    600621     * @return array $actions Actions
    601622     */
    602     public function row_actions( $actions, $forum ) {
    603 
     623    public function row_actions( $actions = array(), $forum = false ) {
     624
     625        // Disable quick edit (too much to do here)
    604626        unset( $actions['inline hide-if-no-js'] );
    605627
     
    621643        bbp_forum_content( $forum->ID );
    622644
    623         return $actions;
     645        // Sort & return
     646        return $this->sort_row_actions( $actions );
     647    }
     648
     649    /**
     650     * Sort row actions by key
     651     *
     652     * @since 2.6.0
     653     *
     654     * @param array $actions
     655     *
     656     * @return array
     657     */
     658    private function sort_row_actions( $actions = array() ) {
     659
     660        // Return value
     661        $retval = array();
     662
     663        // Known row actions, in sort order
     664        $known_actions = $this->get_row_action_sort_order();
     665
     666        // Sort known actions, and keep any unknown ones
     667        foreach ( $known_actions as $key ) {
     668            if ( isset( $actions[ $key ] ) ) {
     669                $retval[ $key ] = $actions[ $key ];
     670                unset( $actions[ $key ] );
     671            }
     672        }
     673
     674        // Combine & return
     675        return $retval + $actions;
    624676    }
    625677
Note: See TracChangeset for help on using the changeset viewer.