From 84d05ca22117d958a74fd517a14c9a77c29f502a Mon Sep 17 00:00:00 2001 From: Claire Date: Fri, 23 Feb 2024 01:34:45 +0100 Subject: [PATCH] Reimplement glitchy elephant friend --- .../flavours/glitch/actions/compose.js | 7 ---- .../glitch/features/compose/index.jsx | 23 +++++++++- .../flavours/glitch/reducers/compose.js | 11 ----- .../flavours/glitch/styles/components.scss | 42 ------------------- 4 files changed, 21 insertions(+), 62 deletions(-) diff --git a/app/javascript/flavours/glitch/actions/compose.js b/app/javascript/flavours/glitch/actions/compose.js index 350ee6fbbe..06f0d79874 100644 --- a/app/javascript/flavours/glitch/actions/compose.js +++ b/app/javascript/flavours/glitch/actions/compose.js @@ -21,7 +21,6 @@ let fetchComposeSuggestionsAccountsController; let fetchComposeSuggestionsTagsController; export const COMPOSE_CHANGE = 'COMPOSE_CHANGE'; -export const COMPOSE_CYCLE_ELEFRIEND = 'COMPOSE_CYCLE_ELEFRIEND'; export const COMPOSE_SUBMIT_REQUEST = 'COMPOSE_SUBMIT_REQUEST'; export const COMPOSE_SUBMIT_SUCCESS = 'COMPOSE_SUBMIT_SUCCESS'; export const COMPOSE_SUBMIT_FAIL = 'COMPOSE_SUBMIT_FAIL'; @@ -117,12 +116,6 @@ export function changeCompose(text) { }; } -export function cycleElefriendCompose() { - return { - type: COMPOSE_CYCLE_ELEFRIEND, - }; -} - export function replyCompose(status, routerHistory) { return (dispatch, getState) => { const prependCWRe = getState().getIn(['local_settings', 'prepend_cw_re']); diff --git a/app/javascript/flavours/glitch/features/compose/index.jsx b/app/javascript/flavours/glitch/features/compose/index.jsx index fe81787fa8..35743bbd16 100644 --- a/app/javascript/flavours/glitch/features/compose/index.jsx +++ b/app/javascript/flavours/glitch/features/compose/index.jsx @@ -21,6 +21,9 @@ import PublicIcon from '@/material-icons/400-24px/public.svg?react'; import { openModal } from 'flavours/glitch/actions/modal'; import Column from 'flavours/glitch/components/column'; import { Icon } from 'flavours/glitch/components/icon'; +import glitchedElephant1 from 'flavours/glitch/images/mbstobon-ui-0.png'; +import glitchedElephant2 from 'flavours/glitch/images/mbstobon-ui-1.png'; +import glitchedElephant3 from 'flavours/glitch/images/mbstobon-ui-2.png'; import { logOut } from 'flavours/glitch/utils/log_out'; import elephantUIPlane from '../../../../images/elephant_ui_plane.svg'; @@ -51,6 +54,11 @@ const mapStateToProps = (state, ownProps) => ({ showSearch: ownProps.multiColumn ? state.getIn(['search', 'submitted']) && !state.getIn(['search', 'hidden']) : false, }); +// ~4% chance you'll end up with an unexpected friend +// glitch-soc/mastodon repo created_at date: 2017-04-20T21:55:28Z +const glitchProbability = 1 - 0.0420215528; +const totalElefriends = 3; + class Compose extends PureComponent { static propTypes = { @@ -61,6 +69,10 @@ class Compose extends PureComponent { intl: PropTypes.object.isRequired, }; + state = { + elefriend: Math.random() < glitchProbability ? Math.floor(Math.random() * totalElefriends) : totalElefriends, + }; + componentDidMount () { const { dispatch } = this.props; dispatch(mountCompose()); @@ -107,9 +119,15 @@ class Compose extends PureComponent { this.props.dispatch(changeComposing(false)); }; + cycleElefriend = () => { + this.setState((state) => ({ elefriend: (state.elefriend + 1) % totalElefriends })); + }; + render () { const { multiColumn, showSearch, intl } = this.props; + const elefriend = [glitchedElephant1, glitchedElephant2, glitchedElephant3, elephantUIPlane][this.state.elefriend]; + if (multiColumn) { const { columns } = this.props; @@ -147,8 +165,9 @@ class Compose extends PureComponent {
-
- + {/* eslint-disable-next-line jsx-a11y/no-static-element-interactions -- this is not a feature but a visual easter egg */} +
+
diff --git a/app/javascript/flavours/glitch/reducers/compose.js b/app/javascript/flavours/glitch/reducers/compose.js index 181ea38e71..05681738c5 100644 --- a/app/javascript/flavours/glitch/reducers/compose.js +++ b/app/javascript/flavours/glitch/reducers/compose.js @@ -4,7 +4,6 @@ import { COMPOSE_MOUNT, COMPOSE_UNMOUNT, COMPOSE_CHANGE, - COMPOSE_CYCLE_ELEFRIEND, COMPOSE_REPLY, COMPOSE_REPLY_CANCEL, COMPOSE_DIRECT, @@ -62,12 +61,6 @@ import { overwrite } from '../utils/js_helpers'; import { privacyPreference } from '../utils/privacy_preference'; import { uuid } from '../uuid'; -const totalElefriends = 3; - -// ~4% chance you'll end up with an unexpected friend -// glitch-soc/mastodon repo created_at date: 2017-04-20T21:55:28Z -const glitchProbability = 1 - 0.0420215528; - const initialState = ImmutableMap({ mounted: 0, advanced_options: ImmutableMap({ @@ -75,7 +68,6 @@ const initialState = ImmutableMap({ threaded_mode: false, }), sensitive: false, - elefriend: Math.random() < glitchProbability ? Math.floor(Math.random() * totalElefriends) : totalElefriends, spoiler: false, spoiler_text: '', privacy: null, @@ -425,9 +417,6 @@ export default function compose(state = initialState, action) { .set('idempotencyKey', uuid()); case COMPOSE_COMPOSING_CHANGE: return state.set('is_composing', action.value); - case COMPOSE_CYCLE_ELEFRIEND: - return state - .set('elefriend', (state.get('elefriend') + 1) % totalElefriends); case COMPOSE_REPLY: return state.withMutations(map => { map.set('id', null); diff --git a/app/javascript/flavours/glitch/styles/components.scss b/app/javascript/flavours/glitch/styles/components.scss index 3fa8d04124..8757c498e1 100644 --- a/app/javascript/flavours/glitch/styles/components.scss +++ b/app/javascript/flavours/glitch/styles/components.scss @@ -3430,14 +3430,6 @@ $ui-header-height: 55px; user-select: none; } - > .mastodon { - display: block; - width: 100%; - height: 100%; - border: 0; - cursor: inherit; - } - @media screen and (height >= 640px) { display: block; } @@ -3460,40 +3452,6 @@ $ui-header-height: 55px; } } -@for $i from 0 through 3 { - .mbstobon-#{$i} .drawer__inner__mastodon { - @if $i == 3 { - background: - url('~flavours/glitch/images/wave-drawer.png') - no-repeat - bottom / - 100% - auto, - $ui-base-color; - } @else { - background: - url('~flavours/glitch/images/wave-drawer-glitched.png') - no-repeat - bottom / - 100% - auto, - $ui-base-color; - } - - & > .mastodon { - background: url('~flavours/glitch/images/mbstobon-ui-#{$i}.png') - no-repeat - left - bottom / - contain; - - @if $i != 3 { - filter: contrast(50%) brightness(50%); - } - } - } -} - .scrollable { overflow-y: scroll; overflow-x: hidden;