we offer 2 programs

Gold and Platinum

build-footer

Gold Program

Get 10% offǂ your plan service home plan license when purchased directly from Design Basics – single- or unlimited-build (excludes plan alterations and design or drafting of custom home plans). Plus, 10% off product purchases.
(ǂExcludes home plans by W.L. Martin Home Designs #24000 to #24999.)

build-footer

Platinum Program

Get 15% offǂ your plan service home plan license when purchased directly from Design Basics – single- or unlimited-build (excludes plan alterations and design or drafting of custom home plans). Plus, 15% off product purchases.
(ǂExcludes home plans by W.L. Martin Home Designs - #24000 to #24999.)

program comparison

Program Benefit Summary

Choose between our GOLD or PLATINUM Programs and watch your savings multiply! Get study plan sets for a fraction of the cost – use them to estimate building costs and review design options with customers before you buy. Also, choose one FREE upgrade with every order, such as an alternate foundation or reverse plan set.

Builder Benefits

Gold

Platinum

Plan Service Home Plan License Purchase Discount (includes single- and unlimited-build licenses)

10%

15%

Product Purchase Discount

10%

15%

25% off Digital Home Plan Book

50% off your 1st New Trend Makeover

Concierge Service (We'll recommend plans for your next project)

Most Recent Home Plan Books FREE

$100 Study Plan Sets* for Estimating Purposes (up to five different plans per year)

One FREE Upgrade Per Plan License*† Purchased (from available upgrades; varies by plan)

Promotional License with Livability at a Glance™ Floor Plans (per plan licensed through program)

Program Cost

$249/yr

$349/yr

Contact us for more information.
*Applies to Design Basics, Scholz Design, Carmichael & Dame Designs and Plan Pros, Inc., plan licenses purchased directly from Design Basics. †Full construction prints only (PDF, sets, or CAD files).

Still looking for more?

Kickstart Your Neighborhood℠

Expand your portfolio without the risk: Choose 5 plans for estimating purposes and market the plans with color rendered artwork.
You’ll be enrolled in our Builder-Centric PLATINUM program and receive all the additional benefits offered.

What You Will Get

build-footer

Digital Home Plan Book

Customize your digital plan book when you:

  • Personalize your cover design
  • Add your logo and contact information
  • Choose the featured plans with full-color images

Your customized Digital Home Plan Book is delivered in a PDF format that you can add to your website, email to customers, or easily print on 8 1/2 x 11″ paper. Upgrade to a Digital Flip Book (see sample below) for an additional fee. *No additional discounts or offers apply.

build-footer

$100 Study Plan Sets*

Sometimes you need to price out a home in order to get the sale, but you need to have the plans in order to get accurate bids. As a Builder-Centric member you can order estimating Study Sets* for up to five (5) different home plans per year for just $100 per study set! (Starting with the 6th plan, Study Sets are $250 each.)

*NOT FOR CONSTRUCTION PURPOSES. Applies to Design Basics, Design Basics/HBN, Scholz Design, Carmichael & Dame Designs, and Plan Pros, Inc. home plans. Full construction prints only (PDF or CAD files). Excludes custom designs. Does not apply to prior plan license purchases. Cannot be combined with any other promotion or discount.

One FREE Upgrade* per Plan Licensed

build-footer
Alternate Foundation
build-footer
Materials Estimate

Alternate Exterior Wall Framing

build-footer
2" x 4"
build-footer
2" x 6"

Forward + Right Reading Reverse Plans

build-footer
build-footer

No-Step Entry Floor Plan

A No-Step Entry floor plan means there are no barriers to enter the home from the front door or the garage entry. This is helpful for occupants and guests with limited mobility.

*For each plan licensed, choose one available upgrade for that plan: Alternate foundation (basement, crawl, or slab); Alternate exterior wall framing (2x4" or 2x6"); Forward + Reverse plans; No-Step Entry floor plan; or a Materials list (not all upgrades available for all plans). Applies to Design Basics, LLC, Scholz Design, Carmichael & Dame Designs, and Plan Pros, Inc. home plans. Full construction prints only (PDF, sets, or CAD files). Excludes custom designs. Does not apply to prior plan license purchases. Cannot be combined with any other promotion or discount.

New Trend Makeover

Send it to us (CAD file, preferred), and we’ll update your plan with the latest design thought and must-have amenities! Increase marketability while staying with a home design you are familiar with – both in terms of construction and cost.

  • Open floorplan concept

  • Flex room, rather than formal dining

  • Rear foyer with discrete laundry and drop zone

  • Expansive entertaining kitchen with large island and walk-in pantry

  • Expandable dining area for large gatherings

  • Oversized spa shower with no door in owner’s bath

  • Linen storage in owner’s bath

  • Compartmented hall bath with natural light

  • More storage in bedroom 2; more light for bedroom 3

  • Note: The makeover is a design concept; no changes to the construction drawings.

    build-footer

    Example of new trend makeover

    Current Dir: /var/www/designbasics/wp-admin/
    
    [FILE] about.php [ edit | delete | rename ]
    [FILE] admin-ajax.php [ edit | delete | rename ]
    [FILE] admin-footer.php [ edit | delete | rename ]
    [FILE] admin-functions.php [ edit | delete | rename ]
    [FILE] admin-header.php [ edit | delete | rename ]
    [FILE] admin-post.php [ edit | delete | rename ]
    [FILE] admin.php [ edit | delete | rename ]
    [FILE] async-upload.php [ edit | delete | rename ]
    [FILE] authorize-application.php [ edit | delete | rename ]
    [FILE] comment.php [ edit | delete | rename ]
    [FILE] contribute.php [ edit | delete | rename ]
    [FILE] credits.php [ edit | delete | rename ]
    [DIR]  css [ delete | rename ]
    [FILE] custom-background.php [ edit | delete | rename ]
    [FILE] custom-header.php [ edit | delete | rename ]
    [FILE] customize.php [ edit | delete | rename ]
    [FILE] edit-comments.php [ edit | delete | rename ]
    [FILE] edit-form-advanced.php [ edit | delete | rename ]
    [FILE] edit-form-blocks.php [ edit | delete | rename ]
    [FILE] edit-form-comment.php [ edit | delete | rename ]
    [FILE] edit-link-form.php [ edit | delete | rename ]
    [FILE] edit-tag-form.php [ edit | delete | rename ]
    [FILE] edit-tags.php [ edit | delete | rename ]
    [FILE] edit.php [ edit | delete | rename ]
    [FILE] erase-personal-data.php [ edit | delete | rename ]
    [FILE] export-personal-data.php [ edit | delete | rename ]
    [FILE] export.php [ edit | delete | rename ]
    [FILE] freedoms.php [ edit | delete | rename ]
    [DIR]  images [ delete | rename ]
    [FILE] import.php [ edit | delete | rename ]
    [DIR]  includes [ delete | rename ]
    [FILE] index.php [ edit | delete | rename ]
    [FILE] install-helper.php [ edit | delete | rename ]
    [FILE] install.php [ edit | delete | rename ]
    [DIR]  js [ delete | rename ]
    [FILE] link-add.php [ edit | delete | rename ]
    [FILE] link-manager.php [ edit | delete | rename ]
    [FILE] link-parse-opml.php [ edit | delete | rename ]
    [FILE] link.php [ edit | delete | rename ]
    [FILE] load-scripts.php [ edit | delete | rename ]
    [FILE] load-styles.php [ edit | delete | rename ]
    [DIR]  maint [ delete | rename ]
    [FILE] media-new.php [ edit | delete | rename ]
    [FILE] media-upload.php [ edit | delete | rename ]
    [FILE] media.php [ edit | delete | rename ]
    [FILE] menu-header.php [ edit | delete | rename ]
    [FILE] menu.php [ edit | delete | rename ]
    [FILE] moderation.php [ edit | delete | rename ]
    [FILE] ms-admin.php [ edit | delete | rename ]
    [FILE] ms-delete-site.php [ edit | delete | rename ]
    [FILE] ms-edit.php [ edit | delete | rename ]
    [FILE] ms-options.php [ edit | delete | rename ]
    [FILE] ms-sites.php [ edit | delete | rename ]
    [FILE] ms-themes.php [ edit | delete | rename ]
    [FILE] ms-upgrade-network.php [ edit | delete | rename ]
    [FILE] ms-users.php [ edit | delete | rename ]
    [FILE] my-sites.php [ edit | delete | rename ]
    [FILE] nav-menus.php [ edit | delete | rename ]
    [DIR]  network [ delete | rename ]
    [FILE] network.php [ edit | delete | rename ]
    [FILE] options-discussion.php [ edit | delete | rename ]
    [FILE] options-general.php [ edit | delete | rename ]
    [FILE] options-head.php [ edit | delete | rename ]
    [FILE] options-media.php [ edit | delete | rename ]
    [FILE] options-permalink.php [ edit | delete | rename ]
    [FILE] options-privacy.php [ edit | delete | rename ]
    [FILE] options-reading.php [ edit | delete | rename ]
    [FILE] options-writing.php [ edit | delete | rename ]
    [FILE] options.php [ edit | delete | rename ]
    [FILE] plugin-editor.php [ edit | delete | rename ]
    [FILE] plugin-install.php [ edit | delete | rename ]
    [FILE] plugins.php [ edit | delete | rename ]
    [FILE] post-new.php [ edit | delete | rename ]
    [FILE] post.php [ edit | delete | rename ]
    [FILE] press-this.php [ edit | delete | rename ]
    [FILE] privacy-policy-guide.php [ edit | delete | rename ]
    [FILE] privacy.php [ edit | delete | rename ]
    [FILE] profile.php [ edit | delete | rename ]
    [FILE] revision.php [ edit | delete | rename ]
    [FILE] setup-config.php [ edit | delete | rename ]
    [FILE] site-editor.php [ edit | delete | rename ]
    [FILE] site-health-info.php [ edit | delete | rename ]
    [FILE] site-health.php [ edit | delete | rename ]
    [FILE] term.php [ edit | delete | rename ]
    [FILE] theme-editor.php [ edit | delete | rename ]
    [FILE] theme-install.php [ edit | delete | rename ]
    [FILE] themes.php [ edit | delete | rename ]
    [FILE] tools.php [ edit | delete | rename ]
    [FILE] update-core.php [ edit | delete | rename ]
    [FILE] update.php [ edit | delete | rename ]
    [FILE] upgrade-functions.php [ edit | delete | rename ]
    [FILE] upgrade.php [ edit | delete | rename ]
    [FILE] upload.php [ edit | delete | rename ]
    [DIR]  user [ delete | rename ]
    [FILE] user-edit.php [ edit | delete | rename ]
    [FILE] user-new.php [ edit | delete | rename ]
    [FILE] users.php [ edit | delete | rename ]
    [FILE] widgets-form-blocks.php [ edit | delete | rename ]
    [FILE] widgets-form.php [ edit | delete | rename ]
    [FILE] widgets.php [ edit | delete | rename ]
    
    Viewing: /var/www/designbasics/wp-admin/users.php
    
    <?php
    /**
     * User administration panel
     *
     * @package WordPress
     * @subpackage Administration
     * @since 1.0.0
     */
    
    /** WordPress Administration Bootstrap */
    require_once __DIR__ . '/admin.php';
    
    if ( ! current_user_can( 'list_users' ) ) {
    	wp_die(
    		'<h1>' . __( 'You need a higher level of permission.' ) . '</h1>' .
    		'<p>' . __( 'Sorry, you are not allowed to list users.' ) . '</p>',
    		403
    	);
    }
    
    $wp_list_table = _get_list_table( 'WP_Users_List_Table' );
    $pagenum       = $wp_list_table->get_pagenum();
    
    // Used in the HTML title tag.
    $title       = __( 'Users' );
    $parent_file = 'users.php';
    
    add_screen_option( 'per_page' );
    
    // Contextual help - choose Help on the top right of admin panel to preview this.
    get_current_screen()->add_help_tab(
    	array(
    		'id'      => 'overview',
    		'title'   => __( 'Overview' ),
    		'content' => '<p>' . __( 'This screen lists all the existing users for your site. Each user has one of five defined roles as set by the site admin: Site Administrator, Editor, Author, Contributor, or Subscriber. Users with roles other than Administrator will see fewer options in the dashboard navigation when they are logged in, based on their role.' ) . '</p>' .
    		'<p>' . __( 'To add a new user for your site, click the Add New User button at the top of the screen or Add New User in the Users menu section.' ) . '</p>',
    	)
    );
    
    get_current_screen()->add_help_tab(
    	array(
    		'id'      => 'screen-content',
    		'title'   => __( 'Screen Content' ),
    		'content' => '<p>' . __( 'You can customize the display of this screen in a number of ways:' ) . '</p>' .
    						'<ul>' .
    						'<li>' . __( 'You can hide/display columns based on your needs and decide how many users to list per screen using the Screen Options tab.' ) . '</li>' .
    						'<li>' . __( 'You can filter the list of users by User Role using the text links above the users list to show All, Administrator, Editor, Author, Contributor, or Subscriber. The default view is to show all users. Unused User Roles are not listed.' ) . '</li>' .
    						'<li>' . __( 'You can view all posts made by a user by clicking on the number under the Posts column.' ) . '</li>' .
    						'</ul>',
    	)
    );
    
    $help = '<p>' . __( 'Hovering over a row in the users list will display action links that allow you to manage users. You can perform the following actions:' ) . '</p>' .
    	'<ul>' .
    	'<li>' . __( '<strong>Edit</strong> takes you to the editable profile screen for that user. You can also reach that screen by clicking on the username.' ) . '</li>';
    
    if ( is_multisite() ) {
    	$help .= '<li>' . __( '<strong>Remove</strong> allows you to remove a user from your site. It does not delete their content. You can also remove multiple users at once by using bulk actions.' ) . '</li>';
    } else {
    	$help .= '<li>' . __( '<strong>Delete</strong> brings you to the Delete Users screen for confirmation, where you can permanently remove a user from your site and delete their content. You can also delete multiple users at once by using bulk actions.' ) . '</li>';
    }
    
    $help .= '<li>' . __( '<strong>View</strong> takes you to a public author archive which lists all the posts published by the user.' ) . '</li>';
    
    if ( current_user_can( 'edit_users' ) ) {
    	$help .= '<li>' . __( '<strong>Send password reset</strong> sends the user an email with a link to set a new password.' ) . '</li>';
    }
    
    $help .= '</ul>';
    
    get_current_screen()->add_help_tab(
    	array(
    		'id'      => 'action-links',
    		'title'   => __( 'Available Actions' ),
    		'content' => $help,
    	)
    );
    unset( $help );
    
    get_current_screen()->set_help_sidebar(
    	'<p><strong>' . __( 'For more information:' ) . '</strong></p>' .
    	'<p>' . __( '<a href="https://wordpress.org/documentation/article/users-screen/">Documentation on Managing Users</a>' ) . '</p>' .
    	'<p>' . __( '<a href="https://wordpress.org/documentation/article/roles-and-capabilities/">Descriptions of Roles and Capabilities</a>' ) . '</p>' .
    	'<p>' . __( '<a href="https://wordpress.org/support/forums/">Support forums</a>' ) . '</p>'
    );
    
    get_current_screen()->set_screen_reader_content(
    	array(
    		'heading_views'      => __( 'Filter users list' ),
    		'heading_pagination' => __( 'Users list navigation' ),
    		'heading_list'       => __( 'Users list' ),
    	)
    );
    
    if ( empty( $_REQUEST ) ) {
    	$referer = '<input type="hidden" name="wp_http_referer" value="' . esc_attr( wp_unslash( $_SERVER['REQUEST_URI'] ) ) . '" />';
    } elseif ( isset( $_REQUEST['wp_http_referer'] ) ) {
    	$redirect = remove_query_arg( array( 'wp_http_referer', 'updated', 'delete_count' ), wp_unslash( $_REQUEST['wp_http_referer'] ) );
    	$referer  = '<input type="hidden" name="wp_http_referer" value="' . esc_attr( $redirect ) . '" />';
    } else {
    	$redirect = 'users.php';
    	$referer  = '';
    }
    
    $update = '';
    
    switch ( $wp_list_table->current_action() ) {
    
    	/* Bulk Dropdown menu Role changes */
    	case 'promote':
    		check_admin_referer( 'bulk-users' );
    
    		if ( ! current_user_can( 'promote_users' ) ) {
    			wp_die( __( 'Sorry, you are not allowed to edit this user.' ), 403 );
    		}
    
    		if ( empty( $_REQUEST['users'] ) ) {
    			wp_redirect( $redirect );
    			exit;
    		}
    
    		$editable_roles = get_editable_roles();
    		$role           = $_REQUEST['new_role'];
    
    		// Mocking the `none` role so we are able to save it to the database
    		$editable_roles['none'] = array(
    			'name' => __( '&mdash; No role for this site &mdash;' ),
    		);
    
    		if ( ! $role || empty( $editable_roles[ $role ] ) ) {
    			wp_die( __( 'Sorry, you are not allowed to give users that role.' ), 403 );
    		}
    
    		if ( 'none' === $role ) {
    			$role = '';
    		}
    
    		$user_ids = array_map( 'intval', (array) $_REQUEST['users'] );
    		$update   = 'promote';
    
    		foreach ( $user_ids as $id ) {
    			if ( ! current_user_can( 'promote_user', $id ) ) {
    				wp_die( __( 'Sorry, you are not allowed to edit this user.' ), 403 );
    			}
    
    			// The new role of the current user must also have the promote_users cap or be a multisite super admin.
    			if ( $id === $current_user->ID
    				&& ! $wp_roles->role_objects[ $role ]->has_cap( 'promote_users' )
    				&& ! ( is_multisite() && current_user_can( 'manage_network_users' ) )
    			) {
    					$update = 'err_admin_role';
    					continue;
    			}
    
    			// If the user doesn't already belong to the blog, bail.
    			if ( is_multisite() && ! is_user_member_of_blog( $id ) ) {
    				wp_die(
    					'<h1>' . __( 'Something went wrong.' ) . '</h1>' .
    					'<p>' . __( 'One of the selected users is not a member of this site.' ) . '</p>',
    					403
    				);
    			}
    
    			$user = get_userdata( $id );
    			$user->set_role( $role );
    		}
    
    		wp_redirect( add_query_arg( 'update', $update, $redirect ) );
    		exit;
    
    	case 'dodelete':
    		if ( is_multisite() ) {
    			wp_die( __( 'User deletion is not allowed from this screen.' ), 400 );
    		}
    
    		check_admin_referer( 'delete-users' );
    
    		if ( empty( $_REQUEST['users'] ) ) {
    			wp_redirect( $redirect );
    			exit;
    		}
    
    		$user_ids = array_map( 'intval', (array) $_REQUEST['users'] );
    
    		if ( empty( $_REQUEST['delete_option'] ) ) {
    			$url = self_admin_url( 'users.php?action=delete&users[]=' . implode( '&users[]=', $user_ids ) . '&error=true' );
    			$url = str_replace( '&amp;', '&', wp_nonce_url( $url, 'bulk-users' ) );
    			wp_redirect( $url );
    			exit;
    		}
    
    		if ( ! current_user_can( 'delete_users' ) ) {
    			wp_die( __( 'Sorry, you are not allowed to delete users.' ), 403 );
    		}
    
    		$update       = 'del';
    		$delete_count = 0;
    
    		foreach ( $user_ids as $id ) {
    			if ( ! current_user_can( 'delete_user', $id ) ) {
    				wp_die( __( 'Sorry, you are not allowed to delete that user.' ), 403 );
    			}
    
    			if ( $id === $current_user->ID ) {
    				$update = 'err_admin_del';
    				continue;
    			}
    
    			switch ( $_REQUEST['delete_option'] ) {
    				case 'delete':
    					wp_delete_user( $id );
    					break;
    				case 'reassign':
    					wp_delete_user( $id, $_REQUEST['reassign_user'] );
    					break;
    			}
    
    			++$delete_count;
    		}
    
    		$redirect = add_query_arg(
    			array(
    				'delete_count' => $delete_count,
    				'update'       => $update,
    			),
    			$redirect
    		);
    		wp_redirect( $redirect );
    		exit;
    
    	case 'resetpassword':
    		check_admin_referer( 'bulk-users' );
    
    		if ( ! current_user_can( 'edit_users' ) ) {
    			$errors = new WP_Error( 'edit_users', __( 'Sorry, you are not allowed to edit users.' ) );
    		}
    
    		if ( empty( $_REQUEST['users'] ) ) {
    			wp_redirect( $redirect );
    			exit();
    		}
    
    		$user_ids = array_map( 'intval', (array) $_REQUEST['users'] );
    
    		$reset_count = 0;
    
    		foreach ( $user_ids as $id ) {
    			if ( ! current_user_can( 'edit_user', $id ) ) {
    				wp_die( __( 'Sorry, you are not allowed to edit this user.' ) );
    			}
    
    			if ( $id === $current_user->ID ) {
    				$update = 'err_admin_reset';
    				continue;
    			}
    
    			// Send the password reset link.
    			$user = get_userdata( $id );
    			if ( true === retrieve_password( $user->user_login ) ) {
    				++$reset_count;
    			}
    		}
    
    		$redirect = add_query_arg(
    			array(
    				'reset_count' => $reset_count,
    				'update'      => 'resetpassword',
    			),
    			$redirect
    		);
    		wp_redirect( $redirect );
    		exit;
    
    	case 'delete':
    		if ( is_multisite() ) {
    			wp_die( __( 'User deletion is not allowed from this screen.' ), 400 );
    		}
    
    		check_admin_referer( 'bulk-users' );
    
    		if ( empty( $_REQUEST['users'] ) && empty( $_REQUEST['user'] ) ) {
    			wp_redirect( $redirect );
    			exit;
    		}
    
    		if ( ! current_user_can( 'delete_users' ) ) {
    			$errors = new WP_Error( 'edit_users', __( 'Sorry, you are not allowed to delete users.' ) );
    		}
    
    		if ( empty( $_REQUEST['users'] ) ) {
    			$user_ids = array( (int) $_REQUEST['user'] );
    		} else {
    			$user_ids = array_map( 'intval', (array) $_REQUEST['users'] );
    		}
    
    		$all_user_ids = $user_ids;
    
    		if ( in_array( $current_user->ID, $user_ids, true ) ) {
    			$user_ids = array_diff( $user_ids, array( $current_user->ID ) );
    		}
    
    		/**
    		 * Filters whether the users being deleted have additional content
    		 * associated with them outside of the `post_author` and `link_owner` relationships.
    		 *
    		 * @since 5.2.0
    		 *
    		 * @param bool  $users_have_additional_content Whether the users have additional content. Default false.
    		 * @param int[] $user_ids                      Array of IDs for users being deleted.
    		 */
    		$users_have_content = (bool) apply_filters( 'users_have_additional_content', false, $user_ids );
    
    		if ( $user_ids && ! $users_have_content ) {
    			if ( $wpdb->get_var(
    				"SELECT ID FROM {$wpdb->posts}
    				WHERE post_author IN( " . implode( ',', $user_ids ) . ' )
    				LIMIT 1'
    			) ) {
    				$users_have_content = true;
    			} elseif ( $wpdb->get_var(
    				"SELECT link_id FROM {$wpdb->links}
    				WHERE link_owner IN( " . implode( ',', $user_ids ) . ' )
    				LIMIT 1'
    			) ) {
    				$users_have_content = true;
    			}
    		}
    
    		if ( $users_have_content ) {
    			add_action( 'admin_head', 'delete_users_add_js' );
    		}
    
    		require_once ABSPATH . 'wp-admin/admin-header.php';
    		?>
    		<form method="post" name="updateusers" id="updateusers">
    		<?php wp_nonce_field( 'delete-users' ); ?>
    		<?php echo $referer; ?>
    
    		<div class="wrap">
    		<h1><?php _e( 'Delete Users' ); ?></h1>
    
    		<?php
    		if ( isset( $_REQUEST['error'] ) ) :
    			wp_admin_notice(
    				'<strong>' . __( 'Error:' ) . '</strong> ' . __( 'Please select an option.' ),
    				array(
    					'additional_classes' => array( 'error' ),
    				)
    			);
    		endif;
    		?>
    
    		<?php if ( 1 === count( $all_user_ids ) ) : ?>
    			<p><?php _e( 'You have specified this user for deletion:' ); ?></p>
    		<?php else : ?>
    			<p><?php _e( 'You have specified these users for deletion:' ); ?></p>
    		<?php endif; ?>
    
    		<ul>
    		<?php
    		$go_delete = 0;
    
    		foreach ( $all_user_ids as $id ) {
    			$user = get_userdata( $id );
    
    			if ( $id === $current_user->ID ) {
    				echo '<li>';
    				printf(
    					/* translators: 1: User ID, 2: User login. */
    					__( 'ID #%1$s: %2$s <strong>The current user will not be deleted.</strong>' ),
    					$id,
    					$user->user_login
    				);
    				echo "</li>\n";
    			} else {
    				echo '<li>';
    				printf(
    					'<input type="hidden" name="users[]" value="%s" />',
    					esc_attr( $id )
    				);
    				printf(
    					/* translators: 1: User ID, 2: User login. */
    					__( 'ID #%1$s: %2$s' ),
    					$id,
    					$user->user_login
    				);
    				echo "</li>\n";
    
    				++$go_delete;
    			}
    		}
    		?>
    		</ul>
    
    		<?php
    		if ( $go_delete ) :
    
    			if ( ! $users_have_content ) :
    				?>
    				<input type="hidden" name="delete_option" value="delete" />
    			<?php else : ?>
    				<fieldset>
    				<?php if ( 1 === $go_delete ) : ?>
    					<p><legend><?php _e( 'What should be done with content owned by this user?' ); ?></legend></p>
    				<?php else : ?>
    					<p><legend><?php _e( 'What should be done with content owned by these users?' ); ?></legend></p>
    				<?php endif; ?>
    
    				<ul style="list-style:none;">
    					<li>
    						<input type="radio" id="delete_option0" name="delete_option" value="delete" />
    						<label for="delete_option0"><?php _e( 'Delete all content.' ); ?></label>
    					</li>
    					<li>
    						<input type="radio" id="delete_option1" name="delete_option" value="reassign" />
    						<label for="delete_option1"><?php _e( 'Attribute all content to:' ); ?></label>
    						<?php
    						wp_dropdown_users(
    							array(
    								'name'    => 'reassign_user',
    								'exclude' => $user_ids,
    								'show'    => 'display_name_with_login',
    							)
    						);
    						?>
    					</li>
    				</ul>
    				</fieldset>
    				<?php
    			endif;
    
    			/**
    			 * Fires at the end of the delete users form prior to the confirm button.
    			 *
    			 * @since 4.0.0
    			 * @since 4.5.0 The `$user_ids` parameter was added.
    			 *
    			 * @param WP_User $current_user WP_User object for the current user.
    			 * @param int[]   $user_ids     Array of IDs for users being deleted.
    			 */
    			do_action( 'delete_user_form', $current_user, $user_ids );
    			?>
    			<input type="hidden" name="action" value="dodelete" />
    			<?php submit_button( __( 'Confirm Deletion' ), 'primary' ); ?>
    
    		<?php else : ?>
    
    			<p><?php _e( 'There are no valid users selected for deletion.' ); ?></p>
    
    		<?php endif; ?>
    		</div><!-- .wrap -->
    		</form><!-- #updateusers -->
    		<?php
    
    		break;
    
    	case 'doremove':
    		check_admin_referer( 'remove-users' );
    
    		if ( ! is_multisite() ) {
    			wp_die( __( 'You cannot remove users.' ), 400 );
    		}
    
    		if ( empty( $_REQUEST['users'] ) ) {
    			wp_redirect( $redirect );
    			exit;
    		}
    
    		if ( ! current_user_can( 'remove_users' ) ) {
    			wp_die( __( 'Sorry, you are not allowed to remove users.' ), 403 );
    		}
    
    		$user_ids = array_map( 'intval', (array) $_REQUEST['users'] );
    		$update   = 'remove';
    
    		foreach ( $user_ids as $id ) {
    			if ( ! current_user_can( 'remove_user', $id ) ) {
    				$update = 'err_admin_remove';
    				continue;
    			}
    
    			remove_user_from_blog( $id, $blog_id );
    		}
    
    		$redirect = add_query_arg( array( 'update' => $update ), $redirect );
    		wp_redirect( $redirect );
    		exit;
    
    	case 'remove':
    		check_admin_referer( 'bulk-users' );
    
    		if ( ! is_multisite() ) {
    			wp_die( __( 'You cannot remove users.' ), 400 );
    		}
    
    		if ( empty( $_REQUEST['users'] ) && empty( $_REQUEST['user'] ) ) {
    			wp_redirect( $redirect );
    			exit;
    		}
    
    		if ( ! current_user_can( 'remove_users' ) ) {
    			$error = new WP_Error( 'edit_users', __( 'Sorry, you are not allowed to remove users.' ) );
    		}
    
    		if ( empty( $_REQUEST['users'] ) ) {
    			$user_ids = array( (int) $_REQUEST['user'] );
    		} else {
    			$user_ids = array_map( 'intval', (array) $_REQUEST['users'] );
    		}
    
    		require_once ABSPATH . 'wp-admin/admin-header.php';
    		?>
    		<form method="post" name="updateusers" id="updateusers">
    		<?php wp_nonce_field( 'remove-users' ); ?>
    		<?php echo $referer; ?>
    
    		<div class="wrap">
    		<h1><?php _e( 'Remove Users from Site' ); ?></h1>
    
    		<?php if ( 1 === count( $user_ids ) ) : ?>
    			<p><?php _e( 'You have specified this user for removal:' ); ?></p>
    		<?php else : ?>
    			<p><?php _e( 'You have specified these users for removal:' ); ?></p>
    		<?php endif; ?>
    
    		<ul>
    		<?php
    		$go_remove = false;
    
    		foreach ( $user_ids as $id ) {
    			$user = get_userdata( $id );
    
    			if ( ! current_user_can( 'remove_user', $id ) ) {
    				echo '<li>';
    				printf(
    					/* translators: 1: User ID, 2: User login. */
    					__( 'ID #%1$s: %2$s <strong>Sorry, you are not allowed to remove this user.</strong>' ),
    					$id,
    					$user->user_login
    				);
    				echo "</li>\n";
    			} else {
    				echo '<li>';
    				printf(
    					'<input type="hidden" name="users[]" value="%s" />',
    					esc_attr( $id )
    				);
    				printf(
    					/* translators: 1: User ID, 2: User login. */
    					__( 'ID #%1$s: %2$s' ),
    					$id,
    					$user->user_login
    				);
    				echo "</li>\n";
    
    				$go_remove = true;
    			}
    		}
    		?>
    		</ul>
    
    		<?php if ( $go_remove ) : ?>
    
    			<input type="hidden" name="action" value="doremove" />
    			<?php submit_button( __( 'Confirm Removal' ), 'primary' ); ?>
    
    		<?php else : ?>
    
    			<p><?php _e( 'There are no valid users selected for removal.' ); ?></p>
    
    		<?php endif; ?>
    		</div><!-- .wrap -->
    		</form><!-- #updateusers -->
    		<?php
    
    		break;
    
    	default:
    		if ( ! empty( $_GET['_wp_http_referer'] ) ) {
    			wp_redirect( remove_query_arg( array( '_wp_http_referer', '_wpnonce' ), wp_unslash( $_SERVER['REQUEST_URI'] ) ) );
    			exit;
    		}
    
    		if ( $wp_list_table->current_action() && ! empty( $_REQUEST['users'] ) ) {
    			$screen   = get_current_screen()->id;
    			$sendback = wp_get_referer();
    			$user_ids = array_map( 'intval', (array) $_REQUEST['users'] );
    
    			/** This action is documented in wp-admin/edit.php */
    			$sendback = apply_filters( "handle_bulk_actions-{$screen}", $sendback, $wp_list_table->current_action(), $user_ids ); // phpcs:ignore WordPress.NamingConventions.ValidHookName.UseUnderscores
    
    			wp_safe_redirect( $sendback );
    			exit;
    		}
    
    		$wp_list_table->prepare_items();
    		$total_pages = $wp_list_table->get_pagination_arg( 'total_pages' );
    
    		if ( $pagenum > $total_pages && $total_pages > 0 ) {
    			wp_redirect( add_query_arg( 'paged', $total_pages ) );
    			exit;
    		}
    
    		require_once ABSPATH . 'wp-admin/admin-header.php';
    
    		$messages = array();
    		if ( isset( $_GET['update'] ) ) :
    			switch ( $_GET['update'] ) {
    				case 'del':
    				case 'del_many':
    					$delete_count = isset( $_GET['delete_count'] ) ? (int) $_GET['delete_count'] : 0;
    					if ( 1 === $delete_count ) {
    						$message = __( 'User deleted.' );
    					} else {
    						/* translators: %s: Number of users. */
    						$message = _n( '%s user deleted.', '%s users deleted.', $delete_count );
    					}
    					$message    = sprintf( $message, number_format_i18n( $delete_count ) );
    					$messages[] = wp_get_admin_notice(
    						$message,
    						array(
    							'id'                 => 'message',
    							'additional_classes' => array( 'updated' ),
    							'dismissible'        => true,
    						)
    					);
    					break;
    				case 'add':
    					$message = __( 'New user created.' );
    					$user_id = isset( $_GET['id'] ) ? $_GET['id'] : false;
    					if ( $user_id && current_user_can( 'edit_user', $user_id ) ) {
    						$message .= sprintf(
    							' <a href="%1$s">%2$s</a>',
    							esc_url(
    								add_query_arg(
    									'wp_http_referer',
    									urlencode( wp_unslash( $_SERVER['REQUEST_URI'] ) ),
    									self_admin_url( 'user-edit.php?user_id=' . $user_id )
    								)
    							),
    							__( 'Edit user' )
    						);
    					}
    
    					$messages[] = wp_get_admin_notice(
    						$message,
    						array(
    							'id'                 => 'message',
    							'additional_classes' => array( 'updated' ),
    							'dismissible'        => true,
    						)
    					);
    					break;
    				case 'resetpassword':
    					$reset_count = isset( $_GET['reset_count'] ) ? (int) $_GET['reset_count'] : 0;
    					if ( 1 === $reset_count ) {
    						$message = __( 'Password reset link sent.' );
    					} else {
    						/* translators: %s: Number of users. */
    						$message = _n( 'Password reset links sent to %s user.', 'Password reset links sent to %s users.', $reset_count );
    					}
    					$message    = sprintf( $message, number_format_i18n( $reset_count ) );
    					$messages[] = wp_get_admin_notice(
    						$message,
    						array(
    							'id'                 => 'message',
    							'additional_classes' => array( 'updated' ),
    							'dismissible'        => true,
    						)
    					);
    					break;
    				case 'promote':
    					$messages[] = wp_get_admin_notice(
    						__( 'Changed roles.' ),
    						array(
    							'id'                 => 'message',
    							'additional_classes' => array( 'updated' ),
    							'dismissible'        => true,
    						)
    					);
    					break;
    				case 'err_admin_role':
    					$messages[] = wp_get_admin_notice(
    						__( 'The current user&#8217;s role must have user editing capabilities.' ),
    						array(
    							'id'                 => 'message',
    							'additional_classes' => array( 'error' ),
    							'dismissible'        => true,
    						)
    					);
    					$messages[] = wp_get_admin_notice(
    						__( 'Other user roles have been changed.' ),
    						array(
    							'id'                 => 'message',
    							'additional_classes' => array( 'updated' ),
    							'dismissible'        => true,
    						)
    					);
    					break;
    				case 'err_admin_del':
    					$messages[] = wp_get_admin_notice(
    						__( 'You cannot delete the current user.' ),
    						array(
    							'id'                 => 'message',
    							'additional_classes' => array( 'error' ),
    							'dismissible'        => true,
    						)
    					);
    					$messages[] = wp_get_admin_notice(
    						__( 'Other users have been deleted.' ),
    						array(
    							'id'                 => 'message',
    							'additional_classes' => array( 'updated' ),
    							'dismissible'        => true,
    						)
    					);
    					break;
    				case 'remove':
    					$messages[] = wp_get_admin_notice(
    						__( 'User removed from this site.' ),
    						array(
    							'id'                 => 'message',
    							'additional_classes' => array( 'updated', 'fade' ),
    							'dismissible'        => true,
    						)
    					);
    					break;
    				case 'err_admin_remove':
    					$messages[] = wp_get_admin_notice(
    						__( 'You cannot remove the current user.' ),
    						array(
    							'id'                 => 'message',
    							'additional_classes' => array( 'error' ),
    							'dismissible'        => true,
    						)
    					);
    					$messages[] = wp_get_admin_notice(
    						__( 'Other users have been removed.' ),
    						array(
    							'id'                 => 'message',
    							'additional_classes' => array( 'updated', 'fade' ),
    							'dismissible'        => true,
    						)
    					);
    					break;
    			}
    		endif;
    		?>
    
    		<?php
    		if ( isset( $errors ) && is_wp_error( $errors ) ) :
    			$error_message = '';
    			foreach ( $errors->get_error_messages() as $err ) {
    				$error_message .= "<li>$err</li>\n";
    			}
    			wp_admin_notice(
    				'<ul>' . $error_message . '</ul>',
    				array(
    					'additional_classes' => array( 'error' ),
    				)
    			);
    		endif;
    
    		if ( ! empty( $messages ) ) {
    			foreach ( $messages as $msg ) {
    				echo $msg;
    			}
    		}
    		?>
    
    		<div class="wrap">
    		<h1 class="wp-heading-inline">
    			<?php echo esc_html( $title ); ?>
    		</h1>
    
    		<?php
    		if ( current_user_can( 'create_users' ) ) {
    			printf(
    				'<a href="%1$s" class="page-title-action">%2$s</a>',
    				esc_url( admin_url( 'user-new.php' ) ),
    				esc_html__( 'Add New User' )
    			);
    		} elseif ( is_multisite() && current_user_can( 'promote_users' ) ) {
    			printf(
    				'<a href="%1$s" class="page-title-action">%2$s</a>',
    				esc_url( admin_url( 'user-new.php' ) ),
    				esc_html__( 'Add Existing User' )
    			);
    		}
    
    		if ( strlen( $usersearch ) ) {
    			echo '<span class="subtitle">';
    			printf(
    				/* translators: %s: Search query. */
    				__( 'Search results for: %s' ),
    				'<strong>' . esc_html( $usersearch ) . '</strong>'
    			);
    			echo '</span>';
    		}
    		?>
    
    		<hr class="wp-header-end">
    
    		<?php $wp_list_table->views(); ?>
    
    		<form method="get">
    
    		<?php $wp_list_table->search_box( __( 'Search Users' ), 'user' ); ?>
    
    		<?php if ( ! empty( $_REQUEST['role'] ) ) { ?>
    			<input type="hidden" name="role" value="<?php echo esc_attr( $_REQUEST['role'] ); ?>" />
    		<?php } ?>
    
    		<?php $wp_list_table->display(); ?>
    
    		</form>
    
    		<div class="clear"></div>
    		</div><!-- .wrap -->
    		<?php
    		break;
    
    } // End of the $doaction switch.
    
    require_once ABSPATH . 'wp-admin/admin-footer.php';
    
    Upload File: