@use "../../wc";
@use "../../form-control";

:host {
  display: block;
}

.form-control {
  display: flex;
  flex-direction: column;
  height: 100%;
}

.form-control .form-control__label {
  padding-bottom: var(--zn-spacing-small);
}

.checkbox {
  position: relative;
  display: inline-flex;
  align-items: flex-start;
  font-family: var(--zn-input-font-family), sans-serif;
  font-weight: var(--zn-input-font-weight);
  color: var(--zn-input-label-color);
  vertical-align: middle;
  cursor: pointer;
  height: 100%;

  --checkbox-color: var(--zn-color-primary-600);
  --checkbox-color-hover: var(--zn-color-primary-500);
  --checkbox-icon-color: var(--zn-color-neutral-0);
  --checkbox-border-color: var(--zn-input-border-color);
  --checkbox-bg-color: var(--zn-input-background-color);

  &.checkbox--default {
    --checkbox-color: var(--zn-color-primary-600);
    --checkbox-color-hover: var(--zn-color-primary-500);
    --checkbox-border-color: var(--zn-input-border-color);
  }

  &.checkbox--primary {
    --checkbox-color: var(--zn-color-primary-600);
    --checkbox-color-hover: var(--zn-color-primary-500);
    --checkbox-border-color: var(--zn-color-primary-600);
  }

  &.checkbox--secondary {
    --checkbox-color: var(--zn-color-neutral-600);
    --checkbox-color-hover: var(--zn-color-neutral-500);
    --checkbox-border-color: var(--zn-color-neutral-300);
    --checkbox-bg-color: var(--zn-color-neutral-50);
  }

  &.checkbox--info {
    --checkbox-color: var(--zn-color-info-600);
    --checkbox-color-hover: var(--zn-color-info-500);
    --checkbox-border-color: var(--zn-color-info-600);
  }

  &.checkbox--success {
    --checkbox-color: var(--zn-color-success-600);
    --checkbox-color-hover: var(--zn-color-success-500);
    --checkbox-border-color: var(--zn-color-success-600);
  }

  &.checkbox--warning {
    --checkbox-color: var(--zn-color-warning-600);
    --checkbox-color-hover: var(--zn-color-warning-500);
    --checkbox-border-color: var(--zn-color-warning-600);
  }

  &.checkbox--error {
    --checkbox-color: var(--zn-color-danger-600);
    --checkbox-color-hover: var(--zn-color-danger-500);
    --checkbox-border-color: var(--zn-color-danger-600);
  }

  &.checkbox--transparent {
    --checkbox-bg-color: transparent;
    --checkbox-border-color: transparent;
  }
}

.checkbox--small {
  --toggle-size: var(--zn-toggle-size-small);
  font-size: var(--zn-input-font-size-small);
}

.checkbox--small .checkbox__description {
  font-size: var(--zn-font-size-x-small);
}

.checkbox--medium {
  --toggle-size: var(--zn-toggle-size-medium);
  font-size: var(--zn-input-font-size-medium);
}

.checkbox--medium .checkbox__description,
.checkbox--large .checkbox__description {
  font-size: var(--zn-input-font-size-small);
}

.checkbox--large {
  --toggle-size: var(--zn-toggle-size-large);
  font-size: var(--zn-input-font-size-large);
}

.checkbox__control {
  flex: 0 0 auto;
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: var(--toggle-size);
  height: var(--toggle-size);
  box-shadow: var(--zn-shadow-x-small);
  border: solid var(--zn-input-border-width) var(--checkbox-border-color);
  background-color: var(--checkbox-bg-color);
  border-radius: 2px;
  color: var(--checkbox-icon-color);
  transition: var(--zn-transition-fast) border-color,
  var(--zn-transition-fast) background-color,
  var(--zn-transition-fast) color,
  var(--zn-transition-fast) box-shadow;
}

.checkbox__input {
  position: absolute;
  opacity: 0;
  padding: 0;
  margin: 0;
  pointer-events: none;
}

.checkbox__indeterminate-icon {
  --icon-size: var(--toggle-size);
  --icon-color: var(--checkbox-icon-color);

  display: inline-flex;
  width: var(--toggle-size);
  height: var(--toggle-size);
}

.svg-icon {
  height: max(16px, 70%);
  --icon-color: var(--checkbox-icon-color);

  .checkbox__checked-icon {
    stroke-dasharray: 24;
    stroke-dashoffset: 24;
    transition: stroke-dashoffset 0.4s cubic-bezier(0.4, 0, 0.2, 1);
  }
}

.checkbox--indeterminate .svg-icon {
  color: transparent;
}

.checkbox--checked {
  .svg-icon {
    color: var(--checkbox-icon-color);
  }

  .checkbox__checked-icon {
    stroke-dashoffset: 0;
  }
}

/* Hover */
.checkbox:not(.checkbox--checked):not(.checkbox--disabled) .checkbox__control:hover {
  border-color: var(--checkbox-color-hover, var(--zn-input-border-color-hover));
  background-color: var(--zn-input-background-color-hover);
}

/* Focus */
.checkbox:not(.checkbox--checked):not(.checkbox--disabled) .checkbox__input:focus-visible ~ .checkbox__control {
  border-color: var(--checkbox-color);
  outline: var(--zn-focus-ring);
  outline-offset: var(--zn-focus-ring-offset);
}

/* Checked/indeterminate */
.checkbox--checked .checkbox__control,
.checkbox--indeterminate .checkbox__control {
  border-color: var(--checkbox-color);
  background-color: var(--checkbox-color);
  color: var(--checkbox-icon-color);
}

/* Checked/indeterminate + hover */
.checkbox.checkbox--checked:not(.checkbox--disabled) .checkbox__control:hover,
.checkbox.checkbox--indeterminate:not(.checkbox--disabled) .checkbox__control:hover {
  border-color: var(--checkbox-color-hover);
  background-color: var(--checkbox-color-hover);
}

/* Checked/indeterminate + focus */
.checkbox.checkbox--checked:not(.checkbox--disabled) .checkbox__input:focus-visible ~ .checkbox__control,
.checkbox.checkbox--indeterminate:not(.checkbox--disabled) .checkbox__input:focus-visible ~ .checkbox__control {
  outline: var(--zn-focus-ring);
  outline-offset: var(--zn-focus-ring-offset);
}

/* Disabled */
.checkbox--disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

:host-context([required]) .checkbox__label::after {
  display: none;
}

:host([required]) .checkbox__label::after {
  display: none;
}

/* If parent Checkbox Group has 'data-user-invalid', style all checkboxes in the group as 'data-user-invalid' by targeting with a class ('checkbox-user-invalid'), since the checkboxes can't be targeted using ::slotted */
:host(.checkbox-user-invalid) .checkbox__control {
  border-color: var(--zn-color-danger-600);
}

:host(.checkbox-user-invalid) .checkbox:not(.checkbox--checked):not(.checkbox--disabled) .checkbox__input:focus-visible ~ .checkbox__control {
  border-color: var(--zn-color-danger-600);
  outline: var(--zn-focus-ring-style) var(--zn-focus-ring-width) var(--zn-error-focus-ring-color);
  outline-offset: var(--zn-focus-ring-offset);
}

/* Handle spacing for checkbox groups rendered with Simple Form */
:host(.groupedCheckbox) {
  margin-top: var(--zn-spacing-medium);
}

:host(.groupedCheckbox[horizontal]),
:host(.groupedCheckbox[contained]) {
  margin-top: var(--zn-spacing-small);
}

:host(.groupedCheckbox[horizontal][contained]) {
  margin-top: 0;
  height: 100%;
}

.checkbox__label {
  display: inline-block;
  color: var(--zn-input-label-color);
  line-height: var(--toggle-size);
  margin-inline-start: 0.75em;
  user-select: none;
  -webkit-user-select: none;
}

.checkbox--no-border {
  border: none !important;
  outline: none !important;
  border-radius: 0 !important;
}

/* Contained */
.checkbox--contained {
  padding: 1.375rem var(--zn-spacing-large) 1.375rem var(--zn-spacing-medium);
  border: 1px solid var(--zn-color-gray-400);
  border-radius: var(--zn-border-radius-medium);
  width: 100%;
  height: 100%;
}

:not(.checkbox--disabled).checkbox--contained:hover,
:not(.checkbox--disabled).checkbox--contained.checkbox--checked:hover {
  background-color: var(--zn-color-purple-50);
  transition: var(--zn-transition-medium) all;
}

.checkbox--contained.checkbox--checked .checkbox__label {
  color: var(--zn-color-purple-600);
  font-weight: var(--zn-font-weight-semibold);
}

.checkbox--contained.checkbox--checked .checkbox__description {
  color: var(--zn-color-gray-900);
  font-weight: var(--zn-font-weight-normal);
}

.checkbox--contained.checkbox--checked {
  background-color: var(--zn-color-purple-100);
  border: 1px solid var(--zn-color-purple-600);
  outline: 1px solid var(--zn-color-purple-600);
  transition: var(--zn-transition-medium) all;
}

/** Select prefix slot */
:host([slot="prefix"]) {
  height: 100%;
  aspect-ratio: 1;

  .checkbox__control {
    height: 100%;
    width: 100%;
    border: unset;
    box-shadow: unset;
    background-color: var(--zn-color-purple-50);
  }

  .checkbox--primary .checkbox__control,
  .checkbox--success .checkbox__control,
  .checkbox--warning .checkbox__control,
  .checkbox--error .checkbox__control,
  .checkbox--info .checkbox__control {
    background-color: var(--checkbox-color);
    color: var(--zn-color-neutral-0);
    border-color: var(--checkbox-color);
  }

  .checkbox--primary:not(.checkbox--checked):not(.checkbox--disabled) .checkbox__control:hover,
  .checkbox--success:not(.checkbox--checked):not(.checkbox--disabled) .checkbox__control:hover,
  .checkbox--warning:not(.checkbox--checked):not(.checkbox--disabled) .checkbox__control:hover,
  .checkbox--error:not(.checkbox--checked):not(.checkbox--disabled) .checkbox__control:hover,
  .checkbox--info:not(.checkbox--checked):not(.checkbox--disabled) .checkbox__control:hover {
    background-color: var(--checkbox-color-hover);
    border-color: var(--checkbox-color-hover);
    color: var(--zn-color-neutral-0);
  }

  .checkbox--secondary .checkbox__control {
    background-color: var(--zn-color-neutral-200);
    color: var(--zn-color-neutral-700);
  }

  .checkbox--secondary:not(.checkbox--checked):not(.checkbox--disabled) .checkbox__control:hover {
    background-color: var(--zn-color-neutral-300);
    border-color: var(--zn-color-neutral-300);
    color: var(--zn-color-neutral-800);
  }

  .checkbox--checked .checkbox__control {
    background-color: var(--checkbox-color);
    color: var(--zn-color-neutral-0);
  }
}
