/* 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":154798,"date":"2026-06-15T03:56:33","date_gmt":"2026-06-15T03:56:33","guid":{"rendered":"https:\/\/klecet.edu.in\/alumni\/?p=154798"},"modified":"2026-06-15T03:56:33","modified_gmt":"2026-06-15T03:56:33","slug":"bonus-stsbet-casino-evaluees-en-valent-elles-la-peine-au-canada","status":"publish","type":"post","link":"http:\/\/klecet.edu.in\/alumni\/bonus-stsbet-casino-evaluees-en-valent-elles-la-peine-au-canada\/","title":{"rendered":"Bonus STSbet Casino \u00e9valu\u00e9es : en valent-elles la peine au Canada ?"},"content":{"rendered":"
\n

Je suis un joueur canadien qui consacre beaucoup de temps \u00e0 d\u00e9cortiquer les propositions des casinos en ligne https:\/\/stsbetcasino.ca\/fr-ca\/<\/a>. STSbet Casino pr\u00e9sente des promotions qui semblent int\u00e9ressantes pour nous, joueurs d’ici. J’ai donc pris la peine de examiner leurs conditions, de comparer les avantages et d’\u00e9valuer si ces offres sont r\u00e9ellement utiles. Dans cet article, je vous pr\u00e9sente ce que j’ai trouv\u00e9. On va examiner le montant des bonus, bien s\u00fbr, mais aussi leur facilit\u00e9 d’acc\u00e8s et leur conformit\u00e9 avec nos habitudes de jeu au Canada. Mon but est simple : vous aider \u00e0 voir distinctement si ces promotions sont un vrai plus ou juste un app\u00e2t marketing.<\/p>\n

Introduction \u00e0 l’\u00e9cosyst\u00e8me promotionnel de STSbet<\/h2>\n

STSbet Casino fait son entr\u00e9e sur le march\u00e9 canadien avec une strat\u00e9gie particuli\u00e8re. Ils ne ont l’air de ne pas miser sur des bonus gigantesques, mais plut\u00f4t sur des offres r\u00e9guli\u00e8res et multiples. J’ai l’impression que la plateforme s’efforce de retenir ses joueurs sur la p\u00e9riode, avec un m\u00e9lange de bonus de bienvenue, de promotions de la semaine et d’un programme de fid\u00e9lit\u00e9. Ils sont bien implant\u00e9s ici : les offres sont en dollars canadiens et prennent en consid\u00e9ration de nos moyens de paiement nationaux. Mais prudence, un bonus qui semble gros \u00e0 premi\u00e8re vue dissimule souvent des exigences de mise tr\u00e8s \u00e9lev\u00e9es. Je vais d\u00e9mystifier tout \u00e7a, en entamant par leur offre la plus marquante : le bonus de bienvenue.<\/p>\n

La prime d’accueil : un premier aper\u00e7u sous la loupe<\/h2>\n

Pour les joueurs canadiens d\u00e9butants, STSbet Casino offre un package fond\u00e9 sur un match sur le premier d\u00e9p\u00f4t. Les montants sont attractifs sans \u00eatre les plus gros du march\u00e9, ce qui n’est pas obligatoirement un mauvais signe. Tout se joue dans les d\u00e9tails pratiques. Le taux de correspondance et le plafond donnent une id\u00e9e du potentiel, mais c’est la r\u00e9alisation qui compte vraiment. Pour un Canadien, la simplicit\u00e9 pour obtenir le bonus et l’absence d’emb\u00fbches sont essentielles. J’ai v\u00e9rifi\u00e9 si la proc\u00e9dure est facile et si le service client, propos\u00e9 en fran\u00e7ais et en anglais, peut aider les nouveaux sans leur compliquer la vie.<\/p>\n

Organisation et modalit\u00e9s cl\u00e9s de la prime<\/h3>\n

L’organisation est traditionnelle : un pourcentage de correspondance sur votre premier d\u00e9p\u00f4t, avec un maximum. Par exemple, “100% jusqu’\u00e0 200 $” veut dire qu’un d\u00e9p\u00f4t de 200 $ vous donne 200 $ de bonus, pour un bankroll de d\u00e9part de 400 $. La difficult\u00e9 r\u00e9side des conditions de mise, les fameux “wagerings requirements”. Elles pr\u00e9cisent combien de fois vous devez miser le montant du bonus (et parfois celui du d\u00e9p\u00f4t) avant de pouvoir retirer vos gains. Un multiplicateur de 30x est courant, mais 20x serait bien plus int\u00e9ressant. Il est essentiel de contr\u00f4ler si ces mises s’appliquent au bonus seul ou \u00e0 la somme du d\u00e9p\u00f4t et du bonus.<\/p>\n

Ad\u00e9quation avec le joueur canadien moyen<\/h3>\n

Pour le joueur canadien lambda, qui aime peut-\u00eatre les bandits manchots sur le hockey ou les th\u00e8mes naturels, tout d\u00e9pend des jeux \u00e9ligibles. G\u00e9n\u00e9ralement, les contributions aux conditions de mise varient selon le jeu. Les slots comptent g\u00e9n\u00e9ralement pour 100%, alors que des jeux comme le blackjack ou la roulette ne comptent parfois que pour 10%, voire pas du tout. STSbet doit \u00eatre compl\u00e8tement transparent sur ce point. Autre d\u00e9tail crucial : la dur\u00e9e de validit\u00e9 du bonus. Un d\u00e9lai trop restreint rend les conditions de mise irr\u00e9alisables pour un joueur loisir.<\/p>\n

Promotions r\u00e9currentes : b\u00e9n\u00e9fice p\u00e9renne ou perturbations ?<\/h2>\n

Apr\u00e8s l’offre de bienvenue, STSbet pr\u00e9sente un calendrier de promotions : des offres de rechargement, des spins offerts le week-end, des tournois \u00e0 prix garantis. Leur v\u00e9ritable int\u00e9r\u00eat se \u00e9value \u00e0 leur p\u00e9riodicit\u00e9, leur accessibilit\u00e9 et leur coh\u00e9rence. Une “bonus de 50%” chaque lundi peut apporter un r\u00e9el avantage, si ses termes sont favorables. Ces promotions continues gratifient l’activit\u00e9 continue plus qu’elles ne visent \u00e0 s\u00e9duire de nouveaux clients. Pour un parieur fid\u00e8le au Canada, cela peut faire une diff\u00e9rence sensible sur son budget du mois, changeant une divertissement temporaire en un b\u00e9n\u00e9fice tangible.<\/p>\n

Le syst\u00e8me de r\u00e9compenses : gains discrets ou substantielles ?<\/h2>\n

Le programme de fid\u00e9lit\u00e9 est souvent l’\u00e9l\u00e9ment cl\u00e9 de la valeur d’un casino. Celui de STSbet, structur\u00e9 par paliers ou en points, offre des gains progressifs. Mon examen se concentre sur le concret : est-ce facile de gagner des points sur les jeux les plus jou\u00e9s au Canada ? Peut-on convertir en argent liquide, en bonus, ou en biens sp\u00e9ciaux ? Un bon programme offre du cashback, des tours gratuits mensuels, ou un service VIP avec un conseiller d\u00e9di\u00e9. J’examine si les promesses de rang VIP sont assorties d’b\u00e9n\u00e9fices concrets, ou si elles se limitent \u00e0 des insignes ornementaux qui n’apportent rien \u00e0 l’aventure.<\/p>\n

Promotions sportives : miser sur le hockey et plus encore<\/h2>\n

STSbet est ancr\u00e9 dans le pari sportif. Leurs bonus sportifs justifient donc une attention sp\u00e9ciale pour le public canadien. On y rencontre fr\u00e9quemment des promotions de pari gratuit sur des matchs de la LNH, la Coupe Grey, ou la NBA. La valeur est imm\u00e9diate : cela diminue votre risque. Je consid\u00e8re principalement la simplicit\u00e9 de ces offres. Est-ce un “pari gratuit si votre premier pari sur le hockey est perdant” ? Ou un “boost de cote” sur un match pr\u00e9cis ? Pour un parieur canadien, une promotion cibl\u00e9e sur la LNH pendant les s\u00e9ries \u00e9liminatoires repr\u00e9sente bien plus de valeur qu’une offre standard sur un sport moins populaire localement.<\/p>\n