confirm modal + lint
This commit is contained in:
parent
1ee18a7fa3
commit
0eb652f95f
41 changed files with 182 additions and 131 deletions
|
|
@ -63,7 +63,8 @@ export default {
|
||||||
() => import('./components/edit_status_modal/edit_status_modal.vue'),
|
() => import('./components/edit_status_modal/edit_status_modal.vue'),
|
||||||
),
|
),
|
||||||
StatusHistoryModal: defineAsyncComponent(
|
StatusHistoryModal: defineAsyncComponent(
|
||||||
() => import( './components/status_history_modal/status_history_modal.vue'),
|
() =>
|
||||||
|
import('./components/status_history_modal/status_history_modal.vue'),
|
||||||
),
|
),
|
||||||
GlobalNoticeList,
|
GlobalNoticeList,
|
||||||
},
|
},
|
||||||
|
|
|
||||||
|
|
@ -1,16 +1,16 @@
|
||||||
|
import { defineAsyncComponent } from 'vue'
|
||||||
|
|
||||||
import BookmarkTimeline from 'src/components/bookmark_timeline/bookmark_timeline.vue'
|
import BookmarkTimeline from 'src/components/bookmark_timeline/bookmark_timeline.vue'
|
||||||
import BubbleTimeline from 'src/components/bubble_timeline/bubble_timeline.vue'
|
import BubbleTimeline from 'src/components/bubble_timeline/bubble_timeline.vue'
|
||||||
import ConversationPage from 'src/components/conversation-page/conversation-page.vue'
|
import ConversationPage from 'src/components/conversation-page/conversation-page.vue'
|
||||||
import DMs from 'src/components/dm_timeline/dm_timeline.vue'
|
import DMs from 'src/components/dm_timeline/dm_timeline.vue'
|
||||||
import FriendsTimeline from 'src/components/friends_timeline/friends_timeline.vue'
|
import FriendsTimeline from 'src/components/friends_timeline/friends_timeline.vue'
|
||||||
|
import NavPanel from 'src/components/nav_panel/nav_panel.vue'
|
||||||
import PublicAndExternalTimeline from 'src/components/public_and_external_timeline/public_and_external_timeline.vue'
|
import PublicAndExternalTimeline from 'src/components/public_and_external_timeline/public_and_external_timeline.vue'
|
||||||
import PublicTimeline from 'src/components/public_timeline/public_timeline.vue'
|
import PublicTimeline from 'src/components/public_timeline/public_timeline.vue'
|
||||||
|
import QuotesTimeline from 'src/components/quotes_timeline/quotes_timeline.vue'
|
||||||
import RemoteUserResolver from 'src/components/remote_user_resolver/remote_user_resolver.vue'
|
import RemoteUserResolver from 'src/components/remote_user_resolver/remote_user_resolver.vue'
|
||||||
import TagTimeline from 'src/components/tag_timeline/tag_timeline.vue'
|
import TagTimeline from 'src/components/tag_timeline/tag_timeline.vue'
|
||||||
import { defineAsyncComponent } from 'vue'
|
|
||||||
|
|
||||||
import NavPanel from 'src/components/nav_panel/nav_panel.vue'
|
|
||||||
import QuotesTimeline from 'src/components/quotes_timeline/quotes_timeline.vue'
|
|
||||||
|
|
||||||
import { useInstanceStore } from 'src/stores/instance.js'
|
import { useInstanceStore } from 'src/stores/instance.js'
|
||||||
import { useInstanceCapabilitiesStore } from 'src/stores/instance_capabilities.js'
|
import { useInstanceCapabilitiesStore } from 'src/stores/instance_capabilities.js'
|
||||||
|
|
@ -187,7 +187,8 @@ export default (store) => {
|
||||||
name: 'announcements',
|
name: 'announcements',
|
||||||
path: '/announcements',
|
path: '/announcements',
|
||||||
component: defineAsyncComponent(
|
component: defineAsyncComponent(
|
||||||
() => import( 'src/components/announcements_page/announcements_page.vue'),
|
() =>
|
||||||
|
import('src/components/announcements_page/announcements_page.vue'),
|
||||||
),
|
),
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
|
|
@ -257,7 +258,10 @@ export default (store) => {
|
||||||
name: 'bookmark-folder-new',
|
name: 'bookmark-folder-new',
|
||||||
path: '/bookmarks/new-folder',
|
path: '/bookmarks/new-folder',
|
||||||
component: defineAsyncComponent(
|
component: defineAsyncComponent(
|
||||||
() => import( 'src/components/bookmark_folder_edit/bookmark_folder_edit.vue'),
|
() =>
|
||||||
|
import(
|
||||||
|
'src/components/bookmark_folder_edit/bookmark_folder_edit.vue'
|
||||||
|
),
|
||||||
),
|
),
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
|
|
@ -269,7 +273,10 @@ export default (store) => {
|
||||||
name: 'bookmark-folder-edit',
|
name: 'bookmark-folder-edit',
|
||||||
path: '/bookmarks/:id/edit',
|
path: '/bookmarks/:id/edit',
|
||||||
component: defineAsyncComponent(
|
component: defineAsyncComponent(
|
||||||
() => import( 'src/components/bookmark_folder_edit/bookmark_folder_edit.vue'),
|
() =>
|
||||||
|
import(
|
||||||
|
'src/components/bookmark_folder_edit/bookmark_folder_edit.vue'
|
||||||
|
),
|
||||||
),
|
),
|
||||||
},
|
},
|
||||||
]
|
]
|
||||||
|
|
|
||||||
|
|
@ -1,8 +1,8 @@
|
||||||
import { mapState } from 'pinia'
|
import { mapState } from 'pinia'
|
||||||
|
import { defineAsyncComponent } from 'vue'
|
||||||
|
|
||||||
import UserListMenu from 'src/components/user_list_menu/user_list_menu.vue'
|
import UserListMenu from 'src/components/user_list_menu/user_list_menu.vue'
|
||||||
import UserTimedFilterModal from 'src/components/user_timed_filter_modal/user_timed_filter_modal.vue'
|
import UserTimedFilterModal from 'src/components/user_timed_filter_modal/user_timed_filter_modal.vue'
|
||||||
import ConfirmModal from '../confirm_modal/confirm_modal.vue'
|
|
||||||
import Popover from '../popover/popover.vue'
|
import Popover from '../popover/popover.vue'
|
||||||
import ProgressButton from '../progress_button/progress_button.vue'
|
import ProgressButton from '../progress_button/progress_button.vue'
|
||||||
|
|
||||||
|
|
@ -27,7 +27,10 @@ const AccountActions = {
|
||||||
ProgressButton,
|
ProgressButton,
|
||||||
Popover,
|
Popover,
|
||||||
UserListMenu,
|
UserListMenu,
|
||||||
ConfirmModal,
|
ConfirmModal: defineAsyncComponent(
|
||||||
|
() => import('src/components/confirm_modal/confirm_modal.vue'),
|
||||||
|
),
|
||||||
|
|
||||||
UserTimedFilterModal,
|
UserTimedFilterModal,
|
||||||
},
|
},
|
||||||
methods: {
|
methods: {
|
||||||
|
|
|
||||||
|
|
@ -94,7 +94,7 @@
|
||||||
</template>
|
</template>
|
||||||
</Popover>
|
</Popover>
|
||||||
<teleport to="#modal">
|
<teleport to="#modal">
|
||||||
<confirm-modal
|
<ConfirmModal
|
||||||
v-if="showingConfirmBlock && !blockExpiration"
|
v-if="showingConfirmBlock && !blockExpiration"
|
||||||
ref="blockDialog"
|
ref="blockDialog"
|
||||||
:title="$t('user_card.block_confirm_title')"
|
:title="$t('user_card.block_confirm_title')"
|
||||||
|
|
@ -114,10 +114,10 @@
|
||||||
/>
|
/>
|
||||||
</template>
|
</template>
|
||||||
</i18n-t>
|
</i18n-t>
|
||||||
</confirm-modal>
|
</ConfirmModal>
|
||||||
</teleport>
|
</teleport>
|
||||||
<teleport to="#modal">
|
<teleport to="#modal">
|
||||||
<confirm-modal
|
<ConfirmModal
|
||||||
v-if="showingConfirmRemoveFollower"
|
v-if="showingConfirmRemoveFollower"
|
||||||
:title="$t('user_card.remove_follower_confirm_title')"
|
:title="$t('user_card.remove_follower_confirm_title')"
|
||||||
:confirm-text="$t('user_card.remove_follower_confirm_accept_button')"
|
:confirm-text="$t('user_card.remove_follower_confirm_accept_button')"
|
||||||
|
|
@ -136,7 +136,7 @@
|
||||||
/>
|
/>
|
||||||
</template>
|
</template>
|
||||||
</i18n-t>
|
</i18n-t>
|
||||||
</confirm-modal>
|
</ConfirmModal>
|
||||||
<UserTimedFilterModal
|
<UserTimedFilterModal
|
||||||
v-if="blockExpiration"
|
v-if="blockExpiration"
|
||||||
ref="timedBlockDialog"
|
ref="timedBlockDialog"
|
||||||
|
|
|
||||||
|
|
@ -69,9 +69,7 @@ const Attachment = {
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
components: {
|
components: {
|
||||||
Flash: defineAsyncComponent(
|
Flash: defineAsyncComponent(() => import('src/components/flash/flash.vue')),
|
||||||
() => import( 'src/components/flash/flash.vue'),
|
|
||||||
),
|
|
||||||
StillImage,
|
StillImage,
|
||||||
VideoAttachment: defineAsyncComponent(
|
VideoAttachment: defineAsyncComponent(
|
||||||
() => import('src/components/video_attachment/video_attachment.vue'),
|
() => import('src/components/video_attachment/video_attachment.vue'),
|
||||||
|
|
|
||||||
|
|
@ -1,7 +1,7 @@
|
||||||
import { mapState } from 'pinia'
|
import { mapState } from 'pinia'
|
||||||
|
import { defineAsyncComponent } from 'vue'
|
||||||
|
|
||||||
import Select from 'src/components/select/select.vue'
|
import Select from 'src/components/select/select.vue'
|
||||||
import ConfirmModal from './confirm_modal.vue'
|
|
||||||
|
|
||||||
import { useMergedConfigStore } from 'src/stores/merged_config.js'
|
import { useMergedConfigStore } from 'src/stores/merged_config.js'
|
||||||
|
|
||||||
|
|
@ -12,7 +12,10 @@ export default {
|
||||||
showing: false,
|
showing: false,
|
||||||
}),
|
}),
|
||||||
components: {
|
components: {
|
||||||
ConfirmModal,
|
ConfirmModal: defineAsyncComponent(
|
||||||
|
() => import('src/components/confirm_modal/confirm_modal.vue'),
|
||||||
|
),
|
||||||
|
|
||||||
Select,
|
Select,
|
||||||
},
|
},
|
||||||
computed: {
|
computed: {
|
||||||
|
|
|
||||||
|
|
@ -1,5 +1,5 @@
|
||||||
<template>
|
<template>
|
||||||
<confirm-modal
|
<ConfirmModal
|
||||||
v-if="showing"
|
v-if="showing"
|
||||||
:title="$t('user_card.mute_confirm_title')"
|
:title="$t('user_card.mute_confirm_title')"
|
||||||
:confirm-text="$t('user_card.mute_confirm_accept_button')"
|
:confirm-text="$t('user_card.mute_confirm_accept_button')"
|
||||||
|
|
@ -18,7 +18,7 @@
|
||||||
<span v-text="user.screen_name_ui" />
|
<span v-text="user.screen_name_ui" />
|
||||||
</template>
|
</template>
|
||||||
</i18n-t>
|
</i18n-t>
|
||||||
</confirm-modal>
|
</ConfirmModal>
|
||||||
</template>
|
</template>
|
||||||
|
|
||||||
<script src="./mute_confirm.js" />
|
<script src="./mute_confirm.js" />
|
||||||
|
|
|
||||||
|
|
@ -1,7 +1,6 @@
|
||||||
import SearchBar from 'components/search_bar/search_bar.vue'
|
import SearchBar from 'components/search_bar/search_bar.vue'
|
||||||
import { mapActions, mapState } from 'pinia'
|
import { mapActions, mapState } from 'pinia'
|
||||||
|
import { defineAsyncComponent } from 'vue'
|
||||||
import ConfirmModal from '../confirm_modal/confirm_modal.vue'
|
|
||||||
|
|
||||||
import { useInstanceStore } from 'src/stores/instance.js'
|
import { useInstanceStore } from 'src/stores/instance.js'
|
||||||
import { useInterfaceStore } from 'src/stores/interface'
|
import { useInterfaceStore } from 'src/stores/interface'
|
||||||
|
|
@ -39,7 +38,9 @@ library.add(
|
||||||
export default {
|
export default {
|
||||||
components: {
|
components: {
|
||||||
SearchBar,
|
SearchBar,
|
||||||
ConfirmModal,
|
ConfirmModal: defineAsyncComponent(
|
||||||
|
() => import('src/components/confirm_modal/confirm_modal.vue'),
|
||||||
|
),
|
||||||
},
|
},
|
||||||
data: () => ({
|
data: () => ({
|
||||||
searchBarHidden: true,
|
searchBarHidden: true,
|
||||||
|
|
|
||||||
|
|
@ -79,7 +79,7 @@
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<teleport to="#modal">
|
<teleport to="#modal">
|
||||||
<confirm-modal
|
<ConfirmModal
|
||||||
v-if="showingConfirmLogout"
|
v-if="showingConfirmLogout"
|
||||||
:title="$t('login.logout_confirm_title')"
|
:title="$t('login.logout_confirm_title')"
|
||||||
:confirm-danger="true"
|
:confirm-danger="true"
|
||||||
|
|
@ -89,7 +89,7 @@
|
||||||
@cancelled="hideConfirmLogout"
|
@cancelled="hideConfirmLogout"
|
||||||
>
|
>
|
||||||
{{ $t('login.logout_confirm') }}
|
{{ $t('login.logout_confirm') }}
|
||||||
</confirm-modal>
|
</ConfirmModal>
|
||||||
</teleport>
|
</teleport>
|
||||||
</nav>
|
</nav>
|
||||||
</template>
|
</template>
|
||||||
|
|
|
||||||
|
|
@ -1,7 +1,6 @@
|
||||||
import { cloneDeep } from 'lodash'
|
import { cloneDeep } from 'lodash'
|
||||||
import { defineAsyncComponent } from 'vue'
|
import { defineAsyncComponent } from 'vue'
|
||||||
|
|
||||||
import ConfirmModal from 'src/components/confirm_modal/confirm_modal.vue'
|
|
||||||
import Gallery from 'src/components/gallery/gallery.vue'
|
import Gallery from 'src/components/gallery/gallery.vue'
|
||||||
import StatusContent from 'src/components/status_content/status_content.vue'
|
import StatusContent from 'src/components/status_content/status_content.vue'
|
||||||
|
|
||||||
|
|
@ -20,7 +19,10 @@ const Draft = {
|
||||||
EditStatusForm: defineAsyncComponent(
|
EditStatusForm: defineAsyncComponent(
|
||||||
() => import('src/components/edit_status_form/edit_status_form.vue'),
|
() => import('src/components/edit_status_form/edit_status_form.vue'),
|
||||||
),
|
),
|
||||||
ConfirmModal,
|
ConfirmModal: defineAsyncComponent(
|
||||||
|
() => import('src/components/confirm_modal/confirm_modal.vue'),
|
||||||
|
),
|
||||||
|
|
||||||
StatusContent,
|
StatusContent,
|
||||||
Gallery,
|
Gallery,
|
||||||
},
|
},
|
||||||
|
|
|
||||||
|
|
@ -77,7 +77,7 @@
|
||||||
/>
|
/>
|
||||||
</div>
|
</div>
|
||||||
<teleport to="#modal">
|
<teleport to="#modal">
|
||||||
<confirm-modal
|
<ConfirmModal
|
||||||
v-if="showingConfirmDialog"
|
v-if="showingConfirmDialog"
|
||||||
:title="$t('drafts.abandon_confirm_title')"
|
:title="$t('drafts.abandon_confirm_title')"
|
||||||
:confirm-text="$t('drafts.abandon_confirm_accept_button')"
|
:confirm-text="$t('drafts.abandon_confirm_accept_button')"
|
||||||
|
|
@ -86,7 +86,7 @@
|
||||||
@cancelled="hideConfirmDialog"
|
@cancelled="hideConfirmDialog"
|
||||||
>
|
>
|
||||||
{{ $t('drafts.abandon_confirm') }}
|
{{ $t('drafts.abandon_confirm') }}
|
||||||
</confirm-modal>
|
</ConfirmModal>
|
||||||
</teleport>
|
</teleport>
|
||||||
<div class="actions">
|
<div class="actions">
|
||||||
<button
|
<button
|
||||||
|
|
|
||||||
|
|
@ -1,4 +1,5 @@
|
||||||
import ConfirmModal from 'src/components/confirm_modal/confirm_modal.vue'
|
import { defineAsyncComponent } from 'vue'
|
||||||
|
|
||||||
import Draft from 'src/components/draft/draft.vue'
|
import Draft from 'src/components/draft/draft.vue'
|
||||||
import List from 'src/components/list/list.vue'
|
import List from 'src/components/list/list.vue'
|
||||||
|
|
||||||
|
|
@ -6,7 +7,9 @@ const Drafts = {
|
||||||
components: {
|
components: {
|
||||||
Draft,
|
Draft,
|
||||||
List,
|
List,
|
||||||
ConfirmModal,
|
ConfirmModal: defineAsyncComponent(
|
||||||
|
() => import('src/components/confirm_modal/confirm_modal.vue'),
|
||||||
|
),
|
||||||
},
|
},
|
||||||
data() {
|
data() {
|
||||||
return {
|
return {
|
||||||
|
|
|
||||||
|
|
@ -1,14 +1,17 @@
|
||||||
|
import { defineAsyncComponent } from 'vue'
|
||||||
|
|
||||||
import {
|
import {
|
||||||
requestFollow,
|
requestFollow,
|
||||||
requestUnfollow,
|
requestUnfollow,
|
||||||
} from '../../services/follow_manipulate/follow_manipulate'
|
} from '../../services/follow_manipulate/follow_manipulate'
|
||||||
import ConfirmModal from '../confirm_modal/confirm_modal.vue'
|
|
||||||
|
|
||||||
import { useMergedConfigStore } from 'src/stores/merged_config.js'
|
import { useMergedConfigStore } from 'src/stores/merged_config.js'
|
||||||
export default {
|
export default {
|
||||||
props: ['relationship', 'user', 'labelFollowing', 'buttonClass'],
|
props: ['relationship', 'user', 'labelFollowing', 'buttonClass'],
|
||||||
components: {
|
components: {
|
||||||
ConfirmModal,
|
ConfirmModal: defineAsyncComponent(
|
||||||
|
() => import('src/components/confirm_modal/confirm_modal.vue'),
|
||||||
|
),
|
||||||
},
|
},
|
||||||
data() {
|
data() {
|
||||||
return {
|
return {
|
||||||
|
|
|
||||||
|
|
@ -8,7 +8,7 @@
|
||||||
>
|
>
|
||||||
{{ label }}
|
{{ label }}
|
||||||
<teleport to="#modal">
|
<teleport to="#modal">
|
||||||
<confirm-modal
|
<ConfirmModal
|
||||||
v-if="showingConfirmUnfollow"
|
v-if="showingConfirmUnfollow"
|
||||||
:title="$t('user_card.unfollow_confirm_title')"
|
:title="$t('user_card.unfollow_confirm_title')"
|
||||||
:confirm-text="$t('user_card.unfollow_confirm_accept_button')"
|
:confirm-text="$t('user_card.unfollow_confirm_accept_button')"
|
||||||
|
|
@ -27,7 +27,7 @@
|
||||||
/>
|
/>
|
||||||
</template>
|
</template>
|
||||||
</i18n-t>
|
</i18n-t>
|
||||||
</confirm-modal>
|
</ConfirmModal>
|
||||||
</teleport>
|
</teleport>
|
||||||
</button>
|
</button>
|
||||||
</template>
|
</template>
|
||||||
|
|
|
||||||
|
|
@ -1,6 +1,7 @@
|
||||||
|
import { defineAsyncComponent } from 'vue'
|
||||||
|
|
||||||
import { notificationsFromStore } from '../../services/notification_utils/notification_utils.js'
|
import { notificationsFromStore } from '../../services/notification_utils/notification_utils.js'
|
||||||
import BasicUserCard from '../basic_user_card/basic_user_card.vue'
|
import BasicUserCard from '../basic_user_card/basic_user_card.vue'
|
||||||
import ConfirmModal from '../confirm_modal/confirm_modal.vue'
|
|
||||||
|
|
||||||
import { useMergedConfigStore } from 'src/stores/merged_config.js'
|
import { useMergedConfigStore } from 'src/stores/merged_config.js'
|
||||||
|
|
||||||
|
|
@ -8,7 +9,9 @@ const FollowRequestCard = {
|
||||||
props: ['user'],
|
props: ['user'],
|
||||||
components: {
|
components: {
|
||||||
BasicUserCard,
|
BasicUserCard,
|
||||||
ConfirmModal,
|
ConfirmModal: defineAsyncComponent(
|
||||||
|
() => import('src/components/confirm_modal/confirm_modal.vue'),
|
||||||
|
),
|
||||||
},
|
},
|
||||||
data() {
|
data() {
|
||||||
return {
|
return {
|
||||||
|
|
|
||||||
|
|
@ -15,7 +15,7 @@
|
||||||
</button>
|
</button>
|
||||||
</div>
|
</div>
|
||||||
<teleport to="#modal">
|
<teleport to="#modal">
|
||||||
<confirm-modal
|
<ConfirmModal
|
||||||
v-if="showingApproveConfirmDialog"
|
v-if="showingApproveConfirmDialog"
|
||||||
:title="$t('user_card.approve_confirm_title')"
|
:title="$t('user_card.approve_confirm_title')"
|
||||||
:confirm-text="$t('user_card.approve_confirm_accept_button')"
|
:confirm-text="$t('user_card.approve_confirm_accept_button')"
|
||||||
|
|
@ -24,8 +24,8 @@
|
||||||
@cancelled="hideApproveConfirmDialog"
|
@cancelled="hideApproveConfirmDialog"
|
||||||
>
|
>
|
||||||
{{ $t('user_card.approve_confirm', { user: user.screen_name_ui }) }}
|
{{ $t('user_card.approve_confirm', { user: user.screen_name_ui }) }}
|
||||||
</confirm-modal>
|
</ConfirmModal>
|
||||||
<confirm-modal
|
<ConfirmModal
|
||||||
v-if="showingDenyConfirmDialog"
|
v-if="showingDenyConfirmDialog"
|
||||||
:title="$t('user_card.deny_confirm_title')"
|
:title="$t('user_card.deny_confirm_title')"
|
||||||
:confirm-text="$t('user_card.deny_confirm_accept_button')"
|
:confirm-text="$t('user_card.deny_confirm_accept_button')"
|
||||||
|
|
@ -34,7 +34,7 @@
|
||||||
@cancelled="hideDenyConfirmDialog"
|
@cancelled="hideDenyConfirmDialog"
|
||||||
>
|
>
|
||||||
{{ $t('user_card.deny_confirm', { user: user.screen_name_ui }) }}
|
{{ $t('user_card.deny_confirm', { user: user.screen_name_ui }) }}
|
||||||
</confirm-modal>
|
</ConfirmModal>
|
||||||
</teleport>
|
</teleport>
|
||||||
</basic-user-card>
|
</basic-user-card>
|
||||||
</template>
|
</template>
|
||||||
|
|
|
||||||
|
|
@ -1,10 +1,10 @@
|
||||||
import GestureService from '../../services/gesture_service/gesture_service'
|
|
||||||
|
|
||||||
import { useMediaViewerStore } from 'src/stores/media_viewer.js'
|
|
||||||
import { defineAsyncComponent } from 'vue'
|
import { defineAsyncComponent } from 'vue'
|
||||||
|
|
||||||
import Modal from 'src/components/modal/modal.vue'
|
import Modal from 'src/components/modal/modal.vue'
|
||||||
import StillImage from 'src/components/still-image/still-image.vue'
|
import StillImage from 'src/components/still-image/still-image.vue'
|
||||||
|
import GestureService from '../../services/gesture_service/gesture_service'
|
||||||
|
|
||||||
|
import { useMediaViewerStore } from 'src/stores/media_viewer.js'
|
||||||
|
|
||||||
import { library } from '@fortawesome/fontawesome-svg-core'
|
import { library } from '@fortawesome/fontawesome-svg-core'
|
||||||
import {
|
import {
|
||||||
|
|
@ -29,9 +29,7 @@ const MediaModal = {
|
||||||
() => import('src/components/swipe_click/swipe_click.vue'),
|
() => import('src/components/swipe_click/swipe_click.vue'),
|
||||||
),
|
),
|
||||||
Modal,
|
Modal,
|
||||||
Flash: defineAsyncComponent(
|
Flash: defineAsyncComponent(() => import('src/components/flash/flash.vue')),
|
||||||
() => import( 'src/components/flash/flash.vue'),
|
|
||||||
),
|
|
||||||
},
|
},
|
||||||
data() {
|
data() {
|
||||||
return {
|
return {
|
||||||
|
|
|
||||||
|
|
@ -2,7 +2,6 @@ import { mapState } from 'pinia'
|
||||||
import { defineAsyncComponent } from 'vue'
|
import { defineAsyncComponent } from 'vue'
|
||||||
import { mapGetters } from 'vuex'
|
import { mapGetters } from 'vuex'
|
||||||
|
|
||||||
import ConfirmModal from 'src/components/confirm_modal/confirm_modal.vue'
|
|
||||||
import NavigationPins from 'src/components/navigation/navigation_pins.vue'
|
import NavigationPins from 'src/components/navigation/navigation_pins.vue'
|
||||||
import SideDrawer from 'src/components/side_drawer/side_drawer.vue'
|
import SideDrawer from 'src/components/side_drawer/side_drawer.vue'
|
||||||
import GestureService from '../../services/gesture_service/gesture_service'
|
import GestureService from '../../services/gesture_service/gesture_service'
|
||||||
|
|
@ -34,7 +33,9 @@ const MobileNav = {
|
||||||
() => import('src/components/notifications/notifications.vue'),
|
() => import('src/components/notifications/notifications.vue'),
|
||||||
),
|
),
|
||||||
NavigationPins,
|
NavigationPins,
|
||||||
ConfirmModal,
|
ConfirmModal: defineAsyncComponent(
|
||||||
|
() => import('src/components/confirm_modal/confirm_modal.vue'),
|
||||||
|
),
|
||||||
},
|
},
|
||||||
data: () => ({
|
data: () => ({
|
||||||
notificationsCloseGesture: undefined,
|
notificationsCloseGesture: undefined,
|
||||||
|
|
|
||||||
|
|
@ -106,7 +106,7 @@
|
||||||
:logout="logout"
|
:logout="logout"
|
||||||
/>
|
/>
|
||||||
<teleport to="#modal">
|
<teleport to="#modal">
|
||||||
<confirm-modal
|
<ConfirmModal
|
||||||
v-if="showingConfirmLogout"
|
v-if="showingConfirmLogout"
|
||||||
:title="$t('login.logout_confirm_title')"
|
:title="$t('login.logout_confirm_title')"
|
||||||
:confirm-danger="true"
|
:confirm-danger="true"
|
||||||
|
|
@ -116,7 +116,7 @@
|
||||||
@cancelled="hideConfirmLogout"
|
@cancelled="hideConfirmLogout"
|
||||||
>
|
>
|
||||||
{{ $t('login.logout_confirm') }}
|
{{ $t('login.logout_confirm') }}
|
||||||
</confirm-modal>
|
</ConfirmModal>
|
||||||
</teleport>
|
</teleport>
|
||||||
</div>
|
</div>
|
||||||
</template>
|
</template>
|
||||||
|
|
|
||||||
|
|
@ -1,3 +1,4 @@
|
||||||
|
import { defineAsyncComponent } from 'vue'
|
||||||
import { mapState } from 'vuex'
|
import { mapState } from 'vuex'
|
||||||
|
|
||||||
import RichContent from 'src/components/rich_content/rich_content.jsx'
|
import RichContent from 'src/components/rich_content/rich_content.jsx'
|
||||||
|
|
@ -6,7 +7,6 @@ import {
|
||||||
highlightClass,
|
highlightClass,
|
||||||
highlightStyle,
|
highlightStyle,
|
||||||
} from '../../services/user_highlighter/user_highlighter.js'
|
} from '../../services/user_highlighter/user_highlighter.js'
|
||||||
import ConfirmModal from '../confirm_modal/confirm_modal.vue'
|
|
||||||
import Report from '../report/report.vue'
|
import Report from '../report/report.vue'
|
||||||
import Status from '../status/status.vue'
|
import Status from '../status/status.vue'
|
||||||
import StatusContent from '../status_content/status_content.vue'
|
import StatusContent from '../status_content/status_content.vue'
|
||||||
|
|
@ -69,7 +69,9 @@ const Notification = {
|
||||||
RichContent,
|
RichContent,
|
||||||
UserPopover,
|
UserPopover,
|
||||||
UserLink,
|
UserLink,
|
||||||
ConfirmModal,
|
ConfirmModal: defineAsyncComponent(
|
||||||
|
() => import('src/components/confirm_modal/confirm_modal.vue'),
|
||||||
|
),
|
||||||
},
|
},
|
||||||
mounted() {
|
mounted() {
|
||||||
document.addEventListener('selectionchange', this.onContentSelect)
|
document.addEventListener('selectionchange', this.onContentSelect)
|
||||||
|
|
|
||||||
|
|
@ -267,7 +267,7 @@
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<teleport to="#modal">
|
<teleport to="#modal">
|
||||||
<confirm-modal
|
<ConfirmModal
|
||||||
v-if="showingApproveConfirmDialog"
|
v-if="showingApproveConfirmDialog"
|
||||||
:title="$t('user_card.approve_confirm_title')"
|
:title="$t('user_card.approve_confirm_title')"
|
||||||
:confirm-text="$t('user_card.approve_confirm_accept_button')"
|
:confirm-text="$t('user_card.approve_confirm_accept_button')"
|
||||||
|
|
@ -276,8 +276,8 @@
|
||||||
@cancelled="hideApproveConfirmDialog"
|
@cancelled="hideApproveConfirmDialog"
|
||||||
>
|
>
|
||||||
{{ $t('user_card.approve_confirm', { user: user.screen_name_ui }) }}
|
{{ $t('user_card.approve_confirm', { user: user.screen_name_ui }) }}
|
||||||
</confirm-modal>
|
</ConfirmModal>
|
||||||
<confirm-modal
|
<ConfirmModal
|
||||||
v-if="showingDenyConfirmDialog"
|
v-if="showingDenyConfirmDialog"
|
||||||
:title="$t('user_card.deny_confirm_title')"
|
:title="$t('user_card.deny_confirm_title')"
|
||||||
:confirm-text="$t('user_card.deny_confirm_accept_button')"
|
:confirm-text="$t('user_card.deny_confirm_accept_button')"
|
||||||
|
|
@ -286,7 +286,7 @@
|
||||||
@cancelled="hideDenyConfirmDialog"
|
@cancelled="hideDenyConfirmDialog"
|
||||||
>
|
>
|
||||||
{{ $t('user_card.deny_confirm', { user: user.screen_name_ui }) }}
|
{{ $t('user_card.deny_confirm', { user: user.screen_name_ui }) }}
|
||||||
</confirm-modal>
|
</ConfirmModal>
|
||||||
</teleport>
|
</teleport>
|
||||||
</article>
|
</article>
|
||||||
</template>
|
</template>
|
||||||
|
|
|
||||||
|
|
@ -1,6 +1,7 @@
|
||||||
import { defineAsyncComponent } from 'vue'
|
import { defineAsyncComponent } from 'vue'
|
||||||
|
|
||||||
import Status from '../status/status.vue'
|
import Status from '../status/status.vue'
|
||||||
|
|
||||||
import { library } from '@fortawesome/fontawesome-svg-core'
|
import { library } from '@fortawesome/fontawesome-svg-core'
|
||||||
import { faCircleNotch } from '@fortawesome/free-solid-svg-icons'
|
import { faCircleNotch } from '@fortawesome/free-solid-svg-icons'
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -1,4 +1,4 @@
|
||||||
import ConfirmModal from '../confirm_modal/confirm_modal.vue'
|
import { defineAsyncComponent } from 'vue'
|
||||||
|
|
||||||
import { useMergedConfigStore } from 'src/stores/merged_config.js'
|
import { useMergedConfigStore } from 'src/stores/merged_config.js'
|
||||||
|
|
||||||
|
|
@ -11,7 +11,9 @@ export default {
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
components: {
|
components: {
|
||||||
ConfirmModal,
|
ConfirmModal: defineAsyncComponent(
|
||||||
|
() => import('src/components/confirm_modal/confirm_modal.vue'),
|
||||||
|
),
|
||||||
},
|
},
|
||||||
computed: {
|
computed: {
|
||||||
label() {
|
label() {
|
||||||
|
|
|
||||||
|
|
@ -8,7 +8,7 @@
|
||||||
>
|
>
|
||||||
{{ label }}
|
{{ label }}
|
||||||
<teleport to="#modal">
|
<teleport to="#modal">
|
||||||
<confirm-modal
|
<ConfirmModal
|
||||||
v-if="showingConfirmRemoveFollower"
|
v-if="showingConfirmRemoveFollower"
|
||||||
:title="$t('user_card.remove_follower_confirm_title')"
|
:title="$t('user_card.remove_follower_confirm_title')"
|
||||||
:confirm-text="$t('user_card.remove_follower_confirm_accept_button')"
|
:confirm-text="$t('user_card.remove_follower_confirm_accept_button')"
|
||||||
|
|
@ -27,7 +27,7 @@
|
||||||
/>
|
/>
|
||||||
</template>
|
</template>
|
||||||
</i18n-t>
|
</i18n-t>
|
||||||
</confirm-modal>
|
</ConfirmModal>
|
||||||
</teleport>
|
</teleport>
|
||||||
</button>
|
</button>
|
||||||
</template>
|
</template>
|
||||||
|
|
|
||||||
|
|
@ -1,4 +1,4 @@
|
||||||
import { uniqBy, map } from 'lodash'
|
import { map, uniqBy } from 'lodash'
|
||||||
|
|
||||||
import TabSwitcher from 'src/components/tab_switcher/tab_switcher.jsx'
|
import TabSwitcher from 'src/components/tab_switcher/tab_switcher.jsx'
|
||||||
import Conversation from '../conversation/conversation.vue'
|
import Conversation from '../conversation/conversation.vue'
|
||||||
|
|
|
||||||
|
|
@ -1,9 +1,9 @@
|
||||||
import Checkbox from 'components/checkbox/checkbox.vue'
|
import Checkbox from 'components/checkbox/checkbox.vue'
|
||||||
import ConfirmModal from 'components/confirm_modal/confirm_modal.vue'
|
|
||||||
import Popover from 'components/popover/popover.vue'
|
import Popover from 'components/popover/popover.vue'
|
||||||
import Select from 'components/select/select.vue'
|
import Select from 'components/select/select.vue'
|
||||||
import StillImage from 'components/still-image/still-image.vue'
|
import StillImage from 'components/still-image/still-image.vue'
|
||||||
import { assign, clone } from 'lodash'
|
import { assign, clone } from 'lodash'
|
||||||
|
import { defineAsyncComponent } from 'vue'
|
||||||
|
|
||||||
import TabSwitcher from 'src/components/tab_switcher/tab_switcher.jsx'
|
import TabSwitcher from 'src/components/tab_switcher/tab_switcher.jsx'
|
||||||
import EmojiEditingPopover from '../helpers/emoji_editing_popover.vue'
|
import EmojiEditingPopover from '../helpers/emoji_editing_popover.vue'
|
||||||
|
|
@ -33,7 +33,10 @@ const EmojiTab = {
|
||||||
StillImage,
|
StillImage,
|
||||||
Select,
|
Select,
|
||||||
Popover,
|
Popover,
|
||||||
ConfirmModal,
|
ConfirmModal: defineAsyncComponent(
|
||||||
|
() => import('src/components/confirm_modal/confirm_modal.vue'),
|
||||||
|
),
|
||||||
|
|
||||||
ModifiedIndicator,
|
ModifiedIndicator,
|
||||||
EmojiEditingPopover,
|
EmojiEditingPopover,
|
||||||
},
|
},
|
||||||
|
|
|
||||||
|
|
@ -149,13 +149,21 @@
|
||||||
</template>
|
</template>
|
||||||
|
|
||||||
<script>
|
<script>
|
||||||
import ConfirmModal from 'components/confirm_modal/confirm_modal.vue'
|
|
||||||
import Popover from 'components/popover/popover.vue'
|
import Popover from 'components/popover/popover.vue'
|
||||||
import SelectComponent from 'components/select/select.vue'
|
import SelectComponent from 'components/select/select.vue'
|
||||||
import StillImage from 'components/still-image/still-image.vue'
|
import StillImage from 'components/still-image/still-image.vue'
|
||||||
|
import { defineAsyncComponent } from 'vue'
|
||||||
|
|
||||||
export default {
|
export default {
|
||||||
components: { Popover, ConfirmModal, StillImage, SelectComponent },
|
components: {
|
||||||
|
Popover,
|
||||||
|
ConfirmModal: defineAsyncComponent(
|
||||||
|
() => import('src/components/confirm_modal/confirm_modal.vue'),
|
||||||
|
),
|
||||||
|
StillImage,
|
||||||
|
SelectComponent,
|
||||||
|
},
|
||||||
|
|
||||||
inject: ['emojiAddr'],
|
inject: ['emojiAddr'],
|
||||||
props: {
|
props: {
|
||||||
placement: {
|
placement: {
|
||||||
|
|
|
||||||
|
|
@ -1,9 +1,9 @@
|
||||||
import { cloneDeep, isEqual } from 'lodash'
|
import { cloneDeep, isEqual } from 'lodash'
|
||||||
import { mapActions, mapState } from 'pinia'
|
import { mapActions, mapState } from 'pinia'
|
||||||
|
import { defineAsyncComponent } from 'vue'
|
||||||
|
|
||||||
import AsyncComponentError from 'src/components/async_component_error/async_component_error.vue'
|
import AsyncComponentError from 'src/components/async_component_error/async_component_error.vue'
|
||||||
import Checkbox from 'src/components/checkbox/checkbox.vue'
|
import Checkbox from 'src/components/checkbox/checkbox.vue'
|
||||||
import ConfirmModal from 'src/components/confirm_modal/confirm_modal.vue'
|
|
||||||
import Modal from 'src/components/modal/modal.vue'
|
import Modal from 'src/components/modal/modal.vue'
|
||||||
import PanelLoading from 'src/components/panel_loading/panel_loading.vue'
|
import PanelLoading from 'src/components/panel_loading/panel_loading.vue'
|
||||||
import Popover from '../popover/popover.vue'
|
import Popover from '../popover/popover.vue'
|
||||||
|
|
@ -67,7 +67,10 @@ const SettingsModal = {
|
||||||
Modal,
|
Modal,
|
||||||
Popover,
|
Popover,
|
||||||
Checkbox,
|
Checkbox,
|
||||||
ConfirmModal,
|
ConfirmModal: defineAsyncComponent(
|
||||||
|
() => import('src/components/confirm_modal/confirm_modal.vue'),
|
||||||
|
),
|
||||||
|
|
||||||
SettingsModalUserContent: getResettableAsyncComponent(
|
SettingsModalUserContent: getResettableAsyncComponent(
|
||||||
() => import('./settings_modal_user_content.vue'),
|
() => import('./settings_modal_user_content.vue'),
|
||||||
{
|
{
|
||||||
|
|
|
||||||
|
|
@ -1,4 +1,4 @@
|
||||||
import { map, groupBy } from 'lodash'
|
import { groupBy, map } from 'lodash'
|
||||||
import { mapGetters, mapState } from 'vuex'
|
import { mapGetters, mapState } from 'vuex'
|
||||||
|
|
||||||
import BasicUserCard from '../basic_user_card/basic_user_card.vue'
|
import BasicUserCard from '../basic_user_card/basic_user_card.vue'
|
||||||
|
|
|
||||||
|
|
@ -1,23 +1,23 @@
|
||||||
import { unescape as ldUnescape, uniqBy } from 'lodash'
|
import { unescape as ldUnescape, uniqBy } from 'lodash'
|
||||||
import { defineAsyncComponent } from 'vue'
|
import { defineAsyncComponent } from 'vue'
|
||||||
|
|
||||||
|
import AvatarList from 'src/components/avatar_list/avatar_list.vue'
|
||||||
|
import EmojiReactions from 'src/components/emoji_reactions/emoji_reactions.vue'
|
||||||
import MentionLink from 'src/components/mention_link/mention_link.vue'
|
import MentionLink from 'src/components/mention_link/mention_link.vue'
|
||||||
import MentionsLine from 'src/components/mentions_line/mentions_line.vue'
|
import MentionsLine from 'src/components/mentions_line/mentions_line.vue'
|
||||||
import RichContent from 'src/components/rich_content/rich_content.jsx'
|
import RichContent from 'src/components/rich_content/rich_content.jsx'
|
||||||
import StatusActionButtons from 'src/components/status_action_buttons/status_action_buttons.vue'
|
import StatusActionButtons from 'src/components/status_action_buttons/status_action_buttons.vue'
|
||||||
import { muteFilterHits } from '../../services/status_parser/status_parser.js'
|
|
||||||
import {
|
|
||||||
highlightClass,
|
|
||||||
highlightStyle,
|
|
||||||
} from '../../services/user_highlighter/user_highlighter.js'
|
|
||||||
import AvatarList from 'src/components/avatar_list/avatar_list.vue'
|
|
||||||
import EmojiReactions from 'src/components/emoji_reactions/emoji_reactions.vue'
|
|
||||||
import StatusContent from 'src/components/status_content/status_content.vue'
|
import StatusContent from 'src/components/status_content/status_content.vue'
|
||||||
import Timeago from 'src/components/timeago/timeago.vue'
|
import Timeago from 'src/components/timeago/timeago.vue'
|
||||||
import UserAvatar from 'src/components/user_avatar/user_avatar.vue'
|
import UserAvatar from 'src/components/user_avatar/user_avatar.vue'
|
||||||
import UserLink from 'src/components/user_link/user_link.vue'
|
import UserLink from 'src/components/user_link/user_link.vue'
|
||||||
import UserListPopover from 'src/components/user_list_popover/user_list_popover.vue'
|
import UserListPopover from 'src/components/user_list_popover/user_list_popover.vue'
|
||||||
import UserPopover from 'src/components/user_popover/user_popover.vue'
|
import UserPopover from 'src/components/user_popover/user_popover.vue'
|
||||||
|
import { muteFilterHits } from '../../services/status_parser/status_parser.js'
|
||||||
|
import {
|
||||||
|
highlightClass,
|
||||||
|
highlightStyle,
|
||||||
|
} from '../../services/user_highlighter/user_highlighter.js'
|
||||||
|
|
||||||
import { useInstanceStore } from 'src/stores/instance.js'
|
import { useInstanceStore } from 'src/stores/instance.js'
|
||||||
import { useInstanceCapabilitiesStore } from 'src/stores/instance_capabilities.js'
|
import { useInstanceCapabilitiesStore } from 'src/stores/instance_capabilities.js'
|
||||||
|
|
@ -122,7 +122,7 @@ const Status = {
|
||||||
AvatarList,
|
AvatarList,
|
||||||
Timeago,
|
Timeago,
|
||||||
StatusPopover: defineAsyncComponent(
|
StatusPopover: defineAsyncComponent(
|
||||||
() => import( 'src/components/status_popover/status_popover.vue')
|
() => import('src/components/status_popover/status_popover.vue'),
|
||||||
),
|
),
|
||||||
UserListPopover,
|
UserListPopover,
|
||||||
EmojiReactions,
|
EmojiReactions,
|
||||||
|
|
@ -132,9 +132,7 @@ const Status = {
|
||||||
MentionsLine,
|
MentionsLine,
|
||||||
UserPopover,
|
UserPopover,
|
||||||
UserLink,
|
UserLink,
|
||||||
Quote: defineAsyncComponent(
|
Quote: defineAsyncComponent(() => import('src/components/quote/quote.vue')),
|
||||||
() => import('src/components/quote/quote.vue')
|
|
||||||
),
|
|
||||||
StatusActionButtons,
|
StatusActionButtons,
|
||||||
},
|
},
|
||||||
props: [
|
props: [
|
||||||
|
|
|
||||||
|
|
@ -1,15 +1,16 @@
|
||||||
|
import { defineAsyncComponent } from 'vue'
|
||||||
|
|
||||||
import Popover from 'src/components/popover/popover.vue'
|
import Popover from 'src/components/popover/popover.vue'
|
||||||
|
|
||||||
import { useInstanceStore } from 'src/stores/instance.js'
|
import { useInstanceStore } from 'src/stores/instance.js'
|
||||||
import { useInstanceCapabilitiesStore } from 'src/stores/instance_capabilities.js'
|
import { useInstanceCapabilitiesStore } from 'src/stores/instance_capabilities.js'
|
||||||
import { useMergedConfigStore } from 'src/stores/merged_config.js'
|
import { useMergedConfigStore } from 'src/stores/merged_config.js'
|
||||||
import { defineAsyncComponent } from 'vue'
|
|
||||||
|
|
||||||
import { library } from '@fortawesome/fontawesome-svg-core'
|
import { library } from '@fortawesome/fontawesome-svg-core'
|
||||||
import {
|
import {
|
||||||
faBookmark as faBookmarkRegular,
|
faBookmark as faBookmarkRegular,
|
||||||
faStar as faStarRegular,
|
|
||||||
faFaceSmileBeam,
|
faFaceSmileBeam,
|
||||||
|
faStar as faStarRegular,
|
||||||
} from '@fortawesome/free-regular-svg-icons'
|
} from '@fortawesome/free-regular-svg-icons'
|
||||||
import {
|
import {
|
||||||
faBookmark,
|
faBookmark,
|
||||||
|
|
@ -69,7 +70,10 @@ export default {
|
||||||
],
|
],
|
||||||
components: {
|
components: {
|
||||||
StatusBookmarkFolderMenu: defineAsyncComponent(
|
StatusBookmarkFolderMenu: defineAsyncComponent(
|
||||||
() => import( 'src/components/status_bookmark_folder_menu/status_bookmark_folder_menu.vue'),
|
() =>
|
||||||
|
import(
|
||||||
|
'src/components/status_bookmark_folder_menu/status_bookmark_folder_menu.vue'
|
||||||
|
),
|
||||||
),
|
),
|
||||||
EmojiPicker: defineAsyncComponent(
|
EmojiPicker: defineAsyncComponent(
|
||||||
() => import('src/components/emoji_picker/emoji_picker.vue'),
|
() => import('src/components/emoji_picker/emoji_picker.vue'),
|
||||||
|
|
|
||||||
|
|
@ -1,6 +1,6 @@
|
||||||
import { mapState } from 'pinia'
|
import { mapState } from 'pinia'
|
||||||
|
import { defineAsyncComponent } from 'vue'
|
||||||
|
|
||||||
import ConfirmModal from 'src/components/confirm_modal/confirm_modal.vue'
|
|
||||||
import Popover from 'src/components/popover/popover.vue'
|
import Popover from 'src/components/popover/popover.vue'
|
||||||
import ActionButtonContainer from './action_button_container.vue'
|
import ActionButtonContainer from './action_button_container.vue'
|
||||||
import { BUTTONS } from './buttons_definitions.js'
|
import { BUTTONS } from './buttons_definitions.js'
|
||||||
|
|
@ -33,7 +33,10 @@ const StatusActionButtons = {
|
||||||
},
|
},
|
||||||
components: {
|
components: {
|
||||||
Popover,
|
Popover,
|
||||||
ConfirmModal,
|
ConfirmModal: defineAsyncComponent(
|
||||||
|
() => import('src/components/confirm_modal/confirm_modal.vue'),
|
||||||
|
),
|
||||||
|
|
||||||
ActionButtonContainer,
|
ActionButtonContainer,
|
||||||
},
|
},
|
||||||
computed: {
|
computed: {
|
||||||
|
|
|
||||||
|
|
@ -116,7 +116,7 @@
|
||||||
</span>
|
</span>
|
||||||
|
|
||||||
<teleport to="#modal">
|
<teleport to="#modal">
|
||||||
<confirm-modal
|
<ConfirmModal
|
||||||
v-if="showingConfirmDialog"
|
v-if="showingConfirmDialog"
|
||||||
:title="currentConfirmTitle"
|
:title="currentConfirmTitle"
|
||||||
:confirm-text="currentConfirmOkText"
|
:confirm-text="currentConfirmOkText"
|
||||||
|
|
@ -125,7 +125,7 @@
|
||||||
@cancelled="showingConfirmDialog = false"
|
@cancelled="showingConfirmDialog = false"
|
||||||
>
|
>
|
||||||
{{ currentConfirmBody }}
|
{{ currentConfirmBody }}
|
||||||
</confirm-modal>
|
</ConfirmModal>
|
||||||
</teleport>
|
</teleport>
|
||||||
</div>
|
</div>
|
||||||
</template>
|
</template>
|
||||||
|
|
|
||||||
|
|
@ -1,4 +1,9 @@
|
||||||
import { escape as ldEscape, isEqual, merge, unescape as ldUnescape } from 'lodash'
|
import {
|
||||||
|
isEqual,
|
||||||
|
escape as ldEscape,
|
||||||
|
unescape as ldUnescape,
|
||||||
|
merge,
|
||||||
|
} from 'lodash'
|
||||||
import { mapState } from 'pinia'
|
import { mapState } from 'pinia'
|
||||||
|
|
||||||
import Checkbox from 'src/components/checkbox/checkbox.vue'
|
import Checkbox from 'src/components/checkbox/checkbox.vue'
|
||||||
|
|
|
||||||
|
|
@ -1,5 +1,6 @@
|
||||||
|
import { defineAsyncComponent } from 'vue'
|
||||||
|
|
||||||
import Checkbox from 'src/components/checkbox/checkbox.vue'
|
import Checkbox from 'src/components/checkbox/checkbox.vue'
|
||||||
import ConfirmModal from 'src/components/confirm_modal/confirm_modal.vue'
|
|
||||||
import Select from 'src/components/select/select.vue'
|
import Select from 'src/components/select/select.vue'
|
||||||
|
|
||||||
import { useMergedConfigStore } from 'src/stores/merged_config.js'
|
import { useMergedConfigStore } from 'src/stores/merged_config.js'
|
||||||
|
|
@ -36,7 +37,10 @@ const UserTimedFilterModal = {
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
components: {
|
components: {
|
||||||
ConfirmModal,
|
ConfirmModal: defineAsyncComponent(
|
||||||
|
() => import('src/components/confirm_modal/confirm_modal.vue'),
|
||||||
|
),
|
||||||
|
|
||||||
Select,
|
Select,
|
||||||
Checkbox,
|
Checkbox,
|
||||||
},
|
},
|
||||||
|
|
|
||||||
|
|
@ -1,5 +1,5 @@
|
||||||
<template>
|
<template>
|
||||||
<confirm-modal
|
<ConfirmModal
|
||||||
v-if="showing"
|
v-if="showing"
|
||||||
class="UserTimedFilterModal"
|
class="UserTimedFilterModal"
|
||||||
:title="$t(isMute ? $t('user_card.mute') : $t('user_card.block'))"
|
:title="$t(isMute ? $t('user_card.mute') : $t('user_card.block'))"
|
||||||
|
|
@ -80,7 +80,7 @@
|
||||||
</Checkbox>
|
</Checkbox>
|
||||||
</div>
|
</div>
|
||||||
</template>
|
</template>
|
||||||
</confirm-modal>
|
</ConfirmModal>
|
||||||
</template>
|
</template>
|
||||||
|
|
||||||
<script src="./user_timed_filter_modal.js"></script>
|
<script src="./user_timed_filter_modal.js"></script>
|
||||||
|
|
|
||||||
|
|
@ -1,4 +1,4 @@
|
||||||
import { cloneDeep, each, get, set, merge } from 'lodash'
|
import { cloneDeep, each, get, merge, set } from 'lodash'
|
||||||
|
|
||||||
import { storage } from './storage.js'
|
import { storage } from './storage.js'
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -1,4 +1,4 @@
|
||||||
import { maxBy, minBy } from 'lodash'
|
import { maxBy, minBy, orderBy, sortBy, uniqueId } from 'lodash'
|
||||||
|
|
||||||
const empty = (chatId) => {
|
const empty = (chatId) => {
|
||||||
return {
|
return {
|
||||||
|
|
@ -57,7 +57,7 @@ const cullOlderMessages = (storage) => {
|
||||||
const minIndex = maxIndex - 50
|
const minIndex = maxIndex - 50
|
||||||
if (maxIndex <= 50) return
|
if (maxIndex <= 50) return
|
||||||
|
|
||||||
storage.messages = _.sortBy(storage.messages, ['id'])
|
storage.messages = sortBy(storage.messages, ['id'])
|
||||||
storage.minId = storage.messages[minIndex].id
|
storage.minId = storage.messages[minIndex].id
|
||||||
for (const message of storage.messages) {
|
for (const message of storage.messages) {
|
||||||
if (message.id < storage.minId) {
|
if (message.id < storage.minId) {
|
||||||
|
|
@ -78,7 +78,7 @@ const handleMessageError = (storage, fakeId, isRetry) => {
|
||||||
fakeMessage.pending = false
|
fakeMessage.pending = false
|
||||||
if (!isRetry) {
|
if (!isRetry) {
|
||||||
// Ensure the failed message doesn't stay at the bottom of the list.
|
// Ensure the failed message doesn't stay at the bottom of the list.
|
||||||
const lastPersistedMessage = _.orderBy(
|
const lastPersistedMessage = orderBy(
|
||||||
storage.messages,
|
storage.messages,
|
||||||
['pending', 'id'],
|
['pending', 'id'],
|
||||||
['asc', 'desc'],
|
['asc', 'desc'],
|
||||||
|
|
@ -166,11 +166,7 @@ const getView = (storage) => {
|
||||||
}
|
}
|
||||||
|
|
||||||
const result = []
|
const result = []
|
||||||
const messages = _.orderBy(
|
const messages = orderBy(storage.messages, ['pending', 'id'], ['asc', 'asc'])
|
||||||
storage.messages,
|
|
||||||
['pending', 'id'],
|
|
||||||
['asc', 'asc'],
|
|
||||||
)
|
|
||||||
const firstMessage = messages[0]
|
const firstMessage = messages[0]
|
||||||
let previousMessage = messages[messages.length - 1]
|
let previousMessage = messages[messages.length - 1]
|
||||||
let currentMessageChainId
|
let currentMessageChainId
|
||||||
|
|
@ -228,7 +224,7 @@ const getView = (storage) => {
|
||||||
previousMessage.data.account_id) !== message.account_id ||
|
previousMessage.data.account_id) !== message.account_id ||
|
||||||
afterDate
|
afterDate
|
||||||
) {
|
) {
|
||||||
currentMessageChainId = _.uniqueId()
|
currentMessageChainId = uniqueId()
|
||||||
object.isHead = true
|
object.isHead = true
|
||||||
object.messageChainId = currentMessageChainId
|
object.messageChainId = currentMessageChainId
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -87,10 +87,7 @@ export const maybeShowNotification = (
|
||||||
)
|
)
|
||||||
return
|
return
|
||||||
|
|
||||||
const notificationObject = prepareNotificationObject(
|
const notificationObject = prepareNotificationObject(notification, i18n)
|
||||||
notification,
|
|
||||||
i18n,
|
|
||||||
)
|
|
||||||
showDesktopNotification(rootState, notificationObject)
|
showDesktopNotification(rootState, notificationObject)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -193,7 +190,11 @@ export const prepareNotificationObject = (notification, i18n) => {
|
||||||
return notifObj
|
return notifObj
|
||||||
}
|
}
|
||||||
|
|
||||||
export const countExtraNotifications = (store, mergedConfig, unreadAnnouncementCount) => {
|
export const countExtraNotifications = (
|
||||||
|
store,
|
||||||
|
mergedConfig,
|
||||||
|
unreadAnnouncementCount,
|
||||||
|
) => {
|
||||||
const rootGetters = store.rootGetters || store.getters
|
const rootGetters = store.rootGetters || store.getters
|
||||||
|
|
||||||
if (!mergedConfig.showExtraNotifications) {
|
if (!mergedConfig.showExtraNotifications) {
|
||||||
|
|
|
||||||
|
|
@ -18,8 +18,7 @@ function isPushSupported() {
|
||||||
function getOrCreateServiceWorker() {
|
function getOrCreateServiceWorker() {
|
||||||
if (!isSWSupported()) return
|
if (!isSWSupported()) return
|
||||||
const swType = process.env.HAS_MODULE_SERVICE_WORKER ? 'module' : 'classic'
|
const swType = process.env.HAS_MODULE_SERVICE_WORKER ? 'module' : 'classic'
|
||||||
return navigator
|
return navigator.serviceWorker
|
||||||
.serviceWorker
|
|
||||||
.register('/sw-pleroma.js', { type: swType })
|
.register('/sw-pleroma.js', { type: swType })
|
||||||
.catch((err) =>
|
.catch((err) =>
|
||||||
console.error('Unable to get or create a service worker.', err),
|
console.error('Unable to get or create a service worker.', err),
|
||||||
|
|
|
||||||
|
|
@ -1,10 +1,9 @@
|
||||||
import { dirname, resolve } from 'node:path'
|
import { dirname, resolve } from 'node:path'
|
||||||
import { fileURLToPath } from 'node:url'
|
import { fileURLToPath } from 'node:url'
|
||||||
|
import { DevTools } from '@vitejs/devtools'
|
||||||
import vue from '@vitejs/plugin-vue'
|
import vue from '@vitejs/plugin-vue'
|
||||||
import vueJsx from '@vitejs/plugin-vue-jsx'
|
import vueJsx from '@vitejs/plugin-vue-jsx'
|
||||||
import { defineConfig } from 'vite'
|
import { defineConfig } from 'vite'
|
||||||
import { DevTools } from '@vitejs/devtools'
|
|
||||||
|
|
||||||
import eslint from 'vite-plugin-eslint2'
|
import eslint from 'vite-plugin-eslint2'
|
||||||
import stylelint from 'vite-plugin-stylelint'
|
import stylelint from 'vite-plugin-stylelint'
|
||||||
import { configDefaults } from 'vitest/config'
|
import { configDefaults } from 'vitest/config'
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue