Skip to content

Commit

Permalink
fix: authenticate component improvements (#68)
Browse files Browse the repository at this point in the history
* fix: authenticated event should bubble

* chore: remove default margin around provider lists

* chore: changed issuers to property

* fix: use slots, properties for text content

* chore: updated styling for authenticate component

* chore: update autofill background color

* test: updated tests

* test: updated coverage

* chore: hydrate authenticate component
  • Loading branch information
lem-onade authored Oct 11, 2021
1 parent e066db3 commit 373c3a2
Show file tree
Hide file tree
Showing 10 changed files with 141 additions and 71 deletions.
27 changes: 24 additions & 3 deletions packages/dgt-components/demo/demo-authenticate.component.ts
Original file line number Diff line number Diff line change
Expand Up @@ -3,16 +3,19 @@ import { RxLitElement } from 'rx-lit';
import { Theme } from '@digita-ai/dgt-theme';
import { SolidSDKService } from '../lib/services/solid-sdk.service'
import { AuthenticateComponent } from '../lib/components/authentication/authenticate.component';
import { hydrate } from '../lib/util/hydrate';

export class DemoAuthenticateComponent extends RxLitElement {

private solidService = new SolidSDKService('UI Transfer');

onAuthenticated = (event: CustomEvent): void => { };
onCreateWebId = (event: CustomEvent): void => { alert('This is a demo') };


constructor() {
super();
customElements.define('auth-flow', AuthenticateComponent);
customElements.define('auth-flow', hydrate(AuthenticateComponent)(this.solidService));

}
/**
Expand All @@ -23,7 +26,14 @@ export class DemoAuthenticateComponent extends RxLitElement {
render() {

return html`
<auth-flow .solidService="${this.solidService}" @authenticated="${this.onAuthenticated}"></auth-flow>
<auth-flow
.solidService="${this.solidService}"
@authenticated="${this.onAuthenticated}"
@create-webid="${this.onCreateWebId}"
>
<h1 slot="beforeIssuers">Select an identity provider to log in</h1>
<h1 slot="beforeWebId">Enter your WebID</h1>
</auth-flow>
`;

}
Expand All @@ -35,7 +45,18 @@ export class DemoAuthenticateComponent extends RxLitElement {

return [
unsafeCSS(Theme),
css``,
css`
auth-flow {
--webid-input-padding: var(--gap-small);
}
h1[slot] {
margin: var(--gap-large) var(--gap-normal);
font-size: var(--font-size-header-normal);
font-style: normal;
font-weight: bold;
text-align: center;
}
`,
];

}
Expand Down
Original file line number Diff line number Diff line change
@@ -1,40 +1,45 @@
import { html, internalProperty, TemplateResult, property, PropertyValues, unsafeCSS, CSSResultArray, css } from 'lit-element';
import { html, internalProperty, TemplateResult, property, unsafeCSS, CSSResultArray, css } from 'lit-element';
import { createMachine, DoneEvent, interpret, Interpreter, State, StateMachine } from 'xstate';
import { RxLitElement } from 'rx-lit';
import { from } from 'rxjs';
import { map } from 'rxjs/operators';
import { Theme } from '@digita-ai/dgt-theme';
import { SolidSDKService } from '../../services/solid-sdk.service';
import { Issuer } from '../../models/issuer.model';
import { ProviderListComponent } from '../provider/provider-list.component';
import { SeparatorComponent } from '../separator/separator.component';
import { LoadingComponent } from '../loading/loading.component';
import { define } from '../../util/define';
import { SolidService } from '../../services/solid.service';
import { WebIdComponent } from './webid.component';
import { AuthenticateContext, AuthenticateEvent, authenticateMachine, AuthenticateState, AuthenticateStates, AuthenticateStateSchema, SelectedIssuerEvent, WebIdEnteredEvent } from './authenticate.machine';

export class AuthenticateComponent extends RxLitElement {

private actor: Interpreter<AuthenticateContext, AuthenticateStateSchema, AuthenticateEvent, AuthenticateState>;
private machine: StateMachine<AuthenticateContext, AuthenticateStateSchema, AuthenticateEvent, AuthenticateState>;
private predifinedIssuers: Issuer[] = [
{ description: 'Solid Community', icon: '', uri: 'https://solidcommunity.net' },
{ description: 'Inrupt', icon: 'https://inrupt.com/static/inrupt-social_0-372b94bf42bea86a81cc362e0c99d115.jpg', uri: 'https://inrupt.net/' },
];

@internalProperty()
state?: State<AuthenticateContext>;

@internalProperty()
issuers?: Issuer[];

@property({ type: Object }) solidService: SolidSDKService;

@property({ type: Boolean }) hideWebId = false;

@property({ type: Boolean }) hideIssuers = false;
@property({ type: Boolean }) hideCreateNewWebId = false;

@property({ type: Array }) predefinedIssuers: Issuer[] = [
{ description: 'Solid Community', icon: '', uri: 'https://solidcommunity.net' },
{ description: 'Inrupt', icon: 'https://inrupt.com/static/inrupt-social_0-372b94bf42bea86a81cc362e0c99d115.jpg', uri: 'https://inrupt.net/' },
];

@property({ type: String }) textSeparator = 'or';
@property({ type: String }) textWebIdLabel = 'WebID';
@property({ type: String }) textWebIdPlaceholder = 'Please enter your WebID';
@property({ type: String }) textNoWebId = 'No WebID yet?';
@property({ type: String }) textButton = 'Connect';

constructor() {
constructor(private solidService: SolidService) {

super();

Expand All @@ -43,29 +48,17 @@ export class AuthenticateComponent extends RxLitElement {
define('separator-component', SeparatorComponent);
define('loading-component', LoadingComponent);

}

updated(changed: PropertyValues): void {

super.updated(changed);

if (changed.has('solidService')) {

if (this.actor) this.actor.stop();
this.machine = createMachine(authenticateMachine(this.solidService));

this.machine = createMachine(authenticateMachine(this.solidService));
// eslint-disable-next-line no-console
this.actor = interpret(this.machine, { devTools: true }).onTransition((state) => console.log(state.value));

// eslint-disable-next-line no-console
this.actor = interpret(this.machine, { devTools: true }).onTransition((state) => console.log(state.value));
this.subscribe('state', from(this.actor));
this.subscribe('issuers', from(this.actor).pipe(map((state) => state.context.issuers)));

this.subscribe('state', from(this.actor));
this.subscribe('issuers', from(this.actor).pipe(map((state) => state.context.issuers)));
this.actor.onDone((event: DoneEvent) => { this.dispatchEvent(new CustomEvent('authenticated', { detail: event.data.session })); });

this.actor.onDone((event: DoneEvent) => { this.dispatchEvent(new CustomEvent('authenticated', { detail: event.data.session })); });

this.actor.start();

}
this.actor.start();

}

Expand All @@ -76,15 +69,39 @@ export class AuthenticateComponent extends RxLitElement {

};

onButtonCreateWebIDClick = (): void => { this.dispatchEvent(new CustomEvent('create-webid')); };
onButtonCreateWebIDClick = (): void => { this.dispatchEvent(new CustomEvent('create-webid', { bubbles: true })); };

render(): TemplateResult {

return html`
${ this.state?.matches(AuthenticateStates.AWAITING_WEBID) ? html`
${ !this.hideIssuers ? html`<provider-list @issuer-selected="${(event: CustomEvent) => this.actor.send(new SelectedIssuerEvent(event.detail))}" .providers="${this.predifinedIssuers}"></provider-list>` : html``}
${ !this.hideWebId && !this.hideIssuers ? html`<separator-component>of</separator-component>` : html`` }
${ !this.hideWebId ? html`<webid-form @submit-webid="${this.onSubmit}" @create-webid="${this.onButtonCreateWebIDClick}"></webid-form>` : html``}
<provider-list
?hidden="${this.hideIssuers}"
@issuer-selected="${(event: CustomEvent) => this.actor.send(new SelectedIssuerEvent(event.detail))}"
.providers="${this.predefinedIssuers}"
>
<slot name="beforeIssuers" slot="before"></slot>
<slot name="afterIssuers" slot="after"></slot>
</provider-list>
<separator-component ?hidden="${this.hideIssuers || this.hideWebId}">
${ this.textSeparator }
</separator-component>
<webid-form
?hidden="${this.hideWebId}"
?hideCreateNewWebId="${this.hideCreateNewWebId}"
@submit-webid="${this.onSubmit}"
@create-webid="${this.onButtonCreateWebIDClick}"
.textLabel="${this.textWebIdLabel}"
.textPlaceholder="${this.textWebIdPlaceholder}"
.textNoWebId="${this.textNoWebId}"
.textButton="${this.textButton}"
>
<slot name="beforeWebId" slot="before"></slot>
<slot name="afterWebId" slot="after"></slot>
</webid-form>
` : html` ${ this.state?.matches(AuthenticateStates.SELECTING_ISSUER) ? html`
<provider-list @issuer-selected="${(event: CustomEvent) => this.actor.send(new SelectedIssuerEvent(event.detail))}" .providers="${this.issuers}"></provider-list>`
: html`<loading-component></loading-component>` }
Expand All @@ -101,6 +118,12 @@ export class AuthenticateComponent extends RxLitElement {
separator-component {
margin: var(--gap-large) 0;
}
webid-form {
--input-padding: var(--webid-input-padding);
--border-large: var(--webid-border-large);
--button-height: var(--webid-button-height);
}
`,
];

Expand Down
Original file line number Diff line number Diff line change
@@ -1,15 +1,14 @@
import { html, unsafeCSS, css, TemplateResult, CSSResultArray, property } from 'lit-element';
import { RxLitElement } from 'rx-lit';
import { Theme } from '@digita-ai/dgt-theme';
import { SolidSDKService } from '../../services/solid-sdk.service';
export class WebIdComponent extends RxLitElement {

@property() textEnterYourWebID = 'Enter your WebID';
@property() textWebID = 'WebID';
@property() textWebIDFieldPlaceholder = 'Please enter your WebID ...';
@property() textNoWebIDYet = 'No WebID yet?';
@property() textConnect = 'Connect';
@property({ type: Object }) solidService: SolidSDKService;
@property({ type: String }) textLabel = 'WebID';
@property({ type: String }) textPlaceholder = 'Please enter your WebID ...';
@property({ type: String }) textNoWebId = 'No WebID yet?';
@property({ type: String }) textButton = 'Connect';

@property({ type: Boolean }) hideCreateNewWebId = false;

constructor() {

Expand All @@ -29,13 +28,14 @@ export class WebIdComponent extends RxLitElement {
render(): TemplateResult {

return html`
<h1>${this.textEnterYourWebID}</h1>
<slot name="before"></slot>
<form @submit="${this.onSubmit}">
<label for="webid">${this.textWebID}</label>
<input type="text" id="webid" name="webid" placeholder="${this.textWebIDFieldPlaceholder}" />
<span @click="${this.onButtonCreateWebIDClick}">${this.textNoWebIDYet}</span>
<button class="dark">${this.textConnect}</button>
<label for="webid">${this.textLabel}</label>
<input type="text" id="webid" name="webid" placeholder="${this.textPlaceholder}" />
<a ?hidden="${this.hideCreateNewWebId}" @click="${this.onButtonCreateWebIDClick}">${this.textNoWebId}</a>
<button class="dark">${this.textButton}</button>
</form>
<slot name="after"></slot>
`;

}
Expand All @@ -47,24 +47,26 @@ export class WebIdComponent extends RxLitElement {
css`
button {
width: 100%;
margin: var(--gap-large) 0;
margin: var(--gap-normal) 0 0 0;
border-radius: var(--border-large);
height: var(--button-height);
}
input {
margin: var(--gap-small) 0;
padding: var(--gap-normal);
padding: var(--input-padding);
}
span {
a {
font-size: var(--font-size-small);
padding: var(--gap-tiny);
text-decoration: underline;
color: var(--colors-primary-normal);
text-align: right;
cursor: pointer;
}
span:hover {
a:hover {
color: var(--colors-primary-dark);
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -40,7 +40,7 @@ export class ProviderListItemComponent extends RxLitElement {
background: var(--colors-background-light);
box-shadow: 0px 2px 4px rgba(26, 32, 44, 0.1);
border-radius: var(--border-large);
margin: var(--gap-small) var(--gap-normal);
margin: var(--gap-small) 0;
padding: var(--gap-small);
height: var(--gap-large);
cursor: pointer;
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -29,11 +29,13 @@ export class ProviderListComponent extends LitElement {
render(): TemplateResult {

return html`
<h1>Select an identity provider to log in</h1>
<slot name="before"></slot>
<div class="providers">
${ this.providers.map((provider) => html`
${ this.providers.map((provider) => html`
<provider-list-item @button-clicked="${this.onIssuerSelected(provider)}" .icon="${provider.icon}" .description="${provider.description}" ?buttonEnabled=${this.buttonsEnabled}></provider-list-item>
`)}</div>`;
`)}
</div>
<slot name="after"></slot>`;

}

Expand All @@ -42,13 +44,6 @@ export class ProviderListComponent extends LitElement {
return [
unsafeCSS(Theme),
css`
h1 {
margin: var(--gap-large) var(--gap-normal);
font-size: var(--font-size-header-normal);
font-style: normal;
font-weight: bold;
text-align: center;
}
`,
];

Expand Down
Loading

0 comments on commit 373c3a2

Please sign in to comment.