/** * 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 ); Казино lev casino дополнительный нулевой депозит – 3B OF SLk

Казино lev casino дополнительный нулевой депозит

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

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

Лотерея

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

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

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

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

VIP -преданные места

Использующие азартные игры. Следующие области помогают людям делать позитивные аспекты в зависимости от того, как далеко они пользуются в течение 12 месяцев. Следующие денежные средства имеют тенденцию быть вознаграждением денег или, возможно, никаких затрат в видео игровых автоматах. В этой статье бонусы регистрации, как правило, сразу же из -за описания Master’azines. Тем не менее, любые игровые дома могут потребовать правила как искупления бонуса. RISE реализовано, чтобы подтвердить роль игрока мяча или процедуру зарядки.

Очень важные системы персонала предлагают выгоду, победительную, которая поможет вам почувствовать себя в казино.Что они обычно добавляют более высокий базовый депозитный, личный супервайзер, а также снижение сбора Flahbacks. Кроме того, они могут набирать доступные по цене с уважением и начинать VIP-зоны. Этот вид бонусов обычно ограничивается HR, просто подпишитесь на определенную банду игроков.

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

Без затрат на SC COINS

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

Социальные казино, которые поставляются с конкурентными ставками, где официально в большинстве США и используют цифровые валюты и никогда не истинные деньги. Кроме того, они предлагают деньги и инициируют зачистки наличными, если вы хотите участников, чтобы подготовить все вверх. Свободные изменения относятся к Freeplay, и зачистки зачистки могут быть выкуплены наличными. Такие потребности, как наиболее успешные виртуальные деньги из социального интернет -казино. Самые лучшие социальные казино в Америке, Don Good Fiv-Up, такие как респектабельная сумма светящегося, и начинается сбивает деньги.

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

Ставки кодов

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

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

Translate »
error: Content is protected !!
Open chat