@uniformdev/context 20.6.1-alpha.0 → 20.6.2-alpha.10
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/api/api.d.mts +1 -1
- package/dist/api/api.d.ts +1 -1
- package/dist/index.d.mts +33 -4
- package/dist/index.d.ts +33 -4
- package/dist/index.esm.js +211 -39
- package/dist/index.js +216 -40
- package/dist/index.mjs +211 -39
- package/dist/{types-EJl31yuP.d.mts → types-CzIkFCDD.d.mts} +96 -24
- package/dist/{types-EJl31yuP.d.ts → types-CzIkFCDD.d.ts} +96 -24
- package/package.json +2 -2
package/dist/api/api.d.mts
CHANGED
package/dist/api/api.d.ts
CHANGED
package/dist/index.d.mts
CHANGED
@@ -1,5 +1,5 @@
|
|
1
|
-
import { O as OutputSeverity, L as LogDrain, C as ContextPlugin, S as ScoreVector, A as AggregateDimension, T as TransitionDataStore, a as StorageCommands, V as VisitorData, Q as Quirks, b as TransitionDataStoreOptions, D as DecayFunction, c as CriteriaEvaluator, d as StringMatch, e as VariantMatchCriteria, f as LogMessage, g as DevToolsEvents } from './types-
|
2
|
-
export {
|
1
|
+
import { O as OutputSeverity, L as LogDrain, C as ContextPlugin, S as ScoreVector, A as AggregateDimension, T as TransitionDataStore, a as StorageCommands, V as VisitorData, Q as Quirks, b as TransitionDataStoreOptions, D as DecayFunction, c as CriteriaEvaluator, d as StringMatch, e as VariantMatchCriteria, f as LogMessage, P as PersonalizedVariant, g as PersonalizeOptions, h as Context, i as PersonalizedResult, j as VariationMatchDimensionCriteria, k as PersonalizationSelectionAlgorithmOptions, l as DevToolsEvents } from './types-CzIkFCDD.mjs';
|
2
|
+
export { a7 as AggregateDimensionInput, ad as BehaviorTag, m as CONTEXTUAL_EDITING_TEST_NAME, n as CONTEXTUAL_EDITING_TEST_SELECTED_VARIANT_ID, u as ContextEvents, v as ContextInstance, q as ContextOptions, aF as ContextState, aG as ContextStateUpdate, Z as CriteriaEvaluatorParameters, Y as CriteriaEvaluatorResult, au as DecayOptions, y as DevToolsActions, E as DevToolsDataEvent, z as DevToolsEvent, I as DevToolsForgetEvent, F as DevToolsHelloEvent, B as DevToolsLogEvent, H as DevToolsRawCommandsEvent, x as DevToolsState, w as DevToolsUiVersion, G as DevToolsUpdateEvent, ab as DimensionMatch, a4 as EnrichmentCategory, aA as EnrichmentData, aD as EventData, aH as GoalStateUpdate, az as Goals, X as GroupCriteriaEvaluator, an as IdentifyCommand, U as LogMessageGroup, R as LogMessageSingle, J as LogMessages, W as ManifestInstance, $ as ManifestV2, M as MessageCategory, N as MessageFunc, ai as ModifyScoreCommand, aj as ModifySessionScoreCommand, a5 as NumberMatch, s as PersonalizationEvent, r as PersonalizationEventVariantId, a0 as PersonalizationManifest, o as PersonalizationSelectionAlgorithm, p as PersonalizationSelectionAlgorithms, aB as PersonalizeControlVariant, aC as PersonalizeVariants, ac as QuirkMatch, as as SERVER_STATE_ID, ar as ServerToClientTransitionState, ak as SetConsentCommand, ao as SetControlGroupCommand, ah as SetGoalCommand, ap as SetPersonalizeVariantControlCommand, al as SetQuirkCommand, am as SetTestCommand, K as Severity, a1 as Signal, a3 as SignalCriteria, a2 as SignalCriteriaGroup, _ as SignalData, ag as StorageCommand, a6 as TestDefinition, t as TestEvent, a8 as TestOptions, af as TestResult, ae as TestVariant, ay as Tests, at as TransitionDataStoreEvents, aa as VariationMatchMetadata, ax as VisitorDataStore, aw as VisitorDataStoreEvents, av as VisitorDataStoreOptions, aq as areCommandsEqual, aE as emptyVisitorData, a9 as testVariations } from './types-CzIkFCDD.mjs';
|
3
3
|
import Cookies from 'js-cookie';
|
4
4
|
import 'mitt';
|
5
5
|
|
@@ -158,7 +158,35 @@ declare function createDebugConsoleLogDrain(level: OutputSeverity, options?: Con
|
|
158
158
|
*/
|
159
159
|
declare function enableDebugConsoleLogDrain(level: OutputSeverity, options?: ConsoleDebugLogDrainOptions): ContextPlugin;
|
160
160
|
|
161
|
-
declare function evaluateVariantMatch(variantId: string, match: VariantMatchCriteria | undefined | null, vec: ScoreVector, onLogMessage?: (message: LogMessage) => void): boolean;
|
161
|
+
declare function evaluateVariantMatch(variantId: string, match: VariantMatchCriteria | undefined | null, vec: ScoreVector, onLogMessage?: (message: LogMessage) => void, quirks?: Quirks): boolean;
|
162
|
+
|
163
|
+
/**
|
164
|
+
* @deprecated Use `topDownCriteriaPersonalizationSelectionAlgorithm` instead
|
165
|
+
*/
|
166
|
+
declare function personalizeVariations<TVariant extends PersonalizedVariant<VariantMatchCriteria>>(options: PersonalizeOptions<TVariant> & {
|
167
|
+
context: Context;
|
168
|
+
}): PersonalizedResult<TVariant>;
|
169
|
+
|
170
|
+
declare const STRONGEST_SCORE_PERSONALIZATION_ALGORITHM = "ssc";
|
171
|
+
/**
|
172
|
+
* Implementation of the strongest score personalization selection algorithm.
|
173
|
+
*
|
174
|
+
* In this mode, we take all variations and break them into two groups:
|
175
|
+
* 1. Variations that have a positive score for their tagged dimension
|
176
|
+
* 2. Variations that do not have a dimension tag
|
177
|
+
*
|
178
|
+
* We then sort the first group by score, concatenate the second group, and return the top <take> variations.
|
179
|
+
*/
|
180
|
+
declare function strongestScorePersonalizationSelectionAlgorithm<TCriteria extends VariationMatchDimensionCriteria, TVariation extends PersonalizedVariant<TCriteria>>({ name, context, variations, take, onLogMessage, }: PersonalizationSelectionAlgorithmOptions<TCriteria, TVariation>): PersonalizedResult<TVariation>;
|
181
|
+
|
182
|
+
declare const TOP_DOWN_CRITERIA_PERSONALIZATION_ALGORITHM = "default";
|
183
|
+
/**
|
184
|
+
* Implementation of the top-down criteria personalization selection algorithm.
|
185
|
+
*
|
186
|
+
* In this mode, we evaluate variations in the order they are declared and the first <take>
|
187
|
+
* variations whose criteria evaluate to true are selected.
|
188
|
+
*/
|
189
|
+
declare function topDownCriteriaPersonalizationSelectionAlgorithm<TCriteria extends VariantMatchCriteria, TVariation extends PersonalizedVariant<TCriteria>>({ name, context, variations, take, onLogMessage, }: PersonalizationSelectionAlgorithmOptions<TCriteria, TVariation>): PersonalizedResult<TVariation>;
|
162
190
|
|
163
191
|
type ContextDevToolOptions = {
|
164
192
|
onAfterMessageReceived?: (message: DevToolsEvents) => void;
|
@@ -183,6 +211,7 @@ declare enum ScriptType {
|
|
183
211
|
type EdgePersonalizeComponentOptions = {
|
184
212
|
name: string;
|
185
213
|
count?: number;
|
214
|
+
algorithm?: string;
|
186
215
|
};
|
187
216
|
type EdgeTestComponentOptions = {
|
188
217
|
name: string;
|
@@ -213,4 +242,4 @@ type QuickConnectConfig = {
|
|
213
242
|
declare function serializeQuickConnect(config: QuickConnectConfig): string;
|
214
243
|
declare function parseQuickConnect(serialized: string): Required<QuickConnectConfig>;
|
215
244
|
|
216
|
-
export { AggregateDimension, type ConsoleDebugLogDrainOptions, type ContextDevToolOptions, ContextPlugin, CookieTransitionDataStore, type CookieTransitionDataStoreOptions, CriteriaEvaluator, DecayFunction, DevToolsEvents, ENR_SEPARATOR, EdgeNodeTagName, type EdgePersonalizeComponentOptions, type EdgeTestComponentOptions, EdgeTransitionDataStore, type EdgeTransitionDataStoreOptions, type EnableUniformInsightsOptions, KV_SEP, type LinearDecayOptions, LogDrain, LogMessage, OutputSeverity, PAIR_SEP, QUIRK_SEP, type QuickConnectConfig, Quirks, ScoreVector, ScriptType, StorageCommands, StringMatch, TYPE_SEP, TransitionDataStore, TransitionDataStoreOptions, UNIFORM_DEFAULT_COOKIE_NAME, UNIFORM_DEFAULT_QUIRK_COOKIE_NAME, VariantMatchCriteria, VisitorData, computeAggregateDimensions, cookieEvaluator, createConsoleLogDrain, createDebugConsoleLogDrain, createLinearDecay, currentPageEvaluator, decodeCookieType, decodePersonalizeVariants, enableConsoleLogDrain, enableContextDevTools, enableDebugConsoleLogDrain, enableUniformInsights, encodeCookieType, evaluateVariantMatch, eventEvaluator, explainStringMatch, explainStringMatchCriteria, getEnrichmentVectorKey, isStringMatch, pageViewCountDimension, pageViewCountEvaluator, parseCookieScores, parseCookieType, parseQuickConnect, parseQuirkCookie, parseScoreCookie, queryStringEvaluator, quirkEvaluator, serializeCookie, serializeCookieType, serializePersonalizeVariants, serializeQuickConnect, serializeQuirks };
|
245
|
+
export { AggregateDimension, type ConsoleDebugLogDrainOptions, Context, type ContextDevToolOptions, ContextPlugin, CookieTransitionDataStore, type CookieTransitionDataStoreOptions, CriteriaEvaluator, DecayFunction, DevToolsEvents, ENR_SEPARATOR, EdgeNodeTagName, type EdgePersonalizeComponentOptions, type EdgeTestComponentOptions, EdgeTransitionDataStore, type EdgeTransitionDataStoreOptions, type EnableUniformInsightsOptions, KV_SEP, type LinearDecayOptions, LogDrain, LogMessage, OutputSeverity, PAIR_SEP, PersonalizationSelectionAlgorithmOptions, PersonalizeOptions, PersonalizedResult, PersonalizedVariant, QUIRK_SEP, type QuickConnectConfig, Quirks, STRONGEST_SCORE_PERSONALIZATION_ALGORITHM, ScoreVector, ScriptType, StorageCommands, StringMatch, TOP_DOWN_CRITERIA_PERSONALIZATION_ALGORITHM, TYPE_SEP, TransitionDataStore, TransitionDataStoreOptions, UNIFORM_DEFAULT_COOKIE_NAME, UNIFORM_DEFAULT_QUIRK_COOKIE_NAME, VariantMatchCriteria, VariationMatchDimensionCriteria, VisitorData, computeAggregateDimensions, cookieEvaluator, createConsoleLogDrain, createDebugConsoleLogDrain, createLinearDecay, currentPageEvaluator, decodeCookieType, decodePersonalizeVariants, enableConsoleLogDrain, enableContextDevTools, enableDebugConsoleLogDrain, enableUniformInsights, encodeCookieType, evaluateVariantMatch, eventEvaluator, explainStringMatch, explainStringMatchCriteria, getEnrichmentVectorKey, isStringMatch, pageViewCountDimension, pageViewCountEvaluator, parseCookieScores, parseCookieType, parseQuickConnect, parseQuirkCookie, parseScoreCookie, personalizeVariations, queryStringEvaluator, quirkEvaluator, serializeCookie, serializeCookieType, serializePersonalizeVariants, serializeQuickConnect, serializeQuirks, strongestScorePersonalizationSelectionAlgorithm, topDownCriteriaPersonalizationSelectionAlgorithm };
|
package/dist/index.d.ts
CHANGED
@@ -1,5 +1,5 @@
|
|
1
|
-
import { O as OutputSeverity, L as LogDrain, C as ContextPlugin, S as ScoreVector, A as AggregateDimension, T as TransitionDataStore, a as StorageCommands, V as VisitorData, Q as Quirks, b as TransitionDataStoreOptions, D as DecayFunction, c as CriteriaEvaluator, d as StringMatch, e as VariantMatchCriteria, f as LogMessage, g as DevToolsEvents } from './types-
|
2
|
-
export {
|
1
|
+
import { O as OutputSeverity, L as LogDrain, C as ContextPlugin, S as ScoreVector, A as AggregateDimension, T as TransitionDataStore, a as StorageCommands, V as VisitorData, Q as Quirks, b as TransitionDataStoreOptions, D as DecayFunction, c as CriteriaEvaluator, d as StringMatch, e as VariantMatchCriteria, f as LogMessage, P as PersonalizedVariant, g as PersonalizeOptions, h as Context, i as PersonalizedResult, j as VariationMatchDimensionCriteria, k as PersonalizationSelectionAlgorithmOptions, l as DevToolsEvents } from './types-CzIkFCDD.js';
|
2
|
+
export { a7 as AggregateDimensionInput, ad as BehaviorTag, m as CONTEXTUAL_EDITING_TEST_NAME, n as CONTEXTUAL_EDITING_TEST_SELECTED_VARIANT_ID, u as ContextEvents, v as ContextInstance, q as ContextOptions, aF as ContextState, aG as ContextStateUpdate, Z as CriteriaEvaluatorParameters, Y as CriteriaEvaluatorResult, au as DecayOptions, y as DevToolsActions, E as DevToolsDataEvent, z as DevToolsEvent, I as DevToolsForgetEvent, F as DevToolsHelloEvent, B as DevToolsLogEvent, H as DevToolsRawCommandsEvent, x as DevToolsState, w as DevToolsUiVersion, G as DevToolsUpdateEvent, ab as DimensionMatch, a4 as EnrichmentCategory, aA as EnrichmentData, aD as EventData, aH as GoalStateUpdate, az as Goals, X as GroupCriteriaEvaluator, an as IdentifyCommand, U as LogMessageGroup, R as LogMessageSingle, J as LogMessages, W as ManifestInstance, $ as ManifestV2, M as MessageCategory, N as MessageFunc, ai as ModifyScoreCommand, aj as ModifySessionScoreCommand, a5 as NumberMatch, s as PersonalizationEvent, r as PersonalizationEventVariantId, a0 as PersonalizationManifest, o as PersonalizationSelectionAlgorithm, p as PersonalizationSelectionAlgorithms, aB as PersonalizeControlVariant, aC as PersonalizeVariants, ac as QuirkMatch, as as SERVER_STATE_ID, ar as ServerToClientTransitionState, ak as SetConsentCommand, ao as SetControlGroupCommand, ah as SetGoalCommand, ap as SetPersonalizeVariantControlCommand, al as SetQuirkCommand, am as SetTestCommand, K as Severity, a1 as Signal, a3 as SignalCriteria, a2 as SignalCriteriaGroup, _ as SignalData, ag as StorageCommand, a6 as TestDefinition, t as TestEvent, a8 as TestOptions, af as TestResult, ae as TestVariant, ay as Tests, at as TransitionDataStoreEvents, aa as VariationMatchMetadata, ax as VisitorDataStore, aw as VisitorDataStoreEvents, av as VisitorDataStoreOptions, aq as areCommandsEqual, aE as emptyVisitorData, a9 as testVariations } from './types-CzIkFCDD.js';
|
3
3
|
import Cookies from 'js-cookie';
|
4
4
|
import 'mitt';
|
5
5
|
|
@@ -158,7 +158,35 @@ declare function createDebugConsoleLogDrain(level: OutputSeverity, options?: Con
|
|
158
158
|
*/
|
159
159
|
declare function enableDebugConsoleLogDrain(level: OutputSeverity, options?: ConsoleDebugLogDrainOptions): ContextPlugin;
|
160
160
|
|
161
|
-
declare function evaluateVariantMatch(variantId: string, match: VariantMatchCriteria | undefined | null, vec: ScoreVector, onLogMessage?: (message: LogMessage) => void): boolean;
|
161
|
+
declare function evaluateVariantMatch(variantId: string, match: VariantMatchCriteria | undefined | null, vec: ScoreVector, onLogMessage?: (message: LogMessage) => void, quirks?: Quirks): boolean;
|
162
|
+
|
163
|
+
/**
|
164
|
+
* @deprecated Use `topDownCriteriaPersonalizationSelectionAlgorithm` instead
|
165
|
+
*/
|
166
|
+
declare function personalizeVariations<TVariant extends PersonalizedVariant<VariantMatchCriteria>>(options: PersonalizeOptions<TVariant> & {
|
167
|
+
context: Context;
|
168
|
+
}): PersonalizedResult<TVariant>;
|
169
|
+
|
170
|
+
declare const STRONGEST_SCORE_PERSONALIZATION_ALGORITHM = "ssc";
|
171
|
+
/**
|
172
|
+
* Implementation of the strongest score personalization selection algorithm.
|
173
|
+
*
|
174
|
+
* In this mode, we take all variations and break them into two groups:
|
175
|
+
* 1. Variations that have a positive score for their tagged dimension
|
176
|
+
* 2. Variations that do not have a dimension tag
|
177
|
+
*
|
178
|
+
* We then sort the first group by score, concatenate the second group, and return the top <take> variations.
|
179
|
+
*/
|
180
|
+
declare function strongestScorePersonalizationSelectionAlgorithm<TCriteria extends VariationMatchDimensionCriteria, TVariation extends PersonalizedVariant<TCriteria>>({ name, context, variations, take, onLogMessage, }: PersonalizationSelectionAlgorithmOptions<TCriteria, TVariation>): PersonalizedResult<TVariation>;
|
181
|
+
|
182
|
+
declare const TOP_DOWN_CRITERIA_PERSONALIZATION_ALGORITHM = "default";
|
183
|
+
/**
|
184
|
+
* Implementation of the top-down criteria personalization selection algorithm.
|
185
|
+
*
|
186
|
+
* In this mode, we evaluate variations in the order they are declared and the first <take>
|
187
|
+
* variations whose criteria evaluate to true are selected.
|
188
|
+
*/
|
189
|
+
declare function topDownCriteriaPersonalizationSelectionAlgorithm<TCriteria extends VariantMatchCriteria, TVariation extends PersonalizedVariant<TCriteria>>({ name, context, variations, take, onLogMessage, }: PersonalizationSelectionAlgorithmOptions<TCriteria, TVariation>): PersonalizedResult<TVariation>;
|
162
190
|
|
163
191
|
type ContextDevToolOptions = {
|
164
192
|
onAfterMessageReceived?: (message: DevToolsEvents) => void;
|
@@ -183,6 +211,7 @@ declare enum ScriptType {
|
|
183
211
|
type EdgePersonalizeComponentOptions = {
|
184
212
|
name: string;
|
185
213
|
count?: number;
|
214
|
+
algorithm?: string;
|
186
215
|
};
|
187
216
|
type EdgeTestComponentOptions = {
|
188
217
|
name: string;
|
@@ -213,4 +242,4 @@ type QuickConnectConfig = {
|
|
213
242
|
declare function serializeQuickConnect(config: QuickConnectConfig): string;
|
214
243
|
declare function parseQuickConnect(serialized: string): Required<QuickConnectConfig>;
|
215
244
|
|
216
|
-
export { AggregateDimension, type ConsoleDebugLogDrainOptions, type ContextDevToolOptions, ContextPlugin, CookieTransitionDataStore, type CookieTransitionDataStoreOptions, CriteriaEvaluator, DecayFunction, DevToolsEvents, ENR_SEPARATOR, EdgeNodeTagName, type EdgePersonalizeComponentOptions, type EdgeTestComponentOptions, EdgeTransitionDataStore, type EdgeTransitionDataStoreOptions, type EnableUniformInsightsOptions, KV_SEP, type LinearDecayOptions, LogDrain, LogMessage, OutputSeverity, PAIR_SEP, QUIRK_SEP, type QuickConnectConfig, Quirks, ScoreVector, ScriptType, StorageCommands, StringMatch, TYPE_SEP, TransitionDataStore, TransitionDataStoreOptions, UNIFORM_DEFAULT_COOKIE_NAME, UNIFORM_DEFAULT_QUIRK_COOKIE_NAME, VariantMatchCriteria, VisitorData, computeAggregateDimensions, cookieEvaluator, createConsoleLogDrain, createDebugConsoleLogDrain, createLinearDecay, currentPageEvaluator, decodeCookieType, decodePersonalizeVariants, enableConsoleLogDrain, enableContextDevTools, enableDebugConsoleLogDrain, enableUniformInsights, encodeCookieType, evaluateVariantMatch, eventEvaluator, explainStringMatch, explainStringMatchCriteria, getEnrichmentVectorKey, isStringMatch, pageViewCountDimension, pageViewCountEvaluator, parseCookieScores, parseCookieType, parseQuickConnect, parseQuirkCookie, parseScoreCookie, queryStringEvaluator, quirkEvaluator, serializeCookie, serializeCookieType, serializePersonalizeVariants, serializeQuickConnect, serializeQuirks };
|
245
|
+
export { AggregateDimension, type ConsoleDebugLogDrainOptions, Context, type ContextDevToolOptions, ContextPlugin, CookieTransitionDataStore, type CookieTransitionDataStoreOptions, CriteriaEvaluator, DecayFunction, DevToolsEvents, ENR_SEPARATOR, EdgeNodeTagName, type EdgePersonalizeComponentOptions, type EdgeTestComponentOptions, EdgeTransitionDataStore, type EdgeTransitionDataStoreOptions, type EnableUniformInsightsOptions, KV_SEP, type LinearDecayOptions, LogDrain, LogMessage, OutputSeverity, PAIR_SEP, PersonalizationSelectionAlgorithmOptions, PersonalizeOptions, PersonalizedResult, PersonalizedVariant, QUIRK_SEP, type QuickConnectConfig, Quirks, STRONGEST_SCORE_PERSONALIZATION_ALGORITHM, ScoreVector, ScriptType, StorageCommands, StringMatch, TOP_DOWN_CRITERIA_PERSONALIZATION_ALGORITHM, TYPE_SEP, TransitionDataStore, TransitionDataStoreOptions, UNIFORM_DEFAULT_COOKIE_NAME, UNIFORM_DEFAULT_QUIRK_COOKIE_NAME, VariantMatchCriteria, VariationMatchDimensionCriteria, VisitorData, computeAggregateDimensions, cookieEvaluator, createConsoleLogDrain, createDebugConsoleLogDrain, createLinearDecay, currentPageEvaluator, decodeCookieType, decodePersonalizeVariants, enableConsoleLogDrain, enableContextDevTools, enableDebugConsoleLogDrain, enableUniformInsights, encodeCookieType, evaluateVariantMatch, eventEvaluator, explainStringMatch, explainStringMatchCriteria, getEnrichmentVectorKey, isStringMatch, pageViewCountDimension, pageViewCountEvaluator, parseCookieScores, parseCookieType, parseQuickConnect, parseQuirkCookie, parseScoreCookie, personalizeVariations, queryStringEvaluator, quirkEvaluator, serializeCookie, serializeCookieType, serializePersonalizeVariants, serializeQuickConnect, serializeQuirks, strongestScorePersonalizationSelectionAlgorithm, topDownCriteriaPersonalizationSelectionAlgorithm };
|
package/dist/index.esm.js
CHANGED
@@ -516,7 +516,7 @@ var GroupCriteriaEvaluator = class {
|
|
516
516
|
_evaluators = new WeakMap();
|
517
517
|
|
518
518
|
// src/placement/criteria/evaluateVariantMatch.ts
|
519
|
-
function evaluateVariantMatch(variantId, match, vec, onLogMessage) {
|
519
|
+
function evaluateVariantMatch(variantId, match, vec, onLogMessage, quirks) {
|
520
520
|
onLogMessage == null ? void 0 : onLogMessage(["info", 301, "GROUP", { id: variantId, op: match == null ? void 0 : match.op }]);
|
521
521
|
let result;
|
522
522
|
try {
|
@@ -524,9 +524,9 @@ function evaluateVariantMatch(variantId, match, vec, onLogMessage) {
|
|
524
524
|
onLogMessage == null ? void 0 : onLogMessage(["info", 302, { matched: true, description: "default variation" }]);
|
525
525
|
result = true;
|
526
526
|
} else if (!match.op || match.op === "&") {
|
527
|
-
result = match.crit.every((c) =>
|
527
|
+
result = match.crit.every((c) => evaluateMatch(c, vec, quirks != null ? quirks : {}, onLogMessage));
|
528
528
|
} else {
|
529
|
-
result = match.crit.some((c) =>
|
529
|
+
result = match.crit.some((c) => evaluateMatch(c, vec, quirks != null ? quirks : {}, onLogMessage));
|
530
530
|
}
|
531
531
|
onLogMessage == null ? void 0 : onLogMessage(["info", 303, result]);
|
532
532
|
} finally {
|
@@ -534,9 +534,16 @@ function evaluateVariantMatch(variantId, match, vec, onLogMessage) {
|
|
534
534
|
}
|
535
535
|
return result;
|
536
536
|
}
|
537
|
+
function evaluateMatch(crit, vec, quirks, onLogMessage) {
|
538
|
+
if ("t" in crit && crit.t === "q") {
|
539
|
+
return evaluateQuirkMatch(crit, quirks, onLogMessage);
|
540
|
+
} else {
|
541
|
+
return evaluateDimensionMatch(crit, vec, onLogMessage);
|
542
|
+
}
|
543
|
+
}
|
537
544
|
function evaluateDimensionMatch(crit, vec, onLogMessage) {
|
538
545
|
var _a, _b;
|
539
|
-
const {
|
546
|
+
const { l: lhs, op } = crit;
|
540
547
|
const lhsScore = (_a = vec[lhs]) != null ? _a : 0;
|
541
548
|
if (op === "^") {
|
542
549
|
const [cat] = lhs.split(ENR_SEPARATOR);
|
@@ -603,33 +610,65 @@ function evaluateDimensionMatch(crit, vec, onLogMessage) {
|
|
603
610
|
}
|
604
611
|
if (op === ">") {
|
605
612
|
const result = lhsScore > rhsScore;
|
606
|
-
|
613
|
+
explainScore(onLogMessage, result, crit, lhsScore, rhsScore);
|
607
614
|
return result;
|
608
615
|
} else if (op === ">=") {
|
609
616
|
const result = lhsScore >= rhsScore;
|
610
|
-
|
617
|
+
explainScore(onLogMessage, result, crit, lhsScore, rhsScore);
|
611
618
|
return result;
|
612
619
|
} else if (op === "<") {
|
613
620
|
const result = lhsScore < rhsScore;
|
614
|
-
|
621
|
+
explainScore(onLogMessage, result, crit, lhsScore, rhsScore);
|
615
622
|
return result;
|
616
623
|
} else if (op === "<=") {
|
617
624
|
const result = lhsScore <= rhsScore;
|
618
|
-
|
625
|
+
explainScore(onLogMessage, result, crit, lhsScore, rhsScore);
|
619
626
|
return result;
|
620
627
|
} else if (op === "=") {
|
621
628
|
const result = lhsScore === rhsScore;
|
622
|
-
|
629
|
+
explainScore(onLogMessage, result, crit, lhsScore, rhsScore);
|
623
630
|
return result;
|
624
631
|
} else if (op === "!=") {
|
625
632
|
const result = lhsScore !== rhsScore;
|
626
|
-
|
633
|
+
explainScore(onLogMessage, result, crit, lhsScore, rhsScore);
|
627
634
|
return result;
|
628
635
|
} else {
|
629
|
-
|
636
|
+
onLogMessage == null ? void 0 : onLogMessage([
|
637
|
+
"error",
|
638
|
+
302,
|
639
|
+
{
|
640
|
+
matched: false,
|
641
|
+
description: `${crit.l} ${crit.op} ${crit.rDim ? `${crit.rDim}` : crit.r}: Unknown op ${crit.op}.`
|
642
|
+
}
|
643
|
+
]);
|
644
|
+
return false;
|
645
|
+
}
|
646
|
+
}
|
647
|
+
function evaluateQuirkMatch(crit, quirks, onLogMessage) {
|
648
|
+
var _a;
|
649
|
+
const { l: targetQuirk, op, r: targetValue } = crit;
|
650
|
+
const targetQuirkValue = (_a = quirks[targetQuirk]) != null ? _a : "";
|
651
|
+
if (op === "=") {
|
652
|
+
const result = targetQuirkValue === targetValue;
|
653
|
+
explainQuirk(onLogMessage, result, crit, targetQuirkValue);
|
654
|
+
return result;
|
655
|
+
} else if (op === "!=") {
|
656
|
+
const result = targetQuirkValue !== targetValue;
|
657
|
+
explainQuirk(onLogMessage, result, crit, targetQuirkValue);
|
658
|
+
return result;
|
659
|
+
} else {
|
660
|
+
onLogMessage == null ? void 0 : onLogMessage([
|
661
|
+
"error",
|
662
|
+
302,
|
663
|
+
{
|
664
|
+
matched: false,
|
665
|
+
description: `Quirk ${crit.l} ${crit.op} ${crit.r}: Unknown quirk op ${crit.op}.`
|
666
|
+
}
|
667
|
+
]);
|
668
|
+
return false;
|
630
669
|
}
|
631
670
|
}
|
632
|
-
function
|
671
|
+
function explainScore(onLogMessage, result, crit, lhsScore, rhsScore) {
|
633
672
|
onLogMessage == null ? void 0 : onLogMessage([
|
634
673
|
"info",
|
635
674
|
302,
|
@@ -639,9 +678,20 @@ function explain(onLogMessage, result, crit, lhsScore, rhsScore) {
|
|
639
678
|
}
|
640
679
|
]);
|
641
680
|
}
|
681
|
+
function explainQuirk(onLogMessage, result, crit, lhs) {
|
682
|
+
onLogMessage == null ? void 0 : onLogMessage([
|
683
|
+
"info",
|
684
|
+
302,
|
685
|
+
{
|
686
|
+
matched: result,
|
687
|
+
description: `Quirk ${crit.l}[${lhs}] ${crit.op} ${crit.r}`
|
688
|
+
}
|
689
|
+
]);
|
690
|
+
}
|
642
691
|
|
643
|
-
// src/placement/
|
644
|
-
|
692
|
+
// src/placement/topDownCriteriaPersonalizationSelectionAlgorithm.ts
|
693
|
+
var TOP_DOWN_CRITERIA_PERSONALIZATION_ALGORITHM = "default";
|
694
|
+
function topDownCriteriaPersonalizationSelectionAlgorithm({
|
645
695
|
name,
|
646
696
|
context,
|
647
697
|
variations,
|
@@ -651,27 +701,34 @@ function personalizeVariations({
|
|
651
701
|
var _a, _b, _c;
|
652
702
|
onLogMessage == null ? void 0 : onLogMessage(["info", 300, "GROUP", { name, take }]);
|
653
703
|
try {
|
654
|
-
const
|
655
|
-
const
|
656
|
-
const
|
657
|
-
const
|
658
|
-
for (const
|
659
|
-
|
660
|
-
|
661
|
-
|
704
|
+
const variationMatches = [];
|
705
|
+
const defaultVariations = [];
|
706
|
+
const needsConsentToPersonalize = context.requireConsentForPersonalization;
|
707
|
+
const personalizationAllowed = !needsConsentToPersonalize || context.storage.data.consent;
|
708
|
+
for (const variation of variations) {
|
709
|
+
const isInvalidFormat = variation.pz && (typeof variation.pz !== "object" || variation.pz === null || !("crit" in variation.pz && Array.isArray(variation.pz.crit)));
|
710
|
+
let validVariation;
|
711
|
+
if (isInvalidFormat) {
|
712
|
+
validVariation = { id: variation.id };
|
713
|
+
} else {
|
714
|
+
validVariation = variation;
|
715
|
+
}
|
716
|
+
if ((_a = validVariation.pz) == null ? void 0 : _a.crit.length) {
|
717
|
+
if (personalizationAllowed && variationMatches.length !== take && evaluateVariantMatch(variation.id, validVariation.pz, context.scores, onLogMessage, context.quirks)) {
|
718
|
+
variationMatches.push(validVariation);
|
662
719
|
}
|
663
720
|
} else {
|
664
|
-
|
721
|
+
defaultVariations.push(validVariation);
|
665
722
|
}
|
666
723
|
}
|
667
724
|
const result = [];
|
668
|
-
for (let i = 0; i <
|
725
|
+
for (let i = 0; i < variationMatches.length; i++) {
|
669
726
|
let isControl = (_b = context.storage.data.controlGroup) != null ? _b : false;
|
670
|
-
const
|
671
|
-
if (!isControl && typeof ((_c =
|
727
|
+
const variation = variationMatches[i];
|
728
|
+
if (!isControl && typeof ((_c = variation.pz) == null ? void 0 : _c.control) === "number") {
|
672
729
|
isControl = context.getPersonalizeVariantControl(name, i);
|
673
730
|
if (typeof isControl === "undefined") {
|
674
|
-
isControl = rollForControlGroup(
|
731
|
+
isControl = rollForControlGroup(variation.pz.control);
|
675
732
|
context.storage.updateData([
|
676
733
|
{
|
677
734
|
type: "setpersonalizecontrol",
|
@@ -684,13 +741,13 @@ function personalizeVariations({
|
|
684
741
|
]);
|
685
742
|
}
|
686
743
|
}
|
687
|
-
let variantToAdd =
|
744
|
+
let variantToAdd = variation;
|
688
745
|
if (isControl) {
|
689
|
-
const defaultReplacement =
|
746
|
+
const defaultReplacement = defaultVariations.shift();
|
690
747
|
if (defaultReplacement) {
|
691
748
|
variantToAdd = {
|
692
749
|
...defaultReplacement,
|
693
|
-
id:
|
750
|
+
id: variation.id
|
694
751
|
};
|
695
752
|
} else {
|
696
753
|
variantToAdd = void 0;
|
@@ -700,8 +757,8 @@ function personalizeVariations({
|
|
700
757
|
result.push({ ...variantToAdd, control: isControl });
|
701
758
|
}
|
702
759
|
}
|
703
|
-
while (result.length < take &&
|
704
|
-
result.push({ ...
|
760
|
+
while (result.length < take && defaultVariations.length) {
|
761
|
+
result.push({ ...defaultVariations.shift(), control: false });
|
705
762
|
}
|
706
763
|
const personalized = result.some((v) => {
|
707
764
|
var _a2;
|
@@ -716,7 +773,82 @@ function personalizeVariations({
|
|
716
773
|
}
|
717
774
|
}
|
718
775
|
|
719
|
-
// src/placement/
|
776
|
+
// src/placement/personalizeVariations.ts
|
777
|
+
function personalizeVariations(options) {
|
778
|
+
return topDownCriteriaPersonalizationSelectionAlgorithm(options);
|
779
|
+
}
|
780
|
+
|
781
|
+
// src/placement/strongestScorePersonalizationSelectionAlgorithm.ts
|
782
|
+
var STRONGEST_SCORE_PERSONALIZATION_ALGORITHM = "ssc";
|
783
|
+
function strongestScorePersonalizationSelectionAlgorithm({
|
784
|
+
name,
|
785
|
+
context,
|
786
|
+
variations,
|
787
|
+
take = 1,
|
788
|
+
onLogMessage
|
789
|
+
}) {
|
790
|
+
var _a, _b;
|
791
|
+
onLogMessage == null ? void 0 : onLogMessage(["info", 300, "GROUP", { name, take }]);
|
792
|
+
try {
|
793
|
+
const variationMatches = [];
|
794
|
+
const defaultVariations = [];
|
795
|
+
const needsConsentToPersonalize = context.requireConsentForPersonalization;
|
796
|
+
const isInGlobalControlGroup = (_a = context.storage.data.controlGroup) != null ? _a : false;
|
797
|
+
const personalizationAllowed = !needsConsentToPersonalize || context.storage.data.consent;
|
798
|
+
for (const variation of variations) {
|
799
|
+
const isInvalidFormat = variation.pz && (typeof variation.pz !== "object" || variation.pz === null);
|
800
|
+
let validVariation;
|
801
|
+
if (isInvalidFormat) {
|
802
|
+
validVariation = { id: variation.id };
|
803
|
+
} else {
|
804
|
+
validVariation = variation;
|
805
|
+
}
|
806
|
+
if ((_b = validVariation.pz) == null ? void 0 : _b.dim) {
|
807
|
+
if (!personalizationAllowed) {
|
808
|
+
continue;
|
809
|
+
}
|
810
|
+
const score = context.scores[validVariation.pz.dim];
|
811
|
+
if (score === void 0 || score <= 0) {
|
812
|
+
continue;
|
813
|
+
}
|
814
|
+
variationMatches.push({ variation: validVariation, score });
|
815
|
+
} else {
|
816
|
+
defaultVariations.push(validVariation);
|
817
|
+
}
|
818
|
+
}
|
819
|
+
variationMatches.sort((a, b) => b.score - a.score);
|
820
|
+
const result = [];
|
821
|
+
for (let i = 0; i < variationMatches.length; i++) {
|
822
|
+
const variationMatch = variationMatches[i];
|
823
|
+
let variantToAdd = variationMatch.variation;
|
824
|
+
if (isInGlobalControlGroup) {
|
825
|
+
const defaultReplacement = defaultVariations.shift();
|
826
|
+
if (defaultReplacement) {
|
827
|
+
variantToAdd = {
|
828
|
+
...defaultReplacement,
|
829
|
+
id: variationMatch.variation.id
|
830
|
+
};
|
831
|
+
} else {
|
832
|
+
variantToAdd = void 0;
|
833
|
+
}
|
834
|
+
}
|
835
|
+
if (variantToAdd) {
|
836
|
+
result.push({ ...variantToAdd, control: isInGlobalControlGroup });
|
837
|
+
}
|
838
|
+
}
|
839
|
+
while (result.length < take && defaultVariations.length) {
|
840
|
+
result.push({ ...defaultVariations.shift(), control: false });
|
841
|
+
}
|
842
|
+
return {
|
843
|
+
personalized: variationMatches.length > 0 && !isInGlobalControlGroup,
|
844
|
+
variations: result
|
845
|
+
};
|
846
|
+
} finally {
|
847
|
+
onLogMessage == null ? void 0 : onLogMessage(["info", 300, "ENDGROUP"]);
|
848
|
+
}
|
849
|
+
}
|
850
|
+
|
851
|
+
// src/placement/normalizeVariationDistributions.ts
|
720
852
|
var normalizeVariationDistributions = (variations) => {
|
721
853
|
const { values, total, missingDistribution } = variations.reduce(
|
722
854
|
(previous, current) => {
|
@@ -735,7 +867,12 @@ var normalizeVariationDistributions = (variations) => {
|
|
735
867
|
}
|
736
868
|
);
|
737
869
|
if (total > 100) {
|
738
|
-
|
870
|
+
const autoScaleFactor = 100 / total;
|
871
|
+
values.forEach((value, index) => {
|
872
|
+
if (typeof value === "number") {
|
873
|
+
values[index] = value * autoScaleFactor;
|
874
|
+
}
|
875
|
+
});
|
739
876
|
} else if (total < 100) {
|
740
877
|
const remainder = 100 - total;
|
741
878
|
const missingSlice = remainder / missingDistribution;
|
@@ -747,6 +884,8 @@ var normalizeVariationDistributions = (variations) => {
|
|
747
884
|
}
|
748
885
|
return values;
|
749
886
|
};
|
887
|
+
|
888
|
+
// src/placement/testVariations.ts
|
750
889
|
var testVariations = ({
|
751
890
|
name,
|
752
891
|
context,
|
@@ -1513,11 +1652,12 @@ import { dequal as dequal5 } from "dequal/lite";
|
|
1513
1652
|
import mitt3 from "mitt";
|
1514
1653
|
var CONTEXTUAL_EDITING_TEST_NAME = "contextual_editing_test";
|
1515
1654
|
var CONTEXTUAL_EDITING_TEST_SELECTED_VARIANT_ID = "contextual_editing_test_selected_variant";
|
1516
|
-
var _serverTransitionState, _scores, _state, _pzCache, _plugins, _commands, _requireConsentForPersonalization, _mitt3, _Context_instances, emitTest_fn, updateGoals_fn, updateComputedScores_fn, calculateScores_fn;
|
1655
|
+
var _personalizationSelectionAlgorithms, _serverTransitionState, _scores, _state, _pzCache, _plugins, _commands, _requireConsentForPersonalization, _mitt3, _Context_instances, emitTest_fn, updateGoals_fn, updateComputedScores_fn, calculateScores_fn;
|
1517
1656
|
var Context = class {
|
1518
1657
|
constructor(options) {
|
1519
1658
|
__privateAdd(this, _Context_instances);
|
1520
1659
|
__publicField(this, "manifest");
|
1660
|
+
__privateAdd(this, _personalizationSelectionAlgorithms);
|
1521
1661
|
__privateAdd(this, _serverTransitionState);
|
1522
1662
|
__privateAdd(this, _scores, {});
|
1523
1663
|
__privateAdd(this, _state);
|
@@ -1534,7 +1674,7 @@ var Context = class {
|
|
1534
1674
|
off: __privateGet(this, _mitt3).off
|
1535
1675
|
});
|
1536
1676
|
__publicField(this, "storage");
|
1537
|
-
var _a, _b;
|
1677
|
+
var _a, _b, _c;
|
1538
1678
|
const { manifest, ...storageOptions } = options;
|
1539
1679
|
__privateSet(this, _state, {});
|
1540
1680
|
__privateSet(this, _plugins, options.plugins);
|
@@ -1542,7 +1682,20 @@ var Context = class {
|
|
1542
1682
|
if (typeof options.transitionStore !== "undefined") {
|
1543
1683
|
__privateSet(this, _commands, []);
|
1544
1684
|
}
|
1685
|
+
__privateSet(this, _personalizationSelectionAlgorithms, {
|
1686
|
+
[TOP_DOWN_CRITERIA_PERSONALIZATION_ALGORITHM]: topDownCriteriaPersonalizationSelectionAlgorithm,
|
1687
|
+
[STRONGEST_SCORE_PERSONALIZATION_ALGORITHM]: strongestScorePersonalizationSelectionAlgorithm
|
1688
|
+
});
|
1545
1689
|
(_a = __privateGet(this, _plugins)) == null ? void 0 : _a.forEach((plugin) => {
|
1690
|
+
if (!plugin.personalizationSelectionAlgorithms) {
|
1691
|
+
return;
|
1692
|
+
}
|
1693
|
+
__privateSet(this, _personalizationSelectionAlgorithms, {
|
1694
|
+
...__privateGet(this, _personalizationSelectionAlgorithms),
|
1695
|
+
...plugin.personalizationSelectionAlgorithms
|
1696
|
+
});
|
1697
|
+
});
|
1698
|
+
(_b = __privateGet(this, _plugins)) == null ? void 0 : _b.forEach((plugin) => {
|
1546
1699
|
if (!plugin.logDrain) {
|
1547
1700
|
return;
|
1548
1701
|
}
|
@@ -1593,7 +1746,7 @@ var Context = class {
|
|
1593
1746
|
__privateGet(this, _mitt3).emit("quirksUpdated", quirks.quirks);
|
1594
1747
|
__privateGet(this, _mitt3).emit("log", ["info", 4, quirks.quirks]);
|
1595
1748
|
});
|
1596
|
-
(
|
1749
|
+
(_c = __privateGet(this, _plugins)) == null ? void 0 : _c.forEach((plugin) => {
|
1597
1750
|
if (!plugin.init) {
|
1598
1751
|
return;
|
1599
1752
|
}
|
@@ -1843,7 +1996,17 @@ var Context = class {
|
|
1843
1996
|
}
|
1844
1997
|
/** Executes a personalized placement with a given set of variants */
|
1845
1998
|
personalize(options) {
|
1846
|
-
|
1999
|
+
var _a;
|
2000
|
+
const algorithmName = (_a = options.algorithm) != null ? _a : TOP_DOWN_CRITERIA_PERSONALIZATION_ALGORITHM;
|
2001
|
+
const algorithm = __privateGet(this, _personalizationSelectionAlgorithms)[algorithmName];
|
2002
|
+
if (!algorithm) {
|
2003
|
+
__privateGet(this, _mitt3).emit("log", ["warn", 304, { algorithm: algorithmName }]);
|
2004
|
+
return {
|
2005
|
+
personalized: false,
|
2006
|
+
variations: []
|
2007
|
+
};
|
2008
|
+
}
|
2009
|
+
const value = algorithm({
|
1847
2010
|
...options,
|
1848
2011
|
context: this,
|
1849
2012
|
onLogMessage: (message) => __privateGet(this, _mitt3).emit("log", message)
|
@@ -1917,6 +2080,7 @@ var Context = class {
|
|
1917
2080
|
__privateGet(this, _mitt3).emit("personalizationResult", event);
|
1918
2081
|
}
|
1919
2082
|
};
|
2083
|
+
_personalizationSelectionAlgorithms = new WeakMap();
|
1920
2084
|
_serverTransitionState = new WeakMap();
|
1921
2085
|
_scores = new WeakMap();
|
1922
2086
|
_state = new WeakMap();
|
@@ -2512,6 +2676,10 @@ var messageContent = {
|
|
2512
2676
|
301: ({ id, op }) => ["personalization", `testing variation ${id} (${op === "|" ? "OR" : "AND"})`],
|
2513
2677
|
302: ({ matched, description }) => ["personalization", `${description} is ${matched}`],
|
2514
2678
|
303: (selected) => ["personalization", selected ? "selected variation" : "did not select variation"],
|
2679
|
+
304: ({ algorithm }) => [
|
2680
|
+
"personalization",
|
2681
|
+
`personalization selection algorithm '${algorithm}' not found. Hiding placement.`
|
2682
|
+
],
|
2515
2683
|
// TESTING
|
2516
2684
|
400: (name) => ["testing", `executing A/B test '${name}'`],
|
2517
2685
|
401: (testName) => ["testing", `${testName} is not registered in the manifest; it will not be run.`],
|
@@ -2616,7 +2784,9 @@ export {
|
|
2616
2784
|
PAIR_SEP,
|
2617
2785
|
QUIRK_SEP,
|
2618
2786
|
SERVER_STATE_ID,
|
2787
|
+
STRONGEST_SCORE_PERSONALIZATION_ALGORITHM,
|
2619
2788
|
ScriptType,
|
2789
|
+
TOP_DOWN_CRITERIA_PERSONALIZATION_ALGORITHM,
|
2620
2790
|
TYPE_SEP,
|
2621
2791
|
TransitionDataStore,
|
2622
2792
|
UNIFORM_DEFAULT_COOKIE_NAME,
|
@@ -2658,5 +2828,7 @@ export {
|
|
2658
2828
|
serializePersonalizeVariants,
|
2659
2829
|
serializeQuickConnect,
|
2660
2830
|
serializeQuirks,
|
2661
|
-
|
2831
|
+
strongestScorePersonalizationSelectionAlgorithm,
|
2832
|
+
testVariations,
|
2833
|
+
topDownCriteriaPersonalizationSelectionAlgorithm
|
2662
2834
|
};
|