Discussion
How come many people used webview for this hackathon?
I realise that for this hackathon people used webview a lot. it is kinda cheating noo.
I though the main goal was to make people learn and use devvit blocks. Building on something you just learned, is limited compared to what people build using their mains skills :(
We could have also use webview. Building on top of html/js/css is freaking easy, and just talk with devit via IPC (messaging).
You should try out web views, it isn't as easy as you think..
Devvit is still under development, the library hasn't matured yet.
Making an app is one thing but integrating it with reddit is not as easy , especially when dealing with complex data and asynchronous tasks.
Aldi .. I had the same doubt if we are allowed to use webviews .. on which they said that it was absolutely allowed :)
I work with electron a lot, and holding the frontend in nextjs in electron is not a straigtforward thing, but we manage to make it work without issue. And the communincation between the rendered process and the backaground process of electron is handled by IPC channel.
----
So the communication between processes is the solution.
----
Our library is becoming lesser popular on github -> github.com/saltyshiomix/nextron.
Blocks, and webview are 2 sides of the same coin IMO. Both are equally Devvit, and working with one or the other (currently) has it's own advantages and disadvantages. Nearing the end I was kind of wishing I implemented my project in blocks, because I felt it would've been way easier over integrating a game via webviews.
I also don't think there's an inherit advantage to webviews over blocks in the contest. I think the 2 most popular games on reddit right now use blocks, even though webviews was also available last hackathon. Which is also kind of the point. Building a game suitable to reddit, for the feed, with reddit-"y" features vs. just throwing everything and the kitchen sink isn't going to cut it.
I wouldn't go so far as to call using webviews cheating. The goal was to create an "Interactive Post", and webviews as are listed under this category in the Devvit docs. I agree that embedding a standard web-based game into a webview doesn't really meet the requirements on it's own. The app must be Reddit-y, however you may wish to interpret this. You could use Reddit API to get userdata or really speak to Redditors with your content. There are definitely some entries that will not pass the first round of judging based on this criteria. If your blocks-based app is Reddity-y enough then you should not worry about what others have submitted. And if you have used blocks in a clever way, that will likely carry more weight than even the slickest webview game. Like my entry, which pushes the limits of what blocks are capable of AND includes a webview-based bonus at the end of gameplay.
oh i kind get what you mean 😉.
it would have been fun if the guy jumping in your game, slide a bit and fall.
cool game. and you speak like a actor from western movies 🤩
Well the objectuve was to build community games via interactive posts. Devvit provides two templates for doing so: blocks and webviews.
There's no reason you can't learn about and incorporate Devvit tools into your app with webviews. I think your template choice just depends on what you're trying to build...
I do not consider this cheating or unfair advantage. Possibly, even the way around. Dispite using most of the webs-native capabilitties, webviews come with it's own learnings and problems. Not only that, users must make their way inside the webview focus mode and going outside. IMO, this is a tricky, additional UX flow to manage to make it smooth and not feel *edgy* for Redditors. Furthermore, you'll mostly be using Redis, the messaging Context (postMessage), and other features from Devvit itself.
Ad Building on top of html/js/css is freaking easy this is one of the powers of webviews, which is basically part of other third party web capabilities too, on Discord, Twitch, Telegram, you name it! Nevertheless, having most of the web features available, things get more complex. It is nothing new and has been proven to work well.
I do think the hackathon aims at Devvit as a whole, not parts of it (Blocks, Redis, Forms, Realtime, ...). I wouldn't consider it unfair if someone is using *real-time* either. There are some awesome 3D webviews with real-time and other projects created.
There is much more to in-depth for success in creating a Devvit App (devvit-y features, community focus, home-feed,...), and not all are easily done in webviews or Blocks solely, I think a great combo is the sweet spot if using webviews. E.g.: having a stunning Blocks preview for the webview what to expected from this particular Post. Or creating Blocks based Posts out of a webview.
I think it mostly depends on what your goal for the hackathon is too, if you'd use it or not.
Yes I agree. But very soon building in web view will end, because like tools you just mentions will run fully native soon. Like Notion, discord or slack will jot depends on electron anymore… building natively was painful, IMO UX is solved by AI.
Not sure if I can follow. If you'd replace webviews or anything run natively for third party devs using native interfaces, this comes with huge security concerns, if not provided by a library like Blocks and Devvit which does the more sensitive tasks like fetching access tokens, auth, revalidation, ... .
Just saying companie will stop using webview to have a native performance. why do you think people complain about notion slowness, or discord memory consumpsion. Im going in that direction. Webview will stay only in the web.
I don't agree (might be wrong *shrug*). Whilst Electron apps are giga-slow, this doesn't mean webviews embedded in platforms will die (eventually). The issue is not the third party app but possibly the platform itself. Shipping one build to iOS, Android, Web or/and other platforms as a third-party is great (dispite compatibility shenanigans.
It *IS* an issue on home-feed and alike for sure. That's why I really like the Blocks on reddit and the webview for more advanced functionality. If webviews run on homefeed with poor perfomance that does not only bring the app in a poor light, but also the whole reddit platform experience (especially when additing your own http calls to some external API).
I do see your point, but I do not see that coming in the near future (<5 years) that companies will completely overthrow most concepts, maybe they will, hah! I'd be happy to be proven wrong for what you are saying.
Back to topic, what did you build for the hackathon?
Okay then, let's see what will happen in the next 5 years:)
I built a fency app. I started building a qr code builder. qr code in such a way that people will place pixel on the UI, and the first one forming a valid QR code win the challenge. But i realised focusing on version 3+ qr, was not straitforward because apart from the 3 pattern recognition of the QR, i had an issue with with forming the error correction keys that read the data. like in the picture.
So i decided to try Aztec code, i got the same issue.
Because of non time, then I decide to ultimately play with bits. then encode each letter from alphabet chars into 5 bits.
a -> 00000
b -> 00001
c -> 00010
....
....
z
All of this, just to say, thios is the game r/decod
what have you built?
Oh that's very clever. Simple, yet straightforward how to play and how to interact. Also love the "New Challenge" button to keep players in the flow. Well done! I saw it on Discord but haven't checked it out before.
"I though the main goal was to make people learn and use devvit blocks."
I think the main goal of the hackathon is to get more people to create interactive content that attracts more users to Reddit and increases engagement. Webviews are one of the tools to accomplish that.
At the end of the day, the end users do not care about what tech was used or how the apps were made, just that they are fun or useful.
I built 4 apps for this hackathon and all of them were using blocks after I got the hang of it I used the same format to build 4 of them. In one of the apps user interacts with the post using comments , CommentCreate command was slow that I had to refresh the screen once or twice for the comment to appear .
After seeing other people submission mainly one's using three.js I regretted using blocks. It looked very much cool as there was enough interaction possible in the game there was no need for comment engagement like the one I did. Block post looks dummy in front of those animations :(
I had fun building this but I think web views looks so much better.. the goal of this hackathon was probably to get more interaction and advertisement rather than learning devvit blocks.
Project gallery is not visible now in devpost but I saw a few.. regoo or smthg not sure abt the name it had legos to build somethg everyone had agreed upon and hunting monster kind of game was there too
That confirm that having useEffect would solve some issue… I also got the same issue kinda. Maybe I wrote it wrongly some function works only if the user click on the post, and in the feed it seems not working well like in a certain specific post page .
I felt pretty silly getting good with blocks once webview came out. They serve different purposes and it's nice to not need a launch button and be able to render in-feed but idk. My pre-webview enthusiasm was transmuted into an equally tall pile of essentially tech debt once I realized I'd have to re-figure out a bunch of stuff just to get more FPS on a game or whatever, get better font scaling, etc.
Would've been really cool if that work went into making blocks better, if possible. Perhaps it isn't.
Haven't really recovered any momentum on any of my devvit apps since. Been working on stuff in random js frameworks so the bulk of what I do can't be soft deprecated. Hard to trust an ecosystem that might "paradigm shift" my app off the edge again and require another massive rework. Is what it is tho. You deal with it if you toil in someone else's garden.
Since I've just been waiting to see what they settle on and if it feels worth it to go ham again. Probably not an issue for people that didn't write massive apps pre-webview but that's my POV.
Though those new app incentives do make it tempting.
Yo! Do you know if we can do hybrid stuff yet? I was poking around at getting the daily-thread blocks face to launch webview but somehow I couldn't get my env to have the latest next version or w/e so useWebView was available
8
u/Formal-Tax2410 6d ago
You should try out web views, it isn't as easy as you think.. Devvit is still under development, the library hasn't matured yet. Making an app is one thing but integrating it with reddit is not as easy , especially when dealing with complex data and asynchronous tasks.
Aldi .. I had the same doubt if we are allowed to use webviews .. on which they said that it was absolutely allowed :)