// If you want to use Phoenix channels, run `mix help phx.gen.channel` // to get started and then uncomment the line below. // import "./user_socket.js" // You can include dependencies in two ways. // // The simplest option is to put them in assets/vendor and // import them using relative paths: // // import "../vendor/some-package.js" // // Alternatively, you can `npm install some-package --prefix assets` and import // them using a path starting with the package name: // // import "some-package" // // Include phoenix_html to handle method=PUT/DELETE in forms and buttons. import "phoenix_html" // Establish Phoenix Socket and LiveView configuration. import {Socket} from "phoenix" import {LiveSocket} from "phoenix_live_view" import topbar from "../vendor/topbar" let csrfToken = document.querySelector("meta[name='csrf-token']").getAttribute("content") // Hooks for LiveView components let Hooks = {} // ComboBox hook: Prevents form submission when Enter is pressed in dropdown Hooks.ComboBox = { mounted() { this.handleKeyDown = (e) => { const isDropdownOpen = this.el.getAttribute("aria-expanded") === "true" if (e.key === "Enter" && isDropdownOpen) { e.preventDefault() } } this.el.addEventListener("keydown", this.handleKeyDown) }, destroyed() { this.el.removeEventListener("keydown", this.handleKeyDown) }, }; // MemberSortPersistence hook: Persists sorting order to a cookie Hooks.MemberSortPersistence = { mounted() { this.handleEvent("persist_sort", ({ sort_field, sort_order }) => { const setCookie = (name, value) => { const secure = window.location.protocol === "https:" ? "Secure" : ""; document.cookie = `${name}=${encodeURIComponent( value )}; path=/; SameSite=Lax; ${secure}`; }; setCookie("member_sort_field", sort_field); setCookie("member_sort_order", sort_order); }); }, }; // Helper to read and decode cookie value const getCookie = (name) => { const value = `; ${document.cookie}`; const parts = value.split(`; ${name}=`); if (parts.length === 2) { return decodeURIComponent(parts.pop().split(";").shift()); } return null; }; let liveSocket = new LiveSocket("/live", Socket, { longPollFallbackMs: 2500, params: () => { return { _csrf_token: csrfToken, member_sort_field: getCookie("member_sort_field"), member_sort_order: getCookie("member_sort_order"), }; }, hooks: Hooks, }); // Listen for custom events from LiveView window.addEventListener("phx:set-input-value", (e) => { const {id, value} = e.detail const input = document.getElementById(id) if (input) { input.value = value } }) // Show progress bar on live navigation and form submits topbar.config({barColors: {0: "#29d"}, shadowColor: "rgba(0, 0, 0, .3)"}) window.addEventListener("phx:page-loading-start", _info => topbar.show(300)) window.addEventListener("phx:page-loading-stop", _info => topbar.hide()) // connect if there are any LiveViews on the page liveSocket.connect() // expose liveSocket on window for web console debug logs and latency simulation: // >> liveSocket.enableDebug() // >> liveSocket.enableLatencySim(1000) // enabled for duration of browser session // >> liveSocket.disableLatencySim() window.liveSocket = liveSocket