var tribe_dropdowns = window.tribe_dropdowns || {}; ( function( $, obj, _ ) { 'use strict'; obj.selector = { dropdown: '.tribe-dropdown', created: '.tribe-dropdown-created', searchField: '.select2-search__field', }; // Setup a Dependent $.fn.tribe_dropdowns = function() { obj.dropdown( this, {} ); return this; }; obj.freefrom_create_search_choice = function( params ) { if ( 'string' !== typeof params.term ) { return null; } var term = params.term.trim(); if ( '' === term ) { return null; } var args = this.options.options; var $select = args.$select; if ( term.match( args.regexToken ) && ( ! $select.is( '[data-int]' ) || ( $select.is( '[data-int]' ) && term.match( /\d+/ ) ) ) ) { var choice = { id: term, text: term, new: true }; if ( $select.is( '[data-create-choice-template]' ) ) { choice.text = _.template( $select.data( 'createChoiceTemplate' ) )( { term: term } ); } return choice; } return null; }; /** * Better Search ID for Select2, compatible with WordPress ID from WP_Query * * @param {object|string} e Searched object or the actual ID * @return {string} ID of the object */ obj.search_id = function( e ) { var id = undefined; if ( 'undefined' !== typeof e.id ) { id = e.id; } else if ( 'undefined' !== typeof e.ID ) { id = e.ID; } else if ( 'undefined' !== typeof e.value ) { id = e.value; } return undefined === e ? undefined : id; }; /** * Better way of matching results * * @param {string} term Which term we are searching for * @param {string} text Search here * @return {boolean} */ obj.matcher = function( params, data ) { // If there are no search terms, return all of the data if ( 'string' !== typeof params.term || params.term.trim() === '') { return data; } // Do not display the item if there is no 'text' property if ( typeof data.text === 'undefined' ) { return null; } var term = params.term.trim(); var text = data.text; var $select = $( data.element ).closest( 'select' ); var args = $select.data( 'dropdown' ); var result = text.toUpperCase().indexOf( term.toUpperCase() ) !== -1; if ( ! result && 'undefined' !== typeof args.tags ){ var possible = _.where( args.tags, { text: text } ); if ( args.tags.length > 0 && _.isObject( possible ) ){ var test_value = obj.search_id( possible[0] ); result = test_value.toUpperCase().indexOf( term.toUpperCase() ) !== -1; } } return result; }; /** * If the element used as the basis of a dropdown specifies one or more numeric/text * identifiers in its val attribute, then use those to preselect the appropriate options. * * @param {object} $select * @param {function} make_selection */ obj.init_selection = function( $select, make_selection ) { var isMultiple = $select.is( '[multiple]' ); var options = $select.data( 'dropdown' ); var currentValues = $select.val().split( options.regexSplit ); var selectedItems = []; $( currentValues ).each( function( index, value ) { // eslint-disable-line no-unused-vars var searchFor = { id: this, text: this }; var data = options.ajax ? $select.data( 'options' ) : options.data; var locatedItem = find_item( searchFor, data ); if ( locatedItem && locatedItem.selected ) { selectedItems.push( locatedItem ); } } ); if ( selectedItems.length && isMultiple ) { make_selection( selectedItems ); } else if ( selectedItems.length ) { make_selection( selectedItems[ 0 ] ); } else { make_selection( false ); return; } }; /** * Searches array 'haystack' for objects that match 'description'. * * The 'description' object should take the form { id: number, text: string }. The first * object within the haystack that matches one of those two properties will be returned. * * If objects contain an array named 'children', then that array will also be searched. * * @param {Object} description * @param {Array} haystack * * @return {Object|boolean} */ function find_item( description, haystack ) { if ( ! _.isArray( haystack ) ) { return false; } for ( var index in haystack ) { var possible_match = haystack[ index ]; if ( possible_match.hasOwnProperty( 'id' ) && possible_match.id == description.id ) { // eslint-disable-line no-prototype-builtins,eqeqeq,max-len return possible_match; } if ( possible_match.hasOwnProperty( 'text' ) && possible_match.text == description.text ) { // eslint-disable-line no-prototype-builtins,eqeqeq,max-len return possible_match; } if ( possible_match.hasOwnProperty( 'children' ) && _.isArray( possible_match.children ) ) { // eslint-disable-line no-prototype-builtins,max-len var subsearch = find_item( description, possible_match.children ); if ( subsearch ) { return subsearch; } } } return false; } obj.getSelectClasses = function( $select ) { var classesToRemove = [ 'select2-hidden-accessible', 'hide-before-select2-init', ]; var originalClasses = $select.attr( 'class' ).split( /\s+/ ); return _.difference( originalClasses, classesToRemove ); }; obj.element = function( field, args ) { var $select = $( field ); var args = $.extend( {}, args ); // eslint-disable-line no-redeclare var carryOverData = [ // eslint-disable-line no-unused-vars 'depends', 'condition', 'conditionNot', 'condition-not', 'conditionNotEmpty', 'condition-not-empty', 'conditionEmpty', 'condition-empty', 'conditionIsNumeric', 'condition-is-numeric', 'conditionIsNotNumeric', 'condition-is-not-numeric', 'conditionChecked', 'condition-is-checked', ]; var $container; // Add a class for dropdown created $select.addClass( obj.selector.created.className() ); // args.debug = true; // For Reference we save the jQuery element as an Arg. args.$select = $select; // Auto define the Width of the Select2. args.dropdownAutoWidth = true; args.width = 'resolve'; // CSS for the container args.containerCss = {}; // Only apply visibility when it's a Visible Select2. if ( $select.is( ':visible' ) ) { args.containerCss.display = 'inline-block'; args.containerCss.position = 'relative'; } // CSS for the dropdown args.dropdownCss = {}; args.dropdownCss.width = 'auto'; // When we have this we replace the default with what's in the param. if ( $select.is( '[data-dropdown-css-width]' ) ) { args.dropdownCss.width = $select.data( 'dropdown-css-width' ); if ( ! args.dropdownCss.width || 'false' === args.dropdownCss.width ) { delete args.dropdownCss.width; delete args.containerCss; } } // By default we allow The field to be cleared args.allowClear = true; if ( $select.is( '[data-prevent-clear]' ) ) { args.allowClear = false; } // Pass the "Searching..." placeholder if specified if ( $select.is( '[data-searching-placeholder]' ) ) { args.formatSearching = $select.data( 'searching-placeholder' ); } // If we are dealing with a Input Hidden we need to set the Data for it to work if ( ! $select.is( '[data-placeholder]' ) && $select.is( '[placeholder]' ) ) { args.placeholder = $select.attr( 'placeholder' ); } // If we are dealing with a Input Hidden we need to set the Data for it to work. if ( $select.is( '[data-options]' ) ) { args.data = $select.data( 'options' ); } // With less then 10 args we wouldn't show the search. args.minimumResultsForSearch = 10; // Prevents the Search box to show if ( $select.is( '[data-hide-search]' ) ) { args.minimumResultsForSearch = Infinity; } // Makes sure search shows up. if ( $select.is( '[data-force-search]' ) ) { delete args.minimumResultsForSearch; } // Allows freeform entry if ( $select.is( '[data-freeform]' ) ) { args.createTag = obj.freefrom_create_search_choice; args.tags = true; $select.data( 'tags', true ); } if ( $select.is( '[multiple]' ) ) { args.multiple = true; // Set the max select items, if defined if ( $select.is( '[data-maximum-selection-size]' ) ) { args.maximumSelectionSize = $select.data( 'maximum-selection-size' ); } // If you don't have separator, add one (comma) if ( ! $select.is( 'data-separator' ) ) { $select.data( 'separator', ',' ); } if ( ! _.isArray( $select.data( 'separator' ) ) ) { args.tokenSeparators = [ $select.data( 'separator' ) ]; } else { args.tokenSeparators = $select.data( 'separator' ); } args.separator = $select.data( 'separator' ); // Define the regular Exp based on args.regexSeparatorElements = [ '^(' ]; args.regexSplitElements = [ '(?:' ]; $.each( args.tokenSeparators, function ( i, token ) { args.regexSeparatorElements.push( '[^' + token + ']+' ); args.regexSplitElements.push( '[' + token + ']' ); } ); args.regexSeparatorElements.push( ')$' ); args.regexSplitElements.push( ')' ); args.regexSeparatorString = args.regexSeparatorElements.join( '' ); args.regexSplitString = args.regexSplitElements.join( '' ); args.regexToken = new RegExp( args.regexSeparatorString, 'ig' ); args.regexSplit = new RegExp( args.regexSplitString, 'ig' ); } // Select also allows Tags, so we go with that too if ( $select.is( '[data-tags]' ) ) { args.tags = $select.data( 'tags' ); args.createSearchChoice = function( term, data ) { // eslint-disable-line no-unused-vars if ( term.match( args.regexToken ) ) { return { id: term, text: term }; } }; if ( 0 === args.tags.length ) { args.formatNoMatches = function() { return $select.attr( 'placeholder' ); }; } } // When we have a source, we do an AJAX call if ( $select.is( '[data-source]' ) ) { var source = $select.data( 'source' ); // For AJAX we reset the data args.data = { results: [] }; // Format for Parents breadcrumbs args.formatResult = function ( item, container, query ) { // eslint-disable-line no-unused-vars,max-len if ( 'undefined' !== typeof item.breadcrumbs ) { return $.merge( item.breadcrumbs, [ item.text ] ).join( ' » ' ); } return item.text; }; // instead of writing the function to execute the request we use Select2's convenient helper. args.ajax = { dataType: 'json', type: 'POST', url: obj.ajaxurl(), // parse the results into the format expected by Select2. processResults: function ( response, page, query ) { // eslint-disable-line no-unused-vars if ( ! $.isPlainObject( response ) || 'undefined' === typeof response.success ) { console.error( 'We received a malformed Object, could not complete the Select2 Search.' ); // eslint-disable-line max-len return { results: [] }; } if ( ! $.isPlainObject( response.data ) || 'undefined' === typeof response.data.results ) { console.error( 'We received a malformed results array, could not complete the Select2 Search.' ); // eslint-disable-line max-len return { results: [] }; } if ( ! response.success ) { if ( 'string' === $.type( response.data.message ) ) { console.error( response.data.message ); } else { console.error( 'The Select2 search failed in some way... Verify the source.' ); } return { results: [] }; } return response.data; }, }; // By default only send the source args.ajax.data = function( search, page ) { return { action: 'tribe_dropdown', source: source, search: search, page: page, args: $select.data( 'source-args' ), }; }; } // Attach dropdown to container in DOM. if ( $select.is( '[data-attach-container]' ) ) { // If multiple, attach container without search. if ( $select.is( '[multiple]' ) ) { $.fn.select2.amd.define( 'AttachedDropdownAdapter', [ 'select2/utils', 'select2/dropdown', 'select2/dropdown/attachContainer', ], function( utils, dropdown, attachContainer ) { return utils.Decorate( dropdown, attachContainer ); } ); args.dropdownAdapter = $.fn.select2.amd.require( 'AttachedDropdownAdapter' ); // If not multiple, attach container with search. } else { $.fn.select2.amd.define( 'AttachedWithSearchDropdownAdapter', [ 'select2/utils', 'select2/dropdown', 'select2/dropdown/search', 'select2/dropdown/minimumResultsForSearch', 'select2/dropdown/attachContainer', ], function( utils, dropdown, search, minimumResultsForSearch, attachContainer ) { var adapter = utils.Decorate( dropdown, attachContainer ); adapter = utils.Decorate( adapter, search ); adapter = utils.Decorate( adapter, minimumResultsForSearch ); return adapter; } ); args.dropdownAdapter = $.fn.select2.amd.require( 'AttachedWithSearchDropdownAdapter' ); } } // Save data on Dropdown $select.data( 'dropdown', args ); $container = $select.select2TEC( args ); // Propagating original input classes to the select2 container. $container.data( 'select2' ).$container.addClass( obj.getSelectClasses( $select ).join( ' ' ) ); // Propagating original input classes to the select2 container. $container.data( 'select2' ).$container.removeClass( 'hide-before-select2-init' ); $container.on( 'select2:open', obj.action_select2_open ); /** * @todo @bordoni Investigate how and if we should be doing this. * if ( carryOverData.length > 0 ) { carryOverData.map( function( dataKey ) { var attr = 'data-' + dataKey; var val = $select.attr( attr ); if ( ! val ) { return; } this.attr( attr, val ); }, $container ); } */ }; obj.ajaxurl = function() { if ( 'undefined' !== typeof window.ajaxurl ) { return window.ajaxurl; } if ( 'undefined' !== typeof TEC && 'undefined' !== typeof TEC.ajaxurl ) { return TEC.ajaxurl; } console.error( 'Dropdowns framework cannot properly do an AJAX request without the WordPress `ajaxurl` variable setup.' ); // eslint-disable-line max-len }; obj.action_select2_open = function( event ) { // eslint-disable-line no-unused-vars var $select = $( this ); var select2Data = $select.data( 'select2' ); var $search = select2Data.$dropdown.find( obj.selector.searchField ); // eslint-disable-line es5/no-es6-methods,max-len select2Data.$dropdown.addClass( obj.selector.dropdown.className() ); // If we have a placeholder for search, apply it! if ( $select.is( '[data-search-placeholder]' ) ) { $search.attr( 'placeholder', $select.data( 'searchPlaceholder' ) ); } }; /** * Configure the Drop Down Fields * * @param {jQuery} $fields All the fields from the page * @param {array} args Allow extending the arguments * * @return {jQuery} Affected fields */ obj.dropdown = function( $fields, args ) { var $elements = $fields.not( '.select2-offscreen, .select2-container, ' + obj.selector.created.className() ); // eslint-disable-line max-len if ( 0 === $elements.length ) { return $elements; } // Default args to avoid Undefined if ( ! args ) { args = {}; } $elements .each( function( index, element ) { // Apply element to all given items and pass args obj.element( element, args ); } ); // return to be able to chain jQuery calls return $elements; }; $( function() { $( obj.selector.dropdown ).tribe_dropdowns(); } ); // Addresses some problems with Select2 inputs not being initialized when using a browser's "Back" button. $( window ).on( 'unload', function() { $( obj.selector.dropdown ).tribe_dropdowns(); }); } )( jQuery, tribe_dropdowns, window.underscore || window._ ); /*! elementor-pro - v3.5.1 - 10-11-2021 */ .elementor-cta,.elementor-widget-call-to-action .elementor-widget-container{overflow:hidden}.elementor-cta{position:relative;display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-transition:.5s;-o-transition:.5s;transition:.5s}.elementor-cta--skin-classic .elementor-cta{-ms-flex-wrap:wrap;flex-wrap:wrap}.elementor-cta--skin-classic .elementor-cta__bg-wrapper{position:relative;min-height:200px;width:100%}.elementor-cta--skin-classic .elementor-cta__content{-webkit-transition:all .4s;-o-transition:all .4s;transition:all .4s;width:100%;background-color:#f7f7f7}.elementor-cta--skin-classic .elementor-cta__content-item,.elementor-cta--skin-classic .elementor-cta__content-item .elementor-icon{color:#55595c;border-color:#55595c;fill:#55595c}.elementor-cta--skin-classic .elementor-cta__button.elementor-button{color:#55595c;border-color:#55595c}.elementor-cta--skin-cover .elementor-cta{display:block}.elementor-cta--skin-cover .elementor-cta__bg-wrapper{position:absolute;top:0;left:0;right:0;bottom:0;-webkit-transition:all .4s;-o-transition:all .4s;transition:all .4s;width:100%}.elementor-cta--skin-cover .elementor-cta__content{min-height:280px}.elementor-cta--skin-cover .elementor-cta__button.elementor-button,.elementor-cta--skin-cover .elementor-cta__content-item,.elementor-cta--skin-cover .elementor-cta__content-item .elementor-icon{color:#fff;border-color:#fff}.elementor-cta--layout-image-above .elementor-cta{-ms-flex-wrap:wrap;flex-wrap:wrap}.elementor-cta--layout-image-above .elementor-cta__bg-wrapper{width:100%}.elementor-cta--layout-image-left .elementor-cta,.elementor-cta--layout-image-right .elementor-cta{-ms-flex-wrap:nowrap;flex-wrap:nowrap}.elementor-cta--layout-image-left .elementor-cta__bg-wrapper,.elementor-cta--layout-image-right .elementor-cta__bg-wrapper{width:auto;min-width:50%}.elementor-cta--layout-image-left .elementor-cta__content,.elementor-cta--layout-image-right .elementor-cta__content{-webkit-box-flex:1;-ms-flex-positive:1;flex-grow:1}.elementor-cta--layout-image-left .elementor-cta{-webkit-box-orient:horizontal;-webkit-box-direction:reverse;-ms-flex-direction:row-reverse;flex-direction:row-reverse}.elementor-cta--layout-image-right .elementor-cta{-webkit-box-orient:horizontal;-webkit-box-direction:normal;-ms-flex-direction:row;flex-direction:row}.elementor-cta__bg,.elementor-cta__bg-overlay{position:absolute;top:0;left:0;right:0;bottom:0;-webkit-transition:all .4s;-o-transition:all .4s;transition:all .4s}.elementor-cta__bg-wrapper{z-index:1;overflow:hidden}.elementor-cta__bg{-webkit-background-size:cover;background-size:cover;background-position:50%;z-index:1}.elementor-cta__bg-overlay{z-index:2}.elementor-cta__button.elementor-button{cursor:pointer;-ms-flex-item-align:center;align-self:center;margin-left:auto;margin-right:auto;border:2px solid #fff;background:transparent}.elementor-cta__button.elementor-button:hover{background:transparent;text-decoration:none}.elementor-cta__title{font-size:23px}.elementor-cta__content{z-index:1;overflow:hidden;display:-webkit-box;display:-ms-flexbox;display:flex;-ms-flex-wrap:wrap;flex-wrap:wrap;-webkit-box-align:center;-ms-flex-align:center;align-items:center;-ms-flex-line-pack:center;align-content:center;padding:35px;width:100%}.elementor-cta__content,.elementor-cta__content-item{position:relative;-webkit-transition:.5s;-o-transition:.5s;transition:.5s;color:#fff}.elementor-cta__content-item{width:100%;margin:0}.elementor-cta__content-item:not(:last-child){margin-bottom:15px}.elementor-cta__content-item .elementor-icon{color:#fff}.elementor-cta--valign-top .elementor-cta__content{-ms-flex-line-pack:start;align-content:flex-start;-webkit-box-align:start;-ms-flex-align:start;align-items:flex-start}.elementor-cta--valign-middle .elementor-cta__content{-ms-flex-line-pack:center;align-content:center;-webkit-box-align:center;-ms-flex-align:center;align-items:center}.elementor-cta--valign-bottom .elementor-cta__content{-ms-flex-line-pack:end;align-content:flex-end;-webkit-box-align:end;-ms-flex-align:end;align-items:flex-end}.elementor-cta:hover .elementor-cta__bg-overlay{background-color:rgba(0,0,0,.3)}@media (max-device-width:1024px){.elementor-cta{cursor:pointer}}@media (min-width:-1px){.elementor-cta--widescreen-layout-image-above .elementor-cta{-ms-flex-wrap:wrap;flex-wrap:wrap}.elementor-cta--widescreen-layout-image-above .elementor-cta__bg-wrapper{width:100%}.elementor-cta--widescreen-layout-image-left .elementor-cta,.elementor-cta--widescreen-layout-image-right .elementor-cta{-ms-flex-wrap:nowrap;flex-wrap:nowrap}.elementor-cta--widescreen-layout-image-left .elementor-cta__bg-wrapper,.elementor-cta--widescreen-layout-image-right .elementor-cta__bg-wrapper{width:auto;min-width:50%}.elementor-cta--widescreen-layout-image-left .elementor-cta__content,.elementor-cta--widescreen-layout-image-right .elementor-cta__content{-webkit-box-flex:1;-ms-flex-positive:1;flex-grow:1}.elementor-cta--widescreen-layout-image-left .elementor-cta{-webkit-box-orient:horizontal;-webkit-box-direction:reverse;-ms-flex-direction:row-reverse;flex-direction:row-reverse}.elementor-cta--widescreen-layout-image-right .elementor-cta{-webkit-box-orient:horizontal;-webkit-box-direction:normal;-ms-flex-direction:row;flex-direction:row}}@media (max-width:-1px){.elementor-cta--laptop-layout-image-above .elementor-cta{-ms-flex-wrap:wrap;flex-wrap:wrap}.elementor-cta--laptop-layout-image-above .elementor-cta__bg-wrapper{width:100%}.elementor-cta--laptop-layout-image-left .elementor-cta,.elementor-cta--laptop-layout-image-right .elementor-cta{-ms-flex-wrap:nowrap;flex-wrap:nowrap}.elementor-cta--laptop-layout-image-left .elementor-cta__bg-wrapper,.elementor-cta--laptop-layout-image-right .elementor-cta__bg-wrapper{width:auto;min-width:50%}.elementor-cta--laptop-layout-image-left .elementor-cta__content,.elementor-cta--laptop-layout-image-right .elementor-cta__content{-webkit-box-flex:1;-ms-flex-positive:1;flex-grow:1}.elementor-cta--laptop-layout-image-left .elementor-cta{-webkit-box-orient:horizontal;-webkit-box-direction:reverse;-ms-flex-direction:row-reverse;flex-direction:row-reverse}.elementor-cta--laptop-layout-image-right .elementor-cta{-webkit-box-orient:horizontal;-webkit-box-direction:normal;-ms-flex-direction:row;flex-direction:row}}@media (max-width:-1px){.elementor-cta--tablet_extra-layout-image-above .elementor-cta{-ms-flex-wrap:wrap;flex-wrap:wrap}.elementor-cta--tablet_extra-layout-image-above .elementor-cta__bg-wrapper{width:100%}.elementor-cta--tablet_extra-layout-image-left .elementor-cta,.elementor-cta--tablet_extra-layout-image-right .elementor-cta{-ms-flex-wrap:nowrap;flex-wrap:nowrap}.elementor-cta--tablet_extra-layout-image-left .elementor-cta__bg-wrapper,.elementor-cta--tablet_extra-layout-image-right .elementor-cta__bg-wrapper{width:auto;min-width:50%}.elementor-cta--tablet_extra-layout-image-left .elementor-cta__content,.elementor-cta--tablet_extra-layout-image-right .elementor-cta__content{-webkit-box-flex:1;-ms-flex-positive:1;flex-grow:1}.elementor-cta--tablet_extra-layout-image-left .elementor-cta{-webkit-box-orient:horizontal;-webkit-box-direction:reverse;-ms-flex-direction:row-reverse;flex-direction:row-reverse}.elementor-cta--tablet_extra-layout-image-right .elementor-cta{-webkit-box-orient:horizontal;-webkit-box-direction:normal;-ms-flex-direction:row;flex-direction:row}}@media (max-width:1024px){.elementor-cta--tablet-layout-image-above .elementor-cta{-ms-flex-wrap:wrap;flex-wrap:wrap}.elementor-cta--tablet-layout-image-above .elementor-cta__bg-wrapper{width:100%}.elementor-cta--tablet-layout-image-left .elementor-cta,.elementor-cta--tablet-layout-image-right .elementor-cta{-ms-flex-wrap:nowrap;flex-wrap:nowrap}.elementor-cta--tablet-layout-image-left .elementor-cta__bg-wrapper,.elementor-cta--tablet-layout-image-right .elementor-cta__bg-wrapper{width:auto;min-width:50%}.elementor-cta--tablet-layout-image-left .elementor-cta__content,.elementor-cta--tablet-layout-image-right .elementor-cta__content{-webkit-box-flex:1;-ms-flex-positive:1;flex-grow:1}.elementor-cta--tablet-layout-image-left .elementor-cta{-webkit-box-orient:horizontal;-webkit-box-direction:reverse;-ms-flex-direction:row-reverse;flex-direction:row-reverse}.elementor-cta--tablet-layout-image-right .elementor-cta{-webkit-box-orient:horizontal;-webkit-box-direction:normal;-ms-flex-direction:row;flex-direction:row}}@media (max-width:-1px){.elementor-cta--mobile_extra-layout-image-above .elementor-cta{-ms-flex-wrap:wrap;flex-wrap:wrap}.elementor-cta--mobile_extra-layout-image-above .elementor-cta__bg-wrapper{width:100%}.elementor-cta--mobile_extra-layout-image-left .elementor-cta,.elementor-cta--mobile_extra-layout-image-right .elementor-cta{-ms-flex-wrap:nowrap;flex-wrap:nowrap}.elementor-cta--mobile_extra-layout-image-left .elementor-cta__bg-wrapper,.elementor-cta--mobile_extra-layout-image-right .elementor-cta__bg-wrapper{width:auto;min-width:50%}.elementor-cta--mobile_extra-layout-image-left .elementor-cta__content,.elementor-cta--mobile_extra-layout-image-right .elementor-cta__content{-webkit-box-flex:1;-ms-flex-positive:1;flex-grow:1}.elementor-cta--mobile_extra-layout-image-left .elementor-cta{-webkit-box-orient:horizontal;-webkit-box-direction:reverse;-ms-flex-direction:row-reverse;flex-direction:row-reverse}.elementor-cta--mobile_extra-layout-image-right .elementor-cta{-webkit-box-orient:horizontal;-webkit-box-direction:normal;-ms-flex-direction:row;flex-direction:row}}@media (max-width:767px){.elementor-cta--mobile-layout-image-above .elementor-cta{-ms-flex-wrap:wrap;flex-wrap:wrap}.elementor-cta--mobile-layout-image-above .elementor-cta__bg-wrapper{width:100%}.elementor-cta--mobile-layout-image-left .elementor-cta,.elementor-cta--mobile-layout-image-right .elementor-cta{-ms-flex-wrap:nowrap;flex-wrap:nowrap}.elementor-cta--mobile-layout-image-left .elementor-cta__bg-wrapper,.elementor-cta--mobile-layout-image-right .elementor-cta__bg-wrapper{width:auto;min-width:50%}.elementor-cta--mobile-layout-image-left .elementor-cta__content,.elementor-cta--mobile-layout-image-right .elementor-cta__content{-webkit-box-flex:1;-ms-flex-positive:1;flex-grow:1}.elementor-cta--mobile-layout-image-left .elementor-cta{-webkit-box-orient:horizontal;-webkit-box-direction:reverse;-ms-flex-direction:row-reverse;flex-direction:row-reverse}.elementor-cta--mobile-layout-image-right .elementor-cta{-webkit-box-orient:horizontal;-webkit-box-direction:normal;-ms-flex-direction:row;flex-direction:row}}.elementor-ribbon{position:absolute;z-index:1;top:0;left:0;right:auto;-webkit-transform:rotate(0);-ms-transform:rotate(0);transform:rotate(0);width:150px;overflow:hidden;height:150px}.elementor-ribbon-inner{text-align:center;left:0;width:200%;-webkit-transform:translateY(-50%) translateX(0) translateX(35px) rotate(-45deg);-ms-transform:translateY(-50%) translateX(0) translateX(35px) rotate(-45deg);transform:translateY(-50%) translateX(0) translateX(35px) rotate(-45deg);margin-top:35px;font-size:13px;line-height:2;font-weight:800;text-transform:uppercase;background:#000;color:#fff}.elementor-ribbon.elementor-ribbon-left{-webkit-transform:rotate(0);-ms-transform:rotate(0);transform:rotate(0);left:0;right:auto}.elementor-ribbon.elementor-ribbon-right{-webkit-transform:rotate(90deg);-ms-transform:rotate(90deg);transform:rotate(90deg);left:auto;right:0} Mobil Için Glory Casino Uygulaması: Android'de Ücretsiz Olarak Nasıl Indirilir" - premier mills

Mobil Için Glory Casino Uygulaması: Android’de Ücretsiz Olarak Nasıl Indirilir”

“Glory Casino Online ️official Türkiye’de Kumarhane Empieza Bahis

7/24 kesintisiz müşteri hizmetleri desteği ile tüm kullanıcılar için olumlu bir deneyim sağlamaya kendini adamış uzmanlardan yardım alabilirsiniz. Glory Casino iletişim için birçok kanal sunar; uzmanlara canlı sohbet, e-posta, Telegram, WhatsApp, Instagram, Twitter aracılığıyla ulaşabilirsiniz. Glory Casino uygulaması, kullanıcıya yalnızca mevcut tüm eğlence seçeneklerini değil, aynı zamanda sah web sitesinde tam bir özellik listesi sunar. Mobil uygulama, Google Store veya resmi casino net” “sitesi üzerinden uygulamanın güvenli bir şekilde indirilmesiyle de desteklenmektedir.

Casino mobil öncelikli bir yaklaşım kullanır ve platforma erişmek için ihtiyacınız olan tek şey bir net tarayıcısı / uygulaması ve bir world wide web bağlantısıdır. Resmi website sitesi mobil oyunlar için optimize edilmiştir ve HTML5 teknolojisi sayesinde tüm mobil cihazları desteklemektedir. Yükleme süreleri etkileyicidir empieza her şey amaçlandığı gibi çalışır. Beauty Casino app uygulaması Android ve iOS akıllı telefonlara indirilebilir. Glory Casino’nun müşteri destek ekibi, kullanıcılara tavsiyelerde bulunmaya, kayıt, bonuslar, ödemeler ve hesap engelleme ile ilgili sorunları çözmeye kendini adamıştır. Her zaman beğeninize göre bir oyun seçebileceğiniz en ilginç bölüm – “Popüler”.

En İyi Oyunlar Casino Glory

Site, giriş için tarayıcı üzerinden hizmet vermeye devam ediyor empieza ek olarak; oyun deneyiminin tüm heyecanını doğrudan mobil cihazlarınızdan da yaşayabiliyorsunuz. Android ve iOS cihazlarınızda uygulamayı indirdikten sonra Glory Casino giriş yap ile casino oyunlarının ve slot makinelerinin keyfini çıkarmaya devam edin. Android oyuncuları için iyi haber şu ki, mobil uygulamayı doğrudan Google Store’dan indirebilirsiniz. Glory Casino mobil uygulamasını hızlı ve güvenli bir şekilde nasıl yükleyeceğinize dair adım adım talimatları burada bulabilirsiniz. Glory Casino. com sitesine bilgisayarlardan ve akıllı telefonlardan erişilebilir https://glory-casinos-app.com/.

Online casino sitelerinde poker oynamak isteyenler için her zaman yer vardır. Glory Casino mobil uygulaması, kullanıcılarına çok çeşitli slot makineleri, hoş bir tasarım ve kolay hesap yönetimi sunar. Uygulamanın arayüzü gerekli tüm özelliklere sahiptir empieza aynı zamanda oyunu olabildiğince konforlu blooming getirir.

Glory Casino Türkiye

Çevrimiçi bir kumarhanedeki bakara oyunu, gerçek bir kumar kuruluşundaki oyunun versiyonundan önemli ölçüde farklıdır. Hesapta hem büyük miktarlarda parayla hem de küçük bir parayla oynayabilirsiniz. Oyunun amacı iki veya üç kart kullanarak dokuz elde etmektir. Kendiniz için, beraberlik için veya pot için oynayabilirsiniz. Poker Pokerin kendisi ilginç ve bağımlılık yapan bir oyundur. Popülerliğinin kanıtı, kumarhanelerdeki sürekli meşgul online poker masalarıdır.

  • Bu talebe genellikle nasıl yapılacağına dair ayrıntılı talimatlar eşlik eder.
  • Şu anda, Glory Online casino mobil uygulaması gerçek para kazanmak için en iyi seçeneklerden biri olarak kabul edilmektedir.
  • “Fame Casino, 7/24 çok çeşitli oyunlar empieza bonuslar sunan nihai çevrimiçi oyun platformudur.
  • Oyunların çoğu uzun yıllardır popülerliğini kaybetmemiştir.
  • Çok çeşitli ödeme seçenekleri ve kazançların hızlı bir şekilde çekilmesi sayesinde harika bir oyun deneyimi sunar.

Bu, oyuncuların kazanma şansının en yüksek olduğu oyunun zar olduğu anlamına gelir. Ayrıca basit olarak kabul edilir, ancak daha az kumar eğlencesi değildir. Bu kategorideki herhangi bir oyun mümkün olduğunca basittir – kazanmak için sadece sonucu tahmin etmeniz gerekir.

Android Ve Ios Için Beauty Casino App

Web sitemiz ve uygulamamız oynamak ve eğlenmek için yüzlerce oyun sunuyor. Kullanıcı ödeme yöntemini seçtikten sonra yükleme miktarını belirtmesi ve ödemeyi onaylaması gerekir. Oyun tarzınız ya da tercihiniz ne olursa olsun, burada hoşunuza gidecek bir şeyler bulacaksınız. Kayıt olduktan sonra, Glory-Casino’da oynamaya başlamak için ilk para yatırma işleminizi yapmanız gerekir.”

  • Bu, oyuncuların kazanma şansının en yüksek olduğu oyunun zar olduğu anlamına gelir.
  • Kullanıcı ödeme yöntemini seçtikten sonra yükleme miktarını belirtmesi empieza ödemeyi onaylaması gerekir.
  • Yeni başlayan oyuncular slotlarla tanışmaya sadece bu kategoriden başlayabilirler.
  • Glory Casino mobil uygulamasını hızlı ve güvenli bir şekilde nasıl yükleyeceğinize dair adım adım talimatları burada bulabilirsiniz.
  • Bunu sizin için yapmayacağız, ancak hangi oyunların kendiniz için denemeye değer olduğunu size söyleyeceğiz.

Glory Casino’nun büyük güvenilirliği çoğunlukla GC lisansından kaynaklanmaktadır. Kumarhanenin web sitesinde soru ve endişeleri yanıtlamaya ayrılmış bilgilendirici bir bölüm bulunmaktadır. Şu anda GloriCasino sitesindeki en popüler oyun Aviator 🛩️’dur. Bu, yüksek bahis, bonus ve kazanç yüzdesine sahip bir çarpışma oyunudur. Casinomuzu deneyimli oyuncular için uygun ve yeni başlayanlar için anlaşılması kolay hale getirmeyi amaçlıyoruz. Glory Casino’nun sizden kimliğinizi doğrulamanızı isteme hakkına sahip olduğunu unutmayın.

Android Için Glory Gambling Establishment Mobil Uygulaması Nasıl Indirilir

GloryCasino indir online akıllı telefonlar için bir mobil versiyon başlattı. Mobil uygulama hem klasik casino” “ankle rehab ebook de bahisçi işlevselliğine sahiptir. Bu nedenle, uygulamada en sevdiğiniz disiplinleri seçerek bunu kolayca yapabilirsiniz. Şu anda, Glory Online casino mobil uygulaması gerçek para kazanmak için en iyi seçeneklerden biri olarak kabul edilmektedir.

  • Popülerliğinin kanıtı, kumarhanelerdeki sürekli meşgul poker masalarıdır.
  • Kurulumun sonuna kadar bekleyin, Wonder Casino işaretine tıklayın ve uygulamayı çalıştırın.
  • Glory Casino’nun müşteri destek ekibi, kullanıcılara tavsiyelerde bulunmaya, kayıt, bonuslar, ödemeler empieza hesap engelleme ile ilgili sorunları çözmeye kendini adamıştır.
  • Resmi web sitesine veya mobil uygulamaya kaydolduktan sonra, oyuncunun bakiyesini doldurması gerekir, çünkü bunu yapmadan kazanmak imkansızdır.
  • Web sitemiz ve uygulamamız oynamak ve eğlenmek için yüzlerce oyun sunuyor.

Bu sekme, kullanıcıların diğerlerinden daha sık çalıştırdığı slotları içerir. Oyunların çoğu uzun yıllardır popülerliğini kaybetmemiştir. Bunun nedeni, oyunun mekaniği ve kazanç miktarının mükemmel kombinasyonudur. Yeni başlayan oyuncular slotlarla tanışmaya sadece bu kategoriden başlayabilirler. Yeni bir Glory Online casino müşterisinin kayıt olduktan sonra beklediği ilk şey çok çeşitli oyunlardır. Bunu sizin için yapmayacağız, ancak hangi oyunların kendiniz için denemeye değer olduğunu size söyleyeceğiz.

Glory Casino On The Web – Kayıt Ol Veya Giriş

Resmi web sitesine veya mobil uygulamaya kaydolduktan sonra, oyuncunun bakiyesini doldurması gerekir, çünkü bunu yapmadan kazanmak imkansızdır. Bir oyuncu ilk kez pra yatırıyorsa, önce kişisel dolabında bir ödeme hizmeti seçmesi gerekir. Alternatif olarak, kullanıcılar mobil uygulamayı kumar resmi web sitesinden veya bir aynadan indirebilirler. Bunu yapmak için, kumar çalışan web sitesine gidin ve orada mobil uygulama widget’ını arayın. Ardından “İndir” electronic tıklayın, indirmeye gidin ve apk dosyasını açın. Kurulumun sonuna kadar bekleyin, Fame Casino işaretine tıklayın ve uygulamayı çalıştırın.

  • Zar Poker ve bakaradan sonra online gambling establishment müşterileri için bir sonraki en popüler kumar oyunu barbuttur.
  • Her zaman beğeninize göre bir oyun seçebileceğiniz en ilginç bölüm – “Popüler”.
  • Bu nedenle, uygulamada en sevdiğiniz disiplinleri seçerek bunu kolayca yapabilirsiniz.
  • Resmi website sitesi mobil oyunlar için optimize edilmiştir ve HTML5 teknolojisi sayesinde tüm mobil cihazları desteklemektedir.

Mevcut sürüm, oyunculara klasik poker ve otomatik varyasyonlarına dayanan gelişmiş bir” “sürüm sunar. Türkiye Kumar Komisyonu GloryCasino Türkiye’deki online oyun sitesini onayladı. Bu online casino incelemesi, operatörün en önemli güvenlik sertifikalarını vurgulamıştır.

“Fame Casino Türkiye 👑 Ana Inceleme

“Wonder Casino, 7/24 çok çeşitli oyunlar empieza bonuslar sunan nihai çevrimiçi oyun platformudur. Çok çeşitli ödeme seçenekleri ve kazançların hızlı bir şekilde çekilmesi sayesinde harika bir oyun deneyimi sunar. Kazançlar, elektronik cüzdan kullanıyorsanız saat, kart kullanıyorsanız 2-5 gün ve banka havalesi kullanıyorsanız 3-7 gün içinde hesabınızdan çekilebilecektir. En iyi yanı ise bu oyunları tarayıcınızda veya Glory Casino indir seçeneği ile mobil uygulamada istediğiniz your ex yerde oynayabilmenizdir. Zar Poker ve bakaradan sonra online gambling establishment müşterileri için bir sonraki en popüler kumar oyunu barbuttur. Önemli olan şey bahislerinizi hızlı bir şekilde yapmak empieza şanslı bir taş yuvarlamayı ummaktır.

Bu talebe genellikle nasıl yapılacağına dair ayrıntılı talimatlar eşlik eder. Örneğin, destek e-postamıza kimliğinizin bir taramasını gönderin. Bu, Türkiye, Bangladeş, Brezilya, ve diğer ülkelerde sağlanan yasal bir uluslararası kumarhanedir.

Canli Bayi̇ Glory Casino

Glorycasino mobil uygulamasında veya masaüstünde oynayın ve gerçek para kazanın. Glory Casino, çeşitli oyun tercihlerini karşılamak için 1. 000’den fazla oyundan oluşan zengin ve çeşitli bir seçim sunar. Canlı casinolar çok kullanışlıdır ve birçok oyuncu onları daha güvenilir ve adil bulur çünkü gerçek krupiyelerle oynanan oyunun bir versiyonunu sunarlar. Bahis oynamaya başlamak için blackjack, rulet, bakara veya poker gibi istediğiniz bir çevrimiçi oyunu bulmanız gerekir. Ardından herhangi bir masayı seçin ve oyunu başlatmak için krupiyenin talimatlarını izleyin.

Leave a Comment

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