| <script lang="ts"> |
| import { createEventDispatcher } from "svelte"; |
|
|
| import type { ReferencePoint } from "@graphite/messages"; |
|
|
| const dispatch = createEventDispatcher<{ value: ReferencePoint }>(); |
|
|
| export let value: string; |
| export let disabled = false; |
|
|
| function setValue(newValue: ReferencePoint) { |
| dispatch("value", newValue); |
| } |
| </script> |
|
|
| <div class="reference-point-input" class:disabled> |
| <button on:click={() => setValue("TopLeft")} class="row-1 col-1" class:active={value === "TopLeft"} tabindex="-1" {disabled}><div /></button> |
| <button on:click={() => setValue("TopCenter")} class="row-1 col-2" class:active={value === "TopCenter"} tabindex="-1" {disabled}><div /></button> |
| <button on:click={() => setValue("TopRight")} class="row-1 col-3" class:active={value === "TopRight"} tabindex="-1" {disabled}><div /></button> |
| <button on:click={() => setValue("CenterLeft")} class="row-2 col-1" class:active={value === "CenterLeft"} tabindex="-1" {disabled}><div /></button> |
| <button on:click={() => setValue("Center")} class="row-2 col-2" class:active={value === "Center"} tabindex="-1" {disabled}><div /></button> |
| <button on:click={() => setValue("CenterRight")} class="row-2 col-3" class:active={value === "CenterRight"} tabindex="-1" {disabled}><div /></button> |
| <button on:click={() => setValue("BottomLeft")} class="row-3 col-1" class:active={value === "BottomLeft"} tabindex="-1" {disabled}><div /></button> |
| <button on:click={() => setValue("BottomCenter")} class="row-3 col-2" class:active={value === "BottomCenter"} tabindex="-1" {disabled}><div /></button> |
| <button on:click={() => setValue("BottomRight")} class="row-3 col-3" class:active={value === "BottomRight"} tabindex="-1" {disabled}><div /></button> |
| </div> |
|
|
| <style lang="scss" global> |
| .reference-point-input { |
| position: relative; |
| flex: 0 0 auto; |
| width: 24px; |
| height: 24px; |
| --reference-point-border-color: var(--color-5-dullgray); |
| --reference-point-fill-active: var(--color-e-nearwhite); |
|
|
| button { |
| position: absolute; |
| width: 5px; |
| height: 5px; |
| margin: 0; |
| padding: 0; |
| background: var(--color-1-nearblack); |
| border: 1px solid var(--reference-point-border-color); |
|
|
| &.active { |
| border-color: transparent; |
| background: var(--reference-point-fill-active); |
| } |
|
|
| &.col-1::before, |
| &.col-2::before { |
| content: ""; |
| pointer-events: none; |
| width: 2px; |
| height: 0; |
| border-top: 1px solid var(--reference-point-border-color); |
| position: absolute; |
| top: 1px; |
| right: -3px; |
| } |
|
|
| &.row-1::after, |
| &.row-2::after { |
| content: ""; |
| pointer-events: none; |
| width: 0; |
| height: 2px; |
| border-left: 1px solid var(--reference-point-border-color); |
| position: absolute; |
| bottom: -3px; |
| right: 1px; |
| } |
|
|
| &.row-1 { |
| top: 3px; |
| } |
| &.col-1 { |
| left: 3px; |
| } |
|
|
| &.row-2 { |
| top: 10px; |
| } |
| &.col-2 { |
| left: 10px; |
| } |
|
|
| &.row-3 { |
| top: 17px; |
| } |
| &.col-3 { |
| left: 17px; |
| } |
|
|
| |
| div { |
| width: 100%; |
| height: 100%; |
| padding: 2px; |
| margin: -2px; |
| } |
| } |
|
|
| &:not(.disabled) button:not(.active):hover { |
| border-color: transparent; |
| background: var(--color-6-lowergray); |
| } |
|
|
| &.disabled button { |
| --reference-point-border-color: var(--color-4-dimgray); |
| --reference-point-fill-active: var(--color-8-uppergray); |
| } |
| } |
| </style> |
|
|