GridTrackSize.cpp 4.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212
  1. /*
  2. * Copyright (c) 2022, Martin Falisse <mfalisse@outlook.com>
  3. *
  4. * SPDX-License-Identifier: BSD-2-Clause
  5. */
  6. #include "GridTrackSize.h"
  7. #include <AK/DeprecatedString.h>
  8. #include <AK/String.h>
  9. #include <LibWeb/CSS/Length.h>
  10. #include <LibWeb/CSS/Percentage.h>
  11. #include <LibWeb/CSS/StyleValue.h>
  12. namespace Web::CSS {
  13. GridSize::GridSize(Length length)
  14. : m_type(Type::Length)
  15. , m_length(length)
  16. {
  17. }
  18. GridSize::GridSize(Percentage percentage)
  19. : m_type(Type::Percentage)
  20. , m_length { Length::make_px(0) }
  21. , m_percentage(percentage)
  22. {
  23. }
  24. GridSize::GridSize(float flexible_length)
  25. : m_type(Type::FlexibleLength)
  26. , m_length { Length::make_px(0) }
  27. , m_flexible_length(flexible_length)
  28. {
  29. }
  30. GridSize::GridSize(Type type)
  31. : m_length { Length::make_auto() }
  32. {
  33. VERIFY(type == Type::MinContent || type == Type::MaxContent);
  34. m_type = type;
  35. }
  36. GridSize::GridSize()
  37. : m_length { Length::make_auto() }
  38. {
  39. }
  40. GridSize::~GridSize() = default;
  41. GridSize GridSize::make_auto()
  42. {
  43. return GridSize(CSS::Length::make_auto());
  44. }
  45. ErrorOr<String> GridSize::to_string() const
  46. {
  47. switch (m_type) {
  48. case Type::Length:
  49. return m_length.to_string();
  50. case Type::Percentage:
  51. return m_percentage.to_string();
  52. case Type::FlexibleLength:
  53. return String::formatted("{}fr", m_flexible_length);
  54. case Type::MaxContent:
  55. return String::from_utf8("max-content"sv);
  56. case Type::MinContent:
  57. return String::from_utf8("min-content"sv);
  58. }
  59. VERIFY_NOT_REACHED();
  60. }
  61. Length GridSize::length() const
  62. {
  63. return m_length;
  64. }
  65. GridMinMax::GridMinMax(GridSize min_grid_size, GridSize max_grid_size)
  66. : m_min_grid_size(min_grid_size)
  67. , m_max_grid_size(max_grid_size)
  68. {
  69. }
  70. ErrorOr<String> GridMinMax::to_string() const
  71. {
  72. StringBuilder builder;
  73. builder.append("minmax("sv);
  74. builder.appendff("{}", TRY(m_min_grid_size.to_string()));
  75. builder.append(", "sv);
  76. builder.appendff("{}", TRY(m_max_grid_size.to_string()));
  77. builder.append(")"sv);
  78. return builder.to_string();
  79. }
  80. GridRepeat::GridRepeat(GridTrackSizeList grid_track_size_list, int repeat_count)
  81. : m_type(Type::Default)
  82. , m_grid_track_size_list(grid_track_size_list)
  83. , m_repeat_count(repeat_count)
  84. {
  85. }
  86. GridRepeat::GridRepeat(GridTrackSizeList grid_track_size_list, Type type)
  87. : m_type(type)
  88. , m_grid_track_size_list(grid_track_size_list)
  89. {
  90. }
  91. GridRepeat::GridRepeat()
  92. {
  93. }
  94. ErrorOr<String> GridRepeat::to_string() const
  95. {
  96. StringBuilder builder;
  97. builder.append("repeat("sv);
  98. switch (m_type) {
  99. case Type::AutoFit:
  100. builder.append("auto-fill"sv);
  101. break;
  102. case Type::AutoFill:
  103. builder.append("auto-fit"sv);
  104. break;
  105. case Type::Default:
  106. builder.appendff("{}", m_repeat_count);
  107. break;
  108. default:
  109. VERIFY_NOT_REACHED();
  110. }
  111. builder.append(", "sv);
  112. builder.appendff("{}", TRY(m_grid_track_size_list.to_string()));
  113. builder.append(")"sv);
  114. return builder.to_string();
  115. }
  116. ExplicitGridTrack::ExplicitGridTrack(CSS::GridMinMax grid_minmax)
  117. : m_type(Type::MinMax)
  118. , m_grid_minmax(grid_minmax)
  119. {
  120. }
  121. ExplicitGridTrack::ExplicitGridTrack(CSS::GridRepeat grid_repeat)
  122. : m_type(Type::Repeat)
  123. , m_grid_repeat(grid_repeat)
  124. {
  125. }
  126. ExplicitGridTrack::ExplicitGridTrack(CSS::GridSize grid_size)
  127. : m_type(Type::Default)
  128. , m_grid_size(grid_size)
  129. {
  130. }
  131. ErrorOr<String> ExplicitGridTrack::to_string() const
  132. {
  133. switch (m_type) {
  134. case Type::MinMax:
  135. return m_grid_minmax.to_string();
  136. case Type::Repeat:
  137. return m_grid_repeat.to_string();
  138. case Type::Default:
  139. return m_grid_size.to_string();
  140. default:
  141. VERIFY_NOT_REACHED();
  142. }
  143. }
  144. GridTrackSizeList::GridTrackSizeList(Vector<CSS::ExplicitGridTrack> track_list, Vector<Vector<String>> line_names)
  145. : m_track_list(track_list)
  146. , m_line_names(line_names)
  147. {
  148. }
  149. GridTrackSizeList::GridTrackSizeList()
  150. : m_track_list({})
  151. , m_line_names({})
  152. {
  153. }
  154. GridTrackSizeList GridTrackSizeList::make_auto()
  155. {
  156. return GridTrackSizeList();
  157. }
  158. ErrorOr<String> GridTrackSizeList::to_string() const
  159. {
  160. StringBuilder builder;
  161. auto print_line_names = [&](size_t index) -> void {
  162. builder.append("["sv);
  163. for (size_t y = 0; y < m_line_names[index].size(); ++y) {
  164. builder.append(m_line_names[index][y]);
  165. if (y != m_line_names[index].size() - 1)
  166. builder.append(" "sv);
  167. }
  168. builder.append("]"sv);
  169. };
  170. for (size_t i = 0; i < m_track_list.size(); ++i) {
  171. if (m_line_names[i].size() > 0) {
  172. print_line_names(i);
  173. builder.append(" "sv);
  174. }
  175. builder.append(TRY(m_track_list[i].to_string()));
  176. if (i < m_track_list.size() - 1)
  177. builder.append(" "sv);
  178. }
  179. if (m_line_names[m_track_list.size()].size() > 0) {
  180. builder.append(" "sv);
  181. print_line_names(m_track_list.size());
  182. }
  183. return builder.to_string();
  184. }
  185. }