|
|
|
|
@@ -12,14 +12,13 @@ import {UserService} from '../../../services/user/user.service';
|
|
|
|
|
export class ShowSongService {
|
|
|
|
|
public constructor(private showSongDataService: ShowSongDataService, private songDataService: SongDataService, private userService: UserService) {}
|
|
|
|
|
|
|
|
|
|
public async new$(showId: string, songId: string, order: number, addedLive = false): Promise<string | null> {
|
|
|
|
|
public async new$(showId: string, songId: string, addedLive = false): Promise<string | null> {
|
|
|
|
|
const song = await this.songDataService.read$(songId).pipe(take(1)).toPromise();
|
|
|
|
|
const user = await this.userService.user$.pipe(take(1)).toPromise();
|
|
|
|
|
if (!song || !user) return null;
|
|
|
|
|
const data: Partial<ShowSong> = {
|
|
|
|
|
...song,
|
|
|
|
|
songId,
|
|
|
|
|
order,
|
|
|
|
|
key: song.key,
|
|
|
|
|
keyOriginal: song.key,
|
|
|
|
|
chordMode: user.chordMode,
|
|
|
|
|
@@ -31,7 +30,7 @@ export class ShowSongService {
|
|
|
|
|
public read$ = (showId: string, songId: string): Observable<ShowSong | null> => this.showSongDataService.read$(showId, songId);
|
|
|
|
|
public read = (showId: string, songId: string): Promise<ShowSong | null> => this.read$(showId, songId).pipe(first()).toPromise();
|
|
|
|
|
|
|
|
|
|
public list$ = (showId: string): Observable<ShowSong[]> => this.showSongDataService.list$(showId, _ => _.orderBy('order'));
|
|
|
|
|
public list$ = (showId: string): Observable<ShowSong[]> => this.showSongDataService.list$(showId);
|
|
|
|
|
public list = (showId: string): Promise<ShowSong[]> => this.list$(showId).pipe(first()).toPromise();
|
|
|
|
|
public delete$ = (showId: string, songId: string): Promise<void> => this.showSongDataService.delete(showId, songId);
|
|
|
|
|
public update$ = async (showId: string, songId: string, data: Partial<ShowSong>): Promise<void> => await this.showSongDataService.update$(showId, songId, data);
|
|
|
|
|
|