2018-10-31 05:02:03 +01:00
|
|
|
import { Injectable } from '@angular/core';
|
|
|
|
import { Store } from '@ngxs/store';
|
|
|
|
|
|
|
|
import { AccountInfo } from '../states/accounts.state';
|
2018-11-03 02:35:33 +01:00
|
|
|
import { MastodonService } from './mastodon.service';
|
|
|
|
import { Account, Results } from "./models/mastodon.interfaces";
|
2018-10-31 05:02:03 +01:00
|
|
|
|
|
|
|
|
|
|
|
@Injectable({
|
|
|
|
providedIn: 'root'
|
|
|
|
})
|
|
|
|
export class ToolsService {
|
|
|
|
|
2018-11-03 02:35:33 +01:00
|
|
|
constructor(
|
|
|
|
private readonly mastodonService: MastodonService,
|
|
|
|
private readonly store: Store) { }
|
2018-10-31 05:02:03 +01:00
|
|
|
|
|
|
|
|
|
|
|
getSelectedAccounts(): AccountInfo[] {
|
|
|
|
var regAccounts = <AccountInfo[]>this.store.snapshot().registeredaccounts.accounts;
|
|
|
|
return regAccounts.filter(x => x.isSelected);
|
|
|
|
}
|
|
|
|
|
2018-11-03 02:35:33 +01:00
|
|
|
findAccount(account: AccountInfo, accountName: string): Promise<Account> {
|
|
|
|
return this.mastodonService.search(account, accountName, true)
|
|
|
|
.then((result: Results) => {
|
|
|
|
console.warn('findAccount');
|
|
|
|
console.warn(`accountName ${accountName}`);
|
|
|
|
console.warn(result);
|
|
|
|
|
|
|
|
const foundAccount = result.accounts.filter(
|
|
|
|
x => x.acct.toLowerCase() === accountName.toLowerCase()
|
|
|
|
|| x.acct.toLowerCase() === accountName.toLowerCase().split('@')[0]
|
|
|
|
)[0];
|
|
|
|
return foundAccount;
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
2018-10-31 05:02:03 +01:00
|
|
|
}
|