mirror of
https://github.com/aelve/guide.git
synced 2024-11-26 03:08:37 +03:00
Categories category links moved to external component
This commit is contained in:
parent
4ac5c1820c
commit
00d5d2c857
@ -24,30 +24,23 @@
|
||||
{{ groupName }}
|
||||
</h2>
|
||||
|
||||
<!-- TODO remove duplication of category title links (move to component or refactor v-for) -->
|
||||
<router-link
|
||||
class="category-title ml-2"
|
||||
data-testid="Categories-CategoryTitle"
|
||||
<CategoriesCategoryLink
|
||||
v-for="category in groupCategories[CategoryStatus.finished]"
|
||||
:key="category.id"
|
||||
:to="`/haskell/${getCategoryUrl(category)}`"
|
||||
>
|
||||
{{ category.title }}
|
||||
</router-link>
|
||||
:category="category"
|
||||
class="ml-2"
|
||||
/>
|
||||
|
||||
<template v-if="groupCategories[CategoryStatus.inProgress]">
|
||||
<h3 class="status-title">
|
||||
In progress
|
||||
</h3>
|
||||
<router-link
|
||||
class="category-title ml-3"
|
||||
data-testid="Categories-CategoryTitle"
|
||||
<CategoriesCategoryLink
|
||||
v-for="category in groupCategories[CategoryStatus.inProgress]"
|
||||
:key="category.id"
|
||||
:to="`/haskell/${getCategoryUrl(category)}`"
|
||||
>
|
||||
{{ category.title }}
|
||||
</router-link>
|
||||
:category="category"
|
||||
class="ml-3"
|
||||
/>
|
||||
</template>
|
||||
|
||||
<template v-if="groupCategories[CategoryStatus.toBeWritten]">
|
||||
@ -55,15 +48,12 @@
|
||||
To be written
|
||||
</h3>
|
||||
|
||||
<router-link
|
||||
class="category-title ml-3"
|
||||
data-testid="Categories-CategoryTitle"
|
||||
<CategoriesCategoryLink
|
||||
v-for="category in groupCategories[CategoryStatus.toBeWritten]"
|
||||
:key="category.id"
|
||||
:to="`/haskell/${getCategoryUrl(category)}`"
|
||||
>
|
||||
{{ category.title }}
|
||||
</router-link>
|
||||
:category="category"
|
||||
class="ml-3"
|
||||
/>
|
||||
</template>
|
||||
|
||||
<AddCategoryBtn @click="openAddCategoryDialog(groupName)"/>
|
||||
@ -84,6 +74,7 @@ import Vue from 'vue'
|
||||
import Component from 'vue-class-component'
|
||||
import AddCategoryDialog from 'client/components/AddCategoryDialog.vue'
|
||||
import AddCategoryBtn from 'client/components/AddCategoryBtn.vue'
|
||||
import CategoriesCategoryLink from 'client/components/CategoriesCategoryLink.vue'
|
||||
import _groupBy from 'lodash/groupBy'
|
||||
import _sortBy from 'lodash/sortBy'
|
||||
import _fromPairs from 'lodash/fromPairs'
|
||||
@ -93,7 +84,8 @@ import { ICategoryInfo, CategoryStatus } from 'client/service/Category'
|
||||
@Component({
|
||||
components: {
|
||||
AddCategoryDialog,
|
||||
AddCategoryBtn
|
||||
AddCategoryBtn,
|
||||
CategoriesCategoryLink
|
||||
}
|
||||
})
|
||||
export default class Categories extends Vue {
|
||||
@ -127,8 +119,6 @@ export default class Categories extends Vue {
|
||||
this.addCategoryGroupName = groupName
|
||||
this.isAddGroupDialogOpen = true
|
||||
}
|
||||
|
||||
getCategoryUrl = getCategoryUrl
|
||||
}
|
||||
</script>
|
||||
|
||||
@ -194,12 +184,6 @@ export default class Categories extends Vue {
|
||||
max-width: 90%;
|
||||
word-break: break-word;
|
||||
}
|
||||
.category-title {
|
||||
font-size: 0.9rem;
|
||||
font-weight: 600;
|
||||
margin-top: 5px;
|
||||
}
|
||||
.category-title,
|
||||
.status-title {
|
||||
line-height: 1.2;
|
||||
}
|
||||
@ -207,7 +191,7 @@ export default class Categories extends Vue {
|
||||
font-size: 0.9rem;
|
||||
margin: 6px 0 4px 8px;
|
||||
|
||||
+ .category-title {
|
||||
+ >>> .categories__category-link {
|
||||
margin-top: 0;
|
||||
}
|
||||
}
|
||||
|
32
front/client/components/CategoriesCategoryLink.vue
Normal file
32
front/client/components/CategoriesCategoryLink.vue
Normal file
@ -0,0 +1,32 @@
|
||||
<template>
|
||||
<router-link
|
||||
class="categories__category-link"
|
||||
data-testid="Categories-CategoryTitle"
|
||||
:to="`/haskell/${getCategoryUrl(category)}`"
|
||||
>
|
||||
{{ category.title }}
|
||||
</router-link>
|
||||
</template>
|
||||
|
||||
<script lang="ts">
|
||||
import Vue from 'vue'
|
||||
import Component from 'vue-class-component'
|
||||
import { Prop } from 'vue-property-decorator'
|
||||
import getCategoryUrl from 'client/helpers/getCategoryUrl'
|
||||
|
||||
@Component
|
||||
export default class CategoriesCategoryLink extends Vue {
|
||||
@Prop(Object) category: object
|
||||
|
||||
getCategoryUrl = getCategoryUrl
|
||||
}
|
||||
</script>
|
||||
|
||||
<style scoped>
|
||||
.categories__category-link {
|
||||
font-size: 0.9rem;
|
||||
font-weight: 600;
|
||||
margin-top: 5px;
|
||||
line-height: 1.2;
|
||||
}
|
||||
</style>
|
Loading…
Reference in New Issue
Block a user