pleroma/app/soapbox/reducers/accounts.js

120 lines
3.5 KiB
JavaScript
Raw Normal View History

2020-03-27 13:59:38 -07:00
import {
ACCOUNT_IMPORT,
ACCOUNTS_IMPORT,
ACCOUNT_FETCH_FAIL_FOR_USERNAME_LOOKUP,
} from '../actions/importer';
2020-08-28 12:42:58 -07:00
import { CHATS_FETCH_SUCCESS, CHAT_FETCH_SUCCESS } from 'soapbox/actions/chats';
import { STREAMING_CHAT_UPDATE } from 'soapbox/actions/streaming';
import { normalizeAccount as normalizeAccount2 } from 'soapbox/actions/importer/normalizer';
2021-03-15 19:50:16 -07:00
import {
Map as ImmutableMap,
List as ImmutableList,
fromJS,
} from 'immutable';
import { normalizePleromaUserFields } from 'soapbox/utils/pleroma';
2021-03-15 19:50:16 -07:00
import {
ADMIN_USERS_TAG_REQUEST,
ADMIN_USERS_TAG_FAIL,
ADMIN_USERS_UNTAG_REQUEST,
ADMIN_USERS_UNTAG_FAIL,
} from 'soapbox/actions/admin';
2021-06-30 01:02:52 -07:00
import { ADMIN_USERS_DELETE_REQUEST } from 'soapbox/actions/admin';
2020-03-27 13:59:38 -07:00
const initialState = ImmutableMap();
const normalizePleroma = account => {
if (!account.pleroma) return account;
account.pleroma = normalizePleromaUserFields(account.pleroma);
delete account.pleroma.chat_token;
return account;
};
2020-03-27 13:59:38 -07:00
const normalizeAccount = (state, account) => {
const normalized = fromJS(normalizePleroma(account)).deleteAll([
2020-07-04 17:37:07 -07:00
'followers_count',
'following_count',
'statuses_count',
]);
2020-03-27 13:59:38 -07:00
2020-07-04 17:37:07 -07:00
return state.set(account.id, normalized);
2020-03-27 13:59:38 -07:00
};
const normalizeAccounts = (state, accounts) => {
accounts.forEach(account => {
state = normalizeAccount(state, account);
});
return state;
};
const importAccountFromChat = (state, chat) =>
// TODO: Fix this monstrosity
normalizeAccount(state, normalizeAccount2(chat.account));
const importAccountsFromChats = (state, chats) =>
state.withMutations(mutable =>
chats.forEach(chat => importAccountFromChat(mutable, chat)));
2021-03-15 19:50:16 -07:00
const addTags = (state, accountIds, tags) => {
return state.withMutations(state => {
accountIds.forEach(id => {
state.updateIn([id, 'pleroma', 'tags'], ImmutableList(), v =>
v.toOrderedSet().union(tags).toList(),
);
});
});
};
const removeTags = (state, accountIds, tags) => {
return state.withMutations(state => {
accountIds.forEach(id => {
state.updateIn([id, 'pleroma', 'tags'], ImmutableList(), v =>
v.toOrderedSet().subtract(tags).toList(),
);
});
});
};
2021-06-30 01:02:52 -07:00
const nicknamesToIds = (state, nicknames) => {
return nicknames.map(nickname => {
return state.find(account => account.get('acct') === nickname, null, ImmutableMap()).get('id');
});
};
const setDeactivated = (state, nicknames) => {
const ids = nicknamesToIds(state, nicknames);
return state.withMutations(state => {
ids.forEach(id => {
state.setIn([id, 'pleroma', 'is_active'], false);
});
});
};
2020-03-27 13:59:38 -07:00
export default function accounts(state = initialState, action) {
switch(action.type) {
case ACCOUNT_IMPORT:
return normalizeAccount(state, action.account);
case ACCOUNTS_IMPORT:
return normalizeAccounts(state, action.accounts);
case ACCOUNT_FETCH_FAIL_FOR_USERNAME_LOOKUP:
return state.set(-1, ImmutableMap({
2020-04-14 11:44:40 -07:00
username: action.username,
2020-03-27 13:59:38 -07:00
}));
case CHATS_FETCH_SUCCESS:
return importAccountsFromChats(state, action.chats);
2020-08-28 12:42:58 -07:00
case CHAT_FETCH_SUCCESS:
case STREAMING_CHAT_UPDATE:
return importAccountsFromChats(state, [action.chat]);
2021-03-15 19:50:16 -07:00
case ADMIN_USERS_TAG_REQUEST:
case ADMIN_USERS_UNTAG_FAIL:
return addTags(state, action.accountIds, action.tags);
case ADMIN_USERS_UNTAG_REQUEST:
case ADMIN_USERS_TAG_FAIL:
return removeTags(state, action.accountIds, action.tags);
2021-06-30 01:02:52 -07:00
case ADMIN_USERS_DELETE_REQUEST:
return setDeactivated(state, action.nicknames);
2020-03-27 13:59:38 -07:00
default:
return state;
}
};