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: develop section component #61

Merged
merged 13 commits into from
Oct 11, 2021
Merged
49 changes: 49 additions & 0 deletions packages/dgt-components/demo/demo-authenticate.component.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,49 @@
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();
this.define('auth-flow', AuthenticateComponent);

}

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

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

}
/**
* 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: 10 additions & 8 deletions packages/dgt-components/demo/demo.ts
Original file line number Diff line number Diff line change
@@ -1,15 +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 {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);
customElements.define('profile-name-component', ProfileNameComponent);
customElements.define('profile-contact-component', ProfileContactComponent);
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
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