stimulus-library 0.7.5 → 0.9.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/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/persisted_dismissable_controller.js +19 -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 +17 -24
- package/CHANGELOG.md +0 -513
- 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_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 -5094
- 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,97 @@
|
|
|
1
|
+
import { BaseController } from "../../utilities/base_controller";
|
|
2
|
+
import { useCollectionEventListener } from "../../mixins/use_event_listener";
|
|
3
|
+
export class TableSortController extends BaseController {
|
|
4
|
+
constructor() {
|
|
5
|
+
super(...arguments);
|
|
6
|
+
this._lastIndex = null;
|
|
7
|
+
this._reverse = false;
|
|
8
|
+
}
|
|
9
|
+
get _tableHead() {
|
|
10
|
+
let head = this.el.tHead;
|
|
11
|
+
if (head == null) {
|
|
12
|
+
throw new Error('Expected table to have a <thead> element.');
|
|
13
|
+
}
|
|
14
|
+
return head;
|
|
15
|
+
}
|
|
16
|
+
get _tableHeaders() {
|
|
17
|
+
let rows = this._tableHead.rows;
|
|
18
|
+
if (rows.length == 0) {
|
|
19
|
+
throw new Error('Expected table to have a <thead> element with at least one row.');
|
|
20
|
+
}
|
|
21
|
+
return Array.from(rows[0].cells);
|
|
22
|
+
}
|
|
23
|
+
get _tableBody() {
|
|
24
|
+
return this.el.tBodies[0];
|
|
25
|
+
}
|
|
26
|
+
get _tableRows() {
|
|
27
|
+
return Array.from(this._tableBody.rows);
|
|
28
|
+
}
|
|
29
|
+
connect() {
|
|
30
|
+
requestAnimationFrame(() => {
|
|
31
|
+
useCollectionEventListener(this, this._tableHeaders, "click", this.sort);
|
|
32
|
+
if (this.hasStartSortValue) {
|
|
33
|
+
this._sortByColumn(this.startSortValue);
|
|
34
|
+
}
|
|
35
|
+
});
|
|
36
|
+
}
|
|
37
|
+
sort(event) {
|
|
38
|
+
event.preventDefault();
|
|
39
|
+
let headerCell = event.target;
|
|
40
|
+
let headerCellIndex = this._indexOfHeaderCell(headerCell);
|
|
41
|
+
if (headerCell.dataset.sortable == "false") {
|
|
42
|
+
return;
|
|
43
|
+
}
|
|
44
|
+
if (headerCell.dataset.sort == "asc") {
|
|
45
|
+
this._reverse = true;
|
|
46
|
+
this._otherHeaderCells(headerCell).forEach(cell => delete cell.dataset.sort);
|
|
47
|
+
headerCell.dataset.sort = "desc";
|
|
48
|
+
this._sortByColumn(headerCellIndex);
|
|
49
|
+
}
|
|
50
|
+
else {
|
|
51
|
+
this._reverse = false;
|
|
52
|
+
this._otherHeaderCells(headerCell).forEach(cell => delete cell.dataset.sort);
|
|
53
|
+
headerCell.dataset.sort = "asc";
|
|
54
|
+
this._sortByColumn(headerCellIndex);
|
|
55
|
+
}
|
|
56
|
+
}
|
|
57
|
+
_indexOfHeaderCell(cell) {
|
|
58
|
+
return this._tableHeaders.indexOf(cell);
|
|
59
|
+
}
|
|
60
|
+
_otherHeaderCells(cell) {
|
|
61
|
+
return Array.from(this._tableHeaders).filter(otherCell => otherCell != cell);
|
|
62
|
+
}
|
|
63
|
+
_sortByColumn(index) {
|
|
64
|
+
let frag = document.createDocumentFragment();
|
|
65
|
+
let rows = this._tableRows;
|
|
66
|
+
let newRows = rows.sort((row, otherRow) => {
|
|
67
|
+
var _a, _b;
|
|
68
|
+
let cells = Array.from(row.cells);
|
|
69
|
+
let otherCells = Array.from(otherRow.cells);
|
|
70
|
+
// TODO: Handle colspans?
|
|
71
|
+
let x = ((_a = cells[index]) === null || _a === void 0 ? void 0 : _a.innerText) || "";
|
|
72
|
+
let y = ((_b = otherCells[index]) === null || _b === void 0 ? void 0 : _b.innerText) || "";
|
|
73
|
+
let sortVal = x.localeCompare(y, "en", { sensitivity: "base", numeric: true, caseFirst: "upper" });
|
|
74
|
+
if (row.dataset.sortTop || otherRow.dataset.sortBottom) {
|
|
75
|
+
if (row.dataset.sortTop && otherRow.dataset.sortTop) {
|
|
76
|
+
return sortVal;
|
|
77
|
+
}
|
|
78
|
+
return -1;
|
|
79
|
+
}
|
|
80
|
+
if (row.dataset.sortBottom || otherRow.dataset.sortTop) {
|
|
81
|
+
if (row.dataset.sortBottom && otherRow.dataset.sortBottom) {
|
|
82
|
+
return sortVal;
|
|
83
|
+
}
|
|
84
|
+
return 1;
|
|
85
|
+
}
|
|
86
|
+
if (this._reverse) {
|
|
87
|
+
return sortVal > 0 ? -1 : 1;
|
|
88
|
+
}
|
|
89
|
+
return sortVal;
|
|
90
|
+
});
|
|
91
|
+
newRows.forEach(row => frag.appendChild(row));
|
|
92
|
+
this._tableBody.innerHTML = "";
|
|
93
|
+
this._tableBody.appendChild(frag);
|
|
94
|
+
this._lastIndex = index;
|
|
95
|
+
}
|
|
96
|
+
}
|
|
97
|
+
TableSortController.values = { startSort: Number };
|
|
@@ -0,0 +1,81 @@
|
|
|
1
|
+
import { BaseController } from "../../utilities/base_controller";
|
|
2
|
+
import { useEventListener } from "../../mixins/use_event_listener";
|
|
3
|
+
import { useMutationObserver } from "../../mixins/use_mutation_observer";
|
|
4
|
+
export class TableTruncateController extends BaseController {
|
|
5
|
+
get _truncated() {
|
|
6
|
+
return this.hasTruncatedValue ? this.truncatedValue : false;
|
|
7
|
+
}
|
|
8
|
+
set _truncated(value) {
|
|
9
|
+
this.truncatedValue = value;
|
|
10
|
+
}
|
|
11
|
+
get _tableBody() {
|
|
12
|
+
return this.el.tBodies[0];
|
|
13
|
+
}
|
|
14
|
+
get _tableRows() {
|
|
15
|
+
return Array.from(this._tableBody.rows);
|
|
16
|
+
}
|
|
17
|
+
get _limit() {
|
|
18
|
+
return this.hasLimitValue ? this.limitValue : 20;
|
|
19
|
+
}
|
|
20
|
+
connect() {
|
|
21
|
+
useMutationObserver(this, this._tableBody, this.mutate, { childList: true });
|
|
22
|
+
requestAnimationFrame(() => {
|
|
23
|
+
this.truncate();
|
|
24
|
+
useEventListener(this, this.showMoreTarget, "click", this.expand);
|
|
25
|
+
});
|
|
26
|
+
}
|
|
27
|
+
truncate(event) {
|
|
28
|
+
event === null || event === void 0 ? void 0 : event.preventDefault();
|
|
29
|
+
this._truncated = true;
|
|
30
|
+
if (this._tableRows.length >= this._limit) {
|
|
31
|
+
this._tableRows.slice(this._limit).forEach((el) => {
|
|
32
|
+
if (el !== this.showMoreTarget) {
|
|
33
|
+
this._hideElement(el);
|
|
34
|
+
}
|
|
35
|
+
});
|
|
36
|
+
this._showElement(this.showMoreTarget);
|
|
37
|
+
}
|
|
38
|
+
else {
|
|
39
|
+
this._hideElement(this.showMoreTarget);
|
|
40
|
+
}
|
|
41
|
+
}
|
|
42
|
+
expand(event) {
|
|
43
|
+
this._truncated = false;
|
|
44
|
+
event === null || event === void 0 ? void 0 : event.preventDefault();
|
|
45
|
+
this._tableRows.slice(this._limit).forEach((el) => {
|
|
46
|
+
if (el !== this.showMoreTarget) {
|
|
47
|
+
this._showElement(el);
|
|
48
|
+
}
|
|
49
|
+
});
|
|
50
|
+
this._hideElement(this.showMoreTarget);
|
|
51
|
+
}
|
|
52
|
+
mutate(entries) {
|
|
53
|
+
if (this._truncated) {
|
|
54
|
+
this._reTruncate();
|
|
55
|
+
}
|
|
56
|
+
}
|
|
57
|
+
_showElement(el) {
|
|
58
|
+
el.style.display = "";
|
|
59
|
+
}
|
|
60
|
+
_hideElement(el) {
|
|
61
|
+
el.style.display = "none";
|
|
62
|
+
}
|
|
63
|
+
_reTruncate() {
|
|
64
|
+
this._tableRows.slice(0, this._limit).forEach((el) => {
|
|
65
|
+
if (el !== this.showMoreTarget) {
|
|
66
|
+
this._showElement(el);
|
|
67
|
+
}
|
|
68
|
+
});
|
|
69
|
+
this._tableRows.slice(this._limit).forEach((el) => {
|
|
70
|
+
if (el !== this.showMoreTarget) {
|
|
71
|
+
this._hideElement(el);
|
|
72
|
+
}
|
|
73
|
+
});
|
|
74
|
+
this._showElement(this.showMoreTarget);
|
|
75
|
+
}
|
|
76
|
+
}
|
|
77
|
+
TableTruncateController.targets = ["showMore"];
|
|
78
|
+
TableTruncateController.values = {
|
|
79
|
+
limit: Number,
|
|
80
|
+
truncated: Boolean,
|
|
81
|
+
};
|
|
@@ -0,0 +1,48 @@
|
|
|
1
|
+
import { EphemeralController } from "../utilities/ephemeral_controller";
|
|
2
|
+
export class TeleportController extends EphemeralController {
|
|
3
|
+
connect() {
|
|
4
|
+
if (!this.hasInsertValue) {
|
|
5
|
+
throw new Error("`insert` value was not specified");
|
|
6
|
+
}
|
|
7
|
+
requestAnimationFrame(() => {
|
|
8
|
+
if (this.hasImmediateValue && this.immediateValue) {
|
|
9
|
+
this.execute();
|
|
10
|
+
}
|
|
11
|
+
});
|
|
12
|
+
}
|
|
13
|
+
execute(event) {
|
|
14
|
+
event === null || event === void 0 ? void 0 : event.preventDefault();
|
|
15
|
+
let element = this.el;
|
|
16
|
+
let destination = document.querySelector(this.targetValue);
|
|
17
|
+
if (destination == null) {
|
|
18
|
+
this.dispatchEvent(element, "teleport:error");
|
|
19
|
+
return;
|
|
20
|
+
}
|
|
21
|
+
let copy = element.cloneNode(true);
|
|
22
|
+
this.cleanup(copy);
|
|
23
|
+
switch (this.insertValue) {
|
|
24
|
+
case "beforebegin":
|
|
25
|
+
case "beforeend":
|
|
26
|
+
case "afterend":
|
|
27
|
+
case "afterbegin":
|
|
28
|
+
destination.insertAdjacentHTML(this.insertValue, copy.outerHTML);
|
|
29
|
+
break;
|
|
30
|
+
case "replaceOuter":
|
|
31
|
+
destination.outerHTML = copy.outerHTML;
|
|
32
|
+
break;
|
|
33
|
+
case "replaceInner":
|
|
34
|
+
destination.innerHTML = copy.outerHTML;
|
|
35
|
+
break;
|
|
36
|
+
case "prepend":
|
|
37
|
+
destination.insertAdjacentHTML("afterbegin", copy.outerHTML);
|
|
38
|
+
break;
|
|
39
|
+
case "append":
|
|
40
|
+
destination.insertAdjacentHTML("beforeend", copy.outerHTML);
|
|
41
|
+
break;
|
|
42
|
+
default:
|
|
43
|
+
throw new Error("`insert` value was not specified");
|
|
44
|
+
}
|
|
45
|
+
element.remove();
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
TeleportController.values = { target: String, insert: String, immediate: Boolean };
|
|
@@ -0,0 +1,65 @@
|
|
|
1
|
+
import camelCase from "lodash-es/camelCase";
|
|
2
|
+
import _get from "lodash-es/get";
|
|
3
|
+
import _set from "lodash-es/set";
|
|
4
|
+
import { EphemeralController } from "../utilities/ephemeral_controller";
|
|
5
|
+
import { useTimeout } from "../mixins/use_timeout";
|
|
6
|
+
import "../polyfills/string.replaceAll";
|
|
7
|
+
export class TemporaryStateController extends EphemeralController {
|
|
8
|
+
constructor() {
|
|
9
|
+
super(...arguments);
|
|
10
|
+
this._previousState = {};
|
|
11
|
+
}
|
|
12
|
+
get _value() {
|
|
13
|
+
if (this.hasValueValue) {
|
|
14
|
+
return this.valueValue;
|
|
15
|
+
}
|
|
16
|
+
throw new Error("Expected `valueValue` to be present");
|
|
17
|
+
}
|
|
18
|
+
get _attribute() {
|
|
19
|
+
if (this.hasAttributeValue) {
|
|
20
|
+
return this.attributeValue;
|
|
21
|
+
}
|
|
22
|
+
throw new Error("Expected `attributeValue` to be present");
|
|
23
|
+
}
|
|
24
|
+
get _seconds() {
|
|
25
|
+
if (this.hasSecondsValue) {
|
|
26
|
+
return this.secondsValue * 1000;
|
|
27
|
+
}
|
|
28
|
+
throw new Error("Expected `secondsValue` to be present");
|
|
29
|
+
}
|
|
30
|
+
connect() {
|
|
31
|
+
this.setState();
|
|
32
|
+
useTimeout(this, this.removeState, this._seconds);
|
|
33
|
+
}
|
|
34
|
+
disconnect() {
|
|
35
|
+
this.removeState();
|
|
36
|
+
}
|
|
37
|
+
setState() {
|
|
38
|
+
this._previousState[this._attribute] = _get(this.el, this._attribute);
|
|
39
|
+
_set(this.el, this._attribute, this.valueValue);
|
|
40
|
+
}
|
|
41
|
+
removeState() {
|
|
42
|
+
_set(this.el, this._attribute, this._previousState[this._attribute]);
|
|
43
|
+
}
|
|
44
|
+
}
|
|
45
|
+
TemporaryStateController.values = {
|
|
46
|
+
attribute: String,
|
|
47
|
+
seconds: Number,
|
|
48
|
+
value: String,
|
|
49
|
+
};
|
|
50
|
+
export function applyTemporaryState(element, propertyString, value, seconds, controllerIdentifier = "temporary-state") {
|
|
51
|
+
var _a;
|
|
52
|
+
if (!element.dataset.controller || !((_a = element.dataset.controller) === null || _a === void 0 ? void 0 : _a.includes(controllerIdentifier))) {
|
|
53
|
+
let controllerName = (element.dataset.controller || '' + ` ${controllerIdentifier} `).trim();
|
|
54
|
+
// @ts-ignore
|
|
55
|
+
controllerName = controllerName.replaceAll(' ', ' ');
|
|
56
|
+
element.dataset.controller = controllerName;
|
|
57
|
+
}
|
|
58
|
+
// @ts-ignore
|
|
59
|
+
element[camelCase(`${controllerIdentifier}-attribute-value`)] = propertyString;
|
|
60
|
+
// @ts-ignore
|
|
61
|
+
element[camelCase(`${controllerIdentifier}-seconds-value`)] = seconds.toString();
|
|
62
|
+
}
|
|
63
|
+
export function applyTemporaryClass(element, value, seconds) {
|
|
64
|
+
applyTemporaryState(element, 'className', value, seconds);
|
|
65
|
+
}
|
|
@@ -0,0 +1,115 @@
|
|
|
1
|
+
import { BaseController } from "../utilities/base_controller";
|
|
2
|
+
import { useClickOutside } from "../mixins/use_click_outside";
|
|
3
|
+
import { useHover } from "../mixins/use_hover";
|
|
4
|
+
export class ToggleClassController extends BaseController {
|
|
5
|
+
connect() {
|
|
6
|
+
if (!this.hasClassValue) {
|
|
7
|
+
throw new Error("data-toggle-class-class-value must not be empty");
|
|
8
|
+
}
|
|
9
|
+
if (this.hasMouseEnterValue || this.hasMouseLeaveValue) {
|
|
10
|
+
useHover(this, this.el, this.mouseEnter, this.mouseLeave);
|
|
11
|
+
}
|
|
12
|
+
if (this.hasClickAwayValue && this.clickAwayValue) {
|
|
13
|
+
useClickOutside(this, this.el, this.clickOutside);
|
|
14
|
+
}
|
|
15
|
+
requestAnimationFrame(() => {
|
|
16
|
+
if (this.hasInitialValue) {
|
|
17
|
+
if (this.initialValue === "on") {
|
|
18
|
+
this.toggleTargets.forEach((target) => this._elementOn(target));
|
|
19
|
+
}
|
|
20
|
+
else {
|
|
21
|
+
this.toggleTargets.forEach((target) => this._elementOff(target));
|
|
22
|
+
}
|
|
23
|
+
}
|
|
24
|
+
});
|
|
25
|
+
}
|
|
26
|
+
clickOutside() {
|
|
27
|
+
this.toggleTargets.forEach((target) => {
|
|
28
|
+
if (this._elementWasToggled(target)) {
|
|
29
|
+
this._elementToggleStatus(target);
|
|
30
|
+
this._elementToggle(target);
|
|
31
|
+
}
|
|
32
|
+
});
|
|
33
|
+
}
|
|
34
|
+
mouseEnter() {
|
|
35
|
+
if (this.hasMouseEnterValue) {
|
|
36
|
+
switch (this.mouseEnterValue) {
|
|
37
|
+
case "on":
|
|
38
|
+
this.on();
|
|
39
|
+
break;
|
|
40
|
+
case "off":
|
|
41
|
+
this.off();
|
|
42
|
+
break;
|
|
43
|
+
case "toggle":
|
|
44
|
+
this.toggle();
|
|
45
|
+
break;
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
return {};
|
|
49
|
+
}
|
|
50
|
+
mouseLeave() {
|
|
51
|
+
if (this.hasMouseLeaveValue) {
|
|
52
|
+
switch (this.mouseLeaveValue) {
|
|
53
|
+
case "on":
|
|
54
|
+
this.on();
|
|
55
|
+
break;
|
|
56
|
+
case "off":
|
|
57
|
+
this.off();
|
|
58
|
+
break;
|
|
59
|
+
case "toggle":
|
|
60
|
+
this.toggle();
|
|
61
|
+
break;
|
|
62
|
+
}
|
|
63
|
+
}
|
|
64
|
+
return {};
|
|
65
|
+
}
|
|
66
|
+
on(event) {
|
|
67
|
+
this.toggleTargets.forEach((target) => {
|
|
68
|
+
this._elementToggleStatus(target);
|
|
69
|
+
this._elementOn(target);
|
|
70
|
+
});
|
|
71
|
+
}
|
|
72
|
+
off(event) {
|
|
73
|
+
this.toggleTargets.forEach((target) => {
|
|
74
|
+
this._elementToggleStatus(target);
|
|
75
|
+
this._elementOff(target);
|
|
76
|
+
});
|
|
77
|
+
}
|
|
78
|
+
toggle(event) {
|
|
79
|
+
this.toggleTargets.forEach((target) => {
|
|
80
|
+
this._elementToggleStatus(target);
|
|
81
|
+
this._elementToggle(target);
|
|
82
|
+
});
|
|
83
|
+
}
|
|
84
|
+
_elementWasToggled(el) {
|
|
85
|
+
return el.dataset.toggled == "true";
|
|
86
|
+
}
|
|
87
|
+
_elementToggleStatus(el) {
|
|
88
|
+
if (this._elementWasToggled(el)) {
|
|
89
|
+
delete el.dataset.toggled;
|
|
90
|
+
}
|
|
91
|
+
else {
|
|
92
|
+
el.dataset.toggled = "true";
|
|
93
|
+
}
|
|
94
|
+
}
|
|
95
|
+
_elementToggle(el) {
|
|
96
|
+
let classes = this.classValue.split(" ");
|
|
97
|
+
classes.forEach((klass) => el.classList.toggle(klass));
|
|
98
|
+
}
|
|
99
|
+
_elementOn(el) {
|
|
100
|
+
let classes = this.classValue.split(" ");
|
|
101
|
+
classes.forEach((klass) => el.classList.toggle(klass, true));
|
|
102
|
+
}
|
|
103
|
+
_elementOff(el) {
|
|
104
|
+
let classes = this.classValue.split(" ");
|
|
105
|
+
classes.forEach((klass) => el.classList.toggle(klass, false));
|
|
106
|
+
}
|
|
107
|
+
}
|
|
108
|
+
ToggleClassController.targets = ["toggle"];
|
|
109
|
+
ToggleClassController.values = {
|
|
110
|
+
class: String,
|
|
111
|
+
mouseEnter: String,
|
|
112
|
+
mouseLeave: String,
|
|
113
|
+
clickAway: Boolean,
|
|
114
|
+
initial: String,
|
|
115
|
+
};
|
|
@@ -0,0 +1,121 @@
|
|
|
1
|
+
import { BaseController } from "../utilities/base_controller";
|
|
2
|
+
import { useTrixModifiers } from "../mixins/use_trix_modifiers";
|
|
3
|
+
export class TrixModifierController extends BaseController {
|
|
4
|
+
get enabledBehaviours() {
|
|
5
|
+
let enabled = (datasetProp) => datasetProp !== undefined && datasetProp !== 'false';
|
|
6
|
+
let behaviourIfEnabled = (datasetProp, trixInstallable) => enabled(datasetProp) ? [trixInstallable] : [];
|
|
7
|
+
return [
|
|
8
|
+
...(behaviourIfEnabled(this.el.dataset.noBold, this.bold)),
|
|
9
|
+
...(behaviourIfEnabled(this.el.dataset.noBulletList, this.bulletList)),
|
|
10
|
+
...(behaviourIfEnabled(this.el.dataset.noCode, this.code)),
|
|
11
|
+
...(behaviourIfEnabled(this.el.dataset.noHeading, this.heading)),
|
|
12
|
+
...(behaviourIfEnabled(this.el.dataset.noItalic, this.italic)),
|
|
13
|
+
...(behaviourIfEnabled(this.el.dataset.noStrikethrough, this.strikethrough)),
|
|
14
|
+
...(behaviourIfEnabled(this.el.dataset.noLink, this.link)),
|
|
15
|
+
...(behaviourIfEnabled(this.el.dataset.noIndents, this.indents)),
|
|
16
|
+
...(behaviourIfEnabled(this.el.dataset.noNumberList, this.numberList)),
|
|
17
|
+
...(behaviourIfEnabled(this.el.dataset.noQuote, this.quote)),
|
|
18
|
+
...(behaviourIfEnabled(this.el.dataset.noFileUploads, this.fileUploads)),
|
|
19
|
+
];
|
|
20
|
+
}
|
|
21
|
+
get bold() {
|
|
22
|
+
return this.formattingHandlers('.trix-button--icon-bold', 'bold');
|
|
23
|
+
}
|
|
24
|
+
get bulletList() {
|
|
25
|
+
return this.formattingHandlers('.trix-button--icon-bullet-list', 'bullet-list');
|
|
26
|
+
}
|
|
27
|
+
get code() {
|
|
28
|
+
return this.formattingHandlers('.trix-button--icon-code', 'code');
|
|
29
|
+
}
|
|
30
|
+
get heading() {
|
|
31
|
+
return this.formattingHandlers('.trix-button--icon-heading-1', 'heading');
|
|
32
|
+
}
|
|
33
|
+
get italic() {
|
|
34
|
+
return this.formattingHandlers('.trix-button--icon-italic', 'italic');
|
|
35
|
+
}
|
|
36
|
+
get strikethrough() {
|
|
37
|
+
return this.formattingHandlers('.trix-button--icon-strike', 'strike');
|
|
38
|
+
}
|
|
39
|
+
get link() {
|
|
40
|
+
return this.formattingHandlers('.trix-button--icon-link', 'href');
|
|
41
|
+
}
|
|
42
|
+
get indents() {
|
|
43
|
+
return this.simpleHideShowHandlers([
|
|
44
|
+
".trix-button--icon-decrease-nesting-level, .trix-button--icon-increase-nesting-level",
|
|
45
|
+
".trix-button--icon-decrease-nesting-level, .trix-button--icon-increase-nesting-level",
|
|
46
|
+
].join(', '));
|
|
47
|
+
}
|
|
48
|
+
get numberList() {
|
|
49
|
+
return this.simpleHideShowHandlers('.trix-button--icon-number-list');
|
|
50
|
+
}
|
|
51
|
+
get quote() {
|
|
52
|
+
return this.simpleHideShowHandlers('.trix-button--icon-quote');
|
|
53
|
+
}
|
|
54
|
+
get fileUploads() {
|
|
55
|
+
let selector = '.trix-button-group.trix-button-group--file-tools';
|
|
56
|
+
let preventUploads = (e) => e === null || e === void 0 ? void 0 : e.preventDefault();
|
|
57
|
+
let self = this;
|
|
58
|
+
let element = this.el;
|
|
59
|
+
return {
|
|
60
|
+
install(elements) {
|
|
61
|
+
self.simpleHideShowHandlers(selector).install(elements);
|
|
62
|
+
self.el.addEventListener('trix-file-accept', preventUploads);
|
|
63
|
+
},
|
|
64
|
+
pasteEvent(event) {
|
|
65
|
+
let { dataTransfer, html } = event.paste;
|
|
66
|
+
let { editor } = element;
|
|
67
|
+
if (dataTransfer.files.length > 0 || html.includes('<img')) {
|
|
68
|
+
alert('The content you pasted contains images and/or files. File uploads are not supported.');
|
|
69
|
+
editor.undo();
|
|
70
|
+
}
|
|
71
|
+
},
|
|
72
|
+
uninstall(elements) {
|
|
73
|
+
self.simpleHideShowHandlers(selector).uninstall(elements);
|
|
74
|
+
self.el.removeEventListener('trix-file-accept', preventUploads);
|
|
75
|
+
},
|
|
76
|
+
};
|
|
77
|
+
}
|
|
78
|
+
connect() {
|
|
79
|
+
useTrixModifiers(this);
|
|
80
|
+
}
|
|
81
|
+
install(elements) {
|
|
82
|
+
this.enabledBehaviours.forEach(behaviour => behaviour.install(elements));
|
|
83
|
+
}
|
|
84
|
+
pasteEvent(event) {
|
|
85
|
+
this.enabledBehaviours.forEach(behaviour => behaviour.pasteEvent && behaviour.pasteEvent(event));
|
|
86
|
+
}
|
|
87
|
+
uninstall(elements) {
|
|
88
|
+
this.enabledBehaviours.forEach(behaviour => behaviour.uninstall(elements));
|
|
89
|
+
}
|
|
90
|
+
simpleHideShowHandlers(selector) {
|
|
91
|
+
return {
|
|
92
|
+
install: ({ toolbar }) => this.hideToolbarSelector(toolbar, selector),
|
|
93
|
+
uninstall: ({ toolbar }) => this.showToolbarSelector(toolbar, selector),
|
|
94
|
+
};
|
|
95
|
+
}
|
|
96
|
+
formattingHandlers(selector, trixAttribute) {
|
|
97
|
+
let element = this.el;
|
|
98
|
+
let { editor } = element;
|
|
99
|
+
return {
|
|
100
|
+
install: (elements) => {
|
|
101
|
+
this.simpleHideShowHandlers(selector).install(elements);
|
|
102
|
+
},
|
|
103
|
+
pasteEvent(pasteEvent) {
|
|
104
|
+
let { range } = pasteEvent.paste;
|
|
105
|
+
let prevRange = element.editor.getSelectedRange();
|
|
106
|
+
editor.setSelectedRange(range);
|
|
107
|
+
editor.deactivateAttribute(trixAttribute);
|
|
108
|
+
editor.setSelectedRange(prevRange);
|
|
109
|
+
},
|
|
110
|
+
uninstall: (elements) => {
|
|
111
|
+
this.simpleHideShowHandlers(selector).uninstall(elements);
|
|
112
|
+
},
|
|
113
|
+
};
|
|
114
|
+
}
|
|
115
|
+
showToolbarSelector(toolbar, selector) {
|
|
116
|
+
toolbar.querySelectorAll(selector).forEach(el => el.style.display = '');
|
|
117
|
+
}
|
|
118
|
+
hideToolbarSelector(toolbar, selector) {
|
|
119
|
+
toolbar.querySelectorAll(selector).forEach(el => el.style.display = 'none');
|
|
120
|
+
}
|
|
121
|
+
}
|
|
@@ -0,0 +1,65 @@
|
|
|
1
|
+
import { BaseController } from "../utilities/base_controller";
|
|
2
|
+
import { isHTMLAnchorElement } from "../utilities/elements";
|
|
3
|
+
import { isTurboFrame } from "../utilities/turbo";
|
|
4
|
+
export class TurboFrameRCController extends BaseController {
|
|
5
|
+
toggle(event) {
|
|
6
|
+
event === null || event === void 0 ? void 0 : event.preventDefault();
|
|
7
|
+
let frame = this._getFrame();
|
|
8
|
+
let frameSrc = frame.src;
|
|
9
|
+
if (frameSrc == null || frameSrc !== this._getSrc()) {
|
|
10
|
+
this._setSrc();
|
|
11
|
+
}
|
|
12
|
+
else {
|
|
13
|
+
this._clear();
|
|
14
|
+
}
|
|
15
|
+
}
|
|
16
|
+
setSrc(event) {
|
|
17
|
+
event === null || event === void 0 ? void 0 : event.preventDefault();
|
|
18
|
+
this._setSrc();
|
|
19
|
+
}
|
|
20
|
+
clear(event) {
|
|
21
|
+
event === null || event === void 0 ? void 0 : event.preventDefault();
|
|
22
|
+
this._clear();
|
|
23
|
+
}
|
|
24
|
+
_setSrc() {
|
|
25
|
+
let frame = this._getFrame();
|
|
26
|
+
if (this.hasLoadingMessageValue) {
|
|
27
|
+
frame.innerHTML = this.loadingMessageValue;
|
|
28
|
+
}
|
|
29
|
+
frame.src = this._getSrc();
|
|
30
|
+
}
|
|
31
|
+
_clear() {
|
|
32
|
+
let frame = this._getFrame();
|
|
33
|
+
frame.src = "";
|
|
34
|
+
frame.innerHTML = "";
|
|
35
|
+
}
|
|
36
|
+
_getFrame() {
|
|
37
|
+
let frame = document.getElementById(`${this.frameIdValue}`);
|
|
38
|
+
if (frame == null) {
|
|
39
|
+
throw new Error(`Could not find frame with ID '${this.frameIdValue}'`);
|
|
40
|
+
}
|
|
41
|
+
if (!isTurboFrame(frame)) {
|
|
42
|
+
throw new Error(`Element targeted by ID '${this.frameIdValue}'`);
|
|
43
|
+
}
|
|
44
|
+
else {
|
|
45
|
+
return frame;
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
_getSrc() {
|
|
49
|
+
let element = this.el;
|
|
50
|
+
if (this.hasSrcValue) {
|
|
51
|
+
return this.srcValue;
|
|
52
|
+
}
|
|
53
|
+
else if (isHTMLAnchorElement(element)) {
|
|
54
|
+
return element.href;
|
|
55
|
+
}
|
|
56
|
+
else {
|
|
57
|
+
throw new Error("No link given to drive frame to");
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
TurboFrameRCController.values = {
|
|
62
|
+
frameId: String,
|
|
63
|
+
src: String,
|
|
64
|
+
loadingMessage: String,
|
|
65
|
+
};
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
import { BaseController } from "../utilities/base_controller";
|
|
2
|
+
import { isTurboFrame } from "../utilities/turbo";
|
|
3
|
+
import { useTimeout } from "../mixins/use_timeout";
|
|
4
|
+
// noinspection SillyAssignmentJS
|
|
5
|
+
export class TurboFrameRefreshController extends BaseController {
|
|
6
|
+
get _poll() {
|
|
7
|
+
return this.hasPollValue ? this.pollValue : false;
|
|
8
|
+
}
|
|
9
|
+
connect() {
|
|
10
|
+
let element = this.el;
|
|
11
|
+
if (isTurboFrame(element)) {
|
|
12
|
+
if (!!element.src) {
|
|
13
|
+
throw new Error('The provided <turbo-frame> element has no `src` attribute.');
|
|
14
|
+
}
|
|
15
|
+
}
|
|
16
|
+
else {
|
|
17
|
+
throw new Error('Expected controller to be mounted on a <turbo-frame> element.');
|
|
18
|
+
}
|
|
19
|
+
if (this._poll) {
|
|
20
|
+
requestAnimationFrame(() => useTimeout(this, this.refresh, this.intervalValue));
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
refresh(event) {
|
|
24
|
+
event === null || event === void 0 ? void 0 : event.preventDefault();
|
|
25
|
+
let element = this.el;
|
|
26
|
+
element.src = element.src;
|
|
27
|
+
}
|
|
28
|
+
}
|
|
29
|
+
TurboFrameRefreshController.values = {
|
|
30
|
+
interval: Number,
|
|
31
|
+
poll: Boolean,
|
|
32
|
+
};
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import { BaseController } from "../../utilities/base_controller";
|
|
2
|
+
import { useFullscreen } from "../../mixins";
|
|
3
|
+
export class FullscreenController extends BaseController {
|
|
4
|
+
connect() {
|
|
5
|
+
let { enter, exit, toggle } = useFullscreen(this);
|
|
6
|
+
this.enter = enter;
|
|
7
|
+
this.exit = exit;
|
|
8
|
+
this.toggle = toggle;
|
|
9
|
+
}
|
|
10
|
+
}
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
import { BaseController } from "../../utilities/base_controller";
|
|
2
|
+
import { useIntersection } from "../../mixins/use_intersection";
|
|
3
|
+
import { dispatchEvent } from "../../utilities/events";
|
|
4
|
+
export class IntersectionController extends BaseController {
|
|
5
|
+
get _threshold() {
|
|
6
|
+
if (this.hasThresholdValue) {
|
|
7
|
+
return this.thresholdValue.split(',').map(val => Number.parseFloat(val.trim())).filter(val => val >= 0 && val <= 1);
|
|
8
|
+
}
|
|
9
|
+
else {
|
|
10
|
+
return [0, 1];
|
|
11
|
+
}
|
|
12
|
+
}
|
|
13
|
+
connect() {
|
|
14
|
+
useIntersection(this, this.el, this.appear, this.disappear, { threshold: this._threshold });
|
|
15
|
+
}
|
|
16
|
+
appear(entry) {
|
|
17
|
+
dispatchEvent(this, this.el, "intersection:appear");
|
|
18
|
+
}
|
|
19
|
+
;
|
|
20
|
+
disappear(entry) {
|
|
21
|
+
dispatchEvent(this, this.el, "intersection:disappear");
|
|
22
|
+
}
|
|
23
|
+
;
|
|
24
|
+
}
|
|
25
|
+
IntersectionController.values = { threshold: String };
|