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}
Warning: Cannot modify header information - headers already sent by (output started at /home1/brighdbt/public_html/premills.com/wp-content/plugins/svg-support/functions/thumbnail-display.php:1) in /home1/brighdbt/public_html/premills.com/wp-includes/feed-rss2.php on line 8
reviews Archives - premier mills https://www.premills.com/category/reviews/ Mon, 16 Jun 2025 15:25:19 +0000 en-US hourly 1 https://wordpress.org/?v=6.8.1 https://www.premills.com/wp-content/uploads/2021/08/PM_No.1_Favicon-01.png reviews Archives - premier mills https://www.premills.com/category/reviews/ 32 32 Обеспечение безопасности для игроков онлайн казино с бонусами. https://www.premills.com/obespechenie-bezopasnosti-dlja-igrokov-onlajn-10/ https://www.premills.com/obespechenie-bezopasnosti-dlja-igrokov-onlajn-10/#respond Mon, 16 Jun 2025 09:09:13 +0000 https://www.premills.com/?p=17370 Обеспечение безопасности для игроков онлайн казино с бонусами. Vulkan KZ входит в топ-10 лучших казино планеты. Азартных игроков завлекают гарантии безопасности, официальный программное обеспечение, высокая степень клиентоориентированности и быстрый вывод выигрыша. Официальный портал интернет гэмблинг-клуба обладает привлекательный дизайн, удобный интерфейс и разнообразие навигационных инструментов. В нижерасположенной части главной страницы размещен обширный информационный сегмент о деятельности […]

The post Обеспечение безопасности для игроков онлайн казино с бонусами. appeared first on premier mills.

]]>
Обеспечение безопасности для игроков онлайн казино с бонусами.

Vulkan KZ входит в топ-10 лучших казино планеты. Азартных игроков завлекают гарантии безопасности, официальный программное обеспечение, высокая степень клиентоориентированности и быстрый вывод выигрыша. Официальный портал интернет гэмблинг-клуба обладает привлекательный дизайн, удобный интерфейс и разнообразие навигационных инструментов. В нижерасположенной части главной страницы размещен обширный информационный сегмент о деятельности ресурса, политике конфиденциальности, ответы на часто задаваемые вопросы. Доступность статистики позволяет познакомиться с популярными слотами, текущими и предельными джекпотами.

Сервис работает на любых мобильных и стационарных гаджетах. Совместимость дает возможность вступать к чемпионатам или запускать в автоматы в живом казино участникам, которые задействуют компьютеры или гаджеты с различной ОС.

С целью пользователь быстро откликался на информацию сайта и мог запускать игровые автоматы в приятном для себя пространстве, была создана мобильная версия Вулкан Рояль Казахстан. Инсталляционный дистрибутив для iOS и Андроид можно даром скачать на формальном веб-сайте гейминг-платформы. В разделе «Мобильное софт» тщательно описана особенности инсталляции и установки приложения на телефон и планшет. Главное требование – доступность на устройстве достаточного пространства и отключенный блок на загрузку файлов с незнакомых источников. Плюсы установки приложения:

  1. Доступ к услугам и коллекции онлайн развлечений 24/7.
  2. Лишение фиксации к персональному компьютеру, запуск геймов в комфортном для юзера локации.
  3. Устойчивая работа при плохом качестве связи связи.
  4. Автоматический поиск и переход на актуальное активное зеркало.
  5. Дополнительные бонусы за инсталляции программы.
  6. Хранение информации учетной записи на данном гаджете, авторизация «В один клик».
  7. Типичные параметры охраны, защита индивидуальных информации.

Если пользователь не хочет наполнять телефон избыточной информацией, он может воспользоваться адаптированной версией сайта для мобильных устройств. Найти способ для гаджета можно через инсталлированный на мобильнике веб-обозреватель. Игрок заносит имя онлайн казино с поощрениями и переходит по ссылке по активной ссылке. Мобильная версия определяет тип используемого аппарата и моментально адаптируется под его эксплуатационные характеристики. Сайт различается от варианты для ПК большими кнопками меню, интуитивным пользовательским интерфейсом. Минус мобильной вариации – для эксплуатации требуется стабильное подключение к интернету, не работает при запрете на доступ к главного портала.

Воздействие лицензии на ранг игорного дома

С использованием сертификата геймерская система узаконивает свою деятельность и в разы увеличивает пул клиентов. Обладание разрешительного свидетельства обеспечивает безопасность игорного дома и отличное качество предоставляемых услуг. Вулкан Рояль удачно выполнил процесс сертификации и имеет разрешение на различные формы игорной деятельности. Детальная информация о текущем документе размещена в футере утвержденного сайта и в доступных списках.

Разрешение Кюрасао управляет деятельность платформы. Онлайн игорное заведение ежегодно подвергается аудит независимой ревизионной организацией на соблюдение онлайн-платформы глобальным стандартам качества. Права авторизованных игроков безопасно охраняются. В возникновении спорных ситуаций игрок клиент обратиться для решения проблемы в уполномоченный орган.

Лицензированная система для гейминга обеспечивает игрокам обширный набор методов перевода средств для транзакций. Основные основы легальной работы – борьба с отмыванием капитала, разумная игровая деятельность, недопущение на мультиаккаунтность, участие несовершеннолетних в игре и другие обманные действия. Игроки всего мира больше доверяет лицензированному заведению, ведь желают быть уверенными в безопасности личных данных и денежных операций. Приватная сведения пользователя защищена на всех шагах актуальными технологиями SSL-зашифровки. Сведения клиентов сберегаются на серверах в закодированном формате.

Коллаборация с лучшими производителями игровых машин.

Один из среди значимых признаков доверенного виртуального казино – развлечения от популярных глобально признанных поставщиков игр. Вулкан выступает законным союзником многочисленных популярных и перспективных производителей игрового софта. Каждые слоты первоклассного качества, регулярно подвергаются проверку на соответствование указанным параметрам, честность и безопасность. Основные всемирные инспекторы – eCOGRA, iTech Labs, GLI.

Сервис для игр является медиатором, потому что обеспечивает доступ к слотам, которые установлены на удаленных серверных системах производителя. С помощью этому способу исключена манипуляция результатов со стороны руководства и пользователей.

Главные признаки сертифицированного программного обеспечения:

  • Отчетливая визуализация, насыщенный дизайн, удобный игровой процесс, присутствие визуальных и трехмерных эффектов, персонализированный звуковая дорожка.
  • Подробное описание игрового хода, перечень выигрышей, опции.
  • Значительный уровень отдачи – RTP свыше 90% (оптимальный показатель 92-98%).
  • Вариативная нестабильность – разброс бывает маленькая, средняя и высокая, влияет на периодичность и объем ожидаемых выигрышей.
  • Справедливая сессия за счет использования устройства рандомных значений, который отвечает за рандомное формирование результатов данного раунда.
  • Доступность дополнительных опций в актуальных аппаратах – рискованная игра, увеличители, вайлды, расширители, фри-вращения, приобретение бонусов, этапов и прочее.

Дизайнеры сайта позаботились об удобстве пользователей. В азартном зале предусмотрена классификация цифровых развлечений по категориям, создателям, тематике. Чтобы мгновенного поиска по имени разработан поисковый инструмент. Развлечения можно сортировать в категориях по востребованности, выплатам, рейтингу пользователей, в порядке алфавита. Регулярное обновление материалов свежими релизами и формальное партнёрство с игровыми студиями позволяет участникам первыми протестировать новейшие игры в мире азартных игр.

Присутствие тестового режима представляет собой огромным преимуществом Vulkan KZ. Даровой режим предоставляется в слотах, столовых и аварийных играх. Категория Live гэмблинга не включает демонстрационного варианта ставок из-за того, что игра осуществляется в онлайн режиме с наличием настоящего крупье. Для клиентов тестовой версии – это прекрасный возможность освоить особенности слота и попрактиковаться без финансовых затрат. Деморежим не имеет временных ограничений, доступен без аккаунта и депозита.

Варианты регистрации для игры на реальные средства

Критерии к потенциальным пользователям интернет-казино:

  • Годы 18+.
  • Ввод регистрационной анкеты и анкеты аккаунта.
  • Подтверждение связных данных.
  • Этап идентификации.
  • Блокировка на мультиаккаунты.
  • Одобрение с условиями функционирования портала.

Операция оформления учетной записи легкая, занимает пару минут. Геймер входит на основной ресурс или в доступное зеркало, кликает на клавишу «Регистрация» и заполняет высветившуюся бланк персональной информацией. В казино предоставлено 3 метода регистрации профиля: через имейл, по номеру телефона, с использованием социальных медиа или чат-приложений. Игрок подбирает удобный по своему выбору вариант и оканчивает процедуру нажатием на кнопку «Зарегистрироваться».

Значительное значение обладает созданный код доступа. Секретный пароль обязан быть сложным, состоять из по крайней мере шести букв верхнего и нижнего регистра латинского алфавита и чисел. Игрок способен задействовать особое софт для создания безопасного секретного кода или придумывает его самостоятельно.

Регистрация в виртуальном казино предоставляет шанс участнику вкладывать средства в игру, забирать разнообразные бонусы от игорного заведения и провайдеров, участвовать в турнирах и акциях. Геймер делается обладателем личного профиля, в каком отслеживает собственный уровень в программе вознаграждений, доступные бонусы, совершает платежи, изучает историю посещений и транзакций.

По завершении ввода данных в регистрационной формы участник добавляет деньги на баланс в рамках установленного лимита и приобретает значительный бонус за регистрацию. Поднять величину выигрыша удастся при помощи бонус-кода. Обнаружить особый подарочный ключ от Вулкан Рояль удастся на тематических сайтах и обсуждениях, на профилях блогеров в онлайн-сообществах, в онлайн-чате мессенджеров.

Игрокам предоставляется кешбэк в размере до 10 процентов от потерь. Верифицированные игроки получают бездеп приз на День Рождения, при загрузке аппа, после проверки контактных данных или исполнения требований актуальных предложений. Участие в постоянных соревнованиях позволит завоевать главный приз или же заработать вознаграждение за участие. Каждый клиент онлайн казино имеет возможность поучаствовать в лотерее джекпота.

Специфика авторизации внутри персональный кабинет.

Кнопка «Логин» закреплена в верхушке части официального сайта. Пользователь определяет тот вариант авторизации, с помощью которого выполнял регистрационный процесс на сайте. В открывшейся бланке игрок вносит учетную запись (email, номер мобильного) и код доступа или выбирает иконку социальной сети. Для того чтобы войти в свой профиль посредством социальные сети, участник применяет данные учетной записи выбранного онлайн сообщества. Если игрок забыл личный ключ, он может воспользоваться услугой «Забыли пароль?».

Авторизация в индивидуальный аккаунт осуществляется с официального веб-сайта, через действующее запасной сайт, мобильный сайт или мобильное приложение для Android и iOS. Независимо относительно вида задействованного устройства процедура авторизации на платформе проходит по типичному плану. Вулкан Рояль предоставляет шанс вошедшим игрокам подключать дополнительную аутентификацию.

В отдельных странах вследствие бана на игорные развлечения, онлайн казино ограничиваются сетевыми операторами. Для того чтобы участники имели вход к веб-сайту в всякой части света, программисты делают рабочие зеркала. Дублирующий сайт представляет собой 100% дубликатом главного портала, но расположен в другой доменной области.

Для обхождения запретов игроки способны задействовать TOR-браузеры, прокси-серверы, анонимайзеры, VPN-сервисы. Любой из указанных способов содержит свои преимущества и недостатки. Игроки гемблинговой сайта чаще всего для входа в недоступный ресурс предпочитают рабочие зеркала. Ключевые критерии отбора – существующие условия сохранности и быстрая быстродействие действия.

Нормы осознанной игры для участников игорных заведений

Ставки на средства никого не оставляют. Масса игроков приходят в Vulkan KZ, чтобы отдохнуть и хорошо использовать время отдыха. Часть доля юзеров видит игровой сайт, как источник главного заработка. Желание выиграть во что бы то ни стало, чтобы обрести долгожданный джекпот, часто приводит к негативных последствий для азартного игрока.

Лудомания – это болезненное ситуация, которое результирует в полной утрате контроля над поведением. Появляется недуг у игроков интернет-казино на основе материальной заинтересованности и вследствие совокупности определённых неблагоприятных обстоятельств. Чаще чаще всего попадают в зависимость игроки в диапазоне 20-40 годиков, у которых фиксируются душевные и эмоциональные проблемы.

В целях предупреждения геймерской пристрастия геймер должен серьезно обращаться с ставкам на деньги. Сознательные игроки регулируют период пребывания на портале, выставляют предел на ежедневное депозит баланса, управляют размером ставок за день, никогда не используют кредитные средства. Если у данного игрока появились затруднения с самообладанием, он может на некоторое время приостановить свою учетную запись.

На портале не разрешена игра детей, которые принадлежат к группе риска. Проверка профиля дает возможность найти игроков, чей возраст не достигли 18 годков, и запретить доступ к их учетную запись вместе с средствами на счете. В регламентах функционирования портала описана ответственность участника за внесение неправдивой информации и использование персональных данных, платежных инструментов, принадлежащих третьим лицам.

Безопасные финансовые транзакции, проверка профиля

Вулкан предоставляет обширный спектр достоверных финансовых операторов. Все перечисления проводятся посредством агента, что был задействован для начального депозитации средств. Валюта также устанавливается однократно. Популярные платежные методы: банковские карточки Виза, Мастеркард, виртуальные кошельки, цифровые валюты на биржи.

Депозит денег и вывод приза осуществляются в профиле по заданной схеме. Игрок определяет вид транзакции «Зачислить» или «Получить выигрыш», способ оплаты, заполняет размер средств и кликает на «Совершить платеж». После выбора посредника отображается действующий лимит на трансфер денег для данного провайдера.

Финансы переводятся на счет учетной записи сразу, не облагаются комиссией. Молниеносная темп транзакции связана тем фактом, что запросы на внесение средств выполняются автоматически. Администратор удерживает плату за снятие выигрышей. Время поступления средств на личный баланс определяется предпочтительного платежной системы.

Первоначальный вывод средств выигрыша доступен по завершении вэйджера подарочных денег и положительной идентификации. Процедура подтверждения пользователя позволяет полностью полноценно пользоваться функциями онлайн казино. Геймер вводит форму учетной записи своими сведениями (имя и фамилия, год рождения, место жительства), вводит телефонный номер, почтовый адрес, задает валюту и метод платежа.

С целью осуществить этап подтверждения индивидуальности, участник выполняет определённое количество последовательных операций:

  • Заходит в персональный кабинет и выбирает категорию «Верификация».
  • Отправляет фото удостоверения личности либо водительских прав, селфи с удостоверением в руках.
  • Ожидает итогов верификации – среднее период подтверждения от 2-3 часовочек до 5 будних дней.

Снимки должны быть хорошего уровня, резкие, установленного формата. В единичных обстоятельствах сотрудникам казино нужно дополнительно запрашиваемые бумаги для финализации верификации. После удачного прохождения аутентификации у геймера меняется уровень аккаунта.

Сервис поддержки виртуального гэмблинг-платформы с акциями.

В справочной части сайта можно отыскать связь службы поддержки. Обратиться с агентами можно с помощью фирменную e-mail или онлайн чат. Служба поддержки функционирует в любое время, без перерывов и отдыха. Участники виртуального казино связываются в службу поддержки в следующих ситуациях:

  1. Трудности с созданием аккаунта, идентификацией, входом в систему.
  2. Отсрочки с пополнением баланса или снятием приза.
  3. Восстановить пароля для доступа в личный кабинет.
  4. Помощь с загрузкой приложения.
  5. Сложности с включением и прокрутом бонусом.
  6. Обхождение фильтров – линки на активные рабочие копии сайта.
  7. Объяснение оснований приостановки аккаунта.

Когда вопрос необходим срочного решения, рекомендуется воспользоваться онлайн чат. Интервал отклика на вопрос – одна-две минуты. На портале предусмотрен комфортный инструмент «История обращений», где пользователь может просмотреть свое общение с операторами сайта.

В подвальной части главной страницы размещён раздел «FAQ», где игрок получает решения на распространённые запросы. Бланк обратной связи дает возможность компании глубже разбираться в своих пользователей и своевременно исправлять возникшие трудности. Игрок может опубликовать свое мнение о любом событии, описать положительным или плохим опытом, оставить рецензию о посещении сайта. В портативной редакции Вулкан и в аппликации функционирование поддержки организована подобным методом.

The post Обеспечение безопасности для игроков онлайн казино с бонусами. appeared first on premier mills.

]]>
https://www.premills.com/obespechenie-bezopasnosti-dlja-igrokov-onlajn-10/feed/ 0