Skip to content

Commit

Permalink
✨ feat: 로그 뷰어 컴포넌트 스타일 수정
Browse files Browse the repository at this point in the history
  • Loading branch information
2skydev committed Oct 9, 2023
1 parent 0bb780f commit 9c23ab3
Show file tree
Hide file tree
Showing 3 changed files with 83 additions and 10 deletions.
2 changes: 1 addition & 1 deletion src/main/modules/migration/migration.module.ts
Original file line number Diff line number Diff line change
Expand Up @@ -61,7 +61,7 @@ export class MigrationModule {
await this[version]()
log.info(`[Migration Module] Migrated to ${currentVersion}`)
} catch (error) {
log.error(`[Migration Module] ${currentVersion}`, error)
log.error(`[Migration Module] ${currentVersion}\n`, error)
}
}

Expand Down
2 changes: 1 addition & 1 deletion src/renderer/src/components/LogViewer/LogViewer.styled.ts
Original file line number Diff line number Diff line change
Expand Up @@ -21,6 +21,6 @@ export const Root = styled.div`
}
> .ant-divider {
margin: 1rem 0;
margin: 0.8rem 0 1rem;
}
`
89 changes: 81 additions & 8 deletions src/renderer/src/components/LogViewer/LogViewer.tsx
Original file line number Diff line number Diff line change
@@ -1,7 +1,10 @@
import { useTranslation } from 'react-i18next'
import { List } from 'react-virtualized'

import { Divider } from 'antd'
import clsx from 'clsx'
import dayjs from 'dayjs'
import { useTheme } from 'styled-components'

import * as Styled from './LogViewer.styled'

Expand All @@ -11,24 +14,94 @@ export interface LogViewerProps {
lines: string[]
}

const LogViewer = ({ className, path, lines }: LogViewerProps) => {
const DATE_VIEW_WIDTH_LOCALES = {
ko_KR: '5rem',
en_US: '8rem',
}

const LogViewer = ({ className, path, lines: _lines }: LogViewerProps) => {
const { i18n } = useTranslation()

const {
colors: { red, orange },
} = useTheme()

const lines = _lines.toReversed()

const statusColors = {
error: red,
warn: orange,
}

const dateViewWidth = DATE_VIEW_WIDTH_LOCALES[i18n.language]

return (
<Styled.Root className={clsx('LogViewer', className)}>
<div className="path selectable">{path}</div>

<Divider />

{/* @ts-ignore */}
{/* @ts-ignore 라이브러리 내부 타입 오류 무시 */}
<List
width={500}
height={300}
rowCount={lines.length}
rowHeight={20}
rowRenderer={({ index, key, style }) => (
<pre className="selectable" key={key} style={style}>
{lines[index]}
</pre>
)}
rowHeight={({ index }) => {
return 20 * lines[index].split('\n').length + 10
}}
rowRenderer={({ index, key, style }) => {
let line = lines[index]
const date = line.match(/^\[([0-9\-._:\s]+)\]/)?.[1]
const status = line.match(
/^\[[0-9\-._:\s]+\] \[(info|debug|log|warn|error|verbose)\]/,
)?.[1]

const color = statusColors[status!]

line = line.replace(/^\[[0-9\-._:\s]+\] /, '')
line = line.replace(/^\[(info|debug|log|warn|error|verbose)\] /, '')

return (
<div
key={key}
style={{
...style,
color,
}}
>
<div
style={{
display: 'flex',
}}
>
<div
style={{
display: 'flex',
alignItems: 'center',
height: '20px',
}}
>
<div className="selectable" style={{ width: dateViewWidth }}>
{dayjs(date).fromNow()}
</div>
<Divider type="vertical" style={{ borderColor: color, margin: '0 .6rem' }} />
<div className="selectable" style={{ width: '2.5rem' }}>
{status}
</div>
<Divider type="vertical" style={{ borderColor: color, margin: '0 .6rem' }} />
</div>

<div>
{line.split('\n').map((text, i) => (
<div key={i} className="selectable" style={{ height: 20 }}>
{text}
</div>
))}
</div>
</div>
</div>
)
}}
/>
</Styled.Root>
)
Expand Down

0 comments on commit 9c23ab3

Please sign in to comment.