File: /var/www/html/triad-infosec/wp-content/plugins/fusion-builder/shortcodes/form/time.php
<?php
/**
* Add an element to fusion-builder.
*
* @package fusion-builder
* @since 3.1
*/
if ( fusion_is_element_enabled( 'fusion_form_time' ) ) {
if ( ! class_exists( 'FusionForm_Time' ) ) {
/**
* Shortcode class.
*
* @since 3.1
*/
class FusionForm_Time extends Fusion_Form_Component {
/**
* Constructor.
*
* @access public
* @since 3.1
*/
public function __construct() {
parent::__construct( 'fusion_form_time' );
}
/**
* Gets the default values.
*
* @static
* @access public
* @since 3.1
* @return array
*/
public static function get_element_defaults() {
return [
'label' => '',
'clock' => 'half',
'name' => '',
'required' => '',
'empty_notice' => '',
'picker' => 'custom',
'placeholder' => '',
'input_field_icon' => '',
'tab_index' => '',
'class' => '',
'value' => '',
'id' => '',
'logics' => '',
'tooltip' => '',
];
}
/**
* Render form field html.
*
* @access public
* @since 3.1
* @param string $content The content.
* @return string
*/
public function render_input_field( $content ) {
$element_data = $this->create_element_data( $this->args );
$html = '';
if ( '' !== $this->args['tooltip'] ) {
$element_data['label'] .= $this->get_field_tooltip( $this->args );
}
// If we are using a script the autocomplete popup blocks selection.
$auto_complete = 'native' !== $this->args['picker'] ? 'autocomplete="no"' : '';
// Input markup.
$element_html = '<input type="time" ';
$element_html .= '' !== $element_data['empty_notice'] ? 'data-empty-notice="' . $element_data['empty_notice'] . '" ' : '';
$element_html .= 'tabindex="' . $this->args['tab_index'] . '" id="' . $this->args['name'] . '" name="' . $this->args['name'] . '" data-type="' . esc_attr( $this->args['picker'] ) . '" data-clock="' . esc_attr( $this->args['clock'] ) . '" value="' . $this->args['value'] . '"' . $element_data['holds_private_data'] . $element_data['class'] . $element_data['required'] . $element_data['placeholder'] . $element_data['style'] . $auto_complete . '/>';
if ( isset( $this->args['input_field_icon'] ) && '' !== $this->args['input_field_icon'] ) {
$icon_html = '<div class="fusion-form-input-with-icon">';
$icon_html .= '<i class="' . fusion_font_awesome_name_handler( $this->args['input_field_icon'] ) . '"></i>';
$element_html = $icon_html . $element_html;
$element_html .= '</div>';
}
if ( 'above' === $this->params['form_meta']['label_position'] ) {
$html .= $element_data['label'] . $element_html;
} else {
$html .= $element_html . $element_data['label'];
}
return $html;
}
/**
* Sets the necessary scripts.
*
* @access public
* @since 3.2
* @return void
*/
public function on_first_render() {
Fusion_Dynamic_JS::enqueue_script(
'fusion-date-picker',
FusionBuilder::$js_folder_url . '/library/flatpickr.js',
FusionBuilder::$js_folder_path . '/library/flatpickr.js',
[ 'jquery' ],
FUSION_BUILDER_VERSION,
true
);
}
/**
* Load flat pickr.
*
* @access public
* @since 3.1
* @return void
*/
public function add_css_files() {
FusionBuilder()->add_element_css( FUSION_BUILDER_PLUGIN_DIR . 'assets/css/flatpickr.min.css' );
}
}
}
new FusionForm_Time();
}
/**
* Map shortcode to Fusion Builder
*
* @since 3.1
*/
function fusion_form_time() {
fusion_builder_map(
fusion_builder_frontend_data(
'FusionForm_Time',
[
'name' => esc_attr__( 'Time Field', 'fusion-builder' ),
'shortcode' => 'fusion_form_time',
'icon' => 'fusiona-af-time',
'form_component' => true,
'preview' => FUSION_BUILDER_PLUGIN_DIR . 'inc/templates/previews/fusion-form-element-preview.php',
'preview_id' => 'fusion-builder-block-module-form-element-preview-template',
'params' => [
[
'type' => 'textfield',
'heading' => esc_attr__( 'Field Label', 'fusion-builder' ),
'description' => esc_attr__( 'Enter the label for the input field. This is how users will identify individual fields.', 'fusion-builder' ),
'param_name' => 'label',
'value' => '',
'placeholder' => true,
],
[
'type' => 'textfield',
'heading' => esc_attr__( 'Field Name', 'fusion-builder' ),
'description' => esc_attr__( 'Enter the field name. Please use only lowercase alphanumeric characters, dashes, and underscores.', 'fusion-builder' ),
'param_name' => 'name',
'value' => '',
'placeholder' => true,
],
[
'type' => 'radio_button_set',
'heading' => esc_attr__( 'Required Field', 'fusion-builder' ),
'description' => esc_attr__( 'Make a selection to ensure that this field is completed before allowing the user to submit the form.', 'fusion-builder' ),
'param_name' => 'required',
'default' => 'no',
'value' => [
'yes' => esc_attr__( 'Yes', 'fusion-builder' ),
'no' => esc_attr__( 'No', 'fusion-builder' ),
],
],
[
'type' => 'textfield',
'heading' => esc_attr__( 'Empty Input Notice', 'fusion-builder' ),
'description' => esc_attr__( 'Enter text validation notice that should display if data input is empty.', 'fusion-builder' ),
'param_name' => 'empty_notice',
'value' => '',
'dependency' => [
[
'element' => 'required',
'value' => 'yes',
'operator' => '==',
],
],
],
[
'type' => 'textfield',
'heading' => esc_attr__( 'Placeholder Text', 'fusion-builder' ),
'param_name' => 'placeholder',
'value' => '',
'description' => esc_attr__( 'The placeholder text to display as hint for the input type. If tooltip is enabled, the placeholder will be displayed as tooltip.', 'fusion-builder' ),
],
[
'type' => 'textfield',
'heading' => esc_attr__( 'Tooltip Text', 'fusion-builder' ),
'param_name' => 'tooltip',
'value' => '',
'description' => esc_attr__( 'The text to display as tooltip hint for the input.', 'fusion-builder' ),
],
[
'type' => 'radio_button_set',
'heading' => esc_attr__( 'Custom Picker', 'fusion-builder' ),
'description' => esc_attr__( 'Choose to enable a lightweight custom picker on mobile only, mobile and desktop or set to never to use browser native.', 'fusion-builder' ),
'param_name' => 'picker',
'default' => 'custom',
'value' => [
'native' => esc_attr__( 'Never', 'fusion-builder' ),
'desktop' => esc_attr__( 'Desktop Only', 'fusion-builder' ),
'custom' => esc_attr__( 'Always', 'fusion-builder' ),
],
],
[
'type' => 'radio_button_set',
'heading' => esc_attr__( 'Clock Type', 'fusion-builder' ),
'description' => esc_attr__( 'Choose between 12 hour and 24 hour clock type. Note, will only work for custom picker type.', 'fusion-builder' ),
'param_name' => 'clock',
'default' => 'half',
'value' => [
'half' => esc_attr__( '12 Hour', 'fusion-builder' ),
'full' => esc_attr__( '24 Hour', 'fusion-builder' ),
],
'dependency' => [
[
'element' => 'picker',
'value' => 'native',
'operator' => '!=',
],
],
],
[
'type' => 'iconpicker',
'heading' => esc_attr__( 'Input Field Icon', 'fusion-builder' ),
'param_name' => 'input_field_icon',
'value' => '',
'description' => esc_attr__( 'Select an icon for the input field, click again to deselect.', 'fusion-builder' ),
],
[
'type' => 'textfield',
'heading' => esc_attr__( 'Tab Index', 'fusion-builder' ),
'param_name' => 'tab_index',
'value' => '',
'description' => esc_attr__( 'Tab index for the form field.', 'fusion-builder' ),
],
[
'type' => 'textfield',
'heading' => esc_attr__( 'CSS Class', 'fusion-builder' ),
'param_name' => 'class',
'value' => '',
'description' => esc_attr__( 'Add a class for the form field.', 'fusion-builder' ),
],
[
'type' => 'textfield',
'heading' => esc_attr__( 'CSS ID', 'fusion-builder' ),
'param_name' => 'id',
'value' => '',
'description' => esc_attr__( 'Add an ID for the form field.', 'fusion-builder' ),
],
'fusion_form_logics_placeholder' => [],
],
]
)
);
}
add_action( 'fusion_builder_before_init', 'fusion_form_time' );