Promises resolving in different order than added

I am creating a PDF with jsPDF. In the code I have some loops, where I create promises to add images to the document.
Now I want to add a new page in between the other promises if certain conditions are met. But the page is always added before every other promise. Here is my code:

var docPromises = [];

for (var i = 0; i < usedMonths.length; i++){

  if(checkColumnPage(startPos)){
    var addPagePromise = new Promise((resolve, reject) => {
      doc.addPage();
      resolve();
    });
    docPromises.push(addPagePromise);
  }



  var imgSourceMonth = eval("img_months_" + currentMonth);

  (function(imgSrc, position) {
    var clonedStartPos = position.slice();

    var addImagePromiseMonth = calculateImageWidth(imgSrc, 20)
      .then(function(width) {
        doc.addImage(imgSrc, 'PNG', clonedStartPos[0], clonedStartPos[1], width, 20);
      })
      .catch(function(error) {
        console.error(error);
      });

    docPromises.push(addImagePromiseMonth);
  })(imgSourceMonth, startPos);

}

checkColumnPage(startPos) returns true if a new page has to be added and false if not.

I resolve the promises like this:
Promise.all(docPromises)

The second part in the loop works perfectly. The order of the image is correct.

I logged every promise action to the console and it appeared that the page was always added first, followed by every other promise.
I can’t figure out the problem… In my mind it should work like this:

Iteration 1 (checkColumnPage = false): add image promise
Iteration 2 (checkColumnPage = false): add image promise
Iteration 3 (checkColumnPage = true): add page promise, add image promise
Iteration 4 (checkColumnPage = false): add image promise

But the page always comes first. Can anyone help me with this problem? Thanks in advance.