diff --git a/frontend/src/components/common/fixed-width-table.js b/frontend/src/components/common/fixed-width-table.js
index 12fd4b11a28..953831fbcf5 100644
--- a/frontend/src/components/common/fixed-width-table.js
+++ b/frontend/src/components/common/fixed-width-table.js
@@ -26,9 +26,19 @@ const FixedWidthTable = ({ className, headers, theadOptions = {}, children }) =>
{headers.map((header, index) => {
- const { width, isFixed, children: thChildren, className } = header;
- const validWidth = isFixed ? width : (containerWidth - fixedWidth) * width;
- return ({thChildren} | );
+ const { width, isFixed, className, onClick = () => {}, title = '', ariaLabel = '' } = header;
+ return (
+
+ {header.children}
+ |
+ );
})}
diff --git a/frontend/src/components/common/seahub-checkbox.js b/frontend/src/components/common/seahub-checkbox.js
new file mode 100644
index 00000000000..633701656af
--- /dev/null
+++ b/frontend/src/components/common/seahub-checkbox.js
@@ -0,0 +1,25 @@
+import React from 'react';
+import PropTypes from 'prop-types';
+import classnames from 'classnames';
+import '../../css/seahub-checkbox.css';
+
+const SeahubCheckbox = ({ isSelected, highlight }) => {
+ return (
+
+
+
+ );
+};
+
+SeahubCheckbox.propTypes = {
+ isSelected: PropTypes.bool,
+ highlight: PropTypes.bool,
+};
+
+export default SeahubCheckbox;
diff --git a/frontend/src/components/dirent-list-view/dirent-list-item.js b/frontend/src/components/dirent-list-view/dirent-list-item.js
index a44a81abe24..038e7bc3c5d 100644
--- a/frontend/src/components/dirent-list-view/dirent-list-item.js
+++ b/frontend/src/components/dirent-list-view/dirent-list-item.js
@@ -23,6 +23,7 @@ import LibSubFolderPermissionDialog from '../dialog/lib-sub-folder-permission-di
import FileAccessLog from '../dialog/file-access-log';
import toaster from '../toast';
import FileTag from './file-tag';
+import SeahubCheckbox from '../common/seahub-checkbox';
import '../../css/dirent-list-item.css';
@@ -829,16 +830,13 @@ class DirentListItem extends React.Component {
onMouseDown={this.onItemMouseDown}
onContextMenu={this.onItemContextMenu}
>
-
- {}}
- checked={isSelected}
- aria-label={isSelected ? gettext('Unselect this item') : gettext('Select this item')}
- />
+ |
+
|
{dirent.starred !== undefined &&
diff --git a/frontend/src/components/dirent-list-view/dirent-list-view.js b/frontend/src/components/dirent-list-view/dirent-list-view.js
index d7e4d426bf3..9104a79814c 100644
--- a/frontend/src/components/dirent-list-view/dirent-list-view.js
+++ b/frontend/src/components/dirent-list-view/dirent-list-view.js
@@ -22,6 +22,7 @@ import EmptyTip from '../empty-tip';
import imageAPI from '../../utils/image-api';
import { seafileAPI } from '../../utils/seafile-api';
import FixedWidthTable from '../common/fixed-width-table';
+import SeahubCheckbox from '../common/seahub-checkbox';
const propTypes = {
path: PropTypes.string.isRequired,
@@ -680,7 +681,7 @@ class DirentListView extends React.Component {
};
getHeaders = (isDesktop) => {
- const { direntList, sortBy, sortOrder } = this.props;
+ const { sortBy, sortOrder } = this.props;
if (!isDesktop) {
return [
{ isFixed: false, width: 0.12 },
@@ -689,36 +690,45 @@ class DirentListView extends React.Component {
];
}
- // sort
- const sortByName = sortBy == 'name';
- const sortByTime = sortBy == 'time';
- const sortBySize = sortBy == 'size';
- const sortIcon = sortOrder == 'asc' ? : ;
+ const sortIcon = ;
return [
- { isFixed: true, width: 31, className: 'pl10 pr-2', children: (
-
- ) }, {
+ { isFixed: true,
+ width: 31,
+ className: 'pl10 pr-2 cursor-pointer',
+ title: this.props.isAllItemSelected ? gettext('Unselect all items') : gettext('Select all items'),
+ ariaLabel: this.props.isAllItemSelected ? gettext('Unselect all items') : gettext('Select all items'),
+ children: (),
+ onClick: (e) => {
+ e.stopPropagation();
+ this.props.onAllItemSelected();
+ }
+ },
+ {
isFixed: true, width: 32, className: 'pl-2 pr-2', // star
- }, {
+ },
+ {
isFixed: true, width: 40, className: 'pl-2 pr-2', // icon
- }, {
- isFixed: false, width: 0.5, children: ({gettext('Name')} {sortByName && sortIcon}),
- }, {
+ },
+ {
+ isFixed: false,
+ width: 0.5,
+ children: ({gettext('Name')} {sortBy == 'name' && sortIcon}),
+ },
+ {
isFixed: false, width: 0.06, // tag
- }, {
+ },
+ {
isFixed: false, width: 0.18, // operation
- }, {
- isFixed: false, width: 0.11, children: ({gettext('Size')} {sortBySize && sortIcon})
- }, {
- isFixed: false, width: 0.15, children: ({gettext('Last Update')} {sortByTime && sortIcon})
+ },
+ {
+ isFixed: false,
+ width: 0.11,
+ children: ({gettext('Size')} {sortBy == 'size' && sortIcon})
+ },
+ {
+ isFixed: false,
+ width: 0.15,
+ children: ({gettext('Last Update')} {sortBy == 'time' && sortIcon})
}
];
};
@@ -728,7 +738,6 @@ class DirentListView extends React.Component {
const isDesktop = Utils.isDesktop();
const repoEncrypted = this.props.currentRepoInfo.encrypted;
- const headers = this.getHeaders(isDesktop);
return (
0 && (
{direntList.map((dirent, index) => {
diff --git a/frontend/src/css/seahub-checkbox.css b/frontend/src/css/seahub-checkbox.css
new file mode 100644
index 00000000000..9865a909083
--- /dev/null
+++ b/frontend/src/css/seahub-checkbox.css
@@ -0,0 +1,36 @@
+:root {
+ --seahub-checkbox-hover-color: #c1c5c8;
+ --seahub-checkbox-selected-color: #ff9800;
+ --seahub-checkbox-hover-selected-color: #eb8205;
+}
+
+.seahub-checkbox-icon {
+ width: 14px;
+ height: 14px;
+ display: flex;
+ justify-content: center;
+ align-items: center;
+ border-radius: 4px;
+ background-color: #fff;
+ border: 1px solid var(--seahub-checkbox-hover-color);
+}
+
+.seahub-checkbox-icon.seahub-checkbox-icon-highlight {
+ background-color: var(--seahub-checkbox-hover-color);
+}
+
+.seahub-checkbox-icon.seahub-checkbox-icon-selected {
+ background-color: var(--seahub-checkbox-selected-color);
+ border: 1px solid var(--seahub-checkbox-selected-color);
+}
+
+.seahub-checkbox-icon.seahub-checkbox-icon-highlight.seahub-checkbox-icon-selected {
+ background-color: var(--seahub-checkbox-hover-selected-color);
+ border: 1px solid var(--seahub-checkbox-hover-selected-color);
+}
+
+.seahub-checkbox-icon .sf2-icon-tick {
+ color: #fff;
+ font-size: 12px;
+ font-weight: 700;
+}
|