stimulus-library 0.7.3 → 0.8.0-beta
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 +1 -1
- 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} +3 -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 +8 -18
- package/CHANGELOG.md +0 -499
- 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/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_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 -4719
- 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
package/README.md
CHANGED
|
@@ -30,7 +30,7 @@ Then, to get started, import and register the controllers you want to use.
|
|
|
30
30
|
*Please Note* as below, that when registering the name for the controller, you should use `kebab-case` and omit the `-controller` suffix.
|
|
31
31
|
|
|
32
32
|
```js
|
|
33
|
-
import { Application } from "stimulus";
|
|
33
|
+
import { Application } from "@hotwired/stimulus";
|
|
34
34
|
import { AutoSubmitFormController } from "stimulus-library";
|
|
35
35
|
|
|
36
36
|
const application = Application.start();
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
2
|
+
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
3
|
+
return new (P || (P = Promise))(function (resolve, reject) {
|
|
4
|
+
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
5
|
+
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
6
|
+
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
7
|
+
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
8
|
+
});
|
|
9
|
+
};
|
|
10
|
+
import { LoadBlockController } from "./load_block_controller";
|
|
11
|
+
export class AsyncBlockController extends LoadBlockController {
|
|
12
|
+
get _errorMessage() {
|
|
13
|
+
return this.hasErrorMessageValue ? this.errorMessageValue : "This content failed to load";
|
|
14
|
+
}
|
|
15
|
+
// This is a simple controller to load a block of content when the page loads.
|
|
16
|
+
// It should be used to give a quick initial response before calling out to an
|
|
17
|
+
// an AJAX endpoint to do some expensive work.
|
|
18
|
+
connect() {
|
|
19
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
20
|
+
yield this.loadContent();
|
|
21
|
+
});
|
|
22
|
+
}
|
|
23
|
+
}
|
|
24
|
+
AsyncBlockController.targets = ["replace"];
|
|
25
|
+
AsyncBlockController.values = {
|
|
26
|
+
endpoint: String,
|
|
27
|
+
errorMessage: String,
|
|
28
|
+
selector: String,
|
|
29
|
+
maxRetries: Number,
|
|
30
|
+
};
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
2
|
+
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
3
|
+
return new (P || (P = Promise))(function (resolve, reject) {
|
|
4
|
+
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
5
|
+
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
6
|
+
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
7
|
+
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
8
|
+
});
|
|
9
|
+
};
|
|
10
|
+
import { LoadBlockController } from "./load_block_controller";
|
|
11
|
+
import { useIntersection } from "../../mixins/use_intersection";
|
|
12
|
+
export class LazyBlockController extends LoadBlockController {
|
|
13
|
+
connect() {
|
|
14
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
15
|
+
let element = this.el;
|
|
16
|
+
if ("IntersectionObserver" in window) {
|
|
17
|
+
let { observe, unobserve } = useIntersection(this, element, this.appear, null, { threshold: 0.3 });
|
|
18
|
+
this.observe = observe;
|
|
19
|
+
this.unobserve = unobserve;
|
|
20
|
+
}
|
|
21
|
+
else {
|
|
22
|
+
// Client doesn't support intersection observer, fallback to pre-loading
|
|
23
|
+
yield this.loadContent();
|
|
24
|
+
}
|
|
25
|
+
});
|
|
26
|
+
}
|
|
27
|
+
appear(entry) {
|
|
28
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
29
|
+
if (entry.target === this.el && entry.isIntersecting) {
|
|
30
|
+
yield this.loadContent();
|
|
31
|
+
if (this.unobserve) {
|
|
32
|
+
this.unobserve();
|
|
33
|
+
}
|
|
34
|
+
}
|
|
35
|
+
});
|
|
36
|
+
}
|
|
37
|
+
}
|
|
@@ -0,0 +1,63 @@
|
|
|
1
|
+
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
2
|
+
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
3
|
+
return new (P || (P = Promise))(function (resolve, reject) {
|
|
4
|
+
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
5
|
+
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
6
|
+
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
7
|
+
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
8
|
+
});
|
|
9
|
+
};
|
|
10
|
+
import { BaseController } from "../../utilities/base_controller";
|
|
11
|
+
import { fetchRetry } from "../../utilities/fetchRetry";
|
|
12
|
+
export class LoadBlockController extends BaseController {
|
|
13
|
+
get _errorMessage() {
|
|
14
|
+
return this.hasErrorMessageValue ? this.errorMessageValue : "This content failed to load";
|
|
15
|
+
}
|
|
16
|
+
get _maxRetries() {
|
|
17
|
+
return this.hasMaxRetriesValue ? this.maxRetriesValue : 1;
|
|
18
|
+
}
|
|
19
|
+
connect() {
|
|
20
|
+
}
|
|
21
|
+
loadContent(event = null) {
|
|
22
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
23
|
+
event === null || event === void 0 ? void 0 : event.preventDefault();
|
|
24
|
+
let self = this;
|
|
25
|
+
let el = this.hasReplaceTarget ? this.replaceTarget : this.el;
|
|
26
|
+
let failure = () => {
|
|
27
|
+
el.replaceWith(this._errorMessage);
|
|
28
|
+
self.dispatchEvent(el, "ajax:error");
|
|
29
|
+
};
|
|
30
|
+
try {
|
|
31
|
+
let response = yield fetchRetry(this._maxRetries, this.endpointValue);
|
|
32
|
+
if (!response.ok) {
|
|
33
|
+
failure();
|
|
34
|
+
}
|
|
35
|
+
let text = yield response.text();
|
|
36
|
+
let newEl = document.createElement("div");
|
|
37
|
+
newEl.innerHTML = text;
|
|
38
|
+
if (this.hasSelectorValue) {
|
|
39
|
+
let selectedContent = newEl.querySelectorAll(this.selectorValue);
|
|
40
|
+
el.replaceWith(...selectedContent);
|
|
41
|
+
}
|
|
42
|
+
else {
|
|
43
|
+
el.replaceWith(...newEl.children);
|
|
44
|
+
}
|
|
45
|
+
// Trigger event to show block has loaded
|
|
46
|
+
self.dispatchEvent(el, "ajax:success");
|
|
47
|
+
}
|
|
48
|
+
catch (e) {
|
|
49
|
+
failure();
|
|
50
|
+
}
|
|
51
|
+
finally {
|
|
52
|
+
self.dispatchEvent(el, "ajax:complete");
|
|
53
|
+
}
|
|
54
|
+
});
|
|
55
|
+
}
|
|
56
|
+
}
|
|
57
|
+
LoadBlockController.targets = ["replace"];
|
|
58
|
+
LoadBlockController.values = {
|
|
59
|
+
endpoint: String,
|
|
60
|
+
errorMessage: String,
|
|
61
|
+
selector: String,
|
|
62
|
+
maxRetries: Number,
|
|
63
|
+
};
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
2
|
+
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
3
|
+
return new (P || (P = Promise))(function (resolve, reject) {
|
|
4
|
+
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
5
|
+
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
6
|
+
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
7
|
+
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
8
|
+
});
|
|
9
|
+
};
|
|
10
|
+
import { LoadBlockController } from "./load_block_controller";
|
|
11
|
+
import { useInterval } from "../../mixins/use_interval";
|
|
12
|
+
export class PollBlockController extends LoadBlockController {
|
|
13
|
+
connect() {
|
|
14
|
+
if (!this.hasSecondsValue) {
|
|
15
|
+
throw new Error("Required value `seconds` is missing");
|
|
16
|
+
}
|
|
17
|
+
requestAnimationFrame(() => {
|
|
18
|
+
this._timeout();
|
|
19
|
+
useInterval(this, this._timeout, this.secondsValue * 1000);
|
|
20
|
+
});
|
|
21
|
+
}
|
|
22
|
+
_timeout() {
|
|
23
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
24
|
+
yield this.loadContent();
|
|
25
|
+
});
|
|
26
|
+
}
|
|
27
|
+
}
|
|
28
|
+
PollBlockController.targets = ["replace"];
|
|
29
|
+
PollBlockController.values = {
|
|
30
|
+
endpoint: String,
|
|
31
|
+
errorMessage: String,
|
|
32
|
+
selector: String,
|
|
33
|
+
maxRetries: Number,
|
|
34
|
+
seconds: Number,
|
|
35
|
+
};
|
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
import { BaseController } from "../utilities/base_controller";
|
|
2
|
+
import { useEventListener } from "../mixins/use_event_listener";
|
|
3
|
+
import { installClassMethods } from "../mixins/install_class_methods";
|
|
4
|
+
import "../polyfills/string.replaceAll";
|
|
5
|
+
export class AnchorSpyController extends BaseController {
|
|
6
|
+
get defaultActiveClasses() {
|
|
7
|
+
return ["active"];
|
|
8
|
+
}
|
|
9
|
+
get defaultInactiveClasses() {
|
|
10
|
+
return ["inactive"];
|
|
11
|
+
}
|
|
12
|
+
get _key() {
|
|
13
|
+
// @ts-ignore
|
|
14
|
+
return this.keyValue.replaceAll('#', '');
|
|
15
|
+
}
|
|
16
|
+
get _anchor() {
|
|
17
|
+
return window.location.hash.substr(1);
|
|
18
|
+
}
|
|
19
|
+
set _anchor(value) {
|
|
20
|
+
window.location.hash = value;
|
|
21
|
+
}
|
|
22
|
+
connect() {
|
|
23
|
+
installClassMethods(this);
|
|
24
|
+
requestAnimationFrame(() => {
|
|
25
|
+
this._checkAnchor();
|
|
26
|
+
useEventListener(this, window, 'hashchange', this._checkAnchor);
|
|
27
|
+
});
|
|
28
|
+
}
|
|
29
|
+
write(event) {
|
|
30
|
+
event === null || event === void 0 ? void 0 : event.preventDefault();
|
|
31
|
+
this._anchor = this._key;
|
|
32
|
+
}
|
|
33
|
+
_checkAnchor() {
|
|
34
|
+
if (this._key === this._anchor) {
|
|
35
|
+
this.dispatchEvent(this.el, "anchor-spy:active");
|
|
36
|
+
this.addActiveClasses(this.el);
|
|
37
|
+
this.removeInactiveClasses(this.el);
|
|
38
|
+
}
|
|
39
|
+
else {
|
|
40
|
+
this.dispatchEvent(this.el, "anchor-spy:inactive");
|
|
41
|
+
this.addInactiveClasses(this.el);
|
|
42
|
+
this.removeActiveClasses(this.el);
|
|
43
|
+
}
|
|
44
|
+
}
|
|
45
|
+
}
|
|
46
|
+
AnchorSpyController.values = { key: String };
|
|
47
|
+
AnchorSpyController.classes = ["active", "inactive"];
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
import { BaseController } from "../utilities/base_controller";
|
|
2
|
+
import { useTimeout } from "../mixins/use_timeout";
|
|
3
|
+
import { useEventListener } from "../mixins/use_event_listener";
|
|
4
|
+
export class BackLinkController extends BaseController {
|
|
5
|
+
get _pages() {
|
|
6
|
+
return this.hasPagesValue ? Math.abs(this.pagesValue) : 1;
|
|
7
|
+
}
|
|
8
|
+
get _timeout() {
|
|
9
|
+
return this.hasTimeoutValue ? this.timeoutValue : 1500;
|
|
10
|
+
}
|
|
11
|
+
connect() {
|
|
12
|
+
useEventListener(this, this.el, "click", this.goBack);
|
|
13
|
+
}
|
|
14
|
+
goBack(event) {
|
|
15
|
+
event === null || event === void 0 ? void 0 : event.preventDefault();
|
|
16
|
+
history.go(-this._pages);
|
|
17
|
+
if (this.el.href) {
|
|
18
|
+
useTimeout(this, this.fallback, this._timeout);
|
|
19
|
+
}
|
|
20
|
+
}
|
|
21
|
+
fallback() {
|
|
22
|
+
window.location.href = this.el.href;
|
|
23
|
+
}
|
|
24
|
+
}
|
|
25
|
+
BackLinkController.values = { timeout: Number, pages: Number };
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
import { BaseController } from "../utilities/base_controller";
|
|
2
|
+
export class ClipboardController extends BaseController {
|
|
3
|
+
constructor() {
|
|
4
|
+
super(...arguments);
|
|
5
|
+
this._supported = false;
|
|
6
|
+
}
|
|
7
|
+
connect() {
|
|
8
|
+
this._supported = document.queryCommandSupported("copy");
|
|
9
|
+
if (this.hasRemoveUnusedValue && this.removeUnusedValue) {
|
|
10
|
+
if (this._supported && this.hasFallbackTarget) {
|
|
11
|
+
this.fallbackTarget.remove();
|
|
12
|
+
}
|
|
13
|
+
else if (this.hasCopyTarget) {
|
|
14
|
+
this.copyTarget.remove();
|
|
15
|
+
}
|
|
16
|
+
}
|
|
17
|
+
}
|
|
18
|
+
select(event) {
|
|
19
|
+
if (event) {
|
|
20
|
+
event.preventDefault();
|
|
21
|
+
}
|
|
22
|
+
this.sourceTarget.select();
|
|
23
|
+
}
|
|
24
|
+
copy(event) {
|
|
25
|
+
if (event) {
|
|
26
|
+
event.preventDefault();
|
|
27
|
+
}
|
|
28
|
+
this.sourceTarget.select();
|
|
29
|
+
if (this._supported) {
|
|
30
|
+
document.execCommand("copy");
|
|
31
|
+
}
|
|
32
|
+
}
|
|
33
|
+
}
|
|
34
|
+
ClipboardController.targets = ["source", "button", "copy", "fallback"];
|
|
35
|
+
ClipboardController.values = { removeUnused: Boolean };
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
import { BaseController } from '../utilities/base_controller';
|
|
2
|
+
import { isHTMLAnchorElement, isHTMLFormElement } from "../utilities/elements";
|
|
3
|
+
import { useEventListener } from "../mixins/use_event_listener";
|
|
4
|
+
export class ConfirmController extends BaseController {
|
|
5
|
+
get _message() {
|
|
6
|
+
return this.hasMessageValue ? this.messageValue : 'Are you sure?';
|
|
7
|
+
}
|
|
8
|
+
get _eventType() {
|
|
9
|
+
if (isHTMLFormElement(this.el)) {
|
|
10
|
+
return "submit";
|
|
11
|
+
}
|
|
12
|
+
else if (isHTMLAnchorElement(this.el)) {
|
|
13
|
+
return "click";
|
|
14
|
+
}
|
|
15
|
+
else {
|
|
16
|
+
throw new Error("Can't handle confirmation on attached element");
|
|
17
|
+
}
|
|
18
|
+
}
|
|
19
|
+
connect() {
|
|
20
|
+
requestAnimationFrame(() => {
|
|
21
|
+
useEventListener(this, this.el, this._eventType, this.confirm);
|
|
22
|
+
});
|
|
23
|
+
}
|
|
24
|
+
confirm(event) {
|
|
25
|
+
if (!(window.confirm(this._message))) {
|
|
26
|
+
event.preventDefault();
|
|
27
|
+
this.dispatchEvent(this.el, "confirm:cancelled");
|
|
28
|
+
}
|
|
29
|
+
}
|
|
30
|
+
}
|
|
31
|
+
ConfirmController.values = {
|
|
32
|
+
message: String,
|
|
33
|
+
};
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
import { BaseController } from "../utilities/base_controller";
|
|
2
|
+
import { useEventListener } from "../mixins/use_event_listener";
|
|
3
|
+
export class ConfirmNavigationController extends BaseController {
|
|
4
|
+
get _message() {
|
|
5
|
+
return this.hasMessageValue ? this.messageValue : "Do you want to leave this page? Changes you made may not be saved";
|
|
6
|
+
}
|
|
7
|
+
connect() {
|
|
8
|
+
window.onbeforeunload = () => this._message;
|
|
9
|
+
useEventListener(this, window, "popstate", this.confirmNavigation);
|
|
10
|
+
useEventListener(this, window, "submit", this.allowSubmit);
|
|
11
|
+
useEventListener(this, window, ["turbolinks:before-visit", "turbo:before-visit"], this.confirmTurboNavigation);
|
|
12
|
+
}
|
|
13
|
+
disconnect() {
|
|
14
|
+
window.onbeforeunload = null;
|
|
15
|
+
}
|
|
16
|
+
allowSubmit(_event) {
|
|
17
|
+
window.removeEventListener("popstate", this.confirmNavigation);
|
|
18
|
+
window.onbeforeunload = null;
|
|
19
|
+
}
|
|
20
|
+
confirmNavigation(_event) {
|
|
21
|
+
return false;
|
|
22
|
+
}
|
|
23
|
+
confirmTurboNavigation(event) {
|
|
24
|
+
if (!confirm(this._message)) {
|
|
25
|
+
event.preventDefault();
|
|
26
|
+
}
|
|
27
|
+
}
|
|
28
|
+
}
|
|
29
|
+
ConfirmNavigationController.values = { message: String };
|
|
@@ -0,0 +1,66 @@
|
|
|
1
|
+
import { BaseController } from '../utilities/base_controller';
|
|
2
|
+
import { isTypeOfButtonableElement } from "../utilities/elements";
|
|
3
|
+
import { useEventListener } from "../mixins/use_event_listener";
|
|
4
|
+
import { useTemporaryContent } from "../mixins/use_temporary_content";
|
|
5
|
+
export class DisableWithController extends BaseController {
|
|
6
|
+
get _message() {
|
|
7
|
+
return this.hasMessageValue ? this.messageValue : 'Submitting...';
|
|
8
|
+
}
|
|
9
|
+
get _timeout() {
|
|
10
|
+
return this.hasTimeoutValue ? this.timeoutValue : 1000;
|
|
11
|
+
}
|
|
12
|
+
connect() {
|
|
13
|
+
requestAnimationFrame(() => {
|
|
14
|
+
useEventListener(this, this.el, ["click"], this.disable);
|
|
15
|
+
useEventListener(this, window, ["turbo:load", "turbolinks:load"], this._enable);
|
|
16
|
+
});
|
|
17
|
+
}
|
|
18
|
+
disable(event) {
|
|
19
|
+
let element = this.el;
|
|
20
|
+
if (this._isDisabled(element)) {
|
|
21
|
+
event === null || event === void 0 ? void 0 : event.preventDefault();
|
|
22
|
+
event === null || event === void 0 ? void 0 : event.stopImmediatePropagation();
|
|
23
|
+
}
|
|
24
|
+
else {
|
|
25
|
+
this._disable();
|
|
26
|
+
useTemporaryContent(this, element, this._message, this._timeout, this._enable);
|
|
27
|
+
}
|
|
28
|
+
}
|
|
29
|
+
enable(event) {
|
|
30
|
+
event === null || event === void 0 ? void 0 : event.preventDefault();
|
|
31
|
+
let element = this.el;
|
|
32
|
+
if (this._isDisabled(element)) {
|
|
33
|
+
this._enable();
|
|
34
|
+
}
|
|
35
|
+
}
|
|
36
|
+
_isDisabled(el) {
|
|
37
|
+
if (isTypeOfButtonableElement(el)) {
|
|
38
|
+
return el.disabled;
|
|
39
|
+
}
|
|
40
|
+
else {
|
|
41
|
+
return el.dataset.disabled == "true";
|
|
42
|
+
}
|
|
43
|
+
}
|
|
44
|
+
_disable() {
|
|
45
|
+
let el = this.el;
|
|
46
|
+
if (isTypeOfButtonableElement(el)) {
|
|
47
|
+
el.disabled = true;
|
|
48
|
+
}
|
|
49
|
+
else {
|
|
50
|
+
el.dataset.disabled = "true";
|
|
51
|
+
}
|
|
52
|
+
}
|
|
53
|
+
_enable() {
|
|
54
|
+
let el = this.el;
|
|
55
|
+
if (isTypeOfButtonableElement(el)) {
|
|
56
|
+
el.disabled = false;
|
|
57
|
+
}
|
|
58
|
+
else {
|
|
59
|
+
el.dataset.disabled = undefined;
|
|
60
|
+
}
|
|
61
|
+
}
|
|
62
|
+
}
|
|
63
|
+
DisableWithController.values = {
|
|
64
|
+
message: String,
|
|
65
|
+
timeout: Number,
|
|
66
|
+
};
|
|
@@ -0,0 +1,80 @@
|
|
|
1
|
+
import debounce from "lodash-es/debounce";
|
|
2
|
+
import _get from "lodash-es/get";
|
|
3
|
+
import _set from "lodash-es/set";
|
|
4
|
+
import { BaseController } from '../utilities/base_controller';
|
|
5
|
+
import { useLocalStorage } from "../mixins";
|
|
6
|
+
export class ElementSaveController extends BaseController {
|
|
7
|
+
get _id() {
|
|
8
|
+
if (this.hasIdValue) {
|
|
9
|
+
return this.idValue;
|
|
10
|
+
}
|
|
11
|
+
let elementID = this.el.id;
|
|
12
|
+
if (elementID !== "") {
|
|
13
|
+
return elementID;
|
|
14
|
+
}
|
|
15
|
+
else {
|
|
16
|
+
throw new Error(`No ID value to uniquely identify this element. Please either specify data-${this.identifier}-id-value or give this element an 'id' attribute. `);
|
|
17
|
+
}
|
|
18
|
+
}
|
|
19
|
+
get _uniqueIdentifier() {
|
|
20
|
+
const url = location.href;
|
|
21
|
+
return `${url} ${this._id}`;
|
|
22
|
+
}
|
|
23
|
+
get _restoreOnLoad() {
|
|
24
|
+
return this.hasRestoreOnLoadValue ? this.restoreOnLoadValue : true;
|
|
25
|
+
}
|
|
26
|
+
get _element() {
|
|
27
|
+
return this.hasElementTarget ? this.elementTarget : this.el;
|
|
28
|
+
}
|
|
29
|
+
initialize() {
|
|
30
|
+
this.save = debounce(this.save.bind(this), 300);
|
|
31
|
+
}
|
|
32
|
+
connect() {
|
|
33
|
+
this._store = useLocalStorage(this, this._uniqueIdentifier, {});
|
|
34
|
+
requestAnimationFrame(() => {
|
|
35
|
+
if (this._restoreOnLoad) {
|
|
36
|
+
this.restore();
|
|
37
|
+
}
|
|
38
|
+
});
|
|
39
|
+
}
|
|
40
|
+
clear(event) {
|
|
41
|
+
if (event) {
|
|
42
|
+
event.preventDefault();
|
|
43
|
+
}
|
|
44
|
+
this._store.clear();
|
|
45
|
+
this.dispatchEvent(this._element, `element-save:cleared`);
|
|
46
|
+
}
|
|
47
|
+
save(event) {
|
|
48
|
+
if (event) {
|
|
49
|
+
event.preventDefault();
|
|
50
|
+
}
|
|
51
|
+
let element = this._element;
|
|
52
|
+
let attributes = this.attributesValue.split(" ");
|
|
53
|
+
let data = {};
|
|
54
|
+
attributes.forEach((attr) => data[attr] = _get(element, attr));
|
|
55
|
+
this._store.value = data;
|
|
56
|
+
this.dispatchEvent(element, `element-save:save:success`);
|
|
57
|
+
}
|
|
58
|
+
restore(event) {
|
|
59
|
+
if (event) {
|
|
60
|
+
event.preventDefault();
|
|
61
|
+
}
|
|
62
|
+
let element = this._element;
|
|
63
|
+
if (!this._store.isEmpty()) {
|
|
64
|
+
const savedData = this._store.value; // get and parse the saved data from localStorage
|
|
65
|
+
Object.keys(savedData).forEach((attr) => _set(element, attr, savedData[attr]));
|
|
66
|
+
this.dispatchEvent(element, `element-save:restore:success`);
|
|
67
|
+
}
|
|
68
|
+
else {
|
|
69
|
+
this.dispatchEvent(element, `element-save:restore:empty`);
|
|
70
|
+
}
|
|
71
|
+
}
|
|
72
|
+
}
|
|
73
|
+
ElementSaveController.targets = [
|
|
74
|
+
"element",
|
|
75
|
+
];
|
|
76
|
+
ElementSaveController.values = {
|
|
77
|
+
id: String,
|
|
78
|
+
attributes: String,
|
|
79
|
+
restoreOnLoad: Boolean,
|
|
80
|
+
};
|
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
import { useMutationObserver } from "../mixins/use_mutation_observer";
|
|
2
|
+
import { BaseController } from "../utilities/base_controller";
|
|
3
|
+
import { installClassMethods } from "../mixins/install_class_methods";
|
|
4
|
+
export class EmptyDomController extends BaseController {
|
|
5
|
+
get _container() {
|
|
6
|
+
return this.hasContainerTarget ? this.containerTarget : this.el;
|
|
7
|
+
}
|
|
8
|
+
get _children() {
|
|
9
|
+
let element = this._container;
|
|
10
|
+
if (this.hasScopeSelectorValue) {
|
|
11
|
+
return Array.from(element.querySelectorAll(this.scopeSelectorValue));
|
|
12
|
+
}
|
|
13
|
+
else {
|
|
14
|
+
return Array.from(element.children);
|
|
15
|
+
}
|
|
16
|
+
}
|
|
17
|
+
connect() {
|
|
18
|
+
installClassMethods(this);
|
|
19
|
+
useMutationObserver(this, this._container, this.mutate, { childList: true });
|
|
20
|
+
this.checkEmpty();
|
|
21
|
+
}
|
|
22
|
+
mutate(entries) {
|
|
23
|
+
this.checkEmpty();
|
|
24
|
+
}
|
|
25
|
+
checkEmpty() {
|
|
26
|
+
let element = this._container;
|
|
27
|
+
let children = this._children;
|
|
28
|
+
if (children.length === 0) {
|
|
29
|
+
this.removeNotEmptyClasses();
|
|
30
|
+
this.addEmptyClasses();
|
|
31
|
+
this.dispatchEvent(element, "dom:empty");
|
|
32
|
+
}
|
|
33
|
+
else {
|
|
34
|
+
this.addNotEmptyClasses();
|
|
35
|
+
this.removeEmptyClasses();
|
|
36
|
+
this.dispatchEvent(element, "dom:not-empty", { detail: { count: children.length } });
|
|
37
|
+
}
|
|
38
|
+
}
|
|
39
|
+
}
|
|
40
|
+
EmptyDomController.targets = ["container"];
|
|
41
|
+
EmptyDomController.classes = ["empty", "notEmpty"];
|
|
42
|
+
EmptyDomController.values = { scopeSelector: String };
|
|
@@ -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 };
|