Dołącz plik widgetu do plikufunctions.php motywu potomnego
![Dołącz plik widgetu do plikufunctions.php motywu potomnego](https://oen.pl/wp-content/uploads/2023/09/apple-touch-icon@2.png)
Stworzyłem widżet dla WP 5.9.3 w oparciu o samouczek online, który działał dobrze, ale polegał na umieszczeniu całego kodu w plikufunctions.php motywu potomnego, co zaczęło wyglądać nieco niechlujnie.
Umieściłem więc cały kod w osobnym pliku, w katalogu podstawowym motywu potomnego i próbowałem to zrobić require
to z motywu podrzędnego functions.php
.
Jednak teraz wydaje się, że w ogóle nie działa ani nie jest rejestrowany. Po kilku godzinach majsterkowania nadal wydaje się, że w ogóle nie został rozpoznany. Przejrzałem mnóstwo innych pytań, ale nie mogę znaleźć niczego, co działa. Strona nadal się ładuje, ale widżet nie jest widoczny ani na stronie, ani w obszarze administracyjnym.
Wśród rzeczy, które próbowałem umieścić w plikufunctions.php, poza zakodowaniem ścieżki (w ostateczności) są następujące:
1) require_once('my_widget1.php');
2) define('MY_THEME_FOLDER_PATH', trailingslashit(get_template_directory(__FILE__)));
require_once (MY_THEME_FOLDER_PATH . 'my_widget1.php');
3) require_once( get_stylesheet_directory() . '/my_widget1.php');
Rzeczywista ścieżka do pliku widżetu to:
/var/www/sites/xyz/wp_main/wp-content/themes/mychildtheme/my_widget1.php
Nie korzystałem zbyt często z WP, ale jestem zdziwiony, dlaczego to nie działa. Chyba brakuje mi czegoś oczywistego, ale nie jestem pewien, jak poczynić dalsze postępy. Wszelkie sugestie i pomoc będą bardzo mile widziane.
Zgodnie z prośbą w komentarzach, oto kod widżetu (bez bitów wyjściowych). Zasadniczo jest to przykład z WPB, który zmodyfikowałem i, jak zauważono, już działa dobrze, gdy kod znajduje się w plikufunctions.php. Uprawnienia Linuksa 644.
<?php
// Widget Creation
class wpb_widget extends WP_Widget {
function __construct() {
parent::__construct(
// Base ID of your widget
'wpb_widget',
// Widget name will appear in UI
__('WPBeginner Widget', 'wpb_widget_domain'),
// Widget description
array( 'description' => __( 'Sample widget', 'wpb_widget_domain' ), )
);
}
// Creating widget front-end
public function widget( $args, $instance ) {
$title = apply_filters( 'widget_title', $instance['title'] );
// before and after widget arguments are defined by themes
echo $args['before_widget'];
if ( ! empty( $title ) )
echo $args['before_title'] . $title . $args['after_title'];
// This is where you run the code and display the output
$post_id = get_the_ID();
# ... then a bunch of stuff to output
echo $args['after_widget'];
}
// Widget Backend
public function form( $instance ) {
if ( isset( $instance[ 'title' ] ) ) {
$title = $instance[ 'title' ];
}
else {
$title = __( 'New title', 'wpb_widget_domain' );
}
// Widget admin form
?>
<p>
<label for="<?php echo $this->get_field_id( 'title' ); ?>"><?php _e( 'Title:' ); ?></label>
<input class="widefat" id="<?php echo $this->get_field_id( 'title' ); ?>" name="<?php echo $this->get_field_name( 'title' ); ?>" type="text" value="<?php echo esc_attr( $title ); ?>" />
</p>
<?php
}
// Updating widget replacing old instances with new
public function update( $new_instance, $old_instance ) {
$instance = array();
$instance['title'] = ( ! empty( $new_instance['title'] ) ) ? strip_tags( $new_instance['title'] ) : '';
return $instance;
}
// Class wpb_widget ends here
}
// Register and load the widget
function wpb_load_widget() {
register_widget( 'wpb_widget' );
}
?>
Jeśli ma to jakiekolwiek znaczenie, motyw potomny, którego używam, pochodzi z momentous-lite
temat.