Skip to content

YIDE: a lightweight online front-end compiler, with React and Typescript as the front end, Egg.js as the back end, support html, js, css and markdown compilation, is a small helper to validate ideas, practice ideas and write documents.

License

Notifications You must be signed in to change notification settings

waiterxiaoyy/YIDE

Repository files navigation

YIDE

English / 简体中文 🌏

👉 A lightweight online front-end compiler💘 👈

Online version: YIDE online address

Documentation is ongoing......

GitHub Repo stars GitHub commit activity GitHub package.json version GitHub License GitHub language count

Introduction 🌟

Project entry page Project master diagram

  • YIDE is an editor that supports writing front-end code online, with React and Typescript as the front end, Egg.js andMysqlas the back end, supportinghtml, js,cssandmarkdowncompilation, which is very suitable for verifying ideas. Practice and organize documentation.

  • This project has the following features compared to some current online compilers:

    • Support user differentiation, users can have independent file management space
    • Support for custom scripts and style files
    • Support Markdown file writing and compilation
  • There are two main reasons for developing this project:

    • First, often ask GPT to write some styles, but can not see the effect in time, simply hand off a own online viewer directly, and do some things to improve some functions
    • The second is to increase my project experience

Features 💥

  • 📁 File Management : Support to distinguish between users and file storage, currently only support new file creation, compared to other online platforms, support to select compiled master files such as html and md files.

  • 🐱 Efficiency Editing : The integrated Monaco-Editor supports language recognition, code completion and highlighting, and supports a series of shortcut keys, such as saving compiled and formatted code.

  • 🐧 Window Drag : The main page layout is the file area Explorer, Editor and display area Viewer, supporting the "free" drag of each column.

  • 🐼 Multi-type File Compilation : Support html combined with style files and script files, support Markdown format file compilation.

  • 🐒 Liberalization : Write html files to support the automatic introduction of default script files and style files, you can also customize script files and style files, specifically view the use of documents.

  • 🐶 Built-in Map Bed : Markdwon supports image uploading, built-in OSS map bed.

Document 📱

  • Create new file

In the left file index area of the main page Explorer creates a new file, supporting files with the suffix html, css, js,md, where html and md are compilable files.

Default files: index.html, script.js,style.cssare default files, default files are not allowed to be deleted.

Self-created file names are not recommended to contain the words index , style and script.

  • Edit file

In the middle area of the main page is the file editing area Editor, the current file name displayed in the middle, can adjust the font size in the editing area, select compile file (html/md), click compile button will automatically save all unsaved files and then compile, click save button will save the current file.

  1. html edit

The html file does not need a standard template, only the main structure needs to be written

<div>
    <h1 style="color: #eb7806">Welcome to YIDE</h1>
    <h3 style="color: #eb7806">by waiterxiaoyy</h3>
</div>
  1. css edit
body {
    color: #e56e0c;
    margin: 0;
    padding: 0;
    background-color: #f4f4f4;
}
  1. js edit
document.addEventListener(`DOMContentLoaded`, function () { 
    console.log(`JavaScript loaded for YIDE`); 
});
  1. Md edit

Md file editing supports general basic operations, and does not support complex styles such as class diagrams and flow charts.

  • File compilation

File compilation Currently supports only html and md file compilation, and the TODO List is integrated in the future.

  1. html compilation

html will automatically parse out the qualified code by the background, and will parse the code instyle.css andscript.js, and the background will combine into a complete set of page code to return to the foreground display.

If you need a custom style file and a script file, you need to add the following two lines in thehtml file:

<!-- Unintroduce default styles and scripts -->
// no style.css
// no script.js

These two lines of code need to be written in strict accordance with the above format in the need to customize thehtml file, the background will recognize and cancel the default style and script files, user-defined files introduced as follows:

<!-- Unintroduce default styles and scripts -->
// no style.css
// no script.js

<!-- Introduce style file -->
<link rel="stylesheet" href="/my.css" />

<!-- Import script file -->
<script type="text/script" src="/my.js" ></script>

<div>
    <h1 style="color: #eb7806">Welcome to YIDE</h1>
    <h3 style="color: #eb7806">by waiterxiaoyy</h3>
</div>

Note: Importing custom files must start with slash /, otherwise the files under the user will not be recognized.

Of course, if you do not need to introduce files, you can also write styles and script operations directly in <style></style> and <script></script> of the html file.

  1. Md compilation

Md compilation is combined with the theme of the Nuggets forum, and the replacement theme is not supported for the time being.

  • Download file

You can download files in both the file index area and the edit area by clicking the Download button.

  • Upload files

Upload is not supported

  • Rename file

Not supported for now, update later

Installation/configuration 🔧

  • Cloning
git clone [email protected]:waiterxiaoyy/YIDE.git
  • Structure
YIDE
├── YIDE-Egg-Server
├── YIDE-React-Client

YIDE-Egg-Server is the back-end project of Egg.js and mysql as the technology stack, and YIDE-React-client is the front-end project of React as the technology stack, and the two need to be started at the same time to be used normally

  • Install yarn globally

Project start and deployment need node environment, please install the environment in advance, the node version used in the project is v18.18.1 , the following operations are based on this version, if there is inconsistency, please install nvm switch to the corresponding node version, install nvm please consult the relevant information.

npm install -g yarn
  • Front-end project YIDE-React-Client configuration/startup
  1. Installation dependency
cd YIDE-React-Client

yarn
  1. Configuration port

Configure the project port and proxy forwarding in vite.config.js and vite.config.ts. The default front-end port is 3001and the back-end port is 8000

  1. Start-up project
// Start-up project in development
yarn dev
  • Backend project YIDE-Egg-Server configuration/startup
  1. Install and configure MySQL

The back-end needs to install MySQL in advance, consult the data to install, version 8.0 or more.

After the installation is complete, configure the user name and password.

  1. Configure MySQL in the project

Configure mysql entries and sequelize entries in config.default.js in YIDE-Egg-Server/config, and change the password and database to your own Settings.

config.mysql = {
    app: true,
    agent: false,
    client: {
        host: `localhost`,
        port: `3306`,
        user: `root`,
        password: ``,
        database: `yide`
    }
};

config.sequelize = {
    dialect: `mysql`,
    host: `localhost`,
    port: `3306`,
    user: `root`,
    password: ``,
    database: `yide`,
    define: {
        timestamps: false,
        freezeTableName: true
    }
};
  1. Run sql statements to import tables and basic data

In the project directory there is the app.sql file, all copy to the MySQL console execution.

  1. Installation dependency

Under directory YIDE-Egg-Server

yarn
  1. Configuring the oss service (optional)

Because the project used the graph bed, using the oss cloud service, so you need to configure oss, otherwise the graph bed will not be available.

In the config.default.js configuration ossitem, regionaccessKeyId , accessKeySecret, bucket is obtained in the oss application, the specific oss service opening please consult the information.

config.oss = {
    client: {
        region: ``,
        accessKeyId: ``,
        accessKeySecret: ``,
        bucket: ``
    }
};
  1. Start-up

After starting the project, the project will be exposed to port 8000

yarn dev
  • Project deployment

The server uses docker to manage the project, the front-end project uses nginx deployment, and the back-end can be packaged as an image to start.

Deployment questions welcome to add wechat communication: zhouyiyang0328

ChangeLog 📅

See the ChangeLog for the latest updates.

TODO List 📋

If you want to get involved, you are welcome to submit a PR as a contributor to the project and work together to build a more lightweight and user-friendly online IDE.

  • Page layout optimization: index area indent, responsive adaptation
  • File upload function
  • Supports more file types, such as vue and react
  • Integrated console
  • Rename the file
  • Create directory, directory management, directory tree
  • Code sharing

Contribution 🤝

Contributions are welcome! Please feel free to submit a Pull Request.

This project exists thanks to all the people who contribute:

License 📄

This project is licensed under the MIT License - see the LICENSE file for details.

Support 💖

If you find this project helpful, please consider giving it a ⭐️ on GitHub!

About

YIDE: a lightweight online front-end compiler, with React and Typescript as the front end, Egg.js as the back end, support html, js, css and markdown compilation, is a small helper to validate ideas, practice ideas and write documents.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published