Skip to content

Commit

Permalink
feat: add fixed issuers to authenticate component (#62)
Browse files Browse the repository at this point in the history
* feat: moved models from uitransfer to shared

* feat: moved services from uitransfer to shared

* feat: moved auth components from uitransfer to shared

* feat: added provider list above the webid component

* fix: show components on correct machine state

* fix: updated coverage

* chore: center components in demo view

Co-authored-by: Arne Vandoorslaer <[email protected]>
  • Loading branch information
lem-onade and Arne Vandoorslaer authored Oct 7, 2021
1 parent bf85f47 commit efcb2ee
Show file tree
Hide file tree
Showing 68 changed files with 2,567 additions and 79 deletions.
43 changes: 43 additions & 0 deletions packages/dgt-components/demo/demo-authenticate.component.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,43 @@
import { css, html, unsafeCSS } from 'lit-element';
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';

export class DemoAuthenticateComponent extends RxLitElement {
private solidService = new SolidSDKService('UI Transfer');

onAuthenticated = (event: CustomEvent): void => { };


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

}
/**
* Renders the component as HTML.
*
* @returns The rendered HTML of the component.
*/
render() {

return html`
<auth-flow .solidService="${this.solidService}" @authenticated="${this.onAuthenticated}"></auth-flow>
`;

}

/**
* The styles associated with the component.
*/
static get styles() {

return [
unsafeCSS(Theme),
css``,
];

}

}
18 changes: 11 additions & 7 deletions packages/dgt-components/demo/demo.ts
Original file line number Diff line number Diff line change
@@ -1,13 +1,17 @@
import { Parser } from 'n3';
import { ComponentEventType, ComponentReadEvent, ComponentResponseEvent, ComponentWriteEvent } from '@digita-ai/semcom-sdk';
import {ProfileNameComponent} from '../lib/profile/profile-name.component';
import {FormElementComponent} from '../lib/forms/form-element.component';
import {ContentHeaderComponent} from '../lib/header/content-header.component';
import {CardComponent} from '../lib/cards/card.component';
import { ProfileContactComponent } from '../lib/profile/profile-contact.component';
import { ProfilePayslipComponent } from '../lib/profile/profile-payslip.component';
import { ListItemComponent } from '../lib/list-item/list-item.component';
import {ProfileNameComponent} from '../lib/components/profile/profile-name.component';
import {FormElementComponent} from '../lib/components/forms/form-element.component';
import {ContentHeaderComponent} from '../lib/components/header/content-header.component';
import {CardComponent} from '../lib/components/cards/card.component';
import { ProfileContactComponent } from '../lib/components/profile/profile-contact.component';
import { ProfilePayslipComponent } from '../lib/components/profile/profile-payslip.component';
import { DemoAuthenticateComponent } from './demo-authenticate.component';
import { ListItemComponent } from '../lib/components/list-item/list-item.component';



customElements.define('demo-auth', DemoAuthenticateComponent);
customElements.define('nde-form-element', FormElementComponent);
customElements.define('nde-content-header', ContentHeaderComponent);
customElements.define('nde-card', CardComponent);
Expand Down
2 changes: 1 addition & 1 deletion packages/dgt-components/demo/index.html
Original file line number Diff line number Diff line change
Expand Up @@ -13,6 +13,7 @@
<!-- just a placeholder for serving in develop -->
<script>window.global = window;</script>
<script type="module" src="./demo.ts"></script>
<demo-auth></demo-auth>

<list-item>
<div slot="icon"><img style="height: 50px" src="./itsme.svg"></div>
Expand All @@ -22,6 +23,5 @@
<profile-name-component entry="./data/profile.txt"></profile-name-component>
<profile-contact-component entry="./data/profile.txt"></profile-contact-component>
<profile-payslip-component entry="./data/profile.txt"></profile-payslip-component>

</body>
</html>
2 changes: 2 additions & 0 deletions packages/dgt-components/demo/styles.module.css
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,8 @@ html {
}

body {
margin: auto;
width: 550px;
height: 100%;
background-color: var(--colors-background-normal);
display: flex;
Expand Down
File renamed without changes.
Original file line number Diff line number Diff line change
@@ -0,0 +1,115 @@
import { html, internalProperty, TemplateResult, property, PropertyValues, 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 { 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;

constructor() {

super();

this.define('provider-list', ProviderListComponent);
this.define('webid-form', WebIdComponent);
this.define('separator-component', SeparatorComponent);
this.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));

// 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.actor.onDone((event: DoneEvent) => { this.dispatchEvent(new CustomEvent('authenticated', { detail: event.data.session })); });

this.actor.start();

}

}

onSubmit = (event: CustomEvent): void => {

event.preventDefault();
this.actor.send(new WebIdEnteredEvent(event.detail));

};

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

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``}
` : 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>` }
`}`;

}

define(tag: string, module: CustomElementConstructor): void {

if (!customElements.get(tag)) customElements.define(tag, module);

}
static get styles(): CSSResultArray {

return [
unsafeCSS(Theme),
css`
separator-component {
margin: var(--gap-large) 0;
}
`,
];

}

}

export default AuthenticateComponent;
Loading

0 comments on commit efcb2ee

Please sign in to comment.