Skip to content

This project is a devtool-like tool. Trying to build a library to select the html element position and inject content visually in any website!

Notifications You must be signed in to change notification settings

neil585456525/vue-content-selector

Repository files navigation

vue-content-selector

A vue-component that select the html element position and inject content visually!

online preview

demo gif

Overview

Why ?

If you have created any website add-on like a share-like-button or a advertisement window, that will be inserted into user's website. This tool can help your users to select and feel a good position for your content!

Roadmap

  • Basic componet usage
  • Modify position appearance
  • Add unit-testing
  • Add e2e-testing
  • List and select parent element
  • Mobile preview mode

Installation and Usage

Installation

npm install @neil585456525/vue-content-selector

Usage

import { createApp } from "vue";
import VueContentSelector from "@neil585456525/vue-content-selector";
import App from "./App.vue";

createApp(App).use(VueContentSelector).mount("#app");
<template>
  <div>
    <vue-content-selector>
      # things you want to dynamic injected
      <custom-content />
    </vue-content-selector>
  </div>
</template>

Api

Props

  • isWidgetInShadow

    • type: Boolean
    • default: true

    Should widget component rendered in shawdow dom, which can encapsulate css style. It will be convenient when injecte into customer pages.

  • widgetStyleInShadow

    • type: String

    When widget component in shawdow dom, it will encapsulate global css style. You can provide the css string to override the style, it will auto inject into shadow.

  • isContentInShadow

    • type: Boolean
    • default: false

    Let injected-contnet component rendered in shawdow dom.

  • contentStyleInShadow

    • type: String

    Auto injected-contnet style into shadow.

  • baseZIndex

    • type: Number

    Set the widget base-z-index, it also affect positionSelecter logic.

Emits

  • onHoverChanged()

    • parameters: hovered element
    • type: Element

    Triggers when select hovered element changes

  • onPositionSelected()

    • parameters: hovered element
    • type: Element

    Triggers when select sucessed

  • onCanceled()

    Triggers when click cancel button

Discussion

This project is trying to build a library to select the html element position and inject content visually in any website! To achieve this there are a number of primary problems should be solved as bellow.

  1. Isolate css from the original page.
  • Using shadow dom and custom webpack style-loader config to dynamic inject style into the shadow root. I don't using iframe as my solution because I want it can easily communicate with page runtime, and it's also can deploy more smoothly.
  1. Selecting page element with the cursor, but don't trigger the element event, also try to optimize the performence as possible.
  • Oringinal I used dynamic event binding when any elememnt that cursor hovered, but it can't prevent the original element hover and click behavior, and will cause some performence problem, so I come out another solution. Using an invisible mask and using elementFromPoint API to reach this effect, this can solve both problems.

Development

In root folder :

yarn intall
yarn dev

Then in /example folder

yarn install
yarn serve

About

This project is a devtool-like tool. Trying to build a library to select the html element position and inject content visually in any website!

Topics

Resources

Stars

Watchers

Forks

Packages

No packages published