/**
 * Copyright IBM Corp. 2021, 2025
 * SPDX-License-Identifier: MPL-2.0
 */

//
// COPY > SNIPPET
//
@use "../../mixins/focus-ring" as *;

@mixin hds-copy-snippet-success-error() {
  &.hds-copy-snippet--status-success {
    background-color: var(--token-color-surface-interactive);

    .hds-copy-snippet__icon {
      color: var(--token-color-foreground-success);
    }
  }

  &.hds-copy-snippet--status-error {
    background-color: var(--token-color-surface-interactive);

    .hds-copy-snippet__icon {
      color: var(--token-color-foreground-critical);
    }
  }
}

.hds-copy-snippet {
  @include hds-focus-ring-with-pseudo-element();

  display: flex;
  gap: 8px;
  align-items: center;
  justify-content: space-between;
  padding: 6px 4px;
  text-align: left;
  border: 1px solid transparent;
  border-radius: var(--token-border-radius-small);
  cursor: pointer;
}

.hds-copy-snippet--color-primary {
  color: var(--token-color-foreground-action);
  background-color: transparent;

  &:hover,
  &.mock-hover {
    color: var(--token-color-foreground-action-hover);
    background-color: var(--token-color-surface-interactive);
    border-color: var(--token-color-border-strong);
  }

  &:active,
  &.mock-active {
    color: var(--token-color-foreground-action-active);
    background-color: var(--token-color-surface-interactive-active);
    border-color: var(--token-color-border-strong);
  }

  @include hds-copy-snippet-success-error();
}

.hds-copy-snippet--color-secondary {
  color: var(--token-color-foreground-primary);
  background-color: transparent;

  .hds-copy-snippet__icon {
    color: var(--token-color-foreground-action);
  }

  &:hover,
  &.mock-hover {
    background-color: var(--token-color-surface-interactive);
    border-color: var(--token-color-border-strong);

    .hds-copy-snippet__icon {
      color: var(--token-color-foreground-action-hover);
    }
  }

  &:active,
  &.mock-active {
    background-color: var(--token-color-surface-interactive-active);
    border-color: var(--token-color-border-strong);

    .hds-copy-snippet__icon {
      color: var(--token-color-foreground-action-active);
    }
  }

  @include hds-copy-snippet-success-error();
}

.hds-copy-snippet--status-success {
  background-color: var(--token-color-surface-interactive);

  .hds-copy-snippet__icon {
    color: var(--token-color-foreground-success);
  }
}

.hds-copy-snippet--status-error {
  background-color: var(--token-color-surface-interactive);

  .hds-copy-snippet__icon {
    color: var(--token-color-foreground-critical);
  }
}

.hds-copy-snippet__text {
  flex: 1 0 0;
}

.hds-copy-snippet__icon {
  flex: none;
}

.hds-copy-snippet--width-full {
  width: 100%;
  max-width: 100%;
}

.hds-copy-snippet--is-truncated {
  width: 100%;
  max-width: 100%;

  .hds-copy-snippet__text {
    overflow: hidden;
    white-space: nowrap;
    text-overflow: ellipsis;
  }
}
