Daniel Büchele cbab597236 show only one device in sidbar
Summary:
Refactors the plugin architecture of Sonar:
- Before plugin rendering had it's own implementation of the react lifecycle. This means the `render`-function was not called by react, but rather by the application it self. In this diff, the render method is now called from react, which enables better debugging and allows react to do optimizations.
- Business logic for querying emulators is moved away from the view components into its own dispatcher
- All plugin handling is moved from `App.js` to `PluginContainer`.
- The sidebar only shows one selected device. This allows us to add the screenshot feature as part of the Sonar main app and not a plugin.
- This also fixes the inconsistency between the devices button and the sidebar

Reviewed By: jknoxville

Differential Revision: D8186933

fbshipit-source-id: 46404443025bcf18d6eeba0679e098d5440822d5
2018-06-25 10:04:00 -07:00
2018-06-01 11:03:58 +01:00
2018-06-25 06:02:32 -07:00
2018-06-01 11:03:58 +01:00
2018-06-25 10:04:00 -07:00
2018-06-01 11:03:58 +01:00
2018-06-01 11:03:58 +01:00
2018-06-25 10:04:00 -07:00
2018-06-01 11:03:58 +01:00
2018-06-13 09:04:04 -07:00
2018-06-01 11:03:58 +01:00
2018-06-19 15:31:33 +01:00
2018-06-01 11:03:58 +01:00
2018-06-01 11:03:58 +01:00
2018-06-01 11:03:58 +01:00
2018-06-01 11:03:58 +01:00
2018-06-01 11:03:58 +01:00
2018-06-19 04:45:39 -07:00
2018-06-14 19:55:29 +01:00
2018-06-13 09:04:04 -07:00

Sonar

Sonar is a platform for debugging mobile apps on iOS and Android. Visualize, inspect, and control your apps from a simple desktop interface. Use Sonar as is or extend it using the plugin API.

Sonar

Mobile development

Sonar aims to be your number one companion for mobile app development on iOS and Android. Therefore, we provide a bunch of useful tools including a log viewer, interactive layout inspector, and network inspector.

Extending Sonar

Sonar is built as a platform. In addition to using the tools already included, you can create your own plugins to visualize and debug data from your mobile apps. Sonar takes care of sending data back and forth, calling functions, and listening for events on the mobile app.

Contributing to Sonar

Both Sonar's desktop app and native mobile SDKs are open-source and MIT licensed. This enables you to see and understand how we are building plugins, and of course join the community and help improve Sonar. We are excited to see what you will build on this platform.

In this repo

This repository includes all parts of Sonar. This includes:

  • Sonar's desktop app built using Electron (/src)
  • native Sonar SDKs for iOS (/iOS)
  • native Sonar SDKs for Android (/android)
  • Plugins:
    • Logs (/src/device-plugins/logs)
    • Layout inspector (/src/plugins/layout)
    • Network inspector (/src/plugins/network)
  • website and documentation (/website / /docs)

Getting started

Please refer to our Getting Started guide to set up Sonar.

Requirements

  • macOS (while Sonar is buildable using other systems as well, only macOS is officially supported)
  • node >= 8
  • yarn >= 1.5
  • iOS developer tools (for developing iOS plugins)
  • Android SDK and adb

Starting the desktop app

git clone https://github.com/facebook/Sonar.git
cd Sonar
yarn
yarn start

Building the desktop app

yarn build --mac --version $buildNumber

Documentation

Find the full documentation for this project at fbsonar.com.

Contributing and license

See the CONTRIBUTING file for how to help out. Sonar is MIT licensed, as found in the LICENSE file.

Description
No description provided
Readme 106 MiB
Languages
TypeScript 61.2%
Java 9.9%
Objective-C 7%
Kotlin 5.8%
C++ 4.8%
Other 11.2%