@opensite/ui 1.3.2 → 1.3.4
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/footer-accordion-social.cjs +1344 -0
- package/dist/footer-accordion-social.d.cts +154 -0
- package/dist/footer-accordion-social.d.ts +154 -0
- package/dist/footer-accordion-social.js +1322 -0
- package/dist/footer-info-cards-accordion.cjs +1427 -0
- package/dist/footer-info-cards-accordion.d.cts +278 -0
- package/dist/footer-info-cards-accordion.d.ts +278 -0
- package/dist/footer-info-cards-accordion.js +1404 -0
- package/dist/footer-newsletter-contact.cjs +1281 -0
- package/dist/footer-newsletter-contact.d.cts +163 -0
- package/dist/footer-newsletter-contact.d.ts +163 -0
- package/dist/footer-newsletter-contact.js +1259 -0
- package/dist/footer-split-image-accordion.cjs +1395 -0
- package/dist/footer-split-image-accordion.d.cts +236 -0
- package/dist/footer-split-image-accordion.d.ts +236 -0
- package/dist/footer-split-image-accordion.js +1372 -0
- package/dist/list-achievements-showcase.cjs +1141 -0
- package/dist/list-achievements-showcase.d.cts +131 -0
- package/dist/list-achievements-showcase.d.ts +131 -0
- package/dist/list-achievements-showcase.js +1119 -0
- package/dist/list-career-timeline.cjs +531 -0
- package/dist/list-career-timeline.d.cts +153 -0
- package/dist/list-career-timeline.d.ts +153 -0
- package/dist/list-career-timeline.js +509 -0
- package/dist/list-feature-comparison.cjs +1211 -0
- package/dist/list-feature-comparison.d.cts +189 -0
- package/dist/list-feature-comparison.d.ts +189 -0
- package/dist/list-feature-comparison.js +1190 -0
- package/dist/list-metrics-dashboard.cjs +1402 -0
- package/dist/list-metrics-dashboard.d.cts +191 -0
- package/dist/list-metrics-dashboard.d.ts +191 -0
- package/dist/list-metrics-dashboard.js +1379 -0
- package/dist/list-service-category-table.cjs +762 -0
- package/dist/list-service-category-table.d.cts +135 -0
- package/dist/list-service-category-table.d.ts +135 -0
- package/dist/list-service-category-table.js +741 -0
- package/dist/offer-modal-membership-image.cjs +1361 -0
- package/dist/offer-modal-membership-image.d.cts +194 -0
- package/dist/offer-modal-membership-image.d.ts +194 -0
- package/dist/offer-modal-membership-image.js +1339 -0
- package/dist/offer-modal-newsletter-discount.cjs +1296 -0
- package/dist/offer-modal-newsletter-discount.d.cts +164 -0
- package/dist/offer-modal-newsletter-discount.d.ts +164 -0
- package/dist/offer-modal-newsletter-discount.js +1274 -0
- package/dist/offer-modal-sheet-newsletter.cjs +1360 -0
- package/dist/offer-modal-sheet-newsletter.d.cts +221 -0
- package/dist/offer-modal-sheet-newsletter.d.ts +221 -0
- package/dist/offer-modal-sheet-newsletter.js +1337 -0
- package/dist/pricing-addons-cards.cjs +1143 -0
- package/dist/pricing-addons-cards.d.cts +203 -0
- package/dist/pricing-addons-cards.d.ts +203 -0
- package/dist/pricing-addons-cards.js +1122 -0
- package/dist/pricing-addons-featured.cjs +1224 -0
- package/dist/pricing-addons-featured.d.cts +271 -0
- package/dist/pricing-addons-featured.d.ts +271 -0
- package/dist/pricing-addons-featured.js +1203 -0
- package/dist/pricing-collapsible-plans.cjs +1315 -0
- package/dist/pricing-collapsible-plans.d.cts +258 -0
- package/dist/pricing-collapsible-plans.d.ts +258 -0
- package/dist/pricing-collapsible-plans.js +1294 -0
- package/dist/pricing-columns-toggle.cjs +1234 -0
- package/dist/pricing-columns-toggle.d.cts +251 -0
- package/dist/pricing-columns-toggle.d.ts +251 -0
- package/dist/pricing-columns-toggle.js +1212 -0
- package/dist/pricing-comparison-headers.cjs +1235 -0
- package/dist/pricing-comparison-headers.d.cts +245 -0
- package/dist/pricing-comparison-headers.d.ts +245 -0
- package/dist/pricing-comparison-headers.js +1213 -0
- package/dist/pricing-comparison-table.cjs +1374 -0
- package/dist/pricing-comparison-table.d.cts +280 -0
- package/dist/pricing-comparison-table.d.ts +280 -0
- package/dist/pricing-comparison-table.js +1352 -0
- package/dist/pricing-discount-card.cjs +1217 -0
- package/dist/pricing-discount-card.d.cts +195 -0
- package/dist/pricing-discount-card.d.ts +195 -0
- package/dist/pricing-discount-card.js +1195 -0
- package/dist/pricing-enterprise-contact.cjs +1094 -0
- package/dist/pricing-enterprise-contact.d.cts +170 -0
- package/dist/pricing-enterprise-contact.d.ts +170 -0
- package/dist/pricing-enterprise-contact.js +1073 -0
- package/dist/pricing-feature-matrix.cjs +1197 -0
- package/dist/pricing-feature-matrix.d.cts +56 -0
- package/dist/pricing-feature-matrix.d.ts +56 -0
- package/dist/pricing-feature-matrix.js +1174 -0
- package/dist/pricing-four-tier-toggle.cjs +1320 -0
- package/dist/pricing-four-tier-toggle.d.cts +266 -0
- package/dist/pricing-four-tier-toggle.d.ts +266 -0
- package/dist/pricing-four-tier-toggle.js +1297 -0
- package/dist/pricing-full-comparison.cjs +1301 -0
- package/dist/pricing-full-comparison.d.cts +265 -0
- package/dist/pricing-full-comparison.d.ts +265 -0
- package/dist/pricing-full-comparison.js +1279 -0
- package/dist/pricing-gradient-cards.cjs +1248 -0
- package/dist/pricing-gradient-cards.d.cts +258 -0
- package/dist/pricing-gradient-cards.d.ts +258 -0
- package/dist/pricing-gradient-cards.js +1226 -0
- package/dist/pricing-icon-headers.cjs +1163 -0
- package/dist/pricing-icon-headers.d.cts +218 -0
- package/dist/pricing-icon-headers.d.ts +218 -0
- package/dist/pricing-icon-headers.js +1142 -0
- package/dist/pricing-minimal-cards.cjs +1146 -0
- package/dist/pricing-minimal-cards.d.cts +210 -0
- package/dist/pricing-minimal-cards.d.ts +210 -0
- package/dist/pricing-minimal-cards.js +1125 -0
- package/dist/pricing-packages-radio.cjs +1203 -0
- package/dist/pricing-packages-radio.d.cts +243 -0
- package/dist/pricing-packages-radio.d.ts +243 -0
- package/dist/pricing-packages-radio.js +1182 -0
- package/dist/pricing-popular-highlight.cjs +1293 -0
- package/dist/pricing-popular-highlight.d.cts +255 -0
- package/dist/pricing-popular-highlight.d.ts +255 -0
- package/dist/pricing-popular-highlight.js +1271 -0
- package/dist/pricing-radio-toggle.cjs +1277 -0
- package/dist/pricing-radio-toggle.d.cts +251 -0
- package/dist/pricing-radio-toggle.d.ts +251 -0
- package/dist/pricing-radio-toggle.js +1255 -0
- package/dist/pricing-responsive-table.cjs +1229 -0
- package/dist/pricing-responsive-table.d.cts +55 -0
- package/dist/pricing-responsive-table.d.ts +55 -0
- package/dist/pricing-responsive-table.js +1206 -0
- package/dist/pricing-services-cards.cjs +1209 -0
- package/dist/pricing-services-cards.d.cts +230 -0
- package/dist/pricing-services-cards.d.ts +230 -0
- package/dist/pricing-services-cards.js +1188 -0
- package/dist/pricing-simple-card.cjs +1102 -0
- package/dist/pricing-simple-card.d.cts +174 -0
- package/dist/pricing-simple-card.d.ts +174 -0
- package/dist/pricing-simple-card.js +1081 -0
- package/dist/pricing-single-card.cjs +1174 -0
- package/dist/pricing-single-card.d.cts +201 -0
- package/dist/pricing-single-card.d.ts +201 -0
- package/dist/pricing-single-card.js +1152 -0
- package/dist/pricing-split-layout.cjs +1001 -0
- package/dist/pricing-split-layout.d.cts +44 -0
- package/dist/pricing-split-layout.d.ts +44 -0
- package/dist/pricing-split-layout.js +980 -0
- package/dist/pricing-spotlight-card.cjs +1157 -0
- package/dist/pricing-spotlight-card.d.cts +201 -0
- package/dist/pricing-spotlight-card.d.ts +201 -0
- package/dist/pricing-spotlight-card.js +1136 -0
- package/dist/pricing-switch-cards.cjs +1274 -0
- package/dist/pricing-switch-cards.d.cts +254 -0
- package/dist/pricing-switch-cards.d.ts +254 -0
- package/dist/pricing-switch-cards.js +1252 -0
- package/dist/pricing-tabs-toggle.cjs +1314 -0
- package/dist/pricing-tabs-toggle.d.cts +274 -0
- package/dist/pricing-tabs-toggle.d.ts +274 -0
- package/dist/pricing-tabs-toggle.js +1291 -0
- package/dist/pricing-tier-grid.cjs +1190 -0
- package/dist/pricing-tier-grid.d.cts +224 -0
- package/dist/pricing-tier-grid.d.ts +224 -0
- package/dist/pricing-tier-grid.js +1169 -0
- package/dist/pricing-toggle-cards.cjs +1330 -0
- package/dist/pricing-toggle-cards.d.cts +267 -0
- package/dist/pricing-toggle-cards.d.ts +267 -0
- package/dist/pricing-toggle-cards.js +1307 -0
- package/dist/pricing-toggle-period.cjs +1251 -0
- package/dist/pricing-toggle-period.d.cts +265 -0
- package/dist/pricing-toggle-period.d.ts +265 -0
- package/dist/pricing-toggle-period.js +1230 -0
- package/dist/pricing-two-column-basic.cjs +1243 -0
- package/dist/pricing-two-column-basic.d.cts +244 -0
- package/dist/pricing-two-column-basic.d.ts +244 -0
- package/dist/pricing-two-column-basic.js +1222 -0
- package/dist/registry.cjs +109 -85
- package/dist/registry.js +931 -907
- package/package.json +1 -1
|
@@ -0,0 +1,266 @@
|
|
|
1
|
+
import * as React from 'react';
|
|
2
|
+
import { f as SectionBackground, g as SectionSpacing, t as PatternName } from './community-initiatives-Bz_A5vLU.cjs';
|
|
3
|
+
import { A as ActionConfig } from './blocks-Cohq4eio.cjs';
|
|
4
|
+
import 'react/jsx-runtime';
|
|
5
|
+
import 'class-variance-authority';
|
|
6
|
+
import './button-variants-lRElsmTc.cjs';
|
|
7
|
+
import 'class-variance-authority/types';
|
|
8
|
+
|
|
9
|
+
interface PricingFourTierFeature {
|
|
10
|
+
/**
|
|
11
|
+
* Feature label
|
|
12
|
+
*/
|
|
13
|
+
name?: React.ReactNode;
|
|
14
|
+
/**
|
|
15
|
+
* Whether the feature is included
|
|
16
|
+
*/
|
|
17
|
+
included?: boolean;
|
|
18
|
+
/**
|
|
19
|
+
* Optional icon element
|
|
20
|
+
*/
|
|
21
|
+
icon?: React.ReactNode;
|
|
22
|
+
/**
|
|
23
|
+
* Optional icon name for DynamicIcon
|
|
24
|
+
*/
|
|
25
|
+
iconName?: string;
|
|
26
|
+
/**
|
|
27
|
+
* Additional CSS classes for the feature item
|
|
28
|
+
*/
|
|
29
|
+
className?: string;
|
|
30
|
+
/**
|
|
31
|
+
* Additional CSS classes for the feature icon
|
|
32
|
+
*/
|
|
33
|
+
iconClassName?: string;
|
|
34
|
+
/**
|
|
35
|
+
* Additional CSS classes for the feature text
|
|
36
|
+
*/
|
|
37
|
+
textClassName?: string;
|
|
38
|
+
}
|
|
39
|
+
interface PricingFourTierPlan {
|
|
40
|
+
/**
|
|
41
|
+
* Plan name
|
|
42
|
+
*/
|
|
43
|
+
name?: React.ReactNode;
|
|
44
|
+
/**
|
|
45
|
+
* Monthly price display
|
|
46
|
+
*/
|
|
47
|
+
monthlyPrice?: React.ReactNode;
|
|
48
|
+
/**
|
|
49
|
+
* Yearly price display
|
|
50
|
+
*/
|
|
51
|
+
yearlyPrice?: React.ReactNode;
|
|
52
|
+
/**
|
|
53
|
+
* Plan description
|
|
54
|
+
*/
|
|
55
|
+
description?: React.ReactNode;
|
|
56
|
+
/**
|
|
57
|
+
* Feature list
|
|
58
|
+
*/
|
|
59
|
+
features?: PricingFourTierFeature[];
|
|
60
|
+
/**
|
|
61
|
+
* Custom slot for rendering features (overrides features array)
|
|
62
|
+
*/
|
|
63
|
+
featuresSlot?: React.ReactNode;
|
|
64
|
+
/**
|
|
65
|
+
* Action configuration
|
|
66
|
+
*/
|
|
67
|
+
action?: ActionConfig;
|
|
68
|
+
/**
|
|
69
|
+
* Custom slot for rendering action (overrides action)
|
|
70
|
+
*/
|
|
71
|
+
actionSlot?: React.ReactNode;
|
|
72
|
+
/**
|
|
73
|
+
* Highlight this plan
|
|
74
|
+
*/
|
|
75
|
+
isPopular?: boolean;
|
|
76
|
+
/**
|
|
77
|
+
* Badge content for popular plan
|
|
78
|
+
*/
|
|
79
|
+
badge?: React.ReactNode;
|
|
80
|
+
/**
|
|
81
|
+
* Additional CSS classes for the plan card
|
|
82
|
+
*/
|
|
83
|
+
className?: string;
|
|
84
|
+
}
|
|
85
|
+
interface PricingFourTierToggleProps {
|
|
86
|
+
/**
|
|
87
|
+
* Section title
|
|
88
|
+
*/
|
|
89
|
+
title?: React.ReactNode;
|
|
90
|
+
/**
|
|
91
|
+
* Section subtitle
|
|
92
|
+
*/
|
|
93
|
+
subtitle?: React.ReactNode;
|
|
94
|
+
/**
|
|
95
|
+
* Toggle label for monthly billing
|
|
96
|
+
*/
|
|
97
|
+
monthlyLabel?: React.ReactNode;
|
|
98
|
+
/**
|
|
99
|
+
* Toggle label for annual billing
|
|
100
|
+
*/
|
|
101
|
+
yearlyLabel?: React.ReactNode;
|
|
102
|
+
/**
|
|
103
|
+
* Badge displayed on yearly toggle
|
|
104
|
+
*/
|
|
105
|
+
yearlyBadge?: React.ReactNode;
|
|
106
|
+
/**
|
|
107
|
+
* Monthly price suffix
|
|
108
|
+
*/
|
|
109
|
+
monthlyInterval?: React.ReactNode;
|
|
110
|
+
/**
|
|
111
|
+
* Yearly price suffix
|
|
112
|
+
*/
|
|
113
|
+
yearlyInterval?: React.ReactNode;
|
|
114
|
+
/**
|
|
115
|
+
* Pricing plans
|
|
116
|
+
*/
|
|
117
|
+
plans?: PricingFourTierPlan[];
|
|
118
|
+
/**
|
|
119
|
+
* Custom slot for rendering plans (overrides plans array)
|
|
120
|
+
*/
|
|
121
|
+
plansSlot?: React.ReactNode;
|
|
122
|
+
/**
|
|
123
|
+
* Icon used when feature is included
|
|
124
|
+
*/
|
|
125
|
+
includedIcon?: React.ReactNode;
|
|
126
|
+
/**
|
|
127
|
+
* Icon used when feature is excluded
|
|
128
|
+
*/
|
|
129
|
+
excludedIcon?: React.ReactNode;
|
|
130
|
+
/**
|
|
131
|
+
* Icon name used when feature is included
|
|
132
|
+
*/
|
|
133
|
+
includedIconName?: string;
|
|
134
|
+
/**
|
|
135
|
+
* Icon name used when feature is excluded
|
|
136
|
+
*/
|
|
137
|
+
excludedIconName?: string;
|
|
138
|
+
/**
|
|
139
|
+
* Badge content for popular plans
|
|
140
|
+
*/
|
|
141
|
+
popularBadge?: React.ReactNode;
|
|
142
|
+
/**
|
|
143
|
+
* Background style for the section
|
|
144
|
+
*/
|
|
145
|
+
background?: SectionBackground;
|
|
146
|
+
/**
|
|
147
|
+
* Vertical spacing for the section
|
|
148
|
+
*/
|
|
149
|
+
spacing?: SectionSpacing;
|
|
150
|
+
/**
|
|
151
|
+
* Optional background pattern name or URL
|
|
152
|
+
*/
|
|
153
|
+
pattern?: PatternName | undefined;
|
|
154
|
+
/**
|
|
155
|
+
* Pattern overlay opacity (0-1)
|
|
156
|
+
*/
|
|
157
|
+
patternOpacity?: number;
|
|
158
|
+
/**
|
|
159
|
+
* Additional CSS classes for the pattern overlay
|
|
160
|
+
*/
|
|
161
|
+
patternClassName?: string;
|
|
162
|
+
/**
|
|
163
|
+
* Additional CSS classes for the section
|
|
164
|
+
*/
|
|
165
|
+
className?: string;
|
|
166
|
+
/**
|
|
167
|
+
* Additional CSS classes for the container
|
|
168
|
+
*/
|
|
169
|
+
containerClassName?: string;
|
|
170
|
+
/**
|
|
171
|
+
* Additional CSS classes for the header
|
|
172
|
+
*/
|
|
173
|
+
headerClassName?: string;
|
|
174
|
+
/**
|
|
175
|
+
* Additional CSS classes for the title
|
|
176
|
+
*/
|
|
177
|
+
titleClassName?: string;
|
|
178
|
+
/**
|
|
179
|
+
* Additional CSS classes for the subtitle
|
|
180
|
+
*/
|
|
181
|
+
subtitleClassName?: string;
|
|
182
|
+
/**
|
|
183
|
+
* Additional CSS classes for the toggle wrapper
|
|
184
|
+
*/
|
|
185
|
+
toggleClassName?: string;
|
|
186
|
+
/**
|
|
187
|
+
* Additional CSS classes for toggle labels
|
|
188
|
+
*/
|
|
189
|
+
toggleLabelClassName?: string;
|
|
190
|
+
/**
|
|
191
|
+
* Additional CSS classes for yearly badge
|
|
192
|
+
*/
|
|
193
|
+
yearlyBadgeClassName?: string;
|
|
194
|
+
/**
|
|
195
|
+
* Additional CSS classes for the grid
|
|
196
|
+
*/
|
|
197
|
+
gridClassName?: string;
|
|
198
|
+
/**
|
|
199
|
+
* Additional CSS classes for plan cards
|
|
200
|
+
*/
|
|
201
|
+
cardClassName?: string;
|
|
202
|
+
/**
|
|
203
|
+
* Additional CSS classes for popular cards
|
|
204
|
+
*/
|
|
205
|
+
popularCardClassName?: string;
|
|
206
|
+
/**
|
|
207
|
+
* Additional CSS classes for badge
|
|
208
|
+
*/
|
|
209
|
+
badgeClassName?: string;
|
|
210
|
+
/**
|
|
211
|
+
* Additional CSS classes for plan titles
|
|
212
|
+
*/
|
|
213
|
+
planTitleClassName?: string;
|
|
214
|
+
/**
|
|
215
|
+
* Additional CSS classes for plan descriptions
|
|
216
|
+
*/
|
|
217
|
+
planDescriptionClassName?: string;
|
|
218
|
+
/**
|
|
219
|
+
* Additional CSS classes for price
|
|
220
|
+
*/
|
|
221
|
+
priceClassName?: string;
|
|
222
|
+
/**
|
|
223
|
+
* Additional CSS classes for price interval
|
|
224
|
+
*/
|
|
225
|
+
priceIntervalClassName?: string;
|
|
226
|
+
/**
|
|
227
|
+
* Additional CSS classes for features list
|
|
228
|
+
*/
|
|
229
|
+
featuresClassName?: string;
|
|
230
|
+
/**
|
|
231
|
+
* Additional CSS classes for feature items
|
|
232
|
+
*/
|
|
233
|
+
featureItemClassName?: string;
|
|
234
|
+
/**
|
|
235
|
+
* Additional CSS classes for feature icons
|
|
236
|
+
*/
|
|
237
|
+
featureIconClassName?: string;
|
|
238
|
+
/**
|
|
239
|
+
* Additional CSS classes for feature text
|
|
240
|
+
*/
|
|
241
|
+
featureTextClassName?: string;
|
|
242
|
+
/**
|
|
243
|
+
* Additional CSS classes for action
|
|
244
|
+
*/
|
|
245
|
+
actionClassName?: string;
|
|
246
|
+
}
|
|
247
|
+
/**
|
|
248
|
+
* PricingFourTierToggle displays a 4-column pricing grid with annual billing toggle.
|
|
249
|
+
* Features check/X icons for feature availability, popular plan highlighting, and responsive layout.
|
|
250
|
+
* Switch toggle allows users to compare monthly vs annual pricing with savings indicator.
|
|
251
|
+
*
|
|
252
|
+
* Ideal for SaaS products with multiple tiers from free to enterprise.
|
|
253
|
+
*
|
|
254
|
+
* @example
|
|
255
|
+
* ```tsx
|
|
256
|
+
* <PricingFourTierToggle
|
|
257
|
+
* title="Choose Your Plan"
|
|
258
|
+
* plans={[
|
|
259
|
+
* { name: "Free", monthlyPrice: "$0", yearlyPrice: "$0", features: [{ name: "Feature", included: true }] }
|
|
260
|
+
* ]}
|
|
261
|
+
* />
|
|
262
|
+
* ```
|
|
263
|
+
*/
|
|
264
|
+
declare function PricingFourTierToggle({ title, subtitle, monthlyLabel, yearlyLabel, yearlyBadge, monthlyInterval, yearlyInterval, plans, plansSlot, includedIcon, excludedIcon, includedIconName, excludedIconName, popularBadge, background, spacing, pattern, patternOpacity, patternClassName, className, containerClassName, headerClassName, titleClassName, subtitleClassName, toggleClassName, toggleLabelClassName, yearlyBadgeClassName, gridClassName, cardClassName, popularCardClassName, badgeClassName, planTitleClassName, planDescriptionClassName, priceClassName, priceIntervalClassName, featuresClassName, featureItemClassName, featureIconClassName, featureTextClassName, actionClassName, }: PricingFourTierToggleProps): React.JSX.Element;
|
|
265
|
+
|
|
266
|
+
export { PricingFourTierToggle, type PricingFourTierToggleProps };
|
|
@@ -0,0 +1,266 @@
|
|
|
1
|
+
import * as React from 'react';
|
|
2
|
+
import { f as SectionBackground, g as SectionSpacing, t as PatternName } from './community-initiatives-Bi_ClKrO.js';
|
|
3
|
+
import { A as ActionConfig } from './blocks-k17uluAz.js';
|
|
4
|
+
import 'react/jsx-runtime';
|
|
5
|
+
import 'class-variance-authority';
|
|
6
|
+
import './button-variants-lRElsmTc.js';
|
|
7
|
+
import 'class-variance-authority/types';
|
|
8
|
+
|
|
9
|
+
interface PricingFourTierFeature {
|
|
10
|
+
/**
|
|
11
|
+
* Feature label
|
|
12
|
+
*/
|
|
13
|
+
name?: React.ReactNode;
|
|
14
|
+
/**
|
|
15
|
+
* Whether the feature is included
|
|
16
|
+
*/
|
|
17
|
+
included?: boolean;
|
|
18
|
+
/**
|
|
19
|
+
* Optional icon element
|
|
20
|
+
*/
|
|
21
|
+
icon?: React.ReactNode;
|
|
22
|
+
/**
|
|
23
|
+
* Optional icon name for DynamicIcon
|
|
24
|
+
*/
|
|
25
|
+
iconName?: string;
|
|
26
|
+
/**
|
|
27
|
+
* Additional CSS classes for the feature item
|
|
28
|
+
*/
|
|
29
|
+
className?: string;
|
|
30
|
+
/**
|
|
31
|
+
* Additional CSS classes for the feature icon
|
|
32
|
+
*/
|
|
33
|
+
iconClassName?: string;
|
|
34
|
+
/**
|
|
35
|
+
* Additional CSS classes for the feature text
|
|
36
|
+
*/
|
|
37
|
+
textClassName?: string;
|
|
38
|
+
}
|
|
39
|
+
interface PricingFourTierPlan {
|
|
40
|
+
/**
|
|
41
|
+
* Plan name
|
|
42
|
+
*/
|
|
43
|
+
name?: React.ReactNode;
|
|
44
|
+
/**
|
|
45
|
+
* Monthly price display
|
|
46
|
+
*/
|
|
47
|
+
monthlyPrice?: React.ReactNode;
|
|
48
|
+
/**
|
|
49
|
+
* Yearly price display
|
|
50
|
+
*/
|
|
51
|
+
yearlyPrice?: React.ReactNode;
|
|
52
|
+
/**
|
|
53
|
+
* Plan description
|
|
54
|
+
*/
|
|
55
|
+
description?: React.ReactNode;
|
|
56
|
+
/**
|
|
57
|
+
* Feature list
|
|
58
|
+
*/
|
|
59
|
+
features?: PricingFourTierFeature[];
|
|
60
|
+
/**
|
|
61
|
+
* Custom slot for rendering features (overrides features array)
|
|
62
|
+
*/
|
|
63
|
+
featuresSlot?: React.ReactNode;
|
|
64
|
+
/**
|
|
65
|
+
* Action configuration
|
|
66
|
+
*/
|
|
67
|
+
action?: ActionConfig;
|
|
68
|
+
/**
|
|
69
|
+
* Custom slot for rendering action (overrides action)
|
|
70
|
+
*/
|
|
71
|
+
actionSlot?: React.ReactNode;
|
|
72
|
+
/**
|
|
73
|
+
* Highlight this plan
|
|
74
|
+
*/
|
|
75
|
+
isPopular?: boolean;
|
|
76
|
+
/**
|
|
77
|
+
* Badge content for popular plan
|
|
78
|
+
*/
|
|
79
|
+
badge?: React.ReactNode;
|
|
80
|
+
/**
|
|
81
|
+
* Additional CSS classes for the plan card
|
|
82
|
+
*/
|
|
83
|
+
className?: string;
|
|
84
|
+
}
|
|
85
|
+
interface PricingFourTierToggleProps {
|
|
86
|
+
/**
|
|
87
|
+
* Section title
|
|
88
|
+
*/
|
|
89
|
+
title?: React.ReactNode;
|
|
90
|
+
/**
|
|
91
|
+
* Section subtitle
|
|
92
|
+
*/
|
|
93
|
+
subtitle?: React.ReactNode;
|
|
94
|
+
/**
|
|
95
|
+
* Toggle label for monthly billing
|
|
96
|
+
*/
|
|
97
|
+
monthlyLabel?: React.ReactNode;
|
|
98
|
+
/**
|
|
99
|
+
* Toggle label for annual billing
|
|
100
|
+
*/
|
|
101
|
+
yearlyLabel?: React.ReactNode;
|
|
102
|
+
/**
|
|
103
|
+
* Badge displayed on yearly toggle
|
|
104
|
+
*/
|
|
105
|
+
yearlyBadge?: React.ReactNode;
|
|
106
|
+
/**
|
|
107
|
+
* Monthly price suffix
|
|
108
|
+
*/
|
|
109
|
+
monthlyInterval?: React.ReactNode;
|
|
110
|
+
/**
|
|
111
|
+
* Yearly price suffix
|
|
112
|
+
*/
|
|
113
|
+
yearlyInterval?: React.ReactNode;
|
|
114
|
+
/**
|
|
115
|
+
* Pricing plans
|
|
116
|
+
*/
|
|
117
|
+
plans?: PricingFourTierPlan[];
|
|
118
|
+
/**
|
|
119
|
+
* Custom slot for rendering plans (overrides plans array)
|
|
120
|
+
*/
|
|
121
|
+
plansSlot?: React.ReactNode;
|
|
122
|
+
/**
|
|
123
|
+
* Icon used when feature is included
|
|
124
|
+
*/
|
|
125
|
+
includedIcon?: React.ReactNode;
|
|
126
|
+
/**
|
|
127
|
+
* Icon used when feature is excluded
|
|
128
|
+
*/
|
|
129
|
+
excludedIcon?: React.ReactNode;
|
|
130
|
+
/**
|
|
131
|
+
* Icon name used when feature is included
|
|
132
|
+
*/
|
|
133
|
+
includedIconName?: string;
|
|
134
|
+
/**
|
|
135
|
+
* Icon name used when feature is excluded
|
|
136
|
+
*/
|
|
137
|
+
excludedIconName?: string;
|
|
138
|
+
/**
|
|
139
|
+
* Badge content for popular plans
|
|
140
|
+
*/
|
|
141
|
+
popularBadge?: React.ReactNode;
|
|
142
|
+
/**
|
|
143
|
+
* Background style for the section
|
|
144
|
+
*/
|
|
145
|
+
background?: SectionBackground;
|
|
146
|
+
/**
|
|
147
|
+
* Vertical spacing for the section
|
|
148
|
+
*/
|
|
149
|
+
spacing?: SectionSpacing;
|
|
150
|
+
/**
|
|
151
|
+
* Optional background pattern name or URL
|
|
152
|
+
*/
|
|
153
|
+
pattern?: PatternName | undefined;
|
|
154
|
+
/**
|
|
155
|
+
* Pattern overlay opacity (0-1)
|
|
156
|
+
*/
|
|
157
|
+
patternOpacity?: number;
|
|
158
|
+
/**
|
|
159
|
+
* Additional CSS classes for the pattern overlay
|
|
160
|
+
*/
|
|
161
|
+
patternClassName?: string;
|
|
162
|
+
/**
|
|
163
|
+
* Additional CSS classes for the section
|
|
164
|
+
*/
|
|
165
|
+
className?: string;
|
|
166
|
+
/**
|
|
167
|
+
* Additional CSS classes for the container
|
|
168
|
+
*/
|
|
169
|
+
containerClassName?: string;
|
|
170
|
+
/**
|
|
171
|
+
* Additional CSS classes for the header
|
|
172
|
+
*/
|
|
173
|
+
headerClassName?: string;
|
|
174
|
+
/**
|
|
175
|
+
* Additional CSS classes for the title
|
|
176
|
+
*/
|
|
177
|
+
titleClassName?: string;
|
|
178
|
+
/**
|
|
179
|
+
* Additional CSS classes for the subtitle
|
|
180
|
+
*/
|
|
181
|
+
subtitleClassName?: string;
|
|
182
|
+
/**
|
|
183
|
+
* Additional CSS classes for the toggle wrapper
|
|
184
|
+
*/
|
|
185
|
+
toggleClassName?: string;
|
|
186
|
+
/**
|
|
187
|
+
* Additional CSS classes for toggle labels
|
|
188
|
+
*/
|
|
189
|
+
toggleLabelClassName?: string;
|
|
190
|
+
/**
|
|
191
|
+
* Additional CSS classes for yearly badge
|
|
192
|
+
*/
|
|
193
|
+
yearlyBadgeClassName?: string;
|
|
194
|
+
/**
|
|
195
|
+
* Additional CSS classes for the grid
|
|
196
|
+
*/
|
|
197
|
+
gridClassName?: string;
|
|
198
|
+
/**
|
|
199
|
+
* Additional CSS classes for plan cards
|
|
200
|
+
*/
|
|
201
|
+
cardClassName?: string;
|
|
202
|
+
/**
|
|
203
|
+
* Additional CSS classes for popular cards
|
|
204
|
+
*/
|
|
205
|
+
popularCardClassName?: string;
|
|
206
|
+
/**
|
|
207
|
+
* Additional CSS classes for badge
|
|
208
|
+
*/
|
|
209
|
+
badgeClassName?: string;
|
|
210
|
+
/**
|
|
211
|
+
* Additional CSS classes for plan titles
|
|
212
|
+
*/
|
|
213
|
+
planTitleClassName?: string;
|
|
214
|
+
/**
|
|
215
|
+
* Additional CSS classes for plan descriptions
|
|
216
|
+
*/
|
|
217
|
+
planDescriptionClassName?: string;
|
|
218
|
+
/**
|
|
219
|
+
* Additional CSS classes for price
|
|
220
|
+
*/
|
|
221
|
+
priceClassName?: string;
|
|
222
|
+
/**
|
|
223
|
+
* Additional CSS classes for price interval
|
|
224
|
+
*/
|
|
225
|
+
priceIntervalClassName?: string;
|
|
226
|
+
/**
|
|
227
|
+
* Additional CSS classes for features list
|
|
228
|
+
*/
|
|
229
|
+
featuresClassName?: string;
|
|
230
|
+
/**
|
|
231
|
+
* Additional CSS classes for feature items
|
|
232
|
+
*/
|
|
233
|
+
featureItemClassName?: string;
|
|
234
|
+
/**
|
|
235
|
+
* Additional CSS classes for feature icons
|
|
236
|
+
*/
|
|
237
|
+
featureIconClassName?: string;
|
|
238
|
+
/**
|
|
239
|
+
* Additional CSS classes for feature text
|
|
240
|
+
*/
|
|
241
|
+
featureTextClassName?: string;
|
|
242
|
+
/**
|
|
243
|
+
* Additional CSS classes for action
|
|
244
|
+
*/
|
|
245
|
+
actionClassName?: string;
|
|
246
|
+
}
|
|
247
|
+
/**
|
|
248
|
+
* PricingFourTierToggle displays a 4-column pricing grid with annual billing toggle.
|
|
249
|
+
* Features check/X icons for feature availability, popular plan highlighting, and responsive layout.
|
|
250
|
+
* Switch toggle allows users to compare monthly vs annual pricing with savings indicator.
|
|
251
|
+
*
|
|
252
|
+
* Ideal for SaaS products with multiple tiers from free to enterprise.
|
|
253
|
+
*
|
|
254
|
+
* @example
|
|
255
|
+
* ```tsx
|
|
256
|
+
* <PricingFourTierToggle
|
|
257
|
+
* title="Choose Your Plan"
|
|
258
|
+
* plans={[
|
|
259
|
+
* { name: "Free", monthlyPrice: "$0", yearlyPrice: "$0", features: [{ name: "Feature", included: true }] }
|
|
260
|
+
* ]}
|
|
261
|
+
* />
|
|
262
|
+
* ```
|
|
263
|
+
*/
|
|
264
|
+
declare function PricingFourTierToggle({ title, subtitle, monthlyLabel, yearlyLabel, yearlyBadge, monthlyInterval, yearlyInterval, plans, plansSlot, includedIcon, excludedIcon, includedIconName, excludedIconName, popularBadge, background, spacing, pattern, patternOpacity, patternClassName, className, containerClassName, headerClassName, titleClassName, subtitleClassName, toggleClassName, toggleLabelClassName, yearlyBadgeClassName, gridClassName, cardClassName, popularCardClassName, badgeClassName, planTitleClassName, planDescriptionClassName, priceClassName, priceIntervalClassName, featuresClassName, featureItemClassName, featureIconClassName, featureTextClassName, actionClassName, }: PricingFourTierToggleProps): React.JSX.Element;
|
|
265
|
+
|
|
266
|
+
export { PricingFourTierToggle, type PricingFourTierToggleProps };
|