@craftercms/studio-ui
Version:
Services, components, models & utils to build CrafterCMS authoring extensions.
41 lines (39 loc) • 1.82 kB
TypeScript
/*
* Copyright (C) 2007-2022 Crafter Software Corporation. All Rights Reserved.
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU Lesser General Public License version 3 as published by
* the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
import ContentType from '../../models/ContentType';
import { Resource } from '../../models/Resource';
import { FetchContentTypeUsageResponse } from '../../services/contentTypes';
import { EnhancedDialogProps } from '../EnhancedDialog';
import React from 'react';
import { onSubmittingAndOrPendingChangeProps } from '../../hooks/useEnhancedDialogState';
export interface DeleteContentTypeBaseProps {
contentType: ContentType;
}
export interface DeleteContentTypeDialogProps extends DeleteContentTypeBaseProps, EnhancedDialogProps {
onSubmittingAndOrPendingChange(value: onSubmittingAndOrPendingChangeProps): void;
onComplete?(): any;
}
export interface DeleteContentTypeDialogContainerProps
extends DeleteContentTypeBaseProps,
Pick<DeleteContentTypeDialogProps, 'onComplete' | 'onClose' | 'isSubmitting' | 'onSubmittingAndOrPendingChange'> {}
export interface DeleteContentTypeDialogBodyProps {
submitting: boolean;
contentType: ContentType;
resource: Resource<FetchContentTypeUsageResponse>;
password?: string;
onCloseButtonClick?(e: React.MouseEvent<HTMLButtonElement, MouseEvent>): void;
onSubmit(): void;
}