UNPKG

naive-ui

Version:

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

456 lines (455 loc) 15.7 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); const fade_in_scale_up_cssr_1 = require("../../../_styles/transitions/fade-in-scale-up.cssr"); const icon_switch_cssr_1 = require("../../../_styles/transitions/icon-switch.cssr"); const cssr_1 = require("../../../_utils/cssr"); 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 exports.default = (0, cssr_1.c)([(0, cssr_1.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-hover: var(--n-th-color-hover); --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); `, [(0, cssr_1.cB)('data-table-wrapper', ` flex-grow: 1; display: flex; flex-direction: column; `), (0, cssr_1.cM)('flex-height', [(0, cssr_1.c)('>', [(0, cssr_1.cB)('data-table-wrapper', [(0, cssr_1.c)('>', [(0, cssr_1.cB)('data-table-base-table', ` display: flex; flex-direction: column; flex-grow: 1; `, [(0, cssr_1.c)('>', [(0, cssr_1.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% (0, cssr_1.c)('&:last-child', 'flex-grow: 1;')])])])])])])]), (0, cssr_1.c)('>', [(0, cssr_1.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; `, [(0, fade_in_scale_up_cssr_1.fadeInScaleUpTransition)({ originalTransform: 'translateX(-50%) translateY(-50%)' })])]), (0, cssr_1.cB)('data-table-expand-placeholder', ` margin-right: 8px; display: inline-block; width: 16px; height: 1px; `), (0, cssr_1.cB)('data-table-indent', ` display: inline-block; height: 1px; `), (0, cssr_1.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); `, [(0, cssr_1.cM)('expanded', [(0, cssr_1.cB)('icon', 'transform: rotate(90deg);', [(0, icon_switch_cssr_1.iconSwitchTransition)({ originalTransform: 'rotate(90deg)' })]), (0, cssr_1.cB)('base-icon', 'transform: rotate(90deg);', [(0, icon_switch_cssr_1.iconSwitchTransition)({ originalTransform: 'rotate(90deg)' })])]), (0, cssr_1.cB)('base-loading', ` color: var(--n-loading-color); transition: color .3s var(--n-bezier); position: absolute; left: 0; right: 0; top: 0; bottom: 0; `, [(0, icon_switch_cssr_1.iconSwitchTransition)()]), (0, cssr_1.cB)('icon', ` position: absolute; left: 0; right: 0; top: 0; bottom: 0; `, [(0, icon_switch_cssr_1.iconSwitchTransition)()]), (0, cssr_1.cB)('base-icon', ` position: absolute; left: 0; right: 0; top: 0; bottom: 0; `, [(0, icon_switch_cssr_1.iconSwitchTransition)()])]), (0, cssr_1.cB)('data-table-thead', ` transition: background-color .3s var(--n-bezier); background-color: var(--n-merged-th-color); `), (0, cssr_1.cB)('data-table-tr', ` position: relative; box-sizing: border-box; background-clip: padding-box; transition: background-color .3s var(--n-bezier); `, [(0, cssr_1.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; `), (0, cssr_1.cM)('striped', 'background-color: var(--n-merged-td-color-striped);', [(0, cssr_1.cB)('data-table-td', 'background-color: var(--n-merged-td-color-striped);')]), (0, cssr_1.cNotM)('summary', [(0, cssr_1.c)('&:hover', 'background-color: var(--n-merged-td-color-hover);', [(0, cssr_1.c)('>', [(0, cssr_1.cB)('data-table-td', 'background-color: var(--n-merged-td-color-hover);')])])])]), (0, cssr_1.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); `, [(0, cssr_1.cM)('filterable', ` padding-right: 36px; `, [(0, cssr_1.cM)('sortable', ` padding-right: calc(var(--n-th-padding) + 36px); `)]), fixedColumnStyle, (0, cssr_1.cM)('selection', ` padding: 0; text-align: center; line-height: 0; z-index: 3; `), (0, cssr_1.cE)('title-wrapper', ` display: flex; align-items: center; flex-wrap: nowrap; max-width: 100%; `, [(0, cssr_1.cE)('title', ` flex: 1; min-width: 0; `)]), (0, cssr_1.cE)('ellipsis', ` display: inline-block; vertical-align: bottom; text-overflow: ellipsis; overflow: hidden; white-space: nowrap; max-width: 100%; `), (0, cssr_1.cM)('hover', ` background-color: var(--n-merged-th-color-hover); `), (0, cssr_1.cM)('sorting', ` background-color: var(--n-merged-th-color-sorting); `), (0, cssr_1.cM)('sortable', ` cursor: pointer; `, [(0, cssr_1.cE)('ellipsis', ` max-width: calc(100% - 18px); `), (0, cssr_1.c)('&:hover', ` background-color: var(--n-merged-th-color-hover); `)]), (0, cssr_1.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); `, [(0, cssr_1.cB)('base-icon', 'transition: transform .3s var(--n-bezier)'), (0, cssr_1.cM)('desc', [(0, cssr_1.cB)('base-icon', ` transform: rotate(0deg); `)]), (0, cssr_1.cM)('asc', [(0, cssr_1.cB)('base-icon', ` transform: rotate(-180deg); `)]), (0, cssr_1.cM)('asc, desc', ` color: var(--n-th-icon-color-active); `)]), (0, cssr_1.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; `, [(0, cssr_1.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: ''; `), (0, cssr_1.cM)('active', [(0, cssr_1.c)('&::after', ` background-color: var(--n-th-icon-color-active); `)]), (0, cssr_1.c)('&:hover::after', ` background-color: var(--n-th-icon-color-active); `)]), (0, cssr_1.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); `, [(0, cssr_1.c)('&:hover', ` background-color: var(--n-th-button-color-hover); `), (0, cssr_1.cM)('show', ` background-color: var(--n-th-button-color-hover); `), (0, cssr_1.cM)('active', ` background-color: var(--n-th-button-color-hover); color: var(--n-th-icon-color-active); `)])]), (0, cssr_1.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); `, [(0, cssr_1.cM)('expand', [(0, cssr_1.cB)('data-table-expand-trigger', ` margin-right: 0; `)]), (0, cssr_1.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 (0, cssr_1.c)('&::after', ` bottom: 0 !important; `), (0, cssr_1.c)('&::before', ` bottom: 0 !important; `)]), (0, cssr_1.cM)('summary', ` background-color: var(--n-merged-th-color); `), (0, cssr_1.cM)('hover', ` background-color: var(--n-merged-td-color-hover); `), (0, cssr_1.cM)('sorting', ` background-color: var(--n-merged-td-color-sorting); `), (0, cssr_1.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); `), (0, cssr_1.cM)('selection, expand', ` text-align: center; padding: 0; line-height: 0; `), fixedColumnStyle]), (0, cssr_1.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); `, [(0, cssr_1.cM)('hide', ` opacity: 0; `)]), (0, cssr_1.cE)('pagination', ` margin: var(--n-pagination-margin); display: flex; justify-content: flex-end; `), (0, cssr_1.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); `), (0, cssr_1.cM)('loading', [(0, cssr_1.cB)('data-table-wrapper', ` opacity: var(--n-opacity-loading); pointer-events: none; `)]), (0, cssr_1.cM)('single-column', [(0, cssr_1.cB)('data-table-td', ` border-bottom: 0 solid var(--n-merged-border-color); `, [(0, cssr_1.c)('&::after, &::before', ` bottom: 0 !important; `)])]), (0, cssr_1.cNotM)('single-line', [(0, cssr_1.cB)('data-table-th', ` border-right: 1px solid var(--n-merged-border-color); `, [(0, cssr_1.cM)('last', ` border-right: 0 solid var(--n-merged-border-color); `)]), (0, cssr_1.cB)('data-table-td', ` border-right: 1px solid var(--n-merged-border-color); `, [(0, cssr_1.cM)('last-col', ` border-right: 0 solid var(--n-merged-border-color); `)])]), (0, cssr_1.cM)('bordered', [(0, cssr_1.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; `)]), (0, cssr_1.cB)('data-table-base-table', [(0, cssr_1.cM)('transition-disabled', [(0, cssr_1.cB)('data-table-th', [(0, cssr_1.c)('&::after, &::before', 'transition: none;')]), (0, cssr_1.cB)('data-table-td', [(0, cssr_1.c)('&::after, &::before', 'transition: none;')])])]), (0, cssr_1.cM)('bottom-bordered', [(0, cssr_1.cB)('data-table-td', [(0, cssr_1.cM)('last-row', ` border-bottom: 1px solid var(--n-merged-border-color); `)])]), (0, cssr_1.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); `), (0, cssr_1.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; `, [(0, cssr_1.c)('&::-webkit-scrollbar, &::-webkit-scrollbar-track-piece, &::-webkit-scrollbar-thumb', ` display: none; width: 0; height: 0; `)]), (0, cssr_1.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; `)]), (0, cssr_1.cB)('data-table-filter-menu', [(0, cssr_1.cB)('scrollbar', ` max-height: 240px; `), (0, cssr_1.cE)('group', ` display: flex; flex-direction: column; padding: 12px 12px 0 12px; `, [(0, cssr_1.cB)('checkbox', ` margin-bottom: 12px; margin-right: 0; `), (0, cssr_1.cB)('radio', ` margin-bottom: 12px; margin-right: 0; `)]), (0, cssr_1.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); `, [(0, cssr_1.cB)('button', [(0, cssr_1.c)('&:not(:last-child)', ` margin: var(--n-action-button-margin); `), (0, cssr_1.c)('&:last-child', ` margin-right: 0; `)])]), (0, cssr_1.cB)('divider', ` margin: 0 !important; `)]), (0, cssr_1.insideModal)((0, cssr_1.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); `)), (0, cssr_1.insidePopover)((0, cssr_1.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 [(0, cssr_1.cM)('fixed-left', ` left: 0; position: sticky; z-index: 2; `, [(0, cssr_1.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; `)]), (0, cssr_1.cM)('fixed-right', ` right: 0; position: sticky; z-index: 1; `, [(0, cssr_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; `)])]; }