import { mount } from '@vue/test-utils';
import TabPanel from '../tabpanel/TabPanel.vue';
import TabView from './TabView.vue';

describe('TabPanel.vue', () => {
    let wrapper;

    window.HTMLElement.prototype.scrollIntoView = function () {};

    beforeEach(() => {
        wrapper = mount(TabView, {
            global: {
                components: {
                    TabPanel
                }
            },
            slots: {
                default: `
                    <TabPanel header="Header I">
                        <p>Lorem ipsum dolor sit amet, consectetur adipiscing elit,</p>
                    </TabPanel>
                    <TabPanel header="Header II">
                        <p>Sed ut perspiciatis unde omnis iste natus error sit voluptatem</p>
                    </TabPanel>
                    <TabPanel header="Header III">
                        <p>At vero eos et accusamus et iusto odio dignissimos ducimus qui</p>
                    </TabPanel>
                `
            }
        });
    });

    it('should exist', () => {
        expect(wrapper.find('.p-tabview.p-component').exists()).toBe(true);
        expect(wrapper.find('.p-tabview-ink-bar').exists()).toBe(true);
        expect(wrapper.findAll('a.p-tabview-nav-link').length).toBe(3);
        expect(wrapper.findAll('.p-tabview-panel').length).toBe(3);
        expect(wrapper.findAll('li[role="presentation"]')[0].classes()).toContain('p-highlight');
        expect(wrapper.findAll('.p-tabview-panel')[1].attributes().style).toBe('display: none;');
    });

    it('should change the active item', async () => {
        await wrapper.vm.onTabClick({}, 1);

        expect(wrapper.findAll('li[role="presentation"]')[1].classes()).toContain('p-tabview-header');
        expect(wrapper.findAll('.p-tabview-panel')[0].attributes().style).toBe('display: none;');
    });
});

describe('dynamic tabs', () => {
    it('should exist', () => {
        const wrapper = mount(TabView, {
            global: {
                components: {
                    TabPanel
                }
            },
            slots: {
                default: `
                    <TabPanel v-for="tab in Array.from({ length: 5 }, (_, i) => ({ title: \`Tab \${i + 1}\`, content: \`Tab \${i + 1} Content\` }))" :key="tab.title" :header="tab.title">
                        <p>{{tab.content}}</p>
                    </TabPanel>
                `
            }
        });

        expect(wrapper.find('.p-tabview.p-component').exists()).toBe(true);
        expect(wrapper.find('.p-tabview-ink-bar').exists()).toBe(true);
        expect(wrapper.findAll('a.p-tabview-nav-link').length).toBe(5);
        expect(wrapper.findAll('.p-tabview-panel').length).toBe(5);
        expect(wrapper.findAll('li[role="presentation"]')[0].classes()).toContain('p-highlight');
        expect(wrapper.findAll('.p-tabview-panel')[1].attributes().style).toBe('display: none;');
    });
});