@envive-ai/react-widgets-v3 0.3.14 → 0.3.15-beta.1
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/hocs/withBaseWidget/types.d.cts +3 -3
- package/dist/hocs/withBaseWidget/types.d.ts +5 -3
- package/dist/hocs/withBaseWidget/withBaseWidget.d.cts +2 -2
- package/dist/hocs/withBaseWidget/withBaseWidget.d.ts +2 -2
- package/dist/hooks/dist/application/models/api/widgetText.d.cts +8 -0
- package/dist/hooks/dist/contexts/hardcopyContext/hardcopyContext.d.cts +12 -0
- package/dist/hooks/dist/contexts/types.d.cts +38 -0
- package/dist/hooks/dist/contexts/typesV3.d.cts +239 -0
- package/dist/hooks/dist/services/amplitudeService/eventNames.d.cts +43 -0
- package/dist/hooks/dist/types/customerService.d.cts +21 -0
- package/dist/packages/hooks/dist/application/models/api/orgConfigResults.d.ts +1 -0
- package/dist/packages/hooks/dist/application/models/api/widgetText.d.ts +8 -0
- package/dist/packages/hooks/dist/application/models/frontendConfig.d.ts +1 -0
- package/dist/packages/hooks/dist/contexts/amplitudeContext/amplitudeContext.d.ts +2 -0
- package/dist/packages/hooks/dist/contexts/amplitudeContext/index.d.ts +2 -0
- package/dist/packages/hooks/dist/contexts/featureFlagServiceContext/featureFlagServiceContext.d.ts +2 -0
- package/dist/packages/hooks/dist/contexts/hardcopyContext/hardcopyContext.d.ts +14 -0
- package/dist/packages/hooks/dist/contexts/hardcopyContext/index.d.ts +1 -0
- package/dist/packages/hooks/dist/contexts/types.d.ts +42 -0
- package/dist/packages/hooks/dist/contexts/typesV3.d.ts +239 -0
- package/dist/packages/hooks/dist/services/amplitudeService/amplitudeService.d.ts +1 -0
- package/dist/packages/hooks/dist/services/amplitudeService/eventNames.d.ts +43 -0
- package/dist/packages/hooks/dist/types/customerService.d.ts +21 -0
- package/dist/packages/widgets/dist/SearchResults/SearchResults.d.ts +4 -3
- package/dist/packages/widgets/dist/SearchResults/SearchResultsWidget.d.ts +2 -2
- package/dist/packages/widgets/dist/SearchZeroState/index.d.ts +2 -1
- package/dist/packages/widgets/dist/SearchZeroState/types.d.ts +2 -2
- package/dist/packages/widgets/dist/SuggestionBar/SuggestionBar.d.ts +3 -3
- package/dist/packages/widgets/dist/SuggestionButtonContainer/index.d.ts +2 -0
- package/dist/packages/widgets/dist/SuggestionButtonContainer/types.d.ts +3 -2
- package/dist/packages/widgets/dist/packages/hooks/dist/application/models/api/response.d.ts +14 -0
- package/dist/packages/widgets/dist/packages/hooks/dist/application/models/api/search.d.ts +15 -0
- package/dist/packages/widgets/dist/packages/hooks/dist/application/models/utilityTypes/camelCase.d.ts +73 -0
- package/dist/packages/widgets/dist/packages/hooks/dist/application/models/utilityTypes/camelCasedPropertiesDeep.d.ts +61 -0
- package/dist/packages/widgets/dist/packages/hooks/dist/application/models/utilityTypes/internal.d.ts +25 -0
- package/dist/packages/widgets/dist/packages/hooks/dist/application/models/utilityTypes/splitWords.d.ts +35 -0
- package/dist/packages/widgets/dist/packages/hooks/dist/application/models/utilityTypes/trim.d.ts +32 -0
- package/dist/packages/widgets/dist/packages/hooks/dist/application/models/utilityTypes/unknownArray.d.ts +32 -0
- package/dist/packages/widgets/dist/packages/hooks/dist/application/models/variantInfo/variantInfo.d.ts +1 -0
- package/dist/packages/widgets/dist/packages/hooks/dist/atoms/search/searchAPI.d.ts +15 -0
- package/dist/packages/widgets/dist/packages/hooks/dist/contexts/hardcopyContext/hardcopyContext.d.ts +1 -0
- package/dist/packages/widgets/dist/packages/hooks/dist/contexts/types.d.ts +63 -0
- package/dist/packages/widgets/dist/packages/hooks/dist/hooks/Search/useSearch.d.ts +60 -0
- package/dist/packages/widgets/dist/packages/hooks/dist/hooks/utils.d.ts +13 -0
- package/dist/packages/widgets/dist/packages/hooks/dist/types/OrgInfo.d.ts +1 -0
- package/dist/packages/widgets/dist/packages/hooks/dist/types/index.d.ts +1 -0
- package/dist/packages/widgets/dist/packages/hooks/dist/types/search-filter-types.d.ts +28 -0
- package/dist/packages/widgets/dist/packages/hooks/dist/types/test-types.d.ts +10 -0
- package/dist/widgets/ChatPreviewComparisonWidget/ChatPreviewComparisonWidget.d.cts +3 -3
- package/dist/widgets/ChatPreviewComparisonWidget/ChatPreviewComparisonWidget.d.ts +3 -3
- package/dist/widgets/ChatPreviewLoadingWidget/ChatPreviewLoadingWidget.d.ts +3 -3
- package/dist/widgets/ChatPreviewWidget/ChatPreviewWidget.d.cts +3 -3
- package/dist/widgets/ChatPreviewWidget/ChatPreviewWidget.d.ts +3 -3
- package/dist/widgets/FloatingChatWidget/FloatingChatWidget.cjs +29 -5
- package/dist/widgets/FloatingChatWidget/FloatingChatWidget.d.cts +2 -2
- package/dist/widgets/FloatingChatWidget/FloatingChatWidget.d.ts +2 -2
- package/dist/widgets/FloatingChatWidget/FloatingChatWidget.js +30 -6
- package/dist/widgets/FullPageSalesAgentWidget/FullPageSalesAgentWidget.d.cts +2 -2
- package/dist/widgets/FullPageSalesAgentWidget/FullPageSalesAgentWidget.d.ts +2 -2
- package/dist/widgets/ProductCardWidget/ProductCardWidget.d.cts +2 -2
- package/dist/widgets/ProductCardWidget/ProductCardWidget.d.ts +2 -2
- package/dist/widgets/PromptButtonCarouselWithImageWidget/PromptButtonCarouselWithImageWidget.d.cts +3 -3
- package/dist/widgets/PromptButtonCarouselWithImageWidget/PromptButtonCarouselWithImageWidget.d.ts +3 -3
- package/dist/widgets/PromptCarouselWidget/PromptCarouselWidget.cjs +13 -1
- package/dist/widgets/PromptCarouselWidget/PromptCarouselWidget.d.cts +2 -2
- package/dist/widgets/PromptCarouselWidget/PromptCarouselWidget.d.ts +2 -2
- package/dist/widgets/PromptCarouselWidget/PromptCarouselWidget.js +15 -3
- package/dist/widgets/SocialProofFlowWidget/SocialProofFlowWidget.d.cts +2 -2
- package/dist/widgets/SocialProofFlowWidget/SocialProofFlowWidget.d.ts +2 -2
- package/dist/widgets/SocialProofWidget/SocialProofWidget.d.cts +3 -3
- package/dist/widgets/TitledPromptCarouselWidget/TitledPromptCarouselWidget.d.cts +2 -2
- package/dist/widgets/TitledPromptCarouselWidget/TitledPromptCarouselWidget.d.ts +2 -2
- package/dist/widgets/TypingAnimationFlowWidget/TypingAnimationFlowWidget.d.cts +2 -2
- package/dist/widgets/TypingAnimationFlowWidget/TypingAnimationFlowWidget.d.ts +2 -2
- package/dist/widgets/TypingAnimationWidget/TypingAnimationWidget.d.cts +3 -3
- package/dist/widgets/dist/SearchResults/SearchResults.d.cts +4 -3
- package/dist/widgets/dist/SearchResults/SearchResultsWidget.d.cts +2 -2
- package/dist/widgets/dist/SearchZeroState/types.d.cts +2 -2
- package/dist/widgets/dist/SuggestionBar/SuggestionBar.d.cts +3 -3
- package/dist/widgets/dist/SuggestionButtonContainer/types.d.cts +3 -2
- package/dist/widgets/dist/packages/hooks/dist/application/models/api/response.d.cts +14 -0
- package/dist/widgets/dist/packages/hooks/dist/application/models/api/search.d.cts +15 -0
- package/dist/widgets/dist/packages/hooks/dist/application/models/utilityTypes/camelCase.d.cts +73 -0
- package/dist/widgets/dist/packages/hooks/dist/application/models/utilityTypes/camelCasedPropertiesDeep.d.cts +61 -0
- package/dist/widgets/dist/packages/hooks/dist/application/models/utilityTypes/internal.d.cts +25 -0
- package/dist/widgets/dist/packages/hooks/dist/application/models/utilityTypes/splitWords.d.cts +35 -0
- package/dist/widgets/dist/packages/hooks/dist/application/models/utilityTypes/trim.d.cts +32 -0
- package/dist/widgets/dist/packages/hooks/dist/application/models/utilityTypes/unknownArray.d.cts +32 -0
- package/dist/widgets/dist/packages/hooks/dist/atoms/search/searchAPI.d.cts +14 -0
- package/dist/widgets/dist/packages/hooks/dist/contexts/types.d.cts +61 -0
- package/dist/widgets/dist/packages/hooks/dist/hooks/Search/useSearch.d.cts +60 -0
- package/dist/widgets/dist/packages/hooks/dist/hooks/utils.d.cts +12 -0
- package/dist/widgets/dist/packages/hooks/dist/types/search-filter-types.d.cts +28 -0
- package/dist/widgets/dist/packages/hooks/dist/types/test-types.d.cts +10 -0
- package/dist/widgets-v2/SearchZeroState/index.d.cts +2 -1
- package/dist/widgets-v2/SearchZeroState/index.d.ts +2 -1
- package/dist/widgets-v2/SuggestionButtonContainer/index.d.ts +1 -0
- package/package.json +1 -1
- package/src/widgets/FloatingChatWidget/FloatingChatWidget.tsx +56 -15
- package/src/widgets/PromptCarouselWidget/PromptCarouselWidget.tsx +32 -9
|
@@ -0,0 +1,239 @@
|
|
|
1
|
+
import { CustomerServiceType } from "../types/customerService.js";
|
|
2
|
+
import { SearchConfig } from "./types.js";
|
|
3
|
+
import { Theme } from "@envive-ai/react-toolkit-v3/Tokens";
|
|
4
|
+
import { AnimationSpeed, PromptCarouselRows } from "@envive-ai/react-toolkit-v3/PromptCarousel";
|
|
5
|
+
import { FloatingButtonLocation } from "@envive-ai/react-toolkit-v3/FloatingButton";
|
|
6
|
+
import { DynamicLayout, WidgetKind } from "@envive-ai/react-toolkit-v3/SocialProof";
|
|
7
|
+
import { WidgetWrapperVariant } from "@envive-ai/react-toolkit-v3/WidgetWrapper";
|
|
8
|
+
import { ImageGalleryImage, ImageGalleryLayout } from "@envive-ai/react-toolkit-v3/ImageGallery";
|
|
9
|
+
import { PromptButtonVariant } from "@envive-ai/react-toolkit-v3/PromptButton";
|
|
10
|
+
import { SparkleIconColor } from "@envive-ai/react-toolkit-v3/WelcomeMessage";
|
|
11
|
+
|
|
12
|
+
//#region ../hooks/dist/contexts/typesV3.d.ts
|
|
13
|
+
|
|
14
|
+
type ImageAspectRatio = '1/1' | '3/4';
|
|
15
|
+
type ButtonColors = {
|
|
16
|
+
lightButtonBackgroundColor: string;
|
|
17
|
+
lightButtonIconColor: string;
|
|
18
|
+
darkButtonBackgroundColor: string;
|
|
19
|
+
darkButtonIconColor: string;
|
|
20
|
+
};
|
|
21
|
+
type Typography = {
|
|
22
|
+
titleFontFamily: string;
|
|
23
|
+
headerFontFamily: string;
|
|
24
|
+
bodyFontFamily: string;
|
|
25
|
+
fontSize?: {
|
|
26
|
+
t1: string;
|
|
27
|
+
t2: string;
|
|
28
|
+
t3: string;
|
|
29
|
+
h1: string;
|
|
30
|
+
h2: string;
|
|
31
|
+
h3: string;
|
|
32
|
+
b1: string;
|
|
33
|
+
b2: string;
|
|
34
|
+
b3: string;
|
|
35
|
+
b4: string;
|
|
36
|
+
b5: string;
|
|
37
|
+
l1: string;
|
|
38
|
+
l2: string;
|
|
39
|
+
};
|
|
40
|
+
fontWeight?: {
|
|
41
|
+
rg: string;
|
|
42
|
+
md: string;
|
|
43
|
+
sb: string;
|
|
44
|
+
};
|
|
45
|
+
letterSpacing?: {
|
|
46
|
+
'0': string;
|
|
47
|
+
'wide-1': string;
|
|
48
|
+
};
|
|
49
|
+
lineHeight?: {
|
|
50
|
+
'124': number;
|
|
51
|
+
'120': number;
|
|
52
|
+
'118': number;
|
|
53
|
+
'116': number;
|
|
54
|
+
'114': number;
|
|
55
|
+
'148': number;
|
|
56
|
+
'140': number;
|
|
57
|
+
'128': number;
|
|
58
|
+
'130': number;
|
|
59
|
+
'133': number;
|
|
60
|
+
};
|
|
61
|
+
};
|
|
62
|
+
type LookAndFeelConfig = {
|
|
63
|
+
theme: Theme;
|
|
64
|
+
agentName: string;
|
|
65
|
+
chatHeaderLogoDarkSrc: string;
|
|
66
|
+
chatHeaderLogoLightSrc: string;
|
|
67
|
+
widgetLogoSrc: string;
|
|
68
|
+
hideWidgetLogo: boolean;
|
|
69
|
+
elementRadius: number;
|
|
70
|
+
imageAspectRatio: ImageAspectRatio;
|
|
71
|
+
buttonColors: ButtonColors;
|
|
72
|
+
typography: Typography;
|
|
73
|
+
};
|
|
74
|
+
declare enum ConfigVersionEnum {
|
|
75
|
+
V3 = "v3",
|
|
76
|
+
Deprecated = "deprecated",
|
|
77
|
+
}
|
|
78
|
+
type ConfigVersion = ConfigVersionEnum.V3 | ConfigVersionEnum.Deprecated | undefined;
|
|
79
|
+
type Mode = 'dark' | 'light';
|
|
80
|
+
type ShowOptions = 'always' | 'postInteraction' | 'none';
|
|
81
|
+
type Style = 'attached' | 'detached';
|
|
82
|
+
type FloatingButtonConfig = {
|
|
83
|
+
position: FloatingButtonLocation;
|
|
84
|
+
backgroundColor?: string;
|
|
85
|
+
mode: Mode;
|
|
86
|
+
showOption: ShowOptions;
|
|
87
|
+
iconSVGSrc?: string;
|
|
88
|
+
style: Style;
|
|
89
|
+
};
|
|
90
|
+
type ReferrerPopupTrigger = {
|
|
91
|
+
type: 'referrer';
|
|
92
|
+
referrers: string[];
|
|
93
|
+
};
|
|
94
|
+
type AutomaticPopupTrigger = {
|
|
95
|
+
type: 'automatic';
|
|
96
|
+
};
|
|
97
|
+
type PopupTrigger = ReferrerPopupTrigger | AutomaticPopupTrigger;
|
|
98
|
+
type AutoPopupTrigger = {
|
|
99
|
+
delay: number;
|
|
100
|
+
trigger: PopupTrigger;
|
|
101
|
+
};
|
|
102
|
+
interface AutoPopupConfig {
|
|
103
|
+
triggers: AutoPopupTrigger[];
|
|
104
|
+
}
|
|
105
|
+
type PartialViewConfig = {
|
|
106
|
+
/**
|
|
107
|
+
* When true, only full-screen mode is supported (no partial/draggable middle state).
|
|
108
|
+
* Useful when partial view causes usability issues on mobile.
|
|
109
|
+
* Default: false (undefined and false = partial view enabled).
|
|
110
|
+
*/
|
|
111
|
+
disabled?: boolean;
|
|
112
|
+
};
|
|
113
|
+
type FloatingChatConfig = {
|
|
114
|
+
headerBackgroundColor?: string;
|
|
115
|
+
headerMode: Mode;
|
|
116
|
+
welcomeMessageIconColor: SparkleIconColor;
|
|
117
|
+
showVerifiedBuyer: boolean;
|
|
118
|
+
userQueryInputEnabled: boolean;
|
|
119
|
+
showEnviveLogo: boolean;
|
|
120
|
+
ignoreFirstModelResponse?: boolean;
|
|
121
|
+
neverShowSingleProductCards?: boolean;
|
|
122
|
+
welcomeMessageTitle: string;
|
|
123
|
+
welcomeMessageText: string;
|
|
124
|
+
chatFooterTextFieldPlaceholderText: string;
|
|
125
|
+
autoPopupConfig?: AutoPopupConfig;
|
|
126
|
+
partialViewConfig?: PartialViewConfig;
|
|
127
|
+
};
|
|
128
|
+
type CustomerServiceIntegration = {
|
|
129
|
+
enabled: boolean;
|
|
130
|
+
provider: CustomerServiceType;
|
|
131
|
+
suppressMerchantButton?: boolean;
|
|
132
|
+
};
|
|
133
|
+
type SPASettings = {
|
|
134
|
+
enabled: boolean;
|
|
135
|
+
refreshInterval?: number;
|
|
136
|
+
};
|
|
137
|
+
type OrgUIConfigV3 = {
|
|
138
|
+
id?: string;
|
|
139
|
+
version: ConfigVersion;
|
|
140
|
+
shortName: string;
|
|
141
|
+
lookAndFeel: LookAndFeelConfig;
|
|
142
|
+
floatingButton: FloatingButtonConfig;
|
|
143
|
+
floatingChat: FloatingChatConfig;
|
|
144
|
+
merchantOverrideCss?: string;
|
|
145
|
+
customerServiceIntegration?: CustomerServiceIntegration;
|
|
146
|
+
singlePageApplicationSettings?: SPASettings;
|
|
147
|
+
searchConfig?: SearchConfig;
|
|
148
|
+
};
|
|
149
|
+
declare enum WidgetTypeV3 {
|
|
150
|
+
PromptCarouselV3 = "PromptCarouselV3",
|
|
151
|
+
TitledPromptCarouselV3 = "TitledPromptCarouselV3",
|
|
152
|
+
SocialProofV3 = "SocialProofV3",
|
|
153
|
+
TypingAnimationV3 = "TypingAnimationV3",
|
|
154
|
+
ChatPreviewV3 = "ChatPreviewV3",
|
|
155
|
+
ChatPreviewComparisonV3 = "ChatPreviewComparisonV3",
|
|
156
|
+
ChatPreviewLoadingV3 = "ChatPreviewLoadingV3",
|
|
157
|
+
ImagePromptCardV3 = "ImagePromptCardV3",
|
|
158
|
+
PromptButtonCarouselWithImageV3 = "PromptButtonCarouselWithImageV3",
|
|
159
|
+
ImageBannerV3 = "ImageBannerV3",
|
|
160
|
+
SingleImagePromptV3 = "SingleImagePromptV3",
|
|
161
|
+
FloatingChatV3 = "FloatingChatV3",
|
|
162
|
+
FloatingButtonV3 = "FloatingButtonV3",
|
|
163
|
+
ProductCardV3 = "ProductCardV3",
|
|
164
|
+
FullPageSalesAgentV3 = "FullPageSalesAgentV3",
|
|
165
|
+
}
|
|
166
|
+
interface BaseWidgetConfig<T extends WidgetTypeV3> {
|
|
167
|
+
widgetConfigId: string;
|
|
168
|
+
type: T;
|
|
169
|
+
contentId?: string;
|
|
170
|
+
}
|
|
171
|
+
interface PromptCarouselWidgetV3Config extends BaseWidgetConfig<WidgetTypeV3.PromptCarouselV3> {
|
|
172
|
+
promptButtonType?: PromptButtonVariant;
|
|
173
|
+
boldFirstButton?: boolean;
|
|
174
|
+
promptCarouselRows?: PromptCarouselRows;
|
|
175
|
+
animationSpeed?: AnimationSpeed;
|
|
176
|
+
}
|
|
177
|
+
interface TitledPromptCarouselWidgetV3Config extends BaseWidgetConfig<WidgetTypeV3.TitledPromptCarouselV3> {
|
|
178
|
+
promptButtonType?: PromptButtonVariant;
|
|
179
|
+
boldFirstButton?: boolean;
|
|
180
|
+
promptCarouselRows?: PromptCarouselRows;
|
|
181
|
+
animationSpeed?: AnimationSpeed;
|
|
182
|
+
}
|
|
183
|
+
interface SocialProofWidgetV3Config extends BaseWidgetConfig<WidgetTypeV3.SocialProofV3> {
|
|
184
|
+
kind: WidgetKind;
|
|
185
|
+
variant: WidgetWrapperVariant;
|
|
186
|
+
hexCardColor?: string;
|
|
187
|
+
promptCarouselRows: PromptCarouselRows;
|
|
188
|
+
hideImage?: boolean;
|
|
189
|
+
imageGalleryLayout: Exclude<ImageGalleryLayout, 'TWO_SIDE'>;
|
|
190
|
+
hideTextField?: boolean;
|
|
191
|
+
primaryButtonVariant: Exclude<PromptButtonVariant, 'suggestedResponse' | 'ghost'>;
|
|
192
|
+
secondaryButtonVariant: Exclude<PromptButtonVariant, 'suggestedResponse' | 'ghost'>;
|
|
193
|
+
dynamicLayout?: DynamicLayout;
|
|
194
|
+
images?: ImageGalleryImage[];
|
|
195
|
+
}
|
|
196
|
+
interface TypingAnimationWidgetV3Config extends BaseWidgetConfig<WidgetTypeV3.TypingAnimationV3> {
|
|
197
|
+
widgetVariant?: WidgetWrapperVariant;
|
|
198
|
+
cardColor?: string;
|
|
199
|
+
promptButtonType?: PromptButtonVariant;
|
|
200
|
+
promptCarouselRows?: PromptCarouselRows;
|
|
201
|
+
showTextField?: boolean;
|
|
202
|
+
}
|
|
203
|
+
interface ChatPreviewComparisonWidgetV3Config extends BaseWidgetConfig<WidgetTypeV3.ChatPreviewComparisonV3> {
|
|
204
|
+
variant: WidgetWrapperVariant;
|
|
205
|
+
hexCardColor?: string;
|
|
206
|
+
hideImage?: boolean;
|
|
207
|
+
hideTextField?: boolean;
|
|
208
|
+
}
|
|
209
|
+
interface ChatPreviewLoadingWidgetV3Config extends BaseWidgetConfig<WidgetTypeV3.ChatPreviewLoadingV3> {
|
|
210
|
+
variant: WidgetWrapperVariant;
|
|
211
|
+
hexCardColor?: string;
|
|
212
|
+
hideTextField?: boolean;
|
|
213
|
+
}
|
|
214
|
+
interface ChatPreviewWidgetV3Config extends BaseWidgetConfig<WidgetTypeV3.ChatPreviewV3> {
|
|
215
|
+
variant: WidgetWrapperVariant;
|
|
216
|
+
hexCardColor?: string;
|
|
217
|
+
hideTextField?: boolean;
|
|
218
|
+
}
|
|
219
|
+
interface PromptButtonCarouselWithImageWidgetV3Config extends BaseWidgetConfig<WidgetTypeV3.PromptButtonCarouselWithImageV3> {
|
|
220
|
+
promptButtonType?: PromptButtonVariant;
|
|
221
|
+
image?: ImageGalleryImage;
|
|
222
|
+
hideTextField?: boolean;
|
|
223
|
+
isDynamic?: boolean;
|
|
224
|
+
}
|
|
225
|
+
interface FloatingChatWidgetV3Config extends BaseWidgetConfig<WidgetTypeV3.FloatingChatV3> {}
|
|
226
|
+
interface ProductCardWidgetV3Config extends BaseWidgetConfig<WidgetTypeV3.ProductCardV3> {
|
|
227
|
+
promptButtonType?: PromptButtonVariant;
|
|
228
|
+
italicizeHeadline?: boolean;
|
|
229
|
+
fallbackColor?: string;
|
|
230
|
+
imageSrc?: string;
|
|
231
|
+
}
|
|
232
|
+
interface FullPageSalesAgentWidgetV3Config extends BaseWidgetConfig<WidgetTypeV3.FullPageSalesAgentV3> {
|
|
233
|
+
headerContainer?: string;
|
|
234
|
+
autoHeight?: boolean;
|
|
235
|
+
}
|
|
236
|
+
type WidgetConfigV3 = PromptCarouselWidgetV3Config | SocialProofWidgetV3Config | TitledPromptCarouselWidgetV3Config | ChatPreviewComparisonWidgetV3Config | ChatPreviewLoadingWidgetV3Config | TypingAnimationWidgetV3Config | ChatPreviewWidgetV3Config | PromptButtonCarouselWithImageWidgetV3Config | FloatingChatWidgetV3Config | ProductCardWidgetV3Config | FullPageSalesAgentWidgetV3Config;
|
|
237
|
+
//#endregion
|
|
238
|
+
//#endregion
|
|
239
|
+
export { type OrgUIConfigV3, type WidgetConfigV3, WidgetTypeV3 };
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import "../../contexts/featureFlagServiceContext/featureFlagServiceContext.js";
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
//#region ../hooks/dist/services/amplitudeService/eventNames.d.ts
|
|
2
|
+
//#region src/services/amplitudeService/eventNames.d.ts
|
|
3
|
+
/**
|
|
4
|
+
* Event name enums for Amplitude tracking.
|
|
5
|
+
*
|
|
6
|
+
* NOTE: This file exists separately to avoid circular dependency issues.
|
|
7
|
+
* The amplitudeService imports from ga4ProjectionService, which needs these enums.
|
|
8
|
+
* By keeping the enums in a separate file, ga4ProjectionService can import them
|
|
9
|
+
* without creating a circular dependency with amplitudeService.
|
|
10
|
+
*/
|
|
11
|
+
declare enum SpiffyMetricsEventName {
|
|
12
|
+
BundleLoaded = "Bundle Loaded",
|
|
13
|
+
EnvironmentInitialized = "Environment Initialized",
|
|
14
|
+
ChatLiveAgentBtnClick = "Chat Live Agent Btn Click",
|
|
15
|
+
ChatFloatingButtonVisible = "Chat Floating Button Visible",
|
|
16
|
+
ChatComponentVisible = "Chat Component Visible",
|
|
17
|
+
ChatComponentExpanded = "Chat Component Expanded",
|
|
18
|
+
ChatComponentCollapsed = "Chat Component Collapsed",
|
|
19
|
+
ChatUserMessageInput = "Chat User Message Input",
|
|
20
|
+
ChatSuggestionClicked = "Chat Suggestion Clicked",
|
|
21
|
+
ChatAssistantResponse = "Chat Assistant Response",
|
|
22
|
+
ProductCardClicked = "Product Card Clicked",
|
|
23
|
+
ProductReviewCardClicked = "Product Review Card Clicked",
|
|
24
|
+
AddToCartClicked = "Add To Cart Clicked",
|
|
25
|
+
PromptCardClicked = "Prompt Card Clicked",
|
|
26
|
+
SupportedEvent = "Supported Event",
|
|
27
|
+
SearchBackToResponseClicked = "Search Back to Response Clicked",
|
|
28
|
+
PerformanceMetrics = "Performance Metrics",
|
|
29
|
+
SearchBarClicked = "Search Bar Clicked",
|
|
30
|
+
OrderLookupStarted = "Order Lookup Started",
|
|
31
|
+
OrderLookupFormSubmitted = "Order Lookup Form Submitted",
|
|
32
|
+
SearchComponentVisible = "Search Component Visible",
|
|
33
|
+
SearchZeroStateSuggestionClicked = "Search Zero State Suggestion Clicked",
|
|
34
|
+
SearchInputStarted = "Search Input Started",
|
|
35
|
+
SearchQuerySubmitted = "Search Query Submitted",
|
|
36
|
+
SearchResultsViewed = "Search Results Viewed",
|
|
37
|
+
SearchTimeToFirstClick = "Search Time to First Click",
|
|
38
|
+
SearchZeroResultsRate = "Search Zero Results Rate",
|
|
39
|
+
SearchFilterClicked = "Search Filter Clicked",
|
|
40
|
+
SearchSortClicked = "Search Sort Clicked",
|
|
41
|
+
}
|
|
42
|
+
//#endregion
|
|
43
|
+
export { SpiffyMetricsEventName };
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
//#region ../hooks/dist/types/customerService.d.ts
|
|
2
|
+
|
|
3
|
+
//#region src/types/customerService.d.ts
|
|
4
|
+
declare enum CustomerServiceType {
|
|
5
|
+
shopify = "shopify",
|
|
6
|
+
gorgias = "gorgias",
|
|
7
|
+
kustomer = "kustomer",
|
|
8
|
+
groove = "groove",
|
|
9
|
+
tidio = "tidio",
|
|
10
|
+
zowie = "zowie",
|
|
11
|
+
redo = "redo",
|
|
12
|
+
gladly = "gladly",
|
|
13
|
+
richpanel = "richpanel",
|
|
14
|
+
zendesk = "zendesk",
|
|
15
|
+
helpscout = "helpscout",
|
|
16
|
+
talkdesk = "talkdesk",
|
|
17
|
+
eightByEight = "8x8",
|
|
18
|
+
unsupported = "unsupported",
|
|
19
|
+
}
|
|
20
|
+
//#endregion
|
|
21
|
+
export { CustomerServiceType };
|
|
@@ -1,13 +1,14 @@
|
|
|
1
|
+
import { SearchResultsHocProps } from "../packages/hooks/dist/hooks/Search/useSearch.js";
|
|
1
2
|
import { SearchResultsEntryPointWidgetConfig } from "./types.js";
|
|
2
|
-
import * as
|
|
3
|
-
import { SearchResultsHocProps } from "@envive-ai/react-hooks/hooks/Search";
|
|
3
|
+
import * as react_jsx_runtime0 from "react/jsx-runtime";
|
|
4
4
|
|
|
5
5
|
//#region ../widgets/dist/SearchResults/SearchResults.d.ts
|
|
6
|
+
|
|
6
7
|
//#region src/SearchResults/SearchResults.d.ts
|
|
7
8
|
interface SearchResultsProps extends SearchResultsHocProps {
|
|
8
9
|
widgetConfig: SearchResultsEntryPointWidgetConfig;
|
|
9
10
|
}
|
|
10
|
-
declare const SearchResults: (props: Omit<SearchResultsProps,
|
|
11
|
+
declare const SearchResults: (props: Omit<SearchResultsProps, keyof SearchResultsHocProps>) => react_jsx_runtime0.JSX.Element;
|
|
11
12
|
//#endregion
|
|
12
13
|
|
|
13
14
|
//#endregion
|
|
@@ -1,8 +1,8 @@
|
|
|
1
|
-
import * as
|
|
1
|
+
import * as react_jsx_runtime2 from "react/jsx-runtime";
|
|
2
2
|
|
|
3
3
|
//#region ../widgets/dist/SearchResults/SearchResultsWidget.d.ts
|
|
4
4
|
//#region src/SearchResults/SearchResultsWidget.d.ts
|
|
5
|
-
declare const SearchResultsWidget: () =>
|
|
5
|
+
declare const SearchResultsWidget: () => react_jsx_runtime2.JSX.Element;
|
|
6
6
|
//#endregion
|
|
7
7
|
|
|
8
8
|
//#endregion
|
|
@@ -1,3 +1,4 @@
|
|
|
1
|
-
import { SearchEntryPointWidgetConfig, SearchInputVariant
|
|
1
|
+
import { SearchEntryPointWidgetConfig, SearchInputVariant } from "../packages/hooks/dist/contexts/types.js";
|
|
2
|
+
import { SearchZeroStateProps } from "./types.js";
|
|
2
3
|
import { SearchZeroState } from "./SearchZeroState.js";
|
|
3
4
|
import { SearchZeroStateWidget } from "./SearchZeroStateWidget.js";
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { SearchEntryPointWidgetConfig
|
|
1
|
+
import { SearchEntryPointWidgetConfig } from "../packages/hooks/dist/contexts/types.js";
|
|
2
2
|
|
|
3
3
|
//#region ../widgets/dist/SearchZeroState/types.d.ts
|
|
4
4
|
//#region src/SearchZeroState/types.d.ts
|
|
@@ -10,4 +10,4 @@ interface SearchZeroStateProps {
|
|
|
10
10
|
//#endregion
|
|
11
11
|
|
|
12
12
|
//#endregion
|
|
13
|
-
export {
|
|
13
|
+
export { SearchZeroStateProps };
|
|
@@ -1,6 +1,6 @@
|
|
|
1
|
+
import { SuggestionButtonVariant } from "../packages/hooks/dist/contexts/types.js";
|
|
1
2
|
import { SuggestionBarLocationForMetrics } from "./types.js";
|
|
2
|
-
import * as
|
|
3
|
-
import { SuggestionButtonVariant } from "@envive-ai/react-hooks/contexts/types";
|
|
3
|
+
import * as react_jsx_runtime3 from "react/jsx-runtime";
|
|
4
4
|
import { Message } from "postcss";
|
|
5
5
|
|
|
6
6
|
//#region ../widgets/dist/SuggestionBar/SuggestionBar.d.ts
|
|
@@ -30,7 +30,7 @@ declare function SuggestionBar({
|
|
|
30
30
|
buttonBorderRadius,
|
|
31
31
|
handleReply,
|
|
32
32
|
dataTestId
|
|
33
|
-
}: Readonly<SuggestionBarProps>):
|
|
33
|
+
}: Readonly<SuggestionBarProps>): react_jsx_runtime3.JSX.Element;
|
|
34
34
|
//#endregion
|
|
35
35
|
//#endregion
|
|
36
36
|
export { SuggestionBar };
|
|
@@ -1,5 +1,6 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import {
|
|
1
|
+
import { TestProps } from "../packages/hooks/dist/types/test-types.js";
|
|
2
|
+
import { SuggestionButtonVariant } from "../packages/hooks/dist/contexts/types.js";
|
|
3
|
+
import "../packages/hooks/dist/types/index.js";
|
|
3
4
|
|
|
4
5
|
//#region ../widgets/dist/SuggestionButtonContainer/types.d.ts
|
|
5
6
|
//#region src/SuggestionButtonContainer/types.d.ts
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { CamelCasedPropertiesDeep } from "../utilityTypes/camelCasedPropertiesDeep.js";
|
|
2
|
+
import { ResponseCategory, SearchResponseProduct } from "@spiffy-ai/commerce-api-client";
|
|
3
|
+
|
|
4
|
+
//#region ../widgets/dist/packages/hooks/dist/application/models/api/response.d.ts
|
|
5
|
+
|
|
6
|
+
//#region ../hooks/dist/application/models/api/response.d.ts
|
|
7
|
+
interface SearchResponseProductAttributes {
|
|
8
|
+
category: ResponseCategory.Product;
|
|
9
|
+
attributes: CamelCasedPropertiesDeep<SearchResponseProduct>;
|
|
10
|
+
}
|
|
11
|
+
//#endregion
|
|
12
|
+
|
|
13
|
+
//#endregion
|
|
14
|
+
export { SearchResponseProductAttributes };
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import { SearchResponseProduct } from "@spiffy-ai/commerce-api-client";
|
|
2
|
+
|
|
3
|
+
//#region ../widgets/dist/packages/hooks/dist/application/models/api/search.d.ts
|
|
4
|
+
|
|
5
|
+
//#region ../hooks/dist/application/models/api/search.d.ts
|
|
6
|
+
interface SearchResult {
|
|
7
|
+
products: SearchResponseProduct[];
|
|
8
|
+
filters: string[];
|
|
9
|
+
generatedQuery?: string;
|
|
10
|
+
totalProductCount: number;
|
|
11
|
+
searchResponseId: string;
|
|
12
|
+
}
|
|
13
|
+
//#endregion
|
|
14
|
+
//#endregion
|
|
15
|
+
export { SearchResult };
|
|
@@ -0,0 +1,73 @@
|
|
|
1
|
+
import { SplitWords } from "./splitWords.js";
|
|
2
|
+
|
|
3
|
+
//#region ../widgets/dist/packages/hooks/dist/application/models/utilityTypes/camelCase.d.ts
|
|
4
|
+
|
|
5
|
+
//#region ../hooks/dist/application/models/utilityTypes/camelCase.d.ts
|
|
6
|
+
//#region src/application/models/utilityTypes/camelCase.d.ts
|
|
7
|
+
/**
|
|
8
|
+
* CamelCase options.
|
|
9
|
+
*
|
|
10
|
+
* @see {@link CamelCase}
|
|
11
|
+
*/
|
|
12
|
+
type CamelCaseOptions = {
|
|
13
|
+
/**
|
|
14
|
+
* Whether to preserved consecutive uppercase letter.
|
|
15
|
+
*
|
|
16
|
+
* @default true
|
|
17
|
+
*/
|
|
18
|
+
preserveConsecutiveUppercase?: boolean;
|
|
19
|
+
};
|
|
20
|
+
/**
|
|
21
|
+
* Convert an array of words to camel-case.
|
|
22
|
+
*/
|
|
23
|
+
type CamelCaseFromArray<Words extends string[], Options extends CamelCaseOptions, OutputString extends string = ''> = Words extends [infer FirstWord extends string, ...infer RemainingWords extends string[]] ? Options['preserveConsecutiveUppercase'] extends true ? `${Capitalize<FirstWord>}${CamelCaseFromArray<RemainingWords, Options>}` : `${Capitalize<Lowercase<FirstWord>>}${CamelCaseFromArray<RemainingWords, Options>}` : OutputString;
|
|
24
|
+
/**
|
|
25
|
+
* Convert a string literal to camel-case.
|
|
26
|
+
*
|
|
27
|
+
* This can be useful when, for example, converting some kebab-cased command-line flags or a snake-cased database result.
|
|
28
|
+
*
|
|
29
|
+
* By default, consecutive uppercase letter are preserved. See {@link CamelCaseOptions.preserveConsecutiveUppercase preserveConsecutiveUppercase} option to change this behaviour.
|
|
30
|
+
*
|
|
31
|
+
* @example
|
|
32
|
+
* ```
|
|
33
|
+
* import type {CamelCase} from 'type-fest';
|
|
34
|
+
*
|
|
35
|
+
* // Simple
|
|
36
|
+
*
|
|
37
|
+
* const someVariable: CamelCase<'foo-bar'> = 'fooBar';
|
|
38
|
+
*
|
|
39
|
+
* // Advanced
|
|
40
|
+
*
|
|
41
|
+
* type CamelCasedProperties<T> = {
|
|
42
|
+
* [K in keyof T as CamelCase<K>]: T[K]
|
|
43
|
+
* };
|
|
44
|
+
*
|
|
45
|
+
* interface RawOptions {
|
|
46
|
+
* 'dry-run': boolean;
|
|
47
|
+
* 'full_family_name': string;
|
|
48
|
+
* foo: number;
|
|
49
|
+
* BAR: string;
|
|
50
|
+
* QUZ_QUX: number;
|
|
51
|
+
* 'OTHER-FIELD': boolean;
|
|
52
|
+
* }
|
|
53
|
+
*
|
|
54
|
+
* const dbResult: CamelCasedProperties<RawOptions> = {
|
|
55
|
+
* dryRun: true,
|
|
56
|
+
* fullFamilyName: 'bar.js',
|
|
57
|
+
* foo: 123,
|
|
58
|
+
* bar: 'foo',
|
|
59
|
+
* quzQux: 6,
|
|
60
|
+
* otherField: false
|
|
61
|
+
* };
|
|
62
|
+
* ```
|
|
63
|
+
*
|
|
64
|
+
* @category Change case
|
|
65
|
+
* @category Template literal
|
|
66
|
+
*/
|
|
67
|
+
type CamelCase<Type, Options extends CamelCaseOptions = {
|
|
68
|
+
preserveConsecutiveUppercase: true;
|
|
69
|
+
}> = Type extends string ? string extends Type ? Type : Uncapitalize<CamelCaseFromArray<SplitWords<Type extends Uppercase<Type> ? Lowercase<Type> : Type>, Options>> : Type;
|
|
70
|
+
//#endregion
|
|
71
|
+
//#endregion
|
|
72
|
+
//#endregion
|
|
73
|
+
export { CamelCase, CamelCaseOptions };
|
|
@@ -0,0 +1,61 @@
|
|
|
1
|
+
import { CamelCase, CamelCaseOptions } from "./camelCase.js";
|
|
2
|
+
import { UnknownArray } from "./unknownArray.js";
|
|
3
|
+
|
|
4
|
+
//#region ../widgets/dist/packages/hooks/dist/application/models/utilityTypes/camelCasedPropertiesDeep.d.ts
|
|
5
|
+
|
|
6
|
+
//#region ../hooks/dist/application/models/utilityTypes/camelCasedPropertiesDeep.d.ts
|
|
7
|
+
//#region src/application/models/utilityTypes/camelCasedPropertiesDeep.d.ts
|
|
8
|
+
/**
|
|
9
|
+
* Convert object properties to camel case recursively.
|
|
10
|
+
*
|
|
11
|
+
* This can be useful when, for example, converting some API types from a different style.
|
|
12
|
+
*
|
|
13
|
+
* @see CamelCasedProperties
|
|
14
|
+
* @see CamelCase
|
|
15
|
+
*
|
|
16
|
+
* @example
|
|
17
|
+
* ```
|
|
18
|
+
* import type {CamelCasedPropertiesDeep} from 'type-fest';
|
|
19
|
+
*
|
|
20
|
+
* interface User {
|
|
21
|
+
* UserId: number;
|
|
22
|
+
* UserName: string;
|
|
23
|
+
* }
|
|
24
|
+
*
|
|
25
|
+
* interface UserWithFriends {
|
|
26
|
+
* UserInfo: User;
|
|
27
|
+
* UserFriends: User[];
|
|
28
|
+
* }
|
|
29
|
+
*
|
|
30
|
+
* const result: CamelCasedPropertiesDeep<UserWithFriends> = {
|
|
31
|
+
* userInfo: {
|
|
32
|
+
* userId: 1,
|
|
33
|
+
* userName: 'Tom',
|
|
34
|
+
* },
|
|
35
|
+
* userFriends: [
|
|
36
|
+
* {
|
|
37
|
+
* userId: 2,
|
|
38
|
+
* userName: 'Jerry',
|
|
39
|
+
* },
|
|
40
|
+
* {
|
|
41
|
+
* userId: 3,
|
|
42
|
+
* userName: 'Spike',
|
|
43
|
+
* },
|
|
44
|
+
* ],
|
|
45
|
+
* };
|
|
46
|
+
* ```
|
|
47
|
+
*
|
|
48
|
+
* @category Change case
|
|
49
|
+
* @category Template literal
|
|
50
|
+
* @category Object
|
|
51
|
+
*/
|
|
52
|
+
type CamelCasedPropertiesDeep<Value, Options extends CamelCaseOptions = {
|
|
53
|
+
preserveConsecutiveUppercase: true;
|
|
54
|
+
}> = Value extends Function ? Value : Value extends UnknownArray ? CamelCasedPropertiesArrayDeep<Value> : Value extends Set<infer U> ? Set<CamelCasedPropertiesDeep<U, Options>> : { [K in keyof Value as CamelCase<K, Options>]: CamelCasedPropertiesDeep<Value[K], Options> };
|
|
55
|
+
type CamelCasedPropertiesArrayDeep<Value extends UnknownArray> = Value extends [] ? [] : Value extends [infer U, ...infer V] ? [CamelCasedPropertiesDeep<U>, ...CamelCasedPropertiesDeep<V>] : Value extends readonly [infer U, ...infer V] ? readonly [CamelCasedPropertiesDeep<U>, ...CamelCasedPropertiesDeep<V>] : Value extends readonly [...infer U, infer V] ? [...CamelCasedPropertiesDeep<U>, CamelCasedPropertiesDeep<V>] : Value extends readonly [...infer U, infer V] ? readonly [...CamelCasedPropertiesDeep<U>, CamelCasedPropertiesDeep<V>] : Value extends Array<infer U> ? Array<CamelCasedPropertiesDeep<U>> : Value extends ReadonlyArray<infer U> ? ReadonlyArray<CamelCasedPropertiesDeep<U>> : never;
|
|
56
|
+
//#endregion
|
|
57
|
+
|
|
58
|
+
//#endregion
|
|
59
|
+
|
|
60
|
+
//#endregion
|
|
61
|
+
export { CamelCasedPropertiesDeep };
|
package/dist/packages/widgets/dist/packages/hooks/dist/application/models/utilityTypes/internal.d.ts
ADDED
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
import { Trim } from "./trim.js";
|
|
2
|
+
|
|
3
|
+
//#region ../widgets/dist/packages/hooks/dist/application/models/utilityTypes/internal.d.ts
|
|
4
|
+
|
|
5
|
+
//#region ../hooks/dist/application/models/utilityTypes/internal.d.ts
|
|
6
|
+
/**
|
|
7
|
+
* Returns a boolean for whether the string is numeric.
|
|
8
|
+
*
|
|
9
|
+
* This type is a workaround for [Microsoft/TypeScript#46109](https://github.com/microsoft/TypeScript/issues/46109#issuecomment-930307987).
|
|
10
|
+
*/
|
|
11
|
+
type IsNumeric<T extends string> = T extends `${number}` ? Trim<T> extends T ? true : false : false;
|
|
12
|
+
/**
|
|
13
|
+
* Returns a boolean for whether the string is lowercased.
|
|
14
|
+
*/
|
|
15
|
+
type IsLowerCase<T extends string> = T extends Lowercase<T> ? true : false;
|
|
16
|
+
/**
|
|
17
|
+
* Returns a boolean for whether the string is upper-cased.
|
|
18
|
+
*/
|
|
19
|
+
type IsUpperCase<T extends string> = T extends Uppercase<T> ? true : false;
|
|
20
|
+
type WordSeparators = '-' | '_' | Whitespace;
|
|
21
|
+
type Whitespace = '\u{9}' | '\u{A}' | '\u{B}' | '\u{C}' | '\u{D}' | '\u{20}' | '\u{85}' | '\u{A0}' | '\u{1680}' | '\u{2000}' | '\u{2001}' | '\u{2002}' | '\u{2003}' | '\u{2004}' | '\u{2005}' | '\u{2006}' | '\u{2007}' | '\u{2008}' | '\u{2009}' | '\u{200A}' | '\u{2028}' | '\u{2029}' | '\u{202F}' | '\u{205F}' | '\u{3000}' | '\u{FEFF}';
|
|
22
|
+
//#endregion
|
|
23
|
+
|
|
24
|
+
//#endregion
|
|
25
|
+
export { IsLowerCase, IsNumeric, IsUpperCase, Whitespace, WordSeparators };
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
import { IsLowerCase, IsNumeric, IsUpperCase, WordSeparators } from "./internal.js";
|
|
2
|
+
|
|
3
|
+
//#region ../widgets/dist/packages/hooks/dist/application/models/utilityTypes/splitWords.d.ts
|
|
4
|
+
|
|
5
|
+
//#region ../hooks/dist/application/models/utilityTypes/splitWords.d.ts
|
|
6
|
+
//#region src/application/models/utilityTypes/splitWords.d.ts
|
|
7
|
+
type SkipEmptyWord<Word extends string> = Word extends '' ? [] : [Word];
|
|
8
|
+
type RemoveLastCharacter<Sentence extends string, Character extends string> = Sentence extends `${infer LeftSide}${Character}` ? SkipEmptyWord<LeftSide> : never;
|
|
9
|
+
/**
|
|
10
|
+
* Split a string (almost) like Lodash's `_.words()` function.
|
|
11
|
+
*
|
|
12
|
+
* - Split on each word that begins with a capital letter.
|
|
13
|
+
* - Split on each {@link WordSeparators}.
|
|
14
|
+
* - Split on numeric sequence.
|
|
15
|
+
*
|
|
16
|
+
* @example
|
|
17
|
+
* ```
|
|
18
|
+
* type Words0 = SplitWords<'helloWorld'>; // ['hello', 'World']
|
|
19
|
+
* type Words1 = SplitWords<'helloWORLD'>; // ['hello', 'WORLD']
|
|
20
|
+
* type Words2 = SplitWords<'hello-world'>; // ['hello', 'world']
|
|
21
|
+
* type Words3 = SplitWords<'--hello the_world'>; // ['hello', 'the', 'world']
|
|
22
|
+
* type Words4 = SplitWords<'lifeIs42'>; // ['life', 'Is', '42']
|
|
23
|
+
* ```
|
|
24
|
+
*
|
|
25
|
+
* @internal
|
|
26
|
+
* @category Change case
|
|
27
|
+
* @category Template literal
|
|
28
|
+
*/
|
|
29
|
+
type SplitWords<Sentence extends string, LastCharacter extends string = '', CurrentWord extends string = ''> = Sentence extends `${infer FirstCharacter}${infer RemainingCharacters}` ? FirstCharacter extends WordSeparators ? [...SkipEmptyWord<CurrentWord>, ...SplitWords<RemainingCharacters>] : LastCharacter extends '' ? SplitWords<RemainingCharacters, FirstCharacter, FirstCharacter> : [false, true] extends [IsNumeric<LastCharacter>, IsNumeric<FirstCharacter>] ? [...SkipEmptyWord<CurrentWord>, ...SplitWords<RemainingCharacters, FirstCharacter, FirstCharacter>] : [true, false] extends [IsNumeric<LastCharacter>, IsNumeric<FirstCharacter>] ? [...SkipEmptyWord<CurrentWord>, ...SplitWords<RemainingCharacters, FirstCharacter, FirstCharacter>] : [true, true] extends [IsNumeric<LastCharacter>, IsNumeric<FirstCharacter>] ? SplitWords<RemainingCharacters, FirstCharacter, `${CurrentWord}${FirstCharacter}`> : [true, true] extends [IsLowerCase<LastCharacter>, IsUpperCase<FirstCharacter>] ? [...SkipEmptyWord<CurrentWord>, ...SplitWords<RemainingCharacters, FirstCharacter, FirstCharacter>] : [true, true] extends [IsUpperCase<LastCharacter>, IsLowerCase<FirstCharacter>] ? [...RemoveLastCharacter<CurrentWord, LastCharacter>, ...SplitWords<RemainingCharacters, FirstCharacter, `${LastCharacter}${FirstCharacter}`>] : SplitWords<RemainingCharacters, FirstCharacter, `${CurrentWord}${FirstCharacter}`> : [...SkipEmptyWord<CurrentWord>];
|
|
30
|
+
//#endregion
|
|
31
|
+
|
|
32
|
+
//#endregion
|
|
33
|
+
|
|
34
|
+
//#endregion
|
|
35
|
+
export { SplitWords };
|
package/dist/packages/widgets/dist/packages/hooks/dist/application/models/utilityTypes/trim.d.ts
ADDED
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
import { Whitespace } from "./internal.js";
|
|
2
|
+
|
|
3
|
+
//#region ../widgets/dist/packages/hooks/dist/application/models/utilityTypes/trim.d.ts
|
|
4
|
+
|
|
5
|
+
//#region ../hooks/dist/application/models/utilityTypes/trim.d.ts
|
|
6
|
+
//#region src/application/models/utilityTypes/trim.d.ts
|
|
7
|
+
/**
|
|
8
|
+
* Remove spaces from the left side.
|
|
9
|
+
*/
|
|
10
|
+
type TrimLeft<V extends string> = V extends `${Whitespace}${infer R}` ? TrimLeft<R> : V;
|
|
11
|
+
/**
|
|
12
|
+
* Remove spaces from the right side.
|
|
13
|
+
*/
|
|
14
|
+
type TrimRight<V extends string> = V extends `${infer R}${Whitespace}` ? TrimRight<R> : V;
|
|
15
|
+
/**
|
|
16
|
+
* Remove leading and trailing spaces from a string.
|
|
17
|
+
* @example
|
|
18
|
+
* ```
|
|
19
|
+
* import type {Trim} from 'type-fest';
|
|
20
|
+
*
|
|
21
|
+
* Trim<' foo '>
|
|
22
|
+
* //=> 'foo'
|
|
23
|
+
* ```
|
|
24
|
+
*
|
|
25
|
+
* @category String
|
|
26
|
+
* @category Template literal
|
|
27
|
+
*/
|
|
28
|
+
type Trim<V extends string> = TrimLeft<TrimRight<V>>;
|
|
29
|
+
//#endregion
|
|
30
|
+
//#endregion
|
|
31
|
+
//#endregion
|
|
32
|
+
export { Trim };
|