Merge pull request #16767 from calixteman/color_storage

Add the color changes in the annotation storage
This commit is contained in:
calixteman 2023-07-30 15:17:27 +02:00 committed by GitHub
commit 7bdd3491b0
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
4 changed files with 57 additions and 12 deletions

View File

@ -331,9 +331,13 @@ class AnnotationElement {
get _commonActions() { get _commonActions() {
const setColor = (jsName, styleName, event) => { const setColor = (jsName, styleName, event) => {
const color = event.detail[jsName]; const color = event.detail[jsName];
event.target.style[styleName] = ColorConverters[`${color[0]}_HTML`]( const colorType = color[0];
color.slice(1) const colorArray = color.slice(1);
); event.target.style[styleName] =
ColorConverters[`${colorType}_HTML`](colorArray);
this.annotationStorage.setValue(this.data.id, {
[styleName]: ColorConverters[`${colorType}_rgb`](colorArray),
});
}; };
return shadow(this, "_commonActions", { return shadow(this, "_commonActions", {

View File

@ -26,6 +26,10 @@ function makeColorComp(n) {
.padStart(2, "0"); .padStart(2, "0");
} }
function scaleAndClamp(x) {
return Math.max(0, Math.min(255, 255 * x));
}
// PDF specifications section 10.3 // PDF specifications section 10.3
class ColorConverters { class ColorConverters {
static CMYK_G([c, y, m, k]) { static CMYK_G([c, y, m, k]) {
@ -40,6 +44,11 @@ class ColorConverters {
return ["RGB", g, g, g]; return ["RGB", g, g, g];
} }
static G_rgb([g]) {
g = scaleAndClamp(g);
return [g, g, g];
}
static G_HTML([g]) { static G_HTML([g]) {
const G = makeColorComp(g); const G = makeColorComp(g);
return `#${G}${G}${G}`; return `#${G}${G}${G}`;
@ -49,17 +58,22 @@ class ColorConverters {
return ["G", 0.3 * r + 0.59 * g + 0.11 * b]; return ["G", 0.3 * r + 0.59 * g + 0.11 * b];
} }
static RGB_HTML([r, g, b]) { static RGB_rgb(color) {
const R = makeColorComp(r); return color.map(scaleAndClamp);
const G = makeColorComp(g); }
const B = makeColorComp(b);
return `#${R}${G}${B}`; static RGB_HTML(color) {
return `#${color.map(makeColorComp).join("")}`;
} }
static T_HTML() { static T_HTML() {
return "#00000000"; return "#00000000";
} }
static T_rgb() {
return [null];
}
static CMYK_RGB([c, y, m, k]) { static CMYK_RGB([c, y, m, k]) {
return [ return [
"RGB", "RGB",
@ -69,6 +83,14 @@ class ColorConverters {
]; ];
} }
static CMYK_rgb([c, y, m, k]) {
return [
scaleAndClamp(1 - Math.min(1, c + k)),
scaleAndClamp(1 - Math.min(1, m + k)),
scaleAndClamp(1 - Math.min(1, y + k)),
];
}
static CMYK_HTML(components) { static CMYK_HTML(components) {
const rgb = this.CMYK_RGB(components).slice(1); const rgb = this.CMYK_RGB(components).slice(1);
return this.RGB_HTML(rgb); return this.RGB_HTML(rgb);

View File

@ -20,6 +20,7 @@ const {
getQuerySelector, getQuerySelector,
getComputedStyleSelector, getComputedStyleSelector,
loadAndWait, loadAndWait,
getFirstSerialized,
} = require("./test_utils.js"); } = require("./test_utils.js");
describe("Interaction", () => { describe("Interaction", () => {
@ -751,10 +752,22 @@ describe("Interaction", () => {
delay: 10, delay: 10,
}); });
for (const [id, propName, expected] of [ for (const [id, propName, storedName, expected, storedExpected] of [
[41, "backgroundColor", "rgb(255, 0, 0)"], [
[43, "color", "rgb(0, 255, 0)"], 41,
[44, "border-top-color", "rgb(0, 0, 255)"], "backgroundColor",
"backgroundColor",
"rgb(255, 0, 0)",
[255, 0, 0],
],
[43, "color", "color", "rgb(0, 255, 0)", [0, 255, 0]],
[
44,
"border-top-color",
"borderColor",
"rgb(0, 0, 255)",
[0, 0, 255],
],
]) { ]) {
const current = await page.$eval( const current = await page.$eval(
getSelector(ref), getSelector(ref),
@ -775,6 +788,11 @@ describe("Interaction", () => {
propName propName
); );
expect(color).withContext(`In ${browserName}`).toEqual(expected); expect(color).withContext(`In ${browserName}`).toEqual(expected);
const storedValue = (await getFirstSerialized(page))[storedName];
expect(storedValue)
.withContext(`In ${browserName}`)
.toEqual(storedExpected);
} }
} }
}) })

View File

@ -63,6 +63,7 @@ exports.clearInput = async (page, selector) => {
await page.keyboard.press("A"); await page.keyboard.press("A");
await page.keyboard.up("Control"); await page.keyboard.up("Control");
await page.keyboard.press("Backspace"); await page.keyboard.press("Backspace");
await page.waitForTimeout(10);
}; };
function getSelector(id) { function getSelector(id) {