mirror of
https://github.com/pcottle/learnGitBranching.git
synced 2025-06-26 16:08:34 +02:00
[Flux] Level arbiter removed WOOO
This commit is contained in:
parent
0eade399d2
commit
095c52cec3
7 changed files with 20 additions and 186 deletions
|
@ -13,7 +13,6 @@ var events = _.clone(Backbone.Events);
|
||||||
var commandUI;
|
var commandUI;
|
||||||
var sandbox;
|
var sandbox;
|
||||||
var eventBaton;
|
var eventBaton;
|
||||||
var levelArbiter;
|
|
||||||
var levelDropdown;
|
var levelDropdown;
|
||||||
|
|
||||||
///////////////////////////////////////////////////////////////////////
|
///////////////////////////////////////////////////////////////////////
|
||||||
|
@ -30,13 +29,11 @@ var init = function() {
|
||||||
**/
|
**/
|
||||||
var Sandbox = require('../sandbox/').Sandbox;
|
var Sandbox = require('../sandbox/').Sandbox;
|
||||||
var EventBaton = require('../util/eventBaton').EventBaton;
|
var EventBaton = require('../util/eventBaton').EventBaton;
|
||||||
var LevelArbiter = require('../level/arbiter').LevelArbiter;
|
|
||||||
var LevelDropdownView = require('../views/levelDropdownView').LevelDropdownView;
|
var LevelDropdownView = require('../views/levelDropdownView').LevelDropdownView;
|
||||||
|
|
||||||
eventBaton = new EventBaton();
|
eventBaton = new EventBaton();
|
||||||
commandUI = new CommandUI();
|
commandUI = new CommandUI();
|
||||||
sandbox = new Sandbox();
|
sandbox = new Sandbox();
|
||||||
levelArbiter = new LevelArbiter();
|
|
||||||
levelDropdown = new LevelDropdownView({
|
levelDropdown = new LevelDropdownView({
|
||||||
wait: true
|
wait: true
|
||||||
});
|
});
|
||||||
|
@ -304,10 +301,6 @@ exports.getCommandUI = function() {
|
||||||
return commandUI;
|
return commandUI;
|
||||||
};
|
};
|
||||||
|
|
||||||
exports.getLevelArbiter = function() {
|
|
||||||
return levelArbiter;
|
|
||||||
};
|
|
||||||
|
|
||||||
exports.getLevelDropdown = function() {
|
exports.getLevelDropdown = function() {
|
||||||
return levelDropdown;
|
return levelDropdown;
|
||||||
};
|
};
|
||||||
|
|
|
@ -1,163 +0,0 @@
|
||||||
var _ = require('underscore');
|
|
||||||
var Backbone = require('backbone');
|
|
||||||
|
|
||||||
// Each level is part of a "sequence;" levels within
|
|
||||||
// a sequence proceed in order.
|
|
||||||
var levelSequences = require('../../levels').levelSequences;
|
|
||||||
var sequenceInfo = require('../../levels').sequenceInfo;
|
|
||||||
|
|
||||||
var Main = require('../app');
|
|
||||||
|
|
||||||
function LevelArbiter() {
|
|
||||||
this.levelMap = {};
|
|
||||||
this.levelSequences = levelSequences;
|
|
||||||
this.sequences = [];
|
|
||||||
this.init();
|
|
||||||
|
|
||||||
var solvedMap;
|
|
||||||
try {
|
|
||||||
solvedMap = JSON.parse(localStorage.getItem('solvedMap') || '{}');
|
|
||||||
} catch (e) {
|
|
||||||
console.warn('local storage failed', e);
|
|
||||||
// throw e;
|
|
||||||
}
|
|
||||||
this.solvedMap = solvedMap || {};
|
|
||||||
|
|
||||||
Main.getEvents().on('levelSolved', this.levelSolved, this);
|
|
||||||
}
|
|
||||||
|
|
||||||
LevelArbiter.prototype.init = function() {
|
|
||||||
_.each(this.levelSequences, function(levels, levelSequenceName) {
|
|
||||||
this.sequences.push(levelSequenceName);
|
|
||||||
if (!levels || !levels.length) {
|
|
||||||
throw new Error('no empty sequences allowed');
|
|
||||||
}
|
|
||||||
|
|
||||||
// for this particular sequence...
|
|
||||||
_.each(levels, function(level, index) {
|
|
||||||
this.validateLevel(level);
|
|
||||||
|
|
||||||
var id = levelSequenceName + String(index + 1);
|
|
||||||
var compiledLevel = _.extend(
|
|
||||||
{},
|
|
||||||
level,
|
|
||||||
{
|
|
||||||
index: index,
|
|
||||||
id: id,
|
|
||||||
sequenceName: levelSequenceName
|
|
||||||
}
|
|
||||||
);
|
|
||||||
|
|
||||||
// update our internal data
|
|
||||||
this.levelMap[id] = compiledLevel;
|
|
||||||
this.levelSequences[levelSequenceName][index] = compiledLevel;
|
|
||||||
}, this);
|
|
||||||
}, this);
|
|
||||||
};
|
|
||||||
|
|
||||||
LevelArbiter.prototype.isLevelSolved = function(id) {
|
|
||||||
if (!this.levelMap[id]) {
|
|
||||||
throw new Error('that level doesnt exist!');
|
|
||||||
}
|
|
||||||
return Boolean(this.solvedMap[id]);
|
|
||||||
};
|
|
||||||
|
|
||||||
LevelArbiter.prototype.levelSolved = function(id) {
|
|
||||||
// called without an id when we reset solved status
|
|
||||||
if (!id) { return; }
|
|
||||||
|
|
||||||
this.solvedMap[id] = true;
|
|
||||||
this.syncToStorage();
|
|
||||||
};
|
|
||||||
|
|
||||||
LevelArbiter.prototype.resetSolvedMap = function() {
|
|
||||||
this.solvedMap = {};
|
|
||||||
this.syncToStorage();
|
|
||||||
Main.getEvents().trigger('levelSolved');
|
|
||||||
};
|
|
||||||
|
|
||||||
LevelArbiter.prototype.syncToStorage = function() {
|
|
||||||
try {
|
|
||||||
localStorage.setItem('solvedMap', JSON.stringify(this.solvedMap));
|
|
||||||
} catch (e) {
|
|
||||||
console.warn('local storage fialed on set', e);
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
LevelArbiter.prototype.validateLevel = function(level) {
|
|
||||||
level = level || {};
|
|
||||||
var requiredFields = [
|
|
||||||
'name',
|
|
||||||
'goalTreeString',
|
|
||||||
//'description',
|
|
||||||
'solutionCommand'
|
|
||||||
];
|
|
||||||
|
|
||||||
var optionalFields = [
|
|
||||||
'hint',
|
|
||||||
'disabledMap',
|
|
||||||
'startTree'
|
|
||||||
];
|
|
||||||
|
|
||||||
_.each(requiredFields, function(field) {
|
|
||||||
if (level[field] === undefined) {
|
|
||||||
console.log(level);
|
|
||||||
throw new Error('I need this field for a level: ' + field);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
};
|
|
||||||
|
|
||||||
LevelArbiter.prototype.getSequenceToLevels = function() {
|
|
||||||
return this.levelSequences;
|
|
||||||
};
|
|
||||||
|
|
||||||
LevelArbiter.prototype.getSequences = function() {
|
|
||||||
return _.keys(this.levelSequences);
|
|
||||||
};
|
|
||||||
|
|
||||||
LevelArbiter.prototype.getLevelsInSequence = function(sequenceName) {
|
|
||||||
if (!this.levelSequences[sequenceName]) {
|
|
||||||
throw new Error('that sequecne name ' + sequenceName + 'does not exist');
|
|
||||||
}
|
|
||||||
return this.levelSequences[sequenceName];
|
|
||||||
};
|
|
||||||
|
|
||||||
LevelArbiter.prototype.getSequenceInfo = function(sequenceName) {
|
|
||||||
return sequenceInfo[sequenceName];
|
|
||||||
};
|
|
||||||
|
|
||||||
LevelArbiter.prototype.getLevel = function(id) {
|
|
||||||
return this.levelMap[id];
|
|
||||||
};
|
|
||||||
|
|
||||||
LevelArbiter.prototype.getNextLevel = function(id) {
|
|
||||||
if (!this.levelMap[id]) {
|
|
||||||
console.warn('that level doesnt exist!!!');
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
|
|
||||||
// meh, this method could be better. It's a tradeoff between
|
|
||||||
// having the sequence structure be really simple JSON
|
|
||||||
// and having no connectivity information between levels, which means
|
|
||||||
// you have to build that up yourself on every query
|
|
||||||
var level = this.levelMap[id];
|
|
||||||
var sequenceName = level.sequenceName;
|
|
||||||
var sequence = this.levelSequences[sequenceName];
|
|
||||||
|
|
||||||
var nextIndex = level.index + 1;
|
|
||||||
if (nextIndex < sequence.length) {
|
|
||||||
return sequence[nextIndex];
|
|
||||||
}
|
|
||||||
|
|
||||||
var nextSequenceIndex = this.sequences.indexOf(sequenceName) + 1;
|
|
||||||
if (nextSequenceIndex < this.sequences.length) {
|
|
||||||
var nextSequenceName = this.sequences[nextSequenceIndex];
|
|
||||||
return this.levelSequences[nextSequenceName][0];
|
|
||||||
}
|
|
||||||
|
|
||||||
// they finished the last level!
|
|
||||||
return null;
|
|
||||||
};
|
|
||||||
|
|
||||||
exports.LevelArbiter = LevelArbiter;
|
|
||||||
|
|
|
@ -11,6 +11,7 @@ var Visualization = require('../visuals/visualization').Visualization;
|
||||||
var ParseWaterfall = require('../level/parseWaterfall').ParseWaterfall;
|
var ParseWaterfall = require('../level/parseWaterfall').ParseWaterfall;
|
||||||
var Level = require('../level').Level;
|
var Level = require('../level').Level;
|
||||||
var LocaleStore = require('../stores/LocaleStore');
|
var LocaleStore = require('../stores/LocaleStore');
|
||||||
|
var LevelStore = require('../stores/LevelStore');
|
||||||
|
|
||||||
var Command = require('../models/commandModel').Command;
|
var Command = require('../models/commandModel').Command;
|
||||||
var GitShim = require('../git/gitShim').GitShim;
|
var GitShim = require('../git/gitShim').GitShim;
|
||||||
|
@ -54,7 +55,7 @@ var LevelBuilder = Level.extend({
|
||||||
// if we are editing a level our behavior is a bit different
|
// if we are editing a level our behavior is a bit different
|
||||||
var editLevelJSON;
|
var editLevelJSON;
|
||||||
if (options.editLevel) {
|
if (options.editLevel) {
|
||||||
editLevelJSON = Main.getLevelArbiter().getLevel(options.editLevel);
|
LevelStore.getLevel(options.editLevel);
|
||||||
options.level = editLevelJSON;
|
options.level = editLevelJSON;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -10,6 +10,7 @@ var Errors = require('../util/errors');
|
||||||
var Sandbox = require('../sandbox/').Sandbox;
|
var Sandbox = require('../sandbox/').Sandbox;
|
||||||
var GlobalStateActions = require('../actions/GlobalStateActions');
|
var GlobalStateActions = require('../actions/GlobalStateActions');
|
||||||
var LevelActions = require('../actions/LevelActions');
|
var LevelActions = require('../actions/LevelActions');
|
||||||
|
var LevelStore = require('../stores/LevelStore');
|
||||||
var Visualization = require('../visuals/visualization').Visualization;
|
var Visualization = require('../visuals/visualization').Visualization;
|
||||||
var DisabledMap = require('../level/disabledMap').DisabledMap;
|
var DisabledMap = require('../level/disabledMap').DisabledMap;
|
||||||
var GitShim = require('../git/gitShim').GitShim;
|
var GitShim = require('../git/gitShim').GitShim;
|
||||||
|
@ -414,14 +415,13 @@ var Level = Sandbox.extend({
|
||||||
levelSolved: function(defer) {
|
levelSolved: function(defer) {
|
||||||
this.solved = true;
|
this.solved = true;
|
||||||
if (!this.isShowingSolution) {
|
if (!this.isShowingSolution) {
|
||||||
Main.getEvents().trigger('levelSolved', this.level.id);
|
|
||||||
LevelActions.setLevelSolved(this.level.id);
|
LevelActions.setLevelSolved(this.level.id);
|
||||||
log.levelSolved(this.getEnglishName());
|
log.levelSolved(this.getEnglishName());
|
||||||
}
|
}
|
||||||
|
|
||||||
this.hideGoal();
|
this.hideGoal();
|
||||||
|
|
||||||
var nextLevel = Main.getLevelArbiter().getNextLevel(this.level.id);
|
var nextLevel = LevelStore.getNextLevel(this.level.id);
|
||||||
var numCommands = this.gitCommandsIssued.length;
|
var numCommands = this.gitCommandsIssued.length;
|
||||||
var best = this.getNumSolutionCommands();
|
var best = this.getNumSolutionCommands();
|
||||||
|
|
||||||
|
|
|
@ -13,6 +13,8 @@ var ParseWaterfall = require('../level/parseWaterfall').ParseWaterfall;
|
||||||
var DisabledMap = require('../level/disabledMap').DisabledMap;
|
var DisabledMap = require('../level/disabledMap').DisabledMap;
|
||||||
var Command = require('../models/commandModel').Command;
|
var Command = require('../models/commandModel').Command;
|
||||||
var GitShim = require('../git/gitShim').GitShim;
|
var GitShim = require('../git/gitShim').GitShim;
|
||||||
|
var LevelActions = require('../actions/LevelActions');
|
||||||
|
var LevelStore = require('../stores/LevelStore');
|
||||||
|
|
||||||
var Views = require('../views');
|
var Views = require('../views');
|
||||||
var ModalTerminal = Views.ModalTerminal;
|
var ModalTerminal = Views.ModalTerminal;
|
||||||
|
@ -152,7 +154,7 @@ var Sandbox = Backbone.View.extend({
|
||||||
startLevel: function(command, deferred) {
|
startLevel: function(command, deferred) {
|
||||||
var regexResults = command.get('regexResults') || [];
|
var regexResults = command.get('regexResults') || [];
|
||||||
var desiredID = regexResults[1] || '';
|
var desiredID = regexResults[1] || '';
|
||||||
var levelJSON = Main.getLevelArbiter().getLevel(desiredID);
|
var levelJSON = LevelStore.getLevel(desiredID);
|
||||||
|
|
||||||
// handle the case where that level is not found...
|
// handle the case where that level is not found...
|
||||||
if (!levelJSON) {
|
if (!levelJSON) {
|
||||||
|
@ -224,7 +226,7 @@ var Sandbox = Backbone.View.extend({
|
||||||
},
|
},
|
||||||
|
|
||||||
resetSolved: function(command, deferred) {
|
resetSolved: function(command, deferred) {
|
||||||
Main.getLevelArbiter().resetSolvedMap();
|
LevelActions.resetLevelsSolved();
|
||||||
command.addWarning(
|
command.addWarning(
|
||||||
intl.str('solved-map-reset')
|
intl.str('solved-map-reset')
|
||||||
);
|
);
|
||||||
|
|
|
@ -31,7 +31,6 @@ var toGlobalize = {
|
||||||
Markdown: require('markdown'),
|
Markdown: require('markdown'),
|
||||||
LevelDropdownView: require('../views/levelDropdownView'),
|
LevelDropdownView: require('../views/levelDropdownView'),
|
||||||
BuilderViews: require('../views/builderViews'),
|
BuilderViews: require('../views/builderViews'),
|
||||||
LevelArbiter: require('../level/arbiter'),
|
|
||||||
Util: require('../util/index'),
|
Util: require('../util/index'),
|
||||||
Intl: require('../intl')
|
Intl: require('../intl')
|
||||||
};
|
};
|
||||||
|
|
|
@ -9,6 +9,7 @@ var intl = require('../intl');
|
||||||
var log = require('../log');
|
var log = require('../log');
|
||||||
var KeyboardListener = require('../util/keyboard').KeyboardListener;
|
var KeyboardListener = require('../util/keyboard').KeyboardListener;
|
||||||
var Main = require('../app');
|
var Main = require('../app');
|
||||||
|
var LevelStore = require('../stores/LevelStore');
|
||||||
|
|
||||||
var ModalTerminal = require('../views').ModalTerminal;
|
var ModalTerminal = require('../views').ModalTerminal;
|
||||||
var ContainedBase = require('../views').ContainedBase;
|
var ContainedBase = require('../views').ContainedBase;
|
||||||
|
@ -62,8 +63,8 @@ var LevelDropdownView = ContainedBase.extend({
|
||||||
wait: true
|
wait: true
|
||||||
});
|
});
|
||||||
|
|
||||||
this.sequences = Main.getLevelArbiter().getSequences();
|
this.sequences = LevelStore.getSequences();
|
||||||
this.sequenceToLevels = Main.getLevelArbiter().getSequenceToLevels();
|
this.sequenceToLevels = LevelStore.getSequenceToLevels();
|
||||||
|
|
||||||
this.container = new ModalTerminal({
|
this.container = new ModalTerminal({
|
||||||
title: intl.str('select-a-level')
|
title: intl.str('select-a-level')
|
||||||
|
@ -76,9 +77,10 @@ var LevelDropdownView = ContainedBase.extend({
|
||||||
LocaleStore.subscribe(function() {
|
LocaleStore.subscribe(function() {
|
||||||
that.render.apply(that);
|
that.render.apply(that);
|
||||||
});
|
});
|
||||||
|
LevelStore.subscribe(function() {
|
||||||
|
that.render();
|
||||||
|
});
|
||||||
this.render();
|
this.render();
|
||||||
|
|
||||||
Main.getEvents().on('resetMapSolved', this.render, this);
|
|
||||||
if (!options.wait) {
|
if (!options.wait) {
|
||||||
this.show();
|
this.show();
|
||||||
}
|
}
|
||||||
|
@ -246,7 +248,7 @@ var LevelDropdownView = ContainedBase.extend({
|
||||||
},
|
},
|
||||||
|
|
||||||
getIndexForID: function(id) {
|
getIndexForID: function(id) {
|
||||||
return Main.getLevelArbiter().getLevel(id).index;
|
return LevelStore.getLevel(id).index;
|
||||||
},
|
},
|
||||||
|
|
||||||
selectFirst: function() {
|
selectFirst: function() {
|
||||||
|
@ -322,7 +324,7 @@ var LevelDropdownView = ContainedBase.extend({
|
||||||
'commandSubmitted',
|
'commandSubmitted',
|
||||||
'level ' + id
|
'level ' + id
|
||||||
);
|
);
|
||||||
var level = Main.getLevelArbiter().getLevel(id);
|
var level = LevelStore.getLevel(id);
|
||||||
var name = level.name.en_US;
|
var name = level.name.en_US;
|
||||||
log.levelSelected(name);
|
log.levelSelected(name);
|
||||||
}
|
}
|
||||||
|
@ -360,8 +362,8 @@ var SeriesView = BaseView.extend({
|
||||||
initialize: function(options) {
|
initialize: function(options) {
|
||||||
this.name = options.name || 'intro';
|
this.name = options.name || 'intro';
|
||||||
this.navEvents = options.navEvents;
|
this.navEvents = options.navEvents;
|
||||||
this.info = Main.getLevelArbiter().getSequenceInfo(this.name);
|
this.info = LevelStore.getSequenceInfo(this.name);
|
||||||
this.levels = Main.getLevelArbiter().getLevelsInSequence(this.name);
|
this.levels = LevelStore.getLevelsInSequence(this.name);
|
||||||
|
|
||||||
this.levelIDs = [];
|
this.levelIDs = [];
|
||||||
_.each(this.levels, function(level) {
|
_.each(this.levels, function(level) {
|
||||||
|
@ -386,7 +388,7 @@ var SeriesView = BaseView.extend({
|
||||||
// property changing but it's the 11th hour...
|
// property changing but it's the 11th hour...
|
||||||
var toLoop = this.$('div.levelIcon').each(function(index, el) {
|
var toLoop = this.$('div.levelIcon').each(function(index, el) {
|
||||||
var id = $(el).attr('data-id');
|
var id = $(el).attr('data-id');
|
||||||
$(el).toggleClass('solved', Main.getLevelArbiter().isLevelSolved(id));
|
$(el).toggleClass('solved', LevelStore.isLevelSolved(id));
|
||||||
});
|
});
|
||||||
},
|
},
|
||||||
|
|
||||||
|
@ -410,7 +412,7 @@ var SeriesView = BaseView.extend({
|
||||||
},
|
},
|
||||||
|
|
||||||
updateAboutForLevelID: function(id) {
|
updateAboutForLevelID: function(id) {
|
||||||
var level = Main.getLevelArbiter().getLevel(id);
|
var level = LevelStore.getLevel(id);
|
||||||
this.setAbout(intl.getName(level));
|
this.setAbout(intl.getName(level));
|
||||||
},
|
},
|
||||||
|
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue