Хотите расти как разработчик и найти крутую работу? Не протирайте штаны — займитесь Open Source проектами. Так легче всего попасть в лучшие команды разработчиков и положить себе в резюме настоящий проект, вместо нелепых «примеров кода». Но найти подходящий проект для участия сложно. Начинаются лень и отговорки, а за ними — отсутствие профессионального роста, критики по-настоящему крутых программистов, уныние и застой.
На Cult of Martians мы собираем интересные задачи для современных веб-программистов. Можно выбрать подходящую по сложности, продолжительности и специализации. Задачи не выдуманы «из воздуха» — каждая решает насущную проблему, и решить ее можно через создание нового Open Source проекта или улучшение существующего. Решайте задачи, прокачивайтесь, присылайте решение на оценку. Лучших могут пригласить к себе на работу компании, программистам которых понравится ваше решен ие.
Для новичков, задача на пару дней
KeyUX добавляет на сайт обработку событий с клавиатуры, чтобы пользоваться сайтом с клавиатуры было удобнее.
Например, он добавляет для списков с role="menu"
(табы, меню навигации) навигацию стрелочками. Так, вместо огромного списка для Tab-навигации, у нас выделяются изолированные блоки, между которыми мы перемещаемся Tab-ом, а внутри — стрелочками.
Но такая навигация нужна не только role="menu"
, но и многим другим role
(но у каждой немного отличается поведение, будьте внимательны).
Польза: строка в резюме, которая показывает знание технологий доступности в веб-разработке.
menuKeyUX
в focusGroupKeyUX
. Заменить все связанные файлы.role="menubar"
. У нее по умолчанию другая ориентация (горизонтальная).role="listbox"
.role="tablist"
. Для нее не нужно делать поиск по мере ввода. И не нужно реализовывать aria-multiselectable
. У нее другая ориентация, по умолчанию (горизонтальная).role="toolbar"
. В отличие от role="menu"
у нее нет специальной role
для детей. И у нее другая ориентация, по умолчанию (горизонтальная).pnpm size-limit
и обновить размер в size-limit
в package.json
.