Add field gesture and field images for the different gestures (#803)

This commit is contained in:
Sam El-Husseini
2018-05-24 17:09:08 -07:00
committed by GitHub
parent af766cedbc
commit c20efd5942
29 changed files with 185 additions and 3 deletions

View File

@ -1,10 +1,15 @@
/// <reference path="../node_modules/pxt-core/built/pxteditor.d.ts"/>
/// <reference path="../node_modules/pxt-core/built/pxtsim.d.ts"/>
import { FieldGestures } from "./field_gestures";
pxt.editor.initFieldExtensionsAsync = function (opts: pxt.editor.FieldExtensionOptions): Promise<pxt.editor.FieldExtensionResult> {
pxt.debug('loading pxt-microbit field editors...')
const res: pxt.editor.FieldExtensionResult = {
fieldEditors: []
fieldEditors: [{
selector: "gestures",
editor: FieldGestures
}]
};
return Promise.resolve<pxt.editor.FieldExtensionResult>(res);
}

View File

@ -0,0 +1,33 @@
/// <reference path="../node_modules/pxt-core/localtypings/blockly.d.ts"/>
/// <reference path="../node_modules/pxt-core/built/pxtblocks.d.ts"/>
/// <reference path="../node_modules/pxt-core/built/pxtsim.d.ts"/>
export interface FieldGesturesOptions extends pxtblockly.FieldImagesOptions {
columns?: string;
width?: string;
}
export class FieldGestures extends pxtblockly.FieldImages implements Blockly.FieldCustom {
public isFieldCustom_ = true;
constructor(text: string, options: FieldGesturesOptions, validator?: Function) {
super(text, options, validator);
this.columns_ = parseInt(options.columns) || 4;
this.width_ = parseInt(options.width) || 350;
this.addLabel_ = true;
this.setText = Blockly.FieldDropdown.prototype.setText;
this.updateWidth = (Blockly.Field as any).prototype.updateWidth;
this.updateTextNode_ = Blockly.Field.prototype.updateTextNode_;
}
trimOptions_() {
}
protected buttonClick_ = function (e: any) {
let value = e.target.getAttribute('data-value');
this.setValue(value);
Blockly.DropDownDiv.hide();
};
}