Comments (5)
Hi, I've begun working on this, however, as I am relatively new to ocaml/reason ecosystem, I am not sure how to implement the focus module. So far I have, but that would cause a dependency cycle.
module Make = (T: {type t;}) => {
let focusedNode: ref(option(Node.node(T.t))) = ref(None);
let focusOn = (node: Node.node(T.t)) => {
let _ =
switch (focusedNode^) {
| None => ()
| Some(node) => node#blur()
};
focusedNode := Some(node);
};
};
from revery.
Would I have to implement a focusable sub-class, make sure node extends it and the use that for type parameters?
from revery.
Thanks a lot for taking this on, @WhoAteDaCake !
That functor looks like a solid start - it looks like it'd be testable. Based on the dependency issue - I'm thinking it'd be nice if the Node
didn't need to know about focus management. It could work the following way:
- The
focus
module keeps track of the active node - Input events get funneled through the
Focus
module (we could implement aFocus.dispatch
- like what we did forMouse
events here:Line 88 in 2ec9ecb
- We could add
Blur
andFocus
events toNodeEvents
- Instead of sending a
Node
object to theref
- we could send a more functional wrapper. This would contain ablur
andfocus
method, which, under the hood, would call to theFocus
module. This 'proxying' could be facilitated by wrapping theonRef
inNodeEvents
This would decouple the dependency tree - because the node wouldn't need to care about focus management, the only concern the Node
would have with regard to focus is respond to Blur
and Focus
events, and dispatching to the appropriate handler in NodeEvents
.
Still a little vague, but hopefully that helps give some ideas. Thanks for thinking about this!
from revery.
I've open #199 . That implements the basic functionality required for focus management.
from revery.
Maybe we can update this issue to indicate what's already done and what's missing?
Also, @bryphe , in Testability section first case should be most likely without tabindex
instead of with
from revery.
Related Issues (20)
- Ubuntu 20.10: revery-ui/esy-skia build failed HOT 3
- Ubuntu 18.10 / 19.04: @opam/ocamlfind@opam:1.8.1 build failed HOT 5
- esy '@examples' run output has no text (Revery.FontCache: Error loading typeface (skia)) HOT 4
- Uncaught Division_by_zero crash on window resize. (maxHeight vs flexGrow ?) HOT 1
- Revery roadmap in face of Reason->Rescript rebrand HOT 2
- Having problem with building revery-quick-start project on Mac HOT 7
- MacOS: Allow selective modifier key mapping
- esy install failing on Windows. HOT 3
- Build Revery is presenting failure in shell.c HOT 2
- ScrollView does not work if children are added after initial mount
- CI: esy-skia won't build on Linux HOT 1
- createWindow with visible=false does not create a hidden window HOT 3
- Update the build guide for Fedora HOT 4
- SVG drawing mangled if OS locale does use a different floating point presentation HOT 4
- Quickstart build step error HOT 1
- Windows10 esy is installed but revery-ui can not be installed
- Build revery with esy on mac failed HOT 9
- Can't build on Fedora 35 due to glibc bug HOT 4
- OCaml <=14.12 doesn't support glibc>=2.34 HOT 9
- Support for FreeBSD HOT 1
Recommend Projects
-
React
A declarative, efficient, and flexible JavaScript library for building user interfaces.
-
Vue.js
🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.
-
Typescript
TypeScript is a superset of JavaScript that compiles to clean JavaScript output.
-
TensorFlow
An Open Source Machine Learning Framework for Everyone
-
Django
The Web framework for perfectionists with deadlines.
-
Laravel
A PHP framework for web artisans
-
D3
Bring data to life with SVG, Canvas and HTML. 📊📈🎉
-
Recommend Topics
-
javascript
JavaScript (JS) is a lightweight interpreted programming language with first-class functions.
-
web
Some thing interesting about web. New door for the world.
-
server
A server is a program made to process requests and deliver data to clients.
-
Machine learning
Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.
-
Visualization
Some thing interesting about visualization, use data art
-
Game
Some thing interesting about game, make everyone happy.
Recommend Org
-
Facebook
We are working to build community through open source technology. NB: members must have two-factor auth.
-
Microsoft
Open source projects and samples from Microsoft.
-
Google
Google ❤️ Open Source for everyone.
-
Alibaba
Alibaba Open Source for everyone
-
D3
Data-Driven Documents codes.
-
Tencent
China tencent open source team.
from revery.