| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154 |
- import React, { useState } from 'react';
- import { UserPicture } from '@growi/ui';
- import PropTypes from 'prop-types';
- import { useTranslation } from 'react-i18next';
- import PageContainer from '~/client/services/PageContainer';
- import { useCurrentUpdatedAt, useShareLinkId } from '~/stores/context';
- import { usePageDeleteModal, usePutBackPageModal } from '~/stores/modal';
- import { useSWRxPageInfo } from '~/stores/page';
- import EmptyTrashModal from '../EmptyTrashModal';
- import { withUnstatedContainers } from '../UnstatedUtils';
- const onDeletedHandler = (pathOrPathsToDelete, isRecursively, isCompletely) => {
- if (typeof pathOrPathsToDelete !== 'string') {
- return;
- }
- window.location.href = '/';
- };
- const TrashPageAlert = (props) => {
- const { t } = useTranslation();
- const { pageContainer } = props;
- const {
- pageId, revisionId, path, isDeleted, lastUpdateUsername, deletedUserName, deletedAt,
- } = pageContainer.state;
- const { data: shareLinkId } = useShareLinkId();
- /*
- * TODO: Do not use useSWRxPageInfo on this component
- * Ideal: use useSWRxPageInfo on TrashPage after applying Next.js
- * Reference: https://github.com/weseek/growi/pull/5359#discussion_r808381329
- */
- const { data: pageInfo } = useSWRxPageInfo(pageId ?? null, shareLinkId);
- const { data: updatedAt } = useCurrentUpdatedAt();
- const [isEmptyTrashModalShown, setIsEmptyTrashModalShown] = useState(false);
- const { open: openDeleteModal } = usePageDeleteModal();
- const { open: openPutBackPageModal } = usePutBackPageModal();
- function openEmptyTrashModalHandler() {
- setIsEmptyTrashModalShown(true);
- }
- function closeEmptyTrashModalHandler() {
- setIsEmptyTrashModalShown(false);
- }
- function openPutbackPageModalHandler() {
- const putBackedHandler = (path) => {
- window.location.reload();
- };
- openPutBackPageModal({ pageId, path }, { onPutBacked: putBackedHandler });
- }
- function openPageDeleteModalHandler() {
- const pageToDelete = {
- data: {
- _id: pageId,
- revision: revisionId,
- path,
- },
- meta: pageInfo,
- };
- openDeleteModal([pageToDelete], { onDeleted: onDeletedHandler });
- }
- function renderEmptyButton() {
- return (
- <button
- href="#"
- type="button"
- className="btn btn-danger rounded-pill btn-sm ml-auto"
- data-target="#emptyTrash"
- onClick={openEmptyTrashModalHandler}
- >
- <i className="icon-trash" aria-hidden="true"></i>{ t('modal_empty.empty_the_trash') }
- </button>
- );
- }
- function renderTrashPageManagementButtons() {
- return (
- <>
- <button
- type="button"
- className="btn btn-info rounded-pill btn-sm ml-auto mr-2"
- onClick={openPutbackPageModalHandler}
- data-toggle="modal"
- >
- <i className="icon-action-undo" aria-hidden="true"></i> { t('Put Back') }
- </button>
- <button
- type="button"
- className="btn btn-danger rounded-pill btn-sm"
- disabled={!(pageInfo?.isAbleToDeleteCompletely ?? false)}
- onClick={openPageDeleteModalHandler}
- >
- <i className="icon-fire" aria-hidden="true"></i> { t('Delete Completely') }
- </button>
- </>
- );
- }
- function renderModals() {
- return (
- <>
- <EmptyTrashModal
- isOpen={isEmptyTrashModalShown}
- onClose={closeEmptyTrashModalHandler}
- />
- </>
- );
- }
- return (
- <>
- <div className="alert alert-warning py-3 pl-4 d-flex flex-column flex-lg-row">
- <div className="flex-grow-1">
- This page is in the trash <i className="icon-trash" aria-hidden="true"></i>.
- {isDeleted && (
- <>
- <br />
- <UserPicture user={{ username: deletedUserName || lastUpdateUsername }} />
- <span className="ml-2">
- Deleted by {deletedUserName || lastUpdateUsername} at {deletedAt || updatedAt}
- </span>
- </>
- )}
- </div>
- <div className="pt-1 d-flex align-items-end align-items-lg-center">
- <span>{ pageContainer.isAbleToShowEmptyTrashButton && renderEmptyButton()}</span>
- { pageContainer.isAbleToShowTrashPageManagementButtons && renderTrashPageManagementButtons()}
- </div>
- </div>
- {renderModals()}
- </>
- );
- };
- TrashPageAlert.propTypes = {
- pageContainer: PropTypes.instanceOf(PageContainer).isRequired,
- };
- /**
- * Wrapper component for using unstated
- */
- const TrashPageAlertWrapper = withUnstatedContainers(TrashPageAlert, [PageContainer]);
- export default TrashPageAlertWrapper;
|