Members
# constant APIUrls
- To Do:
- 
        - Use these variables instead of hardcoded URLs
- Rename with prefix to indicate method. Example: APIV2_POST, APIV3_PATCH
 
# constant APIV3RequestDatetimeFormat
- To Do:
- 
        - Replace hardcoded moment format with these variables in the entire application
 
# constant autoRefreshMixin
Location module results can auto refresh each X seconds
# blacklistedSearchModuleFormTabs
Some clients do not have right to perform a search realtime/history ib certain tab (i.g driver)
# circuitServiceDuration
Use now as end date if null is supplied
# currentFormattedAddress
Used by NearbyVehiclesFeature
# currentLayoutName
Customize current layout name Used by V3 - Location Module - Table+Map mode -> To preserve the map if details windows is closed
# constant defaultSensorsVisibility
Used by Diagnostics module to determine whenever to show/hide tor/ana by default
# disableLeafletMapInvalidateSize
Prevent child maps to re-compute their size if hidden
# constant envNames
Some frameworks prefix variables differently
- To Do:
- 
        - Resemble all the env names here (Each time you see process.env.VUE_APP..., replace with getEnvValue)
 
# constant layoutStaticContext
Used by MapToolbox to hide itself if Table+Carto (i.g Location module) (Module context pattern)
# constant LoginNewsMixin
- Retrieves application messages from geonline news
- Compute notice message like follow: newest message matching the current locale
# constant mitt
Mitt default instance
IMPORTANT NOTICE: Avoid using mitt as much as possible. Ask for alternative communication strategies.
# constant providerState
Module context pattern
# constant wrapper
Map singleton that holds references to active maps.
Methods
# after()
Fit bounds over vehicle markers
# compiledLineStrings(state)
Group and compil multiples polylines in only one polyline
Parameters:
| Name | Type | Description | 
|---|---|---|
| state | 
# computeFilenameFromTableCode(code)
Parameters:
| Name | Type | Default | Description | 
|---|---|---|---|
| code | * | table-export | i.g locationDetailsCircuit | 
# convertLinestringToPolylines()
APIV2: linestring can be String or Array of strings (Zone interdiction might split trip history sometimes)
# createEchartDateValueTooltipFormatter(unit) → {Object}
Used by diagnostics module Expects echarts serie data item value to be [timestamp, value]
Parameters:
| Name | Type | Description | 
|---|---|---|
| unit | String | i.g 'km' | 
| options.i18n | Object | i18n instance | 
echart series item tooltip formatter handler
Object
    # createLeafletWrapperPolylineItem(linestring, options)
Wrapper for Leaflet polyline (Array of LatLng)
Parameters:
| Name | Type | Description | 
|---|---|---|
| linestring | * | |
| options | * | 
# createMarkerFromRealtimeItem(item)
Used by Location module (Real-time) to render real-time results in the map (Vehicle markers).
Parameters:
| Name | Type | Description | 
|---|---|---|
| item | * | Wrapper on top of location item (main results) that includes a Leaflet icon. | 
# createSimplicitiErrorLogger()
Custom error logger. Initially, we use to send errors to server (APIV3) but this was disabled in favor of Sentry.
# createSinglePolylineEntity(item, singleLinestring, options)
Wrapper for Leaflet polyline (Array of LatLng)
Parameters:
| Name | Type | Description | 
|---|---|---|
| item | * | |
| singleLinestring | * | |
| options | * | 
# defineFeatureCircuitExecStepHighlightShowStartStopMarkers()
Used by CircuitRef / Location Will display Stop/Start markers when the user highlight a circuit exec step.
# dispatchAlertForAPIV2Error(err, dispatch) → {*}
Parameters:
| Name | Type | Description | 
|---|---|---|
| err | * | |
| dispatch | * | 
*
    # drawCircuitVersions()
# drawClientZones()
Draws client zones on the map based on the current bounds. Clustering is enabled at certain zoom levels. If non-clustering, zones are filtered out if outside viewport.
# drawLocateAddressMarker(mapVm, lat, lng, formattedAddress, options)
Used by
- LocationAddressNatural.vue (Autocomplete)
- LocateAddressFeature (Form)
- LocateAddressLatLng (Reverse)
Parameters:
| Name | Type | Description | 
|---|---|---|
| mapVm | * | |
| lat | * | |
| lng | * | |
| formattedAddress | * | |
| options | * | 
# drawPositionsMarkersFromData()
Draw common position markers (without sensor data) Border: Same as trip history Fill: #cccccc (Same as V2)
# drawSensorMarkersFromData()
Draw sensor markers (positions with sensor data) using LeafletMap::drawGeometries Border: Trip history polyline color Fill: Sensor color
# echartMixin(echarts, domElement)
Wrapper on top of echart vue components
Parameters:
| Name | Type | Description | 
|---|---|---|
| echarts | Object | Echarts core singleton (i.e import * as echarts from 'echarts/core'; echarts.use([GaugeChart, CanvasRenderer])) | 
| domElement | Object | Dom element used to render the chart | 
| options.optionsHandler | function | Handler to compute echart options | 
Example
{
mixins: [
    echartMixin((vm) => vm.$refs.chart, {
      optionsHandler: createEchartInstanceOptions,
      renderOnMounted: true,
    }),
  ],
  watch:{
    value(){
      this.renderChart();
    }
  }
}# encodeLoginNameClientId(loginName, clientId) → {String}
Used by settings store to cache settings parameters
Parameters:
| Name | Type | Description | 
|---|---|---|
| loginName | * | |
| clientId | * | 
encoded string
String
    # exportDatatable()
Parameters:
| Name | Type | Description | 
|---|---|---|
| options.data | Array | arrayOfObjects | 
| options.tableCode | String | i.g locationIdentification | 
| options.format | String | csv/xls (default to csv) | 
| options.columns | Array | 
# exportToCSV(arrayOfObjects, filename)
Parameters:
| Name | Type | Description | 
|---|---|---|
| arrayOfObjects | * | |
| filename | * | 
Example
exportToCSV([{name:"FOO",size:"200"},{name:"BAR",size:"300"}],"test")
exportToCSV([{name:"FOO",size:"200"},{name:"BAR",size:"300"}],"test",{columns:['NAME','SIZE']})# exportToXLS(columns, data, name)
Parameters:
| Name | Type | Description | 
|---|---|---|
| columns | Array | |
| data | Array | |
| name | * | i.g test | 
Example
exportToXLS([{name:"FOO",size:"200"},{name:"BAR",size:"300"}],"test")
exportToXLS([{ name: "FOO", size: "200" },{ name: "BAR", size: "300" }],"test",{columns: {name:"NOMBRE",size:"TAMAÑO"},});
exportToXLS([{ name: "FOO", size: "200" },{ name: "BAR", size: "300" }],"test",{columns: ["NAME", "SIZE"]});# fetchCircuits(transform)
Parameters:
| Name | Type | Description | 
|---|---|---|
| transform | * | 
- To Do:
- 
        - SearchModule: Move the normalization from search_module into this function (default normalization)
 
# fetchCircuitVersionSections(circuitId, versionId, circuitActivities)
Parameters:
| Name | Type | Description | 
|---|---|---|
| circuitId | * | |
| versionId | * | |
| circuitActivities | Array | Circuit activities: Used during normalization | 
# fetchCircuitVersionStepLastExecutions(circuitId, versionId, sectionId)
Retrieve the last five circuit execution steps given a circuit, version and step id
Parameters:
| Name | Type | Description | 
|---|---|---|
| circuitId | * | |
| versionId | * | |
| sectionId | * | 
# fetchEvents()
Used by events module.
- Data used for: Map markers and table
Split: 5 element, then 1 date (i.g: 1 request per vehicle/date)
Parameters:
| Name | Type | Description | 
|---|---|---|
| options.elementIds | Array | Vehicle or circuit ids [1,2,3] | 
| options.dates | Array | Dates ['2022-04-29'] or [Moment] | 
| options.filters | Object | Custom querystring parameters | 
| options.elementType | String | Helps build the uri (vehicle/circuit) | 
| options.fetchOptions | Object | Give options to axios | 
| options.handleResults | function | (results)=>({}) Each time results are available | 
- To Do:
- 
        - To be able to stop the search (i.g user stop an automatic search)
 
# fetchEventsCumulation(elementIds, dates, options)
Replace JSON mock with hardcoded/auto-generated mock inside the code source (Optimize)
Parameters:
| Name | Type | Description | 
|---|---|---|
| elementIds | * | |
| dates | * | |
| options | * | 
# fetchVehicleCategories(transformer)
Parameters:
| Name | Type | Description | 
|---|---|---|
| transformer | * | 
- To Do:
- 
        - Add server order/sort asc once 502 issue is resolved
 
# fetchVehicles(transformer)
- @todo Add server order/sort asc once 502 issue is resolved
Parameters:
| Name | Type | Description | 
|---|---|---|
| transformer | * | 
# formatLinestring(linestring)
Format a linestring for LPolyline
Parameters:
| Name | Type | Description | 
|---|---|---|
| linestring | 
# generateChartReferenceDataForDynamicSensor(sensorName)
Parameters:
| Name | Type | Default | Description | 
|---|---|---|---|
| sensorName | String | tor | tor/ana | 
- See:
- 
        - colors.scss
 
# generateLeafletGeometriesBulkAsync_DISABLED()
POC: Snap poylines to street (using a routing machine that hits an OSM server)
# generateLeafletZoneGeometriesFromItem(item, param1)
Will generate a Circle/Polygon along with an access point icon and the Zone name (Text node)
Parameters:
| Name | Type | Description | 
|---|---|---|
| item | * | |
| param1 | * | 
# generateShortId(prefix)
Wrap unique id generator
Parameters:
| Name | Type | Description | 
|---|---|---|
| prefix | * | 
- To Do:
- 
        - Replace shortid with a new algorithm (shortid is now unsafe: https://www.npmjs.com/package/shortid )
 
# getBearingFromTwoLatAndLng(prevLatLng, nextLatLng)
Used by Diagnostics module to compute the vehicle marker bearing angle.
Bearing from point A to B https://www.igismap.com/formula-to-find-bearing-or-heading-angle-between-two-points-latitude-longitude/
Parameters:
| Name | Type | Description | 
|---|---|---|
| prevLatLng | * | |
| nextLatLng | * | 
# getBoxSensorAssigments(boxConfigurationId)
- Used by Diagnostics module
Parameters:
| Name | Type | Description | 
|---|---|---|
| boxConfigurationId | * | 
# getCanValueFromItem(item, canName)
Used by SensorsInfos to grab CAN values from an mixed object (location result or position result)
Parameters:
| Name | Type | Description | 
|---|---|---|
| item | * | |
| canName | * | 
# getCircuitExecutionDetails(circuitId, date)
Used by: Location - Main search -> History by Circuit Location - Main search -> History by Vehicle/Driver -> Circuit Tab
Parameters:
| Name | Type | Description | 
|---|---|---|
| circuitId | Number | [OPTIONAL] | 
| date | String | Circuit execution start date | 
Normalized circuit execution detail item
# getCircuitExecutionSteps(vehicleId, circuitId, fromDate, toDate)
Parameters:
| Name | Type | Description | 
|---|---|---|
| vehicleId | Number | |
| circuitId | Number | |
| fromDate | String | Circuit execution start date | 
| toDate | String | Circuit execution end date | 
# getClientChildsClientsProgressively(callback, options)
Parameters:
| Name | Type | Description | 
|---|---|---|
| callback | function | Called each time a response is finish. Return false to abort operation. | 
| options | Object | axios wrapper get options | 
- To Do:
- 
        - Replace with getAPIV3Pooling Fetch client childs (clients) from current user progressively
 
# getClientLoginAsToken(jwt, clientId, userId)
Parameters:
| Name | Type | Description | 
|---|---|---|
| jwt | * | api jwt need to be supplied manually (i.g: nested login as) | 
| clientId | * | |
| userId | * | 
# getClientLogoAsBase64(getOptions) → {String}
Grab logo client from APIV3
Parameters:
| Name | Type | Description | 
|---|---|---|
| getOptions | Object | AXIOS options (Optional) | 
base64 or defaultValue
String
    # getClientParameter(key, getOptions)
Parameters:
| Name | Type | Description | 
|---|---|---|
| key | * | |
| getOptions | * | 
- To Do:
- 
        - Refactor/Move into client-service
 
# getClusterIcon(cluster)
Uses the same icon as identification module
Parameters:
| Name | Type | Description | 
|---|---|---|
| cluster | * | 
# getComputedLanguageCodeFromCountryCode(countryCode)
Parameters:
| Name | Type | Description | 
|---|---|---|
| countryCode | * | 
# getDriverChronoStatus(value)
Parameters:
| Name | Type | Description | 
|---|---|---|
| value | * | 
- To Do:
- 
        - Move to chrono-service
 
View Source services/entities/location-main-search-item.js, line 543
# getEnvValue(name) → {String}
Wrapper to retrieve env values. Adapt to different frameworks if needed (i.g vite)
Parameters:
| Name | Type | Description | 
|---|---|---|
| name | * | 
String
    # getFirstProperty(object)
Used by: Location - Main search -> Real-time by Vehicle/Driver/Circuit
Parameters:
| Name | Type | Description | 
|---|---|---|
| object | * | 
# getHistoryAPIQueryStringDatePart(selectedDateRanges, isFirstAndLastDay,)
Helper to compute querystring date parameters (v2 historique APIs) from Array of date ranges.
Parameters:
| Name | Type | Description | 
|---|---|---|
| selectedDateRanges | ||
| isFirstAndLastDay, | Boolean that indicate if the search is for the first and last day | 
# getItemsFromHistoryCircuitAPIV2Response(responseData)
Parses APIV2 response (by_circuit_dates) into flat array.
Note: Response can contain multiple "historique" (circuit executions) for a single date/circuit_id
Parameters:
| Name | Type | Description | 
|---|---|---|
| responseData | Object | 
Example
Input: apiv2_response.data.items
 Output: Array of histories (circuit)# getItemsFromHistoryDriverAPIV2Response(responseData)
Parses APIV2 response (by_chauffeur_dates) into flat array.
Parameters:
| Name | Type | Description | 
|---|---|---|
| responseData | Object | 
Example
Input: apiv2_response.data.items
 Output: Array of histories (driver)# getItemsFromHistoryVehicleDriverAPIV2Response(responseData)
Parses APIV2 response (by_vehicule_dates) into flat array.
Parameters:
| Name | Type | Description | 
|---|---|---|
| responseData | Object | 
Example
Input: apiv2_response.data.items
 Output: Array of histories (vehicle)# getLastCircuitExecutionDetails({vehicleId})
Used by: Location - Main search -> Real-time by Vehicle/Driver/Circuit
Get last executed circuit infos from fixtures or API.
Parameters:
| Name | Type | Description | 
|---|---|---|
| {vehicleId} | Object | 
- To Do:
- 
        - Remove fixtures feature without braking unit test
 
Normalized circuit execution detail item
# getLeafletPolylinesArrayFromMultipleItems(items)
Used by Location module Some items might have multiple associated polylines (relatedPolylines attribute)
Parameters:
| Name | Type | Description | 
|---|---|---|
| items | * | Normalized array of items | 
# getNormalizedLatLngValueForAPI()
API stores Lat/Lng as integer (multiply by latLngScaleFactor and remove decimals)
# getNormalizedResults()
Normalizes API responses into a flat array
-APIV2 Responses are not flat and there are different (history/realtime)
# getPolylineFromLinestring(linestring)
Linestring example: 1.4659516666667 45.162342314815,1.4659516666667 45.162342314815 Polyline example: [[1.4659516666667,45.162342314815],[1.4659516666667,45.162342314815]]
Parameters:
| Name | Type | Description | 
|---|---|---|
| linestring | * | 
# getPolylinesFromItemLinestring(linestring, options)
Special polyline entity used by Location - History, Location - Realtime - Circuit getNormalizedItem: To be able to retrieve item details from leaflet popup (Trip-history/Circuit-exec polyline popup)
Parameters:
| Name | Type | Description | 
|---|---|---|
| linestring | * | |
| options | * | 
# getPositionBorderColor()
Border color: same as trip history polyline if available
# getSensors(vehicleId, datetimeStart, datetimeEnd, options)
Parameters:
| Name | Type | Description | 
|---|---|---|
| vehicleId | * | |
| datetimeStart | * | |
| datetimeEnd | * | |
| options | * | {positions: false, sensors: false} | 
# getSettingsParamFromRemote() → {Object}
Used to retrieve defaultMapPredefinedView Parses onlinePersistanceConfig and call 'retrieve' method for each key.
Object key/value pairs i.g {defaultMapPredefinedView:1}
Object
    # getTerrestrialDistance(la1, lo1, la2, lo2)
Calculates the distance between two coordinates Copied from generic.inc.php "DistanceTerrestre"
Parameters:
| Name | Type | Description | 
|---|---|---|
| la1 | * | |
| lo1 | * | |
| la2 | * | |
| lo2 | * | 
# getUserParametersAsObject(currentUserLogin) → {Object}
Used by Settings store.
Parameters:
| Name | Type | Description | 
|---|---|---|
| currentUserLogin | * | 
Settings state object Example: { defaultMapZoomLevel: 14, userBaseLayer: cBaseLayerSabatier }
Object
    # getVehicleBoxAllocations(vehicleId) → {Array}
Used by Diagnostics module
Parameters:
| Name | Type | Description | 
|---|---|---|
| vehicleId | Number | Required | 
| filterParams.boxNumber | Number|Array | i.g 43 or [43,85,23] | 
Array of vehicle box allocations (Affectation boitier)
Array
    # getVehicleCategoryObject(vehicleId, rootGetters)
Parameters:
| Name | Type | Description | 
|---|---|---|
| vehicleId | * | |
| rootGetters | * | 
- To Do:
- 
        - Refactor/Improve Get vehicle category object from search module loaded dataset
 
# getVehicleChrono()
Used by Location module - Chrono tab Used by Diagnostics module
Parameters:
| Name | Type | Description | 
|---|---|---|
| params.date | String|Date|Moment | Date or Moment | 
| params.vehicleId | String | Vehicle identifier | 
| params.startDate | Date|Moment | |
| params.endDate | Date|Moment | |
| params.apiHandler | function | (unit-test only) | 
# getVehicleHistoryFromDate(vehicleId, date) → {Object}
Used by Diagnostic module to fetch vehicle overview information about the trip history for a particular date.
Parameters:
| Name | Type | Description | 
|---|---|---|
| vehicleId | Number | |
| date | Date|Moment | 
Overview information about the trip history
Object
    # getVehicleHistoryPositionDetailsFromDateLegacy(vehicleId, datetime)
Used by Diagnostic module
Parameters:
| Name | Type | Description | 
|---|---|---|
| vehicleId | * | |
| datetime | * | 
- Version:
- APIV2
 
- To Do:
- 
        - Remove when unused
 
# getVehicleHistoryStepsFromDate(vehicleId, date)
Parameters:
| Name | Type | Description | 
|---|---|---|
| vehicleId | * | |
| date | * | 
- Version:
- APIV2
 
# getVehicleIconHTML(vehicleClassName, options)
Used by Location module. Get vehicle svg based on vehicle type (className)
Parameters:
| Name | Type | Description | 
|---|---|---|
| vehicleClassName | * | I.g: 30070 (Vehicule leger) | 
| options | * | options.className override svg class | 
# getVehiclePositions(vehicleId, date, options)
Used by Diagnostic module
Parameters:
| Name | Type | Description | 
|---|---|---|
| vehicleId | * | |
| date | * | |
| options | * | 
- Version:
- APIV3
 
- To Do:
- 
        - Use properties[positions][]= to reduce size of nested objects (It doesn't work with arrays like tor/ana)
 
# getVehicleSensorsConfiguration(vehicleId, date) → {Array}
Used by Location module (Trip history details - table) to load positions and sensors configuration
Parameters:
| Name | Type | Description | 
|---|---|---|
| vehicleId | * | |
| date | * | 
Array
    # getVehiculesPositions(vehicleIds, startDatetime, endDatetime)
Parameters:
| Name | Type | Description | 
|---|---|---|
| vehicleIds | * | |
| startDatetime | * | |
| endDatetime | * | 
# immediateDeepWatchHandlerForChartUpdate()
Otherwise, multiple watchers compete for the same action
# injectJWTAndLanguageParametersToURL(url)
Parameters:
| Name | Type | Description | 
|---|---|---|
| url | String | i.g https://dev-geored.geored.fr/desktop | 
Example
Input: https://dev-geored.geored.fr/desktop
 Output: https://dev-geored.geored.fr/desktop?_token=JWT&lg=fr# isMapSelectablePolylinesFeatureEnabled()
Polylines can be click. A popup is shown. Used by Location - History - Vehicle/Driver/Circuit (Main search) Enable by default
# isSearchModuleDatePickerDisabledHandler()
Some clients do not have right to history mode on certain tab (i.g circuit)
# isSearchModuleDatePickerEnabled()
Some clients do not have right to history mode at all
# isValidPositionId(positionId)
Valid APIV3 position id has the following format: {serverId}{boxId}{timestamp80}
Count the number of occurences of one character in the string ("41_123_12312312312".match(new RegExp("_", "g")) || []).length
Parameters:
| Name | Type | Description | 
|---|---|---|
| positionId | * | 
# linestringsToPolylines(linestrings)
Used by: Location - Real-time - Circuit Location - Circuit tab Location - History tab Diagnostics Converts Array of items containing a linestring property (APV2 format) into an array of polylines (Format accepted by LeafletMap wrapper) The linestring property can be either an string or an array (multiple linestrings) (#31781)
Parameters:
| Name | Type | Description | 
|---|---|---|
| linestrings | String | Array of LatLng I.g: "lat1 lng1, lat2 lng2" | 
# loginWithToken(jwt, viewPath)
Used by dev to login quicky into a view
Parameters:
| Name | Type | Description | 
|---|---|---|
| jwt | * | |
| viewPath | String | ig diagnostics | 
# mutateNormalize(item)
Normalize Zone to APIV3 entity format
Parameters:
| Name | Type | Description | 
|---|---|---|
| item | * | 
# normalizeAnalyzeHistorySegment(response)
Used by Diagnostic module
Parameters:
| Name | Type | Description | 
|---|---|---|
| response | * | 
- To Do:
- 
        - Refactor/Move into entity "diagnostic-analysis-entity"
 
# normalizeAPIV3Item(item)
Parameters:
| Name | Type | Description | 
|---|---|---|
| item | Object | Object to transform | 
- To Do:
- 
        - Immatriculation
 
# normalizeChronoResponseDetails(item)
Parameters:
| Name | Type | Description | 
|---|---|---|
| item | * | 
- To Do:
- 
        - Map type to custom values ['driving', 'available', 'resting', 'working'],
 
# normalizeCircuitActivityItem()
# normalizeCircuitExecutionDetailsItem(item)
Transform/Presenter function for circuit execution details item
Parameters:
| Name | Type | Description | 
|---|---|---|
| item | * | Details item from APIV2 Historique by_circuit_dates or APIV2 dernier_circuit | 
# normalizeLatLng(latOrLng)
Server stores Lat/Lng coordinates as Integer values.
Parameters:
| Name | Type | Description | 
|---|---|---|
| latOrLng | * | 
# normalizePositionTorsForDiagnosticsModule(position, activeTorPositions, sensorAssignments)
Will inject startTimestamp/endTimestamp to TORs with measureType "temps" (Those attributes are then used to render a duration chart)
Parameters:
| Name | Type | Description | 
|---|---|---|
| position | * | |
| activeTorPositions | * | |
| sensorAssignments | * | 
# normalizeTripHistoryItem()
# normalizeVehicleHistoryPositions(positions, vehicleId)
Unused
Parameters:
| Name | Type | Description | 
|---|---|---|
| positions | Array | |
| vehicleId | String | 
# normalizeWmsOptions(options)
Creates the projection object (crs) just before configuring leaflet tilelayer
Parameters:
| Name | Type | Description | 
|---|---|---|
| options | * | 
# onAnimate(currentIndex)
Parameters:
| Name | Type | Description | 
|---|---|---|
| currentIndex | * | 
- To Do:
- 
        - Drawing operations could be split using requestAnimationFrame
 
# onSearchModuleDatePickerPredefinedSelectionClick()
Provide handler to react to date picker predefined options change and limit date range selection if necessary
- See:
- 
        - SMDatePicker.vue Date picker will inject this handler
 
# openMapToolboxFeature(featureName)
Used internally to open reverse geocoding view if map menu context option "nearby vehicles" is clicked
Parameters:
| Name | Type | Description | 
|---|---|---|
| featureName | * | 
# parseHistoryItem(item)
Parses item from API /v2/historique/
- Circuit: by_circuit_dates
- Vehicle/Driver: by_vehicule_dates/by_chauffeur_dates
Parameters:
| Name | Type | Description | 
|---|---|---|
| item | Object | |
| options.selectionType | String | vehicle/driver/circuit | 
| options.relatedPolylines | Array | 
# parseLocationItem(item, options, rootGetters)
Parses Location module item from main search Item comes from API (temp reel / historique)
Parameters:
| Name | Type | Description | 
|---|---|---|
| item | * | |
| options | * | |
| rootGetters | * | 
- To Do:
- 
        - Refactor/Move into services/entities/location-main-search-entity
 
# parseLocationItemDates(item, options)
Parse dates fields from both real-time/history
Parameters:
| Name | Type | Description | 
|---|---|---|
| item | * | |
| options | * | 
# parseLocationItemSensors(item)
Parses sensor infos (Temp reel)
Parameters:
| Name | Type | Description | 
|---|---|---|
| item | * | 
# performMultipleSearch()
While in "Free search" (Input in on top of map), the user can combine vehicles/drivers/circuits. For now, we should call the APIs separately, at the same time (Multiple search)
# pickColor(conso, panel) → {string}
Get linestring color for given conso.
Parameters:
| Name | Type | Description | 
|---|---|---|
| conso | ||
| panel | 
string
    # reactToMapPredefinedViewsListUpdate()
Used MapPredefinedViewSettingsSelect.vue to update itself if an item is added/removed.
# reduceAttributesIntoNestedProperty(obj, attribute)
Used by Datatable library. Datatable expects a language property which is a nested object: https://www.datatables.net/plug-ins/i18n/English But we store translations in a plain object:
- datatable.paginate.next
- datatable.paginate.prev This function will collect all the keys starting with datatable. and build a nested object similar to the one expected by datatable.
Parameters:
| Name | Type | Description | 
|---|---|---|
| obj | Object | Plain object | 
| attribute | String | Object attribute (Computed nested object) | 
# saveSettingsParamLocally(name, value)
Uses browser client-side storage.
Parameters:
| Name | Type | Description | 
|---|---|---|
| name | String | |
| value | Any | |
| options.suffix | String | Optional | 
# saveSettingsParamRemotely(name, value)
Used to save defaultMapZoomLevel and userBaseLayer Used to save defaultMapPredefinedView
Parameters:
| Name | Type | Description | 
|---|---|---|
| name | * | |
| value | * | 
# SensorPopupSectionMixin()
Retrieves position details (including sensor infos) from vehicle_id and date.
# setHigherMapToolboxZIndex()
Svelte module context patron: https://svelte.dev/tutorial/module-exports
# setLowerMapToolboxZIndex()
This was added to prevent the map toolbox from overlapping on top of other components (because of his position being absolute).
Faq: This map toolbox is associated to the map, why is being present when the map is hidden? Because this component is wrapped in a portal (portal-vue)
Used by Location (Full table mode) Used by Routing (Full table mode)
Svelte module context patron: https://svelte.dev/tutorial/module-exports
# SimplicitiLoggerPlugin()
This plugin will automatically catch all errors. and send them to server (APIV3)
If the error states 'Script Error', take a look at: https://scotch.io/bar-talk/what-the-heck-is-script-error
- Deprecated:
- server logging disabled due to Sentry being enough (and some APIV3 issues)
 
Example
Usage (From outside components)
 Vue.ErrorLogger.logError(error)
 Usage (From inside components)
 this.$logError(error)
 Usage (Listen errors)
 Vue.ErrorLogger.$on("error")# sortableColumn()
- To Do:
- 
        - Refactor/Extract
 
View Source components/location/LocationEvents/LocationEventsTable.vue, line 18
# updateCanSection()
Will update Can section with Can information from API
# updateCircuitExecutionDetails() → {Boolean}
Real-time: Load last circuit execution details History: Load related circuit execution details
True if success
Boolean
    # updateTorAnaSection()
Will update popupSections with Tor/Ana information from API
# useMapToolbox()
# watchAndReactToMapMenuContextOptions()
- Will open reverse geocoding view automatically
Type Definitions
Object
    
# dynamicToggleControlSectionsMixin
Dynamic toggle control sections allow us to define toggle controls once. Each toggle control will automatically show/hide itself and show/hide related leaflet layers.
- To Do:
- 
        - Refactor existing layers toggles (i.g zone) into a dynamic section Note: Add extra sections in the related vuex store "map_options/index.js"
 
View Source components/location/MapOptions/MapOptions.vue, line 22