0

私の最初の実験はelggです。elgg_view('input/date' は datepicker 関数を使用していますが、いくつかオプションを追加する必要があります。

私のプラグイン (「ヘルプ」と呼ばれる) 初期化関数 (start.php) で、elgg_extend_view('js/elgg', 'help/js'); を宣言しました。次に、\mod\help\views\default\help\js.php で、elgg コアから elgg.ui.initDatePicker 関数をコピーし、それにオプションを追加しました。また、追加しました

elgg.provide('elgg.help');

上部と

elgg.register_hook_handler('init', 'system', elgg.ui.initDatePicker);

下部に、次のように:

-- \mod\help\views\default\help\js.php コードの始まり

elgg.provide('elgg.help');

elgg.ui.initDatePicker = function() {
    var loadDatePicker = function() {
        $('.elgg-input-date').datepicker({

            // MY OPTIONS ADDED
            yearRange: "-100:+0",
            changeYear: true,
            changeMonth: true,

            // ISO-8601
            dateFormat: 'yy-mm-dd',
            onSelect: function(dateText) {
                if ($(this).is('.elgg-input-timestamp')) {
                    // convert to unix timestamp
                    var dateParts = dateText.split("-");
                    var timestamp = Date.UTC(dateParts[0], dateParts[1] - 1, dateParts[2]);
                    timestamp = timestamp / 1000;

                    var id = $(this).attr('id');
                    $('input[name="' + id + '"]').val(timestamp);
                }
            }
        });
    };

    if ($('.elgg-input-date').length && elgg.get_language() == 'en') {
        loadDatePicker();
    } else if ($('.elgg-input-date').length) {
        elgg.get({
            url: elgg.config.wwwroot + 'vendors/jquery/i18n/jquery.ui.datepicker-'+ elgg.get_language() +'.js',
            dataType: "script",
            cache: true,
            success: loadDatePicker,
            error: loadDatePicker // english language is already loaded.
        });
    }
}

elgg.register_hook_handler('init', 'system', elgg.ui.initDatePicker);

--- \mod\help\views\default\help\js.php コードの終わり

確かにカレンダーは開きますが、yearRange、changeYear、および changeMonth オプションは適用されません。ただし、elgg\js\lib\ui.js にオプションを追加するだけで問題なく動作します。コア ファイルをいじりたくないので、ここでヒントを求めます。ありがとうございました

4

2 に答える 2