build: added ng-bootstrap for dropdown nav menu, removed material

This commit is contained in:
Mathew Guest 2024-08-04 04:45:33 -06:00
parent d948062154
commit cb7bc56e01
19 changed files with 198 additions and 1031 deletions

@ -13,11 +13,7 @@
"project": ["tsconfig.*?.json"], "project": ["tsconfig.*?.json"],
"createDefaultProgram": true "createDefaultProgram": true
}, },
"extends": [ "extends": ["plugin:@angular-eslint/recommended", "plugin:@typescript-eslint/recommended", "prettier"],
"plugin:@angular-eslint/recommended",
"plugin:@typescript-eslint/recommended",
"prettier"
],
"rules": { "rules": {
"@angular-eslint/component-class-suffix": [ "@angular-eslint/component-class-suffix": [
"error", "error",
@ -25,14 +21,8 @@
"suffixes": ["Component", "Page"] "suffixes": ["Component", "Page"]
} }
], ],
"@angular-eslint/directive-selector": [ "@angular-eslint/directive-selector": ["error", { "type": "attribute", "prefix": "app", "style": "camelCase" }],
"error", "@angular-eslint/component-selector": ["error", { "type": "element", "prefix": "app", "style": "kebab-case" }]
{ "type": "attribute", "prefix": "app", "style": "camelCase" }
],
"@angular-eslint/component-selector": [
"error",
{ "type": "element", "prefix": "app", "style": "kebab-case" }
]
} }
}, },
{ {

@ -31,11 +31,11 @@ podman compose up
``` ```
```bash ```bash
# Build Docker image # Build Docker
$ docker build . -t angular-starter $ docker build . -t skrill-frontend
# Run Docker Container # Run Docker Container
$ docker run -p 3000:80 angular-starter $ docker run -p 3000:80 skrill-frontend
``` ```
## Docker Hub ## Docker Hub

@ -1,4 +1,4 @@
version: '3' version: "3"
services: services:
app: app:
image: skrill:latest image: skrill:latest

1033
package-lock.json generated

File diff suppressed because it is too large Load Diff

@ -52,10 +52,10 @@
"@angular/compiler": "^17.3.6", "@angular/compiler": "^17.3.6",
"@angular/core": "^17.3.6", "@angular/core": "^17.3.6",
"@angular/forms": "^17.3.6", "@angular/forms": "^17.3.6",
"@angular/material": "^17.3.6",
"@angular/platform-browser": "^17.3.6", "@angular/platform-browser": "^17.3.6",
"@angular/platform-browser-dynamic": "^17.3.6", "@angular/platform-browser-dynamic": "^17.3.6",
"@angular/router": "^17.3.6", "@angular/router": "^17.3.6",
"@ng-bootstrap/ng-bootstrap": "^16.0.0",
"@ngneat/transloco": "^6.0.4", "@ngneat/transloco": "^6.0.4",
"bootstrap": "^5.3.3", "bootstrap": "^5.3.3",
"ng": "^0.0.0", "ng": "^0.0.0",

@ -1,36 +1,19 @@
<!-- Toolbar --> <!-- Toolbar -->
<header> <header>
<!--<div class="toolbar" role="banner">--> <div class="container-fluid">
<img <div class="row">
width="40" <div class="col">
alt="Angular Logo" <h1>$kriLL</h1>
src="" </div>
/> </div>
<span>$kriLL</span>
<!-- <div class="spacer"></div>-->
<nav> <div class="row">
<ul> <div class="col">
<li> <app-main-navigation></app-main-navigation>
<a routerLink="/scout"> </div>
<button class="btn btn-warning" type="button">Scouting</button> </div>
</a> </div>
</li>
<li>
<button class="btn btn-warning" type="button">
<a routerLink="/portfolio">Portfolio</a>
</button>
</li>
<li>
<button class="btn btn-warning" type="button">
<a routerLink="/trade">Trade</a>
</button>
</li>
</ul>
</nav>
<!--</div>-->
</header> </header>
<main> <main>
@ -42,7 +25,7 @@
<footer> <footer>
<div class="container-fluid"> <div class="container-fluid">
Copyright &copy 2024 Zavage Software Inc., all rights reserved.<br /> Copyright &copy; 2024 Zavage Software Inc., all rights reserved.<br />
Denver, CO Denver, CO
</div> </div>
</footer> </footer>

@ -4,9 +4,7 @@ import { AppComponent } from './app.component';
describe('AppComponent', () => { describe('AppComponent', () => {
beforeEach(async(() => { beforeEach(async(() => {
TestBed.configureTestingModule({ TestBed.configureTestingModule({
declarations: [ declarations: [AppComponent],
AppComponent
],
}).compileComponents(); }).compileComponents();
})); }));

@ -9,6 +9,8 @@ import { TranslocoRootModule } from './transloco-root.module';
import { ScoutingCryptoComponent } from './scouting-crypto/scouting-crypto.component'; import { ScoutingCryptoComponent } from './scouting-crypto/scouting-crypto.component';
import { HomeComponent } from './home-component/home.component'; import { HomeComponent } from './home-component/home.component';
import { RouterModule } from '@angular/router'; import { RouterModule } from '@angular/router';
import { NgbModule } from '@ng-bootstrap/ng-bootstrap';
import { MainNavigationComponent } from './main-navigation/main-navigation.component';
@NgModule({ @NgModule({
imports: [ imports: [
@ -16,10 +18,11 @@ import { RouterModule } from '@angular/router';
BrowserModule, BrowserModule,
BrowserAnimationsModule, BrowserAnimationsModule,
HttpClientModule, HttpClientModule,
NgbModule,
TranslocoRootModule, TranslocoRootModule,
RouterModule.forRoot([{ path: '', component: ScoutingCryptoComponent }]), RouterModule.forRoot([{ path: '', component: ScoutingCryptoComponent }]),
], ],
declarations: [ScoutingCryptoComponent, HomeComponent, AppComponent], declarations: [ScoutingCryptoComponent, HomeComponent, AppComponent, MainNavigationComponent],
providers: [], providers: [],
bootstrap: [AppComponent], bootstrap: [AppComponent],
}) })

@ -0,0 +1,10 @@
nav ul {
margin: 0;
padding: 0;
list-style-type: none;
}
nav ul li {
display: inline;
margin-right: 1em;
}

@ -0,0 +1,30 @@
<nav>
<div
ngbDropdown
class="d-inline-block"
#myDrop="ngbDropdown"
(mouseenter)="onMouseEnter()"
(mouseleave)="onMouseLeave()"
>
<button type="button" class="btn btn-outline-warning" id="scouting" ngbDropdownToggle>Scouting</button>
<div ngbDropdownMenu aria-labelledby="scouting">
<button ngbDropdownItem><a routerLink="/scouting/cypto">Crypto</a></button>
<button ngbDropdownItem><a routerLink="/scouting/stocks">Stocks</a></button>
<button ngbDropdownItem><a routerLink="/scouting/indicators">Indicators</a></button>
</div>
</div>
<!-- <div ngbDropdown class="d-inline-block"-->
<!-- #myDrop="ngbDropdown"-->
<!-- (mouseenter)="onMouseEnter()"-->
<!-- (mouseleave)="onMouseLeave()"-->
<!-- >-->
<!-- <button type="button" class="btn btn-outline-warning" id="portfolio" ngbDropdownToggle>-->
<!-- Scouting-->
<!-- </button>-->
<!-- <div ngbDropdownMenu aria-labelledby="portfolio">-->
<!-- <button ngbDropdownItem><a routerLink="/portfolio/holdings">Crypto</a></button>-->
<!-- <button ngbDropdownItem><a routerLink="/portfolio/orders">Stocks</a></button>-->
<!-- </div>-->
<!-- </div>-->
</nav>

@ -0,0 +1,23 @@
import { Component, ViewChild } from '@angular/core';
import { NgbDropdown } from '@ng-bootstrap/ng-bootstrap';
@Component({
selector: 'app-main-navigation',
templateUrl: './main-navigation.component.html',
styleUrl: './main-navigation.component.css',
})
export class MainNavigationComponent {
@ViewChild('myDrop', { static: false }) myDrop: NgbDropdown;
private timeout: number;
onMouseEnter() {
clearTimeout(this.timeout);
this.myDrop.open();
}
onMouseLeave() {
this.timeout = setTimeout(() => {
this.myDrop.close();
}, 300); // Delay before closing helps if mouse moves to 1px gap for submenu
}
}

@ -5,7 +5,7 @@ import {
TranslocoLoader, TranslocoLoader,
TRANSLOCO_CONFIG, TRANSLOCO_CONFIG,
translocoConfig, translocoConfig,
TranslocoModule TranslocoModule,
} from '@ngneat/transloco'; } from '@ngneat/transloco';
import { Injectable, NgModule } from '@angular/core'; import { Injectable, NgModule } from '@angular/core';
import { environment } from '../environments/environment'; import { environment } from '../environments/environment';
@ -31,9 +31,9 @@ export class TranslocoHttpLoader implements TranslocoLoader {
// Remove this option if your application doesn't support changing language in runtime. // Remove this option if your application doesn't support changing language in runtime.
reRenderOnLangChange: true, reRenderOnLangChange: true,
prodMode: environment.production, prodMode: environment.production,
}) }),
}, },
{ provide: TRANSLOCO_LOADER, useClass: TranslocoHttpLoader } { provide: TRANSLOCO_LOADER, useClass: TranslocoHttpLoader },
] ],
}) })
export class TranslocoRootModule {} export class TranslocoRootModule {}

@ -1,3 +1,3 @@
export const environment = { export const environment = {
production: true production: true,
}; };

@ -3,7 +3,7 @@
// The list of file replacements can be found in `angular.json`. // The list of file replacements can be found in `angular.json`.
export const environment = { export const environment = {
production: false production: false,
}; };
/* /*

@ -1,14 +1,14 @@
Object.defineProperty(window, 'CSS', { value: null }); Object.defineProperty(window, 'CSS', { value: null });
Object.defineProperty(document, 'doctype', { Object.defineProperty(document, 'doctype', {
value: '<!DOCTYPE html>' value: '<!DOCTYPE html>',
}); });
Object.defineProperty(window, 'getComputedStyle', { Object.defineProperty(window, 'getComputedStyle', {
value: () => { value: () => {
return { return {
display: 'none', display: 'none',
appearance: ['-webkit-appearance'] appearance: ['-webkit-appearance'],
}; };
} },
}); });
/** /**
* ISSUE: https://github.com/angular/material2/issues/7101 * ISSUE: https://github.com/angular/material2/issues/7101

@ -8,5 +8,6 @@ if (environment.production) {
enableProdMode(); enableProdMode();
} }
platformBrowserDynamic().bootstrapModule(AppModule) platformBrowserDynamic()
.catch(err => console.error(err)); .bootstrapModule(AppModule)
.catch((err) => console.error(err));

@ -1,5 +1,5 @@
module.exports = { module.exports = {
rootTranslationsPath: 'src/assets/i18n/', rootTranslationsPath: "src/assets/i18n/",
langs: ['de', 'en'], langs: ["de", "en"],
keysManager: {} keysManager: {},
}; };

@ -2,16 +2,8 @@
"extends": "./tsconfig.json", "extends": "./tsconfig.json",
"compilerOptions": { "compilerOptions": {
"outDir": "./out-tsc/spec", "outDir": "./out-tsc/spec",
"types": [ "types": ["jest", "node"]
"jest",
"node"
]
}, },
"files": [ "files": ["src/polyfills.ts"],
"src/polyfills.ts" "include": ["src/**/*.spec.ts", "src/**/*.d.ts"]
],
"include": [
"src/**/*.spec.ts",
"src/**/*.d.ts"
]
} }