Files
medusa-store/docs/content/references/services/classes/ShippingProfileService.md
Shahed Nasser a8293af8e1 fix: overlapping branch names for generated PRs of references (#2097)
* fix overlapping branch names of generated references

* regenerate references
2022-08-25 17:47:58 +03:00

540 lines
13 KiB
Markdown

# Class: ShippingProfileService
Provides layer to manipulate profiles.
**`Implements`**
## Hierarchy
- `TransactionBaseService`
**`ShippingProfileService`**
## Constructors
### constructor
**new ShippingProfileService**(`__namedParameters`)
#### Parameters
| Name | Type |
| :------ | :------ |
| `__namedParameters` | `InjectedDependencies` |
#### Overrides
TransactionBaseService.constructor
#### Defined in
[packages/medusa/src/services/shipping-profile.ts:45](https://github.com/medusajs/medusa/blob/f7a63f178/packages/medusa/src/services/shipping-profile.ts#L45)
## Properties
### \_\_configModule\_\_
`Protected` `Optional` `Readonly` **\_\_configModule\_\_**: `Record`<`string`, `unknown`\>
#### Inherited from
TransactionBaseService.\_\_configModule\_\_
#### Defined in
[packages/medusa/src/interfaces/transaction-base-service.ts:10](https://github.com/medusajs/medusa/blob/f7a63f178/packages/medusa/src/interfaces/transaction-base-service.ts#L10)
___
### \_\_container\_\_
`Protected` `Readonly` **\_\_container\_\_**: `any`
#### Inherited from
TransactionBaseService.\_\_container\_\_
#### Defined in
[packages/medusa/src/interfaces/transaction-base-service.ts:9](https://github.com/medusajs/medusa/blob/f7a63f178/packages/medusa/src/interfaces/transaction-base-service.ts#L9)
___
### customShippingOptionService\_
`Protected` `Readonly` **customShippingOptionService\_**: [`CustomShippingOptionService`](CustomShippingOptionService.md)
#### Defined in
[packages/medusa/src/services/shipping-profile.ts:38](https://github.com/medusajs/medusa/blob/f7a63f178/packages/medusa/src/services/shipping-profile.ts#L38)
___
### manager\_
`Protected` **manager\_**: `EntityManager`
#### Overrides
TransactionBaseService.manager\_
#### Defined in
[packages/medusa/src/services/shipping-profile.ts:42](https://github.com/medusajs/medusa/blob/f7a63f178/packages/medusa/src/services/shipping-profile.ts#L42)
___
### productRepository\_
`Protected` `Readonly` **productRepository\_**: typeof `ProductRepository`
#### Defined in
[packages/medusa/src/services/shipping-profile.ts:40](https://github.com/medusajs/medusa/blob/f7a63f178/packages/medusa/src/services/shipping-profile.ts#L40)
___
### productService\_
`Protected` `Readonly` **productService\_**: [`ProductService`](ProductService.md)
#### Defined in
[packages/medusa/src/services/shipping-profile.ts:36](https://github.com/medusajs/medusa/blob/f7a63f178/packages/medusa/src/services/shipping-profile.ts#L36)
___
### shippingOptionService\_
`Protected` `Readonly` **shippingOptionService\_**: [`ShippingOptionService`](ShippingOptionService.md)
#### Defined in
[packages/medusa/src/services/shipping-profile.ts:37](https://github.com/medusajs/medusa/blob/f7a63f178/packages/medusa/src/services/shipping-profile.ts#L37)
___
### shippingProfileRepository\_
`Protected` `Readonly` **shippingProfileRepository\_**: typeof `ShippingProfileRepository`
#### Defined in
[packages/medusa/src/services/shipping-profile.ts:39](https://github.com/medusajs/medusa/blob/f7a63f178/packages/medusa/src/services/shipping-profile.ts#L39)
___
### transactionManager\_
`Protected` **transactionManager\_**: `undefined` \| `EntityManager`
#### Overrides
TransactionBaseService.transactionManager\_
#### Defined in
[packages/medusa/src/services/shipping-profile.ts:43](https://github.com/medusajs/medusa/blob/f7a63f178/packages/medusa/src/services/shipping-profile.ts#L43)
## Methods
### addProduct
**addProduct**(`profileId`, `productId`): `Promise`<`ShippingProfile`\>
Adds a product to a profile. The method is idempotent, so multiple calls
with the same product variant will have the same result.
#### Parameters
| Name | Type | Description |
| :------ | :------ | :------ |
| `profileId` | `string` | the profile to add the product to. |
| `productId` | `string` | the product to add. |
#### Returns
`Promise`<`ShippingProfile`\>
the result of update
#### Defined in
[packages/medusa/src/services/shipping-profile.ts:358](https://github.com/medusajs/medusa/blob/f7a63f178/packages/medusa/src/services/shipping-profile.ts#L358)
___
### addShippingOption
**addShippingOption**(`profileId`, `optionId`): `Promise`<`ShippingProfile`\>
Adds a shipping option to the profile. The shipping option can be used to
fulfill the products in the products field.
#### Parameters
| Name | Type | Description |
| :------ | :------ | :------ |
| `profileId` | `string` | the profile to apply the shipping option to |
| `optionId` | `string` | the option to add to the profile |
#### Returns
`Promise`<`ShippingProfile`\>
the result of the model update operation
#### Defined in
[packages/medusa/src/services/shipping-profile.ts:378](https://github.com/medusajs/medusa/blob/f7a63f178/packages/medusa/src/services/shipping-profile.ts#L378)
___
### atomicPhase\_
`Protected` **atomicPhase_**<`TResult`, `TError`\>(`work`, `isolationOrErrorHandler?`, `maybeErrorHandlerOrDontFail?`): `Promise`<`TResult`\>
Wraps some work within a transactional block. If the service already has
a transaction manager attached this will be reused, otherwise a new
transaction manager is created.
#### Type parameters
| Name |
| :------ |
| `TResult` |
| `TError` |
#### Parameters
| Name | Type | Description |
| :------ | :------ | :------ |
| `work` | (`transactionManager`: `EntityManager`) => `Promise`<`TResult`\> | the transactional work to be done |
| `isolationOrErrorHandler?` | `IsolationLevel` \| (`error`: `TError`) => `Promise`<`void` \| `TResult`\> | the isolation level to be used for the work. |
| `maybeErrorHandlerOrDontFail?` | (`error`: `TError`) => `Promise`<`void` \| `TResult`\> | Potential error handler |
#### Returns
`Promise`<`TResult`\>
the result of the transactional work
#### Inherited from
TransactionBaseService.atomicPhase\_
#### Defined in
[packages/medusa/src/interfaces/transaction-base-service.ts:50](https://github.com/medusajs/medusa/blob/f7a63f178/packages/medusa/src/interfaces/transaction-base-service.ts#L50)
___
### create
**create**(`profile`): `Promise`<`ShippingProfile`\>
Creates a new shipping profile.
#### Parameters
| Name | Type | Description |
| :------ | :------ | :------ |
| `profile` | `CreateShippingProfile` | the shipping profile to create from |
#### Returns
`Promise`<`ShippingProfile`\>
the result of the create operation
#### Defined in
[packages/medusa/src/services/shipping-profile.ts:247](https://github.com/medusajs/medusa/blob/f7a63f178/packages/medusa/src/services/shipping-profile.ts#L247)
___
### createDefault
**createDefault**(): `Promise`<`ShippingProfile`\>
Creates a default shipping profile, if this does not already exist.
#### Returns
`Promise`<`ShippingProfile`\>
the shipping profile
#### Defined in
[packages/medusa/src/services/shipping-profile.ts:177](https://github.com/medusajs/medusa/blob/f7a63f178/packages/medusa/src/services/shipping-profile.ts#L177)
___
### createGiftCardDefault
**createGiftCardDefault**(): `Promise`<`ShippingProfile`\>
Creates a default shipping profile, for gift cards if unless it already
exists.
#### Returns
`Promise`<`ShippingProfile`\>
the shipping profile
#### Defined in
[packages/medusa/src/services/shipping-profile.ts:221](https://github.com/medusajs/medusa/blob/f7a63f178/packages/medusa/src/services/shipping-profile.ts#L221)
___
### delete
**delete**(`profileId`): `Promise`<`void`\>
Deletes a profile with a given profile id.
#### Parameters
| Name | Type | Description |
| :------ | :------ | :------ |
| `profileId` | `string` | the id of the profile to delete. Must be castable as an ObjectId |
#### Returns
`Promise`<`void`\>
the result of the delete operation.
#### Defined in
[packages/medusa/src/services/shipping-profile.ts:332](https://github.com/medusajs/medusa/blob/f7a63f178/packages/medusa/src/services/shipping-profile.ts#L332)
___
### fetchCartOptions
**fetchCartOptions**(`cart`): `Promise`<`ShippingOption`[]\>
Finds all the shipping profiles that cover the products in a cart, and
validates all options that are available for the cart.
#### Parameters
| Name | Type | Description |
| :------ | :------ | :------ |
| `cart` | `any` | the cart object to find shipping options for |
#### Returns
`Promise`<`ShippingOption`[]\>
a list of the available shipping options
#### Defined in
[packages/medusa/src/services/shipping-profile.ts:398](https://github.com/medusajs/medusa/blob/f7a63f178/packages/medusa/src/services/shipping-profile.ts#L398)
___
### fetchOptionsByProductIds
**fetchOptionsByProductIds**(`productIds`, `filter`): `Promise`<`ShippingOption`[]\>
#### Parameters
| Name | Type |
| :------ | :------ |
| `productIds` | `string`[] |
| `filter` | `Selector`<`ShippingOption`\> |
#### Returns
`Promise`<`ShippingOption`[]\>
#### Defined in
[packages/medusa/src/services/shipping-profile.ts:87](https://github.com/medusajs/medusa/blob/f7a63f178/packages/medusa/src/services/shipping-profile.ts#L87)
___
### getProfilesInCart
`Protected` **getProfilesInCart**(`cart`): `string`[]
Returns a list of all the productIds in the cart.
#### Parameters
| Name | Type | Description |
| :------ | :------ | :------ |
| `cart` | `Cart` | the cart to extract products from |
#### Returns
`string`[]
a list of product ids
#### Defined in
[packages/medusa/src/services/shipping-profile.ts:468](https://github.com/medusajs/medusa/blob/f7a63f178/packages/medusa/src/services/shipping-profile.ts#L468)
___
### list
**list**(`selector?`, `config?`): `Promise`<`ShippingProfile`[]\>
#### Parameters
| Name | Type | Description |
| :------ | :------ | :------ |
| `selector` | `Selector`<`ShippingProfile`\> | the query object for find |
| `config` | `FindConfig`<`ShippingProfile`\> | the config object for find |
#### Returns
`Promise`<`ShippingProfile`[]\>
the result of the find operation
#### Defined in
[packages/medusa/src/services/shipping-profile.ts:75](https://github.com/medusajs/medusa/blob/f7a63f178/packages/medusa/src/services/shipping-profile.ts#L75)
___
### retrieve
**retrieve**(`profileId`, `options?`): `Promise`<`ShippingProfile`\>
Gets a profile by id.
Throws in case of DB Error and if profile was not found.
#### Parameters
| Name | Type | Description |
| :------ | :------ | :------ |
| `profileId` | `string` | the id of the profile to get. |
| `options` | `FindConfig`<`ShippingProfile`\> | options opf the query. |
#### Returns
`Promise`<`ShippingProfile`\>
the profile document.
#### Defined in
[packages/medusa/src/services/shipping-profile.ts:139](https://github.com/medusajs/medusa/blob/f7a63f178/packages/medusa/src/services/shipping-profile.ts#L139)
___
### retrieveDefault
**retrieveDefault**(): `Promise`<`undefined` \| `ShippingProfile`\>
#### Returns
`Promise`<`undefined` \| `ShippingProfile`\>
#### Defined in
[packages/medusa/src/services/shipping-profile.ts:161](https://github.com/medusajs/medusa/blob/f7a63f178/packages/medusa/src/services/shipping-profile.ts#L161)
___
### retrieveGiftCardDefault
**retrieveGiftCardDefault**(): `Promise`<`undefined` \| `ShippingProfile`\>
Retrieves the default gift card profile
#### Returns
`Promise`<`undefined` \| `ShippingProfile`\>
the shipping profile for gift cards
#### Defined in
[packages/medusa/src/services/shipping-profile.ts:204](https://github.com/medusajs/medusa/blob/f7a63f178/packages/medusa/src/services/shipping-profile.ts#L204)
___
### shouldRetryTransaction\_
`Protected` **shouldRetryTransaction_**(`err`): `boolean`
#### Parameters
| Name | Type |
| :------ | :------ |
| `err` | `Record`<`string`, `unknown`\> \| { `code`: `string` } |
#### Returns
`boolean`
#### Inherited from
TransactionBaseService.shouldRetryTransaction\_
#### Defined in
[packages/medusa/src/interfaces/transaction-base-service.ts:31](https://github.com/medusajs/medusa/blob/f7a63f178/packages/medusa/src/interfaces/transaction-base-service.ts#L31)
___
### update
**update**(`profileId`, `update`): `Promise`<`ShippingProfile`\>
Updates a profile. Metadata updates and product updates should use
dedicated methods, e.g. `setMetadata`, `addProduct`, etc. The function
will throw errors if metadata or product updates are attempted.
#### Parameters
| Name | Type | Description |
| :------ | :------ | :------ |
| `profileId` | `string` | the id of the profile. Must be a string that can be casted to an ObjectId |
| `update` | `UpdateShippingProfile` | an object with the update values. |
#### Returns
`Promise`<`ShippingProfile`\>
resolves to the update result.
#### Defined in
[packages/medusa/src/services/shipping-profile.ts:275](https://github.com/medusajs/medusa/blob/f7a63f178/packages/medusa/src/services/shipping-profile.ts#L275)
___
### withTransaction
**withTransaction**(`transactionManager?`): [`ShippingProfileService`](ShippingProfileService.md)
#### Parameters
| Name | Type |
| :------ | :------ |
| `transactionManager?` | `EntityManager` |
#### Returns
[`ShippingProfileService`](ShippingProfileService.md)
#### Inherited from
TransactionBaseService.withTransaction
#### Defined in
[packages/medusa/src/interfaces/transaction-base-service.ts:13](https://github.com/medusajs/medusa/blob/f7a63f178/packages/medusa/src/interfaces/transaction-base-service.ts#L13)