Mosaic
Web browser that can display multiple web pages at the same time in one shared window. A tiling web browser.
Latest release: 0.0.3
Download Β· Changelog
Value proposition
The main value of using Mosaic over Chrome with builtin macOS tiling can be seen on this non-exhaustive list of tasks that often pop up when you want to use web in a tiling fashion:
- Task 1 β create a 1:2 splitscreen from a single fullscreen window containing two tabs
- Chrome on macOS β video, 12 seconds
- turn-off fullscreen
- tear off one tab into a window
- hold cursor over green (maximise) window button
- select "Tile window to the left side"
- choose the second Chrome window to fill the rest of the screen (right side)
- resize via the splitter between the tiles
- Mosaic on macOS β video, 6 seconds
- drag out a tab to the wanted place
- π€¬ the animation is extremely choppy
- resize via the splitter between the tiles
- Task 2 β interact with unfocused tile and repeat
- Chrome on macOS β video, 5 seconds
- move cursor over unfocused tile
- click on the unfocused tile to focus it
- click on the interactive element
- [repeat]
- Mosaic on macOS β video, 2 seconds
- move cursor over unfocused tile
- π€¬ tile did not change the appearance to communicate focus
- click on the interactive element
- [repeat]
Features
- [x] Documented Design Decisions
- [x] Blink rendering engine
- [x] Written in Typescript using React
- [x] Intuitive drag&drop tile managment
- [x] Built-in DuckDuckGo search engine
- auto suggest while typing
- use !bang for advanced searches
- e.g. "!g hello" to google for "hello"
- [x] Minimalistic dark look
- [x] Dock
- drag out icon from dock to make a new tab
- [x] Automatic zoom-to-fit of webpage
- [x] Familiar shortcuts for tab managment (βT, βW)
- [ ] Built-in privacy
- [ ] Adblock (uBlock Origin)
- [ ] Blocking cookie consent non-sense
- [x] No history
- [ ] HTTPS everywhere
- [ ] System keychain integration
Development
Requirements: Git, NodeJS, Yarn
Clone repository and install project dependencies:
$ git clone https://github.com/mlajtos/mosaic.git
$ cd mosaic
$ yarn
Live development
$ yarn dev