Skip to content

Commit

Permalink
Add disabled state to RichContenteditable
Browse files Browse the repository at this point in the history
Signed-off-by: John Molakvoæ (skjnldsv) <skjnldsv@protonmail.com>
  • Loading branch information
skjnldsv committed Apr 29, 2021
1 parent c5d79e5 commit b730e16
Showing 1 changed file with 49 additions and 12 deletions.
61 changes: 49 additions & 12 deletions src/components/RichContenteditable/RichContenteditable.vue
Original file line number Diff line number Diff line change
Expand Up @@ -31,7 +31,7 @@ This component displays contenteditable div with automated @ autocompletion [at]
<template>
<div>
<RichContenteditable
v-model="message"
:value.sync="message"
:auto-complete="autoComplete"
:maxlength="100"
:user-data="userData"
Expand All @@ -40,7 +40,7 @@ This component displays contenteditable div with automated @ autocompletion [at]
<br>

<RichContenteditable
v-model="message"
:value.sync="message"
:auto-complete="autoComplete"
:maxlength="400"
:multiline="true"
Expand Down Expand Up @@ -114,8 +114,9 @@ export default {
'rich-contenteditable__input--empty': isEmptyValue,
'rich-contenteditable__input--multiline': multiline,
'rich-contenteditable__input--overflow': isOverMaxlength,
'rich-contenteditable__input--disabled': disabled,
}"
:contenteditable="contenteditable"
:contenteditable="canEdit"
:placeholder="placeholder"
aria-multiline="true"
class="rich-contenteditable__input"
Expand Down Expand Up @@ -148,10 +149,12 @@ export default {
default: '',
required: true,
},

placeholder: {
type: String,
default: t('Write message, @ to mention someone …'),
},

autoComplete: {
type: Function,
required: true,
Expand Down Expand Up @@ -181,6 +184,14 @@ export default {
default: true,
},

/**
* Disable the editing and show specific disabled design
*/
disabled: {
type: Boolean,
default: false,
},

/**
* Max allowed length
*/
Expand Down Expand Up @@ -259,6 +270,14 @@ export default {
trigger: 'manual',
}
},

/**
* Edit is only allowed when contenteditableis true and disabled is false
* @returns {boolean}
*/
canEdit() {
return this.contenteditable && !this.disabled
},
},

watch: {
Expand All @@ -284,7 +303,7 @@ export default {

// Removes the contenteditable attribute at first load if the prop is
// set to false.
this.$refs.contenteditable.contentEditable = this.contenteditable
this.$refs.contenteditable.contentEditable = this.canEdit
},
beforeDestroy() {
if (this.tribute) {
Expand All @@ -308,6 +327,11 @@ export default {
* @emits {Event} paste the original paste event
*/
onPaste(event) {
// Either disabled or edit deactivated
if (!this.canEdit) {
return
}

event.preventDefault()
const clipboardData = event.clipboardData

Expand Down Expand Up @@ -352,7 +376,6 @@ export default {
updateValue(htmlOrText) {
const text = this.parseContent(htmlOrText)
this.localValue = text
this.$emit('input', text)
this.$emit('update:value', text)
},

Expand All @@ -379,6 +402,11 @@ export default {
return
}

// Either disabled or edit deactivated
if (!this.canEdit) {
return
}

// fix backspace bug in FF
// https://bugzilla.mozilla.org/show_bug.cgi?id=685445
const selection = window.getSelection()
Expand Down Expand Up @@ -429,8 +457,9 @@ export default {
event.stopPropagation()
this.$emit('submit', event)
},

/**
* Ctrl + Enter key pressed
* Ctrl + Enter key pressed is used to submit
* @param {Event} event the keydown event
*/
onCtrlEnter(event) {
Expand Down Expand Up @@ -477,20 +506,28 @@ export default {
color: var(--color-text-maxcontrast);
}

&[contenteditable='false'] {
&[contenteditable='false']:not(&--disabled) {
cursor: default;
opacity: .5;
color: var(--color-text-lighter);
border: 1px solid var(--color-background-darker);
border-radius: var(--border-radius);
background-color: var(--color-background-dark);
background-color: transparent;
color: var(--color-main-text);
border-color: transparent;
opacity: 1;
border-radius: 0;
}

&--multiline {
min-height: $clickable-area * 3;
// No max for mutiline
max-height: none;
}

&--disabled {
opacity: $opacity_disabled;
color: var(--color-text-lighter);
border: 1px solid var(--color-background-darker);
border-radius: var(--border-radius);
background-color: var(--color-background-dark);
}
}

</style>
Expand Down

0 comments on commit b730e16

Please sign in to comment.