Source: item_checkbox.js

/*************************************************************
 *
 *  Copyright (c) 2015-2016 The MathJax Consortium
 *
 *  Licensed under the Apache License, Version 2.0 (the "License");
 *  you may not use this file except in compliance with the License.
 *  You may obtain a copy of the License at
 *
 *      http://www.apache.org/licenses/LICENSE-2.0
 *
 *  Unless required by applicable law or agreed to in writing, software
 *  distributed under the License is distributed on an "AS IS" BASIS,
 *  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 *  See the License for the specific language governing permissions and
 *  limitations under the License.
 */
/**
 * @fileoverview Class of checkbox items.
 *
 * @author volker.sorge@gmail.com (Volker Sorge)
 */
/// <reference path="abstract_item.ts" />
/// <reference path="menu_util.ts" />
/// <reference path="variable.ts" />
/// <reference path="variable_item.ts" />
var ContextMenu;
(function (ContextMenu) {
    class Checkbox extends ContextMenu.AbstractItem {
        /**
         * @constructor
         * @extends {AbstractItem}
         * @param {Menu} menu The context menu or sub-menu the item belongs to.
         * @param {string} content The content of the menu item.
         * @param {string} variable The variable that is changed.
         * @param {string=} id Optionally the id of the menu item.
         */
        constructor(menu, content, variable, id) {
            super(menu, 'checkbox', content, id);
            /**
             * @override
             */
            this.role = 'menuitemcheckbox';
            this.variable = menu.getPool().lookup(variable);
            this.register();
        }
        /**
         * Parses a JSON respresentation of a checkbox item.
         * @param {JSON} json The JSON object to parse.
         * @param {Menu} menu The menu the item is attached to.
         * @return {Checkbox} The new checkbox object.
         */
        static parse({ content: content, variable: variable, id: id }, menu) {
            return new Checkbox(menu, content, variable, id);
        }
        /**
         * @override
         */
        executeAction() {
            this.variable.setValue(!this.variable.getValue());
            ContextMenu.MenuUtil.close(this);
        }
        /**
         * @override
         */
        generateHtml() {
            super.generateHtml();
            let html = this.getHtml();
            this.span = document.createElement('span');
            this.span.textContent = '\u2713';
            this.span.classList.add(ContextMenu.HtmlClasses['MENUCHECK']);
            html.appendChild(this.span);
            this.update();
        }
        /**
         * @override
         */
        register() {
            this.variable.register(this);
        }
        /**
         * @override
         */
        unregister() {
            this.variable.unregister(this);
        }
        /**
         * @override
         */
        update() {
            let disp = this.variable.getValue() ? '' : 'none';
            this.span.style.display = this.variable.getValue() ? '' : 'none';
        }
    }
    ContextMenu.Checkbox = Checkbox;
})(ContextMenu || (ContextMenu = {}));