You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
635 lines
14 KiB
635 lines
14 KiB
3 years ago
|
/* ------------------------------------------------------------------------------
|
||
|
*
|
||
|
* # Spectrum color picker
|
||
|
*
|
||
|
* Flexible and powerful jQuery colorpicker library
|
||
|
*
|
||
|
* Version: 1.0
|
||
|
* Latest update: May 25, 2015
|
||
|
*
|
||
|
* ---------------------------------------------------------------------------- */
|
||
|
|
||
|
|
||
|
// Base styles
|
||
|
// ------------------------------
|
||
|
|
||
|
// Base
|
||
|
.sp-sat,
|
||
|
.sp-val,
|
||
|
.sp-top-inner,
|
||
|
.sp-color,
|
||
|
.sp-hue,
|
||
|
.sp-clear-enabled .sp-clear,
|
||
|
.sp-preview-inner,
|
||
|
.sp-alpha-inner,
|
||
|
.sp-thumb-inner {
|
||
|
position: absolute;
|
||
|
top: 0;
|
||
|
left: 0;
|
||
|
right: 0;
|
||
|
bottom: 0;
|
||
|
}
|
||
|
|
||
|
// Hide containers by default
|
||
|
.sp-container.sp-input-disabled .sp-input-container,
|
||
|
.sp-container.sp-buttons-disabled .sp-button-container,
|
||
|
.sp-container.sp-palette-buttons-disabled .sp-palette-button-container,
|
||
|
.sp-palette-only .sp-picker-container,
|
||
|
.sp-palette-disabled .sp-palette-container,
|
||
|
.sp-initial-disabled .sp-initial {
|
||
|
display: none;
|
||
|
}
|
||
|
.sp-hidden {
|
||
|
display: none!important;
|
||
|
}
|
||
|
.sp-cf {
|
||
|
&:before,
|
||
|
&:after {
|
||
|
content: "";
|
||
|
display: table;
|
||
|
}
|
||
|
|
||
|
&:after {
|
||
|
clear: both;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
// Elements
|
||
|
.sp-preview,
|
||
|
.sp-alpha,
|
||
|
.sp-thumb-el {
|
||
|
position: relative;
|
||
|
background-image: url();
|
||
|
}
|
||
|
|
||
|
// Previews
|
||
|
.sp-preview-inner,
|
||
|
.sp-alpha-inner,
|
||
|
.sp-thumb-inner {
|
||
|
display: block;
|
||
|
}
|
||
|
|
||
|
// Picker and palette containers
|
||
|
.sp-container {
|
||
|
position: absolute;
|
||
|
top: 0;
|
||
|
left: 0;
|
||
|
display: inline-block;
|
||
|
z-index: @zindex-dropdown;
|
||
|
background-color: @dropdown-bg;
|
||
|
border: 1px solid @dropdown-border;
|
||
|
border-radius: @border-radius-base;
|
||
|
overflow: hidden;
|
||
|
.box-sizing(content-box);
|
||
|
.box-shadow(0 1px 3px fade(#000, 10%));
|
||
|
|
||
|
&.sp-flat {
|
||
|
position: relative;
|
||
|
overflow-x: auto;
|
||
|
max-width: 100%;
|
||
|
white-space: nowrap
|
||
|
}
|
||
|
}
|
||
|
.sp-picker-container,
|
||
|
.sp-palette-container {
|
||
|
display: block;
|
||
|
white-space: nowrap;
|
||
|
vertical-align: top;
|
||
|
position: relative;
|
||
|
padding: 10px;
|
||
|
padding-bottom: 300px;
|
||
|
margin-bottom: -290px;
|
||
|
|
||
|
@media (min-width: @screen-sm) {
|
||
|
display: inline-block;
|
||
|
}
|
||
|
}
|
||
|
.sp-picker-container {
|
||
|
width: 220px;
|
||
|
}
|
||
|
|
||
|
// Disable user selection
|
||
|
.sp-container,
|
||
|
.sp-replacer,
|
||
|
.sp-preview,
|
||
|
.sp-dragger,
|
||
|
.sp-slider,
|
||
|
.sp-alpha,
|
||
|
.sp-clear,
|
||
|
.sp-alpha-handle,
|
||
|
.sp-container.sp-dragging .sp-input,
|
||
|
.sp-container button {
|
||
|
.user-select(none);
|
||
|
}
|
||
|
|
||
|
|
||
|
|
||
|
// Picker elements
|
||
|
// ------------------------------
|
||
|
|
||
|
// Colors and hue areas
|
||
|
.sp-top {
|
||
|
position: relative;
|
||
|
width: 100%;
|
||
|
display: block;
|
||
|
}
|
||
|
.sp-color {
|
||
|
right: 20%;
|
||
|
}
|
||
|
.sp-hue {
|
||
|
left: 85%;
|
||
|
height: 100%;
|
||
|
}
|
||
|
.sp-clear-enabled .sp-hue {
|
||
|
top: 40px;
|
||
|
height: 75%;
|
||
|
}
|
||
|
.sp-fill {
|
||
|
padding-top: 80%;
|
||
|
}
|
||
|
|
||
|
// Alpha
|
||
|
.sp-alpha-enabled {
|
||
|
.sp-top {
|
||
|
margin-bottom: 26px;
|
||
|
}
|
||
|
|
||
|
.sp-alpha {
|
||
|
display: block;
|
||
|
}
|
||
|
}
|
||
|
.sp-alpha-handle {
|
||
|
position: absolute;
|
||
|
top: -4px;
|
||
|
bottom: -4px;
|
||
|
width: 5px;
|
||
|
left: 50%;
|
||
|
cursor: pointer;
|
||
|
border: 1px solid @gray-light;
|
||
|
background-color: #fff;
|
||
|
border-radius: @border-radius-large;
|
||
|
}
|
||
|
.sp-alpha {
|
||
|
display: none;
|
||
|
position: absolute;
|
||
|
bottom: -16px;
|
||
|
right: 0;
|
||
|
left: 0;
|
||
|
height: 6px;
|
||
|
}
|
||
|
|
||
|
// Clear
|
||
|
.sp-clear {
|
||
|
display: none;
|
||
|
}
|
||
|
.sp-clear-display {
|
||
|
cursor: pointer;
|
||
|
|
||
|
// Icon
|
||
|
&:after {
|
||
|
content: '\ee6e';
|
||
|
display: block;
|
||
|
font-family: 'icomoon';
|
||
|
font-size: @icon-font-size;
|
||
|
-webkit-font-smoothing: antialiased;
|
||
|
-moz-osx-font-smoothing: grayscale;
|
||
|
line-height: 30px;
|
||
|
}
|
||
|
|
||
|
// Hide icon in previews
|
||
|
.sp-preview &:after,
|
||
|
.sp-initial &:after {
|
||
|
content: none;
|
||
|
}
|
||
|
}
|
||
|
.sp-clear-enabled .sp-clear {
|
||
|
display: block;
|
||
|
left: 85%;
|
||
|
height: 30px;
|
||
|
text-align: center;
|
||
|
color: #999;
|
||
|
.box-shadow(0 0 0 1px #ddd inset);
|
||
|
}
|
||
|
|
||
|
// Input
|
||
|
.sp-input-container {
|
||
|
margin-top: 10px;
|
||
|
|
||
|
.sp-initial-disabled & {
|
||
|
width: 100%;
|
||
|
}
|
||
|
}
|
||
|
.sp-input {
|
||
|
border: 1px solid @input-border;
|
||
|
padding: @padding-base-vertical @padding-base-horizontal;
|
||
|
width: 100%;
|
||
|
background-color: @input-bg;
|
||
|
border-radius: @input-border-radius;
|
||
|
outline: 0;
|
||
|
color: @input-color;
|
||
|
}
|
||
|
|
||
|
// Initial
|
||
|
.sp-initial {
|
||
|
margin-top: 10px;
|
||
|
|
||
|
span {
|
||
|
width: 50%;
|
||
|
height: 25px;
|
||
|
display: block;
|
||
|
float: left;
|
||
|
|
||
|
.sp-thumb-inner {
|
||
|
height: 25px;
|
||
|
width: 100%;
|
||
|
display: block;
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
// Dragger and slider
|
||
|
.sp-dragger {
|
||
|
height: 5px;
|
||
|
width: 5px;
|
||
|
border: 1px solid #fff;
|
||
|
background-color: #333;
|
||
|
cursor: pointer;
|
||
|
position: absolute;
|
||
|
top: 0;
|
||
|
left: 0;
|
||
|
}
|
||
|
.sp-slider {
|
||
|
position: absolute;
|
||
|
top: 0;
|
||
|
cursor: pointer;
|
||
|
height: 4px;
|
||
|
left: -2px;
|
||
|
right: -2px;
|
||
|
border: 1px solid @gray-light;
|
||
|
background-color: #fff;
|
||
|
border-radius: @border-radius-base;
|
||
|
}
|
||
|
|
||
|
|
||
|
|
||
|
// Color preview
|
||
|
// ------------------------------
|
||
|
|
||
|
// Replacer (the little preview div that shows up instead of the <input>)
|
||
|
.sp-replacer {
|
||
|
overflow: hidden;
|
||
|
cursor: pointer;
|
||
|
padding: 5px;
|
||
|
display: inline-block;
|
||
|
border: 1px solid @input-border;
|
||
|
background-color: #fafafa;
|
||
|
vertical-align: middle;
|
||
|
border-radius: @input-border-radius;
|
||
|
|
||
|
// States
|
||
|
&:hover,
|
||
|
&.sp-active {
|
||
|
border-color: darken(@input-border, 10%);
|
||
|
color: @text-color;
|
||
|
|
||
|
.sp-dd {
|
||
|
color: @text-color;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
// Custom color replacer
|
||
|
&[class*=bg-] {
|
||
|
&,
|
||
|
&:hover,
|
||
|
&:focus {
|
||
|
border-color: transparent;
|
||
|
}
|
||
|
|
||
|
.sp-dd {
|
||
|
color: #fff;
|
||
|
}
|
||
|
|
||
|
&.sp-active .sp-dd {
|
||
|
color: #fff;
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
// Disabled state
|
||
|
.sp-replacer {
|
||
|
&.sp-disabled {
|
||
|
cursor: default;
|
||
|
.opacity(0.8);
|
||
|
|
||
|
&:not([class*=bg-]) {
|
||
|
&:hover,
|
||
|
&:focus {
|
||
|
border-color: @input-border;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
.sp-dd,
|
||
|
&[class*=bg-] .sp-dd {
|
||
|
color: @text-muted;
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
// Color preview
|
||
|
.sp-preview {
|
||
|
position: relative;
|
||
|
width: 26px;
|
||
|
height: 24px;
|
||
|
margin-right: 5px;
|
||
|
float: left;
|
||
|
z-index: 0;
|
||
|
|
||
|
.sp-preview-inner,
|
||
|
.sp-clear-display {
|
||
|
.box-shadow(0 0 0 1px fade(#000, 5%));
|
||
|
}
|
||
|
|
||
|
.sp-replacer[class*=bg-] & {
|
||
|
.sp-preview-inner {
|
||
|
.box-shadow(0 0 0 1px fade(#000, 50%));
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
// Arrow
|
||
|
.sp-dd {
|
||
|
float: left;
|
||
|
font-size: 0;
|
||
|
position: relative;
|
||
|
margin: 3px 1px;
|
||
|
color: @gray-light;
|
||
|
|
||
|
// Arrow icon
|
||
|
&:after {
|
||
|
content: '\e9c5';
|
||
|
display: block;
|
||
|
font-family: 'icomoon';
|
||
|
font-size: @icon-font-size;
|
||
|
line-height: 1;
|
||
|
-webkit-font-smoothing: antialiased;
|
||
|
-moz-osx-font-smoothing: grayscale;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
|
||
|
|
||
|
// Gradients
|
||
|
// ------------------------------
|
||
|
|
||
|
// Gradients for hue, saturation and value instead of images. Not pretty... but it works
|
||
|
.sp-sat {
|
||
|
background-image: -webkit-gradient(linear, 0 0, 100% 0, from(#FFF), to(rgba(204, 154, 129, 0)));
|
||
|
background-image: -webkit-linear-gradient(left, #FFF, rgba(204, 154, 129, 0));
|
||
|
background-image: -moz-linear-gradient(left, #fff, rgba(204, 154, 129, 0));
|
||
|
background-image: -o-linear-gradient(left, #fff, rgba(204, 154, 129, 0));
|
||
|
background-image: -ms-linear-gradient(left, #fff, rgba(204, 154, 129, 0));
|
||
|
background-image: linear-gradient(to right, #fff, rgba(204, 154, 129, 0));
|
||
|
-ms-filter: "progid:DXImageTransform.Microsoft.gradient(GradientType = 1, startColorstr=#FFFFFFFF, endColorstr=#00CC9A81)";
|
||
|
filter : progid:DXImageTransform.Microsoft.gradient(GradientType = 1, startColorstr='#FFFFFFFF', endColorstr='#00CC9A81');
|
||
|
.box-shadow(0 0 0 1px #ccc inset);
|
||
|
}
|
||
|
.sp-val {
|
||
|
background-image: -webkit-gradient(linear, 0 100%, 0 0, from(#000000), to(rgba(204, 154, 129, 0)));
|
||
|
background-image: -webkit-linear-gradient(bottom, #000000, rgba(204, 154, 129, 0));
|
||
|
background-image: -moz-linear-gradient(bottom, #000, rgba(204, 154, 129, 0));
|
||
|
background-image: -o-linear-gradient(bottom, #000, rgba(204, 154, 129, 0));
|
||
|
background-image: -ms-linear-gradient(bottom, #000, rgba(204, 154, 129, 0));
|
||
|
background-image: linear-gradient(to top, #000, rgba(204, 154, 129, 0));
|
||
|
-ms-filter: "progid:DXImageTransform.Microsoft.gradient(startColorstr=#00CC9A81, endColorstr=#FF000000)";
|
||
|
filter : progid:DXImageTransform.Microsoft.gradient(startColorstr='#00CC9A81', endColorstr='#FF000000');
|
||
|
}
|
||
|
.sp-hue {
|
||
|
background: -moz-linear-gradient(top, #ff0000 0%, #ffff00 17%, #00ff00 33%, #00ffff 50%, #0000ff 67%, #ff00ff 83%, #ff0000 100%);
|
||
|
background: -ms-linear-gradient(top, #ff0000 0%, #ffff00 17%, #00ff00 33%, #00ffff 50%, #0000ff 67%, #ff00ff 83%, #ff0000 100%);
|
||
|
background: -o-linear-gradient(top, #ff0000 0%, #ffff00 17%, #00ff00 33%, #00ffff 50%, #0000ff 67%, #ff00ff 83%, #ff0000 100%);
|
||
|
background: -webkit-gradient(linear, left top, left bottom, from(#ff0000), color-stop(0.17, #ffff00), color-stop(0.33, #00ff00), color-stop(0.5, #00ffff), color-stop(0.67, #0000ff), color-stop(0.83, #ff00ff), to(#ff0000));
|
||
|
background: -webkit-linear-gradient(top, #ff0000 0%, #ffff00 17%, #00ff00 33%, #00ffff 50%, #0000ff 67%, #ff00ff 83%, #ff0000 100%);
|
||
|
background: linear-gradient(to bottom, #ff0000 0%, #ffff00 17%, #00ff00 33%, #00ffff 50%, #0000ff 67%, #ff00ff 83%, #ff0000 100%);
|
||
|
}
|
||
|
|
||
|
|
||
|
//
|
||
|
// IE filters do not support multiple color stops.
|
||
|
// Generate 6 divs, line them up, and do two color gradients for each.
|
||
|
// Yes, really.
|
||
|
//
|
||
|
|
||
|
.sp-1 {
|
||
|
height: 17%;
|
||
|
filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#ff0000', endColorstr='#ffff00');
|
||
|
}
|
||
|
.sp-2 {
|
||
|
height: 16%;
|
||
|
filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#ffff00', endColorstr='#00ff00');
|
||
|
}
|
||
|
.sp-3 {
|
||
|
height: 17%;
|
||
|
filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#00ff00', endColorstr='#00ffff');
|
||
|
}
|
||
|
.sp-4 {
|
||
|
height: 17%;
|
||
|
filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#00ffff', endColorstr='#0000ff');
|
||
|
}
|
||
|
.sp-5 {
|
||
|
height: 16%;
|
||
|
filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#0000ff', endColorstr='#ff00ff');
|
||
|
}
|
||
|
.sp-6 {
|
||
|
height: 17%;
|
||
|
filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#ff00ff', endColorstr='#ff0000');
|
||
|
}
|
||
|
|
||
|
|
||
|
|
||
|
// Color palettes
|
||
|
// ------------------------------
|
||
|
|
||
|
// Basic styles
|
||
|
.sp-palette {
|
||
|
max-width: 220px;
|
||
|
}
|
||
|
.sp-palette-container {
|
||
|
.sp-palette-only & {
|
||
|
border: 0;
|
||
|
}
|
||
|
|
||
|
@media (min-width: @screen-sm) {
|
||
|
border-right: 1px solid @dropdown-border;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
// Palette thumbs
|
||
|
.sp-thumb-el {
|
||
|
position: relative;
|
||
|
|
||
|
.sp-palette & {
|
||
|
display: inline-block;
|
||
|
position: relative;
|
||
|
cursor: pointer;
|
||
|
}
|
||
|
|
||
|
// Add 1px inner semi-transparent border
|
||
|
.sp-thumb-inner {
|
||
|
.box-shadow(0 0 0 1px fade(#000, 10%) inset);
|
||
|
|
||
|
&:hover {
|
||
|
.box-shadow(0 0 0 1px fade(#000, 25%) inset);
|
||
|
}
|
||
|
}
|
||
|
|
||
|
.sp-palette & {
|
||
|
width: 16px;
|
||
|
height: 16px;
|
||
|
|
||
|
+ .sp-thumb-el {
|
||
|
margin-left: 5px;
|
||
|
}
|
||
|
|
||
|
&.sp-thumb-active {
|
||
|
.box-shadow(0 0 0 2px fade(#000, 10%) inset);
|
||
|
|
||
|
.sp-thumb-inner {
|
||
|
.box-shadow(0 0 0 1px fade(#000, 25%) inset);
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
// Adding checkmark to the active thumb
|
||
|
.sp-palette {
|
||
|
.sp-thumb-active {
|
||
|
&.sp-thumb-dark,
|
||
|
&.sp-thumb-light {
|
||
|
.sp-thumb-inner {
|
||
|
&:after {
|
||
|
content: '\e600';
|
||
|
display: block;
|
||
|
font-family: 'icomoon';
|
||
|
font-size: @icon-font-size;
|
||
|
line-height: 1;
|
||
|
color: #fff;
|
||
|
-webkit-font-smoothing: antialiased;
|
||
|
-moz-osx-font-smoothing: grayscale;
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
&.sp-thumb-light .sp-thumb-inner:after {
|
||
|
color: @text-color;
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
// Thumbnail row
|
||
|
.sp-palette-row {
|
||
|
font-size: 0;
|
||
|
|
||
|
& + .sp-palette-row {
|
||
|
margin-top: 5px;
|
||
|
}
|
||
|
|
||
|
&:empty {
|
||
|
margin-top: 0;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
|
||
|
|
||
|
// Picker buttons
|
||
|
// ------------------------------
|
||
|
|
||
|
// Button base
|
||
|
.sp-cancel,
|
||
|
.sp-choose,
|
||
|
.sp-palette-toggle {
|
||
|
border: 0;
|
||
|
border-radius: @border-radius-small;
|
||
|
padding: @padding-small-vertical @padding-small-horizontal;
|
||
|
float: left;
|
||
|
width: 48%;
|
||
|
text-align: center;
|
||
|
outline: 0;
|
||
|
}
|
||
|
|
||
|
// Button containers
|
||
|
.sp-palette-button-container,
|
||
|
.sp-button-container {
|
||
|
margin-top: 10px;
|
||
|
text-align: center;
|
||
|
|
||
|
// In colored container
|
||
|
.sp-container[class*=bg-] & {
|
||
|
a,
|
||
|
button {
|
||
|
background-color: fade(#000, 25%);
|
||
|
color: #fff;
|
||
|
border-color: transparent;
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
// Button states
|
||
|
.sp-cancel,
|
||
|
.sp-palette-toggle {
|
||
|
border: 1px solid transparent;
|
||
|
|
||
|
// Hover state
|
||
|
&:hover,
|
||
|
&:focus {
|
||
|
.box-shadow(0 0 0 100px fade(#000, 1%) inset);
|
||
|
}
|
||
|
|
||
|
// Active state
|
||
|
&:active {
|
||
|
.box-shadow(0 0 0 100px fade(#000, 3%) inset);
|
||
|
}
|
||
|
}
|
||
|
|
||
|
// Choose button
|
||
|
.sp-choose {
|
||
|
border: 1px solid transparent;
|
||
|
|
||
|
// Hover state
|
||
|
&:hover,
|
||
|
&:focus {
|
||
|
.box-shadow(0 0 0 100px fade(#000, 5%) inset);
|
||
|
}
|
||
|
|
||
|
// Active state
|
||
|
&:active {
|
||
|
.box-shadow(0 0 0 100px fade(#000, 10%) inset);
|
||
|
}
|
||
|
|
||
|
}
|
||
|
|
||
|
// Cancel and palette toggle buttons
|
||
|
.sp-cancel,
|
||
|
.sp-palette-toggle {
|
||
|
color: @btn-default-color;
|
||
|
margin-right: 5px;
|
||
|
background-color: @btn-default-bg;
|
||
|
margin-right: 4%;
|
||
|
border-color: @btn-default-border;
|
||
|
|
||
|
&:hover,
|
||
|
&:focus {
|
||
|
color: @btn-default-color;
|
||
|
}
|
||
|
}
|
||
|
.sp-palette-toggle {
|
||
|
margin-right: 0;
|
||
|
width: auto;
|
||
|
float: none;
|
||
|
}
|
||
|
|
||
|
// Choose button
|
||
|
.sp-choose {
|
||
|
color: #fff;
|
||
|
background-color: @color-slate-500;
|
||
|
}
|