Skip to content

Conversation

@rasamassen
Copy link

@rasamassen rasamassen commented Sep 1, 2025

Returns line return instead of paragraph return on textrun, footnote, and endnote.

Description

TextBreak was always creating a new paragraph, even when it should have just been making a line break.

Fixes # (issue)

Checklist:

  • My CI is 🟢
  • I have covered by unit tests my new code (check build/coverage for coverage report)
  • I have updated the documentation to describe the changes
  • I have updated the changelog

Returns line return instead of paragraph return on textrun, footnote, and endnote.
@rasamassen rasamassen changed the title Fix TextBreak.php RTF: Fix TextBreak.php Sep 1, 2025
@coveralls
Copy link

coveralls commented Sep 1, 2025

Coverage Status

coverage: 96.757%. remained the same
when pulling 711945e on rasamassen:TextBreak
into 0ab0b49 on PHPOffice:master.

Copy link
Member

@Progi1984 Progi1984 left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@rasamassen Thank you for your contribution.

Could you add an unit test, please ?

@rasamassen
Copy link
Author

@rasamassen Thank you for your contribution.

Could you add an unit test, please ?

Probably not. I don't program much anymore - it's been a decade or more - and it's been a lot of work to figure out the parts of the RTF writer that weren't working; figuring out how the tests work will be a lot more work I don't have time for. I can give you a sample below that shows the error if you compare the current code to my revisions. Hopefully that helps you create a test.

// Create PhpWord
$phpWord = new PhpOffice\PhpWord\PhpWord();

// Set default settings
$phpWord->setDefaultParagraphStyle(['align' => 'left']);

// Styles
$phpWord->addFontStyle('bold', ['bold' => true]);
$phpWord->addParagraphStyle('center', ['align' => 'center']);

// Build Document
$section = $phpWord->addSection();
$section->addText('The default style.');
$section->addTextBreak();
$textrun = $section->addTextRun('center');
$textrun->addText('This is a single sentence', 'bold');
$textrun->addTextBreak();
$textrun->addText('spread over multiple lines', 'bold');
$textrun->addTextBreak();
$textrun->addText('all centered', 'bold');
$section->addText('A new sentence in the default style.');

In the original code, there was a paragraph break, resulting in the additional lines losing their paragraph styling.

Original Output (lines 2 and 3 are left-align when they should be center; line 4 is center):
\pard\nowidctlpar {The default style.}\par
\pard\par
pard\nowidctlpar \qc{{\b This is a single sentence}\pard\par
{\b spread over multiple lines}\pard\par
{\b all centered}}\par
\pard\nowidctlpar {A new sentence in the default style.}\par

New Output (correct):
\pard\nowidctlpar {The default style.}\par
\pard\par
pard\nowidctlpar \qc{{\b This is a single sentence}\line
{\b spread over multiple lines}\line
{\b all centered}}\par
\pard\nowidctlpar {A new sentence in the default style.}\par

@Progi1984
Copy link
Member

@rasamassen Could you invite me on your repository and I will add unit test for your PRs ? Else I can't merge PR without linked unit tests.

@rasamassen
Copy link
Author

Done

@rasamassen rasamassen changed the title RTF: Fix TextBreak.php RTF Writer: Fix TextBreak.php Sep 4, 2025
@rasamassen rasamassen changed the title RTF Writer: Fix TextBreak.php RTF Writer: Fix TextBreak.php to work for linebreaks Sep 5, 2025
@rasamassen
Copy link
Author

@Progi1984 If you could approve all the various Pull Requests I've made, I'll work on making tests for the RTF Writer, but there's a lot of refactoring work to be done. Right now all the tests are collapsed down into a few files and very limited. I'll start working on putting together for new elements and styles that I created until you're able to get around to approving (please give PHPWord a little of your attention), but some of the items will be easier to do when everything is approved due to the refactoring work needed.

@rasamassen rasamassen changed the title RTF Writer: Fix TextBreak.php to work for linebreaks RTF Writer: Textbreak - Fix to work for linebreaks Oct 4, 2025
@rasamassen
Copy link
Author

@Progi1984 I've created some of the unit tests. Is there any way you can spend some time on PHPWord, approve the pull requests I've made, and then I'll work on more unit tests as a separate pull request? Between like 3 of my pulls changing section and the need to refactor the existing tests, it'll be easier to create more tests once all the pulls are approved. And it'll be easier to figure out what needs to be worked on next for RTF to keep adding missing features.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

None yet

Development

Successfully merging this pull request may close these issues.

3 participants