Merge pull request #23130 from nextcloud/fix/user-status
Move online status into modalpull/23136/head
commit
905e1918d2
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
@ -0,0 +1,103 @@ |
||||
<!-- |
||||
- @copyright Copyright (c) 2020 John Molakvoæ <skjnldsv@protonmail.com> |
||||
- |
||||
- @author John Molakvoæ <skjnldsv@protonmail.com> |
||||
- |
||||
- @license GNU AGPL version 3 or any later version |
||||
- |
||||
- This program is free software: you can redistribute it and/or modify |
||||
- it under the terms of the GNU Affero General Public License as |
||||
- published by the Free Software Foundation, either version 3 of the |
||||
- License, or (at your option) any later version. |
||||
- |
||||
- This program is distributed in the hope that it will be useful, |
||||
- but WITHOUT ANY WARRANTY; without even the implied warranty of |
||||
- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
||||
- GNU Affero General Public License for more details. |
||||
- |
||||
- You should have received a copy of the GNU Affero General Public License |
||||
- along with this program. If not, see <http://www.gnu.org/licenses/>. |
||||
- |
||||
--> |
||||
<template> |
||||
<div class="user-status-online-select"> |
||||
<input :id="id" |
||||
:checked="checked" |
||||
class="user-status-online-select__input" |
||||
type="radio" |
||||
name="user-status-online" |
||||
@change="onChange"> |
||||
<label :for="id" :class="icon" class="user-status-online-select__label"> |
||||
<slot /> |
||||
</label> |
||||
</div> |
||||
</template> |
||||
|
||||
<script> |
||||
export default { |
||||
name: 'OnlineStatusSelect', |
||||
|
||||
props: { |
||||
checked: { |
||||
type: Boolean, |
||||
default: false, |
||||
}, |
||||
icon: { |
||||
type: String, |
||||
required: true, |
||||
}, |
||||
type: { |
||||
type: String, |
||||
required: true, |
||||
}, |
||||
}, |
||||
|
||||
computed: { |
||||
id() { |
||||
return `user-status-online-status-${this.type}` |
||||
}, |
||||
}, |
||||
|
||||
methods: { |
||||
onChange() { |
||||
this.$emit('select', this.type) |
||||
}, |
||||
}, |
||||
} |
||||
</script> |
||||
|
||||
<style lang="scss" scoped> |
||||
$icon-size: 24px; |
||||
$label-padding: 8px; |
||||
|
||||
.user-status-online-select { |
||||
// Inputs are here for keyboard navigation, they are not visually visible |
||||
&__input { |
||||
position: absolute; |
||||
top: auto; |
||||
left: -10000px; |
||||
overflow: hidden; |
||||
width: 1px; |
||||
height: 1px; |
||||
} |
||||
|
||||
&__label { |
||||
display: block; |
||||
margin: $label-padding; |
||||
padding: $label-padding; |
||||
padding-left: $icon-size + $label-padding * 2; |
||||
border: 2px solid var(--color-main-background); |
||||
border-radius: var(--border-radius-large); |
||||
background-color: var(--color-background-hover); |
||||
background-position: $label-padding center; |
||||
background-size: $icon-size; |
||||
} |
||||
|
||||
&__input:checked + &__label, |
||||
&__input:focus + &__label, |
||||
&__label:hover { |
||||
border-color: var(--color-primary); |
||||
} |
||||
} |
||||
|
||||
</style> |
@ -0,0 +1,110 @@ |
||||
/** |
||||
* @copyright Copyright (c) 2020 John Molakvoæ <skjnldsv@protonmail.com> |
||||
* |
||||
* @author John Molakvoæ <skjnldsv@protonmail.com> |
||||
* |
||||
* @license GNU AGPL version 3 or any later version |
||||
* |
||||
* This program is free software: you can redistribute it and/or modify |
||||
* it under the terms of the GNU Affero General Public License as |
||||
* published by the Free Software Foundation, either version 3 of the |
||||
* License, or (at your option) any later version. |
||||
* |
||||
* This program is distributed in the hope that it will be useful, |
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of |
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
||||
* GNU Affero General Public License for more details. |
||||
* |
||||
* You should have received a copy of the GNU Affero General Public License |
||||
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||
* |
||||
*/ |
||||
import { mapState } from 'vuex' |
||||
import { showError } from '@nextcloud/dialogs' |
||||
|
||||
export default { |
||||
computed: { |
||||
...mapState({ |
||||
statusType: state => state.userStatus.status, |
||||
statusIsUserDefined: state => state.userStatus.statusIsUserDefined, |
||||
customIcon: state => state.userStatus.icon, |
||||
customMessage: state => state.userStatus.message, |
||||
}), |
||||
|
||||
/** |
||||
* The message displayed in the top right corner |
||||
* |
||||
* @returns {String} |
||||
*/ |
||||
visibleMessage() { |
||||
if (this.customIcon && this.customMessage) { |
||||
return `${this.customIcon} ${this.customMessage}` |
||||
} |
||||
|
||||
if (this.customMessage) { |
||||
return this.customMessage |
||||
} |
||||
|
||||
if (this.statusIsUserDefined) { |
||||
switch (this.statusType) { |
||||
case 'online': |
||||
return this.$t('user_status', 'Online') |
||||
|
||||
case 'away': |
||||
return this.$t('user_status', 'Away') |
||||
|
||||
case 'dnd': |
||||
return this.$t('user_status', 'Do not disturb') |
||||
|
||||
case 'invisible': |
||||
return this.$t('user_status', 'Invisible') |
||||
|
||||
case 'offline': |
||||
return this.$t('user_status', 'Offline') |
||||
} |
||||
} |
||||
|
||||
return this.$t('user_status', 'Set status') |
||||
}, |
||||
|
||||
/** |
||||
* The status indicator icon |
||||
* |
||||
* @returns {String|null} |
||||
*/ |
||||
statusIcon() { |
||||
switch (this.statusType) { |
||||
case 'online': |
||||
return 'icon-user-status-online' |
||||
|
||||
case 'away': |
||||
return 'icon-user-status-away' |
||||
|
||||
case 'dnd': |
||||
return 'icon-user-status-dnd' |
||||
|
||||
case 'invisible': |
||||
case 'offline': |
||||
return 'icon-user-status-invisible' |
||||
} |
||||
|
||||
return '' |
||||
}, |
||||
}, |
||||
|
||||
methods: { |
||||
/** |
||||
* Changes the user-status |
||||
* |
||||
* @param {String} statusType (online / away / dnd / invisible) |
||||
*/ |
||||
async changeStatus(statusType) { |
||||
try { |
||||
await this.$store.dispatch('setStatus', { statusType }) |
||||
} catch (err) { |
||||
showError(this.$t('user_status', 'There was an error saving the new status')) |
||||
console.debug(err) |
||||
} |
||||
}, |
||||
}, |
||||
} |
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
Loading…
Reference in new issue