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} لعبة فيديو Insane Heart للعب مجانًا في كازينوهات Merkur على الإنترنت - premier mills

لعبة فيديو Insane Heart للعب مجانًا في كازينوهات Merkur على الإنترنت

سيتحمل الفائز الجديد على الأرجح أي رسوم إضافية على المستوى الفيدرالي، أو مستوى المقاطعة، أو أي رسوم محلية أخرى. يمكن استلام التذاكر الرابحة التي تصل قيمتها إلى مليون دولار أمريكي في مكتب منطقة يانصيب فلوريدا. أما التذاكر الفائزة التي تزيد قيمتها عن مليون دولار أمريكي، فيجب استلامها في مقر اليانصيب في تالاهاسي. ووفقًا لمسؤولي اليانصيب، فإن احتمالات فوزك بالجائزة الكبرى هي واحد من 302 مليون. سواء كنت مقامرًا عاديًا أو محترفًا، فإن SportPesa تُبسط اللعب من خلال نظام ويندوز صديق الأعضاء. وللحصول على رهانات تقنية، توفر الشركات الكبرى رهانات دعائية محددة، وتتميز SportPesa International بتقديم خيارات مراهنة فورية شاملة.

خريطة الكازينو

مع كل فوز، ينخفض ​​العدد بمقدار واحد، وبمجرد أن يُخفق اللاعب، تُجمع المكسرات الطازجة أسفل البكرة. بعد إعادة الدورات، تُجرى دورة أخيرة حيث تتراكم الرموز البرية المتراكمة لتمويل البكرة بأكملها، مما يُؤدي إلى تشغيل بكرات الرموز البرية. عندما تُسجل عدة رموز برية انتصارات، تكون مكافآتها متبادلة، مما يزيد بشكل كبير من احتمالية الدفع. ضع خمس أو أربع أو ست أو سبع خلايا نحل لتفعيل ست أو ثماني أو عشر أو اثنتي عشرة دورة مجانية من "ملك العسل". تُضيف "ملكة النحل" الجديدة مضاعفات مضاعفة للبكرات في ميزة ممتعة عندما تُؤدي جميع التركيبات الفائزة إلى إعادة تدوير ثابتة.

استمتع بموانئ المراهنات العتيقة من Merkur

لأن جائزة Honey Jewels PowerPlay Jackpot من بين أفضل جوائز المال الحقيقي من Playtech، يمكنك اختيار أحد الكازينوهات الإلكترونية المفضلة لديك. تمنحك الجوائز التقدمية أعلى المكاسب، ومن بينها Mega Moolah. بعض ألعاب ماكينات القمار الإلكترونية، والألعاب الكلاسيكية، ومتعددة خطوط الدفع، وألعاب الفيديو، تدفع أرقامًا إضافية.

سلم نحو الملايين في قائمة أفضل 5 أموال في التاريخ

خلال اللعبة الرئيسية، تبدأ لعبة ماكينات القمار ببكرات دوارة برموز متنوعة، بهدف الحصول على مجموعات فعّالة على خطوط الدفع. لكل لعبة سلوتس طابعها الخاص، من tusk-casino.org مواقع الويب الحضارات القديمة إلى المغامرات المتقدمة، مما يضمن وجود كل ما يناسب الجميع. يفوز العديد من اللاعبين بجوائز رائعة لتجربة ألعاب السلوتس على الإنترنت بأموال حقيقية، ويفوز آخرون بمكافآت دائمة. تقدم ماكينات القمار الحديثة أكبر الجوائز لمن يحققون انتصارات كبيرة. إذا لم تكن منزعجًا من تصميم ماكينات القمار، فلا داعي لعدم الاستمتاع بالدورات التي تقدمها ماكينة سلوتس IGT.

casino app store

تبدأ اللعبة بأربعة صفوف مفتوحة، ويمكنك تأمين أربعة صفوف، ثم تربح ثلاث دورات. مع ذلك، لا تقتصر هذه اللعبة على جاذبية الوحش الجديد فحسب، بل تُعبّر أيضًا عن أسلوب مرتبط بالمجتمع الجديد وأساليبه في الغرب الأمريكي. نتيجةً لذلك، زُيّنت البكرات بريش مختلف لإضفاء مظهر قبلي أنيق، وهو ما يُضفي لمسةً عتيقة على الغرب الأمريكي الأصلي.

قد تربح حوالي 15,000 ضعفًا من أحدث خيار، بالإضافة إلى جائزة Mega Moolah Jackpot الحديثة. بين جميع مراحل مركز الترفيه الرئيسي لدينا وبار الأنشطة، يمكنك توقع أنشطة نموذجية ستشجعك على العودة. توفر مجموعة الأنشطة العديد من الأحداث والأنشطة المتكررة، بالإضافة إلى العديد من العروض الأفضل لكل من العروض المباشرة والعروض الموسعة. لا تتردد في الاتصال بنا للحصول على مساعدة لأولئك الذين يواجهون أيضًا مشاكل كبيرة بسبب قيود المراهنة الشخصية أو التفكير في استبعاد مشاكل المقامرة. إذا كنت أو أي شخص تعرفه يعاني من إدمان المقامرة، فستجد معلومات متاحة للمساعدة. تقدم منظمات مثل المجلس الوطني للمقامرة في المواقف، والمقامرون الخاصون، وGam-Anon الدعم والمعلومات للأفراد والعائلات المتأثرين بالمقامرة في المواقف.

بالإضافة إلى ذلك، تتميز اللعبة بسلسلة من الرموز التي تُصوّر تماثيل صغيرة لقضبان الطوطم، تُشير إلى شعارك القبلي. يُكافئ برنامج "التزام" اللاعبين الدائمين بمزايا مُتنوعة، مثل الحوافز، والدورات المجانية، والإعلانات الحصرية. من خلال اللعب المُنتظم، يُمكنك الحصول على مكافآت وترقية إلى أقسام جديدة في برنامج الدعم. تُعد لعبة كازينو Playtech من بين الألعاب التي يُمكنك المراهنة عليها مجانًا دون الحاجة للتسجيل، وتعتمد على أحدث رموز السكان الأصليين في الولايات المتحدة. جميع الرموز الجديدة في اللعبة مستوحاة من أسلوب السكان الأصليين الأمريكيين، بالإضافة إلى رموز أمريكية عادية مثل النسور والخيول – "المعنويات البرية" الجديدة. استثمر أموالك في ألعاب البنسات العادية، أو راهن بأقصى قدر ممكن مع الحد الأقصى للرهان للحصول على عوائد أعلى!

في الوقت نفسه، تعرّف على جدول مدفوعات اللعبة وخطوط الدفع والعروض الإضافية، فهذه المعرفة تُمكّنك من اتخاذ قرارات أكثر دقة أثناء اللعب. يتميز كازينو بوفادا بخيارات ماكينات القمار الشاملة والمكافآت الجذابة، مما يجعله الخيار الأمثل للاعبي القمار. تضم مكتبة الكازينو الجديدة مجموعة متنوعة من ألعاب السلوتس، من ماكينات القمار التقليدية ذات الثلاث بكرات إلى ماكينات القمار المعقدة ذات خطوط الدفع المتعددة والعروض الإضافية. يشتهر كازينو ريستورانت لوكال بمجموعته المتنوعة من ألعاب ماكينات القمار بأموال حقيقية، حيث تتميز كل لعبة بصورة جذابة وأسلوب لعب ممتع. كما يقدم الكازينو ماكينات قمار كلاسيكية وأحدث ماكينات القمار، المصممة لتقديم تجربة ألعاب كازينو غامرة. لعب ماكينات القمار على الإنترنت سهل وممتع، ولكنه يُساعد على فهم المفاهيم.

  • إن السر في الحصول على مبالغ ضخمة من المال في لعبة Wild Soul هو دائمًا توفير عنصر اللعب الجديد لانتصاراتك المنخفضة وتجميع الانتصارات الكبيرة على هذا النحو.
  • فقط عندما تتمكن من فحص لعبة الفيديو بشكل صحيح، يمكنك المضي قدمًا ووضع رهاناتك.
  • يقدم هذا النوع من الألعاب أعلى مستوى من الكفاءة للناس على مر السنين، مما يجعلها أكثر جاذبية لأولئك الذين يسعون إلى تحقيق أقصى قدر من الأرباح المحتملة.
  • يفهم المعجبون بفتحات الإنترنت فتحاتك المخزنة بالكامل على سبيل المثال Divine Fortune و Cosmic Luck و Super Chance.
  • تؤدي إلى دورات مجانية تمامًا مع عشوائية وتوسع، وستجد البرية المحيطة بعد لعب الخطوة الثالثة Whirring Wilds بواسطة Pragmatic Gamble.
  • كما أن Nuts Heart من لعبة Merkur Video هو موقع ليس شائعًا جدًا بين المقامرين ذوي الخبرة حتى الآن.

best online casino no deposit

تطفو رقاقات الثلج بخفة على خلفية حمراء زاهية للبكرات، وترمز اللعبة إلى أكثر من مجرد ثلج وهدايا، وستجد نفسك في غابة عيد الميلاد. إنها تجربة مبهجة للغاية، والصوت عبارة عن نسخة من أغنية "جينجل بيلز" التي ستُمكّنك بالتأكيد من الانغماس في معظم الدورات الموسمية. في هذه الخوادم، لديك فرصة الحصول على دورات مجانية، حيث يمكنك زيادة أرباحك بشكل ملحوظ – حتى بدون رمز المكافأة.

يُضاف مُضاعِف ممتاز إلى جميع الرهانات المُضمنة في سعر الدخول. تُساعدك لعبة القمار الرائعة "خمسة نطاقات" على البقاء على حافة الكرسي وأنت مُترقب لمزاياها المثيرة. على غرار لعبة SEVENS الكلاسيكية، تتميز اللعبة الجديدة بثلاث بكرات، وبتصميمها المُتقن. لعبة Genie Jackpots Megaways الأحدث من Means Gaming هي لعبة فيديو رائعة مليئة بالمكافآت والرموز الجديدة.

اختر أحد صناديق التقدير لترى إن كنت قد فزت بمكافأة شخصية. أستثمر في أحدث الشروط والأحكام. يجب عليك الالتزام بأحدث الشروط والأحكام لإنشاء حساب مجاني.

  • بمجرد تفضيلك لانتصارات محددة في موقع Honey Gems PowerPlay Jackpot على الإنترنت، قم بتدوير فتحات ذات طابع النحل من فريق برامج أفضل آخر.
  • تستوفي الكازينوهات المدرجة في القائمة المختصرة أعلى المعايير، وتوفر موانئ عالية المستوى لمستخدمي سطح المكتب والهواتف المحمولة.
  • لقد أعجبتنا علامات المكسرات الأحدث، فضلاً عن الأيقونات شبه المحملة التي كانت قادرة على تحسين بناء خطوط الدفع الأولى المكونة من 10 خطوط.
  • قم بإلقاء نظرة على هذه المراجعة وشاهد ما إذا كان موقع Jackpot Bells الخاص بعيد الميلاد على الإنترنت يجلب لك فرحة احتفالية.
  • اكتشف المزيد عن المجتمع الأمريكي الأصلي الجديد على البكرات من تجربة لعبة Heart Controls out of Wide range المجانية الجديدة من Microgaming ويمكنك أيضًا تجربة لعبة Indian Heart من Novomatic.
  • توفر العديد من الكازينوهات على شبكة الإنترنت الآن شبكات صديقة للهواتف المحمولة أو تطبيقات مخصصة تمكنك من الاستمتاع بلعبة القمار المفضلة لديك في أي مكان وفي أي وقت.

ألعاب القمار

thunderstruck 2 online casino

فيما يلي بعضٌ من كتابنا المُنجز، والذي نُقيّم فيه مواقع مراهناتٍ مُستنيرة لعام ٢٠٢٥. بدءًا من القيمة الباهظة للهنود، يُجرّبون فحولهم، مثل المهر الأبيض، ليُقدّموا مكافآتٍ أعلى. يميل أحدث المهر إلى تبديل صورٍ أخرى مع بعض الاستثناءات البسيطة مثل صورة الجائزة. بعد أن حللنا الوضع، إليك بعض هذه الألعاب المُشابهة التي يُمكنك الاستمتاع بها.

يمكنك العثور على أربعة رموز منخفضة الربح في لعبة Spirit slots الرائعة. يُصوَّر على شكل رموز ملكية، ويُدفع مبلغ يتراوح بين 5x و100x لاختيار خط واحد، حتى تحصل على خمسة رموز متشابهة. على صعيد التوسع، حققت شركة Settle Down Gambling تقدمًا ملحوظًا في أمريكا اللاتينية، حيث وصلت إلى البرازيل وبيرو. وبحلول الأول من يناير 2025، بدأت الشركة في تقديم أكثر من 40 من أفضل عناوينها لخداع الموزعين في البرازيل.

بدايةً، تكشف المعلومات أن معظم المزايا الأخرى مرتبطة بمعاملات خدمات الكازينو الإقليمي. المزيد من نتائج سحوبات سوبر مئات الآلاف السابقة معروضة أدناه. بعد ذلك، بالنسبة للمبالغ المختارة في السحب، سترى عدد الأبطال ورقم الجائزة الكبرى المُقدم – سواءً كنت تفضل خيار المعاش السنوي أو الدفعة النقدية الإجمالية. يمكنك معرفة المزيد حول جوائز السحب من خلال خيار "الفائزون والمدفوعات" الجديد، أو ابحث عن المبلغ السابق من خلال رابط الأرشيف أسفل صفحتك. احجز إقامتك في كازينو سول ماونتن وستحصل على أفضل ماكينات القمار وألعاب الفيديو بوكر في ولاية أوريغون.