Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

feat: [M3-8180] - Notification Menu story #10950

Merged
Merged
Show file tree
Hide file tree
Changes from 14 commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
5 changes: 5 additions & 0 deletions packages/manager/.changeset/pr-10950-added-1727092343272.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
---
"@linode/manager": Added
---

Notification Menu story ([#10950](https://github.com/linode/manager/pull/10950))
Original file line number Diff line number Diff line change
@@ -0,0 +1,36 @@
import React from 'react';

import {
notificationCenterContext as _notificationContext,
useNotificationContext,
} from 'src/features/NotificationCenter/NotificationCenterContext';

import { NotificationMenu } from './NotificationMenu';

import type { Meta, StoryFn, StoryObj } from '@storybook/react';

type Story = StoryObj<typeof NotificationMenu>;

const meta: Meta<typeof NotificationMenu> = {
component: NotificationMenu,
decorators: [
(Story: StoryFn) => {
// eslint-disable-next-line react-hooks/rules-of-hooks
const contextValue = useNotificationContext();
const NotificationProvider = _notificationContext.Provider;
return (
<NotificationProvider value={contextValue}>
<Story />
</NotificationProvider>
);
},
],
render: () => <NotificationMenu />,
title: 'Components/Notifications/Notification Menu',
};

export default meta;

export const Default: Story = {
render: (args) => <NotificationMenu />,
};
82 changes: 31 additions & 51 deletions packages/manager/src/mocks/serverHandlers.ts
Original file line number Diff line number Diff line change
Expand Up @@ -100,9 +100,12 @@ import { accountLoginFactory } from 'src/factories/accountLogin';
import { accountUserFactory } from 'src/factories/accountUsers';
import { grantFactory, grantsFactory } from 'src/factories/grants';
import { LinodeKernelFactory } from 'src/factories/linodeKernel';
import { eventMessages } from 'src/features/Events/factory';
import { pickRandom } from 'src/utilities/random';
import { getStorage } from 'src/utilities/storage';

import type { Event } from '@linode/api-v4';

const getRandomWholeNumber = (min: number, max: number) =>
Math.floor(Math.random() * (max - min + 1) + min);

Expand Down Expand Up @@ -1573,69 +1576,46 @@ export const handlers = [
])
);
}),

http.post('*/seen', () => {
return HttpResponse.json({});
}),
http.get(
'*/events',
() => {
const events = eventFactory.buildList(1, {
action: 'lke_node_create',
entity: { id: 999, label: 'linode-1', type: 'linode' },
message:
'Rebooting this thing and showing an extremely long event message for no discernible reason other than the fairly obvious reason that we want to do some testing of whether or not these messages wrap.',
percent_complete: 15,
});
const dbEvents = eventFactory.buildList(1, {
action: 'database_low_disk_space',
entity: { id: 999, label: 'database-1', type: 'database' },
message: 'Low disk space.',
});
const oldEvents = eventFactory.buildList(20, {
action: 'account_update',
percent_complete: 100,
seen: true,
});
const eventWithSpecialCharacters = eventFactory.build({
action: 'ticket_update',
const baseEvent: Event = eventFactory.build({
action: 'linode_boot',
entity: {
id: 10,
label: 'Ticket name with special characters... (?)',
type: 'ticket',
id: 1,
label: '{entity}',
type: 'linode',
url: 'https://google.com',
},
message: 'Ticket name with special characters... (?)',
percent_complete: 100,
status: 'notification',
});
const placementGroupCreateEvent = eventFactory.buildList(1, {
action: 'placement_group_create',
entity: { id: 999, label: 'PG-1', type: 'placement_group' },
message: 'Placement Group successfully created.',
percent_complete: 100,
status: 'notification',
});
const placementGroupAssignedEvent = eventFactory.buildList(1, {
action: 'placement_group_assign',
entity: { id: 990, label: 'PG-2', type: 'placement_group' },
message: 'Placement Group successfully assigned.',
percent_complete: 100,
message: 'message with a `ticked` word - please contact Support',
secondary_entity: {
id: 1,
label: 'My Config',
label: '{secondary entity}',
type: 'linode',
url: '/v4/linode/instances/1/configs/1',
url: 'https://google.com',
},
status: 'notification',
status: '{status}' as Event['status'],
username: 'Mock User',
});

return HttpResponse.json(
makeResourcePage([
...events,
...dbEvents,
...oldEvents,
...placementGroupAssignedEvent,
...placementGroupCreateEvent,
eventWithSpecialCharacters,
])
const events = Object.entries(eventMessages).flatMap(
([eventKey, statuses], eventIndex) =>
Object.entries(statuses).map(
([status, messageFunc], statusIndex) => ({
...baseEvent,
action: eventKey as Event['action'],
id: eventIndex * 1000 + statusIndex,
status: status as Event['status'],
})
)
);
// Randomly select 25 items
const randomEvents = events.sort(() => 0.5 - Math.random()).slice(0, 25);

return HttpResponse.json(makeResourcePage(randomEvents));
},
{
once: true,
Expand Down
Loading