StyleValue.cpp 10 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259
  1. /*
  2. * Copyright (c) 2018-2020, Andreas Kling <kling@serenityos.org>
  3. * Copyright (c) 2021, Sam Atkins <atkinssj@serenityos.org>
  4. *
  5. * SPDX-License-Identifier: BSD-2-Clause
  6. */
  7. #include <AK/ByteBuffer.h>
  8. #include <LibGfx/Palette.h>
  9. #include <LibWeb/CSS/Parser/StyleComponentValueRule.h>
  10. #include <LibWeb/CSS/StyleValue.h>
  11. #include <LibWeb/DOM/Document.h>
  12. #include <LibWeb/Loader/LoadRequest.h>
  13. #include <LibWeb/Loader/ResourceLoader.h>
  14. #include <LibWeb/Page/BrowsingContext.h>
  15. #include <LibWeb/Page/Page.h>
  16. namespace Web::CSS {
  17. StyleValue::StyleValue(Type type)
  18. : m_type(type)
  19. {
  20. }
  21. StyleValue::~StyleValue()
  22. {
  23. }
  24. bool StyleValue::is_color() const
  25. {
  26. if (type() == Type::Color)
  27. return true;
  28. if (type() != Type::Identifier)
  29. return false;
  30. switch (to_identifier()) {
  31. case ValueID::Currentcolor:
  32. case ValueID::LibwebLink:
  33. case ValueID::LibwebPaletteActiveLink:
  34. case ValueID::LibwebPaletteActiveWindowBorder1:
  35. case ValueID::LibwebPaletteActiveWindowBorder2:
  36. case ValueID::LibwebPaletteActiveWindowTitle:
  37. case ValueID::LibwebPaletteBase:
  38. case ValueID::LibwebPaletteBaseText:
  39. case ValueID::LibwebPaletteButton:
  40. case ValueID::LibwebPaletteButtonText:
  41. case ValueID::LibwebPaletteDesktopBackground:
  42. case ValueID::LibwebPaletteFocusOutline:
  43. case ValueID::LibwebPaletteHighlightWindowBorder1:
  44. case ValueID::LibwebPaletteHighlightWindowBorder2:
  45. case ValueID::LibwebPaletteHighlightWindowTitle:
  46. case ValueID::LibwebPaletteHoverHighlight:
  47. case ValueID::LibwebPaletteInactiveSelection:
  48. case ValueID::LibwebPaletteInactiveSelectionText:
  49. case ValueID::LibwebPaletteInactiveWindowBorder1:
  50. case ValueID::LibwebPaletteInactiveWindowBorder2:
  51. case ValueID::LibwebPaletteInactiveWindowTitle:
  52. case ValueID::LibwebPaletteLink:
  53. case ValueID::LibwebPaletteMenuBase:
  54. case ValueID::LibwebPaletteMenuBaseText:
  55. case ValueID::LibwebPaletteMenuSelection:
  56. case ValueID::LibwebPaletteMenuSelectionText:
  57. case ValueID::LibwebPaletteMenuStripe:
  58. case ValueID::LibwebPaletteMovingWindowBorder1:
  59. case ValueID::LibwebPaletteMovingWindowBorder2:
  60. case ValueID::LibwebPaletteMovingWindowTitle:
  61. case ValueID::LibwebPaletteRubberBandBorder:
  62. case ValueID::LibwebPaletteRubberBandFill:
  63. case ValueID::LibwebPaletteRuler:
  64. case ValueID::LibwebPaletteRulerActiveText:
  65. case ValueID::LibwebPaletteRulerBorder:
  66. case ValueID::LibwebPaletteRulerInactiveText:
  67. case ValueID::LibwebPaletteSelection:
  68. case ValueID::LibwebPaletteSelectionText:
  69. case ValueID::LibwebPaletteSyntaxComment:
  70. case ValueID::LibwebPaletteSyntaxControlKeyword:
  71. case ValueID::LibwebPaletteSyntaxIdentifier:
  72. case ValueID::LibwebPaletteSyntaxKeyword:
  73. case ValueID::LibwebPaletteSyntaxNumber:
  74. case ValueID::LibwebPaletteSyntaxOperator:
  75. case ValueID::LibwebPaletteSyntaxPreprocessorStatement:
  76. case ValueID::LibwebPaletteSyntaxPreprocessorValue:
  77. case ValueID::LibwebPaletteSyntaxPunctuation:
  78. case ValueID::LibwebPaletteSyntaxString:
  79. case ValueID::LibwebPaletteSyntaxType:
  80. case ValueID::LibwebPaletteTextCursor:
  81. case ValueID::LibwebPaletteThreedHighlight:
  82. case ValueID::LibwebPaletteThreedShadow1:
  83. case ValueID::LibwebPaletteThreedShadow2:
  84. case ValueID::LibwebPaletteVisitedLink:
  85. case ValueID::LibwebPaletteWindow:
  86. case ValueID::LibwebPaletteWindowText:
  87. return true;
  88. default:
  89. break;
  90. }
  91. return false;
  92. }
  93. float StyleValue::as_number() const
  94. {
  95. VERIFY(is_numeric());
  96. return static_cast<NumericStyleValue const&>(*this).value();
  97. }
  98. String IdentifierStyleValue::to_string() const
  99. {
  100. return CSS::string_from_value_id(m_id);
  101. }
  102. Color IdentifierStyleValue::to_color(Layout::NodeWithStyle const& node) const
  103. {
  104. if (id() == CSS::ValueID::Currentcolor) {
  105. if (!node.has_style())
  106. return Color::Black;
  107. return node.computed_values().color();
  108. }
  109. auto& document = node.document();
  110. if (id() == CSS::ValueID::LibwebLink)
  111. return document.link_color();
  112. VERIFY(document.page());
  113. auto palette = document.page()->palette();
  114. switch (id()) {
  115. case CSS::ValueID::LibwebPaletteDesktopBackground:
  116. return palette.color(ColorRole::DesktopBackground);
  117. case CSS::ValueID::LibwebPaletteActiveWindowBorder1:
  118. return palette.color(ColorRole::ActiveWindowBorder1);
  119. case CSS::ValueID::LibwebPaletteActiveWindowBorder2:
  120. return palette.color(ColorRole::ActiveWindowBorder2);
  121. case CSS::ValueID::LibwebPaletteActiveWindowTitle:
  122. return palette.color(ColorRole::ActiveWindowTitle);
  123. case CSS::ValueID::LibwebPaletteInactiveWindowBorder1:
  124. return palette.color(ColorRole::InactiveWindowBorder1);
  125. case CSS::ValueID::LibwebPaletteInactiveWindowBorder2:
  126. return palette.color(ColorRole::InactiveWindowBorder2);
  127. case CSS::ValueID::LibwebPaletteInactiveWindowTitle:
  128. return palette.color(ColorRole::InactiveWindowTitle);
  129. case CSS::ValueID::LibwebPaletteMovingWindowBorder1:
  130. return palette.color(ColorRole::MovingWindowBorder1);
  131. case CSS::ValueID::LibwebPaletteMovingWindowBorder2:
  132. return palette.color(ColorRole::MovingWindowBorder2);
  133. case CSS::ValueID::LibwebPaletteMovingWindowTitle:
  134. return palette.color(ColorRole::MovingWindowTitle);
  135. case CSS::ValueID::LibwebPaletteHighlightWindowBorder1:
  136. return palette.color(ColorRole::HighlightWindowBorder1);
  137. case CSS::ValueID::LibwebPaletteHighlightWindowBorder2:
  138. return palette.color(ColorRole::HighlightWindowBorder2);
  139. case CSS::ValueID::LibwebPaletteHighlightWindowTitle:
  140. return palette.color(ColorRole::HighlightWindowTitle);
  141. case CSS::ValueID::LibwebPaletteMenuStripe:
  142. return palette.color(ColorRole::MenuStripe);
  143. case CSS::ValueID::LibwebPaletteMenuBase:
  144. return palette.color(ColorRole::MenuBase);
  145. case CSS::ValueID::LibwebPaletteMenuBaseText:
  146. return palette.color(ColorRole::MenuBaseText);
  147. case CSS::ValueID::LibwebPaletteMenuSelection:
  148. return palette.color(ColorRole::MenuSelection);
  149. case CSS::ValueID::LibwebPaletteMenuSelectionText:
  150. return palette.color(ColorRole::MenuSelectionText);
  151. case CSS::ValueID::LibwebPaletteWindow:
  152. return palette.color(ColorRole::Window);
  153. case CSS::ValueID::LibwebPaletteWindowText:
  154. return palette.color(ColorRole::WindowText);
  155. case CSS::ValueID::LibwebPaletteButton:
  156. return palette.color(ColorRole::Button);
  157. case CSS::ValueID::LibwebPaletteButtonText:
  158. return palette.color(ColorRole::ButtonText);
  159. case CSS::ValueID::LibwebPaletteBase:
  160. return palette.color(ColorRole::Base);
  161. case CSS::ValueID::LibwebPaletteBaseText:
  162. return palette.color(ColorRole::BaseText);
  163. case CSS::ValueID::LibwebPaletteThreedHighlight:
  164. return palette.color(ColorRole::ThreedHighlight);
  165. case CSS::ValueID::LibwebPaletteThreedShadow1:
  166. return palette.color(ColorRole::ThreedShadow1);
  167. case CSS::ValueID::LibwebPaletteThreedShadow2:
  168. return palette.color(ColorRole::ThreedShadow2);
  169. case CSS::ValueID::LibwebPaletteHoverHighlight:
  170. return palette.color(ColorRole::HoverHighlight);
  171. case CSS::ValueID::LibwebPaletteSelection:
  172. return palette.color(ColorRole::Selection);
  173. case CSS::ValueID::LibwebPaletteSelectionText:
  174. return palette.color(ColorRole::SelectionText);
  175. case CSS::ValueID::LibwebPaletteInactiveSelection:
  176. return palette.color(ColorRole::InactiveSelection);
  177. case CSS::ValueID::LibwebPaletteInactiveSelectionText:
  178. return palette.color(ColorRole::InactiveSelectionText);
  179. case CSS::ValueID::LibwebPaletteRubberBandFill:
  180. return palette.color(ColorRole::RubberBandFill);
  181. case CSS::ValueID::LibwebPaletteRubberBandBorder:
  182. return palette.color(ColorRole::RubberBandBorder);
  183. case CSS::ValueID::LibwebPaletteLink:
  184. return palette.color(ColorRole::Link);
  185. case CSS::ValueID::LibwebPaletteActiveLink:
  186. return palette.color(ColorRole::ActiveLink);
  187. case CSS::ValueID::LibwebPaletteVisitedLink:
  188. return palette.color(ColorRole::VisitedLink);
  189. case CSS::ValueID::LibwebPaletteRuler:
  190. return palette.color(ColorRole::Ruler);
  191. case CSS::ValueID::LibwebPaletteRulerBorder:
  192. return palette.color(ColorRole::RulerBorder);
  193. case CSS::ValueID::LibwebPaletteRulerActiveText:
  194. return palette.color(ColorRole::RulerActiveText);
  195. case CSS::ValueID::LibwebPaletteRulerInactiveText:
  196. return palette.color(ColorRole::RulerInactiveText);
  197. case CSS::ValueID::LibwebPaletteTextCursor:
  198. return palette.color(ColorRole::TextCursor);
  199. case CSS::ValueID::LibwebPaletteFocusOutline:
  200. return palette.color(ColorRole::FocusOutline);
  201. case CSS::ValueID::LibwebPaletteSyntaxComment:
  202. return palette.color(ColorRole::SyntaxComment);
  203. case CSS::ValueID::LibwebPaletteSyntaxNumber:
  204. return palette.color(ColorRole::SyntaxNumber);
  205. case CSS::ValueID::LibwebPaletteSyntaxString:
  206. return palette.color(ColorRole::SyntaxString);
  207. case CSS::ValueID::LibwebPaletteSyntaxType:
  208. return palette.color(ColorRole::SyntaxType);
  209. case CSS::ValueID::LibwebPaletteSyntaxPunctuation:
  210. return palette.color(ColorRole::SyntaxPunctuation);
  211. case CSS::ValueID::LibwebPaletteSyntaxOperator:
  212. return palette.color(ColorRole::SyntaxOperator);
  213. case CSS::ValueID::LibwebPaletteSyntaxKeyword:
  214. return palette.color(ColorRole::SyntaxKeyword);
  215. case CSS::ValueID::LibwebPaletteSyntaxControlKeyword:
  216. return palette.color(ColorRole::SyntaxControlKeyword);
  217. case CSS::ValueID::LibwebPaletteSyntaxIdentifier:
  218. return palette.color(ColorRole::SyntaxIdentifier);
  219. case CSS::ValueID::LibwebPaletteSyntaxPreprocessorStatement:
  220. return palette.color(ColorRole::SyntaxPreprocessorStatement);
  221. case CSS::ValueID::LibwebPaletteSyntaxPreprocessorValue:
  222. return palette.color(ColorRole::SyntaxPreprocessorValue);
  223. default:
  224. return {};
  225. }
  226. }
  227. ImageStyleValue::ImageStyleValue(const AK::URL& url, DOM::Document& document)
  228. : StyleValue(Type::Image)
  229. , m_url(url)
  230. , m_document(document)
  231. {
  232. auto request = LoadRequest::create_for_url_on_page(url, document.page());
  233. set_resource(ResourceLoader::the().load_resource(Resource::Type::Image, request));
  234. }
  235. void ImageStyleValue::resource_did_load()
  236. {
  237. if (!m_document)
  238. return;
  239. m_bitmap = resource()->bitmap();
  240. // FIXME: Do less than a full repaint if possible?
  241. if (m_document->browsing_context())
  242. m_document->browsing_context()->set_needs_display({});
  243. }
  244. }