mirror of
https://github.com/HabitRPG/habitica.git
synced 2025-12-16 06:07:21 +01:00
* add colors palette * add secondary menu component and style it * add box shadow to secondary menu * misc css, fixes for secondary menu * client: add equipment page with grouping, css: add some styles * add typography * more equipment * stable: fix linting * equipment: add styles (lots of general styles too) * remove duplicate google fonts loading * add dropdowns * design: white search input background, remove gray from items * start adding drawer and selected indicator * wip equipment * fix equipment * equipment: correctly bind new properties on items.gear.equipped * equipment: fix vue binding. version 2 * equipment: fix vue binding. version 3 * back to first fix for equip op, fix for sourcemaps, send http request when an item is equipped, load bootstrap-vue components where needed * checkboxes and radio buttons * correctly renders selected items in first postion during the first render * add search * general changes, constants part of app state, add popovers * add toggle switch, rename css * correct offset * upgrade deps * upgrade deps * drawer and lot of other work * update equipping mechanism * finish equipment * fix compilation and upgrade deps * use v-show in place of v-if to fix ui issues * v-show -> v-if * Start of guild syyles * fix linting in test/client * fix es6 compilation in test/client * fix babel compilation for tests * fix groupsUtilities mixin tests * More designs * Added public guild state * Added my guilds store * client: buttons * client: buttons: fix colors * Added join and leave * Began adding new guild form * Create form updates * Added search to local data * Added filtering * Added initial code for group create * Added more create checks * Added more guild routes * Added styles to guild page * Added more chat styles * Began porting over angular functions * Moved over group service functions * Added paging * Updated sidebar * Updated join/leave and minor text * Added new sidebar functions * Updated paging * Added some form updates * Added more translations and styles * Updated shrinkwrap * Removed features config * Lint cleanup * Added member modal * Added more member actions * Updated nav * Fixed filter toggling * Updated create guild * Added no guild page * Added sort select * Added more styles * Added update guild form * Removed extra css and other minor changes * Many css and syntax fixes * Fixed color and merge conflic * Removed paging from my guilds * Removed extra strings * Many requests updates * Small style fixes
153 lines
3.6 KiB
Vue
153 lines
3.6 KiB
Vue
<template lang="pug">
|
|
.col-2.standard-sidebar
|
|
.form-group
|
|
input.form-control.search(type="text", :placeholder="$t('search')", v-model='searchTerm')
|
|
|
|
form
|
|
h3(v-once) {{ $t('filter') }}
|
|
.form-group
|
|
h5 Category
|
|
.form-check(
|
|
v-for="group in categoryOptions",
|
|
:key="group.key",
|
|
)
|
|
label.custom-control.custom-checkbox
|
|
input.custom-control-input(type="checkbox", :value='group.key' v-model="categoryFilters")
|
|
span.custom-control-indicator
|
|
span.custom-control-description(v-once) {{ $t(group.label) }}
|
|
.form-group
|
|
h5 Role
|
|
.form-check(
|
|
v-for="group in roleOptions",
|
|
:key="group.key",
|
|
)
|
|
label.custom-control.custom-checkbox
|
|
input.custom-control-input(type="checkbox", :value='group.key' v-model="roleFilters")
|
|
span.custom-control-indicator
|
|
span.custom-control-description(v-once) {{ $t(group.label) }}
|
|
.form-group
|
|
h5 Guild Size
|
|
.form-check(
|
|
v-for="group in guildSizeOptions",
|
|
:key="group.key",
|
|
)
|
|
label.custom-control.custom-checkbox
|
|
input.custom-control-input(type="checkbox", :value='group.key' v-model="guildSizeFilters")
|
|
span.custom-control-indicator
|
|
span.custom-control-description(v-once) {{ $t(group.label) }}
|
|
</template>
|
|
|
|
<script>
|
|
import throttle from 'lodash/throttle';
|
|
|
|
export default {
|
|
data () {
|
|
return {
|
|
categoryFilters: [],
|
|
categoryOptions: [
|
|
{
|
|
label: 'habiticaOfficial',
|
|
key: 'official',
|
|
},
|
|
{
|
|
label: 'animals',
|
|
key: 'animals',
|
|
},
|
|
{
|
|
label: 'artDesign',
|
|
key: 'art_design',
|
|
},
|
|
{
|
|
label: 'booksWriting',
|
|
key: 'books_writing',
|
|
},
|
|
{
|
|
label: 'comicsHobbies',
|
|
key: 'comics_hobbies',
|
|
},
|
|
{
|
|
label: 'diyCrafts',
|
|
key: 'diy_crafts',
|
|
},
|
|
{
|
|
label: 'education',
|
|
key: 'education',
|
|
},
|
|
{
|
|
label: 'foodCooking',
|
|
key: 'food_cooking',
|
|
},
|
|
{
|
|
label: 'healthFitness',
|
|
key: 'health_fitness',
|
|
},
|
|
{
|
|
label: 'music',
|
|
key: 'music',
|
|
},
|
|
{
|
|
label: 'relationship',
|
|
key: 'relationship',
|
|
},
|
|
{
|
|
label: 'scienceTech',
|
|
key: 'science_tech ',
|
|
},
|
|
],
|
|
roleFilters: [],
|
|
roleOptions: [
|
|
{
|
|
label: 'guildLeader',
|
|
key: 'guild_leader',
|
|
},
|
|
{
|
|
label: 'member',
|
|
key: 'member',
|
|
},
|
|
],
|
|
guildSizeFilters: [],
|
|
guildSizeOptions: [
|
|
{
|
|
label: 'goldTier',
|
|
key: 'gold_tier',
|
|
},
|
|
{
|
|
label: 'silverTier',
|
|
key: 'silver_tier',
|
|
},
|
|
{
|
|
label: 'bronzeTier',
|
|
key: 'bronze_tier',
|
|
},
|
|
],
|
|
searchTerm: '',
|
|
};
|
|
},
|
|
watch: {
|
|
categoryFilters: function categoryFilters () {
|
|
this.emitFilters();
|
|
},
|
|
roleFilters: function roleFilters () {
|
|
this.emitFilters();
|
|
},
|
|
guildSizeFilters: function guildSizeFilters () {
|
|
this.emitFilters();
|
|
},
|
|
searchTerm: throttle(function searchTerm (newSearch) {
|
|
this.$emit('search', {
|
|
searchTerm: newSearch,
|
|
});
|
|
}, 250),
|
|
},
|
|
methods: {
|
|
emitFilters () {
|
|
this.$emit('filter', {
|
|
categories: this.categoryFilters,
|
|
roles: this.roleFilters,
|
|
guildSize: this.guildSizeFilters,
|
|
});
|
|
},
|
|
},
|
|
};
|
|
</script>
|