-
Notifications
You must be signed in to change notification settings - Fork 591
Create Silex components
This document is a outdated, there is an easier and cleaner way to add the components to the + menu, ask questions in an issue and fix the info here please
Please read the page How to Host An Instance of Silex before trying to create your own components
Silex components are elements you can add to a website through the "+" menu. They are created with a tool called "Prodotype" which compiles them for Silex and generates the UI.
- Empower your users with new tools
- The UI is generated, you just need to describe the parameters
- It is like a widget (simple HTML code you put in an HTML box) but your users can not view the code, and can edit parameters in a UI
Here is the code which is explained in this section
You can add components to your instance for your users. Start by creating a new nodejs project as explained in the page How To Add Silex To Your Node.js Project. In short, Silex is included in your project as an npm dependency.
For now a simple component example. Below your will find more info about how to create components.
test.ejs:
<h1><%= title %></h1>
<p><%= paragraph %></p>
test.yml:
---
name: Test component
description: A simple component which displays a title and a paragraph.
doc: https://github.com/silexlabs/Silex/wiki/Create-Silex-components
category: Test
faIconClass: fa-square
props:
- name: title
type: string
- name: paragraph
type: string
description: 'This is a help text for Silex UI'
default: 'This is the default value'
Copy your component to Silex components folder: node_modules/silex-website-builder/src/prodotype/components/
.
Rebuild components:
$ cd node_modules/silex-website-builder/
$ npm run build:components
This will add your component to node_modules/silex-website-builder/dist/prodotype/components/components.json
and make it available in the "+" menu of Silex.
Now run npm start
in your project (created from How To Add Silex To Your Node.js Project) and open http://localhost:6805/
.
This section is outdated. It should still work like that but there is a clean way to do that with Silex API.
Now that it works, you need to cleanup all this. You are not supposed to write in the node_modules folder. If you do, when you update Silex, you will loose all your changes.
Create a folder named components/
in your project. Move your component's 2 files to this folder. Add this to your package.json:
{
"build": "cp components/* node_modules/silex-website-builder/src/prodotype/components/ && cd node_modules/silex-website-builder/ && npm run build:components"
Now you can do
$ npm run build
$ npm start
To build and add your component(s) to your Silex instance. Just open http://localhost:6805/
to test it/them.
Install Silex sources, see Silex Developer Guide
The components files live in src/prodotype/components/. Each component is made of an HTML template (.ejs file) and a description file in a markdown file (.md).
Components files are compiled with the command npm run build:prodotype
If you add components - thank you! Please make a pull request and after it is merged update the documentation wiki.
Components are made of 2 files: a text file which describes its properties, and an HTML template which use the properties to render the component.
Links:
This is how it looks like when you add a component:
This is the documentation for Silex website builder. It is a collaborative effort, click edit and start contributing. Also have a look at these discussions.
WARNING: Support for Silex v2 has stopped. Try Silex v3 alpha, Read about it, Subscribe to the newsletter