-
-
Notifications
You must be signed in to change notification settings - Fork 90
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
docs(core): add autoMap mapping configuration docs (#539)
- Loading branch information
1 parent
4b03318
commit d92f62f
Showing
10 changed files
with
110 additions
and
16 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
63 changes: 63 additions & 0 deletions
63
packages/documentations/docs/mapping-configuration/auto-map.mdx
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,63 @@ | ||
--- | ||
id: auto-map | ||
title: AutoMap | ||
sidebar_label: AutoMap | ||
sidebar_position: 3 | ||
--- | ||
|
||
`autoMap()` is an alternative to the the `@AutoMap()` decorator. It trivially maps a property with the **same name and type** on the `Source` and `Destination` objects. | ||
|
||
## Decoratorless entities and DTOs | ||
|
||
Use this specially when your entities and DTOs cannot have the `@AutoMap()` decorator (e.g. when using **constructor assignments**), or when you would rather avoid them: | ||
|
||
```ts | ||
import { | ||
autoMap, | ||
createMap, | ||
forMember, | ||
mapFrom, | ||
Mapper, | ||
} from '@automapper/core'; | ||
|
||
export class DecoratorlessUserEntity { | ||
constructor( | ||
public readonly firstName: string, | ||
public readonly lastName: string, | ||
public readonly birthday: Date | ||
) {} | ||
} | ||
|
||
export class DecoratorlessUserDto { | ||
firstName!: string; | ||
lastName!: string; | ||
birthday!: string; | ||
fullName!: string; | ||
} | ||
|
||
export function decoratorlessUserProfile(mapper: Mapper) { | ||
createMap( | ||
mapper, | ||
DecoratorlessUserEntity, | ||
DecoratorlessUserDto, | ||
// Use `autoMap()` on properties that can be trivially mapped. | ||
autoMap('firstName'), | ||
autoMap('lastName'), | ||
|
||
// Use more elaborate mapping configurations when necessary: | ||
|
||
// 'birthday' exists on both `Source` and `Destination`, but with | ||
// different types. | ||
forMember( | ||
(d) => d.birthday, | ||
mapFrom((s) => s.birthday.toDateString()) | ||
), | ||
|
||
// 'fullName' doesn't exist on `Source` and must be mapped manually. | ||
forMember( | ||
(d) => d.fullName, | ||
mapFrom((s) => `${s.firstName} ${s.lastName}`) | ||
) | ||
); | ||
} | ||
``` |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters