189 lines
4.9 KiB
Markdown
189 lines
4.9 KiB
Markdown
![]() |
---
|
||
|
title: plugin-cutlist
|
||
|
---
|
||
|
|
||
|
Published as [@freesewing/plugin-cutlist][1], this plugin provides additional methods to the [part draft function](/reference/api/part/draft) which allow you to configure cutting instructions for your parts.
|
||
|
|
||
|
<Tip> For an in-depth look at how to add cutting instructions to your part, see our [cutlist how-to](/howtos/design/cutlist) </Tip>
|
||
|
|
||
|
## Installation
|
||
|
|
||
|
```sh
|
||
|
npm install @freesewing/plugin-cutonfold
|
||
|
```
|
||
|
|
||
|
## Usage
|
||
|
|
||
|
Either [add it as a part plugin](/reference/api/part/config/plugins) in your
|
||
|
design, or [add it to a pattern instance with
|
||
|
Pattern.use()](/reference/api/pattern/use).
|
||
|
|
||
|
To import the plugin for use:
|
||
|
```js
|
||
|
import { cutlistPlugin } from '@freesewing/plugin-cutlist'
|
||
|
// or
|
||
|
import { pluginCutlist } from '@freesewing/plugin-cutlist'
|
||
|
```
|
||
|
|
||
|
## Methods
|
||
|
|
||
|
The cutlist plugin adds the following methods to the part draft method parameter
|
||
|
|
||
|
### addCut
|
||
|
|
||
|
The `addCut()` method will add a set of cutting instructions for the part
|
||
|
|
||
|
#### Signature
|
||
|
```js
|
||
|
addCut(Object so)
|
||
|
````
|
||
|
|
||
|
Pass an object to the `addCut` method with any of the following keys; any you don't provide will be filled with the defaults:
|
||
|
|
||
|
| Key | Type | Default | Description |
|
||
|
| :-- | :--- | :------ | :---------- |
|
||
|
| cut | Number\|false | 2 | the number of pieces to cut from the specified material. Pass `false` to clear all cutting instructions for the material |
|
||
|
| material | String | 'fabric' | the translation key of the material to cut from |
|
||
|
| identical | Boolean | false | should even numbers of pieces be cut in the same direction? false for mirrored |
|
||
|
| bias | Boolean | false | should the pieces in these cutting instructions be cut on the bias |
|
||
|
| ignoreOnFold | Boolean | false | should these cutting instructions ignore any cutOnFold information set by the part |
|
||
|
|
||
|
<Note>
|
||
|
<details>
|
||
|
<summary> You can use any `string` you want for your material, but here are some standard ones we have translation for </summary>
|
||
|
<div>
|
||
|
|
||
|
| Key | Translation |
|
||
|
|:--|:--|
|
||
|
| fabric | Main Fabric |
|
||
|
| lining | Lining |
|
||
|
| canvas | Canvas |
|
||
|
| lmhCanavas | Light to Medium Hair Canvas |
|
||
|
| heavyCanvas | Heavyweight Hair Canvas |
|
||
|
| interfacing | Interfacing |
|
||
|
| plastic | Plastic |
|
||
|
| ribbing | Ribbing |
|
||
|
|
||
|
</div>
|
||
|
</details>
|
||
|
</Note>
|
||
|
|
||
|
#### Example
|
||
|
|
||
|
```js
|
||
|
import {pluginCutlist} from '@freesewing/plugin-cutlist'
|
||
|
|
||
|
const part = {
|
||
|
name: 'example.front',
|
||
|
plugins: [pluginCutlist],
|
||
|
draft: ({part, addCut}) => {
|
||
|
// add instructions to cut two from main fabric
|
||
|
addCut()
|
||
|
// add instructions to cut four on the biad from lining
|
||
|
addCut({cut: 4, material: 'lining', bias: true, })
|
||
|
return part
|
||
|
}
|
||
|
}
|
||
|
```
|
||
|
|
||
|
You can also add multiple sets of cutting instructions for the same material
|
||
|
```js
|
||
|
import {pluginCutlist} from '@freesewing/plugin-cutlist'
|
||
|
|
||
|
const part = {
|
||
|
name: 'example.front',
|
||
|
plugins: [pluginCutlist],
|
||
|
draft: ({part, addCut}) => {
|
||
|
// add instructions to 1 from lining
|
||
|
addCut({cut: 1, material: 'lining'})
|
||
|
// add instructions to cut 1 on the bias from lining
|
||
|
addCut({cut: 1, material: 'lining', bias: true, })
|
||
|
return part
|
||
|
}
|
||
|
}
|
||
|
```
|
||
|
|
||
|
### removeCut
|
||
|
|
||
|
The `removeCut()` method will remove cutting instructions from the part
|
||
|
|
||
|
#### Signature
|
||
|
|
||
|
```js
|
||
|
removeCut(String material)
|
||
|
```
|
||
|
|
||
|
#### Example
|
||
|
```js
|
||
|
import {pluginCutlist} from '@freesewing/plugin-cutlist'
|
||
|
|
||
|
const part = {
|
||
|
name: 'example.front',
|
||
|
plugins: [pluginCutlist],
|
||
|
draft: ({part, removeCut}) => {
|
||
|
// remove all cutting instructions for all materials
|
||
|
removeCut()
|
||
|
|
||
|
// remove cutting instructions for just one material
|
||
|
removeCut('fabric')
|
||
|
return part
|
||
|
}
|
||
|
}
|
||
|
```
|
||
|
### setGrain
|
||
|
|
||
|
The `setGrain()` method will record the angle of the grainline annotation. This method is called internally by [`plugin-grainline`](/reference/plugins/grainline) to store information for cutting layout tools. You shouldn't have to call it, but it's there if you need it.
|
||
|
|
||
|
#### Signature
|
||
|
|
||
|
```js
|
||
|
setGrain(Number grainAngle)
|
||
|
```
|
||
|
|
||
|
#### Example
|
||
|
```js
|
||
|
import {pluginCutlist} from '@freesewing/plugin-cutlist'
|
||
|
|
||
|
const part = {
|
||
|
name: 'example.front',
|
||
|
plugins: [pluginCutlist],
|
||
|
draft: ({part, setGrain}) => {
|
||
|
// set the grainline angle
|
||
|
setGrain(0)
|
||
|
return part
|
||
|
}
|
||
|
}
|
||
|
```
|
||
|
|
||
|
### setCutOnFold
|
||
|
The `setCutOnFold()` method will record the points that make up the cut on fold line. This method is called internally by [`plugin-cutonfold`](/reference/plugins/cutonfold) to store information for cutting layout tools. You shouldn't have to call it, but it's there if you need it.
|
||
|
|
||
|
#### Signature
|
||
|
|
||
|
```js
|
||
|
setCutOnFold(Point p1, Point p2)
|
||
|
```
|
||
|
|
||
|
#### Example
|
||
|
```js
|
||
|
import {pluginCutlist} from '@freesewing/plugin-cutlist'
|
||
|
|
||
|
const part = {
|
||
|
name: 'example.front',
|
||
|
plugins: [pluginCutlist],
|
||
|
draft: ({part, points, Point, setCutOnFold}) => {
|
||
|
// set the cut on fold line
|
||
|
points.p1 = new Point(0, 0)
|
||
|
points.p2 = new Point(0, 10)
|
||
|
setCutOnFold(points.p1, points.p2)
|
||
|
return part
|
||
|
}
|
||
|
}
|
||
|
```
|
||
|
|
||
|
## Notes
|
||
|
|
||
|
The cutlist plugin is part of our [plugin-bundle](/reference/plugins/bundle)
|
||
|
|
||
|
[1]: https://www.npmjs.com/package/@freesewing/plugin-cutlist
|