koel/resources/assets/js/components/screens/user-list.vue

56 lines
1.8 KiB
Vue
Raw Normal View History

2022-04-15 14:24:30 +00:00
<template>
<section id="usersWrapper">
2022-04-15 17:00:08 +00:00
<ScreenHeader>
2022-04-15 14:24:30 +00:00
Users
2022-04-15 17:00:08 +00:00
<ControlsToggler :showing-controls="showingControls" @toggleControls="toggleControls"/>
2022-04-15 14:24:30 +00:00
<template v-slot:controls>
2022-04-15 17:00:08 +00:00
<BtnGroup uppercased v-if="showingControls || !isPhone">
<Btn class="btn-add" @click="showAddUserForm" green data-testid="add-user-btn">
2022-04-15 14:24:30 +00:00
<i class="fa fa-plus"></i>
Add
2022-04-15 17:00:08 +00:00
</Btn>
</BtnGroup>
2022-04-15 14:24:30 +00:00
</template>
2022-04-15 17:00:08 +00:00
</ScreenHeader>
2022-04-15 14:24:30 +00:00
<div class="main-scroll-wrap">
<div class="users">
2022-04-15 17:00:08 +00:00
<UserCard v-for="user in state.users" :user="user" @editUser="showEditUserForm" :key="user.id"/>
2022-04-15 14:24:30 +00:00
</div>
</div>
</section>
</template>
2022-04-15 17:00:08 +00:00
<script lang="ts" setup>
import { defineAsyncComponent, reactive, ref } from 'vue'
2022-04-15 14:24:30 +00:00
import isMobile from 'ismobilejs'
import { userStore } from '@/stores'
import { eventBus } from '@/utils'
2022-04-21 16:06:45 +00:00
const ScreenHeader = defineAsyncComponent(() => import('@/components/ui/ScreenHeader.vue'))
const ControlsToggler = defineAsyncComponent(() => import('@/components/ui/ScreenControlsToggler.vue'))
2022-04-15 17:00:08 +00:00
const Btn = defineAsyncComponent(() => import('@/components/ui/btn.vue'))
2022-04-21 16:06:45 +00:00
const BtnGroup = defineAsyncComponent(() => import('@/components/ui/BtnGroup.vue'))
2022-04-15 17:00:08 +00:00
const UserCard = defineAsyncComponent(() => import('@/components/user/card.vue'))
2022-04-15 14:24:30 +00:00
2022-04-15 17:00:08 +00:00
const state = reactive(userStore.state)
const isPhone = isMobile.phone
const showingControls = ref(false)
2022-04-15 14:24:30 +00:00
2022-04-15 17:00:08 +00:00
const toggleControls = () => (showingControls.value = !showingControls.value)
const showAddUserForm = () => eventBus.emit('MODAL_SHOW_ADD_USER_FORM')
const showEditUserForm = (user: User) => eventBus.emit('MODAL_SHOW_EDIT_USER_FORM', user)
2022-04-15 14:24:30 +00:00
</script>
<style lang="scss">
#usersWrapper {
.users {
display: grid;
grid-gap: .7rem 1rem;
grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
}
}
</style>