{"id":481996,"date":"2026-06-02T04:46:38","date_gmt":"2026-06-02T04:46:38","guid":{"rendered":"https:\/\/savepearlharbor.com\/?p=481996"},"modified":"-0001-11-30T00:00:00","modified_gmt":"-0001-11-29T21:00:00","slug":"","status":"publish","type":"post","link":"https:\/\/savepearlharbor.com\/?p=481996","title":{"rendered":"\u041f\u043e\u0447\u0435\u043c\u0443 \u043a\u043e\u0434, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u0433\u0435\u043d\u0435\u0440\u0438\u0440\u0443\u0435\u0442 \u0432\u0430\u0448 AI-\u0430\u0441\u0441\u0438\u0441\u0442\u0435\u043d\u0442, \u0432\u044b\u0433\u043b\u044f\u0434\u0438\u0442 \u043e\u0434\u0438\u043d\u0430\u043a\u043e\u0432\u043e \u043f\u043b\u043e\u0445\u043e, \u0438 \u043a\u0430\u043a \u044d\u0442\u043e \u0438\u0441\u043f\u0440\u0430\u0432\u0438\u0442\u044c \u0437\u0430 30 \u0441\u0435\u043a\u0443\u043d"},"content":{"rendered":"<div xmlns=\"http:\/\/www.w3.org\/1999\/xhtml\">\n<h3>\ud83d\udd0d \u041f\u0440\u043e\u0431\u043b\u0435\u043c\u0430 \u043d\u0435 \u0432 \u043c\u043e\u0434\u0435\u043b\u0438<\/h3>\n<p>GPT-4, Claude 3.5, Gemini 1.5: \u0432\u0441\u0435 \u043e\u043d\u0438 \u0443\u043c\u0435\u044e\u0442 \u043f\u0438\u0441\u0430\u0442\u044c \u0445\u043e\u0440\u043e\u0448\u0438\u0439 \u043a\u043e\u0434. \u041d\u043e \u043f\u043e \u0443\u043c\u043e\u043b\u0447\u0430\u043d\u0438\u044e \u043d\u0438 \u043e\u0434\u0438\u043d \u0438\u0437 \u043d\u0438\u0445 \u043d\u0435 \u0437\u043d\u0430\u0435\u0442 \u0432\u0430\u0448\u0438\u0445 \u0441\u0442\u0430\u043d\u0434\u0430\u0440\u0442\u043e\u0432. \ud83e\udd37\u200d\u2642\ufe0f<\/p>\n<p>\u0427\u0442\u043e \u043f\u043e\u043b\u0443\u0447\u0430\u0435\u0442 \u043c\u043e\u0434\u0435\u043b\u044c \u0431\u0435\u0437 \u0441\u0438\u0441\u0442\u0435\u043c\u043d\u043e\u0433\u043e \u043f\u0440\u043e\u043c\u043f\u0442\u0430:<\/p>\n<ul>\n<li>\n<p>\u041d\u0438\u043a\u0430\u043a\u0438\u0445 \u043e\u0433\u0440\u0430\u043d\u0438\u0447\u0435\u043d\u0438\u0439 \u043d\u0430 \u0430\u0440\u0445\u0438\u0442\u0435\u043a\u0442\u0443\u0440\u0443 \ud83c\udfd7\ufe0f<\/p>\n<\/li>\n<li>\n<p>\u041d\u0438\u043a\u0430\u043a\u0438\u0445 \u043f\u0440\u0435\u0434\u043f\u043e\u0447\u0442\u0435\u043d\u0438\u0439 \u043f\u043e \u0442\u0435\u0441\u0442\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u044e \ud83e\uddea<\/p>\n<\/li>\n<li>\n<p>\u041d\u0438\u043a\u0430\u043a\u0438\u0445 \u043f\u0440\u0430\u0432\u0438\u043b \u043f\u043e \u0432\u0438\u0437\u0443\u0430\u043b\u044c\u043d\u043e\u043c\u0443 \u043a\u0430\u0447\u0435\u0441\u0442\u0432\u0443 \ud83c\udfa8<\/p>\n<\/li>\n<li>\n<p>\u041d\u0438\u043a\u0430\u043a\u0438\u0445 \u0442\u0440\u0435\u0431\u043e\u0432\u0430\u043d\u0438\u0439 \u043a \u0431\u0435\u0437\u043e\u043f\u0430\u0441\u043d\u043e\u0441\u0442\u0438 \ud83d\udd12<\/p>\n<\/li>\n<\/ul>\n<p>\u0420\u0435\u0437\u0443\u043b\u044c\u0442\u0430\u0442 \u043f\u0440\u0435\u0434\u0441\u043a\u0430\u0437\u0443\u0435\u043c. \u041a\u043e\u043c\u043f\u043e\u043d\u0435\u043d\u0442 \u0440\u0430\u0431\u043e\u0442\u0430\u0435\u0442. \u0421\u0442\u0438\u043b\u0438: \u0434\u0435\u0444\u043e\u043b\u0442\u043d\u044b\u0439 Tailwind. \u0422\u0435\u0441\u0442\u044b \u043d\u0435 \u043d\u0430\u043f\u0438\u0441\u0430\u043d\u044b. <code>any<\/code> \u0432\u0435\u0437\u0434\u0435, \u0433\u0434\u0435 TypeScript \u0441\u043e\u043f\u0440\u043e\u0442\u0438\u0432\u043b\u044f\u043b\u0441\u044f. \u041c\u0430\u0433\u0438\u0447\u0435\u0441\u043a\u0438\u0435 \u0447\u0438\u0441\u043b\u0430 \u0431\u0435\u0437 \u043e\u0431\u044a\u044f\u0441\u043d\u0435\u043d\u0438\u0439. \ud83d\ude05<\/p>\n<p>\u042d\u0442\u043e \u043d\u0435 \u043c\u043e\u0434\u0435\u043b\u044c \u043f\u043b\u043e\u0445\u0430\u044f. \u042d\u0442\u043e \u043f\u0443\u0441\u0442\u043e\u0435 \u043f\u043e\u043b\u0435 \u0432\u043c\u0435\u0441\u0442\u043e \u0442\u0435\u0445\u043d\u0438\u0447\u0435\u0441\u043a\u043e\u0433\u043e \u0437\u0430\u0434\u0430\u043d\u0438\u044f. \ud83d\udcdd<\/p>\n<hr\/>\n<h3>\ud83d\udca1 \u0421\u0438\u0441\u0442\u0435\u043c\u043d\u044b\u0439 \u043f\u0440\u043e\u043c\u043f\u0442: \u043f\u043e\u0447\u0435\u043c\u0443 \u043d\u0435 \u0440\u0430\u0431\u043e\u0442\u0430\u0435\u0442 \u00abact as a senior dev\u00bb<\/h3>\n<p>\u0421\u0442\u0430\u043d\u0434\u0430\u0440\u0442\u043d\u044b\u0435 \u0441\u043e\u0432\u0435\u0442\u044b \u043f\u0440\u043e \u0441\u0438\u0441\u0442\u0435\u043c\u043d\u044b\u0435 \u043f\u0440\u043e\u043c\u043f\u0442\u044b \u043e\u0431\u044b\u0447\u043d\u043e \u0437\u0430\u043a\u0430\u043d\u0447\u0438\u0432\u0430\u044e\u0442\u0441\u044f \u043d\u0430 \u00ab\u0441\u043a\u0430\u0436\u0438 \u043c\u043e\u0434\u0435\u043b\u0438, \u0447\u0442\u043e \u043e\u043d\u0430 \u043e\u043f\u044b\u0442\u043d\u044b\u0439 \u0440\u0430\u0437\u0440\u0430\u0431\u043e\u0442\u0447\u0438\u043a\u00bb. \u042d\u0442\u043e \u043f\u0440\u0438\u043c\u0435\u0440\u043d\u043e \u043a\u0430\u043a \u043d\u0430\u043d\u044f\u0442\u044c \u0441\u043f\u0435\u0446\u0438\u0430\u043b\u0438\u0441\u0442\u0430 \u0438 \u043e\u043f\u0438\u0441\u0430\u0442\u044c \u0435\u0433\u043e \u0440\u043e\u043b\u044c \u0441\u043b\u043e\u0432\u043e\u043c \u00ab\u0445\u043e\u0440\u043e\u0448\u0438\u0439\u00bb. \ud83e\uddd0<\/p>\n<p>\u041d\u0430\u0441\u0442\u043e\u044f\u0449\u0438\u0439 \u0441\u0438\u0441\u0442\u0435\u043c\u043d\u044b\u0439 \u043f\u0440\u043e\u043c\u043f\u0442 \u0434\u043b\u044f \u0438\u043d\u0436\u0435\u043d\u0435\u0440\u043d\u044b\u0445 \u0437\u0430\u0434\u0430\u0447 \u0432\u044b\u0433\u043b\u044f\u0434\u0438\u0442 \u0438\u043d\u0430\u0447\u0435. \u0412\u043e\u0442 \u0447\u0442\u043e \u0432 \u0440\u0435\u0430\u043b\u044c\u043d\u043e\u0441\u0442\u0438 \u0441\u043e\u0434\u0435\u0440\u0436\u0438\u0442 \u0445\u043e\u0440\u043e\u0448\u043e \u043d\u0430\u043f\u0438\u0441\u0430\u043d\u043d\u0430\u044f \u043f\u0435\u0440\u0441\u043e\u043d\u0430 \u0434\u043b\u044f senior fullstack \u0438\u043d\u0436\u0435\u043d\u0435\u0440\u0430:<\/p>\n<ul>\n<li>\n<p>\u041a\u043e\u043d\u043a\u0440\u0435\u0442\u043d\u044b\u0435 \u0430\u0440\u0445\u0438\u0442\u0435\u043a\u0442\u0443\u0440\u043d\u044b\u0435 \u043f\u0440\u0438\u043d\u0446\u0438\u043f\u044b (\u043a\u043e\u0433\u0434\u0430 \u043f\u043e\u0434\u043d\u0438\u043c\u0430\u0442\u044c \u0441\u0442\u0435\u0439\u0442, \u043a\u043e\u0433\u0434\u0430 \u043d\u0435\u0442) \ud83d\udcd0<\/p>\n<\/li>\n<li>\n<p>\u0416\u0435\u0441\u0442\u043a\u0438\u0435 \u043f\u0440\u0430\u0432\u0438\u043b\u0430 \u043f\u043e \u0438\u043c\u0435\u043d\u043e\u0432\u0430\u043d\u0438\u044e \u0438 \u0441\u0442\u0440\u0443\u043a\u0442\u0443\u0440\u0435 \ud83d\uddc2\ufe0f<\/p>\n<\/li>\n<li>\n<p>\u041e\u0431\u044f\u0437\u0430\u0442\u0435\u043b\u044c\u043d\u044b\u0435 \u043f\u0430\u0442\u0442\u0435\u0440\u043d\u044b \u0434\u043b\u044f \u043a\u043e\u043d\u043a\u0440\u0435\u0442\u043d\u044b\u0445 \u0441\u0446\u0435\u043d\u0430\u0440\u0438\u0435\u0432 (data fetching, error boundaries, loading states) \ud83d\udd04<\/p>\n<\/li>\n<li>\n<p>\u042f\u0432\u043d\u044b\u0435 \u0437\u0430\u043f\u0440\u0435\u0442\u044b \u043d\u0430 \u0434\u0435\u0439\u0441\u0442\u0432\u0438\u044f \u0431\u0435\u0437 \u0441\u043e\u0433\u043b\u0430\u0441\u043e\u0432\u0430\u043d\u0438\u044f \ud83d\uded1<\/p>\n<\/li>\n<li>\n<p>\u0421\u0442\u0430\u043d\u0434\u0430\u0440\u0442\u044b code review \u0438 \u043a\u0440\u0438\u0442\u0435\u0440\u0438\u0438 \u0433\u043e\u0442\u043e\u0432\u043d\u043e\u0441\u0442\u0438 \u043a PR \ud83e\udd1d<\/p>\n<\/li>\n<\/ul>\n<p>\u0420\u0430\u0437\u043d\u0438\u0446\u0430 \u043c\u0435\u0436\u0434\u0443 \u0448\u0430\u0431\u043b\u043e\u043d\u043d\u044b\u043c \u00abact as senior developer\u00bb \u0438 \u0434\u0435\u0442\u0430\u043b\u044c\u043d\u043e\u0439 \u0438\u043d\u0441\u0442\u0440\u0443\u043a\u0446\u0438\u0435\u0439 \u0441\u0440\u0430\u0432\u043d\u0438\u043c\u0430 \u0441 \u0440\u0430\u0437\u043d\u0438\u0446\u0435\u0439 \u043c\u0435\u0436\u0434\u0443 \u0434\u0436\u0443\u043d\u0438\u043e\u0440\u043e\u043c \u0438 \u0442\u0435\u0445\u043b\u0438\u0434\u043e\u043c. \ud83d\udc68\u200d\ud83d\udcbb<\/p>\n<hr\/>\n<h3>\ud83d\udce6 proagents: 794 \u0442\u0430\u043a\u0438\u0445 \u043f\u0440\u043e\u043c\u043f\u0442\u0430, \u043d\u043e\u043b\u044c \u0437\u0430\u0432\u0438\u0441\u0438\u043c\u043e\u0441\u0442\u0435\u0439<\/h3>\n<p><a href=\"https:\/\/github.com\/Arlandaren\/proagents\" rel=\"noopener noreferrer nofollow\"><strong>github.com\/Arlandaren\/proagents<\/strong><\/a>: \u043e\u0442\u043a\u0440\u044b\u0442\u0430\u044f \u0431\u0438\u0431\u043b\u0438\u043e\u0442\u0435\u043a\u0430, \u0441\u043e\u0431\u0440\u0430\u043d\u043d\u0430\u044f \u0438\u0437 \u0448\u0435\u0441\u0442\u0438 \u0432\u0435\u0434\u0443\u0449\u0438\u0445 \u0440\u0435\u043f\u043e\u0437\u0438\u0442\u043e\u0440\u0438\u0435\u0432 \u0441 \u0430\u0433\u0435\u043d\u0442\u043d\u044b\u043c\u0438 \u043a\u043e\u043d\u0444\u0438\u0433\u0443\u0440\u0430\u0446\u0438\u044f\u043c\u0438. \ud83d\udcc1<\/p>\n<p>\u0421\u0442\u0440\u0443\u043a\u0442\u0443\u0440\u0430 \u043f\u0440\u043e\u0435\u043a\u0442\u0430:<\/p>\n<pre><code>proagents\/\u251c\u2500\u2500 personas\/          # 232 \u0430\u0433\u0435\u043d\u0442\u0430-\u0441\u043f\u0435\u0446\u0438\u0430\u043b\u0438\u0441\u0442\u0430\u2502   \u251c\u2500\u2500 engineering\/   # 126 \u0438\u043d\u0436\u0435\u043d\u0435\u0440\u043d\u044b\u0445 \u0440\u043e\u043b\u0435\u0439\u2502   \u251c\u2500\u2500 design\/        # 15 \u0434\u0438\u0437\u0430\u0439\u043d-\u043f\u0435\u0440\u0441\u043e\u043d\u2502   \u251c\u2500\u2500 operations\/    # 33 \u043e\u043f\u0435\u0440\u0430\u0446\u0438\u043e\u043d\u043d\u044b\u0445 \u0440\u043e\u043b\u0438\u2502   \u2514\u2500\u2500 ...\u251c\u2500\u2500 workflows\/         # 521 \u0438\u0441\u043f\u043e\u043b\u043d\u044f\u0435\u043c\u044b\u0439 \u0447\u0435\u043a\u043b\u0438\u0441\u0442\u2502   \u251c\u2500\u2500 development\/   # 363 \u0432\u043e\u0440\u043a\u0444\u043b\u043e\u0443 \u0440\u0430\u0437\u0440\u0430\u0431\u043e\u0442\u043a\u0438\u2502   \u251c\u2500\u2500 security\/      # 64 \u0447\u0435\u043a\u043b\u0438\u0441\u0442\u0430 \u0431\u0435\u0437\u043e\u043f\u0430\u0441\u043d\u043e\u0441\u0442\u0438\u2502   \u2514\u2500\u2500 ...\u2514\u2500\u2500 rules\/             # 41 \u043f\u0440\u0430\u0432\u0438\u043b\u043e \u0433\u0435\u043d\u0435\u0440\u0430\u0446\u0438\u0438    \u251c\u2500\u2500 taste\/         # \u0412\u0438\u0437\u0443\u0430\u043b\u044c\u043d\u044b\u0435 \u0441\u0442\u0430\u043d\u0434\u0430\u0440\u0442\u044b    \u2514\u2500\u2500 core\/          # \u0413\u0438\u0433\u0438\u0435\u043d\u0430 \u043a\u043e\u0434\u0430<\/code><div class=\"code-explainer\"><a href=\"https:\/\/sourcecraft.dev\/\" class=\"tm-button code-explainer__link\" style=\"visibility: hidden;\"><img style=\"width:87px;height:14px;object-fit:cover;object-position:left;\"\/><\/a><\/div><\/pre>\n<p>\u0423\u0441\u0442\u0430\u043d\u043e\u0432\u043a\u0430 \u0432 IDE \u0432\u044b\u043f\u043e\u043b\u043d\u044f\u0435\u0442\u0441\u044f \u043e\u0434\u043d\u043e\u0439 \u043a\u043e\u043c\u0430\u043d\u0434\u043e\u0439: \u26a1<\/p>\n<pre><code class=\"bash\">git clone https:\/\/github.com\/Arlandaren\/proagents.gitcd proagents.\/proagents install react-patterns --cursor<\/code><div class=\"code-explainer\"><a href=\"https:\/\/sourcecraft.dev\/\" class=\"tm-button code-explainer__link\" style=\"visibility: hidden;\"><img style=\"width:14px;height:14px;object-fit:cover;object-position:left;\"\/><\/a><\/div><\/pre>\n<p>\u041d\u0430\u0441\u0442\u0440\u043e\u0439\u043a\u0430 \u0437\u0430\u0432\u0435\u0440\u0448\u0435\u043d\u0430. \u0420\u0435\u0434\u0430\u043a\u0442\u043e\u0440 Cursor \u0442\u0435\u043f\u0435\u0440\u044c \u0437\u043d\u0430\u0435\u0442 \u0432\u0430\u0448\u0438 \u0441\u0442\u0430\u043d\u0434\u0430\u0440\u0442\u044b. \ud83c\udf89<\/p>\n<hr\/>\n<h3>\ud83c\udfa8 \u0420\u0430\u0437\u0431\u043e\u0440: \u0447\u0442\u043e \u043c\u0435\u043d\u044f\u0435\u0442\u0441\u044f \u0441 rules\/taste\/<\/h3>\n<p>\u041f\u0430\u043f\u043a\u0430 <code>rules\/taste\/<\/code>, \u043f\u043e\u0436\u0430\u043b\u0443\u0439, \u0441\u0430\u043c\u0430\u044f \u043d\u0435\u0434\u043e\u043e\u0446\u0435\u043d\u0435\u043d\u043d\u0430\u044f \u0447\u0430\u0441\u0442\u044c \u0440\u0435\u043f\u043e\u0437\u0438\u0442\u043e\u0440\u0438\u044f. \u041e\u043d\u0430 \u043d\u0435 \u043e\u043f\u0438\u0441\u044b\u0432\u0430\u0435\u0442 \u0440\u043e\u043b\u044c. \u041e\u043d\u0430 \u043e\u043f\u0438\u0441\u044b\u0432\u0430\u0435\u0442 \u044d\u0441\u0442\u0435\u0442\u0438\u043a\u0443. \u2728<\/p>\n<h4>animate.md \ud83c\udfc3\u200d\u2642\ufe0f<\/h4>\n<p>\u0417\u0430\u043f\u0440\u0435\u0449\u0430\u0435\u0442 CSS <code>transition<\/code> \u0438 <code>animation<\/code> \u0432 \u043f\u043e\u043b\u044c\u0437\u0443 spring physics. \u0412\u043c\u0435\u0441\u0442\u043e <code>transition: all 0.3s ease<\/code> \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u0442\u0441\u044f <code>useSpring<\/code> \u0438\u0437 framer-motion \u0441 \u043a\u043e\u043d\u043a\u0440\u0435\u0442\u043d\u044b\u043c\u0438 \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u044f\u043c\u0438 stiffness \u0438 damping. \u0412 \u0440\u0435\u0437\u0443\u043b\u044c\u0442\u0430\u0442\u0435 \u0430\u043d\u0438\u043c\u0430\u0446\u0438\u0438 \u043e\u0449\u0443\u0449\u0430\u044e\u0442\u0441\u044f \u0444\u0438\u0437\u0438\u0447\u0435\u0441\u043a\u0438 \u043f\u0440\u0430\u0432\u0434\u043e\u043f\u043e\u0434\u043e\u0431\u043d\u044b\u043c\u0438, \u0430 \u043d\u0435 \u043f\u0440\u043e\u0441\u0442\u043e \u00ab\u043f\u043b\u0430\u0432\u043d\u044b\u043c\u0438\u00bb.<\/p>\n<h4>liquid-glass.md \ud83d\udd2e<\/h4>\n<p>\u041d\u0430\u0441\u0442\u0440\u043e\u0439\u043a\u0430 \u044d\u0444\u0444\u0435\u043a\u0442\u0430 Glassmorphism. \u041d\u0438\u043a\u0430\u043a\u0438\u0445 <code>backdrop-filter: blur(10px)<\/code> \u043d\u0430\u0443\u0433\u0430\u0434, \u0442\u043e\u043b\u044c\u043a\u043e \u043f\u0440\u043e\u0432\u0435\u0440\u0435\u043d\u043d\u044b\u0435 \u043a\u043e\u043c\u0431\u0438\u043d\u0430\u0446\u0438\u0438 blur, saturation \u0438 overlay-\u0446\u0432\u0435\u0442\u043e\u0432, \u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u0440\u0430\u0431\u043e\u0442\u0430\u044e\u0442 \u043d\u0430 \u0440\u0430\u0437\u043d\u044b\u0445 \u0444\u043e\u043d\u0430\u0445. \u0414\u043e\u043f\u043e\u043b\u043d\u0438\u0442\u0435\u043b\u044c\u043d\u043e \u043e\u043f\u0438\u0441\u0430\u043d\u044b \u043f\u0440\u0430\u0432\u0438\u043b\u0430, \u043a\u043e\u0433\u0434\u0430 \u044d\u0442\u043e\u0442 \u044d\u0444\u0444\u0435\u043a\u0442 \u0443\u043c\u0435\u0441\u0442\u0435\u043d, \u0430 \u043a\u043e\u0433\u0434\u0430 \u0441\u043e\u0437\u0434\u0430\u0435\u0442 \u043f\u0440\u043e\u0431\u043b\u0435\u043c\u044b \u0441 \u0434\u043e\u0441\u0442\u0443\u043f\u043d\u043e\u0441\u0442\u044c\u044e \u0438\u043d\u0442\u0435\u0440\u0444\u0435\u0439\u0441\u0430.<\/p>\n<h4>bolder.md \u270d\ufe0f<\/h4>\n<p>\u0422\u0438\u043f\u043e\u0433\u0440\u0430\u0444\u0438\u043a\u0430 \u0431\u0435\u0437 \u043a\u043e\u043c\u043f\u0440\u043e\u043c\u0438\u0441\u0441\u043e\u0432. \u0418\u0435\u0440\u0430\u0440\u0445\u0438\u044f \u043a\u043e\u043d\u0442\u0440\u0430\u0441\u0442\u0430, \u043f\u0440\u0430\u0432\u0438\u043b\u0430 \u0434\u043b\u044f font-weight, \u0437\u0430\u043f\u0440\u0435\u0442 \u043d\u0430 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043d\u0438\u0435 <code>color: #888888<\/code> \u0432 \u043a\u0430\u0447\u0435\u0441\u0442\u0432\u0435 \u043d\u0435\u0439\u0442\u0440\u0430\u043b\u044c\u043d\u043e\u0433\u043e \u0446\u0432\u0435\u0442\u0430. \u0422\u0435\u043a\u0441\u0442 \u043b\u0438\u0431\u043e \u0447\u0438\u0442\u0430\u0435\u0442\u0441\u044f, \u043b\u0438\u0431\u043e \u0435\u0433\u043e \u043d\u0435\u0442.<\/p>\n<h4>overdrive.md \ud83d\udc8e<\/h4>\n<p>\u0418\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u0442\u0441\u044f, \u043a\u043e\u0433\u0434\u0430 \u043d\u0443\u0436\u0435\u043d \u043c\u0430\u043a\u0441\u0438\u043c\u0430\u043b\u044c\u043d\u044b\u0439 \u043f\u0440\u0435\u043c\u0438\u0430\u043b\u044c\u043d\u044b\u0439 \u0432\u0438\u0434. \u0412\u044b\u0441\u043e\u043a\u0430\u044f \u0432\u0438\u0437\u0443\u0430\u043b\u044c\u043d\u0430\u044f \u043f\u043b\u043e\u0442\u043d\u043e\u0441\u0442\u044c \u043f\u0440\u0438 \u0441\u043e\u0445\u0440\u0430\u043d\u0435\u043d\u0438\u0438 \u0447\u0438\u0442\u0430\u0435\u043c\u043e\u0441\u0442\u0438. \u042d\u0442\u043e\u0442 \u0444\u0430\u0439\u043b \u0441\u0442\u043e\u0438\u0442 \u043f\u0440\u0438\u043c\u0435\u043d\u044f\u0442\u044c \u0442\u043e\u0447\u0435\u0447\u043d\u043e, \u0442\u0430\u043a \u043a\u0430\u043a \u043e\u043d \u0434\u0435\u043b\u0430\u0435\u0442 UI \u0430\u0433\u0440\u0435\u0441\u0441\u0438\u0432\u043d\u043e \u0432\u044b\u0440\u0430\u0437\u0438\u0442\u0435\u043b\u044c\u043d\u044b\u043c.<\/p>\n<hr\/>\n<h3>\ud83d\udcbb \u041a\u043e\u043d\u043a\u0440\u0435\u0442\u043d\u044b\u0439 \u043f\u0440\u0438\u043c\u0435\u0440: \u0434\u043e \u0438 \u043f\u043e\u0441\u043b\u0435<\/h3>\n<p><strong>\u0417\u0430\u0434\u0430\u0447\u0430<\/strong>: \u043d\u0430\u043f\u0438\u0441\u0430\u0442\u044c \u043a\u0430\u0440\u0442\u043e\u0447\u043a\u0443 \u043f\u0440\u043e\u0434\u0443\u043a\u0442\u0430 \u0432 React.<\/p>\n<p><strong>\u0411\u0435\u0437 \u0441\u0438\u0441\u0442\u0435\u043c\u043d\u043e\u0433\u043e \u043f\u0440\u043e\u043c\u043f\u0442\u0430:<\/strong> \u274c<\/p>\n<pre><code>function ProductCard({ product }) {  return (    &lt;div style={{ border: '1px solid #ccc', padding: '16px', borderRadius: '8px' }}&gt;      &lt;img src={product.image} alt={product.name} \/&gt;      &lt;h3&gt;{product.name}&lt;\/h3&gt;      &lt;p&gt;{product.price}&lt;\/p&gt;      &lt;button onClick={() =&gt; addToCart(product.id)}&gt;Add to Cart&lt;\/button&gt;    &lt;\/div&gt;  );}<\/code><div class=\"code-explainer\"><a href=\"https:\/\/sourcecraft.dev\/\" class=\"tm-button code-explainer__link\" style=\"visibility: hidden;\"><img style=\"width:14px;height:14px;object-fit:cover;object-position:left;\"\/><\/a><\/div><\/pre>\n<p>\u041a\u043e\u0434 \u0440\u0430\u0431\u043e\u0442\u0430\u0435\u0442, \u043d\u043e \u0432\u044b\u0433\u043b\u044f\u0434\u0438\u0442 \u0441\u043b\u0430\u0431\u043e. \u0410\u0442\u0440\u0438\u0431\u0443\u0442 <code>alt<\/code> \u043d\u0435 \u043d\u0435\u0441\u0435\u0442 \u0441\u043c\u044b\u0441\u043b\u0430. \u041d\u0435\u0442 \u0441\u043e\u0441\u0442\u043e\u044f\u043d\u0438\u044f \u0437\u0430\u0433\u0440\u0443\u0437\u043a\u0438, \u043e\u0442\u0441\u0443\u0442\u0441\u0442\u0432\u0443\u0435\u0442 \u043e\u0431\u0440\u0430\u0431\u043e\u0442\u043a\u0430 \u043e\u0448\u0438\u0431\u043e\u043a. \u041f\u0435\u0440\u0435\u043c\u0435\u043d\u043d\u0430\u044f <code>addToCart<\/code> \u0431\u0435\u0440\u0435\u0442\u0441\u044f \u0438\u0437 \u043d\u0438\u043e\u0442\u043a\u0443\u0434\u0430. \ud83d\ude12<\/p>\n<p><strong>\u0421 <\/strong><code><strong>react-patterns<\/strong><\/code><strong> + <\/strong><code><strong>animate<\/strong><\/code><strong> \u0438\u0437 proagents:<\/strong> \u2705<\/p>\n<pre><code>interface ProductCardProps {  product: Product;  onAddToCart: (productId: string) =&gt; void;}function ProductCard({ product, onAddToCart }: ProductCardProps) {  const [isAdding, setIsAdding] = useState(false);  const cardSpring = useSpring({ scale: 1, config: { stiffness: 300, damping: 20 } });  const handleAddToCart = async () =&gt; {    setIsAdding(true);    await onAddToCart(product.id);    setIsAdding(false);  };  return (    &lt;animated.article      style={cardSpring}      onMouseEnter={() =&gt; cardSpring.scale.set(1.02)}      onMouseLeave={() =&gt; cardSpring.scale.set(1)}      aria-label={`${product.name}, ${formatPrice(product.price)}`}    &gt;      &lt;img        src={product.imageUrl}        alt={product.name}        loading=\"lazy\"      \/&gt;      &lt;h3&gt;{product.name}&lt;\/h3&gt;      &lt;p&gt;{formatPrice(product.price)}&lt;\/p&gt;      &lt;button        onClick={handleAddToCart}        disabled={isAdding}        aria-busy={isAdding}      &gt;        {isAdding ? '\u0414\u043e\u0431\u0430\u0432\u043b\u044f\u0435\u043c...' : '\u0412 \u043a\u043e\u0440\u0437\u0438\u043d\u0443'}      &lt;\/button&gt;    &lt;\/animated.article&gt;  );}<\/code><div class=\"code-explainer\"><a href=\"https:\/\/sourcecraft.dev\/\" class=\"tm-button code-explainer__link\" style=\"visibility: hidden;\"><img style=\"width:14px;height:14px;object-fit:cover;object-position:left;\"\/><\/a><\/div><\/pre>\n<p>\u041a\u043e\u0434 \u043f\u043e\u043b\u043d\u043e\u0441\u0442\u044c\u044e \u0442\u0438\u043f\u0438\u0437\u0438\u0440\u043e\u0432\u0430\u043d. \u0424\u0443\u043d\u043a\u0446\u0438\u044f <code>onAddToCart<\/code> \u043a\u043e\u0440\u0440\u0435\u043a\u0442\u043d\u043e \u043f\u0435\u0440\u0435\u0434\u0430\u0435\u0442\u0441\u044f \u0447\u0435\u0440\u0435\u0437 props. \u0414\u043e\u0431\u0430\u0432\u043b\u0435\u043d\u043e \u0441\u043e\u0441\u0442\u043e\u044f\u043d\u0438\u0435 \u0437\u0430\u0433\u0440\u0443\u0437\u043a\u0438 \u0438 \u043f\u043e\u0434\u0434\u0435\u0440\u0436\u043a\u0430 \u0434\u043e\u0441\u0442\u0443\u043f\u043d\u043e\u0441\u0442\u0438. \u0420\u0435\u0430\u043b\u0438\u0437\u043e\u0432\u0430\u043d\u0430 spring-\u0430\u043d\u0438\u043c\u0430\u0446\u0438\u044f \u0441 \u043a\u043e\u043d\u043a\u0440\u0435\u0442\u043d\u044b\u043c\u0438 \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u044f\u043c\u0438. \u0424\u043e\u0440\u043c\u0430\u0442\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u0435 \u0446\u0435\u043d\u044b \u0432\u044b\u043d\u0435\u0441\u0435\u043d\u043e \u0432 <code>formatPrice<\/code>. \ud83d\udc4d<\/p>\n<p>\u041c\u043e\u0434\u0435\u043b\u044c \u043d\u0435 \u0441\u0442\u0430\u043b\u0430 \u0443\u043c\u043d\u0435\u0435. \u041f\u0440\u043e\u0441\u0442\u043e \u043f\u043e\u043b\u0443\u0447\u0438\u043b\u0430 \u043f\u0440\u0430\u0432\u0438\u043b\u044c\u043d\u043e\u0435 \u0422\u0417. \ud83e\udde0<\/p>\n<hr\/>\n<h3>\ud83d\udd0c \u041a\u0430\u043a\u0438\u0435 IDE \u043f\u043e\u0434\u0434\u0435\u0440\u0436\u0438\u0432\u0430\u044e\u0442\u0441\u044f<\/h3>\n<div>\n<div class=\"table\">\n<table>\n<tbody>\n<tr>\n<th>\n<p align=\"left\">IDE<\/p>\n<\/th>\n<th>\n<p align=\"left\">\u041a\u043e\u043c\u0430\u043d\u0434\u0430<\/p>\n<\/th>\n<\/tr>\n<tr>\n<td>\n<p align=\"left\">Cursor \ud83d\ude80<\/p>\n<\/td>\n<td>\n<p align=\"left\"><code>.\/proagents install &lt;name&gt; --cursor<\/code><\/p>\n<\/td>\n<\/tr>\n<tr>\n<td>\n<p align=\"left\">Claude Code \ud83e\udd16<\/p>\n<\/td>\n<td>\n<p align=\"left\"><code>.\/proagents install &lt;name&gt; --stdout &gt;&gt; CLAUDE.md<\/code><\/p>\n<\/td>\n<\/tr>\n<tr>\n<td>\n<p align=\"left\">Windsurf \ud83c\udf0a<\/p>\n<\/td>\n<td>\n<p align=\"left\"><code>.\/proagents install &lt;name&gt; --windsurf<\/code><\/p>\n<\/td>\n<\/tr>\n<tr>\n<td>\n<p align=\"left\">Gemini CLI \u264a<\/p>\n<\/td>\n<td>\n<p align=\"left\"><code>.\/proagents install &lt;name&gt; --antigravity<\/code><\/p>\n<\/td>\n<\/tr>\n<tr>\n<td>\n<p align=\"left\">OpenCode \ud83d\udcbb<\/p>\n<\/td>\n<td>\n<p align=\"left\"><code>.\/proagents install &lt;name&gt; --opencode<\/code><\/p>\n<\/td>\n<\/tr>\n<tr>\n<td>\n<p align=\"left\">\u041b\u044e\u0431\u043e\u0439 \ud83d\udee0\ufe0f<\/p>\n<\/td>\n<td>\n<p align=\"left\"><code>.\/proagents install &lt;name&gt; --target \/path\/to\/file<\/code><\/p>\n<\/td>\n<\/tr>\n<\/tbody>\n<\/table>\n<\/div>\n<\/div>\n<hr\/>\n<h3>\u26a1 \u041f\u043e\u043f\u0440\u043e\u0431\u0443\u0439\u0442\u0435 \u043f\u0440\u044f\u043c\u043e \u0441\u0435\u0439\u0447\u0430\u0441<\/h3>\n<pre><code class=\"bash\">git clone https:\/\/github.com\/Arlandaren\/proagents.gitcd proagents.\/proagents search security  # \u043d\u0430\u0439\u0434\u0438\u0442\u0435 \u043d\u0443\u0436\u043d\u044b\u0435 \u0444\u0430\u0439\u043b\u044b.\/proagents install owasp-threat-modeling --stdout  # \u043f\u0440\u043e\u0441\u043c\u043e\u0442\u0440\u0438\u0442\u0435 \u0441\u043e\u0434\u0435\u0440\u0436\u0438\u043c\u043e\u0435<\/code><div class=\"code-explainer\"><a href=\"https:\/\/sourcecraft.dev\/\" class=\"tm-button code-explainer__link\" style=\"visibility: hidden;\"><img style=\"width:14px;height:14px;object-fit:cover;object-position:left;\"\/><\/a><\/div><\/pre>\n<p>\u0420\u0435\u043f\u043e\u0437\u0438\u0442\u043e\u0440\u0438\u0439: <a href=\"https:\/\/github.com\/Arlandaren\/proagents\" rel=\"noopener noreferrer nofollow\"><strong>github.com\/Arlandaren\/proagents<\/strong><\/a> \u2b50<\/p>\n<p>\u0415\u0441\u043b\u0438 \u0431\u0438\u0431\u043b\u0438\u043e\u0442\u0435\u043a\u0430 \u0443\u043f\u0440\u043e\u0441\u0442\u0438\u043b\u0430 \u0432\u0430\u0448\u0443 \u0440\u0430\u0431\u043e\u0442\u0443, \u043f\u043e\u0434\u0434\u0435\u0440\u0436\u0438\u0442\u0435 \u043f\u0440\u043e\u0435\u043a\u0442 \u0437\u0432\u0435\u0437\u0434\u043e\u0439 \u043d\u0430 GitHub \u0438 \u043b\u0430\u0439\u043a\u043e\u043c \u043d\u0430 \u0425\u0430\u0431\u0440\u0435. \u0415\u0441\u043b\u0438 \u0443 \u0432\u0430\u0441 \u0435\u0441\u0442\u044c \u0441\u0432\u043e\u0438 \u043f\u0440\u043e\u0432\u0435\u0440\u0435\u043d\u043d\u044b\u0435 \u043f\u0440\u043e\u043c\u043f\u0442\u044b, \u043f\u0443\u043b\u0440\u0435\u043a\u0432\u0435\u0441\u0442\u044b \u043f\u0440\u0438\u0432\u0435\u0442\u0441\u0442\u0432\u0443\u044e\u0442\u0441\u044f. \ud83e\udd1d<\/p>\n<\/div>\n<p>\u0441\u0441\u044b\u043b\u043a\u0430 \u043d\u0430 \u043e\u0440\u0438\u0433\u0438\u043d\u0430\u043b \u0441\u0442\u0430\u0442\u044c\u0438 <a href=\"https:\/\/habr.com\/ru\/articles\/1042444\/\">https:\/\/habr.com\/ru\/articles\/1042444\/<\/a><\/p>\n","protected":false},"excerpt":{"rendered":"<p>\ud83d\udd0d \u041f\u0440\u043e\u0431\u043b\u0435\u043c\u0430 \u043d\u0435 \u0432 \u043c\u043e\u0434\u0435\u043b\u0438GPT-4, Claude 3.5, Gemini 1.5: \u0432\u0441\u0435 \u043e\u043d\u0438 \u0443\u043c\u0435\u044e\u0442 \u043f\u0438\u0441\u0430\u0442\u044c \u0445\u043e\u0440\u043e\u0448\u0438\u0439 \u043a\u043e\u0434. \u041d\u043e \u043f\u043e \u0443\u043c\u043e\u043b\u0447\u0430\u043d\u0438\u044e \u043d\u0438 \u043e\u0434\u0438\u043d \u0438\u0437 \u043d\u0438\u0445 \u043d\u0435 \u0437\u043d\u0430\u0435\u0442 \u0432\u0430\u0448\u0438\u0445 \u0441\u0442\u0430\u043d\u0434\u0430\u0440\u0442\u043e\u0432. \ud83e\udd37\u200d\u2642\ufe0f\u0427\u0442\u043e \u043f\u043e\u043b\u0443\u0447\u0430\u0435\u0442 \u043c\u043e\u0434\u0435\u043b\u044c \u0431\u0435\u0437 \u0441\u0438\u0441\u0442\u0435\u043c\u043d\u043e\u0433\u043e \u043f\u0440\u043e\u043c\u043f\u0442\u0430:\u041d\u0438\u043a\u0430\u043a\u0438\u0445 \u043e\u0433\u0440\u0430\u043d\u0438\u0447\u0435\u043d\u0438\u0439 \u043d\u0430 \u0430\u0440\u0445\u0438\u0442\u0435\u043a\u0442\u0443\u0440\u0443 \ud83c\udfd7\ufe0f\u041d\u0438\u043a\u0430\u043a\u0438\u0445 \u043f\u0440\u0435\u0434\u043f\u043e\u0447\u0442\u0435\u043d\u0438\u0439 \u043f\u043e \u0442\u0435\u0441\u0442\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u044e \ud83e\uddea\u041d\u0438\u043a\u0430\u043a\u0438\u0445 \u043f\u0440\u0430\u0432\u0438\u043b \u043f\u043e \u0432\u0438\u0437\u0443\u0430\u043b\u044c\u043d\u043e\u043c\u0443 \u043a\u0430\u0447\u0435\u0441\u0442\u0432\u0443 \ud83c\udfa8\u041d\u0438\u043a\u0430\u043a\u0438\u0445 \u0442\u0440\u0435\u0431\u043e\u0432\u0430\u043d\u0438\u0439 \u043a \u0431\u0435\u0437\u043e\u043f\u0430\u0441\u043d\u043e\u0441\u0442\u0438 \ud83d\udd12\u0420\u0435\u0437\u0443\u043b\u044c\u0442\u0430\u0442 \u043f\u0440\u0435\u0434\u0441\u043a\u0430\u0437\u0443\u0435\u043c. \u041a\u043e\u043c\u043f\u043e\u043d\u0435\u043d\u0442 \u0440\u0430\u0431\u043e\u0442\u0430\u0435\u0442. \u0421\u0442\u0438\u043b\u0438: \u0434\u0435\u0444\u043e\u043b\u0442\u043d\u044b\u0439 Tailwind. \u0422\u0435\u0441\u0442\u044b \u043d\u0435 \u043d\u0430\u043f\u0438\u0441\u0430\u043d\u044b. any \u0432\u0435\u0437\u0434\u0435, \u0433\u0434\u0435 TypeScript \u0441\u043e\u043f\u0440\u043e\u0442\u0438\u0432\u043b\u044f\u043b\u0441\u044f. \u041c\u0430\u0433\u0438\u0447\u0435\u0441\u043a\u0438\u0435 \u0447\u0438\u0441\u043b\u0430 \u0431\u0435\u0437 \u043e\u0431\u044a\u044f\u0441\u043d\u0435\u043d\u0438\u0439. \ud83d\ude05\u042d\u0442\u043e \u043d\u0435 \u043c\u043e\u0434\u0435\u043b\u044c \u043f\u043b\u043e\u0445\u0430\u044f. \u042d\u0442\u043e \u043f\u0443\u0441\u0442\u043e\u0435 \u043f\u043e\u043b\u0435 \u0432\u043c\u0435\u0441\u0442\u043e \u0442\u0435\u0445\u043d\u0438\u0447\u0435\u0441\u043a\u043e\u0433\u043e \u0437\u0430\u0434\u0430\u043d\u0438\u044f. \ud83d\udcdd\ud83d\udca1 \u0421\u0438\u0441\u0442\u0435\u043c\u043d\u044b\u0439 \u043f\u0440\u043e\u043c\u043f\u0442: \u043f\u043e\u0447\u0435\u043c\u0443 \u043d\u0435 \u0440\u0430\u0431\u043e\u0442\u0430\u0435\u0442 \u00abact as a senior dev\u00bb\u0421\u0442\u0430\u043d\u0434\u0430\u0440\u0442\u043d\u044b\u0435 \u0441\u043e\u0432\u0435\u0442\u044b \u043f\u0440\u043e \u0441\u0438\u0441\u0442\u0435\u043c\u043d\u044b\u0435 \u043f\u0440\u043e\u043c\u043f\u0442\u044b \u043e\u0431\u044b\u0447\u043d\u043e \u0437\u0430\u043a\u0430\u043d\u0447\u0438\u0432\u0430\u044e\u0442\u0441\u044f \u043d\u0430 \u00ab\u0441\u043a\u0430\u0436\u0438 \u043c\u043e\u0434\u0435\u043b\u0438, \u0447\u0442\u043e \u043e\u043d\u0430 \u043e\u043f\u044b\u0442\u043d\u044b\u0439 \u0440\u0430\u0437\u0440\u0430\u0431\u043e\u0442\u0447\u0438\u043a\u00bb. \u042d\u0442\u043e \u043f\u0440\u0438\u043c\u0435\u0440\u043d\u043e \u043a\u0430\u043a \u043d\u0430\u043d\u044f\u0442\u044c \u0441\u043f\u0435\u0446\u0438\u0430\u043b\u0438\u0441\u0442\u0430 \u0438 \u043e\u043f\u0438\u0441\u0430\u0442\u044c \u0435\u0433\u043e \u0440\u043e\u043b\u044c \u0441\u043b\u043e\u0432\u043e\u043c \u00ab\u0445\u043e\u0440\u043e\u0448\u0438\u0439\u00bb. \ud83e\uddd0\u041d\u0430\u0441\u0442\u043e\u044f\u0449\u0438\u0439 \u0441\u0438\u0441\u0442\u0435\u043c\u043d\u044b\u0439 \u043f\u0440\u043e\u043c\u043f\u0442 \u0434\u043b\u044f \u0438\u043d\u0436\u0435\u043d\u0435\u0440\u043d\u044b\u0445 \u0437\u0430\u0434\u0430\u0447 \u0432\u044b\u0433\u043b\u044f\u0434\u0438\u0442 \u0438\u043d\u0430\u0447\u0435. \u0412\u043e\u0442 \u0447\u0442\u043e \u0432 \u0440\u0435\u0430\u043b\u044c\u043d\u043e\u0441\u0442\u0438 \u0441\u043e\u0434\u0435\u0440\u0436\u0438\u0442 \u0445\u043e\u0440\u043e\u0448\u043e \u043d\u0430\u043f\u0438\u0441\u0430\u043d\u043d\u0430\u044f \u043f\u0435\u0440\u0441\u043e\u043d\u0430 \u0434\u043b\u044f senior fullstack \u0438\u043d\u0436\u0435\u043d\u0435\u0440\u0430:\u041a\u043e\u043d\u043a\u0440\u0435\u0442\u043d\u044b\u0435 \u0430\u0440\u0445\u0438\u0442\u0435\u043a\u0442\u0443\u0440\u043d\u044b\u0435 \u043f\u0440\u0438\u043d\u0446\u0438\u043f\u044b (\u043a\u043e\u0433\u0434\u0430 \u043f\u043e\u0434\u043d\u0438\u043c\u0430\u0442\u044c \u0441\u0442\u0435\u0439\u0442, \u043a\u043e\u0433\u0434\u0430 \u043d\u0435\u0442) \ud83d\udcd0\u0416\u0435\u0441\u0442\u043a\u0438\u0435 \u043f\u0440\u0430\u0432\u0438\u043b\u0430 \u043f\u043e \u0438\u043c\u0435\u043d\u043e\u0432\u0430\u043d\u0438\u044e \u0438 \u0441\u0442\u0440\u0443\u043a\u0442\u0443\u0440\u0435 \ud83d\uddc2\ufe0f\u041e\u0431\u044f\u0437\u0430\u0442\u0435\u043b\u044c\u043d\u044b\u0435 \u043f\u0430\u0442\u0442\u0435\u0440\u043d\u044b \u0434\u043b\u044f \u043a\u043e\u043d\u043a\u0440\u0435\u0442\u043d\u044b\u0445 \u0441\u0446\u0435\u043d\u0430\u0440\u0438\u0435\u0432 (data fetching, error boundaries, loading states) \ud83d\udd04\u042f\u0432\u043d\u044b\u0435 \u0437\u0430\u043f\u0440\u0435\u0442\u044b \u043d\u0430 \u0434\u0435\u0439\u0441\u0442\u0432\u0438\u044f \u0431\u0435\u0437 \u0441\u043e\u0433\u043b\u0430\u0441\u043e\u0432\u0430\u043d\u0438\u044f \ud83d\uded1\u0421\u0442\u0430\u043d\u0434\u0430\u0440\u0442\u044b code review \u0438 \u043a\u0440\u0438\u0442\u0435\u0440\u0438\u0438 \u0433\u043e\u0442\u043e\u0432\u043d\u043e\u0441\u0442\u0438 \u043a PR \ud83e\udd1d\u0420\u0430\u0437\u043d\u0438\u0446\u0430 \u043c\u0435\u0436\u0434\u0443 \u0448\u0430\u0431\u043b\u043e\u043d\u043d\u044b\u043c \u00abact as senior developer\u00bb \u0438 \u0434\u0435\u0442\u0430\u043b\u044c\u043d\u043e\u0439 \u0438\u043d\u0441\u0442\u0440\u0443\u043a\u0446\u0438\u0435\u0439 \u0441\u0440\u0430\u0432\u043d\u0438\u043c\u0430 \u0441 \u0440\u0430\u0437\u043d\u0438\u0446\u0435\u0439 \u043c\u0435\u0436\u0434\u0443 \u0434\u0436\u0443\u043d\u0438\u043e\u0440\u043e\u043c \u0438 \u0442\u0435\u0445\u043b\u0438\u0434\u043e\u043c. \ud83d\udc68\u200d\ud83d\udcbb\ud83d\udce6 proagents: 794 \u0442\u0430\u043a\u0438\u0445 \u043f\u0440\u043e\u043c\u043f\u0442\u0430, \u043d\u043e\u043b\u044c \u0437\u0430\u0432\u0438\u0441\u0438\u043c\u043e\u0441\u0442\u0435\u0439github.com\/Arlandaren\/proagents: \u043e\u0442\u043a\u0440\u044b\u0442\u0430\u044f \u0431\u0438\u0431\u043b\u0438\u043e\u0442\u0435\u043a\u0430, \u0441\u043e\u0431\u0440\u0430\u043d\u043d\u0430\u044f \u0438\u0437 \u0448\u0435\u0441\u0442\u0438 \u0432\u0435\u0434\u0443\u0449\u0438\u0445 \u0440\u0435\u043f\u043e\u0437\u0438\u0442\u043e\u0440\u0438\u0435\u0432 \u0441 \u0430\u0433\u0435\u043d\u0442\u043d\u044b\u043c\u0438 \u043a\u043e\u043d\u0444\u0438\u0433\u0443\u0440\u0430\u0446\u0438\u044f\u043c\u0438. \ud83d\udcc1\u0421\u0442\u0440\u0443\u043a\u0442\u0443\u0440\u0430 \u043f\u0440\u043e\u0435\u043a\u0442\u0430:proagents\/\u251c\u2500\u2500 personas\/          # 232 \u0430\u0433\u0435\u043d\u0442\u0430-\u0441\u043f\u0435\u0446\u0438\u0430\u043b\u0438\u0441\u0442\u0430\u2502   \u251c\u2500\u2500 engineering\/   # 126 \u0438\u043d\u0436\u0435\u043d\u0435\u0440\u043d\u044b\u0445 \u0440\u043e\u043b\u0435\u0439\u2502   \u251c\u2500\u2500 design\/        # 15 \u0434\u0438\u0437\u0430\u0439\u043d-\u043f\u0435\u0440\u0441\u043e\u043d\u2502   \u251c\u2500\u2500 operations\/    # 33 \u043e\u043f\u0435\u0440\u0430\u0446\u0438\u043e\u043d\u043d\u044b\u0445 \u0440\u043e\u043b\u0438\u2502   \u2514\u2500\u2500 &#8230;\u251c\u2500\u2500 workflows\/         # 521 \u0438\u0441\u043f\u043e\u043b\u043d\u044f\u0435\u043c\u044b\u0439 \u0447\u0435\u043a\u043b\u0438\u0441\u0442\u2502   \u251c\u2500\u2500 development\/   # 363 \u0432\u043e\u0440\u043a\u0444\u043b\u043e\u0443 \u0440\u0430\u0437\u0440\u0430\u0431\u043e\u0442\u043a\u0438\u2502   \u251c\u2500\u2500 security\/      # 64 \u0447\u0435\u043a\u043b\u0438\u0441\u0442\u0430 \u0431\u0435\u0437\u043e\u043f\u0430\u0441\u043d\u043e\u0441\u0442\u0438\u2502   \u2514\u2500\u2500 &#8230;\u2514\u2500\u2500 rules\/             # 41 \u043f\u0440\u0430\u0432\u0438\u043b\u043e \u0433\u0435\u043d\u0435\u0440\u0430\u0446\u0438\u0438    \u251c\u2500\u2500 taste\/         # \u0412\u0438\u0437\u0443\u0430\u043b\u044c\u043d\u044b\u0435 \u0441\u0442\u0430\u043d\u0434\u0430\u0440\u0442\u044b    \u2514\u2500\u2500 core\/          # \u0413\u0438\u0433\u0438\u0435\u043d\u0430 \u043a\u043e\u0434\u0430\u0423\u0441\u0442\u0430\u043d\u043e\u0432\u043a\u0430 \u0432 IDE \u0432\u044b\u043f\u043e\u043b\u043d\u044f\u0435\u0442\u0441\u044f \u043e\u0434\u043d\u043e\u0439 \u043a\u043e\u043c\u0430\u043d\u0434\u043e\u0439: \u26a1git clone https:\/\/github.com\/Arlandaren\/proagents.gitcd proagents.\/proagents install react-patterns &#8212;cursor\u041d\u0430\u0441\u0442\u0440\u043e\u0439\u043a\u0430 \u0437\u0430\u0432\u0435\u0440\u0448\u0435\u043d\u0430. \u0420\u0435\u0434\u0430\u043a\u0442\u043e\u0440 Cursor \u0442\u0435\u043f\u0435\u0440\u044c \u0437\u043d\u0430\u0435\u0442 \u0432\u0430\u0448\u0438 \u0441\u0442\u0430\u043d\u0434\u0430\u0440\u0442\u044b. \ud83c\udf89\ud83c\udfa8 \u0420\u0430\u0437\u0431\u043e\u0440: \u0447\u0442\u043e \u043c\u0435\u043d\u044f\u0435\u0442\u0441\u044f \u0441 rules\/taste\/\u041f\u0430\u043f\u043a\u0430 rules\/taste\/, \u043f\u043e\u0436\u0430\u043b\u0443\u0439, \u0441\u0430\u043c\u0430\u044f \u043d\u0435\u0434\u043e\u043e\u0446\u0435\u043d\u0435\u043d\u043d\u0430\u044f \u0447\u0430\u0441\u0442\u044c \u0440\u0435\u043f\u043e\u0437\u0438\u0442\u043e\u0440\u0438\u044f. \u041e\u043d\u0430 \u043d\u0435 \u043e\u043f\u0438\u0441\u044b\u0432\u0430\u0435\u0442 \u0440\u043e\u043b\u044c. \u041e\u043d\u0430 \u043e\u043f\u0438\u0441\u044b\u0432\u0430\u0435\u0442 \u044d\u0441\u0442\u0435\u0442\u0438\u043a\u0443. \u2728animate.md \ud83c\udfc3\u200d\u2642\ufe0f\u0417\u0430\u043f\u0440\u0435\u0449\u0430\u0435\u0442 CSS transition \u0438 animation \u0432 \u043f\u043e\u043b\u044c\u0437\u0443 spring physics. \u0412\u043c\u0435\u0441\u0442\u043e transition: all 0.3s ease \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u0442\u0441\u044f useSpring \u0438\u0437 framer-motion \u0441 \u043a\u043e\u043d\u043a\u0440\u0435\u0442\u043d\u044b\u043c\u0438 \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u044f\u043c\u0438 stiffness \u0438 damping. \u0412 \u0440\u0435\u0437\u0443\u043b\u044c\u0442\u0430\u0442\u0435 \u0430\u043d\u0438\u043c\u0430\u0446\u0438\u0438 \u043e\u0449\u0443\u0449\u0430\u044e\u0442\u0441\u044f \u0444\u0438\u0437\u0438\u0447\u0435\u0441\u043a\u0438 \u043f\u0440\u0430\u0432\u0434\u043e\u043f\u043e\u0434\u043e\u0431\u043d\u044b\u043c\u0438, \u0430 \u043d\u0435 \u043f\u0440\u043e\u0441\u0442\u043e \u00ab\u043f\u043b\u0430\u0432\u043d\u044b\u043c\u0438\u00bb.liquid-glass.md \ud83d\udd2e\u041d\u0430\u0441\u0442\u0440\u043e\u0439\u043a\u0430 \u044d\u0444\u0444\u0435\u043a\u0442\u0430 Glassmorphism. \u041d\u0438\u043a\u0430\u043a\u0438\u0445 backdrop-filter: blur(10px) \u043d\u0430\u0443\u0433\u0430\u0434, \u0442\u043e\u043b\u044c\u043a\u043e \u043f\u0440\u043e\u0432\u0435\u0440\u0435\u043d\u043d\u044b\u0435 \u043a\u043e\u043c\u0431\u0438\u043d\u0430\u0446\u0438\u0438 blur, saturation \u0438 overlay-\u0446\u0432\u0435\u0442\u043e\u0432, \u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u0440\u0430\u0431\u043e\u0442\u0430\u044e\u0442 \u043d\u0430 \u0440\u0430\u0437\u043d\u044b\u0445 \u0444\u043e\u043d\u0430\u0445. \u0414\u043e\u043f\u043e\u043b\u043d\u0438\u0442\u0435\u043b\u044c\u043d\u043e \u043e\u043f\u0438\u0441\u0430\u043d\u044b \u043f\u0440\u0430\u0432\u0438\u043b\u0430, \u043a\u043e\u0433\u0434\u0430 \u044d\u0442\u043e\u0442 \u044d\u0444\u0444\u0435\u043a\u0442 \u0443\u043c\u0435\u0441\u0442\u0435\u043d, \u0430 \u043a\u043e\u0433\u0434\u0430 \u0441\u043e\u0437\u0434\u0430\u0435\u0442 \u043f\u0440\u043e\u0431\u043b\u0435\u043c\u044b \u0441 \u0434\u043e\u0441\u0442\u0443\u043f\u043d\u043e\u0441\u0442\u044c\u044e \u0438\u043d\u0442\u0435\u0440\u0444\u0435\u0439\u0441\u0430.bolder.md \u270d\ufe0f\u0422\u0438\u043f\u043e\u0433\u0440\u0430\u0444\u0438\u043a\u0430 \u0431\u0435\u0437 \u043a\u043e\u043c\u043f\u0440\u043e\u043c\u0438\u0441\u0441\u043e\u0432. \u0418\u0435\u0440\u0430\u0440\u0445\u0438\u044f \u043a\u043e\u043d\u0442\u0440\u0430\u0441\u0442\u0430, \u043f\u0440\u0430\u0432\u0438\u043b\u0430 \u0434\u043b\u044f font-weight, \u0437\u0430\u043f\u0440\u0435\u0442 \u043d\u0430 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043d\u0438\u0435 color: #888888 \u0432 \u043a\u0430\u0447\u0435\u0441\u0442\u0432\u0435 \u043d\u0435\u0439\u0442\u0440\u0430\u043b\u044c\u043d\u043e\u0433\u043e \u0446\u0432\u0435\u0442\u0430. \u0422\u0435\u043a\u0441\u0442 \u043b\u0438\u0431\u043e \u0447\u0438\u0442\u0430\u0435\u0442\u0441\u044f, \u043b\u0438\u0431\u043e \u0435\u0433\u043e \u043d\u0435\u0442.overdrive.md \ud83d\udc8e\u0418\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u0442\u0441\u044f, \u043a\u043e\u0433\u0434\u0430 \u043d\u0443\u0436\u0435\u043d \u043c\u0430\u043a\u0441\u0438\u043c\u0430\u043b\u044c\u043d\u044b\u0439 \u043f\u0440\u0435\u043c\u0438\u0430\u043b\u044c\u043d\u044b\u0439 \u0432\u0438\u0434. \u0412\u044b\u0441\u043e\u043a\u0430\u044f \u0432\u0438\u0437\u0443\u0430\u043b\u044c\u043d\u0430\u044f \u043f\u043b\u043e\u0442\u043d\u043e\u0441\u0442\u044c \u043f\u0440\u0438 \u0441\u043e\u0445\u0440\u0430\u043d\u0435\u043d\u0438\u0438 \u0447\u0438\u0442\u0430\u0435\u043c\u043e\u0441\u0442\u0438. \u042d\u0442\u043e\u0442 \u0444\u0430\u0439\u043b \u0441\u0442\u043e\u0438\u0442 \u043f\u0440\u0438\u043c\u0435\u043d\u044f\u0442\u044c \u0442\u043e\u0447\u0435\u0447\u043d\u043e, \u0442\u0430\u043a \u043a\u0430\u043a \u043e\u043d \u0434\u0435\u043b\u0430\u0435\u0442 UI \u0430\u0433\u0440\u0435\u0441\u0441\u0438\u0432\u043d\u043e \u0432\u044b\u0440\u0430\u0437\u0438\u0442\u0435\u043b\u044c\u043d\u044b\u043c.\ud83d\udcbb \u041a\u043e\u043d\u043a\u0440\u0435\u0442\u043d\u044b\u0439 \u043f\u0440\u0438\u043c\u0435\u0440: \u0434\u043e \u0438 \u043f\u043e\u0441\u043b\u0435\u0417\u0430\u0434\u0430\u0447\u0430: \u043d\u0430\u043f\u0438\u0441\u0430\u0442\u044c \u043a\u0430\u0440\u0442\u043e\u0447\u043a\u0443 \u043f\u0440\u043e\u0434\u0443\u043a\u0442\u0430 \u0432 React.\u0411\u0435\u0437 \u0441\u0438\u0441\u0442\u0435\u043c\u043d\u043e\u0433\u043e \u043f\u0440\u043e\u043c\u043f\u0442\u0430: \u274cfunction ProductCard({ product }) {  return (    &lt;div style={{ border: &#8216;1px solid #ccc&#8217;, padding: &#8217;16px&#8217;, borderRadius: &#8216;8px&#8217; }}&gt;      &lt;img src={product.image} alt={product.name} \/&gt;      &lt;h3&gt;{product.name}&lt;\/h3&gt;      &lt;p&gt;{product.price}&lt;\/p&gt;      &lt;button onClick={() =&gt; addToCart(product.id)}&gt;Add to Cart&lt;\/button&gt;    &lt;\/div&gt;  );}\u041a\u043e\u0434 \u0440\u0430\u0431\u043e\u0442\u0430\u0435\u0442, \u043d\u043e \u0432\u044b\u0433\u043b\u044f\u0434\u0438\u0442 \u0441\u043b\u0430\u0431\u043e. \u0410\u0442\u0440\u0438\u0431\u0443\u0442 alt \u043d\u0435 \u043d\u0435\u0441\u0435\u0442 \u0441\u043c\u044b\u0441\u043b\u0430. \u041d\u0435\u0442 \u0441\u043e\u0441\u0442\u043e\u044f\u043d\u0438\u044f \u0437\u0430\u0433\u0440\u0443\u0437\u043a\u0438, \u043e\u0442\u0441\u0443\u0442\u0441\u0442\u0432\u0443\u0435\u0442 \u043e\u0431\u0440\u0430\u0431\u043e\u0442\u043a\u0430 \u043e\u0448\u0438\u0431\u043e\u043a. \u041f\u0435\u0440\u0435\u043c\u0435\u043d\u043d\u0430\u044f addToCart \u0431\u0435\u0440\u0435\u0442\u0441\u044f \u0438\u0437 \u043d\u0438\u043e\u0442\u043a\u0443\u0434\u0430. \ud83d\ude12\u0421 react-patterns + animate \u0438\u0437 proagents: \u2705interface ProductCardProps {  product: Product;  onAddToCart: (productId: string) =&gt; void;}function ProductCard({ product, onAddToCart }: ProductCardProps) {  const [isAdding, setIsAdding] = useState(false);  const cardSpring = useSpring({ scale: 1, config: { stiffness: 300, damping: 20 } });  const handleAddToCart = async () =&gt; {    setIsAdding(true);    await onAddToCart(product.id);    setIsAdding(false);  };  return (    &lt;animated.article      style={cardSpring}      onMouseEnter={() =&gt; cardSpring.scale.set(1.02)}      onMouseLeave={() =&gt; cardSpring.scale.set(1)}      aria-label={`${product.name}, ${formatPrice(product.price)}`}    &gt;      &lt;img        src={product.imageUrl}        alt={product.name}        loading=&#187;lazy&#187;      \/&gt;      &lt;h3&gt;{product.name}&lt;\/h3&gt;      &lt;p&gt;{formatPrice(product.price)}&lt;\/p&gt;      &lt;button        onClick={handleAddToCart}        disabled={isAdding}        aria-busy={isAdding}      &gt;        {isAdding ? &#8216;\u0414\u043e\u0431\u0430\u0432\u043b\u044f\u0435\u043c&#8230;&#8217; : &#8216;\u0412 \u043a\u043e\u0440\u0437\u0438\u043d\u0443&#8217;}      &lt;\/button&gt;    &lt;\/animated.article&gt;  );}\u041a\u043e\u0434 \u043f\u043e\u043b\u043d\u043e\u0441\u0442\u044c\u044e \u0442\u0438\u043f\u0438\u0437\u0438\u0440\u043e\u0432\u0430\u043d. \u0424\u0443\u043d\u043a\u0446\u0438\u044f onAddToCart \u043a\u043e\u0440\u0440\u0435\u043a\u0442\u043d\u043e \u043f\u0435\u0440\u0435\u0434\u0430\u0435\u0442\u0441\u044f \u0447\u0435\u0440\u0435\u0437 props. \u0414\u043e\u0431\u0430\u0432\u043b\u0435\u043d\u043e \u0441\u043e\u0441\u0442\u043e\u044f\u043d\u0438\u0435 \u0437\u0430\u0433\u0440\u0443\u0437\u043a\u0438 \u0438 \u043f\u043e\u0434\u0434\u0435\u0440\u0436\u043a\u0430 \u0434\u043e\u0441\u0442\u0443\u043f\u043d\u043e\u0441\u0442\u0438. \u0420\u0435\u0430\u043b\u0438\u0437\u043e\u0432\u0430\u043d\u0430 spring-\u0430\u043d\u0438\u043c\u0430\u0446\u0438\u044f \u0441 \u043a\u043e\u043d\u043a\u0440\u0435\u0442\u043d\u044b\u043c\u0438 \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u044f\u043c\u0438. \u0424\u043e\u0440\u043c\u0430\u0442\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u0435 \u0446\u0435\u043d\u044b \u0432\u044b\u043d\u0435\u0441\u0435\u043d\u043e \u0432 formatPrice. \ud83d\udc4d\u041c\u043e\u0434\u0435\u043b\u044c \u043d\u0435 \u0441\u0442\u0430\u043b\u0430 \u0443\u043c\u043d\u0435\u0435. \u041f\u0440\u043e\u0441\u0442\u043e \u043f\u043e\u043b\u0443\u0447\u0438\u043b\u0430 \u043f\u0440\u0430\u0432\u0438\u043b\u044c\u043d\u043e\u0435 \u0422\u0417. \ud83e\udde0\ud83d\udd0c \u041a\u0430\u043a\u0438\u0435 IDE \u043f\u043e\u0434\u0434\u0435\u0440\u0436\u0438\u0432\u0430\u044e\u0442\u0441\u044fIDE\u041a\u043e\u043c\u0430\u043d\u0434\u0430Cursor \ud83d\ude80.\/proagents install &lt;name&gt; &#8212;cursorClaude Code \ud83e\udd16.\/proagents install &lt;name&gt; &#8212;stdout &gt;&gt; CLAUDE.mdWindsurf \ud83c\udf0a.\/proagents install &lt;name&gt; &#8212;windsurfGemini CLI \u264a.\/proagents install &lt;name&gt; &#8212;antigravityOpenCode \ud83d\udcbb.\/proagents install &lt;name&gt; &#8212;opencode\u041b\u044e\u0431\u043e\u0439 \ud83d\udee0\ufe0f.\/proagents install &lt;name&gt; &#8212;target \/path\/to\/file\u26a1 \u041f\u043e\u043f\u0440\u043e\u0431\u0443\u0439\u0442\u0435 \u043f\u0440\u044f\u043c\u043e \u0441\u0435\u0439\u0447\u0430\u0441git clone https:\/\/github.com\/Arlandaren\/proagents.gitcd proagents.\/proagents search security  # \u043d\u0430\u0439\u0434\u0438\u0442\u0435 \u043d\u0443\u0436\u043d\u044b\u0435 \u0444\u0430\u0439\u043b\u044b.\/proagents install owasp-threat-modeling &#8212;stdout  # \u043f\u0440\u043e\u0441\u043c\u043e\u0442\u0440\u0438\u0442\u0435 \u0441\u043e\u0434\u0435\u0440\u0436\u0438\u043c\u043e\u0435\u0420\u0435\u043f\u043e\u0437\u0438\u0442\u043e\u0440\u0438\u0439: github.com\/Arlandaren\/proagents \u2b50\u0415\u0441\u043b\u0438 \u0431\u0438\u0431\u043b\u0438\u043e\u0442\u0435\u043a\u0430 \u0443\u043f\u0440\u043e\u0441\u0442\u0438\u043b\u0430 \u0432\u0430\u0448\u0443 \u0440\u0430\u0431\u043e\u0442\u0443, \u043f\u043e\u0434\u0434\u0435\u0440\u0436\u0438\u0442\u0435 \u043f\u0440\u043e\u0435\u043a\u0442 \u0437\u0432\u0435\u0437\u0434\u043e\u0439 \u043d\u0430 GitHub \u0438 \u043b\u0430\u0439\u043a\u043e\u043c \u043d\u0430 \u0425\u0430\u0431\u0440\u0435. \u0415\u0441\u043b\u0438 \u0443 \u0432\u0430\u0441 \u0435\u0441\u0442\u044c \u0441\u0432\u043e\u0438 \u043f\u0440\u043e\u0432\u0435\u0440\u0435\u043d\u043d\u044b\u0435 \u043f\u0440\u043e\u043c\u043f\u0442\u044b, \u043f\u0443\u043b\u0440\u0435\u043a\u0432\u0435\u0441\u0442\u044b \u043f\u0440\u0438\u0432\u0435\u0442\u0441\u0442\u0432\u0443\u044e\u0442\u0441\u044f. \ud83e\udd1d\u0441\u0441\u044b\u043b\u043a\u0430 \u043d\u0430 \u043e\u0440\u0438\u0433\u0438\u043d\u0430\u043b \u0441\u0442\u0430\u0442\u044c\u0438 https:\/\/habr.com\/ru\/articles\/1042444\/<\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"closed","ping_status":"closed","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[],"tags":[],"class_list":["post-481996","post","type-post","status-publish","format-standard","hentry"],"_links":{"self":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/posts\/481996","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Fcomments&post=481996"}],"version-history":[{"count":0,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/posts\/481996\/revisions"}],"wp:attachment":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Fmedia&parent=481996"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Fcategories&post=481996"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Ftags&post=481996"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}