forked from AkkomaGang/akkoma-fe
54 lines
1.3 KiB
JavaScript
54 lines
1.3 KiB
JavaScript
const ScopeSelector = {
|
|
props: [
|
|
'showAll',
|
|
'userDefault',
|
|
'originalScope',
|
|
'initialScope',
|
|
'onScopeChange'
|
|
],
|
|
data () {
|
|
return {
|
|
currentScope: this.initialScope
|
|
}
|
|
},
|
|
computed: {
|
|
showNothing () {
|
|
return !this.showPublic && !this.showUnlisted && !this.showPrivate && !this.showDirect
|
|
},
|
|
showPublic () {
|
|
return this.originalScope !== 'direct' && this.shouldShow('public')
|
|
},
|
|
showUnlisted () {
|
|
return this.originalScope !== 'direct' && this.shouldShow('unlisted')
|
|
},
|
|
showPrivate () {
|
|
return this.originalScope !== 'direct' && this.shouldShow('private')
|
|
},
|
|
showDirect () {
|
|
return this.shouldShow('direct')
|
|
},
|
|
css () {
|
|
return {
|
|
public: {selected: this.currentScope === 'public'},
|
|
unlisted: {selected: this.currentScope === 'unlisted'},
|
|
private: {selected: this.currentScope === 'private'},
|
|
direct: {selected: this.currentScope === 'direct'}
|
|
}
|
|
}
|
|
},
|
|
methods: {
|
|
shouldShow (scope) {
|
|
return this.showAll ||
|
|
this.currentScope === scope ||
|
|
this.originalScope === scope ||
|
|
this.userDefault === scope ||
|
|
scope === 'direct'
|
|
},
|
|
changeVis (scope) {
|
|
this.currentScope = scope
|
|
this.onScopeChange && this.onScopeChange(scope)
|
|
}
|
|
}
|
|
}
|
|
|
|
export default ScopeSelector
|