Add ability to disable federated timeline
This commit is contained in:
parent
5817230fcd
commit
498cef91c6
21 changed files with 175 additions and 45 deletions
|
@ -22,7 +22,13 @@ class Api::V1::Timelines::PublicController < Api::BaseController
|
|||
!Setting.timeline_preview
|
||||
end
|
||||
|
||||
def disable_federated_timeline?
|
||||
!(truthy_param?(:local) || params[:domain]) && (current_user && !current_user.setting_enable_federated_timeline)
|
||||
end
|
||||
|
||||
def load_statuses
|
||||
return [] if disable_federated_timeline?
|
||||
|
||||
cached_public_statuses_page
|
||||
end
|
||||
|
||||
|
|
|
@ -70,7 +70,9 @@ class Settings::PreferencesController < Settings::BaseController
|
|||
:setting_place_tab_bar_at_bottom,
|
||||
:setting_show_tab_bar_label,
|
||||
:setting_show_target,
|
||||
:setting_enable_federated_timeline,
|
||||
:setting_enable_limited_timeline,
|
||||
:setting_enable_local_timeline,
|
||||
:setting_enable_reaction,
|
||||
:setting_compact_reaction,
|
||||
:setting_show_reply_tree_button,
|
||||
|
|
|
@ -14,7 +14,7 @@ import { openModal } from './modal';
|
|||
import { defineMessages } from 'react-intl';
|
||||
import { addYears, addMonths, addDays, addHours, addMinutes, addSeconds, millisecondsToSeconds, set, parseISO, formatISO, format } from 'date-fns';
|
||||
import { Set as ImmutableSet } from 'immutable';
|
||||
import { postReferenceModal } from '../initial_state';
|
||||
import { postReferenceModal, enableFederatedTimeline } from '../initial_state';
|
||||
|
||||
let cancelFetchComposeSuggestionsAccounts, cancelFetchComposeSuggestionsTags;
|
||||
|
||||
|
@ -313,7 +313,9 @@ export function submitCompose(routerHistory) {
|
|||
}
|
||||
|
||||
if (response.data.in_reply_to_id === null && response.data.visibility === 'public') {
|
||||
if (enableFederatedTimeline) {
|
||||
insertIfOnline('public');
|
||||
}
|
||||
insertIfOnline(`account:${response.data.account.id}`);
|
||||
}
|
||||
}).catch(function (error) {
|
||||
|
|
|
@ -14,7 +14,7 @@ import SearchResultsContainer from './containers/search_results_container';
|
|||
import { changeComposing } from '../../actions/compose';
|
||||
import { openModal } from 'mastodon/actions/modal';
|
||||
import elephantUIPlane from '../../../images/elephant_ui_plane.svg';
|
||||
import { mascot, show_tab_bar_label, enable_limited_timeline } from '../../initial_state';
|
||||
import { mascot, show_tab_bar_label, enableLimitedTimeline, enableFederatedTimeline, enableLocalTimeline } from '../../initial_state';
|
||||
import Icon from 'mastodon/components/icon';
|
||||
import { logOut } from 'mastodon/utils/log_out';
|
||||
import NotificationsCounterIcon from '../ui/components/notifications_counter_icon';
|
||||
|
@ -35,6 +35,7 @@ const messages = defineMessages({
|
|||
limited_timeline: { id: 'tabs_bar.limited_timeline', defaultMessage: 'Limited home' },
|
||||
notifications: { id: 'tabs_bar.notifications', defaultMessage: 'Notifications' },
|
||||
public: { id: 'navigation_bar.public_timeline', defaultMessage: 'Federated timeline' },
|
||||
community: { id: 'navigation_bar.community_timeline', defaultMessage: 'Local timeline' },
|
||||
lists: { id: 'navigation_bar.lists', defaultMessage: 'Lists' },
|
||||
preferences: { id: 'navigation_bar.preferences', defaultMessage: 'Preferences' },
|
||||
logout: { id: 'navigation_bar.logout', defaultMessage: 'Logout' },
|
||||
|
@ -110,7 +111,7 @@ class Compose extends React.PureComponent {
|
|||
'HOME': { to: '/timelines/home', title: formatMessage(messages.home_timeline), label: formatMessage(messages.short_home_timeline), icon_id: 'home' },
|
||||
'LIMITED': { to: '/timelines/limited', title: formatMessage(messages.limited_timeline), label: formatMessage(messages.short_limited_timeline), icon_id: 'lock' },
|
||||
'NOTIFICATIONS': { to: '/notifications', title: formatMessage(messages.notifications), label: formatMessage(messages.short_notifications), icon_id: 'bell' },
|
||||
// 'COMMUNITY': { to: '/timelines/public/local', title: formatMessage(messages.community), label: formatMessage(messages.short_community), icon_id: 'users' },
|
||||
'COMMUNITY': { to: '/timelines/public/local', title: formatMessage(messages.community), label: formatMessage(messages.short_community), icon_id: 'users' },
|
||||
'PUBLIC': { to: '/timelines/public', title: formatMessage(messages.public), label: formatMessage(messages.short_public), icon_id: 'globe' },
|
||||
'LIST': { to: '/lists', title: formatMessage(messages.lists), label: formatMessage(messages.short_lists), icon_id: 'list-ul' },
|
||||
'PREFERENCES': { href: '/settings/preferences', title: formatMessage(messages.preferences), label: formatMessage(messages.short_preferences), icon_id: 'cog' },
|
||||
|
@ -140,8 +141,17 @@ class Compose extends React.PureComponent {
|
|||
let header = '';
|
||||
|
||||
if (multiColumn) {
|
||||
// const defaultTabIds = ['START', 'HOME', 'NOTIFICATIONS', 'COMMUNITY', 'PUBLIC', 'LIST', 'PREFERENCES', 'SIGN_OUT'];
|
||||
const defaultTabIds = enable_limited_timeline ? ['START', 'HOME', 'LIMITED', 'NOTIFICATIONS', 'PUBLIC', 'LIST', 'PREFERENCES', 'SIGN_OUT'] : ['START', 'HOME', 'NOTIFICATIONS', 'PUBLIC', 'LIST', 'PREFERENCES', 'SIGN_OUT'];
|
||||
const defaultTabIds = [
|
||||
'START',
|
||||
'HOME',
|
||||
enableLimitedTimeline ? 'LIMITED' : null,
|
||||
'NOTIFICATIONS',
|
||||
enableLocalTimeline ? 'COMMUNITY' : null,
|
||||
enableFederatedTimeline ? 'PUBLIC' : null,
|
||||
'LIST',
|
||||
'PREFERENCES',
|
||||
'SIGN_OUT',
|
||||
].filter(x => !!x);
|
||||
|
||||
let tabs = defaultTabIds;
|
||||
|
||||
|
|
|
@ -7,7 +7,7 @@ import { connect } from 'react-redux';
|
|||
import PropTypes from 'prop-types';
|
||||
import ImmutablePropTypes from 'react-immutable-proptypes';
|
||||
import ImmutablePureComponent from 'react-immutable-pure-component';
|
||||
import { me, profile_directory, showTrends, enable_limited_timeline, enableEmptyColumn, defaultColumnWidth } from '../../initial_state';
|
||||
import { me, profile_directory, showTrends, enableLimitedTimeline, enableFederatedTimeline, enableLocalTimeline, enableEmptyColumn, defaultColumnWidth } from '../../initial_state';
|
||||
import { fetchFollowRequests } from 'mastodon/actions/accounts';
|
||||
import { fetchFavouriteDomains } from 'mastodon/actions/favourite_domains';
|
||||
import { fetchFavouriteTags } from 'mastodon/actions/favourite_tags';
|
||||
|
@ -25,6 +25,7 @@ const messages = defineMessages({
|
|||
home_timeline: { id: 'tabs_bar.home', defaultMessage: 'Home' },
|
||||
notifications: { id: 'tabs_bar.notifications', defaultMessage: 'Notifications' },
|
||||
public_timeline: { id: 'navigation_bar.public_timeline', defaultMessage: 'Federated timeline' },
|
||||
community_timeline: { id: 'navigation_bar.community_timeline', defaultMessage: 'Local timeline' },
|
||||
settings_subheading: { id: 'column_subheading.settings', defaultMessage: 'Settings' },
|
||||
direct: { id: 'navigation_bar.direct', defaultMessage: 'Direct messages' },
|
||||
bookmarks: { id: 'navigation_bar.bookmarks', defaultMessage: 'Bookmarks' },
|
||||
|
@ -128,10 +129,25 @@ class GettingStarted extends ImmutablePureComponent {
|
|||
if (multiColumn) {
|
||||
navItems.push(
|
||||
<ColumnSubheading key='header-discover' text={intl.formatMessage(messages.discover)} />,
|
||||
);
|
||||
|
||||
height += 34;
|
||||
|
||||
if (enableLocalTimeline) {
|
||||
navItems.push(
|
||||
<ColumnLink key='community_timeline' icon='users' text={intl.formatMessage(messages.community_timeline)} to='timelines/public/local' />,
|
||||
);
|
||||
|
||||
height += 48;
|
||||
}
|
||||
|
||||
if (enableFederatedTimeline) {
|
||||
navItems.push(
|
||||
<ColumnLink key='public_timeline' icon='globe' text={intl.formatMessage(messages.public_timeline)} to='/timelines/public' />,
|
||||
);
|
||||
|
||||
height += 34 + 48;
|
||||
height += 48;
|
||||
}
|
||||
|
||||
navItems.push(
|
||||
<ColumnLink key='group_directory' icon='address-book' text={intl.formatMessage(messages.group_directory)} to='/group_directory' />,
|
||||
|
@ -203,7 +219,7 @@ class GettingStarted extends ImmutablePureComponent {
|
|||
height += 48;
|
||||
}
|
||||
|
||||
if (enable_limited_timeline && multiColumn && !columns.find(item => item.get('id') === 'LIMITED')) {
|
||||
if (enableLimitedTimeline && multiColumn && !columns.find(item => item.get('id') === 'LIMITED')) {
|
||||
navItems.push(
|
||||
<ColumnLink key='limited_timeline' icon='lock' text={intl.formatMessage(messages.limited_timeline)} to='/timelines/limited' />,
|
||||
);
|
||||
|
|
|
@ -3,7 +3,7 @@ import PropTypes from 'prop-types';
|
|||
import ImmutablePropTypes from 'react-immutable-proptypes';
|
||||
import { injectIntl, FormattedMessage } from 'react-intl';
|
||||
import SettingToggle from '../../notifications/components/setting_toggle';
|
||||
import { enable_limited_timeline } from 'mastodon/initial_state';
|
||||
import { enableLimitedTimeline } from 'mastodon/initial_state';
|
||||
|
||||
export default @injectIntl
|
||||
class ColumnSettings extends React.PureComponent {
|
||||
|
@ -30,7 +30,7 @@ class ColumnSettings extends React.PureComponent {
|
|||
<SettingToggle prefix='home_timeline' settings={settings} settingPath={['shows', 'reply']} onChange={onChange} label={<FormattedMessage id='home.column_settings.show_replies' defaultMessage='Show replies' />} />
|
||||
</div>
|
||||
|
||||
{enable_limited_timeline && <Fragment>
|
||||
{enableLimitedTimeline && <Fragment>
|
||||
<span className='column-settings__section'><FormattedMessage id='home.column_settings.visibility' defaultMessage='Visibility' /></span>
|
||||
|
||||
<div className='column-settings__row'>
|
||||
|
|
|
@ -8,7 +8,7 @@ import ReactSwipeableViews from 'react-swipeable-views';
|
|||
import TabsBar, { getSwipeableIndex, getSwipeableLink } from './tabs_bar';
|
||||
import { Link } from 'react-router-dom';
|
||||
|
||||
import { disableSwiping, place_tab_bar_at_bottom, enable_limited_timeline } from 'mastodon/initial_state';
|
||||
import { disableSwiping, place_tab_bar_at_bottom, enableLimitedTimeline, enableFederatedTimeline, enableLocalTimeline } from 'mastodon/initial_state';
|
||||
|
||||
import BundleContainer from '../containers/bundle_container';
|
||||
import ColumnLoading from './column_loading';
|
||||
|
@ -19,6 +19,7 @@ import {
|
|||
Notifications,
|
||||
HomeTimeline,
|
||||
GroupTimeline,
|
||||
CommunityTimeline,
|
||||
PublicTimeline,
|
||||
DomainTimeline,
|
||||
HashtagTimeline,
|
||||
|
@ -49,6 +50,7 @@ const componentMap = {
|
|||
'NOTIFICATIONS': Notifications,
|
||||
'PUBLIC': PublicTimeline,
|
||||
'REMOTE': PublicTimeline,
|
||||
'COMMUNITY': CommunityTimeline,
|
||||
'DOMAIN': DomainTimeline,
|
||||
'GROUP': GroupTimeline,
|
||||
'HASHTAG': HashtagTimeline,
|
||||
|
@ -122,13 +124,17 @@ class ColumnsArea extends ImmutablePureComponent {
|
|||
|
||||
this.setState({ shouldAnimate: true });
|
||||
|
||||
if (!enable_limited_timeline) {
|
||||
const limitedColumn = columns.find(item => item.get('id') === 'LIMITED')
|
||||
const removeColumnById = id => {
|
||||
const column = columns.find(item => item.get('id') === id)
|
||||
|
||||
if (limitedColumn) {
|
||||
dispatch(removeColumn(limitedColumn.get('uuid')));
|
||||
}
|
||||
if (column) {
|
||||
dispatch(removeColumn(column.get('uuid')));
|
||||
}
|
||||
};
|
||||
|
||||
if (!enableFederatedTimeline) { removeColumnById('PUBLIC'); }
|
||||
if (!enableLocalTimeline) { removeColumnById('COMMUNITY'); }
|
||||
if (!enableLimitedTimeline) { removeColumnById('LIMITED'); }
|
||||
}
|
||||
|
||||
componentWillUpdate(nextProps) {
|
||||
|
|
|
@ -2,7 +2,7 @@ import React from 'react';
|
|||
import { NavLink, withRouter } from 'react-router-dom';
|
||||
import { FormattedMessage } from 'react-intl';
|
||||
import Icon from 'mastodon/components/icon';
|
||||
import { profile_directory, showTrends, enable_limited_timeline } from 'mastodon/initial_state';
|
||||
import { profile_directory, showTrends, enableLimitedTimeline, enableFederatedTimeline, enableLocalTimeline } from 'mastodon/initial_state';
|
||||
import NotificationsCounterIcon from './notifications_counter_icon';
|
||||
import FollowRequestsNavLink from './follow_requests_nav_link';
|
||||
import ListPanel from './list_panel';
|
||||
|
@ -13,10 +13,11 @@ import TrendsContainer from 'mastodon/features/getting_started/containers/trends
|
|||
const NavigationPanel = () => (
|
||||
<div className='navigation-panel'>
|
||||
<NavLink className='column-link column-link--transparent' to='/timelines/home' data-preview-title-id='column.home' data-preview-icon='home' ><Icon className='column-link__icon' id='home' fixedWidth /><FormattedMessage id='tabs_bar.home' defaultMessage='Home' /></NavLink>
|
||||
{enable_limited_timeline && <NavLink className='column-link column-link--transparent' to='/timelines/limited' data-preview-title-id='column.limited' data-preview-icon='lock' ><Icon className='column-link__icon' id='lock' fixedWidth /><FormattedMessage id='navigation_bar.limited_timeline' defaultMessage='Limited home' /></NavLink>}
|
||||
{enableLimitedTimeline && <NavLink className='column-link column-link--transparent' to='/timelines/limited' data-preview-title-id='column.limited' data-preview-icon='lock' ><Icon className='column-link__icon' id='lock' fixedWidth /><FormattedMessage id='navigation_bar.limited_timeline' defaultMessage='Limited home' /></NavLink>}
|
||||
<NavLink className='column-link column-link--transparent' to='/notifications' data-preview-title-id='column.notifications' data-preview-icon='bell' ><NotificationsCounterIcon className='column-link__icon' /><FormattedMessage id='tabs_bar.notifications' defaultMessage='Notifications' /></NavLink>
|
||||
<FollowRequestsNavLink />
|
||||
<NavLink className='column-link column-link--transparent' exact to='/timelines/public' data-preview-title-id='column.public' data-preview-icon='globe' ><Icon className='column-link__icon' id='globe' fixedWidth /><FormattedMessage id='tabs_bar.federated_timeline' defaultMessage='Federated' /></NavLink>
|
||||
{enableLocalTimeline && <NavLink className='column-link column-link--transparent' exact to='/timelines/public/local' data-preview-title-id='column.community' data-preview-icon='users' ><Icon className='column-link__icon' id='users' fixedWidth /><FormattedMessage id='tabs_bar.local_timeline' defaultMessage='Local' /></NavLink>}
|
||||
{enableFederatedTimeline && <NavLink className='column-link column-link--transparent' exact to='/timelines/public' data-preview-title-id='column.public' data-preview-icon='globe' ><Icon className='column-link__icon' id='globe' fixedWidth /><FormattedMessage id='tabs_bar.federated_timeline' defaultMessage='Federated' /></NavLink>}
|
||||
<NavLink className='column-link column-link--transparent' to='/accounts/2'><Icon className='column-link__icon' id='info-circle' fixedWidth /><FormattedMessage id='navigation_bar.information_acct' defaultMessage='Fedibird info' /></NavLink>
|
||||
<NavLink className='column-link column-link--transparent' to='/timelines/tag/fedibird'><Icon className='column-link__icon' id='hashtag' fixedWidth /><FormattedMessage id='navigation_bar.hashtag_fedibird' defaultMessage='Fedibird topics' /></NavLink>
|
||||
<NavLink className='column-link column-link--transparent' to='/timelines/direct'><Icon className='column-link__icon' id='envelope' fixedWidth /><FormattedMessage id='navigation_bar.direct' defaultMessage='Direct messages' /></NavLink>
|
||||
|
|
|
@ -6,7 +6,7 @@ import { debounce, memoize } from 'lodash';
|
|||
import { isUserTouching } from '../../../is_mobile';
|
||||
import Icon from 'mastodon/components/icon';
|
||||
import NotificationsCounterIcon from './notifications_counter_icon';
|
||||
import { place_tab_bar_at_bottom, show_tab_bar_label, enable_limited_timeline } from 'mastodon/initial_state';
|
||||
import { place_tab_bar_at_bottom, show_tab_bar_label, enableLimitedTimeline, enableFederatedTimeline, enableLocalTimeline } from 'mastodon/initial_state';
|
||||
import ImmutablePropTypes from 'react-immutable-proptypes';
|
||||
import { connect } from 'react-redux';
|
||||
import { createSelector } from 'reselect';
|
||||
|
@ -15,6 +15,7 @@ import classNames from 'classnames';
|
|||
const link_home = <NavLink className='tabs-bar__link' to='/timelines/home' data-preview-title-id='column.home' data-preview-icon='home' ><Icon id='home' fixedWidth /><span className='tabs-bar__link__full-label'><FormattedMessage id='tabs_bar.home' defaultMessage='Home' children={msg=> <>{msg}</>} /></span><span className='tabs-bar__link__short-label'><FormattedMessage id='navigation_bar.short.home' defaultMessage='Home' children={msg=> <>{msg}</>} /></span></NavLink>;
|
||||
const link_limited = <NavLink className='tabs-bar__link tabs-bar__limited' to='/timelines/limited' data-preview-title-id='column.limited' data-preview-icon='lock' ><Icon id='lock' fixedWidth /><span className='tabs-bar__link__full-label'><FormattedMessage id='tabs_bar.limited_timeline' defaultMessage='Limited' children={msg=> <>{msg}</>} /></span><span className='tabs-bar__link__short-label'><FormattedMessage id='navigation_bar.short.limited_timeline' defaultMessage='Ltd.' children={msg=> <>{msg}</>} /></span></NavLink>;
|
||||
const link_notifications = <NavLink className='tabs-bar__link' to='/notifications' data-preview-title-id='column.notifications' data-preview-icon='bell' ><NotificationsCounterIcon /><span className='tabs-bar__link__full-label'><FormattedMessage id='tabs_bar.notifications' defaultMessage='Notifications' children={msg=> <>{msg}</>} /></span><span className='tabs-bar__link__short-label'><FormattedMessage id='navigation_bar.short.notifications' defaultMessage='Notif.' children={msg=> <>{msg}</>} /></span></NavLink>;
|
||||
const link_local = <NavLink className='tabs-bar__link' exact to='/timelines/public/local' data-preview-title-id='column.community' data-preview-icon='users' ><Icon id='users' fixedWidth /><span className='tabs-bar__link__full-label'><FormattedMessage id='tabs_bar.local_timeline' defaultMessage='Local' children={msg=> <>{msg}</>} /></span><span className='tabs-bar__link__short-label'><FormattedMessage id='navigation_bar.short.local_timeline' defaultMessage='LTL' children={msg=> <>{msg}</>} /></span></NavLink>;
|
||||
const link_public = <NavLink className='tabs-bar__link' exact to='/timelines/public' data-preview-title-id='column.public' data-preview-icon='globe' ><Icon id='globe' fixedWidth /><span className='tabs-bar__link__full-label'><FormattedMessage id='tabs_bar.federated_timeline' defaultMessage='Federated' children={msg=> <>{msg}</>} /></span><span className='tabs-bar__link__short-label'><FormattedMessage id='navigation_bar.short.public_timeline' defaultMessage='FTL' children={msg=> <>{msg}</>} /></span></NavLink>;
|
||||
// const link_lists = <NavLink className='tabs-bar__link' exact to='/lists' data-preview-title-id='column.lists' data-preview-icon='list-ul' ><Icon id='list-ul' fixedWidth /><span className='tabs-bar__link__full-label'><FormattedMessage id='tabs_bar.lists' defaultMessage='Lists' children={msg=> <>{msg}</>} /></span><span className='tabs-bar__link__short-label'><FormattedMessage id='navigation_bar.short.lists' defaultMessage='List' children={msg=> <>{msg}</>} /></span></NavLink>;
|
||||
const link_search = <NavLink className='tabs-bar__link optional' to='/search' data-preview-title-id='tabs_bar.search' data-preview-icon='bell' ><Icon id='search' fixedWidth /><span className='tabs-bar__link__full-label'><FormattedMessage id='tabs_bar.search' defaultMessage='Search' children={msg=> <>{msg}</>} /></span><span className='tabs-bar__link__short-label'><FormattedMessage id='navigation_bar.short.search' defaultMessage='Search' children={msg=> <>{msg}</>} /></span></NavLink>;
|
||||
|
@ -38,10 +39,11 @@ export const getLinks = memoize((favouriteLists = null) => {
|
|||
|
||||
return [
|
||||
link_home,
|
||||
enable_limited_timeline ? link_limited : null,
|
||||
enableLimitedTimeline ? link_limited : null,
|
||||
link_favourite_lists,
|
||||
link_notifications,
|
||||
link_public,
|
||||
enableLocalTimeline ? link_local : null,
|
||||
enableFederatedTimeline ? link_public : null,
|
||||
link_search,
|
||||
link_started,
|
||||
].flat().filter(v => !!v);
|
||||
|
|
|
@ -30,6 +30,7 @@ import {
|
|||
GettingStarted,
|
||||
KeyboardShortcuts,
|
||||
PublicTimeline,
|
||||
CommunityTimeline,
|
||||
DomainTimeline,
|
||||
GroupTimeline,
|
||||
AccountTimeline,
|
||||
|
@ -176,6 +177,7 @@ class SwitchingColumnsArea extends React.PureComponent {
|
|||
<WrappedRoute path='/keyboard-shortcuts' component={KeyboardShortcuts} content={children} />
|
||||
<WrappedRoute path='/timelines/home' component={HomeTimeline} content={children} />
|
||||
<WrappedRoute path='/timelines/public' exact component={PublicTimeline} content={children} />
|
||||
<WrappedRoute path='/timelines/public/local' exact component={CommunityTimeline} content={children} />
|
||||
<WrappedRoute path='/timelines/public/domain/:domain' exact component={DomainTimeline} content={children} />
|
||||
<WrappedRoute path='/timelines/groups/:id/:tagged?' exact component={GroupTimeline} content={children} />
|
||||
<WrappedRoute path='/timelines/direct' component={DirectTimeline} content={children} />
|
||||
|
|
|
@ -18,6 +18,10 @@ export function PublicTimeline () {
|
|||
return import(/* webpackChunkName: "features/public_timeline" */'../../public_timeline');
|
||||
}
|
||||
|
||||
export function CommunityTimeline () {
|
||||
return import(/* webpackChunkName: "features/community_timeline" */'../../public_timeline');
|
||||
}
|
||||
|
||||
export function DomainTimeline () {
|
||||
return import(/* webpackChunkName: "features/domain_timeline" */'../../domain_timeline');
|
||||
}
|
||||
|
|
|
@ -42,7 +42,9 @@ export const show_bookmark_button = getMeta('show_bookmark_button');
|
|||
export const show_target = getMeta('show_target');
|
||||
export const place_tab_bar_at_bottom = getMeta('place_tab_bar_at_bottom');
|
||||
export const show_tab_bar_label = getMeta('show_tab_bar_label');
|
||||
export const enable_limited_timeline = getMeta('enable_limited_timeline');
|
||||
export const enableLimitedTimeline = getMeta('enable_limited_timeline');
|
||||
export const enableFederatedTimeline = getMeta('enable_federated_timeline') ?? true;
|
||||
export const enableLocalTimeline = getMeta('enable_local_timeline') ?? true;
|
||||
export const enableReaction = getMeta('enable_reaction');
|
||||
export const compactReaction = getMeta('compact_reaction');
|
||||
export const show_reply_tree_button = getMeta('show_reply_tree_button');
|
||||
|
|
|
@ -1,6 +1,6 @@
|
|||
import { createSelector } from 'reselect';
|
||||
import { List as ImmutableList, Map as ImmutableMap, is } from 'immutable';
|
||||
import { me, enable_limited_timeline } from '../initial_state';
|
||||
import { me, enableLimitedTimeline } from '../initial_state';
|
||||
|
||||
const getAccountBase = (state, id) => state.getIn(['accounts', id], null);
|
||||
const getAccountCounters = (state, id) => state.getIn(['accounts_counters', id], null);
|
||||
|
@ -249,22 +249,20 @@ export const getAccountGallery = createSelector([
|
|||
|
||||
export const getHomeVisibilities = createSelector(
|
||||
state => state.getIn(['settings', 'home', 'shows']),
|
||||
shows => {
|
||||
return enable_limited_timeline ? (
|
||||
['public', 'unlisted']
|
||||
.concat(shows.get('private') ? ['private'] : [])
|
||||
.concat(shows.get('limited') ? ['limited'] : [])
|
||||
.concat(shows.get('direct') ? ['direct'] : [])
|
||||
) : [];
|
||||
});
|
||||
shows => !enableLimitedTimeline ? [] : [
|
||||
'public',
|
||||
'unlisted',
|
||||
shows.get('private') ? 'private' : null,
|
||||
shows.get('limited') ? 'limited' : null,
|
||||
shows.get('direct') ? 'direct' : null,
|
||||
].filter(x => !!x),
|
||||
);
|
||||
|
||||
export const getLimitedVisibilities = createSelector(
|
||||
state => state.getIn(['settings', 'limited', 'shows']),
|
||||
shows => {
|
||||
return enable_limited_timeline ? (
|
||||
[]
|
||||
.concat(shows.get('private') ? ['private'] : [])
|
||||
.concat(shows.get('limited') ? ['limited'] : [])
|
||||
.concat(shows.get('direct') ? ['direct'] : [])
|
||||
) : [];
|
||||
});
|
||||
shows => !enableLimitedTimeline ? [] : [
|
||||
shows.get('private') ? 'private' : null,
|
||||
shows.get('limited') ? 'limited' : null,
|
||||
shows.get('direct') ? 'direct' : null,
|
||||
].filter(x => !!x),
|
||||
);
|
||||
|
|
|
@ -63,7 +63,9 @@ class UserSettingsDecorator
|
|||
show_target
|
||||
place_tab_bar_at_bottom
|
||||
show_tab_bar_label
|
||||
enable_federated_timeline
|
||||
enable_limited_timeline
|
||||
enable_local_timeline
|
||||
enable_reaction
|
||||
compact_reaction
|
||||
show_reply_tree_button
|
||||
|
|
|
@ -129,7 +129,9 @@ class User < ApplicationRecord
|
|||
:show_follow_button_on_timeline, :show_subscribe_button_on_timeline, :show_target,
|
||||
:show_follow_button_on_timeline, :show_subscribe_button_on_timeline, :show_followed_by, :show_target,
|
||||
:follow_button_to_list_adder, :show_navigation_panel, :show_quote_button, :show_bookmark_button,
|
||||
:place_tab_bar_at_bottom,:show_tab_bar_label, :enable_limited_timeline, :enable_reaction, :compact_reaction,
|
||||
:place_tab_bar_at_bottom,:show_tab_bar_label,
|
||||
:enable_local_timeline, :enable_federated_timeline, :enable_limited_timeline,
|
||||
:enable_reaction, :compact_reaction,
|
||||
:show_reply_tree_button,
|
||||
:hide_statuses_count, :hide_following_count, :hide_followers_count, :disable_joke_appearance,
|
||||
:new_features_policy,
|
||||
|
|
|
@ -53,7 +53,9 @@ class InitialStateSerializer < ActiveModel::Serializer
|
|||
store[:show_target] = object.current_account.user.setting_show_target
|
||||
store[:place_tab_bar_at_bottom] = object.current_account.user.setting_place_tab_bar_at_bottom
|
||||
store[:show_tab_bar_label] = object.current_account.user.setting_show_tab_bar_label
|
||||
store[:enable_federated_timeline] = object.current_account.user.setting_enable_federated_timeline
|
||||
store[:enable_limited_timeline] = object.current_account.user.setting_enable_limited_timeline
|
||||
store[:enable_local_timeline] = false #object.current_account.user.setting_enable_local_timeline
|
||||
store[:enable_reaction] = object.current_account.user.setting_enable_reaction
|
||||
store[:compact_reaction] = object.current_account.user.setting_compact_reaction
|
||||
store[:show_reply_tree_button] = object.current_account.user.setting_show_reply_tree_button
|
||||
|
|
|
@ -86,6 +86,12 @@
|
|||
.fields-group
|
||||
= f.input :setting_show_tab_bar_label, as: :boolean, wrapper: :with_label, fedibird_features: true
|
||||
|
||||
-# .fields-group
|
||||
-# = f.input :setting_enable_local_timeline, as: :boolean, wrapper: :with_label, fedibird_features: true
|
||||
|
||||
.fields-group
|
||||
= f.input :setting_enable_federated_timeline, as: :boolean, wrapper: :with_label, fedibird_features: true
|
||||
|
||||
.fields-group
|
||||
= f.input :setting_enable_limited_timeline, as: :boolean, wrapper: :with_label, fedibird_features: true
|
||||
|
||||
|
|
|
@ -83,7 +83,9 @@ en:
|
|||
setting_display_media_hide_all: Always hide media
|
||||
setting_display_media_show_all: Always show media
|
||||
setting_enable_empty_column: The last column is initially hidden and can be closed at will
|
||||
setting_enable_federated_timeline: 'Enable a federated timeline (default: enable)'
|
||||
setting_enable_limited_timeline: Enable a limited home to display private and circle and direct message
|
||||
setting_enable_local_timeline: 'Enable a local timeline (default: enable)'
|
||||
setting_enable_reaction: Enable the reaction display on the timeline and display the reaction button
|
||||
setting_enable_status_reference: Enable the feature where a post references another post
|
||||
setting_follow_button_to_list_adder: Change the behavior of the Follow / Subscribe button, open a dialog where you can select a list to follow / subscribe, or opt out of receiving at home
|
||||
|
@ -267,7 +269,9 @@ en:
|
|||
setting_display_media_show_all: Show all
|
||||
setting_emoji_scale: Single emoji size
|
||||
setting_enable_empty_column: Enable last column to be closed
|
||||
setting_enable_federated_timeline: Enable federated timeline
|
||||
setting_enable_limited_timeline: Enable limited timeline
|
||||
setting_enable_local_timeline: Enable local timeline
|
||||
setting_enable_reaction: Enable reaction
|
||||
setting_enable_status_reference: Enable reference
|
||||
setting_expand_spoilers: Always expand posts marked with content warnings
|
||||
|
|
|
@ -79,7 +79,9 @@ ja:
|
|||
setting_display_media_hide_all: メディアを常に隠す
|
||||
setting_display_media_show_all: メディアを常に表示する
|
||||
setting_enable_empty_column: 最後のカラムを初期状態で非表示にし、任意に閉じられるようにします
|
||||
setting_enable_federated_timeline: 連合タイムラインを有効にします(デフォルト)
|
||||
setting_enable_limited_timeline: フォロワー限定・サークル・ダイレクトメッセージを表示する限定ホームを有効にします
|
||||
setting_enable_local_timeline: ローカルタイムラインを有効にします(デフォルト)
|
||||
setting_enable_reaction: タイムラインでリアクションの表示を有効にし、リアクションボタンを表示する
|
||||
setting_enable_status_reference: 投稿が別の投稿を参照する機能を有効にします
|
||||
setting_follow_button_to_list_adder: フォロー・購読ボタンの動作を変更し、フォロー・購読するリストを選択したり、ホームで受け取らないよう設定するダイアログを開きます
|
||||
|
@ -263,7 +265,9 @@ ja:
|
|||
setting_display_media_show_all: 表示
|
||||
setting_emoji_scale: 単独絵文字のサイズ
|
||||
setting_enable_empty_column: 最終カラムを閉じられるようにする
|
||||
setting_enable_federated_timeline: 連合タイムラインを有効にする
|
||||
setting_enable_limited_timeline: 限定ホームを有効にする
|
||||
setting_enable_local_timeline: ローカルタイムラインを有効にする
|
||||
setting_enable_reaction: リアクションを有効にする
|
||||
setting_enable_status_reference: 参照を有効にする
|
||||
setting_expand_spoilers: 閲覧注意としてマークされた投稿を常に展開する
|
||||
|
|
|
@ -53,7 +53,9 @@ defaults: &defaults
|
|||
show_target: false
|
||||
place_tab_bar_at_bottom: false
|
||||
show_tab_bar_label: false
|
||||
enable_federated_timeline: true
|
||||
enable_limited_timeline: false
|
||||
enable_local_timeline: true
|
||||
enable_reaction: true
|
||||
compact_reaction: false
|
||||
show_reply_tree_button: true
|
||||
|
|
|
@ -294,7 +294,7 @@ const startWorker = (workerId) => {
|
|||
return;
|
||||
}
|
||||
|
||||
client.query('SELECT oauth_access_tokens.id, oauth_access_tokens.resource_owner_id, users.account_id, users.chosen_languages, oauth_access_tokens.scopes, devices.device_id, oauth_applications.name, oauth_applications.website, (select settings.value from settings where thing_type = \'User\' and thing_id=users.id and var = \'hide_bot_on_public_timeline\') as bot FROM oauth_access_tokens INNER JOIN oauth_applications ON oauth_access_tokens.application_id = oauth_applications.id INNER JOIN users ON oauth_access_tokens.resource_owner_id = users.id LEFT OUTER JOIN devices ON oauth_access_tokens.id = devices.access_token_id WHERE oauth_access_tokens.token = $1 AND oauth_access_tokens.revoked_at IS NULL LIMIT 1', [token], (err, result) => {
|
||||
client.query('SELECT oauth_access_tokens.id, oauth_access_tokens.resource_owner_id, users.account_id, users.chosen_languages, oauth_access_tokens.scopes, devices.device_id, oauth_applications.name, oauth_applications.website, (select settings.value from settings where thing_type = \'User\' and thing_id=users.id and var = \'hide_bot_on_public_timeline\') as bot, (select exists (select settings.value from settings where thing_type = \'User\' and thing_id=users.id and var = \'enable_federated_timeline\' and value ilike \'%false%\')) as disable_federated_timeline FROM oauth_access_tokens INNER JOIN oauth_applications ON oauth_access_tokens.application_id = oauth_applications.id INNER JOIN users ON oauth_access_tokens.resource_owner_id = users.id LEFT OUTER JOIN devices ON oauth_access_tokens.id = devices.access_token_id WHERE oauth_access_tokens.token = $1 AND oauth_access_tokens.revoked_at IS NULL LIMIT 1', [token], (err, result) => {
|
||||
done();
|
||||
|
||||
if (err) {
|
||||
|
@ -315,6 +315,7 @@ const startWorker = (workerId) => {
|
|||
req.accountId = result.rows[0].account_id;
|
||||
req.chosenLanguages = result.rows[0].chosen_languages;
|
||||
req.bot = result.rows[0].bot;
|
||||
req.enableFederatedTimeline = !result.rows[0].disable_federated_timeline;
|
||||
req.allowNotifications = req.scopes.some(scope => ['read', 'read:notifications'].includes(scope));
|
||||
req.deviceId = result.rows[0].device_id;
|
||||
req.applicationName = result.rows[0].name;
|
||||
|
@ -826,6 +827,10 @@ const startWorker = (workerId) => {
|
|||
|
||||
break;
|
||||
case 'public':
|
||||
if (!isEnableFederatedTimeline(req)) {
|
||||
reject('No local stream provided');
|
||||
}
|
||||
|
||||
resolve({
|
||||
channelIds: req.applicationName === '◆ Tootdon ◆' ? ['timeline:public:remote'] : ['timeline:public'],
|
||||
options: { needsFiltering: true, notificationOnly: false },
|
||||
|
@ -833,6 +838,10 @@ const startWorker = (workerId) => {
|
|||
|
||||
break;
|
||||
case 'public:nobot':
|
||||
if (!isEnableFederatedTimeline(req)) {
|
||||
reject('No local stream provided');
|
||||
}
|
||||
|
||||
resolve({
|
||||
channelIds: req.applicationName === '◆ Tootdon ◆' ? ['timeline:public:remote:nobot'] : ['timeline:public:nobot'],
|
||||
options: { needsFiltering: true, notificationOnly: false },
|
||||
|
@ -872,6 +881,10 @@ const startWorker = (workerId) => {
|
|||
|
||||
break;
|
||||
case 'public:remote':
|
||||
if (!isEnableFederatedTimeline(req)) {
|
||||
reject('No local stream provided');
|
||||
}
|
||||
|
||||
resolve({
|
||||
channelIds: ['timeline:public:remote'],
|
||||
options: { needsFiltering: true, notificationOnly: false },
|
||||
|
@ -879,6 +892,10 @@ const startWorker = (workerId) => {
|
|||
|
||||
break;
|
||||
case 'public:remote:nobot':
|
||||
if (!isEnableFederatedTimeline(req)) {
|
||||
reject('No local stream provided');
|
||||
}
|
||||
|
||||
resolve({
|
||||
channelIds: ['timeline:public:remote:nobot'],
|
||||
options: { needsFiltering: true, notificationOnly: false },
|
||||
|
@ -919,6 +936,10 @@ const startWorker = (workerId) => {
|
|||
|
||||
break;
|
||||
case 'public:media':
|
||||
if (!isEnableFederatedTimeline(req)) {
|
||||
reject('No local stream provided');
|
||||
}
|
||||
|
||||
resolve({
|
||||
channelIds: req.applicationName === '◆ Tootdon ◆' ? ['timeline:public:remote:media'] : ['timeline:public:media'],
|
||||
options: { needsFiltering: true, notificationOnly: false },
|
||||
|
@ -926,6 +947,10 @@ const startWorker = (workerId) => {
|
|||
|
||||
break;
|
||||
case 'public:nobot:media':
|
||||
if (!isEnableFederatedTimeline(req)) {
|
||||
reject('No local stream provided');
|
||||
}
|
||||
|
||||
resolve({
|
||||
channelIds: req.applicationName === '◆ Tootdon ◆' ? ['timeline:public:remote:nobot:media'] : ['timeline:public:nobot:media'],
|
||||
options: { needsFiltering: true, notificationOnly: false },
|
||||
|
@ -965,6 +990,10 @@ const startWorker = (workerId) => {
|
|||
|
||||
break;
|
||||
case 'public:remote:media':
|
||||
if (!isEnableFederatedTimeline(req)) {
|
||||
reject('No local stream provided');
|
||||
}
|
||||
|
||||
resolve({
|
||||
channelIds: ['timeline:public:remote:media'],
|
||||
options: { needsFiltering: true, notificationOnly: false },
|
||||
|
@ -972,6 +1001,10 @@ const startWorker = (workerId) => {
|
|||
|
||||
break;
|
||||
case 'public:remote:nobot:media':
|
||||
if (!isEnableFederatedTimeline(req)) {
|
||||
reject('No local stream provided');
|
||||
}
|
||||
|
||||
resolve({
|
||||
channelIds: ['timeline:public:remote:nobot:media'],
|
||||
options: { needsFiltering: true, notificationOnly: false },
|
||||
|
@ -1001,6 +1034,10 @@ const startWorker = (workerId) => {
|
|||
|
||||
break;
|
||||
case 'public:nomedia':
|
||||
if (!isEnableFederatedTimeline(req)) {
|
||||
reject('No local stream provided');
|
||||
}
|
||||
|
||||
resolve({
|
||||
channelIds: req.applicationName === '◆ Tootdon ◆' ? ['timeline:public:remote:nomedia'] : ['timeline:public:nomedia'],
|
||||
options: { needsFiltering: true, notificationOnly: false },
|
||||
|
@ -1008,6 +1045,10 @@ const startWorker = (workerId) => {
|
|||
|
||||
break;
|
||||
case 'public:nobot:nomedia':
|
||||
if (!isEnableFederatedTimeline(req)) {
|
||||
reject('No local stream provided');
|
||||
}
|
||||
|
||||
resolve({
|
||||
channelIds: req.applicationName === '◆ Tootdon ◆' ? ['timeline:public:remote:nobot:nomedia'] : ['timeline:public:nobot:nomedia'],
|
||||
options: { needsFiltering: true, notificationOnly: false },
|
||||
|
@ -1047,6 +1088,10 @@ const startWorker = (workerId) => {
|
|||
|
||||
break;
|
||||
case 'public:remote:nomedia':
|
||||
if (!isEnableFederatedTimeline(req)) {
|
||||
reject('No local stream provided');
|
||||
}
|
||||
|
||||
resolve({
|
||||
channelIds: ['timeline:public:remote:nomedia'],
|
||||
options: { needsFiltering: true, notificationOnly: false },
|
||||
|
@ -1054,6 +1099,10 @@ const startWorker = (workerId) => {
|
|||
|
||||
break;
|
||||
case 'public:remote:nobot:nomedia':
|
||||
if (!isEnableFederatedTimeline(req)) {
|
||||
reject('No local stream provided');
|
||||
}
|
||||
|
||||
resolve({
|
||||
channelIds: ['timeline:public:remote:nobot:nomedia'],
|
||||
options: { needsFiltering: true, notificationOnly: false },
|
||||
|
@ -1346,6 +1395,14 @@ const startWorker = (workerId) => {
|
|||
process.on('uncaughtException', onError);
|
||||
};
|
||||
|
||||
/**
|
||||
* @param {any} req
|
||||
* @return {boolean}
|
||||
*/
|
||||
const isEnableFederatedTimeline = (req) => {
|
||||
return req.enableFederatedTimeline;
|
||||
};
|
||||
|
||||
/**
|
||||
* @param {any} req
|
||||
* @return {boolean}
|
||||
|
|
Loading…
Reference in a new issue