From 387b5938ebd469708dae997d5d4701ebb1215edb Mon Sep 17 00:00:00 2001 From: Matt Gallo Date: Thu, 4 May 2023 13:17:16 -0400 Subject: [PATCH] feat(Datagrid): add feature flag to select hooks until fully released (#2937) --- packages/cloud-cognitive/README.md | 2 +- .../components/Datagrid/Datagrid.stories.js | 7 +++++++ .../ColumnCustomization.stories.js | 21 +++++++++++++++++++ .../ExpandableRow/ExpandableRow.stories.js | 17 ++++++++++++++- .../Extensions/Filtering/Flyout.stories.js | 15 +++++++++++++ .../InlineEdit/InlineEdit.stories.js | 15 ++++++++++++- .../NestedRows/NestedRows.stories.js | 18 +++++++++++++++- .../RowActionButtons.stories.js | 17 ++++++++++++++- .../components/Datagrid/useActionsColumn.js | 18 +++++++++------- .../Datagrid/useCustomizeColumns.js | 7 ++++++- .../src/components/Datagrid/useExpandedRow.js | 19 ++++++++++------- .../src/components/Datagrid/useFiltering.js | 20 +++++++++++------- .../src/components/Datagrid/useInlineEdit.js | 4 ++++ .../src/components/Datagrid/useNestedRows.js | 17 +++++++++------ .../src/global/js/package-settings.js | 13 +++++++++++- packages/core/.storybook/index.scss | 2 +- packages/core/.storybook/preview.js | 4 +++- 17 files changed, 179 insertions(+), 37 deletions(-) diff --git a/packages/cloud-cognitive/README.md b/packages/cloud-cognitive/README.md index 47c3997e4a..37ce7f4837 100644 --- a/packages/cloud-cognitive/README.md +++ b/packages/cloud-cognitive/README.md @@ -102,7 +102,7 @@ const App = () => { }; ``` -### Enabling Canary components +### Enabling Canary components and flagged features Components that have not yet completed the release review process are considered to be canary and require the consumer to enable via a feature flag in a diff --git a/packages/cloud-cognitive/src/components/Datagrid/Datagrid.stories.js b/packages/cloud-cognitive/src/components/Datagrid/Datagrid.stories.js index f742688706..fe49f4963f 100644 --- a/packages/cloud-cognitive/src/components/Datagrid/Datagrid.stories.js +++ b/packages/cloud-cognitive/src/components/Datagrid/Datagrid.stories.js @@ -43,6 +43,13 @@ export default { page: mdx, }, }, + argTypes: { + featureFlags: { + table: { + disable: true, + }, + }, + }, }; const getColumns = (rows) => { diff --git a/packages/cloud-cognitive/src/components/Datagrid/Extensions/ColumnCustomization/ColumnCustomization.stories.js b/packages/cloud-cognitive/src/components/Datagrid/Extensions/ColumnCustomization/ColumnCustomization.stories.js index 9d235b1055..160cac9af8 100644 --- a/packages/cloud-cognitive/src/components/Datagrid/Extensions/ColumnCustomization/ColumnCustomization.stories.js +++ b/packages/cloud-cognitive/src/components/Datagrid/Extensions/ColumnCustomization/ColumnCustomization.stories.js @@ -39,6 +39,13 @@ export default { styles, docs: { page: mdx }, }, + argTypes: { + featureFlags: { + table: { + disable: true, + }, + }, + }, }; const blockClass = `${pkg.prefix}--datagrid`; @@ -199,6 +206,12 @@ const ColumnCustomizationUsage = ({ ...args }) => { useColumnOrder ); + // Warnings are ordinarily silenced in storybook, add this to test + pkg._silenceWarnings(false); + // Enable feature flag for `useCustomizeColumns` hook + pkg.feature['Datagrid.useCustomizeColumns'] = true; + pkg._silenceWarnings(true); + return ( <> @@ -235,6 +248,7 @@ export const ColumnCustomizationUsageStory = prepareStory( }, args: { ...columnCustomizationControlProps, + featureFlags: ['Datagrid.useCustomizeColumns'], }, } ); @@ -263,6 +277,12 @@ const ColumnCustomizationWithFixedColumn = ({ ...args }) => { ); const [data] = useState(makeData(10)); + // Warnings are ordinarily silenced in storybook, add this to test + pkg._silenceWarnings(false); + // Enable feature flag for `useCustomizeColumns` hook + pkg.feature['Datagrid.useCustomizeColumns'] = true; + pkg._silenceWarnings(true); + const datagridState = useDatagrid( { className: `c4p--datagrid__hidden--columns`, @@ -337,6 +357,7 @@ export const ColumnCustomizationWithFixedColumnStory = prepareStory( }, args: { ...columnCustomizationControlProps, + featureFlags: ['Datagrid.useCustomizeColumns'], }, } ); diff --git a/packages/cloud-cognitive/src/components/Datagrid/Extensions/ExpandableRow/ExpandableRow.stories.js b/packages/cloud-cognitive/src/components/Datagrid/Extensions/ExpandableRow/ExpandableRow.stories.js index 2452c1822c..76d2665110 100644 --- a/packages/cloud-cognitive/src/components/Datagrid/Extensions/ExpandableRow/ExpandableRow.stories.js +++ b/packages/cloud-cognitive/src/components/Datagrid/Extensions/ExpandableRow/ExpandableRow.stories.js @@ -1,6 +1,6 @@ /* eslint-disable react-hooks/exhaustive-deps */ /** - * Copyright IBM Corp. 2022, 2022 + * Copyright IBM Corp. 2022, 2023 * * This source code is licensed under the Apache-2.0 license found in the * LICENSE file in the root directory of this source tree. @@ -20,6 +20,7 @@ import { DatagridActions } from '../../utils/DatagridActions'; import { DatagridPagination } from '../../utils/DatagridPagination'; import { makeData } from '../../utils/makeData'; import { ARG_TYPES } from '../../utils/getArgTypes'; +import { pkg } from '../../../../settings'; export default { title: `${getStoryTitle(Datagrid.displayName)}/Extensions/ExpandableRow`, @@ -28,6 +29,13 @@ export default { styles, docs: { page: mdx }, }, + argTypes: { + featureFlags: { + table: { + disable: true, + }, + }, + }, }; const defaultHeader = [ @@ -198,6 +206,12 @@ const ExpandedRows = ({ ...args }) => { const [data] = useState(makeData(10)); const rows = React.useMemo(() => data, [data]); + // Warnings are ordinarily silenced in storybook, add this to test. + pkg._silenceWarnings(false); + // Enable feature flag for `useExpandedRow` hook + pkg.feature['Datagrid.useExpandedRow'] = true; + pkg._silenceWarnings(true); + const datagridState = useDatagrid( { columns, @@ -236,5 +250,6 @@ export const ExpandableRowStory = prepareStory(BasicTemplateWrapper, { }, args: { ...expandableRowControlProps, + featureFlags: ['Datagrid.useExpandedRow'], }, }); diff --git a/packages/cloud-cognitive/src/components/Datagrid/Extensions/Filtering/Flyout.stories.js b/packages/cloud-cognitive/src/components/Datagrid/Extensions/Filtering/Flyout.stories.js index e50a9c2bbe..87174ef3c2 100644 --- a/packages/cloud-cognitive/src/components/Datagrid/Extensions/Filtering/Flyout.stories.js +++ b/packages/cloud-cognitive/src/components/Datagrid/Extensions/Filtering/Flyout.stories.js @@ -20,6 +20,7 @@ import { makeData } from '../../utils/makeData'; import { ARG_TYPES } from '../../utils/getArgTypes'; import { DatagridActions } from '../../utils/DatagridActions'; import { StatusIcon } from '../../../StatusIcon'; +import { pkg } from '../../../../settings'; export default { title: `${getStoryTitle(Datagrid.displayName)}/Extensions/Filtering/Flyout`, @@ -28,6 +29,13 @@ export default { styles, docs: { page: mdx }, }, + argTypes: { + featureFlags: { + table: { + disable: true, + }, + }, + }, }; const getBatchActions = () => { @@ -153,6 +161,12 @@ const FilteringUsage = ({ defaultGridProps }) => { const columns = React.useMemo(() => headers, []); const [data] = useState(makeData(20)); + // Warnings are ordinarily silenced in storybook, add this to test + pkg._silenceWarnings(false); + // Enable feature flag for `useFiltering` hook + pkg.feature['Datagrid.useFiltering'] = true; + pkg._silenceWarnings(true); + const datagridState = useDatagrid( { columns, @@ -310,6 +324,7 @@ export const FlyoutBatch = prepareStory(FilteringTemplateWrapper, { onFlyoutClose: action('onFlyoutClose'), filters, }, + featureFlags: ['Datagrid.useFiltering'], }, }); diff --git a/packages/cloud-cognitive/src/components/Datagrid/Extensions/InlineEdit/InlineEdit.stories.js b/packages/cloud-cognitive/src/components/Datagrid/Extensions/InlineEdit/InlineEdit.stories.js index 80cd484ff0..36469292b5 100644 --- a/packages/cloud-cognitive/src/components/Datagrid/Extensions/InlineEdit/InlineEdit.stories.js +++ b/packages/cloud-cognitive/src/components/Datagrid/Extensions/InlineEdit/InlineEdit.stories.js @@ -1,6 +1,6 @@ /* eslint-disable react-hooks/exhaustive-deps */ /** - * Copyright IBM Corp. 2022, 2022 + * Copyright IBM Corp. 2022, 2023 * * This source code is licensed under the Apache-2.0 license found in the * LICENSE file in the root directory of this source tree. @@ -31,6 +31,13 @@ export default { styles, docs: { page: mdx }, }, + argTypes: { + featureFlags: { + table: { + disable: true, + }, + }, + }, }; const sharedDatagridProps = { @@ -84,6 +91,11 @@ const InlineEditUsage = ({ ...args }) => { const [data, setData] = useState(makeData(10)); const columns = React.useMemo(() => getInlineEditColumns(), []); + // Warnings are ordinarily silenced in storybook, add this to test. + pkg._silenceWarnings(false); + pkg.feature['Datagrid.useInlineEdit'] = true; + pkg._silenceWarnings(true); + const datagridState = useDatagrid( { columns, @@ -151,5 +163,6 @@ export const InlineEditUsageStory = prepareStory(InlineEditTemplateWrapper, { }, args: { ...inlineEditUsageControlProps, + featureFlags: ['Datagrid.useInlineEdit'], }, }); diff --git a/packages/cloud-cognitive/src/components/Datagrid/Extensions/NestedRows/NestedRows.stories.js b/packages/cloud-cognitive/src/components/Datagrid/Extensions/NestedRows/NestedRows.stories.js index 1a6cc888ac..568b130d85 100644 --- a/packages/cloud-cognitive/src/components/Datagrid/Extensions/NestedRows/NestedRows.stories.js +++ b/packages/cloud-cognitive/src/components/Datagrid/Extensions/NestedRows/NestedRows.stories.js @@ -1,6 +1,6 @@ /* eslint-disable react-hooks/exhaustive-deps */ /** - * Copyright IBM Corp. 2022, 2022 + * Copyright IBM Corp. 2022, 2023 * * This source code is licensed under the Apache-2.0 license found in the * LICENSE file in the root directory of this source tree. @@ -19,6 +19,7 @@ import mdx from '../../Datagrid.mdx'; import { DatagridActions } from '../../utils/DatagridActions'; import { makeData } from '../../utils/makeData'; import { ARG_TYPES } from '../../utils/getArgTypes'; +import { pkg } from '../../../../settings'; export default { title: `${getStoryTitle(Datagrid.displayName)}/Extensions/NestedRows`, @@ -27,6 +28,13 @@ export default { styles, docs: { page: mdx }, }, + argTypes: { + featureFlags: { + table: { + disable: true, + }, + }, + }, }; const defaultHeader = [ @@ -146,6 +154,13 @@ const sharedDatagridProps = { const NestedRows = ({ ...args }) => { const columns = React.useMemo(() => defaultHeader, []); const [data] = useState(makeData(10, 5, 2, 2)); + + // Warnings are ordinarily silenced in storybook, add this to test + pkg._silenceWarnings(false); + // Enable feature flag for `useNestedRows` hook + pkg.feature['Datagrid.useNestedRows'] = true; + pkg._silenceWarnings(true); + const datagridState = useDatagrid( { columns, @@ -184,5 +199,6 @@ export const NestedRowsUsageStory = prepareStory(BasicTemplateWrapper, { }, args: { ...nestedRowsControlProps, + featureFlags: ['Datagrid.useNestedRows'], }, }); diff --git a/packages/cloud-cognitive/src/components/Datagrid/Extensions/RowActionButtons/RowActionButtons.stories.js b/packages/cloud-cognitive/src/components/Datagrid/Extensions/RowActionButtons/RowActionButtons.stories.js index e34f74be72..86eac41f23 100644 --- a/packages/cloud-cognitive/src/components/Datagrid/Extensions/RowActionButtons/RowActionButtons.stories.js +++ b/packages/cloud-cognitive/src/components/Datagrid/Extensions/RowActionButtons/RowActionButtons.stories.js @@ -1,6 +1,6 @@ /* eslint-disable react-hooks/exhaustive-deps */ /** - * Copyright IBM Corp. 2022, 2022 + * Copyright IBM Corp. 2022, 2023 * * This source code is licensed under the Apache-2.0 license found in the * LICENSE file in the root directory of this source tree. @@ -27,6 +27,7 @@ import { DatagridActions } from '../../utils/DatagridActions'; import { DatagridPagination } from '../../utils/DatagridPagination'; import { makeData } from '../../utils/makeData'; import { ARG_TYPES } from '../../utils/getArgTypes'; +import { pkg } from '../../../../settings'; export default { title: `${getStoryTitle(Datagrid.displayName)}/Extensions/RowActionButtons`, @@ -35,6 +36,13 @@ export default { styles, docs: { page: mdx }, }, + argTypes: { + featureFlags: { + table: { + disable: true, + }, + }, + }, }; const defaultHeader = [ @@ -166,6 +174,12 @@ const RowActionButtons = ({ ...args }) => { const [data] = useState(makeData(10)); const rows = React.useMemo(() => data, [data]); + // Warnings are ordinarily silenced in storybook, add this to test. + pkg._silenceWarnings(false); + // Enable feature flag for `useActionsColumn` hook + pkg.feature['Datagrid.useActionsColumn'] = true; + pkg._silenceWarnings(true); + const datagridState = useDatagrid( { columns, @@ -208,6 +222,7 @@ export const RowActionButtonsUsageStory = prepareStory( }, args: { ...rowActionButtonsProps, + featureFlags: ['Datagrid.useActionsColumn'], }, } ); diff --git a/packages/cloud-cognitive/src/components/Datagrid/useActionsColumn.js b/packages/cloud-cognitive/src/components/Datagrid/useActionsColumn.js index abee7ee794..0af2c44ddb 100644 --- a/packages/cloud-cognitive/src/components/Datagrid/useActionsColumn.js +++ b/packages/cloud-cognitive/src/components/Datagrid/useActionsColumn.js @@ -1,11 +1,11 @@ -/* - * Licensed Materials - Property of IBM - * 5724-Q36 - * (c) Copyright IBM Corp. 2021 - * US Government Users Restricted Rights - Use, duplication or disclosure - * restricted by GSA ADP Schedule Contract with IBM Corp. +/** + * Copyright IBM Corp. 2021, 2023 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. */ -import React from 'react'; + +import React, { useEffect } from 'react'; import cx from 'classnames'; import { IconSkeleton, @@ -16,6 +16,10 @@ import { pkg } from '../../settings'; const blockClass = `${pkg.prefix}--datagrid`; const useActionsColumn = (hooks) => { + useEffect(() => { + pkg.checkReportFeatureEnabled('Datagrid.useActionsColumn'); + }, []); + const useAttachActionsOnInstance = (instance) => { const { rowActions, isFetching, selectedFlatRows } = instance; diff --git a/packages/cloud-cognitive/src/components/Datagrid/useCustomizeColumns.js b/packages/cloud-cognitive/src/components/Datagrid/useCustomizeColumns.js index d6645203d4..faafdcbd34 100644 --- a/packages/cloud-cognitive/src/components/Datagrid/useCustomizeColumns.js +++ b/packages/cloud-cognitive/src/components/Datagrid/useCustomizeColumns.js @@ -1,17 +1,22 @@ /** - * Copyright IBM Corp. 2022, 2022 + * Copyright IBM Corp. 2022, 2023 * * This source code is licensed under the Apache-2.0 license found in the * LICENSE file in the root directory of this source tree. */ import * as React from 'react'; +import { pkg } from '../../settings'; import { CustomizeColumnsTearsheetWrapper, ToggleButtonWrapper, } from './Datagrid/addons/CustomizeColumns'; const useCustomizeColumns = (hooks) => { + React.useEffect(() => { + pkg.checkReportFeatureEnabled('Datagrid.useCustomizeColumns'); + }, []); + const [isTearsheetOpen, setIsTearsheetOpen] = React.useState(false); hooks.useInstance.push((instance) => { const { customizeColumnsProps } = instance; diff --git a/packages/cloud-cognitive/src/components/Datagrid/useExpandedRow.js b/packages/cloud-cognitive/src/components/Datagrid/useExpandedRow.js index fceebb2ffb..c63f99b7ba 100644 --- a/packages/cloud-cognitive/src/components/Datagrid/useExpandedRow.js +++ b/packages/cloud-cognitive/src/components/Datagrid/useExpandedRow.js @@ -1,15 +1,20 @@ -/* - * Licensed Materials - Property of IBM - * 5724-Q36 - * (c) Copyright IBM Corp. 2020 - * US Government Users Restricted Rights - Use, duplication or disclosure - * restricted by GSA ADP Schedule Contract with IBM Corp. +/** + * Copyright IBM Corp. 2020, 2023 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. */ -import { useState } from 'react'; + +import { useEffect, useState } from 'react'; +import { pkg } from '../../settings'; import DatagridExpandedRow from './Datagrid/DatagridExpandedRow'; import useRowExpander from './useRowExpander'; const useExpandedRow = (hooks) => { + useEffect(() => { + pkg.checkReportFeatureEnabled('Datagrid.useExpandedRow'); + }, []); + useRowExpander(hooks); const useInstance = (instance) => { const { rows, expandedContentHeight, ExpandedRowContentComponent } = diff --git a/packages/cloud-cognitive/src/components/Datagrid/useFiltering.js b/packages/cloud-cognitive/src/components/Datagrid/useFiltering.js index 3c22d21fb9..bb8bddaa20 100644 --- a/packages/cloud-cognitive/src/components/Datagrid/useFiltering.js +++ b/packages/cloud-cognitive/src/components/Datagrid/useFiltering.js @@ -1,16 +1,20 @@ -// @flow -/* - * Licensed Materials - Property of IBM - * 5724-Q36 - * (c) Copyright IBM Corp. 2022 - * US Government Users Restricted Rights - Use, duplication or disclosure - * restricted by GSA ADP Schedule Contract with IBM Corp. +/** + * Copyright IBM Corp. 2022, 2023 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. */ -import { useMemo } from 'react'; + +import { useMemo, useEffect } from 'react'; +import { pkg } from '../../settings'; import { FilterFlyout } from './Datagrid/addons/Filtering'; import { BATCH } from './Datagrid/addons/Filtering/constants'; const useFiltering = (hooks) => { + useEffect(() => { + pkg.checkReportFeatureEnabled('Datagrid.useFiltering'); + }, []); + const filterTypes = useMemo( () => ({ date: (rows, id, [startDate, endDate]) => { diff --git a/packages/cloud-cognitive/src/components/Datagrid/useInlineEdit.js b/packages/cloud-cognitive/src/components/Datagrid/useInlineEdit.js index 18da5f3c0a..db23a2630b 100644 --- a/packages/cloud-cognitive/src/components/Datagrid/useInlineEdit.js +++ b/packages/cloud-cognitive/src/components/Datagrid/useInlineEdit.js @@ -14,6 +14,10 @@ import { warn } from '../../global/js/utils/pconsole'; const blockClass = `${pkg.prefix}--datagrid`; const useInlineEdit = (hooks, usingEditableCell) => { + useEffect(() => { + pkg.checkReportFeatureEnabled('Datagrid.useInlineEdit'); + }, []); + useEffect(() => { if (!usingEditableCell) { warn( diff --git a/packages/cloud-cognitive/src/components/Datagrid/useNestedRows.js b/packages/cloud-cognitive/src/components/Datagrid/useNestedRows.js index 87fec4a6f9..4bfa4a17b1 100644 --- a/packages/cloud-cognitive/src/components/Datagrid/useNestedRows.js +++ b/packages/cloud-cognitive/src/components/Datagrid/useNestedRows.js @@ -1,10 +1,11 @@ -/* - * Licensed Materials - Property of IBM - * 5724-Q36 - * (c) Copyright IBM Corp. 2020 - * US Government Users Restricted Rights - Use, duplication or disclosure - * restricted by GSA ADP Schedule Contract with IBM Corp. +/** + * Copyright IBM Corp. 2020, 2023 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. */ + +import { useEffect } from 'react'; import { pkg } from '../../settings'; import cx from 'classnames'; import useNestedRowExpander from './useNestedRowExpander'; @@ -12,6 +13,10 @@ import useNestedRowExpander from './useNestedRowExpander'; const blockClass = `${pkg.prefix}--datagrid`; const useNestedRows = (hooks) => { + useEffect(() => { + pkg.checkReportFeatureEnabled('Datagrid.useNestedRows'); + }, []); + useNestedRowExpander(hooks); const marginLeft = 24; diff --git a/packages/cloud-cognitive/src/global/js/package-settings.js b/packages/cloud-cognitive/src/global/js/package-settings.js index 5e3e1a0859..96dd82b49b 100644 --- a/packages/cloud-cognitive/src/global/js/package-settings.js +++ b/packages/cloud-cognitive/src/global/js/package-settings.js @@ -1,5 +1,5 @@ // -// Copyright IBM Corp. 2020, 2021 +// Copyright IBM Corp. 2020, 2023 // // This source code is licensed under the Apache-2.0 license found in the // LICENSE file in the root directory of this source tree. @@ -81,6 +81,12 @@ const defaults = { feature: { 'a-new-feature': false, 'default-portal-target-body': true, + 'Datagrid.useExpandedRow': false, + 'Datagrid.useNestedRows': false, + 'Datagrid.useInlineEdit': false, + 'Datagrid.useActionsColumn': false, + 'Datagrid.useFiltering': false, + 'Datagrid.useCustomizeColumns': false, 'ExampleComponent.secondaryIcon': false, 'ExampleComponent.useExample': false, }, @@ -126,6 +132,11 @@ const feature = new Proxy( { ...defaults.feature }, { set(target, property, value) { + // If we receive a feature flag that doesn't exist in our defaults we should not log + // a warning message and instead just return + if (!Object.getOwnPropertyDescriptor(defaults.feature, property)) { + return true; + } if (target[property] !== true && !silent && value) { // not already true, not silent, and now true console.warn(warningMessageFeature(property)); diff --git a/packages/core/.storybook/index.scss b/packages/core/.storybook/index.scss index e31072013d..39f5e75820 100644 --- a/packages/core/.storybook/index.scss +++ b/packages/core/.storybook/index.scss @@ -1,5 +1,5 @@ // -// Copyright IBM Corp. 2020, 2022 +// Copyright IBM Corp. 2020, 2023 // // This source code is licensed under the Apache-2.0 license found in the // LICENSE file in the root directory of this source tree. diff --git a/packages/core/.storybook/preview.js b/packages/core/.storybook/preview.js index f4ddf55220..2960e8f66f 100644 --- a/packages/core/.storybook/preview.js +++ b/packages/core/.storybook/preview.js @@ -1,5 +1,5 @@ /** - * Copyright IBM Corp. 2020, 2021 + * Copyright IBM Corp. 2020, 2023 * * This source code is licensed under the Apache-2.0 license found in the * LICENSE file in the root directory of this source tree. @@ -47,6 +47,8 @@ const decorators = [ (storyFn, { args, parameters: { styles } }) => { const story = storyFn(); + JSON.stringify(args.featureFlags); + return (