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

CC-31652 Introduced datasource.dependable and datasource.trigger services. #2282

Merged
Merged
Show file tree
Hide file tree
Changes from 8 commits
Commits
Show all changes
23 commits
Select commit Hold shift + click to select a range
9993d27
Merge branch 'master' of https://github.com/spryker/spryker-docs
Oct 25, 2023
04ef08c
Merge branch 'master' of https://github.com/spryker/spryker-docs
Oct 25, 2023
2109c3d
CC-31652 Introduced `datasource.dependable` and `datasource.trigger` …
Oct 30, 2023
3ca5262
CC-31652 Updated datasource-trigger.md.
Nov 6, 2023
969f16a
CC-31652 Updated ui-components-library.md
Nov 6, 2023
e6ce260
Update datasource-dependable.md
andriitserkovnyi Jan 9, 2024
e625b1b
Merge branch 'master' into feature/cc-31652-fe-new-services-documenta…
andriitserkovnyi Jan 9, 2024
ae12247
Update datasource-trigger-change.md
andriitserkovnyi Jan 10, 2024
39523fa
review
andriitserkovnyi Jan 10, 2024
8bfedb3
Update datasource-trigger.md
andriitserkovnyi Jan 10, 2024
878ef59
Update datasource-trigger.md
andriitserkovnyi Jan 10, 2024
0131cb6
Update datasource-trigger.md
andriitserkovnyi Jan 10, 2024
b201e1a
review
andriitserkovnyi Jan 10, 2024
52757d8
Update datasource-trigger.md
andriitserkovnyi Jan 11, 2024
bff3e6b
Merge branch 'master' into feature/cc-31652-fe-new-services-documenta…
andriitserkovnyi Jan 11, 2024
2eb3895
final
andriitserkovnyi Jan 11, 2024
3ccae2c
Merge branch 'master' into feature/cc-31652-fe-new-services-documenta…
andriitserkovnyi Jan 12, 2024
98681ec
links
andriitserkovnyi Jan 12, 2024
ccf141f
Merge branch 'master' into feature/cc-31652-fe-new-services-documenta…
andriitserkovnyi Jan 15, 2024
a5ea1d3
Update scos_dev_sidebar.yml
andriitserkovnyi Jan 15, 2024
4e4d206
Merge branch 'master' into feature/cc-31652-fe-new-services-documenta…
andriitserkovnyi Jan 15, 2024
aeeff3d
Merge branch 'master' into feature/cc-31652-fe-new-services-documenta…
andriitserkovnyi Jan 16, 2024
9cd3a48
links
andriitserkovnyi Jan 16, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
9 changes: 9 additions & 0 deletions _data/sidebars/scos_dev_sidebar.yml
Original file line number Diff line number Diff line change
Expand Up @@ -1862,6 +1862,15 @@ entries:
- title: "Datasources"
url: /docs/scos/dev/front-end-development/marketplace/ui-components-library/datasources/datasources.html
nested:
- title: "Trigger"
url: /docs/scos/dev/front-end-development/marketplace/ui-components-library/datasources/datasource-trigger/datasource-trigger.html
nested:
- title: "Change"
url: /docs/scos/dev/front-end-development/marketplace/ui-components-library/datasources/datasource-trigger/datasource-trigger-change.html
- title: "Input"
url: /docs/scos/dev/front-end-development/marketplace/ui-components-library/datasources/datasource-trigger/datasource-trigger-input.html
- title: "Depenable"
url: /docs/scos/dev/front-end-development/marketplace/ui-components-library/datasources/datasource-dependable.html
- title: "HTTP"
url: /docs/scos/dev/front-end-development/marketplace/ui-components-library/datasources/datasource-http.html
- title: "Inline"
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,115 @@
---
title: Datasource Dependable
description: This document provides details about the Datasource Dependable service in the Components Library.
template: concept-topic-template
related:
- title: Datasource Trigger
link: docs/scos/dev/front-end-development/page.version/marketplace/ui-components-library/datasources/datasource-trigger.html
- title: Datasource Http
link: docs/scos/dev/front-end-development/page.version/marketplace/ui-components-library/datasources/datasource-http.html
- title: Datasource Inline Table
link: docs/scos/dev/front-end-development/page.version/marketplace/ui-components-library/datasources/datasource-inline-table.html
- title: Datasource Inline
link: docs/scos/dev/front-end-development/page.version/marketplace/ui-components-library/datasources/datasource-inline.html
---

This document explains the Datasource Dependable service in the Components Library.

## Overview

Datasource Dependable is an Angular service that resolves datasources for a component based on the value of a specific element.

Check out an example usage of the Datasource Dependable.
andriitserkovnyi marked this conversation as resolved.
Show resolved Hide resolved

Service configuration:

| ATTRIBUTE | DESCRIPTION |
| - | - |
| type | A datasource type. |
| id | An ID of the dependent element |
| datasource | The next datasource that runs based on the depended element value, like [http](/docs/scos/dev/front-end-development/{{page.version}}/marketplace/ui-components-library/datasources/datasource-http.html). |

```html
<spy-datasource-dependable id="dependable-select">
<spy-select
[options]="{ ... }"
>
</spy-select>
</spy-datasource-dependable>

<spy-select
[datasource]="{
type: 'dependable-element',
id: 'dependable-select',
datasource: {
type: 'http',
url: '/request-url',
},
}"
>
</spy-select>
```

The dependent element, `SelectComponent` in the example, must implement a `DatasourceDependableElement` abstract class (token) and return component value using the `getValueChanges()` abstract method:

```ts
@Component({
...,
providers: [
{
provide: DatasourceDependableElement,
useExisting: SelectComponent,
},
],
})
export class SelectComponent implements DatasourceDependableElement {
...
getValueChanges(): Observable<SelectValueSelected> {
// This method must return an Observable of the component value.
}
...
}
```

## Service registration

Register the service:

```ts
declare module '@spryker/datasource' {
interface DatasourceRegistry {
'dependable-element': DatasourceDependableService;
}
}

@NgModule({
imports: [
DatasourceModule.withDatasources({
'dependable-element': DatasourceDependableService,
}),
],
})
export class RootModule {}
```

## Interfaces

Datasource dependable interfaces:

```ts
import { DatasourceConfig } from '@spryker/datasource';
import { Observable } from 'rxjs';

export interface DatasourceDependableConfig extends DatasourceConfig {
id: string;
datasource: DatasourceConfig;
}

export interface DatasourceDependableElementsConfig {
[id: string]: DatasourceDependableElement;
}

export abstract class DatasourceDependableElement {
abstract getValueChanges(): Observable<unknown>;
}
```
Original file line number Diff line number Diff line change
Expand Up @@ -5,8 +5,10 @@ template: concept-topic-template
redirect_from:
- /docs/marketplace/dev/front-end/202212.0/ui-components-library/datasources/datasource-http.html
related:
- title: Datasources
link: docs/scos/dev/front-end-development/page.version/marketplace/ui-components-library/datasources/datasources.html
- title: Datasource Dependable
link: docs/scos/dev/front-end-development/page.version/marketplace/ui-components-library/datasources/datasource-dependable.html
- title: Datasource Trigger
link: docs/scos/dev/front-end-development/page.version/marketplace/ui-components-library/datasources/datasource-trigger.html
- title: Datasource Inline Table
link: docs/scos/dev/front-end-development/page.version/marketplace/ui-components-library/datasources/datasource-inline-table.html
- title: Datasource Inline
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -5,8 +5,10 @@ template: concept-topic-template
redirect_from:
- /docs/marketplace/dev/front-end/202212.0/ui-components-library/datasources/datasource-inline-table.html
related:
- title: Datasources
link: docs/scos/dev/front-end-development/page.version/marketplace/ui-components-library/datasources/datasources.html
- title: Datasource Dependable
link: docs/scos/dev/front-end-development/page.version/marketplace/ui-components-library/datasources/datasource-dependable.html
- title: Datasource Trigger
link: docs/scos/dev/front-end-development/page.version/marketplace/ui-components-library/datasources/datasource-trigger.html
- title: Datasource Http
link: docs/scos/dev/front-end-development/page.version/marketplace/ui-components-library/datasources/datasource-http.html
- title: Datasource Inline
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -5,8 +5,10 @@ template: concept-topic-template
redirect_from:
- /docs/marketplace/dev/front-end/202212.0/ui-components-library/datasources/datasource-inline.html
related:
- title: Datasources
link: docs/scos/dev/front-end-development/page.version/marketplace/ui-components-library/datasources/datasources.html
- title: Datasource Dependable
link: docs/scos/dev/front-end-development/page.version/marketplace/ui-components-library/datasources/datasource-dependable.html
- title: Datasource Trigger
link: docs/scos/dev/front-end-development/page.version/marketplace/ui-components-library/datasources/datasource-trigger.html
- title: Datasource Http
link: docs/scos/dev/front-end-development/page.version/marketplace/ui-components-library/datasources/datasource-http.html
- title: Datasource Inline Table
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,86 @@
---
title: Datasource Trigger Change
description: This document provides details about the Datasource Trigger Change service in the Components Library.
template: concept-topic-template
related:
- title: Datasource Dependable
link: docs/scos/dev/front-end-development/page.version/marketplace/ui-components-library/datasources/datasource-dependable.html
- title: Datasource Http
link: docs/scos/dev/front-end-development/page.version/marketplace/ui-components-library/datasources/datasource-http.html
- title: Datasource Inline Table
link: docs/scos/dev/front-end-development/page.version/marketplace/ui-components-library/datasources/datasource-inline-table.html
- title: Datasource Inline
link: docs/scos/dev/front-end-development/page.version/marketplace/ui-components-library/datasources/datasource-inline.html
---

This document explains the Datasource Trigger Change service in the Components Library.

## Overview

Datasource Trigger Change is an Angular service that extracts the value from an event trigger element and checks whether it meets a certain criteria. If the value is valid, it emits an object containing the value.

Check out an example usage of the Datasource Trigger Change.

Service configuration:

| ATTRIBUTE | DESCRIPTION |
| - | - |
|type | A datasource type. |
|event | An event type triggered by element. |
|debounce | Delays the emission of values the next datasource (default is `300ms`). |
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Can you clarify the description? Looks like something is missing

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

What exactly? Description looks clear

Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I don't get how the next datasource relates to the preceding part of the sentence

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

datasource is an angular service and not exactly data source

Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Still don't get it, but I'll try to guess:

Suggested change
|debounce | Delays the emission of values the next datasource (default is `300ms`). |
|debounce | Delays the emission of values of the next datasource (default is `300ms`). |

|minCharacters | Emits the trigger element value if the length is greater than or equal to the `minCharacters` property. The default value is `2`. |
|datasource | the next datasource that runs based on the dependent element value, like [http](/docs/scos/dev/front-end-development/page.version/marketplace/ui-components-library/datasources/datasource-http.html). |

```html
<spy-select
[datasource]="{
type: 'trigger',
event: 'change',
debounce: 400,
minCharacters: 3,
datasource: {
type: 'http',
url: '/request-url',
},
}"
>
</spy-select>
```

## Service registration

Register the service:

```ts
declare module '@spryker/datasource' {
interface DatasourceRegistry {
trigger: DatasourceTriggerService;
}
}

@NgModule({
imports: [
DatasourceModule.withDatasources({
trigger: DatasourceTriggerService,
}),
DatasourceTriggerModule.withEvents({
change: ChangeDatasourceTriggerService,
}),
],
})
export class RootModule {}
```

## Interfaces

Below you can find interfaces for the Datasource Trigger Change:

```ts
import { DatasourceTriggerConfig } from '@spryker/datasource.trigger';

export interface ChangeDatasourceTriggerConfig extends DatasourceTriggerConfig {
minCharacters?: number;
}

export type ChangeDatasourceTriggerHTMLElement = HTMLInputElement | HTMLTextAreaElement | HTMLSelectElement;
```
Original file line number Diff line number Diff line change
@@ -0,0 +1,84 @@
---
title: Datasource Trigger Input
description: This document provides details about the Datasource Trigger Input service in the Components Library.
template: concept-topic-template
related:
- title: Datasource Dependable
link: docs/scos/dev/front-end-development/page.version/marketplace/ui-components-library/datasources/datasource-dependable.html
- title: Datasource Http
link: docs/scos/dev/front-end-development/page.version/marketplace/ui-components-library/datasources/datasource-http.html
- title: Datasource Inline Table
link: docs/scos/dev/front-end-development/page.version/marketplace/ui-components-library/datasources/datasource-inline-table.html
- title: Datasource Inline
link: docs/scos/dev/front-end-development/page.version/marketplace/ui-components-library/datasources/datasource-inline.html
---

This document explains the Datasource Trigger Input service in the Components Library.

## Overview

Datasource Trigger Input is an Angular Service that extracts the value from the event trigger element and checks whether it meets certain criteria. If the value is valid, it emits an object containing the value.

Check out an example usage of the Datasource Trigger Input.

Service configuration:

- `type` — a datasource type.
- `event` — an event type triggered by element.
- `debounce` - delays the emission of values the next datasource (default is `300ms`).
- `minCharacters` - emits the trigger element value if the length is greater than or equal to the `minCharacters` property (default is `2`).
- `datasource` — the next datasource that runs based on the depended element value (e.g. [http](/docs/scos/dev/front-end-development/page.version/marketplace/ui-components-library/datasources/datasource-http.html)).

```html
<spy-select
[datasource]="{
type: 'trigger',
event: 'input',
debounce: 400,
minCharacters: 3,
datasource: {
type: 'http',
url: '/request-url',
},
}"
>
</spy-select>
```

## Service registration

Register the service:

```ts
declare module '@spryker/datasource' {
interface DatasourceRegistry {
trigger: DatasourceTriggerService;
}
}

@NgModule({
imports: [
DatasourceModule.withDatasources({
trigger: DatasourceTriggerService,
}),
DatasourceTriggerModule.withEvents({
input: InputDatasourceTriggerService,
}),
],
})
export class RootModule {}
```

## Interfaces

Below you can find interfaces for the Datasource Trigger Input:

```ts
import { DatasourceTriggerConfig } from '@spryker/datasource.trigger';

export interface InputDatasourceTriggerConfig extends DatasourceTriggerConfig {
minCharacters?: number;
}

export type InputDatasourceTriggerHTMLElement = HTMLInputElement | HTMLTextAreaElement | HTMLSelectElement;
```
Loading
Loading