diff --git a/src/app/shared/shared-components/location-dialog/location-dialog.component.scss b/src/app/shared/shared-components/location-dialog/location-dialog.component.scss
new file mode 100644
index 0000000..1eb9441
--- /dev/null
+++ b/src/app/shared/shared-components/location-dialog/location-dialog.component.scss
@@ -0,0 +1,28 @@
+.locationdialog-conatiner {
+ position: relative;
+ padding: 15px 10px;
+ .cross {
+ position: absolute;
+ right: 5px;
+ top: -5px;
+ margin: 20px;
+ width: 20px;
+ height: 20px;
+ }
+ background-color: #f6f6f6;
+ overflow-y: auto;
+ overflow-x: hidden;
+ max-height: 75vh;
+ .browser-content {
+ margin: 15px 0px;
+ img {
+ width: 100%;
+ height: auto;
+ }
+ h3 {
+ font-weight: bolder;
+ text-decoration: underline;
+ text-align: center;
+ }
+ }
+}
diff --git a/src/app/shared/shared-components/location-dialog/location-dialog.component.ts b/src/app/shared/shared-components/location-dialog/location-dialog.component.ts
new file mode 100644
index 0000000..ad49ffb
--- /dev/null
+++ b/src/app/shared/shared-components/location-dialog/location-dialog.component.ts
@@ -0,0 +1,143 @@
+import { Component, OnInit } from '@angular/core';
+import { DeviceDetectorService } from 'ngx-device-detector';
+import { MatBottomSheetRef } from '@angular/material';
+
+export const BROWSERS = {
+ CHROME: 'Chrome',
+ FIREFOX: 'Firefox',
+ SAFARI: 'Safari',
+ OPERA: 'Opera',
+ IE: 'IE',
+ MS_EDGE: 'MS-Edge',
+ MS_EDGE_CHROMIUM: 'MS-Edge-Chromium',
+ FB_MESSANGER: 'FB-Messanger',
+ SAMSUNG: 'Samsung',
+ UCBROWSER: 'UC-Browser',
+ UNKNOWN: 'Unknown'
+};
+@Component({
+ selector: 'app-location-dialog',
+ templateUrl: './location-dialog.component.html',
+ styleUrls: ['./location-dialog.component.scss'],
+})
+export class LocationDialogComponent implements OnInit {
+ selectedBrowser = [];
+ stepsMap = {
+ [BROWSERS.CHROME]: [
+ {
+ step: '1',
+ image: 'https://password-managers.bestreviews.net/files/six-web-browsers.png',
+ text: "Lorem Ipsum is simply dummy text of the printing and typesetting industry. Lorem Ipsum has been the industry's.",
+ },
+ {
+ step: '2',
+ image: 'https://password-managers.bestreviews.net/files/six-web-browsers.png',
+ text: "Lorem Ipsum is simply dummy text of the printing and typesetting industry. Lorem Ipsum has been the industry's.",
+ },
+ {
+ step: '3',
+ image: 'https://password-managers.bestreviews.net/files/six-web-browsers.png',
+ text: "Lorem Ipsum is simply dummy text of the printing and typesetting industry. Lorem Ipsum has been the industry's.",
+ },
+ ],
+ [BROWSERS.MS_EDGE]: [
+ {
+ step: '1',
+ image: 'https://password-managers.bestreviews.net/files/six-web-browsers.png',
+ text: "Lorem Ipsum is simply dummy text of the printing and typesetting industry. Lorem Ipsum has been the industry's.",
+ },
+ {
+ step: '2',
+ image: 'https://password-managers.bestreviews.net/files/six-web-browsers.png',
+ text: "Lorem Ipsum is simply dummy text of the printing and typesetting industry. Lorem Ipsum has been the industry's.",
+ },
+ {
+ step: '3',
+ image: 'https://password-managers.bestreviews.net/files/six-web-browsers.png',
+ text: "Lorem Ipsum is simply dummy text of the printing and typesetting industry. Lorem Ipsum has been the industry's.",
+ },
+ ],
+ [BROWSERS.FIREFOX]: [
+ {
+ step: '1',
+ image: 'https://password-managers.bestreviews.net/files/six-web-browsers.png',
+ text: "Lorem Ipsum is simply dummy text of the printing and typesetting industry. Lorem Ipsum has been the industry's.",
+ },
+ {
+ step: '2',
+ image: 'https://password-managers.bestreviews.net/files/six-web-browsers.png',
+ text: "Lorem Ipsum is simply dummy text of the printing and typesetting industry. Lorem Ipsum has been the industry's.",
+ },
+ {
+ step: '3',
+ image: 'https://password-managers.bestreviews.net/files/six-web-browsers.png',
+ text: "Lorem Ipsum is simply dummy text of the printing and typesetting industry. Lorem Ipsum has been the industry's.",
+ },
+ ],
+ [BROWSERS.SAFARI]: [
+ {
+ step: '1',
+ image: 'https://password-managers.bestreviews.net/files/six-web-browsers.png',
+ text: "Lorem Ipsum is simply dummy text of the printing and typesetting industry. Lorem Ipsum has been the industry's.",
+ },
+ {
+ step: '2',
+ image: 'https://password-managers.bestreviews.net/files/six-web-browsers.png',
+ text: "Lorem Ipsum is simply dummy text of the printing and typesetting industry. Lorem Ipsum has been the industry's.",
+ },
+ {
+ step: '3',
+ image: 'https://password-managers.bestreviews.net/files/six-web-browsers.png',
+ text: "Lorem Ipsum is simply dummy text of the printing and typesetting industry. Lorem Ipsum has been the industry's.",
+ },
+ ],
+ [BROWSERS.UNKNOWN]: [
+ {
+ step: '1',
+ image: 'https://password-managers.bestreviews.net/files/six-web-browsers.png',
+ text: "Lorem Ipsum is simply dummy text of the printing and typesetting industry. Lorem Ipsum has been the industry's.",
+ },
+ {
+ step: '2',
+ image: 'https://password-managers.bestreviews.net/files/six-web-browsers.png',
+ text: "Lorem Ipsum is simply dummy text of the printing and typesetting industry. Lorem Ipsum has been the industry's.",
+ },
+ {
+ step: '3',
+ image: 'https://password-managers.bestreviews.net/files/six-web-browsers.png',
+ text: "Lorem Ipsum is simply dummy text of the printing and typesetting industry. Lorem Ipsum has been the industry's.",
+ },
+ ],
+ };
+
+ chrome = [
+ {
+ step: '1',
+ image: 'https://password-managers.bestreviews.net/files/six-web-browsers.png',
+ text: "Lorem Ipsum is simply dummy text of the printing and typesetting industry. Lorem Ipsum has been the industry's.",
+ },
+ {
+ step: '2',
+ image: 'https://password-managers.bestreviews.net/files/six-web-browsers.png',
+ text: "Lorem Ipsum is simply dummy text of the printing and typesetting industry. Lorem Ipsum has been the industry's.",
+ },
+ {
+ step: '3',
+ image: 'https://password-managers.bestreviews.net/files/six-web-browsers.png',
+ text: "Lorem Ipsum is simply dummy text of the printing and typesetting industry. Lorem Ipsum has been the industry's.",
+ },
+ ];
+ deviceInfo: any;
+
+ constructor(private deviceService: DeviceDetectorService, private bottomRef: MatBottomSheetRef) {}
+
+ ngOnInit() {
+ console.log('hello `Home` component');
+ this.deviceInfo = this.deviceService.getDeviceInfo();
+ this.selectedBrowser = this.stepsMap[this.deviceInfo.browser];
+ }
+
+ closePage() {
+ this.bottomRef.dismiss();
+ }
+}
diff --git a/src/app/shared/shared-components/location-popup/location-popup.component.html b/src/app/shared/shared-components/location-popup/location-popup.component.html
new file mode 100644
index 0000000..45d4540
--- /dev/null
+++ b/src/app/shared/shared-components/location-popup/location-popup.component.html
@@ -0,0 +1,10 @@
+