@michalrakus/x-react-web-lib 1.7.0 → 1.7.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -147,7 +147,7 @@ var XFormBase = /** @class */ (function (_super) {
147
147
  return __generator(this, function (_a) {
148
148
  switch (_a.label) {
149
149
  case 0:
150
- console.log("volany XFormBase.componentDidMount()");
150
+ //console.log("volany XFormBase.componentDidMount()");
151
151
  // kontrola (musi byt tu, v konstruktore este property nie je nastavena)
152
152
  if (this.entity === undefined) {
153
153
  throw "XFormBase: Property entity is not defined - use decorator @Form.";
@@ -167,8 +167,8 @@ var XFormBase = /** @class */ (function (_super) {
167
167
  _a.label = 3;
168
168
  case 3:
169
169
  this.preInitForm(object, operationType);
170
- console.log("volany XFormBase.componentDidMount() - ideme setnut object");
171
- this.setState({ object: object }, function () { return console.log("volany XFormBase.componentDidMount() - callback setState"); });
170
+ //console.log("volany XFormBase.componentDidMount() - ideme setnut object");
171
+ this.setState({ object: object } /*, () => console.log("volany XFormBase.componentDidMount() - callback setState")*/);
172
172
  return [2 /*return*/];
173
173
  }
174
174
  });
@@ -261,8 +261,8 @@ var XFormDataTable2 = /** @class */ (function (_super) {
261
261
  return filterMatchMode;
262
262
  };
263
263
  XFormDataTable2.prototype.onSelectionChange = function (event) {
264
- console.log("zavolany onSelectionChange");
265
- console.log(event.value);
264
+ //console.log("zavolany onSelectionChange");
265
+ //console.log(event.value);
266
266
  this.setState({ selectedRow: event.value });
267
267
  };
268
268
  XFormDataTable2.prototype.onDropdownOptionsMapChange = function (dropdownOptionsMap) {
@@ -1,5 +1,6 @@
1
1
  /// <reference types="react" />
2
2
  import { XFormBase } from "./XFormBase";
3
+ export declare const xSaveButtonId: string;
3
4
  export declare const XFormFooter: (props: {
4
5
  form: XFormBase;
5
6
  }) => JSX.Element;
@@ -3,13 +3,16 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
3
3
  return (mod && mod.__esModule) ? mod : { "default": mod };
4
4
  };
5
5
  Object.defineProperty(exports, "__esModule", { value: true });
6
- exports.XFormFooter = void 0;
6
+ exports.XFormFooter = exports.xSaveButtonId = void 0;
7
7
  var react_1 = __importDefault(require("react"));
8
8
  var XButton_1 = require("./XButton");
9
+ // constant to be used in method formReadOnly to identify save button
10
+ exports.xSaveButtonId = "x-save-button-id";
9
11
  // helper wrapper
10
12
  var XFormFooter = function (props) {
13
+ var readOnly = props.form.formReadOnlyBase(exports.xSaveButtonId);
11
14
  return (react_1.default.createElement("div", { className: "flex justify-content-center" },
12
- react_1.default.createElement(XButton_1.XButton, { label: "Save", onClick: props.form.onClickSave }),
15
+ react_1.default.createElement(XButton_1.XButton, { label: "Save", onClick: props.form.onClickSave, disabled: readOnly }),
13
16
  react_1.default.createElement(XButton_1.XButton, { label: "Cancel", onClick: props.form.onClickCancel })));
14
17
  };
15
18
  exports.XFormFooter = XFormFooter;
@@ -15,6 +15,7 @@ export interface XInputFileListProps {
15
15
  readOnly?: boolean;
16
16
  saveDest: "fileSystem" | "database";
17
17
  subdir?: string;
18
+ maxFileSize?: number;
18
19
  }
19
20
  export declare class XInputFileList extends Component<XInputFileListProps> {
20
21
  static defaultProps: {
@@ -28,6 +29,7 @@ export declare class XInputFileList extends Component<XInputFileListProps> {
28
29
  xFileField: string;
29
30
  constructor(props: XInputFileListProps);
30
31
  uploadHandler(event: FileUploadHandlerEvent): Promise<void>;
32
+ static sizeInMB(size: number): string;
31
33
  onDownloadFile(xFile: XFile): Promise<void>;
32
34
  onRemoveFile(fileItem: any): Promise<void>;
33
35
  render(): JSX.Element;
@@ -73,6 +73,7 @@ var XUtilsMetadata_1 = require("./XUtilsMetadata");
73
73
  var XUtils_1 = require("./XUtils");
74
74
  var XButton_1 = require("./XButton");
75
75
  var XButtonIconNarrow_1 = require("./XButtonIconNarrow");
76
+ var XUtilsConversions_1 = require("./XUtilsConversions");
76
77
  var XInputFileList = /** @class */ (function (_super) {
77
78
  __extends(XInputFileList, _super);
78
79
  function XInputFileList(props) {
@@ -108,6 +109,11 @@ var XInputFileList = /** @class */ (function (_super) {
108
109
  case 2:
109
110
  if (!!_b.done) return [3 /*break*/, 8];
110
111
  file = _b.value;
112
+ // skontrolujeme velkost - robime to tuto, lebo ked nastavime maxFileSize na komponente FileUpload, tak prilis velky subor sem do handlera ani neposle
113
+ if (this.props.maxFileSize !== undefined && file.size > this.props.maxFileSize) {
114
+ alert("Upload of file \"".concat(file.name, "\" was canceled: file size ").concat(XInputFileList.sizeInMB(file.size), " is more than maximum allowed size ").concat(XInputFileList.sizeInMB(this.props.maxFileSize), "."));
115
+ return [3 /*break*/, 7]; // ideme na dalsi subor
116
+ }
111
117
  xFile = void 0;
112
118
  _d.label = 3;
113
119
  case 3:
@@ -148,6 +154,10 @@ var XInputFileList = /** @class */ (function (_super) {
148
154
  });
149
155
  });
150
156
  };
157
+ XInputFileList.sizeInMB = function (size) {
158
+ var sizeInMB = size / (Math.pow(10, 6));
159
+ return (0, XUtilsConversions_1.numberAsUI)(sizeInMB, 2) + ' MB'; // zobrazime 2 desatinky
160
+ };
151
161
  XInputFileList.prototype.onDownloadFile = function (xFile) {
152
162
  return __awaiter(this, void 0, void 0, function () {
153
163
  var response, e_3, fileName, respBlob, url, a;
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@michalrakus/x-react-web-lib",
3
- "version": "1.7.0",
3
+ "version": "1.7.2",
4
4
  "description": "",
5
5
  "scripts": {
6
6
  "clean": "rimraf lib",