You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
					
					
						
							217 lines
						
					
					
						
							6.5 KiB
						
					
					
				
			
		
		
	
	
							217 lines
						
					
					
						
							6.5 KiB
						
					
					
				<?php | 
						|
namespace yiiunit\extensions\bootstrap; | 
						|
 | 
						|
use yii\bootstrap\Tabs; | 
						|
use yii\helpers\Html; | 
						|
 | 
						|
/** | 
						|
 * Tests for Tabs widget | 
						|
 * | 
						|
 * @group bootstrap | 
						|
 */ | 
						|
class TabsTest extends TestCase | 
						|
{ | 
						|
    /** | 
						|
     * Each tab should have a corresponding unique ID | 
						|
     * | 
						|
     * @see https://github.com/yiisoft/yii2/issues/6150 | 
						|
     */ | 
						|
    public function testIds() | 
						|
    { | 
						|
        Tabs::$counter = 0; | 
						|
        $out = Tabs::widget([ | 
						|
            'items' => [ | 
						|
                [ | 
						|
                    'label' => 'Page1', 'content' => 'Page1', | 
						|
                ], | 
						|
                [ | 
						|
                    'label' => 'Dropdown1', | 
						|
                    'items' => [ | 
						|
                        ['label' => 'Page2', 'content' => 'Page2'], | 
						|
                        ['label' => 'Page3', 'content' => 'Page3'], | 
						|
                    ] | 
						|
                ], | 
						|
                [ | 
						|
                    'label' => 'Dropdown2', | 
						|
                    'items' => [ | 
						|
                        ['label' => 'Page4', 'content' => 'Page4'], | 
						|
                        ['label' => 'Page5', 'content' => 'Page5'], | 
						|
                    ] | 
						|
                ], | 
						|
                [ | 
						|
                    'label' => $extAnchor1 = 'External link', 'url' => $extUrl1 = ['//other/route'], | 
						|
                ], | 
						|
                [ | 
						|
                    'label' => 'Dropdown3', | 
						|
                    'items' => [ | 
						|
                        ['label' => $extAnchor2 = 'External Dropdown Link', 'url' => $extUrl2 = ['//other/dropdown/route']], | 
						|
                    ] | 
						|
                ], | 
						|
            ] | 
						|
        ]); | 
						|
 | 
						|
        $page1 = 'w0-tab0'; | 
						|
        $page2 = 'w0-dd1-tab0'; | 
						|
        $page3 = 'w0-dd1-tab1'; | 
						|
        $page4 = 'w0-dd2-tab0'; | 
						|
        $page5 = 'w0-dd2-tab1'; | 
						|
 | 
						|
        $shouldContain = [ | 
						|
            'w0', // nav widget container | 
						|
                "#$page1", // Page1 | 
						|
 | 
						|
                'w1', // Dropdown1 | 
						|
                    "$page2", // Page2 | 
						|
                    "$page3", // Page3 | 
						|
 | 
						|
 | 
						|
                'w2', // Dropdown2 | 
						|
                    "#$page4", // Page4 | 
						|
                    "#$page5", // Page5 | 
						|
 | 
						|
                'w3', // Dropdown3 | 
						|
 | 
						|
            // containers | 
						|
            "id=\"$page1\"", | 
						|
            "id=\"$page2\"", | 
						|
            "id=\"$page3\"", | 
						|
            "id=\"$page4\"", | 
						|
            "id=\"$page5\"", | 
						|
            Html::a($extAnchor1,$extUrl1), | 
						|
            Html::a($extAnchor2,$extUrl2, ['tabindex' => -1]), | 
						|
        ]; | 
						|
 | 
						|
        foreach ($shouldContain as $string) { | 
						|
            $this->assertContains($string, $out); | 
						|
        } | 
						|
    } | 
						|
 | 
						|
    public function testVisible() | 
						|
    { | 
						|
        Tabs::$counter = 0; | 
						|
        $html = Tabs::widget([ | 
						|
            'items' => [ | 
						|
                [ | 
						|
                    'label' => 'Page1', 'content' => 'Page1', | 
						|
                ], | 
						|
                [ | 
						|
                    'label' => 'InvisiblePage', | 
						|
                    'content' => 'Invisible Page Content', | 
						|
                    'visible' => false | 
						|
                ], | 
						|
                [ | 
						|
                    'label' => 'Dropdown1', | 
						|
                    'items' => [ | 
						|
                        ['label' => 'Page2', 'content' => 'Page2'], | 
						|
                        ['label' => 'InvisibleItem', 'content' => 'Invisible Item Content', 'visible' => false], | 
						|
                        ['label' => 'Page3', 'content' => 'Page3'], | 
						|
                        ['label' => 'External Link', 'url' => ['//other/dropdown/route']], | 
						|
                        ['label' => 'Invisible External Link', 'url' => ['//other/dropdown/route'], 'visible' => false], | 
						|
                    ] | 
						|
                ], | 
						|
            ] | 
						|
        ]); | 
						|
 | 
						|
        $this->assertNotContains('InvisiblePage', $html); | 
						|
        $this->assertNotContains('Invisible Page Content', $html); | 
						|
        $this->assertNotContains('InvisibleItem', $html); | 
						|
        $this->assertNotContains('Invisible Item Content', $html); | 
						|
        $this->assertNotContains('Invisible External Link', $html); | 
						|
    } | 
						|
 | 
						|
    public function testItem() | 
						|
    { | 
						|
        $checkTag = 'article'; | 
						|
 | 
						|
        $out = Tabs::widget([ | 
						|
            'items' => [ | 
						|
                [ | 
						|
                    'label' => 'Page1', 'content' => 'Page1', | 
						|
                ], | 
						|
                [ | 
						|
                    'label' => 'Page2', 'content' => 'Page2', | 
						|
                ], | 
						|
            ], | 
						|
            'itemOptions' => ['tag' => $checkTag], | 
						|
            'renderTabContent' => true, | 
						|
        ]); | 
						|
 | 
						|
        $this->assertContains('<' . $checkTag, $out); | 
						|
    } | 
						|
 | 
						|
    public function testTabContentOptions() | 
						|
    { | 
						|
        $checkAttribute = "test_attribute"; | 
						|
        $checkValue = "check_attribute"; | 
						|
 | 
						|
        $out = Tabs::widget([ | 
						|
            'items' => [ | 
						|
                [ | 
						|
                    'label' => 'Page1', 'content' => 'Page1' | 
						|
                ] | 
						|
            ], | 
						|
            'tabContentOptions' => [ | 
						|
                $checkAttribute => $checkValue | 
						|
            ] | 
						|
        ]); | 
						|
 | 
						|
        $this->assertContains($checkAttribute . '=', $out); | 
						|
        $this->assertContains($checkValue, $out); | 
						|
    } | 
						|
 | 
						|
    public function testActivateFirstVisibleTab() | 
						|
    { | 
						|
        $html = Tabs::widget([ | 
						|
            'id'=>'mytab', | 
						|
            'items' => [ | 
						|
                [ | 
						|
                    'label' => 'Tab 1', | 
						|
                    'content' => 'some content', | 
						|
                    'visible' => false | 
						|
                ], | 
						|
                [ | 
						|
                    'label' => 'Tab 2', | 
						|
                    'content' => 'some content'                             | 
						|
                ], | 
						|
                [ | 
						|
                    'label' => 'Tab 3', | 
						|
                    'content' => 'some content' | 
						|
                ], | 
						|
                [ | 
						|
                    'label' => 'Tab 4', | 
						|
                    'content' => 'some content' | 
						|
                ] | 
						|
            ] | 
						|
        ]);         | 
						|
        $this->assertNotContains('<li class="active"><a href="#mytab-tab0" data-toggle="tab">Tab 1</a></li>', $html); | 
						|
        $this->assertContains('<li class="active"><a href="#mytab-tab1" data-toggle="tab">Tab 2</a></li>', $html); | 
						|
    } | 
						|
 | 
						|
    public function testActivateTab() | 
						|
    { | 
						|
        $html = Tabs::widget([ | 
						|
            'id'=>'mytab', | 
						|
            'items' => [ | 
						|
                [ | 
						|
                    'label' => 'Tab 1', | 
						|
                    'content' => 'some content', | 
						|
                    'visible'=>false | 
						|
                ], | 
						|
                [ | 
						|
                    'label' => 'Tab 2', | 
						|
                    'content' => 'some content' | 
						|
                ], | 
						|
                [ | 
						|
                    'label' => 'Tab 3', | 
						|
                    'content' => 'some content', | 
						|
                    'active' => true | 
						|
                ], | 
						|
                [ | 
						|
                    'label' => 'Tab 4', | 
						|
                    'content' => 'some content' | 
						|
                ] | 
						|
            ] | 
						|
        ]); | 
						|
        $this->assertContains('<li class="active"><a href="#mytab-tab2" data-toggle="tab">Tab 3</a></li>', $html); | 
						|
    } | 
						|
}
 | 
						|
 |