Skip to content

Commit

Permalink
AP-78 Add grid column resizing
Browse files Browse the repository at this point in the history
  • Loading branch information
vin0401 committed Feb 28, 2024
1 parent e2dc682 commit 0c7ba37
Show file tree
Hide file tree
Showing 13 changed files with 199 additions and 26 deletions.
7 changes: 7 additions & 0 deletions assets/js/src/components/editor-tabs/editor-tabs.styles.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,13 @@ import { createStyles } from 'antd-style'
export const useStyle = createStyles(({ token, css }) => {
return {
editorTabs: css`
height: 100%;
overflow: hidden;
.ant-tabs-content-holder {
overflow: auto;
}
&.ant-tabs .ant-tabs-tab+.ant-tabs-tab {
margin-left: ${token.paddingSM}px;
margin-right: ${token.paddingSM}px;
Expand Down
36 changes: 35 additions & 1 deletion assets/js/src/components/grid/grid.styles.ts
Original file line number Diff line number Diff line change
Expand Up @@ -4,15 +4,49 @@ export const useStyles = createStyles(({ token, css }) => {
return {
grid: css`
table {
table-layout: auto;
table-layout: fixed;
width: auto;
}
th {
user-select: none;
}
&.ant-table-wrapper .ant-table-container table>thead>tr:first-child >*:first-child {
border-start-start-radius: 0;
}
&.ant-table-wrapper .ant-table-container table>thead>tr:first-child >*:last-child {
border-start-end-radius: 0;
}
.grid__cell-content {
display: block;
width: fit-content;
max-width: 100%;
overflow: hidden;
text-overflow: ellipsis;
}
.ant-table-cell {
position: relative;
border-left: 1px solid #F0F0F0;
white-space: nowrap;
text-overflow: ellipsis;
&:first-of-type {
border-left: 0;
}
&:last-of-type {
border-right: 1px solid #F0F0F0;
}
}
.ant-table-thead {
position: sticky;
top: 0;
z-index: 1;
}
`
}
Expand Down
72 changes: 58 additions & 14 deletions assets/js/src/components/grid/grid.tsx
Original file line number Diff line number Diff line change
@@ -1,42 +1,68 @@
import { useCssComponentHash } from '@Pimcore/modules/ant-design/hooks/use-css-component-hash'
import { type ColumnDef, flexRender, getCoreRowModel, useReactTable } from '@tanstack/react-table'
import { type ColumnDef, flexRender, getCoreRowModel, useReactTable, type ColumnResizeMode, type TableOptions } from '@tanstack/react-table'
import React, { useState } from 'react'
import { useStyles } from './grid.styles'
import { Resizer } from './resizer/resizer'

export interface GridProps {
data: any[]
columns: Array<ColumnDef<any>>
resizeable?: boolean
}

export const Grid = (props: GridProps): React.JSX.Element => {
const { columns } = props
const [columns] = useState(props.columns)
const [data] = useState(props.data)
const hashId = useCssComponentHash('table')
const { styles } = useStyles()
const [columnResizeMode] = useState<ColumnResizeMode>('onEnd')

const table = useReactTable({
const tableProps: TableOptions<any> = {
data,
columns,
getCoreRowModel: getCoreRowModel()
})
}

if (props.resizeable === true) {
tableProps.columnResizeMode = columnResizeMode
}

const table = useReactTable(tableProps)

return (
<div className={['ant-table-wrapper', hashId, styles.grid].join(' ')}>
<div className="ant-table ant-table-small">
<div className='ant-table-container'>
<div className='ant-table-content'>
<table>
<table style={{ width: table.getCenterTotalSize() }}>
<thead className='ant-table-thead'>
{table.getHeaderGroups().map(headerGroup => (
<tr key={headerGroup.id}>
{headerGroup.headers.map(header => (
<th className='ant-table-cell' key={header.id} style={{ width: header.column.getSize() }}>
{header.isPlaceholder
? null
: flexRender(
header.column.columnDef.header,
header.getContext()
)}
<th
key={header.id}
className='ant-table-cell'
style={
{
width: header.column.getSize(),
maxWidth: header.column.getSize()
}
}
>
<div className='grid__cell-content'>
{flexRender(
header.column.columnDef.header,
header.getContext()
)}
</div>

{props.resizeable === true && header.column.getCanResize() && (
<Resizer
onMouseDown={header.getResizeHandler()}
isResizing={header.column.getIsResizing()}
table={table}
/>
)}
</th>
))}
</tr>
Expand All @@ -46,8 +72,26 @@ export const Grid = (props: GridProps): React.JSX.Element => {
{table.getRowModel().rows.map(row => (
<tr className='ant-table-row' key={row.id}>
{row.getVisibleCells().map(cell => (
<td className='ant-table-cell' key={cell.id} style={{ width: cell.column.getSize() }} >
{flexRender(cell.column.columnDef.cell, cell.getContext())}
<td
key={cell.id}
className='ant-table-cell'
style={
{
width: cell.column.getSize(),
maxWidth: cell.column.getSize()
}
}
>
<div className='grid__cell-content'>
{flexRender(cell.column.columnDef.cell, cell.getContext())}
</div>

{props.resizeable === true && (
<Resizer
isResizing={cell.column.getIsResizing()}
table={table}
/>
)}
</td>
))}
</tr>
Expand Down
27 changes: 27 additions & 0 deletions assets/js/src/components/grid/resizer/resizer.styles.tsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,27 @@
import { createStyles } from 'antd-style'

export const useStyles = createStyles(({ token, css }) => {
return {
resizer: css`
&.grid__resizer {
position: absolute;
right: -4px;
top: 0;
bottom: 0;
width: 8px;
z-index: 1;
background-color: transparent;
&--resizing {
background-color: ${token.colorPrimary};
width: 2px;
right: -1px;
}
&--hoverable {
cursor: col-resize;
}
}
`
}
})
46 changes: 46 additions & 0 deletions assets/js/src/components/grid/resizer/resizer.tsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,46 @@
import React from 'react'
import { useStyles } from './resizer.styles'
import { type Table } from '@tanstack/react-table'

interface ResizerProps {
onMouseDown?: (event: unknown) => void
isResizing: boolean
table: Table<any>
}

const Resizer = (props: ResizerProps): React.JSX.Element => {
const { styles } = useStyles()
const classes = ['grid__resizer']

classes.push(styles.resizer)

if (props.onMouseDown !== undefined) {
classes.push('grid__resizer--hoverable')
}

if (props.isResizing) {
classes.push('grid__resizer--resizing')
}

return (
<div
onMouseDown={props.onMouseDown}
className={classes.join(' ')}
style={{
transform:
props.isResizing
? `translateX(${
(props.table.options.columnResizeDirection ===
'rtl'
? -1
: 1) *
(props.table.getState().columnSizingInfo
.deltaOffset ?? 0)
}px)`
: ''
}}
/>
)
}

export { Resizer }
Original file line number Diff line number Diff line change
@@ -1,9 +1,10 @@
import { FormattedDate } from '@Pimcore/components/formatted-date/formatted-date'
import { Grid } from '@Pimcore/components/grid/grid'
import { type AssetJsonldAssetReadDependencyReadPropertyRead, useApiAssetsGetCollectionQuery } from '@Pimcore/modules/asset/asset-api-slice.gen'
import { type AssetJsonldAssetReadDependencyReadPropertyReadRead, useApiAssetsGetCollectionQuery } from '@Pimcore/modules/asset/asset-api-slice.gen'
import { AssetContext } from '@Pimcore/modules/asset/asset-container'
import { ImageView } from '@Pimcore/modules/asset/grid/columns/views/image-view'
import { createColumnHelper } from '@tanstack/react-table'
import { Tag } from 'antd'
import React, { useContext } from 'react'
import { useTranslation } from 'react-i18next'

Expand All @@ -22,12 +23,19 @@ const ListContainer = (): React.JSX.Element => {
}

const assets = data['hydra:member']
const columnHelper = createColumnHelper<AssetJsonldAssetReadDependencyReadPropertyRead>()
const columnHelper = createColumnHelper<AssetJsonldAssetReadDependencyReadPropertyReadRead>()

const columns = [
columnHelper.accessor('fullPath', {
header: t('asset.asset-editor-tabs.list.columns.preview'),
cell: info => <ImageView src={info.getValue() as string} />,
cell: info => {
if (info.row.original.type !== 'image') {
return <></>
}

return <ImageView src={info.getValue()!} />
},
id: 'preview',
size: 110
}),

Expand All @@ -39,6 +47,13 @@ const ListContainer = (): React.JSX.Element => {
header: t('asset.asset-editor-tabs.list.columns.type')
}),

columnHelper.accessor('fullPath', {
header: t('asset.asset-editor-tabs.list.columns.fullPath'),
cell: info => <Tag bordered={false} color='processing'>{info.getValue()!}</Tag>,
id: 'fullPath',
size: 300
}),

columnHelper.accessor('creationDate', {
header: t('asset.asset-editor-tabs.list.columns.creationDate'),
cell: info => <FormattedDate timestamp={info.getValue() as number * 1000} />
Expand All @@ -51,7 +66,7 @@ const ListContainer = (): React.JSX.Element => {
]

return (
<Grid data={assets} columns={columns} />
<Grid data={assets} columns={columns} resizeable />
)
}

Expand Down
2 changes: 0 additions & 2 deletions public/build/331.7d193447.js

This file was deleted.

2 changes: 2 additions & 0 deletions public/build/70.4bade3d2.js

Large diffs are not rendered by default.

File renamed without changes.
4 changes: 2 additions & 2 deletions public/build/entrypoints.json
Original file line number Diff line number Diff line change
Expand Up @@ -2,8 +2,8 @@
"entrypoints": {
"main": {
"js": [
"/bundles/pimcorestudioui/build/331.7d193447.js",
"/bundles/pimcorestudioui/build/main.577fbd26.js"
"/bundles/pimcorestudioui/build/70.4bade3d2.js",
"/bundles/pimcorestudioui/build/main.cecf5e07.js"
],
"css": [
"/bundles/pimcorestudioui/build/main.3691bcd8.css"
Expand Down
1 change: 0 additions & 1 deletion public/build/main.577fbd26.js

This file was deleted.

1 change: 1 addition & 0 deletions public/build/main.cecf5e07.js

Large diffs are not rendered by default.

4 changes: 2 additions & 2 deletions public/build/manifest.json
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
{
"bundles/pimcorestudioui/build/main.css": "/bundles/pimcorestudioui/build/main.3691bcd8.css",
"bundles/pimcorestudioui/build/main.js": "/bundles/pimcorestudioui/build/main.577fbd26.js",
"bundles/pimcorestudioui/build/main.js": "/bundles/pimcorestudioui/build/main.cecf5e07.js",
"bundles/pimcorestudioui/build/58.9cf6e23a.js": "/bundles/pimcorestudioui/build/58.9cf6e23a.js",
"bundles/pimcorestudioui/build/678.c220b736.js": "/bundles/pimcorestudioui/build/678.c220b736.js",
"bundles/pimcorestudioui/build/625.b487b20e.js": "/bundles/pimcorestudioui/build/625.b487b20e.js",
Expand All @@ -18,7 +18,7 @@
"bundles/pimcorestudioui/build/324.eb495a70.js": "/bundles/pimcorestudioui/build/324.eb495a70.js",
"bundles/pimcorestudioui/build/307.c11c33c6.js": "/bundles/pimcorestudioui/build/307.c11c33c6.js",
"bundles/pimcorestudioui/build/298.830d7e38.js": "/bundles/pimcorestudioui/build/298.830d7e38.js",
"bundles/pimcorestudioui/build/331.7d193447.js": "/bundles/pimcorestudioui/build/331.7d193447.js",
"bundles/pimcorestudioui/build/70.4bade3d2.js": "/bundles/pimcorestudioui/build/70.4bade3d2.js",
"bundles/pimcorestudioui/build/fonts/Lato-Light.ttf": "/bundles/pimcorestudioui/build/fonts/Lato-Light.c7400fca.ttf",
"bundles/pimcorestudioui/build/fonts/Lato-Regular.ttf": "/bundles/pimcorestudioui/build/fonts/Lato-Regular.9d883d54.ttf",
"bundles/pimcorestudioui/build/fonts/Lato-Bold.ttf": "/bundles/pimcorestudioui/build/fonts/Lato-Bold.636be8de.ttf"
Expand Down

0 comments on commit 0c7ba37

Please sign in to comment.