Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

New Web package #491

Merged
merged 13 commits into from
Sep 29, 2023
Merged
Show file tree
Hide file tree
Changes from 11 commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 1 addition & 1 deletion .gitattributes
Original file line number Diff line number Diff line change
Expand Up @@ -31,4 +31,4 @@ LICENSE text eol=lf
*.gif binary
*.jpg binary
*.node binary
*.png binary
*.png binary
2 changes: 1 addition & 1 deletion .gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -26,4 +26,4 @@ log.json
eslint-results.sarif

# junit test results
junit-tests.xml
junit-tests.xml
2 changes: 1 addition & 1 deletion .prettierignore
Original file line number Diff line number Diff line change
Expand Up @@ -3,5 +3,5 @@ package-lock.json
coverage
.nyc_output
**/out
packages/td_to_openAPI/examples/openapi.yaml
packages/td_to_openapi/examples/openapi.yaml
packages/td_to_asyncapi/examples/asyncapi.yaml
12 changes: 12 additions & 0 deletions .vscode/templates/scss.lict
Original file line number Diff line number Diff line change
@@ -0,0 +1,12 @@
Copyright (c) %(CreationYear) Contributors to the Eclipse Foundation

See the NOTICE file(s) distributed with this work for additional
information regarding copyright ownership.

This program and the accompanying materials are made available under the
terms of the Eclipse Public License v. 2.0 which is available at
http://www.eclipse.org/legal/epl-2.0, or the W3C Software Notice and
Document License (2015-05-13) which is available at
https://www.w3.org/Consortium/Legal/2015/copyright-software-and-document.

SPDX-License-Identifier: EPL-2.0 OR W3C-20150513
111 changes: 111 additions & 0 deletions packages/web-new/README.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,111 @@
# @thing-description-playground/**WEB-NEW**

This package provides the new web interface of the Web of Things Playground. It uses the functionality of the `core` package to validate Thing Descriptions and Models. You can find more information about the Thingweb-Playground [here](https://github.com/eclipse-thingweb/playground).

## Main Features

- Validation of TDs and TMs
- Multiple editors
- JSON and YAML conversion
- An examples menu to use as templates
- A save menu, where your currently opened TD/TM can be:
- Exported as an URL either on a new tab/browser or on the [ediTDor] (https://eclipse.github.io/editdor/) website
- Downloaded directly
- Saved in a specific folder within your file system (This function is only available on `Chrome`, `Edge` and `Opera`)
- A preferences menu within the settings, where the color theme, and font size can be change
- OpenAPI conversion
- AsyncAPI conversion
- A defaults view where all defaults can be added or removed from your current TD
- Visualize view, where your current TD/TM can be represented visually as a Graph or Tree, as well as downloaded as either SVG or PNG

## License

Licensed under the MIT license, see [License](../../LICENSE.md).

## How to use

- Online: It is hosted [here](http://plugfest.thingweb.io/playground-new/)
- Simply paste a TD or utilize an example from the examples menu and click on validate
- The validation process will then start on the bottom console, where more information will be provided in case of errors or warnings

## Testing with Playwright

## Webpack functionality and bundling

This package is built by utilizing webpack, allowing to bundle and compile the projects JavaScript and CSS files. It also handles asset management and optimization. Below are the steps to understand the current configuration:

### 1. Introduction

The `webpack.config.js` file is used to set up Webpack for the project. It manages various aspects of the build process, including bundling JavaScript and CSS file, handling assets like images and fonts, and optimizing code for production.

### 2. Required Dependencies

- `path`: This is a built-in Node.js module for handling file paths
- `HtmlWebpackPlugin`: A Webpack plugin for generating HTML files
- `CopyWebpackPlugin`: A Webpack plugin for copying files and directories during the build process
- `MonacoWebpackPlugin`: A Webpack plugin for integrating the Monaco code editor
- `MiniCssExtractPlugin`: A Webpack plugin for extracting CSS into separate files
- `CssMinimizerPlugin`: A Webpack plugin for minimizing CSS files

### 3. Webpack Configuration Obejct

**3.1 Entry Points**
- `entry`: Specifies the entry points for your application. In this case, there are two entry points: 'bundle' for JavaScript and 'styles' for CSS

**3.2 Output**
- `output`: Specifies where Webpack should output the bundled files. The path property defines the output directory as 'dist', and the filename property determines the naming pattern for generated files. [name] is a placeholder for the entry point name, and [contenthash] is a unique hash based on file content
- `clean`: Tells Webpack to clean the 'dist' directory before each build
- `assetModuleFilename`: Specifies the filename for asset files

**3.3 Development Server**
- `devServer`: Configures the development server with settings such as the port, compressing assets, and enabling history API fallback

**3.4 Module Rules**
- `module`: Defines rules for how Webpack should process different file types. There are rules for JavaScript, images, CSS, and more. For example, it uses Babel to transpile JavaScript, handles image assets, and processes CSS with style loaders and sass loaders

**3.5 Plugins**
- `plugins`: Lists the plugins used in the build process. Key plugins include
- `HtmlWebpackPlugin` for generating HTML files,
- `CopyWebpackPlugin` for copying assets,
- `MonacoWebpackPlugin` for the Monaco code editor integration, and
- `MiniCssExtractPlugin` for extracting CSS into separate files

**3.6 Optimization**
- `optimization`: Contains settings for optimizing the build, including minimizing CSS using `CssMinimizerPlugin`


## Deployment

Requires [Lerna](https://www.npmjs.com/package/lerna) to be installed globally (`npm install -g lerna`).

1. Clone the repo
2. Install the monorepo (allows linking unpublished versions)
3. Install the web package locally to ensure that e.g. `core` dependency is not just a symlink

```sh
git clone [email protected]:eclipse-thingweb/playground.git
cd playground
lerna bootstrap
cd ./packages/web-new
npm install
```

Finally the web application can be deployed in production or in development mode:

### Development mode

1. Utilze the command `npm run dev` which will start the webpack-dev-server in development mode, generate source maps for easier debuging, open your default browser and serve the application.
egekorkan marked this conversation as resolved.
Show resolved Hide resolved

```sh
npm run dev
```

### Production mode

1. Build the project with the command `npm run build` which will automatically set the mode to production
2. Finally utilize the command `npm run serve` to serve the application utilizing express as the server

```sh
npm run build
npm run serve
```
93 changes: 93 additions & 0 deletions packages/web-new/external-scripts/generate-paths.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,93 @@
/*
* Copyright (c) 2023 Contributors to the Eclipse Foundation
*
* See the NOTICE file(s) distributed with this work for additional
* information regarding copyright ownership.
*
* This program and the accompanying materials are made available under the
* terms of the Eclipse Public License v. 2.0 which is available at
* http://www.eclipse.org/legal/epl-2.0, or the W3C Software Notice and
* Document License (2015-05-13) which is available at
* https://www.w3.org/Consortium/Legal/2015/copyright-software-and-document.
*
* SPDX-License-Identifier: EPL-2.0 OR W3C-20150513
*/

/**
* @file The `examples.js` generates a json file
* with all the links, title and descriptions of the TD and TM examples in the
* main github repository utilizing the examples folder
*/

const fs = require('fs').promises;
const path = require('path');
//path to where all the td/tm examples
const initialPath = "../../examples";
//path to the get the raw files from the github
const rawFilePath = "https://raw.githubusercontent.com/eclipse-thingweb/playground/master/examples"

async function getExamples(){
const files = await fs.readdir(initialPath)

const examplesPaths = {}

for(const file of files){
examplesPaths[file] = {}

const categories = await fs.readdir(path.join(initialPath, file))

//sorting them by the first number in their name
categories.sort((a, b) => a.localeCompare(b, undefined, { numeric: true }))

for(const category of categories){

const examples = await fs.readdir(path.join(initialPath, file, category))

//for each category, create a description with the path to the readMe file, and an examples object to store all the respective exampele
examplesPaths[file][category] = {
"description": "",
"examples": {}
}

for(const example of examples){
if(path.extname(example) == ".txt"){
try {
const categoryDescription = await fs.readFile(path.join(initialPath, file, category, example), 'utf8')
examplesPaths[file][category]["description"] = categoryDescription
} catch (err) {
console.error("Failed to read file: ", err);
}
}

if(path.extname(example) == ".jsonld"){
const exampleData = JSON.parse(await fs.readFile(path.join(initialPath, file, category, example), 'utf8'))
const exampleTitle = exampleData["$title"]
const exampleDescription = exampleData["$description"]
examplesPaths[file][category]["examples"][example] = {
"title": exampleTitle,
"description": exampleDescription,
"path": `${rawFilePath}/${file}/${category}/${example}`
}
}
}
}
}

return examplesPaths
}

async function writeExamplesToFile(){
const examplesData = await getExamples()

try {
const jsonData = JSON.stringify(examplesData, null, 2)
const filePath = "./src/examples-paths/examples-paths.json"
await fs.writeFile(filePath, jsonData, 'utf-8')
console.log("File created succesfully")

} catch (err) {
console.error("Failed to wirte JSON file: ", err)
}
}

writeExamplesToFile()
Loading