File: /var/www/novotecs.com/wp-content/themes/itfirm/elementor/core/register/ct_button.php
<?php
// Register Button Widget
ct_add_custom_widget(
array(
'name' => 'ct_button',
'title' => esc_html__('Case Button', 'itfirm' ),
'icon' => 'eicon-button',
'categories' => array( Case_Theme_Core::CT_CATEGORY_NAME ),
'scripts' => [
'ct-inline-css-js',
],
'params' => array(
'sections' => array(
array(
'name' => 'source_section',
'label' => esc_html__('Source Settings', 'itfirm' ),
'tab' => \Elementor\Controls_Manager::TAB_CONTENT,
'controls' => array(
array(
'name' => 'style',
'label' => esc_html__('Style', 'itfirm' ),
'type' => \Elementor\Controls_Manager::SELECT,
'default' => 'btn-default',
'options' => [
'btn-default' => esc_html__('Default (Gradient)', 'itfirm' ),
'btn-primary' => esc_html__('Primary', 'itfirm' ),
'btn-circle-text btn-ctext' => esc_html__('Circle Text', 'itfirm' ),
'btn-underline-text btn-ctext' => esc_html__('Underline Text', 'itfirm' ),
'btn-gradient-bottom' => esc_html__('Gradient Bottom', 'itfirm' ),
'btn-gradient-rotate' => esc_html__('Gradient Rotate', 'itfirm' ),
'btn-outline-gradient' => esc_html__('Outline Gradient', 'itfirm' ),
],
),
array(
'name' => 'text',
'label' => esc_html__('Text', 'itfirm' ),
'type' => \Elementor\Controls_Manager::TEXT,
'default' => esc_html__('Click here', 'itfirm'),
'placeholder' => esc_html__('Click here', 'itfirm'),
),
array(
'name' => 'link',
'label' => esc_html__('Link', 'itfirm' ),
'type' => \Elementor\Controls_Manager::URL,
'placeholder' => esc_html__('https://your-link.com', 'itfirm' ),
'default' => [
'url' => '#',
],
),
array(
'name' => 'align',
'label' => esc_html__('Alignment', 'itfirm' ),
'type' => \Elementor\Controls_Manager::CHOOSE,
'control_type' => 'responsive',
'options' => [
'left' => [
'title' => esc_html__('Left', 'itfirm' ),
'icon' => 'fa fa-align-left',
],
'center' => [
'title' => esc_html__('Center', 'itfirm' ),
'icon' => 'fa fa-align-center',
],
'right' => [
'title' => esc_html__('Right', 'itfirm' ),
'icon' => 'fa fa-align-right',
],
'justify' => [
'title' => esc_html__('Justified', 'itfirm' ),
'icon' => 'fa fa-align-justify',
],
],
'prefix_class' => 'elementor-align-',
'default' => '',
'selectors' => [
'{{WRAPPER}} .ct-button-wrapper' => 'text-align: {{VALUE}}',
],
),
array(
'name' => 'btn_padding',
'label' => esc_html__('Padding', 'itfirm' ),
'type' => \Elementor\Controls_Manager::DIMENSIONS,
'size_units' => [ 'px' ],
'selectors' => [
'{{WRAPPER}} .ct-button-wrapper .btn' => 'padding: {{TOP}}{{UNIT}} {{RIGHT}}{{UNIT}} {{BOTTOM}}{{UNIT}} {{LEFT}}{{UNIT}};',
],
'control_type' => 'responsive',
),
array(
'name' => 'btn_border_radius',
'label' => esc_html__('Border Radius', 'itfirm' ),
'type' => \Elementor\Controls_Manager::DIMENSIONS,
'size_units' => [ 'px' ],
'selectors' => [
'{{WRAPPER}} .ct-button-wrapper .btn' => 'border-radius: {{TOP}}{{UNIT}} {{RIGHT}}{{UNIT}} {{BOTTOM}}{{UNIT}} {{LEFT}}{{UNIT}};',
],
),
array(
'name' => 'typography',
'label' => esc_html__('Typography', 'itfirm' ),
'type' => \Elementor\Group_Control_Typography::get_type(),
'control_type' => 'group',
'selector' => '{{WRAPPER}} .ct-button-wrapper .btn',
),
array(
'name' => 'box_sh_color',
'label' => esc_html__( 'Box Shadow', 'itfirm' ),
'type' => \Elementor\Group_Control_Box_Shadow::get_type(),
'control_type' => 'group',
'selector' => '{{WRAPPER}} .ct-button-wrapper .btn'
),
array(
'name' => 'btn_icon',
'label' => esc_html__('Icon', 'itfirm' ),
'type' => \Elementor\Controls_Manager::ICONS,
'label_block' => true,
'fa4compatibility' => 'icon',
),
array(
'name' => 'icon_rotate',
'label' => esc_html__('Icon Rotate', 'itfirm' ),
'type' => \Elementor\Controls_Manager::SELECT,
'default' => 'ct-icon-normal',
'options' => [
'ct-icon-normal' => esc_html__('No', 'itfirm' ),
'ct-icon-rotate' => esc_html__('Yes', 'itfirm' ),
],
),
array(
'name' => 'icon_color',
'label' => esc_html__('Icon Color', 'itfirm' ),
'type' => \Elementor\Controls_Manager::COLOR,
'selectors' => [
'{{WRAPPER}} .ct-button-wrapper .ct-button-icon i' => 'color: {{VALUE}};text-fill-color: {{VALUE}};-webkit-text-fill-color: {{VALUE}};background-image: none;',
],
),
array(
'name' => 'icon_color_hover',
'label' => esc_html__('Icon Color Hover', 'itfirm' ),
'type' => \Elementor\Controls_Manager::COLOR,
'selectors' => [
'{{WRAPPER}} .ct-button-wrapper .btn:hover .ct-button-icon i, {{WRAPPER}} .ct-button-wrapper .btn:focus .ct-button-icon i' => 'color: {{VALUE}};text-fill-color: {{VALUE}};-webkit-text-fill-color: {{VALUE}};background-image: none;',
],
),
array(
'name' => 'icon_align',
'label' => esc_html__('Icon Position', 'itfirm' ),
'type' => \Elementor\Controls_Manager::SELECT,
'default' => 'left',
'options' => [
'left' => esc_html__('Before', 'itfirm' ),
'right' => esc_html__('After', 'itfirm' ),
],
'condition' => [
'btn_icon!' => '',
],
),
array(
'name' => 'icon_space_left',
'label' => esc_html__('Icon Space Left', 'itfirm' ),
'type' => \Elementor\Controls_Manager::SLIDER,
'control_type' => 'responsive',
'size_units' => [ 'px' ],
'range' => [
'px' => [
'min' => 0,
'max' => 300,
],
],
'selectors' => [
'{{WRAPPER}} .ct-button-wrapper .ct-button-icon.ct-align-icon-left' => 'margin-right: {{SIZE}}{{UNIT}};',
],
'condition' => [
'icon_align' => ['left'],
],
),
array(
'name' => 'icon_space_right',
'label' => esc_html__('Icon Space Right', 'itfirm' ),
'type' => \Elementor\Controls_Manager::SLIDER,
'control_type' => 'responsive',
'size_units' => [ 'px' ],
'range' => [
'px' => [
'min' => 0,
'max' => 300,
],
],
'selectors' => [
'{{WRAPPER}} .ct-button-wrapper .ct-button-icon.ct-align-icon-right' => 'margin-left: {{SIZE}}{{UNIT}};',
],
'condition' => [
'icon_align' => ['right'],
],
),
array(
'name' => 'icon_font_size',
'label' => esc_html__('Icon Font Size', 'itfirm' ),
'type' => \Elementor\Controls_Manager::SLIDER,
'control_type' => 'responsive',
'size_units' => [ 'px' ],
'range' => [
'px' => [
'min' => 0,
'max' => 300,
],
],
'selectors' => [
'{{WRAPPER}} .ct-button-wrapper .ct-button-icon i' => 'font-size: {{SIZE}}{{UNIT}};',
],
),
array(
'name' => 'btn_color',
'label' => esc_html__('Text Color', 'itfirm' ),
'type' => \Elementor\Controls_Manager::COLOR,
'selectors' => [
'{{WRAPPER}} .ct-button-wrapper .btn' => 'color: {{VALUE}} !important;',
],
),
array(
'name' => 'btn_bg_color',
'label' => esc_html__('Background Color Main', 'itfirm' ),
'type' => \Elementor\Controls_Manager::COLOR,
'selectors' => [
'{{WRAPPER}} .ct-button-wrapper .btn:not(.btn-ctext), {{WRAPPER}} .ct-button-wrapper .btn.btn-ctext:before' => 'background-color: {{VALUE}} !important;background-image: none !important;',
],
'condition' => [
'style' => ['btn-default','btn-primary','btn-circle-text btn-ctext']
],
),
array(
'name' => 'btn_bg_color_gradient',
'label' => esc_html__('Background Color Gradient', 'itfirm' ),
'type' => \Elementor\Controls_Manager::COLOR,
'condition' => [
'style' => 'btn-default',
],
),
array(
'name' => 'btn_gradient_rotate',
'label' => esc_html__('Gradient Rotate', 'itfirm' ),
'type' => \Elementor\Controls_Manager::SLIDER,
'control_type' => 'responsive',
'size_units' => [ 'px' ],
'range' => [
'px' => [
'min' => 0,
'max' => 360,
],
],
'condition' => [
'style' => 'btn-default',
],
),
array(
'name' => 'btn_bg_color_hover',
'label' => esc_html__('Background Color Hover', 'itfirm' ),
'type' => \Elementor\Controls_Manager::COLOR,
'selectors' => [
'{{WRAPPER}} .ct-button-wrapper .btn:not(.btn-ctext):hover, {{WRAPPER}} .ct-button-wrapper .btn:not(.btn-ctext):focus, {{WRAPPER}} .ct-button-wrapper .btn.btn-ctext:hover:before' => 'background: {{VALUE}} !important;',
],
'condition' => [
'style' => ['btn-default','btn-primary','btn-circle-text btn-ctext']
],
),
array(
'name' => 'btn_color_hover',
'label' => esc_html__('Text Color Hover', 'itfirm' ),
'type' => \Elementor\Controls_Manager::COLOR,
'selectors' => [
'{{WRAPPER}} .ct-button-wrapper .btn:hover' => 'color: {{VALUE}} !important;',
],
),
array(
'name' => 'border_type',
'label' => esc_html__( 'Border Type', 'itfirm' ),
'type' => \Elementor\Controls_Manager::SELECT,
'options' => [
'' => esc_html__( 'None', 'itfirm' ),
'solid' => esc_html__( 'Solid', 'itfirm' ),
'double' => esc_html__( 'Double', 'itfirm' ),
'dotted' => esc_html__( 'Dotted', 'itfirm' ),
'dashed' => esc_html__( 'Dashed', 'itfirm' ),
'groove' => esc_html__( 'Groove', 'itfirm' ),
],
'selectors' => [
'{{WRAPPER}} .ct-button-wrapper .btn' => 'border-style: {{VALUE}} !important;',
],
),
array(
'name' => 'border_width',
'label' => esc_html__( 'Border Width', 'itfirm' ),
'type' => \Elementor\Controls_Manager::DIMENSIONS,
'selectors' => [
'{{WRAPPER}} .ct-button-wrapper .btn' => 'border-width: {{TOP}}{{UNIT}} {{RIGHT}}{{UNIT}} {{BOTTOM}}{{UNIT}} {{LEFT}}{{UNIT}} !important;',
],
'condition' => [
'border_type!' => '',
],
'responsive' => true,
),
array(
'name' => 'border_color',
'label' => esc_html__( 'Border Color', 'itfirm' ),
'type' => \Elementor\Controls_Manager::COLOR,
'default' => '',
'selectors' => [
'{{WRAPPER}} .ct-button-wrapper .btn' => 'border-color: {{VALUE}} !important;',
],
'condition' => [
'border_type!' => '',
],
),
array(
'name' => 'ct_animate',
'label' => esc_html__('Case Animate', 'itfirm' ),
'type' => \Elementor\Controls_Manager::SELECT,
'options' => itfirm_animate(),
'default' => '',
),
array(
'name' => 'ct_animate_delay',
'label' => esc_html__('Animate Delay', 'itfirm' ),
'type' => \Elementor\Controls_Manager::TEXT,
'default' => '0',
'description' => 'Enter number. Default 0ms',
),
),
),
),
),
),
get_template_directory() . '/elementor/core/widgets/'
);