Files
blockly/core/renderers/zelos/renderer.js
Sam El-Husseini 426e17a06d Move more CSS into renderers. (#3455)
* Move more CSS into renderers.
2019-11-20 11:57:37 -08:00

170 lines
5.0 KiB
JavaScript

/**
* @license
* Copyright 2019 Google LLC
*
* 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 Zelos renderer.
* @author fenichel@google.com (Rachel Fenichel)
*/
'use strict';
goog.provide('Blockly.zelos.Renderer');
goog.require('Blockly.blockRendering');
goog.require('Blockly.blockRendering.Renderer');
goog.require('Blockly.utils.object');
goog.require('Blockly.zelos.ConstantProvider');
goog.require('Blockly.zelos.Drawer');
goog.require('Blockly.zelos.PathObject');
goog.require('Blockly.zelos.RenderInfo');
goog.require('Blockly.zelos.CursorSvg');
/**
* The zelos renderer.
* @param {string} name The renderer name.
* @package
* @constructor
* @extends {Blockly.blockRendering.Renderer}
*/
Blockly.zelos.Renderer = function(name) {
Blockly.zelos.Renderer.superClass_.constructor.call(this, name);
};
Blockly.utils.object.inherits(Blockly.zelos.Renderer,
Blockly.blockRendering.Renderer);
/**
* Create a new instance of the renderer's constant provider.
* @return {!Blockly.zelos.ConstantProvider} The constant provider.
* @protected
* @override
*/
Blockly.zelos.Renderer.prototype.makeConstants_ = function() {
return new Blockly.zelos.ConstantProvider();
};
/**
* Create a new instance of the renderer's render info object.
* @param {!Blockly.BlockSvg} block The block to measure.
* @return {!Blockly.zelos.RenderInfo} The render info object.
* @protected
* @override
*/
Blockly.zelos.Renderer.prototype.makeRenderInfo_ = function(block) {
return new Blockly.zelos.RenderInfo(this, block);
};
/**
* Create a new instance of the renderer's drawer.
* @param {!Blockly.BlockSvg} block The block to render.
* @param {!Blockly.blockRendering.RenderInfo} info An object containing all
* information needed to render this block.
* @return {!Blockly.zelos.Drawer} The drawer.
* @protected
* @override
*/
Blockly.zelos.Renderer.prototype.makeDrawer_ = function(block, info) {
return new Blockly.zelos.Drawer(block,
/** @type {!Blockly.zelos.RenderInfo} */ (info));
};
/**
* Create a new instance of the renderer's cursor drawer.
* @param {!Blockly.WorkspaceSvg} workspace The workspace the cursor belongs to.
* @param {boolean=} opt_marker True if the cursor is a marker. A marker is used
* to save a location and is an immovable cursor. False or undefined if the
* cursor is not a marker.
* @return {!Blockly.blockRendering.CursorSvg} The cursor drawer.
* @package
* @override
*/
Blockly.zelos.Renderer.prototype.makeCursorDrawer = function(
workspace, opt_marker) {
return new Blockly.zelos.CursorSvg(workspace, this.getConstants(), opt_marker);
};
/**
* Create a new instance of a renderer path object.
* @param {!SVGElement} root The root SVG element.
* @return {!Blockly.zelos.PathObject} The renderer path object.
* @package
* @override
*/
Blockly.zelos.Renderer.prototype.makePathObject = function(root) {
return new Blockly.zelos.PathObject(root,
/** @type {!Blockly.zelos.ConstantProvider} */ (this.getConstants()));
};
/**
* @override
*/
Blockly.zelos.Renderer.prototype.shouldHighlightConnection = function(conn) {
return conn.type != Blockly.INPUT_VALUE && conn.type !== Blockly.OUTPUT_VALUE;
};
/**
* @override
*/
Blockly.zelos.Renderer.prototype.shouldInsertDraggedBlock = function(_block,
_conn) {
return false;
};
/**
* @override
*/
Blockly.zelos.Renderer.prototype.getCSS_ = function() {
var selector = '.' + this.name + '-renderer';
var constants = this.getConstants();
return [
/* eslint-disable indent */
// Fields.
selector + ' .blocklyText {',
'cursor: default;',
'fill: #fff;',
'font-family: ' + constants.FIELD_TEXT_FONTFAMILY + ';',
'font-size: ' + constants.FIELD_TEXT_FONTSIZE + 'pt;',
'font-weight: ' + constants.FIELD_TEXT_FONTWEIGHT + ';',
'}',
// Editable field hover.
selector + ' .blocklyEditableText:not(.editing):hover>rect ,',
selector + ' .blocklyEditableText:not(.editing):hover>.blocklyPath {',
'stroke: #fff;',
'stroke-width: 2;',
'}',
// Text field input.
selector + ' .blocklyHtmlInput {',
'font-family: ' + constants.FIELD_TEXT_FONTFAMILY + ';',
'font-weight: ' + constants.FIELD_TEXT_FONTWEIGHT + ';',
'}',
// Dropdown field.
selector + ' .blocklyDropdownText {',
'fill: #fff !important;',
'}',
// Connection highlight.
selector + ' .blocklyHighlightedConnectionPath {',
'stroke: #fff200;',
'}',
/* eslint-enable indent */
];
};
Blockly.blockRendering.register('zelos', Blockly.zelos.Renderer);