mirror of
https://github.com/discourse/discourse.git
synced 2025-02-21 03:19:10 +00:00
FIX: improve regex used for image sizing controls (#8291)
This commit is contained in:
parent
5502128105
commit
8e419a772f
@ -836,7 +836,11 @@ export default Component.extend({
|
||||
return;
|
||||
}
|
||||
|
||||
const replacement = match.replace(imageScaleRegex, `$1,${scale}%$3`);
|
||||
const replacement = match.replace(
|
||||
imageScaleRegex,
|
||||
`data:image/s3,"s3://crabby-images/9cef0/9cef039dc3b348824deba101ecf068ee33976195" alt="$1|$2, ${scale}%"`
|
||||
);
|
||||
|
||||
this.appEvents.trigger(
|
||||
"composer:replace-text",
|
||||
matchingPlaceholder[index],
|
||||
@ -851,11 +855,18 @@ export default Component.extend({
|
||||
// regex matches only upload placeholders with size defined,
|
||||
// which is required for resizing
|
||||
|
||||
// original string `data:image/s3,"s3://crabby-images/80995/809959fd70e09941afa9d6d742fce27f1a1c980d" alt="28|690x226,5%"`
|
||||
// match 1 `data:image/s3,"s3://crabby-images/80995/809959fd70e09941afa9d6d742fce27f1a1c980d" alt="28|690x226`
|
||||
// match 2 `5`
|
||||
// match 3 `"`
|
||||
const imageScaleRegex = /(!\[(?:\S*?(?=\|)\|)*?(?:\d{1,6}x\d{1,6})+?)(?:,?(\d{1,3})?%?)?(\]\(upload:\/\/\S*?\))/g;
|
||||
// original string `data:image/s3,"s3://crabby-images/74f4e/74f4ea54d4d4ba701f130b2ca2f5d0d0c9dc60ad" alt="image|690x220, 50%"`
|
||||
// group 1 `image`
|
||||
// group 2 `690x220`
|
||||
// group 3 `, 50%`
|
||||
// group 4 'upload://1TjaobgKObzpU7xRMw2HuUc87vO.png'
|
||||
// group 4 'upload://1TjaobgKObzpU7xRMw2HuUc87vO.png "image title"'
|
||||
|
||||
// Notes:
|
||||
// Group 3 is optional. group 4 can match images with or without a markdown title.
|
||||
// All matches are whitespace tolerant as long it's still valid markdown
|
||||
|
||||
const imageScaleRegex = /!\[(.*?)\|(\d{1,4}x\d{1,4})(,\s*\d{1,3}%)?\]\((upload:\/\/.*?)\)/g;
|
||||
|
||||
// wraps previewed upload markdown in a codeblock in its own class to keep a track
|
||||
// of indexes later on to replace the correct upload placeholder in the composer
|
||||
|
@ -721,49 +721,68 @@ QUnit.test("Image resizing buttons", async assert => {
|
||||
await click("#create-topic");
|
||||
|
||||
let uploads = [
|
||||
// 0 Default markdown with dimensions- should work
|
||||
"data:image/s3,"s3://crabby-images/12720/12720f39685eb20d7e871189cea9ec129d01567f" alt="test|690x313"",
|
||||
"[img]http://example.com/image.jpg[/img]",
|
||||
"data:image/s3,"s3://crabby-images/ce532/ce53203e7a5a063f8a3781e75a0747d8840c0058" alt="anotherOne|690x463"",
|
||||
"data:image/s3,"s3://crabby-images/7d12e/7d12eefd78e9f91fe702d438b850c735ef093d08" alt=""",
|
||||
// 1 Image with scaling percentage, should work
|
||||
"data:image/s3,"s3://crabby-images/12720/12720f39685eb20d7e871189cea9ec129d01567f" alt="test|690x313,50%"",
|
||||
// 2 image with scaling percentage and a proceeding whitespace, should work
|
||||
"data:image/s3,"s3://crabby-images/12720/12720f39685eb20d7e871189cea9ec129d01567f" alt="test|690x313, 50%"",
|
||||
// 3 No dimensions, should not work
|
||||
"data:image/s3,"s3://crabby-images/ce960/ce96072c79223d92142ce107862650bf874dcbd1" alt="test"",
|
||||
// 4 Wrapped in backquetes should not work
|
||||
"`data:image/s3,"s3://crabby-images/12720/12720f39685eb20d7e871189cea9ec129d01567f" alt="test|690x313"`",
|
||||
"data:image/s3,"s3://crabby-images/82d7e/82d7ed5586b6f7f579b5fb7cf7990293bc94f717" alt="withoutSize"",
|
||||
// 5 html image - should not work
|
||||
"<img src='http://someimage.jpg' wight='20' height='20'>",
|
||||
// 6 two images one the same line, but both are syntactically correct - both should work
|
||||
"data:image/s3,"s3://crabby-images/61bf3/61bf3350a82c64c852c328a071f9e8299a615dd6" alt="onTheSameLine1|200x200" data:image/s3,"s3://crabby-images/66a45/66a45c6c2ec32498d0394b8039cbed2e9ee48929" alt="onTheSameLine2|250x250"",
|
||||
// 7 & 8 Identical images - both should work
|
||||
"data:image/s3,"s3://crabby-images/72bf0/72bf0e008384f64b7d44d2c0ffebf1c89b6a4db1" alt="identicalImage|300x300"",
|
||||
"data:image/s3,"s3://crabby-images/72bf0/72bf0e008384f64b7d44d2c0ffebf1c89b6a4db1" alt="identicalImage|300x300""
|
||||
"data:image/s3,"s3://crabby-images/72bf0/72bf0e008384f64b7d44d2c0ffebf1c89b6a4db1" alt="identicalImage|300x300"",
|
||||
// 9 Image with whitespaces in alt - should work
|
||||
"data:image/s3,"s3://crabby-images/12720/12720f39685eb20d7e871189cea9ec129d01567f" alt="image with spaces in alt|690x220"",
|
||||
// 10 Image with markdown title - should work
|
||||
`data:image/s3,"s3://crabby-images/cf414/cf414571584cea1a595defa001fd573149a1bfef" alt="image|690x220"`,
|
||||
// 11 bbcode - should not work
|
||||
"[img]http://example.com/image.jpg[/img]"
|
||||
];
|
||||
|
||||
await fillIn(".d-editor-input", uploads.join("\n"));
|
||||
|
||||
assert.ok(
|
||||
find(".button-wrapper").length === 6,
|
||||
find(".button-wrapper").length === 9,
|
||||
"it adds correct amount of scaling button groups"
|
||||
);
|
||||
|
||||
uploads[0] = "data:image/s3,"s3://crabby-images/12720/12720f39685eb20d7e871189cea9ec129d01567f" alt="test|690x313,50%"";
|
||||
// Default
|
||||
uploads[0] = "data:image/s3,"s3://crabby-images/12720/12720f39685eb20d7e871189cea9ec129d01567f" alt="test|690x313, 50%"";
|
||||
await click(find(".button-wrapper .scale-btn[data-scale='50']")[0]);
|
||||
assertImageResized(assert, uploads);
|
||||
|
||||
uploads[2] = "data:image/s3,"s3://crabby-images/ce532/ce53203e7a5a063f8a3781e75a0747d8840c0058" alt="anotherOne|690x463,75%"";
|
||||
await click(find(".button-wrapper .scale-btn[data-scale='75']")[1]);
|
||||
// Targets the correct image if two on the same line
|
||||
uploads[6] =
|
||||
"data:image/s3,"s3://crabby-images/61bf3/61bf3350a82c64c852c328a071f9e8299a615dd6" alt="onTheSameLine1|200x200, 50%" data:image/s3,"s3://crabby-images/66a45/66a45c6c2ec32498d0394b8039cbed2e9ee48929" alt="onTheSameLine2|250x250"";
|
||||
await click(find(".button-wrapper .scale-btn[data-scale='50']")[3]);
|
||||
assertImageResized(assert, uploads);
|
||||
|
||||
uploads[7] =
|
||||
"data:image/s3,"s3://crabby-images/61bf3/61bf3350a82c64c852c328a071f9e8299a615dd6" alt="onTheSameLine1|200x200,50%" data:image/s3,"s3://crabby-images/66a45/66a45c6c2ec32498d0394b8039cbed2e9ee48929" alt="onTheSameLine2|250x250"";
|
||||
await click(find(".button-wrapper .scale-btn[data-scale='50']")[2]);
|
||||
// Try the other image on the same line
|
||||
uploads[6] =
|
||||
"data:image/s3,"s3://crabby-images/61bf3/61bf3350a82c64c852c328a071f9e8299a615dd6" alt="onTheSameLine1|200x200, 50%" data:image/s3,"s3://crabby-images/66a45/66a45c6c2ec32498d0394b8039cbed2e9ee48929" alt="onTheSameLine2|250x250, 75%"";
|
||||
await click(find(".button-wrapper .scale-btn[data-scale='75']")[4]);
|
||||
assertImageResized(assert, uploads);
|
||||
|
||||
uploads[7] =
|
||||
"data:image/s3,"s3://crabby-images/61bf3/61bf3350a82c64c852c328a071f9e8299a615dd6" alt="onTheSameLine1|200x200,50%" data:image/s3,"s3://crabby-images/66a45/66a45c6c2ec32498d0394b8039cbed2e9ee48929" alt="onTheSameLine2|250x250,75%"";
|
||||
await click(find(".button-wrapper .scale-btn[data-scale='75']")[3]);
|
||||
// Make sure we target the correct image if there are duplicates
|
||||
uploads[7] = "data:image/s3,"s3://crabby-images/72bf0/72bf0e008384f64b7d44d2c0ffebf1c89b6a4db1" alt="identicalImage|300x300, 50%"";
|
||||
await click(find(".button-wrapper .scale-btn[data-scale='50']")[5]);
|
||||
assertImageResized(assert, uploads);
|
||||
|
||||
uploads[8] = "data:image/s3,"s3://crabby-images/72bf0/72bf0e008384f64b7d44d2c0ffebf1c89b6a4db1" alt="identicalImage|300x300,50%"";
|
||||
await click(find(".button-wrapper .scale-btn[data-scale='50']")[4]);
|
||||
// Try the other dupe
|
||||
uploads[8] = "data:image/s3,"s3://crabby-images/72bf0/72bf0e008384f64b7d44d2c0ffebf1c89b6a4db1" alt="identicalImage|300x300, 75%"";
|
||||
await click(find(".button-wrapper .scale-btn[data-scale='75']")[6]);
|
||||
assertImageResized(assert, uploads);
|
||||
|
||||
uploads[9] = "data:image/s3,"s3://crabby-images/72bf0/72bf0e008384f64b7d44d2c0ffebf1c89b6a4db1" alt="identicalImage|300x300,75%"";
|
||||
await click(find(".button-wrapper .scale-btn[data-scale='75']")[5]);
|
||||
// Don't mess with image titles
|
||||
uploads[10] = `data:image/s3,"s3://crabby-images/cf414/cf414571584cea1a595defa001fd573149a1bfef" alt="image|690x220, 75%"`;
|
||||
await click(find(".button-wrapper .scale-btn[data-scale='75']")[8]);
|
||||
assertImageResized(assert, uploads);
|
||||
|
||||
await fillIn(
|
||||
|
Loading…
x
Reference in New Issue
Block a user