Task
A time entry [Task
] is a time slot worked by an employee on a work package.
Review the Usage Guidelines for the Task
object.
— |
XML |
SOAP |
REST |
Database table |
---|---|---|---|---|
Object |
|
|
|
|
Supported Commands |
See Time Entries |
— |
The Task
object has the following standard properties:
Task
object properties may also include custom fields. The object type supports the custom equal to
read method and the enable_custom
read attribute.
XML / SOAP |
REST |
Database |
Description |
---|---|---|---|
|
|
|
The accounting period date of the time entry. See Date Fields |
|
|
|
The internal ID of the associated service (category). |
|
|
|
The internal ID of the associated service line |
|
|
|
The internal ID of the associated cost center. |
|
|
|
[Read-only] The date the time entry was created. See Date Fields |
|
|
|
The internal ID of the associated customer. Determined automatically from |
|
|
|
[Required] The date of the time entry. See Date Fields |
|
|
— |
The number of decimal hours for the time entry. If the Use Days Instead of Hours for All Time Entries feature is not enabled for your account:
See also Usage Guidelines. |
|
|
|
The description of the time entry. |
|
|
|
The time entry end time. |
— |
|
|
Date and time the time entry was marked as "exported". |
|
|
|
The number of hours for the time entry. If the Use Days Instead of Hours for All Time Entries feature is not enabled for your account:
See also Usage Guidelines. |
— |
|
— |
The number of hours remaining of the associated project task. |
|
|
|
[Read-only] The unique internal identifier of the time entry . Assigned by SuiteProjects Pro. |
|
|
|
The internal ID of the associated job code. |
|
— |
|
The loaded cost for the associated resource, using the forex future rate from the exchange rate table. |
|
— |
|
User's second level loaded cost, using the forex future rate from the exchange rate table. |
|
— |
|
User's third level loaded cost, using the forex future rate from the exchange rate table. |
|
|
|
The number of minutes for the time entry.
Important:
|
|
|
|
Notes about the time entry. |
|
|
|
The internal ID of the associated payroll type. |
|
— |
|
User's project cost override in project currency. Uses the future rate from the exchange rate table. |
|
— |
|
User's project second cost in project currency. Uses the future rate from the exchange rate table. |
|
— |
|
User's project third cost in project currency. Uses the future rate from the exchange rate table. |
|
|
|
The internal ID of the associated project. |
|
|
|
The internal ID of the project task type of the associated project task. |
|
|
|
The internal ID of the task within the associated project. |
— |
|
|
The internal ID of the schedule change item from a schedule request. |
|
|
|
The internal ID of the associated slip if this task was billed. |
|
|
|
The time entry start time. |
|
|
|
Used by thin clients to reconcile imported records. |
|
|
|
The internal ID of the associated timesheet. Set automatically to the internal ID matching the time entry |
|
|
|
The internal ID of the associated time type. |
|
|
|
[Read-only] The date the time entry was last updated or modified. |
|
|
|
[Required] The internal ID of the associated employee. The user must exist, must not be marked as deleted, must be active and must not be a generic user. |
Usage Guidelines
Review the following guidelines:
-
The Require a task on time entries setting for the Timesheets application (Administration > Application Settings > Timesheets > Other settings) is not supported. The API lets you add or modify time entries without an associated projecttask (
projecttaskid
) even if a task is required on time entries in the SuiteProjects Pro UI. -
If a
projecttaskid
is specified and time entry is restricted to the date range covered by that project task, the API returns an error (error code 888) if the time entrydate
is outside the project task date range. -
By default, the loaded cost [
loaded_cost
] and project loaded cost override [project_loaded_cost
] in the time entry [Task
] object use the future currency exchange rate from the foreign exchange conversion table [forex
]. To force these values to use the exchange rate at the date of the time entry instead of the future exchange rate, contact SuiteProjects Pro Support and request the following account configuration setting to be enabled: API to Respect Time Entry Date for Currency Conversion in Loaded Costs. -
You cannot modify a time entry if the authenticated user cannot modify the associated timesheet, or if the Signers feature is enabled and the time entry has been accepted (signed off).
-
You can enter decimal values for the number of hours [
hours
] if the Use Days Instead of Hours for All Time Entries feature is not enabled for your account. See Decimal time entry (hours). -
You can read and modify the start time [
start_time
] and end time [end_time
] for time entries using the XML API or SOAP API. To modifystart_time
and [end_time
], start and end time entry on timesheets must be enabled for your account. See Modifying the Time Entry Start and End Times.Important:You should not use Enable start and end time entry on timesheets and Use Days Instead of Hours for All Time Entries in conjunction.
When Enable start and end time entry on timesheets is enabled and a user enters a start time and end time in SuiteProjects Pro, the duration is calculated in hours and not converted to days.
If both features are enabled, the API returns an error (error code 1407) if you set both
decimal_hours
andminutes
but nothours
in the request.
Modifying the Time Entry Start and End Times
You can read and modify the start time [start_time
] and end time [end_time
] for time entries using the XML API or SOAP API.
Review the following requirements to modify start_time
and end_time
:
-
Start and end time entry on timesheets must be enabled. The Enable start and end time entry on timesheets box must be checked on the Administration > Application Settings > Timesheets > Other settings form. The API returns an error (error code: 1406) if you attempt to edit the start or end times and the functionality is not enabled.
-
The format for
start_time
andend_time
must behh:mm:ss
. The API returns an error (error code: 1404) if either properties are set to an invalid value or a value with the wrong format.The following examples are valid values:
10:30:15
,2:30
(equivalent to02:30:00)
),2:30:15
(equivalent to02:30:15)
),2:3
(equivalent to02:03:00)
),2:3:4
(equivalent to02:03:04)
). -
The
start_time
value must be before theend_time
value. The API returns an error (error code: 1405) if an invalid time range is passed. -
When setting
start_time
andend_time
, you must also set the duration using eitherdecimal_hours
orhours
andminutes
.Note:The duration is not calculated when you set
start_time
andend_time
. However, the duration is validated. The API returns an error (error code: 1407) if the duration does not match the period betweenstart_time
andend_time
. -
To clear the
start_time
orend_time
, set it to00:00:00
. Setting bothstart_time
andend_time
to00:00:00
setsdecimal_hours
,hours
andminutes
to0
automatically.
Decimal time entry (hours)
Decimal time entry for the number of hours is supported if the feature Use Days Instead of Hours for All Time Entries is disabled for your account:
-
hours
accepts decimal part and the decimal part is converted to minutes. For example, iftask.hours = “5.5”;
is equivalent totask.hours = “5”; task.minutes = “30”;
. -
Minutes passed as the decimal part of
hours
andminutes
are added. For example,task.hours = “5.5”; task.minutes = “6”;
is equivalent totask.hours = “5”; task.minutes = “36”;
. -
decimal_hours
accepts decimal part and the decimal part is converted to minutes. For example,task.decimal_hours = “5.5”;
is equivalent totask.hours = “5”; task.minutes = “30”;
. -
Minutes passed as the decimal part of
decimal_hours
are ignored ifminutes
is also passed. For example,task.decimal_hours = “5.5”; task.minutes = “6”;
is equivalent totask.hours = “5”; task.minutes = “36”;
. -
If both
decimal_hours
andhours
are passed, the integer part ofdecimal_hours
is ignored and only the integer part ofhours
is used. However, the decimal parts ofdecimal_hours
andhours
are added. For example,task.decimal_hours = “5.5”; task.hours = “2.1”;
is equivalent totask.hours = “2”; task.minutes = “36”;
. -
If
decimal_hours
,hours
andminutes
are passed, both the decimal and integer parts ofdecimal_hours
are ignored. Minutes passed as the decimal part ofhours
andminutes
are added. For example,task.decimal_hours = “5.5”; task.hours = “2.1”; task.minutes = “20”;
is equivalent totask.hours = “2”; task.minutes = “26”;
.