0.3.0 • Published 7 years ago

socket-adapter v0.3.0

Weekly downloads
4
License
MIT
Repository
github
Last release
7 years ago

Socket Adapter

Allows yeoman generators to prompt for user input over socket.io sockets.This allows for communication between yeoman generators and web applications.

Usage

Back end

To use this adapter, create a new yeoman environment using a new instance of socket-adapter, supplying the socket to be used as an argument.

var yeoman = require('yeoman-environment');
var SocketAdapter = require('socket-adapter');
var app = require('express')();
var server = require('http').Server(app);
var io = require('socket.io');

io.on('connection', function(socket){
  var env = yeoman.createEnv([], {}, new SocketAdapter(socket));
});

server.listen(3000);

Any generators run in this environment will use the SocketAdapter instead of the command line when prompting for input. Refer to the yeoman documentation for more information on using environments.

Front end

The socket adapter recieves an array of questions, and returns a hash of answers.

For each question on the array, the adapter emits a yo:question on the socket and waits for an yo:answer. This process is repeated until all questions have been answered.

Your front end application should create a socket connection, and then wait for the first yo:question event. Once the question is recieved, a prompt must be created. The socket adapter does not transform the questions in any way, so the method of form creation is up to the developer. Once an answer recieved, the yo:answer event should be emitted, formatting the data in a way that can be understood by the yeoman generator.

The transformation of data is left to the front end so that prompts are not restricted to the inquirer.js api. For example, you may decide to create and use generators that emit questions using JSON schema, allowing for greater customization and validation.

Example implementation

to-do

Logging

The adapter makes use of the standard logging function provided by the yeoman-environment and used in the TerminalAdapter is used.

Source

To Do

  • sample application
  • diff function *logging function
0.3.0

7 years ago

0.2.0

8 years ago

0.1.6

8 years ago

0.1.5

8 years ago

0.1.4

8 years ago

0.1.3

8 years ago

0.1.2

8 years ago

0.1.1

8 years ago

0.1.0

8 years ago