Progress on refactor
Update files paths, components
This commit is contained in:
parent
c0f0d4f07a
commit
cb55ef9f04
@ -33,7 +33,7 @@ export default getState => axios.create({
|
|||||||
transformResponse: [function (data) {
|
transformResponse: [function (data) {
|
||||||
try {
|
try {
|
||||||
return JSON.parse(data);
|
return JSON.parse(data);
|
||||||
} catch(Exception) {
|
} catch (Exception) {
|
||||||
return data;
|
return data;
|
||||||
}
|
}
|
||||||
}],
|
}],
|
||||||
|
@ -3,10 +3,10 @@ import { Link } from 'react-router-dom';
|
|||||||
import ImmutablePropTypes from 'react-immutable-proptypes';
|
import ImmutablePropTypes from 'react-immutable-proptypes';
|
||||||
import { defineMessages, injectIntl } from 'react-intl';
|
import { defineMessages, injectIntl } from 'react-intl';
|
||||||
import ImmutablePureComponent from 'react-immutable-pure-component';
|
import ImmutablePureComponent from 'react-immutable-pure-component';
|
||||||
|
import { me } from '../../initial_state';
|
||||||
import Avatar from '../avatar/avatar';
|
import Avatar from '../avatar/avatar';
|
||||||
import DisplayName from '../display_name';
|
import DisplayName from '../display_name';
|
||||||
import IconButton from '../icon_button';
|
import IconButton from '../icon_button';
|
||||||
import { me } from '../../initial_state';
|
|
||||||
|
|
||||||
import './account.scss';
|
import './account.scss';
|
||||||
|
|
||||||
@ -122,7 +122,7 @@ class Account extends ImmutablePureComponent {
|
|||||||
</div>
|
</div>
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<div className='account'>
|
<div className='account'>
|
||||||
<div className='account__wrapper'>
|
<div className='account__wrapper'>
|
||||||
|
@ -1,8 +1,8 @@
|
|||||||
import ImmutablePropTypes from 'react-immutable-proptypes';
|
import ImmutablePropTypes from 'react-immutable-proptypes';
|
||||||
import ImmutablePureComponent from 'react-immutable-pure-component';
|
import ImmutablePureComponent from 'react-immutable-pure-component';
|
||||||
|
import { makeGetAccount } from '../../selectors';
|
||||||
import Avatar from '../avatar';
|
import Avatar from '../avatar';
|
||||||
import DisplayName from '../display_name';
|
import DisplayName from '../display_name';
|
||||||
import { makeGetAccount } from '../../selectors';
|
|
||||||
|
|
||||||
import './autosuggest_account.scss';
|
import './autosuggest_account.scss';
|
||||||
|
|
||||||
|
@ -2,10 +2,10 @@ import ImmutablePropTypes from 'react-immutable-proptypes';
|
|||||||
import classNames from 'classnames';
|
import classNames from 'classnames';
|
||||||
import ImmutablePureComponent from 'react-immutable-pure-component';
|
import ImmutablePureComponent from 'react-immutable-pure-component';
|
||||||
import Textarea from 'react-textarea-autosize';
|
import Textarea from 'react-textarea-autosize';
|
||||||
import AutosuggestAccount from '../autosuggest_account';
|
|
||||||
import AutosuggestEmoji from '../autosuggest_emoji';
|
|
||||||
import { isRtl } from '../../utils/rtl';
|
import { isRtl } from '../../utils/rtl';
|
||||||
import { textAtCursorMatchesToken } from '../../utils/cursor_token_match';
|
import { textAtCursorMatchesToken } from '../../utils/cursor_token_match';
|
||||||
|
import AutosuggestAccount from '../autosuggest_account';
|
||||||
|
import AutosuggestEmoji from '../autosuggest_emoji';
|
||||||
|
|
||||||
import './autosuggest_textbox.scss';
|
import './autosuggest_textbox.scss';
|
||||||
|
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
import ColumnHeader from '../column_header';
|
|
||||||
import { isMobile } from '../../utils/is_mobile';
|
import { isMobile } from '../../utils/is_mobile';
|
||||||
|
import { ColumnHeader } from '../column_header';
|
||||||
import ColumnBackButton from '../column_back_button';
|
import ColumnBackButton from '../column_back_button';
|
||||||
|
|
||||||
import './column.scss';
|
import './column.scss';
|
||||||
@ -23,9 +23,9 @@ export default class Column extends PureComponent {
|
|||||||
|
|
||||||
const showHeading = heading && (!hideHeadingOnMobile || (hideHeadingOnMobile && !isMobile(window.innerWidth)));
|
const showHeading = heading && (!hideHeadingOnMobile || (hideHeadingOnMobile && !isMobile(window.innerWidth)));
|
||||||
const columnHeaderId = showHeading && heading.replace(/ /g, '-');
|
const columnHeaderId = showHeading && heading.replace(/ /g, '-');
|
||||||
// const header = showHeading && (
|
const header = showHeading && (
|
||||||
// <ColumnHeader icon={icon} active={active} type={heading} columnHeaderId={columnHeaderId} />
|
<ColumnHeader icon={icon} active={active} type={heading} columnHeaderId={columnHeaderId} />
|
||||||
// );
|
);
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<div role='region' aria-labelledby={columnHeaderId} className='column'>
|
<div role='region' aria-labelledby={columnHeaderId} className='column'>
|
||||||
|
@ -4,8 +4,8 @@ import classNames from 'classnames';
|
|||||||
import { injectIntl, defineMessages } from 'react-intl';
|
import { injectIntl, defineMessages } from 'react-intl';
|
||||||
import { Link } from 'react-router-dom';
|
import { Link } from 'react-router-dom';
|
||||||
import { createSelector } from 'reselect';
|
import { createSelector } from 'reselect';
|
||||||
import Icon from '../icon';
|
|
||||||
import { fetchLists } from '../../actions/lists';
|
import { fetchLists } from '../../actions/lists';
|
||||||
|
import Icon from '../icon';
|
||||||
|
|
||||||
import './column_header.scss';
|
import './column_header.scss';
|
||||||
|
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
import ImmutablePropTypes from 'react-immutable-proptypes';
|
import ImmutablePropTypes from 'react-immutable-proptypes';
|
||||||
import ImmutablePureComponent from 'react-immutable-pure-component';
|
import ImmutablePureComponent from 'react-immutable-pure-component';
|
||||||
import VerifiedIcon from '../verified_icon/verified_icon';
|
import VerifiedIcon from '../verified_icon';
|
||||||
|
|
||||||
import './display_name.scss';
|
import './display_name.scss';
|
||||||
|
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
import IconButton from '../icon_button';
|
|
||||||
import { defineMessages, injectIntl } from 'react-intl';
|
import { defineMessages, injectIntl } from 'react-intl';
|
||||||
|
import IconButton from '../icon_button';
|
||||||
|
|
||||||
import './domain.scss';
|
import './domain.scss';
|
||||||
|
|
||||||
|
@ -3,8 +3,8 @@ import ImmutablePureComponent from 'react-immutable-pure-component';
|
|||||||
import detectPassiveEvents from 'detect-passive-events';
|
import detectPassiveEvents from 'detect-passive-events';
|
||||||
import Overlay from 'react-overlays/lib/Overlay';
|
import Overlay from 'react-overlays/lib/Overlay';
|
||||||
import spring from 'react-motion/lib/spring';
|
import spring from 'react-motion/lib/spring';
|
||||||
import IconButton from '../icon_button';
|
|
||||||
import Motion from '../../features/ui/util/optional_motion';
|
import Motion from '../../features/ui/util/optional_motion';
|
||||||
|
import IconButton from '../icon_button';
|
||||||
|
|
||||||
import './dropdown_menu.scss';
|
import './dropdown_menu.scss';
|
||||||
|
|
||||||
|
@ -1,7 +1,9 @@
|
|||||||
import { NavLink, withRouter } from 'react-router-dom';
|
import { NavLink, withRouter } from 'react-router-dom';
|
||||||
import { FormattedMessage, injectIntl } from 'react-intl';
|
import { FormattedMessage, injectIntl } from 'react-intl';
|
||||||
import NotificationCounter from '../../../components/notification_counter';
|
import NotificationCounter from '../notification_counter';
|
||||||
import { me } from '../../../initial_state';
|
import { me } from '../../initial_state';
|
||||||
|
|
||||||
|
import './footer_bar.scss';
|
||||||
|
|
||||||
const links = [
|
const links = [
|
||||||
<NavLink key='pr1' className='footer-bar__link' to='/home' data-preview-title-id='column.home'>
|
<NavLink key='pr1' className='footer-bar__link' to='/home' data-preview-title-id='column.home'>
|
@ -0,0 +1,45 @@
|
|||||||
|
.footer-bar {
|
||||||
|
display: block;
|
||||||
|
position: fixed;
|
||||||
|
background: #000;
|
||||||
|
height: 58px;
|
||||||
|
bottom: 0;
|
||||||
|
left: 0;
|
||||||
|
right: 0;
|
||||||
|
z-index: 1000;
|
||||||
|
transition: transform 0.2s ease;
|
||||||
|
overflow: hidden;
|
||||||
|
padding-bottom: 0;
|
||||||
|
padding-bottom: env(safe-area-inset-bottom);
|
||||||
|
|
||||||
|
@media screen and (min-width: 895px) {
|
||||||
|
display: none !important;
|
||||||
|
}
|
||||||
|
|
||||||
|
&__container {
|
||||||
|
display: flex;
|
||||||
|
flex-direction: row;
|
||||||
|
align-items: stretch;
|
||||||
|
}
|
||||||
|
|
||||||
|
&__link {
|
||||||
|
display: flex;
|
||||||
|
flex: 1 1 auto;
|
||||||
|
margin: 0;
|
||||||
|
min-width: 36px;
|
||||||
|
height: 58px;
|
||||||
|
padding-top: 4px;
|
||||||
|
justify-content: center;
|
||||||
|
color: white;
|
||||||
|
text-decoration: none;
|
||||||
|
border-top: 2px solid transparent;
|
||||||
|
|
||||||
|
&.active {
|
||||||
|
border-top-color: $gab-brand-default;
|
||||||
|
}
|
||||||
|
|
||||||
|
& > span {
|
||||||
|
display: none;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
1
app/javascript/gabsocial/components/footer_bar/index.js
Normal file
1
app/javascript/gabsocial/components/footer_bar/index.js
Normal file
@ -0,0 +1 @@
|
|||||||
|
export { default } from './footer_bar';
|
@ -2,7 +2,7 @@ import ImmutablePropTypes from 'react-immutable-proptypes';
|
|||||||
import ImmutablePureComponent from 'react-immutable-pure-component';
|
import ImmutablePureComponent from 'react-immutable-pure-component';
|
||||||
import { defineMessages, injectIntl } from 'react-intl';
|
import { defineMessages, injectIntl } from 'react-intl';
|
||||||
import { Link } from 'react-router-dom';
|
import { Link } from 'react-router-dom';
|
||||||
import { shortNumberFormat } from '../utils/numbers';
|
import { shortNumberFormat } from '../../utils/numbers';
|
||||||
|
|
||||||
const messages = defineMessages({
|
const messages = defineMessages({
|
||||||
members: { id: 'groups.card.members', defaultMessage: 'Members' },
|
members: { id: 'groups.card.members', defaultMessage: 'Members' },
|
@ -1,6 +1,6 @@
|
|||||||
import { defineMessages, injectIntl } from 'react-intl';
|
import { defineMessages, injectIntl } from 'react-intl';
|
||||||
import { invitesEnabled, version, repository, source_url, me } from '../../initial_state';
|
|
||||||
import { openModal } from '../../actions/modal';
|
import { openModal } from '../../actions/modal';
|
||||||
|
import { invitesEnabled, version, repository, source_url, me } from '../../initial_state';
|
||||||
|
|
||||||
import './link_footer.scss';
|
import './link_footer.scss';
|
||||||
|
|
||||||
|
@ -4,14 +4,13 @@ import { is } from 'immutable';
|
|||||||
import { defineMessages, injectIntl } from 'react-intl';
|
import { defineMessages, injectIntl } from 'react-intl';
|
||||||
import classNames from 'classnames';
|
import classNames from 'classnames';
|
||||||
import { decode } from 'blurhash';
|
import { decode } from 'blurhash';
|
||||||
|
import { autoPlayGif, displayMedia } from '../../initial_state';
|
||||||
import { isIOS } from '../../utils/is_mobile';
|
import { isIOS } from '../../utils/is_mobile';
|
||||||
import { isPanoramic, isPortrait, isNonConformingRatio, minimumAspectRatio, maximumAspectRatio } from '../../utils/media_aspect_ratio';
|
import { isPanoramic, isPortrait, isNonConformingRatio, minimumAspectRatio, maximumAspectRatio } from '../../utils/media_aspect_ratio';
|
||||||
import { autoPlayGif, displayMedia } from '../../initial_state';
|
|
||||||
import IconButton from '../icon_button';
|
import IconButton from '../icon_button';
|
||||||
|
|
||||||
import './media_gallery.scss';
|
import './media_gallery.scss';
|
||||||
|
|
||||||
|
|
||||||
const messages = defineMessages({
|
const messages = defineMessages({
|
||||||
toggle_visible: { id: 'media_gallery.toggle_visible', defaultMessage: 'Toggle visibility' },
|
toggle_visible: { id: 'media_gallery.toggle_visible', defaultMessage: 'Toggle visibility' },
|
||||||
warning: { id: 'status.sensitive_warning', defaultMessage: 'Sensitive content' },
|
warning: { id: 'status.sensitive_warning', defaultMessage: 'Sensitive content' },
|
||||||
|
@ -1,9 +1,9 @@
|
|||||||
import { injectIntl, defineMessages } from 'react-intl';
|
import { injectIntl, defineMessages } from 'react-intl';
|
||||||
import ToggleSwitch from '../../toggle_switch';
|
|
||||||
import Button from '../../button';
|
|
||||||
import { closeModal } from '../../../actions/modal';
|
import { closeModal } from '../../../actions/modal';
|
||||||
import { muteAccount } from '../../../actions/accounts';
|
import { muteAccount } from '../../../actions/accounts';
|
||||||
import { toggleHideNotifications } from '../../../actions/mutes';
|
import { toggleHideNotifications } from '../../../actions/mutes';
|
||||||
|
import ToggleSwitch from '../../toggle_switch';
|
||||||
|
import Button from '../../button';
|
||||||
|
|
||||||
const messages = defineMessages({
|
const messages = defineMessages({
|
||||||
muteMessage: { id: 'confirmations.mute.message', defaultMessage: 'Are you sure you want to mute {name}?' },
|
muteMessage: { id: 'confirmations.mute.message', defaultMessage: 'Are you sure you want to mute {name}?' },
|
||||||
|
@ -1,8 +1,8 @@
|
|||||||
import { defineMessages, injectIntl, FormattedMessage } from 'react-intl';
|
import { defineMessages, injectIntl, FormattedMessage } from 'react-intl';
|
||||||
import ImmutablePureComponent from 'react-immutable-pure-component';
|
import ImmutablePureComponent from 'react-immutable-pure-component';
|
||||||
import { me } from '../../../initial_state';
|
import { me } from '../initial_state';
|
||||||
import IconButton from '../../../components/icon_button';
|
import IconButton from './icon_button';
|
||||||
import Icon from '../../../components/icon';
|
import Icon from './icon';
|
||||||
|
|
||||||
const messages = defineMessages({
|
const messages = defineMessages({
|
||||||
close: { id: 'lightbox.close', defaultMessage: 'Close' },
|
close: { id: 'lightbox.close', defaultMessage: 'Close' },
|
@ -2,11 +2,11 @@ import ImmutablePropTypes from 'react-immutable-proptypes';
|
|||||||
import { defineMessages, injectIntl } from 'react-intl';
|
import { defineMessages, injectIntl } from 'react-intl';
|
||||||
import { OrderedSet } from 'immutable';
|
import { OrderedSet } from 'immutable';
|
||||||
import ImmutablePureComponent from 'react-immutable-pure-component';
|
import ImmutablePureComponent from 'react-immutable-pure-component';
|
||||||
import ToggleSwitch from '../../toggle_switch';
|
|
||||||
import { changeReportComment, changeReportForward, submitReport } from '../../../actions/reports';
|
import { changeReportComment, changeReportForward, submitReport } from '../../../actions/reports';
|
||||||
import { expandAccountTimeline } from '../../../actions/timelines';
|
import { expandAccountTimeline } from '../../../actions/timelines';
|
||||||
import { makeGetAccount } from '../../../selectors';
|
import { makeGetAccount } from '../../../selectors';
|
||||||
import StatusCheckBox from '../../status_check_box';
|
import StatusCheckBox from '../../status_check_box';
|
||||||
|
import ToggleSwitch from '../../toggle_switch';
|
||||||
import Button from '../../button';
|
import Button from '../../button';
|
||||||
import IconButton from '../../icon_button';
|
import IconButton from '../../icon_button';
|
||||||
|
|
||||||
|
@ -2,7 +2,7 @@
|
|||||||
import { defineMessages, injectIntl, FormattedMessage } from 'react-intl';
|
import { defineMessages, injectIntl, FormattedMessage } from 'react-intl';
|
||||||
import ImmutablePropTypes from 'react-immutable-proptypes';
|
import ImmutablePropTypes from 'react-immutable-proptypes';
|
||||||
import ImmutablePureComponent from 'react-immutable-pure-component';
|
import ImmutablePureComponent from 'react-immutable-pure-component';
|
||||||
import StatusRevisionListContainer from '../containers/status_revision_list_container';
|
import StatusRevisionListContainer from '../../../containers/status_revision_list_container';
|
||||||
import IconButton from '../../../components/icon_button';
|
import IconButton from '../../../components/icon_button';
|
||||||
|
|
||||||
const messages = defineMessages({
|
const messages = defineMessages({
|
@ -12,9 +12,6 @@ import {
|
|||||||
ComposeModal,
|
ComposeModal,
|
||||||
UnauthorizedModal,
|
UnauthorizedModal,
|
||||||
} from '../modal';
|
} from '../modal';
|
||||||
|
|
||||||
import ModalLoading from '../modal_loading';
|
|
||||||
|
|
||||||
import {
|
import {
|
||||||
MuteModal,
|
MuteModal,
|
||||||
ReportModal,
|
ReportModal,
|
||||||
@ -23,6 +20,7 @@ import {
|
|||||||
ListAdder,
|
ListAdder,
|
||||||
StatusRevisionModal,
|
StatusRevisionModal,
|
||||||
} from '../../features/ui/util/async-components';
|
} from '../../features/ui/util/async-components';
|
||||||
|
import ModalLoading from '../modal_loading';
|
||||||
|
|
||||||
const MODAL_COMPONENTS = {
|
const MODAL_COMPONENTS = {
|
||||||
'MEDIA': () => Promise.resolve({ default: MediaModal }),
|
'MEDIA': () => Promise.resolve({ default: MediaModal }),
|
||||||
|
@ -7,7 +7,7 @@ import spring from 'react-motion/lib/spring';
|
|||||||
import Motion from '../../features/ui/util/optional_motion';
|
import Motion from '../../features/ui/util/optional_motion';
|
||||||
import { vote, fetchPoll } from '../../actions/polls';
|
import { vote, fetchPoll } from '../../actions/polls';
|
||||||
import emojify from '../emoji/emoji';
|
import emojify from '../emoji/emoji';
|
||||||
import RelativeTimestamp from '../relative_timestamp/relative_timestamp';
|
import RelativeTimestamp from '../relative_timestamp';
|
||||||
import Button from '../button';
|
import Button from '../button';
|
||||||
|
|
||||||
import './poll.scss';
|
import './poll.scss';
|
||||||
|
@ -0,0 +1 @@
|
|||||||
|
export { default } from './progress_panel';
|
@ -1,4 +1,4 @@
|
|||||||
import { monthlyExpensesComplete } from '../../../initial_state';
|
import { monthlyExpensesComplete } from '../../initial_state';
|
||||||
|
|
||||||
export default class ProgressPanel extends React.PureComponent {
|
export default class ProgressPanel extends React.PureComponent {
|
||||||
render() {
|
render() {
|
@ -1,9 +1,9 @@
|
|||||||
import { throttle } from 'lodash';
|
import { throttle } from 'lodash';
|
||||||
import { List as ImmutableList } from 'immutable';
|
import { List as ImmutableList } from 'immutable';
|
||||||
import ColumnIndicator from '../column_indicator';
|
|
||||||
import IntersectionObserverArticleContainer from '../../containers/intersection_observer_article_container';
|
import IntersectionObserverArticleContainer from '../../containers/intersection_observer_article_container';
|
||||||
import LoadMore from '../load_more';
|
|
||||||
import IntersectionObserverWrapper from '../../features/ui/util/intersection_observer_wrapper';
|
import IntersectionObserverWrapper from '../../features/ui/util/intersection_observer_wrapper';
|
||||||
|
import ColumnIndicator from '../column_indicator';
|
||||||
|
import LoadMore from '../load_more';
|
||||||
|
|
||||||
import './scrollable_list.scss';
|
import './scrollable_list.scss';
|
||||||
|
|
||||||
|
@ -13,7 +13,7 @@ export default class SearchPopout extends PureComponent {
|
|||||||
|
|
||||||
render() {
|
render() {
|
||||||
const { style } = this.props;
|
const { style } = this.props;
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<div className='search-popout-container' style={{ ...style, position: 'absolute', zIndex: 1000 }}>
|
<div className='search-popout-container' style={{ ...style, position: 'absolute', zIndex: 1000 }}>
|
||||||
<Motion defaultStyle={{ opacity: 0, scaleX: 1, scaleY: 1 }} style={{ opacity: spring(1, { damping: 35, stiffness: 400 }), scaleX: spring(1, { damping: 35, stiffness: 400 }), scaleY: spring(1, { damping: 35, stiffness: 400 }) }}>
|
<Motion defaultStyle={{ opacity: 0, scaleX: 1, scaleY: 1 }} style={{ opacity: spring(1, { damping: 35, stiffness: 400 }), scaleX: spring(1, { damping: 35, stiffness: 400 }), scaleY: spring(1, { damping: 35, stiffness: 400 }) }}>
|
||||||
|
@ -0,0 +1 @@
|
|||||||
|
export { default } from './sidebar_menu';
|
@ -3,15 +3,17 @@ import ImmutablePropTypes from 'react-immutable-proptypes';
|
|||||||
import ImmutablePureComponent from 'react-immutable-pure-component';
|
import ImmutablePureComponent from 'react-immutable-pure-component';
|
||||||
import { injectIntl, defineMessages } from 'react-intl';
|
import { injectIntl, defineMessages } from 'react-intl';
|
||||||
import classNames from 'classnames';
|
import classNames from 'classnames';
|
||||||
import Avatar from './avatar';
|
import Avatar from '../avatar';
|
||||||
import IconButton from './icon_button';
|
import IconButton from '../icon_button';
|
||||||
import Icon from './icon';
|
import Icon from '../icon';
|
||||||
import DisplayName from './display_name';
|
import DisplayName from '../display_name';
|
||||||
import { closeSidebar } from '../actions/sidebar';
|
import { closeSidebar } from '../../actions/sidebar';
|
||||||
import { shortNumberFormat } from '../utils/numbers';
|
import { shortNumberFormat } from '../../utils/numbers';
|
||||||
import { me } from '../initial_state';
|
import { me } from '../../initial_state';
|
||||||
import { makeGetAccount } from '../selectors';
|
import { makeGetAccount } from '../../selectors';
|
||||||
import ProgressPanel from '../features/ui/components/progress_panel';
|
import ProgressPanel from '../progress_panel';
|
||||||
|
|
||||||
|
import './sidebar_menu.scss';
|
||||||
|
|
||||||
const messages = defineMessages({
|
const messages = defineMessages({
|
||||||
followers: { id: 'account.followers', defaultMessage: 'Followers' },
|
followers: { id: 'account.followers', defaultMessage: 'Followers' },
|
@ -0,0 +1,174 @@
|
|||||||
|
.sidebar-menu {
|
||||||
|
display: flex;
|
||||||
|
position: fixed;
|
||||||
|
flex-direction: column;
|
||||||
|
width: 275px;
|
||||||
|
height: 100vh;
|
||||||
|
top: 0;
|
||||||
|
bottom: 0;
|
||||||
|
left: 0;
|
||||||
|
background: $gab-background-container;
|
||||||
|
transform: translateX(-275px);
|
||||||
|
transition: all 0.15s linear;
|
||||||
|
z-index: 10001;
|
||||||
|
|
||||||
|
body.theme-gabsocial-light & {
|
||||||
|
background: $gab-background-container-light;
|
||||||
|
}
|
||||||
|
|
||||||
|
&__root {
|
||||||
|
display: none;
|
||||||
|
}
|
||||||
|
|
||||||
|
&__wrapper {
|
||||||
|
display: block;
|
||||||
|
position: fixed;
|
||||||
|
top: 0;
|
||||||
|
left: 0;
|
||||||
|
right: 0;
|
||||||
|
bottom: 0;
|
||||||
|
z-index: 10000;
|
||||||
|
background-color: transparent;
|
||||||
|
transition: background-color 0.2s linear;
|
||||||
|
transition-delay: 0.1s;
|
||||||
|
}
|
||||||
|
|
||||||
|
&__content {
|
||||||
|
display: flex;
|
||||||
|
flex: 1 1;
|
||||||
|
flex-direction: column;
|
||||||
|
padding-bottom: 40px;
|
||||||
|
overflow: hidden;
|
||||||
|
overflow-y: scroll;
|
||||||
|
-webkit-overflow-scrolling: touch;
|
||||||
|
}
|
||||||
|
|
||||||
|
&__section {
|
||||||
|
display: block;
|
||||||
|
margin: 4px 0;
|
||||||
|
border-top: 1px solid lighten($ui-base-color, 4%);
|
||||||
|
|
||||||
|
&--borderless {
|
||||||
|
margin: 0;
|
||||||
|
border-top: none;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@media (max-width: 400px) {
|
||||||
|
width: 90vw;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
.sidebar-menu__root--visible {
|
||||||
|
display: block;
|
||||||
|
|
||||||
|
.sidebar-menu {
|
||||||
|
transform: translateX(0);
|
||||||
|
}
|
||||||
|
|
||||||
|
.sidebar-menu__wrapper {
|
||||||
|
background-color: rgba(0,0,0,0.3);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
.sidebar-menu-header {
|
||||||
|
display: flex;
|
||||||
|
height: 46px;
|
||||||
|
padding: 12px 14px;
|
||||||
|
border-bottom: 1px solid lighten($ui-base-color, 4%);
|
||||||
|
box-sizing: border-box;
|
||||||
|
align-items: center;
|
||||||
|
|
||||||
|
&__title {
|
||||||
|
display: block;
|
||||||
|
font-size: 18px;
|
||||||
|
font-weight: 600;
|
||||||
|
color: $primary-text-color;
|
||||||
|
}
|
||||||
|
|
||||||
|
&__btn {
|
||||||
|
margin-left: auto;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
.sidebar-menu-profile {
|
||||||
|
display: block;
|
||||||
|
padding: 14px 18px;
|
||||||
|
|
||||||
|
&__avatar {
|
||||||
|
display: block;
|
||||||
|
width: 56px;
|
||||||
|
height: 56px;
|
||||||
|
}
|
||||||
|
|
||||||
|
&__name {
|
||||||
|
display: block;
|
||||||
|
margin-top: 10px;
|
||||||
|
|
||||||
|
.display-name__account {
|
||||||
|
display: block;
|
||||||
|
margin-top: 2px;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
&__stats {
|
||||||
|
display: flex;
|
||||||
|
margin-top: 12px;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
.sidebar-menu-profile-stat {
|
||||||
|
display: flex;
|
||||||
|
font-size: 14px;
|
||||||
|
text-decoration: none;
|
||||||
|
|
||||||
|
&:not(:first-of-type) {
|
||||||
|
margin-left: 18px;
|
||||||
|
}
|
||||||
|
|
||||||
|
&__value {
|
||||||
|
display: flex;
|
||||||
|
margin-right: 3px;
|
||||||
|
font-weight: 700;
|
||||||
|
color: $primary-text-color;
|
||||||
|
}
|
||||||
|
|
||||||
|
&__label {
|
||||||
|
display: flex;
|
||||||
|
color: $primary-text-color;
|
||||||
|
}
|
||||||
|
|
||||||
|
&:hover {
|
||||||
|
text-decoration: underline;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
.sidebar-menu-item {
|
||||||
|
display: flex;
|
||||||
|
padding: 16px 18px;
|
||||||
|
cursor: pointer;
|
||||||
|
text-decoration: none;
|
||||||
|
color: $primary-text-color;
|
||||||
|
font-size: 15px;
|
||||||
|
font-weight: 400;
|
||||||
|
height: 50px;
|
||||||
|
box-sizing: border-box;
|
||||||
|
|
||||||
|
&:hover {
|
||||||
|
background-color: rgba($gab-brand-default, 0.1);
|
||||||
|
|
||||||
|
.fa {
|
||||||
|
color: $primary-text-color;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
.fa {
|
||||||
|
margin-right: 10px;
|
||||||
|
}
|
||||||
|
|
||||||
|
&:hover {
|
||||||
|
&__title {
|
||||||
|
color: $primary-text-color;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
@ -5,18 +5,18 @@ import { injectIntl, FormattedMessage } from 'react-intl';
|
|||||||
import ImmutablePureComponent from 'react-immutable-pure-component';
|
import ImmutablePureComponent from 'react-immutable-pure-component';
|
||||||
import { HotKeys } from 'react-hotkeys';
|
import { HotKeys } from 'react-hotkeys';
|
||||||
import classNames from 'classnames';
|
import classNames from 'classnames';
|
||||||
|
import { displayMedia } from '../../initial_state';
|
||||||
|
import Card from '../../features/status/components/card';
|
||||||
|
import { MediaGallery, Video } from '../../features/ui/util/async-components';
|
||||||
import Avatar from '../avatar';
|
import Avatar from '../avatar';
|
||||||
import StatusQuote from '../status_quote';
|
import StatusQuote from '../status_quote';
|
||||||
import AvatarOverlay from '../avatar_overlay';
|
import AvatarOverlay from '../avatar_overlay';
|
||||||
import RelativeTimestamp from '../relative_timestamp';
|
import RelativeTimestamp from '../relative_timestamp';
|
||||||
import DisplayName from '../display_name';
|
import DisplayName from '../display_name';
|
||||||
import Icon from '../icon';
|
|
||||||
import Poll from '../poll';
|
|
||||||
import StatusContent from '../status_content';
|
import StatusContent from '../status_content';
|
||||||
import StatusActionBar from '../status_action_bar';
|
import StatusActionBar from '../status_action_bar';
|
||||||
import Card from '../../features/status/components/card';
|
import Icon from '../icon';
|
||||||
import { MediaGallery, Video } from '../../features/ui/util/async-components';
|
import Poll from '../poll';
|
||||||
import { displayMedia } from '../../initial_state';
|
|
||||||
|
|
||||||
import './status.scss';
|
import './status.scss';
|
||||||
|
|
||||||
@ -483,9 +483,9 @@ class Status extends ImmutablePureComponent {
|
|||||||
|
|
||||||
{media}
|
{media}
|
||||||
|
|
||||||
{status.get('quote') && <StatusQuote
|
{ /* status.get('quote') && <StatusQuote
|
||||||
id={status.get('quote')}
|
id={status.get('quote')}
|
||||||
/>}
|
/> */ }
|
||||||
|
|
||||||
{showThread && status.get('in_reply_to_id') && status.get('in_reply_to_account_id') === status.getIn(['account', 'id']) && (
|
{showThread && status.get('in_reply_to_id') && status.get('in_reply_to_account_id') === status.getIn(['account', 'id']) && (
|
||||||
<button className='status__content__read-more-button' onClick={this.handleClick}>
|
<button className='status__content__read-more-button' onClick={this.handleClick}>
|
||||||
|
@ -3,10 +3,10 @@ import ImmutablePropTypes from 'react-immutable-proptypes';
|
|||||||
import ImmutablePureComponent from 'react-immutable-pure-component';
|
import ImmutablePureComponent from 'react-immutable-pure-component';
|
||||||
import { defineMessages, injectIntl } from 'react-intl';
|
import { defineMessages, injectIntl } from 'react-intl';
|
||||||
import { Link } from 'react-router-dom';
|
import { Link } from 'react-router-dom';
|
||||||
|
import { openModal } from '../../actions/modal';
|
||||||
|
import { me, isStaff } from '../../initial_state';
|
||||||
import DropdownMenuContainer from '../../containers/dropdown_menu_container';
|
import DropdownMenuContainer from '../../containers/dropdown_menu_container';
|
||||||
import IconButton from '../icon_button';
|
import IconButton from '../icon_button';
|
||||||
import { me, isStaff } from '../../initial_state';
|
|
||||||
import { openModal } from '../../actions/modal';
|
|
||||||
|
|
||||||
import './status_action_bar.scss';
|
import './status_action_bar.scss';
|
||||||
|
|
||||||
|
@ -2,10 +2,10 @@ import ImmutablePropTypes from 'react-immutable-proptypes';
|
|||||||
import ImmutablePureComponent from 'react-immutable-pure-component';
|
import ImmutablePureComponent from 'react-immutable-pure-component';
|
||||||
import { Set as ImmutableSet } from 'immutable';
|
import { Set as ImmutableSet } from 'immutable';
|
||||||
import noop from 'lodash/noop';
|
import noop from 'lodash/noop';
|
||||||
import StatusContent from '../status_content';
|
import { toggleStatusReport } from '../../actions/reports';
|
||||||
import { MediaGallery, Video } from '../../features/ui/util/async-components';
|
import { MediaGallery, Video } from '../../features/ui/util/async-components';
|
||||||
import Bundle from '../../features/ui/util/bundle';
|
import Bundle from '../../features/ui/util/bundle';
|
||||||
import { toggleStatusReport } from '../../actions/reports';
|
import StatusContent from '../status_content';
|
||||||
import ToggleSwitch from '../toggle_switch';
|
import ToggleSwitch from '../toggle_switch';
|
||||||
|
|
||||||
import './status_check_box.scss';
|
import './status_check_box.scss';
|
||||||
|
@ -2,11 +2,10 @@ import { Fragment } from 'react';
|
|||||||
import { debounce } from 'lodash';
|
import { debounce } from 'lodash';
|
||||||
import ImmutablePropTypes from 'react-immutable-proptypes';
|
import ImmutablePropTypes from 'react-immutable-proptypes';
|
||||||
import ImmutablePureComponent from 'react-immutable-pure-component';
|
import ImmutablePureComponent from 'react-immutable-pure-component';
|
||||||
import LoadMore from '../load_more';
|
import StatusContainer from '../../containers/status_container';
|
||||||
import ScrollableList from '../scrollable_list';
|
import ScrollableList from '../scrollable_list';
|
||||||
import TimelineQueueButtonHeader from '../timeline_queue_button_header';
|
import TimelineQueueButtonHeader from '../timeline_queue_button_header';
|
||||||
import ColumnIndicator from '../column_indicator';
|
import ColumnIndicator from '../column_indicator';
|
||||||
import StatusContainer from '../../containers/status_container';
|
|
||||||
|
|
||||||
export default class StatusList extends ImmutablePureComponent {
|
export default class StatusList extends ImmutablePureComponent {
|
||||||
|
|
||||||
|
@ -1,8 +1,10 @@
|
|||||||
import ImmutablePropTypes from 'react-immutable-proptypes';
|
import ImmutablePropTypes from 'react-immutable-proptypes';
|
||||||
import StatusContent from './status_content';
|
import StatusContent from '../status_content';
|
||||||
import DisplayName from './display_name';
|
import DisplayName from '../display_name';
|
||||||
import { NavLink } from 'react-router-dom';
|
import { NavLink } from 'react-router-dom';
|
||||||
|
|
||||||
|
import './status_quote.scss';
|
||||||
|
|
||||||
const mapStateToProps = (state, { id }) => ({
|
const mapStateToProps = (state, { id }) => ({
|
||||||
status: state.getIn(['statuses', id]),
|
status: state.getIn(['statuses', id]),
|
||||||
account: state.getIn(['accounts', state.getIn(['statuses', id, 'account'])]),
|
account: state.getIn(['accounts', state.getIn(['statuses', id, 'account'])]),
|
@ -0,0 +1,40 @@
|
|||||||
|
|
||||||
|
import { injectIntl } from 'react-intl';
|
||||||
|
import ImmutablePureComponent from 'react-immutable-pure-component';
|
||||||
|
import ModalLoading from './modal_loading';
|
||||||
|
import RelativeTimestamp from './relative_timestamp';
|
||||||
|
|
||||||
|
export default @injectIntl
|
||||||
|
class StatusRevisionsList extends ImmutablePureComponent {
|
||||||
|
|
||||||
|
static propTypes = {
|
||||||
|
loading: PropTypes.bool.isRequired,
|
||||||
|
error: PropTypes.object,
|
||||||
|
data: PropTypes.array
|
||||||
|
};
|
||||||
|
|
||||||
|
render() {
|
||||||
|
const { loading, error, data } = this.props;
|
||||||
|
|
||||||
|
if (loading || !data) return <ModalLoading />;
|
||||||
|
|
||||||
|
if (error) return (
|
||||||
|
<div className='status-revisions-list'>
|
||||||
|
<div className='status-revisions-list__error'>An error occured</div>
|
||||||
|
</div>
|
||||||
|
);
|
||||||
|
|
||||||
|
return (
|
||||||
|
<div className='status-revisions-list'>
|
||||||
|
{data.map((revision, i) => (
|
||||||
|
<div key={i} className='status-revisions-list__item'>
|
||||||
|
<div className='status-revisions-list__item__timestamp'>
|
||||||
|
<RelativeTimestamp timestamp={revision.created_at} />
|
||||||
|
</div>
|
||||||
|
<div className='status-revisions-list__item__text'>{revision.text}</div>
|
||||||
|
</div>
|
||||||
|
))}
|
||||||
|
</div>
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
@ -2,12 +2,12 @@ import ImmutablePureComponent from 'react-immutable-pure-component';
|
|||||||
import ImmutablePropTypes from 'react-immutable-proptypes';
|
import ImmutablePropTypes from 'react-immutable-proptypes';
|
||||||
import { NavLink, withRouter } from 'react-router-dom';
|
import { NavLink, withRouter } from 'react-router-dom';
|
||||||
import { FormattedMessage } from 'react-intl';
|
import { FormattedMessage } from 'react-intl';
|
||||||
import { me } from '../../initial_state';
|
|
||||||
import NotificationsCounter from '../notification_counter';
|
|
||||||
import SearchContainer from '../../features/compose/containers/search_container';
|
|
||||||
import Avatar from '../avatar';
|
|
||||||
import ActionBar from '../../features/compose/components/action_bar';
|
|
||||||
import { openModal } from '../../actions/modal';
|
import { openModal } from '../../actions/modal';
|
||||||
|
import { me } from '../../initial_state';
|
||||||
|
import SearchContainer from '../../features/compose/containers/search_container';
|
||||||
|
import ActionBar from '../../features/compose/components/action_bar';
|
||||||
|
import Avatar from '../avatar';
|
||||||
|
import NotificationsCounter from '../notification_counter';
|
||||||
import GabLogo from './assets/gab_logo/gab_logo';
|
import GabLogo from './assets/gab_logo/gab_logo';
|
||||||
import {
|
import {
|
||||||
GroupIcon,
|
GroupIcon,
|
||||||
|
@ -1,8 +1,8 @@
|
|||||||
import ImmutablePureComponent from 'react-immutable-pure-component';
|
import ImmutablePureComponent from 'react-immutable-pure-component';
|
||||||
import ImmutablePropTypes from 'react-immutable-proptypes';
|
import ImmutablePropTypes from 'react-immutable-proptypes';
|
||||||
import Avatar from '../avatar';
|
|
||||||
import ComposeFormContainer from '../../features/compose/containers/compose_form_container';
|
|
||||||
import { me } from '../../initial_state';
|
import { me } from '../../initial_state';
|
||||||
|
import ComposeFormContainer from '../../features/compose/containers/compose_form_container';
|
||||||
|
import Avatar from '../avatar';
|
||||||
|
|
||||||
import './timeline_compose_block.scss';
|
import './timeline_compose_block.scss';
|
||||||
|
|
||||||
|
@ -2,8 +2,8 @@ import { Sparklines, SparklinesCurve } from 'react-sparklines';
|
|||||||
import { FormattedMessage } from 'react-intl';
|
import { FormattedMessage } from 'react-intl';
|
||||||
import ImmutablePropTypes from 'react-immutable-proptypes';
|
import ImmutablePropTypes from 'react-immutable-proptypes';
|
||||||
import ImmutablePureComponent from 'react-immutable-pure-component';
|
import ImmutablePureComponent from 'react-immutable-pure-component';
|
||||||
import Permalink from '../permalink/permalink';
|
|
||||||
import { shortNumberFormat } from '../../utils/numbers';
|
import { shortNumberFormat } from '../../utils/numbers';
|
||||||
|
import Permalink from '../permalink';
|
||||||
|
|
||||||
import './trending_item.scss';
|
import './trending_item.scss';
|
||||||
|
|
||||||
@ -15,7 +15,7 @@ export default class TrendingItem extends ImmutablePureComponent {
|
|||||||
|
|
||||||
render() {
|
render() {
|
||||||
const { hashtag } = this.props;
|
const { hashtag } = this.props;
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<div className='trending-item'>
|
<div className='trending-item'>
|
||||||
<div className='trending-item__text'>
|
<div className='trending-item__text'>
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
import Motion from '../../features/ui/util/optional_motion';
|
|
||||||
import spring from 'react-motion/lib/spring';
|
|
||||||
import { FormattedMessage } from 'react-intl';
|
import { FormattedMessage } from 'react-intl';
|
||||||
|
import spring from 'react-motion/lib/spring';
|
||||||
|
import Motion from '../../features/ui/util/optional_motion';
|
||||||
|
|
||||||
import './upload_area.scss';
|
import './upload_area.scss';
|
||||||
|
|
||||||
|
@ -4,8 +4,8 @@ import ImmutablePropTypes from 'react-immutable-proptypes';
|
|||||||
import ImmutablePureComponent from 'react-immutable-pure-component';
|
import ImmutablePureComponent from 'react-immutable-pure-component';
|
||||||
import { autoPlayGif, me } from '../../initial_state';
|
import { autoPlayGif, me } from '../../initial_state';
|
||||||
import { makeGetAccount } from '../../selectors';
|
import { makeGetAccount } from '../../selectors';
|
||||||
import Avatar from '../avatar';
|
|
||||||
import { shortNumberFormat } from '../../utils/numbers';
|
import { shortNumberFormat } from '../../utils/numbers';
|
||||||
|
import Avatar from '../avatar';
|
||||||
|
|
||||||
import './user_panel.scss';
|
import './user_panel.scss';
|
||||||
|
|
||||||
|
@ -1,6 +1,4 @@
|
|||||||
import { defineMessages, injectIntl, FormattedMessage } from 'react-intl';
|
import { defineMessages, injectIntl, FormattedMessage } from 'react-intl';
|
||||||
import { makeGetAccount } from '../selectors';
|
|
||||||
import Account from '../components/account';
|
|
||||||
import {
|
import {
|
||||||
followAccount,
|
followAccount,
|
||||||
unfollowAccount,
|
unfollowAccount,
|
||||||
@ -12,6 +10,8 @@ import {
|
|||||||
import { openModal } from '../actions/modal';
|
import { openModal } from '../actions/modal';
|
||||||
import { initMuteModal } from '../actions/mutes';
|
import { initMuteModal } from '../actions/mutes';
|
||||||
import { unfollowModal } from '../initial_state';
|
import { unfollowModal } from '../initial_state';
|
||||||
|
import { makeGetAccount } from '../selectors';
|
||||||
|
import Account from '../components/account';
|
||||||
|
|
||||||
const messages = defineMessages({
|
const messages = defineMessages({
|
||||||
unfollowConfirm: { id: 'confirmations.unfollow.confirm', defaultMessage: 'Unfollow' },
|
unfollowConfirm: { id: 'confirmations.unfollow.confirm', defaultMessage: 'Unfollow' },
|
||||||
|
@ -1,11 +1,11 @@
|
|||||||
import { Provider } from 'react-redux';
|
import { Provider } from 'react-redux';
|
||||||
import { IntlProvider, addLocaleData } from 'react-intl';
|
import { IntlProvider, addLocaleData } from 'react-intl';
|
||||||
|
import { getLocale } from '../locales';
|
||||||
import configureStore from '../store/configureStore';
|
import configureStore from '../store/configureStore';
|
||||||
import { hydrateStore } from '../actions/store';
|
import { hydrateStore } from '../actions/store';
|
||||||
import { getLocale } from '../locales';
|
|
||||||
import Compose from '../features/standalone/compose';
|
|
||||||
import initialState from '../initial_state';
|
|
||||||
import { fetchCustomEmojis } from '../actions/custom_emojis';
|
import { fetchCustomEmojis } from '../actions/custom_emojis';
|
||||||
|
import initialState from '../initial_state';
|
||||||
|
import Compose from '../features/standalone/compose';
|
||||||
|
|
||||||
const { localeData, messages } = getLocale();
|
const { localeData, messages } = getLocale();
|
||||||
addLocaleData(localeData);
|
addLocaleData(localeData);
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
import { defineMessages, injectIntl, FormattedMessage } from 'react-intl';
|
import { defineMessages, injectIntl, FormattedMessage } from 'react-intl';
|
||||||
import { blockDomain, unblockDomain } from '../actions/domain_blocks';
|
import { blockDomain, unblockDomain } from '../actions/domain_blocks';
|
||||||
import Domain from '../components/domain';
|
|
||||||
import { openModal } from '../actions/modal';
|
import { openModal } from '../actions/modal';
|
||||||
|
import Domain from '../components/domain';
|
||||||
|
|
||||||
const messages = defineMessages({
|
const messages = defineMessages({
|
||||||
blockDomainConfirm: { id: 'confirmations.domain_block.confirm', defaultMessage: 'Hide entire domain' },
|
blockDomainConfirm: { id: 'confirmations.domain_block.confirm', defaultMessage: 'Hide entire domain' },
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
import { openDropdownMenu, closeDropdownMenu } from '../actions/dropdown_menu';
|
import { openDropdownMenu, closeDropdownMenu } from '../actions/dropdown_menu';
|
||||||
import { openModal, closeModal } from '../actions/modal';
|
import { openModal, closeModal } from '../actions/modal';
|
||||||
import DropdownMenu from '../components/dropdown_menu';
|
|
||||||
import { isUserTouching } from '../utils/is_mobile';
|
import { isUserTouching } from '../utils/is_mobile';
|
||||||
|
import DropdownMenu from '../components/dropdown_menu';
|
||||||
|
|
||||||
const mapStateToProps = state => ({
|
const mapStateToProps = state => ({
|
||||||
isModalOpen: state.get('modal').modalType === 'ACTIONS',
|
isModalOpen: state.get('modal').modalType === 'ACTIONS',
|
||||||
|
@ -5,18 +5,18 @@ import configureStore from '../store/configureStore';
|
|||||||
import { INTRODUCTION_VERSION } from '../actions/onboarding';
|
import { INTRODUCTION_VERSION } from '../actions/onboarding';
|
||||||
import { BrowserRouter, Route } from 'react-router-dom';
|
import { BrowserRouter, Route } from 'react-router-dom';
|
||||||
import { ScrollContext } from 'react-router-scroll-4';
|
import { ScrollContext } from 'react-router-scroll-4';
|
||||||
import UI from '../features/ui';
|
import { IntlProvider, addLocaleData } from 'react-intl';
|
||||||
import Introduction from '../features/introduction';
|
|
||||||
import { fetchCustomEmojis } from '../actions/custom_emojis';
|
import { fetchCustomEmojis } from '../actions/custom_emojis';
|
||||||
import { hydrateStore } from '../actions/store';
|
import { hydrateStore } from '../actions/store';
|
||||||
import {
|
import {
|
||||||
connectUserStream,
|
connectUserStream,
|
||||||
connectStatusUpdateStream,
|
connectStatusUpdateStream,
|
||||||
} from '../actions/streaming';
|
} from '../actions/streaming';
|
||||||
import { IntlProvider, addLocaleData } from 'react-intl';
|
|
||||||
import { getLocale } from '../locales';
|
import { getLocale } from '../locales';
|
||||||
import initialState from '../initial_state';
|
import initialState from '../initial_state';
|
||||||
import { me } from '../initial_state';
|
import { me } from '../initial_state';
|
||||||
|
import UI from '../features/ui';
|
||||||
|
// import Introduction from '../features/introduction';
|
||||||
import ErrorBoundary from '../components/error_boundary';
|
import ErrorBoundary from '../components/error_boundary';
|
||||||
|
|
||||||
const { localeData, messages } = getLocale();
|
const { localeData, messages } = getLocale();
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
import IntersectionObserverArticle from '../components/intersection_observer_article';
|
|
||||||
import { setHeight } from '../actions/height_cache';
|
import { setHeight } from '../actions/height_cache';
|
||||||
|
import IntersectionObserverArticle from '../components/intersection_observer_article';
|
||||||
|
|
||||||
const makeMapStateToProps = (state, props) => ({
|
const makeMapStateToProps = (state, props) => ({
|
||||||
cachedHeight: state.getIn(['height_cache', props.saveHeightKey, props.id]),
|
cachedHeight: state.getIn(['height_cache', props.saveHeightKey, props.id]),
|
||||||
|
@ -1,5 +1,4 @@
|
|||||||
import Status from '../components/status';
|
import { defineMessages, injectIntl, FormattedMessage } from 'react-intl';
|
||||||
import { makeGetStatus } from '../selectors';
|
|
||||||
import {
|
import {
|
||||||
replyCompose,
|
replyCompose,
|
||||||
mentionCompose,
|
mentionCompose,
|
||||||
@ -26,13 +25,14 @@ import {
|
|||||||
import { initMuteModal } from '../actions/mutes';
|
import { initMuteModal } from '../actions/mutes';
|
||||||
import { initReport } from '../actions/reports';
|
import { initReport } from '../actions/reports';
|
||||||
import { openModal } from '../actions/modal';
|
import { openModal } from '../actions/modal';
|
||||||
import { defineMessages, injectIntl, FormattedMessage } from 'react-intl';
|
|
||||||
import { boostModal, deleteModal } from '../initial_state';
|
import { boostModal, deleteModal } from '../initial_state';
|
||||||
import { showAlertForError } from '../actions/alerts';
|
import { showAlertForError } from '../actions/alerts';
|
||||||
import {
|
import {
|
||||||
createRemovedAccount,
|
createRemovedAccount,
|
||||||
groupRemoveStatus
|
groupRemoveStatus
|
||||||
} from '../actions/groups';
|
} from '../actions/groups';
|
||||||
|
import { makeGetStatus } from '../selectors';
|
||||||
|
import Status from '../components/status';
|
||||||
|
|
||||||
const messages = defineMessages({
|
const messages = defineMessages({
|
||||||
deleteConfirm: { id: 'confirmations.delete.confirm', defaultMessage: 'Delete' },
|
deleteConfirm: { id: 'confirmations.delete.confirm', defaultMessage: 'Delete' },
|
||||||
|
@ -1,10 +1,10 @@
|
|||||||
import { Map as ImmutableMap, List as ImmutableList } from 'immutable';
|
import { Map as ImmutableMap, List as ImmutableList } from 'immutable';
|
||||||
import { createSelector } from 'reselect';
|
import { createSelector } from 'reselect';
|
||||||
import { debounce, sample } from 'lodash';
|
import { debounce, sample } from 'lodash';
|
||||||
import { me, promotions } from '../initial_state';
|
|
||||||
import { dequeueTimeline } from '../actions/timelines';
|
import { dequeueTimeline } from '../actions/timelines';
|
||||||
import { scrollTopTimeline } from '../actions/timelines';
|
import { scrollTopTimeline } from '../actions/timelines';
|
||||||
import { fetchStatus } from '../actions/statuses';
|
import { fetchStatus } from '../actions/statuses';
|
||||||
|
import { me, promotions } from '../initial_state';
|
||||||
import StatusList from '../components/status_list';
|
import StatusList from '../components/status_list';
|
||||||
|
|
||||||
const makeGetStatusIds = () => createSelector([
|
const makeGetStatusIds = () => createSelector([
|
||||||
|
@ -2,13 +2,13 @@ import { Fragment } from 'react';
|
|||||||
import ReactDOM from 'react-dom';
|
import ReactDOM from 'react-dom';
|
||||||
import { Provider } from 'react-redux';
|
import { Provider } from 'react-redux';
|
||||||
import { IntlProvider, addLocaleData } from 'react-intl';
|
import { IntlProvider, addLocaleData } from 'react-intl';
|
||||||
|
import { getLocale } from '../locales';
|
||||||
import configureStore from '../store/configureStore';
|
import configureStore from '../store/configureStore';
|
||||||
import { hydrateStore } from '../actions/store';
|
import { hydrateStore } from '../actions/store';
|
||||||
import { getLocale } from '../locales';
|
import initialState from '../initial_state';
|
||||||
import PublicTimeline from '../features/standalone/public_timeline';
|
import PublicTimeline from '../features/standalone/public_timeline';
|
||||||
import HashtagTimeline from '../features/standalone/hashtag_timeline';
|
import HashtagTimeline from '../features/standalone/hashtag_timeline';
|
||||||
import ModalContainer from './modal_container';
|
import ModalContainer from './modal_container';
|
||||||
import initialState from '../initial_state';
|
|
||||||
|
|
||||||
const { localeData, messages } = getLocale();
|
const { localeData, messages } = getLocale();
|
||||||
addLocaleData(localeData);
|
addLocaleData(localeData);
|
||||||
|
@ -5,14 +5,14 @@ import {
|
|||||||
fetchAccount,
|
fetchAccount,
|
||||||
fetchAccountByUsername,
|
fetchAccountByUsername,
|
||||||
} from '../../actions/accounts';
|
} from '../../actions/accounts';
|
||||||
|
import { openModal } from '../../actions/modal';
|
||||||
import { expandAccountMediaTimeline } from '../../actions/timelines';
|
import { expandAccountMediaTimeline } from '../../actions/timelines';
|
||||||
|
import { me } from '../../initial_state';
|
||||||
|
import { getAccountGallery } from '../../selectors';
|
||||||
import ColumnIndicator from '../../components/column_indicator';
|
import ColumnIndicator from '../../components/column_indicator';
|
||||||
import Column from '../../components/column';
|
import Column from '../../components/column';
|
||||||
import { getAccountGallery } from '../../selectors';
|
|
||||||
import MediaItem from './components/media_item';
|
import MediaItem from './components/media_item';
|
||||||
import LoadMore from '../../components/load_more';
|
import LoadMore from '../../components/load_more';
|
||||||
import { openModal } from '../../actions/modal';
|
|
||||||
import { me } from '../../initial_state';
|
|
||||||
import SectionHeadlineBar from '../../components/section_headline_bar';
|
import SectionHeadlineBar from '../../components/section_headline_bar';
|
||||||
|
|
||||||
import './account_gallery.scss';
|
import './account_gallery.scss';
|
||||||
|
@ -4,11 +4,11 @@ import { List as ImmutableList } from 'immutable';
|
|||||||
import { injectIntl, defineMessages, FormattedMessage } from 'react-intl';
|
import { injectIntl, defineMessages, FormattedMessage } from 'react-intl';
|
||||||
import { fetchAccount, fetchAccountByUsername } from '../../actions/accounts';
|
import { fetchAccount, fetchAccountByUsername } from '../../actions/accounts';
|
||||||
import { expandAccountFeaturedTimeline, expandAccountTimeline } from '../../actions/timelines';
|
import { expandAccountFeaturedTimeline, expandAccountTimeline } from '../../actions/timelines';
|
||||||
|
import { fetchAccountIdentityProofs } from '../../actions/identity_proofs';
|
||||||
|
import { me } from '../../initial_state';
|
||||||
import StatusList from '../../components/status_list/status_list';
|
import StatusList from '../../components/status_list/status_list';
|
||||||
import ColumnIndicator from '../../components/column_indicator/column_indicator';
|
import ColumnIndicator from '../../components/column_indicator/column_indicator';
|
||||||
import Column from '../../components/column';
|
import Column from '../../components/column';
|
||||||
import { fetchAccountIdentityProofs } from '../../actions/identity_proofs';
|
|
||||||
import { me } from '../../initial_state';
|
|
||||||
import SectionHeadlineBar from '../../components/section_headline_bar' ;
|
import SectionHeadlineBar from '../../components/section_headline_bar' ;
|
||||||
|
|
||||||
const messages = defineMessages({
|
const messages = defineMessages({
|
||||||
|
@ -39,7 +39,6 @@ export default class SearchResults extends ImmutablePureComponent {
|
|||||||
let accounts, statuses, hashtags, groups;
|
let accounts, statuses, hashtags, groups;
|
||||||
let count = 0;
|
let count = 0;
|
||||||
|
|
||||||
|
|
||||||
if (results.get('accounts') && results.get('accounts').size > 0 && (isTop || showPeople)) {
|
if (results.get('accounts') && results.get('accounts').size > 0 && (isTop || showPeople)) {
|
||||||
const size = isTop ? Math.min(results.get('accounts').size, 5) : results.get('accounts').size;
|
const size = isTop ? Math.min(results.get('accounts').size, 5) : results.get('accounts').size;
|
||||||
count += size;
|
count += size;
|
||||||
@ -51,7 +50,6 @@ export default class SearchResults extends ImmutablePureComponent {
|
|||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
if (results.get('groups') && results.get('groups').size > 0 && (isTop || showGroups)) {
|
if (results.get('groups') && results.get('groups').size > 0 && (isTop || showGroups)) {
|
||||||
const size = isTop ? Math.min(results.get('groups').size, 5) : results.get('groups').size;
|
const size = isTop ? Math.min(results.get('groups').size, 5) : results.get('groups').size;
|
||||||
count += size;
|
count += size;
|
||||||
|
@ -2,15 +2,18 @@ import ImmutablePropTypes from 'react-immutable-proptypes';
|
|||||||
import ImmutablePureComponent from 'react-immutable-pure-component';
|
import ImmutablePureComponent from 'react-immutable-pure-component';
|
||||||
import { injectIntl, defineMessages } from 'react-intl';
|
import { injectIntl, defineMessages } from 'react-intl';
|
||||||
import spring from 'react-motion/lib/spring';
|
import spring from 'react-motion/lib/spring';
|
||||||
|
import {
|
||||||
|
changeComposing,
|
||||||
|
mountCompose,
|
||||||
|
unmountCompose,
|
||||||
|
} from '../../actions/compose';
|
||||||
|
import { mascot } from '../../initial_state';
|
||||||
import Motion from '../ui/util/optional_motion';
|
import Motion from '../ui/util/optional_motion';
|
||||||
import ComposeFormContainer from './containers/compose_form_container';
|
import ComposeFormContainer from './containers/compose_form_container';
|
||||||
import NavigationBar from './components/navigation_bar';
|
|
||||||
import { mountCompose, unmountCompose } from '../../actions/compose';
|
|
||||||
import SearchContainer from './containers/search_container';
|
import SearchContainer from './containers/search_container';
|
||||||
import SearchResultsContainer from './containers/search_results_container';
|
import SearchResultsContainer from './containers/search_results_container';
|
||||||
import { changeComposing } from '../../actions/compose';
|
import NavigationBar from './components/navigation_bar';
|
||||||
import elephantUIPlane from '../../../images/logo_ui_column_footer.png';
|
import elephantUIPlane from '../../../images/logo_ui_column_footer.png';
|
||||||
import { mascot } from '../../initial_state';
|
|
||||||
|
|
||||||
import './compose.scss';
|
import './compose.scss';
|
||||||
|
|
||||||
|
@ -2,10 +2,10 @@ import { defineMessages, injectIntl, FormattedMessage } from 'react-intl';
|
|||||||
import ImmutablePureComponent from 'react-immutable-pure-component';
|
import ImmutablePureComponent from 'react-immutable-pure-component';
|
||||||
import ImmutablePropTypes from 'react-immutable-proptypes';
|
import ImmutablePropTypes from 'react-immutable-proptypes';
|
||||||
import { debounce } from 'lodash';
|
import { debounce } from 'lodash';
|
||||||
|
import { fetchDomainBlocks, expandDomainBlocks } from '../../actions/domain_blocks';
|
||||||
|
import DomainContainer from '../../containers/domain_container';
|
||||||
import ColumnIndicator from '../../components/column_indicator';
|
import ColumnIndicator from '../../components/column_indicator';
|
||||||
import Column from '../../components/column';
|
import Column from '../../components/column';
|
||||||
import DomainContainer from '../../containers/domain_container';
|
|
||||||
import { fetchDomainBlocks, expandDomainBlocks } from '../../actions/domain_blocks';
|
|
||||||
import ScrollableList from '../../components/scrollable_list';
|
import ScrollableList from '../../components/scrollable_list';
|
||||||
|
|
||||||
const messages = defineMessages({
|
const messages = defineMessages({
|
||||||
|
@ -3,9 +3,9 @@ import { FormattedMessage } from 'react-intl';
|
|||||||
import ImmutablePureComponent from 'react-immutable-pure-component';
|
import ImmutablePureComponent from 'react-immutable-pure-component';
|
||||||
import { debounce } from 'lodash';
|
import { debounce } from 'lodash';
|
||||||
import { fetchFavouritedStatuses, expandFavouritedStatuses } from '../../actions/favourites';
|
import { fetchFavouritedStatuses, expandFavouritedStatuses } from '../../actions/favourites';
|
||||||
|
import { meUsername } from '../../initial_state';
|
||||||
import Column from '../../components/column';
|
import Column from '../../components/column';
|
||||||
import StatusList from '../../components/status_list';
|
import StatusList from '../../components/status_list';
|
||||||
import { meUsername } from '../../initial_state';
|
|
||||||
import ColumnIndicator from '../../components/column_indicator';
|
import ColumnIndicator from '../../components/column_indicator';
|
||||||
|
|
||||||
const mapStateToProps = (state, { params: { username } }) => {
|
const mapStateToProps = (state, { params: { username } }) => {
|
||||||
|
@ -1,12 +1,12 @@
|
|||||||
import { defineMessages, injectIntl } from 'react-intl';
|
import { defineMessages, injectIntl } from 'react-intl';
|
||||||
import ImmutablePureComponent from 'react-immutable-pure-component';
|
import ImmutablePureComponent from 'react-immutable-pure-component';
|
||||||
import ImmutablePropTypes from 'react-immutable-proptypes';
|
import ImmutablePropTypes from 'react-immutable-proptypes';
|
||||||
|
import { authorizeFollowRequest, rejectFollowRequest } from '../../../../actions/accounts';
|
||||||
|
import { makeGetAccount } from '../../../../selectors';
|
||||||
import Permalink from '../../../../components/permalink';
|
import Permalink from '../../../../components/permalink';
|
||||||
import Avatar from '../../../../components/avatar';
|
import Avatar from '../../../../components/avatar';
|
||||||
import DisplayName from '../../../../components/display_name';
|
import DisplayName from '../../../../components/display_name';
|
||||||
import IconButton from '../../../../components/icon_button';
|
import IconButton from '../../../../components/icon_button';
|
||||||
import { makeGetAccount } from '../../../../selectors';
|
|
||||||
import { authorizeFollowRequest, rejectFollowRequest } from '../../../../actions/accounts';
|
|
||||||
|
|
||||||
import './account_authorize.scss';
|
import './account_authorize.scss';
|
||||||
|
|
||||||
|
@ -2,10 +2,10 @@ import { defineMessages, injectIntl, FormattedMessage } from 'react-intl';
|
|||||||
import ImmutablePureComponent from 'react-immutable-pure-component';
|
import ImmutablePureComponent from 'react-immutable-pure-component';
|
||||||
import ImmutablePropTypes from 'react-immutable-proptypes';
|
import ImmutablePropTypes from 'react-immutable-proptypes';
|
||||||
import { debounce } from 'lodash';
|
import { debounce } from 'lodash';
|
||||||
|
import { fetchFollowRequests, expandFollowRequests } from '../../actions/accounts';
|
||||||
import ColumnIndicator from '../../components/column_indicator';
|
import ColumnIndicator from '../../components/column_indicator';
|
||||||
import Column from '../../components/column';
|
import Column from '../../components/column';
|
||||||
import AccountAuthorize from './components/account_authorize';
|
import AccountAuthorize from './components/account_authorize';
|
||||||
import { fetchFollowRequests, expandFollowRequests } from '../../actions/accounts';
|
|
||||||
import ScrollableList from '../../components/scrollable_list';
|
import ScrollableList from '../../components/scrollable_list';
|
||||||
|
|
||||||
const messages = defineMessages({
|
const messages = defineMessages({
|
||||||
|
@ -9,10 +9,10 @@ import {
|
|||||||
expandFollowers,
|
expandFollowers,
|
||||||
fetchAccountByUsername,
|
fetchAccountByUsername,
|
||||||
} from '../../actions/accounts';
|
} from '../../actions/accounts';
|
||||||
|
import { me } from '../../initial_state';
|
||||||
import AccountContainer from '../../containers/account_container';
|
import AccountContainer from '../../containers/account_container';
|
||||||
import Column from '../../components/column';
|
import Column from '../../components/column';
|
||||||
import ScrollableList from '../../components/scrollable_list';
|
import ScrollableList from '../../components/scrollable_list';
|
||||||
import { me } from '../../initial_state';
|
|
||||||
|
|
||||||
const mapStateToProps = (state, { params: { username } }) => {
|
const mapStateToProps = (state, { params: { username } }) => {
|
||||||
const accounts = state.getIn(['accounts']);
|
const accounts = state.getIn(['accounts']);
|
||||||
|
@ -2,13 +2,13 @@ import ImmutablePureComponent from 'react-immutable-pure-component';
|
|||||||
import ImmutablePropTypes from 'react-immutable-proptypes';
|
import ImmutablePropTypes from 'react-immutable-proptypes';
|
||||||
import { debounce } from 'lodash';
|
import { debounce } from 'lodash';
|
||||||
import { FormattedMessage } from 'react-intl';
|
import { FormattedMessage } from 'react-intl';
|
||||||
import { me } from '../../initial_state';
|
|
||||||
import {
|
import {
|
||||||
fetchAccount,
|
fetchAccount,
|
||||||
fetchFollowing,
|
fetchFollowing,
|
||||||
expandFollowing,
|
expandFollowing,
|
||||||
fetchAccountByUsername,
|
fetchAccountByUsername,
|
||||||
} from '../../actions/accounts';
|
} from '../../actions/accounts';
|
||||||
|
import { me } from '../../initial_state';
|
||||||
import AccountContainer from '../../containers/account_container';
|
import AccountContainer from '../../containers/account_container';
|
||||||
import ColumnIndicator from '../../components/column_indicator';
|
import ColumnIndicator from '../../components/column_indicator';
|
||||||
import Column from '../../components/column';
|
import Column from '../../components/column';
|
||||||
|
@ -1,11 +1,10 @@
|
|||||||
|
import { FormattedMessage } from 'react-intl';
|
||||||
|
import { isEqual } from 'lodash';
|
||||||
|
import { expandHashtagTimeline, clearTimeline } from '../../actions/timelines';
|
||||||
|
import { connectHashtagStream } from '../../actions/streaming';
|
||||||
import StatusListContainer from '../../containers/status_list_container';
|
import StatusListContainer from '../../containers/status_list_container';
|
||||||
import Column from '../../components/column';
|
import Column from '../../components/column';
|
||||||
import { ColumnHeader } from '../../components/column_header';
|
import { ColumnHeader } from '../../components/column_header';
|
||||||
import { expandHashtagTimeline, clearTimeline } from '../../actions/timelines';
|
|
||||||
import { FormattedMessage } from 'react-intl';
|
|
||||||
import { connectHashtagStream } from '../../actions/streaming';
|
|
||||||
import { isEqual } from 'lodash';
|
|
||||||
import ColumnBackButton from '../../components/column_back_button';
|
|
||||||
|
|
||||||
const mapStateToProps = (state, props) => ({
|
const mapStateToProps = (state, props) => ({
|
||||||
hasUnread: state.getIn(['timelines', `hashtag:${props.params.id}`, 'unread']) > 0,
|
hasUnread: state.getIn(['timelines', `hashtag:${props.params.id}`, 'unread']) > 0,
|
||||||
@ -43,11 +42,11 @@ class HashtagTimeline extends PureComponent {
|
|||||||
additionalFor = (mode) => {
|
additionalFor = (mode) => {
|
||||||
const { tags } = this.props.params;
|
const { tags } = this.props.params;
|
||||||
|
|
||||||
if (tags && (tags[mode] || []).length > 0) {
|
try {
|
||||||
return tags[mode].map(tag => tag.value).join('/');
|
return tags[mode].map(tag => tag.value).join('/');
|
||||||
|
} catch (error) {
|
||||||
|
return '';
|
||||||
}
|
}
|
||||||
|
|
||||||
return '';
|
|
||||||
}
|
}
|
||||||
|
|
||||||
_subscribe (dispatch, id, tags = {}) {
|
_subscribe (dispatch, id, tags = {}) {
|
||||||
|
@ -1,9 +1,9 @@
|
|||||||
import { defineMessages, injectIntl, FormattedMessage } from 'react-intl';
|
import { defineMessages, injectIntl, FormattedMessage } from 'react-intl';
|
||||||
import { expandHomeTimeline } from '../../actions/timelines';
|
import { expandHomeTimeline } from '../../actions/timelines';
|
||||||
import StatusListContainer from '../../containers/status_list_container';
|
import StatusListContainer from '../../containers/status_list_container';
|
||||||
import Column from '../../components/column';
|
|
||||||
import ColumnSettings from './components/column_settings';
|
import ColumnSettings from './components/column_settings';
|
||||||
import HomeColumnHeader from '../../components/column_header';
|
import Column from '../../components/column';
|
||||||
|
import { HomeColumnHeader } from '../../components/column_header';
|
||||||
|
|
||||||
const messages = defineMessages({
|
const messages = defineMessages({
|
||||||
title: { id: 'column.home', defaultMessage: 'Home' },
|
title: { id: 'column.home', defaultMessage: 'Home' },
|
||||||
@ -67,9 +67,9 @@ class HomeTimeline extends PureComponent {
|
|||||||
|
|
||||||
return (
|
return (
|
||||||
<Column heading={intl.formatMessage(messages.title)}>
|
<Column heading={intl.formatMessage(messages.title)}>
|
||||||
{ /* <HomeColumnHeader activeItem='home' active={hasUnread}>
|
<HomeColumnHeader activeItem='home' active={hasUnread}>
|
||||||
<ColumnSettings />
|
<ColumnSettings />
|
||||||
</HomeColumnHeader> */}
|
</HomeColumnHeader>
|
||||||
<StatusListContainer
|
<StatusListContainer
|
||||||
scrollKey='home_timeline'
|
scrollKey='home_timeline'
|
||||||
onLoadMore={this.handleLoadMore}
|
onLoadMore={this.handleLoadMore}
|
||||||
|
@ -12,11 +12,7 @@ class FrameWelcome extends Component {
|
|||||||
};
|
};
|
||||||
|
|
||||||
shouldComponentUpdate(nextProps) {
|
shouldComponentUpdate(nextProps) {
|
||||||
if (nextProps.domain !== this.props.domain) {
|
return nextProps.domain !== this.props.domain;
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
return false;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
render() {
|
render() {
|
||||||
@ -55,7 +51,7 @@ class FrameFederation extends Component {
|
|||||||
}
|
}
|
||||||
|
|
||||||
shouldComponentUpdate() {
|
shouldComponentUpdate() {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
render() {
|
render() {
|
||||||
|
@ -1,8 +1,8 @@
|
|||||||
import { defineMessages, injectIntl } from 'react-intl';
|
import { defineMessages, injectIntl } from 'react-intl';
|
||||||
import ImmutablePureComponent from 'react-immutable-pure-component';
|
import ImmutablePureComponent from 'react-immutable-pure-component';
|
||||||
import ImmutablePropTypes from 'react-immutable-proptypes';
|
import ImmutablePropTypes from 'react-immutable-proptypes';
|
||||||
import IconButton from '../../../../components/icon_button';
|
|
||||||
import { removeFromListAdder, addToListAdder } from '../../../../actions/lists';
|
import { removeFromListAdder, addToListAdder } from '../../../../actions/lists';
|
||||||
|
import IconButton from '../../../../components/icon_button';
|
||||||
import Icon from '../../../../components/icon';
|
import Icon from '../../../../components/icon';
|
||||||
|
|
||||||
import './list.scss';
|
import './list.scss';
|
||||||
|
@ -56,8 +56,7 @@ class ListAdder extends ImmutablePureComponent {
|
|||||||
}
|
}
|
||||||
|
|
||||||
componentWillUnmount() {
|
componentWillUnmount() {
|
||||||
const { onReset } = this.props;
|
this.props.onReset();
|
||||||
onReset();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
onClickClose = () => {
|
onClickClose = () => {
|
||||||
|
@ -1,11 +1,12 @@
|
|||||||
import { makeGetAccount } from '../../../selectors';
|
|
||||||
|
import { defineMessages, injectIntl } from 'react-intl';
|
||||||
import ImmutablePureComponent from 'react-immutable-pure-component';
|
import ImmutablePureComponent from 'react-immutable-pure-component';
|
||||||
import ImmutablePropTypes from 'react-immutable-proptypes';
|
import ImmutablePropTypes from 'react-immutable-proptypes';
|
||||||
|
import { removeFromListEditor, addToListEditor } from '../../../actions/lists';
|
||||||
|
import { makeGetAccount } from '../../../selectors';
|
||||||
import Avatar from '../../../components/avatar';
|
import Avatar from '../../../components/avatar';
|
||||||
import DisplayName from '../../../components/display_name';
|
import DisplayName from '../../../components/display_name';
|
||||||
import IconButton from '../../../components/icon_button';
|
import IconButton from '../../../components/icon_button';
|
||||||
import { defineMessages, injectIntl } from 'react-intl';
|
|
||||||
import { removeFromListEditor, addToListEditor } from '../../../actions/lists';
|
|
||||||
|
|
||||||
const messages = defineMessages({
|
const messages = defineMessages({
|
||||||
remove: { id: 'lists.account.remove', defaultMessage: 'Remove from list' },
|
remove: { id: 'lists.account.remove', defaultMessage: 'Remove from list' },
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
import ImmutablePropTypes from 'react-immutable-proptypes';
|
import ImmutablePropTypes from 'react-immutable-proptypes';
|
||||||
import ImmutablePureComponent from 'react-immutable-pure-component';
|
import ImmutablePureComponent from 'react-immutable-pure-component';
|
||||||
import { injectIntl, defineMessages } from 'react-intl';
|
import { injectIntl, defineMessages } from 'react-intl';
|
||||||
import { setupListEditor, clearListSuggestions, resetListEditor } from '../../actions/lists';
|
import { setupListEditor, resetListEditor } from '../../actions/lists';
|
||||||
import Account from './components/account';
|
import Account from './components/account';
|
||||||
import ListEditorSearch from './components/list_editor_search';
|
import ListEditorSearch from './components/list_editor_search';
|
||||||
import EditListForm from './components/edit_list_form/edit_list_form';
|
import EditListForm from './components/edit_list_form/edit_list_form';
|
||||||
@ -48,8 +48,7 @@ class ListEditor extends ImmutablePureComponent {
|
|||||||
}
|
}
|
||||||
|
|
||||||
componentWillUnmount() {
|
componentWillUnmount() {
|
||||||
const { onReset } = this.props;
|
this.props.onReset();
|
||||||
onReset();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
onClickClose = () => {
|
onClickClose = () => {
|
||||||
|
@ -1,15 +1,13 @@
|
|||||||
import ImmutablePropTypes from 'react-immutable-proptypes';
|
import ImmutablePropTypes from 'react-immutable-proptypes';
|
||||||
import ImmutablePureComponent from 'react-immutable-pure-component';
|
import ImmutablePureComponent from 'react-immutable-pure-component';
|
||||||
import { Link } from 'react-router-dom';
|
|
||||||
import { FormattedMessage, defineMessages, injectIntl } from 'react-intl';
|
import { FormattedMessage, defineMessages, injectIntl } from 'react-intl';
|
||||||
import StatusListContainer from '../../containers/status_list_container';
|
|
||||||
import Column from '../../components/column';
|
|
||||||
import { connectListStream } from '../../actions/streaming';
|
import { connectListStream } from '../../actions/streaming';
|
||||||
import { expandListTimeline } from '../../actions/timelines';
|
import { expandListTimeline } from '../../actions/timelines';
|
||||||
import { fetchList, deleteList } from '../../actions/lists';
|
import { fetchList, deleteList } from '../../actions/lists';
|
||||||
import { openModal } from '../../actions/modal';
|
import { openModal } from '../../actions/modal';
|
||||||
|
import StatusListContainer from '../../containers/status_list_container';
|
||||||
|
import Column from '../../components/column';
|
||||||
import ColumnIndicator from '../../components/column_indicator';
|
import ColumnIndicator from '../../components/column_indicator';
|
||||||
import Icon from '../../components/icon';
|
|
||||||
import { HomeColumnHeader } from '../../components/column_header';
|
import { HomeColumnHeader } from '../../components/column_header';
|
||||||
import Button from '../../components/button';
|
import Button from '../../components/button';
|
||||||
import ColumnHeaderSettingButton from '../../components/column_header_setting_button';
|
import ColumnHeaderSettingButton from '../../components/column_header_setting_button';
|
||||||
|
@ -2,9 +2,9 @@ import ImmutablePropTypes from 'react-immutable-proptypes';
|
|||||||
import { createSelector } from 'reselect';
|
import { createSelector } from 'reselect';
|
||||||
import { defineMessages, injectIntl, FormattedMessage } from 'react-intl';
|
import { defineMessages, injectIntl, FormattedMessage } from 'react-intl';
|
||||||
import ImmutablePureComponent from 'react-immutable-pure-component';
|
import ImmutablePureComponent from 'react-immutable-pure-component';
|
||||||
|
import { fetchLists } from '../../actions/lists';
|
||||||
import ColumnIndicator from '../../components/column_indicator';
|
import ColumnIndicator from '../../components/column_indicator';
|
||||||
import Column from '../../components/column';
|
import Column from '../../components/column';
|
||||||
import { fetchLists } from '../../actions/lists';
|
|
||||||
import ColumnLink from '../../components/column_link';
|
import ColumnLink from '../../components/column_link';
|
||||||
import ColumnSubheading from '../../components/column_subheading';
|
import ColumnSubheading from '../../components/column_subheading';
|
||||||
import NewListForm from './components/new_list_form';
|
import NewListForm from './components/new_list_form';
|
||||||
|
@ -2,10 +2,10 @@ import { defineMessages, injectIntl, FormattedMessage } from 'react-intl';
|
|||||||
import ImmutablePureComponent from 'react-immutable-pure-component';
|
import ImmutablePureComponent from 'react-immutable-pure-component';
|
||||||
import ImmutablePropTypes from 'react-immutable-proptypes';
|
import ImmutablePropTypes from 'react-immutable-proptypes';
|
||||||
import { debounce } from 'lodash';
|
import { debounce } from 'lodash';
|
||||||
|
import { fetchMutes, expandMutes } from '../../actions/mutes';
|
||||||
|
import AccountContainer from '../../containers/account_container';
|
||||||
import ColumnIndicator from '../../components/column_indicator';
|
import ColumnIndicator from '../../components/column_indicator';
|
||||||
import Column from '../../components/column';
|
import Column from '../../components/column';
|
||||||
import AccountContainer from '../../containers/account_container';
|
|
||||||
import { fetchMutes, expandMutes } from '../../actions/mutes';
|
|
||||||
import ScrollableList from '../../components/scrollable_list';
|
import ScrollableList from '../../components/scrollable_list';
|
||||||
|
|
||||||
const messages = defineMessages({
|
const messages = defineMessages({
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
import FilterBar from '../components/notification_filter_bar/notification_filter_bar';
|
|
||||||
import { setFilter } from '../../../actions/notifications';
|
import { setFilter } from '../../../actions/notifications';
|
||||||
|
import FilterBar from '../components/notification_filter_bar';
|
||||||
|
|
||||||
const makeMapStateToProps = state => ({
|
const makeMapStateToProps = state => ({
|
||||||
selectedFilter: state.getIn(['settings', 'notifications', 'quickFilter', 'active']),
|
selectedFilter: state.getIn(['settings', 'notifications', 'quickFilter', 'active']),
|
||||||
|
@ -1,5 +1,3 @@
|
|||||||
import { makeGetNotification, makeGetStatus } from '../../../selectors';
|
|
||||||
import Notification from '../components/notification/notification';
|
|
||||||
import { openModal } from '../../../actions/modal';
|
import { openModal } from '../../../actions/modal';
|
||||||
import { mentionCompose } from '../../../actions/compose';
|
import { mentionCompose } from '../../../actions/compose';
|
||||||
import {
|
import {
|
||||||
@ -13,6 +11,8 @@ import {
|
|||||||
revealStatus,
|
revealStatus,
|
||||||
} from '../../../actions/statuses';
|
} from '../../../actions/statuses';
|
||||||
import { boostModal } from '../../../initial_state';
|
import { boostModal } from '../../../initial_state';
|
||||||
|
import { makeGetNotification, makeGetStatus } from '../../../selectors';
|
||||||
|
import Notification from '../components/notification/notification';
|
||||||
|
|
||||||
const makeMapStateToProps = () => {
|
const makeMapStateToProps = () => {
|
||||||
const getNotification = makeGetNotification();
|
const getNotification = makeGetNotification();
|
||||||
|
@ -4,8 +4,6 @@ import { defineMessages, injectIntl, FormattedMessage } from 'react-intl';
|
|||||||
import { createSelector } from 'reselect';
|
import { createSelector } from 'reselect';
|
||||||
import { List as ImmutableList } from 'immutable';
|
import { List as ImmutableList } from 'immutable';
|
||||||
import { debounce } from 'lodash';
|
import { debounce } from 'lodash';
|
||||||
import Column from '../../components/column';
|
|
||||||
import { ColumnHeader } from '../../components/column_header';
|
|
||||||
import {
|
import {
|
||||||
expandNotifications,
|
expandNotifications,
|
||||||
scrollTopNotifications,
|
scrollTopNotifications,
|
||||||
@ -17,6 +15,8 @@ import FilterBarContainer from './containers/filter_bar_container';
|
|||||||
import ScrollableList from '../../components/scrollable_list';
|
import ScrollableList from '../../components/scrollable_list';
|
||||||
import LoadMore from '../../components/load_more';
|
import LoadMore from '../../components/load_more';
|
||||||
import TimelineQueueButtonHeader from '../../components/timeline_queue_button_header';
|
import TimelineQueueButtonHeader from '../../components/timeline_queue_button_header';
|
||||||
|
import Column from '../../components/column';
|
||||||
|
import { ColumnHeader } from '../../components/column_header';
|
||||||
|
|
||||||
const messages = defineMessages({
|
const messages = defineMessages({
|
||||||
title: { id: 'column.notifications', defaultMessage: 'Notifications' },
|
title: { id: 'column.notifications', defaultMessage: 'Notifications' },
|
||||||
|
@ -2,9 +2,9 @@ import ImmutablePropTypes from 'react-immutable-proptypes';
|
|||||||
import ImmutablePureComponent from 'react-immutable-pure-component';
|
import ImmutablePureComponent from 'react-immutable-pure-component';
|
||||||
import { FormattedMessage } from 'react-intl';
|
import { FormattedMessage } from 'react-intl';
|
||||||
import { fetchPinnedStatuses } from '../../actions/pin_statuses';
|
import { fetchPinnedStatuses } from '../../actions/pin_statuses';
|
||||||
|
import { meUsername } from '../../initial_state';
|
||||||
import Column from '../../components/column';
|
import Column from '../../components/column';
|
||||||
import StatusList from '../../components/status_list/status_list';
|
import StatusList from '../../components/status_list/status_list';
|
||||||
import { meUsername } from '../../initial_state';
|
|
||||||
import ColumnIndicator from '../../components/column_indicator/column_indicator';
|
import ColumnIndicator from '../../components/column_indicator/column_indicator';
|
||||||
|
|
||||||
const mapStateToProps = (state, { params: { username } }) => {
|
const mapStateToProps = (state, { params: { username } }) => {
|
||||||
|
@ -1,13 +1,13 @@
|
|||||||
import ImmutablePureComponent from 'react-immutable-pure-component';
|
import ImmutablePureComponent from 'react-immutable-pure-component';
|
||||||
import ImmutablePropTypes from 'react-immutable-proptypes';
|
import ImmutablePropTypes from 'react-immutable-proptypes';
|
||||||
import { FormattedMessage } from 'react-intl';
|
import { FormattedMessage } from 'react-intl';
|
||||||
import ColumnIndicator from '../../components/column_indicator';
|
|
||||||
import { fetchReblogs } from '../../actions/interactions';
|
import { fetchReblogs } from '../../actions/interactions';
|
||||||
import { fetchStatus } from '../../actions/statuses';
|
import { fetchStatus } from '../../actions/statuses';
|
||||||
|
import { makeGetStatus } from '../../selectors';
|
||||||
import AccountContainer from '../../containers/account_container';
|
import AccountContainer from '../../containers/account_container';
|
||||||
|
import ColumnIndicator from '../../components/column_indicator';
|
||||||
import Column from '../../components/column';
|
import Column from '../../components/column';
|
||||||
import ScrollableList from '../../components/scrollable_list';
|
import ScrollableList from '../../components/scrollable_list';
|
||||||
import { makeGetStatus } from '../../selectors';
|
|
||||||
|
|
||||||
const mapStateToProps = (state, props) => {
|
const mapStateToProps = (state, props) => {
|
||||||
const getStatus = makeGetStatus();
|
const getStatus = makeGetStatus();
|
||||||
|
@ -1,8 +1,6 @@
|
|||||||
import SearchContainer from '../compose/containers/search_container';
|
import SearchContainer from '../compose/containers/search_container';
|
||||||
import SearchResultsContainer from '../compose/containers/search_results_container';
|
import SearchResultsContainer from '../compose/containers/search_results_container';
|
||||||
|
|
||||||
|
|
||||||
// : TODO : test
|
|
||||||
export default class Search extends PureComponent {
|
export default class Search extends PureComponent {
|
||||||
|
|
||||||
render() {
|
render() {
|
||||||
|
@ -3,16 +3,16 @@ import { FormattedDate, FormattedNumber } from 'react-intl';
|
|||||||
import ImmutablePropTypes from 'react-immutable-proptypes';
|
import ImmutablePropTypes from 'react-immutable-proptypes';
|
||||||
import ImmutablePureComponent from 'react-immutable-pure-component';
|
import ImmutablePureComponent from 'react-immutable-pure-component';
|
||||||
import classNames from 'classnames';
|
import classNames from 'classnames';
|
||||||
|
import scheduleIdleTask from '../../../../utils/schedule_idle_task';
|
||||||
import StatusQuote from '../../../../components/status_quote';
|
import StatusQuote from '../../../../components/status_quote';
|
||||||
import Avatar from '../../../../components/avatar';
|
import Avatar from '../../../../components/avatar';
|
||||||
import DisplayName from '../../../../components/display_name';
|
import DisplayName from '../../../../components/display_name';
|
||||||
import StatusContent from '../../../../components/status_content';
|
import StatusContent from '../../../../components/status_content';
|
||||||
import MediaGallery from '../../../../components/media_gallery';
|
import MediaGallery from '../../../../components/media_gallery';
|
||||||
import Card from '../card';
|
|
||||||
import Video from '../../../video';
|
|
||||||
import scheduleIdleTask from '../../../../utils/schedule_idle_task';
|
|
||||||
import Icon from '../../../../components/icon';
|
import Icon from '../../../../components/icon';
|
||||||
import Poll from '../../../../components/poll';
|
import Poll from '../../../../components/poll';
|
||||||
|
import Card from '../card';
|
||||||
|
import Video from '../../../video';
|
||||||
|
|
||||||
import './detailed_status.scss';
|
import './detailed_status.scss';
|
||||||
|
|
||||||
|
@ -1,10 +1,10 @@
|
|||||||
import ImmutablePropTypes from 'react-immutable-proptypes';
|
import ImmutablePropTypes from 'react-immutable-proptypes';
|
||||||
import ImmutablePureComponent from 'react-immutable-pure-component';
|
import ImmutablePureComponent from 'react-immutable-pure-component';
|
||||||
import { defineMessages, injectIntl } from 'react-intl';
|
import { defineMessages, injectIntl } from 'react-intl';
|
||||||
import DropdownMenuContainer from '../../../../containers/dropdown_menu_container';
|
|
||||||
import { openModal } from '../../../../actions/modal';
|
import { openModal } from '../../../../actions/modal';
|
||||||
import IconButton from '../../../../components/icon_button';
|
|
||||||
import { me, isStaff } from '../../../../initial_state';
|
import { me, isStaff } from '../../../../initial_state';
|
||||||
|
import DropdownMenuContainer from '../../../../containers/dropdown_menu_container';
|
||||||
|
import IconButton from '../../../../components/icon_button';
|
||||||
|
|
||||||
import './detailed_status_action_bar.scss';
|
import './detailed_status_action_bar.scss';
|
||||||
|
|
||||||
|
@ -1,5 +1,4 @@
|
|||||||
import DetailedStatus from '../components/detailed_status';
|
import { defineMessages, injectIntl, FormattedMessage } from 'react-intl';
|
||||||
import { makeGetStatus } from '../../../selectors';
|
|
||||||
import {
|
import {
|
||||||
replyCompose,
|
replyCompose,
|
||||||
mentionCompose,
|
mentionCompose,
|
||||||
@ -24,9 +23,10 @@ import {
|
|||||||
import { initMuteModal } from '../../../actions/mutes';
|
import { initMuteModal } from '../../../actions/mutes';
|
||||||
import { initReport } from '../../../actions/reports';
|
import { initReport } from '../../../actions/reports';
|
||||||
import { openModal } from '../../../actions/modal';
|
import { openModal } from '../../../actions/modal';
|
||||||
import { defineMessages, injectIntl, FormattedMessage } from 'react-intl';
|
|
||||||
import { boostModal, deleteModal } from '../../../initial_state';
|
|
||||||
import { showAlertForError } from '../../../actions/alerts';
|
import { showAlertForError } from '../../../actions/alerts';
|
||||||
|
import { boostModal, deleteModal } from '../../../initial_state';
|
||||||
|
import { makeGetStatus } from '../../../selectors';
|
||||||
|
import DetailedStatus from '../components/detailed_status';
|
||||||
|
|
||||||
const messages = defineMessages({
|
const messages = defineMessages({
|
||||||
deleteConfirm: { id: 'confirmations.delete.confirm', defaultMessage: 'Delete' },
|
deleteConfirm: { id: 'confirmations.delete.confirm', defaultMessage: 'Delete' },
|
||||||
|
@ -5,9 +5,6 @@ import { defineMessages, injectIntl, FormattedMessage } from 'react-intl';
|
|||||||
import ImmutablePureComponent from 'react-immutable-pure-component';
|
import ImmutablePureComponent from 'react-immutable-pure-component';
|
||||||
import { HotKeys } from 'react-hotkeys';
|
import { HotKeys } from 'react-hotkeys';
|
||||||
import { fetchStatus } from '../../actions/statuses';
|
import { fetchStatus } from '../../actions/statuses';
|
||||||
import DetailedStatus from './components/detailed_status';
|
|
||||||
import ActionBar from './components/detailed_status_action_bar';
|
|
||||||
import Column from '../../components/column';
|
|
||||||
import {
|
import {
|
||||||
favourite,
|
favourite,
|
||||||
unfavourite,
|
unfavourite,
|
||||||
@ -31,15 +28,18 @@ import {
|
|||||||
} from '../../actions/statuses';
|
} from '../../actions/statuses';
|
||||||
import { initMuteModal } from '../../actions/mutes';
|
import { initMuteModal } from '../../actions/mutes';
|
||||||
import { initReport } from '../../actions/reports';
|
import { initReport } from '../../actions/reports';
|
||||||
import { makeGetStatus } from '../../selectors';
|
|
||||||
import { ColumnHeader } from '../../components/column_header';
|
|
||||||
import StatusContainer from '../../containers/status_container';
|
|
||||||
import { openModal } from '../../actions/modal';
|
import { openModal } from '../../actions/modal';
|
||||||
import { boostModal, deleteModal, me } from '../../initial_state';
|
import { boostModal, deleteModal, me } from '../../initial_state';
|
||||||
|
import { makeGetStatus } from '../../selectors';
|
||||||
import { attachFullscreenListener, detachFullscreenListener, isFullscreen } from '../../utils/fullscreen';
|
import { attachFullscreenListener, detachFullscreenListener, isFullscreen } from '../../utils/fullscreen';
|
||||||
|
import StatusContainer from '../../containers/status_container';
|
||||||
|
import { ColumnHeader } from '../../components/column_header';
|
||||||
import { textForScreenReader, defaultMediaVisibility } from '../../components/status/status';
|
import { textForScreenReader, defaultMediaVisibility } from '../../components/status/status';
|
||||||
import Icon from '../../components/icon';
|
import Icon from '../../components/icon';
|
||||||
import ColumnIndicator from '../../components/column_indicator';
|
import ColumnIndicator from '../../components/column_indicator';
|
||||||
|
import DetailedStatus from './components/detailed_status';
|
||||||
|
import ActionBar from './components/detailed_status_action_bar';
|
||||||
|
import Column from '../../components/column';
|
||||||
|
|
||||||
const messages = defineMessages({
|
const messages = defineMessages({
|
||||||
deleteConfirm: { id: 'confirmations.delete.confirm', defaultMessage: 'Delete' },
|
deleteConfirm: { id: 'confirmations.delete.confirm', defaultMessage: 'Delete' },
|
||||||
@ -417,7 +417,6 @@ class Status extends ImmutablePureComponent {
|
|||||||
render () {
|
render () {
|
||||||
let ancestors, descendants;
|
let ancestors, descendants;
|
||||||
const { status, ancestorsIds, descendantsIds, intl, domain } = this.props;
|
const { status, ancestorsIds, descendantsIds, intl, domain } = this.props;
|
||||||
const { fullscreen } = this.state;
|
|
||||||
|
|
||||||
if (status === null) {
|
if (status === null) {
|
||||||
return (<ColumnIndicator type='loading' />);
|
return (<ColumnIndicator type='loading' />);
|
||||||
|
@ -1,43 +0,0 @@
|
|||||||
|
|
||||||
import { injectIntl } from 'react-intl';
|
|
||||||
import ImmutablePureComponent from 'react-immutable-pure-component';
|
|
||||||
import ModalLoading from '../../../components/modal_loading';
|
|
||||||
import RelativeTimestamp from '../../../components/relative_timestamp';
|
|
||||||
|
|
||||||
export default @injectIntl
|
|
||||||
class StatusRevisionsList extends ImmutablePureComponent {
|
|
||||||
|
|
||||||
static propTypes = {
|
|
||||||
loading: PropTypes.bool.isRequired,
|
|
||||||
error: PropTypes.object,
|
|
||||||
data: PropTypes.array
|
|
||||||
};
|
|
||||||
|
|
||||||
render () {
|
|
||||||
const { loading, error, data } = this.props;
|
|
||||||
|
|
||||||
if (loading || !data) return <ModalLoading />;
|
|
||||||
|
|
||||||
if (error) return (
|
|
||||||
<div className='status-revisions-list'>
|
|
||||||
<div className='status-revisions-list__error'>
|
|
||||||
An error occured
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
);
|
|
||||||
|
|
||||||
return (
|
|
||||||
<div className='status-revisions-list'>
|
|
||||||
{data.map((revision, i) => (
|
|
||||||
<div key={i} className='status-revisions-list__item'>
|
|
||||||
<div className='status-revisions-list__item__timestamp'>
|
|
||||||
<RelativeTimestamp timestamp={revision.created_at} />
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<div className='status-revisions-list__item__text'>{revision.text}</div>
|
|
||||||
</div>
|
|
||||||
))}
|
|
||||||
</div>
|
|
||||||
);
|
|
||||||
}
|
|
||||||
}
|
|
@ -21,7 +21,7 @@ import LoadingBarContainer from '../../containers/loading_bar_container';
|
|||||||
import ModalContainer from '../../containers/modal_container';
|
import ModalContainer from '../../containers/modal_container';
|
||||||
import UploadArea from '../../components/upload_area';
|
import UploadArea from '../../components/upload_area';
|
||||||
import TabsBar from '../../components/tabs_bar';
|
import TabsBar from '../../components/tabs_bar';
|
||||||
import FooterBar from './components/footer_bar';
|
import FooterBar from '../../components/footer_bar';
|
||||||
// import TrendsPanel from './components/trends_panel';
|
// import TrendsPanel from './components/trends_panel';
|
||||||
import { WhoToFollowPanel } from '../../components/panel';
|
import { WhoToFollowPanel } from '../../components/panel';
|
||||||
import LinkFooter from '../../components/link_footer';
|
import LinkFooter from '../../components/link_footer';
|
||||||
@ -178,8 +178,7 @@ class SwitchingColumnsArea extends React.PureComponent {
|
|||||||
}
|
}
|
||||||
|
|
||||||
render() {
|
render() {
|
||||||
const { children, account } = this.props;
|
const { children } = this.props;
|
||||||
const { mobile } = this.state;
|
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<Switch>
|
<Switch>
|
||||||
|
@ -111,7 +111,7 @@ export function MuteModal () {
|
|||||||
}
|
}
|
||||||
|
|
||||||
export function StatusRevisionModal () {
|
export function StatusRevisionModal () {
|
||||||
return import(/* webpackChunkName: "modals/mute_modal" */'../components/status_revision_modal');
|
return import(/* webpackChunkName: "modals/mute_modal" */'../../../components/modal');
|
||||||
}
|
}
|
||||||
|
|
||||||
export function ReportModal () {
|
export function ReportModal () {
|
||||||
|
@ -1,14 +1,14 @@
|
|||||||
import { Fragment } from 'react';
|
import { Fragment } from 'react';
|
||||||
import ImmutablePropTypes from 'react-immutable-proptypes';
|
import ImmutablePropTypes from 'react-immutable-proptypes';
|
||||||
import ImmutablePureComponent from 'react-immutable-pure-component';
|
import ImmutablePureComponent from 'react-immutable-pure-component';
|
||||||
|
import { fetchGroup } from '../actions/groups';
|
||||||
|
import HeaderContainer from '../features/groups/timeline/containers/header_container';
|
||||||
|
import GroupPanel from '../features/groups/timeline/components/panel';
|
||||||
|
import GroupSidebarPanel from '../features/groups/sidebar_panel';
|
||||||
|
import ColumnsArea from '../components/columns_area';
|
||||||
import { WhoToFollowPanel } from '../components/panel';
|
import { WhoToFollowPanel } from '../components/panel';
|
||||||
import LinkFooter from '../components/link_footer';
|
import LinkFooter from '../components/link_footer';
|
||||||
import PromoPanel from '../components/promo_panel';
|
import PromoPanel from '../components/promo_panel';
|
||||||
import HeaderContainer from '../features/groups/timeline/containers/header_container';
|
|
||||||
import GroupPanel from '../features/groups/timeline/components/panel';
|
|
||||||
import { fetchGroup } from '../actions/groups';
|
|
||||||
import GroupSidebarPanel from '../features/groups/sidebar_panel';
|
|
||||||
import ColumnsArea from '../components/columns_area';
|
|
||||||
|
|
||||||
const mapStateToProps = (state, { params: { id } }) => ({
|
const mapStateToProps = (state, { params: { id } }) => ({
|
||||||
group: state.getIn(['groups', id]),
|
group: state.getIn(['groups', id]),
|
||||||
|
@ -1,9 +1,8 @@
|
|||||||
import { Fragment } from 'react';
|
import { Fragment } from 'react';
|
||||||
import WhoToFollowPanel from '../components/panel';
|
import GroupSidebarPanel from '../features/groups/sidebar_panel';
|
||||||
import LinkFooter from '../components/link_footer';
|
import LinkFooter from '../components/link_footer';
|
||||||
import PromoPanel from '../components/promo_panel';
|
import PromoPanel from '../components/promo_panel';
|
||||||
import UserPanel from '../components/user_panel';
|
import UserPanel from '../components/user_panel';
|
||||||
import GroupSidebarPanel from '../features/groups/sidebar_panel';
|
|
||||||
import ColumnsArea from '../components/columns_area';
|
import ColumnsArea from '../components/columns_area';
|
||||||
import TimelineComposeBlock from '../components/timeline_compose_block';
|
import TimelineComposeBlock from '../components/timeline_compose_block';
|
||||||
|
|
||||||
@ -18,7 +17,6 @@ export default class HomePage extends PureComponent {
|
|||||||
RIGHT: (
|
RIGHT: (
|
||||||
<Fragment>
|
<Fragment>
|
||||||
<GroupSidebarPanel />
|
<GroupSidebarPanel />
|
||||||
{ /* <WhoToFollowPanel /> */ }
|
|
||||||
</Fragment>
|
</Fragment>
|
||||||
),
|
),
|
||||||
LEFT: (
|
LEFT: (
|
||||||
|
@ -2,9 +2,9 @@ import { Fragment } from 'react';
|
|||||||
import ImmutablePropTypes from 'react-immutable-proptypes';
|
import ImmutablePropTypes from 'react-immutable-proptypes';
|
||||||
import ImmutablePureComponent from 'react-immutable-pure-component';
|
import ImmutablePureComponent from 'react-immutable-pure-component';
|
||||||
import HeaderContainer from '../features/account_timeline/containers/header_container';
|
import HeaderContainer from '../features/account_timeline/containers/header_container';
|
||||||
|
import ProfileInfoPanel from '../features/account_timeline/components/profile_info_panel/profile_info_panel';
|
||||||
import { WhoToFollowPanel, SignUpPanel } from '../components/panel';
|
import { WhoToFollowPanel, SignUpPanel } from '../components/panel';
|
||||||
import LinkFooter from '../components/link_footer';
|
import LinkFooter from '../components/link_footer';
|
||||||
import ProfileInfoPanel from '../features/account_timeline/components/profile_info_panel/profile_info_panel';
|
|
||||||
import ColumnsArea from '../components/columns_area';
|
import ColumnsArea from '../components/columns_area';
|
||||||
|
|
||||||
const mapStateToProps = (state, { params: { username }, withReplies = false }) => {
|
const mapStateToProps = (state, { params: { username }, withReplies = false }) => {
|
||||||
|
@ -2,10 +2,10 @@ import { createSelector } from 'reselect';
|
|||||||
import { List as ImmutableList } from 'immutable';
|
import { List as ImmutableList } from 'immutable';
|
||||||
import { me } from '../initial_state';
|
import { me } from '../initial_state';
|
||||||
|
|
||||||
const getAccountBase = (state, id) => state.getIn(['accounts', id], null);
|
const getAccountBase = (state, id) => state.getIn(['accounts', id], null);
|
||||||
const getAccountCounters = (state, id) => state.getIn(['accounts_counters', id], null);
|
const getAccountCounters = (state, id) => state.getIn(['accounts_counters', id], null);
|
||||||
const getAccountRelationship = (state, id) => state.getIn(['relationships', id], null);
|
const getAccountRelationship = (state, id) => state.getIn(['relationships', id], null);
|
||||||
const getAccountMoved = (state, id) => state.getIn(['accounts', state.getIn(['accounts', id, 'moved'])]);
|
const getAccountMoved = (state, id) => state.getIn(['accounts', state.getIn(['accounts', id, 'moved'])]);
|
||||||
|
|
||||||
export const makeGetAccount = () => {
|
export const makeGetAccount = () => {
|
||||||
return createSelector([getAccountBase, getAccountCounters, getAccountRelationship, getAccountMoved], (base, counters, relationship, moved) => {
|
return createSelector([getAccountBase, getAccountCounters, getAccountRelationship, getAccountMoved], (base, counters, relationship, moved) => {
|
||||||
@ -22,17 +22,17 @@ export const makeGetAccount = () => {
|
|||||||
|
|
||||||
const toServerSideType = columnType => {
|
const toServerSideType = columnType => {
|
||||||
switch (columnType) {
|
switch (columnType) {
|
||||||
case 'home':
|
case 'home':
|
||||||
case 'notifications':
|
case 'notifications':
|
||||||
case 'public':
|
case 'public':
|
||||||
case 'thread':
|
case 'thread':
|
||||||
return columnType;
|
return columnType;
|
||||||
default:
|
default:
|
||||||
if (columnType.indexOf('list:') > -1) {
|
if (columnType.indexOf('list:') > -1) {
|
||||||
return 'home';
|
return 'home';
|
||||||
} else {
|
} else {
|
||||||
return 'public'; // community, account, hashtag
|
return 'public'; // community, account, hashtag
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -91,7 +91,7 @@ export const makeGetStatus = () => {
|
|||||||
statusReblog = null;
|
statusReblog = null;
|
||||||
}
|
}
|
||||||
|
|
||||||
const regex = (accountReblog || accountBase).get('id') !== me && regexFromFilters(filters);
|
const regex = (accountReblog || accountBase).get('id') !== me && regexFromFilters(filters);
|
||||||
const filtered = regex && regex.test(statusBase.get('reblog') ? statusReblog.get('search_index') : statusBase.get('search_index'));
|
const filtered = regex && regex.test(statusBase.get('reblog') ? statusReblog.get('search_index') : statusBase.get('search_index'));
|
||||||
|
|
||||||
return statusBase.withMutations(map => {
|
return statusBase.withMutations(map => {
|
||||||
@ -125,7 +125,7 @@ export const getAlerts = createSelector([getAlertsBase], (base) => {
|
|||||||
|
|
||||||
export const makeGetNotification = () => {
|
export const makeGetNotification = () => {
|
||||||
return createSelector([
|
return createSelector([
|
||||||
(_, base) => base,
|
(_, base) => base,
|
||||||
(state, _, accountId) => state.getIn(['accounts', accountId]),
|
(state, _, accountId) => state.getIn(['accounts', accountId]),
|
||||||
], (base, account) => {
|
], (base, account) => {
|
||||||
return base.set('account', account);
|
return base.set('account', account);
|
||||||
@ -134,7 +134,7 @@ export const makeGetNotification = () => {
|
|||||||
|
|
||||||
export const getAccountGallery = createSelector([
|
export const getAccountGallery = createSelector([
|
||||||
(state, id) => state.getIn(['timelines', `account:${id}:media`, 'items'], ImmutableList()),
|
(state, id) => state.getIn(['timelines', `account:${id}:media`, 'items'], ImmutableList()),
|
||||||
state => state.get('statuses'),
|
state => state.get('statuses'),
|
||||||
], (statusIds, statuses) => {
|
], (statusIds, statuses) => {
|
||||||
let medias = ImmutableList();
|
let medias = ImmutableList();
|
||||||
|
|
||||||
|
@ -18,13 +18,13 @@ function fetchRoot() {
|
|||||||
|
|
||||||
// Cause a new version of a registered Service Worker to replace an existing one
|
// Cause a new version of a registered Service Worker to replace an existing one
|
||||||
// that is already installed, and replace the currently active worker on open pages.
|
// that is already installed, and replace the currently active worker on open pages.
|
||||||
self.addEventListener('install', function(event) {
|
self.addEventListener('install', function (event) {
|
||||||
event.waitUntil(Promise.all([openWebCache(), fetchRoot()]).then(([cache, root]) => cache.put('/', root)));
|
event.waitUntil(Promise.all([openWebCache(), fetchRoot()]).then(([cache, root]) => cache.put('/', root)));
|
||||||
});
|
});
|
||||||
self.addEventListener('activate', function(event) {
|
self.addEventListener('activate', function (event) {
|
||||||
event.waitUntil(self.clients.claim());
|
event.waitUntil(self.clients.claim());
|
||||||
});
|
});
|
||||||
self.addEventListener('fetch', function(event) {
|
self.addEventListener('fetch', function (event) {
|
||||||
const url = new URL(event.request.url);
|
const url = new URL(event.request.url);
|
||||||
|
|
||||||
if (url.pathname === '/auth/sign_out') {
|
if (url.pathname === '/auth/sign_out') {
|
||||||
|
@ -1,17 +1,17 @@
|
|||||||
/* @preval */
|
/* @preval */
|
||||||
|
|
||||||
const fs = require('fs');
|
const fs = require('fs');
|
||||||
const path = require('path');
|
const path = require('path');
|
||||||
|
|
||||||
const filtered = {};
|
const filtered = {};
|
||||||
const filenames = fs.readdirSync(path.resolve(__dirname, '../locales'));
|
const filenames = fs.readdirSync(path.resolve(__dirname, '../locales'));
|
||||||
|
|
||||||
filenames.forEach(filename => {
|
filenames.forEach(filename => {
|
||||||
if (!filename.match(/\.json$/) || filename.match(/defaultMessages|whitelist/)) return;
|
if (!filename.match(/\.json$/) || filename.match(/defaultMessages|whitelist/)) return;
|
||||||
|
|
||||||
const content = fs.readFileSync(path.resolve(__dirname, `../locales/${filename}`), 'utf-8');
|
const content = fs.readFileSync(path.resolve(__dirname, `../locales/${filename}`), 'utf-8');
|
||||||
const full = JSON.parse(content);
|
const full = JSON.parse(content);
|
||||||
const locale = filename.split('.')[0];
|
const locale = filename.split('.')[0];
|
||||||
|
|
||||||
filtered[locale] = {
|
filtered[locale] = {
|
||||||
'notification.favourite': full['notification.favourite'] || '',
|
'notification.favourite': full['notification.favourite'] || '',
|
||||||
|
@ -28,8 +28,8 @@ const notify = options =>
|
|||||||
const group = cloneNotification(notifications[0]);
|
const group = cloneNotification(notifications[0]);
|
||||||
|
|
||||||
group.title = formatMessage('notifications.group', options.data.preferred_locale, { count: group.data.count + 1 });
|
group.title = formatMessage('notifications.group', options.data.preferred_locale, { count: group.data.count + 1 });
|
||||||
group.body = `${options.title}\n${group.body}`;
|
group.body = `${options.title}\n${group.body}`;
|
||||||
group.data = { ...group.data, count: group.data.count + 1 };
|
group.data = { ...group.data, count: group.data.count + 1 };
|
||||||
|
|
||||||
return self.registration.showNotification(group.title, group);
|
return self.registration.showNotification(group.title, group);
|
||||||
}
|
}
|
||||||
@ -62,7 +62,7 @@ const cloneNotification = notification => {
|
|||||||
let k;
|
let k;
|
||||||
|
|
||||||
// Object.assign() does not work with notifications
|
// Object.assign() does not work with notifications
|
||||||
for(k in notification) {
|
for (k in notification) {
|
||||||
clone[k] = notification[k];
|
clone[k] = notification[k];
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -83,24 +83,24 @@ const handlePush = (event) => {
|
|||||||
fetchFromApi(`/api/v1/notifications/${notification_id}`, 'get', access_token).then(notification => {
|
fetchFromApi(`/api/v1/notifications/${notification_id}`, 'get', access_token).then(notification => {
|
||||||
const options = {};
|
const options = {};
|
||||||
|
|
||||||
options.title = formatMessage(`notification.${notification.type}`, preferred_locale, { name: notification.account.display_name.length > 0 ? notification.account.display_name : notification.account.username });
|
options.title = formatMessage(`notification.${notification.type}`, preferred_locale, { name: notification.account.display_name.length > 0 ? notification.account.display_name : notification.account.username });
|
||||||
options.body = notification.status && htmlToPlainText(notification.status.content);
|
options.body = notification.status && htmlToPlainText(notification.status.content);
|
||||||
options.icon = notification.account.avatar_static;
|
options.icon = notification.account.avatar_static;
|
||||||
options.timestamp = notification.created_at && new Date(notification.created_at);
|
options.timestamp = notification.created_at && new Date(notification.created_at);
|
||||||
options.tag = notification.id;
|
options.tag = notification.id;
|
||||||
options.badge = '/badge.png';
|
options.badge = '/badge.png';
|
||||||
options.image = notification.status && notification.status.media_attachments.length > 0 && notification.status.media_attachments[0].preview_url || undefined;
|
options.image = notification.status && notification.status.media_attachments.length > 0 && notification.status.media_attachments[0].preview_url || undefined;
|
||||||
options.data = { access_token, preferred_locale, id: notification.status ? notification.status.id : notification.account.id, url: notification.status ? `/${notification.account.username}/posts/${notification.status.id}` : `/${notification.account.username}` };
|
options.data = { access_token, preferred_locale, id: notification.status ? notification.status.id : notification.account.id, url: notification.status ? `/${notification.account.username}/posts/${notification.status.id}` : `/${notification.account.username}` };
|
||||||
|
|
||||||
if (notification.status && notification.status.spoiler_text || notification.status.sensitive) {
|
if (notification.status && notification.status.spoiler_text || notification.status.sensitive) {
|
||||||
options.data.hiddenBody = htmlToPlainText(notification.status.content);
|
options.data.hiddenBody = htmlToPlainText(notification.status.content);
|
||||||
options.data.hiddenImage = notification.status.media_attachments.length > 0 && notification.status.media_attachments[0].preview_url;
|
options.data.hiddenImage = notification.status.media_attachments.length > 0 && notification.status.media_attachments[0].preview_url;
|
||||||
|
|
||||||
if (notification.status.spoiler_text) {
|
if (notification.status.spoiler_text) {
|
||||||
options.body = notification.status.spoiler_text;
|
options.body = notification.status.spoiler_text;
|
||||||
}
|
}
|
||||||
|
|
||||||
options.image = undefined;
|
options.image = undefined;
|
||||||
options.actions = [actionExpand(preferred_locale)];
|
options.actions = [actionExpand(preferred_locale)];
|
||||||
} else if (notification.type === 'mention') {
|
} else if (notification.type === 'mention') {
|
||||||
options.actions = [actionReblog(preferred_locale), actionFavourite(preferred_locale)];
|
options.actions = [actionReblog(preferred_locale), actionFavourite(preferred_locale)];
|
||||||
@ -149,8 +149,8 @@ const findBestClient = clients => {
|
|||||||
const expandNotification = notification => {
|
const expandNotification = notification => {
|
||||||
const newNotification = cloneNotification(notification);
|
const newNotification = cloneNotification(notification);
|
||||||
|
|
||||||
newNotification.body = newNotification.data.hiddenBody;
|
newNotification.body = newNotification.data.hiddenBody;
|
||||||
newNotification.image = newNotification.data.hiddenImage;
|
newNotification.image = newNotification.data.hiddenImage;
|
||||||
newNotification.actions = [actionReblog(notification.data.preferred_locale), actionFavourite(notification.data.preferred_locale)];
|
newNotification.actions = [actionReblog(notification.data.preferred_locale), actionFavourite(notification.data.preferred_locale)];
|
||||||
|
|
||||||
return self.registration.showNotification(newNotification.title, newNotification);
|
return self.registration.showNotification(newNotification.title, newNotification);
|
||||||
@ -171,7 +171,7 @@ const openUrl = url =>
|
|||||||
const webClients = clientList.filter(client => /\//.test(client.url));
|
const webClients = clientList.filter(client => /\//.test(client.url));
|
||||||
|
|
||||||
if (webClients.length !== 0) {
|
if (webClients.length !== 0) {
|
||||||
const client = findBestClient(webClients);
|
const client = findBestClient(webClients);
|
||||||
const { pathname } = new URL(url, self.location);
|
const { pathname } = new URL(url, self.location);
|
||||||
|
|
||||||
// : TODO :
|
// : TODO :
|
||||||
|
@ -4,7 +4,7 @@ import WebSocketClient from 'websocket.js';
|
|||||||
|
|
||||||
const randomIntUpTo = max => Math.floor(Math.random() * Math.floor(max));
|
const randomIntUpTo = max => Math.floor(Math.random() * Math.floor(max));
|
||||||
|
|
||||||
export function connectStream(path, pollingRefresh = null, callbacks = () => ({ onConnect() {}, onDisconnect() {}, onReceive() {} })) {
|
export function connectStream(path, pollingRefresh = null, callbacks = () => ({ onConnect() { }, onDisconnect() { }, onReceive() { } })) {
|
||||||
return (dispatch, getState) => {
|
return (dispatch, getState) => {
|
||||||
const streamingAPIBaseURL = getState().getIn(['meta', 'streaming_api_base_url']);
|
const streamingAPIBaseURL = getState().getIn(['meta', 'streaming_api_base_url']);
|
||||||
const accessToken = getState().getIn(['meta', 'access_token']);
|
const accessToken = getState().getIn(['meta', 'access_token']);
|
||||||
@ -26,7 +26,7 @@ export function connectStream(path, pollingRefresh = null, callbacks = () => ({
|
|||||||
};
|
};
|
||||||
|
|
||||||
const subscription = getStream(streamingAPIBaseURL, accessToken, path, {
|
const subscription = getStream(streamingAPIBaseURL, accessToken, path, {
|
||||||
connected () {
|
connected() {
|
||||||
if (pollingRefresh) {
|
if (pollingRefresh) {
|
||||||
clearPolling();
|
clearPolling();
|
||||||
}
|
}
|
||||||
@ -34,7 +34,7 @@ export function connectStream(path, pollingRefresh = null, callbacks = () => ({
|
|||||||
onConnect();
|
onConnect();
|
||||||
},
|
},
|
||||||
|
|
||||||
disconnected () {
|
disconnected() {
|
||||||
if (pollingRefresh) {
|
if (pollingRefresh) {
|
||||||
polling = setTimeout(() => setupPolling(), randomIntUpTo(40000));
|
polling = setTimeout(() => setupPolling(), randomIntUpTo(40000));
|
||||||
}
|
}
|
||||||
@ -42,11 +42,11 @@ export function connectStream(path, pollingRefresh = null, callbacks = () => ({
|
|||||||
onDisconnect();
|
onDisconnect();
|
||||||
},
|
},
|
||||||
|
|
||||||
received (data) {
|
received(data) {
|
||||||
onReceive(data);
|
onReceive(data);
|
||||||
},
|
},
|
||||||
|
|
||||||
reconnected () {
|
reconnected() {
|
||||||
if (pollingRefresh) {
|
if (pollingRefresh) {
|
||||||
clearPolling();
|
clearPolling();
|
||||||
pollingRefresh(dispatch);
|
pollingRefresh(dispatch);
|
||||||
@ -71,13 +71,13 @@ export function connectStream(path, pollingRefresh = null, callbacks = () => ({
|
|||||||
|
|
||||||
|
|
||||||
export default function getStream(streamingAPIBaseURL, accessToken, stream, { connected, received, disconnected, reconnected }) {
|
export default function getStream(streamingAPIBaseURL, accessToken, stream, { connected, received, disconnected, reconnected }) {
|
||||||
const params = [ `stream=${stream}` ];
|
const params = [`stream=${stream}`];
|
||||||
|
|
||||||
const ws = new WebSocketClient(`${streamingAPIBaseURL}/api/v1/streaming/?${params.join('&')}`, accessToken);
|
const ws = new WebSocketClient(`${streamingAPIBaseURL}/api/v1/streaming/?${params.join('&')}`, accessToken);
|
||||||
|
|
||||||
ws.onopen = connected;
|
ws.onopen = connected;
|
||||||
ws.onmessage = e => received(JSON.parse(e.data));
|
ws.onmessage = e => received(JSON.parse(e.data));
|
||||||
ws.onclose = disconnected;
|
ws.onclose = disconnected;
|
||||||
ws.onreconnect = reconnected;
|
ws.onreconnect = reconnected;
|
||||||
|
|
||||||
return ws;
|
return ws;
|
||||||
|
@ -6,7 +6,7 @@ export default function compareId(id1, id2) {
|
|||||||
}
|
}
|
||||||
if (id1.length === id2.length) {
|
if (id1.length === id2.length) {
|
||||||
return id1 > id2 ? 1 : -1;
|
return id1 > id2 ? 1 : -1;
|
||||||
} else {
|
|
||||||
return id1.length > id2.length ? 1 : -1;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
return id1.length > id2.length ? 1 : -1;
|
||||||
}
|
}
|
||||||
|
@ -3,7 +3,7 @@ import { FormattedNumber } from 'react-intl';
|
|||||||
export const shortNumberFormat = number => {
|
export const shortNumberFormat = number => {
|
||||||
if (number < 1000) {
|
if (number < 1000) {
|
||||||
return <FormattedNumber value={number} />;
|
return <FormattedNumber value={number} />;
|
||||||
} else {
|
|
||||||
return <span><FormattedNumber value={number / 1000} maximumFractionDigits={1} />K</span>;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
return <span><FormattedNumber value={number / 1000} maximumFractionDigits={1} />K</span>;
|
||||||
};
|
};
|
||||||
|
@ -14,7 +14,7 @@ const getImageUrl = inputFile => new Promise((resolve, reject) => {
|
|||||||
|
|
||||||
const reader = new FileReader();
|
const reader = new FileReader();
|
||||||
reader.onerror = (...args) => reject(...args);
|
reader.onerror = (...args) => reject(...args);
|
||||||
reader.onload = ({ target }) => resolve(target.result);
|
reader.onload = ({ target }) => resolve(target.result);
|
||||||
|
|
||||||
reader.readAsDataURL(inputFile);
|
reader.readAsDataURL(inputFile);
|
||||||
});
|
});
|
||||||
@ -24,7 +24,7 @@ const loadImage = inputFile => new Promise((resolve, reject) => {
|
|||||||
const img = new Image();
|
const img = new Image();
|
||||||
|
|
||||||
img.onerror = (...args) => reject(...args);
|
img.onerror = (...args) => reject(...args);
|
||||||
img.onload = () => resolve(img);
|
img.onload = () => resolve(img);
|
||||||
|
|
||||||
img.src = url;
|
img.src = url;
|
||||||
}).catch(reject);
|
}).catch(reject);
|
||||||
@ -43,26 +43,26 @@ const getOrientation = (img, type = 'image/png') => new Promise(resolve => {
|
|||||||
});
|
});
|
||||||
|
|
||||||
const processImage = (img, { width, height, orientation, type = 'image/png' }) => new Promise(resolve => {
|
const processImage = (img, { width, height, orientation, type = 'image/png' }) => new Promise(resolve => {
|
||||||
const canvas = document.createElement('canvas');
|
const canvas = document.createElement('canvas');
|
||||||
|
|
||||||
if (4 < orientation && orientation < 9) {
|
if (4 < orientation && orientation < 9) {
|
||||||
canvas.width = height;
|
canvas.width = height;
|
||||||
canvas.height = width;
|
canvas.height = width;
|
||||||
} else {
|
} else {
|
||||||
canvas.width = width;
|
canvas.width = width;
|
||||||
canvas.height = height;
|
canvas.height = height;
|
||||||
}
|
}
|
||||||
|
|
||||||
const context = canvas.getContext('2d');
|
const context = canvas.getContext('2d');
|
||||||
|
|
||||||
switch (orientation) {
|
switch (orientation) {
|
||||||
case 2: context.transform(-1, 0, 0, 1, width, 0); break;
|
case 2: context.transform(-1, 0, 0, 1, width, 0); break;
|
||||||
case 3: context.transform(-1, 0, 0, -1, width, height); break;
|
case 3: context.transform(-1, 0, 0, -1, width, height); break;
|
||||||
case 4: context.transform(1, 0, 0, -1, 0, height); break;
|
case 4: context.transform(1, 0, 0, -1, 0, height); break;
|
||||||
case 5: context.transform(0, 1, 1, 0, 0, 0); break;
|
case 5: context.transform(0, 1, 1, 0, 0, 0); break;
|
||||||
case 6: context.transform(0, 1, -1, 0, height, 0); break;
|
case 6: context.transform(0, 1, -1, 0, height, 0); break;
|
||||||
case 7: context.transform(0, -1, -1, 0, height, width); break;
|
case 7: context.transform(0, -1, -1, 0, height, width); break;
|
||||||
case 8: context.transform(0, -1, 1, 0, 0, width); break;
|
case 8: context.transform(0, -1, 1, 0, 0, width); break;
|
||||||
}
|
}
|
||||||
|
|
||||||
context.drawImage(img, 0, 0, width, height);
|
context.drawImage(img, 0, 0, width, height);
|
||||||
@ -73,7 +73,7 @@ const processImage = (img, { width, height, orientation, type = 'image/png' }) =
|
|||||||
const resizeImage = (img, type = 'image/png') => new Promise((resolve, reject) => {
|
const resizeImage = (img, type = 'image/png') => new Promise((resolve, reject) => {
|
||||||
const { width, height } = img;
|
const { width, height } = img;
|
||||||
|
|
||||||
const newWidth = Math.round(Math.sqrt(MAX_IMAGE_PIXELS * (width / height)));
|
const newWidth = Math.round(Math.sqrt(MAX_IMAGE_PIXELS * (width / height)));
|
||||||
const newHeight = Math.round(Math.sqrt(MAX_IMAGE_PIXELS * (height / width)));
|
const newHeight = Math.round(Math.sqrt(MAX_IMAGE_PIXELS * (height / width)));
|
||||||
|
|
||||||
getOrientation(img, type)
|
getOrientation(img, type)
|
||||||
|
@ -1,45 +0,0 @@
|
|||||||
.footer-bar {
|
|
||||||
display: block;
|
|
||||||
position: fixed;
|
|
||||||
background: #000;
|
|
||||||
height: 58px;
|
|
||||||
bottom: 0;
|
|
||||||
left: 0;
|
|
||||||
right: 0;
|
|
||||||
z-index: 1000;
|
|
||||||
transition: transform 0.2s ease;
|
|
||||||
overflow: hidden;
|
|
||||||
padding-bottom: 0;
|
|
||||||
padding-bottom: env(safe-area-inset-bottom);
|
|
||||||
|
|
||||||
@media screen and (min-width: 895px) {
|
|
||||||
display: none !important;
|
|
||||||
}
|
|
||||||
|
|
||||||
&__container {
|
|
||||||
display: flex;
|
|
||||||
flex-direction: row;
|
|
||||||
align-items: stretch;
|
|
||||||
}
|
|
||||||
|
|
||||||
&__link {
|
|
||||||
display: flex;
|
|
||||||
flex: 1 1 auto;
|
|
||||||
margin: 0;
|
|
||||||
min-width: 36px;
|
|
||||||
height: 58px;
|
|
||||||
padding-top: 4px;
|
|
||||||
justify-content: center;
|
|
||||||
color: white;
|
|
||||||
text-decoration: none;
|
|
||||||
border-top: 2px solid transparent;
|
|
||||||
|
|
||||||
&.active {
|
|
||||||
border-top-color: $gab-brand-default;
|
|
||||||
}
|
|
||||||
|
|
||||||
& > span {
|
|
||||||
display: none;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,174 +0,0 @@
|
|||||||
.sidebar-menu {
|
|
||||||
display: flex;
|
|
||||||
position: fixed;
|
|
||||||
flex-direction: column;
|
|
||||||
width: 275px;
|
|
||||||
height: 100vh;
|
|
||||||
top: 0;
|
|
||||||
bottom: 0;
|
|
||||||
left: 0;
|
|
||||||
background: $gab-background-container;
|
|
||||||
transform: translateX(-275px);
|
|
||||||
transition: all 0.15s linear;
|
|
||||||
z-index: 10001;
|
|
||||||
|
|
||||||
body.theme-gabsocial-light & {
|
|
||||||
background: $gab-background-container-light;
|
|
||||||
}
|
|
||||||
|
|
||||||
&__root {
|
|
||||||
display: none;
|
|
||||||
}
|
|
||||||
|
|
||||||
&__wrapper {
|
|
||||||
display: block;
|
|
||||||
position: fixed;
|
|
||||||
top: 0;
|
|
||||||
left: 0;
|
|
||||||
right: 0;
|
|
||||||
bottom: 0;
|
|
||||||
z-index: 10000;
|
|
||||||
background-color: transparent;
|
|
||||||
transition: background-color 0.2s linear;
|
|
||||||
transition-delay: 0.1s;
|
|
||||||
}
|
|
||||||
|
|
||||||
&__content {
|
|
||||||
display: flex;
|
|
||||||
flex: 1 1;
|
|
||||||
flex-direction: column;
|
|
||||||
padding-bottom: 40px;
|
|
||||||
overflow: hidden;
|
|
||||||
overflow-y: scroll;
|
|
||||||
-webkit-overflow-scrolling: touch;
|
|
||||||
}
|
|
||||||
|
|
||||||
&__section {
|
|
||||||
display: block;
|
|
||||||
margin: 4px 0;
|
|
||||||
border-top: 1px solid lighten($ui-base-color, 4%);
|
|
||||||
|
|
||||||
&--borderless {
|
|
||||||
margin: 0;
|
|
||||||
border-top: none;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@media (max-width: 400px) {
|
|
||||||
width: 90vw;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
.sidebar-menu__root--visible {
|
|
||||||
display: block;
|
|
||||||
|
|
||||||
.sidebar-menu {
|
|
||||||
transform: translateX(0);
|
|
||||||
}
|
|
||||||
|
|
||||||
.sidebar-menu__wrapper {
|
|
||||||
background-color: rgba(0,0,0,0.3);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
.sidebar-menu-header {
|
|
||||||
display: flex;
|
|
||||||
height: 46px;
|
|
||||||
padding: 12px 14px;
|
|
||||||
border-bottom: 1px solid lighten($ui-base-color, 4%);
|
|
||||||
box-sizing: border-box;
|
|
||||||
align-items: center;
|
|
||||||
|
|
||||||
&__title {
|
|
||||||
display: block;
|
|
||||||
font-size: 18px;
|
|
||||||
font-weight: 600;
|
|
||||||
color: $primary-text-color;
|
|
||||||
}
|
|
||||||
|
|
||||||
&__btn {
|
|
||||||
margin-left: auto;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
.sidebar-menu-profile {
|
|
||||||
display: block;
|
|
||||||
padding: 14px 18px;
|
|
||||||
|
|
||||||
&__avatar {
|
|
||||||
display: block;
|
|
||||||
width: 56px;
|
|
||||||
height: 56px;
|
|
||||||
}
|
|
||||||
|
|
||||||
&__name {
|
|
||||||
display: block;
|
|
||||||
margin-top: 10px;
|
|
||||||
|
|
||||||
.display-name__account {
|
|
||||||
display: block;
|
|
||||||
margin-top: 2px;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
&__stats {
|
|
||||||
display: flex;
|
|
||||||
margin-top: 12px;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
.sidebar-menu-profile-stat {
|
|
||||||
display: flex;
|
|
||||||
font-size: 14px;
|
|
||||||
text-decoration: none;
|
|
||||||
|
|
||||||
&:not(:first-of-type) {
|
|
||||||
margin-left: 18px;
|
|
||||||
}
|
|
||||||
|
|
||||||
&__value {
|
|
||||||
display: flex;
|
|
||||||
margin-right: 3px;
|
|
||||||
font-weight: 700;
|
|
||||||
color: $primary-text-color;
|
|
||||||
}
|
|
||||||
|
|
||||||
&__label {
|
|
||||||
display: flex;
|
|
||||||
color: $primary-text-color;
|
|
||||||
}
|
|
||||||
|
|
||||||
&:hover {
|
|
||||||
text-decoration: underline;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
.sidebar-menu-item {
|
|
||||||
display: flex;
|
|
||||||
padding: 16px 18px;
|
|
||||||
cursor: pointer;
|
|
||||||
text-decoration: none;
|
|
||||||
color: $primary-text-color;
|
|
||||||
font-size: 15px;
|
|
||||||
font-weight: 400;
|
|
||||||
height: 50px;
|
|
||||||
box-sizing: border-box;
|
|
||||||
|
|
||||||
&:hover {
|
|
||||||
background-color: rgba($gab-brand-default, 0.1);
|
|
||||||
|
|
||||||
.fa {
|
|
||||||
color: $primary-text-color;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
.fa {
|
|
||||||
margin-right: 10px;
|
|
||||||
}
|
|
||||||
|
|
||||||
&:hover {
|
|
||||||
&__title {
|
|
||||||
color: $primary-text-color;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
Loading…
x
Reference in New Issue
Block a user