Resolve i18n conflict
All checks were successful
ci/woodpecker/pr/woodpecker Pipeline was successful
All checks were successful
ci/woodpecker/pr/woodpecker Pipeline was successful
This commit is contained in:
commit
b473ac8f57
15 changed files with 5468 additions and 5036 deletions
|
@ -30,7 +30,7 @@ module.exports = {
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
resolve: {
|
resolve: {
|
||||||
extensions: ['.js', '.jsx', '.vue'],
|
extensions: ['.js', '.jsx', '.vue', '.mjs'],
|
||||||
modules: [
|
modules: [
|
||||||
path.join(__dirname, '../node_modules')
|
path.join(__dirname, '../node_modules')
|
||||||
],
|
],
|
||||||
|
@ -68,6 +68,11 @@ module.exports = {
|
||||||
path.resolve(__dirname, '../src/i18n')
|
path.resolve(__dirname, '../src/i18n')
|
||||||
]
|
]
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
test: /\.mjs$/,
|
||||||
|
include: /node_modules/,
|
||||||
|
type: "javascript/auto"
|
||||||
|
},
|
||||||
{
|
{
|
||||||
test: /\.vue$/,
|
test: /\.vue$/,
|
||||||
loader: 'vue-loader',
|
loader: 'vue-loader',
|
||||||
|
|
|
@ -34,8 +34,7 @@
|
||||||
"js-cookie": "^3.0.1",
|
"js-cookie": "^3.0.1",
|
||||||
"localforage": "1.10.0",
|
"localforage": "1.10.0",
|
||||||
"marked": "^4.0.17",
|
"marked": "^4.0.17",
|
||||||
"marked-mfm": "^0.4.0",
|
"marked-mfm": "^0.5.0",
|
||||||
"mfm-js": "^0.22.1",
|
|
||||||
"parse-link-header": "1.0.1",
|
"parse-link-header": "1.0.1",
|
||||||
"phoenix": "1.6.2",
|
"phoenix": "1.6.2",
|
||||||
"punycode.js": "2.1.0",
|
"punycode.js": "2.1.0",
|
||||||
|
@ -57,7 +56,7 @@
|
||||||
"@vue/babel-helper-vue-jsx-merge-props": "1.2.1",
|
"@vue/babel-helper-vue-jsx-merge-props": "1.2.1",
|
||||||
"@vue/babel-plugin-jsx": "1.1.1",
|
"@vue/babel-plugin-jsx": "1.1.1",
|
||||||
"@vue/compiler-sfc": "^3.1.0",
|
"@vue/compiler-sfc": "^3.1.0",
|
||||||
"@vue/test-utils": "2.0.0-rc.17",
|
"@vue/test-utils": "^2.0.2",
|
||||||
"autoprefixer": "6.7.7",
|
"autoprefixer": "6.7.7",
|
||||||
"babel-eslint": "7.2.3",
|
"babel-eslint": "7.2.3",
|
||||||
"babel-loader": "8.2.4",
|
"babel-loader": "8.2.4",
|
||||||
|
|
|
@ -124,6 +124,14 @@ export default {
|
||||||
}
|
}
|
||||||
|
|
||||||
const renderMisskeyMarkdown = (content) => {
|
const renderMisskeyMarkdown = (content) => {
|
||||||
|
// Untangle code blocks from <br> tags
|
||||||
|
const codeblocks = content.match(/(<br\/>)?(~~~|```)\w*<br\/>.+?<br\/>\2\1?/g)
|
||||||
|
if (codeblocks) {
|
||||||
|
codeblocks.forEach((pre) => {
|
||||||
|
content = content.replace(pre, pre.replaceAll('<br/>', '\n'))
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
marked.use(markedMfm, {
|
marked.use(markedMfm, {
|
||||||
mangle: false,
|
mangle: false,
|
||||||
gfm: false,
|
gfm: false,
|
||||||
|
|
|
@ -37,6 +37,15 @@
|
||||||
{{ $t('settings.hide_muted_posts') }}
|
{{ $t('settings.hide_muted_posts') }}
|
||||||
</BooleanSetting>
|
</BooleanSetting>
|
||||||
</li>
|
</li>
|
||||||
|
<li>
|
||||||
|
<BooleanSetting
|
||||||
|
v-if="user"
|
||||||
|
:disabled="hideFilteredStatuses"
|
||||||
|
path="hideThreadsWithBlockedUsers"
|
||||||
|
>
|
||||||
|
{{ $t('settings.hide_threads_with_blocked_users') }}
|
||||||
|
</BooleanSetting>
|
||||||
|
</li>
|
||||||
</ul>
|
</ul>
|
||||||
</li>
|
</li>
|
||||||
<li>
|
<li>
|
||||||
|
|
|
@ -261,6 +261,38 @@ const Status = {
|
||||||
hasMentionsLine () {
|
hasMentionsLine () {
|
||||||
return this.mentionsLine.length > 0
|
return this.mentionsLine.length > 0
|
||||||
},
|
},
|
||||||
|
mentionsBlockedUser () {
|
||||||
|
// XXX: doesn't work on domain blocks, because users from blocked domains
|
||||||
|
// don't appear in `attentions' and therefore cannot be filtered.
|
||||||
|
let mentions = false
|
||||||
|
|
||||||
|
// find if user in mentions list is blocked
|
||||||
|
this.status.attentions.forEach((attn) => {
|
||||||
|
if (attn.id === this.currentUser.id) return
|
||||||
|
const relationship = this.$store.getters.relationship(attn.id)
|
||||||
|
if (relationship.blocking) {
|
||||||
|
mentions = true
|
||||||
|
}
|
||||||
|
})
|
||||||
|
|
||||||
|
return mentions
|
||||||
|
},
|
||||||
|
mentionsMutedUser () {
|
||||||
|
// XXX: doesn't work on domain blocks, because users from blocked domains
|
||||||
|
// don't appear in `attentions' and therefore cannot be filtered.
|
||||||
|
let mentions = false
|
||||||
|
|
||||||
|
// find if user in mentions list is blocked
|
||||||
|
this.status.attentions.forEach((attn) => {
|
||||||
|
if (attn.id === this.currentUser.id) return
|
||||||
|
const relationship = this.$store.getters.relationship(attn.id)
|
||||||
|
if (relationship.muting) {
|
||||||
|
mentions = true
|
||||||
|
}
|
||||||
|
})
|
||||||
|
|
||||||
|
return mentions
|
||||||
|
},
|
||||||
muted () {
|
muted () {
|
||||||
if (this.statusoid.user.id === this.currentUser.id) return false
|
if (this.statusoid.user.id === this.currentUser.id) return false
|
||||||
const reasonsToMute = this.userIsMuted ||
|
const reasonsToMute = this.userIsMuted ||
|
||||||
|
@ -269,7 +301,11 @@ const Status = {
|
||||||
// Wordfiltered
|
// Wordfiltered
|
||||||
this.muteWordHits.length > 0 ||
|
this.muteWordHits.length > 0 ||
|
||||||
// bot status
|
// bot status
|
||||||
(this.muteBotStatuses && this.botStatus && !this.compact)
|
(this.muteBotStatuses && this.botStatus && !this.compact) ||
|
||||||
|
// mentions blocked user
|
||||||
|
this.mentionsBlockedUser ||
|
||||||
|
// mentions muted user
|
||||||
|
this.mentionsMutedUser
|
||||||
return !this.unmuted && !this.shouldNotMute && reasonsToMute
|
return !this.unmuted && !this.shouldNotMute && reasonsToMute
|
||||||
},
|
},
|
||||||
userIsMuted () {
|
userIsMuted () {
|
||||||
|
@ -312,6 +348,9 @@ const Status = {
|
||||||
hideFilteredStatuses () {
|
hideFilteredStatuses () {
|
||||||
return this.mergedConfig.hideFilteredStatuses
|
return this.mergedConfig.hideFilteredStatuses
|
||||||
},
|
},
|
||||||
|
hideThreadsWithBlockedUsers () {
|
||||||
|
return this.mergedConfig.hideThreadsWithBlockedUsers
|
||||||
|
},
|
||||||
hideWordFilteredPosts () {
|
hideWordFilteredPosts () {
|
||||||
return this.mergedConfig.hideWordFilteredPosts
|
return this.mergedConfig.hideWordFilteredPosts
|
||||||
},
|
},
|
||||||
|
@ -319,8 +358,9 @@ const Status = {
|
||||||
return (!this.shouldNotMute) && (
|
return (!this.shouldNotMute) && (
|
||||||
(this.muted && this.hideFilteredStatuses) ||
|
(this.muted && this.hideFilteredStatuses) ||
|
||||||
(this.userIsMuted && this.hideMutedUsers) ||
|
(this.userIsMuted && this.hideMutedUsers) ||
|
||||||
(this.status.thread_muted && this.hideMutedThreads) ||
|
((this.status.thread_muted || this.mentionsMutedUser) && this.hideMutedThreads) ||
|
||||||
(this.muteWordHits.length > 0 && this.hideWordFilteredPosts)
|
(this.muteWordHits.length > 0 && this.hideWordFilteredPosts) ||
|
||||||
|
(this.mentionsBlockedUser && this.hideThreadsWithBlockedUsers)
|
||||||
)
|
)
|
||||||
},
|
},
|
||||||
isFocused () {
|
isFocused () {
|
||||||
|
|
|
@ -157,16 +157,19 @@
|
||||||
|
|
||||||
--emoji-size: 16px;
|
--emoji-size: 16px;
|
||||||
|
|
||||||
& .body,
|
& .body:not(:active),
|
||||||
& .attachments {
|
& .attachments {
|
||||||
max-height: 3.25em;
|
max-height: 3.25em;
|
||||||
}
|
}
|
||||||
|
|
||||||
.body {
|
.body {
|
||||||
overflow: hidden;
|
|
||||||
white-space: normal;
|
white-space: normal;
|
||||||
min-width: 5em;
|
min-width: 5em;
|
||||||
flex: 5 1 auto;
|
flex: 5 1 auto;
|
||||||
|
}
|
||||||
|
|
||||||
|
.body:not(:active) {
|
||||||
|
overflow: hidden;
|
||||||
mask-size: auto 3.5em, auto auto;
|
mask-size: auto 3.5em, auto auto;
|
||||||
mask-position: 0 0, 0 0;
|
mask-position: 0 0, 0 0;
|
||||||
mask-repeat: repeat-x, repeat;
|
mask-repeat: repeat-x, repeat;
|
||||||
|
|
|
@ -23,7 +23,7 @@
|
||||||
"media_removal_desc": "Aquesta instància elimina els adjunts multimèdia dels apunts de les següents instàncies:",
|
"media_removal_desc": "Aquesta instància elimina els adjunts multimèdia dels apunts de les següents instàncies:",
|
||||||
"not_applicable": "N/A",
|
"not_applicable": "N/A",
|
||||||
"quarantine": "Quarantena",
|
"quarantine": "Quarantena",
|
||||||
"quarantine_desc": "Aquesta instància només enviarà entrades públiques a les següents instàncies:",
|
"quarantine_desc": "Aquesta instància no enviarà apunts a les següents instàncies:",
|
||||||
"reason": "Motiu",
|
"reason": "Motiu",
|
||||||
"reject": "Rebutja",
|
"reject": "Rebutja",
|
||||||
"reject_desc": "Aquesta instància no acceptarà missatges de les següents instàncies:",
|
"reject_desc": "Aquesta instància no acceptarà missatges de les següents instàncies:",
|
||||||
|
|
|
@ -23,7 +23,7 @@
|
||||||
"media_removal_desc": "This instance removes media from posts on the following instances:",
|
"media_removal_desc": "This instance removes media from posts on the following instances:",
|
||||||
"not_applicable": "N/A",
|
"not_applicable": "N/A",
|
||||||
"quarantine": "Quarantine",
|
"quarantine": "Quarantine",
|
||||||
"quarantine_desc": "This instance will send only public posts to the following instances:",
|
"quarantine_desc": "This instance will not send posts to the following instances:",
|
||||||
"reason": "Reason",
|
"reason": "Reason",
|
||||||
"reject": "Reject",
|
"reject": "Reject",
|
||||||
"reject_desc": "This instance will not accept messages from the following instances:",
|
"reject_desc": "This instance will not accept messages from the following instances:",
|
||||||
|
@ -460,6 +460,7 @@
|
||||||
"hide_shoutbox": "Hide instance shoutbox",
|
"hide_shoutbox": "Hide instance shoutbox",
|
||||||
"hide_site_favicon": "Hide instance favicon in top panel",
|
"hide_site_favicon": "Hide instance favicon in top panel",
|
||||||
"hide_site_name": "Hide instance name in top panel",
|
"hide_site_name": "Hide instance name in top panel",
|
||||||
|
"hide_threads_with_blocked_users": "Hide threads tagging blocked users",
|
||||||
"hide_user_stats": "Hide user statistics (e.g. the number of followers)",
|
"hide_user_stats": "Hide user statistics (e.g. the number of followers)",
|
||||||
"hide_wallpaper": "Hide instance wallpaper",
|
"hide_wallpaper": "Hide instance wallpaper",
|
||||||
"hide_wordfiltered_statuses": "Hide word-filtered statuses",
|
"hide_wordfiltered_statuses": "Hide word-filtered statuses",
|
||||||
|
|
1979
src/i18n/fr.json
1979
src/i18n/fr.json
File diff suppressed because it is too large
Load diff
1320
src/i18n/nl.json
1320
src/i18n/nl.json
File diff suppressed because it is too large
Load diff
|
@ -31,6 +31,7 @@ export const defaultState = {
|
||||||
// bad name: actually hides posts of muted USERS
|
// bad name: actually hides posts of muted USERS
|
||||||
hideMutedPosts: undefined, // instance default
|
hideMutedPosts: undefined, // instance default
|
||||||
hideMutedThreads: undefined, // instance default
|
hideMutedThreads: undefined, // instance default
|
||||||
|
hideThreadsWithBlockedUsers: undefined, // instance default
|
||||||
hideWordFilteredPosts: undefined, // instance default
|
hideWordFilteredPosts: undefined, // instance default
|
||||||
muteBotStatuses: undefined, // instance default
|
muteBotStatuses: undefined, // instance default
|
||||||
collapseMessageWithSubject: undefined, // instance default
|
collapseMessageWithSubject: undefined, // instance default
|
||||||
|
|
|
@ -30,6 +30,7 @@ const defaultState = {
|
||||||
// bad name: actually hides posts of muted USERS
|
// bad name: actually hides posts of muted USERS
|
||||||
hideMutedPosts: false,
|
hideMutedPosts: false,
|
||||||
hideMutedThreads: true,
|
hideMutedThreads: true,
|
||||||
|
hideThreadsWithBlockedUsers: false,
|
||||||
hideWordFilteredPosts: false,
|
hideWordFilteredPosts: false,
|
||||||
hidePostStats: false,
|
hidePostStats: false,
|
||||||
hideBotIndication: false,
|
hideBotIndication: false,
|
||||||
|
|
|
@ -57,12 +57,16 @@ const actions = {
|
||||||
commit('setList', { id, title })
|
commit('setList', { id, title })
|
||||||
},
|
},
|
||||||
setListAccounts ({ rootState, commit }, { id, accountIds }) {
|
setListAccounts ({ rootState, commit }, { id, accountIds }) {
|
||||||
|
const saved = rootState.lists.allListsObject[id].accountIds
|
||||||
|
const added = accountIds.filter(id => !saved.includes(id))
|
||||||
|
const removed = saved.filter(id => !accountIds.includes(id))
|
||||||
commit('setListAccounts', { id, accountIds })
|
commit('setListAccounts', { id, accountIds })
|
||||||
rootState.api.backendInteractor.addAccountsToList({ id, accountIds })
|
if (added.length > 0) {
|
||||||
rootState.api.backendInteractor.removeAccountsFromList({
|
rootState.api.backendInteractor.addAccountsToList({ id, accountIds: added })
|
||||||
id,
|
}
|
||||||
accountIds: rootState.lists.allListsObject[id].accountIds.filter(id => !accountIds.includes(id))
|
if (removed.length > 0) {
|
||||||
})
|
rootState.api.backendInteractor.removeAccountsFromList({ id, accountIds: removed })
|
||||||
|
}
|
||||||
},
|
},
|
||||||
deleteList ({ rootState, commit }, { id }) {
|
deleteList ({ rootState, commit }, { id }) {
|
||||||
rootState.api.backendInteractor.deleteList({ id })
|
rootState.api.backendInteractor.deleteList({ id })
|
||||||
|
@ -76,7 +80,7 @@ export const getters = {
|
||||||
return state.allListsObject[id].title
|
return state.allListsObject[id].title
|
||||||
},
|
},
|
||||||
findListAccounts: state => id => {
|
findListAccounts: state => id => {
|
||||||
return state.allListsObject[id].accountIds
|
return [...state.allListsObject[id].accountIds]
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -37,11 +37,11 @@
|
||||||
}
|
}
|
||||||
|
|
||||||
._mfm_jump_ {
|
._mfm_jump_ {
|
||||||
animation: mfm-jump 0.75 linear infinite;
|
animation: mfm-jump 0.75s linear infinite;
|
||||||
}
|
}
|
||||||
|
|
||||||
._mfm_bounce_ {
|
._mfm_bounce_ {
|
||||||
animation: mfm-bounce 0.75 linear infinite;
|
animation: mfm-bounce 0.75s linear infinite;
|
||||||
transform-origin: center bottom;
|
transform-origin: center bottom;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -67,7 +67,13 @@
|
||||||
font-size: 600%;
|
font-size: 600%;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* blur */
|
._mfm_blur_ {
|
||||||
|
filter: blur(6px);
|
||||||
|
transition: filter 0.3s
|
||||||
|
}
|
||||||
|
._mfm_blur_:hover {
|
||||||
|
filter: blur(0px);
|
||||||
|
}
|
||||||
|
|
||||||
._mfm_rainbow_ {
|
._mfm_rainbow_ {
|
||||||
animation: mfm-rainbow 1s linear infinite;
|
animation: mfm-rainbow 1s linear infinite;
|
||||||
|
|
Loading…
Reference in a new issue