Команда Laravel нещодавно представила суттєві оновлення для Laravel Echo — JavaScript-бібліотеки для трансляції подій в реальному часі.
По-перше, вдосконалено процес встановлення. Тепер, запустивши команду install:broadcasting в Artisan, ви отримаєте запит на введення необхідних даних, а відповідні змінні .env автоматично будуть внесені у систему.
По-друге, додано хук useEcho для React та Vue. Він спростить прослуховування подій та автоматичне відключення від каналів у потрібний момент. Наприклад, у Vue:
<script setup lang="ts">
import { useEcho } from "@laravel/echo-vue";
useEcho(
`orders.${orderId}`,
"OrderShipmentStatusUpdated",
(e) => {
console.log(e.order);
},
);
</script>
Тепер стало простіше прослуховувати події моделей за допомогою нового хуку useEchoModel, який також забезпечує типобезпеку.
<script setup lang="ts">
import { useEchoModel } from "@laravel/echo-vue";
useEchoModel("App.Models.User", userId, ["UserUpdated"], (e) => {
console.log(e.model);
});
</script>
Наостанок, додано можливість вказувати структуру даних події, що підвищує типобезпеку та автозаповнення.
type User = {
id: number;
name: string;
email: string;
};
useEchoModel<User, "App.Models.User">("App.Models.User", userId, ["UserUpdated"], (e) => {
console.log(e.model.id);
console.log(e.model.name);
});
Дізнайтеся більше про ці покращення та інші нововведення, ознайомившись з оновленою документацією з трансляції
Laravel пропонує зручні методи для роботи з датами, які значно спрощують запити до бази даних. Досліджуйте, як ці інтуїтивно зрозумілі функції допомагають створювати чіткі та зрозумілі умови для роботи з часовими даними!
Ви хочете навчитися, як інтегрувати Google OAuth у вашому проекті Laravel, використовуючи Socialite? Дізнайтеся, як налаштувати доступ до сервісів Google, таких як Календар, у нашій сьогоднішній статті
Зазирніть у світ Laravel, де потужний CLI-фреймворк відкриває нові можливості для розробки командного інтерфейсу. Дізнайтеся, як створити просту утиліту для перевірки акцій, яка працює з Docker, та які переваги це може принести у вашому проєкті!