APIs

Show:
/**
 * @namespace flexygo.ui.wc
 */
var flexygo;
(function (flexygo) {
    var ui;
    (function (ui) {
        var wc;
        (function (wc) {
            /**
        * Library for the FlxWhiteBoardElement web component.
        *
        * @class FlxWhiteBoardElement
        * @constructor
        * @return {FlxWhiteBoardElement}
        */
            class FlxWhiteBoardElement extends HTMLElement {
                constructor() {
                    super();
                    /**
                   * Set when component is attached to DOM
                   * @property connected {boolean}
                   */
                    this.connected = false;
                    this.type = 'whiteboard';
                    this.property = null;
                    this.options = null;
                    this.moduleName = null;
                    this.mode = 'whiteboard';
                    this.readonly = false;
                    this.myCM = null; //TODO_TS
                    this.control = null;
                    this.value = null;
                }
                /**
                * Fires when element is attached to DOM
                * @method connectedCallback
                */
                connectedCallback() {
                    let element = $(this);
                    this.type = element.attr('type') || 'html';
                    let propName = element.attr('property');
                    if (propName && flexygo.utils.isBlank(this.options)) {
                        let parentCtl = element.closest('flx-edit,flx-list,flx-propertymanager,flx-view,flx-filter');
                        if (parentCtl && parentCtl.length > 0) {
                            let wcParent = parentCtl[0];
                            if (parentCtl.is('flx-filter')) {
                                let objName = element.attr('object');
                                this.options = jQuery.extend(true, {}, wcParent.properties[objName + '-' + propName]);
                            }
                            else {
                                this.options = jQuery.extend(true, {}, wcParent.properties[propName]);
                            }
                        }
                        this.property = propName;
                    }
                    if (typeof element.attr('Required') !== 'undefined') {
                        if (!this.options) {
                            this.options = new flexygo.api.ObjectProperty();
                        }
                        this.options.IsRequired = true;
                    }
                    if (typeof element.attr('Disabled') !== 'undefined') {
                        if (!this.options) {
                            this.options = new flexygo.api.ObjectProperty();
                        }
                        this.options.Locked = true;
                    }
                    let RequiredMessage = element.attr('RequiredMessage');
                    if (RequiredMessage && RequiredMessage !== '') {
                        if (!this.options) {
                            this.options = new flexygo.api.ObjectProperty();
                        }
                        this.options.IsRequiredMessage = RequiredMessage;
                    }
                    let Class = element.attr('Class');
                    if (Class && Class !== '') {
                        if (!this.options) {
                            this.options = new flexygo.api.ObjectProperty();
                        }
                        this.options.CssClass = Class;
                        element.attr('Control-Class', this.options.CssClass);
                        element.attr('Class', '');
                    }
                    let PlaceHolder = element.attr('PlaceHolder');
                    if (PlaceHolder && PlaceHolder !== '') {
                        if (!this.options) {
                            this.options = new flexygo.api.ObjectProperty();
                        }
                        this.options.PlaceHolder = PlaceHolder;
                    }
                    let IconClass = element.attr('IconClass');
                    if (IconClass && IconClass !== '') {
                        if (!this.options) {
                            this.options = new flexygo.api.ObjectProperty();
                        }
                        this.options.IconClass = IconClass;
                    }
                    let HelpId = element.attr('HelpId');
                    if (HelpId && HelpId !== '') {
                        if (!this.options) {
                            this.options = new flexygo.api.ObjectProperty();
                        }
                        this.options.HelpId = HelpId;
                    }
                    let ctlClass = element.attr('Control-Class');
                    if (ctlClass && ctlClass !== '') {
                        if (!this.options) {
                            this.options = new flexygo.api.ObjectProperty();
                        }
                        this.options.CssClass = ctlClass;
                    }
                    let ctlStyle = element.attr('Control-Style');
                    if (ctlStyle && ctlStyle !== '') {
                        if (!this.options) {
                            this.options = new flexygo.api.ObjectProperty();
                        }
                        this.options.Style = ctlStyle;
                    }
                    let Hide = element.attr('Hide');
                    if (Hide && Hide !== '') {
                        if (!this.options) {
                            this.options = new flexygo.api.ObjectProperty();
                        }
                        this.options.Hide = (Hide == 'true') ? true : false;
                    }
                    this.init();
                    let Value = element.attr('Value');
                    if (Value && Value !== '') {
                        this.setValue(Value);
                    }
                    this.connected = true;
                }
                /**
               * Array of observed attributes. REQUIRED
               * @property observedAttributes {Array}
               */
                static get observedAttributes() {
                    return ['type', 'property', 'required', 'disabled', 'requiredmessage', 'class', 'placeholder', 'iconclass', 'helpid', 'hide'];
                }
                attributeChangedCallback(attrName, oldVal, newVal) {
                    let element = $(this);
                    if (!this.connected) {
                        return;
                    }
                    if (this.connected) {
                        if (attrName.toLowerCase() === 'type' && newVal && newVal !== '') {
                            this.type = newVal;
                            this.refresh();
                            //if (this.moduleName) { this.init(); }
                        }
                        if (attrName.toLowerCase() === 'property' && newVal && newVal !== '') {
                            let propName = newVal;
                            let parentCtl = element.closest('flx-edit, flx-list,flx-propertymanager');
                            if (parentCtl && parentCtl.length > 0) {
                                let wcParent = parentCtl[0];
                                this.options = jQuery.extend(true, {}, wcParent.properties[propName]);
                            }
                            this.property = newVal;
                            this.refresh();
                        }
                        if (attrName.toLowerCase() === 'required') {
                            if (!this.options) {
                                this.options = new flexygo.api.ObjectProperty();
                            }
                            if (typeof element.attr('required') !== 'undefined') {
                                this.options.IsRequired = true;
                            }
                            else {
                                this.options.IsRequired = false;
                            }
                            element.find('textarea').prop('required', this.options.IsRequired);
                        }
                        if (attrName.toLowerCase() === 'disabled') {
                            if (!this.options) {
                                this.options = new flexygo.api.ObjectProperty();
                            }
                            if (typeof element.attr('disabled') !== 'undefined') {
                                this.options.Locked = true;
                            }
                            else {
                                this.options.Locked = false;
                            }
                            element.find('textarea, input, button').prop('disabled', this.options.Locked);
                            if (this.options.Locked) {
                                element.find('.note-editable').attr('contenteditable', 'false');
                            }
                            else {
                                element.find('.note-editable').attr('contenteditable', 'true');
                            }
                            this.refresh();
                        }
                        if (attrName.toLowerCase() === 'requiredmessage' && newVal && newVal !== '') {
                            if (!this.options) {
                                this.options = new flexygo.api.ObjectProperty();
                            }
                            this.options.IsRequiredMessage = newVal;
                            this.refresh();
                        }
                        if (attrName.toLowerCase() === 'class' && element.attr('Control-Class') !== newVal && newVal != oldVal) {
                            if (!this.options) {
                                this.options = new flexygo.api.ObjectProperty();
                            }
                            this.options.CssClass = newVal;
                            if (element.attr('Control-Class') !== this.options.CssClass) {
                                if (newVal != '') {
                                    element.attr('Control-Class', this.options.CssClass);
                                }
                                element.attr('Class', '');
                                this.refresh();
                            }
                        }
                        if (attrName.toLowerCase() === 'placeholder' && newVal && newVal !== '') {
                            if (!this.options) {
                                this.options = new flexygo.api.ObjectProperty();
                            }
                            this.options.PlaceHolder = newVal;
                            this.refresh();
                        }
                        if (attrName.toLowerCase() === 'iconclass' && newVal && newVal !== '') {
                            if (!this.options) {
                                this.options = new flexygo.api.ObjectProperty();
                            }
                            this.options.IconClass = newVal;
                            this.refresh();
                        }
                        if (attrName.toLowerCase() === 'helpid' && newVal && newVal !== '') {
                            if (!this.options) {
                                this.options = new flexygo.api.ObjectProperty();
                            }
                            this.options.HelpId = newVal;
                            this.refresh();
                        }
                        if (attrName.toLowerCase() === 'hide' && newVal && newVal !== '') {
                            if (!this.options) {
                                this.options = new flexygo.api.ObjectProperty();
                            }
                            this.options.Hide = newVal;
                            this.init();
                        }
                    }
                }
                refresh() {
                    let val = this.getValue();
                    this.init();
                    if (val && val !== "") {
                        this.setValue(val);
                    }
                }
                init() {
                    let me = $(this);
                    if (me.attr('mode') && me.attr('mode').toLowerCase() === 'view') {
                        this.initViewMode();
                    }
                    else {
                        this.initEditMode();
                    }
                }
                initViewMode() {
                    let me = $(this);
                    this.initEditMode();
                    me.parent('div[data-tag="control"]').attr('style', 'height:inherit;');
                    me.find('i').remove();
                    me.find('div.ctl-container').removeClass().addClass('cpr-view-container');
                    me.off();
                    if (this.options && this.options.Style) {
                        me.children('div.cpr-view-container img.img-responsive').attr('style', this.options.Style);
                    }
                    if (this.options && this.options.CssClass) {
                        me.children('div').addClass(this.options.CssClass);
                    }
                    if (this.options && this.options.Hide) {
                        me.addClass("hideControl");
                    }
                }
                initEditMode() {
                    let me = $(this);
                    let input;
                    let img;
                    let icon;
                    me.parent('div[data-tag="control"]').attr('style', 'height:94%;');
                    this.control = $('<div class="ctl-container ctl-cpr-transition ctl-hover">');
                    input = $('<input src=""  type="hidden"/>');
                    icon = $('<i class="flx-icon icon-pencil ctl-icon ctl-cpr-transition" ></i> ');
                    img = $('<img src="" class="img-responsive ctl-image ctl-cpr-transition"/>');
                    this.control.append(input);
                    this.control.append(icon);
                    this.control.append(img);
                    me.html(this.control);
                    me.off('click').on('click', () => {
                        this.initWhiteBoard();
                    });
                    if (this.options && this.options.Locked) {
                        this.readonly = this.options.Locked;
                    }
                    if (this.options && this.options.PlaceHolder) {
                        me.attr('placeholder', this.options.PlaceHolder);
                    }
                    this.setOptions();
                }
                setOptions() {
                    let me = $(this);
                    let input = me.find('input');
                    let img = me.find('img');
                    input.on('change.refreshvalue', () => {
                        me.attr('value', input.val());
                    });
                    if (this.options && this.options.Name && this.options.Name !== '') {
                        input.attr('name', this.options.Name);
                    }
                    else {
                        input.attr('name', flexygo.utils.uniqueName());
                    }
                    if (me.attr('tab') && me.attr('tab') !== '') {
                        input.attr('tabindex', me.attr('tab'));
                    }
                    if (this.options && this.options.Locked) {
                        input.prop('disabled', this.options.Locked);
                        me.off();
                        me.find('div.ctl-container').removeClass('ctl-hover').addClass('ctl-container-locked');
                        img.addClass('ctl-image-locked');
                    }
                    if (this.options && this.options.ClientReadOnly) {
                        me.find('i').removeClass('icon-pencil').addClass('icon-eye');
                    }
                    if (this.options && this.options.Style) {
                        me.find('img').attr('style', this.options.Style);
                    }
                    if (this.options && this.options.CssClass) {
                        me.children('div').addClass(this.options.CssClass);
                    }
                    if (this.options && this.options.Hide) {
                        me.addClass("hideControl");
                    }
                    if (this.options && this.options.IsRequired) {
                        input.prop('required', true);
                    }
                    if (this.options && this.options.CauseRefresh) {
                        input.on('change', (e) => {
                            //$(document).trigger('refreshProperty', [input.closest('flx-edit'), this.options.Name]);
                            let ev = {
                                class: "property",
                                type: "changed",
                                sender: this,
                                masterIdentity: this.property
                            };
                            flexygo.events.trigger(ev);
                        });
                    }
                }
                getValue() {
                    let me = $(this);
                    return me.find('input').val();
                }
                setValue(value) {
                    $(this).find('input').val(value);
                    if (value) {
                        $(this).find("img").attr("src", value);
                    }
                    $(this).attr('value', value);
                }
                setValueView(value) {
                    this.value = value;
                    let input = $(this).find('input');
                    input.html(flexygo.string.escapeHTML(value));
                    $(this).attr('value', value);
                }
                initWhiteBoard() {
                    let property = this.property;
                    let whiteBoardCanvas;
                    let whiteBoardContext;
                    let inputControlToSave;
                    let imgControlToSave;
                    let pizarraTransparent = false;
                    let lineColor;
                    let lineWeight;
                    let img = new Image;
                    let imgLength;
                    let position;
                    lineColor = "rgb(105, 105, 105)";
                    lineWeight = 0.5;
                    inputControlToSave = $("flx-whiteboard[property='" + property + "']").find('input');
                    imgControlToSave = $("flx-whiteboard[property='" + property + "']").find('img');
                    let pizarraHtml = `<div id="WBContainer" style="z-index:999999;width:100%;height:100%;position:fixed;margin:0px;padding:0px;top:0px;left:0px;background-color:white;text-align:center;">
               <canvas id="WBcanvas"></canvas>               
                   <nav class="WBButtonsContainer">
                  <a class="WBColorButtons Colours clickable"></a>
                   <a class="WBColorButtons Colours clickable"></a>
                    <a class="WBColorButtons Colours clickable"></a>
                    <input id="WBWeight" class="WBColorButtons" type="range" min="0.5" max="15" value="0.5" step="0.1" name="weight" >
                   <a id="WBControlButton" class="WBColorButtons clickable" ></a>
                  </nav>
                   <!-- <i id="WBUpload"  tooltip="Subir Imagen" class="WBActionButtons"><input id="subirImagen" type="file" name="files[]" accept="image/*"></i>-->
                  <i id="WBSave" tooltip="Guardar"   class="WBActionButtons"></i>
                    <i id="WBDelete" tooltip="Borrar" class="WBActionButtons"></i>               
                <i id="WBClose" tooltip="Cerrar" class="WBActionButtons"></i>
               </div>`;
                    $('#WBContainer').remove();
                    $('body').append(pizarraHtml);
                    whiteBoardCanvas = $("#WBcanvas")[0];
                    whiteBoardCanvas.width = $('#WBContainer').width() - 2;
                    whiteBoardCanvas.height = $('#WBContainer').height() - 48;
                    whiteBoardContext = whiteBoardCanvas.getContext("2d");
                    if (whiteBoardCanvas.width > whiteBoardCanvas.height) {
                        position = true;
                    }
                    else {
                        position = false;
                    }
                    whiteBoardContext.fillStyle = 'white';
                    whiteBoardContext.fillRect(0, 0, whiteBoardCanvas.width, whiteBoardCanvas.height);
                    imgLength = imgControlToSave.attr("src").length;
                    if (imgLength > 0) {
                        img.src = imgControlToSave.attr("src");
                        if (img.width > img.height) {
                            whiteBoardContext.drawImage(img, 0, whiteBoardCanvas.height / 2 - whiteBoardCanvas.width * img.height / img.width / 2, whiteBoardCanvas.width, whiteBoardCanvas.width * img.height / img.width);
                        }
                        else {
                            whiteBoardContext.drawImage(img, whiteBoardCanvas.width / 2 - whiteBoardCanvas.height * img.width / img.height / 2, 0, whiteBoardCanvas.height * img.width / img.height, whiteBoardCanvas.height);
                        }
                    }
                    inputControlToSave = $("flx-whiteboard[property='" + property + "']").find('input');
                    imgControlToSave = $("flx-whiteboard[property='" + property + "']").find('img');
                    whiteBoardContext.strokeStyle = lineColor;
                    whiteBoardContext.lineWidth = lineWeight;
                    whiteBoardContext.shadowBlur = 0.4;
                    whiteBoardContext.shadowColor = lineColor;
                    whiteBoardContext.lineJoin = whiteBoardContext.lineCap = "round";
                    let entra;
                    let lastX;
                    let lastY;
                    $(whiteBoardCanvas).on('mousedown', (e) => {
                        entra = 0;
                        whiteBoardContext.beginPath();
                        whiteBoardContext.moveTo(e.clientX - $(whiteBoardCanvas).offset().left, e.clientY - $(whiteBoardCanvas).offset().top);
                        $(whiteBoardCanvas).on('mousemove', (e) => {
                            e.preventDefault();
                            if (e.originalEvent.targetTouches && e.originalEvent.targetTouches[0].pageX) {
                                lastX = e.originalEvent.targetTouches[0].pageX - $(whiteBoardCanvas).offset().left;
                                lastY = e.originalEvent.targetTouches[0].pageY - $(whiteBoardCanvas).offset().top;
                            }
                            else {
                                lastX = e.clientX - $(whiteBoardCanvas).offset().left;
                                lastY = e.clientY - $(whiteBoardCanvas).offset().top;
                            }
                            whiteBoardContext.lineTo(lastX, lastY);
                            whiteBoardContext.stroke();
                            if (entra < 200)
                                entra++;
                        });
                        $(whiteBoardCanvas).on('touchmove', (e) => {
                            e.preventDefault();
                            if (e.originalEvent.targetTouches && e.originalEvent.targetTouches[0].pageX) {
                                lastX = e.originalEvent.targetTouches[0].pageX - $(whiteBoardCanvas).offset().left;
                                lastY = e.originalEvent.targetTouches[0].pageY - $(whiteBoardCanvas).offset().top;
                            }
                            else {
                                lastX = e.clientX - $(whiteBoardCanvas).offset().left;
                                lastY = e.clientY - $(whiteBoardCanvas).offset().top;
                            }
                            whiteBoardContext.lineTo(lastX, lastY);
                            whiteBoardContext.stroke();
                            if (entra < 200)
                                entra++;
                        });
                    });
                    $(whiteBoardCanvas).on('mouseup', function (ev) {
                        $(whiteBoardCanvas).off('mousemove');
                        $(whiteBoardCanvas).off('touchmove');
                        if (entra < 2) {
                            //whiteBoardContext.fillRect(lastX,lastY,4,4); // fill in the pixel at (10,10)
                            whiteBoardContext.beginPath();
                            whiteBoardContext.arc(lastX, lastY, 3, 0, 2 * Math.PI, true);
                            whiteBoardContext.fill();
                        }
                        lastX = 0;
                        lastY = 0;
                    });
                    $(whiteBoardCanvas).on('touchstart', (e) => {
                        entra = 0;
                        whiteBoardContext.beginPath();
                        whiteBoardContext.moveTo(e.clientX - $(whiteBoardCanvas).offset().left, e.clientY - $(whiteBoardCanvas).offset().top);
                        $(whiteBoardCanvas).on('mousemove', function (ev) {
                            ev.preventDefault();
                            if (ev.originalEvent.targetTouches && ev.originalEvent.targetTouches[0].pageX) {
                                lastX = ev.originalEvent.targetTouches[0].pageX - $(whiteBoardCanvas).offset().left;
                                lastY = ev.originalEvent.targetTouches[0].pageY - $(whiteBoardCanvas).offset().top;
                            }
                            else {
                                lastX = ev.clientX - $(whiteBoardCanvas).offset().left;
                                lastY = ev.clientY - $(whiteBoardCanvas).offset().top;
                            }
                            whiteBoardContext.lineTo(lastX, lastY);
                            whiteBoardContext.stroke();
                            if (entra < 200)
                                entra++;
                        });
                        $(whiteBoardCanvas).on('touchmove', function (ev) {
                            ev.preventDefault();
                            if (ev.originalEvent.targetTouches && ev.originalEvent.targetTouches[0].pageX) {
                                lastX = ev.originalEvent.targetTouches[0].pageX - $(whiteBoardCanvas).offset().left;
                                lastY = ev.originalEvent.targetTouches[0].pageY - $(whiteBoardCanvas).offset().top;
                            }
                            else {
                                lastX = ev.clientX - $(whiteBoardCanvas).offset().left;
                                lastY = ev.clientY - $(whiteBoardCanvas).offset().top;
                            }
                            whiteBoardContext.lineTo(lastX, lastY);
                            whiteBoardContext.stroke();
                            if (entra < 200)
                                entra++;
                        });
                    });
                    $(whiteBoardCanvas).on('touchend', function (ev) {
                        $(whiteBoardCanvas).off('mousemove');
                        $(whiteBoardCanvas).off('touchmove');
                        if (entra < 2) {
                            //whiteBoardContext.fillRect(lastX,lastY,4,4); // fill in the pixel at (10,10)
                            whiteBoardContext.beginPath();
                            whiteBoardContext.arc(lastX, lastY, 3, 0, 2 * Math.PI, true);
                            whiteBoardContext.fill();
                        }
                        lastX = 0;
                        lastY = 0;
                    });
                    $(whiteBoardCanvas).on('mouseout', function (ev) {
                        $(whiteBoardCanvas).off('mousemove');
                        $(whiteBoardCanvas).off('touchmove');
                        if (entra < 2) {
                            //whiteBoardContext.fillRect(lastX,lastY,4,4); // fill in the pixel at (10,10)
                            whiteBoardContext.beginPath();
                            whiteBoardContext.arc(lastX, lastY, 3, 0, 2 * Math.PI, true);
                            whiteBoardContext.fill();
                        }
                        lastX = 0;
                        lastY = 0;
                    });
                    $("#WBSave").on('click', (e) => {
                        let data = whiteBoardCanvas.toDataURL();
                        let emptyWhiteBoard = "";
                        if (data == emptyWhiteBoard) {
                            data = "";
                        }
                        if (imgControlToSave) {
                            imgControlToSave.attr('src', data);
                        }
                        if (inputControlToSave) {
                            inputControlToSave.val(data);
                        }
                        inputControlToSave.trigger('change');
                        imgControlToSave.trigger('change');
                        $('#WBContainer').remove();
                    });
                    $("#WBClose").on('click', (e) => {
                        $('#WBContainer').remove();
                    });
                    $("#WBDelete").on('click', (e) => {
                        whiteBoardContext.clearRect(0, 0, whiteBoardCanvas.width, whiteBoardCanvas.height);
                        whiteBoardContext.fillStyle = 'white';
                        whiteBoardContext.fillRect(0, 0, whiteBoardCanvas.width, whiteBoardCanvas.height);
                        if (whiteBoardCanvas.width > whiteBoardCanvas.height) {
                            position = true;
                        }
                        else {
                            position = false;
                        }
                    });
                    $(window).off('resize').on('resize', () => {
                        if (whiteBoardCanvas) {
                            let w = $('#WBContainer').width() - 2;
                            let h = $('#WBContainer').height() - 48;
                            let temp_cnvs = document.createElement('canvas');
                            let temp_cntx = temp_cnvs.getContext('2d');
                            temp_cnvs.width = w;
                            temp_cnvs.height = h;
                            temp_cntx.fillStyle = 'white';
                            temp_cntx.fillRect(0, 0, w, h);
                            if (position) {
                                temp_cntx.drawImage(whiteBoardCanvas, 0, h / 2 - w * whiteBoardCanvas.height / whiteBoardCanvas.width / 2, w, w * whiteBoardCanvas.height / whiteBoardCanvas.width);
                            }
                            else {
                                temp_cntx.drawImage(whiteBoardCanvas, w / 2 - h * whiteBoardCanvas.width / whiteBoardCanvas.height / 2, 0, h * whiteBoardCanvas.width / whiteBoardCanvas.height, h);
                            }
                            whiteBoardCanvas.width = w;
                            whiteBoardCanvas.height = h;
                            whiteBoardContext.drawImage(temp_cnvs, 0, 0);
                            whiteBoardContext.strokeStyle = lineColor;
                            whiteBoardContext.lineWidth = lineWeight;
                            whiteBoardContext.shadowBlur = 0.4;
                            whiteBoardContext.shadowColor = lineColor;
                            whiteBoardContext.lineJoin = whiteBoardContext.lineCap = 'round';
                        }
                    });
                    $(".Colours").click(function (a) {
                        lineColor = $(this).css("background-Color");
                        let x = $("#WBControlButton").css("background-color");
                        $(this).css("background-color", x);
                        $("#WBControlButton").css("background-color", lineColor);
                        whiteBoardContext.strokeStyle = lineColor;
                        whiteBoardContext.shadowColor = lineColor;
                    });
                    $('#WBControlButton').on(function (a) {
                        lineColor = $(a).css("background-Color");
                        let x = $("#WBControlButton").css("background-color");
                        $(a).css("background-color", x);
                        $("#WBControlButton").css("background-color", lineColor);
                        whiteBoardContext.strokeStyle = lineColor;
                        whiteBoardContext.shadowColor = lineColor;
                    });
                    $('#WBWeight').on('change', () => {
                        lineWeight = $("#WBWeight").val();
                        whiteBoardContext.lineWidth = lineWeight;
                    });
                    $('#subirImagen').on('change', (e) => {
                        let element = $(e.currentTarget);
                        if (element.attr('type') === 'file') {
                            if (element[0].files && element[0].files[0]) {
                                let reader = new FileReader();
                                //  reader.onloadend = function () {
                                reader.onload = (e) => {
                                    whiteBoardContext.clearRect(0, 0, whiteBoardCanvas.width, whiteBoardCanvas.height);
                                    whiteBoardContext.fillStyle = 'white';
                                    whiteBoardContext.fillRect(0, 0, whiteBoardCanvas.width, whiteBoardCanvas.height);
                                    if (whiteBoardCanvas.width > whiteBoardCanvas.height) {
                                        position = true;
                                    }
                                    else {
                                        position = false;
                                    }
                                    //setTimeout(() => { 
                                    img.src = reader.result;
                                    //img.src = e.target.result;
                                    if (img.width > img.height) {
                                        whiteBoardContext.drawImage(img, 0, whiteBoardCanvas.height / 2 - whiteBoardCanvas.width * img.height / img.width / 2, whiteBoardCanvas.width, whiteBoardCanvas.width * img.height / img.width);
                                    }
                                    else {
                                        whiteBoardContext.drawImage(img, whiteBoardCanvas.width / 2 - whiteBoardCanvas.height * img.width / img.height / 2, 0, whiteBoardCanvas.height * img.width / img.height, whiteBoardCanvas.height);
                                    }
                                    //  }, 500);
                                };
                                if (element[0].files[0]) {
                                    reader.readAsDataURL(element[0].files[0]);
                                }
                                element.value = "";
                            }
                        }
                    });
                }
                /**
                * Trigger Dependencies.
                * @method triggerDependencies
                */
                triggerDependencies() {
                    let me;
                    let input;
                    me = $(this);
                    input = me.find('input');
                    input.trigger('change');
                }
            }
            wc.FlxWhiteBoardElement = FlxWhiteBoardElement;
        })(wc = ui.wc || (ui.wc = {}));
    })(ui = flexygo.ui || (flexygo.ui = {}));
})(flexygo || (flexygo = {}));
window.customElements.define('flx-whiteboard', flexygo.ui.wc.FlxWhiteBoardElement);
//# sourceMappingURL=flx-whiteboard.js.map