UNPKG

naive-ui

Version:

A Vue 3 Component Library. Fairly Complete, Theme Customizable, Uses TypeScript, Fast

449 lines 14 kB
import { fadeInScaleUpTransition } from "../../../_styles/transitions/fade-in-scale-up.cssr.mjs"; import { iconSwitchTransition } from "../../../_styles/transitions/icon-switch.cssr.mjs"; import { c, cB, cE, cM, cNotM, insideModal, insidePopover } from "../../../_utils/cssr/index.mjs"; const fixedColumnStyle = createFixedColumnStyle(); // vars: // --n-font-size // --n-th-padding // --n-td-padding // --n-bezier // --n-border-radius // --n-line-height // --n-border-color // --n-border-color-modal // --n-border-color-popover // --n-th-color // --n-th-color-hover // --n-th-color-sorting // --n-th-color-modal // --n-th-color-hover-modal // --n-th-color-sorting-modal // --n-th-color-popover // --n-th-color-hover-popover // --n-th-color-sorting-popover // --n-td-color // --n-td-color-hover // --n-td-color-sorting // --n-td-color-modal // --n-td-color-hover-modal // --n-td-color-sorting-modal // --n-td-color-popover // --n-td-color-hover-popover // --n-td-color-sorting-popover // --n-th-text-color // --n-td-text-color // --n-th-font-weight // --n-th-button-color-hover // --n-th-icon-color // --n-th-icon-color-active // --n-filter-size // --n-action-divider-color // --n-action-padding // --n-action-button-margin // --n-pagination-margin // --n-empty-padding // --n-sorter-size // --n-resizable-container-size // --n-resizable-size // --n-loading-size // --n-loading-color // --n-opacity-loading // --n-box-shadow-before used in Body.tsx // --n-box-shadow-after used in Body.tsx // --indent-offset for ellipsis & expand trigger export default c([cB('data-table', ` width: 100%; font-size: var(--n-font-size); display: flex; flex-direction: column; position: relative; --n-merged-th-color: var(--n-th-color); --n-merged-td-color: var(--n-td-color); --n-merged-border-color: var(--n-border-color); --n-merged-th-color-sorting: var(--n-th-color-sorting); --n-merged-td-color-hover: var(--n-td-color-hover); --n-merged-td-color-sorting: var(--n-td-color-sorting); --n-merged-td-color-striped: var(--n-td-color-striped); `, [cB('data-table-wrapper', ` flex-grow: 1; display: flex; flex-direction: column; `), cM('flex-height', [c('>', [cB('data-table-wrapper', [c('>', [cB('data-table-base-table', ` display: flex; flex-direction: column; flex-grow: 1; `, [c('>', [cB('data-table-base-table-body', 'flex-basis: 0;', [ // last-child means there is no empty icon // body is a scrollbar, we need to override height 100% c('&:last-child', 'flex-grow: 1;')])])])])])])]), c('>', [cB('data-table-loading-wrapper', ` color: var(--n-loading-color); font-size: var(--n-loading-size); position: absolute; left: 50%; top: 50%; transform: translateX(-50%) translateY(-50%); transition: color .3s var(--n-bezier); display: flex; align-items: center; justify-content: center; `, [fadeInScaleUpTransition({ originalTransform: 'translateX(-50%) translateY(-50%)' })])]), cB('data-table-expand-placeholder', ` margin-right: 8px; display: inline-block; width: 16px; height: 1px; `), cB('data-table-indent', ` display: inline-block; height: 1px; `), cB('data-table-expand-trigger', ` display: inline-flex; margin-right: 8px; cursor: pointer; font-size: 16px; vertical-align: -0.2em; position: relative; width: 16px; height: 16px; color: var(--n-td-text-color); transition: color .3s var(--n-bezier); `, [cM('expanded', [cB('icon', 'transform: rotate(90deg);', [iconSwitchTransition({ originalTransform: 'rotate(90deg)' })]), cB('base-icon', 'transform: rotate(90deg);', [iconSwitchTransition({ originalTransform: 'rotate(90deg)' })])]), cB('base-loading', ` color: var(--n-loading-color); transition: color .3s var(--n-bezier); position: absolute; left: 0; right: 0; top: 0; bottom: 0; `, [iconSwitchTransition()]), cB('icon', ` position: absolute; left: 0; right: 0; top: 0; bottom: 0; `, [iconSwitchTransition()]), cB('base-icon', ` position: absolute; left: 0; right: 0; top: 0; bottom: 0; `, [iconSwitchTransition()])]), cB('data-table-thead', ` transition: background-color .3s var(--n-bezier); background-color: var(--n-merged-th-color); `), cB('data-table-tr', ` position: relative; box-sizing: border-box; background-clip: padding-box; transition: background-color .3s var(--n-bezier); `, [cB('data-table-expand', ` position: sticky; left: 0; overflow: hidden; margin: calc(var(--n-th-padding) * -1); padding: var(--n-th-padding); box-sizing: border-box; `), cM('striped', 'background-color: var(--n-merged-td-color-striped);', [cB('data-table-td', 'background-color: var(--n-merged-td-color-striped);')]), cNotM('summary', [c('&:hover', 'background-color: var(--n-merged-td-color-hover);', [c('>', [cB('data-table-td', 'background-color: var(--n-merged-td-color-hover);')])])])]), cB('data-table-th', ` padding: var(--n-th-padding); position: relative; text-align: start; box-sizing: border-box; background-color: var(--n-merged-th-color); border-color: var(--n-merged-border-color); border-bottom: 1px solid var(--n-merged-border-color); color: var(--n-th-text-color); transition: border-color .3s var(--n-bezier), color .3s var(--n-bezier), background-color .3s var(--n-bezier); font-weight: var(--n-th-font-weight); `, [cM('filterable', ` padding-right: 36px; `, [cM('sortable', ` padding-right: calc(var(--n-th-padding) + 36px); `)]), fixedColumnStyle, cM('selection', ` padding: 0; text-align: center; line-height: 0; z-index: 3; `), cE('title-wrapper', ` display: flex; align-items: center; flex-wrap: nowrap; max-width: 100%; `, [cE('title', ` flex: 1; min-width: 0; `)]), cE('ellipsis', ` display: inline-block; vertical-align: bottom; text-overflow: ellipsis; overflow: hidden; white-space: nowrap; max-width: 100%; `), cM('hover', ` background-color: var(--n-merged-th-color-hover); `), cM('sorting', ` background-color: var(--n-merged-th-color-sorting); `), cM('sortable', ` cursor: pointer; `, [cE('ellipsis', ` max-width: calc(100% - 18px); `), c('&:hover', ` background-color: var(--n-merged-th-color-hover); `)]), cB('data-table-sorter', ` height: var(--n-sorter-size); width: var(--n-sorter-size); margin-left: 4px; position: relative; display: inline-flex; align-items: center; justify-content: center; vertical-align: -0.2em; color: var(--n-th-icon-color); transition: color .3s var(--n-bezier); `, [cB('base-icon', 'transition: transform .3s var(--n-bezier)'), cM('desc', [cB('base-icon', ` transform: rotate(0deg); `)]), cM('asc', [cB('base-icon', ` transform: rotate(-180deg); `)]), cM('asc, desc', ` color: var(--n-th-icon-color-active); `)]), cB('data-table-resize-button', ` width: var(--n-resizable-container-size); position: absolute; top: 0; right: calc(var(--n-resizable-container-size) / 2); bottom: 0; cursor: col-resize; user-select: none; `, [c('&::after', ` width: var(--n-resizable-size); height: 50%; position: absolute; top: 50%; left: calc(var(--n-resizable-container-size) / 2); bottom: 0; background-color: var(--n-merged-border-color); transform: translateY(-50%); transition: background-color .3s var(--n-bezier); z-index: 1; content: ''; `), cM('active', [c('&::after', ` background-color: var(--n-th-icon-color-active); `)]), c('&:hover::after', ` background-color: var(--n-th-icon-color-active); `)]), cB('data-table-filter', ` position: absolute; z-index: auto; right: 0; width: 36px; top: 0; bottom: 0; cursor: pointer; display: flex; justify-content: center; align-items: center; transition: background-color .3s var(--n-bezier), color .3s var(--n-bezier); font-size: var(--n-filter-size); color: var(--n-th-icon-color); `, [c('&:hover', ` background-color: var(--n-th-button-color-hover); `), cM('show', ` background-color: var(--n-th-button-color-hover); `), cM('active', ` background-color: var(--n-th-button-color-hover); color: var(--n-th-icon-color-active); `)])]), cB('data-table-td', ` padding: var(--n-td-padding); text-align: start; box-sizing: border-box; border: none; background-color: var(--n-merged-td-color); color: var(--n-td-text-color); border-bottom: 1px solid var(--n-merged-border-color); transition: box-shadow .3s var(--n-bezier), background-color .3s var(--n-bezier), border-color .3s var(--n-bezier), color .3s var(--n-bezier); `, [cM('expand', [cB('data-table-expand-trigger', ` margin-right: 0; `)]), cM('last-row', ` border-bottom: 0 solid var(--n-merged-border-color); `, [ // make sure there is no overlap between bottom border and // fixed column box shadow c('&::after', ` bottom: 0 !important; `), c('&::before', ` bottom: 0 !important; `)]), cM('summary', ` background-color: var(--n-merged-th-color); `), cM('hover', ` background-color: var(--n-merged-td-color-hover); `), cM('sorting', ` background-color: var(--n-merged-td-color-sorting); `), cE('ellipsis', ` display: inline-block; text-overflow: ellipsis; overflow: hidden; white-space: nowrap; max-width: 100%; vertical-align: bottom; max-width: calc(100% - var(--indent-offset, -1.5) * 16px - 24px); `), cM('selection, expand', ` text-align: center; padding: 0; line-height: 0; `), fixedColumnStyle]), cB('data-table-empty', ` box-sizing: border-box; padding: var(--n-empty-padding); flex-grow: 1; flex-shrink: 0; opacity: 1; display: flex; align-items: center; justify-content: center; transition: opacity .3s var(--n-bezier); `, [cM('hide', ` opacity: 0; `)]), cE('pagination', ` margin: var(--n-pagination-margin); display: flex; justify-content: flex-end; `), cB('data-table-wrapper', ` position: relative; opacity: 1; transition: opacity .3s var(--n-bezier), border-color .3s var(--n-bezier); border-top-left-radius: var(--n-border-radius); border-top-right-radius: var(--n-border-radius); line-height: var(--n-line-height); `), cM('loading', [cB('data-table-wrapper', ` opacity: var(--n-opacity-loading); pointer-events: none; `)]), cM('single-column', [cB('data-table-td', ` border-bottom: 0 solid var(--n-merged-border-color); `, [c('&::after, &::before', ` bottom: 0 !important; `)])]), cNotM('single-line', [cB('data-table-th', ` border-right: 1px solid var(--n-merged-border-color); `, [cM('last', ` border-right: 0 solid var(--n-merged-border-color); `)]), cB('data-table-td', ` border-right: 1px solid var(--n-merged-border-color); `, [cM('last-col', ` border-right: 0 solid var(--n-merged-border-color); `)])]), cM('bordered', [cB('data-table-wrapper', ` border: 1px solid var(--n-merged-border-color); border-bottom-left-radius: var(--n-border-radius); border-bottom-right-radius: var(--n-border-radius); overflow: hidden; `)]), cB('data-table-base-table', [cM('transition-disabled', [cB('data-table-th', [c('&::after, &::before', 'transition: none;')]), cB('data-table-td', [c('&::after, &::before', 'transition: none;')])])]), cM('bottom-bordered', [cB('data-table-td', [cM('last-row', ` border-bottom: 1px solid var(--n-merged-border-color); `)])]), cB('data-table-table', ` font-variant-numeric: tabular-nums; width: 100%; word-break: break-word; transition: background-color .3s var(--n-bezier); border-collapse: separate; border-spacing: 0; background-color: var(--n-merged-td-color); `), cB('data-table-base-table-header', ` border-top-left-radius: calc(var(--n-border-radius) - 1px); border-top-right-radius: calc(var(--n-border-radius) - 1px); z-index: 3; overflow: scroll; flex-shrink: 0; transition: border-color .3s var(--n-bezier); scrollbar-width: none; `, [c('&::-webkit-scrollbar', ` width: 0; height: 0; `)]), cB('data-table-check-extra', ` transition: color .3s var(--n-bezier); color: var(--n-th-icon-color); position: absolute; font-size: 14px; right: -4px; top: 50%; transform: translateY(-50%); z-index: 1; `)]), cB('data-table-filter-menu', [cB('scrollbar', ` max-height: 240px; `), cE('group', ` display: flex; flex-direction: column; padding: 12px 12px 0 12px; `, [cB('checkbox', ` margin-bottom: 12px; margin-right: 0; `), cB('radio', ` margin-bottom: 12px; margin-right: 0; `)]), cE('action', ` padding: var(--n-action-padding); display: flex; flex-wrap: nowrap; justify-content: space-evenly; border-top: 1px solid var(--n-action-divider-color); `, [cB('button', [c('&:not(:last-child)', ` margin: var(--n-action-button-margin); `), c('&:last-child', ` margin-right: 0; `)])]), cB('divider', ` margin: 0 !important; `)]), insideModal(cB('data-table', ` --n-merged-th-color: var(--n-th-color-modal); --n-merged-td-color: var(--n-td-color-modal); --n-merged-border-color: var(--n-border-color-modal); --n-merged-th-color-hover: var(--n-th-color-hover-modal); --n-merged-td-color-hover: var(--n-td-color-hover-modal); --n-merged-th-color-sorting: var(--n-th-color-hover-modal); --n-merged-td-color-sorting: var(--n-td-color-hover-modal); --n-merged-td-color-striped: var(--n-td-color-striped-modal); `)), insidePopover(cB('data-table', ` --n-merged-th-color: var(--n-th-color-popover); --n-merged-td-color: var(--n-td-color-popover); --n-merged-border-color: var(--n-border-color-popover); --n-merged-th-color-hover: var(--n-th-color-hover-popover); --n-merged-td-color-hover: var(--n-td-color-hover-popover); --n-merged-th-color-sorting: var(--n-th-color-hover-popover); --n-merged-td-color-sorting: var(--n-td-color-hover-popover); --n-merged-td-color-striped: var(--n-td-color-striped-popover); `))]); function createFixedColumnStyle() { return [cM('fixed-left', ` left: 0; position: sticky; z-index: 2; `, [c('&::after', ` pointer-events: none; content: ""; width: 36px; display: inline-block; position: absolute; top: 0; bottom: -1px; transition: box-shadow .2s var(--n-bezier); right: -36px; `)]), cM('fixed-right', ` right: 0; position: sticky; z-index: 1; `, [c('&::before', ` pointer-events: none; content: ""; width: 36px; display: inline-block; position: absolute; top: 0; bottom: -1px; transition: box-shadow .2s var(--n-bezier); left: -36px; `)])]; }