diff --git a/packages/primevue/src/multiselect/BaseMultiSelect.vue b/packages/primevue/src/multiselect/BaseMultiSelect.vue
index a8a6bc6161..ccdff789e5 100644
--- a/packages/primevue/src/multiselect/BaseMultiSelect.vue
+++ b/packages/primevue/src/multiselect/BaseMultiSelect.vue
@@ -38,6 +38,18 @@ export default {
default: null
},
dataKey: null,
+ showClear: {
+ type: Boolean,
+ default: false
+ },
+ clearIcon: {
+ type: String,
+ default: undefined
+ },
+ resetFilterOnClear: {
+ type: Boolean,
+ default: false
+ },
filter: Boolean,
filterPlaceholder: String,
filterLocale: String,
diff --git a/packages/primevue/src/multiselect/MultiSelect.d.ts b/packages/primevue/src/multiselect/MultiSelect.d.ts
index 450a01c379..a5b11320a4 100755
--- a/packages/primevue/src/multiselect/MultiSelect.d.ts
+++ b/packages/primevue/src/multiselect/MultiSelect.d.ts
@@ -131,6 +131,10 @@ export interface MultiSelectPassThroughOptions {
* Used to pass attributes to the label's DOM element.
*/
label?: MultiSelectPassThroughOptionType;
+ /**
+ * Used to pass attributes to the label's DOM element.
+ */
+ clearIcon?: MultiSelectPassThroughOptionType;
/**
* Used to pass attributes to the chip's DOM element.
*/
@@ -407,6 +411,20 @@ export interface MultiSelectProps {
* A property to uniquely identify an option.
*/
dataKey?: string | undefined;
+ /**
+ * When enabled, a clear icon is displayed to clear the value.
+ * @defaultValue false
+ */
+ showClear?: boolean | undefined;
+ /**
+ * Icon to display in clear button.
+ */
+ clearIcon?: string | undefined;
+ /**
+ * Clears the filter value when clicking on the clear icon.
+ * @defaultValue false
+ */
+ resetFilterOnClear?: boolean;
/**
* When specified, displays a filter input at header.
* @defaultValue false
@@ -803,6 +821,17 @@ export interface MultiSelectSlots {
*/
class: string;
}): VNode[];
+ /**
+ * Custom clear icon template.
+ * @param {Object} scope - clear icon slot's params.
+ */
+ clearicon(scope: {
+ /**
+ * Clear icon click function.
+ * @param {Event} event - Browser event
+ */
+ clearCallback: (event: Event) => void;
+ }): VNode[];
/**
* Custom dropdown icon template.
* @param {Object} scope - dropdownicon slot's params.
diff --git a/packages/primevue/src/multiselect/MultiSelect.vue b/packages/primevue/src/multiselect/MultiSelect.vue
index ef8171d067..e41e677d44 100755
--- a/packages/primevue/src/multiselect/MultiSelect.vue
+++ b/packages/primevue/src/multiselect/MultiSelect.vue
@@ -50,6 +50,9 @@
+