First pass formatting with Prettier
* Added .prettierrc.json * Added .prettierignore * Formatted
This commit is contained in:
310
core/bbs_list.js
310
core/bbs_list.js
@@ -2,72 +2,69 @@
|
||||
'use strict';
|
||||
|
||||
// ENiGMA½
|
||||
const MenuModule = require('./menu_module.js').MenuModule;
|
||||
const MenuModule = require('./menu_module.js').MenuModule;
|
||||
|
||||
const {
|
||||
getModDatabasePath,
|
||||
getTransactionDatabase
|
||||
} = require('./database.js');
|
||||
const { getModDatabasePath, getTransactionDatabase } = require('./database.js');
|
||||
|
||||
const ViewController = require('./view_controller.js').ViewController;
|
||||
const ansi = require('./ansi_term.js');
|
||||
const theme = require('./theme.js');
|
||||
const User = require('./user.js');
|
||||
const stringFormat = require('./string_format.js');
|
||||
const ViewController = require('./view_controller.js').ViewController;
|
||||
const ansi = require('./ansi_term.js');
|
||||
const theme = require('./theme.js');
|
||||
const User = require('./user.js');
|
||||
const stringFormat = require('./string_format.js');
|
||||
|
||||
// deps
|
||||
const async = require('async');
|
||||
const sqlite3 = require('sqlite3');
|
||||
const _ = require('lodash');
|
||||
const async = require('async');
|
||||
const sqlite3 = require('sqlite3');
|
||||
const _ = require('lodash');
|
||||
|
||||
// :TODO: add notes field
|
||||
|
||||
const moduleInfo = exports.moduleInfo = {
|
||||
name : 'BBS List',
|
||||
desc : 'List of other BBSes',
|
||||
author : 'Andrew Pamment',
|
||||
packageName : 'com.magickabbs.enigma.bbslist'
|
||||
};
|
||||
const moduleInfo = (exports.moduleInfo = {
|
||||
name: 'BBS List',
|
||||
desc: 'List of other BBSes',
|
||||
author: 'Andrew Pamment',
|
||||
packageName: 'com.magickabbs.enigma.bbslist',
|
||||
});
|
||||
|
||||
const MciViewIds = {
|
||||
view : {
|
||||
BBSList : 1,
|
||||
SelectedBBSName : 2,
|
||||
SelectedBBSSysOp : 3,
|
||||
SelectedBBSTelnet : 4,
|
||||
SelectedBBSWww : 5,
|
||||
SelectedBBSLoc : 6,
|
||||
SelectedBBSSoftware : 7,
|
||||
SelectedBBSNotes : 8,
|
||||
SelectedBBSSubmitter : 9,
|
||||
view: {
|
||||
BBSList: 1,
|
||||
SelectedBBSName: 2,
|
||||
SelectedBBSSysOp: 3,
|
||||
SelectedBBSTelnet: 4,
|
||||
SelectedBBSWww: 5,
|
||||
SelectedBBSLoc: 6,
|
||||
SelectedBBSSoftware: 7,
|
||||
SelectedBBSNotes: 8,
|
||||
SelectedBBSSubmitter: 9,
|
||||
},
|
||||
add: {
|
||||
BBSName: 1,
|
||||
Sysop: 2,
|
||||
Telnet: 3,
|
||||
Www: 4,
|
||||
Location: 5,
|
||||
Software: 6,
|
||||
Notes: 7,
|
||||
Error: 8,
|
||||
},
|
||||
add : {
|
||||
BBSName : 1,
|
||||
Sysop : 2,
|
||||
Telnet : 3,
|
||||
Www : 4,
|
||||
Location : 5,
|
||||
Software : 6,
|
||||
Notes : 7,
|
||||
Error : 8,
|
||||
}
|
||||
};
|
||||
|
||||
const FormIds = {
|
||||
View : 0,
|
||||
Add : 1,
|
||||
View: 0,
|
||||
Add: 1,
|
||||
};
|
||||
|
||||
const SELECTED_MCI_NAME_TO_ENTRY = {
|
||||
SelectedBBSName : 'bbsName',
|
||||
SelectedBBSSysOp : 'sysOp',
|
||||
SelectedBBSTelnet : 'telnet',
|
||||
SelectedBBSWww : 'www',
|
||||
SelectedBBSLoc : 'location',
|
||||
SelectedBBSSoftware : 'software',
|
||||
SelectedBBSSubmitter : 'submitter',
|
||||
SelectedBBSSubmitterId : 'submitterUserId',
|
||||
SelectedBBSNotes : 'notes',
|
||||
SelectedBBSName: 'bbsName',
|
||||
SelectedBBSSysOp: 'sysOp',
|
||||
SelectedBBSTelnet: 'telnet',
|
||||
SelectedBBSWww: 'www',
|
||||
SelectedBBSLoc: 'location',
|
||||
SelectedBBSSoftware: 'software',
|
||||
SelectedBBSSubmitter: 'submitter',
|
||||
SelectedBBSSubmitterId: 'submitterUserId',
|
||||
SelectedBBSNotes: 'notes',
|
||||
};
|
||||
|
||||
exports.getModule = class BBSListModule extends MenuModule {
|
||||
@@ -79,10 +76,10 @@ exports.getModule = class BBSListModule extends MenuModule {
|
||||
//
|
||||
// Validators
|
||||
//
|
||||
viewValidationListener : function(err, cb) {
|
||||
viewValidationListener: function (err, cb) {
|
||||
const errMsgView = self.viewControllers.add.getView(MciViewIds.add.Error);
|
||||
if(errMsgView) {
|
||||
if(err) {
|
||||
if (errMsgView) {
|
||||
if (err) {
|
||||
errMsgView.setText(err.message);
|
||||
} else {
|
||||
errMsgView.clearText();
|
||||
@@ -95,39 +92,48 @@ exports.getModule = class BBSListModule extends MenuModule {
|
||||
//
|
||||
// Key & submit handlers
|
||||
//
|
||||
addBBS : function(formData, extraArgs, cb) {
|
||||
addBBS: function (formData, extraArgs, cb) {
|
||||
self.displayAddScreen(cb);
|
||||
},
|
||||
deleteBBS : function(formData, extraArgs, cb) {
|
||||
if(!_.isNumber(self.selectedBBS) || 0 === self.entries.length) {
|
||||
deleteBBS: function (formData, extraArgs, cb) {
|
||||
if (!_.isNumber(self.selectedBBS) || 0 === self.entries.length) {
|
||||
return cb(null);
|
||||
}
|
||||
|
||||
const entriesView = self.viewControllers.view.getView(MciViewIds.view.BBSList);
|
||||
const entriesView = self.viewControllers.view.getView(
|
||||
MciViewIds.view.BBSList
|
||||
);
|
||||
|
||||
if(self.entries[self.selectedBBS].submitterUserId !== self.client.user.userId && !self.client.user.isSysOp()) {
|
||||
if (
|
||||
self.entries[self.selectedBBS].submitterUserId !==
|
||||
self.client.user.userId &&
|
||||
!self.client.user.isSysOp()
|
||||
) {
|
||||
// must be owner or +op
|
||||
return cb(null);
|
||||
}
|
||||
|
||||
const entry = self.entries[self.selectedBBS];
|
||||
if(!entry) {
|
||||
if (!entry) {
|
||||
return cb(null);
|
||||
}
|
||||
|
||||
self.database.run(
|
||||
`DELETE FROM bbs_list
|
||||
WHERE id=?;`,
|
||||
[ entry.id ],
|
||||
[entry.id],
|
||||
err => {
|
||||
if (err) {
|
||||
self.client.log.error( { err : err }, 'Error deleting from BBS list');
|
||||
self.client.log.error(
|
||||
{ err: err },
|
||||
'Error deleting from BBS list'
|
||||
);
|
||||
} else {
|
||||
self.entries.splice(self.selectedBBS, 1);
|
||||
|
||||
self.setEntries(entriesView);
|
||||
|
||||
if(self.entries.length > 0) {
|
||||
if (self.entries.length > 0) {
|
||||
entriesView.focusPrevious();
|
||||
}
|
||||
|
||||
@@ -138,15 +144,19 @@ exports.getModule = class BBSListModule extends MenuModule {
|
||||
}
|
||||
);
|
||||
},
|
||||
submitBBS : function(formData, extraArgs, cb) {
|
||||
|
||||
submitBBS: function (formData, extraArgs, cb) {
|
||||
let ok = true;
|
||||
[ 'BBSName', 'Sysop', 'Telnet' ].forEach( mciName => {
|
||||
if('' === self.viewControllers.add.getView(MciViewIds.add[mciName]).getData()) {
|
||||
['BBSName', 'Sysop', 'Telnet'].forEach(mciName => {
|
||||
if (
|
||||
'' ===
|
||||
self.viewControllers.add
|
||||
.getView(MciViewIds.add[mciName])
|
||||
.getData()
|
||||
) {
|
||||
ok = false;
|
||||
}
|
||||
});
|
||||
if(!ok) {
|
||||
if (!ok) {
|
||||
// validators should prevent this!
|
||||
return cb(null);
|
||||
}
|
||||
@@ -155,12 +165,21 @@ exports.getModule = class BBSListModule extends MenuModule {
|
||||
`INSERT INTO bbs_list (bbs_name, sysop, telnet, www, location, software, submitter_user_id, notes)
|
||||
VALUES(?, ?, ?, ?, ?, ?, ?, ?);`,
|
||||
[
|
||||
formData.value.name, formData.value.sysop, formData.value.telnet, formData.value.www,
|
||||
formData.value.location, formData.value.software, self.client.user.userId, formData.value.notes
|
||||
formData.value.name,
|
||||
formData.value.sysop,
|
||||
formData.value.telnet,
|
||||
formData.value.www,
|
||||
formData.value.location,
|
||||
formData.value.software,
|
||||
self.client.user.userId,
|
||||
formData.value.notes,
|
||||
],
|
||||
err => {
|
||||
if(err) {
|
||||
self.client.log.error( { err : err }, 'Error adding to BBS list');
|
||||
if (err) {
|
||||
self.client.log.error(
|
||||
{ err: err },
|
||||
'Error adding to BBS list'
|
||||
);
|
||||
}
|
||||
|
||||
self.clearAddForm();
|
||||
@@ -168,10 +187,10 @@ exports.getModule = class BBSListModule extends MenuModule {
|
||||
}
|
||||
);
|
||||
},
|
||||
cancelSubmit : function(formData, extraArgs, cb) {
|
||||
cancelSubmit: function (formData, extraArgs, cb) {
|
||||
self.clearAddForm();
|
||||
self.displayBBSList(true, cb);
|
||||
}
|
||||
},
|
||||
};
|
||||
}
|
||||
|
||||
@@ -184,10 +203,10 @@ exports.getModule = class BBSListModule extends MenuModule {
|
||||
},
|
||||
function display(callback) {
|
||||
self.displayBBSList(false, callback);
|
||||
}
|
||||
},
|
||||
],
|
||||
err => {
|
||||
if(err) {
|
||||
if (err) {
|
||||
// :TODO: Handle me -- initSequence() should really take a completion callback
|
||||
}
|
||||
self.finishedLoading();
|
||||
@@ -196,21 +215,28 @@ exports.getModule = class BBSListModule extends MenuModule {
|
||||
}
|
||||
|
||||
drawSelectedEntry(entry) {
|
||||
if(!entry) {
|
||||
if (!entry) {
|
||||
Object.keys(SELECTED_MCI_NAME_TO_ENTRY).forEach(mciName => {
|
||||
this.setViewText('view', MciViewIds.view[mciName], '');
|
||||
});
|
||||
} else {
|
||||
const youSubmittedFormat = this.menuConfig.youSubmittedFormat || '{submitter} (You!)';
|
||||
const youSubmittedFormat =
|
||||
this.menuConfig.youSubmittedFormat || '{submitter} (You!)';
|
||||
|
||||
Object.keys(SELECTED_MCI_NAME_TO_ENTRY).forEach(mciName => {
|
||||
const t = entry[SELECTED_MCI_NAME_TO_ENTRY[mciName]];
|
||||
if(MciViewIds.view[mciName]) {
|
||||
|
||||
if('SelectedBBSSubmitter' == mciName && entry.submitterUserId == this.client.user.userId) {
|
||||
this.setViewText('view',MciViewIds.view.SelectedBBSSubmitter, stringFormat(youSubmittedFormat, entry));
|
||||
if (MciViewIds.view[mciName]) {
|
||||
if (
|
||||
'SelectedBBSSubmitter' == mciName &&
|
||||
entry.submitterUserId == this.client.user.userId
|
||||
) {
|
||||
this.setViewText(
|
||||
'view',
|
||||
MciViewIds.view.SelectedBBSSubmitter,
|
||||
stringFormat(youSubmittedFormat, entry)
|
||||
);
|
||||
} else {
|
||||
this.setViewText('view',MciViewIds.view[mciName], t);
|
||||
this.setViewText('view', MciViewIds.view[mciName], t);
|
||||
}
|
||||
}
|
||||
});
|
||||
@@ -227,7 +253,7 @@ exports.getModule = class BBSListModule extends MenuModule {
|
||||
async.waterfall(
|
||||
[
|
||||
function clearAndDisplayArt(callback) {
|
||||
if(self.viewControllers.add) {
|
||||
if (self.viewControllers.add) {
|
||||
self.viewControllers.add.setFocus(false);
|
||||
}
|
||||
if (clearScreen) {
|
||||
@@ -236,34 +262,41 @@ exports.getModule = class BBSListModule extends MenuModule {
|
||||
theme.displayThemedAsset(
|
||||
self.menuConfig.config.art.entries,
|
||||
self.client,
|
||||
{ font : self.menuConfig.font, trailingLF : false },
|
||||
{ font: self.menuConfig.font, trailingLF: false },
|
||||
(err, artData) => {
|
||||
return callback(err, artData);
|
||||
}
|
||||
);
|
||||
},
|
||||
function initOrRedrawViewController(artData, callback) {
|
||||
if(_.isUndefined(self.viewControllers.add)) {
|
||||
if (_.isUndefined(self.viewControllers.add)) {
|
||||
const vc = self.addViewController(
|
||||
'view',
|
||||
new ViewController( { client : self.client, formId : FormIds.View } )
|
||||
new ViewController({
|
||||
client: self.client,
|
||||
formId: FormIds.View,
|
||||
})
|
||||
);
|
||||
|
||||
const loadOpts = {
|
||||
callingMenu : self,
|
||||
mciMap : artData.mciMap,
|
||||
formId : FormIds.View,
|
||||
callingMenu: self,
|
||||
mciMap: artData.mciMap,
|
||||
formId: FormIds.View,
|
||||
};
|
||||
|
||||
return vc.loadFromMenuConfig(loadOpts, callback);
|
||||
} else {
|
||||
self.viewControllers.view.setFocus(true);
|
||||
self.viewControllers.view.getView(MciViewIds.view.BBSList).redraw();
|
||||
self.viewControllers.view
|
||||
.getView(MciViewIds.view.BBSList)
|
||||
.redraw();
|
||||
return callback(null);
|
||||
}
|
||||
},
|
||||
function fetchEntries(callback) {
|
||||
const entriesView = self.viewControllers.view.getView(MciViewIds.view.BBSList);
|
||||
const entriesView = self.viewControllers.view.getView(
|
||||
MciViewIds.view.BBSList
|
||||
);
|
||||
self.entries = [];
|
||||
|
||||
self.database.each(
|
||||
@@ -272,16 +305,16 @@ exports.getModule = class BBSListModule extends MenuModule {
|
||||
(err, row) => {
|
||||
if (!err) {
|
||||
self.entries.push({
|
||||
text : row.bbs_name, // standard field
|
||||
id : row.id,
|
||||
bbsName : row.bbs_name,
|
||||
sysOp : row.sysop,
|
||||
telnet : row.telnet,
|
||||
www : row.www,
|
||||
location : row.location,
|
||||
software : row.software,
|
||||
submitterUserId : row.submitter_user_id,
|
||||
notes : row.notes,
|
||||
text: row.bbs_name, // standard field
|
||||
id: row.id,
|
||||
bbsName: row.bbs_name,
|
||||
sysOp: row.sysop,
|
||||
telnet: row.telnet,
|
||||
www: row.www,
|
||||
location: row.location,
|
||||
software: row.software,
|
||||
submitterUserId: row.submitter_user_id,
|
||||
notes: row.notes,
|
||||
});
|
||||
}
|
||||
},
|
||||
@@ -291,18 +324,22 @@ exports.getModule = class BBSListModule extends MenuModule {
|
||||
);
|
||||
},
|
||||
function getUserNames(entriesView, callback) {
|
||||
async.each(self.entries, (entry, next) => {
|
||||
User.getUserName(entry.submitterUserId, (err, username) => {
|
||||
if(username) {
|
||||
entry.submitter = username;
|
||||
} else {
|
||||
entry.submitter = 'N/A';
|
||||
}
|
||||
return next();
|
||||
});
|
||||
}, () => {
|
||||
return callback(null, entriesView);
|
||||
});
|
||||
async.each(
|
||||
self.entries,
|
||||
(entry, next) => {
|
||||
User.getUserName(entry.submitterUserId, (err, username) => {
|
||||
if (username) {
|
||||
entry.submitter = username;
|
||||
} else {
|
||||
entry.submitter = 'N/A';
|
||||
}
|
||||
return next();
|
||||
});
|
||||
},
|
||||
() => {
|
||||
return callback(null, entriesView);
|
||||
}
|
||||
);
|
||||
},
|
||||
function populateEntries(entriesView, callback) {
|
||||
self.setEntries(entriesView);
|
||||
@@ -312,7 +349,7 @@ exports.getModule = class BBSListModule extends MenuModule {
|
||||
|
||||
self.drawSelectedEntry(entry);
|
||||
|
||||
if(!entry) {
|
||||
if (!entry) {
|
||||
self.selectedBBS = -1;
|
||||
} else {
|
||||
self.selectedBBS = idx;
|
||||
@@ -331,10 +368,10 @@ exports.getModule = class BBSListModule extends MenuModule {
|
||||
entriesView.redraw();
|
||||
|
||||
return callback(null);
|
||||
}
|
||||
},
|
||||
],
|
||||
err => {
|
||||
if(cb) {
|
||||
if (cb) {
|
||||
return cb(err);
|
||||
}
|
||||
}
|
||||
@@ -353,23 +390,26 @@ exports.getModule = class BBSListModule extends MenuModule {
|
||||
theme.displayThemedAsset(
|
||||
self.menuConfig.config.art.add,
|
||||
self.client,
|
||||
{ font : self.menuConfig.font },
|
||||
{ font: self.menuConfig.font },
|
||||
(err, artData) => {
|
||||
return callback(err, artData);
|
||||
}
|
||||
);
|
||||
},
|
||||
function initOrRedrawViewController(artData, callback) {
|
||||
if(_.isUndefined(self.viewControllers.add)) {
|
||||
if (_.isUndefined(self.viewControllers.add)) {
|
||||
const vc = self.addViewController(
|
||||
'add',
|
||||
new ViewController( { client : self.client, formId : FormIds.Add } )
|
||||
new ViewController({
|
||||
client: self.client,
|
||||
formId: FormIds.Add,
|
||||
})
|
||||
);
|
||||
|
||||
const loadOpts = {
|
||||
callingMenu : self,
|
||||
mciMap : artData.mciMap,
|
||||
formId : FormIds.Add,
|
||||
callingMenu: self,
|
||||
mciMap: artData.mciMap,
|
||||
formId: FormIds.Add,
|
||||
};
|
||||
|
||||
return vc.loadFromMenuConfig(loadOpts, callback);
|
||||
@@ -379,10 +419,10 @@ exports.getModule = class BBSListModule extends MenuModule {
|
||||
self.viewControllers.add.switchFocus(MciViewIds.add.BBSName);
|
||||
return callback(null);
|
||||
}
|
||||
}
|
||||
},
|
||||
],
|
||||
err => {
|
||||
if(cb) {
|
||||
if (cb) {
|
||||
return cb(err);
|
||||
}
|
||||
}
|
||||
@@ -390,7 +430,16 @@ exports.getModule = class BBSListModule extends MenuModule {
|
||||
}
|
||||
|
||||
clearAddForm() {
|
||||
[ 'BBSName', 'Sysop', 'Telnet', 'Www', 'Location', 'Software', 'Error', 'Notes' ].forEach( mciName => {
|
||||
[
|
||||
'BBSName',
|
||||
'Sysop',
|
||||
'Telnet',
|
||||
'Www',
|
||||
'Location',
|
||||
'Software',
|
||||
'Error',
|
||||
'Notes',
|
||||
].forEach(mciName => {
|
||||
this.setViewText('add', MciViewIds.add[mciName], '');
|
||||
});
|
||||
}
|
||||
@@ -401,13 +450,12 @@ exports.getModule = class BBSListModule extends MenuModule {
|
||||
async.series(
|
||||
[
|
||||
function openDatabase(callback) {
|
||||
self.database = getTransactionDatabase(new sqlite3.Database(
|
||||
getModDatabasePath(moduleInfo),
|
||||
callback
|
||||
));
|
||||
self.database = getTransactionDatabase(
|
||||
new sqlite3.Database(getModDatabasePath(moduleInfo), callback)
|
||||
);
|
||||
},
|
||||
function createTables(callback) {
|
||||
self.database.serialize( () => {
|
||||
self.database.serialize(() => {
|
||||
self.database.run(
|
||||
`CREATE TABLE IF NOT EXISTS bbs_list (
|
||||
id INTEGER PRIMARY KEY,
|
||||
@@ -423,7 +471,7 @@ exports.getModule = class BBSListModule extends MenuModule {
|
||||
);
|
||||
});
|
||||
callback(null);
|
||||
}
|
||||
},
|
||||
],
|
||||
err => {
|
||||
return cb(err);
|
||||
|
||||
Reference in New Issue
Block a user