diff --git a/bin/mastodon-data.js b/bin/mastodon-data.js index 66206f3..46584d2 100644 --- a/bin/mastodon-data.js +++ b/bin/mastodon-data.js @@ -326,5 +326,12 @@ export const actions = times(30, i => ({ inReplyTo: 'bazthread-thread 2b2', privacy: 'unlisted' } + }, + { + user: 'LockedAccount', + post: { + text: 'This account is locked', + privacy: 'private' + } } ])) diff --git a/bin/svgs.js b/bin/svgs.js index cbf13f9..e4bd6a7 100644 --- a/bin/svgs.js +++ b/bin/svgs.js @@ -30,5 +30,6 @@ module.exports = [ {id: 'fa-smile', src: 'node_modules/font-awesome-svg-png/white/svg/smile-o.svg', title: 'Custom emoji'}, {id: 'fa-exclamation-triangle', src: 'node_modules/font-awesome-svg-png/white/svg/exclamation-triangle.svg', title: 'Content warning'}, {id: 'fa-check', src: 'node_modules/font-awesome-svg-png/white/svg/check.svg', title: 'Check'}, - {id: 'fa-trash', src: 'node_modules/font-awesome-svg-png/white/svg/trash-o.svg', title: 'Delete'} + {id: 'fa-trash', src: 'node_modules/font-awesome-svg-png/white/svg/trash-o.svg', title: 'Delete'}, + {id: 'fa-hourglass', src: 'node_modules/font-awesome-svg-png/white/svg/hourglass.svg', title: 'Follow requested'} ] diff --git a/fixtures/dump.sql b/fixtures/dump.sql index a2038b2..af6f4d8 100644 Binary files a/fixtures/dump.sql and b/fixtures/dump.sql differ diff --git a/fixtures/system.tgz b/fixtures/system.tgz index acf3a07..92fcc8f 100644 Binary files a/fixtures/system.tgz and b/fixtures/system.tgz differ diff --git a/routes/_actions/follow.js b/routes/_actions/follow.js index cf5ccf5..9f9c1c0 100644 --- a/routes/_actions/follow.js +++ b/routes/_actions/follow.js @@ -2,6 +2,7 @@ import { store } from '../_store/store' import { followAccount, unfollowAccount } from '../_api/follow' import { database } from '../_database/database' import { toast } from '../_utils/toast' +import { updateProfileAndRelationship } from './accounts' export async function setAccountFollowed (accountId, follow, toastOnSuccess) { let instanceName = store.get('currentInstance') @@ -12,11 +13,18 @@ export async function setAccountFollowed (accountId, follow, toastOnSuccess) { } else { await unfollowAccount(instanceName, accessToken, accountId) } + await updateProfileAndRelationship(accountId) let relationship = await database.getRelationship(instanceName, accountId) - relationship.following = follow - await database.setRelationship(instanceName, relationship) if (toastOnSuccess) { - toast.say(`${follow ? 'Followed' : 'Unfollowed'}`) + if (follow) { + if (relationship.requested) { + toast.say('Requested to follow account') + } else { + toast.say('Followed account') + } + } else { + toast.say('Unfollowed account') + } } } catch (e) { console.error(e) diff --git a/routes/_actions/followRequests.js b/routes/_actions/followRequests.js new file mode 100644 index 0000000..42427cb --- /dev/null +++ b/routes/_actions/followRequests.js @@ -0,0 +1,17 @@ +import { getWithTimeout, postWithTimeout } from '../_utils/ajax' +import { auth, basename } from '../_api/utils' + +export async function getFollowRequests (instanceName, accessToken) { + let url = `${basename(instanceName)}/api/v1/follow_requests` + return getWithTimeout(url, auth(accessToken)) +} + +export async function authorizeFollowRequest (instanceName, accessToken, id) { + let url = `${basename(instanceName)}/api/v1/follow_requests/${id}/authorize` + return postWithTimeout(url, null, auth(accessToken)) +} + +export async function rejectFollowRequest (instanceName, accessToken, id) { + let url = `${basename(instanceName)}/api/v1/follow_requests/${id}/reject` + return postWithTimeout(url, null, auth(accessToken)) +} diff --git a/routes/_actions/timeline.js b/routes/_actions/timeline.js index 05b06e6..2bdce46 100644 --- a/routes/_actions/timeline.js +++ b/routes/_actions/timeline.js @@ -40,10 +40,10 @@ async function addTimelineItems (instanceName, timelineName, items, stale) { } export async function addTimelineItemIds (instanceName, timelineName, newIds, newStale) { - let oldIds = store.getForTimeline(instanceName, timelineName, 'timelineItemIds') || [] + let oldIds = store.getForTimeline(instanceName, timelineName, 'timelineItemIds') let oldStale = store.getForTimeline(instanceName, timelineName, 'timelineItemIdsAreStale') - let mergedIds = mergeArrays(oldIds, newIds) + let mergedIds = mergeArrays(oldIds || [], newIds) if (!isEqual(oldIds, mergedIds)) { store.setForTimeline(instanceName, timelineName, {timelineItemIds: mergedIds}) diff --git a/routes/_components/AccountProfile.html b/routes/_components/AccountProfile.html index a942ff5..8568e1c 100644 --- a/routes/_components/AccountProfile.html +++ b/routes/_components/AccountProfile.html @@ -24,8 +24,8 @@