Skip to content

Commit

Permalink
feat(NcRichContenteditable): programmatically show tributes
Browse files Browse the repository at this point in the history
Signed-off-by: DorraJaouad <dorra.jaoued7@gmail.com>
  • Loading branch information
DorraJaouad committed Jun 10, 2024
1 parent 224004b commit 310ac62
Showing 1 changed file with 66 additions and 0 deletions.
66 changes: 66 additions & 0 deletions src/components/NcRichContenteditable/NcRichContenteditable.vue
Original file line number Diff line number Diff line change
Expand Up @@ -210,6 +210,48 @@ export default {
</style>
```

### Using methods

```vue
<template>
<div>
<div class="buttons-wrapper">

Check failure on line 218 in src/components/NcRichContenteditable/NcRichContenteditable.vue

View workflow job for this annotation

GitHub Actions / NPM lint

Trailing spaces not allowed
<NcButton class="show-slash-button" @click.stop="showSlashCommands">Slash commands</NcButton>
<NcButton class="focus-button" @click.stop="focus">Focus on input</NcButton>
</div>
<NcRichContenteditable
ref="contenteditable"
label="Write a comment"
:value.sync="message"
:maxlength="100"/>
</div>
</template>
<script>
export default {
data() {
return {
message: '**Lorem ipsum** dolor sit amet. ',
}
},
methods: {
showSlashCommands() {
this.$refs.contenteditable.showTribute('/')
},
focus() {
this.$refs.contenteditable.focus()
},
},
}
</script>
<style lang="scss" scoped>
.buttons-wrapper {
display: flex;
gap: 10px;
margin-bottom: 20px;
}
</style>
```

</docs>

<template>
Expand Down Expand Up @@ -922,6 +964,8 @@ export default {
this.getTributeContainer().setAttribute('class', this.tribute.current.collection.containerClass || this.$style['tribute-container'])

this.setupTributeIntegration()
// Remove the event handler if any
document.removeEventListener('click', this.hideTribute)
} else {
// Cancel loading data for autocomplete
// Otherwise it could be received when another autocomplete is already opened
Expand Down Expand Up @@ -1001,6 +1045,28 @@ export default {
this.getTributeContainer().classList.remove(this.$style['tribute-container--focus-visible'])
}
},

/**
* Show tribute menu programmatically. If using a click event, stop propagation to prevent closing the menu
* @param {string} trigger - trigger character, can be '/', '@', or ':'
*
* @public
*/
showTribute(trigger) {
this.focus()
const index = this.tribute.collection.findIndex(collection => collection.trigger === trigger)
this.tribute.showMenuForCollection(this.$refs.contenteditable, index)
document.addEventListener('click', this.hideTribute)
},

/**
* Hide tribute menu programmatically
*
*/
hideTribute() {
this.tribute.hideMenu()
document.removeEventListener('click', this.hideTribute)
},
},
}
</script>
Expand Down

0 comments on commit 310ac62

Please sign in to comment.