@uex/web-extensions
Version:
Uex extensions for Angular 6+ web projects
420 lines • 30.3 kB
JavaScript
/**
* @fileoverview added by tsickle
* Generated from: lib/modules/table/classes/item.ts
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import * as _ from "lodash";
import { TableButton } from "./button";
export class TableItem {
/**
* @param {?} column
* @param {?} row_data
* @param {?} row
*/
constructor(column, row_data, row) {
this.column = column;
this.row_data = row_data;
this.row = row;
this._has_link = false;
this._has_link_with_action = false;
this._has_link_with_url = false;
this._has_buttons = false;
this._has_input = false;
this._setInput();
this._setButtons();
this.update();
}
/**
* @return {?}
*/
get label() {
return this._label || "";
}
/**
* @return {?}
*/
get title() {
return this._title || "";
}
/**
* @return {?}
*/
get accessor() {
return this.column.accessor;
}
/**
* @return {?}
*/
get input() {
return this._input;
}
/**
* @return {?}
*/
get schema() {
return this._schema;
}
/**
* @return {?}
*/
get buttons() {
return this._buttons
? this._buttons.filter((/**
* @param {?} button
* @return {?}
*/
button => button.visible))
: null;
}
/**
* @return {?}
*/
get numeric() {
return this.column.numeric;
}
/**
* @return {?}
*/
get html() {
return this.column.html;
}
/**
* @return {?}
*/
get width() {
return this.column.width;
}
/**
* @return {?}
*/
get selectable() {
return _.isBoolean(this.column.selectable) ? this.column.selectable : false;
}
/**
* @return {?}
*/
get truncate() {
return _.isBoolean(this.column.truncate) ? this.column.truncate : false;
}
/**
* @return {?}
*/
get allow_select() {
return this.column.selectable && this.row.selectable;
}
/**
* @return {?}
*/
get selected() {
return this.row.selected;
}
/**
* @return {?}
*/
get has_link() {
return this._has_link;
}
/**
* @return {?}
*/
get has_link_with_action() {
return this._has_link_with_action;
}
/**
* @return {?}
*/
get has_link_with_url() {
return this._has_link_with_url;
}
/**
* @return {?}
*/
get has_buttons() {
return this._has_buttons;
}
/**
* @return {?}
*/
get has_input() {
return this._has_input;
}
/**
* @return {?}
*/
update() {
this._setAttributes();
this._setLabel();
this._setTitle();
this._setLink();
this._updateButtons();
}
/**
* @param {?} schema
* @return {?}
*/
$setSchema(schema) {
this._schema = schema;
}
/**
* @private
* @return {?}
*/
_setAttributes() {
/** @type {?} */
const link = this.column.link;
this._has_link =
link && (link.url || _.isFunction(link.action)) ? true : false;
this._has_link_with_action = link && _.isFunction(link.action);
this._has_link_with_url = link && !_.isFunction(link.action);
this._has_buttons = this.buttons && this.buttons.length > 0;
this._has_input = this._input ? true : false;
}
/**
* @private
* @return {?}
*/
_setButtons() {
/** @type {?} */
let buttons = [];
if (this.column.buttons) {
buttons = this.column.buttons.map((/**
* @param {?} button
* @return {?}
*/
button => {
return new TableButton(button, this, this.row);
}));
}
this._buttons = buttons;
}
/**
* @private
* @return {?}
*/
_updateButtons() {
if (this._buttons) {
this._buttons.forEach((/**
* @param {?} button
* @return {?}
*/
button => button.update()));
}
}
/**
* @private
* @return {?}
*/
_setInput() {
/** @type {?} */
let input;
if (this.column.input) {
input = _.cloneDeep(this.column.input);
if (input) {
this._setLabel();
input.key = this.column.accessor;
if (this.row_data.id) {
input.key += `-${this.row_data.id}`;
}
else {
input.key += `-${this.row.index}`;
}
/** @type {?} */
const events = this.column.input.events || {};
if (!_.isEmpty(events)) {
_.forEach(_.clone(events), (/**
* @param {?} fn
* @param {?} key
* @return {?}
*/
(fn, key) => {
if (_.includes(["onInit", "onChange", "onKeyup"], key) ||
!_.isFunction(fn)) {
return;
}
events[key] = (/**
* @param {?} event
* @return {?}
*/
event => {
event.table_row = this.row;
event.table_item = this;
event.data = this.row_data;
fn(event);
});
}));
}
input.events = _.merge({}, events, {
onInit: (/**
* @param {?} event
* @return {?}
*/
event => this._onInputInit(event, events.onInit)),
onChange: (/**
* @param {?} event
* @return {?}
*/
event => this._onInputChange(event, events.onChange))
});
input.value = this._label;
}
}
this._input = input;
}
/**
* @private
* @return {?}
*/
_setLabel() {
if (_.isFunction(this.column.format)) {
this._label = this.column.format(this.row_data);
}
else {
/** @type {?} */
const label = _.at(this.row_data, this.column.accessor)[0];
this._label = label ? label.toString() : null;
}
}
/**
* @private
* @return {?}
*/
_setTitle() {
this._title = _.isFunction(this.column.title)
? ((/** @type {?} */ (this.column.title)))(this.row_data)
: this.html
? this.label.replace(/<(?:.|\n)*?>/gm, "")
: this.label;
}
/**
* @private
* @return {?}
*/
_setLink() {
if (!this._has_link) {
this.link = null;
return;
}
else {
/** @type {?} */
const link = this.column.link;
if (link.action) {
/** @type {?} */
const action = (/**
* @param {?} event
* @return {?}
*/
(event) => {
event.preventDefault();
link.action(this.row_data);
});
this.link = {
action: action
};
}
else {
this.link = {
url: _.isFunction(link.url)
? ((/** @type {?} */ (link.url)))(this.row_data)
: link.url,
target: link.target
};
}
}
}
/**
* @private
* @param {?} event
* @param {?} callback_event
* @return {?}
*/
_onInputInit(event, callback_event) {
if (_.isFunction(callback_event)) {
event.table_row = this.row;
event.table_item = this;
event.data = this.row_data;
if (_.isFunction(callback_event)) {
callback_event(event);
}
}
}
/**
* @private
* @param {?} event
* @param {?} callback_event
* @return {?}
*/
_onInputChange(event, callback_event) {
this._input.value = event.schema.value;
_.set(this.row_data, this.column.accessor, event.schema.value);
if (_.isFunction(callback_event)) {
event.table_row = this.row;
event.table_item = this;
event.data = this.row_data;
if (_.isFunction(callback_event)) {
callback_event(event);
}
}
this.row.update();
}
}
if (false) {
/**
* @type {?}
* @private
*/
TableItem.prototype._label;
/**
* @type {?}
* @private
*/
TableItem.prototype._title;
/**
* @type {?}
* @private
*/
TableItem.prototype._buttons;
/**
* @type {?}
* @private
*/
TableItem.prototype._input;
/**
* @type {?}
* @private
*/
TableItem.prototype._schema;
/**
* @type {?}
* @private
*/
TableItem.prototype._has_link;
/**
* @type {?}
* @private
*/
TableItem.prototype._has_link_with_action;
/**
* @type {?}
* @private
*/
TableItem.prototype._has_link_with_url;
/**
* @type {?}
* @private
*/
TableItem.prototype._has_buttons;
/**
* @type {?}
* @private
*/
TableItem.prototype._has_input;
/** @type {?} */
TableItem.prototype.link;
/** @type {?} */
TableItem.prototype.column;
/** @type {?} */
TableItem.prototype.row_data;
/** @type {?} */
TableItem.prototype.row;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"item.js","sourceRoot":"ng://@uex/web-extensions/","sources":["lib/modules/table/classes/item.ts"],"names":[],"mappings":"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","sourcesContent":["import * as _ from \"lodash\";\r\n\r\nimport { FormSchema } from \"../../form/classes/schema\";\r\nimport {\r\n  FormSchemaData,\r\n  FormSchemaEventFunction\r\n} from \"../../form/form.interface\";\r\n\r\nimport { TableButton } from \"./button\";\r\nimport { TableColumn } from \"./column\";\r\nimport { TableRow } from \"./row\";\r\n\r\nimport {\r\n  TableColumnLink,\r\n  TableColumnInputSchemaEvent,\r\n  TableColumnInputData,\r\n  TableColumnFormatter\r\n} from \"../table.interface\";\r\n\r\nexport class TableItem {\r\n  constructor(\r\n    public column: TableColumn,\r\n    public row_data: any,\r\n    public row: TableRow\r\n  ) {\r\n    this._setInput();\r\n    this._setButtons();\r\n    this.update();\r\n  }\r\n\r\n  private _label: string;\r\n  private _title: string;\r\n  private _buttons: Array<TableButton>;\r\n  private _input: FormSchemaData;\r\n  private _schema: FormSchema;\r\n\r\n  private _has_link = false;\r\n  private _has_link_with_action = false;\r\n  private _has_link_with_url = false;\r\n  private _has_buttons = false;\r\n  private _has_input = false;\r\n\r\n  public link: TableColumnLink;\r\n\r\n  public get label(): string {\r\n    return this._label || \"\";\r\n  }\r\n\r\n  public get title(): string {\r\n    return this._title || \"\";\r\n  }\r\n\r\n  public get accessor(): string {\r\n    return this.column.accessor;\r\n  }\r\n\r\n  public get input(): FormSchemaData {\r\n    return this._input;\r\n  }\r\n\r\n  public get schema(): FormSchema {\r\n    return this._schema;\r\n  }\r\n\r\n  public get buttons(): Array<TableButton> {\r\n    return this._buttons\r\n      ? this._buttons.filter(button => button.visible)\r\n      : null;\r\n  }\r\n\r\n  public get numeric(): boolean {\r\n    return this.column.numeric;\r\n  }\r\n\r\n  public get html(): boolean {\r\n    return this.column.html;\r\n  }\r\n\r\n  public get width(): string {\r\n    return this.column.width;\r\n  }\r\n\r\n  public get selectable(): boolean {\r\n    return _.isBoolean(this.column.selectable) ? this.column.selectable : false;\r\n  }\r\n\r\n  public get truncate(): boolean {\r\n    return _.isBoolean(this.column.truncate) ? this.column.truncate : false;\r\n  }\r\n\r\n  public get allow_select(): boolean {\r\n    return this.column.selectable && this.row.selectable;\r\n  }\r\n\r\n  public get selected(): boolean {\r\n    return this.row.selected;\r\n  }\r\n\r\n  public get has_link(): boolean {\r\n    return this._has_link;\r\n  }\r\n  public get has_link_with_action(): boolean {\r\n    return this._has_link_with_action;\r\n  }\r\n  public get has_link_with_url(): boolean {\r\n    return this._has_link_with_url;\r\n  }\r\n\r\n  public get has_buttons(): boolean {\r\n    return this._has_buttons;\r\n  }\r\n\r\n  public get has_input(): boolean {\r\n    return this._has_input;\r\n  }\r\n\r\n  public update() {\r\n    this._setAttributes();\r\n    this._setLabel();\r\n    this._setTitle();\r\n    this._setLink();\r\n    this._updateButtons();\r\n  }\r\n\r\n  public $setSchema(schema: FormSchema) {\r\n    this._schema = schema;\r\n  }\r\n\r\n  private _setAttributes() {\r\n    const link = this.column.link;\r\n    this._has_link =\r\n      link && (link.url || _.isFunction(link.action)) ? true : false;\r\n    this._has_link_with_action = link && _.isFunction(link.action);\r\n    this._has_link_with_url = link && !_.isFunction(link.action);\r\n    this._has_buttons = this.buttons && this.buttons.length > 0;\r\n    this._has_input = this._input ? true : false;\r\n  }\r\n\r\n  private _setButtons() {\r\n    let buttons: Array<TableButton> = [];\r\n    if (this.column.buttons) {\r\n      buttons = this.column.buttons.map(button => {\r\n        return new TableButton(button, this, this.row);\r\n      });\r\n    }\r\n    this._buttons = buttons;\r\n  }\r\n\r\n  private _updateButtons() {\r\n    if (this._buttons) {\r\n      this._buttons.forEach(button => button.update());\r\n    }\r\n  }\r\n\r\n  private _setInput() {\r\n    let input: TableColumnInputData;\r\n    if (this.column.input) {\r\n      input = _.cloneDeep(this.column.input);\r\n      if (input) {\r\n        this._setLabel();\r\n        input.key = this.column.accessor;\r\n        if (this.row_data.id) {\r\n          input.key += `-${this.row_data.id}`;\r\n        } else {\r\n          input.key += `-${this.row.index}`;\r\n        }\r\n        const events = this.column.input.events || {};\r\n        if (!_.isEmpty(events)) {\r\n          _.forEach(_.clone(events), (fn, key) => {\r\n            if (\r\n              _.includes([\"onInit\", \"onChange\", \"onKeyup\"], key) ||\r\n              !_.isFunction(fn)\r\n            ) {\r\n              return;\r\n            }\r\n            events[key] = event => {\r\n              event.table_row = this.row;\r\n              event.table_item = this;\r\n              event.data = this.row_data;\r\n              fn(event);\r\n            };\r\n          });\r\n        }\r\n        input.events = _.merge({}, events, {\r\n          onInit: event => this._onInputInit(event, events.onInit),\r\n          onChange: event => this._onInputChange(event, events.onChange)\r\n        });\r\n        input.value = this._label;\r\n      }\r\n    }\r\n    this._input = input;\r\n  }\r\n\r\n  private _setLabel() {\r\n    if (_.isFunction(this.column.format)) {\r\n      this._label = this.column.format(this.row_data);\r\n    } else {\r\n      const label = _.at(this.row_data, this.column.accessor)[0];\r\n      this._label = label ? label.toString() : null;\r\n    }\r\n  }\r\n\r\n  private _setTitle() {\r\n    this._title = _.isFunction(this.column.title)\r\n      ? (<TableColumnFormatter>this.column.title)(this.row_data)\r\n      : this.html\r\n      ? this.label.replace(/<(?:.|\\n)*?>/gm, \"\")\r\n      : this.label;\r\n  }\r\n\r\n  private _setLink() {\r\n    if (!this._has_link) {\r\n      this.link = null;\r\n      return;\r\n    } else {\r\n      const link = this.column.link;\r\n      if (link.action) {\r\n        const action = (event: MouseEvent) => {\r\n          event.preventDefault();\r\n          link.action(this.row_data);\r\n        };\r\n        this.link = {\r\n          action: action\r\n        };\r\n      } else {\r\n        this.link = {\r\n          url: _.isFunction(link.url)\r\n            ? (<any>link.url)(this.row_data)\r\n            : link.url,\r\n          target: link.target\r\n        };\r\n      }\r\n    }\r\n  }\r\n\r\n  private _onInputInit(\r\n    event: TableColumnInputSchemaEvent,\r\n    callback_event: FormSchemaEventFunction<TableColumnInputSchemaEvent>\r\n  ) {\r\n    if (_.isFunction(callback_event)) {\r\n      event.table_row = this.row;\r\n      event.table_item = this;\r\n      event.data = this.row_data;\r\n      if (_.isFunction(callback_event)) {\r\n        callback_event(event);\r\n      }\r\n    }\r\n  }\r\n\r\n  private _onInputChange(\r\n    event: TableColumnInputSchemaEvent,\r\n    callback_event: FormSchemaEventFunction<TableColumnInputSchemaEvent>\r\n  ) {\r\n    this._input.value = event.schema.value;\r\n    _.set(this.row_data, this.column.accessor, event.schema.value);\r\n    if (_.isFunction(callback_event)) {\r\n      event.table_row = this.row;\r\n      event.table_item = this;\r\n      event.data = this.row_data;\r\n      if (_.isFunction(callback_event)) {\r\n        callback_event(event);\r\n      }\r\n    }\r\n    this.row.update();\r\n  }\r\n}\r\n"]}