glebmachine / until-destroy

Наброс на управление отписками путем подкапотной магии

Geek Repo:Geek Repo

Github PK Tool:Github PK Tool

⚠ Важно, этот наброс еще не обкатан, с осторожностью используйте его в продакшене (а лучше вообще не используйте)! Не показывайте детям, впечатлительным людям, больным эпилепсией, кормящим матерям и беременным женщинам.

Еще один наброс на автоотписки 😅

untilDestroyed(this)- просто бери и пользуйся, никакого бойлерплейта и ограничений 🐱‍🏍.

На самом деле нет, ввиду подкапотной специфики angular'a, с сервисами он требует UntilDestroy декоратора, но, опустим эту частность)

Зачем ты это сделал?

Да, есть минимум пяток хороших реализацией, и еще каждый наворачивает свои собственные. Но, каждая из реализаций говорит: возьми декоратор и\или имплементируй интерфейс, и это вот все еще не безопасно в плане типизации: ты должен держать в голове то, что нужно декоратор поставить, стрим обьявить, дать ему правильный тип (самостоятельно). Если же речь о декораторе на свойстве класса, то тип ты опять же ставишь самостоятельно. Другими словами - много что нужно держать в голове и не ошибаться.

Надоело, хочется по-человечески: нужен оператор, использую оператор, все остальное - долнжо как-то само магически отруливаться где-то под капотом. Другими словами - хочу DX, не хочу думать.

Какие потенциальные проблемы могут возникнуть у тех кто решиться?

Проблемы могут возникнуть при мажорных обновлениях, если команда angular'а решит перелопатить реализацию рендерера (опять, но в этом случае думаю сломается большинство либ, как всегда). Либо, если уберут ngContext у компонента\директивы (у сервиса к примеру они его не подмешивают в экземпляр, и эта та самая причина почему я не могу дотянуться до кишочек и зарегать ngOnDestroy в рантайме для сервиса, как я смог это сделать для компонента)

Какому дизайну ты следовал?

Нет никакого большого дизайна. Есть потребность, чтобы_работало, вот оно и работает.

Как ты тестировал?

Автотестами ничего не покрыто. В репе лежит прилага, которая позволяет руками потестить как ведут себя сервисы компоненты и директивы и под капотом есть пару переменных, что содержат статусы. Все тестируется ручками

Если кому-то очень захочется - будут рад если покроете тестами. Тест кейсы описать помогу

P.S

Либа специально не выложена в npm, а реп тут лежит скорее для того, чтобы продолжать в нем ее разрабатывать. Когда я пойму что есть потребность и она готова - сделаю пакет

About

Наброс на управление отписками путем подкапотной магии


Languages

Language:TypeScript 87.7%Language:JavaScript 8.3%Language:HTML 3.7%Language:CSS 0.2%