mirror of
https://github.com/HabitRPG/habitica.git
synced 2025-12-17 06:37:23 +01:00
* Separated private message model * Added markdown to profile * Add color backgrounds * Added broken challenge flow * Added summary field to getgroups * Fixed group form information loading * Updated autocomplete to use chat * Fixed npc styles * Fixed onload mentions
77 lines
2.0 KiB
Vue
77 lines
2.0 KiB
Vue
<template lang="pug">
|
|
div.autocomplete-selection(v-if='searchResults.length > 0', :style='autocompleteStyle')
|
|
.autocomplete-results(v-for='result in searchResults', @click='select(result)') {{ result }}
|
|
</template>
|
|
|
|
<style scoped>
|
|
.autocomplete-results {
|
|
padding: .5em;
|
|
box-shadow: 1px 1px 1px #efefef;
|
|
}
|
|
</style>
|
|
|
|
<script>
|
|
import groupBy from 'lodash/groupBy';
|
|
|
|
export default {
|
|
props: ['selections', 'text', 'coords', 'chat'],
|
|
data () {
|
|
return {
|
|
currentSearch: '',
|
|
searchActive: false,
|
|
currentSearchPosition: 0,
|
|
tmpSelections: [],
|
|
};
|
|
},
|
|
computed: {
|
|
autocompleteStyle () {
|
|
return {
|
|
top: `${this.coords.TOP + 30}px`,
|
|
left: `${this.coords.LEFT + 30}px`,
|
|
position: 'absolute',
|
|
minWidth: '100px',
|
|
minHeight: '100px',
|
|
zIndex: 100,
|
|
backgroundColor: 'white',
|
|
};
|
|
},
|
|
searchResults () {
|
|
if (!this.searchActive) return [];
|
|
let currentSearch = this.text.substring(this.currentSearchPosition + 1, this.text.length);
|
|
return this.tmpSelections.filter((option) => {
|
|
return option.toLowerCase().indexOf(currentSearch.toLowerCase()) !== -1;
|
|
});
|
|
},
|
|
},
|
|
mounted () {
|
|
this.grabUserNames();
|
|
},
|
|
watch: {
|
|
text (newText) {
|
|
if (newText[newText.length - 1] !== '@') return;
|
|
this.searchActive = true;
|
|
this.currentSearchPosition = newText.length - 1;
|
|
},
|
|
chat () {
|
|
this.grabUserNames();
|
|
},
|
|
},
|
|
methods: {
|
|
grabUserNames () {
|
|
let usersThatMessage = groupBy(this.chat, 'user');
|
|
for (let userName in usersThatMessage) {
|
|
let systemMessage = userName === 'undefined';
|
|
if (!systemMessage && this.tmpSelections.indexOf(userName) === -1) {
|
|
this.tmpSelections.push(userName);
|
|
}
|
|
}
|
|
},
|
|
select (result) {
|
|
let newText = this.text.slice(0, this.currentSearchPosition + 1) + result;
|
|
this.searchActive = false;
|
|
this.$emit('select', newText);
|
|
},
|
|
},
|
|
};
|
|
</script>
|