Classes_Prop_Type::make() ->default( [] ), 'image' => Image_Prop_Type::make() ->default_url( Placeholder_Image::get_placeholder_image() ) ->default_size( 'full' ), 'link' => Link_Prop_Type::make(), ]; if ( Plugin::$instance->experiments->is_feature_active( Module::EXPERIMENT_VERSION_3_30 ) ) { $props['_cssid'] = String_Prop_Type::make(); } return $props; } protected function define_atomic_controls(): array { $content_section = Section::make() ->set_label( esc_html__( 'Content', 'elementor' ) ) ->set_items( [ Image_Control::bind_to( 'image' ) ->set_show_mode( 'media' ), ] ); $settings_section_items = [ Image_Control::bind_to( 'image' ) ->set_show_mode( 'sizes' ), Link_Control::bind_to( 'link' )->set_meta( [ 'topDivider' => true, ] )->set_label( __( 'Link', 'elementor' ) ), ]; if ( Plugin::$instance->experiments->is_feature_active( Module::EXPERIMENT_VERSION_3_30 ) ) { $settings_section_items[] = Text_Control::bind_to( '_cssid' )->set_label( __( 'ID', 'elementor' ) )->set_meta( [ 'layout' => 'two-columns', 'topDivider' => true, ] ); } return [ $content_section, Section::make() ->set_label( esc_html__( 'Settings', 'elementor' ) ) ->set_items( $settings_section_items ), ]; } protected function define_base_styles(): array { return [ self::LINK_BASE_STYLE_KEY => Style_Definition::make() ->add_variant( Style_Variant::make() ->add_prop( 'display', 'inherit' ) ->add_prop( 'width', 'fit-content' ) ), self::BASE_STYLE_KEY => Style_Definition::make() ->add_variant( Style_Variant::make() ->add_prop( 'display', 'block' ) ), ]; } protected function get_templates(): array { return [ 'elementor/elements/atomic-image' => __DIR__ . '/atomic-image.html.twig', ]; } }