Integration with personal Toggl timer
Toggl Button is a Chrome browser extension that lets you track time from various online apps. Fortunately, Targetprocess is among them!
data:image/s3,"s3://crabby-images/b5ce5/b5ce5a5432ab7771661d82f327ff26ab4f8ab9a2" alt="toggl-button.png 1498"
Integration with Toggl consists of two parts:
- Installing the Toggl plugin to the web browser. As a result special start / stop timer button appears in detailed views of your Targetprocess entities. Recorded time is posted to your Toggl account.
- Set up a Zapier zap to post time submitted to Toggl to Targetprocess automatically.
Sign up with Zapier is required
You will need to sign up with Zapier service to use this integration. The setup includes 3 steps on Zapier side, therefore For Work pricing plan is required.
The guide describes setup for a single user. You should create separate Zap in your Zapier account and repeat steps 1...4 for each Targetprocess user who submits time via Toggl.
Step 1: Install the Toggl button
Install the Toggl button using the Chrome web store.
Detailed instructions are available at support.toggl.com.
Allow access to your Targetprocess account under the Permissions tab. Add Custom Domain Url Permission for your Targetprocess domain.
data:image/s3,"s3://crabby-images/91618/91618a9936c3d6cf7ef5e63997f4eba479f96fe9" alt="1.png 987"
Afterwards log in into Toggl account in your Chrome web browser. Login button is shown in the menu of Chrome extensions.
Once completed, the Toggl button appears next to the Entity name in Targetprocess:
data:image/s3,"s3://crabby-images/40b41/40b41c7861849b9ffcdef5138a03b755194c9449" alt="image8.png 1498"
Press the button once - and it starts the Timer. Press it again - and the timer stops, sending the time record to your Toggl account.
Now we're ready to forward time records from Toggl to Targetprocess using Zapier!
Step 2: Set up Toggl Trigger in Zapier
Log in to your Zapier account.
Create new Zap. Select Toggl as a Trigger App:
data:image/s3,"s3://crabby-images/0f865/0f8659e98881fc0bf21a6eed81ee832c6f933305" alt="toggl-trigger-toggl.png 1165"
Select "New Time Entry" for the Toggl trigger:
data:image/s3,"s3://crabby-images/99bcb/99bcb15741d24c76f29203acabe1a4aa71f1b3bf" alt="toggl-trigger-new-time.png 1169"
Connect your Toggl account to Toggl trigger. Create a New account in Zapier if details of your Toggl account are not there yet.
data:image/s3,"s3://crabby-images/8fbbb/8fbbb9d3288521945a1af6fe63e81fd23e557e1f" alt="toggl-connect.png 1171"
Grab your Toggl API token from Toggl account details > "My Profile" section. Connect your Toggl account to Toggl trigger in Zapier using the token.
data:image/s3,"s3://crabby-images/7ff68/7ff681fcebb0c37aad40f168059668048c0954cf" alt="toggl-token.png 474"
Test connection.
data:image/s3,"s3://crabby-images/3a668/3a6686bf4f667e97418e59072c5db7f2645a2a01" alt="toggl-trigger-account-test.png 1165"
To test the whole step please submit a new time entry in Toggl and then perform a test in Zapier.
data:image/s3,"s3://crabby-images/263e6/263e664101837edd05f25f2206251def755b7c12" alt="toggl-test.png 1170"
Step 3 (optional) setup 'Filter by' in Zapier.
If you use toggl outside of Target Process, then Zapier will receive an error every time a non target process related time entry is created, a quick way to reduce these errors is to add a "Filter By" step in Zapier which prevents the Zap from continuing unless the Toggl entry 'Description' starts with '#' (see image below).
Step 4: Pull Entity ID and Time Remain using Code Action
Add new Action. Select "Code by Zapier" as an Action App:
data:image/s3,"s3://crabby-images/28a03/28a036139c3aa6b4c2ae2d45c1ee7eb09ee5335c" alt="image5.png 1744"
Choose Run Javascript
for the "Code by Zapier" action
Edit Template:
data:image/s3,"s3://crabby-images/242fb/242fbb721539ce14005f7e728082f7a2487e3fb9" alt="js-template.png 1170"
Edit the Input data as shown in the screenshot below:
description | Step 1 Description |
spent | Step 1 Duration Hours |
data:image/s3,"s3://crabby-images/765ac/765ac39462aeb03195d7ee11baf51ed4b3023822" alt="input-data.png 760"
Copy and paste the following Code. Replace accountUrl
and access_token
values with your personal ones.
Access Token is generated under My Profile > Access Tokens tab in your Targetprocess account.
var match = input.description.match(/[\w\s]*#(\d+)\s(.*)/i);
var id = match ? match[1] : 0;
var accountUrl = 'https://myaccount.tpondemand.com';
var access_token = 'MjkwMDI6c1RHczJaUWsrRWpKZkpEUWlNeXFibjdkajM2M3ppY2ZIaWhIS0owUEVDMD9=';
var url = accountUrl + '/api/v1/assignables/' + id + '?access_token=' + access_token + '&include=[TimeRemain,RoleEfforts]&format=json';
fetch(url)
.then(function(res) {
return res.json();
})
.then(function(json) {
var newRemain = 0;
var roleEffortsCount = Object.keys(json.RoleEfforts.Items).length;
if (roleEffortsCount == 1) {
newRemain = json.TimeRemain - input.spent;
if (newRemain < 0) {
newRemain = 0;
}
}
var output = { id: id, remain: newRemain };
callback(null, output);
})
.catch(callback);
return { id: id, remain : 0 };
Test this step.
data:image/s3,"s3://crabby-images/1ac6c/1ac6c3fde3bbf5bb6813aee0847e649361dd940d" alt="js-test.png 1170"
Step 5: Post time record to Targetprocess
Add one more Action 'Webhook by Zapier' with POST option:
data:image/s3,"s3://crabby-images/39e0a/39e0a38f6450387922d896639ca4b2df29d553e1" alt="webhooks-app.png 1171"
Select Webhooks by Zapier Action: POST
data:image/s3,"s3://crabby-images/c07ae/c07ae10dccf9f5d4bedc530aef6cbd77fc074666" alt="webhooks-post.png 1174"
Edit Template:
data:image/s3,"s3://crabby-images/34430/3443015c1a7e2f98c468a669d2a45a804f2f9b86" alt="wh-template.png 1195"
Use a template like the one below.
URL | https://myaccount.tpondemand.com/api/v1/times?access_token=MjkwMDI6c1RHczJaUWsrRWpKZkpEUWlNeXFibjdkajM2M4ppY2ZIaWhIS0owUEVDMD9= | Replace account URL and access token with your own values. |
Payload Type | Json | |
Wrap Request In Array | no | |
Unflatten | yes |
data:image/s3,"s3://crabby-images/68dcc/68dcc14118214961292fbf8eadda63a78faa6432" alt="action-url-payload.png 760"
Data:
Assignable__Id | Step 2 Id | Two underscore symbols are used. |
User__Id | 1234 | Two underscore symbols are used. Paste your Targetprocess User ID here. |
Spent | Step 1 Duration Hours | |
Remain | Step 2 Remain | |
Description | Time submitted via Toggl | Any text can be inserted here. |
To retrieve your Targetprocess User ID please make the following REST API call to Targetprocess application in your web browser:
GET /api/v1/Users/LoggedUser?include=[Id]&format=json
Example of valid output:
{"ResourceType":"User","Kind":"User","Id":1234}
data:image/s3,"s3://crabby-images/1fc59/1fc59ed632f93b2e074053859824519d95dca118" alt="action-data.png 748"
Headers:
Content-type | application/json |
Test this step.
data:image/s3,"s3://crabby-images/68e9f/68e9f3bc268df1395a2d935fa0170418e22a1900" alt="wh-test.png 1196"
Turn on this Zap and enjoy automatic time posting!
data:image/s3,"s3://crabby-images/bd4a4/bd4a423d451a3d42b0e0569cf467e52d8b3c7cf6" alt="zap-on.png 396"
Here is how Task History of Zap looks like in Zapier:
data:image/s3,"s3://crabby-images/47a0c/47a0c20875cb08cf151ed0b3de2ce9e7a44cccef" alt="zapier-task-history.png 1097"
Here is how automatically submitted Time entities are displayed in Targetprocess entity details view:
data:image/s3,"s3://crabby-images/05e9a/05e9a114fc49875c6b29d186e27815499f75f087" alt="targetprocess-time.png 949"
Time Remain value is updated automatically when the entity you submit time to has only one Role with Effort in Assignments area. Otherwise in automatically posted Times Remain value is set to 0.
Updated almost 5 years ago