diff --git a/examples/components/tag.html b/examples/components/tag.html index 164762b6..b6d2a59a 100644 --- a/examples/components/tag.html +++ b/examples/components/tag.html @@ -50,6 +50,20 @@ tags + +

+ +
+ tags + + tags + + tags + + tags + + tags +
diff --git a/scss/abstracts/icon/mixin-mask-icon.scss b/scss/abstracts/icon/mixin-mask-icon.scss index 62ba5b3f..2ef45590 100644 --- a/scss/abstracts/icon/mixin-mask-icon.scss +++ b/scss/abstracts/icon/mixin-mask-icon.scss @@ -1,4 +1,4 @@ -@mixin ch-mask-icon ($image, $option: 'complete') { +@mixin ch-mask-icon ($image, $option: 'complete', $backgroundColor: ch-get-color(text, 2)) { mask-image: url(#{$image}); -webkit-mask-image: url(#{$image}); @@ -7,6 +7,6 @@ -webkit-mask-repeat: no-repeat; mask-position: center; -webkit-mask-position: center; - background-color: #{ch-get-color(text, 2)}; + background-color: $backgroundColor; } } diff --git a/scss/abstracts/icon/variables.scss b/scss/abstracts/icon/variables.scss index b96c1147..cd02edf5 100644 --- a/scss/abstracts/icon/variables.scss +++ b/scss/abstracts/icon/variables.scss @@ -18,3 +18,5 @@ $ch-icon-angle-left: ' $ch-icon-nav-expand: ''; $ch-icon-nav-retract: ''; + +$ch-icon-check: ' ' diff --git a/scss/components/checkbox/checkbox.scss b/scss/components/checkbox/checkbox.scss index 1415616d..6740a9b5 100644 --- a/scss/components/checkbox/checkbox.scss +++ b/scss/components/checkbox/checkbox.scss @@ -31,9 +31,7 @@ + label:before, + label:after { - $empty: ''; - - content: $empty; + content: ''; } // 2.1. Wrapper @@ -71,13 +69,43 @@ width: $size; height: $size; } - + } + + // 3. Checkbox + + @at-root .ch-checkbox > input[type="checkbox"] { + &:checked:not([readonly]) + label:before { + background-color: ch-get-color(primary); + border-color: ch-get-color(primary); + } + &:checked + label:after { - background: #{ch-get-color(primary)}; + @include ch-mask-icon($ch-icon-check 'only-mask', $option: 'complete', $backgroundColor: ch-get-color(neutral, 1)); + } + + &[readonly] + label:after { + background-color: ch-get-color(text, 1); } } - // 3. Label + // 4. Radio + + @at-root .ch-radio > input[type="radio"] { + + label:before, + &:checked + label:after { + border-radius: ch-get-border-radius(circle); + } + + &:checked + label:before { + border-color: ch-get-color(primary, focus); + } + + &:checked + label:after { + background: ch-get-color(primary); + } + } + + // 5. Label > input[type="checkbox"] + label, > input[type="radio"] + label { @@ -92,7 +120,7 @@ } } - // 4. Disabled and readonly states + // 6. Disabled and readonly states > input { &:disabled, @@ -137,7 +165,7 @@ } } - // 5. Negative variation + // 7. Negative variation &--negative { color: #{ch-get-color(negative)}; @@ -163,13 +191,4 @@ } } } - - // 6. Radio - - @at-root .ch-radio > input[type="radio"] { - + label:before, - &:checked + label:after { - border-radius: ch-get-border-radius(circle); - } - } } diff --git a/scss/components/table/table.scss b/scss/components/table/table.scss index 99dc672c..0a10bf03 100644 --- a/scss/components/table/table.scss +++ b/scss/components/table/table.scss @@ -11,6 +11,7 @@ &-header, thead { display: table-header-group; + background-color: ch-get-color(neutral, 2); } // 3. Content @@ -81,6 +82,11 @@ vertical-align: middle; } + th { + @include ch-space-inset(default, s); + font-weight: ch-get-text-weight(semibold); + } + // 5.1. Leading, actions and compact variation .ch-table-cell--leading, diff --git a/scss/components/tag/tag.scss b/scss/components/tag/tag.scss index 1f341804..04bab5e1 100644 --- a/scss/components/tag/tag.scss +++ b/scss/components/tag/tag.scss @@ -5,6 +5,7 @@ @include ch-text-caption; @include ch-truncate; + @include ch-border-radius(circle); display: inline-block; position: relative; @@ -16,6 +17,8 @@ vertical-align: middle; padding-right: ch-get-space(s); padding-left: ch-get-space(s); + background-color: ch-get-color(neutral, 2); + box-shadow: 0 0 0px 1px currentColor; // 2. Close button @@ -47,51 +50,30 @@ } } - // 3. Background - - &, - &:after { - @include ch-border-radius(circle); - } - - &:after { - display: block; - position: absolute; - top: 0; - left: 0; - z-index: -1; - - content: ''; - width: 100%; - height: 100%; - background: #{ch-get-color(neutral, 2)}; + &.is-borderless { + box-shadow: none; } // 4. Support variations @each $variation in (info, warning, positive, negative) { &--#{$variation} { - color: ch-get-color($variation); + color: if($variation != 'warning', ch-get-color($variation), ch-get-color($variation, focus)); + background-image: linear-gradient(90deg, rgba(#fff, 0.85), rgba(#fff, 0.85)); + background-color: ch-get-color($variation); // 4.1. Close button > .ch-tag-close { - background-color: ch-get-color($variation); - + background-color: if($variation != 'warning', ch-get-color($variation), ch-get-color($variation, focus)); + &:hover:focus, &:hover, &:focus, &:active { - background-color: ch-get-color($variation, focus); + background-color: if($variation != 'warning', ch-get-color($variation, focus), ch-get-color($variation, active)); } } - - // 4.2. Background - - &:after { - opacity: 0.15; - background: #{ch-get-color($variation)}; - } } } }