stimulus-library 0.7.4 → 0.8.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +43 -43
- package/dist/controllers/ajax/async_block_controller.js +30 -0
- package/dist/controllers/ajax/{index.d.ts → index.js} +0 -1
- package/dist/controllers/ajax/lazy_block_controller.js +37 -0
- package/dist/controllers/ajax/load_block_controller.js +63 -0
- package/dist/controllers/ajax/poll_block_controller.js +35 -0
- package/dist/controllers/anchor_spy_controller.js +47 -0
- package/dist/controllers/back_link_controller.js +25 -0
- package/dist/controllers/clipboard_controller.js +35 -0
- package/dist/controllers/confirm_controller.js +33 -0
- package/dist/controllers/confirm_navigation_controller.js +29 -0
- package/dist/controllers/debug_controller.js +7 -0
- package/dist/controllers/disable_with_controller.js +66 -0
- package/dist/controllers/dismissable_controller.js +8 -0
- package/dist/controllers/element_save_controller.js +80 -0
- package/dist/controllers/empty_dom_controller.js +42 -0
- package/dist/controllers/equalize_controller.js +39 -0
- package/dist/controllers/forms/auto_submit_form_controller.js +62 -0
- package/dist/controllers/forms/autosize_controller.js +32 -0
- package/dist/controllers/forms/char_count_controller.js +37 -0
- package/dist/controllers/forms/checkbox_disable_inputs_controller.js +32 -0
- package/dist/controllers/forms/checkbox_enable_inputs_controller.js +32 -0
- package/dist/controllers/forms/checkbox_select_all_controller.js +35 -0
- package/dist/controllers/forms/checkbox_xor_controller.js +24 -0
- package/dist/controllers/forms/detect_dirty_controller.js +98 -0
- package/dist/controllers/forms/detect_dirty_form_controller.js +107 -0
- package/dist/controllers/forms/enable_inputs_controller.js +21 -0
- package/dist/controllers/forms/focus_steal_controller.js +28 -0
- package/dist/controllers/forms/form_rc_controller.js +47 -0
- package/dist/controllers/forms/form_save_controller.js +109 -0
- package/dist/controllers/forms/{index.d.ts → index.js} +0 -1
- package/dist/controllers/forms/limited_selection_checkboxes_controller.js +28 -0
- package/dist/controllers/forms/navigate_form_errors_controller.js +154 -0
- package/dist/controllers/forms/nested_form_controller.js +49 -0
- package/dist/controllers/forms/password_confirm_controller.js +26 -0
- package/dist/controllers/forms/password_peek_controller.js +21 -0
- package/dist/controllers/forms/remote_form_controller.js +26 -0
- package/dist/controllers/forms/sync_inputs_controller.js +67 -0
- package/dist/controllers/forms/value_warn_controller.js +45 -0
- package/dist/controllers/forms/word_count_controller.js +37 -0
- package/dist/controllers/{index.d.ts → index.js} +2 -1
- package/dist/controllers/media/fallback_image_controller.js +44 -0
- package/dist/controllers/media/{index.d.ts → index.js} +0 -1
- package/dist/controllers/media/lightbox_image_controller.js +71 -0
- package/dist/controllers/media/media_player_controller.js +31 -0
- package/dist/controllers/prefetch_controller.js +74 -0
- package/dist/controllers/print_button_controller.js +18 -0
- package/dist/controllers/responsive_iframe_controller.js +35 -0
- package/dist/controllers/scroll/{index.d.ts → index.js} +0 -1
- package/dist/controllers/scroll/scroll_container_controller.js +81 -0
- package/dist/controllers/scroll/scroll_into_focus_controller.js +20 -0
- package/dist/controllers/scroll/scroll_to_bottom_controller.js +37 -0
- package/dist/controllers/scroll/scroll_to_controller.js +22 -0
- package/dist/controllers/scroll/scroll_to_top_controller.js +37 -0
- package/dist/controllers/self_destruct_controller.js +11 -0
- package/dist/controllers/signal/events.js +12 -0
- package/dist/controllers/signal/expressions.js +54 -0
- package/dist/controllers/signal/{index.d.ts → index.js} +0 -1
- package/dist/controllers/signal/signal_action_controller.js +31 -0
- package/dist/controllers/signal/signal_dom_children_controller.js +40 -0
- package/dist/controllers/signal/signal_input_controller.js +36 -0
- package/dist/controllers/signal/signal_visibility_controller.js +44 -0
- package/dist/controllers/sticky_controller.js +44 -0
- package/dist/controllers/tables/{index.d.ts → index.js} +0 -1
- package/dist/controllers/tables/table_sort_controller.js +97 -0
- package/dist/controllers/tables/table_truncate_controller.js +81 -0
- package/dist/controllers/teleport_controller.js +48 -0
- package/dist/controllers/temporary_state_controller.js +65 -0
- package/dist/controllers/toggle_class_controller.js +115 -0
- package/dist/controllers/trix_modifier_controller.js +121 -0
- package/dist/controllers/turbo_frame_rc_controller.js +65 -0
- package/dist/controllers/turbo_frame_refresh_controller.js +32 -0
- package/dist/controllers/utility/alert_controller.js +7 -0
- package/dist/controllers/utility/fullscreen_controller.js +10 -0
- package/dist/controllers/utility/{index.d.ts → index.js} +0 -1
- package/dist/controllers/utility/intersection_controller.js +25 -0
- package/dist/controllers/utility/interval_controller.js +16 -0
- package/dist/controllers/utility/presence_controller.js +19 -0
- package/dist/controllers/utility/print_controller.js +7 -0
- package/dist/controllers/utility/timeout_controller.js +13 -0
- package/dist/controllers/utility/user_focus_controller.js +23 -0
- package/dist/controllers/visual/clock_controller.js +51 -0
- package/dist/controllers/visual/countdown_controller.js +116 -0
- package/dist/controllers/visual/duration_controller.js +79 -0
- package/dist/controllers/visual/{index.d.ts → index.js} +0 -1
- package/dist/controllers/visual/tabs_controller.js +79 -0
- package/dist/controllers/visual/time_distance_controller.js +50 -0
- package/dist/controllers/visual/tree_view_controller.js +92 -0
- package/dist/{index.d.ts → index.js} +3 -1
- package/dist/mixins/create_mixin.js +11 -0
- package/dist/mixins/{index.d.ts → index.js} +0 -1
- package/dist/mixins/install_class_methods.js +28 -0
- package/dist/mixins/use_click_outside.js +17 -0
- package/dist/mixins/use_event_bus.js +19 -0
- package/dist/mixins/use_event_listener.js +34 -0
- package/dist/mixins/use_fullscreen.js +42 -0
- package/dist/mixins/use_geolocation.js +62 -0
- package/dist/mixins/use_hover.js +29 -0
- package/dist/mixins/use_injected_html.js +37 -0
- package/dist/mixins/use_intersection.js +45 -0
- package/dist/mixins/use_interval.js +13 -0
- package/dist/mixins/use_localstorage.js +122 -0
- package/dist/mixins/use_mutation_observer.js +9 -0
- package/dist/mixins/use_temporary_content.js +38 -0
- package/dist/mixins/use_timeout.js +20 -0
- package/dist/mixins/use_trix_modifiers.js +71 -0
- package/dist/polyfills/string.replaceAll.js +13 -0
- package/dist/utilities/arrays.js +3 -0
- package/dist/utilities/base_controller.js +56 -0
- package/dist/utilities/elements.js +102 -0
- package/dist/utilities/ephemeral_controller.js +42 -0
- package/dist/utilities/event_bus.js +2 -0
- package/dist/utilities/events.js +10 -0
- package/dist/utilities/fetchRetry.js +22 -0
- package/dist/utilities/{index.d.ts → index.js} +0 -1
- package/dist/utilities/logging.js +82 -0
- package/dist/utilities/reactive.js +23 -0
- package/dist/utilities/request_submit.js +20 -0
- package/dist/utilities/scroll.js +89 -0
- package/dist/utilities/stimulus.js +13 -0
- package/dist/utilities/strings.js +5 -0
- package/dist/utilities/turbo.js +3 -0
- package/package.json +56 -66
- package/CHANGELOG.md +0 -506
- package/dist/controllers/ajax/async_block_controller.d.ts +0 -18
- package/dist/controllers/ajax/async_block_controller.d.ts.map +0 -1
- package/dist/controllers/ajax/index.d.ts.map +0 -1
- package/dist/controllers/ajax/lazy_block_controller.d.ts +0 -10
- package/dist/controllers/ajax/lazy_block_controller.d.ts.map +0 -1
- package/dist/controllers/ajax/load_block_controller.d.ts +0 -24
- package/dist/controllers/ajax/load_block_controller.d.ts.map +0 -1
- package/dist/controllers/ajax/poll_block_controller.d.ts +0 -16
- package/dist/controllers/ajax/poll_block_controller.d.ts.map +0 -1
- package/dist/controllers/anchor_spy_controller.d.ts +0 -21
- package/dist/controllers/anchor_spy_controller.d.ts.map +0 -1
- package/dist/controllers/back_link_controller.d.ts +0 -17
- package/dist/controllers/back_link_controller.d.ts.map +0 -1
- package/dist/controllers/clipboard_controller.d.ts +0 -19
- package/dist/controllers/clipboard_controller.d.ts.map +0 -1
- package/dist/controllers/confirm_controller.d.ts +0 -13
- package/dist/controllers/confirm_controller.d.ts.map +0 -1
- package/dist/controllers/confirm_navigation_controller.d.ts +0 -15
- package/dist/controllers/confirm_navigation_controller.d.ts.map +0 -1
- package/dist/controllers/debug_controller.d.ts +0 -7
- package/dist/controllers/debug_controller.d.ts.map +0 -1
- package/dist/controllers/disable_with_controller.d.ts +0 -20
- package/dist/controllers/disable_with_controller.d.ts.map +0 -1
- package/dist/controllers/dismissable_controller.d.ts +0 -7
- package/dist/controllers/dismissable_controller.d.ts.map +0 -1
- package/dist/controllers/element_save_controller.d.ts +0 -31
- package/dist/controllers/element_save_controller.d.ts.map +0 -1
- package/dist/controllers/empty_dom_controller.d.ts +0 -22
- package/dist/controllers/empty_dom_controller.d.ts.map +0 -1
- package/dist/controllers/equalize_controller.d.ts +0 -16
- package/dist/controllers/equalize_controller.d.ts.map +0 -1
- package/dist/controllers/forms/auto_submit_form_controller.d.ts +0 -23
- package/dist/controllers/forms/auto_submit_form_controller.d.ts.map +0 -1
- package/dist/controllers/forms/autosize_controller.d.ts +0 -9
- package/dist/controllers/forms/autosize_controller.d.ts.map +0 -1
- package/dist/controllers/forms/char_count_controller.d.ts +0 -21
- package/dist/controllers/forms/char_count_controller.d.ts.map +0 -1
- package/dist/controllers/forms/checkbox_disable_inputs_controller.d.ts +0 -17
- package/dist/controllers/forms/checkbox_disable_inputs_controller.d.ts.map +0 -1
- package/dist/controllers/forms/checkbox_enable_inputs_controller.d.ts +0 -17
- package/dist/controllers/forms/checkbox_enable_inputs_controller.d.ts.map +0 -1
- package/dist/controllers/forms/checkbox_select_all_controller.d.ts +0 -14
- package/dist/controllers/forms/checkbox_select_all_controller.d.ts.map +0 -1
- package/dist/controllers/forms/checkbox_xor_controller.d.ts +0 -9
- package/dist/controllers/forms/checkbox_xor_controller.d.ts.map +0 -1
- package/dist/controllers/forms/detect_dirty_controller.d.ts +0 -15
- package/dist/controllers/forms/detect_dirty_controller.d.ts.map +0 -1
- package/dist/controllers/forms/detect_dirty_form_controller.d.ts +0 -18
- package/dist/controllers/forms/detect_dirty_form_controller.d.ts.map +0 -1
- package/dist/controllers/forms/enable_inputs_controller.d.ts +0 -14
- package/dist/controllers/forms/enable_inputs_controller.d.ts.map +0 -1
- package/dist/controllers/forms/focus_steal_controller.d.ts +0 -12
- package/dist/controllers/forms/focus_steal_controller.d.ts.map +0 -1
- package/dist/controllers/forms/form_rc_controller.d.ts +0 -18
- package/dist/controllers/forms/form_rc_controller.d.ts.map +0 -1
- package/dist/controllers/forms/form_save_controller.d.ts +0 -32
- package/dist/controllers/forms/form_save_controller.d.ts.map +0 -1
- package/dist/controllers/forms/index.d.ts.map +0 -1
- package/dist/controllers/forms/limited_selection_checkboxes_controller.d.ts +0 -17
- package/dist/controllers/forms/limited_selection_checkboxes_controller.d.ts.map +0 -1
- package/dist/controllers/forms/navigate_form_errors_controller.d.ts +0 -41
- package/dist/controllers/forms/navigate_form_errors_controller.d.ts.map +0 -1
- package/dist/controllers/forms/nested_form_controller.d.ts +0 -22
- package/dist/controllers/forms/nested_form_controller.d.ts.map +0 -1
- package/dist/controllers/forms/password_confirm_controller.d.ts +0 -12
- package/dist/controllers/forms/password_confirm_controller.d.ts.map +0 -1
- package/dist/controllers/forms/password_peek_controller.d.ts +0 -9
- package/dist/controllers/forms/password_peek_controller.d.ts.map +0 -1
- package/dist/controllers/forms/remote_form_controller.d.ts +0 -14
- package/dist/controllers/forms/remote_form_controller.d.ts.map +0 -1
- package/dist/controllers/forms/sync_inputs_controller.d.ts +0 -20
- package/dist/controllers/forms/sync_inputs_controller.d.ts.map +0 -1
- package/dist/controllers/forms/value_warn_controller.d.ts +0 -31
- package/dist/controllers/forms/value_warn_controller.d.ts.map +0 -1
- package/dist/controllers/forms/word_count_controller.d.ts +0 -21
- package/dist/controllers/forms/word_count_controller.d.ts.map +0 -1
- package/dist/controllers/index.d.ts.map +0 -1
- package/dist/controllers/media/fallback_image_controller.d.ts +0 -20
- package/dist/controllers/media/fallback_image_controller.d.ts.map +0 -1
- package/dist/controllers/media/index.d.ts.map +0 -1
- package/dist/controllers/media/lightbox_image_controller.d.ts +0 -31
- package/dist/controllers/media/lightbox_image_controller.d.ts.map +0 -1
- package/dist/controllers/media/media_player_controller.d.ts +0 -10
- package/dist/controllers/media/media_player_controller.d.ts.map +0 -1
- package/dist/controllers/prefetch_controller.d.ts +0 -17
- package/dist/controllers/prefetch_controller.d.ts.map +0 -1
- package/dist/controllers/print_button_controller.d.ts +0 -8
- package/dist/controllers/print_button_controller.d.ts.map +0 -1
- package/dist/controllers/responsive_iframe_controller.d.ts +0 -17
- package/dist/controllers/responsive_iframe_controller.d.ts.map +0 -1
- package/dist/controllers/scroll/index.d.ts.map +0 -1
- package/dist/controllers/scroll/scroll_container_controller.d.ts +0 -22
- package/dist/controllers/scroll/scroll_container_controller.d.ts.map +0 -1
- package/dist/controllers/scroll/scroll_into_focus_controller.d.ts +0 -16
- package/dist/controllers/scroll/scroll_into_focus_controller.d.ts.map +0 -1
- package/dist/controllers/scroll/scroll_to_bottom_controller.d.ts +0 -12
- package/dist/controllers/scroll/scroll_to_bottom_controller.d.ts.map +0 -1
- package/dist/controllers/scroll/scroll_to_controller.d.ts +0 -18
- package/dist/controllers/scroll/scroll_to_controller.d.ts.map +0 -1
- package/dist/controllers/scroll/scroll_to_top_controller.d.ts +0 -12
- package/dist/controllers/scroll/scroll_to_top_controller.d.ts.map +0 -1
- package/dist/controllers/self_destruct_controller.d.ts +0 -9
- package/dist/controllers/self_destruct_controller.d.ts.map +0 -1
- package/dist/controllers/signal/events.d.ts +0 -5
- package/dist/controllers/signal/events.d.ts.map +0 -1
- package/dist/controllers/signal/expressions.d.ts +0 -2
- package/dist/controllers/signal/expressions.d.ts.map +0 -1
- package/dist/controllers/signal/index.d.ts.map +0 -1
- package/dist/controllers/signal/signal_action_controller.d.ts +0 -15
- package/dist/controllers/signal/signal_action_controller.d.ts.map +0 -1
- package/dist/controllers/signal/signal_dom_children_controller.d.ts +0 -17
- package/dist/controllers/signal/signal_dom_children_controller.d.ts.map +0 -1
- package/dist/controllers/signal/signal_input_controller.d.ts +0 -20
- package/dist/controllers/signal/signal_input_controller.d.ts.map +0 -1
- package/dist/controllers/signal/signal_visibility_controller.d.ts +0 -18
- package/dist/controllers/signal/signal_visibility_controller.d.ts.map +0 -1
- package/dist/controllers/sticky_controller.d.ts +0 -16
- package/dist/controllers/sticky_controller.d.ts.map +0 -1
- package/dist/controllers/tables/index.d.ts.map +0 -1
- package/dist/controllers/tables/table_sort_controller.d.ts +0 -20
- package/dist/controllers/tables/table_sort_controller.d.ts.map +0 -1
- package/dist/controllers/tables/table_truncate_controller.d.ts +0 -26
- package/dist/controllers/tables/table_truncate_controller.d.ts.map +0 -1
- package/dist/controllers/teleport_controller.d.ts +0 -16
- package/dist/controllers/teleport_controller.d.ts.map +0 -1
- package/dist/controllers/temporary_state_controller.d.ts +0 -27
- package/dist/controllers/temporary_state_controller.d.ts.map +0 -1
- package/dist/controllers/toggle_class_controller.d.ts +0 -36
- package/dist/controllers/toggle_class_controller.d.ts.map +0 -1
- package/dist/controllers/trix_modifier_controller.d.ts +0 -88
- package/dist/controllers/trix_modifier_controller.d.ts.map +0 -1
- package/dist/controllers/turbo_frame_rc_controller.d.ts +0 -21
- package/dist/controllers/turbo_frame_rc_controller.d.ts.map +0 -1
- package/dist/controllers/turbo_frame_refresh_controller.d.ts +0 -14
- package/dist/controllers/turbo_frame_refresh_controller.d.ts.map +0 -1
- package/dist/controllers/utility/alert_controller.d.ts +0 -9
- package/dist/controllers/utility/alert_controller.d.ts.map +0 -1
- package/dist/controllers/utility/fullscreen_controller.d.ts +0 -8
- package/dist/controllers/utility/fullscreen_controller.d.ts.map +0 -1
- package/dist/controllers/utility/index.d.ts.map +0 -1
- package/dist/controllers/utility/intersection_controller.d.ts +0 -14
- package/dist/controllers/utility/intersection_controller.d.ts.map +0 -1
- package/dist/controllers/utility/interval_controller.d.ts +0 -11
- package/dist/controllers/utility/interval_controller.d.ts.map +0 -1
- package/dist/controllers/utility/presence_controller.d.ts +0 -14
- package/dist/controllers/utility/presence_controller.d.ts.map +0 -1
- package/dist/controllers/utility/print_controller.d.ts +0 -5
- package/dist/controllers/utility/print_controller.d.ts.map +0 -1
- package/dist/controllers/utility/timeout_controller.d.ts +0 -10
- package/dist/controllers/utility/timeout_controller.d.ts.map +0 -1
- package/dist/controllers/utility/user_focus_controller.d.ts +0 -9
- package/dist/controllers/utility/user_focus_controller.d.ts.map +0 -1
- package/dist/controllers/visual/clock_controller.d.ts +0 -16
- package/dist/controllers/visual/clock_controller.d.ts.map +0 -1
- package/dist/controllers/visual/countdown_controller.d.ts +0 -46
- package/dist/controllers/visual/countdown_controller.d.ts.map +0 -1
- package/dist/controllers/visual/duration_controller.d.ts +0 -26
- package/dist/controllers/visual/duration_controller.d.ts.map +0 -1
- package/dist/controllers/visual/index.d.ts.map +0 -1
- package/dist/controllers/visual/tabs_controller.d.ts +0 -30
- package/dist/controllers/visual/tabs_controller.d.ts.map +0 -1
- package/dist/controllers/visual/time_distance_controller.d.ts +0 -16
- package/dist/controllers/visual/time_distance_controller.d.ts.map +0 -1
- package/dist/controllers/visual/tree_view_controller.d.ts +0 -26
- package/dist/controllers/visual/tree_view_controller.d.ts.map +0 -1
- package/dist/index.d.ts.map +0 -1
- package/dist/mixins/create_mixin.d.ts +0 -3
- package/dist/mixins/create_mixin.d.ts.map +0 -1
- package/dist/mixins/index.d.ts.map +0 -1
- package/dist/mixins/install_class_methods.d.ts +0 -6
- package/dist/mixins/install_class_methods.d.ts.map +0 -1
- package/dist/mixins/use_click_outside.d.ts +0 -5
- package/dist/mixins/use_click_outside.d.ts.map +0 -1
- package/dist/mixins/use_event_bus.d.ts +0 -8
- package/dist/mixins/use_event_bus.d.ts.map +0 -1
- package/dist/mixins/use_event_listener.d.ts +0 -20
- package/dist/mixins/use_event_listener.d.ts.map +0 -1
- package/dist/mixins/use_fullscreen.d.ts +0 -9
- package/dist/mixins/use_fullscreen.d.ts.map +0 -1
- package/dist/mixins/use_geolocation.d.ts +0 -19
- package/dist/mixins/use_geolocation.d.ts.map +0 -1
- package/dist/mixins/use_hover.d.ts +0 -5
- package/dist/mixins/use_hover.d.ts.map +0 -1
- package/dist/mixins/use_injected_html.d.ts +0 -11
- package/dist/mixins/use_injected_html.d.ts.map +0 -1
- package/dist/mixins/use_intersection.d.ts +0 -14
- package/dist/mixins/use_intersection.d.ts.map +0 -1
- package/dist/mixins/use_interval.d.ts +0 -3
- package/dist/mixins/use_interval.d.ts.map +0 -1
- package/dist/mixins/use_localstorage.d.ts +0 -21
- package/dist/mixins/use_localstorage.d.ts.map +0 -1
- package/dist/mixins/use_mutation_observer.d.ts +0 -3
- package/dist/mixins/use_mutation_observer.d.ts.map +0 -1
- package/dist/mixins/use_resize.d.ts +0 -5
- package/dist/mixins/use_resize.d.ts.map +0 -1
- package/dist/mixins/use_temporary_content.d.ts +0 -6
- package/dist/mixins/use_temporary_content.d.ts.map +0 -1
- package/dist/mixins/use_timeout.d.ts +0 -3
- package/dist/mixins/use_timeout.d.ts.map +0 -1
- package/dist/mixins/use_trix_modifiers.d.ts +0 -11
- package/dist/mixins/use_trix_modifiers.d.ts.map +0 -1
- package/dist/stimulus-library.cjs.js +0 -2
- package/dist/stimulus-library.cjs.js.map +0 -1
- package/dist/stimulus-library.es.js +0 -4755
- package/dist/stimulus-library.es.js.map +0 -1
- package/dist/stimulus-library.umd.js +0 -2
- package/dist/stimulus-library.umd.js.map +0 -1
- package/dist/utilities/arrays.d.ts +0 -2
- package/dist/utilities/arrays.d.ts.map +0 -1
- package/dist/utilities/base_controller.d.ts +0 -11
- package/dist/utilities/base_controller.d.ts.map +0 -1
- package/dist/utilities/elements.d.ts +0 -49
- package/dist/utilities/elements.d.ts.map +0 -1
- package/dist/utilities/ephemeral_controller.d.ts +0 -6
- package/dist/utilities/ephemeral_controller.d.ts.map +0 -1
- package/dist/utilities/event_bus.d.ts +0 -4
- package/dist/utilities/event_bus.d.ts.map +0 -1
- package/dist/utilities/events.d.ts +0 -3
- package/dist/utilities/events.d.ts.map +0 -1
- package/dist/utilities/fetchRetry.d.ts +0 -2
- package/dist/utilities/fetchRetry.d.ts.map +0 -1
- package/dist/utilities/index.d.ts.map +0 -1
- package/dist/utilities/logging.d.ts +0 -6
- package/dist/utilities/logging.d.ts.map +0 -1
- package/dist/utilities/reactive.d.ts +0 -2
- package/dist/utilities/reactive.d.ts.map +0 -1
- package/dist/utilities/request_submit.d.ts +0 -3
- package/dist/utilities/request_submit.d.ts.map +0 -1
- package/dist/utilities/scroll.d.ts +0 -11
- package/dist/utilities/scroll.d.ts.map +0 -1
- package/dist/utilities/stimulus.d.ts +0 -3
- package/dist/utilities/stimulus.d.ts.map +0 -1
- package/dist/utilities/strings.d.ts +0 -2
- package/dist/utilities/strings.d.ts.map +0 -1
- package/dist/utilities/turbo.d.ts +0 -2
- package/dist/utilities/turbo.d.ts.map +0 -1
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
import { BaseController } from "../utilities/base_controller";
|
|
2
|
+
import debounce from "lodash-es/debounce";
|
|
3
|
+
import { useIntersection } from "../mixins/use_intersection";
|
|
4
|
+
export class EqualizeController extends BaseController {
|
|
5
|
+
initialize() {
|
|
6
|
+
this._equalize = debounce(this._equalize.bind(this), 100);
|
|
7
|
+
this.observer = new ResizeObserver((_entries) => this._equalize());
|
|
8
|
+
}
|
|
9
|
+
connect() {
|
|
10
|
+
let { teardown } = useIntersection(this, this.el, this.appear);
|
|
11
|
+
this._unobserveIntersection = teardown;
|
|
12
|
+
requestAnimationFrame(this._equalize);
|
|
13
|
+
}
|
|
14
|
+
disconnect() {
|
|
15
|
+
this._unequalize();
|
|
16
|
+
}
|
|
17
|
+
watchTargetConnected(element) {
|
|
18
|
+
this.observer.observe(element);
|
|
19
|
+
this._equalize();
|
|
20
|
+
}
|
|
21
|
+
watchTargetDisconnected(element) {
|
|
22
|
+
this.observer.unobserve(element);
|
|
23
|
+
this._equalize();
|
|
24
|
+
}
|
|
25
|
+
appear(_entry) {
|
|
26
|
+
this._unobserveIntersection();
|
|
27
|
+
this._equalize();
|
|
28
|
+
}
|
|
29
|
+
_equalize() {
|
|
30
|
+
this._unequalize();
|
|
31
|
+
let maxHeight = 0;
|
|
32
|
+
Array.from(this.watchTargets).forEach(target => maxHeight = Math.max(maxHeight, target.getBoundingClientRect().height));
|
|
33
|
+
Array.from(this.watchTargets).forEach(target => target.style.minHeight = `${maxHeight}px`);
|
|
34
|
+
}
|
|
35
|
+
_unequalize() {
|
|
36
|
+
Array.from(this.watchTargets).forEach(target => target.style.minHeight = "");
|
|
37
|
+
}
|
|
38
|
+
}
|
|
39
|
+
EqualizeController.targets = ["watch"];
|
|
@@ -0,0 +1,62 @@
|
|
|
1
|
+
import { BaseController } from "../../utilities/base_controller";
|
|
2
|
+
import { requestSubmit } from "../../utilities/request_submit";
|
|
3
|
+
import { useEventListener } from "../../mixins/use_event_listener";
|
|
4
|
+
export class AutoSubmitFormController extends BaseController {
|
|
5
|
+
get _eventModes() {
|
|
6
|
+
if (this.hasEventModeValue) {
|
|
7
|
+
let modes = this.eventModeValue.split(' ').map(mode => mode.trim());
|
|
8
|
+
if (modes.length === 1 && modes[0] === 'debounced') {
|
|
9
|
+
return ['change', 'input'];
|
|
10
|
+
}
|
|
11
|
+
if (!modes.every(mode => ['change', 'input'].includes(mode))) {
|
|
12
|
+
throw new Error(`The modeValue provided '${this.eventModeValue}' is not one of the recognised configuration options`);
|
|
13
|
+
}
|
|
14
|
+
return modes;
|
|
15
|
+
}
|
|
16
|
+
else {
|
|
17
|
+
return ["change"];
|
|
18
|
+
}
|
|
19
|
+
}
|
|
20
|
+
get _debounceTimeout() {
|
|
21
|
+
return this.hasDebounceIntervalValue ? this.debounceIntervalValue : -1;
|
|
22
|
+
}
|
|
23
|
+
get _mode() {
|
|
24
|
+
if (this.hasSubmitModeValue) {
|
|
25
|
+
if (!["direct", "request"].includes(this.submitModeValue)) {
|
|
26
|
+
throw new Error(`The modeValue provided '${this.submitModeValue}' is not one of the recognised configuration options`);
|
|
27
|
+
}
|
|
28
|
+
return this.submitModeValue;
|
|
29
|
+
}
|
|
30
|
+
else {
|
|
31
|
+
return "request";
|
|
32
|
+
}
|
|
33
|
+
}
|
|
34
|
+
get _cssSelector() {
|
|
35
|
+
let inputTypes = ['input', 'textarea', 'select'];
|
|
36
|
+
let ignore = ':not([data-no-autosubmit])';
|
|
37
|
+
return inputTypes.map(type => type.concat(ignore)).join(',');
|
|
38
|
+
}
|
|
39
|
+
get inputElements() {
|
|
40
|
+
let subElements = Array.from(this.element.querySelectorAll(this._cssSelector));
|
|
41
|
+
subElements = subElements.filter(el => !this._ancestorIsTrix(el));
|
|
42
|
+
return subElements;
|
|
43
|
+
}
|
|
44
|
+
connect() {
|
|
45
|
+
this.inputElements.forEach(el => {
|
|
46
|
+
return useEventListener(this, el, this._eventModes, this.submit, { debounce: this._debounceTimeout && this._debounceTimeout > 0 ? this._debounceTimeout : undefined });
|
|
47
|
+
});
|
|
48
|
+
}
|
|
49
|
+
_ancestorIsTrix(element) {
|
|
50
|
+
return element.closest('trix-toolbar') !== null && element.closest('trix-editor') !== null;
|
|
51
|
+
}
|
|
52
|
+
submit() {
|
|
53
|
+
let el = this.el;
|
|
54
|
+
if (this._mode == 'request') {
|
|
55
|
+
requestSubmit(el);
|
|
56
|
+
}
|
|
57
|
+
else {
|
|
58
|
+
el.submit();
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
}
|
|
62
|
+
AutoSubmitFormController.values = { submitMode: String, eventMode: String, debounceInterval: Number };
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
import { BaseController } from '../../utilities/base_controller';
|
|
2
|
+
import { isHTMLTextAreaElement } from "../../utilities/elements";
|
|
3
|
+
import { useEventListener } from "../../mixins/use_event_listener";
|
|
4
|
+
import { useIntersection } from "../../mixins/use_intersection";
|
|
5
|
+
export class AutosizeController extends BaseController {
|
|
6
|
+
connect() {
|
|
7
|
+
let { teardown } = useIntersection(this, this.el, this.appear);
|
|
8
|
+
this._unobserveIntersection = teardown;
|
|
9
|
+
if (!isHTMLTextAreaElement(this.el)) {
|
|
10
|
+
throw new Error(`Expected controller to be attached to a textarea, but was a '${this.el.tagName}'`);
|
|
11
|
+
}
|
|
12
|
+
requestAnimationFrame(() => {
|
|
13
|
+
this.el.style.resize = "none";
|
|
14
|
+
this.el.style.boxSizing = "border-box";
|
|
15
|
+
this._handler();
|
|
16
|
+
useEventListener(this, window, ['resize'], this._handler);
|
|
17
|
+
useEventListener(this, this.el, ['input', 'change', 'focus'], this._handler, { debounce: 100 });
|
|
18
|
+
});
|
|
19
|
+
}
|
|
20
|
+
appear(_entry) {
|
|
21
|
+
this.autosize(this.el);
|
|
22
|
+
this._unobserveIntersection();
|
|
23
|
+
}
|
|
24
|
+
_handler() {
|
|
25
|
+
this.autosize(this.el);
|
|
26
|
+
}
|
|
27
|
+
autosize(element) {
|
|
28
|
+
let offset = element.offsetHeight - element.clientHeight;
|
|
29
|
+
element.style.height = "auto";
|
|
30
|
+
element.style.height = element.scrollHeight + offset + "px";
|
|
31
|
+
}
|
|
32
|
+
}
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
import { BaseController } from "../../utilities/base_controller";
|
|
2
|
+
import { useEventListener } from "../../mixins/use_event_listener";
|
|
3
|
+
import { installClassMethods } from "../../mixins/install_class_methods";
|
|
4
|
+
export class CharCountController extends BaseController {
|
|
5
|
+
connect() {
|
|
6
|
+
installClassMethods(this);
|
|
7
|
+
requestAnimationFrame(() => {
|
|
8
|
+
useEventListener(this, this.inputTarget, "input", this._updateCharCount);
|
|
9
|
+
this._updateCharCount();
|
|
10
|
+
});
|
|
11
|
+
}
|
|
12
|
+
_updateCharCount() {
|
|
13
|
+
let charCount = this.inputTarget.value.length;
|
|
14
|
+
this.outputTarget.innerText = charCount.toString();
|
|
15
|
+
if (this._isValidCount(charCount)) {
|
|
16
|
+
this.removeErrorClasses(this.outputTarget);
|
|
17
|
+
}
|
|
18
|
+
else {
|
|
19
|
+
this.addErrorClasses(this.outputTarget);
|
|
20
|
+
}
|
|
21
|
+
}
|
|
22
|
+
_isValidCount(count) {
|
|
23
|
+
let min = 0;
|
|
24
|
+
let max = 99999;
|
|
25
|
+
if (this.hasMinValue) {
|
|
26
|
+
min = this.minValue;
|
|
27
|
+
}
|
|
28
|
+
if (this.hasMaxValue) {
|
|
29
|
+
max = this.maxValue;
|
|
30
|
+
}
|
|
31
|
+
return count >= min && count <= max;
|
|
32
|
+
}
|
|
33
|
+
}
|
|
34
|
+
// Config
|
|
35
|
+
CharCountController.targets = ["input", "output"];
|
|
36
|
+
CharCountController.values = { min: Number, max: Number };
|
|
37
|
+
CharCountController.classes = ["error"];
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
import { BaseController } from "../../utilities/base_controller";
|
|
2
|
+
export class CheckboxDisableInputsController extends BaseController {
|
|
3
|
+
connect() {
|
|
4
|
+
this.toggle();
|
|
5
|
+
}
|
|
6
|
+
toggle() {
|
|
7
|
+
if (this.hasDisablerTarget && this.disablerTarget.checked) {
|
|
8
|
+
this.disable();
|
|
9
|
+
}
|
|
10
|
+
else {
|
|
11
|
+
this.enable();
|
|
12
|
+
}
|
|
13
|
+
}
|
|
14
|
+
disable() {
|
|
15
|
+
let shouldClear = this.hasClearValue && this.clearValue;
|
|
16
|
+
this.disableTargets.forEach((el, _) => {
|
|
17
|
+
if (shouldClear) {
|
|
18
|
+
el.value = "";
|
|
19
|
+
}
|
|
20
|
+
el.disabled = true;
|
|
21
|
+
});
|
|
22
|
+
}
|
|
23
|
+
enable() {
|
|
24
|
+
this.disableTargets.forEach((el, _) => {
|
|
25
|
+
el.disabled = false;
|
|
26
|
+
});
|
|
27
|
+
}
|
|
28
|
+
}
|
|
29
|
+
CheckboxDisableInputsController.targets = ["disabler", "disable"];
|
|
30
|
+
CheckboxDisableInputsController.values = {
|
|
31
|
+
clear: Boolean,
|
|
32
|
+
};
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
import { BaseController } from "../../utilities/base_controller";
|
|
2
|
+
export class CheckboxEnableInputsController extends BaseController {
|
|
3
|
+
connect() {
|
|
4
|
+
this.toggle();
|
|
5
|
+
}
|
|
6
|
+
toggle() {
|
|
7
|
+
if (this.hasEnablerTarget && this.enablerTarget.checked) {
|
|
8
|
+
this.enable();
|
|
9
|
+
}
|
|
10
|
+
else {
|
|
11
|
+
this.disable();
|
|
12
|
+
}
|
|
13
|
+
}
|
|
14
|
+
disable() {
|
|
15
|
+
let shouldClear = this.hasClearValue && this.clearValue;
|
|
16
|
+
this.enableTargets.forEach((el, _) => {
|
|
17
|
+
if (shouldClear) {
|
|
18
|
+
el.value = "";
|
|
19
|
+
}
|
|
20
|
+
el.disabled = true;
|
|
21
|
+
});
|
|
22
|
+
}
|
|
23
|
+
enable() {
|
|
24
|
+
this.enableTargets.forEach((el, _) => {
|
|
25
|
+
el.disabled = false;
|
|
26
|
+
});
|
|
27
|
+
}
|
|
28
|
+
}
|
|
29
|
+
CheckboxEnableInputsController.targets = ["enabler", "enable"];
|
|
30
|
+
CheckboxEnableInputsController.values = {
|
|
31
|
+
clear: Boolean,
|
|
32
|
+
};
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
import { BaseController } from '../../utilities/base_controller';
|
|
2
|
+
import { useCollectionEventListener, useEventListener } from "../../mixins/use_event_listener";
|
|
3
|
+
export class CheckboxSelectAllController extends BaseController {
|
|
4
|
+
get _checked() {
|
|
5
|
+
return this._enabled.filter(checkbox => checkbox.checked);
|
|
6
|
+
}
|
|
7
|
+
get _enabled() {
|
|
8
|
+
return this.checkboxTargets.filter(checkbox => !checkbox.disabled && !checkbox.readOnly);
|
|
9
|
+
}
|
|
10
|
+
get _unchecked() {
|
|
11
|
+
return this._enabled.filter(checkbox => !checkbox.checked);
|
|
12
|
+
}
|
|
13
|
+
connect() {
|
|
14
|
+
requestAnimationFrame(() => {
|
|
15
|
+
if (!this.hasSelectAllTarget) {
|
|
16
|
+
return;
|
|
17
|
+
}
|
|
18
|
+
useEventListener(this, this.selectAllTarget, 'change', this._toggle);
|
|
19
|
+
useCollectionEventListener(this, this.checkboxTargets, 'change', this._refresh);
|
|
20
|
+
this._refresh();
|
|
21
|
+
});
|
|
22
|
+
}
|
|
23
|
+
_toggle(event) {
|
|
24
|
+
event.preventDefault();
|
|
25
|
+
let target = event.target;
|
|
26
|
+
this._enabled.forEach((checkbox) => checkbox.checked = (checkbox.disabled || checkbox.readOnly) ? checkbox.checked : target.checked);
|
|
27
|
+
}
|
|
28
|
+
_refresh() {
|
|
29
|
+
const checkboxesCount = this._enabled.length;
|
|
30
|
+
const checkboxesCheckedCount = this._checked.length;
|
|
31
|
+
this.selectAllTarget.checked = checkboxesCheckedCount > 0;
|
|
32
|
+
this.selectAllTarget.indeterminate = checkboxesCheckedCount > 0 && checkboxesCheckedCount < checkboxesCount;
|
|
33
|
+
}
|
|
34
|
+
}
|
|
35
|
+
CheckboxSelectAllController.targets = ['selectAll', 'checkbox'];
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import { BaseController } from "../../utilities/base_controller";
|
|
2
|
+
import { useCollectionEventListener } from "../../mixins";
|
|
3
|
+
export class CheckboxXORController extends BaseController {
|
|
4
|
+
connect() {
|
|
5
|
+
useCollectionEventListener(this, this.checkboxTargets, "change", this._update);
|
|
6
|
+
}
|
|
7
|
+
_otherCheckboxes(el) {
|
|
8
|
+
return Array.from(this.checkboxTargets).filter(field => field !== el);
|
|
9
|
+
}
|
|
10
|
+
_update(event) {
|
|
11
|
+
const target = event.target;
|
|
12
|
+
if (!target) {
|
|
13
|
+
throw new Error("No target found on event");
|
|
14
|
+
}
|
|
15
|
+
let others = this._otherCheckboxes(target);
|
|
16
|
+
if (target.checked) {
|
|
17
|
+
others.forEach(checkbox => {
|
|
18
|
+
checkbox.checked = false;
|
|
19
|
+
this.dispatchEvent(this.el, 'change');
|
|
20
|
+
});
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
}
|
|
24
|
+
CheckboxXORController.targets = ["checkbox"];
|
|
@@ -0,0 +1,98 @@
|
|
|
1
|
+
import { BaseController } from "../../utilities/base_controller";
|
|
2
|
+
import { getOtherRadiosInGroup, isElementCheckable, isHTMLInputElement, isHTMLSelectElement } from "../../utilities/elements";
|
|
3
|
+
import { useEventListener } from "../../mixins/use_event_listener";
|
|
4
|
+
export class DetectDirtyController extends BaseController {
|
|
5
|
+
get _cacheAttrName() {
|
|
6
|
+
return 'detect-dirty-load-value';
|
|
7
|
+
}
|
|
8
|
+
connect() {
|
|
9
|
+
let element = this.el;
|
|
10
|
+
this._cacheLoadValues();
|
|
11
|
+
this._checkDirty();
|
|
12
|
+
useEventListener(this, element, ["input", "change"], this._checkDirty, { debounce: 10 });
|
|
13
|
+
}
|
|
14
|
+
restore(event) {
|
|
15
|
+
event === null || event === void 0 ? void 0 : event.preventDefault();
|
|
16
|
+
this._restoreElementFromLoadValue();
|
|
17
|
+
}
|
|
18
|
+
_getElementValue() {
|
|
19
|
+
let element = this.el;
|
|
20
|
+
return isElementCheckable(element) ? element.checked : element.value;
|
|
21
|
+
}
|
|
22
|
+
_getElementLoadValue() {
|
|
23
|
+
let element = this.el;
|
|
24
|
+
let value = element.getAttribute(this._cacheAttrName);
|
|
25
|
+
if (isElementCheckable(element)) {
|
|
26
|
+
return value == null ? element.defaultChecked : value == "true";
|
|
27
|
+
}
|
|
28
|
+
else if (isHTMLSelectElement(element)) {
|
|
29
|
+
let options = Array.from(element.options);
|
|
30
|
+
options.forEach((option) => {
|
|
31
|
+
if (option.defaultSelected) {
|
|
32
|
+
element.value = option.value;
|
|
33
|
+
return option.value;
|
|
34
|
+
}
|
|
35
|
+
});
|
|
36
|
+
}
|
|
37
|
+
else if (value !== null) {
|
|
38
|
+
return value;
|
|
39
|
+
}
|
|
40
|
+
return value;
|
|
41
|
+
}
|
|
42
|
+
_elementHasCachedLoadValue() {
|
|
43
|
+
let element = this.el;
|
|
44
|
+
return element.hasAttribute(this._cacheAttrName);
|
|
45
|
+
}
|
|
46
|
+
_checkDirty() {
|
|
47
|
+
let element = this.el;
|
|
48
|
+
if (isHTMLInputElement(element) && element.type == "radio") {
|
|
49
|
+
getOtherRadiosInGroup(element).forEach((radio) => radio.removeAttribute('data-dirty'));
|
|
50
|
+
}
|
|
51
|
+
if (this._isElementDirty()) {
|
|
52
|
+
element.setAttribute('data-dirty', "true");
|
|
53
|
+
}
|
|
54
|
+
else {
|
|
55
|
+
element.removeAttribute('data-dirty');
|
|
56
|
+
}
|
|
57
|
+
}
|
|
58
|
+
_isElementDirty() {
|
|
59
|
+
return this._getElementValue() !== this._getElementLoadValue();
|
|
60
|
+
}
|
|
61
|
+
_restoreElementFromLoadValue() {
|
|
62
|
+
let element = this.el;
|
|
63
|
+
let cacheValue = element.getAttribute(this._cacheAttrName);
|
|
64
|
+
if (isElementCheckable(element)) {
|
|
65
|
+
element.setAttribute(this._cacheAttrName, element.checked.toString());
|
|
66
|
+
element.checked = cacheValue == null ? element.defaultChecked : cacheValue == "true";
|
|
67
|
+
}
|
|
68
|
+
else if (isHTMLSelectElement(element)) {
|
|
69
|
+
if (cacheValue == null) {
|
|
70
|
+
let options = Array.from(element.options);
|
|
71
|
+
options.forEach((option) => {
|
|
72
|
+
if (option.defaultSelected) {
|
|
73
|
+
element.value = option.value;
|
|
74
|
+
return;
|
|
75
|
+
}
|
|
76
|
+
});
|
|
77
|
+
}
|
|
78
|
+
else {
|
|
79
|
+
element.value = cacheValue;
|
|
80
|
+
}
|
|
81
|
+
}
|
|
82
|
+
else {
|
|
83
|
+
element.value = cacheValue == null ? element.defaultValue : cacheValue;
|
|
84
|
+
}
|
|
85
|
+
}
|
|
86
|
+
_cacheLoadValues() {
|
|
87
|
+
let element = this.el;
|
|
88
|
+
if (!this._elementHasCachedLoadValue() && isElementCheckable(element)) {
|
|
89
|
+
element.setAttribute(this._cacheAttrName, element.checked.toString());
|
|
90
|
+
}
|
|
91
|
+
else {
|
|
92
|
+
element.setAttribute(this._cacheAttrName, element.value.toString());
|
|
93
|
+
}
|
|
94
|
+
}
|
|
95
|
+
}
|
|
96
|
+
export function isDirty(element) {
|
|
97
|
+
return element.hasAttribute("data-dirty");
|
|
98
|
+
}
|
|
@@ -0,0 +1,107 @@
|
|
|
1
|
+
import { BaseController } from "../../utilities/base_controller";
|
|
2
|
+
import { getOtherRadiosInGroup, isElementCheckable, isHTMLInputElement, isHTMLSelectElement } from "../../utilities/elements";
|
|
3
|
+
import { useEventListener } from "../../mixins/use_event_listener";
|
|
4
|
+
export class DetectDirtyFormController extends BaseController {
|
|
5
|
+
get _formElements() {
|
|
6
|
+
return Array.from(this.el.querySelectorAll('input, select, textarea'));
|
|
7
|
+
}
|
|
8
|
+
get _cacheAttrName() {
|
|
9
|
+
return 'detect-dirty-load-value';
|
|
10
|
+
}
|
|
11
|
+
connect() {
|
|
12
|
+
let element = this.el;
|
|
13
|
+
this._cacheLoadValues();
|
|
14
|
+
this._checkDirty();
|
|
15
|
+
useEventListener(this, element, ["input", "change"], this._checkDirty, { debounce: 10 });
|
|
16
|
+
}
|
|
17
|
+
restore(event) {
|
|
18
|
+
event === null || event === void 0 ? void 0 : event.preventDefault();
|
|
19
|
+
this._formElements.forEach(element => this._restoreElementFromLoadValue(element));
|
|
20
|
+
}
|
|
21
|
+
_getElementValue(element) {
|
|
22
|
+
return isElementCheckable(element) ? element.checked : element.value;
|
|
23
|
+
}
|
|
24
|
+
_getElementLoadValue(element) {
|
|
25
|
+
let value = element.getAttribute(this._cacheAttrName);
|
|
26
|
+
if (isElementCheckable(element)) {
|
|
27
|
+
return value == null ? element.defaultChecked : value == "true";
|
|
28
|
+
}
|
|
29
|
+
else if (isHTMLSelectElement(element)) {
|
|
30
|
+
let options = Array.from(element.options);
|
|
31
|
+
options.forEach((option) => {
|
|
32
|
+
if (option.defaultSelected) {
|
|
33
|
+
element.value = option.value;
|
|
34
|
+
return option.value;
|
|
35
|
+
}
|
|
36
|
+
});
|
|
37
|
+
}
|
|
38
|
+
else if (value !== null) {
|
|
39
|
+
return value;
|
|
40
|
+
}
|
|
41
|
+
return value;
|
|
42
|
+
}
|
|
43
|
+
_elementHasCachedLoadValue(element) {
|
|
44
|
+
return element.hasAttribute(this._cacheAttrName);
|
|
45
|
+
}
|
|
46
|
+
_checkElementDirty(element) {
|
|
47
|
+
if (isHTMLInputElement(element) && element.type == "radio") {
|
|
48
|
+
getOtherRadiosInGroup(element).forEach((radio) => radio.removeAttribute('data-dirty'));
|
|
49
|
+
}
|
|
50
|
+
if (this._isElementDirty(element)) {
|
|
51
|
+
element.setAttribute('data-dirty', "true");
|
|
52
|
+
}
|
|
53
|
+
else {
|
|
54
|
+
element.removeAttribute('data-dirty');
|
|
55
|
+
}
|
|
56
|
+
}
|
|
57
|
+
_isElementDirty(element) {
|
|
58
|
+
return this._getElementValue(element) !== this._getElementLoadValue(element);
|
|
59
|
+
}
|
|
60
|
+
_cacheElementLoadValue(element) {
|
|
61
|
+
if (!this._elementHasCachedLoadValue(element) && isElementCheckable(element)) {
|
|
62
|
+
element.setAttribute(this._cacheAttrName, element.checked.toString());
|
|
63
|
+
}
|
|
64
|
+
else {
|
|
65
|
+
element.setAttribute(this._cacheAttrName, element.value.toString());
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
_restoreElementFromLoadValue(element) {
|
|
69
|
+
let cacheValue = element.getAttribute(this._cacheAttrName);
|
|
70
|
+
if (isElementCheckable(element)) {
|
|
71
|
+
element.setAttribute(this._cacheAttrName, element.checked.toString());
|
|
72
|
+
element.checked = cacheValue == null ? element.defaultChecked : cacheValue == "true";
|
|
73
|
+
}
|
|
74
|
+
else if (isHTMLSelectElement(element)) {
|
|
75
|
+
if (cacheValue == null) {
|
|
76
|
+
let options = Array.from(element.options);
|
|
77
|
+
options.forEach((option) => {
|
|
78
|
+
if (option.defaultSelected) {
|
|
79
|
+
element.value = option.value;
|
|
80
|
+
return;
|
|
81
|
+
}
|
|
82
|
+
});
|
|
83
|
+
}
|
|
84
|
+
else {
|
|
85
|
+
element.value = cacheValue;
|
|
86
|
+
}
|
|
87
|
+
}
|
|
88
|
+
else {
|
|
89
|
+
element.value = cacheValue == null ? element.defaultValue : cacheValue;
|
|
90
|
+
}
|
|
91
|
+
}
|
|
92
|
+
_cacheLoadValues() {
|
|
93
|
+
this._formElements.forEach(el => this._cacheElementLoadValue(el));
|
|
94
|
+
}
|
|
95
|
+
_checkDirty() {
|
|
96
|
+
this._formElements.forEach(el => this._checkElementDirty(el));
|
|
97
|
+
if (this._formElements.some(el => isFormDirty(el))) {
|
|
98
|
+
this.el.setAttribute("data-dirty", "true");
|
|
99
|
+
}
|
|
100
|
+
else {
|
|
101
|
+
this.el.removeAttribute("data-dirty");
|
|
102
|
+
}
|
|
103
|
+
}
|
|
104
|
+
}
|
|
105
|
+
export function isFormDirty(element) {
|
|
106
|
+
return element.hasAttribute("data-dirty");
|
|
107
|
+
}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import { BaseController } from "../../utilities/base_controller";
|
|
2
|
+
export class EnableInputsController extends BaseController {
|
|
3
|
+
connect() {
|
|
4
|
+
}
|
|
5
|
+
disable() {
|
|
6
|
+
let shouldClear = this.hasClearValue && this.clearValue;
|
|
7
|
+
this.inputTargets.forEach((el, _) => {
|
|
8
|
+
if (shouldClear) {
|
|
9
|
+
el.value = "";
|
|
10
|
+
}
|
|
11
|
+
el.disabled = true;
|
|
12
|
+
});
|
|
13
|
+
}
|
|
14
|
+
enable() {
|
|
15
|
+
this.inputTargets.forEach((el, _) => el.disabled = false);
|
|
16
|
+
}
|
|
17
|
+
}
|
|
18
|
+
EnableInputsController.targets = ["input"];
|
|
19
|
+
EnableInputsController.values = {
|
|
20
|
+
clear: Boolean,
|
|
21
|
+
};
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
import { BaseController } from "../../utilities/base_controller";
|
|
2
|
+
export class FocusStealController extends BaseController {
|
|
3
|
+
get _mode() {
|
|
4
|
+
const MODES = ['immediate', 'wait'];
|
|
5
|
+
if (this.hasModeValue) {
|
|
6
|
+
if (!MODES.includes(this.modeValue)) {
|
|
7
|
+
throw new Error(`The given modeValue '${this.modeValue}' is not one of the supported modes: "${MODES.join('", "')}"`);
|
|
8
|
+
}
|
|
9
|
+
else {
|
|
10
|
+
return this.modeValue;
|
|
11
|
+
}
|
|
12
|
+
}
|
|
13
|
+
else {
|
|
14
|
+
return MODES[0];
|
|
15
|
+
}
|
|
16
|
+
}
|
|
17
|
+
connect() {
|
|
18
|
+
if (this._mode == 'immediate') {
|
|
19
|
+
this.steal();
|
|
20
|
+
}
|
|
21
|
+
}
|
|
22
|
+
steal() {
|
|
23
|
+
this.el.focus();
|
|
24
|
+
}
|
|
25
|
+
}
|
|
26
|
+
FocusStealController.values = {
|
|
27
|
+
mode: String,
|
|
28
|
+
};
|
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
import { BaseController } from '../../utilities/base_controller';
|
|
2
|
+
import { requestReset, requestSubmit } from "../../utilities/request_submit";
|
|
3
|
+
export class FormRcController extends BaseController {
|
|
4
|
+
get _mode() {
|
|
5
|
+
if (this.hasSubmitModeValue) {
|
|
6
|
+
if (!["direct", "request"].includes(this.submitModeValue)) {
|
|
7
|
+
throw new Error(`The modeValue provided '${this.submitModeValue}' is not one of the recognised configuration options`);
|
|
8
|
+
}
|
|
9
|
+
return this.submitModeValue;
|
|
10
|
+
}
|
|
11
|
+
else {
|
|
12
|
+
return "request";
|
|
13
|
+
}
|
|
14
|
+
}
|
|
15
|
+
get form() {
|
|
16
|
+
let form;
|
|
17
|
+
if (this.hasFormSelectorValue) {
|
|
18
|
+
form = document.querySelector(this.formSelectorValue);
|
|
19
|
+
if (!form) {
|
|
20
|
+
throw new Error(`Could not find a form on the page that matches selector '${this.formSelectorValue}'`);
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
else {
|
|
24
|
+
form = this.formTarget;
|
|
25
|
+
}
|
|
26
|
+
return form;
|
|
27
|
+
}
|
|
28
|
+
submit(event) {
|
|
29
|
+
event === null || event === void 0 ? void 0 : event.preventDefault();
|
|
30
|
+
let el = this.form;
|
|
31
|
+
if (this._mode == 'request') {
|
|
32
|
+
requestSubmit(el);
|
|
33
|
+
}
|
|
34
|
+
else {
|
|
35
|
+
el.submit();
|
|
36
|
+
}
|
|
37
|
+
}
|
|
38
|
+
reset(event) {
|
|
39
|
+
event === null || event === void 0 ? void 0 : event.preventDefault();
|
|
40
|
+
requestReset(this.form);
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
FormRcController.targets = ["form"];
|
|
44
|
+
FormRcController.values = {
|
|
45
|
+
formSelector: String,
|
|
46
|
+
submitMode: String,
|
|
47
|
+
};
|