All files / modules/75-cf/pages/segment-details/segment-details-page-options-menu SegmentDetailsPageOptionsMenu.tsx

100% Statements 14/14
50% Branches 1/2
100% Functions 1/1
100% Lines 14/14

Press n or j to go to the next uncovered block, b, p or k for the previous block.

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55              1x 1x 1x 1x 1x 1x 1x             1x 3x 3x 3x   3x                   3x                                   1x  
/*
 * Copyright 2022 Harness Inc. All rights reserved.
 * Use of this source code is governed by the PolyForm Shield 1.0.0 license
 * that can be found in the licenses directory at the root of this repository, also available at
 * https://polyformproject.org/wp-content/uploads/2020/06/PolyForm-Shield-1.0.0.txt.
 */
 
import React, { ReactElement } from 'react'
import usePlanEnforcement from '@cf/hooks/usePlanEnforcement'
import RbacOptionsMenuButton from '@rbac/components/RbacOptionsMenuButton/RbacOptionsMenuButton'
import { FeatureIdentifier } from 'framework/featureStore/FeatureIdentifier'
import { ResourceType } from '@rbac/interfaces/ResourceType'
import { PermissionIdentifier } from '@rbac/interfaces/PermissionIdentifier'
import { useStrings } from 'framework/strings'
 
export interface SegmentDetailsPageOptionsMenuProps {
  deleteSegmentConfirm: () => void
  activeEnvironment: string
}
 
const SegmentDetailsPageOptionsMenu = (props: SegmentDetailsPageOptionsMenuProps): ReactElement => {
  const { activeEnvironment, deleteSegmentConfirm } = props
  const { isPlanEnforcementEnabled } = usePlanEnforcement()
  const { getString } = useStrings()
 
  const planEnforcementProps = isPlanEnforcementEnabled
    ? {
        featuresProps: {
          featuresRequest: {
            featureNames: [FeatureIdentifier.MAUS]
          }
        }
      }
    : undefined
 
  return (
    <RbacOptionsMenuButton
      items={[
        {
          icon: 'cross',
          text: getString('delete'),
          onClick: deleteSegmentConfirm,
          permission: {
            resource: { resourceType: ResourceType.ENVIRONMENT, resourceIdentifier: activeEnvironment },
            permission: PermissionIdentifier.DELETE_FF_TARGETGROUP
          },
          ...planEnforcementProps
        }
      ]}
    />
  )
}
 
export default SegmentDetailsPageOptionsMenu