forked from AkkomaGang/akkoma-fe
Merge branch 'feature/follow-import' into 'develop'
Add feature: follow import. See merge request pleroma/pleroma-fe!188
This commit is contained in:
commit
28872d8da4
6 changed files with 71 additions and 5 deletions
|
@ -5,7 +5,10 @@ const UserSettings = {
|
||||||
return {
|
return {
|
||||||
newname: this.$store.state.users.currentUser.name,
|
newname: this.$store.state.users.currentUser.name,
|
||||||
newbio: this.$store.state.users.currentUser.description,
|
newbio: this.$store.state.users.currentUser.description,
|
||||||
uploading: [ false, false, false ],
|
followList: null,
|
||||||
|
followImportError: false,
|
||||||
|
followsImported: false,
|
||||||
|
uploading: [ false, false, false, false ],
|
||||||
previews: [ null, null, null ]
|
previews: [ null, null, null ]
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
@ -15,6 +18,9 @@ const UserSettings = {
|
||||||
computed: {
|
computed: {
|
||||||
user () {
|
user () {
|
||||||
return this.$store.state.users.currentUser
|
return this.$store.state.users.currentUser
|
||||||
|
},
|
||||||
|
pleromaBackend () {
|
||||||
|
return this.$store.state.config.pleromaBackend
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
methods: {
|
methods: {
|
||||||
|
@ -117,6 +123,29 @@ const UserSettings = {
|
||||||
}
|
}
|
||||||
this.uploading[2] = false
|
this.uploading[2] = false
|
||||||
})
|
})
|
||||||
|
},
|
||||||
|
importFollows () {
|
||||||
|
this.uploading[3] = true
|
||||||
|
const followList = this.followList
|
||||||
|
this.$store.state.api.backendInteractor.followImport({params: followList})
|
||||||
|
.then((status) => {
|
||||||
|
if (status) {
|
||||||
|
this.followsImported = true
|
||||||
|
} else {
|
||||||
|
this.followImportError = true
|
||||||
|
}
|
||||||
|
this.uploading[3] = false
|
||||||
|
})
|
||||||
|
},
|
||||||
|
followListChange () {
|
||||||
|
// eslint-disable-next-line no-undef
|
||||||
|
let formData = new FormData()
|
||||||
|
formData.append('list', this.$refs.followlist.files[0])
|
||||||
|
this.followList = formData
|
||||||
|
},
|
||||||
|
dismissImported () {
|
||||||
|
this.followsImported = false
|
||||||
|
this.followImportError = false
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -49,6 +49,23 @@
|
||||||
<i class="base09 icon-spin4 animate-spin uploading" v-if="uploading[2]"></i>
|
<i class="base09 icon-spin4 animate-spin uploading" v-if="uploading[2]"></i>
|
||||||
<button class="btn btn-default base05 base02-background" v-else-if="previews[2]" @click="submitBg">{{$t('general.submit')}}</button>
|
<button class="btn btn-default base05 base02-background" v-else-if="previews[2]" @click="submitBg">{{$t('general.submit')}}</button>
|
||||||
</div>
|
</div>
|
||||||
|
<div class="setting-item" v-if="pleromaBackend">
|
||||||
|
<h3>{{$t('settings.follow_import')}}</h3>
|
||||||
|
<p>{{$t('settings.import_followers_from_a_csv_file')}}</p>
|
||||||
|
<form v-model="followImportForm">
|
||||||
|
<input type="file" ref="followlist" v-on:change="followListChange"></input>
|
||||||
|
</form>
|
||||||
|
<i class="base09 icon-spin4 animate-spin uploading" v-if="uploading[3]"></i>
|
||||||
|
<button class="btn btn-default base05 base02-background" v-else @click="importFollows">{{$t('general.submit')}}</button>
|
||||||
|
<div v-if="followsImported">
|
||||||
|
<i class="icon-cross" @click="dismissImported"></i>
|
||||||
|
<p>{{$t('settings.follows_imported')}}</p>
|
||||||
|
</div>
|
||||||
|
<div v-else-if="followImportError">
|
||||||
|
<i class="icon-cross" @click="dismissImported"</i>
|
||||||
|
<p>{{$t('settings.follow_import_error')}}</p>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</template>
|
</template>
|
||||||
|
|
|
@ -242,7 +242,11 @@ const en = {
|
||||||
nsfw_clickthrough: 'Enable clickthrough NSFW attachment hiding',
|
nsfw_clickthrough: 'Enable clickthrough NSFW attachment hiding',
|
||||||
autoload: 'Enable automatic loading when scrolled to the bottom',
|
autoload: 'Enable automatic loading when scrolled to the bottom',
|
||||||
streaming: 'Enable automatic streaming of new posts when scrolled to the top',
|
streaming: 'Enable automatic streaming of new posts when scrolled to the top',
|
||||||
reply_link_preview: 'Enable reply-link preview on mouse hover'
|
reply_link_preview: 'Enable reply-link preview on mouse hover',
|
||||||
|
follow_import: 'Follow import',
|
||||||
|
import_followers_from_a_csv_file: 'Import followers from a csv file',
|
||||||
|
follows_imported: 'Follows imported! Processing them will take a while.',
|
||||||
|
follow_import_error: 'Error importing followers'
|
||||||
},
|
},
|
||||||
notifications: {
|
notifications: {
|
||||||
notifications: 'Notifications',
|
notifications: 'Notifications',
|
||||||
|
|
|
@ -137,8 +137,11 @@ window.fetch('/api/pleroma/emoji.json')
|
||||||
return { shortcode: key, image_url: values[key] }
|
return { shortcode: key, image_url: values[key] }
|
||||||
})
|
})
|
||||||
store.dispatch('setOption', { name: 'emoji', value: emoji })
|
store.dispatch('setOption', { name: 'emoji', value: emoji })
|
||||||
|
store.dispatch('setOption', { name: 'pleromaBackend', value: true })
|
||||||
},
|
},
|
||||||
(failure) => {}
|
(failure) => {
|
||||||
|
store.dispatch('setOption', { name: 'pleromaBackend', value: false })
|
||||||
|
}
|
||||||
),
|
),
|
||||||
(error) => console.log(error)
|
(error) => console.log(error)
|
||||||
)
|
)
|
||||||
|
|
|
@ -29,6 +29,7 @@ const QVITTER_USER_TIMELINE_URL = '/api/qvitter/statuses/user_timeline.json'
|
||||||
const BLOCKING_URL = '/api/blocks/create.json'
|
const BLOCKING_URL = '/api/blocks/create.json'
|
||||||
const UNBLOCKING_URL = '/api/blocks/destroy.json'
|
const UNBLOCKING_URL = '/api/blocks/destroy.json'
|
||||||
const USER_URL = '/api/users/show.json'
|
const USER_URL = '/api/users/show.json'
|
||||||
|
const FOLLOW_IMPORT_URL = '/api/pleroma/follow_import'
|
||||||
|
|
||||||
import { each, map } from 'lodash'
|
import { each, map } from 'lodash'
|
||||||
import 'whatwg-fetch'
|
import 'whatwg-fetch'
|
||||||
|
@ -362,6 +363,15 @@ const uploadMedia = ({formData, credentials}) => {
|
||||||
.then((text) => (new DOMParser()).parseFromString(text, 'application/xml'))
|
.then((text) => (new DOMParser()).parseFromString(text, 'application/xml'))
|
||||||
}
|
}
|
||||||
|
|
||||||
|
const followImport = ({params, credentials}) => {
|
||||||
|
return fetch(FOLLOW_IMPORT_URL, {
|
||||||
|
body: params,
|
||||||
|
method: 'POST',
|
||||||
|
headers: authHeaders(credentials)
|
||||||
|
})
|
||||||
|
.then((response) => response.ok)
|
||||||
|
}
|
||||||
|
|
||||||
const fetchMutes = ({credentials}) => {
|
const fetchMutes = ({credentials}) => {
|
||||||
const url = '/api/qvitter/mutes.json'
|
const url = '/api/qvitter/mutes.json'
|
||||||
|
|
||||||
|
@ -396,7 +406,8 @@ const apiService = {
|
||||||
updateBg,
|
updateBg,
|
||||||
updateProfile,
|
updateProfile,
|
||||||
updateBanner,
|
updateBanner,
|
||||||
externalProfile
|
externalProfile,
|
||||||
|
followImport
|
||||||
}
|
}
|
||||||
|
|
||||||
export default apiService
|
export default apiService
|
||||||
|
|
|
@ -59,6 +59,7 @@ const backendInteractorService = (credentials) => {
|
||||||
const updateProfile = ({params}) => apiService.updateProfile({credentials, params})
|
const updateProfile = ({params}) => apiService.updateProfile({credentials, params})
|
||||||
|
|
||||||
const externalProfile = (profileUrl) => apiService.externalProfile({profileUrl, credentials})
|
const externalProfile = (profileUrl) => apiService.externalProfile({profileUrl, credentials})
|
||||||
|
const followImport = ({params}) => apiService.followImport({params, credentials})
|
||||||
|
|
||||||
const backendInteractorServiceInstance = {
|
const backendInteractorServiceInstance = {
|
||||||
fetchStatus,
|
fetchStatus,
|
||||||
|
@ -80,7 +81,8 @@ const backendInteractorService = (credentials) => {
|
||||||
updateBg,
|
updateBg,
|
||||||
updateBanner,
|
updateBanner,
|
||||||
updateProfile,
|
updateProfile,
|
||||||
externalProfile
|
externalProfile,
|
||||||
|
followImport
|
||||||
}
|
}
|
||||||
|
|
||||||
return backendInteractorServiceInstance
|
return backendInteractorServiceInstance
|
||||||
|
|
Loading…
Reference in a new issue