Bug(バグ) #3485
完了PC向けUIの未ログイン時に jQuery 等のライブラリがロードされない
100%
説明
Overview (現象)¶
jquery.min.js
などのライブラリが PC 向け UI の未ログイン時には読み込まれない。これにより jQuery 等に依存するプラグインが未ログイン時の画面で動作できない状態となっている。
Causes (原因)¶
source:apps/pc_frontend/templates/_layout.php@27853bc5 の下記コードの通り、未ログイン時には use_javascript('jquery.min.js')
を通過しないためこれらのライブラリのロードが行われない。
<?php if (opConfig::get('enable_jsonapi') && opToolkit::isSecurePage()): ?>
<?php
use_helper('Javascript');
use_javascript('jquery.min.js');
use_javascript('jquery.tmpl.min.js');
use_javascript('jquery.notify.js');
use_javascript('op_notify.js');
$jsonData = array(
'apiKey' => $sf_user->getMemberApiKey(),
'apiBase' => app_url_for('api', 'homepage'),
'baseUrl' => $sf_request->getRelativeUrlRoot().'/',
);
echo javascript_tag('
var openpne = '.json_encode($jsonData).';
');
?>
<?php endif ?>
opConfig::get('enable_jsonapi') && opToolkit::isSecurePage()
という条件は API キーの出力を行うか否かを判断するための条件であるが、 9f50bdf66e3cdaaa4372669902995a1558d8cbe8 にて誤って use_javascript をこの if ブロック内に追加してしまったことが原因で当チケットの問題が発生した。
Way to fix (修正内容)¶
jQuery 等をロードする use_javascript
を opConfig::get('enable_jsonapi') && opToolkit::isSecurePage()
の if ブロックの外に移動する。
Youichi Kimura さんが約11年前に更新
- ステータス を New(新規) から Pending Review(レビュー待ち) に変更
- 進捗率 を 0 から 50 に変更
更新履歴 66a31866e32f8b9c10ca58ccb9ee3186e4105946 で適用されました。
Yuya Watanabe さんがほぼ11年前に更新
- ステータス を Pending Review(レビュー待ち) から Pending Testing(テスト待ち) に変更
- 進捗率 を 50 から 70 に変更
Shinichi Urabe さんが10年以上前に更新
- 次のチケットが重複 Bug(バグ) #3589: pc_frontend 全画面で呼び出される util.js が必須とする jquery.min.js が呼び出されていない条件がある を追加
Shinichi Urabe さんが10年以上前に更新
- ステータス を Pending Testing(テスト待ち) から Rejected(差し戻し) に変更
- 進捗率 を 70 から 50 に変更
source:apps/pc_frontend/config/view.yml@406bb371 によって jquery が必須な util.js が全画面で呼び出されるように修正されています
layout が plain など _lauyout.php 以外のレイアウトにセットされた場合 jquery が呼び出されませんので、 同様の条件で呼び出されていたほうがよいかと考えます (別チケット対応でいいかもしれません)
Rimpei Ogawa さんが3年以上前に更新
- ステータス を Pending Review(レビュー待ち) から Pending Testing(テスト待ち) に変更
- 進捗率 を 50 から 70 に変更