質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

ただいまの
回答率

90.12%

BuddyPressの子テーマ

受付中

回答 1

投稿

  • 評価
  • クリップ 0
  • VIEW 398

hizirida

score 22

BuddyPress(ワードプレス プラグイン)の子テーマを、

途中まで作ってみたのですが、行き詰まってしまいました。

子テーマの作成方法を教えてください。

行なった一連の流れはこうです。

BuddyPressのテーマ(bp-default)をコピー。
wp-content/plugins/buddypress/bp-themes/bp-default

wp-content/themes 内にbp-defaultをペースト。

ディレクトリ名変更 bp-default → BuddyPress-child

BuddyPress-child 内ファイル(style.css)に下記記述。

@charset "UTF-8";
/**
* Theme Name: BuddyPress child
* Theme URI: https://www.example.com/blog/wp-content/themes/BuddyPress-child
* Description: 子テーマ
* Template: bp-default
* Version: 0.0.0
* Author URI: https://www.example.com/
*/

すると、
親テーマが見つかりません。
「bp-default」の親テーマをインストールしてください。
と、エラー表示されます。

Template の記述をどう明記して良いものか?

次に、
こちらのサイトには@import方法が書かれてるので、
https://www.tecking.org/archives/2318

参考にして、こう記述してみした。

@charset "UTF-8";
/**
* Theme Name: BuddyPress child
* Theme URI: https://www.example.com/blog/wp-content/themes/BuddyPress-child
* Description: 子テーマ
* Template: bp-default
* Version: 0.0.0
* Author URI: https://www.example.com/
*/
@import url( ../../plugins/buddypress/bp-themes/bp-default/_inc/css/default.css );
@import url( ../../plugins/buddypress/bp-themes/bp-default/_inc/css/adminbar.css );

しかし、「親テーマが見つかりません。」とエラーします。

ここで行き詰ってしまいました。
アドバイスよろしくお願いします。

  • 気になる質問をクリップする

    クリップした質問は、後からいつでもマイページで確認できます。

    またクリップした質問に回答があった際、通知やメールを受け取ることができます。

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

回答 1

+1

1. BuddyPressのテーマ(wp-content/plugins/buddypress/bp-themes/bp-default)を wp-content/themes 内にコピーして、 bp-default を作成する。

2. wp-content/themes/BuddyPress-child ディレクトリを作成

3. wp-content/themes/BuddyPress-child/style.css を下記の内容で作成

/**
* Theme Name: BuddyPress child
* Theme URI: https://www.example.com/blog/wp-content/themes/BuddyPress-child
* Description: 子テーマ
* Template: bp-default
* Version: 0.0.0
* Author URI: https://www.example.com/
*/

4. wp-content/themes/BuddyPress-child/functions.php を下記の内容で作成

add_action( 'wp_enqueue_scripts', 'theme_enqueue_styles' );
function theme_enqueue_styles() {
    wp_enqueue_style( 'parent-style', get_template_directory_uri() . '/style.css' );

}

で、子テーマが作成できると思います。

投稿

編集

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2019/02/05 07:24 編集

    ご回答ありがとうございます。
    何となく理解し、子テーマを作成できましたが、
    いくつか疑問があるので教えてください。

    プラグイン(BuddyPress)をバージョンアップした際、
    BuddyPressのテーマ(wp-content/plugins/buddypress/bp-themes/bp-default)はバージョンアップされるのでしょうか?それとも、wp-content/themes/bp-default がバージョンアップされるのでしょうか?

    現在、自作テーマで稼働していますが、
    wp-content/themes/bp-default は有効化しなくてもよいのでしょうか?
    有効化すると自作テーマが休止してしまうので。

    style.css以外にも手を加えたファイルがありますが、
    「functions.php」にどう追記するのでしょうか?
    そして、
    wp-content/themes/BuddyPress-child ディレクトリ
    にも手を加えてファイルを作ったほうがよいでしょうか。


    今後カスタマイズする際、例えばstyle.css は、

    * Description: 子テーマ
    * Template: bp-default
    * Version: 0.0.0
    * Author URI: https://www.example.com/
    */


    この後に追記していくのでしょうか?

    アドバイスお願いします。

    キャンセル

  • 2019/02/05 07:59

    > プラグイン(BuddyPress)をバージョンアップした際、
    BuddyPressのテーマ(wp-content/plugins/buddypress/bp-themes/bp-default)はバージョンアップされるのでしょうか?それとも、wp-content/themes/bp-default がバージョンアップされるのでしょうか?

    プラグインのアップデートで更新されるのは、 ` wp-content/plugins/buddypress/bp-themes/bp-default ` の方ですね。

    親テーマのコピーではなくて、
    ```
    cd wp-content/themes/
    ln -s ../plugins/buddypress/bp-themes/bp-default ./
    ```
    のように、プラグインの中の親テーマからテーマディレクトリにシンボリックリンクを作成すれば、親テーマが更新された場合に反映されます。

    なお、子テーマは、親テーマの一部を変更する場合に用いることが多いですので、すでに独自にテーマを使っている場合は、自作テーマをカスタマイズする方がようでしょう。

    > 現在、自作テーマで稼働していますが、wp-content/themes/bp-default は有効化しなくてもよいのでしょうか?
    > 有効化すると自作テーマが休止してしまうので。

    WordPress で選択できるテーマは1つだけです。
    自作テーマをつかわれているのであれば、 bp-default は、選択する必要がありません。

    > style.css以外にも手を加えたファイルがありますが、「functions.php」にどう追記するのでしょうか?
    > そして、wp-content/themes/BuddyPress-child ディレクトリにも手を加えてファイルを作ったほうがよいでしょうか。

    style.css や functions.php 以外のファイルは、テーマファイル内に作成します。


    > 今後カスタマイズする際、例えばstyle.css は、
    > * Description: 子テーマ
    > * Template: bp-default
    > * Version: 0.0.0
    > * Author URI: https://www.example.com/
    > */
    >
    > ↑
    > この後に追記していくのでしょうか?

    子テーマを使って、カスタマイズしていくのであれば、子テーマの style.css に追記していく形になります。
    独自テーマの場合は不要です。

    子テーマについての情報は、 https://wpdocs.osdn.jp/%E5%AD%90%E3%83%86%E3%83%BC%E3%83%9E
    等を参照してください。

    キャンセル

  • 2019/02/06 11:24 編集

    この手はそう熟知している訳ではないので、
    理解したことを整理しおきます。
    誤りがあればご指摘して下さい。

    プラグインの子テーマ作成は、
    wp-content/themes/ ここに2ディレクトリ作成。

    1.BuddyPress-child (子テーマ)
    2.bp-default (ショートカットみたいなもの?)

    1内には、style.css と functions.php
    2は BuddyPressのテーマ(wp-content/plugins/buddypress/bp-themes/bp-default)の複製。

    プラグインがバージョンアップされると、2もバージョンアップされる。

    bp-default内の「style.css」は、BuddyPress-child(子テーマ)内の「style.css」に紐付けされているので、
    編集(カスタマイズ)する場合、
    BuddyPress-child(子テーマ)内の「style.css」に手を加えるとで、
    それがbp-defaultを辿り、プラグイン内の親テーマに継承される。

    ところで、
    親テーマ「bp-default」(wp-content/plugins/buddypress/bp-themes/bp-default)と、
    この複製(wp-content/themes/bp-default)の紐付けは、自動的に認識されるのですか?

    レイアウト変更等のカスタマイズは、
    親テーマ(plugins/buddypress/bp-themes/bp-default/_inc/css/default.css)だと思うのですが、
    子テーマの(wp-content/themes/bp-default/style.css)に手を加えても、
    /bp-default/_inc/css/default.css には継承されるのでしょうか。

    キャンセル

15分調べてもわからないことは、teratailで質問しよう!

  • ただいまの回答率 90.12%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる