/**
 *
 * Tree Design Tokens
 *
 * [Live Demo](https://www.primeng.org/tree/)
 *
 * @module themes/tree
 *
 */
import { DesignTokens } from '..';

export interface TreeDesignTokens extends DesignTokens<TreeDesignTokens> {
    /**
     * Used to pass tokens of the root section
     */
    root?: {
        /**
         * Background of root
         *
         * @designToken tree.background
         */
        background?: string;
        /**
         * Color of root
         *
         * @designToken tree.color
         */
        color?: string;
        /**
         * Padding of root
         *
         * @designToken tree.padding
         */
        padding?: string;
        /**
         * Gap of root
         *
         * @designToken tree.gap
         */
        gap?: string;
        /**
         * Indent of root
         *
         * @designToken tree.indent
         */
        indent?: string;
        /**
         * Transition duration of root
         *
         * @designToken tree.transition.duration
         */
        transitionDuration?: string;
    };
    /**
     * Used to pass tokens of the node section
     */
    node?: {
        /**
         * Padding of node
         *
         * @designToken tree.node.padding
         */
        padding?: string;
        /**
         * Border radius of node
         *
         * @designToken tree.node.border.radius
         */
        borderRadius?: string;
        /**
         * Hover background of node
         *
         * @designToken tree.node.hover.background
         */
        hoverBackground?: string;
        /**
         * Selected background of node
         *
         * @designToken tree.node.selected.background
         */
        selectedBackground?: string;
        /**
         * Color of node
         *
         * @designToken tree.node.color
         */
        color?: string;
        /**
         * Hover color of node
         *
         * @designToken tree.node.hover.color
         */
        hoverColor?: string;
        /**
         * Selected color of node
         *
         * @designToken tree.node.selected.color
         */
        selectedColor?: string;
        /**
         * Focus ring of node
         */
        focusRing?: {
            /**
             * Focus ring width of node
             *
             * @designToken tree.node.focus.ring.width
             */
            width?: string;
            /**
             * Focus ring style of node
             *
             * @designToken tree.node.focus.ring.style
             */
            style?: string;
            /**
             * Focus ring color of node
             *
             * @designToken tree.node.focus.ring.color
             */
            color?: string;
            /**
             * Focus ring offset of node
             *
             * @designToken tree.node.focus.ring.offset
             */
            offset?: string;
            /**
             * Focus ring shadow of node
             *
             * @designToken tree.node.focus.ring.shadow
             */
            shadow?: string;
        };
        /**
         * Gap of node
         *
         * @designToken tree.node.gap
         */
        gap?: string;
    };
    /**
     * Used to pass tokens of the node icon section
     */
    nodeIcon?: {
        /**
         * Color of node icon
         *
         * @designToken tree.node.icon.color
         */
        color?: string;
        /**
         * Hover color of node icon
         *
         * @designToken tree.node.icon.hover.color
         */
        hoverColor?: string;
        /**
         * Selected color of node icon
         *
         * @designToken tree.node.icon.selected.color
         */
        selectedColor?: string;
    };
    /**
     * Used to pass tokens of the node toggle button section
     */
    nodeToggleButton?: {
        /**
         * Border radius of node toggle button
         *
         * @designToken tree.node.toggle.button.border.radius
         */
        borderRadius?: string;
        /**
         * Size of node toggle button
         *
         * @designToken tree.node.toggle.button.size
         */
        size?: string;
        /**
         * Hover background of node toggle button
         *
         * @designToken tree.node.toggle.button.hover.background
         */
        hoverBackground?: string;
        /**
         * Selected hover background of node toggle button
         *
         * @designToken tree.node.toggle.button.selected.hover.background
         */
        selectedHoverBackground?: string;
        /**
         * Color of node toggle button
         *
         * @designToken tree.node.toggle.button.color
         */
        color?: string;
        /**
         * Hover color of node toggle button
         *
         * @designToken tree.node.toggle.button.hover.color
         */
        hoverColor?: string;
        /**
         * Selected hover color of node toggle button
         *
         * @designToken tree.node.toggle.button.selected.hover.color
         */
        selectedHoverColor?: string;
        /**
         * Focus ring of node toggle button
         */
        focusRing?: {
            /**
             * Focus ring width of node toggle button
             *
             * @designToken tree.node.toggle.button.focus.ring.width
             */
            width?: string;
            /**
             * Focus ring style of node toggle button
             *
             * @designToken tree.node.toggle.button.focus.ring.style
             */
            style?: string;
            /**
             * Focus ring color of node toggle button
             *
             * @designToken tree.node.toggle.button.focus.ring.color
             */
            color?: string;
            /**
             * Focus ring offset of node toggle button
             *
             * @designToken tree.node.toggle.button.focus.ring.offset
             */
            offset?: string;
            /**
             * Focus ring shadow of node toggle button
             *
             * @designToken tree.node.toggle.button.focus.ring.shadow
             */
            shadow?: string;
        };
    };
    /**
     * Used to pass tokens of the loading icon section
     */
    loadingIcon?: {
        /**
         * Size of loading icon
         *
         * @designToken tree.loading.icon.size
         */
        size?: string;
    };
    /**
     * Used to pass tokens of the filter section
     */
    filter?: {
        /**
         * Margin of filter
         *
         * @designToken tree.filter.margin
         */
        margin?: string;
    };
}
