On the iOS and Android platforms, you can view BOM tables and change the view from flattened to structured.
Use the Onshape Bill of Materials (BOM) functionality to automatically create a BOM from any workspace Assembly. You can insert parts and assemblies into an Assembly post-release, from an Onshape version, or assemble the parts and sub-assemblies and then release the Assembly all at once. For more information on Release management, see Release Management.
Onshape BOMs include a default set of properties as columns, and you can add or remove columns at will. You can also define Custom Properties and include those in the BOM, as well as supply Display names for all Onshape-supplied properties through the Custom properties page of Company/Enterprise settings.
Your company or Enterprise administrator can create a default template to use for your Bill of Materials.
All Onshape Assemblies have a BOM table icon on the far right of the graphics area, below the View tools icon.
- In an Assembly, click the BOM table icon on the right edge of the graphics area.
- When the table opens, Onshape retrieves the data for the Assembly and populates the table (if there are parts or assemblies present, see the top example below). If no parts or assemblies are present, Onshape opens with default column names (properties) displayed (see the bottom example below):
- To populate an empty BOM, simply create your assembly in the Assembly tab, following the instructions in Insert Parts and Assemblies.
- In the BOM panel, select how to view the information (through the BOM type menu):
- Flattened - This view provides a simple list of parts by item number, with no indication of subassemblies.
Structured - This view provides a list of parts including indication of expandable subassemblies. Subassemblies are indicated with small right-facing caret; for example:
When viewing in Structured format, double-click the cell with the caret (the subassembly) to expand the list below the cell and see the parts included in the subassembly, labeled with the subassembly item number followed by a dot and then the part item number (9, 9.1, 9.2, and 9.3 in the example below):
The item numbers assigned to the subassemblies and parts reflect the order of the instances in the Instances list. If you reorder the instances in the list, the BOM table updates to reflect that new order.
Before, 002c-Oil Tank Nozzle is seventh in the Instances list and item number 7 in the BOM table:
After the part is moved to first place in the Instances list, it is updated to item number 1 in the BOM table:
Overridden computed properties (and properties that are aggregated from overridden computed properties) are indicated by an icon next to the property, with a tooltip upon hovering over the icon.
You can sort items in the BOM table alphanumerically by a column variable. Each column variable heading cell act as a three-way toggle, from (1) unsorted to (2) ascending sort order to (3) descending sort order. Double-click on the header to toggle from one sort state to the next.
Tips
- The Item column is fixed and cannot be sorted.
- Table data can only be sorted by one column at a time.
To locate items from your Instances list in your model, click the item name in the Instances list and the selected item is highlighted in the model. Concurrently, in the BOM table, the associated item row is highlighted and scrolls into focus. Alternately, click the item name in the BOM table, and the selected item is highlighted in the model and Instances list.
If you have automatic part numbering turned on in the Numbering schemes settings, in a BOM you can:
- Generate part numbers for a particular part - Right-click the Part number cell of the part and select Generate next part number.
- Generate part numbers for any parts in the table that are missing part numbers - Right-click the Part number column header and select Generate missing part numbers.
Right click on the BOM item's row and select:
-
Switch to Part Studio/Assembly - Displays when the BOM item is located in a tab in the current document. The BOM item's Part Studio or Assembly tab opens in the current browser tab.
-
Open linked document - Displays when the BOM item is located in a linked document outside the current document. The BOM item's linked document opens in a new browser tab.
You can specify whether a part or subassembly is excluded from all BOMs globally. When an excluded part is inserted into any Assembly, the part and all its corresponding data is excluded from the Assembly's BOM. When the excluded subassembly is inserted into any Assembly, the subassembly, all its instances, and all corresponding data is excluded from all BOMs globally.
Excluding a part or subassembly
Do one of the following:
-
To exclude one or more parts from all BOMs, in a Part Studio select the part(s) you want to exclude from the BOM in the Parts list, then right-click and select Properties. Check Exclude from all BOMs and click Save:
-
To exclude a subassembly and all its instances from all BOMs, right-click on the Assembly tab and select Properties. Check Exclude from all BOMs and click Save.
-
To exclude a part or subassembly from the BOM table, right-click on the part or subassembly row and select Exclude from all BOMs from the context menu:
Viewing excluded parts or subassemblies
To view globally excluded parts that are inserted into an Assembly on the BOM:
-
Click on the overflow menu () at the top right corner of the BOM table and select Show excluded:
-
Parts are viewed with dashes (--) under the Item column:
To view globally excluded subassemblies that are inserted into an Assembly, click Structured view from the BOM type dropdown. The subassembly item number is replaced with dashes (--):
Including parts or subassemblies
To include the Part or subassembly back into all BOMs, do one of the following:
-
Uncheck the Exclude from all BOMs box in the corresponding part Properties dialog or Assembly Properties dialog and click Save.
-
Ensure the excluded part or subassembly is viewable in the BOM table (see Viewing excluded parts or subassemblies). Then right-click on the part or subassembly row in the BOM table, and select Include in all BOMs from the context menu:
Calculating mass with excluded data
To calculate mass when some data has been excluded, click the Calculate value button in the Mass section of the Properties panel. An alert appears to indicate excluded instances have not been included in the mass calculation.
You can choose how to list a subassembly in a BOM, either as the assembly and its components, as the assembly only, or as the components only:
-
Open the Properties dialog for the Assembly (the tab or the subassembly listed in the Instances lists).
-
Scroll to the Subassembly BOM behavior field:
-
Select one of the options:
-
Show assembly and components - In a Structured view of the BOM, the assembly is listed along with individual line items for each of the assembly components.
-
Show assembly only - In a Structured view of the BOM, only the assembly is listed (no components).
-
Show components only - In a Structure view of the BOM, only the components are listed (no assembly line item).
-
-
Click Apply to register the change, or Save to register the change and close the dialog, or Close to close the dialog without registering the change.
The changes to the Assembly property affect all BOMs the assembly is inserted into, including BOMs in drawings.
Item number, Quantity, Part number and Description are the default properties displayed for parts and subassemblies as columns in the BOM table. You can add more columns according to the properties defined for your account.
-
Click the
Add column
drop down and select a property to insert from the list. Additional columns are inserted at the far right side of the table.
- The Category column cannot be added if the property is multivalued.
- Any Category that can be edited via the Properties dialog can also be edited via the BOM table if added as a column.
- For properties marked as editable (in your account Properties), you can click in the cell and add data. This data is saved for the specific part, in the specific property and is available throughout your document and company for that part.
For example, you can enter information in the Vendor cell for each part. That information is saved in that part's Properties, Vendor field.
The Vendor cell with a value in a BOM table:
The Properties dialog for the part:
When creating a property (through the Properties tab in your account settings), you can mark it Edit value in workspace, Edit value in version or both. If you mark it Edit value in version only, you can edit that value in a BOM table for any released parts since released parts become part of a version. However if Edit value in version is not marked, you would have to branch a workspace from that version, edit the values, then either create a version, or re-release the parts.
A Standard content instance cannot be edited from the BOM table, and is grayed out. To edit a standard content instance, right-click on the instance in the Instances list and select Edit standard content instance. See Editing the standard content instance for more information.
You can insert non-geometric items (items not modeled in CAD, like glue, tape, paint, thread locker, etc) into your bill of material, through the BOM panel in an Assembly tab. Onshape refers to these types of entities simply as items.
There is some setup required in order to have the information available for insertion into the bill of material. Refer to Managing Your Onshape Professional Subscription if you have a Professional subscription or to Managing Your Onshape Enterprise Subscription if you have an Enterprise subscription. Once you have items added to your subscription (in your company/enterprise settings Properties), you can follow these instructions to insert those items into a bill of material within an Assembly tab.
- In the Bill of Material panel, select the Insert items icon at the top of the panel:
- In the dialog:
- Select the item to include in the BOM, and the quantity. You can search the items and also filter by classification (click the down arrow next to Classification all).
- Click Insert to add the selected items to the BOM.
- When you click Insert, the item is added to the Items list in the Instances list first. You can click Undo to remove items, if you change your mind about an item.
- When you click the checkmark to accept your actions and close the dialog, the items appear in the BOM panel.
You can edit the items through the Instance list.
Right-click an item to:
- Edit - Change the quantity
- Suppress - Temporarily take the item out of the BOM (and assembly)
- Add comment - Add a comment to the assembly that directly references the item
- Delete - Delete the item from the assembly and the BOM
Once you have edited the Bill of Materials format, you can save that as a template and use it.
-
Click the three-dot menu in the upper right corner of the Bill of Materials table, and click Save as template...
-
The Create BOM template dialog opens. Provide a Name for the template. This is mandatory.
-
Select the BOM Type, either Flattened or Structured. This is used as the template default when a new BOM is created using this template.
-
Using the Property columns dropdown list, add the columns you require. The Item column is required and cannot be removed.
-
Check All uppercase in Drawings to enforce uppercase column headings and Property strings when inserting BOM tables using this template in Drawings.
-
Click Create to create the template. Click Cancel to close the dialog without creating the template.
New templates you create can be applied by clicking the Apply template dropdown at the top of the panel, and selecting a template from the list:
The selected template is used in your Assembly's BOM table.
You may also have templates in that list created by your Company/Classroom/Enterprise administrator.
Use the overflow menu's Export to CSV command to export the entire BOM table to a comma-separated file. If subassemblies are not expanded, the entire BOM will not be exported.
Resize the table in the following ways:
- Click and drag the left-most edge of the panel to resize the panel, larger or smaller. There are limits to how large and small you can make the panel.
- Resize rows by clicking and dragging the column header border to the left or right. Note that the first column is stationary for reference; it cannot be moved or resized.
- You can move any column to the right or left, or remove it from the table through the context-menu on the column name:
- To add a removed column back to the table, use the Add column drop down at the top right of the panel.
When using imported or released parts in an Assembly, the properties will display in the BOM table as read-only. To create a BOM with editable fields, you can branch from the version to create a new workspace. The fields in the BOM will be editable per the settings for each property (through the account settings).
When you insert released (revisioned) parts into the Assembly and then create the BOM table, the state property will be Released.
You can insert Onshape BOM tables into your drawings. See the Insert BOM topic.