/* Widget Name: Button Description: Create a custom button with flexible styling, icon support, and click tracking functionality. Author: SiteOrigin Author URI: https://siteorigin.com Documentation: https://siteorigin.com/widgets-bundle/button-widget-documentation/ Keywords: event, icon, link */ class SiteOrigin_Widget_Button_Widget extends SiteOrigin_Widget { public function __construct() { parent::__construct( 'sow-button', __( 'SiteOrigin Button', 'so-widgets-bundle' ), array( 'description' => __( 'Create a custom button with flexible styling, icon support, and click tracking functionality.', 'so-widgets-bundle' ), 'help' => 'https://siteorigin.com/widgets-bundle/button-widget-documentation/', ), array( ), false, plugin_dir_path( __FILE__ ) ); } public function get_settings_form() { return array( 'responsive_breakpoint' => array( 'type' => 'measurement', 'label' => __( 'Responsive Breakpoint', 'so-widgets-bundle' ), 'default' => '780px', 'description' => __( 'This setting controls when the Mobile Align setting will be used. The default value is 780px.', 'so-widgets-bundle' ), ), ); } public function initialize() { $this->register_frontend_styles( array( array( 'sow-button-base', plugin_dir_url( __FILE__ ) . 'css/style.css', array(), SOW_BUNDLE_VERSION, ), ) ); } public function get_widget_form() { return array( 'text' => array( 'type' => 'text', 'label' => __( 'Button Text', 'so-widgets-bundle' ), ), 'url' => array( 'type' => 'link', 'label' => __( 'Destination URL', 'so-widgets-bundle' ), 'allow_shortcode' => true, ), 'new_window' => array( 'type' => 'checkbox', 'default' => false, 'label' => __( 'Open in a new window', 'so-widgets-bundle' ), ), 'download' => array( 'type' => 'checkbox', 'default' => false, 'label' => __( 'Download', 'so-widgets-bundle' ), 'description' => __( 'The Destination URL will be downloaded when a user clicks on the button.', 'so-widgets-bundle' ), ), 'button_icon' => array( 'type' => 'section', 'label' => __( 'Icon', 'so-widgets-bundle' ), 'fields' => array( 'icon_selected' => array( 'type' => 'icon', 'label' => __( 'Icon', 'so-widgets-bundle' ), ), 'icon_color' => array( 'type' => 'color', 'label' => __( 'Icon Color', 'so-widgets-bundle' ), ), 'icon' => array( 'type' => 'media', 'label' => __( 'Image Icon', 'so-widgets-bundle' ), 'description' => __( 'Replaces the icon with your own image icon.', 'so-widgets-bundle' ), ), 'icon_placement' => array( 'type' => 'select', 'label' => __( 'Icon Placement', 'so-widgets-bundle' ), 'default' => 'left', 'options' => array( 'top' => __( 'Top', 'so-widgets-bundle' ), 'right' => __( 'Right', 'so-widgets-bundle' ), 'bottom' => __( 'Bottom', 'so-widgets-bundle' ), 'left' => __( 'Left', 'so-widgets-bundle' ), ), ), ), ), 'design' => array( 'type' => 'section', 'label' => __( 'Design and Layout', 'so-widgets-bundle' ), 'hide' => true, 'fields' => array( 'width' => array( 'type' => 'measurement', 'label' => __( 'Width', 'so-widgets-bundle' ), 'description' => __( 'Leave blank to let the button resize according to content.', 'so-widgets-bundle' ), ), 'align' => array( 'type' => 'select', 'label' => __( 'Align', 'so-widgets-bundle' ), 'default' => 'center', 'options' => array( 'left' => __( 'Left', 'so-widgets-bundle' ), 'right' => __( 'Right', 'so-widgets-bundle' ), 'center' => __( 'Center', 'so-widgets-bundle' ), 'justify' => __( 'Full Width', 'so-widgets-bundle' ), ), ), 'mobile_align' => array( 'type' => 'select', 'label' => __( 'Mobile Align', 'so-widgets-bundle' ), 'default' => 'center', 'options' => array( 'left' => __( 'Left', 'so-widgets-bundle' ), 'right' => __( 'Right', 'so-widgets-bundle' ), 'center' => __( 'Center', 'so-widgets-bundle' ), 'justify' => __( 'Full Width', 'so-widgets-bundle' ), ), ), 'theme' => array( 'type' => 'select', 'label' => __( 'Button Theme', 'so-widgets-bundle' ), 'default' => 'flat', 'options' => array( 'atom' => __( 'Atom', 'so-widgets-bundle' ), 'flat' => __( 'Flat', 'so-widgets-bundle' ), 'wire' => __( 'Wire', 'so-widgets-bundle' ), ), ), 'button_color' => array( 'type' => 'color', 'label' => __( 'Button Color', 'so-widgets-bundle' ), ), 'text_color' => array( 'type' => 'color', 'label' => __( 'Text Color', 'so-widgets-bundle' ), ), 'hover' => array( 'type' => 'checkbox', 'default' => true, 'label' => __( 'Use hover effects', 'so-widgets-bundle' ), 'state_emitter' => array( 'callback' => 'conditional', 'args' => array( 'hover[show]: val', 'hover[hide]: ! val', ), ), ), 'hover_background_color' => array( 'type' => 'color', 'label' => __( 'Hover Background Color', 'so-widgets-bundle' ), 'state_handler' => array( 'hover[show]' => array( 'show' ), 'hover[hide]' => array( 'hide' ), ), ), 'hover_text_color' => array( 'type' => 'color', 'label' => __( 'Hover Text Color', 'so-widgets-bundle' ), 'state_handler' => array( 'hover[show]' => array( 'show' ), 'hover[hide]' => array( 'hide' ), ), ), 'font' => array( 'type' => 'font', 'label' => __( 'Font', 'so-widgets-bundle' ), 'default' => 'default', ), 'font_size' => array( 'type' => 'measurement', 'label' => __( 'Font Size', 'so-widgets-bundle' ), 'default' => '1em', ), 'icon_size' => array( 'type' => 'measurement', 'label' => __( 'Icon Size', 'so-widgets-bundle' ), 'default' => '1.3em', ), 'padding' => array( 'type' => 'measurement', 'label' => __( 'Padding', 'so-widgets-bundle' ), 'default' => '1em', ), 'rounding' => array( 'type' => 'multi-measurement', 'label' => __( 'Rounding', 'so-widgets-bundle' ), 'default' => '0.25em 0.25em 0.25em 0.25em', 'measurements' => array( 'top' => array( 'label' => __( 'Top', 'so-widgets-bundle' ), ), 'right' => array( 'label' => __( 'Right', 'so-widgets-bundle' ), ), 'bottom' => array( 'label' => __( 'Bottom', 'so-widgets-bundle' ), ), 'left' => array( 'label' => __( 'Left', 'so-widgets-bundle' ), ), ), ), ), ), 'attributes' => array( 'type' => 'section', 'label' => __( 'Other Attributes and SEO', 'so-widgets-bundle' ), 'hide' => true, 'fields' => array( 'id' => array( 'type' => 'text', 'label' => __( 'Button ID', 'so-widgets-bundle' ), 'description' => __( 'An ID attribute allows you to target this button in JavaScript.', 'so-widgets-bundle' ), ), 'classes' => array( 'type' => 'text', 'label' => __( 'Button Classes', 'so-widgets-bundle' ), 'description' => __( 'Additional CSS classes added to the button link.', 'so-widgets-bundle' ), ), 'title' => array( 'type' => 'text', 'label' => __( 'Title Attribute', 'so-widgets-bundle' ), 'description' => __( 'Adds a title attribute to the button link.', 'so-widgets-bundle' ), ), 'on_click' => array( 'type' => 'text', 'label' => __( 'Onclick', 'so-widgets-bundle' ), 'description' => __( 'Run this JavaScript when the button is clicked. Ideal for tracking.', 'so-widgets-bundle' ), 'onclick' => true, ), 'rel' => array( 'type' => 'text', 'label' => __( 'Rel Attribute', 'so-widgets-bundle' ), 'description' => __( 'Adds a rel attribute to the button link.', 'so-widgets-bundle' ), ), ), ), ); } public function get_style_name( $instance ) { if ( empty( $instance['design']['theme'] ) ) { return 'atom'; } return $instance['design']['theme']; } /** * Get the variables for the Button Widget. * * @return array */ public function get_template_variables( $instance, $args ) { $button_attributes = array(); $attributes = $instance['attributes']; $classes = ! empty( $attributes['classes'] ) ? $attributes['classes'] : ''; if ( ! empty( $classes ) ) { $classes .= ' '; } $classes .= 'sowb-button ow-icon-placement-' . $instance['button_icon']['icon_placement']; if ( ! empty( $instance['design']['hover'] ) ) { $classes .= ' ow-button-hover'; } $button_attributes['class'] = implode( ' ', array_map( 'sanitize_html_class', explode( ' ', $classes ) ) ); if ( ! empty( $instance['new_window'] ) ) { $button_attributes['target'] = '_blank'; $button_attributes['rel'] = 'noopener noreferrer'; } if ( ! empty( $instance['download'] ) ) { $button_attributes['download'] = null; } if ( ! empty( $attributes['id'] ) ) { $button_attributes['id'] = $attributes['id']; } if ( ! empty( $attributes['title'] ) ) { $button_attributes['title'] = $attributes['title']; } if ( ! empty( $attributes['rel'] ) ) { if ( isset( $button_attributes['rel'] ) ) { $button_attributes['rel'] .= " $attributes[rel]"; } else { $button_attributes['rel'] = $attributes['rel']; } } $icon_image_url = ''; if ( ! empty( $instance['button_icon']['icon'] ) ) { $attachment = wp_get_attachment_image_src( $instance['button_icon']['icon'] ); if ( ! empty( $attachment ) ) { $icon_image_url = $attachment[0]; } } return array( 'button_attributes' => apply_filters( 'siteorigin_widgets_button_attributes', $button_attributes, $instance ), 'href' => ! empty( $instance['url'] ) ? $instance['url'] : '', 'on_click' => ! empty( $attributes['on_click'] ) ? $attributes['on_click'] : '', 'align' => $instance['design']['align'], 'icon_image_url' => $icon_image_url, 'icon' => $instance['button_icon']['icon_selected'], 'icon_color' => $instance['button_icon']['icon_color'], 'text' => $instance['text'], ); } /** * Get the variables that we'll be injecting into the less stylesheet. * * @return array */ public function get_less_variables( $instance ) { if ( empty( $instance ) || empty( $instance['design'] ) ) { return array(); } $text_color = isset( $instance['design']['text_color'] ) ? $instance['design']['text_color'] : ''; $button_color = isset( $instance['design']['button_color'] ) ? $instance['design']['button_color'] : ''; $less_vars = array( 'button_width' => isset( $instance['design']['width'] ) ? $instance['design']['width'] : '', 'button_color' => $button_color, 'text_color' => $text_color, 'icon_size' => ! empty( $instance['design']['icon_size'] ) ? $instance['design']['icon_size'] : '1.3em', 'hover_text_color' => ! empty( $instance['design']['hover_text_color'] ) ? $instance['design']['hover_text_color'] : $text_color, 'hover_background_color' => ! empty( $instance['design']['hover_background_color'] ) ? $instance['design']['hover_background_color'] : $button_color, 'font_size' => isset( $instance['design']['font_size'] ) ? $instance['design']['font_size'] : '', 'rounding' => isset( $instance['design']['rounding'] ) ? $instance['design']['rounding'] : '', 'padding' => isset( $instance['design']['padding'] ) ? $instance['design']['padding'] : '', 'has_text' => empty( $instance['text'] ) ? 'false' : 'true', 'responsive_breakpoint' => $this->get_global_settings( 'responsive_breakpoint' ), 'align' => ! empty( $instance['design']['align'] ) ? $instance['design']['align'] : 'center', 'mobile_align' => ! empty( $instance['design']['mobile_align'] ) ? $instance['design']['mobile_align'] : 'center', 'has_button_icon' => empty( $instance['button_icon']['icon_selected'] ) ? 'false' : 'true', ); if ( ! empty( $instance['design']['font'] ) ) { $font = siteorigin_widget_get_font( $instance['design']['font'] ); $less_vars['button_font'] = $font['family']; if ( ! empty( $font['weight'] ) ) { $less_vars['button_font_weight'] = $font['weight_raw']; $less_vars['button_font_style'] = $font['style']; } } return $less_vars; } /** * Make sure the instance is the most up to date version. * * @return mixed */ public function modify_instance( $instance ) { if ( empty( $instance ) ) { return array(); } $migrate_props = array( 'button_icon' => array( 'icon_selected', 'icon_color', 'icon', ), 'design' => array( 'align', 'theme', 'button_color', 'text_color', 'hover', 'hover_text_color', 'hover_background_color', 'font_size', 'rounding', 'padding', ), 'attributes' => array( 'id', ), ); foreach ( $migrate_props as $prop => $sub_props ) { if ( empty( $instance[ $prop ] ) ) { $instance[ $prop ] = array(); foreach ( $sub_props as $sub_prop ) { if ( isset( $instance[ $sub_prop ] ) ) { $instance[ $prop ][ $sub_prop ] = $instance[ $sub_prop ]; unset( $instance[ $sub_prop ] ); } } } } // Migrate onclick setting to prevent Wordfence flag. if ( ! empty( $instance['attributes'] ) && ! empty( $instance['attributes']['onclick'] ) ) { $instance['attributes']['on_click'] = $instance['attributes']['onclick']; } // If the mobile_align setting isn't set, set it to the same value as the align value. if ( ! empty( $instance['design'] ) && ! empty( $instance['design']['align'] ) && empty( $instance['design']['mobile_align'] ) ) { $instance['design']['mobile_align'] = $instance['design']['align']; } // Migrate predefined settings to more customizable settings. if ( ! empty( $instance['design']['font_size'] ) && is_numeric( $instance['design']['font_size'] ) ) { $instance['design']['font_size'] .= 'em'; } if ( ! empty( $instance['design']['padding'] ) && is_numeric( $instance['design']['padding'] ) ) { $instance['design']['padding'] .= 'em'; } if ( ! empty( $instance['design']['rounding'] ) && is_numeric( $instance['design']['rounding'] ) ) { $instance['design']['rounding'] = $instance['design']['rounding'] . 'em ' . $instance['design']['rounding'] . 'em ' . $instance['design']['rounding'] . 'em ' . $instance['design']['rounding'] . 'em'; } if ( empty( $instance['design']['icon_size'] ) ) { $instance['design']['icon_size'] = '1.3em'; } return $instance; } public function get_form_teaser() { if ( class_exists( 'SiteOrigin_Premium' ) ) { return false; } return array( sprintf( __( 'Add a beautiful tooltip to the Button Widget with %sSiteOrigin Premium%s', 'so-widgets-bundle' ), '', '' ), ); } } siteorigin_widget_register( 'sow-button', __FILE__, 'SiteOrigin_Widget_Button_Widget' );{"id":140383,"date":"2026-06-10T20:25:07","date_gmt":"2026-06-10T20:25:07","guid":{"rendered":"https:\/\/klecet.edu.in\/alumni\/?p=140383"},"modified":"2026-06-10T20:25:07","modified_gmt":"2026-06-10T20:25:07","slug":"bonuskong-kasino-2026-kasinobonukset-ja-niiden-hyoedyntaeminen","status":"publish","type":"post","link":"https:\/\/klecet.edu.in\/alumni\/bonuskong-kasino-2026-kasinobonukset-ja-niiden-hyoedyntaeminen\/","title":{"rendered":"BonusKong kasino 2026: Kasinobonukset ja niiden hy\u00f6dynt\u00e4minen"},"content":{"rendered":"
Ennen pelaamista muistathan tarkistaa kasinon bonusehdot. Tieto bonusten ehdoista voi s\u00e4\u00e4st\u00e4\u00e4 sinulta aikaa ja vaivaa, erityisesti kun kyseess\u00e4 on kierr\u00e4tysvaatimukset. N\u00e4in voit varmistaa, ett\u00e4 saat kaiken irti Bonuskongin tarjoamista mahdollisuuksista.<\/p>\n
Pelivalikoima Bonuskong-kasinolla kattaa my\u00f6s uusimmat pelijulkaisut. Uudet kasinot ovat tunnettuja innovatiivisista ja j\u00e4nnitt\u00e4vist\u00e4 peleist\u00e4, ja Bonuskong pit\u00e4\u00e4 huolen siit\u00e4, ett\u00e4 pelaajat pysyv\u00e4t ajan tasalla uusista trendeist\u00e4 ja suosikeista.<\/p>\n
Uudet kasinot tarjoavat usein innovatiivisia ominaisuuksia ja Bonuskong on yksi niist\u00e4. Se erottuu joukosta houkuttelevilla bonuksillaan ja k\u00e4ytt\u00e4j\u00e4yst\u00e4v\u00e4llisell\u00e4 sivustollaan. Pelaajat voivat kokea uudenlaisen pelikokemuksen, joka yhdist\u00e4\u00e4 perinteiset ja modernit pelit.<\/p>\n
Bonuskongin k\u00e4ytt\u00f6liittym\u00e4 on optimoitu pelaajien tarpeet huomioiden. Se on helppok\u00e4ytt\u00f6inen, ja pelaajat voivat l\u00f6yt\u00e4\u00e4 etsim\u00e4ns\u00e4 pelit nopeasti. K\u00e4ytett\u00e4vyys ja visuaalinen ilme tekev\u00e4t Bonuskongista houkuttelevan vaihtoehdon niille, jotka arvostavat esteettist\u00e4 pelikokemusta.<\/p>\n
Bonuskong on yksi internetin johtavista nettikasinoista, joka tarjoaa laajan valikoiman pelej\u00e4 pelaajille. Alusta on suunniteltu k\u00e4ytt\u00e4j\u00e4yst\u00e4v\u00e4lliseksi, ja se on helppo navigoida. Pelivalikoimaan kuuluu niin kolikkopelej\u00e4 kuin p\u00f6yt\u00e4pelej\u00e4, joten jokaiselle l\u00f6ytyy jotain mieluista. Bonuskongin motto on tarjota turvallinen ja nautinnollinen pelikokemus, mik\u00e4 tekee siit\u00e4 erinomaisen valinnan pelaajille.<\/p>\n
K\u00e4ytt\u00e4j\u00e4t ovat l\u00f6yt\u00e4neet Bonuskongista turvallisen ymp\u00e4rist\u00f6n pelata. Alustalla on k\u00e4yt\u00f6ss\u00e4 monipuolisia turvallisuusratkaisuja, jotka suojaavat pelaajien tietoja ja varoja. Kun pelaajat tuntevat olonsa turvalliseksi, he voivat keskitty\u00e4 t\u00e4ysin pelaamiseen. Bonuskong tekee kaikkensa varmistaakseen, ett\u00e4 pelaajilla on turvallinen pelikokemus.<\/p>\n
| Ominaisuus<\/th>\n | Tieto<\/th>\n<\/tr>\n | |||||||||
|---|---|---|---|---|---|---|---|---|---|---|
| Pelimekaniikka<\/td>\n | Innovatiivisia ja j\u00e4nnitt\u00e4vi\u00e4 pelimekaniikkoja<\/td>\n<\/tr>\n | |||||||||
| Asiakaspalvelu<\/td>\n | Yst\u00e4v\u00e4llinen ja asiantunteva asiakastuki<\/td>\n<\/tr>\n<\/table>\nKuinka bonuskong kasinon mobiiliversio vet\u00e4\u00e4 asiakkaita puoleensa?<\/h2>\nEnnen kuin aloitat pelaamisen, on hyv\u00e4 tutustua BonusKongin tarjoamiin bonuksiin ja ilmaiskierroksiin. N\u00e4m\u00e4 edut voivat parantaa pelikokemustasi huomattavasti ja tuoda lis\u00e4\u00e4 mahdollisuuksia voittoihin. Varmista, ett\u00e4 hy\u00f6dynn\u00e4t kaikki saatavilla olevat tarjoukset mobiiliversiossa, jotta saat parhaan mahdollisen hy\u00f6dyn. T\u00e4ll\u00e4 tavalla voit maksimoida pelikassasi k\u00e4yt\u00f6n ja nauttia enemm\u00e4n pelist\u00e4si.<\/p>\n Mobiilik\u00e4ytt\u00e4j\u00e4t voivat nauttia BonusKongin laajasta pelivalikoimasta suoraan \u00e4lypuhelimensa tai tablettinsa kautta. T\u00e4m\u00e4 mahdollistaa pelaamisen miss\u00e4 tahansa ja milloin tahansa ilman tarvetta tietokoneelle. Mobiiliversio on optimoitu tarjoamaan erinomaisen k\u00e4ytt\u00e4j\u00e4kokemuksen, joten voit keskitty\u00e4 voittamiseen ilman h\u00e4iri\u00f6tekij\u00f6it\u00e4.<\/p>\n K\u00e4ytt\u00f6liittym\u00e4 on suunniteltu erityisesti mobiililaitteille, mik\u00e4 tekee navigoinnista helppoa. Selke\u00e4t valikot ja responsiivinen muotoilu varmistavat, ett\u00e4 l\u00f6yd\u00e4t etsim\u00e4si pelit nopeasti. BonusKongin mobiiliversio tuo pelit suoraan sormiesi ulottuville.<\/p>\n
|