Fixed #5823 #5824 - New Stepper implementation

pull/5838/head
tugcekucukoglu 2024-06-04 09:23:00 +03:00
parent ff0df14ed7
commit 033a50fcbb
51 changed files with 1571 additions and 693 deletions

View File

@ -0,0 +1,34 @@
<script>
import BaseComponent from 'primevue/basecomponent';
import StepStyle from 'primevue/step/style';
export default {
name: 'BaseStep',
extends: BaseComponent,
props: {
value: {
type: [String, Number],
default: undefined
},
disabled: {
type: Boolean,
default: false
},
asChild: {
type: Boolean,
default: false
},
as: {
type: String,
default: 'DIV'
}
},
style: StepStyle,
provide() {
return {
$pcStep: this,
$parentInstance: this
};
}
};
</script>

187
components/lib/step/Step.d.ts vendored Normal file
View File

@ -0,0 +1,187 @@
/**
*
* Step is a helper component for Stepper component.
*
* [Live Demo](https://www.primevue.org/stepper/)
*
* @module step
*
*/
import { VNode } from 'vue';
import { ComponentHooks } from '../basecomponent';
import { PassThroughOptions } from '../passthrough';
import { DefineComponent, DesignToken, EmitFn, GlobalComponentConstructor, PassThrough } from '../ts-helpers';
export declare type StepPassThroughOptionType = StepPassThroughAttributes | ((options: StepPassThroughMethodOptions) => StepPassThroughAttributes | string) | string | null | undefined;
/**
* Custom passthrough(pt) option method.
*/
export interface StepPassThroughMethodOptions {
/**
* Defines instance.
*/
instance: any;
/**
* Defines valid properties.
*/
props: StepProps;
/**
* Defines current options.
*/
context: StepContext;
/**
* Defines valid attributes.
*/
attrs: any;
/**
* Defines parent options.
*/
parent: any;
/**
* Defines passthrough(pt) options in global config.
*/
global: object | undefined;
}
/**
* Custom passthrough(pt) options.
* @see {@link StepProps.pt}
*/
export interface StepPassThroughOptions {
/**
* Used to pass attributes to the root's DOM element.
*/
root?: StepPassThroughOptionType;
/**
* Used to pass attributes to the header's DOM element.
*/
header?: StepPassThroughOptionType;
/**
* Used to pass attributes to the number's DOM element.
*/
number?: StepPassThroughOptionType;
/**
* Used to pass attributes to the title's DOM element.
*/
title?: StepPassThroughOptionType;
/**
* Used to manage all lifecycle hooks.
* @see {@link BaseComponent.ComponentHooks}
*/
hooks?: ComponentHooks;
}
export interface StepPassThroughAttributes {
[key: string]: any;
}
/**
* Defines valid properties in Step component.
*/
export interface StepProps {
/**
* Value of step.
*/
value?: string | number | undefined;
/**
* Whether the step is disabled.
* @defaultValue false
*/
disabled?: boolean | undefined;
/**
* Use to change the HTML tag of root element.
* @defaultValue BUTTON
*/
as?: string | undefined;
/**
* When enabled, it changes the default rendered element for the one passed as a child element.
* @defaultValue false
*/
asChild?: boolean | undefined;
/**
* It generates scoped CSS variables using design tokens for the component.
*/
dt?: DesignToken<any>;
/**
* Used to pass attributes to DOM elements inside the component.
* @type {StepPassThroughOptions}
*/
pt?: PassThrough<StepPassThroughOptions>;
/**
* Used to configure passthrough(pt) options of the component.
* @type {PassThroughOptions}
*/
ptOptions?: PassThroughOptions;
}
/**
* Defines current options in Step component.
*/
export interface StepContext {
/**
* Whether the step is active.
*/
active: boolean;
/**
* Whether the step is disabled.
*/
disabled: boolean;
}
/**
* Defines valid slots in Step slots.
*/
export interface StepSlots {
/**
* Custom content template. Slot attributes can be used when asChild prop is true.
*/
default(scope: {
/**
* Style class of the loader.
*/
class: string;
/**
* Whether the step is active.
*/
active: boolean;
/**
* Value of step.
*/
value: string | number;
/**
* A11t attributes
*/
a11yAttrs: any;
/**
* Click function.
*/
activateCallback: () => void;
}): VNode[];
}
export interface StepEmitsOptions {}
export declare type StepEmits = EmitFn<StepEmitsOptions>;
/**
* **PrimeVue - Step**
*
* _Step is a helper component for Stepper component._
*
* [Live Demo](https://www.primevue.org/stepper/)
* --- ---
* ![PrimeVue](https://primefaces.org/cdn/primevue/images/logo-100.png)
*
* @group Component
*
*/
declare const Step: DefineComponent<StepProps, StepSlots, StepEmits>;
declare module 'vue' {
export interface GlobalComponents {
Step: GlobalComponentConstructor<StepProps, StepSlots, StepEmits>;
}
}
export default Step;

View File

@ -0,0 +1,98 @@
<template>
<component v-if="!asChild" :is="as" :class="cx('root')" :aria-current="active ? 'step' : undefined" role="presentation" :data-p-active="active" :data-p-disabled="disabled" v-bind="getPTOptions('root')">
<button :id="id" :class="cx('header')" role="tab" type="button" :tabindex="disabled ? -1 : undefined" :aria-controls="ariaControls" :disabled="disabled" @click="onStepClick" v-bind="getPTOptions('header')">
<span :class="cx('number')" v-bind="getPTOptions('number')">{{ activeValue }}</span>
<span :class="cx('title')" v-bind="getPTOptions('title')">
<slot />
</span>
</button>
<StepperSeparator v-if="isSeparatorVisible" />
</component>
<slot v-else :class="cx('root')" :active="active" :value="value" :a11yAttrs="a11yAttrs" :activateCallback="onStepClick" />
</template>
<script>
import { DomHandler, ObjectUtils } from 'primevue/utils';
import StepperSeparator from '../stepper/StepperSeparator.vue';
import BaseStep from './BaseStep.vue';
export default {
name: 'Step',
extends: BaseStep,
inheritAttrs: false,
inject: {
$pcStepper: { default: null },
$pcStepList: { default: null },
$pcStepItem: { default: null }
},
data() {
return {
isSeparatorVisible: false
};
},
mounted() {
if (this.$el && this.$pcStepList) {
let index = ObjectUtils.findIndexInList(this.$el, DomHandler.find(this.$pcStepper.$el, '[data-pc-name="step"]'));
let stepLen = DomHandler.find(this.$pcStepper.$el, '[data-pc-name="step"]').length;
this.isSeparatorVisible = index !== stepLen - 1;
}
},
methods: {
getPTOptions(key) {
const _ptm = key === 'root' ? this.ptmi : this.ptm;
return _ptm(key, {
context: {
active: this.active,
disabled: this.disabled
}
});
},
isStepDisabled() {
return this.$pcStepper.isStepDisabled();
},
onStepClick() {
this.$pcStepper.updateValue(this.activeValue);
}
},
computed: {
active() {
return this.$pcStepper.isStepActive(this.activeValue);
},
activeValue() {
return !!this.$pcStepItem ? this.$pcStepItem?.value : this.value;
},
id() {
return `${this.$pcStepper?.id}_step_${this.activeValue}`;
},
ariaControls() {
return `${this.$pcStepper?.id}_steppanel_${this.activeValue}`;
},
a11yAttrs() {
return {
root: {
role: 'presentation',
'aria-current': this.active ? 'step' : undefined,
'data-pc-name': 'step',
'data-pc-section': 'root',
'data-p-disabled': this.disabled,
'data-p-active': this.active
},
header: {
id: this.id,
role: 'tab',
taindex: this.disabled ? -1 : undefined,
'aria-controls': this.ariaControls,
'data-pc-section': 'header',
disabled: this.disabled,
onClick: this.onStepClick
}
};
}
},
components: {
StepperSeparator
}
};
</script>

View File

@ -0,0 +1,11 @@
{
"main": "./step.mjs",
"module": "./step.mjs",
"types": "./Step.d.ts",
"browser": {
"./sfc": "./Step.vue"
},
"sideEffects": [
"*.vue"
]
}

View File

@ -0,0 +1,31 @@
/**
*
* Step is a helper component for Stepper component.
*
* [Live Demo](https://www.primevue.org/stepper/)
*
* @module stepstyle
*
*/
import { BaseStyle } from '../../base/style';
export enum StepClasses {
/**
* Class name of the root element
*/
root = 'p-step',
/**
* Class name of the header element
*/
header = 'p-step-header',
/**
* Class name of the number element
*/
number = 'p-step-number',
/**
* Class name of the title element
*/
title = 'p-step-title'
}
export interface StepStyle extends BaseStyle {}

View File

@ -0,0 +1,19 @@
import BaseStyle from 'primevue/base/style';
const classes = {
root: ({ instance, props }) => [
'p-step',
{
'p-step-active': instance.active,
'p-disabled': instance.isStepDisabled() || props.disabled
}
],
header: 'p-step-header',
number: 'p-step-number',
title: 'p-step-title'
};
export default BaseStyle.extend({
name: 'step',
classes
});

View File

@ -0,0 +1,6 @@
{
"main": "./stepstyle.mjs",
"module": "./stepstyle.mjs",
"types": "./StepStyle.d.ts",
"sideEffects": false
}

View File

@ -0,0 +1,22 @@
<script>
import BaseComponent from 'primevue/basecomponent';
import StepItemStyle from 'primevue/stepitem/style';
export default {
name: 'BaseStepItem',
extends: BaseComponent,
props: {
value: {
type: String,
default: undefined
}
},
style: StepItemStyle,
provide() {
return {
$pcStepItem: this,
$parentInstance: this
};
}
};
</script>

121
components/lib/stepitem/StepItem.d.ts vendored Normal file
View File

@ -0,0 +1,121 @@
/**
*
* StepItem is a helper component for Stepper component.
*
* [Live Demo](https://www.primevue.org/stepper/)
*
* @module stepitem
*
*/
import { VNode } from 'vue';
import { ComponentHooks } from '../basecomponent';
import { PassThroughOptions } from '../passthrough';
import { DefineComponent, DesignToken, EmitFn, GlobalComponentConstructor, PassThrough } from '../ts-helpers';
export declare type StepItemPassThroughOptionType = StepItemPassThroughAttributes | ((options: StepItemPassThroughMethodOptions) => StepItemPassThroughAttributes | string) | string | null | undefined;
/**
* Custom passthrough(pt) option method.
*/
export interface StepItemPassThroughMethodOptions {
/**
* Defines instance.
*/
instance: any;
/**
* Defines valid properties.
*/
props: StepItemProps;
/**
* Defines valid attributes.
*/
attrs: any;
/**
* Defines parent options.
*/
parent: any;
/**
* Defines passthrough(pt) options in global config.
*/
global: object | undefined;
}
/**
* Custom passthrough(pt) options.
* @see {@link StepItemProps.pt}
*/
export interface StepItemPassThroughOptions {
/**
* Used to pass attributes to the root's DOM element.
*/
root?: StepItemPassThroughOptionType;
/**
* Used to manage all lifecycle hooks.
* @see {@link BaseComponent.ComponentHooks}
*/
hooks?: ComponentHooks;
}
export interface StepItemPassThroughAttributes {
[key: string]: any;
}
/**
* Defines valid properties in StepItem component.
*/
export interface StepItemProps {
/**
* Value of step.
*/
value?: string | number | undefined;
/**
* It generates scoped CSS variables using design tokens for the component.
*/
dt?: DesignToken<any>;
/**
* Used to pass attributes to DOM elements inside the component.
* @type {StepItemPassThroughOptions}
*/
pt?: PassThrough<StepItemPassThroughOptions>;
/**
* Used to configure passthrough(pt) options of the component.
* @type {PassThroughOptions}
*/
ptOptions?: PassThroughOptions;
}
/**
* Defines valid slots in StepItem slots.
*/
export interface StepItemSlots {
/**
* Custom content template.
*/
default(): VNode[];
}
export interface StepItemEmitsOptions {}
export declare type StepItemEmits = EmitFn<StepItemEmitsOptions>;
/**
* **PrimeVue - StepItem**
*
* _StepItem is a helper component for Stepper component._
*
* [Live Demo](https://www.primevue.org/stepper/)
* --- ---
* ![PrimeVue](https://primefaces.org/cdn/primevue/images/logo-100.png)
*
* @group Component
*
*/
declare const StepItem: DefineComponent<StepItemProps, StepItemSlots, StepItemEmits>;
declare module 'vue' {
export interface GlobalComponents {
StepItem: GlobalComponentConstructor<StepItemProps, StepItemSlots, StepItemEmits>;
}
}
export default StepItem;

View File

@ -0,0 +1,21 @@
<template>
<div :class="cx('root')" :data-p-active="isActive" v-bind="ptmi('root')">
<slot />
</div>
</template>
<script>
import BaseStepItem from './BaseStepItem.vue';
export default {
name: 'StepItem',
extends: BaseStepItem,
inheritAttrs: false,
inject: ['$pcStepper'],
computed: {
isActive() {
return this.$pcStepper?.d_value === this.value;
}
}
};
</script>

View File

@ -0,0 +1,11 @@
{
"main": "./stepitem.mjs",
"module": "./stepitem.mjs",
"types": "./StepItem.d.ts",
"browser": {
"./sfc": "./StepItem.vue"
},
"sideEffects": [
"*.vue"
]
}

View File

@ -0,0 +1,19 @@
/**
*
* StepItem is a helper component for Stepper component.
*
* [Live Demo](https://www.primevue.org/stepper/)
*
* @module stepitemstyle
*
*/
import { BaseStyle } from '../../base/style';
export enum StepItemClasses {
/**
* Class name of the root element
*/
root = 'p-stepitem'
}
export interface StepItemStyle extends BaseStyle {}

View File

@ -0,0 +1,15 @@
import BaseStyle from 'primevue/base/style';
const classes = {
root: ({ instance }) => [
'p-stepitem',
{
'p-stepitem-active': instance.isActive
}
]
};
export default BaseStyle.extend({
name: 'stepitem',
classes
});

View File

@ -0,0 +1,6 @@
{
"main": "./stepitemstyle.mjs",
"module": "./stepitemstyle.mjs",
"types": "./StepItemStyle.d.ts",
"sideEffects": false
}

View File

@ -0,0 +1,22 @@
<script>
import BaseComponent from 'primevue/basecomponent';
import StepListStyle from 'primevue/steplist/style';
export default {
name: 'BaseStepList',
extends: BaseComponent,
props: {
value: {
type: String,
default: undefined
}
},
style: StepListStyle,
provide() {
return {
$pcStepList: this,
$parentInstance: this
};
}
};
</script>

121
components/lib/steplist/StepList.d.ts vendored Normal file
View File

@ -0,0 +1,121 @@
/**
*
* StepList is a helper component for Stepper component.
*
* [Live Demo](https://www.primevue.org/stepper/)
*
* @module steplist
*
*/
import { VNode } from 'vue';
import { ComponentHooks } from '../basecomponent';
import { PassThroughOptions } from '../passthrough';
import { DefineComponent, DesignToken, EmitFn, GlobalComponentConstructor, PassThrough } from '../ts-helpers';
export declare type StepListPassThroughOptionType = StepListPassThroughAttributes | ((options: StepListPassThroughMethodOptions) => StepListPassThroughAttributes | string) | string | null | undefined;
/**
* Custom passthrough(pt) option method.
*/
export interface StepListPassThroughMethodOptions {
/**
* Defines instance.
*/
instance: any;
/**
* Defines valid properties.
*/
props: StepListProps;
/**
* Defines valid attributes.
*/
attrs: any;
/**
* Defines parent options.
*/
parent: any;
/**
* Defines passthrough(pt) options in global config.
*/
global: object | undefined;
}
/**
* Custom passthrough(pt) options.
* @see {@link StepListProps.pt}
*/
export interface StepListPassThroughOptions {
/**
* Used to pass attributes to the root's DOM element.
*/
root?: StepListPassThroughOptionType;
/**
* Used to manage all lifecycle hooks.
* @see {@link BaseComponent.ComponentHooks}
*/
hooks?: ComponentHooks;
}
export interface StepListPassThroughAttributes {
[key: string]: any;
}
/**
* Defines valid properties in StepList component.
*/
export interface StepListProps {
/**
* Value of step.
*/
value: string;
/**
* It generates scoped CSS variables using design tokens for the component.
*/
dt?: DesignToken<any>;
/**
* Used to pass attributes to DOM elements inside the component.
* @type {StepListPassThroughOptions}
*/
pt?: PassThrough<StepListPassThroughOptions>;
/**
* Used to configure passthrough(pt) options of the component.
* @type {PassThroughOptions}
*/
ptOptions?: PassThroughOptions;
}
/**
* Defines valid slots in StepList slots.
*/
export interface StepListSlots {
/**
* Custom content template.
*/
default(): VNode[];
}
export interface StepListEmitsOptions {}
export declare type StepListEmits = EmitFn<StepListEmitsOptions>;
/**
* **PrimeVue - StepList**
*
* _StepList is a helper component for Stepper component._
*
* [Live Demo](https://www.primevue.org/stepper/)
* --- ---
* ![PrimeVue](https://primefaces.org/cdn/primevue/images/logo-100.png)
*
* @group Component
*
*/
declare const StepList: DefineComponent<StepListProps, StepListSlots, StepListEmits>;
declare module 'vue' {
export interface GlobalComponents {
StepList: GlobalComponentConstructor<StepListProps, StepListSlots, StepListEmits>;
}
}
export default StepList;

View File

@ -0,0 +1,15 @@
<template>
<div :class="cx('root')" v-bind="ptmi('root')">
<slot />
</div>
</template>
<script>
import BaseStepList from './BaseStepList.vue';
export default {
name: 'StepList',
extends: BaseStepList,
inheritAttrs: false
};
</script>

View File

@ -0,0 +1,11 @@
{
"main": "./steplist.mjs",
"module": "./steplist.mjs",
"types": "./StepList.d.ts",
"browser": {
"./sfc": "./StepList.vue"
},
"sideEffects": [
"*.vue"
]
}

View File

@ -0,0 +1,19 @@
/**
*
* StepList is a helper component for Stepper component.
*
* [Live Demo](https://www.primevue.org/stepper/)
*
* @module stepliststyle
*
*/
import { BaseStyle } from '../../base/style';
export enum StepListClasses {
/**
* Class name of the root element
*/
root = 'p-steplist'
}
export interface StepListStyle extends BaseStyle {}

View File

@ -0,0 +1,10 @@
import BaseStyle from 'primevue/base/style';
const classes = {
root: 'p-steplist'
};
export default BaseStyle.extend({
name: 'steplist',
classes
});

View File

@ -0,0 +1,6 @@
{
"main": "./stepliststyle.mjs",
"module": "./stepliststyle.mjs",
"types": "./StepListStyle.d.ts",
"sideEffects": false
}

View File

@ -0,0 +1,30 @@
<script>
import BaseComponent from 'primevue/basecomponent';
import StepPanelStyle from 'primevue/steppanel/style';
export default {
name: 'BaseStepPanel',
extends: BaseComponent,
props: {
value: {
type: [String, Number],
default: undefined
},
asChild: {
type: Boolean,
default: false
},
as: {
type: String,
default: 'DIV'
}
},
style: StepPanelStyle,
provide() {
return {
$pcStepPanel: this,
$parentInstance: this
};
}
};
</script>

148
components/lib/steppanel/StepPanel.d.ts vendored Normal file
View File

@ -0,0 +1,148 @@
/**
*
* StepPanel is a helper component for Stepper component.
*
* [Live Demo](https://www.primevue.org/stepper/)
*
* @module steppanel
*
*/
import { VNode } from 'vue';
import { ComponentHooks } from '../basecomponent';
import { PassThroughOptions } from '../passthrough';
import { DefineComponent, DesignToken, EmitFn, GlobalComponentConstructor, PassThrough } from '../ts-helpers';
export declare type StepPanelPassThroughOptionType = StepPanelPassThroughAttributes | ((options: StepPanelPassThroughMethodOptions) => StepPanelPassThroughAttributes | string) | string | null | undefined;
/**
* Custom passthrough(pt) option method.
*/
export interface StepPanelPassThroughMethodOptions {
/**
* Defines instance.
*/
instance: any;
/**
* Defines valid properties.
*/
props: StepPanelProps;
/**
* Defines valid attributes.
*/
attrs: any;
/**
* Defines parent options.
*/
parent: any;
/**
* Defines passthrough(pt) options in global config.
*/
global: object | undefined;
}
/**
* Custom passthrough(pt) options.
* @see {@link StepPanelProps.pt}
*/
export interface StepPanelPassThroughOptions {
/**
* Used to pass attributes to the root's DOM element.
*/
root?: StepPanelPassThroughOptionType;
/**
* Used to manage all lifecycle hooks.
* @see {@link BaseComponent.ComponentHooks}
*/
hooks?: ComponentHooks;
}
export interface StepPanelPassThroughAttributes {
[key: string]: any;
}
/**
* Defines valid properties in StepPanel component.
*/
export interface StepPanelProps {
/**
* Value of step.
*/
value?: string | number | undefined;
/**
* Use to change the HTML tag of root element.
* @defaultValue BUTTON
*/
as?: string | undefined;
/**
* When enabled, it changes the default rendered element for the one passed as a child element.
* @defaultValue false
*/
asChild?: boolean | undefined;
/**
* It generates scoped CSS variables using design tokens for the component.
*/
dt?: DesignToken<any>;
/**
* Used to pass attributes to DOM elements inside the component.
* @type {StepPanelPassThroughOptions}
*/
pt?: PassThrough<StepPanelPassThroughOptions>;
/**
* Used to configure passthrough(pt) options of the component.
* @type {PassThroughOptions}
*/
ptOptions?: PassThroughOptions;
}
/**
* Defines valid slots in StepPanel slots.
*/
export interface StepPanelSlots {
/**
* Custom content template. Slot attributes can be used when asChild prop is true.
*/
default(scope: {
/**
* Whether the step is active.
*/
active: boolean;
/**
* Value of step.
*/
value: string | number;
/**
* A11t attributes
*/
a11yAttrs: any;
/**
* Click function.
*/
activateCallback: () => void;
}): VNode[];
}
export interface StepPanelEmitsOptions {}
export declare type StepPanelEmits = EmitFn<StepPanelEmitsOptions>;
/**
* **PrimeVue - StepPanel**
*
* _StepPanel is a helper component for Stepper component._
*
* [Live Demo](https://www.primevue.org/stepper/)
* --- ---
* ![PrimeVue](https://primefaces.org/cdn/primevue/images/logo-100.png)
*
* @group Component
*
*/
declare const StepPanel: DefineComponent<StepPanelProps, StepPanelSlots, StepPanelEmits>;
declare module 'vue' {
export interface GlobalComponents {
StepPanel: GlobalComponentConstructor<StepPanelProps, StepPanelSlots, StepPanelEmits>;
}
}
export default StepPanel;

View File

@ -0,0 +1,99 @@
<template>
<template v-if="isVertical">
<template v-if="!asChild">
<transition name="p-toggleable-content" v-bind="ptm('transition')">
<component v-show="active" :is="as" :id="id" :class="cx('root')" role="tabpanel" :aria-controls="ariaControls" v-bind="getPTOptions('root')">
<StepperSeparator v-if="isSeparatorVisible" />
<div :class="cx('content')" v-bind="getPTOptions('content')">
<slot :active="active" :activateCallback="(val) => updateValue(val)" />
</div>
</component>
</transition>
</template>
<slot v-else :active="active" :a11yAttrs="a11yAttrs" :activateCallback="(val) => updateValue(val)" />
</template>
<template v-else>
<template v-if="!asChild">
<component v-if="active" :is="as" :id="id" :class="cx('root')" role="tabpanel" :aria-controls="ariaControls" v-bind="getPTOptions('root')">
<slot :active="active" :activateCallback="(val) => updateValue(val)" />
</component>
</template>
<slot v-else-if="asChild && active" :active="active" :a11yAttrs="a11yAttrs" :activateCallback="(val) => updateValue(val)" />
</template>
</template>
<script>
import { DomHandler, ObjectUtils } from 'primevue/utils';
import StepperSeparator from '../stepper/StepperSeparator.vue';
import BaseStepPanel from './BaseStepPanel.vue';
export default {
name: 'StepPanel',
extends: BaseStepPanel,
inheritAttrs: false,
inject: {
$pcStepper: { default: null },
$pcStepItem: { default: null },
$pcStepList: { default: null }
},
data() {
return {
isSeparatorVisible: false
};
},
mounted() {
if (this.$el) {
let stepElements = DomHandler.find(this.$pcStepper.$el, '[data-pc-name="step"]');
let stepPanelEl = DomHandler.findSingle(this.isVertical ? this.$pcStepItem?.$el : this.$pcStepList?.$el, '[data-pc-name="step"]');
let stepPanelIndex = ObjectUtils.findIndexInList(stepPanelEl, stepElements);
this.isSeparatorVisible = this.isVertical && stepPanelIndex !== stepElements.length - 1;
}
},
methods: {
getPTOptions(key) {
const _ptm = key === 'root' ? this.ptmi : this.ptm;
return _ptm(key, {
context: {
active: this.active
}
});
},
updateValue(val) {
this.$pcStepper.updateValue(val);
}
},
computed: {
active() {
let activeValue = !!this.$pcStepItem ? this.$pcStepItem?.value : this.value;
return activeValue === this.$pcStepper?.d_value;
},
isVertical() {
return !!this.$pcStepItem;
},
activeValue() {
return this.isVertical ? this.$pcStepItem?.value : this.value;
},
id() {
return `${this.$pcStepper?.id}_steppanel_${this.activeValue}`;
},
ariaControls() {
return `${this.$pcStepper?.id}_step_${this.activeValue}`;
},
a11yAttrs() {
return {
id: this.id,
role: 'tabpanel',
'aria-controls': this.ariaControls,
'data-pc-name': 'steppanel',
'data-p-active': this.active
};
}
},
components: {
StepperSeparator
}
};
</script>

View File

@ -0,0 +1,11 @@
{
"main": "./steppanel.mjs",
"module": "./steppanel.mjs",
"types": "./StepPanel.d.ts",
"browser": {
"./sfc": "./StepPanel.vue"
},
"sideEffects": [
"*.vue"
]
}

View File

@ -0,0 +1,19 @@
/**
*
* StepPanel is a helper component for Stepper component.
*
* [Live Demo](https://www.primevue.org/stepper/)
*
* @module steppanelstyle
*
*/
import { BaseStyle } from '../../base/style';
export enum StepPanelClasses {
/**
* Class name of the root element
*/
root = 'p-steppanel'
}
export interface StepPanelStyle extends BaseStyle {}

View File

@ -0,0 +1,16 @@
import BaseStyle from 'primevue/base/style';
const classes = {
root: ({ instance }) => [
'p-steppanel',
{
'p-steppanel-active': instance.isVertical && instance.active
}
],
content: 'p-steppanel-content'
};
export default BaseStyle.extend({
name: 'steppanel',
classes
});

View File

@ -0,0 +1,6 @@
{
"main": "./steppanelstyle.mjs",
"module": "./steppanelstyle.mjs",
"types": "./StepPanelStyle.d.ts",
"sideEffects": false
}

View File

@ -0,0 +1,22 @@
<script>
import BaseComponent from 'primevue/basecomponent';
import StepPanelsStyle from 'primevue/steppanels/style';
export default {
name: 'BaseStepPanels',
extends: BaseComponent,
props: {
value: {
type: String,
default: undefined
}
},
style: StepPanelsStyle,
provide() {
return {
$pcStepPanels: this,
$parentInstance: this
};
}
};
</script>

View File

@ -0,0 +1,121 @@
/**
*
* StepPanels is a helper component for Stepper component.
*
* [Live Demo](https://www.primevue.org/stepper/)
*
* @module steppanels
*
*/
import { VNode } from 'vue';
import { ComponentHooks } from '../basecomponent';
import { PassThroughOptions } from '../passthrough';
import { DefineComponent, DesignToken, EmitFn, GlobalComponentConstructor, PassThrough } from '../ts-helpers';
export declare type StepPanelsPassThroughOptionType = StepPanelsPassThroughAttributes | ((options: StepPanelsPassThroughMethodOptions) => StepPanelsPassThroughAttributes | string) | string | null | undefined;
/**
* Custom passthrough(pt) option method.
*/
export interface StepPanelsPassThroughMethodOptions {
/**
* Defines instance.
*/
instance: any;
/**
* Defines valid properties.
*/
props: StepPanelsProps;
/**
* Defines valid attributes.
*/
attrs: any;
/**
* Defines parent options.
*/
parent: any;
/**
* Defines passthrough(pt) options in global config.
*/
global: object | undefined;
}
/**
* Custom passthrough(pt) options.
* @see {@link StepPanelsProps.pt}
*/
export interface StepPanelsPassThroughOptions {
/**
* Used to pass attributes to the root's DOM element.
*/
root?: StepPanelsPassThroughOptionType;
/**
* Used to manage all lifecycle hooks.
* @see {@link BaseComponent.ComponentHooks}
*/
hooks?: ComponentHooks;
}
export interface StepPanelsPassThroughAttributes {
[key: string]: any;
}
/**
* Defines valid properties in StepPanels component.
*/
export interface StepPanelsProps {
/**
* Value of step.
*/
value: string;
/**
* It generates scoped CSS variables using design tokens for the component.
*/
dt?: DesignToken<any>;
/**
* Used to pass attributes to DOM elements inside the component.
* @type {StepPanelsPassThroughOptions}
*/
pt?: PassThrough<StepPanelsPassThroughOptions>;
/**
* Used to configure passthrough(pt) options of the component.
* @type {PassThroughOptions}
*/
ptOptions?: PassThroughOptions;
}
/**
* Defines valid slots in StepPanels slots.
*/
export interface StepPanelsSlots {
/**
* Custom content template.
*/
default(): VNode[];
}
export interface StepPanelsEmitsOptions {}
export declare type StepPanelsEmits = EmitFn<StepPanelsEmitsOptions>;
/**
* **PrimeVue - StepPanels**
*
* _StepPanels is a helper component for Stepper component._
*
* [Live Demo](https://www.primevue.org/stepper/)
* --- ---
* ![PrimeVue](https://primefaces.org/cdn/primevue/images/logo-100.png)
*
* @group Component
*
*/
declare const StepPanels: DefineComponent<StepPanelsProps, StepPanelsSlots, StepPanelsEmits>;
declare module 'vue' {
export interface GlobalComponents {
StepPanels: GlobalComponentConstructor<StepPanelsProps, StepPanelsSlots, StepPanelsEmits>;
}
}
export default StepPanels;

View File

@ -0,0 +1,15 @@
<template>
<div :class="cx('root')" v-bind="ptmi('root')">
<slot />
</div>
</template>
<script>
import BaseStepPanels from './BaseStepPanels.vue';
export default {
name: 'StepPanels',
extends: BaseStepPanels,
inheritAttrs: false
};
</script>

View File

@ -0,0 +1,11 @@
{
"main": "./steppanels.mjs",
"module": "./steppanels.mjs",
"types": "./StepPanels.d.ts",
"browser": {
"./sfc": "./StepPanels.vue"
},
"sideEffects": [
"*.vue"
]
}

View File

@ -0,0 +1,19 @@
/**
*
* StepPanels
*
* [Live Demo](https://www.primevue.org/stepper/)
*
* @module steppanelsstyle
*
*/
import { BaseStyle } from '../../base/style';
export enum StepPanelsClasses {
/**
* Class name of the root element
*/
root = 'p-steppanels'
}
export interface StepPanelsStyle extends BaseStyle {}

View File

@ -0,0 +1,10 @@
import BaseStyle from 'primevue/base/style';
const classes = {
root: 'p-steppanels'
};
export default BaseStyle.extend({
name: 'steppanels',
classes
});

View File

@ -0,0 +1,6 @@
{
"main": "./steppanelsstyle.mjs",
"module": "./steppanelsstyle.mjs",
"types": "./StepPanelsStyle.d.ts",
"sideEffects": false
}

View File

@ -6,13 +6,9 @@ export default {
name: 'BaseStepper', name: 'BaseStepper',
extends: BaseComponent, extends: BaseComponent,
props: { props: {
activeStep: { value: {
type: Number, type: [String, Number],
default: 0 default: undefined
},
orientation: {
type: String,
default: 'horizontal'
}, },
linear: { linear: {
type: Boolean, type: Boolean,

View File

@ -10,7 +10,6 @@
import { VNode } from 'vue'; import { VNode } from 'vue';
import { ComponentHooks } from '../basecomponent'; import { ComponentHooks } from '../basecomponent';
import { PassThroughOptions } from '../passthrough'; import { PassThroughOptions } from '../passthrough';
import { StepperPanelPassThroughOptionType } from '../stepperpanel';
import { DefineComponent, DesignToken, EmitFn, GlobalComponentConstructor, PassThrough } from '../ts-helpers'; import { DefineComponent, DesignToken, EmitFn, GlobalComponentConstructor, PassThrough } from '../ts-helpers';
export declare type StepperPassThroughOptionType = StepperPassThroughAttributes | ((options: StepperPassThroughMethodOptions) => StepperPassThroughAttributes | string) | string | null | undefined; export declare type StepperPassThroughOptionType = StepperPassThroughAttributes | ((options: StepperPassThroughMethodOptions) => StepperPassThroughAttributes | string) | string | null | undefined;
@ -54,18 +53,6 @@ export interface StepperPassThroughOptions {
* Used to pass attributes to the root's DOM element. * Used to pass attributes to the root's DOM element.
*/ */
root?: StepperPassThroughOptionType; root?: StepperPassThroughOptionType;
/**
* Used to pass attributes to the list's DOM element.
*/
list?: StepperPassThroughOptionType;
/**
* Used to pass attributes to the panels' DOM element.
*/
panels?: StepperPassThroughOptionType;
/**
* Used to pass attributes to the end handler's DOM element.
*/
stepperpanel?: StepperPanelPassThroughOptionType;
/** /**
* Used to manage all lifecycle hooks. * Used to manage all lifecycle hooks.
* @see {@link BaseComponent.ComponentHooks} * @see {@link BaseComponent.ComponentHooks}
@ -85,44 +72,24 @@ export interface StepperPassThroughAttributes {
*/ */
export interface StepperState { export interface StepperState {
/** /**
* Current active index state. * Current active value state.
*/ */
d_activeStep: number; d_value: any;
/** /**
* Unique id for the Stepper component. * Unique id for the Stepper component.
*/ */
id: string; id: string;
} }
/**
* Custom tab change event.
* @see {@link StepperEmitsOptions['step-change']}
*/
export interface StepperChangeEvent {
/**
* Browser event
*/
originalEvent: Event;
/**
* Index of the selected stepper panel
*/
index: number;
}
/** /**
* Defines valid properties in Stepper component. * Defines valid properties in Stepper component.
*/ */
export interface StepperProps { export interface StepperProps {
/** /**
* Active step index of stepper. * Active value of stepper.
* @defaultValue 0 * @defaultValue null
*/ */
activeStep?: number | undefined; value?: string | number | undefined;
/**
* Orientation of the stepper.
* @defaultValue horizontal
*/
orientation?: 'horizontal' | 'vertical' | undefined;
/** /**
* Whether the steps are clickable or not. * Whether the steps are clickable or not.
* @defaultValue false * @defaultValue false
@ -153,6 +120,10 @@ export interface StepperProps {
* Defines valid slots in Stepper component. * Defines valid slots in Stepper component.
*/ */
export interface StepperSlots { export interface StepperSlots {
/**
* Custom default template.
*/
default(): VNode[];
/** /**
* Custom start template. * Custom start template.
*/ */
@ -169,13 +140,9 @@ export interface StepperSlots {
export interface StepperEmitsOptions { export interface StepperEmitsOptions {
/** /**
* Emitted when the value changes. * Emitted when the value changes.
* @param {number | number[]} value - New value. * @param {any} value - New value.
*/ */
'update:activeStep'(value: number): void; 'update:value'(value: any): void;
/**
* Callback to invoke when an active panel is changed.
*/
'step-change'(event: StepperChangeEvent): void;
} }
export declare type StepperEmits = EmitFn<StepperEmitsOptions>; export declare type StepperEmits = EmitFn<StepperEmitsOptions>;

View File

@ -1,266 +1,50 @@
<template> <template>
<div :class="cx('root')" role="tablist" v-bind="ptmi('root')"> <div :class="cx('root')" role="tablist" v-bind="ptmi('root')">
<slot v-if="$slots.start" name="start" /> <slot v-if="$slots.start" name="start" />
<slot />
<template v-if="orientation === 'horizontal'">
<ul ref="nav" :class="cx('list')" v-bind="ptm('list')">
<li
v-for="(step, index) of stepperpanels"
:key="getStepKey(step, index)"
:class="cx('stepper.item', { step, index })"
:aria-current="isStepActive(index) ? 'step' : undefined"
role="presentation"
v-bind="{ ...getStepPT(step, 'root', index), ...getStepPT(step, 'item', index) }"
data-pc-name="stepperpanel"
:data-p-active="isStepActive(index)"
:data-p-disabled="isItemDisabled(index)"
:data-pc-index="index"
>
<slot name="header">
<StepperHeader
:id="getStepHeaderActionId(index)"
:template="step.children?.header"
:stepperpanel="step"
:index="index"
:disabled="isItemDisabled(index)"
:active="isStepActive(index)"
:highlighted="index < d_activeStep"
:class="cx('stepper.itemHeader')"
:aria-controls="getStepContentId(index)"
:clickCallback="(event) => onItemClick(event, index)"
:getStepPT="getStepPT"
:getStepProp="getStepProp"
:unstyled="unstyled"
/>
</slot>
<slot v-if="index !== stepperpanels.length - 1" name="separator">
<StepperSeparator
:template="step.children?.separator"
:separatorClass="cx('stepper.separator')"
:stepperpanel="step"
:index="index"
:active="isStepActive(index)"
:highlighted="index < d_activeStep"
:getStepPT="getStepPT(step, 'separator', index)"
:unstyled="unstyled"
/>
</slot>
</li>
</ul>
<div :class="cx('panels')" v-bind="ptm('panels')">
<template v-for="(step, index) of stepperpanels" :key="getStepKey(step, index)">
<StepperContent
v-show="isStepActive(index)"
:id="getStepContentId(index)"
:template="step?.children?.content"
:stepperpanel="step"
:index="index"
:active="isStepActive(index)"
:highlighted="index < d_activeStep"
:clickCallback="(event) => onItemClick(event, index)"
:prevCallback="(event) => prevCallback(event, index)"
:nextCallback="(event) => nextCallback(event, index)"
:getStepPT="getStepPT"
:aria-labelledby="getStepHeaderActionId(index)"
:unstyled="unstyled"
/>
</template>
</div>
</template>
<template v-else-if="orientation === 'vertical'">
<div
v-for="(step, index) of stepperpanels"
ref="nav"
:key="getStepKey(step, index)"
:class="cx('panel', { step, index })"
:aria-current="isStepActive(index) ? 'step' : undefined"
v-bind="{ ...getStepPT(step, 'root', index), ...getStepPT(step, 'panel', index) }"
data-pc-name="stepperpanel"
:data-p-active="isStepActive(index)"
:data-p-disabled="isItemDisabled(index)"
:data-pc-index="index"
>
<div :class="cx('stepper.item', { step, index })" v-bind="getStepPT(step, 'item', index)">
<slot name="header">
<StepperHeader
:id="getStepHeaderActionId(index)"
:template="step.children?.header"
:stepperpanel="step"
:index="index"
:disabled="isItemDisabled(index)"
:active="isStepActive(index)"
:highlighted="index < d_activeStep"
:class="cx('stepper.itemHeader')"
:aria-controls="getStepContentId(index)"
:clickCallback="(event) => onItemClick(event, index)"
:getStepPT="getStepPT"
:getStepProp="getStepProp"
/>
</slot>
</div>
<transition name="p-toggleable-content" v-bind="getStepPT(step, 'transition', index)">
<div v-show="isStepActive(index)" :class="cx('stepper.panelContentContainer')" v-bind="getStepPT(step, 'panelContentContainer', index)">
<slot v-if="index !== stepperpanels.length - 1" name="separator">
<StepperSeparator
:template="step.children?.separator"
:separatorClass="cx('stepper.separator')"
:stepperpanel="step"
:index="index"
:active="isStepActive(index)"
:highlighted="index < d_activeStep"
:getStepPT="getStepPT(step, 'separator', index)"
/>
</slot>
<slot name="content">
<StepperContent
:id="getStepContentId(index)"
:template="step?.children?.content"
:stepperpanel="step"
:index="index"
:active="isStepActive(index)"
:highlighted="index < d_activeStep"
:clickCallback="(event) => onItemClick(event, index)"
:prevCallback="(event) => prevCallback(event, index)"
:nextCallback="(event) => nextCallback(event, index)"
:getStepPT="getStepPT"
:aria-labelledby="getStepHeaderActionId(index)"
/>
</slot>
</div>
</transition>
</div>
</template>
<slot v-if="$slots.end" name="end" /> <slot v-if="$slots.end" name="end" />
</div> </div>
</template> </template>
<script> <script>
import { UniqueComponentId } from 'primevue/utils'; import { UniqueComponentId } from 'primevue/utils';
import { mergeProps } from 'vue';
import BaseStepper from './BaseStepper.vue'; import BaseStepper from './BaseStepper.vue';
import StepperContent from './StepperContent.vue';
import StepperHeader from './StepperHeader.vue';
import StepperSeparator from './StepperSeparator.vue';
export default { export default {
name: 'Stepper', name: 'Stepper',
extends: BaseStepper, extends: BaseStepper,
inheritAttrs: false, inheritAttrs: false,
emits: ['update:activeStep', 'step-change'], emits: ['update:value'],
data() { data() {
return { return {
id: this.$attrs.id, id: this.$attrs.id,
d_activeStep: this.activeStep d_value: this.value
}; };
}, },
watch: { watch: {
'$attrs.id': function (newValue) { '$attrs.id'(newValue) {
this.id = newValue || UniqueComponentId(); this.id = newValue || UniqueComponentId();
}, },
activeStep(newValue) { value(newValue) {
this.d_activeStep = newValue; this.d_value = newValue;
} }
}, },
mounted() { mounted() {
this.id = this.id || UniqueComponentId(); this.id = this.id || UniqueComponentId();
}, },
methods: { methods: {
isStep(child) { updateValue(newValue) {
return child.type.name === 'StepperPanel'; if (this.d_value !== newValue) {
}, this.d_value = newValue;
isStepActive(index) { this.$emit('update:value', newValue);
return this.d_activeStep === index;
},
getStepProp(step, name) {
return step.props ? step.props[name] : undefined;
},
getStepKey(step, index) {
return this.getStepProp(step, 'header') || index;
},
getStepHeaderActionId(index) {
return `${this.id}_${index}_header_action`;
},
getStepContentId(index) {
return `${this.id}_${index}_content`;
},
getStepPT(step, key, index) {
const count = this.stepperpanels.length;
const stepMetaData = {
props: step.props,
parent: {
instance: this,
props: this.$props,
state: this.$data
},
context: {
index,
count,
first: index === 0,
last: index === count - 1,
active: this.isStepActive(index),
highlighted: index < this.d_activeStep,
disabled: this.isItemDisabled(index)
}
};
return mergeProps(this.ptm(`stepperpanel.${key}`, { stepperpanel: stepMetaData }), this.ptm(`stepperpanel.${key}`, stepMetaData), this.ptmo(this.getStepProp(step, 'pt'), key, stepMetaData));
},
updateActiveStep(event, index) {
this.d_activeStep = index;
this.$emit('update:activeStep', index);
this.$emit('step-change', {
originalEvent: event,
index
});
},
onItemClick(event, index) {
if (this.linear) {
event.preventDefault();
return;
}
if (index !== this.d_activeStep) {
this.updateActiveStep(event, index);
} }
}, },
isItemDisabled(index) { isStepActive(value) {
return this.linear && !this.isStepActive(index); return this.d_value === value;
}, },
prevCallback(event, index) { isStepDisabled() {
if (index !== 0) { return this.linear;
this.updateActiveStep(event, index - 1);
}
},
nextCallback(event, index) {
if (index !== this.stepperpanels.length - 1) {
this.updateActiveStep(event, index + 1);
}
} }
},
computed: {
stepperpanels() {
return this.$slots.default().reduce((stepperpanels, child) => {
if (this.isStep(child)) {
stepperpanels.push(child);
} else if (child.children && child.children instanceof Array) {
child.children.forEach((nestedChild) => {
if (this.isStep(nestedChild)) {
stepperpanels.push(nestedChild);
}
});
}
return stepperpanels;
}, []);
}
},
components: {
StepperContent,
StepperHeader,
StepperSeparator
} }
}; };
</script> </script>

View File

@ -1,47 +0,0 @@
<template>
<div
:id="id"
:class="cx('stepper.panelContent', { stepperpanel, index })"
role="tabpanel"
:aria-labelledby="ariaLabelledby"
v-bind="{ ...getStepPT(stepperpanel, 'root', index), ...getStepPT(stepperpanel, 'panelContent', index) }"
data-pc-name="stepperpanel"
:data-pc-index="index"
:data-p-active="active"
>
<component
v-if="template"
:is="template"
:index="index"
:active="active"
:highlighted="highlighted"
:clickCallback="(event) => onItemClick(event, index)"
:prevCallback="(event) => prevCallback(event, index)"
:nextCallback="(event) => nextCallback(event, index)"
></component>
<component v-else :is="stepperpanel"></component>
</div>
</template>
<script>
import BaseComponent from 'primevue/basecomponent';
export default {
name: 'StepperContent',
hostName: 'Stepper',
extends: BaseComponent,
props: {
id: null,
template: null,
ariaLabelledby: null,
stepperpanel: null,
index: null,
active: null,
highlighted: null,
clickCallback: null,
prevCallback: null,
nextCallback: null,
getStepPT: null
}
};
</script>

View File

@ -1,41 +0,0 @@
<template>
<component
v-if="template"
:is="template"
:index="index"
:active="active"
:highlighted="highlighted"
:class="cx('stepper.itemHeader')"
:headerClass="cx('stepper.itemHeader')"
:numberClass="cx('stepper.itemNumber')"
:titleClass="cx('stepper.itemTitle')"
:clickCallback="(event) => clickCallback(event, index)"
/>
<button v-else :id="id" :class="cx('stepper.itemHeader')" role="tab" :tabindex="disabled ? -1 : undefined" :aria-controls="ariaControls" @click="clickCallback($event, index)" v-bind="getStepPT(stepperpanel, 'itemHeader', index)">
<span :class="cx('stepper.itemNumber')" v-bind="getStepPT(stepperpanel, 'itemNumber', index)">{{ index + 1 }}</span>
<span :class="cx('stepper.itemTitle')" v-bind="getStepPT(stepperpanel, 'itemTitle', index)">{{ getStepProp(stepperpanel, 'header') }}</span>
</button>
</template>
<script>
import BaseComponent from 'primevue/basecomponent';
export default {
name: 'StepperHeader',
hostName: 'Stepper',
extends: BaseComponent,
props: {
id: null,
template: null,
stepperpanel: null,
index: null,
disabled: null,
active: null,
highlighted: null,
ariaControls: null,
clickCallback: null,
getStepPT: null,
getStepProp: null
}
};
</script>

View File

@ -1,6 +1,5 @@
<template> <template>
<component v-if="template" :is="template" :class="separatorClass" :index="index" :active="active" :highlighted="highlighted" /> <span :class="cx('separator')" v-bind="ptm('separator')" />
<span v-else :class="separatorClass" aria-hidden="true" v-bind="getStepPT" />
</template> </template>
<script> <script>
@ -9,15 +8,6 @@ import BaseComponent from 'primevue/basecomponent';
export default { export default {
name: 'StepperSeparator', name: 'StepperSeparator',
hostName: 'Stepper', hostName: 'Stepper',
extends: BaseComponent, extends: BaseComponent
props: {
template: null,
separatorClass: null,
stepperpanel: null,
index: null,
active: null,
highlighted: null,
getStepPT: null
}
}; };
</script> </script>

View File

@ -15,45 +15,9 @@ export enum StepperClasses {
*/ */
root = 'p-stepper', root = 'p-stepper',
/** /**
* Class name of the list element * Class name of the separator element
*/ */
list = 'p-stepper-list', separator = 'p-stepper-separator'
/**
* Class name of the stepper item element
*/
stepperItem = 'p-stepper-item',
/**
* Class name of the stepper item header element
*/
stepperItemHeader = 'p-stepper-item-header',
/**
* Class name of the stepper item number element
*/
stepperItemNumber = 'p-stepper-item-number',
/**
* Class name of the stepper item title element
*/
stepperItemTitle = 'p-stepper-item-title',
/**
* Class name of the stepper separator element
*/
stepperSeparator = 'p-stepper-separator',
/**
* Class name of the stepper panel content container element
*/
stepperPanelContentContainer = 'p-stepper-panel-content-container',
/**
* Class name of the stepper panel content element
*/
stepperPanelContent = 'p-stepper-panel-content',
/**
* Class name of the panels element
*/
panels = 'p-stepper-panels',
/**
* Class name of the panel element
*/
panel = 'p-stepper-panel'
} }
export interface StepperStyle extends BaseStyle {} export interface StepperStyle extends BaseStyle {}

View File

@ -1,7 +1,7 @@
import BaseStyle from 'primevue/base/style'; import BaseStyle from 'primevue/base/style';
const theme = ({ dt }) => ` const theme = ({ dt }) => `
.p-stepper-list { .p-steplist {
position: relative; position: relative;
display: flex; display: flex;
justify-content: space-between; justify-content: space-between;
@ -12,20 +12,20 @@ const theme = ({ dt }) => `
overflow-x: auto; overflow-x: auto;
} }
.p-stepper-item { .p-step {
position: relative; position: relative;
display: flex; display: flex;
flex: 1 1 auto; flex: 1 1 auto;
align-items: center; align-items: center;
gap: ${dt('stepper.item.gap')}; gap: ${dt('stepper.step.gap')};
padding: ${dt('stepper.item.padding')}; padding: ${dt('stepper.step.padding')};
} }
.p-stepper-item:last-of-type { .p-step:last-of-type {
flex: initial; flex: initial;
} }
.p-stepper-item-header { .p-step-header {
border: 0 none; border: 0 none;
display: inline-flex; display: inline-flex;
align-items: center; align-items: center;
@ -34,82 +34,86 @@ const theme = ({ dt }) => `
transition: background ${dt('stepper.transition.duration')}, color ${dt('stepper.transition.duration')}, border-color ${dt('stepper.transition.duration')}, outline-color ${dt('stepper.transition.duration')}, box-shadow ${dt( transition: background ${dt('stepper.transition.duration')}, color ${dt('stepper.transition.duration')}, border-color ${dt('stepper.transition.duration')}, outline-color ${dt('stepper.transition.duration')}, box-shadow ${dt(
'stepper.transition.duration' 'stepper.transition.duration'
)}; )};
border-radius: ${dt('stepper.item.header.border.radius')}; border-radius: ${dt('stepper.step.header.border.radius')};
outline-color: transparent; outline-color: transparent;
background: transparent; background: transparent;
padding: ${dt('stepper.item.header.padding')}; padding: ${dt('stepper.step.header.padding')};
gap: ${dt('stepper.item.header.gap')}; gap: ${dt('stepper.step.header.gap')};
} }
.p-stepper-item-header:focus-visible { .p-step-header:focus-visible {
box-shadow: ${dt('stepper.item.header.focus.ring.shadow')}; box-shadow: ${dt('stepper.step.header.focus.ring.shadow')};
outline: ${dt('stepper.item.header.focus.ring.width')} ${dt('stepper.item.header.focus.ring.style')} ${dt('stepper.item.header.focus.ring.color')}; outline: ${dt('stepper.step.header.focus.ring.width')} ${dt('stepper.step.header.focus.ring.style')} ${dt('stepper.step.header.focus.ring.color')};
outline-offset: ${dt('stepper.item.header.focus.ring.offset')}; outline-offset: ${dt('stepper.step.header.focus.ring.offset')};
} }
.p-stepper.p-stepper-readonly .p-stepper-item { .p-stepper.p-stepper-readonly .p-step {
cursor: auto; cursor: auto;
} }
.p-stepper-item-title { .p-step-title {
display: block; display: block;
white-space: nowrap; white-space: nowrap;
overflow: hidden; overflow: hidden;
text-overflow: ellipsis; text-overflow: ellipsis;
max-width: 100%; max-width: 100%;
color: ${dt('stepper.item.title.color')}; color: ${dt('stepper.step.title.color')};
font-weight: ${dt('stepper.item.title.font.weight')}; font-weight: ${dt('stepper.step.title.font.weight')};
transition: background ${dt('stepper.transition.duration')}, color ${dt('stepper.transition.duration')}, border-color ${dt('stepper.transition.duration')}, box-shadow ${dt('stepper.transition.duration')}, outline-color ${dt( transition: background ${dt('stepper.transition.duration')}, color ${dt('stepper.transition.duration')}, border-color ${dt('stepper.transition.duration')}, box-shadow ${dt('stepper.transition.duration')}, outline-color ${dt(
'stepper.transition.duration' 'stepper.transition.duration'
)}; )};
} }
.p-stepper-item-number { .p-step-number {
display: flex; display: flex;
align-items: center; align-items: center;
justify-content: center; justify-content: center;
color: ${dt('stepper.item.number.color')}; color: ${dt('stepper.step.number.color')};
border: 2px solid ${dt('stepper.item.number.border.color')}; border: 2px solid ${dt('stepper.step.number.border.color')};
background: ${dt('stepper.item.number.background')}; background: ${dt('stepper.step.number.background')};
min-width: ${dt('stepper.item.number.size')}; min-width: ${dt('stepper.step.number.size')};
height: ${dt('stepper.item.number.size')}; height: ${dt('stepper.step.number.size')};
line-height: ${dt('stepper.item.number.size')}; line-height: ${dt('stepper.step.number.size')};
font-size: ${dt('stepper.item.number.font.size')}; font-size: ${dt('stepper.step.number.font.size')};
z-index: 1; z-index: 1;
border-radius: ${dt('stepper.item.number.border.radius')}; border-radius: ${dt('stepper.step.number.border.radius')};
position: relative; position: relative;
font-weight: ${dt('stepper.item.number.font.weight')}; font-weight: ${dt('stepper.step.number.font.weight')};
} }
.p-stepper-item-number::after { .p-step-number::after {
content: " "; content: " ";
position: absolute; position: absolute;
width: 100%; width: 100%;
height: 100%; height: 100%;
border-radius: ${dt('stepper.item.number.border.radius')}; border-radius: ${dt('stepper.step.number.border.radius')};
box-shadow: ${dt('stepper.item.number.shadow')}; box-shadow: ${dt('stepper.step.number.shadow')};
} }
.p-stepper-item-active .p-stepper-item-header { .p-step-active .p-step-header {
cursor: default; cursor: default;
} }
.p-stepper-item-active .p-stepper-item-number { .p-step-active .p-step-number {
background: ${dt('stepper.item.number.active.background')}; background: ${dt('stepper.step.number.active.background')};
border-color: ${dt('stepper.item.number.active.border.color')}; border-color: ${dt('stepper.step.number.active.border.color')};
color: ${dt('stepper.item.number.active.color')}; color: ${dt('stepper.step.number.active.color')};
} }
.p-stepper-item-active .p-stepper-item-title { .p-step-active .p-step-title {
color: ${dt('stepper.item.title.active.color')}; color: ${dt('stepper.step.title.active.color')};
} }
.p-stepper-item:not(.p-disabled):focus-visible { .p-step:not(.p-disabled):focus-visible {
outline: ${dt('focus.ring.width')} ${dt('focus.ring.style')} ${dt('focus.ring.color')}; outline: ${dt('focus.ring.width')} ${dt('focus.ring.style')} ${dt('focus.ring.color')};
outline-offset: ${dt('focus.ring.offset')}; outline-offset: ${dt('focus.ring.offset')};
} }
.p-stepper-item:has(~ .p-stepper-item-active) .p-stepper-separator { .p-step:has(~ .p-step-active) .p-stepper-separator {
background: ${dt('stepper.separator.active.background')};
}
.p-step:has(~ .p-step-active) .p-stepper-separator {
background: ${dt('stepper.separator.active.background')}; background: ${dt('stepper.separator.active.background')};
} }
@ -123,63 +127,59 @@ const theme = ({ dt }) => `
)}; )};
} }
.p-stepper-panels { .p-steppanels {
padding: ${dt('stepper.panel.content.orientation.horizontal.padding')}; padding: ${dt('stepper.steppanels.padding')};
} }
.p-stepper-panel-content { .p-steppanel {
background: ${dt('stepper.panel.content.background')}; background: ${dt('stepper.steppanel.content.background')};
color: ${dt('stepper.panel.content.color')}; color: ${dt('stepper.steppanel.content.color')};
} }
.p-stepper-vertical .p-stepper-list { .p-stepper:has(.p-stepitem) {
flex-direction: column;
}
.p-stepper-vertical {
display: flex; display: flex;
flex-direction: column; flex-direction: column;
} }
.p-stepper-vertical .p-stepper-panel-content-container { .p-stepitem {
display: flex;
flex: 1 1 auto;
}
.p-stepper-vertical .p-stepper-panel {
display: flex; display: flex;
flex-direction: column; flex-direction: column;
flex: initial; flex: initial;
} }
.p-stepper-vertical .p-stepper-panel.p-stepper-panel-active { .p-stepitem.p-stepitem-active {
flex: 1 1 auto; flex: 1 1 auto;
} }
.p-stepper-vertical .p-stepper-panel .p-stepper-item { .p-stepitem .p-step {
flex: initial; flex: initial;
} }
.p-stepper-vertical .p-stepper-panel .p-stepper-panel-content { .p-stepitem .p-steppanel-content {
width: 100%; width: 100%;
padding: ${dt('stepper.panel.content.orientation.vertical.padding')}; padding: ${dt('stepper.steppanel.padding')};
} }
.p-stepper-vertical .p-stepper-panel .p-stepper-separator { .p-stepitem .p-steppanel {
display: flex;
flex: 1 1 auto;
}
.p-stepitem .p-stepper-separator {
flex: 0 0 auto; flex: 0 0 auto;
width: ${dt('stepper.separator.size')}; width: ${dt('stepper.separator.size')};
height: auto; height: auto;
margin: ${dt('stepper.separator.orientation.vertical.margin')}; margin: ${dt('stepper.separator.margin')};
position: relative; position: relative;
left: calc(-1 * ${dt('stepper.separator.size')} / 2); left: calc(-1 * ${dt('stepper.separator.size')});
} }
.p-stepper-vertical .p-stepper-panel:has(~ .p-stepper-panel-active) .p-stepper-separator { .p-stepitem:has(~ .p-stepitem-active) .p-stepper-separator {
background: ${dt('stepper.connector.active.background')}; background: ${dt('stepper.separator.active.background')};
} }
.p-stepper-vertical .p-stepper-panel:last-of-type .p-stepper-panel-content { .p-stepitem:last-of-type .p-steppanel {
padding: ${dt('stepper.panel.content.orientation.vertical.last.padding')}; padding: ${dt('stepper.steppanel.last.padding')};
} }
`; `;
@ -187,34 +187,10 @@ const classes = {
root: ({ props }) => [ root: ({ props }) => [
'p-stepper p-component', 'p-stepper p-component',
{ {
'p-stepper-horizontal': props.orientation === 'horizontal',
'p-stepper-vertical': props.orientation === 'vertical',
'p-readonly': props.linear 'p-readonly': props.linear
} }
], ],
list: 'p-stepper-list', separator: 'p-stepper-separator'
stepper: {
item: ({ instance, step, index }) => [
'p-stepper-item',
{
'p-stepper-item-active': instance.isStepActive(index),
'p-disabled': instance.isItemDisabled(index)
}
],
itemHeader: 'p-stepper-item-header',
itemNumber: 'p-stepper-item-number',
itemTitle: 'p-stepper-item-title',
separator: 'p-stepper-separator',
panelContentContainer: 'p-stepper-panel-content-container',
panelContent: 'p-stepper-panel-content'
},
panels: 'p-stepper-panels',
panel: ({ instance, props, index }) => [
'p-stepper-panel',
{
'p-stepper-panel-active': props.orientation === 'vertical' && instance.isStepActive(index)
}
]
}; };
export default BaseStyle.extend({ export default BaseStyle.extend({

View File

@ -266,6 +266,8 @@ export interface StepperPanelEmitsOptions {}
export declare type StepperPanelEmits = EmitFn<StepperPanelEmitsOptions>; export declare type StepperPanelEmits = EmitFn<StepperPanelEmitsOptions>;
/** /**
* @deprecated since v4. Use the new structure of Stepper instead.
*
* **PrimeVue - StepperPanel** * **PrimeVue - StepperPanel**
* *
* _StepperPanel is a helper component for Stepper component._ * _StepperPanel is a helper component for Stepper component._

View File

@ -7,6 +7,9 @@ import BaseStepperPanel from './BaseStepperPanel.vue';
export default { export default {
name: 'StepperPanel', name: 'StepperPanel',
extends: BaseStepperPanel extends: BaseStepperPanel,
mounted() {
console.warn('Deprecated since v4. Use the new structure of Stepper instead.');
}
}; };
</script> </script>

View File

@ -5,18 +5,14 @@ export default {
separator: { separator: {
background: '{content.border.color}', background: '{content.border.color}',
activeBackground: '{primary.color}', activeBackground: '{primary.color}',
orientation: { margin: '0 0 0 1.625rem',
vertical: {
margin: '0 0 0 1.625rem'
}
},
size: '2px' size: '2px'
}, },
item: { step: {
padding: '0.5rem', padding: '0.5rem',
gap: '1rem' gap: '1rem'
}, },
itemHeader: { stepHeader: {
padding: '0', padding: '0',
borderRadius: '{content.border.radius}', borderRadius: '{content.border.radius}',
focusRing: { focusRing: {
@ -28,12 +24,12 @@ export default {
}, },
gap: '0.5rem' gap: '0.5rem'
}, },
itemTitle: { stepTitle: {
color: '{text.muted.color}', color: '{text.muted.color}',
activeColor: '{primary.color}', activeColor: '{primary.color}',
fontWeight: '500' fontWeight: '500'
}, },
itemNumber: { stepNumber: {
background: '{content.background}', background: '{content.background}',
activeBackground: '{content.background}', activeBackground: '{content.background}',
borderColor: '{content.border.color}', borderColor: '{content.border.color}',
@ -46,22 +42,15 @@ export default {
borderRadius: '50%', borderRadius: '50%',
shadow: '0px 0.5px 0px 0px rgba(0, 0, 0, 0.06), 0px 1px 1px 0px rgba(0, 0, 0, 0.12)' shadow: '0px 0.5px 0px 0px rgba(0, 0, 0, 0.06), 0px 1px 1px 0px rgba(0, 0, 0, 0.12)'
}, },
verticalPanelContainer: { steppanels: {
paddingLeft: '1rem' padding: '0.875rem 0.5rem 1.125rem 0.5rem'
}, },
panelContent: { steppanel: {
background: '{content.background}', background: '{content.background}',
color: '{content.color}', color: '{content.color}',
orientation: { padding: '0 0 0 1rem',
horizontal: { last: {
padding: '0.875rem 0.5rem 1.125rem 0.5rem' padding: '0 0 0 1.625rem'
},
vertical: {
padding: '0 0 0 1rem',
last: {
padding: '0 0 0 3rem'
}
}
} }
} }
}; };

View File

@ -5,18 +5,14 @@ export default {
separator: { separator: {
background: '{content.border.color}', background: '{content.border.color}',
activeBackground: '{primary.color}', activeBackground: '{primary.color}',
orientation: { margin: '0 0 0 1.625rem',
vertical: {
margin: '0 0 0 1.625rem'
}
},
size: '2px' size: '2px'
}, },
item: { step: {
padding: '0.5rem', padding: '0.5rem',
gap: '1rem' gap: '1rem'
}, },
itemHeader: { stepHeader: {
padding: '0', padding: '0',
borderRadius: '{content.border.radius}', borderRadius: '{content.border.radius}',
focusRing: { focusRing: {
@ -28,12 +24,12 @@ export default {
}, },
gap: '0.5rem' gap: '0.5rem'
}, },
itemTitle: { stepTitle: {
color: '{text.muted.color}', color: '{text.muted.color}',
activeColor: '{primary.color}', activeColor: '{primary.color}',
fontWeight: '500' fontWeight: '500'
}, },
itemNumber: { stepNumber: {
background: '{content.background}', background: '{content.background}',
activeBackground: '{primary.color}', activeBackground: '{primary.color}',
borderColor: '{content.border.color}', borderColor: '{content.border.color}',
@ -46,22 +42,15 @@ export default {
borderRadius: '50%', borderRadius: '50%',
shadow: 'none' shadow: 'none'
}, },
verticalPanelContainer: { steppanels: {
paddingLeft: '1rem' padding: '0.875rem 0.5rem 1.125rem 0.5rem'
}, },
panelContent: { steppanel: {
background: '{content.background}', background: '{content.background}',
color: '{content.color}', color: '{content.color}',
orientation: { padding: '0 0 0 1rem',
horizontal: { last: {
padding: '0.875rem 0.5rem 1.125rem 0.5rem' padding: '0 0 0 1.625rem'
},
vertical: {
padding: '0 0 0 1rem',
last: {
padding: '0 0 0 3rem'
}
}
} }
} }
}; };

View File

@ -5,18 +5,14 @@ export default {
separator: { separator: {
background: '{content.border.color}', background: '{content.border.color}',
activeBackground: '{primary.color}', activeBackground: '{primary.color}',
orientation: { margin: '0 0 0 1.625rem',
vertical: {
margin: '0 0 0 1.625rem'
}
},
size: '2px' size: '2px'
}, },
item: { step: {
padding: '0.5rem', padding: '0.5rem',
gap: '1rem' gap: '1rem'
}, },
itemHeader: { stepHeader: {
padding: '0', padding: '0',
borderRadius: '{content.border.radius}', borderRadius: '{content.border.radius}',
focusRing: { focusRing: {
@ -28,12 +24,12 @@ export default {
}, },
gap: '0.5rem' gap: '0.5rem'
}, },
itemTitle: { stepTitle: {
color: '{text.muted.color}', color: '{text.muted.color}',
activeColor: '{primary.color}', activeColor: '{primary.color}',
fontWeight: '700' fontWeight: '700'
}, },
itemNumber: { stepNumber: {
background: '{content.background}', background: '{content.background}',
activeBackground: '{primary.color}', activeBackground: '{primary.color}',
borderColor: '{content.border.color}', borderColor: '{content.border.color}',
@ -46,22 +42,15 @@ export default {
borderRadius: '50%', borderRadius: '50%',
shadow: 'none' shadow: 'none'
}, },
verticalPanelContainer: { steppanels: {
paddingLeft: '1rem' padding: '0.875rem 0.5rem 1.125rem 0.5rem'
}, },
panelContent: { steppanel: {
background: '{content.background}', background: '{content.background}',
color: '{content.color}', color: '{content.color}',
orientation: { padding: '0 0 0 1rem',
horizontal: { last: {
padding: '0.875rem 0.5rem 1.125rem 0.5rem' padding: '0 0 0 1.625rem'
},
vertical: {
padding: '0 0 0 1rem',
last: {
padding: '0 0 0 3rem'
}
}
} }
} }
}; };

View File

@ -39,21 +39,11 @@ export interface StepperDesignTokens extends ColorSchemeDesignToken<StepperDesig
*/ */
activeBackground?: string; activeBackground?: string;
/** /**
* Orientation of separator * Margin of separator
*
* @designToken stepper.separator.margin
*/ */
orientation?: { margin?: string;
/**
* Orientation vertical of separator
*/
vertical?: {
/**
* Orientation vertical margin of separator
*
* @designToken stepper.separator.orientation.vertical.margin
*/
margin?: string;
};
};
/** /**
* Size of separator * Size of separator
* *
@ -62,238 +52,217 @@ export interface StepperDesignTokens extends ColorSchemeDesignToken<StepperDesig
size?: string; size?: string;
}; };
/** /**
* Used to pass tokens of the item section * Used to pass tokens of the step section
*/ */
item?: { step?: {
/** /**
* Padding of item * Padding of step
* *
* @designToken stepper.item.padding * @designToken stepper.step.padding
*/ */
padding?: string; padding?: string;
/** /**
* Gap of item * Gap of step
* *
* @designToken stepper.item.gap * @designToken stepper.step.gap
*/ */
gap?: string; gap?: string;
}; };
/** /**
* Used to pass tokens of the item header section * Used to pass tokens of the step header section
*/ */
itemHeader?: { stepHeader?: {
/** /**
* Padding of item header * Padding of step header
* *
* @designToken stepper.item.header.padding * @designToken stepper.step.header.padding
*/ */
padding?: string; padding?: string;
/** /**
* Border radius of item header * Border radius of step header
* *
* @designToken stepper.item.header.border.radius * @designToken stepper.step.header.border.radius
*/ */
borderRadius?: string; borderRadius?: string;
/** /**
* Focus ring of item header * Focus ring of step header
*/ */
focusRing?: { focusRing?: {
/** /**
* Focus ring width of item header * Focus ring width of step header
* *
* @designToken stepper.item.header.focus.ring.width * @designToken stepper.step.header.focus.ring.width
*/ */
width?: string; width?: string;
/** /**
* Focus ring style of item header * Focus ring style of step header
* *
* @designToken stepper.item.header.focus.ring.style * @designToken stepper.step.header.focus.ring.style
*/ */
style?: string; style?: string;
/** /**
* Focus ring color of item header * Focus ring color of step header
* *
* @designToken stepper.item.header.focus.ring.color * @designToken stepper.step.header.focus.ring.color
*/ */
color?: string; color?: string;
/** /**
* Focus ring offset of item header * Focus ring offset of step header
* *
* @designToken stepper.item.header.focus.ring.offset * @designToken stepper.step.header.focus.ring.offset
*/ */
offset?: string; offset?: string;
/** /**
* Focus ring shadow of item header * Focus ring shadow of step header
* *
* @designToken stepper.item.header.focus.ring.shadow * @designToken stepper.step.header.focus.ring.shadow
*/ */
shadow?: string; shadow?: string;
}; };
/** /**
* Gap of item header * Gap of step header
* *
* @designToken stepper.item.header.gap * @designToken stepper.step.header.gap
*/ */
gap?: string; gap?: string;
}; };
/** /**
* Used to pass tokens of the item title section * Used to pass tokens of the step title section
*/ */
itemTitle?: { stepTitle?: {
/** /**
* Color of item title * Color of step title
* *
* @designToken stepper.item.title.color * @designToken stepper.step.title.color
*/ */
color?: string; color?: string;
/** /**
* Active color of item title * Active color of step title
* *
* @designToken stepper.item.title.active.color * @designToken stepper.step.title.active.color
*/ */
activeColor?: string; activeColor?: string;
/** /**
* Font weight of item title * Font weight of step title
* *
* @designToken stepper.item.title.font.weight * @designToken stepper.step.title.font.weight
*/ */
fontWeight?: string; fontWeight?: string;
}; };
/** /**
* Used to pass tokens of the item number section * Used to pass tokens of the step number section
*/ */
itemNumber?: { stepNumber?: {
/** /**
* Background of item number * Background of step number
* *
* @designToken stepper.item.number.background * @designToken stepper.step.number.background
*/ */
background?: string; background?: string;
/** /**
* Active background of item number * Active background of step number
* *
* @designToken stepper.item.number.active.background * @designToken stepper.step.number.active.background
*/ */
activeBackground?: string; activeBackground?: string;
/** /**
* Border color of item number * Border color of step number
* *
* @designToken stepper.item.number.border.color * @designToken stepper.step.number.border.color
*/ */
borderColor?: string; borderColor?: string;
/** /**
* Active border color of item number * Active border color of step number
* *
* @designToken stepper.item.number.active.border.color * @designToken stepper.step.number.active.border.color
*/ */
activeBorderColor?: string; activeBorderColor?: string;
/** /**
* Color of item number * Color of step number
* *
* @designToken stepper.item.number.color * @designToken stepper.step.number.color
*/ */
color?: string; color?: string;
/** /**
* Active color of item number * Active color of step number
* *
* @designToken stepper.item.number.active.color * @designToken stepper.step.number.active.color
*/ */
activeColor?: string; activeColor?: string;
/** /**
* Size of item number * Size of step number
* *
* @designToken stepper.item.number.size * @designToken stepper.step.number.size
*/ */
size?: string; size?: string;
/** /**
* Font size of item number * Font size of step number
* *
* @designToken stepper.item.number.font.size * @designToken stepper.step.number.font.size
*/ */
fontSize?: string; fontSize?: string;
/** /**
* Font weight of item number * Font weight of step number
* *
* @designToken stepper.item.number.font.weight * @designToken stepper.step.number.font.weight
*/ */
fontWeight?: string; fontWeight?: string;
/** /**
* Border radius of item number * Border radius of step number
* *
* @designToken stepper.item.number.border.radius * @designToken stepper.step.number.border.radius
*/ */
borderRadius?: string; borderRadius?: string;
/** /**
* Shadow of item number * Shadow of step number
* *
* @designToken stepper.item.number.shadow * @designToken stepper.step.number.shadow
*/ */
shadow?: string; shadow?: string;
}; };
/** /**
* Used to pass tokens of the vertical panel container section * Used to pass tokens of the steppanels section
*/ */
verticalPanelContainer?: { steppanels?: {
/** /**
* Padding left of vertical panel container * Padding of steppanels
* *
* @designToken stepper.vertical.panel.container.padding.left * @designToken stepper.steppanels.padding
*/ */
paddingLeft?: string; padding?: string;
}; };
/** /**
* Used to pass tokens of the panel content section * Used to pass tokens of the steppanel section
*/ */
panelContent?: { steppanel?: {
/** /**
* Background of panel content * Background of steppanel
* *
* @designToken stepper.panel.content.background * @designToken stepper.steppanel.background
*/ */
background?: string; background?: string;
/** /**
* Color of panel content * Color of steppanel
* *
* @designToken stepper.panel.content.color * @designToken stepper.steppanel.color
*/ */
color?: string; color?: string;
/** /**
* Orientation of panel content * Padding of steppanel
*
* @designToken stepper.steppanel.padding
*/ */
orientation?: { padding?: string;
/**
* Last of steppanel
*/
last?: {
/** /**
* Orientation horizontal of panel content * Last padding of steppanel
*
* @designToken stepper.steppanel.last.padding
*/ */
horizontal?: { padding?: string;
/**
* Orientation horizontal padding of panel content
*
* @designToken stepper.panel.content.orientation.horizontal.padding
*/
padding?: string;
};
/**
* Orientation vertical of panel content
*/
vertical?: {
/**
* Orientation vertical padding of panel content
*
* @designToken stepper.panel.content.orientation.vertical.padding
*/
padding?: string;
/**
* Orientation vertical last of panel content
*/
last?: {
/**
* Orientation vertical last padding of panel content
*
* @designToken stepper.panel.content.orientation.vertical.last.padding
*/
padding?: string;
};
};
}; };
}; };
} }

View File

@ -52,6 +52,11 @@ const panel = [
'ScrollPanel', 'ScrollPanel',
'Splitter', 'Splitter',
'SplitterPanel', 'SplitterPanel',
'Step',
'StepItem',
'StepList',
'StepPanel',
'StepPanels',
'Stepper', 'Stepper',
'StepperPanel', 'StepperPanel',
'TabView', 'TabView',

View File

@ -102,9 +102,14 @@ const STYLE_ALIAS = {
'primevue/splitbutton/style': path.resolve(__dirname, './components/lib/splitbutton/style/SplitButtonStyle.js'), 'primevue/splitbutton/style': path.resolve(__dirname, './components/lib/splitbutton/style/SplitButtonStyle.js'),
'primevue/splitter/style': path.resolve(__dirname, './components/lib/splitter/style/SplitterStyle.js'), 'primevue/splitter/style': path.resolve(__dirname, './components/lib/splitter/style/SplitterStyle.js'),
'primevue/splitterpanel/style': path.resolve(__dirname, './components/lib/splitterpanel/style/SplitterPanelStyle.js'), 'primevue/splitterpanel/style': path.resolve(__dirname, './components/lib/splitterpanel/style/SplitterPanelStyle.js'),
'primevue/steps/style': path.resolve(__dirname, './components/lib/steps/style/StepsStyle.js'), 'primevue/step/style': path.resolve(__dirname, './components/lib/step/style/StepStyle.js'),
'primevue/stepitem/style': path.resolve(__dirname, './components/lib/stepitem/style/StepItemStyle.js'),
'primevue/steplist/style': path.resolve(__dirname, './components/lib/steplist/style/StepListStyle.js'),
'primevue/steppanel/style': path.resolve(__dirname, './components/lib/steppanel/style/StepPanelStyle.js'),
'primevue/steppanels/style': path.resolve(__dirname, './components/lib/steppanels/style/StepPanelsStyle.js'),
'primevue/stepper/style': path.resolve(__dirname, './components/lib/stepper/style/StepperStyle.js'), 'primevue/stepper/style': path.resolve(__dirname, './components/lib/stepper/style/StepperStyle.js'),
'primevue/stepperpanel/style': path.resolve(__dirname, './components/lib/stepperpanel/style/StepperPanelStyle.js'), 'primevue/stepperpanel/style': path.resolve(__dirname, './components/lib/stepperpanel/style/StepperPanelStyle.js'),
'primevue/steps/style': path.resolve(__dirname, './components/lib/steps/style/StepsStyle.js'),
'primevue/styleclass/style': path.resolve(__dirname, './components/lib/styleclass/style/StyleClassStyle.js'), 'primevue/styleclass/style': path.resolve(__dirname, './components/lib/styleclass/style/StyleClassStyle.js'),
'primevue/tabmenu/style': path.resolve(__dirname, './components/lib/tabmenu/style/TabMenuStyle.js'), 'primevue/tabmenu/style': path.resolve(__dirname, './components/lib/tabmenu/style/TabMenuStyle.js'),
'primevue/tabs/style': path.resolve(__dirname, './components/lib/tabs/style/TabsStyle.js'), 'primevue/tabs/style': path.resolve(__dirname, './components/lib/tabs/style/TabsStyle.js'),