All Downloads are FREE. Search and download functionalities are using the official Maven repository.

resources.js.qpid.common.ResourceWidget.js Maven / Gradle / Ivy

/*
 *
 * Licensed to the Apache Software Foundation (ASF) under one
 * or more contributor license agreements.  See the NOTICE file
 * distributed with this work for additional information
 * regarding copyright ownership.  The ASF licenses this file
 * to you 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.
 *
 */
define(["dojo/_base/declare",
        "dojo/_base/array",
        "dojo/_base/lang",
        "qpid/common/util",
        "dijit/_Widget",
        "dijit/_TemplatedMixin",
        "dijit/_WidgetsInTemplateMixin",
        "qpid/common/FormWidgetMixin",
        "dojo/text!common/ResourceWidget.html",
        "dojox/html/entities",
        "dojox/form/Uploader",
        "dijit/form/Button",
        "dijit/form/ValidationTextBox",
        "dojox/validate/us",
        "dojox/validate/web",
        "dojo/domReady!"],
    function (declare,
              array,
              lang,
              util,
              _WidgetBase,
              _TemplatedMixin,
              _WidgetsInTemplateMixin,
              FormWidgetMixin,
              template,
              entities)
    {

        return declare("qpid.common.ResourceWidget",
            [_WidgetBase, _TemplatedMixin, _WidgetsInTemplateMixin, FormWidgetMixin],
            {
                templateString: template,
                fileReaderSupported: window.FileReader ? true : false,
                displayWarningWhenFileReaderUnsupported: false,
                isDebug: false,
                uploaded: false,

                buildRendering: function ()
                {
                    //Strip out the apache comment header from the template html as comments unsupported.
                    this.templateString = this.templateString.replace(//g, "");
                    this.inherited(arguments);
                },
                postCreate: function ()
                {
                    this.inherited(arguments);

                    if (this._resetValue === undefined)
                    {
                        this._lastValueReported = this._resetValue = this.value;
                    }

                    var that = this;

                    if (this.fileReaderSupported)
                    {
                        this.fileReader = new FileReader();
                        this.fileReader.onload = function (evt)
                        {
                            that._uploadFileComplete(evt);
                        };
                        this.fileReader.onerror = function (ex)
                        {
                            console.error("Failed to load file for " + this.name, ex);
                        };
                        this.uploader.on("change", function (selected)
                        {
                            that._fileChanged(selected)
                        });
                        this.clearButton.on("click", function (event)
                        {
                            that._fileClearButtonClicked(event)
                        });
                    }
                    else
                    {
                        // Fall back for IE8/9 which do not support FileReader
                        this.uploadFields.style.display = "none";
                        if (this.displayWarningWhenFileReaderUnsupported)
                        {
                            this.unsupportedWarning.className = this.unsupportedWarning.className.replace("hidden", "");
                        }
                    }
                    this.resourceLocation.on("blur", function ()
                    {
                        that._pathChanged()
                    });
                    this._originalValue = arguments.value;
                    if (this.placeHolder)
                    {
                        this.resourceLocation.set("placeHolder", this.placeHolder);
                    }
                    if (this.promptMessage)
                    {
                        this.resourceLocation.set("promptMessage", this.promptMessage);
                    }
                    if (this.title)
                    {
                        this.resourceLocation.set("title", this.title);
                    }
                    this.resourceLocation.set("required", this.required ? true : false);
                    this.uploadData.style.display = "none";
                },
                startup: function ()
                {
                    if (this.fileReaderSupported)
                    {
                        this.uploader.startup();
                    }
                },
                destroy: function ()
                {
                    if (this.fileReaderSupported && this.fileReader)
                    {
                        util.abortReaderSafely(this.fileReader);
                    }
                    this.inherited(arguments);
                },
                reset: function () {
                    this.inherited(arguments);
                    this.uploader.reset();
                },
                _fileChanged: function (evt)
                {
                    var file = this.uploader.domNode.children[0].files[0];
                    this.selectedFileName = file.name;
                    this.selectedFile.innerHTML = file.name;
                    this.selectedFileStatus.className = "loadingIcon";
                    if (this.isDebug)
                    {
                        this._log("Beginning to read file " + file.name + " for " + this.name);
                    }
                    this.fileReader.readAsDataURL(file);
                },
                _uploadFileComplete: function (evt)
                {
                    var reader = evt.target;
                    var result = reader.result;
                    if (this.isDebug)
                    {
                        this._log(this.name + " file read complete, contents " + result);
                    }
                    this.set("value", result);
                },
                _fileClearButtonClicked: function (event)
                {
                    this.uploaded = false;
                    this.uploader.reset();
                    this.set("value", this._resetValue);
                },
                _pathChanged: function ()
                {
                    var serverPathValue = this.resourceLocation.get("value") || this._resetValue;
                    this.set("value", serverPathValue);
                    if (this.uploaded)
                    {
                        this.uploaded = !serverPathValue;
                    }
                },
                _setValueAttr: function (newValue, priorityChange)
                {
                    var isDataUrl = this.uploaded || ( newValue && newValue.indexOf("data:") == 0 );
                    if (isDataUrl)
                    {
                        this._initUploaded(true);
                    }
                    else
                    {
                        this.resourceLocation.set("value", newValue);
                        this.selectedFileName = null;
                        this.selectedFileStatus.className = "";
                        this.selectedFile.innerHTML = "";
                        this.resourceLocation.set("required", this.required ? true : false);
                        this.resourceLocation.setDisabled(false);
                        this.clearButton.setDisabled(true);
                        this.uploadData.style.display = "none";
                    }
                    this.inherited(arguments);
                },
                _log: function (message)
                {
                    if (this.isDebug)
                    {
                        console.log(message);
                    }
                },
                _setPlaceHolderAttr: function (newValue)
                {
                    this.resourceLocation.set("placeHolder", newValue);
                },
                _setUploadedAttr: function (uploaded)
                {
                    this.uploaded = uploaded;
                    this._initUploaded(uploaded);
                },
                _initUploaded: function (uploaded)
                {
                    if (uploaded)
                    {
                        this.uploadData.style.display = "block";
                        this.selectedFileStatus.className = "loadedIcon";
                        this.selectedFile.innerHTML = this.selectedFileName || "uploaded data";
                        this.resourceLocation.set("value", "");
                        this.resourceLocation.setDisabled(true);
                        this.resourceLocation.set("required", false);
                        this.clearButton.setDisabled(false);
                        this.selectedFileStatus.className = "loadedIcon";
                    }
                }
            });
    });




© 2015 - 2025 Weber Informatics LLC | Privacy Policy