Worksharing |
The WorksharingUtils type exposes the following members.
Name | Description | |
---|---|---|
![]() | IsValidObject | Specifies whether the .NET object represents a valid Revit entity. |
Name | Description | |
---|---|---|
![]() ![]() ![]() | CheckoutElements(Document, ICollectionElementId) | Obtains ownership for the current user of as many specified elements as possible. |
![]() ![]() | CheckoutElements(Document, ISetElementId, TransactWithCentralOptions) | Obtains ownership for the current user of as many specified elements as possible. |
![]() ![]() ![]() | CheckoutWorksets(Document, ICollectionWorksetId) | Obtains ownership for the current user of as many specified worksets as possible. |
![]() ![]() | CheckoutWorksets(Document, ISetWorksetId, TransactWithCentralOptions) | Obtains ownership for the current user of as many specified worksets as possible. |
![]() ![]() | CreateNewLocal | Takes a path to a central model and copies the model into a new local file for the current user. |
![]() | Dispose | Releases all resources used by the WorksharingUtils |
![]() | Equals | Determines whether the specified object is equal to the current object. (Inherited from Object) |
![]() ![]() | GetCheckoutStatus(Document, ElementId) | Gets the ownership status of an element. |
![]() ![]() | GetCheckoutStatus(Document, ElementId, String) | Gets the ownership status and outputs the owner of an element. |
![]() | GetHashCode | Serves as the default hash function. (Inherited from Object) |
![]() ![]() ![]() | GetModelUpdatesStatus | Gets the status of a single element in the central model. |
![]() | GetType | Gets the Type of the current instance. (Inherited from Object) |
![]() ![]() | GetUserWorksetInfo | Gets information about user worksets in a workshared model file, without fully opening the file. |
![]() ![]() | GetWorksharingTooltipInfo | Gets worksharing information about an element to display in an in-canvas tooltip. |
![]() ![]() | RelinquishOwnership | Relinquishes ownership by the current user of as many specified elements and worksets as possible, and grants element ownership requested by other users on a first-come, first-served basis. |
![]() | ToString | Returns a string that represents the current object. (Inherited from Object) |
Return values from inquiries about the worksharing status of elements or worksets rely on local caching of information from the central model so it is possible that the information is out of date. Because of this, the return value is suitable for reporting to an interactive user (e.g. via a mechanism similar to Worksharing display mode), but cannot be considered a reliable indication of whether the element can be immediately edited by the application. To make an immediate attempt to edit elements, use [!:CheckoutElements()] and check the return status, then confirm if the elements are up to date.
In addition, information about the current user may not be reliable while Revit is in the middle of an editing transaction. For example, if you move an unowned wall from an unowned workset to a workset you own, then before you explicitly or Revit automatically checks out the wall for you, GetCheckoutStatus() might erroneously tell you CheckoutStatus.OwnedByCurrentUser because although the official (as seen in central and by other users) owner is no one, locally it looks like you already own it since it belongs to a workset you own.
For operations that interact with central (as opposed to use only cached values), Revit might opportunistically refresh some editing permissions or check the status of editing requests.
Some useful definitions to keep in mind follow:
public void GetElementWorksharingInfo(Document doc, Element elem) { String message = String.Empty; message += "Element Id: " + elem.Id; // The workset the element belongs to WorksetId worksetId = elem.WorksetId; message += ("\nWorkset Id : " + worksetId.ToString()); // Model Updates Status of the element ModelUpdatesStatus updateStatus = WorksharingUtils.GetModelUpdatesStatus(doc, elem.Id); message += ("\nUpdate status : " + updateStatus.ToString()); // Checkout Status of the element CheckoutStatus checkoutStatus = WorksharingUtils.GetCheckoutStatus(doc, elem.Id); message += ("\nCheckout status : " + checkoutStatus.ToString()); // Getting WorksharingTooltipInfo of a given element Id WorksharingTooltipInfo tooltipInfo = WorksharingUtils.GetWorksharingTooltipInfo(doc, elem.Id); message += ("\nCreator : " + tooltipInfo.Creator); message += ("\nCurrent Owner : " + tooltipInfo.Owner); message += ("\nLast Changed by : " + tooltipInfo.LastChangedBy); Autodesk.Revit.UI.TaskDialog.Show("GetElementWorksharingInfo", message); }