type-sharetwitter-text-before']); } else { $twitter_share_text_before = ""; } if(!empty($layer['settings']['link-type-sharetwitter-text-after'])){ $twitter_share_text_after = str_replace(array("%title%","%excerpt%"), array($title,$excerpt), $layer['settings']['link-type-sharetwitter-text-after']); } else { $twitter_share_text_after = ""; } $twitter_share_text = $twitter_share_text_before.$twitter_share_url.$twitter_share_text_after; $text = ''.$text.''; break; case 'likepost': if(!empty($this->post['ID'])) $text = ''.$text.''; //javascript-link else $text = ''; break; } if($link_to !== 'none') $do_display = true; //set back to true if a link is set on layer $text = trim($text); //check for special styling coming from post option and set css to the queue if(isset($layer['id'])) $this->set_meta_element_changes($layer['id'], $unique_class); $post_class = (!isset($post['ID'])) ? '' : ' eg-post-'.$post['ID']; if($base->text_has_certain_tag($text, 'a') && !$do_ignore_styles){ //check if a tag exists, if yes, class will be set to a tags and not the wrapping div, also the div will receive the position and other stylings // && @$layer['settings']['source'] !== 'text' if($is_woo_cats && strpos($text, 'class="') !== false || $is_woo_button || $is_filter_cat && strpos($text, 'class="') !== false){ //add to the classes instead of creating own class attribute if it is woocommerce cats AND a class can be found $text = str_replace('class="', 'class="'.$unique_class.$post_class.$lb_class.' ', $text); }elseif($is_html_source && strpos($text, 'class="') !== false){ $text = str_replace('', '', $text); //moved to more global css generation process @version: 2.0 //$this->add_css_wrap[$unique_class]['a']['display'] = $do_display; //do_display defines if we should write display: block; //$this->add_css_wrap[$unique_class]['a']['full'] = $do_full; //do full styles (for categories and tags separator) $unique_class .= '-a'; } if($do_ignore_styles) $unique_class = 'eg-'.esc_attr($this->handle).'-nostyle-element-'.$layer['id']; //replace all the normal shortcodes if(function_exists('qtrans_useCurrentLanguageIfNotFoundUseDefaultLanguage')){ //use qTranslate $text = qtrans_useCurrentLanguageIfNotFoundUseDefaultLanguage($text); }elseif(function_exists('ppqtrans_useCurrentLanguageIfNotFoundUseDefaultLanguage')){ //use qTranslate plus $text = ppqtrans_useCurrentLanguageIfNotFoundUseDefaultLanguage($text); }elseif(function_exists('qtranxf_useCurrentLanguageIfNotFoundUseDefaultLanguage')){ //use qTranslate X $text = qtranxf_useCurrentLanguageIfNotFoundUseDefaultLanguage($text); } $text = do_shortcode($text); if($special_item == 'true' && $special_item_type == 'line-break'){ //line break element echo ' '."\n"; }elseif(trim($text) !== ''){ //}elseif(!empty($text)){ $use_tag = $base->getVar($layer['settings'], 'tag-type', 'div'); echo ' <'.$use_tag.' class="esg-'.$class.$post_class.$video_play.$ajax_class.' '.$hideunderClass.$unique_class.$transition.'"'.$ajax_attr.$transition_split.$delay.$hideunderHTML; echo ($demo == 'custom') ? $demo_element_type : ''; echo $data_transition_transition . '>'; echo $text; echo ''."\n"; } } /** * Retrieve the value of post elements */ public function get_post_value($handle, $separator, $function, $meta, $catmax = '-1', $taxonomy = ""){ $base = new Essential_Grid_Base(); $text = ''; /* 2.1.5 category max option */ $adjustMax = false; if( in_array( $handle, array( 'cat_list','tag_list','taxonomy') ) ) { if(!empty($catmax) && $catmax !== '-1' && is_numeric($catmax) && intval($catmax) > 0) { $catmax = intval($catmax); $adjustMax = true; } } switch($handle){ //Post elements case 'post_id': $text = $base->getVar($this->post, 'ID', ''); break; case 'post_url': $post_id = $base->getVar($this->post, 'ID', ''); $text = get_permalink($post_id); break; case 'title': $text = $base->getVar($this->post, 'post_title', ''); break; case 'caption': case 'excerpt': $text = trim($base->getVar($this->post, 'post_excerpt')); if(empty($text)){ //strip essential grid shortcode here $text = do_shortcode($base->strip_essential_shortcode($base->getVar($this->post, 'post_content'))); $text = preg_replace("/]*>(.*?)<\\/style>/s", "", $text); $text = preg_replace("/]*>(.*?)<\\/script>/s", "", $text); } $text = strip_tags($text); //,"

" break; case 'meta': $m = new Essential_Grid_Meta(); $text = $m->get_meta_value_by_handle($base->getVar($this->post, 'ID', ''),$meta); break; case 'likespost': $post_id = $base->getVar($this->post, 'ID', ''); if(!empty($post_id)){ $count = get_post_meta($post_id, "eg_votes_count", 0); if(!$count) $count[0] = 0; if(is_array($count)){ $text = ''.$count[0].''; } } else{ $text = ''; } break; case 'alias': $text = $base->getVar($this->post, 'post_name'); break; case 'content': $text = apply_filters('the_content', $base->getVar($this->post, 'post_content')); break; case 'link': $text = get_permalink($base->getVar($this->post, 'ID', '')); break; case 'date': $postDate = $base->getVar($this->post, "post_date_gmt"); $text = $base->convert_post_date($postDate); break; case 'date_day': $postDate = $base->getVar($this->post, "post_date_gmt"); $text = date('dd',strtotime($postDate)); break; case 'date_month': $postDate = $base->getVar($this->post, "post_date_gmt"); $text = date('m',strtotime($postDate)); break; case 'date_month_abbr': $postDate = $base->getVar($this->post, "post_date_gmt"); $text = date('M',strtotime($postDate)); break; case 'date_year': $postDate = $base->getVar($this->post, "post_date_gmt"); $text = date('Y',strtotime($postDate)); break; case 'date_year_abbr': $postDate = $base->getVar($this->post, "post_date_gmt"); $text = date('y',strtotime($postDate)); break; case 'date_modified': $dateModified = $base->getVar($this->post, "post_modified"); $text = $base->convert_post_date($dateModified); break; case 'author_name': $authorID = $base->getVar($this->post, 'post_author'); $text = get_the_author_meta('display_name', $authorID); break; case 'author_posts': $authorID = $base->getVar($this->post, 'post_author'); $text = get_author_posts_url($authorID ); break; case 'author_profile': $authorID = $base->getVar($this->post, 'post_author'); $meta_value = get_the_author_meta('url', $authorID); break; case 'author_avatar_32': $authorID = $base->getVar($this->post, 'post_author'); $meta_value = get_avatar( $authorID, 32); break; case 'author_avatar_64': $authorID = $base->getVar($this->post, 'post_author'); $meta_value = get_avatar( $authorID, 64); break; case 'author_avatar_96': $authorID = $base->getVar($this->post, 'post_author'); $meta_value = get_avatar( $authorID, 96); break; case 'author_avatar_512': $authorID = $base->getVar($this->post, 'post_author'); $meta_value = get_avatar( $authorID, 512); break; case 'num_comments': $text = $base->getVar($this->post, 'comment_count'); break; case 'cat_list': $use_taxonomies = false; $postCatsIDs = $base->getVar($this->post, 'post_category'); if(empty($postCatsIDs) && isset($this->post['post_type'])){ $postCatsIDs = array(); $obj = get_object_taxonomies($this->post['post_type']); if(!empty($obj) && is_array($obj)){ foreach($obj as $tax){ if($tax == 'post_tag') continue; $use_taxonomies[] = $tax; $new_terms = get_the_terms($base->getVar($this->post, 'ID', ''), $tax); if(is_array($new_terms) && !empty($new_terms)){ foreach($new_terms as $term){ $postCatsIDs[$term->term_id] = $term->term_id; } } } } } /* 2.1.5 category max option */ if($adjustMax && is_array($postCatsIDs)) $postCatsIDs = array_slice($postCatsIDs, 0, $catmax, true); $text = $base->get_categories_html_list($postCatsIDs, $function, $separator, $use_taxonomies); break; case 'tag_list': if(!$adjustMax) { $text = $base->get_tags_html_list($base->getVar($this->post, 'ID', ''), $separator, $function); } else { $text = $base->get_tags_html_list($base->getVar($this->post, 'ID', ''), $separator, $function, $catmax); } break; case 'taxonomy': if(!$adjustMax) { $text = $base->get_tax_html_list($base->getVar($this->post, 'ID', ''), $taxonomy, $separator, $function); } else { $text = $base->get_tax_html_list($base->getVar($this->post, 'ID', ''), $taxonomy, $separator, $function, $catmax); } break; /* case 'iframe': print '

HELLO!

'; die(); break; */ default: $text = apply_filters('essgrid_post_meta_content', $text, $handle, $base->getVar($this->post, 'ID', ''), $this->post); break; } return $text; } /** * Retrieve the value of post elements */ public function get_custom_element_value($handle, $separator, $meta = ''){ $base = new Essential_Grid_Base(); $m = new Essential_Grid_Meta(); $text = ''; $text = $base->getVar($this->layer_values, $handle, ''); if($text == '' && $meta != '') $text = $base->getVar($this->layer_values, $meta, ''); if(intval($text) > 0){ //we may be an image from the metas $custom_meta = $m->get_all_meta(false); if(!empty($custom_meta)){ foreach($custom_meta as $cmeta){ if($cmeta['handle'] == $handle){ if($cmeta['type'] == 'image'){ $img = wp_get_attachment_image_src($text, $this->media_sources_type); if($img !== false){ $text = $img[0]; //replace with URL } } break; } } } } return $text; } /** * Retrieve the value of event elements */ public function get_event_manager_value($handle){ $base = new Essential_Grid_Base(); $text = ''; switch($handle){ //check for event manager case 'event_start_date': break; case 'event_end_date': break; case 'event_start_time': break; case 'event_end_time': break; case 'event_event_id': break; case 'event_location_name': break; case 'event_location_slug': break; case 'event_location_address': break; case 'event_location_town': break; case 'event_location_state': break; case 'event_location_postcode': break; case 'event_location_region': break; case 'event_location_country': break; } return $text; } /** * Retrieve the value of woocommerce elements */ public function get_woocommerce_value($meta, $separator, $catmax = false){ $text = ''; if(isset($this->post['ID'])){ if(Essential_Grid_Woocommerce::is_woo_exists()){ $base = new Essential_Grid_Base(); $m = new Essential_Grid_Meta(); /* 2.1.5 category max option */ $adjustMax = false; if($meta === 'wc_categories') { if(!empty($catmax) && $catmax !== '-1' && is_numeric($catmax) && intval($catmax) > 0) { $catmax = intval($catmax); $adjustMax = true; } } if($adjustMax) { $text = Essential_Grid_Woocommerce::get_value_by_meta($this->post['ID'], $meta, $separator, $catmax); } else { $text = Essential_Grid_Woocommerce::get_value_by_meta($this->post['ID'], $meta, $separator); } } } return $text; } } 5 Things I wish I knew before becoming a digital nomad - Dear Alyne

This guest post is by blogger Kristin Kee, from Wanderlust or Love. Thank you Kristin for your great and informative post!

It was just a short two months ago when I packed up my belongings that mattered most, sold or donated the rest, and put what was left into storage to live the digital nomad lifestyle. I was nearing the end of my 35th year of existence, and I had just quit my 11 year teaching career to live as a full-time travel and self discovery blogger.

I was a big ball of emotions, which ranged from the kind of excitement that you only get as a kid on Christmas morning to freaking out…“OMGee, what have I just done?!”

I didn’t really know what to expect with this major life change other than a life full of adventure. If being a digital nomad who travels the world sounds appealing to you, here are five things I wish I knew before taking the leap:

1) You have to get comfortable with being uncomfortable.

Whether it’s not knowing where you’ll lay your head next or where your next pay check will come from or how soon will you wear out your welcome at so and so’s house, there’s a lot of unknown in this lifestyle.

And living a life with lots of uncertainty can make some people uncomfortable. In my case, it started causing a lot of anxiety, and until I learned how to get comfortable with the discomfort of the unknown, the anxiety just got worse, much worse.

I had to make my peace with the fact that I am now literally living life by the seat of my travelling pants and that my old, steady life as I knew it was over. On the bright side, I’m getting to create the lifestyle that I want, be my own boss, and travel as much as I want (or as much as my pocketbook allows)!

Intentionality is key to creating the life that you want.

I’m currently at the crossroads of living my best life now and creating my best future self, but that wasn’t the case at the beginning of this journey.

With so much of the aforementioned uncertainty in my life, I had to become very intentional about my thoughts, which in turn affected my actions.

I started scripting a few times each week, which is like journaling from the perspective of your future self. I wrote about all the awesome things my future self was doing as if I were doing them at this moment in time, and I gushed about how grateful I was for my blessings. In this way, I am able to get into the mindset of my future, successful self and intentionally shape the outcome of my present life simultaneously.

Flexibility is the name of the game.

Flexibility is key, and no, I’m not talking about the kind of flexibility that allows you to curl up in a ball so you can fit into a suitcase and fly for free!

When you live the digital nomad lifestyle, you have to have a go with the flow kind of attitude.

Travel plans, work, and living arrangements can change on a dime for a variety of reasons, so it’s important to be able to adapt to make the most of this lifestyle. Otherwise, you’ll just want to beat your head against a wall (and that wouldn’t be fair to the wall, lol)!

Put 3-6 months of living expenses into savings, and then DOUBLE IT!

When I started my travel blog about a year and a half ago, I was pretty sure this was the lifestyle I eventually wanted to pursue. So, I started saving what I could from my teacher’s salary, while still traveling as much as possible. But lemme tell you, it wasn’t an easy feat! In the end, I saved as much as I could in a year’s time before resigning from my teaching position at the end of the school year. However, shortly after I resigned, I developed some health issues and used up most of my savings paying off medical bills, which is why it’s sooooo important to double your savings before starting this adventure.

Dating can be difficult.

Dating in this day and age is difficult enough, but throw in the added factor of not having a permanent address and being constantly on the go, and that makes dating a real challenge. But in a way, it almost weeds out the potentials that wouldn’t gel well with your lifestyle. In fact, I’ve been in relationships before I became a digital nomad where my significant other really didn’t like the fact that I traveled so much.

So, those men are obviously not a good fit for a travel blogger taking the world on by storm! Through dating trials and errors, I’ve discovered that I need a man who is very secure, non-controlling, and independent with his own interests and hobbies. Of course, it would be great if he could travel with me, but I know that’s not always feasible.

The important thing is to stay true to yourself and not compromise who you are for any man.

The right one will come along, or so I’ve been told, and while I’m waiting on Mr. Right, I’m just going to keep doing what makes me happy! ;-D


Ultimately, you have to decide what’s best for you and your life! You can read about every digital nomad’s experience until your eyes cross, but in the end, it’s your dream life that you’re consciously creating. Follow your heart and trust your gut!

This lifestyle isn’t for the faint of heart, but it’s sooooo worth it if you decide to go for it.

This journey has definitely changed my life for the better! I’ve started attracting the kind of people and experiences that add a touch of magic to my previously “normal” existence. I’ve always wanted to live an incredible life, and now, apart from road tripping cross country with my dog and lunching on top of mountains by myself, my energy has changed the way people look at me and how I see other people too.

I even have moments now where flashes of other people’s thoughts cross my mind, which seems to be a direct result of traveling and being exposed to different ways of perceiving the world around me. I seem to have tapped into a higher consciousness of awareness, which is all still very new to me. Of course, every digital nomad will have their own, unique experience in this nomadic journey, so trust the magic of life and explore the opportunities that come your way!

If you do decide to become a fellow nomad, perhaps our paths will cross in this brave new world that we call home! To read more about my adventures in travel, life, and love, check out my blog www.wanderlustorlove.com or find Wanderlust or Love on social media. XOXO! :-*

NOTE: This article has been edited to remove a term which (previously unknown to us) was offensive. We’re really sorry for any offense caused!

Total
73
Shares

Leave a Reply

Your email address will not be published. Required fields are marked *

*
*