mirror of
https://github.com/Mueller-Patrick/Betterzon.git
synced 2024-12-23 20:15:13 +00:00
Compare commits
9 Commits
5c02314180
...
c3c0fa73b9
Author | SHA1 | Date | |
---|---|---|---|
|
c3c0fa73b9 | ||
b1db97af87 | |||
|
730e1aada0 | ||
|
deec125242 | ||
d8638cab4b | |||
cfda636f07 | |||
61a0125229 | |||
0bc02ee9ea | |||
7ac73204df |
|
@ -11,7 +11,7 @@
|
||||||
<!-- About Section Content-->
|
<!-- About Section Content-->
|
||||||
<div class="row">
|
<div class="row">
|
||||||
<div class="col-lg-4 ms-auto"><p class="lead">You follow the same passion as we do and you want to find alternatives to the de-facto monopolist Amazon?</p></div>
|
<div class="col-lg-4 ms-auto"><p class="lead">You follow the same passion as we do and you want to find alternatives to the de-facto monopolist Amazon?</p></div>
|
||||||
<div class="col-lg-4 me-auto"><p class="lead">In this case, welcome aboard! We’re happy that you share our passion and hope that we can help you achieving this goal with the website</p></div>
|
<div class="col-lg-4 me-auto"><p class="lead">In this case, welcome aboard! We’re happy that you share our passion and hope that we can help you achieving this goal with the website.</p></div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</section>
|
</section>
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
import { Component, OnInit } from '@angular/core';
|
import {Component, OnInit} from '@angular/core';
|
||||||
|
|
||||||
@Component({
|
@Component({
|
||||||
selector: 'app-about-us',
|
selector: 'app-about-us',
|
||||||
|
@ -7,7 +7,8 @@ import { Component, OnInit } from '@angular/core';
|
||||||
})
|
})
|
||||||
export class AboutUsComponent implements OnInit {
|
export class AboutUsComponent implements OnInit {
|
||||||
|
|
||||||
constructor() { }
|
constructor() {
|
||||||
|
}
|
||||||
|
|
||||||
ngOnInit(): void {
|
ngOnInit(): void {
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
import { Component, OnInit } from '@angular/core';
|
import {Component, OnInit} from '@angular/core';
|
||||||
import { FormBuilder, FormGroup, Validators } from '@angular/forms';
|
import {FormBuilder, FormGroup, Validators} from '@angular/forms';
|
||||||
import {ApiService} from "../../../services/api.service";
|
import {ApiService} from '../../../services/api.service';
|
||||||
import {Router} from "@angular/router";
|
import {Router} from '@angular/router';
|
||||||
|
|
||||||
|
|
||||||
@Component({
|
@Component({
|
||||||
|
@ -16,9 +16,10 @@ export class RegistrationComponent implements OnInit {
|
||||||
|
|
||||||
constructor(
|
constructor(
|
||||||
private formBuilder: FormBuilder,
|
private formBuilder: FormBuilder,
|
||||||
private api : ApiService,
|
private api: ApiService,
|
||||||
private router: Router
|
private router: Router
|
||||||
) { }
|
) {
|
||||||
|
}
|
||||||
|
|
||||||
ngOnInit(): void {
|
ngOnInit(): void {
|
||||||
this.form = this.formBuilder.group({
|
this.form = this.formBuilder.group({
|
||||||
|
@ -31,11 +32,13 @@ export class RegistrationComponent implements OnInit {
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
get me() { return this.form.controls; }
|
get me() {
|
||||||
|
return this.form.controls;
|
||||||
|
}
|
||||||
|
|
||||||
onSubmit() {
|
onSubmit(): void {
|
||||||
this.api.registerUser(this.form.value.username, this.form.value.password, this.form.value.email).subscribe(
|
this.api.registerUser(this.form.value.username, this.form.value.password, this.form.value.email).subscribe(
|
||||||
res=> {
|
res => {
|
||||||
this.api.saveSessionInfoToLocalStorage(res);
|
this.api.saveSessionInfoToLocalStorage(res);
|
||||||
this.router.navigate(['/']);
|
this.router.navigate(['/']);
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
import { Component, OnInit } from '@angular/core';
|
import {Component, OnInit} from '@angular/core';
|
||||||
|
|
||||||
@Component({
|
@Component({
|
||||||
selector: 'app-resetpasswort',
|
selector: 'app-resetpasswort',
|
||||||
|
@ -7,7 +7,8 @@ import { Component, OnInit } from '@angular/core';
|
||||||
})
|
})
|
||||||
export class ResetpasswortComponent implements OnInit {
|
export class ResetpasswortComponent implements OnInit {
|
||||||
|
|
||||||
constructor() { }
|
constructor() {
|
||||||
|
}
|
||||||
|
|
||||||
ngOnInit(): void {
|
ngOnInit(): void {
|
||||||
}
|
}
|
||||||
|
|
|
@ -12,7 +12,7 @@
|
||||||
</div>
|
</div>
|
||||||
<!-- Footer Social Icons-->
|
<!-- Footer Social Icons-->
|
||||||
<div class="col-lg-4 mb-5 mb-lg-0">
|
<div class="col-lg-4 mb-5 mb-lg-0">
|
||||||
<h4 class="text-uppercase mb-4">FOLLOW UNS</h4>
|
<h4 class="text-uppercase mb-4">FOLLOW US</h4>
|
||||||
<a class="btn btn-outline-light btn-social mx-1" href="https://github.com/Mueller-Patrick/Betterzon"><i class="fab fa-fw fa-github"></i></a>
|
<a class="btn btn-outline-light btn-social mx-1" href="https://github.com/Mueller-Patrick/Betterzon"><i class="fab fa-fw fa-github"></i></a>
|
||||||
<a class="btn btn-outline-light btn-social mx-1" href="https://blog.betterzon.xyz/"><i class="fab fa-fw fa-dribbble"></i></a>
|
<a class="btn btn-outline-light btn-social mx-1" href="https://blog.betterzon.xyz/"><i class="fab fa-fw fa-dribbble"></i></a>
|
||||||
</div>
|
</div>
|
||||||
|
|
|
@ -1,13 +1,14 @@
|
||||||
import { Component, OnInit } from '@angular/core';
|
import {Component, OnInit} from '@angular/core';
|
||||||
|
|
||||||
@Component({
|
@Component({
|
||||||
selector: 'app-bottom-bar',
|
selector: 'app-bottom-bar',
|
||||||
templateUrl: "./bottom-bar.component.html",
|
templateUrl: './bottom-bar.component.html',
|
||||||
styleUrls: ["./bottom-bar.component.css"]
|
styleUrls: ['./bottom-bar.component.css']
|
||||||
})
|
})
|
||||||
export class BottomBarComponent implements OnInit {
|
export class BottomBarComponent implements OnInit {
|
||||||
|
|
||||||
constructor() { }
|
constructor() {
|
||||||
|
}
|
||||||
|
|
||||||
ngOnInit(): void {
|
ngOnInit(): void {
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
import { Component, OnInit } from '@angular/core';
|
import {Component, OnInit} from '@angular/core';
|
||||||
|
|
||||||
@Component({
|
@Component({
|
||||||
selector: 'app-copyright',
|
selector: 'app-copyright',
|
||||||
|
@ -7,7 +7,8 @@ import { Component, OnInit } from '@angular/core';
|
||||||
})
|
})
|
||||||
export class CopyrightComponent implements OnInit {
|
export class CopyrightComponent implements OnInit {
|
||||||
|
|
||||||
constructor() { }
|
constructor() {
|
||||||
|
}
|
||||||
|
|
||||||
ngOnInit(): void {
|
ngOnInit(): void {
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
import { Component, OnInit } from '@angular/core';
|
import {Component, OnInit} from '@angular/core';
|
||||||
import {ActivatedRoute, Router} from '@angular/router';
|
import {ActivatedRoute, Router} from '@angular/router';
|
||||||
|
|
||||||
@Component({
|
@Component({
|
||||||
|
@ -11,7 +11,8 @@ export class FooterComponent implements OnInit {
|
||||||
constructor(
|
constructor(
|
||||||
private router: Router,
|
private router: Router,
|
||||||
private route: ActivatedRoute
|
private route: ActivatedRoute
|
||||||
) {}
|
) {
|
||||||
|
}
|
||||||
|
|
||||||
ngOnInit(): void {
|
ngOnInit(): void {
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
import { Component, OnInit } from '@angular/core';
|
import {Component, OnInit} from '@angular/core';
|
||||||
|
|
||||||
@Component({
|
@Component({
|
||||||
selector: 'app-greeting-info-slider',
|
selector: 'app-greeting-info-slider',
|
||||||
|
@ -7,7 +7,8 @@ import { Component, OnInit } from '@angular/core';
|
||||||
})
|
})
|
||||||
export class GreetingInfoSliderComponent implements OnInit {
|
export class GreetingInfoSliderComponent implements OnInit {
|
||||||
|
|
||||||
constructor() { }
|
constructor() {
|
||||||
|
}
|
||||||
|
|
||||||
ngOnInit(): void {
|
ngOnInit(): void {
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
<section class="page-section portfolio" id="top-gesuchte">
|
<section class="page-section portfolio" id="top-gesuchte">
|
||||||
<div class="container">
|
<div class="container">
|
||||||
<!-- Portfolio Section Heading-->
|
<!-- Portfolio Section Heading-->
|
||||||
<h2 class="page-section-heading text-center text-uppercase text-secondary mb-0">TOP-SEARCHES</h2>
|
<h2 class="page-section-heading text-center text-uppercase text-secondary mb-0">TOP-OFFERS</h2>
|
||||||
<!-- Icon Divider-->
|
<!-- Icon Divider-->
|
||||||
<div class="divider-custom">
|
<div class="divider-custom">
|
||||||
<div class="divider-custom-line"></div>
|
<div class="divider-custom-line"></div>
|
||||||
|
@ -17,10 +17,10 @@
|
||||||
<div class="bbb_deals_item_name">{{productsPricesMap[productId]?.product?.name}}</div>
|
<div class="bbb_deals_item_name">{{productsPricesMap[productId]?.product?.name}}</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="bbb_deals_info_line d-flex flex-row justify-content-start">
|
<div class="bbb_deals_info_line d-flex flex-row justify-content-start">
|
||||||
<div class="bbb_deals_item_category">Amazon: <span id="bbb_deals_item_price_a"><strike>{{productsPricesMap[productId]?.amazonPrice?.price_in_cents/100}}$</strike></span></div>
|
<div class="bbb_deals_item_category">Amazon: <span id="bbb_deals_item_price_a"><strike>{{productsPricesMap[productId]?.amazonPrice?.price_in_cents/100}}€</strike></span></div>
|
||||||
</div>
|
</div>
|
||||||
<div class="bbb_deals_info_line d-flex flex-row justify-content-start">
|
<div class="bbb_deals_info_line d-flex flex-row justify-content-start">
|
||||||
<div class="bbb_deals_item_category">{{productsPricesMap[productId]?.vendor?.name}}: <span id="bbb_deals_item_price_b">{{productsPricesMap[productId]?.lowestPrice?.price_in_cents/100}}</span></div>
|
<div class="bbb_deals_item_category">{{productsPricesMap[productId]?.vendor?.name}}: <span id="bbb_deals_item_price_b">{{productsPricesMap[productId]?.lowestPrice?.price_in_cents/100}}€</span></div>
|
||||||
</div>
|
</div>
|
||||||
<div class="available_bar">
|
<div class="available_bar">
|
||||||
<span style="width:17%"></span>
|
<span style="width:17%"></span>
|
||||||
|
|
|
@ -52,7 +52,7 @@ export class HotDealsWidgetComponent implements OnInit {
|
||||||
default: {
|
default: {
|
||||||
this.getProductsByIds();
|
this.getProductsByIds();
|
||||||
this.getAmazonPricesForBestDeals();
|
this.getAmazonPricesForBestDeals();
|
||||||
this.getVendors()
|
this.getVendors();
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -73,7 +73,7 @@ export class HotDealsWidgetComponent implements OnInit {
|
||||||
deals => {
|
deals => {
|
||||||
deals.forEach(deal => {
|
deals.forEach(deal => {
|
||||||
this.bestDealsProductIds.push(deal.product_id);
|
this.bestDealsProductIds.push(deal.product_id);
|
||||||
this.productsPricesMap [deal.product_id] = {lowestPrice: deal}
|
this.productsPricesMap [deal.product_id] = {lowestPrice: deal};
|
||||||
});
|
});
|
||||||
this.loadParams();
|
this.loadParams();
|
||||||
}
|
}
|
||||||
|
@ -92,7 +92,7 @@ export class HotDealsWidgetComponent implements OnInit {
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
getAmazonPricesForBestDeals(): void{
|
getAmazonPricesForBestDeals(): void {
|
||||||
this.bestDealsProductIds.forEach(id => {
|
this.bestDealsProductIds.forEach(id => {
|
||||||
this.apiService.getAmazonPrice(id).subscribe(
|
this.apiService.getAmazonPrice(id).subscribe(
|
||||||
price => {
|
price => {
|
||||||
|
|
|
@ -14,7 +14,7 @@
|
||||||
<div class="portfolio-item-caption d-flex align-items-center justify-content-center h-100 w-100">
|
<div class="portfolio-item-caption d-flex align-items-center justify-content-center h-100 w-100">
|
||||||
<div class="portfolio-item-caption-content text-center text-white"><i class="fas fa-plus fa-3x"></i></div>
|
<div class="portfolio-item-caption-content text-center text-white"><i class="fas fa-plus fa-3x"></i></div>
|
||||||
</div>
|
</div>
|
||||||
<img class="productImage" src="assets/images/Betterzon.svg"/>
|
<img width="100%" class="productImage" src="assets/images/cropped-unknown-1-1.png"/>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="col-md-6 col-lg-4 mb-5">
|
<div class="col-md-6 col-lg-4 mb-5">
|
||||||
|
@ -22,7 +22,7 @@
|
||||||
<div class="portfolio-item-caption d-flex align-items-center justify-content-center h-100 w-100">
|
<div class="portfolio-item-caption d-flex align-items-center justify-content-center h-100 w-100">
|
||||||
<div class="portfolio-item-caption-content text-center text-white"><i class="fas fa-plus fa-3x"></i></div>
|
<div class="portfolio-item-caption-content text-center text-white"><i class="fas fa-plus fa-3x"></i></div>
|
||||||
</div>
|
</div>
|
||||||
<img class="productImage" src="assets/images/Betterzon.svg"/>
|
<img width="100%" class="productImage" src="assets/images/plantshub.jpg"/>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="col-md-6 col-lg-4 mb-5">
|
<div class="col-md-6 col-lg-4 mb-5">
|
||||||
|
@ -30,7 +30,7 @@
|
||||||
<div class="portfolio-item-caption d-flex align-items-center justify-content-center h-100 w-100">
|
<div class="portfolio-item-caption d-flex align-items-center justify-content-center h-100 w-100">
|
||||||
<div class="portfolio-item-caption-content text-center text-white"><i class="fas fa-plus fa-3x"></i></div>
|
<div class="portfolio-item-caption-content text-center text-white"><i class="fas fa-plus fa-3x"></i></div>
|
||||||
</div>
|
</div>
|
||||||
<img class="productImage" src="assets/images/Betterzon.svg"/>
|
<img width="70%" class="productImage" src="assets/images/CeangalLogo.png"/>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
|
@ -46,7 +46,7 @@ export class ProductDetailsComponent implements OnInit {
|
||||||
this.getProduct();
|
this.getProduct();
|
||||||
this.getVendors();
|
this.getVendors();
|
||||||
this.getPrices();
|
this.getPrices();
|
||||||
if (this.apiService.getSessionInfoFromLocalStorage().session_id != "") {
|
if (this.apiService.getSessionInfoFromLocalStorage().session_id != '') {
|
||||||
this.isLoggedIn = true;
|
this.isLoggedIn = true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -123,10 +123,10 @@ export class ProductDetailsComponent implements OnInit {
|
||||||
return Math.round(percentage);
|
return Math.round(percentage);
|
||||||
}
|
}
|
||||||
|
|
||||||
setPriceAlarm() {
|
setPriceAlarm(): void {
|
||||||
this.apiService.createPriceAlarms(this.productId, this.price*100).subscribe(
|
this.apiService.createPriceAlarms(this.productId, this.price * 100).subscribe(
|
||||||
alarms => console.log(alarms)
|
alarms => console.log(alarms)
|
||||||
)
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -19,3 +19,8 @@ table, th, td {
|
||||||
cursor: pointer;
|
cursor: pointer;
|
||||||
color: #0d5a4b;
|
color: #0d5a4b;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
.edit {
|
||||||
|
width: 5%;
|
||||||
|
height: 5%;
|
||||||
|
}
|
||||||
|
|
|
@ -86,10 +86,10 @@
|
||||||
{{productsMap[alarm.product_id]?.name}}
|
{{productsMap[alarm.product_id]?.name}}
|
||||||
</td>
|
</td>
|
||||||
<td>
|
<td>
|
||||||
{{alarm.defined_price/100}}
|
{{alarm.defined_price/100}}€
|
||||||
</td>
|
</td>
|
||||||
<td>
|
<td>
|
||||||
<img class="delete" src="../assets/images/Delete_icon-icons.com_55931.png" (click)="delete(alarm.alarm_id)">
|
<img class="delete" src="../assets/images/pencil.png">
|
||||||
</td>
|
</td>
|
||||||
<td>
|
<td>
|
||||||
<img class="delete" src="../assets/images/Delete_icon-icons.com_55931.png" (click)="delete(alarm.alarm_id)">
|
<img class="delete" src="../assets/images/Delete_icon-icons.com_55931.png" (click)="delete(alarm.alarm_id)">
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
import { Component, OnInit } from '@angular/core';
|
import {Component, OnInit} from '@angular/core';
|
||||||
import {ApiService} from "../../services/api.service";
|
import {ApiService} from '../../services/api.service';
|
||||||
|
|
||||||
@Component({
|
@Component({
|
||||||
selector: 'app-profile',
|
selector: 'app-profile',
|
||||||
|
@ -9,17 +9,18 @@ import {ApiService} from "../../services/api.service";
|
||||||
export class ProfileComponent implements OnInit {
|
export class ProfileComponent implements OnInit {
|
||||||
|
|
||||||
currentUser: any;
|
currentUser: any;
|
||||||
obj:any;
|
obj: any;
|
||||||
alarms: any [];
|
alarms: any [];
|
||||||
productsMap: any = {};
|
productsMap: any = {};
|
||||||
|
|
||||||
constructor(private api: ApiService ) { }
|
constructor(private api: ApiService) {
|
||||||
|
}
|
||||||
|
|
||||||
ngOnInit(): void {
|
ngOnInit(): void {
|
||||||
|
|
||||||
this.api.getUserInfo().subscribe(
|
this.api.getUserInfo().subscribe(
|
||||||
user=> {
|
user => {
|
||||||
this.currentUser = user
|
this.currentUser = user;
|
||||||
console.log(this.currentUser);
|
console.log(this.currentUser);
|
||||||
},
|
},
|
||||||
);
|
);
|
||||||
|
@ -30,29 +31,33 @@ export class ProfileComponent implements OnInit {
|
||||||
getPriceAlarms(): void {
|
getPriceAlarms(): void {
|
||||||
this.api.getPriceAlarms().subscribe(
|
this.api.getPriceAlarms().subscribe(
|
||||||
alarms => {
|
alarms => {
|
||||||
this.alarms = alarms
|
this.alarms = alarms;
|
||||||
this.getProductsByIds()
|
this.getProductsByIds();
|
||||||
}
|
}
|
||||||
)
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
getProductsByIds(): void {
|
getProductsByIds(): void {
|
||||||
let productIds: number [] = [];
|
const productIds: number [] = [];
|
||||||
this.alarms.forEach(
|
this.alarms.forEach(
|
||||||
alarm => {productIds.push(alarm.product_id)}
|
alarm => {
|
||||||
|
productIds.push(alarm.product_id);
|
||||||
|
}
|
||||||
);
|
);
|
||||||
this.api.getProductsByIds(productIds).subscribe(
|
this.api.getProductsByIds(productIds).subscribe(
|
||||||
products => {
|
products => {
|
||||||
products.forEach(
|
products.forEach(
|
||||||
product => {this.productsMap[product.product_id] = product}
|
product => {
|
||||||
)
|
this.productsMap[product.product_id] = product;
|
||||||
}
|
}
|
||||||
)
|
);
|
||||||
|
}
|
||||||
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
delete(id:number): void {
|
delete(id: number): void {
|
||||||
this.api.deletePriceAlarm(id).subscribe(
|
this.api.deletePriceAlarm(id).subscribe(
|
||||||
res => window.location.reload()
|
res => window.location.reload()
|
||||||
)
|
);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
import { Component, OnInit } from '@angular/core';
|
import {Component, OnInit} from '@angular/core';
|
||||||
|
|
||||||
@Component({
|
@Component({
|
||||||
selector: 'app-slider-for-products',
|
selector: 'app-slider-for-products',
|
||||||
|
@ -7,7 +7,8 @@ import { Component, OnInit } from '@angular/core';
|
||||||
})
|
})
|
||||||
export class SliderForProductsComponent implements OnInit {
|
export class SliderForProductsComponent implements OnInit {
|
||||||
|
|
||||||
constructor() { }
|
constructor() {
|
||||||
|
}
|
||||||
|
|
||||||
ngOnInit(): void {
|
ngOnInit(): void {
|
||||||
}
|
}
|
||||||
|
|
|
@ -10,7 +10,7 @@
|
||||||
</button>
|
</button>
|
||||||
<div class="collapse navbar-collapse" id="navbarResponsive">
|
<div class="collapse navbar-collapse" id="navbarResponsive">
|
||||||
<ul class="navbar-nav ms-auto">
|
<ul class="navbar-nav ms-auto">
|
||||||
<li class="nav-item mx-0 mx-lg-1"><a class="nav-link py-3 px-0 px-lg-3 rounded" href="#top-gesuchte">top-searches</a></li>
|
<li class="nav-item mx-0 mx-lg-1"><a class="nav-link py-3 px-0 px-lg-3 rounded" href="#top-gesuchte">top-offers</a></li>
|
||||||
<li class="nav-item mx-0 mx-lg-1"><a class="nav-link py-3 px-0 px-lg-3 rounded" href="#about">about</a></li>
|
<li class="nav-item mx-0 mx-lg-1"><a class="nav-link py-3 px-0 px-lg-3 rounded" href="#about">about</a></li>
|
||||||
<li class="nav-item mx-0 mx-lg-1"><a class="nav-link py-3 px-0 px-lg-3 rounded" href="#unsere-kunden">our clients</a></li>
|
<li class="nav-item mx-0 mx-lg-1"><a class="nav-link py-3 px-0 px-lg-3 rounded" href="#unsere-kunden">our clients</a></li>
|
||||||
<li class="nav-item mx-0 mx-lg-1" *ngIf="!isLoggedIn"><a class="nav-link py-3 px-0 px-lg-3 rounded" routerLink="/signin">sign in</a></li>
|
<li class="nav-item mx-0 mx-lg-1" *ngIf="!isLoggedIn"><a class="nav-link py-3 px-0 px-lg-3 rounded" routerLink="/signin">sign in</a></li>
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
import {Component, Input, OnInit} from '@angular/core';
|
import {Component, Input, OnInit} from '@angular/core';
|
||||||
import {ApiService} from "../../services/api.service";
|
import {ApiService} from '../../services/api.service';
|
||||||
import {Router} from "@angular/router";
|
import {NavigationEnd, Router} from '@angular/router';
|
||||||
|
|
||||||
|
|
||||||
@Component({
|
@Component({
|
||||||
|
@ -20,13 +20,12 @@ export class TopBarComponent implements OnInit {
|
||||||
) {
|
) {
|
||||||
}
|
}
|
||||||
|
|
||||||
ngOnInit() {
|
ngOnInit(): void {
|
||||||
|
|
||||||
this.api.getUserInfo().subscribe(data => {
|
this.api.getUserInfo().subscribe(data => {
|
||||||
console.log(data)
|
console.log(data);
|
||||||
});
|
});
|
||||||
|
|
||||||
if (this.api.getSessionInfoFromLocalStorage().session_id != "") {
|
if (this.api.getSessionInfoFromLocalStorage().session_id !== '') {
|
||||||
this.isLoggedIn = true;
|
this.isLoggedIn = true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -34,7 +33,11 @@ export class TopBarComponent implements OnInit {
|
||||||
logout(): void {
|
logout(): void {
|
||||||
localStorage.setItem('session_id', '');
|
localStorage.setItem('session_id', '');
|
||||||
localStorage.setItem('session_key', '');
|
localStorage.setItem('session_key', '');
|
||||||
window.location.reload()
|
if (this.router.url === '/profile') {
|
||||||
|
this.router.navigate(['/']);
|
||||||
|
} else {
|
||||||
|
window.location.reload();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
getSearchedProducts(): void {
|
getSearchedProducts(): void {
|
||||||
|
|
BIN
Frontend/src/assets/images/CeangalLogo.png
Normal file
BIN
Frontend/src/assets/images/CeangalLogo.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 51 KiB |
BIN
Frontend/src/assets/images/cropped-unknown-1-1.png
Normal file
BIN
Frontend/src/assets/images/cropped-unknown-1-1.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 74 KiB |
BIN
Frontend/src/assets/images/pencil.png
Normal file
BIN
Frontend/src/assets/images/pencil.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 1.4 KiB |
BIN
Frontend/src/assets/images/plantshub.jpg
Normal file
BIN
Frontend/src/assets/images/plantshub.jpg
Normal file
Binary file not shown.
After Width: | Height: | Size: 15 KiB |
Loading…
Reference in New Issue
Block a user