From 59241338f1432b8399d5e5e85b1d522ae3765412 Mon Sep 17 00:00:00 2001 From: markuczy Date: Thu, 7 Nov 2024 10:04:09 +0100 Subject: [PATCH 1/4] feat: storybooks split --- .../angular-accelerator/.storybook/preview.ts | 8 +- ...group-column-selector.component.stories.ts | 2 +- .../data-list-grid.component.stories.ts | 44 +- .../data-table.component.stories.ts | 2 +- .../diagram/diagram.component.stories.ts | 2 +- ...roup-by-count-diagram.component.stories.ts | 2 +- ...data-view-filter-view.component.stories.ts | 287 ++++++++++++ ...interactive-data-view.component.stories.ts | 432 +----------------- .../interactive-data-view/storybook-config.ts | 175 +++++++ .../page-header.component.stories.ts | 4 +- .../search-header/search-header.stories.ts | 2 +- 11 files changed, 512 insertions(+), 448 deletions(-) create mode 100644 libs/angular-accelerator/src/lib/components/interactive-data-view/interactive-data-view-filter-view.component.stories.ts create mode 100644 libs/angular-accelerator/src/lib/components/interactive-data-view/storybook-config.ts diff --git a/libs/angular-accelerator/.storybook/preview.ts b/libs/angular-accelerator/.storybook/preview.ts index 92613aef..dcacfc1d 100644 --- a/libs/angular-accelerator/.storybook/preview.ts +++ b/libs/angular-accelerator/.storybook/preview.ts @@ -19,8 +19,14 @@ const preview: Preview = { date: /Date$/, }, }, + options: { + storySort: { + method: 'alphabetical', + order: ['Components', '*'], + }, + }, }, - tags: ['autodocs', 'autodocs', 'autodocs'] + tags: ['autodocs', 'autodocs', 'autodocs'], } export default preview diff --git a/libs/angular-accelerator/src/lib/components/custom-group-column-selector/custom-group-column-selector.component.stories.ts b/libs/angular-accelerator/src/lib/components/custom-group-column-selector/custom-group-column-selector.component.stories.ts index de30c5f8..66d473d5 100644 --- a/libs/angular-accelerator/src/lib/components/custom-group-column-selector/custom-group-column-selector.component.stories.ts +++ b/libs/angular-accelerator/src/lib/components/custom-group-column-selector/custom-group-column-selector.component.stories.ts @@ -27,7 +27,7 @@ type CustomGroupColumnSelectorInputs = Pick< | 'inactiveColumnsLabel' > const CustomGroupColumnSelectorComponentSBConfig: Meta = { - title: 'CustomGroupColumnSelectorComponent', + title: 'Components/CustomGroupColumnSelectorComponent', component: CustomGroupColumnSelectorComponent, decorators: [ applicationConfig({ diff --git a/libs/angular-accelerator/src/lib/components/data-list-grid/data-list-grid.component.stories.ts b/libs/angular-accelerator/src/lib/components/data-list-grid/data-list-grid.component.stories.ts index b15ae84b..8c577f69 100644 --- a/libs/angular-accelerator/src/lib/components/data-list-grid/data-list-grid.component.stories.ts +++ b/libs/angular-accelerator/src/lib/components/data-list-grid/data-list-grid.component.stories.ts @@ -16,7 +16,7 @@ import { TooltipOnOverflowDirective } from '../../directives/tooltipOnOverflow.d import { MockAuthModule } from '../../mock-auth/mock-auth.module' const DataListGridComponentSBConfig: Meta = { - title: 'DataListGridComponent', + title: 'Components/DataListGridComponent', component: DataListGridComponent, decorators: [ applicationConfig({ @@ -185,9 +185,9 @@ export const ListWithAdditionalActions = { id: '1', labelKey: 'Additional 1', icon: 'pi pi-plus', - permission: 'TEST_MGMT#TEST_VIEW' - } - ] + permission: 'TEST_MGMT#TEST_VIEW', + }, + ], }, } @@ -202,9 +202,9 @@ export const ListWithConditionallyEnabledAdditionalActions = { labelKey: 'Additional 1', icon: 'pi pi-plus', permission: 'TEST_MGMT#TEST_VIEW', - actionEnabledField: 'available' - } - ] + actionEnabledField: 'available', + }, + ], }, } @@ -219,9 +219,9 @@ export const ListWithConditionallyVisibleAdditionalActions = { labelKey: 'Additional 1', icon: 'pi pi-plus', permission: 'TEST_MGMT#TEST_VIEW', - actionVisibleField: 'available' - } - ] + actionVisibleField: 'available', + }, + ], }, } @@ -254,7 +254,7 @@ export const ListWithAdditionalOverflowActions = { showAsOverflow: true, actionEnabledField: 'available', }, - ] + ], }, } @@ -293,7 +293,7 @@ export const ListWithOnlyAdditionalOverflowActions = { showAsOverflow: true, actionEnabledField: 'available', }, - ] + ], }, } @@ -303,7 +303,7 @@ export const ListWithPageSizes = { args: { ...defaultComponentArgs, pageSizes: [2, 15, 25], - data: extendedMockData + data: extendedMockData, }, } @@ -359,9 +359,9 @@ export const GridWithAdditionalActions = { id: '1', labelKey: 'Additional 1', icon: 'pi pi-plus', - permission: 'TEST_MGMT#TEST_VIEW' - } - ] + permission: 'TEST_MGMT#TEST_VIEW', + }, + ], }, } @@ -377,9 +377,9 @@ export const GridWithConditionallyEnabledAdditionalActions = { labelKey: 'Additional 1', icon: 'pi pi-plus', permission: 'TEST_MGMT#TEST_VIEW', - actionEnabledField: 'available' - } - ] + actionEnabledField: 'available', + }, + ], }, } @@ -395,9 +395,9 @@ export const GridWithConditionallyVisibleAdditionalActions = { labelKey: 'Additional 1', icon: 'pi pi-plus', permission: 'TEST_MGMT#TEST_VIEW', - actionVisibleField: 'available' - } - ] + actionVisibleField: 'available', + }, + ], }, } diff --git a/libs/angular-accelerator/src/lib/components/data-table/data-table.component.stories.ts b/libs/angular-accelerator/src/lib/components/data-table/data-table.component.stories.ts index be4a3eab..134726f6 100644 --- a/libs/angular-accelerator/src/lib/components/data-table/data-table.component.stories.ts +++ b/libs/angular-accelerator/src/lib/components/data-table/data-table.component.stories.ts @@ -20,7 +20,7 @@ import { FormsModule } from '@angular/forms' type DataTableInputTypes = Pick const DataTableComponentSBConfig: Meta = { - title: 'DataTableComponent', + title: 'Components/DataTableComponent', component: DataTableComponent, decorators: [ applicationConfig({ diff --git a/libs/angular-accelerator/src/lib/components/diagram/diagram.component.stories.ts b/libs/angular-accelerator/src/lib/components/diagram/diagram.component.stories.ts index 8fe4f73e..ce2809d6 100644 --- a/libs/angular-accelerator/src/lib/components/diagram/diagram.component.stories.ts +++ b/libs/angular-accelerator/src/lib/components/diagram/diagram.component.stories.ts @@ -16,7 +16,7 @@ import { DiagramType } from '../../model/diagram-type' import { DiagramData } from '../../model/diagram-data' export default { - title: 'DiagramComponent', + title: 'Components/DiagramComponent', component: DiagramComponent, argTypes: { diagramType: { diff --git a/libs/angular-accelerator/src/lib/components/group-by-count-diagram/group-by-count-diagram.component.stories.ts b/libs/angular-accelerator/src/lib/components/group-by-count-diagram/group-by-count-diagram.component.stories.ts index 3519f545..20b998ae 100644 --- a/libs/angular-accelerator/src/lib/components/group-by-count-diagram/group-by-count-diagram.component.stories.ts +++ b/libs/angular-accelerator/src/lib/components/group-by-count-diagram/group-by-count-diagram.component.stories.ts @@ -16,7 +16,7 @@ import { DiagramComponent } from '../diagram/diagram.component' import { ColumnType } from '../../model/column-type.model' export default { - title: 'GroupByCountDiagramComponent', + title: 'Components/GroupByCountDiagramComponent', component: GroupByCountDiagramComponent, argTypes: { diagramType: { diff --git a/libs/angular-accelerator/src/lib/components/interactive-data-view/interactive-data-view-filter-view.component.stories.ts b/libs/angular-accelerator/src/lib/components/interactive-data-view/interactive-data-view-filter-view.component.stories.ts new file mode 100644 index 00000000..88fd91cf --- /dev/null +++ b/libs/angular-accelerator/src/lib/components/interactive-data-view/interactive-data-view-filter-view.component.stories.ts @@ -0,0 +1,287 @@ +import { Meta, StoryFn } from '@storybook/angular' +import { InteractiveDataViewComponent } from './interactive-data-view.component' +import { Filter } from '../../model/filter.model' +import { + defaultInteractiveDataViewArgs, + InteractiveDataViewComponentSBConfig, + InteractiveDataViewTemplate, +} from './storybook-config' + +const InteractiveDataViewComponentFilterViewSBConfig: Meta = { + ...InteractiveDataViewComponentSBConfig, + title: 'Components/InteractiveDataViewComponent/FilterView', +} + +type InteractiveDataViewFilterViewInputTypes = Pick< + InteractiveDataViewComponent, + 'data' | 'columns' | 'emptyResultsMessage' | 'disableFilterView' | 'filterViewDisplayMode' +> +const defaultArgs: InteractiveDataViewFilterViewInputTypes = { + ...defaultInteractiveDataViewArgs, + disableFilterView: true, + filterViewDisplayMode: 'button', +} + +const CustomContentInteractiveDataView: StoryFn = (args) => ({ + props: args, + template: ` + + +
+

{{item.product}}

+ +
+
+ +
+

{{item.product}}

+ +
+
+ + + +
`, +}) + +export const WithFilterViewChips = { + render: CustomContentInteractiveDataView, + args: { + ...defaultArgs, + disableFilterView: false, + filterViewDisplayMode: 'chips', + }, +} + +export const WithFilterViewButton = { + render: CustomContentInteractiveDataView, + args: { + ...defaultArgs, + disableFilterView: false, + filterViewDisplayMode: 'button', + }, +} + +const CustomFilterViewChipsInteractiveDataView: StoryFn = (args) => ({ + props: args, + template: ` + + + STRING: {{ rowObject[column.id] }} + + + STRING FILTER: {{ rowObject[column.id] }} + + + CHIP: {{ rowObject[column.id] }} + + `, +}) + +export const WithFilterViewCustomChipsTemplates = { + render: CustomFilterViewChipsInteractiveDataView, + args: { + ...defaultArgs, + disableFilterView: false, + filterViewDisplayMode: 'chips', + }, +} + +const CustomFilterViewChipsByColumnInteractiveDataView: StoryFn = (args) => ({ + props: args, + template: ` + + + STRING: {{ rowObject[column.id] }} + + + STRING FILTER: {{ rowObject[column.id] }} + + + CHIP: {{ rowObject[column.id] }} + + + PRODUCT (ID): {{ rowObject[column.id] }} + + + PRODUCT FILTER (ID): {{ rowObject[column.id] }} + + + PRODUCT CHIP (ID): {{ rowObject[column.id] }} + + `, +}) + +export const WithFilterViewCustomChipsByColumnTemplates = { + render: CustomFilterViewChipsByColumnInteractiveDataView, + args: { + ...defaultArgs, + disableFilterView: false, + filterViewDisplayMode: 'chips', + }, +} + +const CustomFilterViewCellsInteractiveDataView: StoryFn = (args) => ({ + props: args, + template: ` + + + STRING: {{ rowObject[column.id] }} + + + STRING FILTER: {{ rowObject[column.id] }} + + + STRING FILTER VIEW: {{ rowObject[column.id] }} + + `, +}) + +export const WithFilterViewCustomCellTemplates = { + render: CustomFilterViewCellsInteractiveDataView, + args: { + ...defaultArgs, + disableFilterView: false, + filterViewDisplayMode: 'button', + }, +} + +const CustomFilterViewCellsByColumnInteractiveDataView: StoryFn = (args) => ({ + props: args, + template: ` + + + STRING: {{ rowObject[column.id] }} + + + STRING FILTER: {{ rowObject[column.id] }} + + + STRING FILTER VIEW: {{ rowObject[column.id] }} + + + PRODUCT (ID): {{ rowObject[column.id] }} + + + PRODUCT FILTER (ID): {{ rowObject[column.id] }} + + + PRODUCT FILTER VIEW (ID): {{ rowObject[column.id] }} + + `, +}) + +export const WithFilterViewCustomCellByColumnTemplates = { + render: CustomFilterViewCellsByColumnInteractiveDataView, + args: { + ...defaultArgs, + disableFilterView: false, + filterViewDisplayMode: 'button', + }, +} + +const CustomFilterViewNoFiltersInteractiveDataView: StoryFn = (args) => ({ + props: args, + template: ` + + + Filter data to display chips + + `, +}) + +export const WithFilterViewCustomNoFiltersTemplate = { + render: CustomFilterViewNoFiltersInteractiveDataView, + args: { + ...defaultArgs, + disableFilterView: false, + filterViewDisplayMode: 'chips', + }, +} + +const CustomFilterViewChipContentInteractiveDataView: StoryFn = (args) => ({ + props: args, + template: ` + + + {{(column.nameKey | translate).at(0)}} + + + {{filter.value ? 'MY_YES' : 'MY_NO'}} + + + + + + + + + + [P]{{ rowObject[column.id] }} + + + + D: {{ rowObject[column.id] | date }} + + `, +}) + +export const WithFilterViewCustomChipContentTemplate = { + render: CustomFilterViewChipContentInteractiveDataView, + args: { + ...defaultArgs, + disableFilterView: false, + filterViewDisplayMode: 'chips', + }, +} + +const CustomFilterViewShowMoreChipInteractiveDataView: StoryFn = (args) => ({ + props: args, + template: ` + + + + {{value}} + + + `, +}) + +export const WithFilterViewCustomShowMoreChipTemplate = { + render: CustomFilterViewShowMoreChipInteractiveDataView, + args: { + ...defaultArgs, + disableFilterView: false, + filterViewDisplayMode: 'chips', + }, +} + +export const WithFilterViewCustomChipSelection = { + render: InteractiveDataViewTemplate, + args: { + ...defaultArgs, + disableFilterView: false, + filterViewDisplayMode: 'chips', + selectDisplayedChips: (filters: Filter[]) => { + return filters.slice(0, 2).reverse() + }, + }, +} + +export const WithFilterViewCustomStyles = { + render: InteractiveDataViewTemplate, + args: { + ...defaultArgs, + disableFilterView: false, + filterViewDisplayMode: 'button', + filterViewTableStyle: { 'max-height': '30vh' }, + filterViewPanelStyle: { 'max-width': '80%' }, + }, +} + +export default InteractiveDataViewComponentFilterViewSBConfig diff --git a/libs/angular-accelerator/src/lib/components/interactive-data-view/interactive-data-view.component.stories.ts b/libs/angular-accelerator/src/lib/components/interactive-data-view/interactive-data-view.component.stories.ts index fa0c6a8f..fa4c1066 100644 --- a/libs/angular-accelerator/src/lib/components/interactive-data-view/interactive-data-view.component.stories.ts +++ b/libs/angular-accelerator/src/lib/components/interactive-data-view/interactive-data-view.component.stories.ts @@ -1,183 +1,19 @@ -import { importProvidersFrom } from '@angular/core' -import { FormsModule } from '@angular/forms' -import { BrowserModule } from '@angular/platform-browser' -import { BrowserAnimationsModule } from '@angular/platform-browser/animations' -import { ActivatedRoute } from '@angular/router' -import { UserService } from '@onecx/angular-integration-interface' -import { MockUserService } from '@onecx/angular-integration-interface/mocks' -import { Meta, StoryFn, applicationConfig, moduleMetadata } from '@storybook/angular' -import { ButtonModule } from 'primeng/button' -import { DataViewModule } from 'primeng/dataview' -import { DialogModule } from 'primeng/dialog' -import { DropdownModule } from 'primeng/dropdown' -import { InputTextModule } from 'primeng/inputtext' -import { MenuModule } from 'primeng/menu' -import { MultiSelectModule } from 'primeng/multiselect' -import { PickListModule } from 'primeng/picklist' -import { ProgressBarModule } from 'primeng/progressbar' -import { SelectButtonModule } from 'primeng/selectbutton' -import { FloatLabelModule } from 'primeng/floatlabel' -import { TableModule } from 'primeng/table' -import { ChipModule } from 'primeng/chip' -import { OverlayPanelModule } from 'primeng/overlaypanel' -import { IfPermissionDirective } from '../../directives/if-permission.directive' -import { IfBreakpointDirective } from '../../directives/if-breakpoint.directive' -import { MockAuthModule } from '../../mock-auth/mock-auth.module' -import { ColumnType } from '../../model/column-type.model' -import { StorybookTranslateModule } from '../../storybook-translate.module' -import { ColumnGroupSelectionComponent } from '../column-group-selection/column-group-selection.component' -import { CustomGroupColumnSelectorComponent } from '../custom-group-column-selector/custom-group-column-selector.component' -import { DataLayoutSelectionComponent } from '../data-layout-selection/data-layout-selection.component' -import { DataListGridSortingComponent } from '../data-list-grid-sorting/data-list-grid-sorting.component' -import { DataListGridComponent } from '../data-list-grid/data-list-grid.component' -import { DataTableComponent } from '../data-table/data-table.component' -import { DataViewComponent } from '../data-view/data-view.component' +import { Meta, StoryFn } from '@storybook/angular' import { InteractiveDataViewComponent } from './interactive-data-view.component' -import { SlotService } from '@onecx/angular-remote-components' -import { of } from 'rxjs' -import { Filter, FilterType } from '../../model/filter.model' -import { FilterViewComponent } from '../filter-view/filter-view.component' -import { FocusTrapModule } from 'primeng/focustrap' +import { + InteractiveDataViewComponentSBConfig, + defaultInteractiveDataViewArgs, + InteractiveDataViewTemplate, +} from './storybook-config' -type InteractiveDataViewInputTypes = Pick< - InteractiveDataViewComponent, - 'data' | 'columns' | 'emptyResultsMessage' | 'disableFilterView' | 'filterViewDisplayMode' -> -const InteractiveDataViewComponentSBConfig: Meta = { - title: 'InteractiveDataViewComponent', - component: InteractiveDataViewComponent, - decorators: [ - applicationConfig({ - providers: [ - importProvidersFrom(BrowserModule), - importProvidersFrom(BrowserAnimationsModule), - { provide: UserService, useClass: MockUserService }, - { - provide: ActivatedRoute, - useValue: { - snapshot: { - paramMap: { - get: () => '1', - }, - }, - }, - }, - { - provide: SlotService, - useValue: { - isSomeComponentDefinedForSlot() { - return of(false) - }, - }, - }, - ], - }), - moduleMetadata({ - declarations: [ - InteractiveDataViewComponent, - IfPermissionDirective, - IfBreakpointDirective, - CustomGroupColumnSelectorComponent, - ColumnGroupSelectionComponent, - DataViewComponent, - DataTableComponent, - DataLayoutSelectionComponent, - DataListGridComponent, - DataListGridSortingComponent, - FilterViewComponent, - ], - imports: [ - TableModule, - ButtonModule, - MultiSelectModule, - StorybookTranslateModule, - MockAuthModule, - MenuModule, - PickListModule, - SelectButtonModule, - DialogModule, - DataViewModule, - DropdownModule, - FormsModule, - ProgressBarModule, - InputTextModule, - FloatLabelModule, - OverlayPanelModule, - FocusTrapModule, - ChipModule, - ], - }), - ], - argTypes: { - selectDisplayedChips: { type: 'function', control: false }, - }, +const InteractiveDataViewComponentDefaultSBConfig: Meta = { + ...InteractiveDataViewComponentSBConfig, + title: 'Components/InteractiveDataViewComponent', } -const Template: StoryFn = (args) => ({ - props: args, -}) +type InteractiveDataViewInputTypes = Pick const defaultComponentArgs: InteractiveDataViewInputTypes = { - columns: [ - { - id: 'product', - columnType: ColumnType.STRING, - nameKey: 'Product', - sortable: false, - filterable: true, - predefinedGroupKeys: ['test'], - }, - { - id: 'amount', - columnType: ColumnType.NUMBER, - nameKey: 'Amount', - sortable: true, - predefinedGroupKeys: ['test', 'test1'], - }, - { - id: 'available', - columnType: ColumnType.STRING, - nameKey: 'Available', - sortable: false, - filterable: true, - filterType: FilterType.TRUTHY, - predefinedGroupKeys: ['test2'], - }, - { - id: 'date', - columnType: ColumnType.DATE, - nameKey: 'Date', - sortable: false, - filterable: true, - predefinedGroupKeys: ['test2'], - }, - ], - data: [ - { - id: 1, - product: 'Apples', - amount: 2, - available: false, - imagePath: '', - date: new Date(2022, 1, 1, 13, 14, 55, 120), - }, - { - id: 2, - product: 'Bananas', - amount: 10, - imagePath: '', - date: new Date(2022, 1, 1, 13, 14, 55, 120), - }, - { - id: 3, - product: 'Strawberries', - amount: 5, - imagePath: '', - date: new Date(2022, 1, 3, 13, 14, 55, 120), - }, - ], - emptyResultsMessage: 'No results', - disableFilterView: true, - filterViewDisplayMode: 'button', + ...defaultInteractiveDataViewArgs, } export const WithMockData = { @@ -185,7 +21,7 @@ export const WithMockData = { componentStateChanged: { action: 'componentStateChanged' }, selectionChanged: { action: 'selectionChanged' }, }, - render: Template, + render: InteractiveDataViewTemplate, args: { ...defaultComponentArgs, selectedRows: [], @@ -196,7 +32,7 @@ export const WithPageSizes = { argTypes: { componentStateChanged: { action: 'componentStateChanged' }, }, - render: Template, + render: InteractiveDataViewTemplate, args: { ...defaultComponentArgs, pageSizes: [2, 15, 25], @@ -329,244 +165,4 @@ export const WithCustomTableColumnTemplates = { }, } -export const WithFilterViewChips = { - render: CustomContentInteractiveDataView, - args: { - ...defaultComponentArgs, - disableFilterView: false, - filterViewDisplayMode: 'chips', - }, -} - -export const WithFilterViewButton = { - render: CustomContentInteractiveDataView, - args: { - ...defaultComponentArgs, - disableFilterView: false, - filterViewDisplayMode: 'button', - }, -} - -const CustomFilterViewChipsInteractiveDataView: StoryFn = (args) => ({ - props: args, - template: ` - - - STRING: {{ rowObject[column.id] }} - - - STRING FILTER: {{ rowObject[column.id] }} - - - CHIP: {{ rowObject[column.id] }} - - `, -}) - -export const WithFilterViewCustomChipsTemplates = { - render: CustomFilterViewChipsInteractiveDataView, - args: { - ...defaultComponentArgs, - disableFilterView: false, - filterViewDisplayMode: 'chips', - }, -} - -const CustomFilterViewChipsByColumnInteractiveDataView: StoryFn = (args) => ({ - props: args, - template: ` - - - STRING: {{ rowObject[column.id] }} - - - STRING FILTER: {{ rowObject[column.id] }} - - - CHIP: {{ rowObject[column.id] }} - - - PRODUCT (ID): {{ rowObject[column.id] }} - - - PRODUCT FILTER (ID): {{ rowObject[column.id] }} - - - PRODUCT CHIP (ID): {{ rowObject[column.id] }} - - `, -}) - -export const WithFilterViewCustomChipsByColumnTemplates = { - render: CustomFilterViewChipsByColumnInteractiveDataView, - args: { - ...defaultComponentArgs, - disableFilterView: false, - filterViewDisplayMode: 'chips', - }, -} - -const CustomFilterViewCellsInteractiveDataView: StoryFn = (args) => ({ - props: args, - template: ` - - - STRING: {{ rowObject[column.id] }} - - - STRING FILTER: {{ rowObject[column.id] }} - - - STRING FILTER VIEW: {{ rowObject[column.id] }} - - `, -}) - -export const WithFilterViewCustomCellTemplates = { - render: CustomFilterViewCellsInteractiveDataView, - args: { - ...defaultComponentArgs, - disableFilterView: false, - filterViewDisplayMode: 'button', - }, -} - -const CustomFilterViewCellsByColumnInteractiveDataView: StoryFn = (args) => ({ - props: args, - template: ` - - - STRING: {{ rowObject[column.id] }} - - - STRING FILTER: {{ rowObject[column.id] }} - - - STRING FILTER VIEW: {{ rowObject[column.id] }} - - - PRODUCT (ID): {{ rowObject[column.id] }} - - - PRODUCT FILTER (ID): {{ rowObject[column.id] }} - - - PRODUCT FILTER VIEW (ID): {{ rowObject[column.id] }} - - `, -}) - -export const WithFilterViewCustomCellByColumnTemplates = { - render: CustomFilterViewCellsByColumnInteractiveDataView, - args: { - ...defaultComponentArgs, - disableFilterView: false, - filterViewDisplayMode: 'button', - }, -} - -const CustomFilterViewNoFiltersInteractiveDataView: StoryFn = (args) => ({ - props: args, - template: ` - - - Filter data to display chips - - `, -}) - -export const WithFilterViewCustomNoFiltersTemplate = { - render: CustomFilterViewNoFiltersInteractiveDataView, - args: { - ...defaultComponentArgs, - disableFilterView: false, - filterViewDisplayMode: 'chips', - }, -} - -const CustomFilterViewChipContentInteractiveDataView: StoryFn = (args) => ({ - props: args, - template: ` - - - {{(column.nameKey | translate).at(0)}} - - - {{filter.value ? 'MY_YES' : 'MY_NO'}} - - - - - - - - - - [P]{{ rowObject[column.id] }} - - - - D: {{ rowObject[column.id] | date }} - - `, -}) - -export const WithFilterViewCustomChipContentTemplate = { - render: CustomFilterViewChipContentInteractiveDataView, - args: { - ...defaultComponentArgs, - disableFilterView: false, - filterViewDisplayMode: 'chips', - }, -} - -const CustomFilterViewShowMoreChipInteractiveDataView: StoryFn = (args) => ({ - props: args, - template: ` - - - - {{value}} - - - `, -}) - -export const WithFilterViewCustomShowMoreChipTemplate = { - render: CustomFilterViewShowMoreChipInteractiveDataView, - args: { - ...defaultComponentArgs, - disableFilterView: false, - filterViewDisplayMode: 'chips', - }, -} - -export const WithFilterViewCustomChipSelection = { - render: Template, - args: { - ...defaultComponentArgs, - disableFilterView: false, - filterViewDisplayMode: 'chips', - selectDisplayedChips: (filters: Filter[]) => { - return filters.slice(0, 2).reverse() - }, - }, -} - -export const WithFilterViewCustomStyles = { - render: Template, - args: { - ...defaultComponentArgs, - disableFilterView: false, - filterViewDisplayMode: 'button', - filterViewTableStyle: { 'max-height': '30vh' }, - filterViewPanelStyle: { 'max-width': '80%' }, - }, -} - -export default InteractiveDataViewComponentSBConfig +export default InteractiveDataViewComponentDefaultSBConfig diff --git a/libs/angular-accelerator/src/lib/components/interactive-data-view/storybook-config.ts b/libs/angular-accelerator/src/lib/components/interactive-data-view/storybook-config.ts new file mode 100644 index 00000000..16f8d083 --- /dev/null +++ b/libs/angular-accelerator/src/lib/components/interactive-data-view/storybook-config.ts @@ -0,0 +1,175 @@ +import { Meta, StoryFn, applicationConfig, moduleMetadata } from '@storybook/angular' +import { InteractiveDataViewComponent } from './interactive-data-view.component' +import { importProvidersFrom } from '@angular/core' +import { BrowserModule } from '@angular/platform-browser' +import { BrowserAnimationsModule } from '@angular/platform-browser/animations' +import { MockUserService } from '@onecx/angular-integration-interface/mocks' +import { UserService } from '@onecx/angular-integration-interface' +import { ActivatedRoute } from '@angular/router' +import { SlotService } from '@onecx/angular-remote-components' +import { of } from 'rxjs' +import { IfPermissionDirective } from '../../directives/if-permission.directive' +import { IfBreakpointDirective } from '../../directives/if-breakpoint.directive' +import { CustomGroupColumnSelectorComponent } from '../custom-group-column-selector/custom-group-column-selector.component' +import { ColumnGroupSelectionComponent } from '../column-group-selection/column-group-selection.component' +import { DataViewComponent } from '../data-view/data-view.component' +import { DataTableComponent } from '../data-table/data-table.component' +import { DataLayoutSelectionComponent } from '../data-layout-selection/data-layout-selection.component' +import { DataListGridComponent } from '../data-list-grid/data-list-grid.component' +import { DataListGridSortingComponent } from '../data-list-grid-sorting/data-list-grid-sorting.component' +import { FilterViewComponent } from '../filter-view/filter-view.component' +import { TableModule } from 'primeng/table' +import { ButtonModule } from 'primeng/button' +import { MultiSelectModule } from 'primeng/multiselect' +import { StorybookTranslateModule } from '../../storybook-translate.module' +import { MockAuthModule } from '../../mock-auth/mock-auth.module' +import { MenuModule } from 'primeng/menu' +import { PickListModule } from 'primeng/picklist' +import { SelectButtonModule } from 'primeng/selectbutton' +import { DialogModule } from 'primeng/dialog' +import { DataViewModule } from 'primeng/dataview' +import { DropdownModule } from 'primeng/dropdown' +import { FormsModule } from '@angular/forms' +import { ProgressBarModule } from 'primeng/progressbar' +import { InputTextModule } from 'primeng/inputtext' +import { FloatLabelModule } from 'primeng/floatlabel' +import { OverlayPanelModule } from 'primeng/overlaypanel' +import { FocusTrapModule } from 'primeng/focustrap' +import { ChipModule } from 'primeng/chip' +import { ColumnType } from '../../model/column-type.model' +import { FilterType } from '../../model/filter.model' + +export const InteractiveDataViewComponentSBConfig: Meta = { + title: 'Components/InteractiveDataViewComponent', + component: InteractiveDataViewComponent, + decorators: [ + applicationConfig({ + providers: [ + importProvidersFrom(BrowserModule), + importProvidersFrom(BrowserAnimationsModule), + { provide: UserService, useClass: MockUserService }, + { + provide: ActivatedRoute, + useValue: { + snapshot: { + paramMap: { + get: () => '1', + }, + }, + }, + }, + { + provide: SlotService, + useValue: { + isSomeComponentDefinedForSlot() { + return of(false) + }, + }, + }, + ], + }), + moduleMetadata({ + declarations: [ + InteractiveDataViewComponent, + IfPermissionDirective, + IfBreakpointDirective, + CustomGroupColumnSelectorComponent, + ColumnGroupSelectionComponent, + DataViewComponent, + DataTableComponent, + DataLayoutSelectionComponent, + DataListGridComponent, + DataListGridSortingComponent, + FilterViewComponent, + ], + imports: [ + TableModule, + ButtonModule, + MultiSelectModule, + StorybookTranslateModule, + MockAuthModule, + MenuModule, + PickListModule, + SelectButtonModule, + DialogModule, + DataViewModule, + DropdownModule, + FormsModule, + ProgressBarModule, + InputTextModule, + FloatLabelModule, + OverlayPanelModule, + FocusTrapModule, + ChipModule, + ], + }), + ], + argTypes: { + selectDisplayedChips: { type: 'function', control: false }, + }, +} +export const InteractiveDataViewTemplate: StoryFn = (args) => ({ + props: args, +}) + +export const defaultInteractiveDataViewArgs = { + columns: [ + { + id: 'product', + columnType: ColumnType.STRING, + nameKey: 'Product', + sortable: false, + filterable: true, + predefinedGroupKeys: ['test'], + }, + { + id: 'amount', + columnType: ColumnType.NUMBER, + nameKey: 'Amount', + sortable: true, + predefinedGroupKeys: ['test', 'test1'], + }, + { + id: 'available', + columnType: ColumnType.STRING, + nameKey: 'Available', + sortable: false, + filterable: true, + filterType: FilterType.TRUTHY, + predefinedGroupKeys: ['test2'], + }, + { + id: 'date', + columnType: ColumnType.DATE, + nameKey: 'Date', + sortable: false, + filterable: true, + predefinedGroupKeys: ['test2'], + }, + ], + data: [ + { + id: 1, + product: 'Apples', + amount: 2, + available: false, + imagePath: '', + date: new Date(2022, 1, 1, 13, 14, 55, 120), + }, + { + id: 2, + product: 'Bananas', + amount: 10, + imagePath: '', + date: new Date(2022, 1, 1, 13, 14, 55, 120), + }, + { + id: 3, + product: 'Strawberries', + amount: 5, + imagePath: '', + date: new Date(2022, 1, 3, 13, 14, 55, 120), + }, + ], + emptyResultsMessage: 'No results', +} diff --git a/libs/angular-accelerator/src/lib/components/page-header/page-header.component.stories.ts b/libs/angular-accelerator/src/lib/components/page-header/page-header.component.stories.ts index 43482eda..98496324 100644 --- a/libs/angular-accelerator/src/lib/components/page-header/page-header.component.stories.ts +++ b/libs/angular-accelerator/src/lib/components/page-header/page-header.component.stories.ts @@ -15,7 +15,7 @@ import { StorybookBreadcrumbModule } from './../../storybook-breadcrumb.module' import { Action, ObjectDetailItem, PageHeaderComponent } from './page-header.component' export default { - title: 'PageHeaderComponent', + title: 'Components/PageHeaderComponent', component: PageHeaderComponent, decorators: [ applicationConfig({ @@ -82,7 +82,7 @@ const demoActions: Action[] = [ }, show: 'asOverflow', icon: PrimeIcons.ADDRESS_BOOK, - title: 'Tooltip for some action' + title: 'Tooltip for some action', }, { label: 'Other action', diff --git a/libs/angular-accelerator/src/lib/components/search-header/search-header.stories.ts b/libs/angular-accelerator/src/lib/components/search-header/search-header.stories.ts index 35e81df6..69071963 100644 --- a/libs/angular-accelerator/src/lib/components/search-header/search-header.stories.ts +++ b/libs/angular-accelerator/src/lib/components/search-header/search-header.stories.ts @@ -17,7 +17,7 @@ import { StorybookBreadcrumbModule } from './../../storybook-breadcrumb.module' import { SearchHeaderComponent } from './search-header.component' export default { - title: 'SearchHeaderComponent', + title: 'Components/SearchHeaderComponent', component: SearchHeaderComponent, decorators: [ applicationConfig({ From 50b1d17bf52128a86aab8dde75de41e91c542cc1 Mon Sep 17 00:00:00 2001 From: markuczy Date: Thu, 7 Nov 2024 13:23:24 +0100 Subject: [PATCH 2/4] fix: remove unwanted params --- .../interactive-data-view.component.stories.ts | 14 ++++---------- 1 file changed, 4 insertions(+), 10 deletions(-) diff --git a/libs/angular-accelerator/src/lib/components/interactive-data-view/interactive-data-view.component.stories.ts b/libs/angular-accelerator/src/lib/components/interactive-data-view/interactive-data-view.component.stories.ts index fa4c1066..37030634 100644 --- a/libs/angular-accelerator/src/lib/components/interactive-data-view/interactive-data-view.component.stories.ts +++ b/libs/angular-accelerator/src/lib/components/interactive-data-view/interactive-data-view.component.stories.ts @@ -42,7 +42,7 @@ export const WithPageSizes = { const CustomContentInteractiveDataView: StoryFn = (args) => ({ props: args, template: ` - +

{{item.product}}

@@ -69,7 +69,7 @@ export const WithCustomContentTemplates = { const CustomTableCellsInteractiveDataView: StoryFn = (args) => ({ props: args, template: ` - + STRING: {{ rowObject[column.id] }} @@ -86,15 +86,13 @@ export const WithCustomTableCellTemplates = { render: CustomTableCellsInteractiveDataView, args: { ...defaultComponentArgs, - disableFilterView: false, - filterViewDisplayMode: 'button', }, } const CustomTableFilterCellsInteractiveDataView: StoryFn = (args) => ({ props: args, template: ` - + STRING: {{ rowObject[column.id] }} @@ -117,15 +115,13 @@ export const WithCustomTableFilterCellTemplates = { render: CustomTableFilterCellsInteractiveDataView, args: { ...defaultComponentArgs, - disableFilterView: false, - filterViewDisplayMode: 'button', }, } const CustomTableColumnCellsInteractiveDataView: StoryFn = (args) => ({ props: args, template: ` - + STRING: {{ rowObject[column.id] }} @@ -160,8 +156,6 @@ export const WithCustomTableColumnTemplates = { render: CustomTableColumnCellsInteractiveDataView, args: { ...defaultComponentArgs, - disableFilterView: false, - filterViewDisplayMode: 'button', }, } From 45159f19fb49114d5fac06df222beb80bc7cc6a1 Mon Sep 17 00:00:00 2001 From: markuczy Date: Thu, 7 Nov 2024 13:34:53 +0100 Subject: [PATCH 3/4] feat: content provided via control --- .../interactive-data-view.component.stories.ts | 18 ++++++++++++++++++ 1 file changed, 18 insertions(+) diff --git a/libs/angular-accelerator/src/lib/components/interactive-data-view/interactive-data-view.component.stories.ts b/libs/angular-accelerator/src/lib/components/interactive-data-view/interactive-data-view.component.stories.ts index 37030634..7c7305cd 100644 --- a/libs/angular-accelerator/src/lib/components/interactive-data-view/interactive-data-view.component.stories.ts +++ b/libs/angular-accelerator/src/lib/components/interactive-data-view/interactive-data-view.component.stories.ts @@ -159,4 +159,22 @@ export const WithCustomTableColumnTemplates = { }, } +const ExampleTemplate: StoryFn = (args) => ({ + props: args, + template: ` + + ${args.content} + `, +}) + +export const ExampleWithTemplateControl = { + render: ExampleTemplate, + args: { + ...defaultComponentArgs, + content: ` + MY STRING TEMPLATE PROVIDED VIA CONTENT CONTROL: {{ rowObject[column.id] }} +`, + }, +} + export default InteractiveDataViewComponentDefaultSBConfig From 667a89c02f6956751f5cc917d2022118b775833b Mon Sep 17 00:00:00 2001 From: markuczy Date: Wed, 13 Nov 2024 16:19:12 +0100 Subject: [PATCH 4/4] fix: fixed filter view examples dir --- .../interactive-data-view-filter-view.component.stories.ts | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/libs/angular-accelerator/src/lib/components/interactive-data-view/interactive-data-view-filter-view.component.stories.ts b/libs/angular-accelerator/src/lib/components/interactive-data-view/interactive-data-view-filter-view.component.stories.ts index 88fd91cf..dfd0567a 100644 --- a/libs/angular-accelerator/src/lib/components/interactive-data-view/interactive-data-view-filter-view.component.stories.ts +++ b/libs/angular-accelerator/src/lib/components/interactive-data-view/interactive-data-view-filter-view.component.stories.ts @@ -9,7 +9,7 @@ import { const InteractiveDataViewComponentFilterViewSBConfig: Meta = { ...InteractiveDataViewComponentSBConfig, - title: 'Components/InteractiveDataViewComponent/FilterView', + title: 'Components/InteractiveDataViewComponent/Filtering', } type InteractiveDataViewFilterViewInputTypes = Pick<