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} Casino en ligne Quatro Les meilleurs jeux de casino.354 (2) - premier mills

Casino en ligne Quatro Les meilleurs jeux de casino.354 (2)

Содержимое

Casino en ligne Quatro – Les meilleurs jeux de casino

Quatro Casino est l’un des casinos en ligne les plus populaires et les plus fiables du marché. Depuis sa création, il a réussi à gagner la confiance de millions de joueurs du monde entier. Avec sa plateforme de jeu en ligne, Quatro Casino offre une expérience de jeu de casino en ligne exceptionnelle, avec des jeux de casino de haute qualité, des bonus réguliers et des promotions attractives.

Les jeux de casino de Quatro sont nombreux et variés, allant des jeux de table classiques comme le blackjack et le roulette, aux jeux de machine à sous les plus récents et aux jeux de loterie. Vous pouvez également profiter de nos jeux de casino mobile, conçus spécifiquement pour les joueurs qui aiment jouer sur leurs appareils mobiles.

Les joueurs canadiens peuvent également profiter de notre offre spéciale de casino en ligne Quatro Canada, qui leur offre la possibilité de jouer en français et de profiter de nos jeux de casino en ligne les plus populaires.

Si vous êtes nouveau sur Quatro Casino, vous pouvez vous inscrire en quelques minutes et commencer à jouer immédiatement. Vous pouvez également vous connecter à votre compte en utilisant vos informations de connexion.

Les joueurs de Quatro Casino peuvent également profiter de nos récompenses régulières, telles que les bonus de bienvenue, les bonus de reload et les promotions spéciales. Nos récompenses sont conçues pour vous aider à maximiser vos gains et à améliorer votre expérience de jeu.

En résumé, Quatro Casino est l’un des meilleurs casinos en ligne du marché, offrant une expérience de jeu de casino en ligne exceptionnelle, des jeux de casino de haute qualité et des récompenses régulières. Allez-y et découvrez pourquoi Quatro Casino est l’un des casinos en ligne les plus populaires du monde.

Quelques-uns des avantages de jouer sur Quatro Casino :

  • Plus de 500 jeux de casino en ligne
  • Bonus de bienvenue de 100% jusqu’à 200€
  • Bonus de reload de 50% jusqu’à 100€
  • Plateforme de jeu mobile
  • Jeux de casino en français
  • Service client disponible 24/7

Vous êtes prêt à commencer ? Allez-y et inscrivez-vous maintenant !

Casino en ligne Quatro: Les meilleurs jeux de casino

Quatro Casino Canada is a popular online casino that offers a wide range of games to its players. With a user-friendly interface and a variety of payment options, Quatro Casino is a great choice for those who want to play online casino games. In this article, we will explore the best games offered by Quatro Casino, including slots, table games, and video poker.

Quatro Casino Games

Quatro Casino offers a vast selection of games, including:

Slots: Quatro Casino has a vast collection of slots, including classic slots, video slots, and progressive slots. Some of the most popular slots include Book of Ra, Sizzling Hot, and Mega Moolah.

Table Games: Quatro Casino offers a range of table games, including blackjack, roulette, and baccarat. Players can choose from different variants, such as European Roulette, American Roulette, and French Roulette.

Video Poker: Quatro Casino offers a variety of video poker games, including Jacks or Better, Deuces Wild, and All American.

Quatro Casino Rewards

Quatro Casino offers a loyalty program that rewards players for their deposits and gameplay. The program is divided into five levels, each with its own set of benefits, including:

Bronze: 1% cashback on deposits

Silver: 2% cashback on deposits

Gold: 3% cashback on deposits

Platinum: 5% cashback on deposits

Diamond: 10% cashback on deposits

Quatro Casino Mobile

Quatro Casino is available on mobile devices, allowing players to access their favorite games on-the-go. The mobile version of the casino is optimized for both iOS and Android devices, making it easy to play on the move.

Quatro casino quatro Casino Français

Quatro Casino also offers a French version of its website, making it easy for French-speaking players to access their favorite games. The French version of the website is available at [www.quatro-casino.fr](http://www.quatro-casino.fr).

Quatro Casino Connexion

Quatro Casino offers a secure and reliable connection, ensuring that players’ personal and financial information is protected. The casino uses 128-bit SSL encryption to secure all transactions, making it a safe and trustworthy option for players.

Quatro Casino Login

To access Quatro Casino, players need to create an account and log in using their username and password. The login process is quick and easy, and players can access their account information and game history at any time.

Quatro Casino Canada

Quatro Casino is available to players in Canada, offering a range of games and promotions to its Canadian players. The casino is licensed and regulated by the Malta Gaming Authority, ensuring that it operates fairly and securely.

In conclusion, Quatro Casino is a great option for those who want to play online casino games. With a wide range of games, a user-friendly interface, and a variety of payment options, Quatro Casino is a great choice for players. Whether you’re a seasoned player or a newcomer to online casino games, Quatro Casino is definitely worth checking out.

Game
Features

Book of Ra 5 reels, 10 paylines, free spins Sizzling Hot 5 reels, 5 paylines, wild symbol Mega Moolah 5 reels, 25 paylines, progressive jackpot European Roulette single zero, outside bets, inside bets Jacks or Better 5 reels, 25 paylines, wild symbol, free spins

La sélection des meilleurs jeux de casino

Quand vous vous inscrivez au quatro casino, vous avez accès à une grande variété de jeux de casino en ligne. Mais comment choisir les meilleurs ? C’est ce que nous allons vous expliquer dans cet article.

La première étape consiste à définir vos objectifs. Qu’est-ce que vous cherchez dans un jeu de casino ? Vous voulez-vous distraire, gagner de l’argent ou simplement vous amuser ? En connaissant vos objectifs, vous pourrez choisir les jeux qui correspondent le mieux à vos attentes.

Ensuite, il est important de considérer les règles du jeu. Les règles peuvent varier en fonction du jeu et du fournisseur de jeux. Il est donc essentiel de comprendre les règles avant de commencer à jouer. De plus, il est important de vérifier si le jeu est disponible en français, car cela peut faciliter votre expérience de jeu.

La connexion au quatro casino est également un aspect important à considérer. Vous devez vous assurer que la connexion est sécurisée et que vos données personnelles sont protégées. Vous pouvez vérifier si le site web est sécurisé en regardant si l’adresse URL commence par “https” et non par “http”.

Enfin, il est important de considérer les récompenses et les avantages offerts par le quatro casino. Certains jeux offrent des récompenses et des avantages à long terme, tandis que d’autres offrent des récompenses immédiates. Il est donc important de comprendre les conditions des récompenses et des avantages avant de commencer à jouer.

En résumé, pour choisir les meilleurs jeux de casino, il est important de définir vos objectifs, de comprendre les règles du jeu, de vérifier la connexion au quatro casino, de considérer les récompenses et les avantages offerts. En suivant ces étapes, vous pourrez choisir les jeux qui correspondent le mieux à vos attentes et vous offrent la meilleure expérience de jeu possible.

Quand vous êtes prêt à commencer à jouer, vous pouvez vous inscrire au quatro casino et commencer à explorer les différents jeux disponibles. N’oubliez pas de vérifier les conditions des récompenses et des avantages avant de commencer à jouer. Vous pouvez également vous connecter au quatro casino canada pour jouer en français.

En résumé, le quatro casino est un endroit où vous pouvez vous distraire, gagner de l’argent ou simplement vous amuser. En suivant les étapes ci-dessus, vous pourrez choisir les jeux qui correspondent le mieux à vos attentes et vous offrent la meilleure expérience de jeu possible.

Quand vous êtes prêt à commencer à jouer, vous pouvez vous inscrire au quatro casino et commencer à explorer les différents jeux disponibles. N’oubliez pas de vérifier les conditions des récompenses et des avantages avant de commencer à jouer. Vous pouvez également vous connecter au quatro casino françaïs pour jouer en français.

En résumé, le quatro casino est un endroit où vous pouvez vous distraire, gagner de l’argent ou simplement vous amuser. En suivant les étapes ci-dessus, vous pourrez choisir les jeux qui correspondent le mieux à vos attentes et vous offrent la meilleure expérience de jeu possible.

Les avantages de jouer aux jeux de casino en ligne

Jouer aux jeux de casino en ligne offre de nombreux avantages par rapport aux casinos traditionnels. Voici quelques-uns des plus importants :

Confort et flexibilité

Vous pouvez jouer en ligne à partir de votre ordinateur ou de votre appareil mobile, où que vous soyez dans le monde.

Vous pouvez choisir de jouer à tout moment de la journée ou de la nuit, sans avoir à vous soucier de la distance ou des horaires de fermeture.

Vous pouvez même jouer en même temps que vos amis ou votre famille, grâce à la fonctionnalité de jeu en ligne.

  • Vous pouvez choisir de jouer à tout moment de la journée ou de la nuit
  • Vous pouvez jouer en même temps que vos amis ou votre famille
  • Vous pouvez choisir de jouer à partir de votre ordinateur ou de votre appareil mobile

Sécurité et confidentialité

Les casinos en ligne utilisent des systèmes de sécurité de pointe pour protéger vos données et vos transactions.

Vous pouvez être sûr que vos informations personnelles sont sécurisées et confidentielles.

Vous pouvez même utiliser des méthodes de paiement sécurisées, telles que les cartes de crédit ou les systèmes de paiement en ligne.

  • Les casinos en ligne utilisent des systèmes de sécurité de pointe
  • Vos informations personnelles sont sécurisées et confidentielles
  • Vous pouvez utiliser des méthodes de paiement sécurisées
  • Choix et variété

    Les casinos en ligne offrent une grande variété de jeux de casino, y compris les jeux de table, les machines à sous et les jeux de loterie.

    Vous pouvez choisir de jouer à des jeux qui vous plaisent, ou même essayer de nouveaux jeux pour vous divertir.

    Vous pouvez même jouer à des jeux qui ne sont pas disponibles dans les casinos traditionnels.

    • Les casinos en ligne offrent une grande variété de jeux de casino
    • Vous pouvez choisir de jouer à des jeux qui vous plaisent
    • Vous pouvez même essayer de nouveaux jeux pour vous divertir

    Quelques mots sur Quatro Casino

    Quatro Casino est un exemple de casino en ligne qui offre de nombreux avantages, notamment une grande variété de jeux, une connexion sécurisée et des méthodes de paiement sécurisées.

    Quatro Casino est disponible en français, en anglais et en plusieurs autres langues, ce qui en fait un choix idéal pour les joueurs internationaux.

    Quatro Casino est même disponible sur mobile, ce qui vous permet de jouer partout où vous êtes.

    En résumé, jouer aux jeux de casino en ligne offre de nombreux avantages, notamment le confort et la flexibilité, la sécurité et la confidentialité, et la variété des jeux. Quatro Casino est un exemple de casino en ligne qui offre de nombreux avantages, notamment une grande variété de jeux, une connexion sécurisée et des méthodes de paiement sécurisées.

    Les règles du jeu et les stratégies pour gagner

    When it comes to playing at Quatro Casino, it’s essential to understand the rules of the game and develop strategies to increase your chances of winning. In this section, we’ll delve into the world of online casino gaming and provide you with valuable insights to help you make the most of your experience.

    Understanding the Rules of the Game

    Before you start playing, it’s crucial to understand the rules of the game you’ve chosen. Whether it’s slots, blackjack, or roulette, each game has its unique set of rules and objectives. Take the time to read and understand the rules, as this will help you make informed decisions and avoid costly mistakes.

    Developing a Winning Strategy

    A well-thought-out strategy can make all the difference in your gaming experience. Here are a few tips to help you develop a winning strategy:

    Set a budget: Decide how much you’re willing to spend and stick to it. This will help you avoid overspending and ensure you have enough funds for future gaming sessions.

    Choose the right game: Select a game that suits your skill level and preferences. For example, if you’re new to online casino gaming, you may want to start with a game that has a lower house edge, such as blackjack.

    Manage your bankroll: Make sure to manage your bankroll effectively by setting limits and tracking your progress. This will help you stay on top of your finances and avoid financial difficulties.

    Take advantage of bonuses: Quatro Casino offers a range of bonuses and promotions to help you get started. Take advantage of these offers to boost your bankroll and increase your chances of winning.

    Quatro Casino’s Rewards Program

    Quatro Casino’s rewards program is designed to reward loyal players and provide them with exclusive benefits. By joining the program, you’ll be able to earn points and redeem them for cash, bonuses, and other rewards. Here are a few ways to earn points:

    Make a deposit: Earn points by making a deposit and playing your favorite games.

    Participate in tournaments: Take part in Quatro Casino’s tournaments and earn points by competing against other players.

    Refer a friend: Refer a friend to Quatro Casino and earn points by doing so.

    By following these tips and strategies, you’ll be well on your way to becoming a successful online casino player. Remember to always gamble responsibly and within your means. Good luck, and happy gaming!

    Les offres de bonus et les promotions

    Quatro Casino est connu pour ses offres de bonus et ses promotions régulières, qui permettent aux joueurs de profiter encore plus de leur expérience de jeu en ligne. Les nouveaux joueurs peuvent bénéficier d’un bonus de bienvenue de 100% jusqu’à 100€, ainsi que de 100 free spins sur le slot “Book of Dead”.

    En outre, les joueurs réguliers peuvent profiter de promotions telles que le “Quatro Casino Mobile” qui offre des bonus spécifiques aux joueurs qui jouent sur leur appareil mobile. Les joueurs qui utilisent le site web de Quatro Casino peuvent également bénéficier d’un bonus de 10% sur leurs dépôts, jusqu’à 50€.

    Les joueurs qui utilisent le site web de Quatro Casino en français peuvent également bénéficier d’un bonus de 10% sur leurs dépôts, jusqu’à 50€. Les joueurs qui utilisent le site web de Quatro Casino au Canada peuvent également bénéficier d’un bonus de 10% sur leurs dépôts, jusqu’à 50€.

    Les joueurs qui sont membres du programme de récompense “Quatro Casino Rewards” peuvent également bénéficier de récompenses telles que des free spins, des bonus de jeu et des cadeaux. Les joueurs peuvent gagner des points en jouant aux jeux de casino et en utilisant les services du site web, et ces points peuvent être échangés contre des récompenses.

    Enfin, les joueurs qui ont un compte “Quatro Casino Connexion” peuvent également bénéficier de promotions telles que des free spins et des bonus de jeu. Les joueurs peuvent gagner des points en jouant aux jeux de casino et en utilisant les services du site web, et ces points peuvent être échangés contre des récompenses.

    En résumé, Quatro Casino offre une variété d’offres de bonus et de promotions qui permettent aux joueurs de profiter encore plus de leur expérience de jeu en ligne. Les joueurs peuvent bénéficier de bonus de bienvenue, de promotions spécifiques aux joueurs réguliers, de bonus de jeu et de récompenses.

    Leave a Comment

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