<?xml version="1.0" encoding="UTF-8"?>
<rss version="2.0" xmlns:atom="http://www.w3.org/2005/Atom" xmlns:dc="http://purl.org/dc/elements/1.1/">
  <channel>
    <title>Forem: Mohamed Seif Ben Salah</title>
    <description>The latest articles on Forem by Mohamed Seif Ben Salah (@samir_soupape).</description>
    <link>https://forem.com/samir_soupape</link>
    <image>
      <url>https://media2.dev.to/dynamic/image/width=90,height=90,fit=cover,gravity=auto,format=auto/https:%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Fuser%2Fprofile_image%2F1726650%2Fc5b3bbb4-ee46-483e-90d6-088da840551c.jpg</url>
      <title>Forem: Mohamed Seif Ben Salah</title>
      <link>https://forem.com/samir_soupape</link>
    </image>
    <atom:link rel="self" type="application/rss+xml" href="https://forem.com/feed/samir_soupape"/>
    <language>en</language>
    <item>
      <title>why login not working after form submission ?</title>
      <dc:creator>Mohamed Seif Ben Salah</dc:creator>
      <pubDate>Thu, 04 Jul 2024 01:02:54 +0000</pubDate>
      <link>https://forem.com/samir_soupape/why-login-not-working-after-form-submission--4lli</link>
      <guid>https://forem.com/samir_soupape/why-login-not-working-after-form-submission--4lli</guid>
      <description>&lt;p&gt;login.ts : &lt;br&gt;
`async onSubmit(): Promise {&lt;br&gt;
    this.email = true;&lt;br&gt;
    this.pwd = true;&lt;br&gt;
    this.mailform = true;&lt;br&gt;
    this.isLoginInProgress.set(true);&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight plaintext"&gt;&lt;code&gt;this._authService
  .login(this.form.controls.email.value.trim(), this.form.controls.password.value.trim())
  .pipe(
    catchError((error: HttpErrorResponse) =&amp;gt; {
      this.handleAuthError(error);
      return of(error);
    }),
    tap(response =&amp;gt; this._handleLogin(response)),
    finalize(() =&amp;gt; this.isLoginInProgress.set(false))
  )
  .subscribe({
    error: (error) =&amp;gt; {
      console.error('Login error:', error);
    }
  });
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;

&lt;p&gt;}&lt;/p&gt;

&lt;p&gt;private _handleLogin(response: any): void {&lt;br&gt;
    if (!response?.user) return;&lt;br&gt;
    this.login = true;&lt;br&gt;
    const accessToken = response.user.accessToken;&lt;br&gt;
    const user_uid = response.user.uid;&lt;br&gt;
    localStorage.setItem('accessToken', accessToken);&lt;br&gt;
    localStorage.setItem('user_uid', user_uid);&lt;br&gt;
    window.location.reload();&lt;br&gt;
    this._router.navigateByUrl('/dashboard');&lt;/p&gt;

&lt;p&gt;}&lt;/p&gt;

&lt;p&gt;handleAuthError(err: HttpErrorResponse): void {&lt;br&gt;
    if (!err.error.code) return;&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight plaintext"&gt;&lt;code&gt;this.authError.set(true);
this.form.valueChanges
  .pipe(
    take(1),
    tap(() =&amp;gt; this.authError.set(true))
  )
  .subscribe();
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;

&lt;p&gt;}&lt;br&gt;
`&lt;/p&gt;

&lt;p&gt;login.html : &lt;br&gt;
&lt;code&gt;&amp;lt;form [formGroup]="form" (ngSubmit)="onSubmit()" class="form-detail"&amp;gt;&lt;br&gt;
&amp;lt;/form&amp;gt;&lt;/code&gt;&lt;br&gt;
authservice.ts : &lt;br&gt;
`login(email: string, password: string): Observable {&lt;br&gt;
    console.log('Logging in user:', email);&lt;br&gt;
    const promise = signInWithEmailAndPassword(this.firebaseAuth, email, password)&lt;br&gt;
      .then(response =&amp;gt; {&lt;br&gt;
        console.log('Login successful:', response);&lt;br&gt;
        return response;&lt;br&gt;
      })&lt;br&gt;
      .catch(error =&amp;gt; {&lt;br&gt;
        console.error('Login error:', error);&lt;br&gt;
        throw error; &lt;br&gt;
      });&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight plaintext"&gt;&lt;code&gt;return from(promise);
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;

&lt;p&gt;}&lt;br&gt;
`&lt;/p&gt;

</description>
      <category>angular</category>
      <category>html</category>
      <category>typescript</category>
    </item>
  </channel>
</rss>
