VaKeR CYBER ARMY
Logo of a company Server : Apache/2.4.41 (Ubuntu)
System : Linux absol.cf 5.4.0-198-generic #218-Ubuntu SMP Fri Sep 27 20:18:53 UTC 2024 x86_64
User : www-data ( 33)
PHP Version : 7.4.33
Disable Function : pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_get_handler,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,pcntl_async_signals,pcntl_unshare,
Directory :  /var/www/html/libs/absol-full/dist/js/

Upload File :
current_dir [ Writeable ] document_root [ Writeable ]

 

Current File : /var/www/html/libs/absol-full/dist/js/mdls__absol-form__js__components__ImageFileInput.js
/*** module: node_modules/absol-form/js/components/ImageFileInput.js ***/
"use strict";

Object.defineProperty(exports, "__esModule", {
  value: true
});
exports.default = void 0;

var _FCore = _interopRequireWildcard(require("../core/FCore"));

var _ScalableComponent = _interopRequireDefault(require("../core/ScalableComponent"));

var _inheritComponentClass = _interopRequireDefault(require("../core/inheritComponentClass"));

require("../../css/imagefileinput.css");

var _utils = require("absol-acomp/js/utils");

var _Assembler = require("../core/Assembler");

var _FileInput = _interopRequireDefault(require("./FileInput"));




var _ = _FCore.default._;
/***
 * @extends ScalableComponent
 * @constructor
 */

function ImageFileInput() {
  _ScalableComponent.default.call(this);

  this._imageSrc = undefined;
}

(0, _inheritComponentClass.default)(ImageFileInput, _ScalableComponent.default);
ImageFileInput.prototype.tag = "ImageFileInput";
ImageFileInput.prototype.menuIcon = "span.mdi.mdi-image-plus";
ImageFileInput.prototype.style.vAlign = 'center';
ImageFileInput.prototype.style.display = 'inline-block';
ImageFileInput.prototype._defaultBackgroundImg = '';
ImageFileInput.prototype.attributes.uploadMethol = 'default';
ImageFileInput.prototype.attributeHandlers.value = {
  set: function (value) {
    var ref = arguments[arguments.length - 1];
    var prev = ref.get();

    if (typeof value === 'string') {
      this._imageSrc = value;
    } else if (value instanceof File || value instanceof Blob) {
      this._imageSrc = URL.createObjectURL(value);
    } else if (value && value.url) {
      this._imageSrc = value.url;
    } else {
      this._imageSrc = undefined;
      value = null;
    }

    if (this._imageSrc) {
      this.$img.addStyle('backgroundImage', 'url(' + this._imageSrc + ')');
      this.domElt.addClass('as-has-file');
    } else {
      this.$img.addStyle('backgroundImage', 'url(' + this._defaultBackgroundImg + ')');
      this.domElt.removeClass('as-has-file');
    }

    ref.set(value); //set before send to pin

    if (!value !== !prev || value && prev && value !== prev) {
      this.pinFire('value');
      this.notifyChange();
    }

    return value;
  },
  descriptor: {
    type: "ImageSource",
    sign: 'ImageSource'
  },
  export: function () {
    return this._imageSrc;
  }
};
ImageFileInput.prototype.attributeHandlers.readonly = {
  set: function (value) {
    return !!value;
  },
  descriptor: {
    type: 'bool'
  },
  export: function () {
    return arguments[arguments.length - 1].get() || undefined;
  }
};
ImageFileInput.prototype.styleHandlers.previewSize = {
  set: function (value) {
    if (!['contain', 'cover'].includes(value)) value = 'contain';
    if (value === 'contain') this.$img.removeStyle('backgroundSize');else this.$img.addStyle('backgroundSize', value);
    return value;
  },
  export: function () {
    var value = arguments[arguments.length - 1];
    return value === 'contain' ? undefined : value;
  },
  descriptor: {
    type: 'enum',
    values: ['contain', 'cover']
  }
};
ImageFileInput.prototype.attributeHandlers.uploadMethol = {
  set: function (value) {
    if (['default', 'quick', 'browser_file'].indexOf(value) < 0) {
      value = 'default';
    }

    return value;
  },
  export: function (ref) {
    var value = ref.get();
    if (value === 'default') value = undefined;
    return value;
  },
  descriptor: {
    type: 'enum',
    values: ['default', 'quick', 'browser_file']
  }
};
ImageFileInput.prototype.pinHandlers.value = {
  get: function () {
    return this.attributes.value;
  },
  descriptor: {
    type: "ImageFile"
  }
};

ImageFileInput.prototype.onCreate = function () {
  _ScalableComponent.default.prototype.onCreate.call(this);

  this.attributes.readonly = false;
  this.style.previewSize = 'contain';
  this.attributes.value = null;
};

ImageFileInput.prototype.onCreated = function () {
  _ScalableComponent.default.prototype.onCreated.call(this);

  this.domElt.on('click', this.openImageFileDialog.bind(this));
};

ImageFileInput.prototype.openImageFileDialog = function () {
  if (this.attributes.uploadMethol !== 'browser_file' && window.contentModule && window.contentModule.chooseFile) {
    window.contentModule.chooseFile({
      type: "image_file",
      accept: 'image/*',
      hideFinder: this.attributes.uploadMethol === 'quick'
    }).then(function (result) {
      if (result && result.length > 0) result = result[0];

      if (result) {
        this.attributes.value = result;
      }
    }.bind(this));
  } else {
    (0, _utils.openFileDialog)({
      accept: 'image/*'
    }).then(function (files) {
      if (files && files.length > 0) {
        this.attributes.value = files[0];
      }
    }.bind(this));
  }
};

ImageFileInput.prototype.render = function () {
  var res = _({
    class: 'asf-image-file-input',
    child: [{
      class: 'asf-image-file-input-img',
      style: {
        backgroundImage: 'url(' + this._defaultBackgroundImg + ')'
      }
    }]
  });

  this.$img = (0, _FCore.$)('.asf-image-file-input-img', res);
  return res;
};

ImageFileInput.prototype.getAcceptsStyleNames = function () {
  return _ScalableComponent.default.prototype.getAcceptsStyleNames.call(this).concat(['previewSize']);
};

ImageFileInput.prototype.createDataBindingDescriptor = function () {
  var thisC = this;
  return {
    set: function (value) {
      thisC.setAttribute('value', value);
    },
    get: function () {
      return thisC.getAttribute('value');
    }
  };
};

_Assembler.AssemblerInstance.addClass(ImageFileInput);

var _default = ImageFileInput;
exports.default = _default;

VaKeR 2022