mirror of
				https://github.com/zulip/zulip.git
				synced 2025-11-03 21:43:21 +00:00 
			
		
		
		
	flatpickr: Move show_flatpickr function in a new module.
				
					
				
			This would avoid cyclic imports to access `show_flatpickr` function.
This commit is contained in:
		@@ -12,8 +12,8 @@ import * as compose_fade from "./compose_fade";
 | 
				
			|||||||
import * as compose_state from "./compose_state";
 | 
					import * as compose_state from "./compose_state";
 | 
				
			||||||
import * as compose_ui from "./compose_ui";
 | 
					import * as compose_ui from "./compose_ui";
 | 
				
			||||||
import * as compose_validate from "./compose_validate";
 | 
					import * as compose_validate from "./compose_validate";
 | 
				
			||||||
import * as composebox_typeahead from "./composebox_typeahead";
 | 
					 | 
				
			||||||
import * as echo from "./echo";
 | 
					import * as echo from "./echo";
 | 
				
			||||||
 | 
					import * as flatpickr from "./flatpickr";
 | 
				
			||||||
import * as giphy from "./giphy";
 | 
					import * as giphy from "./giphy";
 | 
				
			||||||
import {$t, $t_html} from "./i18n";
 | 
					import {$t, $t_html} from "./i18n";
 | 
				
			||||||
import * as loading from "./loading";
 | 
					import * as loading from "./loading";
 | 
				
			||||||
@@ -637,7 +637,7 @@ export function initialize() {
 | 
				
			|||||||
                compose_ui.insert_syntax_and_focus(timestr, target_textarea);
 | 
					                compose_ui.insert_syntax_and_focus(timestr, target_textarea);
 | 
				
			||||||
            };
 | 
					            };
 | 
				
			||||||
 | 
					
 | 
				
			||||||
            composebox_typeahead.show_flatpickr(
 | 
					            flatpickr.show_flatpickr(
 | 
				
			||||||
                $(compose_click_target)[0],
 | 
					                $(compose_click_target)[0],
 | 
				
			||||||
                on_timestamp_selection,
 | 
					                on_timestamp_selection,
 | 
				
			||||||
                new Date(),
 | 
					                new Date(),
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1,5 +1,3 @@
 | 
				
			|||||||
import {formatISO} from "date-fns";
 | 
					 | 
				
			||||||
import ConfirmDatePlugin from "flatpickr/dist/plugins/confirmDate/confirmDate";
 | 
					 | 
				
			||||||
import $ from "jquery";
 | 
					import $ from "jquery";
 | 
				
			||||||
import _ from "lodash";
 | 
					import _ from "lodash";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -12,7 +10,7 @@ import * as compose_pm_pill from "./compose_pm_pill";
 | 
				
			|||||||
import * as compose_state from "./compose_state";
 | 
					import * as compose_state from "./compose_state";
 | 
				
			||||||
import * as compose_ui from "./compose_ui";
 | 
					import * as compose_ui from "./compose_ui";
 | 
				
			||||||
import * as compose_validate from "./compose_validate";
 | 
					import * as compose_validate from "./compose_validate";
 | 
				
			||||||
import {get_keydown_hotkey} from "./hotkey";
 | 
					import * as flatpickr from "./flatpickr";
 | 
				
			||||||
import {$t} from "./i18n";
 | 
					import {$t} from "./i18n";
 | 
				
			||||||
import * as message_store from "./message_store";
 | 
					import * as message_store from "./message_store";
 | 
				
			||||||
import * as muted_users from "./muted_users";
 | 
					import * as muted_users from "./muted_users";
 | 
				
			||||||
@@ -768,118 +766,6 @@ export function content_highlighter(item) {
 | 
				
			|||||||
    }
 | 
					    }
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
function is_numeric_key(key) {
 | 
					 | 
				
			||||||
    return ["0", "1", "2", "3", "4", "5", "6", "7", "8", "9"].includes(key);
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
export function show_flatpickr(element, callback, default_timestamp, options = {}) {
 | 
					 | 
				
			||||||
    const flatpickr_input = $("<input id='#timestamp_flatpickr'>");
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    const instance = flatpickr_input.flatpickr({
 | 
					 | 
				
			||||||
        mode: "single",
 | 
					 | 
				
			||||||
        enableTime: true,
 | 
					 | 
				
			||||||
        clickOpens: false,
 | 
					 | 
				
			||||||
        defaultDate: default_timestamp,
 | 
					 | 
				
			||||||
        plugins: [
 | 
					 | 
				
			||||||
            new ConfirmDatePlugin({
 | 
					 | 
				
			||||||
                showAlways: true,
 | 
					 | 
				
			||||||
                confirmText: $t({defaultMessage: "Confirm"}),
 | 
					 | 
				
			||||||
                confirmIcon: "",
 | 
					 | 
				
			||||||
            }),
 | 
					 | 
				
			||||||
        ],
 | 
					 | 
				
			||||||
        positionElement: element,
 | 
					 | 
				
			||||||
        dateFormat: "Z",
 | 
					 | 
				
			||||||
        formatDate: (date) => formatISO(date),
 | 
					 | 
				
			||||||
        disableMobile: true,
 | 
					 | 
				
			||||||
        onKeyDown: (selectedDates, dateStr, instance, event) => {
 | 
					 | 
				
			||||||
            if (is_numeric_key(event.key)) {
 | 
					 | 
				
			||||||
                // Don't attempt to get_keydown_hotkey for numeric inputs
 | 
					 | 
				
			||||||
                // as it would return undefined.
 | 
					 | 
				
			||||||
                return;
 | 
					 | 
				
			||||||
            }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
            const hotkey = get_keydown_hotkey(event);
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
            if (["tab", "shift_tab"].includes(hotkey.name)) {
 | 
					 | 
				
			||||||
                const elems = [
 | 
					 | 
				
			||||||
                    instance.selectedDateElem,
 | 
					 | 
				
			||||||
                    instance.hourElement,
 | 
					 | 
				
			||||||
                    instance.minuteElement,
 | 
					 | 
				
			||||||
                    instance.amPM,
 | 
					 | 
				
			||||||
                    $(".flatpickr-confirm")[0],
 | 
					 | 
				
			||||||
                ];
 | 
					 | 
				
			||||||
                const i = elems.indexOf(event.target);
 | 
					 | 
				
			||||||
                const n = elems.length;
 | 
					 | 
				
			||||||
                const remain = (i + (event.shiftKey ? -1 : 1)) % n;
 | 
					 | 
				
			||||||
                const target = elems[Math.floor(remain >= 0 ? remain : remain + n)];
 | 
					 | 
				
			||||||
                event.preventDefault();
 | 
					 | 
				
			||||||
                event.stopPropagation();
 | 
					 | 
				
			||||||
                target.focus();
 | 
					 | 
				
			||||||
            }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
            event.stopPropagation();
 | 
					 | 
				
			||||||
        },
 | 
					 | 
				
			||||||
        ...options,
 | 
					 | 
				
			||||||
    });
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    const container = $($(instance.innerContainer).parent());
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    container.on("keydown", (e) => {
 | 
					 | 
				
			||||||
        if (is_numeric_key(e.key)) {
 | 
					 | 
				
			||||||
            // Let users type numeric values
 | 
					 | 
				
			||||||
            return true;
 | 
					 | 
				
			||||||
        }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
        const hotkey = get_keydown_hotkey(e);
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
        if (!hotkey) {
 | 
					 | 
				
			||||||
            return false;
 | 
					 | 
				
			||||||
        }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
        if (hotkey.name === "backspace" || hotkey.name === "delete") {
 | 
					 | 
				
			||||||
            // Let backspace or delete be handled normally
 | 
					 | 
				
			||||||
            return true;
 | 
					 | 
				
			||||||
        }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
        if (hotkey.name === "enter") {
 | 
					 | 
				
			||||||
            if (e.target.classList[0] === "flatpickr-day") {
 | 
					 | 
				
			||||||
                return true; // use flatpickr default implementation
 | 
					 | 
				
			||||||
            }
 | 
					 | 
				
			||||||
            $(element).toggleClass("has_popover");
 | 
					 | 
				
			||||||
            container.find(".flatpickr-confirm").trigger("click");
 | 
					 | 
				
			||||||
        }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
        if (hotkey.name === "escape") {
 | 
					 | 
				
			||||||
            $(element).toggleClass("has_popover");
 | 
					 | 
				
			||||||
            instance.close();
 | 
					 | 
				
			||||||
            instance.destroy();
 | 
					 | 
				
			||||||
        }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
        if (["tab", "shift_tab"].includes(hotkey.name)) {
 | 
					 | 
				
			||||||
            return true; // use flatpickr default implementation
 | 
					 | 
				
			||||||
        }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
        if (["right_arrow", "up_arrow", "left_arrow", "down_arrow"].includes(hotkey.name)) {
 | 
					 | 
				
			||||||
            return true; // use flatpickr default implementation
 | 
					 | 
				
			||||||
        }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
        e.stopPropagation();
 | 
					 | 
				
			||||||
        e.preventDefault();
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
        return true;
 | 
					 | 
				
			||||||
    });
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    container.on("click", ".flatpickr-confirm", () => {
 | 
					 | 
				
			||||||
        callback(flatpickr_input.val());
 | 
					 | 
				
			||||||
        instance.close();
 | 
					 | 
				
			||||||
        instance.destroy();
 | 
					 | 
				
			||||||
    });
 | 
					 | 
				
			||||||
    instance.open();
 | 
					 | 
				
			||||||
    instance.selectedDateElem.focus();
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    return instance;
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
export function content_typeahead_selected(item, event) {
 | 
					export function content_typeahead_selected(item, event) {
 | 
				
			||||||
    const pieces = split_at_cursor(this.query, this.$element);
 | 
					    const pieces = split_at_cursor(this.query, this.$element);
 | 
				
			||||||
    let beginning = pieces[0];
 | 
					    let beginning = pieces[0];
 | 
				
			||||||
@@ -1016,7 +902,7 @@ export function content_typeahead_selected(item, event) {
 | 
				
			|||||||
                textbox.caret(beginning.length, beginning.length);
 | 
					                textbox.caret(beginning.length, beginning.length);
 | 
				
			||||||
                compose_ui.autosize_textarea(textbox);
 | 
					                compose_ui.autosize_textarea(textbox);
 | 
				
			||||||
            };
 | 
					            };
 | 
				
			||||||
            show_flatpickr(this.$element[0], on_timestamp_selection, timestamp);
 | 
					            flatpickr.show_flatpickr(this.$element[0], on_timestamp_selection, timestamp);
 | 
				
			||||||
            return beginning + rest;
 | 
					            return beginning + rest;
 | 
				
			||||||
        }
 | 
					        }
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										118
									
								
								static/js/flatpickr.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										118
									
								
								static/js/flatpickr.js
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,118 @@
 | 
				
			|||||||
 | 
					import {formatISO} from "date-fns";
 | 
				
			||||||
 | 
					import ConfirmDatePlugin from "flatpickr/dist/plugins/confirmDate/confirmDate";
 | 
				
			||||||
 | 
					import $ from "jquery";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import {get_keydown_hotkey} from "./hotkey";
 | 
				
			||||||
 | 
					import {$t} from "./i18n";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					function is_numeric_key(key) {
 | 
				
			||||||
 | 
					    return ["0", "1", "2", "3", "4", "5", "6", "7", "8", "9"].includes(key);
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					export function show_flatpickr(element, callback, default_timestamp, options = {}) {
 | 
				
			||||||
 | 
					    const flatpickr_input = $("<input id='#timestamp_flatpickr'>");
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    const instance = flatpickr_input.flatpickr({
 | 
				
			||||||
 | 
					        mode: "single",
 | 
				
			||||||
 | 
					        enableTime: true,
 | 
				
			||||||
 | 
					        clickOpens: false,
 | 
				
			||||||
 | 
					        defaultDate: default_timestamp,
 | 
				
			||||||
 | 
					        plugins: [
 | 
				
			||||||
 | 
					            new ConfirmDatePlugin({
 | 
				
			||||||
 | 
					                showAlways: true,
 | 
				
			||||||
 | 
					                confirmText: $t({defaultMessage: "Confirm"}),
 | 
				
			||||||
 | 
					                confirmIcon: "",
 | 
				
			||||||
 | 
					            }),
 | 
				
			||||||
 | 
					        ],
 | 
				
			||||||
 | 
					        positionElement: element,
 | 
				
			||||||
 | 
					        dateFormat: "Z",
 | 
				
			||||||
 | 
					        formatDate: (date) => formatISO(date),
 | 
				
			||||||
 | 
					        disableMobile: true,
 | 
				
			||||||
 | 
					        onKeyDown: (selectedDates, dateStr, instance, event) => {
 | 
				
			||||||
 | 
					            if (is_numeric_key(event.key)) {
 | 
				
			||||||
 | 
					                // Don't attempt to get_keydown_hotkey for numeric inputs
 | 
				
			||||||
 | 
					                // as it would return undefined.
 | 
				
			||||||
 | 
					                return;
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					            const hotkey = get_keydown_hotkey(event);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					            if (["tab", "shift_tab"].includes(hotkey.name)) {
 | 
				
			||||||
 | 
					                const elems = [
 | 
				
			||||||
 | 
					                    instance.selectedDateElem,
 | 
				
			||||||
 | 
					                    instance.hourElement,
 | 
				
			||||||
 | 
					                    instance.minuteElement,
 | 
				
			||||||
 | 
					                    instance.amPM,
 | 
				
			||||||
 | 
					                    $(".flatpickr-confirm")[0],
 | 
				
			||||||
 | 
					                ];
 | 
				
			||||||
 | 
					                const i = elems.indexOf(event.target);
 | 
				
			||||||
 | 
					                const n = elems.length;
 | 
				
			||||||
 | 
					                const remain = (i + (event.shiftKey ? -1 : 1)) % n;
 | 
				
			||||||
 | 
					                const target = elems[Math.floor(remain >= 0 ? remain : remain + n)];
 | 
				
			||||||
 | 
					                event.preventDefault();
 | 
				
			||||||
 | 
					                event.stopPropagation();
 | 
				
			||||||
 | 
					                target.focus();
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					            event.stopPropagation();
 | 
				
			||||||
 | 
					        },
 | 
				
			||||||
 | 
					        ...options,
 | 
				
			||||||
 | 
					    });
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    const container = $($(instance.innerContainer).parent());
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    container.on("keydown", (e) => {
 | 
				
			||||||
 | 
					        if (is_numeric_key(e.key)) {
 | 
				
			||||||
 | 
					            // Let users type numeric values
 | 
				
			||||||
 | 
					            return true;
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        const hotkey = get_keydown_hotkey(e);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        if (!hotkey) {
 | 
				
			||||||
 | 
					            return false;
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        if (hotkey.name === "backspace" || hotkey.name === "delete") {
 | 
				
			||||||
 | 
					            // Let backspace or delete be handled normally
 | 
				
			||||||
 | 
					            return true;
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        if (hotkey.name === "enter") {
 | 
				
			||||||
 | 
					            if (e.target.classList[0] === "flatpickr-day") {
 | 
				
			||||||
 | 
					                return true; // use flatpickr default implementation
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					            $(element).toggleClass("has_popover");
 | 
				
			||||||
 | 
					            container.find(".flatpickr-confirm").trigger("click");
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        if (hotkey.name === "escape") {
 | 
				
			||||||
 | 
					            $(element).toggleClass("has_popover");
 | 
				
			||||||
 | 
					            instance.close();
 | 
				
			||||||
 | 
					            instance.destroy();
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        if (["tab", "shift_tab"].includes(hotkey.name)) {
 | 
				
			||||||
 | 
					            return true; // use flatpickr default implementation
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        if (["right_arrow", "up_arrow", "left_arrow", "down_arrow"].includes(hotkey.name)) {
 | 
				
			||||||
 | 
					            return true; // use flatpickr default implementation
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        e.stopPropagation();
 | 
				
			||||||
 | 
					        e.preventDefault();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        return true;
 | 
				
			||||||
 | 
					    });
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    container.on("click", ".flatpickr-confirm", () => {
 | 
				
			||||||
 | 
					        callback(flatpickr_input.val());
 | 
				
			||||||
 | 
					        instance.close();
 | 
				
			||||||
 | 
					        instance.destroy();
 | 
				
			||||||
 | 
					    });
 | 
				
			||||||
 | 
					    instance.open();
 | 
				
			||||||
 | 
					    instance.selectedDateElem.focus();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    return instance;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
@@ -81,6 +81,7 @@ EXEMPT_FILES = make_set(
 | 
				
			|||||||
        "static/js/emojisets.js",
 | 
					        "static/js/emojisets.js",
 | 
				
			||||||
        "static/js/favicon.js",
 | 
					        "static/js/favicon.js",
 | 
				
			||||||
        "static/js/feedback_widget.js",
 | 
					        "static/js/feedback_widget.js",
 | 
				
			||||||
 | 
					        "static/js/flatpickr.js",
 | 
				
			||||||
        "static/js/floating_recipient_bar.js",
 | 
					        "static/js/floating_recipient_bar.js",
 | 
				
			||||||
        "static/js/gear_menu.js",
 | 
					        "static/js/gear_menu.js",
 | 
				
			||||||
        "static/js/giphy.js",
 | 
					        "static/js/giphy.js",
 | 
				
			||||||
 
 | 
				
			|||||||
		Reference in New Issue
	
	Block a user