{"id":85662,"date":"2024-11-27T06:54:51","date_gmt":"2024-11-27T03:24:51","guid":{"rendered":"https:\/\/nabfollower.com\/blog\/mastering-authentication-with-firebase-and-reactjs-anonymous-registration-and-login-made-easy-32il\/"},"modified":"2024-11-27T06:54:51","modified_gmt":"2024-11-27T03:24:51","slug":"mastering-authentication-with-firebase-and-reactjs-anonymous-registration-and-login-made-easy-32il","status":"publish","type":"post","link":"https:\/\/nabfollower.com\/blog\/mastering-authentication-with-firebase-and-reactjs-anonymous-registration-and-login-made-easy-32il\/","title":{"rendered":"\u062a\u0633\u0644\u0637 \u0628\u0631 \u0627\u062d\u0631\u0627\u0632 \u0647\u0648\u06cc\u062a \u0628\u0627 Firebase \u0648 React.js: \u0646\u0627\u0634\u0646\u0627\u0633\u060c \u062b\u0628\u062a \u0646\u0627\u0645 \u0648 \u0648\u0631\u0648\u062f \u0622\u0633\u0627\u0646 \u062f\u0631 \u0646\u0628\u0631\u062f \u06af\u0644\u0627\u062f\u06cc\u0627\u062a\u0648\u0631\u0647\u0627"},"content":{"rendered":"<p>Summarize this content to 400 words in Persian Lang<br \/>\n              \u0627\u062d\u0631\u0627\u0632 \u0647\u0648\u06cc\u062a \u0647\u0633\u062a\u0647 \u0627\u0635\u0644\u06cc \u0647\u0631 \u0628\u0631\u0646\u0627\u0645\u0647 \u0648\u0628 \u0645\u062f\u0631\u0646 \u0627\u0633\u062a. \u0686\u0647 \u062f\u0631 \u062d\u0627\u0644 \u0633\u0627\u062e\u062a\u0646 \u06cc\u06a9 \u067e\u0644\u062a\u0641\u0631\u0645 \u062c\u0627\u0645\u0639\u0647 \u0645\u062d\u0648\u0631\u060c \u06cc\u06a9 \u0633\u0627\u06cc\u062a \u062a\u062c\u0627\u0631\u062a \u0627\u0644\u06a9\u062a\u0631\u0648\u0646\u06cc\u06a9\u060c \u06cc\u0627 \u06cc\u06a9 \u062a\u062c\u0631\u0628\u0647 \u0628\u0627\u0632\u06cc \u062a\u0639\u0627\u0645\u0644\u06cc \u0645\u0627\u0646\u0646\u062f \u0646\u0628\u0631\u062f \u06af\u0644\u0627\u062f\u06cc\u0627\u062a\u0648\u0631\u0647\u0627 \u0628\u0627\u0634\u06cc\u062f\u060c \u0627\u0631\u0627\u0626\u0647 \u06cc\u06a9 \u0633\u06cc\u0633\u062a\u0645 \u0627\u062d\u0631\u0627\u0632 \u0647\u0648\u06cc\u062a \u06cc\u06a9\u067e\u0627\u0631\u0686\u0647 \u0648 \u0627\u06cc\u0645\u0646 \u0636\u0631\u0648\u0631\u06cc \u0627\u0633\u062a. \u062f\u0631 \u0627\u06cc\u0646 \u0631\u0627\u0647\u0646\u0645\u0627\u060c \u0646\u062d\u0648\u0647 \u062a\u0646\u0638\u06cc\u0645 \u06cc\u06a9 \u062c\u0631\u06cc\u0627\u0646 \u0627\u062d\u0631\u0627\u0632 \u0647\u0648\u06cc\u062a \u0642\u0648\u06cc \u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 Firebase \u0648 React.js\u060c \u0627\u0632 \u062c\u0645\u0644\u0647 \u0627\u062d\u0631\u0627\u0632 \u0647\u0648\u06cc\u062a \u0646\u0627\u0634\u0646\u0627\u0633\u060c \u062b\u0628\u062a \u0646\u0627\u0645 \u06a9\u0627\u0631\u0628\u0631 \u0648 \u0648\u0631\u0648\u062f \u0628\u0647 \u0633\u06cc\u0633\u062a\u0645 \u0631\u0627 \u0628\u0631\u0631\u0633\u06cc \u062e\u0648\u0627\u0647\u06cc\u0645 \u06a9\u0631\u062f.<\/p>\n<p>\ud83c\udf1f \u0686\u0631\u0627 Firebase \u0628\u0631\u0627\u06cc \u0627\u062d\u0631\u0627\u0632 \u0647\u0648\u06cc\u062a\u061f<\/p>\n<p>Firebase Authentication \u0627\u0631\u0627\u0626\u0647 \u0645\u06cc \u062f\u0647\u062f:<\/p>\n<p>\u0627\u062f\u063a\u0627\u0645 \u0622\u0633\u0627\u0646 \u0628\u0627 \u0641\u0631\u06cc\u0645\u0648\u0631\u06a9 \u0647\u0627\u06cc \u0645\u062d\u0628\u0648\u0628 \u0645\u0627\u0646\u0646\u062f React.js.<br \/>\n\u067e\u0634\u062a\u06cc\u0628\u0627\u0646\u06cc \u0627\u0632 \u0686\u0646\u062f\u06cc\u0646 \u0631\u0648\u0634 \u0627\u062d\u0631\u0627\u0632 \u0647\u0648\u06cc\u062a\u060c \u0627\u0632 \u062c\u0645\u0644\u0647 \u0627\u06cc\u0645\u06cc\u0644\/\u0631\u0645\u0632 \u0639\u0628\u0648\u0631\u060c \u06af\u0648\u06af\u0644\u060c \u0641\u06cc\u0633 \u0628\u0648\u06a9 \u0648 \u0648\u0631\u0648\u062f \u0646\u0627\u0634\u0646\u0627\u0633.<br \/>\nAPI \u0647\u0627\u06cc \u0627\u0645\u0646\u060c \u0645\u0642\u06cc\u0627\u0633 \u067e\u0630\u06cc\u0631 \u0648 \u0645\u0646\u0627\u0633\u0628 \u0628\u0631\u0627\u06cc \u062a\u0648\u0633\u0639\u0647 \u062f\u0647\u0646\u062f\u06af\u0627\u0646.<br \/>\n\u0627\u06af\u0631 \u062f\u0631 \u062d\u0627\u0644 \u0633\u0627\u062e\u062a\u0646 \u06cc\u06a9 \u0628\u0631\u0646\u0627\u0645\u0647 \u067e\u0648\u06cc\u0627 \u0647\u0633\u062a\u06cc\u062f \u06a9\u0647 \u062f\u0631 \u0622\u0646 \u06a9\u0627\u0631\u0628\u0631\u0627\u0646 \u0645\u06cc \u062a\u0648\u0627\u0646\u0646\u062f \u0641\u0648\u0631\u0627\u064b \u0628\u062f\u0648\u0646 \u0647\u06cc\u0686 \u0645\u0627\u0646\u0639\u06cc \u0628\u0627 \u0647\u0645 \u062a\u0639\u0627\u0645\u0644 \u062f\u0627\u0634\u062a\u0647 \u0628\u0627\u0634\u0646\u062f\u060c \u0627\u062d\u0631\u0627\u0632 \u0647\u0648\u06cc\u062a \u0646\u0627\u0634\u0646\u0627\u0633 \u06cc\u06a9 \u062a\u063a\u06cc\u06cc\u0631 \u0628\u0627\u0632\u06cc \u0627\u0633\u062a. \u0627\u06cc\u0646 \u0628\u0647 \u06a9\u0627\u0631\u0628\u0631\u0627\u0646 \u0627\u0645\u06a9\u0627\u0646 \u0645\u06cc \u062f\u0647\u062f \u0628\u0631\u0646\u0627\u0645\u0647 \u0634\u0645\u0627 \u0631\u0627 \u0628\u0627 \u06cc\u06a9 \u062d\u0633\u0627\u0628 \u0645\u0648\u0642\u062a \u06a9\u0627\u0648\u0634 \u06a9\u0646\u0646\u062f \u0648 \u0628\u0639\u062f\u0627\u064b \u0628\u0647 \u06cc\u06a9 \u062d\u0633\u0627\u0628 \u06a9\u0627\u0645\u0644 \u0645\u0646\u062a\u0642\u0644 \u0634\u0648\u0646\u062f.<\/p>\n<p>\ud83d\udd27 \u0631\u0627\u0647 \u0627\u0646\u062f\u0627\u0632\u06cc Firebase<\/p>\n<p>\u06cc\u06a9 \u067e\u0631\u0648\u0698\u0647 Firebase \u0627\u06cc\u062c\u0627\u062f \u06a9\u0646\u06cc\u062f\u0628\u0647 \u06a9\u0646\u0633\u0648\u0644 Firebase \u0628\u0631\u0648\u06cc\u062f.\u06cc\u06a9 \u067e\u0631\u0648\u0698\u0647 \u062c\u062f\u06cc\u062f \u0627\u06cc\u062c\u0627\u062f \u06a9\u0646\u06cc\u062f \u0648 Authentication \u0631\u0627 \u062f\u0631 \u0642\u0633\u0645\u062a Build \u0641\u0639\u0627\u0644 \u06a9\u0646\u06cc\u062f.<br \/>\nFirebase SDK \u0631\u0627 \u0646\u0635\u0628 \u06a9\u0646\u06cc\u062f\u062f\u0633\u062a\u0648\u0631 \u0632\u06cc\u0631 \u0631\u0627 \u062f\u0631 \u062f\u0627\u06cc\u0631\u06a9\u062a\u0648\u0631\u06cc \u067e\u0631\u0648\u0698\u0647 React \u062e\u0648\u062f \u0627\u062c\u0631\u0627 \u06a9\u0646\u06cc\u062f:<\/p>\n<p>npm install firebase<\/p>\n<p>Firebase \u0631\u0627 \u067e\u06cc\u06a9\u0631\u0628\u0646\u062f\u06cc \u06a9\u0646\u06cc\u062f<\/p>\n<p>\u06cc\u06a9 \u0641\u0627\u06cc\u0644 firebase-config.js \u062f\u0631 \u067e\u0631\u0648\u0698\u0647 \u062e\u0648\u062f \u0627\u06cc\u062c\u0627\u062f \u06a9\u0646\u06cc\u062f:<\/p>\n<p>import { initializeApp } from &#8220;firebase\/app&#8221;;<br \/>\nimport { getAuth } from &#8220;firebase\/auth&#8221;;<br \/>\nimport { getFirestore } from &#8220;firebase\/firestore&#8221;;<\/p>\n<p>const firebaseConfig = {<br \/>\n  apiKey: &#8220;YOUR_API_KEY&#8221;,<br \/>\n  authDomain: &#8220;YOUR_AUTH_DOMAIN&#8221;,<br \/>\n  projectId: &#8220;YOUR_PROJECT_ID&#8221;,<br \/>\n  storageBucket: &#8220;YOUR_STORAGE_BUCKET&#8221;,<br \/>\n  messagingSenderId: &#8220;YOUR_MESSAGING_SENDER_ID&#8221;,<br \/>\n  appId: &#8220;YOUR_APP_ID&#8221;,<br \/>\n};<\/p>\n<p>const app = initializeApp(firebaseConfig);<br \/>\nexport const auth = getAuth(app);<br \/>\nexport const db = getFirestore(app);<\/p>\n<p>    \u0648\u0627\u0631\u062f \u062d\u0627\u0644\u062a \u062a\u0645\u0627\u0645 \u0635\u0641\u062d\u0647 \u0634\u0648\u06cc\u062f<\/p>\n<p>    \u0627\u0632 \u062d\u0627\u0644\u062a \u062a\u0645\u0627\u0645 \u0635\u0641\u062d\u0647 \u062e\u0627\u0631\u062c \u0634\u0648\u06cc\u062f<\/p>\n<p>\ud83d\udee0\ufe0f \u067e\u06cc\u0627\u062f\u0647 \u0633\u0627\u0632\u06cc \u0648\u06cc\u0698\u06af\u06cc \u0647\u0627\u06cc \u0627\u062d\u0631\u0627\u0632 \u0647\u0648\u06cc\u062a<\/p>\n<p>\u0627\u062d\u0631\u0627\u0632 \u0647\u0648\u06cc\u062a \u0646\u0627\u0634\u0646\u0627\u0633 \u0627\u062d\u0631\u0627\u0632 \u0647\u0648\u06cc\u062a \u0646\u0627\u0634\u0646\u0627\u0633 \u0628\u0647 \u06a9\u0627\u0631\u0628\u0631\u0627\u0646 \u0627\u062c\u0627\u0632\u0647 \u0645\u06cc \u062f\u0647\u062f \u062a\u0627 \u0628\u0631\u0646\u0627\u0645\u0647 \u0634\u0645\u0627 \u0631\u0627 \u0628\u062f\u0648\u0646 \u0627\u06cc\u062c\u0627\u062f \u062d\u0633\u0627\u0628 \u06a9\u0627\u0631\u0628\u0631\u06cc \u0628\u0631\u0631\u0633\u06cc \u06a9\u0646\u0646\u062f.<\/p>\n<p>\u0631\u0627\u0647 \u0627\u0646\u062f\u0627\u0632\u06cc \u062f\u0631 Firebase\u0648\u0631\u0648\u062f \u0628\u0647 \u0633\u06cc\u0633\u062a\u0645 \u0646\u0627\u0634\u0646\u0627\u0633 \u0631\u0627 \u062f\u0631 \u0642\u0633\u0645\u062a Authentication > Sign-in Methods \u062f\u0631 \u06a9\u0646\u0633\u0648\u0644 Firebase \u0641\u0639\u0627\u0644 \u06a9\u0646\u06cc\u062f.<\/p>\n<p>\u067e\u06cc\u0627\u062f\u0647 \u0633\u0627\u0632\u06cc \u06a9\u062f\u0648\u0642\u062a\u06cc \u06a9\u0627\u0631\u0628\u0631 \u0628\u062f\u0648\u0646 \u0648\u0631\u0648\u062f \u0628\u0647 \u0633\u06cc\u0633\u062a\u0645 \u0628\u0647 \u0628\u0631\u0646\u0627\u0645\u0647 \u0634\u0645\u0627 \u062f\u0633\u062a\u0631\u0633\u06cc \u067e\u06cc\u062f\u0627 \u0645\u06cc \u06a9\u0646\u062f:<\/p>\n<p>import { signInAnonymously, onAuthStateChanged } from &#8220;firebase\/auth&#8221;;<\/p>\n<p>const handleAnonymousLogin = async () =&gt; {<br \/>\n  try {<br \/>\n    const userCredential = await signInAnonymously(auth);<br \/>\n    console.log(&#8220;Anonymous user ID:&#8221;, userCredential.user.uid);<br \/>\n  } catch (error) {<br \/>\n    console.error(&#8220;Error with anonymous login:&#8221;, error);<br \/>\n  }<br \/>\n};<\/p>\n<p>onAuthStateChanged(auth, (user) =&gt; {<br \/>\n  if (user?.isAnonymous) {<br \/>\n    console.log(&#8220;User is browsing anonymously.&#8221;);<br \/>\n  }<br \/>\n});<\/p>\n<p>    \u0648\u0627\u0631\u062f \u062d\u0627\u0644\u062a \u062a\u0645\u0627\u0645 \u0635\u0641\u062d\u0647 \u0634\u0648\u06cc\u062f<\/p>\n<p>    \u0627\u0632 \u062d\u0627\u0644\u062a \u062a\u0645\u0627\u0645 \u0635\u0641\u062d\u0647 \u062e\u0627\u0631\u062c \u0634\u0648\u06cc\u062f<\/p>\n<p>\u062b\u0628\u062a \u0646\u0627\u0645 \u06a9\u0627\u0631\u0628\u0631<\/p>\n<p>\u0628\u0647 \u06a9\u0627\u0631\u0628\u0631\u0627\u0646 \u0627\u062c\u0627\u0632\u0647 \u062f\u0647\u06cc\u062f \u0628\u0627 \u0627\u06cc\u0645\u06cc\u0644 \u0648 \u0631\u0645\u0632 \u0639\u0628\u0648\u0631 \u062b\u0628\u062a \u0646\u0627\u0645 \u06a9\u0646\u0646\u062f.<\/p>\n<p>\u0627\u06cc\u0645\u06cc\u0644\/\u0631\u0645\u0632 \u0639\u0628\u0648\u0631 \u0631\u0627 \u062f\u0631 Firebase \u0641\u0639\u0627\u0644 \u06a9\u0646\u06cc\u062f\u062f\u0631 \u062a\u0628 Sign-in Methods\u060c \u0627\u062d\u0631\u0627\u0632 \u0647\u0648\u06cc\u062a \u0627\u06cc\u0645\u06cc\u0644\/\u06af\u0630\u0631\u0648\u0627\u0698\u0647 \u0631\u0627 \u0641\u0639\u0627\u0644 \u06a9\u0646\u06cc\u062f.<\/p>\n<p>import { createUserWithEmailAndPassword } from &#8220;firebase\/auth&#8221;;<\/p>\n<p>const handleRegister = async (email, password) =&gt; {<br \/>\n  try {<br \/>\n    const userCredential = await createUserWithEmailAndPassword(auth, email, password);<br \/>\n    console.log(&#8220;Registered user:&#8221;, userCredential.user);<br \/>\n  } catch (error) {<br \/>\n    console.error(&#8220;Error during registration:&#8221;, error);<br \/>\n  }<br \/>\n};<\/p>\n<p>    \u0648\u0627\u0631\u062f \u062d\u0627\u0644\u062a \u062a\u0645\u0627\u0645 \u0635\u0641\u062d\u0647 \u0634\u0648\u06cc\u062f<\/p>\n<p>    \u0627\u0632 \u062d\u0627\u0644\u062a \u062a\u0645\u0627\u0645 \u0635\u0641\u062d\u0647 \u062e\u0627\u0631\u062c \u0634\u0648\u06cc\u062f<\/p>\n<p>\u0630\u062e\u06cc\u0631\u0647 \u0627\u0637\u0644\u0627\u0639\u0627\u062a \u0627\u0636\u0627\u0641\u06cc \u06a9\u0627\u0631\u0628\u0631 \u062f\u0631 Firestore:<\/p>\n<p>import { doc, setDoc } from &#8220;firebase\/firestore&#8221;;<\/p>\n<p>const saveUserData = async (userId, userData) =&gt; {<br \/>\n  try {<br \/>\n    await setDoc(doc(db, &#8220;users&#8221;, userId), userData);<br \/>\n    console.log(&#8220;User data saved.&#8221;);<br \/>\n  } catch (error) {<br \/>\n    console.error(&#8220;Error saving user data:&#8221;, error);<br \/>\n  }<br \/>\n};<\/p>\n<p>    \u0648\u0627\u0631\u062f \u062d\u0627\u0644\u062a \u062a\u0645\u0627\u0645 \u0635\u0641\u062d\u0647 \u0634\u0648\u06cc\u062f<\/p>\n<p>    \u0627\u0632 \u062d\u0627\u0644\u062a \u062a\u0645\u0627\u0645 \u0635\u0641\u062d\u0647 \u062e\u0627\u0631\u062c \u0634\u0648\u06cc\u062f<\/p>\n<p>\u0648\u0631\u0648\u062f \u06a9\u0627\u0631\u0628\u0631<\/p>\n<p>\u0628\u0647 \u06a9\u0627\u0631\u0628\u0631\u0627\u0646 \u0627\u062c\u0627\u0632\u0647 \u062f\u0647\u06cc\u062f \u0628\u0627 \u0627\u0637\u0644\u0627\u0639\u0627\u062a \u06a9\u0627\u0631\u0628\u0631\u06cc \u062e\u0648\u062f \u0648\u0627\u0631\u062f \u0634\u0648\u0646\u062f.<\/p>\n<p>import { signInWithEmailAndPassword } from &#8220;firebase\/auth&#8221;;<\/p>\n<p>const handleLogin = async (email, password) =&gt; {<br \/>\n  try {<br \/>\n    const userCredential = await signInWithEmailAndPassword(auth, email, password);<br \/>\n    console.log(&#8220;Logged-in user:&#8221;, userCredential.user);<br \/>\n  } catch (error) {<br \/>\n    console.error(&#8220;Error during login:&#8221;, error);<br \/>\n  }<br \/>\n};<\/p>\n<p>    \u0648\u0627\u0631\u062f \u062d\u0627\u0644\u062a \u062a\u0645\u0627\u0645 \u0635\u0641\u062d\u0647 \u0634\u0648\u06cc\u062f<\/p>\n<p>    \u0627\u0632 \u062d\u0627\u0644\u062a \u062a\u0645\u0627\u0645 \u0635\u0641\u062d\u0647 \u062e\u0627\u0631\u062c \u0634\u0648\u06cc\u062f<\/p>\n<p>\ud83e\udde0 \u062a\u0631\u06a9\u06cc\u0628 \u0627\u06a9\u0627\u0646\u062a \u0647\u0627\u06cc \u0646\u0627\u0634\u0646\u0627\u0633 \u0648 \u06a9\u0627\u0645\u0644<\/p>\n<p>\u0647\u0646\u06af\u0627\u0645\u06cc \u06a9\u0647 \u06cc\u06a9 \u06a9\u0627\u0631\u0628\u0631 \u0646\u0627\u0634\u0646\u0627\u0633 \u062a\u0635\u0645\u06cc\u0645 \u0628\u0647 \u0627\u06cc\u062c\u0627\u062f \u06cc\u06a9 \u062d\u0633\u0627\u0628 \u0645\u06cc\u200c\u06af\u06cc\u0631\u062f\u060c \u062f\u0627\u062f\u0647\u200c\u0647\u0627\u06cc \u0627\u0648 \u0631\u0627 \u06cc\u06a9\u067e\u0627\u0631\u0686\u0647 \u0627\u062f\u063a\u0627\u0645 \u06a9\u0646\u06cc\u062f.<\/p>\n<p>import { linkWithCredential, EmailAuthProvider } from &#8220;firebase\/auth&#8221;;<\/p>\n<p>const upgradeAnonymousAccount = async (email, password) =&gt; {<br \/>\n  try {<br \/>\n    const credential = EmailAuthProvider.credential(email, password);<br \/>\n    const user = auth.currentUser;<\/p>\n<p>    if (user?.isAnonymous) {<br \/>\n      const linkedUser = await linkWithCredential(user, credential);<br \/>\n      console.log(&#8220;Anonymous account upgraded:&#8221;, linkedUser.user);<br \/>\n    }<br \/>\n  } catch (error) {<br \/>\n    console.error(&#8220;Error upgrading anonymous account:&#8221;, error);<br \/>\n  }<br \/>\n};<\/p>\n<p>    \u0648\u0627\u0631\u062f \u062d\u0627\u0644\u062a \u062a\u0645\u0627\u0645 \u0635\u0641\u062d\u0647 \u0634\u0648\u06cc\u062f<\/p>\n<p>    \u0627\u0632 \u062d\u0627\u0644\u062a \u062a\u0645\u0627\u0645 \u0635\u0641\u062d\u0647 \u062e\u0627\u0631\u062c \u0634\u0648\u06cc\u062f<\/p>\n<p>\ud83c\udf10 \u0645\u062f\u06cc\u0631\u06cc\u062a \u0646\u0627\u0648\u0628\u0631\u06cc \u0648 UI<\/p>\n<p>\u0627\u0632 React Router \u0628\u0631\u0627\u06cc \u0647\u062f\u0627\u06cc\u062a \u06a9\u0627\u0631\u0628\u0631\u0627\u0646 \u0628\u0631 \u0627\u0633\u0627\u0633 \u0648\u0636\u0639\u06cc\u062a \u0627\u062d\u0631\u0627\u0632 \u0647\u0648\u06cc\u062a \u0622\u0646\u0647\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06a9\u0646\u06cc\u062f.<\/p>\n<p>import { useEffect } from &#8220;react&#8221;;<br \/>\nimport { useNavigate } from &#8220;react-router-dom&#8221;;<\/p>\n<p>const AuthHandler = () =&gt; {<br \/>\n  const navigate = useNavigate();<\/p>\n<p>  useEffect(() =&gt; {<br \/>\n    onAuthStateChanged(auth, (user) =&gt; {<br \/>\n      if (user?.isAnonymous) {<br \/>\n        navigate(&#8220;\/create-character&#8221;);<br \/>\n      } else if (user) {<br \/>\n        navigate(&#8220;\/dashboard&#8221;);<br \/>\n      } else {<br \/>\n        navigate(&#8220;\/login&#8221;);<br \/>\n      }<br \/>\n    });<br \/>\n  }, [navigate]);<\/p>\n<p>  return null;<br \/>\n};<\/p>\n<p>    \u0648\u0627\u0631\u062f \u062d\u0627\u0644\u062a \u062a\u0645\u0627\u0645 \u0635\u0641\u062d\u0647 \u0634\u0648\u06cc\u062f<\/p>\n<p>    \u0627\u0632 \u062d\u0627\u0644\u062a \u062a\u0645\u0627\u0645 \u0635\u0641\u062d\u0647 \u062e\u0627\u0631\u062c \u0634\u0648\u06cc\u062f<\/p>\n<p>\ud83d\ude80 \u0628\u0647\u062a\u0631\u06cc\u0646 \u0631\u0648\u0634 \u0647\u0627 \u0628\u0631\u0627\u06cc \u0627\u062d\u0631\u0627\u0632 \u0647\u0648\u06cc\u062a<\/p>\n<p>\u062f\u0627\u062f\u0647 \u0647\u0627\u06cc \u06a9\u0627\u0631\u0628\u0631 \u0627\u0645\u0646: \u0627\u0632 \u0642\u0648\u0627\u0646\u06cc\u0646 Firestore \u0628\u0631\u0627\u06cc \u0645\u062d\u062f\u0648\u062f \u06a9\u0631\u062f\u0646 \u062f\u0633\u062a\u0631\u0633\u06cc \u0628\u0647 \u062f\u0627\u062f\u0647 \u0647\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06a9\u0646\u06cc\u062f.<br \/>\n\u0627\u0639\u062a\u0628\u0627\u0631\u0633\u0646\u062c\u06cc \u0648\u0631\u0648\u062f\u06cc \u0647\u0627: \u0627\u0632 \u0648\u0631\u0648\u062f \u062f\u0627\u062f\u0647 \u0647\u0627\u06cc \u0646\u0627\u0645\u0639\u062a\u0628\u0631 \u06cc\u0627 \u0645\u062e\u0631\u0628 \u062f\u0631 \u0637\u0648\u0644 \u062b\u0628\u062a \u0646\u0627\u0645 \u062c\u0644\u0648\u06af\u06cc\u0631\u06cc \u06a9\u0646\u06cc\u062f.<br \/>\n\u0628\u0647\u0628\u0648\u062f UX: \u067e\u06cc\u0627\u0645 \u0647\u0627\u06cc \u062e\u0637\u0627 \u0648 \u0634\u0627\u062e\u0635 \u0647\u0627\u06cc \u067e\u06cc\u0634\u0631\u0641\u062a \u0648\u0627\u0636\u062d \u0631\u0627 \u062f\u0631 \u062c\u0631\u06cc\u0627\u0646 \u0648\u0631\u0648\u062f\/\u062b\u0628\u062a \u0646\u0627\u0645 \u0627\u0631\u0627\u0626\u0647 \u062f\u0647\u06cc\u062f.<br \/>\n\u0627\u0646\u062a\u0642\u0627\u0644 \u0628\u062f\u0648\u0646 \u062f\u0631\u0632: \u0627\u0632 \u0627\u0631\u062a\u0642\u0627\u06cc \u062d\u0633\u0627\u0628\u200c\u0647\u0627\u06cc \u0646\u0627\u0634\u0646\u0627\u0633 \u0628\u062f\u0648\u0646 \u0627\u0632 \u062f\u0633\u062a \u062f\u0627\u062f\u0646 \u067e\u06cc\u0634\u0631\u0641\u062a \u0627\u0637\u0645\u06cc\u0646\u0627\u0646 \u062d\u0627\u0635\u0644 \u06a9\u0646\u06cc\u062f.<br \/>\n\u0645\u062f\u06cc\u0631\u06cc\u062a \u062c\u0644\u0633\u0647: \u0627\u0646\u0642\u0636\u0627\u06cc \u0631\u0645\u0632 \u0648 \u0645\u0627\u0646\u062f\u06af\u0627\u0631\u06cc \u062c\u0644\u0633\u0647 \u0631\u0627 \u0628\u0647 \u0637\u0648\u0631 \u0645\u0648\u062b\u0631 \u0645\u062f\u06cc\u0631\u06cc\u062a \u06a9\u0646\u06cc\u062f.<\/p>\n<p>\ud83c\udf0c \u0646\u062a\u06cc\u062c\u0647 \u06af\u06cc\u0631\u06cc: \u06cc\u06a9 \u062a\u062c\u0631\u0628\u0647 \u0628\u0627\u0632\u06cc \u0628\u062f\u0648\u0646 \u062f\u0631\u0632 \u062f\u0631 \u0627\u0646\u062a\u0638\u0627\u0631 \u0627\u0633\u062a<\/p>\n<p>\u0633\u0627\u062e\u062a\u0646 \u06cc\u06a9 \u0633\u06cc\u0633\u062a\u0645 \u0627\u062d\u0631\u0627\u0632 \u0647\u0648\u06cc\u062a \u0642\u0648\u06cc \u0628\u0631\u0627\u06cc \u0628\u0631\u0646\u0627\u0645\u0647 \u0647\u0627\u06cc \u06a9\u0627\u0631\u0628\u0631\u062f\u06cc \u0648\u0628 \u0645\u062f\u0631\u0646\u060c \u0628\u0647 \u0648\u06cc\u0698\u0647 \u0628\u0631\u0627\u06cc \u067e\u0644\u062a\u0641\u0631\u0645 \u0647\u0627\u06cc \u062f\u0631\u06af\u06cc\u0631 \u0645\u0627\u0646\u0646\u062f \u0646\u0628\u0631\u062f \u06af\u0644\u0627\u062f\u06cc\u0627\u062a\u0648\u0631\u0647\u0627 \u0628\u0633\u06cc\u0627\u0631 \u0645\u0647\u0645 \u0627\u0633\u062a. \u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 Firebase \u0648 React.js\u060c \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u062f \u062a\u062c\u0631\u0628\u0647 \u0627\u06cc \u0628\u0635\u0631\u06cc\u060c \u0627\u0645\u0646 \u0648 \u0627\u0646\u0639\u0637\u0627\u0641 \u067e\u0630\u06cc\u0631 \u0631\u0627 \u0628\u0631\u0627\u06cc \u06a9\u0627\u0631\u0628\u0631\u0627\u0646 \u0641\u0631\u0627\u0647\u0645 \u06a9\u0646\u06cc\u062f.<\/p>\n<p>\u06a9\u0627\u0631\u0628\u0631\u0627\u0646 \u0634\u0645\u0627 \u0686\u0647 \u062f\u0631 \u062d\u0627\u0644 \u06a9\u0627\u0648\u0634 \u0646\u0627\u0634\u0646\u0627\u0633 \u0628\u0627\u0634\u0646\u062f\u060c \u0686\u0647 \u0628\u0631\u0627\u06cc \u0627\u0648\u0644\u06cc\u0646 \u0628\u0627\u0631 \u062b\u0628\u062a \u0646\u0627\u0645 \u06a9\u0646\u0646\u062f \u06cc\u0627 \u0628\u0631\u0627\u06cc \u06cc\u06a9 \u0646\u0628\u0631\u062f \u062d\u0645\u0627\u0633\u06cc \u0628\u0631\u06af\u0631\u062f\u0646\u062f\u060c \u06a9\u0627\u0631\u0628\u0631\u0627\u0646 \u0634\u0645\u0627 \u0627\u062d\u0633\u0627\u0633 \u0631\u0627\u062d\u062a\u06cc \u0645\u06cc \u06a9\u0646\u0646\u062f.<\/p>\n<p>\ud83d\udd17 \u0646\u0628\u0631\u062f \u06af\u0644\u0627\u062f\u06cc\u0627\u062a\u0648\u0631\u0647\u0627 \u0631\u0627 \u06a9\u0627\u0648\u0634 \u06a9\u0646\u06cc\u062f<\/p>\n<p>\u0628\u0627 \u062a\u0634\u06a9\u0631 \u0627\u0632 \u0634\u0645\u0627 \u0628\u0631\u0627\u06cc \u062e\u0648\u0627\u0646\u062f\u0646\u060c \u0648 \u06a9\u062f \u0646\u0648\u06cc\u0633\u06cc \u0645\u0628\u0627\u0631\u06a9! \ud83c\udf1f<\/p>\n<p>\u0646\u0638\u0631\u0627\u062a \u06cc\u0627 \u0633\u0648\u0627\u0644\u0627\u062a \u062e\u0648\u062f \u0631\u0627 \u062f\u0631 \u0646\u0638\u0631\u0627\u062a \u0632\u06cc\u0631 \u0628\u0627 \u0645\u0646 \u062f\u0631 \u0645\u06cc\u0627\u0646 \u0628\u06af\u0630\u0627\u0631\u06cc\u062f.<\/p>\n<div data-article-id=\"2123178\" id=\"article-body\">\n<p>\u0627\u062d\u0631\u0627\u0632 \u0647\u0648\u06cc\u062a \u0647\u0633\u062a\u0647 \u0627\u0635\u0644\u06cc \u0647\u0631 \u0628\u0631\u0646\u0627\u0645\u0647 \u0648\u0628 \u0645\u062f\u0631\u0646 \u0627\u0633\u062a. \u0686\u0647 \u062f\u0631 \u062d\u0627\u0644 \u0633\u0627\u062e\u062a\u0646 \u06cc\u06a9 \u067e\u0644\u062a\u0641\u0631\u0645 \u062c\u0627\u0645\u0639\u0647 \u0645\u062d\u0648\u0631\u060c \u06cc\u06a9 \u0633\u0627\u06cc\u062a \u062a\u062c\u0627\u0631\u062a \u0627\u0644\u06a9\u062a\u0631\u0648\u0646\u06cc\u06a9\u060c \u06cc\u0627 \u06cc\u06a9 \u062a\u062c\u0631\u0628\u0647 \u0628\u0627\u0632\u06cc \u062a\u0639\u0627\u0645\u0644\u06cc \u0645\u0627\u0646\u0646\u062f \u0646\u0628\u0631\u062f \u06af\u0644\u0627\u062f\u06cc\u0627\u062a\u0648\u0631\u0647\u0627 \u0628\u0627\u0634\u06cc\u062f\u060c \u0627\u0631\u0627\u0626\u0647 \u06cc\u06a9 \u0633\u06cc\u0633\u062a\u0645 \u0627\u062d\u0631\u0627\u0632 \u0647\u0648\u06cc\u062a \u06cc\u06a9\u067e\u0627\u0631\u0686\u0647 \u0648 \u0627\u06cc\u0645\u0646 \u0636\u0631\u0648\u0631\u06cc \u0627\u0633\u062a. \u062f\u0631 \u0627\u06cc\u0646 \u0631\u0627\u0647\u0646\u0645\u0627\u060c \u0646\u062d\u0648\u0647 \u062a\u0646\u0638\u06cc\u0645 \u06cc\u06a9 \u062c\u0631\u06cc\u0627\u0646 \u0627\u062d\u0631\u0627\u0632 \u0647\u0648\u06cc\u062a \u0642\u0648\u06cc \u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 Firebase \u0648 React.js\u060c \u0627\u0632 \u062c\u0645\u0644\u0647 \u0627\u062d\u0631\u0627\u0632 \u0647\u0648\u06cc\u062a \u0646\u0627\u0634\u0646\u0627\u0633\u060c \u062b\u0628\u062a \u0646\u0627\u0645 \u06a9\u0627\u0631\u0628\u0631 \u0648 \u0648\u0631\u0648\u062f \u0628\u0647 \u0633\u06cc\u0633\u062a\u0645 \u0631\u0627 \u0628\u0631\u0631\u0633\u06cc \u062e\u0648\u0627\u0647\u06cc\u0645 \u06a9\u0631\u062f.<\/p>\n<p>\ud83c\udf1f \u0686\u0631\u0627 Firebase \u0628\u0631\u0627\u06cc \u0627\u062d\u0631\u0627\u0632 \u0647\u0648\u06cc\u062a\u061f<\/p>\n<p>Firebase Authentication \u0627\u0631\u0627\u0626\u0647 \u0645\u06cc \u062f\u0647\u062f:<\/p>\n<ul>\n<li>\u0627\u062f\u063a\u0627\u0645 \u0622\u0633\u0627\u0646 \u0628\u0627 \u0641\u0631\u06cc\u0645\u0648\u0631\u06a9 \u0647\u0627\u06cc \u0645\u062d\u0628\u0648\u0628 \u0645\u0627\u0646\u0646\u062f React.js.<\/li>\n<li>\u067e\u0634\u062a\u06cc\u0628\u0627\u0646\u06cc \u0627\u0632 \u0686\u0646\u062f\u06cc\u0646 \u0631\u0648\u0634 \u0627\u062d\u0631\u0627\u0632 \u0647\u0648\u06cc\u062a\u060c \u0627\u0632 \u062c\u0645\u0644\u0647 \u0627\u06cc\u0645\u06cc\u0644\/\u0631\u0645\u0632 \u0639\u0628\u0648\u0631\u060c \u06af\u0648\u06af\u0644\u060c \u0641\u06cc\u0633 \u0628\u0648\u06a9 \u0648 \u0648\u0631\u0648\u062f \u0646\u0627\u0634\u0646\u0627\u0633.<\/li>\n<li>API \u0647\u0627\u06cc \u0627\u0645\u0646\u060c \u0645\u0642\u06cc\u0627\u0633 \u067e\u0630\u06cc\u0631 \u0648 \u0645\u0646\u0627\u0633\u0628 \u0628\u0631\u0627\u06cc \u062a\u0648\u0633\u0639\u0647 \u062f\u0647\u0646\u062f\u06af\u0627\u0646.<\/li>\n<li>\u0627\u06af\u0631 \u062f\u0631 \u062d\u0627\u0644 \u0633\u0627\u062e\u062a\u0646 \u06cc\u06a9 \u0628\u0631\u0646\u0627\u0645\u0647 \u067e\u0648\u06cc\u0627 \u0647\u0633\u062a\u06cc\u062f \u06a9\u0647 \u062f\u0631 \u0622\u0646 \u06a9\u0627\u0631\u0628\u0631\u0627\u0646 \u0645\u06cc \u062a\u0648\u0627\u0646\u0646\u062f \u0641\u0648\u0631\u0627\u064b \u0628\u062f\u0648\u0646 \u0647\u06cc\u0686 \u0645\u0627\u0646\u0639\u06cc \u0628\u0627 \u0647\u0645 \u062a\u0639\u0627\u0645\u0644 \u062f\u0627\u0634\u062a\u0647 \u0628\u0627\u0634\u0646\u062f\u060c \u0627\u062d\u0631\u0627\u0632 \u0647\u0648\u06cc\u062a \u0646\u0627\u0634\u0646\u0627\u0633 \u06cc\u06a9 \u062a\u063a\u06cc\u06cc\u0631 \u0628\u0627\u0632\u06cc \u0627\u0633\u062a. \u0627\u06cc\u0646 \u0628\u0647 \u06a9\u0627\u0631\u0628\u0631\u0627\u0646 \u0627\u0645\u06a9\u0627\u0646 \u0645\u06cc \u062f\u0647\u062f \u0628\u0631\u0646\u0627\u0645\u0647 \u0634\u0645\u0627 \u0631\u0627 \u0628\u0627 \u06cc\u06a9 \u062d\u0633\u0627\u0628 \u0645\u0648\u0642\u062a \u06a9\u0627\u0648\u0634 \u06a9\u0646\u0646\u062f \u0648 \u0628\u0639\u062f\u0627\u064b \u0628\u0647 \u06cc\u06a9 \u062d\u0633\u0627\u0628 \u06a9\u0627\u0645\u0644 \u0645\u0646\u062a\u0642\u0644 \u0634\u0648\u0646\u062f.<\/li>\n<\/ul>\n<p>\ud83d\udd27 \u0631\u0627\u0647 \u0627\u0646\u062f\u0627\u0632\u06cc Firebase<\/p>\n<ol>\n<li>\n<p>\u06cc\u06a9 \u067e\u0631\u0648\u0698\u0647 Firebase \u0627\u06cc\u062c\u0627\u062f \u06a9\u0646\u06cc\u062f<br \/>\u0628\u0647 \u06a9\u0646\u0633\u0648\u0644 Firebase \u0628\u0631\u0648\u06cc\u062f.<br \/>\u06cc\u06a9 \u067e\u0631\u0648\u0698\u0647 \u062c\u062f\u06cc\u062f \u0627\u06cc\u062c\u0627\u062f \u06a9\u0646\u06cc\u062f \u0648 Authentication \u0631\u0627 \u062f\u0631 \u0642\u0633\u0645\u062a Build \u0641\u0639\u0627\u0644 \u06a9\u0646\u06cc\u062f.<\/p>\n<\/li>\n<li>\n<p>Firebase SDK \u0631\u0627 \u0646\u0635\u0628 \u06a9\u0646\u06cc\u062f<br \/>\u062f\u0633\u062a\u0648\u0631 \u0632\u06cc\u0631 \u0631\u0627 \u062f\u0631 \u062f\u0627\u06cc\u0631\u06a9\u062a\u0648\u0631\u06cc \u067e\u0631\u0648\u0698\u0647 React \u062e\u0648\u062f \u0627\u062c\u0631\u0627 \u06a9\u0646\u06cc\u062f:<\/p>\n<\/li>\n<\/ol>\n<p><code>npm install firebase<\/code><\/p>\n<ol>\n<li>Firebase \u0631\u0627 \u067e\u06cc\u06a9\u0631\u0628\u0646\u062f\u06cc \u06a9\u0646\u06cc\u062f<\/li>\n<\/ol>\n<p>\u06cc\u06a9 \u0641\u0627\u06cc\u0644 firebase-config.js \u062f\u0631 \u067e\u0631\u0648\u0698\u0647 \u062e\u0648\u062f \u0627\u06cc\u062c\u0627\u062f \u06a9\u0646\u06cc\u062f:<\/p>\n<div class=\"highlight js-code-highlight\">\n<pre class=\"highlight plaintext\"><code>import { initializeApp } from \"firebase\/app\";\nimport { getAuth } from \"firebase\/auth\";\nimport { getFirestore } from \"firebase\/firestore\";\n\nconst firebaseConfig = {\n  apiKey: \"YOUR_API_KEY\",\n  authDomain: \"YOUR_AUTH_DOMAIN\",\n  projectId: \"YOUR_PROJECT_ID\",\n  storageBucket: \"YOUR_STORAGE_BUCKET\",\n  messagingSenderId: \"YOUR_MESSAGING_SENDER_ID\",\n  appId: \"YOUR_APP_ID\",\n};\n\nconst app = initializeApp(firebaseConfig);\nexport const auth = getAuth(app);\nexport const db = getFirestore(app);\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>\ud83d\udee0\ufe0f \u067e\u06cc\u0627\u062f\u0647 \u0633\u0627\u0632\u06cc \u0648\u06cc\u0698\u06af\u06cc \u0647\u0627\u06cc \u0627\u062d\u0631\u0627\u0632 \u0647\u0648\u06cc\u062a<\/p>\n<ol>\n<li>\u0627\u062d\u0631\u0627\u0632 \u0647\u0648\u06cc\u062a \u0646\u0627\u0634\u0646\u0627\u0633 \u0627\u062d\u0631\u0627\u0632 \u0647\u0648\u06cc\u062a \u0646\u0627\u0634\u0646\u0627\u0633 \u0628\u0647 \u06a9\u0627\u0631\u0628\u0631\u0627\u0646 \u0627\u062c\u0627\u0632\u0647 \u0645\u06cc \u062f\u0647\u062f \u062a\u0627 \u0628\u0631\u0646\u0627\u0645\u0647 \u0634\u0645\u0627 \u0631\u0627 \u0628\u062f\u0648\u0646 \u0627\u06cc\u062c\u0627\u062f \u062d\u0633\u0627\u0628 \u06a9\u0627\u0631\u0628\u0631\u06cc \u0628\u0631\u0631\u0633\u06cc \u06a9\u0646\u0646\u062f.<\/li>\n<\/ol>\n<p>\u0631\u0627\u0647 \u0627\u0646\u062f\u0627\u0632\u06cc \u062f\u0631 Firebase<br \/>\u0648\u0631\u0648\u062f \u0628\u0647 \u0633\u06cc\u0633\u062a\u0645 \u0646\u0627\u0634\u0646\u0627\u0633 \u0631\u0627 \u062f\u0631 \u0642\u0633\u0645\u062a Authentication > Sign-in Methods \u062f\u0631 \u06a9\u0646\u0633\u0648\u0644 Firebase \u0641\u0639\u0627\u0644 \u06a9\u0646\u06cc\u062f.<\/p>\n<p>\u067e\u06cc\u0627\u062f\u0647 \u0633\u0627\u0632\u06cc \u06a9\u062f<br \/>\u0648\u0642\u062a\u06cc \u06a9\u0627\u0631\u0628\u0631 \u0628\u062f\u0648\u0646 \u0648\u0631\u0648\u062f \u0628\u0647 \u0633\u06cc\u0633\u062a\u0645 \u0628\u0647 \u0628\u0631\u0646\u0627\u0645\u0647 \u0634\u0645\u0627 \u062f\u0633\u062a\u0631\u0633\u06cc \u067e\u06cc\u062f\u0627 \u0645\u06cc \u06a9\u0646\u062f:<\/p>\n<div class=\"highlight js-code-highlight\">\n<pre class=\"highlight plaintext\"><code>import { signInAnonymously, onAuthStateChanged } from \"firebase\/auth\";\n\nconst handleAnonymousLogin = async () =&gt; {\n  try {\n    const userCredential = await signInAnonymously(auth);\n    console.log(\"Anonymous user ID:\", userCredential.user.uid);\n  } catch (error) {\n    console.error(\"Error with anonymous login:\", error);\n  }\n};\n\nonAuthStateChanged(auth, (user) =&gt; {\n  if (user?.isAnonymous) {\n    console.log(\"User is browsing anonymously.\");\n  }\n});\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<ol>\n<li>\u062b\u0628\u062a \u0646\u0627\u0645 \u06a9\u0627\u0631\u0628\u0631<\/li>\n<\/ol>\n<p>\u0628\u0647 \u06a9\u0627\u0631\u0628\u0631\u0627\u0646 \u0627\u062c\u0627\u0632\u0647 \u062f\u0647\u06cc\u062f \u0628\u0627 \u0627\u06cc\u0645\u06cc\u0644 \u0648 \u0631\u0645\u0632 \u0639\u0628\u0648\u0631 \u062b\u0628\u062a \u0646\u0627\u0645 \u06a9\u0646\u0646\u062f.<\/p>\n<p>\u0627\u06cc\u0645\u06cc\u0644\/\u0631\u0645\u0632 \u0639\u0628\u0648\u0631 \u0631\u0627 \u062f\u0631 Firebase \u0641\u0639\u0627\u0644 \u06a9\u0646\u06cc\u062f<br \/>\u062f\u0631 \u062a\u0628 Sign-in Methods\u060c \u0627\u062d\u0631\u0627\u0632 \u0647\u0648\u06cc\u062a \u0627\u06cc\u0645\u06cc\u0644\/\u06af\u0630\u0631\u0648\u0627\u0698\u0647 \u0631\u0627 \u0641\u0639\u0627\u0644 \u06a9\u0646\u06cc\u062f.<\/p>\n<div class=\"highlight js-code-highlight\">\n<pre class=\"highlight plaintext\"><code>import { createUserWithEmailAndPassword } from \"firebase\/auth\";\n\nconst handleRegister = async (email, password) =&gt; {\n  try {\n    const userCredential = await createUserWithEmailAndPassword(auth, email, password);\n    console.log(\"Registered user:\", userCredential.user);\n  } catch (error) {\n    console.error(\"Error during registration:\", error);\n  }\n};\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>\u0630\u062e\u06cc\u0631\u0647 \u0627\u0637\u0644\u0627\u0639\u0627\u062a \u0627\u0636\u0627\u0641\u06cc \u06a9\u0627\u0631\u0628\u0631 \u062f\u0631 Firestore:<\/p>\n<div class=\"highlight js-code-highlight\">\n<pre class=\"highlight plaintext\"><code>import { doc, setDoc } from \"firebase\/firestore\";\n\nconst saveUserData = async (userId, userData) =&gt; {\n  try {\n    await setDoc(doc(db, \"users\", userId), userData);\n    console.log(\"User data saved.\");\n  } catch (error) {\n    console.error(\"Error saving user data:\", error);\n  }\n};\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<ol>\n<li>\u0648\u0631\u0648\u062f \u06a9\u0627\u0631\u0628\u0631<\/li>\n<\/ol>\n<p>\u0628\u0647 \u06a9\u0627\u0631\u0628\u0631\u0627\u0646 \u0627\u062c\u0627\u0632\u0647 \u062f\u0647\u06cc\u062f \u0628\u0627 \u0627\u0637\u0644\u0627\u0639\u0627\u062a \u06a9\u0627\u0631\u0628\u0631\u06cc \u062e\u0648\u062f \u0648\u0627\u0631\u062f \u0634\u0648\u0646\u062f.<\/p>\n<div class=\"highlight js-code-highlight\">\n<pre class=\"highlight plaintext\"><code>import { signInWithEmailAndPassword } from \"firebase\/auth\";\n\nconst handleLogin = async (email, password) =&gt; {\n  try {\n    const userCredential = await signInWithEmailAndPassword(auth, email, password);\n    console.log(\"Logged-in user:\", userCredential.user);\n  } catch (error) {\n    console.error(\"Error during login:\", error);\n  }\n};\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>\ud83e\udde0 \u062a\u0631\u06a9\u06cc\u0628 \u0627\u06a9\u0627\u0646\u062a \u0647\u0627\u06cc \u0646\u0627\u0634\u0646\u0627\u0633 \u0648 \u06a9\u0627\u0645\u0644<\/p>\n<p>\u0647\u0646\u06af\u0627\u0645\u06cc \u06a9\u0647 \u06cc\u06a9 \u06a9\u0627\u0631\u0628\u0631 \u0646\u0627\u0634\u0646\u0627\u0633 \u062a\u0635\u0645\u06cc\u0645 \u0628\u0647 \u0627\u06cc\u062c\u0627\u062f \u06cc\u06a9 \u062d\u0633\u0627\u0628 \u0645\u06cc\u200c\u06af\u06cc\u0631\u062f\u060c \u062f\u0627\u062f\u0647\u200c\u0647\u0627\u06cc \u0627\u0648 \u0631\u0627 \u06cc\u06a9\u067e\u0627\u0631\u0686\u0647 \u0627\u062f\u063a\u0627\u0645 \u06a9\u0646\u06cc\u062f.<\/p>\n<div class=\"highlight js-code-highlight\">\n<pre class=\"highlight plaintext\"><code>import { linkWithCredential, EmailAuthProvider } from \"firebase\/auth\";\n\nconst upgradeAnonymousAccount = async (email, password) =&gt; {\n  try {\n    const credential = EmailAuthProvider.credential(email, password);\n    const user = auth.currentUser;\n\n    if (user?.isAnonymous) {\n      const linkedUser = await linkWithCredential(user, credential);\n      console.log(\"Anonymous account upgraded:\", linkedUser.user);\n    }\n  } catch (error) {\n    console.error(\"Error upgrading anonymous account:\", error);\n  }\n};\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>\ud83c\udf10 \u0645\u062f\u06cc\u0631\u06cc\u062a \u0646\u0627\u0648\u0628\u0631\u06cc \u0648 UI<\/p>\n<p>\u0627\u0632 React Router \u0628\u0631\u0627\u06cc \u0647\u062f\u0627\u06cc\u062a \u06a9\u0627\u0631\u0628\u0631\u0627\u0646 \u0628\u0631 \u0627\u0633\u0627\u0633 \u0648\u0636\u0639\u06cc\u062a \u0627\u062d\u0631\u0627\u0632 \u0647\u0648\u06cc\u062a \u0622\u0646\u0647\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06a9\u0646\u06cc\u062f.<\/p>\n<div class=\"highlight js-code-highlight\">\n<pre class=\"highlight plaintext\"><code>import { useEffect } from \"react\";\nimport { useNavigate } from \"react-router-dom\";\n\nconst AuthHandler = () =&gt; {\n  const navigate = useNavigate();\n\n  useEffect(() =&gt; {\n    onAuthStateChanged(auth, (user) =&gt; {\n      if (user?.isAnonymous) {\n        navigate(\"\/create-character\");\n      } else if (user) {\n        navigate(\"\/dashboard\");\n      } else {\n        navigate(\"\/login\");\n      }\n    });\n  }, [navigate]);\n\n  return null;\n};\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>\ud83d\ude80 \u0628\u0647\u062a\u0631\u06cc\u0646 \u0631\u0648\u0634 \u0647\u0627 \u0628\u0631\u0627\u06cc \u0627\u062d\u0631\u0627\u0632 \u0647\u0648\u06cc\u062a<\/p>\n<ul>\n<li>\u062f\u0627\u062f\u0647 \u0647\u0627\u06cc \u06a9\u0627\u0631\u0628\u0631 \u0627\u0645\u0646: \u0627\u0632 \u0642\u0648\u0627\u0646\u06cc\u0646 Firestore \u0628\u0631\u0627\u06cc \u0645\u062d\u062f\u0648\u062f \u06a9\u0631\u062f\u0646 \u062f\u0633\u062a\u0631\u0633\u06cc \u0628\u0647 \u062f\u0627\u062f\u0647 \u0647\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06a9\u0646\u06cc\u062f.<\/li>\n<li>\u0627\u0639\u062a\u0628\u0627\u0631\u0633\u0646\u062c\u06cc \u0648\u0631\u0648\u062f\u06cc \u0647\u0627: \u0627\u0632 \u0648\u0631\u0648\u062f \u062f\u0627\u062f\u0647 \u0647\u0627\u06cc \u0646\u0627\u0645\u0639\u062a\u0628\u0631 \u06cc\u0627 \u0645\u062e\u0631\u0628 \u062f\u0631 \u0637\u0648\u0644 \u062b\u0628\u062a \u0646\u0627\u0645 \u062c\u0644\u0648\u06af\u06cc\u0631\u06cc \u06a9\u0646\u06cc\u062f.<\/li>\n<li>\u0628\u0647\u0628\u0648\u062f UX: \u067e\u06cc\u0627\u0645 \u0647\u0627\u06cc \u062e\u0637\u0627 \u0648 \u0634\u0627\u062e\u0635 \u0647\u0627\u06cc \u067e\u06cc\u0634\u0631\u0641\u062a \u0648\u0627\u0636\u062d \u0631\u0627 \u062f\u0631 \u062c\u0631\u06cc\u0627\u0646 \u0648\u0631\u0648\u062f\/\u062b\u0628\u062a \u0646\u0627\u0645 \u0627\u0631\u0627\u0626\u0647 \u062f\u0647\u06cc\u062f.<\/li>\n<li>\u0627\u0646\u062a\u0642\u0627\u0644 \u0628\u062f\u0648\u0646 \u062f\u0631\u0632: \u0627\u0632 \u0627\u0631\u062a\u0642\u0627\u06cc \u062d\u0633\u0627\u0628\u200c\u0647\u0627\u06cc \u0646\u0627\u0634\u0646\u0627\u0633 \u0628\u062f\u0648\u0646 \u0627\u0632 \u062f\u0633\u062a \u062f\u0627\u062f\u0646 \u067e\u06cc\u0634\u0631\u0641\u062a \u0627\u0637\u0645\u06cc\u0646\u0627\u0646 \u062d\u0627\u0635\u0644 \u06a9\u0646\u06cc\u062f.<\/li>\n<li>\u0645\u062f\u06cc\u0631\u06cc\u062a \u062c\u0644\u0633\u0647: \u0627\u0646\u0642\u0636\u0627\u06cc \u0631\u0645\u0632 \u0648 \u0645\u0627\u0646\u062f\u06af\u0627\u0631\u06cc \u062c\u0644\u0633\u0647 \u0631\u0627 \u0628\u0647 \u0637\u0648\u0631 \u0645\u0648\u062b\u0631 \u0645\u062f\u06cc\u0631\u06cc\u062a \u06a9\u0646\u06cc\u062f.<\/li>\n<\/ul>\n<p>\ud83c\udf0c \u0646\u062a\u06cc\u062c\u0647 \u06af\u06cc\u0631\u06cc: \u06cc\u06a9 \u062a\u062c\u0631\u0628\u0647 \u0628\u0627\u0632\u06cc \u0628\u062f\u0648\u0646 \u062f\u0631\u0632 \u062f\u0631 \u0627\u0646\u062a\u0638\u0627\u0631 \u0627\u0633\u062a<\/p>\n<p>\u0633\u0627\u062e\u062a\u0646 \u06cc\u06a9 \u0633\u06cc\u0633\u062a\u0645 \u0627\u062d\u0631\u0627\u0632 \u0647\u0648\u06cc\u062a \u0642\u0648\u06cc \u0628\u0631\u0627\u06cc \u0628\u0631\u0646\u0627\u0645\u0647 \u0647\u0627\u06cc \u06a9\u0627\u0631\u0628\u0631\u062f\u06cc \u0648\u0628 \u0645\u062f\u0631\u0646\u060c \u0628\u0647 \u0648\u06cc\u0698\u0647 \u0628\u0631\u0627\u06cc \u067e\u0644\u062a\u0641\u0631\u0645 \u0647\u0627\u06cc \u062f\u0631\u06af\u06cc\u0631 \u0645\u0627\u0646\u0646\u062f \u0646\u0628\u0631\u062f \u06af\u0644\u0627\u062f\u06cc\u0627\u062a\u0648\u0631\u0647\u0627 \u0628\u0633\u06cc\u0627\u0631 \u0645\u0647\u0645 \u0627\u0633\u062a. \u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 Firebase \u0648 React.js\u060c \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u062f \u062a\u062c\u0631\u0628\u0647 \u0627\u06cc \u0628\u0635\u0631\u06cc\u060c \u0627\u0645\u0646 \u0648 \u0627\u0646\u0639\u0637\u0627\u0641 \u067e\u0630\u06cc\u0631 \u0631\u0627 \u0628\u0631\u0627\u06cc \u06a9\u0627\u0631\u0628\u0631\u0627\u0646 \u0641\u0631\u0627\u0647\u0645 \u06a9\u0646\u06cc\u062f.<\/p>\n<p>\u06a9\u0627\u0631\u0628\u0631\u0627\u0646 \u0634\u0645\u0627 \u0686\u0647 \u062f\u0631 \u062d\u0627\u0644 \u06a9\u0627\u0648\u0634 \u0646\u0627\u0634\u0646\u0627\u0633 \u0628\u0627\u0634\u0646\u062f\u060c \u0686\u0647 \u0628\u0631\u0627\u06cc \u0627\u0648\u0644\u06cc\u0646 \u0628\u0627\u0631 \u062b\u0628\u062a \u0646\u0627\u0645 \u06a9\u0646\u0646\u062f \u06cc\u0627 \u0628\u0631\u0627\u06cc \u06cc\u06a9 \u0646\u0628\u0631\u062f \u062d\u0645\u0627\u0633\u06cc \u0628\u0631\u06af\u0631\u062f\u0646\u062f\u060c \u06a9\u0627\u0631\u0628\u0631\u0627\u0646 \u0634\u0645\u0627 \u0627\u062d\u0633\u0627\u0633 \u0631\u0627\u062d\u062a\u06cc \u0645\u06cc \u06a9\u0646\u0646\u062f.<\/p>\n<p>\ud83d\udd17 \u0646\u0628\u0631\u062f \u06af\u0644\u0627\u062f\u06cc\u0627\u062a\u0648\u0631\u0647\u0627 \u0631\u0627 \u06a9\u0627\u0648\u0634 \u06a9\u0646\u06cc\u062f<\/p>\n<p>\u0628\u0627 \u062a\u0634\u06a9\u0631 \u0627\u0632 \u0634\u0645\u0627 \u0628\u0631\u0627\u06cc \u062e\u0648\u0627\u0646\u062f\u0646\u060c \u0648 \u06a9\u062f \u0646\u0648\u06cc\u0633\u06cc \u0645\u0628\u0627\u0631\u06a9! \ud83c\udf1f<\/p>\n<p>\u0646\u0638\u0631\u0627\u062a \u06cc\u0627 \u0633\u0648\u0627\u0644\u0627\u062a \u062e\u0648\u062f \u0631\u0627 \u062f\u0631 \u0646\u0638\u0631\u0627\u062a \u0632\u06cc\u0631 \u0628\u0627 \u0645\u0646 \u062f\u0631 \u0645\u06cc\u0627\u0646 \u0628\u06af\u0630\u0627\u0631\u06cc\u062f.<\/p>\n<\/p><\/div>\n","protected":false},"excerpt":{"rendered":"<p>Summarize this content to 400 words in Persian Lang \u0627\u062d\u0631\u0627\u0632 \u0647\u0648\u06cc\u062a \u0647\u0633\u062a\u0647 \u0627\u0635\u0644\u06cc \u0647\u0631 \u0628\u0631\u0646\u0627\u0645\u0647 \u0648\u0628 \u0645\u062f\u0631\u0646 \u0627\u0633\u062a. \u0686\u0647 \u062f\u0631 \u062d\u0627\u0644 \u0633\u0627\u062e\u062a\u0646 \u06cc\u06a9 \u067e\u0644\u062a\u0641\u0631\u0645 \u062c\u0627\u0645\u0639\u0647 \u0645\u062d\u0648\u0631\u060c \u06cc\u06a9 \u0633\u0627\u06cc\u062a \u062a\u062c\u0627\u0631\u062a \u0627\u0644\u06a9\u062a\u0631\u0648\u0646\u06cc\u06a9\u060c \u06cc\u0627 \u06cc\u06a9 \u062a\u062c\u0631\u0628\u0647 \u0628\u0627\u0632\u06cc \u062a\u0639\u0627\u0645\u0644\u06cc \u0645\u0627\u0646\u0646\u062f \u0646\u0628\u0631\u062f \u06af\u0644\u0627\u062f\u06cc\u0627\u062a\u0648\u0631\u0647\u0627 \u0628\u0627\u0634\u06cc\u062f\u060c \u0627\u0631\u0627\u0626\u0647 \u06cc\u06a9 \u0633\u06cc\u0633\u062a\u0645 \u0627\u062d\u0631\u0627\u0632 \u0647\u0648\u06cc\u062a \u06cc\u06a9\u067e\u0627\u0631\u0686\u0647 \u0648 \u0627\u06cc\u0645\u0646 \u0636\u0631\u0648\u0631\u06cc \u0627\u0633\u062a. \u062f\u0631 \u0627\u06cc\u0646 \u0631\u0627\u0647\u0646\u0645\u0627\u060c \u0646\u062d\u0648\u0647 \u062a\u0646\u0638\u06cc\u0645 \u06cc\u06a9 &hellip;<\/p>\n","protected":false},"author":2,"featured_media":85663,"comment_status":"open","ping_status":"closed","sticky":false,"template":"","format":"standard","meta":{"fifu_image_url":"","fifu_image_alt":"","footnotes":""},"categories":[339],"tags":[],"class_list":["post-85662","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\/85662","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=85662"}],"version-history":[{"count":0,"href":"https:\/\/nabfollower.com\/blog\/wp-json\/wp\/v2\/posts\/85662\/revisions"}],"wp:featuredmedia":[{"embeddable":true,"href":"https:\/\/nabfollower.com\/blog\/wp-json\/wp\/v2\/media\/85663"}],"wp:attachment":[{"href":"https:\/\/nabfollower.com\/blog\/wp-json\/wp\/v2\/media?parent=85662"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/nabfollower.com\/blog\/wp-json\/wp\/v2\/categories?post=85662"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/nabfollower.com\/blog\/wp-json\/wp\/v2\/tags?post=85662"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}