プロジェクト

全般

プロフィール

QA #339

未完了

Chromeにおけるredmineのカレンダー設定画面の表示について

湯原 光 さんがほぼ7年前に追加. 4年以上前に更新.

ステータス:
回答済
優先度:
通常
担当者:
-
カテゴリ:
-
対象バージョン:
-
開始日:
2017/06/07
期日:
進捗率:

0%

予定工数:

説明

■現象/要望

ChromeでもIEやFireFoxと同じようにカレンダー設定画面を表示させたい。(Redmine/プラグイン側で定義した休日設定などを反映したい。)


RedmineのView Customize pluginでカレンダーに祝日表示
http://qiita.com/kn5/items/4f0d5f2b86527f5f3a1d

こちらのサイトを参考にView Customize pluginを使用して、redmineのカレンダーに祝日を表示できるようになったのですが、
チケット作成の時に、開始日と期日を設定するときのポップアップカレンダーを表示させようとしたのですが、
IEとFireFoxでは祝日が表示されるポップアップカレンダーが表示されたのですが、Chromeではデフォルトのポップアップカレンダーのままでした。

調査したところ、
https://stackoverflow.com/questions/10932341/jquery-date-picker-not-working-on-chrome
上記のサイトに症状が似ていると思い、
開始日と期日のフィールドタイプをdate.fieldからtext.fieldに変更してみたのですが、
テキストフィールドに変わっただけでカレンダが表示されなくなってしまいました。
(app/view/issues/_attributes.html.ebの55行目と62行目を修正)

ChromeでもIEやFireFoxと同じように表示させたいのですがどのように修正をおこなえばよろしいでしょうか。

■解決策

ブラウザ内のDatePickerではなく、jQuery UI Datepickerを利用すれば良い。下記1,2のいずれか実施。
(Redmine3.3の修正を3.2以前の動作に戻す。スマホ等で使いにくくなる場合有)

なお、この修正は、 Chrome76にて発生したDatePickerが表示されない障害の対策としても有効。(この障害は、7/Eに配信開始され、8/7配信の76.0.3809.100にて修正された)

1.Viewcusyomizeに下記定義追加

(function ( $ ) {
  $.fn.datepickerFallback = function( options ) {
     return this.datepicker( options );
  };
}( jQuery ));

2. Redmineのソース変更

https://twitter.com/g_maeda/status/831012799081877505

public/javascripts/application.js の741行目で nativeDateInputSupported に false をセットする

■対応状況

Redmine本体のソース変更 or Viewcustomizeで対処可能

■補足

上記設定の副作用として、
スマホなどの画面が小さい場合もjQueryUIのカレンダーが表示される。(Redmine3.2以前と同じ)

Redmine3.3にて、モバイルデバイスの対応改善を考慮し、ブラウザ内のDatePickerがあれば、そちらを利用するように変更された。

Replace jQuery UI Datepicker with native browser date fields when available
http://www.redmine.org/issues/19468

Some browsers have started to implement the input type "date" and are rendering nice native date pickers.
This is especially useful on mobile devices where the jQuery UI Datepickers do not seem to work well,

理想を言えば、UI Agentレベルの動作変更を、各サイトレベルで実施可能とすることになる。
(viewcustomizeのスクリプトベース、デフォルトに各現場で詳細調整可能)


ファイル

firefox_カレンダー.PNG (10.3 KB) firefox_カレンダー.PNG プラグイン適用後のFireFoxのポップアップカレンダー(プラグインで設定したカレンダーが表示され、日付入力の隣にカレンダーアイコンあり) 湯原 光, 2017/06/14 11:13
chrome_カレンダー.PNG (9.64 KB) chrome_カレンダー.PNG プラグイン適用後のChromeのポップアップカレンダー(デフォルトのままで、日付入力の隣にカレンダーのアイコンが無い) 湯原 光, 2017/06/14 11:13

奈良 裕記 さんがほぼ7年前に更新

チケットのDatePickerにて、
IE&Firefoxでは休日が区別して表示されるが、
Chromeでは平日・休日の区別無しで表示されることを確認しました。
(手元の3.3の環境にて)

DatePickerの機能自体は動作していますので、下記とは異なると思うのですが。

jQuery Date Picker not working on Chrome
https://stackoverflow.com/questions/10932341/jquery-date-picker-not-working-on-chrome


Datepickerの使用方法(特にbeforeShowDay)で、下記などが関連するかもしれません。

datepickerで祝日を表示し、複数選択できるようにしたい
https://teratail.com/questions/46111

jQuery Datepicker beforeShowDay not working
https://stackoverflow.com/questions/4217262/jquery-datepicker-beforeshowday-not-working

jQuery reloading Date Picker not working on Chrome but it works on Firefox
https://stackoverflow.com/questions/13651932/jquery-reloading-date-picker-not-working-on-chrome-but-it-works-on-firefox

湯原 光 さんがほぼ7年前に更新

調査の方ありがとうございます。

チケットのDatePickerにて、
IE&Firefoxでは休日が区別して表示されるが、
Chromeでは平日・休日の区別無しで表示されることを確認しました。
(手元の3.3の環境にて)

Chromeで表示されているのはデフォルトのカレンダーではないでしょうか。
私の環境でもカレンダーは表示されますが、土日祝日の設定は反映されませんでした。

また、View Customize pluginで土日祝日の設定をした後、FireFoxやIEでは、日付入力の隣にカレンダーのアイコンがあるのですが、Chromeは表示されていませんでした。

FireFoxとIEで動作しているので、Chromeでも表示されると思ったのですがブラウザの仕様でしょうか。

よろしくお願い致します。

奈良 裕記 さんがほぼ7年前に更新

datepicker chrome firefox で検索してみました。

>FireFoxとIEで動作しているので、Chromeでも表示されると思ったのですがブラウザの仕様でしょうか。
そう判断した方が良いかと思います。

Disable native datepicker in Google Chrome
https://stackoverflow.com/questions/11320615/disable-native-datepicker-in-google-chrome

Quick FAQs on input[type=date] in Google Chrome
https://developers.google.com/web/updates/2012/08/Quick-FAQs-on-input-type-date-in-Google-Chrome

奈良 裕記 さんが4年以上前に更新

  • ステータス新規 から 回答済 に変更

奈良 裕記 さんが4年以上前に更新

  • 題名Chromeおけるredmineのカレンダーの表示について から Chromeおけるredmineのカレンダー設定画面の表示について に変更
  • 説明 を更新 (差分)

奈良 裕記 さんが4年以上前に更新

奈良 裕記 さんが4年以上前に更新

  • 題名Chromeおけるredmineのカレンダー設定画面の表示について から Chromeにおけるredmineのカレンダー設定画面の表示について に変更
  • 説明 を更新 (差分)

他の形式にエクスポート: Atom PDF