36 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
		
		
			
		
	
	
			36 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| 
								 | 
							
								<?php
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								namespace PhpOffice\PhpSpreadsheetTests\Style;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								use PhpOffice\PhpSpreadsheet\Spreadsheet;
							 | 
						||
| 
								 | 
							
								use PhpOffice\PhpSpreadsheet\Style\NumberFormat;
							 | 
						||
| 
								 | 
							
								use PHPUnit\Framework\TestCase;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								class NumberFormatBuiltinTest extends TestCase
							 | 
						||
| 
								 | 
							
								{
							 | 
						||
| 
								 | 
							
								    public function testBuiltinCodes(): void
							 | 
						||
| 
								 | 
							
								    {
							 | 
						||
| 
								 | 
							
								        $spreadsheet = new Spreadsheet();
							 | 
						||
| 
								 | 
							
								        $sheet = $spreadsheet->getActiveSheet();
							 | 
						||
| 
								 | 
							
								        $cell1 = $sheet->getCell('A1');
							 | 
						||
| 
								 | 
							
								        $cell1->setValue(1);
							 | 
						||
| 
								 | 
							
								        $cell1->getStyle()->getNumberFormat()->setBuiltInFormatCode(2); // 0.00
							 | 
						||
| 
								 | 
							
								        self::assertEquals('1.00', $cell1->getFormattedValue());
							 | 
						||
| 
								 | 
							
								        $cell2 = $sheet->getCell('A2');
							 | 
						||
| 
								 | 
							
								        $cell2->setValue(1234);
							 | 
						||
| 
								 | 
							
								        $cell2->getStyle()->getNumberFormat()->setFormatCode('#,##0'); // builtin 3
							 | 
						||
| 
								 | 
							
								        self::assertEquals(3, $cell2->getStyle()->getNumberFormat()->getBuiltinFormatCode());
							 | 
						||
| 
								 | 
							
								        self::assertEquals('1,234', $cell2->getFormattedValue());
							 | 
						||
| 
								 | 
							
								        $cell3 = $sheet->getCell('A3');
							 | 
						||
| 
								 | 
							
								        $cell3->setValue(1234);
							 | 
						||
| 
								 | 
							
								        $cell3->getStyle()->getNumberFormat()->setFormatCode(''); // General
							 | 
						||
| 
								 | 
							
								        self::assertEquals(NumberFormat::FORMAT_GENERAL, $cell3->getStyle()->getNumberFormat()->getFormatCode());
							 | 
						||
| 
								 | 
							
								        self::assertEquals(0, $cell3->getStyle()->getNumberFormat()->getBuiltinFormatCode());
							 | 
						||
| 
								 | 
							
								        self::assertEquals('1234', $cell3->getFormattedValue());
							 | 
						||
| 
								 | 
							
								        // non-supervisor
							 | 
						||
| 
								 | 
							
								        $numberFormat = new NumberFormat();
							 | 
						||
| 
								 | 
							
								        $numberFormat->setBuiltInFormatCode(4);
							 | 
						||
| 
								 | 
							
								        self::assertEquals('#,##0.00', $numberFormat->getFormatCode());
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								}
							 |