diff --git a/components/lib/overlaypanel/OverlayPanel.d.ts b/components/lib/overlaypanel/OverlayPanel.d.ts
old mode 100755
new mode 100644
index f50ab38b79..fe0bd83541
--- a/components/lib/overlaypanel/OverlayPanel.d.ts
+++ b/components/lib/overlaypanel/OverlayPanel.d.ts
@@ -2,224 +2,66 @@
*
* OverlayPanel is a container component positioned as connected to its target.
*
- * [Live Demo](https://primevue.org/overlaypanel)
+ * [Live Demo](https://primevue.org/popover)
*
* @module overlaypanel
*
*/
-import { TransitionProps, VNode } from 'vue';
-import { ComponentHooks } from '../basecomponent';
-import { PassThroughOptions } from '../passthrough';
-import { ClassComponent, DesignToken, GlobalComponentConstructor, HintedString, PassThrough } from '../ts-helpers';
-
-export declare type OverlayPanelPassThroughOptionType = OverlayPanelPassThroughAttributes | ((options: OverlayPanelPassThroughMethodOptions) => OverlayPanelPassThroughAttributes | string) | string | null | undefined;
-
-export declare type OverlayPanelPassThroughTransitionType = TransitionProps | ((options: OverlayPanelPassThroughMethodOptions) => TransitionProps) | undefined;
+import 'vue';
+import * as Popover from '../popover';
+import { ClassComponent, GlobalComponentConstructor } from '../ts-helpers';
/**
* Custom passthrough(pt) option method.
*/
-export interface OverlayPanelPassThroughMethodOptions {
- /**
- * Defines instance.
- */
- instance: any;
- /**
- * Defines valid properties.
- */
- props: OverlayPanelProps;
- /**
- * Defines current inline state.
- */
- state: OverlayPanelState;
- /**
- * Defines valid attributes.
- */
- attrs: any;
- /**
- * Defines parent options.
- */
- parent: any;
- /**
- * Defines passthrough(pt) options in global config.
- */
- global: object | undefined;
-}
+export interface OverlayPanelPassThroughMethodOptions extends Popover.PopoverPassThroughMethodOptions {}
/**
* Custom passthrough(pt) options.
* @see {@link OverlayPanelProps.pt}
*/
-export interface OverlayPanelPassThroughOptions {
- /**
- * Used to pass attributes to the root's DOM element.
- */
- root?: OverlayPanelPassThroughOptionType;
- /**
- * Used to pass attributes to the content's DOM element.
- */
- content?: OverlayPanelPassThroughOptionType;
- /**
- * Used to manage all lifecycle hooks.
- * @see {@link BaseComponent.ComponentHooks}
- */
- hooks?: ComponentHooks;
- /**
- * Used to control Vue Transition API.
- */
- transition?: OverlayPanelPassThroughTransitionType;
-}
+export interface OverlayPanelPassThroughOptions extends Popover.PopoverPassThroughOptions {}
/**
* Custom passthrough attributes for each DOM elements
*/
-export interface OverlayPanelPassThroughAttributes {
+export interface OverlayPanelPassThroughAttributes extends Popover.PopoverPassThroughAttributes {
[key: string]: any;
}
/**
* Defines current inline state in OverlayPanel component.
*/
-export interface OverlayPanelState {
- /**
- * Current visible state as a boolean.
- * @defaultValue false
- */
- visible: boolean;
-}
+export interface OverlayPanelState extends Popover.PopoverState {}
/**
* OverlayPanel breakpoint metadata.
*/
-export interface OverlayPanelBreakpoints {
- /**
- * Breakpoint for responsive mode.
- *
- * Example:
- *
- *
- *
- * Result:
- *
- * @media screen and (max-width: ${breakpoint[key]}) {
- * .p-overlaypanel[attributeSelector] {
- * width: ${breakpoint[value]} !important;
- * }
- * }
- */
- [key: string]: string;
-}
+export interface OverlayPanelBreakpoints extends Popover.PopoverBreakpoints {}
/**
* Defines valid properties in OverlayPanel component.
*/
-export interface OverlayPanelProps {
- /**
- * Enables to hide the overlay when outside is clicked.
- * @defaultValue true
- */
- dismissable?: boolean;
- /**
- * A valid query selector or an HTMLElement to specify where the overlay gets attached.
- * @defaultValue body
- */
- appendTo?: HintedString<'body' | 'self'> | undefined | HTMLElement;
- /**
- * Base zIndex value to use in layering.
- * @defaultValue 0
- */
- baseZIndex?: number;
- /**
- * Whether to automatically manage layering.
- * @defaultValue true
- */
- autoZIndex?: boolean;
- /**
- * Object literal to define widths per screen size.
- */
- breakpoints?: OverlayPanelBreakpoints;
- /**
- * It generates scoped CSS variables using design tokens for the component.
- */
- dt?: DesignToken;
- /**
- * Used to pass attributes to DOM elements inside the component.
- * @type {OverlayPanelPassThroughOptions}
- */
- pt?: PassThrough;
- /**
- * Used to configure passthrough(pt) options of the component.
- * @type {PassThroughOptions}
- */
- ptOptions?: PassThroughOptions;
- /**
- * When enabled, it removes component related styles in the core.
- * @defaultValue false
- */
- unstyled?: boolean;
- /**
- * Specifies if pressing escape key should hide the dialog.
- * @defaultValue true
- */
- closeOnEscape?: boolean | undefined;
-}
+export interface OverlayPanelProps extends Popover.PopoverProps {}
/**
* Defines valid slots in OverlayPanel component.
*/
-export interface OverlayPanelSlots {
- /**
- * Custom content template.
- */
- default(): VNode[];
- /**
- * Custom container slot.
- * @param {Object} scope - container slot's params.
- */
- container(scope: {
- /**
- * Close overlay panel function.
- * @deprecated since v3.39.0. Use 'closeCallback' property instead.
- */
- onClose: () => void;
- /**
- * Close button keydown function.
- * @param {Event} event - Browser event
- * @deprecated since v3.39.0. Use 'keydownCallback' property instead.
- */
- onKeydown: (event: Event) => void;
- /**
- * Close overlay panel function.
- */
- closeCallback: () => void;
- /**
- * Close button keydown function.
- * @param {Event} event - Browser event
- */
- keydownCallback: (event: Event) => void;
- }): VNode[];
-}
+export interface OverlayPanelSlots extends Popover.PopoverSlots {}
/**
* Defines valid emits in OverlayPanel component.
*/
-export interface OverlayPanelEmits {
- /**
- * Callback to invoke when the overlay is shown.
- */
- show(): void;
- /**
- * Callback to invoke when the overlay is hidden.
- */
- hide(): void;
-}
+export interface OverlayPanelEmits extends Popover.PopoverEmits {}
/**
+ * @deprecated Deprecated since v4. Use Popover component instead.
+ *
* **PrimeVue - OverlayPanel**
*
* _OverlayPanel, also known as Popover, is a container component that can overlay other components on page._
*
- * [Live Demo](https://www.primevue.org/overlaypanel/)
+ * [Live Demo](https://www.primevue.org/popover/)
* --- ---
* ![PrimeVue](https://primefaces.org/cdn/primevue/images/logo-100.png)
*
diff --git a/components/lib/overlaypanel/OverlayPanel.vue b/components/lib/overlaypanel/OverlayPanel.vue
old mode 100755
new mode 100644
index 846fb1ac70..961c551c3a
--- a/components/lib/overlaypanel/OverlayPanel.vue
+++ b/components/lib/overlaypanel/OverlayPanel.vue
@@ -1,314 +1,11 @@
-
-
-
-
-
-
-
-
diff --git a/components/lib/overlaypanel/style/OverlayPanelStyle.d.ts b/components/lib/overlaypanel/style/OverlayPanelStyle.d.ts
index 00c07cea0b..545a6dfd09 100644
--- a/components/lib/overlaypanel/style/OverlayPanelStyle.d.ts
+++ b/components/lib/overlaypanel/style/OverlayPanelStyle.d.ts
@@ -1,3 +1,3 @@
-import { BaseStyle } from '../../base/style';
+import { PopoverStyle } from '../../popover/style/PopoverStyle';
-export interface OverlayPanelStyle extends BaseStyle {}
+export interface OverlayPanelStyle extends PopoverStyle {}
diff --git a/components/lib/overlaypanel/style/OverlayPanelStyle.js b/components/lib/overlaypanel/style/OverlayPanelStyle.js
index 5473da5f00..5f49164cb4 100644
--- a/components/lib/overlaypanel/style/OverlayPanelStyle.js
+++ b/components/lib/overlaypanel/style/OverlayPanelStyle.js
@@ -1,16 +1,5 @@
import BaseStyle from 'primevue/base/style';
-const classes = {
- root: ({ instance }) => [
- 'p-popover p-component',
- {
- 'p-ripple-disabled': instance.$primevue.config.ripple === false
- }
- ],
- content: 'p-popover-content'
-};
-
export default BaseStyle.extend({
- name: 'overlaypanel',
- classes
+ name: 'overlaypanel'
});
diff --git a/components/lib/overlaypanel/BaseOverlayPanel.vue b/components/lib/popover/BasePopover.vue
similarity index 86%
rename from components/lib/overlaypanel/BaseOverlayPanel.vue
rename to components/lib/popover/BasePopover.vue
index f0f6508859..b41a251faf 100644
--- a/components/lib/overlaypanel/BaseOverlayPanel.vue
+++ b/components/lib/popover/BasePopover.vue
@@ -1,9 +1,9 @@
diff --git a/components/lib/popover/package.json b/components/lib/popover/package.json
new file mode 100644
index 0000000000..f677be40a8
--- /dev/null
+++ b/components/lib/popover/package.json
@@ -0,0 +1,9 @@
+{
+ "main": "./popover.cjs.js",
+ "module": "./popover.esm.js",
+ "unpkg": "./popover.min.js",
+ "types": "./Popover.d.ts",
+ "browser": {
+ "./sfc": "./Popover.vue"
+ }
+}
diff --git a/components/lib/popover/style/PopoverStyle.d.ts b/components/lib/popover/style/PopoverStyle.d.ts
new file mode 100644
index 0000000000..fa132056ff
--- /dev/null
+++ b/components/lib/popover/style/PopoverStyle.d.ts
@@ -0,0 +1,3 @@
+import { BaseStyle } from '../../base/style/BaseStyle';
+
+export interface PopoverStyle extends BaseStyle {}
diff --git a/components/lib/popover/style/PopoverStyle.js b/components/lib/popover/style/PopoverStyle.js
new file mode 100644
index 0000000000..8a2a668150
--- /dev/null
+++ b/components/lib/popover/style/PopoverStyle.js
@@ -0,0 +1,16 @@
+import BaseStyle from 'primevue/base/style';
+
+const classes = {
+ root: ({ instance }) => [
+ 'p-popover p-component',
+ {
+ 'p-ripple-disabled': instance.$primevue.config.ripple === false
+ }
+ ],
+ content: 'p-popover-content'
+};
+
+export default BaseStyle.extend({
+ name: 'popover',
+ classes
+});
diff --git a/components/lib/popover/style/package.json b/components/lib/popover/style/package.json
new file mode 100644
index 0000000000..e6d6e6befd
--- /dev/null
+++ b/components/lib/popover/style/package.json
@@ -0,0 +1,6 @@
+{
+ "main": "./popoverstyle.cjs.js",
+ "module": "./popoverstyle.esm.js",
+ "unpkg": "./popoverstyle.min.js",
+ "types": "./PopoverStyle.d.ts"
+}
diff --git a/components/lib/themes/primeone/base/overlaypanel/index.js b/components/lib/themes/primeone/base/popover/index.js
similarity index 77%
rename from components/lib/themes/primeone/base/overlaypanel/index.js
rename to components/lib/themes/primeone/base/popover/index.js
index 674db7988b..d36aa13183 100644
--- a/components/lib/themes/primeone/base/overlaypanel/index.js
+++ b/components/lib/themes/primeone/base/popover/index.js
@@ -2,9 +2,9 @@ export default {
css: ({ dt }) => `
.p-popover {
margin-top: 10px;
- background: ${dt('overlaypanel.background')};
- color: ${dt('overlaypanel.color')};
- border: 1px solid ${dt('overlaypanel.border.color')};
+ background: ${dt('popover.background')};
+ color: ${dt('popover.color')};
+ border: 1px solid ${dt('popover.border.color')};
border-radius: ${dt('rounded.base')};
box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -2px rgba(0, 0, 0, 0.1);
}
@@ -51,7 +51,7 @@ export default {
margin-left: -8px;
border-style: solid;
border-color: transparent;
- border-bottom-color: ${dt('overlaypanel.background')};
+ border-bottom-color: ${dt('popover.background')};
}
.p-popover:before {
@@ -59,7 +59,7 @@ export default {
margin-left: -10px;
border-style: solid;
border-color: transparent;
- border-bottom-color: ${dt('overlaypanel.border.color')};
+ border-bottom-color: ${dt('popover.border.color')};
}
.p-popover-flipped:after,
@@ -70,12 +70,12 @@ export default {
.p-popover.p-popover-flipped:after {
border-bottom-color: transparent;
- border-top-color: ${dt('overlaypanel.background')};
+ border-top-color: ${dt('popover.background')};
}
.p-popover.p-popover-flipped:before {
border-bottom-color: transparent;
- border-top-color: ${dt('overlaypanel.border.color')};
+ border-top-color: ${dt('popover.border.color')};
}
`
};
diff --git a/components/lib/themes/primeone/base/overlaypanel/package.json b/components/lib/themes/primeone/base/popover/package.json
similarity index 100%
rename from components/lib/themes/primeone/base/overlaypanel/package.json
rename to components/lib/themes/primeone/base/popover/package.json
diff --git a/components/lib/themes/primeone/presets/aura/overlaypanel/index.js b/components/lib/themes/primeone/presets/aura/popover/index.js
similarity index 100%
rename from components/lib/themes/primeone/presets/aura/overlaypanel/index.js
rename to components/lib/themes/primeone/presets/aura/popover/index.js
diff --git a/components/lib/themes/primeone/presets/aura/overlaypanel/package.json b/components/lib/themes/primeone/presets/aura/popover/package.json
similarity index 100%
rename from components/lib/themes/primeone/presets/aura/overlaypanel/package.json
rename to components/lib/themes/primeone/presets/aura/popover/package.json