added services and interfaces for expense types

This commit is contained in:
Joe Arndt 2026-02-12 14:56:09 -06:00
parent bd18fecdff
commit 7bb21f8796
8 changed files with 142 additions and 5 deletions

View file

@ -1,6 +1,5 @@
import { ApplicationConfig, provideBrowserGlobalErrorListeners } from '@angular/core';
import { provideRouter } from '@angular/router';
import { routes } from './app.routes';
export const appConfig: ApplicationConfig = {

View file

@ -11,6 +11,8 @@ export class ExpenseList implements OnInit {
public constructor(private readonly expenses: Expenses) { }
public ngOnInit() {
void this.expenses.getExpenses();
this.expenses.getExpenses().then(expenses => {
console.log({ expenses });
});
}
}

View file

@ -0,0 +1,19 @@
import { Injectable } from '@angular/core';
@Injectable({
providedIn: 'root',
})
export class Categories {
public static readonly BASE_URL = 'http://localhost:3000/common-cents/categories';
public async getCategories(): Promise<Category[]> {
console.log('getCategories called');
return [];
}
}
export interface Category {
id: string;
name: string;
}

View file

@ -1,12 +1,32 @@
import { Injectable } from '@angular/core';
import { SubCategory } from './sub-categories';
import { Category } from './categories';
import { Merchant } from './merchants';
import { Tag } from './tags';
import { Http } from './http';
@Injectable({
providedIn: 'root',
})
export class Expenses {
public static readonly BASE_URL = 'http://localhost:3000/common-cents/expenses';
public static readonly EXPENSES_URI = 'http://localhost:3000/common-cents/expenses';
public async getExpenses(): Promise<void> {
console.log('getExpenses called');
public constructor(private readonly http: Http) { }
public async getExpenses(): Promise<Expense[]> {
return this.http.get<Expense[]>(Expenses.EXPENSES_URI);
}
}
export interface Expense {
id: string;
year: string;
month: string;
day: string;
cents: number;
description?: string;
category: Category;
subCategory?: SubCategory;
merchant?: Merchant;
tags: Tag[];
}

40
src/app/services/http.ts Normal file
View file

@ -0,0 +1,40 @@
import { Injectable } from '@angular/core';
import { HttpClient } from '@angular/common/http';
import { firstValueFrom } from 'rxjs';
@Injectable({
providedIn: 'root',
})
export class Http {
public constructor(private httpClient: HttpClient) { }
public async get<T>(url: string): Promise<T> {
return this.request<T>(url, 'get');
}
public async post<T>(url: string, body?: any): Promise<T> {
return this.request<T>(url, 'post', body);
}
public async put<T>(url: string, body?: any): Promise<T> {
return this.request<T>(url, 'put', body);
}
public async delete<T>(url: string): Promise<T> {
return this.request<T>(url, 'delete');
}
private async request<T>(url: string, method: 'get' | 'post' | 'put' | 'delete', body?: any): Promise<T> {
const headers = { 'Accept': 'application/json', 'Content-Type': 'application/json' };
switch (method) {
case 'post':
return firstValueFrom(this.httpClient.post<T>(url, body, { headers }));
case 'put':
return firstValueFrom(this.httpClient.put<T>(url, body, { headers }));
case 'delete':
return firstValueFrom(this.httpClient.delete<T>(url, { headers }));
default:
return firstValueFrom(this.httpClient.get<T>(url, { headers }));
}
}
}

View file

@ -0,0 +1,19 @@
import { Injectable } from '@angular/core';
@Injectable({
providedIn: 'root',
})
export class Merchants {
public static readonly BASE_URL = 'http://localhost:3000/common-cents/merchants';
public async getMerchants(): Promise<Merchant[]> {
console.log('getMerchants called');
return [];
}
}
export interface Merchant {
id: string;
name: string;
}

View file

@ -0,0 +1,19 @@
import { Injectable } from '@angular/core';
@Injectable({
providedIn: 'root',
})
export class SubCategories {
public static readonly BASE_URL = 'http://localhost:3000/common-cents/sub-categories';
public async getSubCategories(): Promise<SubCategory[]> {
console.log('getSubCategories called');
return [];
}
}
export interface SubCategory {
id: string;
name: string;
}

19
src/app/services/tags.ts Normal file
View file

@ -0,0 +1,19 @@
import { Injectable } from '@angular/core';
@Injectable({
providedIn: 'root',
})
export class Tags {
public static readonly BASE_URL = 'http://localhost:3000/common-cents/tags';
public async getTags(): Promise<Tag[]> {
console.log('getTags called');
return [];
}
}
export interface Tag {
id: string;
name: string;
}