register_experiment(); if ( Plugin::$instance->experiments->is_feature_active( self::EXPERIMENT_NAME ) ) { Dynamic_Tags_Module::instance()->register_hooks(); ( new Atomic_Widget_Styles() )->register_hooks(); add_filter( 'elementor/editor/v2/packages', fn( $packages ) => $this->add_packages( $packages ) ); add_filter( 'elementor/editor/localize_settings', fn( $settings ) => $this->add_styles_schema( $settings ) ); add_filter( 'elementor/widgets/register', fn( Widgets_Manager $widgets_manager ) => $this->register_widgets( $widgets_manager ) ); add_action( 'elementor/atomic-widgets/settings/transformers/register', fn ( $transformers ) => $this->register_settings_transformers( $transformers ) ); add_action( 'elementor/atomic-widgets/styles/transformers/register', fn ( $transformers ) => $this->register_styles_transformers( $transformers ) ); add_action( 'elementor/elements/elements_registered', fn ( $elements_manager ) => $this->register_elements( $elements_manager ) ); add_action( 'elementor/editor/after_enqueue_scripts', fn() => $this->enqueue_scripts() ); add_action( 'elementor/frontend/after_register_styles', fn() => $this->register_styles() ); } } private function register_experiment() { Plugin::$instance->experiments->add_feature( [ 'name' => self::EXPERIMENT_NAME, 'title' => esc_html__( 'Atomic Widgets', 'elementor' ), 'description' => esc_html__( 'Enable atomic widgets.', 'elementor' ), 'hidden' => true, 'default' => Experiments_Manager::STATE_INACTIVE, 'release_status' => Experiments_Manager::RELEASE_STATUS_ALPHA, ] ); } private function add_packages( $packages ) { return array_merge( $packages, self::PACKAGES ); } private function add_styles_schema( $settings ) { if ( ! isset( $settings['atomic'] ) ) { $settings['atomic'] = []; } $settings['atomic']['styles_schema'] = Style_Schema::get(); return $settings; } private function register_widgets( Widgets_Manager $widgets_manager ) { $widgets_manager->register( new Atomic_Heading() ); $widgets_manager->register( new Atomic_Image() ); } private function register_elements( Elements_Manager $elements_manager ) { $elements_manager->register_element_type( new Div_Block() ); } private function register_settings_transformers( Transformers_Registry $transformers ) { // Primitives $transformers->register( Boolean_Prop_Type::get_key(), new Primitive_Transformer() ); $transformers->register( Number_Prop_Type::get_key(), new Primitive_Transformer() ); $transformers->register( String_Prop_Type::get_key(), new Primitive_Transformer() ); // Other $transformers->register( Classes_Prop_Type::get_key(), new Combine_Array_Transformer( ' ' ) ); $transformers->register( Image_Prop_Type::get_key(), new Image_Transformer() ); $transformers->register( Image_Src_Prop_Type::get_key(), new Image_Src_Transformer() ); $transformers->register( Image_Attachment_Id_Prop_Type::get_key(), new Primitive_Transformer() ); $transformers->register( Url_Prop_Type::get_key(), new Primitive_Transformer() ); $transformers->register( Link_Prop_Type::get_key(), new Link_Transformer() ); } private function register_styles_transformers( Transformers_Registry $transformers ) { // Primitives $transformers->register( Boolean_Prop_Type::get_key(), new Primitive_Transformer() ); $transformers->register( Number_Prop_Type::get_key(), new Primitive_Transformer() ); $transformers->register( String_Prop_Type::get_key(), new Primitive_Transformer() ); // Other $transformers->register( Linked_Dimensions_Prop_Type::get_key(), new Linked_Dimensions_Transformer() ); $transformers->register( Size_Prop_Type::get_key(), new Size_Transformer() ); $transformers->register( Color_Prop_Type::get_key(), new Primitive_Transformer() ); $transformers->register( Box_Shadow_Prop_Type::get_key(), new Combine_Array_Transformer( ',' ) ); $transformers->register( Shadow_Prop_Type::get_key(), new Shadow_Transformer() ); $transformers->register( Border_Radius_Prop_Type::get_key(), new Corner_Sizes_Transformer( fn( $corner ) => 'border-' . $corner . '-radius' ) ); $transformers->register( Border_Width_Prop_Type::get_key(), new Edge_Sizes_Transformer( fn( $edge ) => 'border-' . $edge . '-width' ) ); $transformers->register( Stroke_Prop_Type::get_key(), new Stroke_Transformer() ); $transformers->register( Gap_Prop_Type::get_key(), new Gap_Transformer() ); $transformers->register( Background_Color_Overlay_Prop_Type::get_key(), new Background_Color_Overlay_Transformer() ); $transformers->register( Background_Overlay_Prop_Type::get_key(), new Combine_Array_Transformer( ',' ) ); $transformers->register( Background_Prop_Type::get_key(), new Background_Transformer() ); } /** * Enqueue the module scripts. * * @return void */ private function enqueue_scripts() { wp_enqueue_script( 'elementor-atomic-widgets-editor', $this->get_js_assets_url( 'atomic-widgets-editor' ), [ 'elementor-editor' ], ELEMENTOR_VERSION, true ); } public function register_styles() { wp_register_style( 'div-block', $this->get_css_assets_url( 'div-block', 'assets/css/' ), [ 'elementor-frontend' ], ELEMENTOR_VERSION ); } }