e.buffer.length&&((X=new Uint8Array(t+p)).set(e.buffer),e.buffer=X),D=y.input_end,X=y.is_uncompressed,y.is_metadata)for(y=void 0,y=(W=i).bit_pos_+7&-8,W.readBits(y-W.bit_pos_);0>>O.bit_pos_,O.bit_pos_+=8,++k,--x;if(B+(g=O.bit_end_pos_-O.bit_pos_>>3)>he.IBUF_MASK){for(var re=he.IBUF_MASK+1-B,U=0;U>6)?(A-=2,-1):0,H=be.kInsertRangeLut[A]+(q>>3&7),A=be.kCopyRangeLut[A]+(7&q),oe=be.kInsertLengthPrefixCode[H].offset+i.readBits(be.kInsertLengthPrefixCode[H].nbits),R=be.kCopyLengthPrefixCode[A].offset+i.readBits(be.kCopyLengthPrefixCode[A].nbits),n=d[t-1&s],r=d[t-2&s],M=0;M>=f))<<(A=1+(V>>1)))-4)+i.readBits(A)<=pe.minDictionaryWordLength&&R<=pe.maxDictionaryWordLength))throw new Error("Invalid backward reference. pos: "+t+" distance: "+N+" len: "+R+" bytes left: "+p);var le=pe.offsetsByLength[R],A=N-F-1,H=pe.sizeBitsByLength[R],q=A>>H;if(le+=(A&(1<>=1;return(e&n-1)+n}function y(e,t,n,r,o){for(;e[t+(r-=n)]=new v(o.bits,o.value),0>n),s,l,new v(i-n&255,65535&m[b++])),a=g(a,i)}return f}},"dec/prefix.js":function(e,t,n){function r(e,t){this.offset=e,this.nbits=t}n.kBlockLengthPrefixCode=[new r(1,2),new r(5,2),new r(9,2),new r(13,2),new r(17,3),new r(25,3),new r(33,3),new r(41,3),new r(49,4),new r(65,4),new r(81,4),new r(97,4),new r(113,5),new r(145,5),new r(177,5),new r(209,5),new r(241,6),new r(305,6),new r(369,7),new r(497,8),new r(753,9),new r(1265,10),new r(2289,11),new r(4337,12),new r(8433,13),new r(16625,24)],n.kInsertLengthPrefixCode=[new r(0,0),new r(1,0),new r(2,0),new r(3,0),new r(4,0),new r(5,0),new r(6,1),new r(8,1),new r(10,2),new r(14,2),new r(18,3),new r(26,3),new r(34,4),new r(50,4),new r(66,5),new r(98,5),new r(130,6),new r(194,7),new r(322,8),new r(578,9),new r(1090,10),new r(2114,12),new r(6210,14),new r(22594,24)],n.kCopyLengthPrefixCode=[new r(2,0),new r(3,0),new r(4,0),new r(5,0),new r(6,0),new r(7,0),new r(8,0),new r(9,0),new r(10,1),new r(12,1),new r(14,2),new r(18,2),new r(22,3),new r(30,3),new r(38,4),new r(54,4),new r(70,5),new r(102,5),new r(134,6),new r(198,7),new r(326,8),new r(582,9),new r(1094,10),new r(2118,24)],n.kInsertRangeLut=[0,0,8,8,0,16,8,16,16],n.kCopyRangeLut=[0,8,0,8,16,0,16,8,16]},"dec/streams.js":function(e,t,n){function r(e){this.buffer=e,this.pos=0}function o(e){this.buffer=e,this.pos=0}r.prototype.read=function(e,t,n){this.pos+n>this.buffer.length&&(n=this.buffer.length-this.pos);for(var r=0;rthis.buffer.length)throw new Error("Output buffer is not large enough");return this.buffer.set(e.subarray(0,t),this.pos),this.pos+=t,t},n.BrotliOutput=o},"dec/transform.js":function(e,t,n){var p=e("./dictionary");function r(e,t,n){this.prefix=new Uint8Array(e.length),this.transform=t,this.suffix=new Uint8Array(n.length);for(var r=0;r'),new r("",0,"\n"),new r("",3,""),new r("",0,"]"),new r("",0," for "),new r("",14,""),new r("",2,""),new r("",0," a "),new r("",0," that "),new r(" ",10,""),new r("",0,". "),new r(".",0,""),new r(" ",0,", "),new r("",15,""),new r("",0," with "),new r("",0,"'"),new r("",0," from "),new r("",0," by "),new r("",16,""),new r("",17,""),new r(" the ",0,""),new r("",4,""),new r("",0,". The "),new r("",11,""),new r("",0," on "),new r("",0," as "),new r("",0," is "),new r("",7,""),new r("",1,"ing "),new r("",0,"\n\t"),new r("",0,":"),new r(" ",0,". "),new r("",0,"ed "),new r("",20,""),new r("",18,""),new r("",6,""),new r("",0,"("),new r("",10,", "),new r("",8,""),new r("",0," at "),new r("",0,"ly "),new r(" the ",0," of "),new r("",5,""),new r("",9,""),new r(" ",10,", "),new r("",10,'"'),new r(".",0,"("),new r("",11," "),new r("",10,'">'),new r("",0,'="'),new r(" ",0,"."),new r(".com/",0,""),new r(" the ",0," of the "),new r("",10,"'"),new r("",0,". This "),new r("",0,","),new r(".",0," "),new r("",10,"("),new r("",10,"."),new r("",0," not "),new r(" ",0,'="'),new r("",0,"er "),new r(" ",11," "),new r("",0,"al "),new r(" ",11,""),new r("",0,"='"),new r("",11,'"'),new r("",10,". "),new r(" ",0,"("),new r("",0,"ful "),new r(" ",10,". "),new r("",0,"ive "),new r("",0,"less "),new r("",11,"'"),new r("",0,"est "),new r(" ",10,"."),new r("",11,'">'),new r(" ",0,"='"),new r("",10,","),new r("",0,"ize "),new r("",11,"."),new r("\xc2\xa0",0,""),new r(" ",0,","),new r("",10,'="'),new r("",11,'="'),new r("",0,"ous "),new r("",11,", "),new r("",10,"='"),new r(" ",10,","),new r(" ",11,'="'),new r(" ",11,", "),new r("",11,","),new r("",11,"("),new r("",11,". "),new r(" ",11,"."),new r("",11,"='"),new r(" ",11,". "),new r(" ",10,'="'),new r(" ",11,"='"),new r(" ",10,"='")];function m(e,t){return e[t]<192?(97<=e[t]&&e[t]<=122&&(e[t]^=32),1):e[t]<224?(e[t+1]^=32,2):(e[t+2]^=5,3)}n.kTransforms=w,n.kNumTransforms=w.length,n.transformDictionaryWord=function(e,t,n,r,o){for(var i,a=w[o].prefix,s=w[o].suffix,d=(o=w[o].transform)<12?0:o-11,c=0,u=t,l=(r>16&255,o[a++]=n>>8&255,o[a++]=255&n;return 2===r?(n=c[e.charCodeAt(s)]<<2|c[e.charCodeAt(s+1)]>>4,o[a++]=255&n):1===r&&(n=c[e.charCodeAt(s)]<<10|c[e.charCodeAt(s+1)]<<4|c[e.charCodeAt(s+2)]>>2,o[a++]=n>>8&255,o[a++]=255&n),o},n.fromByteArray=function(e){for(var t,n=e.length,r=n%3,o="",i=[],a=0,s=n-r;a>18&63]+d[n>>12&63]+d[n>>6&63]+d[63&n]);return r.join("")}(e,s>2])+d[t<<4&63]+"=="):2==r&&(t=(e[n-2]<<8)+e[n-1],o=(o=(o+=d[t>>10])+d[t>>4&63])+d[t<<2&63]+"="),i.push(o),i.join("")};for(var d=[],c=[],u="undefined"!=typeof Uint8Array?Uint8Array:Array,r="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",o=0,i=r.length;o>3);if(commentOffset=1+n+2+1+2+(o<<3)+7>>3,17==r||commentOffset>e.length)return!1;for(var i=r+(6+(o<<4)+(t.length-1<<6)<>>=8)if(e[a]!=(255&i))return!1;return String.fromCharCode.apply(null,e.subarray(commentOffset,commentOffset+t.length))==t}}};function R(t){W(t);var e=w.cacheControl(w[t]),n=w.companyName&&w.productName?w.cachedFetch:w.fetchWithProgress,r=w[t],o=/file:\/\//.exec(r)?"same-origin":void 0;return n(w[t],{method:"GET",companyName:w.companyName,productName:w.productName,productVersion:w.productVersion,control:e,mode:o,onProgress:function(e){W(t,e)}}).then(function(e){return a=e.parsedBody,s=w[t],new Promise(function(e,t){try{for(var n in B){var r,o,i;if(B[n].hasUnityMarker(a))return s&&console.log('You can reduce startup time if you configure your web server to add "Content-Encoding: '+n+'" response header when serving "'+s+'" file.'),(r=B[n]).worker||(o=URL.createObjectURL(new Blob(["this.require = ",r.require.toString(),"; this.decompress = ",r.decompress.toString(),"; this.onmessage = ",function(e){e={id:e.data.id,decompressed:this.decompress(e.data.compressed)};postMessage(e,e.decompressed?[e.decompressed.buffer]:[])}.toString(),"; postMessage({ ready: true });"],{type:"application/javascript"})),r.worker=new Worker(o),r.worker.onmessage=function(e){e.data.ready?URL.revokeObjectURL(o):(this.callbacks[e.data.id](e.data.decompressed),delete this.callbacks[e.data.id])},r.worker.callbacks={},r.worker.nextCallbackId=0),i=r.worker.nextCallbackId++,r.worker.callbacks[i]=e,void r.worker.postMessage({id:i,compressed:a},[a.buffer])}e(a)}catch(e){t(e)}});var a,s}).catch(function(e){var t="Failed to download file "+r;"file:"==location.protocol?c(t+". Loading web pages via a file:// URL without a web server is not supported by this browser. Please use a local development web server to host Unity content, or use the Unity Build and Run option.","error"):console.error(t)})}function N(){var t=performance.now(),p=(Promise.all([R("frameworkUrl").then(function(e){var s=URL.createObjectURL(new Blob([e],{type:"application/javascript"}));return new Promise(function(i,e){var a=document.createElement("script");a.src=s,a.onload=function(){if("undefined"==typeof unityFramework||!unityFramework){var e,t=[["br","br"],["gz","gzip"]];for(e in t){var n,r=t[e];if(w.frameworkUrl.endsWith("."+r[0]))return n="Unable to parse "+w.frameworkUrl+"!","file:"==location.protocol?void c(n+" Loading pre-compressed (brotli or gzip) content via a file:// URL without a web server is not supported by this browser. Please use a local development web server to host compressed Unity content, or use the Unity Build and Run option.","error"):(n+=' This can happen if build compression was enabled but web server hosting the content was misconfigured to not serve the file with HTTP Response Header "Content-Encoding: '+r[1]+'" present. Check browser Console and Devtools Network tab to debug.',"br"==r[0]&&"http:"==location.protocol&&(r=-1!=["localhost","127.0.0.1"].indexOf(location.hostname)?"":"Migrate your server to use HTTPS.",n=/Firefox/.test(navigator.userAgent)?"Unable to parse "+w.frameworkUrl+'!
If using custom web server, verify that web server is sending .br files with HTTP Response Header "Content-Encoding: br". Brotli compression may not be supported in Firefox over HTTP connections. '+r+' See https://bugzilla.mozilla.org/show_bug.cgi?id=1670675 for more information.':"Unable to parse "+w.frameworkUrl+'!
If using custom web server, verify that web server is sending .br files with HTTP Response Header "Content-Encoding: br". Brotli compression may not be supported over HTTP connections. Migrate your server to use HTTPS.'),void c(n,"error"))}c("Unable to parse "+w.frameworkUrl+"! The file is corrupt, or compression was misconfigured? (check Content-Encoding HTTP Response Header on web server)","error")}var o=unityFramework;unityFramework=null,a.onload=null,URL.revokeObjectURL(s),i(o)},a.onerror=function(e){c("Unable to load file "+w.frameworkUrl+"! Check that the file exists on the remote server. (also check browser Console and Devtools Network tab to debug)","error")},document.body.appendChild(a),w.deinitializers.push(function(){document.body.removeChild(a)})})}),R("codeUrl")]).then(function(e){w.wasmBinary=e[1],e[0](w),w.codeDownloadTimeEnd=performance.now()-t}),performance.now()),e=R("dataUrl");w.preRun.push(function(){w.addRunDependency("dataUrl"),e.then(function(t){var e=new TextDecoder("utf-8"),n=0;function r(){var e=(t[n]|t[n+1]<<8|t[n+2]<<16|t[n+3]<<24)>>>0;return n+=4,e}function o(e){if(B.gzip.hasUnityMarker(t))throw e+'. Failed to parse binary data file, because it is still gzip-compressed and should have been uncompressed by the browser. Web server has likely provided gzip-compressed data without specifying the HTTP Response Header "Content-Encoding: gzip" with it to instruct the browser to decompress it. Please verify your web server hosting configuration.';if(B.br.hasUnityMarker(t))throw e+'. Failed to parse binary data file, because it is still brotli-compressed and should have been uncompressed by the browser. Web server has likely provided brotli-compressed data without specifying the HTTP Response Header "Content-Encoding: br" with it to instruct the browser to decompress it. Please verify your web server hosting configuration.';throw e}var i="UnityWebData1.0\0",a=e.decode(t.subarray(0,i.length)),s=(a!=i&&o('Unknown data format (id="'+a+'")'),n+=i.length,r());for(n+s>t.length&&o("Invalid binary data file header! (pos="+n+", headerSize="+s+", file length="+t.length+")");nt.length&&o("Invalid binary data file size! (offset="+d+", size="+c+", file length="+t.length+")"),r()),l=(n+u>t.length&&o("Invalid binary data file path name! (pos="+n+", length="+u+", file length="+t.length+")"),e.decode(t.subarray(n,n+u)));n+=u;for(var f=0,h=l.indexOf("/",f)+1;0;
+ return ;
}
export default App;
diff --git a/src/components/Header.tsx b/src/components/Header.tsx
new file mode 100644
index 0000000..60c6879
--- /dev/null
+++ b/src/components/Header.tsx
@@ -0,0 +1,17 @@
+import { Outlet } from "react-router-dom";
+import BackIcon from "../icons/BackIcon";
+
+const Header = () => {
+ return (
+ <>
+
+ {}
+ >
+ );
+};
+
+export default Header;
diff --git a/src/components/LoaderModal.tsx b/src/components/LoaderModal.tsx
index fce464b..7dd6085 100644
--- a/src/components/LoaderModal.tsx
+++ b/src/components/LoaderModal.tsx
@@ -29,7 +29,7 @@ const LoaderModal = () => {
}, []);
return (
-
+
{
const { sliders } = parameters;
- const [offset, setOffset] = useState(0);
- const [isScroll, setIsScroll] = useState(false);
+ const [offset, setOffset] = useState(1);
+ const [selectedViewId, setSelectedViewId] = useState(apartmentViews[0].id);
+ // const [animationFrame, setAnimationFrame] = useState(0)
const handleOnSwiped = (eventData: SwipeEventData) => {
if (eventData.dir === "Down") {
@@ -30,8 +36,8 @@ const ViewController = ({ parameters }: ViewControllerProps) => {
setOffset(1);
};
- const handleOnTouchEnd = ({ event }: { event: HandledEvents }) => {
- console.log("event", event);
+ const handleOnViewClick = (viewId: number) => {
+ return () => setSelectedViewId(viewId);
};
const handlers = useSwipeable({
@@ -43,33 +49,69 @@ const ViewController = ({ parameters }: ViewControllerProps) => {
// onSwiped: () => console.log("first"),
// onTouchEndOrOnMouseUp: handleOnTouchEnd,
// swipeDuration: 300,
- preventScrollOnSwipe: true,
+ // preventScrollOnSwipe: true,
+ // onSwipedDown: (e) => e.preventDefault(),
});
return (
-
-
-
-
-
-
-
+
+
+
+
+ {apartmentViews.map((view) => (
+
+ {" "}
+ {view.title}
+
+ ))}
+
+
+
+
+
+
+
+
+
+
+ {parameters.perspectiveWorkings.map((working) => (
+

+ ))}
+
+
+
+
+
+ //
);
};
diff --git a/src/icons/BackIcon.tsx b/src/icons/BackIcon.tsx
new file mode 100644
index 0000000..077cf22
--- /dev/null
+++ b/src/icons/BackIcon.tsx
@@ -0,0 +1,18 @@
+const BackIcon = () => {
+ return (
+
+ );
+};
+
+export default BackIcon;
diff --git a/src/main.tsx b/src/main.tsx
index f0bccee..3488fbf 100644
--- a/src/main.tsx
+++ b/src/main.tsx
@@ -2,11 +2,17 @@ import ReactDOM from "react-dom/client";
import { createBrowserRouter, RouterProvider } from "react-router-dom";
import App from "./App.tsx";
import "./index.css";
+import Header from "./components/Header.tsx";
const router = createBrowserRouter([
{
- path: "/",
- element:
,
+ element:
,
+ children: [
+ {
+ path: "/",
+ element:
,
+ },
+ ],
},
]);
diff --git a/src/pages/Apartment.tsx b/src/pages/Apartment.tsx
new file mode 100644
index 0000000..9f31366
--- /dev/null
+++ b/src/pages/Apartment.tsx
@@ -0,0 +1,69 @@
+import { useEffect } from "react";
+import ViewController from "../components/ViewController";
+import useStore from "../store/store";
+import { Parameters } from "../types/appartment";
+import { Unity, useUnityContext } from "react-unity-webgl";
+import LoaderModal from "../components/LoaderModal";
+
+const mainViewParams: Parameters = {
+ type: "A1M",
+ plotArea: "1080 Sq.m",
+ totalBuildUpArea: "472 Sq.m",
+ TotalCountBedroms: 5,
+ villaTheme: "Modern",
+ sliders: [
+ {
+ title: "General View",
+ image: "/images/apartment/A1M/A1M_P.png",
+ },
+ {
+ title: "Ground Floor",
+ image: "/images/apartment/A1M/A1M_GF.png",
+ },
+ {
+ title: "First Floor",
+ image: "/images/apartment/A1M/A1M_1F.png",
+ },
+ ],
+ perspectiveWorkings: [
+ "/images/apartment/A1M/perspectiveWorking/009_Villa_A1MO_CAM_01_R05.jpg",
+ "/images/apartment/A1M/perspectiveWorking/009_Villa_A1MO_CAM_02_R05.jpg",
+ ],
+};
+
+const Apartment = () => {
+ const { modal, setModal } = useStore();
+ const { unityProvider, isLoaded } = useUnityContext({
+ loaderUrl: "builds/estate-webgl-stable.loader.js",
+ dataUrl: "builds/estate-webgl-stable.data.unityweb",
+ frameworkUrl: "builds/estate-webgl-stable.framework.js.unityweb",
+ codeUrl: "builds/estate-webgl-stable.wasm.unityweb",
+ streamingAssetsUrl: "StreamingAssets",
+ });
+
+ useEffect(() => {
+ if (!isLoaded) {
+ setModal(
);
+ } else {
+ setModal(null);
+ }
+
+ return () => {};
+ }, [isLoaded, setModal]);
+
+ return (
+ <>
+ {modal}
+
+
+
+
+
+ >
+ );
+};
+
+export default Apartment;
diff --git a/src/pages/Main.tsx b/src/pages/Main.tsx
new file mode 100644
index 0000000..dac4f45
--- /dev/null
+++ b/src/pages/Main.tsx
@@ -0,0 +1,23 @@
+import { useEffect } from "react";
+import useStore from "../store/store";
+// import { isMobile } from "react-device-detect";
+import ViewController from "../components/ViewController";
+import { Parameters } from "../types/appartment";
+import LoaderModal from "../components/LoaderModal";
+
+const Main = () => {
+ const { modal, setModal } = useStore();
+
+ useEffect(() => {
+ // setModal(
);
+ }, [setModal]);
+
+ return (
+
+ {modal}
+ {/* */}
+
+ );
+};
+
+export default Main;
diff --git a/src/types/appartment.ts b/src/types/appartment.ts
index bac5137..0304ee2 100644
--- a/src/types/appartment.ts
+++ b/src/types/appartment.ts
@@ -10,6 +10,7 @@ type Parameters = {
TotalCountBedroms: number;
villaTheme: string;
sliders: Slider[];
+ perspectiveWorkings: string[]
};
export type {Slider as SliderType, Parameters}
\ No newline at end of file
diff --git a/src/views/MainView.tsx b/src/views/MainView.tsx
deleted file mode 100644
index a9ea0b3..0000000
--- a/src/views/MainView.tsx
+++ /dev/null
@@ -1,47 +0,0 @@
-import { useEffect } from "react";
-import useStore from "../store/store";
-// import LoaderModal from "../components/LoaderModal";
-import { isMobile } from "react-device-detect";
-import ViewController from "../components/ViewController";
-import { Parameters } from "../types/appartment";
-
-const mainViewParams: Parameters = {
- type: "A1M",
- plotArea: "1080 Sq.m",
- totalBuildUpArea: "472 Sq.m",
- TotalCountBedroms: 5,
- villaTheme: "Modern",
- sliders: [
- {
- title: "General View",
- image: "/images/apartment/A1M/A1M_P.png",
- },
- {
- title: "Ground Floor",
- image: "/images/apartment/A1M/A1M_GF.png",
- },
- {
- title: "First Floor",
- image: "/images/apartment/A1M/A1M_1F.png",
- },
- ],
-};
-
-const MainView = () => {
- const { modal, setModal } = useStore();
- console.log("isMobile", isMobile);
-
- useEffect(() => {
- // setModal(
);
- }, [setModal]);
-
- return (
- <>
- {modal}
- {/*
add
*/}
-
- >
- );
-};
-
-export default MainView;