diff --git a/src/components/ContactDetails.vue b/src/components/ContactDetails.vue
index 97aaf610a..e333ea43d 100644
--- a/src/components/ContactDetails.vue
+++ b/src/components/ContactDetails.vue
@@ -139,6 +139,14 @@
{{ t('contacts', 'Generate QR Code') }}
+
+
+
+
+ {{ excludeFromBirthdayLabel }}
+
@@ -267,6 +275,7 @@ import IconLoading from '@nextcloud/vue/dist/Components/NcLoadingIcon'
import IconDownload from 'vue-material-design-icons/Download'
import IconDelete from 'vue-material-design-icons/Delete'
import IconQr from 'vue-material-design-icons/Qrcode'
+import CakeIcon from 'vue-material-design-icons/Cake'
import IconCopy from 'vue-material-design-icons/ContentCopy'
import rfcProps from '../models/rfcProps'
@@ -299,6 +308,7 @@ export default {
IconDownload,
IconDelete,
IconQr,
+ CakeIcon,
IconCopy,
IconLoading,
Modal,
@@ -338,6 +348,7 @@ export default {
pickedAddressbook: null,
contactDetailsSelector: '.contact-details',
+ excludeFromBirthdayKey: 'x-nc-exclude-from-birthday-calendar',
}
},
@@ -502,6 +513,16 @@ export default {
contact() {
return this.$store.getters.getContact(this.contactKey)
},
+
+ excludeFromBirthdayLabel() {
+ return this.localContact.vCard.hasProperty(this.excludeFromBirthdayKey)
+ ? t('contacts', 'Add contact to Birthday Calendar')
+ : t('contacts', 'Exclude contact from Birthday Calendar')
+ },
+
+ enableToggleBirthdayExclusion() {
+ return parseInt(OC.config.version.split('.')[0]) >= 26
+ },
},
watch: {
@@ -576,6 +597,16 @@ export default {
}
},
+ async toggleBirthdayExclusionForContact() {
+ if (!this.localContact.vCard.hasProperty(this.excludeFromBirthdayKey)) {
+ this.localContact.vCard.addPropertyWithValue(this.excludeFromBirthdayKey, true)
+ } else {
+ this.localContact.vCard.removeProperty(this.excludeFromBirthdayKey)
+ }
+
+ await this.updateContact()
+ },
+
/**
* Select the text in the input if it is still set to 'new Contact'
*/