Skip to content

Commit

Permalink
Merge pull request #1272 from nicoder/add-getVariableCount-method
Browse files Browse the repository at this point in the history
Add getVariableCount method in TemplateProcessor
  • Loading branch information
troosan authored Dec 11, 2018
2 parents cf3132a + b188ab9 commit 0db21ae
Show file tree
Hide file tree
Showing 3 changed files with 62 additions and 6 deletions.
1 change: 1 addition & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,7 @@ This project adheres to [Semantic Versioning](http://semver.org/).
v0.16.0 (xx dec 2018)
----------------------
### Added
- Add getVariableCount method in TemplateProcessor. @nicoder #1272
- Add setting Chart Title and Legend visibility @Tom-Magill #1433
- Add ability to pass a Style object in Section constructor @ndench #1416
- Add support for hidden text @Alexmg86 #1527
Expand Down
28 changes: 22 additions & 6 deletions src/PhpWord/TemplateProcessor.php
Original file line number Diff line number Diff line change
Expand Up @@ -234,23 +234,39 @@ public function setValue($search, $replace, $limit = self::MAXIMUM_REPLACEMENTS_
}

/**
* Returns array of all variables in template.
* Returns count of all variables in template.
*
* @return string[]
* @return array
*/
public function getVariables()
public function getVariableCount()
{
$variables = $this->getVariablesForPart($this->tempDocumentMainPart);

foreach ($this->tempDocumentHeaders as $headerXML) {
$variables = array_merge($variables, $this->getVariablesForPart($headerXML));
$variables = array_merge(
$variables,
$this->getVariablesForPart($headerXML)
);
}

foreach ($this->tempDocumentFooters as $footerXML) {
$variables = array_merge($variables, $this->getVariablesForPart($footerXML));
$variables = array_merge(
$variables,
$this->getVariablesForPart($footerXML)
);
}

return array_unique($variables);
return array_count_values($variables);
}

/**
* Returns array of all variables in template.
*
* @return string[]
*/
public function getVariables()
{
return array_keys($this->getVariableCount());
}

/**
Expand Down
39 changes: 39 additions & 0 deletions tests/PhpWord/TemplateProcessorTest.php
Original file line number Diff line number Diff line change
Expand Up @@ -224,6 +224,44 @@ public function testCloneDeleteBlock()
$this->assertTrue($docFound);
}

/**
* @covers ::getVariableCount
* @test
*/
public function getVariableCountCountsHowManyTimesEachPlaceholderIsPresent()
{
// create template with placeholders
$phpWord = new PhpWord();
$section = $phpWord->addSection();
$header = $section->addHeader();
$header->addText('${a_field_that_is_present_three_times}');
$footer = $section->addFooter();
$footer->addText('${a_field_that_is_present_twice}');
$section2 = $phpWord->addSection();
$section2->addText('
${a_field_that_is_present_one_time}
${a_field_that_is_present_three_times}
${a_field_that_is_present_twice}
${a_field_that_is_present_three_times}
');
$objWriter = IOFactory::createWriter($phpWord);
$templatePath = 'test.docx';
$objWriter->save($templatePath);

$templateProcessor = new TemplateProcessor($templatePath);
$variableCount = $templateProcessor->getVariableCount();
unlink($templatePath);

$this->assertEquals(
array(
'a_field_that_is_present_three_times' => 3,
'a_field_that_is_present_twice' => 2,
'a_field_that_is_present_one_time' => 1,
),
$variableCount
);
}

/**
* @covers ::cloneBlock
* @test
Expand All @@ -242,6 +280,7 @@ public function cloneBlockCanCloneABlockTwice()
foreach ($documentElements as $documentElement) {
$section->addText($documentElement);
}

$objWriter = IOFactory::createWriter($phpWord);
$templatePath = 'test.docx';
$objWriter->save($templatePath);
Expand Down

0 comments on commit 0db21ae

Please sign in to comment.