Theo dõi một lô hàng

Giờ đây, bạn đã thiết lập JavaScript Consumer SDK cho các tác vụ theo lịch, bạn có thể theo dõi lô hàng bằng ứng dụng dành cho người tiêu dùng. Tài liệu này trình bày các bước chính sau đây trong quy trình này:

  • Khởi chạy bản đồ và hiển thị hành trình được chia sẻ
  • Cập nhật và theo dõi tiến trình của hành trình
  • Ngừng theo dõi lô hàng
  • Xử lý lỗi theo dõi lô hàng

Thiết lập bản đồ

Để theo dõi việc lấy hoặc giao hàng trong ứng dụng web, bạn cần tải bản đồ và tạo thực thể Consumer SDK để bắt đầu theo dõi lô hàng. Bạn có thể tải một bản đồ mới hoặc sử dụng bản đồ hiện có. Sau đó, bạn dùng hàm khởi tạo để tạo thực thể Consumer SDK sao cho khung hiển thị bản đồ tương ứng với vị trí của mục đang được theo dõi.

Tải một bản đồ mới bằng API JavaScript của Google Maps

Để tạo một bản đồ mới, hãy tải API JavaScript của Google Maps vào ứng dụng web của bạn. Ví dụ sau đây cho biết cách tải API JavaScript của Google Maps, bật SDK và kích hoạt quy trình kiểm tra khởi tạo.

  • Tham số callback chạy hàm initMap sau khi API tải.
  • Thuộc tính defer cho phép trình duyệt tiếp tục hiển thị phần còn lại của trang trong khi API tải.

Dùng hàm initMap để tạo thực thể Consumer SDK. Ví dụ:

    <script src="https://maps.googleapis.com/maps/api/js?key=YOUR_API_KEY&callback=initMap&libraries=journeySharing" defer></script>

Tải một bản đồ hiện có

Bạn cũng có thể tải một bản đồ hiện có do API JavaScript của Google Maps tạo, chẳng hạn như bản đồ mà bạn đã sử dụng.

Ví dụ: giả sử bạn có một trang web có thực thể google.maps.Map tiêu chuẩn mà trên đó một điểm đánh dấu xuất hiện như được xác định trong mã HTML sau. Thao tác này sẽ cho thấy bản đồ của bạn bằng cách sử dụng cùng một hàm initMap trong lệnh gọi lại ở cuối:

    <!DOCTYPE html>
    <html>
      <head>
        <style>
           /* Set the size of the div element that contains the map */
          #map {
            height: 400px;  /* The height is 400 pixels */
            width: 100%;  /* The width is the width of the web page */
           }
        </style>
      </head>
      <body>
        <h3>My Google Maps Demo</h3>
        <!--The div element for the map -->
        <div id="map"></div>
        <script>
        // Initialize and add the map
        function initMap() {
          // The location of Pier 39 in San Francisco
          var pier39 = {lat: 37.809326, lng: -122.409981};
          // The map, initially centered at Mountain View, CA.
          var map = new google.maps.Map(document.getElementById('map'));
          map.setOptions({center: {lat: 37.424069, lng: -122.0916944}, zoom: 14});

          // The marker, now positioned at Pier 39
          var marker = new google.maps.Marker({position: pier39, map: map});
        }
        </script>
        <!-- Load the API from the specified URL.
           * The defer attribute allows the browser to render the page while the API loads.
           * The key parameter contains your own API key.
           * The callback parameter executes the initMap() function.
        -->
        <script defer src="https://maps.googleapis.com/maps/api/js?key=YOUR_API_KEY&callback=initMap">
        </script>
      </body>
    </html>

Khởi tạo một trình cung cấp vị trí giao hàng

Sử dụng trình cung cấp vị trí lô hàng cùng với trình tìm nạp mã thông báo uỷ quyền mà bạn đã xác định trước đó để bắt đầu nhận dữ liệu từ Fleet Engine.

Những ví dụ này cho thấy cách khởi tạo trình cung cấp vị trí.

JavaScript

const locationProvider =
  new google.maps.journeySharing.FleetEngineShipmentLocationProvider({
      projectId: 'your-project-id',
      authTokenFetcher: authTokenFetcher,  // the fetcher defined previously
  });

TypeScript

const locationProvider =
  new google.maps.journeySharing.FleetEngineShipmentLocationProvider({
      projectId: 'your-project-id',
      authTokenFetcher: authTokenFetcher,  // the fetcher defined previously
  });

Hiển thị hành trình được chia sẻ

Để hiển thị tiến trình của một tác vụ theo lịch, hãy khởi tạo chế độ xem của tác vụ đó. Chế độ xem này sẽ đặt khung cho bản đồ tương ứng với vị trí của hành trình được theo dõi. Sau đó, Consumer SDK sẽ cung cấp tiến trình sau khi nhận được thông tin từ Fleet Engine.

Mẹo:

  1. Đảm bảo trang của bạn có chứa một phần tử <div> chứa chế độ xem bản đồ. Trong ví dụ sau, phần tử <div> có tên là map_canvas.

  2. Nắm rõ các quy tắc hiển thị mặc định mà Fleet Engine áp dụng cho các hành trình được theo dõi. Bạn cũng có thể thiết lập các quy tắc hiển thị cho lô hàng đang hoạt động và các nhiệm vụ dừng theo lịch của xe. Hãy xem phần Tuỳ chỉnh chế độ hiển thị việc cần làm trong hướng dẫn Định cấu hình việc cần làm.

Các ví dụ này minh hoạ cách khởi tạo một khung hiển thị bản đồ.

JavaScript

function initMap() {
  const mapView = new
    google.maps.journeySharing.JourneySharingMapView({
    element: document.getElementById('map_canvas'),
    // Any undefined styling options use defaults.
  });

  // If you did not specify a tracking ID in the location
  // provider constructor, you may do so here.
  // Location tracking starts as soon as this is set.
  locationProvider.trackingId = 'your-tracking-id';

  // Give the map an initial viewport to allow it to
  // initialize; otherwise the 'ready' event above may
  // not fire. The user also has access to the mapView
  // object to customize as they wish.
  mapView.map.setCenter({lat: 37.2, lng: -121.9});
  mapView.map.setZoom(14);
}

TypeScript

function initMap() {
  const mapView = new
    google.maps.journeySharing.JourneySharingMapView({
    element: document.getElementById('map_canvas'),
   // Any undefined styling options will use defaults.
  });

  // If you did not specify a tracking ID in the location
  // provider constructor, you may do so here.
  // Location tracking starts as soon as this is set.
  locationProvider.trackingId = 'your-tracking-id';

  // Give the map an initial viewport to allow it to
  // initialize; otherwise the 'ready' event above may
  // not fire. The user also has access to the mapView
  // object to customize as they wish.
  mapView.map.setCenter({lat: 37.2, lng: -121.9});
  mapView.map.setZoom(14);
}

Cập nhật tiến trình vận chuyển

Bạn có thể theo dõi các sự kiện và cập nhật tiến trình vận chuyển khi hành trình diễn ra. Sử dụng trình cung cấp vị trí để truy xuất thông tin meta từ đối tượng taskTrackingInfo. Các thay đổi đối với thông tin meta sẽ kích hoạt sự kiện cập nhật. Đối tượng taskTrackingInfo cung cấp những thông tin sau:

  • ETA
  • Số điểm dừng còn lại
  • Khoảng cách còn lại trước khi đến lấy hoặc giao hàng

Ví dụ sau đây cho thấy cách theo dõi các sự kiện thay đổi này.

JavaScript

locationProvider.addListener('update', e => {
  // e.taskTrackingInfo contains data that may be useful
  // to the rest of the UI.
  console.log(e.taskTrackingInfo.remainingStopCount);
});

TypeScript

locationProvider.addListener('update',
    (e: google.maps.journeySharing.FleetEngineShipmentLocationProviderUpdateEvent) => {
  // e.taskTrackingInfo contains data that may be useful
  // to the rest of the UI.
  console.log(e.taskTrackingInfo.remainingStopCount);
});

Tiêu chí hiển thị cho nhiều nhiệm vụ

Consumer SDK cho các tác vụ theo lịch chỉ hiển thị một tác vụ cho mỗi mã nhận dạng theo dõi trên bản đồ. Tuy nhiên, bạn cũng thường chỉ định một mã theo dõi cho một hàng hoá được vận chuyển cụ thể. Mã này vẫn được liên kết với hàng hoá trong suốt quá trình vận chuyển trong hệ thống của bạn. Điều này có nghĩa là một mã theo dõi duy nhất có thể được liên kết với nhiều việc cần làm, chẳng hạn như việc cần làm là đến lấy hàng, sau đó là việc cần làm là giao hàng cho cùng một gói hàng hoặc nhiều việc cần làm là giao hàng không thành công cho một gói hàng.

Để xử lý tình huống này, Fleet Engine áp dụng các tiêu chí để hiển thị nhiệm vụ, như trong bảng sau.

Tiêu chí về việc cần làm Kết quả
Mở nhiệm vụ đến lấy hàng
Chỉ có một Hiện việc cần làm
Nhiều Lỗi tạo
Nhiệm vụ lấy hàng đã hoàn thành
Chỉ có một Hiện việc cần làm
Nhiều lần thoát (một số lần có thời gian kết quả) Hiện tác vụ có thời gian kết quả gần đây nhất
Nhiều kết quả (không có kết quả nào có thời gian) Lỗi tạo
Mở các việc cần làm về việc giao hàng
Chỉ có một Hiện việc cần làm
Nhiều Lỗi tạo
Việc cần làm đã hoàn thành
Chỉ có một Hiện việc cần làm
Nhiều lần thoát (một số lần có thời gian kết quả) Hiện tác vụ có thời gian kết quả gần đây nhất
Nhiều kết quả (không có kết quả nào có thời gian) Lỗi tạo

Ngừng theo dõi lô hàng

Khi hành trình vận chuyển hoàn tất hoặc bị huỷ, ứng dụng dành cho người tiêu dùng của bạn sẽ ngừng theo dõi một lô hàng bằng cách xoá mã theo dõi và trình cung cấp vị trí khỏi chế độ xem bản đồ. Để biết chi tiết, hãy xem các phần sau đây.

Xoá mã theo dõi

Để nhà cung cấp dịch vụ vị trí ngừng theo dõi lô hàng, hãy xoá mã theo dõi khỏi nhà cung cấp dịch vụ vị trí. Các ví dụ sau đây cho thấy cách thực hiện việc này.

JavaScript

locationProvider.trackingId = '';

TypeScript

locationProvider.trackingId = '';

Xoá trình cung cấp vị trí khỏi khung hiển thị bản đồ

Ví dụ sau đây cho biết cách xoá một trình cung cấp vị trí khỏi khung hiển thị bản đồ.

JavaScript

mapView.removeLocationProvider(locationProvider);

TypeScript

mapView.removeLocationProvider(locationProvider);

Xử lý lỗi theo dõi lô hàng

Các lỗi phát sinh không đồng bộ từ việc yêu cầu thông tin vận chuyển sẽ kích hoạt các sự kiện error. Ví dụ sau đây cho thấy cách theo dõi các sự kiện này để xử lý lỗi.

JavaScript

locationProvider.addListener('error', e => {
  // e.error is the error that triggered the event.
  console.error(e.error);
});

TypeScript

locationProvider.addListener('error', (e: google.maps.ErrorEvent) => {
  // e.error is the error that triggered the event.
  console.error(e.error);
});

Lưu ý: Nhớ gói các lệnh gọi thư viện trong các khối try...catch để xử lý các lỗi không lường trước được.

Bước tiếp theo