diff options
author | Roeland Jago Douma <rullzer@users.noreply.github.com> | 2020-10-02 11:24:29 +0200 |
---|---|---|
committer | GitHub <noreply@github.com> | 2020-10-02 11:24:29 +0200 |
commit | 905e1918d2796b9a79025283cd6edf2c40f49d77 (patch) | |
tree | 7bedb43af8a3a1d1c911f2a63bfef708ce16057f /apps/user_status/src/components/OnlineStatusSelect.vue | |
parent | 5451dcbec504c3b0a9b57c0794e71868a9b6254e (diff) | |
parent | e9c7fa0f045756fe05ab7c4632cf886e329f4582 (diff) | |
download | nextcloud-server-905e1918d2796b9a79025283cd6edf2c40f49d77.tar.gz nextcloud-server-905e1918d2796b9a79025283cd6edf2c40f49d77.zip |
Merge pull request #23130 from nextcloud/fix/user-status
Move online status into modal
Diffstat (limited to 'apps/user_status/src/components/OnlineStatusSelect.vue')
-rw-r--r-- | apps/user_status/src/components/OnlineStatusSelect.vue | 103 |
1 files changed, 103 insertions, 0 deletions
diff --git a/apps/user_status/src/components/OnlineStatusSelect.vue b/apps/user_status/src/components/OnlineStatusSelect.vue new file mode 100644 index 00000000000..b03af75681e --- /dev/null +++ b/apps/user_status/src/components/OnlineStatusSelect.vue @@ -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> |