diff --git a/.idea/PassionBy5dot0.iml b/.idea/PassionBy5dot0.iml new file mode 100644 index 0000000..24643cc --- /dev/null +++ b/.idea/PassionBy5dot0.iml @@ -0,0 +1,12 @@ + + + + + + + + + + + + \ No newline at end of file diff --git a/.idea/encodings.xml b/.idea/encodings.xml new file mode 100644 index 0000000..15a15b2 --- /dev/null +++ b/.idea/encodings.xml @@ -0,0 +1,4 @@ + + + + \ No newline at end of file diff --git a/.idea/misc.xml b/.idea/misc.xml new file mode 100644 index 0000000..28a804d --- /dev/null +++ b/.idea/misc.xml @@ -0,0 +1,6 @@ + + + + + \ No newline at end of file diff --git a/.idea/modules.xml b/.idea/modules.xml new file mode 100644 index 0000000..fbe1e85 --- /dev/null +++ b/.idea/modules.xml @@ -0,0 +1,8 @@ + + + + + + + + \ No newline at end of file diff --git a/.idea/vcs.xml b/.idea/vcs.xml new file mode 100644 index 0000000..94a25f7 --- /dev/null +++ b/.idea/vcs.xml @@ -0,0 +1,6 @@ + + + + + + \ No newline at end of file diff --git a/.idea/workspace.xml b/.idea/workspace.xml new file mode 100644 index 0000000..5470137 --- /dev/null +++ b/.idea/workspace.xml @@ -0,0 +1,854 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + h1 + menu + menugit + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+ + + + +
+
+ +
+ + + + +
diff --git a/EduWaiterAppClient/src/app/components/login/admin-login/admin-login.component.spec.ts b/EduWaiterAppClient/src/app/components/login/admin-login/admin-login.component.spec.ts new file mode 100644 index 0000000..08ce656 --- /dev/null +++ b/EduWaiterAppClient/src/app/components/login/admin-login/admin-login.component.spec.ts @@ -0,0 +1,25 @@ +import { async, ComponentFixture, TestBed } from '@angular/core/testing'; + +import { AdminLoginComponent } from './admin-login.component'; + +describe('AdminLoginComponent', () => { + let component: AdminLoginComponent; + let fixture: ComponentFixture; + + beforeEach(async(() => { + TestBed.configureTestingModule({ + declarations: [ AdminLoginComponent ] + }) + .compileComponents(); + })); + + beforeEach(() => { + fixture = TestBed.createComponent(AdminLoginComponent); + component = fixture.componentInstance; + fixture.detectChanges(); + }); + + it('should create', () => { + expect(component).toBeTruthy(); + }); +}); diff --git a/EduWaiterAppClient/src/app/components/login/admin-login/admin-login.component.ts b/EduWaiterAppClient/src/app/components/login/admin-login/admin-login.component.ts new file mode 100644 index 0000000..08f876d --- /dev/null +++ b/EduWaiterAppClient/src/app/components/login/admin-login/admin-login.component.ts @@ -0,0 +1,55 @@ +import {Component, OnInit} from '@angular/core'; +import {FormBuilder, FormGroup} from "@angular/forms"; +import {Router} from "@angular/router"; +import {AccountService} from "../../../services/account.service"; +import {LocalStorageService} from "ngx-webstorage"; +import {RestaurantService} from "../../../services/restaurant.service"; + +@Component({ + selector: 'app-admin-login', + templateUrl: './admin-login.component.html', + styleUrls: ['./admin-login.component.css'] +}) +export class AdminLoginComponent implements OnInit { + + loginForm: FormGroup; + submitted: boolean; + response: any; + + constructor(private formBuilder: FormBuilder, + private router: Router, + private accountService: AccountService, + private storage: LocalStorageService, + private restaurantService: RestaurantService) { + } + + ngOnInit() { + this.submitted = false; + this.loginForm = this.formBuilder.group({ + username: '', + password: '' + }); + } + + onSubmit() { + let username = this.loginForm.controls.username.value; + let password = this.loginForm.controls.password.value; + this.accountService.loginAdmin(username, password).subscribe(success => { + this.response = success; + this.submitted = true; + if (this.response instanceof Object) { + this.updateRestaurant(username); + this.router.navigate(["/home"]); + } + }); + } + + updateRestaurant(username: string) { + this.accountService.findAdminByUsername(username).subscribe(admin => { + this.restaurantService.findById(admin.restaurant.id).subscribe(restaurant => { + this.storage.store("restaurant", restaurant); + console.log(restaurant); + }); + }); + } +} diff --git a/EduWaiterAppClient/src/app/components/login/employee-login/employee-login.component.css b/EduWaiterAppClient/src/app/components/login/employee-login/employee-login.component.css new file mode 100644 index 0000000..e69de29 diff --git a/EduWaiterAppClient/src/app/components/login/employee-login/employee-login.component.html b/EduWaiterAppClient/src/app/components/login/employee-login/employee-login.component.html new file mode 100644 index 0000000..69453b7 --- /dev/null +++ b/EduWaiterAppClient/src/app/components/login/employee-login/employee-login.component.html @@ -0,0 +1,34 @@ + +
+ +
+
+

Employee Login

+ +
+

{{response}}

+
+ +
+ +
+ + +
+
+ + + + +
+
+ +
+
+
+
+
+
+ diff --git a/EduWaiterAppClient/src/app/components/login/employee-login/employee-login.component.spec.ts b/EduWaiterAppClient/src/app/components/login/employee-login/employee-login.component.spec.ts new file mode 100644 index 0000000..0cc74be --- /dev/null +++ b/EduWaiterAppClient/src/app/components/login/employee-login/employee-login.component.spec.ts @@ -0,0 +1,25 @@ +import { async, ComponentFixture, TestBed } from '@angular/core/testing'; + +import { EmployeeLoginComponent } from './employee-login.component'; + +describe('EmployeeLoginComponent', () => { + let component: EmployeeLoginComponent; + let fixture: ComponentFixture; + + beforeEach(async(() => { + TestBed.configureTestingModule({ + declarations: [ EmployeeLoginComponent ] + }) + .compileComponents(); + })); + + beforeEach(() => { + fixture = TestBed.createComponent(EmployeeLoginComponent); + component = fixture.componentInstance; + fixture.detectChanges(); + }); + + it('should create', () => { + expect(component).toBeTruthy(); + }); +}); diff --git a/EduWaiterAppClient/src/app/components/login/employee-login/employee-login.component.ts b/EduWaiterAppClient/src/app/components/login/employee-login/employee-login.component.ts new file mode 100644 index 0000000..9f6d8fc --- /dev/null +++ b/EduWaiterAppClient/src/app/components/login/employee-login/employee-login.component.ts @@ -0,0 +1,53 @@ +import {Component, OnInit} from '@angular/core'; +import {FormBuilder, FormGroup} from "@angular/forms"; +import {Router} from "@angular/router"; +import {AccountService} from "../../../services/account.service"; +import {LocalStorageService} from "ngx-webstorage"; +import {RestaurantService} from "../../../services/restaurant.service"; + +@Component({ + selector: 'app-employee-login', + templateUrl: './employee-login.component.html', + styleUrls: ['./employee-login.component.css'] +}) +export class EmployeeLoginComponent implements OnInit { + + loginForm: FormGroup; + submitted: boolean; + response: any; + + constructor(private formBuilder: FormBuilder, + private router: Router, + private accountService: AccountService, + private storage: LocalStorageService, + private restaurantService: RestaurantService) { + } + + ngOnInit() { + this.loginForm = this.formBuilder.group({ + username: '', + password: '' + }); + } + + onSubmit() { + let username = this.loginForm.controls.username.value; + let password = this.loginForm.controls.password.value; + this.accountService.loginEmployee(username, password).subscribe(success => { + this.response = success; + this.submitted = true; + if (this.response instanceof Object) { + this.updateRestaurant(username); + this.router.navigate(["/home"]); + } + }); + } + + updateRestaurant(username: string) { + this.accountService.findEmployeeByUsername(username).subscribe(employee => { + this.restaurantService.findById(employee.restaurant.id).subscribe(restaurant => { + this.storage.store("restaurant", restaurant); + }); + }); + } +} diff --git a/EduWaiterAppClient/src/app/components/login/login.component.css b/EduWaiterAppClient/src/app/components/login/login.component.css new file mode 100644 index 0000000..e69de29 diff --git a/EduWaiterAppClient/src/app/components/login/login.component.html b/EduWaiterAppClient/src/app/components/login/login.component.html new file mode 100644 index 0000000..98b9c52 --- /dev/null +++ b/EduWaiterAppClient/src/app/components/login/login.component.html @@ -0,0 +1,12 @@ +
+ +
+
+ +

Login

+ + Login as Admin
+ Login as Employee
+
+
+
diff --git a/EduWaiterAppClient/src/app/components/login/login.component.spec.ts b/EduWaiterAppClient/src/app/components/login/login.component.spec.ts new file mode 100644 index 0000000..d6d85a8 --- /dev/null +++ b/EduWaiterAppClient/src/app/components/login/login.component.spec.ts @@ -0,0 +1,25 @@ +import { async, ComponentFixture, TestBed } from '@angular/core/testing'; + +import { LoginComponent } from './login.component'; + +describe('LoginComponent', () => { + let component: LoginComponent; + let fixture: ComponentFixture; + + beforeEach(async(() => { + TestBed.configureTestingModule({ + declarations: [ LoginComponent ] + }) + .compileComponents(); + })); + + beforeEach(() => { + fixture = TestBed.createComponent(LoginComponent); + component = fixture.componentInstance; + fixture.detectChanges(); + }); + + it('should create', () => { + expect(component).toBeTruthy(); + }); +}); diff --git a/EduWaiterAppClient/src/app/components/login/login.component.ts b/EduWaiterAppClient/src/app/components/login/login.component.ts new file mode 100644 index 0000000..4841fae --- /dev/null +++ b/EduWaiterAppClient/src/app/components/login/login.component.ts @@ -0,0 +1,16 @@ +import { Component, OnInit } from '@angular/core'; +import {Router} from "@angular/router"; + +@Component({ + selector: 'app-login', + templateUrl: './login.component.html', + styleUrls: ['./login.component.css'] +}) +export class LoginComponent implements OnInit { + + constructor(private router: Router) { } + + ngOnInit() { + } + +} diff --git a/EduWaiterAppClient/src/app/components/menu/menu-detail/menu-detail.component.css b/EduWaiterAppClient/src/app/components/menu/menu-detail/menu-detail.component.css new file mode 100644 index 0000000..e69de29 diff --git a/EduWaiterAppClient/src/app/components/menu/menu-detail/menu-detail.component.html b/EduWaiterAppClient/src/app/components/menu/menu-detail/menu-detail.component.html new file mode 100644 index 0000000..694f1dd --- /dev/null +++ b/EduWaiterAppClient/src/app/components/menu/menu-detail/menu-detail.component.html @@ -0,0 +1,28 @@ +
+
+ +

{{menu.name}}

+

{{menu.description}}

+
+ +
+ +
+ + + + +
+
+ + +
+ +
+
+
+ +
+ +
+
\ No newline at end of file diff --git a/EduWaiterAppClient/src/app/components/menu/menu-detail/menu-detail.component.spec.ts b/EduWaiterAppClient/src/app/components/menu/menu-detail/menu-detail.component.spec.ts new file mode 100644 index 0000000..cb5bd2d --- /dev/null +++ b/EduWaiterAppClient/src/app/components/menu/menu-detail/menu-detail.component.spec.ts @@ -0,0 +1,25 @@ +import { async, ComponentFixture, TestBed } from '@angular/core/testing'; + +import { MenuDetailComponent } from './menu-detail.component'; + +describe('MenuDetailComponent', () => { + let component: MenuDetailComponent; + let fixture: ComponentFixture; + + beforeEach(async(() => { + TestBed.configureTestingModule({ + declarations: [ MenuDetailComponent ] + }) + .compileComponents(); + })); + + beforeEach(() => { + fixture = TestBed.createComponent(MenuDetailComponent); + component = fixture.componentInstance; + fixture.detectChanges(); + }); + + it('should create', () => { + expect(component).toBeTruthy(); + }); +}); diff --git a/EduWaiterAppClient/src/app/components/menu/menu-detail/menu-detail.component.ts b/EduWaiterAppClient/src/app/components/menu/menu-detail/menu-detail.component.ts new file mode 100644 index 0000000..8294d73 --- /dev/null +++ b/EduWaiterAppClient/src/app/components/menu/menu-detail/menu-detail.component.ts @@ -0,0 +1,56 @@ +import {Component, OnInit} from '@angular/core'; +import {LocalStorageService} from "ngx-webstorage"; +import {Menu} from "../../../models/menu"; +import {MenuItem} from "../../../models/menu-item"; +import {AdminAccount} from "../../../models/admin-account"; +import {EmployeeAccount} from "../../../models/employee-account"; +import {MenuService} from "../../../services/menu.service"; +import {Restaurant} from "../../../models/restaurant"; + +@Component({ + selector: 'app-menu-detail', + templateUrl: './menu-detail.component.html', + styleUrls: ['./menu-detail.component.css'] +}) +export class MenuDetailComponent implements OnInit { + + menu: Menu; + menuItems: MenuItem[]; + admin: AdminAccount; + restaurant: Restaurant; + employee: EmployeeAccount; + editing: boolean; + + constructor(private storage: LocalStorageService, + private menuService: MenuService) { + } + + ngOnInit() { + this.menu = this.storage.retrieve("currentMenu"); + this.restaurant = this.storage.retrieve("restaurant"); + this.admin = this.storage.retrieve("admin"); + this.employee = this.storage.retrieve("employee"); + } + + goBack() { + this.storage.store("currentMenu", null); + } + + + saveDescription() { + console.log(this.menu); + this.menuService.updateRestaurant(this.menu, this.restaurant.id).subscribe(updatedMenu => { + this.menuService.updateDescription(updatedMenu, this.menu.description).subscribe(menu => { + this.storage.store("currentMenu", menu); + this.menu = menu; + console.log(menu); + this.editing = false; + }); + }); + } + + + addMenuItem() { + } + +} diff --git a/EduWaiterAppClient/src/app/components/menu/menu-editor/menu-editor.component.css b/EduWaiterAppClient/src/app/components/menu/menu-editor/menu-editor.component.css new file mode 100644 index 0000000..e69de29 diff --git a/EduWaiterAppClient/src/app/components/menu/menu-editor/menu-editor.component.html b/EduWaiterAppClient/src/app/components/menu/menu-editor/menu-editor.component.html new file mode 100644 index 0000000..c2c42b5 --- /dev/null +++ b/EduWaiterAppClient/src/app/components/menu/menu-editor/menu-editor.component.html @@ -0,0 +1 @@ +

Menu Editor

\ No newline at end of file diff --git a/EduWaiterAppClient/src/app/components/menu/menu-editor/menu-editor.component.spec.ts b/EduWaiterAppClient/src/app/components/menu/menu-editor/menu-editor.component.spec.ts new file mode 100644 index 0000000..20fa496 --- /dev/null +++ b/EduWaiterAppClient/src/app/components/menu/menu-editor/menu-editor.component.spec.ts @@ -0,0 +1,25 @@ +import { async, ComponentFixture, TestBed } from '@angular/core/testing'; + +import { MenuEditorComponent } from './menu-editor.component'; + +describe('MenuEditorComponent', () => { + let component: MenuEditorComponent; + let fixture: ComponentFixture; + + beforeEach(async(() => { + TestBed.configureTestingModule({ + declarations: [ MenuEditorComponent ] + }) + .compileComponents(); + })); + + beforeEach(() => { + fixture = TestBed.createComponent(MenuEditorComponent); + component = fixture.componentInstance; + fixture.detectChanges(); + }); + + it('should create', () => { + expect(component).toBeTruthy(); + }); +}); diff --git a/EduWaiterAppClient/src/app/components/menu/menu-editor/menu-editor.component.ts b/EduWaiterAppClient/src/app/components/menu/menu-editor/menu-editor.component.ts new file mode 100644 index 0000000..fd92ad7 --- /dev/null +++ b/EduWaiterAppClient/src/app/components/menu/menu-editor/menu-editor.component.ts @@ -0,0 +1,15 @@ +import { Component, OnInit } from '@angular/core'; + +@Component({ + selector: 'app-menu-editor', + templateUrl: './menu-editor.component.html', + styleUrls: ['./menu-editor.component.css'] +}) +export class MenuEditorComponent implements OnInit { + + constructor() { } + + ngOnInit() { + } + +} diff --git a/EduWaiterAppClient/src/app/components/menu/menu.component.css b/EduWaiterAppClient/src/app/components/menu/menu.component.css new file mode 100644 index 0000000..e69de29 diff --git a/EduWaiterAppClient/src/app/components/menu/menu.component.html b/EduWaiterAppClient/src/app/components/menu/menu.component.html new file mode 100644 index 0000000..fc8c2b6 --- /dev/null +++ b/EduWaiterAppClient/src/app/components/menu/menu.component.html @@ -0,0 +1,25 @@ + + +

Menus

+ + +
+ +
+ + +
+
+ +
+ +
+ Add +
+
+
+
+
diff --git a/EduWaiterAppClient/src/app/components/menu/menu.component.spec.ts b/EduWaiterAppClient/src/app/components/menu/menu.component.spec.ts new file mode 100644 index 0000000..beb2d9b --- /dev/null +++ b/EduWaiterAppClient/src/app/components/menu/menu.component.spec.ts @@ -0,0 +1,25 @@ +import { async, ComponentFixture, TestBed } from '@angular/core/testing'; + +import { MenuComponent } from './menu.component'; + +describe('MenuComponent', () => { + let component: MenuComponent; + let fixture: ComponentFixture; + + beforeEach(async(() => { + TestBed.configureTestingModule({ + declarations: [ MenuComponent ] + }) + .compileComponents(); + })); + + beforeEach(() => { + fixture = TestBed.createComponent(MenuComponent); + component = fixture.componentInstance; + fixture.detectChanges(); + }); + + it('should create', () => { + expect(component).toBeTruthy(); + }); +}); diff --git a/EduWaiterAppClient/src/app/components/menu/menu.component.ts b/EduWaiterAppClient/src/app/components/menu/menu.component.ts new file mode 100644 index 0000000..96eb81d --- /dev/null +++ b/EduWaiterAppClient/src/app/components/menu/menu.component.ts @@ -0,0 +1,60 @@ +import {Component, OnInit} from '@angular/core'; +import {Menu} from "../../models/menu"; +import {Restaurant} from "../../models/restaurant"; +import {LocalStorageService} from "ngx-webstorage"; +import {MenuService} from "../../services/menu.service"; +import {RestaurantService} from "../../services/restaurant.service"; + +@Component({ + selector: 'app-menu', + templateUrl: './menu.component.html', + styleUrls: ['./menu.component.css'] +}) +export class MenuComponent implements OnInit { + + + employee: Account; + admin: Account; + restaurant: Restaurant = new Restaurant(); + currentMenu: Menu; + newMenuName: string; + selectedMenu: any; + + constructor(private storage: LocalStorageService, + private menuService: MenuService, + private restaurantService: RestaurantService) { + } + + ngOnInit() { + this.currentMenu = null; + this.storage.store("currentMenu", null); + this.admin = this.storage.retrieve("admin"); + this.employee = this.storage.retrieve("employee"); + this.restaurantService.findById(this.storage.retrieve("restaurant").id).subscribe(restaurant => { + this.restaurant = restaurant; + }); + } + + selected() { + if (this.selectedMenu) { + console.log(this.selectedMenu); + this.storage.store("currentMenu", this.selectedMenu); + } + } + + + addMenu() { + if (this.newMenuName) { + this.menuService.createMenu(new Menu(null, this.newMenuName, "", [], null)).subscribe(newMenu => { + this.restaurantService.addMenu(this.restaurant, newMenu.id).subscribe(restaurant => { + this.menuService.updateRestaurant(newMenu, restaurant.id).subscribe(menu => { + this.storage.store("restaurant", restaurant); + this.storage.store("currentMenu", menu); + this.restaurant = restaurant; + this.currentMenu = menu; + }); + }); + }); + } + } +} diff --git a/EduWaiterAppClient/src/app/components/register/admin-register/admin-register.component.css b/EduWaiterAppClient/src/app/components/register/admin-register/admin-register.component.css new file mode 100644 index 0000000..e69de29 diff --git a/EduWaiterAppClient/src/app/components/register/admin-register/admin-register.component.html b/EduWaiterAppClient/src/app/components/register/admin-register/admin-register.component.html new file mode 100644 index 0000000..d2e06f9 --- /dev/null +++ b/EduWaiterAppClient/src/app/components/register/admin-register/admin-register.component.html @@ -0,0 +1,104 @@ + +
+ +
+
+

Register as Admin

+ + +

+ +

+ +
+

Register a new restaurant account

+
+ +
+ + +
+
+ + +
+
+ + +
+
+ + + + +
+
+ + +
+
+ + + + +
+
+ +
+
+
+ +
+

Register with an existing restaurant account

+
+ +
+ + +
+
+ + +
+
+ + +
+
+ + + + +
+
+ + +
+
+ + + + +
+
+ +
+
+
+
+
+
+
diff --git a/EduWaiterAppClient/src/app/components/register/admin-register/admin-register.component.spec.ts b/EduWaiterAppClient/src/app/components/register/admin-register/admin-register.component.spec.ts new file mode 100644 index 0000000..4dc4804 --- /dev/null +++ b/EduWaiterAppClient/src/app/components/register/admin-register/admin-register.component.spec.ts @@ -0,0 +1,25 @@ +import { async, ComponentFixture, TestBed } from '@angular/core/testing'; + +import { AdminRegisterComponent } from './admin-register.component'; + +describe('AdminRegisterComponent', () => { + let component: AdminRegisterComponent; + let fixture: ComponentFixture; + + beforeEach(async(() => { + TestBed.configureTestingModule({ + declarations: [ AdminRegisterComponent ] + }) + .compileComponents(); + })); + + beforeEach(() => { + fixture = TestBed.createComponent(AdminRegisterComponent); + component = fixture.componentInstance; + fixture.detectChanges(); + }); + + it('should create', () => { + expect(component).toBeTruthy(); + }); +}); diff --git a/EduWaiterAppClient/src/app/components/register/admin-register/admin-register.component.ts b/EduWaiterAppClient/src/app/components/register/admin-register/admin-register.component.ts new file mode 100644 index 0000000..0fea934 --- /dev/null +++ b/EduWaiterAppClient/src/app/components/register/admin-register/admin-register.component.ts @@ -0,0 +1,108 @@ +import {Component, OnInit} from '@angular/core'; +import {FormBuilder, FormGroup} from '@angular/forms'; +import {Router} from "@angular/router"; +import {AccountService} from "../../../services/account.service"; +import {LocalStorageService} from "ngx-webstorage"; +import {RestaurantService} from "../../../services/restaurant.service"; +import {Restaurant} from "../../../models/restaurant"; + +@Component({ + selector: 'app-admin-register', + templateUrl: './admin-register.component.html', + styleUrls: ['./admin-register.component.css'] +}) +export class AdminRegisterComponent implements OnInit { + + newRestaurantRegisterForm: FormGroup; + existingRestaurantRegisterForm: FormGroup; + submitted: boolean; + newRestaurant: boolean; + existingRestaurant: boolean; + + + constructor(private formBuilder: FormBuilder, + private router: Router, + private accountService: AccountService, + private storage: LocalStorageService, + private restaurantService: RestaurantService) { + } + + ngOnInit() { + this.newRestaurantRegisterForm = this.formBuilder.group({ + firstName: '', + lastName: '', + username: '', + password: '', + restaurantName: '', + restaurantPassword: '' + }); + + this.existingRestaurantRegisterForm = this.formBuilder.group({ + firstName2: '', + lastName2: '', + username2: '', + password2: '', + restaurantId: '', + restaurantPassword2: '' + }); + } + + onSubmitNewRestaurant() { + this.submitted = true; + let restaurantJson = + "{" + + "\"name\" : \"" + this.newRestaurantRegisterForm.controls.restaurantName.value + "\"," + + "\"password\" : \"" + this.newRestaurantRegisterForm.controls.restaurantPassword.value + "\"" + + "}"; + this.restaurantService.registerRestaurant(JSON.parse(restaurantJson)).subscribe(restaurant => { + let adminJson = + "{" + + "\"firstName\" : \"" + this.newRestaurantRegisterForm.controls.firstName.value + "\"," + + "\"lastName\" : \"" + this.newRestaurantRegisterForm.controls.lastName.value + "\"," + + "\"username\" : \"" + this.newRestaurantRegisterForm.controls.username.value + "\"," + + "\"password\" : \"" + this.newRestaurantRegisterForm.controls.password.value + "\"," + + "\"restaurant\" : null" + + "}"; + this.accountService.registerAdmin(JSON.parse(adminJson)).subscribe(admin => { + this.restaurantService.addAdmin(restaurant, admin.id).subscribe(restaurant => { + this.storage.store("restaurant", restaurant); + this.storage.store("admin", admin); + }); + }); + }); + this.router.navigate(['/home']); + } + + onSubmitExistingRestaurant() { + this.submitted = true; + let adminJson = + "{" + + "\"firstName\" : \"" + this.existingRestaurantRegisterForm.controls.firstName2.value + "\"," + + "\"lastName\" : \"" + this.existingRestaurantRegisterForm.controls.lastName2.value + "\"," + + "\"username\" : \"" + this.existingRestaurantRegisterForm.controls.username2.value + "\"," + + "\"password\" : \"" + this.existingRestaurantRegisterForm.controls.password2.value + "\"," + + "\"restaurant\" : null" + + "}"; + let restaurantId: number = this.existingRestaurantRegisterForm.controls.restaurantId.value; + this.accountService.registerAdmin(JSON.parse(adminJson)).subscribe(admin => { + this.accountService.adminUpdateRestaurant(restaurantId, admin).subscribe(admin => { + this.restaurantService.findById(admin.restaurant.id).subscribe(restaurant => { + this.storage.store("restaurant", restaurant); + admin.restaurant = restaurant; + this.storage.store("admin", admin); + this.router.navigate(['/home']); + }); + }); + }); + } + + makeNewRestaurant(): void { + this.newRestaurant = true; + this.existingRestaurant = false; + } + + useExistingRestaurant(): void { + this.existingRestaurant = true; + this.newRestaurant = false; + } +} diff --git a/EduWaiterAppClient/src/app/components/register/employee-register/employee-register.component.css b/EduWaiterAppClient/src/app/components/register/employee-register/employee-register.component.css new file mode 100644 index 0000000..e69de29 diff --git a/EduWaiterAppClient/src/app/components/register/employee-register/employee-register.component.html b/EduWaiterAppClient/src/app/components/register/employee-register/employee-register.component.html new file mode 100644 index 0000000..c2f75f2 --- /dev/null +++ b/EduWaiterAppClient/src/app/components/register/employee-register/employee-register.component.html @@ -0,0 +1,51 @@ + +
+ +
+
+

Register as Employee

+
+ +
+ + +
+
+ + +
+
+ + +
+
+ + + + +
+
+ + +
+
+ + + + +
+
+ +
+
+
+
+
+
+ diff --git a/EduWaiterAppClient/src/app/components/register/employee-register/employee-register.component.spec.ts b/EduWaiterAppClient/src/app/components/register/employee-register/employee-register.component.spec.ts new file mode 100644 index 0000000..50b9d66 --- /dev/null +++ b/EduWaiterAppClient/src/app/components/register/employee-register/employee-register.component.spec.ts @@ -0,0 +1,25 @@ +import { async, ComponentFixture, TestBed } from '@angular/core/testing'; + +import { EmployeeRegisterComponent } from './employee-register.component'; + +describe('EmployeeRegisterComponent', () => { + let component: EmployeeRegisterComponent; + let fixture: ComponentFixture; + + beforeEach(async(() => { + TestBed.configureTestingModule({ + declarations: [ EmployeeRegisterComponent ] + }) + .compileComponents(); + })); + + beforeEach(() => { + fixture = TestBed.createComponent(EmployeeRegisterComponent); + component = fixture.componentInstance; + fixture.detectChanges(); + }); + + it('should create', () => { + expect(component).toBeTruthy(); + }); +}); diff --git a/EduWaiterAppClient/src/app/components/register/employee-register/employee-register.component.ts b/EduWaiterAppClient/src/app/components/register/employee-register/employee-register.component.ts new file mode 100644 index 0000000..4e82164 --- /dev/null +++ b/EduWaiterAppClient/src/app/components/register/employee-register/employee-register.component.ts @@ -0,0 +1,60 @@ +import {Component, OnInit} from '@angular/core'; +import {FormBuilder, FormGroup} from "@angular/forms"; +import {Router} from "@angular/router"; +import {AccountService} from "../../../services/account.service"; +import {LocalStorageService} from "ngx-webstorage"; +import {RestaurantService} from "../../../services/restaurant.service"; +import {Restaurant} from "../../../models/restaurant"; + +@Component({ + selector: 'app-employee-register', + templateUrl: './employee-register.component.html', + styleUrls: ['./employee-register.component.css'] +}) +export class EmployeeRegisterComponent implements OnInit { + + registerForm: FormGroup; + submitted: boolean; + + constructor(private formBuilder: FormBuilder, + private router: Router, + private accountService: AccountService, + private storage: LocalStorageService, + private restaurantService: RestaurantService) { + } + + ngOnInit() { + this.registerForm = this.formBuilder.group({ + firstName: '', + lastName: '', + username: '', + password: '', + restaurantId: '', + restaurantPassword: '' + }); + } + + onSubmit() { + this.submitted = true; + let json = + "{" + + "\"firstName\" : \"" + this.registerForm.controls.firstName.value + "\"," + + "\"lastName\" : \"" + this.registerForm.controls.lastName.value + "\"," + + "\"username\" : \"" + this.registerForm.controls.username.value + "\"," + + "\"password\" : \"" + this.registerForm.controls.password.value + "\"," + + "\"restaurant\" : null" + + "}"; + let restaurantId: number = this.registerForm.controls.restaurantId.value; + console.log(restaurantId); + this.accountService.registerEmployee(JSON.parse(json)).subscribe(account => { + this.accountService.employeeUpdateRestaurant(restaurantId, account).subscribe(account => { + this.restaurantService.findById(account.restaurant.id).subscribe(restaurant => { + this.storage.store("restaurant", restaurant); + account.restaurant = restaurant; + this.storage.store("employee", account); + this.router.navigate(['/home']); + }); + }); + }); + } +} diff --git a/EduWaiterAppClient/src/app/components/register/register/register.component.css b/EduWaiterAppClient/src/app/components/register/register/register.component.css new file mode 100644 index 0000000..e69de29 diff --git a/EduWaiterAppClient/src/app/components/register/register/register.component.html b/EduWaiterAppClient/src/app/components/register/register/register.component.html new file mode 100644 index 0000000..d8eac62 --- /dev/null +++ b/EduWaiterAppClient/src/app/components/register/register/register.component.html @@ -0,0 +1,3 @@ +

Register

+Register as an Admin
+Register as an Employee
diff --git a/EduWaiterAppClient/src/app/components/register/register/register.component.spec.ts b/EduWaiterAppClient/src/app/components/register/register/register.component.spec.ts new file mode 100644 index 0000000..6c19551 --- /dev/null +++ b/EduWaiterAppClient/src/app/components/register/register/register.component.spec.ts @@ -0,0 +1,25 @@ +import { async, ComponentFixture, TestBed } from '@angular/core/testing'; + +import { RegisterComponent } from './register.component'; + +describe('RegisterComponent', () => { + let component: RegisterComponent; + let fixture: ComponentFixture; + + beforeEach(async(() => { + TestBed.configureTestingModule({ + declarations: [ RegisterComponent ] + }) + .compileComponents(); + })); + + beforeEach(() => { + fixture = TestBed.createComponent(RegisterComponent); + component = fixture.componentInstance; + fixture.detectChanges(); + }); + + it('should create', () => { + expect(component).toBeTruthy(); + }); +}); diff --git a/EduWaiterAppClient/src/app/components/register/register/register.component.ts b/EduWaiterAppClient/src/app/components/register/register/register.component.ts new file mode 100644 index 0000000..b7db7f8 --- /dev/null +++ b/EduWaiterAppClient/src/app/components/register/register/register.component.ts @@ -0,0 +1,15 @@ +import { Component, OnInit } from '@angular/core'; + +@Component({ + selector: 'app-register', + templateUrl: './register.component.html', + styleUrls: ['./register.component.css'] +}) +export class RegisterComponent implements OnInit { + + constructor() { } + + ngOnInit() { + } + +} diff --git a/EduWaiterAppClient/src/app/components/restaurant/restaurant.component.css b/EduWaiterAppClient/src/app/components/restaurant/restaurant.component.css new file mode 100644 index 0000000..e69de29 diff --git a/EduWaiterAppClient/src/app/components/restaurant/restaurant.component.html b/EduWaiterAppClient/src/app/components/restaurant/restaurant.component.html new file mode 100644 index 0000000..6faf903 --- /dev/null +++ b/EduWaiterAppClient/src/app/components/restaurant/restaurant.component.html @@ -0,0 +1,26 @@ +
+
+

My Restaurant

+

{{currentRestaurant.name}}

+
+ Restaurant ID: {{currentRestaurant.id}} +

+
    Employees: +
  • + {{employee.firstName}} {{employee.lastName}} +
  • +
+
+
    Admins: +
  • + {{admin.firstName}} {{admin.lastName}} +
  • +
+
+
+ +
+
+ +
+
\ No newline at end of file diff --git a/EduWaiterAppClient/src/app/components/restaurant/restaurant.component.spec.ts b/EduWaiterAppClient/src/app/components/restaurant/restaurant.component.spec.ts new file mode 100644 index 0000000..af9d1c3 --- /dev/null +++ b/EduWaiterAppClient/src/app/components/restaurant/restaurant.component.spec.ts @@ -0,0 +1,25 @@ +import { async, ComponentFixture, TestBed } from '@angular/core/testing'; + +import { RestaurantComponent } from './restaurant.component'; + +describe('RestaurantComponent', () => { + let component: RestaurantComponent; + let fixture: ComponentFixture; + + beforeEach(async(() => { + TestBed.configureTestingModule({ + declarations: [ RestaurantComponent ] + }) + .compileComponents(); + })); + + beforeEach(() => { + fixture = TestBed.createComponent(RestaurantComponent); + component = fixture.componentInstance; + fixture.detectChanges(); + }); + + it('should create', () => { + expect(component).toBeTruthy(); + }); +}); diff --git a/EduWaiterAppClient/src/app/components/restaurant/restaurant.component.ts b/EduWaiterAppClient/src/app/components/restaurant/restaurant.component.ts new file mode 100644 index 0000000..db610cd --- /dev/null +++ b/EduWaiterAppClient/src/app/components/restaurant/restaurant.component.ts @@ -0,0 +1,28 @@ +import { Component, OnInit } from '@angular/core'; +import {Restaurant} from "../../models/restaurant"; +import {LocalStorageService} from "ngx-webstorage"; +import {Menu} from "../../models/menu"; + +@Component({ + selector: 'app-restaurant', + templateUrl: './restaurant.component.html', + styleUrls: ['./restaurant.component.css'] +}) +export class RestaurantComponent implements OnInit { + + currentRestaurant: Restaurant; + currentMenu: Menu; + + constructor(private storage: LocalStorageService) { } + + ngOnInit() { + this.currentMenu = null; + this.storage.store("currentMenu", null); + this.currentRestaurant = this.storage.retrieve("restaurant"); + } + + ngDoCheck(){ + this.currentMenu = this.storage.retrieve("currentMenu"); + } + +} diff --git a/EduWaiterAppClient/src/app/models/admin-account.ts b/EduWaiterAppClient/src/app/models/admin-account.ts new file mode 100644 index 0000000..126c65c --- /dev/null +++ b/EduWaiterAppClient/src/app/models/admin-account.ts @@ -0,0 +1,13 @@ +import {Restaurant} from "./restaurant"; + +export class AdminAccount { + + id: number; + firstName: string; + lastName: string; + username: string; + password: string; + restaurant: Restaurant; + + +} diff --git a/EduWaiterAppClient/src/app/models/employee-account.ts b/EduWaiterAppClient/src/app/models/employee-account.ts new file mode 100644 index 0000000..a84f9ed --- /dev/null +++ b/EduWaiterAppClient/src/app/models/employee-account.ts @@ -0,0 +1,13 @@ +import {Restaurant} from "./restaurant"; + +export class EmployeeAccount { + + id: number; + firstName: string; + lastName: string; + username: string; + password: string; + restaurant: Restaurant; + + +} diff --git a/EduWaiterAppClient/src/app/models/fact.ts b/EduWaiterAppClient/src/app/models/fact.ts new file mode 100644 index 0000000..38e8b23 --- /dev/null +++ b/EduWaiterAppClient/src/app/models/fact.ts @@ -0,0 +1 @@ +export class Fact {} diff --git a/EduWaiterAppClient/src/app/models/ingredient.ts b/EduWaiterAppClient/src/app/models/ingredient.ts new file mode 100644 index 0000000..27007a7 --- /dev/null +++ b/EduWaiterAppClient/src/app/models/ingredient.ts @@ -0,0 +1,10 @@ +import {MenuItem} from "./menu-item"; + +export class Ingredient{ + + id: number; + name: string; + allergen: boolean; + menuItems: MenuItem[]; + +} diff --git a/EduWaiterAppClient/src/app/models/menu-item.ts b/EduWaiterAppClient/src/app/models/menu-item.ts new file mode 100644 index 0000000..e261fc2 --- /dev/null +++ b/EduWaiterAppClient/src/app/models/menu-item.ts @@ -0,0 +1,12 @@ +import {Ingredient} from "./ingredient"; +import {Menu} from "./menu"; + +export class MenuItem { + + id: number; + name: string; + description: string; + price: number; + ingredients: Ingredient[]; + menus: Menu[]; +} diff --git a/EduWaiterAppClient/src/app/models/menu.ts b/EduWaiterAppClient/src/app/models/menu.ts new file mode 100644 index 0000000..1963a6a --- /dev/null +++ b/EduWaiterAppClient/src/app/models/menu.ts @@ -0,0 +1,19 @@ +import {MenuItem} from "./menu-item"; +import {Restaurant} from "./restaurant"; + +export class Menu { + + id: number; + name: string; + description: string; + menuItems: MenuItem[]; + restaurant: Restaurant; + + constructor(id, name, description, menuItems, restaurant){ + this.id = id; + this.name = name; + this.description = description; + this.menuItems = menuItems; + this.restaurant = restaurant; + } +} diff --git a/EduWaiterAppClient/src/app/models/restaurant.ts b/EduWaiterAppClient/src/app/models/restaurant.ts new file mode 100644 index 0000000..2edba40 --- /dev/null +++ b/EduWaiterAppClient/src/app/models/restaurant.ts @@ -0,0 +1,17 @@ +import {Menu} from "./menu"; +import {AdminAccount} from "./admin-account"; +import {EmployeeAccount} from "./employee-account"; +import {Fact} from "./fact"; + +export class Restaurant { + + id: number; + name: string; + password: string; + menus: Menu[]; + admin: AdminAccount[]; + employees: EmployeeAccount[]; + facts: Fact[]; + + +} diff --git a/EduWaiterAppClient/src/app/services/account.service.spec.ts b/EduWaiterAppClient/src/app/services/account.service.spec.ts new file mode 100644 index 0000000..6aab80b --- /dev/null +++ b/EduWaiterAppClient/src/app/services/account.service.spec.ts @@ -0,0 +1,12 @@ +import { TestBed } from '@angular/core/testing'; + +import { AccountService } from './account.service'; + +describe('AccountService', () => { + beforeEach(() => TestBed.configureTestingModule({})); + + it('should be created', () => { + const service: AccountService = TestBed.get(AccountService); + expect(service).toBeTruthy(); + }); +}); diff --git a/EduWaiterAppClient/src/app/services/account.service.ts b/EduWaiterAppClient/src/app/services/account.service.ts new file mode 100644 index 0000000..cea0db7 --- /dev/null +++ b/EduWaiterAppClient/src/app/services/account.service.ts @@ -0,0 +1,110 @@ +import {Injectable} from '@angular/core'; +import {HttpClient, HttpHeaders} from "@angular/common/http"; +import {AdminAccount} from "../models/admin-account"; +import {Observable} from "rxjs"; +import {map} from 'rxjs/operators'; +import {EmployeeAccount} from "../models/employee-account"; +import {LocalStorageService} from "ngx-webstorage"; + +const httpOptions = { + headers: new HttpHeaders({'Content-Type': 'application/json'}) +}; + +@Injectable({ + providedIn: 'root' +}) + +export class AccountService { + + private url = "/api/accounts"; + + constructor(private http: HttpClient, + private storage: LocalStorageService) { + } + + registerAdmin(adminAccount: AdminAccount): Observable { + return this.http.post(`${this.url}/admin`, adminAccount, httpOptions); + } + + registerEmployee(employeeAccount: EmployeeAccount): Observable { + return this.http.post(`${this.url}/employees`, employeeAccount, httpOptions); + } + + findAdminByUsername(username: string): Observable { + return this.http.get(`${this.url}/admin/username/${username}`); + } + + findEmployeeByUsername(username: string): Observable{ + return this.http.get(`${this.url}/employees/username/${username}`) + } + + loginAdmin(username: string, password: string) { + this.storage.store("employee", null); + return this.findAdminByUsername(username).pipe( + map(admin => { + this.storage.store("admin", admin); + if (admin == null) { + return "Invalid Username!"; + } + return admin; + }), + map(admin => { + if (admin != "Invalid Username!") { + if ((admin as AdminAccount).password !== password) { + return "Invalid Password!"; + } + } + return admin; + }), + map(admin => { + if ((admin != "Invalid Username!") && (admin != "Invalid Password!")) { + return this.storage.retrieve("admin"); + } + return admin; + }) + ); + } + + loginEmployee(username: string, password: string) { + this.storage.store("admin", null); + return this.findEmployeeByUsername(username).pipe( + map(employee => { + this.storage.store("employee", employee); + if (employee == null) { + return "Invalid Username!"; + } + return employee; + }), + map(employee => { + if (employee != "Invalid Username!") { + if ((employee as EmployeeAccount).password !== password) { + return "Invalid Password!"; + } + } + return employee; + }), + map(employee => { + if ((employee != "Invalid Username!") && (employee != "Invalid Password!")) { + return this.storage.retrieve("employee"); + } + return employee; + }) + ) + } + + logout() { + this.storage.store("admin", null); + this.storage.store("employee", null); + this.storage.store("restaurant", null); + } + + employeeUpdateRestaurant(restaurantId: number, account: EmployeeAccount): Observable { + return this.http.put(`${this.url}/employees/${account.id}/updateRestaurant?restaurantId=${restaurantId}`, account, httpOptions); + } + + + adminUpdateRestaurant(restaurantId: number, account: AdminAccount): Observable { + return this.http.put(`${this.url}/admin/${account.id}/updateRestaurant?restaurantId=${restaurantId}`, account, httpOptions); + } + +} diff --git a/EduWaiterAppClient/src/app/services/menu.service.spec.ts b/EduWaiterAppClient/src/app/services/menu.service.spec.ts new file mode 100644 index 0000000..d23b03b --- /dev/null +++ b/EduWaiterAppClient/src/app/services/menu.service.spec.ts @@ -0,0 +1,12 @@ +import { TestBed } from '@angular/core/testing'; + +import { MenuService } from './menu.service'; + +describe('MenuService', () => { + beforeEach(() => TestBed.configureTestingModule({})); + + it('should be created', () => { + const service: MenuService = TestBed.get(MenuService); + expect(service).toBeTruthy(); + }); +}); diff --git a/EduWaiterAppClient/src/app/services/menu.service.ts b/EduWaiterAppClient/src/app/services/menu.service.ts new file mode 100644 index 0000000..a7fb8be --- /dev/null +++ b/EduWaiterAppClient/src/app/services/menu.service.ts @@ -0,0 +1,35 @@ +import {Injectable} from '@angular/core'; +import {HttpClient, HttpHeaders} from "@angular/common/http"; +import {Menu} from "../models/menu"; +import {Observable} from "rxjs"; + + + +const httpOptions = { + headers: new HttpHeaders({'Content-Type': 'application/json'}) +}; + +@Injectable({ + providedIn: 'root' +}) + + +export class MenuService { + + url: string = "/api/menus" + + constructor(private http: HttpClient) { + } + + createMenu(menu: Menu): Observable { + return this.http.post(this.url, menu, httpOptions); + } + + updateDescription(menu: Menu, description: string): Observable { + return this.http.put(`${this.url}/updateDescription/${description}`, menu, httpOptions); + } + + updateRestaurant(menu: Menu, restaurantId: number): Observable { + return this.http.put(`${this.url}/updateRestaurant/${restaurantId}`, menu, httpOptions); + } +} diff --git a/EduWaiterAppClient/src/app/services/restaurant.service.spec.ts b/EduWaiterAppClient/src/app/services/restaurant.service.spec.ts new file mode 100644 index 0000000..376b27c --- /dev/null +++ b/EduWaiterAppClient/src/app/services/restaurant.service.spec.ts @@ -0,0 +1,12 @@ +import { TestBed } from '@angular/core/testing'; + +import { RestaurantService } from './restaurant.service'; + +describe('RestaurantService', () => { + beforeEach(() => TestBed.configureTestingModule({})); + + it('should be created', () => { + const service: RestaurantService = TestBed.get(RestaurantService); + expect(service).toBeTruthy(); + }); +}); diff --git a/EduWaiterAppClient/src/app/services/restaurant.service.ts b/EduWaiterAppClient/src/app/services/restaurant.service.ts new file mode 100644 index 0000000..9ad035e --- /dev/null +++ b/EduWaiterAppClient/src/app/services/restaurant.service.ts @@ -0,0 +1,68 @@ +import { Injectable } from '@angular/core'; +import {HttpClient, HttpHeaders} from "@angular/common/http"; +import {Observable} from "rxjs"; +import {Restaurant} from "../models/restaurant"; +import {map} from "rxjs/operators"; +import {LocalStorageService} from "ngx-webstorage"; + +const httpOptions = { + headers: new HttpHeaders({'Content-Type': 'application/json'}) +}; + + +@Injectable({ + providedIn: 'root' +}) +export class RestaurantService { + + private url = "/api/restaurants" + + constructor(private http: HttpClient, + private storage: LocalStorageService) { } + + registerRestaurant(restaurant: Restaurant): Observable { + return this.http.post(this.url, restaurant, httpOptions); + } + + findById(id: number): Observable { + return this.http.get(`${this.url}/${id}`); + } + + loginRestaurant(id: number, password: string): any { + return this.findById(id).pipe( + map(restaurant => { + this.storage.store("restaurant", restaurant); + if(restaurant == null){ + return "Invalid Restaurant Id!"; + } + return restaurant; + }), + map(restaurant => { + if(restaurant != "Invalid Restaurant Id!"){ + if((restaurant as Restaurant).password !== password){ + return "Invalid Password!"; + } + } + return restaurant; + }), + map(restaurant => { + if((restaurant != "Invalid Restaurant Id!") && (restaurant != "Invalid Password!")){ + return this.storage.retrieve("restaurant"); + } + return restaurant; + }) + ); + } + + addAdmin(restaurant: Restaurant, adminId: number): Observable { + return this.http.put(`${this.url}/addAdmin/${adminId}`, restaurant, httpOptions); + } + + addEmployee(restaurant: Restaurant, employeeId: number): Observable { + return this.http.put(`${this.url}/addEmployee/${employeeId}`, restaurant, httpOptions); + } + + addMenu(restaurant: Restaurant, menuId: number): Observable { + return this.http.put(`${this.url}/addMenu/${menuId}`, restaurant, httpOptions); + } +} diff --git a/EduWaiterAppClient/src/assets/.gitkeep b/EduWaiterAppClient/src/assets/.gitkeep new file mode 100644 index 0000000..e69de29 diff --git a/EduWaiterAppClient/src/browserslist b/EduWaiterAppClient/src/browserslist new file mode 100644 index 0000000..37371cb --- /dev/null +++ b/EduWaiterAppClient/src/browserslist @@ -0,0 +1,11 @@ +# This file is currently used by autoprefixer to adjust CSS to support the below specified browsers +# For additional information regarding the format and rule options, please see: +# https://github.com/browserslist/browserslist#queries +# +# For IE 9-11 support, please remove 'not' from the last line of the file and adjust as needed + +> 0.5% +last 2 versions +Firefox ESR +not dead +not IE 9-11 \ No newline at end of file diff --git a/EduWaiterAppClient/src/environments/environment.prod.ts b/EduWaiterAppClient/src/environments/environment.prod.ts new file mode 100644 index 0000000..3612073 --- /dev/null +++ b/EduWaiterAppClient/src/environments/environment.prod.ts @@ -0,0 +1,3 @@ +export const environment = { + production: true +}; diff --git a/EduWaiterAppClient/src/environments/environment.ts b/EduWaiterAppClient/src/environments/environment.ts new file mode 100644 index 0000000..7b4f817 --- /dev/null +++ b/EduWaiterAppClient/src/environments/environment.ts @@ -0,0 +1,16 @@ +// This file can be replaced during build by using the `fileReplacements` array. +// `ng build --prod` replaces `environment.ts` with `environment.prod.ts`. +// The list of file replacements can be found in `angular.json`. + +export const environment = { + production: false +}; + +/* + * For easier debugging in development mode, you can import the following file + * to ignore zone related error stack frames such as `zone.run`, `zoneDelegate.invokeTask`. + * + * This import should be commented out in production mode because it will have a negative impact + * on performance if an error is thrown. + */ +// import 'zone.js/dist/zone-error'; // Included with Angular CLI. diff --git a/EduWaiterAppClient/src/favicon.ico b/EduWaiterAppClient/src/favicon.ico new file mode 100644 index 0000000..8081c7c Binary files /dev/null and b/EduWaiterAppClient/src/favicon.ico differ diff --git a/EduWaiterAppClient/src/index.html b/EduWaiterAppClient/src/index.html new file mode 100644 index 0000000..97db031 --- /dev/null +++ b/EduWaiterAppClient/src/index.html @@ -0,0 +1,14 @@ + + + + + EduWaiterAppClient + + + + + + + + + diff --git a/EduWaiterAppClient/src/karma.conf.js b/EduWaiterAppClient/src/karma.conf.js new file mode 100644 index 0000000..cc156fb --- /dev/null +++ b/EduWaiterAppClient/src/karma.conf.js @@ -0,0 +1,32 @@ +// Karma configuration file, see link for more information +// https://karma-runner.github.io/1.0/config/configuration-file.html + +module.exports = function (config) { + config.set({ + basePath: '', + frameworks: ['jasmine', '@angular-devkit/build-angular'], + plugins: [ + require('karma-jasmine'), + require('karma-chrome-launcher'), + require('karma-jasmine-html-reporter'), + require('karma-coverage-istanbul-reporter'), + require('@angular-devkit/build-angular/plugins/karma') + ], + client: { + clearContext: false // leave Jasmine Spec Runner output visible in browser + }, + coverageIstanbulReporter: { + dir: require('path').join(__dirname, '../coverage/EduWaiterAppClient'), + reports: ['html', 'lcovonly', 'text-summary'], + fixWebpackSourcePaths: true + }, + reporters: ['progress', 'kjhtml'], + port: 9876, + colors: true, + logLevel: config.LOG_INFO, + autoWatch: true, + browsers: ['Chrome'], + singleRun: false, + restartOnFileChange: true + }); +}; diff --git a/EduWaiterAppClient/src/main.ts b/EduWaiterAppClient/src/main.ts new file mode 100644 index 0000000..c7b673c --- /dev/null +++ b/EduWaiterAppClient/src/main.ts @@ -0,0 +1,12 @@ +import { enableProdMode } from '@angular/core'; +import { platformBrowserDynamic } from '@angular/platform-browser-dynamic'; + +import { AppModule } from './app/app.module'; +import { environment } from './environments/environment'; + +if (environment.production) { + enableProdMode(); +} + +platformBrowserDynamic().bootstrapModule(AppModule) + .catch(err => console.error(err)); diff --git a/EduWaiterAppClient/src/polyfills.ts b/EduWaiterAppClient/src/polyfills.ts new file mode 100644 index 0000000..75d6393 --- /dev/null +++ b/EduWaiterAppClient/src/polyfills.ts @@ -0,0 +1,63 @@ +/** + * This file includes polyfills needed by Angular and is loaded before the app. + * You can add your own extra polyfills to this file. + * + * This file is divided into 2 sections: + * 1. Browser polyfills. These are applied before loading ZoneJS and are sorted by browsers. + * 2. Application imports. Files imported after ZoneJS that should be loaded before your main + * file. + * + * The current setup is for so-called "evergreen" browsers; the last versions of browsers that + * automatically update themselves. This includes Safari >= 10, Chrome >= 55 (including Opera), + * Edge >= 13 on the desktop, and iOS 10 and Chrome on mobile. + * + * Learn more in https://angular.io/guide/browser-support + */ + +/*************************************************************************************************** + * BROWSER POLYFILLS + */ + +/** IE10 and IE11 requires the following for NgClass support on SVG elements */ +// import 'classlist.js'; // Run `npm install --save classlist.js`. + +/** + * Web Animations `@angular/platform-browser/animations` + * Only required if AnimationBuilder is used within the application and using IE/Edge or Safari. + * Standard animation support in Angular DOES NOT require any polyfills (as of Angular 6.0). + */ +// import 'web-animations-js'; // Run `npm install --save web-animations-js`. + +/** + * By default, zone.js will patch all possible macroTask and DomEvents + * user can disable parts of macroTask/DomEvents patch by setting following flags + * because those flags need to be set before `zone.js` being loaded, and webpack + * will put import in the top of bundle, so user need to create a separate file + * in this directory (for example: zone-flags.ts), and put the following flags + * into that file, and then add the following code before importing zone.js. + * import './zone-flags.ts'; + * + * The flags allowed in zone-flags.ts are listed here. + * + * The following flags will work for all browsers. + * + * (window as any).__Zone_disable_requestAnimationFrame = true; // disable patch requestAnimationFrame + * (window as any).__Zone_disable_on_property = true; // disable patch onProperty such as onclick + * (window as any).__zone_symbol__BLACK_LISTED_EVENTS = ['scroll', 'mousemove']; // disable patch specified eventNames + * + * in IE/Edge developer tools, the addEventListener will also be wrapped by zone.js + * with the following flag, it will bypass `zone.js` patch for IE/Edge + * + * (window as any).__Zone_enable_cross_context_check = true; + * + */ + +/*************************************************************************************************** + * Zone JS is required by default for Angular itself. + */ +import 'zone.js/dist/zone'; // Included with Angular CLI. + + +/*************************************************************************************************** + * APPLICATION IMPORTS + */ diff --git a/EduWaiterAppClient/src/styles.css b/EduWaiterAppClient/src/styles.css new file mode 100644 index 0000000..97928c5 --- /dev/null +++ b/EduWaiterAppClient/src/styles.css @@ -0,0 +1,12 @@ +/*! + * Bootswatch v4.3.1 + * Homepage: https://bootswatch.com + * Copyright 2012-2019 Thomas Park + * Licensed under MIT + * Based on Bootstrap +*//*! + * Bootstrap v4.3.1 (https://getbootstrap.com/) + * Copyright 2011-2019 The Bootstrap Authors + * Copyright 2011-2019 Twitter, Inc. + * Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE) + */@import url("https://fonts.googleapis.com/css?family=Source+Sans+Pro");:root{--blue: #B58900;--indigo: #6610f2;--purple: #6f42c1;--pink: #e83e8c;--red: #D33682;--orange: #fd7e14;--yellow: #CB4B16;--green: #2AA198;--teal: #20c997;--cyan: #268BD2;--white: #fff;--gray: #839496;--gray-dark: #073642;--primary: #B58900;--secondary: #839496;--success: #2AA198;--info: #268BD2;--warning: #CB4B16;--danger: #D33682;--light: #FDF6E3;--dark: #073642;--breakpoint-xs: 0;--breakpoint-sm: 576px;--breakpoint-md: 768px;--breakpoint-lg: 992px;--breakpoint-xl: 1200px;--font-family-sans-serif: "Source Sans Pro", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol";--font-family-monospace: SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace}*,*::before,*::after{-webkit-box-sizing:border-box;box-sizing:border-box}html{font-family:sans-serif;line-height:1.15;-webkit-text-size-adjust:100%;-webkit-tap-highlight-color:rgba(0,0,0,0)}article,aside,figcaption,figure,footer,header,hgroup,main,nav,section{display:block}body{margin:0;font-family:"Source Sans Pro", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol";font-size:1rem;font-weight:400;line-height:1.5;color:#839496;text-align:left;background-color:#002B36}[tabindex="-1"]:focus{outline:0 !important}hr{-webkit-box-sizing:content-box;box-sizing:content-box;height:0;overflow:visible}h1,h2,h3,h4,h5,h6{margin-top:0;margin-bottom:0.5rem}p{margin-top:0;margin-bottom:1rem}abbr[title],abbr[data-original-title]{text-decoration:underline;-webkit-text-decoration:underline dotted;text-decoration:underline dotted;cursor:help;border-bottom:0;text-decoration-skip-ink:none}address{margin-bottom:1rem;font-style:normal;line-height:inherit}ol,ul,dl{margin-top:0;margin-bottom:1rem}ol ol,ul ul,ol ul,ul ol{margin-bottom:0}dt{font-weight:700}dd{margin-bottom:.5rem;margin-left:0}blockquote{margin:0 0 1rem}b,strong{font-weight:bolder}small{font-size:80%}sub,sup{position:relative;font-size:75%;line-height:0;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}a{color:#2AA198;text-decoration:none;background-color:transparent}a:hover{color:#2AA198;text-decoration:underline}a:not([href]):not([tabindex]){color:inherit;text-decoration:none}a:not([href]):not([tabindex]):hover,a:not([href]):not([tabindex]):focus{color:inherit;text-decoration:none}a:not([href]):not([tabindex]):focus{outline:0}pre,code,kbd,samp{font-family:SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;font-size:1em}pre{margin-top:0;margin-bottom:1rem;overflow:auto}figure{margin:0 0 1rem}img{vertical-align:middle;border-style:none}svg{overflow:hidden;vertical-align:middle}table{border-collapse:collapse}caption{padding-top:0.75rem;padding-bottom:0.75rem;color:#839496;text-align:left;caption-side:bottom}th{text-align:inherit}label{display:inline-block;margin-bottom:0.5rem}button{border-radius:0}button:focus{outline:1px dotted;outline:5px auto -webkit-focus-ring-color}input,button,select,optgroup,textarea{margin:0;font-family:inherit;font-size:inherit;line-height:inherit}button,input{overflow:visible}button,select{text-transform:none}select{word-wrap:normal}button,[type="button"],[type="reset"],[type="submit"]{-webkit-appearance:button}button:not(:disabled),[type="button"]:not(:disabled),[type="reset"]:not(:disabled),[type="submit"]:not(:disabled){cursor:pointer}button::-moz-focus-inner,[type="button"]::-moz-focus-inner,[type="reset"]::-moz-focus-inner,[type="submit"]::-moz-focus-inner{padding:0;border-style:none}input[type="radio"],input[type="checkbox"]{-webkit-box-sizing:border-box;box-sizing:border-box;padding:0}input[type="date"],input[type="time"],input[type="datetime-local"],input[type="month"]{-webkit-appearance:listbox}textarea{overflow:auto;resize:vertical}fieldset{min-width:0;padding:0;margin:0;border:0}legend{display:block;width:100%;max-width:100%;padding:0;margin-bottom:.5rem;font-size:1.5rem;line-height:inherit;color:inherit;white-space:normal}progress{vertical-align:baseline}[type="number"]::-webkit-inner-spin-button,[type="number"]::-webkit-outer-spin-button{height:auto}[type="search"]{outline-offset:-2px;-webkit-appearance:none}[type="search"]::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{font:inherit;-webkit-appearance:button}output{display:inline-block}summary{display:list-item;cursor:pointer}template{display:none}[hidden]{display:none !important}h1,h2,h3,h4,h5,h6,.h1,.h2,.h3,.h4,.h5,.h6{margin-bottom:0.5rem;font-weight:500;line-height:1.2; text-align: center}h1,.h1{font-size:2.5rem}h2,.h2{font-size:2rem}h3,.h3{font-size:1.75rem}h4,.h4{font-size:1.5rem}h5,.h5{font-size:1.25rem}h6,.h6{font-size:1rem}.lead{font-size:1.25rem;font-weight:300}.display-1{font-size:6rem;font-weight:300;line-height:1.2}.display-2{font-size:5.5rem;font-weight:300;line-height:1.2}.display-3{font-size:4.5rem;font-weight:300;line-height:1.2}.display-4{font-size:3.5rem;font-weight:300;line-height:1.2}hr{margin-top:1rem;margin-bottom:1rem;border:0;border-top:1px solid rgba(0,0,0,0.1)}small,.small{font-size:80%;font-weight:400}mark,.mark{padding:0.2em;background-color:#fcf8e3}.list-unstyled{padding-left:0;list-style:none}.list-inline{padding-left:0;list-style:none}.list-inline-item{display:inline-block}.list-inline-item:not(:last-child){margin-right:0.5rem}.initialism{font-size:90%;text-transform:uppercase}.blockquote{margin-bottom:1rem;font-size:1.25rem}.blockquote-footer{display:block;font-size:80%;color:#839496}.blockquote-footer::before{content:"\2014\00A0"}.img-fluid{max-width:100%;height:auto}.img-thumbnail{padding:0.25rem;background-color:#002B36;border:1px solid #dee2e6;border-radius:0.25rem;max-width:100%;height:auto}.figure{display:inline-block}.figure-img{margin-bottom:0.5rem;line-height:1}.figure-caption{font-size:90%;color:#839496}code{font-size:87.5%;color:#e83e8c;word-break:break-word}a>code{color:inherit}kbd{padding:0.2rem 0.4rem;font-size:87.5%;color:#fff;background-color:#002B36;border-radius:0.2rem}kbd kbd{padding:0;font-size:100%;font-weight:700}pre{display:block;font-size:87.5%;color:inherit}pre code{font-size:inherit;color:inherit;word-break:normal}.pre-scrollable{max-height:340px;overflow-y:scroll}.container{width:100%;padding-right:15px;padding-left:15px;margin-right:auto;margin-left:auto}@media (min-width: 576px){.container{max-width:540px}}@media (min-width: 768px){.container{max-width:720px}}@media (min-width: 992px){.container{max-width:960px}}@media (min-width: 1200px){.container{max-width:1140px}}.container-fluid{width:100%;padding-right:15px;padding-left:15px;margin-right:auto;margin-left:auto}.row{display:-webkit-box;display:-ms-flexbox;display:flex;-ms-flex-wrap:wrap;flex-wrap:wrap;margin-right:-15px;margin-left:-15px}.no-gutters{margin-right:0;margin-left:0}.no-gutters>.col,.no-gutters>[class*="col-"]{padding-right:0;padding-left:0}.col-1,.col-2,.col-3,.col-4,.col-5,.col-6,.col-7,.col-8,.col-9,.col-10,.col-11,.col-12,.col,.col-auto,.col-sm-1,.col-sm-2,.col-sm-3,.col-sm-4,.col-sm-5,.col-sm-6,.col-sm-7,.col-sm-8,.col-sm-9,.col-sm-10,.col-sm-11,.col-sm-12,.col-sm,.col-sm-auto,.col-md-1,.col-md-2,.col-md-3,.col-md-4,.col-md-5,.col-md-6,.col-md-7,.col-md-8,.col-md-9,.col-md-10,.col-md-11,.col-md-12,.col-md,.col-md-auto,.col-lg-1,.col-lg-2,.col-lg-3,.col-lg-4,.col-lg-5,.col-lg-6,.col-lg-7,.col-lg-8,.col-lg-9,.col-lg-10,.col-lg-11,.col-lg-12,.col-lg,.col-lg-auto,.col-xl-1,.col-xl-2,.col-xl-3,.col-xl-4,.col-xl-5,.col-xl-6,.col-xl-7,.col-xl-8,.col-xl-9,.col-xl-10,.col-xl-11,.col-xl-12,.col-xl,.col-xl-auto{position:relative;width:100%;padding-right:15px;padding-left:15px}.col{-ms-flex-preferred-size:0;flex-basis:0;-webkit-box-flex:1;-ms-flex-positive:1;flex-grow:1;max-width:100%}.col-auto{-webkit-box-flex:0;-ms-flex:0 0 auto;flex:0 0 auto;width:auto;max-width:100%}.col-1{-webkit-box-flex:0;-ms-flex:0 0 8.3333333333%;flex:0 0 8.3333333333%;max-width:8.3333333333%}.col-2{-webkit-box-flex:0;-ms-flex:0 0 16.6666666667%;flex:0 0 16.6666666667%;max-width:16.6666666667%}.col-3{-webkit-box-flex:0;-ms-flex:0 0 25%;flex:0 0 25%;max-width:25%}.col-4{-webkit-box-flex:0;-ms-flex:0 0 33.3333333333%;flex:0 0 33.3333333333%;max-width:33.3333333333%}.col-5{-webkit-box-flex:0;-ms-flex:0 0 41.6666666667%;flex:0 0 41.6666666667%;max-width:41.6666666667%}.col-6{-webkit-box-flex:0;-ms-flex:0 0 50%;flex:0 0 50%;max-width:50%}.col-7{-webkit-box-flex:0;-ms-flex:0 0 58.3333333333%;flex:0 0 58.3333333333%;max-width:58.3333333333%}.col-8{-webkit-box-flex:0;-ms-flex:0 0 66.6666666667%;flex:0 0 66.6666666667%;max-width:66.6666666667%}.col-9{-webkit-box-flex:0;-ms-flex:0 0 75%;flex:0 0 75%;max-width:75%}.col-10{-webkit-box-flex:0;-ms-flex:0 0 83.3333333333%;flex:0 0 83.3333333333%;max-width:83.3333333333%}.col-11{-webkit-box-flex:0;-ms-flex:0 0 91.6666666667%;flex:0 0 91.6666666667%;max-width:91.6666666667%}.col-12{-webkit-box-flex:0;-ms-flex:0 0 100%;flex:0 0 100%;max-width:100%}.order-first{-webkit-box-ordinal-group:0;-ms-flex-order:-1;order:-1}.order-last{-webkit-box-ordinal-group:14;-ms-flex-order:13;order:13}.order-0{-webkit-box-ordinal-group:1;-ms-flex-order:0;order:0}.order-1{-webkit-box-ordinal-group:2;-ms-flex-order:1;order:1}.order-2{-webkit-box-ordinal-group:3;-ms-flex-order:2;order:2}.order-3{-webkit-box-ordinal-group:4;-ms-flex-order:3;order:3}.order-4{-webkit-box-ordinal-group:5;-ms-flex-order:4;order:4}.order-5{-webkit-box-ordinal-group:6;-ms-flex-order:5;order:5}.order-6{-webkit-box-ordinal-group:7;-ms-flex-order:6;order:6}.order-7{-webkit-box-ordinal-group:8;-ms-flex-order:7;order:7}.order-8{-webkit-box-ordinal-group:9;-ms-flex-order:8;order:8}.order-9{-webkit-box-ordinal-group:10;-ms-flex-order:9;order:9}.order-10{-webkit-box-ordinal-group:11;-ms-flex-order:10;order:10}.order-11{-webkit-box-ordinal-group:12;-ms-flex-order:11;order:11}.order-12{-webkit-box-ordinal-group:13;-ms-flex-order:12;order:12}.offset-1{margin-left:8.3333333333%}.offset-2{margin-left:16.6666666667%}.offset-3{margin-left:25%}.offset-4{margin-left:33.3333333333%}.offset-5{margin-left:41.6666666667%}.offset-6{margin-left:50%}.offset-7{margin-left:58.3333333333%}.offset-8{margin-left:66.6666666667%}.offset-9{margin-left:75%}.offset-10{margin-left:83.3333333333%}.offset-11{margin-left:91.6666666667%}@media (min-width: 576px){.col-sm{-ms-flex-preferred-size:0;flex-basis:0;-webkit-box-flex:1;-ms-flex-positive:1;flex-grow:1;max-width:100%}.col-sm-auto{-webkit-box-flex:0;-ms-flex:0 0 auto;flex:0 0 auto;width:auto;max-width:100%}.col-sm-1{-webkit-box-flex:0;-ms-flex:0 0 8.3333333333%;flex:0 0 8.3333333333%;max-width:8.3333333333%}.col-sm-2{-webkit-box-flex:0;-ms-flex:0 0 16.6666666667%;flex:0 0 16.6666666667%;max-width:16.6666666667%}.col-sm-3{-webkit-box-flex:0;-ms-flex:0 0 25%;flex:0 0 25%;max-width:25%}.col-sm-4{-webkit-box-flex:0;-ms-flex:0 0 33.3333333333%;flex:0 0 33.3333333333%;max-width:33.3333333333%}.col-sm-5{-webkit-box-flex:0;-ms-flex:0 0 41.6666666667%;flex:0 0 41.6666666667%;max-width:41.6666666667%}.col-sm-6{-webkit-box-flex:0;-ms-flex:0 0 50%;flex:0 0 50%;max-width:50%}.col-sm-7{-webkit-box-flex:0;-ms-flex:0 0 58.3333333333%;flex:0 0 58.3333333333%;max-width:58.3333333333%}.col-sm-8{-webkit-box-flex:0;-ms-flex:0 0 66.6666666667%;flex:0 0 66.6666666667%;max-width:66.6666666667%}.col-sm-9{-webkit-box-flex:0;-ms-flex:0 0 75%;flex:0 0 75%;max-width:75%}.col-sm-10{-webkit-box-flex:0;-ms-flex:0 0 83.3333333333%;flex:0 0 83.3333333333%;max-width:83.3333333333%}.col-sm-11{-webkit-box-flex:0;-ms-flex:0 0 91.6666666667%;flex:0 0 91.6666666667%;max-width:91.6666666667%}.col-sm-12{-webkit-box-flex:0;-ms-flex:0 0 100%;flex:0 0 100%;max-width:100%}.order-sm-first{-webkit-box-ordinal-group:0;-ms-flex-order:-1;order:-1}.order-sm-last{-webkit-box-ordinal-group:14;-ms-flex-order:13;order:13}.order-sm-0{-webkit-box-ordinal-group:1;-ms-flex-order:0;order:0}.order-sm-1{-webkit-box-ordinal-group:2;-ms-flex-order:1;order:1}.order-sm-2{-webkit-box-ordinal-group:3;-ms-flex-order:2;order:2}.order-sm-3{-webkit-box-ordinal-group:4;-ms-flex-order:3;order:3}.order-sm-4{-webkit-box-ordinal-group:5;-ms-flex-order:4;order:4}.order-sm-5{-webkit-box-ordinal-group:6;-ms-flex-order:5;order:5}.order-sm-6{-webkit-box-ordinal-group:7;-ms-flex-order:6;order:6}.order-sm-7{-webkit-box-ordinal-group:8;-ms-flex-order:7;order:7}.order-sm-8{-webkit-box-ordinal-group:9;-ms-flex-order:8;order:8}.order-sm-9{-webkit-box-ordinal-group:10;-ms-flex-order:9;order:9}.order-sm-10{-webkit-box-ordinal-group:11;-ms-flex-order:10;order:10}.order-sm-11{-webkit-box-ordinal-group:12;-ms-flex-order:11;order:11}.order-sm-12{-webkit-box-ordinal-group:13;-ms-flex-order:12;order:12}.offset-sm-0{margin-left:0}.offset-sm-1{margin-left:8.3333333333%}.offset-sm-2{margin-left:16.6666666667%}.offset-sm-3{margin-left:25%}.offset-sm-4{margin-left:33.3333333333%}.offset-sm-5{margin-left:41.6666666667%}.offset-sm-6{margin-left:50%}.offset-sm-7{margin-left:58.3333333333%}.offset-sm-8{margin-left:66.6666666667%}.offset-sm-9{margin-left:75%}.offset-sm-10{margin-left:83.3333333333%}.offset-sm-11{margin-left:91.6666666667%}}@media (min-width: 768px){.col-md{-ms-flex-preferred-size:0;flex-basis:0;-webkit-box-flex:1;-ms-flex-positive:1;flex-grow:1;max-width:100%}.col-md-auto{-webkit-box-flex:0;-ms-flex:0 0 auto;flex:0 0 auto;width:auto;max-width:100%}.col-md-1{-webkit-box-flex:0;-ms-flex:0 0 8.3333333333%;flex:0 0 8.3333333333%;max-width:8.3333333333%}.col-md-2{-webkit-box-flex:0;-ms-flex:0 0 16.6666666667%;flex:0 0 16.6666666667%;max-width:16.6666666667%}.col-md-3{-webkit-box-flex:0;-ms-flex:0 0 25%;flex:0 0 25%;max-width:25%}.col-md-4{-webkit-box-flex:0;-ms-flex:0 0 33.3333333333%;flex:0 0 33.3333333333%;max-width:33.3333333333%}.col-md-5{-webkit-box-flex:0;-ms-flex:0 0 41.6666666667%;flex:0 0 41.6666666667%;max-width:41.6666666667%}.col-md-6{-webkit-box-flex:0;-ms-flex:0 0 50%;flex:0 0 50%;max-width:50%}.col-md-7{-webkit-box-flex:0;-ms-flex:0 0 58.3333333333%;flex:0 0 58.3333333333%;max-width:58.3333333333%}.col-md-8{-webkit-box-flex:0;-ms-flex:0 0 66.6666666667%;flex:0 0 66.6666666667%;max-width:66.6666666667%}.col-md-9{-webkit-box-flex:0;-ms-flex:0 0 75%;flex:0 0 75%;max-width:75%}.col-md-10{-webkit-box-flex:0;-ms-flex:0 0 83.3333333333%;flex:0 0 83.3333333333%;max-width:83.3333333333%}.col-md-11{-webkit-box-flex:0;-ms-flex:0 0 91.6666666667%;flex:0 0 91.6666666667%;max-width:91.6666666667%}.col-md-12{-webkit-box-flex:0;-ms-flex:0 0 100%;flex:0 0 100%;max-width:100%}.order-md-first{-webkit-box-ordinal-group:0;-ms-flex-order:-1;order:-1}.order-md-last{-webkit-box-ordinal-group:14;-ms-flex-order:13;order:13}.order-md-0{-webkit-box-ordinal-group:1;-ms-flex-order:0;order:0}.order-md-1{-webkit-box-ordinal-group:2;-ms-flex-order:1;order:1}.order-md-2{-webkit-box-ordinal-group:3;-ms-flex-order:2;order:2}.order-md-3{-webkit-box-ordinal-group:4;-ms-flex-order:3;order:3}.order-md-4{-webkit-box-ordinal-group:5;-ms-flex-order:4;order:4}.order-md-5{-webkit-box-ordinal-group:6;-ms-flex-order:5;order:5}.order-md-6{-webkit-box-ordinal-group:7;-ms-flex-order:6;order:6}.order-md-7{-webkit-box-ordinal-group:8;-ms-flex-order:7;order:7}.order-md-8{-webkit-box-ordinal-group:9;-ms-flex-order:8;order:8}.order-md-9{-webkit-box-ordinal-group:10;-ms-flex-order:9;order:9}.order-md-10{-webkit-box-ordinal-group:11;-ms-flex-order:10;order:10}.order-md-11{-webkit-box-ordinal-group:12;-ms-flex-order:11;order:11}.order-md-12{-webkit-box-ordinal-group:13;-ms-flex-order:12;order:12}.offset-md-0{margin-left:0}.offset-md-1{margin-left:8.3333333333%}.offset-md-2{margin-left:16.6666666667%}.offset-md-3{margin-left:25%}.offset-md-4{margin-left:33.3333333333%}.offset-md-5{margin-left:41.6666666667%}.offset-md-6{margin-left:50%}.offset-md-7{margin-left:58.3333333333%}.offset-md-8{margin-left:66.6666666667%}.offset-md-9{margin-left:75%}.offset-md-10{margin-left:83.3333333333%}.offset-md-11{margin-left:91.6666666667%}}@media (min-width: 992px){.col-lg{-ms-flex-preferred-size:0;flex-basis:0;-webkit-box-flex:1;-ms-flex-positive:1;flex-grow:1;max-width:100%}.col-lg-auto{-webkit-box-flex:0;-ms-flex:0 0 auto;flex:0 0 auto;width:auto;max-width:100%}.col-lg-1{-webkit-box-flex:0;-ms-flex:0 0 8.3333333333%;flex:0 0 8.3333333333%;max-width:8.3333333333%}.col-lg-2{-webkit-box-flex:0;-ms-flex:0 0 16.6666666667%;flex:0 0 16.6666666667%;max-width:16.6666666667%}.col-lg-3{-webkit-box-flex:0;-ms-flex:0 0 25%;flex:0 0 25%;max-width:25%}.col-lg-4{-webkit-box-flex:0;-ms-flex:0 0 33.3333333333%;flex:0 0 33.3333333333%;max-width:33.3333333333%}.col-lg-5{-webkit-box-flex:0;-ms-flex:0 0 41.6666666667%;flex:0 0 41.6666666667%;max-width:41.6666666667%}.col-lg-6{-webkit-box-flex:0;-ms-flex:0 0 50%;flex:0 0 50%;max-width:50%}.col-lg-7{-webkit-box-flex:0;-ms-flex:0 0 58.3333333333%;flex:0 0 58.3333333333%;max-width:58.3333333333%}.col-lg-8{-webkit-box-flex:0;-ms-flex:0 0 66.6666666667%;flex:0 0 66.6666666667%;max-width:66.6666666667%}.col-lg-9{-webkit-box-flex:0;-ms-flex:0 0 75%;flex:0 0 75%;max-width:75%}.col-lg-10{-webkit-box-flex:0;-ms-flex:0 0 83.3333333333%;flex:0 0 83.3333333333%;max-width:83.3333333333%}.col-lg-11{-webkit-box-flex:0;-ms-flex:0 0 91.6666666667%;flex:0 0 91.6666666667%;max-width:91.6666666667%}.col-lg-12{-webkit-box-flex:0;-ms-flex:0 0 100%;flex:0 0 100%;max-width:100%}.order-lg-first{-webkit-box-ordinal-group:0;-ms-flex-order:-1;order:-1}.order-lg-last{-webkit-box-ordinal-group:14;-ms-flex-order:13;order:13}.order-lg-0{-webkit-box-ordinal-group:1;-ms-flex-order:0;order:0}.order-lg-1{-webkit-box-ordinal-group:2;-ms-flex-order:1;order:1}.order-lg-2{-webkit-box-ordinal-group:3;-ms-flex-order:2;order:2}.order-lg-3{-webkit-box-ordinal-group:4;-ms-flex-order:3;order:3}.order-lg-4{-webkit-box-ordinal-group:5;-ms-flex-order:4;order:4}.order-lg-5{-webkit-box-ordinal-group:6;-ms-flex-order:5;order:5}.order-lg-6{-webkit-box-ordinal-group:7;-ms-flex-order:6;order:6}.order-lg-7{-webkit-box-ordinal-group:8;-ms-flex-order:7;order:7}.order-lg-8{-webkit-box-ordinal-group:9;-ms-flex-order:8;order:8}.order-lg-9{-webkit-box-ordinal-group:10;-ms-flex-order:9;order:9}.order-lg-10{-webkit-box-ordinal-group:11;-ms-flex-order:10;order:10}.order-lg-11{-webkit-box-ordinal-group:12;-ms-flex-order:11;order:11}.order-lg-12{-webkit-box-ordinal-group:13;-ms-flex-order:12;order:12}.offset-lg-0{margin-left:0}.offset-lg-1{margin-left:8.3333333333%}.offset-lg-2{margin-left:16.6666666667%}.offset-lg-3{margin-left:25%}.offset-lg-4{margin-left:33.3333333333%}.offset-lg-5{margin-left:41.6666666667%}.offset-lg-6{margin-left:50%}.offset-lg-7{margin-left:58.3333333333%}.offset-lg-8{margin-left:66.6666666667%}.offset-lg-9{margin-left:75%}.offset-lg-10{margin-left:83.3333333333%}.offset-lg-11{margin-left:91.6666666667%}}@media (min-width: 1200px){.col-xl{-ms-flex-preferred-size:0;flex-basis:0;-webkit-box-flex:1;-ms-flex-positive:1;flex-grow:1;max-width:100%}.col-xl-auto{-webkit-box-flex:0;-ms-flex:0 0 auto;flex:0 0 auto;width:auto;max-width:100%}.col-xl-1{-webkit-box-flex:0;-ms-flex:0 0 8.3333333333%;flex:0 0 8.3333333333%;max-width:8.3333333333%}.col-xl-2{-webkit-box-flex:0;-ms-flex:0 0 16.6666666667%;flex:0 0 16.6666666667%;max-width:16.6666666667%}.col-xl-3{-webkit-box-flex:0;-ms-flex:0 0 25%;flex:0 0 25%;max-width:25%}.col-xl-4{-webkit-box-flex:0;-ms-flex:0 0 33.3333333333%;flex:0 0 33.3333333333%;max-width:33.3333333333%}.col-xl-5{-webkit-box-flex:0;-ms-flex:0 0 41.6666666667%;flex:0 0 41.6666666667%;max-width:41.6666666667%}.col-xl-6{-webkit-box-flex:0;-ms-flex:0 0 50%;flex:0 0 50%;max-width:50%}.col-xl-7{-webkit-box-flex:0;-ms-flex:0 0 58.3333333333%;flex:0 0 58.3333333333%;max-width:58.3333333333%}.col-xl-8{-webkit-box-flex:0;-ms-flex:0 0 66.6666666667%;flex:0 0 66.6666666667%;max-width:66.6666666667%}.col-xl-9{-webkit-box-flex:0;-ms-flex:0 0 75%;flex:0 0 75%;max-width:75%}.col-xl-10{-webkit-box-flex:0;-ms-flex:0 0 83.3333333333%;flex:0 0 83.3333333333%;max-width:83.3333333333%}.col-xl-11{-webkit-box-flex:0;-ms-flex:0 0 91.6666666667%;flex:0 0 91.6666666667%;max-width:91.6666666667%}.col-xl-12{-webkit-box-flex:0;-ms-flex:0 0 100%;flex:0 0 100%;max-width:100%}.order-xl-first{-webkit-box-ordinal-group:0;-ms-flex-order:-1;order:-1}.order-xl-last{-webkit-box-ordinal-group:14;-ms-flex-order:13;order:13}.order-xl-0{-webkit-box-ordinal-group:1;-ms-flex-order:0;order:0}.order-xl-1{-webkit-box-ordinal-group:2;-ms-flex-order:1;order:1}.order-xl-2{-webkit-box-ordinal-group:3;-ms-flex-order:2;order:2}.order-xl-3{-webkit-box-ordinal-group:4;-ms-flex-order:3;order:3}.order-xl-4{-webkit-box-ordinal-group:5;-ms-flex-order:4;order:4}.order-xl-5{-webkit-box-ordinal-group:6;-ms-flex-order:5;order:5}.order-xl-6{-webkit-box-ordinal-group:7;-ms-flex-order:6;order:6}.order-xl-7{-webkit-box-ordinal-group:8;-ms-flex-order:7;order:7}.order-xl-8{-webkit-box-ordinal-group:9;-ms-flex-order:8;order:8}.order-xl-9{-webkit-box-ordinal-group:10;-ms-flex-order:9;order:9}.order-xl-10{-webkit-box-ordinal-group:11;-ms-flex-order:10;order:10}.order-xl-11{-webkit-box-ordinal-group:12;-ms-flex-order:11;order:11}.order-xl-12{-webkit-box-ordinal-group:13;-ms-flex-order:12;order:12}.offset-xl-0{margin-left:0}.offset-xl-1{margin-left:8.3333333333%}.offset-xl-2{margin-left:16.6666666667%}.offset-xl-3{margin-left:25%}.offset-xl-4{margin-left:33.3333333333%}.offset-xl-5{margin-left:41.6666666667%}.offset-xl-6{margin-left:50%}.offset-xl-7{margin-left:58.3333333333%}.offset-xl-8{margin-left:66.6666666667%}.offset-xl-9{margin-left:75%}.offset-xl-10{margin-left:83.3333333333%}.offset-xl-11{margin-left:91.6666666667%}}.table{width:100%;margin-bottom:1rem;color:#839496}.table th,.table td{padding:0.75rem;vertical-align:top;border-top:1px solid #073642}.table thead th{vertical-align:bottom;border-bottom:2px solid #073642}.table tbody+tbody{border-top:2px solid #073642}.table-sm th,.table-sm td{padding:0.3rem}.table-bordered{border:1px solid #073642}.table-bordered th,.table-bordered td{border:1px solid #073642}.table-bordered thead th,.table-bordered thead td{border-bottom-width:2px}.table-borderless th,.table-borderless td,.table-borderless thead th,.table-borderless tbody+tbody{border:0}.table-striped tbody tr:nth-of-type(odd){background-color:rgba(255,255,255,0.05)}.table-hover tbody tr:hover{color:#839496;background-color:rgba(255,255,255,0.075)}.table-primary,.table-primary>th,.table-primary>td{background-color:#eadeb8}.table-primary th,.table-primary td,.table-primary thead th,.table-primary tbody+tbody{border-color:#d9c27a}.table-hover .table-primary:hover{background-color:#e4d5a4}.table-hover .table-primary:hover>td,.table-hover .table-primary:hover>th{background-color:#e4d5a4}.table-secondary,.table-secondary>th,.table-secondary>td{background-color:#dce1e2}.table-secondary th,.table-secondary td,.table-secondary thead th,.table-secondary tbody+tbody{border-color:#bfc7c8}.table-hover .table-secondary:hover{background-color:#ced5d6}.table-hover .table-secondary:hover>td,.table-hover .table-secondary:hover>th{background-color:#ced5d6}.table-success,.table-success>th,.table-success>td{background-color:#c3e5e2}.table-success th,.table-success td,.table-success thead th,.table-success tbody+tbody{border-color:#90cec9}.table-hover .table-success:hover{background-color:#b1ddd9}.table-hover .table-success:hover>td,.table-hover .table-success:hover>th{background-color:#b1ddd9}.table-info,.table-info>th,.table-info>td{background-color:#c2dff2}.table-info th,.table-info td,.table-info thead th,.table-info tbody+tbody{border-color:#8ec3e8}.table-hover .table-info:hover{background-color:#add4ee}.table-hover .table-info:hover>td,.table-hover .table-info:hover>th{background-color:#add4ee}.table-warning,.table-warning>th,.table-warning>td{background-color:#f0cdbe}.table-warning th,.table-warning td,.table-warning thead th,.table-warning tbody+tbody{border-color:#e4a186}.table-hover .table-warning:hover{background-color:#ebbda9}.table-hover .table-warning:hover>td,.table-hover .table-warning:hover>th{background-color:#ebbda9}.table-danger,.table-danger>th,.table-danger>td{background-color:#f3c7dc}.table-danger th,.table-danger td,.table-danger thead th,.table-danger tbody+tbody{border-color:#e896be}.table-hover .table-danger:hover{background-color:#efb2cf}.table-hover .table-danger:hover>td,.table-hover .table-danger:hover>th{background-color:#efb2cf}.table-light,.table-light>th,.table-light>td{background-color:#fefcf7}.table-light th,.table-light td,.table-light thead th,.table-light tbody+tbody{border-color:#fefaf0}.table-hover .table-light:hover{background-color:#fbf4e0}.table-hover .table-light:hover>td,.table-hover .table-light:hover>th{background-color:#fbf4e0}.table-dark,.table-dark>th,.table-dark>td{background-color:#bac7ca}.table-dark th,.table-dark td,.table-dark thead th,.table-dark tbody+tbody{border-color:#7e969d}.table-hover .table-dark:hover{background-color:#acbbbf}.table-hover .table-dark:hover>td,.table-hover .table-dark:hover>th{background-color:#acbbbf}.table-active,.table-active>th,.table-active>td{background-color:rgba(255,255,255,0.075)}.table-hover .table-active:hover{background-color:rgba(242,242,242,0.075)}.table-hover .table-active:hover>td,.table-hover .table-active:hover>th{background-color:rgba(242,242,242,0.075)}.table .thead-dark th{color:#002B36;background-color:#adb5bd;border-color:#a5adb6}.table .thead-light th{color:#495057;background-color:#EEE8D5;border-color:#073642}.table-dark{color:#002B36;background-color:#adb5bd}.table-dark th,.table-dark td,.table-dark thead th{border-color:#a5adb6}.table-dark.table-bordered{border:0}.table-dark.table-striped tbody tr:nth-of-type(odd){background-color:rgba(255,255,255,0.05)}.table-dark.table-hover tbody tr:hover{color:#002B36;background-color:rgba(255,255,255,0.075)}@media (max-width: 575.98px){.table-responsive-sm{display:block;width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch}.table-responsive-sm>.table-bordered{border:0}}@media (max-width: 767.98px){.table-responsive-md{display:block;width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch}.table-responsive-md>.table-bordered{border:0}}@media (max-width: 991.98px){.table-responsive-lg{display:block;width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch}.table-responsive-lg>.table-bordered{border:0}}@media (max-width: 1199.98px){.table-responsive-xl{display:block;width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch}.table-responsive-xl>.table-bordered{border:0}}.table-responsive{display:block;width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch}.table-responsive>.table-bordered{border:0}.form-control{display:block;width:100%;height:calc(1.5em + 0.75rem + 2px);padding:0.375rem 0.75rem;font-size:1rem;font-weight:400;line-height:1.5;color:#495057;background-color:#A9BDBD;background-clip:padding-box;border:1px solid rgba(0,0,0,0.15);border-radius:0.25rem;-webkit-transition:border-color 0.15s ease-in-out, -webkit-box-shadow 0.15s ease-in-out;transition:border-color 0.15s ease-in-out, -webkit-box-shadow 0.15s ease-in-out;transition:border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out;transition:border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out, -webkit-box-shadow 0.15s ease-in-out}@media (prefers-reduced-motion: reduce){.form-control{-webkit-transition:none;transition:none}}.form-control::-ms-expand{background-color:transparent;border:0}.form-control:focus{color:#495057;background-color:#A9BDBD;border-color:#1394b5;outline:0;-webkit-box-shadow:0 0 0 0.2rem rgba(7,54,66,0.25);box-shadow:0 0 0 0.2rem rgba(7,54,66,0.25)}.form-control::-webkit-input-placeholder{color:#657B83;opacity:1}.form-control::-ms-input-placeholder{color:#657B83;opacity:1}.form-control::placeholder{color:#657B83;opacity:1}.form-control:disabled,.form-control[readonly]{background-color:#657B83;opacity:1}select.form-control:focus::-ms-value{color:#495057;background-color:#A9BDBD}.form-control-file,.form-control-range{display:block;width:100%}.col-form-label{padding-top:calc(0.375rem + 1px);padding-bottom:calc(0.375rem + 1px);margin-bottom:0;font-size:inherit;line-height:1.5}.col-form-label-lg{padding-top:calc(0.5rem + 1px);padding-bottom:calc(0.5rem + 1px);font-size:1.25rem;line-height:1.5}.col-form-label-sm{padding-top:calc(0.25rem + 1px);padding-bottom:calc(0.25rem + 1px);font-size:0.875rem;line-height:1.5}.form-control-plaintext{display:block;width:100%;padding-top:0.375rem;padding-bottom:0.375rem;margin-bottom:0;line-height:1.5;color:#839496;background-color:transparent;border:solid transparent;border-width:1px 0}.form-control-plaintext.form-control-sm,.form-control-plaintext.form-control-lg{padding-right:0;padding-left:0}.form-control-sm{height:calc(1.5em + 0.5rem + 2px);padding:0.25rem 0.5rem;font-size:0.875rem;line-height:1.5;border-radius:0.2rem}.form-control-lg{height:calc(1.5em + 1rem + 2px);padding:0.5rem 1rem;font-size:1.25rem;line-height:1.5;border-radius:0.3rem}select.form-control[size],select.form-control[multiple]{height:auto}textarea.form-control{height:auto}.form-group{margin-bottom:1rem}.form-text{display:block;margin-top:0.25rem}.form-row{display:-webkit-box;display:-ms-flexbox;display:flex;-ms-flex-wrap:wrap;flex-wrap:wrap;margin-right:-5px;margin-left:-5px}.form-row>.col,.form-row>[class*="col-"]{padding-right:5px;padding-left:5px}.form-check{position:relative;display:block;padding-left:1.25rem}.form-check-input{position:absolute;margin-top:0.3rem;margin-left:-1.25rem}.form-check-input:disabled ~ .form-check-label{color:#839496}.form-check-label{margin-bottom:0}.form-check-inline{display:-webkit-inline-box;display:-ms-inline-flexbox;display:inline-flex;-webkit-box-align:center;-ms-flex-align:center;align-items:center;padding-left:0;margin-right:0.75rem}.form-check-inline .form-check-input{position:static;margin-top:0;margin-right:0.3125rem;margin-left:0}.valid-feedback{display:none;width:100%;margin-top:0.25rem;font-size:80%;color:#2AA198}.valid-tooltip{position:absolute;top:100%;z-index:5;display:none;max-width:100%;padding:0.25rem 0.5rem;margin-top:.1rem;font-size:0.875rem;line-height:1.5;color:#fff;background-color:rgba(42,161,152,0.9);border-radius:0.25rem}.was-validated .form-control:valid,.form-control.is-valid{border-color:#2AA198;padding-right:calc(1.5em + 0.75rem);background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 8 8'%3e%3cpath fill='%232AA198' d='M2.3 6.73L.6 4.53c-.4-1.04.46-1.4 1.1-.8l1.1 1.4 3.4-3.8c.6-.63 1.6-.27 1.2.7l-4 4.6c-.43.5-.8.4-1.1.1z'/%3e%3c/svg%3e");background-repeat:no-repeat;background-position:center right calc(0.375em + 0.1875rem);background-size:calc(0.75em + 0.375rem) calc(0.75em + 0.375rem)}.was-validated .form-control:valid:focus,.form-control.is-valid:focus{border-color:#2AA198;-webkit-box-shadow:0 0 0 0.2rem rgba(42,161,152,0.25);box-shadow:0 0 0 0.2rem rgba(42,161,152,0.25)}.was-validated .form-control:valid ~ .valid-feedback,.was-validated .form-control:valid ~ .valid-tooltip,.form-control.is-valid ~ .valid-feedback,.form-control.is-valid ~ .valid-tooltip{display:block}.was-validated textarea.form-control:valid,textarea.form-control.is-valid{padding-right:calc(1.5em + 0.75rem);background-position:top calc(0.375em + 0.1875rem) right calc(0.375em + 0.1875rem)}.was-validated .custom-select:valid,.custom-select.is-valid{border-color:#2AA198;padding-right:calc((1em + 0.75rem) * 3 / 4 + 1.75rem);background:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 4 5'%3e%3cpath fill='%23073642' d='M2 0L0 2h4zm0 5L0 3h4z'/%3e%3c/svg%3e") no-repeat right 0.75rem center/8px 10px,url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 8 8'%3e%3cpath fill='%232AA198' d='M2.3 6.73L.6 4.53c-.4-1.04.46-1.4 1.1-.8l1.1 1.4 3.4-3.8c.6-.63 1.6-.27 1.2.7l-4 4.6c-.43.5-.8.4-1.1.1z'/%3e%3c/svg%3e") #A9BDBD no-repeat center right 1.75rem/calc(0.75em + 0.375rem) calc(0.75em + 0.375rem)}.was-validated .custom-select:valid:focus,.custom-select.is-valid:focus{border-color:#2AA198;-webkit-box-shadow:0 0 0 0.2rem rgba(42,161,152,0.25);box-shadow:0 0 0 0.2rem rgba(42,161,152,0.25)}.was-validated .custom-select:valid ~ .valid-feedback,.was-validated .custom-select:valid ~ .valid-tooltip,.custom-select.is-valid ~ .valid-feedback,.custom-select.is-valid ~ .valid-tooltip{display:block}.was-validated .form-control-file:valid ~ .valid-feedback,.was-validated .form-control-file:valid ~ .valid-tooltip,.form-control-file.is-valid ~ .valid-feedback,.form-control-file.is-valid ~ .valid-tooltip{display:block}.was-validated .form-check-input:valid ~ .form-check-label,.form-check-input.is-valid ~ .form-check-label{color:#2AA198}.was-validated .form-check-input:valid ~ .valid-feedback,.was-validated .form-check-input:valid ~ .valid-tooltip,.form-check-input.is-valid ~ .valid-feedback,.form-check-input.is-valid ~ .valid-tooltip{display:block}.was-validated .custom-control-input:valid ~ .custom-control-label,.custom-control-input.is-valid ~ .custom-control-label{color:#2AA198}.was-validated .custom-control-input:valid ~ .custom-control-label::before,.custom-control-input.is-valid ~ .custom-control-label::before{border-color:#2AA198}.was-validated .custom-control-input:valid ~ .valid-feedback,.was-validated .custom-control-input:valid ~ .valid-tooltip,.custom-control-input.is-valid ~ .valid-feedback,.custom-control-input.is-valid ~ .valid-tooltip{display:block}.was-validated .custom-control-input:valid:checked ~ .custom-control-label::before,.custom-control-input.is-valid:checked ~ .custom-control-label::before{border-color:#35c9be;background:#35c9be -webkit-gradient(linear, left top, left bottom, from(#2db2aa), to(#35c9be)) repeat-x;background:#35c9be linear-gradient(180deg, #2db2aa, #35c9be) repeat-x}.was-validated .custom-control-input:valid:focus ~ .custom-control-label::before,.custom-control-input.is-valid:focus ~ .custom-control-label::before{-webkit-box-shadow:0 0 0 0.2rem rgba(42,161,152,0.25);box-shadow:0 0 0 0.2rem rgba(42,161,152,0.25)}.was-validated .custom-control-input:valid:focus:not(:checked) ~ .custom-control-label::before,.custom-control-input.is-valid:focus:not(:checked) ~ .custom-control-label::before{border-color:#2AA198}.was-validated .custom-file-input:valid ~ .custom-file-label,.custom-file-input.is-valid ~ .custom-file-label{border-color:#2AA198}.was-validated .custom-file-input:valid ~ .valid-feedback,.was-validated .custom-file-input:valid ~ .valid-tooltip,.custom-file-input.is-valid ~ .valid-feedback,.custom-file-input.is-valid ~ .valid-tooltip{display:block}.was-validated .custom-file-input:valid:focus ~ .custom-file-label,.custom-file-input.is-valid:focus ~ .custom-file-label{border-color:#2AA198;-webkit-box-shadow:0 0 0 0.2rem rgba(42,161,152,0.25);box-shadow:0 0 0 0.2rem rgba(42,161,152,0.25)}.invalid-feedback{display:none;width:100%;margin-top:0.25rem;font-size:80%;color:#D33682}.invalid-tooltip{position:absolute;top:100%;z-index:5;display:none;max-width:100%;padding:0.25rem 0.5rem;margin-top:.1rem;font-size:0.875rem;line-height:1.5;color:#fff;background-color:rgba(211,54,130,0.9);border-radius:0.25rem}.was-validated .form-control:invalid,.form-control.is-invalid{border-color:#D33682;padding-right:calc(1.5em + 0.75rem);background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='%23D33682' viewBox='-2 -2 7 7'%3e%3cpath stroke='%23D33682' d='M0 0l3 3m0-3L0 3'/%3e%3ccircle r='.5'/%3e%3ccircle cx='3' r='.5'/%3e%3ccircle cy='3' r='.5'/%3e%3ccircle cx='3' cy='3' r='.5'/%3e%3c/svg%3E");background-repeat:no-repeat;background-position:center right calc(0.375em + 0.1875rem);background-size:calc(0.75em + 0.375rem) calc(0.75em + 0.375rem)}.was-validated .form-control:invalid:focus,.form-control.is-invalid:focus{border-color:#D33682;-webkit-box-shadow:0 0 0 0.2rem rgba(211,54,130,0.25);box-shadow:0 0 0 0.2rem rgba(211,54,130,0.25)}.was-validated .form-control:invalid ~ .invalid-feedback,.was-validated .form-control:invalid ~ .invalid-tooltip,.form-control.is-invalid ~ .invalid-feedback,.form-control.is-invalid ~ .invalid-tooltip{display:block}.was-validated textarea.form-control:invalid,textarea.form-control.is-invalid{padding-right:calc(1.5em + 0.75rem);background-position:top calc(0.375em + 0.1875rem) right calc(0.375em + 0.1875rem)}.was-validated .custom-select:invalid,.custom-select.is-invalid{border-color:#D33682;padding-right:calc((1em + 0.75rem) * 3 / 4 + 1.75rem);background:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 4 5'%3e%3cpath fill='%23073642' d='M2 0L0 2h4zm0 5L0 3h4z'/%3e%3c/svg%3e") no-repeat right 0.75rem center/8px 10px,url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='%23D33682' viewBox='-2 -2 7 7'%3e%3cpath stroke='%23D33682' d='M0 0l3 3m0-3L0 3'/%3e%3ccircle r='.5'/%3e%3ccircle cx='3' r='.5'/%3e%3ccircle cy='3' r='.5'/%3e%3ccircle cx='3' cy='3' r='.5'/%3e%3c/svg%3E") #A9BDBD no-repeat center right 1.75rem/calc(0.75em + 0.375rem) calc(0.75em + 0.375rem)}.was-validated .custom-select:invalid:focus,.custom-select.is-invalid:focus{border-color:#D33682;-webkit-box-shadow:0 0 0 0.2rem rgba(211,54,130,0.25);box-shadow:0 0 0 0.2rem rgba(211,54,130,0.25)}.was-validated .custom-select:invalid ~ .invalid-feedback,.was-validated .custom-select:invalid ~ .invalid-tooltip,.custom-select.is-invalid ~ .invalid-feedback,.custom-select.is-invalid ~ .invalid-tooltip{display:block}.was-validated .form-control-file:invalid ~ .invalid-feedback,.was-validated .form-control-file:invalid ~ .invalid-tooltip,.form-control-file.is-invalid ~ .invalid-feedback,.form-control-file.is-invalid ~ .invalid-tooltip{display:block}.was-validated .form-check-input:invalid ~ .form-check-label,.form-check-input.is-invalid ~ .form-check-label{color:#D33682}.was-validated .form-check-input:invalid ~ .invalid-feedback,.was-validated .form-check-input:invalid ~ .invalid-tooltip,.form-check-input.is-invalid ~ .invalid-feedback,.form-check-input.is-invalid ~ .invalid-tooltip{display:block}.was-validated .custom-control-input:invalid ~ .custom-control-label,.custom-control-input.is-invalid ~ .custom-control-label{color:#D33682}.was-validated .custom-control-input:invalid ~ .custom-control-label::before,.custom-control-input.is-invalid ~ .custom-control-label::before{border-color:#D33682}.was-validated .custom-control-input:invalid ~ .invalid-feedback,.was-validated .custom-control-input:invalid ~ .invalid-tooltip,.custom-control-input.is-invalid ~ .invalid-feedback,.custom-control-input.is-invalid ~ .invalid-tooltip{display:block}.was-validated .custom-control-input:invalid:checked ~ .custom-control-label::before,.custom-control-input.is-invalid:checked ~ .custom-control-label::before{border-color:#dc609c;background:#dc609c -webkit-gradient(linear, left top, left bottom, from(#bb588d), to(#dc609c)) repeat-x;background:#dc609c linear-gradient(180deg, #bb588d, #dc609c) repeat-x}.was-validated .custom-control-input:invalid:focus ~ .custom-control-label::before,.custom-control-input.is-invalid:focus ~ .custom-control-label::before{-webkit-box-shadow:0 0 0 0.2rem rgba(211,54,130,0.25);box-shadow:0 0 0 0.2rem rgba(211,54,130,0.25)}.was-validated .custom-control-input:invalid:focus:not(:checked) ~ .custom-control-label::before,.custom-control-input.is-invalid:focus:not(:checked) ~ .custom-control-label::before{border-color:#D33682}.was-validated .custom-file-input:invalid ~ .custom-file-label,.custom-file-input.is-invalid ~ .custom-file-label{border-color:#D33682}.was-validated .custom-file-input:invalid ~ .invalid-feedback,.was-validated .custom-file-input:invalid ~ .invalid-tooltip,.custom-file-input.is-invalid ~ .invalid-feedback,.custom-file-input.is-invalid ~ .invalid-tooltip{display:block}.was-validated .custom-file-input:invalid:focus ~ .custom-file-label,.custom-file-input.is-invalid:focus ~ .custom-file-label{border-color:#D33682;-webkit-box-shadow:0 0 0 0.2rem rgba(211,54,130,0.25);box-shadow:0 0 0 0.2rem rgba(211,54,130,0.25)}.form-inline{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-orient:horizontal;-webkit-box-direction:normal;-ms-flex-flow:row wrap;flex-flow:row wrap;-webkit-box-align:center;-ms-flex-align:center;align-items:center}.form-inline .form-check{width:100%}@media (min-width: 576px){.form-inline label{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-align:center;-ms-flex-align:center;align-items:center;-webkit-box-pack:center;-ms-flex-pack:center;justify-content:center;margin-bottom:0}.form-inline .form-group{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-flex:0;-ms-flex:0 0 auto;flex:0 0 auto;-webkit-box-orient:horizontal;-webkit-box-direction:normal;-ms-flex-flow:row wrap;flex-flow:row wrap;-webkit-box-align:center;-ms-flex-align:center;align-items:center;margin-bottom:0}.form-inline .form-control{display:inline-block;width:auto;vertical-align:middle}.form-inline .form-control-plaintext{display:inline-block}.form-inline .input-group,.form-inline .custom-select{width:auto}.form-inline .form-check{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-align:center;-ms-flex-align:center;align-items:center;-webkit-box-pack:center;-ms-flex-pack:center;justify-content:center;width:auto;padding-left:0}.form-inline .form-check-input{position:relative;-ms-flex-negative:0;flex-shrink:0;margin-top:0;margin-right:0.25rem;margin-left:0}.form-inline .custom-control{-webkit-box-align:center;-ms-flex-align:center;align-items:center;-webkit-box-pack:center;-ms-flex-pack:center;justify-content:center}.form-inline .custom-control-label{margin-bottom:0}}.btn{display:inline-block;font-weight:400;color:#839496;text-align:center;vertical-align:middle;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;background-color:transparent;border:1px solid transparent;padding:0.375rem 0.75rem;font-size:1rem;line-height:1.5;border-radius:0.25rem;-webkit-transition:color 0.15s ease-in-out, background-color 0.15s ease-in-out, border-color 0.15s ease-in-out, -webkit-box-shadow 0.15s ease-in-out;transition:color 0.15s ease-in-out, background-color 0.15s ease-in-out, border-color 0.15s ease-in-out, -webkit-box-shadow 0.15s ease-in-out;transition:color 0.15s ease-in-out, background-color 0.15s ease-in-out, border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out;transition:color 0.15s ease-in-out, background-color 0.15s ease-in-out, border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out, -webkit-box-shadow 0.15s ease-in-out}@media (prefers-reduced-motion: reduce){.btn{-webkit-transition:none;transition:none}}.btn:hover{color:#839496;text-decoration:none}.btn:focus,.btn.focus{outline:0;-webkit-box-shadow:0 0 0 0.2rem rgba(7,54,66,0.25);box-shadow:0 0 0 0.2rem rgba(7,54,66,0.25)}.btn.disabled,.btn:disabled{opacity:0.65}a.btn.disabled,fieldset:disabled a.btn{pointer-events:none}.btn-primary{color:#fff;background:#B58900 -webkit-gradient(linear, left top, left bottom, from(#9a7b08), to(#B58900)) repeat-x;background:#B58900 linear-gradient(180deg, #9a7b08, #B58900) repeat-x;border-color:#B58900}.btn-primary:hover{color:#fff;background:#8f6c00 -webkit-gradient(linear, left top, left bottom, from(#796208), to(#8f6c00)) repeat-x;background:#8f6c00 linear-gradient(180deg, #796208, #8f6c00) repeat-x;border-color:#826200}.btn-primary:focus,.btn-primary.focus{-webkit-box-shadow:0 0 0 0.2rem rgba(192,155,38,0.5);box-shadow:0 0 0 0.2rem rgba(192,155,38,0.5)}.btn-primary.disabled,.btn-primary:disabled{color:#fff;background-color:#B58900;border-color:#B58900;background-image:none}.btn-primary:not(:disabled):not(.disabled):active,.btn-primary:not(:disabled):not(.disabled).active,.show>.btn-primary.dropdown-toggle{color:#fff;background-color:#826200;background-image:none;border-color:#755900}.btn-primary:not(:disabled):not(.disabled):active:focus,.btn-primary:not(:disabled):not(.disabled).active:focus,.show>.btn-primary.dropdown-toggle:focus{-webkit-box-shadow:0 0 0 0.2rem rgba(192,155,38,0.5);box-shadow:0 0 0 0.2rem rgba(192,155,38,0.5)}.btn-secondary{color:#fff;background:#839496 -webkit-gradient(linear, left top, left bottom, from(#6f8488), to(#839496)) repeat-x;background:#839496 linear-gradient(180deg, #6f8488, #839496) repeat-x;border-color:#839496}.btn-secondary:hover{color:#fff;background:#6f8183 -webkit-gradient(linear, left top, left bottom, from(#5f7478), to(#6f8183)) repeat-x;background:#6f8183 linear-gradient(180deg, #5f7478, #6f8183) repeat-x;border-color:#697b7d}.btn-secondary:focus,.btn-secondary.focus{-webkit-box-shadow:0 0 0 0.2rem rgba(150,164,166,0.5);box-shadow:0 0 0 0.2rem rgba(150,164,166,0.5)}.btn-secondary.disabled,.btn-secondary:disabled{color:#fff;background-color:#839496;border-color:#839496;background-image:none}.btn-secondary:not(:disabled):not(.disabled):active,.btn-secondary:not(:disabled):not(.disabled).active,.show>.btn-secondary.dropdown-toggle{color:#fff;background-color:#697b7d;background-image:none;border-color:#647476}.btn-secondary:not(:disabled):not(.disabled):active:focus,.btn-secondary:not(:disabled):not(.disabled).active:focus,.show>.btn-secondary.dropdown-toggle:focus{-webkit-box-shadow:0 0 0 0.2rem rgba(150,164,166,0.5);box-shadow:0 0 0 0.2rem rgba(150,164,166,0.5)}.btn-success{color:#fff;background:#2AA198 -webkit-gradient(linear, left top, left bottom, from(#248f89), to(#2AA198)) repeat-x;background:#2AA198 linear-gradient(180deg, #248f89, #2AA198) repeat-x;border-color:#2AA198}.btn-success:hover{color:#fff;background:#22837b -webkit-gradient(linear, left top, left bottom, from(#1d7671), to(#22837b)) repeat-x;background:#22837b linear-gradient(180deg, #1d7671, #22837b) repeat-x;border-color:#1f7972}.btn-success:focus,.btn-success.focus{-webkit-box-shadow:0 0 0 0.2rem rgba(74,175,167,0.5);box-shadow:0 0 0 0.2rem rgba(74,175,167,0.5)}.btn-success.disabled,.btn-success:disabled{color:#fff;background-color:#2AA198;border-color:#2AA198;background-image:none}.btn-success:not(:disabled):not(.disabled):active,.btn-success:not(:disabled):not(.disabled).active,.show>.btn-success.dropdown-toggle{color:#fff;background-color:#1f7972;background-image:none;border-color:#1d6e68}.btn-success:not(:disabled):not(.disabled):active:focus,.btn-success:not(:disabled):not(.disabled).active:focus,.show>.btn-success.dropdown-toggle:focus{-webkit-box-shadow:0 0 0 0.2rem rgba(74,175,167,0.5);box-shadow:0 0 0 0.2rem rgba(74,175,167,0.5)}.btn-info{color:#fff;background:#268BD2 -webkit-gradient(linear, left top, left bottom, from(#207dbb), to(#268BD2)) repeat-x;background:#268BD2 linear-gradient(180deg, #207dbb, #268BD2) repeat-x;border-color:#268BD2}.btn-info:hover{color:#fff;background:#2076b2 -webkit-gradient(linear, left top, left bottom, from(#1b6a9f), to(#2076b2)) repeat-x;background:#2076b2 linear-gradient(180deg, #1b6a9f, #2076b2) repeat-x;border-color:#1e6ea7}.btn-info:focus,.btn-info.focus{-webkit-box-shadow:0 0 0 0.2rem rgba(71,156,217,0.5);box-shadow:0 0 0 0.2rem rgba(71,156,217,0.5)}.btn-info.disabled,.btn-info:disabled{color:#fff;background-color:#268BD2;border-color:#268BD2;background-image:none}.btn-info:not(:disabled):not(.disabled):active,.btn-info:not(:disabled):not(.disabled).active,.show>.btn-info.dropdown-toggle{color:#fff;background-color:#1e6ea7;background-image:none;border-color:#1c679c}.btn-info:not(:disabled):not(.disabled):active:focus,.btn-info:not(:disabled):not(.disabled).active:focus,.show>.btn-info.dropdown-toggle:focus{-webkit-box-shadow:0 0 0 0.2rem rgba(71,156,217,0.5);box-shadow:0 0 0 0.2rem rgba(71,156,217,0.5)}.btn-warning{color:#fff;background:#CB4B16 -webkit-gradient(linear, left top, left bottom, from(#ad461b), to(#CB4B16)) repeat-x;background:#CB4B16 linear-gradient(180deg, #ad461b, #CB4B16) repeat-x;border-color:#CB4B16}.btn-warning:hover{color:#fff;background:#a83e12 -webkit-gradient(linear, left top, left bottom, from(#8f3b18), to(#a83e12)) repeat-x;background:#a83e12 linear-gradient(180deg, #8f3b18, #a83e12) repeat-x;border-color:#9d3a11}.btn-warning:focus,.btn-warning.focus{-webkit-box-shadow:0 0 0 0.2rem rgba(211,102,57,0.5);box-shadow:0 0 0 0.2rem rgba(211,102,57,0.5)}.btn-warning.disabled,.btn-warning:disabled{color:#fff;background-color:#CB4B16;border-color:#CB4B16;background-image:none}.btn-warning:not(:disabled):not(.disabled):active,.btn-warning:not(:disabled):not(.disabled).active,.show>.btn-warning.dropdown-toggle{color:#fff;background-color:#9d3a11;background-image:none;border-color:#913610}.btn-warning:not(:disabled):not(.disabled):active:focus,.btn-warning:not(:disabled):not(.disabled).active:focus,.show>.btn-warning.dropdown-toggle:focus{-webkit-box-shadow:0 0 0 0.2rem rgba(211,102,57,0.5);box-shadow:0 0 0 0.2rem rgba(211,102,57,0.5)}.btn-danger{color:#fff;background:#D33682 -webkit-gradient(linear, left top, left bottom, from(#b33477), to(#D33682)) repeat-x;background:#D33682 linear-gradient(180deg, #b33477, #D33682) repeat-x;border-color:#D33682}.btn-danger:hover{color:#fff;background:#ba296f -webkit-gradient(linear, left top, left bottom, from(#9e2967), to(#ba296f)) repeat-x;background:#ba296f linear-gradient(180deg, #9e2967, #ba296f) repeat-x;border-color:#b02669}.btn-danger:focus,.btn-danger.focus{-webkit-box-shadow:0 0 0 0.2rem rgba(218,84,149,0.5);box-shadow:0 0 0 0.2rem rgba(218,84,149,0.5)}.btn-danger.disabled,.btn-danger:disabled{color:#fff;background-color:#D33682;border-color:#D33682;background-image:none}.btn-danger:not(:disabled):not(.disabled):active,.btn-danger:not(:disabled):not(.disabled).active,.show>.btn-danger.dropdown-toggle{color:#fff;background-color:#b02669;background-image:none;border-color:#a52463}.btn-danger:not(:disabled):not(.disabled):active:focus,.btn-danger:not(:disabled):not(.disabled).active:focus,.show>.btn-danger.dropdown-toggle:focus{-webkit-box-shadow:0 0 0 0.2rem rgba(218,84,149,0.5);box-shadow:0 0 0 0.2rem rgba(218,84,149,0.5)}.btn-light{color:#002B36;background:#FDF6E3 -webkit-gradient(linear, left top, left bottom, from(#d7d8c9), to(#FDF6E3)) repeat-x;background:#FDF6E3 linear-gradient(180deg, #d7d8c9, #FDF6E3) repeat-x;border-color:#FDF6E3}.btn-light:hover{color:#002B36;background:#faebbf -webkit-gradient(linear, left top, left bottom, from(#d5ceab), to(#faebbf)) repeat-x;background:#faebbf linear-gradient(180deg, #d5ceab, #faebbf) repeat-x;border-color:#fae7b3}.btn-light:focus,.btn-light.focus{-webkit-box-shadow:0 0 0 0.2rem rgba(215,216,201,0.5);box-shadow:0 0 0 0.2rem rgba(215,216,201,0.5)}.btn-light.disabled,.btn-light:disabled{color:#002B36;background-color:#FDF6E3;border-color:#FDF6E3;background-image:none}.btn-light:not(:disabled):not(.disabled):active,.btn-light:not(:disabled):not(.disabled).active,.show>.btn-light.dropdown-toggle{color:#002B36;background-color:#fae7b3;background-image:none;border-color:#f9e3a8}.btn-light:not(:disabled):not(.disabled):active:focus,.btn-light:not(:disabled):not(.disabled).active:focus,.show>.btn-light.dropdown-toggle:focus{-webkit-box-shadow:0 0 0 0.2rem rgba(215,216,201,0.5);box-shadow:0 0 0 0.2rem rgba(215,216,201,0.5)}.btn-dark{color:#fff;background:#073642 -webkit-gradient(linear, left top, left bottom, from(#063440), to(#073642)) repeat-x;background:#073642 linear-gradient(180deg, #063440, #073642) repeat-x;border-color:#073642}.btn-dark:hover{color:#fff;background:#031a1f -webkit-gradient(linear, left top, left bottom, from(#031c23), to(#031a1f)) repeat-x;background:#031a1f linear-gradient(180deg, #031c23, #031a1f) repeat-x;border-color:#021014}.btn-dark:focus,.btn-dark.focus{-webkit-box-shadow:0 0 0 0.2rem rgba(44,84,94,0.5);box-shadow:0 0 0 0.2rem rgba(44,84,94,0.5)}.btn-dark.disabled,.btn-dark:disabled{color:#fff;background-color:#073642;border-color:#073642;background-image:none}.btn-dark:not(:disabled):not(.disabled):active,.btn-dark:not(:disabled):not(.disabled).active,.show>.btn-dark.dropdown-toggle{color:#fff;background-color:#021014;background-image:none;border-color:#010708}.btn-dark:not(:disabled):not(.disabled):active:focus,.btn-dark:not(:disabled):not(.disabled).active:focus,.show>.btn-dark.dropdown-toggle:focus{-webkit-box-shadow:0 0 0 0.2rem rgba(44,84,94,0.5);box-shadow:0 0 0 0.2rem rgba(44,84,94,0.5)}.btn-outline-primary{color:#B58900;border-color:#B58900}.btn-outline-primary:hover{color:#fff;background-color:#B58900;border-color:#B58900}.btn-outline-primary:focus,.btn-outline-primary.focus{-webkit-box-shadow:0 0 0 0.2rem rgba(181,137,0,0.5);box-shadow:0 0 0 0.2rem rgba(181,137,0,0.5)}.btn-outline-primary.disabled,.btn-outline-primary:disabled{color:#B58900;background-color:transparent}.btn-outline-primary:not(:disabled):not(.disabled):active,.btn-outline-primary:not(:disabled):not(.disabled).active,.show>.btn-outline-primary.dropdown-toggle{color:#fff;background-color:#B58900;border-color:#B58900}.btn-outline-primary:not(:disabled):not(.disabled):active:focus,.btn-outline-primary:not(:disabled):not(.disabled).active:focus,.show>.btn-outline-primary.dropdown-toggle:focus{-webkit-box-shadow:0 0 0 0.2rem rgba(181,137,0,0.5);box-shadow:0 0 0 0.2rem rgba(181,137,0,0.5)}.btn-outline-secondary{color:#839496;border-color:#839496}.btn-outline-secondary:hover{color:#fff;background-color:#839496;border-color:#839496}.btn-outline-secondary:focus,.btn-outline-secondary.focus{-webkit-box-shadow:0 0 0 0.2rem rgba(131,148,150,0.5);box-shadow:0 0 0 0.2rem rgba(131,148,150,0.5)}.btn-outline-secondary.disabled,.btn-outline-secondary:disabled{color:#839496;background-color:transparent}.btn-outline-secondary:not(:disabled):not(.disabled):active,.btn-outline-secondary:not(:disabled):not(.disabled).active,.show>.btn-outline-secondary.dropdown-toggle{color:#fff;background-color:#839496;border-color:#839496}.btn-outline-secondary:not(:disabled):not(.disabled):active:focus,.btn-outline-secondary:not(:disabled):not(.disabled).active:focus,.show>.btn-outline-secondary.dropdown-toggle:focus{-webkit-box-shadow:0 0 0 0.2rem rgba(131,148,150,0.5);box-shadow:0 0 0 0.2rem rgba(131,148,150,0.5)}.btn-outline-success{color:#2AA198;border-color:#2AA198}.btn-outline-success:hover{color:#fff;background-color:#2AA198;border-color:#2AA198}.btn-outline-success:focus,.btn-outline-success.focus{-webkit-box-shadow:0 0 0 0.2rem rgba(42,161,152,0.5);box-shadow:0 0 0 0.2rem rgba(42,161,152,0.5)}.btn-outline-success.disabled,.btn-outline-success:disabled{color:#2AA198;background-color:transparent}.btn-outline-success:not(:disabled):not(.disabled):active,.btn-outline-success:not(:disabled):not(.disabled).active,.show>.btn-outline-success.dropdown-toggle{color:#fff;background-color:#2AA198;border-color:#2AA198}.btn-outline-success:not(:disabled):not(.disabled):active:focus,.btn-outline-success:not(:disabled):not(.disabled).active:focus,.show>.btn-outline-success.dropdown-toggle:focus{-webkit-box-shadow:0 0 0 0.2rem rgba(42,161,152,0.5);box-shadow:0 0 0 0.2rem rgba(42,161,152,0.5)}.btn-outline-info{color:#268BD2;border-color:#268BD2}.btn-outline-info:hover{color:#fff;background-color:#268BD2;border-color:#268BD2}.btn-outline-info:focus,.btn-outline-info.focus{-webkit-box-shadow:0 0 0 0.2rem rgba(38,139,210,0.5);box-shadow:0 0 0 0.2rem rgba(38,139,210,0.5)}.btn-outline-info.disabled,.btn-outline-info:disabled{color:#268BD2;background-color:transparent}.btn-outline-info:not(:disabled):not(.disabled):active,.btn-outline-info:not(:disabled):not(.disabled).active,.show>.btn-outline-info.dropdown-toggle{color:#fff;background-color:#268BD2;border-color:#268BD2}.btn-outline-info:not(:disabled):not(.disabled):active:focus,.btn-outline-info:not(:disabled):not(.disabled).active:focus,.show>.btn-outline-info.dropdown-toggle:focus{-webkit-box-shadow:0 0 0 0.2rem rgba(38,139,210,0.5);box-shadow:0 0 0 0.2rem rgba(38,139,210,0.5)}.btn-outline-warning{color:#CB4B16;border-color:#CB4B16}.btn-outline-warning:hover{color:#fff;background-color:#CB4B16;border-color:#CB4B16}.btn-outline-warning:focus,.btn-outline-warning.focus{-webkit-box-shadow:0 0 0 0.2rem rgba(203,75,22,0.5);box-shadow:0 0 0 0.2rem rgba(203,75,22,0.5)}.btn-outline-warning.disabled,.btn-outline-warning:disabled{color:#CB4B16;background-color:transparent}.btn-outline-warning:not(:disabled):not(.disabled):active,.btn-outline-warning:not(:disabled):not(.disabled).active,.show>.btn-outline-warning.dropdown-toggle{color:#fff;background-color:#CB4B16;border-color:#CB4B16}.btn-outline-warning:not(:disabled):not(.disabled):active:focus,.btn-outline-warning:not(:disabled):not(.disabled).active:focus,.show>.btn-outline-warning.dropdown-toggle:focus{-webkit-box-shadow:0 0 0 0.2rem rgba(203,75,22,0.5);box-shadow:0 0 0 0.2rem rgba(203,75,22,0.5)}.btn-outline-danger{color:#D33682;border-color:#D33682}.btn-outline-danger:hover{color:#fff;background-color:#D33682;border-color:#D33682}.btn-outline-danger:focus,.btn-outline-danger.focus{-webkit-box-shadow:0 0 0 0.2rem rgba(211,54,130,0.5);box-shadow:0 0 0 0.2rem rgba(211,54,130,0.5)}.btn-outline-danger.disabled,.btn-outline-danger:disabled{color:#D33682;background-color:transparent}.btn-outline-danger:not(:disabled):not(.disabled):active,.btn-outline-danger:not(:disabled):not(.disabled).active,.show>.btn-outline-danger.dropdown-toggle{color:#fff;background-color:#D33682;border-color:#D33682}.btn-outline-danger:not(:disabled):not(.disabled):active:focus,.btn-outline-danger:not(:disabled):not(.disabled).active:focus,.show>.btn-outline-danger.dropdown-toggle:focus{-webkit-box-shadow:0 0 0 0.2rem rgba(211,54,130,0.5);box-shadow:0 0 0 0.2rem rgba(211,54,130,0.5)}.btn-outline-light{color:#FDF6E3;border-color:#FDF6E3}.btn-outline-light:hover{color:#002B36;background-color:#FDF6E3;border-color:#FDF6E3}.btn-outline-light:focus,.btn-outline-light.focus{-webkit-box-shadow:0 0 0 0.2rem rgba(253,246,227,0.5);box-shadow:0 0 0 0.2rem rgba(253,246,227,0.5)}.btn-outline-light.disabled,.btn-outline-light:disabled{color:#FDF6E3;background-color:transparent}.btn-outline-light:not(:disabled):not(.disabled):active,.btn-outline-light:not(:disabled):not(.disabled).active,.show>.btn-outline-light.dropdown-toggle{color:#002B36;background-color:#FDF6E3;border-color:#FDF6E3}.btn-outline-light:not(:disabled):not(.disabled):active:focus,.btn-outline-light:not(:disabled):not(.disabled).active:focus,.show>.btn-outline-light.dropdown-toggle:focus{-webkit-box-shadow:0 0 0 0.2rem rgba(253,246,227,0.5);box-shadow:0 0 0 0.2rem rgba(253,246,227,0.5)}.btn-outline-dark{color:#073642;border-color:#073642}.btn-outline-dark:hover{color:#fff;background-color:#073642;border-color:#073642}.btn-outline-dark:focus,.btn-outline-dark.focus{-webkit-box-shadow:0 0 0 0.2rem rgba(7,54,66,0.5);box-shadow:0 0 0 0.2rem rgba(7,54,66,0.5)}.btn-outline-dark.disabled,.btn-outline-dark:disabled{color:#073642;background-color:transparent}.btn-outline-dark:not(:disabled):not(.disabled):active,.btn-outline-dark:not(:disabled):not(.disabled).active,.show>.btn-outline-dark.dropdown-toggle{color:#fff;background-color:#073642;border-color:#073642}.btn-outline-dark:not(:disabled):not(.disabled):active:focus,.btn-outline-dark:not(:disabled):not(.disabled).active:focus,.show>.btn-outline-dark.dropdown-toggle:focus{-webkit-box-shadow:0 0 0 0.2rem rgba(7,54,66,0.5);box-shadow:0 0 0 0.2rem rgba(7,54,66,0.5)}.btn-link{font-weight:400;color:#2AA198;text-decoration:none}.btn-link:hover{color:#2AA198;text-decoration:underline}.btn-link:focus,.btn-link.focus{text-decoration:underline;-webkit-box-shadow:none;box-shadow:none}.btn-link:disabled,.btn-link.disabled{color:#839496;pointer-events:none}.btn-lg,.btn-group-lg>.btn{padding:0.5rem 1rem;font-size:1.25rem;line-height:1.5;border-radius:0.3rem}.btn-sm,.btn-group-sm>.btn{padding:0.25rem 0.5rem;font-size:0.875rem;line-height:1.5;border-radius:0.2rem}.btn-block{display:block;width:100%}.btn-block+.btn-block{margin-top:0.5rem}input[type="submit"].btn-block,input[type="reset"].btn-block,input[type="button"].btn-block{width:100%}.fade{-webkit-transition:opacity 0.15s linear;transition:opacity 0.15s linear}@media (prefers-reduced-motion: reduce){.fade{-webkit-transition:none;transition:none}}.fade:not(.show){opacity:0}.collapse:not(.show){display:none}.collapsing{position:relative;height:0;overflow:hidden;-webkit-transition:height 0.35s ease;transition:height 0.35s ease}@media (prefers-reduced-motion: reduce){.collapsing{-webkit-transition:none;transition:none}}.dropup,.dropright,.dropdown,.dropleft{position:relative}.dropdown-toggle{white-space:nowrap}.dropdown-toggle::after{display:inline-block;margin-left:0.255em;vertical-align:0.255em;content:"";border-top:0.3em solid;border-right:0.3em solid transparent;border-bottom:0;border-left:0.3em solid transparent}.dropdown-toggle:empty::after{margin-left:0}.dropdown-menu{position:absolute;top:100%;left:0;z-index:1000;display:none;float:left;min-width:10rem;padding:0.5rem 0;margin:0.125rem 0 0;font-size:1rem;color:#839496;text-align:left;list-style:none;background-color:#073642;background-clip:padding-box;border:1px solid rgba(0,0,0,0.15);border-radius:0.25rem}.dropdown-menu-left{right:auto;left:0}.dropdown-menu-right{right:0;left:auto}@media (min-width: 576px){.dropdown-menu-sm-left{right:auto;left:0}.dropdown-menu-sm-right{right:0;left:auto}}@media (min-width: 768px){.dropdown-menu-md-left{right:auto;left:0}.dropdown-menu-md-right{right:0;left:auto}}@media (min-width: 992px){.dropdown-menu-lg-left{right:auto;left:0}.dropdown-menu-lg-right{right:0;left:auto}}@media (min-width: 1200px){.dropdown-menu-xl-left{right:auto;left:0}.dropdown-menu-xl-right{right:0;left:auto}}.dropup .dropdown-menu{top:auto;bottom:100%;margin-top:0;margin-bottom:0.125rem}.dropup .dropdown-toggle::after{display:inline-block;margin-left:0.255em;vertical-align:0.255em;content:"";border-top:0;border-right:0.3em solid transparent;border-bottom:0.3em solid;border-left:0.3em solid transparent}.dropup .dropdown-toggle:empty::after{margin-left:0}.dropright .dropdown-menu{top:0;right:auto;left:100%;margin-top:0;margin-left:0.125rem}.dropright .dropdown-toggle::after{display:inline-block;margin-left:0.255em;vertical-align:0.255em;content:"";border-top:0.3em solid transparent;border-right:0;border-bottom:0.3em solid transparent;border-left:0.3em solid}.dropright .dropdown-toggle:empty::after{margin-left:0}.dropright .dropdown-toggle::after{vertical-align:0}.dropleft .dropdown-menu{top:0;right:100%;left:auto;margin-top:0;margin-right:0.125rem}.dropleft .dropdown-toggle::after{display:inline-block;margin-left:0.255em;vertical-align:0.255em;content:""}.dropleft .dropdown-toggle::after{display:none}.dropleft .dropdown-toggle::before{display:inline-block;margin-right:0.255em;vertical-align:0.255em;content:"";border-top:0.3em solid transparent;border-right:0.3em solid;border-bottom:0.3em solid transparent}.dropleft .dropdown-toggle:empty::after{margin-left:0}.dropleft .dropdown-toggle::before{vertical-align:0}.dropdown-menu[x-placement^="top"],.dropdown-menu[x-placement^="right"],.dropdown-menu[x-placement^="bottom"],.dropdown-menu[x-placement^="left"]{right:auto;bottom:auto}.dropdown-divider{height:0;margin:0.5rem 0;overflow:hidden;border-top:1px solid #002B36}.dropdown-item{display:block;width:100%;padding:0.25rem 1.5rem;clear:both;font-weight:400;color:#839496;text-align:inherit;white-space:nowrap;background-color:transparent;border:0}.dropdown-item:hover,.dropdown-item:focus{color:rgba(255,255,255,0.75);text-decoration:none;background:#002B36 -webkit-gradient(linear, left top, left bottom, from(#002b36), to(#002B36)) repeat-x;background:#002B36 linear-gradient(180deg, #002b36, #002B36) repeat-x}.dropdown-item.active,.dropdown-item:active{color:rgba(255,255,255,0.75);text-decoration:none;background:#073642 -webkit-gradient(linear, left top, left bottom, from(#063440), to(#073642)) repeat-x;background:#073642 linear-gradient(180deg, #063440, #073642) repeat-x}.dropdown-item.disabled,.dropdown-item:disabled{color:#839496;pointer-events:none;background-color:transparent;background-image:none}.dropdown-menu.show{display:block}.dropdown-header{display:block;padding:0.5rem 1.5rem;margin-bottom:0;font-size:0.875rem;color:#839496;white-space:nowrap}.dropdown-item-text{display:block;padding:0.25rem 1.5rem;color:#839496}.btn-group,.btn-group-vertical{position:relative;display:-webkit-inline-box;display:-ms-inline-flexbox;display:inline-flex;vertical-align:middle}.btn-group>.btn,.btn-group-vertical>.btn{position:relative;-webkit-box-flex:1;-ms-flex:1 1 auto;flex:1 1 auto}.btn-group>.btn:hover,.btn-group-vertical>.btn:hover{z-index:1}.btn-group>.btn:focus,.btn-group>.btn:active,.btn-group>.btn.active,.btn-group-vertical>.btn:focus,.btn-group-vertical>.btn:active,.btn-group-vertical>.btn.active{z-index:1}.btn-toolbar{display:-webkit-box;display:-ms-flexbox;display:flex;-ms-flex-wrap:wrap;flex-wrap:wrap;-webkit-box-pack:start;-ms-flex-pack:start;justify-content:flex-start}.btn-toolbar .input-group{width:auto}.btn-group>.btn:not(:first-child),.btn-group>.btn-group:not(:first-child){margin-left:-1px}.btn-group>.btn:not(:last-child):not(.dropdown-toggle),.btn-group>.btn-group:not(:last-child)>.btn{border-top-right-radius:0;border-bottom-right-radius:0}.btn-group>.btn:not(:first-child),.btn-group>.btn-group:not(:first-child)>.btn{border-top-left-radius:0;border-bottom-left-radius:0}.dropdown-toggle-split{padding-right:0.5625rem;padding-left:0.5625rem}.dropdown-toggle-split::after,.dropup .dropdown-toggle-split::after,.dropright .dropdown-toggle-split::after{margin-left:0}.dropleft .dropdown-toggle-split::before{margin-right:0}.btn-sm+.dropdown-toggle-split,.btn-group-sm>.btn+.dropdown-toggle-split{padding-right:0.375rem;padding-left:0.375rem}.btn-lg+.dropdown-toggle-split,.btn-group-lg>.btn+.dropdown-toggle-split{padding-right:0.75rem;padding-left:0.75rem}.btn-group-vertical{-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;flex-direction:column;-webkit-box-align:start;-ms-flex-align:start;align-items:flex-start;-webkit-box-pack:center;-ms-flex-pack:center;justify-content:center}.btn-group-vertical>.btn,.btn-group-vertical>.btn-group{width:100%}.btn-group-vertical>.btn:not(:first-child),.btn-group-vertical>.btn-group:not(:first-child){margin-top:-1px}.btn-group-vertical>.btn:not(:last-child):not(.dropdown-toggle),.btn-group-vertical>.btn-group:not(:last-child)>.btn{border-bottom-right-radius:0;border-bottom-left-radius:0}.btn-group-vertical>.btn:not(:first-child),.btn-group-vertical>.btn-group:not(:first-child)>.btn{border-top-left-radius:0;border-top-right-radius:0}.btn-group-toggle>.btn,.btn-group-toggle>.btn-group>.btn{margin-bottom:0}.btn-group-toggle>.btn input[type="radio"],.btn-group-toggle>.btn input[type="checkbox"],.btn-group-toggle>.btn-group>.btn input[type="radio"],.btn-group-toggle>.btn-group>.btn input[type="checkbox"]{position:absolute;clip:rect(0, 0, 0, 0);pointer-events:none}.input-group{position:relative;display:-webkit-box;display:-ms-flexbox;display:flex;-ms-flex-wrap:wrap;flex-wrap:wrap;-webkit-box-align:stretch;-ms-flex-align:stretch;align-items:stretch;width:100%}.input-group>.form-control,.input-group>.form-control-plaintext,.input-group>.custom-select,.input-group>.custom-file{position:relative;-webkit-box-flex:1;-ms-flex:1 1 auto;flex:1 1 auto;width:1%;margin-bottom:0}.input-group>.form-control+.form-control,.input-group>.form-control+.custom-select,.input-group>.form-control+.custom-file,.input-group>.form-control-plaintext+.form-control,.input-group>.form-control-plaintext+.custom-select,.input-group>.form-control-plaintext+.custom-file,.input-group>.custom-select+.form-control,.input-group>.custom-select+.custom-select,.input-group>.custom-select+.custom-file,.input-group>.custom-file+.form-control,.input-group>.custom-file+.custom-select,.input-group>.custom-file+.custom-file{margin-left:-1px}.input-group>.form-control:focus,.input-group>.custom-select:focus,.input-group>.custom-file .custom-file-input:focus ~ .custom-file-label{z-index:3}.input-group>.custom-file .custom-file-input:focus{z-index:4}.input-group>.form-control:not(:last-child),.input-group>.custom-select:not(:last-child){border-top-right-radius:0;border-bottom-right-radius:0}.input-group>.form-control:not(:first-child),.input-group>.custom-select:not(:first-child){border-top-left-radius:0;border-bottom-left-radius:0}.input-group>.custom-file{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-align:center;-ms-flex-align:center;align-items:center}.input-group>.custom-file:not(:last-child) .custom-file-label,.input-group>.custom-file:not(:last-child) .custom-file-label::after{border-top-right-radius:0;border-bottom-right-radius:0}.input-group>.custom-file:not(:first-child) .custom-file-label{border-top-left-radius:0;border-bottom-left-radius:0}.input-group-prepend,.input-group-append{display:-webkit-box;display:-ms-flexbox;display:flex}.input-group-prepend .btn,.input-group-append .btn{position:relative;z-index:2}.input-group-prepend .btn:focus,.input-group-append .btn:focus{z-index:3}.input-group-prepend .btn+.btn,.input-group-prepend .btn+.input-group-text,.input-group-prepend .input-group-text+.input-group-text,.input-group-prepend .input-group-text+.btn,.input-group-append .btn+.btn,.input-group-append .btn+.input-group-text,.input-group-append .input-group-text+.input-group-text,.input-group-append .input-group-text+.btn{margin-left:-1px}.input-group-prepend{margin-right:-1px}.input-group-append{margin-left:-1px}.input-group-text{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-align:center;-ms-flex-align:center;align-items:center;padding:0.375rem 0.75rem;margin-bottom:0;font-size:1rem;font-weight:400;line-height:1.5;color:#839496;text-align:center;white-space:nowrap;background-color:#073642;border:1px solid rgba(0,0,0,0.15);border-radius:0.25rem}.input-group-text input[type="radio"],.input-group-text input[type="checkbox"]{margin-top:0}.input-group-lg>.form-control:not(textarea),.input-group-lg>.custom-select{height:calc(1.5em + 1rem + 2px)}.input-group-lg>.form-control,.input-group-lg>.custom-select,.input-group-lg>.input-group-prepend>.input-group-text,.input-group-lg>.input-group-append>.input-group-text,.input-group-lg>.input-group-prepend>.btn,.input-group-lg>.input-group-append>.btn{padding:0.5rem 1rem;font-size:1.25rem;line-height:1.5;border-radius:0.3rem}.input-group-sm>.form-control:not(textarea),.input-group-sm>.custom-select{height:calc(1.5em + 0.5rem + 2px)}.input-group-sm>.form-control,.input-group-sm>.custom-select,.input-group-sm>.input-group-prepend>.input-group-text,.input-group-sm>.input-group-append>.input-group-text,.input-group-sm>.input-group-prepend>.btn,.input-group-sm>.input-group-append>.btn{padding:0.25rem 0.5rem;font-size:0.875rem;line-height:1.5;border-radius:0.2rem}.input-group-lg>.custom-select,.input-group-sm>.custom-select{padding-right:1.75rem}.input-group>.input-group-prepend>.btn,.input-group>.input-group-prepend>.input-group-text,.input-group>.input-group-append:not(:last-child)>.btn,.input-group>.input-group-append:not(:last-child)>.input-group-text,.input-group>.input-group-append:last-child>.btn:not(:last-child):not(.dropdown-toggle),.input-group>.input-group-append:last-child>.input-group-text:not(:last-child){border-top-right-radius:0;border-bottom-right-radius:0}.input-group>.input-group-append>.btn,.input-group>.input-group-append>.input-group-text,.input-group>.input-group-prepend:not(:first-child)>.btn,.input-group>.input-group-prepend:not(:first-child)>.input-group-text,.input-group>.input-group-prepend:first-child>.btn:not(:first-child),.input-group>.input-group-prepend:first-child>.input-group-text:not(:first-child){border-top-left-radius:0;border-bottom-left-radius:0}.custom-control{position:relative;display:block;min-height:1.5rem;padding-left:1.5rem}.custom-control-inline{display:-webkit-inline-box;display:-ms-inline-flexbox;display:inline-flex;margin-right:1rem}.custom-control-input{position:absolute;z-index:-1;opacity:0}.custom-control-input:checked ~ .custom-control-label::before{color:rgba(255,255,255,0.75);border-color:#073642;background:#073642 -webkit-gradient(linear, left top, left bottom, from(#063440), to(#073642)) repeat-x;background:#073642 linear-gradient(180deg, #063440, #073642) repeat-x}.custom-control-input:focus ~ .custom-control-label::before{-webkit-box-shadow:0 0 0 0.2rem rgba(7,54,66,0.25);box-shadow:0 0 0 0.2rem rgba(7,54,66,0.25)}.custom-control-input:focus:not(:checked) ~ .custom-control-label::before{border-color:#1394b5}.custom-control-input:not(:disabled):active ~ .custom-control-label::before{color:rgba(255,255,255,0.75);background-color:#18bae3;border-color:#18bae3}.custom-control-input:disabled ~ .custom-control-label{color:#839496}.custom-control-input:disabled ~ .custom-control-label::before{background-color:#657B83}.custom-control-label{position:relative;margin-bottom:0;vertical-align:top}.custom-control-label::before{position:absolute;top:0.25rem;left:-1.5rem;display:block;width:1rem;height:1rem;pointer-events:none;content:"";background-color:#A9BDBD;border:#adb5bd solid 1px}.custom-control-label::after{position:absolute;top:0.25rem;left:-1.5rem;display:block;width:1rem;height:1rem;content:"";background:no-repeat 50% / 50% 50%}.custom-checkbox .custom-control-label::before{border-radius:0.25rem}.custom-checkbox .custom-control-input:checked ~ .custom-control-label::after{background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 8 8'%3e%3cpath fill='rgba(255, 255, 255, 0.75)' d='M6.564.75l-3.59 3.612-1.538-1.55L0 4.26 2.974 7.25 8 2.193z'/%3e%3c/svg%3e")}.custom-checkbox .custom-control-input:indeterminate ~ .custom-control-label::before{border-color:#073642;background:#073642 -webkit-gradient(linear, left top, left bottom, from(#063440), to(#073642)) repeat-x;background:#073642 linear-gradient(180deg, #063440, #073642) repeat-x}.custom-checkbox .custom-control-input:indeterminate ~ .custom-control-label::after{background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 4 4'%3e%3cpath stroke='rgba(255, 255, 255, 0.75)' d='M0 2h4'/%3e%3c/svg%3e")}.custom-checkbox .custom-control-input:disabled:checked ~ .custom-control-label::before{background-color:rgba(181,137,0,0.5)}.custom-checkbox .custom-control-input:disabled:indeterminate ~ .custom-control-label::before{background-color:rgba(181,137,0,0.5)}.custom-radio .custom-control-label::before{border-radius:50%}.custom-radio .custom-control-input:checked ~ .custom-control-label::after{background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='-4 -4 8 8'%3e%3ccircle r='3' fill='rgba(255, 255, 255, 0.75)'/%3e%3c/svg%3e")}.custom-radio .custom-control-input:disabled:checked ~ .custom-control-label::before{background-color:rgba(181,137,0,0.5)}.custom-switch{padding-left:2.25rem}.custom-switch .custom-control-label::before{left:-2.25rem;width:1.75rem;pointer-events:all;border-radius:0.5rem}.custom-switch .custom-control-label::after{top:calc(0.25rem + 2px);left:calc(-2.25rem + 2px);width:calc(1rem - 4px);height:calc(1rem - 4px);background-color:#adb5bd;border-radius:0.5rem;-webkit-transition:background-color 0.15s ease-in-out, border-color 0.15s ease-in-out, -webkit-transform 0.15s ease-in-out, -webkit-box-shadow 0.15s ease-in-out;transition:background-color 0.15s ease-in-out, border-color 0.15s ease-in-out, -webkit-transform 0.15s ease-in-out, -webkit-box-shadow 0.15s ease-in-out;transition:transform 0.15s ease-in-out, background-color 0.15s ease-in-out, border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out;transition:transform 0.15s ease-in-out, background-color 0.15s ease-in-out, border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out, -webkit-transform 0.15s ease-in-out, -webkit-box-shadow 0.15s ease-in-out}@media (prefers-reduced-motion: reduce){.custom-switch .custom-control-label::after{-webkit-transition:none;transition:none}}.custom-switch .custom-control-input:checked ~ .custom-control-label::after{background-color:#A9BDBD;-webkit-transform:translateX(0.75rem);transform:translateX(0.75rem)}.custom-switch .custom-control-input:disabled:checked ~ .custom-control-label::before{background-color:rgba(181,137,0,0.5)}.custom-select{display:inline-block;width:100%;height:calc(1.5em + 0.75rem + 2px);padding:0.375rem 1.75rem 0.375rem 0.75rem;font-size:1rem;font-weight:400;line-height:1.5;color:#495057;vertical-align:middle;background:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 4 5'%3e%3cpath fill='%23073642' d='M2 0L0 2h4zm0 5L0 3h4z'/%3e%3c/svg%3e") no-repeat right 0.75rem center/8px 10px;background-color:#A9BDBD;border:1px solid rgba(0,0,0,0.15);border-radius:0.25rem;-webkit-appearance:none;-moz-appearance:none;appearance:none}.custom-select:focus{border-color:#1394b5;outline:0;-webkit-box-shadow:0 0 0 0.2rem rgba(7,54,66,0.25);box-shadow:0 0 0 0.2rem rgba(7,54,66,0.25)}.custom-select:focus::-ms-value{color:#495057;background-color:#A9BDBD}.custom-select[multiple],.custom-select[size]:not([size="1"]){height:auto;padding-right:0.75rem;background-image:none}.custom-select:disabled{color:#839496;background-color:#EEE8D5}.custom-select::-ms-expand{display:none}.custom-select-sm{height:calc(1.5em + 0.5rem + 2px);padding-top:0.25rem;padding-bottom:0.25rem;padding-left:0.5rem;font-size:0.875rem}.custom-select-lg{height:calc(1.5em + 1rem + 2px);padding-top:0.5rem;padding-bottom:0.5rem;padding-left:1rem;font-size:1.25rem}.custom-file{position:relative;display:inline-block;width:100%;height:calc(1.5em + 0.75rem + 2px);margin-bottom:0}.custom-file-input{position:relative;z-index:2;width:100%;height:calc(1.5em + 0.75rem + 2px);margin:0;opacity:0}.custom-file-input:focus ~ .custom-file-label{border-color:#1394b5;-webkit-box-shadow:0 0 0 0.2rem rgba(7,54,66,0.25);box-shadow:0 0 0 0.2rem rgba(7,54,66,0.25)}.custom-file-input:disabled ~ .custom-file-label{background-color:#657B83}.custom-file-input:lang(en) ~ .custom-file-label::after{content:"Browse"}.custom-file-input ~ .custom-file-label[data-browse]::after{content:attr(data-browse)}.custom-file-label{position:absolute;top:0;right:0;left:0;z-index:1;height:calc(1.5em + 0.75rem + 2px);padding:0.375rem 0.75rem;font-weight:400;line-height:1.5;color:#495057;background-color:#A9BDBD;border:1px solid rgba(0,0,0,0.15);border-radius:0.25rem}.custom-file-label::after{position:absolute;top:0;right:0;bottom:0;z-index:3;display:block;height:calc(1.5em + 0.75rem);padding:0.375rem 0.75rem;line-height:1.5;color:#495057;content:"Browse";background:#073642 -webkit-gradient(linear, left top, left bottom, from(#063440), to(#073642)) repeat-x;background:#073642 linear-gradient(180deg, #063440, #073642) repeat-x;border-left:inherit;border-radius:0 0.25rem 0.25rem 0}.custom-range{width:100%;height:calc(1rem + 0.4rem);padding:0;background-color:transparent;-webkit-appearance:none;-moz-appearance:none;appearance:none}.custom-range:focus{outline:none}.custom-range:focus::-webkit-slider-thumb{-webkit-box-shadow:0 0 0 1px #002B36,0 0 0 0.2rem rgba(7,54,66,0.25);box-shadow:0 0 0 1px #002B36,0 0 0 0.2rem rgba(7,54,66,0.25)}.custom-range:focus::-moz-range-thumb{box-shadow:0 0 0 1px #002B36,0 0 0 0.2rem rgba(7,54,66,0.25)}.custom-range:focus::-ms-thumb{box-shadow:0 0 0 1px #002B36,0 0 0 0.2rem rgba(7,54,66,0.25)}.custom-range::-moz-focus-outer{border:0}.custom-range::-webkit-slider-thumb{width:1rem;height:1rem;margin-top:-0.25rem;background:#073642 -webkit-gradient(linear, left top, left bottom, from(#063440), to(#073642)) repeat-x;background:#073642 linear-gradient(180deg, #063440, #073642) repeat-x;border:0;border-radius:1rem;-webkit-transition:background-color 0.15s ease-in-out, border-color 0.15s ease-in-out, -webkit-box-shadow 0.15s ease-in-out;transition:background-color 0.15s ease-in-out, border-color 0.15s ease-in-out, -webkit-box-shadow 0.15s ease-in-out;transition:background-color 0.15s ease-in-out, border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out;transition:background-color 0.15s ease-in-out, border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out, -webkit-box-shadow 0.15s ease-in-out;-webkit-appearance:none;appearance:none}@media (prefers-reduced-motion: reduce){.custom-range::-webkit-slider-thumb{-webkit-transition:none;transition:none}}.custom-range::-webkit-slider-thumb:active{background:#18bae3 -webkit-gradient(linear, left top, left bottom, from(#14a5c9), to(#18bae3)) repeat-x;background:#18bae3 linear-gradient(180deg, #14a5c9, #18bae3) repeat-x}.custom-range::-webkit-slider-runnable-track{width:100%;height:0.5rem;color:transparent;cursor:pointer;background-color:#dee2e6;border-color:transparent;border-radius:1rem}.custom-range::-moz-range-thumb{width:1rem;height:1rem;background:#073642 linear-gradient(180deg, #063440, #073642) repeat-x;border:0;border-radius:1rem;-webkit-transition:background-color 0.15s ease-in-out, border-color 0.15s ease-in-out, -webkit-box-shadow 0.15s ease-in-out;transition:background-color 0.15s ease-in-out, border-color 0.15s ease-in-out, -webkit-box-shadow 0.15s ease-in-out;transition:background-color 0.15s ease-in-out, border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out;transition:background-color 0.15s ease-in-out, border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out, -webkit-box-shadow 0.15s ease-in-out;-moz-appearance:none;appearance:none}@media (prefers-reduced-motion: reduce){.custom-range::-moz-range-thumb{-webkit-transition:none;transition:none}}.custom-range::-moz-range-thumb:active{background:#18bae3 linear-gradient(180deg, #14a5c9, #18bae3) repeat-x}.custom-range::-moz-range-track{width:100%;height:0.5rem;color:transparent;cursor:pointer;background-color:#dee2e6;border-color:transparent;border-radius:1rem}.custom-range::-ms-thumb{width:1rem;height:1rem;margin-top:0;margin-right:0.2rem;margin-left:0.2rem;background:#073642 linear-gradient(180deg, #063440, #073642) repeat-x;border:0;border-radius:1rem;-webkit-transition:background-color 0.15s ease-in-out, border-color 0.15s ease-in-out, -webkit-box-shadow 0.15s ease-in-out;transition:background-color 0.15s ease-in-out, border-color 0.15s ease-in-out, -webkit-box-shadow 0.15s ease-in-out;transition:background-color 0.15s ease-in-out, border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out;transition:background-color 0.15s ease-in-out, border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out, -webkit-box-shadow 0.15s ease-in-out;appearance:none}@media (prefers-reduced-motion: reduce){.custom-range::-ms-thumb{-webkit-transition:none;transition:none}}.custom-range::-ms-thumb:active{background:#18bae3 linear-gradient(180deg, #14a5c9, #18bae3) repeat-x}.custom-range::-ms-track{width:100%;height:0.5rem;color:transparent;cursor:pointer;background-color:transparent;border-color:transparent;border-width:0.5rem}.custom-range::-ms-fill-lower{background-color:#dee2e6;border-radius:1rem}.custom-range::-ms-fill-upper{margin-right:15px;background-color:#dee2e6;border-radius:1rem}.custom-range:disabled::-webkit-slider-thumb{background-color:#adb5bd}.custom-range:disabled::-webkit-slider-runnable-track{cursor:default}.custom-range:disabled::-moz-range-thumb{background-color:#adb5bd}.custom-range:disabled::-moz-range-track{cursor:default}.custom-range:disabled::-ms-thumb{background-color:#adb5bd}.custom-control-label::before,.custom-file-label,.custom-select{-webkit-transition:background-color 0.15s ease-in-out, border-color 0.15s ease-in-out, -webkit-box-shadow 0.15s ease-in-out;transition:background-color 0.15s ease-in-out, border-color 0.15s ease-in-out, -webkit-box-shadow 0.15s ease-in-out;transition:background-color 0.15s ease-in-out, border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out;transition:background-color 0.15s ease-in-out, border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out, -webkit-box-shadow 0.15s ease-in-out}@media (prefers-reduced-motion: reduce){.custom-control-label::before,.custom-file-label,.custom-select{-webkit-transition:none;transition:none}}.nav{display:-webkit-box;display:-ms-flexbox;display:flex;-ms-flex-wrap:wrap;flex-wrap:wrap;padding-left:0;margin-bottom:0;list-style:none}.nav-link{display:block;padding:0.5rem 1rem}.nav-link:hover,.nav-link:focus{text-decoration:none}.nav-link.disabled{color:#839496;pointer-events:none;cursor:default}.nav-tabs{border-bottom:1px solid #073642}.nav-tabs .nav-item{margin-bottom:-1px}.nav-tabs .nav-link{border:1px solid transparent;border-top-left-radius:0.25rem;border-top-right-radius:0.25rem}.nav-tabs .nav-link:hover,.nav-tabs .nav-link:focus{border-color:#073642}.nav-tabs .nav-link.disabled{color:#839496;background-color:transparent;border-color:transparent}.nav-tabs .nav-link.active,.nav-tabs .nav-item.show .nav-link{color:rgba(255,255,255,0.75);background-color:#002B36;border-color:#073642}.nav-tabs .dropdown-menu{margin-top:-1px;border-top-left-radius:0;border-top-right-radius:0}.nav-pills .nav-link{border-radius:0.25rem}.nav-pills .nav-link.active,.nav-pills .show>.nav-link{color:rgba(255,255,255,0.75);background-color:#073642}.nav-fill .nav-item{-webkit-box-flex:1;-ms-flex:1 1 auto;flex:1 1 auto;text-align:center}.nav-justified .nav-item{-ms-flex-preferred-size:0;flex-basis:0;-webkit-box-flex:1;-ms-flex-positive:1;flex-grow:1;text-align:center}.tab-content>.tab-pane{display:none}.tab-content>.active{display:block}.navbar{position:relative;display:-webkit-box;display:-ms-flexbox;display:flex;-ms-flex-wrap:wrap;flex-wrap:wrap;-webkit-box-align:center;-ms-flex-align:center;align-items:center;-webkit-box-pack:justify;-ms-flex-pack:justify;justify-content:space-between;padding:0.5rem 1rem}.navbar>.container,.navbar>.container-fluid{display:-webkit-box;display:-ms-flexbox;display:flex;-ms-flex-wrap:wrap;flex-wrap:wrap;-webkit-box-align:center;-ms-flex-align:center;align-items:center;-webkit-box-pack:justify;-ms-flex-pack:justify;justify-content:space-between}.navbar-brand{display:inline-block;padding-top:0.3125rem;padding-bottom:0.3125rem;margin-right:1rem;font-size:1.25rem;line-height:inherit;white-space:nowrap}.navbar-brand:hover,.navbar-brand:focus{text-decoration:none}.navbar-nav{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;flex-direction:column;padding-left:0;margin-bottom:0;list-style:none}.navbar-nav .nav-link{padding-right:0;padding-left:0}.navbar-nav .dropdown-menu{position:static;float:none}.navbar-text{display:inline-block;padding-top:0.5rem;padding-bottom:0.5rem}.navbar-collapse{-ms-flex-preferred-size:100%;flex-basis:100%;-webkit-box-flex:1;-ms-flex-positive:1;flex-grow:1;-webkit-box-align:center;-ms-flex-align:center;align-items:center}.navbar-toggler{padding:0.25rem 0.75rem;font-size:1.25rem;line-height:1;background-color:transparent;border:1px solid transparent;border-radius:0.25rem}.navbar-toggler:hover,.navbar-toggler:focus{text-decoration:none}.navbar-toggler-icon{display:inline-block;width:1.5em;height:1.5em;vertical-align:middle;content:"";background:no-repeat center center;background-size:100% 100%}@media (max-width: 575.98px){.navbar-expand-sm>.container,.navbar-expand-sm>.container-fluid{padding-right:0;padding-left:0}}@media (min-width: 576px){.navbar-expand-sm{-webkit-box-orient:horizontal;-webkit-box-direction:normal;-ms-flex-flow:row nowrap;flex-flow:row nowrap;-webkit-box-pack:start;-ms-flex-pack:start;justify-content:flex-start}.navbar-expand-sm .navbar-nav{-webkit-box-orient:horizontal;-webkit-box-direction:normal;-ms-flex-direction:row;flex-direction:row}.navbar-expand-sm .navbar-nav .dropdown-menu{position:absolute}.navbar-expand-sm .navbar-nav .nav-link{padding-right:0.5rem;padding-left:0.5rem}.navbar-expand-sm>.container,.navbar-expand-sm>.container-fluid{-ms-flex-wrap:nowrap;flex-wrap:nowrap}.navbar-expand-sm .navbar-collapse{display:-webkit-box !important;display:-ms-flexbox !important;display:flex !important;-ms-flex-preferred-size:auto;flex-basis:auto}.navbar-expand-sm .navbar-toggler{display:none}}@media (max-width: 767.98px){.navbar-expand-md>.container,.navbar-expand-md>.container-fluid{padding-right:0;padding-left:0}}@media (min-width: 768px){.navbar-expand-md{-webkit-box-orient:horizontal;-webkit-box-direction:normal;-ms-flex-flow:row nowrap;flex-flow:row nowrap;-webkit-box-pack:start;-ms-flex-pack:start;justify-content:flex-start}.navbar-expand-md .navbar-nav{-webkit-box-orient:horizontal;-webkit-box-direction:normal;-ms-flex-direction:row;flex-direction:row}.navbar-expand-md .navbar-nav .dropdown-menu{position:absolute}.navbar-expand-md .navbar-nav .nav-link{padding-right:0.5rem;padding-left:0.5rem}.navbar-expand-md>.container,.navbar-expand-md>.container-fluid{-ms-flex-wrap:nowrap;flex-wrap:nowrap}.navbar-expand-md .navbar-collapse{display:-webkit-box !important;display:-ms-flexbox !important;display:flex !important;-ms-flex-preferred-size:auto;flex-basis:auto}.navbar-expand-md .navbar-toggler{display:none}}@media (max-width: 991.98px){.navbar-expand-lg>.container,.navbar-expand-lg>.container-fluid{padding-right:0;padding-left:0}}@media (min-width: 992px){.navbar-expand-lg{-webkit-box-orient:horizontal;-webkit-box-direction:normal;-ms-flex-flow:row nowrap;flex-flow:row nowrap;-webkit-box-pack:start;-ms-flex-pack:start;justify-content:flex-start}.navbar-expand-lg .navbar-nav{-webkit-box-orient:horizontal;-webkit-box-direction:normal;-ms-flex-direction:row;flex-direction:row}.navbar-expand-lg .navbar-nav .dropdown-menu{position:absolute}.navbar-expand-lg .navbar-nav .nav-link{padding-right:0.5rem;padding-left:0.5rem}.navbar-expand-lg>.container,.navbar-expand-lg>.container-fluid{-ms-flex-wrap:nowrap;flex-wrap:nowrap}.navbar-expand-lg .navbar-collapse{display:-webkit-box !important;display:-ms-flexbox !important;display:flex !important;-ms-flex-preferred-size:auto;flex-basis:auto}.navbar-expand-lg .navbar-toggler{display:none}}@media (max-width: 1199.98px){.navbar-expand-xl>.container,.navbar-expand-xl>.container-fluid{padding-right:0;padding-left:0}}@media (min-width: 1200px){.navbar-expand-xl{-webkit-box-orient:horizontal;-webkit-box-direction:normal;-ms-flex-flow:row nowrap;flex-flow:row nowrap;-webkit-box-pack:start;-ms-flex-pack:start;justify-content:flex-start}.navbar-expand-xl .navbar-nav{-webkit-box-orient:horizontal;-webkit-box-direction:normal;-ms-flex-direction:row;flex-direction:row}.navbar-expand-xl .navbar-nav .dropdown-menu{position:absolute}.navbar-expand-xl .navbar-nav .nav-link{padding-right:0.5rem;padding-left:0.5rem}.navbar-expand-xl>.container,.navbar-expand-xl>.container-fluid{-ms-flex-wrap:nowrap;flex-wrap:nowrap}.navbar-expand-xl .navbar-collapse{display:-webkit-box !important;display:-ms-flexbox !important;display:flex !important;-ms-flex-preferred-size:auto;flex-basis:auto}.navbar-expand-xl .navbar-toggler{display:none}}.navbar-expand{-webkit-box-orient:horizontal;-webkit-box-direction:normal;-ms-flex-flow:row nowrap;flex-flow:row nowrap;-webkit-box-pack:start;-ms-flex-pack:start;justify-content:flex-start}.navbar-expand>.container,.navbar-expand>.container-fluid{padding-right:0;padding-left:0}.navbar-expand .navbar-nav{-webkit-box-orient:horizontal;-webkit-box-direction:normal;-ms-flex-direction:row;flex-direction:row}.navbar-expand .navbar-nav .dropdown-menu{position:absolute}.navbar-expand .navbar-nav .nav-link{padding-right:0.5rem;padding-left:0.5rem}.navbar-expand>.container,.navbar-expand>.container-fluid{-ms-flex-wrap:nowrap;flex-wrap:nowrap}.navbar-expand .navbar-collapse{display:-webkit-box !important;display:-ms-flexbox !important;display:flex !important;-ms-flex-preferred-size:auto;flex-basis:auto}.navbar-expand .navbar-toggler{display:none}.navbar-light .navbar-brand{color:rgba(0,0,0,0.7)}.navbar-light .navbar-brand:hover,.navbar-light .navbar-brand:focus{color:rgba(0,0,0,0.7)}.navbar-light .navbar-nav .nav-link{color:rgba(0,0,0,0.4)}.navbar-light .navbar-nav .nav-link:hover,.navbar-light .navbar-nav .nav-link:focus{color:rgba(0,0,0,0.7)}.navbar-light .navbar-nav .nav-link.disabled{color:rgba(0,0,0,0.3)}.navbar-light .navbar-nav .show>.nav-link,.navbar-light .navbar-nav .active>.nav-link,.navbar-light .navbar-nav .nav-link.show,.navbar-light .navbar-nav .nav-link.active{color:rgba(0,0,0,0.7)}.navbar-light .navbar-toggler{color:rgba(0,0,0,0.4);border-color:rgba(0,0,0,0.1)}.navbar-light .navbar-toggler-icon{background-image:url("data:image/svg+xml,%3csvg viewBox='0 0 30 30' xmlns='http://www.w3.org/2000/svg'%3e%3cpath stroke='rgba(0, 0, 0, 0.4)' stroke-width='2' stroke-linecap='round' stroke-miterlimit='10' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e")}.navbar-light .navbar-text{color:rgba(0,0,0,0.4)}.navbar-light .navbar-text a{color:rgba(0,0,0,0.7)}.navbar-light .navbar-text a:hover,.navbar-light .navbar-text a:focus{color:rgba(0,0,0,0.7)}.navbar-dark .navbar-brand{color:#fff}.navbar-dark .navbar-brand:hover,.navbar-dark .navbar-brand:focus{color:#fff}.navbar-dark .navbar-nav .nav-link{color:rgba(255,255,255,0.5)}.navbar-dark .navbar-nav .nav-link:hover,.navbar-dark .navbar-nav .nav-link:focus{color:rgba(255,255,255,0.75)}.navbar-dark .navbar-nav .nav-link.disabled{color:rgba(255,255,255,0.25)}.navbar-dark .navbar-nav .show>.nav-link,.navbar-dark .navbar-nav .active>.nav-link,.navbar-dark .navbar-nav .nav-link.show,.navbar-dark .navbar-nav .nav-link.active{color:#fff}.navbar-dark .navbar-toggler{color:rgba(255,255,255,0.5);border-color:rgba(255,255,255,0.1)}.navbar-dark .navbar-toggler-icon{background-image:url("data:image/svg+xml,%3csvg viewBox='0 0 30 30' xmlns='http://www.w3.org/2000/svg'%3e%3cpath stroke='rgba(255, 255, 255, 0.5)' stroke-width='2' stroke-linecap='round' stroke-miterlimit='10' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e")}.navbar-dark .navbar-text{color:rgba(255,255,255,0.5)}.navbar-dark .navbar-text a{color:#fff}.navbar-dark .navbar-text a:hover,.navbar-dark .navbar-text a:focus{color:#fff}.card{position:relative;display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;flex-direction:column;min-width:0;word-wrap:break-word;background-color:rgba(238,232,213,0.125);background-clip:border-box;border:1px solid rgba(0,43,54,0.95);border-radius:0.25rem}.card>hr{margin-right:0;margin-left:0}.card>.list-group:first-child .list-group-item:first-child{border-top-left-radius:0.25rem;border-top-right-radius:0.25rem}.card>.list-group:last-child .list-group-item:last-child{border-bottom-right-radius:0.25rem;border-bottom-left-radius:0.25rem}.card-body{-webkit-box-flex:1;-ms-flex:1 1 auto;flex:1 1 auto;padding:1.25rem}.card-title{margin-bottom:0.75rem}.card-subtitle{margin-top:-0.375rem;margin-bottom:0}.card-text:last-child{margin-bottom:0}.card-link:hover{text-decoration:none}.card-link+.card-link{margin-left:1.25rem}.card-header{padding:0.75rem 1.25rem;margin-bottom:0;background-color:rgba(7,54,66,0.25);border-bottom:1px solid rgba(0,43,54,0.95)}.card-header:first-child{border-radius:calc(0.25rem - 1px) calc(0.25rem - 1px) 0 0}.card-header+.list-group .list-group-item:first-child{border-top:0}.card-footer{padding:0.75rem 1.25rem;background-color:rgba(7,54,66,0.25);border-top:1px solid rgba(0,43,54,0.95)}.card-footer:last-child{border-radius:0 0 calc(0.25rem - 1px) calc(0.25rem - 1px)}.card-header-tabs{margin-right:-0.625rem;margin-bottom:-0.75rem;margin-left:-0.625rem;border-bottom:0}.card-header-pills{margin-right:-0.625rem;margin-left:-0.625rem}.card-img-overlay{position:absolute;top:0;right:0;bottom:0;left:0;padding:1.25rem}.card-img{width:100%;border-radius:calc(0.25rem - 1px)}.card-img-top{width:100%;border-top-left-radius:calc(0.25rem - 1px);border-top-right-radius:calc(0.25rem - 1px)}.card-img-bottom{width:100%;border-bottom-right-radius:calc(0.25rem - 1px);border-bottom-left-radius:calc(0.25rem - 1px)}.card-deck{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;flex-direction:column}.card-deck .card{margin-bottom:15px}@media (min-width: 576px){.card-deck{-webkit-box-orient:horizontal;-webkit-box-direction:normal;-ms-flex-flow:row wrap;flex-flow:row wrap;margin-right:-15px;margin-left:-15px}.card-deck .card{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-flex:1;-ms-flex:1 0 0%;flex:1 0 0%;-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;flex-direction:column;margin-right:15px;margin-bottom:0;margin-left:15px}}.card-group{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;flex-direction:column}.card-group>.card{margin-bottom:15px}@media (min-width: 576px){.card-group{-webkit-box-orient:horizontal;-webkit-box-direction:normal;-ms-flex-flow:row wrap;flex-flow:row wrap}.card-group>.card{-webkit-box-flex:1;-ms-flex:1 0 0%;flex:1 0 0%;margin-bottom:0}.card-group>.card+.card{margin-left:0;border-left:0}.card-group>.card:not(:last-child){border-top-right-radius:0;border-bottom-right-radius:0}.card-group>.card:not(:last-child) .card-img-top,.card-group>.card:not(:last-child) .card-header{border-top-right-radius:0}.card-group>.card:not(:last-child) .card-img-bottom,.card-group>.card:not(:last-child) .card-footer{border-bottom-right-radius:0}.card-group>.card:not(:first-child){border-top-left-radius:0;border-bottom-left-radius:0}.card-group>.card:not(:first-child) .card-img-top,.card-group>.card:not(:first-child) .card-header{border-top-left-radius:0}.card-group>.card:not(:first-child) .card-img-bottom,.card-group>.card:not(:first-child) .card-footer{border-bottom-left-radius:0}}.card-columns .card{margin-bottom:0.75rem}@media (min-width: 576px){.card-columns{-webkit-column-count:3;column-count:3;-webkit-column-gap:1.25rem;column-gap:1.25rem;orphans:1;widows:1}.card-columns .card{display:inline-block;width:100%}}.accordion>.card{overflow:hidden}.accordion>.card:not(:first-of-type) .card-header:first-child{border-radius:0}.accordion>.card:not(:first-of-type):not(:last-of-type){border-bottom:0;border-radius:0}.accordion>.card:first-of-type{border-bottom:0;border-bottom-right-radius:0;border-bottom-left-radius:0}.accordion>.card:last-of-type{border-top-left-radius:0;border-top-right-radius:0}.accordion>.card .card-header{margin-bottom:-1px}.breadcrumb{display:-webkit-box;display:-ms-flexbox;display:flex;-ms-flex-wrap:wrap;flex-wrap:wrap;padding:0.75rem 1rem;margin-bottom:1rem;list-style:none;background-color:#073642;border-radius:0.25rem}.breadcrumb-item+.breadcrumb-item{padding-left:0.5rem}.breadcrumb-item+.breadcrumb-item::before{display:inline-block;padding-right:0.5rem;color:#839496;content:"/"}.breadcrumb-item+.breadcrumb-item:hover::before{text-decoration:underline}.breadcrumb-item+.breadcrumb-item:hover::before{text-decoration:none}.breadcrumb-item.active{color:#839496}.pagination{display:-webkit-box;display:-ms-flexbox;display:flex;padding-left:0;list-style:none;border-radius:0.25rem}.page-link{position:relative;display:block;padding:0.5rem 0.75rem;margin-left:-1px;line-height:1.25;color:#2AA198;background-color:transparent;border:1px solid #073642}.page-link:hover{z-index:2;color:#2AA198;text-decoration:none;background-color:#073642;border-color:#073642}.page-link:focus{z-index:2;outline:0;-webkit-box-shadow:0 0 0 0.2rem rgba(7,54,66,0.25);box-shadow:0 0 0 0.2rem rgba(7,54,66,0.25)}.page-item:first-child .page-link{margin-left:0;border-top-left-radius:0.25rem;border-bottom-left-radius:0.25rem}.page-item:last-child .page-link{border-top-right-radius:0.25rem;border-bottom-right-radius:0.25rem}.page-item.active .page-link{z-index:1;color:rgba(255,255,255,0.75);background-color:#073642;border-color:#073642}.page-item.disabled .page-link{color:#073642;pointer-events:none;cursor:auto;background-color:transparent;border-color:#073642}.pagination-lg .page-link{padding:0.75rem 1.5rem;font-size:1.25rem;line-height:1.5}.pagination-lg .page-item:first-child .page-link{border-top-left-radius:0.3rem;border-bottom-left-radius:0.3rem}.pagination-lg .page-item:last-child .page-link{border-top-right-radius:0.3rem;border-bottom-right-radius:0.3rem}.pagination-sm .page-link{padding:0.25rem 0.5rem;font-size:0.875rem;line-height:1.5}.pagination-sm .page-item:first-child .page-link{border-top-left-radius:0.2rem;border-bottom-left-radius:0.2rem}.pagination-sm .page-item:last-child .page-link{border-top-right-radius:0.2rem;border-bottom-right-radius:0.2rem}.badge{display:inline-block;padding:0.25em 0.4em;font-size:75%;font-weight:700;line-height:1;text-align:center;white-space:nowrap;vertical-align:baseline;border-radius:0.25rem;-webkit-transition:color 0.15s ease-in-out, background-color 0.15s ease-in-out, border-color 0.15s ease-in-out, -webkit-box-shadow 0.15s ease-in-out;transition:color 0.15s ease-in-out, background-color 0.15s ease-in-out, border-color 0.15s ease-in-out, -webkit-box-shadow 0.15s ease-in-out;transition:color 0.15s ease-in-out, background-color 0.15s ease-in-out, border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out;transition:color 0.15s ease-in-out, background-color 0.15s ease-in-out, border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out, -webkit-box-shadow 0.15s ease-in-out}@media (prefers-reduced-motion: reduce){.badge{-webkit-transition:none;transition:none}}a.badge:hover,a.badge:focus{text-decoration:none}.badge:empty{display:none}.btn .badge{position:relative;top:-1px}.badge-pill{padding-right:0.6em;padding-left:0.6em;border-radius:10rem}.badge-primary{color:#fff;background-color:#B58900}a.badge-primary:hover,a.badge-primary:focus{color:#fff;background-color:#826200}a.badge-primary:focus,a.badge-primary.focus{outline:0;-webkit-box-shadow:0 0 0 0.2rem rgba(181,137,0,0.5);box-shadow:0 0 0 0.2rem rgba(181,137,0,0.5)}.badge-secondary{color:#fff;background-color:#839496}a.badge-secondary:hover,a.badge-secondary:focus{color:#fff;background-color:#697b7d}a.badge-secondary:focus,a.badge-secondary.focus{outline:0;-webkit-box-shadow:0 0 0 0.2rem rgba(131,148,150,0.5);box-shadow:0 0 0 0.2rem rgba(131,148,150,0.5)}.badge-success{color:#fff;background-color:#2AA198}a.badge-success:hover,a.badge-success:focus{color:#fff;background-color:#1f7972}a.badge-success:focus,a.badge-success.focus{outline:0;-webkit-box-shadow:0 0 0 0.2rem rgba(42,161,152,0.5);box-shadow:0 0 0 0.2rem rgba(42,161,152,0.5)}.badge-info{color:#fff;background-color:#268BD2}a.badge-info:hover,a.badge-info:focus{color:#fff;background-color:#1e6ea7}a.badge-info:focus,a.badge-info.focus{outline:0;-webkit-box-shadow:0 0 0 0.2rem rgba(38,139,210,0.5);box-shadow:0 0 0 0.2rem rgba(38,139,210,0.5)}.badge-warning{color:#fff;background-color:#CB4B16}a.badge-warning:hover,a.badge-warning:focus{color:#fff;background-color:#9d3a11}a.badge-warning:focus,a.badge-warning.focus{outline:0;-webkit-box-shadow:0 0 0 0.2rem rgba(203,75,22,0.5);box-shadow:0 0 0 0.2rem rgba(203,75,22,0.5)}.badge-danger{color:#fff;background-color:#D33682}a.badge-danger:hover,a.badge-danger:focus{color:#fff;background-color:#b02669}a.badge-danger:focus,a.badge-danger.focus{outline:0;-webkit-box-shadow:0 0 0 0.2rem rgba(211,54,130,0.5);box-shadow:0 0 0 0.2rem rgba(211,54,130,0.5)}.badge-light{color:#002B36;background-color:#FDF6E3}a.badge-light:hover,a.badge-light:focus{color:#002B36;background-color:#fae7b3}a.badge-light:focus,a.badge-light.focus{outline:0;-webkit-box-shadow:0 0 0 0.2rem rgba(253,246,227,0.5);box-shadow:0 0 0 0.2rem rgba(253,246,227,0.5)}.badge-dark{color:#fff;background-color:#073642}a.badge-dark:hover,a.badge-dark:focus{color:#fff;background-color:#021014}a.badge-dark:focus,a.badge-dark.focus{outline:0;-webkit-box-shadow:0 0 0 0.2rem rgba(7,54,66,0.5);box-shadow:0 0 0 0.2rem rgba(7,54,66,0.5)}.jumbotron{padding:2rem 1rem;margin-bottom:2rem;background-color:#073642;border-radius:0.3rem}@media (min-width: 576px){.jumbotron{padding:4rem 2rem}}.jumbotron-fluid{padding-right:0;padding-left:0;border-radius:0}.alert{position:relative;padding:0.75rem 1.25rem;margin-bottom:1rem;border:1px solid transparent;border-radius:0.25rem}.alert-heading{color:inherit}.alert-link{font-weight:700}.alert-dismissible{padding-right:4rem}.alert-dismissible .close{position:absolute;top:0;right:0;padding:0.75rem 1.25rem;color:inherit}.alert-primary{color:#5e4700;background:#f0e7cc -webkit-gradient(linear, left top, left bottom, from(#cccbb6), to(#f0e7cc)) repeat-x;background:#f0e7cc linear-gradient(180deg, #cccbb6, #f0e7cc) repeat-x;border-color:#eadeb8}.alert-primary hr{border-top-color:#e4d5a4}.alert-primary .alert-link{color:#2b2000}.alert-secondary{color:#444d4e;background:#e6eaea -webkit-gradient(linear, left top, left bottom, from(#c4cdcf), to(#e6eaea)) repeat-x;background:#e6eaea linear-gradient(180deg, #c4cdcf, #e6eaea) repeat-x;border-color:#dce1e2}.alert-secondary hr{border-top-color:#ced5d6}.alert-secondary .alert-link{color:#2c3233}.alert-success{color:#16544f;background:#d4ecea -webkit-gradient(linear, left top, left bottom, from(#b4cfcf), to(#d4ecea)) repeat-x;background:#d4ecea linear-gradient(180deg, #b4cfcf, #d4ecea) repeat-x;border-color:#c3e5e2}.alert-success hr{border-top-color:#b1ddd9}.alert-success .alert-link{color:#0b2c29}.alert-info{color:#14486d;background:#d4e8f6 -webkit-gradient(linear, left top, left bottom, from(#b4ccd9), to(#d4e8f6)) repeat-x;background:#d4e8f6 linear-gradient(180deg, #b4ccd9, #d4e8f6) repeat-x;border-color:#c2dff2}.alert-info hr{border-top-color:#add4ee}.alert-info .alert-link{color:#0c2c42}.alert-warning{color:#6a270b;background:#f5dbd0 -webkit-gradient(linear, left top, left bottom, from(#d0c1b9), to(#f5dbd0)) repeat-x;background:#f5dbd0 linear-gradient(180deg, #d0c1b9, #f5dbd0) repeat-x;border-color:#f0cdbe}.alert-warning hr{border-top-color:#ebbda9}.alert-warning .alert-link{color:#3c1606}.alert-danger{color:#6e1c44;background:#f6d7e6 -webkit-gradient(linear, left top, left bottom, from(#d1bdcc), to(#f6d7e6)) repeat-x;background:#f6d7e6 linear-gradient(180deg, #d1bdcc, #f6d7e6) repeat-x;border-color:#f3c7dc}.alert-danger hr{border-top-color:#efb2cf}.alert-danger .alert-link{color:#45122b}.alert-light{color:#848076;background:#fffdf9 -webkit-gradient(linear, left top, left bottom, from(#d9dedc), to(#fffdf9)) repeat-x;background:#fffdf9 linear-gradient(180deg, #d9dedc, #fffdf9) repeat-x;border-color:#fefcf7}.alert-light hr{border-top-color:#fbf4e0}.alert-light .alert-link{color:#69665e}.alert-dark{color:#041c22;background:#cdd7d9 -webkit-gradient(linear, left top, left bottom, from(#aebdc1), to(#cdd7d9)) repeat-x;background:#cdd7d9 linear-gradient(180deg, #aebdc1, #cdd7d9) repeat-x;border-color:#bac7ca}.alert-dark hr{border-top-color:#acbbbf}.alert-dark .alert-link{color:black}@-webkit-keyframes progress-bar-stripes{from{background-position:1rem 0}to{background-position:0 0}}@keyframes progress-bar-stripes{from{background-position:1rem 0}to{background-position:0 0}}.progress{display:-webkit-box;display:-ms-flexbox;display:flex;height:1rem;overflow:hidden;font-size:0.75rem;background-color:#073642;border-radius:0.25rem}.progress-bar{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;flex-direction:column;-webkit-box-pack:center;-ms-flex-pack:center;justify-content:center;color:#B58900;text-align:center;white-space:nowrap;background-color:#B58900;-webkit-transition:width 0.6s ease;transition:width 0.6s ease}@media (prefers-reduced-motion: reduce){.progress-bar{-webkit-transition:none;transition:none}}.progress-bar-striped{background-image:linear-gradient(45deg, rgba(255,255,255,0.15) 25%, transparent 25%, transparent 50%, rgba(255,255,255,0.15) 50%, rgba(255,255,255,0.15) 75%, transparent 75%, transparent);background-size:1rem 1rem}.progress-bar-animated{-webkit-animation:progress-bar-stripes 1s linear infinite;animation:progress-bar-stripes 1s linear infinite}@media (prefers-reduced-motion: reduce){.progress-bar-animated{-webkit-animation:none;animation:none}}.media{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-align:start;-ms-flex-align:start;align-items:flex-start}.media-body{-webkit-box-flex:1;-ms-flex:1;flex:1}.list-group{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;flex-direction:column;padding-left:0;margin-bottom:0}.list-group-item-action{width:100%;color:#839496;text-align:inherit}.list-group-item-action:hover,.list-group-item-action:focus{z-index:1;color:rgba(255,255,255,0.75);text-decoration:none;background-color:#073642}.list-group-item-action:active{color:#839496;background-color:#EEE8D5}.list-group-item{position:relative;display:block;padding:0.75rem 1.25rem;margin-bottom:-1px;background-color:transparent;border:1px solid #073642}.list-group-item:first-child{border-top-left-radius:0.25rem;border-top-right-radius:0.25rem}.list-group-item:last-child{margin-bottom:0;border-bottom-right-radius:0.25rem;border-bottom-left-radius:0.25rem}.list-group-item.disabled,.list-group-item:disabled{color:#073642;pointer-events:none;background-color:transparent}.list-group-item.active{z-index:2;color:rgba(255,255,255,0.75);background-color:#073642;border-color:#073642}.list-group-horizontal{-webkit-box-orient:horizontal;-webkit-box-direction:normal;-ms-flex-direction:row;flex-direction:row}.list-group-horizontal .list-group-item{margin-right:-1px;margin-bottom:0}.list-group-horizontal .list-group-item:first-child{border-top-left-radius:0.25rem;border-bottom-left-radius:0.25rem;border-top-right-radius:0}.list-group-horizontal .list-group-item:last-child{margin-right:0;border-top-right-radius:0.25rem;border-bottom-right-radius:0.25rem;border-bottom-left-radius:0}@media (min-width: 576px){.list-group-horizontal-sm{-webkit-box-orient:horizontal;-webkit-box-direction:normal;-ms-flex-direction:row;flex-direction:row}.list-group-horizontal-sm .list-group-item{margin-right:-1px;margin-bottom:0}.list-group-horizontal-sm .list-group-item:first-child{border-top-left-radius:0.25rem;border-bottom-left-radius:0.25rem;border-top-right-radius:0}.list-group-horizontal-sm .list-group-item:last-child{margin-right:0;border-top-right-radius:0.25rem;border-bottom-right-radius:0.25rem;border-bottom-left-radius:0}}@media (min-width: 768px){.list-group-horizontal-md{-webkit-box-orient:horizontal;-webkit-box-direction:normal;-ms-flex-direction:row;flex-direction:row}.list-group-horizontal-md .list-group-item{margin-right:-1px;margin-bottom:0}.list-group-horizontal-md .list-group-item:first-child{border-top-left-radius:0.25rem;border-bottom-left-radius:0.25rem;border-top-right-radius:0}.list-group-horizontal-md .list-group-item:last-child{margin-right:0;border-top-right-radius:0.25rem;border-bottom-right-radius:0.25rem;border-bottom-left-radius:0}}@media (min-width: 992px){.list-group-horizontal-lg{-webkit-box-orient:horizontal;-webkit-box-direction:normal;-ms-flex-direction:row;flex-direction:row}.list-group-horizontal-lg .list-group-item{margin-right:-1px;margin-bottom:0}.list-group-horizontal-lg .list-group-item:first-child{border-top-left-radius:0.25rem;border-bottom-left-radius:0.25rem;border-top-right-radius:0}.list-group-horizontal-lg .list-group-item:last-child{margin-right:0;border-top-right-radius:0.25rem;border-bottom-right-radius:0.25rem;border-bottom-left-radius:0}}@media (min-width: 1200px){.list-group-horizontal-xl{-webkit-box-orient:horizontal;-webkit-box-direction:normal;-ms-flex-direction:row;flex-direction:row}.list-group-horizontal-xl .list-group-item{margin-right:-1px;margin-bottom:0}.list-group-horizontal-xl .list-group-item:first-child{border-top-left-radius:0.25rem;border-bottom-left-radius:0.25rem;border-top-right-radius:0}.list-group-horizontal-xl .list-group-item:last-child{margin-right:0;border-top-right-radius:0.25rem;border-bottom-right-radius:0.25rem;border-bottom-left-radius:0}}.list-group-flush .list-group-item{border-right:0;border-left:0;border-radius:0}.list-group-flush .list-group-item:last-child{margin-bottom:-1px}.list-group-flush:first-child .list-group-item:first-child{border-top:0}.list-group-flush:last-child .list-group-item:last-child{margin-bottom:0;border-bottom:0}.list-group-item-primary{color:#5e4700;background-color:#eadeb8}.list-group-item-primary.list-group-item-action:hover,.list-group-item-primary.list-group-item-action:focus{color:#5e4700;background-color:#e4d5a4}.list-group-item-primary.list-group-item-action.active{color:#fff;background-color:#5e4700;border-color:#5e4700}.list-group-item-secondary{color:#444d4e;background-color:#dce1e2}.list-group-item-secondary.list-group-item-action:hover,.list-group-item-secondary.list-group-item-action:focus{color:#444d4e;background-color:#ced5d6}.list-group-item-secondary.list-group-item-action.active{color:#fff;background-color:#444d4e;border-color:#444d4e}.list-group-item-success{color:#16544f;background-color:#c3e5e2}.list-group-item-success.list-group-item-action:hover,.list-group-item-success.list-group-item-action:focus{color:#16544f;background-color:#b1ddd9}.list-group-item-success.list-group-item-action.active{color:#fff;background-color:#16544f;border-color:#16544f}.list-group-item-info{color:#14486d;background-color:#c2dff2}.list-group-item-info.list-group-item-action:hover,.list-group-item-info.list-group-item-action:focus{color:#14486d;background-color:#add4ee}.list-group-item-info.list-group-item-action.active{color:#fff;background-color:#14486d;border-color:#14486d}.list-group-item-warning{color:#6a270b;background-color:#f0cdbe}.list-group-item-warning.list-group-item-action:hover,.list-group-item-warning.list-group-item-action:focus{color:#6a270b;background-color:#ebbda9}.list-group-item-warning.list-group-item-action.active{color:#fff;background-color:#6a270b;border-color:#6a270b}.list-group-item-danger{color:#6e1c44;background-color:#f3c7dc}.list-group-item-danger.list-group-item-action:hover,.list-group-item-danger.list-group-item-action:focus{color:#6e1c44;background-color:#efb2cf}.list-group-item-danger.list-group-item-action.active{color:#fff;background-color:#6e1c44;border-color:#6e1c44}.list-group-item-light{color:#848076;background-color:#fefcf7}.list-group-item-light.list-group-item-action:hover,.list-group-item-light.list-group-item-action:focus{color:#848076;background-color:#fbf4e0}.list-group-item-light.list-group-item-action.active{color:#fff;background-color:#848076;border-color:#848076}.list-group-item-dark{color:#041c22;background-color:#bac7ca}.list-group-item-dark.list-group-item-action:hover,.list-group-item-dark.list-group-item-action:focus{color:#041c22;background-color:#acbbbf}.list-group-item-dark.list-group-item-action.active{color:#fff;background-color:#041c22;border-color:#041c22}.close{float:right;font-size:1.5rem;font-weight:700;line-height:1;color:#839496;text-shadow:none;opacity:.5}.close:hover{color:#839496;text-decoration:none}.close:not(:disabled):not(.disabled):hover,.close:not(:disabled):not(.disabled):focus{opacity:.75}button.close{padding:0;background-color:transparent;border:0;-webkit-appearance:none;-moz-appearance:none;appearance:none}a.close.disabled{pointer-events:none}.toast{max-width:350px;overflow:hidden;font-size:0.875rem;background-color:rgba(255,255,255,0.85);background-clip:padding-box;border:1px solid rgba(0,0,0,0.1);-webkit-box-shadow:0 0.25rem 0.75rem rgba(0,0,0,0.1);box-shadow:0 0.25rem 0.75rem rgba(0,0,0,0.1);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);opacity:0;border-radius:0.25rem}.toast:not(:last-child){margin-bottom:0.75rem}.toast.showing{opacity:1}.toast.show{display:block;opacity:1}.toast.hide{display:none}.toast-header{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-align:center;-ms-flex-align:center;align-items:center;padding:0.25rem 0.75rem;color:#839496;background-color:rgba(255,255,255,0.85);background-clip:padding-box;border-bottom:1px solid rgba(0,0,0,0.05)}.toast-body{padding:0.75rem}.modal-open{overflow:hidden}.modal-open .modal{overflow-x:hidden;overflow-y:auto}.modal{position:fixed;top:0;left:0;z-index:1050;display:none;width:100%;height:100%;overflow:hidden;outline:0}.modal-dialog{position:relative;width:auto;margin:0.5rem;pointer-events:none}.modal.fade .modal-dialog{-webkit-transition:-webkit-transform 0.3s ease-out;transition:-webkit-transform 0.3s ease-out;transition:transform 0.3s ease-out;transition:transform 0.3s ease-out, -webkit-transform 0.3s ease-out;-webkit-transform:translate(0, -50px);transform:translate(0, -50px)}@media (prefers-reduced-motion: reduce){.modal.fade .modal-dialog{-webkit-transition:none;transition:none}}.modal.show .modal-dialog{-webkit-transform:none;transform:none}.modal-dialog-scrollable{display:-webkit-box;display:-ms-flexbox;display:flex;max-height:calc(100% - 1rem)}.modal-dialog-scrollable .modal-content{max-height:calc(100vh - 1rem);overflow:hidden}.modal-dialog-scrollable .modal-header,.modal-dialog-scrollable .modal-footer{-ms-flex-negative:0;flex-shrink:0}.modal-dialog-scrollable .modal-body{overflow-y:auto}.modal-dialog-centered{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-align:center;-ms-flex-align:center;align-items:center;min-height:calc(100% - 1rem)}.modal-dialog-centered::before{display:block;height:calc(100vh - 1rem);content:""}.modal-dialog-centered.modal-dialog-scrollable{-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;flex-direction:column;-webkit-box-pack:center;-ms-flex-pack:center;justify-content:center;height:100%}.modal-dialog-centered.modal-dialog-scrollable .modal-content{max-height:none}.modal-dialog-centered.modal-dialog-scrollable::before{content:none}.modal-content{position:relative;display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;flex-direction:column;width:100%;pointer-events:auto;background-color:#073642;background-clip:padding-box;border:1px solid #002B36;border-radius:0.3rem;outline:0}.modal-backdrop{position:fixed;top:0;left:0;z-index:1040;width:100vw;height:100vh;background-color:#000}.modal-backdrop.fade{opacity:0}.modal-backdrop.show{opacity:0.5}.modal-header{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-align:start;-ms-flex-align:start;align-items:flex-start;-webkit-box-pack:justify;-ms-flex-pack:justify;justify-content:space-between;padding:1rem 1rem;border-bottom:1px solid #002B36;border-top-left-radius:0.3rem;border-top-right-radius:0.3rem}.modal-header .close{padding:1rem 1rem;margin:-1rem -1rem -1rem auto}.modal-title{margin-bottom:0;line-height:1.5}.modal-body{position:relative;-webkit-box-flex:1;-ms-flex:1 1 auto;flex:1 1 auto;padding:1rem}.modal-footer{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-align:center;-ms-flex-align:center;align-items:center;-webkit-box-pack:end;-ms-flex-pack:end;justify-content:flex-end;padding:1rem;border-top:1px solid #002B36;border-bottom-right-radius:0.3rem;border-bottom-left-radius:0.3rem}.modal-footer>:not(:first-child){margin-left:.25rem}.modal-footer>:not(:last-child){margin-right:.25rem}.modal-scrollbar-measure{position:absolute;top:-9999px;width:50px;height:50px;overflow:scroll}@media (min-width: 576px){.modal-dialog{max-width:500px;margin:1.75rem auto}.modal-dialog-scrollable{max-height:calc(100% - 3.5rem)}.modal-dialog-scrollable .modal-content{max-height:calc(100vh - 3.5rem)}.modal-dialog-centered{min-height:calc(100% - 3.5rem)}.modal-dialog-centered::before{height:calc(100vh - 3.5rem)}.modal-sm{max-width:300px}}@media (min-width: 992px){.modal-lg,.modal-xl{max-width:800px}}@media (min-width: 1200px){.modal-xl{max-width:1140px}}.tooltip{position:absolute;z-index:1070;display:block;margin:0;font-family:"Source Sans Pro", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol";font-style:normal;font-weight:400;line-height:1.5;text-align:left;text-align:start;text-decoration:none;text-shadow:none;text-transform:none;letter-spacing:normal;word-break:normal;word-spacing:normal;white-space:normal;line-break:auto;font-size:0.875rem;word-wrap:break-word;opacity:0}.tooltip.show{opacity:0.9}.tooltip .arrow{position:absolute;display:block;width:0.8rem;height:0.4rem}.tooltip .arrow::before{position:absolute;content:"";border-color:transparent;border-style:solid}.bs-tooltip-top,.bs-tooltip-auto[x-placement^="top"]{padding:0.4rem 0}.bs-tooltip-top .arrow,.bs-tooltip-auto[x-placement^="top"] .arrow{bottom:0}.bs-tooltip-top .arrow::before,.bs-tooltip-auto[x-placement^="top"] .arrow::before{top:0;border-width:0.4rem 0.4rem 0;border-top-color:#000}.bs-tooltip-right,.bs-tooltip-auto[x-placement^="right"]{padding:0 0.4rem}.bs-tooltip-right .arrow,.bs-tooltip-auto[x-placement^="right"] .arrow{left:0;width:0.4rem;height:0.8rem}.bs-tooltip-right .arrow::before,.bs-tooltip-auto[x-placement^="right"] .arrow::before{right:0;border-width:0.4rem 0.4rem 0.4rem 0;border-right-color:#000}.bs-tooltip-bottom,.bs-tooltip-auto[x-placement^="bottom"]{padding:0.4rem 0}.bs-tooltip-bottom .arrow,.bs-tooltip-auto[x-placement^="bottom"] .arrow{top:0}.bs-tooltip-bottom .arrow::before,.bs-tooltip-auto[x-placement^="bottom"] .arrow::before{bottom:0;border-width:0 0.4rem 0.4rem;border-bottom-color:#000}.bs-tooltip-left,.bs-tooltip-auto[x-placement^="left"]{padding:0 0.4rem}.bs-tooltip-left .arrow,.bs-tooltip-auto[x-placement^="left"] .arrow{right:0;width:0.4rem;height:0.8rem}.bs-tooltip-left .arrow::before,.bs-tooltip-auto[x-placement^="left"] .arrow::before{left:0;border-width:0.4rem 0 0.4rem 0.4rem;border-left-color:#000}.tooltip-inner{max-width:200px;padding:0.25rem 0.5rem;color:#fff;text-align:center;background-color:#000;border-radius:0.25rem}.popover{position:absolute;top:0;left:0;z-index:1060;display:block;max-width:276px;font-family:"Source Sans Pro", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol";font-style:normal;font-weight:400;line-height:1.5;text-align:left;text-align:start;text-decoration:none;text-shadow:none;text-transform:none;letter-spacing:normal;word-break:normal;word-spacing:normal;white-space:normal;line-break:auto;font-size:0.875rem;word-wrap:break-word;background-color:#073642;background-clip:padding-box;border:1px solid #002B36;border-radius:0.3rem}.popover .arrow{position:absolute;display:block;width:1rem;height:0.5rem;margin:0 0.3rem}.popover .arrow::before,.popover .arrow::after{position:absolute;display:block;content:"";border-color:transparent;border-style:solid}.bs-popover-top,.bs-popover-auto[x-placement^="top"]{margin-bottom:0.5rem}.bs-popover-top>.arrow,.bs-popover-auto[x-placement^="top"]>.arrow{bottom:calc((0.5rem + 1px) * -1)}.bs-popover-top>.arrow::before,.bs-popover-auto[x-placement^="top"]>.arrow::before{bottom:0;border-width:0.5rem 0.5rem 0;border-top-color:#002b36}.bs-popover-top>.arrow::after,.bs-popover-auto[x-placement^="top"]>.arrow::after{bottom:1px;border-width:0.5rem 0.5rem 0;border-top-color:#073642}.bs-popover-right,.bs-popover-auto[x-placement^="right"]{margin-left:0.5rem}.bs-popover-right>.arrow,.bs-popover-auto[x-placement^="right"]>.arrow{left:calc((0.5rem + 1px) * -1);width:0.5rem;height:1rem;margin:0.3rem 0}.bs-popover-right>.arrow::before,.bs-popover-auto[x-placement^="right"]>.arrow::before{left:0;border-width:0.5rem 0.5rem 0.5rem 0;border-right-color:#002b36}.bs-popover-right>.arrow::after,.bs-popover-auto[x-placement^="right"]>.arrow::after{left:1px;border-width:0.5rem 0.5rem 0.5rem 0;border-right-color:#073642}.bs-popover-bottom,.bs-popover-auto[x-placement^="bottom"]{margin-top:0.5rem}.bs-popover-bottom>.arrow,.bs-popover-auto[x-placement^="bottom"]>.arrow{top:calc((0.5rem + 1px) * -1)}.bs-popover-bottom>.arrow::before,.bs-popover-auto[x-placement^="bottom"]>.arrow::before{top:0;border-width:0 0.5rem 0.5rem 0.5rem;border-bottom-color:#002b36}.bs-popover-bottom>.arrow::after,.bs-popover-auto[x-placement^="bottom"]>.arrow::after{top:1px;border-width:0 0.5rem 0.5rem 0.5rem;border-bottom-color:#073642}.bs-popover-bottom .popover-header::before,.bs-popover-auto[x-placement^="bottom"] .popover-header::before{position:absolute;top:0;left:50%;display:block;width:1rem;margin-left:-0.5rem;content:"";border-bottom:1px solid #073642}.bs-popover-left,.bs-popover-auto[x-placement^="left"]{margin-right:0.5rem}.bs-popover-left>.arrow,.bs-popover-auto[x-placement^="left"]>.arrow{right:calc((0.5rem + 1px) * -1);width:0.5rem;height:1rem;margin:0.3rem 0}.bs-popover-left>.arrow::before,.bs-popover-auto[x-placement^="left"]>.arrow::before{right:0;border-width:0.5rem 0 0.5rem 0.5rem;border-left-color:#002b36}.bs-popover-left>.arrow::after,.bs-popover-auto[x-placement^="left"]>.arrow::after{right:1px;border-width:0.5rem 0 0.5rem 0.5rem;border-left-color:#073642}.popover-header{padding:0.5rem 0.75rem;margin-bottom:0;font-size:1rem;background-color:#073642;border-bottom:1px solid #05232b;border-top-left-radius:calc(0.3rem - 1px);border-top-right-radius:calc(0.3rem - 1px)}.popover-header:empty{display:none}.popover-body{padding:0.5rem 0.75rem;color:#839496}.carousel{position:relative}.carousel.pointer-event{-ms-touch-action:pan-y;touch-action:pan-y}.carousel-inner{position:relative;width:100%;overflow:hidden}.carousel-inner::after{display:block;clear:both;content:""}.carousel-item{position:relative;display:none;float:left;width:100%;margin-right:-100%;-webkit-backface-visibility:hidden;backface-visibility:hidden;-webkit-transition:-webkit-transform 0.6s ease-in-out;transition:-webkit-transform 0.6s ease-in-out;transition:transform 0.6s ease-in-out;transition:transform 0.6s ease-in-out, -webkit-transform 0.6s ease-in-out}@media (prefers-reduced-motion: reduce){.carousel-item{-webkit-transition:none;transition:none}}.carousel-item.active,.carousel-item-next,.carousel-item-prev{display:block}.carousel-item-next:not(.carousel-item-left),.active.carousel-item-right{-webkit-transform:translateX(100%);transform:translateX(100%)}.carousel-item-prev:not(.carousel-item-right),.active.carousel-item-left{-webkit-transform:translateX(-100%);transform:translateX(-100%)}.carousel-fade .carousel-item{opacity:0;-webkit-transition-property:opacity;transition-property:opacity;-webkit-transform:none;transform:none}.carousel-fade .carousel-item.active,.carousel-fade .carousel-item-next.carousel-item-left,.carousel-fade .carousel-item-prev.carousel-item-right{z-index:1;opacity:1}.carousel-fade .active.carousel-item-left,.carousel-fade .active.carousel-item-right{z-index:0;opacity:0;-webkit-transition:0s 0.6s opacity;transition:0s 0.6s opacity}@media (prefers-reduced-motion: reduce){.carousel-fade .active.carousel-item-left,.carousel-fade .active.carousel-item-right{-webkit-transition:none;transition:none}}.carousel-control-prev,.carousel-control-next{position:absolute;top:0;bottom:0;z-index:1;display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-align:center;-ms-flex-align:center;align-items:center;-webkit-box-pack:center;-ms-flex-pack:center;justify-content:center;width:15%;color:#fff;text-align:center;opacity:0.5;-webkit-transition:opacity 0.15s ease;transition:opacity 0.15s ease}@media (prefers-reduced-motion: reduce){.carousel-control-prev,.carousel-control-next{-webkit-transition:none;transition:none}}.carousel-control-prev:hover,.carousel-control-prev:focus,.carousel-control-next:hover,.carousel-control-next:focus{color:#fff;text-decoration:none;outline:0;opacity:0.9}.carousel-control-prev{left:0;background:-webkit-gradient(linear, left top, right top, from(rgba(0,0,0,0.25)), to(rgba(0,0,0,0.001)));background:linear-gradient(90deg, rgba(0,0,0,0.25), rgba(0,0,0,0.001))}.carousel-control-next{right:0;background:-webkit-gradient(linear, right top, left top, from(rgba(0,0,0,0.25)), to(rgba(0,0,0,0.001)));background:linear-gradient(270deg, rgba(0,0,0,0.25), rgba(0,0,0,0.001))}.carousel-control-prev-icon,.carousel-control-next-icon{display:inline-block;width:20px;height:20px;background:no-repeat 50% / 100% 100%}.carousel-control-prev-icon{background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='%23fff' viewBox='0 0 8 8'%3e%3cpath d='M5.25 0l-4 4 4 4 1.5-1.5-2.5-2.5 2.5-2.5-1.5-1.5z'/%3e%3c/svg%3e")}.carousel-control-next-icon{background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='%23fff' viewBox='0 0 8 8'%3e%3cpath d='M2.75 0l-1.5 1.5 2.5 2.5-2.5 2.5 1.5 1.5 4-4-4-4z'/%3e%3c/svg%3e")}.carousel-indicators{position:absolute;right:0;bottom:0;left:0;z-index:15;display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-pack:center;-ms-flex-pack:center;justify-content:center;padding-left:0;margin-right:15%;margin-left:15%;list-style:none}.carousel-indicators li{-webkit-box-sizing:content-box;box-sizing:content-box;-webkit-box-flex:0;-ms-flex:0 1 auto;flex:0 1 auto;width:30px;height:3px;margin-right:3px;margin-left:3px;text-indent:-999px;cursor:pointer;background-color:#fff;background-clip:padding-box;border-top:10px solid transparent;border-bottom:10px solid transparent;opacity:.5;-webkit-transition:opacity 0.6s ease;transition:opacity 0.6s ease}@media (prefers-reduced-motion: reduce){.carousel-indicators li{-webkit-transition:none;transition:none}}.carousel-indicators .active{opacity:1}.carousel-caption{position:absolute;right:15%;bottom:20px;left:15%;z-index:10;padding-top:20px;padding-bottom:20px;color:#fff;text-align:center}@-webkit-keyframes spinner-border{to{-webkit-transform:rotate(360deg);transform:rotate(360deg)}}@keyframes spinner-border{to{-webkit-transform:rotate(360deg);transform:rotate(360deg)}}.spinner-border{display:inline-block;width:2rem;height:2rem;vertical-align:text-bottom;border:0.25em solid currentColor;border-right-color:transparent;border-radius:50%;-webkit-animation:spinner-border .75s linear infinite;animation:spinner-border .75s linear infinite}.spinner-border-sm{width:1rem;height:1rem;border-width:0.2em}@-webkit-keyframes spinner-grow{0%{-webkit-transform:scale(0);transform:scale(0)}50%{opacity:1}}@keyframes spinner-grow{0%{-webkit-transform:scale(0);transform:scale(0)}50%{opacity:1}}.spinner-grow{display:inline-block;width:2rem;height:2rem;vertical-align:text-bottom;background-color:currentColor;border-radius:50%;opacity:0;-webkit-animation:spinner-grow .75s linear infinite;animation:spinner-grow .75s linear infinite}.spinner-grow-sm{width:1rem;height:1rem}.align-baseline{vertical-align:baseline !important}.align-top{vertical-align:top !important}.align-middle{vertical-align:middle !important}.align-bottom{vertical-align:bottom !important}.align-text-bottom{vertical-align:text-bottom !important}.align-text-top{vertical-align:text-top !important}.bg-primary{background-color:#B58900 !important}a.bg-primary:hover,a.bg-primary:focus,button.bg-primary:hover,button.bg-primary:focus{background-color:#826200 !important}.bg-secondary{background-color:#839496 !important}a.bg-secondary:hover,a.bg-secondary:focus,button.bg-secondary:hover,button.bg-secondary:focus{background-color:#697b7d !important}.bg-success{background-color:#2AA198 !important}a.bg-success:hover,a.bg-success:focus,button.bg-success:hover,button.bg-success:focus{background-color:#1f7972 !important}.bg-info{background-color:#268BD2 !important}a.bg-info:hover,a.bg-info:focus,button.bg-info:hover,button.bg-info:focus{background-color:#1e6ea7 !important}.bg-warning{background-color:#CB4B16 !important}a.bg-warning:hover,a.bg-warning:focus,button.bg-warning:hover,button.bg-warning:focus{background-color:#9d3a11 !important}.bg-danger{background-color:#D33682 !important}a.bg-danger:hover,a.bg-danger:focus,button.bg-danger:hover,button.bg-danger:focus{background-color:#b02669 !important}.bg-light{background-color:#FDF6E3 !important}a.bg-light:hover,a.bg-light:focus,button.bg-light:hover,button.bg-light:focus{background-color:#fae7b3 !important}.bg-dark{background-color:#073642 !important}a.bg-dark:hover,a.bg-dark:focus,button.bg-dark:hover,button.bg-dark:focus{background-color:#021014 !important}.bg-gradient-primary{background:#B58900 -webkit-gradient(linear, left top, left bottom, from(#9a7b08), to(#B58900)) repeat-x !important;background:#B58900 linear-gradient(180deg, #9a7b08, #B58900) repeat-x !important}.bg-gradient-secondary{background:#839496 -webkit-gradient(linear, left top, left bottom, from(#6f8488), to(#839496)) repeat-x !important;background:#839496 linear-gradient(180deg, #6f8488, #839496) repeat-x !important}.bg-gradient-success{background:#2AA198 -webkit-gradient(linear, left top, left bottom, from(#248f89), to(#2AA198)) repeat-x !important;background:#2AA198 linear-gradient(180deg, #248f89, #2AA198) repeat-x !important}.bg-gradient-info{background:#268BD2 -webkit-gradient(linear, left top, left bottom, from(#207dbb), to(#268BD2)) repeat-x !important;background:#268BD2 linear-gradient(180deg, #207dbb, #268BD2) repeat-x !important}.bg-gradient-warning{background:#CB4B16 -webkit-gradient(linear, left top, left bottom, from(#ad461b), to(#CB4B16)) repeat-x !important;background:#CB4B16 linear-gradient(180deg, #ad461b, #CB4B16) repeat-x !important}.bg-gradient-danger{background:#D33682 -webkit-gradient(linear, left top, left bottom, from(#b33477), to(#D33682)) repeat-x !important;background:#D33682 linear-gradient(180deg, #b33477, #D33682) repeat-x !important}.bg-gradient-light{background:#FDF6E3 -webkit-gradient(linear, left top, left bottom, from(#d7d8c9), to(#FDF6E3)) repeat-x !important;background:#FDF6E3 linear-gradient(180deg, #d7d8c9, #FDF6E3) repeat-x !important}.bg-gradient-dark{background:#073642 -webkit-gradient(linear, left top, left bottom, from(#063440), to(#073642)) repeat-x !important;background:#073642 linear-gradient(180deg, #063440, #073642) repeat-x !important}.bg-white{background-color:#fff !important}.bg-transparent{background-color:transparent !important}.border{border:1px solid #dee2e6 !important}.border-top{border-top:1px solid #dee2e6 !important}.border-right{border-right:1px solid #dee2e6 !important}.border-bottom{border-bottom:1px solid #dee2e6 !important}.border-left{border-left:1px solid #dee2e6 !important}.border-0{border:0 !important}.border-top-0{border-top:0 !important}.border-right-0{border-right:0 !important}.border-bottom-0{border-bottom:0 !important}.border-left-0{border-left:0 !important}.border-primary{border-color:#B58900 !important}.border-secondary{border-color:#839496 !important}.border-success{border-color:#2AA198 !important}.border-info{border-color:#268BD2 !important}.border-warning{border-color:#CB4B16 !important}.border-danger{border-color:#D33682 !important}.border-light{border-color:#FDF6E3 !important}.border-dark{border-color:#073642 !important}.border-white{border-color:#fff !important}.rounded-sm{border-radius:0.2rem !important}.rounded{border-radius:0.25rem !important}.rounded-top{border-top-left-radius:0.25rem !important;border-top-right-radius:0.25rem !important}.rounded-right{border-top-right-radius:0.25rem !important;border-bottom-right-radius:0.25rem !important}.rounded-bottom{border-bottom-right-radius:0.25rem !important;border-bottom-left-radius:0.25rem !important}.rounded-left{border-top-left-radius:0.25rem !important;border-bottom-left-radius:0.25rem !important}.rounded-lg{border-radius:0.3rem !important}.rounded-circle{border-radius:50% !important}.rounded-pill{border-radius:50rem !important}.rounded-0{border-radius:0 !important}.clearfix::after{display:block;clear:both;content:""}.d-none{display:none !important}.d-inline{display:inline !important}.d-inline-block{display:inline-block !important}.d-block{display:block !important}.d-table{display:table !important}.d-table-row{display:table-row !important}.d-table-cell{display:table-cell !important}.d-flex{display:-webkit-box !important;display:-ms-flexbox !important;display:flex !important}.d-inline-flex{display:-webkit-inline-box !important;display:-ms-inline-flexbox !important;display:inline-flex !important}@media (min-width: 576px){.d-sm-none{display:none !important}.d-sm-inline{display:inline !important}.d-sm-inline-block{display:inline-block !important}.d-sm-block{display:block !important}.d-sm-table{display:table !important}.d-sm-table-row{display:table-row !important}.d-sm-table-cell{display:table-cell !important}.d-sm-flex{display:-webkit-box !important;display:-ms-flexbox !important;display:flex !important}.d-sm-inline-flex{display:-webkit-inline-box !important;display:-ms-inline-flexbox !important;display:inline-flex !important}}@media (min-width: 768px){.d-md-none{display:none !important}.d-md-inline{display:inline !important}.d-md-inline-block{display:inline-block !important}.d-md-block{display:block !important}.d-md-table{display:table !important}.d-md-table-row{display:table-row !important}.d-md-table-cell{display:table-cell !important}.d-md-flex{display:-webkit-box !important;display:-ms-flexbox !important;display:flex !important}.d-md-inline-flex{display:-webkit-inline-box !important;display:-ms-inline-flexbox !important;display:inline-flex !important}}@media (min-width: 992px){.d-lg-none{display:none !important}.d-lg-inline{display:inline !important}.d-lg-inline-block{display:inline-block !important}.d-lg-block{display:block !important}.d-lg-table{display:table !important}.d-lg-table-row{display:table-row !important}.d-lg-table-cell{display:table-cell !important}.d-lg-flex{display:-webkit-box !important;display:-ms-flexbox !important;display:flex !important}.d-lg-inline-flex{display:-webkit-inline-box !important;display:-ms-inline-flexbox !important;display:inline-flex !important}}@media (min-width: 1200px){.d-xl-none{display:none !important}.d-xl-inline{display:inline !important}.d-xl-inline-block{display:inline-block !important}.d-xl-block{display:block !important}.d-xl-table{display:table !important}.d-xl-table-row{display:table-row !important}.d-xl-table-cell{display:table-cell !important}.d-xl-flex{display:-webkit-box !important;display:-ms-flexbox !important;display:flex !important}.d-xl-inline-flex{display:-webkit-inline-box !important;display:-ms-inline-flexbox !important;display:inline-flex !important}}@media print{.d-print-none{display:none !important}.d-print-inline{display:inline !important}.d-print-inline-block{display:inline-block !important}.d-print-block{display:block !important}.d-print-table{display:table !important}.d-print-table-row{display:table-row !important}.d-print-table-cell{display:table-cell !important}.d-print-flex{display:-webkit-box !important;display:-ms-flexbox !important;display:flex !important}.d-print-inline-flex{display:-webkit-inline-box !important;display:-ms-inline-flexbox !important;display:inline-flex !important}}.embed-responsive{position:relative;display:block;width:100%;padding:0;overflow:hidden}.embed-responsive::before{display:block;content:""}.embed-responsive .embed-responsive-item,.embed-responsive iframe,.embed-responsive embed,.embed-responsive object,.embed-responsive video{position:absolute;top:0;bottom:0;left:0;width:100%;height:100%;border:0}.embed-responsive-21by9::before{padding-top:42.8571428571%}.embed-responsive-16by9::before{padding-top:56.25%}.embed-responsive-4by3::before{padding-top:75%}.embed-responsive-1by1::before{padding-top:100%}.flex-row{-webkit-box-orient:horizontal !important;-webkit-box-direction:normal !important;-ms-flex-direction:row !important;flex-direction:row !important}.flex-column{-webkit-box-orient:vertical !important;-webkit-box-direction:normal !important;-ms-flex-direction:column !important;flex-direction:column !important}.flex-row-reverse{-webkit-box-orient:horizontal !important;-webkit-box-direction:reverse !important;-ms-flex-direction:row-reverse !important;flex-direction:row-reverse !important}.flex-column-reverse{-webkit-box-orient:vertical !important;-webkit-box-direction:reverse !important;-ms-flex-direction:column-reverse !important;flex-direction:column-reverse !important}.flex-wrap{-ms-flex-wrap:wrap !important;flex-wrap:wrap !important}.flex-nowrap{-ms-flex-wrap:nowrap !important;flex-wrap:nowrap !important}.flex-wrap-reverse{-ms-flex-wrap:wrap-reverse !important;flex-wrap:wrap-reverse !important}.flex-fill{-webkit-box-flex:1 !important;-ms-flex:1 1 auto !important;flex:1 1 auto !important}.flex-grow-0{-webkit-box-flex:0 !important;-ms-flex-positive:0 !important;flex-grow:0 !important}.flex-grow-1{-webkit-box-flex:1 !important;-ms-flex-positive:1 !important;flex-grow:1 !important}.flex-shrink-0{-ms-flex-negative:0 !important;flex-shrink:0 !important}.flex-shrink-1{-ms-flex-negative:1 !important;flex-shrink:1 !important}.justify-content-start{-webkit-box-pack:start !important;-ms-flex-pack:start !important;justify-content:flex-start !important}.justify-content-end{-webkit-box-pack:end !important;-ms-flex-pack:end !important;justify-content:flex-end !important}.justify-content-center{-webkit-box-pack:center !important;-ms-flex-pack:center !important;justify-content:center !important}.justify-content-between{-webkit-box-pack:justify !important;-ms-flex-pack:justify !important;justify-content:space-between !important}.justify-content-around{-ms-flex-pack:distribute !important;justify-content:space-around !important}.align-items-start{-webkit-box-align:start !important;-ms-flex-align:start !important;align-items:flex-start !important}.align-items-end{-webkit-box-align:end !important;-ms-flex-align:end !important;align-items:flex-end !important}.align-items-center{-webkit-box-align:center !important;-ms-flex-align:center !important;align-items:center !important}.align-items-baseline{-webkit-box-align:baseline !important;-ms-flex-align:baseline !important;align-items:baseline !important}.align-items-stretch{-webkit-box-align:stretch !important;-ms-flex-align:stretch !important;align-items:stretch !important}.align-content-start{-ms-flex-line-pack:start !important;align-content:flex-start !important}.align-content-end{-ms-flex-line-pack:end !important;align-content:flex-end !important}.align-content-center{-ms-flex-line-pack:center !important;align-content:center !important}.align-content-between{-ms-flex-line-pack:justify !important;align-content:space-between !important}.align-content-around{-ms-flex-line-pack:distribute !important;align-content:space-around !important}.align-content-stretch{-ms-flex-line-pack:stretch !important;align-content:stretch !important}.align-self-auto{-ms-flex-item-align:auto !important;align-self:auto !important}.align-self-start{-ms-flex-item-align:start !important;align-self:flex-start !important}.align-self-end{-ms-flex-item-align:end !important;align-self:flex-end !important}.align-self-center{-ms-flex-item-align:center !important;align-self:center !important}.align-self-baseline{-ms-flex-item-align:baseline !important;align-self:baseline !important}.align-self-stretch{-ms-flex-item-align:stretch !important;align-self:stretch !important}@media (min-width: 576px){.flex-sm-row{-webkit-box-orient:horizontal !important;-webkit-box-direction:normal !important;-ms-flex-direction:row !important;flex-direction:row !important}.flex-sm-column{-webkit-box-orient:vertical !important;-webkit-box-direction:normal !important;-ms-flex-direction:column !important;flex-direction:column !important}.flex-sm-row-reverse{-webkit-box-orient:horizontal !important;-webkit-box-direction:reverse !important;-ms-flex-direction:row-reverse !important;flex-direction:row-reverse !important}.flex-sm-column-reverse{-webkit-box-orient:vertical !important;-webkit-box-direction:reverse !important;-ms-flex-direction:column-reverse !important;flex-direction:column-reverse !important}.flex-sm-wrap{-ms-flex-wrap:wrap !important;flex-wrap:wrap !important}.flex-sm-nowrap{-ms-flex-wrap:nowrap !important;flex-wrap:nowrap !important}.flex-sm-wrap-reverse{-ms-flex-wrap:wrap-reverse !important;flex-wrap:wrap-reverse !important}.flex-sm-fill{-webkit-box-flex:1 !important;-ms-flex:1 1 auto !important;flex:1 1 auto !important}.flex-sm-grow-0{-webkit-box-flex:0 !important;-ms-flex-positive:0 !important;flex-grow:0 !important}.flex-sm-grow-1{-webkit-box-flex:1 !important;-ms-flex-positive:1 !important;flex-grow:1 !important}.flex-sm-shrink-0{-ms-flex-negative:0 !important;flex-shrink:0 !important}.flex-sm-shrink-1{-ms-flex-negative:1 !important;flex-shrink:1 !important}.justify-content-sm-start{-webkit-box-pack:start !important;-ms-flex-pack:start !important;justify-content:flex-start !important}.justify-content-sm-end{-webkit-box-pack:end !important;-ms-flex-pack:end !important;justify-content:flex-end !important}.justify-content-sm-center{-webkit-box-pack:center !important;-ms-flex-pack:center !important;justify-content:center !important}.justify-content-sm-between{-webkit-box-pack:justify !important;-ms-flex-pack:justify !important;justify-content:space-between !important}.justify-content-sm-around{-ms-flex-pack:distribute !important;justify-content:space-around !important}.align-items-sm-start{-webkit-box-align:start !important;-ms-flex-align:start !important;align-items:flex-start !important}.align-items-sm-end{-webkit-box-align:end !important;-ms-flex-align:end !important;align-items:flex-end !important}.align-items-sm-center{-webkit-box-align:center !important;-ms-flex-align:center !important;align-items:center !important}.align-items-sm-baseline{-webkit-box-align:baseline !important;-ms-flex-align:baseline !important;align-items:baseline !important}.align-items-sm-stretch{-webkit-box-align:stretch !important;-ms-flex-align:stretch !important;align-items:stretch !important}.align-content-sm-start{-ms-flex-line-pack:start !important;align-content:flex-start !important}.align-content-sm-end{-ms-flex-line-pack:end !important;align-content:flex-end !important}.align-content-sm-center{-ms-flex-line-pack:center !important;align-content:center !important}.align-content-sm-between{-ms-flex-line-pack:justify !important;align-content:space-between !important}.align-content-sm-around{-ms-flex-line-pack:distribute !important;align-content:space-around !important}.align-content-sm-stretch{-ms-flex-line-pack:stretch !important;align-content:stretch !important}.align-self-sm-auto{-ms-flex-item-align:auto !important;align-self:auto !important}.align-self-sm-start{-ms-flex-item-align:start !important;align-self:flex-start !important}.align-self-sm-end{-ms-flex-item-align:end !important;align-self:flex-end !important}.align-self-sm-center{-ms-flex-item-align:center !important;align-self:center !important}.align-self-sm-baseline{-ms-flex-item-align:baseline !important;align-self:baseline !important}.align-self-sm-stretch{-ms-flex-item-align:stretch !important;align-self:stretch !important}}@media (min-width: 768px){.flex-md-row{-webkit-box-orient:horizontal !important;-webkit-box-direction:normal !important;-ms-flex-direction:row !important;flex-direction:row !important}.flex-md-column{-webkit-box-orient:vertical !important;-webkit-box-direction:normal !important;-ms-flex-direction:column !important;flex-direction:column !important}.flex-md-row-reverse{-webkit-box-orient:horizontal !important;-webkit-box-direction:reverse !important;-ms-flex-direction:row-reverse !important;flex-direction:row-reverse !important}.flex-md-column-reverse{-webkit-box-orient:vertical !important;-webkit-box-direction:reverse !important;-ms-flex-direction:column-reverse !important;flex-direction:column-reverse !important}.flex-md-wrap{-ms-flex-wrap:wrap !important;flex-wrap:wrap !important}.flex-md-nowrap{-ms-flex-wrap:nowrap !important;flex-wrap:nowrap !important}.flex-md-wrap-reverse{-ms-flex-wrap:wrap-reverse !important;flex-wrap:wrap-reverse !important}.flex-md-fill{-webkit-box-flex:1 !important;-ms-flex:1 1 auto !important;flex:1 1 auto !important}.flex-md-grow-0{-webkit-box-flex:0 !important;-ms-flex-positive:0 !important;flex-grow:0 !important}.flex-md-grow-1{-webkit-box-flex:1 !important;-ms-flex-positive:1 !important;flex-grow:1 !important}.flex-md-shrink-0{-ms-flex-negative:0 !important;flex-shrink:0 !important}.flex-md-shrink-1{-ms-flex-negative:1 !important;flex-shrink:1 !important}.justify-content-md-start{-webkit-box-pack:start !important;-ms-flex-pack:start !important;justify-content:flex-start !important}.justify-content-md-end{-webkit-box-pack:end !important;-ms-flex-pack:end !important;justify-content:flex-end !important}.justify-content-md-center{-webkit-box-pack:center !important;-ms-flex-pack:center !important;justify-content:center !important}.justify-content-md-between{-webkit-box-pack:justify !important;-ms-flex-pack:justify !important;justify-content:space-between !important}.justify-content-md-around{-ms-flex-pack:distribute !important;justify-content:space-around !important}.align-items-md-start{-webkit-box-align:start !important;-ms-flex-align:start !important;align-items:flex-start !important}.align-items-md-end{-webkit-box-align:end !important;-ms-flex-align:end !important;align-items:flex-end !important}.align-items-md-center{-webkit-box-align:center !important;-ms-flex-align:center !important;align-items:center !important}.align-items-md-baseline{-webkit-box-align:baseline !important;-ms-flex-align:baseline !important;align-items:baseline !important}.align-items-md-stretch{-webkit-box-align:stretch !important;-ms-flex-align:stretch !important;align-items:stretch !important}.align-content-md-start{-ms-flex-line-pack:start !important;align-content:flex-start !important}.align-content-md-end{-ms-flex-line-pack:end !important;align-content:flex-end !important}.align-content-md-center{-ms-flex-line-pack:center !important;align-content:center !important}.align-content-md-between{-ms-flex-line-pack:justify !important;align-content:space-between !important}.align-content-md-around{-ms-flex-line-pack:distribute !important;align-content:space-around !important}.align-content-md-stretch{-ms-flex-line-pack:stretch !important;align-content:stretch !important}.align-self-md-auto{-ms-flex-item-align:auto !important;align-self:auto !important}.align-self-md-start{-ms-flex-item-align:start !important;align-self:flex-start !important}.align-self-md-end{-ms-flex-item-align:end !important;align-self:flex-end !important}.align-self-md-center{-ms-flex-item-align:center !important;align-self:center !important}.align-self-md-baseline{-ms-flex-item-align:baseline !important;align-self:baseline !important}.align-self-md-stretch{-ms-flex-item-align:stretch !important;align-self:stretch !important}}@media (min-width: 992px){.flex-lg-row{-webkit-box-orient:horizontal !important;-webkit-box-direction:normal !important;-ms-flex-direction:row !important;flex-direction:row !important}.flex-lg-column{-webkit-box-orient:vertical !important;-webkit-box-direction:normal !important;-ms-flex-direction:column !important;flex-direction:column !important}.flex-lg-row-reverse{-webkit-box-orient:horizontal !important;-webkit-box-direction:reverse !important;-ms-flex-direction:row-reverse !important;flex-direction:row-reverse !important}.flex-lg-column-reverse{-webkit-box-orient:vertical !important;-webkit-box-direction:reverse !important;-ms-flex-direction:column-reverse !important;flex-direction:column-reverse !important}.flex-lg-wrap{-ms-flex-wrap:wrap !important;flex-wrap:wrap !important}.flex-lg-nowrap{-ms-flex-wrap:nowrap !important;flex-wrap:nowrap !important}.flex-lg-wrap-reverse{-ms-flex-wrap:wrap-reverse !important;flex-wrap:wrap-reverse !important}.flex-lg-fill{-webkit-box-flex:1 !important;-ms-flex:1 1 auto !important;flex:1 1 auto !important}.flex-lg-grow-0{-webkit-box-flex:0 !important;-ms-flex-positive:0 !important;flex-grow:0 !important}.flex-lg-grow-1{-webkit-box-flex:1 !important;-ms-flex-positive:1 !important;flex-grow:1 !important}.flex-lg-shrink-0{-ms-flex-negative:0 !important;flex-shrink:0 !important}.flex-lg-shrink-1{-ms-flex-negative:1 !important;flex-shrink:1 !important}.justify-content-lg-start{-webkit-box-pack:start !important;-ms-flex-pack:start !important;justify-content:flex-start !important}.justify-content-lg-end{-webkit-box-pack:end !important;-ms-flex-pack:end !important;justify-content:flex-end !important}.justify-content-lg-center{-webkit-box-pack:center !important;-ms-flex-pack:center !important;justify-content:center !important}.justify-content-lg-between{-webkit-box-pack:justify !important;-ms-flex-pack:justify !important;justify-content:space-between !important}.justify-content-lg-around{-ms-flex-pack:distribute !important;justify-content:space-around !important}.align-items-lg-start{-webkit-box-align:start !important;-ms-flex-align:start !important;align-items:flex-start !important}.align-items-lg-end{-webkit-box-align:end !important;-ms-flex-align:end !important;align-items:flex-end !important}.align-items-lg-center{-webkit-box-align:center !important;-ms-flex-align:center !important;align-items:center !important}.align-items-lg-baseline{-webkit-box-align:baseline !important;-ms-flex-align:baseline !important;align-items:baseline !important}.align-items-lg-stretch{-webkit-box-align:stretch !important;-ms-flex-align:stretch !important;align-items:stretch !important}.align-content-lg-start{-ms-flex-line-pack:start !important;align-content:flex-start !important}.align-content-lg-end{-ms-flex-line-pack:end !important;align-content:flex-end !important}.align-content-lg-center{-ms-flex-line-pack:center !important;align-content:center !important}.align-content-lg-between{-ms-flex-line-pack:justify !important;align-content:space-between !important}.align-content-lg-around{-ms-flex-line-pack:distribute !important;align-content:space-around !important}.align-content-lg-stretch{-ms-flex-line-pack:stretch !important;align-content:stretch !important}.align-self-lg-auto{-ms-flex-item-align:auto !important;align-self:auto !important}.align-self-lg-start{-ms-flex-item-align:start !important;align-self:flex-start !important}.align-self-lg-end{-ms-flex-item-align:end !important;align-self:flex-end !important}.align-self-lg-center{-ms-flex-item-align:center !important;align-self:center !important}.align-self-lg-baseline{-ms-flex-item-align:baseline !important;align-self:baseline !important}.align-self-lg-stretch{-ms-flex-item-align:stretch !important;align-self:stretch !important}}@media (min-width: 1200px){.flex-xl-row{-webkit-box-orient:horizontal !important;-webkit-box-direction:normal !important;-ms-flex-direction:row !important;flex-direction:row !important}.flex-xl-column{-webkit-box-orient:vertical !important;-webkit-box-direction:normal !important;-ms-flex-direction:column !important;flex-direction:column !important}.flex-xl-row-reverse{-webkit-box-orient:horizontal !important;-webkit-box-direction:reverse !important;-ms-flex-direction:row-reverse !important;flex-direction:row-reverse !important}.flex-xl-column-reverse{-webkit-box-orient:vertical !important;-webkit-box-direction:reverse !important;-ms-flex-direction:column-reverse !important;flex-direction:column-reverse !important}.flex-xl-wrap{-ms-flex-wrap:wrap !important;flex-wrap:wrap !important}.flex-xl-nowrap{-ms-flex-wrap:nowrap !important;flex-wrap:nowrap !important}.flex-xl-wrap-reverse{-ms-flex-wrap:wrap-reverse !important;flex-wrap:wrap-reverse !important}.flex-xl-fill{-webkit-box-flex:1 !important;-ms-flex:1 1 auto !important;flex:1 1 auto !important}.flex-xl-grow-0{-webkit-box-flex:0 !important;-ms-flex-positive:0 !important;flex-grow:0 !important}.flex-xl-grow-1{-webkit-box-flex:1 !important;-ms-flex-positive:1 !important;flex-grow:1 !important}.flex-xl-shrink-0{-ms-flex-negative:0 !important;flex-shrink:0 !important}.flex-xl-shrink-1{-ms-flex-negative:1 !important;flex-shrink:1 !important}.justify-content-xl-start{-webkit-box-pack:start !important;-ms-flex-pack:start !important;justify-content:flex-start !important}.justify-content-xl-end{-webkit-box-pack:end !important;-ms-flex-pack:end !important;justify-content:flex-end !important}.justify-content-xl-center{-webkit-box-pack:center !important;-ms-flex-pack:center !important;justify-content:center !important}.justify-content-xl-between{-webkit-box-pack:justify !important;-ms-flex-pack:justify !important;justify-content:space-between !important}.justify-content-xl-around{-ms-flex-pack:distribute !important;justify-content:space-around !important}.align-items-xl-start{-webkit-box-align:start !important;-ms-flex-align:start !important;align-items:flex-start !important}.align-items-xl-end{-webkit-box-align:end !important;-ms-flex-align:end !important;align-items:flex-end !important}.align-items-xl-center{-webkit-box-align:center !important;-ms-flex-align:center !important;align-items:center !important}.align-items-xl-baseline{-webkit-box-align:baseline !important;-ms-flex-align:baseline !important;align-items:baseline !important}.align-items-xl-stretch{-webkit-box-align:stretch !important;-ms-flex-align:stretch !important;align-items:stretch !important}.align-content-xl-start{-ms-flex-line-pack:start !important;align-content:flex-start !important}.align-content-xl-end{-ms-flex-line-pack:end !important;align-content:flex-end !important}.align-content-xl-center{-ms-flex-line-pack:center !important;align-content:center !important}.align-content-xl-between{-ms-flex-line-pack:justify !important;align-content:space-between !important}.align-content-xl-around{-ms-flex-line-pack:distribute !important;align-content:space-around !important}.align-content-xl-stretch{-ms-flex-line-pack:stretch !important;align-content:stretch !important}.align-self-xl-auto{-ms-flex-item-align:auto !important;align-self:auto !important}.align-self-xl-start{-ms-flex-item-align:start !important;align-self:flex-start !important}.align-self-xl-end{-ms-flex-item-align:end !important;align-self:flex-end !important}.align-self-xl-center{-ms-flex-item-align:center !important;align-self:center !important}.align-self-xl-baseline{-ms-flex-item-align:baseline !important;align-self:baseline !important}.align-self-xl-stretch{-ms-flex-item-align:stretch !important;align-self:stretch !important}}.float-left{float:left !important}.float-right{float:right !important}.float-none{float:none !important}@media (min-width: 576px){.float-sm-left{float:left !important}.float-sm-right{float:right !important}.float-sm-none{float:none !important}}@media (min-width: 768px){.float-md-left{float:left !important}.float-md-right{float:right !important}.float-md-none{float:none !important}}@media (min-width: 992px){.float-lg-left{float:left !important}.float-lg-right{float:right !important}.float-lg-none{float:none !important}}@media (min-width: 1200px){.float-xl-left{float:left !important}.float-xl-right{float:right !important}.float-xl-none{float:none !important}}.overflow-auto{overflow:auto !important}.overflow-hidden{overflow:hidden !important}.position-static{position:static !important}.position-relative{position:relative !important}.position-absolute{position:absolute !important}.position-fixed{position:fixed !important}.position-sticky{position:-webkit-sticky !important;position:sticky !important}.fixed-top{position:fixed;top:0;right:0;left:0;z-index:1030}.fixed-bottom{position:fixed;right:0;bottom:0;left:0;z-index:1030}@supports (position: -webkit-sticky) or (position: sticky){.sticky-top{position:-webkit-sticky;position:sticky;top:0;z-index:1020}}.sr-only{position:absolute;width:1px;height:1px;padding:0;overflow:hidden;clip:rect(0, 0, 0, 0);white-space:nowrap;border:0}.sr-only-focusable:active,.sr-only-focusable:focus{position:static;width:auto;height:auto;overflow:visible;clip:auto;white-space:normal}.shadow-sm{-webkit-box-shadow:0 0.125rem 0.25rem rgba(0,0,0,0.075) !important;box-shadow:0 0.125rem 0.25rem rgba(0,0,0,0.075) !important}.shadow{-webkit-box-shadow:0 0.5rem 1rem rgba(0,0,0,0.15) !important;box-shadow:0 0.5rem 1rem rgba(0,0,0,0.15) !important}.shadow-lg{-webkit-box-shadow:0 1rem 3rem rgba(0,0,0,0.175) !important;box-shadow:0 1rem 3rem rgba(0,0,0,0.175) !important}.shadow-none{-webkit-box-shadow:none !important;box-shadow:none !important}.w-25{width:25% !important}.w-50{width:50% !important}.w-75{width:75% !important}.w-100{width:100% !important}.w-auto{width:auto !important}.h-25{height:25% !important}.h-50{height:50% !important}.h-75{height:75% !important}.h-100{height:100% !important}.h-auto{height:auto !important}.mw-100{max-width:100% !important}.mh-100{max-height:100% !important}.min-vw-100{min-width:100vw !important}.min-vh-100{min-height:100vh !important}.vw-100{width:100vw !important}.vh-100{height:100vh !important}.stretched-link::after{position:absolute;top:0;right:0;bottom:0;left:0;z-index:1;pointer-events:auto;content:"";background-color:rgba(0,0,0,0)}.m-0{margin:0 !important}.mt-0,.my-0{margin-top:0 !important}.mr-0,.mx-0{margin-right:0 !important}.mb-0,.my-0{margin-bottom:0 !important}.ml-0,.mx-0{margin-left:0 !important}.m-1{margin:0.25rem !important}.mt-1,.my-1{margin-top:0.25rem !important}.mr-1,.mx-1{margin-right:0.25rem !important}.mb-1,.my-1{margin-bottom:0.25rem !important}.ml-1,.mx-1{margin-left:0.25rem !important}.m-2{margin:0.5rem !important}.mt-2,.my-2{margin-top:0.5rem !important}.mr-2,.mx-2{margin-right:0.5rem !important}.mb-2,.my-2{margin-bottom:0.5rem !important}.ml-2,.mx-2{margin-left:0.5rem !important}.m-3{margin:1rem !important}.mt-3,.my-3{margin-top:1rem !important}.mr-3,.mx-3{margin-right:1rem !important}.mb-3,.my-3{margin-bottom:1rem !important}.ml-3,.mx-3{margin-left:1rem !important}.m-4{margin:1.5rem !important}.mt-4,.my-4{margin-top:1.5rem !important}.mr-4,.mx-4{margin-right:1.5rem !important}.mb-4,.my-4{margin-bottom:1.5rem !important}.ml-4,.mx-4{margin-left:1.5rem !important}.m-5{margin:3rem !important}.mt-5,.my-5{margin-top:3rem !important}.mr-5,.mx-5{margin-right:3rem !important}.mb-5,.my-5{margin-bottom:3rem !important}.ml-5,.mx-5{margin-left:3rem !important}.p-0{padding:0 !important}.pt-0,.py-0{padding-top:0 !important}.pr-0,.px-0{padding-right:0 !important}.pb-0,.py-0{padding-bottom:0 !important}.pl-0,.px-0{padding-left:0 !important}.p-1{padding:0.25rem !important}.pt-1,.py-1{padding-top:0.25rem !important}.pr-1,.px-1{padding-right:0.25rem !important}.pb-1,.py-1{padding-bottom:0.25rem !important}.pl-1,.px-1{padding-left:0.25rem !important}.p-2{padding:0.5rem !important}.pt-2,.py-2{padding-top:0.5rem !important}.pr-2,.px-2{padding-right:0.5rem !important}.pb-2,.py-2{padding-bottom:0.5rem !important}.pl-2,.px-2{padding-left:0.5rem !important}.p-3{padding:1rem !important}.pt-3,.py-3{padding-top:1rem !important}.pr-3,.px-3{padding-right:1rem !important}.pb-3,.py-3{padding-bottom:1rem !important}.pl-3,.px-3{padding-left:1rem !important}.p-4{padding:1.5rem !important}.pt-4,.py-4{padding-top:1.5rem !important}.pr-4,.px-4{padding-right:1.5rem !important}.pb-4,.py-4{padding-bottom:1.5rem !important}.pl-4,.px-4{padding-left:1.5rem !important}.p-5{padding:3rem !important}.pt-5,.py-5{padding-top:3rem !important}.pr-5,.px-5{padding-right:3rem !important}.pb-5,.py-5{padding-bottom:3rem !important}.pl-5,.px-5{padding-left:3rem !important}.m-n1{margin:-0.25rem !important}.mt-n1,.my-n1{margin-top:-0.25rem !important}.mr-n1,.mx-n1{margin-right:-0.25rem !important}.mb-n1,.my-n1{margin-bottom:-0.25rem !important}.ml-n1,.mx-n1{margin-left:-0.25rem !important}.m-n2{margin:-0.5rem !important}.mt-n2,.my-n2{margin-top:-0.5rem !important}.mr-n2,.mx-n2{margin-right:-0.5rem !important}.mb-n2,.my-n2{margin-bottom:-0.5rem !important}.ml-n2,.mx-n2{margin-left:-0.5rem !important}.m-n3{margin:-1rem !important}.mt-n3,.my-n3{margin-top:-1rem !important}.mr-n3,.mx-n3{margin-right:-1rem !important}.mb-n3,.my-n3{margin-bottom:-1rem !important}.ml-n3,.mx-n3{margin-left:-1rem !important}.m-n4{margin:-1.5rem !important}.mt-n4,.my-n4{margin-top:-1.5rem !important}.mr-n4,.mx-n4{margin-right:-1.5rem !important}.mb-n4,.my-n4{margin-bottom:-1.5rem !important}.ml-n4,.mx-n4{margin-left:-1.5rem !important}.m-n5{margin:-3rem !important}.mt-n5,.my-n5{margin-top:-3rem !important}.mr-n5,.mx-n5{margin-right:-3rem !important}.mb-n5,.my-n5{margin-bottom:-3rem !important}.ml-n5,.mx-n5{margin-left:-3rem !important}.m-auto{margin:auto !important}.mt-auto,.my-auto{margin-top:auto !important}.mr-auto,.mx-auto{margin-right:auto !important}.mb-auto,.my-auto{margin-bottom:auto !important}.ml-auto,.mx-auto{margin-left:auto !important}@media (min-width: 576px){.m-sm-0{margin:0 !important}.mt-sm-0,.my-sm-0{margin-top:0 !important}.mr-sm-0,.mx-sm-0{margin-right:0 !important}.mb-sm-0,.my-sm-0{margin-bottom:0 !important}.ml-sm-0,.mx-sm-0{margin-left:0 !important}.m-sm-1{margin:0.25rem !important}.mt-sm-1,.my-sm-1{margin-top:0.25rem !important}.mr-sm-1,.mx-sm-1{margin-right:0.25rem !important}.mb-sm-1,.my-sm-1{margin-bottom:0.25rem !important}.ml-sm-1,.mx-sm-1{margin-left:0.25rem !important}.m-sm-2{margin:0.5rem !important}.mt-sm-2,.my-sm-2{margin-top:0.5rem !important}.mr-sm-2,.mx-sm-2{margin-right:0.5rem !important}.mb-sm-2,.my-sm-2{margin-bottom:0.5rem !important}.ml-sm-2,.mx-sm-2{margin-left:0.5rem !important}.m-sm-3{margin:1rem !important}.mt-sm-3,.my-sm-3{margin-top:1rem !important}.mr-sm-3,.mx-sm-3{margin-right:1rem !important}.mb-sm-3,.my-sm-3{margin-bottom:1rem !important}.ml-sm-3,.mx-sm-3{margin-left:1rem !important}.m-sm-4{margin:1.5rem !important}.mt-sm-4,.my-sm-4{margin-top:1.5rem !important}.mr-sm-4,.mx-sm-4{margin-right:1.5rem !important}.mb-sm-4,.my-sm-4{margin-bottom:1.5rem !important}.ml-sm-4,.mx-sm-4{margin-left:1.5rem !important}.m-sm-5{margin:3rem !important}.mt-sm-5,.my-sm-5{margin-top:3rem !important}.mr-sm-5,.mx-sm-5{margin-right:3rem !important}.mb-sm-5,.my-sm-5{margin-bottom:3rem !important}.ml-sm-5,.mx-sm-5{margin-left:3rem !important}.p-sm-0{padding:0 !important}.pt-sm-0,.py-sm-0{padding-top:0 !important}.pr-sm-0,.px-sm-0{padding-right:0 !important}.pb-sm-0,.py-sm-0{padding-bottom:0 !important}.pl-sm-0,.px-sm-0{padding-left:0 !important}.p-sm-1{padding:0.25rem !important}.pt-sm-1,.py-sm-1{padding-top:0.25rem !important}.pr-sm-1,.px-sm-1{padding-right:0.25rem !important}.pb-sm-1,.py-sm-1{padding-bottom:0.25rem !important}.pl-sm-1,.px-sm-1{padding-left:0.25rem !important}.p-sm-2{padding:0.5rem !important}.pt-sm-2,.py-sm-2{padding-top:0.5rem !important}.pr-sm-2,.px-sm-2{padding-right:0.5rem !important}.pb-sm-2,.py-sm-2{padding-bottom:0.5rem !important}.pl-sm-2,.px-sm-2{padding-left:0.5rem !important}.p-sm-3{padding:1rem !important}.pt-sm-3,.py-sm-3{padding-top:1rem !important}.pr-sm-3,.px-sm-3{padding-right:1rem !important}.pb-sm-3,.py-sm-3{padding-bottom:1rem !important}.pl-sm-3,.px-sm-3{padding-left:1rem !important}.p-sm-4{padding:1.5rem !important}.pt-sm-4,.py-sm-4{padding-top:1.5rem !important}.pr-sm-4,.px-sm-4{padding-right:1.5rem !important}.pb-sm-4,.py-sm-4{padding-bottom:1.5rem !important}.pl-sm-4,.px-sm-4{padding-left:1.5rem !important}.p-sm-5{padding:3rem !important}.pt-sm-5,.py-sm-5{padding-top:3rem !important}.pr-sm-5,.px-sm-5{padding-right:3rem !important}.pb-sm-5,.py-sm-5{padding-bottom:3rem !important}.pl-sm-5,.px-sm-5{padding-left:3rem !important}.m-sm-n1{margin:-0.25rem !important}.mt-sm-n1,.my-sm-n1{margin-top:-0.25rem !important}.mr-sm-n1,.mx-sm-n1{margin-right:-0.25rem !important}.mb-sm-n1,.my-sm-n1{margin-bottom:-0.25rem !important}.ml-sm-n1,.mx-sm-n1{margin-left:-0.25rem !important}.m-sm-n2{margin:-0.5rem !important}.mt-sm-n2,.my-sm-n2{margin-top:-0.5rem !important}.mr-sm-n2,.mx-sm-n2{margin-right:-0.5rem !important}.mb-sm-n2,.my-sm-n2{margin-bottom:-0.5rem !important}.ml-sm-n2,.mx-sm-n2{margin-left:-0.5rem !important}.m-sm-n3{margin:-1rem !important}.mt-sm-n3,.my-sm-n3{margin-top:-1rem !important}.mr-sm-n3,.mx-sm-n3{margin-right:-1rem !important}.mb-sm-n3,.my-sm-n3{margin-bottom:-1rem !important}.ml-sm-n3,.mx-sm-n3{margin-left:-1rem !important}.m-sm-n4{margin:-1.5rem !important}.mt-sm-n4,.my-sm-n4{margin-top:-1.5rem !important}.mr-sm-n4,.mx-sm-n4{margin-right:-1.5rem !important}.mb-sm-n4,.my-sm-n4{margin-bottom:-1.5rem !important}.ml-sm-n4,.mx-sm-n4{margin-left:-1.5rem !important}.m-sm-n5{margin:-3rem !important}.mt-sm-n5,.my-sm-n5{margin-top:-3rem !important}.mr-sm-n5,.mx-sm-n5{margin-right:-3rem !important}.mb-sm-n5,.my-sm-n5{margin-bottom:-3rem !important}.ml-sm-n5,.mx-sm-n5{margin-left:-3rem !important}.m-sm-auto{margin:auto !important}.mt-sm-auto,.my-sm-auto{margin-top:auto !important}.mr-sm-auto,.mx-sm-auto{margin-right:auto !important}.mb-sm-auto,.my-sm-auto{margin-bottom:auto !important}.ml-sm-auto,.mx-sm-auto{margin-left:auto !important}}@media (min-width: 768px){.m-md-0{margin:0 !important}.mt-md-0,.my-md-0{margin-top:0 !important}.mr-md-0,.mx-md-0{margin-right:0 !important}.mb-md-0,.my-md-0{margin-bottom:0 !important}.ml-md-0,.mx-md-0{margin-left:0 !important}.m-md-1{margin:0.25rem !important}.mt-md-1,.my-md-1{margin-top:0.25rem !important}.mr-md-1,.mx-md-1{margin-right:0.25rem !important}.mb-md-1,.my-md-1{margin-bottom:0.25rem !important}.ml-md-1,.mx-md-1{margin-left:0.25rem !important}.m-md-2{margin:0.5rem !important}.mt-md-2,.my-md-2{margin-top:0.5rem !important}.mr-md-2,.mx-md-2{margin-right:0.5rem !important}.mb-md-2,.my-md-2{margin-bottom:0.5rem !important}.ml-md-2,.mx-md-2{margin-left:0.5rem !important}.m-md-3{margin:1rem !important}.mt-md-3,.my-md-3{margin-top:1rem !important}.mr-md-3,.mx-md-3{margin-right:1rem !important}.mb-md-3,.my-md-3{margin-bottom:1rem !important}.ml-md-3,.mx-md-3{margin-left:1rem !important}.m-md-4{margin:1.5rem !important}.mt-md-4,.my-md-4{margin-top:1.5rem !important}.mr-md-4,.mx-md-4{margin-right:1.5rem !important}.mb-md-4,.my-md-4{margin-bottom:1.5rem !important}.ml-md-4,.mx-md-4{margin-left:1.5rem !important}.m-md-5{margin:3rem !important}.mt-md-5,.my-md-5{margin-top:3rem !important}.mr-md-5,.mx-md-5{margin-right:3rem !important}.mb-md-5,.my-md-5{margin-bottom:3rem !important}.ml-md-5,.mx-md-5{margin-left:3rem !important}.p-md-0{padding:0 !important}.pt-md-0,.py-md-0{padding-top:0 !important}.pr-md-0,.px-md-0{padding-right:0 !important}.pb-md-0,.py-md-0{padding-bottom:0 !important}.pl-md-0,.px-md-0{padding-left:0 !important}.p-md-1{padding:0.25rem !important}.pt-md-1,.py-md-1{padding-top:0.25rem !important}.pr-md-1,.px-md-1{padding-right:0.25rem !important}.pb-md-1,.py-md-1{padding-bottom:0.25rem !important}.pl-md-1,.px-md-1{padding-left:0.25rem !important}.p-md-2{padding:0.5rem !important}.pt-md-2,.py-md-2{padding-top:0.5rem !important}.pr-md-2,.px-md-2{padding-right:0.5rem !important}.pb-md-2,.py-md-2{padding-bottom:0.5rem !important}.pl-md-2,.px-md-2{padding-left:0.5rem !important}.p-md-3{padding:1rem !important}.pt-md-3,.py-md-3{padding-top:1rem !important}.pr-md-3,.px-md-3{padding-right:1rem !important}.pb-md-3,.py-md-3{padding-bottom:1rem !important}.pl-md-3,.px-md-3{padding-left:1rem !important}.p-md-4{padding:1.5rem !important}.pt-md-4,.py-md-4{padding-top:1.5rem !important}.pr-md-4,.px-md-4{padding-right:1.5rem !important}.pb-md-4,.py-md-4{padding-bottom:1.5rem !important}.pl-md-4,.px-md-4{padding-left:1.5rem !important}.p-md-5{padding:3rem !important}.pt-md-5,.py-md-5{padding-top:3rem !important}.pr-md-5,.px-md-5{padding-right:3rem !important}.pb-md-5,.py-md-5{padding-bottom:3rem !important}.pl-md-5,.px-md-5{padding-left:3rem !important}.m-md-n1{margin:-0.25rem !important}.mt-md-n1,.my-md-n1{margin-top:-0.25rem !important}.mr-md-n1,.mx-md-n1{margin-right:-0.25rem !important}.mb-md-n1,.my-md-n1{margin-bottom:-0.25rem !important}.ml-md-n1,.mx-md-n1{margin-left:-0.25rem !important}.m-md-n2{margin:-0.5rem !important}.mt-md-n2,.my-md-n2{margin-top:-0.5rem !important}.mr-md-n2,.mx-md-n2{margin-right:-0.5rem !important}.mb-md-n2,.my-md-n2{margin-bottom:-0.5rem !important}.ml-md-n2,.mx-md-n2{margin-left:-0.5rem !important}.m-md-n3{margin:-1rem !important}.mt-md-n3,.my-md-n3{margin-top:-1rem !important}.mr-md-n3,.mx-md-n3{margin-right:-1rem !important}.mb-md-n3,.my-md-n3{margin-bottom:-1rem !important}.ml-md-n3,.mx-md-n3{margin-left:-1rem !important}.m-md-n4{margin:-1.5rem !important}.mt-md-n4,.my-md-n4{margin-top:-1.5rem !important}.mr-md-n4,.mx-md-n4{margin-right:-1.5rem !important}.mb-md-n4,.my-md-n4{margin-bottom:-1.5rem !important}.ml-md-n4,.mx-md-n4{margin-left:-1.5rem !important}.m-md-n5{margin:-3rem !important}.mt-md-n5,.my-md-n5{margin-top:-3rem !important}.mr-md-n5,.mx-md-n5{margin-right:-3rem !important}.mb-md-n5,.my-md-n5{margin-bottom:-3rem !important}.ml-md-n5,.mx-md-n5{margin-left:-3rem !important}.m-md-auto{margin:auto !important}.mt-md-auto,.my-md-auto{margin-top:auto !important}.mr-md-auto,.mx-md-auto{margin-right:auto !important}.mb-md-auto,.my-md-auto{margin-bottom:auto !important}.ml-md-auto,.mx-md-auto{margin-left:auto !important}}@media (min-width: 992px){.m-lg-0{margin:0 !important}.mt-lg-0,.my-lg-0{margin-top:0 !important}.mr-lg-0,.mx-lg-0{margin-right:0 !important}.mb-lg-0,.my-lg-0{margin-bottom:0 !important}.ml-lg-0,.mx-lg-0{margin-left:0 !important}.m-lg-1{margin:0.25rem !important}.mt-lg-1,.my-lg-1{margin-top:0.25rem !important}.mr-lg-1,.mx-lg-1{margin-right:0.25rem !important}.mb-lg-1,.my-lg-1{margin-bottom:0.25rem !important}.ml-lg-1,.mx-lg-1{margin-left:0.25rem !important}.m-lg-2{margin:0.5rem !important}.mt-lg-2,.my-lg-2{margin-top:0.5rem !important}.mr-lg-2,.mx-lg-2{margin-right:0.5rem !important}.mb-lg-2,.my-lg-2{margin-bottom:0.5rem !important}.ml-lg-2,.mx-lg-2{margin-left:0.5rem !important}.m-lg-3{margin:1rem !important}.mt-lg-3,.my-lg-3{margin-top:1rem !important}.mr-lg-3,.mx-lg-3{margin-right:1rem !important}.mb-lg-3,.my-lg-3{margin-bottom:1rem !important}.ml-lg-3,.mx-lg-3{margin-left:1rem !important}.m-lg-4{margin:1.5rem !important}.mt-lg-4,.my-lg-4{margin-top:1.5rem !important}.mr-lg-4,.mx-lg-4{margin-right:1.5rem !important}.mb-lg-4,.my-lg-4{margin-bottom:1.5rem !important}.ml-lg-4,.mx-lg-4{margin-left:1.5rem !important}.m-lg-5{margin:3rem !important}.mt-lg-5,.my-lg-5{margin-top:3rem !important}.mr-lg-5,.mx-lg-5{margin-right:3rem !important}.mb-lg-5,.my-lg-5{margin-bottom:3rem !important}.ml-lg-5,.mx-lg-5{margin-left:3rem !important}.p-lg-0{padding:0 !important}.pt-lg-0,.py-lg-0{padding-top:0 !important}.pr-lg-0,.px-lg-0{padding-right:0 !important}.pb-lg-0,.py-lg-0{padding-bottom:0 !important}.pl-lg-0,.px-lg-0{padding-left:0 !important}.p-lg-1{padding:0.25rem !important}.pt-lg-1,.py-lg-1{padding-top:0.25rem !important}.pr-lg-1,.px-lg-1{padding-right:0.25rem !important}.pb-lg-1,.py-lg-1{padding-bottom:0.25rem !important}.pl-lg-1,.px-lg-1{padding-left:0.25rem !important}.p-lg-2{padding:0.5rem !important}.pt-lg-2,.py-lg-2{padding-top:0.5rem !important}.pr-lg-2,.px-lg-2{padding-right:0.5rem !important}.pb-lg-2,.py-lg-2{padding-bottom:0.5rem !important}.pl-lg-2,.px-lg-2{padding-left:0.5rem !important}.p-lg-3{padding:1rem !important}.pt-lg-3,.py-lg-3{padding-top:1rem !important}.pr-lg-3,.px-lg-3{padding-right:1rem !important}.pb-lg-3,.py-lg-3{padding-bottom:1rem !important}.pl-lg-3,.px-lg-3{padding-left:1rem !important}.p-lg-4{padding:1.5rem !important}.pt-lg-4,.py-lg-4{padding-top:1.5rem !important}.pr-lg-4,.px-lg-4{padding-right:1.5rem !important}.pb-lg-4,.py-lg-4{padding-bottom:1.5rem !important}.pl-lg-4,.px-lg-4{padding-left:1.5rem !important}.p-lg-5{padding:3rem !important}.pt-lg-5,.py-lg-5{padding-top:3rem !important}.pr-lg-5,.px-lg-5{padding-right:3rem !important}.pb-lg-5,.py-lg-5{padding-bottom:3rem !important}.pl-lg-5,.px-lg-5{padding-left:3rem !important}.m-lg-n1{margin:-0.25rem !important}.mt-lg-n1,.my-lg-n1{margin-top:-0.25rem !important}.mr-lg-n1,.mx-lg-n1{margin-right:-0.25rem !important}.mb-lg-n1,.my-lg-n1{margin-bottom:-0.25rem !important}.ml-lg-n1,.mx-lg-n1{margin-left:-0.25rem !important}.m-lg-n2{margin:-0.5rem !important}.mt-lg-n2,.my-lg-n2{margin-top:-0.5rem !important}.mr-lg-n2,.mx-lg-n2{margin-right:-0.5rem !important}.mb-lg-n2,.my-lg-n2{margin-bottom:-0.5rem !important}.ml-lg-n2,.mx-lg-n2{margin-left:-0.5rem !important}.m-lg-n3{margin:-1rem !important}.mt-lg-n3,.my-lg-n3{margin-top:-1rem !important}.mr-lg-n3,.mx-lg-n3{margin-right:-1rem !important}.mb-lg-n3,.my-lg-n3{margin-bottom:-1rem !important}.ml-lg-n3,.mx-lg-n3{margin-left:-1rem !important}.m-lg-n4{margin:-1.5rem !important}.mt-lg-n4,.my-lg-n4{margin-top:-1.5rem !important}.mr-lg-n4,.mx-lg-n4{margin-right:-1.5rem !important}.mb-lg-n4,.my-lg-n4{margin-bottom:-1.5rem !important}.ml-lg-n4,.mx-lg-n4{margin-left:-1.5rem !important}.m-lg-n5{margin:-3rem !important}.mt-lg-n5,.my-lg-n5{margin-top:-3rem !important}.mr-lg-n5,.mx-lg-n5{margin-right:-3rem !important}.mb-lg-n5,.my-lg-n5{margin-bottom:-3rem !important}.ml-lg-n5,.mx-lg-n5{margin-left:-3rem !important}.m-lg-auto{margin:auto !important}.mt-lg-auto,.my-lg-auto{margin-top:auto !important}.mr-lg-auto,.mx-lg-auto{margin-right:auto !important}.mb-lg-auto,.my-lg-auto{margin-bottom:auto !important}.ml-lg-auto,.mx-lg-auto{margin-left:auto !important}}@media (min-width: 1200px){.m-xl-0{margin:0 !important}.mt-xl-0,.my-xl-0{margin-top:0 !important}.mr-xl-0,.mx-xl-0{margin-right:0 !important}.mb-xl-0,.my-xl-0{margin-bottom:0 !important}.ml-xl-0,.mx-xl-0{margin-left:0 !important}.m-xl-1{margin:0.25rem !important}.mt-xl-1,.my-xl-1{margin-top:0.25rem !important}.mr-xl-1,.mx-xl-1{margin-right:0.25rem !important}.mb-xl-1,.my-xl-1{margin-bottom:0.25rem !important}.ml-xl-1,.mx-xl-1{margin-left:0.25rem !important}.m-xl-2{margin:0.5rem !important}.mt-xl-2,.my-xl-2{margin-top:0.5rem !important}.mr-xl-2,.mx-xl-2{margin-right:0.5rem !important}.mb-xl-2,.my-xl-2{margin-bottom:0.5rem !important}.ml-xl-2,.mx-xl-2{margin-left:0.5rem !important}.m-xl-3{margin:1rem !important}.mt-xl-3,.my-xl-3{margin-top:1rem !important}.mr-xl-3,.mx-xl-3{margin-right:1rem !important}.mb-xl-3,.my-xl-3{margin-bottom:1rem !important}.ml-xl-3,.mx-xl-3{margin-left:1rem !important}.m-xl-4{margin:1.5rem !important}.mt-xl-4,.my-xl-4{margin-top:1.5rem !important}.mr-xl-4,.mx-xl-4{margin-right:1.5rem !important}.mb-xl-4,.my-xl-4{margin-bottom:1.5rem !important}.ml-xl-4,.mx-xl-4{margin-left:1.5rem !important}.m-xl-5{margin:3rem !important}.mt-xl-5,.my-xl-5{margin-top:3rem !important}.mr-xl-5,.mx-xl-5{margin-right:3rem !important}.mb-xl-5,.my-xl-5{margin-bottom:3rem !important}.ml-xl-5,.mx-xl-5{margin-left:3rem !important}.p-xl-0{padding:0 !important}.pt-xl-0,.py-xl-0{padding-top:0 !important}.pr-xl-0,.px-xl-0{padding-right:0 !important}.pb-xl-0,.py-xl-0{padding-bottom:0 !important}.pl-xl-0,.px-xl-0{padding-left:0 !important}.p-xl-1{padding:0.25rem !important}.pt-xl-1,.py-xl-1{padding-top:0.25rem !important}.pr-xl-1,.px-xl-1{padding-right:0.25rem !important}.pb-xl-1,.py-xl-1{padding-bottom:0.25rem !important}.pl-xl-1,.px-xl-1{padding-left:0.25rem !important}.p-xl-2{padding:0.5rem !important}.pt-xl-2,.py-xl-2{padding-top:0.5rem !important}.pr-xl-2,.px-xl-2{padding-right:0.5rem !important}.pb-xl-2,.py-xl-2{padding-bottom:0.5rem !important}.pl-xl-2,.px-xl-2{padding-left:0.5rem !important}.p-xl-3{padding:1rem !important}.pt-xl-3,.py-xl-3{padding-top:1rem !important}.pr-xl-3,.px-xl-3{padding-right:1rem !important}.pb-xl-3,.py-xl-3{padding-bottom:1rem !important}.pl-xl-3,.px-xl-3{padding-left:1rem !important}.p-xl-4{padding:1.5rem !important}.pt-xl-4,.py-xl-4{padding-top:1.5rem !important}.pr-xl-4,.px-xl-4{padding-right:1.5rem !important}.pb-xl-4,.py-xl-4{padding-bottom:1.5rem !important}.pl-xl-4,.px-xl-4{padding-left:1.5rem !important}.p-xl-5{padding:3rem !important}.pt-xl-5,.py-xl-5{padding-top:3rem !important}.pr-xl-5,.px-xl-5{padding-right:3rem !important}.pb-xl-5,.py-xl-5{padding-bottom:3rem !important}.pl-xl-5,.px-xl-5{padding-left:3rem !important}.m-xl-n1{margin:-0.25rem !important}.mt-xl-n1,.my-xl-n1{margin-top:-0.25rem !important}.mr-xl-n1,.mx-xl-n1{margin-right:-0.25rem !important}.mb-xl-n1,.my-xl-n1{margin-bottom:-0.25rem !important}.ml-xl-n1,.mx-xl-n1{margin-left:-0.25rem !important}.m-xl-n2{margin:-0.5rem !important}.mt-xl-n2,.my-xl-n2{margin-top:-0.5rem !important}.mr-xl-n2,.mx-xl-n2{margin-right:-0.5rem !important}.mb-xl-n2,.my-xl-n2{margin-bottom:-0.5rem !important}.ml-xl-n2,.mx-xl-n2{margin-left:-0.5rem !important}.m-xl-n3{margin:-1rem !important}.mt-xl-n3,.my-xl-n3{margin-top:-1rem !important}.mr-xl-n3,.mx-xl-n3{margin-right:-1rem !important}.mb-xl-n3,.my-xl-n3{margin-bottom:-1rem !important}.ml-xl-n3,.mx-xl-n3{margin-left:-1rem !important}.m-xl-n4{margin:-1.5rem !important}.mt-xl-n4,.my-xl-n4{margin-top:-1.5rem !important}.mr-xl-n4,.mx-xl-n4{margin-right:-1.5rem !important}.mb-xl-n4,.my-xl-n4{margin-bottom:-1.5rem !important}.ml-xl-n4,.mx-xl-n4{margin-left:-1.5rem !important}.m-xl-n5{margin:-3rem !important}.mt-xl-n5,.my-xl-n5{margin-top:-3rem !important}.mr-xl-n5,.mx-xl-n5{margin-right:-3rem !important}.mb-xl-n5,.my-xl-n5{margin-bottom:-3rem !important}.ml-xl-n5,.mx-xl-n5{margin-left:-3rem !important}.m-xl-auto{margin:auto !important}.mt-xl-auto,.my-xl-auto{margin-top:auto !important}.mr-xl-auto,.mx-xl-auto{margin-right:auto !important}.mb-xl-auto,.my-xl-auto{margin-bottom:auto !important}.ml-xl-auto,.mx-xl-auto{margin-left:auto !important}}.text-monospace{font-family:SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace !important}.text-justify{text-align:justify !important}.text-wrap{white-space:normal !important}.text-nowrap{white-space:nowrap !important}.text-truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.text-left{text-align:left !important}.text-right{text-align:right !important}.text-center{text-align:center !important}@media (min-width: 576px){.text-sm-left{text-align:left !important}.text-sm-right{text-align:right !important}.text-sm-center{text-align:center !important}}@media (min-width: 768px){.text-md-left{text-align:left !important}.text-md-right{text-align:right !important}.text-md-center{text-align:center !important}}@media (min-width: 992px){.text-lg-left{text-align:left !important}.text-lg-right{text-align:right !important}.text-lg-center{text-align:center !important}}@media (min-width: 1200px){.text-xl-left{text-align:left !important}.text-xl-right{text-align:right !important}.text-xl-center{text-align:center !important}}.text-lowercase{text-transform:lowercase !important}.text-uppercase{text-transform:uppercase !important}.text-capitalize{text-transform:capitalize !important}.font-weight-light{font-weight:300 !important}.font-weight-lighter{font-weight:lighter !important}.font-weight-normal{font-weight:400 !important}.font-weight-bold{font-weight:700 !important}.font-weight-bolder{font-weight:bolder !important}.font-italic{font-style:italic !important}.text-white{color:#fff !important}.text-primary{color:#B58900 !important}a.text-primary:hover,a.text-primary:focus{color:#694f00 !important}.text-secondary{color:#839496 !important}a.text-secondary:hover,a.text-secondary:focus{color:#5e6d6f !important}.text-success{color:#2AA198 !important}a.text-success:hover,a.text-success:focus{color:#1a645f !important}.text-info{color:#268BD2 !important}a.text-info:hover,a.text-info:focus{color:#1a6091 !important}.text-warning{color:#CB4B16 !important}a.text-warning:hover,a.text-warning:focus{color:#86320f !important}.text-danger{color:#D33682 !important}a.text-danger:hover,a.text-danger:focus{color:#9b225c !important}.text-light{color:#FDF6E3 !important}a.text-light:hover,a.text-light:focus{color:#f8df9c !important}.text-dark{color:#073642 !important}a.text-dark:hover,a.text-dark:focus{color:black !important}.text-body{color:#839496 !important}.text-muted{color:#839496 !important}.text-black-50{color:rgba(0,0,0,0.5) !important}.text-white-50{color:rgba(255,255,255,0.5) !important}.text-hide{font:0/0 a;color:transparent;text-shadow:none;background-color:transparent;border:0}.text-decoration-none{text-decoration:none !important}.text-break{word-break:break-word !important;overflow-wrap:break-word !important}.text-reset{color:inherit !important}.visible{visibility:visible !important}.invisible{visibility:hidden !important}@media print{*,*::before,*::after{text-shadow:none !important;-webkit-box-shadow:none !important;box-shadow:none !important}a:not(.btn){text-decoration:underline}abbr[title]::after{content:" (" attr(title) ")"}pre{white-space:pre-wrap !important}pre,blockquote{border:1px solid #adb5bd;page-break-inside:avoid}thead{display:table-header-group}tr,img{page-break-inside:avoid}p,h2,h3{orphans:3;widows:3}h2,h3{page-break-after:avoid}@page{size:a3}body{min-width:992px !important}.container{min-width:992px !important}.navbar{display:none}.badge{border:1px solid #000}.table{border-collapse:collapse !important}.table td,.table th{background-color:#fff !important}.table-bordered th,.table-bordered td{border:1px solid #dee2e6 !important}.table-dark{color:inherit}.table-dark th,.table-dark td,.table-dark thead th,.table-dark tbody+tbody{border-color:#073642}.table .thead-dark th{color:inherit;border-color:#073642}}.btn-primary{background:#B58900 -webkit-gradient(linear, left top, left bottom, from(#c09b26), to(#B58900)) repeat-x;background:#B58900 linear-gradient(180deg, #c09b26, #B58900) repeat-x}.btn-secondary{background:#839496 -webkit-gradient(linear, left top, left bottom, from(#96a4a6), to(#839496)) repeat-x;background:#839496 linear-gradient(180deg, #96a4a6, #839496) repeat-x}.btn-success{background:#2AA198 -webkit-gradient(linear, left top, left bottom, from(#4aafa7), to(#2AA198)) repeat-x;background:#2AA198 linear-gradient(180deg, #4aafa7, #2AA198) repeat-x}.btn-info{background:#268BD2 -webkit-gradient(linear, left top, left bottom, from(#479cd9), to(#268BD2)) repeat-x;background:#268BD2 linear-gradient(180deg, #479cd9, #268BD2) repeat-x}.btn-warning{background:#CB4B16 -webkit-gradient(linear, left top, left bottom, from(#d36639), to(#CB4B16)) repeat-x;background:#CB4B16 linear-gradient(180deg, #d36639, #CB4B16) repeat-x}.btn-danger{background:#D33682 -webkit-gradient(linear, left top, left bottom, from(#da5495), to(#D33682)) repeat-x;background:#D33682 linear-gradient(180deg, #da5495, #D33682) repeat-x}.btn-light{background:#FDF6E3 -webkit-gradient(linear, left top, left bottom, from(#fdf7e7), to(#FDF6E3)) repeat-x;background:#FDF6E3 linear-gradient(180deg, #fdf7e7, #FDF6E3) repeat-x}.btn-dark{background:#073642 -webkit-gradient(linear, left top, left bottom, from(#2c545e), to(#073642)) repeat-x;background:#073642 linear-gradient(180deg, #2c545e, #073642) repeat-x}.table-primary,.table-secondary,.table-dark,.table-success,.table-info,.table-warning,.table-danger{color:#fff}.table-primary,.table-primary>th,.table-primary>td{background-color:#B58900}.table-secondary,.table-secondary>th,.table-secondary>td{background-color:#839496}.table-light,.table-light>th,.table-light>td{background-color:#FDF6E3}.table-dark,.table-dark>th,.table-dark>td{background-color:#073642}.table-success,.table-success>th,.table-success>td{background-color:#2AA198}.table-info,.table-info>th,.table-info>td{background-color:#268BD2}.table-danger,.table-danger>th,.table-danger>td{background-color:#D33682}.table-warning,.table-warning>th,.table-warning>td{background-color:#CB4B16}.table-active,.table-active>th,.table-active>td{background-color:rgba(255,255,255,0.075)}.table-hover .table-primary:hover,.table-hover .table-primary:hover>th,.table-hover .table-primary:hover>td{background-color:#9c7600}.table-hover .table-secondary:hover,.table-hover .table-secondary:hover>th,.table-hover .table-secondary:hover>td{background-color:#75888a}.table-hover .table-light:hover,.table-hover .table-light:hover>th,.table-hover .table-light:hover>td{background-color:#fbeecb}.table-hover .table-dark:hover,.table-hover .table-dark:hover>th,.table-hover .table-dark:hover>td{background-color:#05232b}.table-hover .table-success:hover,.table-hover .table-success:hover>th,.table-hover .table-success:hover>td{background-color:#258d85}.table-hover .table-info:hover,.table-hover .table-info:hover>th,.table-hover .table-info:hover>td{background-color:#227dbc}.table-hover .table-danger:hover,.table-hover .table-danger:hover>th,.table-hover .table-danger:hover>td{background-color:#c42b75}.table-hover .table-warning:hover,.table-hover .table-warning:hover>th,.table-hover .table-warning:hover>td{background-color:#b44314}.table-hover .table-active:hover,.table-hover .table-active:hover>th,.table-hover .table-active:hover>td{background-color:rgba(255,255,255,0.075)}.alert{border:none;color:#fff}.alert a,.alert .alert-link{color:#fff;text-decoration:underline}.alert-primary{background:#B58900 -webkit-gradient(linear, left top, left bottom, from(#c09b26), to(#B58900)) repeat-x;background:#B58900 linear-gradient(180deg, #c09b26, #B58900) repeat-x}.alert-secondary{background:#839496 -webkit-gradient(linear, left top, left bottom, from(#96a4a6), to(#839496)) repeat-x;background:#839496 linear-gradient(180deg, #96a4a6, #839496) repeat-x}.alert-success{background:#2AA198 -webkit-gradient(linear, left top, left bottom, from(#4aafa7), to(#2AA198)) repeat-x;background:#2AA198 linear-gradient(180deg, #4aafa7, #2AA198) repeat-x}.alert-info{background:#268BD2 -webkit-gradient(linear, left top, left bottom, from(#479cd9), to(#268BD2)) repeat-x;background:#268BD2 linear-gradient(180deg, #479cd9, #268BD2) repeat-x}.alert-warning{background:#CB4B16 -webkit-gradient(linear, left top, left bottom, from(#d36639), to(#CB4B16)) repeat-x;background:#CB4B16 linear-gradient(180deg, #d36639, #CB4B16) repeat-x}.alert-danger{background:#D33682 -webkit-gradient(linear, left top, left bottom, from(#da5495), to(#D33682)) repeat-x;background:#D33682 linear-gradient(180deg, #da5495, #D33682) repeat-x}.alert-light{background:#FDF6E3 -webkit-gradient(linear, left top, left bottom, from(#fdf7e7), to(#FDF6E3)) repeat-x;background:#FDF6E3 linear-gradient(180deg, #fdf7e7, #FDF6E3) repeat-x}.alert-dark{background:#073642 -webkit-gradient(linear, left top, left bottom, from(#2c545e), to(#073642)) repeat-x;background:#073642 linear-gradient(180deg, #2c545e, #073642) repeat-x}.alert-light,.alert-light a:not(.btn),.alert-light .alert-link{color:#002B36} diff --git a/EduWaiterAppClient/src/test.ts b/EduWaiterAppClient/src/test.ts new file mode 100644 index 0000000..1631789 --- /dev/null +++ b/EduWaiterAppClient/src/test.ts @@ -0,0 +1,20 @@ +// This file is required by karma.conf.js and loads recursively all the .spec and framework files + +import 'zone.js/dist/zone-testing'; +import { getTestBed } from '@angular/core/testing'; +import { + BrowserDynamicTestingModule, + platformBrowserDynamicTesting +} from '@angular/platform-browser-dynamic/testing'; + +declare const require: any; + +// First, initialize the Angular testing environment. +getTestBed().initTestEnvironment( + BrowserDynamicTestingModule, + platformBrowserDynamicTesting() +); +// Then we find all the tests. +const context = require.context('./', true, /\.spec\.ts$/); +// And load the modules. +context.keys().map(context); diff --git a/EduWaiterAppClient/src/tsconfig.app.json b/EduWaiterAppClient/src/tsconfig.app.json new file mode 100644 index 0000000..190fd30 --- /dev/null +++ b/EduWaiterAppClient/src/tsconfig.app.json @@ -0,0 +1,11 @@ +{ + "extends": "../tsconfig.json", + "compilerOptions": { + "outDir": "../out-tsc/app", + "types": [] + }, + "exclude": [ + "test.ts", + "**/*.spec.ts" + ] +} diff --git a/EduWaiterAppClient/src/tsconfig.spec.json b/EduWaiterAppClient/src/tsconfig.spec.json new file mode 100644 index 0000000..de77336 --- /dev/null +++ b/EduWaiterAppClient/src/tsconfig.spec.json @@ -0,0 +1,18 @@ +{ + "extends": "../tsconfig.json", + "compilerOptions": { + "outDir": "../out-tsc/spec", + "types": [ + "jasmine", + "node" + ] + }, + "files": [ + "test.ts", + "polyfills.ts" + ], + "include": [ + "**/*.spec.ts", + "**/*.d.ts" + ] +} diff --git a/EduWaiterAppClient/src/tslint.json b/EduWaiterAppClient/src/tslint.json new file mode 100644 index 0000000..aa7c3ee --- /dev/null +++ b/EduWaiterAppClient/src/tslint.json @@ -0,0 +1,17 @@ +{ + "extends": "../tslint.json", + "rules": { + "directive-selector": [ + true, + "attribute", + "app", + "camelCase" + ], + "component-selector": [ + true, + "element", + "app", + "kebab-case" + ] + } +} diff --git a/EduWaiterAppClient/tsconfig.json b/EduWaiterAppClient/tsconfig.json new file mode 100644 index 0000000..b271fd9 --- /dev/null +++ b/EduWaiterAppClient/tsconfig.json @@ -0,0 +1,22 @@ +{ + "compileOnSave": false, + "compilerOptions": { + "baseUrl": "./", + "outDir": "./dist/out-tsc", + "sourceMap": true, + "declaration": false, + "module": "es2015", + "moduleResolution": "node", + "emitDecoratorMetadata": true, + "experimentalDecorators": true, + "importHelpers": true, + "target": "es5", + "typeRoots": [ + "node_modules/@types" + ], + "lib": [ + "es2018", + "dom" + ] + } +} diff --git a/EduWaiterAppClient/tslint.json b/EduWaiterAppClient/tslint.json new file mode 100644 index 0000000..868ecba --- /dev/null +++ b/EduWaiterAppClient/tslint.json @@ -0,0 +1,75 @@ +{ + "extends": "tslint:recommended", + "rulesDirectory": [ + "codelyzer" + ], + "rules": { + "array-type": false, + "arrow-parens": false, + "deprecation": { + "severity": "warn" + }, + "import-blacklist": [ + true, + "rxjs/Rx" + ], + "interface-name": false, + "max-classes-per-file": false, + "max-line-length": [ + true, + 140 + ], + "member-access": false, + "member-ordering": [ + true, + { + "order": [ + "static-field", + "instance-field", + "static-method", + "instance-method" + ] + } + ], + "no-consecutive-blank-lines": false, + "no-console": [ + true, + "debug", + "info", + "time", + "timeEnd", + "trace" + ], + "no-empty": false, + "no-inferrable-types": [ + true, + "ignore-params" + ], + "no-non-null-assertion": true, + "no-redundant-jsdoc": true, + "no-switch-case-fall-through": true, + "no-use-before-declare": true, + "no-var-requires": false, + "object-literal-key-quotes": [ + true, + "as-needed" + ], + "object-literal-sort-keys": false, + "ordered-imports": false, + "quotemark": [ + true, + "single" + ], + "trailing-comma": false, + "no-output-on-prefix": true, + "use-input-property-decorator": true, + "use-output-property-decorator": true, + "use-host-property-decorator": true, + "no-input-rename": true, + "no-output-rename": true, + "use-life-cycle-interface": true, + "use-pipe-transform-interface": true, + "component-class-suffix": true, + "directive-class-suffix": true + } +} diff --git a/EduWaiterAppServer/.gitignore b/EduWaiterAppServer/.gitignore new file mode 100644 index 0000000..153c933 --- /dev/null +++ b/EduWaiterAppServer/.gitignore @@ -0,0 +1,29 @@ +HELP.md +/target/ +!.mvn/wrapper/maven-wrapper.jar + +### STS ### +.apt_generated +.classpath +.factorypath +.project +.settings +.springBeans +.sts4-cache + +### IntelliJ IDEA ### +.idea +*.iws +*.iml +*.ipr + +### NetBeans ### +/nbproject/private/ +/nbbuild/ +/dist/ +/nbdist/ +/.nb-gradle/ +/build/ + +### VS Code ### +.vscode/ diff --git a/EduWaiterAppServer/.mvn/wrapper/MavenWrapperDownloader.java b/EduWaiterAppServer/.mvn/wrapper/MavenWrapperDownloader.java new file mode 100644 index 0000000..72308aa --- /dev/null +++ b/EduWaiterAppServer/.mvn/wrapper/MavenWrapperDownloader.java @@ -0,0 +1,114 @@ +/* +Licensed to the Apache Software Foundation (ASF) under one +or more contributor license agreements. See the NOTICE file +distributed with this work for additional information +regarding copyright ownership. The ASF licenses this file +to you under the Apache License, Version 2.0 (the +"License"); you may not use this file except in compliance +with the License. You may obtain a copy of the License at + + https://www.apache.org/licenses/LICENSE-2.0 + +Unless required by applicable law or agreed to in writing, +software distributed under the License is distributed on an +"AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY +KIND, either express or implied. See the License for the +specific language governing permissions and limitations +under the License. +*/ + +import java.io.File; +import java.io.FileInputStream; +import java.io.FileOutputStream; +import java.io.IOException; +import java.net.URL; +import java.nio.channels.Channels; +import java.nio.channels.ReadableByteChannel; +import java.util.Properties; + +public class MavenWrapperDownloader { + + /** + * Default URL to download the maven-wrapper.jar from, if no 'downloadUrl' is provided. + */ + private static final String DEFAULT_DOWNLOAD_URL = + "https://repo.maven.apache.org/maven2/io/takari/maven-wrapper/0.4.2/maven-wrapper-0.4.2.jar"; + + /** + * Path to the maven-wrapper.properties file, which might contain a downloadUrl property to + * use instead of the default one. + */ + private static final String MAVEN_WRAPPER_PROPERTIES_PATH = + ".mvn/wrapper/maven-wrapper.properties"; + + /** + * Path where the maven-wrapper.jar will be saved to. + */ + private static final String MAVEN_WRAPPER_JAR_PATH = + ".mvn/wrapper/maven-wrapper.jar"; + + /** + * Name of the property which should be used to override the default download url for the wrapper. + */ + private static final String PROPERTY_NAME_WRAPPER_URL = "wrapperUrl"; + + public static void main(String args[]) { + System.out.println("- Downloader started"); + File baseDirectory = new File(args[0]); + System.out.println("- Using base directory: " + baseDirectory.getAbsolutePath()); + + // If the maven-wrapper.properties exists, read it and check if it contains a custom + // wrapperUrl parameter. + File mavenWrapperPropertyFile = new File(baseDirectory, MAVEN_WRAPPER_PROPERTIES_PATH); + String url = DEFAULT_DOWNLOAD_URL; + if(mavenWrapperPropertyFile.exists()) { + FileInputStream mavenWrapperPropertyFileInputStream = null; + try { + mavenWrapperPropertyFileInputStream = new FileInputStream(mavenWrapperPropertyFile); + Properties mavenWrapperProperties = new Properties(); + mavenWrapperProperties.load(mavenWrapperPropertyFileInputStream); + url = mavenWrapperProperties.getProperty(PROPERTY_NAME_WRAPPER_URL, url); + } catch (IOException e) { + System.out.println("- ERROR loading '" + MAVEN_WRAPPER_PROPERTIES_PATH + "'"); + } finally { + try { + if(mavenWrapperPropertyFileInputStream != null) { + mavenWrapperPropertyFileInputStream.close(); + } + } catch (IOException e) { + // Ignore ... + } + } + } + System.out.println("- Downloading from: : " + url); + + File outputFile = new File(baseDirectory.getAbsolutePath(), MAVEN_WRAPPER_JAR_PATH); + if(!outputFile.getParentFile().exists()) { + if(!outputFile.getParentFile().mkdirs()) { + System.out.println( + "- ERROR creating output direcrory '" + outputFile.getParentFile().getAbsolutePath() + "'"); + } + } + System.out.println("- Downloading to: " + outputFile.getAbsolutePath()); + try { + downloadFileFromURL(url, outputFile); + System.out.println("Done"); + System.exit(0); + } catch (Throwable e) { + System.out.println("- Error downloading"); + e.printStackTrace(); + System.exit(1); + } + } + + private static void downloadFileFromURL(String urlString, File destination) throws Exception { + URL website = new URL(urlString); + ReadableByteChannel rbc; + rbc = Channels.newChannel(website.openStream()); + FileOutputStream fos = new FileOutputStream(destination); + fos.getChannel().transferFrom(rbc, 0, Long.MAX_VALUE); + fos.close(); + rbc.close(); + } + +} diff --git a/EduWaiterAppServer/.mvn/wrapper/maven-wrapper.jar b/EduWaiterAppServer/.mvn/wrapper/maven-wrapper.jar new file mode 100644 index 0000000..01e6799 Binary files /dev/null and b/EduWaiterAppServer/.mvn/wrapper/maven-wrapper.jar differ diff --git a/EduWaiterAppServer/.mvn/wrapper/maven-wrapper.properties b/EduWaiterAppServer/.mvn/wrapper/maven-wrapper.properties new file mode 100644 index 0000000..cd0d451 --- /dev/null +++ b/EduWaiterAppServer/.mvn/wrapper/maven-wrapper.properties @@ -0,0 +1 @@ +distributionUrl=https://repo.maven.apache.org/maven2/org/apache/maven/apache-maven/3.6.0/apache-maven-3.6.0-bin.zip diff --git a/EduWaiterAppServer/mvnw b/EduWaiterAppServer/mvnw new file mode 100755 index 0000000..8b9da3b --- /dev/null +++ b/EduWaiterAppServer/mvnw @@ -0,0 +1,286 @@ +#!/bin/sh +# ---------------------------------------------------------------------------- +# Licensed to the Apache Software Foundation (ASF) under one +# or more contributor license agreements. See the NOTICE file +# distributed with this work for additional information +# regarding copyright ownership. The ASF licenses this file +# to you under the Apache License, Version 2.0 (the +# "License"); you may not use this file except in compliance +# with the License. You may obtain a copy of the License at +# +# https://www.apache.org/licenses/LICENSE-2.0 +# +# Unless required by applicable law or agreed to in writing, +# software distributed under the License is distributed on an +# "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY +# KIND, either express or implied. See the License for the +# specific language governing permissions and limitations +# under the License. +# ---------------------------------------------------------------------------- + +# ---------------------------------------------------------------------------- +# Maven2 Start Up Batch script +# +# Required ENV vars: +# ------------------ +# JAVA_HOME - location of a JDK home dir +# +# Optional ENV vars +# ----------------- +# M2_HOME - location of maven2's installed home dir +# MAVEN_OPTS - parameters passed to the Java VM when running Maven +# e.g. to debug Maven itself, use +# set MAVEN_OPTS=-Xdebug -Xrunjdwp:transport=dt_socket,server=y,suspend=y,address=8000 +# MAVEN_SKIP_RC - flag to disable loading of mavenrc files +# ---------------------------------------------------------------------------- + +if [ -z "$MAVEN_SKIP_RC" ] ; then + + if [ -f /etc/mavenrc ] ; then + . /etc/mavenrc + fi + + if [ -f "$HOME/.mavenrc" ] ; then + . "$HOME/.mavenrc" + fi + +fi + +# OS specific support. $var _must_ be set to either true or false. +cygwin=false; +darwin=false; +mingw=false +case "`uname`" in + CYGWIN*) cygwin=true ;; + MINGW*) mingw=true;; + Darwin*) darwin=true + # Use /usr/libexec/java_home if available, otherwise fall back to /Library/Java/Home + # See https://developer.apple.com/library/mac/qa/qa1170/_index.html + if [ -z "$JAVA_HOME" ]; then + if [ -x "/usr/libexec/java_home" ]; then + export JAVA_HOME="`/usr/libexec/java_home`" + else + export JAVA_HOME="/Library/Java/Home" + fi + fi + ;; +esac + +if [ -z "$JAVA_HOME" ] ; then + if [ -r /etc/gentoo-release ] ; then + JAVA_HOME=`java-config --jre-home` + fi +fi + +if [ -z "$M2_HOME" ] ; then + ## resolve links - $0 may be a link to maven's home + PRG="$0" + + # need this for relative symlinks + while [ -h "$PRG" ] ; do + ls=`ls -ld "$PRG"` + link=`expr "$ls" : '.*-> \(.*\)$'` + if expr "$link" : '/.*' > /dev/null; then + PRG="$link" + else + PRG="`dirname "$PRG"`/$link" + fi + done + + saveddir=`pwd` + + M2_HOME=`dirname "$PRG"`/.. + + # make it fully qualified + M2_HOME=`cd "$M2_HOME" && pwd` + + cd "$saveddir" + # echo Using m2 at $M2_HOME +fi + +# For Cygwin, ensure paths are in UNIX format before anything is touched +if $cygwin ; then + [ -n "$M2_HOME" ] && + M2_HOME=`cygpath --unix "$M2_HOME"` + [ -n "$JAVA_HOME" ] && + JAVA_HOME=`cygpath --unix "$JAVA_HOME"` + [ -n "$CLASSPATH" ] && + CLASSPATH=`cygpath --path --unix "$CLASSPATH"` +fi + +# For Mingw, ensure paths are in UNIX format before anything is touched +if $mingw ; then + [ -n "$M2_HOME" ] && + M2_HOME="`(cd "$M2_HOME"; pwd)`" + [ -n "$JAVA_HOME" ] && + JAVA_HOME="`(cd "$JAVA_HOME"; pwd)`" + # TODO classpath? +fi + +if [ -z "$JAVA_HOME" ]; then + javaExecutable="`which javac`" + if [ -n "$javaExecutable" ] && ! [ "`expr \"$javaExecutable\" : '\([^ ]*\)'`" = "no" ]; then + # readlink(1) is not available as standard on Solaris 10. + readLink=`which readlink` + if [ ! `expr "$readLink" : '\([^ ]*\)'` = "no" ]; then + if $darwin ; then + javaHome="`dirname \"$javaExecutable\"`" + javaExecutable="`cd \"$javaHome\" && pwd -P`/javac" + else + javaExecutable="`readlink -f \"$javaExecutable\"`" + fi + javaHome="`dirname \"$javaExecutable\"`" + javaHome=`expr "$javaHome" : '\(.*\)/bin'` + JAVA_HOME="$javaHome" + export JAVA_HOME + fi + fi +fi + +if [ -z "$JAVACMD" ] ; then + if [ -n "$JAVA_HOME" ] ; then + if [ -x "$JAVA_HOME/jre/sh/java" ] ; then + # IBM's JDK on AIX uses strange locations for the executables + JAVACMD="$JAVA_HOME/jre/sh/java" + else + JAVACMD="$JAVA_HOME/bin/java" + fi + else + JAVACMD="`which java`" + fi +fi + +if [ ! -x "$JAVACMD" ] ; then + echo "Error: JAVA_HOME is not defined correctly." >&2 + echo " We cannot execute $JAVACMD" >&2 + exit 1 +fi + +if [ -z "$JAVA_HOME" ] ; then + echo "Warning: JAVA_HOME environment variable is not set." +fi + +CLASSWORLDS_LAUNCHER=org.codehaus.plexus.classworlds.launcher.Launcher + +# traverses directory structure from process work directory to filesystem root +# first directory with .mvn subdirectory is considered project base directory +find_maven_basedir() { + + if [ -z "$1" ] + then + echo "Path not specified to find_maven_basedir" + return 1 + fi + + basedir="$1" + wdir="$1" + while [ "$wdir" != '/' ] ; do + if [ -d "$wdir"/.mvn ] ; then + basedir=$wdir + break + fi + # workaround for JBEAP-8937 (on Solaris 10/Sparc) + if [ -d "${wdir}" ]; then + wdir=`cd "$wdir/.."; pwd` + fi + # end of workaround + done + echo "${basedir}" +} + +# concatenates all lines of a file +concat_lines() { + if [ -f "$1" ]; then + echo "$(tr -s '\n' ' ' < "$1")" + fi +} + +BASE_DIR=`find_maven_basedir "$(pwd)"` +if [ -z "$BASE_DIR" ]; then + exit 1; +fi + +########################################################################################## +# Extension to allow automatically downloading the maven-wrapper.jar from Maven-central +# This allows using the maven wrapper in projects that prohibit checking in binary data. +########################################################################################## +if [ -r "$BASE_DIR/.mvn/wrapper/maven-wrapper.jar" ]; then + if [ "$MVNW_VERBOSE" = true ]; then + echo "Found .mvn/wrapper/maven-wrapper.jar" + fi +else + if [ "$MVNW_VERBOSE" = true ]; then + echo "Couldn't find .mvn/wrapper/maven-wrapper.jar, downloading it ..." + fi + jarUrl="https://repo.maven.apache.org/maven2/io/takari/maven-wrapper/0.4.2/maven-wrapper-0.4.2.jar" + while IFS="=" read key value; do + case "$key" in (wrapperUrl) jarUrl="$value"; break ;; + esac + done < "$BASE_DIR/.mvn/wrapper/maven-wrapper.properties" + if [ "$MVNW_VERBOSE" = true ]; then + echo "Downloading from: $jarUrl" + fi + wrapperJarPath="$BASE_DIR/.mvn/wrapper/maven-wrapper.jar" + + if command -v wget > /dev/null; then + if [ "$MVNW_VERBOSE" = true ]; then + echo "Found wget ... using wget" + fi + wget "$jarUrl" -O "$wrapperJarPath" + elif command -v curl > /dev/null; then + if [ "$MVNW_VERBOSE" = true ]; then + echo "Found curl ... using curl" + fi + curl -o "$wrapperJarPath" "$jarUrl" + else + if [ "$MVNW_VERBOSE" = true ]; then + echo "Falling back to using Java to download" + fi + javaClass="$BASE_DIR/.mvn/wrapper/MavenWrapperDownloader.java" + if [ -e "$javaClass" ]; then + if [ ! -e "$BASE_DIR/.mvn/wrapper/MavenWrapperDownloader.class" ]; then + if [ "$MVNW_VERBOSE" = true ]; then + echo " - Compiling MavenWrapperDownloader.java ..." + fi + # Compiling the Java class + ("$JAVA_HOME/bin/javac" "$javaClass") + fi + if [ -e "$BASE_DIR/.mvn/wrapper/MavenWrapperDownloader.class" ]; then + # Running the downloader + if [ "$MVNW_VERBOSE" = true ]; then + echo " - Running MavenWrapperDownloader.java ..." + fi + ("$JAVA_HOME/bin/java" -cp .mvn/wrapper MavenWrapperDownloader "$MAVEN_PROJECTBASEDIR") + fi + fi + fi +fi +########################################################################################## +# End of extension +########################################################################################## + +export MAVEN_PROJECTBASEDIR=${MAVEN_BASEDIR:-"$BASE_DIR"} +if [ "$MVNW_VERBOSE" = true ]; then + echo $MAVEN_PROJECTBASEDIR +fi +MAVEN_OPTS="$(concat_lines "$MAVEN_PROJECTBASEDIR/.mvn/jvm.config") $MAVEN_OPTS" + +# For Cygwin, switch paths to Windows format before running java +if $cygwin; then + [ -n "$M2_HOME" ] && + M2_HOME=`cygpath --path --windows "$M2_HOME"` + [ -n "$JAVA_HOME" ] && + JAVA_HOME=`cygpath --path --windows "$JAVA_HOME"` + [ -n "$CLASSPATH" ] && + CLASSPATH=`cygpath --path --windows "$CLASSPATH"` + [ -n "$MAVEN_PROJECTBASEDIR" ] && + MAVEN_PROJECTBASEDIR=`cygpath --path --windows "$MAVEN_PROJECTBASEDIR"` +fi + +WRAPPER_LAUNCHER=org.apache.maven.wrapper.MavenWrapperMain + +exec "$JAVACMD" \ + $MAVEN_OPTS \ + -classpath "$MAVEN_PROJECTBASEDIR/.mvn/wrapper/maven-wrapper.jar" \ + "-Dmaven.home=${M2_HOME}" "-Dmaven.multiModuleProjectDirectory=${MAVEN_PROJECTBASEDIR}" \ + ${WRAPPER_LAUNCHER} $MAVEN_CONFIG "$@" diff --git a/EduWaiterAppServer/mvnw.cmd b/EduWaiterAppServer/mvnw.cmd new file mode 100644 index 0000000..fef5a8f --- /dev/null +++ b/EduWaiterAppServer/mvnw.cmd @@ -0,0 +1,161 @@ +@REM ---------------------------------------------------------------------------- +@REM Licensed to the Apache Software Foundation (ASF) under one +@REM or more contributor license agreements. See the NOTICE file +@REM distributed with this work for additional information +@REM regarding copyright ownership. The ASF licenses this file +@REM to you under the Apache License, Version 2.0 (the +@REM "License"); you may not use this file except in compliance +@REM with the License. You may obtain a copy of the License at +@REM +@REM https://www.apache.org/licenses/LICENSE-2.0 +@REM +@REM Unless required by applicable law or agreed to in writing, +@REM software distributed under the License is distributed on an +@REM "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY +@REM KIND, either express or implied. See the License for the +@REM specific language governing permissions and limitations +@REM under the License. +@REM ---------------------------------------------------------------------------- + +@REM ---------------------------------------------------------------------------- +@REM Maven2 Start Up Batch script +@REM +@REM Required ENV vars: +@REM JAVA_HOME - location of a JDK home dir +@REM +@REM Optional ENV vars +@REM M2_HOME - location of maven2's installed home dir +@REM MAVEN_BATCH_ECHO - set to 'on' to enable the echoing of the batch commands +@REM MAVEN_BATCH_PAUSE - set to 'on' to wait for a key stroke before ending +@REM MAVEN_OPTS - parameters passed to the Java VM when running Maven +@REM e.g. to debug Maven itself, use +@REM set MAVEN_OPTS=-Xdebug -Xrunjdwp:transport=dt_socket,server=y,suspend=y,address=8000 +@REM MAVEN_SKIP_RC - flag to disable loading of mavenrc files +@REM ---------------------------------------------------------------------------- + +@REM Begin all REM lines with '@' in case MAVEN_BATCH_ECHO is 'on' +@echo off +@REM set title of command window +title %0 +@REM enable echoing my setting MAVEN_BATCH_ECHO to 'on' +@if "%MAVEN_BATCH_ECHO%" == "on" echo %MAVEN_BATCH_ECHO% + +@REM set %HOME% to equivalent of $HOME +if "%HOME%" == "" (set "HOME=%HOMEDRIVE%%HOMEPATH%") + +@REM Execute a user defined script before this one +if not "%MAVEN_SKIP_RC%" == "" goto skipRcPre +@REM check for pre script, once with legacy .bat ending and once with .cmd ending +if exist "%HOME%\mavenrc_pre.bat" call "%HOME%\mavenrc_pre.bat" +if exist "%HOME%\mavenrc_pre.cmd" call "%HOME%\mavenrc_pre.cmd" +:skipRcPre + +@setlocal + +set ERROR_CODE=0 + +@REM To isolate internal variables from possible post scripts, we use another setlocal +@setlocal + +@REM ==== START VALIDATION ==== +if not "%JAVA_HOME%" == "" goto OkJHome + +echo. +echo Error: JAVA_HOME not found in your environment. >&2 +echo Please set the JAVA_HOME variable in your environment to match the >&2 +echo location of your Java installation. >&2 +echo. +goto error + +:OkJHome +if exist "%JAVA_HOME%\bin\java.exe" goto init + +echo. +echo Error: JAVA_HOME is set to an invalid directory. >&2 +echo JAVA_HOME = "%JAVA_HOME%" >&2 +echo Please set the JAVA_HOME variable in your environment to match the >&2 +echo location of your Java installation. >&2 +echo. +goto error + +@REM ==== END VALIDATION ==== + +:init + +@REM Find the project base dir, i.e. the directory that contains the folder ".mvn". +@REM Fallback to current working directory if not found. + +set MAVEN_PROJECTBASEDIR=%MAVEN_BASEDIR% +IF NOT "%MAVEN_PROJECTBASEDIR%"=="" goto endDetectBaseDir + +set EXEC_DIR=%CD% +set WDIR=%EXEC_DIR% +:findBaseDir +IF EXIST "%WDIR%"\.mvn goto baseDirFound +cd .. +IF "%WDIR%"=="%CD%" goto baseDirNotFound +set WDIR=%CD% +goto findBaseDir + +:baseDirFound +set MAVEN_PROJECTBASEDIR=%WDIR% +cd "%EXEC_DIR%" +goto endDetectBaseDir + +:baseDirNotFound +set MAVEN_PROJECTBASEDIR=%EXEC_DIR% +cd "%EXEC_DIR%" + +:endDetectBaseDir + +IF NOT EXIST "%MAVEN_PROJECTBASEDIR%\.mvn\jvm.config" goto endReadAdditionalConfig + +@setlocal EnableExtensions EnableDelayedExpansion +for /F "usebackq delims=" %%a in ("%MAVEN_PROJECTBASEDIR%\.mvn\jvm.config") do set JVM_CONFIG_MAVEN_PROPS=!JVM_CONFIG_MAVEN_PROPS! %%a +@endlocal & set JVM_CONFIG_MAVEN_PROPS=%JVM_CONFIG_MAVEN_PROPS% + +:endReadAdditionalConfig + +SET MAVEN_JAVA_EXE="%JAVA_HOME%\bin\java.exe" +set WRAPPER_JAR="%MAVEN_PROJECTBASEDIR%\.mvn\wrapper\maven-wrapper.jar" +set WRAPPER_LAUNCHER=org.apache.maven.wrapper.MavenWrapperMain + +set DOWNLOAD_URL="https://repo.maven.apache.org/maven2/io/takari/maven-wrapper/0.4.2/maven-wrapper-0.4.2.jar" +FOR /F "tokens=1,2 delims==" %%A IN (%MAVEN_PROJECTBASEDIR%\.mvn\wrapper\maven-wrapper.properties) DO ( + IF "%%A"=="wrapperUrl" SET DOWNLOAD_URL=%%B +) + +@REM Extension to allow automatically downloading the maven-wrapper.jar from Maven-central +@REM This allows using the maven wrapper in projects that prohibit checking in binary data. +if exist %WRAPPER_JAR% ( + echo Found %WRAPPER_JAR% +) else ( + echo Couldn't find %WRAPPER_JAR%, downloading it ... + echo Downloading from: %DOWNLOAD_URL% + powershell -Command "(New-Object Net.WebClient).DownloadFile('%DOWNLOAD_URL%', '%WRAPPER_JAR%')" + echo Finished downloading %WRAPPER_JAR% +) +@REM End of extension + +%MAVEN_JAVA_EXE% %JVM_CONFIG_MAVEN_PROPS% %MAVEN_OPTS% %MAVEN_DEBUG_OPTS% -classpath %WRAPPER_JAR% "-Dmaven.multiModuleProjectDirectory=%MAVEN_PROJECTBASEDIR%" %WRAPPER_LAUNCHER% %MAVEN_CONFIG% %* +if ERRORLEVEL 1 goto error +goto end + +:error +set ERROR_CODE=1 + +:end +@endlocal & set ERROR_CODE=%ERROR_CODE% + +if not "%MAVEN_SKIP_RC%" == "" goto skipRcPost +@REM check for post script, once with legacy .bat ending and once with .cmd ending +if exist "%HOME%\mavenrc_post.bat" call "%HOME%\mavenrc_post.bat" +if exist "%HOME%\mavenrc_post.cmd" call "%HOME%\mavenrc_post.cmd" +:skipRcPost + +@REM pause the script if MAVEN_BATCH_PAUSE is set to 'on' +if "%MAVEN_BATCH_PAUSE%" == "on" pause + +if "%MAVEN_TERMINATE_CMD%" == "on" exit %ERROR_CODE% + +exit /B %ERROR_CODE% diff --git a/EduWaiterAppServer/pom.xml b/EduWaiterAppServer/pom.xml new file mode 100644 index 0000000..0a22ea2 --- /dev/null +++ b/EduWaiterAppServer/pom.xml @@ -0,0 +1,62 @@ + + + 4.0.0 + + org.springframework.boot + spring-boot-starter-parent + 2.1.4.RELEASE + + + com.caraeppes + EduWaiterAppServer + 0.0.1-SNAPSHOT + EduWaiterAppServer + EduWaiter Application + + + 1.8 + + + + + org.springframework.boot + spring-boot-starter-data-jpa + + + org.springframework.boot + spring-boot-starter-jdbc + + + org.springframework.boot + spring-boot-starter-web + + + + mysql + mysql-connector-java + runtime + + + org.springframework.boot + spring-boot-starter-test + test + + + org.javassist + javassist + 3.24.1-GA + + + + + + + + org.springframework.boot + spring-boot-maven-plugin + + + + + diff --git a/EduWaiterAppServer/src/main/java/com/caraeppes/EduWaiterAppServer/EduWaiterAppServerApplication.java b/EduWaiterAppServer/src/main/java/com/caraeppes/EduWaiterAppServer/EduWaiterAppServerApplication.java new file mode 100644 index 0000000..c946181 --- /dev/null +++ b/EduWaiterAppServer/src/main/java/com/caraeppes/EduWaiterAppServer/EduWaiterAppServerApplication.java @@ -0,0 +1,13 @@ +package com.caraeppes.EduWaiterAppServer; + +import org.springframework.boot.SpringApplication; +import org.springframework.boot.autoconfigure.SpringBootApplication; + +@SpringBootApplication +public class EduWaiterAppServerApplication { + + public static void main(String[] args) { + SpringApplication.run(EduWaiterAppServerApplication.class, args); + } + +} diff --git a/EduWaiterAppServer/src/main/java/com/caraeppes/EduWaiterAppServer/controllers/AdminAccountController.java b/EduWaiterAppServer/src/main/java/com/caraeppes/EduWaiterAppServer/controllers/AdminAccountController.java new file mode 100644 index 0000000..841dc30 --- /dev/null +++ b/EduWaiterAppServer/src/main/java/com/caraeppes/EduWaiterAppServer/controllers/AdminAccountController.java @@ -0,0 +1,58 @@ +package com.caraeppes.EduWaiterAppServer.controllers; + +import com.caraeppes.EduWaiterAppServer.models.AdminAccount; +import com.caraeppes.EduWaiterAppServer.models.Restaurant; +import com.caraeppes.EduWaiterAppServer.services.AdminAccountService; +import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.http.HttpStatus; +import org.springframework.http.ResponseEntity; +import org.springframework.web.bind.annotation.*; + +import java.util.List; + +@RestController +@RequestMapping("/accounts/admin") +public class AdminAccountController { + + private AdminAccountService adminAccountService; + + @Autowired + public AdminAccountController(AdminAccountService adminAccountService) { + this.adminAccountService = adminAccountService; + } + + @GetMapping("/{id}") + public ResponseEntity findById(@PathVariable Long id) { + return new ResponseEntity<>(adminAccountService.findById(id), HttpStatus.OK); + } + + @GetMapping + public ResponseEntity> findAll() { + return new ResponseEntity<>(adminAccountService.findAll(), HttpStatus.OK); + } + + @GetMapping("/username/{username}") + public ResponseEntity findByUsername(@PathVariable String username){ + return new ResponseEntity<>(adminAccountService.findByUsername(username), HttpStatus.OK); + } + + @PostMapping + public ResponseEntity create(@RequestBody AdminAccount adminAccount) { + return new ResponseEntity<>(adminAccountService.create(adminAccount), HttpStatus.CREATED); + } + + @PutMapping("/update/{id}") + private ResponseEntity update(@RequestBody AdminAccount adminAccount, @PathVariable Long id) { + return new ResponseEntity<>(adminAccountService.update(adminAccount, id), HttpStatus.OK); + } + + @PutMapping("{id}/updateRestaurant") + private ResponseEntity updateRestaurant(@RequestParam Long restaurantId, @PathVariable Long id){ + return new ResponseEntity<>(adminAccountService.updateRestaurant(restaurantId, id), HttpStatus.OK); + } + + @DeleteMapping("/{id}") + private ResponseEntity deleteById(@PathVariable Long id) { + return new ResponseEntity<>(adminAccountService.deleteById(id), HttpStatus.NOT_FOUND); + } +} diff --git a/EduWaiterAppServer/src/main/java/com/caraeppes/EduWaiterAppServer/controllers/EmployeeAccountController.java b/EduWaiterAppServer/src/main/java/com/caraeppes/EduWaiterAppServer/controllers/EmployeeAccountController.java new file mode 100644 index 0000000..4b7b153 --- /dev/null +++ b/EduWaiterAppServer/src/main/java/com/caraeppes/EduWaiterAppServer/controllers/EmployeeAccountController.java @@ -0,0 +1,63 @@ +package com.caraeppes.EduWaiterAppServer.controllers; + +import com.caraeppes.EduWaiterAppServer.models.EmployeeAccount; +import com.caraeppes.EduWaiterAppServer.models.Restaurant; +import com.caraeppes.EduWaiterAppServer.repositories.RestaurantRepository; +import com.caraeppes.EduWaiterAppServer.services.EmployeeAccountService; +import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.http.HttpStatus; +import org.springframework.http.ResponseEntity; +import org.springframework.web.bind.annotation.*; + +import java.util.List; + +@RestController +@RequestMapping("/accounts/employees") +public class EmployeeAccountController { + + private EmployeeAccountService employeeAccountService; + private RestaurantRepository restaurantRepository; + + @Autowired + public EmployeeAccountController(EmployeeAccountService employeeAccountService, + RestaurantRepository restaurantRepository) { + this.employeeAccountService = employeeAccountService; + this.restaurantRepository = restaurantRepository; + } + + @GetMapping("/{id}") + public ResponseEntity findById(@PathVariable Long id){ + return new ResponseEntity<>(employeeAccountService.findById(id), HttpStatus.OK); + } + + @GetMapping + public ResponseEntity> findAll(){ + return new ResponseEntity<>(employeeAccountService.findAll(), HttpStatus.OK); + } + + @GetMapping("/username/{username}") + public ResponseEntity findByUsername(@PathVariable String username){ + return new ResponseEntity<>(employeeAccountService.findByUsername(username), HttpStatus.OK); + } + + @PostMapping + public ResponseEntity create(@RequestBody EmployeeAccount employeeAccount){ + return new ResponseEntity<>(employeeAccountService.create(employeeAccount), HttpStatus.CREATED); + } + + @PutMapping("/update/{id}") + public ResponseEntity update(@RequestBody EmployeeAccount employeeAccount, @PathVariable Long id){ + return new ResponseEntity<>(employeeAccountService.update(employeeAccount, id), HttpStatus.OK); + } + + @PutMapping("{id}/updateRestaurant") + public ResponseEntity updateRestaurant(@RequestParam Long restaurantId, @PathVariable Long id){ + return new ResponseEntity<>(employeeAccountService.updateRestaurant(restaurantId, id), HttpStatus.OK); + } + + @DeleteMapping("/{id}") + public ResponseEntity deleteById(@PathVariable Long id){ + return new ResponseEntity<>(employeeAccountService.deleteById(id), HttpStatus.NOT_FOUND); + } + +} diff --git a/EduWaiterAppServer/src/main/java/com/caraeppes/EduWaiterAppServer/controllers/FactController.java b/EduWaiterAppServer/src/main/java/com/caraeppes/EduWaiterAppServer/controllers/FactController.java new file mode 100644 index 0000000..eb39af1 --- /dev/null +++ b/EduWaiterAppServer/src/main/java/com/caraeppes/EduWaiterAppServer/controllers/FactController.java @@ -0,0 +1,4 @@ +package com.caraeppes.EduWaiterAppServer.controllers; + +public class FactController { +} diff --git a/EduWaiterAppServer/src/main/java/com/caraeppes/EduWaiterAppServer/controllers/IngredientController.java b/EduWaiterAppServer/src/main/java/com/caraeppes/EduWaiterAppServer/controllers/IngredientController.java new file mode 100644 index 0000000..11b5737 --- /dev/null +++ b/EduWaiterAppServer/src/main/java/com/caraeppes/EduWaiterAppServer/controllers/IngredientController.java @@ -0,0 +1,47 @@ +package com.caraeppes.EduWaiterAppServer.controllers; + +import com.caraeppes.EduWaiterAppServer.models.Ingredient; +import com.caraeppes.EduWaiterAppServer.services.IngredientService; +import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.http.HttpStatus; +import org.springframework.http.ResponseEntity; +import org.springframework.web.bind.annotation.*; + +import java.util.List; + +@RestController +@RequestMapping("/ingredients") +public class IngredientController { + + private IngredientService ingredientService; + + @Autowired + public IngredientController(IngredientService ingredientService) { + this.ingredientService = ingredientService; + } + + @PostMapping + public ResponseEntity create(@RequestBody Ingredient ingredient){ + return new ResponseEntity<>(ingredientService.create(ingredient), HttpStatus.CREATED); + } + + @GetMapping + public ResponseEntity> findAll(){ + return new ResponseEntity<>(ingredientService.findAll(), HttpStatus.OK); + } + + @GetMapping("/{id}") + public ResponseEntity findById(@PathVariable Long id){ + return new ResponseEntity<>(ingredientService.findById(id), HttpStatus.OK); + } + + @PutMapping("/update/{id}") + public ResponseEntity update(@RequestBody Ingredient ingredient, @PathVariable Long id){ + return new ResponseEntity<>(ingredientService.update(ingredient, id), HttpStatus.OK); + } + + @DeleteMapping("/{id}") + public ResponseEntity deleteById(@PathVariable Long id){ + return new ResponseEntity<>(ingredientService.deleteById(id), HttpStatus.NOT_FOUND); + } +} diff --git a/EduWaiterAppServer/src/main/java/com/caraeppes/EduWaiterAppServer/controllers/MenuController.java b/EduWaiterAppServer/src/main/java/com/caraeppes/EduWaiterAppServer/controllers/MenuController.java new file mode 100644 index 0000000..08c0e2e --- /dev/null +++ b/EduWaiterAppServer/src/main/java/com/caraeppes/EduWaiterAppServer/controllers/MenuController.java @@ -0,0 +1,58 @@ +package com.caraeppes.EduWaiterAppServer.controllers; + +import com.caraeppes.EduWaiterAppServer.models.Menu; +import com.caraeppes.EduWaiterAppServer.services.MenuService; +import com.caraeppes.EduWaiterAppServer.services.RestaurantService; +import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.http.HttpStatus; +import org.springframework.http.ResponseEntity; +import org.springframework.web.bind.annotation.*; + +import java.util.List; + +@RestController +@RequestMapping("/menus") +public class MenuController { + + private MenuService menuService; + + @Autowired + public MenuController(MenuService menuService) { + this.menuService = menuService; + } + + @GetMapping("/{id}") + public ResponseEntity findById(@PathVariable Long id){ + return new ResponseEntity<>(menuService.findById(id), HttpStatus.OK); + } + + @GetMapping + public ResponseEntity> findAll(){ + return new ResponseEntity<>(menuService.findAll(), HttpStatus.OK); + } + + @PostMapping + public ResponseEntity create(@RequestBody Menu menu){ + return new ResponseEntity<>(menuService.create(menu), HttpStatus.CREATED); + } + + @PutMapping("/update/{id}") + public ResponseEntity update(@RequestBody Menu menu, @PathVariable Long id){ + return new ResponseEntity<>(menuService.update(menu, id), HttpStatus.OK); + } + + @PutMapping("/updateDescription/{description}") + public ResponseEntity updateDescription(@RequestBody Menu menu, @PathVariable String description){ + return new ResponseEntity<>(menuService.updateDescription(menu, description), HttpStatus.OK); + } + + @PutMapping("/updateRestaurant/{restaurantId}") + public ResponseEntity updateRestaurant(@RequestBody Menu menu, @PathVariable Long restaurantId){ + return new ResponseEntity<>(menuService.updateRestaurant(menu, restaurantId), HttpStatus.OK); + } + + @DeleteMapping("/{id}") + public ResponseEntity deleteById(@PathVariable Long id){ + return new ResponseEntity<>(menuService.deleteById(id), HttpStatus.NOT_FOUND); + } +} \ No newline at end of file diff --git a/EduWaiterAppServer/src/main/java/com/caraeppes/EduWaiterAppServer/controllers/MenuItemController.java b/EduWaiterAppServer/src/main/java/com/caraeppes/EduWaiterAppServer/controllers/MenuItemController.java new file mode 100644 index 0000000..32ff563 --- /dev/null +++ b/EduWaiterAppServer/src/main/java/com/caraeppes/EduWaiterAppServer/controllers/MenuItemController.java @@ -0,0 +1,49 @@ +package com.caraeppes.EduWaiterAppServer.controllers; + +import com.caraeppes.EduWaiterAppServer.models.MenuItem; +import com.caraeppes.EduWaiterAppServer.services.MenuItemService; +import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.http.HttpStatus; +import org.springframework.http.ResponseEntity; +import org.springframework.web.bind.annotation.*; + +import java.util.List; + +@RestController +@RequestMapping("/menuItems") +public class MenuItemController { + + private MenuItemService menuItemService; + + @Autowired + public MenuItemController(MenuItemService menuItemService) { + this.menuItemService = menuItemService; + } + + @PostMapping + public ResponseEntity create(@RequestBody MenuItem menuItem){ + return new ResponseEntity<>(menuItemService.create(menuItem), HttpStatus.CREATED); + } + + @GetMapping("/{id}") + public ResponseEntity findById(@PathVariable Long id){ + return new ResponseEntity<>(menuItemService.findById(id), HttpStatus.OK); + } + + @GetMapping + public ResponseEntity> findAll(){ + return new ResponseEntity<>(menuItemService.findAll(), HttpStatus.OK); + } + + @PutMapping("/update/{id}") + public ResponseEntity update(@RequestBody MenuItem menuItem, @PathVariable Long id){ + return new ResponseEntity<>(menuItemService.update(menuItem, id), HttpStatus.OK); + } + + @DeleteMapping("/{id}") + public ResponseEntity deleteById(@PathVariable Long id){ + return new ResponseEntity<>(menuItemService.deleteById(id), HttpStatus.NOT_FOUND); + } + +} + diff --git a/EduWaiterAppServer/src/main/java/com/caraeppes/EduWaiterAppServer/controllers/RestaurantController.java b/EduWaiterAppServer/src/main/java/com/caraeppes/EduWaiterAppServer/controllers/RestaurantController.java new file mode 100644 index 0000000..7f6c813 --- /dev/null +++ b/EduWaiterAppServer/src/main/java/com/caraeppes/EduWaiterAppServer/controllers/RestaurantController.java @@ -0,0 +1,64 @@ +package com.caraeppes.EduWaiterAppServer.controllers; + +import com.caraeppes.EduWaiterAppServer.models.Restaurant; +import com.caraeppes.EduWaiterAppServer.services.RestaurantService; +import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.http.HttpStatus; +import org.springframework.http.ResponseEntity; +import org.springframework.web.bind.annotation.*; + +import java.util.List; + +@RestController +@RequestMapping("/restaurants") +public class RestaurantController { + + private RestaurantService restaurantService; + + @Autowired + public RestaurantController(RestaurantService restaurantService) { + this.restaurantService = restaurantService; + } + + @GetMapping("/{id}") + public ResponseEntity findById(@PathVariable Long id){ + return new ResponseEntity<>(restaurantService.findById(id), HttpStatus.OK); + } + + @GetMapping + public ResponseEntity> findAll(){ + return new ResponseEntity<>(restaurantService.findAll(), HttpStatus.OK); + } + + @PostMapping + public ResponseEntity create(@RequestBody Restaurant restaurant){ + return new ResponseEntity<>(restaurantService.create(restaurant), HttpStatus.CREATED); + } + + @PutMapping("/update/{id}") + public ResponseEntity update(@RequestBody Restaurant restaurant, @PathVariable Long id){ + return new ResponseEntity<>(restaurantService.update(restaurant, id), HttpStatus.OK); + } + + @PutMapping("/addAdmin/{adminId}") + public ResponseEntity addAdmin(@RequestBody Restaurant restaurant, @PathVariable Long adminId){ + return new ResponseEntity<>(restaurantService.addAdmin(restaurant, adminId), HttpStatus.OK); + } + + @PutMapping("/addEmployee/{employeeId}") + public ResponseEntity addEmployee(@RequestBody Restaurant restaurant, @PathVariable Long employeeId){ + return new ResponseEntity<>(restaurantService.addEmployee(restaurant, employeeId), HttpStatus.OK); + } + + @PutMapping("/addMenu/{menuId}") + public ResponseEntity addMenu(@RequestBody Restaurant restaurant, @PathVariable Long menuId){ + return new ResponseEntity<>(restaurantService.addMenu(restaurant, menuId), HttpStatus.OK); + } + + @DeleteMapping("/{id}") + public ResponseEntity delete(@PathVariable Long id){ + return new ResponseEntity<>(restaurantService.deleteById(id), HttpStatus.NOT_FOUND); + } + + +} diff --git a/EduWaiterAppServer/src/main/java/com/caraeppes/EduWaiterAppServer/models/AdminAccount.java b/EduWaiterAppServer/src/main/java/com/caraeppes/EduWaiterAppServer/models/AdminAccount.java new file mode 100644 index 0000000..40d95fa --- /dev/null +++ b/EduWaiterAppServer/src/main/java/com/caraeppes/EduWaiterAppServer/models/AdminAccount.java @@ -0,0 +1,79 @@ +package com.caraeppes.EduWaiterAppServer.models; + +import com.fasterxml.jackson.annotation.JsonIgnoreProperties; +import com.fasterxml.jackson.annotation.JsonRawValue; + +import javax.persistence.*; +import java.util.List; + +@Entity +@Table(name = "admin_accounts") +@JsonIgnoreProperties({"hibernateLazyInitializer", "handler"}) +public class AdminAccount { + @Id + @GeneratedValue(strategy = GenerationType.AUTO) + + @Column(name = "account_id") + private Long id; + @Column(name = "first_name") + private String firstName; + @Column(name = "last_name") + private String lastName; + @Column(name = "username") + private String username; + @Column(name ="password") + private String password; + @ManyToOne(fetch = FetchType.EAGER, targetEntity = Restaurant.class) + @JoinColumn(name="restaurant_id") + @JsonIgnoreProperties(value = "admin") + private Restaurant restaurant; + + public Long getId() { + return id; + } + + public void setId(Long id) { + this.id = id; + } + + public String getFirstName() { + return firstName; + } + + public void setFirstName(String firstName) { + this.firstName = firstName; + } + + public String getLastName() { + return lastName; + } + + public void setLastName(String lastName) { + this.lastName = lastName; + } + + public String getUsername() { + return username; + } + + public void setUsername(String username) { + this.username = username; + } + + public String getPassword() { + return password; + } + + public void setPassword(String password) { + this.password = password; + } + + public Restaurant getRestaurant() { + return restaurant; + } + + public void setRestaurant(Restaurant restaurant) { + this.restaurant = restaurant; + } + +} diff --git a/EduWaiterAppServer/src/main/java/com/caraeppes/EduWaiterAppServer/models/EmployeeAccount.java b/EduWaiterAppServer/src/main/java/com/caraeppes/EduWaiterAppServer/models/EmployeeAccount.java new file mode 100644 index 0000000..30ab756 --- /dev/null +++ b/EduWaiterAppServer/src/main/java/com/caraeppes/EduWaiterAppServer/models/EmployeeAccount.java @@ -0,0 +1,81 @@ +package com.caraeppes.EduWaiterAppServer.models; + +import com.fasterxml.jackson.annotation.JsonIgnoreProperties; +import com.fasterxml.jackson.annotation.JsonRawValue; + +import javax.persistence.*; +import java.util.List; + +@Entity +@Table(name = "employee_accounts") +@JsonIgnoreProperties({"hibernateLazyInitializer", "handler"}) +public class EmployeeAccount { + + @Id + @GeneratedValue(strategy = GenerationType.AUTO) + @Column(name = "account_id") + private Long id; + @Column(name = "first_name") + private String firstName; + @Column(name = "last_name") + private String lastName; + @Column(name = "username") + private String username; + @Column(name ="password") + private String password; + @ManyToOne(fetch = FetchType.EAGER, targetEntity = Restaurant.class) + @JoinColumn(name="restaurant_id") + @JsonIgnoreProperties(value = "employees") + private Restaurant restaurant; + + public Long getId() { + return id; + } + + public void setId(Long id) { + this.id = id; + } + + public String getFirstName() { + return firstName; + } + + public void setFirstName(String firstName) { + this.firstName = firstName; + } + + public String getLastName() { + return lastName; + } + + public void setLastName(String lastName) { + this.lastName = lastName; + } + + public String getUsername() { + return username; + } + + public void setUsername(String username) { + this.username = username; + } + + public String getPassword() { + return password; + } + + public void setPassword(String password) { + this.password = password; + } + + public Restaurant getRestaurant() { + return restaurant; + } + + public void setRestaurant(Restaurant restaurant) { + this.restaurant = restaurant; + } + + +} + diff --git a/EduWaiterAppServer/src/main/java/com/caraeppes/EduWaiterAppServer/models/Fact.java b/EduWaiterAppServer/src/main/java/com/caraeppes/EduWaiterAppServer/models/Fact.java new file mode 100644 index 0000000..c97ebbb --- /dev/null +++ b/EduWaiterAppServer/src/main/java/com/caraeppes/EduWaiterAppServer/models/Fact.java @@ -0,0 +1,55 @@ +package com.caraeppes.EduWaiterAppServer.models; + +import com.fasterxml.jackson.annotation.JsonIgnoreProperties; + +import javax.persistence.*; + +@Entity +@Table(name = "facts") +@JsonIgnoreProperties({"hibernateLazyInitializer", "handler"}) +public class Fact { + + @Id + @GeneratedValue(strategy = GenerationType.AUTO) + @Column(name = "fact_id") + private Long id; + @Column(name = "fact") + private String fact; + @ManyToOne(fetch=FetchType.LAZY) + @JoinColumn(name="restaurant_id") + private Restaurant restaurant; + @Column(name = "entity_id") + private Long entityId; + + public Long getId() { + return id; + } + + public void setId(Long id) { + this.id = id; + } + + public String getFact() { + return fact; + } + + public void setFact(String fact) { + this.fact = fact; + } + + public Restaurant getRestaurant() { + return restaurant; + } + + public void setRestaurant(Restaurant restaurant) { + this.restaurant = restaurant; + } + + public Long getEntityId() { + return entityId; + } + + public void setEntityId(Long entityId) { + this.entityId = entityId; + } +} diff --git a/EduWaiterAppServer/src/main/java/com/caraeppes/EduWaiterAppServer/models/Game.java b/EduWaiterAppServer/src/main/java/com/caraeppes/EduWaiterAppServer/models/Game.java new file mode 100644 index 0000000..5e7393f --- /dev/null +++ b/EduWaiterAppServer/src/main/java/com/caraeppes/EduWaiterAppServer/models/Game.java @@ -0,0 +1,7 @@ +package com.caraeppes.EduWaiterAppServer.models; + +import javax.persistence.Entity; + + +public interface Game { +} diff --git a/EduWaiterAppServer/src/main/java/com/caraeppes/EduWaiterAppServer/models/Ingredient.java b/EduWaiterAppServer/src/main/java/com/caraeppes/EduWaiterAppServer/models/Ingredient.java new file mode 100644 index 0000000..ad10017 --- /dev/null +++ b/EduWaiterAppServer/src/main/java/com/caraeppes/EduWaiterAppServer/models/Ingredient.java @@ -0,0 +1,55 @@ +package com.caraeppes.EduWaiterAppServer.models; + +import com.fasterxml.jackson.annotation.JsonIgnoreProperties; + +import javax.persistence.*; +import java.util.List; + +@Entity +@Table(name = "ingredients") +@JsonIgnoreProperties({"hibernateLazyInitializer", "handler"}) +public class Ingredient { + + @Id + @GeneratedValue(strategy = GenerationType.AUTO) + @Column(name = "ingredient_id") + private Long id; + @Column(name = "name") + private String name; + @Column(name="allergen") + private Boolean allergen; + @ManyToMany(mappedBy="ingredients") + private List menuItems; + + public Long getId() { + return id; + } + + public void setId(Long id) { + this.id = id; + } + + public String getName() { + return name; + } + + public void setName(String name) { + this.name = name; + } + + public Boolean getAllergen() { + return allergen; + } + + public void setAllergen(Boolean allergen) { + this.allergen = allergen; + } + + public List getMenuItems() { + return menuItems; + } + + public void setMenuItems(List menuItems) { + this.menuItems = menuItems; + } +} diff --git a/EduWaiterAppServer/src/main/java/com/caraeppes/EduWaiterAppServer/models/Menu.java b/EduWaiterAppServer/src/main/java/com/caraeppes/EduWaiterAppServer/models/Menu.java new file mode 100644 index 0000000..a21e572 --- /dev/null +++ b/EduWaiterAppServer/src/main/java/com/caraeppes/EduWaiterAppServer/models/Menu.java @@ -0,0 +1,87 @@ +package com.caraeppes.EduWaiterAppServer.models; + +import com.caraeppes.EduWaiterAppServer.utilities.MenuItemSerializer; +import com.fasterxml.jackson.annotation.JsonIgnoreProperties; +import com.fasterxml.jackson.databind.annotation.JsonSerialize; +import javax.persistence.*; +import java.util.List; + +@Entity +@Table(name = "menus") +@JsonIgnoreProperties({"hibernateLazyInitializer", "handler"}) +public class Menu { + + @Id + @GeneratedValue(strategy = GenerationType.AUTO) + @Column(name = "menu_id") + private Long id; + + @Column(name = "menu_name") + private String name; + + @Column(name = "description") + private String description; + + @ManyToMany + @JoinTable( + name="menu_menu_items", + joinColumns=@JoinColumn(name="menu_id", referencedColumnName="menu_id"), + inverseJoinColumns=@JoinColumn(name="menu_item_id", referencedColumnName = "menu_item_id")) + @JsonSerialize(using = MenuItemSerializer.class) + private List menuItems; + + @ManyToOne(fetch = FetchType.EAGER) + @JoinColumn(name = "restaurant_id") + @JsonIgnoreProperties({"password", "menus", "admin", "employees", "facts"}) + private Restaurant restaurant; + + public Menu() { + } + + public Menu(String name, String description, List menuItems, Restaurant restaurant) { + this.name = name; + this.description = description; + this.menuItems = menuItems; + this.restaurant = restaurant; + } + + public Long getId() { + return id; + } + + public void setId(Long id) { + this.id = id; + } + + public String getName() { + return name; + } + + public void setName(String name) { + this.name = name; + } + + public String getDescription() { + return description; + } + + public void setDescription(String description) { + this.description = description; + } + + public List getMenuItems() { + return menuItems; + } + + public void setMenuItems(List menuItems) { + this.menuItems = menuItems; + } + + public Restaurant getRestaurant() { + return restaurant; + } + + public void setRestaurant(Restaurant restaurant) { + this.restaurant = restaurant; + } +} diff --git a/EduWaiterAppServer/src/main/java/com/caraeppes/EduWaiterAppServer/models/MenuItem.java b/EduWaiterAppServer/src/main/java/com/caraeppes/EduWaiterAppServer/models/MenuItem.java new file mode 100644 index 0000000..1d9389f --- /dev/null +++ b/EduWaiterAppServer/src/main/java/com/caraeppes/EduWaiterAppServer/models/MenuItem.java @@ -0,0 +1,83 @@ +package com.caraeppes.EduWaiterAppServer.models; + +import com.caraeppes.EduWaiterAppServer.utilities.IngredientSerializer; +import com.fasterxml.jackson.annotation.JsonIgnoreProperties; +import com.fasterxml.jackson.databind.annotation.JsonSerialize; + +import javax.persistence.*; +import java.util.List; + +@Entity +@Table(name = "menu_items") +@JsonIgnoreProperties({"hibernateLazyInitializer", "handler"}) +public class MenuItem { + + @Id + @GeneratedValue(strategy = GenerationType.AUTO) + @Column(name = "menu_item_id") + private Long id; + @Column(name = "name") + private String name; + @Column(name = "description") + private String description; + @Column(name = "price") + private Double price; + @ManyToMany + @JoinTable( + name="menu_item_ingredients", + joinColumns=@JoinColumn(name="menu_item_id", referencedColumnName="menu_item_id"), + inverseJoinColumns=@JoinColumn(name="ingredient_id", referencedColumnName="ingredient_id")) + @JsonSerialize(using = IngredientSerializer.class) + private List ingredients; + @ManyToMany(mappedBy = "menuItems", targetEntity = Menu.class) + private List menus; + + public Long getId() { + return id; + } + + public void setId(Long id) { + this.id = id; + } + + public String getName() { + return name; + } + + public void setName(String name) { + this.name = name; + } + + public String getDescription() { + return description; + } + + public void setDescription(String description) { + this.description = description; + } + + public Double getPrice() { + return price; + } + + public void setPrice(Double price) { + this.price = price; + } + + public List getIngredients() { + return ingredients; + } + + public void setIngredients(List ingredients) { + this.ingredients = ingredients; + } + + public List getMenus() { + return menus; + } + + public void setMenus(List menus) { + this.menus = menus; + } + +} diff --git a/EduWaiterAppServer/src/main/java/com/caraeppes/EduWaiterAppServer/models/Restaurant.java b/EduWaiterAppServer/src/main/java/com/caraeppes/EduWaiterAppServer/models/Restaurant.java new file mode 100644 index 0000000..9c05912 --- /dev/null +++ b/EduWaiterAppServer/src/main/java/com/caraeppes/EduWaiterAppServer/models/Restaurant.java @@ -0,0 +1,101 @@ +package com.caraeppes.EduWaiterAppServer.models; + +import com.caraeppes.EduWaiterAppServer.utilities.AdminSerializer; +import com.caraeppes.EduWaiterAppServer.utilities.EmployeeSerializer; +import com.fasterxml.jackson.annotation.JsonIgnoreProperties; +import com.fasterxml.jackson.databind.annotation.JsonSerialize; + +import javax.persistence.*; +import java.util.ArrayList; +import java.util.List; + +@Entity +@Table(name = "restaurants") +@JsonIgnoreProperties({"hibernateLazyInitializer", "handler"}) +public class Restaurant { + + @Id + @Column(name = "restaurant_id") + @GeneratedValue(strategy = GenerationType.AUTO) + private Long id; + @Column(name = "name") + private String name; + @Column(name = "password") + private String password; + @OneToMany(fetch = FetchType.EAGER, cascade = CascadeType.ALL, mappedBy = "restaurant") + @JsonIgnoreProperties(value = "restaurant", allowSetters=true) + private List menus; + @OneToMany(mappedBy = "restaurant") + @JsonIgnoreProperties(value = "restaurant") + private List admin; + @OneToMany(mappedBy = "restaurant") + @JsonIgnoreProperties(value = "restaurant") + private List employees; + @OneToMany(mappedBy = "restaurant") + @JsonIgnoreProperties(value = "restaurant") + private List facts; + + public Restaurant() { + menus = new ArrayList<>(); + admin = new ArrayList<>(); + employees = new ArrayList<>(); + facts = new ArrayList<>(); + } + + public Long getId() { + return id; + } + + public void setId(Long id) { + this.id = id; + } + + public String getName() { + return name; + } + + public void setName(String name) { + this.name = name; + } + + public String getPassword() { + return password; + } + + public void setPassword(String password) { + this.password = password; + } + + public List getMenus() { + return menus; + } + + public void setMenus(List menus) { + this.menus = menus; + } + + public List getAdmin() { + return admin; + } + + public void setAdmin(List admin) { + this.admin = admin; + } + + public List getEmployees() { + return employees; + } + + public void setEmployees(List employees) { + this.employees = employees; + } + + public List getFacts() { + return facts; + } + + public void setFacts(List facts) { + this.facts = facts; + } + +} diff --git a/EduWaiterAppServer/src/main/java/com/caraeppes/EduWaiterAppServer/repositories/AdminAccountRepository.java b/EduWaiterAppServer/src/main/java/com/caraeppes/EduWaiterAppServer/repositories/AdminAccountRepository.java new file mode 100644 index 0000000..ea9dfa4 --- /dev/null +++ b/EduWaiterAppServer/src/main/java/com/caraeppes/EduWaiterAppServer/repositories/AdminAccountRepository.java @@ -0,0 +1,12 @@ +package com.caraeppes.EduWaiterAppServer.repositories; + +import com.caraeppes.EduWaiterAppServer.models.AdminAccount; +import org.springframework.data.jpa.repository.JpaRepository; +import org.springframework.stereotype.Repository; + +@Repository +public interface AdminAccountRepository extends JpaRepository { + + AdminAccount findAdminAccountByUsername(String username); +} + diff --git a/EduWaiterAppServer/src/main/java/com/caraeppes/EduWaiterAppServer/repositories/EmployeeAccountRepository.java b/EduWaiterAppServer/src/main/java/com/caraeppes/EduWaiterAppServer/repositories/EmployeeAccountRepository.java new file mode 100644 index 0000000..7a35ea6 --- /dev/null +++ b/EduWaiterAppServer/src/main/java/com/caraeppes/EduWaiterAppServer/repositories/EmployeeAccountRepository.java @@ -0,0 +1,11 @@ +package com.caraeppes.EduWaiterAppServer.repositories; + +import com.caraeppes.EduWaiterAppServer.models.EmployeeAccount; +import org.springframework.data.jpa.repository.JpaRepository; +import org.springframework.stereotype.Repository; + +@Repository +public interface EmployeeAccountRepository extends JpaRepository { + + EmployeeAccount findByUsername(String username); +} diff --git a/EduWaiterAppServer/src/main/java/com/caraeppes/EduWaiterAppServer/repositories/FactRepository.java b/EduWaiterAppServer/src/main/java/com/caraeppes/EduWaiterAppServer/repositories/FactRepository.java new file mode 100644 index 0000000..62d5be1 --- /dev/null +++ b/EduWaiterAppServer/src/main/java/com/caraeppes/EduWaiterAppServer/repositories/FactRepository.java @@ -0,0 +1,9 @@ +package com.caraeppes.EduWaiterAppServer.repositories; + +import com.caraeppes.EduWaiterAppServer.models.Fact; +import org.springframework.data.jpa.repository.JpaRepository; +import org.springframework.stereotype.Repository; + +@Repository +public interface FactRepository extends JpaRepository { +} diff --git a/EduWaiterAppServer/src/main/java/com/caraeppes/EduWaiterAppServer/repositories/IngredientRepository.java b/EduWaiterAppServer/src/main/java/com/caraeppes/EduWaiterAppServer/repositories/IngredientRepository.java new file mode 100644 index 0000000..5431330 --- /dev/null +++ b/EduWaiterAppServer/src/main/java/com/caraeppes/EduWaiterAppServer/repositories/IngredientRepository.java @@ -0,0 +1,9 @@ +package com.caraeppes.EduWaiterAppServer.repositories; + +import com.caraeppes.EduWaiterAppServer.models.Ingredient; +import org.springframework.data.jpa.repository.JpaRepository; +import org.springframework.stereotype.Repository; + +@Repository +public interface IngredientRepository extends JpaRepository { +} diff --git a/EduWaiterAppServer/src/main/java/com/caraeppes/EduWaiterAppServer/repositories/MenuItemRepository.java b/EduWaiterAppServer/src/main/java/com/caraeppes/EduWaiterAppServer/repositories/MenuItemRepository.java new file mode 100644 index 0000000..b9bc652 --- /dev/null +++ b/EduWaiterAppServer/src/main/java/com/caraeppes/EduWaiterAppServer/repositories/MenuItemRepository.java @@ -0,0 +1,9 @@ +package com.caraeppes.EduWaiterAppServer.repositories; + +import com.caraeppes.EduWaiterAppServer.models.MenuItem; +import org.springframework.data.jpa.repository.JpaRepository; +import org.springframework.stereotype.Repository; + +@Repository +public interface MenuItemRepository extends JpaRepository { +} diff --git a/EduWaiterAppServer/src/main/java/com/caraeppes/EduWaiterAppServer/repositories/MenuRepository.java b/EduWaiterAppServer/src/main/java/com/caraeppes/EduWaiterAppServer/repositories/MenuRepository.java new file mode 100644 index 0000000..3e836f7 --- /dev/null +++ b/EduWaiterAppServer/src/main/java/com/caraeppes/EduWaiterAppServer/repositories/MenuRepository.java @@ -0,0 +1,8 @@ +package com.caraeppes.EduWaiterAppServer.repositories; + +import com.caraeppes.EduWaiterAppServer.models.Menu; +import org.springframework.data.jpa.repository.JpaRepository; +import org.springframework.stereotype.Repository; + +@Repository +public interface MenuRepository extends JpaRepository {} diff --git a/EduWaiterAppServer/src/main/java/com/caraeppes/EduWaiterAppServer/repositories/RestaurantRepository.java b/EduWaiterAppServer/src/main/java/com/caraeppes/EduWaiterAppServer/repositories/RestaurantRepository.java new file mode 100644 index 0000000..e727fb4 --- /dev/null +++ b/EduWaiterAppServer/src/main/java/com/caraeppes/EduWaiterAppServer/repositories/RestaurantRepository.java @@ -0,0 +1,9 @@ +package com.caraeppes.EduWaiterAppServer.repositories; + +import com.caraeppes.EduWaiterAppServer.models.Restaurant; +import org.springframework.data.jpa.repository.JpaRepository; +import org.springframework.stereotype.Repository; + +@Repository +public interface RestaurantRepository extends JpaRepository { +} diff --git a/EduWaiterAppServer/src/main/java/com/caraeppes/EduWaiterAppServer/services/AdminAccountService.java b/EduWaiterAppServer/src/main/java/com/caraeppes/EduWaiterAppServer/services/AdminAccountService.java new file mode 100644 index 0000000..7065974 --- /dev/null +++ b/EduWaiterAppServer/src/main/java/com/caraeppes/EduWaiterAppServer/services/AdminAccountService.java @@ -0,0 +1,61 @@ +package com.caraeppes.EduWaiterAppServer.services; + +import com.caraeppes.EduWaiterAppServer.models.AdminAccount; +import com.caraeppes.EduWaiterAppServer.models.Restaurant; +import com.caraeppes.EduWaiterAppServer.repositories.AdminAccountRepository; +import com.caraeppes.EduWaiterAppServer.repositories.RestaurantRepository; +import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.stereotype.Service; + +import java.util.List; + +@Service +public class AdminAccountService { + + private AdminAccountRepository adminAccountRepository; + private RestaurantRepository restaurantRepository; + + @Autowired + public AdminAccountService(AdminAccountRepository adminAccountRepository, RestaurantRepository restaurantRepository) { + this.adminAccountRepository = adminAccountRepository; + this.restaurantRepository = restaurantRepository; + } + + public AdminAccount create(AdminAccount adminAccount) { + return adminAccountRepository.save(adminAccount); + } + + public AdminAccount findById(Long id) { + return adminAccountRepository.getOne(id); + } + + public List findAll() { + return adminAccountRepository.findAll(); + } + + public AdminAccount findByUsername(String username) { + return adminAccountRepository.findAdminAccountByUsername(username); + } + + public AdminAccount update(AdminAccount adminAccount, Long id) { + AdminAccount original = adminAccountRepository.getOne(id); + original.setFirstName(adminAccount.getFirstName()); + original.setLastName(adminAccount.getLastName()); + original.setRestaurant(adminAccount.getRestaurant()); + return adminAccountRepository.save(original); + } + + public AdminAccount updateRestaurant(Long restaurantId, Long id) { + AdminAccount original = adminAccountRepository.getOne(id); + Restaurant restaurant = restaurantRepository.getOne(restaurantId); + original.setRestaurant(restaurant); + return adminAccountRepository.save(original); + } + + public Boolean deleteById(Long id) { + adminAccountRepository.deleteById(id); + return true; + } + + +} diff --git a/EduWaiterAppServer/src/main/java/com/caraeppes/EduWaiterAppServer/services/EmployeeAccountService.java b/EduWaiterAppServer/src/main/java/com/caraeppes/EduWaiterAppServer/services/EmployeeAccountService.java new file mode 100644 index 0000000..a51223e --- /dev/null +++ b/EduWaiterAppServer/src/main/java/com/caraeppes/EduWaiterAppServer/services/EmployeeAccountService.java @@ -0,0 +1,60 @@ +package com.caraeppes.EduWaiterAppServer.services; + +import com.caraeppes.EduWaiterAppServer.models.EmployeeAccount; +import com.caraeppes.EduWaiterAppServer.models.Restaurant; +import com.caraeppes.EduWaiterAppServer.repositories.EmployeeAccountRepository; +import com.caraeppes.EduWaiterAppServer.repositories.RestaurantRepository; +import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.stereotype.Service; + +import java.util.List; + +@Service +public class EmployeeAccountService { + + private EmployeeAccountRepository employeeAccountRepository; + private RestaurantRepository restaurantRepository; + + @Autowired + public EmployeeAccountService(EmployeeAccountRepository employeeAccountRepository, + RestaurantRepository restaurantRepository) { + this.employeeAccountRepository = employeeAccountRepository; + this.restaurantRepository = restaurantRepository; + } + + public EmployeeAccount create(EmployeeAccount employeeAccount){ + return employeeAccountRepository.save(employeeAccount); + } + + public EmployeeAccount findById(Long id){ + return employeeAccountRepository.getOne(id); + } + + public List findAll(){ + return employeeAccountRepository.findAll(); + } + + public EmployeeAccount findByUsername(String username){ + return employeeAccountRepository.findByUsername(username); + } + + public EmployeeAccount update(EmployeeAccount employeeAccount, Long id){ + EmployeeAccount original = employeeAccountRepository.getOne(id); + original.setFirstName(employeeAccount.getFirstName()); + original.setLastName(employeeAccount.getLastName()); + original.setRestaurant(employeeAccount.getRestaurant()); + return employeeAccountRepository.save(original); + } + + public EmployeeAccount updateRestaurant(Long restaurantId, Long id){ + EmployeeAccount original = this.employeeAccountRepository.getOne(id); + Restaurant restaurant = this.restaurantRepository.getOne(restaurantId); + original.setRestaurant(restaurant); + return employeeAccountRepository.save(original); + } + + public Boolean deleteById(Long id){ + employeeAccountRepository.deleteById(id); + return true; + } +} diff --git a/EduWaiterAppServer/src/main/java/com/caraeppes/EduWaiterAppServer/services/FactService.java b/EduWaiterAppServer/src/main/java/com/caraeppes/EduWaiterAppServer/services/FactService.java new file mode 100644 index 0000000..22d60a5 --- /dev/null +++ b/EduWaiterAppServer/src/main/java/com/caraeppes/EduWaiterAppServer/services/FactService.java @@ -0,0 +1,7 @@ +package com.caraeppes.EduWaiterAppServer.services; + +import org.springframework.stereotype.Service; + +@Service +public class FactService { +} diff --git a/EduWaiterAppServer/src/main/java/com/caraeppes/EduWaiterAppServer/services/IngredientService.java b/EduWaiterAppServer/src/main/java/com/caraeppes/EduWaiterAppServer/services/IngredientService.java new file mode 100644 index 0000000..80f6da6 --- /dev/null +++ b/EduWaiterAppServer/src/main/java/com/caraeppes/EduWaiterAppServer/services/IngredientService.java @@ -0,0 +1,44 @@ +package com.caraeppes.EduWaiterAppServer.services; + +import com.caraeppes.EduWaiterAppServer.models.Ingredient; +import com.caraeppes.EduWaiterAppServer.repositories.IngredientRepository; +import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.stereotype.Service; + +import java.util.List; + +@Service +public class IngredientService { + + private IngredientRepository ingredientRepository; + + @Autowired + public IngredientService(IngredientRepository ingredientRepository) { + this.ingredientRepository = ingredientRepository; + } + + public Ingredient create(Ingredient ingredient){ + return ingredientRepository.save(ingredient); + } + + public Ingredient findById(Long id){ + return ingredientRepository.getOne(id); + } + + public List findAll(){ + return ingredientRepository.findAll(); + } + + public Ingredient update(Ingredient ingredient, Long id){ + Ingredient original = ingredientRepository.getOne(id); + original.setName(ingredient.getName()); + original.setMenuItems(ingredient.getMenuItems()); + original.setAllergen(ingredient.getAllergen()); + return ingredientRepository.save(original); + } + + public Boolean deleteById(Long id){ + ingredientRepository.deleteById(id); + return true; + } +} diff --git a/EduWaiterAppServer/src/main/java/com/caraeppes/EduWaiterAppServer/services/MenuItemService.java b/EduWaiterAppServer/src/main/java/com/caraeppes/EduWaiterAppServer/services/MenuItemService.java new file mode 100644 index 0000000..2ac408c --- /dev/null +++ b/EduWaiterAppServer/src/main/java/com/caraeppes/EduWaiterAppServer/services/MenuItemService.java @@ -0,0 +1,47 @@ +package com.caraeppes.EduWaiterAppServer.services; + +import com.caraeppes.EduWaiterAppServer.models.Menu; +import com.caraeppes.EduWaiterAppServer.models.MenuItem; +import com.caraeppes.EduWaiterAppServer.repositories.MenuItemRepository; +import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.stereotype.Service; + +import java.util.List; + +@Service +public class MenuItemService { + + private MenuItemRepository menuItemRepository; + + @Autowired + public MenuItemService(MenuItemRepository menuItemRepository) { + this.menuItemRepository = menuItemRepository; + } + + public MenuItem create(MenuItem menuItem) { + return menuItemRepository.save(menuItem); + } + + public MenuItem findById(Long id) { + return menuItemRepository.getOne(id); + } + + public List findAll() { + return menuItemRepository.findAll(); + } + + public MenuItem update(MenuItem menuItem, Long id) { + MenuItem original = menuItemRepository.getOne(id); + original.setName(menuItem.getName()); + original.setDescription(menuItem.getDescription()); + original.setMenus(menuItem.getMenus()); + original.setIngredients(menuItem.getIngredients()); + original.setPrice(menuItem.getPrice()); + return menuItemRepository.save(original); + } + + public Boolean deleteById(Long id) { + menuItemRepository.deleteById(id); + return true; + } +} diff --git a/EduWaiterAppServer/src/main/java/com/caraeppes/EduWaiterAppServer/services/MenuService.java b/EduWaiterAppServer/src/main/java/com/caraeppes/EduWaiterAppServer/services/MenuService.java new file mode 100644 index 0000000..bb10601 --- /dev/null +++ b/EduWaiterAppServer/src/main/java/com/caraeppes/EduWaiterAppServer/services/MenuService.java @@ -0,0 +1,58 @@ +package com.caraeppes.EduWaiterAppServer.services; + +import com.caraeppes.EduWaiterAppServer.models.Menu; +import com.caraeppes.EduWaiterAppServer.repositories.MenuRepository; +import com.caraeppes.EduWaiterAppServer.repositories.RestaurantRepository; +import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.stereotype.Service; + +import java.util.List; + +@Service +public class MenuService { + + private MenuRepository menuRepository; + private RestaurantRepository restaurantRepository; + + @Autowired + public MenuService(MenuRepository menuRepository, RestaurantRepository restaurantRepository) { + this.menuRepository = menuRepository; + this.restaurantRepository = restaurantRepository; + } + + public Menu create(Menu menu){ + return menuRepository.save(menu); + } + + public Menu findById(Long id){ + return menuRepository.getOne(id); + } + + public List findAll(){ + return menuRepository.findAll(); + } + + public Menu update(Menu menu, Long id){ + Menu original = menuRepository.getOne(id); + original.setName(menu.getName()); + original.setDescription(menu.getDescription()); + original.setRestaurant(menu.getRestaurant()); + original.setMenuItems(menu.getMenuItems()); + return menuRepository.save(original); + } + + public Menu updateDescription(Menu menu, String description){ + menu.setDescription(description); + return menuRepository.save(menu); + } + + public Menu updateRestaurant(Menu menu, Long restaurantId){ + menu.setRestaurant(restaurantRepository.getOne(restaurantId)); + return menuRepository.save(menu); + } + + public Boolean deleteById (Long id){ + menuRepository.deleteById(id); + return true; + } +} diff --git a/EduWaiterAppServer/src/main/java/com/caraeppes/EduWaiterAppServer/services/RestaurantService.java b/EduWaiterAppServer/src/main/java/com/caraeppes/EduWaiterAppServer/services/RestaurantService.java new file mode 100644 index 0000000..d56c90c --- /dev/null +++ b/EduWaiterAppServer/src/main/java/com/caraeppes/EduWaiterAppServer/services/RestaurantService.java @@ -0,0 +1,88 @@ +package com.caraeppes.EduWaiterAppServer.services; + +import com.caraeppes.EduWaiterAppServer.models.AdminAccount; +import com.caraeppes.EduWaiterAppServer.models.EmployeeAccount; +import com.caraeppes.EduWaiterAppServer.models.Menu; +import com.caraeppes.EduWaiterAppServer.models.Restaurant; +import com.caraeppes.EduWaiterAppServer.repositories.AdminAccountRepository; +import com.caraeppes.EduWaiterAppServer.repositories.EmployeeAccountRepository; +import com.caraeppes.EduWaiterAppServer.repositories.MenuRepository; +import com.caraeppes.EduWaiterAppServer.repositories.RestaurantRepository; +import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.stereotype.Service; + +import java.util.List; + +@Service +public class RestaurantService { + + private RestaurantRepository restaurantRepository; + private AdminAccountRepository adminAccountRepository; + private EmployeeAccountRepository employeeAccountRepository; + private MenuRepository menuRepository; + + @Autowired + public RestaurantService(RestaurantRepository restaurantRepository, + AdminAccountRepository adminAccountRepository, + EmployeeAccountRepository employeeAccountRepository, + MenuRepository menuRepository) { + this.restaurantRepository = restaurantRepository; + this.adminAccountRepository = adminAccountRepository; + this.employeeAccountRepository = employeeAccountRepository; + this.menuRepository = menuRepository; + + } + + public Restaurant create(Restaurant restaurant){ + return restaurantRepository.save(restaurant); + } + + public Restaurant findById(Long id){ + return restaurantRepository.getOne(id); + } + + public List findAll(){ + return restaurantRepository.findAll(); + } + + public Restaurant update(Restaurant restaurant, Long id){ + Restaurant original = restaurantRepository.getOne(id); + original.setName(restaurant.getName()); + original.setMenus(restaurant.getMenus()); + original.setEmployees(restaurant.getEmployees()); + original.setAdmin(restaurant.getAdmin()); + original.setFacts(restaurant.getFacts()); + return restaurantRepository.save(original); + } + + public Restaurant addAdmin(Restaurant restaurant, Long adminId){ + AdminAccount admin = adminAccountRepository.getOne(adminId); + restaurant.getAdmin().add(admin); + admin.setRestaurant(restaurant); + adminAccountRepository.save(admin); + return restaurantRepository.save(restaurant); + } + + public Restaurant addEmployee(Restaurant restaurant, Long employeeId){ + EmployeeAccount employeeAccount = employeeAccountRepository.getOne(employeeId); + restaurant.getEmployees().add(employeeAccount); + employeeAccount.setRestaurant(restaurant); + employeeAccountRepository.save(employeeAccount); + return restaurantRepository.save(restaurant); + } + + public Restaurant addMenu(Restaurant restaurant, Long menuId){ + Menu menu = menuRepository.getOne(menuId); + restaurant.getMenus().add(menu); + for(Menu m: restaurant.getMenus()){ + m.setRestaurant(restaurant); + } + menuRepository.saveAll(restaurant.getMenus()); + return restaurantRepository.save(restaurant); + } + + public Boolean deleteById(Long id){ + restaurantRepository.deleteById(id); + return true; + } +} diff --git a/EduWaiterAppServer/src/main/java/com/caraeppes/EduWaiterAppServer/utilities/AdminSerializer.java b/EduWaiterAppServer/src/main/java/com/caraeppes/EduWaiterAppServer/utilities/AdminSerializer.java new file mode 100644 index 0000000..0eb8e78 --- /dev/null +++ b/EduWaiterAppServer/src/main/java/com/caraeppes/EduWaiterAppServer/utilities/AdminSerializer.java @@ -0,0 +1,33 @@ +package com.caraeppes.EduWaiterAppServer.utilities; + +import com.caraeppes.EduWaiterAppServer.models.AdminAccount; +import com.caraeppes.EduWaiterAppServer.models.Ingredient; +import com.fasterxml.jackson.core.JsonGenerator; +import com.fasterxml.jackson.core.JsonProcessingException; +import com.fasterxml.jackson.databind.SerializerProvider; +import com.fasterxml.jackson.databind.ser.std.StdSerializer; + +import java.io.IOException; +import java.util.ArrayList; +import java.util.List; + +public class AdminSerializer extends StdSerializer> { + + public AdminSerializer() { + this(null); + } + + public AdminSerializer(Class> a) { + super(a); + } + + @Override + public void serialize(List admins, JsonGenerator gen, SerializerProvider provider) throws IOException { + List serializedAdmins = new ArrayList<>(); + for(AdminAccount a :admins){ + a.setRestaurant(null); + serializedAdmins.add(a); + } + gen.writeObject(serializedAdmins); + } +} diff --git a/EduWaiterAppServer/src/main/java/com/caraeppes/EduWaiterAppServer/utilities/EmployeeSerializer.java b/EduWaiterAppServer/src/main/java/com/caraeppes/EduWaiterAppServer/utilities/EmployeeSerializer.java new file mode 100644 index 0000000..29868ed --- /dev/null +++ b/EduWaiterAppServer/src/main/java/com/caraeppes/EduWaiterAppServer/utilities/EmployeeSerializer.java @@ -0,0 +1,32 @@ +package com.caraeppes.EduWaiterAppServer.utilities; + +import com.caraeppes.EduWaiterAppServer.models.EmployeeAccount; +import com.caraeppes.EduWaiterAppServer.models.EmployeeAccount; +import com.fasterxml.jackson.core.JsonGenerator; +import com.fasterxml.jackson.databind.SerializerProvider; +import com.fasterxml.jackson.databind.ser.std.StdSerializer; + +import java.io.IOException; +import java.util.ArrayList; +import java.util.List; + +public class EmployeeSerializer extends StdSerializer> { + + public EmployeeSerializer() { + this(null); + } + + public EmployeeSerializer(Class> e) { + super(e); + } + + @Override + public void serialize(List employees, JsonGenerator gen, SerializerProvider provider) throws IOException { + List serializedEmployees = new ArrayList<>(); + for(EmployeeAccount e : employees){ + e.setRestaurant(null); + serializedEmployees.add(e); + } + gen.writeObject(serializedEmployees); + } +} diff --git a/EduWaiterAppServer/src/main/java/com/caraeppes/EduWaiterAppServer/utilities/IngredientSerializer.java b/EduWaiterAppServer/src/main/java/com/caraeppes/EduWaiterAppServer/utilities/IngredientSerializer.java new file mode 100644 index 0000000..8f0e383 --- /dev/null +++ b/EduWaiterAppServer/src/main/java/com/caraeppes/EduWaiterAppServer/utilities/IngredientSerializer.java @@ -0,0 +1,35 @@ +package com.caraeppes.EduWaiterAppServer.utilities; + +import com.caraeppes.EduWaiterAppServer.models.Ingredient; +import com.caraeppes.EduWaiterAppServer.models.MenuItem; +import com.fasterxml.jackson.core.JsonGenerator; +import com.fasterxml.jackson.core.JsonProcessingException; +import com.fasterxml.jackson.databind.SerializerProvider; +import com.fasterxml.jackson.databind.ser.std.StdSerializer; + +import java.io.IOException; +import java.util.ArrayList; +import java.util.List; + +public class IngredientSerializer extends StdSerializer> { + + public IngredientSerializer() { + this(null); + } + + public IngredientSerializer(Class> i) { + super(i); + } + + @Override + public void serialize(List ingredients, JsonGenerator generator, + SerializerProvider provider) throws IOException{ + + List serializedIngredients = new ArrayList<>(); + for (Ingredient i : ingredients) { + i.setMenuItems(null); + serializedIngredients.add(i); + } + generator.writeObject(serializedIngredients); + } +} \ No newline at end of file diff --git a/EduWaiterAppServer/src/main/java/com/caraeppes/EduWaiterAppServer/utilities/MenuItemSerializer.java b/EduWaiterAppServer/src/main/java/com/caraeppes/EduWaiterAppServer/utilities/MenuItemSerializer.java new file mode 100644 index 0000000..84048b7 --- /dev/null +++ b/EduWaiterAppServer/src/main/java/com/caraeppes/EduWaiterAppServer/utilities/MenuItemSerializer.java @@ -0,0 +1,35 @@ +package com.caraeppes.EduWaiterAppServer.utilities; + + +import com.caraeppes.EduWaiterAppServer.models.MenuItem; +import com.fasterxml.jackson.core.JsonGenerator; +import com.fasterxml.jackson.core.JsonProcessingException; +import com.fasterxml.jackson.databind.SerializerProvider; +import com.fasterxml.jackson.databind.ser.std.StdSerializer; + +import java.io.IOException; +import java.util.ArrayList; +import java.util.List; + +public class MenuItemSerializer extends StdSerializer> { + + public MenuItemSerializer() { + this(null); + } + + public MenuItemSerializer(Class> m) { + super(m); + } + + @Override + public void serialize(List menuItems, JsonGenerator generator, + SerializerProvider provider) throws IOException{ + + List serializedMenuItems = new ArrayList<>(); + for (MenuItem m : menuItems) { + m.setMenus(null); + serializedMenuItems.add(m); + } + generator.writeObject(serializedMenuItems); + } +} \ No newline at end of file diff --git a/EduWaiterAppServer/src/main/resources/application.properties b/EduWaiterAppServer/src/main/resources/application.properties new file mode 100644 index 0000000..fcdceb1 --- /dev/null +++ b/EduWaiterAppServer/src/main/resources/application.properties @@ -0,0 +1,12 @@ + +spring.jpa.database-platform=org.hibernate.dialect.MySQL5Dialect +spring.jpa.hibernate.ddl-auto=create-drop +spring.jpa.show-sql=true + +spring.datasource.url=jdbc:mysql://localhost:3306/eduwaiter?useLegacyDatetimeCode=false&serverTimezone=UTC +spring.datasource.username=root +spring.datasource.password=root +spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver + +server.port=8888 + diff --git a/EduWaiterAppServer/src/test/java/com/caraeppes/EduWaiterAppServer/EduWaiterAppServerApplicationTests.java b/EduWaiterAppServer/src/test/java/com/caraeppes/EduWaiterAppServer/EduWaiterAppServerApplicationTests.java new file mode 100644 index 0000000..b2f2be7 --- /dev/null +++ b/EduWaiterAppServer/src/test/java/com/caraeppes/EduWaiterAppServer/EduWaiterAppServerApplicationTests.java @@ -0,0 +1,16 @@ +package com.caraeppes.EduWaiterAppServer; + +import org.junit.Test; +import org.junit.runner.RunWith; +import org.springframework.boot.test.context.SpringBootTest; +import org.springframework.test.context.junit4.SpringRunner; + +@RunWith(SpringRunner.class) +@SpringBootTest +public class EduWaiterAppServerApplicationTests { + + @Test + public void contextLoads() { + } + +} diff --git a/ListOfRepos.md b/ListOfRepos.md index dc9f26b..4927943 100644 --- a/ListOfRepos.md +++ b/ListOfRepos.md @@ -8,5 +8,6 @@ list of pull requests both in your account and in my repo. ### List of Names and URLs * [Johnny Appleseed](https://github.com/kristofer/ziti) +* [Cara Eppes](https://github.com/caraeppes/PassionBy5dot0) Add your name and URL like the one above. diff --git a/ProjectDescription.md b/ProjectDescription.md index 6d59c48..1f77823 100644 --- a/ProjectDescription.md +++ b/ProjectDescription.md @@ -1,8 +1,19 @@ -# Your Project Name +## EduWaiter -### a cool tagline... +EduWaiter is a restaurant waitstaff training application. -Less than 300 words which describe your project. Etc,.... +This computer application generates customized study aids, games, and quizzes to help new servers maximize their restaurant and menu knowledge. +EduWaiter allows restaurant owners to: +* input menu items with images and detailed descriptions of ingredients, quantities, prices, allergens, and potential upsells +* easily create custom, interactive restaurant floor maps +* provide new employees with important restaurant information and answers to frequently asked questions +* keep staff updated with daily specials, drink selections, and new menu items +* track the progress of staff and trainees to ensure that their servers are ready to take the floor -* Your Name Here \ No newline at end of file +Rapid server turnover due to insufficient training is a prominent source of waste in the restaurant industry. EduWaiter's +easily accessible, interactive learning tools improve the waitstaff training proces and contribute to the ongoing success of +restaurant owners and staff alike. + + +* Cara Eppes diff --git a/README.md b/README.md index c29a4dc..677e480 100644 --- a/README.md +++ b/README.md @@ -1,54 +1,16 @@ -# PassionBy5dot0 - -a start on the passion projects of cohort 5.0 - -Fork this project. Edit the ListOfRepos file, adding your name and URL to the list. - -In your passion project repo, the one that is pointed to by the URL you put in the list, -edit your `README.md` file with your writeup. -If you want to make it fancy, learn how to use [MarkDown](https://guides.github.com/pdfs/markdown-cheatsheet-online.pdf) as the way to make - -## headers, - -* bullets, -* lists -* and other useful -* etc. - -In your passion project's repo, in README.md, is to write about 300 words on what you think you'd like to try to do. -Also put that description into the ProjectDescription.md file of your own repo. If you are uncertain about what -project to do, put a list of all your ideas into the file. - -This is an early __stake in the ground__, not a contract to have to do your very first idea. You'll have plenty of chance to -think about it and modify as needed. But get *something* scratched out. - -It's best if you write a few paragraphs on the idea itself. Something like - -> Figaro is a personal information manager that keeps your very important documents, notes and other -> digital assets safe and secure. It provides you instant, fingertip access to these personal -> items, allowing you to share them with others who are important to you. -> -> It is both a mobile and desktop app, with an Amazon cloud-based backend storage vault. -> -> Figaro allows you to categorize various filings by various tags, and gives you clear control of -> the information you keep. - -This kind of overview can help crystalize the way you think about your project, since you should consider: - -__Questions__ - -* who your app/project serves (who is the user) -* what information the app tracks for them or provides for them -* what the backend/database tracks about your users -* what the overall user concepts are you'd like the app center on - * Ex: email apps: have an INBOX, which tracks MESSAGEs, and a way to COMPOSE a MESSAGE - * Ex: spreadsheet: has a matrix of CELLs that can hold NUMBERs, TEXT or FORMULAs - * Ex: phonebook: has a list of CONTACTs, each of which can have many PHONENUMBERs -* what problems does your app/project solve -* is is modelled after another app, if so, how is your different - -The app can be a mobile app or a desktop/laptop app, so dream big. +## EduWaiter +EduWaiter is a restaurant waitstaff training application. +This computer application generates customized study aids, games, and quizzes to help new servers maximize their restaurant and menu knowledge. +EduWaiter allows restaurant owners to: +* input menu items with images and detailed descriptions of ingredients, quantities, prices, allergens, and potential upsells +* easily create custom, interactive restaurant floor maps +* provide new employees with important restaurant information and answers to frequently asked questions +* keep staff updated with daily specials, drink selections, and new menu items +* track the progress of staff and trainees to ensure that their servers are ready to take the floor +Rapid server turnover due to insufficient training is a prominent source of waste in the restaurant industry. EduWaiter's +easily accessible, interactive learning tools improve the waitstaff training proces and contribute to the ongoing success of +restaurant owners and staff alike.