import { css, styled } from "styled-components";
import * as Dropdown from "../../../components/controls/dropdown/Dropdown.styled";
import * as Box from "../../../components/layouts/box/Box.styled";
export const Side = styled.div `
    display: flex;
    // min-width: max-content;
    min-width: ${({ $width }) => ($width ? `calc(var(--unit) * ${$width})` : "max-content")};
    transition: 0.3s ease;

    &:not(:has(> :is(h1, h2, h3, h4, h5, h6, strong, b, p, i))) {
        /* &:has(> :is(div, span)) { */
        &:first-child {
            margin-left: -${({ $gap }) => $gap}em;
        }

        &:last-child {
            margin-right: -${({ $gap }) => $gap}em;
        }
    }

    & > * {
        width: 100%;
    }

    & > span {
        font-size: 1.5em;
        display: flex;
        align-items: center;
        justify-content: center;
        font-weight: bold;
        height: 100%;
        min-height: 1.337em;
        min-width: max-content;
        padding: 0.6667em;
        margin: 0;
        opacity: 0.45;
    }

    & > *${Dropdown.default} {
        &,
        & > ul,
        & > ul > li {
            -webkit-backdrop-filter: none;
            backdrop-filter: none;
        }
    }
`;
export const Inner = styled.div `
    transition: 0.3s ease;
    overflow: hidden;

    ${({ $gap, $expand }) => $expand
    ? css `
                  opacity: 1;
                  max-width: 100%;
              `
    : css `
                  &:last-child {
                      margin-left: -${$gap}em;
                  }
                  &:first-child {
                      margin-right: -${$gap}em;
                  }
                  &:not(:first-child):not(:last-child) {
                      margin-left: -${$gap}em;
                      margin-right: -${$gap}em;
                  }
                  opacity: 0;
                  max-width: 0;
                  pointer-events: none;

                  & > button {
                      &:first-child {
                          margin-left: -${$gap}em;
                      }

                      &:last-child {
                          margin-right: -${$gap}em;
                      }
                  }
              `}
`;
export const Wrapper = styled.div `
    display: flex;
    justify-content: ${({ $foldPosition }) => $foldPosition === "left" ? "flex-start" : $foldPosition === "center" ? "center" : "flex-end"};

    ${({ $fold, $expand }) => css `
        ${$fold &&
    !$expand &&
    css `
            & ${Style} {
                & > * > *:first-child {
                    opacity: 0.4;
                    transition: 0.3s ease;
                }
                &:hover > * > *:first-child {
                    opacity: 1;
                }
            }
            & > *:active {
                background: rgba(var(--white), var(--o015));
            }
        `}
    `}

    & > * {
        position: absolute;
        max-width: ${({ $expand }) => ($expand ? "100%" : "0")};
        min-width: min-content;
        width: 100%;
        transition: 0.3s ease;

        & > * > * {
            pointer-events: ${({ $expand }) => ($expand ? "initial" : "none")};
        }
    }
`;
export const Dot = styled.div `
    position: absolute;
    top: 0.5em !important;
    right: 0.5em !important;
    width: 0.75em !important;
    height: 0.75em !important;
    background: rgb(var(--white));
    border-radius: 100%;
    transition: 0.3s ease;
    opacity: ${({ $active, $expand }) => ($active && !$expand ? "1" : "0")};
`;
const Style = styled.div `
    font-size: ${({ $scale }) => $scale}em;
    -webkit-user-drag: none;
    -webkit-touch-callout: none;
    -webkit-user-select: none;
    -khtml-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
    transition: 0.3s ease;

    ${({ $fold, $expand, $lock }) => $fold && !$expand && !$lock && "cursor:pointer;"}
    backdrop-filter: blur(${({ $fold, $expand }) => ($fold && $expand ? "4em" : "0")});

    & > * {
        transition: 0.3s ease;

        &:first-child {
            position: relative;
            display: flex;
            flex-direction: column;
            justify-content: center;
            min-height: 4em;
            padding: 0 1em;

            ${({ $expand, $error }) => $expand &&
    css `
                    background: rgba(var(--${!$error ? "white" : "red"}), var(--o01));
                `}

            & > * {
                display: flex;
                align-items: center;
                justify-content: center;
                width: -webkit-fill-available;
                height: auto;
                gap: ${({ $gap }) => $gap}em;

                & > ${Side} {
                    & > i > svg {
                        ${({ $error }) => $error && "fill: rgb(var(--red));"}
                    }
                }

                & > *:not(${Side}) {
                    display: flex;
                    align-items: center;
                    width: 100%;
                }

                & > ${Inner} {
                    ${({ $clearable, $clearPosition }) => $clearable &&
    ($clearPosition === "left"
        ? css `
                                  & > *:first-child {
                                      margin-left: -1em;
                                  }
                              `
        : css `
                                  & > *:last-child {
                                      margin-right: -1em;
                                  }
                              `)}
                }

                input {
                    background: transparent;
                    display: flex;
                    width: 100%;
                    height: 100%;
                    min-height: 2.6667em;
                    color: var(--white);
                    font-size: 1.5em;
                    font-weight: bold;
                    outline: none;

                    &::placeholder {
                        text-align: ${({ $align }) => $align};
                        font-weight: normal;
                        color: inherit;
                        opacity: 0.3;
                    }

                    &[type="number"],
                    &[type="date"] {
                        -moz-appearance: textfield;
                    }

                    &[type="number"]::-webkit-outer-spin-button,
                    &[type="number"]::-webkit-inner-spin-button,
                    &[type="date"]::-webkit-outer-spin-button,
                    &[type="date"]::-webkit-inner-spin-button {
                        -webkit-appearance: none;
                        display: none;
                        margin: 0;
                    }

                    &:disabled {
                        pointer-events: none;
                    }

                    ${({ $type }) => ($type === "number" || $type === "currency") &&
    css `
                            font-feature-settings:
                                "tnum" on,
                                "lnum" on;
                        `}
                }
            }

            &:hover {
                background: rgba(
                    var(--${({ $fold, $expand, $error }) => (!$fold || $expand ? ($error ? "red" : "white") : "white")}),
                    ${({ $fold, $expand }) => (!$fold && $expand ? "var(--o03)" : "var(--o015)")}
                );
            }

            &:active {
                ${({ $fold, $expand }) => ($fold && !$expand ? "background: rgba(var(--white), var(--o03));" : "")}
            }

            ${({ $lock }) => $lock &&
    css `
                    background: rgba(var(--white), var(--o003));
                    cursor: pointer;
                    pointer-events: none;
                    & > * {
                        pointer-events: none;
                        & > * {
                            pointer-events: none;
                            input {
                                cursor: pointer;
                                pointer-events: none;
                            }
                        }
                        & > ${Side} {
                            cursor: pointer;
                            pointer-events: none;
                        }
                    }
                `}

            ${({ $disabled }) => $disabled &&
    css `
                    cursor: pointer;
                    opacity: var(--o015);
                    pointer-events: none;
                    & > * {
                        pointer-events: none;
                        & > * {
                            pointer-events: none;
                            input {
                                cursor: pointer;
                                pointer-events: none;
                            }
                        }
                        & > ${Side} {
                            cursor: pointer;
                            pointer-events: none;
                        }
                    }
                `}
        }

        &:last-child:not(:only-child) {
            margin-top: 0.5em;
        }
    }

    &[data-active="true"] {
        & > *:first-child {
            background: rgba(var(--${({ $error }) => (!$error ? "white" : "red")}), var(--o015));

            /* ${Box.default} {
            background: rgba(var(--${({ $error }) => (!$error ? "white" : "red")}), var(--o01));
            } */
        }
    }
`;
export default Style;
//# sourceMappingURL=Input.styled.jsx.map