Current File : /home/mdkeenpw/www/wp-content/plugins/trx_addons/components/api/quickcal/quickcal-sc-elementor.php |
<?php
/**
* Plugin support: QuickCal (Elementor support)
*
* @package ThemeREX Addons
* @since v2.26.0
*/
// Don't load directly
if ( ! defined( 'TRX_ADDONS_VERSION' ) ) {
exit;
}
if ( ! function_exists( 'trx_addons_sc_quickcal_add_in_elementor_ba' ) ) {
add_action( trx_addons_elementor_get_action_for_widgets_registration(), 'trx_addons_sc_quickcal_add_in_elementor_ba' );
/**
* Register "QuickCal" widget in Elementor as wrapper for shortcode [quickcal_appointments]
*
* @hooked elementor/widgets/register
*/
function trx_addons_sc_quickcal_add_in_elementor_ba() {
if ( ! trx_addons_exists_quickcal() || ! class_exists( 'TRX_Addons_Elementor_Widget' ) ) {
return;
}
class TRX_Addons_Elementor_Widget_QuickCal_Appontments extends TRX_Addons_Elementor_Widget {
/**
* Retrieve widget name.
*
* @since 1.6.41
* @access public
*
* @return string Widget name.
*/
public function get_name() {
return 'trx_sc_quickcal_appointments';
}
/**
* Retrieve widget title.
*
* @since 1.6.41
* @access public
*
* @return string Widget title.
*/
public function get_title() {
return __( 'QuickCal Appointments', 'trx_addons' );
}
/**
* Get widget keywords.
*
* Retrieve the list of keywords the widget belongs to.
*
* @since 2.27.2
* @access public
*
* @return array Widget keywords.
*/
public function get_keywords() {
return [ 'quick', 'calendar', 'schedule', 'appointment', 'booked' ];
}
/**
* Retrieve widget icon.
*
* @since 1.6.41
* @access public
*
* @return string Widget icon.
*/
public function get_icon() {
return 'eicon-checkbox trx_addons_elementor_widget_icon';
}
/**
* Retrieve the list of categories the widget belongs to.
*
* Used to determine where to display the widget in the editor.
*
* @since 1.6.41
* @access public
*
* @return array Widget categories.
*/
public function get_categories() {
return ['trx_addons-elements'];
}
/**
* Register widget controls.
*
* Adds different input fields to allow the user to change and customize the widget settings.
*
* @since 1.6.41
* @access protected
*/
protected function register_controls() {
$this->start_controls_section(
'section_sc_quickcal_appointments',
[
'label' => __( 'ThemeREX QuickCal Appoinments', 'trx_addons' ),
]
);
$this->add_control( 'sc_quickcal_appointments_heading', array(
'type' => \Elementor\Controls_Manager::HEADING,
'label' => esc_html__( 'This widget has no parameters!', 'trx_addons' ),
'separator' => 'none',
) );
$this->end_controls_section();
}
// Return widget's layout
public function render() {
if (shortcode_exists('quickcal-appointments')) {
if ( is_user_logged_in() ) {
trx_addons_show_layout( do_shortcode( '[quickcal-appointments]' ) );
}
} else {
$this->shortcode_not_exists( 'quickcal-appointments', 'QuickCal Appointment' );
}
}
}
// Add a widget to compatibility with old Booked plugin
class TRX_Addons_Elementor_Widget_Booked_Appontments extends TRX_Addons_Elementor_Widget_QuickCal_Appontments {
/**
* Retrieve widget name.
*
* @since 1.6.41
* @access public
*
* @return string Widget name.
*/
public function get_name() {
return 'trx_sc_booked_appointments';
}
/**
* Retrieve widget title.
*
* @since 1.6.41
* @access public
*
* @return string Widget title.
*/
public function get_title() {
return __( 'Booked Appointments (Legacy)', 'trx_addons' );
}
/**
* Get widget keywords.
*
* Retrieve the list of keywords the widget belongs to.
*
* @since 2.27.2
* @access public
*
* @return array Widget keywords.
*/
public function get_keywords() {
return [ 'booked', 'appointment', 'schedule', 'calendar' ];
}
}
// Register widget
trx_addons_elm_register_widget( 'TRX_Addons_Elementor_Widget_QuickCal_Appontments' );
trx_addons_elm_register_widget( 'TRX_Addons_Elementor_Widget_Booked_Appontments' );
}
}
if ( ! function_exists( 'trx_addons_sc_quickcal_add_in_elementor_bp' ) ) {
add_action( trx_addons_elementor_get_action_for_widgets_registration(), 'trx_addons_sc_quickcal_add_in_elementor_bp' );
/**
* Register "QuickCal Profile" widget in Elementor as wrapper for shortcode [quickcal-profile]
*
* @hooked elementor/widgets/register
*/
function trx_addons_sc_quickcal_add_in_elementor_bp() {
if ( ! trx_addons_exists_quickcal() || ! class_exists( 'TRX_Addons_Elementor_Widget' ) ) {
return;
}
class TRX_Addons_Elementor_Widget_QuickCal_Profile extends TRX_Addons_Elementor_Widget {
/**
* Retrieve widget name.
*
* @since 1.6.41
* @access public
*
* @return string Widget name.
*/
public function get_name() {
return 'trx_sc_quickcal_profile';
}
/**
* Retrieve widget title.
*
* @since 1.6.41
* @access public
*
* @return string Widget title.
*/
public function get_title() {
return __( 'QuickCal Profile', 'trx_addons' );
}
/**
* Get widget keywords.
*
* Retrieve the list of keywords the widget belongs to.
*
* @since 2.27.2
* @access public
*
* @return array Widget keywords.
*/
public function get_keywords() {
return [ 'quick', 'calendar', 'schedule', 'appointment', 'booked', 'profile' ];
}
/**
* Retrieve widget icon.
*
* @since 1.6.41
* @access public
*
* @return string Widget icon.
*/
public function get_icon() {
return 'eicon-lock-user trx_addons_elementor_widget_icon';
}
/**
* Retrieve the list of categories the widget belongs to.
*
* Used to determine where to display the widget in the editor.
*
* @since 1.6.41
* @access public
*
* @return array Widget categories.
*/
public function get_categories() {
return ['trx_addons-elements'];
}
/**
* Register widget controls.
*
* Adds different input fields to allow the user to change and customize the widget settings.
*
* @since 1.6.41
* @access protected
*/
protected function register_controls() {
$this->start_controls_section(
'section_sc_quickcal_profile',
[
'label' => __( 'ThemeREX QuickCal Profile', 'trx_addons' ),
'description' => __( 'This widget has no parameters!', 'trx_addons' ),
]
);
$this->add_control( 'sc_quickcal_profile_heading', array(
'type' => \Elementor\Controls_Manager::HEADING,
'label' => esc_html__( 'This widget has no parameters!', 'trx_addons' ),
'separator' => 'none',
) );
$this->end_controls_section();
}
// Return widget's layout
public function render() {
if (shortcode_exists('quickcal-profile')) {
if ( is_user_logged_in() ) {
trx_addons_show_layout( do_shortcode( '[quickcal-profile]' ) );
}
} else {
$this->shortcode_not_exists( 'quickcal-profile', 'QuickCal Profile' );
}
}
}
// Add a widget to compatibility with old Booked plugin
class TRX_Addons_Elementor_Widget_Booked_Profile extends TRX_Addons_Elementor_Widget_QuickCal_Profile {
/**
* Retrieve widget name.
*
* @since 1.6.41
* @access public
*
* @return string Widget name.
*/
public function get_name() {
return 'trx_sc_booked_profile';
}
/**
* Retrieve widget title.
*
* @since 1.6.41
* @access public
*
* @return string Widget title.
*/
public function get_title() {
return __( 'Booked Profile (Legacy)', 'trx_addons' );
}
/**
* Get widget keywords.
*
* Retrieve the list of keywords the widget belongs to.
*
* @since 2.27.2
* @access public
*
* @return array Widget keywords.
*/
public function get_keywords() {
return [ 'calendar', 'schedule', 'appointment', 'booked', 'profile' ];
}
}
// Register widget
trx_addons_elm_register_widget( 'TRX_Addons_Elementor_Widget_QuickCal_Profile' );
trx_addons_elm_register_widget( 'TRX_Addons_Elementor_Widget_Booked_Profile' );
}
}
if ( ! function_exists( 'trx_addons_sc_quickcal_add_in_elementor_bc' ) ) {
add_action( trx_addons_elementor_get_action_for_widgets_registration(), 'trx_addons_sc_quickcal_add_in_elementor_bc' );
/**
* Register "QuickCal Calendar" widget in Elementor as wrapper for shortcode [quickcal-calendar]
*
* @hooked elementor/widgets/register
*/
function trx_addons_sc_quickcal_add_in_elementor_bc() {
if ( ! trx_addons_exists_quickcal() || ! class_exists( 'TRX_Addons_Elementor_Widget' ) ) {
return;
}
class TRX_Addons_Elementor_Widget_QuickCal_Calendar extends TRX_Addons_Elementor_Widget {
/**
* Retrieve widget name.
*
* @since 1.6.41
* @access public
*
* @return string Widget name.
*/
public function get_name() {
return 'trx_sc_quickcal_calendar';
}
/**
* Retrieve widget title.
*
* @since 1.6.41
* @access public
*
* @return string Widget title.
*/
public function get_title() {
return __( 'QuickCal Calendar', 'trx_addons' );
}
/**
* Get widget keywords.
*
* Retrieve the list of keywords the widget belongs to.
*
* @since 2.27.2
* @access public
*
* @return array Widget keywords.
*/
public function get_keywords() {
return [ 'quick', 'calendar', 'schedule', 'appointment', 'booked' ];
}
/**
* Retrieve widget icon.
*
* @since 1.6.41
* @access public
*
* @return string Widget icon.
*/
public function get_icon() {
return 'eicon-calendar trx_addons_elementor_widget_icon';
}
/**
* Retrieve the list of categories the widget belongs to.
*
* Used to determine where to display the widget in the editor.
*
* @since 1.6.41
* @access public
*
* @return array Widget categories.
*/
public function get_categories() {
return ['trx_addons-elements'];
}
/**
* Register widget controls.
*
* Adds different input fields to allow the user to change and customize the widget settings.
*
* @since 1.6.41
* @access protected
*/
protected function register_controls() {
// Detect edit mode
$is_edit_mode = trx_addons_elm_is_edit_mode();
// Register controls
$this->start_controls_section(
'section_sc_quickcal',
[
'label' => __( 'ThemeREX QuickCal Calendar', 'trx_addons' ),
]
);
$this->add_control(
'style',
[
'label' => __( 'Layout', 'trx_addons' ),
'label_block' => false,
'type' => \Elementor\Controls_Manager::SELECT,
'options' => [
'calendar' => esc_html__('Calendar', 'trx_addons'),
'list' => esc_html__('List', 'trx_addons')
],
'default' => 'calendar'
]
);
$this->add_control(
'calendar',
[
'label' => __( 'Calendar', 'trx_addons' ),
'label_block' => false,
'type' => \Elementor\Controls_Manager::SELECT,
'options' => ! $is_edit_mode ? array() : trx_addons_array_merge( array( 0 => trx_addons_get_not_selected_text( esc_html__( 'Select calendar', 'trx_addons' ) ) ), trx_addons_get_list_terms(false, 'booked_custom_calendars' ) ),
'default' => '0'
]
);
$this->add_control(
'month',
[
'label' => __( 'Month', 'trx_addons' ),
'label_block' => false,
'type' => \Elementor\Controls_Manager::SELECT,
'options' => ! $is_edit_mode ? array() : trx_addons_array_merge( array( 0 => trx_addons_get_not_selected_text( esc_html__( 'Current month', 'trx_addons' ) ) ), trx_addons_get_list_months() ),
'default' => '0'
]
);
$this->add_control(
'year',
[
'label' => __( 'Year', 'trx_addons' ),
'label_block' => false,
'type' => \Elementor\Controls_Manager::SELECT,
'options' => ! $is_edit_mode ? array() : trx_addons_array_merge( array( 0 => trx_addons_get_not_selected_text( esc_html__( 'Current year', 'trx_addons' ) ) ), trx_addons_get_list_range( date('Y'), date('Y') + 25 ) ),
'default' => '0'
]
);
$this->end_controls_section();
}
// Return widget's layout
public function render() {
if ( shortcode_exists('quickcal-calendar') ) {
$atts = $this->sc_prepare_atts( $this->get_settings(), $this->get_sc_name() );
trx_addons_show_layout(
do_shortcode(
sprintf( '[quickcal-calendar style="%1$s" calendar="%2$s" month="%3$s" year="%4$s"]',
$atts['style'],
$atts['calendar'],
$atts['month'],
$atts['year']
)
)
);
} else {
$this->shortcode_not_exists( 'quickcal-calendar', 'QuickCal Calendar' );
}
}
}
// Add a widget to compatibility with old Booked plugin
class TRX_Addons_Elementor_Widget_Booked_Calendar extends TRX_Addons_Elementor_Widget_QuickCal_Calendar {
/**
* Retrieve widget name.
*
* @since 1.6.41
* @access public
*
* @return string Widget name.
*/
public function get_name() {
return 'trx_sc_booked_calendar';
}
/**
* Retrieve widget title.
*
* @since 1.6.41
* @access public
*
* @return string Widget title.
*/
public function get_title() {
return __( 'Booked Calendar (Legacy)', 'trx_addons' );
}
/**
* Get widget keywords.
*
* Retrieve the list of keywords the widget belongs to.
*
* @since 2.27.2
* @access public
*
* @return array Widget keywords.
*/
public function get_keywords() {
return [ 'calendar', 'schedule', 'appointment', 'booked' ];
}
}
// Register widget
trx_addons_elm_register_widget( 'TRX_Addons_Elementor_Widget_QuickCal_Calendar' );
trx_addons_elm_register_widget( 'TRX_Addons_Elementor_Widget_Booked_Calendar' );
}
}