blob: bd1010e20f85462df698b5f6fcf63b4621819483 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
|
// Copyright 2017 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#include "third_party/blink/renderer/core/css/properties/longhands/caret_color.h"
#include "third_party/blink/renderer/core/css/css_color_value.h"
#include "third_party/blink/renderer/core/css/parser/css_parser_context.h"
#include "third_party/blink/renderer/core/css/parser/css_property_parser_helpers.h"
#include "third_party/blink/renderer/core/css/resolver/style_builder_converter.h"
#include "third_party/blink/renderer/core/style/computed_style.h"
namespace blink {
namespace CSSLonghand {
const CSSValue* CaretColor::ParseSingleValue(
CSSParserTokenRange& range,
const CSSParserContext& context,
const CSSParserLocalContext&) const {
if (range.Peek().Id() == CSSValueAuto)
return CSSPropertyParserHelpers::ConsumeIdent(range);
return CSSPropertyParserHelpers::ConsumeColor(range, context.Mode());
}
const blink::Color CaretColor::ColorIncludingFallback(
bool visited_link,
const ComputedStyle& style) const {
StyleAutoColor auto_color =
visited_link ? style.VisitedLinkCaretColor() : style.CaretColor();
// TODO(rego): We may want to adjust the caret color if it's the same as
// the background to ensure good visibility and contrast.
StyleColor result = auto_color.IsAutoColor() ? StyleColor::CurrentColor()
: auto_color.ToStyleColor();
if (!result.IsCurrentColor())
return result.GetColor();
return visited_link ? style.VisitedLinkColor() : style.GetColor();
}
const CSSValue* CaretColor::CSSValueFromComputedStyleInternal(
const ComputedStyle& style,
const SVGComputedStyle&,
const LayoutObject*,
Node*,
bool allow_visited_style) const {
blink::Color color;
if (allow_visited_style)
color = style.VisitedDependentColor(*this);
else if (style.CaretColor().IsAutoColor())
color = StyleColor::CurrentColor().Resolve(style.GetColor());
else
color = style.CaretColor().ToStyleColor().Resolve(style.GetColor());
return cssvalue::CSSColorValue::Create(color.Rgb());
}
void CaretColor::ApplyInitial(StyleResolverState& state) const {
StyleAutoColor color = StyleAutoColor::AutoColor();
if (state.ApplyPropertyToRegularStyle())
state.Style()->SetCaretColor(color);
if (state.ApplyPropertyToVisitedLinkStyle())
state.Style()->SetVisitedLinkCaretColor(color);
}
void CaretColor::ApplyInherit(StyleResolverState& state) const {
StyleAutoColor color = state.ParentStyle()->CaretColor();
if (state.ApplyPropertyToRegularStyle())
state.Style()->SetCaretColor(color);
if (state.ApplyPropertyToVisitedLinkStyle())
state.Style()->SetVisitedLinkCaretColor(color);
}
void CaretColor::ApplyValue(StyleResolverState& state,
const CSSValue& value) const {
if (state.ApplyPropertyToRegularStyle()) {
state.Style()->SetCaretColor(
StyleBuilderConverter::ConvertStyleAutoColor(state, value));
}
if (state.ApplyPropertyToVisitedLinkStyle()) {
state.Style()->SetVisitedLinkCaretColor(
StyleBuilderConverter::ConvertStyleAutoColor(state, value, true));
}
}
} // namespace CSSLonghand
} // namespace blink
|