Вы можете упростить метод контроллера, считая, что CreateProjectRequest
обработал всю необходимую проверку, и ее входы соответствуют входам, которые вы хотите обновить. Edit: я предпочитаю проверять все с помощью formrequests с правилами и к тому времени, когда он дойдет до контроллера, он просто звонит в службы или делает вещи. Что касается соглашений об именах, вам может не потребоваться отправить идентификатор $ в параметре url и отправить его в тело, чтобы избежать использования Request в formrequest для проверки того, существует ли он в базе данных
public function update($projectId, $id, CreateProjectRequest $request)
{
$data = $request->validated();
Page::findOrFail($id)->update($data);
return redirect('/projects/' . $projectId);
}
Вы можете использовать функцию, подобную этой, чтобы найти самый высокий элемент заголовка и установить остальные значения этого размера.
window.onload = resizeHeaders;
function resizeHeaders()
{
var headers = document.getElementsByClassName("column-header");
var maxHeight = 0;
for(var i = 0; i < headers.length; i++)
{
if(maxHeight < headers[i].offsetHeight)
maxHeight = headers[i].offsetHeight;
}
for(var i = 0; i < headers.length; i++)
{
headers[i].style.height = maxHeight+"px";
}
}
.column-stack {
display: -ms-flexbox;
display: flex;
-ms-flex-pack: justify;
justify-content: space-between;
padding: 30px
}
.column-stack ul {
-ms-flex: none;
flex: none;
width: calc(33.333% - 10px);
}
.column-stack ul .column-header {
font-size: 12px;
text-transform: uppercase;
color: #006a4d;
font-weight: 500;
padding-bottom: 5px;
border-bottom: 1px solid #3a3a3a;
display: flex;
align-items: stretch;
/* Default */
justify-content: space-between;
}
<div class="column-stack">
<ul>
<li class="column-header">Header 1 One Line</li>
<li>Item 1</li>
<li>Item 2</li>
<li>Item 3</li>
<li>Item 4</li>
</ul>
<ul>
<li class="column-header">Header 2 Many Lines of Text this is many lines of text and is the longest column wow it keeps going and going and going like the energizer rabbit</li>
<li>Item 1</li>
<li>Item 2</li>
<li>Item 3</li>
<li>Item 4</li>
</ul>
<ul>
<li class="column-header">Header 3 Two Line at most on most use cases</li>
<li>Item 1</li>
<li>Item 2</li>
<li>Item 3</li>
<li>Item 4</li>
</ul>
</div>
Просто добавьте высоту к вашему .column-header
.column-stack ul .column-header {
height:80px;
}
, и это будет правильно выровнено
Думая о нескольких вариантах, например таблица, сетка и т. д., но это может быть полезно, если вы хотите остаться с flex, но не хотите ограничиваться фиксированным количеством столбцов.
Если вы можете изменить порядок своего HTML-кода, чтобы заголовки находились в отдельном контейнере с отображением flex, а списки - также в контейнере с отображением flex, который обеспечил бы одинаковую высоту всех заголовков, как: ]
.column-stack {
display: -ms-flexbox;
display: flex;
-ms-flex-pack: justify;
justify-content: space-between;
}
.column-stack ul {
flex-grow: 1;
flex-basis: 1px;
}
.headers {
display:flex;
}
.column-header {
font-size: 12px;
text-transform: uppercase;
color: #006a4d;
font-weight: 500;
padding-bottom: 5px;
border-bottom: 1px solid #3a3a3a;
display: flex;
align-items: stretch; /* Default */
justify-content: space-between;
flex-grow: 1;
flex-basis: 1px;
margin: 10px;
}
<div class="headers">
<div class="column-header">Header 1 One Line</div>
<div class="column-header">Header 2 Many Lines of Text this is many lines of text and is the longest column wow it keeps going and going and going like the energizer rabbit</div>
<div class="column-header">Header 3 Two Line at most on most use cases</div>
</div>
<div class="column-stack">
<ul>
<li>Item 1</li>
<li>Item 2</li>
<li>Item 3</li>
<li>Item 4</li>
</ul>
<ul>
<li>Item 1</li>
<li>Item 2</li>
<li>Item 3</li>
<li>Item 4</li>
</ul>
<ul>
<li>Item 1</li>
<li>Item 2</li>
<li>Item 3</li>
<li>Item 4</li>
</ul>
</div>
просто не забудьте добавить flex-grow: 1;
и flex-basis: 1px;
, чтобы ширина была одинаковой
Если бы вы могли настроить разметку, я бы убрал column-header
из списка. Таким образом, вы можете согнуть заголовок и список в одном родительском flexbox.
Примечание: Семантически говоря, на самом деле не имеет большого смысла, что заголовок списка сам по себе является элементом списка в списке.
.column-stack {
display: flex;
justify-content: space-between;
}
.column {
padding: 10px;
flex: 1 1 33%;
display: flex;
flex-direction: column;
justify-content: space-between;
}
.column-stack .column-header {
font-size: 12px;
text-transform: uppercase;
color: #006a4d;
font-weight: 500;
padding-bottom: 5px;
border-bottom: 1px solid #3a3a3a;
flex: 1;
display: flex;
justify-content: center;
flex-direction: column;
}
<div class="column-stack">
<div class="column">
<h5 class="column-header">Header 1 One Line</h5>
<ul class="column-list">
<li>Item 1</li>
<li>Item 2</li>
<li>Item 3</li>
<li>Item 4</li>
</ul>
</div>
<div class="column">
<h5 class="column-header">Header 2 Many Lines of Text this is many lines of text and is the longest column wow it keeps going and going and going like the energizer rabbit</h5>
<ul class="column-list">
<li>Item 1</li>
<li>Item 2</li>
<li>Item 3</li>
<li>Item 4</li>
</ul>
</div>
<div class="column">
<h5 class="column-header">Header 3 Two Line at most on most use cases</h5>
<ul class="column-list">
<li>Item 1</li>
<li>Item 2</li>
<li>Item 3</li>
<li>Item 4</li>
</ul>
</div>
</div>
Похоже, что вы на самом деле ищете скромную таблицу HTML.
th {
font-size: 12px;
text-transform: uppercase;
color: #006a4d;
font-weight: 500;
padding-bottom: 5px;
border-bottom: 1px solid #3a3a3a;
}
td {
width: 33%;
}
<table>
<thead>
<th>Header 1 One line</th>
<th>Header 2 Many Lines of Text this is many lines of text and is the longest column wow it keeps going and going and going like the energizer rabbit</th>
<th>Header 3 Two Line at most on most use cases</th>
</thead>
<tbody>
<tr>
<td>Item 1</td>
<td>Item 1</td>
<td>Item 1</td>
</tr>
<tr>
<td>Item 2</td>
<td>Item 2</td>
<td>Item 2</td>
</tr>
<tr>
<td>Item 3</td>
<td>Item 3</td>
<td>Item 3</td>
</tr>
<tr>
<td>Item 4</td>
<td>Item 4</td>
<td>Item 4</td>
</tr>
</tbody>
</table>