https
NADCAST.03 Ρ Π Π°Π΄ΠΎ ΠΠ΅ΠΎΡΠ³ΠΈΠ΅Π²
Π’ΡΠ΅ΡΠΈ Π΅ΠΏΠΈΠ·ΠΎΠ΄ Π½Π° "NADCAST". Π’ΠΎΠ·ΠΈ ΠΏΡΡ ΡΡΡ Π Π°Π΄ΠΎ ΠΠ΅ΠΎΡΠ³ΠΈΠ΅Π². Π Π°Π΄ΠΎ ΠΏΡΠ΅ΠΏΠΎΠ΄Π°Π²Π° ΠΈ ΠΏΡΠΎΠ³ΡΠ°ΠΌΠΈΡΠ° ΠΈ ΠΊΠΎΠΌΠΏΠ°Π½ΠΈΡ Π΄Π²ΠΈΠΆΠΈ ΠΈ ΠΊΠΎΠ½ΡΠ΅ΡΠ΅Π½ΡΠΈΡ ΠΎΡΠ³Π°Π½ΠΈΠ·ΠΈΡΠ° ΠΈ ΠΎΡΠ΅ ΠΊΠ°ΠΊΠ²ΠΎ Π»ΠΈ Π½Π΅. ΠΠΎΠ³ΠΎΠ²ΠΎΡΠΈΡ ΠΌΠ΅ ΡΠΈ Π·Π° Π΄ΠΎΡΡΠ° Π½Π΅ΡΠ° ΠΈ Π΅ ΡΡΡΠ΄Π½ΠΎ Π΄Π° Π³ΠΈ ΠΈΠ·Π±ΡΠΎΡ ΡΡΠΊ. Π’Π° ΠΈΠ·ΡΠ»ΡΡΠ°ΠΉΡΠ΅ Π³ΠΎ ΡΠ΅Π»ΠΈΡ Π΅ΠΏΠΈΠ·ΠΎΠ΄ :)
NADCAST.06 with Cole Peters
Episode 6 of my podcast with Cole Peters. We had a nice chat about the good old days, designing for web and CSS.
NADCAST.07 with Kent C. Dodds
Episode 7 of my podcast with Kent C. Dodds. We had a nice chat about open source, teaching, React and Prettier.
NADCAST.09 Ρ Π Π°Π΄ΠΎ Π‘ΡΠ°Π½ΠΊΠΎΠ²
ΠΠΏΠΈΠ·ΠΎΠ΄ 9 Π½Π° NADCAST Π΅ Ρ Π Π°Π΄ΠΎ Π‘ΡΠ°Π½ΠΊΠΎΠ². ΠΡΠ½ΠΎΠ²Π½ΠΎ ΡΠΈ ΠΏΠΎΠ³ΠΎΠ²ΠΎΡΠΈΡ ΠΌΠ΅ Π·Π° React ΠΈ Π½Π°ΡΡΠΌΠ΅Π»ΠΈΡΠ΅ ΠΎΠΊΠΎΠ»ΠΎ Π±ΠΈΠ±Π»ΠΈΠΎΡΠ΅ΠΊΠ°ΡΠ° ΡΠ΅ΠΌΠΈ. ΠΡΠΈΡΡΠ½ΠΎ ΡΠ»ΡΡΠ°Π½Π΅ :)
NADCAST.12 Ρ ΠΠΈΠΌΠΈΡΡΡ ΠΠΈΠΌΠΈΡΡΠΎΠ²
ΠΠΏΠΈΠ·ΠΎΠ΄ Π½ΠΎΠΌΠ΅Ρ 12 Π΅ Ρ ΠΠΈΠΌΠΈΡΡΡ ΠΠΈΠΌΠΈΡΡΠΎΠ² (ΠΠΈΡΡΠΎ). ΠΠΎΠ³ΠΎΠ²ΠΎΡΠΈΡ ΠΌΠ΅ ΡΠΈ Π·Π° ΠΌΠ΅Π½ΡΠΎΡΡΡΠ²ΠΎΡΠΎ ΠΈ Π·Π° ΡΠΎΠ²Π° ΠΊΠ°ΠΊ ΡΡΡΠ±Π²Π° Π΄Π° ΡΠ΅ ΠΏΠΎΠ΄Ρ ΠΎΠΆΠ΄Π° ΠΊΡΠΌ Π½Π°ΡΠΈΠ½Π°Π΅ΡΠΈΡΠ΅ ΠΏΡΠΎΠ³ΡΠ°ΠΌΠΈΡΡΠΈ. ΠΠΌΠ°ΡΠ΅ ΠΈ ΠΌΠ°Π»ΠΊΠΎ DevOps Π΄Π°ΠΆΠ΅ :)
NADCAST.13 Ρ Π Π°Π΄ΠΎ Π‘ΡΠ°Π½ΠΊΠΎΠ²
Π€Π°ΡΠ°Π»Π½ΠΈΡΡ Π΅ΠΏΠΈΠ·ΠΎΠ΄ 13 Π½Π° NADCAST Π΅ Ρ ΠΌΠΎΡ Π΄ΠΎΠ±ΡΠ΅ ΠΏΠΎΠ·Π½Π°Ρ ΡΡΠ±Π΅ΡΠ΅Π΄Π½ΠΈΠΊ Π Π°Π΄ΠΎ Π‘ΡΠ°Π½ΠΊΠΎΠ². ΠΡΠ½ΠΎΠ²Π½Π° ΡΠ΅ΠΌΠ° Π½Π° Π½Π°ΡΠΈΡ ΡΠ°Π·Π³ΠΎΠ²ΠΎΡ Π±Π΅ΡΠ΅ Π½ΠΎΠ²Π°ΡΠ° Π²Π΅ΡΡΠΈΡ Π½Π° React ΠΈ ΠΏΡΠ΅Π΄ΡΡΠΎΡΡΠΈΡΠ΅ React.NotAConf (http://react-not-a-conf.com/) ΠΈ Bulgaria Web Summit (https://bulgariawebsummit.com/) ΠΊΠΎΠ½ΡΠ΅ΡΠ΅Π½ΡΠΈΠΈ.
NADCAST.14 ΡΡΡ Π‘ΡΠ΅ΡΠ°Π½ ΠΡΠ½Π΅Π² ΠΈ ΠΠΈΠΌΠΈΡΡΡ ΠΠΈΠΌΠΈΡΡΠΎΠ²
Π‘ΡΠ΅ΡΠ°Π½ ΠΈ ΠΠΈΡΡΠΎ ΡΠΏΠΎΠ΄Π΅Π»ΠΈΡ Π° ΡΠΎΠ»ΠΈΠ΄Π½ΠΈ ΠΏΡΠ°ΠΊΡΠΈΠΊΠΈ ΠΈ ΠΎΠΏΠΈΡ Π² ΠΌΠ΅Π½ΡΠΎΡΠΈΡΠ°Π½Π΅ΡΠΎ Π½Π° ΠΏΠΎ-Π½Π°ΡΠΈΠ½Π°Π΅ΡΠΈ ΠΏΡΠΎΠ³ΡΠ°ΠΌΠΈΡΡΠΈ. ΠΠ°Π΄ΡΠ²Π°ΠΌ ΡΠ΅ ΡΠΎΠ·ΠΈ 14-ΡΠΈ Π΅ΠΏΠΈΠ·ΠΎΠ΄ Π΄Π° Π²ΠΈ Π±ΡΠ΄Π΅ ΠΏΠΎΠ»Π΅Π·Π΅Π½ Π½Π΅Π·Π°Π²ΠΈΡΠΈΠΌΠΎ Π½Π° ΠΊΠ°ΠΊΠ²ΠΎ Π½ΠΈΠ²ΠΎ ΡΡΠ΅.
MP3: http://nadcast.krasimirtsonev.com/StefanKanev_DimitarDimitrov.mp3
NADCAST.16 Ρ ΠΠ»Π°Π΄ΠΈΠΌΠΈΡ ΠΠΎΠ½ΡΡΠ»ΠΈΠ΅Π²
ΠΠ½ΠΎΠ³ΠΎ ΡΠ΅Π½Π΅Π½ ΡΠ°Π·Π³ΠΎΠ²ΠΎΡ Ρ ΠΠ»Π°Π΄ΠΎ ΡΠ΅ ΠΏΠΎΠ»ΡΡΠΈ. Π ΡΠΎΠ·ΠΈ 16-ΡΠΈ Π΅ΠΏΠΈΠ·ΠΎΠ΄ Π΄ΠΈΡΠΊΡΡΠΈΡΠ°ΠΌΠ΅ code review ΠΏΡΠΎΡΠ΅ΡΠΈ, Π½Π°Π²ΠΈΡΠΈ, ΠΌΠΎΡΠΈΠ²Π°ΡΠΈΡ ΠΈ ΠΊΠ°ΡΠΎ Π·Π° ΡΠΈΠ½Π°Π» ΠΌΠ°Π»ΠΊΠΎ Π·Π° Π±Π°Π»Π°Π½ΡΠ° Π² Π½Π°ΡΠ°ΡΠ° ΠΏΡΠΎΡΠ΅ΡΠΈΡ. ΠΠ°Π΄ΡΠ²Π°ΠΌ ΡΠ΅ Π΄Π° Π²ΠΈ Ρ Π°ΡΠ΅ΡΠ°.
NADCAST.17 Ρ Π Π°Π΄ΠΎ Π‘ΡΠ°Π½ΠΊΠΎΠ²
Π‘Π»Π΅Π΄ Π΄ΡΠ»Π³Π°ΡΠ°, ΠΏΠΎΡΡΠΈ Π΄Π²Π° ΠΌΠ΅ΡΠ΅ΡΠ° ΠΏΠ°ΡΠ·Π°, Π΅ΠΏΠΈΠ·ΠΎΠ΄ 17 Π½Π° NADCAST Π΅ Ρ Π Π°Π΄ΠΎ Π‘ΡΠ°Π½ΠΊΠΎΠ². ΠΠ°ΠΏΠΎΡΠ½Π°Ρ ΠΌΠ΅ Ρ Π½ΡΠΊΠΎΠΈ ΠΌΠ½ΠΎΠ³ΠΎ ΠΈΠ½ΡΠ΅ΡΠ΅ΡΠ½ΠΈ Π½ΠΎΠ²ΠΈΠ½ΠΈ ΠΊΠ°ΡΠΎ ΠΏΡΠ΅Π΄ΡΡΠΎΡΡΠΈΡ NotAHackathon ΠΈ VarnaConf. Π‘Π»Π΅Π΄ ΡΠΎΠ²Π° ΡΠΈ ΠΏΠΎΠ³ΠΎΠ²ΠΎΡΠΈΡ ΠΌΠ΅ Π·Π° ΡΠ°Π·Π»ΠΈΡΠ½ΠΈΡΠ΅ ΠΏΠΎ Π²ΠΈΠ΄ ΡΠ°Π±ΠΎΡΠ½ΠΈ ΡΡΠ΅Π΄ΠΈ. ΠΡΠ΅Π· freelancer-ΡΡΠ²ΠΎΡΠΎ Π΄ΠΎ ΡΠ°Π±ΠΎΡΠ°ΡΠ° Π² ΠΏΡΠΎΠ΄ΡΠΊΡΠΎΠ²Π° ΠΊΠΎΠΌΠΏΠ°Π½ΠΈΡ.
NADCAST.18 with Sara Vieira
This episode is with Sara Vieira. She is doing a lot of interesting things with React, GraphQL, Apollo and with JavaScript in general. She's also part of bunch of conferences doing talks and workshops which itself is a big challenge. Happy listening :)
NADCAST.19 Ρ Π Π°Π΄ΠΎ Π‘ΡΠ°Π½ΠΊΠΎΠ² ΠΈ ΠΠΈΠ½ΠΊΠΎ ΠΠ΅Π½ΡΠ΅Π²
ΠΡΠΎ Π΅Π΄ΠΈΠ½ ΠΌΠ°Π»ΡΠΊ ΠΊΠΎΠ»Π΅Π΄Π΅Π½ ΠΏΠΎΠ΄Π°ΡΡΠΊ - Π΅ΠΏΠΈΠ·ΠΎΠ΄ Π½ΠΎΠΌΠ΅Ρ 19 Π½Π° NADCAST. ΠΠΎΡΠ»Π΅Π΄Π½ΠΈΡΠ΅ Π½ΡΠΊΠΎΠ»ΠΊΠΎ ΠΌΠ΅ΡΠ΅ΡΠ° ΡΡΠΌ Π½Π° Π²ΡΠ»Π½Π° ΠΏΡΠΎΠ΄ΡΠΊΡΠΈΠ²Π½ΠΎΡΡ. Π‘ Π Π°Π΄ΠΎ Π‘ΡΠ°Π½ΠΊΠΎΠ² ΠΈ ΠΠΈΠ½ΠΊΠΎ ΠΠ΅ΡΠ΅Π² ΡΠΈ ΠΏΠΎΠ³ΠΎΠ²ΠΎΡΠΈΡ ΠΌΠ΅ Π·Π° TEA framework. ΠΠ»ΠΈ ΠΊΠ°Π·Π°Π½ΠΎ ΠΏΠΎ Π΄ΡΡΠ³ Π½Π°ΡΠΈΠ½, ΠΊΠ°ΠΊ Π΄Π° Π½Π°ΠΌΠ΅ΡΠΈΠΌ ΠΏΠΎΠ²Π΅ΡΠ΅ Π²ΡΠ΅ΠΌΠ΅ (time), Π΅Π½Π΅ΡΠ³ΠΈΡ (energy) ΠΈ ΡΠΎΠΊΡΡ (attention). ΠΡΠΈΡΡΠ½ΠΎ ΡΠ»ΡΡΠ°Π½Π΅.
NADCAST.20 ΡΡΡ Π‘ΡΠ΅ΡΠ°Π½ ΠΡΠ½Π΅Π²
ΠΠΈΠ»ΠΎΡΠ½ΠΈΡ Π·Π° ΡΠ΅Π·ΠΎΠ½ 2019 Π΅ΠΏΠΈΠ·ΠΎΠ΄ Π΅ ΡΡΡ Π‘ΡΠ΅ΡΠ°Π½ ΠΡΠ½Π΅Π². ΠΠΎΠ³ΠΎΠ²ΠΎΡΠΈΡ ΠΌΠ΅ ΡΠΈ Π·Π° ΠΌΠ΅Π½ΠΈΠ΄ΠΆΠΌΡΠ½Ρ ΠΈ Π»ΠΈΠ΄Π΅ΡΡΡΠ²ΠΎ. ΠΡΠΈΡΡΠ½ΠΎ ΡΠ»ΡΡΠ°Π½Π΅.
From PHP to Node with Zeit's lambdas and Cypress.io
The first post in this blog was published on 25th of August 2008. This place was always living on a shared PHP/MySQL hosting. It was driven by a custom made PHP CMS for over 10 years. It is time to move forward and follow my actual language of choice - JavaScript. I spent some time recently migrating it to Zeit and this article is showing my process.
NADCAST.23 Ρ Π―Π½ΠΈ ΠΈ ΠΠΈΡ
ΠΠΏΠΈΠ·ΠΎΠ΄ 23 Π½Π° ΠΌΠ°Π»ΠΊΠΎ ΠΏΠΎΠ·Π°Π±ΡΠ°Π²Π΅Π½ΠΈΡ NADCAST Π΅ ΡΡΠΊ. Π’ΠΎΠ·ΠΈ ΠΏΡΡ Π³ΠΎΡΡΠΈ ΠΌΠΈ Π±ΡΡ Π° Π―Π½ΠΈ (https://remoteit.world/) ΠΈ ΠΠΈΡ (https://influencer.bg/). ΠΠΎΠ³ΠΎΠ²ΠΎΡΠΈΡ ΠΌΠ΅ ΡΠΈ Π·Π° ΠΌΠ°ΡΠΊΠ΅ΡΠΈΠ½Π³, Π±ΡΠ°Π½Π΄ΠΈΠ½Π³, hiring ΠΈ ΡΠ°Π±ΠΎΡΠ° ΠΎΡ ΡΠ°Π·ΡΡΠΎΡΠ½ΠΈΠ΅. ΠΡΠΈΡΡΠ½ΠΎ ΡΠ»ΡΡΠ°Π½Π΅.
Reactive view - the concept
Something bugs me last couple of years. I'm using React for some time now and there is always this doubt if I'm placing the business logic on the right place. I'm trying to be pragmatic, to follow best practices and listen what the community is saying. However, I still feel that something is not ok. This blog post presents the idea of the reactive view. That is nothing new per se but I came up with this term because it fits well in my idea.
Hopa - zero config CLI that runs JavaScript and TypeScript
Yesterday was one of those days. I stumbled a task and wanted to find the right tool for it. That same task is on my way at least twice a week and I always refuse to optimize it. Because it was a weekend I decided to spend some time and research a proper tool for the job. Well, I find nothing that suites my need. I time-boxed a hour and said F.ck it!. I will code it myself. That's how Hopa was born - a zero config CLI that runs JavaScript and TypeScript. Transpiles, bundles, watches and executes code.
Octomments - using GitHub as a comment plugin
87% of my readers are using Chrome on desktop. This means that I have the luxury to care less about performance. However I just recently found that this blog has 56 (out of 100) points on Google's pagespeed test. That's not good. The report says that my Disqus comments are blocking the main thread for ~900ms. I want comments on my blog but I also want my users to reach to content as quickly as possible. So, after so many years using Disqus I decided to break with it and use something else.
From 0 to 100 GitHub stars in a week
2020 for me started with the release of several OS projects. Two of them reached 100 stars in a week and I was thinking that would be nice sharing my workflow. Not like it is working every time, absolutely not, but leads to some good results.
Pairify - how to match balanced string pairs
I'm now actively working on a VSCode extension. I started it as a theme but then decided to add some more features. Like for example a tin line on the left side of the editor marking the current function scope. In order to do that I had to analyze the current file's code and find the lines that are included in that scope. The obvious approach will be to translate the code to AST and then traverse the tree finding the information that I need. This however will require the usage of a language server which now I don't want to deal with. So I decided to explore a brute force approach. Looping over the string characters and finding balanced matches. I quickly wrapped it into a library. I called it Pairify. It consumes text and returns an array of pairs. This blog post will show you how it works.
NADCAST.24 Ρ Π Π°Π΄ΠΎ Π‘ΡΠ°Π½ΠΊΠΎΠ²
Π ΡΠ΅Π·ΠΈ ΡΠΌΡΡΠ½ΠΈ Π²ΡΠ΅ΠΌΠ΅Π½Π° ΡΠ΅ ΡΡΠ²Π°ΠΌΠ΅ online Ρ Π Π°Π΄ΠΎ Π‘ΡΠ°Π½ΠΊΠΎΠ² Π·Π° Π΄Π° ΡΠΈ ΠΏΠΎΠ³ΠΎΠ²ΠΎΡΠΈΠΌ Π·Π° remote working. ΠΠ΅ ΡΠ΅ ΠΏΠΎ ΠΏΡΠΈΠ½ΡΠΈΠΏ Π½Π΅ ΡΠ΅ ΡΡΠ²Π°ΠΌΠ΅ ΡΠ°ΠΊΠ°, Π½ΠΎ ΡΠ΅Π³Π° Π΅ ΠΌΠ°Π»ΠΊΠΎ ΠΏΠΎ-ΡΠ°Π·Π»ΠΈΡΠ½ΠΎ. Π ΡΠΎΠ·ΠΈ 24-ΡΠΈ Π΅ΠΏΠΈΠ·ΠΎΠ΄ ΡΠΏΠΎΠ΄Π΅Π»ΡΠΌΠ΅ Π½Π°ΡΠΈΡ ΠΎΠΏΠΈΡ Π² ΡΠ°Π±ΠΎΡΠ° ΠΎΡ ΡΠ°Π·ΡΡΠΎΡΠ½ΠΈΠ΅. ΠΡΠΈΡΡΠ½ΠΎ ΡΠ»ΡΡΠ°Π½Π΅.
Create your own Covid-19 data tracker
I'm continuing to experiment with React and TypeScript. The weekend-long project this time was a Covid-19 data tracker. In this blog post I will share how I built c19stats.now.sh. I exposed the data as a public API at the same URL. I guess you, as many other people, follow the situation so you may want to glue your fingers on the keyboard and create something useful around the data. I got lots of fun playing with the diagrams.
Smart placeholders in your markdown
I β€οΈ markdown. I like its simplicity and minimalistic API which is good enough to cover most of needed HTML markup. At least for textual content. At work we have a small node based microservice that delivers data from Contentful in exactly markdown format. It's all working well but we started having cases where part of the text is in Contentful and the other part is in that microservice. For example when we have a button with a catchy design. We want to content manage the label of the button but the actual markup to be on our side.