scaffolding
This commit is contained in:
@@ -0,0 +1,55 @@
|
|||||||
|
const fs = require('fs');
|
||||||
|
|
||||||
|
function getType(t){
|
||||||
|
return (t?.type.names[0] || '').replace(/^Array\.\<(.*)\>$/, '$1*')
|
||||||
|
}
|
||||||
|
|
||||||
|
function graft(childNodes, parentLongname) {
|
||||||
|
let result = '';
|
||||||
|
childNodes.filter(({memberof}) => memberof === parentLongname)
|
||||||
|
.forEach(element => {
|
||||||
|
if (element.kind === 'function') {
|
||||||
|
result += `${getType(element.returns?.[0]) || 'void'} ${element.name}(${ element.params?.map(p=>
|
||||||
|
`/* ${p.description || ''} */ ${getType(p)} ${p.name}`
|
||||||
|
).join(', ') || ''});\n`;
|
||||||
|
}
|
||||||
|
else if (element.kind === 'member') {
|
||||||
|
result += `/* ${element.description || ''} */ ${getType(element)} ${element.name};`
|
||||||
|
}
|
||||||
|
|
||||||
|
else if (element.kind === 'class') {
|
||||||
|
result+= `/** ${element.classdesc || ''} */\nclass ${element.name}{\n public: \n`;
|
||||||
|
result += graft(childNodes, element.longname);
|
||||||
|
result+= '\n};\n';
|
||||||
|
}
|
||||||
|
});
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
@param {TAFFY} data
|
||||||
|
@param {object} opts
|
||||||
|
*/
|
||||||
|
exports.publish = (data, {destination, query}) => {
|
||||||
|
let docs;
|
||||||
|
|
||||||
|
data({undocumented: true}).remove();
|
||||||
|
docs = data().get(); // <-- an array of Doclet objects
|
||||||
|
|
||||||
|
fs.promises.writeFile('./result.json', JSON.stringify(docs), {encoding:'utf-8'})
|
||||||
|
|
||||||
|
let result = graft(docs);
|
||||||
|
console.log(result)
|
||||||
|
|
||||||
|
if (destination === 'console') {
|
||||||
|
if (query && query.format === 'xml') {
|
||||||
|
//console.log( xml.parse('xs:schema', root) );
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
//console.log( require('jsdoc/util/dumper').dump(root) );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
console.log('This template only supports output to the console. Use the option "-d console" when you run JSDoc.');
|
||||||
|
}
|
||||||
|
};
|
||||||
@@ -0,0 +1,102 @@
|
|||||||
|
|
||||||
|
/**
|
||||||
|
* Games manager class
|
||||||
|
*/
|
||||||
|
class GamesManager{
|
||||||
|
name = 'games';
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Class initializer
|
||||||
|
* @param {App} app Class initializer
|
||||||
|
*/
|
||||||
|
init(app){
|
||||||
|
const {db} = app;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Creates a new game definition
|
||||||
|
* @param {Context} ctx Request context
|
||||||
|
* @param {Game} data the game description
|
||||||
|
*/
|
||||||
|
this.create = async function(ctx, data){
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Reads game definition by ID
|
||||||
|
* @param {Number} id game ID
|
||||||
|
* @returns {Game}
|
||||||
|
*/
|
||||||
|
this.read = async function(id){
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Updates game definition
|
||||||
|
* @param {Context} ctx Request context
|
||||||
|
* @param {Game} data the game description
|
||||||
|
*/
|
||||||
|
this.update = async function(ctx, data){
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Removes game by ID
|
||||||
|
* @param {Number} id game definition ID
|
||||||
|
*/
|
||||||
|
this.remove = async function(id){
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns a set of games by given criteria
|
||||||
|
* @param {Query} query criteria
|
||||||
|
* @returns {Game[]}
|
||||||
|
*/
|
||||||
|
this.list = async function(query){
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Class starter
|
||||||
|
* @param {App} app The application
|
||||||
|
*/
|
||||||
|
async start(app){
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Game entity
|
||||||
|
*/
|
||||||
|
class Game {
|
||||||
|
/**
|
||||||
|
* Game name
|
||||||
|
* @type string
|
||||||
|
*/
|
||||||
|
name = null;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Game formal description
|
||||||
|
* @type GameDefinition
|
||||||
|
*/
|
||||||
|
definition = {
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
levels:[
|
||||||
|
{
|
||||||
|
name: 'Level 1',
|
||||||
|
environment: null,
|
||||||
|
objects:[
|
||||||
|
{
|
||||||
|
id: 15
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
||||||
|
]
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
export { GamesManager }
|
||||||
@@ -0,0 +1,82 @@
|
|||||||
|
|
||||||
|
/**
|
||||||
|
* Rules manager class
|
||||||
|
*/
|
||||||
|
class RulesManager{
|
||||||
|
name = 'rules';
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Class initializer
|
||||||
|
* @param {App} app Class initializer
|
||||||
|
*/
|
||||||
|
init(app){
|
||||||
|
const {db} = app;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Creates a new rule
|
||||||
|
* @param {Context} ctx Request context
|
||||||
|
* @param {Rule} data the rule
|
||||||
|
*/
|
||||||
|
this.create = async function(ctx, data){
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Reads rule by ID
|
||||||
|
* @param {Number} id rule ID
|
||||||
|
* @returns {Rule}
|
||||||
|
*/
|
||||||
|
this.read = async function(id){
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Updates rule
|
||||||
|
* @param {Context} ctx Request context
|
||||||
|
* @param {Rule} data the rule
|
||||||
|
*/
|
||||||
|
this.update = async function(ctx, data){
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Removes rule by ID
|
||||||
|
* @param {Number} id rule ID
|
||||||
|
*/
|
||||||
|
this.remove = async function(id){
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns a set of rules by given criteria
|
||||||
|
* @param {Query} query criteria
|
||||||
|
* @returns {Rule[]}
|
||||||
|
*/
|
||||||
|
this.list = async function(query){
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Class starter
|
||||||
|
* @param {App} app The application
|
||||||
|
*/
|
||||||
|
async start(app){
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Rule entity
|
||||||
|
*/
|
||||||
|
class Rule {
|
||||||
|
/**
|
||||||
|
* Rule name
|
||||||
|
* @type string
|
||||||
|
*/
|
||||||
|
name = null;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
export { RulesManager }
|
||||||
@@ -0,0 +1,82 @@
|
|||||||
|
|
||||||
|
/**
|
||||||
|
* Scenarios manager class
|
||||||
|
*/
|
||||||
|
class ScenariosManager{
|
||||||
|
name = 'scenarios';
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Class initializer
|
||||||
|
* @param {App} app Class initializer
|
||||||
|
*/
|
||||||
|
init(app){
|
||||||
|
const {db} = app;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Creates a new scenario
|
||||||
|
* @param {Context} ctx Request context
|
||||||
|
* @param {Scenario} data the scenario
|
||||||
|
*/
|
||||||
|
this.create = async function(ctx, data){
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Reads scenario by ID
|
||||||
|
* @param {Number} id scenario ID
|
||||||
|
* @returns {Scenario}
|
||||||
|
*/
|
||||||
|
this.read = async function(id){
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Updates scenario
|
||||||
|
* @param {Context} ctx Request context
|
||||||
|
* @param {Scenario} data the scenario
|
||||||
|
*/
|
||||||
|
this.update = async function(ctx, data){
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Removes scenario by ID
|
||||||
|
* @param {Number} id scenario ID
|
||||||
|
*/
|
||||||
|
this.remove = async function(id){
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns a set of scenarios by given criteria
|
||||||
|
* @param {Query} query criteria
|
||||||
|
* @returns {Scenario[]}
|
||||||
|
*/
|
||||||
|
this.list = async function(query){
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Class starter
|
||||||
|
* @param {App} app The application
|
||||||
|
*/
|
||||||
|
async start(app){
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Scenario entity
|
||||||
|
*/
|
||||||
|
class Scenario {
|
||||||
|
/**
|
||||||
|
* Scenario name
|
||||||
|
* @type string
|
||||||
|
*/
|
||||||
|
name = null;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
export { ScenariosManager }
|
||||||
@@ -0,0 +1,13 @@
|
|||||||
|
import express from 'express';
|
||||||
|
|
||||||
|
class GamesController{
|
||||||
|
|
||||||
|
name = 'gamesApi'
|
||||||
|
route = '/api/game'
|
||||||
|
|
||||||
|
init(app){
|
||||||
|
const router = express.Router();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
export { GamesController }
|
||||||
@@ -9,7 +9,7 @@
|
|||||||
<v-list>
|
<v-list>
|
||||||
<v-list-item to="/game-objects/add">Нов игрови обект</v-list-item>
|
<v-list-item to="/game-objects/add">Нов игрови обект</v-list-item>
|
||||||
<v-list-item>Нов сценарий</v-list-item>
|
<v-list-item>Нов сценарий</v-list-item>
|
||||||
<v-list-item>Нова игра</v-list-item>
|
<v-list-item to="/games/add">Нова игра</v-list-item>
|
||||||
</v-list>
|
</v-list>
|
||||||
</v-menu>
|
</v-menu>
|
||||||
</v-app-bar>
|
</v-app-bar>
|
||||||
@@ -24,7 +24,7 @@
|
|||||||
<v-list-item prepend-icon="mdi-receipt-text-edit-outline" :title="$l.gameScenarios"></v-list-item>
|
<v-list-item prepend-icon="mdi-receipt-text-edit-outline" :title="$l.gameScenarios"></v-list-item>
|
||||||
<v-list-item prepend-icon="mdi-cogs" :title="$l.gameRules"></v-list-item>
|
<v-list-item prepend-icon="mdi-cogs" :title="$l.gameRules"></v-list-item>
|
||||||
<v-divider></v-divider>
|
<v-divider></v-divider>
|
||||||
<v-list-item prepend-icon="mdi-controller" :title="$l.games"></v-list-item>
|
<v-list-item prepend-icon="mdi-controller" :title="$l.games" to="/games/list"></v-list-item>
|
||||||
</v-list>
|
</v-list>
|
||||||
<v-divider></v-divider>
|
<v-divider></v-divider>
|
||||||
<v-list nav>
|
<v-list nav>
|
||||||
|
|||||||
@@ -0,0 +1,9 @@
|
|||||||
|
<template>
|
||||||
|
|
||||||
|
</template>
|
||||||
|
|
||||||
|
<script>
|
||||||
|
export default {
|
||||||
|
|
||||||
|
}
|
||||||
|
</script>
|
||||||
Reference in New Issue
Block a user