Implementing commute search in your UI

You can integrate commute search into your UI to allow job seekers to search for jobs within a geographic area set by commute time. Commute search estimates commute time based on a user's selected transit mode and the time of day they plan to travel.

  1. Before you can implement commute search, Cloud Talent Solution must be hooked up to your UI. Follow the quickstart guides to set up Cloud Talent Solution.

  2. Commute search uses the address data that you uploaded with your jobs during CTS implementation to calculate commute time. To enable this feature in your existing CTS UI, send a jobs.search request and include a CommuteFilter object in the JobQuery.commuteFilter field. commuteMethod , travelDuration , startCoordinates , and either roadTraffic or departureTime are required fields.

Go

To learn how to install and use the client library for CTS, see CTS client libraries . For more information, see the CTS Go API reference documentation .

To authenticate to CTS, set up Application Default Credentials. For more information, see Set up authentication for a local development environment .

  import 
  
 ( 
  
 "context" 
  
 "fmt" 
  
 "io" 
  
 talent 
  
 "cloud.google.com/go/talent/apiv4beta1" 
  
 "cloud.google.com/go/talent/apiv4beta1/talentpb" 
  
 "github.com/golang/protobuf/ptypes/duration" 
  
 "google.golang.org/genproto/googleapis/type/latlng" 
 ) 
 // commuteSearch searches for jobs within commute filter. 
 func 
  
 commuteSearch 
 ( 
 w 
  
 io 
 . 
 Writer 
 , 
  
 projectID 
 , 
  
 companyID 
  
 string 
 ) 
  
 error 
  
 { 
  
 ctx 
  
 := 
  
 context 
 . 
 Background 
 () 
  
 // Initialize a jobService client. 
  
 c 
 , 
  
 err 
  
 := 
  
 talent 
 . 
  NewJobClient 
 
 ( 
 ctx 
 ) 
  
 if 
  
 err 
  
 != 
  
 nil 
  
 { 
  
 return 
  
 fmt 
 . 
 Errorf 
 ( 
 "talent.NewJobClient: %w" 
 , 
  
 err 
 ) 
  
 } 
  
 defer 
  
 c 
 . 
 Close 
 () 
  
 // Construct a jobQuery request with a commute filter. 
  
 jobQuery 
  
 := 
  
& talentpb 
 . 
 JobQuery 
 { 
  
 CommuteFilter 
 : 
  
& talentpb 
 . 
 CommuteFilter 
 { 
  
 CommuteMethod 
 : 
  
 talentpb 
 . 
  CommuteMethod_TRANSIT 
 
 , 
  
 TravelDuration 
 : 
  
& duration 
 . 
 Duration 
 { 
 Seconds 
 : 
  
 1800 
 }, 
  
 StartCoordinates 
 : 
  
& latlng 
 . 
 LatLng 
 { 
  
 Latitude 
 : 
  
 37.422408 
 , 
  
 Longitude 
 : 
  
 - 
 122.085609 
 , 
  
 }, 
  
 }, 
  
 } 
  
 if 
  
 companyID 
  
 != 
  
 "" 
  
 { 
  
 jobQuery 
 . 
 Companies 
  
 = 
  
 [] 
 string 
 { 
 fmt 
 . 
 Sprintf 
 ( 
 "projects/%s/companies/%s" 
 , 
  
 projectID 
 , 
  
 companyID 
 )} 
  
 } 
  
 // Construct a searchJobs request with a jobQuery. 
  
 req 
  
 := 
  
& talentpb 
 . 
 SearchJobsRequest 
 { 
  
 Parent 
 : 
  
 fmt 
 . 
 Sprintf 
 ( 
 "projects/%s" 
 , 
  
 projectID 
 ), 
  
 // Make sure to set the RequestMetadata the same as the associated 
  
 // search request. 
  
 RequestMetadata 
 : 
  
& talentpb 
 . 
 RequestMetadata 
 { 
  
 // Make sure to hash your userID. 
  
 UserId 
 : 
  
 "HashedUsrID" 
 , 
  
 // Make sure to hash the sessionID. 
  
 SessionId 
 : 
  
 "HashedSessionID" 
 , 
  
 // Domain of the website where the search is conducted. 
  
 Domain 
 : 
  
 "www.googlesample.com" 
 , 
  
 }, 
  
 // Set the actual search term as defined in the jobQuery. 
  
 JobQuery 
 : 
  
 jobQuery 
 , 
  
 } 
  
 resp 
 , 
  
 err 
  
 := 
  
 c 
 . 
 SearchJobs 
 ( 
 ctx 
 , 
  
 req 
 ) 
  
 if 
  
 err 
  
 != 
  
 nil 
  
 { 
  
 return 
  
 fmt 
 . 
 Errorf 
 ( 
 "SearchJobs: %w" 
 , 
  
 err 
 ) 
  
 } 
  
 for 
  
 _ 
 , 
  
 job 
  
 := 
  
 range 
  
 resp 
 . 
 GetMatchingJobs 
 () 
  
 { 
  
 fmt 
 . 
 Fprintf 
 ( 
 w 
 , 
  
 "Matcing Job: %q\n" 
 , 
  
 job 
 . 
 GetJob 
 (). 
 GetName 
 ()) 
  
 fmt 
 . 
 Fprintf 
 ( 
 w 
 , 
  
 "Job address: %v\n" 
 , 
  
 job 
 . 
 GetCommuteInfo 
 (). 
 GetJobLocation 
 (). 
 GetPostalAddress 
 (). 
 GetAddressLines 
 ()) 
  
 } 
  
 return 
  
 nil 
 } 
 

Java

To learn how to install and use the client library for CTS, see CTS client libraries . For more information, see the CTS Java API reference documentation .

To authenticate to CTS, set up Application Default Credentials. For more information, see Set up authentication for a local development environment .

  import 
  
 com.google.cloud.talent.v4. CommuteFilter 
 
 ; 
 import 
  
 com.google.cloud.talent.v4. CommuteMethod 
 
 ; 
 import 
  
 com.google.cloud.talent.v4. Job 
 
 ; 
 import 
  
 com.google.cloud.talent.v4. JobQuery 
 
 ; 
 import 
  
 com.google.cloud.talent.v4. JobServiceClient 
 
 ; 
 import 
  
 com.google.cloud.talent.v4. RequestMetadata 
 
 ; 
 import 
  
 com.google.cloud.talent.v4. SearchJobsRequest 
 
 ; 
 import 
  
 com.google.cloud.talent.v4. SearchJobsResponse 
 
 ; 
 import 
  
 com.google.cloud.talent.v4. TenantName 
 
 ; 
 import 
  
 com.google.protobuf. Duration 
 
 ; 
 import 
  
 com.google.type. LatLng 
 
 ; 
 import 
  
 java.io.IOException 
 ; 
 public 
  
 class 
 CommuteSearchJobs 
  
 { 
  
 public 
  
 static 
  
 void 
  
 searchJobs 
 () 
  
 throws 
  
 IOException 
  
 { 
  
 // TODO(developer): Replace these variables before running the sample. 
  
 String 
  
 projectId 
  
 = 
  
 "your-project-id" 
 ; 
  
 String 
  
 tenantId 
  
 = 
  
 "your-tenant-id" 
 ; 
  
 searchJobs 
 ( 
 projectId 
 , 
  
 tenantId 
 ); 
  
 } 
  
 // Search Jobs with histogram queries. 
  
 public 
  
 static 
  
 void 
  
 searchJobs 
 ( 
 String 
  
 projectId 
 , 
  
 String 
  
 tenantId 
 ) 
  
 throws 
  
 IOException 
  
 { 
  
 // Initialize client that will be used to send requests. This client only needs to be created 
  
 // once, and can be reused for multiple requests. After completing all of your requests, call 
  
 // the "close" method on the client to safely clean up any remaining background resources. 
  
 try 
  
 ( 
  JobServiceClient 
 
  
 jobServiceClient 
  
 = 
  
  JobServiceClient 
 
 . 
 create 
 ()) 
  
 { 
  
  TenantName 
 
  
 parent 
  
 = 
  
  TenantName 
 
 . 
 of 
 ( 
 projectId 
 , 
  
 tenantId 
 ); 
  
 String 
  
 domain 
  
 = 
  
 "www.example.com" 
 ; 
  
 String 
  
 sessionId 
  
 = 
  
 "Hashed session identifier" 
 ; 
  
 String 
  
 userId 
  
 = 
  
 "Hashed user identifier" 
 ; 
  
  RequestMetadata 
 
  
 requestMetadata 
  
 = 
  
  RequestMetadata 
 
 . 
 newBuilder 
 () 
  
 . 
  setDomain 
 
 ( 
 domain 
 ) 
  
 . 
  setSessionId 
 
 ( 
 sessionId 
 ) 
  
 . 
  setUserId 
 
 ( 
 userId 
 ) 
  
 . 
 build 
 (); 
  
  CommuteMethod 
 
  
 commuteMethod 
  
 = 
  
  CommuteMethod 
 
 . 
 DRIVING 
 ; 
  
 long 
  
 seconds 
  
 = 
  
 3600L 
 ; 
  
  Duration 
 
  
 travelDuration 
  
 = 
  
  Duration 
 
 . 
 newBuilder 
 (). 
 setSeconds 
 ( 
 seconds 
 ). 
 build 
 (); 
  
 double 
  
 latitude 
  
 = 
  
 37.422408 
 ; 
  
 double 
  
 longitude 
  
 = 
  
 - 
 122.084068 
 ; 
  
  LatLng 
 
  
 startCoordinates 
  
 = 
  
  LatLng 
 
 . 
 newBuilder 
 (). 
  setLatitude 
 
 ( 
 latitude 
 ). 
  setLongitude 
 
 ( 
 longitude 
 ). 
 build 
 (); 
  
  CommuteFilter 
 
  
 commuteFilter 
  
 = 
  
  CommuteFilter 
 
 . 
 newBuilder 
 () 
  
 . 
  setCommuteMethod 
 
 ( 
 commuteMethod 
 ) 
  
 . 
 setTravelDuration 
 ( 
 travelDuration 
 ) 
  
 . 
  setStartCoordinates 
 
 ( 
 startCoordinates 
 ) 
  
 . 
 build 
 (); 
  
  JobQuery 
 
  
 jobQuery 
  
 = 
  
  JobQuery 
 
 . 
 newBuilder 
 (). 
  setCommuteFilter 
 
 ( 
 commuteFilter 
 ). 
 build 
 (); 
  
  SearchJobsRequest 
 
  
 request 
  
 = 
  
  SearchJobsRequest 
 
 . 
 newBuilder 
 () 
  
 . 
 setParent 
 ( 
 parent 
 . 
  toString 
 
 ()) 
  
 . 
  setRequestMetadata 
 
 ( 
 requestMetadata 
 ) 
  
 . 
  setJobQuery 
 
 ( 
 jobQuery 
 ) 
  
 . 
 build 
 (); 
  
 for 
  
 ( 
  SearchJobsResponse 
 
 . 
  MatchingJob 
 
  
 responseItem 
  
 : 
  
 jobServiceClient 
 . 
 searchJobs 
 ( 
 request 
 ). 
 getMatchingJobsList 
 ()) 
  
 { 
  
 System 
 . 
 out 
 . 
 format 
 ( 
 "Job summary: %s%n" 
 , 
  
 responseItem 
 . 
 getJobSummary 
 ()); 
  
 System 
 . 
 out 
 . 
 format 
 ( 
 "Job title snippet: %s%n" 
 , 
  
 responseItem 
 . 
 getJobTitleSnippet 
 ()); 
  
  Job 
 
  
 job 
  
 = 
  
 responseItem 
 . 
 getJob 
 (); 
  
 System 
 . 
 out 
 . 
 format 
 ( 
 "Job name: %s%n" 
 , 
  
 job 
 . 
  getName 
 
 ()); 
  
 System 
 . 
 out 
 . 
 format 
 ( 
 "Job title: %s%n" 
 , 
  
 job 
 . 
  getTitle 
 
 ()); 
  
 } 
  
 } 
  
 } 
 } 
 

Node.js

To learn how to install and use the client library for CTS, see CTS client libraries . For more information, see the CTS Node.js API reference documentation .

To authenticate to CTS, set up Application Default Credentials. For more information, see Set up authentication for a local development environment .

  const 
  
 talent 
  
 = 
  
 require 
 ( 
 ' @google-cloud/talent 
' 
 ). 
 v4 
 ; 
 /** Search Jobs using commute distance */ 
 function 
  
 sampleSearchJobs 
 ( 
 projectId 
 , 
  
 tenantId 
 ) 
  
 { 
  
 const 
  
 client 
  
 = 
  
 new 
  
 talent 
 . 
  JobServiceClient 
 
 (); 
  
 // Iterate over all elements. 
  
 // const projectId = 'Your Google Cloud Project ID'; 
  
 // const tenantId = 'Your Tenant ID (using tenancy is optional)'; 
  
 const 
  
 formattedParent 
  
 = 
  
 client 
 . 
 tenantPath 
 ( 
 projectId 
 , 
  
 tenantId 
 ); 
  
 const 
  
 domain 
  
 = 
  
 'www.example.com' 
 ; 
  
 const 
  
 sessionId 
  
 = 
  
 'Hashed session identifier' 
 ; 
  
 const 
  
 userId 
  
 = 
  
 'Hashed user identifier' 
 ; 
  
 const 
  
 requestMetadata 
  
 = 
  
 { 
  
 domain 
 : 
  
 domain 
 , 
  
 sessionId 
 : 
  
 sessionId 
 , 
  
 userId 
 : 
  
 userId 
 , 
  
 }; 
  
 const 
  
 commuteMethod 
  
 = 
  
 'TRANSIT' 
 ; 
  
 const 
  
 seconds 
  
 = 
  
 1800 
 ; 
  
 const 
  
 travelDuration 
  
 = 
  
 { 
  
 seconds 
 : 
  
 seconds 
 , 
  
 }; 
  
 const 
  
 latitude 
  
 = 
  
 37.422408 
 ; 
  
 const 
  
 longitude 
  
 = 
  
 122.084068 
 ; 
  
 const 
  
 startCoordinates 
  
 = 
  
 { 
  
 latitude 
 : 
  
 latitude 
 , 
  
 longitude 
 : 
  
 longitude 
 , 
  
 }; 
  
 const 
  
 commuteFilter 
  
 = 
  
 { 
  
 commuteMethod 
 : 
  
 commuteMethod 
 , 
  
 travelDuration 
 : 
  
 travelDuration 
 , 
  
 startCoordinates 
 : 
  
 startCoordinates 
 , 
  
 }; 
  
 const 
  
 jobQuery 
  
 = 
  
 { 
  
 commuteFilter 
 : 
  
 commuteFilter 
 , 
  
 }; 
  
 const 
  
 request 
  
 = 
  
 { 
  
 parent 
 : 
  
 formattedParent 
 , 
  
 requestMetadata 
 : 
  
 requestMetadata 
 , 
  
 jobQuery 
 : 
  
 jobQuery 
 , 
  
 }; 
  
 client 
  
 . 
 searchJobs 
 ( 
 request 
 ) 
  
 . 
 then 
 ( 
 responses 
  
 = 
>  
 { 
  
 const 
  
 resources 
  
 = 
  
 responses 
 [ 
 0 
 ]; 
  
 for 
  
 ( 
 const 
  
 resource 
  
 of 
  
 resources 
 ) 
  
 { 
  
 console 
 . 
 log 
 ( 
 `Job summary: 
 ${ 
 resource 
 . 
 jobSummary 
 } 
 ` 
 ); 
  
 console 
 . 
 log 
 ( 
 `Job title snippet: 
 ${ 
 resource 
 . 
 jobTitleSnippet 
 } 
 ` 
 ); 
  
 const 
  
 job 
  
 = 
  
 resource 
 . 
 job 
 ; 
  
 console 
 . 
 log 
 ( 
 `Job name: 
 ${ 
 job 
 . 
 name 
 } 
 ` 
 ); 
  
 console 
 . 
 log 
 ( 
 `Job title: 
 ${ 
 job 
 . 
 title 
 } 
 ` 
 ); 
  
 } 
  
 }) 
  
 . 
 catch 
 ( 
 err 
  
 = 
>  
 { 
  
 console 
 . 
 error 
 ( 
 err 
 ); 
  
 }); 
 } 
 

Python

To learn how to install and use the client library for CTS, see CTS client libraries . For more information, see the CTS Python API reference documentation .

To authenticate to CTS, set up Application Default Credentials. For more information, see Set up authentication for a local development environment .

  from 
  
 google.cloud 
  
 import 
 talent 
 def 
  
 search_jobs 
 ( 
 project_id 
 , 
 tenant_id 
 ): 
  
 """Search Jobs using commute distance""" 
 client 
 = 
 talent 
 . 
  JobServiceClient 
 
 () 
 # project_id = 'Your Google Cloud Project ID' 
 # tenant_id = 'Your Tenant ID (using tenancy is optional)' 
 if 
 isinstance 
 ( 
 project_id 
 , 
 bytes 
 ): 
 project_id 
 = 
 project_id 
 . 
 decode 
 ( 
 "utf-8" 
 ) 
 if 
 isinstance 
 ( 
 tenant_id 
 , 
 bytes 
 ): 
 tenant_id 
 = 
 tenant_id 
 . 
 decode 
 ( 
 "utf-8" 
 ) 
 parent 
 = 
 f 
 "projects/ 
 { 
 project_id 
 } 
 /tenants/ 
 { 
 tenant_id 
 } 
 " 
 domain 
 = 
 "www.example.com" 
 session_id 
 = 
 "Hashed session identifier" 
 user_id 
 = 
 "Hashed user identifier" 
 request_metadata 
 = 
 talent 
 . 
  RequestMetadata 
 
 ( 
 domain 
 = 
 domain 
 , 
 session_id 
 = 
 session_id 
 , 
 user_id 
 = 
 user_id 
 ) 
 commute_method 
 = 
 talent 
 . 
  CommuteMethod 
 
 . 
 TRANSIT 
 seconds 
 = 
 1800 
 travel_duration 
 = 
 { 
 "seconds" 
 : 
 seconds 
 } 
 latitude 
 = 
 37.422408 
 longitude 
 = 
 - 
 122.084068 
 start_coordinates 
 = 
 { 
 "latitude" 
 : 
 latitude 
 , 
 "longitude" 
 : 
 longitude 
 } 
 commute_filter 
 = 
 talent 
 . 
  CommuteFilter 
 
 ( 
 commute_method 
 = 
 commute_method 
 , 
 travel_duration 
 = 
 travel_duration 
 , 
 start_coordinates 
 = 
 start_coordinates 
 , 
 ) 
 job_query 
 = 
 talent 
 . 
  JobQuery 
 
 ( 
 commute_filter 
 = 
 commute_filter 
 ) 
 # Iterate over all results 
 results 
 = 
 [] 
 request 
 = 
 talent 
 . 
  SearchJobsRequest 
 
 ( 
 parent 
 = 
 parent 
 , 
 request_metadata 
 = 
 request_metadata 
 , 
 job_query 
 = 
 job_query 
 , 
 ) 
 for 
 response_item 
 in 
 client 
 . 
  search_jobs 
 
 ( 
 request 
 = 
 request 
 ) 
 . 
 matching_jobs 
 : 
 print 
 ( 
 f 
 "Job summary: 
 { 
 response_item 
 . 
 job_summary 
 } 
 " 
 ) 
 print 
 ( 
 f 
 "Job title snippet: 
 { 
 response_item 
 . 
 job_title_snippet 
 } 
 " 
 ) 
 job 
 = 
 response_item 
 . 
 job 
 results 
 . 
 append 
 ( 
 job 
 . 
 name 
 ) 
 print 
 ( 
 f 
 "Job name: 
 { 
 job 
 . 
 name 
 } 
 " 
 ) 
 print 
 ( 
 f 
 "Job title: 
 { 
 job 
 . 
 title 
 } 
 " 
 ) 
 return 
 results 
 

UI recommendations

  1. Cloud Talent Solution doesn't allow searching by both distance (using the CTS location filter) commute time in the same API call. To allow job seekers to access both options, use a 2-tab approach or similar.

  2. Modify the frontend of your application to ensure that the backend automatically populates a job seeker's relevant information into the commute filter . The backend should call the API as it would in a regular search request.

  3. Include items in your UI:

    • An option to select either a distance search or commute search. For example, your Search UI could look like the sample below:

    • A drop-down menu of commute method options.

    • An option to adjust traffic conditions.

    • The total travel time (the maximum supported travel time is 60 minutes).

    • Commute start time.

  4. The commute time information returned from the API is used to display information to the job seeker. Only relevant jobs located within the designated commute time area are returned in the results list. See the Job Search Best Practices documentation for a discussion of ways to adjust the order and number of jobs returned within this area.

  5. Commute search results are based on historical and aggregated data rather than live traffic conditions. The departureTime traffic conditions are calculated from average traffic conditions at the specified time of day. The BUSY_HOUR / TRAFFIC_FREE options under roadTraffic are average traffic conditions at morning rush hour and midnight, respectively. Users receive the same commute search results no matter what time of day they send a query.

You can leverage Google Maps to generate a map based on the commute time information returned from CTS and embed it into the results returned to a job seeker. The Maps API suite has several options for displaying a map. Some Maps API options are more effective than others. For example, the Google Maps JavaScript Heatmap visualization paired with marker clustering is an effective way to visualize the relevant jobs returned to a job seeker inside the area determined by their set commute preferences. Conversely, Directions Mode does not show all jobs returned in a search request and is not a recommended option.

For more information on implementing a commute-based search, see the Commute Search how-to guide .

Create a Mobile Website
View Site in Mobile | Classic
Share by: