diff --git a/.vscode/settings.json b/.vscode/settings.json
index 3b6153d..6c7f886 100644
--- a/.vscode/settings.json
+++ b/.vscode/settings.json
@@ -27,6 +27,7 @@
"plss",
"PROJECTCATEGORYFUNDING",
"sgid",
+ "shapefile",
"sitla",
"srid",
"tagname",
diff --git a/search.html b/search.html
new file mode 100644
index 0000000..15aa896
--- /dev/null
+++ b/search.html
@@ -0,0 +1,5 @@
+
+
+
+
+
diff --git a/src/App.tsx b/src/App.tsx
index 4242f7d..08558dc 100644
--- a/src/App.tsx
+++ b/src/App.tsx
@@ -100,7 +100,7 @@ export default function App() {
-
+
{
+ return (
+
+
Something went wrong:
+
{error.message}
+
+ );
+};
+
+esriConfig.assetsPath = import.meta.env.MODE === 'production' ? '/wri/js/ugrc/assets' : '/js/ugrc/assets';
+
+export default function App() {
+ return (
+
+
+
+
+ );
+}
diff --git a/src/components/AreaOfInterest.tsx b/src/components/AreaOfInterest.tsx
new file mode 100644
index 0000000..bfb49bd
--- /dev/null
+++ b/src/components/AreaOfInterest.tsx
@@ -0,0 +1,23 @@
+import { Button, ToggleButton } from '@ugrc/utah-design-system';
+import { useRef } from 'react';
+
+export const AreaOfInterest = () => {
+ const areaOfInterestNode = useRef(null);
+
+ return (
+
+
Area of Interest
+
+
+ (areaOfInterestNode.current!.value = value.toString())}>
+ Draw a polygon
+
+
+
+
+
+
+
+
+ );
+};
diff --git a/src/components/MapContainer.tsx b/src/components/MapContainer.tsx
index c37217d..4dcfe14 100644
--- a/src/components/MapContainer.tsx
+++ b/src/components/MapContainer.tsx
@@ -42,7 +42,7 @@ type SelectorOptions = {
position: 'top-left' | 'top-right' | 'bottom-left' | 'bottom-right';
};
-export const MapContainer = () => {
+export const MapContainer = ({ configuration }: { configuration: 'search' | 'edit' }) => {
const mapNode = useRef(null);
const mapComponent = useRef(null);
const mapView = useRef(null);
@@ -101,7 +101,7 @@ export const MapContainer = () => {
if (isReady) {
// layers are stacked on top of each other in a reverse order from how they are listed
// e.g. land ownership is on the very bottom and centroids are on the very top
- addLayers([
+ const referenceLayers = [
landOwnership,
plss,
streams,
@@ -114,14 +114,18 @@ export const MapContainer = () => {
forestService,
sageGrouse,
stewardship,
- polygons,
- lines,
- points,
- centroids,
- ]);
+ ];
+ const operationalLayers = [polygons, lines, points, centroids];
+
+ if (configuration === 'search') {
+ operationalLayers.forEach((x) => (x.visible = false));
+ addLayers(operationalLayers);
+ } else {
+ addLayers(referenceLayers.concat(operationalLayers));
+ }
}
setMapView(mapView.current!);
- }, [isReady, mapView, addLayers, setMapView]);
+ }, [isReady, mapView, addLayers, setMapView, configuration]);
return (
<>
diff --git a/src/components/index.ts b/src/components/index.ts
index c74121d..a261684 100644
--- a/src/components/index.ts
+++ b/src/components/index.ts
@@ -1,3 +1,4 @@
+export * from './AreaOfInterest.tsx';
export * from './CentroidToggle.tsx';
export * from './FeatureData.tsx';
export * from './Loaders.tsx';
diff --git a/src/mainSearch.tsx b/src/mainSearch.tsx
new file mode 100644
index 0000000..b2857cd
--- /dev/null
+++ b/src/mainSearch.tsx
@@ -0,0 +1,14 @@
+import '@arcgis/core/assets/esri/themes/light/main.css';
+import React from 'react';
+import { createRoot } from 'react-dom/client';
+import App from './AppSearch';
+import { MapProvider } from './components/contexts';
+import './index.css';
+
+createRoot(document.getElementById('root')!).render(
+
+
+
+
+ ,
+);
diff --git a/vite.config.ts b/vite.config.ts
index 1f59789..b262680 100644
--- a/vite.config.ts
+++ b/vite.config.ts
@@ -17,6 +17,7 @@ export default defineConfig(({ mode }) => {
input: {
main: resolve(__dirname, 'map.html'),
dev: resolve(__dirname, 'index.html'),
+ search: resolve(__dirname, 'search.html'),
},
},
},