mirror of
https://github.com/bitwarden/browser.git
synced 2025-03-12 13:39:14 +01:00
* setup anon-layout component * add story with content * simplify stories and add title input * add responsiveness * adjust border styling * add logo * add logo * mock PlatformUtilsService * more responsivness * add secondary content * add stories and clarifying comments * add more to responsiveness * Update libs/components/tailwind.config.js Co-authored-by: Oscar Hinton <Hinton@users.noreply.github.com> * Update libs/components/tailwind.config.base.js Co-authored-by: Oscar Hinton <Hinton@users.noreply.github.com> * Update libs/auth/src/components/anon-layout.stories.ts Co-authored-by: Oscar Hinton <Hinton@users.noreply.github.com> * refactor: use bit-icon instead of css file, add auth- prefix, adjust tailwind settings * account for longer content * allow for adding an icon above logo * simplify stories by removing unnecessary styling * delete duplicate logo and minify logo and icon * remove componentWrapperDecorator * change subTitle to subtitle * use bitTypography * add accessibility title and use tw class for fill color * add <title> element to SVG * typography update and minor styling updates for stories * match breakpoint for logo and h1 * reduce spacing between sections * move to new folder * add closing tag * make fields protected * use svg directly * refactor icons * revert to allow for additional icons in the future * decouple icon from component --------- Co-authored-by: Oscar Hinton <Hinton@users.noreply.github.com>
108 lines
4.7 KiB
TypeScript
108 lines
4.7 KiB
TypeScript
import { Meta, StoryObj, moduleMetadata } from "@storybook/angular";
|
|
|
|
import { PlatformUtilsService } from "@bitwarden/common/platform/abstractions/platform-utils.service";
|
|
|
|
import { ButtonModule } from "../../../../components/src/button";
|
|
import { IconLock } from "../../icons/icon-lock";
|
|
|
|
import { AnonLayoutComponent } from "./anon-layout.component";
|
|
|
|
class MockPlatformUtilsService implements Partial<PlatformUtilsService> {
|
|
getApplicationVersion = () => Promise.resolve("Version 2023.1.1");
|
|
}
|
|
|
|
export default {
|
|
title: "Auth/Anon Layout",
|
|
component: AnonLayoutComponent,
|
|
decorators: [
|
|
moduleMetadata({
|
|
imports: [ButtonModule],
|
|
providers: [
|
|
{
|
|
provide: PlatformUtilsService,
|
|
useClass: MockPlatformUtilsService,
|
|
},
|
|
],
|
|
}),
|
|
],
|
|
args: {
|
|
title: "The Page Title",
|
|
subtitle: "The subtitle (optional)",
|
|
icon: IconLock,
|
|
},
|
|
} as Meta;
|
|
|
|
type Story = StoryObj<AnonLayoutComponent>;
|
|
|
|
export const WithPrimaryContent: Story = {
|
|
render: (args) => ({
|
|
props: args,
|
|
template:
|
|
/**
|
|
* The projected content (i.e. the <div> ) and styling below is just a
|
|
* sample and could be replaced with any content and styling
|
|
*/
|
|
`
|
|
<auth-anon-layout [title]="title" [subtitle]="subtitle">
|
|
<div class="tw-font-bold">Primary Projected Content Area (customizable)</div>
|
|
<div>Lorem ipsum dolor sit amet consectetur adipisicing elit. Necessitatibus illum vero, placeat recusandae esse ratione eius minima veniam nemo, quas beatae! Impedit molestiae alias sapiente explicabo. Sapiente corporis ipsa numquam?</div>
|
|
</auth-anon-layout>
|
|
`,
|
|
}),
|
|
};
|
|
|
|
export const WithSecondaryContent: Story = {
|
|
render: (args) => ({
|
|
props: args,
|
|
template:
|
|
// Notice that slot="secondary" is requred to project any secondary content:
|
|
`
|
|
<auth-anon-layout [title]="title" [subtitle]="subtitle">
|
|
<div>
|
|
<div class="tw-font-bold">Primary Projected Content Area (customizable)</div>
|
|
<div>Lorem ipsum dolor sit amet consectetur adipisicing elit. Necessitatibus illum vero, placeat recusandae esse ratione eius minima veniam nemo, quas beatae! Impedit molestiae alias sapiente explicabo. Sapiente corporis ipsa numquam?</div>
|
|
</div>
|
|
|
|
<div slot="secondary" class="text-center">
|
|
<div class="tw-font-bold tw-mb-2">Secondary Projected Content (optional)</div>
|
|
<button bitButton>Perform Action</button>
|
|
</div>
|
|
</auth-anon-layout>
|
|
`,
|
|
}),
|
|
};
|
|
|
|
export const WithLongContent: Story = {
|
|
render: (args) => ({
|
|
props: args,
|
|
template: `
|
|
<auth-anon-layout title="Page Title lorem ipsum dolor consectetur sit amet expedita quod est" subtitle="Subtitle here Lorem ipsum dolor sit amet consectetur adipisicing elit. Expedita, quod est?">
|
|
<div>
|
|
<div class="tw-font-bold">Primary Projected Content Area (customizable)</div>
|
|
<div>Lorem ipsum dolor sit amet consectetur adipisicing elit. Necessitatibus illum vero, placeat recusandae esse ratione eius minima veniam nemo, quas beatae! Impedit molestiae alias sapiente explicabo. Sapiente corporis ipsa numquam? Lorem ipsum dolor sit amet consectetur adipisicing elit. Lorem ipsum dolor sit amet consectetur adipisicing elit. Lorem ipsum dolor sit amet consectetur adipisicing elit. Lorem ipsum dolor sit amet consectetur adipisicing elit. Lorem ipsum dolor sit amet consectetur adipisicing elit. Lorem ipsum dolor sit amet consectetur adipisicing elit. Lorem ipsum dolor sit amet consectetur adipisicing elit. Lorem ipsum dolor sit amet consectetur adipisicing elit. Lorem ipsum dolor sit amet consectetur adipisicing elit.</div>
|
|
</div>
|
|
|
|
<div slot="secondary" class="text-center">
|
|
<div class="tw-font-bold tw-mb-2">Secondary Projected Content (optional)</div>
|
|
<p>Lorem ipsum dolor sit amet consectetur adipisicing elit. Molestias laborum nostrum natus. Lorem ipsum dolor sit amet consectetur adipisicing elit. Molestias laborum nostrum natus. Expedita, quod est? </p>
|
|
<button bitButton>Perform Action</button>
|
|
</div>
|
|
</auth-anon-layout>
|
|
`,
|
|
}),
|
|
};
|
|
|
|
export const WithIcon: Story = {
|
|
render: (args) => ({
|
|
props: args,
|
|
template: `
|
|
<auth-anon-layout [title]="title" [subtitle]="subtitle" [icon]="icon">
|
|
<div>
|
|
<div class="tw-font-bold">Primary Projected Content Area (customizable)</div>
|
|
<div>Lorem ipsum dolor sit amet consectetur adipisicing elit. Necessitatibus illum vero, placeat recusandae esse ratione eius minima veniam nemo, quas beatae! Impedit molestiae alias sapiente explicabo. Sapiente corporis ipsa numquam?</div>
|
|
</div>
|
|
</auth-anon-layout>
|
|
`,
|
|
}),
|
|
};
|