diff options
| author | shpuld <shp@cock.li> | 2019-04-01 22:42:06 +0300 |
|---|---|---|
| committer | shpuld <shp@cock.li> | 2019-04-01 22:42:06 +0300 |
| commit | 46de457f50416d0c8f37a833356b0b7ea643a53f (patch) | |
| tree | 2af3e96da21aee1e06f0eb6beff82c24770b7296 /src/components/scope_selector/scope_selector.js | |
| parent | 2879495b8ab16a07d337965871e951f660fc1815 (diff) | |
| parent | df366a586d6549b41d5537c57eb51c5f0f54a641 (diff) | |
Merge branch 'develop' into feature/mobile-improvements-3
Diffstat (limited to 'src/components/scope_selector/scope_selector.js')
| -rw-r--r-- | src/components/scope_selector/scope_selector.js | 54 |
1 files changed, 54 insertions, 0 deletions
diff --git a/src/components/scope_selector/scope_selector.js b/src/components/scope_selector/scope_selector.js new file mode 100644 index 00000000..8a42ee7b --- /dev/null +++ b/src/components/scope_selector/scope_selector.js @@ -0,0 +1,54 @@ +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 |
