{"id":63946,"date":"2024-05-27T19:01:54","date_gmt":"2024-05-27T15:31:54","guid":{"rendered":"https:\/\/nabfollower.com\/blog\/saladui-%d8%a7%d8%ac%d8%b1%d8%a7%db%8c-%d9%85%d9%88%d9%84%d9%81%d9%87-%d8%a2%d9%88%d8%a7%d8%aa%d8%a7%d8%b1-%d8%a8%d8%b1%d8%a7%db%8c-phoenix-liveview\/"},"modified":"2024-05-27T19:01:54","modified_gmt":"2024-05-27T15:31:54","slug":"saladui-%d8%a7%d8%ac%d8%b1%d8%a7%db%8c-%d9%85%d9%88%d9%84%d9%81%d9%87-%d8%a2%d9%88%d8%a7%d8%aa%d8%a7%d8%b1-%d8%a8%d8%b1%d8%a7%db%8c-phoenix-liveview","status":"publish","type":"post","link":"https:\/\/nabfollower.com\/blog\/saladui-%d8%a7%d8%ac%d8%b1%d8%a7%db%8c-%d9%85%d9%88%d9%84%d9%81%d9%87-%d8%a2%d9%88%d8%a7%d8%aa%d8%a7%d8%b1-%d8%a8%d8%b1%d8%a7%db%8c-phoenix-liveview\/","title":{"rendered":"SaladUI &#8211; \u0627\u062c\u0631\u0627\u06cc \u0645\u0648\u0644\u0641\u0647 \u0622\u0648\u0627\u062a\u0627\u0631 \u0628\u0631\u0627\u06cc Phoenix LiveView"},"content":{"rendered":"<p><\/p>\n<div data-article-id=\"1866670\" id=\"article-body\">\n<p>\u0627\u06cc\u0646 \u067e\u0633\u062a \u067e\u0633 \u0627\u0632 \u067e\u06cc\u0627\u062f\u0647\u200c\u0633\u0627\u0632\u06cc \u0645\u0624\u0644\u0641\u0647 Avatar \u0628\u0631\u0627\u06cc \u06a9\u062a\u0627\u0628\u062e\u0627\u0646\u0647 \u0645\u0624\u0644\u0641\u0647 SaladUI \u0628\u0631\u0627\u06cc Phoenix Liveview \u0646\u0648\u0634\u062a\u0647 \u0634\u062f\u0647 \u0627\u0633\u062a.<\/p>\n<p>\u06cc\u06a9 \u062c\u0632\u0621 \u0622\u0648\u0627\u062a\u0627\u0631 \u0628\u0633\u06cc\u0627\u0631 \u0633\u0627\u062f\u0647 \u0627\u0633\u062a\u060c \u0627\u0645\u0627 \u0645\u0646 \u0645\u06cc\u200c\u062e\u0648\u0627\u0647\u0645 \u0622\u0646 \u0631\u0627 \u0628\u0627 \u0645\u062a\u0646 \u0622\u0648\u0627\u062a\u0627\u0631 \u0628\u0647\u0628\u0648\u062f \u0628\u0628\u062e\u0634\u0645.  \u0633\u0627\u062e\u062a\u0627\u0631 \u0642\u0627\u0644\u0628 \u0628\u0647 \u0635\u0648\u0631\u062a \u0632\u06cc\u0631 \u0627\u0633\u062a:<\/p>\n<div class=\"highlight js-code-highlight\">\n<pre class=\"highlight html\"><code><span class=\"nt\">&lt;<\/span><span class=\"err\">.<\/span><span class=\"na\">avatar<\/span><span class=\"nt\">&gt;<\/span>\n  <span class=\"nt\">&lt;<\/span><span class=\"err\">.<\/span><span class=\"na\">avatar_image<\/span> <span class=\"na\">src=<\/span><span class=\"s\">\".\/my-profile-img.jpg\"<\/span><span class=\"nt\">&gt;<\/span><span class=\"err\">.<\/span><span class=\"nt\">avatar_image&gt;<\/span>\n  <span class=\"nt\">&lt;<\/span><span class=\"err\">.<\/span><span class=\"na\">avatar_fallback<\/span> <span class=\"na\">class=<\/span><span class=\"s\">\"bg-primary text-white\"<\/span><span class=\"nt\">&gt;<\/span>CN<span class=\"nt\"\/><span class=\"err\">.<\/span><span class=\"nt\">avatar_fallback&gt;<\/span>\n<span class=\"nt\">&lt;<\/span><span class=\"err\">.<\/span><span class=\"na\">avatar<\/span><span class=\"nt\">&gt;<\/span>\n<\/code><\/pre>\n<div class=\"highlight__panel js-actions-panel\">\n<div class=\"highlight__panel-action js-fullscreen-code-action\">\n    <svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" width=\"20px\" height=\"20px\" viewbox=\"0 0 24 24\" class=\"highlight-action crayons-icon highlight-action--fullscreen-on\"><title>\u0648\u0627\u0631\u062f \u062d\u0627\u0644\u062a \u062a\u0645\u0627\u0645 \u0635\u0641\u062d\u0647 \u0634\u0648\u06cc\u062f<\/title>\n    <path d=\"M16 3h6v6h-2V5h-4V3zM2 3h6v2H4v4H2V3zm18 16v-4h2v6h-6v-2h4zM4 19h4v2H2v-6h2v4z\"\/>\n<\/svg><\/p>\n<p>    <svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" width=\"20px\" height=\"20px\" viewbox=\"0 0 24 24\" class=\"highlight-action crayons-icon highlight-action--fullscreen-off\"><title>\u0627\u0632 \u062d\u0627\u0644\u062a \u062a\u0645\u0627\u0645 \u0635\u0641\u062d\u0647 \u062e\u0627\u0631\u062c \u0634\u0648\u06cc\u062f<\/title>\n    <path d=\"M18 7h4v2h-6V3h2v4zM8 9H2V7h4V3h2v6zm10 8v4h-2v-6h6v2h-4zM8 15v6H6v-4H2v-2h6z\"\/>\n<\/svg><\/p>\n<\/div>\n<\/div>\n<\/div>\n<p>\u062f\u0631 \u0627\u06cc\u0646\u062c\u0627 \u067e\u06cc\u0627\u062f\u0647 \u0633\u0627\u0632\u06cc \u062c\u0632\u0621 \u0622\u0648\u0627\u062a\u0627\u0631 \u062f\u0631 html \u0622\u0645\u062f\u0647 \u0627\u0633\u062a<\/p>\n<div class=\"highlight js-code-highlight\">\n<pre class=\"highlight html\"><code><span class=\"nt\"><span> <span class=\"na\">class=<\/span><span class=\"s\">\"relative rounded-full overflow-hidden w-10 h-10\"<\/span><span class=\"nt\">&gt;<\/span>\n    <span class=\"nt\"><img\/> <span class=\"na\">class=<\/span><span class=\"s\">\"aspect-square w-full h-full\"<\/span> <span class=\"na\">src=<\/span><span class=\"s\">\"https:\/\/github.com\/shadcn.png\"<\/span><span class=\"nt\">&gt;<\/span>\n    <span class=\"nt\"><span> <span class=\"na\">class=<\/span><span class=\"s\">\"flex rounded-full bg-primary text-white items-center justify-center w-full h-full\"<\/span><span class=\"nt\">&gt;<\/span>CN<span class=\"nt\"\/><\/span>\n<span class=\"nt\"\/><\/span>\n<\/span><\/span><\/span><\/code><\/pre>\n<div class=\"highlight__panel js-actions-panel\">\n<div class=\"highlight__panel-action js-fullscreen-code-action\">\n    <svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" width=\"20px\" height=\"20px\" viewbox=\"0 0 24 24\" class=\"highlight-action crayons-icon highlight-action--fullscreen-on\"><title>\u0648\u0627\u0631\u062f \u062d\u0627\u0644\u062a \u062a\u0645\u0627\u0645 \u0635\u0641\u062d\u0647 \u0634\u0648\u06cc\u062f<\/title>\n    <path d=\"M16 3h6v6h-2V5h-4V3zM2 3h6v2H4v4H2V3zm18 16v-4h2v6h-6v-2h4zM4 19h4v2H2v-6h2v4z\"\/>\n<\/svg><\/p>\n<p>    <svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" width=\"20px\" height=\"20px\" viewbox=\"0 0 24 24\" class=\"highlight-action crayons-icon highlight-action--fullscreen-off\"><title>\u0627\u0632 \u062d\u0627\u0644\u062a \u062a\u0645\u0627\u0645 \u0635\u0641\u062d\u0647 \u062e\u0627\u0631\u062c \u0634\u0648\u06cc\u062f<\/title>\n    <path d=\"M18 7h4v2h-6V3h2v4zM8 9H2V7h4V3h2v6zm10 8v4h-2v-6h6v2h-4zM8 15v6H6v-4H2v-2h6z\"\/>\n<\/svg><\/p>\n<\/div>\n<\/div>\n<\/div>\n<p><img decoding=\"async\" src=\"https:\/\/media.dev.to\/cdn-cgi\/image\/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto\/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2F3001dp2sgguqeyxk2irh.png\" alt=\"\u062a\u0648\u0636\u06cc\u062d\u0627\u062a \u062a\u0635\u0648\u06cc\u0631\" loading=\"lazy\" width=\"800\" height=\"234\" title=\"\"><\/p>\n<p>\u0627\u06cc\u0646 \u0645\u0648\u0631\u062f \u062e\u0648\u0634\u062d\u0627\u0644 \u06a9\u0646\u0646\u062f\u0647 \u0627\u0633\u062a\u060c \u062a\u0635\u0648\u06cc\u0631 \u0648\u062c\u0648\u062f \u062f\u0627\u0631\u062f\u060c \u0648 \u0639\u0646\u0635\u0631 \u0628\u0627\u0632\u06af\u0634\u062a\u06cc \u0628\u0647 \u062f\u0644\u06cc\u0644 \u06a9\u0644\u0627\u0633 \u0628\u0647 \u067e\u0627\u06cc\u06cc\u0646 \u0641\u0634\u0627\u0631 \u062f\u0627\u062f\u0647 \u0634\u062f\u0647 \u0648 \u067e\u0646\u0647\u0627\u0646 \u0645\u06cc \u0634\u0648\u062f <code>overflow-hidden<\/code>.<\/p>\n<p>\u0627\u0645\u0627 \u0632\u0645\u0627\u0646\u06cc \u06a9\u0647 \u062a\u0635\u0648\u06cc\u0631 \u0648\u062c\u0648\u062f \u0646\u062f\u0627\u0634\u062a\u0647 \u0628\u0627\u0634\u062f\u060c \u062a\u0635\u0648\u06cc\u0631 \u0634\u06a9\u0633\u062a\u0647 \u0646\u0645\u0627\u06cc\u0634 \u062f\u0627\u062f\u0647 \u0645\u06cc \u0634\u0648\u062f.<\/p>\n<p><img decoding=\"async\" src=\"https:\/\/media.dev.to\/cdn-cgi\/image\/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto\/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2Fbejgjom7ydyyd8l81brw.png\" alt=\"\u062a\u0648\u0636\u06cc\u062d\u0627\u062a \u062a\u0635\u0648\u06cc\u0631\" loading=\"lazy\" width=\"800\" height=\"237\" title=\"\"><\/p>\n<p>\u0647\u0648\u0645\u060c \u0627\u06af\u0631 \u062a\u0635\u0648\u06cc\u0631 \u0648\u062c\u0648\u062f \u0646\u062f\u0627\u0634\u062a\u0647 \u0628\u0627\u0634\u062f \u06cc\u0627 \u0647\u0646\u06af\u0627\u0645 \u0628\u0627\u0631\u06af\u06cc\u0631\u06cc \u062e\u0637\u0627 \u062f\u0627\u0634\u062a\u0647 \u0628\u0627\u0634\u062f\u060c \u0628\u0627\u06cc\u062f \u067e\u0646\u0647\u0627\u0646 \u0634\u0648\u062f.  \u062e\u0648\u0634\u0628\u062e\u062a\u0627\u0646\u0647\u060c <code>img<\/code> \u0641\u0631\u0627\u0647\u0645 \u06a9\u0646\u062f <code>onerror<\/code> \u0631\u0648\u06cc\u062f\u0627\u062f.<\/p>\n<div class=\"highlight js-code-highlight\">\n<pre class=\"highlight html\"><code><span class=\"nt\"><span> <span class=\"na\">class=<\/span><span class=\"s\">\"relative rounded-full overflow-hidden w-10 h-10\"<\/span><span class=\"nt\">&gt;<\/span>\n    <span class=\"nt\"><img\/> <span class=\"na\">class=<\/span><span class=\"s\">\"aspect-square w-full h-full\"<\/span> <span class=\"na\">src=<\/span><span class=\"s\">\"badimage.png\"<\/span> <span class=\"na\">onerror=<\/span><span class=\"s\">\"this.style.display='none'\"<\/span><span class=\"nt\">&gt;<\/span>\n    <span class=\"nt\"><span> <span class=\"na\">class=<\/span><span class=\"s\">\"flex rounded-full bg-primary text-white items-center justify-center w-full h-full\"<\/span><span class=\"nt\">&gt;<\/span>CN<span class=\"nt\"\/><\/span>\n<span class=\"nt\"\/><\/span>\n<\/span><\/span><\/span><\/code><\/pre>\n<div class=\"highlight__panel js-actions-panel\">\n<div class=\"highlight__panel-action js-fullscreen-code-action\">\n    <svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" width=\"20px\" height=\"20px\" viewbox=\"0 0 24 24\" class=\"highlight-action crayons-icon highlight-action--fullscreen-on\"><title>\u0648\u0627\u0631\u062f \u062d\u0627\u0644\u062a \u062a\u0645\u0627\u0645 \u0635\u0641\u062d\u0647 \u0634\u0648\u06cc\u062f<\/title>\n    <path d=\"M16 3h6v6h-2V5h-4V3zM2 3h6v2H4v4H2V3zm18 16v-4h2v6h-6v-2h4zM4 19h4v2H2v-6h2v4z\"\/>\n<\/svg><\/p>\n<p>    <svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" width=\"20px\" height=\"20px\" viewbox=\"0 0 24 24\" class=\"highlight-action crayons-icon highlight-action--fullscreen-off\"><title>\u0627\u0632 \u062d\u0627\u0644\u062a \u062a\u0645\u0627\u0645 \u0635\u0641\u062d\u0647 \u062e\u0627\u0631\u062c \u0634\u0648\u06cc\u062f<\/title>\n    <path d=\"M18 7h4v2h-6V3h2v4zM8 9H2V7h4V3h2v6zm10 8v4h-2v-6h6v2h-4zM8 15v6H6v-4H2v-2h6z\"\/>\n<\/svg><\/p>\n<\/div>\n<\/div>\n<\/div>\n<p>\u0645\u0647\u0645\u0627\u0646 \u0686\u06cc  \u0686\u06cc\u0632\u06cc \u062a\u063a\u06cc\u06cc\u0631 \u0646\u06a9\u0631\u062f\u0647 \u0627\u0633\u062a\u060c \u062a\u0635\u0648\u06cc\u0631 \u0634\u06a9\u0633\u062a\u0647 \u0647\u0646\u0648\u0632 \u0642\u0627\u0628\u0644 \u0645\u0634\u0627\u0647\u062f\u0647 \u0627\u0633\u062a.<br \/>\u0645\u062f\u062a\u06cc \u0637\u0648\u0644 \u06a9\u0634\u06cc\u062f \u062a\u0627 \u062f\u0644\u06cc\u0644 \u0622\u0646 \u0631\u0627 \u06a9\u0634\u0641 \u06a9\u0646\u0645. <code>onerror=\"this.style.display='none'\"<\/code> \u0648\u06cc\u0698\u06af\u06cc \u0631\u0627 \u062f\u0631 \u0633\u0645\u062a \u06a9\u0644\u0627\u06cc\u0646\u062a \u062a\u063a\u06cc\u06cc\u0631 \u062f\u0647\u06cc\u062f\u060c \u0647\u0646\u06af\u0627\u0645\u06cc \u06a9\u0647 Phoenix LiveView \u0628\u0647 \u0631\u0648\u0632 \u0645\u06cc \u0634\u0648\u062f\u060c html \u0631\u0627 \u0648\u0635\u0644\u0647 \u0645\u06cc \u06a9\u0646\u062f \u0648 \u062d\u0630\u0641 \u0645\u06cc \u06a9\u0646\u062f <code>display<\/code> \u0627\u0631\u0632\u0634 \u0633\u0628\u06a9  \u067e\u0633 \u0641\u0642\u0637 \u0627\u0636\u0627\u0641\u0647 \u06a9\u0646\u06cc\u062f <code>phx-update=\"ignore\"<\/code> \u0648 \u0634\u0645\u0627 \u062a\u0635\u0648\u06cc\u0631 \u062e\u0637\u0627 \u0631\u0627 \u0645\u062e\u0641\u06cc \u06a9\u0631\u062f\u06cc\u062f.<\/p>\n<div class=\"highlight js-code-highlight\">\n<pre class=\"highlight html\"><code><span class=\"nt\"><span> <span class=\"na\">class=<\/span><span class=\"s\">\"relative rounded-full overflow-hidden w-10 h-10\"<\/span><span class=\"nt\">&gt;<\/span>\n    <span class=\"nt\"><img\/> <span class=\"na\">class=<\/span><span class=\"s\">\"aspect-square w-full h-full\"<\/span> <span class=\"na\">src=<\/span><span class=\"s\">\"https:\/\/github.com\/shadcn.png\"<\/span> <span class=\"na\">onerror=<\/span><span class=\"s\">\"this.style.display='none'\"<\/span> <span class=\"na\">phx-update=<\/span><span class=\"s\">\"ignore\"<\/span><span class=\"nt\">&gt;<\/span>\n    <span class=\"nt\"><span> <span class=\"na\">class=<\/span><span class=\"s\">\"flex rounded-full bg-primary text-white items-center justify-center w-full h-full\"<\/span><span class=\"nt\">&gt;<\/span>CN<span class=\"nt\"\/><\/span>\n<span class=\"nt\"\/><\/span>\n<\/span><\/span><\/span><\/code><\/pre>\n<div class=\"highlight__panel js-actions-panel\">\n<div class=\"highlight__panel-action js-fullscreen-code-action\">\n    <svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" width=\"20px\" height=\"20px\" viewbox=\"0 0 24 24\" class=\"highlight-action crayons-icon highlight-action--fullscreen-on\"><title>\u0648\u0627\u0631\u062f \u062d\u0627\u0644\u062a \u062a\u0645\u0627\u0645 \u0635\u0641\u062d\u0647 \u0634\u0648\u06cc\u062f<\/title>\n    <path d=\"M16 3h6v6h-2V5h-4V3zM2 3h6v2H4v4H2V3zm18 16v-4h2v6h-6v-2h4zM4 19h4v2H2v-6h2v4z\"\/>\n<\/svg><\/p>\n<p>    <svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" width=\"20px\" height=\"20px\" viewbox=\"0 0 24 24\" class=\"highlight-action crayons-icon highlight-action--fullscreen-off\"><title>\u0627\u0632 \u062d\u0627\u0644\u062a \u062a\u0645\u0627\u0645 \u0635\u0641\u062d\u0647 \u062e\u0627\u0631\u062c \u0634\u0648\u06cc\u062f<\/title>\n    <path d=\"M18 7h4v2h-6V3h2v4zM8 9H2V7h4V3h2v6zm10 8v4h-2v-6h6v2h-4zM8 15v6H6v-4H2v-2h6z\"\/>\n<\/svg><\/p>\n<\/div>\n<\/div>\n<\/div>\n<p>\u0648 \u0647\u0645\u0627\u0646\u0637\u0648\u0631 \u06a9\u0647 \u0627\u0646\u062a\u0638\u0627\u0631 \u0645\u06cc \u0631\u0648\u062f \u06a9\u0627\u0631 \u0645\u06cc \u06a9\u0646\u062f<\/p>\n<p><img decoding=\"async\" src=\"https:\/\/media.dev.to\/cdn-cgi\/image\/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto\/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2Fkmb3oe3r18foh1gf8z4x.png\" alt=\"\u062a\u0648\u0636\u06cc\u062d\u0627\u062a \u062a\u0635\u0648\u06cc\u0631\" loading=\"lazy\" width=\"800\" height=\"218\" title=\"\"><\/p>\n<p><strong>\u062d\u0627\u0644\u0627 \u062c\u0632\u0621 \u0631\u0627 \u0628\u067e\u06cc\u0686\u06cc\u062f<\/strong><\/p>\n<div class=\"highlight js-code-highlight\">\n<pre class=\"highlight elixir\"><code><span class=\"k\">defmodule<\/span> <span class=\"no\">SaladUI<\/span><span class=\"o\">.<\/span><span class=\"no\">Avatar<\/span> <span class=\"k\">do<\/span>\n  <span class=\"nv\">@moduledoc<\/span> <span class=\"no\">false<\/span>\n  <span class=\"kn\">use<\/span> <span class=\"no\">Phoenix<\/span><span class=\"o\">.<\/span><span class=\"no\">Component<\/span>\n\n  <span class=\"n\">attr<\/span><span class=\"p\">(<\/span><span class=\"ss\">:class<\/span><span class=\"p\">,<\/span> <span class=\"ss\">:string<\/span><span class=\"p\">,<\/span> <span class=\"ss\">default:<\/span> <span class=\"no\">nil<\/span><span class=\"p\">)<\/span>\n  <span class=\"n\">attr<\/span><span class=\"p\">(<\/span><span class=\"ss\">:rest<\/span><span class=\"p\">,<\/span> <span class=\"ss\">:global<\/span><span class=\"p\">)<\/span>\n\n  <span class=\"k\">def<\/span> <span class=\"n\">avatar<\/span><span class=\"p\">(<\/span><span class=\"n\">assigns<\/span><span class=\"p\">)<\/span> <span class=\"k\">do<\/span>\n    <span class=\"sx\">~H\"\"<\/span><span class=\"s2\">\"\n    <span class=\"{classes([&quot;&lt;\/span\"><span class=\"n\">relative<\/span> <span class=\"n\">h<\/span><span class=\"o\">-<\/span><span class=\"mi\">10<\/span> <span class=\"n\">w<\/span><span class=\"o\">-<\/span><span class=\"mi\">10<\/span> <span class=\"n\">overflow<\/span><span class=\"o\">-<\/span><span class=\"n\">hidden<\/span> <span class=\"n\">rounded<\/span><span class=\"o\">-<\/span><span class=\"n\">full<\/span><span class=\"s2\">\", @class])} {@rest}&gt;\n      &lt;%= render_slot(@inner_block) %&gt;\n    <\/span>\n    \"\"\"<\/span>\n  <span class=\"k\">end<\/span>\n\n  <span class=\"n\">attr<\/span><span class=\"p\">(<\/span><span class=\"ss\">:class<\/span><span class=\"p\">,<\/span> <span class=\"ss\">:string<\/span><span class=\"p\">,<\/span> <span class=\"ss\">default:<\/span> <span class=\"no\">nil<\/span><span class=\"p\">)<\/span>\n  <span class=\"n\">attr<\/span><span class=\"p\">(<\/span><span class=\"ss\">:rest<\/span><span class=\"p\">,<\/span> <span class=\"ss\">:global<\/span><span class=\"p\">)<\/span>\n\n  <span class=\"k\">def<\/span> <span class=\"n\">avatar_image<\/span><span class=\"p\">(<\/span><span class=\"n\">assigns<\/span><span class=\"p\">)<\/span> <span class=\"k\">do<\/span>\n    <span class=\"sx\">~H\"\"<\/span><span class=\"s2\">\"\n    <img class=\"{classes([&quot;&lt;\/span\"\/><span class=\"n\">aspect<\/span><span class=\"o\">-<\/span><span class=\"n\">square<\/span> <span class=\"n\">h<\/span><span class=\"o\">-<\/span><span class=\"n\">full<\/span> <span class=\"n\">w<\/span><span class=\"o\">-<\/span><span class=\"n\">full<\/span><span class=\"s2\">\", @class])}\n      {@rest}\n      phx-update=\"<\/span><span class=\"n\">ignore<\/span><span class=\"s2\">\"\n      style=\"<\/span><span class=\"ss\">display:<\/span><span class=\"n\">none<\/span><span class=\"s2\">\"\n      onload=\"<\/span><span class=\"n\">this<\/span><span class=\"o\">.<\/span><span class=\"n\">style<\/span><span class=\"o\">.<\/span><span class=\"n\">display<\/span><span class=\"o\">=<\/span><span class=\"s1\">''<\/span><span class=\"s2\">\"\n    \/&gt;\n    \"\"\"<\/span>\n  <span class=\"k\">end<\/span>\n\n  <span class=\"n\">attr<\/span><span class=\"p\">(<\/span><span class=\"ss\">:class<\/span><span class=\"p\">,<\/span> <span class=\"ss\">:string<\/span><span class=\"p\">,<\/span> <span class=\"ss\">default:<\/span> <span class=\"no\">nil<\/span><span class=\"p\">)<\/span>\n  <span class=\"n\">attr<\/span><span class=\"p\">(<\/span><span class=\"ss\">:rest<\/span><span class=\"p\">,<\/span> <span class=\"ss\">:global<\/span><span class=\"p\">)<\/span>\n  <span class=\"n\">slot<\/span><span class=\"p\">(<\/span><span class=\"ss\">:inner_block<\/span><span class=\"p\">,<\/span> <span class=\"ss\">required:<\/span> <span class=\"no\">false<\/span><span class=\"p\">)<\/span>\n\n  <span class=\"k\">def<\/span> <span class=\"n\">avatar_fallback<\/span><span class=\"p\">(<\/span><span class=\"n\">assigns<\/span><span class=\"p\">)<\/span> <span class=\"k\">do<\/span>\n    <span class=\"sx\">~H\"\"<\/span><span class=\"s2\">\"\n    <span class=\"{\" classes=\"\"><span class=\"n\">flex<\/span> <span class=\"n\">h<\/span><span class=\"o\">-<\/span><span class=\"n\">full<\/span> <span class=\"n\">w<\/span><span class=\"o\">-<\/span><span class=\"n\">full<\/span> <span class=\"n\">items<\/span><span class=\"o\">-<\/span><span class=\"n\">center<\/span> <span class=\"n\">justify<\/span><span class=\"o\">-<\/span><span class=\"n\">center<\/span> <span class=\"n\">rounded<\/span><span class=\"o\">-<\/span><span class=\"n\">full<\/span> <span class=\"n\">bg<\/span><span class=\"o\">-<\/span><span class=\"n\">muted<\/span><span class=\"s2\">\", @class])\n      }\n      {@rest}\n    &gt;\n      &lt;%= render_slot(@inner_block) %&gt;\n    <\/span>\n    \"\"\"<\/span>\n  <span class=\"k\">end<\/span>\n<span class=\"k\">end<\/span>\n<\/span><\/span><\/span><\/code><\/pre>\n<div class=\"highlight__panel js-actions-panel\">\n<div class=\"highlight__panel-action js-fullscreen-code-action\">\n    <svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" width=\"20px\" height=\"20px\" viewbox=\"0 0 24 24\" class=\"highlight-action crayons-icon highlight-action--fullscreen-on\"><title>\u0648\u0627\u0631\u062f \u062d\u0627\u0644\u062a \u062a\u0645\u0627\u0645 \u0635\u0641\u062d\u0647 \u0634\u0648\u06cc\u062f<\/title>\n    <path d=\"M16 3h6v6h-2V5h-4V3zM2 3h6v2H4v4H2V3zm18 16v-4h2v6h-6v-2h4zM4 19h4v2H2v-6h2v4z\"\/>\n<\/svg><\/p>\n<p>    <svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" width=\"20px\" height=\"20px\" viewbox=\"0 0 24 24\" class=\"highlight-action crayons-icon highlight-action--fullscreen-off\"><title>\u0627\u0632 \u062d\u0627\u0644\u062a \u062a\u0645\u0627\u0645 \u0635\u0641\u062d\u0647 \u062e\u0627\u0631\u062c \u0634\u0648\u06cc\u062f<\/title>\n    <path d=\"M18 7h4v2h-6V3h2v4zM8 9H2V7h4V3h2v6zm10 8v4h-2v-6h6v2h-4zM8 15v6H6v-4H2v-2h6z\"\/>\n<\/svg><\/p>\n<\/div>\n<\/div>\n<\/div>\n<p>\u0645\u0645\u06a9\u0646 \u0627\u0633\u062a \u0645\u062a\u0648\u062c\u0647 \u0634\u0648\u06cc\u062f \u06a9\u0647 \u0645\u0646 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc \u06a9\u0646\u0645 <code>onload<\/code> \u0631\u0648\u06cc\u062f\u0627\u062f \u0628\u0647 \u062c\u0627\u06cc <code>onerror<\/code>:<\/p>\n<div class=\"highlight js-code-highlight\">\n<pre class=\"highlight plaintext\"><code>style=\"display:none\"\nonload=\"this.style.display=''\"\n<\/code><\/pre>\n<div class=\"highlight__panel js-actions-panel\">\n<div class=\"highlight__panel-action js-fullscreen-code-action\">\n    <svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" width=\"20px\" height=\"20px\" viewbox=\"0 0 24 24\" class=\"highlight-action crayons-icon highlight-action--fullscreen-on\"><title>\u0648\u0627\u0631\u062f \u062d\u0627\u0644\u062a \u062a\u0645\u0627\u0645 \u0635\u0641\u062d\u0647 \u0634\u0648\u06cc\u062f<\/title>\n    <path d=\"M16 3h6v6h-2V5h-4V3zM2 3h6v2H4v4H2V3zm18 16v-4h2v6h-6v-2h4zM4 19h4v2H2v-6h2v4z\"\/>\n<\/svg><\/p>\n<p>    <svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" width=\"20px\" height=\"20px\" viewbox=\"0 0 24 24\" class=\"highlight-action crayons-icon highlight-action--fullscreen-off\"><title>\u0627\u0632 \u062d\u0627\u0644\u062a \u062a\u0645\u0627\u0645 \u0635\u0641\u062d\u0647 \u062e\u0627\u0631\u062c \u0634\u0648\u06cc\u062f<\/title>\n    <path d=\"M18 7h4v2h-6V3h2v4zM8 9H2V7h4V3h2v6zm10 8v4h-2v-6h6v2h-4zM8 15v6H6v-4H2v-2h6z\"\/>\n<\/svg><\/p>\n<\/div>\n<\/div>\n<\/div>\n<p>\u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0643\u0631\u062f\u0646 <code>onerror<\/code> \u0645\u0631\u0648\u0631\u06af\u0631 \u0645\u0646\u062a\u0638\u0631 \u0645\u06cc \u0645\u0627\u0646\u062f \u062a\u0627 \u0628\u0627\u0631\u06af\u06cc\u0631\u06cc \u062a\u0635\u0648\u06cc\u0631 \u06a9\u0627\u0645\u0644 \u0634\u0648\u062f \u062a\u0627 \u062a\u0635\u0645\u06cc\u0645 \u0628\u06af\u06cc\u0631\u062f \u06a9\u0647 \u0622\u06cc\u0627 \u062e\u0637\u0627\u06cc\u06cc \u0648\u062c\u0648\u062f \u062f\u0627\u0631\u062f \u06cc\u0627 \u062e\u06cc\u0631 \u0648 \u0633\u067e\u0633 \u0631\u0648\u06cc\u062f\u0627\u062f \u0631\u0627 \u0631\u0627\u0647 \u0627\u0646\u062f\u0627\u0632\u06cc \u06a9\u0646\u062f.  \u0627\u06cc\u0646 \u0628\u0627\u0639\u062b \u0627\u06cc\u062c\u0627\u062f \u0622\u0648\u0627\u062a\u0627\u0631 \u0633\u0641\u06cc\u062f \u062f\u0631 \u0647\u0646\u06af\u0627\u0645 \u0628\u0627\u0631\u06af\u06cc\u0631\u06cc \u062a\u0635\u0648\u06cc\u0631 \u0645\u06cc \u0634\u0648\u062f.  \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0643\u0631\u062f\u0646 <code>onload<\/code> \u0631\u0648\u06cc\u062f\u0627\u062f \u0628\u0631\u0627\u06cc \u0646\u0645\u0627\u06cc\u0634 \u062a\u0635\u0648\u06cc\u0631 \u067e\u0633 \u0627\u0632 \u062a\u06a9\u0645\u06cc\u0644 \u0641\u0631\u0622\u06cc\u0646\u062f \u0628\u0627\u0631\u06af\u0630\u0627\u0631\u06cc\u060c \u0628\u0646\u0627\u0628\u0631\u0627\u06cc\u0646 \u0628\u0647 \u0637\u0648\u0631 \u067e\u06cc\u0634 \u0641\u0631\u0636 \u0627\u06af\u0631 \u0628\u0627\u0631\u06af\u0630\u0627\u0631\u06cc \u062a\u0635\u0648\u06cc\u0631 \u06a9\u0646\u062f \u0628\u0627\u0634\u062f\u060c \u0622\u0648\u0627\u062a\u0627\u0631 \u0628\u0627\u0632\u06af\u0634\u062a\u06cc \u0647\u0645\u0686\u0646\u0627\u0646 \u0646\u0645\u0627\u06cc\u0634 \u062f\u0627\u062f\u0647 \u0645\u06cc \u0634\u0648\u062f.<\/p>\n<p>\u0627\u06af\u0631 \u0645\u06cc\u200c\u062e\u0648\u0627\u0647\u06cc\u062f \u0628\u06cc\u0634\u062a\u0631 \u0628\u062f\u0627\u0646\u06cc\u062f\u060c \u0627\u0632 \u0645\u062e\u0632\u0646 github \u0645\u0646 https:\/\/github.com\/bluzky\/salad_ui \u062f\u06cc\u062f\u0646 \u06a9\u0646\u06cc\u062f.<\/p>\n<p>\u0628\u0627 \u062a\u0634\u06a9\u0631 \u0628\u0631\u0627\u06cc \u062e\u0648\u0627\u0646\u062f\u0646.<\/p>\n<\/p><\/div>\n","protected":false},"excerpt":{"rendered":"<p>\u0627\u06cc\u0646 \u067e\u0633\u062a \u067e\u0633 \u0627\u0632 \u067e\u06cc\u0627\u062f\u0647\u200c\u0633\u0627\u0632\u06cc \u0645\u0624\u0644\u0641\u0647 Avatar \u0628\u0631\u0627\u06cc \u06a9\u062a\u0627\u0628\u062e\u0627\u0646\u0647 \u0645\u0624\u0644\u0641\u0647 SaladUI \u0628\u0631\u0627\u06cc Phoenix Liveview \u0646\u0648\u0634\u062a\u0647 \u0634\u062f\u0647 \u0627\u0633\u062a. \u06cc\u06a9 \u062c\u0632\u0621 \u0622\u0648\u0627\u062a\u0627\u0631 \u0628\u0633\u06cc\u0627\u0631 \u0633\u0627\u062f\u0647 \u0627\u0633\u062a\u060c \u0627\u0645\u0627 \u0645\u0646 \u0645\u06cc\u200c\u062e\u0648\u0627\u0647\u0645 \u0622\u0646 \u0631\u0627 \u0628\u0627 \u0645\u062a\u0646 \u0622\u0648\u0627\u062a\u0627\u0631 \u0628\u0647\u0628\u0648\u062f \u0628\u0628\u062e\u0634\u0645. \u0633\u0627\u062e\u062a\u0627\u0631 \u0642\u0627\u0644\u0628 \u0628\u0647 \u0635\u0648\u0631\u062a \u0632\u06cc\u0631 \u0627\u0633\u062a: &lt;.avatar&gt; &lt;.avatar_image src=&#8221;.\/my-profile-img.jpg&#8221;&gt;.avatar_image&gt; &lt;.avatar_fallback class=&#8221;bg-primary text-white&#8221;&gt;CN.avatar_fallback&gt; &lt;.avatar&gt; \u0648\u0627\u0631\u062f \u062d\u0627\u0644\u062a \u062a\u0645\u0627\u0645 \u0635\u0641\u062d\u0647 \u0634\u0648\u06cc\u062f \u0627\u0632 \u062d\u0627\u0644\u062a \u062a\u0645\u0627\u0645 \u0635\u0641\u062d\u0647 &hellip;<\/p>\n","protected":false},"author":2,"featured_media":63947,"comment_status":"open","ping_status":"closed","sticky":false,"template":"","format":"standard","meta":{"fifu_image_url":"https:\/\/media.dev.to\/cdn-cgi\/image\/width=1000,height=500,fit=cover,gravity=auto,format=auto\/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2F194jan7pi8vn5604smhz.png","fifu_image_alt":"","footnotes":""},"categories":[339],"tags":[],"class_list":["post-63946","post","type-post","status-publish","format-standard","has-post-thumbnail","hentry","category-dev"],"_links":{"self":[{"href":"https:\/\/nabfollower.com\/blog\/wp-json\/wp\/v2\/posts\/63946","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/nabfollower.com\/blog\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/nabfollower.com\/blog\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/nabfollower.com\/blog\/wp-json\/wp\/v2\/users\/2"}],"replies":[{"embeddable":true,"href":"https:\/\/nabfollower.com\/blog\/wp-json\/wp\/v2\/comments?post=63946"}],"version-history":[{"count":0,"href":"https:\/\/nabfollower.com\/blog\/wp-json\/wp\/v2\/posts\/63946\/revisions"}],"wp:featuredmedia":[{"embeddable":true,"href":"https:\/\/nabfollower.com\/blog\/wp-json\/wp\/v2\/media\/63947"}],"wp:attachment":[{"href":"https:\/\/nabfollower.com\/blog\/wp-json\/wp\/v2\/media?parent=63946"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/nabfollower.com\/blog\/wp-json\/wp\/v2\/categories?post=63946"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/nabfollower.com\/blog\/wp-json\/wp\/v2\/tags?post=63946"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}