plugin install

This commit is contained in:
Tony Volpe
2024-06-18 17:29:05 -04:00
parent e1aaedd1ae
commit 41f50eacc4
5880 changed files with 1057631 additions and 39681 deletions

View File

@@ -0,0 +1,150 @@
<?php
namespace Gravity_Forms\Gravity_Forms\Form_Display\Block_Styles;
use GFCommon;
use Gravity_Forms\Gravity_Forms\Form_Display\Block_Styles\Views\Confirmation_View;
use Gravity_Forms\Gravity_Forms\Form_Display\Block_Styles\Views\Form_View;
use Gravity_Forms\Gravity_Forms\Theme_Layers\API\Fluent\Theme_Layer_Builder;
class Block_Styles_Handler {
const NAME = 'block_styles';
protected $defaults_map;
public function __construct( $defaults_map ) {
$this->defaults_map = $defaults_map;
}
public function defaults_map( $form ) {
return call_user_func( $this->defaults_map, $form );
}
public function handle() {
$layer = new Theme_Layer_Builder();
$layer->set_name( self::NAME )
->set_form_css_properties( array( $this, 'form_css_properties' ) )
->set_overidden_fields( $this->overriden_fields() )
->set_styles( array( $this, 'styles' ) )
->register();
}
public function form_css_properties( $form_id, $settings, $block_settings, $form = array() ) {
if ( rgar( $form, 'styles' ) === false ) {
return array();
}
$applied_settings = wp_parse_args( $block_settings, $this->defaults_map( $form ) );
// Bail early if orbital isn't applied.
if ( $applied_settings['theme'] !== 'orbital' ) {
return array();
}
$color_palette = GFCommon::generate_block_styles_palette( $applied_settings );
return array(
/* Global CSS API: Theme */
'gf-color-primary' => $color_palette['primary']['color'],
'gf-color-primary-rgb' => implode( ', ', $color_palette['primary']['color-rgb'] ),
'gf-color-primary-contrast' => $color_palette['primary']['color-contrast'],
'gf-color-primary-contrast-rgb' => implode( ', ', $color_palette['primary']['color-contrast-rgb'] ),
'gf-color-primary-darker' => $color_palette['primary']['color-darker'],
'gf-color-primary-lighter' => $color_palette['primary']['color-lighter'],
'gf-color-secondary' => $color_palette['secondary']['color'],
'gf-color-secondary-rgb' => implode( ', ', $color_palette['secondary']['color-rgb'] ),
'gf-color-secondary-contrast' => $color_palette['secondary']['color-contrast'],
'gf-color-secondary-contrast-rgb' => implode( ', ', $color_palette['secondary']['color-contrast-rgb'] ),
'gf-color-secondary-darker' => $color_palette['secondary']['color-darker'],
'gf-color-secondary-lighter' => $color_palette['secondary']['color-lighter'],
'gf-color-out-ctrl-light' => $color_palette['outside-control-light']['color'],
'gf-color-out-ctrl-light-rgb' => implode( ', ', $color_palette['outside-control-light']['color-rgb'] ),
'gf-color-out-ctrl-light-darker' => $color_palette['outside-control-light']['color-darker'],
'gf-color-out-ctrl-light-lighter' => $color_palette['outside-control-light']['color-lighter'],
'gf-color-out-ctrl-dark' => $color_palette['outside-control-dark']['color'],
'gf-color-out-ctrl-dark-rgb' => implode( ', ', $color_palette['outside-control-dark']['color-rgb'] ),
'gf-color-out-ctrl-dark-darker' => $color_palette['outside-control-dark']['color-darker'],
'gf-color-out-ctrl-dark-lighter' => $color_palette['outside-control-dark']['color-lighter'],
'gf-color-in-ctrl' => $color_palette['inside-control']['color'],
'gf-color-in-ctrl-rgb' => implode( ', ', $color_palette['inside-control']['color-rgb'] ),
'gf-color-in-ctrl-contrast' => $color_palette['inside-control']['color-contrast'],
'gf-color-in-ctrl-contrast-rgb' => implode( ', ', $color_palette['inside-control']['color-contrast-rgb'] ),
'gf-color-in-ctrl-darker' => $color_palette['inside-control']['color-darker'],
'gf-color-in-ctrl-lighter' => $color_palette['inside-control']['color-lighter'],
'gf-color-in-ctrl-primary' => $color_palette['inside-control-primary']['color'],
'gf-color-in-ctrl-primary-rgb' => implode( ', ', $color_palette['inside-control-primary']['color-rgb'] ),
'gf-color-in-ctrl-primary-contrast' => $color_palette['inside-control-primary']['color-contrast'],
'gf-color-in-ctrl-primary-contrast-rgb' => implode( ', ', $color_palette['inside-control-primary']['color-contrast-rgb'] ),
'gf-color-in-ctrl-primary-darker' => $color_palette['inside-control-primary']['color-darker'],
'gf-color-in-ctrl-primary-lighter' => $color_palette['inside-control-primary']['color-lighter'],
'gf-color-in-ctrl-light' => $color_palette['inside-control-light']['color'],
'gf-color-in-ctrl-light-rgb' => implode( ', ', $color_palette['inside-control-light']['color-rgb'] ),
'gf-color-in-ctrl-light-darker' => $color_palette['inside-control-light']['color-darker'],
'gf-color-in-ctrl-light-lighter' => $color_palette['inside-control-light']['color-lighter'],
'gf-color-in-ctrl-dark' => $color_palette['inside-control-dark']['color'],
'gf-color-in-ctrl-dark-rgb' => implode( ', ', $color_palette['inside-control-dark']['color-rgb'] ),
'gf-color-in-ctrl-dark-darker' => $color_palette['inside-control-dark']['color-darker'],
'gf-color-in-ctrl-dark-lighter' => $color_palette['inside-control-dark']['color-lighter'],
'gf-radius' => $applied_settings['inputBorderRadius'] . 'px',
/* Global CSS API: Typography */
'gf-font-size-secondary' => $applied_settings['labelFontSize'] . 'px',
'gf-font-size-tertiary' => $applied_settings['descriptionFontSize'] . 'px',
/* Global CSS API: Icons */
'gf-icon-ctrl-number' => "url(\"data:image/svg+xml,%3Csvg width='8' height='14' viewBox='0 0 8 14' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M4 0C4.26522 5.96046e-08 4.51957 0.105357 4.70711 0.292893L7.70711 3.29289C8.09763 3.68342 8.09763 4.31658 7.70711 4.70711C7.31658 5.09763 6.68342 5.09763 6.29289 4.70711L4 2.41421L1.70711 4.70711C1.31658 5.09763 0.683417 5.09763 0.292893 4.70711C-0.0976311 4.31658 -0.097631 3.68342 0.292893 3.29289L3.29289 0.292893C3.48043 0.105357 3.73478 0 4 0ZM0.292893 9.29289C0.683417 8.90237 1.31658 8.90237 1.70711 9.29289L4 11.5858L6.29289 9.29289C6.68342 8.90237 7.31658 8.90237 7.70711 9.29289C8.09763 9.68342 8.09763 10.3166 7.70711 10.7071L4.70711 13.7071C4.31658 14.0976 3.68342 14.0976 3.29289 13.7071L0.292893 10.7071C-0.0976311 10.3166 -0.0976311 9.68342 0.292893 9.29289Z' fill='{$color_palette['inside-control-dark']['color-lighter']}'/%3E%3C/svg%3E\")",
'gf-icon-ctrl-select' => "url(\"data:image/svg+xml,%3Csvg width='10' height='6' viewBox='0 0 10 6' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M0.292893 0.292893C0.683417 -0.097631 1.31658 -0.097631 1.70711 0.292893L5 3.58579L8.29289 0.292893C8.68342 -0.0976311 9.31658 -0.0976311 9.70711 0.292893C10.0976 0.683417 10.0976 1.31658 9.70711 1.70711L5.70711 5.70711C5.31658 6.09763 4.68342 6.09763 4.29289 5.70711L0.292893 1.70711C-0.0976311 1.31658 -0.0976311 0.683418 0.292893 0.292893Z' fill='{$color_palette['inside-control-dark']['color-lighter']}'/%3E%3C/svg%3E\")",
'gf-icon-ctrl-search' => "url(\"data:image/svg+xml,%3Csvg version='1.1' xmlns='http://www.w3.org/2000/svg' width='640' height='640'%3E%3Cpath d='M256 128c-70.692 0-128 57.308-128 128 0 70.691 57.308 128 128 128 70.691 0 128-57.309 128-128 0-70.692-57.309-128-128-128zM64 256c0-106.039 85.961-192 192-192s192 85.961 192 192c0 41.466-13.146 79.863-35.498 111.248l154.125 154.125c12.496 12.496 12.496 32.758 0 45.254s-32.758 12.496-45.254 0L367.248 412.502C335.862 434.854 297.467 448 256 448c-106.039 0-192-85.962-192-192z' fill='{$color_palette['inside-control-dark']['color-lighter']}'/%3E%3C/svg%3E\")",
/* Global CSS API: Layout & Spacing */
'gf-label-space-y-secondary' => 'var(--gf-label-space-y-' . $applied_settings['inputSize'] . '-secondary)',
/* Global CSS API: Controls - Default For All Types */
'gf-ctrl-border-color' => $applied_settings['inputBorderColor'],
'gf-ctrl-size' => 'var(--gf-ctrl-size-' . $applied_settings['inputSize'] . ')',
/* Global CSS API: Control - Label */
'gf-ctrl-label-color-primary' => $applied_settings['labelColor'],
'gf-ctrl-label-color-secondary' => $applied_settings['labelColor'],
/* Global CSS API: Control - Choice (Checkbox, Radio, & Consent) */
'gf-ctrl-choice-size' => 'var(--gf-ctrl-choice-size-' . $applied_settings['inputSize'] . ')',
'gf-ctrl-checkbox-check-size' => 'var(--gf-ctrl-checkbox-check-size-' . $applied_settings['inputSize'] . ')',
'gf-ctrl-radio-check-size' => 'var(--gf-ctrl-radio-check-size-' . $applied_settings['inputSize'] . ')',
/* Global CSS API: Control - Button */
'gf-ctrl-btn-font-size' => 'var(--gf-ctrl-btn-font-size-' . $applied_settings['inputSize'] . ')',
'gf-ctrl-btn-padding-x' => 'var(--gf-ctrl-btn-padding-x-' . $applied_settings['inputSize'] . ')',
'gf-ctrl-btn-size' => 'var(--gf-ctrl-btn-size-' . $applied_settings['inputSize'] . ')',
'gf-ctrl-btn-border-color-secondary' => $applied_settings['inputBorderColor'],
/* Global CSS API: Control - File */
'gf-ctrl-file-btn-bg-color-hover' => GFCommon::darken_color( $color_palette['inside-control']['color-darker'], 2 ),
/* Global CSS API: Field - Page */
'gf-field-pg-steps-number-color' => 'rgba(' . implode( ', ', GFCommon::darken_color( $applied_settings['labelColor'], 0, 'rgb' ) ) . ', 0.8)',
);
}
private function overriden_fields() {
return array(
'form' => Form_View::class,
'confirmation' => Confirmation_View::class,
);
}
public function styles( $form, $ajax, $settings, $block_settings ) {
return array();
}
}

View File

@@ -0,0 +1,58 @@
<?php
namespace Gravity_Forms\Gravity_Forms\Form_Display\Block_Styles\Views;
use Gravity_Forms\Gravity_Forms\Settings\Fields\Text;
use Gravity_Forms\Gravity_Forms\Theme_Layers\API\View;
use \GFFormDisplay;
class Confirmation_View extends Form_View {
protected $string_search = "class='gform_confirmation_wrapper";
protected $retain_original = true;
public function get_markup( $content, $form, $value, $lead_id, $form_id ) {
$content = $this->add_wrapper_class( $content, $form );
$content = $this->add_form_theme_data_attr( $content, $form );
return $content;
}
protected function add_wrapper_class( $content, $form ) {
$theme_slug = GFFormDisplay::get_form_theme_slug( $form );
$classes = '';
switch ( $theme_slug ) {
case 'orbital':
$classes = 'gform_confirmation_wrapper gform_wrapper gform-theme gform-theme--foundation gform-theme--framework gform-theme--' . $theme_slug;
break;
case 'gravity-theme':
default:
$classes = 'gform_confirmation_wrapper gravity-theme gform-theme--no-framework';
break;
case 'legacy':
$classes = 'gform_confirmation_wrapper gform_legacy_markup_wrapper gform_legacy_confirmation_markup_wrapper gform-theme--no-framework';
break;
}
$classes = sprintf( "class='%s", $classes );
return str_replace( $this->string_search, $classes, $content );
}
/**
* Add the form theme data attribute to the confirmation wrapper class.
*
* @since 2.7
*
* @param $content
* @param $form
*
* @return array|string|string[]
*/
protected function add_form_theme_data_attr( $content, $form ) {
$theme_slug = GFFormDisplay::get_form_theme_slug( $form );
$theme_attr = sprintf( "data-form-theme='%s' class='gform_confirmation_wrapper", $theme_slug );
return str_replace( $this->string_search, $theme_attr, $content );
}
}

View File

@@ -0,0 +1,43 @@
<?php
namespace Gravity_Forms\Gravity_Forms\Form_Display\Block_Styles\Views;
use Gravity_Forms\Gravity_Forms\Theme_Layers\API\View;
use \GFFormDisplay;
class Form_View extends View {
protected $string_search = ' gform_wrapper';
public function should_override( $form, $form_id, $block_settings = array() ) {
return true;
}
public function get_markup( $content, $form, $value, $lead_id, $form_id ) {
$content = $this->add_wrapper_class( $content, $form );
return $content;
}
protected function add_wrapper_class( $content, $form ) {
require_once( \GFCommon::get_base_path() . '/form_display.php' );
$theme_slug = GFFormDisplay::get_form_theme_slug( $form );
$classes = '';
switch ( $theme_slug ) {
case 'orbital':
$classes = ' gform_wrapper gform-theme gform-theme--foundation gform-theme--framework gform-theme--' . $theme_slug;
break;
case 'gravity-theme':
default:
$classes = ' gform_wrapper gravity-theme gform-theme--no-framework';
break;
case 'legacy':
$classes = ' gform_wrapper gform_legacy_markup_wrapper gform-theme--no-framework';
break;
}
return str_replace( $this->string_search, $classes, $content );
}
}