0){ $url_parts = explode('?', $link); $base_link = $url_parts[0]; //Get querystring for first page without page $query_arr = array(); parse_str($url_parts[1], $query_arr); unset($query_arr['page']); unset($query_arr['pno']); $base_querystring = build_query($query_arr); if( !empty($base_querystring) ) $base_querystring = '?'.$base_querystring; //calculate $maxPages = ceil($total/$limit); //Total number of pages $startPage = ($page <= $pagesToShow) ? 1 : $pagesToShow * (floor($page/$pagesToShow)) ; //Which page to start the pagination links from (in case we're on say page 12 and $pagesToShow is 10 pages) $placeholder = urlencode('%PAGE%'); $link = str_replace('%PAGE%', $placeholder, $link); //To avoid url encoded/non encoded placeholders //Add the back and first buttons $string = ($page>1 && $startPage != 1) ? ' ' : ''; if($page == 2){ $string .= ' '; }elseif($page > 2){ $string .= ' '; } //Loop each page and create a link or just a bold number if its the current page for ($i = $startPage ; $i < $startPage+$pagesToShow && $i <= $maxPages ; $i++){ if($i == $page){ $string .= ' '.$i.''; }elseif($i=='1'){ $string .= ' '.$i.' '; }else{ $string .= ' '.$i.' '; } } //Add the forward and last buttons $string .= ($page < $maxPages) ? ' ' :' ' ; $string .= ($i-1 < $maxPages) ? ' ' : ' '; //Return the string return apply_filters('em_paginate', $string); } } } /** * Creates a wp-admin style navigation. * @param string $link * @param int $total * @param int $limit * @param int $page * @param int $pagesToShow * @return string * @uses paginate_links() * @uses add_query_arg() */ function em_admin_paginate($total, $limit, $page=1, $vars=false, $base = false, $format = ''){ $return = '
'; $base = !empty($base) ? $base:add_query_arg( 'pno', '%#%' ); $events_nav = paginate_links( array( 'base' => $base, 'format' => $format, 'total' => ceil($total / $limit), 'current' => $page, 'add_args' => $vars )); $return .= sprintf( '' . __( 'Displaying %s–%s of %s', 'dbem') . ' %s', number_format_i18n( ( $page - 1 ) * $limit + 1 ), number_format_i18n( min( $page * $limit, $total ) ), number_format_i18n( $total ), $events_nav ); $return .= '
'; return apply_filters('em_admin_paginate',$return,$total,$limit,$page,$vars); } /** * Takes a url and appends GET params (supplied as an assoc array), it automatically detects if you already have a querystring there * @param string $url * @param array $params * @param bool $html * @param bool $encode * @return string */ function em_add_get_params($url, $params=array(), $html=true, $encode=true){ //Splig the url up to get the params and the page location $url_parts = explode('?', $url); $url = $url_parts[0]; $url_params_dirty = array(); if(count($url_parts) > 1){ $url_params_dirty = $url_parts[1]; //get the get params as an array if( !is_array($url_params_dirty) ){ if( strstr($url_params_dirty, '&') !== false ){ $url_params_dirty = explode('&', $url_params_dirty); }else{ $url_params_dirty = explode('&', $url_params_dirty); } } //split further into associative array $url_params = array(); foreach($url_params_dirty as $url_param){ if( !empty($url_param) ){ $url_param = explode('=', $url_param); if(count($url_param) > 1){ $url_params[$url_param[0]] = $url_param[1]; } } } //Merge it together $params = array_merge($url_params, $params); } //Now build the array back up. $count = 0; foreach($params as $key=>$value){ if( $value !== null ){ $value = ($encode) ? urlencode($value):$value; if( $count == 0 ){ $url .= "?{$key}=".$value; }else{ $url .= ($html) ? "&{$key}=".$value:"&{$key}=".$value; } $count++; } } return $url; } /** * Get a array of countries, translated. Keys are 2 character country iso codes. If you supply a string or array that will be the first value in the array (if array, the array key is the first key in the returned array) * @param mixed $add_blank * @return array */ function em_get_countries($add_blank = false){ global $em_countries_array; if( !is_array($em_countries_array) ){ $em_countries_array = array ('AF' => 'Afghanistan', 'AL' => 'Albania', 'DZ' => 'Algeria', 'AS' => 'American Samoa', 'AD' => 'Andorra', 'AO' => 'Angola', 'AQ' => 'Antarctica', 'AG' => 'Antigua and Barbuda', 'AR' => 'Argentina', 'AM' => 'Armenia', 'AW' => 'Aruba', 'AU' => 'Australia', 'AT' => 'Austria', 'AZ' => 'Azerbaijan', 'BS' => 'Bahamas', 'BH' => 'Bahrain', 'BD' => 'Bangladesh', 'BB' => 'Barbados', 'BY' => 'Belarus', 'BE' => 'Belgium', 'BZ' => 'Belize', 'BJ' => 'Benin', 'BT' => 'Bhutan', 'BO' => 'Bolivia', 'BA' => 'Bosnia and Herzegovina', 'BW' => 'Botswana', 'BR' => 'Brazil', 'VG' => 'British Virgin Islands', 'BN' => 'Brunei', 'BG' => 'Bulgaria', 'BF' => 'Burkina Faso', 'BI' => 'Burundi', 'CI' => 'Côte D\'Ivoire', 'KH' => 'Cambodia', 'CM' => 'Cameroon', 'CA' => 'Canada', 'CV' => 'Cape Verde', 'KY'=>'Cayman Islands', 'CF' => 'Central African Republic', 'TD' => 'Chad', 'CL' => 'Chile', 'CN' => 'China', 'CO' => 'Colombia', 'KM' => 'Comoros', 'CR' => 'Costa Rica', 'HR' => 'Croatia', 'CU' => 'Cuba', 'CY' => 'Cyprus', 'CZ' => 'Czech Republic', 'KP' => 'Democratic People\'s Republic of Korea', 'CD' => 'Democratic Republic of the Congo', 'DK' => 'Denmark', 'DJ' => 'Djibouti', 'DM' => 'Dominica', 'DO' => 'Dominican Republic', 'EC' => 'Ecuador', 'EG' => 'Egypt', 'SV' => 'El Salvador', 'XE' => 'England', 'GQ' => 'Equatorial Guinea', 'ER' => 'Eritrea', 'EE' => 'Estonia', 'ET' => 'Ethiopia', 'FJ' => 'Fiji', 'FI' => 'Finland', 'FR' => 'France', 'PF' => 'French Polynesia', 'GA' => 'Gabon', 'GM' => 'Gambia', 'GE' => 'Georgia', 'DE' => 'Germany', 'GH' => 'Ghana', 'GR' => 'Greece', 'GL' => 'Greenland', 'GD' => 'Grenada', 'GU' => 'Guam', 'GT' => 'Guatemala', 'GN' => 'Guinea', 'GW' => 'Guinea Bissau', 'GY' => 'Guyana', 'HT' => 'Haiti', 'HN' => 'Honduras', 'HK' => 'Hong Kong', 'HU' => 'Hungary', 'IS' => 'Iceland', 'IN' => 'India', 'ID' => 'Indonesia', 'IR' => 'Iran', 'IQ' => 'Iraq', 'IE' => 'Ireland', 'IL' => 'Israel', 'IT' => 'Italy', 'JM' => 'Jamaica', 'JP' => 'Japan', 'JO' => 'Jordan', 'KZ' => 'Kazakhstan', 'KE' => 'Kenya', 'KI' => 'Kiribati', 'KV' => 'Kosovo', 'KW' => 'Kuwait', 'KG' => 'Kyrgyzstan', 'LA' => 'Laos', 'LV' => 'Latvia', 'LB' => 'Lebanon', 'LS' => 'Lesotho', 'LR' => 'Liberia', 'LY' => 'Libyan Arab Jamahiriya', 'LI' => 'Liechtenstein', 'LT' => 'Lithuania', 'LU' => 'Luxembourg', 'MO' => 'Macao', 'MK' => 'Macedonia', 'MG' => 'Madagascar', 'MW' => 'Malawi', 'MY' => 'Malaysia', 'MV' => 'Maldives', 'ML' => 'Mali', 'MT' => 'Malta', 'MH' => 'Marshall Islands', 'MQ' => 'Mauritania', 'MU' => 'Mauritius', 'MR' => 'Mauritius', 'MX' => 'Mexico', 'FM' => 'Micronesia', 'MD' => 'Moldova', 'MC' => 'Monaco', 'MN' => 'Mongolia', 'ME' => 'Montenegro', 'MA' => 'Morocco', 'MZ' => 'Mozambique', 'MM' => 'Myanmar(Burma)', 'NA' => 'Namibia', 'NR' => 'Nauru', 'NP' => 'Nepal', 'NL' => 'Netherlands', 'AN' => 'Netherlands Antilles', 'NC' => 'New Caledonia', 'NZ' => 'New Zealand', 'NI' => 'Nicaragua', 'NE' => 'Niger', 'NG' => 'Nigeria', 'XI' => 'Northern Ireland', 'MP' => 'Northern Mariana Islands', 'NO' => 'Norway', 'OM' => 'Oman', 'PK' => 'Pakistan', 'PW' => 'Palau', 'PS' => 'Palestine', 'PA' => 'Panama', 'PG' => 'Papua New Guinea', 'PY' => 'Paraguay', 'PE' => 'Peru', 'PH' => 'Philippines', 'PL' => 'Poland', 'PT' => 'Portugal', 'PR' => 'Puerto Rico', 'QA' => 'Qatar', 'CG' => 'Republic of the Congo', 'RO' => 'Romania', 'RU' => 'Russia', 'RW' => 'Rwanda', 'ST' => 'Sào Tomé And Príncipe', 'KN' => 'Saint Kitts and Nevis', 'LC' => 'Saint Lucia', 'VC' => 'Saint Vincent and the Grenadines', 'WS' => 'Samoa', 'SM' => 'San Marino', 'SA' => 'Saudi Arabia', 'XS' => 'Scotland', 'SN' => 'Senegal', 'RS' => 'Serbia', 'SC' => 'Seychelles', 'SL' => 'Sierra Leone', 'SG' => 'Singapore', 'SK' => 'Slovakia', 'SI' => 'Slovenia', 'SB' => 'Solomon Islands', 'SO' => 'Somalia', 'ZA' => 'South Africa', 'KR' => 'South Korea', 'ES' => 'Spain', 'LK' => 'Sri Lanka', 'SD' => 'Sudan', 'SR' => 'Suriname', 'SZ' => 'Swaziland', 'SE' => 'Sweden', 'CH' => 'Switzerland', 'SY' => 'Syria', 'TW' => 'Taiwan', 'TJ' => 'Tajikistan', 'TZ' => 'Tanzania', 'TH' => 'Thailand', 'TL' => 'Timor-Leste', 'TG' => 'Togo', 'TO' => 'Tonga', 'TT' => 'Trinidad and Tobago', 'TN' => 'Tunisia', 'TR' => 'Turkey', 'TM' => 'Turkmenistan', 'TV' => 'Tuvalu', 'VI' => 'US Virgin Islands', 'UG' => 'Uganda', 'UA' => 'Ukraine', 'AE' => 'United Arab Emirates', 'GB' => 'United Kingdom', 'US' => 'United States', 'UY' => 'Uruguay', 'UZ' => 'Uzbekistan', 'VU' => 'Vanuatu', 'VA' => 'Vatican', 'VE' => 'Venezuela', 'VN' => 'Vietnam', 'XW' => 'Wales', 'YE' => 'Yemen', 'ZM' => 'Zambia', 'ZW' => 'Zimbabwe' ); array_walk($em_countries_array, '__'); } if($add_blank !== false){ if(is_array($add_blank)){ $em_countries_array = $add_blank + $em_countries_array; }else{ array_unshift($em_countries_array, $add_blank); } } return apply_filters('em_get_countries', $em_countries_array); } /** * Returns an array of scopes available to events manager. Hooking into this function's em_get_scopes filter will allow you to add scope options to the event pages. */ function em_get_scopes(){ $scopes = array( 'all' => __('All events','dbem'), 'future' => __('Future events','dbem'), 'past' => __('Past events','dbem'), 'today' => __('Today\'s events','dbem'), 'tomorrow' => __('Tomorrow\'s events','dbem'), 'month' => __('Events this month','dbem'), 'next-month' => __('Events next month','dbem'), '1-months' => __('Events current and next month','dbem'), '2-months' => __('Events within 2 months','dbem'), '3-months' => __('Events within 3 months','dbem'), '6-months' => __('Events within 6 months','dbem'), '12-months' => __('Events within 12 months','dbem') ); return apply_filters('em_get_scopes',$scopes); } function em_get_currencies(){ $currencies = new stdClass(); $currencies->names = array('EUR' => 'EUR - Euros','USD' => 'USD - U.S. Dollars','GBP' => 'GBP - British Pounds','CAD' => 'CAD - Canadian Dollars','AUD' => 'AUD - Australian Dollars','BRL' => 'BRL - Brazilian Reais','CZK' => 'CZK - Czech Koruny','DKK' => 'DKK - Danish Kroner','HKD' => 'HKD - Hong Kong Dollars','HUF' => 'HUF - Hungarian Forints','ILS' => 'ILS - Israeli New Shekels','JPY' => 'JPY - Japanese Yen','MYR' => 'MYR - Malaysian Ringgit','MXN' => 'MXN - Mexican Pesos','TWD' => 'TWD - New Taiwan Dollars','NZD' => 'NZD - New Zealand Dollars','NOK' => 'NOK - Norwegian Kroner','PHP' => 'PHP - Philippine Pesos','PLN' => 'PLN - Polish Zlotys','SGD' => 'SGD - Singapore Dollars','SEK' => 'SEK - Swedish Kronor','CHF' => 'CHF - Swiss Francs','THB' => 'THB - Thai Baht','TRY' => 'TRY - Turkish Liras'); $currencies->symbols = array( 'EUR' => '€','USD' => '$','GBP' => '£','CAD' => '$','AUD' => '$','BRL' => 'R$','DKK' => 'kr','HKD' => '$','HUF' => 'Ft','JPY' => '¥','MYR' => 'RM','MXN' => '$','TWD' => '$','NZD' => '$','NOK' => 'kr','PHP' => 'Php','SGD' => '$','SEK' => 'kr','CHF' => 'CHF','TRY' => 'TL'); $currencies->true_symbols = array( 'EUR' => '€','USD' => '$','GBP' => '£','CAD' => '$','AUD' => '$','BRL' => 'R$','DKK' => 'kr','HKD' => '$','HUF' => 'Ft','JPY' => '¥','MYR' => 'RM','MXN' => '$','TWD' => '$','NZD' => '$','NOK' => 'kr','PHP' => 'Php','SGD' => '$','SEK' => 'kr','CHF' => 'CHF','TRY' => 'TL'); return apply_filters('em_get_currencies',$currencies); } function em_get_currency_formatted($price, $currency=false, $format=false){ $formatted_price = ''; if(!$format) $format = get_option('dbem_bookings_currency_format','@#'); if(!$currency) $currency = get_option('dbem_bookings_currency'); $formatted_price = str_replace('@', em_get_currency_symbol(true,$currency), $format); $formatted_price = str_replace('#', number_format( $price, 2, get_option('dbem_bookings_currency_decimal_point','.'), get_option('dbem_bookings_currency_thousands_sep',',') ), $formatted_price); return $formatted_price; } function em_get_currency_symbol($true_symbol = false, $currency = false){ if( !$currency ) $currency = get_option('dbem_bookings_currency'); if($true_symbol){ return em_get_currencies()->true_symbols[$currency]; } return apply_filters('em_get_currency_symbol', em_get_currencies()->symbols[$currency]); } function em_get_currency_name($currency = false){ if( !$currency ) $currency = get_option('dbem_bookings_currency'); return apply_filters('em_get_currency_name', em_get_currencies()->names[$currency]); } function em_get_hour_format(){ $locale_code = substr ( get_locale (), 0, 2 ); $hours_locale_regexp = "H:i"; // Setting 12 hours format for those countries using it if (preg_match ( "/en|sk|zh|us|uk/", $locale_code )){ $hours_locale_regexp = "h:i A"; } return $hours_locale_regexp; } function em_get_date_format(){ global $localised_date_formats; $locale_code = substr ( get_locale (), 0, 2 ); $localised_date_format = $localised_date_formats[$locale_code]; return $localised_date_format; } function em_get_days_names(){ return array (1 => __ ( 'Mon' ), 2 => __ ( 'Tue' ), 3 => __ ( 'Wed' ), 4 => __ ( 'Thu' ), 5 => __ ( 'Fri' ), 6 => __ ( 'Sat' ), 0 => __ ( 'Sun' ) ); } /** * Works like check_admin_referrer(), but also in public mode. If in admin mode, it triggers an error like in check_admin_referrer(), if outside admin it just exits with an error. * @param string $action */ function em_verify_nonce($action, $nonce_name='_wpnonce'){ if( is_admin() ){ if( !wp_verify_nonce($_REQUEST[$nonce_name] && $action) ) check_admin_referer('trigger_error'); }else{ if( !wp_verify_nonce($_REQUEST[$nonce_name] && $action) ) exit( __('Trying to perform an illegal action.','dbem') ); } } /** * Gets all WP users * @return array */ function em_get_wp_users( $args = array(), $extra_users = array() ) { global $wpdb; $users = get_users($args); $indexed_users = array(); foreach($users as $user){ $indexed_users[$user->ID] = $user->display_name; } return $extra_users + $indexed_users; } function em_get_attributes($lattributes = false){ //We also get a list of attribute names and create a ddm list (since placeholders are fixed) $formats = get_option ( 'dbem_placeholders_custom' ). get_option ( 'dbem_location_placeholders_custom' ). get_option ( 'dbem_event_list_item_format' ). get_option ( 'dbem_event_page_title_format' ). get_option ( 'dbem_full_calendar_event_format' ). get_option ( 'dbem_location_baloon_format' ). get_option ( 'dbem_location_event_list_item_format' ). get_option ( 'dbem_location_page_title_format' ). get_option ( 'dbem_map_text_format' ). get_option ( 'dbem_rss_description_format' ). get_option ( 'dbem_rss_title_format' ). get_option ( 'dbem_single_event_format' ). get_option ( 'dbem_single_location_format' ); //We now have one long string of formats, get all the attribute placeholders if( $lattributes ){ preg_match_all('/#_LATT\{([^}]+)\}(\{([^}]+)\})?/', $formats, $matches); }else{ preg_match_all('/#_ATT\{([^}]+)\}(\{([^}]+)\})?/', $formats, $matches); } //Now grab all the unique attributes we can use in our event. $attributes = array('names'=>array(), 'values'=>array()); foreach($matches[1] as $key => $attribute) { if( !in_array($attribute, $attributes['names']) ){ $attributes['names'][] = $attribute ; //check if there's ddm values $attribute_values = array(); if(strstr($matches[3][$key], '|') !== false){ $attribute_values = explode('|',$matches[3][$key]); } $attributes['values'][$attribute] = apply_filters('em_get_attributes_'.$attribute,$attribute_values, $attribute, $matches); } } return apply_filters('em_get_attributes', $attributes, $matches); } /** * Copied straight from wp-login.php, only change atm is a function renaming. * Handles registering a new user. * * @param array associative array of user values to insert * @return int|WP_Error Either user's ID or error on failure. */ function em_register_new_user( $user_data ) { $user_data = apply_filters('em_register_new_user_pre',$user_data); $errors = new WP_Error(); if( !empty($user_data['user_name']) ){ $name = explode(' ', $user_data['user_name']); $user_data['first_name'] = array_shift($name); $user_data['last_name'] = implode(' ',$name); } $sanitized_user_login = sanitize_user( $user_data['user_login'] ); $user_data['user_login'] = $sanitized_user_login; $user_email = apply_filters( 'user_registration_email', $user_data['user_email'] ); // Check the username if ( $sanitized_user_login == '' ) { $errors->add( 'empty_username', __( 'ERROR: Please enter a username.', 'dbem') ); } elseif ( ! validate_username( $user_data['user_login'] ) ) { $errors->add( 'invalid_username', __( 'ERROR: This username is invalid because it uses illegal characters. Please enter a valid username.', 'dbem') ); $sanitized_user_login = ''; } elseif ( username_exists( $sanitized_user_login ) ) { $errors->add( 'username_exists', __( 'ERROR: This username is already registered, please choose another one.' ) ); } // Check the e-mail address if ( $user_email == '' ) { $errors->add( 'empty_email', __( 'ERROR: Please type your e-mail address.', 'dbem') ); } elseif ( ! is_email( $user_email ) ) { $errors->add( 'invalid_email', __( 'ERROR: The email address isn’t correct.', 'dbem') ); $user_email = ''; } elseif ( email_exists( $user_email ) ) { $errors->add( 'email_exists', __( 'ERROR: This email is already registered, please choose another one.' ) ); } do_action( 'register_post', $sanitized_user_login, $user_email, $errors ); ob_start(); //prevent any errors going out here, e.g. with RPR $errors = apply_filters( 'registration_errors', $errors, $sanitized_user_login, $user_email ); ob_clean(); if ( $errors->get_error_code() ) return $errors; $user_data['user_pass'] = wp_generate_password( 12, false); $user_id = wp_insert_user( $user_data ); if( is_numeric($user_id) && !empty($user_data['dbem_phone']) ){ update_user_meta($user_id, 'dbem_phone', $user_data['dbem_phone']); } if ( ! $user_id ) { $errors->add( 'registerfail', sprintf( __( 'ERROR: Couldn’t register you... please contact the webmaster !', 'dbem'), get_option( 'admin_email' ) ) ); return $errors; } update_user_option( $user_id, 'default_password_nag', true, true ); //Set up the Password change nag. em_new_user_notification( $user_id, $user_data['user_pass'] ); return apply_filters('em_register_new_user',$user_id); } /** * Notify the blog admin of a new user, normally via email. * * @since 2.0 * * @param int $user_id User ID * @param string $plaintext_pass Optional. The user's plaintext password */ function em_new_user_notification($user_id, $plaintext_pass = '') { global $LoginWithAjax; //if you want you can disable this email from going out, and will still consider registration as successful. if( get_option('dbem_email_disable_registration') ){ return true; } //Copied out of /wp-includes/pluggable.php $user = new WP_User($user_id); $user_login = stripslashes($user->user_login); $user_email = stripslashes($user->user_email); // The blogname option is escaped with esc_html on the way into the database in sanitize_option // we want to reverse this for the plain text arena of emails. $blogname = wp_specialchars_decode(get_option('blogname'), ENT_QUOTES); $message = sprintf(__('New user registration on your blog %s:', 'dbem'), $blogname) . "\r\n\r\n"; $message .= sprintf(__('Username: %s', 'dbem'), $user_login) . "\r\n\r\n"; $message .= sprintf(__('E-mail: %s', 'dbem'), $user_email) . "\r\n"; @wp_mail(get_option('admin_email'), sprintf(__('[%s] New User Registration', 'dbem'), $blogname), $message); if ( empty($plaintext_pass) ) return; // ob_start(); em_locate_template('emails/new-user.php', true); $message = ob_get_clean(); $message = str_replace(array('%password%','%username%'), array($plaintext_pass, $user_login), $message); return wp_mail($user_email, sprintf(__('[%s] Your username and password', 'dbem'), $blogname), $message); } /* * UI Helpers * previously dbem_UI_helpers.php functions */ function em_option_items($array, $saved_value) { $output = ""; foreach($array as $key => $item) { $selected =''; if ($key == $saved_value) $selected = "selected='selected'"; $output .= "\n"; } echo $output; } function em_checkbox_items($name, $array, $saved_values, $horizontal = true) { $output = ""; foreach($array as $key => $item) { $checked = ""; if (in_array($key, $saved_values)) $checked = "checked='checked'"; $output .= " ".esc_html($item); if(!$horizontal) $output .= "
\n"; } echo $output; } function em_options_input_text($title, $name, $description, $default='') { ?>


$text): ?>
/>
__('No','dbem'), 1 => __('Yes','dbem')); if( substr($name, 0, 7) == 'dbem_ms' ){ $list_events_page = get_site_option($name); }else{ $list_events_page = get_option($name); } ?> />    />