[Glitch] Add dropdown menu item to open admin interface for remote domains
Port 18d00055f4 to glitch-soc
Signed-off-by: Claire <claire.github-309c@sitedethib.com>
			
			
This commit is contained in:
		
							parent
							
								
									1219c57209
								
							
						
					
					
						commit
						c4649ae9d4
					
				| 
						 | 
					@ -9,7 +9,7 @@ import { me } from 'flavours/glitch/initial_state';
 | 
				
			||||||
import RelativeTimestamp from './relative_timestamp';
 | 
					import RelativeTimestamp from './relative_timestamp';
 | 
				
			||||||
import { accountAdminLink, statusAdminLink } from 'flavours/glitch/utils/backend_links';
 | 
					import { accountAdminLink, statusAdminLink } from 'flavours/glitch/utils/backend_links';
 | 
				
			||||||
import classNames from 'classnames';
 | 
					import classNames from 'classnames';
 | 
				
			||||||
import { PERMISSION_MANAGE_USERS } from 'flavours/glitch/permissions';
 | 
					import { PERMISSION_MANAGE_USERS, PERMISSION_MANAGE_FEDERATION } from 'flavours/glitch/permissions';
 | 
				
			||||||
 | 
					
 | 
				
			||||||
const messages = defineMessages({
 | 
					const messages = defineMessages({
 | 
				
			||||||
  delete: { id: 'status.delete', defaultMessage: 'Delete' },
 | 
					  delete: { id: 'status.delete', defaultMessage: 'Delete' },
 | 
				
			||||||
| 
						 | 
					@ -38,6 +38,7 @@ const messages = defineMessages({
 | 
				
			||||||
  embed: { id: 'status.embed', defaultMessage: 'Embed' },
 | 
					  embed: { id: 'status.embed', defaultMessage: 'Embed' },
 | 
				
			||||||
  admin_account: { id: 'status.admin_account', defaultMessage: 'Open moderation interface for @{name}' },
 | 
					  admin_account: { id: 'status.admin_account', defaultMessage: 'Open moderation interface for @{name}' },
 | 
				
			||||||
  admin_status: { id: 'status.admin_status', defaultMessage: 'Open this post in the moderation interface' },
 | 
					  admin_status: { id: 'status.admin_status', defaultMessage: 'Open this post in the moderation interface' },
 | 
				
			||||||
 | 
					  admin_domain: { id: 'status.admin_domain', defaultMessage: 'Open moderation interface for {domain}' },
 | 
				
			||||||
  copy: { id: 'status.copy', defaultMessage: 'Copy link to post' },
 | 
					  copy: { id: 'status.copy', defaultMessage: 'Copy link to post' },
 | 
				
			||||||
  hide: { id: 'status.hide', defaultMessage: 'Hide post' },
 | 
					  hide: { id: 'status.hide', defaultMessage: 'Hide post' },
 | 
				
			||||||
  edited: { id: 'status.edited', defaultMessage: 'Edited {date}' },
 | 
					  edited: { id: 'status.edited', defaultMessage: 'Edited {date}' },
 | 
				
			||||||
| 
						 | 
					@ -197,6 +198,7 @@ class StatusActionBar extends ImmutablePureComponent {
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  render () {
 | 
					  render () {
 | 
				
			||||||
    const { status, intl, withDismiss, withCounters, showReplyCount, scrollKey } = this.props;
 | 
					    const { status, intl, withDismiss, withCounters, showReplyCount, scrollKey } = this.props;
 | 
				
			||||||
 | 
					    const { permissions } = this.context.identity;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    const anonymousAccess    = !me;
 | 
					    const anonymousAccess    = !me;
 | 
				
			||||||
    const mutingConversation = status.get('muted');
 | 
					    const mutingConversation = status.get('muted');
 | 
				
			||||||
| 
						 | 
					@ -252,19 +254,19 @@ class StatusActionBar extends ImmutablePureComponent {
 | 
				
			||||||
      menu.push({ text: intl.formatMessage(messages.block, { name: status.getIn(['account', 'username']) }), action: this.handleBlockClick });
 | 
					      menu.push({ text: intl.formatMessage(messages.block, { name: status.getIn(['account', 'username']) }), action: this.handleBlockClick });
 | 
				
			||||||
      menu.push({ text: intl.formatMessage(messages.report, { name: status.getIn(['account', 'username']) }), action: this.handleReport });
 | 
					      menu.push({ text: intl.formatMessage(messages.report, { name: status.getIn(['account', 'username']) }), action: this.handleReport });
 | 
				
			||||||
 | 
					
 | 
				
			||||||
      if ((this.context.identity.permissions & PERMISSION_MANAGE_USERS) === PERMISSION_MANAGE_USERS && (accountAdminLink || statusAdminLink)) {
 | 
					      if (((permissions & PERMISSION_MANAGE_USERS) === PERMISSION_MANAGE_USERS && (accountAdminLink || statusAdminLink)) || (isRemote && (permissions & PERMISSION_MANAGE_FEDERATION) === PERMISSION_MANAGE_FEDERATION)) {
 | 
				
			||||||
        menu.push(null);
 | 
					        menu.push(null);
 | 
				
			||||||
 | 
					        if ((permissions & PERMISSION_MANAGE_USERS) === PERMISSION_MANAGE_USERS) {
 | 
				
			||||||
          if (accountAdminLink !== undefined) {
 | 
					          if (accountAdminLink !== undefined) {
 | 
				
			||||||
          menu.push({
 | 
					            menu.push({ text: intl.formatMessage(messages.admin_account, { name: status.getIn(['account', 'username']) }), href: accountAdminLink(status.getIn(['account', 'id'])) });
 | 
				
			||||||
            text: intl.formatMessage(messages.admin_account, { name: status.getIn(['account', 'username']) }),
 | 
					 | 
				
			||||||
            href: accountAdminLink(status.getIn(['account', 'id'])),
 | 
					 | 
				
			||||||
          });
 | 
					 | 
				
			||||||
          }
 | 
					          }
 | 
				
			||||||
          if (statusAdminLink !== undefined) {
 | 
					          if (statusAdminLink !== undefined) {
 | 
				
			||||||
          menu.push({
 | 
					            menu.push({ text: intl.formatMessage(messages.admin_status), href: statusAdminLink(status.getIn(['account', 'id']), status.get('id')) });
 | 
				
			||||||
            text: intl.formatMessage(messages.admin_status),
 | 
					          }
 | 
				
			||||||
            href: statusAdminLink(status.getIn(['account', 'id']), status.get('id')),
 | 
					        }
 | 
				
			||||||
          });
 | 
					        if (isRemote && (permissions & PERMISSION_MANAGE_FEDERATION) === PERMISSION_MANAGE_FEDERATION) {
 | 
				
			||||||
 | 
					          const domain = status.getIn(['account', 'acct']).split('@')[1];
 | 
				
			||||||
 | 
					          menu.push({ text: intl.formatMessage(messages.admin_domain, { domain: domain }), href: `/admin/instances/${domain}` });
 | 
				
			||||||
        }
 | 
					        }
 | 
				
			||||||
      }
 | 
					      }
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -14,7 +14,7 @@ import { NavLink } from 'react-router-dom';
 | 
				
			||||||
import DropdownMenuContainer from 'flavours/glitch/containers/dropdown_menu_container';
 | 
					import DropdownMenuContainer from 'flavours/glitch/containers/dropdown_menu_container';
 | 
				
			||||||
import AccountNoteContainer from '../containers/account_note_container';
 | 
					import AccountNoteContainer from '../containers/account_note_container';
 | 
				
			||||||
import FollowRequestNoteContainer from '../containers/follow_request_note_container';
 | 
					import FollowRequestNoteContainer from '../containers/follow_request_note_container';
 | 
				
			||||||
import { PERMISSION_MANAGE_USERS } from 'flavours/glitch/permissions';
 | 
					import { PERMISSION_MANAGE_USERS, PERMISSION_MANAGE_FEDERATION } from 'flavours/glitch/permissions';
 | 
				
			||||||
import { Helmet } from 'react-helmet';
 | 
					import { Helmet } from 'react-helmet';
 | 
				
			||||||
 | 
					
 | 
				
			||||||
const messages = defineMessages({
 | 
					const messages = defineMessages({
 | 
				
			||||||
| 
						 | 
					@ -52,6 +52,7 @@ const messages = defineMessages({
 | 
				
			||||||
  unendorse: { id: 'account.unendorse', defaultMessage: 'Don\'t feature on profile' },
 | 
					  unendorse: { id: 'account.unendorse', defaultMessage: 'Don\'t feature on profile' },
 | 
				
			||||||
  add_or_remove_from_list: { id: 'account.add_or_remove_from_list', defaultMessage: 'Add or Remove from lists' },
 | 
					  add_or_remove_from_list: { id: 'account.add_or_remove_from_list', defaultMessage: 'Add or Remove from lists' },
 | 
				
			||||||
  admin_account: { id: 'status.admin_account', defaultMessage: 'Open moderation interface for @{name}' },
 | 
					  admin_account: { id: 'status.admin_account', defaultMessage: 'Open moderation interface for @{name}' },
 | 
				
			||||||
 | 
					  admin_domain: { id: 'status.admin_domain', defaultMessage: 'Open moderation interface for {domain}' },
 | 
				
			||||||
  add_account_note: { id: 'account.add_account_note', defaultMessage: 'Add note for @{name}' },
 | 
					  add_account_note: { id: 'account.add_account_note', defaultMessage: 'Add note for @{name}' },
 | 
				
			||||||
  languages: { id: 'account.languages', defaultMessage: 'Change subscribed languages' },
 | 
					  languages: { id: 'account.languages', defaultMessage: 'Change subscribed languages' },
 | 
				
			||||||
  openOriginalPage: { id: 'account.open_original_page', defaultMessage: 'Open original page' },
 | 
					  openOriginalPage: { id: 'account.open_original_page', defaultMessage: 'Open original page' },
 | 
				
			||||||
| 
						 | 
					@ -155,7 +156,7 @@ class Header extends ImmutablePureComponent {
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  render () {
 | 
					  render () {
 | 
				
			||||||
    const { account, hidden, intl, domain } = this.props;
 | 
					    const { account, hidden, intl, domain } = this.props;
 | 
				
			||||||
    const { signedIn } = this.context.identity;
 | 
					    const { signedIn, permissions } = this.context.identity;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    if (!account) {
 | 
					    if (!account) {
 | 
				
			||||||
      return null;
 | 
					      return null;
 | 
				
			||||||
| 
						 | 
					@ -291,10 +292,15 @@ class Header extends ImmutablePureComponent {
 | 
				
			||||||
      }
 | 
					      }
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    if (account.get('id') !== me && (this.context.identity.permissions & PERMISSION_MANAGE_USERS) === PERMISSION_MANAGE_USERS && accountAdminLink) {
 | 
					    if (account.get('id') !== me && ((permissions & PERMISSION_MANAGE_USERS) === PERMISSION_MANAGE_USERS && accountAdminLink) || (isRemote && (permissions & PERMISSION_MANAGE_FEDERATION) === PERMISSION_MANAGE_FEDERATION)) {
 | 
				
			||||||
      menu.push(null);
 | 
					      menu.push(null);
 | 
				
			||||||
 | 
					      if ((permissions & PERMISSION_MANAGE_USERS) === PERMISSION_MANAGE_USERS && accountAdminLink) {
 | 
				
			||||||
        menu.push({ text: intl.formatMessage(messages.admin_account, { name: account.get('username') }), href: accountAdminLink(account.get('id')) });
 | 
					        menu.push({ text: intl.formatMessage(messages.admin_account, { name: account.get('username') }), href: accountAdminLink(account.get('id')) });
 | 
				
			||||||
      }
 | 
					      }
 | 
				
			||||||
 | 
					      if (isRemote && (permissions & PERMISSION_MANAGE_FEDERATION) === PERMISSION_MANAGE_FEDERATION) {
 | 
				
			||||||
 | 
					        menu.push({ text: intl.formatMessage(messages.admin_domain, { domain: remoteDomain }), href: `/admin/instances/${remoteDomain}` });
 | 
				
			||||||
 | 
					      }
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    const content          = { __html: account.get('note_emojified') };
 | 
					    const content          = { __html: account.get('note_emojified') };
 | 
				
			||||||
    const displayNameHtml = { __html: account.get('display_name_html') };
 | 
					    const displayNameHtml = { __html: account.get('display_name_html') };
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -7,7 +7,7 @@ import { defineMessages, injectIntl } from 'react-intl';
 | 
				
			||||||
import { me } from 'flavours/glitch/initial_state';
 | 
					import { me } from 'flavours/glitch/initial_state';
 | 
				
			||||||
import { accountAdminLink, statusAdminLink } from 'flavours/glitch/utils/backend_links';
 | 
					import { accountAdminLink, statusAdminLink } from 'flavours/glitch/utils/backend_links';
 | 
				
			||||||
import classNames from 'classnames';
 | 
					import classNames from 'classnames';
 | 
				
			||||||
import { PERMISSION_MANAGE_USERS } from 'flavours/glitch/permissions';
 | 
					import { PERMISSION_MANAGE_USERS, PERMISSION_MANAGE_FEDERATION } from 'flavours/glitch/permissions';
 | 
				
			||||||
 | 
					
 | 
				
			||||||
const messages = defineMessages({
 | 
					const messages = defineMessages({
 | 
				
			||||||
  delete: { id: 'status.delete', defaultMessage: 'Delete' },
 | 
					  delete: { id: 'status.delete', defaultMessage: 'Delete' },
 | 
				
			||||||
| 
						 | 
					@ -34,6 +34,7 @@ const messages = defineMessages({
 | 
				
			||||||
  embed: { id: 'status.embed', defaultMessage: 'Embed' },
 | 
					  embed: { id: 'status.embed', defaultMessage: 'Embed' },
 | 
				
			||||||
  admin_account: { id: 'status.admin_account', defaultMessage: 'Open moderation interface for @{name}' },
 | 
					  admin_account: { id: 'status.admin_account', defaultMessage: 'Open moderation interface for @{name}' },
 | 
				
			||||||
  admin_status: { id: 'status.admin_status', defaultMessage: 'Open this status in the moderation interface' },
 | 
					  admin_status: { id: 'status.admin_status', defaultMessage: 'Open this status in the moderation interface' },
 | 
				
			||||||
 | 
					  admin_domain: { id: 'status.admin_domain', defaultMessage: 'Open moderation interface for {domain}' },
 | 
				
			||||||
  copy: { id: 'status.copy', defaultMessage: 'Copy link to status' },
 | 
					  copy: { id: 'status.copy', defaultMessage: 'Copy link to status' },
 | 
				
			||||||
  openOriginalPage: { id: 'account.open_original_page', defaultMessage: 'Open original page' },
 | 
					  openOriginalPage: { id: 'account.open_original_page', defaultMessage: 'Open original page' },
 | 
				
			||||||
});
 | 
					});
 | 
				
			||||||
| 
						 | 
					@ -177,19 +178,19 @@ class ActionBar extends React.PureComponent {
 | 
				
			||||||
      menu.push({ text: intl.formatMessage(messages.mute, { name: status.getIn(['account', 'username']) }), action: this.handleMuteClick });
 | 
					      menu.push({ text: intl.formatMessage(messages.mute, { name: status.getIn(['account', 'username']) }), action: this.handleMuteClick });
 | 
				
			||||||
      menu.push({ text: intl.formatMessage(messages.block, { name: status.getIn(['account', 'username']) }), action: this.handleBlockClick });
 | 
					      menu.push({ text: intl.formatMessage(messages.block, { name: status.getIn(['account', 'username']) }), action: this.handleBlockClick });
 | 
				
			||||||
      menu.push({ text: intl.formatMessage(messages.report, { name: status.getIn(['account', 'username']) }), action: this.handleReport });
 | 
					      menu.push({ text: intl.formatMessage(messages.report, { name: status.getIn(['account', 'username']) }), action: this.handleReport });
 | 
				
			||||||
      if ((permissions & PERMISSION_MANAGE_USERS) === PERMISSION_MANAGE_USERS && (accountAdminLink || statusAdminLink)) {
 | 
					      if (((permissions & PERMISSION_MANAGE_USERS) === PERMISSION_MANAGE_USERS && (accountAdminLink || statusAdminLink)) || (isRemote && (permissions & PERMISSION_MANAGE_FEDERATION) === PERMISSION_MANAGE_FEDERATION)) {
 | 
				
			||||||
        menu.push(null);
 | 
					        menu.push(null);
 | 
				
			||||||
 | 
					        if ((permissions & PERMISSION_MANAGE_USERS) === PERMISSION_MANAGE_USERS) {
 | 
				
			||||||
          if (accountAdminLink !== undefined) {
 | 
					          if (accountAdminLink !== undefined) {
 | 
				
			||||||
          menu.push({
 | 
					            menu.push({ text: intl.formatMessage(messages.admin_account, { name: status.getIn(['account', 'username']) }), href: accountAdminLink(status.getIn(['account', 'id'])) });
 | 
				
			||||||
            text: intl.formatMessage(messages.admin_account, { name: status.getIn(['account', 'username']) }),
 | 
					 | 
				
			||||||
            href: accountAdminLink(status.getIn(['account', 'id'])),
 | 
					 | 
				
			||||||
          });
 | 
					 | 
				
			||||||
          }
 | 
					          }
 | 
				
			||||||
          if (statusAdminLink !== undefined) {
 | 
					          if (statusAdminLink !== undefined) {
 | 
				
			||||||
          menu.push({
 | 
					            menu.push({ text: intl.formatMessage(messages.admin_status), href: statusAdminLink(status.getIn(['account', 'id']), status.get('id')) });
 | 
				
			||||||
            text: intl.formatMessage(messages.admin_status),
 | 
					          }
 | 
				
			||||||
            href: statusAdminLink(status.getIn(['account', 'id']), status.get('id')),
 | 
					        }
 | 
				
			||||||
          });
 | 
					        if (isRemote && (permissions & PERMISSION_MANAGE_FEDERATION) === PERMISSION_MANAGE_FEDERATION) {
 | 
				
			||||||
 | 
					          const domain = status.getIn(['account', 'acct']).split('@')[1];
 | 
				
			||||||
 | 
					          menu.push({ text: intl.formatMessage(messages.admin_domain, { domain: domain }), href: `/admin/instances/${domain}` });
 | 
				
			||||||
        }
 | 
					        }
 | 
				
			||||||
      }
 | 
					      }
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -1,3 +1,4 @@
 | 
				
			||||||
export const PERMISSION_INVITE_USERS      = 0x0000000000010000;
 | 
					export const PERMISSION_INVITE_USERS      = 0x0000000000010000;
 | 
				
			||||||
export const PERMISSION_MANAGE_USERS      = 0x0000000000000400;
 | 
					export const PERMISSION_MANAGE_USERS      = 0x0000000000000400;
 | 
				
			||||||
 | 
					export const PERMISSION_MANAGE_FEDERATION = 0x0000000000000020;
 | 
				
			||||||
export const PERMISSION_MANAGE_REPORTS    = 0x0000000000000010;
 | 
					export const PERMISSION_MANAGE_REPORTS    = 0x0000000000000010;
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
		Loading…
	
		Reference in New Issue