Task list improvements
All checks were successful
Build BAB Application Deployment Artifact / build (push) Successful in 1m47s
All checks were successful
Build BAB Application Deployment Artifact / build (push) Successful in 1m47s
This commit is contained in:
@@ -15,21 +15,6 @@
|
|||||||
:filter-method="filterRows"
|
:filter-method="filterRows"
|
||||||
>
|
>
|
||||||
<template v-slot:top>
|
<template v-slot:top>
|
||||||
<q-btn
|
|
||||||
color="primary"
|
|
||||||
:disable="loading"
|
|
||||||
label="New Task"
|
|
||||||
to="/task/edit"
|
|
||||||
/>
|
|
||||||
<q-btn
|
|
||||||
v-if="tasks.length !== 0"
|
|
||||||
class="q-ml-sm"
|
|
||||||
color="primary"
|
|
||||||
:disable="loading"
|
|
||||||
label="Delete task(s)"
|
|
||||||
@click="deleteTasks"
|
|
||||||
/>
|
|
||||||
<q-space />
|
|
||||||
<q-select
|
<q-select
|
||||||
style="width: 250px"
|
style="width: 250px"
|
||||||
multiple
|
multiple
|
||||||
@@ -64,6 +49,7 @@
|
|||||||
flatten
|
flatten
|
||||||
debounce="300"
|
debounce="300"
|
||||||
color="primary"
|
color="primary"
|
||||||
|
clearable
|
||||||
v-model="searchFilter.title"
|
v-model="searchFilter.title"
|
||||||
>
|
>
|
||||||
<template v-slot:append>
|
<template v-slot:append>
|
||||||
@@ -121,7 +107,107 @@
|
|||||||
/>
|
/>
|
||||||
</q-td>
|
</q-td>
|
||||||
</template>
|
</template>
|
||||||
|
<template v-slot:item="props">
|
||||||
|
<div
|
||||||
|
class="q-pa-xs col-xs-12 col-sm-6 col-md-4 col-lg-3 grid-style-transition"
|
||||||
|
:style="props.selected ? 'transform: scale(0.95);' : ''"
|
||||||
|
>
|
||||||
|
<q-card
|
||||||
|
bordered
|
||||||
|
flat
|
||||||
|
:class="
|
||||||
|
props.selected
|
||||||
|
? $q.dark.isActive
|
||||||
|
? 'bg-grey-9'
|
||||||
|
: 'bg-grey-2'
|
||||||
|
: ''
|
||||||
|
"
|
||||||
|
>
|
||||||
|
<q-card-section>
|
||||||
|
<q-checkbox
|
||||||
|
dense
|
||||||
|
v-model="props.selected"
|
||||||
|
:label="props.row.name"
|
||||||
|
/>
|
||||||
|
</q-card-section>
|
||||||
|
<q-separator />
|
||||||
|
<q-list dense>
|
||||||
|
<q-item
|
||||||
|
v-for="col in props.cols.filter((col) => col.name !== 'desc')"
|
||||||
|
:key="col.name"
|
||||||
|
>
|
||||||
|
<q-item-section>
|
||||||
|
<q-item-label>{{ col.label }}</q-item-label>
|
||||||
|
</q-item-section>
|
||||||
|
<q-item-section side>
|
||||||
|
<q-item-label caption v-if="col.name === 'skills'">
|
||||||
|
<q-chip
|
||||||
|
size="sm"
|
||||||
|
v-for="skill in col.value"
|
||||||
|
outline
|
||||||
|
color="primary"
|
||||||
|
:key="skill.$id"
|
||||||
|
>{{ skill.name }}</q-chip
|
||||||
|
></q-item-label
|
||||||
|
>
|
||||||
|
<q-item-label caption v-else-if="col.name === 'tags'">
|
||||||
|
<q-chip
|
||||||
|
size="sm"
|
||||||
|
v-for="tag in col.value"
|
||||||
|
outline
|
||||||
|
color="primary"
|
||||||
|
:key="tag.$id"
|
||||||
|
>{{ tag.name }}</q-chip
|
||||||
|
></q-item-label
|
||||||
|
>
|
||||||
|
<q-item-label caption v-else-if="col.name === 'actions'">
|
||||||
|
<q-btn
|
||||||
|
label="Sign Up"
|
||||||
|
size="sm"
|
||||||
|
color="primary"
|
||||||
|
:to="{ name: 'signup-task', params: { id: col.value } }"
|
||||||
|
/>
|
||||||
|
<q-btn
|
||||||
|
label="Edit"
|
||||||
|
size="sm"
|
||||||
|
color="primary"
|
||||||
|
:to="{ name: 'edit-task', params: { id: col.value } }"
|
||||||
|
/>
|
||||||
|
</q-item-label>
|
||||||
|
<q-item-label v-else caption>{{ col.value }}</q-item-label>
|
||||||
|
</q-item-section>
|
||||||
|
</q-item>
|
||||||
|
</q-list>
|
||||||
|
</q-card>
|
||||||
|
</div>
|
||||||
|
</template>
|
||||||
</q-table>
|
</q-table>
|
||||||
|
<q-page-sticky position="bottom-right" :offset="[18, 18]">
|
||||||
|
<q-fab
|
||||||
|
v-model="fabShow"
|
||||||
|
vertical-actions-align="right"
|
||||||
|
color="primary"
|
||||||
|
glossy
|
||||||
|
icon="keyboard_arrow_up"
|
||||||
|
direction="up"
|
||||||
|
>
|
||||||
|
<q-fab-action
|
||||||
|
color="primary"
|
||||||
|
:disable="loading"
|
||||||
|
label="New Task"
|
||||||
|
to="/task/edit"
|
||||||
|
icon="add"
|
||||||
|
/>
|
||||||
|
<q-fab-action
|
||||||
|
v-if="tasks.length !== 0"
|
||||||
|
class="q-ml-sm"
|
||||||
|
color="primary"
|
||||||
|
:disable="loading"
|
||||||
|
label="Delete task(s)"
|
||||||
|
@click="deleteTasks"
|
||||||
|
icon="delete"
|
||||||
|
/> </q-fab
|
||||||
|
></q-page-sticky>
|
||||||
</div>
|
</div>
|
||||||
</template>
|
</template>
|
||||||
|
|
||||||
@@ -135,6 +221,7 @@ import { useRouter } from 'vue-router';
|
|||||||
const router = useRouter();
|
const router = useRouter();
|
||||||
const selected = ref([]);
|
const selected = ref([]);
|
||||||
const loading = ref(false); // Placeholder
|
const loading = ref(false); // Placeholder
|
||||||
|
const fabShow = ref(false);
|
||||||
const columns = <QTableProps['columns']>[
|
const columns = <QTableProps['columns']>[
|
||||||
{
|
{
|
||||||
name: 'title',
|
name: 'title',
|
||||||
@@ -240,14 +327,14 @@ const filterRows = computed(
|
|||||||
: true
|
: true
|
||||||
);
|
);
|
||||||
result = result.filter((row) =>
|
result = result.filter((row) =>
|
||||||
terms.skillTags.length > 0
|
terms.skillTags && terms.skillTags.length > 0
|
||||||
? row.required_skills.some((req_skill) =>
|
? row.required_skills.some((req_skill) =>
|
||||||
terms.skillTags.map((t) => t.$id).includes(req_skill)
|
terms.skillTags.map((t) => t.$id).includes(req_skill)
|
||||||
)
|
)
|
||||||
: true
|
: true
|
||||||
);
|
);
|
||||||
result = result.filter((row) =>
|
result = result.filter((row) =>
|
||||||
terms.taskTags.length > 0
|
terms.taskTags && terms.taskTags.length > 0
|
||||||
? row.tags.some((tag) => terms.taskTags.map((t) => t.$id).includes(tag))
|
? row.tags.some((tag) => terms.taskTags.map((t) => t.$id).includes(tag))
|
||||||
: true
|
: true
|
||||||
);
|
);
|
||||||
|
|||||||
Reference in New Issue
Block a user