Skip to content

Commit

Permalink
Regular updates 1.4.4 (#67)
Browse files Browse the repository at this point in the history
  • Loading branch information
BlueHorn07 authored Mar 9, 2024
1 parent be65a95 commit d1c14fd
Show file tree
Hide file tree
Showing 6 changed files with 600 additions and 358 deletions.
69 changes: 62 additions & 7 deletions components/equipment/equipment.table.jsx
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
import React from 'react'
import Link from "next/link";
import { Table } from 'semantic-ui-react'
import _ from 'lodash'

const ownerNames = {
'chonghak': '총학생회',
Expand All @@ -10,23 +11,77 @@ const ownerNames = {
'others': '그 외',
}
const EquipmentTable = ({ equipmentList }) => {
const [state, dispatch] = React.useReducer(exampleReducer, {
column: null,
data: equipmentList,
direction: null,
})
const { column, data, direction } = state

function exampleReducer(state, action) {
switch (action.type) {
case 'CHANGE_SORT':
if (state.column === action.column) {
return {
...state,
data: state.data.slice().reverse(),
direction:
state.direction === 'ascending' ? 'descending' : 'ascending',
}
}

return {
column: action.column,
data: _.sortBy(state.data, [action.column]),
direction: 'ascending',
}
default:
throw new Error()
}
}

return (
<Table
celled selectable
celled selectable sortable
textAlign={'center'}>
<Table.Header>
<Table.Row>
<Table.HeaderCell>idx.</Table.HeaderCell>
<Table.HeaderCell>장비명</Table.HeaderCell>
<Table.HeaderCell>장비 소속</Table.HeaderCell>
<Table.HeaderCell>대여비</Table.HeaderCell>
<Table.HeaderCell>일일 한도 (분)</Table.HeaderCell>
<Table.HeaderCell>총 예약 갯수</Table.HeaderCell>
<Table.HeaderCell
sorted={column === 'name' ? direction : null}
onClick={() => dispatch({ type: 'CHANGE_SORT', column: 'name' })}
>
장비명
</Table.HeaderCell>
<Table.HeaderCell
sorted={column === 'equip_owner' ? direction : null}
onClick={() => dispatch({ type: 'CHANGE_SORT', column: 'equip_owner' })}
>
장비 소속
</Table.HeaderCell>
<Table.HeaderCell
sorted={column === 'fee' ? direction : null}
onClick={() => dispatch({ type: 'CHANGE_SORT', column: 'fee' })}
>
대여비
</Table.HeaderCell>
<Table.HeaderCell
sorted={column === 'max_minutes' ? direction : null}
onClick={() => dispatch({ type: 'CHANGE_SORT', column: 'max_minutes' })}
>
일일 한도 (분)
</Table.HeaderCell>
<Table.HeaderCell
sorted={column === 'total_reservation_count' ? direction : null}
onClick={() => dispatch({ type: 'CHANGE_SORT', column: 'total_reservation_count' })}
>
총 예약 갯수
</Table.HeaderCell>
</Table.Row>
</Table.Header>
<Table.Body>
{
equipmentList.map((equipment, idx) => (
data.map((equipment, idx) => (
<Link href={`/equipment/update/${equipment.uuid}`} key={equipment.uuid}>
<Table.Row>
<Table.Cell>{idx + 1}</Table.Cell>
Expand Down
68 changes: 61 additions & 7 deletions components/place/place.table.jsx
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
import React from 'react'
import Link from "next/link";
import { Table } from 'semantic-ui-react'
import _ from 'lodash'

const regionNames = {
'STUDENT_HALL': '학생 회관',
Expand All @@ -11,24 +12,77 @@ const regionNames = {
}

const PlaceTable = ({ placeList }) => {
const [state, dispatch] = React.useReducer(exampleReducer, {
column: null,
data: placeList,
direction: null,
})
const { column, data, direction } = state

function exampleReducer(state, action) {
switch (action.type) {
case 'CHANGE_SORT':
if (state.column === action.column) {
return {
...state,
data: state.data.slice().reverse(),
direction:
state.direction === 'ascending' ? 'descending' : 'ascending',
}
}

return {
column: action.column,
data: _.sortBy(state.data, [action.column]),
direction: 'ascending',
}
default:
throw new Error()
}
}

return (
<Table
celled selectable
celled selectable sortable
textAlign={'center'}>
<Table.Header>
<Table.Row>
<Table.HeaderCell>idx.</Table.HeaderCell>
<Table.HeaderCell>장소명</Table.HeaderCell>
<Table.HeaderCell>위치</Table.HeaderCell>
<Table.HeaderCell>지역</Table.HeaderCell>
<Table.HeaderCell>일일 한도 (분)</Table.HeaderCell>
<Table.HeaderCell>총 예약 갯수</Table.HeaderCell>
<Table.HeaderCell
sorted={column === 'name' ? direction : null}
onClick={() => dispatch({ type: 'CHANGE_SORT', column: 'name' })}
>
장소명
</Table.HeaderCell>
<Table.HeaderCell
sorted={column === 'location' ? direction : null}
onClick={() => dispatch({ type: 'CHANGE_SORT', column: 'location' })}
>
위치
</Table.HeaderCell>
<Table.HeaderCell
sorted={column === 'region' ? direction : null}
onClick={() => dispatch({ type: 'CHANGE_SORT', column: 'region' })}
>
지역
</Table.HeaderCell>
<Table.HeaderCell
sorted={column === 'max_minutes' ? direction : null}
onClick={() => dispatch({ type: 'CHANGE_SORT', column: 'max_minutes' })}
>
일일 한도 (분)
</Table.HeaderCell>
<Table.HeaderCell
sorted={column === 'total_reservation_count' ? direction : null}
onClick={() => dispatch({ type: 'CHANGE_SORT', column: 'total_reservation_count' })}
>
총 예약 갯수
</Table.HeaderCell>
</Table.Row>
</Table.Header>
<Table.Body>
{
placeList.map((place, idx) => (
data.map((place, idx) => (
<Link href={`place/update/${place.uuid}`} key={place.uuid}>
<Table.Row>
<Table.Cell>{idx + 1}</Table.Cell>
Expand Down
Loading

0 comments on commit d1c14fd

Please sign in to comment.