cookie

We use cookies to improve your browsing experience. By clicking «Accept all», you agree to the use of cookies.

avatar

Sleepless tech

DIY, web, coffee Автоматизирую все и вся, ремонтирую что сломалось, трачу время на just-for-fun проекты. Пишу про хардвар и софтвар и не только. http://jem-space.ru Связь со мной: @jem_jem Донаты на припой и хостинги: https://bit.ly/2MKcRoJ

Show more
Advertising posts
723
Subscribers
No data24 hours
+17 days
+330 days

Data loading in progress...

Subscriber growth rate

Data loading in progress...

Photo unavailableShow in Telegram
👾 6🔥 3
Всем привет. На днях столкнулся с задачей, что при отправкt формы с типом multipart/form-data нужно было добавить отдельные заголовки для каждого файла из формы. Задача немного нестандартная и как средствами клиентского JS ее решить не сразу понятно. В rtk-query и axios такой конфигурации не нашел, как и в клиентском FormData. В интернете гуглится мало инфы и часто встречается решение с использованием пакета form-data (но он для node). Глядя в Network, видно, что браузер сам добавляет Content-Disposition и Content-Type. В спецификации же к http написано, что можно добавлять отдельные заголовки для полей. В итоге выход один - генерить руками тело запроса и преобразовывать его в Blob. Генерим заголовки как текст, добавляем 2 пустые сроки, преобразуем в blob и добавляем в массив. Затем преобразуем файл в blob и добавляем в массив. И так со всеми файлами. Не забываем разделить поля при помощь boundery типа ----WebKitFormBoundary{random_string} Из всех блобов делаем один общий

    type: `multipart/form-data; boundary=${boundary}`,
  });
И отправляем нахуй Спасибо чатгпт за алгоритм (я бы охерел это руками писать). Chrome кстати говорит, что это пустая FormData, но бекенд успешно сохраняет файлы из запроса.
Show all...
npm: form-data

A library to create readable "multipart/form-data" streams. Can be used to submit forms and file uploads to other web applications.. Latest version: 4.0.0, last published: 3 years ago. Start using form-data in your project by running `npm i form-data`. There are 9828 other projects in the npm registry using form-data.

🔥 6🤯 1😎 1
Photo unavailableShow in Telegram
Привет! Давно слышал, что на айфонах с 13 версии появился лидр, с помощью которого можно сканить 3D объекты. Находил инфу, что точность у него 0.3 мм, так что многообещающе. Все хотел попробовать. Появилась возможность поиграть с ним, и в результате немного разочарован. Чтобы получить нормальную модельку, видимо, нужно нормально поплясать (либо просто руки попрямее) Снимал на scaniverse.
Show all...
🦄 4
Autodesk Fusion 360 for personal use Сохраню ссылку на бесплатную версию Fusion 360 для личного использования. При поиске на сайте эту версию что-то особо не предлагают, а из гугла - доступна по первой ссылке. Работает, правда, только при регистрации через vpn. https://www.autodesk.com/products/fusion-360/personal
Show all...
Compare Autodesk Fusion vs Autodesk Fusion for Personal Use | Autodesk

Compare features and functionality between Autodesk Fusion for personal use and Autodesk Fusion, formerly known as Fusion 360, and learn which CAD, CAM, CAE and PCB software is the right solution for you.

❤‍🔥 5
Привет! Вчера был мой последний рабочий день в компании 😢 В Артезио проработал почти 7 лет, а на проекте Партнёрского кабинета почти 6. Есть повод немного порефлексировать (интересно, скорее всего, не будет, но зафиксировать нужно). В компанию пришел неокрепшим мидлом с заниженной самооценкой, т к на своем первом проекте прилично отхватывал от лида и получал фидбеки ниже среднего (в чем есть и моя вина, потому что качество кода было сомнительное). В Артезио я попал на проект Партнёрского кабинета Альфа-Банка, который нужно было писать с нуля. Для меня это был интересный опыт, т к никогда еще я не был на начальных этапах проектов. Прикольно ощущать, что клиенты начинают пользоваться абсолютно новым продуктом, и ты приложил руку к тому, с чем они взаимодействуют. За время проекта у нас были ежегодные аттестации и сборы фидбека, на которых мне прилетали нормальные оценки (что сначала было странно для меня). Так я почувствовал немного больше уверенности в себе. Здесь, конечно, скрывалась одна из проблем - я начал клепать код без критического взгляда на него. Не то чтобы я не думал над оптимизацией функций, но вот гибкости и чистоты не хватало. Был некий флоу по разработке фич в основе которого была react-redux архитектура. Есть компоненты, они вызывают экшены, в которых выполняются запросы к мидлу, результат кладется в стор и все работает. Бизнес логика размазана по всему приложению… Вопросы архитектуры меня волновали и тогда, но ответов на них особо не находил (про выделение бизнес логики, clean и feature-sliced я узнал года 3-4 назад). Да и думать честно говоря было некогда - нужно было быстро наращивать функционал приложения. Работали мы без особого планирования и спринтов, просто брали приоритетные задачи в разработку и старались сделать быстро. Но, замечу, без овертаймов! Здесь крылась вторая проблема - нет времени на тесты. При оценке задач я всегда ориентировался только на этап разработки (+ багфикс) и забывал про тесты. Точнее я все думал, что надо когда нибудь попросить времени на них, но времени не было. Только потом я понял/узнал что продать бизнесу тесты невозможно. Их нужно изначально закладывать в оценку. Третья проблема близка ко второй - отсутствие документации. По тестам можно понять как должен работать тот или иной процесс. Но можно вести документацию в той же конфлюенс. Мы этого не делали. На тот момент, как и что должно работать знал наш ПО + тестировщик, ну и разрабы, которые имплементили фичи. В какой то момент ПО ушел и частенько у нас начали сыпаться вопросы "А это всегда так работало или это баг?", ответить на которые мы могли только покопавшись в коде. В какой-то момент обороты по реализации фич поутихли и проблемы кодовой базы уже не списать на то, что тебя торопили. По мере возможности я старался привести очевидные WTF части к нормальному виду. Особенно после того, как подумал, что если буду уходить с проекта, передавать его в таком виде оч стыдно. Это прям стало реальным мотиватором к тому, чтобы писать лучше. Да и вообще пришло осознание (хотя и поздно), что если ты один фронт, то этот репозиторий чисто твой проект и ты за все в ответе. За то, что у проекта нет нормального Read.me, за то что там до сих пор 4 версия react-router, древний redux без хуков и 4 вебпак. ▫️Многое удалось поправить, а то что не удалось - вроде работает и жалоб нет (надеюсь, кек) ▫️Начал вести документацию по разработке на конфлюенс. ▫️Попробовал подход чистой архитектуры для фронтенда (понял что на самом деле тяжело и долго и не всегда нужно), решил что выделение моделей, функций бизнес логики, прикладного слоя и адаптеров в принципе достаточно. ▫️Перестал забивать на линтер А вообще, на проекте была классная отзывчивая команда и хорошо отлаженные процессы. За все время не овертаймили ни разу. Компетенции внутри команды хватало, чтобы решать почти все проблемы проекта. В банке за это время уже появились свои стандарты разработки по фронту, которые помогают не свернуть на скользкую дорожку "сделать побыстрее и в прод". Короче, классный опыт. Что-то из него вынес. Посмотрим, что будет дальше 😅
Show all...
❤‍🔥 8👍 4🎉 1
00:09
Video unavailableShow in Telegram
Как побороть сдвиг сайта из-за появление скрола Недавно увидел потрясающий CSS хак как компенсировать сдвиг сайта, когда у вас появляется скролл на странице. Вся верстка будто прыгает, появлется так называемый CLS – content layout shift. Нехорошо. Глаз раздражает и приводит к мискликам (смотри комментарии к посту). А хак до жути простой:

padding-left: calc(100vw - 100%); // 15px 
100vw – ширина всей страницы с учетом скролбара 100% – ширина страницы без учета скролбара Вычитаем и получаем заветные 15px, когда скролл есть и 0px, когда его нет. А дальше добавляем куда вам нужно – будь это padding, margin, top, left или еще чего. Просто и гениально. А пост пишу, потому что удалось сразу проверить в проде как оно работает. Весь дифф до и после компенсации видно на видео. Не забывайте про мелочи (а тем более про CLS) и тогда сайтом будет действительно приятно пользоваться. @dlents
Show all...
🔥 5👍 2 2
Photo unavailableShow in Telegram
Надеюсь, это именно та разметка, которую они хотели видеть в поисковике)
Show all...
😁 8👀 1
Ладно, вот вам задачка. Есть 2 стула пакета в node_modules, которые использую третий как зависимость. Но в зависимостях он разной версии. Один пакет нормально резолвит его. Второй же пытается найти его в общих node_modules, вместо своих внутренних (хотя во внутренних он есть). Какие есть варианты, чтобы донести до второго пакета, что нужно резолвить его из внутренних модулей? Если поставить этот пакет в общие модули, сломаются импорты первого пакета 🤯 Пробовал resolutions в package.json - не помогло. Пока рабочее решения - поправить руками импорты и накатывать патч на postinstall через patch-package.
Show all...
npm: patch-package

Fix broken node modules with no fuss. Latest version: 8.0.0, last published: 7 months ago. Start using patch-package in your project by running `npm i patch-package`. There are 863 other projects in the npm registry using patch-package.

Photo unavailableShow in Telegram
Дарова! Щас развоняюсь как дед. Github ввел двухфакторную аутентификацию. И теперь как дед пытаюсь разобраться с какими то санными аутентификаторами. Либо ставь какую то херню на телефон или комп либо расширение для хрома. Отправить мне код на почту они блядь не могут, а смс естественно в Россию не доходят. Ну это ладно, но то что он предлагают это мать его платные решения типа 1Password. Плати 2 доллара в месяц чтобы логиниться на сайт. Алооо, вы там ох*ели? Либо приложение от Копрософта с битой ссылкой на установку. Ладно, мож я че не так понял. Пойду разбираться) Если кто уже понял как сделать чтоб нормально было, черканите деду)
Show all...
🙈 4👏 1🤝 1
Repost from UX Live 🔥
02:01
Video unavailableShow in Telegram
Когда посмотрел уже все на порнхабе и придумал собственный жанр
Show all...
5😁 3🔥 1🤡 1