本文整理匯總了PHP中eZ\Publish\SPI\Persistence\Content\Type\Handler::removeFieldDefinition方法的典型用法代碼示例。如果您正苦於以下問題:PHP Handler::removeFieldDefinition方法的具體用法?PHP Handler::removeFieldDefinition怎麽用?PHP Handler::removeFieldDefinition使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類eZ\Publish\SPI\Persistence\Content\Type\Handler
的用法示例。
在下文中一共展示了Handler::removeFieldDefinition方法的2個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的PHP代碼示例。
示例1: removeFieldDefinition
/**
* Remove a field definition from an existing Type.
*
* @throws \eZ\Publish\API\Repository\Exceptions\InvalidArgumentException If the given field definition does not belong to the given type
* @throws \eZ\Publish\API\Repository\Exceptions\UnauthorizedException if the user is not allowed to edit a content type
*
* @param \eZ\Publish\API\Repository\Values\ContentType\ContentTypeDraft $contentTypeDraft
* @param \eZ\Publish\API\Repository\Values\ContentType\FieldDefinition $fieldDefinition
*/
public function removeFieldDefinition( APIContentTypeDraft $contentTypeDraft, APIFieldDefinition $fieldDefinition )
{
if ( $this->repository->hasAccess( 'class', 'update' ) !== true )
throw new UnauthorizedException( 'ContentType', 'update' );
$loadedFieldDefinition = $this->loadContentTypeDraft(
$contentTypeDraft->id
)->getFieldDefinition(
$fieldDefinition->identifier
);
if ( empty( $loadedFieldDefinition ) || $loadedFieldDefinition->id != $fieldDefinition->id )
{
throw new InvalidArgumentException(
"\$fieldDefinition",
"The given FieldDefinition does not belong to the ContentType"
);
}
$this->repository->beginTransaction();
try
{
$this->contentTypeHandler->removeFieldDefinition(
$contentTypeDraft->id,
SPIContentType::STATUS_DRAFT,
$fieldDefinition->id
);
$this->repository->commit();
}
catch ( Exception $e )
{
$this->repository->rollback();
throw $e;
}
}
示例2: removeFieldDefinition
/**
* Removes a field definition from an existing Type.
*
* This method creates a new status of the Type with the field definition
* referred to by $fieldDefinitionId removed. It does not update existing
* content objects depending on the field (default) values.
*
* @param mixed $contentTypeId
* @param mixed $fieldDefinitionId
* @return boolean
*/
public function removeFieldDefinition($contentTypeId, $status, $fieldDefinitionId)
{
$this->clearCache();
return $this->innerHandler->removeFieldDefinition($contentTypeId, $status, $fieldDefinitionId);
}