Socket
Socket
Sign inDemoInstall

femonitor-web

Package Overview
Dependencies
30
Maintainers
1
Versions
18
Alerts
File Explorer

Advanced tools

Install Socket

Detect and block malicious and high-risk dependencies

Install

    femonitor-web

A web SDK for frontend error and performance monnitor


Version published
Weekly downloads
3
Maintainers
1
Created
Weekly downloads
 

Readme

Source

Description

A sdk for web error and performance monitor.

Development

npm run watch  // Watch tsfile change and compile by rollup
npm run server // Start a nodejs server for request test

Build

npm run build

Test

npm run test

Installation

CDN

<script src="https://cdn.jsdelivr.net/npm/femonitor-web@latest/bin/femonitor-web.min.js"></script>

NPM

npm i femonitor-web -S

Usage

Minimal options

import { WebMonitor } from "femonitor-web";
const monitor = Monitor.init();
monitor.on([event], () => {});

Full options

// Default full options
const defaultTrackerOptions = {
  env: 'dev',
  reportUrl: "",
  data: {},
  error: {
    watch: true,  // If listen all error
    random: 1,    // Sampling rate from 0 to 1, 1 means emit all error
    repeat: 5,    // Don't emit sample error events when exceed 5 times
    delay: 1000   // Delay emit event after 1000 ms
  },
  performance: false,  // If want to collect performance data
  http: {
    fetch: true,  // If listen request use fetch interface
    ajax: true    // If listen ajax request
  },
  behavior: {
    watch: false,
    console: [ConsoleType.error],
    click: true,     // If set to true will listen all dom click event
    queueLimit: 20   // Limit behavior queue to 20
  },
  /**
   * rrweb use mutation observer api, for compatibility see:
   * https://caniuse.com/mutationobserver
   */
  rrweb: {
    watch: false,
    queueLimit: 50,  // Limit rrweb queue to 20
    delay: 1000      // Emit event after 1000 ms
  },
  isSpa: true        // If watch is true, globalData can get _spaUrl for report when route change
};
const monitor = Monitor.init(defaultTrackerOptions);

Vue project

Sdk support Vue.config.errorHandler to handle error for get detail component info. You just need to call useVueErrorListener before create Vue instance.

monitor.useVueErrorListener(Vue)

React project

React supply a hook called componentDidCatch for error listen and concept called ErrorBoundary which is enabled to catch errors at top and prevent app to shutdown. You can report it by yourself like below.

class ErrorBoundary extends React.Component {
  constructor(props) {
    super(props);
    this.state = { hasError: false };
  }

  componentDidCatch(error, info) {
    this.setState({ hasError: true });
    reportError(error, info);
  }

  render() {
    if (this.state.hasError) {
      return <h1>Something went wrong.</h1>;
    }
    return this.props.children;
  }
}

Support events

EventNameDescription
jsErrorwinodw.onerror
vuejsErrorVue.config.errorHandler
unhandleRejectionwindow.onunhandledrejection
resourceErrorResource request error
batchErrorsBatch collection of error events, trigger every specified time interval
reqErrorNetwork request error
reqStartNetwork request start
reqEndNetwork request end
performanceInfoReadyPerformance data is ready

Keywords

FAQs

Last updated on 04 May 2021

Did you know?

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc