From eb9247b78fa5c094732648189cbe2a0502d3bf63 Mon Sep 17 00:00:00 2001 From: Ken Sternberg Date: Tue, 17 Oct 2023 13:38:27 -0700 Subject: [PATCH] web: updated storybook stories for the wizard, illustration how "a simple wizard" is configured in source code and tested with storybook. --- .../ak-wizard-main/stories/ak-demo-wizard.ts | 65 +++++++++---------- .../stories/ak-wizard-main.stories.ts | 27 +------- 2 files changed, 34 insertions(+), 58 deletions(-) diff --git a/web/src/components/ak-wizard-main/stories/ak-demo-wizard.ts b/web/src/components/ak-wizard-main/stories/ak-demo-wizard.ts index d28b38d53..eaf8de53e 100644 --- a/web/src/components/ak-wizard-main/stories/ak-demo-wizard.ts +++ b/web/src/components/ak-wizard-main/stories/ak-demo-wizard.ts @@ -1,48 +1,47 @@ -import { AKElement } from "@goauthentik/elements/Base"; - import { customElement } from "@lit/reactive-element/decorators/custom-element.js"; import { html } from "lit"; -import { property } from "lit/decorators.js"; -import { ifDefined } from "lit/directives/if-defined.js"; +import { BackStep, CancelWizard, CloseWizard, NextStep } from "../commonWizardButtons"; +import { msg } from "@lit/localize"; import PFButton from "@patternfly/patternfly/components/Button/button.css"; import PFRadio from "@patternfly/patternfly/components/Radio/radio.css"; import PFBase from "@patternfly/patternfly/patternfly-base.css"; -import "../ak-wizard-context"; -import "../ak-wizard-frame"; -import type { WizardStep } from "../types"; +import type { WizardStep } from "@goauthentik/components/ak-wizard-main/types"; +import { AkWizard } from "../AkWizard"; + +type WizardStateUpdate = { + message: string; +}; + +const dummySteps: WizardStep[] = [ + { + label: "Test Step1", + render: () => html`

This space intentionally left blank today

`, + disabled: false, + buttons: [NextStep, CancelWizard], + }, + { + label: "Test Step 2", + render: () => html`

This space also intentionally left blank

`, + disabled: false, + buttons: [BackStep, CloseWizard], + }, +]; @customElement("ak-demo-wizard") -export class AkDemoWizard extends AKElement { +export class ApplicationWizard extends AkWizard { static get styles() { return [PFBase, PFButton, PFRadio]; } - @property({ attribute: false }) - steps: WizardStep[] = []; - - @property({ type: Boolean }) - open = false; - - @property() - header!: string; - - @property() - description?: string; - - render() { - return html` - - - - - - `; + constructor() { + super(msg("Open Wizard"), msg("Demo Wizard"), msg("Run the demo wizard")); + this.steps = [...dummySteps]; } + + close() { + this.frame.value!.open = false; + } + } diff --git a/web/src/components/ak-wizard-main/stories/ak-wizard-main.stories.ts b/web/src/components/ak-wizard-main/stories/ak-wizard-main.stories.ts index 89b783061..f841f47bf 100644 --- a/web/src/components/ak-wizard-main/stories/ak-wizard-main.stories.ts +++ b/web/src/components/ak-wizard-main/stories/ak-wizard-main.stories.ts @@ -2,11 +2,7 @@ import "@goauthentik/elements/messages/MessageContainer"; import { Meta } from "@storybook/web-components"; import { TemplateResult, html } from "lit"; - -import AkWizard from "../ak-wizard-frame"; -import "../ak-wizard-main"; -import { BackStep, CancelWizard, CloseWizard, NextStep } from "../commonWizardButtons"; -import type { WizardStep } from "../types"; +import "./ak-demo-wizard"; const metadata: Meta = { title: "Components / Wizard / Basic", @@ -36,28 +32,9 @@ const container = (testItem: TemplateResult) => ${testItem} `; -const dummySteps: WizardStep[] = [ - { - label: "Test Step1", - render: () => html`

This space intentionally left blank today

`, - disabled: false, - buttons: [NextStep, CancelWizard], - }, - { - label: "Test Step 2", - render: () => html`

This space also intentionally left blank

`, - disabled: false, - buttons: [BackStep, CloseWizard], - }, -]; export const OnePageWizard = () => { return container( - html` `, + html` ` ); };