Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/gimenete/unicycle
Unicycle is an Electron application built using TypeScript, React and ant.design. Its purpose is to unify the design / development cycle.
https://github.com/gimenete/unicycle
Last synced: 2 months ago
JSON representation
Unicycle is an Electron application built using TypeScript, React and ant.design. Its purpose is to unify the design / development cycle.
- Host: GitHub
- URL: https://github.com/gimenete/unicycle
- Owner: gimenete
- Created: 2017-07-28T18:31:30.000Z (over 7 years ago)
- Default Branch: master
- Last Pushed: 2023-01-12T09:21:49.000Z (almost 2 years ago)
- Last Synced: 2024-10-23T13:41:35.884Z (3 months ago)
- Language: TypeScript
- Homepage:
- Size: 3.72 MB
- Stars: 69
- Watchers: 2
- Forks: 5
- Open Issues: 8
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# Unicycle
Unicycle is an Electron application built using TypeScript, React and ant.design. Its purpose is to unify the design / development cycle.
Unicycle allows you to *create, live edit and test presentational components and export them to different frameworks* (React and Vue.js by now). Each component has three different parts:
- Markup: the markup, written in HTML with special attributes for conditional writing and loops
- Style: SCSS for the component
- Tests: JSON structure where you can define example values of the props the component accepts![Main window](/screenshots/main.png?raw=true "Main window")
## Benefits
- A designer with knowledge of web technologies can create presentational components without having to install a full development environment.
- A frontend developer will obtain fully working code that can integrate directly into the app without having to spend hours trying to mimic a design## Code coverage
Since Unicycle knows all the possible tests/states of a component it is able to provide you:
- Markup coverage. If an HTML element is never renderer you'll get noticed in the code editor
- SCSS coverage. If a selector is never used, you'll get noticed in the code editor
- State coverage (WIP). If a value in your test data / state is not used, you'll get noticed in the code editor![Code coverage](/screenshots/code-coverage.png?raw=true "Code coverage")
## Emulate browser capabilities
Unicycle is able to emulate media capabilities (e.g. media=print), orientation media queries,... So you can test all scenarios without leaving the app.
## Import from Sketch
Unicycle provides a Sketch plugin to export a selection and convert it to a component. The result is not perfect but the CSS and the HTML structure is optimal and semantic to be as simple as possible to fine tune.
![Import from Sketch](/screenshots/import-from-sketch.png?raw=true "Import from Sketch")
## Remote testing
Unicycle provides an internal HTTP server that you can enable so you can test your live preview in any browser, including mobile phones.
![Remote testing](/screenshots/remote-testing.png?raw=true "Remote testing")
## Style palette
Unicycle encourages to use a design system. Thus, it provides tools for creating a global stylesheet for defining colors, shadows, fonts and animations. And like everything in Unicycle, you can edit it and see the changes in real time.
![Style palette](/screenshots/style-palette.png?raw=true "Style palette")
# Installing and running
- Clone the repository
- Run `npm install`
- Run `./build-sass.sh` (required to rebuild native dependencies with electron as target and not Node.js)
- Run `npm run build` (transpiles the TypeScript to JavaScript)
- Run `npm start`# Markup templating engine
## String interpolation
You can output values by using curly braces (`{expression}`). The content is a JavaScript expression. For example:
```html
{author.fullname}
```## Dynamic attributes
You can dynamically set an HTML attribute by prefixing it with `:`. The value of the attribute will be evaluated as a JavaScript expression.
```html
```Another, more advanced, example:
```html
```## Conditionals
You can implement conditional rendering by using the special `@if` attribute. Example:
```html
Renders the paragraph element if author is null
```## Loops
```html
{message.text}
```## Including other components
For including a component into another component use `...`
# Roadmap
- Generate React Native code. It will require to support XML as markup instead of HTML and re-think the way CSS is handled.
- Support designing email templates through [Inky](https://foundation.zurb.com/emails/docs/inky.html)
- Git integration. Right now there is initial code for that. The idea is to allow designers to contribute directly to git repositories to further improve the collaboration between designers and developers.# Status of the project
This app is a mature experiment. It mostly works, but many options are not implemented yet (e.g. all the exporting options, support for React Native and support for email templates) or are basically a proof of concept (git integration). Also a few things could change in a backwards incompatible way in the near future, so don't.