Code Monkey home page Code Monkey logo

overvue's Introduction

Prototyping Development Tool for Vue Developers

OverVue is a prototyping tool that allows developers to dynamically create and visualize a Vue application, implementing a real-time intuitive tree display of component hierarchy and a live-generated code preview. The resulting boilerplate can be exported as a template for further development.

这个程序能帮你生成Vue 组件, 设置 routes , 也可以帮你显像Component Parent-Child组件树。你只要做一些小配置然后可以下载code boilerplate. 这样你就可以很方便简洁地生成Vue前台APP了!

Table of Contents

Installation

To download the production version for windows or mac, please visit https://www.Overvue.io

Install dependencies

npm i

To run electron app in dev mode (note: Vue Devtools will launch automatically)

npm run dev

To build a new .dmg / windows .exe

npm run build

WSL Installation

The ability to load the application and/or devtools requires a tool/application to run a linux display as WSL does not have any display drivers since it is based off of just a CLI. I recommend X410 (https://x410.dev/), althought it does cost $15, for ease of use. There are free options such as VcXsrv(https://sourceforge.net/projects/vcxsrv/) that you can get, but requires more set up.

If you choose to use VcXsrv, you will need to select a couple options:

  • Launch XLaunch
  • Select multiple windows and display number=0.
  • Select no client.
  • Select Clipboard, Primary Selection, Native opengl, and disable access control.
  • If Windows firewall pops up - select Public for this server to work.

If you choose to use x410, you will need to set the environment DISPLAY variable on each console:

So, to open either the Vue devtools or OverVue in dev mode, first start your X Server then enter into the terminal: For WSL 1 :

export DISPLAY=:0

For WSL 2 :

export DISPLAY=$(awk '/nameserver / {print $2; exit}' /etc/resolv.conf 2>/dev/null):0
export LIBGL_ALWAYS_INDIRECT=1

Then run the following command to run both OverVue and Vue developer tools.

npm run dev

To launch the Vue devloper tool, use the following command.

./node_modules/.bin/vue-devtools

Then to start only OverVue in developer mode, open a new terminal instance and set the DISPLAY value again (re-enter above command for DISPLAY):

quasar dev -m electron

NOTE:

  • Electron-deeplink currently does not work on our WSL2 computers and output an error during installing the dependency which prevented the application to open in dev mode. Go to /src-electron/electron-main.js and comment out line 3/import line to bypass error. The developers did not find any impacts on application so far.
  • There might be an npm install error despite all instructions. Try the following command below:
sudo apt install libgconf-2-4 libatk1.0-0 libatk-bridge2.0-0 libgdk-pixbuf2.0-0 libgtk-3-0 libgbm-dev libnss3-dev libxss-dev

Running the Docker Image

To run the built version, pull down the docker image from [Docker repo]

In your terminal, run:

docker run -v /tmp/.X11-unix:/tmp/.X11-unix -e DISPLAY=$DISPLAY -v`pwd`/src:/app/src --rm -it overvue

Running the dev environment on Docker as a Mac User

To run OverVue through Docker on a Mac, you'll need to install XQuartz:

brew install --cask xquartz

Important: RESTART your computer.

Update your PATH variable to /opt/x11/bin to your .zshrc. For example:

export PATH=/opt/X11/bin:$PATH

Set up XQuartz:

  • Launch XQuartz
  • Under the XQuartz menu, select Preferences.
  • Go to the security tab and ensure "Allow connections from network clients" is checked.
  • Restart XQuartz

Run the following command in your terminal (replacing localhostname with your local host name)

xhost +localhostname

If you don't know your local host name, run the following command to find it:

echo $(hostname)

Build the image using Dockerfile-Mac:

docker build -t overvue -f Dockerfile-Mac .

Run the image using the following command

docker run -it --env="DISPLAY=$(ifconfig en0 | grep inet | awk '$1=="inet" {print$2}'):0" --security-opt seccomp=./chrome.json overvue

Run in dev mode using:

npm run dev 

For more information about running Electron through Docker on a Mac, check out these posts:

  • How to run Electron on Linux on Docker on Mac
  • Workaround for sockets on Docker on macOS
  • How to use new Docker seccomp profiles

  • Running the dev environment on Docker as a WSL user

    Build the image using Dockerfile-WSL:

    docker build -t overvue -f Dockerfile-WSL .
    

    To run

    docker run -v /tmp/.X11-unix:/tmp/.X11-unix -e DISPLAY=$DISPLAY -v`pwd`/src:/app/src --rm -it overvue bash
    

    Run in dev mode using:

    npm run dev
    

    ↥Back to top

    How to use

    • OverVue will assign a default root App component and a default route called "HomeView"

    • To add a new component, type its name in the component name box and select any HTML elements that should be rendered by that component.

    • HTML elements can also be added after creation by selecting the component in the display, then selecting HTML elements.

    • You may nest HTML elements by clicking the chevron and selecting the nested HTML elements. Return to the parent HTML element by clicking clicking the carrot above the HTML element.

    • Select a parent component for the new component if needed.

    • After creating the component, you can move, resize, and recolor the component in the display. For advanced styling options, double click on the desired HTML element to modify. Here, you may add attributes such as class, ID, and v-model.

    • You can also duplicate components with Ctrl/Cmd C & V and see the component tree updated in real time.

    • Duplicate components will appear offset from their original and retain the same state and route assignments.

    • Child components will inherit the same parents, but parent components will not inherit duplicate children.

    • The right-side, Component Details > Code Snippet Tab displays live code snippets for the selected component.

    • You can view and add new routes and associated components in the right-side, Routes Gab. The newly created routes will be visible in the Project Tree Tab.

    • State and actions can be created, edited, and assigned to components.

    • When finished creating, view your code snippet under the code snippet tab and you can export to a file location of your choice. Below is the exported file structure:

    public/
      index.html
    src/
      assets/
      components/
        UserCreatedComponent1.vue
        UserCreatedComponent2.vue
        ...
      router/
        index.js
      views/
        HomeView.vue
        UserCreatedRouteComponent1.vue
        UserCreatedRouteComponent2.vue
        ...
      App.vue
      main.js
    babel.config.js
    package.json
    

    ↥Back to top

    BETA

    Slack OAuth

    For the Slack OAuth, you will need to create a Slack app through their website (https://api.slack.com/apps?new_app=1), so that you have your own Client Secret and Client ID. Then create two .env files (one for development and one for production).

    1. Create a Slack App from the link above. Copy your Client ID and Client Secret somewhere safe.
    2. Create two .env files in the main root of this repository. Name them:
    .env
    .env.development
    
    1. Open .env and add these three environment variables. Replace and with the client id and client secret given to you when you created your Slack App.
    SLACK_CLIENT_SECRET = "<client secret>"
    SLACK_CLIENT_ID = "<client id>"
    SLACK_REDIRECT_URI = "overvue://slack"
    
    1. Next, open .env.development and do the same, just note that the SLACK_REDIRECT_URI will be different here:
    SLACK_CLIENT_SECRET = "<client secret>"
    SLACK_CLIENT_ID = "<client id>"
    SLACK_REDIRECT_URI = "overvuedev://test"
    

    ↥Back to top

    Changelog

    Changelog 2.0

    OverVue 2.0
    • Improved hierarchy tree rendering
    • Improved Route addition and deletion
    • Able to search for components by name
    • Improved UI to be more informative
    • UI is more reactive, code snippets update dynamically
    • Component children menu is consistent with children list at time of creation
    • Children components can no longer choose any of their ancestors to be their children.
    • Can now use Quasar build -m electron to make windows .exe
    • Exporting projects now exports the mockup files as well into the assets folder
    • Saving projects now saves the mockup image url
    • Extensive bug fixing for Vue component and HTML element deletion behavior, exporting and saving.

    Changelog 3.0

    OverVue 3.0
    • Implemented full component edit functionality
    • Improved sidebar user interface to consolidate edit functionality
    • UI is more reactive, improved dashboard's ability to update dynamically
    • Added ability to incorporate Vuex in application
    • Updated component details section to better display all aspects of a component
    • Added action, state, and props section to component details dashboard
    • New Vuex store dashboard section
    • More robust code snippets with Vuex props, state, and actions included
    • Bug fixes for parent/child issues
    • Improved Documentation for easier onboarding of new contributors

    Changelog 4.0

    OverVue 4.0
    • Integrated Slack through a Slack Login button to link user's slack channel to their OverVue instance
    • After logging in with Slack, user's have the ability to send a message to their selected Slack channel after saving
    • Implemented the ability to delete State and Actions from the store
    • Added the feature to quickly copy/paste Components through hotkeys
    • Reworked the interface to give users a more intuitive experience
      • Moved bottom dashboard to the right
      • Features on the left are geared toward creation/editing components
      • Features on the right are geared toward viewing overall hierarchy of App Prototype
      • Component Editor menu now switches between create/edit mode depending on if a Component is selected
      • Vuex Store and Actions now moved to left menu with ability to view/create/delete state and actions
    • Implemented Vue Devtools for development ease
    • Sped up component tree rendering speed for quicker, smoother viewing

    • Bug Fixes

    • Fixed html buttons not properly rendering for selected component
    • Fixed code snippet not properly rendering for selected component
    • Fixed JSON parser typeerror with component html lists
    • Fixed component tree view rendering instability with right sidebar
    • Fixed children and parent relationship mutations causing type related side effects
    • Fixed issue where state/actions deleted in store aren't reflected across components
    • Fixed issue with undo feature that would delete inputed text one character at a time

    Changelog 5.0

    OverVue 5.0
    • Upgraded source code to Vue 3
    • Upgraded major dependencies to newest versions
      • Upgraded from Vuex 3 to Vuex 4
      • Upgraded from Electron 5 to 16
      • Upgraded from Quasar 1 to 2
    • Rewrote exports in Vue 3
    • Reconfigured Vue Devtools to launch and connect upon running quasar in dev mode
    • Note that due to breaking changes when upgrading to Vue 3, vued3tree had to be replaced with vue3-tree.Due to this, a bulleted list currently renders instead of a tree. This is intended to be a short-term change, with the old package being utilized again once it is compatible.

    Changelog 6.0

    OverVue 6.0
    • Toggle to TypeScript mode to generate code snippets and export your project or individual components in TypeScript
    • An interactive and real-time tree display of your component hierarchy allows you to easily visualize parent-child component relationships and the Vue Router structure
    • Enhance your workflow by adding notes to your components. When you export your project or components into your favorite IDE, notes will be converted into comments within your Vue files.
    • Now with a “Get Started” tutorial, a visual queue of your HTML elements, and an overall simplified UI, OveVue is as intuitive as ever.
    • OverVue is now containerized with Docker to bring developers the same experience, regardless of your operating system.

    • Bug Fixes

    • Fixed drawer disappearing when the window size is smaller
    • Fixed inability to delete parent/child relationship
    • Fixed the inability to add multiple children to parent except when making a new component
    • Fixed CodeSnippet does not scroll when it overflows the container
    • Fixed clicking canvas does not fully deactivate active component
    • Fixed Error handling for 'pasting' component when no component is copied
    • Fixed dancing components
    • Fixed project tree visulization

    Changelog 7.0

    OverVue 7.0
    • Color customizability of components
    • Code snippet reflects CSS styling of components
    • Added more semantic HTML tags
    • Options to add class, ID, and v-model attributes
    • Added drag and drop feature when adding/altering HTML tags
    • Ability to add child components to the code snippet of parent components
    • Added scoped style tags - On class creation will create styling entry with positioning of component/html element
    • Consolidated state/actions/props into one tab
    • UI overhaul

    • Bug Fixes

    • Fixed undo and redo capabilities
    • Fixed badge number not rendering for nested HTML tags

    Changelog 8.0

    OverVue 8.0
    • Added component snap to grid functionality with additional grid density drop down menu feature
    • Code snippet reflects CSS grid area styling of components
    • Ability to import components from Element Plus library
    • Exported project template code now more accurately reflects component placement in app
    • Improved canvas drag and deselect
    • Improved WSL developer installation instructions
    • Added TypeScipt to application
    • Implemented component search bar feature
    • Ability to add Google and Github OAuth to exported project
    • Added unit testing and component testing boilerplate to exported project
    • UI overhaul

    • Bug Fixes

    • Fixed routing components in project exports
    • Fixed component hierarchy in project exports
    • Fixed import statements of route child components
    • Fixed edge case HTML element bugs in project exports
    • Fixed in app component movement bugs which caused position to not update correctly
    • Fixed drag and drop HTML element on click bug
    • Eliminated code redundancy by implementing mixins

    ↥Back to top

    Contributing

    We'd love for you to test this application out and submit any issues you encounter. Also feel free to fork to your own repo and submit PRs. Here are some features we're thinking about adding:

    • Ability to place child components into HTML elements
    • Ability to export Vuex store boilerplate
    • Ability to add two-way binding to input elements
    • More granular typing options for TypeScript mode

    If you make changes and wish to update the website, here is the link to the repo: https://github.com/TeamOverVue/OverVuePage


    ↥Back to top

    Authors

    Contributors:
    Joseph Eisele @jeisele2
    Dean Chung @deanfchung
    Dean Ohashi @dnohashi
    Drew Nguyen @drewngyen
    Alexander Havas @LOLDragoon
    Keriann Lin @keliphan
    Allison Pratt @allisons11
    Joju Olaode @JojuOlaode
    Sean Grace @ziggrace
    Nicholas Schillaci @schillaci767
    Terry Tilley @codeByCandlelight
    Faraz Moallemi @farazmoallemi
    Alex Lu @aleckslu
    Jeffrey Sul @jeffreysul
    Kenny Lee @kennyea
    Ryan Bender @rdbender
    Sonny Nguyen @sn163
    Gabriela Kokhabi @gkokhabi
    Ross Lamerson @lamerson28
    Shanon Lee @shanonlee541
    Zoew McGrath @Z-McGrath
    Aram Paparian @apaparian
    Bryan Bart @MrBeeAreWhy
    Julia Bakerink @jbbake
    Kerolos Nesem @Kerolos-Nesem
    Megan Nadkarni @megatera
    Johnny Chan @jchan444
    Jace Crowe @JaceCrowe
    Keyla Koizumi Nishimura @keylakoizumin
    Katherine Kim @katherinek123
    Chris Wong @Koregano73
    Honghao(Michael) Sun @sunhonghaoparis
    Alex Law @alexlaw528
    Emma Genesen @EGenesen
    

    Inspired by PreVue


    ↥Back to top

    overvue's People

    Contributors

    aleckslu avatar alexlaw528 avatar allisons11 avatar codebycandlelight avatar deanfchung avatar dependabot[bot] avatar dnohashi avatar drewngyen avatar egenesen avatar farazmoallemi avatar jacecrowe avatar jbbake avatar jchan444 avatar jeffreysul avatar jeisele2 avatar jojuolaode avatar katherinek123 avatar keliphan avatar kerolos-nesem avatar keylakoizumin avatar koregano73 avatar lamerson28 avatar loldragoon avatar megatera avatar mrbeearewhy avatar schillaci767 avatar shanonlee541 avatar sn163 avatar sunhonghaoparis avatar ziggrace avatar

    Recommend Projects

    • React photo React

      A declarative, efficient, and flexible JavaScript library for building user interfaces.

    • Vue.js photo Vue.js

      🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

    • Typescript photo Typescript

      TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

    • TensorFlow photo TensorFlow

      An Open Source Machine Learning Framework for Everyone

    • Django photo Django

      The Web framework for perfectionists with deadlines.

    • D3 photo 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.

    • Game

      Some thing interesting about game, make everyone happy.

    Recommend Org

    • Facebook photo Facebook

      We are working to build community through open source technology. NB: members must have two-factor auth.

    • Microsoft photo Microsoft

      Open source projects and samples from Microsoft.

    • Google photo Google

      Google ❤️ Open Source for everyone.

    • D3 photo D3

      Data-Driven Documents codes.