מעקב אחר משלוח

עכשיו, אחרי שהגדרתם את JavaScript Consumer SDK למשימות מתוזמנות, אתם מוכנים לעקוב אחרי משלוח באמצעות אפליקציית הצרכן. במסמך הזה נסביר על השלבים העיקריים בתהליך:

  • איך מפעילים מפה ומציגים את המסלול המשותף
  • עדכון ההתקדמות של התהליך ומעקב אחריו
  • איך מפסיקים לעקוב אחרי משלוח
  • טיפול בשגיאות במעקב אחר משלוחים

הגדרת מפה

כדי לעקוב אחרי איסוף או מסירה של משלוח באפליקציית האינטרנט, צריך לטעון מפה וליצור מופע של Consumer SDK כדי להתחיל לעקוב אחרי המשלוח. אפשר לטעון מפה חדשה או להשתמש במפה קיימת. לאחר מכן משתמשים בפונקציית האיפוס כדי ליצור מופע של Consumer SDK, כך שתצוגת המפה תתאים למיקום של הפריט שעליו מתבצע המעקב.

טעינת מפה חדשה באמצעות Google Maps JavaScript API

כדי ליצור מפה חדשה, צריך לטעון את Google Maps JavaScript API באפליקציית האינטרנט. בדוגמה הבאה מוסבר איך לטעון את Google Maps JavaScript API, להפעיל את ה-SDK ולהפעיל את בדיקת האיפוס.

  • הפרמטר callback מפעיל את הפונקציה initMap אחרי טעינת ה-API.
  • המאפיין defer מאפשר לדפדפן להמשיך את העיבוד של שאר הדף בזמן טעינת ה-API.

משתמשים בפונקציה initMap כדי ליצור מופע של Consumer SDK. לדוגמה:

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

טעינת מפה קיימת

אפשר גם לטעון מפה קיימת שנוצרה באמצעות ממשק ה-API של JavaScript במפות Google, למשל מפה שכבר משתמשים בה.

לדוגמה, נניח שיש לכם דף אינטרנט עם ישות google.maps.Map רגילה שבה מוצג סמן כפי שמוגדר בקוד ה-HTML הבא. כאן מוצגת המפה באמצעות אותה פונקציה initMap בקריאה החוזרת בסוף:

    <!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>

יצירת מכונה של ספק מיקום משלוח

כדי להתחיל לקבל נתונים מ-Fleet Engine, משתמשים בספק המיקום של המשלוח יחד עם הגורם לאחזור אסימון ההרשאה שהגדרתם קודם.

בדוגמאות הבאות מוסבר איך ליצור מופע של ספק המיקום.

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
  });

הצגת המסלול המשותף

כדי להציג את ההתקדמות של משימה מתוזמנת, צריך לאתחל את התצוגה שלה. כך המסגרת של המפה תתאים למיקום של המסלול במעקב. לאחר מכן, ההתקדמות מוצגת על ידי Consumer SDK אחרי שהוא מקבל את המידע מ-Fleet Engine.

טיפים:

  1. מוודאים שהדף מכיל רכיב <div> שמכיל את תצוגת המפה. בדוגמה הבאה, הרכיב <div> נקרא map_canvas.

  2. חשוב לדעת על כללי ברירת המחדל של הרשאות הגישה שמערכת Fleet Engine מחילה על המסלולים במעקב. אפשר גם להגדיר כללי חשיפה למשימות של שליחת כלי רכב פעיל ולמשימות של עצירות מתוזמנות. מידע נוסף זמין בקטע התאמה אישית של הרשאות הגישה למשימות במדריך הגדרת משימות.

בדוגמאות הבאות מוסבר איך לאתחל תצוגת מפה.

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);
}

עדכון של סטטוס המשלוח

אפשר להאזין לאירועים ולעדכן את ההתקדמות של המשלוח במהלך התהליך. משתמשים בספק המיקום כדי לאחזר מטא-מידע מהאובייקט taskTrackingInfo. שינויים במטא-נתונים מפעילים אירוע עדכון. האובייקט taskTrackingInfo מספק את הפרטים הבאים:

  • זמן הגעה משוער
  • מספר תחנות העצירה שנותרו
  • המרחק שנותר עד לאיסוף או למשלוח

הדוגמה הבאה מראה איך להאזין לאירועי השינוי האלה.

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);
});

הצגת קריטריונים למספר משימות

ב-Consumer SDK למשימות מתוזמנות מוצגת במפה רק משימה אחת לכל מזהה מעקב. עם זאת, בדרך כלל מקצים גם מזהה מעקב אחד לטובין במשלוח ספציפי, שמשויך לטובין לאורך המסלול שלו במערכת. כלומר, מזהה מעקב אחד יכול להיות משויך למספר משימות, למשל משימה של איסוף ואחריה משימה של מסירה לאותה חבילה, או מספר משימות של שליחה שנכשלו לאותה חבילה.

כדי לטפל במצב כזה, מערכת Fleet Engine מחילה קריטריונים להצגת משימות, כפי שמפורט בטבלה הבאה.

קריטריונים למשימות תוצאה
פתיחת משימות איסוף
קיים רק אחד הצגת המשימה
קיימים כמה פריטים יצירת שגיאה
משימות איסוף סגורות
קיים רק אחד הצגת המשימה
יש כמה תוצאות (חלקן עם זמני תוצאה) הצגת המשימה עם זמן התוצאה האחרון
יש כמה תוצאות (אף אחת מהן לא כוללת זמני תוצאה) יצירת שגיאה
פתיחת משימות מסירה
קיים רק אחד הצגת המשימה
קיימים כמה פריטים יצירת שגיאה
משימות מסירה סגורות
קיים רק אחד הצגת המשימה
יש כמה תוצאות (חלקן עם זמני תוצאה) הצגת המשימה עם זמן התוצאה האחרון
יש כמה תוצאות (אף אחת מהן לא כוללת זמני תוצאה) יצירת שגיאה

איך מפסיקים לעקוב אחרי משלוח

כשמסע המשלוח מסתיים או מבוטל, באפליקציה של הצרכן צריך להפסיק לעקוב אחרי המשלוח על ידי הסרת מזהה המעקב וספקי המיקום מתצוגת המפה. פרטים נוספים זמינים בסעיפים הבאים.

הסרת המזהה לצורכי מעקב

כדי להפסיק את המעקב אחר המשלוח על ידי ספק המיקום, צריך להסיר את מזהה המעקב מספק המיקום. בדוגמאות הבאות מוסבר איך לעשות זאת.

JavaScript

locationProvider.trackingId = '';

TypeScript

locationProvider.trackingId = '';

הסרת ספק המיקום מתצוגת המפה

בדוגמה הבאה מוסבר איך להסיר ספק מיקום מתצוגת המפה.

JavaScript

mapView.removeLocationProvider(locationProvider);

TypeScript

mapView.removeLocationProvider(locationProvider);

טיפול בשגיאות במעקב אחר משלוחים

שגיאות שמתרחשות באופן אסינכרוני מבקשת לקבלת פרטי משלוח מפעילות אירועי error. בדוגמה הבאה מוסבר איך להאזין לאירועים האלה כדי לטפל בשגיאות.

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);
});

הערה: חשוב לעטוף את הקריאות לספרייה בבלוק try...catch כדי לטפל בשגיאות בלתי צפויות.

המאמרים הבאים