From 2f7ae2bff704fd3208c8dab4f014f5437fb8f2a6 Mon Sep 17 00:00:00 2001 From: vasikgreif Date: Fri, 8 Jan 2021 14:25:18 +0100 Subject: [PATCH 1/3] WP Code Style --- src/Metaboxes.php | 268 +++++++++++++++++++++++++++------------------- 1 file changed, 160 insertions(+), 108 deletions(-) diff --git a/src/Metaboxes.php b/src/Metaboxes.php index a77bf26..9ae6a3c 100644 --- a/src/Metaboxes.php +++ b/src/Metaboxes.php @@ -25,7 +25,6 @@ public function __construct( Plugin $loader ) { * TODO: find a way to add custom post types */ public function page_metaboxes() { - $ssc_group = new Group(); $groups = $ssc_group->get_groups(); $ssc_access = $this->loader->get_access(); @@ -36,46 +35,60 @@ public function page_metaboxes() { /** * Initiate the metabox */ - $cmb = new_cmb2_box( [ - 'id' => 'ssc_page_groups', - 'title' => __( 'SimpleShop - Member sections', 'simpleshop-cz' ), - 'object_types' => $post_types, - 'context' => 'normal', - 'priority' => 'high', - 'show_names' => true, - ] ); - - $cmb->add_field( [ - 'name' => __( 'Member section with allowed access to page', 'simpleshop-cz' ), - 'desc' => __( 'Access to this page is permit only for users of selected Member Sections. If no one section selected, all users is permit to access this page.', - 'simpleshop-cz' ), - 'id' => $this->prefix . 'groups', - 'type' => 'multicheck', - 'options' => $groups, - ] ); + $cmb = new_cmb2_box( + [ + 'id' => 'ssc_page_groups', + 'title' => __( 'SimpleShop - Member sections', 'simpleshop-cz' ), + 'object_types' => $post_types, + 'context' => 'normal', + 'priority' => 'high', + 'show_names' => true, + ] + ); + + $cmb->add_field( + [ + 'name' => __( 'Member section with allowed access to page', 'simpleshop-cz' ), + 'desc' => __( + 'Access to this page is permit only for users of selected Member Sections. If no one section selected, all users is permit to access this page.', + 'simpleshop-cz' + ), + 'id' => $this->prefix . 'groups', + 'type' => 'multicheck', + 'options' => $groups, + ] + ); $tmp_post_types = $post_types; unset( $tmp_post_types['attachment'] ); - $cmb->add_field( [ - 'name' => __( 'Page ID to redirect', 'simpleshop-cz' ), - 'desc' => __( 'Select one Page to which user will be redirected when uses is logged in, but have no access to page. This is preffered way. Redirect will works even if target page URL will be changer in future.', - 'simpleshop-cz' ), - 'id' => $this->prefix . 'no_access_redirect_post_id', - 'type' => 'post_search_text', - 'select_type' => 'radio', - 'select_behavior' => 'replace', - 'post_type' => $tmp_post_types - ] ); - - - $cmb->add_field( [ - 'name' => __( 'Manual URL to redirect', 'simpleshop-cz' ), - 'desc' => __( 'Put URL to which user will be redirected when uses is logged in, but have no access to page. If you want to use this method, keep previous field empty.', - 'simpleshop-cz' ), - 'id' => $this->prefix . 'no_access_redirect', - 'type' => 'text' - ] ); + $cmb->add_field( + [ + 'name' => __( 'Page ID to redirect', 'simpleshop-cz' ), + 'desc' => __( + 'Select one Page to which user will be redirected when uses is logged in, but have no access to page. This is preffered way. Redirect will works even if target page URL will be changer in future.', + 'simpleshop-cz' + ), + 'id' => $this->prefix . 'no_access_redirect_post_id', + 'type' => 'post_search_text', + 'select_type' => 'radio', + 'select_behavior' => 'replace', + 'post_type' => $tmp_post_types, + ] + ); + + + $cmb->add_field( + [ + 'name' => __( 'Manual URL to redirect', 'simpleshop-cz' ), + 'desc' => __( + 'Put URL to which user will be redirected when uses is logged in, but have no access to page. If you want to use this method, keep previous field empty.', + 'simpleshop-cz' + ), + 'id' => $this->prefix . 'no_access_redirect', + 'type' => 'text', + ] + ); // $cmb->add_field(array( // 'name' => __('Přesměrovat na přihlášení', 'ssc'), @@ -85,47 +98,67 @@ public function page_metaboxes() { // )); - $cmb->add_field( [ - 'name' => __( 'Delay access to content (days from group assign)', 'simpleshop-cz' ), - 'desc' => __( 'Put number of days to delay before access to content is allowed after registration. For example: If registration to group is at January 1st and you set delay to 5 days, user get access to content from January 6th.', - 'simpleshop-cz' ), - 'id' => $this->prefix . 'days_to_access', - 'type' => 'text' - ] ); - - $cmb->add_field( [ - 'name' => __( 'Allow access from date', 'simpleshop-cz' ), - 'desc' => __( 'Put date which will be access to content allowed (applied to all groups)', - 'simpleshop-cz' ), - 'id' => $this->prefix . 'date_to_access', - 'type' => 'text_date', - 'date_format' => 'Y-m-d', - ] ); - - $cmb->add_field( [ - 'name' => __( 'Allow access to date', 'simpleshop-cz' ), - 'desc' => __( 'Put date until will be access to content allowed (applied to all groups)', - 'simpleshop-cz' ), - 'id' => $this->prefix . 'date_until_to_access', - 'type' => 'text_date', - 'date_format' => 'Y-m-d', - ] ); - - $cmb->add_field( [ - 'name' => __( 'Subject of email when content access allowed', 'simpleshop-cz' ), - 'desc' => __( 'Enter the subject of the email that will automatically be sent to the user when gains access to this content based on the days set above.', - 'simpleshop-cz' ), - 'id' => $this->prefix . 'email_subject_user_can_access', - 'type' => 'text' - ] ); - - $cmb->add_field( [ - 'name' => __( 'Email message when content access allowed', 'simpleshop-cz' ), - 'desc' => __( 'Enter an email that will automatically be sent to the user when gains access to this content based on the days set above.', - 'simpleshop-cz' ), - 'id' => $this->prefix . 'email_user_can_access', - 'type' => 'wysiwyg' - ] ); + $cmb->add_field( + [ + 'name' => __( 'Delay access to content (days from group assign)', 'simpleshop-cz' ), + 'desc' => __( + 'Put number of days to delay before access to content is allowed after registration. For example: If registration to group is at January 1st and you set delay to 5 days, user get access to content from January 6th.', + 'simpleshop-cz' + ), + 'id' => $this->prefix . 'days_to_access', + 'type' => 'text', + ] + ); + + $cmb->add_field( + [ + 'name' => __( 'Allow access from date', 'simpleshop-cz' ), + 'desc' => __( + 'Put date which will be access to content allowed (applied to all groups)', + 'simpleshop-cz' + ), + 'id' => $this->prefix . 'date_to_access', + 'type' => 'text_date', + 'date_format' => 'Y-m-d', + ] + ); + + $cmb->add_field( + [ + 'name' => __( 'Allow access to date', 'simpleshop-cz' ), + 'desc' => __( + 'Put date until will be access to content allowed (applied to all groups)', + 'simpleshop-cz' + ), + 'id' => $this->prefix . 'date_until_to_access', + 'type' => 'text_date', + 'date_format' => 'Y-m-d', + ] + ); + + $cmb->add_field( + [ + 'name' => __( 'Subject of email when content access allowed', 'simpleshop-cz' ), + 'desc' => __( + 'Enter the subject of the email that will automatically be sent to the user when gains access to this content based on the days set above.', + 'simpleshop-cz' + ), + 'id' => $this->prefix . 'email_subject_user_can_access', + 'type' => 'text', + ] + ); + + $cmb->add_field( + [ + 'name' => __( 'Email message when content access allowed', 'simpleshop-cz' ), + 'desc' => __( + 'Enter an email that will automatically be sent to the user when gains access to this content based on the days set above.', + 'simpleshop-cz' + ), + 'id' => $this->prefix . 'email_user_can_access', + 'type' => 'wysiwyg', + ] + ); } } @@ -133,18 +166,19 @@ public function page_metaboxes() { * Add metabox to user profile */ public function user_metaboxes() { - /** * Initiate the metabox */ - $cmb = new_cmb2_box( [ - 'id' => 'ssc_user_groups', - 'title' => __( 'SimpleShop', 'simpleshop-cz' ), - 'object_types' => [ 'user' ], - 'context' => 'normal', - 'priority' => 'high', - 'show_names' => true, - ] ); + $cmb = new_cmb2_box( + [ + 'id' => 'ssc_user_groups', + 'title' => __( 'SimpleShop', 'simpleshop-cz' ), + 'object_types' => [ 'user' ], + 'context' => 'normal', + 'priority' => 'high', + 'show_names' => true, + ] + ); $ssc_group = new Group(); $groups = $ssc_group->get_groups(); @@ -153,30 +187,48 @@ public function user_metaboxes() { $access = $this->loader->get_access(); if ( $access->user_is_admin() ) { - $cmb->add_field( [ - 'name' => __( 'SimpleShop - member sections
Choose which member sections the user should have access to.', - 'simpleshop-cz' ), + $cmb->add_field( + [ + 'name' => __( + 'SimpleShop - member sections
Choose which member sections the user should have access to.', + 'simpleshop-cz' + ), // 'desc' => __('Vyberte, do kterých členských sekcí má mít uživatel přístup','ssc'), - 'id' => $this->prefix . 'user_groups', - 'type' => 'multicheck', - 'options' => $groups, - ] ); + 'id' => $this->prefix . 'user_groups', + 'type' => 'multicheck', + 'options' => $groups, + ] + ); foreach ( $groups as $key => $group ) { - $cmb->add_field( [ - 'name' => '' . sprintf( __( 'Registration date to group %s.', - 'simpleshop-cz' ), $group ) . '', - 'id' => $this->prefix . 'group_subscription_date_' . $key, - 'type' => 'text_date', - 'date_format' => 'Y-m-d', - ] ); - $cmb->add_field( [ - 'name' => '' . sprintf( __( 'Expiration date of registration to group %s.', - 'simpleshop-cz' ), $group ) . '', - 'id' => $this->prefix . 'group_subscription_valid_to_' . $key, - 'type' => 'text_date', - 'date_format' => 'Y-m-d', - ] ); + $cmb->add_field( + [ + 'name' => '' . sprintf( + __( + 'Registration date to group %s.', + 'simpleshop-cz' + ), + $group + ) . '', + 'id' => $this->prefix . 'group_subscription_date_' . $key, + 'type' => 'text_date', + 'date_format' => 'Y-m-d', + ] + ); + $cmb->add_field( + [ + 'name' => '' . sprintf( + __( + 'Expiration date of registration to group %s.', + 'simpleshop-cz' + ), + $group + ) . '', + 'id' => $this->prefix . 'group_subscription_valid_to_' . $key, + 'type' => 'text_date', + 'date_format' => 'Y-m-d', + ] + ); } } } From e9990420cbfa583d78abe93c30ac3ffe7808f7db Mon Sep 17 00:00:00 2001 From: vasikgreif Date: Fri, 8 Jan 2021 14:52:52 +0100 Subject: [PATCH 2/3] Save the edited values --- src/Membership.php | 4 +- src/Metaboxes.php | 150 ++++++++++++++++++++++++++------------------- 2 files changed, 90 insertions(+), 64 deletions(-) diff --git a/src/Membership.php b/src/Membership.php index ae0454e..b700a06 100644 --- a/src/Membership.php +++ b/src/Membership.php @@ -30,13 +30,13 @@ public function __construct( $user_id = '' ) { */ public function get() { $ssc_groups = new Group(); - $groups = $ssc_groups->get_user_groups( $this->user_id ); + $groups = $ssc_groups->get_user_groups( $this->user_id ) ?: []; foreach ( $groups as $group ) { $this->groups[ $group ] = [ 'group_id' => $group, 'subscription_date' => $this->get_subscription_date( $group ), - 'valid_to' => $this->get_valid_to( $group ) + 'valid_to' => $this->get_valid_to( $group ), ]; } } diff --git a/src/Metaboxes.php b/src/Metaboxes.php index 9ae6a3c..134fd72 100644 --- a/src/Metaboxes.php +++ b/src/Metaboxes.php @@ -8,6 +8,8 @@ namespace Redbit\SimpleShop\WpPlugin; +use WP_User; + class Metaboxes { public $prefix = '_ssc_'; @@ -17,7 +19,10 @@ class Metaboxes { public function __construct( Plugin $loader ) { $this->loader = $loader; add_action( 'cmb2_admin_init', [ $this, 'page_metaboxes' ] ); - add_action( 'cmb2_admin_init', [ $this, 'user_metaboxes' ] ); + add_action( 'show_user_profile', [ $this, 'render_user_profile_groups' ] ); + add_action( 'edit_user_profile', [ $this, 'render_user_profile_groups' ] ); + add_action( 'personal_options_update', [ $this, 'save_user_profile_groups' ] ); + add_action( 'edit_user_profile_update', [ $this, 'save_user_profile_groups' ] ); } /** @@ -163,73 +168,94 @@ public function page_metaboxes() { } /** - * Add metabox to user profile + * Add groups table to user profile + * + * @param WP_User $user WP User */ - public function user_metaboxes() { - /** - * Initiate the metabox - */ - $cmb = new_cmb2_box( - [ - 'id' => 'ssc_user_groups', - 'title' => __( 'SimpleShop', 'simpleshop-cz' ), - 'object_types' => [ 'user' ], - 'context' => 'normal', - 'priority' => 'high', - 'show_names' => true, - ] - ); - - $ssc_group = new Group(); - $groups = $ssc_group->get_groups(); + public function render_user_profile_groups( $user ) { + $ssc_group = new Group(); + $groups = $ssc_group->get_groups(); + $membership = new Membership( $user->ID ); + $access = $this->loader->get_access(); ?> + + + + + + +
+ + + + + + + + + + + + + $group_name ) { ?> + + + + + + + + +
+ user_is_admin() ) { ?> + groups ), true ); ?>/> + groups ) ? __( 'Yes', 'simpleshop-cz' ) : __( 'No', 'simpleshop-cz' ); + } ?> + + user_is_admin() ) { ?> + + ID, $this->prefix . 'group_subscription_date_' . $group_id, true ); + } ?> + + user_is_admin() ) { ?> + + ID, $this->prefix . 'group_subscription_valid_to_' . $group_id, true ); + } ?> +
+
+ loader->get_access(); + if ( ! $access->user_is_admin() ) { + return; + } - if ( $access->user_is_admin() ) { - $cmb->add_field( - [ - 'name' => __( - 'SimpleShop - member sections
Choose which member sections the user should have access to.', - 'simpleshop-cz' - ), -// 'desc' => __('Vyberte, do kterých členských sekcí má mít uživatel přístup','ssc'), - 'id' => $this->prefix . 'user_groups', - 'type' => 'multicheck', - 'options' => $groups, - ] - ); - - foreach ( $groups as $key => $group ) { - $cmb->add_field( - [ - 'name' => '' . sprintf( - __( - 'Registration date to group %s.', - 'simpleshop-cz' - ), - $group - ) . '', - 'id' => $this->prefix . 'group_subscription_date_' . $key, - 'type' => 'text_date', - 'date_format' => 'Y-m-d', - ] - ); - $cmb->add_field( - [ - 'name' => '' . sprintf( - __( - 'Expiration date of registration to group %s.', - 'simpleshop-cz' - ), - $group - ) . '', - 'id' => $this->prefix . 'group_subscription_valid_to_' . $key, - 'type' => 'text_date', - 'date_format' => 'Y-m-d', - ] - ); + $groups = []; + foreach ( $_POST['ssc_groups'] as $group_id => $group ) { + if ( ! empty( $group['is_member'] ) && $group['is_member'] ) { + $groups[] = $group_id; + if ( empty( $group['subscription_date'] ) ) { + $group['subscription_date'] = date( 'Y-m-d' ); + } } + + update_user_meta( $user_id, $this->prefix . 'user_groups', $groups ); + update_user_meta( $user_id, $this->prefix . 'group_subscription_date_' . $group_id, empty( $group['subscription_date'] ) ? '' : date( 'Y-m-d', strtotime( $group['subscription_date'] ) ) ); + update_user_meta( $user_id, $this->prefix . 'group_subscription_valid_to_' . $group_id, empty( $group['subscription_valid_to'] ) ? '' : date( 'Y-m-d', strtotime( $group['subscription_valid_to'] ) ) ); } } } From 60a3de97c9448d1b61ce3822f0d35fa266741eac Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Jakub=20Bouc=CC=8Cek?= Date: Mon, 18 Jan 2021 14:10:12 +0100 Subject: [PATCH 3/3] Fix code style (SP -> TAB) --- src/Access.php | 10 +++---- src/Admin.php | 36 +++++++++++----------- src/Metaboxes.php | 76 +++++++++++++++++++++++------------------------ src/Settings.php | 24 +++++++-------- 4 files changed, 73 insertions(+), 73 deletions(-) diff --git a/src/Access.php b/src/Access.php index f9ae737..8de0176 100644 --- a/src/Access.php +++ b/src/Access.php @@ -388,11 +388,11 @@ public function setup_nav_menu_item( $item ) { */ public function hide_menu_items() { ?> - + post_type == $mg_post_type ) { echo ''; + .misc-pub-section.misc-pub-visibility, + .misc-pub-section.curtime + { + display:none; + } + '; } ?> - - + get_groups(); $membership = new Membership( $user->ID ); $access = $this->loader->get_access(); ?> - - - - - +
- - - - - - - - - + +
+ + + - -
+ + + + + + + + + - - - + + + $group_name ) { ?> - - - + + - + - + - + + - -
+
user_is_admin() ) { ?> - groups ), true ); ?>/> + groups ), true ); ?>/> groups ) ? __( 'Yes', 'simpleshop-cz' ) : __( 'No', 'simpleshop-cz' ); } ?> - + user_is_admin() ) { ?> - + ID, $this->prefix . 'group_subscription_date_' . $group_id, true ); } ?> - + user_is_admin() ) { ?> - + ID, $this->prefix . 'group_subscription_valid_to_' . $group_id, true ); } ?> -
-
+
+ + + ' - . _e( 'Disconnect Simple Shop', 'simpleshop-cz' ) - . ''; + . _e( 'Disconnect Simple Shop', 'simpleshop-cz' ) + . ''; } /** @@ -128,10 +128,10 @@ public function add_options_page() { */ public function admin_page_display() { ?> -
-

+
+

metabox_id, $this->key ); ?> -
+
__( 'Email message', 'simpleshop-cz' ), 'desc' => __( 'Povolené zástupné znaky:
' - . '
{login} = login
' - . '{password} = heslo
' - . '{login_url} = adresa, na které je možné se přihlásit
' - . '{pages} = seznam stránek, do kterých má uživatel zakoupený přístup
' - . '{mail} = e-mail uživatele (většinou stejný jako login)
' - . '
' - . '', 'simpleshop-cz' ), + . '
{login} = login
' + . '{password} = heslo
' + . '{login_url} = adresa, na které je možné se přihlásit
' + . '{pages} = seznam stránek, do kterých má uživatel zakoupený přístup
' + . '{mail} = e-mail uživatele (většinou stejný jako login)
' + . '
' + . '', 'simpleshop-cz' ), 'id' => 'ssc_email_text', 'type' => 'wysiwyg', 'classes_cb' => [ $this, 'hide_when_invalid_keys' ],