From 694f9448adeb849c21bb81ec582be3d8abf9ac0e Mon Sep 17 00:00:00 2001 From: Giulia Ghisini Date: Wed, 18 Dec 2024 16:22:44 +0100 Subject: [PATCH] added pagination, select all, column op --- .../manage/Controlpanels/UndoControlpanel.jsx | 271 ++++++++---------- .../volto/src/components/theme/Logo/Logo.jsx | 4 +- 2 files changed, 116 insertions(+), 159 deletions(-) diff --git a/packages/volto/src/components/manage/Controlpanels/UndoControlpanel.jsx b/packages/volto/src/components/manage/Controlpanels/UndoControlpanel.jsx index 5bb3ba7766..8b9ace7193 100644 --- a/packages/volto/src/components/manage/Controlpanels/UndoControlpanel.jsx +++ b/packages/volto/src/components/manage/Controlpanels/UndoControlpanel.jsx @@ -16,6 +16,7 @@ import { Dimmer, Loader, Checkbox, + Message, Confirm, } from 'semantic-ui-react'; import { FormattedMessage, defineMessages, injectIntl } from 'react-intl'; @@ -28,8 +29,6 @@ import map from 'lodash/map'; import remove from 'lodash/remove'; import findIndex from 'lodash/findIndex'; import Helmet from '@plone/volto/helpers/Helmet/Helmet'; -import nextIcon from '@plone/volto/icons/right-key.svg'; -import prevIcon from '@plone/volto/icons/left-key.svg'; import undoSVG from '@plone/volto/icons/undo.svg'; import { getTransactions, @@ -37,6 +36,7 @@ import { } from '@plone/volto/actions/transactions/transactions'; import FormattedDate from '@plone/volto/components/theme/FormattedDate/FormattedDate'; import { toast } from 'react-toastify'; +import Pagination from '@plone/volto/components/theme/Pagination/Pagination'; const messages = defineMessages({ success: { @@ -88,17 +88,22 @@ const messages = defineMessages({ defaultMessage: 'Filter transactions by User, Path or Date', }, filterByUsername_filter: { - id: 'Enter Username', + id: 'Enter Username to filter', defaultMessage: 'Enter Username', }, filterByPath_filter: { - id: 'Enter Path', + id: 'Enter path to filter', defaultMessage: 'Enter Path', }, filterByDate_filter: { - id: 'Enter Date', + id: 'Enter Date and time to filter', defaultMessage: 'Enter Date and time', }, + filterByDate_filter_description: { + id: 'Enter Date description filter', + defaultMessage: + 'Will display transactions from start of selected day, until time selected', + }, failedToUndoTransactions: { id: 'Failed To Undo Transactions', defaultMessage: 'Failed to undo transactions', @@ -123,16 +128,14 @@ const messages = defineMessages({ id: 'Please enter any input to perform filter', defaultMessage: 'Please enter any input to perform filter', }, - prevPage: { - id: 'Prev page', - defaultMessage: 'Previous page', - }, - nextPage: { - id: 'Next page', - defaultMessage: 'Next page', + selectAll: { + id: 'Select all', + defaultMessage: 'Select all', }, }); +const PAGE_SIZES = [20, 50, 100, 200, 500]; + /** * UndoControlpanel class. * @class UndoControlpanel @@ -177,32 +180,28 @@ class UndoControlpanel extends Component { this.state = { isClient: false, filterType: 'no value', + currentPage: 0, lowerIndex: 0, upperIndex: 20, selectedTransactions: [], - defaultTransactionsLenInTable: 20, + pageSize: 20, isFilterTypeSelected: false, filteredTransactions: [], isemptyInputForFiltering: false, isTransactionsNotFound: false, undoRequested: false, doUndo: false, - showPrevButton: false, - showNextButton: false, }; this.onCancelFilter = this.onCancelFilter.bind(this); this.onFilter = this.onFilter.bind(this); this.onSelect = this.onSelect.bind(this); - this.onPrev = this.onPrev.bind(this); - this.onNext = this.onNext.bind(this); + this.onUndo = this.onUndo.bind(this); this.handleTableVisiblity = this.handleTableVisiblity.bind(this); - this.handleNotFilteredNextPrevButtons = - this.handleNotFilteredNextPrevButtons.bind(this); - this.handleFilteredNextPrevButtons = - this.handleFilteredNextPrevButtons.bind(this); this.checkTransactionsUndoneStatus = this.checkTransactionsUndoneStatus.bind(this); + this.toggleCheckedTransactions = this.toggleCheckedTransactions.bind(this); + this.onChangePageSize = this.onChangePageSize.bind(this); } /** @@ -234,7 +233,7 @@ class UndoControlpanel extends Component { if (filteredTransactions.length > 0) { this.setState({ lowerIndex: 0, - upperIndex: this.state.defaultTransactionsLenInTable, + upperIndex: this.state.pageSize, filteredTransactions: filteredTransactions, isemptyInputForFiltering: false, isTransactionsNotFound: false, @@ -268,7 +267,7 @@ class UndoControlpanel extends Component { filterType: 'no value', filteredTransactions: [], lowerIndex: 0, - upperIndex: this.state.defaultTransactionsLenInTable, + upperIndex: this.state.pageSize, }); } @@ -385,87 +384,12 @@ class UndoControlpanel extends Component { } /** - * On Prev - * @method onPrev - * @returns {undefined} - */ - onPrev() { - 0 < this.state.lowerIndex && - this.setState({ - upperIndex: this.state.lowerIndex, - lowerIndex: - this.state.lowerIndex - this.state.defaultTransactionsLenInTable, - }); - } - - /** - * On Next - * @method onNext - * @returns {undefined} - */ - onNext() { - this.props.transactions.length > this.state.upperIndex && - this.setState({ - lowerIndex: this.state.upperIndex, - upperIndex: - this.state.upperIndex + this.state.defaultTransactionsLenInTable, - }); - } - - /** - * Handle next and prev buttons visibility when transactions are filtered - * @method handleFilteredNextPrevButtons - * @returns {undefined} - */ - handleFilteredNextPrevButtons() { - this.state.upperIndex >= this.state.filteredTransactions.length && - this.state.showNextButton && - this.setState({ showNextButton: false }); - - this.state.upperIndex < this.state.filteredTransactions.length && - !this.state.showNextButton && - this.setState({ showNextButton: true }); - - this.state.lowerIndex <= 0 && - this.state.showPrevButton && - this.setState({ showPrevButton: false }); - - this.state.lowerIndex > 0 && - !this.state.showPrevButton && - this.setState({ showPrevButton: true }); - } - - /** - * Handle next and prev buttons visibility when transactions are not filtered - * @method handleNotFilteredNextPrevButtons - * @returns {undefined} - */ - handleNotFilteredNextPrevButtons() { - this.state.upperIndex >= this.props.transactions?.length && - this.state.showNextButton && - this.setState({ showNextButton: false }); - - this.state.upperIndex < this.props.transactions?.length && - !this.state.showNextButton && - this.setState({ showNextButton: true }); - - this.state.lowerIndex <= 0 && - this.state.showPrevButton && - this.setState({ showPrevButton: false }); - - this.state.lowerIndex > 0 && - !this.state.showPrevButton && - this.setState({ showPrevButton: true }); - } - - /** - * Handle next, prev buttons and table visibility + * Handle table visibility * @method handleTableVisiblity * @returns {undefined} */ handleTableVisiblity() { if (this.state.filteredTransactions.length > 0) { - this.handleFilteredNextPrevButtons(); } else if (!this.state.isFilterTypeSelected) { this.props.transactions?.length > 0 && this.state.isTransactionsNotFound && @@ -474,10 +398,6 @@ class UndoControlpanel extends Component { this.props.transactions?.length <= 0 && !this.state.isTransactionsNotFound && this.setState({ isTransactionsNotFound: true }); - - this.handleNotFilteredNextPrevButtons(); - } else { - this.handleNotFilteredNextPrevButtons(); } } @@ -523,16 +443,37 @@ class UndoControlpanel extends Component { } } - toggleCheckedTransactions(t, checked) { + toggleCheckedTransactions(items, checked) { let list = [...this.state.selectedTransactions]; - if (checked) { - list.push(t); - } else { - remove(list, t); - } + items.map((t) => { + const selected = findIndex(list, t) >= 0; + if (selected) { + if (!checked) { + remove(list, t); + } + } else { + if (checked) { + list.push(t); + } + } + }); this.setState({ selectedTransactions: list }); } + onChangePageSize(e, v) { + this.setState({ + upperIndex: this.state.pageSize, + lowerIndex: 0, + selectAll: false, + pageSize: v.value, + }); + } + + onChangePage = (event, { value }) => { + this.setState({ + currentPage: value, + }); + }; /** * Render method. * @method render @@ -542,19 +483,33 @@ class UndoControlpanel extends Component { const transactionsRange = (this.state.filteredTransactions.length > 0 && this.state.filteredTransactions.slice( - this.state.lowerIndex, - this.state.upperIndex, + this.state.currentPage * this.state.pageSize, + this.state.pageSize * (this.state.currentPage + 1), )) || this.props.transactions?.slice( - this.state.lowerIndex, - this.state.upperIndex, + this.state.currentPage * this.state.pageSize, + this.state.pageSize * (this.state.currentPage + 1), ); this.handleTableVisiblity(); this.checkTransactionsUndoneStatus(); const TransactionsTable = ({ items, summary = false }) => { + const getReqType = (str) => { + const regex = /\/([^\/@]*_application_json_[^\/@]*)/; + + const matches = str.match(regex); + + const t = matches?.length > 0 ? matches[1] : null; + return { + t: t, + type: t?.replace('_application_json_', ''), + clearStr: t ? str.replaceAll(t, '') : str, + }; + }; + const elabDescription = (d) => { - const parts = d + const str = getReqType(d).clearStr ?? ''; + const parts = str .replaceAll('\nUndo', '
Undo:') .replaceAll('\n', '
') .replaceAll(' ', '
') @@ -573,6 +528,7 @@ class UndoControlpanel extends Component { ); }; + return ( @@ -583,13 +539,20 @@ class UndoControlpanel extends Component { textAlign="center" style={{ width: '40px' }} > - { + this.setState({ selectAll: data.checked }); + this.toggleCheckedTransactions(items, data.checked); + }} + checked={this.state.selectAll} /> )} - + + + + @@ -614,7 +577,7 @@ class UndoControlpanel extends Component { { this.toggleCheckedTransactions( - transaction, + [transaction], data.checked, ); }} @@ -627,8 +590,11 @@ class UndoControlpanel extends Component { /> )} + + {getReqType(transaction.description).type ?? ''} + {elabDescription(transaction.description)} @@ -660,24 +626,18 @@ class UndoControlpanel extends Component { - - {this.state.showPrevButton && ( - - - + + + - - {this.state.showNextButton ? ( - - ) : ( -
- )} -
@@ -797,6 +738,9 @@ class UndoControlpanel extends Component { title: this.props.intl.formatMessage( messages.filterByDate_filter, ), + description: this.props.intl.formatMessage( + messages.filterByDate_filter_description, + ), type: 'date', }, }, @@ -844,7 +788,20 @@ class UndoControlpanel extends Component { /> ) : ( - + <> + {this.state.selectedTransactions.length > 0 && ( + + + + )} + + )} diff --git a/packages/volto/src/components/theme/Logo/Logo.jsx b/packages/volto/src/components/theme/Logo/Logo.jsx index e2bb4cd73e..2a67830c0f 100644 --- a/packages/volto/src/components/theme/Logo/Logo.jsx +++ b/packages/volto/src/components/theme/Logo/Logo.jsx @@ -46,7 +46,7 @@ const Logo = () => { return ( - { alt={ intl.formatMessage(messages.logoOf) + ' ' + site['plone.site_title'] } - /> + /> */} ); };