/* jslint node: true */ 'use strict'; const MenuView = require('./menu_view.js').MenuView; const ansi = require('./ansi_term.js'); const strUtil = require('./string_util.js'); const { pipeToAnsi } = require('./color_codes.js'); const formatString = require('./string_format'); const util = require('util'); const assert = require('assert'); const _ = require('lodash'); exports.SpinnerMenuView = SpinnerMenuView; function SpinnerMenuView(options) { options.justify = options.justify || 'left'; options.cursor = options.cursor || 'hide'; MenuView.call(this, options); this.initDefaultWidth(); var self = this; /* this.cachePositions = function() { self.positionCacheExpired = false; }; */ this.updateSelection = function () { //assert(!self.positionCacheExpired); assert(this.focusedItemIndex >= 0 && this.focusedItemIndex <= self.items.length); this.drawItem(this.focusedItemIndex); this.emit('index update', this.focusedItemIndex); }; this.drawItem = function (index) { const item = this.items[index]; if (!item) { return; } const cached = this.getRenderCacheItem(index, this.hasFocus); if (cached) { return this.client.term.write( `${ansi.goto(this.position.row, this.position.col)}${cached}` ); } let text; let sgr; if (this.complexItems) { text = pipeToAnsi( formatString( this.hasFocus && this.focusItemFormat ? this.focusItemFormat : this.itemFormat, item ) ); sgr = this.focusItemFormat ? '' : this.hasFocus ? this.getFocusSGR() : self.getSGR(); } else { text = strUtil.stylizeString( item.text, this.hasFocus ? self.focusTextStyle : self.textStyle ); sgr = this.hasFocus ? this.getFocusSGR() : this.getSGR(); } text = `${sgr}${strUtil.pad( text, this.dimens.width, this.fillChar, this.justify )}`; this.client.term.write( `${ansi.goto(this.position.row, this.position.col)}${text}` ); this.setRenderCacheItem(index, text, this.hasFocus); }; } util.inherits(SpinnerMenuView, MenuView); SpinnerMenuView.prototype.redraw = function () { SpinnerMenuView.super_.prototype.redraw.call(this); this.drawItem(this.focusedItemIndex); }; SpinnerMenuView.prototype.setFocus = function (focused) { SpinnerMenuView.super_.prototype.setFocus.call(this, focused); this.redraw(); }; SpinnerMenuView.prototype.setFocusItemIndex = function (index) { SpinnerMenuView.super_.prototype.setFocusItemIndex.call(this, index); // sets this.focusedItemIndex this.updateSelection(); // will redraw }; SpinnerMenuView.prototype.onKeyPress = function (ch, key) { if (key) { if (this.isKeyMapped('up', key.name)) { if (0 === this.focusedItemIndex) { this.focusedItemIndex = this.items.length - 1; } else { this.focusedItemIndex--; } this.updateSelection(); return; } else if (this.isKeyMapped('down', key.name)) { if (this.items.length - 1 === this.focusedItemIndex) { this.focusedItemIndex = 0; } else { this.focusedItemIndex++; } this.updateSelection(); return; } } SpinnerMenuView.super_.prototype.onKeyPress.call(this, ch, key); }; SpinnerMenuView.prototype.getData = function () { const item = this.getItem(this.focusedItemIndex); return _.isString(item.data) ? item.data : this.focusedItemIndex; };