Skip to content
Snippets Groups Projects
Attachment.module.scss 2.95 KiB
Newer Older
insert's avatar
insert committed
.attachment {
    display: grid;
    grid-auto-columns: min(100%, 480px);
    grid-auto-flow: row dense;
    width: max-content;
    border-radius: 6px;
    margin: .125rem 0 .125rem;
insert's avatar
insert committed
    &[data-spoiler="true"] {
        filter: blur(30px);
        pointer-events: none;
    }

    &[data-has-content="true"] {
        margin-top: 4px;
    }

    &.image {
        cursor: pointer;
        
        max-height: 640px;
        max-width: min(480px, 100%);
        
        object-fit: contain;

        &.loaded {
            width: auto;
            height: auto;
        }
insert's avatar
insert committed
    }

    &.video {        
        .actions {
            padding: 10px 12px;
            border-radius: 6px 6px 0 0;
        }

        video {
            border-radius: 0 0 6px 6px;
            
            max-height: 640px;
            max-width: min(480px, 100%);
        }

        video.loaded {
            width: auto;
            height: auto;
insert's avatar
insert committed
        }
    }

    &.audio {
        gap: 4px;
        padding: 6px;
        display: flex;
        border-radius: 6px;
        flex-direction: column;
        background: var(--secondary-background);
        max-width: 400px;

        > audio {
            width: 100%;
        }
    }

    &.file {
        > div {
            width: 400px;
            padding: 12px;
            user-select: none;
            width: fit-content;
            border-radius: 6px;
        }
    }

    &.text {
insert's avatar
insert committed
        max-width: 800px;
        overflow: hidden;
        grid-auto-columns: unset;

insert's avatar
insert committed
        border-radius: 6px;

        .textContent {
            height: 140px;
            padding: 12px;
            overflow-x: auto;
            overflow-y: auto;
            border-radius: 0 !important;
            background: var(--secondary-header);
    
            pre {
                margin: 0;
            }
    
            pre code {
                font-family: var(--monoscape-font), sans-serif;
insert's avatar
insert committed
            }

            &[data-loading="true"] {
                display: flex;
                
                > * {
                    flex-grow: 1;
                }
            }
        }
    }
}

.actions.imageAction {
    grid-template: 
        "name icon download" auto
        "size icon download" auto
        / minmax(20px, 1fr) min-content min-content;
}

insert's avatar
insert committed
.actions {
    display: grid;
    grid-template: 
        "icon name download" auto
        "icon size download" auto
        / min-content minmax(20px, 1fr) min-content;

    align-items: center;
    column-gap: 8px;
    
    width: 100%;
insert's avatar
insert committed
    padding: 8px;
    overflow: none;
insert's avatar
insert committed
    color: var(--foreground);
    background: var(--secondary-background);

    span {
        text-overflow: ellipsis;
        white-space: nowrap;
        overflow: hidden;
    .filesize {
        grid-area: size;
        font-size: 10px;
        color: var(--secondary-foreground);
    }
    .downloadIcon {
        grid-area: download;
    }

    .iconType {
        grid-area: icon;