Skip to content

Commit

Permalink
Merge remote-tracking branch 'origin/dev' into feature-mathtex
Browse files Browse the repository at this point in the history
  • Loading branch information
sneakers-the-rat committed Dec 25, 2022
2 parents 51e90be + c66d56f commit b7b0ad1
Show file tree
Hide file tree
Showing 7 changed files with 108 additions and 40 deletions.
3 changes: 3 additions & 0 deletions .env.production.sample
Original file line number Diff line number Diff line change
Expand Up @@ -294,6 +294,9 @@ MAX_POLL_OPTION_CHARS=100
# HCAPTCHA_SECRET_KEY=
# HCAPTCHA_SITE_KEY=

# New registrations will automatically follow these accounts (separated by commas)
AUTOFOLLOW=

# IP and session retention
# -----------------------
# Make sure to modify the scheduling of ip_cleanup_scheduler in config/sidekiq.yml
Expand Down
9 changes: 9 additions & 0 deletions app/javascript/flavours/glitch/components/status.js
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,7 @@ import StatusHeader from './status_header';
import StatusIcons from './status_icons';
import StatusContent from './status_content';
import StatusActionBar from './status_action_bar';
import StatusExpandButton from './status_expand_button';
import AttachmentList from './attachment_list';
import Card from '../features/status/components/card';
import { injectIntl, FormattedMessage } from 'react-intl';
Expand Down Expand Up @@ -799,6 +800,14 @@ class Status extends ImmutablePureComponent {
tagLinks={settings.get('tag_misleading_links')}
rewriteMentions={settings.get('rewrite_mentions')}
/>
{/* Only show expand button if collapsed and no spoiler tag is present */}
{isCollapsed && status.get('spoiler_text').length===0 ? (
<StatusExpandButton
hidden={isCollapsed}
handleSpoilerClick={parseClick}
mediaIcons={contentMediaIcons}
/>
) : null}

{!isCollapsed || !(muted || !settings.getIn(['collapsed', 'show_action_bar'])) ? (
<StatusActionBar
Expand Down
41 changes: 6 additions & 35 deletions app/javascript/flavours/glitch/components/status_content.js
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,7 @@ import classnames from 'classnames';
import Icon from 'flavours/glitch/components/icon';
import { autoPlayGif, languages as preloadedLanguages, translationEnabled } from 'flavours/glitch/initial_state';
import { decode as decodeIDNA } from 'flavours/glitch/utils/idna';
import StatusExpandButton from './status_expand_button';

const textMatchesTarget = (text, origin, host) => {
return (text === origin || text === host
Expand Down Expand Up @@ -359,38 +360,6 @@ class StatusContent extends React.PureComponent {
</Permalink>
)).reduce((aggregate, item) => [...aggregate, item, ' '], []);

let toggleText = null;
if (hidden) {
toggleText = [
<FormattedMessage
id='status.show_more'
defaultMessage='Show more'
key='0'
/>,
];
if (mediaIcons) {
mediaIcons.forEach((mediaIcon, idx) => {
toggleText.push(
<Icon
fixedWidth
className='status__content__spoiler-icon'
id={mediaIcon}
aria-hidden='true'
key={`icon-${idx}`}
/>,
);
});
}
} else {
toggleText = (
<FormattedMessage
id='status.show_less'
defaultMessage='Show less'
key='0'
/>
);
}

if (hidden) {
mentionsPlaceholder = <div>{mentionLinks}</div>;
}
Expand All @@ -402,9 +371,11 @@ class StatusContent extends React.PureComponent {
>
<span dangerouslySetInnerHTML={spoilerContent} className='translate' lang={lang} />
{' '}
<button type='button' className='status__content__spoiler-link' onClick={this.handleSpoilerClick} aria-expanded={!hidden}>
{toggleText}
</button>
<StatusExpandButton
hidden={hidden}
handleSpoilerClick={this.handleSpoilerClick}
mediaIcons={mediaIcons}
/>
</p>

{mentionsPlaceholder}
Expand Down
71 changes: 71 additions & 0 deletions app/javascript/flavours/glitch/components/status_expand_button.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,71 @@
import React from 'react';
import { useState, useEffect } from 'react';
import PropTypes from 'prop-types';
import { FormattedMessage } from 'react-intl';
import Icon from './icon';


const StatusExpandButton=(
{
hidden,
handleSpoilerClick,
mediaIcons,
},
)=>{
const makeToggleText = () => {
let newText;
if (hidden) {
newText = [
<FormattedMessage
id='status.show_more'
defaultMessage='Show more'
key='0'
/>,
];
if (mediaIcons) {
mediaIcons.forEach((mediaIcon, idx) => {
newText.push(
<Icon
fixedWidth
className='status__content__spoiler-icon'
id={mediaIcon}
aria-hidden='true'
key={`icon-${idx}`}
/>,
);
});
}
} else {
newText = (
<FormattedMessage
id='status.show_less'
defaultMessage='Show less'
key='0'
/>
);
}
return(newText);
};

// const [hidden, setHidden] = useState(false);
const [toggleText, setToggleText] = useState(makeToggleText());

// Change the text when the hidden state changes
useEffect(() => {
setToggleText(makeToggleText());
}, [hidden]);

return(
<button type='button' className='status__content__spoiler-link' onClick={handleSpoilerClick} aria-expanded={!hidden}>
{toggleText}
</button>
);
};

StatusExpandButton.propTypes = {
hidden: PropTypes.bool,
handleSpoilerClick: PropTypes.func,
mediaIcons: PropTypes.arrayOf(PropTypes.string),
};

export default StatusExpandButton;
8 changes: 4 additions & 4 deletions app/javascript/flavours/glitch/styles/components/status.scss
Original file line number Diff line number Diff line change
Expand Up @@ -391,22 +391,22 @@
}

.status__content {
height: 20px;
max-height: 6em;
overflow: hidden;
text-overflow: ellipsis;
padding-top: 0;
//padding-top: 0;

&:after {
content: "";
position: absolute;
top: 0;
height: 40%;
bottom: 0;
left: 0;
right: 0;
background: linear-gradient(rgba($ui-base-color, 0), rgba($ui-base-color, 1));
pointer-events: none;
}

a:hover {
text-decoration: none;
}
Expand Down
14 changes: 14 additions & 0 deletions app/services/bootstrap_timeline_service.rb
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,7 @@ def call(source_account)

autofollow_inviter!
notify_staff!
autofollow!
end

private
Expand All @@ -16,6 +17,19 @@ def autofollow_inviter!
FollowService.new.call(@source_account, @source_account.user.invite.user.account)
end

def autofollow!
return unless ENV['AUTOFOLLOW'].present?

ENV['AUTOFOLLOW'].to_s.split(',').each do |account|
begin
to_follow = Account.find_local!(account.strip)
FollowService.new.call(@source_account, to_follow)
rescue ActiveRecord::RecordNotFound
Rails.logger.warn("Could not find account #{account} to autofollow")
end
end
end

def notify_staff!
User.those_who_can(:manage_users).includes(:account).find_each do |user|
LocalNotificationWorker.perform_async(user.account_id, @source_account.id, 'Account', 'admin.sign_up')
Expand Down
2 changes: 1 addition & 1 deletion config/settings.yml
Original file line number Diff line number Diff line change
Expand Up @@ -43,7 +43,7 @@ defaults: &defaults
trending_status_cw: true
crop_images: true
notification_emails:
follow: true
follow: false
reblog: false
favourite: false
mention: true
Expand Down

0 comments on commit b7b0ad1

Please sign in to comment.