Some projects require that a location must be recorded when a new order is made or whenever a record is modified. Code On Time client library will automatically request the latitude and longitude from the browset with the use of tags on the data field level.
For example, let’s consider the Northwind sample database. When a new order is created, we would like to save the location. Let’s add two pairs columns to the Orders database table, refresh the Orders controller, and tag these fields as coordinates.
Adding Latitude and Longitude to Orders Table
Start SQL Server Management Studio. In the Object Explorer, right-click on Databases / Northwind / Tables / dbo.Orders node, and press Design.
data:image/s3,"s3://crabby-images/1659b/1659bcb8f585a95635ead865c19bf39fe45fed16" alt="Designing the Orders table of the Northwind database. Designing the Orders table of the Northwind database."
Add four more columns with the following values:
Column Name | Data Type | Allow Nulls |
CreatedLatitude | nvarchar(50) | yes |
CreatedLongitude | nvarchar(50) | yes |
ModifiedLatitude | nvarchar(50) | yes |
ModifiedLongitude | nvarchar(50) | yes |
Save the design to add the columns to the table.
Refreshing Orders Controller
Start the web app generator. Click on the project name, and press Refresh. Check the box next to Orders controller, and click Refresh.
data:image/s3,"s3://crabby-images/31787/31787aa79b7c40a5f003023c5453f10b33726302" alt="Refreshing the Orders controller. Refreshing the Orders controller."
Tagging the Data Fields
Press Design to activate the Project Designer. In the Project Explorer, switch to the Controllers tab. Double-click on Orders / Views / editForm1 / c1- Orders / CreatedLatitude (String(50)) data field node.
data:image/s3,"s3://crabby-images/1e061/1e06130d2a92a1021ec17b5952e6a7815431b50f" alt="'CreatedLatitude' data field of view 'editForm1' in the Orders controller. 'CreatedLatitude' data field of view 'editForm1' in the Orders controller."
Add a tag to the data field:
Property | New Value |
Tags | created-latitude |
Press OK to save. Double-click on Orders / Views / editForm1 / c1- Orders / CreatedLongitude (String(50)) data field node.
data:image/s3,"s3://crabby-images/c6796/c67969fcf3d550aad24892b771876e4d43ad2625" alt="'CreatedLongitude' data field of view 'editForm1' in the Orders controller. 'CreatedLongitude' data field of view 'editForm1' in the Orders controller."
Add the following tag:
Property | New Value |
Tags | created-longitude |
Save the data field. Double-click on Orders / Views / editForm1 / c1- Orders / CreatedLongitude (String(50)) data field node.
data:image/s3,"s3://crabby-images/ee944/ee94419417b13870019b507d92081abe528ef4e4" alt="'ModifiedLatitude' data field of view 'editForm1' in the Orders controller. 'ModifiedLatitude' data field of view 'editForm1' in the Orders controller."
Use this tag:
Property | New Value |
Tags | modified-latitude |
Save the item. Double-click on Orders / Views / editForm1 / c1- Orders / ModifiedLongitude (String(50)) data field node.
data:image/s3,"s3://crabby-images/dead8/dead8382fb9a27f53987cc4e655b7d0ab8f43a4e" alt="'ModifiedLongitude' data field of view 'editForm1' in the Orders controller. 'ModifiedLongitude' data field of view 'editForm1' in the Orders controller."
Use this tag:
Property | New Value |
Tags | modified-longitude |
Save the data field.
Now, repeat the steps above to assign the correct tags to the relevant data fields in createForm1 view.
It is also possible to store latitude and longitude in the same field in the form “[latitude],[longitude]” by using the tags “created-coords” and “modified-coords.”
Viewing the Results
On the toolbar, press Browse. Navigate to the Orders page. Create a new record. A request for permission will be triggered – every browser will display it differently.
data:image/s3,"s3://crabby-images/b0273/b027390a0a0cc45f10f06169c39a630f8bc2310e" alt="Internet Explorer 9 requesting permission for the site to track physical location. Internet Explorer 9 requesting permission for the site to track physical location."
Allow the website location request for the session or site. Press Cancel and open the create form again. Both sets of coordinates will be updated. Note that the data fields are read-only.
data:image/s3,"s3://crabby-images/2afe4/2afe405fc5f21022ca30aa756c098318c5083518" alt="All coordinate fields are updated with the values supplied by the browser. All coordinate fields are updated with the values supplied by the browser."
Save the record and edit the record again. Note that only Modified Latitude and Longitude values are changed.
data:image/s3,"s3://crabby-images/00352/003529045112180f92db23bfee2d924320515ae9" alt=""Modified" coordinates updated with the values supplied by the browser. "Modified" coordinates updated with the values supplied by the browser."