-
Notifications
You must be signed in to change notification settings - Fork 43
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #6 from washingtonpost/integration
Renaming target.position for old creatives
- Loading branch information
Showing
9 changed files
with
11,981 additions
and
96 deletions.
There are no files selected for viewing
Large diffs are not rendered by default.
Oops, something went wrong.
Large diffs are not rendered by default.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,19 @@ | ||
import { renamePositionKey } from '../util/customTargeting'; | ||
|
||
describe('The CustomTargeting.js functions', () => { | ||
it('should take targeting and position value, and rename the key as posn', () => { | ||
const targeting = { | ||
position: { | ||
as: 'posn' | ||
} | ||
}; | ||
|
||
const positionValue = 2; | ||
const updatedTargeting = renamePositionKey(targeting, positionValue); | ||
const newTargeting = { | ||
posn: positionValue | ||
}; | ||
|
||
expect(updatedTargeting).toEqual(newTargeting); | ||
}); | ||
}); |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,14 @@ | ||
/** | ||
* @desc If a different key is required to serve position targeting for older creatives, rename it here. | ||
* @param {object} targeting - Targeting object passed in from the ad object. | ||
* @param {number} positionValue - The nth number of adType included. | ||
* @return - Returns the targeting object with the old position value stripped out, and the new one with the desired key in its place. | ||
**/ | ||
export function renamePositionKey(targeting, positionValue) { | ||
const newTargetingObject = targeting; | ||
const keyName = targeting.position.as; | ||
delete newTargetingObject.position; | ||
newTargetingObject[keyName] = positionValue; | ||
Object.assign(targeting, newTargetingObject); | ||
return targeting; | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,41 @@ | ||
import Promise from 'promise-polyfill'; | ||
|
||
if (!window.Promise) { | ||
window.Promise = Promise; | ||
} | ||
|
||
/* eslint-disable */ | ||
|
||
// source: https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Object/assign#Polyfill | ||
/* Object.assign() for IE11 (obviously) */ | ||
if (typeof Object.assign != 'function') { | ||
// Must be writable: true, enumerable: false, configurable: true | ||
Object.defineProperty(Object, "assign", { | ||
value: function assign(target, varArgs) { // .length of function is 2 | ||
'use strict'; | ||
if (target == null) { // TypeError if undefined or null | ||
throw new TypeError('Cannot convert undefined or null to object'); | ||
} | ||
|
||
var to = Object(target); | ||
|
||
for (var index = 1; index < arguments.length; index++) { | ||
var nextSource = arguments[index]; | ||
|
||
if (nextSource != null) { // Skip over if undefined or null | ||
for (var nextKey in nextSource) { | ||
// Avoid bugs when hasOwnProperty is shadowed | ||
if (Object.prototype.hasOwnProperty.call(nextSource, nextKey)) { | ||
to[nextKey] = nextSource[nextKey]; | ||
} | ||
} | ||
} | ||
} | ||
return to; | ||
}, | ||
writable: true, | ||
configurable: true | ||
}); | ||
} | ||
|
||
/* eslint-enable */ |
Oops, something went wrong.