/** * WooCommerce Account Functions * * Functions for account specific things. * * @package WooCommerce\Functions * @version 2.6.0 */ use Automattic\WooCommerce\Enums\OrderStatus; defined( 'ABSPATH' ) || exit; /** * Returns the url to the lost password endpoint url. * * @param string $default_url Default lost password URL. * @return string */ function wc_lostpassword_url( $default_url = '' ) { // Avoid loading too early. if ( ! did_action( 'init' ) ) { return $default_url; } // Don't change the admin form. if ( did_action( 'login_form_login' ) ) { return $default_url; } // Don't redirect to the woocommerce endpoint on global network admin lost passwords. if ( is_multisite() && isset( $_GET['redirect_to'] ) && false !== strpos( wp_unslash( $_GET['redirect_to'] ), network_admin_url() ) ) { // WPCS: input var ok, sanitization ok, CSRF ok. return $default_url; } $wc_account_page_url = wc_get_page_permalink( 'myaccount' ); $wc_account_page_exists = wc_get_page_id( 'myaccount' ) > 0; $lost_password_endpoint = get_option( 'woocommerce_myaccount_lost_password_endpoint' ); if ( $wc_account_page_exists && ! empty( $lost_password_endpoint ) ) { return wc_get_endpoint_url( $lost_password_endpoint, '', $wc_account_page_url ); } else { return $default_url; } } add_filter( 'lostpassword_url', 'wc_lostpassword_url', 10, 1 ); /** * Get the link to the edit account details page. * * @return string */ function wc_customer_edit_account_url() { $edit_account_url = wc_get_endpoint_url( 'edit-account', '', wc_get_page_permalink( 'myaccount' ) ); return apply_filters( 'woocommerce_customer_edit_account_url', $edit_account_url ); } /** * Get the edit address slug translation. * * @param string $id Address ID. * @param bool $flip Flip the array to make it possible to retrieve the values ​​from both sides. * * @return string Address slug i18n. */ function wc_edit_address_i18n( $id, $flip = false ) { $slugs = apply_filters( 'woocommerce_edit_address_slugs', array( 'billing' => sanitize_title( _x( 'billing', 'edit-address-slug', 'woocommerce' ) ), 'shipping' => sanitize_title( _x( 'shipping', 'edit-address-slug', 'woocommerce' ) ), ) ); if ( $flip ) { $slugs = array_flip( $slugs ); } if ( ! isset( $slugs[ $id ] ) ) { return $id; } return $slugs[ $id ]; } /** * Get My Account menu items. * * @since 2.6.0 * @return array */ function wc_get_account_menu_items() { $endpoints = array( 'orders' => get_option( 'woocommerce_myaccount_orders_endpoint', 'orders' ), 'downloads' => get_option( 'woocommerce_myaccount_downloads_endpoint', 'downloads' ), 'edit-address' => get_option( 'woocommerce_myaccount_edit_address_endpoint', 'edit-address' ), 'payment-methods' => get_option( 'woocommerce_myaccount_payment_methods_endpoint', 'payment-methods' ), 'edit-account' => get_option( 'woocommerce_myaccount_edit_account_endpoint', 'edit-account' ), 'customer-logout' => get_option( 'woocommerce_logout_endpoint', 'customer-logout' ), ); $items = array( 'dashboard' => __( 'Dashboard', 'woocommerce' ), 'orders' => __( 'Orders', 'woocommerce' ), 'downloads' => __( 'Downloads', 'woocommerce' ), 'edit-address' => _n( 'Address', 'Addresses', ( 1 + (int) wc_shipping_enabled() ), 'woocommerce' ), 'payment-methods' => __( 'Payment methods', 'woocommerce' ), 'edit-account' => __( 'Account details', 'woocommerce' ), 'customer-logout' => __( 'Log out', 'woocommerce' ), ); // Remove missing endpoints. foreach ( $endpoints as $endpoint_id => $endpoint ) { if ( empty( $endpoint ) ) { unset( $items[ $endpoint_id ] ); } } // Check if payment gateways support add new payment methods. if ( isset( $items['payment-methods'] ) ) { $support_payment_methods = false; foreach ( WC()->payment_gateways->get_available_payment_gateways() as $gateway ) { if ( $gateway->supports( 'add_payment_method' ) || $gateway->supports( 'tokenization' ) ) { $support_payment_methods = true; break; } } if ( ! $support_payment_methods ) { unset( $items['payment-methods'] ); } } return apply_filters( 'woocommerce_account_menu_items', $items, $endpoints ); } /** * Find current item in account menu. * * @since 9.3.0 * @param string $endpoint Endpoint. * @return bool */ function wc_is_current_account_menu_item( $endpoint ) { global $wp; $current = isset( $wp->query_vars[ $endpoint ] ); if ( 'dashboard' === $endpoint && ( isset( $wp->query_vars['page'] ) || empty( $wp->query_vars ) ) ) { $current = true; // Dashboard is not an endpoint, so needs a custom check. } elseif ( 'orders' === $endpoint && isset( $wp->query_vars['view-order'] ) ) { $current = true; // When looking at individual order, highlight Orders list item (to signify where in the menu the user currently is). } elseif ( 'payment-methods' === $endpoint && isset( $wp->query_vars['add-payment-method'] ) ) { $current = true; } return $current; } /** * Get account menu item classes. * * @since 2.6.0 * @param string $endpoint Endpoint. * @return string */ function wc_get_account_menu_item_classes( $endpoint ) { $classes = array( 'woocommerce-MyAccount-navigation-link', 'woocommerce-MyAccount-navigation-link--' . $endpoint, ); if ( wc_is_current_account_menu_item( $endpoint ) ) { $classes[] = 'is-active'; } $classes = apply_filters( 'woocommerce_account_menu_item_classes', $classes, $endpoint ); return implode( ' ', array_map( 'sanitize_html_class', $classes ) ); } /** * Get account endpoint URL. * * @since 2.6.0 * @param string $endpoint Endpoint. * @return string */ function wc_get_account_endpoint_url( $endpoint ) { if ( 'dashboard' === $endpoint ) { return wc_get_page_permalink( 'myaccount' ); } $url = wc_get_endpoint_url( $endpoint, '', wc_get_page_permalink( 'myaccount' ) ); if ( 'customer-logout' === $endpoint ) { return wp_nonce_url( $url, 'customer-logout' ); } return $url; } /** * Get My Account > Orders columns. * * @since 2.6.0 * @return array */ function wc_get_account_orders_columns() { /** * Filters the array of My Account > Orders columns. * * @since 2.6.0 * @param array $columns Array of column labels keyed by column IDs. */ return apply_filters( 'woocommerce_account_orders_columns', array( 'order-number' => __( 'Order', 'woocommerce' ), 'order-date' => __( 'Date', 'woocommerce' ), 'order-status' => __( 'Status', 'woocommerce' ), 'order-total' => __( 'Total', 'woocommerce' ), 'order-actions' => __( 'Actions', 'woocommerce' ), ) ); } /** * Get My Account > Downloads columns. * * @since 2.6.0 * @return array */ function wc_get_account_downloads_columns() { $columns = apply_filters( 'woocommerce_account_downloads_columns', array( 'download-product' => __( 'Product', 'woocommerce' ), 'download-remaining' => __( 'Downloads remaining', 'woocommerce' ), 'download-expires' => __( 'Expires', 'woocommerce' ), 'download-file' => __( 'Download', 'woocommerce' ), 'download-actions' => ' ', ) ); if ( ! has_filter( 'woocommerce_account_download_actions' ) ) { unset( $columns['download-actions'] ); } return $columns; } /** * Get My Account > Payment methods columns. * * @since 2.6.0 * @return array */ function wc_get_account_payment_methods_columns() { return apply_filters( 'woocommerce_account_payment_methods_columns', array( 'method' => __( 'Method', 'woocommerce' ), 'expires' => __( 'Expires', 'woocommerce' ), 'actions' => ' ', ) ); } /** * Get My Account > Payment methods types * * @since 2.6.0 * @return array */ function wc_get_account_payment_methods_types() { return apply_filters( 'woocommerce_payment_methods_types', array( 'cc' => __( 'Credit card', 'woocommerce' ), 'echeck' => __( 'eCheck', 'woocommerce' ), ) ); } /** * Get account orders actions. * * @since 3.2.0 * @param int|WC_Order $order Order instance or ID. * @return array */ function wc_get_account_orders_actions( $order ) { if ( ! is_object( $order ) ) { $order_id = absint( $order ); $order = wc_get_order( $order_id ); } $actions = array( 'pay' => array( 'url' => $order->get_checkout_payment_url(), 'name' => __( 'Pay', 'woocommerce' ), /* translators: %s: order number */ 'aria-label' => sprintf( __( 'Pay for order %s', 'woocommerce' ), $order->get_order_number() ), ), 'view' => array( 'url' => $order->get_view_order_url(), 'name' => __( 'View', 'woocommerce' ), /* translators: %s: order number */ 'aria-label' => sprintf( __( 'View order %s', 'woocommerce' ), $order->get_order_number() ), ), 'cancel' => array( 'url' => $order->get_cancel_order_url( wc_get_page_permalink( 'myaccount' ) ), 'name' => __( 'Cancel', 'woocommerce' ), /* translators: %s: order number */ 'aria-label' => sprintf( __( 'Cancel order %s', 'woocommerce' ), $order->get_order_number() ), ), ); if ( ! $order->needs_payment() ) { unset( $actions['pay'] ); } /** * Filters the valid order statuses for cancel action. * * @since 3.2.0 * * @param array $statuses_for_cancel Array of valid order statuses for cancel action. * @param WC_Order $order Order instance. */ $statuses_for_cancel = apply_filters( 'woocommerce_valid_order_statuses_for_cancel', array( OrderStatus::PENDING, OrderStatus::FAILED ), $order ); if ( ! in_array( $order->get_status(), $statuses_for_cancel, true ) ) { unset( $actions['cancel'] ); } return apply_filters( 'woocommerce_my_account_my_orders_actions', $actions, $order ); } /** * Get account formatted address. * * @since 3.2.0 * @param string $address_type Type of address; 'billing' or 'shipping'. * @param int $customer_id Customer ID. * Defaults to 0. * @return string */ function wc_get_account_formatted_address( $address_type = 'billing', $customer_id = 0 ) { $getter = "get_{$address_type}"; $address = array(); if ( 0 === $customer_id ) { $customer_id = get_current_user_id(); } $customer = new WC_Customer( $customer_id ); if ( is_callable( array( $customer, $getter ) ) ) { $address = $customer->$getter(); unset( $address['email'], $address['tel'] ); } return WC()->countries->get_formatted_address( apply_filters( 'woocommerce_my_account_my_address_formatted_address', $address, $customer->get_id(), $address_type ) ); } /** * Returns an array of a user's saved payments list for output on the account tab. * * @since 2.6 * @param array $list List of payment methods passed from wc_get_customer_saved_methods_list(). * @param int $customer_id The customer to fetch payment methods for. * @return array Filtered list of customers payment methods. */ function wc_get_account_saved_payment_methods_list( $list, $customer_id ) { $payment_tokens = WC_Payment_Tokens::get_customer_tokens( $customer_id ); foreach ( $payment_tokens as $payment_token ) { $delete_url = wc_get_endpoint_url( 'delete-payment-method', $payment_token->get_id() ); $delete_url = wp_nonce_url( $delete_url, 'delete-payment-method-' . $payment_token->get_id() ); $set_default_url = wc_get_endpoint_url( 'set-default-payment-method', $payment_token->get_id() ); $set_default_url = wp_nonce_url( $set_default_url, 'set-default-payment-method-' . $payment_token->get_id() ); $type = strtolower( $payment_token->get_type() ); $list[ $type ][] = array( 'method' => array( 'gateway' => $payment_token->get_gateway_id(), ), 'expires' => esc_html__( 'N/A', 'woocommerce' ), 'is_default' => $payment_token->is_default(), 'actions' => array( 'delete' => array( 'url' => $delete_url, 'name' => esc_html__( 'Delete', 'woocommerce' ), ), ), ); $key = key( array_slice( $list[ $type ], -1, 1, true ) ); if ( ! $payment_token->is_default() ) { $list[ $type ][ $key ]['actions']['default'] = array( 'url' => $set_default_url, 'name' => esc_html__( 'Make default', 'woocommerce' ), ); } $list[ $type ][ $key ] = apply_filters( 'woocommerce_payment_methods_list_item', $list[ $type ][ $key ], $payment_token ); } return $list; } add_filter( 'woocommerce_saved_payment_methods_list', 'wc_get_account_saved_payment_methods_list', 10, 2 ); /** * Controls the output for credit cards on the my account page. * * @since 2.6 * @param array $item Individual list item from woocommerce_saved_payment_methods_list. * @param WC_Payment_Token $payment_token The payment token associated with this method entry. * @return array Filtered item. */ function wc_get_account_saved_payment_methods_list_item_cc( $item, $payment_token ) { if ( 'cc' !== strtolower( $payment_token->get_type() ) ) { return $item; } $card_type = $payment_token->get_card_type(); $item['method']['last4'] = $payment_token->get_last4(); $item['method']['brand'] = ( ! empty( $card_type ) ? ucwords( str_replace( '_', ' ', $card_type ) ) : esc_html__( 'Credit card', 'woocommerce' ) ); $item['expires'] = $payment_token->get_expiry_month() . '/' . substr( $payment_token->get_expiry_year(), -2 ); return $item; } add_filter( 'woocommerce_payment_methods_list_item', 'wc_get_account_saved_payment_methods_list_item_cc', 10, 2 ); /** * Controls the output for eChecks on the my account page. * * @since 2.6 * @param array $item Individual list item from woocommerce_saved_payment_methods_list. * @param WC_Payment_Token $payment_token The payment token associated with this method entry. * @return array Filtered item. */ function wc_get_account_saved_payment_methods_list_item_echeck( $item, $payment_token ) { if ( 'echeck' !== strtolower( $payment_token->get_type() ) ) { return $item; } $item['method']['last4'] = $payment_token->get_last4(); $item['method']['brand'] = esc_html__( 'eCheck', 'woocommerce' ); return $item; } add_filter( 'woocommerce_payment_methods_list_item', 'wc_get_account_saved_payment_methods_list_item_echeck', 10, 2 ); Онлайн -казино в Зума казино Интернете бесплатно – 3B OF SLk

Онлайн -казино в Зума казино Интернете бесплатно

Интернет-казино он-лайн без затрат на игры казино выкладывают участников захватывающим и начинаю убедительный опыт без какого-либо потенциала отсутствия реальных денег. Они также могут опробовать совершенно новые названия без напряжения, связанного с экономическими инвестициями.

В интернет -казино приводят деньги, используя свои онлайн -игры в маркетинге и рекламе цифровых зарубежных за рубежом для своих участников. Тем не менее, дефицит реального рыночного вознаграждения вполне может сбросить свадьбу.

Слоты

Слот -игровые автоматы для азартных игр без затрат не являются отличным способом для совершенно новых участников, если вам нужно экспериментировать с подходами девушки без вознаграждения от фактических денег. Следующие онлайн -игры помогают людям испытать принципы различных видеоигр интернет -казино и начинать методы происхождения в прошлом, сталкиваясь на реальных деньгах. Кроме того, они предлагают возможность выяснить, какие разновидности наслаждаются, как правило, почти все привлекательны для участников, независимо от того, выбирают ли они не солатильность игр с битом, победными, видеоигры с высокой волатильностью, тем не менее, являются победами, или более продвинуты

Огромное количество азартных домов в Интернете попадает в участников, используя несколько игровых онлайн -игр, которые можно получить, что делает его возможным для человека, чтобы прийти к тому, что всем нравится. Зума казино заручает клиентам хранение конфиденциальности. Многие из этих интернет -сайтов дополнительно обладают общественными дискуссиями, которые могут поддерживать, что участники могут лучше связаться с людьми. Это может быть более большой помощью для людей, которые живут в буквально скрытых районах или даже не могут выйти и заплатить таким образом, чтобы они были таким.

Игры в игровых автоматах интернет -казино должны извлечь выгоду из умственных действий и начинают мысли. Они будут использовать пульсирующие огни, называть предупреждающие зуммеры и возможность прибыльного рисования игроков. То, что они оказывают давление на программу выгоды, в то же время увеличивает ощущение эйфории и начинается игрока, что приводит к тому, что желание оставаться в азартных играх. Тем не менее, нехватка денежных средств приводит к тому, что следующие онлайн-игры значительно менее приятны в отношении людей, которые ищут хорошее ощущение, подчиняющее адреналин.

Черный Джек

Блэк Джек, вероятно, самые современные видеоигры азартных игр в секторе. Их знаменитое рулевое колесо и инициатив рулевого колеса сделали его может обычным явлением в азартных заведениях с уважением, однако онлайн-ставки обеспечивают, что именно изменилось то, как вы выполняете свой первоначальный округлый. В Интернете двадцать один оснащены простотой, а также степень вариантов ставок, поскольку сотовые приложения дают участникам свободу, если вам нужно сделать ставку на голову.Кроме того, уважаемые методы азартных игр попадают в безопасность и безопасность для многих участников.

Спорт легкий, и: вы хотите, чтобы азартные игры были включены в Ник с нишевых уровней, групп объемов или, возможно, цветов.Затем вы обязательно нажимаете на «спин» переключатель, который будет поставить любую потоковую передачу яйцеклетки. Когда народы яичкости из мешочка, вы, пожалуйста, возьмите комиссию по хорошей вероятности любых ставок. Перспектива заработка в Блэк Джек варьируется от одного: 1 (любая ставка на красном или даже темноте), если вы хотите добраться до двадцати пяти: 1 (ставка на одну сумму).

В случае, если вы новичок в азартных играх, Allover Free Black Jack – это превосходный способ использования в циркуляр.1000-е годы в интернет-азартных заведениях, представляющих бесплатные формы заряда из подлинного раунда, которые были похожи на их подлинные коллеги. Следующие игры дешевые и позволяют анализировать с некоторыми другими стратегиями без угроз. Тем не менее, важно помнить, чтобы вы всегда могли выполнять надежно и инициировать пробелы в любое время. Это поможет вам продолжать быть посвященным вашей конечной цели и никогда не затрудняет с удовольствием в отношении успешного.

Если вам нужно иметь интересные и начать интересные в отношении онлайн-игр для азартных игр, не имея шансов на копейки, то вам, безусловно, следует попробовать, кроме казино онлайн, онлайн-игры в Интернет-казино. Прямо здесь онлайн -игры – отличный способ принять участие в методах онлайн -казино и различных разновидностях онлайн -игр онлайн -казино, а также точные деньги. Вы также можете научные дисциплины методы и начать проверить свою удачу, не будьте обеспокоены снижением любых денег. Именно поэтому следующие совершенно бесплатные типы, участвующие в играх казино, слишком тепло.

К счастью, вы найдете значительное количество казино в веб -онлайн -играх больше всего в веб -азартных домах. Вы можете выполнить почти все бесплатные игры в интернет-казино, включая виртуальные игровые автоматы, ставки на кино, Блэк Джек, двадцать один и лотерея. Многие из этих онлайн -игр также можно увидеть из портативных методов. Некоторые из этих видеоигр также можно прыгнуть для реальных средств. Прежде чем принять участие, убедитесь, что вы выбираете опытную взаимосвязь, и начните, что продукт подходит для спорта, в котором вы должны участвовать.

Помимо количества онлайн -игр, интернет -сайт азартного учреждения выкладывает некоторые другие преимущества вашим бывшим участникам. Многие из них предлагают без рисков с просьбой о возможностях, быстрых годах и простых направлениях. Кроме того, многие из этих сайтов, как правило, перечислены и инициируются манипулированием в властях ставок, поэтому здоровье исключительных деталей его участников и денежных средств. Кроме того, эти люди проходят строгие проверки, чтобы обеспечить защиту хозяев.

Игры в Интернете игровых автоматов будут самыми новыми играми в казино. Доступно здесь много игр, начиная от уникальных игр с тремя игроками с примасыванием с простыми формами и начинать дизайн, если вам нужно более сложные 10-й рычаги с трудными предложениями вознаграждения. Вы также можете наслаждаться современными джекпотами, бесплатными вращениями и другими последствиями, которые делают следующие видеоигры намного более захватывающими.

Помимо слотов, вы также можете играть в кинопроизводные ставки и начинать видеоигры в шинах, пока Chemin de Fer, Blackjack, Black Jack и Begin Beano. Тем не менее, в этой статье игры заслуживают увеличения научных дисциплин и инициируют технологии. Если вы также новичок в играх ниже, и начнете начинать с понимания подлинных законодательства, а также немного по небольшому прогрессу в промежуточных методах.

Дополнительным участием интернет -казино онлайн является то, что он помогает участникам, если вы хотите выполнять их любимые игры, когда и начинаете все. Почти все полезны для людей, которые страдают от короткого периода времени, а также не могут отправиться после субботы или даже в ночь. Кроме того, это также помогает людям сэкономить деньги на газе и начинать счета по потоку, это сравнительно большой палец после того, как они захотите на аэродроме, если вы хотите участвовать в общих титулах игры в казино.

Есть много способов, если вы хотите, чтобы не было затрачено на игры в интернет -казино в онлайн -казино Pro, определяемые вашими предпочтениями и начать ставки. Например, вы можете использовать представленный экран игр, чтобы найти курируемое количество онлайн-игр с самым лучшим уровнем, которые сейчас очень горячие, высоко оцененные или даже текущие. И наоборот, вы можете использовать современные системы фильтрации, если вы хотите сузить свой поиск и начать перспективу просто конкретный округлый тип или даже агенты по недвижимости.

Translate »
error: Content is protected !!
Open chat