<template>
    <div>
        <Head>
            <Title>Vue OrganizationChart Component</Title>
            <Meta name="description" content="OrganizationChart visualizes hierarchical organization data." />
        </Head>

        <div class="content-section introduction">
            <div class="feature-intro">
                <h1>OrganizationChart</h1>
                <p>OrganizationChart visualizes hierarchical organization data.</p>
            </div>
            <AppDemoActions />
        </div>

        <div class="content-section implementation">
            <div class="card">
                <h5>Advanced</h5>
                <OrganizationChart
                    v-model:selectionKeys="selection"
                    :value="data1"
                    :collapsible="true"
                    class="company"
                    selectionMode="single"
                    @node-select="onNodeSelect"
                    @node-unselect="onNodeUnselect"
                    @node-collapse="onNodeCollapse"
                    @node-expand="onNodeExpand"
                >
                    <template #person="slotProps">
                        <div class="node-header ui-corner-top">{{ slotProps.node.data.label }}</div>
                        <div class="node-content">
                            <img :src="'demo/images/organization/' + slotProps.node.data.avatar" width="32" />
                            <div>{{ slotProps.node.data.name }}</div>
                        </div>
                    </template>
                    <template #default="slotProps">
                        <span>{{ slotProps.node.data.label }}</span>
                    </template>
                </OrganizationChart>
            </div>

            <div class="card">
                <h5>Basic</h5>
                <OrganizationChart :value="data2">
                    <template #default="slotProps">
                        <span>{{ slotProps.node.data.label }}</span>
                    </template>
                </OrganizationChart>
            </div>
        </div>

        <OrganizationChartDoc />
    </div>
</template>
<script>
import OrganizationChartDoc from './OrganizationChartDoc';

export default {
    data() {
        return {
            data1: {
                key: '0',
                type: 'person',
                styleClass: 'p-person',
                data: { label: 'CEO', name: 'Walter White', avatar: 'walter.jpg' },
                children: [
                    {
                        key: '0_0',
                        type: 'person',
                        styleClass: 'p-person',
                        data: { label: 'CFO', name: 'Saul Goodman', avatar: 'saul.jpg' },
                        children: [
                            {
                                key: '0_0_0',
                                data: { label: 'Tax' },
                                selectable: false,
                                styleClass: 'department-cfo'
                            },
                            {
                                key: '0_0_1',
                                data: { label: 'Legal' },
                                selectable: false,
                                styleClass: 'department-cfo'
                            }
                        ]
                    },
                    {
                        key: '0_1',
                        type: 'person',
                        styleClass: 'p-person',
                        data: { label: 'COO', name: 'Mike E.', avatar: 'mike.jpg' },
                        children: [
                            {
                                key: '0_1_0',
                                data: { label: 'Operations' },
                                selectable: false,
                                styleClass: 'department-coo'
                            }
                        ]
                    },
                    {
                        key: '0_2',
                        type: 'person',
                        styleClass: 'p-person',
                        data: { label: 'CTO', name: 'Jesse Pinkman', avatar: 'jesse.jpg' },
                        children: [
                            {
                                key: '0_2_0',
                                data: { label: 'Development' },
                                selectable: false,
                                styleClass: 'department-cto',
                                children: [
                                    {
                                        key: '0_2_0_0',
                                        data: { label: 'Analysis' },
                                        selectable: false,
                                        styleClass: 'department-cto'
                                    },
                                    {
                                        key: '0_2_0_1',
                                        data: { label: 'Front End' },
                                        selectable: false,
                                        styleClass: 'department-cto'
                                    },
                                    {
                                        key: '0_2_0_2',
                                        data: { label: 'Back End' },
                                        selectable: false,
                                        styleClass: 'department-cto'
                                    }
                                ]
                            },
                            {
                                key: '0_2_1',
                                data: { label: 'QA' },
                                selectable: false,
                                styleClass: 'department-cto'
                            },
                            {
                                key: '0_2_2',
                                data: { label: 'R&D' },
                                selectable: false,
                                styleClass: 'department-cto'
                            }
                        ]
                    }
                ]
            },
            data2: {
                key: '0',
                data: { label: 'F.C. Barcelona' },
                children: [
                    {
                        key: '0_0',
                        data: { label: 'F.C. Barcelona' },
                        children: [
                            {
                                key: '0_0_0',
                                data: { label: 'Chelsea F.C.' }
                            },
                            {
                                key: '0_0_1',
                                data: { label: 'F.C. Barcelona' }
                            }
                        ]
                    },
                    {
                        key: '0_1',
                        data: { label: 'Real Madrid' },
                        children: [
                            {
                                key: '0_1_0',
                                data: { label: 'Bayern Munich' }
                            },
                            {
                                key: '0_1_1',
                                data: { label: 'Real Madrid' }
                            }
                        ]
                    }
                ]
            },
            selection: {}
        };
    },
    methods: {
        onNodeSelect(node) {
            this.$toast.add({ severity: 'success', summary: 'Node Selected', detail: node.data.label, life: 3000 });
        },
        onNodeUnselect(node) {
            this.$toast.add({ severity: 'success', summary: 'Node Unselected', detail: node.data.label, life: 3000 });
        },
        onNodeExpand(node) {
            this.$toast.add({ severity: 'success', summary: 'Node Expanded', detail: node.data.label, life: 3000 });
        },
        onNodeCollapse(node) {
            this.$toast.add({ severity: 'success', summary: 'Node Collapsed', detail: node.data.label, life: 3000 });
        }
    },
    components: {
        OrganizationChartDoc: OrganizationChartDoc
    }
};
</script>

<style scoped lang="scss">
::v-deep(.p-organizationchart) {
    .p-person {
        padding: 0;
        border: 0 none;
    }

    .node-header,
    .node-content {
        padding: 0.5em 0.7rem;
    }

    .node-header {
        background-color: #495ebb;
        color: #ffffff;
    }

    .node-content {
        text-align: center;
        border: 1px solid #495ebb;
    }

    .node-content img {
        border-radius: 50%;
    }

    .department-cfo {
        background-color: #7247bc;
        color: #ffffff;
    }

    .department-coo {
        background-color: #a534b6;
        color: #ffffff;
    }

    .department-cto {
        background-color: #e9286f;
        color: #ffffff;
    }
}
</style>