@import 'ui-variables'; @token-top: lighten(@background-secondary,0.6%); @token-bottom: darken(@background-secondary, 2.5%); @token-hover-top: mix(@token-top, @component-active-color, 92%); @token-hover-bottom: mix(@token-bottom, @component-active-color, 90%); @token-selected-top: mix(@token-top, @component-active-color, 15%); @token-selected-bottom: mix(@token-bottom, @component-active-color, 0%); @token-invalid-selected-top: mix(@token-top, red, 60%); @token-invalid-selected-bottom: mix(@token-bottom, red, 55%); @base-box-shadow: 0 0.5px 0 rgba(0,0,0,0.17), 0 -0.5px 0 rgba(0,0,0,0.17), 0.5px 0 0 rgba(0,0,0,0.17), -0.5px 0 0 rgba(0,0,0,0.17), 0 1px 1px rgba(0, 0, 0, 0.1); .tokenizing-field { display: block; margin: 0; padding: 0; position: relative; &.disabled { background: rgba(0, 0, 0, 0.02); opacity: 0.7; .token { background: @token-top; box-shadow: @base-box-shadow; &:hover { background: @token-top; cursor: default; box-shadow: @base-box-shadow; } } .tokenizing-field-input { &:hover { cursor: default; } } &:hover { cursor: default; } } .content-container { border: 1px solid @border-color-secondary; box-shadow: 0 2px 8px rgba(0, 0, 0, 0.2); border-radius: @border-radius-small; background-color: @background-primary; position: absolute; z-index: 3; } .content-container.empty { border: 0; box-shadow: none; } .header-container, .footer-container { background-color: transparent; padding: 0; margin: 0; border: 0; } .token-editing-input { max-width: 100%; font-size: 15px; line-height: 17px; padding: 2em; //0.5em @spacing-three-quarters 0.5em @spacing-three-quarters; padding-right: 1.5em; margin: 3px 6px 6px 1px; } .token { display: inline-block; position: relative; color: @text-color; padding: 0 @spacing-three-quarters; padding-right: 1.5em; margin: 1px 5px 1px 1px; border-radius: @border-radius-base * 0.8; max-width: 100%; line-height: 1.9em; background: linear-gradient(to bottom, @token-top 0%, @token-bottom 100%); box-shadow: @base-box-shadow; vertical-align: middle; .action { position: absolute; padding: 0; border: 0; margin: 0; right: 7px; background-color: transparent; color: @text-color-very-subtle; img { background-color: @text-color-very-subtle; } font-size: 10px; } &:hover { background: linear-gradient(to bottom, @token-hover-top 0%, @token-hover-bottom 100%); box-shadow: 0 0.5px 0 darken(@token-hover-bottom, 35%), 0 -0.5px 0 darken(@token-hover-top, 25%), 0.5px 0 0 darken(@token-hover-bottom, 25%), -0.5px 0 0 darken(@token-hover-bottom, 25%), 0 1px 1px rgba(0, 0, 0, 0.07); cursor: default; } &.invalid { border-bottom: 1px dashed red; margin-bottom: -1px; background: transparent; &:hover { box-shadow: 0 -0.5px 0 @token-invalid-selected-top, 0.5px 0 0 @token-invalid-selected-bottom, -0.5px 0 0 @token-invalid-selected-bottom, 0 1px 1px rgba(0, 0, 0, 0.07); } } &.invalid.selected, &.invalid.dragging { background: linear-gradient( to bottom, @token-invalid-selected-top 0%, @token-invalid-selected-bottom 100% ); box-shadow: inset 0 1.5px 0 rgba(255, 255, 255, 0.3), 0 1px 1px rgba(0, 0, 0, 0.1); border: 1px solid darken(@token-invalid-selected-bottom, 8%); border-top: 1px solid darken(@token-invalid-selected-top, 10%); } &.selected, &.dragging { background: linear-gradient(to bottom, @token-selected-top 0%, @token-selected-bottom 100%); box-shadow: inset 0 1.5px 0 rgba(255, 255, 255, 0.3), 0 1px 1px rgba(0, 0, 0, 0.1); border: 1px solid darken(@token-selected-bottom, 8%); border-top: 1px solid darken(@token-selected-top, 10%); border-radius: @border-radius-base; // Note: we switch from 0.5px borders with box shadows to a real border, // because the 0.5px shadows can't be as dark as we want. This means // margins / border radius change by 1px. margin: 0 4px 0 0; color: @text-color-inverse; .action { color: @text-color-inverse-subtle; img { background-color: @text-color-inverse-subtle; } } .secondary, .participant-secondary { color: @text-color-inverse-subtle; } } &.dragging { cursor: -webkit-grabbing; } } .tokenizing-field-label { color: @text-color-very-subtle; float: left; text-transform: capitalize; padding-top: 12px; display: block; &:hover { cursor: default; } } .tokenizing-field-input { position: relative; margin-left: 2.8em; padding-top: 9px; padding-bottom: 3px; &:hover { cursor: text; } &.at-max-tokens { cursor: default; input { &:hover { cursor: default; } opacity: 0; } } input { display: inline-block; width: initial; vertical-align: top; border: none; min-width: 0.5em; background-color: transparent; // NOTE: padding-top and padding-bottom need to match that of // `.token`. to ensure they have the same baseline. // // The padding-left and padding-right must be 0 so we can manually // set the width properly to always match the size of the input // test. padding: 0.3em 0 0.3em 0; &.noop-input { position: absolute; min-width: 0; padding-left: 0; margin-right: 0; box-shadow: none; &:focus { box-shadow: none; } } } input:focus { box-shadow: none; } } .placeholder { color: fade(@text-color, 50%); position: absolute; top: 50%; margin-top: -0.75em; left: 8px; } } body.is-blurred .tokenizing-field .token:not(.invalid) { background: @background-secondary; color: @text-color; &.selected .action img { background-color: @text-color-very-subtle; } } body.platform-win32 { .tokenizing-field { .content-container { border-radius: 0; } .tokenizing-field-input { input, input:focus { border: 0; box-shadow: 0 0 0; } } } .token { border-radius: 0; background: @token-bottom; &.selected, &.dragging { border-radius: 0; background: @token-selected-top; } &:hover { background: @token-hover-bottom; } &.invalid.selected, &.invalid.dragging { background: @token-invalid-selected-top; } } }