“Search as you type” uses AI to find the address based on users input.
Easily Added by Anyone - The video below demonstrates how SimplyCompleteAI Address Finder can be easily added to almost any Web Site or Web App by adding a ONE simple line of HTML. The AI-assisted Address Finder can be easily Setup and Styled with our "Page Assist" wizard as shown in the video.
Experienced Web Developers - For those with the skills and demand, once set up (via "Page Assist"), the site-specific Address Finder code can be downloaded from your API link. The JavaScript class can be built into your specific page/application build. More about the SimplyCompleteAI Class
The following example illustrates how to integrate Address Finder into your website or web app, following the video at the top of the page.
We have a full Address Finder demo restricted to 15 searches per day, which shows the code in action, with search from the Dedicated Search Field and from the First Line of Address in a form. Which is discussed in the tutorial below.
Try Demo Address Finder Discussed on this page
The API key identifies your account; under the online account 'SimplyCompleteAI' tab, you can restrict your key to work only from sites of defined origin.
Open Trial Account
Once the account is created, we can generate a single line of HTML to add to your page and utilize the "Page Assist" wizard to map the address fields correctly. Lets proceed...
Under the 'SimplyCompleteAI' tab, press Add to your Web Page.
'SimplyCompleteAI' tab to add SimplyCompleteAI definitions
Give a name tells you what this is. Such as "Checkout", "Contact Form" or "Main Address".
Set Search Options
Press Next
Set Address Finder Search Options
Set Search Options and here we can specify a Origin Filter to make sure no one else uses your API Key. We suggest you leave this blank until you have everything running. Then apply a filter.
HTML to add to your page.
Next press Copy to copy the line of code. Add this line to any part of <head> or <body> section of the web page. Best at the bottom of <body> section if possible, then only runs after everything is loaded.
<head>
<body>
Download this Example Form used in this tutorial
In the example form, we have two main address sections and two completely different Address Finder form layouts, which shows SimplyCompleteAI's flexibility.
Here are the text inputs without formatting HTML:
Address Finder in Dedicated Search Field
Example 1 - Search in Dedicated Search Field <input type="text" class="form-control " id="dedicatedSearchField" autocomplete="off"> <textarea class="form-control" id="wholeaddress" rows="11"></textarea><br> <input type="text" class="form-control" id="geoposition" > <input type="text" class="form-control" id="geodistance" >
<input type="text" class="form-control " id="dedicatedSearchField" autocomplete="off"> <textarea class="form-control" id="wholeaddress" rows="11"></textarea><br> <input type="text" class="form-control" id="geoposition" > <input type="text" class="form-control" id="geodistance" >
Where 'dedicatedSearchField' is the search text field, to enable the Address Finder, to search from.
'dedicatedSearchField'
Address Finder in First Line of Address
Here the address finder is active or the first line of the Address in the form:
Example 2 - Search in First Line of Address <input type="text" class="form-control" id="organisation" > <input type="text" class="form-control " id="line1" > <input type="text" class="form-control" id="line2" > <input type="text" class="form-control" id="line3" > <input type="text" class="form-control" id="town" > <input type="text" class="form-control" id="county" > <input type="text" class="form-control" id="postcode" > <input type="text" class="form-control" id="country" >
<input type="text" class="form-control" id="organisation" > <input type="text" class="form-control " id="line1" > <input type="text" class="form-control" id="line2" > <input type="text" class="form-control" id="line3" > <input type="text" class="form-control" id="town" > <input type="text" class="form-control" id="county" > <input type="text" class="form-control" id="postcode" > <input type="text" class="form-control" id="country" >
Where organisation is the search text field, to enable the Address Finder, to search from. After search it will contain the address organisation after the search.
organisation
These two search fields are styled with the simplycomplete class; the wizard allows them to be styled, but they can be overridden. The style and placement text denotes to the user they are for Address Finder fields. More information
simplycomplete
Next we add the line of code you copied from the 'SimplyCompleteAI' tab when we created the SimplyCompleteAI definition in your online account.
Script line added to page <script type='text/javascript' src='https://api.simplylookupadmin.co.uk/pageassist/addtopage.min/v1/API KEY'> </script >
<script type='text/javascript' src='https://api.simplylookupadmin.co.uk/pageassist/addtopage.min/v1/API KEY'> </script >
After adding the line your your web page. Refresh the web page, and you should see a small button appear at the bottom right of the page:
Upload Page Structure Button
Press the 1 Upload Page Structure button on your page to read your page structure. This will send all web field IDs to Page Assist. If you have many, type a value into the field you are interested in mapping to search. Page Assist will show these values against the mapping selection in the wizard.
All Page Assist Buttons visible after Structure Upload
Then press the 2 Open Page Assist button to edit the mappings. This will open the Page Assist page:
Page Assist Name, Search Options and Security
The first tab offers many of the settings you see in the online account
The second tab "Style" allows the basic style of the search fields and list:
Style the Address Finder list and search field
Next, we can move on to mapping your fields to the Daily Updated Simply Postcode PAF Address Data. In this case from a dedicated search field:
Mapping Example 1 to web fields
Here we have written in the wholeaddress field organisation[NL]line1[NL]line2[NL]line3[NL]town[NL]postcode[NL]country which puts new line between each address field. We can also have the addres comma delimited by using organisation[,]line1[,]line2[,]line3[,]town[,]county[,]postcode[,]country.
wholeaddress
organisation[NL]line1[NL]line2[NL]line3[NL]town[NL]postcode[NL]country
organisation[,]line1[,]line2[,]line3[,]town[,]county[,]postcode[,]country
And, in our second example, from the first line of the address.
Mapping Example 2 to web fields
Now press the green Save button and go back to your web page and press the 3 Refresh Page button. We should now have styled the designed search fields, with placemenet text to tell the user they are Address Finder search fields:
After Page refresh SimplyCompleteAI is now activate
Now Test, Edit, Save, and Refine your mappings.
To protect your API key from being used on someone else's website, set the origin filter in your online account under the "SimplyCompleteAI" tab or in the "Page Assist" settings.
Finally, turn off "Edit Mode" at the top right of the Page Assist page. Hit the big red button Exit Edit Mode.
Turn off "Edit Mode" top Right
To re-enable it, you need to go to the 'SimplyCompleteAI' tab in your online account and press Edit to switch back on in the second page of the wizard.
Turn "Edit Mode" back on under the SimplyCompleteAI tab
The Address Finder Advanced options page allows:
Turn off "Edit Mode"
The Page Assist wizard allows us to quickly setup and apply styling. Should you want to define your own styles, tick the "Manual Style the Page with Stylesheet" option at the bottom of the "style" page of the wizard. Then define:
SimplyCompleteAI styles
style /* SimplyCompleteAI styles for search box */ /* Search box */ .simplycomplete { width: 100%; padding: 10px; font-size: 16px;background-color: #e3f2fd; border: 3px solid #ced4da; } .simplycomplete::placeholder { color: #afaeae; font-style: italic; } /* Search List */ .simplysuggestions { font-family: Arial, Helvetica, sans-serif; font-size: 16px; line-height: 1.5em; border: 1px solid #ccc; max-height: 450px; overflow-y: auto; position: absolute; background: white; width: calc(100% - 2px); display: none; z-index: 3; }
/* SimplyCompleteAI styles for search box */ /* Search box */ .simplycomplete { width: 100%; padding: 10px; font-size: 16px;background-color: #e3f2fd; border: 3px solid #ced4da; } .simplycomplete::placeholder { color: #afaeae; font-style: italic; } /* Search List */ .simplysuggestions { font-family: Arial, Helvetica, sans-serif; font-size: 16px; line-height: 1.5em; border: 1px solid #ccc; max-height: 450px; overflow-y: auto; position: absolute; background: white; width: calc(100% - 2px); display: none; z-index: 3; }
style .simplysuggestions b { font-size: 1.1em; font-weight: 700; } /* Search List Item */ .simplysuggestion-item { padding: 10px; cursor: pointer; } .simplysuggestion-item:hover, .simplysuggestion-item.highlighted { background-color: #eee; } /* Search Instructions in first line */ .simplyinstructions { color: #e97c17; cursor: default; font-style: italic; font-size: 0.9em; background-color: #f8f9fa !important; } /* Search Instructions Tab to complete */ .simplyinstructionstab { font-weight: 400; color: #0b0ff5 !important; }
.simplysuggestions b { font-size: 1.1em; font-weight: 700; } /* Search List Item */ .simplysuggestion-item { padding: 10px; cursor: pointer; } .simplysuggestion-item:hover, .simplysuggestion-item.highlighted { background-color: #eee; } /* Search Instructions in first line */ .simplyinstructions { color: #e97c17; cursor: default; font-style: italic; font-size: 0.9em; background-color: #f8f9fa !important; } /* Search Instructions Tab to complete */ .simplyinstructionstab { font-weight: 400; color: #0b0ff5 !important; }
For those who wish to include the SimplyCompleteAI code either within a web build or hosted on their own server, once set up, you can download the SimplyCompleteAI code to include in your web offering.
To get a minified version we call https://api.simplylookupadmin.co.uk/pageassist/addtopage.min/v1/API KEY"" or an unminified version "https://api.simplylookupadmin.co.uk/pageassist/addtopage.unmin/v1/API KEY".
https://api.simplylookupadmin.co.uk/pageassist/addtopage.min/v1/API KEY"
"https://api.simplylookupadmin.co.uk/pageassist/addtopage.unmin/v1/API KEY"
Obviously the unminified version is easier to understand. Here is a brief outline of the functions:
Firstly, we define a class called SimplyComplete, which contains all the functionality. Then, when the DOM is loaded, we initialise this class with the API key and other values set by "Page Assist". The "Page Assist" settings also alter the generated code in order to make it as efficient and short as possible.
SimplyComplete
The class initialiser then calls .setupInputs() to style and add hooks to the Address Finder Fields from the list specified settings. This adds class='simplycomplete' to each designated search box, and if style is set by "Page Assist" then it appends the 'simplycomplete' style configuration to the page.
.setupInputs()
class='simplycomplete'
When an address is selected by the user of the Web Address Finder, the .PAD(details, inputid) function is passed the selected address details (listed in the next section) to populate to populate the form fields. inputid is a number corresponding to the field having searched from.
.PAD(details, inputid)
After the address is selected by the user, the Web Address Finder returns the following data.
For 99% of our customers, they only need the following core address data:
★ - Not required by the Royal Mail to send letters and parcels.
The current License status, or error is returned:
The GeoLocation is returned if known within 100 meters. SimplyCompleteAI will also return straight line distance if a home location is specified (Lat/Long or valid postcode):
The Simply Postcode PAF database contains some additional data returned as follows:
Additional Data Example Postcode SW11 1QG returns address: Flat 6 Carrington Court 21 Limburg Road London SW11 1QG United Kingdom unique1 returns "Flat 6" unique2 returns "Carrington Court" PropertyNo returns "21" PropertyName returns "Carrington Court" StreetName returns "Limburg Road"
Postcode SW11 1QG returns address: Flat 6 Carrington Court 21 Limburg Road London SW11 1QG United Kingdom unique1 returns "Flat 6" unique2 returns "Carrington Court" PropertyNo returns "21" PropertyName returns "Carrington Court" StreetName returns "Limburg Road"