Blank Brick Dataset Schema
I created a blank brick to track office locations in the path of hurricane Beryl. My ETL produces a dataset with latitude and longitude in decimal. Now my blank brick is showing these values as integers. They are not integer. How do I force the blank brick to re-evaluate the schema. I tried reloading and reassigning.
I also tried the toolkit under admin. It shows the schema with decimal values.
What made the brick start treating them as integer?
** Was this post helpful? Click Agree or Like below. **
** Did this solve your problem? Accept it as a solution! **
Best Answer
-
@ArborRose I found your issue. On your javascript line 24 (and on line 42 of your example data) you are "Check[ing] if latitude and longitude are valid".
However, because the longitude always happens to be a negative number (a falsey boolean) in your dataset your function is bypassing the if statement and not adding the data to your mapping.
*This is a wonderful quirk of javascript that does not exist in Python/Ruby/PHP/C/C++/Java** Was this post helpful? Click 💡/💖/👍/😊 below. **
** If it solved your problem. Accept it as a solution! ✔️ **
Or do you need more help? https://calendly.com/matthew-kastner/15-minute-chat
Did I help you out? Feedback is priceless and will help me more than you know.Write a review!1
Answers
-
So if you view the data in the dataset its all decimals but when you get to the brick it shows as all integers?
0 -
Yes, correct. My dataset has the values as decimal. And the schema confirms it.
In my code, I created "data2" as a set of values typed in rather than the dataset. Those values plot just fine. You can see one on Dallas and another on Houston.
But the dataset values are not plotting on my map because the dataset is somehow not allowing them to stay in decimal format.This is scary because I am currently working on an accounts receivable brick that has a lot of columns. I cringe at the thought that Domo might suddenly warp my dataset on the way in.
** Was this post helpful? Click Agree or Like below. **
** Did this solve your problem? Accept it as a solution! **0 -
For Eric or anyone who wants my code, I include it below. In fact, I should include @eddiesmall, as this is method people may want to incorporate into infographics. For my purpose, I am tracking hurricane Beryl so we can keep an eye on our medical offices along its path. You can join your Domo address information with a city location database containing longitude and latitude data.
html:<div id="map" style="height: 800px; width: 100%;"></div> <link rel="stylesheet" href="https://unpkg.com/leaflet@1.9.4/dist/leaflet.css" /> <script src="https://unpkg.com/leaflet@1.9.4/dist/leaflet.js"></script>
function initMap() { // Create a map centered on Texas var map = L.map('map').setView([31.9686, -99.9018], 6); // Add OpenStreetMap tile layer L.tileLayer('https://{s}.tile.openstreetmap.org/{z}/{x}/{y}.png', { attribution: '© <a href="https://www.openstreetmap.org/copyright">OpenStreetMap</a> contributors' }).addTo(map); // Define a smaller dot style var dotStyle = { radius: 5, // Size of the dot fillColor: '#ff7800', // Dot color color: '#000', // Dot border color weight: 1, // Border thickness opacity: 1, // Border opacity fillOpacity: 0.8 // Dot fill opacity }; // Fetch data from `dataset0` domo.get('/data/dataset0').then(function(response) { response.forEach(function(record) { // Check if latitude and longitude are valid if (record.latitude && record.longitude) { L.circleMarker([record.latitude, record.longitude], dotStyle) .addTo(map) .bindPopup(record.name + '<br>' + record.address_line1 + '<br>' + record.city + ', ' + record.state + ' ' + record.zipcode); } }); }).catch(function(error) { console.error('Error fetching data from dataset0:', error); }); // Example data var data2 = [ {latitude: 32.78, longitude: -96.80, name: 'Dallas, TX', address_line1: '123 Main St', city: 'Dallas', state: 'TX', zipcode: '75201'}, {latitude: 29.76, longitude: -95.37, name: 'Houston, TX', address_line1: '456 Elm St', city: 'Houston', state: 'TX', zipcode: '77002'} ]; // Add dots for each location data2.forEach(function(record) { if (record.latitude && record.longitude) { L.circleMarker([record.latitude, record.longitude], dotStyle) .addTo(map) .bindPopup(record.name + '<br>' + record.address_line1 + '<br>'); } }); } // Initialize the map initMap();
css:
/* Style for the map container */ #map { height: 100%; width: 100%; }
** Was this post helpful? Click Agree or Like below. **
** Did this solve your problem? Accept it as a solution! **0 -
@ArborRose I found your issue. On your javascript line 24 (and on line 42 of your example data) you are "Check[ing] if latitude and longitude are valid".
However, because the longitude always happens to be a negative number (a falsey boolean) in your dataset your function is bypassing the if statement and not adding the data to your mapping.
*This is a wonderful quirk of javascript that does not exist in Python/Ruby/PHP/C/C++/Java** Was this post helpful? Click 💡/💖/👍/😊 below. **
** If it solved your problem. Accept it as a solution! ✔️ **
Or do you need more help? https://calendly.com/matthew-kastner/15-minute-chat
Did I help you out? Feedback is priceless and will help me more than you know.Write a review!1 -
@MattTheGuru - Interesting catch. Thanks. But it won't fix anything if the dataset is defining those values as integers. {Look at the screenshots of the dataset table.}
** Was this post helpful? Click Agree or Like below. **
** Did this solve your problem? Accept it as a solution! **0 -
It appears my issue was in the fetching of the dataset. Here's code that works. Thank you Matt.
function initMap() { // Create a map centered on Texas var map = L.map('map').setView([31.9686, -99.9018], 6); // Add OpenStreetMap tile layer L.tileLayer('https://{s}.tile.openstreetmap.org/{z}/{x}/{y}.png', { attribution: '© <a href="https://www.openstreetmap.org/copyright">OpenStreetMap</a> contributors' }).addTo(map); // Define a smaller dot style var dotStyle = { radius: 5, // Size of the dot fillColor: '#ff7800', // Dot color color: '#000', // Dot border color weight: 1, // Border thickness opacity: 1, // Border opacity fillOpacity: 0.8 // Dot fill opacity }; // Function to check if a value is a valid number function isValidNumber(value) { return typeof value === 'number' && !isNaN(value); } // Fetch data from `dataset0` domo.get('/data/v1/dataset0').then(function(response) { // Log fetched data to a div const logDiv = document.createElement('div'); logDiv.innerHTML = '<strong>Fetched data from dataset0:</strong><br>' + JSON.stringify(response, null, 2); document.body.appendChild(logDiv); response.forEach(function(record) { // Log each record to a div const recordDiv = document.createElement('div'); recordDiv.innerHTML = '<strong>Record:</strong><br>' + JSON.stringify(record, null, 2); document.body.appendChild(recordDiv); // Check if latitude and longitude are valid numbers if (isValidNumber(record.latitude) && isValidNumber(record.longitude)) { const validCoordDiv = document.createElement('div'); validCoordDiv.innerHTML = '<strong>Valid coordinates:</strong><br> Latitude: ' + record.latitude + ', Longitude: ' + record.longitude; document.body.appendChild(validCoordDiv); L.circleMarker([record.latitude, record.longitude], dotStyle) .addTo(map) .bindPopup(record.name + '<br>' + record.address_line1 + '<br>' + record.city + ', ' + record.state + ' ' + record.zipcode); } else { const invalidCoordDiv = document.createElement('div'); invalidCoordDiv.innerHTML = '<strong>Invalid coordinates:</strong><br> Latitude: ' + record.latitude + ', Longitude: ' + record.longitude; document.body.appendChild(invalidCoordDiv); } }); }).catch(function(error) { const errorDiv = document.createElement('div'); errorDiv.innerHTML = '<strong>Error fetching data from dataset0:</strong><br>' + error; document.body.appendChild(errorDiv); console.error('Error fetching data from dataset0:', error); }); } // Initialize the map initMap();
** Was this post helpful? Click Agree or Like below. **
** Did this solve your problem? Accept it as a solution! **1
Categories
- All Categories
- 1.8K Product Ideas
- 1.8K Ideas Exchange
- 1.5K Connect
- 1.2K Connectors
- 300 Workbench
- 6 Cloud Amplifier
- 8 Federated
- 2.9K Transform
- 100 SQL DataFlows
- 616 Datasets
- 2.2K Magic ETL
- 3.8K Visualize
- 2.5K Charting
- 738 Beast Mode
- 56 App Studio
- 40 Variables
- 684 Automate
- 176 Apps
- 452 APIs & Domo Developer
- 46 Workflows
- 10 DomoAI
- 35 Predict
- 14 Jupyter Workspaces
- 21 R & Python Tiles
- 394 Distribute
- 113 Domo Everywhere
- 275 Scheduled Reports
- 6 Software Integrations
- 123 Manage
- 120 Governance & Security
- 8 Domo Community Gallery
- 38 Product Releases
- 10 Domo University
- 5.4K Community Forums
- 40 Getting Started
- 30 Community Member Introductions
- 108 Community Announcements
- 4.8K Archive